Update .gitea/workflows/deploy-ci.yaml

This commit is contained in:
2025-06-08 19:31:04 +02:00
parent 517d669aa3
commit 9f0847eb41

View File

@@ -17,7 +17,8 @@ jobs:
- name: Fetch CI template via Gitea API
shell: bash
run: |
resp=$(curl -sSL -H "Authorization: token $TOKEN" "$GITEA_API/repos/osc/skins-template/contents/$TEMPLATE_PATH?ref=main")
resp=$(curl -sSL -H "Authorization: token $TOKEN" \
"$GITEA_API/repos/osc/skins-template/contents/$TEMPLATE_PATH?ref=main")
template_b64=$(echo "$resp" | jq -r .content)
echo "TEMPLATE_B64=$template_b64" >> $GITHUB_ENV
@@ -27,48 +28,65 @@ jobs:
page=1
per_page=50
valid_repos_file=$(mktemp)
user_count_total=$(curl -sSL -H "Authorization: token $TOKEN" "$GITEA_API/admin/users" | jq 'length')
user_count_total=$(curl -sSL -H "Authorization: token $TOKEN" \
"$GITEA_API/admin/users" | jq 'length')
user_counter=1
while :; do
users_json=$(curl -sSL -H "Authorization: token $TOKEN" "$GITEA_API/admin/users?limit=$per_page&page=$page")
users_json=$(curl -sSL -H "Authorization: token $TOKEN" \
"$GITEA_API/admin/users?limit=$per_page&page=$page")
users_count=$(echo "$users_json" | jq 'length')
[ "$users_count" -eq 0 ] && break
for i in $(seq 0 $((users_count - 1))); do
user_login=$(echo "$users_json" | jq -r ".[$i].login")
echo "[$user_counter/$user_count_total] Processing user: $user_login"
repos_json=$(curl -sSL -H "Authorization: token $TOKEN" "$GITEA_API/users/$user_login/repos")
repos_json=$(curl -sSL -H "Authorization: token $TOKEN" \
"$GITEA_API/users/$user_login/repos")
repo_count=$(echo "$repos_json" | jq 'length')
if [ "$repo_count" -ne 0 ]; then
repo_matched=false
for j in $(seq 0 $((repo_count - 1))); do
owner=$(echo "$repos_json" | jq -r ".[$j].owner.login")
repo=$(echo "$repos_json" | jq -r ".[$j].name")
echo "DEBUG: Fetching README for $owner/$repo"
readme_json=$(curl -sSL -H "Authorization: token $TOKEN" \
"$GITEA_API/repos/$owner/$repo/contents/README.md?ref=main" || echo "{}")
echo "DEBUG: README JSON for $owner/$repo: $readme_json"
content=$(echo "$readme_json" \
| jq -r .content 2>/dev/null \
| base64 -d 2>/dev/null || echo "")
echo "DEBUG: Decoded content for $owner/$repo (first 10 lines):"
echo "$content" | sed -n '1,10p' | sed -n l
if echo "$content" | grep -qF '# Skins'; then
echo "DEBUG: Match found for '# Skins' in $owner/$repo"
content=$(echo "$readme_json" | jq -r .content 2>/dev/null \
| base64 -d 2>/dev/null || echo "")
content=$(echo "$content" \
| sed $'1s/^\xEF\xBB\xBF//' \
| sed 's/\r$//')
if [ "$owner" = "Zacatel" ]; then
echo "DEBUG: Normalized content for $owner/$repo (first 10 lines):"
echo "$content" | sed -n '1,10p' | sed -n l
fi
if echo "$content" | grep -qE '^[[:space:]]*#[[:space:]]*Skins[[:space:]]*$'; then
echo "DEBUG: Regex match for '# Skins' in $owner/$repo"
echo "$owner/$repo" >> "$valid_repos_file"
echo "added $owner/$repo"
repo_matched=true
else
echo "DEBUG: No '# Skins' heading in $owner/$repo"
echo "DEBUG: No regex match in $owner/$repo"
fi
done
[ "$repo_matched" = false ] && echo "no matching repos for $user_login"
else
echo "no repos for $user_login"
fi
user_counter=$((user_counter + 1))
done
page=$((page + 1))
done
echo "VALID_REPOS_FILE=$valid_repos_file" >> $GITHUB_ENV
- name: Update CI via Gitea API
@@ -80,13 +98,17 @@ jobs:
owner=${repo_full%%/*}
repo=${repo_full##*/}
api="$GITEA_API/repos/$owner/$repo"
default_branch=$(curl -sSL --fail -H "Authorization: token $TOKEN" "$api" | jq -r '.default_branch')
latest_tag=$(curl -sSL --fail -H "Authorization: token $TOKEN" "$api/tags" | jq -r '.[0].name // empty')
default_branch=$(curl -sSL --fail -H "Authorization: token $TOKEN" \
"$api" | jq -r '.default_branch')
latest_tag=$(curl -sSL --fail -H "Authorization: token $TOKEN" \
"$api/tags" | jq -r '.[0].name // empty')
if [[ -n "$latest_tag" && "$latest_tag" != "v1.0.0" ]]; then
curl -sSL -X DELETE -H "Authorization: token $TOKEN" "$api/git/refs/tags/$latest_tag" || true
curl -sSL -X DELETE -H "Authorization: token $TOKEN" \
"$api/git/refs/tags/$latest_tag" || true
fi
url="$api/contents/$TEMPLATE_PATH"
sha=$(curl -sSL -H "Authorization: token $TOKEN" "$url" | jq -r 'select(.sha != null).sha // empty' || true)
sha=$(curl -sSL -H "Authorization: token $TOKEN" "$url" \
| jq -r 'select(.sha != null).sha // empty' || true)
if [[ -z "$sha" ]]; then
action="Add"
msg="Add CI from skins-template"