Resource Model
Issuer: openEHR Specification Program | |
---|---|
Release: BASE development |
Status: STABLE |
Revision: [latest_issue] |
Date: [latest_issue_date] |
Keywords: openehr, resources |
© 2003 - 2025 The openEHR Foundation | |
---|---|
The openEHR Foundation is an independent, non-profit foundation, facilitating the sharing of health records by consumers and clinicians via open specifications, clinical models and open platform implementations. |
|
Licence |
Creative Commons Attribution-NoDerivs 3.0 Unported. https://creativecommons.org/licenses/by-nd/3.0/ |
Support |
Issues: Problem Reports |
Acknowledgements
Contributors
This specification has benefited from formal and informal input from the openEHR and wider health informatics community. The openEHR Foundation would like to recognise the following people for their contributions.
-
Silje Ljosland Bakke, RN, National ICT health trust, Norway
-
Diego Boscá, IBIME, Technical University Valencia, VeraTech for Health, Spain
-
Sebastian Garde PhD, Ocean Health Systems, Germany
-
Grahame Grieve, Health Intersections, Australia
-
Heather Leslie MD, FRACGP, FACHI, Ocean Health Systems, Australia
-
Ian McNicoll MD, FreshEHR UK
-
Andrew Patterson PhD, LLM, Federation Health Software, Australia
Supporters
The work reported in this paper has been funded in by the following organisations:
-
University College London - Centre for Health Informatics and Multi-professional Education (CHIME);
-
Ocean Informatics.
Special thanks to David Ingram, Emeritus Professor of Health Informatics at UCL, who provided a vision and collegial working environment ever since the days of GEHR (1992).
1. Preface
1.1. Purpose
This document describes the openEHR Resource Model, a model of any 'authored resource', including identification, meta-data, annotations and translations.
The intended audience includes:
-
Standards bodies producing health informatics standards;
-
Academic groups using openEHR;
-
Solution vendors;
-
Medical informaticians and clinicians interested in health information.
1.3. Status
The content of this specification were separated out from the RM 1.0.3 Common IM specification, in order to allow re-use by any openEHR component.
This specification is in the STABLE state. The development version of this document can be found at https://specifications.openehr.org/releases/BASE/development/resource.html.
Known omissions or questions are indicated in the text with a 'to be determined' paragraph, as follows:
TBD: (example To Be Determined paragraph)
1.4. Feedback
Feedback may be provided on the technical mailing list.
Issues may be raised on the specifications Problem Report tracker.
To see changes made due to previously reported issues, see the BASE component Change Request tracker.
1.5. Conformance
Conformance of a data or software artifact to an openEHR specification is determined by a formal test of that artifact against the relevant openEHR Implementation Technology Specification(s) (ITSs), such as an IDL interface or an XML-schema. Since ITSs are formal derivations from underlying models, ITS conformance indicates model conformance.
2. Resource Package
2.1. Overview
The openEHR BASE component resource
package defines the structure and semantics of the general notion of an online resource which has been created by a human author, and consequently for which natural language is a factor. The package is illustrated below.
2.1.1. Natural Languages and Translation
Authored resources contain natural language elements, and are therefore created in some original language, recorded in the orginal_language
attribute of the AUTHORED_RESOURCE
class. Information about translations is included in the translations attribute, which allows for one or more sets of translation details to be recorded. A resource is translated by doing the following:
-
translating every language-dependent element to the new language;
-
adding a new
TRANSLATION_DETAILS
instance to translations, containing details about the translator, organisation, quality assurance and so on. -
any further translations to language-specific elements in instances of descendent type of
AUTHORED_RESOURCE
.
The languages_available function provides a complete list of languages in the resource.
2.1.2. Meta-data
What is normally considered the 'meta-data' of a resource, i.e. its author, date of creation, purpose, and other descriptive items, is described by the RESOURCE_DESCRIPTION
and RESOURCE_DESCRIPTION_ITEM
classes. The parts of this that are in natural language, and therefore may require translated versions, are represented in instances of the RESOURCE_DESCRIPTION_ITEM
class. Thus, if a RESOURCE_DESCRIPTION
has more than one RESOURCE_DESCRIPTION_ITEM
, each of these should carry exactly the same information in a different natural language.
The AUTHORED_RESOURCE
.description
attribute is optional, allowing for resources with no meta-data at all, e.g. resources in a partial state of construction. The translations attribute may still be required, since there may be other parts of the resource object (specified by a class into which AUTHORED_RESOURCE
is inherited) that are language-dependent.
2.1.3. Revision History
When the resource is considered to be in a state where changes to it should be controlled, the is_controlled
attribute is set to True, and all subsequent changes should have an audit trail recorded. Usually controlled resources would be managed in a versioned repository (e.g. implemented by a Git, Subversion or similar systems), and audit information will be stored somewhere in the repository (e.g. in version control files).
2.2. Class Descriptions
2.2.1. AUTHORED_RESOURCE Class
Class |
AUTHORED_RESOURCE (abstract) |
|
---|---|---|
Description |
Abstract idea of an online resource created by a human author. |
|
Attributes |
Signature |
Meaning |
0..1 |
uid: |
Unique identifier of the family of archetypes having the same interface identifier (same major version). |
1..1 |
original_language: |
Language in which this resource was initially authored. Although there is no language primacy of resources overall, the language of original authoring is required to ensure natural language translations can preserve quality. Language is relevant in both the description and ontology sections. |
0..1 |
description: |
Description and lifecycle information of the resource. |
0..1 |
is_controlled: |
True if this resource is under any kind of change control (even file copying), in which case revision history is created. |
0..1 |
annotations: |
Annotations on individual items within the resource, keyed by path. The inner table takes the form of a Hash table of String values keyed by String tags. |
0..1 |
translations: |
List of details for each natural translation made of this resource, keyed by language code. For each translation listed here, there must be corresponding sections in all language-dependent parts of the resource. The |
Functions |
Signature |
Meaning |
1..1 |
Total list of languages available in this resource, derived from original_language and translations. |
|
Invariants |
Original_language_valid: |
|
Current_revision_valid: |
||
Translations_valid: |
||
Description_valid: |
||
Languages_available_valid: |
2.2.2. TRANSLATION_DETAILS Class
Class |
TRANSLATION_DETAILS |
|
---|---|---|
Description |
Class providing details of a natural language translation. |
|
Attributes |
Signature |
Meaning |
1..1 |
language: |
Language of the translation, encoded following the RFC 5646 standard, using ISO 639-1 (two-character) language codes, e.g. "en". It may include a region subtag conforming to ISO 3166-1 alpha-2 (two-character country codes), e.g. "pt-br" for Brazilian Portuguese. |
1..1 |
Primary translator name and other demographic details. |
|
0..1 |
accreditation: |
Accreditation of primary translator or group, usually a national translator’s registration or association membership id. |
0..1 |
Any other meta-data. |
|
0..1 |
version_last_translated: |
Version of this resource last time it was translated into the language represented by this |
0..1 |
Additional contributors to this translation, each listed in the preferred format of the relevant organisation for the artefacts in question. A typical default is |
2.2.3. RESOURCE_DESCRIPTION Class
Class |
RESOURCE_DESCRIPTION |
|
---|---|---|
Description |
Defines the descriptive meta-data of a resource. |
|
Attributes |
Signature |
Meaning |
0..1 |
title: |
Long-form descriptive title of the resource, typically needed in templates and occasionally in specialised archetypes where the root archetype/template name is not descriptive enough to disambiguate from similar archetypes/templates. |
1..1 |
Original author of this resource, with all relevant details, including organisation. |
|
0..1 |
original_namespace: |
Namespace of original author’s organisation, in reverse internet form, if applicable. |
0..1 |
original_publisher: |
Plain text name of organisation that originally published this artefact, if any. |
0..1 |
Other contributors to the resource, each listed in "name <email>" form. |
|
1..1 |
parent_resource: |
Reference to owning resource. |
1..1 |
lifecycle_state: |
Lifecycle state of the resource, typically using macro-states such as: unmanaged, in_development, release_candidate, published, rejected, deprecated. |
0..1 |
custodian_namespace: |
Namespace in reverse internet id form, of current custodian organisation. |
0..1 |
custodian_organisation: |
Plain text name of current custodian organisation. |
0..1 |
copyright: |
Optional copyright statement for the resource as a knowledge resource. |
0..1 |
licence: |
Licence of current artefact, in format "short licence name <URL of licence>", e.g. "Apache 2.0 License http://www.apache.org/licenses/LICENSE-2.0.html" |
0..1 |
List of acknowledgements of other IP directly referenced in this archetype, typically terminology codes, ontology ids etc. Recommended keys are the widely known name or namespace for the IP source, as shown in the following example: ip_acknowledgements = < ["loinc"] = <"This content from LOINC® is copyright © 1995 Regenstrief Institute, Inc. and the LOINC Committee, and available at no cost under the license at http://loinc.org/terms-of-use"> ["snomedct"] = <"Content from SNOMED CT® is copyright © 2007 IHTSDO <ihtsdo.org>"> > |
|
0..1 |
List of references of material on which this artefact is based, as a keyed list of strings. The keys should be in a standard citation format. |
|
0..1 |
resource_package_uri: |
URI of package to which this resource belongs. |
0..1 |
Details related to conversion process that generated this model from an original, if relevant, as a list of name/value pairs. Typical example with recommended tags: conversion_details = < ["source_model"] = <"CEM model xyz <http://location.in.clinicalelementmodels.com>"> ["tool"] = <"cem2adl v6.3.0"> ["time"] = <"2014-11-03T09:05:00"> > |
|
0..1 |
details: |
Details of all parts of resource description that are natural language-dependent, keyed by language code. |
0..1 |
Additional non-language-sensitive resource meta-data, as a list of name/value pairs. |
2.2.4. RESOURCE_DESCRIPTION_ITEM Class
Class |
RESOURCE_DESCRIPTION_ITEM |
|
---|---|---|
Description |
Language-specific detail of resource description. When a resource is translated for use in another language environment, each |
|
Attributes |
Signature |
Meaning |
1..1 |
language: |
The localised language in which the items in this description item are written. Encoded following the RFC 5646 standard, using ISO 639-1 (two-character) language codes, e.g. "en". It may include a region subtag conforming to ISO 3166-1 alpha-2 (two-character country codes), e.g. "pt-br" for Brazilian Portuguese. |
1..1 |
purpose: |
Purpose of the resource. |
0..1 |
Keywords which characterise this resource, used e.g. for indexing and searching. |
|
0..1 |
use: |
Description of the uses of the resource, i.e. contexts in which it could be used. |
0..1 |
misuse: |
Description of any misuses of the resource, i.e. contexts in which it should not be used. |
0..1 |
URIs of original clinical document(s) or description of which resource is a formalisation, in the language of this description item; keyed by meaning. |
|
0..1 |
Additional language-senstive resource metadata, as a list of name/value pairs. |
2.2.5. RESOURCE_ANNOTATIONS Class
Class |
RESOURCE_ANNOTATIONS |
|
---|---|---|
Description |
Object representing annotations on an archetype. These can be of various forms, with a documentation form defined so far, which has a multi-level tabular structure [ [ [String value, String key], path key], language key]. Example instance, showing the documentation structure. documentation = < ["en"] = < ["/data[id2]"] = < ["ui"] = <"passthrough"> > ["/data[id2]/items[id3]"] = < ["design note"] = <"this is a design note on Statement"> ["requirements note"] = <"this is a requirements note on Statement"> ["medline ref"] = <"this is a medline ref on Statement"> > > > Other sub-structures might have different keys, e.g. based on programming languages, UI toolkits etc. |
|
Attributes |
Signature |
Meaning |
1..1 |
documentation: |
Documentary annotations in a multi-level keyed structure. |
Amendment Record
Issue | Details | Raiser | Completed |
---|---|---|---|
SPECBASE-6: Specify language attributes of |
T Beale, |
||
Documentation fixes and typos (including SPECPR-451). |
M Zawahra, |
09 Jan 2025 |
|
1.9.0 |
SPECBASE-39: Change |
I McNicoll |
05 Nov 2024 |
SPECBASE-40: Add |
I McNicoll |
||
BASE Release 1.2.0 |
|||
1.8.3 |
SPECBASE-23: Add |
S Garde |
[22 Feb 2021 |
SPECPUB-6: Correct spelling error in |
S Garde |
13 Nov 2019 |
|
BASE Release 1.1.0 |
|||
1.8.2 |
SPECPUB-6: Type error in RM-spec: |
B Verhees |
03 Nov 2018 |
1.8.1 |
SPECPUB-6: Correct UML package nesting and paths in documents; insert |
T Beale |
27 Nov 2017 |
1.8.0 |
SPECBASE-13: Separate out from openEHR Common IM 2.1.2 / RM Release 1.0.3. |
openEHR SEC |
15 Feb 2016 |
Re-engineer |
T Beale, |
||
Release 1.0.1 |
|||
1.6.0 |
SPECRM-209: Minor changes to correctly define |
Y S Lim |
08 Apr 2007 |
SPEC-203: Release 1.0 explanatory text improvements. |
A Patterson |
||
Release 0.95 |
|||
SPEC-118. Make package names lower-case. |
T Beale |
||
Release 0.9 |
|||
1.0 |
SPEC-95. Remove property attribute from |
DSTC |
09 Mar 2004 |
Formally validated using ISE Eiffel 5.4. |
T Beale |
||
0.9 |
Initial Writing. Taken from Data types and Common Reference Models. Formally validated using ISE Eiffel 5.2. |
T Beale |
25 Feb 2003 |