This project is still early in development. Therefore, until the first major version is released, non-backward changes may be introduced.
API | Supported? | Major Versions Supported |
---|---|---|
Discovery Manifest | ✔️ | 5 |
Echo | ✔️ | 2 |
Institutions | ✔️ | 2 |
Organizational Units | ✔️ | 2 |
Courses | ✔️ | 0 |
Simple Course Replication | ✔️ | 1 |
Interinstitutional Agreements | ✔️ | 4 |
Interinstitutional Agreements CNR | ✔️ | 2 |
Interinstitutional Approval | ✔️ | 1 |
Interinstitutional Approval CNR | ✔️ | 1 |
Mobility Factsheet | ✔️ | 1 |
Outgoing Mobilities | ✔️ | 1 |
Outgoing Mobility Learning Agreements | ✔️ | 1 |
Outgoing Mobility CNR | ✔️ | 1 |
Outgoing Mobility Learning Agreement CNR | ✔️ | 1 |
Incoming Mobilities | ||
Incoming Mobility CNR | ||
Incoming Mobility ToR | ||
Incoming Mobility ToR CNR |
API | Supported? | Major Versions Supported |
---|---|---|
Institutions | ✔️ | 2 |
Organizational Units | ✔️ | 2 |
Courses | ✔️ | 0 |
Simple Course Replication | ✔️ | 1 |
Interinstitutional Agreements | ✔️ | 3 & 4 & 6 |
Interinstitutional Agreements CNR | ✔️ | 2 |
Interinstitutional Approval | ✔️ | 1 |
Interinstitutional Approval CNR | ✔️ | 1 |
Mobility Factsheet | ✔️ | 1 |
Outgoing Mobilities | ✔️ | 1 |
Outgoing Mobility Learning Agreements | ✔️ | 1 |
Outgoing Mobility CNR | ✔️ | 1 |
Outgoing Mobility Learning Agreement CNR | ✔️ | 1 |
Incoming Mobilities | ✔️ | 1 |
Incoming Mobility CNR | ✔️ | 1 |
Incoming Mobility ToR | ✔️ | 1 |
Incoming Mobility ToR CNR | ✔️ | 1 |
To clone and run this project, you"ll need Git and, depending on your preference, Maven or Docker.
To clone the project run:
git clone --recursive https://github.com/ULisboa/ewp-node
Note the --recursive
flag that is needed so the external dependencies configured as submodules are also cloned.
Run the command line:
mvn spring-boot:run
Run the command line:
docker build -t ulisboa/ewp-node .
Run the command line (check the section Docker Image Parameters for reference):
docker run \
--name=ewp-node \
-p 8080:8080 \
-v <path to config folder>:/config \
-v <path to logs folder>:/logs \
--restart unless-stopped \
ulisboa/ewp-node
Write into a docker-compose.yml file (check the section Docker Image Parameters for reference):
---
version: "2.1"
services:
ewp-node:
image: ulisboa/ewp-node
container_name: ewp-node
volumes:
- <path to config folder>:/config
- <path to logs folder>:/logs
ports:
- 8080:8080
healthcheck:
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "--no-check-certificate", "http://localhost:8080/rest/healthcheck"]
interval: 30s
timeout: 10s
retries: 3
start_period: 60s
restart: unless-stopped
Then run on the folder containing that file:
docker-compose up -d
Note: This configuration can be adapted to run on Docker Swarm.
Container images are configured using parameters passed at runtime.
These parameters are separated by a colon and indicate <external>:<internal>
respectively.
For example, -p 80:8080
would expose port 8080 from inside the container to be accessible
from the host"s IP on port 80 outside the container.
Parameter | Function |
---|---|
-p 8080 |
Port used by the server |
-v /config |
Path from where the server will read the configuration when starting. Namely, it expects a file application.yml with the same structure as src/main/resources/application.yml (check this file for an example as well documentation on it). |
-v /logs |
Path where the server will store the logs. |
When the project is running, the endpoint http://localhost:8080/swagger-ui.html will provide an interface to the APIs automatic documentation.
This project is licensed under the terms of the MIT license.