The backend contains the following components:
- etp-backend - backend services for both the public and authorities -sections
- etp-db - database migration tool
See top-level directories etp-front and etp-public
For Ubuntu:
sudo apt install openjdk-17-jdk
Installation for Linux by following the instructions at the following URL:
https://docs.docker.com/install/linux/docker-ce/ubuntu/#install-using-the-repository
Remember to follow the Docker postinstall -guide. Then logout and login.
Docker-compose is also required:
https://docs.docker.com/compose/install/
For Ubuntu:
https://clojure.org/guides/getting_started#_installation_on_linux
Install LibreOffice
For MacOS:
brew install libreoffice
ln -s /opt/homebrew/bin/soffice /opt/homebrew/bin/libreoffice
Start the required services (database etc):
cd docker
./start.sh
Start script starts docker-compose, creates template and dev databases and runs migrations for both of them.
Docker-compose has a service for faking digital signatures, mpollux. It uses a self-signed certificate. Visit https://127.0.0.1:53952/ and trust the certificate to get the digital signatures working.
Start the backend. Backend developers should start the REPL from
their IDE and start the services from there by calling the reset
function.
The application can be also started from the command line with the following
command:
cd etp-backend
clojure -M:dev -m solita.etp.core
Tests can be run (parallel) with
cd etp-backend
clojure -M:dev:test
Test coverage report (without API layer) can be generated with
cd etp-backend
clojure -M:dev:coverage
Check dependencies for vulnerabilities
cd etp-backend
./nvd.sh
Check outdated dependencies
cd etp-backend
clojure -M:outdated
When the server is running, the API documentation can be found at http://localhost:8080/api/documentation/index.html
MinIO is used as a replacement for S3 in local development environment. MinIO Console can be accessed through http://localhost:9001/ (user: minio pw: minio123).
There are two users for the database:
etp
: has all privileges topostgres
database.etp_app
: can read and write to tables inpostgres
database.
In production and test environments the postgres
database is used
normally. It needs to be created during instance setup and migrations are ran as
etp
user. etp_app
user writes and reads data from the tables.
In development environment the postgres
database is used as a template
that can be used for setting up new databases. The dockerized Postgres sets up
a second database etp_dev
which should be used locally during
development. For convenience, docker directory contains script
flyway.sh that can be used for migrating and cleaning
both databases with a single call.
Tests will utilize postgres
database as template extensively as each test
will create their own database from it.
The function user/generate-energiatodistukset-for-performance-testing!
can be used to add multiple signed energiatodistus into the database. For
performance testing purpose most strings are just randomly generated and
signing the documents is done by just directly inserting signed documents.
For example, to generate 2000 energiatodistus you can run:
(user/generate-energiatodistukset-for-performance-testing! 2000)
update-test-data.sh
script can be used to add current state of the database and minio (S3) files into test dataset that is initialised when the service is started.
The script copies all user data (i.e. data that's not from migrations or from audit tables) and select audit data that has functionality tied to it.
To use the script, clean everything, create new desired state and run the script. To reduce amount of changes in the data, temporarily remove other test migrations before making new test data.
# Clean database and volumes
(cd docker && docker compose down -v && ./start.sh)
# Make modifications, like use the UI to start a new käytänvalvont
# Create new initial state
./docker/update-test-data.sh
Remember to commit the changes if necessary.
To generate a site of used licenses:
cd etp-backend
clojure -Spom
# Now add Clojars to repositories in generated pom.xml
mvn project-info-reports:dependencies
Both projects contain script build-docker-image.sh
which can be
used to build the uberjars and related docker containers. The build containers
can be executed by running docker run [etp-db or etp-backend]
.