Advance Care Planning (PZP)
0.1.3-beta3 - consultation

Advance Care Planning (PZP) - Local Development build (v0.1.3-beta3) built by the FHIR (HL7® FHIR® Standard) Build Tools. See the Directory of published versions

Resource Profile: HealthProfessional PractitionerRole

Official URL: https://fhir.iknl.nl/fhir/StructureDefinition/ACP-HealthProfessional-PractitionerRole Version: 0.1.3-beta3
Draft as of 2025-08-28 Computable Name: ACPHealthProfessionalPractitionerRole

Copyright/Legal: Copyright and related rights waived via CC0, https://creativecommons.org/publicdomain/zero/1.0/. This does not apply to information from third parties, for example a medical terminology system. The implementer alone is responsible for identifying and obtaining any necessary licenses or authorizations to utilize third party IP in connection with the specification or otherwise.

The specialty of a person who is authorized to perform actions in the field of individual healthcare. Based on nl-core-HealthProfessionalPractitionerRole and HCIM HealthProfessional.

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.

NaamMarkeringenKard.TypeOmschrijving & constraints    Filter: Filtersdoco
.. PractitionerRole 0..* NlcoreHealthProfessionalPractitionerRole HealthProfessional
... implicitRules ?!Σ 0..1 uri A set of rules under which this content was created
... modifierExtension ?! 0..* Extension Extensions that cannot be ignored
Constraints: ext-1
... practitioner Σ 0..1 Reference(HealthProfessional Practitioner(0.1.3-beta3)) Practitioner that is able to provide the defined services for the organization
.... specialty:specialty Σ 0..1 CodeableConcept Specialty
Binding: SpecialismeCodelijsten (2020-09-01T00:00:00) (required): Specific specialty associated with the agency.
... Slices voor telecom Σ 0..* ContactPoint ContactInformation
Slice: Zonder volgorde, Open op profile:$this
.... telecom:telephoneNumbers ΣCN 0..* NlcoreContactInformationTelephoneNumbers TelephoneNumbers
Constraints: cpt-2
.... telecom:emailAddresses ΣCN 0..* NlcoreContactInformationEmailAddresses EmailAddresses
Constraints: cpt-2

doco Documentatie voor dit formaat

Terminologiebindings

PadConformanceValueSetUri
PractitionerRole.specialtypreferredPracticeSettingCodeValueSet
http://hl7.org/fhir/ValueSet/c80-practice-codes|4.0.1
From the FHIR Standard
PractitionerRole.specialty:specialtyrequiredSpecialismeCodelijsten
http://decor.nictiz.nl/fhir/ValueSet/2.16.840.1.113883.2.4.3.11.60.121.11.22--20200901000000|2020-09-01T00:00:00

Constrains

IdGradePad(en)DetailsRequirements
cpt-2errorPractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddressesA system is required if a value is provided.
: value.empty() or system.exists()
dom-2errorPractitionerRoleIf the resource is contained in another resource, it SHALL NOT contain nested Resources
: contained.contained.empty()
dom-3errorPractitionerRoleIf 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-4errorPractitionerRoleIf 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-5errorPractitionerRoleIf a resource is contained in another resource, it SHALL NOT have a security label
: contained.meta.security.empty()
dom-6best practicePractitionerRoleA resource should have narrative for robust management
: text.`div`.exists()
ele-1errorPractitionerRole.implicitRules, PractitionerRole.modifierExtension, PractitionerRole.practitioner, PractitionerRole.specialty, PractitionerRole.specialty:specialty, PractitionerRole.telecom, PractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddressesAll FHIR elements must have a @value or children
: hasValue() or (children().count() > id.count())
ext-1errorPractitionerRole.modifierExtensionMust have either extensions or value[x], not both
: extension.exists() != value.exists()

This structure is derived from NlcoreHealthProfessionalPractitionerRole

NaamMarkeringenKard.TypeOmschrijving & constraints    Filter: Filtersdoco
.. PractitionerRole 0..* NlcoreHealthProfessionalPractitionerRole HealthProfessional
... practitioner 0..1 Reference(HealthProfessional Practitioner(0.1.3-beta3)) Practitioner that is able to provide the defined services for the organization
... Slices voor specialty Content/regels voor alle slices
.... specialty:specialty 0..1 CodeableConcept Specialty

doco Documentatie voor dit formaat
NaamMarkeringenKard.TypeOmschrijving & constraints    Filter: Filtersdoco
.. PractitionerRole 0..* NlcoreHealthProfessionalPractitionerRole HealthProfessional
... 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
... extension 0..* Extension Additional content defined by implementations
Constraints: ext-1
... modifierExtension ?! 0..* Extension Extensions that cannot be ignored
Constraints: ext-1
... 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 Σ 0..1 Reference(HealthProfessional Practitioner(0.1.3-beta3)) Practitioner that is able to provide the defined services for the organization
... organization Σ 0..1 Reference(Organization | nl core HealthcareProvider Organization) HealthcareProvider
... code Σ 0..* CodeableConcept Roles which this practitioner may perform
Binding: PractitionerRole (example): The role a person plays representing an organization.
... Slices voor specialty Σ 0..* CodeableConcept Specific specialty of the practitioner
Slice: Zonder volgorde, Open op value:$this
Binding: PracticeSettingCodeValueSet (preferred): Specific specialty associated with the agency.
.... specialty:specialty Σ 0..1 CodeableConcept Specialty
Binding: SpecialismeCodelijsten (2020-09-01T00:00:00) (required): Specific specialty associated with the agency.
... location Σ 0..* Reference(Location | nl core HealthcareProvider) 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)
... Slices voor telecom Σ 0..* ContactPoint ContactInformation
Slice: Zonder volgorde, Open op profile:$this
.... telecom:telephoneNumbers ΣCN 0..* NlcoreContactInformationTelephoneNumbers TelephoneNumbers
Constraints: cpt-2
.... telecom:emailAddresses ΣCN 0..* NlcoreContactInformationEmailAddresses EmailAddresses
Constraints: cpt-2
... 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
Constraints: ext-1
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
Constraints: ext-1
.... 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
Constraints: ext-1
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
Constraints: ext-1
.... 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 Documentatie voor dit formaat

Terminologiebindings

PadConformanceValueSetUri
PractitionerRole.languagepreferredCommonLanguages
http://hl7.org/fhir/ValueSet/languages|4.0.1
From the FHIR Standard
Additionele bindings Doel
AllLanguages Max binding
PractitionerRole.codeexamplePractitionerRole
http://hl7.org/fhir/ValueSet/practitioner-role|4.0.1
From the FHIR Standard
PractitionerRole.specialtypreferredPracticeSettingCodeValueSet
http://hl7.org/fhir/ValueSet/c80-practice-codes|4.0.1
From the FHIR Standard
PractitionerRole.specialty:specialtyrequiredSpecialismeCodelijsten
http://decor.nictiz.nl/fhir/ValueSet/2.16.840.1.113883.2.4.3.11.60.121.11.22--20200901000000|2020-09-01T00:00:00
PractitionerRole.availableTime.daysOfWeekrequiredDaysOfWeek
http://hl7.org/fhir/ValueSet/days-of-week|4.0.1
From the FHIR Standard

Constrains

IdGradePad(en)DetailsRequirements
cpt-2errorPractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddressesA system is required if a value is provided.
: value.empty() or system.exists()
dom-2errorPractitionerRoleIf the resource is contained in another resource, it SHALL NOT contain nested Resources
: contained.contained.empty()
dom-3errorPractitionerRoleIf 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-4errorPractitionerRoleIf 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-5errorPractitionerRoleIf a resource is contained in another resource, it SHALL NOT have a security label
: contained.meta.security.empty()
dom-6best practicePractitionerRoleA resource should have narrative for robust management
: text.`div`.exists()
ele-1errorPractitionerRole.meta, PractitionerRole.implicitRules, PractitionerRole.language, PractitionerRole.text, PractitionerRole.extension, PractitionerRole.modifierExtension, PractitionerRole.identifier, PractitionerRole.active, PractitionerRole.period, PractitionerRole.practitioner, PractitionerRole.organization, PractitionerRole.code, PractitionerRole.specialty, PractitionerRole.specialty:specialty, PractitionerRole.location, PractitionerRole.healthcareService, PractitionerRole.telecom, PractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddresses, PractitionerRole.availableTime, PractitionerRole.availableTime.extension, PractitionerRole.availableTime.modifierExtension, PractitionerRole.availableTime.daysOfWeek, PractitionerRole.availableTime.allDay, PractitionerRole.availableTime.availableStartTime, PractitionerRole.availableTime.availableEndTime, PractitionerRole.notAvailable, PractitionerRole.notAvailable.extension, PractitionerRole.notAvailable.modifierExtension, PractitionerRole.notAvailable.description, PractitionerRole.notAvailable.during, PractitionerRole.availabilityExceptions, PractitionerRole.endpointAll FHIR elements must have a @value or children
: hasValue() or (children().count() > id.count())
ext-1errorPractitionerRole.extension, PractitionerRole.modifierExtension, PractitionerRole.availableTime.extension, PractitionerRole.availableTime.modifierExtension, PractitionerRole.notAvailable.extension, PractitionerRole.notAvailable.modifierExtensionMust have either extensions or value[x], not both
: extension.exists() != value.exists()

Key Elements View

NaamMarkeringenKard.TypeOmschrijving & constraints    Filter: Filtersdoco
.. PractitionerRole 0..* NlcoreHealthProfessionalPractitionerRole HealthProfessional
... implicitRules ?!Σ 0..1 uri A set of rules under which this content was created
... modifierExtension ?! 0..* Extension Extensions that cannot be ignored
Constraints: ext-1
... practitioner Σ 0..1 Reference(HealthProfessional Practitioner(0.1.3-beta3)) Practitioner that is able to provide the defined services for the organization
.... specialty:specialty Σ 0..1 CodeableConcept Specialty
Binding: SpecialismeCodelijsten (2020-09-01T00:00:00) (required): Specific specialty associated with the agency.
... Slices voor telecom Σ 0..* ContactPoint ContactInformation
Slice: Zonder volgorde, Open op profile:$this
.... telecom:telephoneNumbers ΣCN 0..* NlcoreContactInformationTelephoneNumbers TelephoneNumbers
Constraints: cpt-2
.... telecom:emailAddresses ΣCN 0..* NlcoreContactInformationEmailAddresses EmailAddresses
Constraints: cpt-2

doco Documentatie voor dit formaat

Terminologiebindings

PadConformanceValueSetUri
PractitionerRole.specialtypreferredPracticeSettingCodeValueSet
http://hl7.org/fhir/ValueSet/c80-practice-codes|4.0.1
From the FHIR Standard
PractitionerRole.specialty:specialtyrequiredSpecialismeCodelijsten
http://decor.nictiz.nl/fhir/ValueSet/2.16.840.1.113883.2.4.3.11.60.121.11.22--20200901000000|2020-09-01T00:00:00

Constrains

IdGradePad(en)DetailsRequirements
cpt-2errorPractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddressesA system is required if a value is provided.
: value.empty() or system.exists()
dom-2errorPractitionerRoleIf the resource is contained in another resource, it SHALL NOT contain nested Resources
: contained.contained.empty()
dom-3errorPractitionerRoleIf 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-4errorPractitionerRoleIf 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-5errorPractitionerRoleIf a resource is contained in another resource, it SHALL NOT have a security label
: contained.meta.security.empty()
dom-6best practicePractitionerRoleA resource should have narrative for robust management
: text.`div`.exists()
ele-1errorPractitionerRole.implicitRules, PractitionerRole.modifierExtension, PractitionerRole.practitioner, PractitionerRole.specialty, PractitionerRole.specialty:specialty, PractitionerRole.telecom, PractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddressesAll FHIR elements must have a @value or children
: hasValue() or (children().count() > id.count())
ext-1errorPractitionerRole.modifierExtensionMust have either extensions or value[x], not both
: extension.exists() != value.exists()

Differential View

This structure is derived from NlcoreHealthProfessionalPractitionerRole

NaamMarkeringenKard.TypeOmschrijving & constraints    Filter: Filtersdoco
.. PractitionerRole 0..* NlcoreHealthProfessionalPractitionerRole HealthProfessional
... practitioner 0..1 Reference(HealthProfessional Practitioner(0.1.3-beta3)) Practitioner that is able to provide the defined services for the organization
... Slices voor specialty Content/regels voor alle slices
.... specialty:specialty 0..1 CodeableConcept Specialty

doco Documentatie voor dit formaat

Snapshot View

NaamMarkeringenKard.TypeOmschrijving & constraints    Filter: Filtersdoco
.. PractitionerRole 0..* NlcoreHealthProfessionalPractitionerRole HealthProfessional
... 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
... extension 0..* Extension Additional content defined by implementations
Constraints: ext-1
... modifierExtension ?! 0..* Extension Extensions that cannot be ignored
Constraints: ext-1
... 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 Σ 0..1 Reference(HealthProfessional Practitioner(0.1.3-beta3)) Practitioner that is able to provide the defined services for the organization
... organization Σ 0..1 Reference(Organization | nl core HealthcareProvider Organization) HealthcareProvider
... code Σ 0..* CodeableConcept Roles which this practitioner may perform
Binding: PractitionerRole (example): The role a person plays representing an organization.
... Slices voor specialty Σ 0..* CodeableConcept Specific specialty of the practitioner
Slice: Zonder volgorde, Open op value:$this
Binding: PracticeSettingCodeValueSet (preferred): Specific specialty associated with the agency.
.... specialty:specialty Σ 0..1 CodeableConcept Specialty
Binding: SpecialismeCodelijsten (2020-09-01T00:00:00) (required): Specific specialty associated with the agency.
... location Σ 0..* Reference(Location | nl core HealthcareProvider) 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)
... Slices voor telecom Σ 0..* ContactPoint ContactInformation
Slice: Zonder volgorde, Open op profile:$this
.... telecom:telephoneNumbers ΣCN 0..* NlcoreContactInformationTelephoneNumbers TelephoneNumbers
Constraints: cpt-2
.... telecom:emailAddresses ΣCN 0..* NlcoreContactInformationEmailAddresses EmailAddresses
Constraints: cpt-2
... 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
Constraints: ext-1
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
Constraints: ext-1
.... 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
Constraints: ext-1
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
Constraints: ext-1
.... 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 Documentatie voor dit formaat

Terminologiebindings

PadConformanceValueSetUri
PractitionerRole.languagepreferredCommonLanguages
http://hl7.org/fhir/ValueSet/languages|4.0.1
From the FHIR Standard
Additionele bindings Doel
AllLanguages Max binding
PractitionerRole.codeexamplePractitionerRole
http://hl7.org/fhir/ValueSet/practitioner-role|4.0.1
From the FHIR Standard
PractitionerRole.specialtypreferredPracticeSettingCodeValueSet
http://hl7.org/fhir/ValueSet/c80-practice-codes|4.0.1
From the FHIR Standard
PractitionerRole.specialty:specialtyrequiredSpecialismeCodelijsten
http://decor.nictiz.nl/fhir/ValueSet/2.16.840.1.113883.2.4.3.11.60.121.11.22--20200901000000|2020-09-01T00:00:00
PractitionerRole.availableTime.daysOfWeekrequiredDaysOfWeek
http://hl7.org/fhir/ValueSet/days-of-week|4.0.1
From the FHIR Standard

Constrains

IdGradePad(en)DetailsRequirements
cpt-2errorPractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddressesA system is required if a value is provided.
: value.empty() or system.exists()
dom-2errorPractitionerRoleIf the resource is contained in another resource, it SHALL NOT contain nested Resources
: contained.contained.empty()
dom-3errorPractitionerRoleIf 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-4errorPractitionerRoleIf 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-5errorPractitionerRoleIf a resource is contained in another resource, it SHALL NOT have a security label
: contained.meta.security.empty()
dom-6best practicePractitionerRoleA resource should have narrative for robust management
: text.`div`.exists()
ele-1errorPractitionerRole.meta, PractitionerRole.implicitRules, PractitionerRole.language, PractitionerRole.text, PractitionerRole.extension, PractitionerRole.modifierExtension, PractitionerRole.identifier, PractitionerRole.active, PractitionerRole.period, PractitionerRole.practitioner, PractitionerRole.organization, PractitionerRole.code, PractitionerRole.specialty, PractitionerRole.specialty:specialty, PractitionerRole.location, PractitionerRole.healthcareService, PractitionerRole.telecom, PractitionerRole.telecom:telephoneNumbers, PractitionerRole.telecom:emailAddresses, PractitionerRole.availableTime, PractitionerRole.availableTime.extension, PractitionerRole.availableTime.modifierExtension, PractitionerRole.availableTime.daysOfWeek, PractitionerRole.availableTime.allDay, PractitionerRole.availableTime.availableStartTime, PractitionerRole.availableTime.availableEndTime, PractitionerRole.notAvailable, PractitionerRole.notAvailable.extension, PractitionerRole.notAvailable.modifierExtension, PractitionerRole.notAvailable.description, PractitionerRole.notAvailable.during, PractitionerRole.availabilityExceptions, PractitionerRole.endpointAll FHIR elements must have a @value or children
: hasValue() or (children().count() > id.count())
ext-1errorPractitionerRole.extension, PractitionerRole.modifierExtension, PractitionerRole.availableTime.extension, PractitionerRole.availableTime.modifierExtension, PractitionerRole.notAvailable.extension, PractitionerRole.notAvailable.modifierExtensionMust have either extensions or value[x], not both
: extension.exists() != value.exists()

 

Other representations of profile: CSV, Excel, Schematron