<StructureDefinition xmlns="http://hl7.org/fhir">
  <id value="dipag-nutzungsprotokoll" />
  <url value="https://gematik.de/fhir/dipag/StructureDefinition/dipag-nutzungsprotokoll" />
  <version value="1.0.7" />
  <name value="DiPagNutzungsprotokoll" />
  <title value="Digitale Patientenrechnung Nutzungsprotokoll" />
  <status value="active" />
  <experimental value="false" />
  <date value="2026-03-26" />
  <publisher value="gematik GmbH" />
  <contact>
    <telecom>
      <system value="url" />
      <value value="http://gematik.de/" />
    </telecom>
  </contact>
  <fhirVersion value="4.0.1" />
  <kind value="resource" />
  <abstract value="false" />
  <type value="AuditEvent" />
  <baseDefinition value="http://hl7.org/fhir/StructureDefinition/AuditEvent" />
  <derivation value="constraint" />
  <differential>
    <element id="AuditEvent.type">
      <path value="AuditEvent.type" />
      <comment value="Angabe ob es sich um eine zu protokollierende Nutzerinteraktion nach Abschnittt '5.5.9 Nutzerprotokolle' des Feature-Dokuments 'Digitale Patientenrechnung' handelt oder um eine durchgeführte REST-API-Interaktion durch den FD." />
      <mustSupport value="true" />
      <binding>
        <strength value="required" />
        <valueSet value="https://gematik.de/fhir/dipag/ValueSet/dipag-audit-event-type-vs" />
      </binding>
    </element>
    <element id="AuditEvent.subtype">
      <path value="AuditEvent.subtype" />
      <comment value="Erlaubt die Kodierung aller REST-API Operationen der Spec-Digitale Patientenrechnung" />
      <min value="1" />
      <max value="1" />
      <mustSupport value="true" />
      <binding>
        <strength value="required" />
        <valueSet value="https://gematik.de/fhir/dipag/ValueSet/dipag-audit-event-sub-type-vs" />
      </binding>
    </element>
    <element id="AuditEvent.action">
      <path value="AuditEvent.action" />
      <comment value="Angabe ob es sich um eine lesende/schreibende/ausführende Interaktion handelt." />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.recorded">
      <path value="AuditEvent.recorded" />
      <comment value="Der Zeitpunkt des Zugriffs ist zu protokollieren. Siehe Abschnittt '4.8.6 Protokolleintrag'des Feature-Dokuments 'Digitale Patientenrechnung'." />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.outcome">
      <path value="AuditEvent.outcome" />
      <comment value="Angabe ob die zu protokollierende Interaktion erfolgreich ausgeführt werden konnte." />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.agent">
      <path value="AuditEvent.agent" />
      <comment value="Angaben zum Akteur (Nutzer oder DiPag FD), der den Zugriff durchgeführt hat. Siehe Abschnittt '4.8.6 Protokolleintrag'des Feature-Dokuments 'Digitale Patientenrechnung'." />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.agent.type">
      <path value="AuditEvent.agent.type" />
      <min value="1" />
      <mustSupport value="true" />
      <binding>
        <strength value="required" />
        <valueSet value="https://gematik.de/fhir/dipag/ValueSet/dipag-audit-event-agent-type-vs" />
      </binding>
    </element>
    <element id="AuditEvent.agent.who">
      <path value="AuditEvent.agent.who" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.agent.who.identifier">
      <path value="AuditEvent.agent.who.identifier" />
      <comment value="Der Identifier wird vom Server gesetzt und kann entweder eine KVNR oder Telematik-ID sein. Im Falle einer Applikations-internen Aktivität muss die OID des FD gesetzt werden." />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.agent.who.display">
      <path value="AuditEvent.agent.who.display" />
      <min value="1" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.source.observer.identifier">
      <path value="AuditEvent.source.observer.identifier" />
      <comment value="Identifier (OID) des DiPag Fachdienst-Server, auf dem das Event ausgelöst wurde" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.source.observer.display">
      <path value="AuditEvent.source.observer.display" />
      <comment value="Name des DiPag Fachdienst-Server, auf dem das Event ausgelöst wurde" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity">
      <path value="AuditEvent.entity" />
      <slicing>
        <discriminator>
          <type value="pattern" />
          <path value="what.type" />
        </discriminator>
        <rules value="open" />
      </slicing>
      <min value="1" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity.detail">
      <path value="AuditEvent.entity.detail" />
      <comment value="Details zum Dokument, z.B. die Art der Interaktion" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity.detail.type">
      <path value="AuditEvent.entity.detail.type" />
      <mustSupport value="true" />
      <binding>
        <strength value="required" />
        <valueSet value="https://gematik.de/fhir/dipag/ValueSet/dipag-audit-event-detail-vs" />
      </binding>
    </element>
    <element id="AuditEvent.entity.detail.value[x]">
      <path value="AuditEvent.entity.detail.value[x]" />
      <slicing>
        <discriminator>
          <type value="type" />
          <path value="$this" />
        </discriminator>
        <ordered value="false" />
        <rules value="open" />
      </slicing>
    </element>
    <element id="AuditEvent.entity.detail.value[x]:valueString">
      <path value="AuditEvent.entity.detail.value[x]" />
      <sliceName value="valueString" />
      <comment value="Freitextliche Angabe zu den Details der Interaktion. Der Freitext soll verständlich und für die Anzeige im Frontend geeignet sein." />
      <min value="0" />
      <max value="1" />
      <type>
        <code value="string" />
      </type>
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Versicherter">
      <path value="AuditEvent.entity" />
      <sliceName value="Versicherter" />
      <min value="1" />
      <max value="1" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Versicherter.what">
      <path value="AuditEvent.entity.what" />
      <comment value="Referenz auf das von der zu protokollierenden Interaktion betroffene Benutzerkonto im Fachdienst." />
    </element>
    <element id="AuditEvent.entity:Versicherter.what.reference">
      <path value="AuditEvent.entity.what.reference" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Versicherter.what.type">
      <path value="AuditEvent.entity.what.type" />
      <min value="1" />
      <patternUri value="Patient" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:DocumentReference">
      <path value="AuditEvent.entity" />
      <sliceName value="DocumentReference" />
      <min value="0" />
      <max value="*" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:DocumentReference.what">
      <path value="AuditEvent.entity.what" />
      <comment value="Referenz auf alle betroffenen DocumentReference Resourcen" />
    </element>
    <element id="AuditEvent.entity:DocumentReference.what.reference">
      <path value="AuditEvent.entity.what.reference" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:DocumentReference.what.type">
      <path value="AuditEvent.entity.what.type" />
      <min value="1" />
      <patternUri value="DocumentReference" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:DocumentReference.name">
      <path value="AuditEvent.entity.name" />
      <comment value="Freitextname des Dokumentes, auf das sich die Referenz bezieht" />
      <min value="1" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Binary">
      <path value="AuditEvent.entity" />
      <sliceName value="Binary" />
      <min value="0" />
      <max value="*" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Binary.what">
      <path value="AuditEvent.entity.what" />
      <comment value="Referenz auf alle betroffenen Binary   Resourcen" />
    </element>
    <element id="AuditEvent.entity:Binary.what.reference">
      <path value="AuditEvent.entity.what.reference" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Binary.what.type">
      <path value="AuditEvent.entity.what.type" />
      <min value="1" />
      <patternUri value="Binary" />
      <mustSupport value="true" />
    </element>
    <element id="AuditEvent.entity:Binary.name">
      <path value="AuditEvent.entity.name" />
      <comment value="Freitextname des Dokumenten-Binary, auf das sich die Referenz bezieht" />
      <min value="1" />
      <mustSupport value="true" />
    </element>
  </differential>
</StructureDefinition>