This page is part of the FHIR Specification (v5.0.0-snapshot3: R5 Snapshot #3, to support Connectathon 32). The current version which supercedes this version is 5.0.0. For a full list of available versions, see the Directory of published versions . Page versions: R5 R4B R4 R3
Security Work Group | Maturity Level: N/A | Standards Status: Informative | Security Category: Not Classified | Compartments: Device, Patient, Practitioner |
R4 : R5 Conversion maps for AuditEvent.
Functional status for this map: 8 tests that all execute ok. All tests pass round-trip testing and all r3 resources are valid. (see documentation)
map "http://hl7.org/fhir/StructureMap/AuditEvent3to4" = "R3 to R4 Conversions for AuditEvent" uses "http://hl7.org/fhir/3.0/StructureDefinition/AuditEvent" alias AuditEventR3 as source uses "http://hl7.org/fhir/StructureDefinition/AuditEvent" alias AuditEvent as target imports "http://hl7.org/fhir/StructureMap/*3to4" group AuditEvent(source src : AuditEventR3, target tgt : AuditEvent) extends DomainResource <<type+>> { src.type -> tgt.type; src.subtype -> tgt.subtype; src.action -> tgt.action; src.recorded -> tgt.recorded; src.outcome -> tgt.outcome; src.outcomeDesc -> tgt.outcomeDesc; src.purposeOfEvent -> tgt.purposeOfEvent; src.agent as s -> tgt.agent as t then AuditEventAgent(s, t); src.source as s -> tgt.source as t then AuditEventSource(s, t); src.entity as s -> tgt.entity as t then AuditEventEntity(s, t); } group AuditEventAgent(source src, target tgt) extends BackboneElement { src.role -> tgt.role; src.reference as vs0 -> tgt.who as vt0 then Reference(vs0, vt0); src.userId as vs0 -> tgt.who as vt0 then Identifier2Reference(vs0, vt0); src.altId -> tgt.altId; src.name -> tgt.name; src.requestor -> tgt.requestor; src.location -> tgt.location; src.policy -> tgt.policy; src.media -> tgt.media; src.network as s -> tgt.network as t then AuditEventAgentNetwork(s, t); src.purposeOfUse -> tgt.purposeOfUse; } group AuditEventAgentNetwork(source src, target tgt) extends BackboneElement { src.address -> tgt.address; src.type -> tgt.type; } group AuditEventSource(source src, target tgt) extends BackboneElement { src.site -> tgt.site; src.identifier as vs0 -> tgt.observer as vt0 then Identifier2Reference(vs0, vt0); src.type -> tgt.type; } group AuditEventEntity(source src, target tgt) extends BackboneElement { src.identifier as vs0 -> tgt.what as vt0 then Identifier2Reference(vs0, vt0); src.reference as vs0 -> tgt.what as vt0 then Reference(vs0, vt0); src.type -> tgt.type; src.role -> tgt.role; src.lifecycle -> tgt.lifecycle; src.securityLabel -> tgt.securityLabel; src.name -> tgt.name; src.description -> tgt.description; src.query -> tgt.query; src.detail as s -> tgt.detail as t then AuditEventEntityDetail(s, t); } group AuditEventEntityDetail(source src, target tgt) extends BackboneElement { src.type -> tgt.type; src.value as vs0 -> tgt.value = create('base64Binary') as vt0 then base64Binary(vs0, vt0); }
map "http://hl7.org/fhir/StructureMap/AuditEvent4to3" = "R4 to R3 Conversion for AuditEvent" uses "http://hl7.org/fhir/StructureDefinition/AuditEvent" alias AuditEvent as source uses "http://hl7.org/fhir/3.0/StructureDefinition/AuditEvent" alias AuditEventR3 as target imports "http://hl7.org/fhir/StructureMap/*4to3" group AuditEvent(source src : AuditEvent, target tgt : AuditEventR3) extends DomainResource <<type+>> { src.type -> tgt.type; src.subtype -> tgt.subtype; src.action -> tgt.action; src.recorded -> tgt.recorded; src.outcome -> tgt.outcome; src.outcomeDesc -> tgt.outcomeDesc; src.purposeOfEvent -> tgt.purposeOfEvent; src.agent as s -> tgt.agent as t then AuditEventAgent(s, t); src.source as s -> tgt.source as t then AuditEventSource(s, t); src.entity as s -> tgt.entity as t then AuditEventEntity(s, t); } group AuditEventAgent(source src, target tgt) extends BackboneElement { src.role -> tgt.role; src.who as vs0 where reference.exists() -> tgt.reference as vt0 then ReferenceNoIdentifier(vs0, vt0); src.who as vs0 where identifier.exists() -> tgt.userId as vt0 then Reference2Identifier(vs0, vt0); src.altId -> tgt.altId; src.name -> tgt.name; src.requestor -> tgt.requestor; src.location -> tgt.location; src.policy -> tgt.policy; src.media -> tgt.media; src.network as s -> tgt.network as t then AuditEventAgentNetwork(s, t); src.purposeOfUse -> tgt.purposeOfUse; } group AuditEventAgentNetwork(source src, target tgt) extends BackboneElement { src.address -> tgt.address; src.type -> tgt.type; } group AuditEventSource(source src, target tgt) extends BackboneElement { src.site -> tgt.site; src.observer as vs0 -> tgt.identifier as vt0 then Reference2Identifier(vs0, vt0); src.type -> tgt.type; } group AuditEventEntity(source src, target tgt) extends BackboneElement { src.what as vs0 where identifier.exists() -> tgt.identifier as vt0 then Reference2Identifier(vs0, vt0); src.what as vs0 where reference.exists() -> tgt.reference as vt0 then ReferenceNoIdentifier(vs0, vt0); src.type -> tgt.type; src.role -> tgt.role; src.lifecycle -> tgt.lifecycle; src.securityLabel -> tgt.securityLabel; src.name -> tgt.name; src.description -> tgt.description; src.query -> tgt.query; src.detail as s -> tgt.detail as t then AuditEventEntityDetail(s, t); } group AuditEventEntityDetail(source src, target tgt) extends BackboneElement { src.type -> tgt.type; src.value where $this is base64Binary -> tgt.value; }