This
page
is
part
of
the
FHIR
Specification
(v4.3.0:
R4B
-
STU
(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 |
R3
:
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 : AuditEventR3, target tgt : AuditEvent) extends DomainResource <<type+>> {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; }