Creating a docker image should be as simple as docker build -t spre-gosys-pdf .
To run the application with templates, data and fonts locally mounted you can use
docker run \
-v /full/path/to/templates:/app/templates \
-v /full/path/to/fonts:/app/fonts \
-v /full/path/to/data:/app/data \
-v /full/path/to/resources:/app/resources \
-p 8080:8080 \
-e DISABLE_PDF_GET=false \
-it \
--rm \
ghcr.io/navikt/pdfgen:2.0.64
Or you can use the convenience script ./run_development.sh
When running the application you can use the env var DISABLE_PDF_GET
to enable GET requests at
/api/v1/genpdf/<application>/<template>
which looks for test data at data/<application>/<template>.json
and outputs
a PDF to your browser. Additionally, the template folder will be fetched on every request, and reflect any changes made
since the last GET, making this ideal for developing new templates for your application.
The template and data directory structure both follow the <application>/<template>
structure.
Example url: http://0.0.0.0:8080/api/v1/genpdf/spre-gosys/vedtak-v2
It is a known issue that pdfgen's output documents look different depending on whether the template
has \r\n
or \n
as line endings. Therefore, it is strongly recommended to configure Git to not convert newlines, as well as ensure that your editor ends its lines with LF (\n
) and not CRLF (\r\n
), as the former will accurately show what your
templates will look like in production.
Code and project related questions should be asked as issues on this GitHub repo.
We are available at the Slack channel #område-helse.