Обновить .woodpecker/sync-releases.yaml
This commit is contained in:
@@ -4,21 +4,18 @@ when:
|
|||||||
event: cron
|
event: cron
|
||||||
cron:
|
cron:
|
||||||
include:
|
include:
|
||||||
- sync-hourly # Убедитесь, что имя совпадает с cron-заданием в Woodpecker
|
- sync-hourly
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: sync_releases
|
- name: sync_releases
|
||||||
image: alpine/git
|
image: alpine/git
|
||||||
environment:
|
environment:
|
||||||
# Определяем ВСЕ нужные переменные из секретов
|
|
||||||
GITEA_TOKEN:
|
GITEA_TOKEN:
|
||||||
from_secret: gitea_token
|
from_secret: gitea_token
|
||||||
GITHUB_TOKEN:
|
GITHUB_TOKEN:
|
||||||
from_secret: github_token # Этот секрет опционален, но нужен для API лимитов GitHub
|
from_secret: github_token
|
||||||
GITEA_URL: # Используем просто GITEA_URL как имя переменной окружения
|
GITEA_URL:
|
||||||
from_secret: gitea_url # Берем значение из секрета gitea_url
|
from_secret: gitea_url
|
||||||
|
|
||||||
# Оставляем переменную для имени файла
|
|
||||||
REPO_LIST_FILE: repos_to_sync.txt
|
REPO_LIST_FILE: repos_to_sync.txt
|
||||||
commands:
|
commands:
|
||||||
# 1. Установка зависимостей
|
# 1. Установка зависимостей
|
||||||
@@ -28,35 +25,35 @@ steps:
|
|||||||
- |
|
- |
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -e # Останавливаться при ошибках
|
set -e # Останавливаться при ошибках
|
||||||
set -x # Для отладки
|
# set -x # Оставьте закомментированным для нормальной работы, раскомментируйте ТОЛЬКО для отладки
|
||||||
|
|
||||||
echo "Starting release sync..."
|
echo "Starting release sync..."
|
||||||
|
|
||||||
# --- Конфигурация ---
|
# --- Конфигурация ---
|
||||||
REPO_FILE="${REPO_LIST_FILE:-repos_to_sync.txt}"
|
REPO_FILE="${REPO_LIST_FILE:-repos_to_sync.txt}"
|
||||||
# Переменная GITEA_URL теперь должна быть установлена из секрета
|
|
||||||
|
|
||||||
# Проверки переменных (теперь GITEA_URL тоже проверяется после инъекции секрета)
|
# Проверки переменных
|
||||||
if [ -z "$GITEA_URL" ]; then echo "Error: GITEA_URL was not injected from secret 'gitea_url'!"; exit 1; fi
|
if [ -z "$GITEA_URL" ]; then echo "Error: GITEA_URL was not injected from secret 'gitea_url'!"; exit 1; fi
|
||||||
if [ -z "$GITEA_TOKEN" ]; then echo "Error: GITEA_TOKEN was not injected from secret 'gitea_token'!"; exit 1; fi
|
if [ -z "$GITEA_TOKEN" ]; then echo "Error: GITEA_TOKEN was not injected from secret 'gitea_token'!"; exit 1; fi
|
||||||
# GITHUB_TOKEN опционален
|
|
||||||
if [ ! -f "$REPO_FILE" ]; then echo "Error: Repository list file '$REPO_FILE' not found!"; exit 1; fi
|
if [ ! -f "$REPO_FILE" ]; then echo "Error: Repository list file '$REPO_FILE' not found!"; exit 1; fi
|
||||||
|
|
||||||
echo "Using Gitea URL: $GITEA_URL" # Используем переменную GITEA_URL
|
echo "Using Gitea URL: $GITEA_URL"
|
||||||
GITEA_AUTH_HEADER="Authorization: token ${GITEA_TOKEN}"
|
GITEA_AUTH_HEADER="Authorization: token ${GITEA_TOKEN}"
|
||||||
# Формируем API URL на основе GITEA_URL из секрета
|
# ИСПРАВЛЕНИЕ 1: Формируем API URL, обрабатывая ПЕРЕМЕННУЮ $GITEA_URL
|
||||||
GITEA_API_URL="$(echo ${GITEA_URL} | sed 's|/api/v1$||; s|/*$||')/api/v1"
|
GITEA_BASE_URL=$(echo "${GITEA_URL}" | sed 's|/api/v1$||; s|/*$||')
|
||||||
echo "Using Gitea API URL: $GITEA_API_URL"
|
GITEA_API_URL="${GITEA_BASE_URL}/api/v1"
|
||||||
|
echo "Using Gitea API URL: ${GITEA_API_URL}" # Используем {} для ясности
|
||||||
|
|
||||||
GITHUB_AUTH_HEADER=""
|
GITHUB_AUTH_HEADER=""
|
||||||
if [ -n "$GITHUB_TOKEN" ]; then GITHUB_AUTH_HEADER="Authorization: token ${GITHUB_TOKEN}"; fi
|
if [ -n "$GITHUB_TOKEN" ]; then GITHUB_AUTH_HEADER="Authorization: token ${GITHUB_TOKEN}"; fi
|
||||||
GITHUB_API_URL="https://api.github.com"
|
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 $?; }
|
download_asset() { local url="$1"; local filename="$2"; echo "Downloading asset: $filename"; curl -L -H "$GITHUB_AUTH_HEADER" -o "$filename" "$url"; return $?; }
|
||||||
|
# ИСПРАВЛЕНИЕ 2.1: Корректный URL в upload_asset
|
||||||
upload_asset() { local repo="$1"; local id="$2"; local file="$3"; echo "Uploading asset: $file"; UPLOAD_URL="${GITEA_API_URL}/repos/${repo}/releases/${id}/assets?name=$(basename "$file")"; curl -sf --fail -X POST -H "$GITEA_AUTH_HEADER" -H "Content-Type: application/octet-stream" --data-binary "@$file" "$UPLOAD_URL"; local status=$?; if [ $status -eq 0 ]; then rm "$file"; fi; return $status; }
|
upload_asset() { local repo="$1"; local id="$2"; local file="$3"; echo "Uploading asset: $file"; UPLOAD_URL="${GITEA_API_URL}/repos/${repo}/releases/${id}/assets?name=$(basename "$file")"; curl -sf --fail -X POST -H "$GITEA_AUTH_HEADER" -H "Content-Type: application/octet-stream" --data-binary "@$file" "$UPLOAD_URL"; local status=$?; if [ $status -eq 0 ]; then rm "$file"; fi; return $status; }
|
||||||
|
|
||||||
# --- Основной цикл (без изменений) ---
|
# --- Основной цикл ---
|
||||||
echo "Reading repository list from $REPO_FILE"
|
echo "Reading repository list from $REPO_FILE"
|
||||||
while IFS= read -r repo_pair || [[ -n "$repo_pair" ]]; do
|
while IFS= read -r repo_pair || [[ -n "$repo_pair" ]]; do
|
||||||
if [[ -z "$repo_pair" || "$repo_pair" == \#* ]]; then continue; fi
|
if [[ -z "$repo_pair" || "$repo_pair" == \#* ]]; then continue; fi
|
||||||
@@ -65,7 +62,9 @@ steps:
|
|||||||
GITHUB_REPO_PATH=$(echo "$repo_pair" | cut -d':' -f1); GITEA_REPO_PATH=$(echo "$repo_pair" | cut -d':' -f2)
|
GITHUB_REPO_PATH=$(echo "$repo_pair" | cut -d':' -f1); GITEA_REPO_PATH=$(echo "$repo_pair" | cut -d':' -f2)
|
||||||
echo "-------------------------------------"; echo "Syncing: $GITHUB_REPO_PATH -> $GITEA_REPO_PATH"
|
echo "-------------------------------------"; echo "Syncing: $GITHUB_REPO_PATH -> $GITEA_REPO_PATH"
|
||||||
|
|
||||||
|
# ИСПРАВЛЕНИЕ 2.2: Корректный URL для получения релизов Gitea
|
||||||
echo "Fetching Gitea releases..."; GITEA_RELEASES_JSON=$(curl -sf --fail -H "$GITEA_AUTH_HEADER" "${GITEA_API_URL}/repos/${GITEA_REPO_PATH}/releases") || { echo "Error Gitea fetch: $GITEA_REPO_PATH"; continue; }; EXISTING_GITEA_TAGS=$(echo "$GITEA_RELEASES_JSON" | jq -r '.[].tag_name')
|
echo "Fetching Gitea releases..."; GITEA_RELEASES_JSON=$(curl -sf --fail -H "$GITEA_AUTH_HEADER" "${GITEA_API_URL}/repos/${GITEA_REPO_PATH}/releases") || { echo "Error Gitea fetch: $GITEA_REPO_PATH"; continue; }; EXISTING_GITEA_TAGS=$(echo "$GITEA_RELEASES_JSON" | jq -r '.[].tag_name')
|
||||||
|
# ИСПРАВЛЕНИЕ 2.3: Корректный URL для получения релизов GitHub (просто для консистентности)
|
||||||
echo "Fetching GitHub releases..."; GITHUB_RELEASES_JSON=$(curl -sf --fail -H "$GITHUB_AUTH_HEADER" "${GITHUB_API_URL}/repos/${GITHUB_REPO_PATH}/releases?per_page=20") || { echo "Error GitHub fetch: $GITHUB_REPO_PATH"; continue; }
|
echo "Fetching GitHub releases..."; GITHUB_RELEASES_JSON=$(curl -sf --fail -H "$GITHUB_AUTH_HEADER" "${GITHUB_API_URL}/repos/${GITHUB_REPO_PATH}/releases?per_page=20") || { echo "Error GitHub fetch: $GITHUB_REPO_PATH"; continue; }
|
||||||
|
|
||||||
echo "$GITHUB_RELEASES_JSON" | jq -c '.[] | select(.draft == false)' | tac | while IFS= read -r release_json; do
|
echo "$GITHUB_RELEASES_JSON" | jq -c '.[] | select(.draft == false)' | tac | while IFS= read -r release_json; do
|
||||||
@@ -74,6 +73,7 @@ steps:
|
|||||||
|
|
||||||
echo ">>> New release: $TAG_NAME"; RELEASE_NAME=$(echo "$release_json" | jq -r '.name'); RELEASE_BODY=$(echo "$release_json" | jq -r '.body // ""'); IS_PRERELEASE=$(echo "$release_json" | jq -r '.prerelease'); ASSETS=$(echo "$release_json" | jq -c '.assets[]')
|
echo ">>> New release: $TAG_NAME"; RELEASE_NAME=$(echo "$release_json" | jq -r '.name'); RELEASE_BODY=$(echo "$release_json" | jq -r '.body // ""'); IS_PRERELEASE=$(echo "$release_json" | jq -r '.prerelease'); ASSETS=$(echo "$release_json" | jq -c '.assets[]')
|
||||||
|
|
||||||
|
# ИСПРАВЛЕНИЕ 2.4: Корректный URL для создания релиза Gitea
|
||||||
echo "Creating Gitea release $TAG_NAME..."; CREATE_PAYLOAD=$(jq -n --arg t "$TAG_NAME" --arg n "$RELEASE_NAME" --arg b "$RELEASE_BODY" --argjson p "$IS_PRERELEASE" '{tag_name:$t, name:$n, body:$b, prerelease:$p}'); GITEA_NEW_RELEASE_JSON=$(curl -sf --fail -X POST -H "$GITEA_AUTH_HEADER" -H "Content-Type: application/json" -d "$CREATE_PAYLOAD" "${GITEA_API_URL}/repos/${GITEA_REPO_PATH}/releases") || { echo "Error creating Gitea release $TAG_NAME (maybe tag not synced?). Skipping."; continue; }
|
echo "Creating Gitea release $TAG_NAME..."; CREATE_PAYLOAD=$(jq -n --arg t "$TAG_NAME" --arg n "$RELEASE_NAME" --arg b "$RELEASE_BODY" --argjson p "$IS_PRERELEASE" '{tag_name:$t, name:$n, body:$b, prerelease:$p}'); GITEA_NEW_RELEASE_JSON=$(curl -sf --fail -X POST -H "$GITEA_AUTH_HEADER" -H "Content-Type: application/json" -d "$CREATE_PAYLOAD" "${GITEA_API_URL}/repos/${GITEA_REPO_PATH}/releases") || { echo "Error creating Gitea release $TAG_NAME (maybe tag not synced?). Skipping."; continue; }
|
||||||
GITEA_RELEASE_ID=$(echo "$GITEA_NEW_RELEASE_JSON" | jq -r '.id'); echo "Gitea release ID: $GITEA_RELEASE_ID"
|
GITEA_RELEASE_ID=$(echo "$GITEA_NEW_RELEASE_JSON" | jq -r '.id'); echo "Gitea release ID: $GITEA_RELEASE_ID"
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user