All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- overhauled Mongo view update logic to avoid requesting
dropCollection
privilege action
- updated service dependencies
- upgrade NodeJS version in Docker image to v22.12.0
- added step for generating SBOM (Software Bill of Materials)
- added step for scanning the built image
- improve how query parser discriminates update operator modifiers (e.g.
$each
) from actual record value - introduce support for
$eq
operator also for integer fields (the ones defined in nested array and objects)
- introduce support for Array of ObjectIds at document root level
- introduce support for
$size
operator in_q
for fields of typearray
- enable bom stripping when importing CSV files
- change CSV escape character to align it with CSV field quote character, as recommended by RFC 4180
- extend to
/bulk
endpoint the requests preprocessing performed on exposed routes of View with lookup feature enabled
- new optional environment variable
CRYPT_SHARED_LIB_PATH
that specify wherecrypt_shared
MongoDB dynamic library is located. This variable is already set within the Docker image and it points to the correct location, so that it is not necessary to customize it.
- replace
mongocryptd
libraries with Mongocrypt_shared
- upgrade NodeJS version in Docker image to v20.17.0
- enforce quoting all strings in CSV export to prevent issues with delimiter character
- when the service was configured to run with the (CSFLE)[https://www.mongodb.com/docs/manual/core/csfle/] feature enabled and a Mongo View was defined alongside the collections models, the service crashed at startup due to an incompatibility between Mongo Views and the auto-encryption feature.
This issue has been resolved and the service can now properly start, creating the Mongo Views even in such situation.
- bug that made compilers collide with collections having the same prefix.
- hooks and serializer compiler are not registered anymore on every
httpInterface.js
, but only once inindex.js
, to avoid multiple registers for collections; - validator compiler is still applied to each HTTP interface to avoid OOM, but it has been moved to
compilers.js
; AdditionalCaster
class does not need to compute the fields that are eitherObjectId
,Date
, orGeopoint
: in the newcastItem
method, field types are inferred with theinstanceof
keyword;- upgrade NodeJS version in Docker image to v20.14.0
- added
await
keyword when registering Fastify plugins
- fixed projection example in json schema generator
serializerCompiler
has been added to use explicitlyfastifiy-fast-json
, along withAdditionalCaster
$eq
operator can now be used also for array fields- #286:
/-/schemas
accept header defaults toapplication/json
- #326:
/schemas
and/-/schemas
endpoints now return alsorequired
property
- added
_exportOpts
query parameter forGET /export
calls
- fixed
GET /export
withcsv
format:csv
files contain all the requested fields as columns without omissions - fixed
GET /export
withexcel
format:excel
files contain all the requested fields as columns instead of containing always all the collection fields - allow running raw queries with
_q
over fields containing a digit in their name
OPEN_API_SPECIFICATION
env to choose specification used for exposing Swagger
- improve internal logic bulk
POST
andPATCH
operations
- #189 introduce support to MongoDB v7.0 and remove support to MongoDB v4.2
- #140 changed response code on unique constraint violation with respect to mia-platform/#175
- #53 request to transition to a disallowed state now returns HTTP error 400 instead of 404
- #55 additional query _q now return 400 Bad Request in case a field is not included in the collection definition schema
- #144 method
GET /:id
returns document containing only fields defined in the JSON Schema of the collection
- #236 added
defaultSorting
field to collection definition: the field applies a sorting object document to find queries, if no explicit_s
parameter is set on request
- remove
additionalProperties
constraints from collection definition schema to allow greater flexibility in adding further config entries - updated NodeJS version in Dockerfile to v20.11.0
- updated
@fastify/mongodb
to v8.0.0 - updated
@fastify/multipart
to v8.0.0
- added step for generating SBOM (Software Bill of Materials)
- added step for scanning the built image
- downgrade debian image to bullseye, aligning the behavior of the service with that prior to v6.10.1.
- upgrade NodeJS version in Docker image to v20.14.0
- fixed projection example in json schema generator
- introduce new query parameter
_useEstimate
onGET /count
request. In this manner the endpoint employs theestimatedDocumentCount
method of MongoDB, returning the number of documents from the collection metadata - added
/-/schemas
and/<collection>/schema
routes to discover/inspect the data models' of each collection as JSON schema
- #237: casting values in
_q
queries are now executed even in case of nested fields
- improved excel export to ensure column consistency
- #247:
xls
andxlsx
export formats
- updated service dependencies
- updated NodeJS version in Dockerfile to v18.19.0
- #225:
MONGODB_MAX_IDLE_TIME_MS
env to control MongoDBmaxIdleTimeMs
connection option (default set to 0 for backward compatibility, meaning the opened connection remain opened indefinitely)
- #227: create indexes limiting promises concurrency to prevent connection creation spikes at boot
- review writable views to introduce a proper support of multi-lookup references (one-to-many relationship), addressing the point raised in this discussion
- rewritten writable views documentation to clarify their motivation and configuration
- add optional chaining to allow not to specify
pipeline
field in$lookup
views whenenabledLookup
is set
- upgrade
tap
tov18.5.2
- updated NodeJS version in Dockerfile to v18.18.2
- #172 collection export endpoint can now parse multiple accept header values and select the one with the highest weight
- #119 created route to import collection files (json, ndjson and csv)
- #137 export route allows different file formats (json, ndjson and csv)
- CRUD Service image is now pushed also on the internal Mia-Platform registry
- new Github Action that cleans up the cache generated by actions carried out when working on PRs
- updated NodeJS version in Dockerfile to v18.17.1
- updated service minor and patch dependencies
- #154 import route with PATCH method now does an upsert instead of a simple update
- #138 patch import route validate the presence for the
_id
field - #145 increased get response performances
- #129 introduce the option to enable strict validation on service responses
- #125 handled streaming error on GET / and GET /export
- #123 resolved performance issues on many collections
- mia-platform/#256 configurable collection tags.
- $text search query now working on aggregation
- #158 fixed wrong validation on nested objects.
- endpoint tag format has been updated to correctly display paths with underscores
- #92 abstraction for view writing support with the "enableLookup" flag in views configuration.
- #88 dot (
.
) notation with operator$set
is now correctly supported - #89 operators
$addToSet
and$pull
are now supported on properties added viaadditionalProperties
JSON schema definition - collection definition validation is now carried out only once per collection
- update minor and patch dependencies
- add option to enable tracing
- upgrade lc39 to v7, which upgrade fastify to v4
- updated documentation regarding service configuration to clarify the database name in the connection string
- call to configure MongoDB are now concurrent
- JSON Schema Generator refactoring to reduce duplicated operations
- updated broken links in documentation
- wrong swagger configuration
__mia_configuration
property in a collectionschema
now accepts additional properties- improved validation message for "body must NOT have additional properties" Ajv error, now it also says the unwanted property
- optimization of the
__STATE__
query sent to MongoDB: $in operator has been removed when not necessary
- encryption not working with JSON Schema collection definition
- Collections configuration files can now accept a new field
schema
which allows to define the collection data model by means of a JSON Schema. The propertyschema
in the configuration files is an opt-in feature and when defined it takes precedence over thefields
property.
Though the latter property is still supported, it is recommended to convert your collections to adopt a JSON schema definition to access the new functionality offered by JSON schema. $pull
operator support$addToSet
supports mongo operators
- Collections definition via
fields
property is now considered deprecated and it will be removed in future versions.
- Support to $addToSet operations for array fields
- Upgraded service libraries
- Refactored tests to further reduce their execution time and prevent tests timeouts
- Improved service documentation
- .npmrc file added to .dockerignore and .gitignore
README.md
improved with instructions on how to run the service in a local environment and how to configure collections and views;- Refactored
./tests
folder to support parallel run of tests in CI pipelines - Improved description of API methods exposed in API specification;
- Dockerfile: remove
crud-service-base-image
and merge its configuration into crud-service image definition - upgrade NodeJS to
v18
- upgrade
mongodb-enterprise-cryptd
tov5.0.14
- upgrade
libmongocrypt
tov1.6.2-0
- Removal of references to Mia s.r.l. internal documents, minor updates on the code for readability
- JSON definitions of MongoDB Views does not require the property
type
anymore (it will be automatically added with theview
value)
ALLOW_DISK_USE_IN_QUERIES
supports/count
operations
- Fields stored as string are casted to number if requested by schema
- support for
$dateToString
project operator in_rawp
query param.
- The CRUD Service officially supports MongoDB v6.0. See the official MongoDB release note for more information.
- Add new environment variable
ALLOW_DISK_USE_IN_QUERIES
to setallowDiskUse
option in MongoDB queries, useful when working with MongoDB Views (works with MongoDB >= 4.4).
- Added header
json-query-params-encoding
for the json query params encoding.
- the header
json_query_params_encoding
is marked as deprecated and its support is going to be dropped in the next major release.
Ajv
major upgrade to v8. Look at its release notes.- Remove multi-type definition for nullable objects, in order to favor the
nullable
property. The service expected behavior will be equivalent, but the API Schemas will change if compared to the previous versions. - Refactored Partial Indexes configuration properties
- object
nullable
field attribute is now recognized - array
nullable
field attribute is now recognized - export route works also when an array field is set to null
- failing tests on Mongo encryption lib
- Refactored Partial Indexes configuration properties, in order to be more aligned to what is displayed on the Console Frontend
- replaced deprecated
fastify-mongodb
andfastify-env
with their respective namespace scoped version@fastify/mongodb
andfastify/env
- remove multi-type definitions (
["<type>", "null"]
) to exploit onlynullable
attribute when defining that a property can be set tonull
- replace
standard
andsnazzy
with Miaeslint
configuration, refactoring code where needed to match the latest code styles - set Fastify to use Ajv v8 compiler
- upgraded Ajv to v8, adopting its newer (and stricter) default configs. This required to review source code and tests according to the migration guide.
- upgraded service dependencies
- Added support for base64 encoded (json) query params to support the ODI HTTP Client
- Added support to partial indexes
- Fixed $currentDate operator behavior for patchById, patchMany, patchBulk and upsertOne APIs
- security fixes
-
Add new _rawp's operators: $eq, $gt, $gte, $lt, $lte, $ne, $nin, $and, $not, $nor, $or, $exists, $type, $all, $elemMatch, $size, $cond, $regexMatch, $map, $mod
-
Add the
CRUD_MAX_LIMIT
environment variable, for setting up the maximum limit of object per query
- Docker Image base file @1.1.1
standard
@^17.0.0
- prevent query with empty object in
$and
to avoid full scan
- sorting by nested and multiple fields
- lc39 to v6.0.0
- Throw error on findAll stream error event
- removed check on text indexes presence when $text operator is used, mongodb performs the check by itself
- resolved a regression introduced in version 5.1.0. Now all of the endpoints of a collection are correctly exposed.
- null values in
_q
query filter are correctly handled for GET endpoints
- support for
$first
project operator in_rawp
query param
- supports MongoDB views
- mongocryptd v2
- added pino to dependencies
- remove async from get list handler
- node.js to v16
- dependency pino to ^7.1.0
- added tests and improved documentation
This version brings Mongo breaking changes from Mongo v4.4 to v5. Specially, if you are using some query (e.g. with _q
parameter) no more supported by new Mongo version or new driver version, it will return an error.
Known limitation in this version:
- before, it would be possible to make a count using
$nearSphere
operator. This operator is not permitted by mongo v4.4 and mongo v5, so in this version the count with this filter will throw.
- support to mongo v5.0
- update mongo driver to use v4
- handle mongo stream error in findAll
- Client side field level encryption
- Corrected JSON schema for text indexes.
- Corrected some logs that were not showing objects
- PATCH: $.merge operator on multiple nested array
- Upgraded
lc39
to version 5 (handled with retrocompatibility by setting swagger in order to avoid breaking changes)
- new parameter
_rawp
to perform raw projections with aggregation operators on MongoDB v4.4 or above - error handling for
_rawp
trying to overrideacl_read_columns
header - check on not allowed operators used during
_rawp
- Changed base image from
node:12.22.3-alpine
tonode:14.17.6-slim
- Installed version 4.4.8 of
mongocryptd
inside the Docker image - Installed version 1.2.2 of
libmongocrypt
inside the Docker image - Upgrade node version in
nvm
- Required node engine is now v14.17.6
- Inserted
KMS
configuration variables
- support to text search indexes (with weights and language options) and $text queries on findAll
- projection regex pattern is removed in order to allow the projection over nested fields.
- support
__STATE__
change of multiple documents using a filter and without knowing the_id
of each one.
- installed
@mia-platform/mongodb-healthchecker
for mongo healthchecks
- fix
checkNormalIndexEquality
comparison
- lc39 v3.3.0
- patch with unset of ObjectId field no longer fails
- support json schema for RawObject and array of RawObject field properties
- castToObjectId allow also null value as input and return null itself.
- lc39 v3.1.4
- Updated gitlab-ci.yml mongo dependency, from this version mongo 4.4 support is guaranteed.
- Allow $inc, $set, $unset on sub properties of raw object
- update lc39 to v3.1.3.
BREAKING CHANGE
- lc39 to v3.1.2. The update is breaking since it's bringing up lc39 v3.x with the newer logging format.
- Expose some metrics about collections
- lc39 to v3.1.0
- Omit required if empty
BROKEN: do not use this version
- Remove default limit from /export
- Update package-lock for zero-downtime
- passing
{useUnifiedTopology: false}
to fastify-mongo to avoid that isConnected() always return true
- fix CRUD startup with 0 collections
- handle ttl index
- support _id of type string
- Fixed missing data in STATE field of post and post-bulk json schema
- Implement nullable flag.
Before this, the nullable flag is ignored. The default behavior is to convert
null
into falsy value for the field type type. For example, for an integernull
value is converted to0
, for a string to''
(empty string).
- Both the handlers of
/-/check-up
and/-/healthz
route check the connection to Mongo.
- Support for the CRUD_LIMIT_CONSTRAINT_ENABLED env variables to enable constraints on minimum, maximum and default values. New limits are: maximum 200, minimum 1 and default 25
Changes that have landed in master but are not yet released.
- Support for patching array items. The
$set
command works properly on both primitive andRawObject
item types, by usingarray.$.replace
andarray.$.merge
as keys in the$set
command object. This feature involves the following CRUD operations:- Patch by ID
- Patch many
- Patch bulk
array.$.replace
Replace entirely the query-matching array item with the content passed as value.array.$.merge
Edits only the specified fields of the query-matching array item with the content passed as value.
See below for some sample cURLs for /PATCH /books-endpoint/{:id} where _q={"attachments.name": "John Doe", _st: "PUBLIC"}
Case Merge
curl -X PATCH "http://crud-service:3000/books-endpoint/5cf83b600000000000000000?_q=%7B%22attachments.name%22%3A%20%22John%20Doe%22%7D&_st=PUBLIC" -H "accept: application/json" -H "Content-Type: application/json" -d "{ "$set": { "attachments.$.merge": { "name": "renamed attachment" } }}"
Case Replace
curl -X PATCH "http://crud-service:3000/books-endpoint/5cf83b600000000000000000?_q=%7B%22attachments.name%22%3A%20%22John%20Doe%22%7D&_st=PUBLIC" -H "accept: application/json" -H "Content-Type: application/json" -d "{ "$set": { "attachments.$.replace": { "name": "renamed attachment", content: "Lorem ipsum dolor sit amet", "state": "attached" } }}"