@@ -1,4 +1,3 @@
# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
name : Release Plugin
on :
@@ -11,216 +10,340 @@ jobs:
runs-on : alpine-latest
defaults :
run :
shell : sh
shell : ba sh
steps :
- name : Install dependencies
- 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 : Checkout
- name : Code holen
run : |
git clone --depth 1 \
--branch ${{ github.ref_name }} \
https://x-access-token:${{ secrets.RELEASE_TOKEN }}@${{ vars.RELEASE_URL }}/${{ github.repository }}.git \
.
# Tag aus GitHub Actions Kontext extrahieren
TAG="${GITHUB_REF#refs/tags/}"
echo "DEBUG | Tag erkannt: $TAG"
- name : Determine ve rsion and channel
id : info
# Repo-URL dynamisch aus va rs 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
*-dev *) CHANNEL="dev " ;;
*-beta *) CHANNEL="beta " ;;
*) CHANNEL="stable" ;;
*-unstable *) CHANNEL="unstable " ;;
*-testing *) CHANNEL="testing " ;;
*) CHANNEL="stable" ;;
esac
echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "channel=${CHANNEL}" >> $GITHUB_OUTPUT
echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "channel=${CHANNEL}" >> $GITHUB_OUTPUT
# Nur fürs Log:
echo "VERSION: $VERSION"
echo "CHANNEL: $CHANNEL"
echo "DEBUG | Version: $VERSION"
echo "DEBUG | Kanal: $CHANNEL"
- name: Read plugin.cfg
id : cfg
# - 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 : |
CFG=".plugin/plugin.cfg"
cd repo
while IFS='=' read -r key value; do
echo "$key=$value" >> $GITHUB_OUTPUT
done < plugin.info
get_value() {
grep -i "^$1" "$CFG" | head -1 | cut -d= -f2- | tr -d '\r' | xargs
}
echo "DEBUG | plugin.info geladen:"
cat plugin.info
echo "zip_folder=$(get_value zip_folder)" >> $GITHUB_OUTPUT
echo "name=$(get_value name)" >> $GITHUB_OUTPUT
echo "qgis_min=$(get_value qgisMinimumVersion)" >> $GITHUB_OUTPUT
echo "qgis_max=$(get_value qgisMaximumVersion)" >> $GITHUB_OUTPUT
echo "description=$(get_value description)" >> $GITHUB_OUTPUT
echo "author=$(get_value author)" >> $GITHUB_OUTPUT
echo "email=$(get_value email)" >> $GITHUB_OUTPUT
echo "homepage=$(get_value homepage)" >> $GITHUB_OUTPUT
echo "tracker=$(get_value tracker)" >> $GITHUB_OUTPUT
echo "repository=$(get_value repository)" >> $GITHUB_OUTPUT
echo "experimental=$(get_value experimental)" >> $GITHUB_OUTPUT
echo "deprecated=$(get_value deprecated)" >> $GITHUB_OUTPUT
# Nur fürs Log:
echo "zip_folder=$(get_value zip_folder)"
echo "name=$(get_value name)"
echo "qgis_min=$(get_value qgisMinimumVersion)"
echo "qgis_max=$(get_value qgisMaximumVersion)"
echo "description=$(get_value description)"
echo "author=$(get_value author)"
echo "email=$(get_value email)"
echo "homepage=$(get_value homepage)"
echo "tracker=$(get_value tracker)"
echo "repository=$(get_value repository)"
echo "experimental=$(get_value experimental)"
echo "deprecated=$(get_value deprecated)"
- name : Generate metadata.txt
- name : metadata.txt erzeugen
run : |
VERSION="${{ steps.info.outputs.version }}"
CHANGELOG=$(cat .plugin/changelog.txt)
cd repo
cat > metadata.txt << EOF
[general]
name=${{ steps.cfg.outputs.name }}
version=${VERSION}
qgisMinimumVersion=${{ steps.cfg.outputs.qgis_min }}
qgisMaximumVersion=${{ steps.cfg.outputs.qgis_max }}
description=${{ steps.cfg.outputs.description }}
author=${{ steps.cfg.outputs.author }}
email=${{ steps.cfg.outputs.email }}
homepage=${{ steps.cfg.outputs.homepage }}
tracker=${{ steps.cfg.outputs.tracker }}
repository=${{ steps.cfg.outputs.repository }}
experimental=${{ steps.cfg.outputs.experimental }}
deprecated=${{ steps.cfg.outputs.deprecated }}
changelog=${VERSION}
$(cat .plugin/changelog.txt)
EOF
TEMPLATE=".plugin/ metadata.template"
OUT="metadata.txt"
# Nur fürs Log:
CONTENT=$(cat "$TEMPLATE")
CONTENT="${CONTENT//\{\{NAME\}\}/${{ steps.info.outputs.name }}}"
CONTENT="${CONTENT//\{\{DESCRIPTION\}\}/${{ steps.info.outputs.description }}}"
CONTENT="${CONTENT//\{\{AUTHOR\}\}/${{ steps.info.outputs.author }}}"
CONTENT="${CONTENT//\{\{EMAIL\}\}/${{ steps.info.outputs.email }}}"
CONTENT="${CONTENT//\{\{VERSION\}\}/${{ steps.releaseinfo.outputs.version }}}"
printf "%s\n" "$CONTENT" > "$OUT"
echo "DEBUG | metadata.txt erzeugt:"
cat metadata.txt
- name: Build plugin ZIP
# - 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 : |
REPO_NAME="${{ github.event.repository.name }}"
ZIP_FOLDER="${{ steps.cfg.outputs.zip_folder }}"
VERSION ="${{ steps.info.outputs.version }}"
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"
# Temporären Ordner mit zip_folder-Namen anlegen
echo "DEBUG | ZIP wird erzeugt: $ZIP_NAME"
mkdir -p dist/${ZIP_FOLDER}
# Alle Plugin-Dateien hineinkopieren (ohne .gitea, .plugin, dist)
rsync -a \
--exclude='.git' \
--exclude='.gitea' \
--exclude='.plugin' \
--exclude='.git' \
--exclude='dist' \
./ dist/${ZIP_FOLDER}/
# ZIP bauen
cd dist
zip -r ${ZIP_NAME} ${ZIP_FOLDER}/ \
zip -r " ${ZIP_NAME}" " ${ZIP_FOLDER}/" \
-x "*.pyc" -x "*/__pycache__/*"
cd ..
echo "ZIP_NAME =${ZIP_NAME}" >> $GITHUB_ENV
echo "zip_name =${ZIP_NAME}" >> $GITHUB_OUTPUT
# Nur fürs Log:
echo "ZIP_NAME=${ZIP_NAME}"
- name : Create Gitea Release
- name : Gitea‑ Release erstellen
id : create_release
run : |
echo "Kommuniziere mit Gitea API über HTTPS... "
API_RESPONSE=$(curl -s -k -X POST "https://${{ vars.RELEASE_URL }}/api/v1/repos/${{ github.repository }}/releases" \
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 '{
"body": "Dieses Release wurde automatisch vom Gitea Runner erstellt.",
"draft": false,
"name": "Version ${{ github.ref_name }}",
"prerelease": false,
"tag_name": "${{ github.ref_name }}"
}')
-d "$JSON")
RELEASE_ID=$(echo $API_RESPONSE | jq -r '.id')
RELEASE_ID=$(echo " $API_RESPONSE" | jq -r '.id')
if [ "$RELEASE_ID" = "null" ] || [ -z "$RELEASE_ID" ]; then
echo "Fehler beim Erstellen des Releases. API Antwort: "
echo $ API_RESPONSE
echo "Fehler beim Erstellen des Releases! "
echo " API‑ Antwort:"
echo "$API_RESPONSE"
exit 1
fi
echo "Release ID: $RELEASE_ID"
echo "RELEASE_ID =$RELEASE_ID" >> $GITHUB_ENV
echo "Release erfolgreich erstellt. ID: $RELEASE_ID"
echo "release_id =$RELEASE_ID" >> $GITHUB_OUTPUT
- name : Upload ZIP asset
id : upload_asset
- name : ZIP-Datei hochladen
run : |
echo "Lade release_${{ github.ref_name }}.zip (${{ env.ZIP_NAME }}) hoch... "
RELEASE_ID="${{ steps.create_release.outputs.release_id }} "
ZIP_NAME="${{ steps.zip.outputs.zip_name }}"
RESPONSE=$(curl -s -k -X POST \
"https://${{ vars.RELEASE_URL }}/api/v1/repos/${{ github.repository }}/releases/${{ env.RELEASE_ID }}/assets?name=${{ env.ZIP_NAME }}" \
-H "accept: application/json" \
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: multipart/form-data " \
-F "attachment=@ dist/${{ env. ZIP_NAME }}")
-H "Content-Type: application/zip " \
--data-binary "@repo/ dist/${ZIP_NAME}" \
-o upload_response.json
echo "Upload response: $RESPONSE "
echo "Upload-Antwort: "
cat upload_response.json
DOWNLOAD_URL=$(echo "$RESPONSE" | grep -o '"browser_download_url":"[^"]*' | cut -d'"' -f4)
echo "download_url=${DOWNLOAD_URL}" >> $GITHUB_OUTPUT
# 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: Build XML block
id : xmlblock
# - 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 : |
NAME="${{ steps.cfg.outputs.name }}"
VERSION="${{ steps.info.outputs.version }}"
cd repo
BLOCK=$(cat <<EOF
<pyqgis_plugin name="${NAME}" version="${VERSION }">
<description> ${{ steps.cfg .outputs.description }}</description>
<qgisMinimumVersion>${{ steps.cfg.outputs.qgis_min }}</qgisMinimumVersion>
<qgisMaximumVersion>${{ steps.cfg.outputs.qgis_max }}</qgisMaximumVersion>
<author>${{ steps.cfg.outputs.author }}</author>
<email>${{ steps.cfg.outputs.email }}</email>
<homepage>${{ steps.cfg.outputs.homepage }}</homepage>
<tracker>${{ steps.cfg.outputs.tracker }}</tracker>
<repository>${{ steps.cfg.outputs.repository }}</repository>
<download_url>${{ steps.upload_asset.outputs.download_url }}</download_url>
<experimental>${{ steps.cfg.outputs.experimental }}</experimental>
<deprecated>${{ steps.cfg.outputs.deprecated }}</deprecated>
</pyqgis_plugin>
EOF
)
VERSION="${{ steps.releaseinfo.outputs.version }}"
CHANNEL="${{ steps.releaseinfo.outputs.channel } }"
ZIP_NAME=" ${{ steps.zip .outputs.zip_name }}"
{
echo "block<<EOF"
echo "$BLOCK"
echo "EOF"
} >> "$GITHUB_OUTPUT"
DOWNLOAD_URL="https://${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}/releases/download/${{ github.ref_name }}/${ZIP_NAME}"
- name : Dispatch to Repository
shell : bash
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 : |
curl -s -X POST \
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" \
"https://${{ vars.RELEASE_URL }}/api/v1/repos/${{ github.repository_owner }}/Repository/dispatches " \
-d "{
\"type\": \"plugin-released\",
\"payload\": {
\"plugin\": \"${{ steps.cfg.outputs.name }}\",
\"channel\": \"${{ steps.info.outputs.channel }}\",
\"xml_block\": \"${{ steps.xmlblock.outputs.block }}\"
}
}"
-d "$JSON " \
"https://${{ vars.RELEASE_URL }}/api/v1/repos/${OWNER}/Repository/actions/workflows/${WORKFLOW}/dispatches"