Event Model

This page describes the types of event messages that are published to destinations (topic/queue) on the message broker for the eHealth Infrastructure

The eHealth Infrastructure publishes numerous events as part of the business processes carried out on the Platform.

This page describes the types of event messages that are published to destinations (topic/queue) on the message broker for the eHealth Infrastructure. Each message consists of a JSON body and additionally some message properties.

Structure of event messages


The JSON body contains the event details, while the message properties enable the use of message selectors when consuming messages from a destination.

For each message type is documented:

  • naming of destination (topic/queue)

  • JSON schema for the message body

  • table of message selector properties

EHealthReferenceEvent

Messages of EHealthReferenceEvent message type are issued when a resource element containing references is updated. Separate messages are issued for references added, and references removed

Destination
topic: Topic is named: [FHIR profile of the resource].[name of resource element]

Message content

Properties
eventType: The type of event
messageType: The name of the message type
messageVersion: The version of the message type, eg. “1.0”
resourceElement: The reference resource element that has changed
resourceReference: The reference (absolute URL) of the resource for which the event message is issued
messageClass: The Java class path of the event message. For internal use (serializing/deserializing from/to Java objects))
patientReference: The reference (absolute URL) to the patient resource, if the resource, for which the event message is issued, is related to a patient
resourceProfile: The FHIR profile of the resource for which the event message is issued

{ "type" : "object", "id" : "urn:jsonschema:com:systematic:ehealth:event:event:EHealthReferenceEvent", "properties" : { "messageType" : { "type" : "string", "description" : "EHealthReferenceEvent" }, "messageVersion" : { "type" : "string", "description" : "1.0" }, "eventType" : { "type" : "string", "description" : "{ enum : [ reference_added, reference_removed ] }" }, "resourceReference" : { "type" : "string", "description" : "The reference (absolute URL) of the resource for which the event message is issued" }, "resourceVersion" : { "type" : "string", "description" : "The version of the resource after change" }, "resourceElement" : { "type" : "string", "description" : "The reference resource element that has changed" }, "references" : { "type" : "array", "description" : "The resource element references (absolute URLs) that were added or removed", "items" : { "type" : "string" } } } }


EHealthSimpleEvent

Messages of EHealthSimpleEvent message type are issued when a resource is created, updated or deleted.

Destination
topic: Topic is named: [FHIR profile of the resource]

Message content

Properties
eventType: The type of event
messageType: The name of the message type
messageVersion: The version of the message type, eg. “1.0”
resourceReference: The reference (absolute URL) of the resource for which the event message is issued
messageClass: The Java class path of the event message. For internal use (serializing/deserializing from/to Java objects))
patientReference: The reference (absolute URL) to the patient resource, if the resource, for which the event message is issued, is related to a patient
resourceProfile: The FHIR profile of the resource for which the event message is issued

 

{ "type" : "object", "id" : "urn:jsonschema:com:systematic:ehealth:event:event:EHealthSimpleEvent", "properties" : { "messageType" : { "type" : "string", "description" : "EHealthSimpleEvent" }, "messageVersion" : { "type" : "string", "description" : "1.0" }, "eventType" : { "type" : "string", "description" : "{ enum : [ created, updated, deleted ] }" }, "resourceReference" : { "type" : "string", "description" : "The reference (absolute URL) of the resource for which the event message is issued" }, "resourceVersion" : { "type" : "string", "description" : "The version of the resource (version after: created, updated, version before: deleted)" } } }

 

Example

Simple Events are published at a CRUD resource level. This means that these can be generated as a side-effect of a business event. In the example below a ServiceRequest has been created as a side-effect of applying a CarePlan to a Patient’s EpisodeOfCare.

{ "messageType": "EHealthSimpleEvent", "messageVersion": "1.0", "eventType": "created", "resourceReference": "http://careplan.inttest.ehealth.sundhed.dk/fhir/ServiceRequest/68", "resourceVersion": "1" } Message properties: { date = Fri, 27 Sep 2019 09:37:59 GMT server = istio-envoy expires = Thu, 01 Jan 1970 00:00:00 GMT x-envoy-upstream-service-time = 1 messageversion = 1.0 transfer-encoding = chunked messagetype = EHealthSimpleEvent x-frame-options = SAMEORIGIN destination = topic://ehealth-servicerequest patientreference = http://patient.inttest.ehealth.sundhed.dk/fhir/Patient/10907 resourcereference = http://careplan.inttest.ehealth.sundhed.dk/fhir/ServiceRequest/68 pragma = no-cache resourceprofile = ehealth-servicerequest content-type = text/plain; charset=ISO-8859-1 eventtype = created id = ID:careplan-6b7f84d69d-sdpkp-39827-1569566074696-1:2:66:3:1 cache-control = no-cache, no-store, must-revalidate messageclass = com.systematic.ehealth.event.event.EHealthSimpleEvent }