US Behavioral Health Profiles Implementation Guide
            
            0.1.0 - CI Build
  
            
          
This page is part of the US Behavioral Health Profiles (v0.1.0: Release) based on FHIR (HL7® FHIR® Standard) R4. This is the current published version. For a full list of available versions, see the Directory of published versions
| Draft as of 2025-08-18 | 
Definitions for the program-info extension.
Guidance on how to interpret the contents of this table can be foundhere
| 0. Extension | |
| Definition | An Extension Optional Extension Element - found in all resources. | 
| Short | Grant Program ID and NumberOptional Extensions Element | 
| Control | 0..* This element is affected by the following invariants: ele-1 | 
| Is Modifier | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists())ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists()) | 
| 2. Extension.extension | |
| Definition | An Extension May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. | 
| Short | ExtensionAdditional content defined by implementations | 
| Comments | There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone. | 
| Control | 10..* | 
| Type | Extension | 
| Is Modifier | false | 
| Summary | false | 
| Alternate Names | extensions, user content | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists()) | 
| Slicing | This element introduces a set of slices on Extension.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators: | 
| 4. Extension.extension:program-id | |
| Slice Name | program-id | 
| Definition | The program id for a program that that is participating in a designated behavioral health program. | 
| Short | The program id for a program that that is participating in a designated behavioral health program.Additional content defined by implementations | 
| Control | 0..1* | 
| Type | Extension | 
| Is Modifier | false | 
| Must Support | true | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists()) | 
| 6. Extension.extension:program-id.extension | |
| Definition | An Extension May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. | 
| Short | ExtensionAdditional content defined by implementations | 
| Comments | There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone. | 
| Control | 0..0* | 
| Type | Extension | 
| Is Modifier | false | 
| Summary | false | 
| Alternate Names | extensions, user content | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists()) | 
| Slicing | This element introduces a set of slices on Extension.extension.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators: | 
| 8. Extension.extension:program-id.url | |
| Definition | Source of the definition for the extension code - a logical name or a URL. | 
| Short | identifies the meaning of the extension | 
| Comments | The definition may point directly to a computable or human-readable definition of the extensibility codes, or it may be a logical URI as declared in some other specification. The definition SHALL be a URI for the Structure Definition defining the extension. | 
| Control | 1..1 | 
| Type | uri | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| Fixed Value | program-id | 
| 10. Extension.extension:program-id.value[x] | |
| Definition | Value of extension - must be one of a constrained set of the data types (see Extensibility for a list). | 
| Short | Value of extension | 
| Control | 10..1 | 
| Type | string, date, Meta, Address, Attachment, integer, Count, DataRequirement, Dosage, uuid, Identifier, Coding, SampledData, id, positiveInt, Distance, Period, Duration, canonical, Range, RelatedArtifact, base64Binary, UsageContext, Timing, decimal, CodeableConcept, ParameterDefinition, dateTime, code, Contributor, oid, instant, ContactPoint, HumanName, Money, markdown, Ratio, Age, Reference, TriggerDefinition, Quantity, uri, url, Annotation, ContactDetail, boolean, Expression, Signature, unsignedInt, time | 
| [x] Note | SeeChoice of Data Typesfor further information about how to use [x] | 
| Is Modifier | false | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) | 
| 12. Extension.extension:grant-number | |
| Slice Name | grant-number | 
| Definition | The grant number that the behavioral health service is operating under. | 
| Short | The grant number that the behavioral health service is operating under.Additional content defined by implementations | 
| Control | 0..1* | 
| Type | Extension | 
| Is Modifier | false | 
| Must Support | true | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists()) | 
| 14. Extension.extension:grant-number.extension | |
| Definition | An Extension May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. | 
| Short | ExtensionAdditional content defined by implementations | 
| Comments | There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone. | 
| Control | 0..0* | 
| Type | Extension | 
| Is Modifier | false | 
| Summary | false | 
| Alternate Names | extensions, user content | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists()) | 
| Slicing | This element introduces a set of slices on Extension.extension.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators: | 
| 16. Extension.extension:grant-number.url | |
| Definition | Source of the definition for the extension code - a logical name or a URL. | 
| Short | identifies the meaning of the extension | 
| Comments | The definition may point directly to a computable or human-readable definition of the extensibility codes, or it may be a logical URI as declared in some other specification. The definition SHALL be a URI for the Structure Definition defining the extension. | 
| Control | 1..1 | 
| Type | uri | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| Fixed Value | grant-number | 
| 18. Extension.extension:grant-number.value[x] | |
| Definition | Value of extension - must be one of a constrained set of the data types (see Extensibility for a list). | 
| Short | Value of extension | 
| Control | 0..1 | 
| Type | string, date, Meta, Address, Attachment, integer, Count, DataRequirement, Dosage, uuid, Identifier, Coding, SampledData, id, positiveInt, Distance, Period, Duration, canonical, Range, RelatedArtifact, base64Binary, UsageContext, Timing, decimal, CodeableConcept, ParameterDefinition, dateTime, code, Contributor, oid, instant, ContactPoint, HumanName, Money, markdown, Ratio, Age, Reference, TriggerDefinition, Quantity, uri, url, Annotation, ContactDetail, boolean, Expression, Signature, unsignedInt, time | 
| [x] Note | SeeChoice of Data Typesfor further information about how to use [x] | 
| Is Modifier | false | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) | 
| 20. Extension.url | |
| Definition | Source of the definition for the extension code - a logical name or a URL. | 
| Short | identifies the meaning of the extension | 
| Comments | The definition may point directly to a computable or human-readable definition of the extensibility codes, or it may be a logical URI as declared in some other specification. The definition SHALL be a URI for the Structure Definition defining the extension. | 
| Control | 1..1 | 
| Type | uri | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| Fixed Value | http://fhir.org/guides/astp/bhp/StructureDefinition/program-info | 
| 22. Extension.value[x] | |
| Definition | Value of extension - must be one of a constrained set of the data types (see Extensibility for a list). | 
| Short | Value of extension | 
| Control | 0..01 | 
| Type | Choice of: base64Binary, boolean, canonical, code, date, dateTime, decimal, id, instant, integer, markdown, oid, positiveInt, string, time, unsignedInt, uri, url, uuid, Address, Age, Annotation, Attachment, CodeableConcept, Coding, ContactPoint, Count, Distance, Duration, HumanName, Identifier, Money, Period, Quantity, Range, Ratio, Reference, SampledData, Signature, Timing, ContactDetail, Contributor, DataRequirement, Expression, ParameterDefinition, RelatedArtifact, TriggerDefinition, UsageContext, Dosage, Meta | 
| Is Modifier | false | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children (hasValue() or (children().count() > id.count())) | 
Guidance on how to interpret the contents of this table can be foundhere
| 0. Extension | |
| Short | Grant Program ID and Number | 
| 2. Extension.extension | |
| Control | 1..? | 
| 4. Extension.extension:program-id | |
| Slice Name | program-id | 
| Definition | The program id for a program that that is participating in a designated behavioral health program. | 
| Short | The program id for a program that that is participating in a designated behavioral health program. | 
| Control | 0..1 | 
| Must Support | true | 
| 6. Extension.extension:program-id.extension | |
| Control | 0..0 | 
| 8. Extension.extension:program-id.url | |
| Fixed Value | program-id | 
| 10. Extension.extension:program-id.value[x] | |
| Control | 1..? | 
| Type | string | 
| [x] Note | SeeChoice of Data Typesfor further information about how to use [x] | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| 12. Extension.extension:grant-number | |
| Slice Name | grant-number | 
| Definition | The grant number that the behavioral health service is operating under. | 
| Short | The grant number that the behavioral health service is operating under. | 
| Control | 0..1 | 
| Must Support | true | 
| 14. Extension.extension:grant-number.extension | |
| Control | 0..0 | 
| 16. Extension.extension:grant-number.url | |
| Fixed Value | grant-number | 
| 18. Extension.extension:grant-number.value[x] | |
| Type | string | 
| [x] Note | SeeChoice of Data Typesfor further information about how to use [x] | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| 20. Extension.url | |
| Fixed Value | http://fhir.org/guides/astp/bhp/StructureDefinition/program-info | 
| 22. Extension.value[x] | |
| Control | 0..0 | 
Guidance on how to interpret the contents of this table can be foundhere
| 0. Extension | |
| Definition | An Extension | 
| Short | Grant Program ID and Number | 
| Control | 0..* This element is affected by the following invariants: ele-1 | 
| Is Modifier | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count()))ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists()) | 
| 2. Extension.id | |
| Definition | Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces. | 
| Short | Unique id for inter-element referencing | 
| Control | 0..1 | 
| Type | string | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| 4. Extension.extension | |
| Definition | An Extension | 
| Short | Extension | 
| Control | 1..* | 
| Type | Extension | 
| Is Modifier | false | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count()))ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists()) | 
| Slicing | This element introduces a set of slices on Extension.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators: | 
| 6. Extension.extension:program-id | |
| Slice Name | program-id | 
| Definition | The program id for a program that that is participating in a designated behavioral health program. | 
| Short | The program id for a program that that is participating in a designated behavioral health program. | 
| Control | 0..1 | 
| Type | Extension | 
| Is Modifier | false | 
| Must Support | true | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count()))ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists()) | 
| 8. Extension.extension:program-id.id | |
| Definition | Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces. | 
| Short | Unique id for inter-element referencing | 
| Control | 0..1 | 
| Type | string | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| 10. Extension.extension:program-id.extension | |
| Definition | An Extension | 
| Short | Extension | 
| Control | 0..0 | 
| Type | Extension | 
| Is Modifier | false | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count()))ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists()) | 
| Slicing | This element introduces a set of slices on Extension.extension.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators: | 
| 12. Extension.extension:program-id.url | |
| Definition | Source of the definition for the extension code - a logical name or a URL. | 
| Short | identifies the meaning of the extension | 
| Comments | The definition may point directly to a computable or human-readable definition of the extensibility codes, or it may be a logical URI as declared in some other specification. The definition SHALL be a URI for the Structure Definition defining the extension. | 
| Control | 1..1 | 
| Type | uri | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| Fixed Value | program-id | 
| 14. Extension.extension:program-id.value[x] | |
| Definition | Value of extension - must be one of a constrained set of the data types (see Extensibility for a list). | 
| Short | Value of extension | 
| Control | 1..1 | 
| Type | string | 
| [x] Note | SeeChoice of Data Typesfor further information about how to use [x] | 
| Is Modifier | false | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count())) | 
| 16. Extension.extension:grant-number | |
| Slice Name | grant-number | 
| Definition | The grant number that the behavioral health service is operating under. | 
| Short | The grant number that the behavioral health service is operating under. | 
| Control | 0..1 | 
| Type | Extension | 
| Is Modifier | false | 
| Must Support | true | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count()))ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists()) | 
| 18. Extension.extension:grant-number.id | |
| Definition | Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces. | 
| Short | Unique id for inter-element referencing | 
| Control | 0..1 | 
| Type | string | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| 20. Extension.extension:grant-number.extension | |
| Definition | An Extension | 
| Short | Extension | 
| Control | 0..0 | 
| Type | Extension | 
| Is Modifier | false | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count()))ext-1: Must have either extensions or value[x], not both ( extension.exists() != value.exists()) | 
| Slicing | This element introduces a set of slices on Extension.extension.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators: | 
| 22. Extension.extension:grant-number.url | |
| Definition | Source of the definition for the extension code - a logical name or a URL. | 
| Short | identifies the meaning of the extension | 
| Comments | The definition may point directly to a computable or human-readable definition of the extensibility codes, or it may be a logical URI as declared in some other specification. The definition SHALL be a URI for the Structure Definition defining the extension. | 
| Control | 1..1 | 
| Type | uri | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| Fixed Value | grant-number | 
| 24. Extension.extension:grant-number.value[x] | |
| Definition | Value of extension - must be one of a constrained set of the data types (see Extensibility for a list). | 
| Short | Value of extension | 
| Control | 0..1 | 
| Type | string | 
| [x] Note | SeeChoice of Data Typesfor further information about how to use [x] | 
| Is Modifier | false | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count())) | 
| 26. Extension.url | |
| Definition | Source of the definition for the extension code - a logical name or a URL. | 
| Short | identifies the meaning of the extension | 
| Comments | The definition may point directly to a computable or human-readable definition of the extensibility codes, or it may be a logical URI as declared in some other specification. The definition SHALL be a URI for the Structure Definition defining the extension. | 
| Control | 1..1 | 
| Type | uri | 
| Is Modifier | false | 
| XML Format | In the XML format, this property is represented as an attribute. | 
| Summary | false | 
| Fixed Value | http://fhir.org/guides/astp/bhp/StructureDefinition/program-info | 
| 28. Extension.value[x] | |
| Definition | Value of extension - must be one of a constrained set of the data types (see Extensibility for a list). | 
| Short | Value of extension | 
| Control | 0..0 | 
| Type | Choice of: base64Binary, boolean, canonical, code, date, dateTime, decimal, id, instant, integer, markdown, oid, positiveInt, string, time, unsignedInt, uri, url, uuid, Address, Age, Annotation, Attachment, CodeableConcept, Coding, ContactPoint, Count, Distance, Duration, HumanName, Identifier, Money, Period, Quantity, Range, Ratio, Reference, SampledData, Signature, Timing, ContactDetail, Contributor, DataRequirement, Expression, ParameterDefinition, RelatedArtifact, TriggerDefinition, UsageContext, Dosage, Meta | 
| Is Modifier | false | 
| Primitive Value | This primitive element may be present, or absent, or replaced by an extension | 
| Summary | false | 
| Invariants | ele-1: All FHIR elements must have a @value or children ( hasValue() or (children().count() > id.count())) |