Compare commits
52 Commits
38df0cf2da
...
hidden/wor
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9bed9acf63 | ||
|
|
f8a9fb5296 | ||
|
|
1fb14d9a20 | ||
|
|
ed417e2324 | ||
|
|
20b8e2a2a0 | ||
|
|
167b9dfc64 | ||
|
|
4835be5bed | ||
|
|
cb12cd7d84 | ||
| fced948b1e | |||
|
|
d5ffff5383 | ||
|
|
075579174e | ||
|
|
b7c0b64f8c | ||
|
|
8904fb24cc | ||
|
|
3359596693 | ||
|
|
24c5879aaf | ||
|
|
19116b5d24 | ||
|
|
16e6319125 | ||
|
|
bf2890f318 | ||
|
|
0ce4b8e181 | ||
|
|
57ed4a0c83 | ||
|
|
fd8d7644d4 | ||
|
|
883b4ed327 | ||
|
|
1dbc7cde09 | ||
|
|
6f13b8f240 | ||
|
|
efe8f297d4 | ||
|
|
d872fc0d2a | ||
|
|
9dbc0bd2f0 | ||
|
|
8d4ab652a2 | ||
|
|
d0c2f43075 | ||
|
|
8c31def8e4 | ||
|
|
5342cd9bef | ||
|
|
a91fb68276 | ||
|
|
96fedd70ab | ||
|
|
1020929511 | ||
|
|
541261a15a | ||
|
|
d44900afd7 | ||
|
|
977466a026 | ||
|
|
ec0ae4d54d | ||
|
|
8d9f9ac251 | ||
|
|
8abf18165d | ||
|
|
a576bbe638 | ||
|
|
653cbb59f8 | ||
|
|
d92b86020f | ||
|
|
d83192e9cf | ||
|
|
fd2fd505c5 | ||
|
|
24b3b75837 | ||
|
|
14e6ec381d | ||
|
|
2a2bde07bf | ||
|
|
428fa3e2a5 | ||
|
|
d313473a5d | ||
|
|
249efca913 | ||
|
|
860f041837 |
@@ -25,31 +25,53 @@ jobs:
|
|||||||
- name: Abhängigkeiten installieren
|
- name: Abhängigkeiten installieren
|
||||||
shell: sh
|
shell: sh
|
||||||
run: |
|
run: |
|
||||||
apk add --no-cache bash jq git rsync zip
|
apk add --no-cache bash jq git rsync zip curl python3
|
||||||
|
|
||||||
- name: Daten zusammenstellen
|
- name: Daten zusammenstellen
|
||||||
id: daten
|
id: daten
|
||||||
run: |
|
run: |
|
||||||
DECODED=$(echo "${{ github.event.inputs.payload }}" | base64 -d)
|
DECODED=$(echo "${{ github.event.inputs.payload }}" | base64 -d)
|
||||||
|
|
||||||
echo "version=$(echo "$DECODED" | jq -r '.version')" >> $GITHUB_OUTPUT
|
# Werte aus Payload auslesen
|
||||||
echo "channel=$(echo "$DECODED" | jq -r '.channel')" >> $GITHUB_OUTPUT
|
NAME=$(echo "$DECODED" | jq -r '.name')
|
||||||
echo "prerelease=$(echo "$DECODED" | jq -r '.prerelease')" >> $GITHUB_OUTPUT
|
GROUP=$(echo "$DECODED" | jq -r '.group')
|
||||||
echo "zip_folder=$(echo "$DECODED" | jq -r '.zip_folder')" >> $GITHUB_OUTPUT
|
VERSION=$(echo "$DECODED" | jq -r '.version')
|
||||||
|
CHANNEL=$(echo "$DECODED" | jq -r '.channel')
|
||||||
|
PRERELEASE=$(echo "$DECODED" | jq -r '.prerelease')
|
||||||
|
ZIP_FOLDER=$(echo "$DECODED" | jq -r '.zip_folder')
|
||||||
|
ZIP_FILE=$(echo "$DECODED" | jq -r '.zip_file')
|
||||||
|
TAG=$(echo "$DECODED" | jq -r '.tag')
|
||||||
|
ID=$(echo "$DECODED" | jq -r '.zip_folder')
|
||||||
|
|
||||||
echo "version=$(echo "$DECODED" | jq -r '.version')"
|
# Outputs setzen
|
||||||
echo "channel=$(echo "$DECODED" | jq -r '.channel')"
|
echo "name=$NAME" >> $GITHUB_OUTPUT
|
||||||
echo "prerelease=$(echo "$DECODED" | jq -r '.prerelease')"
|
echo "group=$GROUP" >> $GITHUB_OUTPUT
|
||||||
echo "zip_folder=$(echo "$DECODED" | jq -r '.zip_folder')"
|
echo "version=$VERSION" >> $GITHUB_OUTPUT
|
||||||
|
echo "channel=$CHANNEL" >> $GITHUB_OUTPUT
|
||||||
|
echo "prerelease=$PRERELEASE" >> $GITHUB_OUTPUT
|
||||||
|
echo "zip_folder=$ZIP_FOLDER" >> $GITHUB_OUTPUT
|
||||||
|
echo "zip_file=$ZIP_FILE" >> $GITHUB_OUTPUT
|
||||||
|
echo "tag=$TAG" >> $GITHUB_OUTPUT
|
||||||
|
echo "id=$ID" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
# Debug-Ausgabe
|
||||||
|
echo "name=$NAME"
|
||||||
|
echo "group=$GROUP"
|
||||||
|
echo "version=$VERSION"
|
||||||
|
echo "channel=$CHANNEL"
|
||||||
|
echo "prerelease=$PRERELEASE"
|
||||||
|
echo "zip_folder=$ZIP_FOLDER"
|
||||||
|
echo "zip_file=$ZIP_FILE"
|
||||||
|
echo "tag=$TAG"
|
||||||
|
echo "id=$ID"
|
||||||
|
|
||||||
GIT_REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git"
|
GIT_REPO_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}.git"
|
||||||
echo "git_repo_url=$GIT_REPO_URL" >> $GITHUB_OUTPUT
|
echo "git_repo_url=$GIT_REPO_URL" >> $GITHUB_OUTPUT
|
||||||
echo "git_repo_url=$GIT_REPO_URL"
|
|
||||||
|
|
||||||
PAYLOAD_REPO=$(echo "$DECODED" | jq -r '.git_url')
|
PAYLOAD_REPO="${GROUP}/${NAME}"
|
||||||
|
echo $PAYLOAD_REPO
|
||||||
GIT_PLUGIN_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/$PAYLOAD_REPO.git"
|
GIT_PLUGIN_URL="https://${RELEASE_TOKEN}:x-oauth-basic@${{ vars.RELEASE_URL }}/$PAYLOAD_REPO.git"
|
||||||
echo "git_plugin_url=$GIT_PLUGIN_URL" >> $GITHUB_OUTPUT
|
echo "git_plugin_url=$GIT_PLUGIN_URL" >> $GITHUB_OUTPUT
|
||||||
echo "git_plugin_url=$GIT_PLUGIN_URL"
|
|
||||||
|
|
||||||
- name: Repositorys klonen
|
- name: Repositorys klonen
|
||||||
run: |
|
run: |
|
||||||
@@ -68,25 +90,24 @@ jobs:
|
|||||||
- name: Metadata anpassen
|
- name: Metadata anpassen
|
||||||
run: |
|
run: |
|
||||||
cd plugin
|
cd plugin
|
||||||
INI_FILE="metadata.txt"
|
|
||||||
# version setzen
|
|
||||||
sed -i "s/^version=.*/version=$VERSION/" "$INI_FILE"
|
|
||||||
|
|
||||||
# experimental setzen
|
sed -i "s/^version=.*/version=$VERSION-$CHANNEL/" "$FILE"
|
||||||
|
|
||||||
if [ "$PRERELEASE" = "true" ]; then
|
if [ "$PRERELEASE" = "true" ]; then
|
||||||
sed -i "s/^experimental=.*/experimental=true/" "$INI_FILE"
|
sed -i "s/^experimental=.*/experimental=true/" "$FILE"
|
||||||
else
|
else
|
||||||
sed -i "s/^experimental=.*/experimental=false/" "$INI_FILE"
|
sed -i "s/^experimental=.*/experimental=false/" "$FILE"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# channel im repository ersetzen
|
# channel im repository ersetzen
|
||||||
sed -i "s|^\(repository=.*src/branch/\).*|\1$CHANNEL/|" "$INI_FILE"
|
sed -i "s|^\(repository=.*src/branch/\).*|\1$CHANNEL/|" "$FILE"
|
||||||
|
|
||||||
# Debug: Ausgabe der Datei
|
# Debug: Ausgabe der Datei
|
||||||
echo "== Inhalt der angepassten INI-Datei =="
|
echo "== Inhalt der angepassten INI-Datei =="
|
||||||
cat "$INI_FILE"
|
cat "$FILE"
|
||||||
|
|
||||||
env:
|
env:
|
||||||
|
FILE: "metadata.txt"
|
||||||
VERSION: ${{ steps.daten.outputs.version }}
|
VERSION: ${{ steps.daten.outputs.version }}
|
||||||
PRERELEASE: ${{ steps.daten.outputs.prerelease }}
|
PRERELEASE: ${{ steps.daten.outputs.prerelease }}
|
||||||
CHANNEL: ${{ steps.daten.outputs.channel }}
|
CHANNEL: ${{ steps.daten.outputs.channel }}
|
||||||
@@ -94,18 +115,298 @@ jobs:
|
|||||||
- name: ZIP-Datei erstellen
|
- name: ZIP-Datei erstellen
|
||||||
id: zip
|
id: zip
|
||||||
run: |
|
run: |
|
||||||
mkdir -p zip
|
mkdir -p ${ZIP_FOLDER}
|
||||||
|
|
||||||
rsync -a \
|
rsync -a \
|
||||||
--exclude='.git' \
|
--exclude='.git' \
|
||||||
--exclude='.gitea' \
|
--exclude='.gitea' \
|
||||||
--exclude='.gitignore' \
|
--exclude='.gitignore' \
|
||||||
--exclude='plugin.cfg' \
|
|
||||||
--exclude='*/__pycache__/*' \
|
--exclude='*/__pycache__/*' \
|
||||||
./plugin/ ./zip/${ZIP_FOLDER}/
|
./plugin/ ./${ZIP_FOLDER}/
|
||||||
|
|
||||||
ls -la zip/${ZIP_FOLDER}/
|
ls -la ${ZIP_FOLDER}/
|
||||||
|
zip -r "${ZIP_FILE}" "${ZIP_FOLDER}/"
|
||||||
|
ls -la
|
||||||
|
|
||||||
env:
|
env:
|
||||||
ZIP_FOLDER: ${{ steps.daten.outputs.zip_folder }}
|
ZIP_FOLDER: ${{ steps.daten.outputs.zip_folder }}
|
||||||
ZIP_FILE: ${{ steps.daten.outputs.zip_folder }}.zip
|
ZIP_FILE: ${{ steps.daten.outputs.zip_file }}
|
||||||
|
|
||||||
|
- name: Changelog einlesen
|
||||||
|
id: changelog
|
||||||
|
run: |
|
||||||
|
cd plugin
|
||||||
|
|
||||||
|
# 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: Gitea-Release erstellen
|
||||||
|
id: create_release
|
||||||
|
run: |
|
||||||
|
API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${PLUGIN_GROUP}/${PLUGIN_NAME}/releases"
|
||||||
|
|
||||||
|
JSON=$(jq -n \
|
||||||
|
--arg tag "$VERSION-$CHANNEL" \
|
||||||
|
--arg name "Version $VERSION-$CHANNEL" \
|
||||||
|
--arg body "$BODY" \
|
||||||
|
--argjson prerelease "$PRERELEASE" \
|
||||||
|
'{tag_name: $tag, name: $name, body: $body, prerelease: $prerelease}')
|
||||||
|
|
||||||
|
API_RESPONSE=$(curl -s -X POST "$API_URL" \
|
||||||
|
-H "accept: application/json" \
|
||||||
|
-H "Authorization: token $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
|
||||||
|
env:
|
||||||
|
PRERELEASE: ${{ steps.daten.outputs.prerelease }}
|
||||||
|
BODY: ${{ steps.changelog.outputs.current }}
|
||||||
|
VERSION: ${{ steps.daten.outputs.version }}
|
||||||
|
TAG: ${{ steps.daten.outputs.tag }}
|
||||||
|
PLUGIN_NAME: ${{ steps.daten.outputs.name }}
|
||||||
|
PLUGIN_GROUP: ${{ steps.daten.outputs.group }}
|
||||||
|
RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }}
|
||||||
|
CHANNEL: ${{ steps.daten.outputs.channel }}
|
||||||
|
|
||||||
|
- name: ZIP-Datei hochladen
|
||||||
|
run: |
|
||||||
|
pwd
|
||||||
|
ls -la
|
||||||
|
echo @${ZIP_FILE}
|
||||||
|
|
||||||
|
API_URL="https://${{ vars.RELEASE_URL }}/api/v1/repos/${PLUGIN_GROUP}/${PLUGIN_NAME}/releases/${RELEASE_ID}/assets?name=${ZIP_FILE}"
|
||||||
|
|
||||||
|
curl -sf -X POST "$API_URL" \
|
||||||
|
-H "Authorization: token $RELEASE_TOKEN" \
|
||||||
|
-H "Content-Type: application/zip" \
|
||||||
|
--data-binary "@${ZIP_FILE}" \
|
||||||
|
-o upload_response.json
|
||||||
|
|
||||||
|
if jq -e '.id' upload_response.json >/dev/null 2>&1; then
|
||||||
|
echo "ZIP erfolgreich hochgeladen."
|
||||||
|
else
|
||||||
|
echo "Fehler beim Hochladen der ZIP!"
|
||||||
|
cat upload_response.json
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
env:
|
||||||
|
RELEASE_ID: ${{ steps.create_release.outputs.release_id }}
|
||||||
|
ZIP_FILE: ${{ steps.daten.outputs.zip_file }}
|
||||||
|
PLUGIN_NAME: ${{ steps.daten.outputs.name }}
|
||||||
|
PLUGIN_GROUP: ${{ steps.daten.outputs.group }}
|
||||||
|
RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }}
|
||||||
|
|
||||||
|
- name: Changelog aktualisieren
|
||||||
|
run: |
|
||||||
|
cd plugin
|
||||||
|
TMP_FILE=$(mktemp)
|
||||||
|
|
||||||
|
{
|
||||||
|
echo "---"
|
||||||
|
echo "Version $VERSION-$CHANNEL:"
|
||||||
|
cat "$FILE"
|
||||||
|
} > "$TMP_FILE"
|
||||||
|
|
||||||
|
mv "$TMP_FILE" "$FILE"
|
||||||
|
|
||||||
|
# Debug
|
||||||
|
echo "== Neuer Inhalt von changelog.txt =="
|
||||||
|
head -n 5 "$FILE"
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
pwd
|
||||||
|
env:
|
||||||
|
FILE: "changelog.txt"
|
||||||
|
VERSION: ${{ steps.daten.outputs.version }}
|
||||||
|
CHANNEL: ${{ steps.daten.outputs.channel }}
|
||||||
|
|
||||||
|
- name: Repository aktualisieren
|
||||||
|
run: |
|
||||||
|
cd plugin
|
||||||
|
|
||||||
|
git config user.name "release-bot"
|
||||||
|
git config user.email "ci@example.local"
|
||||||
|
|
||||||
|
if git rev-parse "$TAG" >/dev/null 2>&1; then
|
||||||
|
echo "Lösche alten lokalen Tag $TAG"
|
||||||
|
git tag -d "$TAG"
|
||||||
|
echo "Lösche alten Remote-Tag $TAG"
|
||||||
|
git -c http.extraheader="AUTHORIZATION: bearer $RELEASE_TOKEN" push origin :refs/tags/"$TAG"
|
||||||
|
else
|
||||||
|
echo "Tag $TAG nicht vorhanden"
|
||||||
|
fi
|
||||||
|
|
||||||
|
git add metadata.txt changelog.txt
|
||||||
|
git commit -m "Release $VERSION-$CHANNEL"
|
||||||
|
|
||||||
|
git -c http.extraheader="AUTHORIZATION: bearer $RELEASE_TOKEN" push origin HEAD:"$CHANNEL"
|
||||||
|
|
||||||
|
|
||||||
|
env:
|
||||||
|
CHANNEL: ${{ steps.daten.outputs.channel }}
|
||||||
|
VERSION: ${{ steps.daten.outputs.version }}
|
||||||
|
RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }}
|
||||||
|
TAG: ${{ steps.daten.outputs.tag }}
|
||||||
|
|
||||||
|
- name: XML-Datei bestimmen
|
||||||
|
id: xmlfile
|
||||||
|
run: |
|
||||||
|
case "${{ steps.daten.outputs.channel }}" in
|
||||||
|
stable) FILE="plugins.xml" ;;
|
||||||
|
testing) FILE="plugins-testing.xml" ;;
|
||||||
|
unstable) FILE="plugins-unstable.xml" ;;
|
||||||
|
esac
|
||||||
|
echo "file=$FILE" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: XML-Datei initialisieren
|
||||||
|
run: |
|
||||||
|
cd repo
|
||||||
|
FILE="${{ steps.xmlfile.outputs.file }}"
|
||||||
|
if [ ! -s "$FILE" ]; then
|
||||||
|
echo "<plugins></plugins>" > "$FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Alten Plugin-Eintrag entfernen
|
||||||
|
run: |
|
||||||
|
cd repo
|
||||||
|
FILE="${{ steps.xmlfile.outputs.file }}"
|
||||||
|
ID="${{ steps.daten.outputs.id }}"
|
||||||
|
|
||||||
|
# Entfernt den kompletten Plugin-Block
|
||||||
|
sed -i "/<pyqgis_plugin[^>]*plugin_id=\"${ID//\//\\/}\"/,/<\/pyqgis_plugin>/d" "$FILE"
|
||||||
|
|
||||||
|
- name: metadata.txt einlesen
|
||||||
|
id: metadata
|
||||||
|
run: |
|
||||||
|
cd plugin
|
||||||
|
while read -r line || [ -n "$line" ]; do
|
||||||
|
key="${line%%=*}"
|
||||||
|
value="${line#*=}"
|
||||||
|
echo "$key=$value" >> $GITHUB_OUTPUT
|
||||||
|
echo "$key=$value"
|
||||||
|
done < $FILE
|
||||||
|
env:
|
||||||
|
FILE: "metadata.txt"
|
||||||
|
|
||||||
|
- name: Template anwenden und neue XML erzeugen
|
||||||
|
run: |
|
||||||
|
cd repo
|
||||||
|
|
||||||
|
FILE="${{ steps.xmlfile.outputs.file }}"
|
||||||
|
|
||||||
|
git fetch origin hidden/templates
|
||||||
|
git checkout origin/hidden/templates -- plugin.template
|
||||||
|
|
||||||
|
TEMPLATE="plugin.template"
|
||||||
|
cat "$TEMPLATE"
|
||||||
|
|
||||||
|
# Template laden
|
||||||
|
ENTRY=$(cat "$TEMPLATE")
|
||||||
|
|
||||||
|
ENTRY="${ENTRY//\{\{NAME\}\}/${{ steps.metadata.outputs.name }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{QGIS_MIN\}\}/${{ steps.metadata.outputs.qgisMinimumVersion }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{QGIS_MAX\}\}/${{ steps.metadata.outputs.qgisMaximumVersion }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{DESCRIPTION\}\}/${{ steps.metadata.outputs.description }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{VERSION\}\}/${{ steps.metadata.outputs.version }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{AUTHOR\}\}/${{ steps.metadata.outputs.author }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{EMAIL\}\}/${{ steps.metadata.outputs.email }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{HOMEPAGE\}\}/${{ steps.metadata.outputs.homepage }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{TRACKER\}\}/${{ steps.metadata.outputs.tracker }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{REPOSITORY\}\}/${{ steps.metadata.outputs.repository }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{EXPERIMENTAL\}\}/${{ steps.metadata.outputs.experimental }}}"
|
||||||
|
ENTRY="${ENTRY//\{\{DEPRECATED\}\}/${{ steps.metadata.outputs.deprecated }}}"
|
||||||
|
|
||||||
|
ENTRY="${ENTRY//\{\{ID\}\}/${{ steps.daten.outputs.id }}}"
|
||||||
|
|
||||||
|
URL=${{ steps.metadata.outputs.homepage }}/releases/download/${{ steps.daten.outputs.version }}-${{ steps.daten.outputs.channel }}/${{ steps.daten.outputs.zip_file }}
|
||||||
|
ENTRY="${ENTRY//\{\{URL\}\}/$URL}"
|
||||||
|
|
||||||
|
export CHANGELOG="${{ steps.changelog.outputs.current }}"
|
||||||
|
export ENTRY="$ENTRY"
|
||||||
|
ENTRY=$(python3 - <<'EOF'
|
||||||
|
import os
|
||||||
|
|
||||||
|
changelog = os.environ.get("CHANGELOG", "")
|
||||||
|
entry = os.environ.get("ENTRY", "")
|
||||||
|
|
||||||
|
changelog = changelog.replace("&", "&")
|
||||||
|
changelog = changelog.replace("<", "<")
|
||||||
|
changelog = changelog.replace(">", ">")
|
||||||
|
|
||||||
|
lines = changelog.splitlines()
|
||||||
|
changelog_clean = " ".join(line for line in lines if line.strip())
|
||||||
|
|
||||||
|
result = entry.replace("{{CHANGELOG}}", changelog_clean)
|
||||||
|
|
||||||
|
print(result, end="")
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
|
||||||
|
echo "$ENTRY"
|
||||||
|
|
||||||
|
# Neue Datei erzeugen
|
||||||
|
{
|
||||||
|
# Alles vor </plugins>
|
||||||
|
sed '/<\/plugins>/d' "$FILE"
|
||||||
|
|
||||||
|
# Neuen Eintrag einfügen
|
||||||
|
printf "%s\n" "$ENTRY"
|
||||||
|
|
||||||
|
# </plugins> wieder anhängen
|
||||||
|
echo "</plugins>"
|
||||||
|
} > new.xml
|
||||||
|
|
||||||
|
mv new.xml "$FILE"
|
||||||
|
rm $TEMPLATE
|
||||||
|
|
||||||
|
- name: Commit & Push
|
||||||
|
run: |
|
||||||
|
cd repo
|
||||||
|
|
||||||
|
git config user.name "release-bot"
|
||||||
|
git config user.email "ci@example.local"
|
||||||
|
|
||||||
|
git add .
|
||||||
|
|
||||||
|
# Commit nur, wenn Änderungen vorhanden sind
|
||||||
|
if ! git diff --cached --quiet; then
|
||||||
|
git commit -m "${{ inputs.name }} ${{ steps.metadata.outputs.version }}"
|
||||||
|
else
|
||||||
|
echo "Keine Änderungen – kein Commit notwendig."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Token in die URL einbauen
|
||||||
|
git remote set-url origin "https://${{ secrets.RELEASE_TOKEN }}:@${{ vars.RELEASE_URL }}/AG_QGIS/Repository.git"
|
||||||
|
|
||||||
|
git push origin main
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user