Skip to content

Latest commit

 

History

History
295 lines (189 loc) · 9.38 KB

CHANGELOG.rst

File metadata and controls

295 lines (189 loc) · 9.38 KB

Change history

2.4.x (TBD)

New features

  • made user emails unique to prevent two users logging in with the same email, causing an error

Warning

User email addresses will now be unique on a database level. The database migration will fail if there are already two or more users with the same email address. You must ensure this is not the case before upgrading.

2.4.0 (2024-07-05)

New features

  • added superuser permissions to API (#369)
  • added setup_configuration management command which can configure API with environment variables (#368)
  • added Record.data as a search filter in the Admin (#381)
  • displayed Objecttype.uuid in the Objecttype and Object admin pages (#315)

Bugfixes and QOL

  • supported correctionFor = null in POST/PUT requests (#268)
  • added tests for additionalProperties keyword in JSON schema (#330)
  • fixed creating objects with empty data (#371)
  • fixed displaying the Token admin page if Object Types API is unavailable (#373)
  • fixed styling of OIDC login page (#392)
  • fixed styling of the help text icon in the Admin (#421)
  • updated demo data used in quick start process (#398, #400)

Project maintance

  • updated Python to 3.11 (#379)
  • added open-api-framework dependency (#358)
  • refactored settings using open-api-framework (#413)
  • added logging of outgoind requests (#344)
  • added Trivy into the CI as an docker image scaner (#402)
  • added GitHub issue templates (#389)
  • merged quick start and regular docker compose files into one (#408)
  • changed caching backend from LocMem to Redis
  • Elastic APM service name can now be configured with ELASTIC_APM_SERVICE_NAME envvar

** Documentation**

  • added security policy (#390)
  • updated Quick start documentation (#348)

Warning

Because the caching backend was changed to Redis, existing deployments must add a Redis container or Redis instance (see Installation > Environment configuration reference in the documentation on how to configure) the connection with Redis

Warning

The service name for Elastic APM is now configurable via the ELASTIC_APM_SERVICE_NAME environment variable. The default value changed from Objects API to objects - <ENVIRONMENT>

2.3.2 (2024-05-03)

Bugfix release

This release addresses a security weakness.

  • [GHSA-3wcp-29hm-g82c] replaced PK for Token model.

2.3.1 (2024-03-22)

Bugfixes and QOL

  • fixed celery docker container (#376)
  • configured caches with redis (#377)
  • added flower to monitor celery tasks (#378)

Note

Flower is added to the docker, so now flower container could be deployed for monitoring purposes.

2.3.0 (2024-03-15)

  • Updated to Django 4.2.

Warning

Celery (and thus Redis) is now a required dependency.

Two-factor authentication is enabled by default. The DISABLE_2FA environment variable can be used to disable it if needed.

2.2.1 (2024-03-02)

Bugfixes and QOL

  • fixes OIDC config page by adding django_jsonform to INSTALLED_APPS (#350)
  • added USE_X_FORWARDED_HOST environment variable (#353)
  • added email environment variables (#366)

2.2.0 (2024-01-30)

Component changes

  • Bugfixes and QOL
  • fixed Permission form in the Admin (#309)
  • added ENVIRONMENT environment variable (#310)
  • updated python from 3.7 to 3.10 (#357)
  • bumped Django to 3.2 (#357)
  • bumped python libraries including mozilla-django-oidc, mozilla-django-oidc-db, zgw-consumers, uwsgi (#357, #338)
  • removed hijack library (#357)
  • updated base for docker image from Debian 10 to Debian 12 (#357)

API 2.2.0 changes

  • New features
    • added typeVersion query parameter (#306)
    • supported JSON merge when doing a partial update on data attribute (#351)
  • Bugfixes
    • added typeVersion query parameter (#306)
    • fixed date-time parsing in API filtering (#308)

Warning

Change in deployment is required. /media/ volume should be configured to share OAS files.

Explanation:

The new version of zgw_consumers library adds oas_file filed to Service model. This field saves OAS file into MEDIA_ROOT folder. The deployment now should have a volume for it. Please look at the example in docker-compose.yml

2.1.1 (2022-06-24)

  • Bugfixes and QOL
    • fixed updating objects with earlier startAt attribute (#282)
    • removed boostrap from the landing page (#294)
    • bumped to newer versions of pyjwt (#299)
    • fixed Elastic APM configuration (#289)

2.1.0 (2022-05-17)

Component changes

  • Bugfixes and QOL
    • managed 2FA authentication using environment variables (#250)
    • integrated with OpenID Connect (#246)
    • create initial superuser with environment variables (#254)
    • removed non-actual results when filtering on data_attr query param (#260)
    • supported objecttypes with json schemas without properties in the Objects Admin (#273)
    • bumped to newer versions of mozilla-django-oidc-db (#264), django, lxml, babel, waitress(#293), pillow (#285) and npm packages (#279)
    • remove swagger2openapi from dependencies (#292)
  • Deployment tooling / infrastructure
    • use ansible collections from Ansible Galaxy (#241)

API 1.3.0 changes

  • New features
    • supported numeric values for icontains query param (#262)
    • supported validation on hasGeometry field in the Objecttypes API (#263)

API 2.1.0 changes

  • New features
    • supported numeric values for icontains query param (#262)
    • supported validation on hasGeometry field in the Objecttypes API (#263)
    • supported ordering query param which allows to sort the results (#274)

2.0.0 (2021-09-22)

Component changes

  • Supports API 2.0.0 and API 1.2.0

API 1.2.0 changes

  • New features
    • supported having several API versions at the same time (#195)
    • enabled selecting set of fields for every object type version which are allowed to display in the API (#79)
    • sent notifications when the objects are changed in the API using Notificaties API. Sending notifications is an optional feature that can be disabled (#221, #237)
    • added an endpoint to show which API permissions the client has (#81)
    • made geometry field non-required for the search endpoint (#236)
    • supported dates in the data_attrs= query param (#214)
    • supported icontains operator in the data_attrs= query param, which allows case-insensitive search on the part of the string (#235)
    • added two-factor authentication for the Objects Admin (#232)
  • Bugfixes and QOL
    • bumped to newer versions of django, django-debug-toolbar, urllib3, sqlparse (#225, #243)
    • added superuser for quick-start (#203)
    • tested the performance of the API per version (#219)
  • Documentation
    • marked read-only fields as non-required in OAS (#210)
    • described how to configure authorization with the set of allowed fields in the admin (#79)
    • documented how to configure notifications (#245)

API 2.0.0 changes

  • Breaking features
    • paginated API responses (#148)
  • New features
    • supported data_icontains query param which requires Postgres 12+ (#235)
  • Deployment tooling / infrastructure
    • updated Postgres version in the Objects API Helm chart (#242)

1.1.1 (2021-06-22)

Bugfixes and QOL

  • Fixed OAS generation: remove unrelated error response bodies and headers, swap the notion of material and formal history (#197, #201)
  • Tested the implementation of the material and formal history (#168)

Documentation

  • Documented how to use the Objecttypes admin and the Objects admin (#60)

1.1.0 (2021-04-21)

New features

  • Decoupled authentication tokens from users in the admin (#115)
  • Added additional fields for tokens to store extra information (#155)
  • Adhered the Objecttypes API to API principles API-09, API-18, API-19, API-51 defined in API Design Rules of Nederlandse API Strategie (#46, #174)
  • Supported fields= query param and display only selected fields in the API response (#174)
  • Added length validation fo url fields (#154)
  • Improved the Admin UI:
    • Include uuid field to the "object" page (#156)
    • Make object_type field immutable (#150)
    • Add filtering on object_type to the "object" page (#157)

Bugfixes and QOL

  • Improved performance with database query optimization (#136) ⚡
  • Bumped to newer versions of Django, Jinja2, Pillow, PyYAML, pip-tools including security fixes (#183, #182, #184, #176, #193)
  • Fixed a crash when creating an object without a version in the admin (#146)

Deployment tooling / infrastructure

  • Added Helm chart to deploy the Objects API on Kubernetes (#180)
  • Added Ansible configuration to deploy the Objects API on single server (#59)

Documentation

  • Added a tutorial how to use the Objects API and the Objecttypes API with examples (#61)
  • Documented how to configure authentication and authorization for the Objects API and the Objecttypes API (#179)
  • Documented deployment of the Objects API and the Objecttypes API on single server and Kubernetes (#59)
  • Translated descriptions for Content-Crs and Accept-Crs headers from Dutch to English in the OAS (#106)
  • Added information about validation to the OAS (#106)

1.0.0 (2021-01-13)

🎉 First release of Objects API.