Compare commits

...

16 Commits

Author SHA1 Message Date
Michael Otto
3f41de4fac Release v19 2026-03-03 09:04:39 +01:00
Michael Otto
b885021941 Release v18 2026-03-03 09:01:04 +01:00
Michael Otto
9bdff6a681 Add release workflow 2026-03-03 08:59:04 +01:00
Michael Otto
156c59e707 Add release workflow 2026-03-03 08:53:12 +01:00
Michael Otto
07ec930161 metadata.txt als Template nach .plugin verschoben 2026-03-03 08:52:35 +01:00
Michael Otto
141a867dd3 Add release workflow 2026-03-03 08:17:19 +01:00
Michael Otto
2e3325df16 Add release workflow 2026-03-03 08:16:01 +01:00
Michael Otto
6715ce896c Add release workflow 2026-03-03 08:01:42 +01:00
Michael Otto
0ad9d3e1e5 Add release workflow 2026-03-03 07:57:21 +01:00
Michael Otto
46672dbf2b Add release workflow 2026-03-03 07:46:59 +01:00
Michael Otto
739af302d3 Add release workflow 2026-03-03 07:43:56 +01:00
Michael Otto
c11afa9383 Add release workflow 2026-03-03 07:39:17 +01:00
Michael Otto
78035e08b9 Add release workflow 2026-03-03 07:38:19 +01:00
Michael Otto
a2d8a1f1cf Add release workflow 2026-03-03 07:36:18 +01:00
Michael Otto
eb1c0fa6b9 Add release workflow 2026-03-03 07:29:17 +01:00
Michael Otto
cb71f30c29 Add release workflow 2026-03-03 07:27:55 +01:00
3 changed files with 138 additions and 30 deletions

View File

@@ -15,41 +15,148 @@ jobs:
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: 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: GiteaRelease 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"
# JSONBody 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 APIRequest an: $API_URL"
echo "JSONPayload:"
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 "APIAntwort:"
echo "$API_RESPONSE"
exit 1
fi
echo "Release erfolgreich erstellt. ID: $RELEASE_ID"
echo "release_id=$RELEASE_ID" >> $GITHUB_OUTPUT
- name: Debug Info
run: |
echo "Tag: $GITEA_REF_NAME"
uname -a
# - name: Checkout
# run: |
# git clone --depth 1 \
# --branch ${{ github.ref_name }} \
# https://x-access-token:${{ secrets.RELEASE_TOKEN }}@${{ vars.RELEASE_URL }}/${{ github.repository }}.git \
# .
# - name: Determine version and channel
# id: info
# run: |
# TAG="${{ github.ref_name }}"
# VERSION="${TAG#v}"
# case "$TAG" in
# *-dev*) CHANNEL="dev" ;;
# *-beta*) CHANNEL="beta" ;;
# *) CHANNEL="stable" ;;
# esac
# echo "version=${VERSION}" >> $GITHUB_OUTPUT
# echo "channel=${CHANNEL}" >> $GITHUB_OUTPUT
# # Nur fürs Log:
# echo "VERSION: $VERSION"
# echo "CHANNEL: $CHANNEL"
# - name: Read plugin.cfg
# id: cfg
# run: |

View File

@@ -3,11 +3,11 @@ name=LNO Sachsen | Plugin Test Action
qgisMinimumVersion=3.0
qgisMaximumVersion=3.99
description=Test plugin for release pipeline
version=26.3.1
author=Michael Otto
email=michael.otto@landkreis-mittelsachsen.de
version=@VERSION@
author=Daniel Helbig, Michael Otto
email=daniel.helbig@kreis-meissen.de, michael.otto@landkreis-mittelsachsen.de
homepage=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_Test_Action
tracker=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_Test_Action/issues
repository=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_Test_Action
experimental=False
experimental=True
deprecated=False

1
.plugin/zip_folder Normal file
View File

@@ -0,0 +1 @@
sn_test