Skip to content

Cumulocity-IoT/cumulocity-tedge-profile

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Overview

When you have to manage different types of devices with thin-edge, the way attributes are fetched and operations are processed may need to be implemented in differently depending on the hardware, the OS version and what's installed on it.

Not to mention that you might want to add new attributes to monitor and new operations to be made available, in which case you want a simple way in Cumulocity to add those modifications and deploy them on your devices.

This is exactly what this project proposes to address by implementing "thin-edge profiles".

Thin-edge profiles

A "thin-edge" profile is composed of 3 kind of elements:

  • Categories: a category is a group in which you will put the 2 other kinds of elements;
  • Properties: a property is either an attribute or a table that you will retrieve from the device, for example the IP address, or the list of network interfaces;
  • Actions: an action is a Cumulocity operation that can be sent to the device either without context (for example the reboot operation), or with context (example: changing the hostname). An action can also apply to a line of table.

A thin-edge profile will be stored in the software repository of Cumulocity with the "tedge-profile" type, meaning you will also need to tedge-profile software management plugin to be installed on thin-edge to deploy your profiles. This plugin is presented in the next section.

Categories

Categories are used to categorize the properties and actions.

Properties

A property is used to retrieve information from a device. It has the following attributes:

  • Property name: this is the unique id of the property
  • Property label: this is the label of the property that will be displayed
  • Property categories: the list of categories in which this property will be displayed
  • Property description: description of this property
  • Store property value: deprecated
  • JSON format: whether this property should return a simple value or a json table
  • Property script: shell script to retrieve this property value

It is possible to change the order of the parameters by dragging and dropping them.

When the profile will be deployed on the device, the tedge-profile management plugin will update the inventory.json file and publish it to Cumulocity to update the device attributes in the inventory.

Example of simple property:

Example of table propery:

Actions

Actions are used to define the operations supported by the device.

Actions have the following attributes:

  • Action id: unique id of this action
  • Action name: label of this action that will be displayed
  • Apply on table rows: whether this action should apply to a row of a table or not. If it is false, the action will be available as a button at the top of each categories it belongs to, if it true it will appear on the last column of each row of the table it applies to
  • Requires confirmation: whether to display a confirmation popup or not when performing that action
  • Select a table: dropdown available only when "apply on table rows" is selected. This will display the list of properties that has "JSON format" set to true
  • Action categories: the list of categories in which this action will be available when it does not apply to a table
  • Action script: script that will process this operation. It can be written in any script language available on the device, using the right header. Parameters will be passed as env variables.
  • Parameters: parameters that will passed to this action. Parameters have an id and a name and can have the following types:
    • STRING
    • INTEGER
    • FLOAT
    • BOOL
    • DATE
    • ENUM: in this case you will be able to enter the list of possible values as strings.
  • Groups: groups are special parameters that are used to group parameters. They have the following attributes:
    • Group id: unique id of the group
    • Group name: label of the group
    • Repeatable: whether there can be multiple occurences of this group
    • Min occurences: only available when repeatable is true
    • Max occurences: same as above
    • Depends on param: this group will appear in the form only if the parameter it depends on will have a specific value
    • Param id: only available when "depends on param" is true, this is the id of the param this group visibility depends on
    • Param value: value that the parameter this group depends on must have in order for this group to be displayed
    • Parameters: list of parameters in this group

It is possible to change this order of the actions and their parameters by dragging and dropping them.

Here is a typical refresh action implementation in Python 3:

#!/usr/bin/python3

import subprocess, json, sys, os, requests

def run(cmd):
    return subprocess.check_output(cmd, shell=True, executable="/bin/bash").decode("utf-8").strip()

def update_properties(profile):
    data = {}
    for p in profile["properties"]:
        value = run(p["script"])
        if p["json"]:
            value = json.loads(value)
        if "." in p["name"]:
            objName, valueName = p["name"].split('.')
            if not objName in data:
                data[objName] = {}
            data[objName][valueName] = value
        else:
            data[p["name"]] = value

    with open("/etc/tedge/device/inventory.json", "w") as f:
        json.dump(data, f, indent=4)
    deviceId = run("tedge config get device.id")
    c8y_proxy_bind_address = run("tedge config get c8y.proxy.bind.address")
    c8y_proxy_bind_port = run("tedge config get c8y.proxy.bind.port")
    internalDeviceId = requests.get(f"http://{c8y_proxy_bind_address}:{c8y_proxy_bind_port}/c8y/identity/externalIds/c8y_Serial/{deviceId}").json()["managedObject"]["id"]
    requests.put(f"http://{c8y_proxy_bind_address}:{c8y_proxy_bind_port}/c8y/inventory/managedObjects/{internalDeviceId}", json=data)

BASE_PATH = "/etc/tedge-profile"
PROFILE_PATH = BASE_PATH + "/profile"
with open(PROFILE_PATH, "r") as f:
    data = json.load(f)
    update_properties(data)

Deploying the profile

Thin-edge profiles are stored in the software repository with tedge-profile type.

To deploy a profile you therefore simply use the standard software management feature of Cumulocity.

When a profile is deployed, the software management plugin will perform the following tasks:

  • Call each script of each property, update the inventory.json file, push the content on the inventory.json to Cumulocity inventory, ensure that tedge/tedge is the owner of inventory.json file (important if you want an action that can refresh the properties, since actions are performed by tedge user)
  • Ensure that the c8y_Command operation is supported and correctly configured as it will be used to process the actions
  • Create a file for each action based on the action id

Device detail view

In the device detail view, a new tab "thin-edge" will appear. This view will be composed of horizontal tabs, one for each category, and in each category you will find your properties and actions.

If a property is a table, it will automatically be formatted as a Cumulocity NGX table component, and any contextual action will be available on the right end column.

Actions will be available whether as buttons or actions on table rows. If an action has parameters, a form will be displayed.

When an action completes, a popup will immediately appear informing you of the result of the action. Since actions are implemented as operations they are also available in the "Control" tab of the device.

Example of the "General" category tab with only simple properties:

Example of the "Network" category tab with the network interfaces table:

Example of an action with parameters targetting a line of a table:

The tedge-profile software plugin

Introduction

The tedge-profile software plugin is a Python3 script that follows the specs as defined in thin-edge documentation: https://thin-edge.github.io/thin-edge.io/extend/write-my-software-management-plugin/

The script is packaged as a deb file that can be really simply deployed on your thin-edge devices that as the apt plugin enabled.

If you need to perform any modification to the script, then simply keep the tree structure and run the build-plugin.sh script to build the deb file.

Installation

Installation is rather straightforward: simply put the deb file in your Cumulocity software repository with apt type. You will then be able to install it on any thin-edge device that has the apt plugin enabled.


These tools are provided as-is and without warranty or support. They do not constitute part of the Software AG product suite. Users are free to use, fork and modify them, subject to the license agreement. While Software AG welcomes contributions, we cannot guarantee to include every contribution in the master project.

For more information you can Ask a Question in the TECH Community Forums.

Contact us at TECHcommunity if you have any questions.