Files
clash-rules/.gitea/workflows/update-rules.yml
adminroot f162083fc8
Some checks failed
Auto Update Clash Rules / update-rules (push) Failing after 1m15s
更新 .gitea/workflows/update-rules.yml
2025-09-11 06:27:26 -07:00

368 lines
13 KiB
YAML

name: Auto Update Clash Rules
on:
workflow_dispatch: # 手动触发
schedule:
- cron: "0 2 * * *" # 每天凌晨2点执行
push:
branches:
- main
paths:
- '.gitea/workflows/**'
jobs:
update-rules:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
token: ${{ secrets.WORKFLOW_TOKEN }}
- name: Set environment variables
run: |
echo "RELEASE_NAME=Clash Rules $(date +%Y%m%d-%H%M)" >> $GITHUB_ENV
echo "TAG_NAME=$(date +%Y%m%d%H%M)" >> $GITHUB_ENV
echo "UPDATE_TIME=$(date '+%Y-%m-%d %H:%M:%S UTC')" >> $GITHUB_ENV
- name: Create rules directory
run: |
mkdir -p rules
cd rules
- name: Download reject rules
run: |
echo "正在下载广告拦截规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/reject.txt" -o rules/reject.txt
echo "✅ reject.txt 下载完成"
- name: Download iCloud rules
run: |
echo "正在下载 iCloud 规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/icloud.txt" -o rules/icloud.txt
echo "✅ icloud.txt 下载完成"
- name: Download Apple rules
run: |
echo "正在下载 Apple 规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/apple.txt" -o rules/apple.txt
echo "✅ apple.txt 下载完成"
- name: Download Google rules
run: |
echo "正在下载 Google 规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/google.txt" -o rules/google.txt
echo "✅ google.txt 下载完成"
- name: Download proxy rules
run: |
echo "正在下载代理规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/proxy.txt" -o rules/proxy.txt
echo "✅ proxy.txt 下载完成"
- name: Download direct rules
run: |
echo "正在下载直连规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/direct.txt" -o rules/direct.txt
echo "✅ direct.txt 下载完成"
- name: Download private rules
run: |
echo "正在下载私有地址规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/private.txt" -o rules/private.txt
echo "✅ private.txt 下载完成"
- name: Download GFW rules
run: |
echo "正在下载 GFW 规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/gfw.txt" -o rules/gfw.txt
echo "✅ gfw.txt 下载完成"
- name: Download TLD-not-CN rules
run: |
echo "正在下载非中国顶级域名规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/tld-not-cn.txt" -o rules/tld-not-cn.txt
echo "✅ tld-not-cn.txt 下载完成"
- name: Download Telegram CIDR
run: |
echo "正在下载 Telegram IP 段..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/telegramcidr.txt" -o rules/telegramcidr.txt
echo "✅ telegramcidr.txt 下载完成"
- name: Download CN CIDR
run: |
echo "正在下载中国 IP 段..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/cncidr.txt" -o rules/cncidr.txt
echo "✅ cncidr.txt 下载完成"
- name: Download LAN CIDR
run: |
echo "正在下载局域网 IP 段..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/lancidr.txt" -o rules/lancidr.txt
echo "✅ lancidr.txt 下载完成"
- name: Download applications rules
run: |
echo "正在下载应用程序规则..."
curl -fsSL "https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/applications.txt" -o rules/applications.txt
echo "✅ applications.txt 下载完成"
- name: Generate README
run: |
cat > rules/README.md << 'EOF'
# Clash Rules Mirror
本仓库镜像了 [Loyalsoldier/clash-rules](https://github.com/Loyalsoldier/clash-rules) 的规则文件。
## 📋 规则列表
| 文件名 | 描述 | 类型 |
|--------|------|------|
| reject.txt | 广告拦截规则 | domain |
| icloud.txt | iCloud 服务规则 | domain |
| apple.txt | Apple 服务规则 | domain |
| google.txt | Google 服务规则 | domain |
| proxy.txt | 代理规则 | domain |
| direct.txt | 直连规则 | domain |
| private.txt | 私有地址规则 | domain |
| gfw.txt | GFW 规则 | domain |
| tld-not-cn.txt | 非中国顶级域名 | domain |
| telegramcidr.txt | Telegram IP段 | ipcidr |
| cncidr.txt | 中国大陆 IP段 | ipcidr |
| lancidr.txt | 局域网 IP段 | ipcidr |
| applications.txt | 应用程序规则 | classical |
## 🔗 使用方法
将以下配置添加到你的 Clash 配置文件中:
```yaml
rule-providers:
reject:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/reject.txt"
path: ./ruleset/reject.yaml
interval: 86400
# 其他规则类似配置...
```
## ⏰ 更新时间
最后更新时间: ${{ env.UPDATE_TIME }}
## 📊 统计信息
EOF
# 添加文件统计
echo "| 文件 | 大小 | 行数 |" >> rules/README.md
echo "|------|------|------|" >> rules/README.md
for file in rules/*.txt; do
filename=$(basename "$file")
filesize=$(du -h "$file" | cut -f1)
linecount=$(wc -l < "$file")
echo "| $filename | $filesize | $linecount |" >> rules/README.md
done
- name: Generate usage example
run: |
cat > rules/clash-config-example.yaml << 'EOF'
# Clash 配置示例
# 使用本仓库的规则文件
rule-providers:
reject:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/reject.txt"
path: ./ruleset/reject.yaml
interval: 86400
icloud:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/icloud.txt"
path: ./ruleset/icloud.yaml
interval: 86400
apple:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/apple.txt"
path: ./ruleset/apple.yaml
interval: 86400
google:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/google.txt"
path: ./ruleset/google.yaml
interval: 86400
proxy:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/proxy.txt"
path: ./ruleset/proxy.yaml
interval: 86400
direct:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/direct.txt"
path: ./ruleset/direct.yaml
interval: 86400
private:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/private.txt"
path: ./ruleset/private.yaml
interval: 86400
gfw:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/gfw.txt"
path: ./ruleset/gfw.yaml
interval: 86400
tld-not-cn:
type: http
behavior: domain
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/tld-not-cn.txt"
path: ./ruleset/tld-not-cn.yaml
interval: 86400
telegramcidr:
type: http
behavior: ipcidr
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/telegramcidr.txt"
path: ./ruleset/telegramcidr.yaml
interval: 86400
cncidr:
type: http
behavior: ipcidr
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/cncidr.txt"
path: ./ruleset/cncidr.yaml
interval: 86400
lancidr:
type: http
behavior: ipcidr
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/lancidr.txt"
path: ./ruleset/lancidr.yaml
interval: 86400
applications:
type: http
behavior: classical
url: "https://your-gitea-domain/username/clash-rules/raw/branch/release/applications.txt"
path: ./ruleset/applications.yaml
interval: 86400
rules:
- RULE-SET,applications,DIRECT
- RULE-SET,private,DIRECT
- RULE-SET,reject,REJECT
- RULE-SET,icloud,DIRECT
- RULE-SET,apple,DIRECT
- RULE-SET,google,🚀 代理
- RULE-SET,proxy,🚀 代理
- RULE-SET,gfw,🚀 代理
- RULE-SET,tld-not-cn,🚀 代理
- RULE-SET,telegramcidr,📲 Telegram
- RULE-SET,direct,DIRECT
- RULE-SET,lancidr,DIRECT
- RULE-SET,cncidr,DIRECT
- GEOIP,LAN,DIRECT
- GEOIP,CN,DIRECT
- MATCH,🚀 代理
EOF
- name: Check for changes
id: check_changes
run: |
git add rules/
if git diff --staged --quiet; then
echo "changes=false" >> $GITHUB_OUTPUT
echo "📄 没有检测到规则文件变化"
else
echo "changes=true" >> $GITHUB_OUTPUT
echo "🔄 检测到规则文件有更新"
fi
- name: Commit and push changes
if: steps.check_changes.outputs.changes == 'true'
run: |
git config --local user.email "action@gitea.local"
git config --local user.name "Gitea Actions Bot"
git commit -m "🤖 自动更新 Clash 规则文件 - ${{ env.UPDATE_TIME }}"
git push origin main
- name: Create release branch
if: steps.check_changes.outputs.changes == 'true'
run: |
# 创建或更新 release 分支
git checkout -B release
git push -f origin release
- name: Create release
if: steps.check_changes.outputs.changes == 'true'
run: |
# 生成更新日志
cat > release_notes.md << 'EOF'
## 📋 本次更新内容
🤖 自动同步最新的 Clash 规则文件
### 📊 文件统计
EOF
echo "| 文件名 | 大小 | 行数 |" >> release_notes.md
echo "|--------|------|------|" >> release_notes.md
for file in rules/*.txt; do
filename=$(basename "$file")
filesize=$(du -h "$file" | cut -f1)
linecount=$(wc -l < "$file")
echo "| $filename | $filesize | $linecount |" >> release_notes.md
done
echo "" >> release_notes.md
echo "### 🔗 使用方法" >> release_notes.md
echo "参考仓库中的 \`clash-config-example.yaml\` 文件配置你的 Clash 客户端。" >> release_notes.md
echo "" >> release_notes.md
echo "### ⏰ 更新时间" >> release_notes.md
echo "${{ env.UPDATE_TIME }}" >> release_notes.md
# 使用 Gitea API 创建 Release
curl -X POST \
-H "Authorization: token ${{ secrets.WORKFLOW_TOKEN }}" \
-H "Content-Type: application/json" \
-d '{
"tag_name": "${{ env.TAG_NAME }}",
"target_commitish": "release",
"name": "${{ env.RELEASE_NAME }}",
"body": "'"$(cat release_notes.md | sed 's/"/\\"/g' | tr '\n' ' ')"'",
"draft": false,
"prerelease": false
}' \
"${{ env.GITEA_SERVER_URL }}/api/v1/repos/${{ env.GITEA_REPOSITORY }}/releases" || echo "⚠️ Release 创建可能失败,但文件已成功更新"
- name: Summary
if: steps.check_changes.outputs.changes == 'true'
run: |
echo "✅ Clash 规则文件更新完成!"
echo "🔗 访问地址: ${{ env.GITEA_SERVER_URL }}/${{ env.GITEA_REPOSITORY }}"
echo "📁 文件位置: rules/ 目录"
echo "🏷️ 发布标签: ${{ env.TAG_NAME }}"
- name: No changes
if: steps.check_changes.outputs.changes == 'false'
run: |
echo "📄 规则文件没有变化,跳过发布步骤"