diff --git a/.gitea/workflows/ci.yml b/.gitea/workflows/ci.yml index 03c37f1..85853c6 100644 --- a/.gitea/workflows/ci.yml +++ b/.gitea/workflows/ci.yml @@ -43,129 +43,115 @@ jobs: jq -e . >/dev/null 2>&1 } + curl_json() { + body=$(mktemp) + code=$(curl --retry 3 --retry-delay 5 -s -o "$body" -w "%{http_code}" "$1") + printf "%s\n%s" "$code" "$body" + } + page=1 while :; do # Fetch user list - users_response=$(curl --retry 3 --retry-delay 5 -s -w "%{http_code}" \ - -H "Authorization: token ${{ secrets.TOKEN }}" \ - "$GITEA_API/admin/users?limit=50&page=$page&_ts=$(date +%s)") + read users_code users_body < <(curl_json "$GITEA_API/admin/users?limit=50&page=$page&_ts=$(date +%s)") + users_json=$(cat "$users_body") - users_code=$(printf "%s" "$users_response" | tail -c 3) - users_json=$(printf "%s" "$users_response" | head -c -3) - - if [ "$users_code" != "200" ] || ! echo "$users_json" | json_valid; then + if [ "$users_code" != "200" ] || ! printf "%s" "$users_json" | json_valid; then echo "❌ Invalid users JSON on page $page (HTTP $users_code)" echo "$users_json" > "$ARTIFACT_PATH/invalid_users_page_${page}.json" break fi - count=$(echo "$users_json" | jq 'length') + count=$(printf "%s" "$users_json" | jq 'length') [ "$count" -eq 0 ] && break echo "📄 Found $count users on page $page" - # Loop through users for i in $(seq 0 $((count - 1))); do - user_login=$(echo "$users_json" | jq -r ".[$i].login") + user_login=$(printf "%s" "$users_json" | jq -r ".[$i].login") echo "🔍 User: $user_login" - # Fetch repos for user - repos_response=$(curl --retry 3 --retry-delay 5 -s -w "%{http_code}" \ - -H "Authorization: token ${{ secrets.TOKEN }}" \ - "$GITEA_API/users/$user_login/repos?_ts=$(date +%s)") + # Fetch repos + read repos_code repos_body < <(curl_json "$GITEA_API/users/$user_login/repos?_ts=$(date +%s)") + repos_json=$(cat "$repos_body") - repos_code=$(printf "%s" "$repos_response" | tail -c 3) - repos_json=$(printf "%s" "$repos_response" | head -c -3) - - if [ "$repos_code" != "200" ] || ! echo "$repos_json" | json_valid; then + if [ "$repos_code" != "200" ] || ! printf "%s" "$repos_json" | json_valid; then echo " ❌ Invalid repo list for $user_login (HTTP $repos_code)" echo "$repos_json" > "$ARTIFACT_PATH/invalid_repos_${user_login}.json" continue fi - repos_count=$(echo "$repos_json" | jq 'length') + repos_count=$(printf "%s" "$repos_json" | jq 'length') echo " 📦 $repos_count repos found" [ "$repos_count" -eq 0 ] && continue - # Loop through repos 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") + owner=$(printf "%s" "$repos_json" | jq -r ".[$j].owner.login") + repo=$(printf "%s" "$repos_json" | jq -r ".[$j].name") + html_url=$(printf "%s" "$repos_json" | jq -r ".[$j].html_url") echo " → Repo: $owner/$repo" # Check Skins directory - dir_response=$(curl --retry 3 --retry-delay 5 -s -w "%{http_code}" \ - -H "Authorization: token ${{ secrets.TOKEN }}" \ - "$GITEA_API/repos/$owner/$repo/contents/Skins?_ts=$(date +%s)") - - dir_code=$(printf "%s" "$dir_response" | tail -c 3) - + read dir_code dir_body < <(curl_json "$GITEA_API/repos/$owner/$repo/contents/Skins?_ts=$(date +%s)") if [ "$dir_code" != "200" ]; then echo " ❌ Skipped: No Skins/ directory (HTTP $dir_code)" continue fi # Check README.md - readme_response=$(curl --retry 3 --retry-delay 5 -s -w "%{http_code}" \ - -H "Authorization: token ${{ secrets.TOKEN }}" \ - "$GITEA_API/repos/$owner/$repo/contents/README.md?_ts=$(date +%s)") - readme_code=$(printf "%s" "$readme_response" | tail -c 3) - readme_json=$(printf "%s" "$readme_response" | head -c -3) + read readme_code readme_body < <(curl_json "$GITEA_API/repos/$owner/$repo/contents/README.md?_ts=$(date +%s)") + readme_json=$(cat "$readme_body") - if [ "$readme_code" != "200" ] || ! echo "$readme_json" | json_valid; then + if [ "$readme_code" != "200" ] || ! printf "%s" "$readme_json" | json_valid; then echo " ❌ Skipped: No README.md or invalid JSON (HTTP $readme_code)" continue fi - # Decode README content - content=$(echo "$readme_json" | jq -r .content | base64 -d 2>/dev/null || echo "") + content=$(printf "%s" "$readme_json" | jq -r .content | base64 -d 2>/dev/null || echo "") - # Extract osuid osu_id=$(printf "%s" "$content" | grep -oE "osuid:[ ]*[0-9]+" | grep -oE "[0-9]+" | head -1) - if [ -z "$osu_id" ]; then echo " ❌ Skipped: No osuid in README" continue fi - # Fetch osu! API - osu_response=$(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)") + # Fetch osu API + read api_code api_body < <(curl_json "https://osu.ppy.sh/api/get_user?k=${{ secrets.OSUAPIV1 }}&u=$osu_id&type=id&_ts=$(date +%s)") + osu_json=$(cat "$api_body") - if ! printf "%s" "$osu_response" | json_valid; then + if ! printf "%s" "$osu_json" | json_valid; then echo " ❌ Invalid osu! API JSON for $osu_id" - printf "%s" "$osu_response" > "$ARTIFACT_PATH/invalid_osu_user_${osu_id}.json" + printf "%s" "$osu_json" > "$ARTIFACT_PATH/invalid_osu_user_${osu_id}.json" continue fi - if [ "$(echo "$osu_response" | jq 'length')" -eq 0 ]; then + if [ "$(printf "%s" "$osu_json" | jq 'length')" -eq 0 ]; then echo " 🚫 Restricted or banned user" username="$owner" pp_rank="RESTRICTED" pp_country_rank="RESTRICTED" padded_rank="9999999" - profile_url="https://osu.ppy.sh/users/$osu_id" - avatar_url="https://a.ppy.sh/$osu_id?$(( $(date +%s)/86400*86400 ))" + + timestamp=$(( $(date +%s)/86400*86400 )) + avatar_url="https://a.ppy.sh/$osu_id?$timestamp" printf "%s|%s%s%sProfileSkins\n" \ "$padded_rank" "$username" "$pp_rank" "$pp_country_rank" "$profile_url" "$html_url" >> "$USER_ROWS_FILE" - printf "%s|\n" \ + printf "%s|\n" \ "$padded_rank" "$html_url" "$avatar_url" >> "$AVATAR_ROWS_FILE" total_valid_entries=$((total_valid_entries + 1)) continue fi - # Normal account - pp_rank=$(echo "$osu_response" | jq -r '.[0].pp_rank // "9999999"') - pp_country_rank=$(echo "$osu_response" | jq -r '.[0].pp_country_rank // "-"') - country=$(echo "$osu_response" | jq -r '.[0].country // "-"') - username=$(echo "$osu_response" | jq -r '.[0].username // "'$owner'"') + # Normal user + pp_rank=$(printf "%s" "$osu_json" | jq -r '.[0].pp_rank // "9999999"') + pp_country_rank=$(printf "%s" "$osu_json" | jq -r '.[0].pp_country_rank // "-"') + country=$(printf "%s" "$osu_json" | jq -r '.[0].country // "-"') + username=$(printf "%s" "$osu_json" | jq -r '.[0].username // "'$owner'"') padded_rank=$(printf "%07d" "$pp_rank") @@ -178,9 +164,9 @@ jobs: printf "%s|%s%s%sProfileSkins\n" \ "$padded_rank" "$username" "$pp_rank" "$cc_rank" "$osu_id" "$html_url" >> "$USER_ROWS_FILE" - timestamp=$(( $(date +%s) / 86400 * 86400 )) + timestamp=$(( $(date +%s)/86400*86400 )) - printf "%s|\n" \ + printf "%s|\n" \ "$padded_rank" "$html_url" "$osu_id" "$timestamp" >> "$AVATAR_ROWS_FILE" echo " ✅ Added: $username (#$pp_rank, $cc_rank)" @@ -191,7 +177,6 @@ jobs: page=$((page + 1)) done - echo echo "✅ Total valid entries found: $total_valid_entries" - id: upload-tables