V6.4.6 添加固件版本号合法性验证

This commit is contained in:
Hyy2001X 2021-07-19 20:21:58 +08:00
parent 6a0eb35388
commit f660338337
1 changed files with 32 additions and 19 deletions

View File

@ -63,7 +63,7 @@ SHOW_VARIABLE() {
固件作者 URL: ${Github} 固件作者 URL: ${Github}
Release URL: ${Github_Release_URL} Release URL: ${Github_Release_URL}
Release API: ${Github_API} Release API: ${Github_API}
OpenWrt 源码 URL: https://github.com/${OP_Maintainer}/${OP_REPO_NAME}:${OP_BRANCH} OpenWrt 源码 URL: https://github.com/${OP_Maintainer}/${OP_REPO_NAME}:${OP_BRANCH}
固件匹配框架: $(GET_VARIABLE Egrep_Firmware ${Default_Variable}) 固件匹配框架: $(GET_VARIABLE Egrep_Firmware ${Default_Variable})
固件格式: ${Firmware_Type} 固件格式: ${Firmware_Type}
固件保存路径: ${AutoUpdate_Path} 固件保存路径: ${AutoUpdate_Path}
@ -312,12 +312,12 @@ CHECK_DEPENDS() {
PKG="$(echo $1 | cut -d ":" -f2)" PKG="$(echo $1 | cut -d ":" -f2)"
[[ $(echo ${PKG} | wc -c) -gt 8 ]] && Tab=" " || Tab=" " [[ $(echo ${PKG} | wc -c) -gt 8 ]] && Tab=" " || Tab=" "
echo -e "${PKG}${Tab}$(CHECK_PKG ${PKG})" echo -e "${PKG}${Tab}$(CHECK_PKG ${PKG})"
LOGGER "Checking ${PKG}... $(CHECK_PKG ${PKG})" LOGGER "[CHECK_DEPENDS] Checking [${PKG}] ... $(CHECK_PKG ${PKG})"
} }
else else
[[ $(echo $1 | wc -c) -gt 8 ]] && Tab=" " || Tab=" " [[ $(echo $1 | wc -c) -gt 8 ]] && Tab=" " || Tab=" "
echo -e "$1${Tab}$(CHECK_PKG $1)" echo -e "$1${Tab}$(CHECK_PKG $1)"
LOGGER "Checking $1... $(CHECK_PKG $1)" LOGGER "[CHECK_DEPENDS] Checking [$1] ... $(CHECK_PKG $1)"
fi fi
shift shift
done done
@ -325,6 +325,17 @@ CHECK_DEPENDS() {
EXIT EXIT
} }
FW_VERSION_CHECK() {
[[ $# -gt 1 ]] && echo "false" && return
[[ $1 =~ R[1-9.]{2}.+-[0-9]{8} ]] && {
echo "true"
LOGGER "[FW_VERSION_CHECK] Checking [$1] ... true"
} || {
echo "false"
LOGGER "[FW_VERSION_CHECK] Checking [$1] ... false"
}
}
GET_FW_LOG() { GET_FW_LOG() {
local Update_Log local Update_Log
case "$1" in case "$1" in
@ -342,8 +353,10 @@ GET_FW_LOG() {
esac esac
${Downloader} ${AutoUpdate_Path}/Update_Logs.json ${Release_URL}/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
}
[[ -n ${Update_Log} ]] && {
echo -e "\n${Grey}${FW_Version} for ${TARGET_PROFILE} 更新日志:" echo -e "\n${Grey}${FW_Version} for ${TARGET_PROFILE} 更新日志:"
echo -e "\n${Green}${Update_Log}${White}" echo -e "\n${Green}${Update_Log}${White}"
} }
@ -353,25 +366,22 @@ 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} ${AutoUpdate_Path}/Github_Tags ${Github_API} ${Downloader} ${AutoUpdate_Path}/Github_Tags ${Github_API}
[[ $? != 0 || ! -s ${AutoUpdate_Path}/Github_Tags ]] && { [[ $? != 0 || ! -s ${AutoUpdate_Path}/Github_Tags ]] && {
echo 0 echo "false"
} || echo 1 } || echo "true"
} }
GET_CLOUD_FW() { GET_CLOUD_VERSION() {
local X local X
[[ $(GET_CLOUD_INFO) == 0 ]] && { [[ $(GET_CLOUD_INFO) == false ]] && {
ECHO r "检查更新失败,请稍后重试!" ECHO r "检查更新失败,请稍后重试!"
EXIT 1 EXIT 1
} }
eval X=$(GET_VARIABLE Egrep_Firmware ${Default_Variable}) eval X=$(GET_VARIABLE Egrep_Firmware ${Default_Variable})
FW_Name=$(egrep -o "${X}" ${AutoUpdate_Path}/Github_Tags | awk 'END {print}') FW_Name=$(egrep -o "${X}" ${AutoUpdate_Path}/Github_Tags | awk 'END {print}')
[[ -z ${FW_Name} ]] && ECHO "云端固件名称获取失败!" && EXIT 1 [[ -z ${FW_Name} ]] && ECHO "云端固件名称获取失败!" && EXIT 1
}
GET_CLOUD_VERSION() {
GET_CLOUD_FW
CLOUD_Firmware_Version=$(echo "${FW_Name}" | egrep -o "R[0-9].*202[1-2][0-9]+") CLOUD_Firmware_Version=$(echo "${FW_Name}" | egrep -o "R[0-9].*202[1-2][0-9]+")
[[ -z ${CLOUD_Firmware_Version} ]] && ECHO "云端固件版本获取失败!" && EXIT 1 [[ -z ${CLOUD_Firmware_Version} ]] && ECHO r "云端固件版本获取失败!" && EXIT 1
[[ ! $(FW_VERSION_CHECK ${CLOUD_Firmware_Version}) == true ]] && ECHO r "云端固件版本号合法性检查失败!"
} }
CHECK_UPDATES() { CHECK_UPDATES() {
@ -387,13 +397,13 @@ CHECK_UPDATES() {
Upgrade_Stopped=2 Upgrade_Stopped=2
} }
} }
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/")
} }
PREPARE_UPGRADES() { PREPARE_UPGRADES() {
TITLE TITLE
[[ $* =~ -f && $* =~ -F ]] && SHELL_HELP [[ $* =~ -f && $* =~ -F ]] && SHELL_HELP
Upgrade_Option="${Upgrade_Command} -q" Upgrade_Option="sysupgrade -q"
MSG="更新固件" MSG="更新固件"
while [[ $1 ]];do while [[ $1 ]];do
case "$1" in case "$1" in
@ -454,7 +464,7 @@ PREPARE_UPGRADES() {
Proxy_Mode=1 Proxy_Mode=1
} }
fi fi
CHECK_UPDATES continue CHECK_UPDATES
[[ -z ${CLOUD_Firmware_Version} ]] && { [[ -z ${CLOUD_Firmware_Version} ]] && {
ECHO r "云端固件信息获取失败!" ECHO r "云端固件信息获取失败!"
EXIT 1 EXIT 1
@ -628,6 +638,7 @@ AutoUpdate_Main() {
[[ -z $* ]] && PREPARE_UPGRADES $* [[ -z $* ]] && PREPARE_UPGRADES $*
[[ $1 =~ path=/ && ! $* =~ -x && ! $* =~ -U ]] && PREPARE_UPGRADES $* [[ $1 =~ path=/ && ! $* =~ -x && ! $* =~ -U ]] && PREPARE_UPGRADES $*
[[ $1 =~ --skip ]] && PREPARE_UPGRADES $* [[ $1 =~ --skip ]] && PREPARE_UPGRADES $*
[[ $* =~ -T || $* =~ --verbose ]] && { [[ $* =~ -T || $* =~ --verbose ]] && {
Downloader="$(echo ${Downloader/ --quiet / })" Downloader="$(echo ${Downloader/ --quiet / })"
Downloader="$(echo ${Downloader/ --silent / })" Downloader="$(echo ${Downloader/ --silent / })"
@ -758,7 +769,10 @@ AutoUpdate_Main() {
;; ;;
*) *)
[[ -z $* ]] && EXIT 0 [[ -z $* ]] && EXIT 0
[[ ! $1 =~ R[0-9] ]] && SHELL_HELP || GET_FW_LOG -v $1 [[ $(FW_VERSION_CHECK $1) == true ]] && GET_FW_LOG -v $1 || {
ECHO r "固件版本号合法性检查失败!"
EXIT 1
}
;; ;;
esac esac
EXIT EXIT
@ -807,11 +821,10 @@ AutoUpdate_Main() {
done done
} }
Version=V6.4.5 Version=V6.4.6
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
Upgrade_Command=sysupgrade
Default_Variable=/etc/AutoBuild/Default_Variable Default_Variable=/etc/AutoBuild/Default_Variable
Custom_Variable=/etc/AutoBuild/Custom_Variable Custom_Variable=/etc/AutoBuild/Custom_Variable
[[ -n $* ]] && Run_Command="$0 $*" || Run_Command="$0" [[ -n $* ]] && Run_Command="$0 $*" || Run_Command="$0"