V6.6.7 优化代码

This commit is contained in:
Hyy2001X 2021-10-19 20:54:59 +08:00
parent 25bfb4aa14
commit c43dfb3b5c
1 changed files with 65 additions and 69 deletions

View File

@ -3,7 +3,7 @@
# AutoUpdate for Openwrt
# Dependences: bash wget-ssl/wget/uclient-fetch curl openssl jsonfilter
Version=V6.6.6
Version=V6.6.7
function TITLE() {
clear && echo "Openwrt-AutoUpdate Script by Hyy2001 ${Version}"
@ -111,6 +111,11 @@ function CHECK_ENV() {
}
function EXIT() {
case $1 in
2)
REMOVE_CACHE
;;
esac
exit $1
}
@ -183,7 +188,6 @@ function GET_VARIABLE() {
local Result="$(grep "$1=" $2 | grep -v "#" | awk 'NR==1' | sed -r "s/$1=(.*)/\1/")"
[[ -n ${Result} ]] && {
echo "${Result}"
LOGGER "[GET_VARIABLE] 获取环境变量 $1=[${Result}]"
}
}
@ -353,14 +357,13 @@ function CHECK_TIME() {
}
function ANALYSIS_API() {
local url name date size version count
local url name date size version count sha256
local API_Dump=${Running_Path}/API_Dump
[[ $(CHECK_TIME ${API_File} 1) == false ]] && {
DOWNLOADER --path ${Running_Path} --file-name API_Dump --dl ${DOWNLOADERS} --url "$(URL_X ${Github_Release}/API G@@1 F@@1) ${Github_API}@@1 " --no-url-name --timeout 3 --type 固件信息 --quiet
[[ ! $? == 0 || -z $(cat ${API_Dump} 2> /dev/null) ]] && {
ECHO r "Github API 请求错误,请检查网络后重试!"
RM ${API_File}
EXIT 1
EXIT 2
}
RM ${API_File} && touch -a ${API_File}
LOGGER "[ANALYSIS_API] 开始解析 Github API ..."
@ -374,19 +377,20 @@ function ANALYSIS_API() {
size=$(jsonfilter -i ${API_Dump} -e '@["assets"]' | jsonfilter -e '@['"""$i"""'].size' 2> /dev/null | awk '{a=$1/1048576} {printf("%.2f\n",a)}')
date=$(echo ${version} | cut -d '-' -f2)
count=$(jsonfilter -i ${API_Dump} -e '@["assets"]' | jsonfilter -e '@['"""$i"""'].download_count' 2> /dev/null)
printf "%-5s %-75s %-20s %-10s %-15s %s\n" ${count} ${name} ${version} ${date} ${size}MB ${url} >> ${API_File}
sha256=$(echo ${name} | egrep -o "\-[a-z0-9]+" | cut -c2-6 | awk 'END{print}')
printf "%-75s %-5s %-8s %-20s %-10s %-15s %s\n" ${name} ${count} ${sha256} ${version} ${date} ${size}MB ${url} >> ${API_File}
fi
i=$(($i + 1))
done
unset i
}
awk -F ' ' '{print NF}' ${API_File} | while read X;do
[[ ${X} != 6 ]] && LOGGER "[ANALYSIS_API] API 解析异常: ${X}"
done
[[ -z $(cat ${API_File} 2> /dev/null) ]] && {
ECHO r "Github API 解析失败!"
RM ${API_File}
EXIT 1
} || LOGGER "[ANALYSIS_API] Github API 解析成功!"
EXIT 2
}
}
function GET_CLOUD_LOG() {
@ -415,7 +419,7 @@ function GET_CLOUD_LOG() {
[[ -n ${Result} ]] && {
echo -e "\n${Grey}${Version} for ${TARGET_PROFILE} 更新日志:"
echo -e "\n${Green}${Result}${White}"
} || LOGGER "当前固件日志解析失败!"
} || LOGGER "未获取到当前固件的日志信息!"
}
}
@ -429,27 +433,30 @@ function GET_CLOUD_INFO() {
Info=$(grep "AutoBuild-${OP_REPO_NAME}-${TARGET_PROFILE}" ${API_File} | grep "${x86_Boot}" | uniq)
shift
else
Info=$(grep "AutoBuild-${OP_REPO_NAME}-${TARGET_PROFILE}" ${API_File} | grep "${x86_Boot}" | awk 'BEGIN {MAX = 0} {if ($4+0 > MAX+0) {MAX=$4 ;content=$0} } END {print content}')
Info=$(grep "AutoBuild-${OP_REPO_NAME}-${TARGET_PROFILE}" ${API_File} | grep "${x86_Boot}" | awk 'BEGIN {MAX = 0} {if ($5+0 > MAX+0) {MAX=$5 ;content=$0} } END {print content}')
fi
case "$1" in
count)
name)
echo "${Info}" | awk '{print $1}'
;;
name)
count)
echo "${Info}" | awk '{print $2}'
;;
version)
sha256)
echo "${Info}" | awk '{print $3}'
;;
date)
version)
echo "${Info}" | awk '{print $4}'
;;
size)
date)
echo "${Info}" | awk '{print $5}'
;;
url)
size)
echo "${Info}" | awk '{print $6}'
;;
url)
echo "${Info}" | awk '{print $7}'
;;
esac
}
@ -541,14 +548,15 @@ function UPGRADE() {
fi
ECHO "正在检查版本更新 ..."
ANALYSIS_API
CLOUD_FW_Version="$(GET_CLOUD_INFO version)"
CLOUD_FW_Name="$(GET_CLOUD_INFO name)"
CLOUD_FW_Count="$(GET_CLOUD_INFO count)"
CLOUD_FW_Size="$(GET_CLOUD_INFO size)"
CLOUD_FW_Url="$(GET_CLOUD_INFO url)"
CLOUD_FW_Version=$(GET_CLOUD_INFO version)
CLOUD_FW_Name=$(GET_CLOUD_INFO name)
CLOUD_FW_Count=$(GET_CLOUD_INFO count)
CLOUD_FW_Size=$(GET_CLOUD_INFO size)
CLOUD_FW_Url=$(GET_CLOUD_INFO url)
CLOUD_FW_SHA256=$(GET_CLOUD_INFO sha256)
[[ -z ${CLOUD_FW_Name} ]] && {
ECHO r "云端固件信息获取失败!"
EXIT 1
EXIT 2
}
[[ ${CLOUD_FW_Version} == ${CURRENT_Version} ]] && {
CURRENT_Type="${Yellow} [已是最新]${White}"
@ -587,7 +595,6 @@ EOF
ECHO && read -p "${err_MSG},是否继续更新固件?[Y/n]:" Choose
} || Choose=Y
[[ ! ${Choose} =~ [Yy] ]] && {
LOGGER "已取消固件更新操作!"
EXIT 0
}
;;
@ -608,11 +615,9 @@ EOF
[[ ! -s ${Firmware_Path}/${CLOUD_FW_Name} ]] && EXIT 1
if [[ ! Force_Mode == 1 ]];then
LOCAL_SHA256=$(GET_SHA256SUM ${Firmware_Path}/${CLOUD_FW_Name} 5)
CLOUD_SHA256=$(echo ${CLOUD_FW_Name} | egrep -o "[0-9a-z]+.${Firmware_Format}" | sed -r "s/(.*).${Firmware_Format}/\1/")
[[ ${LOCAL_SHA256} != ${CLOUD_SHA256} ]] && {
[[ ${LOCAL_SHA256} != ${CLOUD_FW_SHA256} ]] && {
ECHO r "SHA256 校验失败,请检查网络后重试!"
REMOVE_CACHE
EXIT 1
EXIT 2
}
LOGGER "固件 SHA256 比对通过!"
fi
@ -623,7 +628,7 @@ EOF
gzip -d -q -f -c ${Firmware_Path}/${CLOUD_FW_Name} > ${Firmware_Path}/$(echo ${CLOUD_FW_Name} | sed -r 's/(.*).gz/\1/')
[[ ! $? == 0 ]] && {
ECHO r "固件解压失败!"
EXIT 1
EXIT 2
} || {
CLOUD_FW_Name="$(echo ${CLOUD_FW_Name} | sed -r 's/(.*).gz/\1/')"
LOGGER "固件解压成功,固件已解压到: [${Firmware_Path}/${CLOUD_FW_Name}]"
@ -644,8 +649,20 @@ EOF
}
}
function DO_UPGRADE() {
ECHO r "警告: 固件更新期间请不要断开电源或重启设备!"
sleep 3
ECHO g "正在更新固件,请耐心等待 ..."
$*
[[ $? -ne 0 ]] && {
ECHO r "固件刷入失败,请尝试使用 [autoupdate -F] 指令更新固件!"
EXIT 1
}
EXIT
}
function DOWNLOADER() {
local DL_Downloader DL_Name DL_URL DL_Path DL_Retries DL_Timeout DL_Type DL_Final Quiet_Mode No_URL_Name Print_Mode DL_Retires_All DL_URL_Final
local u E DL_Downloader DL_Name DL_URL DL_Path DL_Retries DL_Timeout DL_Type DL_Final Quiet_Mode No_URL_Name Print_Mode DL_Retires_All DL_URL_Final
while [[ $1 ]];do
case "$1" in
--dl)
@ -693,7 +710,7 @@ function DOWNLOADER() {
DL_Retires_All="$(echo ${DL_URL[*]} | egrep -o "@@[0-9]+" | egrep -o "[0-9]+" | awk '{Sum += $1};END {print Sum}')"
DL_URL_Count="${#DL_URL[@]}"
}
LOGGER "[DOWNLOADER] URL 数量: [${DL_URL_Count}] 总重试次数: [${DL_Retires_All}]"
LOGGER "URL 数量: [${DL_URL_Count}] 总重试次数: [${DL_Retires_All}]"
while [[ $1 ]];do
[[ $1 =~ '--' ]] && break
[[ ! $1 =~ '--' ]] && shift
@ -721,7 +738,7 @@ function DOWNLOADER() {
--timeout)
shift
[[ ! $1 =~ [1-9] ]] && {
LOGGER "[DOWNLOADER] 参数: [$1] 不是正确的数字!"
LOGGER "[DOWNLOADER] [$1] 不是正确的数字!"
shift
} || {
DL_Timeout="$1"
@ -749,20 +766,19 @@ function DOWNLOADER() {
Quiet_Mode=quiet
;;
*)
LOGGER "[DOWNLOADER] 跳过未知参数: [$1] ..."
shift
;;
esac
done
case "${DL_Downloader}" in
wget | wget-ssl)
DL_Template="wget-ssl --quiet --no-check-certificate --no-dns-cache -x -4 --tries 1 --timeout 5 -O"
DL_Template="$(which wget) --quiet --no-check-certificate --no-dns-cache -x -4 --tries 1 --timeout 5 -O"
;;
curl)
DL_Template="curl --silent --insecure -L -k --connect-timeout 5 --retry 1 -o"
DL_Template="$(which curl) --silent --insecure -L -k --connect-timeout 5 --retry 1 -o"
;;
uclient-fetch)
DL_Template="uclient-fetch --quiet --no-check-certificate -4 --timeout 5 -O"
DL_Template="$(which uclient-fetch) --quiet --no-check-certificate -4 --timeout 5 -O"
;;
esac
[[ ${Test_Mode} == 1 || ${Verbose_Mode} == 1 ]] && {
@ -775,7 +791,7 @@ function DOWNLOADER() {
DL_Retries="${DL_URL_Cache##*@@}"
[[ -z ${DL_Retries} || ! ${DL_Retries} == [0-9] ]] && DL_Retries=1
DL_URL_Final="${DL_URL_Cache%*@@*}"
LOGGER "[DOWNLOADER] 当前 URL: [${DL_URL_Final}] URL 重试次数: [${DL_Retries}]"
LOGGER "当前 URL: [${DL_URL_Final}] URL 重试次数: [${DL_Retries}]"
for u in $(seq ${DL_Retries});do
sleep 1
[[ -z ${Failed} ]] && {
@ -794,7 +810,7 @@ function DOWNLOADER() {
[[ -f ${DL_Path}/${DL_Name} ]] && {
RM ${DL_Path}/${DL_Name}
}
LOGGER "[DOWNLOADER] 执行下载: [${DL_Final}]"
LOGGER "执行下载: [${DL_Final}]"
${DL_Final}
if [[ $? == 0 && -s ${DL_Path}/${DL_Name} ]];then
ECHO y ${Quiet_Mode} "${DL_Type}下载成功!"
@ -822,21 +838,10 @@ function DOWNLOADER() {
return 1
}
function DO_UPGRADE() {
ECHO r "警告: 固件更新期间请不要断开电源或尝试重启设备!"
sleep 3
ECHO g "正在更新固件,请耐心等待 ..."
$*
[[ $? -ne 0 ]] && {
ECHO r "固件刷写失败,请尝试使用 autoupdate -F 指令再次更新固件!"
ECHO r "脚本与固件更新问题请前往 [${Github}] 进行反馈, 请附上 AutoUpdate 运行日志与系统信息"
EXIT 1
} || EXIT 0
}
function REMOVE_CACHE() {
rm -rf ${Running_Path}/API \
${Running_Path}/Update_Logs \
/tmp/AutoUpdate.sh \
${Running_Path}/Update_Logs.json \
${Running_Path}/API_Dump 2> /dev/null
}
@ -855,25 +860,22 @@ function LOG() {
ECHO y "AutoUpdate 日志保存路径相同,无需修改!"
EXIT 0
}
[[ -f $2 ]] && {
ECHO r "AutoUpdate 日志保存路径有误,请重新输入!"
EXIT 1
}
EDIT_VARIABLE rm ${Custom_Variable} Log_Path
EDIT_VARIABLE edit ${Custom_Variable} Log_Path $2
[[ ! -d $2 ]] && mkdir -p $2
[[ -f $2/AutoUpdate.log ]] && mv ${Log_Path}/AutoUpdate.log $2
Log_Path="$2"
ECHO y "AutoUpdate 日志保存路径已修改为: [$2]!"
EXIT 0
;;
del | rm | clean)
RM ${Log_Path}/AutoUpdate.log
EXIT 0
;;
*)
SHELL_HELP
;;
esac
EXIT 0
done
}
}
@ -933,13 +935,7 @@ function AutoUpdate_Main() {
}
[[ ! -f ${Custom_Variable} ]] && touch ${Custom_Variable}
LOAD_VARIABLE ${Default_Variable} ${Custom_Variable}
[[ ! -d ${Running_Path} ]] && {
mkdir -p ${Running_Path}
[[ ! $? == 0 ]] && {
ECHO r "脚本运行路径 [${Running_Path}] 创建失败!"
EXIT 1
}
}
[[ ! -d ${Running_Path} ]] && mkdir -p ${Running_Path}
fi
[[ -z $* ]] && UPGRADE $*
@ -1043,7 +1039,7 @@ function AutoUpdate_Main() {
;;
-V)
shift
[[ -z $* ]] && echo "${CURRENT_Version}" && EXIT 1
[[ -z $* ]] && echo "${CURRENT_Version}" && EXIT 0
case "$1" in
[Cc]loud)
shift
@ -1085,8 +1081,8 @@ function AutoUpdate_Main() {
local Result
shift
[[ $# != 1 ]] && SHELL_HELP
Result=$(GET_VARIABLE "$1" ${Custom_Variable})
[[ -z ${Result} ]] && Result=$(GET_VARIABLE "$1" ${Default_Variable})
Result=$(GET_VARIABLE $1 ${Custom_Variable})
[[ -z ${Result} ]] && Result=$(GET_VARIABLE $1 ${Default_Variable})
[[ -n ${Result} ]] && echo "${Result}"
EXIT
;;
@ -1149,13 +1145,13 @@ function AutoUpdate_Main() {
done
}
KILL_OTHER() {
KILL_PROCESS() {
local i;for i in $(ps | grep -v grep | grep $1 | grep -v $$ | awk '{print $1}');do
kill -9 ${i} 2> /dev/null
kill -9 ${i} 2> /dev/null &
done
}
KILL_OTHER AutoUpdate.sh
KILL_PROCESS AutoUpdate.sh
Running_Path=/tmp/AutoUpdate
Log_Path=/tmp