initial commit: build and publish actions for arch

This commit is contained in:
Carlos Galindo 2026-06-10 22:00:09 +02:00
commit 18f3e90d1e
2 changed files with 78 additions and 0 deletions

40
build-pkg/action.yml Normal file
View file

@ -0,0 +1,40 @@
name: 'Build ArchLinux package'
author: 'Carlos Galindo'
description: |
Builds an ArchLinux package in a container. Setups the container
with a build user, checks out the repository, imports required gpg
keys, builds and uploads the package as an artifact.
inputs:
extra_pkgs:
description: "Additional packages to be installed"
default: ""
gpg_keys:
description: "GPG keys to import in order to check signatures"
default: ""
runs:
using: 'composite'
steps:
- id: container_preparation
name: Install build tools
run: |
echo "##[group]Installing dependencies"
pacman -Sy --noconfirm --noprogressbar git sudo nodejs ${{ inputs.extra_pkgs }}
echo "##[endgroup]"
useradd --create-home --shell=/bin/false builder && usermod --lock builder
echo 'builder ALL = NOPASSWD: /usr/bin/pacman' >> /etc/sudoers
- uses: actions/checkout@v6
- id: makepkg
name: Build the package
run: |
chown -R builder:builder $FORGEJO_WORKSPACE
if [ ! -z "${{ inputs.gpg_keys }}" ]; then
sudo -u builder gpg --receive-keys ${{ inputs.gpg_keys }}
fi
sudo -u builder makepkg --dir $FORGEJO_WORKSPACE --syncdeps --noconfirm --noprogressbar
- uses: actions/upload-artifact@v3
with:
name: packages
path: '*.pkg.tar.zst'

38
publish-pkg/action.yml Normal file
View file

@ -0,0 +1,38 @@
name: 'Publish ArchLinux package'
author: 'Carlos Galindo'
description: |
Publishes an already-built package to Forgejo.
inputs:
repo_name:
description: 'Name of the repository'
default: 'pkgs'
PKG_TOKEN:
description: 'Token with package:write permissions'
required: true
runs:
using: 'composite'
steps:
- uses: actions/download-artifact@v3
- id: publish_package
name: Publish the package(s)
run: |
set -x
echo "::add-mask::${{ inputs.PKG_TOKEN }}"
ls packages | while read; do
echo "##[group]Uploading package $REPLY"
curl -X PUT $FORGEJO_SERVER_URL/api/packages/$FORGEJO_REPOSITORY_OWNER/arch/${{ inputs.repo_name }} \
-H "Authorization: token ${{ inputs.PKG_TOKEN }}" \
-H 'Content-Type: application/octet-stream' \
--data-binary "@packages/$REPLY" \
--fail-with-body --no-progress-meter
echo "##[endgroup]"
PKGNAME=$(echo $REPLY | rev | cut -d/ -f1 | cut -d- -f4- | rev)
REPO_NAME=$(echo $FORGEJO_REPOSITORY | rev | cut -d/ -f1 | rev)
echo "##[group]Linking $PKGNAME to $REPO_NAME"
curl -X POST $FORGEJO_API_URL/packages/$FORGEJO_REPOSITORY_OWNER/arch/$PKGNAME/-/link/$REPO_NAME \
-H "Authorization: token ${{ inputs.PKG_TOKEN }}" \
--no-progress-meter
echo "##[endgroup]"
done