To run the portal locally, you can use the docker-compose file in the /docker folder.
However, a few additional manual steps are required.
A special tomcat container is used, "portal-full", which contains all the services required to run the portal in a single docker image. This is to reduce the amount of resources needed, making it possible to run everything on a single laptop.
Next, to build the portal-full image, you can use the following command:
cd docker && docker buildx bake local-dev --load
Be aware this can take a while, especially the first time.
In order to speed up the build process, we customize the gradle builder image.
Mostly so we can override the maven repositories used by the australian projects.
Details can be found in the gradle docker folder.
Building all these images, all at once can use a large amount of resources. If you want to be able to do other things while building, you might want to limit the required reousrces. That way your computer does not risk becoming entirely unresponsive.
To do this, create and use a custom buildx builder based on the builkitd config provided in the docker folder. Like so:
docker buildx create --use --bootstrap \
--name vbp-builder \
--driver docker-container \
--config ./docker/buildkitd.toml
This limits the amount of tasks the builder will run in parallel to avoid overloading your computer. (especially you memory)
The platform requires a hostname that resolves to the same thing by both the services, running inside docker containers and the client browser.
On linux you can edit your /etc/hosts
file to look something like this:
127.0.0.1 localhost host.docker.internal
We need to generate the static front-end pages.
These are used for the landing page and the custom UI branding.
To do this, you need to run the following command in the branding folder
cd branding
git submodule update --init --recursive
cd commonui-bs3-2019
npm install
npx gulp build
cd ..
npm install
npm run build
Finally, we can start the services using the following command:
docker-compose -f docker/docker-compose.yaml up
The portal uses local databases, all initialized correctly, but entirely empty. We are still working on a way to provide a local database with some test data.
Alternatively, you can use port-forwarding to use remote databases.
Especially for solr, this can be useful, as it can take a long time to index all the data.
Simply comment out the solr docker instances and start a port-forwarding process:
ssh ubuntu@<ip of bastion server> -N -L 0.0.0.0:8983:solr.biodiversiteitsportaal.dev.internal:8983
We use mock-oauth2 to simulate an openid-connect service.
Simply use whatever name you want went prompted for a login.
On order to access the platform as admin, simply adding the json below should work
{
"role": "ROLE_ADMIN"
}
To allow easy debugging, the portal image can be started with REMOTE_DEBUGGER_PORT: 5005
as environment variable.
This make it possible to attach a remote JVM debugger to the 5005 port.
All the services, running in the portal-full image, can be debugged this way.
Because some AWS Cloud services are not available locally, alternatives are used in the local environment. These are:
- nginx
Instead of the AWS Application Load Balancer and the AWS CloudFront distribution with static pages. - mock-oauth2
Instead of AWS Cognito for user authentication and authorization. - mailhog
Instead of SES a smtp server.