no way this works

This commit is contained in:
2025-06-07 12:16:53 +02:00
parent 7d76c29d97
commit 884401e8c8
2 changed files with 44 additions and 75 deletions

View File

@@ -23,7 +23,7 @@ jobs:
with: with:
token: ${{ secrets.TOKEN }} token: ${{ secrets.TOKEN }}
- name: Find matching skin entries - name: Find Skin Repositories for all users
id: find_skins id: find_skins
shell: sh shell: sh
run: | run: |

View File

@@ -22,100 +22,69 @@ jobs:
cd template-repo cd template-repo
git checkout --quiet HEAD -- "${{ env.TEMPLATE_REL_PATH }}" git checkout --quiet HEAD -- "${{ env.TEMPLATE_REL_PATH }}"
- name: Fetch and update every user repository - name: Fetch valid user repositories
id: fetch_repos
run: | run: |
page=1 page=1
per_page=50 per_page=50
valid_repos_file=$(mktemp)
while :; do while :; do
users_json=$( users_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/admin/users?limit=$per_page&page=$page")
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')
if [ "$users_count" -eq 0 ]; then [ "$users_count" -eq 0 ] && break
break
fi
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")
repos_json=$( repos_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/users/${user_login}/repos")
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 for j in $(seq 0 $((repo_count - 1))); do
owner=$(echo "$repos_json" | jq -r ".[$j].owner.login") owner=$(echo "$repos_json" | jq -r ".[$j].owner.login")
repo=$(echo "$repos_json" | jq -r ".[$j].name") repo=$(echo "$repos_json" | jq -r ".[$j].name")
( readme_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" "${{ env.GITEA_API }}/repos/$owner/$repo/contents/README.md" || echo "{}")
set -e content=$(echo "$readme_json" | jq -r .content 2>/dev/null | base64 -d 2>/dev/null || echo "")
echo ""
echo "[Processing repository: ${owner}/${repo}]"
echo " Checking README.md content" if echo "$content" | grep -qE "^---$" && \
readme_json=$(curl -sSL -H "Authorization: token ${{ secrets.TOKEN }}" \ echo "$content" | grep -q "^gitea: none" && \
"${{ env.GITEA_API }}/repos/${owner}/${repo}/contents/README.md" || echo "{}") echo "$content" | grep -q "^include_toc: true" && \
echo "$content" | grep -q "^# Skins"; then
if ! echo "$readme_json" | jq -e '.content' >/dev/null 2>&1; then echo "$owner/$repo" >> "$valid_repos_file"
echo " → No README.md found or inaccessible, skipping ${owner}/${repo}"
exit 0
fi fi
content=$(echo "$readme_json" | jq -r .content | base64 -d 2>/dev/null || echo "")
if ! echo "$content" | head -n 20 | grep -q "^---$"; then
echo " → Missing YAML front matter (---), skipping ${owner}/${repo}"
exit 0
fi
if ! ( echo "$content" | grep -q "^gitea: none" \
&& echo "$content" | grep -q "^include_toc: true" \
&& echo "$content" | grep -q "^# Skins" ); then
echo " → README.md does not match required headers, skipping ${owner}/${repo}"
exit 0
fi
echo " ✓ README.md matches expected format; proceeding"
echo " Cloning ${owner}/${repo}..."
tmpdir=$(mktemp -d)
git clone --quiet "https://${{ secrets.TOKEN }}@${{ vars.CONTAINER_REGISTRY }}/${owner}/${repo}.git" \
--depth 1 "$tmpdir"
cd "$tmpdir"
echo " Configuring commit identity"
git config user.email "arlind@sulej.ch"
git config user.name "ci-bot"
echo " Copying CI file into .gitea/workflows/ci.yml"
mkdir -p .gitea/workflows
cp "/workspace/osc/skins/template-repo/${{ env.TEMPLATE_REL_PATH }}" \
".gitea/workflows/ci.yml"
git add ".gitea/workflows/ci.yml"
echo " Checking for staged changes"
if git diff --cached --quiet; then
echo " → No changes detected, skipping update for ${owner}/${repo}"
else
echo " ✓ Changes detected"
echo " Committing update"
git commit -m "Update CI"
echo " Pushing to main branch"
git push origin HEAD:main
echo " ✓ Update pushed"
fi
cd - >/dev/null
rm -rf "$tmpdir"
echo "[Completed ${owner}/${repo}]"
) || {
echo "⚠ Skipping ${owner}/${repo} due to an error."
}
done done
done done
page=$((page + 1)) page=$((page + 1))
done done
echo "" echo "valid_repos_file=$valid_repos_file" >> "$GITHUB_OUTPUT"
- name: Update user repositories
run: |
valid_repos_file="${{ steps.fetch_repos.outputs.valid_repos_file }}"
while read -r repo_full; do
owner=$(echo "$repo_full" | cut -d'/' -f1)
repo=$(echo "$repo_full" | cut -d'/' -f2)
echo "[Processing repository: ${owner}/${repo}]"
tmpdir=$(mktemp -d)
git clone --quiet "https://${{ secrets.TOKEN }}@${{ vars.CONTAINER_REGISTRY }}/${owner}/${repo}.git" --depth 1 "$tmpdir"
cd "$tmpdir"
mkdir -p .gitea/workflows
cp "/workspace/template-repo/${{ env.TEMPLATE_REL_PATH }}" .gitea/workflows/ci.yml
git config user.email "arlind@sulej.ch"
git config user.name "ci-bot"
git add .gitea/workflows/ci.yml
if ! git diff --cached --quiet; then
git commit -m "Update CI"
git push origin HEAD:main
fi
cd - >/dev/null
rm -rf "$tmpdir"
echo "[Completed ${owner}/${repo}]"
done < "$valid_repos_file"
rm "$valid_repos_file"
echo "[Sync CI Complete]" echo "[Sync CI Complete]"