Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
upload-cloud

GitHub Action

Create OTA Release

v1.1.0

Create OTA Release

upload-cloud

Create OTA Release

Creates OTA update releases

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Create OTA Release

uses: thistletech/ota-release-action@v1.1.0

Learn more about this action in thistletech/ota-release-action

Choose a version

ota-release-action: OTA Update Action with Thistle

Thistle Technologies provides a software solution to over-the-air (OTA) updates for embedded devices. This action creates an OTA update release, and publishes it to Thistle's backend platform, to update devices running the Thistle Update Client (TUC).

Example Usage

To use this action, one needs to create an account in the Thistle Control Center, and obtain the API token ("Project Access Token"). In case a locally managed OTA update signing key is used (which is the only supported option currently), one also needs to go through the Configuration step to create a password-protected Minisign private key with the trh init command.

An example workflow for file update is as follows. Confidential information, such as the aforementioned project access token, private signing key, and signing key password are saved as GitHub repository secrets.

name: 'OTA Release'

on:
  push:
    tags:
      # Trigger release by tagging
      - 'release-v*'

jobs:
  ota_release:
    name: 'OTA Release'
    runs-on: 'ubuntu-latest'
    steps:
      - name: 'Checkout source'
        uses: 'actions/checkout@v4'
    
      - name: 'Create artifacts for OTA release'
        run: |
          ...
          [build artifacts from source]
          [run tests on artifacts]
          ...
          rm -rf artifacts
          mkdir -p artifacts
          ...
          [copy built artifacts to directory artifacts/]
          ...

      - name: 'OTA Release'
        uses: 'thistletech/ota-release-action@v1'
        with:
          release_name: 'OPTIONAL RELEASE NAME'
          release_type: 'file'
          persist_dir: '/tmp/persist'
          artifacts_dir: 'artifacts'
          base_install_path_on_device: '/tmp/ota'
          project_access_token: ${{ secrets.PROJECT_ACCESS_TOKEN }}
          signing_key_management: 'local'
          signing_key: ${{ secrets.SIGNING_KEY }}
          signing_key_password: ${{ secrets.SIGNING_KEY_PASSWORD }}

For rootfs update, configure the "OTA Release" step as

      - name: 'OTA Release'
        uses: 'thistletech/ota-release-action@v1'
        with:
          release_name: 'OPTIONAL RELEASE NAME'
          release_type: 'rootfs'
          persist_dir: '/tmp/persist'
          rootfs_img_path: '/path/to/rootfs.img'
          project_access_token: ${{ secrets.PROJECT_ACCESS_TOKEN }}
          signing_key_management: 'local'
          signing_key: ${{ secrets.SIGNING_KEY }}
          signing_key_password: ${{ secrets.SIGNING_KEY_PASSWORD }}

For zip archive update, configure the "OTA Release" step as

      - name: 'OTA Release'
        uses: 'thistletech/ota-release-action@v1'
        with:
          release_name: 'OPTIONAL RELEASE NAME'
          release_type: 'zip_archive'
          persist_dir: '/tmp/persist'
          zip_archive_dir: '/path/to/uncompressed_artifacts_dir'
          base_install_path_on_device: '/tmp/ota'
          project_access_token: ${{ secrets.PROJECT_ACCESS_TOKEN }}
          signing_key_management: 'local'
          signing_key: ${{ secrets.SIGNING_KEY }}
          signing_key_password: ${{ secrets.SIGNING_KEY_PASSWORD }}

Inputs

INPUT TYPE REQUIRED DEFAULT DESCRIPTION
artifacts_dir string false Path to the directory where
OTA update artifacts are stored
base_install_path_on_device string false Path to base directory on
device file system where OTA
update artifacts will be installed.
Required if release_type is "file"
or "zip_archive"
persist_dir string true Path to the directory where
the device can persist data
project_access_token string true Project access token can be
obtained from the project settings
page in Thistle Control Center
release_name string false Display name of the release.
If not provided or empty,
the unique manifest ID will
be used
release_type string true "file" Release type ("file", "zip_archive", or "rootfs")
rootfs_img_path string false Path to the rootfs image
file. Required only if release_type
is "rootfs"
signing_key string false Minisign signing key in Thistle
format. Required only if signing_key_management
is "local"
signing_key_management string true "local" Indicates how the signing key
is managed ("local" or "remote")
signing_key_password string false Password for the signing key.
Required only if signing_key_management is
"local" and the signing key
is password protected
zip_archive_dir string false Path to the directory whose
content will be zipped before
releasing. Required only if release_type
is "zip_archive"