Release 5 Preview #1

This page is part of the FHIR Specification (v4.2.0: R5 Preview #1). 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 GroupMaturity Level: N/AStandards Status: InformativeSecurity Category: Not Classified Compartments: Device, Patient, Practitioner

R3 : R4 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;
}


<p>No validation errors - all conversions are clean</p>