ISiKSubscription (Subscription)
ISiK Subscription
ISiK Subscription
Motivation
Subscription ist eine FHIR Ressource, um als Client-System Benachrichtigungen über Events auf dem FHIR Server anzufragen. Der Subscription Mechanismus in FHIR R4 ist nicht geeignet, um alle relevanten Events (hier im Speziellen das Mergen von Patienten) zu unterstützen. Daher basiert das ISiK Subscription-Profil auf dem Subscriptions R5 Backport Profil von HL7.
Um als Subsystem über ein Subsription-Event informiert zu werden, KANN der FHIR Subscription Mechanismus gemäß des Subscriptions R5 Backport IGs von HL7 genutzt werden.
Kompatibilität
Das Profil ISiKSubscription basiert auf dem Backport-Subscription Profil. Der SubscriptionStatus, sowie das Subscription Notification Bundle werden unverändert direkt aus dem Subscriptions R5 Backport IG genutzt.
Hinweise zu Inkompatibilitäten können über die Portalseite gemeldet werden.
Bestätigungsrelevanz
Verbindlichkeit | SHALL |
---|
Metadaten
Canonical | https://gematik.de/fhir/isik/StructureDefinition/ISiKSubscription |
---|---|
Status | active |
Version | 5.0.0 |
Basis | http://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition/backport-subscription |
Inhalt
ISiKSubscription (Subscription) | I | ||
id | Σ | 0..1 | id |
meta | Σ | 0..1 | Meta |
implicitRules | Σ ?! | 0..1 | uri |
language | 0..1 | codeBinding | |
text | 0..1 | Narrative | |
contained | I | 0..* | Resource |
extension | I | 0..* | Extension |
modifierExtension | ?! I | 0..* | Extension |
status | S Σ ?! | 1..1 | codeBinding |
contact | Σ | 0..* | ContactPoint |
end | Σ | 0..1 | instant |
reason | S Σ | 1..1 | string |
criteria | S Σ | 1..1 | stringBinding |
id | 0..1 | string | |
extension | I | 0..* | Extension |
filterCriteria | S Σ I | 0..* | Extension(string) |
id | 0..1 | id | |
extension | I | 0..0 | Extension |
url | 1..1 | uriFixed Value | |
value[x] | S | 0..1 | |
valueString | string | ||
value | 0..1 | System.String | |
error | Σ | 0..1 | string |
channel | S Σ | 1..1 | BackboneElement |
id | 0..1 | string | |
extension | I | 0..* | Extension |
heartbeatPeriod | S I | 0..1 | Extension(unsignedInt) |
id | 0..1 | id | |
extension | I | 0..0 | Extension |
url | 1..1 | uriFixed Value | |
value[x] | S | 0..1 | |
valueUnsignedInt | unsignedInt | ||
timeout | I | 0..1 | Extension(unsignedInt) |
maxCount | I | 0..1 | Extension(positiveInt) |
modifierExtension | Σ ?! I | 0..* | Extension |
type | S Σ | 1..1 | codeBinding |
id | 0..1 | string | |
extension | I | 0..* | Extension |
customChannelType | S Σ I | 0..0 | Extension(Coding) |
value | 0..1 | System.String | |
endpoint | S Σ | 0..1 | url |
payload | S Σ | 1..1 | codeBinding |
id | 0..1 | string | |
extension | I | 1..* | Extension |
content | S Σ I | 1..1 | Extension(code) |
value | 0..1 | System.String | |
header | S Σ | 0..* | string |
<StructureDefinition xmlns="http://hl7.org/fhir"> <id value="ISiKSubscription" /> <url value="https://gematik.de/fhir/isik/StructureDefinition/ISiKSubscription" /> <version value="5.0.0" /> <name value="ISiKSubscription" /> <title value="ISiK Subscription" /> <status value="active" /> <experimental value="false" /> <date value="2025-06-26" /> <publisher value="gematik GmbH" /> <description value="ISiK Subscription \n### Motivation\n\nSubscription ist eine FHIR Ressource, um als Client-System Benachrichtigungen über Events auf dem FHIR Server anzufragen. Der Subscription Mechanismus in FHIR R4 ist nicht geeignet, um alle relevanten Events (hier im Speziellen das Mergen von Patienten) zu unterstützen. Daher basiert das ISiK Subscription-Profil auf dem [Subscriptions R5 Backport Profil von HL7](https://hl7.org/fhir/uv/subscriptions-backport/STU1.1/StructureDefinition-backport-subscription.html).\n\nUm als Subsystem über ein Subsription-Event informiert zu werden, KANN der FHIR Subscription Mechanismus gemäß des [Subscriptions R5 Backport IGs von HL7](https://hl7.org/fhir/uv/subscriptions-backport/STU1.1/index.html) genutzt werden.\n\n### Kompatibilität\n\nDas Profil ISiKSubscription basiert auf dem [Backport-Subscription Profil](https://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition-backport-subscription.html).\nDer [SubscriptionStatus](https://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition-backport-subscription-status-r4.html), sowie das [Subscription Notification Bundle](https://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition-backport-subscription-notification-r4.html) werden unverändert direkt aus dem [Subscriptions R5 Backport IG](https://hl7.org/fhir/uv/subscriptions-backport/index.html) genutzt. \n\nHinweise zu Inkompatibilitäten können über die [Portalseite](https://service.gematik.de/servicedesk/customer/portal/16) gemeldet werden." /> <fhirVersion value="4.0.1" /> <kind value="resource" /> <abstract value="false" /> <type value="Subscription" /> <baseDefinition value="http://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition/backport-subscription" /> <derivation value="constraint" /> <differential> <element id="Subscription.status"> <path value="Subscription.status" /> <short value="Status" /> <comment value="**Bedeutung:** Der Status der Subscription, der den Serverstatus der Subscription angibt. \n Neue Subscriptions werden immer mit dem Status `requested` an den Server übergeben. \n Der Server ändert im Anschluss den Status auf `active` oder im Fehlerfall auf `error`." /> <mustSupport value="true" /> </element> <element id="Subscription.reason"> <path value="Subscription.reason" /> <short value="Grund der Subscription" /> <comment value="**Bedeutung:** Beschreibung wieso diese Subscription erstellt wurde." /> <mustSupport value="true" /> </element> <element id="Subscription.criteria"> <path value="Subscription.criteria" /> <short value="Canonical URL des SubscriptionTopic welches man abonnieren möchte." /> <comment value="Enthält eines der in ISiK vereinbarten Subsription Topics." /> <binding> <strength value="extensible" /> <valueSet value="https://gematik.de/fhir/isik/ValueSet/ISiKSubscriptionTopicVS" /> </binding> </element> <element id="Subscription.criteria.extension:filterCriteria"> <path value="Subscription.criteria.extension" /> <sliceName value="filterCriteria" /> <short value="Filterkriterium." /> <comment value="**Bedeutung:** Filterkriterium für die Subscription. Dieses Feld ist optional und kann genutzt werden, um die Subscription auf bestimmte Events zu filtern." /> </element> <element id="Subscription.criteria.extension:filterCriteria.value[x]"> <path value="Subscription.criteria.extension.value[x]" /> <mustSupport value="true" /> </element> <element id="Subscription.channel"> <path value="Subscription.channel" /> <short value="Kommunikationskanal" /> <comment value="**Bedeutung:** Kommunikationskanal über den die Subscription Benachrichtigungen gesendet werden sollen." /> <mustSupport value="true" /> </element> <element id="Subscription.channel.extension:heartbeatPeriod"> <path value="Subscription.channel.extension" /> <sliceName value="heartbeatPeriod" /> <short value="Heartbeat-Intervall" /> <comment value="**Bedeutung:** Intervall in dem der Server prüft, ob der Kommunikationskanal noch aktiv ist." /> <mustSupport value="true" /> </element> <element id="Subscription.channel.extension:heartbeatPeriod.value[x]"> <path value="Subscription.channel.extension.value[x]" /> <mustSupport value="true" /> </element> <element id="Subscription.channel.type"> <path value="Subscription.channel.type" /> <short value="Typ des Kommunikationskanals" /> <comment value="**Bedeutung:** Der Typ des Kommunikationskanals, über den Subscription-Benachrichtigungen gesendet werden sollen. \n In ISiK MUSS der Wert `rest-hook` unterstützt werden, weitere Werte KÖNNEN unterstützt werden." /> <mustSupport value="true" /> </element> <element id="Subscription.channel.type.extension:customChannelType"> <path value="Subscription.channel.type.extension" /> <sliceName value="customChannelType" /> <short value="Custom Channel Type" /> <comment value="**Bedeutung:** Custom Channel Type welcher in ISiK aktuell nicht unterstützt wird." /> <max value="0" /> </element> <element id="Subscription.channel.endpoint"> <path value="Subscription.channel.endpoint" /> <short value="Endpunkt" /> <comment value="**Bedeutung:** Adresse des Kommunikationskanals/ Endpunkts, an den Subscription-Benachrichtigungen gesendet werden sollen. Dies ist nur für rest-hook Subscriptions relevant." /> <mustSupport value="true" /> </element> <element id="Subscription.channel.payload"> <path value="Subscription.channel.payload" /> <short value="Format der Nutzdaten" /> <comment value="**Bedeutung:** Format in dem Subscription Notifications versendet werden sollen (JSON oder XML)." /> <mustSupport value="true" /> <binding> <strength value="required" /> <valueSet value="https://gematik.de/fhir/isik/ValueSet/FhirMimeTypeVS" /> </binding> </element> <element id="Subscription.channel.payload.extension:content"> <path value="Subscription.channel.payload.extension" /> <sliceName value="content" /> <short value="Inhalt der Nutzdaten" /> <comment value="**Bedeutung:** Welcher Ressourceninhalt in der Nutzlast der Benachrichtigung geliefert werden soll. \n Zur Auswahl stehen eine leere Nutzlast (`empty`), nur die Ressourcen-id (`id-only`) oder der gesamte Inhalt der Ressource (`full-resource`)." /> </element> <element id="Subscription.channel.header"> <path value="Subscription.channel.header" /> <short value="Falls eine REST-Enpunkt einen Authorization-Header benötigt, kann dieser hier gesetzt werden" /> <comment value="**Bedeutung:** http-Header welcher dazu genutzt werden kann einen Authorization-header zu setzen. Dies ist nur für rest-hook Subscriptions relevant. \n **Hinweise:** ACHTUNG: dieses Datenfeld muss bei READ-Interaktionen maskiert werden! Siehe [R4 Subscriptions](https://hl7.org/fhir/R4/subscription.html)" /> <mustSupport value="true" /> </element> </differential> </StructureDefinition>
{ "resourceType": "StructureDefinition", "id": "ISiKSubscription", "url": "https://gematik.de/fhir/isik/StructureDefinition/ISiKSubscription", "version": "5.0.0", "name": "ISiKSubscription", "title": "ISiK Subscription", "status": "active", "experimental": false, "date": "2025-06-26", "publisher": "gematik GmbH", "description": "ISiK Subscription \n### Motivation\n\nSubscription ist eine FHIR Ressource, um als Client-System Benachrichtigungen über Events auf dem FHIR Server anzufragen. Der Subscription Mechanismus in FHIR R4 ist nicht geeignet, um alle relevanten Events (hier im Speziellen das Mergen von Patienten) zu unterstützen. Daher basiert das ISiK Subscription-Profil auf dem [Subscriptions R5 Backport Profil von HL7](https://hl7.org/fhir/uv/subscriptions-backport/STU1.1/StructureDefinition-backport-subscription.html).\n\nUm als Subsystem über ein Subsription-Event informiert zu werden, KANN der FHIR Subscription Mechanismus gemäß des [Subscriptions R5 Backport IGs von HL7](https://hl7.org/fhir/uv/subscriptions-backport/STU1.1/index.html) genutzt werden.\n\n### Kompatibilität\n\nDas Profil ISiKSubscription basiert auf dem [Backport-Subscription Profil](https://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition-backport-subscription.html).\nDer [SubscriptionStatus](https://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition-backport-subscription-status-r4.html), sowie das [Subscription Notification Bundle](https://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition-backport-subscription-notification-r4.html) werden unverändert direkt aus dem [Subscriptions R5 Backport IG](https://hl7.org/fhir/uv/subscriptions-backport/index.html) genutzt. \n\nHinweise zu Inkompatibilitäten können über die [Portalseite](https://service.gematik.de/servicedesk/customer/portal/16) gemeldet werden.", "fhirVersion": "4.0.1", "kind": "resource", "abstract": false, "type": "Subscription", "baseDefinition": "http://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition/backport-subscription", "derivation": "constraint", "differential": { "element": [ { "id": "Subscription.status", "path": "Subscription.status", "short": "Status", "comment": "**Bedeutung:** Der Status der Subscription, der den Serverstatus der Subscription angibt. \n Neue Subscriptions werden immer mit dem Status `requested` an den Server übergeben. \n Der Server ändert im Anschluss den Status auf `active` oder im Fehlerfall auf `error`.", "mustSupport": true }, { "id": "Subscription.reason", "path": "Subscription.reason", "short": "Grund der Subscription", "comment": "**Bedeutung:** Beschreibung wieso diese Subscription erstellt wurde.", "mustSupport": true }, { "id": "Subscription.criteria", "path": "Subscription.criteria", "short": "Canonical URL des SubscriptionTopic welches man abonnieren möchte.", "comment": "Enthält eines der in ISiK vereinbarten Subsription Topics.", "binding": { "strength": "extensible", "valueSet": "https://gematik.de/fhir/isik/ValueSet/ISiKSubscriptionTopicVS" } }, { "id": "Subscription.criteria.extension:filterCriteria", "path": "Subscription.criteria.extension", "sliceName": "filterCriteria", "short": "Filterkriterium.", "comment": "**Bedeutung:** Filterkriterium für die Subscription. Dieses Feld ist optional und kann genutzt werden, um die Subscription auf bestimmte Events zu filtern." }, { "id": "Subscription.criteria.extension:filterCriteria.value[x]", "path": "Subscription.criteria.extension.value[x]", "mustSupport": true }, { "id": "Subscription.channel", "path": "Subscription.channel", "short": "Kommunikationskanal", "comment": "**Bedeutung:** Kommunikationskanal über den die Subscription Benachrichtigungen gesendet werden sollen.", "mustSupport": true }, { "id": "Subscription.channel.extension:heartbeatPeriod", "path": "Subscription.channel.extension", "sliceName": "heartbeatPeriod", "short": "Heartbeat-Intervall", "comment": "**Bedeutung:** Intervall in dem der Server prüft, ob der Kommunikationskanal noch aktiv ist.", "mustSupport": true }, { "id": "Subscription.channel.extension:heartbeatPeriod.value[x]", "path": "Subscription.channel.extension.value[x]", "mustSupport": true }, { "id": "Subscription.channel.type", "path": "Subscription.channel.type", "short": "Typ des Kommunikationskanals", "comment": "**Bedeutung:** Der Typ des Kommunikationskanals, über den Subscription-Benachrichtigungen gesendet werden sollen. \n In ISiK MUSS der Wert `rest-hook` unterstützt werden, weitere Werte KÖNNEN unterstützt werden.", "mustSupport": true }, { "id": "Subscription.channel.type.extension:customChannelType", "path": "Subscription.channel.type.extension", "sliceName": "customChannelType", "short": "Custom Channel Type", "comment": "**Bedeutung:** Custom Channel Type welcher in ISiK aktuell nicht unterstützt wird.", "max": "0" }, { "id": "Subscription.channel.endpoint", "path": "Subscription.channel.endpoint", "short": "Endpunkt", "comment": "**Bedeutung:** Adresse des Kommunikationskanals/ Endpunkts, an den Subscription-Benachrichtigungen gesendet werden sollen. Dies ist nur für rest-hook Subscriptions relevant.", "mustSupport": true }, { "id": "Subscription.channel.payload", "path": "Subscription.channel.payload", "short": "Format der Nutzdaten", "comment": "**Bedeutung:** Format in dem Subscription Notifications versendet werden sollen (JSON oder XML).", "mustSupport": true, "binding": { "strength": "required", "valueSet": "https://gematik.de/fhir/isik/ValueSet/FhirMimeTypeVS" } }, { "id": "Subscription.channel.payload.extension:content", "path": "Subscription.channel.payload.extension", "sliceName": "content", "short": "Inhalt der Nutzdaten", "comment": "**Bedeutung:** Welcher Ressourceninhalt in der Nutzlast der Benachrichtigung geliefert werden soll. \n Zur Auswahl stehen eine leere Nutzlast (`empty`), nur die Ressourcen-id (`id-only`) oder der gesamte Inhalt der Ressource (`full-resource`)." }, { "id": "Subscription.channel.header", "path": "Subscription.channel.header", "short": "Falls eine REST-Enpunkt einen Authorization-Header benötigt, kann dieser hier gesetzt werden", "comment": "**Bedeutung:** http-Header welcher dazu genutzt werden kann einen Authorization-header zu setzen. Dies ist nur für rest-hook Subscriptions relevant. \n **Hinweise:** ACHTUNG: dieses Datenfeld muss bei READ-Interaktionen maskiert werden! Siehe [R4 Subscriptions](https://hl7.org/fhir/R4/subscription.html)", "mustSupport": true } ] } }
Constraints/Invarianten
Terminology-Bindings
Element | Staerke | ValueSet |
---|---|---|
Subscription.criteria | extensible | https://gematik.de/fhir/isik/ValueSet/ISiKSubscriptionTopicVS |
Subscription.channel.payload | required | https://gematik.de/fhir/isik/ValueSet/FhirMimeTypeVS |
Anmerkungen zu Must-Support-Feldern
Feldname | Kurzbeschreibung | Hinweise |
---|---|---|
Subscription.status | Status | Bedeutung: Der Status der Subscription, der den Serverstatus der Subscription angibt.
Neue Subscriptions werden immer mit dem Status |
Subscription.reason | Grund der Subscription | Bedeutung: Beschreibung wieso diese Subscription erstellt wurde. |
Subscription.criteria.extension:filterCriteria.value[x] | ||
Subscription.channel | Kommunikationskanal | Bedeutung: Kommunikationskanal über den die Subscription Benachrichtigungen gesendet werden sollen. |
Subscription.channel.extension:heartbeatPeriod | Heartbeat-Intervall | Bedeutung: Intervall in dem der Server prüft, ob der Kommunikationskanal noch aktiv ist. |
Subscription.channel.extension:heartbeatPeriod.value[x] | ||
Subscription.channel.type | Typ des Kommunikationskanals | Bedeutung: Der Typ des Kommunikationskanals, über den Subscription-Benachrichtigungen gesendet werden sollen. |
Subscription.channel.endpoint | Endpunkt | Bedeutung: Adresse des Kommunikationskanals/ Endpunkts, an den Subscription-Benachrichtigungen gesendet werden sollen. Dies ist nur für rest-hook Subscriptions relevant. |
Subscription.channel.payload | Format der Nutzdaten | Bedeutung: Format in dem Subscription Notifications versendet werden sollen (JSON oder XML). |
Subscription.channel.header | Falls eine REST-Enpunkt einen Authorization-Header benötigt, kann dieser hier gesetzt werden | Bedeutung: http-Header welcher dazu genutzt werden kann einen Authorization-header zu setzen. Dies ist nur für rest-hook Subscriptions relevant. |
Interaktionen
Interaktion | Verbindlichkeit |
---|---|
read | SHALL |
create | SHALL |
update | SHALL |
delete | SHALL |
search-type | SHALL |
Parameter | Typ | Verbindlichkeit | Hinweise |
---|---|---|---|
_id | token | SHALL | Beispiel:
|
_tag | token | SHALL | Beispiel:
|
_count | number | SHALL | Beispiel:
|
_has | string | MAY | Beispiel: Suche nach allen Patienten, die eine Observation mit dem Code '1234-5' haben
|
criteria | string | SHALL | Beispiel: |
status | token | SHALL | Beispiel: |
url | uri | SHALL | Beispiel: |
(Reverse-)Include
Name | Spezifikation | Verbindlichkeit |
---|---|---|
status | http://hl7.org/fhir/uv/subscriptions-backport/OperationDefinition/backport-subscription-status | SHALL |
events | http://hl7.org/fhir/uv/subscriptions-backport/OperationDefinition/backport-subscription-events | SHALL |
Beispiele
Subscription |
id : PatientMergeSubscriptionExample |
meta |
profile : https://gematik.de/fhir/isik/StructureDefinition/ISiKSubscription |
status : requested |
reason : Patient merge subscription |
criteria : https://gematik.de/fhir/isik/SubscriptionTopic/patient-merge |
channel |
type : rest-hook |
endpoint : http://localhost:8081/fhir/Bundle |
payload : application/fhir+json |
extension |
url : http://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition/backport-payload-content |
value : full-resource |
header : Authorization: Bearer xxxxxxxxxx |
<Subscription xmlns="http://hl7.org/fhir"> <id value="PatientMergeSubscriptionExample" /> <meta> <profile value="https://gematik.de/fhir/isik/StructureDefinition/ISiKSubscription" /> </meta> <status value="requested" /> <reason value="Patient merge subscription" /> <criteria value="https://gematik.de/fhir/isik/SubscriptionTopic/patient-merge" /> <channel> <type value="rest-hook" /> <endpoint value="http://localhost:8081/fhir/Bundle" /> <payload value="application/fhir+json"> <extension url="http://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition/backport-payload-content"> <valueCode value="full-resource" /> </extension> </payload> <header value="Authorization: Bearer xxxxxxxxxx" /> </channel> </Subscription>
{ "resourceType": "Subscription", "id": "PatientMergeSubscriptionExample", "meta": { "profile": [ "https://gematik.de/fhir/isik/StructureDefinition/ISiKSubscription" ] }, "channel": { "type": "rest-hook", "endpoint": "http://localhost:8081/fhir/Bundle", "payload": "application/fhir+json", "_payload": { "extension": [ { "url": "http://hl7.org/fhir/uv/subscriptions-backport/StructureDefinition/backport-payload-content", "valueCode": "full-resource" } ] }, "header": [ "Authorization: Bearer xxxxxxxxxx" ] }, "status": "requested", "reason": "Patient merge subscription", "criteria": "https://gematik.de/fhir/isik/SubscriptionTopic/patient-merge" }