This is the backend application of the MICADO project. This is where all the business application logic will reside:
- API
- DB migration
The Docker compose file is there to help development; in particular there are 2 services:
- backend
- micado_db
The first is the proper backend code and is based on a specific image to be sure that all use the same coding environment, The second is a PostGIS DB coherent with the production for MICADO: it will install itself with all the needed schemas and configurations. For more details please consult the "deployment repository" [remember to create the prod.env file with password data]
Prepare the backend repo on your local system:
git clone https://github.com/micado-eu/backend.git
cd backend
mkdir db_data
Create a prod.env file with this content:
WSO2_API_ADMIN_PWD=secretpassword1
WSO2_IDENTITY_ADMIN_PWD=secretpassword2
WSO2_IDENTITY_PWD=secretpassword3
WSO2_SHARED_PWD=secretpassword4
WSO2_API_PWD=secretpassword5
MICADO_DB_PWD=secretpassword6
NGO_REALM_CLIENT_SECRET=secret
MIGRANT_REALM_CLIENT_SECRET=secret
PA_REALM_CLIENT_SECRET=secret
PGADMIN_DEFAULT_PASSWORD=secretpassword7
# -------- DATABASE PART --------
POSTGRES_PASSWORD=secretpassword8
# -------- WEBLATE PART ----------
# Weblate setup
WEBLATE_ADMIN_PASSWORD=secretpassword9
# PostgreSQL setup
WEBLATE_POSTGRES_PASSWORD=secretpassword10
WEBLATE_EMAIL_HOST_PASSWORD=secretpassword11
GITEA_DB_PWD=secretpassword12
GIT_SECRET_KEY=xxxxx
To code you will have to run the following command on a first shell
(set -a; source prod.env; set +a; docker-compose -f docker-compose.yaml up backend micado_db)
Wait until you see database system is ready to accept connections
On a second shell the following commands
docker-compose exec backend bash
cd micado-backend/
npm install
npm start
The container will mount the application folder and it will be possibile to code with preferred editor.
Wait until you see Server is running at http://[::1]:3000
For developing the backend for the weblate integration we need also to use GITEA so this means that we need to install and run the GITEA container
The first time that the container is run we need to create the admin user with the following command from within the container (using custom user and password):
/app/gitea/gitea admin create-user --name=gitea --password=gitea --email=test@xx.com --admin --must-change-password=false
To execute the container properly at the moment (until an issue is solved) the user will have to open the git_data/gitea/conf/app.ini and add the following:
[database]
...
SCHEMA = gitea
It is possible to expose directly a Model straightforward as a CRUD API the command is like the one that follows. This operation is needed to activate the table as managed by the model so that the migration will take it into consideration.
lb4 rest-crud --datasource micadoDS --model Topic
To control which tables are migrated and in what order there is an array to manage by hand in the 'src/migrate.ts'; the place is the models key.
await app.migrateSchema({existingSchema, models: ['FeaturesFlags', 'Topic']});
We need to have an option to migrate the DB, at the moment we are using the command line, but there is a way to create an APi that will invoke the migration command.
The way of using the cli is (the environment variable is to see the SQL code that the application is using to better understand errors):
npm run build
DEBUG=loopback:connector:postgresql npm run migrate
This project has received funding from the European Union’s H2020 Innovation Action under Grant Agreement No 822717.