CH EPREG (R4)
1.0.0-ci-build - ci-build Switzerland flag

CH EPREG (R4), published by HL7 Switzerland. This guide is not an authorized publication; it is the continuous build for version 1.0.0-ci-build built by the FHIR (HL7® FHIR® Standard) CI Build. This version is based on the current content of https://github.com/hl7ch/ch-epreg/ and changes regularly. See the Directory of published versions

Resource Profile: CH EPREG PractitionerRole: Treating Healthcare Provider

Official URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-practitionerrole-thcp Version: 1.0.0-ci-build
Active as of 2025-11-03 Computable Name: ChEpregPractitionerRoleTHCP

Copyright/Legal: CC0-1.0

This profile constrains the PractitionerRole resource to represent the treating healthcare provider.

Usages:

You can also check for usages in the FHIR IG Statistics

Formal Views of Profile Content

Description of Profiles, Differentials, Snapshots and how the different presentations work.

NameFlagsCard.TypeDescription & Constraints    Filter: Filtersdoco
.. PractitionerRole C 0..* CHCorePractitionerRole CH EPREG PractitionerRole: Treating Healthcare Provider
Constraints: epreg-pract-org, epreg-code-specialty
... implicitRules ?!Σ 0..1 uri A set of rules under which this content was created
... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
.... extension:note 0..1 string CH EPREG Extension: Note
URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-ext-note
... modifierExtension ?! 0..* Extension Extensions that cannot be ignored
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
... organization SΣ 0..1 Reference(CH EPREG Organization: Treating Healthcare Provider) Organization where the roles are available
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
... code SΣ 0..* CodeableConcept Roles which this practitioner may perform
Binding: HCProfessional.hcProfession (preferred): See also Mapping Healthcare Provider.
... specialty SΣ 0..* CodeableConcept Specific specialty of the practitioner
Binding: HCProfessional.hcSpecialisation (preferred): See also Mapping Healthcare Provider.

doco Documentation for this format

Terminology Bindings

Path Status Usage ValueSet Version Source
PractitionerRole.code Base preferred HCProfessional.hcProfession 📦3.2.0 CH Term v3.2
PractitionerRole.specialty Base preferred HCProfessional.hcSpecialisation 📦3.2.0 CH Term v3.2

Constraints

Id Grade Path(s) Description Expression
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())
epreg-code-specialty error PractitionerRole At least one of code or specialty must be provided. code.exists() or specialty.exists()
epreg-pract-org error PractitionerRole At least one of practitioner or organization must be provided. practitioner.exists() or organization.exists()
ext-1 error **ALL** extensions Must have either extensions or value[x], not both extension.exists() != value.exists()

This structure is derived from CHCorePractitionerRole

NameFlagsCard.TypeDescription & Constraints    Filter: Filtersdoco
.. PractitionerRole C 0..* CHCorePractitionerRole CH EPREG PractitionerRole: Treating Healthcare Provider
Constraints: epreg-pract-org, epreg-code-specialty
... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
.... extension:note 0..1 string CH EPREG Extension: Note
URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-ext-note
... practitioner S 0..1 Reference(CH EPREG Practitioner: Treating Healthcare Provider) Practitioner that is able to provide the defined services for the organization
.... reference 1..1 string Literal reference, Relative, internal or absolute URL
... organization S 0..1 Reference(CH EPREG Organization: Treating Healthcare Provider) Organization where the roles are available
.... reference 1..1 string Literal reference, Relative, internal or absolute URL
... specialty S 0..* CodeableConcept Specific specialty of the practitioner
Binding: HCProfessional.hcSpecialisation (preferred): See also Mapping Healthcare Provider.

doco Documentation for this format

Terminology Bindings (Differential)

Path Status Usage ValueSet Version Source
PractitionerRole.code Base preferred HCProfessional.hcProfession 📦3.2.0 CH Term v3.2
PractitionerRole.specialty Base preferred HCProfessional.hcSpecialisation 📦3.2.0 CH Term v3.2

Constraints

Id Grade Path(s) Description Expression
epreg-code-specialty error PractitionerRole At least one of code or specialty must be provided. code.exists() or specialty.exists()
epreg-pract-org error PractitionerRole At least one of practitioner or organization must be provided. practitioner.exists() or organization.exists()
NameFlagsCard.TypeDescription & Constraints    Filter: Filtersdoco
.. PractitionerRole C 0..* CHCorePractitionerRole CH EPREG PractitionerRole: Treating Healthcare Provider
Constraints: epreg-pract-org, epreg-code-specialty
... 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
... text 0..1 Narrative Text summary of the resource, for human interpretation
This profile does not constrain the narrative in regard to content, language, or traceability to data elements
... contained 0..* Resource Contained, inline Resources
... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
.... extension:note 0..1 string CH EPREG Extension: Note
URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-ext-note
... 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(CH EPREG Practitioner: Treating Healthcare Provider) Practitioner that is able to provide the defined services for the organization
.... id 0..1 string Unique id for inter-element referencing
.... extension 0..* Extension Additional content defined by implementations
Slice: Unordered, Open by value:url
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
.... type Σ 0..1 uri Type the reference refers to (e.g. "Patient")
Binding: ResourceType (extensible): Aa resource (or, for logical models, the URI of the logical model).
.... identifier Σ 0..1 Identifier Logical reference, when literal reference is not known
.... display Σ 0..1 string Text alternative for the resource
... organization SΣ 0..1 Reference(CH EPREG Organization: Treating Healthcare Provider) Organization where the roles are available
.... id 0..1 string Unique id for inter-element referencing
.... extension 0..* Extension Additional content defined by implementations
Slice: Unordered, Open by value:url
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
.... type Σ 0..1 uri Type the reference refers to (e.g. "Patient")
Binding: ResourceType (extensible): Aa resource (or, for logical models, the URI of the logical model).
.... identifier Σ 0..1 Identifier Logical reference, when literal reference is not known
.... display Σ 0..1 string Text alternative for the resource
... code SΣ 0..* CodeableConcept Roles which this practitioner may perform
Binding: HCProfessional.hcProfession (preferred): See also Mapping Healthcare Provider.
... specialty SΣ 0..* CodeableConcept Specific specialty of the practitioner
Binding: HCProfessional.hcSpecialisation (preferred): See also Mapping Healthcare Provider.
... location Σ 0..* Reference(CH Core Location) The location(s) at which this practitioner provides care
... healthcareService 0..* Reference(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

doco Documentation for this format

Terminology Bindings

Path Status Usage ValueSet Version Source
PractitionerRole.language Base preferred Common Languages 📍4.0.1 FHIR Std.
PractitionerRole.practitioner.​type Base extensible ResourceType 📍4.0.1 FHIR Std.
PractitionerRole.organization.​type Base extensible ResourceType 📍4.0.1 FHIR Std.
PractitionerRole.code Base preferred HCProfessional.hcProfession 📦3.2.0 CH Term v3.2
PractitionerRole.specialty Base preferred HCProfessional.hcSpecialisation 📦3.2.0 CH Term v3.2
PractitionerRole.availableTime.​daysOfWeek Base required DaysOfWeek 📍4.0.1 FHIR Std.

Constraints

Id Grade Path(s) Description Expression
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())
epreg-code-specialty error PractitionerRole At least one of code or specialty must be provided. code.exists() or specialty.exists()
epreg-pract-org error PractitionerRole At least one of practitioner or organization must be provided. practitioner.exists() or organization.exists()
ext-1 error **ALL** extensions Must have either extensions or value[x], not both extension.exists() != value.exists()

This structure is derived from CHCorePractitionerRole

Key Elements View

NameFlagsCard.TypeDescription & Constraints    Filter: Filtersdoco
.. PractitionerRole C 0..* CHCorePractitionerRole CH EPREG PractitionerRole: Treating Healthcare Provider
Constraints: epreg-pract-org, epreg-code-specialty
... implicitRules ?!Σ 0..1 uri A set of rules under which this content was created
... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
.... extension:note 0..1 string CH EPREG Extension: Note
URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-ext-note
... modifierExtension ?! 0..* Extension Extensions that cannot be ignored
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
... organization SΣ 0..1 Reference(CH EPREG Organization: Treating Healthcare Provider) Organization where the roles are available
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
... code SΣ 0..* CodeableConcept Roles which this practitioner may perform
Binding: HCProfessional.hcProfession (preferred): See also Mapping Healthcare Provider.
... specialty SΣ 0..* CodeableConcept Specific specialty of the practitioner
Binding: HCProfessional.hcSpecialisation (preferred): See also Mapping Healthcare Provider.

doco Documentation for this format

Terminology Bindings

Path Status Usage ValueSet Version Source
PractitionerRole.code Base preferred HCProfessional.hcProfession 📦3.2.0 CH Term v3.2
PractitionerRole.specialty Base preferred HCProfessional.hcSpecialisation 📦3.2.0 CH Term v3.2

Constraints

Id Grade Path(s) Description Expression
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())
epreg-code-specialty error PractitionerRole At least one of code or specialty must be provided. code.exists() or specialty.exists()
epreg-pract-org error PractitionerRole At least one of practitioner or organization must be provided. practitioner.exists() or organization.exists()
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 CHCorePractitionerRole

NameFlagsCard.TypeDescription & Constraints    Filter: Filtersdoco
.. PractitionerRole C 0..* CHCorePractitionerRole CH EPREG PractitionerRole: Treating Healthcare Provider
Constraints: epreg-pract-org, epreg-code-specialty
... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
.... extension:note 0..1 string CH EPREG Extension: Note
URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-ext-note
... practitioner S 0..1 Reference(CH EPREG Practitioner: Treating Healthcare Provider) Practitioner that is able to provide the defined services for the organization
.... reference 1..1 string Literal reference, Relative, internal or absolute URL
... organization S 0..1 Reference(CH EPREG Organization: Treating Healthcare Provider) Organization where the roles are available
.... reference 1..1 string Literal reference, Relative, internal or absolute URL
... specialty S 0..* CodeableConcept Specific specialty of the practitioner
Binding: HCProfessional.hcSpecialisation (preferred): See also Mapping Healthcare Provider.

doco Documentation for this format

Terminology Bindings (Differential)

Path Status Usage ValueSet Version Source
PractitionerRole.code Base preferred HCProfessional.hcProfession 📦3.2.0 CH Term v3.2
PractitionerRole.specialty Base preferred HCProfessional.hcSpecialisation 📦3.2.0 CH Term v3.2

Constraints

Id Grade Path(s) Description Expression
epreg-code-specialty error PractitionerRole At least one of code or specialty must be provided. code.exists() or specialty.exists()
epreg-pract-org error PractitionerRole At least one of practitioner or organization must be provided. practitioner.exists() or organization.exists()

Snapshot View

NameFlagsCard.TypeDescription & Constraints    Filter: Filtersdoco
.. PractitionerRole C 0..* CHCorePractitionerRole CH EPREG PractitionerRole: Treating Healthcare Provider
Constraints: epreg-pract-org, epreg-code-specialty
... 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
... text 0..1 Narrative Text summary of the resource, for human interpretation
This profile does not constrain the narrative in regard to content, language, or traceability to data elements
... contained 0..* Resource Contained, inline Resources
... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
.... extension:note 0..1 string CH EPREG Extension: Note
URL: http://fhir.ch/ig/ch-epreg/StructureDefinition/ch-epreg-ext-note
... 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(CH EPREG Practitioner: Treating Healthcare Provider) Practitioner that is able to provide the defined services for the organization
.... id 0..1 string Unique id for inter-element referencing
.... extension 0..* Extension Additional content defined by implementations
Slice: Unordered, Open by value:url
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
.... type Σ 0..1 uri Type the reference refers to (e.g. "Patient")
Binding: ResourceType (extensible): Aa resource (or, for logical models, the URI of the logical model).
.... identifier Σ 0..1 Identifier Logical reference, when literal reference is not known
.... display Σ 0..1 string Text alternative for the resource
... organization SΣ 0..1 Reference(CH EPREG Organization: Treating Healthcare Provider) Organization where the roles are available
.... id 0..1 string Unique id for inter-element referencing
.... extension 0..* Extension Additional content defined by implementations
Slice: Unordered, Open by value:url
.... reference ΣC 1..1 string Literal reference, Relative, internal or absolute URL
.... type Σ 0..1 uri Type the reference refers to (e.g. "Patient")
Binding: ResourceType (extensible): Aa resource (or, for logical models, the URI of the logical model).
.... identifier Σ 0..1 Identifier Logical reference, when literal reference is not known
.... display Σ 0..1 string Text alternative for the resource
... code SΣ 0..* CodeableConcept Roles which this practitioner may perform
Binding: HCProfessional.hcProfession (preferred): See also Mapping Healthcare Provider.
... specialty SΣ 0..* CodeableConcept Specific specialty of the practitioner
Binding: HCProfessional.hcSpecialisation (preferred): See also Mapping Healthcare Provider.
... location Σ 0..* Reference(CH Core Location) The location(s) at which this practitioner provides care
... healthcareService 0..* Reference(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

doco Documentation for this format

Terminology Bindings

Path Status Usage ValueSet Version Source
PractitionerRole.language Base preferred Common Languages 📍4.0.1 FHIR Std.
PractitionerRole.practitioner.​type Base extensible ResourceType 📍4.0.1 FHIR Std.
PractitionerRole.organization.​type Base extensible ResourceType 📍4.0.1 FHIR Std.
PractitionerRole.code Base preferred HCProfessional.hcProfession 📦3.2.0 CH Term v3.2
PractitionerRole.specialty Base preferred HCProfessional.hcSpecialisation 📦3.2.0 CH Term v3.2
PractitionerRole.availableTime.​daysOfWeek Base required DaysOfWeek 📍4.0.1 FHIR Std.

Constraints

Id Grade Path(s) Description Expression
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())
epreg-code-specialty error PractitionerRole At least one of code or specialty must be provided. code.exists() or specialty.exists()
epreg-pract-org error PractitionerRole At least one of practitioner or organization must be provided. practitioner.exists() or organization.exists()
ext-1 error **ALL** extensions Must have either extensions or value[x], not both extension.exists() != value.exists()

This structure is derived from CHCorePractitionerRole

 

Other representations of profile: CSV, Excel, Schematron