no way this works
All checks were successful
Update Community Skins README / Full CI/CD Pipeline (push) Successful in 3s

This commit is contained in:
2025-06-07 12:31:49 +02:00
parent fb99a9ce37
commit 77337d63e3

View File

@@ -17,10 +17,11 @@ jobs:
steps: steps:
- name: Clone skins-template - name: Clone skins-template
run: | run: |
echo "[Sync CI Started]" echo "Clone skins-template"
git clone --quiet "${{ env.TEMPLATE_REPO_URL }}" --depth 1 template-repo git clone --quiet "${{ env.TEMPLATE_REPO_URL }}" --depth 1 template-repo
cd template-repo cd template-repo
git checkout --quiet HEAD -- "${{ env.TEMPLATE_REL_PATH }}" git checkout --quiet HEAD -- "${{ env.TEMPLATE_REL_PATH }}"
echo "✓ Finished cloning osc/skins-template"
- name: Fetch valid user repositories - name: Fetch valid user repositories
id: fetch_repos id: fetch_repos
@@ -28,35 +29,45 @@ jobs:
page=1 page=1
per_page=50 per_page=50
valid_repos_file=$(mktemp) valid_repos_file=$(mktemp)
user_count_total=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/admin/users" | jq 'length')
user_counter=1
while :; do while :; do
echo "Fetching users page $page"
users_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/admin/users?limit=$per_page&page=$page") users_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/admin/users?limit=$per_page&page=$page")
users_count=$(echo "$users_json" | jq 'length') users_count=$(echo "$users_json" | jq 'length')
[ "$users_count" -eq 0 ] && break [ "$users_count" -eq 0 ] && break
for i in $(seq 0 $((users_count - 1))); do for i in $(seq 0 $((users_count - 1))); do
user_login=$(echo "$users_json" | jq -r ".[$i].login") user_login=$(echo "$users_json" | jq -r ".[$i].login")
echo "Processing user: $user_login" echo "[$user_counter/$user_count_total] Processing user: $user_login"
repos_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/users/${user_login}/repos") repos_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/users/${user_login}/repos")
repo_count=$(echo "$repos_json" | jq 'length') repo_count=$(echo "$repos_json" | jq 'length')
for j in $(seq 0 $((repo_count - 1))); do if [ "$repo_count" -eq 0 ]; then
owner=$(echo "$repos_json" | jq -r ".[$j].owner.login") echo " ✖ User has no repositories."
repo=$(echo "$repos_json" | jq -r ".[$j].name") 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")
echo "Checking repo: $owner/$repo" readme_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/repos/$owner/$repo/contents/README.md" || echo "{}")
readme_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.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 "")
content=$(echo "$readme_json" | jq -r .content 2>/dev/null | base64 -d 2>/dev/null || echo "")
if echo "$content" | grep -qE "^---$" && \ if echo "$content" | grep -qE "^---$" && \
echo "$content" | grep -q "^gitea: none" && \ echo "$content" | grep -q "^gitea: none" && \
echo "$content" | grep -q "^include_toc: true" && \ echo "$content" | grep -q "^include_toc: true" && \
echo "$content" | grep -q "^# Skins"; then echo "$content" | grep -q "^# Skins"; then
echo "$owner/$repo" >> "$valid_repos_file" echo "$owner/$repo" >> "$valid_repos_file"
echo "Added $owner/$repo to update list" echo "Added $owner/$repo to update list"
fi repo_matched=true
done fi
done
[ "$repo_matched" = false ] && echo " ✓ User has no repositories matching the criteria"
fi
user_counter=$((user_counter + 1))
done done
page=$((page + 1)) page=$((page + 1))
@@ -67,10 +78,14 @@ jobs:
- name: Update user repositories - name: Update user repositories
run: | run: |
valid_repos_file="${{ steps.fetch_repos.outputs.valid_repos_file }}" valid_repos_file="${{ steps.fetch_repos.outputs.valid_repos_file }}"
repo_total=$(wc -l < "$valid_repos_file")
repo_counter=1
while read -r repo_full; do while read -r repo_full; do
owner=$(echo "$repo_full" | cut -d'/' -f1) owner=$(echo "$repo_full" | cut -d'/' -f1)
repo=$(echo "$repo_full" | cut -d'/' -f2) repo=$(echo "$repo_full" | cut -d'/' -f2)
echo "[Processing repository: ${owner}/${repo}]" echo "[$repo_counter/$repo_total] Processing Repository: $owner/$repo"
tmpdir=$(mktemp -d) tmpdir=$(mktemp -d)
git clone --quiet "https://${{ secrets.TOKEN }}@${{ vars.CONTAINER_REGISTRY }}/${owner}/${repo}.git" --depth 1 "$tmpdir" git clone --quiet "https://${{ secrets.TOKEN }}@${{ vars.CONTAINER_REGISTRY }}/${owner}/${repo}.git" --depth 1 "$tmpdir"
cd "$tmpdir" cd "$tmpdir"
@@ -83,15 +98,17 @@ jobs:
if ! git diff --cached --quiet; then if ! git diff --cached --quiet; then
git commit -m "Update CI" git commit -m "Update CI"
git push origin HEAD:main git push origin HEAD:main
echo "Updated and pushed $owner/$repo" echo "Updated and pushed $owner/$repo"
else else
echo "No changes detected for $owner/$repo" echo "No changes detected for $owner/$repo"
fi fi
cd - >/dev/null cd - >/dev/null
rm -rf "$tmpdir" rm -rf "$tmpdir"
echo "[Completed ${owner}/${repo}]" echo "Completed $owner/$repo"
done < "$valid_repos_file"
rm "$valid_repos_file"
repo_counter=$((repo_counter + 1))
done < "$valid_repos_file"
rm "$valid_repos_file"
echo "[Sync CI Complete]" echo "[Sync CI Complete]"