Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mia-platform/crud-service

A lightweight application to expose restful CRUD API over HTTP interface
https://github.com/mia-platform/crud-service

api crud mongodb

Last synced: 3 months ago
JSON representation

A lightweight application to expose restful CRUD API over HTTP interface

Awesome Lists containing this project

README

        

crud-service

CRUD Service



[![pipeline status][build-svg]][pipeline-link]
[![Coverage Status][coverage-svg]][coverage-link]
[![license][license-svg]](./LICENSE)
[![javascript style guide][standard-mia-svg]][standard-mia]

## Introduction

The **CRUD Service** is a lightweight application that exposes an HTTP Interface to perform CRUD operations on MongoDB collections defined via JSON Schema, to make sure to have consistent data in every operation. Moreover, your documents will includes some metadata regarding the creation and the latest update of the document, and a state that will come in handy to better manage draft documents and virtual delete.

The **CRUD Service** can be launched with [lc39](https://github.com/mia-platform/lc39), that will start a [Fastify](https://fastify.io) instance that will include the functionalities. It also includes a Swagger User Interface to be used to perform any operation for each of the collections defined.

Moreover, the **CRUD Service** can be configured used with the [MongoDB Data Encryption](https://www.mongodb.com/basics/mongodb-encryption) functionality to automatically encrypt data stored in the Database.

## How to run it

### Local deployment

To deploy the service in your local environment, you must have:
- Node at version 18 or superior,
- MongoDB instance at version 4.0 or superior

To setup Node, we suggest you to install [nvm][nvm] to have multiple node versions in your computer, and use the version suggested in the `.nvmrc` file.
```sh
nvm install # <-- to be done only the first time
nvm use
```

About mongo, we suggest you to have it in a separate Docker container. You can follow this small guide or use the configuration you prefer:
```shell
docker pull mongo:7.0
docker volume create mongo
docker run --detach --name mongo -p 27017:27017 --mount source=mongo,target=/data/db mongo:7.0
```

In case you want to use the MongoDB Encryption functionality, you must install in your machine the [MongoDB Enterprise Server](https://www.mongodb.com/try/download/enterprise?tck=docs_server) and run the `mongocryptd` file (its location may change based on the version you downloaded).

To run the **CRUD Service**, a `*.env` file including the needed configuration is required. An example of this file is the [default.env](default.env) file. You want to copy the file in a different path to make sure your configuration is ignored by Git (we suggest the name `local.env`):
```shell
cp ./default.env ./local.env
```

The `default.env` only lists the necessary environment variables to be added to successfully run the CRUD Service in your local machine. A complete list of the environment variables can be found [on the related page](envSchema.js#L25).

Once you have your _env_ file, you might want to update the `COLLECTION_DEFINITION_FOLDER` and `VIEWS_DEFINITION_FOLDER` environment variables, which represent the folders where the definition of collections and views are found. The CRUD Service accepts _absolute paths_ only, so please verify them. The default values are folders used in unit tests: if you plan to update the files inside for your needs, it's better to use another folder.

When everything is ready, you can run the service:
```shell
nvm use # <-- only if you use nvm
npm i
npm run start:local # <-- run the service using the 'local.env' file
```

### Use the Docker Image

Docker images of the **CRUD Service** are available on [GitHub Registry](https://github.com/orgs/mia-platform/packages/container/package/crud-service) and [DockerHub](https://hub.docker.com/r/miaplatform/crud-service). An image is released in those two registries for every tag created.

If you instead prefer to create your image (e.g. from your fork), you can use the [`Dockerfile`](./Dockerfile) to generate your image:

```shell
docker build -t crud-service .
```

Thanks to the support of [Docker BuildKit](https://docs.docker.com/build/buildkit/), you can also decide to create an image of the CRUD Service without including the `mongocryptd` libraries:

```shell
DOCKER_BUILDKIT=1 docker build -t crud-service-no-encryption --target=crud-service-no-encryption .
```

If you are interested in it, you can get one and run it locally with these commands:

```shell
docker run --name crud-service \
--detach \
--env LOG_LEVEL=info \
--env MONGODB_URL=mongodb:/// \
--env COLLECTION_DEFINITION_FOLDER=/home/node/app/collections \
--env USER_ID_HEADER_KEY=userid \
--env CRUD_LIMIT_CONSTRAINT_ENABLED=true \
--env CRUD_MAX_LIMIT=200 \
--mount type=bind,source=$(pwd)/tests/collectionDefinitions,target=/home/node/app/collections \
--publish 3000:3000 \
:latest
```

Please note that you can mount the `.env` file with your CRUD Service configuration instead of manually including the environment variables in the command.

### How to use it

You can access the **Swagger User Interface**, generally available at `http://localhost:3000/documentation` (it depends on which port you deployed the service). From there you can verify the list of Collections and Views defined and execute HTTP requests to effectively use the service.

## Local development

### (CSFLE)[https://www.mongodb.com/docs/manual/core/csfle/] Support

In order to run the service with the Client-Side Field Level Encryption feature enable it is necessary to download from (MongoDB Download Center)[https://www.mongodb.com/try/download/enterprise] the `crypt_shared` dynamic library, which provides the automatic encryption functionalities. Upon the compressed file is downloaded, please uncompress and copy the file `lib/mongo_crypt_v1.so` into the folder `.local/lib` within this repository.
In case you would like to choose a different location for storing the `crypt_shared` library, please remember to customize the `CRYPT_SHARED_LIB_PATH` environment variable before launching the service locally or running tests.

:::note
Please remember that CSFLE is a MongoDB Atlas/Enterprise exclusive feature. Consequently, please ensure you are subscribed to one of such plans before using it.
:::

### Run tests

We use [tap](https://github.com/tapjs/node-tap) to test the **CRUD Service**. Once you have all the dependency in place, you can simply launch it with:

```shell
npm run coverage
```

It will run the tests with the coverage report that you can view as an HTML page in `coverage/lcov-report/index.html`.

To run only one test:

```shell
env MONGO_VERSION=7.0 MONGO_HOST=127.0.0.1 TAP_BAIL=1 node tests/createIndexes.test.js
```

## Architecture

```
+----------------------+ +----------------------+ +----------------------+ +----------------------+
| | | | | | | |
| +-------------+ | | +-------------+ | | +-------------+ | | |
| | | | | | | | | | | | | +-------------+ |
| | CrudService | | | | CrudService | | | | CrudService | | | | | |
| | | | | | | | | | | | | | JoinService | |
| +-------------+ | | +-------------+ | | +-------------+ | | | | |
| +-------------+ | | +-------------+ | | +-------------+ | | +-------------+ |
| | | | | | | | | | | | | |
| | QueryParser | | | | QueryParser | | | | QueryParser | | | |
| | | | | | | | | | | | | |
| +-------------+ | | +-------------+ | | +-------------+ | | |
| +-------------+ | | +-------------+ | | +-------------+ | | |
| | | | | | | | | | | | | |
| |HTTPInterface| | | |HTTPInterface| | | |HTTPInterface| | | |
| | | | | | | | | | | | | |
| +-------------+ | | +-------------+ | | +-------------+ | | |
| | | | | | | |
| Crud on a collection | | Crud on a collection | | Crud on a collection | | JoinPlugin |
| | | | | | | |
+-----------^----------+ +-----------^----------+ +-----------^----------+ +-----------^----------+
| | | |
+-----------+-------------------------+-------------------------+-------------------------+----------+
| |
| +--------------------+ +--------------------+ |
| | | | | |
| | Model definitions | FASTIFY | Mongodb connection | |
| | | | | |
| +--------------------+ +--------------------+ |
| |
+----------------------------------------------------------------------------------------------------+
```

The CRUD Service application uses Fastify to connect to a MongoDB instance (thanks to the @fastify/mongodb plugin) and execute CRUD operations. At startup, it requires several details, such as the MongoDB URL to communicate with, but also the folders where the definitions of the collections and the views can be found. A complete and comprehensive list of the environment variables needed can be found on the [Configuration page](./docs/20_Configuration.md).

The collections and the views available in the service are the ones with Model definitions stored in the folders defined in, respectively, `COLLECTION_DEFINITION_FOLDER` and `VIEWS_DEFINITION_FOLDER`. In each folder, there will be one file per collection/view. Each file should be a JSON or a javascript file.

These models will be analyzed by the [JSONSchemaGenerator](./lib/JSONSchemaGenerator.js) class to be transformed to a JSON Schema that will be used to validate HTTP requests, to serialize the output and to return these information to the user as a documentation.

The service exposes several APIs to communicate with the collections. You can send requests as you prefer: you can use curl, use an application such as PostMan, or use the integrated Swagger API Interface accessible to `http://{{url}}/documentation`.

When the Service is live, every HTTP request executed will be caught by the HTTP Interface that works as a communication channel with the CRUD Service. The data included with the request (query parameters, body, commands) is evaluated by the [`QueryParser`](./lib/QueryParser.js) class to verify the query to make sure that every value associated to a specific field is in the correct type. Then it's forwarded to the [`CrudService`](./lib/CrudService.js) class to execute the query. Result of `GET` requests are passed to the [`AdditionalCaster`](./lib/AdditionalCaster.js) class to casts GeoPoints and ObjectIds properties in the data.

### Define your collections

#### JSONSchema Configuration

The collections should be included in separate JSON or JavaScript files in the folder defined with the environment variable `COLLECTION_DEFINITION_FOLDER`. Each collection object requires the following fields:

| Name | Type | Required | Default value | Description |
|------|------|----------|---------------|-------------|
| id | String | - | - | Additional identifier that can be associated to the collection definition. |
| endpointBasePath | String | &check; | - | The endpoint path, used as entry point to CRUD operations |
| name | String | &check; | - | The name of the collection on MongoDB. |
| defaultState | String | - | `DRAFT` | The default state assigned to a document when inserted. Can be one of the [\_\_STATE__ available values](#metadata-fields) |
| defaultSorting | Object | - | - | [MongoDB document](https://www.mongodb.com/docs/manual/reference/method/cursor.sort/#ascending-descending-sort) defining the default order applied to the result set during find operations, **only if no explicit sorting is defined**. A complete description of the field can be found [in the section of the collection JSON Schema](./lib/model.jsonschema.js#L487). |
| schema | JSONSchemaStandard | &check; | - | The JSON Schema configuration of the fields to be included in the collection object. A complete description of its fields can be found in the [ _schema_](./lib/model.jsonschema.js#L495) section of the collection JSON Schema. |
| indexes | Array of objects | &check; | - | The list of indexes to be created when starting the service and initializing all the collections. A complete description of its fields can be found [in the _indexes_ section of the collection JSON Schema](./lib/model.jsonschema.js#L692) |
| tags | Array of strings | - | [] | The list of tags to be associated to the collection's endpoints, useful to group different endpoint under the same section inside the swagger. |

> **WARNING:** The definition of _unique_ indexes makes the CRUD Service fail at startup if the database contains inconsistent documents (e.g. documents that have the same value for that key). Also documents without that key are all considered to have the same value (_null_), thus [violating the uniqueness](https://docs.mongodb.com/manual/core/index-unique/#unique-index-and-missing-field), and causing the index generation (and the CRUD Service) to fail at startup.

> **WARNING:** every index that is not specified in the collection definition wil be **dropped** at startup of the application, unless its _name_ starts with the `preserve_` prefix.

> **TIP:** if a default sorting is defined, is suggested to have its fields covered by an index.

Several examples of collections can be found in the [Collections Definitions folder](./tests/newCollectionDefinitions/),
whereas the schema that defines and validate the data model definition can be found [here](./lib/model.jsonschema.js).

#### Custom Fields configuration (deprecated)

The collections should be included in separate JSON or JavaScript files in the folder defined with the environment variable `COLLECTION_DEFINITION_FOLDER`. Each collection object requires the following fields:

| Name | Type | Required | Default value | Description |
|------|------|----------|---------------|-------------|
| id | String | - | - | Additional identifier that can be associated to the collection definition. |
| endpointBasePath | String | &check; | - | The endpoint path, used as entry point to CRUD operations |
| name | String | &check; | - | The name of the collection on MongoDB. |
| defaultState | String | - | `DRAFT` | The default state assigned to a document when inserted. Can be one of the [\_\_STATE__ available values](#metadata-fields) |
| defaultSorting | Object | - | - | [MongoDB document](https://www.mongodb.com/docs/manual/reference/method/cursor.sort/#ascending-descending-sort) defining the default order applied to the result set during find operations, **only if no explicit sorting is defined**. A complete description of the field can be found [in the section of the collection JSON Schema](./lib/model.jsonschema.js#L76). |
| fields | Array of objects | &check; | - | The list of fields to be included in the collection object. A complete description of its fields can be found [in the _fields_ section of the collection JSON Schema](./lib/model.jsonschema.js#L84). |
| indexes | Array of objects | &check; | - | The list of indexes to be created when starting the service and initializing all the collections. A complete description of its fields can be found [in the _indexes_ section of the collection JSON Schema](./lib/model.jsonschema.js#L247) |
| tags | Array of strings | - | [] | The list of tags to be associated to the collection's endpoints, useful to group different endpoint under the same section inside the swagger. |

> **WARNING:** The definition of _unique_ indexes makes the CRUD Service fail at startup if the database contains inconsistent documents (e.g. documents that have the same value for that key). Also documents without that key are all considered to have the same value (_null_), thus [violating the uniqueness](https://docs.mongodb.com/manual/core/index-unique/#unique-index-and-missing-field), and causing the index generation (and the CRUD Service) to fail at startup.

> **WARNING:** every index that is not specified in the collection definition wil be **dropped** at startup of the application, unless its _name_ starts with the `preserve_` prefix.

> **TIP:** if a default sorting is defined, is suggested to have its fields covered by an index.

Several examples of collections can be found in the [Collections Definitions folder](./tests/collectionDefinitions/),
whereas the schema that defines and validate the data model definition can be found [here](./lib/model.jsonschema.js).

### Define your views

The MongoDB Views should be included in separate JSON or JavaScript files in the folder defined with the environment variable `VIEWS_DEFINITION_FOLDER`. Each collection object requires the following fields:

| Name | Type | Required | Default value | Description |
|------|--------|----------|---------------|-------------|
| name | String | &check; | - | The name of the view, used as identifier |
| source | String | &check; | - | The name of the collection to be used as source to generate the view |
| type | `view` | &check; | - | The type of MongoDB element, which is required by CRUD Service to understand which operations might be performed. It should be the value `view`. |
| pipeline | Object | &check; | - | The pipeline to aggregate the MongoDB View. It uses the same syntax of the [Aggregation Pipeline](https://www.mongodb.com/docs/manual/core/aggregation-pipeline/) |

Several examples of collections can be found in the [Views Definitions folder](./tests/viewsDefinitions/),
whereas the schema that defines and validate the data model definition can be found [here](./lib/model.jsonschema.js) (it is the same schema of the collection definition).

**Note:** `__STATE__` field **must** be returned in each record eventually produced by the view aggregation pipeline.
On the contrary, records without the `__STATE__` field would always be filtered out by the CRUD Service operations
(e.g. listing records via `GET /` API method would not consider them in the result set).

### Writable views

The CRUD service offers the functionality to modify a view by editing the underlying collection. This enables clients to interact with a view as if it was an independent collection. Additionally, the service will expose additional routes that provide a comprehensive list of all possible values that can be included as lookup values, if any in the view.

To enable this feature, you need to include the `enableLookup: true` property in the view configuration JSON. By default, this setting is set to false.

For more information on correctly configuring and understanding the capabilities of writable views, please refer to the [writable views documentation](./docs/50_Writable_Views.md).

### Headers

Every HTTP request trusts in some headers:

* **acl_rows** allows us to limit the rows that the requester can see. The query to limit the rows is passed a stringified json.
* **acl_read_columns** allows us to limit the properties to be returned to the requester. The list of properties is passed as a stringified json.
* **json-query-params-encoding** allows us to use a different encoder for the data passed as query parameters (only supported value: _base64_)
* **user_id** includes the identifier of the user executing the request

### Metadata fields

When working with collections via CRUD Service, some fields will be automatically generated and updated. Those fields are the following:

* **updaterId** is the user id (string) that requests the last change successfully
* **updatedAt** is the date (date) of the request that has performed the last change
* **creatorId** is the user id (string) that creates this object
* **createdAt** is the date (date) of the request that has performed the object creation
* **\_\_STATE__** is the current state of the document, can be one of the following four:
* `PUBLIC` (by default, only data in `public` will be shown via `GET` requests)
* `DRAFT`
* `TRASH` (a "soft delete" state, ideally to be visible in the Trash Bin of a backoffice application)
* `DELETED` (marked as delete, it shouldn't be shown in GET requests and it shouldn't be modified with PUT operations)

#### Document State management

We've just explained the difference between the four possible states of a document. This property can be set directly during an _insert_, and can be changed via REST API calls only in the case of the following transformations:
- a document in `PUBLIC` can be moved to `DRAFT` or `TRASH`;
- a document in `DRAFT` can be moved to `PUBLIC` or `TRASH`;
- a document in `TRASH` can be moved to `DRAFT` or `DELETED`;
- a document in `DELETED` can be moved only to `TRASH`;
Any request to transition to a not allowed state will be refused and a _400 Bad Request_ will be returned.

**NOTE**: If you request to update the state to its current value (e.g., from `PUBLIC` to `PUBLIC`), it will be successful. The `__STATE__` will remain the same, but the _updaterId_ and _updatedAt_ metadata fields will be updated.

Operations of hard delete are supported, although the permissions over this type of operation are defined via ACL.

### Crud service

This class makes the query to the mongodb collection, manages `updaterId`, `updatedAt`,
`creatorId`, `createdAt`, `__STATE__` and checks whether operations are allowed.

### QueryParser

This class casts the value from the query, the body and the commands in order to insert `Date` and `ObjectId`
and perform other conversions such as `GeoPoint` where needed

### AdditionalCaster

This class casts the value of the result from a query executed in order to have consistent data with the definition of the collection. It operates only on one type of properties: MongoDB's `GeoPoint`.

### HTTPInterface

This piece of code is a communication channel between HTTP and the CrudService.
It uses the `QueryParser` to cast the value before forwarding the request to the `crudService`, and the `AdditionalCaster` to cast the GeoPoints and ObjectIds values inside the response to be returned.

The HTTPInterface includes by default different API methods for every kind of operation. The following are available for both Collections and Views:

| Verb | API Method | Description |
|------|------------------------------|--------------------------------------------------|
| GET | {base URL}/{endpoint}/ | Returns a list of documents. |
| GET | {base URL}/{endpoint}/export | Export the collection in different file formats. |
| GET | {base URL}/{endpoint}/{id} | Returns the item with specific _ID_. |
| GET | {base URL}/{endpoint}/count | Returns the number of items in the collection. |

For collections, also the following methods are available:

| Verb | Method | Description |
|--------|----------------------------------|-----------------------------------------------------------------------------------------------------|
| POST | {base URL}/{endpoint}/ | Add a new item to the collection. |
| POST | {base URL}/{endpoint}/upsert-one | Update an item in the collection. If the item is not in the collection, it will be inserted. |
| POST | {base URL}/{endpoint}/bulk | Insert new items in the collection. |
| POST | {base URL}/{endpoint}/state | Change state of multiple items of the collection. |
| POST | {base URL}/{endpoint}/{id}/state | Change state of the item with specific _ID_. |
| POST | {base URL}/{endpoint}/validate | Verify if the body of the request is valid for an insertion in the collection. |
| POST | {base URL}/{endpoint}/import | Inserts new items in the collection from file (json, ndjson and csv). |
| PATCH | {base URL}/{endpoint}/ | Update the items of the collection that match the query. |
| PATCH | {base URL}/{endpoint}/{id} | Update the item with specific _ID_ in the collection. |
| PATCH | {base URL}/{endpoint}/bulk | Update multiple items of the collection, each one with its own modifications |
| PATCH | {base URL}/{endpoint}/import | Update the items in the collection from file (json, ndjson and csv), it must include the _ID_ field |
| DELETE | {base URL}/{endpoint}/ | Delete multiple items from the collection. |
| DELETE | {base URL}/{endpoint}/{id} | Delete an item with specific _ID_ from the collection. |

All these methods might include additional query parameters to refine the search. To have more detail, you can check the [live documentation](http://localhost:3000/documentation) (available only when a service instance is started locally) or refer to the service [documentation overview](./docs/10_Overview_and_Usage.md#crud-endpoints).

### JoinService

The CRUD Service includes also the `join` feature, to join two different models. That feature is served on `/join//:from/:to/export`, where:
- type: `one-to-one` or `one-to-many` or `many-to-many`
- from: the collection endpoint from which the join starts
- to: the collection endpoint which the join ends to
This API responses always in `application/application/x-ndjson`

See the documentation to see which parameters are available.

## Performance test

We use [k6](https://example.com/k6) to simulate the load of traffic directed to the CRUD Service and retrieve some performance metrics. At every version released, a workflow automatically starts executing the following tests:

- **Load Test**: 10 virtual users execute POST requests for one minute on the same collection, then 100 virtual users execute GET, PATCH, and DELETE requests for another minute on the data created.
- **Spike Test**: We simulate a spike of activity by increasing the number of users from 5 to 500 in 30 seconds, then a decrement of activity from 500 to 5 in another 30 seconds. During this test, only GET requests are executed on a collection that includes 100,000 documents.
- **Stress Test**: We simulate a brief time of intense activity with 250 users for 90 seconds, followed by a decrement of activity to 5 in 30 seconds. During this test, only GET requests are executed on a collection that includes 100,000 documents.

These tests are executed ahead of every version release to ensure that further updates do not cause a degradation of performance that might affect the usage of the CRUD Service.

### Execute Performance Test on a Local Environment

In case you want to run the tests on your local environment, follow these steps:

- Start the CRUD Service in a Docker container.
- Have a MongoDB instance ready for use, eventually loaded with existing documents to simulate tests.

To simplify these operations, you can use the same setup for the tests executed during the GitHub workflow, by starting an instance of the CRUD Service using collections and views included in the folder `_bench/definitions`. Use the script `bench/utils/generate-customer-data.js` to quickly include mock documents in the _customers_ collection.

The `generate-customer-data.js` script can be executed at any time with the following command:

```bash
node bench/utils/generate-customer-data.js -c -d -n -s
```
Where the script arguments are the following:
- **connection string** (default: _mongodb://localhost:27017_): Connects to your MongoDB instance.
- **database name** (default: _bench-test_): Specifies the name of the database to write to.
- **number of documents** (default: _100000_): Sets the number of documents to be created and saved in the customers collection of the specified database.
- **number of total shops** (default: _250_): Defines a random value (from 1 to the specified number) applied to the shopID field of each document to be saved.

To simplify these operations, you can execute the command `npm run bench:init` from your shell. This command starts a container with a MongoDB 6.0 instance, a container with the CRUD Service (built from your current branch), and populates the _customers_ collection with 100,000 documents.

To execute any test, start the k6 service with the following command:

```bash
docker compose -f bench/dc-k6.yml up
```

Remember to replace `` with one of the following:
| Service Name | Description | File name containing the test |
|--------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------|
| k6-load-test | Executes a Load Test (1 minute of POST, 1 minute of GET/PATCH/DELETE) on the _items_ collection | [load-test.js](bench/scripts/load-test.js) |
| k6-smoke-test | Executes a Smoke Test (1 minute of GET requests) on the _customers_ collection | [smoke-test.js](bench/scripts/smoke-test.js) |
| k6-stress-test-on-collections | Executes a Stress Test (GET requests for 90 seconds by 250 users) on the _customers_ collection | [stress-test-on-collections.js](bench/scripts/stress-test-on-collections.js) |
| k6-stress-test-on-view | Executes a Stress Test (GET requests for 90 seconds by 250 users) on the _registered-customers_ view | [stress-test-on-view.js](bench/scripts/stress-test-on-view.js) |
| k6-spike-test | Executes a Spike Test (simulate a spike of 500 concurrent users for GET requests) on the _customers_ collection | [spike-test.js](bench/scripts/spike-test.js) |
| k6-bulk-test | Executes a Bulk Test (simulate a spike of 40 `POST /bulk` requests and 40 `PATCH /bulk` requests of 10k records each) on the _items_ collection | [bulk-test.js](bench/scripts/bulk-test.js) |
| runner | An empty test that can be populated for tests on local environment | [runner.js](bench/scripts/runner.js) |

We suggest you use the runner to execute customized tests for your research.

Also, do not run all the tests alltogether via `docker compose -f bench/dc-k6.yml up`, without specifying a test name, otherwise all the tests will run at the same time and the results will not be specific to any test but a global indication on how to service worked during the execution of **all** the tests.

You are free to modify and improve those tests and the definitions used for them but please remember to not use any sensible data.

## FAQ

### How do I change the Mongocryptd version on Debian

To change the cryptd version, you can download the binary file from the [MongoDB Repositories][cryptd], then navigate to the following subpath: `{version_wanted}/main/binary_amd64/mongodb-enterprise-cryptd_{version_wanted}_amd64.deb`.

For example, for version 5.0.14, the final url of the `.deb` will be: https://repo.mongodb.com/apt/debian/dists/bullseye/mongodb-enterprise/5.0/main/binary-amd64/mongodb-enterprise-cryptd_5.0.14_amd64.deb

## Client-side Libraries

For leveraging the CRUD Service APIs in your services you can use one of the following libraries based on supported languages

- [Golang](https://github.com/mia-platform/go-crud-service-client)

## Contributing

CRUD Service is an active project developed and maintained by [Mia Platform](https://mia-platform.eu/), it is distributed open source and it is [Apache 2 licensed](./LICENSE).
You're more than welcome to partecipate by creating and/or partecipating to public discussion and actively partecipate to the development of the application.

The two main communication channel are:
- in the [issues tab](https://github.com/mia-platform/crud-service/issues);
- in the [official Mia Platform Community Discussion page](https://github.com/mia-platform/community/discussions?discussions_q=label%3A%22CRUD+Service%22) (if you want to create a discussion here, please add the _CRUD Service_ tag);

Please read [CONTRIBUTING.md](./CONTRIBUTING.md) for further details about the process for submitting pull requests.

## Disclaimer

### Usage of MongoDB Data Encryption

The CRUD Service can be used along with the [MongoDB Data Encryption](https://www.mongodb.com/basics/mongodb-encryption) functionality, and the images available includes the libraries to use this feature.

However, the MongoDB Data Encryption should be used along with [MongoDB Atlas](https://www.mongodb.com/atlas/database) or [MongoDB Enterprise Advanced](https://www.mongodb.com/products/mongodb-enterprise-advanced). When you use the CRUD Service, for personal projects or commercial applications, you should be aware of that and you will have to comply with [MongoDB terms of use](https://www.mongodb.com/legal/terms-of-use) accordingly.

Mia Platform s.r.l. does not respond to any improper use of the MongoDB Data Encryption or any other MongoDB product.

[nvm]: https://github.com/creationix/nvm
[cryptd]: https://repo.mongodb.com/apt/debian/dists/bullseye/mongodb-enterprise/

[pipeline-link]: https://github.com/mia-platform/crud-service/actions
[build-svg]: https://img.shields.io/github/actions/workflow/status/mia-platform/crud-service/main.yml
[license-svg]: https://img.shields.io/github/license/mia-platform/CRUD-service

[coverage-svg]: https://coveralls.io/repos/github/mia-platform/crud-service/badge.svg?branch=main
[coverage-link]: https://coveralls.io/github/mia-platform/crud-service?branch=main
[standard-mia-svg]: https://img.shields.io/badge/code_style-standard--mia-orange.svg
[standard-mia]: https://github.com/mia-platform/eslint-config-mia