This repository is for the Crown Developments service, and includes all components including the infrastructure-as-code and the applications.
tl;dr run these commands to get started:
npm ci
docker compose up
npm run db-generate
npm run db-migrate-dev
npm run db-seed
Then run each application with npm run dev
.
To get started, ensure you Node v22 (nvm install 22
) installed. Then run:
npm ci
to install all dependencies (the repo is setup with workspaces, this will install dependencies for all apps and packages).
The applications require configuation to run, and these are set via environment variables. These can be set using run configurations, or using a .env
file. There is a .env.example
file to get started with in each app directory.
A SQL Server database server is required for the applications to run. This will start automatically with docker compose. However it is required to migrate and seed the database which can be done from scripts in the database package.
First, make sure you have a .env
file in ./packages/database
(you can copy the .env.example
) and it has SQL_CONNECTION_STRING
and SQL_CONNECTION_STRING_ADMIN
environment variables defined with details pointing to your local database server (mssql
Docker container). These values will/can be the same for local development (admin is used for migrations, the other one for the seeding).
To set up the SQL Server with tables and some data, you will need to run the following commands (whilst the SQL Server Docker container is running using docker compose up
. Alternatively, you can run the Docker container called 'mssql' manually using the Docker interface):
npm run db-generate
npm run db-migrate-dev
npm run db-seed
- npm run db-generate To generate the client from the schema
- npm run db-migrate-dev To apply changes → Creating the database and tables (this will also run seed)
- npm run db-seed Populating the database with some initial data
The ORM used by the application to access SQL Server is Prisma. The schema is defined in schema.prisma.
Note: If the prisma.schema
file has been updated, don't forget to run npm run db-migrate-dev
to apply the changes.
In Azure we have manually created a login/user with db_datareader and db_datawriter roles
The following is run against the server:
CREATE LOGIN [loginname] WITH PASSWORD = 'password';
The following is run against the DB:
create USER [username] for login [loginname];
ALTER ROLE db_datareader ADD MEMBER [username];
ALTER ROLE db_datawriter ADD MEMBER [username];
Azure Data Studio or the MSSQL VS code extension can be used as a database client, to create and monitor the database contents.
Install Azure Data Studio or the VS code extension, and connect to the SQL server by using the credentials specified below:
Server: localhost Authentication type: SQL Login User name: sa Password: DockerDatabaseP@22word! Database: pins_crown_dev Trust server certificate: True
To run the apps for development, using npm run dev
in each application directory.
This repository uses commitlint, eslint, and prettier. This are run with git hooks and also on the CI pipeline. They can also be run directly (from root):
npm run commitlint
npm run format
- to format all filesnpm run format-check
- to check the format of all filesnpm run lint
- to run eslint
This respository uses the Node test runner. To run all tests, use npm run test
from root.
MIT © Planning Inspectorate