Description
I have a situation which I don't fully understand with validation.
Example : https://simplifier.net/erezept-workflow/fsh-generated-resources-Parameters-ExampleCloseInputParametersRezeptur/~overview
Base profile: https://simplifier.net/erezept-workflow/gem_erp_pr_par_closeoperation_input
The legacy validator returns this:
Invariant : Instance failed constraint ref-1 "SHALL have a contained resource if a local reference is provided"
Rule: reference.exists() implies (reference.startsWith('#').not() or (reference.substring(1).trace('url') in %rootResource.contained.id.trace('ids')) or (reference='#' and %rootResource!=%resource))
Parameters.parameter[0].part[1].resource[0].ingredient[0].item[0]
The new validator returns this similar error, but with different explanation:
[ERROR] Instance failed constraint ref-1 "SHALL have a contained resource if a local reference is provided" (at Parameters.parameter[0].part[0].resource[0].performer[0].actor[0], element Parameters(https://gematik.de/fhir/erp/StructureDefinition/GEM_ERP_PR_PAR_CloseOperation_Input).parameter.part.resource->MedicationDispense.performer.actor)
ref-1 (https://hl7.org/fhir/references.html#Reference) states:
reference.exists() implies (reference.startsWith('#').not() or (reference.substring(1).trace('url') in %rootResource.contained.id.trace('ids')) or (reference='#' and %rootResource!=%resource))
Does calling %rootResource cause our Validator to jump to the Parameters Resource, and should it not go towards the Medication Resource?
Is this the part that is causing the issue?
reference.substring(1).trace('url') in %rootResource.contained.id.trace('ids')
What it does is it checks whether the ID of the referenced contained resource exists within the parent resource's contained resource IDs.
The Java Validator does not throw an error here.
Ghost-writer of @MatthijsvdWielen