GitHub Action
Create OTA Release
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).
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 }}
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" |