feat: add forgejo runner
This commit is contained in:
parent
d142da727a
commit
46e0d4f573
95
ct/forgejo-runner.sh
Normal file
95
ct/forgejo-runner.sh
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
|
||||||
|
|
||||||
|
# Copyright (c) 2026
|
||||||
|
# Author: Simon Friedrich
|
||||||
|
# License: MIT
|
||||||
|
# Source: https://forgejo.org/
|
||||||
|
|
||||||
|
APP="Forgejo Runner"
|
||||||
|
var_tags="${var_tags:-ci}"
|
||||||
|
var_cpu="${var_cpu:-2}"
|
||||||
|
var_ram="${var_ram:-2048}"
|
||||||
|
var_disk="${var_disk:-8}"
|
||||||
|
var_os="${var_os:-debian}"
|
||||||
|
var_version="${var_version:-12}"
|
||||||
|
|
||||||
|
# REQUIRED for Podman-in-LXC
|
||||||
|
var_unprivileged="1"
|
||||||
|
var_nesting="1"
|
||||||
|
var_keyctl="1"
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Framework setup
|
||||||
|
# -------------------------------------------------
|
||||||
|
header_info "$APP"
|
||||||
|
variables
|
||||||
|
color
|
||||||
|
catch_errors
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Description
|
||||||
|
# -------------------------------------------------
|
||||||
|
function description() {
|
||||||
|
cat <<EOF
|
||||||
|
Forgejo Actions Runner using Podman (unprivileged LXC)
|
||||||
|
|
||||||
|
Required inputs:
|
||||||
|
- Forgejo Instance URL
|
||||||
|
- Forgejo Runner Registration Token
|
||||||
|
|
||||||
|
Requirements:
|
||||||
|
- unprivileged container
|
||||||
|
- nesting enabled
|
||||||
|
- keyctl enabled
|
||||||
|
- unconfined AppArmor profile
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Update logic
|
||||||
|
# -------------------------------------------------
|
||||||
|
function update_script() {
|
||||||
|
header_info
|
||||||
|
check_container_storage
|
||||||
|
check_container_resources
|
||||||
|
|
||||||
|
if [[ ! -f /usr/local/bin/forgejo-runner ]]; then
|
||||||
|
msg_error "No ${APP} installation found!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
msg_info "Stopping Forgejo Runner"
|
||||||
|
systemctl stop forgejo-runner
|
||||||
|
msg_ok "Stopped Forgejo Runner"
|
||||||
|
|
||||||
|
msg_info "Fetching latest Forgejo Runner version"
|
||||||
|
RELEASE=$(curl -fsSL https://code.forgejo.org/api/v1/repos/forgejo/runner/releases/latest \
|
||||||
|
| grep -oP '"tag_name":\s*"\K[^"]+' | sed 's/^v//')
|
||||||
|
|
||||||
|
msg_info "Updating Forgejo Runner to v${RELEASE}"
|
||||||
|
curl -fsSL \
|
||||||
|
"https://code.forgejo.org/forgejo/runner/releases/download/v${RELEASE}/forgejo-runner-linux-amd64" \
|
||||||
|
-o /usr/local/bin/forgejo-runner
|
||||||
|
|
||||||
|
chmod +x /usr/local/bin/forgejo-runner
|
||||||
|
msg_ok "Updated Forgejo Runner"
|
||||||
|
|
||||||
|
msg_info "Starting Forgejo Runner"
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl start forgejo-runner
|
||||||
|
msg_ok "Started Forgejo Runner"
|
||||||
|
|
||||||
|
msg_ok "Update completed successfully!"
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Install
|
||||||
|
# -------------------------------------------------
|
||||||
|
start
|
||||||
|
build_container
|
||||||
|
description
|
||||||
|
|
||||||
|
msg_ok "Completed successfully!"
|
||||||
|
echo -e "${INFO}${YW}Forgejo Runner is now online and ready.${CL}"
|
||||||
140
install/forgejo-runner-install.sh
Normal file
140
install/forgejo-runner-install.sh
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Copyright (c) 2026
|
||||||
|
# Author: Simon Friedrich
|
||||||
|
# License: MIT
|
||||||
|
# Source: https://forgejo.org/
|
||||||
|
|
||||||
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
||||||
|
color
|
||||||
|
verb_ip6
|
||||||
|
catch_errors
|
||||||
|
setting_up_container
|
||||||
|
network_check
|
||||||
|
update_os
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# App-specific input (MUST be before variables)
|
||||||
|
# -------------------------------------------------
|
||||||
|
if [[ -z "$var_forgejo_instance" ]]; then
|
||||||
|
read -rp "Forgejo Instance URL (e.g. https://code.forgejo.org): " var_forgejo_instance
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$var_forgejo_runner_token" ]]; then
|
||||||
|
read -rp "Forgejo Runner Registration Token: " var_forgejo_runner_token
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$var_forgejo_instance" || -z "$var_forgejo_runner_token" ]]; then
|
||||||
|
echo "❌ Forgejo instance URL and runner token are required."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
export FORGEJO_INSTANCE="$var_forgejo_instance"
|
||||||
|
export FORGEJO_RUNNER_TOKEN="$var_forgejo_runner_token"
|
||||||
|
|
||||||
|
msg_info "Installing dependencies"
|
||||||
|
$STD apt-get install -y \
|
||||||
|
curl jq gnupg git wget ca-certificates \
|
||||||
|
podman podman-docker
|
||||||
|
msg_ok "Dependencies installed"
|
||||||
|
|
||||||
|
msg_info "Enabling Podman socket"
|
||||||
|
systemctl enable --now podman.socket
|
||||||
|
msg_ok "Podman socket enabled"
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Architecture
|
||||||
|
# -------------------------------------------------
|
||||||
|
RAW_ARCH=$(uname -m)
|
||||||
|
ARCH=$(echo "$RAW_ARCH" | sed 's/x86_64/amd64/;s/aarch64/arm64/')
|
||||||
|
msg_info "Detected architecture: $ARCH"
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Fetch latest Forgejo Runner version
|
||||||
|
# -------------------------------------------------
|
||||||
|
msg_info "Fetching latest Forgejo Runner release"
|
||||||
|
RUNNER_VERSION=$(
|
||||||
|
curl -fsSL https://data.forgejo.org/api/v1/repos/forgejo/runner/releases/latest |
|
||||||
|
jq -r .name | sed 's/^v//'
|
||||||
|
)
|
||||||
|
|
||||||
|
[[ -z "$RUNNER_VERSION" ]] && {
|
||||||
|
msg_error "Unable to determine Forgejo Runner version"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_ok "Forgejo Runner v${RUNNER_VERSION}"
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Download Runner
|
||||||
|
# -------------------------------------------------
|
||||||
|
FORGEJO_URL="https://code.forgejo.org/forgejo/runner/releases/download/v${RUNNER_VERSION}/forgejo-runner-${RUNNER_VERSION}-linux-${ARCH}"
|
||||||
|
|
||||||
|
msg_info "Downloading Forgejo Runner"
|
||||||
|
wget -q -O /usr/local/bin/forgejo-runner "$FORGEJO_URL"
|
||||||
|
chmod +x /usr/local/bin/forgejo-runner
|
||||||
|
msg_ok "Runner installed"
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Signature verification
|
||||||
|
# -------------------------------------------------
|
||||||
|
msg_info "Verifying signature"
|
||||||
|
wget -q -O /tmp/forgejo-runner.asc "${FORGEJO_URL}.asc"
|
||||||
|
|
||||||
|
GPG_KEY="EB114F5E6C0DC2BCDD183550A4B61A2DC5923710"
|
||||||
|
if ! gpg --list-keys "$GPG_KEY" >/dev/null 2>&1; then
|
||||||
|
gpg --keyserver hkps://keys.openpgp.org --recv "$GPG_KEY" >/dev/null 2>&1
|
||||||
|
fi
|
||||||
|
|
||||||
|
gpg --verify /tmp/forgejo-runner.asc /usr/local/bin/forgejo-runner >/dev/null 2>&1 \
|
||||||
|
&& msg_ok "Signature valid" \
|
||||||
|
|| { msg_error "Signature verification failed"; exit 1; }
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Runner registration
|
||||||
|
# -------------------------------------------------
|
||||||
|
msg_info "Registering Forgejo Runner"
|
||||||
|
|
||||||
|
export DOCKER_HOST="unix:///run/podman/podman.sock"
|
||||||
|
|
||||||
|
forgejo-runner register \
|
||||||
|
--instance "$FORGEJO_INSTANCE" \
|
||||||
|
--token "$FORGEJO_RUNNER_TOKEN" \
|
||||||
|
--name "$HOSTNAME" \
|
||||||
|
--labels "linux-${ARCH}:docker://node:20-bookworm" \
|
||||||
|
--no-interactive
|
||||||
|
|
||||||
|
msg_ok "Runner registered"
|
||||||
|
|
||||||
|
# -------------------------------------------------
|
||||||
|
# systemd service
|
||||||
|
# -------------------------------------------------
|
||||||
|
msg_info "Creating systemd service"
|
||||||
|
|
||||||
|
cat <<EOF >/etc/systemd/system/forgejo-runner.service
|
||||||
|
[Unit]
|
||||||
|
Description=Forgejo Runner
|
||||||
|
Documentation=https://forgejo.org/docs/latest/admin/actions/
|
||||||
|
After=podman.socket
|
||||||
|
Requires=podman.socket
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=root
|
||||||
|
WorkingDirectory=/root
|
||||||
|
Environment=DOCKER_HOST=unix:///run/podman/podman.sock
|
||||||
|
ExecStart=/usr/local/bin/forgejo-runner daemon
|
||||||
|
Restart=on-failure
|
||||||
|
RestartSec=10
|
||||||
|
TimeoutSec=0
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable --now forgejo-runner
|
||||||
|
msg_ok "Forgejo Runner service enabled"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
cleanup_lxc
|
||||||
Loading…
x
Reference in New Issue
Block a user