diff --git a/.woodpecker/sync-releases.yaml b/.woodpecker/sync-releases.yml similarity index 73% rename from .woodpecker/sync-releases.yaml rename to .woodpecker/sync-releases.yml index a249c9d..0e38e69 100644 --- a/.woodpecker/sync-releases.yaml +++ b/.woodpecker/sync-releases.yml @@ -1,4 +1,4 @@ -# .woodpecker/sync-releases.yaml +# .woodpecker/sync-releases.yml when: event: cron @@ -8,7 +8,7 @@ when: steps: - name: sync_releases - image: debian:stable-slim # Оставляем debian + image: debian:stable-slim environment: GITEA_TOKEN: from_secret: gitea_token @@ -30,24 +30,43 @@ steps: echo "Starting release sync..." REPO_FILE="${REPO_LIST_FILE:-repos_to_sync.txt}" - if [ -z "$GITEA_URL" ]; then echo "Error: GITEA_URL was not injected!"; exit 1; fi - if [ -z "$GITEA_TOKEN" ]; then echo "Error: GITEA_TOKEN was not injected!"; exit 1; fi - if [ ! -f "$REPO_FILE" ]; then echo "Error: Repository list file '$REPO_FILE' not found!"; exit 1; fi + # --- Проверки и Отладка Переменных --- + echo "--- Variable Checks ---" + if [ -z "$GITEA_URL" ]; then echo "FATAL: GITEA_URL is empty!"; exit 1; fi + echo "GITEA_URL (outside subshell): $GITEA_URL" + if [ -z "$GITEA_TOKEN" ]; then echo "FATAL: GITEA_TOKEN is empty!"; exit 1; fi + echo "GITEA_TOKEN check: OK (value hidden)" + if [ ! -f "$REPO_FILE" ]; then echo "FATAL: File '$REPO_FILE' not found!"; exit 1; fi + echo "REPO_FILE check: OK ($REPO_FILE)" - echo "Raw Gitea URL from secret: $GITEA_URL" - GITEA_AUTH_HEADER="Authorization: token ${GITEA_TOKEN}" + # Дополнительная проверка доступности GITEA_URL ВНУТРИ subshell + SUBSHELL_GITEA_URL=$(echo "$GITEA_URL") + echo "GITEA_URL (from inside subshell): $SUBSHELL_GITEA_URL" + if [ -z "$SUBSHELL_GITEA_URL" ]; then + echo "FATAL: GITEA_URL seems empty inside subshell!" + # Попробуем без sed, если subshell пуст + GITEA_BASE_URL="$GITEA_URL" # Просто присвоим, чтобы увидеть, сработает ли это + echo "Attempting direct assignment for GITEA_BASE_URL: $GITEA_BASE_URL" + else + # Если subshell работает, используем echo | sed + echo "Subshell check OK. Calculating GITEA_BASE_URL using echo | sed..." + GITEA_BASE_URL=$(echo "${SUBSHELL_GITEA_URL}" | sed 's|/api/v1$||; s|/*$||') + fi - # ИСПРАВЛЕНИЕ: Возвращаем ${GITEA_URL} в echo !!! - GITEA_BASE_URL=$(echo "${GITEA_URL}" | sed 's|/api/v1$||; s|/*$||') - if [ -z "$GITEA_BASE_URL" ]; then echo "Error: Failed to calculate GITEA_BASE_URL!"; exit 1; fi + # Проверка результата после вычисления + if [ -z "$GITEA_BASE_URL" ]; then echo "FATAL: Failed to calculate GITEA_BASE_URL!"; exit 1; fi GITEA_API_URL="${GITEA_BASE_URL}/api/v1" - echo "Calculated Gitea API URL: ${GITEA_API_URL}" + echo "Final GITEA_BASE_URL: ${GITEA_BASE_URL}" + echo "Final GITEA_API_URL: ${GITEA_API_URL}" + echo "--- End Variable Checks ---" + GITEA_AUTH_HEADER="Authorization: token ${GITEA_TOKEN}" GITHUB_AUTH_HEADER="" if [ -n "$GITHUB_TOKEN" ]; then GITHUB_AUTH_HEADER="Authorization: token ${GITHUB_TOKEN}"; fi GITHUB_API_URL="https://api.github.com" # --- Вспомогательные функции --- + # ... (без изменений) ... download_asset() { local url="$1"; local filename="$2"; echo "Downloading asset: $filename"; curl -L -H "$GITHUB_AUTH_HEADER" -o "$filename" "$url"; return $?; } upload_asset() { local repo="$1"; local id="$2"; local file="$3" @@ -59,7 +78,9 @@ steps: local status=$?; if [ $status -eq 0 ]; then rm "$file"; fi; return $status; } + # --- Основной цикл --- + # ... (без изменений, но теперь должен работать с правильными URL) ... echo "Reading repository list from $REPO_FILE" while IFS= read -r repo_pair || [[ -n "$repo_pair" ]]; do if [[ -z "$repo_pair" || "$repo_pair" == \#* ]]; then continue; fi