diff --git a/.gitea/workflows/deploy-ci.yaml b/.gitea/workflows/deploy-ci.yaml index bb9de5f..17a64e3 100644 --- a/.gitea/workflows/deploy-ci.yaml +++ b/.gitea/workflows/deploy-ci.yaml @@ -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"