MDM micro-service provides endpoints for internal UKEF applications ranging from counties, currencies, yield rates, interest rates to premium schedule.
Status 🚦
CI 💫
CD 🚀
npm install --legacy-peer-deps
How to run mdm
on local environment as dev
runtime mode.
# start the local SQL database
$ docker compose -f docker-compose.db.yml up --build
# using docker-compose
$ docker compose up --build
# without docker-compose
$ npm run start:dev
We are running several test suites as part of our CI/CD pipeline.
- Unit test : These tests are written using Jest and ends with
*.test.ts
extension. - API test : These tests are written using Jest and ends with
*.api-test.ts
extension. - E2E test : These tests are written using Cypress and ends with
*.spec.ts
extension. Currently there are no E2E tests and none are executed during CI/CD.
# unit tests
$ npm run unit-test
# api tests
$ npm run api-test
# api tests with nock debugging (very useful if tests are failing)
$ DEBUG=nock.* npm run api-test
Dockerfile is used to build and run a Node.js application in a containerized environment.
It specifies the base image as node:19.9-alpine3.16
, which is a minimalistic image of Node.js 19.9 running on Alpine Linux 3.16. The RUN command installs bash and curl packages, then deletes the cache to reduce the image size.
The WORKDIR
command sets the working directory to /app
. The COPY
command copies package.json and package-lock.json to the /app directory, followed by the npm ci command, which installs the dependencies listed in package.json while ensuring compatibility with peer dependencies.
The COPY command copies the rest of the files in the current directory to the /app directory. The npm run build
command builds the application.
Finally, the npm ci command installs only the dependencies listed in package.json
, ignoring the devDependencies
, thus reducing the final build image size.
This section sets up the production stage of the Dockerfile. It specifies the same base image as the build stage. The WORKDIR
command sets the working directory to /app
.
The COPY
command copies package.json, package-lock.json, node_modules/, and dist/ directories only from the build stage to the /app directory (production stage).
Finally, the USER
command switches the user to the node user, and the CMD command runs the npm run start:prod
command to start the application in production mode.
Overall, the Dockerfile sets up a secure build and deployment environment for the Node.js application, with a non-root user and a lean production image containing only the necessary dependencies and files.
This is a Docker Compose file used to define and configure the api
service.
The first section defines the version of the Compose file syntax being used (version 3.8
), and the services that will be run.
Under the api service, the following options are specified:
-
build
: specifies the build context for the Docker image. In this case, it is set to the current directory (.), which means that Docker will look for a Dockerfile in the current directory to build the image. -
image
: specifies the name of the Docker image that will be built. -
container_name
: specifies the name of the Docker container that will be created from the image. -
restart
: specifies that the container should always be restarted if it stops running. -
command
: specifies the command that should be run when the container starts. In this case, it is set tonpm run start:prod
. -
ports
: specifies the ports that should be exposed by the container. In this case, it is set to ${PORT}:${PORT}, which means that the value of the PORT environment variable will be used for both the host and container ports. -
volumes
: specifies any directories or files that should be mounted as volumes inside the container. In this case, it is set to./:/app/src:rw
, which means that the current directory on the host machine will be mounted as a read-write volume at/app/src
inside the container. -
environment
: specifies any environment variables that should be set inside the container. In this case, a list of environment variables is provided, but their values are not specified in the file since they will be referred from local.env
file. (Please refer to.env.sample
for getting started).
The next section defines a healthcheck for the container, which will periodically check if the container is running correctly. The options specified are:
test
: specifies the command that should be run to test the health of the container. In this case, it is set to['CMD', 'curl', '-f', 'http://localhost:${PORT}']
, which means that the healthcheck will run the curl command to make a request to the container's web server and check if it receives a response.retries
: specifies the number of times that the healthcheck should be retried before considering the container as unhealthy.interval
: specifies the interval at which the healthcheck should be run.timeout
: specifies the maximum amount of time that the healthcheck command can run before being considered as failed.start_period
: specifies the amount of time to wait before running the first healthcheck after the container has started.
To simplify the generation of new resources, you can use the boilerplate CRUD
nest g resource users
# error
this.logger.error({ id: 'your message here' }, 'context-name');
# log
this.logger.log({ id: 'your message here' }, 'context-name');
The Master Database Management API requires an API Key in order to access its resources.
This can be achieved by providing a randomised API Key as an environment variable (API_KEY
) required for endpoint invocation authentication.
Currently, only the ID token that is used for authenticating our requests to ACBS is cached.
The lifetime of this cache is controlled by the ACBS_AUTHENTICATION_ID_TOKEN_CACHE_TTL_IN_MILLISECONDS
environment variable.
This token has a lifetime of 30 minutes, so it is safe to set this variable to any value between 1 and 180000000.
Do NOT set the variable to 0, as this will cache the ID token permanently.
We do not have a setting to disable this cache, but setting the TTL to 1ms will essentially disable it.
The most important prefixes you should have in mind are:
fix:
which represents bug fixes, and correlates to a SemVer patch.feat:
which represents a new feature, and correlates to a SemVer minor.feat!:
,fix!:
orrefactor!:
, etc., which represent a breaking change (indicated by the!
) and will result in a SemVer major.
- ORDNANCE_SURVEY_URL - Domain https://api.os.co.uk redirects to https://api.os.uk, so please use https://api.os.uk.