Skip to content

Supported oneM2M Functionalities

This article lists the supported oneM2M resource types and related functionalities of the ACME CSE

oneM2M Specification Conformance

The CSE implementation successfully passes all the relevant oneM2M test cases for the supported resource types, attributes and behaviours.

Release Versions

The ACME CSE supports oneM2M release 1 - 4 and the upcoming release 5 for the supported resource types and functionalities listed below.

CSE Types

The ACME CSE supports the following CSE types:

  • IN-CSE
  • MN-CSE
  • ASN-CSE

Resource Types

The ACME CSE supports the following oneM2M resource types. Some resource types are not yet fully implemented, and some features are experimental.

Entities

CSEBase (CB)

The CSEBase resource type is fully supported.

Application Entity (AE)

The Application Entity resource type is supported, except for some of the "S" registration related functionalities.

RemoteCSE (CSR)

The ACME CSE supports CSE registrations via the Mcc reference point. In addtion announced resources, synchronization, and transit requests that target resources on remote CSE's are supported, as well.

Security

Access Control Policy (ACP)

In addition to the basic ACP functionality, the ACME CSE supports the following ACP features:

  • Attribute-based access control
  • accessControlWindow

The following attributes are not supported because the linked-to resource types are not yet supported.

  • authorizationDecisionResourceIDs / <authorizationDecision>
  • authorizationPolicyResourceIDs/ <authorizationPolicy>
  • authorizationInformationResourceIDs / <authorizationInformation>

Data Management

Container (CNT)

The Container resource type is fully supported.

ContentInstance (CIN)

The ContentInstance resource type is fully supported.

Values with the following data types are supported for the content attribute:

  • string
  • integer dev
  • float dev
  • boolean dev
  • list dev
  • dictionary / JSON object dev
FlexContainer (FCNT)

The ACME CSE fully supports the FlexContainer resource type.

It is possible to use the predefined FlexContainer Specializations of oneM2M TS-0023, AllJoin, oneM2M's GenericInterworking, or to define custom FlexContainerSpecializations.

See Attribute Policies for further details.

FlexContainerInstance (FCI)

This is an experimental implementation of the draft FlexContainerInstance specification.

TimeSeries (TS)

The ACME CSE supports missing data detection and the respective notifications.

TimeSeriesInstance (TSI)

The TimeSeriesInstance resource type is fully supported, except for the dataGenerationTime attribute, which is only supported with absolute timestamps.

Values with the following data types are supported for the content attribute:

  • string dev
  • integer dev
  • float dev
  • boolean dev
  • list dev
  • dictionary / JSON object dev

Subscription and Notification

CrossResourceSubscription (CRS)

Besides the standard CrossResourceSubscription functionality the ACME CSE implements an experimental feature to support an eventEvaluationMode to react on missing events.

Subscription (SUB)

The ACME CSE supports notifications via direct url or an AE's Point-of-Access (POA). Further, BatchNotifications, attributes, notification statistics, and operation monitoring are supported.

Device Management

Management Objects

The ACME CSE supports the following management objects:

Management Objects Management Objects Management Objects
AreaNwkDeviceInfo (ANDI) DeviceInfo (DVI) Reboot (REB)
AreaNwkInfo (ANI) EventLog (EVL) SIM (SIM)
Battery (BAT) Firmware (FWR) Software (SWR)
Credentials (CRDS)dev Memory (MEM) WifiClient (WIFIC)
DataCollect (DATC) MobileNetwork (MNWK)
DeviceCapability (DVC) MyCertFileCred (NYCFC)
Node (NOD)

The Node resource type is fully supported.

Communication

PollingChannel (PCH)

Request and notification long-polling via the pcu (pollingChannelURI) virtual child resource are supported.
requestAggregation functionality to retrieve multiple requests in one polling request is supported as well.

Request (REQ)

The ACME CSE supports blocking, and synchronous and asynchronous non-blocking requests, which are managed through <request> resources.

Group Management

Group (GRP)

The ACME CSE supports requests via the fopt (fanOutPoint) virtual resource.
Remote resources may be members of a group.

Automation

Action (ACTR)

The input attribute of the <action> resource type is not supported yet.

Dependency (DEPR)

The Dependency resource type is fully supported.

Semantics

SemanticDescriptor (SMD)

The ACME CSE supports semantic queries and discovery for resources with semantic descriptors.

At the moment, the following presentation formats are supported:

  • RDF/XML
  • JSON-LD
  • Turtle

Location Management

LocationPolicy (LCP)

Only device based location policy is supported. The LCP's cnt stores geo-coordinates and geo-fencing results.

Time Management

Schedule (SCH)

The ACME CSE supports scheduling for various of its functions, such as CSE communication windows, and resource types, such as the <node>, <subscription> and <crossResourceSubscription> resource types.

TimeSyncBeacon (TSB)

The ACME CSE supports the TimeSyncBeacon resource type. The functionality is currently only experimental and might change according to specification changes.

Service Functionalities

The following oneM2M service functionionalities are supported.

AE Registration

The ACME CSE supports AE registration and deregistrations via the Mca reference point.

Blocking Requests

Blocking requests are the common way for an AE to interact with the CSE. They are also used for CSE-to-CSE communication via the Mcc reference point.

Delayed Request Execution*

The ACME CSE supports delayed request execution via the Operation Execution Timestamp request attribute.

Discovery

The ACME CSE supports normal retrieval and discovery of resources via the filterCriteria and discoveryResultType attributes.

Geo-Query

The ACME CSE supports location and geometry queries and location-based discovery.

Location Management

Only device based, and no network based* location policies are supported.

Long Polling

Long Polling is supported for request unreachable AEs and CSEs through pollingChannel resources.

This mechanism is used for sending notifications and other requests to AEs and CSEs that are not directly reachable via the Mca or Mcc reference points, e.g. because of firewalls or NATs.

Notifications

The ACME CSE supports notifications via direct url, or an AE's or CSE's Point-of-Access (POA). Further, BatchNotifications, attributes, notification statistics, and operation monitoring are supported.

Notification Event Types

The following notification event types for Subscriptions are supported:

Notification Event Type Notification Event Type Notification Event Type
resourceUpdate deleteDirectChild blockingUpdate
resourceUpdate retrieveCNTNoChild missingData
createDirectChild triggerReceivedForAE
Partial Retrieve

Partial retrieve of individual resource attributes is supported.

Remote CSE registration

The ACME CSE supports CSE registrations via the Mcc reference point. In addtion announced resources, synchronization, and transit requests that target resources on remote CSE's are supported.

Request Expiration

The Request Expiration Timestamp request attribute is supported.

Request Forwarding

Forwarding requests from one CSE to another is supported.

Request and Resource Validations

Validation of all requests received via the Mca and Mcc reference points is supported.

Resource Addressing

CSE-Relative, SP-Relative and Absolute as well as hybrid addressing are supported.

Resource Announcements

Announcements of resources are supported via the Mcc reference point. Resources are announced under a CSEBaseAnnc resource on the target CSE (R4 feature).
Bi-directional update sync is supported as well.

Resource Expiration

Resources are automatically deleted after the expiration time has passed.

Resource Validations

All requests and resources received via the Mca and Mcc reference points are validated.

Result Content Types

The following result contents are implemented for standard oneM2M requests and discovery:

Discovery Type RCN Discovery Type RCN
nothing 0 child-resource-references 6
attributes 1 original-resource 7
hierarchical address 2 child-resources 8
hierarchical address + attributes 3 modified attributes 9
attributes + child-resources 4 semantic content 10
attributes + child-resource-references 5 discovery result references 11
Result Expiration

The Result Expiration Timestamp request attribute is supported.

Semantics

Basic support for semantic descriptors, semantic queries and discovery is supported.

Subscriptions

Subscriptions are supported, including batch notification, and resource type and attribute filtering.

Time Synchronization

The ACME CSE supports time synchronization via the timeSyncBeacon resource type.

TimeSeries Data Handling

TimeSeries data handling is supported, including missing data detection, monitoring and notifications.

Protocols Bindings

The following Protocol Bindings are supported.
It is possible to enable only one binding, or use any combination of them for a CSE instance.

CoAP

The CoAP protocol is supported.
However, CoAP over DTLS is not yet implemented.

Release 5

The current implementation only support the CoAP binding specification for oneM2M Release 1-4. The upcoming Release 5 specification is not yet supported.

http

The http protocol is supported, including TLS (https) and CORS support.

The basic and bearer authentication methods are supported.

Experimental Feature

Some libraries and embedded chipsets do not support the DELETE method in http/1.0 (this method was only added in http/1.1). The ACME CSE therefore supports DELETE requests via the PATCH method, that is available in many http/1.0 implementations.

See also the allowPatchForDelete configuration setting.

mqtt

The mqtt protocol is supported, including TLS (mqtts) support.

This protocol binding requires a separate MQTT broker to be installed and running.

Basic username/password authentication with an mqtt broker is supported as well.

WebSocket

The WebSocket protocol is supported, including TLS (wss) support

Experimental: Besides the standard oneM2M WebSocket binding, the ACME CSE supports an experimental extension to better support notifications.

Serialization Types

The following serialization types for requests and responses are supported.

Info

The XML serialization is not supported.
Though it is part of the oneM2M standard, it is not planned to be implemented in the ACME CSE because XML is only very rarely used in real-world IoT deployments.

JSON

In addition to the common JSON syntax, C-style and Python-style comments are supported as well:

  • Block comment: /* ... */
  • End-of-line comment: // ... and # ...
CBOR

CBOR is a binary serialization format.
Messages are fairly smaller and faster to process than JSON messages.

Experimental Functionalities

These features are prove-of-concept implementations of new and currently discussed oneM2M functionalities. They are not yet part of the oneM2M standard.

Enhanced CSR functionality

Support for a new R5 eventEvaluationMode to react on missing events.

Subscription References

Support for subscription references for resource instead of direct subscriptions.

Advanced Queries

Experimental implementation of a new query language to support enhanced query capabilities.

Simplified Time Synchronization

Experimental implementation of a simplified time synchronization mechanism.

Support for DELETE requests for http/1.0

Using PATCH requests to emulate DELETE requests for http/1.0 clients.