From 36aa47fc3dfba8ef03ec4634998c601cd570993f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?F=E5=98=89=E9=98=B3?= <1186032234@qq.com> Date: Tue, 25 Nov 2025 22:48:32 +0800 Subject: [PATCH] bladex_to_gitea --- .gitea/workflows/aliyun_to_gitea_pipeline.yml | 84 +++++++++++++++++++ aliyun_to_gitea.yaml | 35 ++++++++ 2 files changed, 119 insertions(+) create mode 100644 .gitea/workflows/aliyun_to_gitea_pipeline.yml create mode 100644 aliyun_to_gitea.yaml diff --git a/.gitea/workflows/aliyun_to_gitea_pipeline.yml b/.gitea/workflows/aliyun_to_gitea_pipeline.yml new file mode 100644 index 0000000..bf582cf --- /dev/null +++ b/.gitea/workflows/aliyun_to_gitea_pipeline.yml @@ -0,0 +1,84 @@ +name: 多仓库同步流水线 + +on: + push: + branches: + - master + paths: + - 'bladex_to_gitea.yaml' + - '.gitea/workflows/bladex_to_gitea_pipeline.yml' + workflow_dispatch: + schedule: + # 每周凌晨1点执行 + - cron: '0 1 * * 0' + +env: + CONFIG_FILE: 'bladex_to_gitea.yaml' + +jobs: + sync-repositories: + runs-on: ubuntu-latest + + steps: + - name: 签出配置仓库 + uses: actions/checkout@v4 + with: + fetch-depth: 1 + + - name: 配置 Git + run: | + git config --global user.name "gitea-runner" + git config --global user.email "actions@gitea.fjy8018.top" + git config --global init.defaultBranch master + + - name: 安装依赖 + run: | + apt-get update + apt-get install -y python3-yaml jq + + - name: 验证配置文件 + run: | + if [ ! -f "${{ env.CONFIG_FILE }}" ]; then + echo "错误: 配置文件 ${{ env.CONFIG_FILE }} 不存在!" + exit 1 + fi + echo "✓ 配置文件已找到" + + - name: 网络连通性诊断 + run: | + echo "================================================================================" + echo "网络连通性诊断" + echo "================================================================================" + echo "" + echo "[1] 检查DNS解析 (center.javablade.com):" + if command -v nslookup >/dev/null 2>&1; then + nslookup center.javablade.com || echo "❌ nslookup 失败" + elif command -v dig >/dev/null 2>&1; then + dig center.javablade.com || echo "❌ dig 失败" + else + getent hosts center.javablade.com || echo "❌ DNS 解析失败" + fi + echo "" + echo "[2] 检查网络连通性:" + if command -v ping >/dev/null 2>&1; then + ping -c 3 -W 5 center.javablade.com || echo "❌ ping 失败" + else + echo "⚠️ ping 命令不可用,跳过连通性测试" + fi + echo "" + echo "[3] 检查是否可以访问上游仓库(匿名测试):" + if command -v git >/dev/null 2>&1; then + timeout 30 git ls-remote https://center.javablade.com/blade/BladeX-Tool.git HEAD || echo "❌ 无法访问仓库" + else + echo "⚠️ git 命令不可用" + fi + echo "" + echo "================================================================================" + + - name: 从配置文件中提取仓库并同步 + env: + UPSTREAM_USERNAME: ${{ secrets.ALIYUN_UPSTREAM_USERNAME }} + UPSTREAM_TOKEN: ${{ secrets.ALIYUN_UPSTREAM_TOKEN }} + TARGET_USERNAME: ${{ secrets.TARGET_USERNAME }} + TARGET_TOKEN: ${{ secrets.TARGET_TOKEN }} + run: python3 sync_repos.py diff --git a/aliyun_to_gitea.yaml b/aliyun_to_gitea.yaml new file mode 100644 index 0000000..ae6a676 --- /dev/null +++ b/aliyun_to_gitea.yaml @@ -0,0 +1,35 @@ +# 多仓库同步配置文件 +# 定义需要同步的仓库对,源仓库 -> 目标仓库 +repositories: + - name: "bladex-tool" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/BladeX-Tool.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/BladeX-Tool.git" + branch: "master" + - name: "BladeX-Safety" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/BladeX-Safety.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/BladeX-Safety.git" + branch: "master" + - name: "bladex" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/BladeX.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/BladeX.git" + branch: "master" + - name: "BladeX-Doc" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/BladeX-Doc.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/BladeX-Doc.git" + branch: "master" + - name: "BladeX-Boot" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/BladeX-Boot.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/BladeX-Boot.git" + branch: "master" + - name: "Saber" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/Saber.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/Saber.git" + branch: "master" + - name: "BladeX-Biz" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/BladeX-Biz.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/BladeX-Biz.git" + branch: "master" + - name: "Saber3" + source_url: "https://${UPSTREAM_USERNAME}:${UPSTREAM_TOKEN}@center.javablade.com/blade/Saber3.git" + target_url: "https://${TARGET_USERNAME}:${TARGET_TOKEN}@gitea.fjy8018.top/BladeX/Saber3.git" + branch: "master"