Compare commits

...

36 Commits

Author SHA1 Message Date
Michael Otto
aecf203932 Letzte Fehler behoben 2026-03-03 14:47:45 +01:00
Michael Otto
3ee93bdc0d Kennzeichnung stable/unstable/testing 2026-03-03 14:22:12 +01:00
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
Michael Otto
5d12fefb1d Test komplette metadata.txt 2026-03-03 11:28:58 +01:00
Michael Otto
495a4ac049 Pfad der metadate.template angepasst 2026-03-03 11:16:03 +01:00
Michael Otto
a69d00df31 auf plugin.info umgestellt 2026-03-03 11:14:22 +01:00
Michael Otto
f77a8d34a0 Release v39 2026-03-03 10:21:27 +01:00
Michael Otto
2cb504ba51 Release v38 2026-03-03 10:18:46 +01:00
Michael Otto
44aae815f5 Release v37 2026-03-03 10:15:05 +01:00
Michael Otto
af43bfeab9 Release v36 2026-03-03 10:13:36 +01:00
Michael Otto
c55dedbbe1 Release v34 2026-03-03 10:10:02 +01:00
Michael Otto
067e0f3170 Release v33 2026-03-03 10:08:03 +01:00
Michael Otto
2e65ec4bc4 Release v29 2026-03-03 09:44:03 +01:00
Michael Otto
0ce29c9e84 Release v27 2026-03-03 09:36:12 +01:00
Michael Otto
75b7e8073a Release v26 2026-03-03 09:28:31 +01:00
Michael Otto
88a62af7c8 Release v25 2026-03-03 09:27:23 +01:00
Michael Otto
049c0f64ed Release v24 2026-03-03 09:26:38 +01:00
Michael Otto
efc695457f Release v23 2026-03-03 09:23:18 +01:00
Michael Otto
c73cde2e57 Release v22 2026-03-03 09:12:42 +01:00
Michael Otto
18e76984bb Release v21 2026-03-03 09:11:49 +01:00
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
7 changed files with 236 additions and 220 deletions

View File

@@ -1,4 +1,3 @@
# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
name: Release Plugin name: Release Plugin
on: on:
@@ -24,11 +23,9 @@ jobs:
run: | run: |
# Tag aus GitHub Actions Kontext extrahieren # Tag aus GitHub Actions Kontext extrahieren
TAG="${GITHUB_REF#refs/tags/}" TAG="${GITHUB_REF#refs/tags/}"
echo "DEBUG | Tag erkannt: $TAG"
# Repo-URL dynamisch aus vars und github.repository bauen # Repo-URL dynamisch aus vars und github.repository bauen
REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git" REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git"
echo "DEBUG | Klone von: $REPO_URL"
# Repository klonen # Repository klonen
git clone "$REPO_URL" repo git clone "$REPO_URL" repo
@@ -39,225 +36,243 @@ jobs:
RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }} RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }}
- name: Version und Kanal bestimmen - name: Version und Kanal bestimmen
id: info id: releaseinfo
run: | run: |
TAG="${{ github.ref_name }}" TAG="${{ github.ref_name }}"
VERSION="${TAG#v}" VERSION="${TAG#v}"
case "$TAG" in case "$TAG" in
*-unstable*) CHANNEL="unstable" ;; *-unstable*)
*-testing*) CHANNEL="testing" ;; CHANNEL="unstable"
*) CHANNEL="stable" ;; DRAFT="false"
PRERELEASE="true"
;;
*-testing*)
CHANNEL="testing"
DRAFT="true"
PRERELEASE="false"
;;
*)
CHANNEL="stable"
DRAFT="false"
PRERELEASE="false"
;;
esac esac
echo "version=${VERSION}" >> $GITHUB_OUTPUT echo "version=$VERSION" >> $GITHUB_OUTPUT
echo "channel=${CHANNEL}" >> $GITHUB_OUTPUT echo "channel=$CHANNEL" >> $GITHUB_OUTPUT
echo "draft=$DRAFT" >> $GITHUB_OUTPUT
echo "prerelease=$PRERELEASE" >> $GITHUB_OUTPUT
echo "DEBUG | Version: $VERSION" - name: plugin.info einlesen
echo "DEBUG | Kanal: $CHANNEL" id: info
- name: Debug Info
run: | run: |
echo "Tag: $GITEA_REF_NAME" cd repo
uname -a while IFS='=' read -r key value; do
echo "$key=$value" >> $GITHUB_OUTPUT
done < plugin.info
# - name: Determine version and channel - name: Changelog einlesen
# id: info id: changelog
# run: | run: |
# TAG="${{ github.ref_name }}" cd repo
# VERSION="${TAG#v}"
# case "$TAG" in # Aktueller Block = alles vor dem ersten ---
# *-dev*) CHANNEL="dev" ;; CURRENT=$(awk '/^---/{exit} {print}' changelog.txt)
# *-beta*) CHANNEL="beta" ;;
# *) CHANNEL="stable" ;;
# esac
# echo "version=${VERSION}" >> $GITHUB_OUTPUT # Vollständige Historie = alles nach dem ersten ---
# echo "channel=${CHANNEL}" >> $GITHUB_OUTPUT HISTORY=$(awk 'found{print} /^---/{found=1}' changelog.txt)
# # Nur fürs Log: # Gitea Release Body zusammenbauen
# echo "VERSION: $VERSION" VERSION="${{ steps.releaseinfo.outputs.version }}"
# echo "CHANNEL: $CHANNEL" FULL=$(printf "## %s\n%s\n\n%s" "$VERSION" "$CURRENT" "$HISTORY")
# - name: Read plugin.cfg echo "DEBUG | Aktueller Changelog:"
# id: cfg echo "$CURRENT"
# run: |
# CFG=".plugin/plugin.cfg"
# get_value() { # Für GITHUB_OUTPUT: Multiline via EOF-Marker
# grep -i "^$1" "$CFG" | head -1 | cut -d= -f2- | tr -d '\r' | xargs echo "current<<EOF" >> $GITHUB_OUTPUT
# } echo "$CURRENT" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
# echo "zip_folder=$(get_value zip_folder)" >> $GITHUB_OUTPUT echo "full<<EOF" >> $GITHUB_OUTPUT
# echo "name=$(get_value name)" >> $GITHUB_OUTPUT echo "$FULL" >> $GITHUB_OUTPUT
# echo "qgis_min=$(get_value qgisMinimumVersion)" >> $GITHUB_OUTPUT echo "EOF" >> $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: - name: metadata.txt erzeugen
# echo "zip_folder=$(get_value zip_folder)" run: |
# echo "name=$(get_value name)" cd repo
# 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 TEMPLATE="templates/metadata.template"
# run: | OUT="metadata.txt"
# VERSION="${{ steps.info.outputs.version }}"
# CHANGELOG=$(cat .plugin/changelog.txt)
# cat > metadata.txt << EOF CONTENT=$(cat "$TEMPLATE")
# [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
# # Nur fürs Log: CONTENT="${CONTENT//\{\{NAME\}\}/${{ steps.info.outputs.name }}}"
# cat metadata.txt 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\}\}/${{ 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 }}}"
# - name: Build plugin ZIP printf "%s\n" "$CONTENT" > "$OUT"
# run: |
# REPO_NAME="${{ github.event.repository.name }}"
# ZIP_FOLDER="${{ steps.cfg.outputs.zip_folder }}"
# VERSION="${{ steps.info.outputs.version }}"
# ZIP_NAME="${REPO_NAME}-${VERSION}.zip"
# # Temporären Ordner mit zip_folder-Namen anlegen - name: ZIP-Datei erstellen
# mkdir -p dist/${ZIP_FOLDER} id: zip
run: |
cd repo
# # Alle Plugin-Dateien hineinkopieren (ohne .gitea, .plugin, dist) ZIP_FOLDER="${{ steps.info.outputs.zip_folder }}"
# rsync -a \
# --exclude='.gitea' \
# --exclude='.plugin' \
# --exclude='.git' \
# --exclude='dist' \
# ./ dist/${ZIP_FOLDER}/
# # ZIP bauen VERSION="${{ steps.releaseinfo.outputs.version }}"
# cd dist REPO_NAME="${GITHUB_REPOSITORY##*/}"
# zip -r ${ZIP_NAME} ${ZIP_FOLDER}/ \ ZIP_NAME="${REPO_NAME}-${VERSION}.zip"
# -x "*.pyc" -x "*/__pycache__/*"
# cd ..
# echo "ZIP_NAME=${ZIP_NAME}" >> $GITHUB_ENV mkdir -p dist/${ZIP_FOLDER}
# # Nur fürs Log: rsync -a \
# echo "ZIP_NAME=${ZIP_NAME}" --exclude='.git' \
--exclude='.gitea' \
--exclude='.plugin' \
--exclude='dist' \
./ dist/${ZIP_FOLDER}/
# - name: Create Gitea Release cd dist
# id: create_release zip -r "${ZIP_NAME}" "${ZIP_FOLDER}/" \
# run: | -x "*.pyc" -x "*/__pycache__/*"
# echo "Kommuniziere mit Gitea API über HTTPS..." cd ..
# API_RESPONSE=$(curl -s -k -X POST "https://${{ vars.RELEASE_URL }}/api/v1/repos/${{ github.repository }}/releases" \
# -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 }}"
# }')
# 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
# exit 1
# fi
# echo "Release ID: $RELEASE_ID"
# echo "RELEASE_ID=$RELEASE_ID" >> $GITHUB_ENV
# - name: Upload ZIP asset echo "zip_name=${ZIP_NAME}" >> $GITHUB_OUTPUT
# id: upload_asset
# run: |
# echo "Lade release_${{ github.ref_name }}.zip (${{ env.ZIP_NAME }}) hoch..."
# RESPONSE=$(curl -s -k -X POST \ - name: Gitea-Release erstellen
# "https://${{ vars.RELEASE_URL }}/api/v1/repos/${{ github.repository }}/releases/${{ env.RELEASE_ID }}/assets?name=${{ env.ZIP_NAME }}" \ id: create_release
# -H "accept: application/json" \ run: |
# -H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \ TAG="${{ github.ref_name }}"
# -H "Content-Type: multipart/form-data" \ VERSION="${{ steps.releaseinfo.outputs.version }}"
# -F "attachment=@dist/${{ env.ZIP_NAME }}") CHANNEL="${{ steps.releaseinfo.outputs.channel }}"
# echo "Upload response: $RESPONSE" API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${GITHUB_REPOSITORY}/releases"
# DOWNLOAD_URL=$(echo "$RESPONSE" | grep -o '"browser_download_url":"[^"]*' | cut -d'"' -f4) JSON=$(jq -n \
# echo "download_url=${DOWNLOAD_URL}" >> $GITHUB_OUTPUT --arg tag "$TAG" \
--arg name "Version $VERSION" \
--arg body "${{ steps.changelog.outputs.current }}" \
--argjson draft "${{ steps.releaseinfo.outputs.draft }}" \
--argjson prerelease "${{ steps.releaseinfo.outputs.prerelease }}" \
'{tag_name: $tag, name: $name, body: $body, draft: $draft, prerelease: $prerelease}')
# - name: Build XML block # JSON=$(jq -n \
# id: xmlblock # --arg tag "$TAG" \
# run: | # --arg name "Version $VERSION" \
# NAME="${{ steps.cfg.outputs.name }}" # --arg body "${{ steps.changelog.outputs.current }}" \
# VERSION="${{ steps.info.outputs.version }}" # '{tag_name: $tag, name: $name, body: $body, draft: false, prerelease: false}')
# BLOCK=$(cat <<EOF API_RESPONSE=$(curl -s -X POST "$API_URL" \
# <pyqgis_plugin name="${NAME}" version="${VERSION}"> -H "accept: application/json" \
# <description>${{ steps.cfg.outputs.description }}</description> -H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \
# <qgisMinimumVersion>${{ steps.cfg.outputs.qgis_min }}</qgisMinimumVersion> -H "Content-Type: application/json" \
# <qgisMaximumVersion>${{ steps.cfg.outputs.qgis_max }}</qgisMaximumVersion> -d "$JSON")
# <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
# )
# { RELEASE_ID=$(echo "$API_RESPONSE" | jq -r '.id')
# echo "block<<EOF"
# echo "$BLOCK"
# echo "EOF"
# } >> "$GITHUB_OUTPUT"
# - name: Dispatch to Repository if [ "$RELEASE_ID" = "null" ] || [ -z "$RELEASE_ID" ]; then
# shell: bash echo "Fehler beim Erstellen des Releases!"
# run: | echo "$API_RESPONSE"
# curl -s -X POST \ exit 1
# -H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \ fi
# -H "Content-Type: application/json" \
# "https://${{ vars.RELEASE_URL }}/api/v1/repos/${{ github.repository_owner }}/Repository/dispatches" \ echo "release_id=$RELEASE_ID" >> $GITHUB_OUTPUT
# -d "{
# \"type\": \"plugin-released\", - name: ZIP-Datei hochladen
# \"payload\": { run: |
# \"plugin\": \"${{ steps.cfg.outputs.name }}\", RELEASE_ID="${{ steps.create_release.outputs.release_id }}"
# \"channel\": \"${{ steps.info.outputs.channel }}\", ZIP_NAME="${{ steps.zip.outputs.zip_name }}"
# \"xml_block\": \"${{ steps.xmlblock.outputs.block }}\"
# } 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
# 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
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 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 }}" \
'{
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
- 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"

3
.gitignore vendored
View File

@@ -174,4 +174,5 @@ cython_debug/
# PyPI configuration file # PyPI configuration file
.pypirc .pypirc
metadata.txt metadata.txt
release.cmd

View File

@@ -1,14 +0,0 @@
[general]
zip_folder=mein_plugin_ordner
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
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
deprecated=False

View File

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

View File

@@ -1,13 +0,0 @@
[general]
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
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
deprecated=False

11
plugin.info Normal file
View File

@@ -0,0 +1,11 @@
name=LNO Sachsen | Plugin Test Action
description=Test plugin for release pipeline
author=Daniel Helbig
email=daniel.helbig@kreis-meissen.de
qgisMinimumVersion=3.0
qgisMaximumVersion=3.99
deprecated=False
experimental=True
supportsQt6=Yes
zip_folder=plugin_folder

View File

@@ -0,0 +1,14 @@
[general]
name={{NAME}}
qgisMinimumVersion={{QGIS_MIN}}
qgisMaximumVersion={{QGIS_MAX}}
description={{DESCRIPTION}}
version={{VERSION}}
author={{AUTHOR}}
email={{EMAIL}}
homepage=https://{{HOMEPAGE}}
tracker=https://{{TRACKER}}/issues
repository=https://{{REPOSITORY}}
experimental={{EXPERIMENTAL}}
deprecated={{DEPRECATED}}
supportsQt6={{QT6}}