Compare commits

...

12 Commits
v48 ... v66

Author SHA1 Message Date
Michael Otto
8ee99fa5da Release v66 2026-03-03 14:12:40 +01:00
Michael Otto
98fb235fb9 Release v65 2026-03-03 14:11:54 +01:00
Michael Otto
a58f6255fc Anpassungen für Releasemeldung 2026-03-03 14:09:39 +01:00
Michael Otto
78ffc6d6d2 Diverses 2026-03-03 14:02:32 +01:00
Michael Otto
00785eeabd Release v61 2026-03-03 13:58:12 +01:00
Michael Otto
8f0e6a9978 Release v60 2026-03-03 13:57:02 +01:00
Michael Otto
5f756be077 Fehler in release.yml beseitigt 2026-03-03 13:50:17 +01:00
Michael Otto
a6837e5fd2 changelog in release.yml aufgenommen 2026-03-03 13:44:48 +01:00
Michael Otto
dac2a8e973 Release v57 2026-03-03 12:55:38 +01:00
Michael Otto
0fa2861040 Optimierungen 2026-03-03 12:50:29 +01:00
Michael Otto
4790001f30 Name und ID angepasst 2026-03-03 12:18:43 +01:00
Michael Otto
2eacee23f5 Payload ergänzt 2026-03-03 12:09:26 +01:00
4 changed files with 84 additions and 185 deletions

View File

@@ -23,11 +23,9 @@ jobs:
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
@@ -52,24 +50,6 @@ jobs:
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: |
@@ -78,8 +58,32 @@ jobs:
echo "$key=$value" >> $GITHUB_OUTPUT
done < plugin.info
echo "DEBUG | plugin.info geladen:"
cat plugin.info
- name: Changelog einlesen
id: changelog
run: |
cd repo
# Aktueller Block = alles vor dem ersten ---
CURRENT=$(awk '/^---/{exit} {print}' changelog.txt)
# Vollständige Historie = alles nach dem ersten ---
HISTORY=$(awk 'found{print} /^---/{found=1}' changelog.txt)
# Gitea Release Body zusammenbauen
VERSION="${{ steps.releaseinfo.outputs.version }}"
FULL=$(printf "## %s\n%s\n\n%s" "$VERSION" "$CURRENT" "$HISTORY")
echo "DEBUG | Aktueller Changelog:"
echo "$CURRENT"
# Für GITHUB_OUTPUT: Multiline via EOF-Marker
echo "current<<EOF" >> $GITHUB_OUTPUT
echo "$CURRENT" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
echo "full<<EOF" >> $GITHUB_OUTPUT
echo "$FULL" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
- name: metadata.txt erzeugen
run: |
@@ -97,69 +101,26 @@ jobs:
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//\{\{HOMEPAGE\}\}/${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}}"
CONTENT="${CONTENT//\{\{TRACKER\}\}/${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}}"
CONTENT="${CONTENT//\{\{REPOSITORY\}\}/${{ vars.RELEASE_URL }}/${GITHUB_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 \
@@ -176,31 +137,21 @@ jobs:
echo "zip_name=${ZIP_NAME}" >> $GITHUB_OUTPUT
- name: GiteaRelease erstellen
- 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"
# 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}')
--arg tag "$TAG" \
--arg name "Version $VERSION" \
--arg body "${{ steps.changelog.outputs.current }}" \
'{tag_name: $tag, name: $name, body: $body, draft: true, prerelease: true}')
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 }}" \
@@ -209,24 +160,19 @@ jobs:
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
if [ "$RELEASE_ID" = "null" ] || [ -z "$RELEASE_ID" ]; then
echo "Fehler beim Erstellen des Releases!"
echo "$API_RESPONSE"
exit 1
fi
echo "Release erfolgreich erstellt. ID: $RELEASE_ID"
echo "release_id=$RELEASE_ID" >> $GITHUB_OUTPUT
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" \
@@ -235,9 +181,6 @@ jobs:
--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."
@@ -246,45 +189,6 @@ jobs:
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
@@ -296,48 +200,43 @@ jobs:
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" \
--arg name "${{ 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 qgis_min "${{ steps.info.outputs.qgisMinimumVersion }}" \
--arg qgis_max "${{ steps.info.outputs.qgisMaximumVersion }}" \
--arg homepage "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
--arg tracker "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
--arg repository "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
--arg experimental "${{ steps.info.outputs.experimental }}" \
--arg deprecated "${{ steps.info.outputs.deprecated }}" \
--arg qt6 "${{ steps.info.outputs.supportsQt6 }}" \
--arg id "${{ steps.info.outputs.zip_folder }}" \
--arg url "$DOWNLOAD_URL" \
--arg changelog "${{ steps.changelog.outputs.current }}" \
'{
plugin: $plugin,
version: $version,
channel: $channel,
description: $description,
author: $author,
email: $email,
url: $url,
changelog: $changelog
name: $name,
version: $version,
channel: $channel,
description: $description,
author: $author,
email: $email,
qgis_min: $qgis_min,
qgis_max: $qgis_max,
homepage: $homepage,
tracker: $tracker,
repository: $repository,
experimental: $experimental,
deprecated: $deprecated,
qt6: $qt6,
id: $id,
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"

View File

@@ -1,4 +1,6 @@
0.2.0
- Ganz viele neue Sachen
---
61
- Feature XY hinzugefügt
- Bug Z behoben
0.1.0

View File

@@ -1,13 +1,11 @@
name=LNO Sachsen | Plugin Test Action
description=Test plugin for release pipeline
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
qgisMinimumVersion=3.0
qgisMaximumVersion=3.99
deprecated=False
experimental=True
experimental=True
supportsQt6=Yes
zip_folder=plugin_folder

View File

@@ -6,9 +6,9 @@ description={{DESCRIPTION}}
version={{VERSION}}
author={{AUTHOR}}
email={{EMAIL}}
homepage={{HOMEPAGE}}
tracker={{TRACKER}}
repository={{REPOSITORY}}
homepage=https://{{HOMEPAGE}}
tracker=https://{{TRACKER}}/issues
repository=https://{{REPOSITORY}}
experimental={{EXPERIMENTAL}}
deprecated={{DEPRECATED}}
supportsQt6={{QT6}}
supportsQt6={{QT6}}