ms-schema
v1.6.0
Published
An migrations repo for Modern Slavery which created images for Kube Jobs
Downloads
26
Readme
MS Schema
A simple container to run migrations on the MS audit database
This will set up required users and tables in order for audit data to be reported from nrm-hof and icasework resolver which can later be read by a grafana.
DB Users
hof | User for the modern slavery hof application to post audit data
grafana | User for the dashboard to get audit data
resolver | User for the icasework resolver to post audit data
reports | User for save-return-lookup-ui, save-return-api, save-return-email-alerts services to get and post session data
Environment variables
You'll need to set the following env vars:
HOF_USER_PASS | Password for the hof USER
RESOLVER_USER_PASS | Password for the resolver USER
GRAFANA_USER_PASS | Password for the graphana USER
REPORTS_USER_PASS | Password for the reports USER
NODE_ENV | So knex knows what config to run against
DB_HOST | The postgres db host
DB_USER | The postgres db username
DB_PASS | The postgres db password
DB_NAME | The postgres db name
Adding new migrations
Add a new migration running
knex migrate:make <migration_name>
Also ensure to add new seed data which can be used for local DB testing in the seed folder.
Then update the config.js file to specify the latest migration file to run to. Then document this in the audit log below.
When new work is merged to master, update the digest for the kube job in the modern-slavery service which should be the commit SHA. The digest is also logged in the Drone console when the image is published to Quay. E.g.:
8b74079b6dbfce20c0dbd683b554ec6c7c0ddfbb: digest:
Finally remember to update the package.json version, tag the repo with the same version, i.e. v1.2.0
, create a release note and publish a new npm module:
npm publish
Which then should be updated in save-return-email-alerts, save-return-lookup-ui and save-return-api. This is so they can test the latest migrations on a local DB if needs be.
Migrations Audit
12th November 2021
- 20211011151008_user.js
Prior to 12th November 2021
- 20201002165609_user.js