An intermediary component between Glaciation Frontend and Metadata Service. The service adapts user interface queries into a series of SPARQL requests to MetadataService and telemetry requests from Storage Service. The service also checking user permissions via oauth server and filters the KGs that a user is not allowed to access.
Work on the server and client is conducted in their respective directories: server and client, as the server-side and client-side parts have different dependencies, configurations, etc.
Python 3.10+
pip install pre-commit
pre-commit install
Go to the /server
folder to install dependencies and work on the server application.
Documentation on setting up the virtual environment, installing dependencies, and working with the server can be found here.
Go to the /client
folder to install dependencies and work on the client application.
Documentation on setting up the virtual environment, installing dependencies, and working with the client can be found here.
The application version is specified in the VERSION file. The version should follow the format a.a.a, where 'a' is a number.
To create a release, update the version in the VERSION file and add a tag in GIT.
The release version for branches, pull requests, and tags will be generated based on the base version in the VERSION file.
GitHub Actions triggers testing, builds, and application publishing for each release.
https://docs.github.com/en/actions
During the build and publish process, a Docker image is built, a Helm chart is created, an openapi.yaml is generated.
Initial setup
- Create the branch gh-pages and use it as a GitHub page https://pages.github.com/.
- Set up secrets at
https://github.com/glaciation-heu/ui_gateway/settings/secrets/actions
:
- PYPI_TOKEN - The secret token for PyPI. https://pypi.org/help/#apitoken
After execution
- The index.yaml file containing the list of Helm charts will be available at
https://glaciation-heu.github.io/ui_gateway/helm-charts/index.yaml
. You can this URL on https://artifacthub.io/. - A package of the client will be available at pypi.org.
HIRO uses and requires from its partners GitFlow with Forks