As described in https://ehealth-dk.atlassian.net/wiki/spaces/EDTW/pages/538935313/Behind+the+Scenes#Overview-of-Communication-produced-by-the-Infrastructure, the eHealth Infrastructure automatically creates FHIR Communication (of profile https://docs.ehealth.sundhed.dk/latest-released/ig/StructureDefinition-ehealth-message.html) in various situations.
It is possible to control if and how these FHIR Communication are created through use of FHIR CommunicationRequest (https://docs.ehealth.sundhed.dk/latest-released/ig/StructureDefinition-ehealth-communication-request.html ).
In the descriptions below, the terms opt-in and opt-out are used with the following meaning:
Opt-in: Use of CommunicationRequest by a Patient or CareTeam to get a copy of a Communication (profile ehealth-message) where the Patient or CareTeam is not recipient of the default Communication.
Opt-out: Use of CommunicationRequest by a Patient or CareTeam to suppress creation of the default Communication to the said Patient or CareTeam.
A CareTeam must be involved in an EpisodeOfCare or CarePlan in order to opt-in for Communication referring the EpisodeOfCare and/or CarePlan and/or ServiceRequest.
Adding Control of Message Creation
To control automatic creation of FHIR Communication, create a CommunicationRequest. In addition to the CommunicationRequest elements described below, certain elements must have specific values depending on the situation in which the Infrastructure automatically creates the Communication. See the subsections below.
CommunicationRequest:
subject
= Patient referenceoccurrencePeriod.start
= start of period for which the control appliesoccurrencePeriod.end
= end of period for which the control applies, if known. Otherwise it can be left empty.status
=active
when control is in effect. Can be set to other values as appropriate (one ofdraft | active | on-hold | revoked | completed
).doNotPerform
=false
(or unset) for opt-in or override of medium/payload,true
in order to opt-out (that is, to suppress creation)
CommunicationRequest subject
shall not be set for control of message creation regarding:
Automated creation of
medium
nemsms
Communication when Communication with categorymessage
and Patient asrecipient
createdReminder about appointment
How to set remaining elements of the CommunicationRequest vary with situation, see below.
The Communication.category
is set depending on the intended use and involved recipients. See the section Introduction on https://docs.ehealth.sundhed.dk/latest-released/ig/StructureDefinition-ehealth-message.html for details. When a Communication with category
=message
is created to do human-human communication, it can be controlled whether to also send a mobile text message (NemSMS) to a Patient recipient as described on https://docs.ehealth.sundhed.dk/latest-released/ig/StructureDefinition-ehealth-message.html#automatic-nemsms-notifications. This requires opt-in as it is not the default behavior.
Controlling Message Creation with Patient as Recipient
The table below describes the various situations in which automatic creation of FHIR Communication (ehealth-message) takes place. In the table, the columns following the naming pattern Element <some element name> describe what values must be used in a corresponding CommunicationRequest in order to control creation.
To apply for FHIR Communication with the Patient as recipient, add the following to the CommunicationRequest:
recipient
= Patient referencecategory
= <depending on situation>reasonCode
= <depending on situation>episodeOfCare
= <depending on situation>basedOn
= <depending on situation>priority
= <depending on situation>
Situation | Created by Default | Opt-in Supported | Opt-out Supported | Payload and Medium Overridable | Element category | Element reasonCode | Element episodeOfCare | Element basedOn | Element priority |
---|---|---|---|---|---|---|---|---|---|
Unexpected measurement submitted | No | Yes | No | Yes |
|
| ServiceRequest reference | ||
Missing measurement determined | No | Yes | No | Yes |
|
| ServiceRequest reference | ||
Reminder to submit measurement (about to be created) | Yes | No | Yes | Yes |
|
| EpisodeOfCare reference | ||
Communication created by triage (or other infrastructure rules) | No | Yes | No | Yes |
| Depends on rule | ServiceRequest reference | Depends on rule | |
EpisodeOfCare created | No | Yes | No | Yes |
|
| |||
EpisodeOfCare changed (in team, status, scheduledStatus or scheduledTeam) | No | Yes | No | Yes |
|
| EpisodeOfCare reference | ||
CarePlan created/changed (in careTeam, status, scheduledStatus or scheduledTeam) | No | Yes | No | Yes |
|
| EpisodeOfCare reference | ||
Reminder about appointment | Yes | No | Yes | Yes |
|
| EpisodeOfCare reference (optional) If specified, the CommunicationRequest is specific to Appointment referencing the EpisodeOfCare. See section on scope of message creation control below. | ||
Automated creation of | No | Yes | No | Only |
| Same as ehealth-message (optional) When omitted, it corresponds to match on all ehealth-message reasonCodes. See section on scope of message creation control below. | EpisodeOfCare reference (optional) If specified, the CommunicationRequest is specific to Communication resources referencing the EpisodeOfCare. See section on scope of message creation control below. |
Currently, no infrastructure rules (see Library Resources) cause creation of Communication. Neither with Patient or CareTeam as recipient.
Controlling Message Creation with CareTeam as Recipient
The table below describes the various situations in which automatic creation of FHIR Communication (ehealth-message) takes place. In the table, the columns following the naming pattern Element <some element name> describe what values must be used in a corresponding CommunicationRequest in order to control creation.
To apply for FHIR Communication with a CareTeam as recipient, add the following to the CommunicationRequest:
recipient
= CareTeam referencecategory
= <depending on situation>reasonCode
= <depending on situation>episodeOfCare
= <depending on situation>basedOn
= <depending on situation>priority
= <depending on situation>
Situation | Created by Default | Opt-in Supported | Opt-out Supported | Payload and Medium Overridable | Element category | Element reasonCode | Element episodeOfCare | Element basedOn | Element priority |
---|---|---|---|---|---|---|---|---|---|
Unexpected measurement submitted | No | Yes | No | No |
|
| ServiceRequest reference | ||
Missing measurement determined | Yes | No | Yes | No |
|
| ServiceRequest reference | ||
Communication created by triage (or other infrastructure rules) | Yes | No | Yes | No | depends on rule | depends on rule | ServiceRequest reference | depends on rule | |
EpisodeOfCare created | Yes | No | Yes | No |
|
| |||
EpisodeOfCare changed (in team, status, scheduledStatus or scheduledTeam) | Yes | No | Yes | No |
|
| EpisodeOfCare reference | ||
CarePlan created/changed (in careTeam, status, scheduledStatus or scheduledTeam) | Yes | No | Yes | No |
|
| EpisodeOfCare reference | ||
Reminder about appointment | No | Yes | No | Only |
|
| EpisodeOfCare reference |
Scope of the Message Creation Control
Search Algorithms for CommunicationRequest applied in the Infrastructure
In general, the different micro services of the Infrastructure perform a single search for CommunicationRequest using the following search parameters:
CommunicationRequest.occurencePeriod
covers current datetime at time of searchCommunicationRequest.status
=active
CommunicationRequest.recipient
matchesCommunication.recipient
or would-be recipient (for opt-in)
In addition, search parameters are added depending on the situation as described in the sections below. For some situations, the search algorithm includes multiple searches.
Search algorithm for situation “Reminder about appointment”
Additional search parameters:
CommunicationRequest.meta.tag
matchesCommunication.meta.tag
(compared for co-existence tags only)
The algorithm entails multiple searches in the following order:
Search for CommunicationRequest resources where both
CommunicationRequest.episodeOfCare
andCommunicationRequest.reasonCode
match that of the Communication. If no results are found continue with next step.Search for CommunicationRequest resources where no
CommunicationRequest.episodeOfCare
is present andCommunicationRequest.reasonCode
matches that of the Communication. If no results are found continue with next step.
Search algorithm for situation “Automated creation of medium nemsms Communication when Communication with category message and Patient as recipient created”
For most situations only a fixed set of reasonCodes are considered. However, a few remarks are in place for the situation “Automated creation of medium nemsms…”: When creating Communication/ehealth-message resources it is possible to specify a reasonCode, which provides the reason for the exchange of information. Using CommunicationRequest resources it is possible to opt-in for automatically created notifications about new messages. The set of reasonCodes is dynamic by nature when it comes to ehealth-message, that is, it may expand over time. Therefore it is meaningful to be able to create a CommunicationRequest, which is valid over time (for all or a specific EpisodeOfCare), and not sensitive to the introduction of new reasonCodes. Alternatively, it would be required to create new CommunicationRequest resources when introducing new reasonCodes, which would be rather cumbersome. Therefore, the semantics around CommunicationResource for ehealth-message notifications is slightly different than for other infrastructure events. For ehealth-message notifications (ie. the possibility for an automatically created ehealth-message with category=“notification”, medium=“nemsms”, and reasonCode copied from the original ehealth-message), it is possible to create a CommunicationRequest with no reasonCode provided, which will then logically match all possible ehealth-message reasonCodes (in contrast to other situations).
Additional search parameters:
CommunicationRequest.meta.tag
matchesCommunication.meta.tag
(compared for co-existence tags only)
The algorithm entails multiple searches in the following order:
Search for CommunicationRequest resources where both
CommunicationRequest.episodeOfCare
andCommunicationRequest.reasonCode
match that of the Communication. If no results are found continue with next step.Search for CommunicationRequest resources where
CommunicationRequest.episodeOfCare
matches that of the Communication and noCommunicationRequest.reasonCode
is present. If no results are found continue with next step.Search for CommunicationRequest resources where no
CommunicationRequest.episodeOfCare
is present andCommunicationRequest.reasonCode
matches that of the Communication. If no results are found continue with next step.Search for CommunicationRequest resources where no
CommunicationRequest.episodeOfCare
and noCommunicationRequest.reasonCode
are present. If no results are found, default behavior applies
Search algorithm for situation EpisodeOfCare created
Additional search parameters:
CommunicationRequest.meta.tag
matchesCommunication.meta.tag
(compared for co-existence tags only)The same additional search parameters as for the remaining situations (see below)
Search algorithm for remaining situations
Additional search parameters:
CommunicationRequest.reasonCode
matchesCommunication.reasonCode
CommunicationRequest.category
matchesCommunication.category
Conditional search parameters depending on the situation (see the tables above):
CommunicationRequest.episodeOfCare
matchesCommunication.episodeOfCare
CommunicationRequest.basedOn
matchesCommunication.basedOn
Selection algorithm
When the results of searching by the algorithms described above results in more than one CommunicationRequest, selection of a single CommunicationRequest is performed as follows (stopping whenever a single CommunicationRequest is left):
If multiple results exist, choose the one with the most recent
occurencePeriod.start
If multiple results exist choose those with
doNotPerform = true
(preference for message suppression)If multiple results exist choose a random one
Overriding the Payload and/or Medium
Example of CommunicationRequest for overriding payload and medium (adding NemSMS). For overriding default NemSMS medium, simply leave medium in CommunicationRequest empty.
Ending a Message Creation Control
To remove the effect of a CommunicationRequest, perform a CommunicationRequest Update and set the status
to completed
. If the CommunicationRequest uses occurrencePeriod
and has no occurrencePeriod.end
, it would be consistent to set it to time of completing the CommunicationRequest.