358 lines
12 KiB
YAML
358 lines
12 KiB
YAML
name: Release Plugin
|
||
|
||
on:
|
||
push:
|
||
tags:
|
||
- 'v*'
|
||
|
||
jobs:
|
||
release:
|
||
runs-on: alpine-latest
|
||
defaults:
|
||
run:
|
||
shell: bash
|
||
|
||
steps:
|
||
- name: Notwendige Abhängigkeiten installieren
|
||
shell: sh
|
||
run: |
|
||
apk add --no-cache git zip curl jq rsync bash
|
||
git config --global http.sslVerify false
|
||
|
||
- name: Code holen
|
||
run: |
|
||
# Tag aus GitHub Actions Kontext extrahieren
|
||
TAG="${GITHUB_REF#refs/tags/}"
|
||
echo "DEBUG | Tag erkannt: $TAG"
|
||
|
||
# Repo-URL dynamisch aus vars und github.repository bauen
|
||
REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git"
|
||
echo "DEBUG | Klone von: $REPO_URL"
|
||
|
||
# Repository klonen
|
||
git clone "$REPO_URL" repo
|
||
cd repo
|
||
|
||
git checkout "$TAG"
|
||
env:
|
||
RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }}
|
||
|
||
- name: Version und Kanal bestimmen
|
||
id: releaseinfo
|
||
run: |
|
||
TAG="${{ github.ref_name }}"
|
||
VERSION="${TAG#v}"
|
||
|
||
case "$TAG" in
|
||
*-unstable*) CHANNEL="unstable" ;;
|
||
*-testing*) CHANNEL="testing" ;;
|
||
*) CHANNEL="stable" ;;
|
||
esac
|
||
|
||
echo "version=${VERSION}" >> $GITHUB_OUTPUT
|
||
echo "channel=${CHANNEL}" >> $GITHUB_OUTPUT
|
||
|
||
echo "DEBUG | Version: $VERSION"
|
||
echo "DEBUG | Kanal: $CHANNEL"
|
||
|
||
# - name: metadata.txt erzeugen
|
||
# run: |
|
||
# cd repo
|
||
|
||
# VERSION="${{ steps.releaseinfo.outputs.version }}"
|
||
|
||
# # Vorlage kopieren
|
||
# cp .plugin/metadata.template metadata.txt
|
||
|
||
# # Platzhalter ersetzen
|
||
# sed -i "s/@VERSION@/${VERSION}/g" metadata.txt
|
||
|
||
# echo "DEBUG | metadata.txt erzeugt:"
|
||
# cat metadata.txt
|
||
|
||
- name: plugin.info einlesen
|
||
id: info
|
||
run: |
|
||
cd repo
|
||
while IFS='=' read -r key value; do
|
||
echo "$key=$value" >> $GITHUB_OUTPUT
|
||
done < plugin.info
|
||
|
||
echo "DEBUG | plugin.info geladen:"
|
||
cat plugin.info
|
||
|
||
- name: metadata.txt erzeugen
|
||
run: |
|
||
cd repo
|
||
|
||
TEMPLATE="templates/metadata.template"
|
||
OUT="metadata.txt"
|
||
|
||
CONTENT=$(cat "$TEMPLATE")
|
||
|
||
CONTENT="${CONTENT//\{\{NAME\}\}/${{ steps.info.outputs.name }}}"
|
||
CONTENT="${CONTENT//\{\{QGIS_MIN\}\}/${{ steps.info.outputs.qgisMinimumVersion }}}"
|
||
CONTENT="${CONTENT//\{\{QGIS_MAX\}\}/${{ steps.info.outputs.qgisMaximumVersion }}}"
|
||
CONTENT="${CONTENT//\{\{DESCRIPTION\}\}/${{ steps.info.outputs.description }}}"
|
||
CONTENT="${CONTENT//\{\{VERSION\}\}/${{ steps.releaseinfo.outputs.version }}}"
|
||
CONTENT="${CONTENT//\{\{AUTHOR\}\}/${{ steps.info.outputs.author }}}"
|
||
CONTENT="${CONTENT//\{\{EMAIL\}\}/${{ steps.info.outputs.email }}}"
|
||
CONTENT="${CONTENT//\{\{HOMEPAGE\}\}/${{ steps.info.outputs.homepage }}}"
|
||
CONTENT="${CONTENT//\{\{TRACKER\}\}/${{ steps.info.outputs.tracker }}}"
|
||
CONTENT="${CONTENT//\{\{REPOSITORY\}\}/${{ steps.info.outputs.repository }}}"
|
||
CONTENT="${CONTENT//\{\{EXPERIMENTAL\}\}/${{ steps.info.outputs.experimental }}}"
|
||
CONTENT="${CONTENT//\{\{DEPRECATED\}\}/${{ steps.info.outputs.deprecated }}}"
|
||
CONTENT="${CONTENT//\{\{QT6\}\}/${{ steps.info.outputs.supportsQt6 }}}"
|
||
|
||
printf "%s\n" "$CONTENT" > "$OUT"
|
||
|
||
echo "DEBUG | metadata.txt erzeugt:"
|
||
cat metadata.txt
|
||
|
||
# - name: ZIP-Datei erstellen
|
||
# id: zip
|
||
# run: |
|
||
# cd repo
|
||
|
||
# # Plugin-Ordnername aus .plugin/zip_folder lesen
|
||
# ZIP_FOLDER=$(cat .plugin/zip_folder)
|
||
# echo "DEBUG | Plugin-Ordnername: $ZIP_FOLDER"
|
||
|
||
# VERSION="${{ steps.releaseinfo.outputs.version }}"
|
||
# REPO_NAME="${GITHUB_REPOSITORY##*/}"
|
||
# ZIP_NAME="${REPO_NAME}-${VERSION}.zip"
|
||
|
||
# echo "DEBUG | ZIP wird erzeugt: $ZIP_NAME"
|
||
|
||
# # Temporären Build-Ordner anlegen
|
||
# mkdir -p dist/${ZIP_FOLDER}
|
||
|
||
# # Plugin-Dateien kopieren (alles außer CI-/Meta-Verzeichnisse)
|
||
# rsync -a \
|
||
# --exclude='.git' \
|
||
# --exclude='.gitea' \
|
||
# --exclude='.plugin' \
|
||
# --exclude='dist' \
|
||
# ./ dist/${ZIP_FOLDER}/
|
||
|
||
# # ZIP erzeugen
|
||
# cd dist
|
||
# zip -r "${ZIP_NAME}" "${ZIP_FOLDER}/" \
|
||
# -x "*.pyc" -x "*/__pycache__/*"
|
||
# cd ..
|
||
|
||
# # ZIP-Name für spätere Steps bereitstellen
|
||
# echo "zip_name=${ZIP_NAME}" >> $GITHUB_OUTPUT
|
||
|
||
# echo "DEBUG | ZIP-Datei erzeugt: dist/${ZIP_NAME}"
|
||
|
||
- name: ZIP-Datei erstellen
|
||
id: zip
|
||
run: |
|
||
cd repo
|
||
|
||
ZIP_FOLDER="${{ steps.info.outputs.zip_folder }}"
|
||
echo "DEBUG | Plugin-Ordnername: $ZIP_FOLDER"
|
||
|
||
VERSION="${{ steps.releaseinfo.outputs.version }}"
|
||
REPO_NAME="${GITHUB_REPOSITORY##*/}"
|
||
ZIP_NAME="${REPO_NAME}-${VERSION}.zip"
|
||
|
||
echo "DEBUG | ZIP wird erzeugt: $ZIP_NAME"
|
||
|
||
mkdir -p dist/${ZIP_FOLDER}
|
||
|
||
rsync -a \
|
||
--exclude='.git' \
|
||
--exclude='.gitea' \
|
||
--exclude='.plugin' \
|
||
--exclude='dist' \
|
||
./ dist/${ZIP_FOLDER}/
|
||
|
||
cd dist
|
||
zip -r "${ZIP_NAME}" "${ZIP_FOLDER}/" \
|
||
-x "*.pyc" -x "*/__pycache__/*"
|
||
cd ..
|
||
|
||
echo "zip_name=${ZIP_NAME}" >> $GITHUB_OUTPUT
|
||
|
||
- name: Gitea‑Release erstellen
|
||
id: create_release
|
||
run: |
|
||
TAG="${{ github.ref_name }}"
|
||
VERSION="${{ steps.releaseinfo.outputs.version }}"
|
||
CHANNEL="${{ steps.releaseinfo.outputs.channel }}"
|
||
|
||
echo "Erstelle Release für Tag: $TAG"
|
||
echo "Version: $VERSION"
|
||
echo "Kanal: $CHANNEL"
|
||
|
||
API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${GITHUB_REPOSITORY}/releases"
|
||
|
||
# JSON‑Body erzeugen
|
||
JSON=$(jq -n \
|
||
--arg tag "$TAG" \
|
||
--arg name "Version $VERSION" \
|
||
--arg body "Automatisch erzeugtes Release für Kanal: $CHANNEL" \
|
||
'{tag_name: $tag, name: $name, body: $body, draft: false, prerelease: false}')
|
||
|
||
echo "Sende API‑Request an: $API_URL"
|
||
echo "JSON‑Payload:"
|
||
echo "$JSON"
|
||
|
||
# Release erstellen
|
||
API_RESPONSE=$(curl -s -X POST "$API_URL" \
|
||
-H "accept: application/json" \
|
||
-H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \
|
||
-H "Content-Type: application/json" \
|
||
-d "$JSON")
|
||
|
||
RELEASE_ID=$(echo "$API_RESPONSE" | jq -r '.id')
|
||
|
||
if [ "$RELEASE_ID" = "null" ] || [ -z "$RELEASE_ID" ]; then
|
||
echo "Fehler beim Erstellen des Releases!"
|
||
echo "API‑Antwort:"
|
||
echo "$API_RESPONSE"
|
||
exit 1
|
||
fi
|
||
|
||
echo "Release erfolgreich erstellt. ID: $RELEASE_ID"
|
||
echo "release_id=$RELEASE_ID" >> $GITHUB_OUTPUT
|
||
|
||
- name: ZIP-Datei hochladen
|
||
run: |
|
||
RELEASE_ID="${{ steps.create_release.outputs.release_id }}"
|
||
ZIP_NAME="${{ steps.zip.outputs.zip_name }}"
|
||
|
||
echo "Lade ZIP-Datei hoch: $ZIP_NAME"
|
||
echo "Release-ID: $RELEASE_ID"
|
||
|
||
API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${GITHUB_REPOSITORY}/releases/${RELEASE_ID}/assets?name=${ZIP_NAME}"
|
||
|
||
curl -s -X POST "$API_URL" \
|
||
-H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \
|
||
-H "Content-Type: application/zip" \
|
||
--data-binary "@repo/dist/${ZIP_NAME}" \
|
||
-o upload_response.json
|
||
|
||
echo "Upload-Antwort:"
|
||
cat upload_response.json
|
||
|
||
# Optional: Fehlerprüfung
|
||
if jq -e '.id' upload_response.json >/dev/null 2>&1; then
|
||
echo "ZIP erfolgreich hochgeladen."
|
||
else
|
||
echo "Fehler beim Hochladen der ZIP!"
|
||
exit 1
|
||
fi
|
||
|
||
# - name: Payload erzeugen
|
||
# run: |
|
||
# cd repo
|
||
|
||
# PLUGIN_NAME=$(grep '^name=' metadata.txt | cut -d '=' -f2)
|
||
# DESCRIPTION=$(grep '^description=' metadata.txt | cut -d '=' -f2)
|
||
# AUTHOR=$(grep '^author=' metadata.txt | cut -d '=' -f2)
|
||
# EMAIL=$(grep '^email=' metadata.txt | cut -d '=' -f2)
|
||
|
||
# VERSION="${{ steps.releaseinfo.outputs.version }}"
|
||
# CHANNEL="${{ steps.releaseinfo.outputs.channel }}"
|
||
# ZIP_NAME="${{ steps.zip.outputs.zip_name }}"
|
||
# CHANGELOG="${{ steps.changelog.outputs.log }}"
|
||
|
||
# DOWNLOAD_URL="https://${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}/releases/download/${{ github.ref_name }}/${ZIP_NAME}"
|
||
|
||
# jq -n \
|
||
# --arg plugin "$PLUGIN_NAME" \
|
||
# --arg version "$VERSION" \
|
||
# --arg channel "$CHANNEL" \
|
||
# --arg description "$DESCRIPTION" \
|
||
# --arg author "$AUTHOR" \
|
||
# --arg email "$EMAIL" \
|
||
# --arg url "$DOWNLOAD_URL" \
|
||
# --arg changelog "$CHANGELOG" \
|
||
# '{
|
||
# plugin: $plugin,
|
||
# version: $version,
|
||
# channel: $channel,
|
||
# description: $description,
|
||
# author: $author,
|
||
# email: $email,
|
||
# url: $url,
|
||
# changelog: $changelog
|
||
# }' > payload.json
|
||
|
||
# echo "Payload:"
|
||
# cat payload.json
|
||
|
||
- name: Payload erzeugen
|
||
run: |
|
||
cd repo
|
||
|
||
VERSION="${{ steps.releaseinfo.outputs.version }}"
|
||
CHANNEL="${{ steps.releaseinfo.outputs.channel }}"
|
||
ZIP_NAME="${{ steps.zip.outputs.zip_name }}"
|
||
|
||
DOWNLOAD_URL="https://${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}/releases/download/${{ github.ref_name }}/${ZIP_NAME}"
|
||
|
||
jq -n \
|
||
--arg plugin "${{ steps.info.outputs.name }}" \
|
||
--arg version "$VERSION" \
|
||
--arg channel "$CHANNEL" \
|
||
--arg description "${{ steps.info.outputs.description }}" \
|
||
--arg author "${{ steps.info.outputs.author }}" \
|
||
--arg email "${{ steps.info.outputs.email }}" \
|
||
--arg url "$DOWNLOAD_URL" \
|
||
--arg changelog "Automatischer Release" \
|
||
'{
|
||
plugin: $plugin,
|
||
version: $version,
|
||
channel: $channel,
|
||
description: $description,
|
||
author: $author,
|
||
email: $email,
|
||
url: $url,
|
||
changelog: $changelog
|
||
}' > payload.json
|
||
|
||
echo "DEBUG | Payload erzeugt:"
|
||
cat payload.json
|
||
|
||
# - name: Repository aktualisieren
|
||
# run: |
|
||
# OWNER="AG_QGIS"
|
||
# WORKFLOW="update.yml"
|
||
|
||
# # payload.json in Base64 umwandeln
|
||
# PAYLOAD_B64=$(base64 -w0 repo/payload.json)
|
||
|
||
# # JSON für Gitea bauen
|
||
# JSON="{\"ref\":\"feature/release\",\"inputs\":{\"payload\":\"$PAYLOAD_B64\"}}"
|
||
|
||
# echo "Sende JSON:"
|
||
# echo "$JSON"
|
||
|
||
# curl -X POST \
|
||
# -H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \
|
||
# -H "Content-Type: application/json" \
|
||
# -d "$JSON" \
|
||
# "https://${{ vars.RELEASE_URL }}/api/v1/repos/${OWNER}/Repository/actions/workflows/${WORKFLOW}/dispatches"
|
||
|
||
- name: Repository aktualisieren
|
||
run: |
|
||
OWNER="AG_QGIS"
|
||
WORKFLOW="update.yml"
|
||
|
||
PAYLOAD_B64=$(base64 -w0 repo/payload.json)
|
||
|
||
JSON="{\"ref\":\"feature/release\",\"inputs\":{\"payload\":\"$PAYLOAD_B64\"}}"
|
||
|
||
echo "DEBUG | Sende JSON:"
|
||
echo "$JSON"
|
||
|
||
curl -X POST \
|
||
-H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \
|
||
-H "Content-Type: application/json" \
|
||
-d "$JSON" \
|
||
"https://${{ vars.RELEASE_URL }}/api/v1/repos/${OWNER}/Repository/actions/workflows/${WORKFLOW}/dispatches"
|