diff --git a/.gitea/workflows/ci.yml b/.gitea/workflows/ci.yml index f800420..94b4024 100644 --- a/.gitea/workflows/ci.yml +++ b/.gitea/workflows/ci.yml @@ -35,53 +35,41 @@ jobs: user_rows_file=$(mktemp) avatar_rows_file=$(mktemp) - echo "Fetching users page 1..." >&2 - users_json=$(curl -sSL \ - -H "Authorization: token ${{ secrets.TOKEN }}" \ - -H "Cache-Control: no-cache" \ - -H "Pragma: no-cache" \ - "$GITEA_API/admin/users?limit=50&page=1&_ts=$(date +%s)") - - jq_type=$(echo "$users_json" | jq -r 'type' 2>/dev/null || echo "jq_error_type") - jq_length=$(echo "$users_json" | jq 'length' 2>/dev/null || echo "jq_error_length") - if [ "$jq_type" != "array" ] || [ "$jq_length" -eq 0 ]; then - echo "No users found or invalid JSON received on page 1. (Type: $jq_type, Length: $jq_length)." >&2 - exit 1 - fi - - i=0 - while [ "$i" -lt "$jq_length" ]; do - user_login=$(echo "$users_json" | jq -r ".[$i].login") - echo "Processing user: $user_login" >&2 - - repos_json=$(curl -sSL \ + page=1 + while :; do + echo "Fetching users page $page..." >&2 + users_json=$(curl --retry 3 --retry-delay 5 -sSL \ -H "Authorization: token ${{ secrets.TOKEN }}" \ - -H "Cache-Control: no-cache" \ - -H "Pragma: no-cache" \ - "$GITEA_API/users/$user_login/repos?_ts=$(date +%s)") + "$GITEA_API/admin/users?limit=50&page=$page&_ts=$(date +%s)") - repos_type=$(echo "$repos_json" | jq -r 'type' 2>/dev/null || echo "not_array") - repos_count=$(echo "$repos_json" | jq 'length' 2>/dev/null || echo "0") - if [ "$repos_type" != "array" ] || [ "$repos_count" -eq 0 ]; then - echo " No repos or invalid JSON for $user_login" >&2 - i=$((i + 1)) - continue - fi + count=$(echo "$users_json" | jq 'length') + [ "$count" -eq 0 ] && break - j=0 - while [ "$j" -lt "$repos_count" ]; do - owner=$(echo "$repos_json" | jq -r ".[$j].owner.login") - repo=$(echo "$repos_json" | jq -r ".[$j].name") - html_url=$(echo "$repos_json" | jq -r ".[$j].html_url") + for i in $(seq 0 $((count - 1))); do + user_login=$(echo "$users_json" | jq -r ".[$i].login") + echo "Processing user: $user_login" >&2 - echo " Checking repo: $repo" >&2 - readme_json=$(curl -sSL \ + repos_json=$(curl --retry 3 --retry-delay 5 -sSL \ -H "Authorization: token ${{ secrets.TOKEN }}" \ - -H "Cache-Control: no-cache" \ - -H "Pragma: no-cache" \ - "$GITEA_API/repos/$owner/$repo/contents/README.md?_ts=$(date +%s)" || echo "{}") + "$GITEA_API/users/$user_login/repos?_ts=$(date +%s)") - if echo "$readme_json" | jq -e '.content' >/dev/null 2>&1; then + repos_type=$(echo "$repos_json" | jq -r 'type' 2>/dev/null || echo "not_array") + repos_count=$(echo "$repos_json" | jq 'length' 2>/dev/null || echo "0") + [ "$repos_type" != "array" ] || [ "$repos_count" -eq 0 ] && continue + + for j in $(seq 0 $((repos_count - 1))); do + owner=$(echo "$repos_json" | jq -r ".[$j].owner.login") + repo=$(echo "$repos_json" | jq -r ".[$j].name") + html_url=$(echo "$repos_json" | jq -r ".[$j].html_url") + + echo " Checking repo: $repo" >&2 + http_code=$(curl --retry 3 --retry-delay 5 -s -w "%{http_code}" -o temp_readme.json \ + -H "Authorization: token ${{ secrets.TOKEN }}" \ + "$GITEA_API/repos/$owner/$repo/contents/README.md?_ts=$(date +%s)") + + [ "$http_code" != "200" ] && continue + + readme_json=$(cat temp_readme.json) content=$(echo "$readme_json" | jq -r .content | base64 -d || echo "") echo "$content" | grep -q "^---$" && \ @@ -91,28 +79,28 @@ jobs: if [ $? -eq 0 ]; then osu_id=$(echo "$content" | awk '/osuid:[ ]*[0-9]+/ { match($0, /[0-9]+/); print substr($0, RSTART, RLENGTH); exit }') if [ -n "$osu_id" ]; then - user_data=$(curl -s \ - -H 'Cache-Control: no-cache' \ - -H 'Pragma: no-cache' \ - --compressed "https://osu.ppy.sh/api/get_user?k=${{ secrets.OSUAPIV1 }}&u=$osu_id&type=id&_ts=$(date +%s)") + user_data=$(curl --retry 3 --retry-delay 5 -s \ + "https://osu.ppy.sh/api/get_user?k=${{ secrets.OSUAPIV1 }}&u=$osu_id&type=id&_ts=$(date +%s)") pp_rank=$(echo "$user_data" | jq -r '.[0].pp_rank // "9999999"') pp_country_rank=$(echo "$user_data" | jq -r '.[0].pp_country_rank // "-"') username=$(echo "$user_data" | jq -r '.[0].username // "'$owner'"') padded_rank=$(printf "%07d" "$pp_rank") - printf "%s|
| Name | " >> "$README_PATH" - echo "Global Rank | " >> "$README_PATH" - echo "Country Rank | " >> "$README_PATH" - echo "Profile | " >> "$README_PATH" - echo "Skins | " >> "$README_PATH" - echo "
|---|
" >> "$README_PATH"
- sort -t '|' -k1,1n "${{ steps.find_skins.outputs.avatar_rows_file }}" | cut -d'|' -f2- >> "$README_PATH"
+ user_rows_file="${{ steps.find_skins.outputs.user_rows_file }}"
+ avatar_rows_file="${{ steps.find_skins.outputs.avatar_rows_file }}"
+
+ cat <
+ EOF
+
+ sort -t '|' -k1,1n "$avatar_rows_file" | cut -d'|' -f2- >> "$README_PATH"
echo "list instead of icons
+
+
+
+
+
+
+
+
+ EOF
+
+ sort -t '|' -k1,1n "$user_rows_file" | cut -d'|' -f2- >> "$README_PATH"
+
+ cat <Name
+ Global Rank
+ Country Rank
+ Profile
+ Skins
+