Raspberry Pi SD card image build for the Web of Things gateway.
Use the trigger-build.py
script to initiate a build. Modifying
any of the files in this repository and pushing them will also
trigger a build using the defaults specified in config.sh
.
The trigger-build.py
will trigger a GitHub workflow to start
building an image. You can check the progress by watching
https://github.com/mozilla-iot/rpi-image-builder/actions
The trigger-build.py
script takes the following arguments:
The --token option specifies the GitHub API token, which can be generated here: https://github.com/settings/tokens
The --repo
option specifies the git repository that the
gateway should be cloned from. If this option is not
specified, then the GATEWAY_REPO
found in config.sh
will
be used (https://github.com/mozilla-iot/gateway)
The --branch
specifies the branch name or tag name used to
checkou the gateway code from the git repository. This option
is required.
The --prefix
specifies the prefix to prepend to the
gateway.tar.gz
file which is generated.
Follow these steps on the wiki to create a base image.
- Download/clone rpi-image-builder
$ git clone https://github.com/benfrancis/rpi-image-builder.git
- Install the Python requests library
$ pip3 install requests
Use the trigger-build.py
script (documented above) to build the
gateway.tar.gz
file, e.g. from the rpi-image-builder directory:
$ ./trigger-build.py --token <token> --branch master --prefix 0.10.0-pre1
This will put these files (with the assigned prefix) onto AWS in a
directory called tarfiles
. You can use the following command to see
the generated files:
aws s3 ls s3://mozillagatewayimages/tarfiles/
You can either use aws commands:
aws s3 cp s3://mozillagatewayimages/tarfiles/PREFIX-gateway.tar.gz .
or you can use URLs like these:
https://s3-us-west-1.amazonaws.com/mozillagatewayimages/tarfiles/PREFIX-gateway.tar.gz
Run the add-gateway.sh
script found in the image
directory of the
gateway repository
./add-gateway.sh -g PREFIX-gateway.tar.gz gateway-VERSION-base.img
The output image file will have the same name as the base image with -base
removed.
Use the image-to-aws.sh
script found in the image
directory of the
gateway repository
./image-to-aws.sh gateway-VERSION.img
You can then access the image using a URL like this:
https://s3-us-west-1.amazonaws.com/mozillagatewayimages/images/gateway-VERSION.img.zip
https://s3-us-west-1.amazonaws.com/mozillagatewayimages/images/gateway-VERSION.img.zip.sha256sum