Skip to content

Instantly share code, notes, and snippets.

View reubenmiller's full-sized avatar

Reuben Miller reubenmiller

  • Hamburg, Germany
View GitHub Profile
#!/bin/bash
#
# 1. Pipe a list of ESNs from a file and create a c8y_Command (shell) operation for each device (using go-c8y-cli piping)
# A unique batch marker is used to group the operations together (to make querying for the operation easier)
# 2. Poll the created operations ()
# 3. Print out a summary of how many operations failed and how man were successful
#
# Input file:
# * esn.txt - Newline delimited file containing one ESN per line (file must have an empty line at the end, otherwise the last ESN might be skipped)
#
@reubenmiller
reubenmiller / README.md
Last active March 11, 2024 09:49
Update Cumulocity Location using thin-edge.io

Updating the location information in Cumulocity IoT should not be a problem with thin-edge.io.

For reference, I created the options by reading the following Cumulocity IoT documentation links:

In summary, updating a location of a device (in the backend) involves creating an event and then updating a fragment on the device's managed object, however you have a few different options on how to achieve this with thin-edge.io:

@reubenmiller
reubenmiller / README.md
Last active October 22, 2024 07:03
Only install specific thin-edge.io version

To install a specific version of thin-edge.io on a Debian based operating system, you will have to use APT Package Pinning, as the tedge-full package is a virtual package, and installing a specific version of the virtual package does not transfer to the package's dependencies (unfortunately).

Below shows how the exact thin-edge.io version can be installed.

  1. Create a debian package pin definition for thin-edge.io

    Create the following file:

sudo vi /etc/apt/preferences.d/tedge

@reubenmiller
reubenmiller / tedge.workflow.json
Last active May 22, 2024 15:16
draft: thin-edge.io workflow schema
{
"$schema": "http://json-schema.org/draft-04/schema#",
"$id": "https://thin-edge.io/workflow.json",
"title": "thin-edge.io workflow",
"description": "Workflows can be used to customize existing operations and add user defined processes which are coordinated by thin-edge.io",
"type": "object",
"definitions": {
"on_state": {
"oneOf": [
{
@reubenmiller
reubenmiller / tedge-workflow-punchlist.md
Last active November 27, 2023 16:33
WIP: thin-edge.io workflow punchlist (firmware update)

1. restart state file is not being deleted (after image has been restarted)

After a successfully completed firmware workflow, if the tedge-agent service is restarted, then tedge-agent will reprocess the restart-current-operation file again as the file is not deleted after the workflow has been completed.

file: /data/tedge/.agent/restart-current-operation

// cat /data/tedge/.agent/restart-current-operation
{"target":"device/main//","cmd_id":"c8y-mapper-2023-11-26T12:26:39.248420821Z","payload":{"status":"executing","context":{"command":{"topic":{"name":"te/device/main///cmd/firmware_update/c8y-mapper-2023-11-26T12:26:39.248420821Z"},"status":"rollback_restart","payload":{"name":"core-image-tedge-mender-raspberrypi4-64","reason":"Nothing to commit. Either the boot loader triggered the rollback, the device was rebooted after switching to new partition, or someone did a manual rollback!","remoteUrl":"https://t2873877.latest.stage.c8y.io/inventory/binaries/4785008","status":"rollback_restart","
@reubenmiller
reubenmiller / copy_managed_objects.md
Created November 15, 2023 08:54
go-c8y-cli: copy managed objects across tenants

Copy managed objects across tenants

Long Version

  1. Activate a session to the source tenant

    set-session
    
@reubenmiller
reubenmiller / c8y-custom-operation-handler.md
Created November 11, 2023 19:49
thin-edge.io - custom operation handler guide

Before creating a custom operation handler, create the configuration and confirm that the operation will be delivered to the device. Once you have confirm this, then you can add your custom handler.

Part 1: Send operations from Cumulocity IoT to thin-edge.io

Below shows the steps to create a custom SmartREST collection for Cumulocity IoT, and how to check that the message arrives on the local thin-edge.io MQTT broker.

  1. Create a SmartREST template collection in Cumulocity IoT, and create a custom "response"

    Below is an example collection which create two custom operations for the message ids:

@reubenmiller
reubenmiller / debug-qos-issue.sh
Last active November 5, 2023 18:31
thin-edge.io script to debug an issue with the tedge-mapper-c8y and jwt request
#!/bin/bash
########################################################################################################################
# Debug script to check the behaviour of the tedge-mapper-c8y/mosquitto and the responsiveness of the
# Cumulocity IoT token request/response topics (c8y/s/uat and c8y/s/dat).
#
# The script does the following:
# 1. Install a systemd service (and enables it)
# 2. Create mqtt subscriber to c8y/s/dat
# 3. Publish a mqtt message to c8y/s/uat
# 4. Wait for a message on the c8y/s/dat topic (give up after a few seconds)
@reubenmiller
reubenmiller / thin-edge.io-custom-topic-schema.md
Created November 3, 2023 14:47
thin-edge.io custom topic schema example

Using custom topic schema with thin-edge.io (>= 0.13.0)

This is a short informal overview of how to use thin-edge.io and a custom topic schema to model different IoT use-cases.

This documentation is provided to help people understand thin-edge.io and to provide some early feedback before adding it to the official docs.

Building management system

This example explores the building management system use-case where thin-edge.io provides the communication from the cloud to a local piece of software which translates the thin-edge.io MQTT API to the required building management system API calls.