V6.4.1 优化 Downloader 逻辑、修复固件更新日志、移除参数 -U

This commit is contained in:
Hyy2001X 2021-07-08 03:48:51 +08:00
parent c1faa63379
commit 9bd9a4932d
1 changed files with 22 additions and 41 deletions

View File

@ -32,11 +32,10 @@ SHELL_HELP() {
-C <Github URL> 更改 Github 地址为提供的 <Github URL> -C <Github URL> 更改 Github 地址为提供的 <Github URL>
-B <UEFI | Legacy> 指定 x86_64 设备下载 <UEFI | Legacy> 引导的固件 (危险) -B <UEFI | Legacy> 指定 x86_64 设备下载 <UEFI | Legacy> 引导的固件 (危险)
-V < | cloud> 打印 <当前 | 云端> AutoUpdate.sh 版本号 -V < | cloud> 打印 <当前 | 云端> AutoUpdate.sh 版本号
-E <local | cloud | *> 打印 <当前 | 云端 | 指定版本> 版本的固件更新日志 -E < | cloud | *> 打印 <当前 | 云端 | 指定版本> 版本的固件更新日志
-H,--help 打印 AutoUpdate 帮助信息 -H,--help 打印 AutoUpdate 帮助信息
-L,--list 打印当前系统信息 -L,--list 打印当前系统信息
-Q < | cloud> 打印 <当前 | 云端> 固件版本 -Q < | cloud> 打印 <当前 | 云端> 固件版本
-U 检查固件版本更新并获取更新日志
--bak <Path> <Name> 备份当前系统配置文件到指定的 <Path> 路径及名称 <Name> --bak <Path> <Name> 备份当前系统配置文件到指定的 <Path> 路径及名称 <Name>
--clean 清理 AutoUpdate 缓存 --clean 清理 AutoUpdate 缓存
--check 检查 AutoUpdate 依赖软件包 --check 检查 AutoUpdate 依赖软件包
@ -284,7 +283,7 @@ UPDATE_SCRIPT() {
ECHO b "下载地址: $2" ECHO b "下载地址: $2"
ECHO "开始更新 AutoUpdate 脚本,请耐心等待..." ECHO "开始更新 AutoUpdate 脚本,请耐心等待..."
[[ ! -d $1 ]] && mkdir -p $1 [[ ! -d $1 ]] && mkdir -p $1
${Downloader} $2 -O /tmp/AutoUpdate.sh ${Downloader} /tmp/AutoUpdate.sh $2
if [[ $? == 0 && -s /tmp/AutoUpdate.sh ]];then if [[ $? == 0 && -s /tmp/AutoUpdate.sh ]];then
mv -f /tmp/AutoUpdate.sh $1 mv -f /tmp/AutoUpdate.sh $1
[[ ! $? == 0 ]] && ECHO r "AutoUpdate 脚本更新失败!" && EXIT 1 [[ ! $? == 0 ]] && ECHO r "AutoUpdate 脚本更新失败!" && EXIT 1
@ -324,7 +323,7 @@ CHECK_DEPENDS() {
} }
GET_FW_LOG() { GET_FW_LOG() {
local FW_Version Update_Log local Update_Log
case "$1" in case "$1" in
local) local)
FW_Version="${CURRENT_Version}" FW_Version="${CURRENT_Version}"
@ -338,28 +337,20 @@ GET_FW_LOG() {
FW_Version="$1" FW_Version="$1"
;; ;;
esac esac
${Downloader} ${Release_URL}/Update_Logs.json -O ${AutoUpdate_Path}/Update_Logs.json ${Downloader} ${AutoUpdate_Path}/Update_Logs.json ${Release_URL}/Update_Logs.json
[[ $? == 0 ]] && { [[ $? == 0 ]] && {
Update_Log=$(jsonfilter -e '@["'"""${TARGET_PROFILE}"""'"]["'"""${FW_Version}"""'"]' < ${AutoUpdate_Path}/Update_Logs.json) Update_Log=$(jsonfilter -e '@["'"""${TARGET_PROFILE}"""'"]["'"""${FW_Version}"""'"]' < ${AutoUpdate_Path}/Update_Logs.json)
rm -f ${AutoUpdate_Path}/Update_Logs.json rm -f ${AutoUpdate_Path}/Update_Logs.json
} } || return
case "$2" in [[ -z ${Update_Log} ]] && return
show) echo -e "\n${Grey}${FW_Version} for ${TARGET_PROFILE} 更新日志:"
if [[ -n ${Update_Log} ]];then echo -e "\n${Green}${Update_Log}${White}"
echo -e "\n${Grey}${FW_Version} 更新日志:"
echo -e "\n${Green}${Update_Log}${White}\n"
else
ECHO r "未查询到版本: [${FW_Version}] 的日志信息!"
fi
;;
esac
} }
GET_CLOUD_INFO() { GET_CLOUD_INFO() {
[[ -f ${AutoUpdate_Path}/Github_Tags ]] && rm -f ${AutoUpdate_Path}/Github_Tags [[ -f ${AutoUpdate_Path}/Github_Tags ]] && rm -f ${AutoUpdate_Path}/Github_Tags
${Downloader} ${Github_API} -O ${AutoUpdate_Path}/Github_Tags ${Downloader} ${AutoUpdate_Path}/Github_Tags ${Github_API}
[[ $? != 0 || ! -s ${AutoUpdate_Path}/Github_Tags ]] && { [[ $? != 0 || ! -s ${AutoUpdate_Path}/Github_Tags ]] && {
[[ $1 == check ]] && echo "获取失败" > /tmp/Cloud_Version
echo 0 echo 0
} || echo 1 } || echo 1
} }
@ -395,11 +386,6 @@ CHECK_UPDATES() {
} }
} }
SHA5BIT=$(echo ${FW_Name} | egrep -o "[a-zA-Z0-9]+.${Firmware_Type}" | sed -r "s/(.*).${Firmware_Type}/\1/") SHA5BIT=$(echo ${FW_Name} | egrep -o "[a-zA-Z0-9]+.${Firmware_Type}" | sed -r "s/(.*).${Firmware_Type}/\1/")
[[ $1 == check ]] && {
echo -e "\n当前固件版本: ${CURRENT_Version}${CURRENT_Type}"
echo -e "云端固件版本: ${CLOUD_Firmware_Version}${CLOUD_Type}"
GET_FW_LOG cloud show
} || GET_FW_LOG cloud
} }
PREPARE_UPGRADES() { PREPARE_UPGRADES() {
@ -451,6 +437,7 @@ PREPARE_UPGRADES() {
esac esac
shift shift
done done
LOGGER "Upgrade Options: ${Upgrade_Option}"
[[ -n "${Special_Commands}" ]] && ECHO g "特殊指令:${Special_Commands} / ${Upgrade_Option}" [[ -n "${Special_Commands}" ]] && ECHO g "特殊指令:${Special_Commands} / ${Upgrade_Option}"
ECHO g "执行: ${MSG}${Special_MSG}" ECHO g "执行: ${MSG}${Special_MSG}"
REMOVE_CACHE quiet REMOVE_CACHE quiet
@ -481,10 +468,7 @@ $(echo -e "云端固件版本: ${CLOUD_Firmware_Version}${CLOUD_Type}")
云端固件名称: ${FW_Name} 云端固件名称: ${FW_Name}
固件下载地址: ${FW_URL} 固件下载地址: ${FW_URL}
EOF EOF
if [[ -n ${Update_Log} ]];then GET_FW_LOG -v ${CLOUD_Firmware_Version}
echo -e "\n${Grey}${CLOUD_Firmware_Version} 更新日志:"
echo -e "\n${Green}${Update_Log}${White}"
fi
rm -f ${AutoUpdate_Path}/Github_Tags rm -f ${AutoUpdate_Path}/Github_Tags
case "${Upgrade_Stopped}" in case "${Upgrade_Stopped}" in
1 | 2) 1 | 2)
@ -512,7 +496,7 @@ EOF
ECHO r "固件下载失败,请检查网络后重试!" ECHO r "固件下载失败,请检查网络后重试!"
EXIT 1 EXIT 1
else else
${Downloader} "${FW_URL}/${FW_Name}" -O ${AutoUpdate_Path}/${FW_Name} ${Downloader} ${AutoUpdate_Path}/${FW_Name} "${FW_URL}/${FW_Name}"
[[ $? == 0 && -s ${AutoUpdate_Path}/${FW_Name} ]] && ECHO y "固件下载成功!" && break [[ $? == 0 && -s ${AutoUpdate_Path}/${FW_Name} ]] && ECHO y "固件下载成功!" && break
fi fi
Retry_Times=$((${Retry_Times} - 1)) Retry_Times=$((${Retry_Times} - 1))
@ -540,7 +524,6 @@ EOF
;; ;;
esac esac
[[ ${Test_Mode} != 1 ]] && { [[ ${Test_Mode} != 1 ]] && {
sleep 3
chmod 777 ${AutoUpdate_Path}/${FW_Name} chmod 777 ${AutoUpdate_Path}/${FW_Name}
DO_UPGRADE ${Upgrade_Option} ${AutoUpdate_Path}/${FW_Name} DO_UPGRADE ${Upgrade_Option} ${AutoUpdate_Path}/${FW_Name}
} || { } || {
@ -550,8 +533,9 @@ EOF
} }
DO_UPGRADE() { DO_UPGRADE() {
ECHO g "正在更新固件,更新期间请耐心等待 ..." ECHO g "准备更新固件,更新期间请不要断开电源或重启设备 ..."
sleep 3 sleep 5
ECHO g "正在更新固件,请耐心等待 ..."
$* $*
[[ $? -ne 0 ]] && { [[ $? -ne 0 ]] && {
ECHO r "固件刷写失败,请尝试手动更新固件!" ECHO r "固件刷写失败,请尝试手动更新固件!"
@ -606,11 +590,11 @@ AutoUpdate_Main() {
[[ ! -d ${AutoUpdate_Path} ]] && mkdir -p ${AutoUpdate_Path} [[ ! -d ${AutoUpdate_Path} ]] && mkdir -p ${AutoUpdate_Path}
if [[ $(CHECK_PKG wget-ssl) == true ]];then if [[ $(CHECK_PKG wget-ssl) == true ]];then
Downloader="wget-ssl -q --no-check-certificate -T 5 --no-dns-cache -x" Downloader="wget-ssl -q --no-check-certificate -T 5 --no-dns-cache -x -O"
elif [[ $(CHECK_PKG wget) == true ]];then elif [[ $(CHECK_PKG wget) == true ]];then
Downloader="wget -q --no-check-certificate -T 5 --no-dns-cache -x" Downloader="wget -q --no-check-certificate -T 5 --no-dns-cache -x -O"
else else
Downloader="uclient-fetch -q --no-check-certificate -T 5" Downloader="uclient-fetch -q --no-check-certificate -T 5 -O"
fi fi
[[ -z $* ]] && PREPARE_UPGRADES $* [[ -z $* ]] && PREPARE_UPGRADES $*
@ -621,6 +605,7 @@ AutoUpdate_Main() {
while [[ $1 ]];do while [[ $1 ]];do
case "$1" in case "$1" in
-n | -f | -u | -T | --test | -P | --proxy | -F) -n | -f | -u | -T | --test | -P | --proxy | -F)
LOGGER "Downloader: ${Downloader}"
PREPARE_UPGRADES $* PREPARE_UPGRADES $*
;; ;;
--bak) --bak)
@ -712,6 +697,7 @@ AutoUpdate_Main() {
} }
shift shift
done done
LOGGER "Downloader: ${Downloader}"
[[ -z ${SH_SAVE_PATH} ]] && SH_SAVE_PATH=/bin [[ -z ${SH_SAVE_PATH} ]] && SH_SAVE_PATH=/bin
UPDATE_SCRIPT ${SH_SAVE_PATH} ${AutoUpdate_Script_URL} UPDATE_SCRIPT ${SH_SAVE_PATH} ${AutoUpdate_Script_URL}
;; ;;
@ -758,16 +744,11 @@ AutoUpdate_Main() {
esac esac
EXIT 0 EXIT 0
;; ;;
-U)
shift && [[ -n $* ]] && SHELL_HELP
CHECK_UPDATES check
[[ $? == 0 ]] && EXIT 0 || EXIT 1
;;
-V) -V)
shift shift
case "$1" in case "$1" in
cloud) cloud)
Result="$(${Downloader} https://ghproxy.com/https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh -O - | egrep -o "V[0-9].+")" Result="$(${Downloader} - ${AutoUpdate_Script_URL} | egrep -o "V[0-9].+")"
;; ;;
*) *)
Result=${Version} Result=${Version}
@ -786,7 +767,7 @@ AutoUpdate_Main() {
done done
} }
Version=V6.4.0 Version=V6.4.1
AutoUpdate_Path=/tmp/AutoUpdate AutoUpdate_Path=/tmp/AutoUpdate
AutoUpdate_Log_Path=/tmp AutoUpdate_Log_Path=/tmp
AutoUpdate_Script_URL=https://ghproxy.com/https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh AutoUpdate_Script_URL=https://ghproxy.com/https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh