Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 8772d838d8 | |||
| 6454b79270 | |||
| 354e54a6d3 |
@@ -11,6 +11,8 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v6
|
- uses: actions/checkout@v6
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- uses: actions/setup-python@v5
|
- uses: actions/setup-python@v5
|
||||||
with:
|
with:
|
||||||
@@ -30,16 +32,17 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
set -eux
|
set -eux
|
||||||
|
|
||||||
mkdir -p dist buildtmp/{bin,logs,update}
|
mkdir -p dist buildtmp/
|
||||||
|
|
||||||
# Copie uniquement le contenu de scripts/ dans buildtmp/bin
|
# Copie uniquement le contenu de scripts/ dans buildtmp/bin
|
||||||
cp -r scripts/. buildtmp/bin/
|
cp -r scripts/. buildtmp/
|
||||||
|
|
||||||
# Exclure __init__.py
|
# Exclure __init__.py and remove buildtmp/__pycache__
|
||||||
find buildtmp/bin -name "__init__.py" -delete
|
find buildtmp/ -name "__init__.py" -delete
|
||||||
|
rm -R "buildtmp/__pycache__"
|
||||||
|
|
||||||
# Metadata
|
# Metadata
|
||||||
cat > buildtmp/update/BUILD_INFO.txt <<EOF
|
cat > buildtmp/BUILD_INFO.txt <<EOF
|
||||||
REPO=${{ gitea.event.repository.name }}
|
REPO=${{ gitea.event.repository.name }}
|
||||||
TAG=${{ gitea.ref_name }}
|
TAG=${{ gitea.ref_name }}
|
||||||
COMMIT=${{ gitea.sha }}
|
COMMIT=${{ gitea.sha }}
|
||||||
@@ -51,7 +54,7 @@ jobs:
|
|||||||
ls -la dist
|
ls -la dist
|
||||||
tar -tzf "dist/SDSAT-${{ gitea.ref_name }}.tar.gz" | head -n 50
|
tar -tzf "dist/SDSAT-${{ gitea.ref_name }}.tar.gz" | head -n 50
|
||||||
|
|
||||||
- name: Create Gitea release (and upload asset)
|
- name: Create Gitea release (with changelog) + upload asset
|
||||||
env:
|
env:
|
||||||
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||||||
OWNER: ${{ gitea.repository_owner }}
|
OWNER: ${{ gitea.repository_owner }}
|
||||||
@@ -59,17 +62,56 @@ jobs:
|
|||||||
TAG: ${{ gitea.ref_name }}
|
TAG: ${{ gitea.ref_name }}
|
||||||
GITEA_SERVER_URL: ${{ gitea.server_url }}
|
GITEA_SERVER_URL: ${{ gitea.server_url }}
|
||||||
run: |
|
run: |
|
||||||
set -eux
|
set -euo pipefail
|
||||||
API="${GITEA_SERVER_URL}/api/v1"
|
API="${GITEA_SERVER_URL}/api/v1"
|
||||||
|
|
||||||
# Create release (si existe déjà, on continue)
|
# 1) Trouver le tag précédent (semver vX.Y.Z), différent du tag courant
|
||||||
|
PREV_TAG=$(git tag --sort=-creatordate | grep -E '^v[0-9]+\.[0-9]+\.[0-9]+$' | grep -v "^${TAG}$" | head -n 1 || true)
|
||||||
|
|
||||||
|
if [ -n "${PREV_TAG}" ]; then
|
||||||
|
RANGE="${PREV_TAG}..${TAG}"
|
||||||
|
COMMITS=$(git log --pretty=format:"- %s (%h)" "${RANGE}")
|
||||||
|
FILES=$(git diff --name-status "${RANGE}")
|
||||||
|
else
|
||||||
|
RANGE="initial (up to ${TAG})"
|
||||||
|
COMMITS=$(git log --pretty=format:"- %s (%h)" "${TAG}")
|
||||||
|
FILES=$(git show --name-status --pretty="" "${TAG}")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 2) Construire le body Markdown
|
||||||
|
cat > /tmp/release_body.md <<EOF
|
||||||
|
## Changes (${RANGE})
|
||||||
|
|
||||||
|
${COMMITS}
|
||||||
|
|
||||||
|
## Files changed
|
||||||
|
\`\`\`
|
||||||
|
${FILES}
|
||||||
|
\`\`\`
|
||||||
|
|
||||||
|
## Build info
|
||||||
|
- Repo: ${REPO}
|
||||||
|
- Tag: ${TAG}
|
||||||
|
- Commit: ${{ gitea.sha }}
|
||||||
|
- Built at (UTC): $(date -u +"%Y-%m-%dT%H:%M:%SZ")
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# 3) Créer le JSON payload (via python pour éviter les soucis d'escaping)
|
||||||
|
python -c 'import json; tag=open("/dev/stdin").read().strip()' <<< "${TAG}" >/dev/null 2>&1 || true
|
||||||
|
python -c 'import json; import pathlib; tag=pathlib.Path("/tmp/tag.txt").read_text().strip() if pathlib.Path("/tmp/tag.txt").exists() else ""' >/dev/null 2>&1 || true
|
||||||
|
echo "${TAG}" > /tmp/tag.txt
|
||||||
|
|
||||||
|
python -c 'import json, pathlib; tag=pathlib.Path("/tmp/tag.txt").read_text().strip(); body=pathlib.Path("/tmp/release_body.md").read_text(); print(json.dumps({"tag_name":tag,"name":tag,"body":body,"draft":False,"prerelease":False}))' \
|
||||||
|
> /tmp/release_payload.json
|
||||||
|
|
||||||
|
# 4) Créer la release (si déjà existante, on continue)
|
||||||
curl -sS -X POST "${API}/repos/${OWNER}/${REPO}/releases" \
|
curl -sS -X POST "${API}/repos/${OWNER}/${REPO}/releases" \
|
||||||
-H "Authorization: token ${GITEA_TOKEN}" \
|
-H "Authorization: token ${GITEA_TOKEN}" \
|
||||||
-H "Content-Type: application/json" \
|
-H "Content-Type: application/json" \
|
||||||
-d "{\"tag_name\":\"${TAG}\",\"name\":\"${TAG}\",\"draft\":false,\"prerelease\":false}" \
|
-d @/tmp/release_payload.json \
|
||||||
>/tmp/release_create.json || true
|
>/tmp/release.json || true
|
||||||
|
|
||||||
# Récupère l'id de la release par tag (fiable)
|
# 5) Récupérer l'ID de la release (par tag) et uploader l'asset
|
||||||
curl -sS "${API}/repos/${OWNER}/${REPO}/releases/tags/${TAG}" \
|
curl -sS "${API}/repos/${OWNER}/${REPO}/releases/tags/${TAG}" \
|
||||||
-H "Authorization: token ${GITEA_TOKEN}" \
|
-H "Authorization: token ${GITEA_TOKEN}" \
|
||||||
>/tmp/release_get.json
|
>/tmp/release_get.json
|
||||||
@@ -77,8 +119,6 @@ jobs:
|
|||||||
RID=$(python -c "import json;print(json.load(open('/tmp/release_get.json'))['id'])")
|
RID=$(python -c "import json;print(json.load(open('/tmp/release_get.json'))['id'])")
|
||||||
|
|
||||||
ASSET="dist/SDSAT-${TAG}.tar.gz"
|
ASSET="dist/SDSAT-${TAG}.tar.gz"
|
||||||
ls -la "${ASSET}"
|
|
||||||
|
|
||||||
curl -sS -X POST "${API}/repos/${OWNER}/${REPO}/releases/${RID}/assets?name=$(basename "${ASSET}")" \
|
curl -sS -X POST "${API}/repos/${OWNER}/${REPO}/releases/${RID}/assets?name=$(basename "${ASSET}")" \
|
||||||
-H "Authorization: token ${GITEA_TOKEN}" \
|
-H "Authorization: token ${GITEA_TOKEN}" \
|
||||||
-H "Content-Type: application/gzip" \
|
-H "Content-Type: application/gzip" \
|
||||||
|
|||||||
Reference in New Issue
Block a user