This mono-repo contains the language and translator services of the Finnish National Agency for Education.
- Maven 3.1+
- JDK 17
- PostgreSQL 14.7
- node v20.9.0
- yarn 4.0.1 (to enable it, run the following command:
corepack enable
)
Below are listed the OPH services which are a part of this mono-repo.
In addition, the shared frontend content can be found here.
- Download Docker Desktop
- Build containers for a specific app
docker-compose -f docker-compose-<app>.yml build
- Run mvn install for the backend:
cd backend/<app>; ./mwnw install
- Run the app with docker-compose
docker-compose -f docker-compose-<app>.yml up
In order to connect the database from terminal, download a PostgreSQL client (14.x). For example with OSX with Homebrew:
brew install postgresql@14
Or use PostgresSQL client inside docker:
docker exec -ti <app>-postgres psql -U postgres -d <app>-postgres
Create and start database, backend, and frontend containers for a specific application:
docker-compose -f docker-compose-<app>.yml up
Or
Start up a certain service of an application:
docker-compose up frontend | backend | postgres
To disable default Spring Security configurations, create the following environment variable and restart the containers:
export AKR_UNSECURE=true
docker-compose -f docker-compose-<app>.yml up
In case of errors, clean cache and recreate volumes:
docker-compose -f docker-compose-<app>.yml down
docker-compose -f docker-compose-<app>.yml up --build --force-recreate --renew-anon-volumes
After starting the services, the frontend runs on > http://localhost:4000
To read packages from github maven repository you need to enable token authentication from maven settings file:
~/.m2/settings.xml
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
http://maven.apache.org/xsd/settings-1.0.0.xsd">
<activeProfiles>
<activeProfile>github</activeProfile>
</activeProfiles>
<profiles>
<profile>
<id>github</id>
<repositories>
<repository>
<id>oph-github-packages</id>
<url>https://maven.pkg.github.com/Opetushallitus/packages</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
</profile>
</profiles>
<servers>
<server>
<id>oph-github-packages</id>
<username>github-username</username>
<password>ghp_TOKEN_CLASSIC</password>
</server>
</servers>
</settings>
Deployments are created automatically when a new push is done into dev
branch. To create a new deployment from other branches use [deploy]
in the commit messages.
For example:
AKR(Frontend): Added new translations [deploy]
The project uses the shared workspace configs. In order to keep code clean and easily maintainable please use the following VS Code Extensions.
To reformat all frontend files for a certain application, run:
yarn <app>:format:write
Prettier Java is used as a code formatter. It enforces a consistent style by parsing your code and re-printing it with its own rules.
To reformat all Java files in a project, run:
mvn validate
CI/CD validates that the files are formatted properly.
If you are using an IDE such as IntelliJ, you might want to configure it to organize imports.
For IntelliJ, you can use the following configurations:
ìmport *
is disabled:
Code Style -> Java -> Imports:
Class count to use import with '*': 999
Names count to use static import with '*': 999
If you are using IntelliJ, you might want to configure it to warn for non-final parameters and variables.
Preferences/Settings > Editor > Inspections > Java > Code style issues > Local variable or parameter can be final
Add this to application-dev.yaml
logging:
level:
org.hibernate.sql: DEBUG
org.hibernate.type: trace
spring:
jpa:
properties:
hibernate:
show_sql: true
use_sql_comments: true
format_sql: true
To create a useful revision history the guidelines of Conventional Commits are broadly followed.
A commit message should be structured as follows:
service(scope): <description>
service: AKR, VKT, OTR, YKI, and SHARED
scope: Frontend, Backend, Docs, Infra
description: Informal description
For example:
AKR(Frontend): Added new translations
Consider writing a detailed commit body when the change is extensive or the reasons behind it are intricate.
Jira ticket numbers are used as branch names with possible suffix indicating what the branch is for.
Used prefixes are feature
, and hotfix
. Below are some examples.
feature/<ticket-number> ----> feature/OPHAKRKEH-250
hotfix/<service-name> ----> hotfix/akr
Ensure the ticket number is included in the pull request title. This enables the association of a commit with its corresponding Jira ticket.
Merging pull requests:
- "Create a merge commit" and "Squash and merge": These options preserve a reference to the pull request and its associated branch.
- "Rebase and Merge": If you choose this option, make sure that commit messages explicitly mention the relevant ticket number.
Production releases for different applications are marked with tags. For example for AKR, tags are named as AKR-ga-1234
where ga-1234
stands for the Github Action workflow number. The name of the tag also matches the name of the release in Jira.
In order to create a new release for example for AKR, check the commit ID of the build to be released, hard reset your local repository to that commit, create tag
git tag AKR-ga-1234
and push the tag to remote repository
git push origin AKR-ga-1234
Vulnerabilities in dependencies used by the applications are scanned daily with Trivy. The scan is performed only against the default branch of the repository.
Results of the scan are uploaded to the GitHub Security tab and are found under the section Code scanning. The results are only available to GitHub users belonging to the Opetushallitus organization.