Changes for page Technical details

Last modified by lzehl on 2021/07/05 18:57

From version 75.1
edited by lzehl
on 2021/06/27 13:37
Change comment: There is no comment for this version
To version 76.1
edited by lzehl
on 2021/06/27 13:47
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -108,6 +108,9 @@
108 108  The few remaining customized technical properties which need additional interpretation or translation to a formal schema languages (e.g. JSON-Schema) have an underscore as prefix (e.g., **##"_type"##**). Within the openMINDS integration pipeline (cf. below), the schema template syntax is interpreted, extended and flexibly translated to various formal schema languages. All further specifications of the openMINDS schema template syntax are described below.
109 109  
110 110  (% style="text-align: justify;" %)
111 +==== Basic openMINDS schema structure ====
112 +
113 +(% style="text-align: justify;" %)
111 111  All openMINDS schemas need to have the extension **##.schema.tpl.json##** and each schema is defined as a nested associative array (dictionary) with the following conceptual structure:
112 112  
113 113  {{code language="json"}}
... ... @@ -134,6 +134,9 @@
134 134  Under **##"required"##** a list of property names can be provided that are obligatory to be present in a correctly instantiated metadata instance of the respective schema. If none of the properties are required, this key-value pair does not have to be specified.
135 135  
136 136  (% style="text-align: justify;" %)
140 +==== Schemas extending schemas ====
141 +
142 +(% style="text-align: justify;" %)
137 137  In the case that several schemas are highly related and contain a common set of properties, it is possible to define a non-type context-schema with these common properties that can be extended and modified by the group of related schemas. All properties and constraints (e.g. required properties, expected data types) defined in the context-schema are passed on to the schemas extending this context-schema. Each of these schemas can define additional properties, or (if necessary) can overwrite the constraints of the context-schema. In order to state that a schema is extending a context-schema, the following additional key-value pair has to be added to the schema template above:
138 138  
139 139  (% style="text-align: center;" %)
... ... @@ -140,6 +140,9 @@
140 140  **##"_extends": "RELATIVE_PATH_TO_OPENMINDS-CONTEXT-SCHEMA"##**
141 141  
142 142  (% style="text-align: justify;" %)
149 +This design not only makes it easier to identify highly related schemas, but also facilitates the maintenance of the commonly used properties. A good hands-on example, is the context-schema [[ResearchProduct>>https://raw.githubusercontent.com/HumanBrainProject/openMINDS_core/v3/schemas/products/researchProduct.schema.tpl.json||rel=" noopener noreferrer" target="_blank"]] which is extended by the following schema set: [[Dataset>>https://raw.githubusercontent.com/HumanBrainProject/openMINDS_core/v3/schemas/products/dataset.schema.tpl.json||rel=" noopener noreferrer" target="_blank"]], [[MetaDataModel>>https://raw.githubusercontent.com/HumanBrainProject/openMINDS_core/v3/schemas/products/metaDataModel.schema.tpl.json]], [[Model>>https://raw.githubusercontent.com/HumanBrainProject/openMINDS_core/v3/schemas/products/model.schema.tpl.json||rel=" noopener noreferrer" target="_blank"]], and [[Software>>https://raw.githubusercontent.com/HumanBrainProject/openMINDS_core/v3/schemas/products/software.schema.tpl.json||rel=" noopener noreferrer" target="_blank"]].
150 +
151 +(% style="text-align: justify;" %)
143 143  Depending on the expected data **##"type"##** additional constraints can be made for the metadata entry of a respective property. Currently, the openMINDS schema template syntax supports the following data types: **##"string"##**, ##**"integer"**##, **##"float"##**, **##"boolean"##**, **##"array"##** and **##"object"##**.
144 144  
145 145  === The openMINDS integration pipeline ===
Public

openMINDS