Tooling to build and distribute Manjaro on via Github Actions
This action ...
- installs the prerequisites to build Manjaro
- builds a ready to go Manjaro iso
- calculates hashes for the resulting image
It optionally provides:
- GPG-signing
- Distribution to Github Releases
The following example is a minimal "matrix strategy" setup, that builds minimal and full images for cinnamon, gnome and builds the images each on stable and testing repositories. Refer here for more information on including / excluding permutations from matrix strategies.
All configuration options and defaults can be found here.
Instead of manjaro/manjaro-iso-action@main
, please refer to the most current release (e.g. manjaro/manjaro-iso-action@v1
).
name: iso_build
on:
workflow_dispatch:
# remove if you don't want to build on a schedule
schedule:
- cron: '30 6 1 * *'
# remove if you don't want to build when commits are pushed to you main/master branch
push:
branches:
- master
- main
jobs:
prepare-release:
runs-on: ubuntu-20.04
steps:
# cancel already running instances of the same action on the currently working on branch
- uses: styfle/cancel-workflow-action@0.9.0
with:
access_token: ${{ github.token }}
- id: time
uses: nanzm/get-time-action@v1.1
with:
format: 'YYYYMMDDHHmm'
outputs:
# generate a common tag to be used in all elements of the matrix strategy
release_tag: ${{ steps.time.outputs.time }}
release:
runs-on: ubuntu-20.04
needs: prepare-release
strategy:
matrix:
##### EDIT ME #####
EDITION: [cinnamon, gnome]
BRANCH: [stable, testing]
SCOPE: [minimal,full]
###################
steps:
# cancel already running instances of the same action on the currently working on branch
- uses: styfle/cancel-workflow-action@0.9.0
with:
access_token: ${{ github.token }}
- id: image-build
uses: manjaro/manjaro-iso-action@main
with:
edition: ${{ matrix.edition }}
branch: ${{ matrix.branch }}
scope: ${{ matrix.scope }}
version: "21.0"
kernel: linux510
code-name: "Ornara"
# providing a release-tag allows for github releases
release-tag: ${{ needs.prepare-release.outputs.release_tag }}
# delete the github release in case of cancellation or failure
# refer to .github/workflows/cleanup-test-release.yml for rollback strategies concerning the other distribution channels
- name: rollback github release
if: ${{ failure() || cancelled() }}
run: |
echo ${{ github.token }} | gh auth login --with-token
gh release delete ${{ needs.prepare-release.outputs.release_tag }} -y --repo ${{ github.repository }}
git push --delete origin ${{ needs.prepare-release.outputs.release_tag }}
- id: image-build
uses: manjaro/manjaro-iso-action@main
with:
...
gpg-secret-key-base64: ${{ secrets.gpg_secret_base64 }}
gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }}
to get an idea how caching might work, please refer here
all distribution channels can be configured by setting / leaving out of their configuration variables.
- id: image-build
uses: manjaro/manjaro-iso-action@main
with:
...
release-tag: ${{ needs.prepare-release.outputs.release_tag }}
- name: rollback github release
if: ${{ failure() || cancelled() }}
run: |
echo ${{ github.token }} | gh auth login --with-token
gh release delete ${{ needs.prepare-release.outputs.release_tag }} -y --repo ${{ github.repository }}
git push --delete origin ${{ needs.prepare-release.outputs.release_tag }}