Skip to main content
Version: 0.13.1

How to use Cumulocity Custom SmartREST 2.0 Templates

Custom SmartRest Templates can be used to extend the functionality of a device to support more operations than what the static SmartREST templates offer.

thin-edge.io supports subscription to custom templates as documented here.

For every template that the device uses, it must publish all data to s/uc/<template-name> topic and subscribe to s/dc/<template-name> to receive data from the cloud, based on that template. When these templates are configured with thin-edge.io, subscriptions to all these relevant topics on Cumulocity cloud will be done by thin-edge.io internally. Local processes on the device can access these templates on the local MQTT broker by simply publishing to c8y/s/uc/<template-name> and subscribing to c8y/s/dc/<template-name> topics (note the c8y/ prefix in topics).

A template named $TEMPLATE_NAME requires the following subscriptions to be added when connecting to Cumulocity:

s/dc/$TEMPLATE_NAME
s/uc/$TEMPLATE_NAME

This is not done automatically and the custom templates have to be declared using the tedge command.

Checking existing templates​

tedge config get c8y.smartrest.templates

Add new template to thin-edge configuration​

To add new template to thin-edge.io the tedge config cli tool can be used as following:

sudo tedge config set c8y.smartrest.templates template-1,template-2
note

To add/append a new template to a device that's already configured with some, all the existing templates should also be declared along with the new one in the tedge config set command. For example, if template-1 is already configured on the device, as following:

tedge config get c8y.smartrest.templates
["template-1"]

To add new template to the set it is required to include current template, so the command would look like this:

tedge config set c8y.smartrest.templates template-1,template-2

Now when we get the configuration the both templates will be there:

tedge config get c8y.smartrest.templates
["template-1", "template-2"]

Removing templates from configuration​

To remove all the templates, the unset subcommand can used as follows:

sudo tedge config unset c8y.smartrest.templates

To remove one of existing templates you can overwrite the existing c8y.smartrest.templates with the new set which doesn't contain the unwanted template.

tedge config get c8y.smartrest.templates
Output
["template-1", "template-2"]
sudo tedge config set c8y.smartrest.templates template-1

You can verify that the template has changed by reading the value again.

tedge config get c8y.smartrest.templates
Output
["template-1"]