Skip to content

Opetushallitus/kieli-ja-kaantajatutkinnot

Repository files navigation

Kieli- ja kääntäjätutkinnot

AKR OTR VKT YKI Shared Frontend

This mono-repo contains the language and translator services of the Finnish National Agency for Education.

Technologies

  • 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)

 

Services

Below are listed the OPH services which are a part of this mono-repo.

In addition, the shared frontend content can be found here.

 

Development setup initialisation with Docker

  1. Download Docker Desktop
  2. Build containers for a specific app
docker-compose -f docker-compose-<app>.yml build
  1. Run mvn install for the backend: cd backend/<app>; ./mwnw install
  2. 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

Development

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

Github maven authentication

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>

 

Deployment

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]

 

Frontend conventions

Visual Studio Code

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

 

Backend conventions

Styling

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.

 

Organizing imports

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

 

Non-final parameters and variables

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

 

Debugging

Show generated SQL in Spring

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

Git conventions

Commit message conventions

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.

Branching naming conventions

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

GitHub conventions

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.

Releases

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

Security

Vulnerabilities

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.