Finnish Implementation Guide for SMART App Launch
            
            2.0.0-rc3 - qa-preview
  
            
          
This page is part of the Finnish Implementation Guide for SMART App Launch (v2.0.0-rc3: STU 2 Ballot 2) 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
| Official URL: https://hl7.fi/fhir/finnish-smart/StructureDefinition/fi-smart-practitioner-role | Version: 2.0.0-rc3 | |||
| Draft as of 2025-06-01 | Computable Name: FiSMARTPractitionerRole | |||
This is the Finnish patient facing profile for the PractitionerRole resource.
Usages:
Description of Profiles, Differentials, Snapshots and how the different presentations work.
| Name | Flags | Card. | Type | Description & Constraints    Filter:   | 
|---|---|---|---|---|
|   PractitionerRole | 0..* | FiBasePractitionerRole | Roles/organizations the practitioner is associated with This profile also imposes the profile IPA-PractitionerRole (1.1.0) dom-2: If the resource is contained in another resource, it SHALL NOT contain nested Resources dom-3: If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource dom-4: If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated dom-5: If a resource is contained in another resource, it SHALL NOT have a security label dom-6: A resource should have narrative for robust management | |
|    implicitRules | ?!Σ | 0..1 | uri | A set of rules under which this content was created ele-1: All FHIR elements must have a @value or children | 
|    modifierExtension | ?! | 0..* | Extension | Extensions that cannot be ignored ele-1: All FHIR elements must have a @value or children ext-1: Must have either extensions or value[x], not both | 
|    practitioner | SΣ | 0..1 | Reference(FI Base Practitioner) | Practitioner that is able to provide the defined services for the organization ele-1: All FHIR elements must have a @value or children | 
|  Documentation for this format | ||||
| Id | Grade | Path(s) | Details | Requirements | 
| dom-2 | error | PractitionerRole | If the resource is contained in another resource, it SHALL NOT contain nested Resources : contained.contained.empty() | |
| dom-3 | error | PractitionerRole | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource : contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty() | |
| dom-4 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated : contained.meta.versionId.empty() and contained.meta.lastUpdated.empty() | |
| dom-5 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a security label : contained.meta.security.empty() | |
| dom-6 | best practice | PractitionerRole | A resource should have narrative for robust management : text.`div`.exists() | |
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children : hasValue() or (children().count() > id.count()) | |
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both : extension.exists() != value.exists() | 
This structure is derived from FiBasePractitionerRole
| Name | Flags | Card. | Type | Description & Constraints    Filter:   | 
|---|---|---|---|---|
|   PractitionerRole | 0..* | FiBasePractitionerRole | Roles/organizations the practitioner is associated with This profile also imposes the profile IPA-PractitionerRole (1.1.0) | |
|  Documentation for this format | ||||
| Name | Flags | Card. | Type | Description & Constraints    Filter:   | ||||
|---|---|---|---|---|---|---|---|---|
|   PractitionerRole | 0..* | FiBasePractitionerRole | Roles/organizations the practitioner is associated with This profile also imposes the profile IPA-PractitionerRole (1.1.0) | |||||
|    id | Σ | 0..1 | id | Logical id of this artifact | ||||
|    meta | Σ | 0..1 | Meta | Metadata about the resource | ||||
|    implicitRules | ?!Σ | 0..1 | uri | A set of rules under which this content was created | ||||
|    language | 0..1 | code | Language of the resource content Binding: CommonLanguages (preferred): A human language. 
 | |||||
|    text | 0..1 | Narrative | Text summary of the resource, for human interpretation | |||||
|    contained | 0..* | Resource | Contained, inline Resources | |||||
|    extension | 0..* | Extension | Additional content defined by implementations | |||||
|    modifierExtension | ?! | 0..* | Extension | Extensions that cannot be ignored | ||||
|    identifier | Σ | 0..* | Identifier | Business Identifiers that are specific to a role/location | ||||
|    active | Σ | 0..1 | boolean | Whether this practitioner role record is in active use | ||||
|    period | Σ | 0..1 | Period | The period during which the practitioner is authorized to perform in these role(s) | ||||
|    practitioner | SΣ | 0..1 | Reference(FI Base Practitioner) | Practitioner that is able to provide the defined services for the organization | ||||
|    organization | Σ | 0..1 | Reference(FI Base Organization) | Organization where the roles are available | ||||
|    code | Σ | 0..* | CodeableConcept | Roles which this practitioner may perform Binding: PractitionerRole (example): The role a person plays representing an organization. | ||||
|    specialty | Σ | 0..* | CodeableConcept | Specific specialty of the practitioner Binding: PracticeSettingCodeValueSet (preferred): Specific specialty associated with the agency. | ||||
|    location | Σ | 0..* | Reference(FI Base Location) | The location(s) at which this practitioner provides care | ||||
|    healthcareService | 0..* | Reference(FI Base HealthcareService) | The list of healthcare services that this worker provides for this role's Organization/Location(s) | |||||
|    telecom | Σ | 0..* | ContactPoint | Contact details that are specific to the role/location/service | ||||
|    availableTime | 0..* | BackboneElement | Times the Service Site is available | |||||
|     id | 0..1 | string | Unique id for inter-element referencing | |||||
|     extension | 0..* | Extension | Additional content defined by implementations | |||||
|     modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
|     daysOfWeek | 0..* | code | mon | tue | wed | thu | fri | sat | sun Binding: DaysOfWeek (required): The days of the week. | |||||
|     allDay | 0..1 | boolean | Always available? e.g. 24 hour service | |||||
|     availableStartTime | 0..1 | time | Opening time of day (ignored if allDay = true) | |||||
|     availableEndTime | 0..1 | time | Closing time of day (ignored if allDay = true) | |||||
|    notAvailable | 0..* | BackboneElement | Not available during this time due to provided reason | |||||
|     id | 0..1 | string | Unique id for inter-element referencing | |||||
|     extension | 0..* | Extension | Additional content defined by implementations | |||||
|     modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
|     description | 1..1 | string | Reason presented to the user explaining why time not available | |||||
|     during | 0..1 | Period | Service not available from this date | |||||
|    availabilityExceptions | 0..1 | string | Description of availability exceptions | |||||
|    endpoint | 0..* | Reference(Endpoint) | Technical endpoints providing access to services operated for the practitioner with this role | |||||
|  Documentation for this format | ||||||||
| Path | Conformance | ValueSet | URI | |||
| PractitionerRole.language | preferred | CommonLanguages http://hl7.org/fhir/ValueSet/languagesFrom the FHIR Standard 
 | ||||
| PractitionerRole.code | example | PractitionerRole http://hl7.org/fhir/ValueSet/practitioner-roleFrom the FHIR Standard | ||||
| PractitionerRole.specialty | preferred | PracticeSettingCodeValueSet http://hl7.org/fhir/ValueSet/c80-practice-codesFrom the FHIR Standard | ||||
| PractitionerRole.availableTime.daysOfWeek | required | DaysOfWeek http://hl7.org/fhir/ValueSet/days-of-week|4.0.1From the FHIR Standard | 
| Id | Grade | Path(s) | Details | Requirements | 
| dom-2 | error | PractitionerRole | If the resource is contained in another resource, it SHALL NOT contain nested Resources : contained.contained.empty() | |
| dom-3 | error | PractitionerRole | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource : contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty() | |
| dom-4 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated : contained.meta.versionId.empty() and contained.meta.lastUpdated.empty() | |
| dom-5 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a security label : contained.meta.security.empty() | |
| dom-6 | best practice | PractitionerRole | A resource should have narrative for robust management : text.`div`.exists() | |
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children : hasValue() or (children().count() > id.count()) | |
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both : extension.exists() != value.exists() | 
This structure is derived from FiBasePractitionerRole
Key Elements View
| Name | Flags | Card. | Type | Description & Constraints    Filter:   | 
|---|---|---|---|---|
|   PractitionerRole | 0..* | FiBasePractitionerRole | Roles/organizations the practitioner is associated with This profile also imposes the profile IPA-PractitionerRole (1.1.0) dom-2: If the resource is contained in another resource, it SHALL NOT contain nested Resources dom-3: If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource dom-4: If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated dom-5: If a resource is contained in another resource, it SHALL NOT have a security label dom-6: A resource should have narrative for robust management | |
|    implicitRules | ?!Σ | 0..1 | uri | A set of rules under which this content was created ele-1: All FHIR elements must have a @value or children | 
|    modifierExtension | ?! | 0..* | Extension | Extensions that cannot be ignored ele-1: All FHIR elements must have a @value or children ext-1: Must have either extensions or value[x], not both | 
|    practitioner | SΣ | 0..1 | Reference(FI Base Practitioner) | Practitioner that is able to provide the defined services for the organization ele-1: All FHIR elements must have a @value or children | 
|  Documentation for this format | ||||
| Id | Grade | Path(s) | Details | Requirements | 
| dom-2 | error | PractitionerRole | If the resource is contained in another resource, it SHALL NOT contain nested Resources : contained.contained.empty() | |
| dom-3 | error | PractitionerRole | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource : contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty() | |
| dom-4 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated : contained.meta.versionId.empty() and contained.meta.lastUpdated.empty() | |
| dom-5 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a security label : contained.meta.security.empty() | |
| dom-6 | best practice | PractitionerRole | A resource should have narrative for robust management : text.`div`.exists() | |
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children : hasValue() or (children().count() > id.count()) | |
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both : extension.exists() != value.exists() | 
Differential View
This structure is derived from FiBasePractitionerRole
| Name | Flags | Card. | Type | Description & Constraints    Filter:   | 
|---|---|---|---|---|
|   PractitionerRole | 0..* | FiBasePractitionerRole | Roles/organizations the practitioner is associated with This profile also imposes the profile IPA-PractitionerRole (1.1.0) | |
|  Documentation for this format | ||||
Snapshot View
| Name | Flags | Card. | Type | Description & Constraints    Filter:   | ||||
|---|---|---|---|---|---|---|---|---|
|   PractitionerRole | 0..* | FiBasePractitionerRole | Roles/organizations the practitioner is associated with This profile also imposes the profile IPA-PractitionerRole (1.1.0) | |||||
|    id | Σ | 0..1 | id | Logical id of this artifact | ||||
|    meta | Σ | 0..1 | Meta | Metadata about the resource | ||||
|    implicitRules | ?!Σ | 0..1 | uri | A set of rules under which this content was created | ||||
|    language | 0..1 | code | Language of the resource content Binding: CommonLanguages (preferred): A human language. 
 | |||||
|    text | 0..1 | Narrative | Text summary of the resource, for human interpretation | |||||
|    contained | 0..* | Resource | Contained, inline Resources | |||||
|    extension | 0..* | Extension | Additional content defined by implementations | |||||
|    modifierExtension | ?! | 0..* | Extension | Extensions that cannot be ignored | ||||
|    identifier | Σ | 0..* | Identifier | Business Identifiers that are specific to a role/location | ||||
|    active | Σ | 0..1 | boolean | Whether this practitioner role record is in active use | ||||
|    period | Σ | 0..1 | Period | The period during which the practitioner is authorized to perform in these role(s) | ||||
|    practitioner | SΣ | 0..1 | Reference(FI Base Practitioner) | Practitioner that is able to provide the defined services for the organization | ||||
|    organization | Σ | 0..1 | Reference(FI Base Organization) | Organization where the roles are available | ||||
|    code | Σ | 0..* | CodeableConcept | Roles which this practitioner may perform Binding: PractitionerRole (example): The role a person plays representing an organization. | ||||
|    specialty | Σ | 0..* | CodeableConcept | Specific specialty of the practitioner Binding: PracticeSettingCodeValueSet (preferred): Specific specialty associated with the agency. | ||||
|    location | Σ | 0..* | Reference(FI Base Location) | The location(s) at which this practitioner provides care | ||||
|    healthcareService | 0..* | Reference(FI Base HealthcareService) | The list of healthcare services that this worker provides for this role's Organization/Location(s) | |||||
|    telecom | Σ | 0..* | ContactPoint | Contact details that are specific to the role/location/service | ||||
|    availableTime | 0..* | BackboneElement | Times the Service Site is available | |||||
|     id | 0..1 | string | Unique id for inter-element referencing | |||||
|     extension | 0..* | Extension | Additional content defined by implementations | |||||
|     modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
|     daysOfWeek | 0..* | code | mon | tue | wed | thu | fri | sat | sun Binding: DaysOfWeek (required): The days of the week. | |||||
|     allDay | 0..1 | boolean | Always available? e.g. 24 hour service | |||||
|     availableStartTime | 0..1 | time | Opening time of day (ignored if allDay = true) | |||||
|     availableEndTime | 0..1 | time | Closing time of day (ignored if allDay = true) | |||||
|    notAvailable | 0..* | BackboneElement | Not available during this time due to provided reason | |||||
|     id | 0..1 | string | Unique id for inter-element referencing | |||||
|     extension | 0..* | Extension | Additional content defined by implementations | |||||
|     modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
|     description | 1..1 | string | Reason presented to the user explaining why time not available | |||||
|     during | 0..1 | Period | Service not available from this date | |||||
|    availabilityExceptions | 0..1 | string | Description of availability exceptions | |||||
|    endpoint | 0..* | Reference(Endpoint) | Technical endpoints providing access to services operated for the practitioner with this role | |||||
|  Documentation for this format | ||||||||
| Path | Conformance | ValueSet | URI | |||
| PractitionerRole.language | preferred | CommonLanguages http://hl7.org/fhir/ValueSet/languagesFrom the FHIR Standard 
 | ||||
| PractitionerRole.code | example | PractitionerRole http://hl7.org/fhir/ValueSet/practitioner-roleFrom the FHIR Standard | ||||
| PractitionerRole.specialty | preferred | PracticeSettingCodeValueSet http://hl7.org/fhir/ValueSet/c80-practice-codesFrom the FHIR Standard | ||||
| PractitionerRole.availableTime.daysOfWeek | required | DaysOfWeek http://hl7.org/fhir/ValueSet/days-of-week|4.0.1From the FHIR Standard | 
| Id | Grade | Path(s) | Details | Requirements | 
| dom-2 | error | PractitionerRole | If the resource is contained in another resource, it SHALL NOT contain nested Resources : contained.contained.empty() | |
| dom-3 | error | PractitionerRole | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource : contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty() | |
| dom-4 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated : contained.meta.versionId.empty() and contained.meta.lastUpdated.empty() | |
| dom-5 | error | PractitionerRole | If a resource is contained in another resource, it SHALL NOT have a security label : contained.meta.security.empty() | |
| dom-6 | best practice | PractitionerRole | A resource should have narrative for robust management : text.`div`.exists() | |
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children : hasValue() or (children().count() > id.count()) | |
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both : extension.exists() != value.exists() | 
This structure is derived from FiBasePractitionerRole
Other representations of profile: CSV, Excel, Schematron