V6.0.7 优化 -B 更换新固件引导参数

This commit is contained in:
Hyy2001X 2021-06-12 18:37:10 +08:00
parent 0b3b05a81d
commit 517cd38d4e
1 changed files with 41 additions and 27 deletions

View File

@ -25,9 +25,9 @@ SHELL_HELP() {
更新固件: 更新固件:
-n 更新固件 [不保留配置] -n 更新固件 [不保留配置]
-f 强制更新固件,即跳过版本号验证,以及强制刷写固件 [保留配置] -f 跳过版本号验证,并强制刷写固件 [保留配置]
-u 适用于定时更新 LUCI 的参数 [保留配置] -u 适用于定时更新 LUCI 的参数 [保留配置]
-? <path=> 更新固件 (保存固件到用户提供的目录) -? <path=> 更新固件 (保存固件到用户指定的目录)
更新脚本: 更新脚本:
-x 更新 AutoUpdate.sh 脚本 -x 更新 AutoUpdate.sh 脚本
@ -35,22 +35,23 @@ SHELL_HELP() {
-x <url=> 更新 AutoUpdate.sh 脚本 (使用用户提供的脚本地址更新) -x <url=> 更新 AutoUpdate.sh 脚本 (使用用户提供的脚本地址更新)
其他参数: 其他参数:
-F,--force 强制刷写固件 (可附加)
-T,--test 测试模式 (可附加)
-P,--proxy 强制使用 [FastGit] 加速 (可附加)
-C <Github URL> 更改 Github 地址 -C <Github URL> 更改 Github 地址
-B <UEFI/Legacy> 指定 x86_64 设备下载 UEFI 或 Legacy 引导的固件 (危险) -B <UEFI/Legacy> 指定 x86_64 设备下载 UEFI 或 Legacy 引导的固件 (危险)
-P,--proxy 强制镜像加速 -H,--help 打印 AutoUpdate 帮助信息
-T,--test 测试模式 (仅运行流程,不更新固件) -L,--list 打印当前系统信息
-H,--help 打印帮助信息 -U 检查版本更新
-L,--list 打印系统信息
-U 仅检查版本更新
--corn <task=> <time> 设置定时任务 --corn <task=> <time> 设置定时任务
--corn-del 删除所有 AutoUpdate 相关定时任务 --corn-del 删除所有 AutoUpdate 定时任务
--bak <path> <name> 备份配置文件到用户指定的目录 --bak <path> <name> 备份 Openwrt 配置文件到用户指定的目录
--clean 清理固件下载缓存 --clean 清理固件下载缓存
--check 检查 AutoUpdate 依赖 --check 检查 AutoUpdate 依赖软件包
--var <variable> 输出指定定义 --var <variable> 打印用户指定的 <variable>
--var-del <variable> 删除指定定义 --var-del <variable> 删除用户指定的 <variable>
--log 打印 AutoUpdate 运行日志 --log 打印 AutoUpdate 历史运行日志
--log-path <path> 更改 AutoUpdate 运行日志保存位置 --log-path <path> 更改 AutoUpdate 运行日志保存目录
EOF EOF
exit 0 exit 0
@ -199,7 +200,9 @@ CHANGE_BOOT() {
case "$1" in case "$1" in
UEFI | Legacy) UEFI | Legacy)
EDIT_VARIABLE edit ${Custom_Variable} x86_64_Boot $1 EDIT_VARIABLE edit ${Custom_Variable} x86_64_Boot $1
echo "ON" > /force_dump
TIME r "警告: 更换引导方式后更新固件后可能导致设备无法正常启动!" TIME r "警告: 更换引导方式后更新固件后可能导致设备无法正常启动!"
TIME y "已创建临时文件 /force_dump,AutoUpdate 将在下一次更新时强制刷写固件!"
TIME y "固件引导格式已指定为: $1" TIME y "固件引导格式已指定为: $1"
;; ;;
*) *)
@ -287,31 +290,36 @@ CHECK_UPDATES() {
PREPARE_UPGRADES() { PREPARE_UPGRADES() {
TITLE TITLE
local Z while [[ $1 ]];do
for Z in $(echo $*) [[ $1 == -T || $1 == --test ]] && {
do
[[ ${Z} == -T || ${Z} == --test ]] && {
Test_Mode=1 Test_Mode=1
TAIL_MSG=" [Test Mode]" TAIL_MSG=" [Test Mode]"
} } ||
[[ ${Z} == -P || ${Z} == --proxy ]] && { [[ $1 == -P || $1 == --proxy ]] && {
Proxy_Mode=1 Proxy_Mode=1
Proxy_Echo="[FastGit] " Proxy_Echo="[FastGit] "
} || { } || {
Proxy_Mode=0 Proxy_Mode=0
unset Proxy_Echo unset Proxy_Echo
} }
[[ ${Z} =~ path= ]] && { [[ $1 =~ path= ]] && {
[ -z "$(echo ${Z} | cut -d "=" -f2)" ] && TIME r "保存路径不能为空!" && exit 1 [ -z "$(echo ${Z} | cut -d "=" -f2)" ] && TIME r "保存路径不能为空!" && exit 1
FW_SAVE_PATH=$(echo ${Z} | cut -d "=" -f2) FW_SAVE_PATH=$(echo ${Z} | cut -d "=" -f2)
TIME g "使用自定义固件保存位置: ${FW_SAVE_PATH}" TIME g "使用自定义固件保存位置: ${FW_SAVE_PATH}"
} }
[[ $1 == -F || $1 == --force ]] && Force_Write=1
case $1 in
-n | -f | -u)
Option="$1"
;;
esac
shift
done done
REMOVE_FW_CACHE quiet ${FW_SAVE_PATH} REMOVE_FW_CACHE quiet ${FW_SAVE_PATH}
Upgrade_Option="${Upgrade_Command} -q" Upgrade_Option="${Upgrade_Command} -q"
case $1 in case ${Option} in
-n) -n)
Upgrade_Option="${Upgrade_Command} -n" Upgrade_Option="${Upgrade_Command} -q -n"
MSG="更新固件 (不保留配置)" MSG="更新固件 (不保留配置)"
;; ;;
-f) -f)
@ -321,13 +329,19 @@ PREPARE_UPGRADES() {
;; ;;
-u) -u)
AutoUpdate_Mode=1 AutoUpdate_Mode=1
MSG="定时更新 (保留配置)" MSG="LUCI 定时更新 (保留配置)"
;; ;;
*) *)
Upgrade_Option="${Upgrade_Command} -q" Upgrade_Option="${Upgrade_Command} -q"
MSG="更新固件 (保留配置)" MSG="更新固件 (保留配置)"
esac esac
TIME g "执行: ${Proxy_Echo}${MSG}${TAIL_MSG}" [ -f /force_dump ] && Force_Write=1
[[ ${Force_Write} == 1 && ! ${Force_Mode} == 1 ]] && {
MSG_2=" [强制刷写]"
Upgrade_Option="${Upgrade_Option} -F"
}
TIME g "执行: ${Proxy_Echo}${MSG}${TAIL_MSG}${MSG_2}"
exit
if [[ $(CHECK_PKG curl) == true && ${Proxy_Mode} == 0 ]];then if [[ $(CHECK_PKG curl) == true && ${Proxy_Mode} == 0 ]];then
Google_Check=$(curl -I -s --connect-timeout 3 google.com -w %{http_code} | tail -n1) Google_Check=$(curl -I -s --connect-timeout 3 google.com -w %{http_code} | tail -n1)
[[ ! ${Google_Check} == 301 ]] && { [[ ! ${Google_Check} == 301 ]] && {
@ -437,7 +451,7 @@ REMOVE_FW_CACHE() {
esac esac
} }
export Version=V6.0.6 export Version=V6.0.7
export log_Path=/tmp export log_Path=/tmp
export Upgrade_Command=sysupgrade export Upgrade_Command=sysupgrade
export Default_Variable=/etc/AutoBuild/Default_Variable export Default_Variable=/etc/AutoBuild/Default_Variable
@ -496,7 +510,7 @@ while [[ $1 ]];do
[[ -z ${SH_SAVE_PATH} ]] && SH_SAVE_PATH=/bin [[ -z ${SH_SAVE_PATH} ]] && SH_SAVE_PATH=/bin
UPDATE_SCRIPT ${SH_SAVE_PATH} ${Script_URL} UPDATE_SCRIPT ${SH_SAVE_PATH} ${Script_URL}
;; ;;
-n | -f | -u | -T | --test | -P) -n | -f | -u | -T | --test | -P | --proxy | -F | --force)
PREPARE_UPGRADES $* PREPARE_UPGRADES $*
;; ;;
--corn) --corn)