Files
skins/.gitea/workflows/deploy-ci.yaml
Arlind Sulejmani 24445bb75f
All checks were successful
Update Community Skins README / Full CI/CD Pipeline (push) Successful in 3s
add bash as shell
2025-06-08 17:05:00 +02:00

103 lines
4.3 KiB
YAML

name: Sync CI from skins-template to Every User Repository
on:
workflow_dispatch:
jobs:
sync-all:
runs-on: ubuntu-latest
container:
image: ${{ vars.CONTAINER_REGISTRY }}/arlind/skins:latest
env:
GITEA_API: https://${{ vars.CONTAINER_REGISTRY }}/api/v1
TOKEN: ${{ secrets.TOKEN }}
TEMPLATE_PATH: .gitea/workflows/ci.yml
steps:
- 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")
template_b64=$(echo "$resp" | jq -r .content)
echo "TEMPLATE_B64=$template_b64" >> $GITHUB_ENV
- name: Fetch valid user repositories
shell: bash
run: |
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_counter=1
while :; do
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")
repo_count=$(echo "$repos_json" | jq 'length')
if [ "$repo_count" -eq 0 ]; then
echo "no repos for $user_login"
else
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")
readme_json=$(curl -sSL -H "Authorization: token $TOKEN" "$GITEA_API/repos/$owner/$repo/contents/README.md" || echo "{}")
content=$(echo "$readme_json" | jq -r .content 2>/dev/null | base64 -d 2>/dev/null || echo "")
if echo "$content" | grep -qE "^---$" && echo "$content" | grep -q "^gitea: none" && echo "$content" | grep -q "^include_toc: true" && echo "$content" | grep -q "^# Skins"; then
echo "$owner/$repo" >> "$valid_repos_file"
echo "added $owner/$repo"
repo_matched=true
fi
done
[ "$repo_matched" = false ] && echo "no matching 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
shell: bash
run: |
mapfile -t repos < "$VALID_REPOS_FILE"
for idx in "${!repos[@]}"; do
repo_full=${repos[$idx]}
owner=${repo_full%%/*}
repo=${repo_full##*/}
url="$GITEA_API/repos/$owner/$repo/contents/$TEMPLATE_PATH"
tags_resp=$(curl -sSL -H "Authorization: token $TOKEN" "$GITEA_API/repos/$owner/$repo/tags")
latest_tag=$(echo "$tags_resp" | jq -r '.[0].name // ""')
if [ -n "$latest_tag" ] && [ "$latest_tag" != "v1.0.0" ]; then
curl -sSL -X DELETE -H "Authorization: token $TOKEN" "$GITEA_API/repos/$owner/$repo/git/refs/tags/$latest_tag"
fi
resp=$(curl -sSL -H "Authorization: token $TOKEN" "$url")
sha=$(echo "$resp" | jq -r 'if (type=="object" and .sha!=null) then .sha else "" end')
if [ -z "$sha" ]; then
payload=$(jq -n --arg m "Add CI from skins-template" --arg c "$TEMPLATE_B64" '{message: $m, content: $c, branch: "main"}')
else
payload=$(jq -n --arg m "Update CI from skins-template" --arg c "$TEMPLATE_B64" --arg s "$sha" '{message: $m, content: $c, sha: $s, branch: "main"}')
fi
curl -sSL -X PUT -H "Authorization: token $TOKEN" -H "Content-Type: application/json" -d "$payload" "$url"
done
- name: Cleanup
shell: bash
run: rm -f "$VALID_REPOS_FILE"