Compare commits

..

2 Commits

Author SHA1 Message Date
dichgrem
130a2298f2 chore:actions 2026-01-18 15:51:42 +08:00
dichgrem
15e1df01f5 chore:actions 2026-01-18 15:41:16 +08:00
3 changed files with 400 additions and 54 deletions

View File

@@ -9,7 +9,6 @@ on:
default: "immortalwrt"
type: choice
options:
- lede
- openwrt
- immortalwrt
- immortalwrt-mt798x
@@ -30,15 +29,15 @@ on:
config_path:
description: "配置文件路径"
required: true
default: "config/myconfig"
default: "config/x86_64_config"
type: string
proxy_nikki:
description: "启用Nikki"
proxy_passwall2:
description: "启用Passwall2"
required: false
default: false
type: boolean
proxy_passwall2:
description: "启用Passwall2"
proxy_luci_app_zzz:
description: "启用luci-app-zzz"
required: false
default: false
type: boolean
@@ -52,10 +51,102 @@ on:
required: false
default: "0"
type: string
cache_enabled:
description: "启用缓存加速编译"
required: false
default: true
type: boolean
custom_shell:
description: "默认 shell"
required: false
default: "ash"
type: choice
options:
- ash
- bash
luci_theme:
description: "LuCI 主题"
required: false
default: "argon"
type: choice
options:
- argon
- bootstrap
- material
enable_bbr:
description: "启用 BBR 拥塞控制"
required: false
default: true
type: boolean
custom_hostname:
description: "自定义 hostname留空则跳过"
required: false
default: "Dwrt"
type: string
custom_ip:
description: "自定义 IP 地址(留空则跳过)"
required: false
default: "192.168.1.1"
type: string
root_password:
description: "自定义 root 密码(留空则跳过)"
required: false
default: ""
type: string
custom_banner:
description: "自定义 SSH 横幅(留空则默认)"
required: false
default: ""
type: string
env:
CCACHE_DIR: ${{ github.workspace }}/wrt/.ccache
DL_DIR: ${{ github.workspace }}/wrt/dl
jobs:
build:
validate:
name: 验证输入参数
runs-on: ubuntu-latest
outputs:
is_valid: ${{ steps.validate.outputs.is_valid }}
config_exists: ${{ steps.validate.outputs.config_exists }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Validate inputs
id: validate
run: |
echo "🔍 验证输入参数..."
# 验证 threads 参数
if [ -n "${{ inputs.threads }}" ]; then
if ! [[ "${{ inputs.threads }}" =~ ^[0-9]+$ ]]; then
echo "❌ threads 参数必须是数字"
echo "is_valid=false" >> "$GITHUB_OUTPUT"
exit 1
fi
fi
# 验证配置文件是否存在
if [ -f "${{ inputs.config_path }}" ]; then
echo "config_exists=true" >> "$GITHUB_OUTPUT"
echo "✅ 配置文件存在:${{ inputs.config_path }}"
else
echo "config_exists=false" >> "$GITHUB_OUTPUT"
echo "❌ 配置文件不存在:${{ inputs.config_path }}"
echo "is_valid=false" >> "$GITHUB_OUTPUT"
exit 1
fi
echo "is_valid=true" >> "$GITHUB_OUTPUT"
echo "✅ 所有输入参数验证通过"
build:
name: 编译固件
runs-on: ubuntu-latest
needs: validate
timeout-minutes: 360
steps:
- name: Checkout current repository
@@ -68,23 +159,52 @@ jobs:
/usr/local/lib/android \
/opt/ghc \
/opt/az \
/opt/microsoft
/opt/microsoft \
/usr/local/share/boost \
/usr/share/swift \
/usr/local/lib/nodejs
sudo apt-get clean
sudo rm -rf /var/lib/apt/lists/*
echo "📊 磁盘使用情况:"
df -h || true
- name: Setup ccache
uses: hendrikmuhs/ccache-action@v1.2
if: inputs.cache_enabled == true
with:
key: ${{ runner.os }}-wrt-ccache-${{ inputs.project }}-${{ inputs.version_type }}
max-size: 2G
- name: Cache downloads
uses: actions/cache@v4
if: inputs.cache_enabled == true
with:
path: ${{ env.DL_DIR }}
key: ${{ runner.os }}-wrt-dl-${{ inputs.project }}-${{ inputs.version_type }}-${{ hashFiles('**/*.config') }}
restore-keys: |
${{ runner.os }}-wrt-dl-${{ inputs.project }}-${{ inputs.version_type }}-
${{ runner.os }}-wrt-dl-${{ inputs.project }}-
${{ runner.os }}-wrt-dl-
- name: Cache build directory
uses: actions/cache@v4
if: inputs.cache_enabled == true
with:
path: wrt/build_dir
key: ${{ runner.os }}-wrt-build-${{ inputs.project }}-${{ inputs.version_type }}-${{ hashFiles('**/*.config') }}
restore-keys: |
${{ runner.os }}-wrt-build-${{ inputs.project }}-${{ inputs.version_type }}-
${{ runner.os }}-wrt-build-${{ inputs.project }}-
${{ runner.os }}-wrt-build-
- name: Choose Wrt Version
id: refinfo
run: |
if [ "$VERSION_TYPE" = "snapshot" ]; then
if [ "${{ inputs.version_type }}" = "snapshot" ]; then
echo "ref=master" >> "$GITHUB_OUTPUT"
else
echo "ref=$TAG" >> "$GITHUB_OUTPUT"
echo "ref=${{ inputs.tag }}" >> "$GITHUB_OUTPUT"
fi
env:
VERSION_TYPE: ${{ inputs.version_type }}
TAG: ${{ inputs.tag }}
- name: Install dependencies
run: |
@@ -99,7 +219,8 @@ jobs:
libelf-dev libfuse-dev liblzma-dev libxml2-dev libyaml-dev \
uuid-dev device-tree-compiler antlr3 gperf \
time bc jq xxd swig upx-ucl ccache ecj fastjar imagemagick \
llvm linux-tools-common libbpf-dev linux-tools-$(uname -r)
llvm linux-tools-common libbpf-dev linux-tools-$(uname -r) \
u-boot-tools device-tree-compiler
- name: Determine Git URL
id: projectinfo
@@ -117,9 +238,6 @@ jobs:
openwrt)
echo "url=https://git.openwrt.org/openwrt/openwrt.git" >> $GITHUB_OUTPUT
;;
lede)
echo "url=https://github.com/coolsnowwolf/lede.git" >> $GITHUB_OUTPUT
;;
*)
echo "❌ 未知项目: ${{ inputs.project }}" >&2
exit 1
@@ -129,35 +247,155 @@ jobs:
- name: Clone Wrt source
run: |
echo "📥 克隆 ${{ inputs.project }} 仓库"
git clone "${{ steps.projectinfo.outputs.url }}" wrt
cd wrt
echo "🔖 切换到版本:${{ steps.refinfo.outputs.ref }}"
git checkout "${{ steps.refinfo.outputs.ref }}"
git clone --depth 1 "${{ steps.projectinfo.outputs.url }}" -b "${{ steps.refinfo.outputs.ref }}" wrt || \
(git clone "${{ steps.projectinfo.outputs.url }}" wrt && cd wrt && git checkout "${{ steps.refinfo.outputs.ref }}")
echo "🔖 当前版本:$(cd wrt && git describe --tags --always || git rev-parse --short HEAD)"
- name: Apply custom configurations
working-directory: wrt
run: |
echo "⚙️ 应用自定义配置..."
# 检测项目类型
DETECT_TARGET_FILE="package/base-files/files/etc/openwrt_release"
if [ -f "$DETECT_TARGET_FILE" ]; then
if grep -qi "immortalwrt" "$DETECT_TARGET_FILE"; then
TARGET_TYPE="ImmortalWrt"
else
TARGET_TYPE="OpenWrt"
fi
else
if [ -d "feeds/packages" ]; then
TARGET_TYPE="ImmortalWrt"
else
TARGET_TYPE="OpenWrt"
fi
fi
echo "📋 检测到目标类型:$TARGET_TYPE"
# 1. 设置自定义 hostname
if [ -n "${{ inputs.custom_hostname }}" ]; then
CONFIG_GEN_FILE="package/base-files/files/bin/config_generate"
if [ -f "$CONFIG_GEN_FILE" ]; then
if [ "$TARGET_TYPE" = "ImmortalWrt" ]; then
sed -i "s/ImmortalWrt/${{ inputs.custom_hostname }}/g" "$CONFIG_GEN_FILE"
else
sed -i "s/OpenWrt/${{ inputs.custom_hostname }}/g" "$CONFIG_GEN_FILE"
fi
echo "✅ Hostname 已设置为:${{ inputs.custom_hostname }}"
fi
fi
# 2. 设置自定义 IP 地址
if [ -n "${{ inputs.custom_ip }}" ]; then
CONFIG_GEN_FILE="package/base-files/files/bin/config_generate"
if [ -f "$CONFIG_GEN_FILE" ]; then
sed -i 's/192\.168\.[0-9]*\.[0-9]*/${{ inputs.custom_ip }}/g' "$CONFIG_GEN_FILE"
echo "✅ 默认 IP 已设置为:${{ inputs.custom_ip }}"
fi
fi
# 3. 设置 root 密码
if [ -n "${{ inputs.root_password }}" ]; then
SHADOW_FILE="package/base-files/files/etc/shadow"
if [ -f "$SHADOW_FILE" ]; then
HASH=$(openssl passwd -1 '${{ inputs.root_password }}')
if grep -q "^root:" "$SHADOW_FILE"; then
sed -i "s|^root:[^:]*:|root:${HASH}:|" "$SHADOW_FILE"
elif grep -q "^root::" "$SHADOW_FILE"; then
sed -i "s|root::|root:${HASH}:|" "$SHADOW_FILE"
fi
echo "✅ root 密码已设置"
fi
fi
# 4. 设置 LuCI 主题
mkdir -p package/base-files/files/etc/uci-defaults
cat >package/base-files/files/etc/uci-defaults/99_set_theme <<'EOF'
uci set luci.main.mediaurlbase=/luci-static/${{ inputs.luci_theme }}
uci commit luci
EOF
chmod +x package/base-files/files/etc/uci-defaults/99_set_theme
echo "✅ LuCI 主题已设置为:${{ inputs.luci_theme }}"
# 5. 启用/禁用 BBR
if [ "${{ inputs.enable_bbr }}" = "true" ]; then
mkdir -p package/base-files/files/etc/sysctl.d
cat >package/base-files/files/etc/sysctl.d/99-bbr.conf <<'EOF'
net.core.default_qdisc=fq_codel
net.ipv4.tcp_congestion_control=bbr
EOF
echo "✅ BBR 拥塞控制算法已启用"
else
rm -f package/base-files/files/etc/sysctl.d/99-bbr.conf || true
echo " BBR 拥塞控制算法已禁用"
fi
# 6. 设置默认 shell
PASSWD_FILE="package/base-files/files/etc/passwd"
if [ -f "$PASSWD_FILE" ]; then
if [ "${{ inputs.custom_shell }}" = "bash" ]; then
if grep -q "/bin/ash" "$PASSWD_FILE"; then
sed -i "s|/bin/ash|/bin/bash|g" "$PASSWD_FILE"
echo "✅ 默认 shell 已设置为 bash"
fi
else
if grep -q "/bin/bash" "$PASSWD_FILE"; then
sed -i "s|/bin/bash|/bin/ash|g" "$PASSWD_FILE"
echo "✅ 默认 shell 已设置为 ash"
fi
fi
fi
# 7. 设置自定义 SSH 横幅
mkdir -p package/base-files/files/etc
if [ -n "${{ inputs.custom_banner }}" ]; then
cat >package/base-files/files/etc/banner <<'EOF'
${{ inputs.custom_banner }}
EOF
echo "✅ 使用自定义 banner"
else
cat >package/base-files/files/etc/banner <<'EOF'
| | _____ _____ ____________/ |______ | |
| |/ \ / \ / _ \_ __ \ __\__ \ | |
| | Y Y \ Y Y ( <_> ) | \/| | / __ \| |__
|___|__|_| /__|_| /\____/|__| |__| (____ /____/
\/ \/ By Dich \/
-----------------------------------------------------
EOF
echo "✅ 默认 banner 已设置"
fi
echo "✅ 自定义配置完成"
- name: Copy and Run diy.sh
run: |
echo "📂 复制 diy.sh 到 wrt 目录并执行"
cp diy.sh wrt/diy.sh
cd wrt
chmod +x diy.sh
./diy.sh
echo "📂 复制 diy.sh 到 wrt 目录并执行(可选)"
if [ -f diy.sh ]; then
cp diy.sh wrt/diy.sh
cd wrt
chmod +x diy.sh
./diy.sh || echo "⚠️ diy.sh 执行失败,继续构建..."
else
echo " diy.sh 不存在,跳过"
fi
- name: Update and install feeds
working-directory: wrt
run: |
if [ "${{ github.event.inputs.proxy_nikki }}" == "true" ]; then
echo "📦 添加 nikki feed"
echo "src-git nikki https://github.com/nikkinikki-org/OpenWrt-nikki.git;main" >> "feeds.conf.default"
if [ "${{ inputs.proxy_luci_app_zzz }}" = "true" ]; then
echo "📦 添加 luci-app-zzz feed"
echo "src-git luci-app-zzz https://github.com/Dichgrem/luci-app-zzz.git" >> "feeds.conf.default"
fi
if [ "${{ github.event.inputs.proxy_passwall2 }}" == "true" ]; then
if [ "${{ inputs.proxy_passwall2 }}" = "true" ]; then
echo "📦 添加 passwall2 feed"
echo "src-git passwall https://github.com/xiaorouji/openwrt-passwall2.git" >> "feeds.conf.default"
fi
if [ "${{ github.event.inputs.proxy_luci_app_momo }}" == "true" ]; then
if [ "${{ inputs.proxy_luci_app_momo }}" = "true" ]; then
echo "📦 添加 luci-app-momo feed"
echo "src-git momo https://github.com/nikkinikki-org/OpenWrt-momo.git;main" >> "feeds.conf.default"
echo "src-git momo https://github.com/nikkinikki-org/OpenWrt-momo.git" >> "feeds.conf.default"
fi
echo "📦 更新 feeds"
@@ -168,11 +406,6 @@ jobs:
- name: Setup configuration
run: |
echo "📋 复制配置:${{ inputs.config_path }} → wrt/.config"
if [ ! -f "${{ inputs.config_path }}" ]; then
echo "❌ 找不到配置文件:${{ inputs.config_path }}"
exit 1
fi
cp "${{ inputs.config_path }}" wrt/.config
cd wrt
@@ -196,9 +429,14 @@ jobs:
run: |
echo "⬇️ 下载所有源码包(使用单线程 -j1 避免卡住)"
set -o pipefail
START=$(date +%s)
time make download -j1
END=$(date +%s)
DURATION=$((END - START))
echo "✅ 下载完成,耗时:${DURATION}秒"
- name: Build Firmware
id: build
working-directory: wrt
run: |
if [ "${{ inputs.threads }}" = "0" ] || [ -z "${{ inputs.threads }}" ]; then
@@ -209,7 +447,9 @@ jobs:
echo "🚀 全量编译(并行 ${JOBS})开始"
START=$(date "+%Y-%m-%d %H:%M:%S")
START_TS=$(date +%s)
echo "⏱️ 编译开始:${START}"
echo "jobs_count=${JOBS}" >> "$GITHUB_OUTPUT"
set -o pipefail
@@ -227,31 +467,72 @@ jobs:
fi
END=$(date "+%Y-%m-%d %H:%M:%S")
END_TS=$(date +%s)
DURATION=$((END_TS - START_TS))
DURATION_H=$((DURATION / 3600))
DURATION_M=$(((DURATION % 3600) / 60))
DURATION_S=$((DURATION % 60))
echo "✅ 编译成功"
echo "⏱️ 编译结束:${END}"
echo "⏱️ 总耗时:${DURATION_H}小时 ${DURATION_M}分钟 ${DURATION_S}秒"
echo "build_success=true" >> "$GITHUB_OUTPUT"
- name: list all target files
- name: Build statistics
if: steps.build.outputs.build_success == 'true'
run: |
echo ">>> 打印 wrt/bin/targets 下所有文件"
echo "📊 编译统计信息"
echo "项目:${{ inputs.project }}"
echo "版本:${{ steps.refinfo.outputs.ref }}"
echo "编译线程:${{ steps.build.outputs.jobs_count }}"
echo "缓存状态:${{ inputs.cache_enabled }}"
echo ""
echo "固件文件列表:"
if [ -d wrt/bin/targets ]; then
find wrt/bin/targets -type f | sed 's/^/ - /'
else
echo "❗ wrt/bin/targets 目录不存在"
find wrt/bin/targets -type f -exec ls -lh {} \; | awk '{print $9, $5}'
echo ""
echo "总固件大小:"
du -sh wrt/bin/targets
fi
- name: Upload build log on failure
uses: actions/upload-artifact@v4
if: failure()
with:
name: ${{ inputs.project }}-build-log-error
path: wrt/world_debug.log
retention-days: 7
if-no-files-found: ignore
- name: Upload build artifacts
uses: actions/upload-artifact@v4
if: steps.build.outputs.build_success == 'true'
with:
name: ${{ inputs.project }}-output
name: ${{ inputs.project }}-output-${{ inputs.version_type }}-${{ github.run_number }}
path: |
wrt/bin/targets/**
!wrt/bin/targets/x86/64/packages/**
!wrt/bin/targets/**/packages/**
if-no-files-found: warn
compression-level: 6
overwrite: false
retention-days: 30
- name: Upload build log
- name: Upload config diff
uses: actions/upload-artifact@v4
if: steps.build.outputs.build_success == 'true'
with:
name: ${{ inputs.project }}-build-log
path: wrt/world_debug.log
name: ${{ inputs.project }}-config-diff
path: |
wrt/.config
wrt/.config.before_oldconfig
if-no-files-found: ignore
retention-days: 7
- name: Cleanup
if: always()
run: |
echo "🧹 清理工作空间..."
cd wrt
make clean || true
echo "✅ 清理完成"

View File

@@ -6,7 +6,6 @@ This is a Openwrt build workflows.
| 名称 | URL | SHORT |
|--------------|------------------------------------------------------------|--------------------------|
| lede | https://github.com/coolsnowwolf/lede.git | coolsnowwolf/lede |
| openwrt | https://git.openwrt.org/openwrt/openwrt.git | openwrt/openwrt |
| immortalwrt | https://github.com/immortalwrt/immortalwrt.git | immortalwrt/immortalwrt |
| immortalwrt-mt798x | https://github.com/hanwckf/immortalwrt-mt798x.git | hanwckf/immortalwrt-mt798x |

80
diy.sh
View File

@@ -14,15 +14,67 @@ echo "🚀 添加自定义 feed 源..."
echo "✅ feeds 添加完成"
# 检测项目类型OpenWrt 或 ImmortalWrt
DETECT_TARGET_FILE="package/base-files/files/etc/openwrt_release"
if [ -f "$DETECT_TARGET_FILE" ]; then
if grep -qi "immortalwrt" "$DETECT_TARGET_FILE"; then
TARGET_TYPE="ImmortalWrt"
elif grep -qi "openwrt" "$DETECT_TARGET_FILE"; then
TARGET_TYPE="OpenWrt"
else
TARGET_TYPE="OpenWrt"
fi
else
# 如果检测文件不存在,通过其他方式判断
if [ -d "feeds/packages" ]; then
TARGET_TYPE="ImmortalWrt"
else
TARGET_TYPE="OpenWrt"
fi
fi
echo "📋 检测到目标类型:$TARGET_TYPE"
# 1. 默认 hostname
sed -i "s/ImmortalWrt/Dwrt/g" package/base-files/files/bin/config_generate
CONFIG_GEN_FILE="package/base-files/files/bin/config_generate"
if [ -f "$CONFIG_GEN_FILE" ]; then
if [ "$TARGET_TYPE" = "ImmortalWrt" ]; then
sed -i "s/ImmortalWrt/Dwrt/g" "$CONFIG_GEN_FILE"
else
sed -i "s/OpenWrt/Dwrt/g" "$CONFIG_GEN_FILE"
fi
echo "✅ Hostname 已修改为 Dwrt"
else
echo "⚠️ $CONFIG_GEN_FILE 不存在,跳过 hostname 修改"
fi
# 2. 默认 IP 地址
sed -i 's/192.168.2.1/192.168.1.1/' package/base-files/files/bin/config_generate
if [ -f "$CONFIG_GEN_FILE" ]; then
if grep -q "192.168.2.1" "$CONFIG_GEN_FILE"; then
sed -i 's/192.168.2.1/192.168.1.1/' "$CONFIG_GEN_FILE"
echo "✅ 默认 IP 已修改为 192.168.1.1"
elif grep -q "192.168.1.1" "$CONFIG_GEN_FILE"; then
echo "✅ 默认 IP 已经是 192.168.1.1"
else
echo "⚠️ $CONFIG_GEN_FILE 中未找到默认 IP 地址"
fi
fi
# 3. 默认 root 密码
HASH=$(openssl passwd -1 'password')
sed -i "s|root::0:0:99999|root:${HASH}:0:0:99999|" package/base-files/files/etc/shadow
SHADOW_FILE="package/base-files/files/etc/shadow"
if [ -f "$SHADOW_FILE" ]; then
HASH=$(openssl passwd -1 'password')
if grep -q "^root::" "$SHADOW_FILE"; then
sed -i "s|root::0:0:99999|root:${HASH}:0:0:99999|" "$SHADOW_FILE"
echo "✅ root 密码已设置"
elif grep -q "^root:" "$SHADOW_FILE"; then
echo "⚠️ root 账户已设置密码,跳过"
else
echo "⚠️ $SHADOW_FILE 中未找到 root 账户"
fi
else
echo "⚠️ $SHADOW_FILE 不存在,跳过 root 密码设置"
fi
# 4. 设置默认 LuCI 主题为 argon
mkdir -p package/base-files/files/etc/uci-defaults
@@ -31,6 +83,7 @@ uci set luci.main.mediaurlbase=/luci-static/argon
uci commit luci
EOF
chmod +x package/base-files/files/etc/uci-defaults/99_set_theme
echo "✅ LuCI 主题已设置为 argon"
# 5. 默认加载 BBR 拥塞控制算法
mkdir -p package/base-files/files/etc/sysctl.d
@@ -38,16 +91,28 @@ cat >package/base-files/files/etc/sysctl.d/99-bbr.conf <<'EOF'
net.core.default_qdisc=fq_codel
net.ipv4.tcp_congestion_control=bbr
EOF
echo "✅ BBR 拥塞控制算法已启用"
# 6. 修改默认 shell 为 bash
sed -i "s|/bin/ash|/bin/bash|g" package/base-files/files/etc/passwd
# 你需要在 .config 中确保包含 bash例如
# echo 'CONFIG_PACKAGE_bash=y' >> .config
PASSWD_FILE="package/base-files/files/etc/passwd"
if [ -f "$PASSWD_FILE" ]; then
if grep -q "/bin/ash" "$PASSWD_FILE"; then
sed -i "s|/bin/ash|/bin/bash|g" "$PASSWD_FILE"
echo "✅ 默认 shell 已修改为 bash"
elif grep -q "/bin/bash" "$PASSWD_FILE"; then
echo "✅ 默认 shell 已经是 bash"
else
echo "⚠️ $PASSWD_FILE 中未找到 ash 或 bash"
fi
else
echo "⚠️ $PASSWD_FILE 不存在,跳过 shell 修改"
fi
# 7. 自定义 SSH 登录横幅
mkdir -p package/base-files/files/etc
if [ -f "scripts/custom-files/banner.txt" ]; then
cp scripts/custom-files/banner.txt package/base-files/files/etc/banner
echo "✅ 使用自定义 banner"
else
cat >package/base-files/files/etc/banner <<'EOF'
| | _____ _____ ____________/ |______ | |
@@ -57,6 +122,7 @@ else
\/ \/ By Dich \/
-----------------------------------------------------
EOF
echo "✅ 默认 banner 已设置"
fi
# 8. 自定义 LuCI 概览设备型号