This page is part of the FHIR Specification (v1.6.0: STU 3 Ballot 4). 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
ShEx statement for implementationguide
PREFIX fhir: <http://hl7.org/fhir/> PREFIX fhirvs: <http://hl7.org/fhir/ValueSet/> PREFIX xsd: <http://www.w3.org/2001/XMLSchema#> BASE <http://hl7.org/fhir/shape/> start=<ImplementationGuide> AND {fhir:nodeRole [fhir:treeRoot]} # A set of rules about how FHIR is used <ImplementationGuide> CLOSED { a [fhir:ImplementationGuide]; fhir:nodeRole [fhir:treeRoot]?; fhir:Resource.id @<id>?; # Logical id of this artifact fhir:Resource.meta @<Meta>?; # Metadata about the resource fhir:Resource.implicitRules @<uri>?; # A set of rules under which this # content was created fhir:Resource.language @<code>?; # Language of the resource content fhir:DomainResource.text @<Narrative>?; # Text summary of the resource, for # human interpretation fhir:DomainResource.contained @<Resource>*; # Contained, inline Resources fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.url @<uri>; # Absolute URL used to reference # this Implementation Guide fhir:ImplementationGuide.version @<string>?; # Logical id for this version of the # Implementation Guide fhir:ImplementationGuide.name @<string>; # Informal name for this # Implementation Guide fhir:ImplementationGuide.status @<code> AND {fhir:value @fhirvs:conformance-resource-status}; # draft | active | retired fhir:ImplementationGuide.experimental @<boolean>?; # If for testing purposes, not real # usage fhir:ImplementationGuide.publisher @<string>?; # Name of the publisher # (Organization or individual) fhir:ImplementationGuide.contact @<ImplementationGuide.contact>*; # Contact details of the publisher fhir:ImplementationGuide.date @<dateTime>?; # Date for this version of the # Implementation Guide fhir:ImplementationGuide.description @<markdown>?; # Natural language description of # the Implementation Guide fhir:ImplementationGuide.useContext @<CodeableConcept>*; # The implementation guide is # intended to support these contexts fhir:ImplementationGuide.copyright @<string>?; # Use and/or publishing restrictions fhir:ImplementationGuide.fhirVersion @<id>?; # FHIR Version this Implementation # Guide targets fhir:ImplementationGuide.dependency @<ImplementationGuide.dependency>*; # Another Implementation guide this # depends on fhir:ImplementationGuide.package @<ImplementationGuide.package>*; # Group of resources as used in # .page.package fhir:ImplementationGuide.global @<ImplementationGuide.global>*; # Profiles that apply globally fhir:ImplementationGuide.binary @<uri>*; # Image, css, script, etc. fhir:ImplementationGuide.page @<ImplementationGuide.page>?; # Page/Section in the Guide fhir:index xsd:integer? # Relative position in a list } # Group of resources as used in .page.package <ImplementationGuide.package> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.package.name @<string>; # Name used .page.package fhir:ImplementationGuide.package.description @<string>?; # Human readable text describing the # package fhir:ImplementationGuide.package.resource @<ImplementationGuide.package.resource>+; # Resource in the implementation # guide fhir:index xsd:integer? # Relative position in a list } # Another Implementation guide this depends on <ImplementationGuide.dependency> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.dependency.type @<code> AND {fhir:value @fhirvs:guide-dependency-type}; # reference | inclusion fhir:ImplementationGuide.dependency.uri @<uri>; # Where to find dependency fhir:index xsd:integer? # Relative position in a list } # Contact details of the publisher <ImplementationGuide.contact> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.contact.name @<string>?; # Name of an individual to contact fhir:ImplementationGuide.contact.telecom @<ContactPoint>*; # Contact details for individual or # publisher fhir:index xsd:integer? # Relative position in a list } # Page/Section in the Guide <ImplementationGuide.page> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.page.source @<uri>; # Where to find that page fhir:ImplementationGuide.page.title @<string>; # Short title shown for navigational # assistance fhir:ImplementationGuide.page.kind @<code> AND {fhir:value @fhirvs:guide-page-kind}; # page | example | list | include | # directory | dictionary | toc | # resource fhir:ImplementationGuide.page.type @<code> AND {fhir:value @fhirvs:resource-types}*; # Kind of resource to include in the # list fhir:ImplementationGuide.page.package @<string>*; # Name of package to include fhir:ImplementationGuide.page.format @<code>?; # Format of the page (e.g. html, # markdown, etc.) fhir:ImplementationGuide.page.page @<ImplementationGuide.page>*; # Nested Pages / Sections fhir:index xsd:integer? # Relative position in a list } # Profiles that apply globally <ImplementationGuide.global> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.global.type @<code> AND {fhir:value @fhirvs:resource-types}; # Type this profiles applies to fhir:ImplementationGuide.global.profile @<StructureDefinitionReference>; # Profile that all resources must # conform to fhir:index xsd:integer? # Relative position in a list } # Resource in the implementation guide <ImplementationGuide.package.resource> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:modifierExtension @<Extension>*; # Extensions that cannot be ignored fhir:ImplementationGuide.package.resource.example @<boolean>; # If not an example, has it's normal # meaning fhir:ImplementationGuide.package.resource.name @<string>?; # Human Name for the resource fhir:ImplementationGuide.package.resource.description @<string>?; # Reason why included in guide fhir:ImplementationGuide.package.resource.acronym @<string>?; # Short code to identify the resource ( # Location of the resource fhir:ImplementationGuide.package.resource.sourceUri @<uri> | fhir:ImplementationGuide.package.resource.sourceReference @<ResourceReference> ); fhir:ImplementationGuide.package.resource.exampleFor @<StructureDefinitionReference>?; # Resource this is an example of (if # applicable) fhir:index xsd:integer? # Relative position in a list } #---------------------- Data Types ------------------- # Primitive Type dateTime <dateTime> CLOSED { fhir:id @<id>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:gYear OR xsd:gYearMonth OR xsd:date OR xsd:dateTime?; # Primitive value for dateTime fhir:index xsd:integer? # Relative position in a list } # Metadata about a resource <Meta> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:Meta.versionId @<id>?; # Version specific identifier fhir:Meta.lastUpdated @<instant>?; # When the resource version last # changed fhir:Meta.profile @<uri>*; # Profiles this resource claims to # conform to fhir:Meta.security @<Coding>*; # Security Labels applied to this # resource fhir:Meta.tag @<Coding>*; # Tags applied to this resource fhir:index xsd:integer? # Relative position in a list } # Primitive Type code <code> CLOSED { fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:string?; # Primitive value for code fhir:index xsd:integer? # Relative position in a list } # Primitive Type string <string> CLOSED { fhir:id @<id>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:string MAXLENGTH 1048576?; # Primitive value for string fhir:index xsd:integer? # Relative position in a list } # Base Resource <Resource> {a .+; fhir:Resource.id @<id>?; # Logical id of this artifact fhir:Resource.meta @<Meta>?; # Metadata about the resource fhir:Resource.implicitRules @<uri>?; # A set of rules under which this # content was created fhir:Resource.language @<code>?; # Language of the resource content fhir:index xsd:integer? } # Primitive Type uri <uri> CLOSED { fhir:id @<id>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:string?; # Primitive value for uri fhir:index xsd:integer? # Relative position in a list } <Extension> {fhir:extension @<Extension>*; fhir:index xsd:integer? } # Details of a Technology mediated contact point (phone, fax, email, etc.) <ContactPoint> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:ContactPoint.system @<code> AND {fhir:value @fhirvs:contact-point-system}?; # phone | fax | email | pager | other fhir:ContactPoint.value @<string>?; # The actual contact point details fhir:ContactPoint.use @<code> AND {fhir:value @fhirvs:contact-point-use}?; # home | work | temp | old | mobile # - purpose of this contact point fhir:ContactPoint.rank @<positiveInt>?; # Specify preferred order of use (1 # = highest) fhir:ContactPoint.period @<Period>?; # Time period when the contact point # was/is in use fhir:index xsd:integer? # Relative position in a list } # Primitive Type boolean <boolean> CLOSED { fhir:id @<id>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:boolean?; # Primitive value for boolean fhir:index xsd:integer? # Relative position in a list } # A human-readable formatted text, including images <Narrative> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:Narrative.status @<code> AND {fhir:value @fhirvs:narrative-status}; # generated | extensions | # additional | empty fhir:Narrative.div xsd:string; # Limited xhtml content fhir:index xsd:integer? # Relative position in a list } # Primitive Type markdown <markdown> CLOSED { fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:string?; # Primitive value for markdown fhir:index xsd:integer? # Relative position in a list } # Primitive Type id <id> CLOSED { fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:string?; # Primitive value for id fhir:index xsd:integer? # Relative position in a list } # Concept - reference to a terminology or just text <CodeableConcept> CLOSED { fhir:concept IRI*; fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:CodeableConcept.coding @<Coding>*; # Code defined by a terminology # system fhir:CodeableConcept.text @<string>?; # Plain text representation of the # concept fhir:index xsd:integer? # Relative position in a list } # Time range defined by start and end date/time <Period> CLOSED { fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:Period.start @<dateTime>?; # Starting time with inclusive # boundary fhir:Period.end @<dateTime>?; # End time with inclusive boundary, # if not ongoing fhir:index xsd:integer? # Relative position in a list } # Primitive Type instant <instant> CLOSED { fhir:id @<id>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:dateTime?; # Primitive value for instant fhir:index xsd:integer? # Relative position in a list } # A reference to a code defined by a terminology system <Coding> CLOSED { fhir:concept IRI?; fhir:Element.id @<string>?; # xml:id (or equivalent in JSON) fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:Coding.system @<uri>?; # Identity of the terminology system fhir:Coding.version @<string>?; # Version of the system - if relevant fhir:Coding.code @<code>?; # Symbol in syntax defined by the # system fhir:Coding.display @<string>?; # Representation defined by the # system fhir:Coding.userSelected @<boolean>?; # If this coding was chosen directly # by the user fhir:index xsd:integer? # Relative position in a list } # Primitive Type positiveInt <positiveInt> CLOSED { fhir:extension @<Extension>*; # Additional Content defined by # implementations fhir:value xsd:positiveInteger?; # Primitive value for positiveInt fhir:index xsd:integer? # Relative position in a list } #---------------------- Reference Types ------------------- <StructureDefinitionReference> CLOSED { fhir:Element.id @<id>?; fhir:extension @<Extension>*; fhir:link @<StructureDefinition> OR CLOSED {a fhir:StructureDefinition}?; fhir:Reference.reference @<string>?; fhir:Reference.display @<string>?; fhir:index xsd:integer? } <ResourceReference> CLOSED { fhir:Element.id @<id>?; fhir:extension @<Extension>*; fhir:link @<Resource> OR CLOSED {a fhir:Resource}?; fhir:Reference.reference @<string>?; fhir:Reference.display @<string>?; fhir:index xsd:integer? } #---------------------- Value Sets ------------------------ # The lifecycle status of a Value Set or Concept Map. @fhirvs:conformance-resource-status = ["draft" "active" "retired"] # Use of contact point @fhirvs:contact-point-use = ["home" "work" "temp" "old" "mobile"] # Telecommunications form for contact point @fhirvs:contact-point-system = ["phone" "fax" "email" "pager" "other"] # One of the resource types defined as part of FHIR. @fhirvs:resource-types = ["Account" "ActivityDefinition" "AllergyIntolerance" "Appointment" "AppointmentResponse" "AuditEvent" "Basic" "Binary" "BodySite" "Bundle" "CarePlan" "CareTeam" "Claim" "ClaimResponse" "ClinicalImpression" "CodeSystem" "Communication" "CommunicationRequest" "CompartmentDefinition" "Composition" "ConceptMap" "Condition" "Conformance" "Consent" "Contract" "Coverage" "DataElement" "DecisionSupportServiceModule" "DetectedIssue" "Device" "DeviceComponent" "DeviceMetric" "DeviceUseRequest" "DeviceUseStatement" "DiagnosticReport" "DiagnosticRequest" "DocumentManifest" "DocumentReference" "DomainResource" "EligibilityRequest" "EligibilityResponse" "Encounter" "Endpoint" "EnrollmentRequest" "EnrollmentResponse" "EpisodeOfCare" "ExpansionProfile" "ExplanationOfBenefit" "FamilyMemberHistory" "Flag" "Goal" "Group" "GuidanceResponse" "HealthcareService" "ImagingManifest" "ImagingStudy" "Immunization" "ImmunizationRecommendation" "ImplementationGuide" "Library" "Linkage" "List" "Location" "Measure" "MeasureReport" "Media" "Medication" "MedicationAdministration" "MedicationDispense" "MedicationOrder" "MedicationStatement" "MessageHeader" "NamingSystem" "NutritionRequest" "Observation" "OperationDefinition" "OperationOutcome" "Organization" "Parameters" "Patient" "PaymentNotice" "PaymentReconciliation" "Person" "PlanDefinition" "Practitioner" "PractitionerRole" "Procedure" "ProcedureRequest" "ProcessRequest" "ProcessResponse" "Provenance" "Questionnaire" "QuestionnaireResponse" "ReferralRequest" "RelatedPerson" "Resource" "RiskAssessment" "Schedule" "SearchParameter" "Sequence" "Slot" "Specimen" "StructureDefinition" "StructureMap" "Subscription" "Substance" "SupplyDelivery" "SupplyRequest" "Task" "TestScript" "ValueSet" "VisionPrescription"] # The status of a resource narrative @fhirvs:narrative-status = ["generated" "extensions" "additional" "empty"] # How a dependency is represented when the guide is published. @fhirvs:guide-dependency-type = ["reference" "inclusion"] # The kind of an included page. @fhirvs:guide-page-kind = ["page" "example" "list" "include" "directory" "dictionary" "toc" "resource"]
Usage note: every effort has been made to ensure that the ShEx files are correct and useful, but they are not a normative part of the specification.