Approved

OGC Standard

OGC API - Connected Systems - Part 2: Dynamic Data
Alexandre Robin Editor
Version: 1.0
OGC Standard

Approved

Document number:23-002
Document type:OGC Standard
Document subtype:Implementation
Document stage:Approved
Document language:English

License Agreement

Use of this document is subject to the license agreement at https://www.ogc.org/license

Suggested additions, changes and comments on this document are welcome and encouraged. Such suggestions may be submitted using the online change request form on OGC web site: http://ogc.standardstracker.org/




I.  Abstract

OGC API Standards define modular API building blocks to spatially enable Web APIs in a consistent way. The OpenAPI specification is used to define the API building blocks.

The OGC API family of Standards is organized by resource type. This Standard specifies the fundamental API building blocks for interacting with Connected Systems and associated resources. A Connected System represents any kind of system that can either directly transmit data via communication networks (being connected to them in a permanent or temporary fashion), or whose data is made available in one form or another via such networks. This definition encompasses systems of all kinds, including in-situ and remote sensors, actuators, fixed and mobile platforms, airborne and space-borne systems, robots and drones, and even humans who collect data or execute specific tasks.

Since many of the resource types defined in this document, including the systems themselves, are also features, the OGC API — Connected Systems Standard is logically written as an extension of OGC API — Features.

But beyond features, this Standard is also intended to act as a bridge between static data (geographic and other application domain features) and dynamic data (observations of these features properties, and commands/actuations that change these features properties). To this end, this Standard also describes protocols and formats to transmit dynamic data to/from connected systems through the API. Some of these protocols allow efficient real-time delivery of data while some others are more suited for transmitting data in batch.

In addition to providing its own mechanism for interacting with static and dynamic data, the API allows linking to other APIs from the OGC ecosystem, such as 3D GeoVolumes, 3D Tiles, Coverages, EDR, SensorThings, Processes, and other Features API instances. Among other things, this linking capability allows one to retrieve more advanced representations of features of interest (3D buildings, etc.) and gridded data (coverages) than the one that would typically be provided through this API.

The API is comprised of multiple parts, each of them being a separate standard. “Part 1 — Feature Resources” defines the feature types and corresponding schemas for some concepts of the Semantic Sensor Network Ontology (SOSA/SSN). This part (“Part 2 — Dynamic Data”) defines the resources, encodings and protocols that allow efficient exchange of dynamic (time-varying) data related to these features, in a way that is also aligned with SOSA/SSN.

II.  Keywords

The following are keywords to be used by search engines and document catalogues.

ogcdoc, OGC document, OpenAPI, REST, feature, API, system, smart system, connected system, IoT, sensorweb, ssn, sensor, actuator, transducer, sampling, platform, robot, drone, unmanned, autonomous, observation, measurement, datastream, command, control, trajectory, dynamic


III.  Preface

The OGC API — Connected Systems Standard is part of the suite of OGC API Standards.

To increase the brevity and readability of this Standard, many OGC document titles are shortened and/or abbreviated. Therefore, in the context of this document, the following phrases are defined.

  • “this Standard” shall be interpreted as equivalent to “OGC API — Connected Systems — Part 2: Dynamic Resources Standard.”

  • “CS API” or “CS API Standard” shall be interpreted as equivalent to “OGC API — Connected Systems Standard” (including all its parts).

  • “OGC API — Features” shall be interpreted as equivalent to “OGC API — Features — Part 1: Core corrigendum.”

  • “OGC API — Common” shall be interpreted as equivalent to “OGC API — Common — Part 1: Core.”

IV.  Security considerations

All security considerations detailed in OGC API — Connected Systems — Part 1 also apply to this Standard.

V.  Submitting Organizations

The following organizations submitted this Document to the Open Geospatial Consortium (OGC):

  • GeoRobotix, Inc.
  • Botts Innovative Research, Inc.
  • Cesium GS, Inc.
  • 52°North Spatial Information Research GmbH
  • Riverside Research
  • Pelagis Data Solutions
  • National Geospatial-Intelligence Agency (NGA)

VI.  Submitters

All questions regarding this submission should be directed to the editor or the submitters listed in the following table:

NameAffiliation
Alex Robin (Editor)GeoRobotix, Inc.
Christian Autermann52° North Spatial Information Research GmbH
Chuck HeazelHeazeltech
Glenn LaughlinPelagis Data Solutions
Mike BottsBotts Innovative Research, Inc.
Patrick CozziCesium GS, Inc.
Sam BollingRiverside Research

Additional contributors to this Standard include the following:

NameAffiliation
Chris TuckerGeoRobotix, Inc.
Ian PattersonBotts Innovative Research, Inc.
Qihua LiGovTech Singapore
Rob AtkinsonOpen Geospatial Consortium, Inc.
Simon CoxOpen Geospatial Consortium, Inc.
Jan Speckamp52°North Spatial Information Research GmbH

1.  Scope

This Standard defines extensions to OGC API — Features for exposing metadata and dynamic data regarding all kinds of observing systems and associated resources. It provides an actionable implementation of concepts defined in the Semantic Sensor Network Ontology (SSN) and also complies with OGC API — Common.

More specifically, Part 2 of the API, specified in this document, implements the SSN concepts allowing exchange of dynamic (possibly real-time) data flowing to and from various types of connected systems (e.g., sensors, actuators, platforms). Several encoding formats are defined in this Standard, including JSON, CSV and binary formats based on the OGC — SWE Common Standard. Additional encodings can be added by extensions.

The following types of resources are defined by Part 2 of the API.

  • DataStream resources represent data feeds coming out of Systems and are containers for Observations. They are used for receiving and ingesting real-time Observations as well as accessing historical Observations. A DataStream is a particular case of sosa:ObservationCollection where all Observations are coming from the same sensor.

  • Observation resources record all information regarding an act of observation, whether it is made by an automated device or a human. In particular, they carry the observation result that is structured according to a well defined schema. Observations are grouped into DataStreams.

  • ControlStream resources represent data feeds going into Systems and are containers for Commands. They are used for receiving and ingesting real-time Commands as well as accessing historical Commands.

  • Command resources represent messages sent to a System to control the parameters of feature of interest. In particular, a command includes parameters that are structured according to a well define schema.

  • CommandStatus resources provide status reports during the execution of a command.

  • SystemEvent resources provide information about a system event, such as sensor activation, recalibration, maintenance, etc.

CS API Part 1 defines the feature resources that these dynamic data feeds are associated to, including both the Systems that produce or receive these data feeds, and the features of interest that these data feeds provide information about.

CS API Part 3 defines pub/sub protocol bindings for exchanging dynamic data that can be used jointly with the HTTP API.

2.  Conformance

This Standard was written to be compliant with the OGC Specification Model – A Standard for Modular Specification (OGC 08-131r3). Extensions of this Standard shall themselves be conformant to the OGC Specification Model.

This Standard defines the following requirements classes.

The standardization target for these requirements classes is an implementation of the Web API.

There is no Core requirements class but an implementation target is expected to implement at least one of the CS resource* types and one encoding.

The conformance classes corresponding to these requirements classes are presented in Annex A (normative). Conformance with this Standard shall be checked using all the relevant tests specified in Annex A. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in the OGC Compliance Testing Policies and Procedures and the OGC Compliance Testing web site.

[*] “CS resources” means “Connected Systems resources” and refers to all resource types defined in this Standard.

3.  Normative references

The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.

Policy SWG: OGC 08-131r3, The Specification Model — Standard for Modular specifications. Open Geospatial Consortium (2009). https://portal.ogc.org/files/?artifact_id=34762&version=2.

Alexandre Robin: OGC 23-001, OGC API — Connected Systems — Part 1: Feature Resources, version 1.0. Open Geospatial Consortium (2025). https://docs.ogc.org/is/23-001/23-001.html

Clemens Portele, Panagiotis (Peter) A. Vretanos, Charles Heazel: OGC 17-069r4, OGC API — Features — Part 1: Core corrigendum. Open Geospatial Consortium (2022). http://www.opengis.net/doc/IS/ogcapi-features-1/1.0.1.

OGC API — Features — Part 4: Create, Replace, Update and Delete, version 1.0.0-DRAFT. http://www.opengis.net/doc/IS/ogcapi-features-4/1.0

Charles Heazel: OGC 19-072, OGC API — Common — Part 1: Core. Open Geospatial Consortium (2023). http://www.opengis.net/doc/is/ogcapi-common-1/1.0.0.

Semantic Sensor Network Ontology, (October 19 2017), https://www.w3.org/TR/vocab-ssn

Alexandre Robin: OGC 23-000, OGC SensorML Encoding Standard, version 3.0. Open Geospatial Consortium (2025). https://docs.ogc.org/is/23-000/23-000.html

Alexandre Robin: OGC 24-014, OGC SWE Common Data Model Encoding Standard, version 3.0. Open Geospatial Consortium (2025). https://docs.ogc.org/is/24-014/24-014.html

ISO: ISO 8601:2019, Date and time — Representations for information interchange — Part 1: Basic rules. International Organization for Standardization, Geneva (2019). https://www.iso.org/standard/70907.html.. ISO (2019).

ISO: ISO 8601:2019, Date and time — Representations for information interchange — Part 2: Extensions. International Organization for Standardization, Geneva (2019). https://www.iso.org/standard/70908.html.. ISO (2019).

T. Bray (ed.): IETF RFC 8259, The JavaScript Object Notation (JSON) Data Interchange Format. RFC Publisher (2017). https://www.rfc-editor.org/info/rfc8259.

M. Nottingham: IETF RFC 8288, Web Linking. RFC Publisher (2017). https://www.rfc-editor.org/info/rfc8288.

JSON Schema Validation: A Vocabulary for Structural Validation of JSON, Version 2020-12, https://json-schema.org/draft/2020-12/json-schema-validation.html

The WebSocket Protocol, December 2011, Proposed Standard. https://www.rfc-editor.org/rfc/rfc6455

MQTT Version 5.0, 07 March 2019, OASIS Standard. http://docs.oasis-open.org/mqtt/mqtt/v5.0/mqtt-v5.0.html

4.  Terms and definitions

This document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2.

This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the ‘ModSpec’. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec.

For the purposes of this document, the following additional terms and definitions apply.

All terms defined in OGC API — Common — Part 1: Core, OGC API — Features — Part 1: Core and OGC API — Features — Part 4: Create, Replace, Update and Delete also apply.

A formally defined set of types and methods which establish a contract between client code which uses the API and implementation code which provides the API.

An Actuation carries out an (Actuation) Procedure to change the state of the world using an Actuator.

[SOURCE: SOSA-SSN, ]

A device that is used by, or implements, an (Actuation) Procedure that changes the state of the world.

[SOURCE: SOSA-SSN, ]

A Command is a message that is sent to a System to trigger an Actuation. The Command message contains the parameters of the Actuation.

Collections of interrelated systems consisting of information technology (IT) devices, sensors, actuators, platforms, and processes that can seamlessly interact.

A Control Stream is a collection of Commands targeted at the same System, and sharing the same controlled properties.

A Data Stream (or Datastream) is a collection of Observations acquired by the same System, and sharing the same observed properties.

Describes the Deployment of one or more Systems for a particular purpose. Deployment may be done on a Platform.

[SOURCE: SOSA/SSN, ]

Abstraction of real-world phenomena.

[SOURCE: ISO-19101, definition 4.11]

A set of features from a dataset.

[SOURCE: OGC API — Features, definition 4.1.4]

The thing whose property is being estimated or calculated in the course of an Observation to arrive at a Result, or whose property is being manipulated by an Actuator, or which is being sampled or transformed in an act of Sampling.

[SOURCE: SOSA/SSN, ]

Act of carrying out an (Observation) Procedure to estimate or calculate a value of a property of a Feature of Interest.

[SOURCE: SOSA/SSN, ]

A Platform is an entity that hosts other entities, particularly Sensors, Actuators, Samplers, and other Platforms.

[SOURCE: SOSA/SSN, ]

A workflow, protocol, plan, algorithm, or computational method specifying how to make an Observation, create a Sample, or make a change to the state of the world (via an Actuator). A Procedure is re-usable, and might be involved in many Observations, Samplings, or Actuations. It explains the steps to be carried out to arrive at reproducible Results.

[SOURCE: SOSA/SSN, ]

Facet or attribute of an object referenced by a name.

Example : Abby’s car has the color red, where “color red” is a property of the car instance

[SOURCE: ISO-19143]

Feature which is intended to be representative of a FeatureOfInterest on which Observations may be made.

[SOURCE: SOSA/SSN, ]

A device that is used by, or implements, a (Sampling) Procedure to create or transform one or more samples.

[SOURCE: SOSA/SSN, ]

Feature representing a subset of a FeatureOfInterest on which properties are observed or controlled. For Observations, Sampling Feature is a synonym of Sample.

Device, agent (including humans), or software (simulation) involved in, or implementing, a Procedure. Sensors respond to a Stimulus, e.g., a change in the environment, or Input data composed from the Results of prior Observations, and generate a Result. Sensors can be hosted by Platforms.

[SOURCE: SOSA/SSN, ]

System is a unit of abstraction for pieces of infrastructure that implement Procedures. A System may have components, its subsystems, which are other Systems.

[SOURCE: SOSA/SSN, ]

6.  Conventions

This sections provides details and examples for any conventions used in the document. Examples of conventions are symbols, abbreviations, use of XML schema, or special notes regarding how to read the document.

6.1.  Identifiers

The normative provisions in this standard are denoted by the URI

http://www.opengis.net/spec/ogcapi-connectedsystems-2/1.0

All requirements and conformance tests that appear in this document are denoted by partial URIs which are relative to this base.

6.2.  Abbreviated terms

In this document the following abbreviations and acronyms are used or introduced:

  • API: Application Programming Interface

  • CRS: Coordinate Reference System

  • CSML: Climate Science Modeling Language

  • CSV: Comma-Separated Values

  • DSV: Delimiter-Separated Values (a generalization of CSV)

  • GPS: Global Positioning System

  • ISO: International Organization for Standardization

  • MISB: Motion Imagery Standards Board

  • OGC: Open Geospatial Consortium

  • SAS: Sensor Alert Service

  • SensorML: Sensor Model Language

  • SI: Système International (International System of Units)

  • SOS: Sensor Observation Service

  • SPS: Sensor Planning Service

  • SWE: Sensor Web Enablement

  • TAI: Temps Atomique International (International Atomic Time)

  • UML: Unified Modeling Language

  • UTC: Coordinated Universal Time

  • XML: eXtensible Markup Language

  • 1D: One Dimensional

  • 2D: Two Dimensional

  • 3D: Three Dimensional

7.  Overview

7.1.  General

All resources defined in Part 1 of this Standard are feature resources, among which the System resource. Part 2 (this document) defines additional resource types to describe and interact with the dynamic data that flows in and out of these systems.

Part 2 of this Standard defines resource types that allow the provision of dynamic data about all kinds of devices, hardware components or processes that can transmit and/or receive data via communication networks (a.k.a. connected systems), including sensors, platforms, robots, human observers, forecast models, computer simulations, etc.

Flows carrying observation and status data coming out of a system are called Datastreams while flows carrying commands sent to a system are called Control Streams (note that the direction of the flow mentioned here is relative to the real system, which is different from the direction of the data flows going in and out of the API server).

7.2.  Design Considerations

In this Standard, Observations and Commands are purposefully not modelled as Features. This choice was made to keep a clear separation between the Features of Interest that represent concrete or virtual objects (or things) of interest (and in the vast majority of use cases, real-world objects) and the other concepts that are used to encapsulate dynamic data related to these features:

  • Observations carry the result of the estimation of one or more feature properties, at a given time (and location); and

  • Commands carry the desired value of one or more feature properties, at a given time.

Likewise, DataStreams and ControlStreams are not modelled as features, as they are simply containers for Observations and Commands, respectively. More specifically, they are particular cases of homogeneous collections that are associated to a single System (see Clauses 9 and 10).

7.3.  Resource Types

As indicated above, while part 1 of this Standard focused on defining “static” feature types, part 2 defines additional resources to deal with dynamic data associated to these features.

Figure 1 shows a UML class diagram of all Connected Systems API resources. Resources defined in part 2 are shown with a solid border while resources that were already defined in part 1 are shown with a dashed light gray outline.

 

api-class-diagram

Figure 1 — Class diagram of API resources

The table below provides a short summary description of these resource types:

Table 1 — Overview of resource types defined by this Standard

Resource TypeRequirements ClassDescriptionPossible Encodings
DataStreamClause 9Description of datastreams, including observed properties and features of interest.JSON
ObservationClause 9Actual observations, including the result data.JSON, SWE-JSON, SWE-Text, SWE-Binary
ControlStreamClause 10Description of control channels, including controllable properties and features of interest.JSON
CommandClause 10Actual command messages, including the command parameters data.JSON, SWE-JSON, SWE-Text, SWE-Binary
Command StatusClause 10Status info about a given command.JSON
Command ResultClause 10Result of a given command.JSON
FeasibilityClause 11Feasibility requests, including the command parameters data.JSON, SWE-JSON, SWE-Text, SWE-Binary
Feasibility StatusClause 11Status info about a given feasibility request.JSON
Feasibility ResultClause 11Result of a given feasibility request.JSON
System EventClause 12System events (e.g., deployment, maintenance or replacement events).JSON

NOTE:  The encodings listed in the table are the ones defined in this Standard document but extensions can define additional encodings.

7.4.  API Endpoints

OGC API — Connected Systems — Part 1 defines the concept of canonical resources endpoint and canonical resource endpoint. This section provides the canonical endpoints used in CS API Part 2.

7.4.1.  Canonical Resources Endpoints

The canonical resources endpoints for resource types defined in Part 2 of the CS API Standard are:

  • {api_root}/datastreams

  • {api_root}/observations

  • {api_root}/controlstreams

  • {api_root}/commands

  • {api_root}/feasibility

  • {api_root}/systemEvents

7.4.2.  Canonical Resource Endpoints

The canonical URL templates to access a single resource defined in Part 2 of the CS API Standard are:

  • {api_root}/datastreams/{id}

  • {api_root}/observations/{id}

  • {api_root}/controlstreams/{id}

  • {api_root}/commands/{id}

  • {api_root}/feasibility/{id}

  • {api_root}/systemEvents/{id}

8.  Requirements Class “Common”

Requirements class 1

Identifier/req/api-common
Target typeWeb API
Conformance classConformance class A.1: /conf/api-common
Prerequisitehttp://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/api-common
Normative statementsRequirement 1: /req/api-common/resources
Requirement 2: /req/api-common/resource-collection

8.1.  Overview

All resource types defined in this Standard must comply with a common set of rules, many of which are inherited from OGC API — Common.

8.2.  Non-feature Resources

Resources defined in this Standard are not considered features, but many of the requirements specified in OGC API — Features — Part 1: Core and OGC API — Features — Part 4: Create, Replace, Update and Delete still apply.

Requirement 1

Identifier/req/api-common/resources
Included inRequirements class 1: /req/api-common
A

All references to the term “features” or “feature” in the OGC API — Features — Part 1: Core and OGC API — Features — Part 4: Create, Replace, Update and Delete Standards SHALL be replaced by the terms “resources” or “resource” when interpreting requirements for OGC API — Connected Systems — Part 2.

8.3.  Resource Collections

Resource collections are exposed in the same way feature collections are in OGC API — Features — Part 1: Core, except that the itemType is set to a different value.

Requirement 2

Identifier/req/api-common/resource-collection
Included inRequirements class 1: /req/api-common
A

A resource collection SHALL fulfill all requirements from Clauses 7.14, 7.15 and 7.16 of OGC API — Features — Part 1: Core, except for clauses 7.15.3 (parameter bbox) and 7.15.4 (parameter datetime).

B

All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

9.  Requirements Class “Datastreams & Observations”

9.1.  Overview

Requirements class 2

Identifier/req/datastream
Target typeWeb API
Conformance classConformance class A.2: /conf/datastream
PrerequisiteRequirements class 1: /req/api-common
Normative statementsRequirement 3: /req/datastream/sf-ref-from-datastream
Requirement 4: /req/datastream/foi-ref-from-datastream
Requirement 5: /req/datastream/canonical-url
Requirement 6: /req/datastream/resources-endpoint
Requirement 7: /req/datastream/canonical-endpoint
Requirement 8: /req/datastream/ref-from-system
Requirement 9: /req/datastream/ref-from-deployment
Requirement 10: /req/datastream/collections
Requirement 11: /req/datastream/schema-op
Requirement 12: /req/datastream/obs-canonical-url
Requirement 13: /req/datastream/obs-resources-endpoint
Requirement 14: /req/datastream/obs-canonical-endpoint
Requirement 15: /req/datastream/obs-ref-from-datastream
Requirement 16: /req/datastream/obs-collections

The “Datastreams & Observations” requirements class specifies how DataStream and Observation resources are provided using the CS API.

A DataStream resource represents data produced by a single output of an (observation) system (itself represented by a System feature in the CS API). The DataStream can be used to provide access to real-time data only, archived data only, or both. The metadata in the DataStream description can be used to disambiguate between these cases.

DataStream and Observation resources implement the ObservationCollection and Observation concepts defined in the Semantic Sensor Network Ontology (SOSA/SSN), respectively.

9.2.  DataStream Resource

9.2.1.  Introduction

In the CS API Standard, DataStream resources are a special kind of resource that implements the sosa:ObservationCollection concept, with the following restrictions:

  • All observations in a DataStream are produced by the same System; and

  • All observations in a DataStream share the same observed properties and the same result schema.

This section defines the attributes and associations composing a DataStream resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the DataStream resource:

 

api-class-diagram

Figure 2 — DataStream Resource Diagram

9.2.2.  Properties

The following tables describe the attributes and associations of a DataStream resource and their mapping to SOSA/SSN.

Table 2 — DataStream Attributes

NameSOSA/SSN PropertyDefinitionData TypeUsage
namerdfs:labelThe human readable name of the datastream.StringMandatory
descriptionrdfs:commentA human readable description for the datastream.StringOptional
type-The type of datastream (see Table 3).EnumOptional
validTimesosa:validTimeThe validity period of the datastream’s description.TimeExtentOptional
phenomenonTimesosa:phenomenonTimeThe time period spanned by the phenomenon times of all observations in the datastream.TimeExtentRequired
resultTimesosa:resultTimeThe time period spanned by the result times of all observations in the datastream.TimeExtentRequired
observedPropertiessosa:observedPropertyProperties for which the observations in the datastream provide measurements.List<URI>Required
resultType-The type of result for observations in the datastream (see Table 4).EnumRequired
live-Indicates whether live data is available from the datastream.BooleanRequired
formats-The list of formats that the observations in the datastream can be encoded to.List<String>Required

The values for the properties observedProperties, phenomenonTime, resultTime, resultType SHALL be automatically generated by the server based the Observations that are linked to the Datastream. If there are no linked Observations the properties SHALL be set to null. The property live MAY be generated by the server. In this case the server MAY ignore updates to the property.

Table 3 — DataStream Types

Datastream TypeUsage
statusFor datastreams providing status observations of the parent system itself or one of its subsystems.
observationFor datastreams providing observations of other features of interest (not the system itself).

Table 4 — Result Types

Result TypeUsage
measureWhen the result is a single scalar value with a unit of measure
vectorWhen the result is a vector quantity (e.g velocity vector, stress tensor)
recordWhen the result is a record containing only scalar values and/or vectors
coverageWhen the result is a coverage (any number of dimensions)
complexWhen the result is a record with nested records and/or arrays

Table 5 — DataStream Associations

NameSOSA/SSN PropertyDefinitionTarget ContentUsage
systemsosa:isObservedByThe System that is the producer of the datastream.A single System resource (by reference).Required
observationssosa:hasMemberThe Observations that are part of the datastream.A list of Observation resources.Required
proceduresosa:usedProcedureThe procedure used to generate observations in the datastream.A single Procedure resource.Optional
deployment-The deployment during which the datastream was generated.A single Deployment resource.Optional
samplingFeaturessosa:hasFeatureOfInterestThe Sampling Features that are the subject of observations in the datastream.A list of SamplingFeature resources.Optional
featuresOfInterestsosa:hasUltimateFeatureOfInterestThe ultimate features of interest that are the subject of observations in the datastream.A list of Feature resources.Optional

When sampling features and ultimate features of interest are hosted on the same server, they are made accessible through sub-endpoints of the DataStream resource.

Requirement 3

Identifier/req/datastream/sf-ref-from-datastream
Included inRequirements class 2: /req/datastream
Conditions

The server implements http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/sampling

A

The server SHALL implement a Sampling Feature resources endpoint at path {api_root}/datastreams/{dsId}/samplingFeatures for each available DataStream resource.

B

The endpoint SHALL only expose the Sampling Feature resources that are associated to observations in the parent DataStream with ID dsId.

Requirement 4

Identifier/req/datastream/foi-ref-from-datastream
Included inRequirements class 2: /req/datastream
Conditions
  • The server provides the featuresOfInterest association as part of DataStream resource representations.

  • The server hosts the features of interest descriptions locally.

A

The server SHALL implement a Feature resources endpoint at path {api_root}/datastreams/{dsId}/featuresOfInterest for each available DataStream resource.

B

The endpoint SHALL only expose the Feature resources that are the ultimate features of interest of observations in the parent DataStream with ID dsId.

9.3.  DataStream Canonical URL

The CS API Standard requires that every DataStream resource has a canonical URL.

Requirement 5

Identifier/req/datastream/canonical-url
Included inRequirements class 2: /req/datastream
A

All DataStream resources exposed by the server SHALL be accessible through their canonical URL of the form {api_root}/datastreams/{id} where id is the local identifier of the DataStream resource.

B

If a DataStream resource is retrieved through any other URL than its canonical URL, the server response SHALL include a link to its canonical URL with relation type canonical.

9.4.  DataStream Resources Endpoints

9.4.1.  Definition

A DataStream resources endpoint is an endpoint exposing a set of DataStream resources that can be further filtered using query parameters.

Requirement 6

Identifier/req/datastream/resources-endpoint
Included inRequirements class 2: /req/datastream
A

The server SHALL support the HTTP GET operation at the path associated to the DataStream resources endpoint.

B

The operation SHALL support the parameter limit defined in Clause 7.15.2 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

The operation SHALL support the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively. Only DataStream resources that have a validTime property that intersects the temporal information in the datetime parameter SHALL be part of the result set.

D

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the DataStream resources selected by the request.

E

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

Clause 13.2 defines additional query parameters applicable to DataStream resources endpoint.

9.4.2.  Canonical DataStream Resources Endpoint

The CS API Standard requires that a canonical DataStream resources endpoint, exposing all DataStream resources, be made available by the server.

Requirement 7

Identifier/req/datastream/canonical-endpoint
Included inRequirements class 2: /req/datastream
A

The server SHALL expose a DataStream resources endpoint at the path {api_root}/datastreams.

B

The endpoint SHALL expose all DataStream resources available on the server.

9.4.3.  Nested DataStream Resources Endpoints

The set of datastreams produced by a specific system is available at a nested endpoint under the corresponding System resource:

Requirement 8

Identifier/req/datastream/ref-from-system
Included inRequirements class 2: /req/datastream
Conditions

The server implements http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/system

A

The server SHALL implement a DataStream resources endpoint at path {api_root}/systems/{sysId}/datastreams for each available System resource.

B

The endpoint SHALL only expose the DataStream resources associated to the System with ID sysId.

The set of datastreams associated to a specific deployment is available at a nested endpoint under the corresponding Deployment resource:

Requirement 9

Identifier/req/datastream/ref-from-deployment
Included inRequirements class 2: /req/datastream
Conditions

The server implements http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/deployment

A

The server SHALL implement a DataStream resources endpoint at path {api_root}/deployments/{depId}/datastreams for each available Deployment resource.

B

The endpoint SHALL only expose the DataStream resources associated to a system that was deployed during the Deployment with ID depId, and whose valid time intersects the deployment time period.

9.5.  DataStream Collections

Any number of resources collections containing DataStream resources can be available at a CS API endpoint. DataStream collections are identified with the item type DataStream.

DataStream resources can be grouped into collections according to any arbitrary criteria, as exemplified below:

Example

Examples of DataStream Collections

  • All data collected by organization X at URL {api_root}/collections/orgx_datastreams

  • All data collected during a field survey involving multiple sensors at URL {api_root}/collections/campaignX_datastreams

Note that a given datastream can be part of multiple collections at the same time.

Requirement 10

Identifier/req/datastream/collections
Included inRequirements class 2: /req/datastream
A

If the server exposes collections of DataStream resources, it SHALL be done as specified in Clause 8.3.

B

The server SHALL identify all resource collections containing DataStream resources by setting the itemType attribute to DataStream in the Collection metadata.

C

For any resource collection with itemType set to DataStream, the HTTP GET operation at the path /collections/{collectionId}/items SHALL support the query parameters and response of a DataStream resources endpoint.

9.6.  Observation Schemas

A different observation schema is needed for each individual datastream because the exact content of the observations result changes according to result type and the properties being observed. Moreover, multiple observation formats can be offered for any given datastream, and the schema is typically expressed differently for each format.

Thus, for each DataStream resource, the CS API provides a way for the server to communicate an observation schema (not necessarily a JSON schema) for each supported observation format. The exact content of a schema resource is defined by each encoding. See section Clause 16.1.4 for example schemas used for observations encoded using the default JSON format.

Extensions to this Standard can define additional representation formats for observations. Such format extensions must clearly define the mapping between elements of the representation format and the Observation resource defined in the next clause.

Requirement 11

Identifier/req/datastream/schema-op
Included inRequirements class 2: /req/datastream
A

For every DataStream resource exposed at the CS API endpoint, the server SHALL support the HTTP GET operation at the path {api_root}/datastreams/{id}/schema.

B

The operation SHALL support the parameter obsFormat with the following characteristics (using an OpenAPI 3.0 fragment):

 

name: obsFormat
in: query
description: Media type of the desired observation format
required: true
schema:
  type: string
C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The server SHALL return a single schema corresponding to the format identified by the obsFormat parameter.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

Example

Example

If a datastream with ID {id} reports the following supported observation formats:

  • application/json

  • application/swe+csv

  • application/swe+binary

The schema for each of these formats is obtained with the following requests, respectively:

  • https://{api_root}/datastreams/{id}/schema?obsFormat=application/json

  • https://{api_root}/datastreams/{id}/schema?obsFormat=application/swe%2Bcsv

  • https://{api_root}/datastreams/{id}/schema?obsFormat=application/swe%2Bbinary

Note that the media type in the request has to be properly URL encoded, leading to the %2B in place of the + character.

9.7.  Observation Resource

9.7.1.  Introduction

In the CS API Standard, Observation resources are a special kind of resource that implements the sosa:Observation concept.

In the CS API, Observation resources are always associated to a DataStream (e.g., a type of ObservationCollection). Some properties of the observation (e.g., link to the observing system, observed properties) can thus be omitted as they are provided at the datastream level.

In addition, the CS API does not restrict Observation resources to have a single observed property. It is thus possible to package the observation result of several properties in a single resource.

This section defines the attributes and associations composing a Observation resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the Observation resource:

 

api-class-diagram

Figure 3 — Observation Resource Diagram

9.7.2.  Properties

The following tables describe the attributes and associations of an Observation resource and their mapping to SOSA/SSN.

Table 6 — Observation Attributes

NameSOSA/SSN PropertyDefinitionData TypeUsage
phenomenonTimesosa:phenomenonTimeThe time the observed property value applies to the feature of interest.DateTimeRequired
resultTimesosa:resultTimeThe time the result value was obtained.DateTimeRequired
parameters-Observation parameters, providing information about how the procedure was used to produce this specific observation.AnyOptional
resultsosa:hasResultObservation result, carrying the estimated values of the observed properties.AnyRequired

NOTE:  The phenomenonTime can be in the far past (e.g., geological or deep space observations) or in the future (e.g., weather forecast). The resultTime, however, can never be in the future.

Table 7 — Observation Associations

NameSOSA/SSN PropertyDefinitionTarget ContentUsage
datastream-The DataStream that the observation is part of.A single DataStream resource.Required
samplingFeaturesosa:hasFeatureOfInterestThe sampling feature that is the subject of the observation.A single SamplingFeature resource.Optional
proceduresosa:usedProcedureThe procedure that was used to make the observationA single Procedure resource.Optional

9.8.  Observation Canonical URL

The CS API Standard requires that every Observation resource has a canonical URL.

Requirement 12

Identifier/req/datastream/obs-canonical-url
Included inRequirements class 2: /req/datastream
A

All Observation resources exposed by the server SHALL be accessible through their canonical URL of the form {api_root}/observations/{id} where id is the local identifier of the Observation resource.

B

If a Observation resource is retrieved through any other URL than its canonical URL, the server response SHALL include a link to its canonical URL with relation type canonical.

9.9.  Observation Resources Endpoint

9.9.1.  Definition

An Observation resources endpoint is an endpoint exposing a set of Observation resources that can be further filtered using query parameters.

Requirement 13

Identifier/req/datastream/obs-resources-endpoint
Included inRequirements class 2: /req/datastream
A

The server SHALL support the HTTP GET operation at the path associated to the Observation resources endpoint.

B

The operation SHALL support the parameter limit defined in Clause 7.15.2 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the Observation resources selected by the request.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

9.9.2.  Canonical Observation Resources Endpoint

The CS API Standard requires that a canonical Observation resources endpoint, exposing all Observation resources, be made available by the server.

Requirement 14

Identifier/req/datastream/obs-canonical-endpoint
Included inRequirements class 2: /req/datastream
A

The server SHALL expose a Observation resources endpoint at the path {api_root}/observations.

B

The endpoint SHALL expose all Observation resources available on the server.

9.9.3.  Nested Observation Resources Endpoint

The set of observations produced as part of a specific datastream is available at a nested endpoint under the corresponding DataStream resource:

Requirement 15

Identifier/req/datastream/obs-ref-from-datastream
Included inRequirements class 2: /req/datastream
A

The server SHALL implement a Observation resources endpoint at path {api_root}/datastreams/{dsId}/observations for each available DataStream resource.

B

The endpoint SHALL only expose the Observation resources that are part of the parent DataStream with ID dsId.

9.10.  Observation Collections

Any number of resources collections containing Observation resources can be available at a CS API endpoint. Observation collections are identified with the item type Observation.

Observation resources can be grouped into collections according to any arbitrary criteria, as exemplified below:

Example

Examples of Observation Collections

  • All observations collected by organization X at URL {api_root}/collections/orgx_obs

  • All observations collected during a field survey involving multiple sensors at URL {api_root}/collections/campaignX_obs

Note that a given observation can be part of multiple collections at the same time.

Requirement 16

Identifier/req/datastream/obs-collections
Included inRequirements class 2: /req/datastream
A

If the server exposes collections of Observation resources, it SHALL be done as specified in Clause 8.3.

B

The server SHALL identify all resource collections containing Observation resources by setting the itemType attribute to Observation in the Collection metadata.

C

For any resource collection with itemType set to Observation, the HTTP GET operation at the path /collections/{collectionId}/items SHALL support the query parameters and response of a Observation resources endpoint.

10.  Requirements Class “Control Streams & Commands”

10.1.  Overview

This requirements class specifies how ControlStream, Command, and CommandStatus resources are provided using the CS API.

A ControlStream resource represents a control channel that is used to change the state of (or affect) a feature of interest (which can be a System itself). The state is changed by sending the desired values of certain controllable properties of the feature of interest, but note that the resulting state will not necessarily reflect the exact values requested (If the exact result state must be known, it can be monitored separately using an associated DataStream resource).

A ControlStream resource represents the real-time stream of command messages sent to the system, as well as all historical commands received through the channel. It can be used to provide access to real-time commands only, archived commands only, or both. The metadata in the ControlStream description can used to disambiguate between these cases.

Command resources are available through their parent ControlStream resource, and each command can lead to the creation of one or more status reports (i.e., CommandStatus resources).

ControlStream and Command resources implement the ActuationCollection and Actuation concepts defined in the Semantic Sensor Network Ontology (SOSA/SSN), respectively.

10.2.  ControlStream Resource

10.2.1.  Introduction

In the CS API Standard, ControlStream resources are a special kind of resource that implements the sosa:ActuationCollection concept, with the following restrictions:

  • All commands in a ControlStream are received by the same System; and

  • All commands in a ControlStream share the same controlled properties and the same parameter schema.

This section defines the attributes and associations composing a ControlStream resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the ControlStream resource:

 

api-class-diagram

Figure 4 — ControlStream Resource Diagram

10.2.2.  Properties

The following tables describe the attributes and associations of the ControlStream resource and their mapping to SOSA/SSN.

Table 8 — ControlStream Attributes

NameSOSA/SSN PropertyDefinitionData TypeUsage
namerdfs:labelThe human readable name of the control stream.StringRequired
descriptionrdfs:commentA human readable description for the control stream.StringOptional
type-The type of control stream (see Table 9).EnumOptional
validTimesosa:validTimeThe validity period of the control stream’s description.TimeExtentOptional
issueTime-The time period spanned by the issue times of all commands in the control stream.TimeExtentRequired
executionTimesosa:phenomenonTimeThe time period spanned by the execution times of all commands in the control stream.TimeExtentRequired
controlledPropertiessosa:actsOnPropertyProperties whose value can be changed by commands in the control stream.List<URI>Required
live-Indicates whether the control stream currently accepts commands.BooleanRequired
async-Indicates whether commands are processed asynchronously in the control stream.BooleanRequired
formats-The list of formats that the commands in the control stream can be encoded to.List<String>Required

Table 9 — ControlStream Types

TypeUsage
selfFor control streams that affect the parent system itself or one of its subsystems.
externalFor control streams that affect external features of interest.

Table 10 — ControlStream Associations

NameSOSA/SSN PropertyDefinitionTarget ContentUsage
systemsosa:madeByActuatorThe System that received commands from the ControlStream.A single System resource.Required
commandssosa:hasMemberThe Commands that were sent to the control channel.A list of Command resources.Required
proceduresosa:usedProcedureThe procedure used to process commands received in the control stream.A single Procedure resource.Optional
deployment-The deployment during which the control stream was used.A single Deployment resource.Optional
samplingFeaturessosa:hasFeatureOfInterestThe Sampling Features that are the target of commands in this control stream.A list of SamplingFeature resources.Optional
featuresOfInterestsosa:hasUltimateFeatureOfInterestThe ultimate features of interest that are affected by the commands in this control stream.A list of Feature resources.Optional

NOTE:  In the case of commands/actuations, the sampling feature is used to describe where the effector interacts with the feature of interest (e.g., the vent of an A/C system, the part of a larger system, etc.).

When sampling features and ultimate features of interest are hosted on the same server, they are made accessible through sub-endpoints of the DataStream resource.

Requirement 17

Identifier/req/controlstream/sf-ref-from-controlstream
Included inRequirements class 3: /req/controlstream
Conditions

The server implements http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/sampling

A

The server SHALL implement a Sampling Feature resources endpoint at path {api_root}/controlstreams/{dsId}/samplingFeatures for each available DataStream resource.

B

The endpoint SHALL only expose the Sampling Feature resources that are associated to observations in the parent DataStream with ID dsId.

Requirement 18

Identifier/req/controlstream/foi-ref-from-controlstream
Included inRequirements class 3: /req/controlstream
Conditions
  • The server provides the featuresOfInterest association as part of ControlStream resource representations.

  • The server hosts the features of interest descriptions locally.

A

The server SHALL implement a Feature resources endpoint at path {api_root}/controlstreams/{dsId}/featuresOfInterest for each available ControlStream resource.

B

The endpoint SHALL only expose the Feature resources that are the ultimate features of interest of commands in the parent ControlStream with ID dsId.

10.3.  ControlStream Canonical URL

The CS API Standard requires that every ControlStream resource has a canonical URL.

Requirement 19

Identifier/req/controlstream/canonical-url
Included inRequirements class 3: /req/controlstream
A

All ControlStream resources exposed by the server SHALL be accessible through their canonical URL of the form {api_root}/controls/{id} where id is the local identifier of the ControlStream resource.

B

If a ControlStream resource is retrieved through any other URL than its canonical URL, the server response SHALL include a link to its canonical URL with relation type canonical.

10.4.  ControlStream Resources Endpoints

10.4.1.  Definition

A DataStream resources endpoint is an endpoint exposing a set of ControlStream resources that can be further filtered using query parameters.

Requirement 20

Identifier/req/controlstream/resources-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL support the HTTP GET operation at the path associated to the ControlStream resources endpoint.

B

The operation SHALL support the parameter limit defined in Clause 7.15.2 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

The operation SHALL support the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively. Only DataStream resources that have a validTime property that intersects the temporal information in the datetime parameter SHALL be part of the result set.

D

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the ControlStream resources selected by the request.

E

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

Clause 13.2 defines additional query parameters applicable to ControlStream resources endpoint.

10.4.2.  Canonical ControlStream Resources Endpoint

The CS API Standard requires that a canonical ControlStream resources endpoint, exposing all ControlStream resources, be made available by the server.

Requirement 21

Identifier/req/controlstream/canonical-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL expose a ControlStream resources endpoint at the path {api_root}/controlstreams.

B

The endpoint SHALL expose all ControlStream resources available on the server.

10.4.3.  Nested ControlStream Resources Endpoints

The set of control streams available on a specific system is available at a nested endpoint under the corresponding System resource:

Requirement 22

Identifier/req/controlstream/ref-from-system
Included inRequirements class 3: /req/controlstream
Conditions

The server implements http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/system

A

The server SHALL implement a ControlStream resources endpoint at path {api_root}/systems/{sysId}/controlstreams for each available System resource.

B

The endpoint SHALL only expose the ControlStream resources associated to the System with ID sysId.

The set of control streams associated to a specific deployment can also be made available at a nested endpoint under the corresponding Deployment resource:

Requirement 23

Identifier/req/controlstream/ref-from-deployment
Included inRequirements class 3: /req/controlstream
Conditions
A

The server SHALL implement a ControlStream resources endpoint at path {api_root}/deployments/{depId}/controlstreams for each available Deployment resource.

B

The endpoint SHALL only expose the ControlStream resources associated to a system that was deployed during the Deployment with ID depId, and whose valid time intersects the deployment time period.

10.5.  ControlStream Collections

Any number of resources collections containing ControlStream resources can be available at a CS API endpoint. ControlStream collections are identified with the item type ControlStream.

ControlStream resources can be grouped into collections according to any arbitrary criteria, as exemplified below:

Example

Examples of ControlStream Collections

  • All control streams used to control a fleet of unmanned systems at URL {api_root}/collections/uxs_controlstreams

  • All control streams used to task agents in a squad at URL {api_root}/collections/squad1_controlstreams

Note that a given control stream can be part of multiple collections at the same time.

Requirement 24

Identifier/req/controlstream/collections
Included inRequirements class 3: /req/controlstream
A

If the server exposes collections of ControlStream resources, it SHALL be done as specified in Clause 8.3.

B

The server SHALL identify all resource collections containing ControlStream resources by setting the itemType attribute to ControlStream in the Collection metadata.

C

For any resource collection with itemType set to ControlStream, the HTTP GET operation at the path /collections/{collectionId}/items SHALL support the query parameters and response of a ControlStream resources endpoint.

10.6.  Command Schemas

A different command schema is needed for each individual control stream because the exact content of the command parameters changes according to the the properties being controlled. Moreover, multiple command formats can be offered for any given control stream, and each format may express the schema in a different manner.

Thus, for each ControlStream resource, the CS API provides a way for the server to communicate a command schema (not necessarily a JSON schema) for each supported command format. The exact content of a schema resource is defined by each encoding. See section Clause 16.1.7 for example schemas used for commands encoded using the default JSON format.

Extensions to this Standard can define additional representation formats for Command resources. Such format extensions must clearly define the mapping between elements of the representation format and the Command resource defined in the next clause.

Requirement 25

Identifier/req/controlstream/schema-op
Included inRequirements class 3: /req/controlstream
A

For every ControlStream resource exposed at the CS API endpoint, the server SHALL support the HTTP GET operation at the path {api_root}/controlstreams/{id}/schema.

B

The operation SHALL support the parameter cmdFormat with the following characteristics (using an OpenAPI 3.0 fragment):

 

name: cmdFormat
in: query
description: Media type of the desired command format
required: false
schema:
  type: string
C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The server SHALL return a single schema corresponding to the format identified by the cmdFormat parameter.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

Example

Example

If a control stream reports the following supported command formats:

  • application/json

  • application/swe+csv

  • application/swe+binary

The schema for each of these formats is obtained with the following requests, respectively:

  • https://{api_root}/controlstreams/{id}/schema?cmdFormat=application/json

  • https://{api_root}/controlstreams/{id}/schema?cmdFormat=application/swe%2Bcsv

  • https://{api_root}/controlstreams/{id}/schema?cmdFormat=application/swe%2Bbinary

Note that the media type in the request has to be properly URL encoded.

10.7.  Command Resource

In the CS API Standard, Command resources are a special kind of resource that implements a generalization of the sosa:Actuation concept.

In the CS API, Command resources are always associated to a ControlStream. Some properties of the command (e.g., link to the parent system, controlled properties) can thus be omitted as they are provided at the control stream level.

In addition, the CS API does not restrict Command resources to have a single controlled property. It is thus possible to package the desired value of several controlled parameters in a single command, and processing a command can result in actions on several properties at once (e.g., both orientation and FOV of a camera can be modified with a single ‘ptz’ command).

This section defines the attributes and associations composing a Command resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the Command resource:

 

api-class-diagram

Figure 5 — Command Resource Diagram

10.7.1.  Properties

The following tables describe the attributes and associations of the Command resource.

Table 11 — Command Attributes

NameDefinitionData TypeUsage
issueTimeThe time the command was received by the system.DateTimeRequired*
executionTimeThe time period during which the command was executed. The time period ends when the effect of the command has modified all controlled properties of the feature of interest.TimeExtentOptional
senderIdentifier of the user or entity who issued the commandStringOptional
currentStatusCurrent status code of the command (see Table 14).EnumRequired*
parametersThe value of the command parameters.AnyRequired

(*) These properties are required when a command is reported by the server but not when creating or updating a command. If provided on creation, they should be ignored by the server.

Table 12 — Command Associations

Relation NameDefinitionTarget Content
controlstreamThe ControlStream that the command is part of.A single ControlStream resource.
samplingFeatureThe feature of interest whose properties are changed by the command.A single SamplingFeature resource.
procedureThe procedure used to process the command.A single Procedure resource.
statusList of status reports related to the command.A list of CommandStatus resources.
resultList of results generated during the execution of the command.A list of CommandResult resources.

10.8.  Command Canonical URL

The CS API Standard requires that every Command resource has a canonical URL.

Requirement 26

Identifier/req/controlstream/cmd-canonical-url
Included inRequirements class 3: /req/controlstream
A

All Command resources exposed by the server SHALL be accessible through their canonical URL of the form {api_root}/commands/{id} where id is the local identifier of the Command resource.

B

If a Command resource is retrieved through any other URL than its canonical URL, the server response SHALL include a link to its canonical URL with relation type canonical.

10.9.  Command Resources Endpoint

10.9.1.  Definition

A Command resources endpoint is an endpoint exposing a set of Command resources that can be further filtered using query parameters.

Requirement 27

Identifier/req/controlstream/cmd-resources-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL support the HTTP GET operation at the path associated to the Command resources endpoint.

B

The operation SHALL support the parameter limit defined in Clause 7.15.2 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the Observation resources selected by the request.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

10.9.2.  Canonical Command Resources Endpoint

The CS API Standard requires that a canonical Command resources endpoint, exposing all Command resources, be made available by the server.

Requirement 28

Identifier/req/controlstream/cmd-canonical-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL expose a Command resources endpoint at the path {api_root}/commands.

B

The endpoint SHALL expose all Command resources available on the server.

10.9.3.  Nested Command Resources Endpoint

The set of commands received within a specific control stream is available at a nested endpoint under the corresponding ControlStream resource:

Requirement 29

Identifier/req/controlstream/cmd-ref-from-controlstream
Included inRequirements class 3: /req/controlstream
A

The server SHALL implement a Command resources endpoint at path {api_root}/controlstream/{csId}/commands for each available ControlStream resource.

B

The endpoint SHALL only expose the Command resources that are part of the parent ControlStream with ID csId.

10.10.  Command Collections

Any number of resources collections containing Command resources can be available at a CS API endpoint. Command collections are identified with the item type Command.

Command resources can be grouped into collections according to any arbitrary criteria.

Example

Examples of Command Collections

  • All commands received from user A {api_root}/collections/userA_commands (would likely be visible only to this user)

  • All commands that targeted a specific feature of interest B {api_root}/collections/featureB_commands

Note that a given commands can be part of multiple collections at the same time.

Requirement 30

Identifier/req/controlstream/cmd-collections
Included inRequirements class 3: /req/controlstream
A

If the server exposes collections of Command resources, it SHALL be done as specified in Clause 8.3.

B

The server SHALL identify all resource collections containing Command resources by setting the itemType attribute to Command in the Collection metadata.

C

For any resource collection with itemType set to Command, the HTTP GET operation at the path /collections/{collectionId}/items SHALL support the query parameters and response of a Command resources endpoint.

10.11.  CommandStatus Resource

CommandStatus resources represent a status report describing the status/progress of a command at a given point in time.

When commands are processed synchronously, a single status report is provided in the HTTP response. The status can be either COMPLETED,REJECTED or FAILED.

When commands are processed asynchronously, several status reports can be issued for any given command. They are used to report early acceptance/rejection of the command, scheduling and execution steps as well as failure and cancellations. It is recommended for a server to generate appropriate status reports to report incremental progress of long running commands.

This section defines the attributes and associations composing a CommandStatus resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the CommandStatus resource:

 

api-class-diagram

Figure 6 — Command Status Resource Diagram

10.11.1.  Properties

The following tables describe the attributes and associations of the CommandStatus resource.

Table 13 — Command Status Attributes

NameDefinitionData TypeUsage
reportTimeThe time when the status report was generated.DateTimeRequired
statusCodeCode describing the state of the command (see Table 14).EnumRequired
percentCompletionEstimated progress as a percentage of total progress.NumberOptional
executionTimeThe time period during which the command was or will be executed. This can either represent the estimated or actual execution time period depending on the associated status code (see status code in Table 14). The time period ends when the effect of the command has modified all controlled properties of the feature of interest.TimeExtentOptional
messageA human readable status message.StringOptional
resultThe result of the command associated to the progress report (this can be a partial result).List of CommandResultOptional

Table 14 — Command Status Codes

CodeUsage
PENDINGThe command is pending, meaning it has been received by the system but no decision to accept or reject it has been made.
ACCEPTEDThe command was accepted by the receiving system. This usually means that the command has passed the first validation steps, but it can still be rejected or fail later during execution.
REJECTEDThe command was rejected by the receiving system. It won’t be executed at all and the message property provides the reason for the rejection. This is a final state. No further status updates will be sent.
SCHEDULEDThe command was validated and effectively scheduled by the receiving system. When this status code is used, the scheduled execution time must be provided.
UPDATEDAn update to the command was received and accepted. This code must be used if the system supports task updates.
CANCELEDThe command was canceled by an authorized user. This code must be used if the system supports user driven task cancellations. The REJECTED state should be used instead if the command was canceled by the receiving system. This is a final state. No further status updates will be sent.
EXECUTINGThe command is currently being executed by the receiving system. The status message can provide more information about the current progress. A system can send several status updates with this code but different time stamps to report progress incrementally. In particular, the progress percentage and the end of the (estimated) execution time period can be refined in each update.
COMPLETEDThe command has completed after a successful execution. The actual execution time must be provided. This is a final state. No further status updates will be sent.
FAILEDThe command has failed during execution. The error and/or status message provides the reason for failure. This is a final state. No further status updates will be sent.

Table 15 — Command Status Associations

NameDefinitionTarget Content
commandThe Command that this status report relates to.A single Command resource.

10.12.  CommandStatus Resources Endpoint

10.12.1.  Definition

A Command Status resources endpoint is an endpoint exposing a set of CommandStatus resources that can be further filtered using query parameters.

Requirement 31

Identifier/req/controlstream/status-resources-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL support the HTTP GET operation at the path associated to the CommandStatus resources endpoint.

B

The operation SHALL support the parameters limit and datetime defined in Clause 7.15.2 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the CommandStatus resources selected by the request.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

10.12.2.  Status Endpoint

The set of status reports associated to a given command is available at a nested endpoint under the corresponding Command resource:

Requirement 32

Identifier/req/controlstream/command-status-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL implement a Command Status resources endpoint at path {api_root}/command/{cmdId}/status for every Command resource.

B

The endpoint SHALL only expose the CommandStatus resources that are related to the Command resource with local ID cmdId.

10.13.  CommandResult Resource

Certain types of commands lead to the production of data (e.g., tasking a system for data collection, triggering a process such as a simulation run, etc.).

Different types of result can be attached to a command status report:

  • Reference to one or more datastreams containing the result data, each with an optional time range;

  • Reference to one or more individual observations containing the result data;

  • Reference to a collection of observations containing the result data; and

  • Inline result data encoded as described by the control stream result schema (can be one or more records).

    NOTE 1:  In the case of a command result provided inline, the result data may or may not be recorded separately in a datastream.

    NOTE 2:  For commands executed synchronously, the result can be provided as part of the status report returned in the HTTP response.

The following examples describe how command results are used in various use cases:

Example

Example 1: Chemical plume simulation
A command is used to trigger a new run of a chemical plume dispersion model with certain parameters. The output of the model is a time series of observations where each observation provides the location of all particles for a given time (phenomenonTime). Each processed command leads to the creation of a new datastream that will contain all observations resulting for the model run. When the run is completed, a last progress report is provided with a reference to the datastream.

Example 2: UAV video footage task
A command is used to task a UAV to collect video data while orbiting around a building. The output is a set of may observations (i.e., video frames) that are appended to the existing video datastream of the UAV. When the task is completed, a last status report is provided with a reference to the video datastream with a time range selecting the portion of the video stream that is relevant to the task.

Example 3: UAV picture task
A command is used to task a UAV to collect an image at a specific location. The output is a single observation that is appended to the existing image datastream of the UAV. When the task is completed, a last progress report is provided with a reference to the image observation.

Example 4: Satellite imagery acquisition
A command is used to task an earth observation satellite to collect imagery to cover a given geographic area (i.e., coverage request). The output is a set of one or more image observations that are appended to the existing image datastream of the EO sensor. When the task is completed, a last status report is provided with references to all the collected image observations.

Example 5: System state retrieval
A command is used to query the state of a system. The result of the query is provided inline in the status report (potentially synchronously if the state data can be retrieved quickly).

Example 6: On-demand processing
A command is used to trigger a simple on-demand process that computes temporal averages of parameters in a datastream over a certain time period. The output of the process is provided inline in the status report (potentially synchronously if the computation can be done quickly).

This section defines the attributes and associations composing a CommandResult resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the CommandResult resource:

 

api-class-diagram

Figure 7 — Command Result Resource Diagram

10.13.1.  Properties

The following tables describe the attributes and associations of the CommandResult resource. At least one of the properties must be provided.

Table 16 — Command Result Attributes

NameDefinitionData TypeUsage
inlineThe result data provided inline (encoded according to the ControlStream result schema).AnyOptional

Table 17 — Command Result Associations

NameDefinitionTarget Content
observationAn observation resulting from the execution of the commandA list of Observation resources (by reference).
datastreamA datastream containing observations resulting from the execution of the commandA single DataStream resource (by reference).
externalAn external dataset containing the results of the command.Any resource (by reference).

10.14.  CommandResult Resources Endpoint

10.14.1.  Definition

A Command Result resources endpoint is an endpoint exposing a set of CommandResult resources that can be further filtered using query parameters.

Requirement 33

Identifier/req/controlstream/result-resources-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL support the HTTP GET operation at the path associated to the CommandResult resources endpoint.

B

The operation SHALL support the parameter limit defined in Clause 7.15.2 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the CommandResult resources selected by the request.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

10.14.2.  Result Endpoint

The set of result items associated to a given command is available at a nested endpoint under the corresponding Command resource:

Requirement 34

Identifier/req/controlstream/command-result-endpoint
Included inRequirements class 3: /req/controlstream
A

The server SHALL implement a Command Result resources endpoint at path {api_root}/command/{cmdId}/result for every Command resource that can be associated to a result.

B

The endpoint SHALL only expose the CommandResult resources that are related to the Command resource with local ID cmdId.

11.  Requirements Class “Command Feasibility”

11.1.  Overview

Requirements class 4

Identifier/req/feasibility
Target typeWeb API
Conformance classConformance class A.4: /conf/feasibility
PrerequisiteRequirements class 3: /req/controlstream
Normative statementsRequirement 35: /req/feasibility/canonical-url
Requirement 36: /req/feasibility/ref-from-controlstream
Requirement 37: /req/feasibility/status-endpoint
Requirement 38: /req/feasibility/result-endpoint
Requirement 39: /req/feasibility/collections

The execution of certain commands is sometimes impossible due to internal or external constraints (e.g., conflict with other scheduled commands, conflict with another user that has exclusive control on the system, etc.).

In order for a client to know if a command/task is feasible without sending the actual command, feasibility channels are supported by the CS API.

In addition to providing a binary (i.e., YES/NO) response to a feasibility request, the CS API also provides a mechanism for returning detailed feasibility analysis information to a client (e.g., provide chances of success, task execution steps, alternatives, etc.).

A feasibility request is initiated by creating a Command resource on the feasibility channel. The server can then respond synchronously or asynchronously just like for a regular command channel. The parameters used for the feasibility request are the same as the one for the corresponding commands (i.e., both commands and feasibility share the same parameters schema).

11.2.  Feasibility Resource

A Feasibility resource is a Command resource created on a control stream feasibility channel (see Clause 10.7, Command Resource for details).

All nested resources available under a regular command resource are also available under the feasibility resource.

11.3.  Feasibility Canonical URL

The CS API Standard requires that every Feasibility resource has a canonical URL.

Requirement 35

Identifier/req/feasibility/canonical-url
Included inRequirements class 4: /req/feasibility
A

All Feasibility resources exposed by the server SHALL be accessible through their canonical URL of the form {api_root}/feasibility/{id} where id is the local identifier of the Feasibility resource.

B

If a Feasibility resource is retrieved through any other URL than its canonical URL, the server response SHALL include a link to its canonical URL with relation type canonical.

11.4.  Feasibility Endpoint

The set of feasibility requests received for a specific control stream is available at a nested endpoint under the corresponding ControlStream resource:

Requirement 36

Identifier/req/feasibility/ref-from-controlstream
Included inRequirements class 4: /req/feasibility
A

The server SHALL implement a Command resources endpoint at path {api_root}/controlstream/{csId}/feasibility for each available ControlStream resource.

B

The endpoint SHALL only expose the Feasibility resources that are part of the parent ControlStream with ID csId.

11.5.  Feasibility Status

Feasibility status is provided using a CommandStatus resource (see Clause 10.11, CommandStatus Resource for details).

The following table clarifies the meaning of status codes in the case of a feasibility request:

Table 18 — Feasibility Status Codes

CodeUsage
PENDINGThe feasibility request is pending, meaning it has been received by the system but no decision to accept or reject it has been made.
ACCEPTEDThe feasibility request was accepted by the receiving system. This usually means that the request parameters have passed the first validation steps, but it can still be rejected or fail later during the analysis.
REJECTEDThe feasibility request was rejected by the receiving system. It won’t be processed at all and the message property provides the reason for the rejection. This is a final state. No further status updates will be sent.
SCHEDULEDUnused for feasibility requests.
UPDATEDUnused for feasibility requests.
CANCELEDThe feasibility request was canceled by an authorized user. This code must be used if the system supports user driven task cancellations. The REJECTED state should be used instead if the feasibility analysis was canceled by the receiving system. This is a final state. No further status updates will be sent.
EXECUTINGThe feasibility request is currently being processed by the receiving system. The status message can provide more information about the current progress. A system can send several status updates with this code but different time stamps to report progress incrementally. In particular, the progress percentage and the end of the (estimated) execution time period can be refined in each update.
COMPLETEDThe feasibility analysis has completed successfully. The actual execution time must be provided. This is a final state. No further status updates will be sent.
FAILEDThe feasibility analysis has failed during processing. The error and/or status message provides the reason for failure. This is a final state. No further status updates will be sent.

The set of status reports associated to a given feasibility request is available at a nested endpoint under the corresponding Feasibility resource:

Requirement 37

Identifier/req/feasibility/status-endpoint
Included inRequirements class 4: /req/feasibility
A

The server SHALL implement a Command Status resources endpoint at path {api_root}/feasibility/{feasId}/status for every Feasibility resource.

B

The endpoint SHALL only expose the CommandStatus resources that are related to the Feasibility resource with local ID feasId.

11.6.  Feasibility Result

Feasibility results are provided using CommandResult resources (see Clause 10.13, CommandResult Resource for details).

The results of a feasibility analysis are usually provided inline. The result structure must match the “feasibility result schema” provided by the parent ControlStream resource. The “feasibility result schema” is typically different from the “command result schema”.

Below are examples of feasibility results for various use cases:

Example

Example 1: Tasking a UAV to go to a lat/lon location
In addition to a binary (yes/no) feasibility response, the result of the feasibility analysis may include the earliest time at which the location could be reached, as well as the expected trajectory.

Example 2: Tasking a satellite to cover an area with visible imagery
The result of the feasibility analysis may include all the attempts needed to have a high enough chance of success to obtain a clear (i.e., cloud free) image of the area. If the area is too large to be covered with a single image, an estimated success rate and completion time could be provided separately for each subdivision of the geographic area.

The set of result items associated to a given feasibility request is available at a nested endpoint under the corresponding Feasibility resource:

Requirement 38

Identifier/req/feasibility/result-endpoint
Included inRequirements class 4: /req/feasibility
A

The server SHALL implement a Command Result resources endpoint at path {api_root}/feasibility/{feasId}/result for every Feasibility resource.

B

The endpoint SHALL only expose the CommandResult resources that are related to the Feasibility resource with local ID feasId.

11.7.  Feasibility Collections

Collections of feasibility resources are also supported, but are optional.

Requirement 39

Identifier/req/feasibility/collections
Included inRequirements class 4: /req/feasibility
A

If the server exposes collections of Feasibility resources, it SHALL be done as specified in Clause 8.3.

B

The server SHALL identify all resource collections containing Feasibility resources by setting the itemType attribute to Feasibility in the Collection metadata.

C

For any resource collection with itemType set to Feasibility, the HTTP GET operation at the path /collections/{collectionId}/items SHALL support the query parameters and response of a Command resources endpoint.

12.  Requirements Class “System Events”

Requirements class 5

Identifier/req/system-event
Target typeWeb API
Conformance classConformance class A.5: /conf/system-event
PrerequisitesRequirements class 1: /req/api-common
http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/req/system
Normative statementsRequirement 40: /req/system-event/canonical-url
Requirement 41: /req/system-event/resources-endpoint
Requirement 42: /req/system-event/canonical-endpoint
Requirement 43: /req/system-event/ref-from-system
Requirement 44: /req/system-event/collections

12.1.  Overview

SystemEvent resources are used to capture information about various events and maintenance operations occurring on (observing) systems such as recalibrations, part replacements, software updates, relocations/deployments, operator handoffs, decommissioning, etc.

This section predefines a certain number of event types but the list can be extended further by extensions.

12.2.  SystemEvent Resource

SystemEvent resources are modeled on the SensorML Event class.

This section defines the attributes and associations composing a SystemEvent resource, but the exact way they are encoded in the payload is defined by each encoding. For encodings defined in this document, please see:

Below is the contextual class diagram of the SystemEvent resource:

 

api-class-diagram

Figure 8 — System Event Diagram

12.2.1.  Properties

The following tables describe the attributes and associations of a SystemEvent resource.

Table 19 — System Event Attributes

NameDefinitionData TypeUsage
nameThe name of the event.StringRequired
descriptionA human readable description for the event.StringOptional
typeThe type of event (see Table 20).URIRequired
eventTimeThe time the event occurred on the system.TimeExtentRequired
messageA human readable message from the operator.StringOptional

Table 20 — System Event Types

Type URIUsage
http://www.opengis.net/def/x-OGC/TBD/CalibrationSystem was calibrated or recalibrated.
http://www.opengis.net/def/x-OGC/TBD/ConfigurationChangeThe configuration was changed.
http://www.opengis.net/def/x-OGC/TBD/SoftwareUpdateThe software was updated.
http://www.opengis.net/def/x-OGC/TBD/PartReplacementOne or more physical parts were replaced.
http://www.opengis.net/def/x-OGC/TBD/RelocationThe system was moved to a different location.
http://www.opengis.net/def/x-OGC/TBD/DeploymentThe system was deployed.
http://www.opengis.net/def/x-OGC/TBD/DecommissionThe system was decommissioned.

Table 21 — System Event Associations

Relation NameDefinitionTarget Content
systemLink to the System this event relates to.A single System resource.

12.3.  SystemEvent Canonical URL

The CS API Standard requires that every SystemEvent resource has a canonical URL.

Requirement 40

Identifier/req/system-event/canonical-url
Included inRequirements class 5: /req/system-event
A

All SystemEvent resources exposed by the server SHALL be accessible through their canonical URL of the form {api_root}/systemEvents/{id} where id is the local identifier of the SystemEvent resource.

B

If a SystemEvent resource is retrieved through any other URL than its canonical URL, the server response SHALL include a link to its canonical URL with relation type canonical.

12.4.  SystemEvent Resources Endpoints

12.4.1.  Definition

A SystemEvent resources endpoint is an endpoint exposing a set of SystemEvent resources that can be further filtered using query parameters.

Requirement 41

Identifier/req/system-event/resources-endpoint
Included inRequirements class 5: /req/system-event
A

The server SHALL support the HTTP GET operation at the path associated to the SystemEvent resources endpoint.

B

The operation SHALL support the parameters limit and datetime defined in Clause 7.15.2 and Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in OGC API — Features — Part 1: Core requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

A successful execution of the operation SHALL be reported as a response with a HTTP status code 200. The response SHALL only include the SystemEvent resources selected by the request.

D

Error cases SHALL be reported using HTTP status codes listed in Clause 7.5.1 of OGC API — Features — Part 1: Core.

Clause 13.7 defines additional query parameters applicable to SystemEvent resources endpoint.

12.4.2.  Canonical SystemEvent Resources Endpoint

The CS API Standard requires that a canonical SystemEvent resources endpoint, exposing all SystemEvent resources, be made available by the server.

Requirement 42

Identifier/req/system-event/canonical-endpoint
Included inRequirements class 5: /req/system-event
A

The server SHALL expose a System Event resources endpoint at the path {api_root}/systemEvents.

B

The endpoint SHALL expose all SystemEvent resources available on the server.

12.4.3.  Nested SystemEvent Resources Endpoints

The set of events related to a specific system is available at a nested endpoint under the corresponding System resource:

Requirement 43

Identifier/req/system-event/ref-from-system
Included inRequirements class 5: /req/system-event
A

The server SHALL implement a System Event resources endpoint at path {api_root}/systems/{sysId}/events for each available System resource.

B

The endpoint SHALL only expose the SystemEvent resources associated to the System with ID sysId.

12.5.  SystemEvent Collections

Any number of resources collections containing SystemEvent resources can be available at a CS API endpoint. SystemEvent collections are identified with the item type SystemEvent.

SystemEvent resources can be grouped into collections according to any arbitrary criteria, as exemplified below:

Example

Examples of SystemEvent Collections

  • All events related to a fleet of UAVs at URL {api_root}/collections/uas_fleet1_events

  • All events related to a particular mission at URL {api_root}/collections/mission23_events

Note that a given event can be part of multiple collections at the same time.

Requirement 44

Identifier/req/system-event/collections
Included inRequirements class 5: /req/system-event
A

If the server exposes collections of SystemEvent resources, it SHALL be done as specified in Clause 8.3.

B

The server SHALL identify all resource collections containing SystemEvent resources by setting the itemType attribute to SystemEvent in the Collection metadata.

C

For any resource collection with itemType set to SystemEvent, the HTTP GET operation at the path /collections/{collectionId}/items SHALL support the query parameters and response of a System Event resources endpoint.

13.  Requirements Class “Advanced Filtering”

13.1.  Overview

This requirements class specifies additional filtering options that may be used to select only a subset of the resources in a collection.

All filters defined in this section are implemented using URL query parameters and are used in addition to the ones defined in other requirements classes. In particular, all parameters defined in Clause 16.3 of OGC API — Connected Systems — Part 1 shall also be supported on all resource types.

13.2.  DataStream Query Parameters

The following query parameters are used to filter DataStream resources at a DataStream resources endpoint.

13.2.1.  Phenomenon Time Filter

This filter is used to select datastreams based on their phenomenonTime extent.

Requirement 45

Identifier/req/advanced-filtering/datastream-by-phenomenontime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an DataStream resources endpoint SHALL support a parameter phenomenonTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the phenomenonTime property of DataStream resources SHALL be used to determine the temporal extent evaluated against the parameter.

13.2.2.  Result Time Filter

This filter is used to select datastreams based on their resultTime extent.

Requirement 46

Identifier/req/advanced-filtering/datastream-by-resulttime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an DataStream resources endpoint SHALL support a parameter resultTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the resultTime property of DataStream resources SHALL be used to determine the temporal extent evaluated against the parameter.

13.2.3.  Observed Property Filter

This filter is used to select datastreams that include specific observable properties.

Requirement 47

Identifier/req/advanced-filtering/datastream-by-obsprop
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at a DataStream resources endpoint SHALL support a parameter observedProperty of type ID_List.

B

Only datastreams that include an observed property that has one of the requested identifiers SHALL be part of the result set.

13.2.4.  Feature of Interest Filter

This filter is used to select datastreams that are associated to specific sampling features or (ultimate) features of interest.

Requirement 48

Identifier/req/advanced-filtering/datastream-by-foi
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an DataStream resources endpoint SHALL support a parameter foi of type ID_List.

B

Only DataStream resources that are associated to a feature of interest that has one of the requested identifiers SHALL be part of the result set.

C

Both sampling features and domain features of interest SHALL be included in the search.

13.3.  Observation Query Parameters

The following query parameters are used to filter Observation resources at an {obs-resources-endpoint}.

13.3.1.  Phenomenon Time Filter

This filter is used to select observations based on their phenomenonTime property.

Requirement 49

Identifier/req/advanced-filtering/obs-by-phenomenontime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Observation resources endpoint SHALL support a parameter phenomenonTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the phenomenonTime property of Observation resources SHALL be used to determine the temporal extent evaluated against the parameter.

Example

Example queries to find Observations by phenomenonTime

closed interval{api_root}/datastreams/123/observations?phenomenonTime=2018-02-12T00:00:00Z/2018-03-18T12:31:12Z
open interval{api_root}/datastreams/123/observations?phenomenonTime=2018-02-12T00:00:00Z/..
special case now{api_root}/datastreams/123/observations?phenomenonTime=now

13.3.2.  Result Time Filter

This filter is used to select observations based on their resultTime property.

Requirement 50

Identifier/req/advanced-filtering/obs-by-resulttime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Observation resources endpoint SHALL support a parameter resultTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the resultTime property of Observation resources SHALL be used to determine the temporal extent evaluated against the parameter.

D

In addition to the possible parameter values defined in OGC API — Features — Part 1: Core, the parameter SHALL also support the special value latest. When this special value is used, only observations with the latest result time SHALL be included in the result set.

Example

Example queries to find Observations by resultTime

closed interval{api_root}/datastreams/123/observations?resultTime=2018-02-12T00:00:00Z/2018-03-18T12:31:12Z
open interval{api_root}/datastreams/123/observations?resultTime=2018-02-12T00:00:00Z/..
special case latest{api_root}/datastreams/123/observations?resultTime=latest

13.3.3.  Feature of Interest Filter

This filter is used to select observations that are associated to specific sampling features or ultimate features of interests.

Requirement 51

Identifier/req/advanced-filtering/obs-by-foi
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Observation resources endpoint SHALL support a parameter foi of type ID_List.

B

Only Observation resources that are associated to a feature of interest that has one of the requested identifiers SHALL be part of the result set.

C

Both sampling features and domain features of interest SHALL be included in the search.

13.4.  ControlStream Query Parameters

The following query parameters are used to filter ControlStream resources at a ControlStream resources endpoint.

13.4.1.  Issue Time Filter

This filter is used to select control streams based on their issueTime extent.

Requirement 52

Identifier/req/advanced-filtering/controlstream-by-issuetime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an ControlStream resources endpoint SHALL support a parameter issueTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the issueTime property of CommandStream resources SHALL be used to determine the temporal extent evaluated against the parameter.

13.4.2.  Execution Time Filter

This filter is used to select control streams based on their executionTime extent.

Requirement 53

Identifier/req/advanced-filtering/controlstream-by-exectime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an ControlStream resources endpoint SHALL support a parameter executionTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the executionTime property of CommandStream resources SHALL be used to determine the temporal extent evaluated against the parameter.

13.4.3.  Controlled Property Filter

This filter is used to select control streams that include specific controllable properties.

Requirement 54

Identifier/req/advanced-filtering/controlstream-by-controlprop
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at a ControlStream resources endpoint SHALL support a parameter controlledProperty of type ID_List.

B

Only control streams that include a controlled property that has one of the requested identifiers SHALL be part of the result set.

13.4.4.  Feature of Interest Filter

This filter is used to select control streams that are associated to specific sampling features or (ultimate) features of interest.

Requirement 55

Identifier/req/advanced-filtering/controlstream-by-foi
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an ControlStream resources endpoint SHALL support a parameter foi of type ID_List.

B

Only CommandStream resources that are associated to a feature of interest that has one of the requested identifiers SHALL be part of the result set.

C

Both sampling features and domain features of interest SHALL be included in the search.

13.5.  Command Query Parameters

The following query parameters are used to filter Command resources at a Command resources endpoint.

13.5.1.  Issue Time Filter

This filter is used to select commands based on their issueTime property.

Requirement 56

Identifier/req/advanced-filtering/cmd-by-issuetime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Command resources endpoint SHALL support a parameter issueTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the issueTime property of Command resources SHALL be used to determine the temporal extent evaluated against the parameter.

13.5.2.  Execution Time Filter

This filter is used to select commands based on their executionTime property.

Requirement 57

Identifier/req/advanced-filtering/cmd-by-exectime
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Command resources endpoint SHALL support a parameter executionTime.

B

The parameter SHALL fulfill the same requirements as the parameter datetime defined in Clause 7.15.4 of OGC API — Features — Part 1: Core. All references to the term “features” or “feature” in these requirements SHALL be replaced by the terms “resources” or “resource”, respectively.

C

Only the executionTime property of Command resources SHALL be used to determine the temporal extent evaluated against the parameter.

13.5.3.  Status Filter

This filter is used to select commands based on their statusCode property.

Requirement 58

Identifier/req/advanced-filtering/cmd-by-status
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Command resources endpoint SHALL support a parameter statusCode with the following characteristics (using an OpenAPI 3.0 fragment):

 

name: statusCode
description: |-
  List of command status codes.
  Only command resources whose current status matches one of the provided status codes are selected.
in: query
required: false
schema:
  type: array
  minItems: 1
  items:
    type: string
    enum: ["PENDING", "ACCEPTED", "REJECTED", "SCHEDULED", "UPDATED", "CANCELED", "EXECUTING", "FAILED", "COMPLETED"]
explode: false
B

Only Command resources whose current status matches one of the specified status codes SHALL be part of the result set.

13.5.4.  Sender Filter

This filter is used to select commands issued by a specific sender.

Requirement 59

Identifier/req/advanced-filtering/cmd-by-sender
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Command resources endpoint SHALL support a parameter sender with the following characteristics (using an OpenAPI 3.0 fragment):

 

name: sender
description: |-
  List of sender IDs.
  Only command resources issued by one of the specified senders are selected.
in: query
required: false
schema:
  type: array
  minItems: 1
  items:
    type: string
explode: false
B

Only Command resources issued by one of the specified senders SHALL be part of the result set.

13.5.5.  Feature of Interest Filter

Requirement 60

Identifier/req/advanced-filtering/cmd-by-foi
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Command resources endpoint SHALL support a parameter foi of type ID_List.

B

Only Command resources that are associated to a feature of interest that has one of the requested identifiers SHALL be part of the result set.

C

Both sampling features and domain features of interest SHALL be included in the search.

13.6.  CommandStatus Query Parameters

The following query parameters are used to filter CommandStatus resources at a Command Status resources endpoint.

13.6.1.  StatusCode Filter

Requirement 61

Identifier/req/advanced-filtering/status-by-statuscode
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an Command Status resources endpoint SHALL support a parameter statusCode with the following characteristics (using an OpenAPI 3.0 fragment):

 

name: statusCode
description: |-
  List of command status codes.
  Only command resources whose current status matches one of the provided status codes are selected.
in: query
required: false
schema:
  type: array
  minItems: 1
  items:
    type: string
    enum: ["PENDING", "ACCEPTED", "REJECTED", "SCHEDULED", "UPDATED", "CANCELED", "EXECUTING", "FAILED", "COMPLETED"]
explode: false
B

Only CommandStatus resources with a status that matches one of the specified status codes SHALL be part of the result set.

13.7.  SystemEvent Query Parameters

The following query parameters are used to filter SystemEvent resources at a System Event resources endpoint.

13.7.1.  Event Type Filter

Requirement 62

Identifier/req/advanced-filtering/event-by-type
Included inRequirements class 6: /req/advanced-filtering
A

The HTTP GET operation at an System Event resources endpoint SHALL support a parameter eventType with the following characteristics (using an OpenAPI 3.0 fragment):

 

name: eventType
description: |-
  List of event types.
  Only event resources with a type that matches one of the provided types are selected.
in: query
required: false
schema:
  type: array
  minItems: 1
  items:
    type: string
explode: false
B

Only SystemEvent resources with a type that matches one of the specified types SHALL be part of the result set.

14.  Requirements Class “Create/Replace/Delete”

14.1.  Overview

The “Create/Replace/Delete” requirements class specifies how instances of the resource types defined in this Standard are created, replaced and deleted via a CS API endpoint.

All resources are created, replaced and deleted using CREATE (HTTP POST), REPLACE (HTTP PUT) and DELETE (HTTP DELETE) operations, respectively, as defined by the OGC API — Features — Part 4: Create, Replace, Update and Delete Standard.

OGC API — Features — Part 4: Create, Replace, Update and Delete uses the terms “resources endpoint” and “resource endpoint” to identify the paths where these operations are supported by the server. The following sections provide these endpoints for each resource type defined by the CS API Standard.

14.2.  DataStreams

Requirement 63

Identifier/req/create-replace-delete/datastream
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL support the CREATE operation at the DataStream resources endpoints defined by the following URI template:

  • {api_root}/systems/{sysId}/datastreams

B

The server SHALL support the REPLACE and DELETE operations at the DataStream resource endpoints defined by the following URI templates:

  • {api_root}/systems/{sysId}/datastreams/{id}

  • {api_root}/datastreams/{id}

C

The sysId parameter is the local identifier of the System resource the DataStream is (or will be) associated to.
The id parameter is the local identifier of the DataStream resource to replace or delete.

The following constraints must be implemented by the server.

Requirement 64

Identifier/req/create-replace-delete/datastream-update-schema
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL reject a REPLACE request on a DataStream resource that modifies the observation schema if the DataStream already has nested Observation resources. The server SHALL use HTTP status code 409 to report the error.

Requirement 65

Identifier/req/create-replace-delete/datastream-delete-cascade
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Datastreams Observations”

A

By default, the server SHALL reject a DELETE request on a DataStream resource that has nested Observation resources. The server SHALL use HTTP status code 409 to report the error.

B

If the request contains the cascade parameter, the server SHALL accept the DELETE request and delete the DataStream resource as well as all its nested Observation resources.

NOTE 1:  A schema must be provided before observations can be inserted in the datastream. The schema is provided along with the DataStream resource itself. Only one schema (for only one format) can be provided by a create operation for a given datastream. However, the server is allowed to automatically convert observations to/from other supported formats, as appropriate. This implies that the server can also automatically generate equivalent schemas for these other formats. Future extensions may define patterns to allow client to define multiple schemas themselves.

NOTE 2:  After a datastream has been created and observations have been associated to it, the server may reject certain updates to the schema (e.g., adding or removing result fields, changing UoM, etc.). Datastream schema evolution will be addressed in more details in a future revision, but the current workaround is to create a new datastream if the schema changes.

14.3.  Observations

Requirement 66

Identifier/req/create-replace-delete/observation
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL support the CREATE operation at the Observation resources endpoints defined by the following URI template:

  • {api_root}/datastreams/{dsId}/observations

B

The server SHALL support the REPLACE and DELETE operations at the Observation resource endpoints defined by the following URI templates:

  • {api_root}/datastreams/{dsId}/observations/{id}

  • {api_root}/observations/{id}

C

The dsId parameter is the local identifier of the DataStream resource the Observation is (or will be) associated to.
The id parameter is the local identifier of the Observation resource to replace or delete.

The following constraints must be implemented by the server.

Requirement 67

Identifier/req/create-replace-delete/observation-schema
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL reject an Observation CREATE or REPLACE request with HTTP status code 400 if the Observation representation is not valid with respect to the schema provided by the parent DataStream resource.

14.4.  Control Streams

Requirement 68

Identifier/req/create-replace-delete/controlstream
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the CREATE operation at the ControlStream resources endpoints defined by the following URI template:

  • {api_root}/systems/{sysId}/controlstreams

B

The server SHALL support the REPLACE and DELETE operations at the ControlStream resource endpoints defined by the following URI templates:

  • {api_root}/systems/{sysId}/controlstreams/{id}

  • {api_root}/controlstreams/{id}

C

The sysId parameter is the local identifier of the System resource the ControlStream is (or will be) associated to.
The id parameter is the local identifier of the ControlStream resource to replace or delete.

The following constraints must be implemented by the server.

Requirement 69

Identifier/req/create-replace-delete/controlstream-update-schema
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL reject a REPLACE request on a ControlStream resource that modifies the command schema if the ControlStream already has nested Command resources. The server SHALL use HTTP status code 409 to report the error.

Requirement 70

Identifier/req/create-replace-delete/controlstream-delete-cascade
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

By default, the server SHALL reject a DELETE request on a ControlStream resource that has nested Command resources. The server SHALL use HTTP status code 409 to report the error.

B

If the request contains the cascade parameter, the server SHALL accept the DELETE request and delete the ControlStream resource as well as all its nested Command resources.

14.5.  Commands

Requirement 71

Identifier/req/create-replace-delete/command
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the CREATE operation at the Command resources endpoints defined by the following URI template:

  • {api_root}/controlstreams/{csId}/commands

B

The server SHALL support the REPLACE and DELETE operations at the Command resource endpoints defined by the following URI templates:

  • {api_root}/controlstreams/{csId}/commands/{id}

  • {api_root}/commands/{id}

C

The csId parameter is the local identifier of the ControlStream resource the Command is (or will be) associated to.
The id parameter is the local identifier of the Command resource to replace or delete.

The following constraints must be implemented by the server.

Requirement 72

Identifier/req/create-replace-delete/command-schema
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL reject a Command CREATE or REPLACE request with HTTP status code 400 if the Command representation is not valid with respect to the schema provided by the parent ControlStream resource.

NOTE:  Cancelling a command is different from deleting the Command resource with an HTTP DELETE request. When a command is cancelled, the Command resource remain on the server but its status is changed to CANCELED (and of course the command processing should be aborted whenever possible). Command cancellation is implemented by posting a new status report with status code CANCELED at the command status endpoint. See requirements for CommandStatus resources endpoints below.

14.6.  Command Status

Requirement 73

Identifier/req/create-replace-delete/command-status
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the CREATE operation at the CommandStatus resources endpoints defined by the following URI template:

  • {api_root}/commands/{cmdId}/status

B

The server SHALL support the REPLACE and DELETE operations at the CommandStatus resource endpoints defined by the following URI template:

  • {api_root}/commands/{cmdId}/status/{id}

C

The cmdId parameter is the local identifier of the Command resource the CommandStatus is (or will be) associated to.
The id parameter is the local identifier of the CommandStatus resource to replace or delete.

14.7.  Command Results

Requirement 74

Identifier/req/create-replace-delete/command-result
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the CREATE operation at the CommandResult resources endpoints defined by the following URI template:

  • {api_root}/commands/{cmdId}/result

B

The server SHALL support the REPLACE and DELETE operations at the CommandResult resource endpoints defined by the following URI template:

  • {api_root}/commands/{cmdId}/result/{id}

C

The cmdId parameter is the local identifier of the Command resource the CommandResult is (or will be) associated to.
The id parameter is the local identifier of the CommandResult resource to replace or delete.

14.8.  Feasibility

Requirement 75

Identifier/req/create-replace-delete/feasibility
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Command Feasibility”

A

The server SHALL support the CREATE operation at the Command resources endpoints defined by the following URI template:

  • {api_root}/controlstreams/{csId}/feasibility

B

The server SHALL support the REPLACE and DELETE operations at the Command resource endpoints defined by the following URI templates:

  • {api_root}/controlstreams/{csId}/feasibility

  • {api_root}/feasibility/{id}

C

The csId parameter is the local identifier of the ControlStream resource the Feasibility is (or will be) associated to.
The id parameter is the local identifier of the Feasibility resource to replace or delete.

14.9.  Feasibility Status

Requirement 76

Identifier/req/create-replace-delete/feasibility-status
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Command Feasibility”

A

The server SHALL support the CREATE operation at the CommandStatus resources endpoints defined by the following URI template:

  • {api_root}/feasibility/{feasId}/status

B

The server SHALL support the REPLACE and DELETE operations at the CommandStatus resource endpoints defined by the following URI template:

  • {api_root}/feasibility/{feasId}/status/{id}

C

The feasId parameter is the local identifier of the Feasibility resource the CommandStatus is (or will be) associated to.
The id parameter is the local identifier of the CommandStatus resource to replace or delete.

14.10.  Feasibility Results

Requirement 77

Identifier/req/create-replace-delete/feasibility-result
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “Command Feasibility”

A

The server SHALL support the CREATE operation at the CommandResult resources endpoints defined by the following URI template:

  • {api_root}/feasibility/{feasId}/result

B

The server SHALL support the REPLACE and DELETE operations at the CommandResult resource endpoints defined by the following URI template:

  • {api_root}/feasibility/{feasId}/result/{id}

C

The feasId parameter is the local identifier of the Feasibility resource the CommandResult is (or will be) associated to.
The id parameter is the local identifier of the CommandResult resource to replace or delete.

14.11.  System Events

Requirement 78

Identifier/req/create-replace-delete/system-event
Included inRequirements class 7: /req/create-replace-delete
Conditions

The server implements Requirements Class “System Events”

A

The server SHALL support the CREATE operation at the SystemEvent resources endpoints defined by the following URI template:

  • {api_root}/systems/{sysId}/events

B

The server SHALL support the REPLACE and DELETE operations at the SystemEvent resource endpoints defined by the following URI template:

  • {api_root}/systems/{sysId}/events/{id}

  • {api_root}/systemEvents/{id}

C

The sysId parameter is the local identifier of the System resource the SystemEvent is (or will be) associated to.
The id parameter is the local identifier of the SystemEvent resource to replace or delete.

15.  Requirements Class “Update”

15.1.  Overview

Requirements class 8

Identifier/req/update
Target typeWeb API
Conformance classConformance class A.8: /conf/update
PrerequisitesRequirements class 7: /req/create-replace-delete
http://www.opengis.net/spec/ogcapi-features-4/1.0/req/update
Normative statementsRequirement 79: /req/update/datastream
Requirement 80: /req/update/datastream-update-schema
Requirement 81: /req/update/observation
Requirement 82: /req/update/observation-schema
Requirement 83: /req/update/controlstream
Requirement 84: /req/update/controlstream-update-schema
Requirement 85: /req/update/command
Requirement 86: /req/update/command-schema
Requirement 87: /req/update/command-status
Requirement 88: /req/update/command-result
Requirement 89: /req/update/feasibility
Requirement 90: /req/update/feasibility-status
Requirement 91: /req/update/feasibility-result
Requirement 92: /req/update/system-event

The “Update” requirements class specifies how instances of the resource types defined in this Standard are updated (i.e., patched) via a CS API endpoint.

All resources are updated using the UPDATE (HTTP PATCH) operation, as defined by the OGC API — Features — Part 4: Create, Replace, Update and Delete Standard.

OGC API — Features — Part 4: Create, Replace, Update and Delete uses the terms “resources endpoint” and “resource endpoint” to identify the paths where these operations are supported by the server. The following sections provide these endpoints for each resource type defined by the CS API Standard.

15.2.  DataStreams

Requirement 79

Identifier/req/update/datastream
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL support the UPDATE operation at the DataStream resources endpoints defined by the following URI templates:

  • {api_root}/systems/{sysId}/datastreams/{id}

  • {api_root}/datastreams/{id}

B

The sysId parameter is the local identifier of the System resource the DataStream is associated to.
The id parameter is the local identifier of the DataStream resource to update.

The following constraints must be implemented by the server.

Requirement 80

Identifier/req/update/datastream-update-schema
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL reject an UPDATE request on a DataStream resource that modifies the observation schema if the DataStream already has nested Observation resources.

15.3.  Observations

Requirement 81

Identifier/req/update/observation
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL support the UPDATE operation at the Observation resource endpoints defined by the following URI templates:

  • {api_root}/datastreams/{dsId}/observations/{id}

  • {api_root}/observations/{id}

B

The dsId parameter is the local identifier of the DataStream resource the Observation is associated to.
The id parameter is the local identifier of the Observation resource to update.

The following constraints must be implemented by the server.

Requirement 82

Identifier/req/update/observation-schema
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Datastreams Observations”

A

The server SHALL reject an Observation UPDATE request with HTTP status code 400 if the Observation representation is not valid with respect to the schema provided by the parent DataStream resource.

15.4.  Control Streams

Requirement 83

Identifier/req/update/controlstream
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the UPDATE operation at the ControlStream resource endpoints defined by the following URI templates:

  • {api_root}/systems/{sysId}/controlstreams/{id}

  • {api_root}/controlstreams/{id}

B

The sysId parameter is the local identifier of the System resource the ControlStream is associated to.
The id parameter is the local identifier of the ControlStream resource to update.

The following constraints must be implemented by the server.

Requirement 84

Identifier/req/update/controlstream-update-schema
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL reject an UPDATE request on a ControlStream resource that modifies the command schema if the ControlStream already has nested Command resources.

15.5.  Commands

Requirement 85

Identifier/req/update/command
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the UPDATE operation at the Command resource endpoints defined by the following URI templates:

  • {api_root}/controlstreams/{csId}/commands/{id}

  • {api_root}/commands/{id}

B

The csId parameter is the local identifier of the ControlStream resource the Command is associated to.
The id parameter is the local identifier of the Command resource to update.

The following constraints must be implemented by the server.

Requirement 86

Identifier/req/update/command-schema
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL reject an UPDATE request on a Command resource with HTTP status code 400 if the Command representation is not valid with respect to the schema provided by the parent ControlStream resource.

15.6.  Command Status

Requirement 87

Identifier/req/update/command-status
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the UPDATE operation at the CommandStatus resources endpoints defined by the following URI template:

  • {api_root}/commands/{cmdId}/status/{id}

B

The cmdId parameter is the local identifier of the Command resource the CommandStatus is associated to.
The id parameter is the local identifier of the CommandStatus resource to update.

15.7.  Command Results

Requirement 88

Identifier/req/update/command-result
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Control Streams Commands”

A

The server SHALL support the UPDATE operation at the CommandResult resources endpoints defined by the following URI template:

  • {api_root}/commands/{cmdId}/result/{id}

B

The cmdId parameter is the local identifier of the Command resource the CommandResult is associated to.
The id parameter is the local identifier of the CommandResult resource to update.

15.8.  Feasibility

Requirement 89

Identifier/req/update/feasibility
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Command Feasibility”

A

The server SHALL support the UPDATE operation at the Command resource endpoints defined by the following URI templates:

  • {api_root}/controlstreams/{csId}/feasibility/{id}

  • {api_root}/feasibility/{id}

B

The csId parameter is the local identifier of the ControlStream resource the Command is associated to.
The id parameter is the local identifier of the Feasibility resource to update.

15.9.  Feasibility Status

Requirement 90

Identifier/req/update/feasibility-status
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Command Feasibility”

A

The server SHALL support the UPDATE operation at the CommandStatus resources endpoints defined by the following URI template:

  • {api_root}/feasibility/{feasId}/status/{id}

B

The feasId parameter is the local identifier of the Feasibility resource the CommandStatus is associated to.
The id parameter is the local identifier of the CommandStatus resource to update.

15.10.  Feasibility Results

Requirement 91

Identifier/req/update/feasibility-result
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “Command Feasibility”

A

The server SHALL support the UPDATE operation at the CommandResult resources endpoints defined by the following URI template:

  • {api_root}/feasibility/{feasId}/result/{id}

B

The feasId parameter is the local identifier of the Feasibility resource the CommandResult is associated to.
The id parameter is the local identifier of the CommandResult resource to update.

15.11.  System Events

Requirement 92

Identifier/req/update/system-event
Included inRequirements class 8: /req/update
Conditions

The server implements Requirements Class “System Events”

A

The server SHALL support the UPDATE operation at the SystemEvent resources endpoints defined by the following URI template:

  • {api_root}/systems/{sysId}/events/{id}

  • {api_root}/systemEvents/{id}

B

The sysId parameter is the local identifier of the System resource the SystemEvent is associated to.
The id parameter is the local identifier of the SystemEvent resource to update.

16.  Requirements Classes for Encodings

16.1.  Requirements Class “JSON Encoding”

16.1.1.  Overview

Requirements class 9

Identifier/req/json
Target typeWeb API
Conformance classConformance class A.9: /conf/json
Prerequisitehttp://www.opengis.net/spec/SWE/3.0/req/json-record-components
Normative statementsRequirement 93: /req/json/mediatype-read
Requirement 94: /req/json/mediatype-write
Requirement 95: /req/json/datastream-schema
Requirement 96: /req/json/obsschema-schema
Requirement 97: /req/json/observation-schema
Requirement 98: /req/json/observation-constraints
Requirement 99: /req/json/controlstream-schema
Requirement 100: /req/json/commandschema-schema
Requirement 101: /req/json/command-schema
Requirement 102: /req/json/command-constraints
Requirement 103: /req/json/commandstatus-schema
Requirement 104: /req/json/commandresult-schema
Requirement 105: /req/json/commandresult-constraints
Requirement 106: /req/json/systemevent-schema

This requirements class defines general JSON encodings for all resource types defined in part 2.

16.1.2.  Media Type

The media type used to advertise support for this encoding is application/json.

Requirement 93

Identifier/req/json/mediatype-read
Included inRequirements class 9: /req/json
A

The server SHALL accept resource retrieval (read) requests with media type application/json for all resource types whose representation is specified in this requirements class.

B

The response to such request SHALL be encoded as specified in the clause corresponding to the resource type.

Requirement 94

Identifier/req/json/mediatype-write
Included inRequirements class 9: /req/json
Conditions

The server implements Requirements Class “Create/Replace/Delete”.

A

The server SHALL accept resource insertion (write) requests with media type application/json for all resource types whose representation is specified in this requirements class.

B

The resource representation provided in the request SHALL be encoded as specified in the clause corresponding to the resource type.

16.1.3.  DataStream Representation

Requirement 95

Identifier/req/json/datastream-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single DataStream resource SHALL be valid against the JSON schema dataStream.json.

B

A JSON document containing a collection of DataStream resources SHALL be valid against the JSON schema dataStreamCollection.json.

Example — A Datastream in JSON format

This is a simple datastream with a single observed property.

 

{
 
"id": "958tf25kjm2f6",
 
"name": "Indoor Thermometer 001 - Living Room Temperature",
 
"outputName": "temp",
 
"system@link": {
   
"href": "https://data.example.org/api/systems/123",
   
"uid": "urn:x-ogc:systems:001"
 
},
 
"featureOfInterest@link": {
   
"href": "https://data.example.org/api/collections/buildings/items/754",
   
"title": "My House"
 
},
 
"samplingFeature@link": {
   
"href": "https://data.example.org/api/samplingFeatures/4478",
   
"title": "Thermometer Sampling Point"
 
},
 
"phenomenonTime": [
   
"2020-06-29T14:32:00Z",
   
"2022-06-29T19:37:00Z"
 
],
 
"resultTime": [
   
"2020-06-29T14:32:00Z",
   
"2012-06-29T19:37:00Z"
 
],
 
"observedProperties": [
   
{
     
"definition": "http://mmisw.org/ont/cf/parameter/air_temperature",
     
"label": "Room Temperature",
     
"description": "Ambient air temperature measured inside the room"
   
}
 
],
 
"resultType": "measure",
 
"formats": [
   
"application/json",
   
"application/swe+json",
   
"application/swe+csv",
   
"application/x-protobuf"
 
],
 
"live": true,
 
"links": [
   
{
     
"rel" : "observations",
     
"href" : "https://data.example.org/api/datastreams/958tf25kjm2f6/observations",
     
"type" : "application/json"
   
}
 
]
}

16.1.4.  Observation Schema Representation

When using the application/json media type for observations, two separate schemas are provided to further describe the content of the observation result and parameters properties (the parameters schema is optional). Both schemas are provided as SWE Common data component tree in JSON format.

Requirement 96

Identifier/req/json/obsschema-schema
Included inRequirements class 9: /req/json
A

The Observation Schema resource for media type application/json SHALL be valid against the JSON schema observationSchemaJson.json.

Example — Example Observation Schemas for the JSON format

This is an example schema for scalar observations:

 

{
 
"obsFormat": "application/json",
 
"resultSchema": {
   
"name": "temp",
   
"type": "Quantity",
   
"definition": "http://mmisw.org/ont/cf/parameter/air_temperature",
   
"label": "Room Temperature",
   
"description": "Ambient air temperature measured inside the room",
   
"uom": {
     
"code": "Cel"
   
},
   
"nilValues": [
     
{ "reason": "http://www.opengis.net/def/nil/OGC/0/missing", "value": "NaN" },
     
{ "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": "-Infinity" },
     
{ "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": "+Infinity" }
   
]
 
}
}

This is an example schema for vector observations:

 

{
 
"obsFormat": "application/json",
 
"resultSchema": {
   
"name": "location",
   
"type": "Vector",
   
"label": "Platform Location",
   
"definition": "http://sensorml.com/ont/swe/property/Location",
   
"referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4979",
   
"coordinates": [
     
{
       
"name": "lat",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude",
       
"axisID": "Lat",
       
"label": "Geodetic Latitude",
       
"uom": {
         
"code": "deg"
       
}
     
},
     
{
       
"name": "lon",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/Longitude",
       
"axisID": "Lon",
       
"label": "Longitude",
       
"uom": {
         
"code": "deg"
       
}
     
},
     
{
       
"name": "h",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/HeightAboveEllipsoid",
       
"axisID": "h",
       
"label": "Ellipsoidal Height",
       
"uom": {
         
"code": "m"
       
}
     
}
   
]
 
}
}

This third example has an out-of-band PNG image as the result:

 

{
   
"obsFormat": "application/json",
   
"resultLink": {
       
"mediaType": "image/png"
   
}
 
}

NOTE:  All other observation properties are the same for all datastreams and thus described in the static schema provided in Clause 16.1.5.

16.1.5.  Observation Representation

Requirement 97

Identifier/req/json/observation-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single Observation resource SHALL be valid against the JSON schema observation.json.

B

A JSON document containing a collection of Observation resources SHALL be valid against the JSON schema observationCollection.json.

Requirement 98

Identifier/req/json/observation-constraints
Included inRequirements class 9: /req/json
Statement

The following constraints apply to Observation resources:

A

The value of the phenomenonTime and resultTime properties SHALL be expressed in the UTC time scale, with an optional time offset.

B

The value of the result property SHALL be encoded according to the schema of the parent DataStream. The schema is provided by the resultSchema property of the schema resource.

C

The value of the parameters property SHALL be encoded according to the parametersSchema of the parent DataStream.

D

See observationSchemaJson.json.

Example — Observations in JSON format

This is a simple observation with a scalar observed property, associated to the datastream of the example above.

 

{
 
"id": "1h6pmb3ntfmogfppknk9aefpvs",
 
"datastream@id": "958tf25kjm2f6",
 
"phenomenonTime": "2021-03-15T04:53:34Z",
 
"resultTime": "2021-03-15T04:53:34Z",
 
"result": 23.5
}

This second observation has a vector result type:

 

{
 
"id": "1125alnna75hafppknk9aefpvs",
 
"datastream@id": "1vf8i5ois38u8",
 
"phenomenonTime": "2021-03-15T04:53:34Z",
 
"resultTime": "2021-03-15T04:53:34Z",
 
"result": {
   
"lat": -86.5861,
   
"lon": 34.7304,
   
"alt": 183
 
}
}

This third observation has PNG image as a result type that is a PNG image encoded inline as a data: URL

 

{
 
"id": "fefaig45w46v5186d6w",
 
"datastream@id": "f44f85rrt",
 
"foi@id": "55f48g48th",
 
"phenomenonTime": "2023-04-03T18:45:23Z",
 
"resultTime": "2023-04-03T18:45:23Z",
 
"result@link": {
   
"href": "",
   
"title": "Inline PNG image",
   
"type": "image/png"
 
}
}

16.1.6.  ControlStream Representation

Requirement 99

Identifier/req/json/controlstream-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single ControlStream resource SHALL be valid against the JSON schema controlStream.json.

B

A JSON document containing a collection of ControlStream resources SHALL be valid against the JSON schema controlStreamCollection.json.

Example — A Control Stream in JSON format

This is a simple control stream for a camera accepting PTZ commands in JSON format.

 

{
 
"id": "hf62t0dotfd5k",
 
"name": "Garage Video Camera 001 - PTZ Control",
 
"inputName": "ptz",
 
"system@link": {
   
"href": "https://data.example.org/api/systems/4722256",
   
"uid": "urn:x-ogc:systems:CAM001",
   
"title": "Garage Video Camera 001"
 
},
 
"issueTime": [
   
"2012-06-29T14:32:34Z",
   
"2012-06-29T14:37:34Z"
 
],
 
"executionTime": [
   
"2012-06-29T14:32:34Z",
   
"2012-06-29T14:37:34Z"
 
],
 
"controlledProperties": [
   
{
     
"definition": "http://sensorml.com/ont/swe/property/PanAngle",
     
"label": "Pan Angle"
   
},
   
{
     
"definition": "http://sensorml.com/ont/swe/property/TiltAngle",
     
"label": "Tilt Angle"
   
},
   
{
     
"definition": "http://sensorml.com/ont/swe/property/ZoomFactor",
     
"label": "Zoom Factor"
   
}
 
],
 
"formats": [
   
"application/json"
 
],
 
"live": true,
 
"async": false,
 
"links": [
   
{
     
"rel": "commands",
     
"href": "https://data.example.org/api/controls/hf62t0dotfd5k/commands"
   
}
 
]
}

16.1.7.  Command Schema Representation

When using the application/json media type for commands, two separate schemas are provided to further describe the content of the parameters and result properties (the result schema is optional). Both schemas are provided as SWE Common data component tree in JSON format.

Requirement 100

Identifier/req/json/commandschema-schema
Included inRequirements class 9: /req/json
A

The Command Schema resource for media type application/json SHALL be valid against the JSON schema commandSchemaJson.json.

Example — Example Command Schemas for the JSON format

This is an example schema for PTZ commands:

 

{
 
"commandFormat": "application/json",
 
"parametersSchema": {
   
"type": "DataRecord",
   
"fields": [
     
{
       
"name": "pan",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/PanAngle",
       
"label": "Pan Angle",
       
"description": "Rotation of the camera around its vertical axis (i.e., causing the image to translate along its horizontal axis)",
       
"uom": {
         
"code": "deg"
       
}
     
},
     
{
       
"name": "tilt",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/PanAngle",
       
"label": "Pan Angle",
       
"description": "Rotation of the camera around its horizontal axis (i.e., causing the image to translate along its vertical axis)",
       
"uom": {
         
"code": "deg"
       
}
     
},
     
{
       
"name": "zoom",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/ZoomFactor",
       
"label": "Zoom Factor",
       
"description": "Amount of zoom, 0 being the highest FOV and 100 being the lowest",
       
"uom": {
         
"code": "%"
       
}
     
}
   
]
 
}
}

NOTE:  All other command properties are the same for all control streams and thus described in the static schema provided in Clause 16.1.8.

16.1.8.  Command Representation

Requirement 101

Identifier/req/json/command-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single Command resource SHALL be valid against the JSON schema command.json.

B

A JSON document containing a collection of Command resources SHALL be valid against the JSON schema commandCollection.json.

Requirement 102

Identifier/req/json/command-constraints
Included inRequirements class 9: /req/json
Statement

The following constraints apply to Command resources:

A

The value of the issueTime and executionTime properties SHALL be expressed in the UTC time scale, with an optional time offset.

B

The value of the parameters property SHALL be encoded according to the schema of the parent ControlStream. The schema is provided by the parametersSchema property of the schema resource.

C

See commandSchemaJson.json.

Example — Command in JSON format

This is an example command used to task a PTZ camera, encoded in JSON format:

 

{
 
"id": "1125alnna75hafppknk9aefpvs",
 
"controlstream@id": "hf62t0dotfd5k",
 
"sender": "user01",
 
"issueTime": "2021-03-15T04:53:34.248Z",
 
"executionTime": [
   
"2021-03-15T04:53:34.543Z",
   
"2021-03-15T04:53:36.021Z"
 
],
 
"currentStatus": "COMPLETED",
 
"parameters": {
   
"pan": -10.0,
   
"tilt": 23.0,
   
"zoom": 0.4
 
}
}

16.1.9.  Command Status Representation

Requirement 103

Identifier/req/json/commandstatus-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single CommandStatus resource SHALL be valid against the JSON schema commandStatus.json.

B

A JSON document containing a collection of CommandStatus resources SHALL be valid against the JSON schema commandStatusCollection.json.

Example — Command Status in JSON format

These are example command status reports, encoded in JSON format:

 

{
 
"id": "rlg2905142qs5uvish4vktotffds2iss8aa0a00",
 
"command@id": "1125alnna75hafppknk9aefpvs",
 
"reportTime": "2021-03-15T04:53:34.348Z",
 
"statusCode": "ACCEPTED"
}

 

{
 
"id": "155rufq7aplr8id10839fc8d6u0ulqfu1bjfumo",
 
"command@id": "1125alnna75hafppknk9aefpvs",
 
"reportTime": "2021-03-15T04:53:36.021Z",
 
"statusCode": "COMPLETED",
 
"message": "Camera moved to new position"
}

16.1.10.  Command Result Representation

Requirement 104

Identifier/req/json/commandresult-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single CommandResult resource SHALL be valid against the JSON schema commandResult.json.

B

A JSON document containing a collection of CommandResult resources SHALL be valid against the JSON schema commandResultCollection.json.

Requirement 105

Identifier/req/json/commandresult-constraints
Included inRequirements class 9: /req/json
A

If a CommandResult resource includes inline data, the content of the data property SHALL be encoded according to the schema provided by the parent ControlStream:

B

For regular commands, the schema is provided by the the resultSchema property of the schema resource.

C

For feasibility requests (i.e., commands received on a feasibility channel), the schema is provided by the the feasibilityResultSchema property of the schema resource.

D

See commandSchemaJson.json.

Example — Command Result in JSON format

These are example command results, encoded in JSON format:

 

{
 
"data": {
   
"mean": "10.51",
   
"stdev": "1.23"
 
}
}

 

{
 
"observation@link": {
   
"href": "https://data.example.org/api/observations/gss45sdf413s387g49445ssdf55?f=json",
   
"title": "Satellite Image",
   
"type": "application/json"
 
}
}

 

{
 
"datastream@link": {
   
"href": "https://data.example.org/api/datastreams/445ssdf55",
   
"title": "Plume Simulation Data",
   
"type": "application/json"
 
}
}

16.1.11.  System Event Representation

Requirement 106

Identifier/req/json/systemevent-schema
Included inRequirements class 9: /req/json
A

A JSON document containing a single SystemEvent resource SHALL be valid against the JSON schema systemEvent.json.

B

A JSON document containing a collection of SystemEvent resources SHALL be valid against the JSON schema systemEventCollection.json.

16.2.  Requirements Class “SWE Common JSON Encoding”

16.2.1.  Overview

This requirements class defines JSON encodings for Observation and Command resources based on SWE Common 3.0.

16.2.2.  Media Type

NOTE:  Implementations should use application/vnd.ogc.swe+json as a preliminary media type until the SWE Common 3.0 Standard is stable to avoid confusing future implementations accessing JSON documents from draft versions of the Standard. The media type application/swe+json will be registered for SWE Common JSON encoding, if and once this Standard is approved by the OGC Members. This note will be removed before publishing this Standard.

The media type used when using the SWE Common JSON encoding is application/swe+json.

Requirement 107

Identifier/req/swecommon-json/mediatype-read
Included inRequirements class 10: /req/swecommon-json
A

The server SHALL accept resource retrieval (read) requests with media type application/swe+json for all resource types whose representation is specified in this requirements class.

B

The response to such request SHALL be encoded as specified in the clause corresponding to the resource type.

Requirement 108

Identifier/req/swecommon-json/mediatype-write
Included inRequirements class 10: /req/swecommon-json
Conditions

The server implements Requirements Class “Create/Replace/Delete”.

A

The server SHALL accept resource insertion (write) requests with media type application/swe+json for all resource types whose representation is specified in this requirements class.

B

The resource representation provided in the request SHALL be encoded as specified in the clause corresponding to the resource type.

16.2.3.  Observation Schema Representation

The observation schema for the application/swe+json media type is a SWE Common data component tree provided in JSON format.

Requirement 109

Identifier/req/swecommon-json/obsschema-schema
Included inRequirements class 10: /req/swecommon-json
A

The Observation Schema resource for media type application/swe+json SHALL be valid against the JSON schema observationSchemaSwe.json.

B

The encoding property SHALL be set to a JSONEncoding object.

Requirement 110

Identifier/req/swecommon-json/obsschema-mapping
Included inRequirements class 10: /req/swecommon-json
A

The recordSchema property SHALL include at least one Time component corresponding to either resultTime or phenomenonTime. This Time component SHALL be identified using one of the following URIs as the definition property.

For phenomenonTime:
http://www.w3.org/ns/sosa/phenomenonTime, or
http://www.opengis.net/def/property/OGC/0/SamplingTime

For resultTime:
http://www.w3.org/ns/sosa/resultTime

B

If the recordSchema property includes a reference to a sampling feature, a Text component SHALL be used.

The component SHALL be identified using the following URI as the definition property:
http://www.w3.org/ns/sosa/FeatureOfInterest

The value of the component SHALL be the local identifier of the SamplingFeature resource.

16.2.4.  Observation Representation

Requirement 111

Identifier/req/swecommon-json/observation-encoding
Included inRequirements class 10: /req/swecommon-json
A

Observation resources SHALL be encoded according to the schema provided by the parent DataStream, using the encoding rules defined in Clause 10.2: Requirements Class: JSON Encoding Rules of SWE Common 3.0.

16.2.5.  Command Schema Representation

The command schema for the application/swe+json media type is a SWE Common data component tree provided in JSON format.

Requirement 112

Identifier/req/swecommon-json/cmdschema-schema
Included inRequirements class 10: /req/swecommon-json
A

The Command Schema resource for media type application/swe+json SHALL be valid against the JSON schema commandSchemaSwe.json.

B

The encoding property SHALL be set to a JSONEncoding object.

Requirement 113

Identifier/req/swecommon-json/cmdschema-mapping
Included inRequirements class 10: /req/swecommon-json
A

If the recordSchema property includes a timestamp to be mapped to the issueTime property of the CommandResource, a Time component SHALL be used.

The component SHALL be identified using the following URI as the definition property:
http://www.opengis.net/def/property/OGC/0/IssueTime

B

If the recordSchema property includes a reference to a sampling feature, a Text component SHALL be used.

The component SHALL be identified using the following URI as the definition property:
http://www.w3.org/ns/sosa/FeatureOfInterest

The value of the component SHALL be the local identifier of the SamplingFeature resource.

16.2.6.  Command Representation

Requirement 114

Identifier/req/swecommon-json/command-encoding
Included inRequirements class 10: /req/swecommon-json
A

Command resources SHALL be encoded according to the schema provided by the parent ControlStream, using the encoding rules defined in Clause 10.2: Requirements Class: JSON Encoding Rules of SWE Common 3.0.

16.3.  Requirements Class “SWE Common Text Encoding”

16.3.1.  Overview

This requirements class defines text encodings (delimiter separated values, or DSV) for Observation and Command resources based on the Text Encoding defined in the SWE Common 3.0 Standard.

16.3.2.  Media Type

NOTE:  Implementations should use application/vnd.ogc.swe+text as a preliminary media type until the SWE Common 3.0 Standard is stable to avoid confusing future implementations accessing JSON documents from draft versions of the Standard. The media type application/swe+text will be registered for SWE Common Text encoding, if and once this Standard is approved by the OGC Members. This note will be removed before publishing this Standard.

The media type used when using the SWE Common Text encoding is application/swe+text.

Requirement 115

Identifier/req/swecommon-text/mediatype-read
Included inRequirements class 11: /req/swecommon-text
A

The server SHALL accept resource retrieval (read) requests with media type application/swe+text for all resource types whose representation is specified in this requirements class.

B

The response to such request SHALL be encoded as specified in the clause corresponding to the resource type.

Requirement 116

Identifier/req/swecommon-text/mediatype-write
Included inRequirements class 11: /req/swecommon-text
Conditions

The server implements Requirements Class “Create/Replace/Delete”.

A

The server SHALL accept resource insertion (write) requests with media type application/swe+text for all resource types whose representation is specified in this requirements class.

B

The resource representation provided in the request SHALL be encoded as specified in the clause corresponding to the resource type.

16.3.3.  Observation Schema Representation

The observation schema for the application/swe+text media type is a SWE Common data component tree provided in JSON format.

Requirement 117

Identifier/req/swecommon-text/obsschema-schema
Included inRequirements class 11: /req/swecommon-text
A

The Observation Schema resource for media type application/swe+text SHALL be valid against the JSON schema observationSchemaSwe.json.

B

The encoding property SHALL be set to a TextEncoding object.

Requirement 118

Identifier/req/swecommon-text/obsschema-mapping
Included inRequirements class 11: /req/swecommon-text
Statement

The recordSchema property SHALL fulfill Requirement 110: /req/swecommon-json/obsschema-mapping.

16.3.4.  Observation Representation

Requirement 119

Identifier/req/swecommon-text/observation-encoding
Included inRequirements class 11: /req/swecommon-text
A

Observation resources SHALL be encoded according to the schema provided by the parent DataStream, using the encoding rules defined in Clause 10.3: Requirements Class: Text Encoding Rules of SWE Common 3.0.

16.3.5.  Command Schema Representation

The command schema for the application/swe+text media type is a SWE Common data component tree provided in JSON format.

Requirement 120

Identifier/req/swecommon-text/cmdschema-schema
Included inRequirements class 11: /req/swecommon-text
A

The Command Schema resource for media type application/swe+text SHALL be valid against the JSON schema commandSchemaSwe.json.

B

The encoding property SHALL be set to a TextEncoding object.

Requirement 121

Identifier/req/swecommon-text/cmdschema-mapping
Included inRequirements class 11: /req/swecommon-text
Statement

The recordSchema property SHALL fulfill Requirement 113: /req/swecommon-json/cmdschema-mapping.

16.3.6.  Command Representation

Requirement 122

Identifier/req/swecommon-text/command-encoding
Included inRequirements class 11: /req/swecommon-text
A

Command resources SHALL be encoded according to the schema provided by the parent ControlStream, using the encoding rules defined in Clause 10.3: Requirements Class: Text Encoding Rules of SWE Common 3.0.

16.4.  Requirements Class “SWE Common Binary Encoding”

16.4.1.  Overview

This requirements class defines binary encodings of Observation and Command resources based on the Binary Encoding defined in the SWE Common 3.0 Standard.

The main objective of this encoding is better data size efficiency than text or JSON, thus allowing for:

  • Transfer of observations and commands over very low power / low bandwidth network links (e.g., LoRa, etc.); and

  • Transfer high bandwidth data sets such as raster data (e.g., video, LiDAR, etc.).

For even better efficiency, this encoding can be combined with a transport protocol such as MQTT.

16.4.2.  Media Type

NOTE:  Implementations should use application/vnd.ogc.swe+binary as a preliminary media type until the SWE Common 3.0 Standard is stable to avoid confusing future implementations accessing JSON documents from draft versions of the Standard. The media type application/swe+binary will be registered for SWE Common binary encoding, if and once this Standard is approved by the OGC Members. This note will be removed before publishing this Standard.

The media type used when using the SWE Common Text encoding is application/swe+binary.

Requirement 123

Identifier/req/swecommon-binary/mediatype-read
Included inRequirements class 12: /req/swecommon-binary
A

The server SHALL accept resource retrieval (read) requests with media type application/swe+binary for all resource types whose representation is specified in this requirements class.

B

The response to such request SHALL be encoded as specified in the clause corresponding to the resource type.

Requirement 124

Identifier/req/swecommon-binary/mediatype-write
Included inRequirements class 12: /req/swecommon-binary
Conditions

The server implements Requirements Class “Create/Replace/Delete”.

A

The server SHALL accept resource insertion (write) requests with media type application/swe+binary for all resource types whose representation is specified in this requirements class.

B

The resource representation provided in the request SHALL be encoded as specified in the clause corresponding to the resource type.

16.4.3.  Observation Schema Representation

The observation schema for the application/swe+binary media type is a SWE Common data component tree provided in JSON format.

Requirement 125

Identifier/req/swecommon-binary/obsschema-schema
Included inRequirements class 12: /req/swecommon-binary
A

The Observation Schema resource for media type application/swe+binary SHALL be valid against the JSON schema observationSchemaSwe.json.

B

The encoding property SHALL be set to a BinaryEncoding object.

Requirement 126

Identifier/req/swecommon-binary/obsschema-mapping
Included inRequirements class 12: /req/swecommon-binary
Statement

The recordSchema property SHALL fulfill Requirement 110: /req/swecommon-json/obsschema-mapping.

16.4.4.  Observation Representation

Requirement 127

Identifier/req/swecommon-binary/observation-encoding
Included inRequirements class 12: /req/swecommon-binary
A

Observation resources SHALL be encoded according to the schema provided by the parent DataStream, using the encoding rules defined in Clause 10.4: Requirements Class: Binary Encoding Rules of SWE Common 3.0.

16.4.5.  Command Schema Representation

The command schema for the application/swe+binary media type is a SWE Common data component tree provided in JSON format.

Requirement 128

Identifier/req/swecommon-binary/cmdschema-schema
Included inRequirements class 12: /req/swecommon-binary
A

The Command Schema resource for media type application/swe+binary SHALL be valid against the JSON schema commandSchemaSwe.json.

B

The encoding property SHALL be set to a BinaryEncoding object.

Requirement 129

Identifier/req/swecommon-binary/cmdschema-mapping
Included inRequirements class 12: /req/swecommon-binary
Statement

The recordSchema property SHALL fulfill Requirement 113: /req/swecommon-json/cmdschema-mapping.

16.4.6.  Command Representation

Requirement 130

Identifier/req/swecommon-binary/command-encoding
Included inRequirements class 12: /req/swecommon-binary
A

Command resources SHALL be encoded according to the schema provided by the parent ControlStream, using the encoding rules defined in Clause 10.4: Requirements Class: Binary Encoding Rules of SWE Common 3.0.


Annex A
(normative)
Conformance Class Abstract Test Suite

A.1.  Conformance Class “Common”

Conformance class A.1

Identifier/conf/api-common
Requirements classRequirements class 1: /req/api-common
Prerequisitehttp://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common
Target TypeWeb API
Conformance testsAbstract test A.1: /conf/api-common/resources
Abstract test A.2: /conf/api-common/resource-collection

Abstract test A.1

Identifier/conf/api-common/resources
RequirementRequirement 1: /req/api-common/resources
Test purpose

No test required for this requirement as it is tested in other classes.

Abstract test A.2

Identifier/conf/api-common/resource-collection
RequirementRequirement 2: /req/api-common/resource-collection
Test purpose

Verify that resource collections are implemented like feature collections.

Test method
  1. For each resource collection available on the server with the property itemType that is NOT set to feature:

    1. Execute the following tests from OGC API — Features — Part 1: Core:

      • /conf/core/fc-md-links

      • /conf/core/fc-md-items

      • /conf/core/fc-md-items-links

      • /conf/core/fc-md-extent

      • /conf/core/sfc-md-op

      • /conf/core/sfc-md-success

      • /conf/core/fc-op

      • /conf/core/fc-limit-definition

      • /conf/core/fc-limit-response

      • /conf/core/query-param-invalid

      • /conf/core/query-param-unknown

      • /conf/core/fc-links

      • /conf/core/fc-timeStamp

      • /conf/core/fc-numberMatched

      • /conf/core/fc-numberReturned

      • /conf/core/f-op

      • /conf/core/f-success

      • /conf/core/f-links

A.2.  Conformance Class “Datastreams & Observations”

Conformance class A.2

Identifier/conf/datastream
Requirements classRequirements class 2: /req/datastream
PrerequisiteConformance class A.1: /conf/api-common
Target TypeWeb API
Conformance testsAbstract test A.3: /conf/datastream/sf-ref-from-datastream
Abstract test A.4: /conf/datastream/foi-ref-from-datastream
Abstract test A.5: /conf/datastream/canonical-url
Abstract test A.6: /conf/datastream/resources-endpoint
Abstract test A.7: /conf/datastream/canonical-endpoint
Abstract test A.8: /conf/datastream/ref-from-system
Abstract test A.9: /conf/datastream/ref-from-deployment
Abstract test A.10: /conf/datastream/collections
Abstract test A.11: /conf/datastream/schema-op
Abstract test A.12: /conf/datastream/obs-canonical-url
Abstract test A.13: /conf/datastream/obs-resources-endpoint
Abstract test A.14: /conf/datastream/obs-canonical-endpoint
Abstract test A.15: /conf/datastream/obs-ref-from-datastream
Abstract test A.16: /conf/datastream/obs-collections

Abstract test A.3

Identifier/conf/datastream/sf-ref-from-datastream
RequirementRequirement 3: /req/datastream/sf-ref-from-datastream
Test purpose

Validate that Sampling Features associated to a given datastream are available as sub-resources.

Test method
  1. Retrieve all DataStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=datastreams.

  2. For each DataStream resource in the response:

    1. Validate that the server implements an Sampling Features resources endpoint at path {api_root}/datastreams/{dsId}/samplingFeatures using test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/sf/resources-endpoint, where dsId is the local ID of the DataStream resource.

Abstract test A.4

Identifier/conf/datastream/foi-ref-from-datastream
RequirementRequirement 4: /req/datastream/foi-ref-from-datastream
Test purpose

Validate that Features of Interest associated to a given datastream are available as sub-resources.

Test method
  1. Retrieve all DataStream resources by executing test {part1-spec}/conf/api-common/canonical-resources with parameter resource-type=datastreams.

  2. For each DataStream resource in the response:

    1. Issue an HTTP GET request at path {api_root}/datastreams/{dsId}/featuresOfInterest, where dsId is the local ID of the DataStream resource.

    2. Validate that a document was returned with a status code 200.

    3. Iterate through the list of resources in the response, following next links as appropriate.

    4. If the response content type is application/geo+json, validate the response using the GeoJSON schema.

Abstract test A.5

Identifier/conf/datastream/canonical-url
RequirementRequirement 5: /req/datastream/canonical-url
Test purpose

Validate that every DataStream resource is accessible via its canonical URL.

Test method

For every collection advertised by the server with the itemType property set to DataStream:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. For each item, check that a link with relation type canonical is included.

  3. Dereference this link and validate that a document is returned with a status code 200.

  4. Check that the returned document has the same content as the resource originally included in the collection items (except for the canonical link).

Abstract test A.6

Identifier/conf/datastream/resources-endpoint
RequirementRequirement 6: /req/datastream/resources-endpoint
Test purpose

Validate that the server implements a DataStream resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_datastream-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.7

Identifier/conf/datastream/canonical-endpoint
RequirementRequirement 7: /req/datastream/canonical-endpoint
Test purpose

Validate that the server exposes the canonical DataStream resources endpoint.

Test method

Validate that the server implements a DataStream resources endpoint at path {api_root}/datastreams using test _conf_datastream_resources-endpoint.

Abstract test A.8

Identifier/conf/datastream/ref-from-system
RequirementRequirement 8: /req/datastream/ref-from-system
Test purpose

Validate that DataStream resources associated to a System are available as sub-resources.

Test method
  1. Retrieve all System resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=systems.

  2. For each System resource in the response:

    1. Validate that the server implements a DataStream resources endpoint at path {api_root}/systems/{sysId}/datastreams using test _conf_datastream_resources-endpoint, where sysId is the local ID of the System resource.

Abstract test A.9

Identifier/conf/datastream/ref-from-deployment
RequirementRequirement 9: /req/datastream/ref-from-deployment
Test purpose

Validate that DataStream resources associated to a Deployment are available as sub-resources.

Test method
  1. Retrieve all Deployment resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=deployments.

  2. For each Deployment resource in the response:

    1. Validate that the server implements a DataStream resources endpoint at path {api_root}/deployments/{depId}/datastreams using test _conf_datastream_resources-endpoint, where depId is the local ID of the Deployment resource.

Abstract test A.10

Identifier/conf/datastream/collections
RequirementRequirement 10: /req/datastream/collections
Test purpose

Validate that DataStream collections are tagged with the proper item type.

Test method

For every collection advertised by the server with the itemType property set to DataStream:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_datastream-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.11

Identifier/conf/datastream/schema-op
RequirementRequirement 11: /req/datastream/schema-op
Test purpose

Validate that every DataStream resource has a schema sub-resource.

Test method
  1. Retrieve all DataStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=datastreams.

  2. For each DataStream resource in the response:

    1. Retrieve the list of supported observation formats listed in the DataStream resource.

    2. For each supported observation format:

      <classification> <tag>step:</tag> <value><p semx-id="_9cca03f7-2168-f693-7f02-188aab6ca26c" original-id="_9cca03f7-2168-f693-7f02-188aab6ca26c">Issue an HTTP GET request at path <tt>{api_root}/datastreams/{dsId}/schema?obsFormat={format}</tt>, where <tt>dsId</tt> is the local ID of the <tt>DataStream</tt> resource, and <tt>format</tt> is one of the supported formats.</p> <dl semx-id="_2ff30dc7-f968-c9e0-17c9-127b76072a0c" original-id="_2ff30dc7-f968-c9e0-17c9-127b76072a0c"><dt>step:</dt> <dd><p semx-id="_8ee5b4fa-8e63-3006-06a3-96da5d0d7f21" original-id="_8ee5b4fa-8e63-3006-06a3-96da5d0d7f21">Validate that a document was returned with a status code 200.</p> </dd> </dl> </value> </classification>

Abstract test A.12

Identifier/conf/datastream/obs-canonical-url
RequirementRequirement 12: /req/datastream/obs-canonical-url
Test purpose

Validate that every Observation resource is accessible via its canonical URL.

Test method

For every collection advertised by the server with the itemType property set to Observation:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. For each item, check that a link with relation type canonical is included.

  3. Dereference this link and validate that a document is returned with a status code 200.

  4. Check that the returned document has the same content as the resource originally included in the collection items (except for the canonical link).

Abstract test A.13

Identifier/conf/datastream/obs-resources-endpoint
RequirementRequirement 13: /req/datastream/obs-resources-endpoint
Test purpose

Validate that the server implements a Observation resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_observation-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.14

Identifier/conf/datastream/obs-canonical-endpoint
RequirementRequirement 14: /req/datastream/obs-canonical-endpoint
Test purpose

Validate that the server exposes the canonical Observation resources endpoint.

Test method

Validate that the server implements an Observation resources endpoint at path {api_root}/observations using test _conf_datastream_obs-resources-endpoint.

Abstract test A.15

Identifier/conf/datastream/obs-ref-from-datastream
RequirementRequirement 15: /req/datastream/obs-ref-from-datastream
Test purpose

Validate that Observation resources associated to a DataStream are available as sub-resources.

Test method
  1. Retrieve all DataStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=datastreams.

  2. For each DataStream resource in the response:

    1. Validate that the server implements an Observation resources endpoint at path {api_root}/datastreams/{dsId}/observations using test _conf_datastream_obs-resources-endpoint, where dsId is the local ID of the DataStream resource.

Abstract test A.16

Identifier/conf/datastream/obs-collections
RequirementRequirement 16: /req/datastream/obs-collections
Test purpose

Validate that Observation collections are tagged with the proper item type.

Test method

For every collection advertised by the server with the itemType property set to Observation:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_observation-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

A.3.  Conformance Class “Control Streams & Commands”

Abstract test A.17

Identifier/conf/controlstream/sf-ref-from-controlstream
RequirementRequirement 17: /req/controlstream/sf-ref-from-controlstream
Test purpose

Validate that Sampling Features associated to a given control stream are available as sub-resources.

Test method
  1. Retrieve all ControlStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=controlstreams.

  2. For each ControlStream resource in the response:

    1. Validate that the server implements an Sampling Features resources endpoint at path {api_root}/controlstreams/{dsId}/samplingFeatures using test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/sf/resources-endpoint, where dsId is the local ID of the ControlStream resource.

Abstract test A.18

Identifier/conf/controlstream/foi-ref-from-controlstream
RequirementRequirement 18: /req/controlstream/foi-ref-from-controlstream
Test purpose

Validate that Features of Interest associated to a given control stream are available as sub-resources.

Test method
  1. Retrieve all controlstream resources by executing test {part1-spec}/conf/api-common/canonical-resources with parameter resource-type=controlstreams.

  2. For each ControlStream resource in the response:

    1. Issue an HTTP GET request at path {api_root}/controlstreams/{dsId}/featuresOfInterest, where dsId is the local ID of the ControlStream resource.

    2. Validate that a document was returned with a status code 200.

    3. Iterate through the list of resources in the response, following next links as appropriate.

    4. If the response content type is application/geo+json, validate the response using the GeoJSON schema.

Abstract test A.19

Identifier/conf/controlstream/canonical-url
RequirementRequirement 19: /req/controlstream/canonical-url
Test purpose

Validate that every ControlStream resource is accessible via its canonical URL.

Test method

For every collection advertised by the server with the itemType property set to ControlStream:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. For each item, check that a link with relation type canonical is included.

  3. Dereference this link and validate that a document is returned with a status code 200.

  4. Check that the returned document has the same content as the resource originally included in the collection items (except for the canonical link).

Abstract test A.20

Identifier/conf/controlstream/resources-endpoint
RequirementRequirement 20: /req/controlstream/resources-endpoint
Test purpose

Validate that the server implements a ControlStream resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_controlstream-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.21

Identifier/conf/controlstream/canonical-endpoint
RequirementRequirement 21: /req/controlstream/canonical-endpoint
Test purpose

Validate that the server exposes the canonical ControlStream resources endpoint.

Test method

Validate that the server implements a ControlStream resources endpoint at path {api_root}/controlstreams using test _conf_controlstream_resources-endpoint.

Abstract test A.22

Identifier/conf/controlstream/ref-from-system
RequirementRequirement 22: /req/controlstream/ref-from-system
Test purpose

Validate that ControlStream resources associated to a System are available as sub-resources.

Test method
  1. Retrieve all System resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=systems.

  2. For each System resource in the response:

    1. Validate that the server implements a ControlStream resources endpoint at path {api_root}/systems/{sysId}/controlstreams using test _conf_controlstream_resources-endpoint, where sysId is the local ID of the System resource.

Abstract test A.23

Identifier/conf/controlstream/ref-from-deployment
RequirementRequirement 23: /req/controlstream/ref-from-deployment
Test purpose

Validate that ControlStream resources associated to a Deployment are available as sub-resources.

Test method
  1. Retrieve all Deployment resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=deployments.

  2. For each Deployment resource in the response:

    1. Validate that the server implements a ControlStream resources endpoint at path {api_root}/deployments/{depId}/controlstreams using test _conf_controlstream_resources-endpoint, where depId is the local ID of the Deployment resource.

Abstract test A.24

Identifier/conf/controlstream/collections
RequirementRequirement 24: /req/controlstream/collections
Test purpose

Validate that ControlStream collections are tagged with the proper item type.

Test method

For every collection advertised by the server with the itemType property set to ControlStream:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_controlstream-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.25

Identifier/conf/controlstream/schema-op
RequirementRequirement 25: /req/controlstream/schema-op
Test purpose

Validate that every ControlStream resource has a schema sub-resource.

Test method
  1. Retrieve all ControlStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=controlstreams.

  2. For each ControlStream resource in the response:

    1. Retrieve the list of supported command formats listed in the ControlStream resource.

    2. For each supported command format:

      <classification> <tag>step:</tag> <value><p semx-id="_7c37ef60-3bc6-bcd1-5cbe-bb644fb2f469" original-id="_7c37ef60-3bc6-bcd1-5cbe-bb644fb2f469">Issue an HTTP GET request at path <tt>{api_root}/controlstreams/{dsId}/schema?cmdFormat={format}</tt>, where <tt>dsId</tt> is the local ID of the <tt>ControlStream</tt> resource, and <tt>format</tt> is one of the supported formats.</p> <dl semx-id="_f7aecef0-541f-72a8-98fb-66a0e9fa672f" original-id="_f7aecef0-541f-72a8-98fb-66a0e9fa672f"><dt>step:</dt> <dd><p semx-id="_674cb2e6-15a2-79e1-4e9e-10c15e518d3e" original-id="_674cb2e6-15a2-79e1-4e9e-10c15e518d3e">Validate that a document was returned with a status code 200.</p> </dd> </dl> </value> </classification>

Abstract test A.26

Identifier/conf/controlstream/cmd-canonical-url
RequirementRequirement 26: /req/controlstream/cmd-canonical-url
Test purpose

Validate that every Command resource is accessible via its canonical URL.

Test method

For every collection advertised by the server with the itemType property set to Command:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. For each item, check that a link with relation type canonical is included.

  3. Dereference this link and validate that a document is returned with a status code 200.

  4. Check that the returned document has the same content as the resource originally included in the collection items (except for the canonical link).

Abstract test A.27

Identifier/conf/controlstream/cmd-resources-endpoint
RequirementRequirement 27: /req/controlstream/cmd-resources-endpoint
Test purpose

Validate that the server implements a Command resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_command-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.28

Identifier/conf/controlstream/cmd-canonical-endpoint
RequirementRequirement 28: /req/controlstream/cmd-canonical-endpoint
Test purpose

Validate that the server exposes the canonical Command resources endpoint.

Test method

Validate that the server implements a Command resources endpoint at path {api_root}/commands using test _conf_controlstream_cmd-resources-endpoint.

Abstract test A.29

Identifier/conf/controlstream/cmd-ref-from-controlstream
RequirementRequirement 29: /req/controlstream/cmd-ref-from-controlstream
Test purpose

Validate that Command resources associated to a ControlStream are available as sub-resources.

Test method
  1. Retrieve all ControlStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=controlstreams.

  2. For each ControlStream resource in the response:

    1. Validate that the server implements a Command resources endpoint at path {api_root}/controlstreams/{dsId}/commands using test _conf_controlstream_cmd-resources-endpoint, where dsId is the local ID of the ControlStream resource.

Abstract test A.30

Identifier/conf/controlstream/cmd-collections
RequirementRequirement 30: /req/controlstream/cmd-collections
Test purpose

Validate that Command collections are tagged with the proper item type.

Test method

For every collection advertised by the server with the itemType property set to Command:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_command-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.31

Identifier/conf/controlstream/status-resources-endpoint
RequirementRequirement 31: /req/controlstream/status-resources-endpoint
Test purpose

Validate that the server implements a CommandStatus resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_commandstatus-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.32

Identifier/conf/controlstream/command-status-endpoint
RequirementRequirement 32: /req/controlstream/command-status-endpoint
Test purpose

Validate that every Command resource has a status endpoint

Test method
  1. Retrieve all Command resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=commands.

  2. For each Command resource in the response:

    1. Validate that the server implements a Command Status resources endpoint at path {api_root}/commands/{cmdId}/status using test _conf_controlstream_status-resources-endpoint, where cmdId is the local ID of the Command resource.

Abstract test A.33

Identifier/conf/controlstream/result-resources-endpoint
RequirementRequirement 33: /req/controlstream/result-resources-endpoint
Test purpose

Validate that the server implements a CommandResult resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_commandresult-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.34

Identifier/conf/controlstream/command-result-endpoint
RequirementRequirement 34: /req/controlstream/command-result-endpoint
Test purpose

Validate that every Command resource has a result endpoint

Test method
  1. Retrieve all Command resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=commands.

  2. For each Command resource in the response:

    1. Validate that the server implements a Command Result resources endpoint at path {api_root}/commands/{cmdId}/result using test _conf_controlstream_result-resources-endpoint, where cmdId is the local ID of the Command resource.

A.4.  Conformance Class “Command Feasibility”

Conformance class A.4

Identifier/conf/feasibility
Requirements classRequirements class 4: /req/feasibility
PrerequisiteConformance class A.3: /conf/controlstream
Target TypeWeb API
Conformance testsAbstract test A.35: /conf/feasibility/canonical-url
Abstract test A.36: /conf/feasibility/ref-from-controlstream
Abstract test A.37: /conf/feasibility/status-endpoint
Abstract test A.38: /conf/feasibility/result-endpoint
Abstract test A.39: /conf/feasibility/collections

Abstract test A.35

Identifier/conf/feasibility/canonical-url
RequirementRequirement 35: /req/feasibility/canonical-url
Test purpose

Validate that every Command resource is accessible via its canonical URL.

Test method

For every collection advertised by the server with the itemType property set to Command:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. For each item, check that a link with relation type canonical is included.

  3. Dereference this link and validate that a document is returned with a status code 200.

  4. Check that the returned document has the same content as the resource originally included in the collection items (except for the canonical link).

Abstract test A.36

Identifier/conf/feasibility/ref-from-controlstream
RequirementRequirement 36: /req/feasibility/ref-from-controlstream
Test purpose

Validate that Command resources associated to a ControlStream are available as sub-resources.

Test method
  1. Retrieve all ControlStream resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=controlstreams.

  2. For each ControlStream resource in the response:

    1. Validate that the server implements a Command resources endpoint at path {api_root}/controlstreams/{dsId}/commands using test _conf_controlstream_cmd-resources-endpoint, where dsId is the local ID of the ControlStream resource.

Abstract test A.37

Identifier/conf/feasibility/status-endpoint
RequirementRequirement 37: /req/feasibility/status-endpoint
Test purpose

Validate that every Feasibility resource has a status endpoint

Test method
  1. Retrieve all Feasibility resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=feasibility.

  2. For each Feasibility resource in the response:

    1. Validate that the server implements a Command Status resources endpoint at path {api_root}/feasibility/{cmdId}/status using test _conf_controlstream_status-resources-endpoint, where cmdId is the local ID of the Feasibility resource.

Abstract test A.38

Identifier/conf/feasibility/result-endpoint
RequirementRequirement 38: /req/feasibility/result-endpoint
Test purpose

Validate that every Feasibility resource has a result endpoint

Test method
  1. Retrieve all Feasibility resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=feasibility.

  2. For each Feasibility resource in the response:

    1. Validate that the server implements a Command Result resources endpoint at path {api_root}/feasibility/{cmdId}/result using test _conf_controlstream_result-resources-endpoint, where cmdId is the local ID of the Feasibility resource.

Abstract test A.39

Identifier/conf/feasibility/collections
RequirementRequirement 39: /req/feasibility/collections
Test purpose

Validate that Feasibility collections are tagged with the proper item type.

Test method

For every collection advertised by the server with the itemType property set to Feasibility:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_command-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

A.5.  Conformance Class “System Events”

Conformance class A.5

Identifier/conf/system-event
Requirements classRequirements class 5: /req/system-event
PrerequisitesConformance class A.1: /conf/api-common
http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/system
Target TypeWeb API
Conformance testsAbstract test A.40: /conf/system-event/canonical-url
Abstract test A.41: /conf/system-event/resources-endpoint
Abstract test A.42: /conf/system-event/canonical-endpoint
Abstract test A.43: /conf/system-event/ref-from-system
Abstract test A.44: /conf/system-event/collections

Abstract test A.40

Identifier/conf/system-event/canonical-url
RequirementRequirement 40: /req/system-event/canonical-url
Test purpose

Validate that every ControlStream resource is accessible via its canonical URL.

Test method

For every collection advertised by the server with the itemType property set to ControlStream:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. For each item, check that a link with relation type canonical is included.

  3. Dereference this link and validate that a document is returned with a status code 200.

  4. Check that the returned document has the same content as the resource originally included in the collection items (except for the canonical link).

Abstract test A.41

Identifier/conf/system-event/resources-endpoint
RequirementRequirement 41: /req/system-event/resources-endpoint
Test purpose

Validate that the server implements a SystemEvent resources endpoint correctly.
This is a parameterized test that requires the endpoint URL as a parameter

Test method
  1. Issue an HTTP GET request to the endpoint URL.

  2. Validate that a document was returned with a status code 200.

  3. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_systemevent-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

Abstract test A.42

Identifier/conf/system-event/canonical-endpoint
RequirementRequirement 42: /req/system-event/canonical-endpoint
Test purpose

Validate that the server exposes the canonical SystemEvent resources endpoint.

Test method

Validate that the server implements a System Event resources endpoint at path {api_root}/systemEvents using test _conf_controlstream_resources-endpoint.

Abstract test A.43

Identifier/conf/system-event/ref-from-system
RequirementRequirement 43: /req/system-event/ref-from-system
Test purpose

Validate that SystemEvent resources associated to a System are available as sub-resources.

Test method
  1. Retrieve all System resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=systems.

  2. For each System resource in the response:

    1. Validate that the server implements a System Event resources endpoint at path {api_root}/systems/{sysId}/systemEvents using test _conf_system-event_resources-endpoint, where sysId is the local ID of the System resource.

Abstract test A.44

Identifier/conf/system-event/collections
RequirementRequirement 44: /req/system-event/collections
Test purpose

Validate that SystemEvent collections are tagged with the proper item type.

Test method

For every collection advertised by the server with the itemType property set to SystemEvent:

  1. Retrieve the collection items as described in test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/collection-items.

  2. Validate that the contents of the returned document conform to the media type reported by the response Content-Type header.

    1. If the response content type is application/json, execute test _conf_json_systemevent-schema.

    2. For other response content types not supported by the testing engine, issue a warning and skip this test.

A.6.  Conformance Class “Advanced Filtering”

Abstract test A.45

Identifier/conf/advanced-filtering/datastream-by-phenomenontime
RequirementRequirement 45: /req/advanced-filtering/datastream-by-phenomenontime
Test purpose

Validate that the phenomenonTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/datastreams?phenomenonTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_datastream_resources-endpoint.

  3. For each DataStream resource in the response:

    1. Retrieve its phenomenonTime property.

    2. Verify that the value of the property intersects the time specified in the request.

Abstract test A.46

Identifier/conf/advanced-filtering/datastream-by-resulttime
RequirementRequirement 46: /req/advanced-filtering/datastream-by-resulttime
Test purpose

Validate that the resultTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/datastreams?resultTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_datastream_resources-endpoint.

  3. For each DataStream resource in the response:

    1. Retrieve its resultTime property.

    2. Verify that the value of the property intersects the time specified in the request.

Abstract test A.47

Identifier/conf/advanced-filtering/datastream-by-obsprop
RequirementRequirement 47: /req/advanced-filtering/datastream-by-obsprop
Test purpose

Validate that the observedProperty query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/datastreams?observedProperty={idList} where {idList} is a list of one or more local IDs of Property resources.
    See test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/advanced-filtering/id-list-schema

  2. Validate the response using the steps described in test _conf_datastream_resources-endpoint.

  3. For each DataStream resource in the response:

    1. Retrieve all observed properties listed in the DataStream resource.

    2. Verify that at least one of the collected properties has one of the identifiers included in {idList}.

  4. Repeat the previous steps with the observedProperty parameter set to a list of one or more URIs identifying observable properties.

Abstract test A.48

Identifier/conf/advanced-filtering/datastream-by-foi
RequirementRequirement 48: /req/advanced-filtering/datastream-by-foi
Test purpose

Validate that the foi query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/datastreams?foi={idList} where {idList} is a list of one or more local IDs of Sampling Feature or Feature resources.
    See test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/advanced-filtering/id-list-schema

  2. Validate the response using the steps described in test _conf_datastream_resources-endpoint.

  3. For each DataStream resource in the response:

    1. Retrieve the datastreams’s sampling features by issuing an HTTP GET request at {api_root}/datastreams/{dsId}/samplingFeatures.

    2. For each Sampling Feature resource in the returned collection:

      1. Follow the sampleOf links to retrieve the target features, recursively. If a link does not resolve or the link media type is not supported by the testing engine, use the link target as the identifier of the feature.

    3. Verify that at least one of the collected features has one of the identifiers included in {idList}.

  4. Repeat the previous steps with the foi parameter set to a list of one or more UIDs of Feature resources.

Abstract test A.49

Identifier/conf/advanced-filtering/obs-by-phenomenontime
RequirementRequirement 49: /req/advanced-filtering/obs-by-phenomenontime
Test purpose

Validate that the phenomenonTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/observations?phenomenonTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_datastream_obs-resources-endpoint.

  3. For each Observation resource in the response:

    1. Retrieve its phenomenonTime property.

    2. Verify that the value of the property intersects the time specified in the request.

  4. Repeat the steps above for every observation resources endpoint nested under a DataStream resource, that is at endpoints {api_root}/datastreams/{dsId}/observations where dsId is the local ID of a DataStream resource.

Abstract test A.50

Identifier/conf/advanced-filtering/obs-by-resulttime
RequirementRequirement 50: /req/advanced-filtering/obs-by-resulttime
Test purpose

Validate that the resultTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/observations?resultTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_datastream_obs-resources-endpoint.

  3. For each Observation resource in the response:

    1. Retrieve its resultTime property.

    2. Verify that the value of the property intersects the time specified in the request.

  4. Repeat the steps above for every observation resources endpoint nested under a DataStream resource, that is at endpoints {api_root}/datastreams/{dsId}/observations where dsId is the local ID of a DataStream resource.

Abstract test A.51

Identifier/conf/advanced-filtering/obs-by-foi
RequirementRequirement 51: /req/advanced-filtering/obs-by-foi
Test purpose

Validate that the foi query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/observations?foi={idList} where {idList} is a list of one or more local IDs of Sampling Feature or Feature resources.
    See test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/advanced-filtering/id-list-schema

  2. Validate the response using the steps described in test _conf_datastream_obs-resources-endpoint.

  3. For each Observation resource in the response:

    1. Retrieve its samplingFeature property.

    2. Follow the sampleOf links to retrieve the sampled features, recursively. If a link does not resolve or the link media type is not supported by the testing engine, use the link target as the identifier of the feature.

    3. Verify that at least one of the collected features has one of the identifiers included in {idList}.

  4. Repeat the previous steps with the foi parameter set to a list of one or more UIDs of Feature resources.

  5. Repeat the steps above for every observation resources endpoint nested under a DataStream resource, that is at endpoints {api_root}/datastreams/{dsId}/observations where dsId is the local ID of a DataStream resource.

Abstract test A.52

Identifier/conf/advanced-filtering/controlstream-by-issuetime
RequirementRequirement 52: /req/advanced-filtering/controlstream-by-issuetime
Test purpose

Validate that the issueTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/controlstreams?issueTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_controlstream_resources-endpoint.

  3. For each ControlStream resource in the response:

    1. Retrieve its issueTime property.

    2. Verify that the value of the property intersects the time specified in the request.

Abstract test A.53

Identifier/conf/advanced-filtering/controlstream-by-exectime
RequirementRequirement 53: /req/advanced-filtering/controlstream-by-exectime
Test purpose

Validate that the executionTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/controlstreams?executionTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_controlstream_resources-endpoint.

  3. For each ControlStream resource in the response:

    1. Retrieve its executionTime property.

    2. Verify that the value of the property intersects the time specified in the request.

Abstract test A.54

Identifier/conf/advanced-filtering/controlstream-by-controlprop
RequirementRequirement 54: /req/advanced-filtering/controlstream-by-controlprop
Test purpose

Validate that the controlledProperty query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/controlstreams?controlledProperty={idList} where {idList} is a list of one or more local IDs of Property resources.
    See test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/advanced-filtering/id-list-schema

  2. Validate the response using the steps described in test _conf_controlstream_resources-endpoint.

  3. For each ControlStream resource in the response:

    1. Retrieve all controlled properties listed in the ControlStream resource.

    2. Verify that at least one of the collected properties has one of the identifiers included in {idList}.

  4. Repeat the previous steps with the controlledProperty parameter set to a list of one or more URIs identifying controllable properties.

Abstract test A.55

Identifier/conf/advanced-filtering/controlstream-by-foi
RequirementRequirement 55: /req/advanced-filtering/controlstream-by-foi
Test purpose

Validate that the foi query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/controlstreams?foi={idList} where {idList} is a list of one or more local IDs of Sampling Feature or Feature resources.
    See test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/advanced-filtering/id-list-schema

  2. Validate the response using the steps described in test _conf_controlstream_resources-endpoint.

  3. For each ControlStream resource in the response:

    1. Retrieve the control streams’s sampling features by issuing an HTTP GET request at {api_root}/controlstreams/{dsId}/samplingFeatures.

    2. For each Sampling Feature resource in the returned collection:

      1. Follow the sampleOf links to retrieve the target features, recursively. If a link does not resolve or the link media type is not supported by the testing engine, use the link target as the identifier of the feature.

    3. Verify that at least one of the collected features has one of the identifiers included in {idList}.

  4. Repeat the previous steps with the foi parameter set to a list of one or more UIDs of Feature resources.

Abstract test A.56

Identifier/conf/advanced-filtering/cmd-by-issuetime
RequirementRequirement 56: /req/advanced-filtering/cmd-by-issuetime
Test purpose

Validate that the issueTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/commands?issueTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_controlstream_cmd-resources-endpoint.

  3. For each Command resource in the response:

    1. Retrieve its issueTime property.

    2. Verify that the value of the property intersects the time specified in the request.

  4. Repeat the steps above for every command resources endpoint nested under a ControlStream resource, that is at endpoints {api_root}/controlstreams/{dsId}/commands where dsId is the local ID of a ControlStream resource.

Abstract test A.57

Identifier/conf/advanced-filtering/cmd-by-exectime
RequirementRequirement 57: /req/advanced-filtering/cmd-by-exectime
Test purpose

Validate that the executionTime query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/commands?executionTime={datetime} where {datetime} is a time instant or period (see the requirement for the exact syntax of the parameter).

  2. Validate the response using the steps described in test _conf_controlstream_cmd-resources-endpoint.

  3. For each Command resource in the response:

    1. Retrieve its executionTime property.

    2. Verify that the value of the property intersects the time specified in the request.

  4. Repeat the steps above for every command resources endpoint nested under a ControlStream resource, that is at endpoints {api_root}/controlstreams/{dsId}/commands where dsId is the local ID of a ControlStream resource.

Abstract test A.58

Identifier/conf/advanced-filtering/cmd-by-status
RequirementRequirement 58: /req/advanced-filtering/cmd-by-status
Test purpose

Validate that the statusCode query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/commands?statusCode={idList} where {idList} is a list of one or more status codes (see requirement for the possible values).

  2. Validate the response using the steps described in test _conf_controlstream_cmd-resources-endpoint.

  3. For each Command resource in the response:

    1. Retrieve its currentStatus property

    2. Verify that the value of the property is equal to one of the status codes listed in the request.

  4. Repeat the steps above for every command resources endpoint nested under a ControlStream resource, that is at endpoints {api_root}/controlstreams/{dsId}/commands where dsId is the local ID of a ControlStream resource.

Abstract test A.59

Identifier/conf/advanced-filtering/cmd-by-sender
RequirementRequirement 59: /req/advanced-filtering/cmd-by-sender
Test purpose

Validate that the sender query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/commands?sender={idList} where {idList} is a list of one or more sender IDs.

  2. Validate the response using the steps described in test _conf_controlstream_cmd-resources-endpoint.

  3. For each Command resource in the response:

    1. Retrieve its sender property

    2. Verify that the value of the property is equal to one of the IDs listed in the request.

  4. Repeat the steps above for every command resources endpoint nested under a ControlStream resource, that is at endpoints {api_root}/controlstreams/{dsId}/commands where dsId is the local ID of a ControlStream resource.

Abstract test A.60

Identifier/conf/advanced-filtering/cmd-by-foi
RequirementRequirement 60: /req/advanced-filtering/cmd-by-foi
Test purpose

Validate that the foi query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/commands?foi={idList} where {idList} is a list of one or more local IDs of Sampling Feature or Feature resources.
    See test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/advanced-filtering/id-list-schema

  2. Validate the response using the steps described in test _conf_controlstream_cmd-resources-endpoint.

  3. For each Command resource in the response:

    1. Retrieve its samplingFeature property.

    2. Follow the sampleOf links to retrieve the sampled features, recursively. If a link does not resolve or the link media type is not supported by the testing engine, use the link target as the identifier of the feature.

    3. Verify that at least one of the collected features has one of the identifiers included in {idList}.

  4. Repeat the previous steps with the foi parameter set to a list of one or more UIDs of Feature resources.

  5. Repeat the steps above for every commands resources endpoint nested under a ControlStream resource, that is at endpoints {api_root}/controlstreams/{dsId}/commands where dsId is the local ID of a ControlStream resource.

Abstract test A.61

Identifier/conf/advanced-filtering/status-by-statuscode
RequirementRequirement 61: /req/advanced-filtering/status-by-statuscode
Test purpose

Validate that the statusCode query parameter is processed correctly.

Test method

Retrieve all Command resources by executing test http://www.opengis.net/spec/ogcapi-connectedsystems-1/1.0/conf/api-common/canonical-resources with parameter resource-type=commands, then for or every Command resource:

  1. Issue an HTTP GET request at URL {api_root}/commands/{cmdId}/status?statusCode={idList} where {idList} is a list of one or more status codes (see requirement for the possible values).

  2. Validate the response using the steps described in test _conf_controlstream_status-resources-endpoint.

  3. For each Command resource in the response:

    1. Retrieve its currentStatus property

    2. Verify that the value of the property is equal to one of the status codes listed in the request.

Abstract test A.62

Identifier/conf/advanced-filtering/event-by-type
RequirementRequirement 62: /req/advanced-filtering/event-by-type
Test purpose

Validate that the eventType query parameter is processed correctly.

Test method
  1. Issue an HTTP GET request at URL {api_root}/systemevents?eventType={type} where {type} is a list of one or more event types.

  2. Validate the response using the steps described in test _conf_system-event_resources-endpoint.

  3. For each SystemEvent resource in the response:

    1. Retrieve its type property

    2. Verify that the value of the property is equal to one of the types listed in the request.

  4. Repeat the steps above for every system event resources endpoint nested under a System resource, that is at endpoints {api_root}/systems/{sysId}/events where sysId is the local ID of a System resource.

A.7.  Conformance Class “Create/Replace/Delete”

Abstract test A.63

Identifier/conf/create-replace-delete/datastream
RequirementRequirement 63: /req/create-replace-delete/datastream
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for DataStream resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/systems/{sysId}/datastreams (for CREATE)

    2. At resource endpoint {api_root}/systems/{sysId}/datastreams/{id} (for REPLACE and DELETE)

    3. At resource endpoint {api_root}/datastreams/{id} (for REPLACE and DELETE)

Abstract test A.64

Identifier/conf/create-replace-delete/datastream-update-schema
RequirementRequirement 64: /req/create-replace-delete/datastream-update-schema
Test purpose

Validate that the server rejects DataStream REPLACE requests with incompatible schemas.

Test method
  1. Given a DataStream resource with ID dsId that has associated observations:

    1. Issue an HTTP PUT request at URL {api_root}/datastreams/{dsId} with a different observation schema.

    2. Verify that the server responds with an error code 409.

Abstract test A.65

Identifier/conf/create-replace-delete/datastream-delete-cascade
RequirementRequirement 65: /req/create-replace-delete/datastream-delete-cascade
Test purpose

Validate that the server implements the cascade query parameter correctly.

Test method
  1. Given a DataStream resource with ID dsId that has observations:

    1. Issue an HTTP DELETE request at URL {api_root}/datastreams/{dsId}?cascade=false.

    2. Verify that the server responds with an error code 409.

    3. Issue an HTTP DELETE request at URL {api_root}/datastreams/{dsId}?cascade=true.

    4. Verify that the datastream and all its observations have been deleted.

Abstract test A.66

Identifier/conf/create-replace-delete/observation
RequirementRequirement 66: /req/create-replace-delete/observation
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for Observation resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/datastreams/{dsId}/observations (for CREATE)

    2. At resource endpoint {api_root}/datastreams/{dsId}/observations/{id} (for REPLACE and DELETE)

    3. At resource endpoint {api_root}/observations/{id} (for REPLACE and DELETE)

Abstract test A.67

Identifier/conf/create-replace-delete/observation-schema
RequirementRequirement 67: /req/create-replace-delete/observation-schema
Test purpose

Validate that the server rejects observations with incompatible schemas.

Test method
  1. Given a DataStream resource with ID dsId:

    1. Issue an HTTP CREATE request at URL {api_root}/datastreams/{dsId}/observations with an observation whose result structure is incompatible with the observation schema registered with the datastream.

    2. Verify that the server responds with an error code 400.

Abstract test A.68

Identifier/conf/create-replace-delete/controlstream
RequirementRequirement 68: /req/create-replace-delete/controlstream
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for ControlStream resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/systems/{sysId}/controlstreams (for CREATE)

    2. At resource endpoint {api_root}/systems/{sysId}/controlstreams/{id} (for REPLACE and DELETE)

    3. At resource endpoint {api_root}/controlstreams/{id} (for REPLACE and DELETE)

Abstract test A.69

Identifier/conf/create-replace-delete/controlstream-update-schema
RequirementRequirement 69: /req/create-replace-delete/controlstream-update-schema
Test purpose

Validate that the server rejects ControlStream REPLACE requests with incompatible schemas.

Test method
  1. Given a ControlStream resource with ID dsId that has associated commands:

    1. Issue an HTTP PUT request at URL {api_root}/controlstreams/{dsId} with a different observation schema.

    2. Verify that the server responds with an error code 409.

Abstract test A.70

Identifier/conf/create-replace-delete/controlstream-delete-cascade
RequirementRequirement 70: /req/create-replace-delete/controlstream-delete-cascade
Test purpose

Validate that the server implements the cascade query parameter correctly.

Test method
  1. Given a ControlStream resource with ID dsId that has commands:

    1. Issue an HTTP DELETE request at URL {api_root}/controlstreams/{dsId}?cascade=false.

    2. Verify that the server responds with an error code 409.

    3. Issue an HTTP DELETE request at URL {api_root}/controlstreams/{dsId}?cascade=true.

    4. Verify that the control stream and all its commands have been deleted.

Abstract test A.71

Identifier/conf/create-replace-delete/command
RequirementRequirement 71: /req/create-replace-delete/command
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for Command resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/controlstreams/{dsId}/commands (for CREATE)

    2. At resource endpoint {api_root}/controlstreams/{dsId}/commands/{id} (for REPLACE and DELETE)

    3. At resource endpoint {api_root}/commands/{id} (for REPLACE and DELETE)

Abstract test A.72

Identifier/conf/create-replace-delete/command-schema
RequirementRequirement 72: /req/create-replace-delete/command-schema
Test purpose

Validate that the server rejects commands with incompatible schemas.

Test method
  1. Given a ControlStream resource with ID dsId:

    1. Issue an HTTP CREATE request at URL {api_root}/controlstreams/{dsId}/commands with a command whose result structure is incompatible with the command schema registered with the control stream.

    2. Verify that the server responds with an error code 400.

Abstract test A.73

Identifier/conf/create-replace-delete/command-status
RequirementRequirement 73: /req/create-replace-delete/command-status
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for CommandStatus resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/commands/{cmdId}/status (for CREATE)

    2. At resource endpoint {api_root}/commands/{cmdId}/status/{id} (for REPLACE and DELETE)

Abstract test A.74

Identifier/conf/create-replace-delete/command-result
RequirementRequirement 74: /req/create-replace-delete/command-result
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for CommandResult resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/commands/{cmdId}/result (for CREATE)

    2. At resource endpoint {api_root}/commands/{cmdId}/result/{id} (for REPLACE and DELETE)

Abstract test A.75

Identifier/conf/create-replace-delete/feasibility
RequirementRequirement 75: /req/create-replace-delete/feasibility
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for Feasibility resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/controlstreams/{dsId}/feasibility (for CREATE)

    2. At resource endpoint {api_root}/controlstreams/{dsId}/feasibility/{id} (for REPLACE and DELETE)

    3. At resource endpoint {api_root}/feasibility/{id} (for REPLACE and DELETE)

Abstract test A.76

Identifier/conf/create-replace-delete/feasibility-status
RequirementRequirement 76: /req/create-replace-delete/feasibility-status
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for feasibility status.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/feasibility/{cmdId}/status (for CREATE)

    2. At resource endpoint {api_root}/feasibility/{cmdId}/status/{id} (for REPLACE and DELETE)

Abstract test A.77

Identifier/conf/create-replace-delete/feasibility-result
RequirementRequirement 77: /req/create-replace-delete/feasibility-result
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for feasibility result.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/feasibility/{cmdId}/result (for CREATE)

    2. At resource endpoint {api_root}/feasibility/{cmdId}/result/{id} (for REPLACE and DELETE)

Abstract test A.78

Identifier/conf/create-replace-delete/system-event
RequirementRequirement 78: /req/create-replace-delete/system-event
Test purpose

Validate that the server implements CREATE/REPLACE/DELETE operations correctly for SystemEvent resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/create-replace-delete at the following endpoints:

    1. At resources endpoint {api_root}/systems/{sysId}/events (for CREATE)

    2. At resource endpoint {api_root}/systems/{sysId}/events/{id} (for REPLACE and DELETE)

    3. At resource endpoint {api_root}/systemEvents/{id} (for REPLACE and DELETE)

A.8.  Conformance Class “Update”

Conformance class A.8

Identifier/conf/update
Requirements classRequirements class 8: /req/update
PrerequisitesConformance class A.7: /conf/create-replace-delete
http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update
Target TypeWeb API
Conformance testsAbstract test A.79: /conf/update/datastream
Abstract test A.80: /conf/update/datastream-update-schema
Abstract test A.81: /conf/update/observation
Abstract test A.82: /conf/update/observation-schema
Abstract test A.83: /conf/update/controlstream
Abstract test A.84: /conf/update/controlstream-update-schema
Abstract test A.85: /conf/update/command
Abstract test A.86: /conf/update/command-schema
Abstract test A.87: /conf/update/command-status
Abstract test A.88: /conf/update/command-result
Abstract test A.89: /conf/update/feasibility
Abstract test A.90: /conf/update/feasibility-status
Abstract test A.91: /conf/update/feasibility-result
Abstract test A.92: /conf/update/system-event

Abstract test A.79

Identifier/conf/update/datastream
RequirementRequirement 79: /req/update/datastream
Test purpose

Validate that the server implements the UPDATE operation correctly for DataStream resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/systems/{sysId}/datastreams/{id}

    2. At resource endpoint {api_root}/datastreams/{id}

Abstract test A.80

Identifier/conf/update/datastream-update-schema
RequirementRequirement 80: /req/update/datastream-update-schema
Test purpose

Validate that the server rejects DataStream UPDATE requests with incompatible schemas.

Test method
  1. Given a DataStream resource with ID dsId that has associated observations:

    1. Issue HTTP UPDATE request at URL {api_root}/datastreams/{dsId} with a different observation schema.

    2. Verify that the server responds with an error code 409.

Abstract test A.81

Identifier/conf/update/observation
RequirementRequirement 81: /req/update/observation
Test purpose

Validate that the server implements the UPDATE operation correctly for Observation resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/datastreams/{dsId}/observations/{id}

    2. At resource endpoint {api_root}/observations/{id}

Abstract test A.82

Identifier/conf/update/observation-schema
RequirementRequirement 82: /req/update/observation-schema
Test purpose

Validate that the server rejects observations with incompatible schemas.

Test method
  1. Given a DataStream resource with ID dsId:

    1. Issue an HTTP PATCH request at URL {api_root}/datastreams/{dsId}/observations/{id} changing the observation’s result to something incompatible with the observation schema registered with the datastream.

    2. Verify that the server responds with an error code 400.

Abstract test A.83

Identifier/conf/update/controlstream
RequirementRequirement 83: /req/update/controlstream
Test purpose

Validate that the server implements the UPDATE operation correctly for ControlStream resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/systems/{sysId}/controlstreams/{id}

    2. At resource endpoint {api_root}/controlstreams/{id}

Abstract test A.84

Identifier/conf/update/controlstream-update-schema
RequirementRequirement 84: /req/update/controlstream-update-schema
Test purpose

Validate that the server rejects ControlStream UPDATE requests with incompatible schemas.

Test method
  1. Given a ControlStream resource with ID dsId that has associated observations:

    1. Issue HTTP UPDATE request at URL {api_root}/controlstreams/{dsId} with a different command schema.

    2. Verify that the server responds with an error code 409.

Abstract test A.85

Identifier/conf/update/command
RequirementRequirement 85: /req/update/command
Test purpose

Validate that the server implements the UPDATE operation correctly for Command resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/controlstreams/{dsId}/commands/{id}

    2. At resource endpoint {api_root}/commands/{id}

Abstract test A.86

Identifier/conf/update/command-schema
RequirementRequirement 86: /req/update/command-schema
Test purpose

Validate that the server rejects commands with incompatible schemas.

Test method
  1. Given a ControlStream resource with ID dsId:

    1. Issue an HTTP PATCH request at URL {api_root}/controlstreams/{dsId}/commands/{id} changing the command’s parameters to something incompatible with the command schema registered with the control stream.

    2. Verify that the server responds with an error code 400.

Abstract test A.87

Identifier/conf/update/command-status
RequirementRequirement 87: /req/update/command-status
Test purpose

Validate that the server implements the UPDATE operation correctly for CommandStatus resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/commands/{cmdId}/status/{id}

Abstract test A.88

Identifier/conf/update/command-result
RequirementRequirement 88: /req/update/command-result
Test purpose

Validate that the server implements the UPDATE operation correctly for CommandResult resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/commands/{cmdId}/result/{id}

Abstract test A.89

Identifier/conf/update/feasibility
RequirementRequirement 89: /req/update/feasibility
Test purpose

Validate that the server implements the UPDATE operation correctly for Feasibility resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/controlstreams/{dsId}/feasibility/{id}

    2. At resource endpoint {api_root}/feasibility/{id}

Abstract test A.90

Identifier/conf/update/feasibility-status
RequirementRequirement 90: /req/update/feasibility-status
Test purpose

Validate that the server implements the UPDATE operation correctly for feasibility status resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/feasibility/{cmdId}/status/{id}

Abstract test A.91

Identifier/conf/update/feasibility-result
RequirementRequirement 91: /req/update/feasibility-result
Test purpose

Validate that the server implements the UPDATE operation correctly for feasibility result resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/feasibility/{cmdId}/result/{id}

Abstract test A.92

Identifier/conf/update/system-event
RequirementRequirement 92: /req/update/system-event
Test purpose

Validate that the server implements the UPDATE operation correctly for SystemEvent resources.

Test method
  1. Execute all tests from conformance class http://www.opengis.net/spec/ogcapi-features-4/1.0/conf/update at the following endpoints:

    1. At resource endpoint {api_root}/systems/{sysId}/events/{id}

    2. At resource endpoint {api_root}/systemEvents/{id}

A.9.  Conformance Class “JSON Encoding”

Conformance class A.9

Identifier/conf/json
Requirements classRequirements class 9: /req/json
Prerequisitehttp://www.opengis.net/spec/SWE/3.0/conf/json-record-components
Target TypeWeb API
Conformance testsAbstract test A.93: /conf/json/mediatype-read
Abstract test A.94: /conf/json/mediatype-write
Abstract test A.95: /conf/json/datastream-schema
Abstract test A.96: /conf/json/obsschema-schema
Abstract test A.97: /conf/json/observation-schema
Abstract test A.98: /conf/json/observation-constraints
Abstract test A.99: /conf/json/controlstream-schema
Abstract test A.100: /conf/json/commandschema-schema
Abstract test A.101: /conf/json/command-schema
Abstract test A.102: /conf/json/command-constraints
Abstract test A.103: /conf/json/commandstatus-schema
Abstract test A.104: /conf/json/commandresult-schema
Abstract test A.105: /conf/json/commandresult-constraints
Abstract test A.106: /conf/json/systemevent-schema

Abstract test A.93

Identifier/conf/json/mediatype-read
RequirementRequirement 93: /req/json/mediatype-read
Test purpose

Verify that the server supports the JSON format on retrieval operations.

Test method
  1. For each supported conformance class:

    1. Request resources from the specified resources endpoint with media type application/json.

    2. Verify that the server responds with HTTP code 200.

    3. Verify that the Content-Type header of the response is set to application/json.

    4. Verify that the response is properly encoded as JSON.

Abstract test A.94

Identifier/conf/json/mediatype-write
RequirementRequirement 94: /req/json/mediatype-write
Test purpose

Verify that the server advertises support for the JSON format on transactional operations.

Test method
  1. For each supported conformance class:

    1. Verify that server advertises support for media type application/json in the API definition for CREATE or REPLACE operations, for the specified resources endpoint.

Abstract test A.95

Identifier/conf/json/datastream-schema
RequirementRequirement 95: /req/json/datastream-schema
Test purpose

Validate that the JSON representation of DataStream resources is valid.

Test method
  1. Request a single DataStream resource.

    1. Issue an HTTP GET request at {api_root}/datastreams/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema dataStream.json using a JSON Schema validator.

  2. Request multiple DataStream resources.

    1. Issue an HTTP GET request at {api_root}/datastreams with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema dataStreamCollection.json using a JSON Schema validator.

    4. Repeat the steps above for nested DataStream resources endpoints {api_root}/systems/{sysId}/datastreams.

Abstract test A.96

Identifier/conf/json/obsschema-schema
RequirementRequirement 96: /req/json/obsschema-schema
Test purpose

Validate that the JSON representation of observation schema resources is valid.

Test method

For every DataStream resource:

  1. Issue an HTTP GET request at {api_root}/datastreams/{id}/schema?obsFormat=application/json.

  2. Validate the document against the schema observationSchemaJson.json using a JSON Schema validator.

Abstract test A.97

Identifier/conf/json/observation-schema
RequirementRequirement 97: /req/json/observation-schema
Test purpose

Validate that the JSON representation of Observation resources is valid.

Test method
  1. Request a single Observation resource.

    1. Issue an HTTP GET request at {api_root}/observations/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema observation.json using a JSON Schema validator.

  2. Request multiple Observation resources.

    1. Issue an HTTP GET request at {api_root}/observations with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema observationCollection.json using a JSON Schema validator.

    4. For each observation in the response, validate it with test _conf_json_observation-constraints

    5. Repeat the steps above for nested Observation resources endpoints {api_root}/datastreams/{dsId}/observations.

Abstract test A.98

Identifier/conf/json/observation-constraints
RequirementRequirement 98: /req/json/observation-constraints
Test purpose

Validate that Observation result and parameters are encoded properly.

Test method
  1. Retrieve the schema from the parent DataStream resource.

  2. Validate that the Observation result is valid according to the resultSchema.

  3. Validate that the Observation parameters, if any, are valid according to the parametersSchema.

Abstract test A.99

Identifier/conf/json/controlstream-schema
RequirementRequirement 99: /req/json/controlstream-schema
Test purpose

Validate that the JSON representation of ControlStream resources is valid.

Test method
  1. Request a single ControlStream resource.

    1. Issue an HTTP GET request at {api_root}/controlstreams/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema controlStream.json using a JSON Schema validator.

  2. Request multiple ControlStream resources.

    1. Issue an HTTP GET request at {api_root}/controlstreams with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema controlStreamCollection.json using a JSON Schema validator.

    4. Repeat the steps above for nested ControlStream resources endpoints {api_root}/systems/{sysId}/controlstreams.

Abstract test A.100

Identifier/conf/json/commandschema-schema
RequirementRequirement 100: /req/json/commandschema-schema
Test purpose

Validate that the JSON representation of command schema resources is valid.

Test method

For every ControlStream resource:

  1. Issue an HTTP GET request at {api_root}/controlstreams/{id}/schema?cmdFormat=application/json.

  2. Validate the document against the schema commandSchemaJson.json using a JSON Schema validator.

Abstract test A.101

Identifier/conf/json/command-schema
RequirementRequirement 101: /req/json/command-schema
Test purpose

Validate that the JSON representation of Command resources is valid.

Test method
  1. Request a single Command resource.

    1. Issue an HTTP GET request at {api_root}/commands/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema command.json using a JSON Schema validator.

  2. Request multiple Command resources.

    1. Issue an HTTP GET request at {api_root}/commands with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema commandCollection.json using a JSON Schema validator.

    4. Repeat the steps above for nested Command resources endpoints {api_root}/controlstreams/{dsId}/commands.

Abstract test A.102

Identifier/conf/json/command-constraints
RequirementRequirement 102: /req/json/command-constraints
Test purpose

Validate that Command parameters are encoded properly.

Test method
  1. Retrieve the schema from the parent ControlStream resource.

  2. Validate that the Command parameters are valid according to the parametersSchema.

Abstract test A.103

Identifier/conf/json/commandstatus-schema
RequirementRequirement 103: /req/json/commandstatus-schema
Test purpose

Validate that the JSON representation of CommandStatus resources is valid.

Test method
  1. Request a single CommandStatus resource.

    1. Issue an HTTP GET request at {api_root}/commands/{cmdId}/status/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema commandStatus.json using a JSON Schema validator.

  2. Request multiple CommandStatus resources.

    1. Issue an HTTP GET request at {api_root}/commands/{cmdId}/status with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema commandStatusCollection.json using a JSON Schema validator.

Abstract test A.104

Identifier/conf/json/commandresult-schema
RequirementRequirement 104: /req/json/commandresult-schema
Test purpose

Validate that the JSON representation of CommandResult resources is valid.

Test method
  1. Request a single CommandResult resource.

    1. Issue an HTTP GET request at {api_root}/commands/{cmdId}/result/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema commandResult.json using a JSON Schema validator.

  2. Request multiple CommandResult resources.

    1. Issue an HTTP GET request at {api_root}/commands/{cmdId}/result with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema commandResultCollection.json using a JSON Schema validator.

Abstract test A.105

Identifier/conf/json/commandresult-constraints
RequirementRequirement 105: /req/json/commandresult-constraints
Test purpose

Validate that CommandResult results are encoded properly.

Test method
  1. Retrieve the schema from the parent ControlStream resource.

  2. Validate that the CommandResult result field is valid according to the resultSchema.

Abstract test A.106

Identifier/conf/json/systemevent-schema
RequirementRequirement 106: /req/json/systemevent-schema
Test purpose

Validate that the JSON representation of SystemEvent resources is valid.

Test method
  1. Request a single SystemEvent resource.

    1. Issue an HTTP GET request at {api_root}/systemEvents/{id} with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema systemEvent.json using a JSON Schema validator.

  2. Request multiple SystemEvent resources.

    1. Issue an HTTP GET request at {api_root}/systemEvents with the Accept header set to application/json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the document against the schema systemEventCollection.json using a JSON Schema validator.

    4. Repeat the steps above for nested SystemEvent resources endpoints {api_root}/systems/{sysId}/events.

A.10.  Conformance Class “SWE Common JSON Encoding”

Conformance class A.10

Identifier/conf/swecommon-json
Requirements classRequirements class 10: /req/swecommon-json
Prerequisitehttp://www.opengis.net/spec/SWE/3.0/conf/json-encoding-rules
Target TypeWeb API
Conformance testsAbstract test A.107: /conf/swecommon-json/mediatype-read
Abstract test A.108: /conf/swecommon-json/mediatype-write
Abstract test A.109: /conf/swecommon-json/obsschema-schema
Abstract test A.110: /conf/swecommon-json/obsschema-mapping
Abstract test A.111: /conf/swecommon-json/observation-encoding
Abstract test A.112: /conf/swecommon-json/cmdschema-schema
Abstract test A.113: /conf/swecommon-json/cmdschema-mapping
Abstract test A.114: /conf/swecommon-json/command-encoding

Abstract test A.107

Identifier/conf/swecommon-json/mediatype-read
RequirementRequirement 107: /req/swecommon-json/mediatype-read
Test purpose

Verify that the server supports the SWE Common JSON format on retrieval operations.

Test method
  1. For at least one of the Observation and/or Command resources endpoint:

    1. Verify that the server advertises support for media type application/swe+json in the API definition for retrieval operations.

    2. Request resources from the resources endpoint with media type application/swe+json.

    3. Verify that the server responds with HTTP code 200.

    4. Verify that the Content-Type header of the response is set to application/swe+json.

    5. Verify that the response is properly encoded as JSON.

Abstract test A.108

Identifier/conf/swecommon-json/mediatype-write
RequirementRequirement 108: /req/swecommon-json/mediatype-write
Test purpose

Verify that the server advertises support for the SWE Common JSON format on transactional operations.

Test method
  1. For at least one of the Observation and/or Command resources endpoint:

    1. Verify that the server advertises support for media type application/swe+json in the API definition for CREATE or REPLACE operations.

Abstract test A.109

Identifier/conf/swecommon-json/obsschema-schema
RequirementRequirement 109: /req/swecommon-json/obsschema-schema
Test purpose

Validate that the JSON representation of observation schema resources is valid.

Test method

For every DataStream resource:

  1. Issue an HTTP GET request at {api_root}/datastreams/{id}/schema?obsFormat=application/swe+json.

  2. Validate the document against the schema observationSchemaSwe.json using a JSON Schema validator.

  3. Validate that the SWE Common encoding is set to JSONEncoding.

  4. Validate the schema using test _conf_swecommon-json_obsschema-mapping

Abstract test A.110

Identifier/conf/swecommon-json/obsschema-mapping
RequirementRequirement 110: /req/swecommon-json/obsschema-mapping
Test purpose

Verify that the mandatory fields are present in the schema.

Test method
  1. Scan the schema and validate that at least one Time data component is present

  2. Validate the the definition field of the Time component is one of:

Abstract test A.111

Identifier/conf/swecommon-json/observation-encoding
RequirementRequirement 111: /req/swecommon-json/observation-encoding
Test purpose

Validate that the JSON representation of Observation resources is valid.

Test method
  1. For every DataStream that advertises support for the application/swe+json format:

    1. Issue an HTTP GET request at {api_root}/datastreams/{dsId}/observations with the Accept header set to application/swe+json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the response using a SWE Common validator implementing the JSON encoding rules.

Abstract test A.112

Identifier/conf/swecommon-json/cmdschema-schema
RequirementRequirement 112: /req/swecommon-json/cmdschema-schema
Test purpose

Validate that the JSON representation of command schema resources is valid.

Test method

For every ControlStream resource:

  1. Issue an HTTP GET request at {api_root}/controlstreams/{id}/schema?cmdFormat=application/swe+json.

  2. Validate the document against the schema commandSchemaSwe.json using a JSON Schema validator.

  3. Validate that the SWE Common encoding is set to JSONEncoding.

  4. Validate the schema using test _conf_swecommon-json_cmdschema-mapping

Abstract test A.113

Identifier/conf/swecommon-json/cmdschema-mapping
RequirementRequirement 113: /req/swecommon-json/cmdschema-mapping
Test purpose

Verify that the mandatory fields are present in the schema.

Test method
  1. Scan the schema and validate that at least one Time data component is present

  2. Validate the the definition field of the Time component is one of:

Abstract test A.114

Identifier/conf/swecommon-json/command-encoding
RequirementRequirement 114: /req/swecommon-json/command-encoding
Test purpose

Validate that the JSON representation of Command resources is valid.

Test method
  1. For every ControlStream that advertises support for the application/swe+json format:

    1. Issue an HTTP GET request at {api_root}/controlstreams/{dsId}/commands with the Accept header set to application/swe+json.

    2. Validate that a document was returned with a status code 200.

    3. Validate the response using a SWE Common validator implementing the JSON encoding rules.

A.11.  Conformance Class “SWE Common Text Encoding”

Conformance class A.11

Identifier/conf/swecommon-text
Requirements classRequirements class 11: /req/swecommon-text
Prerequisitehttp://www.opengis.net/spec/SWE/3.0/conf/text-encoding-rules
Target TypeWeb API
Conformance testsAbstract test A.115: /conf/swecommon-text/mediatype-read
Abstract test A.116: /conf/swecommon-text/mediatype-write
Abstract test A.117: /conf/swecommon-text/obsschema-schema
Abstract test A.118: /conf/swecommon-text/obsschema-mapping
Abstract test A.119: /conf/swecommon-text/observation-encoding
Abstract test A.120: /conf/swecommon-text/cmdschema-schema
Abstract test A.121: /conf/swecommon-text/cmdschema-mapping
Abstract test A.122: /conf/swecommon-text/command-encoding

Abstract test A.115

Identifier/conf/swecommon-text/mediatype-read
RequirementRequirement 115: /req/swecommon-text/mediatype-read
Test purpose

Verify that the server supports the SWE Common Text format on retrieval operations.

Test method
  1. For at least one of the Observation and/or Command resources endpoint:

    1. Verify that the server advertises support for media type application/swe+binary in the API definition for retrieval operations.

    2. Request resources from the resources endpoint with media type application/swe+text.

    3. Verify that the server responds with HTTP code 200.

    4. Verify that the Content-Type header of the response is set to application/swe+text.

Abstract test A.116

Identifier/conf/swecommon-text/mediatype-write
RequirementRequirement 116: /req/swecommon-text/mediatype-write
Test purpose

Verify that the server advertises support for the SWE Common Text format on transactional operations.

Test method
  1. For at least one of the Observation and/or Command resources endpoint:

    1. Verify that the server advertises support for media type application/swe+text in the API definition for CREATE or REPLACE operations.

Abstract test A.117

Identifier/conf/swecommon-text/obsschema-schema
RequirementRequirement 117: /req/swecommon-text/obsschema-schema
Test purpose

Validate that the JSON representation of observation schema resources is valid.

Test method

For every DataStream resource:

  1. Issue an HTTP GET request at {api_root}/datastreams/{id}/schema?obsFormat=application/swe+text.

  2. Validate the document against the schema observationSchemaSwe.json using a JSON Schema validator.

  3. Validate that the SWE Common encoding is set to TextEncoding.

  4. Validate the schema using test _conf_swecommon-text_obsschema-mapping

Abstract test A.118

Identifier/conf/swecommon-text/obsschema-mapping
RequirementRequirement 118: /req/swecommon-text/obsschema-mapping
Test purpose

Verify that the mandatory fields are present in the schema.

Test method

Execute test _conf_swecommon-json_obsschema-mapping

Abstract test A.119

Identifier/conf/swecommon-text/observation-encoding
RequirementRequirement 119: /req/swecommon-text/observation-encoding
Test purpose

Validate that the Text (DSV) representation of Observation resources is valid.

Test method
  1. For every DataStream that advertises support for the application/swe+text format:

    1. Issue an HTTP GET request at {api_root}/datastreams/{dsId}/observations with the Accept header set to application/swe+text.

    2. Validate that a document was returned with a status code 200.

    3. Validate the response using a SWE Common validator implementing the Text encoding rules.

Abstract test A.120

Identifier/conf/swecommon-text/cmdschema-schema
RequirementRequirement 120: /req/swecommon-text/cmdschema-schema
Test purpose

Validate that the JSON representation of command schema resources is valid.

Test method

For every ControlStream resource:

  1. Issue an HTTP GET request at {api_root}/controlstreams/{id}/schema?cmdFormat=application/swe+text.

  2. Validate the document against the schema commandSchemaSwe.json using a JSON Schema validator.

  3. Validate that the SWE Common encoding is set to TextEncoding.

  4. Validate the schema using test _conf_swecommon-text_cmdschema-mapping

Abstract test A.121

Identifier/conf/swecommon-text/cmdschema-mapping
RequirementRequirement 121: /req/swecommon-text/cmdschema-mapping
Test purpose

Verify that the mandatory fields are present in the schema.

Test method

Execute test _conf_swecommon-json_cmdschema-mapping

Abstract test A.122

Identifier/conf/swecommon-text/command-encoding
RequirementRequirement 122: /req/swecommon-text/command-encoding
Test purpose

Validate that the Text (DSV) representation of Command resources is valid.

Test method
  1. For every ControlStream that advertises support for the application/swe+text format:

    1. Issue an HTTP GET request at {api_root}/controlstreams/{dsId}/commands with the Accept header set to application/swe+text.

    2. Validate that a document was returned with a status code 200.

    3. Validate the response using a SWE Common validator implementing the Text encoding rules.

A.12.  Conformance Class “SWE Common Binary Encoding”

Conformance class A.12

Identifier/conf/swecommon-binary
Requirements classRequirements class 12: /req/swecommon-binary
Prerequisitehttp://www.opengis.net/spec/SWE/3.0/conf/binary-encoding-rules
Target TypeWeb API
Conformance testsAbstract test A.123: /conf/swecommon-binary/mediatype-read
Abstract test A.124: /conf/swecommon-binary/mediatype-write
Abstract test A.125: /conf/swecommon-binary/obsschema-schema
Abstract test A.126: /conf/swecommon-binary/obsschema-mapping
Abstract test A.127: /conf/swecommon-binary/observation-encoding
Abstract test A.128: /conf/swecommon-binary/cmdschema-schema
Abstract test A.129: /conf/swecommon-binary/cmdschema-mapping
Abstract test A.130: /conf/swecommon-binary/command-encoding

Abstract test A.123

Identifier/conf/swecommon-binary/mediatype-read
RequirementRequirement 123: /req/swecommon-binary/mediatype-read
Test purpose

Verify that the server supports the SWE Common Binary format on retrieval operations.

Test method
  1. For at least one of the Observation and/or Command resources endpoint:

    1. Verify that the server advertises support for media type application/swe+binary in the API definition for retrieval operations.

    2. Request resources from the resources endpoint with media type application/swe+binary.

    3. Verify that the server responds with HTTP code 200.

    4. Verify that the Content-Type header of the response is set to application/swe+binary.

Abstract test A.124

Identifier/conf/swecommon-binary/mediatype-write
RequirementRequirement 124: /req/swecommon-binary/mediatype-write
Test purpose

Verify that the server advertises support for the SWE Common Binary format on transactional operations.

Test method
  1. For at least one of the Observation and/or Command resources endpoint:

    1. Verify that the server advertises support for media type application/swe+binary in the API definition for CREATE or REPLACE operations.

Abstract test A.125

Identifier/conf/swecommon-binary/obsschema-schema
RequirementRequirement 125: /req/swecommon-binary/obsschema-schema
Test purpose

Validate that the JSON representation of observation schema resources is valid.

Test method

For every DataStream resource:

  1. Issue an HTTP GET request at {api_root}/datastreams/{id}/schema?obsFormat=application/swe+binary.

  2. Validate the document against the schema observationSchemaSwe.json using a JSON Schema validator.

  3. Validate that the SWE Common encoding is set to BinaryEncoding.

  4. Validate the schema using test _conf_swecommon-binary_obsschema-mapping

Abstract test A.126

Identifier/conf/swecommon-binary/obsschema-mapping
RequirementRequirement 126: /req/swecommon-binary/obsschema-mapping
Test purpose

Verify that the mandatory fields are present in the schema.

Test method

Execute test _conf_swecommon-json_obsschema-mapping

Abstract test A.127

Identifier/conf/swecommon-binary/observation-encoding
RequirementRequirement 127: /req/swecommon-binary/observation-encoding
Test purpose

Validate that the binary representation of Observation resources is valid.

Test method
  1. For every DataStream that advertises support for the application/swe+binary format:

    1. Issue an HTTP GET request at {api_root}/datastreams/{dsId}/observations with the Accept header set to application/swe+binary.

    2. Validate that a document was returned with a status code 200.

    3. Validate the response using a SWE Common validator implementing the Text encoding rules.

Abstract test A.128

Identifier/conf/swecommon-binary/cmdschema-schema
RequirementRequirement 128: /req/swecommon-binary/cmdschema-schema
Test purpose

Validate that the JSON representation of command schema resources is valid.

Test method

For every ControlStream resource:

  1. Issue an HTTP GET request at {api_root}/controlstreams/{id}/schema?cmdFormat=application/swe+binary.

  2. Validate the document against the schema commandSchemaSwe.json using a JSON Schema validator.

  3. Validate that the SWE Common encoding is set to BinaryEncoding.

  4. Validate the schema using test _conf_swecommon-binary_cmdschema-mapping

Abstract test A.129

Identifier/conf/swecommon-binary/cmdschema-mapping
RequirementRequirement 129: /req/swecommon-binary/cmdschema-mapping
Test purpose

Verify that the mandatory fields are present in the schema.

Test method

Execute test _conf_swecommon-json_cmdschema-mapping

Abstract test A.130

Identifier/conf/swecommon-binary/command-encoding
RequirementRequirement 130: /req/swecommon-binary/command-encoding
Test purpose

Validate that the binary representation of Command resources is valid.

Test method
  1. For every ControlStream that advertises support for the application/swe+binary format:

    1. Issue an HTTP GET request at {api_root}/controlstreams/{dsId}/commands with the Accept header set to application/swe+binary.

    2. Validate that a document was returned with a status code 200.

    3. Validate the response using a SWE Common validator implementing the Text encoding rules.


Annex B
(informative)
Examples

More JSON examples are available in the project’s GitHub repository at:

https://schemas.opengis.net/ogcapi/connected-systems/part2/1.0/openapi/examples


Annex C
(informative)
Relationship with other OGC/ISO standards (Informative)

See OGC API — Connected Systems — Part 1, Annex C, for a description of relationships with other Standards.


Annex D
(informative)
Revision History

DateReleaseEditorPrimary clauses modifiedDescription
2023-01-101.0 draftAlex RobinAllInitial draft version
2023-04-211.0 draftAlex RobinAllMigration to Metanorma
2024-06-101.0 draftAlex RobinAllAdded missing sections, alignment with Part 1
2024-09-101.0 draftAlex RobinAllAdded ATS
2025-03-181.0 draftChristian AutermannAllIncorporated feedback from public comments

Bibliography

[1]  Simon Cox: OGC 10-004r3, Topic 20 — Observations and Measurements. Open Geospatial Consortium (2013). http://www.opengis.net/doc/as/om/2.0.

[2]  Katharina Schleidt, Ilkka Rinne: OGC 20-082r4, Topic 20 — Observations, measurements and samples. Open Geospatial Consortium (2023). http://www.opengis.net/doc/as/om/3.0.

[3]  Mark Burgoyne, David Blodgett, Charles Heazel, Chris Little: OGC 19-086r6, OGC API — Environmental Data Retrieval Standard. Open Geospatial Consortium (2023). http://www.opengis.net/doc/IS/ogcapi-edr-1/1.1.0.

[4]  Taehoon Kim, Kyoung-Sook Kim, Mahmoud SAKR, Martin Desruisseaux: OGC 22-003r3, OGC API — Moving Features — Part 1: Core. Open Geospatial Consortium (2024). http://www.opengis.net/doc/IS/ogcapi-movingfeatures-1/1.0.

[5]  Steve Liang, Tania Khalafbeigi, Hylke van der Schaaf: OGC 18-088, OGC SensorThings API Part 1: Sensing Version 1.1. Open Geospatial Consortium (2021). http://www.opengis.net/doc/is/sensorthings/1.1.0.

[6]  Steve Liang, Tania Khalafbeigi: OGC 17-079r1, OGC SensorThings API Part 2 – Tasking Core. Open Geospatial Consortium (2019). http://www.opengis.net/doc/IS/sensorthings-part2-TaskingCore/1.0.0.

[7]  Arne Bröring, Christoph Stasch, Johannes Echterhoff: OGC 12-006, OGC® Sensor Observation Service Interface Standard. Open Geospatial Consortium (2012). http://www.opengis.net/doc/IS/SOS/2.0.0.

[8]  Ingo Simonis, Johannes Echterhoff: OGC 09-000, OGC® Sensor Planning Service Implementation Standard. Open Geospatial Consortium (2011). https://portal.ogc.org/files/?artifact_id=38478.

[9]  QUDT Quantity Kinds, Version 2.1. https://www.qudt.org/doc/DOC_VOCAB-QUANTITY-KINDS.html