Unreleased (latest)
- Nothing yet.
2.5.0 (2024-12-18)
- Drop Python 3.8 support.
- Pin
watchdog>=5
to employ typing fixes. - Pin
requests>=2.32.3
to fix security vulnerability. - Pin
setuptools>=70.0.0
to fix security vulnerability. - Do not treat handlers actions that have not been implemented as a dispatch failure.
2.4.0 (2024-07-09)
- Pin
crim-ca/pyramid_celery==5.0.0a
fork (crim-ca/pyramid_celery@5.0.0a) to support Python 3.12 and other package cross-dependency improvements (relates to sontek/pyramid_celery#102). - Pin
threddsclient==0.4.6
to support Python 3.12 (relates to bird-house/threddsclient#17). - Pin
urllib3>=2.2.2
to address CVE-2024-37891. - Pin
gunicorn>=22
to address CVE-2024-1135. - Pin Docker base to
python:3.12.3-alpine
for various security fixes. - Update
magpie==4.0.0
for corresponding fixes (see Changes: magpie @ 4.0.0). - Pin
watchdog>=4
for latest typing additions.
2.3.0 (2023-11-30)
- Add optional key
field
andregex
to be used in thesync_permissions
section found in the config. This allows to sync permissions using a field other thanresource_full_name
when creating thename:type
from the segmentex.: /field1::type1/field2::type2
. Adds support to useresource_display_name
. - The
regex
is used to extract the desired information from thenametype_path
. It should be used to do an exact match. This new search overrides the default way of matching each segment with thenametype_path
. In the case where aregex
is found in the target segment, the data will be formed using the sameresource_type
for every match in the same segment. Similarly, as using- name: "**"
in the config to match multiple segment, it is possible to use aregex
to match multiple resources in the same segment withregex: '(?<=:).*\/?(?=\/)'
2.2.0 (2023-11-16)
- The
FileSystem
handler now creates the WPS outputs data folder if it doesn't exist so that monitoring is setup properly. - User permissions are set explicitly after creating his datastore folder to make sure the user can create and modify files in it.
2.1.0 (2023-09-18)
- Add monitoring to the
FileSystem
handler to watch WPS outputs data. - Synchronize both public and user WPS outputs data to the workspace folder with hardlinks for user access.
- Add resync endpoint
/handlers/{handler_name}/resync
to trigger a handler's resync operations. Only theFileSystem
handler is implemented for now, regenerating hardlinks associated to WPS outputs public data.
2.0.0 (2023-07-21)
- Update Docker image to use
python:3.10-alpine
instead ofpython:3.7-alpine
for latest security updates and performance improvements. - Update GitHub CI tests to include Python 3.9, 3.10 and 3.11, and use 3.10 by default for additional checks.
- Update multiple package dependencies flagged by PyUp as well as any relevant code changes to support updated packages.
- Move
ports
sections of exampledocker/docker-compose.*.yml
files to thedev
variant to reflect a realisticprod
vsdev
configuration scheme and allowports
overrides without merge of lists to avoid conflicts. - Add typing requirements and
check-types[-only]
targets toMakefile
. To avoid breaking the CI on any minor typing issue, leave it asallow_failure: true
for the moment. Further typing conversions and fixes can be applied gradually on a best-effort basis. - Covert type comments to type annotations.
- Fix and improve
Geoserver
typings. - Drop Python 3.7 that reached end-of-life.
1.2.0 (2023-07-10)
- Add permission synchronization between Magpie's permissions and Geoserver files permissions.
- Fix bug where the monitors saved on the database and the internal monitors dictionary from the
Monitoring
class would be desynchronized, not always having the expected monitors, or having monitors that were not started properly. - Fix failing permissions synchronizer by adding
service_type
to the Magpie webhooks and ignoring permissions from resources not defined in the config (relates to Ouranosinc/Magpie#582).
1.1.1 (2023-03-24)
- Return HTTP 424 (Failed Dependency) when the
celery
worker version cannot be retrieved onGET /version
. Also, provide better error logs and detail messages in case of error to help debug the cause of the problem.
- Fix incorrect typings and typographic errors.
1.1.0 (2023-03-14)
- Enforce specification of
COWBIRD_CONFIG_PATH
environment variable orcowbird.config_path
INI configuration to provide thecowbird.yml
file with definitions of services and permissions to manage, and raise directly at application startup otherwise. Without those definitions, Cowbird has no reason to exist. - Add logging details when
handlers
are processed, succeed and failed their operation to provide insights about Cowbird integration with other services. - Add
COWBIRD_REQUEST_TIMEOUT
environment variable andcowbird.request_timeout
INI configuration parameters for specifying the connection timeout (default:5s
) to be applied when sending requests. - Add missing
COWBIRD_SSL_VERIFY
configuration setting in documentation. - Review
FileSystem
's handler for user workspace creation/deletion and to ensure compatibility with birdhouse-deploy's setup.
- Add
timeout
to all request calls (pylint
recommended fix to avoid infinite lock). - Minor typing fixes.
1.0.0 (2022-08-18)
- Renamed Cowbird
services
term tohandlers
, to avoid confusion with Magpie services.
n/a
0.5.0 (2022-08-15)
- Add synchronization of Magpie permissions between different Magpie services, when receiving incoming webhooks.
- Update config's
services
sections undersync_permissions
to use actual Magpie service names instead of Cowbird handler names (relates to #22). - Reorganize
config.example.yml
to support more sync cases, provide info on the type of each segment of a resource path and to use tokenized path. - Add schema validation when starting cowbird app.
n/a
0.4.1 (2022-03-09)
- Add an SSL verification setting.
- Add Geoserver workspace and datastore creation/removal linked to user creation/removal.
- Add automated publishing of shapefiles to Geoserver when new files are found.
- Use
pip
legacy and faster resolver as per pypa/pip#9187 (comment) since current one is endlessly failing to resolve development packages (linting tools fromcheck
targets).
- Pin
pymongo<4
to work with pinnedcelery
version.
0.4.0 (2021-08-05)
- Basic users' workspaces management for new or removed users.
- Add a Mongo database backend to store/restore monitoring state across sessions.
- Celery has now a proper result backend.
- Celery tasks are auto-discovered package-wide, no need to import them manually.
0.3.0 (2021-07-06)
- Add the RequestTask celery task for handling external services requests.
- Add a docker image for the celery worker
n/a
0.2.0 (2021-05-12)
- Preliminary design which includes:
- Webhook API
- Services interface
- Permissions synchronizer
- File system monitoring
n/a
0.1.0 (2021-02-18)
- First structured release which includes:
- CI/CD utilities
- Minimal testing of utils
- Documentation of generic details (WebApp, CLI, OpenAPI, configs, etc.)
- Metadata of the package
- Minimal
/services
API route with dummyService
- Corresponding
cowbird services list
CLI command
n/a