gitea-action-test/.github/workflows/OpenWRT介绍.yml

181 lines
7.4 KiB
YAML
Raw Normal View History

2024-10-28 07:54:39 +00:00
name: 获取完整内核版本
on:
2024-10-28 12:46:44 +00:00
#push:
#branches: # 仅在 main 分支发生更改时触发工作流程
# - main
#paths-ignore: # 忽略 README.md 文件的更改
# - 'README.md'
2024-10-28 09:02:15 +00:00
#workflow_dispatch: # 手动触发工作流程
2024-10-28 07:54:39 +00:00
jobs:
2024-10-28 12:31:10 +00:00
job_1:
2024-10-28 07:54:39 +00:00
runs-on: ubuntu-latest
steps:
2024-10-28 08:02:46 +00:00
# 检出代码
- name: 🛒 检出代码
uses: https://git.aoun.ltd/actions/checkout@v4
2024-10-28 07:54:39 +00:00
# 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
#打印配置文件内容
2024-10-28 13:02:22 +00:00
#cat trojan-go-config.json
2024-10-28 07:54:39 +00:00
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
2024-10-28 10:37:33 +00:00
# 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"
2024-10-28 07:54:39 +00:00
# 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"
2024-10-28 10:37:33 +00:00
#输出示例内核主版本号6.6
2024-10-28 07:54:39 +00:00
# 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"
2024-10-28 08:59:40 +00:00
echo "FULL_KERNEL_VERSION=$FULL_KERNEL_VERSION" >> $GITHUB_ENV
2024-10-28 07:54:39 +00:00
echo "完整的内核版本为:$FULL_KERNEL_VERSION"
2024-10-28 10:37:33 +00:00
#输出示例完整的内核版本为6.6.58
2024-10-28 07:54:39 +00:00
else
echo "未找到对应的内核版本文件 lede/include/kernel-$KERNEL_PATCHVER"
exit 1
fi
2024-10-28 07:57:58 +00:00
# 7. 更新和安装 feeds
- name: 🔄 更新和安装 feeds
2024-10-28 08:34:08 +00:00
env:
ALL_PROXY: "socks5://127.0.0.1:1080"
2024-10-28 07:57:58 +00:00
run: |
cd lede
./scripts/feeds update -a
./scripts/feeds install -a
2024-10-28 07:54:39 +00:00
# 8. 获取 LuCI 版本和分支信息
- name: 📝 获取 LuCI 版本和分支信息
run: |
cd lede/feeds/luci
LUCI_BRANCH=$(git rev-parse --abbrev-ref HEAD)
LUCI_COMMIT=$(git rev-parse --short HEAD)
2024-10-28 10:37:33 +00:00
2024-10-28 10:53:38 +00:00
# 格式化 LuCI 版本信息,将空格替换为下划线,并构建为目标格式
2024-10-28 10:37:33 +00:00
LUCI_VERSION="LuCI_${LUCI_BRANCH}_branch_(git--${LUCI_COMMIT})"
2024-10-28 10:53:38 +00:00
# 替换字符,以确保徽章 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"
2024-10-28 08:20:03 +00:00
# 更新 README.md 文件
- name: ✏️ 更新 README.md 文件
env:
2024-10-28 08:59:40 +00:00
FULL_KERNEL_VERSION: "${{ env.FULL_KERNEL_VERSION }}"
LUCI_VERSION: "${{ env.LUCI_VERSION }}"
2024-10-28 08:20:03 +00:00
run: |
2024-10-28 08:59:40 +00:00
# 生成要插入的新内容
2024-10-28 10:37:33 +00:00
LATEST_VERSION="R$(date +'%y.%m.%d')--$(date +'%H%M')"
2024-10-28 10:43:41 +00:00
ARCHITECTURE="x86__64"
2024-10-28 08:45:12 +00:00
FILE_SIZE="1024MB"
2024-10-28 10:37:33 +00:00
RELEASE_DATE="$(date +'%Y--%m--%d')"
2024-10-28 10:43:41 +00:00
KERNEL_VERSION="${FULL_KERNEL_VERSION}"
2024-10-28 10:37:33 +00:00
DISTRIB_REVISION="${{ env.distrib_revision }}"
2024-10-28 10:43:41 +00:00
#LuCI 版本
2024-10-28 10:53:38 +00:00
LUCI_VERSION="${LUCI_VERSION_FORMATTED}"
2024-10-28 08:59:40 +00:00
2024-10-28 09:05:37 +00:00
NEW_CONTENT="<!--action-tag-start-->\n\n"
2024-10-28 10:37:33 +00:00
NEW_CONTENT+="![Latest Version](https://img.shields.io/badge/固件版本-${DISTRIB_REVISION}-brightgreen)\n"
2024-10-28 10:50:32 +00:00
NEW_CONTENT+="![Based on OpenWrt](https://img.shields.io/badge/内核版本-${KERNEL_VERSION}-00bfff)\n"
2024-10-28 10:56:45 +00:00
NEW_CONTENT+="![LuCI Version](https://img.shields.io/badge/LuCI_版本-${LUCI_VERSION}-blueviolet)\n"
2024-10-28 09:05:37 +00:00
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-->"
2024-10-28 08:59:40 +00:00
# 替换标记范围内的内容
sed -i "/<!--action-tag-start-->/, /<!--action-tag-end-->/c\\$NEW_CONTENT" README.md
2024-10-28 08:40:02 +00:00
2024-10-28 08:20:03 +00:00
# 显示更新后的 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