Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 38114e93fd |
@@ -122,7 +122,7 @@ jobs:
|
|||||||
files: |
|
files: |
|
||||||
dist/**/release-hub-*.tar.gz
|
dist/**/release-hub-*.tar.gz
|
||||||
dist/**/release-hub-*.zip
|
dist/**/release-hub-*.zip
|
||||||
|
|
||||||
publish-agent:
|
publish-agent:
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
needs: release
|
needs: release
|
||||||
@@ -131,43 +131,37 @@ jobs:
|
|||||||
PRODUCT: release-hub
|
PRODUCT: release-hub
|
||||||
AGENT_URL: ${{ secrets.AGENT_URL }}
|
AGENT_URL: ${{ secrets.AGENT_URL }}
|
||||||
AGENT_TOKEN: ${{ secrets.AGENT_TOKEN }}
|
AGENT_TOKEN: ${{ secrets.AGENT_TOKEN }}
|
||||||
|
SERVER_URL: ${{ github.server_url }}
|
||||||
# Funktioniert in GitHub und Gitea (Actions) weitgehend gleich:
|
REPOSITORY: ${{ github.repository }}
|
||||||
SERVER_URL: ${{ github.server_url }} # z.B. https://github.com oder https://gitea.example.com
|
TAG: ${{ github.ref_name }}
|
||||||
REPOSITORY: ${{ github.repository }} # owner/repo
|
|
||||||
TAG: ${{ github.ref_name }} # vX.Y.Z
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Download artifacts
|
- name: Download artifacts
|
||||||
uses: actions/download-artifact@v3
|
uses: actions/download-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: ./dist
|
path: ./dist
|
||||||
|
|
||||||
- name: Publish release metadata to Version Agent
|
- name: Publish release metadata to Version Agent
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
if [[ -z "${AGENT_URL:-}" || -z "${AGENT_TOKEN:-}" ]]; then
|
if [[ -z "${AGENT_URL:-}" || -z "${AGENT_TOKEN:-}" ]]; then
|
||||||
echo "Missing AGENT_URL or AGENT_TOKEN" >&2; exit 1
|
echo "Missing AGENT_URL or AGENT_TOKEN" >&2; exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
VERSION="${TAG#v}" # 12.3.1[-rc.1|-beta.1]
|
VERSION="${TAG#v}"
|
||||||
MAJOR="${VERSION%%.*}" # 12
|
MAJOR="${VERSION%%.*}"
|
||||||
BRANCH="${MAJOR}.x" # 12.x
|
BRANCH="${MAJOR}.x"
|
||||||
|
|
||||||
CHANNEL="stable"
|
CHANNEL="stable"
|
||||||
[[ "$VERSION" == *"-rc"* ]] && CHANNEL="rc"
|
[[ "$VERSION" == *"-rc"* ]] && CHANNEL="rc"
|
||||||
[[ "$VERSION" == *"-beta"* ]] && CHANNEL="beta"
|
[[ "$VERSION" == *"-beta"* ]] && CHANNEL="beta"
|
||||||
# Optional: Nightly-Channel bei Non-Tag-Builds (separater Job, siehe unten)
|
|
||||||
|
|
||||||
RELEASED_AT="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
|
RELEASED_AT="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
|
||||||
NOTES_URL="${SERVER_URL}/${REPOSITORY}/releases/tag/${TAG}"
|
NOTES_URL="${SERVER_URL}/${REPOSITORY}/releases/tag/${TAG}"
|
||||||
|
|
||||||
publish() { # args: OS ARCH FILE
|
publish() { # args: OS ARCH FILE
|
||||||
local OS="$1" ARCH="$2" FILE="$3"
|
local OS="$1" ARCH="$2" FILE="$3"
|
||||||
local BIT="64"
|
local BIT="64"; case "$ARCH" in 386|armv7) BIT="32";; esac
|
||||||
case "$ARCH" in 386|armv7) BIT="32";; esac
|
|
||||||
|
|
||||||
local FNAME="$(basename "$FILE")"
|
local FNAME="$(basename "$FILE")"
|
||||||
local URL="${SERVER_URL}/${REPOSITORY}/releases/download/${TAG}/${FNAME}"
|
local URL="${SERVER_URL}/${REPOSITORY}/releases/download/${TAG}/${FNAME}"
|
||||||
@@ -177,6 +171,7 @@ jobs:
|
|||||||
SIZE="$(stat -c%s "$FILE")"
|
SIZE="$(stat -c%s "$FILE")"
|
||||||
|
|
||||||
jq -n \
|
jq -n \
|
||||||
|
--arg product "$PRODUCT" \
|
||||||
--arg branch "$BRANCH" \
|
--arg branch "$BRANCH" \
|
||||||
--arg channel "$CHANNEL" \
|
--arg channel "$CHANNEL" \
|
||||||
--arg arch "$ARCH" \
|
--arg arch "$ARCH" \
|
||||||
@@ -189,6 +184,7 @@ jobs:
|
|||||||
--arg sha256 "$SHA256" \
|
--arg sha256 "$SHA256" \
|
||||||
--argjson size "$SIZE" \
|
--argjson size "$SIZE" \
|
||||||
'{
|
'{
|
||||||
|
product:$product,
|
||||||
branch:$branch, channel:$channel, arch:$arch, bit:$bit, os:$os,
|
branch:$branch, channel:$channel, arch:$arch, bit:$bit, os:$os,
|
||||||
release:{
|
release:{
|
||||||
version:$version, released_at:$released_at, notes_url:$notes,
|
version:$version, released_at:$released_at, notes_url:$notes,
|
||||||
@@ -202,12 +198,7 @@ jobs:
|
|||||||
}
|
}
|
||||||
|
|
||||||
shopt -s nullglob
|
shopt -s nullglob
|
||||||
|
|
||||||
# linux/amd64
|
|
||||||
for f in dist/**/${PRODUCT}-linux-amd64.tar.gz; do publish linux amd64 "$f"; done
|
for f in dist/**/${PRODUCT}-linux-amd64.tar.gz; do publish linux amd64 "$f"; done
|
||||||
# linux/arm64
|
|
||||||
for f in dist/**/${PRODUCT}-linux-arm64.tar.gz; do publish linux arm64 "$f"; done
|
for f in dist/**/${PRODUCT}-linux-arm64.tar.gz; do publish linux arm64 "$f"; done
|
||||||
# linux/armv7
|
|
||||||
for f in dist/**/${PRODUCT}-linux-armv7.tar.gz; do publish linux armv7 "$f"; done
|
for f in dist/**/${PRODUCT}-linux-armv7.tar.gz; do publish linux armv7 "$f"; done
|
||||||
# windows/amd64
|
for f in dist/**/${PRODUCT}-windows-amd64.zip; do publish windows amd64 "$f"; done
|
||||||
for f in dist/**/${PRODUCT}-windows-amd64.zip; do publish windows amd64 "$f"; done
|
|
||||||
|
|||||||
Reference in New Issue
Block a user