{
  "resourceType": "StructureDefinition",
  "id": "apilogical-er",
  "extension": [
    {
      "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-type-characteristics",
      "valueCode": "can-be-target"
    }
  ],
  "url": "http://electronichealth.se/fhir/NDI/StructureDefinition/apilogical-er",
  "name": "APILogicalEr",
  "title": "API",
  "status": "active",
  "description": "Klassen API håller information om funktion som möjliggör för mjukvaruapplikationer att begära tjänster från eller utbyta information mellan system.",
  "fhirVersion": "5.0.0",
  "mapping": [
    {
      "identity": "APIToEndpointPayloadEr",
      "uri": "EndpointEr.payload"
    }
  ],
  "kind": "logical",
  "abstract": false,
  "type": "http://electronichealth.se/fhir/NDI/StructureDefinition/apilogical-er",
  "baseDefinition": "http://hl7.org/fhir/StructureDefinition/Base",
  "derivation": "specialization",
  "snapshot": {
    "element": [
      {
        "id": "apilogical-er",
        "path": "apilogical-er",
        "short": "API",
        "definition": "Klassen API håller information om funktion som möjliggör för mjukvaruapplikationer att begära tjänster från eller utbyta information mellan system.",
        "min": 0,
        "max": "*",
        "base": {
          "path": "apilogical-er",
          "min": 0,
          "max": "*"
        },
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "apilogical-er.implementeradeOptioner",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-standards-status",
            "valueCode": "normative"
          },
          {
            "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-normative-version",
            "valueCode": "4.0.0"
          }
        ],
        "path": "apilogical-er.implementeradeOptioner",
        "short": "implementeradeOptioner",
        "definition": "Angivelse av kod för vilka valfria optioner i från en API-specifikation som denna ändpunkt har implementerat. Kodverket är specifikt för en given API-specifikation.",
        "comment": "Codes may be defined very casually in enumerations or code lists, up to very formal definitions such as SNOMED CT - see the HL7 v3 Core Principles for more information.",
        "min": 0,
        "max": "*",
        "base": {
          "path": "apilogical-er.implementeradeOptioner",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Coding"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "cod-1",
            "severity": "warning",
            "human": "A Coding SHOULD NOT have a display unless a code is also present.  Computation on Coding.display alone is generally unsafe.  Consider using CodeableConcept.text",
            "expression": "code.exists().not() implies display.exists().not()",
            "source": "http://hl7.org/fhir/StructureDefinition/Coding"
          }
        ],
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          },
          {
            "identity": "v2",
            "map": "CE/CNE/CWE subset one of the sets of component 1-3 or 4-6"
          },
          {
            "identity": "rim",
            "map": "CV"
          },
          {
            "identity": "orim",
            "map": "fhir:Coding rdfs:subClassOf dt:CDCoding"
          },
          {
            "identity": "APIToEndpointPayloadEr"
          }
        ]
      },
      {
        "id": "apilogical-er.giltigFrom",
        "path": "apilogical-er.giltigFrom",
        "short": "giltigFrom",
        "definition": "Angivelse av den tidpunkt från och med vilken ett API som följer en utpekad API-specifikation finns tillgängligt via en viss ändpunkt.",
        "min": 1,
        "max": "1",
        "base": {
          "path": "apilogical-er.giltigFrom",
          "min": 1,
          "max": "1"
        },
        "type": [
          {
            "code": "time"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          }
        ],
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          },
          {
            "identity": "APIToEndpointPayloadEr"
          }
        ]
      },
      {
        "id": "apilogical-er.giltigTom",
        "path": "apilogical-er.giltigTom",
        "short": "giltigTom",
        "definition": "Angivelse av den tidpunkt då ett API som följer en utpekad API-specifikation inte längre finns tillgängligt via en viss ändpunkt.",
        "min": 0,
        "max": "1",
        "base": {
          "path": "apilogical-er.giltigTom",
          "min": 0,
          "max": "1"
        },
        "type": [
          {
            "code": "time"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          }
        ],
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          },
          {
            "identity": "APIToEndpointPayloadEr"
          }
        ]
      },
      {
        "id": "apilogical-er.foljer",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-standards-status",
            "valueCode": "normative"
          },
          {
            "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-normative-version",
            "valueCode": "4.0.0"
          }
        ],
        "path": "apilogical-er.foljer",
        "short": "följer",
        "definition": "följer",
        "comment": "References SHALL be a reference to an actual FHIR resource, and SHALL be resolvable (allowing for access control, temporary unavailability, etc.). Resolution can be either by retrieval from the URL, or, where applicable by resource type, by treating an absolute reference as a canonical URL and looking it up in a local registry/repository.",
        "min": 1,
        "max": "1",
        "base": {
          "path": "apilogical-er.foljer",
          "min": 1,
          "max": "1"
        },
        "type": [
          {
            "code": "Reference",
            "targetProfile": [
              "http://electronichealth.se/fhir/NDI/StructureDefinition/apispecifikation-logical-er"
            ]
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "ref-1",
            "severity": "error",
            "human": "SHALL have a contained resource if a local reference is provided",
            "expression": "reference.exists()  implies (reference.startsWith('#').not() or (reference.substring(1).trace('url') in %rootResource.contained.id.trace('ids')) or (reference='#' and %rootResource!=%resource))",
            "source": "http://hl7.org/fhir/StructureDefinition/Reference"
          },
          {
            "key": "ref-2",
            "severity": "error",
            "human": "At least one of reference, identifier and display SHALL be present (unless an extension is provided).",
            "expression": "reference.exists() or identifier.exists() or display.exists() or extension.exists()",
            "source": "http://hl7.org/fhir/StructureDefinition/Reference"
          }
        ],
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          },
          {
            "identity": "rim",
            "map": "The target of a resource reference is a RIM entry point (Act, Role, or Entity)"
          },
          {
            "identity": "APIToEndpointPayloadEr",
            "map": "EndpointEr.payload.extension[apiSpecification]"
          }
        ]
      }
    ]
  },
  "differential": {
    "element": [
      {
        "id": "apilogical-er",
        "path": "apilogical-er",
        "short": "API",
        "definition": "Klassen API håller information om funktion som möjliggör för mjukvaruapplikationer att begära tjänster från eller utbyta information mellan system."
      },
      {
        "id": "apilogical-er.implementeradeOptioner",
        "path": "apilogical-er.implementeradeOptioner",
        "short": "implementeradeOptioner",
        "definition": "Angivelse av kod för vilka valfria optioner i från en API-specifikation som denna ändpunkt har implementerat. Kodverket är specifikt för en given API-specifikation.",
        "min": 0,
        "max": "*",
        "type": [
          {
            "code": "Coding"
          }
        ],
        "mapping": [
          {
            "identity": "APIToEndpointPayloadEr"
          }
        ]
      },
      {
        "id": "apilogical-er.giltigFrom",
        "path": "apilogical-er.giltigFrom",
        "short": "giltigFrom",
        "definition": "Angivelse av den tidpunkt från och med vilken ett API som följer en utpekad API-specifikation finns tillgängligt via en viss ändpunkt.",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "time"
          }
        ],
        "mapping": [
          {
            "identity": "APIToEndpointPayloadEr"
          }
        ]
      },
      {
        "id": "apilogical-er.giltigTom",
        "path": "apilogical-er.giltigTom",
        "short": "giltigTom",
        "definition": "Angivelse av den tidpunkt då ett API som följer en utpekad API-specifikation inte längre finns tillgängligt via en viss ändpunkt.",
        "min": 0,
        "max": "1",
        "type": [
          {
            "code": "time"
          }
        ],
        "mapping": [
          {
            "identity": "APIToEndpointPayloadEr"
          }
        ]
      },
      {
        "id": "apilogical-er.foljer",
        "path": "apilogical-er.foljer",
        "short": "följer",
        "definition": "följer",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "Reference",
            "targetProfile": [
              "http://electronichealth.se/fhir/NDI/StructureDefinition/apispecifikation-logical-er"
            ]
          }
        ],
        "mapping": [
          {
            "identity": "APIToEndpointPayloadEr",
            "map": "EndpointEr.payload.extension[apiSpecification]"
          }
        ]
      }
    ]
  }
}