We have the strategic goal SG-02 "stand-alone system". We want to succeed this goal, therefor we need to set the ErWIn system separate to the dBC. This repository is used for the development the separate ErWIn system to achieve this goal.
- Node in the version stated in the
package.json
- Container Runtime like Docker or Podman
- Is required for local setup and integration tests
- Run
npm ci
to install all dependencies - Start the required services from the
compose.yaml
file- db
- keycloak
- redis
- Create a
.env
file and set the required environment variables fromenv.config.ts
- run
npm run setup
to initialize the DB and seed data - Run
npm run start:debug
to start the server - Server runs on the url printed in the console
Command | Description | Hint |
---|---|---|
Setup | ||
npm ci | Installs all required dependencies | |
Build | ||
npm run build | Compiles all *.ts files |
|
Run | ||
npm run start | Starts the server | No debug port |
npm run start:debug | Starts the server in debug mode | Debug port is open |
npm run start:prod | Starts the server in production mode | |
Test | ||
npm run test:cov | Runs all tests with coverage | Success is a merge requirement |
npm run test:unit | Runs only unit tests | Files with *.spec.ts ending |
npm run test:integration | Runs only integration tests | Files with *.integration-spec.ts ending |
npm run test:watch | Starts the interactive watch mode | |
Lint | ||
npm run format | Runs the formatter | |
npm run lint | Runs the linter | Success is a merge requirement |
npm run lint:fix | Runs the linter and fixes auto fixable problems | |
Console Applications | ||
npm run setup | Runs db:init to Initialize the DB | |
npm run db:init | Initializes the database (applies SQL schema) | compose.yaml can be used |
npm run db:seed DATA_DIR | Creates seeding-data. DATA_DIR is required, FILES_TO_EXCLUDE optional | e.g. npm run db:seed DATA_DIR FILES_TO_EXCLUDE |
If you only need to run the server, you can start it and all it's dependencies with docker compose.
docker compose --profile full-backend up
will start everything you need.
You may need to initialize the database, use docker compose up db-init
do so.
You can also use another profile, if you want to initialize the db while starting the server docker compose --profile full-backend --profile db-init up
- Code conventions are enforced through the compile, eslint and prettier as far as possible
- Non enforcable conventions will be documented here. If they become enforcable we will put them into automation.
- Table names will be all lowercase if the name contains multiple words they will be separated by underscores.
- Git conventions can be found here
- Test conventions can be found here
- Configuration conventions can be found here
- Authentication guides can be found here
- Developer notes can be found here
- Seeding notes can be found here
- Migration notes can be found here
- Help on how to test API with Insomnia can be found at API manuell lokal testen mit Insomnia
If you push a tag upstream a container will be created for you. (Check Github under Packages)
ghcr.io/dbildungsplattform/dbildungs-iam-server:tag
The software is licensed under the EUPL-1.2 license.