Prerequisites • Exercise 0 • Exercise 1 • Exercise 1.1 • Exercise 2 • Exercise 3 • Exercise 4 • Exercise 5 • Exercise 6
The concept of Tasks
exists in both the FHIR and BPMN domains. For this tutorial Task resource
always refers
to FHIR Tasks and Service Task
always means the BPMN concept.
Over the course of the exercises you will mostly likely want to take a look at the DSF FHIR server or DSF BPE server logs.
You can use the logs provided by docker or the debug logs located in dev-setup/{dsfInstance}/bpe/log
and dev-setup/{dsfInstance}/fhir/log
.
The DSF FHIR server also has an audit log available in this directory.
The first exercise focuses on setting up the development environment used in this tutorial and shows how to implement and execute a simple
BPMN process. But first, let's make ourselves familiar with the project structure.
The tutorial project consists of three parts:
- A
test-data-generator
project used to generate X.509 certificates and FHIR resources during the maven build of the project. The certificates and FHIR resources are needed to start DSF instances which simulate installations at three different organizations. - The DSF instances are created using Docker and configured using
a
docker-compose.yml
file in thedev-setup
folder. The docker-compose dev setup uses a single PostgreSQL database server, a single nginx reverse proxy, a keycloak instance as well as three separate DSF FHIR server instances and 3 separate DSF BPE server instances. - The
tutorial-process
project contains all resources (FHIR resources, BPMN models and Java code) for the actual DSF process plugin. Java code for thetutorial-process
project is located atsrc/main/java
, FHIR resources and BPMN process models atsrc/main/resources
as well as prepared JUnit tests to verify your solution atsrc/test/java
.
FHIR resources used in the DSF are formatted as XML. You can find them in the tutorial-process/src/main/resources/fhir
directory.
When creating your own FHIR resources for DSF process plugins you also want to put them in a fitting subdirectory of tutorial-process/src/main/resources/fhir
.
We recommend you take a quick glance at all the topics in the learning
directory to get a
feel for the scope of this tutorial.
In order to solve this exercise, you need to have read the topics on FHIR,
FHIR Task,
The Process Plugin Definition,
Spring Integration, Service Tasks,
Service Delegates,
BPMN Process Execution,
BPMN Process Variables,
Accessing BPMN Process Variables,
About Version, Placeholders and URLs
and Starting a Process via Task Resources.
Solutions to this exercise are found on the branch solutions/exercise-1
.
-
Set the
DicTask
class as the service implementation of the appropriate service task within thedic-process.bpmn
process model. -
Register the
DicTask
class as a prototype bean in theTutorialConfig
class. -
Add a log message to the
DicTask#doExecute
method that logs the recipient organization identifier from the start FHIR Task resource.Don't know where to get a logger?
This project uses slf4j. So use
LoggerFactory
to get yourself a logger instance.Can't find a way to get the start task?
The
doExecute
method provides aVariables
instance. Try it through this one.Don't know where to look for the identifier?
Take a look at the official FHIR Task resource, find elements that have a recipient and manoeuvre your way to those elements using the right getters. Then test which of them has the correct value.
-
In order to start your process you need to either create a regular Task resource or a Draft Task Resource. Based on whether you would like to use cURL or the DSF FHIR server's web interface for starting processes you can do one of the following assignments (although we invite you to do both):
-
Create a Task resource in
tutorial-process/src/main/resources/fhir/example-task.xml
based on the Task profiletutorial-process/src/main/resources/fhir/StructureDefinition/task-start-dic-process.xml
.
You will need it to start your process via cURL.Don't where to get values for organization identifiers?
Take a look at the topic on organization identifiers.
Don't know how to create Task resources?
Take a look at this guide.
-
Create a Draft Task Resource. You will need to be able to create Task resources as a prerequisite. If you don't know how to do this, we recommend checking out the cURL method first and revisiting this assignment after that.
-
Execute a maven build of the dsf-process-tutorial
parent module via:
mvn clean install -Pexercise-1
Verify that the build was successful and no test failures occurred.
To verify the dsfdev_dicProcess
can be executed successfully, we need to deploy it into a DSF instance and execute the process. The maven install
build is configured to create a process jar file with all necessary resources and to copy the jar to the appropriate locations of the docker dev setup.
-
Start the DSF FHIR server for the
dic.dsf.test
organization in a console at location.../dsf-process-tutorial/dev-setup
:docker-compose up dic-fhir
Verify the DSF FHIR server started successfully at https://dic/fhir. The DSF FHIR server uses a server certificate that was generated during the first maven install build. To authenticate yourself to the server you can use the client certificate located at
.../dsf-process-tutorial/test-data-generator/cert/dic-client/dic-client_certificate.p12
(Password:password
). Add the certificate and the generated Root CA located at.../dsf-process-tutorial/test-data-generator/cert/ca/testca_certificate.pem
to your browser certificate store.Caution: If you add the generated Root CA to your browsers certificate store as a trusted Root CA, make sure you are the only one with access to the private key at
.../dsf-process-tutorial/test-data-generator/cert/ca/testca_private-key.pem
. -
Start the DSF BPE server for the
dic.dsf.test
organization in a second console at location.../dsf-process-tutorial/dev-setup
:docker-compose up dic-bpe
Verify the DSF BPE server started successfully and deployed the
dsfdev_dicProcess
. The DSF BPE server should print a message that the process was deployed. The DSF FHIR server should now have a new ActivityDefinition resource. Go tohttps://dic/fhir/ActivityDefinition
to check if the expected resource was created by the BPE while deploying the process. The returned FHIR Bundle should contain a single ActivityDefinition. Also, go tohttps://dic/fhir/StructureDefinition?url=http://dsf.dev/fhir/StructureDefinition/task-start-dic-process
to check if the expected FHIR Task profile was created. -
Start the
dsfdev_dicProcess
by posting an appropriate FHIR Task resource to the DSF FHIR server using either cURL or the DSF FHIR server's web interface. Check out Starting A Process Via Task Resources again if you are unsure.Verify that the FHIR Task resource could be created at the DSF FHIR server. Either look at your docker container log for the DIC FHIR server or find your Task resource in the list of all Task resources under https://dic/fhir/Task/.
Verify that the
dsfdev_dicProcess
was executed by the DSF BPE server. The BPE server should print a message showing that the process was started, print the log message you added to theDicTask
class and end with a message showing that the process finished.
Prerequisites • Exercise 0 • Exercise 1 • Exercise 1.1 • Exercise 2 • Exercise 3 • Exercise 4 • Exercise 5 • Exercise 6