Warning
Manual intervention required
k8s the correct pod securityGroupContext needs to be specified and on plain Docker deploys the permissions of the volumes will probably have to be fixed.
New features
Updated ADFS-integration support, now Azure AD is properly supported
Allow selection of internal zaaktypen for related zaaktypen with user friendly picker (#910)
Removed the need to register internal services as external services when using CMIS adapter (#938)
More CMIS-adapter optimization
- caching of WSDLs
- use connection pooling for CMIS requests (#956)
Added support for initial superuser creation via environment variables (#952)
Bugfixes
Updated to Zaken API 1.0.3 specification, see the upstream 1.0.3 changelog.
rol_list
operation querystring parameter fixed, frombetrokkeneIdentificatie__vestiging__identificatie
tobetrokkeneIdentificatie__organisatorischeeenheid__identificatie
Fixed missing metadata in CMIS-adapter interface (#925)
Improved test isolation, reducing Heisenbugs
Improved display of catalogi without explicit name so that they're clickable in the admin (#891)
Fixed broken zaaktype export for published zaaktypen (#964)
Deployment tooling / infrastructure
- Added configuration parameter to opt-in to use
X-Forwarded-Host
headers to determine the canonical domain of a request to Open Zaak. This is particularly useful when using Istio sidecars for example. (#916) - Improved dependency management script
- Added CI check to detect improper version bumping
- Bumped version of Django Debug Toolbar to fix an SQL injection. Safe in production, as this dependency is not included in the published Docker images.
- Fixed deleting a Zaak with related documents with CMIS-adapter enabled (#951)
Documentation
- Documented advice to service providers to sign up to the OpenZaak Release Early Notice List and mailing list (#915)
- Updated maturity document (FFPC, #681)
- Improved post-install configuration documentation (#947)
- Documented RabbitMQ's need for minimum of 256MB RAM
External dependency cleanup
- Dropped nlx-url-rewriter, see manual intervention below
- Dropped drf-flex-fields, it was not used
- Upgraded Django, djangorestframework, djangorestframework-camel-case, drf-yasg & other related packages (#935)
- Replaced django-better-admin-arrayfield fork with upstream again
- Replaced deprecated node-sass (and libsass) with dart-sass (#962)
- Bumped a number of dependencies to their latest release to get security fixes. None of the vulnerabilities appeared to impact Open Zaak, but better safe than sorry.
Warning
Manual intervention required
If you're upgrading from an older version than 1.2.0 of Open Zaak and using NLX, you need to update to 1.3.5 first, and then update to the 1.4.x series.
In 1.2.0, the configuration of external API's was reworked, migrating from the nlx-url-rewriter package to zgw-consumers. In 1.4.0, the nlx-url-rewriter package is dropped and no longer present.
1.3.5 is another release focused on bugfixes, performance and quality of life.
Bugfixes
Bumped
cryptography
andhttplib2
versions, which had some vulnerabilities (#856, #858, #859)Fixed an issue where documents were considered external when the CMIS-adapter is enabled (#820)
Various fixes focused on improving the CMIS-adapter performance (#900, #881, #895)
Bumped a number of dependencies to stable versions
Dropped DB constraint preventing versioning of informatieobjecttypen to work as intended (#863)
Fixed a crash when creating zaaktypen because of too-optimistic input validation (#850)
Fixed a crash when using invalid query parameters when filtering the list of zaaktypen/ informatieobjecttypen/besluittypen and related objects (#870)
Mutations in the catalogi admin environment now send notifications similarly to how the same operations in the API would do (#805)
Fixed filtering
ZaakInformatieObjecten
with CMIS enabled (#820)Fixed a crash when updating
Zaaktype.gerelateerdeZaken
(#851)Fixed incorrect and unexpected Autorisaties API behaviour for applications that are not "ready yet"
- applications must have either
heeftAlleAutorisaties
set or haveautorisaties
related to them (cfr. the standard) - applications not satisfying this requirement are not visible in the API (for read, write or delete)
- applications not satisfying this requirement are flagged in the admin interface and can be filtered
- when (zaak)typen are deleted, they're related autorisaties are too. If this leads to an application without autorisaties, the application is also deleted as it is no longer valid
- applications must have either
Fixed serving files for download when using CMIS-adapter and dealing with
BytesIO
streams in general (#902)
Deployment tooling / infrastructure
- Uses new version of deployment tooling with podman support (alternative to Docker runtime)
- Fixed and improved configuration of the Notifications service in the
setup_configuration
management command. Generated credentials are now written tostdout
and need to be used to configure Open Notificaties (or alternatives). - Bumped to newer versions of Django and Jinja2, including bug- and security fixes (#906, #907)
Documentation
- Link to the mailing list added to the security documentation
- On the Github issue template you're now asked to specify which Open Zaak version you're using
- Updated Standard for Public Code checklist w/r to security procedures (#864)
- Documented the project dependencies with versions < 1.0 (#681)
- Updated the feature request template on Github
- Documented which security-related headers are set by the application and which on webserver level.
- Updated Standard for Public Code checklist w/r to using Open Standards (#679)
New features
- Added support for self-signed certificates, especially where Open Zaak consumes services hosted with self-signed (root) certificates. See the documentation on readthedocs for full details and how to use this. (#809)
Cleanup
- Removed unused and undocumented newrelic application performance monitoring integration
- Updated to pip-tools 6 to pin/freeze dependency trees
A regular bugfix release.
Bugfixes
Fixed incorrect protocol used in notification payloads (#802)
Improved test suite determinism (#813, #798)
Fixed deleting documents when CMIS is enabled (#822)
Fixed Open Zaak compatibility with an external Documenten API
- Fixed error logging interpolation (#817)
- Fixed transaction management (#819)
- Fixed some django-loose-fk bugs
- Fixed deleting the remote ObjectInformatieObject on cascading zaak-destroy operations
- Fixed
Besluit.zaak
nullable behaviour - now an empty string is returned correctly
CMIS adapter fixes
- Implemented Documenten API URL shortening for use with select CMIS DMSs
- Fixed an oversight where
Gebruiksrechten
were not updated in the CMIS repository
Removed notifications for ZIO (partial) update & destroy - the standard only prescribes
create
notifications.Fixed running the test suite with the
--keepdb
optionBumped a number of (frontend) dependencies following Github security notices
Throw a command error when testing the notifications sending before correctly configuring the Notifications API (#667)
Fixed Open-Zaak not accepting
application/problem+json
response media type in content negotation (#577)Fixed leaving "producten en diensten" blank in Zaaktype admin (#806)
Increased the
DATA_UPLOAD_MAX_NUMBER_FIELDS
Django setting (#807)Fixed zaaktype/informatieobjecttype/besluittype publish action API documentation (#578)
Fixed the handling of the
SUBPATH
environment variable (#741)
Deployment tooling / infrastructure
Bumped to version 0.11.1 of the deployment tooling, which added support for:
- flexibility in certificate configuration
- enabled http2 in load balancer
- improved support for additional environment variables
- Red Hat and CentOS
Fixed pushing the
latest
docker image tag to Docker Hub for builds on the master branchOpen Zaak now provides Helm charts to deploy Open Zaak & Open Notificaties on Haven compliant clusters (thanks to @bartjkdp)
Documentation
- Fixed CI badges in READMEs
- Fixed example recipe for client application developers (#815)
- Documented the security issue process (#831)
- Added Contezza as service provider
- Removed (outdated) documentation duplication in README (#717)
- Removed
raven test
Sentry test command from documentation - we no longer use Raven but have switched tosentry_sdk
instead (#721) - Documented the need to register notification channels (#666)
- Improved & updated the API schema documentation
- Link to run-time behaviour documentation for each API component (#753)
New features
- Added bulk publishing options to the admin for zaaktype, informatieobjecttype and besluittype (#838)
Security and bugfix release
Warning
this release includes a security fix for CVE-2020-26251, where Open Zaak had a possible vulnerable CORS configuration. It is advised to update as soon as possible. The severity is considered low, since we haven't been able to actually exploit this due to mitigating additional security configuration in other aspects.
The bugfixes are mostly CMIS-adapter related.
Bugfixes
- The Cross-Origin Resource Sharing configuration is now safe by default - no CORS is allowed. Environment configuration options are made available to make CORS possible to varying degrees, which are all opt-in. This fixes CVE-2020-26251.
- Fixed duplicate
ObjectInformatieObject
instances being created with CMIS enabled (#778) - Fixed stale CMIS queryset cache preventing correct chained filtering (#782)
- Fixed some links being opened in new window/tab without
norel
ornoreferrer
set in therel
attribute - Fixed multiple
EnkelvoudigInformatieobject
instances having the samebronorganisatie
andidentificatie
(#768). If you're not using the CMIS-adapter, see the manual intervention required below. - Fixed a bug retrieving
ObjectInformatieObject
collection in the Documenten API when CMIS is enabled. This may also have affected theGebruiksrechten
resource. (#791)
Documentation
- Improved documentation for CMIS services configuration
- Fixed a typo in the Governance document
- Documented environment variable to disable TLS certificate validation. This should never be used in production, instead the certificate setup should be fixed.
Other changes
- Enabled CMIS-adapter logging in DEBUG mode
- Migrated CI from Travis CI to Github Actions
- Explicitly test PostgreSQL versions 10, 11 and 12 (#716)
- Optimized CI build to re-use Docker image artifacts from previous jobs
- Replaced postman.io mocks subscription with nginx container (#790)
- Avoid some unnecessary queries when CMIS is enabled
- Implemented a (likely) fix to non-deterministic behaviour in the test suite (#798)
Warning
Manual intervention required.
There is a chance that documents have been created in the Documents API with
duplicate (bronorganisatie, identificatie)
combinations.
We've provided a management command to check and fix these occurrences.
Run python src/manage.py detect_duplicate_eio --help
in an Open Zaak container
to get the command line options. By default, the command is interactive:
.. tabs:: .. group-tab:: single-server .. code-block:: bash $ docker exec openzaak-0 src/manage.py detect_duplicate_eio Checking 30 records ... Found no duplicate records. .. group-tab:: Kubernetes .. code-block:: bash $ kubectl get pods NAME READY STATUS RESTARTS AGE cache-79455b996-jxk9r 1/1 Running 0 2d9h nginx-8579d9dfbd-gdtbf 1/1 Running 0 2d9h nginx-8579d9dfbd-wz6wn 1/1 Running 0 2d9h openzaak-7b696c8fd5-hchbq 1/1 Running 0 2d9h openzaak-7b696c8fd5-kz2pb 1/1 Running 0 2d9h $ kubectl exec openzaak-7b696c8fd5-hchbq -- src/manage.py detect_duplicate_eio Checking 30 records ... Found no duplicate records.
Open Zaak 1.3.2 fixes a number of issues discovered in 1.3.1. Note that there are two manual interventions listed below these patch notes. Please read them before updating.
Changes
- Added messages in the admin if the selectielijst configuration is invalid (#698)
- Applied a unique constraint on user e-mail address (if provided) (#589) - see manual intervention warning below.
- Upgraded to a newer version of
zgw-consumers
, dropping the extra configuration field for services (#710) - Implemented the upstream API bugfix, adding some zaken list query filters (VNG-Realisatie/gemma-zaken#1686, #732)
- Added Github's code-scanning to detect vulnerable code patterns
- Updated frontend dependencies to secure versions
- Updated backend and deployment dependencies to secure versions (notably
cryptography
) (#755, #756) - [CMIS-adapter] Changed
EnkelvoudigInformatieobject.identificatie
generation. CMIS query does not (always) supportLIKE
queries, nor does it support aggregation queries (#762)
Bugfixes
- Fixed #711 -- changed
Rol.omschrijving
max_length from 20 -> 100 - Fixed input validation of binary document content (when the client forgets to base64 encode it) (#608)
- Fixed primary keys being localized in admin URLs (#587)
- Fixed a crash when trying to download non-existant informatieobjecten (#584)
- Corrected validation of
Eigenschap.lengte
. API and admin are now consistent, and decimals are now correctly interpreted (comma instead of dot) (#685) - Fixed the
register_kanaal
management command auth-issue (#738) - Fixed a bug where deleted zaaktypen had dangling
Autorisatie
records (#713) - see manual intervention warning below. - Updated to CMIS adapter 1.1.1 to fix some bugs (#760)
Documentation
- Update
Governance.md
after a number of steering group meetings - Clarified that Ansible Galaxy roles and collections need to be installed separately
- Added a (technical) roadmap draft
- Drafted code style/code architecture principles
- Fixed a mix-up between authorizations/authentications API (#722)
- Docker image badge now points to Docker Hub
- Removed mention of Klantinteractie-API's - it's unclear what's being done with these API's
- Started documentation entries for developers of client/consumer applications
Warning
Manual intervention required.
E-mail addresses are used for logging in to the admin environment, which had no unique constraint. This is corrected in a database migration, which will crash if there are users with duplicate e-mail addresses. You should fix the duplicate addresses BEFORE updating.
Warning
Manual intervention required.
Some cleanup is required because of a synchronization bug. You need to run
the following sync_autorisaties
management command.
.. tabs:: .. group-tab:: single-server .. code-block:: bash docker exec openzaak-0 src/manage.py sync_autorisaties .. group-tab:: Kubernetes .. code-block:: bash $ kubectl get pods NAME READY STATUS RESTARTS AGE cache-79455b996-jxk9r 1/1 Running 0 2d9h nginx-8579d9dfbd-gdtbf 1/1 Running 0 2d9h nginx-8579d9dfbd-wz6wn 1/1 Running 0 2d9h openzaak-7b696c8fd5-hchbq 1/1 Running 0 2d9h openzaak-7b696c8fd5-kz2pb 1/1 Running 0 2d9h $ kubectl exec openzaak-7b696c8fd5-hchbq -- src/manage.py sync_autorisaties
Changes
- Updated CMIS-adapter to 1.1 featuring support CMIS 1.0 Webservice binding and various new configuration options.
- Added support for configurable Selectielijst years to retrieve specific years from the Selectielijst API (#689)
- Prevent error monitoring from logging special personal data (#696)
Bugfixes
- Accept comma separated in
EigenschapSpecificatie.waardenverzameling
(#686)
Documentation
- Added SPDX license headers and check.
- Added Docker storage hint to make sure users run the Docker containers on volumes with enough disk space.
Version 1.3.0 of Open Zaak introduces some new features, quality of life changes and fixes bugs discovered in 1.2.0.
There is no 1.2.1 bugfix release. Upgrading from 1.2.0 to 1.3.0 requires no manual intervention.
What's new?
Added experimental support for CMIS backends for the Documenten API, as an alternative to Open Zaak database + filesystem. See the documentation for more details.
Added a feature flag to allow unpublished
*Typen
to be used. This should only be used in Proof-of-concept environments, as it violates the VNG standard.Added a number of CLI commands for initial Open Zaak setup following installation. See the documentation for more details.
Implemented extra
zaak_list
filters, added in 1.0.2 of the Zaken API standardmaxVertrouwelijkheidaanduiding
betrokkene
betrokkeneType
omschrijvingGeneriek
natuurlijk persoon BSN
medewerker identificatie
Bugfixes and general QOL changes
- Positioned the Foundation for Public Code and checked Open Zaak against their standard/guidelines
- The documentation now includes a Public Code checklist
- Added Code of Conduct
- Added Governance documentation
- Fixed running tests with
--keepdb
option - Fixed the admin form for
Zaaktype-Informatieobjecttype
relation - Fixed importing a
Zaaktype-Informatieobjecttype
with aStatustype
relation - Improved documentation for deploying on Kubernetes
- Added English version of README
- Fixed configuration form for external services when the NLX directory has not been configured (yet)
- Fixed
BesluitType
create in the admin (#594) - Added and documented performance-profiling tooling for Open Zaak developers
- Fixed performance regression in
zaak_list
endpoint operation ⚡ - Fixed a crash on malformed UUIDs in endpoint URLs that expect a valid UUID 4 pattern
- Added the environment configuration reference to the published documentation
- Refactored notifications/selectielijst configuration to use the external services configuration
- Fixed
EigenschapSpecificatie.waardenverzameling
default value (empty list) (#611) - Fixed missing validation on (zaaktype, eigenschapnaam) uniqueness
- Added Slack invite link
- Relaxed Resultaat.afleidingswijze validation in the admin too (see also
6e38b865c
) - Improved "Contributing" section
New feature release and a set of bugfixes included.
Features
- Update admin layout version
- #507 -- use the original filename when downloading a document from the admin
- Reworked configuration of external APIs
- Added option to specify your NLX outway location and network
- Added the ability to enable/disable APIs offered by Open Zaak
- Added the option to configure external APIs, optionally selecting services from the NLX network.
- Added support for custom OAS urls. Note that you need to add them manually
in
zgw_consumers.Service
for existing APIs (you can do it in the admin).
Bugfixes
- Bumped a number of libraries to their latest security releases
- #511 -- fix saving of resultaattype if bewaartermijn is null
- #495 -- use correct page titles for api schemas per component
- #318 -- Fixed (BesluitType)Admin M2M relations so that they show content from the same catalogus only
- Fixed Document inhoud base64 validation
- Enabled pre-filling the informatieobjecttype in zaaktype-informatieobjecttype admin
- #532 -- fixed issue with
Resultaattype.omschrijving_generiek
not updating - #551 -- ensure client credentials are deleted when an
Applicatie
is deleted in in the admin - #543 -- fix error when trying to create a document in the admin
- Fixed creating a Zaaktype with partial
referentieProces
gegevensgroep - #553 -- made Eigenschap.specificatie required in admin
- #557 -- fix handling of
brondatumArchiefProcedure: null
- #558 -- fixed
ZaakBesluit
DELETE
calls - #556 -- fixed admin crash for resultaattype when the related zaaktype does not have a selectielijst procestype set
- #559 -- fixed deploying Open Zaak on a subpath (as opposed to on its own (sub)domain)
- #554 -- fixed admin crash when related informatieobjecttypen/besluiten are not available for a given zaak.
- #562 -- fixed nested
Eigenschap.specificatie
being ignored
Documentation
- Documentation minimal version of required development tooling
- #299 -- Fixed notification documentation generation
- Updated PR template
- #534 -- updated documentation links in the API specs
Bugfix release w/r to deployment and ADFS
- Added option to disable group sync in ADFS login. If the ADFS provider does not provide the group claim, this would otherwise reset the user groups you carefully configured.
- Updated single-server deployment to make sure the web-server can read and serve uploaded files through the Documenten API.
New feature release. Note that this is not yet an implementation of the 1.1.x API specs!
- Included playbooks for NLX deployment
- Added communication channels to the docs (i.e. - how to find/contact us!)
- Added ADFS support (i.e. you can now log in to the admin with ADFS)
- Fixed some deployment tooling
Improved support for integration with other APIs, most notably BAG/BRT APIs from the kadaster (see https://pdok.nl). This increases the usability of ZaakObject relations.
- Added api-test.nl badge - proves that Open Zaak is compliant with the API's voor zaakgericht werken standard
- Added small documentation improvements
- Updated notification setup instructions
- Added support for API authentication with a simple API key (such as BAG or BRT)
- Added support for URL transformation so that data-fetching is forced over NLX
Fixed infrastructure on single-server where Open Zaak and Open Notificaties run on the same machine.
Bugfixes and usability improvements
- Improve selectielijst-resultaten display in ResultaatType admin (#480)
- Improved production description
- Fixed file permissions for installation on single-server (#481)
Bugfixes from initial release
- Added version information to Docker image
- Added better admin validation in various places [prevent crashes]
- Updated some documentation
- Fixed Besluiten API spec defects
- Fixed rendering the admin detail pages for read-only resources
- Fixed the cache for resultaattypeomschrijvinggeneriek
- Updated to latest Django security release
- Improved help-text for read-only fields
- Fixed CI
🎉 First release of Open Zaak.
Features:
- Zaken API implementation
- Documenten API implementation
- Catalogi API implementation
- Besluiten API implementation
- Autorisaties API implementation
- Support for external APIs
- Admin interface to manage Catalogi
- Admin interface to manage Applicaties and Autorisaties
- Admin interface to view data created via the APIs
- NLX ready (can be used with NLX)
- Documentation on https://open-zaak.readthedocs.io/
- Deployable on Kubernetes, single server and as VMware appliance
- Automated test suite
- Automated deployment