Building Blocks can be defined that use RDF only,
A RDF building block can
- Define RDF (TTL) examples how to use the Semantic model
- Apply SHACL Rules to validate examples
- Perform transforms and validate results
The JSON Schema specification and tooling landscape is complex. Versions of the OpenAPI Specification (OAS) use different versions of JSON-Schema and tool support varies.
In particular, reuse mechanisms such as $dynamicRef may not be available.
OGC APIs are currently bound to OAS v3.0 which limits JSON schema patterns that can be supported.
The implication is that currently it is typical necessary to recreate complex structural hierarchies and compose into "allOf[]" structures in order to place constraints into a location.
e.g. to make the relatively simple constraints that a "SurveyObservationCollection" is a collection "SurveyObservation" objects, and must declare that some schema for describing "SensorType" is used, a significant portion of the structure must be detailed.
"SurveyVectorObsCollection": {
"allOf": [
{
"$ref": "https://opengeospatial.github.io/ogcapi-sosa/build/annotated/unstable/sosa/features/observationCollection/schema.json"
},
{
"properties": {
"features": {
"type": "array",
"items": {
"$ref": "#/$defs/SurveyVectorObsFeature"
}
},
"properties": {
"properties": {
"madeBySensor": {
"$ref": "#/$defs/SensorType"
}
},
"required": [
"madeBySensor"
]
}
}
}
]
}
},
A number of strategies are being considered to simplify this. At this stage alternative approaches:
- define a new constraint language that can be directly compiled from simple statements into the target schema constraint
- use the most compact form in more recent JSON schema - potentially requiring extension hooks in the base schemas - and compile to legacy forms with full structure replication
- work with JSON schema community to define new capabilities designed for easier profiling in a future version of JSON
- create a "wizard" tool to write constraints
All these have significant impact and effort implications.
Follow updates at this issue