This repository provides a command line interface wizard for easily onboarding IoT things to AWS IoT core, thing group management, and OTA job creation. This library is distributed under the Apache-2.0 Open Source License.
This package currently has 4 source files:
-
aws_operations.py
is a wrapper for each AWS SDK call -
utils.py
helps handle input and output -
setup_ota_update.py
runs infrastructure setup for the user. This is the entry point of the script.- When resources are created or configured, the configuration gets written to
config.json
.
- When resources are created or configured, the configuration gets written to
-
run_ota_update.py
is a wrapper for CreateOTAUpdate API and reads fromconfig.json
to get the input needed for it.
Once Python is installed, run pip install pipenv
to install pipenv, enabling you to optionally create a virtual environment for the project via pipenv shell
and use the pipfile to install dependencies via the pipenv install
command.
MacOS OpenSSL Installation:
brew update
brew install openssl
echo 'export PATH="/usr/local/opt/openssl/bin:$PATH"' >> ~/.zshrc
source ~/.zshrc
Ubuntu OpenSSL Installation:
sudo apt update
sudo apt install openssl
Follow the instructions here to create an AWS account.
Follow the instructions here to set up AWS CLI.
This documentation page describes how to run an Over-the-Air (OTA) update agent as one of the RTOS tasks that share the same MQTT connection.
To run this tool, you must first configure your AWS credentials. To see how to do this, refer to the following here. For example, in the terminal, run this with your configured credentials:
export AWS_ACCESS_KEY_ID=AKIAIOSFODNN7EXAMPLE
export AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
export AWS_DEFAULT_REGION=us-west-2
After configuring your CLI credentials in your preferred method, simply run the following:
python3 setup-ota-update.py
This will take you through setting up the infrastructure for an OTA update. You will be prompted if you want to create a new resource or use an existing one for each needed resource, such as IAM roles, S3 buckets, Code signing profiles, etc.
If you generate an OpenSSL certificate through the wizard, you will have two files in your directory, ecdsasigner-priv-key.pem
and ecdsasigner.crt
. You should make sure that your device is signed with the private key file, or else the OTA update will not succeed.
When you are ready, simply run
python3 run-ota-update.py
Which will create the OTA update. You should go into your account or use the CLI to view the status of the update.