Release 5 Ballot

This page is part of the FHIR Specification (v5.0.0-ballot: FHIR R5 Ballot Preview). 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 R2

13.1 Resource Coverage - Content

Financial Management Work GroupMaturity Level: 2 Trial UseSecurity Category: Patient Compartments: Patient, RelatedPerson

Financial instrument which may be used to reimburse or pay for health care products and services. Includes both insurance and self-payment.

The Coverage resource is intended to provide the high-level identifiers and descriptors of an insurance plan, typically the information which would appear on an insurance card, which may be used to pay, in part or in whole, for the provision of health care products and services.

This resource may also be used to register 'SelfPay' where an individual or organization other than an insurer is taking responsibility for payment for a portion of the health care costs. Selfpay should not be confused with being a guarantor of the patient's account.

The Coverage resource is a "event" resource from a FHIR workflow perspective - see Workflow Request.

The eClaim domain includes a number of related insurance resources

Coverage The Coverage resource is intended to provide the high-level identifiers and descriptors of a specific insurance plan for a specific individual - essentially the insurance card information. This may alternately provide the individual or organization, selfpay, which will pay for products and services rendered.
Contract A Contract resource holds the references to parties who have entered into an agreement of some type, the parties who may sign or witness such an agreement, descriptors of the type of agreement and even the actual text or executable copy of the agreement. The agreement may be of a variety of types including service contracts, insurance contracts, directives, etc. The contract may be either definitional or actual instances.
InsurancePlan The InsurancePlan resource holds the definition of an insurance plan which an insurer may offer to potential clients through insurance brokers or an online insurance marketplace. This is only the plan definition and does not contain or reference a list of individuals who have purchased the plan.

Structure

NameFlagsCard.TypeDescription & Constraintsdoco
.. Coverage TUDomainResourceInsurance or medical plan or a payment agreement

Elements defined in Ancestors: id, meta, implicitRules, language, text, contained, extension, modifierExtension
... identifier Σ0..*IdentifierBusiness identifier(s) for this coverage

... status ?!Σ1..1codeactive | cancelled | draft | entered-in-error
Financial Resource Status Codes (Required)
... kind Σ1..1codeinsurance | self-pay | other
Kind (Required)
.... party Σ1..1Reference(Patient | RelatedPerson | Organization)Parties performing self-payment
.... responsibility Σ0..1stringParty's responsibility
... type Σ0..1CodeableConceptCoverage category such as medical or accident
Coverage Type and Self-Pay Codes (Preferred)
... policyHolder Σ0..1Reference(Patient | RelatedPerson | Organization)Owner of the policy
... subscriber Σ0..1Reference(Patient | RelatedPerson)Subscriber to the policy
... subscriberId Σ0..*IdentifierID assigned to the subscriber

... beneficiary Σ1..1Reference(Patient)Plan beneficiary
... dependent Σ0..1stringDependent number
... relationship 0..1CodeableConceptBeneficiary relationship to the subscriber
SubscriberPolicyholder Relationship Codes (Extensible)
... period Σ0..1PeriodCoverage start and end dates
... insurer Σ0..1Reference(Organization)Issuer of the policy
... class 0..*BackboneElementAdditional coverage classifications

.... type Σ1..1CodeableConceptType of class such as 'group' or 'plan'
Coverage Class Codes (Extensible)
.... value Σ1..1IdentifierValue associated with the type
.... name Σ0..1stringHuman readable description of the type and value
... order Σ0..1positiveIntRelative order of the coverage
... network Σ0..1stringInsurer network
... costToBeneficiary 0..*BackboneElementPatient payments for services/products

.... type Σ0..1CodeableConceptCost category
Coverage Copay Type Codes (Extensible)
.... category 0..1CodeableConceptBenefit classification
Benefit Category Codes (Example)
.... network 0..1CodeableConceptIn or out of network
Network Type Codes (Example)
.... unit 0..1CodeableConceptIndividual or family
Unit Type Codes (Example)
.... term 0..1CodeableConceptAnnual or lifetime
Benefit Term Codes (Example)
.... value[x] Σ0..1The amount or percentage due from the beneficiary
..... valueQuantitySimpleQuantity
..... valueMoneyMoney
.... exception 0..*BackboneElementExceptions for patient payments

..... type Σ1..1CodeableConceptException category
Example Coverage Financial Exception Codes (Example)
..... period Σ0..1PeriodThe effective period of the exception
... subrogation 0..1booleanReimbursement to insurer
... contract 0..*Reference(Contract)Contract details

... insurancePlan 0..1Reference(InsurancePlan)Insurance plan details

doco Documentation for this format

See the Extensions for this resource

UML Diagram (Legend)

Coverage (DomainResource)The identifier of the coverage as issued by the insureridentifier : Identifier [0..*]The status of the resource instance (this element modifies the meaning of other elements)status : code [1..1] « null (Strength=Required)FinancialResourceStatusCodes! »The nature of the coverage be it insurance, or cash payment such as self-paykind : code [1..1] « null (Strength=Required)Kind! »The type of coverage: social program, medical plan, accident coverage (workers compensation, auto), group health or payment by an individual or organizationtype : CodeableConcept [0..1] « null (Strength=Preferred)CoverageTypeAndSelf-PayCodes? »The party who 'owns' the insurance policypolicyHolder : Reference [0..1] « Patient|RelatedPerson|Organization »The party who has signed-up for or 'owns' the contractual relationship to the policy or to whom the benefit of the policy for services rendered to them or their family is duesubscriber : Reference [0..1] « Patient|RelatedPerson »The insurer assigned ID for the SubscribersubscriberId : Identifier [0..*]The party who benefits from the insurance coverage; the patient when products and/or services are providedbeneficiary : Reference [1..1] « Patient »A designator for a dependent under the coveragedependent : string [0..1]The relationship of beneficiary (patient) to the subscriberrelationship : CodeableConcept [0..1] « null (Strength=Extensible)SubscriberRelationshipCodes+ »Time period during which the coverage is in force. A missing start date indicates the start date isn't known, a missing end date means the coverage is continuing to be in forceperiod : Period [0..1]The program or plan underwriter, payor, insurance companyinsurer : Reference [0..1] « Organization »The order of applicability of this coverage relative to other coverages which are currently in force. Note, there may be gaps in the numbering and this does not imply primary, secondary etc. as the specific positioning of coverages depends upon the episode of care. For example; a patient might have (0) auto insurance (1) their own health insurance and (2) spouse's health insurance. When claiming for treatments which were not the result of an auto accident then only coverages (1) and (2) above would be applicatble and would apply in the order specified in parenthesisorder : positiveInt [0..1]The insurer-specific identifier for the insurer-defined network of providers to which the beneficiary may seek treatment which will be covered at the 'in-network' rate, otherwise 'out of network' terms and conditions applynetwork : string [0..1]When 'subrogation=true' this insurance instance has been included not for adjudication but to provide insurers with the details to recover costssubrogation : boolean [0..1]The policy(s) which constitute this insurance coveragecontract : Reference [0..*] « Contract »The insurance plan details, benefits and costs, which constitute this insurance coverageinsurancePlan : Reference [0..1] « InsurancePlan »PaymentByThe list of parties providing non-insurance payment for the treatment costsparty : Reference [1..1] « Patient|RelatedPerson|Organization » Description of the financial responsibilityresponsibility : string [0..1]ClassThe type of classification for which an insurer-specific class label or number and optional name is provided. For example, type may be used to identify a class of coverage or employer group, policy, or plantype : CodeableConcept [1..1] « null (Strength=Extensible)CoverageClassCodes+ »The alphanumeric identifier associated with the insurer issued labelvalue : Identifier [1..1]A short description for the classname : string [0..1]CostToBeneficiaryThe category of patient centric costs associated with treatmenttype : CodeableConcept [0..1] « null (Strength=Extensible)CoverageCopayTypeCodes+ »Code to identify the general type of benefits under which products and services are providedcategory : CodeableConcept [0..1] « null (Strength=Example)BenefitCategoryCodes?? »Is a flag to indicate whether the benefits refer to in-network providers or out-of-network providersnetwork : CodeableConcept [0..1] « null (Strength=Example)NetworkTypeCodes?? »Indicates if the benefits apply to an individual or to the familyunit : CodeableConcept [0..1] « null (Strength=Example)UnitTypeCodes?? »The term or period of the values such as 'maximum lifetime benefit' or 'maximum annual visits'term : CodeableConcept [0..1] « null (Strength=Example)BenefitTermCodes?? »The amount due from the patient for the cost categoryvalue[x] : DataType [0..1] « Quantity(SimpleQuantity)|Money »ExemptionThe code for the specific exceptiontype : CodeableConcept [1..1] « null (Strength=Example)ExampleCoverageFinancialExcep...?? »The timeframe the exception is in forceperiod : Period [0..1]Link to the paying party and optionally what specifically they will be responsible to paypaymentBy[0..*]A suite of underwriter specific classifiersclass[0..*]A suite of codes indicating exceptions or reductions to patient costs and their effective periodsexception[0..*]A suite of codes indicating the cost category and associated amount which have been detailed in the policy and may have been included on the health cardcostToBeneficiary[0..*]

XML Template

<Coverage xmlns="http://hl7.org/fhir"> doco
 <!-- from Resource: id, meta, implicitRules, and language -->
 <!-- from DomainResource: text, contained, extension, and modifierExtension -->
 <identifier><!-- 0..* Identifier Business identifier(s) for this coverage --></identifier>
 <status value="[code]"/><!-- 1..1 active | cancelled | draft | entered-in-error -->
 <kind value="[code]"/><!-- 1..1 insurance | self-pay | other -->
 <paymentBy>  <!-- 0..* Self-pay parties and responsibility -->
  <party><!-- 1..1 Reference(Organization|Patient|RelatedPerson) Parties performing self-payment --></party>
  <responsibility value="[string]"/><!-- 0..1 Party's responsibility -->
 </paymentBy>
 <type><!-- 0..1 CodeableConcept Coverage category such as medical or accident --></type>
 <policyHolder><!-- 0..1 Reference(Organization|Patient|RelatedPerson) Owner of the policy --></policyHolder>
 <subscriber><!-- 0..1 Reference(Patient|RelatedPerson) Subscriber to the policy --></subscriber>
 <subscriberId><!-- 0..* Identifier ID assigned to the subscriber --></subscriberId>
 <beneficiary><!-- 1..1 Reference(Patient) Plan beneficiary --></beneficiary>
 <dependent value="[string]"/><!-- 0..1 Dependent number -->
 <relationship><!-- 0..1 CodeableConcept Beneficiary relationship to the subscriber --></relationship>
 <period><!-- 0..1 Period Coverage start and end dates --></period>
 <insurer><!-- 0..1 Reference(Organization) Issuer of the policy --></insurer>
 <class>  <!-- 0..* Additional coverage classifications -->
  <type><!-- 1..1 CodeableConcept Type of class such as 'group' or 'plan' --></type>
  <value><!-- 1..1 Identifier Value associated with the type --></value>
  <name value="[string]"/><!-- 0..1 Human readable description of the type and value -->
 </class>
 <order value="[positiveInt]"/><!-- 0..1 Relative order of the coverage -->
 <network value="[string]"/><!-- 0..1 Insurer network -->
 <costToBeneficiary>  <!-- 0..* Patient payments for services/products -->
  <type><!-- 0..1 CodeableConcept Cost category --></type>
  <category><!-- 0..1 CodeableConcept Benefit classification --></category>
  <network><!-- 0..1 CodeableConcept In or out of network --></network>
  <unit><!-- 0..1 CodeableConcept Individual or family --></unit>
  <term><!-- 0..1 CodeableConcept Annual or lifetime --></term>
  <value[x]><!-- 0..1 Quantity(SimpleQuantity)|Money The amount or percentage due from the beneficiary --></value[x]>
  <exception>  <!-- 0..* Exceptions for patient payments -->
   <type><!-- 1..1 CodeableConcept Exception category --></type>
   <period><!-- 0..1 Period The effective period of the exception --></period>
  </exception>
 </costToBeneficiary>
 <subrogation value="[boolean]"/><!-- 0..1 Reimbursement to insurer -->
 <contract><!-- 0..* Reference(Contract) Contract details --></contract>
 <insurancePlan><!-- 0..1 Reference(InsurancePlan) Insurance plan details --></insurancePlan>
</Coverage>

JSON Template

{doco
  "resourceType" : "Coverage",
  // from Resource: id, meta, implicitRules, and language
  // from DomainResource: text, contained, extension, and modifierExtension
  "identifier" : [{ Identifier }], // Business identifier(s) for this coverage
  "status" : "<code>", // R!  active | cancelled | draft | entered-in-error
  "kind" : "<code>", // R!  insurance | self-pay | other
  "paymentBy" : [{ // Self-pay parties and responsibility
    "party" : { Reference(Organization|Patient|RelatedPerson) }, // R!  Parties performing self-payment
    "responsibility" : "<string>" // Party's responsibility
  }],
  "type" : { CodeableConcept }, // Coverage category such as medical or accident
  "policyHolder" : { Reference(Organization|Patient|RelatedPerson) }, // Owner of the policy
  "subscriber" : { Reference(Patient|RelatedPerson) }, // Subscriber to the policy
  "subscriberId" : [{ Identifier }], // ID assigned to the subscriber
  "beneficiary" : { Reference(Patient) }, // R!  Plan beneficiary
  "dependent" : "<string>", // Dependent number
  "relationship" : { CodeableConcept }, // Beneficiary relationship to the subscriber
  "period" : { Period }, // Coverage start and end dates
  "insurer" : { Reference(Organization) }, // Issuer of the policy
  "class" : [{ // Additional coverage classifications
    "type" : { CodeableConcept }, // R!  Type of class such as 'group' or 'plan'
    "value" : { Identifier }, // R!  Value associated with the type
    "name" : "<string>" // Human readable description of the type and value
  }],
  "order" : "<positiveInt>", // Relative order of the coverage
  "network" : "<string>", // Insurer network
  "costToBeneficiary" : [{ // Patient payments for services/products
    "type" : { CodeableConcept }, // Cost category
    "category" : { CodeableConcept }, // Benefit classification
    "network" : { CodeableConcept }, // In or out of network
    "unit" : { CodeableConcept }, // Individual or family
    "term" : { CodeableConcept }, // Annual or lifetime
    // value[x]: The amount or percentage due from the beneficiary. One of these 2:
    "valueQuantity" : { Quantity(SimpleQuantity) },
    "valueMoney" : { Money },
    "exception" : [{ // Exceptions for patient payments
      "type" : { CodeableConcept }, // R!  Exception category
      "period" : { Period } // The effective period of the exception
    }]
  }],
  "subrogation" : <boolean>, // Reimbursement to insurer
  "contract" : [{ Reference(Contract) }], // Contract details
  "insurancePlan" : { Reference(InsurancePlan) } // Insurance plan details
}

Turtle Template

@prefix fhir: <http://hl7.org/fhir/> .doco


[ a fhir:Coverage;
  fhir:nodeRole fhir:treeRoot; # if this is the parser root

  # from Resource: .id, .meta, .implicitRules, and .language
  # from DomainResource: .text, .contained, .extension, and .modifierExtension
  fhir:Coverage.identifier [ Identifier ], ... ; # 0..* Business identifier(s) for this coverage
  fhir:Coverage.status [ code ]; # 1..1 active | cancelled | draft | entered-in-error
  fhir:Coverage.kind [ code ]; # 1..1 insurance | self-pay | other
  fhir:Coverage.paymentBy [ # 0..* Self-pay parties and responsibility
    fhir:Coverage.paymentBy.party [ Reference(Organization|Patient|RelatedPerson) ]; # 1..1 Parties performing self-payment
    fhir:Coverage.paymentBy.responsibility [ string ]; # 0..1 Party's responsibility
  ], ...;
  fhir:Coverage.type [ CodeableConcept ]; # 0..1 Coverage category such as medical or accident
  fhir:Coverage.policyHolder [ Reference(Organization|Patient|RelatedPerson) ]; # 0..1 Owner of the policy
  fhir:Coverage.subscriber [ Reference(Patient|RelatedPerson) ]; # 0..1 Subscriber to the policy
  fhir:Coverage.subscriberId [ Identifier ], ... ; # 0..* ID assigned to the subscriber
  fhir:Coverage.beneficiary [ Reference(Patient) ]; # 1..1 Plan beneficiary
  fhir:Coverage.dependent [ string ]; # 0..1 Dependent number
  fhir:Coverage.relationship [ CodeableConcept ]; # 0..1 Beneficiary relationship to the subscriber
  fhir:Coverage.period [ Period ]; # 0..1 Coverage start and end dates
  fhir:Coverage.insurer [ Reference(Organization) ]; # 0..1 Issuer of the policy
  fhir:Coverage.class [ # 0..* Additional coverage classifications
    fhir:Coverage.class.type [ CodeableConcept ]; # 1..1 Type of class such as 'group' or 'plan'
    fhir:Coverage.class.value [ Identifier ]; # 1..1 Value associated with the type
    fhir:Coverage.class.name [ string ]; # 0..1 Human readable description of the type and value
  ], ...;
  fhir:Coverage.order [ positiveInt ]; # 0..1 Relative order of the coverage
  fhir:Coverage.network [ string ]; # 0..1 Insurer network
  fhir:Coverage.costToBeneficiary [ # 0..* Patient payments for services/products
    fhir:Coverage.costToBeneficiary.type [ CodeableConcept ]; # 0..1 Cost category
    fhir:Coverage.costToBeneficiary.category [ CodeableConcept ]; # 0..1 Benefit classification
    fhir:Coverage.costToBeneficiary.network [ CodeableConcept ]; # 0..1 In or out of network
    fhir:Coverage.costToBeneficiary.unit [ CodeableConcept ]; # 0..1 Individual or family
    fhir:Coverage.costToBeneficiary.term [ CodeableConcept ]; # 0..1 Annual or lifetime
    # Coverage.costToBeneficiary.value[x] : 0..1 The amount or percentage due from the beneficiary. One of these 2
      fhir:Coverage.costToBeneficiary.valueSimpleQuantity [ Quantity(SimpleQuantity) ]
      fhir:Coverage.costToBeneficiary.valueMoney [ Money ]
    fhir:Coverage.costToBeneficiary.exception [ # 0..* Exceptions for patient payments
      fhir:Coverage.costToBeneficiary.exception.type [ CodeableConcept ]; # 1..1 Exception category
      fhir:Coverage.costToBeneficiary.exception.period [ Period ]; # 0..1 The effective period of the exception
    ], ...;
  ], ...;
  fhir:Coverage.subrogation [ boolean ]; # 0..1 Reimbursement to insurer
  fhir:Coverage.contract [ Reference(Contract) ], ... ; # 0..* Contract details
  fhir:Coverage.insurancePlan [ Reference(InsurancePlan) ]; # 0..1 Insurance plan details
]

Changes since R4

Coverage
Coverage.kind
  • Added Mandatory Element
Coverage.paymentBy
  • Added Element
Coverage.paymentBy.party
  • Added Mandatory Element
Coverage.paymentBy.responsibility
  • Added Element
Coverage.subscriberId
  • Max Cardinality changed from 1 to *
  • Type changed from string to Identifier
  • Type changed from string to Identifier
Coverage.insurer
  • Added Element
Coverage.class.value
  • Type changed from string to Identifier
  • Type changed from string to Identifier
Coverage.costToBeneficiary.category
  • Added Element
Coverage.costToBeneficiary.network
  • Added Element
Coverage.costToBeneficiary.unit
  • Added Element
Coverage.costToBeneficiary.term
  • Added Element
Coverage.costToBeneficiary.value[x]
  • Min Cardinality changed from 1 to 0
  • Min Cardinality changed from 1 to 0
Coverage.insurancePlan
  • Added Element
Coverage.payor
  • deleted

See the Full Difference for further information

This analysis is available as XML or JSON.

See R3 <--> R4 Conversion Maps (status = 4 tests that all execute ok. 1 fail round-trip testing and all r3 resources are valid.)

Structure

NameFlagsCard.TypeDescription & Constraintsdoco
.. Coverage TUDomainResourceInsurance or medical plan or a payment agreement

Elements defined in Ancestors: id, meta, implicitRules, language, text, contained, extension, modifierExtension
... identifier Σ0..*IdentifierBusiness identifier(s) for this coverage

... status ?!Σ1..1codeactive | cancelled | draft | entered-in-error
Financial Resource Status Codes (Required)
... kind Σ1..1codeinsurance | self-pay | other
Kind (Required)
.... party Σ1..1Reference(Patient | RelatedPerson | Organization)Parties performing self-payment
.... responsibility Σ0..1stringParty's responsibility
... type Σ0..1CodeableConceptCoverage category such as medical or accident
Coverage Type and Self-Pay Codes (Preferred)
... policyHolder Σ0..1Reference(Patient | RelatedPerson | Organization)Owner of the policy
... subscriber Σ0..1Reference(Patient | RelatedPerson)Subscriber to the policy
... subscriberId Σ0..*IdentifierID assigned to the subscriber

... beneficiary Σ1..1Reference(Patient)Plan beneficiary
... dependent Σ0..1stringDependent number
... relationship 0..1CodeableConceptBeneficiary relationship to the subscriber
SubscriberPolicyholder Relationship Codes (Extensible)
... period Σ0..1PeriodCoverage start and end dates
... insurer Σ0..1Reference(Organization)Issuer of the policy
... class 0..*BackboneElementAdditional coverage classifications

.... type Σ1..1CodeableConceptType of class such as 'group' or 'plan'
Coverage Class Codes (Extensible)
.... value Σ1..1IdentifierValue associated with the type
.... name Σ0..1stringHuman readable description of the type and value
... order Σ0..1positiveIntRelative order of the coverage
... network Σ0..1stringInsurer network
... costToBeneficiary 0..*BackboneElementPatient payments for services/products

.... type Σ0..1CodeableConceptCost category
Coverage Copay Type Codes (Extensible)
.... category 0..1CodeableConceptBenefit classification
Benefit Category Codes (Example)
.... network 0..1CodeableConceptIn or out of network
Network Type Codes (Example)
.... unit 0..1CodeableConceptIndividual or family
Unit Type Codes (Example)
.... term 0..1CodeableConceptAnnual or lifetime
Benefit Term Codes (Example)
.... value[x] Σ0..1The amount or percentage due from the beneficiary
..... valueQuantitySimpleQuantity
..... valueMoneyMoney
.... exception 0..*BackboneElementExceptions for patient payments

..... type Σ1..1CodeableConceptException category
Example Coverage Financial Exception Codes (Example)
..... period Σ0..1PeriodThe effective period of the exception
... subrogation 0..1booleanReimbursement to insurer
... contract 0..*Reference(Contract)Contract details

... insurancePlan 0..1Reference(InsurancePlan)Insurance plan details

doco Documentation for this format

See the Extensions for this resource

UML Diagram (Legend)

Coverage (DomainResource)The identifier of the coverage as issued by the insureridentifier : Identifier [0..*]The status of the resource instance (this element modifies the meaning of other elements)status : code [1..1] « null (Strength=Required)FinancialResourceStatusCodes! »The nature of the coverage be it insurance, or cash payment such as self-paykind : code [1..1] « null (Strength=Required)Kind! »The type of coverage: social program, medical plan, accident coverage (workers compensation, auto), group health or payment by an individual or organizationtype : CodeableConcept [0..1] « null (Strength=Preferred)CoverageTypeAndSelf-PayCodes? »The party who 'owns' the insurance policypolicyHolder : Reference [0..1] « Patient|RelatedPerson|Organization »The party who has signed-up for or 'owns' the contractual relationship to the policy or to whom the benefit of the policy for services rendered to them or their family is duesubscriber : Reference [0..1] « Patient|RelatedPerson »The insurer assigned ID for the SubscribersubscriberId : Identifier [0..*]The party who benefits from the insurance coverage; the patient when products and/or services are providedbeneficiary : Reference [1..1] « Patient »A designator for a dependent under the coveragedependent : string [0..1]The relationship of beneficiary (patient) to the subscriberrelationship : CodeableConcept [0..1] « null (Strength=Extensible)SubscriberRelationshipCodes+ »Time period during which the coverage is in force. A missing start date indicates the start date isn't known, a missing end date means the coverage is continuing to be in forceperiod : Period [0..1]The program or plan underwriter, payor, insurance companyinsurer : Reference [0..1] « Organization »The order of applicability of this coverage relative to other coverages which are currently in force. Note, there may be gaps in the numbering and this does not imply primary, secondary etc. as the specific positioning of coverages depends upon the episode of care. For example; a patient might have (0) auto insurance (1) their own health insurance and (2) spouse's health insurance. When claiming for treatments which were not the result of an auto accident then only coverages (1) and (2) above would be applicatble and would apply in the order specified in parenthesisorder : positiveInt [0..1]The insurer-specific identifier for the insurer-defined network of providers to which the beneficiary may seek treatment which will be covered at the 'in-network' rate, otherwise 'out of network' terms and conditions applynetwork : string [0..1]When 'subrogation=true' this insurance instance has been included not for adjudication but to provide insurers with the details to recover costssubrogation : boolean [0..1]The policy(s) which constitute this insurance coveragecontract : Reference [0..*] « Contract »The insurance plan details, benefits and costs, which constitute this insurance coverageinsurancePlan : Reference [0..1] « InsurancePlan »PaymentByThe list of parties providing non-insurance payment for the treatment costsparty : Reference [1..1] « Patient|RelatedPerson|Organization » Description of the financial responsibilityresponsibility : string [0..1]ClassThe type of classification for which an insurer-specific class label or number and optional name is provided. For example, type may be used to identify a class of coverage or employer group, policy, or plantype : CodeableConcept [1..1] « null (Strength=Extensible)CoverageClassCodes+ »The alphanumeric identifier associated with the insurer issued labelvalue : Identifier [1..1]A short description for the classname : string [0..1]CostToBeneficiaryThe category of patient centric costs associated with treatmenttype : CodeableConcept [0..1] « null (Strength=Extensible)CoverageCopayTypeCodes+ »Code to identify the general type of benefits under which products and services are providedcategory : CodeableConcept [0..1] « null (Strength=Example)BenefitCategoryCodes?? »Is a flag to indicate whether the benefits refer to in-network providers or out-of-network providersnetwork : CodeableConcept [0..1] « null (Strength=Example)NetworkTypeCodes?? »Indicates if the benefits apply to an individual or to the familyunit : CodeableConcept [0..1] « null (Strength=Example)UnitTypeCodes?? »The term or period of the values such as 'maximum lifetime benefit' or 'maximum annual visits'term : CodeableConcept [0..1] « null (Strength=Example)BenefitTermCodes?? »The amount due from the patient for the cost categoryvalue[x] : DataType [0..1] « Quantity(SimpleQuantity)|Money »ExemptionThe code for the specific exceptiontype : CodeableConcept [1..1] « null (Strength=Example)ExampleCoverageFinancialExcep...?? »The timeframe the exception is in forceperiod : Period [0..1]Link to the paying party and optionally what specifically they will be responsible to paypaymentBy[0..*]A suite of underwriter specific classifiersclass[0..*]A suite of codes indicating exceptions or reductions to patient costs and their effective periodsexception[0..*]A suite of codes indicating the cost category and associated amount which have been detailed in the policy and may have been included on the health cardcostToBeneficiary[0..*]

XML Template

<Coverage xmlns="http://hl7.org/fhir"> doco
 <!-- from Resource: id, meta, implicitRules, and language -->
 <!-- from DomainResource: text, contained, extension, and modifierExtension -->
 <identifier><!-- 0..* Identifier Business identifier(s) for this coverage --></identifier>
 <status value="[code]"/><!-- 1..1 active | cancelled | draft | entered-in-error -->
 <kind value="[code]"/><!-- 1..1 insurance | self-pay | other -->
 <paymentBy>  <!-- 0..* Self-pay parties and responsibility -->
  <party><!-- 1..1 Reference(Organization|Patient|RelatedPerson) Parties performing self-payment --></party>
  <responsibility value="[string]"/><!-- 0..1 Party's responsibility -->
 </paymentBy>
 <type><!-- 0..1 CodeableConcept Coverage category such as medical or accident --></type>
 <policyHolder><!-- 0..1 Reference(Organization|Patient|RelatedPerson) Owner of the policy --></policyHolder>
 <subscriber><!-- 0..1 Reference(Patient|RelatedPerson) Subscriber to the policy --></subscriber>
 <subscriberId><!-- 0..* Identifier ID assigned to the subscriber --></subscriberId>
 <beneficiary><!-- 1..1 Reference(Patient) Plan beneficiary --></beneficiary>
 <dependent value="[string]"/><!-- 0..1 Dependent number -->
 <relationship><!-- 0..1 CodeableConcept Beneficiary relationship to the subscriber --></relationship>
 <period><!-- 0..1 Period Coverage start and end dates --></period>
 <insurer><!-- 0..1 Reference(Organization) Issuer of the policy --></insurer>
 <class>  <!-- 0..* Additional coverage classifications -->
  <type><!-- 1..1 CodeableConcept Type of class such as 'group' or 'plan' --></type>
  <value><!-- 1..1 Identifier Value associated with the type --></value>
  <name value="[string]"/><!-- 0..1 Human readable description of the type and value -->
 </class>
 <order value="[positiveInt]"/><!-- 0..1 Relative order of the coverage -->
 <network value="[string]"/><!-- 0..1 Insurer network -->
 <costToBeneficiary>  <!-- 0..* Patient payments for services/products -->
  <type><!-- 0..1 CodeableConcept Cost category --></type>
  <category><!-- 0..1 CodeableConcept Benefit classification --></category>
  <network><!-- 0..1 CodeableConcept In or out of network --></network>
  <unit><!-- 0..1 CodeableConcept Individual or family --></unit>
  <term><!-- 0..1 CodeableConcept Annual or lifetime --></term>
  <value[x]><!-- 0..1 Quantity(SimpleQuantity)|Money The amount or percentage due from the beneficiary --></value[x]>
  <exception>  <!-- 0..* Exceptions for patient payments -->
   <type><!-- 1..1 CodeableConcept Exception category --></type>
   <period><!-- 0..1 Period The effective period of the exception --></period>
  </exception>
 </costToBeneficiary>
 <subrogation value="[boolean]"/><!-- 0..1 Reimbursement to insurer -->
 <contract><!-- 0..* Reference(Contract) Contract details --></contract>
 <insurancePlan><!-- 0..1 Reference(InsurancePlan) Insurance plan details --></insurancePlan>
</Coverage>

JSON Template

{doco
  "resourceType" : "Coverage",
  // from Resource: id, meta, implicitRules, and language
  // from DomainResource: text, contained, extension, and modifierExtension
  "identifier" : [{ Identifier }], // Business identifier(s) for this coverage
  "status" : "<code>", // R!  active | cancelled | draft | entered-in-error
  "kind" : "<code>", // R!  insurance | self-pay | other
  "paymentBy" : [{ // Self-pay parties and responsibility
    "party" : { Reference(Organization|Patient|RelatedPerson) }, // R!  Parties performing self-payment
    "responsibility" : "<string>" // Party's responsibility
  }],
  "type" : { CodeableConcept }, // Coverage category such as medical or accident
  "policyHolder" : { Reference(Organization|Patient|RelatedPerson) }, // Owner of the policy
  "subscriber" : { Reference(Patient|RelatedPerson) }, // Subscriber to the policy
  "subscriberId" : [{ Identifier }], // ID assigned to the subscriber
  "beneficiary" : { Reference(Patient) }, // R!  Plan beneficiary
  "dependent" : "<string>", // Dependent number
  "relationship" : { CodeableConcept }, // Beneficiary relationship to the subscriber
  "period" : { Period }, // Coverage start and end dates
  "insurer" : { Reference(Organization) }, // Issuer of the policy
  "class" : [{ // Additional coverage classifications
    "type" : { CodeableConcept }, // R!  Type of class such as 'group' or 'plan'
    "value" : { Identifier }, // R!  Value associated with the type
    "name" : "<string>" // Human readable description of the type and value
  }],
  "order" : "<positiveInt>", // Relative order of the coverage
  "network" : "<string>", // Insurer network
  "costToBeneficiary" : [{ // Patient payments for services/products
    "type" : { CodeableConcept }, // Cost category
    "category" : { CodeableConcept }, // Benefit classification
    "network" : { CodeableConcept }, // In or out of network
    "unit" : { CodeableConcept }, // Individual or family
    "term" : { CodeableConcept }, // Annual or lifetime
    // value[x]: The amount or percentage due from the beneficiary. One of these 2:
    "valueQuantity" : { Quantity(SimpleQuantity) },
    "valueMoney" : { Money },
    "exception" : [{ // Exceptions for patient payments
      "type" : { CodeableConcept }, // R!  Exception category
      "period" : { Period } // The effective period of the exception
    }]
  }],
  "subrogation" : <boolean>, // Reimbursement to insurer
  "contract" : [{ Reference(Contract) }], // Contract details
  "insurancePlan" : { Reference(InsurancePlan) } // Insurance plan details
}

Turtle Template

@prefix fhir: <http://hl7.org/fhir/> .doco


[ a fhir:Coverage;
  fhir:nodeRole fhir:treeRoot; # if this is the parser root

  # from Resource: .id, .meta, .implicitRules, and .language
  # from DomainResource: .text, .contained, .extension, and .modifierExtension
  fhir:Coverage.identifier [ Identifier ], ... ; # 0..* Business identifier(s) for this coverage
  fhir:Coverage.status [ code ]; # 1..1 active | cancelled | draft | entered-in-error
  fhir:Coverage.kind [ code ]; # 1..1 insurance | self-pay | other
  fhir:Coverage.paymentBy [ # 0..* Self-pay parties and responsibility
    fhir:Coverage.paymentBy.party [ Reference(Organization|Patient|RelatedPerson) ]; # 1..1 Parties performing self-payment
    fhir:Coverage.paymentBy.responsibility [ string ]; # 0..1 Party's responsibility
  ], ...;
  fhir:Coverage.type [ CodeableConcept ]; # 0..1 Coverage category such as medical or accident
  fhir:Coverage.policyHolder [ Reference(Organization|Patient|RelatedPerson) ]; # 0..1 Owner of the policy
  fhir:Coverage.subscriber [ Reference(Patient|RelatedPerson) ]; # 0..1 Subscriber to the policy
  fhir:Coverage.subscriberId [ Identifier ], ... ; # 0..* ID assigned to the subscriber
  fhir:Coverage.beneficiary [ Reference(Patient) ]; # 1..1 Plan beneficiary
  fhir:Coverage.dependent [ string ]; # 0..1 Dependent number
  fhir:Coverage.relationship [ CodeableConcept ]; # 0..1 Beneficiary relationship to the subscriber
  fhir:Coverage.period [ Period ]; # 0..1 Coverage start and end dates
  fhir:Coverage.insurer [ Reference(Organization) ]; # 0..1 Issuer of the policy
  fhir:Coverage.class [ # 0..* Additional coverage classifications
    fhir:Coverage.class.type [ CodeableConcept ]; # 1..1 Type of class such as 'group' or 'plan'
    fhir:Coverage.class.value [ Identifier ]; # 1..1 Value associated with the type
    fhir:Coverage.class.name [ string ]; # 0..1 Human readable description of the type and value
  ], ...;
  fhir:Coverage.order [ positiveInt ]; # 0..1 Relative order of the coverage
  fhir:Coverage.network [ string ]; # 0..1 Insurer network
  fhir:Coverage.costToBeneficiary [ # 0..* Patient payments for services/products
    fhir:Coverage.costToBeneficiary.type [ CodeableConcept ]; # 0..1 Cost category
    fhir:Coverage.costToBeneficiary.category [ CodeableConcept ]; # 0..1 Benefit classification
    fhir:Coverage.costToBeneficiary.network [ CodeableConcept ]; # 0..1 In or out of network
    fhir:Coverage.costToBeneficiary.unit [ CodeableConcept ]; # 0..1 Individual or family
    fhir:Coverage.costToBeneficiary.term [ CodeableConcept ]; # 0..1 Annual or lifetime
    # Coverage.costToBeneficiary.value[x] : 0..1 The amount or percentage due from the beneficiary. One of these 2
      fhir:Coverage.costToBeneficiary.valueSimpleQuantity [ Quantity(SimpleQuantity) ]
      fhir:Coverage.costToBeneficiary.valueMoney [ Money ]
    fhir:Coverage.costToBeneficiary.exception [ # 0..* Exceptions for patient payments
      fhir:Coverage.costToBeneficiary.exception.type [ CodeableConcept ]; # 1..1 Exception category
      fhir:Coverage.costToBeneficiary.exception.period [ Period ]; # 0..1 The effective period of the exception
    ], ...;
  ], ...;
  fhir:Coverage.subrogation [ boolean ]; # 0..1 Reimbursement to insurer
  fhir:Coverage.contract [ Reference(Contract) ], ... ; # 0..* Contract details
  fhir:Coverage.insurancePlan [ Reference(InsurancePlan) ]; # 0..1 Insurance plan details
]

Changes since Release 4

Coverage
Coverage.kind
  • Added Mandatory Element
Coverage.paymentBy
  • Added Element
Coverage.paymentBy.party
  • Added Mandatory Element
Coverage.paymentBy.responsibility
  • Added Element
Coverage.subscriberId
  • Max Cardinality changed from 1 to *
  • Type changed from string to Identifier
  • Type changed from string to Identifier
Coverage.insurer
  • Added Element
Coverage.class.value
  • Type changed from string to Identifier
  • Type changed from string to Identifier
Coverage.costToBeneficiary.category
  • Added Element
Coverage.costToBeneficiary.network
  • Added Element
Coverage.costToBeneficiary.unit
  • Added Element
Coverage.costToBeneficiary.term
  • Added Element
Coverage.costToBeneficiary.value[x]
  • Min Cardinality changed from 1 to 0
  • Min Cardinality changed from 1 to 0
Coverage.insurancePlan
  • Added Element
Coverage.payor
  • deleted

See the Full Difference for further information

This analysis is available as XML or JSON.

See R3 <--> R4 Conversion Maps (status = 4 tests that all execute ok. 1 fail round-trip testing and all r3 resources are valid.)

 

Additional definitions: Master Definition XML + JSON, XML Schema/Schematron + JSON Schema, ShEx (for Turtle) + see the extensions, the spreadsheet version & the dependency analysis

PathDefinitionTypeReference
Coverage.status

This value set includes Status codes.

RequiredFinancialResourceStatusCodes
Coverage.kind

The kind of coverage: insurance, selfpay or other.

RequiredKind
Coverage.type

This value set includes Coverage Type codes.

PreferredCoverageTypeAndSelf-PayCodes
Coverage.relationship

This value set includes codes for the relationship between the Subscriber and the Beneficiary (insured/covered party/patient).

ExtensibleSubscriberRelationshipCodes
Coverage.class.type

This value set includes Coverage Class codes.

ExtensibleCoverageClassCodes
Coverage.costToBeneficiary.type

This value set includes sample Coverage Copayment Type codes.

ExtensibleCoverageCopayTypeCodes
Coverage.costToBeneficiary.category

This value set includes examples of Benefit Category codes.

ExampleBenefitCategoryCodes
Coverage.costToBeneficiary.network

This value set includes a smattering of Network type codes.

ExampleNetworkTypeCodes
Coverage.costToBeneficiary.unit

This value set includes a smattering of Unit type codes.

ExampleUnitTypeCodes
Coverage.costToBeneficiary.term

This value set includes a smattering of Benefit Term codes.

ExampleBenefitTermCodes
Coverage.costToBeneficiary.exception.type

This value set includes Example Coverage Financial Exception Codes.

ExampleExampleCoverageFinancialExceptionCodes

Search parameters for this resource. The common parameters also apply. See Searching for more information about searching in REST, messaging, and services.

NameTypeDescriptionExpressionIn Common
beneficiaryreferenceCovered partyCoverage.beneficiary
(Patient)
class-typetokenCoverage class (eg. plan, group)Coverage.class.type
class-value NtokenValue of the class (eg. Plan number, group number)Coverage.class.value
dependent NstringDependent numberCoverage.dependent
identifiertokenThe primary identifier of the insured and the coverageCoverage.identifier
insurerreferenceThe identity of the insurerCoverage.insurer
(Organization)
patientreferenceRetrieve coverages for a patientCoverage.beneficiary
(Patient)
paymentby-partyreferenceParties who will pay for servicesCoverage.paymentBy.party
(Organization, Patient, RelatedPerson)
policy-holderreferenceReference to the policyholderCoverage.policyHolder
(Organization, Patient, RelatedPerson)
status NtokenThe status of the CoverageCoverage.status
subscriberreferenceReference to the subscriberCoverage.subscriber
(Patient, RelatedPerson)
subscriberidtokenIdentifier of the subscriberCoverage.subscriberId
typetokenThe kind of coverage (health plan, auto, Workers Compensation)Coverage.type