89 lines
2.8 KiB
YAML
89 lines
2.8 KiB
YAML
name: 🐳 Build Ansible Act Runner Image
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- main
|
|
paths:
|
|
- 'docker/Dockerfile'
|
|
workflow_dispatch:
|
|
inputs:
|
|
force_rebuild:
|
|
description: 'Force rebuild without cache'
|
|
required: false
|
|
default: 'false'
|
|
type: boolean
|
|
|
|
jobs:
|
|
build:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: 🔎 Checkout
|
|
uses: actions/checkout@v4
|
|
|
|
- name: 🐳 Install Docker CLI
|
|
run: |
|
|
apt-get update && apt-get install -y --no-install-recommends \
|
|
ca-certificates \
|
|
curl \
|
|
gnupg
|
|
install -m 0755 -d /etc/apt/keyrings
|
|
curl -fsSL https://download.docker.com/linux/debian/gpg \
|
|
-o /etc/apt/keyrings/docker.asc
|
|
chmod a+r /etc/apt/keyrings/docker.asc
|
|
echo "deb [arch=$(dpkg --print-architecture) \
|
|
signed-by=/etc/apt/keyrings/docker.asc] \
|
|
https://download.docker.com/linux/debian \
|
|
$(. /etc/os-release && echo "$VERSION_CODENAME") stable" \
|
|
> /etc/apt/sources.list.d/docker.list
|
|
apt-get update && apt-get install -y --no-install-recommends docker-ce-cli
|
|
|
|
- name: 🏷️ Set Image Tags
|
|
id: tags
|
|
run: |
|
|
REGISTRY="gitea.mod.home"
|
|
ORG="${{ gitea.repository_owner }}"
|
|
IMAGE="ansible-act-runner"
|
|
SHORT_SHA="${{ gitea.sha }}"
|
|
SHORT_SHA="${SHORT_SHA:0:8}"
|
|
|
|
echo "tag_latest=${REGISTRY}/${ORG}/${IMAGE}:latest" >> $GITHUB_OUTPUT
|
|
echo "tag_sha=${REGISTRY}/${ORG}/${IMAGE}:${SHORT_SHA}" >> $GITHUB_OUTPUT
|
|
echo "short_sha=${SHORT_SHA}" >> $GITHUB_OUTPUT
|
|
|
|
- name: 🐳 Docker Login → Gitea Registry
|
|
run: |
|
|
echo "${{ secrets.REGISTRY_PASSWORD }}" | \
|
|
docker login gitea.mod.home \
|
|
--username "${{ secrets.REGISTRY_USER }}" \
|
|
--password-stdin
|
|
|
|
- name: 🐳 Build Image
|
|
run: |
|
|
BUILD_ARGS=""
|
|
if [ "${{ inputs.force_rebuild }}" = "true" ]; then
|
|
BUILD_ARGS="--no-cache"
|
|
fi
|
|
|
|
docker build ${BUILD_ARGS} \
|
|
-t ${{ steps.tags.outputs.tag_latest }} \
|
|
-t ${{ steps.tags.outputs.tag_sha }} \
|
|
-f docker/Dockerfile \
|
|
docker/
|
|
|
|
- name: 🐳 Push Image
|
|
run: |
|
|
docker push ${{ steps.tags.outputs.tag_latest }}
|
|
docker push ${{ steps.tags.outputs.tag_sha }}
|
|
|
|
- name: 📨 Telegram Notification
|
|
run: |
|
|
STATUS="${{ job.status }}"
|
|
TEXT="🐳 Build: ansible-act-runner:${{ steps.tags.outputs.short_sha }}%0AStatus: ${STATUS}"
|
|
curl -s -X POST \
|
|
"https://api.telegram.org/bot${{ secrets.TELEGRAM_BOT_TOKEN }}/sendMessage" \
|
|
-d "chat_id=${{ secrets.TELEGRAM_CHAT_ID }}" \
|
|
-d "text=${TEXT}"
|
|
if: always()
|