V6.7.8 优化代码

This commit is contained in:
Hyy2001X 2021-12-03 23:58:00 +08:00
parent 467c8086e0
commit a7b2e124cd
1 changed files with 198 additions and 210 deletions

View File

@ -1,9 +1,9 @@
#!/bin/bash #!/bin/bash
# AutoBuild Module by Hyy2001 <https://github.com/Hyy2001X/AutoBuild-Actions> # AutoBuild Module by Hyy2001 <https://github.com/Hyy2001X/AutoBuild-Actions>
# AutoUpdate for Openwrt # AutoUpdate for Openwrt
# Dependences: bash wget-ssl/wget/uclient-fetch curl openssl jsonfilter expr # Dependences: bash wget-ssl/wget/uclient-fetch curl jq expr sysupgrade
Version=V6.7.7 Version=V6.7.8
function TITLE() { function TITLE() {
clear && echo "Openwrt-AutoUpdate Script by Hyy2001 ${Version}" clear && echo "Openwrt-AutoUpdate Script by Hyy2001 ${Version}"
@ -13,14 +13,14 @@ function SHELL_HELP() {
TITLE TITLE
cat <<EOF cat <<EOF
使用方法: bash $0 [-n] [-f] [-u] [-F] [-P] [-D <Downloader>] [--path <PATH>] 使用方法: bash $0 [-n] [-f] [-u] [-F] [-P] [-D <Downloader>] [--path <PATH>] ...
bash $0 [-x] [--path <PATH>] [--url <URL>] bash $0 [-x] [--path <PATH>] [--url <URL>] ...
更新固件: 更新固件:
-n 不保留配置更新固件 * -n 不保留配置更新固件 *
-u 适用于定时更新 LUCI 的参数 * -u 适用于定时更新 LUCI 的参数 *
-f 跳过版本号校验,并强制刷写固件 (不推荐) * -f 跳过版本号校验,并强制刷写固件 (不推荐) *
-F, --force-write 强制刷写固件 * -F, --force-flash 强制刷写固件 *
-P, --proxy 优先开启镜像加速下载固件 * -P, --proxy 优先开启镜像加速下载固件 *
-D <Downloader> 使用指定的下载器 <wget-ssl | wget | curl | uclient-fetch> * -D <Downloader> 使用指定的下载器 <wget-ssl | wget | curl | uclient-fetch> *
--decompress 解压 img.gz 固件后再更新固件 * --decompress 解压 img.gz 固件后再更新固件 *
@ -35,13 +35,14 @@ function SHELL_HELP() {
其他参数: 其他参数:
-B, --boot-mode <TYPE> 指定 x86 设备下载 <TYPE> 引导的固件 (e.g. UEFI BIOS) -B, --boot-mode <TYPE> 指定 x86 设备下载 <TYPE> 引导的固件 (e.g. UEFI BIOS)
-C <Github URL> 更改 Github 地址为提供的 <Github URL> -C <Github URL> 更改 Github 地址为提供的 <Github URL>
--api 打印 Github API 内容
--help 打印 AutoUpdate 帮助信息 --help 打印 AutoUpdate 帮助信息
--log < | del> <打印 | 删除> AutoUpdate 历史运行日志 --log < | del> <打印 | 删除> AutoUpdate 历史运行日志
--log --path <PATH> 更改 AutoUpdate 运行日志路径为提供的绝对路径 <PATH> --log --path <PATH> 更改 AutoUpdate 运行日志路径为提供的绝对路径 <PATH>
-P <F | G> 使用 <FastGit | Ghproxy> 镜像加速 * -P <F | G> 使用 <FastGit | Ghproxy> 镜像加速 *
--backup --path <PATH> 备份当前系统配置文件并移动到提供的绝对路径 <PATH> (可选) --backup --path <PATH> 备份当前系统配置文件到提供的绝对路径 <PATH> (可选)
--env-list < | 1 | 2> 打印 <完整 | 第一列 | 第二列> 环境变量列表 --env-list < | 1 | 2> 打印 <完整 | 第一列 | 第二列> 环境变量列表
--check 检查 AutoUpdate 运行环境 --chk 检查 AutoUpdate 运行环境
--clean 清理 AutoUpdate 缓存 --clean 清理 AutoUpdate 缓存
--fw-log < | *> 打印 <当前 | 指定> 版本的固件更新日志 --fw-log < | *> 打印 <当前 | 指定> 版本的固件更新日志
--fw-list 打印所有云端固件名称 --fw-list 打印所有云端固件名称
@ -51,7 +52,7 @@ function SHELL_HELP() {
-v < | [Cc]loud> 打印 <当前 | 云端> AutoUpdate.sh 版本 -v < | [Cc]loud> 打印 <当前 | 云端> AutoUpdate.sh 版本
-V < | [Cc]loud> 打印 <当前 | 云端> 固件版本 -V < | [Cc]loud> 打印 <当前 | 云端> 固件版本
脚本、固件更新问题反馈请前往 ${Github}, 并附上 AutoUpdate 运行日志与系统信息 (见上方) 脚本、固件更新问题反馈请${Github} 反馈, 并上脚本运行日志与系统信息
EOF EOF
EXIT EXIT
@ -64,7 +65,7 @@ function SHOW_VARIABLE() {
设备名称: $(uname -n) / ${TARGET_PROFILE} 设备名称: $(uname -n) / ${TARGET_PROFILE}
固件版本: ${OP_VERSION} 固件版本: ${OP_VERSION}
内核版本: $(uname -r) 内核版本: $(uname -r)
运行内存: Mem: $(MEMINFO 1)M | Swap: $(MEMINFO 2)M | Total: $(MEMINFO 3)M 运行内存: Mem: $(MEMINFO Mem)M | Swap: $(MEMINFO Swap)M | Total: $(MEMINFO All)M
其他参数: ${TARGET_BOARD} / ${TARGET_SUBTARGET} 其他参数: ${TARGET_BOARD} / ${TARGET_SUBTARGET}
固件作者: ${Author} 固件作者: ${Author}
作者仓库: ${Github} 作者仓库: ${Github}
@ -84,43 +85,35 @@ EOF
} }
function MEMINFO() { function MEMINFO() {
[[ -z $1 || ! $* =~ (All|Mem|Swap) ]] && return 1
local Mem Swap All Result local Mem Swap All Result
Mem=$(free | grep Mem: | awk '{Mem=$7/1024} {printf("%.0f\n",Mem)}' 2> /dev/null) Mem=$(free | grep Mem: | awk '{Mem=$7/1024} {printf("%.0f\n",Mem)}' 2> /dev/null)
Swap=$(free | grep Swap: | awk '{Swap=$4/1024} {printf("%.0f\n",Swap)}' 2> /dev/null) Swap=$(free | grep Swap: | awk '{Swap=$4/1024} {printf("%.0f\n",Swap)}' 2> /dev/null)
All=$(expr ${Mem} + ${Swap} 2> /dev/null) All=$(expr ${Mem} + ${Swap} 2> /dev/null)
case $1 in Result=$(eval echo '$'$1)
1)
Result=${Mem}
;;
2)
Result=${Swap}
;;
3)
Result=${All}
;;
esac
if [[ -n ${Result} ]] if [[ -n ${Result} ]]
then then
LOGGER "[MEMINFO] [$1] 运行内存: ${Result}M" LOGGER "可用 $1 运行内存: ${Result}M"
echo ${Result} echo ${Result}
return 0 return 0
else else
LOGGER "[MEMINFO] [$1] 可用运行内存获取失败!" LOGGER "[$1] 可用 $1 运行内存获取失败!"
return 1 return 1
fi fi
} }
SPACEINFO() { SPACEINFO() {
[[ -z $1 ]] && return 1
local Result Path local Result Path
Path=$(echo $1 | awk -F '/' '{print $2}') Path="$(echo $1 | awk -F '/' '{print $2}')"
Result=$(df -m /${Path} 2> /dev/null | grep -v Filesystem | awk '{print $4}') Result="$(df -m /${Path} 2> /dev/null | grep -v Filesystem | awk '{print $4}')"
if [[ -n ${Result} ]] if [[ -n ${Result} ]]
then then
LOGGER "[SPACEINFO] /${Path} 可用空间: ${Result}M" LOGGER "/${Path} 可用存储空间: ${Result}M"
echo "${Result}" echo "${Result}"
return 0 return 0
else else
LOGGER "[SPACEINFO] /${Path} 可用空间获取失败!" LOGGER "/${Path} 可用存储空间获取失败!"
return 1 return 1
fi fi
} }
@ -128,7 +121,7 @@ SPACEINFO() {
function RM() { function RM() {
[[ -z $* ]] && return 1 [[ -z $* ]] && return 1
rm -rf "$*" 2> /dev/null rm -rf "$*" 2> /dev/null
LOGGER "删除文件: [$1]" LOGGER "删除文件: [$1]"
return 0 return 0
} }
@ -151,9 +144,9 @@ function CHECK_ENV() {
while [[ $1 ]];do while [[ $1 ]];do
if [[ -n $(GET_VARIABLE $1 ${Default_Variable} 2> /dev/null) ]] if [[ -n $(GET_VARIABLE $1 ${Default_Variable} 2> /dev/null) ]]
then then
LOGGER "[CHECK_ENV] 检查环境变量 [$1] ... 正常" LOGGER "检查环境变量 [$1] ... 正常"
else else
ECHO r "[CHECK_ENV] 检查环境变量 [$1] ... 错误" ECHO r "检查环境变量 [$1] ... 错误"
fi fi
shift shift
done done
@ -163,11 +156,11 @@ function CHECK_PKG() {
local Result="$(command -v $1 2> /dev/null)" local Result="$(command -v $1 2> /dev/null)"
if [[ -n ${Result} && $? == 0 ]] if [[ -n ${Result} && $? == 0 ]]
then then
LOGGER "[CHECK_PKG] 检查软件包: [$1] ... 正常" LOGGER "检查软件包: [$1] ... 正常"
echo true echo true
return 0 return 0
else else
LOGGER "[CHECK_PKG] 检查软件包: [$1] ... 错误" LOGGER "检查软件包: [$1] ... 错误"
echo false echo false
return 1 return 1
fi fi
@ -183,7 +176,7 @@ function EXIT() {
} }
function ECHO() { function ECHO() {
local Color Quiet_Mode local Color
[[ -z $1 ]] && { [[ -z $1 ]] && {
echo -ne "\n${Grey}[$(date "+%H:%M:%S")]${White} " echo -ne "\n${Grey}[$(date "+%H:%M:%S")]${White} "
} || { } || {
@ -199,25 +192,19 @@ function ECHO() {
esac esac
shift shift
;; ;;
quiet)
Quiet_Mode=1
shift
;;
*) *)
Message="$1" Message="$1"
break break
;; ;;
esac esac
done done
[[ ! ${Quiet_Mode} == 1 ]] && {
echo -e "\n${Grey}[$(date "+%H:%M:%S")]${White}${Color} ${Message}${White}" echo -e "\n${Grey}[$(date "+%H:%M:%S")]${White}${Color} ${Message}${White}"
LOGGER "${Message}" LOGGER "${Message}"
} || LOGGER "[Quiet Mode] ${Message}"
} }
} }
function LOGGER() { function LOGGER() {
[[ -z ${Log_Path} ]] && return 0 [[ -z ${Log_Path} ]] && return
if [[ ! $* =~ (--help|--log) ]] if [[ ! $* =~ (--help|--log) ]]
then then
[[ ! -d ${Log_Path} ]] && mkdir -p ${Log_Path} [[ ! -d ${Log_Path} ]] && mkdir -p ${Log_Path}
@ -227,22 +214,13 @@ function LOGGER() {
} }
function RANDOM() { function RANDOM() {
local Result="$(openssl rand -base64 $1 | md5sum | cut -c 1-$1)" head -n 5 /dev/urandom | md5sum | cut -c 1-$1
if [[ -n ${Result} ]]
then
LOGGER "[RANDOM] $1 Bit 计算结果: [${Result}]"
echo "${Result}"
return 0
else
return 1
fi
} }
function GET_SHA256SUM() { function GET_SHA256SUM() {
local Result="$(sha256sum $1 | cut -c1-$2)" local Result="$(sha256sum $1 2> /dev/null | cut -c1-$2)"
if [[ -n ${Result} ]] if [[ -n ${Result} && $? == 0 ]]
then then
LOGGER "[GET_SHA256SUM] 计算结果: [${Result}]"
echo "${Result}" echo "${Result}"
return 0 return 0
else else
@ -251,8 +229,8 @@ function GET_SHA256SUM() {
} }
function GET_VARIABLE() { function GET_VARIABLE() {
local Result="$(grep "$1=" "$2" | grep -v "#" | awk -F '=' '{print $2}')" local Result="$(grep "$1=" "$2" 2> /dev/null | grep -v "#" | awk -F '=' '{print $2}')"
if [[ -n ${Result} ]] if [[ -n ${Result} && $? == 0 ]]
then then
eval echo "${Result}" eval echo "${Result}"
return 0 return 0
@ -285,7 +263,7 @@ function EDIT_VARIABLE() {
fi fi
;; ;;
rm) rm)
sed -i "/$2/d" $1 sed -i "/$2=/d" $1
if [[ $? == 0 ]] if [[ $? == 0 ]]
then then
LOGGER "[EDIT_VARIABLE] 从 $1 删除环境变量 [$2] ... 成功" LOGGER "[EDIT_VARIABLE] 从 $1 删除环境变量 [$2] ... 成功"
@ -299,17 +277,29 @@ function EDIT_VARIABLE() {
} }
function LOAD_VARIABLE() { function LOAD_VARIABLE() {
while [[ $1 ]];do for i in ${ENV_DEPENDS[@]};do
[[ -s $1 ]] && { local if_ENV="$(GET_VARIABLE ${i} $1)"
if [[ -z ${if_ENV} ]]
then
ECHO r "无法获取环境变量: ${i}"
fi
eval ${i}="${if_ENV}" 2> /dev/null
done
shift && unset i if_ENV
if [[ -s $1 ]]
then
chmod 777 $1 chmod 777 $1
source $1 source $1
} || LOGGER "[LOAD_VARIABLE] 未检测到环境变量列表: [$1]" else
shift LOGGER "警告: 未检测到环境变量列表: $1"
done fi
[[ -z ${TARGET_PROFILE} ]] && TARGET_PROFILE="$(jsonfilter -i /etc/board.json -e '@.model.id' | tr ',' '_')"
[[ -z ${TARGET_PROFILE} ]] && ECHO r "获取设备名称失败!" && EXIT 1 [[ -z ${TARGET_PROFILE} ]] && eval TARGET_PROFILE="$(jq .model.id /etc/board.json 2> /dev/null)"
[[ -z ${Github} ]] && ECHO r "Github 地址获取失败!" && EXIT 1 [[ -z ${TARGET_PROFILE} || ${TARGET_PROFILE} == null ]] && ECHO r "当前设备名称获取失败!" && EXIT 1
[[ -z ${OP_VERSION} ]] && OP_VERSION="未知" [[ -z ${OP_VERSION} ]] && OP_VERSION="未知"
DISTRIB_TARGET="$(GET_VARIABLE DISTRIB_TARGET /etc/openwrt_release)"
TARGET_BOARD="$(echo ${DISTRIB_TARGET} | cut -d '/' -f1)"
TARGET_SUBTARGET="$(echo ${DISTRIB_TARGET} | cut -d '/' -f2)"
Firmware_Author="${Github##*com/}" Firmware_Author="${Github##*com/}"
Github_Release="${Github}/releases/download/AutoUpdate" Github_Release="${Github}/releases/download/AutoUpdate"
Github_Raw="https://raw.githubusercontent.com/${Firmware_Author}/master" Github_Raw="https://raw.githubusercontent.com/${Firmware_Author}/master"
@ -318,22 +308,23 @@ function LOAD_VARIABLE() {
x86) x86)
[[ -z ${x86_Boot_Method} ]] && { [[ -z ${x86_Boot_Method} ]] && {
[ -d /sys/firmware/efi ] && { [ -d /sys/firmware/efi ] && {
x86_Boot_Method=UEFI x86_Boot_Method="UEFI"
} || x86_Boot_Method=BIOS } || x86_Boot_Method="BIOS"
} }
;; ;;
esac esac
[[ ! -d ${Tmp_Path} ]] && mkdir -p ${Tmp_Path}
} }
function CHANGE_GITHUB() { function CHANGE_GITHUB() {
[[ ! $1 =~ https://github.com/ ]] && { [[ ! $1 =~ https://github.com/ ]] && {
ECHO r "Github 地址输入有误,正确示例: https://github.com/Hyy2001X/AutoBuild-Actions" ECHO r "Github 地址格式错误,正确地址示例: https://github.com/Hyy2001X/AutoBuild-Actions"
EXIT 1 EXIT 1
} }
UCI_Github=$(uci get autoupdate.@common[0].github 2> /dev/null) UCI_Github="$(uci get autoupdate.@common[0].github 2> /dev/null)"
[[ -n ${UCI_Github} && ! ${UCI_Github} == $1 ]] && { [[ -n ${UCI_Github} && ! ${UCI_Github} == $1 ]] && {
uci set autoupdate.@common[0].github=$1 2> /dev/null uci set autoupdate.@common[0].github="$1" 2> /dev/null
LOGGER "[CHANGE_GITHUB] UCI 配置已设定为 [$1]" LOGGER "UCI 地址已修改为 [$1]"
} }
[[ ! ${Github} == $1 ]] && { [[ ! ${Github} == $1 ]] && {
EDIT_VARIABLE edit ${Custom_Variable} Github $1 EDIT_VARIABLE edit ${Custom_Variable} Github $1
@ -345,20 +336,19 @@ function CHANGE_GITHUB() {
fi fi
REMOVE_CACHE REMOVE_CACHE
} }
EXIT 0 EXIT
} }
function CHANGE_BOOT() { function CHANGE_BOOT() {
[[ -z $1 ]] && SHELL_HELP
case "$1" in case "$1" in
UEFI | BIOS) UEFI | BIOS)
EDIT_VARIABLE edit ${Custom_Variable} x86_Boot_Method $1 EDIT_VARIABLE edit ${Custom_Variable} x86_Boot_Method $1
ECHO r "警告: 更换引导方式后更新固件后可能导致设备无法正常启动!" ECHO r "警告: 修改此设置后更新固件后可能导致设备无法启动!"
ECHO y "固件引导格式已指定为: [$1]" ECHO y "固件引导格式已指定为: [$1]"
EXIT 0 EXIT 0
;; ;;
*) *)
ECHO r "错误的参数: [$1],支持的启动方式: [UEFI/BIOS]" ECHO r "错误的参数: [$1],当前支持的选项: [UEFI/BIOS]"
EXIT 1 EXIT 1
;; ;;
esac esac
@ -373,22 +363,22 @@ function UPDATE_SCRIPT() {
fi fi
ECHO "脚本保存路径: [$1]" ECHO "脚本保存路径: [$1]"
DOWNLOADER --file-name AutoUpdate.sh --no-url-name --dl ${DOWNLOADERS} --url $2 --path ${Tmp_Path} --timeout 5 --type 脚本 DOWNLOADER --file-name AutoUpdate.sh --no-url-name --dl ${DOWNLOADERS} --url $2 --path ${Tmp_Path} --timeout 5 --type 脚本
if [[ -s ${Tmp_Path}/AutoUpdate.sh ]];then if [[ $? == 0 && -s ${Tmp_Path}/AutoUpdate.sh ]];then
chmod +x ${Tmp_Path}/AutoUpdate.sh chmod +x ${Tmp_Path}/AutoUpdate.sh
Script_Version=$(awk -F '=' '/Version/{print $2}' ${Tmp_Path}/AutoUpdate.sh | awk 'NR==1') Script_Version="$(awk -F '=' '/Version/{print $2}' ${Tmp_Path}/AutoUpdate.sh | awk 'NR==1')"
Banner_Version=$(egrep -o "V[0-9.]+" /etc/banner) Banner_Version="$(egrep -o "V[0-9.]+" /etc/banner)"
mv -f ${Tmp_Path}/AutoUpdate.sh $1 2> /dev/null mv -f ${Tmp_Path}/AutoUpdate.sh $1 2> /dev/null
[[ $? == 0 ]] && { [[ $? == 0 ]] && {
[[ -n ${Banner_Version} && $1 == /bin ]] && sed -i "s?${Banner_Version}?${Script_Version}?g" /etc/banner [[ -n ${Banner_Version} && $1 == /bin ]] && sed -i "s?${Banner_Version}?${Script_Version}?g" /etc/banner
ECHO y "[${Banner_Version} > ${Script_Version}] AutoUpdate 脚本更新成功!" ECHO y "[${Banner_Version} > ${Script_Version}] AutoUpdate.sh 更新成功!"
REMOVE_CACHE REMOVE_CACHE
EXIT 0 EXIT 0
} || { } || {
ECHO r "无法移动 AutoUpdate 脚本到指定的路径!" ECHO r "移动 AutoUpdate.sh 到指定路径时发生错误 ..."
EXIT 1 EXIT 1
} }
else else
ECHO r "AutoUpdate 脚本下载失败!" ECHO r "AutoUpdate.sh 下载失败!"
EXIT 1 EXIT 1
fi fi
} }
@ -399,8 +389,8 @@ function CHECK_DEPENDS() {
printf "\n%-28s %-5s\n" 软件包 检测结果 printf "\n%-28s %-5s\n" 软件包 检测结果
while [[ $1 ]];do while [[ $1 ]];do
if [[ $1 =~ : ]];then if [[ $1 =~ : ]];then
[[ $(echo $1 | cut -d ":" -f1) == ${TARGET_BOARD} ]] && { [[ $(echo $1 | cut -d : -f1) == ${TARGET_BOARD} ]] && {
PKG="$(echo "$1" | cut -d ":" -f2)" PKG="$(echo $1 | cut -d : -f2)"
printf "%-25s %-5s\n" ${PKG} $(CHECK_PKG ${PKG}) printf "%-25s %-5s\n" ${PKG} $(CHECK_PKG ${PKG})
} }
else else
@ -408,7 +398,7 @@ function CHECK_DEPENDS() {
fi fi
shift shift
done done
ECHO y "AutoUpdate 依赖检测结束,请尝试手动安装测结果为 [false] 的项目!" ECHO y "AutoUpdate 运行环境检测结束,请尝试手动安装测结果为 [false] 的软件包!"
} }
function CHECK_TIME() { function CHECK_TIME() {
@ -423,51 +413,59 @@ function CHECK_TIME() {
} }
function ANALYZE_API() { function ANALYZE_API() {
[[ -z ${Github_Release} ]] && {
ECHO r "Github API 地址为空!"
EXIT 1
}
local API_Cache=${Tmp_Path}/API_Cache local API_Cache=${Tmp_Path}/API_Cache
if [[ $(CHECK_TIME ${API_File} 1) == false ]] if [[ $(CHECK_TIME ${API_File} 1) == false ]]
then then
DOWNLOADER --path ${Tmp_Path} --file-name API_Cache --dl ${DOWNLOADERS} --url "$(URL_X ${Github_Release}/API G@@1 F@@1) ${Github_API}@@1 " --no-url-name --timeout 5 --type "API" --quiet DOWNLOADER --path ${Tmp_Path} --file-name API_Cache --dl ${DOWNLOADERS} --url "$(URL_X ${Github_Release}/API G@@1 F@@1) ${Github_API}@@1 " --no-url-name --timeout 5
[[ ! $? == 0 || -z $(cat ${API_Cache} 2> /dev/null) ]] && { [[ ! $? == 0 || -z $(cat ${API_Cache} 2> /dev/null) ]] && {
ECHO r "Github API 请求错误,请检查网络后试!" ECHO r "Github API 请求错误,请检查网络后试!"
EXIT 2 EXIT 2
} }
fi
RM ${API_File} && touch -a ${API_File} RM ${API_File} && touch -a ${API_File}
LOGGER "开始解析 Github API ..." LOGGER "开始解析 Github API ..."
for i in $(seq 0 500);do for i in $(seq 0 $(jq ".assets | length" ${API_Cache} 2> /dev/null));do
name=$(jsonfilter -i ${API_Cache} -e '@["assets"]' | jsonfilter -e '@['""$i""'].name' 2> /dev/null) eval name=$(jq ".assets[${i}].name" ${API_Cache} 2> /dev/null)
[[ ! $? == 0 ]] && break [[ ${name} == null ]] && continue
if [[ ${name} =~ "AutoBuild-${OP_REPO}-${TARGET_PROFILE}" || ${name} =~ Update_Logs.json ]] case ${name} in
then AutoBuild-${OP_REPO}-${TARGET_PROFILE}-* | Update_Logs.json)
local format=$(echo ${name} | egrep -o "\-[0-9a-z]{5}.[a-z].+" | egrep -o "\..+" | cut -c2-10) LOGGER "可用固件/日志: ${name}"
local version=$(echo ${name} | egrep -o "R[0-9.]+-[0-9]+") eval format=$(echo ${name} | egrep -o "\-[0-9a-z]{5}.[a-z].+" | egrep -o "\..+" | cut -c2-10)
local url=$(jsonfilter -i ${API_Cache} -e '@["assets"]' | jsonfilter -e '@['""$i""'].browser_download_url' 2> /dev/null) eval version=$(echo ${name} | egrep -o "R[0-9.]+-[0-9]+")
local size=$(jsonfilter -i ${API_Cache} -e '@["assets"]' | jsonfilter -e '@['""$i""'].size' 2> /dev/null | awk '{a=$1/1048576} {printf("%.2f\n",a)}') eval sha256=$(echo ${name} | egrep -o "\-[a-z0-9]+" | cut -c2-6 | awk 'END{print}')
local date=$(jsonfilter -i ${API_Cache} -e '@["assets"]' | jsonfilter -e '@['""$i""'].updated_at' 2> /dev/null | sed 's/[-:TZ]//g') eval browser_download_url=$(jq ".assets[${i}].browser_download_url" ${API_Cache} 2> /dev/null)
local count=$(jsonfilter -i ${API_Cache} -e '@["assets"]' | jsonfilter -e '@['""$i""'].download_count' 2> /dev/null) eval size=$(jq ".assets[${i}].size" ${API_Cache} 2> /dev/null | awk '{a=$1/1048576} {printf("%.2f\n",a)}')
local sha256=$(echo ${name} | egrep -o "\-[a-z0-9]+" | cut -c2-6 | awk 'END{print}') eval updated_at=$(jq ".assets[${i}].updated_at" ${API_Cache} 2> /dev/null | sed 's/[-:TZ]//g')
[[ -z ${name} ]] && name="-" eval download_count=$(jq ".assets[${i}].download_count" ${API_Cache} 2> /dev/null)
[[ -z ${format} ]] && format="-" [[ -z ${version} || ${version} == null ]] && version="-"
[[ -z ${version} ]] && version="-" [[ -z ${browser_download_url} || ${browser_download_url} == null ]] && continue
[[ -z ${url} ]] && url="-" [[ -z ${size} || ${size} == null || ${size} == 0 ]] && size="-" || size="${size}MB"
[[ -z ${size} ]] && size="-" || size="${size}MB" [[ -z ${updated_at} || ${updated_at} == null ]] && updated_at="-"
[[ -z ${date} ]] && date="-" [[ -z ${download_count} || ${download_count} == null ]] && download_count="-"
[[ -z ${count} ]] && count="-" [[ -z ${sha256} || ${sha256} == null ]] && sha256="-"
[[ -z ${sha256} ]] && sha256="-" printf "%-75s %-15s %-5s %-8s %-20s %-10s %-15s %s\n" ${name} ${format} ${download_count} ${sha256} ${version} ${updated_at} ${size} ${browser_download_url} | egrep -v "${REGEX_Skip_Format}" >> ${API_File}
printf "%-75s %-15s %-5s %-8s %-20s %-10s %-15s %s\n" ${name} ${format} ${count} ${sha256} ${version} ${date} ${size} ${url} | egrep -v "${REGEX_Format}" >> ${API_File} ;;
fi esac
done done
unset i unset i
fi if [[ -z $(cat ${API_File} 2> /dev/null) ]]
[[ ! -s ${API_File} ]] && { then
ECHO r "Github API 解析内容为空,请稍候再试!" ECHO r "Github API 解析内容为空!"
return 1 return 1
} || return 0 else
LOGGER "Github API 解析结束!"
return 0
fi
} }
function GET_CLOUD_LOG() { function GET_CLOUD_LOG() {
local Result Version local Result Version
[[ ! $(cat ${API_File} 2> /dev/null) =~ Update_Logs.json ]] && { [[ ! $(cat ${API_File} 2> /dev/null) =~ Update_Logs.json ]] && {
LOGGER "未检测到已部署的云端日志!" LOGGER "未检测到已部署的云端日志,跳过下载 ..."
return 1 return 1
} }
case "$1" in case "$1" in
@ -477,20 +475,19 @@ function GET_CLOUD_LOG() {
[Cc]loud) [Cc]loud)
Version="$(GET_FW_INFO 5)" Version="$(GET_FW_INFO 5)"
;; ;;
-v) *)
shift
Version="$1" Version="$1"
;; ;;
esac esac
[[ $(CHECK_TIME ${Tmp_Path}/Update_Logs.json 1) == false ]] && { [[ $(CHECK_TIME ${Tmp_Path}/Update_Logs.json 1) == false ]] && {
DOWNLOADER --path ${Tmp_Path} --file-name Update_Logs.json --dl ${DOWNLOADERS} --url "$(URL_X ${Github_Release} G@@1)" --timeout 5 --type 固件更新日志 --quiet DOWNLOADER --path ${Tmp_Path} --file-name Update_Logs.json --dl ${DOWNLOADERS} --url "$(URL_X ${Github_Release} G@@1)" --timeout 5
} }
[[ -s ${Tmp_Path}/Update_Logs.json ]] && { [[ -s ${Tmp_Path}/Update_Logs.json ]] && {
Result="$(jsonfilter -i ${Tmp_Path}/Update_Logs.json -e '@["'""${TARGET_PROFILE}""'"]["'""${Version}""'"]' 2> /dev/null)" Result="$(jq '."'"${TARGET_PROFILE}"'"."'"${Version}"'"' ${Tmp_Path}/Update_Logs.json)"
[[ -n ${Result} ]] && { [[ -n ${Result} && ${Result} != null ]] && {
echo -e "\n${Grey}${Version} 固件更新日志:" echo -e "\n${Grey}${Version} 固件更新日志:"
echo -e "\n${Green}${Result}${White}" echo -e "\n${Green}${Result}${White}"
} || LOGGER "未获取到当前固件的日志信息!" } || LOGGER "未获取到 [${Version}] 固件的日志信息!"
} }
} }
@ -535,12 +532,11 @@ function UPGRADE() {
EXIT 1 EXIT 1
} }
Firmware_Path="${Tmp_Path}" Firmware_Path="${Tmp_Path}"
Upgrade_Option="sysupgrade -q" Upgrade_Option="$(command -v sysupgrade) -q"
MSG="更新固件" MSG="更新固件"
while [[ $1 ]];do while [[ $1 ]];do
case "$1" in case "$1" in
-T | --test) -T)
Test_Mode=1
Special_Commands="${Special_Commands} [测试模式]" Special_Commands="${Special_Commands} [测试模式]"
;; ;;
-P | --proxy) -P | --proxy)
@ -557,24 +553,21 @@ function UPGRADE() {
;; ;;
-D) -D)
DOWNLOADERS="$2" DOWNLOADERS="$2"
Special_Commands="${Special_Commands} [${DOWNLOADERS}]" Special_Commands="${Special_Commands} [$1 ${DOWNLOADERS}]"
shift shift
;; ;;
-F | --force-write) -F | --force-flash)
[[ -n ${Force_Mode} ]] && SHELL_HELP Force_Flash=1
Only_Force_Write=1
Special_Commands="${Special_Commands} [强制刷写]" Special_Commands="${Special_Commands} [强制刷写]"
Upgrade_Option="${Upgrade_Option} -F"
;; ;;
--decompress) --decompress)
Special_Commands="${Special_Commands} [解压固件]" Special_Commands="${Special_Commands} [优先解压固件]"
Decompress_Mode=1 Decompress_Mode=1
;; ;;
-f) -f)
[[ -n ${Only_Force_Write} ]] && SHELL_HELP
Force_Mode=1 Force_Mode=1
Force_Flash=1
Special_Commands="${Special_Commands} [强制模式]" Special_Commands="${Special_Commands} [强制模式]"
Upgrade_Option="${Upgrade_Option} -F"
;; ;;
-n) -n)
Upgrade_Option="${Upgrade_Option} -n" Upgrade_Option="${Upgrade_Option} -n"
@ -586,11 +579,11 @@ function UPGRADE() {
shift shift
;; ;;
--skip-verify) --skip-verify)
Skip_Verify=1 Skip_Verify_Mode=1
Special_Commands="${Special_Commands} [跳过 SHA256 验证]" Special_Commands="${Special_Commands} [跳过 SHA256 验证]"
;; ;;
-u) -u)
AutoUpdate_Mode=1 Nobody_Mode=1
Special_Commands="${Special_Commands} [定时更新]" Special_Commands="${Special_Commands} [定时更新]"
;; ;;
--verbose) --verbose)
@ -602,16 +595,15 @@ function UPGRADE() {
esac esac
shift shift
done done
LOGGER "固件更新指令: [${Upgrade_Option}]" [[ ${Force_Flash} == 1 ]] && Upgrade_Option="${Upgrade_Option} -F"
[[ -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}"
if [[ -z ${Proxy_Type} ]];then if [[ -z ${Proxy_Type} ]]
then
[[ $(GOOGLE_CHECK) != true ]] && { [[ $(GOOGLE_CHECK) != true ]] && {
ECHO r "Google 连接测试失败,优先使用镜像加速下载!" ECHO r "Google 连接错误,优先使用镜像加速下载!"
Proxy_Type="All" Proxy_Type="All"
} }
else
LOGGER "跳过 Google 连接测试 ..."
fi fi
ECHO "正在检查固件版本更新 ..." ECHO "正在检查固件版本更新 ..."
ANALYZE_API ANALYZE_API
@ -624,20 +616,21 @@ function UPGRADE() {
CLOUD_FW_Size=$(GET_FW_INFO 7) CLOUD_FW_Size=$(GET_FW_INFO 7)
CLOUD_FW_Url=$(GET_FW_INFO 8) CLOUD_FW_Url=$(GET_FW_INFO 8)
[[ -z ${CLOUD_FW_Name} || -z ${CLOUD_FW_Url} ]] && { [[ -z ${CLOUD_FW_Name} || -z ${CLOUD_FW_Url} ]] && {
ECHO r "云端固件信息获取失败!" ECHO r "检查更新失败,请检查网络后再试!"
EXIT 2 EXIT 2
} }
[[ ${CLOUD_FW_Version} == ${OP_VERSION} ]] && { [[ ${CLOUD_FW_Version} == ${OP_VERSION} ]] && {
CURRENT_Type="${Yellow} [已是最新]${White}" CURRENT_Type="${Yellow} [已是最新]${White}"
Upgrade_Stopped=1 Stop_Code=1
} || { } || {
[[ $(echo ${CLOUD_FW_Version} | cut -d "-" -f2) -gt $(echo ${OP_VERSION} | cut -d "-" -f2) ]] && CURRENT_Type="${Green} [可更新]${White}" [[ $(echo ${CLOUD_FW_Version} | cut -d - -f2) -gt $(echo ${OP_VERSION} | cut -d - -f2) ]] && CHECKED_Type="${Green} [可更新]${White}"
[[ $(echo ${CLOUD_FW_Version} | cut -d "-" -f2) -lt $(echo ${OP_VERSION} | cut -d "-" -f2) ]] && { [[ $(echo ${CLOUD_FW_Version} | cut -d - -f2) -lt $(echo ${OP_VERSION} | cut -d - -f2) ]] && {
CHECKED_Type="${Red} [旧版本]${White}" CHECKED_Type="${Red} [旧版本]${White}"
Upgrade_Stopped=2 Stop_Code=2
} }
} }
cat <<EOF echo -e "
${Grey}### 系统 & 云端固件详情 ###${White}
设备名称: ${TARGET_PROFILE} 设备名称: ${TARGET_PROFILE}
内核版本: $(uname -sr) 内核版本: $(uname -sr)
@ -648,11 +641,11 @@ $(echo -e "云端固件版本: ${CLOUD_FW_Version}${CHECKED_Type}")
云端固件名称: ${CLOUD_FW_Name} 云端固件名称: ${CLOUD_FW_Name}
云端固件体积: ${CLOUD_FW_Size} 云端固件体积: ${CLOUD_FW_Size}
固件下载次数: ${CLOUD_FW_Count} 固件下载次数: ${CLOUD_FW_Count}"
EOF
if [[ ${Force_Mode} != 1 ]] if [[ ${Force_Mode} != 1 ]]
then then
if [[ $(MEMINFO 3) -lt $(echo ${CLOUD_FW_Size} | awk -F '.' '{print $1}') ]] (sync && echo 3 > /proc/sys/vm/drop_caches) 2> /dev/null
if [[ $(MEMINFO All) -lt $(echo ${CLOUD_FW_Size} | awk -F '.' '{print $1}') ]]
then then
ECHO r "内存空间不足 [${CLOUD_FW_Size}],请尝试设置 Swap 交换分区或重启设备后再试!" ECHO r "内存空间不足 [${CLOUD_FW_Size}],请尝试设置 Swap 交换分区或重启设备后再试!"
EXIT EXIT
@ -662,18 +655,18 @@ EOF
ECHO r "设备空间不足 [${CLOUD_FW_Size}],请尝试更换固件保存路径后再试!" ECHO r "设备空间不足 [${CLOUD_FW_Size}],请尝试更换固件保存路径后再试!"
EXIT EXIT
fi fi
else
LOGGER "[Force Mode] 跳过可用资源测试"
fi fi
GET_CLOUD_LOG -v ${CLOUD_FW_Version} GET_CLOUD_LOG ${CLOUD_FW_Version}
case "${Upgrade_Stopped}" in case "${Stop_Code}" in
1 | 2) 1 | 2)
[[ ${AutoUpdate_Mode} == 1 ]] && ECHO y "当前固件 [${OP_VERSION}] 已是最新版本,无需更新!" && EXIT 0 [[ ${Nobody_Mode} == 1 ]] && ECHO y "当前固件 [${OP_VERSION}] 已是最新版本,无需更新!" && EXIT 0
[[ ${Upgrade_Stopped} == 1 ]] && err_MSG="当前固件 [${OP_VERSION}] 已是最新版本" || err_MSG="云端固件版本为旧版" [[ ${Stop_Code} == 1 ]] && err_MSG="当前固件 [${OP_VERSION}] 已是最新版本" || err_MSG="云端固件版本为旧版"
[[ ! ${Force_Mode} == 1 ]] && { [[ ! ${Force_Mode} == 1 ]] && {
ECHO && read -p "${err_MSG},是否继续更新固件?[Y/n]:" Choose ECHO && read -p "${err_MSG},是否继续更新固件?[Y/n]:" Choose
} || Choose=Y } || Choose=Y
[[ ! ${Choose} =~ [Yy] ]] && { [[ ! ${Choose} =~ [Yy] ]] && {
ECHO x "已取消固件更新操作,即将退出更新程序 ..."
sleep 1
EXIT 0 EXIT 0
} }
;; ;;
@ -691,27 +684,29 @@ EOF
;; ;;
esac esac
DOWNLOADER --file-name ${CLOUD_FW_Name} --no-url-name --dl ${DOWNLOADERS} --url ${URL} --path ${Firmware_Path} --timeout 15 --type 固件 DOWNLOADER --file-name ${CLOUD_FW_Name} --no-url-name --dl ${DOWNLOADERS} --url ${URL} --path ${Firmware_Path} --timeout 15 --type 固件
[[ ! -s ${Firmware_Path}/${CLOUD_FW_Name} ]] && EXIT 1 [[ ! -s ${Firmware_Path}/${CLOUD_FW_Name} || $? != 0 ]] && {
if [[ ! ${Skip_Verify} == 1 ]];then ECHO r "固件下载失败,请检查网络后再试!"
EXIT 1
}
if [[ ! ${Skip_Verify_Mode} == 1 ]];then
[[ $(GET_SHA256SUM ${Firmware_Path}/${CLOUD_FW_Name} 5) != ${CLOUD_FW_SHA256} ]] && { [[ $(GET_SHA256SUM ${Firmware_Path}/${CLOUD_FW_Name} 5) != ${CLOUD_FW_SHA256} ]] && {
ECHO r "SHA256 校验失败,请检查网络后重试!" ECHO r "SHA256 校验失败!"
EXIT 2 EXIT 2
} }
LOGGER "固件 SHA256 比对通过!" ECHO y "固件完整性校验通过,即将开始更新固件 ..."
else
LOGGER "跳过 SHA256 校验 ..."
fi fi
case "${CLOUD_FW_Format}" in case "${CLOUD_FW_Format}" in
img.gz) img.gz)
if [[ ${Decompress_Mode} == 1 ]];then if [[ ${Decompress_Mode} == 1 ]]
ECHO "正在解压 [${CLOUD_FW_Format}] 固件 ..." then
ECHO "正在解压 gizp 格式固件 ..."
gzip -d -q -f -c ${Firmware_Path}/${CLOUD_FW_Name} > ${Firmware_Path}/$(echo ${CLOUD_FW_Name} | sed -r 's/(.*).gz/\1/') gzip -d -q -f -c ${Firmware_Path}/${CLOUD_FW_Name} > ${Firmware_Path}/$(echo ${CLOUD_FW_Name} | sed -r 's/(.*).gz/\1/')
[[ ! $? == 0 ]] && { [[ ! $? == 0 ]] && {
ECHO r "固件解压失败!" ECHO r "固件解压失败!"
EXIT 2 EXIT 2
} || { } || {
CLOUD_FW_Name="$(echo ${CLOUD_FW_Name} | sed -r 's/(.*).gz/\1/')" CLOUD_FW_Name="$(echo ${CLOUD_FW_Name} | sed -r 's/(.*).gz/\1/')"
LOGGER "固件解压成功,固件已解压到: [${Firmware_Path}/${CLOUD_FW_Name}]" LOGGER "固件已解压到: [${Firmware_Path}/${CLOUD_FW_Name}]"
} }
else else
[[ $(CHECK_PKG gzip) == true ]] && { [[ $(CHECK_PKG gzip) == true ]] && {
@ -747,7 +742,7 @@ function DO_UPGRADE() {
} }
function DOWNLOADER() { function DOWNLOADER() {
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 local u E DL_Downloader DL_Name DL_URL DL_Path DL_Retries DL_Timeout DL_Type DL_Final No_URL_Name Print_Mode DL_Retires_All DL_URL_Final
while [[ $1 ]];do while [[ $1 ]];do
case "$1" in case "$1" in
--dl) --dl)
@ -773,7 +768,7 @@ function DOWNLOADER() {
done done
[[ -z ${DL_Downloader} ]] && { [[ -z ${DL_Downloader} ]] && {
ECHO r "没有可用的下载器!" ECHO r "没有可用的下载器!"
EXIT 1 return 1
} }
;; ;;
--file-name) --file-name)
@ -802,7 +797,6 @@ function DOWNLOADER() {
;; ;;
--no-url-name) --no-url-name)
shift shift
LOGGER "[DOWNLOADER] Enabled No-Url-Filename Mode"
No_URL_Name=1 No_URL_Name=1
;; ;;
--path) --path)
@ -840,14 +834,9 @@ function DOWNLOADER() {
[[ ! $1 =~ '--' ]] && shift [[ ! $1 =~ '--' ]] && shift
done done
;; ;;
--quiet)
shift
Quiet_Mode=quiet
;;
--print) --print)
shift shift
Print_Mode=1 Print_Mode=1
Quiet_Mode=quiet
;; ;;
*) *)
shift shift
@ -879,9 +868,9 @@ function DOWNLOADER() {
for u in $(seq ${DL_Retries});do for u in $(seq ${DL_Retries});do
sleep 1 sleep 1
[[ -z ${Failed} ]] && { [[ -z ${Failed} ]] && {
ECHO ${Quiet_Mode} "正在下载${DL_Type},请耐心等待 ..." [[ -n ${DL_Type} ]] && ECHO "正在下载${DL_Type},请耐心等待 ..."
} || { } || {
ECHO ${Quiet_Mode} "尝试重新下载${DL_Type},剩余重试次数: [${DL_Retires_All}]" [[ -n ${DL_Type} ]] && ECHO "尝试重新下载,剩余重试次数: [${DL_Retires_All}]"
} }
if [[ -z ${DL_Name} ]];then if [[ -z ${DL_Name} ]];then
DL_Name="${DL_URL_Final##*/}" DL_Name="${DL_URL_Final##*/}"
@ -894,15 +883,15 @@ function DOWNLOADER() {
[[ -s ${DL_Path}/${DL_Name} ]] && { [[ -s ${DL_Path}/${DL_Name} ]] && {
RM ${DL_Path}/${DL_Name} RM ${DL_Path}/${DL_Name}
} }
LOGGER "执行下载: [${DL_Final}]" LOGGER "执行下载指令: [${DL_Final}]"
${DL_Final} ${DL_Final}
if [[ $? == 0 && -s ${DL_Path}/${DL_Name} ]];then if [[ $? == 0 && -s ${DL_Path}/${DL_Name} ]];then
ECHO y ${Quiet_Mode} "${DL_Type}下载成功!" touch -a ${DL_Path}/${DL_Name}
[[ ${Print_Mode} == 1 ]] && { [[ ${Print_Mode} == 1 ]] && {
cat ${DL_Path}/${DL_Name} 2> /dev/null cat ${DL_Path}/${DL_Name} 2> /dev/null
RM ${DL_Path}/${DL_Name} RM ${DL_Path}/${DL_Name}
} return 0
touch -a ${DL_Path}/${DL_Name} 2> /dev/null } || [[ -n ${DL_Type} ]] && ECHO y "${DL_Type}下载成功!"
return 0 return 0
else else
[[ -z ${Failed} ]] && local Failed=1 [[ -z ${Failed} ]] && local Failed=1
@ -910,7 +899,7 @@ function DOWNLOADER() {
if [[ ${u} == ${DL_Retries} ]];then if [[ ${u} == ${DL_Retries} ]];then
break 1 break 1
else else
ECHO r ${Quiet_Mode} "下载失败!" [[ -n ${DL_Type} ]] && ECHO r "${DL_Type}下载失败!"
u=$((${u} + 1)) u=$((${u} + 1))
fi fi
fi fi
@ -918,7 +907,7 @@ function DOWNLOADER() {
E=$((${E} + 1)) E=$((${E} + 1))
done done
RM ${DL_Path}/${DL_Name} RM ${DL_Path}/${DL_Name}
ECHO r ${Quiet_Mode} "${DL_Type}下载失败,请检查网络后重试!" [[ -n ${DL_Type} ]] && ECHO r "${DL_Type}下载失败!"
return 1 return 1
} }
@ -967,6 +956,7 @@ function LOG() {
URL_X() { URL_X() {
# URL_X https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh F@@1 G@@1 X@@1 # URL_X https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh F@@1 G@@1 X@@1
local URL=$1 Type URL_Final local URL=$1 Type URL_Final
[[ ${URL} =~ raw.githubusercontent.com ]] && Type=raw [[ ${URL} =~ raw.githubusercontent.com ]] && Type=raw
[[ ${URL} =~ releases/download ]] && Type=release [[ ${URL} =~ releases/download ]] && Type=release
[[ ${URL} =~ codeload.github.com ]] && Type=codeload [[ ${URL} =~ codeload.github.com ]] && Type=codeload
@ -1030,14 +1020,8 @@ function GOOGLE_CHECK() {
} }
function AutoUpdate_Main() { function AutoUpdate_Main() {
if [[ ! $1 =~ (-H|--help) ]];then if [[ ! $1 =~ (-H|--help|--chk|--log) ]];then
[[ ! -f ${Default_Variable} ]] && {
ECHO r "脚本运行环境检测失败,无法正常运行脚本!"
EXIT 1
}
[[ ! -f ${Custom_Variable} ]] && touch ${Custom_Variable}
LOAD_VARIABLE ${Default_Variable} ${Custom_Variable} LOAD_VARIABLE ${Default_Variable} ${Custom_Variable}
[[ ! -d ${Tmp_Path} ]] && mkdir -p ${Tmp_Path}
fi fi
[[ -z $* ]] && UPGRADE $* [[ -z $* ]] && UPGRADE $*
@ -1083,16 +1067,22 @@ function AutoUpdate_Main() {
while [[ $1 ]];do while [[ $1 ]];do
case "$1" in case "$1" in
-n | -f | -u | -T | -P | --proxy | -F | --force-write | --verbose | --decompress | --skip-verify | -D | --path) -n | -f | -u | -T | -P | --proxy | -F | --force-flash | --verbose | --decompress | --skip-verify | -D | --path)
UPGRADE $* UPGRADE $*
EXIT EXIT
;; ;;
--api)
REMOVE_CACHE
ANALYZE_API > /dev/null 2>&1
[[ $? == 0 ]] && cat ${API_File}
EXIT
;;
--backup) --backup)
local FILE="backup-$(uname -n)-$(date +%Y-%m-%d)-$(RANDOM 5).tar.gz" local FILE="backup-$(uname -n)-$(date +%Y-%m-%d)-$(RANDOM 5).tar.gz"
shift shift
[[ $# -gt 1 ]] && SHELL_HELP [[ $# -gt 1 ]] && SHELL_HELP
[[ -z $1 ]] && { [[ -z $1 ]] && {
FILE=$(pwd)/${FILE} FILE="$(pwd)/${FILE}"
} || { } || {
if [[ ! -d $1 ]];then if [[ ! -d $1 ]];then
mkdir -p $1 || { mkdir -p $1 || {
@ -1100,10 +1090,10 @@ function AutoUpdate_Main() {
EXIT 1 EXIT 1
} }
fi fi
FILE=$1/${FILE} FILE="$1/${FILE}"
} }
ECHO "正在备份系统文件到 [${FILE}] ..." ECHO "正在备份系统文件到 [${FILE}] ..."
sysupgrade -b "${FILE}" > /dev/null 2>&1 $(command -v sysupgrade) -b "${FILE}" > /dev/null 2>&1
[[ $? == 0 ]] && { [[ $? == 0 ]] && {
ECHO y "备份文件创建成功!" ECHO y "备份文件创建成功!"
EXIT 0 EXIT 0
@ -1116,15 +1106,15 @@ function AutoUpdate_Main() {
REMOVE_CACHE REMOVE_CACHE
EXIT EXIT
;; ;;
--check) --chk)
shift shift
CHECK_DEPENDS bash uclient-fetch curl wget openssl jsonfilter expr CHECK_DEPENDS bash uclient-fetch curl wget wget-ssl jq expr sysupgrade
[[ $(NETWORK_CHECK www.baidu.com 2) == false ]] && { [[ $(NETWORK_CHECK www.baidu.com 2) == false ]] && {
ECHO r "基础网络连接错误!" ECHO r "网络连接错误!"
} || ECHO y "基础网络连接正常!" }
[[ $(GOOGLE_CHECK) == false ]] && { [[ $(GOOGLE_CHECK) == false ]] && {
ECHO r "Google 连接错误!" ECHO r "Google 连接错误!"
} || ECHO y "Google 连接正常!" }
CHECK_ENV ${ENV_DEPENDS[@]} CHECK_ENV ${ENV_DEPENDS[@]}
EXIT EXIT
;; ;;
@ -1163,7 +1153,7 @@ function AutoUpdate_Main() {
then then
GET_CLOUD_LOG local GET_CLOUD_LOG local
else else
GET_CLOUD_LOG -v $* GET_CLOUD_LOG $*
fi fi
EXIT EXIT
;; ;;
@ -1187,7 +1177,7 @@ function AutoUpdate_Main() {
case "$1" in case "$1" in
[Cc]loud) [Cc]loud)
Script_URL="$(URL_X ${Github_Raw}/Scripts/AutoUpdate.sh G@@1)" Script_URL="$(URL_X ${Github_Raw}/Scripts/AutoUpdate.sh G@@1)"
DOWNLOADER --dl ${DOWNLOADERS} --url ${Script_URL} --path /tmp --print | egrep -o "V[0-9].+" DOWNLOADER --dl ${DOWNLOADERS} --url ${Script_URL} --path /tmp --print --type 脚本 | egrep -o "V[0-9].+"
;; ;;
*) *)
SHELL_HELP SHELL_HELP
@ -1202,8 +1192,8 @@ function AutoUpdate_Main() {
EXIT 1 EXIT 1
} }
Script_Path=/bin Script_Path=/bin
[[ -n ${Custom_Path} ]] && Script_Path=${Custom_Path} [[ -n ${Custom_Path} ]] && Script_Path="${Custom_Path}"
[[ -n ${Custom_URL} ]] && Script_URL=${Custom_URL} [[ -n ${Custom_URL} ]] && Script_URL="${Custom_URL}"
UPDATE_SCRIPT ${Script_Path} ${Script_URL} UPDATE_SCRIPT ${Script_Path} ${Script_URL}
EXIT EXIT
;; ;;
@ -1248,24 +1238,22 @@ KILL_PROCESS() {
KILL_PROCESS AutoUpdate.sh KILL_PROCESS AutoUpdate.sh
Tmp_Path=/tmp/AutoUpdate Tmp_Path="/tmp/AutoUpdate"
Log_Path=/tmp Log_Path="/tmp"
API_File=${Tmp_Path}/API API_File="${Tmp_Path}/API"
Default_Variable=/etc/AutoBuild/Default_Variable Default_Variable="/etc/AutoBuild/Default_Variable"
Custom_Variable=/etc/AutoBuild/Custom_Variable Custom_Variable="/etc/AutoBuild/Custom_Variable"
ENV_DEPENDS=( ENV_DEPENDS=(
Author Author
Github Github
TARGET_PROFILE TARGET_PROFILE
TARGET_BOARD
TARGET_SUBTARGET
OP_VERSION OP_VERSION
OP_AUTHOR OP_AUTHOR
OP_BRANCH OP_BRANCH
OP_REPO OP_REPO
) )
DOWNLOADERS="$(command -v wget-ssl) $(command -v curl) $(command -v wget) $(command -v uclient-fetch)" DOWNLOADERS="$(command -v wget-ssl) $(command -v curl) $(command -v wget) $(command -v uclient-fetch)"
REGEX_Format=".vdi|.vhdx|.vmdk|kernel|rootfs|factory" REGEX_Skip_Format=".vdi|.vhdx|.vmdk|kernel|rootfs|factory"
White="\e[0m" White="\e[0m"
Yellow="\e[33m" Yellow="\e[33m"