181 lines
7.4 KiB
YAML
181 lines
7.4 KiB
YAML
name: 获取完整内核版本
|
||
|
||
on:
|
||
#push:
|
||
#branches: # 仅在 main 分支发生更改时触发工作流程
|
||
# - main
|
||
#paths-ignore: # 忽略 README.md 文件的更改
|
||
# - 'README.md'
|
||
#workflow_dispatch: # 手动触发工作流程
|
||
|
||
jobs:
|
||
job_1:
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
# 检出代码
|
||
- name: 🛒 检出代码
|
||
uses: https://git.aoun.ltd/actions/checkout@v4
|
||
|
||
# 1. 下载并安装 Trojan-Go
|
||
- name: 📦 解压并安装 Trojan-Go
|
||
run: |
|
||
# 下载 Trojan-Go 二进制文件
|
||
wget -O trojan-go.zip https://git.aoun.ltd/18152827937/Trojan-GO/raw/commit/ea063e62859270d123379dc69db57f29db2b192f/trojan-go-linux-amd64.zip
|
||
unzip trojan-go.zip -d trojan-go
|
||
sudo mv trojan-go/trojan-go /usr/local/bin/trojan-go
|
||
rm -rf trojan-go.zip trojan-go
|
||
|
||
# 2. 配置代理参数
|
||
- name: 🔧 配置 Trojan-Go 代理
|
||
run: |
|
||
# 将多行 JSON 配置内容从 Secrets 中写入 trojan-go-config.json 文件
|
||
echo "$TROJAN_GO_CONFIG" > trojan-go-config.json
|
||
#打印配置文件内容
|
||
cat trojan-go-config.json
|
||
env:
|
||
TROJAN_GO_CONFIG: ${{ secrets.TROJAN_GO_CONFIG }}
|
||
|
||
# 3. 启动 Trojan-Go 代理
|
||
- name: 🔍 启动并保持 Trojan-Go 运行
|
||
run: |
|
||
nohup trojan-go -config trojan-go-config.json > /tmp/trojan-go.log 2>&1 & disown
|
||
sleep 5 # 等待代理启动
|
||
# 检查 Trojan-Go 是否在运行
|
||
if pgrep -x "trojan-go" > /dev/null
|
||
then
|
||
echo "Trojan-Go 已成功启动并在运行中。"
|
||
else
|
||
echo "启动失败,检查日志文件 /tmp/trojan-go.log 以获取更多信息。" && cat /tmp/trojan-go.log && exit 1
|
||
fi
|
||
|
||
# 4. 使用代理克隆仓库
|
||
- name: 🚀 使用代理克隆仓库
|
||
env:
|
||
REPO_URL: https://github.com/coolsnowwolf/lede
|
||
REPO_BRANCH: master
|
||
ALL_PROXY: "socks5://127.0.0.1:1080"
|
||
run: |
|
||
echo "检查代理设置:$ALL_PROXY"
|
||
echo "开始尝试克隆仓库..."
|
||
|
||
# 尝试多次克隆仓库,直到成功
|
||
n=1
|
||
max_retries=5
|
||
while [ "$n" -le "$max_retries" ]
|
||
do
|
||
echo "正在尝试第 $n 次克隆仓库..."
|
||
git clone --depth 1 "$REPO_URL" -b "$REPO_BRANCH" && break
|
||
echo "第 $n 次克隆失败,将在5秒后重试..."
|
||
n=$((n+1))
|
||
sleep 5
|
||
done
|
||
|
||
# 检查克隆是否成功
|
||
if [ "$n" -gt "$max_retries" ]; then
|
||
echo "克隆仓库失败,请检查网络或代理设置。"
|
||
exit 1
|
||
else
|
||
echo "仓库克隆成功!"
|
||
fi
|
||
|
||
# 5. 获取固件版本 - 检索当前固件的版本信息
|
||
- name: 📦 获取固件版本 - 检索当前固件的版本信息
|
||
run: |
|
||
cd lede
|
||
grep '"DISTRIB_REVISION=' */*/default-settings/files/zzz-default-settings | cut -d"'" -f2
|
||
|
||
# 获取 DISTRIB_REVISION 值
|
||
DISTRIB_REVISION=$(grep '"DISTRIB_REVISION=' */*/default-settings/files/zzz-default-settings | cut -d"'" -f2)
|
||
|
||
# 将值设置为环境变量
|
||
echo "distrib_revision=$DISTRIB_REVISION" >> $GITHUB_ENV
|
||
|
||
# 在日志中显示 DISTRIB_REVISION 的值
|
||
echo "DISTRIB_REVISION: $DISTRIB_REVISION"
|
||
|
||
# 5. 获取内核主版本号
|
||
- name: 📄 获取内核主版本号
|
||
run: |
|
||
KERNEL_PATCHVER=$(grep "KERNEL_PATCHVER" lede/target/linux/x86/Makefile | awk -F ':=' '{print $2}' | xargs)
|
||
echo "KERNEL_PATCHVER=$KERNEL_PATCHVER" >> $GITHUB_ENV
|
||
echo "内核主版本号:$KERNEL_PATCHVER"
|
||
#输出示例:内核主版本号:6.6
|
||
|
||
# 6. 获取完整内核版本
|
||
- name: 📄 获取完整内核版本
|
||
run: |
|
||
if [ -f "lede/include/kernel-$KERNEL_PATCHVER" ]; then
|
||
PATCH_VERSION=$(grep "LINUX_VERSION-$KERNEL_PATCHVER" "lede/include/kernel-$KERNEL_PATCHVER" | awk -F '=' '{print $2}' | xargs)
|
||
FULL_KERNEL_VERSION="$KERNEL_PATCHVER$PATCH_VERSION"
|
||
echo "FULL_KERNEL_VERSION=$FULL_KERNEL_VERSION" >> $GITHUB_ENV
|
||
echo "完整的内核版本为:$FULL_KERNEL_VERSION"
|
||
#输出示例:完整的内核版本为:6.6.58
|
||
else
|
||
echo "未找到对应的内核版本文件 lede/include/kernel-$KERNEL_PATCHVER"
|
||
exit 1
|
||
fi
|
||
|
||
# 7. 更新和安装 feeds
|
||
- name: 🔄 更新和安装 feeds
|
||
env:
|
||
ALL_PROXY: "socks5://127.0.0.1:1080"
|
||
run: |
|
||
cd lede
|
||
./scripts/feeds update -a
|
||
./scripts/feeds install -a
|
||
|
||
# 8. 获取 LuCI 版本和分支信息
|
||
- name: 📝 获取 LuCI 版本和分支信息
|
||
run: |
|
||
cd lede/feeds/luci
|
||
LUCI_BRANCH=$(git rev-parse --abbrev-ref HEAD)
|
||
LUCI_COMMIT=$(git rev-parse --short HEAD)
|
||
|
||
# 格式化 LuCI 版本信息,将空格替换为下划线,并构建为目标格式
|
||
LUCI_VERSION="LuCI_${LUCI_BRANCH}_branch_(git--${LUCI_COMMIT})"
|
||
# 替换字符,以确保徽章 URL 正确
|
||
LUCI_VERSION_FORMATTED=$(echo "$LUCI_VERSION" | sed 's/ /_/g; s/-/--/g')
|
||
echo "LUCI_VERSION_FORMATTED=$LUCI_VERSION_FORMATTED" >> $GITHUB_ENV
|
||
echo "LuCI 版本信息:$LUCI_VERSION_FORMATTED"
|
||
|
||
# 更新 README.md 文件
|
||
- name: ✏️ 更新 README.md 文件
|
||
env:
|
||
FULL_KERNEL_VERSION: "${{ env.FULL_KERNEL_VERSION }}"
|
||
LUCI_VERSION: "${{ env.LUCI_VERSION }}"
|
||
run: |
|
||
# 生成要插入的新内容
|
||
LATEST_VERSION="R$(date +'%y.%m.%d')--$(date +'%H%M')"
|
||
ARCHITECTURE="x86__64"
|
||
FILE_SIZE="1024MB"
|
||
RELEASE_DATE="$(date +'%Y--%m--%d')"
|
||
KERNEL_VERSION="${FULL_KERNEL_VERSION}"
|
||
DISTRIB_REVISION="${{ env.distrib_revision }}"
|
||
#LuCI 版本
|
||
LUCI_VERSION="${LUCI_VERSION_FORMATTED}"
|
||
|
||
NEW_CONTENT="<!--action-tag-start-->\n\n"
|
||
NEW_CONTENT+="![Latest Version](https://img.shields.io/badge/固件版本-${DISTRIB_REVISION}-brightgreen)\n"
|
||
NEW_CONTENT+="![Based on OpenWrt](https://img.shields.io/badge/内核版本-${KERNEL_VERSION}-00bfff)\n"
|
||
NEW_CONTENT+="![LuCI Version](https://img.shields.io/badge/LuCI_版本-${LUCI_VERSION}-blueviolet)\n"
|
||
NEW_CONTENT+="![Architecture](https://img.shields.io/badge/适用架构-${ARCHITECTURE}-ff69b4)\n"
|
||
NEW_CONTENT+="![File Size](https://img.shields.io/badge/文件大小-${FILE_SIZE}-orange)\n"
|
||
NEW_CONTENT+="![Release Date](https://img.shields.io/badge/发布日期-${RELEASE_DATE}-blue)\n\n"
|
||
NEW_CONTENT+="<!--action-tag-end-->"
|
||
|
||
# 替换标记范围内的内容
|
||
sed -i "/<!--action-tag-start-->/, /<!--action-tag-end-->/c\\$NEW_CONTENT" README.md
|
||
|
||
# 显示更新后的 README.md 内容
|
||
cat README.md
|
||
|
||
# 配置 Git 用户信息并提交更改
|
||
- name: 📤 提交并推送更改
|
||
#env:
|
||
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||
run: |
|
||
git config --global user.name '298977887'
|
||
git config --global user.email '298977887@qq.com'
|
||
git add README.md
|
||
git commit -m "🤖 更新 README.md"
|
||
git push origin HEAD:main |