diff --git a/.gitea/workflows/release.yaml b/.gitea/workflows/release.yaml new file mode 100644 index 0000000..bc3660e --- /dev/null +++ b/.gitea/workflows/release.yaml @@ -0,0 +1,133 @@ +name: Release Plugin +run-name: "Release | ${{ github.ref_name }}" + +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 bash git jq curl + + - name: Code holen + run: | + REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git" + + git clone "$REPO_URL" repo + cd repo + + git checkout "$TAG" + env: + RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }} + TAG: "${{ github.ref_name }}" + + - name: Version und Kanal bestimmen + id: releaseinfo + run: | + TAG="${{ github.ref_name }}" + RAW_VERSION="${TAG#v}" + VERSION="${RAW_VERSION%%-*}" + + # Channel und Suffix automatisch bestimmen anhand des Tag-Suffix + case "$RAW_VERSION" in + *-testing*|*-t|*-T) + CHANNEL="testing" + PRERELEASE="true" + SUFFIX="-testing" + ;; + *-unstable*|*-u|*-U) + CHANNEL="unstable" + PRERELEASE="true" + SUFFIX="-unstable" + ;; + *) + CHANNEL="stable" + PRERELEASE="false" + SUFFIX="" + ;; + esac + + # Output setzen + echo "version=$VERSION" >> $GITHUB_OUTPUT + echo "channel=$CHANNEL" >> $GITHUB_OUTPUT + echo "prerelease=$PRERELEASE" >> $GITHUB_OUTPUT + + # Optional Debug + echo "VERSION=$VERSION" + echo "CHANNEL=$CHANNEL" + echo "PRERELEASE=$PRERELEASE" + + # - name: plugin.cfg einlesen + # id: config + # run: | + # cd repo + # while read -r line || [ -n "$line" ]; do + # key="${line%%=*}" + # value="${line#*=}" + # echo "$key=$value" >> $GITHUB_OUTPUT + # done < plugin.cfg + + - name: Payload erzeugen + id: payload + run: | + cd repo + + NAME="${GITHUB_REPOSITORY##*/}" + GROUP="${GITHUB_REPOSITORY%%/*}" + VERSION="${{ steps.releaseinfo.outputs.version }}" + CHANNEL="${{ steps.releaseinfo.outputs.channel }}" + PRERELEASE="${{ steps.releaseinfo.outputs.prerelease }}" + ZIP_FOLDER="${{ vars.ZIP_FOLDER }}" + ZIP_FILE="${ZIP_FOLDER}.zip" + TAG="${{ github.ref_name }}" + #GIT_URL=${GITHUB_REPOSITORY} + + jq -n \ + --arg name "$NAME" \ + --arg group "$GROUP" \ + --arg version "$VERSION" \ + --arg channel "$CHANNEL" \ + --arg prerelease "$PRERELEASE" \ + --arg zip_folder "$ZIP_FOLDER" \ + --arg zip_file "$ZIP_FILE" \ + --arg tag "$TAG" \ + '{ + name: $name, + group: $group, + version: $version, + channel: $channel, + prerelease: ($prerelease == "true"), + zip_folder: $zip_folder, + zip_file: $zip_file, + tag: $tag + }' > payload.json + + cat payload.json + + - name: Repository aktualisieren + run: | + NAME="${GITHUB_REPOSITORY##*/}" + TAG="${{ steps.releaseinfo.outputs.version }}"-"${{ steps.releaseinfo.outputs.channel }}" + PAYLOAD_B64=$(base64 -w0 repo/payload.json) + + JSON="{\"ref\":\"hidden/workflows\",\"inputs\":{\"payload\":\"$PAYLOAD_B64\",\"name\":\"$NAME\",\"tag\":\"$TAG\"}}" + 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" + env: + RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }} + OWNER: "AG_QGIS" + WORKFLOW: "release.yaml" + \ No newline at end of file diff --git a/.gitea/workflows/release.yml b/.gitea/workflows/release.yml deleted file mode 100644 index fc4e5ce..0000000 --- a/.gitea/workflows/release.yml +++ /dev/null @@ -1,295 +0,0 @@ -name: Release Plugin -run-name: "Release | ${{ github.ref_name }}" - -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/}" - - # Repo-URL dynamisch aus vars und github.repository bauen - REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git" - - # 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" - DRAFT="false" - PRERELEASE="true" - ;; - *-testing*) - CHANNEL="testing" - DRAFT="false" - PRERELEASE="true" - ;; - *) - CHANNEL="stable" - DRAFT="false" - PRERELEASE="false" - ;; - esac - - echo "version=$VERSION" >> $GITHUB_OUTPUT - echo "channel=$CHANNEL" >> $GITHUB_OUTPUT - echo "draft=$DRAFT" >> $GITHUB_OUTPUT - echo "prerelease=$PRERELEASE" >> $GITHUB_OUTPUT - - - name: plugin.cfg einlesen - id: info - run: | - cd repo - while read -r line || [ -n "$line" ]; do - key="${line%%=*}" - value="${line#*=}" - echo "$key=$value" >> $GITHUB_OUTPUT - echo "$key=$value" - done < plugin.cfg - - - 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<> $GITHUB_OUTPUT - echo "$CURRENT" >> $GITHUB_OUTPUT - echo "EOF" >> $GITHUB_OUTPUT - - echo "full<> $GITHUB_OUTPUT - echo "$FULL" >> $GITHUB_OUTPUT - echo "EOF" >> $GITHUB_OUTPUT - - - name: metadata.txt erzeugen - run: | - cd repo - - # ------------------------ GEÄNDERT ------------------------ - # Temporär die Vorlage aus dem hidden/templates Branch holen - git fetch origin hidden/templates - git checkout origin/hidden/templates -- metadata.template - TEMPLATE="metadata.template" - # ----------------------------------------------------------- - - # 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\}\}/${{ 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" - rm $TEMPLATE - - - name: ZIP-Datei erstellen - id: zip - run: | - cd repo - - ZIP_FOLDER="${{ steps.info.outputs.zip_folder }}" - ZIP_FILE="${ZIP_FOLDER}.zip" - - echo "ZIP_FOLDER: $ZIP_FOLDER" - echo "ZIP_FILE: $ZIP_FILE" - - VERSION="${{ steps.releaseinfo.outputs.version }}" - REPO_NAME="${GITHUB_REPOSITORY##*/}" - #ZIP_NAME="${REPO_NAME}-${VERSION}.zip" - - - mkdir -p dist/${ZIP_FOLDER} - - rsync -a \ - --exclude='.git' \ - --exclude='.gitea' \ - --exclude='.plugin' \ - --exclude='dist' \ - ./ dist/${ZIP_FOLDER}/ - - cd dist - zip -r "${ZIP_FILE}" "${ZIP_FOLDER}/" \ - -x "*.pyc" -x "*/__pycache__/*" - cd .. - - echo "zip_file=${ZIP_FILE}" >> $GITHUB_OUTPUT - - - name: Gitea-Release erstellen - id: create_release - run: | - TAG="${{ github.ref_name }}" - VERSION="${{ steps.releaseinfo.outputs.version }}" - CHANNEL="${{ steps.releaseinfo.outputs.channel }}" - - API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${GITHUB_REPOSITORY}/releases" - - JSON=$(jq -n \ - --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}') - - 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_RESPONSE" - exit 1 - fi - - echo "release_id=$RELEASE_ID" >> $GITHUB_OUTPUT - - - name: ZIP-Datei hochladen - run: | - RELEASE_ID="${{ steps.create_release.outputs.release_id }}" - ZIP_FILE="${{ steps.zip.outputs.zip_file }}" - - API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${GITHUB_REPOSITORY}/releases/${RELEASE_ID}/assets?name=${ZIP_FILE}" - - curl -s -X POST "$API_URL" \ - -H "Authorization: token ${{ secrets.RELEASE_TOKEN }}" \ - -H "Content-Type: application/zip" \ - --data-binary "@repo/dist/${ZIP_FILE}" \ - -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_FILE="${{ steps.zip.outputs.zip_file }}" - - DOWNLOAD_URL="https://${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}/releases/download/${{ github.ref_name }}/${ZIP_FILE}" - - 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) - - FULL_NAME="${{ steps.info.outputs.name }}" - NAME=$(echo "$FULL_NAME" | awk -F'|' '{gsub(/^ +| +$/,"",$2); print $2}') - TAG="${{ steps.releaseinfo.outputs.version }}" - - JSON="{\"ref\":\"hidden/workflows\",\"inputs\":{\"payload\":\"$PAYLOAD_B64\",\"name\":\"$NAME\",\"tag\":\"$TAG\"}}" - - #JSON="{\"ref\":\"hidden/workflows\",\"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" diff --git a/metadata.txt b/metadata.txt new file mode 100644 index 0000000..f1860c7 --- /dev/null +++ b/metadata.txt @@ -0,0 +1,14 @@ +[general] +name=LNO Sachsen | Plugin Basisfunktionen +qgisMinimumVersion=3.40 +qgisMaximumVersion=3.99 +description=Plugin mit Basisfunktionen +version= +author=Daniel Helbig +email=daniel.helbig@kreis-meissen.de +homepage=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_SN_Basis +tracker=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_SN_Basis/issues +repository=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_SN_Basis/src/branch/unstable/ +experimental=true +deprecated=false +supportsQt6=true \ No newline at end of file diff --git a/plugin.cfg b/plugin.cfg deleted file mode 100644 index 0f64224..0000000 --- a/plugin.cfg +++ /dev/null @@ -1,10 +0,0 @@ -name=LNO Sachsen | Basisfunktionen -description=Plugin mit Basisfunktionen -author=Michael Otto -email=michael.otto@landkreis-mittelsachsen.de -qgisMinimumVersion=3.40 -qgisMaximumVersion=4.99 -deprecated=False -experimental=True -supportsQt6=Yes -zip_folder=sn_basis \ No newline at end of file