Upstream: https://version.helsinki.fi/OPADev/moodi-app
This project is mirrored to GitHub for public visibility. The canonical repository is at the upstream link above. Do not push directly to GitHub.
Moodi is an integration application that automates course creation and user enrollment to Moodle based on master data from Sisu.
- Sisu (Master data source for courses and course students and teachers)
- Moodle (Target for modification operations by Moodi. Course spaces are created and users are enrolled via Moodle api by Moodi application)
Currently Moodi has 4 environments: local, local_docker, dev, and prod. Integrations are mapped for each environment in corresponding application-.yml. local_docker is meant to be used with the [dockerized development environment] (https://github.com/UH-StudentServices/moodi-development) (see below).
The application utilizes two servers:
- QA server: moodi-qa-23.it.helsinki.fi
- Production server: moodi-prod-23.it.helsinki.fi
Port 443 is open at UH for internal, VPN networks, and the Silta environment.
Deployment processes leverage GitLab CI for testing, building, and deployment initiation. Deployments occur within a separate project, moodi-infra. The QA server receives automatic deployments upon new commits to the master branch. Production deployments are manual, initiated by executing the release prod
job in the GitLab CI pipeline. The GitLab Package Registry stores the application's Maven package. For detailed information, refer to .gitlab-ci.yml.
The following programs must be installed if not using the dockerized development environment:
- JDK 11
This is an integration application and as such running locally requires a lot of setup work with ssh tunnels, certificates etc. The recommended way to test changes to the application locally is by running automated tests. Therefore good automated test coverage is essential when new features are added.
You can use also the dockerized development environment to run the application with Moodle locally (see below for more information).
./gradlew test
# or
./gradlew test_psql # To run against a local Dockerized Postgres, see below.
This is normally done in Gitlab CI (see pipelines), but if you want to test them locally, you need to go through
an ssh tunnel via moodi-qa
, because the Moodle API has IP restrictions in place.
Open a ssh tunnel to call the Moodle API:
ssh moodi-qa-23.it.helsinki.fi -L 1444:moodi-2-moodle-20.student.helsinki.fi:443
Into /etc/hosts:
127.0.0.1 moodi-2-moodle-20.student.helsinki.fi
Then run the tests
# Get the token from moodi-qa-23.it.helsinki.fi:/opt/moodi/config/moodi.properties
read MOODLE_WS_TOKEN
./gradlew itest --rerun-tasks -Pmoodle_base_url=https://moodi-2-moodle-20.student.helsinki.fi:1444/moodlecurrent/webservice/rest/server.php -Pmoodle_ws_token=$MOODLE_WS_TOKEN
Open an ssh tunnel to call Sisu through the test API GW and the Moodle API:
ssh moodi-qa-23.it.helsinki.fi -L 1443:gw-api-test.it.helsinki.fi:443 -L 1444:moodi-2-moodle-20.student.helsinki.fi:443
The file ~/moodi/moodi.properties needs to exist:
httpClient.keystoreLocation: /path/to/moodi-app/moodi.p12
httpClient.keystorePassword: <see moodi-dev:/opt/moodi/config/moodi.properties>
integration.moodle.wstoken: <see moodi-dev:/opt/moodi/config/moodi.properties>
Copy moodi-dev:/opt/moodi/config/keystore/moodi.p12 this directory.
Into /etc/hosts:
127.0.0.1 gw-api-test.it.helsinki.fi
127.0.0.1 moodi-2-moodle-20.student.helsinki.fi
application-dev.yml:
moodle:
baseUrl: https://moodi-2-moodle-20.student.helsinki.fi:1444/moodlecurrent
sisu:
baseUrl: https://gw-api-test.it.helsinki.fi:1443/secure/sisu
apiKey: <see https://api-test.it.helsinki.fi/portal/applications/f2d7ede8-2810-4a1e-97ed-e828100a1e4a/subscriptions?subscription=e959b407-023e-499a-99b4-07023e399adb#s>
./gradlew bootRun
The test UI is now available at http://localhost:8084/login Credentials are: user/password
- Comment out the line in /etc/hosts.
- Delete local moodi.p12
- Remove the keystore password and Moodle token from ~/moodi/moodi.properties
There is a separate project for running the whole application in Docker containers. See https://github.com/UH-StudentServices/moodi-development for more information.
In this project there is few additions to support the dockerized environment:
app.Dockerfile
contains the Dockerfile for the Java app. It is not directly usable without the docker-compose.yml in the moodi-development project.src/main/resources/config/application-local_docker.yml
contains the configuration for the app when running in the dockerized environment.
To make the app.Dockerfile
file more flexible a configuration file should support setting configuration
related to external services (API-GW, Moodle) via environment variables either by developing moodi-development project further or by adding a new configuration file for this purpose. Also some settings could be moved to
moodi.properties
file for supporting the easier configuration of the app.
The server environments use Postgres 16.
The local environment and tests use a H2 database.
Use this, if you want to test DB changes locally with Postgres. For example, if you want to test column type changes with existing data in the DB.
The DB is populated with a dump from Moodi dev environment.
Start the DB by running
docker-compose up
To clear the data, first stop the container and then:
docker rm moodi-postgres
docker volume rm moodi-app_moodi-postgres-data
To create a new dump:
ssh moodi-qa-23.it.helsinki.fi
sudo su - postgres
pg_dump -x -f moodi_dump.sql moodi
# Then copy the new dump file over docker-entrypoint-initdb.d/moodi_dump.sql