X-OpenWrt/Scripts/AutoUpdate.sh

839 lines
23 KiB
Bash
Raw Normal View History

2020-09-19 07:37:55 +00:00
#!/bin/bash
# AutoBuild Module by Hyy2001 <https://github.com/Hyy2001X/AutoBuild-Actions>
# AutoUpdate for Openwrt
# Depends on: bash wget-ssl/wget/uclient-fetch curl x86:gzip openssl
2020-09-19 07:37:55 +00:00
TITLE() {
clear && echo "Openwrt-AutoUpdate Script by Hyy2001 ${Version} [${DL}]"
}
2020-09-23 09:43:46 +00:00
SHELL_HELP() {
2021-06-13 09:46:34 +00:00
TITLE
echo -e "\n当前指令: ${Run_Command}"
cat <<EOF
2021-04-29 12:35:12 +00:00
使用方法: $0 [-n] [-f] [-u] [-F] [-P] [path=<Path>]
$0 [-x] [path=<Path>] [url=<URL>]
2021-04-29 12:35:12 +00:00
更新固件:
-n 不保留配置更新固件 *
-f 跳过版本号、SHA256验证,并强制刷写固件 (危险) *
-u 适用于定时更新 LUCI 的参数 *
-F 强制刷写固件 *
-P 优先开启镜像加速下载固件 *
--skip 跳过云端固件 SHA256 校验 (危险) *
path=<Path> 保存固件到提供的绝对路径 <Path> *
2021-04-29 12:35:12 +00:00
2021-05-16 12:58:30 +00:00
更新脚本:
-x 更新 AutoUpdate.sh 脚本
-x path=<Path> 更新 AutoUpdate.sh 脚本 (保存脚本到提供的绝对路径 <Path>) *
-x url=<URL> 更新 AutoUpdate.sh 脚本 (使用提供的地址 <URL> 更新脚本) *
其他参数:
-C <Github URL> 更改 Github 地址为提供的 <Github URL>
-B <UEFI | Legacy> 指定 x86 设备下载 <UEFI | Legacy> 引导的固件 (危险)
-V < | cloud> 打印 <当前 | 云端> AutoUpdate.sh 版本号
-E < | cloud | *> 打印 <当前 | 云端 | 指定版本> 版本的固件更新日志
2021-06-18 13:53:57 +00:00
-H,--help 打印 AutoUpdate 帮助信息
-L,--list 打印当前系统信息
-Q < | cloud> 打印 <当前 | 云端> 固件版本
--bak <Path> <Name> 备份当前系统配置文件到指定的 <Path> 路径及名称 <Name>
--clean 清理 AutoUpdate 缓存
--check 检查 AutoUpdate 依赖软件包
--verbose 打印更详细的下载信息
--var <Variable> 打印用户指定的变量 <Variable>
--var-rm <Variable> 删除用户指定的变量 <Variable>
--env < | 1 | 2> 打印 AutoUpdate 环境变量 <全部 | 变量名称 | 值>
--log < | del> <打印 | 删除> AutoUpdate 历史运行日志
--log path=<Path> 更改 AutoUpdate 运行日志路径为提供的路径 <Path>
--random <Number> 打印一个 <0-31> 位的随机数字与字母组合
2021-04-29 12:35:12 +00:00
EOF
2021-06-25 13:48:54 +00:00
EXIT
}
SHOW_VARIABLE() {
TITLE
cat <<EOF
2021-04-29 12:35:12 +00:00
设备名称: $(uname -n) / ${TARGET_PROFILE}
固件版本: ${CURRENT_Version}
其他参数: ${TARGET_BOARD} / ${TARGET_SUBTARGET}
2021-06-08 06:22:26 +00:00
固件作者: ${Author}
固件作者 URL: ${Github}
Release URL: ${Github_Release_URL}
Release API: ${Github_API}
OpenWrt 源码 URL: https://github.com/${OP_Maintainer}/${OP_REPO_NAME}:${OP_BRANCH}
固件匹配框架: $(GET_VARIABLE Egrep_Firmware ${Default_Variable})
固件格式: ${Firmware_Type}
固件保存路径: ${AutoUpdate_Path}
运行日志路径: ${AutoUpdate_Log_Path}/AutoUpdate.log
Downloader: ${Downloader}
2021-04-29 12:35:12 +00:00
EOF
[[ ${TARGET_BOARD} == x86 ]] && {
echo "x86 固件引导模式: ${x86_Boot}"
}
EXIT 0
2021-06-13 09:46:34 +00:00
}
2021-07-04 04:39:16 +00:00
GET_PID() {
local Result
while [[ $1 ]];do
Result=$(busybox ps | grep "$1" | grep -v "grep" | awk '{print $1}' | awk 'NR==1')
[[ -n ${Result} ]] && echo ${Result}
shift
done
}
KILL_PID() {
2021-07-04 11:04:07 +00:00
local Result
Result=$(kill -9 $1)
2021-07-04 04:39:16 +00:00
}
UCI_GET() {
local Result="$(uci get $1.@$2[0].$3 2>/dev/null)"
[[ -n ${Result} ]] && echo "${Result}"
}
UCI_SET() {
uci set $1.@$2[0].$3=$4 2>/dev/null
uci commit $1
}
LIST_ENV() {
local X
cat /etc/AutoBuild/*_Variable | grep -v '#' | while read X;do
[[ ${X} =~ "=" ]] && {
case "$1" in
1 | 2)
[[ -n $(echo "${X}" | cut -d "=" -f1) ]] && echo "${X}" | cut -d "=" -f$1
;;
0)
echo "${X}"
;;
esac
}
done
}
2021-06-13 09:46:34 +00:00
EXIT() {
LOGGER "Command :[${Run_Command}] Finished $1"
exit
2020-09-25 01:51:26 +00:00
}
2021-06-25 13:48:54 +00:00
ECHO() {
local Color
[[ -z $1 ]] && {
echo -ne "\n${Grey}[$(date "+%H:%M:%S")]${White} "
} || {
case "$1" in
r) Color="${Red}";;
g) Color="${Green}";;
b) Color="${Blue}";;
y) Color="${Yellow}";;
x) Color="${Grey}";;
esac
[[ $# -lt 2 ]] && {
echo -e "\n${Grey}[$(date "+%H:%M:%S")]${White} $1"
2021-06-25 13:48:54 +00:00
LOGGER $1
} || {
echo -e "\n${Grey}[$(date "+%H:%M:%S")]${White} ${Color}$2${White}"
2021-06-25 13:48:54 +00:00
LOGGER $2
}
}
}
2021-06-25 13:48:54 +00:00
LOGGER() {
2021-07-04 11:04:07 +00:00
[[ ! -d ${AutoUpdate_Log_Path} ]] && mkdir -p ${AutoUpdate_Log_Path}
2021-06-25 13:48:54 +00:00
[[ ! -f ${AutoUpdate_Log_Path}/AutoUpdate.log ]] && touch ${AutoUpdate_Log_Path}/AutoUpdate.log
2021-07-04 04:39:16 +00:00
echo "[$(date "+%Y-%m-%d-%H:%M:%S")] [$(GET_PID AutoUpdate.sh)] $*" >> ${AutoUpdate_Log_Path}/AutoUpdate.log
2021-06-25 13:48:54 +00:00
}
CHECK_PKG() {
which $1 > /dev/null 2>&1
[[ $? == 0 ]] && echo true || echo false
}
2021-06-18 13:53:57 +00:00
RANDOM() {
2021-07-04 11:04:07 +00:00
local Result=$(openssl rand -base64 $1 | md5sum | cut -c 1-$1)
[[ -n ${Result} ]] && echo ${Result}
LOGGER "[RANDOM] $1-bit random-number : ${Result}"
2021-06-18 13:53:57 +00:00
}
GET_SHA256SUM() {
[[ ! -f $1 && ! -s $1 ]] && {
ECHO r "未检测到文件: [$1] 或该文件为空,无法计算 SHA256 值!"
EXIT 1
}
LOGGER "[GET_SHA256SUM] Target File: $1"
2021-07-04 11:04:07 +00:00
local Result=$(sha256sum $1 | cut -c1-$2)
[[ -n ${Result} ]] && echo ${Result}
LOGGER "[GET_SHA256SUM] Calculated result: ${Result}"
}
2021-06-18 13:53:57 +00:00
GET_VARIABLE() {
[[ $# != 2 ]] && SHELL_HELP
2021-06-25 13:48:54 +00:00
[[ ! -f $2 ]] && ECHO "未检测到定义文件: [$2] !" && EXIT 1
2021-07-04 11:04:07 +00:00
local Result="$(grep "$1=" $2 | grep -v "#" | awk 'NR==1' | sed -r "s/$1=(.*)/\1/")"
[[ -n ${Result} ]] && echo ${Result}
LOGGER "[GET_VARIABLE] Get Variable: ${Result}"
2021-06-18 13:53:57 +00:00
}
LOAD_VARIABLE() {
while [[ $1 ]];do
[[ -f $1 ]] && {
chmod 777 $1
source $1
}
shift
done
[[ -z ${TARGET_PROFILE} ]] && TARGET_PROFILE="$(jsonfilter -e '@.model.id' < /etc/board.json | tr ',' '_')"
2021-06-25 13:48:54 +00:00
[[ -z ${TARGET_PROFILE} ]] && ECHO r "获取设备名称失败,无法执行更新!" && EXIT 1
[[ -z ${CURRENT_Version} ]] && CURRENT_Version=未知
Github_Release_URL="${Github}/releases/download/AutoUpdate"
FW_Author="${Github##*com/}"
Github_API="https://api.github.com/repos/${FW_Author}/releases/latest"
Release_URL="https://github.com/${FW_Author}/releases/download/AutoUpdate"
Release_FastGit_URL="https://download.fastgit.org/${FW_Author}/releases/download/AutoUpdate"
Release_Goproxy_URL="https://ghproxy.com/${Release_URL}"
case "${TARGET_BOARD}" in
x86)
case "${Firmware_Type}" in
img.gz | img)
[[ -z ${x86_Boot} ]] && {
[ -d /sys/firmware/efi ] && {
x86_Boot=UEFI
} || x86_Boot=Legacy
}
;;
*)
2021-07-13 05:24:30 +00:00
ECHO r "[${TARGET_PROFILE}] 设备暂不支持当前固件格式!"
2021-06-13 09:46:34 +00:00
EXIT 1
;;
esac
;;
*)
[[ -z ${Firmware_Type} ]] && Firmware_Type=bin
esac
}
EDIT_VARIABLE() {
2021-06-13 09:46:34 +00:00
local Mode="$1"
2021-06-08 06:22:26 +00:00
shift
2021-06-25 13:48:54 +00:00
[[ ! -f $1 ]] && ECHO r "未检测到定义文件: [$1] !" && EXIT 1
2021-06-08 06:22:26 +00:00
case "${Mode}" in
edit)
2021-07-04 11:04:07 +00:00
[[ $# != 3 ]] && SHELL_HELP
[[ -z $(GET_VARIABLE $2 $1) ]] && {
2021-07-04 11:04:07 +00:00
LOGGER "[EDIT_VARIABLE] Appending [$2=$3] to $1 ..."
2021-06-08 06:22:26 +00:00
echo -e "\n$2=$3" >> $1
2021-07-04 11:04:07 +00:00
} || {
sed -i "s?$(GET_VARIABLE $2 $1)?$3?g" $1
}
;;
2021-06-08 06:22:26 +00:00
rm)
[[ $# != 2 ]] && SHELL_HELP
2021-07-04 11:04:07 +00:00
LOGGER "[EDIT_VARIABLE] Removing $2 from $1 ..."
sed -i "/$2/d" $1
2021-06-08 06:22:26 +00:00
;;
esac
}
CHANGE_GITHUB() {
[[ ! $1 =~ https://github.com/ ]] && {
2021-06-25 13:48:54 +00:00
ECHO r "ERROR Github URL: $1"
ECHO r "错误的 Github 地址,示例: https://github.com/Hyy2001X/AutoBuild-Actions"
2021-06-13 09:46:34 +00:00
EXIT 1
}
2021-07-04 04:39:16 +00:00
UCI_Github_URL=$(UCI_GET autoupdate common github)
[[ -n ${UCI_Github_URL} && ! ${UCI_Github_URL} == $1 ]] && {
2021-07-04 04:39:16 +00:00
UCI_SET autoupdate common github $1
2021-06-25 13:48:54 +00:00
ECHO y "UCI 设置已更新!"
}
[[ ! ${Github} == $1 ]] && {
2021-06-08 06:22:26 +00:00
EDIT_VARIABLE edit ${Custom_Variable} Github $1
2021-06-25 13:48:54 +00:00
ECHO y "Github 地址已修改为: $1"
} || {
2021-06-25 13:48:54 +00:00
ECHO y "当前输入的地址与原地址相同,无需修改!"
}
2021-06-13 09:46:34 +00:00
EXIT 0
}
CHANGE_BOOT() {
2021-06-13 09:46:34 +00:00
[[ -z $1 ]] && SHELL_HELP
case "$1" in
UEFI | Legacy)
EDIT_VARIABLE edit ${Custom_Variable} x86_Boot $1
echo "ON" > /force_dump
2021-06-25 13:48:54 +00:00
ECHO r "警告: 更换引导方式后更新固件后可能导致设备无法正常启动!"
ECHO y "固件引导格式已指定为: [$1],AutoUpdate 将在下一次更新时执行强制刷写固件!"
EXIT 0
2020-12-23 14:28:57 +00:00
;;
*)
2021-06-25 13:48:54 +00:00
ECHO r "错误的参数: [$1],当前支持的选项: [UEFI/Legacy] !"
2021-06-13 09:46:34 +00:00
EXIT 1
;;
esac
}
UPDATE_SCRIPT() {
2021-06-13 09:46:34 +00:00
[[ $# != 2 ]] && SHELL_HELP
2021-07-13 05:24:30 +00:00
ECHO b "脚本下载地址: $2"
ECHO b "脚本保存路径: $1"
2021-07-13 05:24:30 +00:00
[[ -f $1 ]] && {
ECHO r "AutoUpdate 脚本保存路径有误,请重新输入!"
EXIT 1
}
2021-06-25 13:48:54 +00:00
ECHO "开始更新 AutoUpdate 脚本,请耐心等待..."
2021-06-18 13:53:57 +00:00
[[ ! -d $1 ]] && mkdir -p $1
${Downloader} /tmp/AutoUpdate.sh $2
if [[ $? == 0 && -s /tmp/AutoUpdate.sh ]];then
mv -f /tmp/AutoUpdate.sh $1
2021-06-25 13:48:54 +00:00
[[ ! $? == 0 ]] && ECHO r "AutoUpdate 脚本更新失败!" && EXIT 1
chmod +x $1/AutoUpdate.sh
NEW_Version=$(egrep -o "V[0-9].+" $1/AutoUpdate.sh | awk 'END{print}')
Banner_Version=$(egrep -o "V[0-9]+.[0-9].+" /etc/banner)
2021-06-18 13:53:57 +00:00
[[ -n ${Banner_Version} ]] && sed -i "s?${Banner_Version}?${NEW_Version}?g" /etc/banner
2021-06-25 13:48:54 +00:00
ECHO y "[${Version}] > [${NEW_Version}] AutoUpdate 脚本更新成功!"
2021-06-18 13:53:57 +00:00
EXIT 0
else
2021-06-25 13:48:54 +00:00
ECHO r "AutoUpdate 脚本更新失败,请检查网络后重试!"
2021-06-18 13:53:57 +00:00
EXIT 1
fi
}
CHECK_DEPENDS() {
TITLE
local PKG
echo -e "\n软件包 检测结果"
2021-06-13 09:46:34 +00:00
while [[ $1 ]];do
if [[ $1 =~ : ]];then
[[ $(echo $1 | cut -d ":" -f1) == ${TARGET_BOARD} ]] && {
PKG="$(echo $1 | cut -d ":" -f2)"
[[ $(echo ${PKG} | wc -c) -gt 8 ]] && Tab=" " || Tab=" "
echo -e "${PKG}${Tab}$(CHECK_PKG ${PKG})"
LOGGER "[CHECK_DEPENDS] Checking [${PKG}] ... $(CHECK_PKG ${PKG})"
}
else
[[ $(echo $1 | wc -c) -gt 8 ]] && Tab=" " || Tab=" "
echo -e "$1${Tab}$(CHECK_PKG $1)"
LOGGER "[CHECK_DEPENDS] Checking [$1] ... $(CHECK_PKG $1)"
fi
2021-06-13 09:46:34 +00:00
shift
done
2021-07-04 11:04:07 +00:00
ECHO y "AutoUpdate 依赖检测结束,若某项检测结果为 [false],请尝试手动安装!"
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"
}
}
2021-06-25 13:48:54 +00:00
GET_FW_LOG() {
local Update_Log
case "$1" in
[Ll]ocal)
FW_Version="${CURRENT_Version}"
;;
[Cc]loud)
[[ -z ${CLOUD_Firmware_Version} ]] && GET_CLOUD_VERSION
FW_Version="${CLOUD_Firmware_Version}"
;;
-v)
shift
FW_Version="$1"
;;
esac
${Downloader} ${AutoUpdate_Path}/Update_Logs.json ${Release_URL}/Update_Logs.json
[[ $? == 0 ]] && {
Update_Log=$(jsonfilter -e '@["'"""${TARGET_PROFILE}"""'"]["'"""${FW_Version}"""'"]' < ${AutoUpdate_Path}/Update_Logs.json)
2021-06-25 13:48:54 +00:00
rm -f ${AutoUpdate_Path}/Update_Logs.json
}
[[ -n ${Update_Log} ]] && {
echo -e "\n${Grey}${FW_Version} for ${TARGET_PROFILE} 更新日志:"
echo -e "\n${Green}${Update_Log}${White}"
}
}
GET_CLOUD_INFO() {
[[ -f ${AutoUpdate_Path}/Github_Tags ]] && rm -f ${AutoUpdate_Path}/Github_Tags
${Downloader} ${AutoUpdate_Path}/Github_Tags ${Github_API}
[[ $? != 0 || ! -s ${AutoUpdate_Path}/Github_Tags ]] && {
echo "false"
} || echo "true"
}
GET_CLOUD_VERSION() {
local X
[[ $(GET_CLOUD_INFO) == false ]] && {
2021-06-25 13:48:54 +00:00
ECHO r "检查更新失败,请稍后重试!"
2021-06-13 09:46:34 +00:00
EXIT 1
}
2021-06-13 09:46:34 +00:00
eval X=$(GET_VARIABLE Egrep_Firmware ${Default_Variable})
2021-06-25 13:48:54 +00:00
FW_Name=$(egrep -o "${X}" ${AutoUpdate_Path}/Github_Tags | awk 'END {print}')
[[ -z ${FW_Name} ]] && ECHO "云端固件名称获取失败!" && EXIT 1
CLOUD_Firmware_Version=$(echo "${FW_Name}" | egrep -o "R[0-9].*202[1-2][0-9]+")
[[ -z ${CLOUD_Firmware_Version} ]] && ECHO r "云端固件版本获取失败!" && EXIT 1
[[ ! $(FW_VERSION_CHECK ${CLOUD_Firmware_Version}) == true ]] && ECHO r "云端固件版本号合法性检查失败!"
}
CHECK_UPDATES() {
2021-06-25 13:48:54 +00:00
ECHO "正在获取版本更新 ..."
GET_CLOUD_VERSION
[[ ${CLOUD_Firmware_Version} == ${CURRENT_Version} ]] && {
CURRENT_Type="${Yellow} [已是最新]${White}"
Upgrade_Stopped=1
} || {
[[ $(echo ${CLOUD_Firmware_Version} | cut -d "-" -f2) -gt $(echo ${CURRENT_Version} | cut -d "-" -f2) ]] && CURRENT_Type="${Green} [可更新]${White}"
[[ $(echo ${CLOUD_Firmware_Version} | cut -d "-" -f2) -lt $(echo ${CURRENT_Version} | cut -d "-" -f2) ]] && {
CLOUD_Type="${Red} [旧版本]${White}"
Upgrade_Stopped=2
}
}
# SHA5BIT=$(echo ${FW_Name} | egrep -o "[a-zA-Z0-9]+.${Firmware_Type}" | sed -r "s/(.*).${Firmware_Type}/\1/")
}
PREPARE_UPGRADES() {
TITLE
[[ $* =~ -f && $* =~ -F ]] && SHELL_HELP
Upgrade_Option="sysupgrade -q"
MSG="更新固件"
while [[ $1 ]];do
case "$1" in
-T | --test)
Test_Mode=1
Special_Commands="${Special_Commands} [测试模式]"
;;
-P)
Proxy_Mode=1
Special_Commands="${Special_Commands} [镜像加速]"
;;
-F)
[[ -n ${Force_Mode} ]] && SHELL_HELP
Only_Force_Write=1
Special_Commands="${Special_Commands} [强制刷写]"
Upgrade_Option="${Upgrade_Option} -F"
;;
--skip)
Skip_SHA256=1
Special_Commands="${Special_Commands} [跳过 SHA256 验证]"
;;
-f)
[[ -n ${Only_Force_Write} ]] && SHELL_HELP
Force_Mode=1
Special_Commands="${Special_Commands} [强制模式]"
Upgrade_Option="${Upgrade_Option} -F"
;;
-n)
Upgrade_Option="${Upgrade_Option} -n"
Special_MSG=" (不保留配置)"
;;
-u)
AutoUpdate_Mode=1
Special_Commands="${Special_Commands} [定时更新]"
;;
path=/*)
[[ -z $(echo $1 | cut -d "=" -f2) ]] && ECHO r "固件保存路径不能为空!" && EXIT 1
AutoUpdate_Path=$(echo $1 | cut -d "=" -f2)
ECHO g "使用自定义固件保存路径: ${AutoUpdate_Path}"
;;
--verbose)
Special_Commands="${Special_Commands} [详细信息]"
;;
*)
SHELL_HELP
esac
shift
done
LOGGER "Upgrade Options: ${Upgrade_Option}"
[[ -n "${Special_Commands}" ]] && ECHO g "特殊指令:${Special_Commands} / ${Upgrade_Option}"
ECHO g "执行: ${MSG}${Special_MSG}"
2021-06-25 13:48:54 +00:00
REMOVE_CACHE quiet
if [[ $(CHECK_PKG curl) == true && ${Proxy_Mode} != 1 ]];then
Google_Check=$(curl -I -s --connect-timeout 3 google.com -w %{http_code} | tail -n1)
LOGGER "Google_Check: ${Google_Check}"
[[ ${Google_Check} != 301 ]] && {
ECHO r "Google 连接失败,优先使用镜像加速!"
Proxy_Mode=1
2021-05-12 13:15:10 +00:00
}
fi
CHECK_UPDATES
[[ -z ${CLOUD_Firmware_Version} ]] && {
2021-06-25 13:48:54 +00:00
ECHO r "云端固件信息获取失败!"
2021-06-13 09:46:34 +00:00
EXIT 1
}
[[ ${Proxy_Mode} == 1 ]] && {
FW_URL="${Release_FastGit_URL}"
} || FW_URL="${Release_URL}"
cat <<EOF
固件作者: ${FW_Author%/*}
设备名称: $(uname -n) / ${TARGET_PROFILE}
$([[ ${TARGET_BOARD} == x86 ]] && echo "固件格式: ${Firmware_Type} / ${x86_Boot}" || echo "固件格式: ${Firmware_Type}")
$(echo -e "当前固件版本: ${CURRENT_Version}${CURRENT_Type}")
$(echo -e "云端固件版本: ${CLOUD_Firmware_Version}${CLOUD_Type}")
云端固件名称: ${FW_Name}
固件下载地址: ${FW_URL}
EOF
GET_FW_LOG -v ${CLOUD_Firmware_Version}
2021-06-25 13:48:54 +00:00
rm -f ${AutoUpdate_Path}/Github_Tags
case "${Upgrade_Stopped}" in
1 | 2)
2021-06-25 13:48:54 +00:00
[[ ${AutoUpdate_Mode} == 1 ]] && ECHO y "已是最新版本,无需更新!" && EXIT 0
[[ ${Upgrade_Stopped} == 1 ]] && MSG="已是最新版本" || MSG="云端固件版本为旧版"
[[ ! ${Force_Mode} == 1 ]] && {
2021-06-25 13:48:54 +00:00
ECHO && read -p "${MSG},是否继续更新固件?[Y/n]:" Choose
} || Choose=Y
2021-06-13 09:46:34 +00:00
[[ ! ${Choose} =~ [Yy] ]] && EXIT 0
;;
esac
Retry_Times=5
2021-06-25 13:48:54 +00:00
ECHO "${Proxy_Echo}正在下载固件,请耐心等待 ..."
while [[ ${Retry_Times} -ge 0 ]];do
if [[ ! ${PROXY_Mode} == 1 && ${Retry_Times} == 4 ]];then
2021-06-25 13:48:54 +00:00
ECHO g "尝试使用 [FastGit] 镜像加速下载固件!"
FW_URL="${Release_FastGit_URL}"
fi
[[ ${Retry_Times} == 3 ]] && {
ECHO g "尝试使用 [Github Proxy] 镜像加速下载固件!"
FW_URL="${Release_Goproxy_URL}"
2021-06-18 13:53:57 +00:00
}
[[ ${Retry_Times} == 2 ]] && FW_URL="${Github_Release_URL}"
if [[ ${Retry_Times} == 0 ]];then
2021-06-25 13:48:54 +00:00
ECHO r "固件下载失败,请检查网络后重试!"
2021-06-13 09:46:34 +00:00
EXIT 1
else
${Downloader} ${AutoUpdate_Path}/${FW_Name} "${FW_URL}/${FW_Name}"
2021-06-25 13:48:54 +00:00
[[ $? == 0 && -s ${AutoUpdate_Path}/${FW_Name} ]] && ECHO y "固件下载成功!" && break
fi
Retry_Times=$((${Retry_Times} - 1))
2021-06-25 13:48:54 +00:00
ECHO r "固件下载失败,剩余尝试次数: ${Retry_Times}"
done
if [[ ! ${Skip_SHA256} == 1 || ! Force_Mode == 1 ]];then
CURRENT_SHA256=$(GET_SHA256SUM ${AutoUpdate_Path}/${FW_Name} 5)
CLOUD_SHA256=$(echo ${FW_Name} | egrep -o "[0-9a-z]+.${Firmware_Type}" | sed -r "s/(.*).${Firmware_Type}/\1/")
[[ ${CURRENT_SHA256} != ${CLOUD_SHA256} ]] && {
ECHO r "本地固件 SHA256 与云端比对校验失败 [${CURRENT_SHA256}],请检查网络后重试!"
EXIT 1
} || LOGGER "固件 SHA256 比对通过!"
fi
case "${Firmware_Type}" in
img.gz)
2021-06-25 13:48:54 +00:00
ECHO "正在解压固件,请耐心等待 ..."
gzip -d -q -f -c ${AutoUpdate_Path}/${FW_Name} > ${AutoUpdate_Path}/$(echo ${FW_Name} | sed -r 's/(.*).gz/\1/')
[[ $? != 0 ]] && {
ECHO r "固件解压失败,请检查网络稳定性或更换固件保存路径!"
2021-06-13 09:46:34 +00:00
EXIT 1
} || {
FW_Name="$(echo ${FW_Name} | sed -r 's/(.*).gz/\1/')"
ECHO "固件解压成功,固件已解压到: ${AutoUpdate_Path}/${FW_Name}"
}
;;
esac
[[ ${Test_Mode} != 1 ]] && {
2021-06-25 13:48:54 +00:00
chmod 777 ${AutoUpdate_Path}/${FW_Name}
DO_UPGRADE ${Upgrade_Option} ${AutoUpdate_Path}/${FW_Name}
} || {
ECHO x "[测试模式] ${Upgrade_Option} ${AutoUpdate_Path}/${FW_Name}"
ECHO x "[测试模式] 运行完毕!"
2021-06-13 09:46:34 +00:00
EXIT 0
}
2021-05-16 12:58:30 +00:00
}
DO_UPGRADE() {
ECHO r "准备更新固件,更新期间请不要断开电源或重启设备 ..."
sleep 5
ECHO g "正在更新固件,请耐心等待 ..."
$*
[[ $? -ne 0 ]] && {
ECHO r "固件刷写失败,请尝试手动下载更新固件或附加 -F 参数强制刷写!"
2021-06-13 09:46:34 +00:00
EXIT 1
} || EXIT 0
2021-05-13 10:40:16 +00:00
}
REMOVE_CACHE() {
2021-06-25 13:48:54 +00:00
rm -rf ${AutoUpdate_Path}/AutoBuild-${TARGET_PROFILE}-* \
${AutoUpdate_Path}/Github_Tags \
${AutoUpdate_Path}/Update_Logs.json
case "$1" in
quiet)
LOGGER "AutoUpdate 缓存清理完成!"
;;
2021-06-25 13:48:54 +00:00
*)
ECHO y "AutoUpdate 缓存清理完成!"
2021-06-13 09:46:34 +00:00
EXIT 0
;;
esac
}
2021-06-25 13:48:54 +00:00
AutoUpdate_LOG() {
[[ -z $1 ]] && {
2021-06-25 13:48:54 +00:00
[[ -s ${AutoUpdate_Log_Path}/AutoUpdate.log ]] && {
TITLE && echo
2021-06-25 13:48:54 +00:00
cat ${AutoUpdate_Log_Path}/AutoUpdate.log
}
} || {
while [[ $1 ]];do
case "$1" in
2021-07-13 05:24:30 +00:00
path=/* | rm | del)
:
;;
*)
SHELL_HELP
;;
esac
if [[ $1 =~ path= ]];then
LOG_PATH="$(echo $1 | cut -d "=" -f2)"
2021-07-13 05:24:30 +00:00
[[ ${LOG_PATH} == ${AutoUpdate_Log_Path} ]] && {
ECHO y "AutoUpdate 日志保存路径相同,无需修改!"
EXIT 0
}
[[ -f ${LOG_PATH} ]] && {
ECHO r "错误的参数: [${LOG_PATH}]"
ECHO r "AutoUpdate 日志保存路径有误,请重新输入!"
EXIT 1
}
2021-06-25 13:48:54 +00:00
EDIT_VARIABLE rm ${Custom_Variable} AutoUpdate_Log_Path
EDIT_VARIABLE edit ${Custom_Variable} AutoUpdate_Log_Path ${LOG_PATH}
[[ ! -d ${LOG_PATH} ]] && mkdir -p ${LOG_PATH}
2021-07-13 05:24:30 +00:00
[[ -f ${AutoUpdate_Log_Path}/AutoUpdate.log ]] && mv ${AutoUpdate_Log_Path}/AutoUpdate.log ${LOG_PATH}
AutoUpdate_Log_Path=${LOG_PATH}
ECHO y "AutoUpdate 日志保存路径已修改为: ${LOG_PATH}"
EXIT 0
fi
[[ $1 == rm || $1 == del ]] && {
2021-06-25 13:48:54 +00:00
[[ -f ${AutoUpdate_Log_Path}/AutoUpdate.log ]] && rm ${AutoUpdate_Log_Path}/AutoUpdate.log
}
2021-06-25 13:48:54 +00:00
EXIT 0
done
}
}
2021-06-08 06:22:26 +00:00
2021-06-13 09:46:34 +00:00
AutoUpdate_Main() {
local Result
2021-06-18 13:53:57 +00:00
[[ ! -f ${Custom_Variable} ]] && touch ${Custom_Variable}
2021-06-13 09:46:34 +00:00
LOAD_VARIABLE ${Default_Variable} ${Custom_Variable}
2021-06-25 13:48:54 +00:00
[[ ! -d ${AutoUpdate_Path} ]] && mkdir -p ${AutoUpdate_Path}
if [[ $(CHECK_PKG wget-ssl) == true ]];then
Downloader="wget-ssl --quiet --no-check-certificate -T 5 --no-dns-cache -x -O"
DL="wget-ssl"
elif [[ $(CHECK_PKG curl) == true ]];then
Downloader="curl -L -k -m 5 --silent -o"
DL="curl"
else
Downloader="uclient-fetch --quiet --no-check-certificate -T 5 -O"
DL="uclient-fetch"
fi
[[ -z $* ]] && PREPARE_UPGRADES $*
[[ $1 =~ path=/ && ! $* =~ -x && ! $* =~ -U ]] && PREPARE_UPGRADES $*
[[ $1 =~ --skip ]] && PREPARE_UPGRADES $*
[[ $* =~ -T || $* =~ --verbose ]] && {
Downloader="$(echo ${Downloader/ --quiet / })"
Downloader="$(echo ${Downloader/ --silent / })"
}
2021-06-13 09:46:34 +00:00
while [[ $1 ]];do
case "$1" in
-n | -f | -u | -T | -P | -F | --verbose)
LOGGER "Downloader: ${DL} / ${Downloader}"
PREPARE_UPGRADES $*
2021-07-04 04:39:16 +00:00
;;
--bak)
2021-07-04 04:39:16 +00:00
shift
[[ $# -lt 1 || $# -gt 2 ]] && ECHO r "格式错误,示例: [bash $0 --bak /mnt/sda1 Openwrt_Backups.tar.gz]" && EXIT 1
[[ $# == 2 ]] && {
[[ ! -d $1 ]] && mkdir -p $1
FILE="$1/$2"
[[ -f ${FILE} ]] && FILE="${FILE}-$(RANDOM 5)"
} || {
[[ ! -d $1 ]] && mkdir -p $1
FILE="$1/$(uname -n)-Backups-$(date +%Y-%m-%d)-$(RANDOM 5)"
}
[[ ! ${FILE} =~ tar.gz ]] && FILE="${FILE}.tar.gz"
ECHO "Saving config files to [${FILE}] ..."
sysupgrade -b "${FILE}" >/dev/null 2>&1
[[ $? == 0 ]] && {
ECHO y "系统文件备份成功!"
ECHO y "保存位置: ${FILE}"
EXIT 0
} || {
ECHO r "备份文件创建失败,请尝试更换保存路径!"
EXIT 1
}
2021-07-04 04:39:16 +00:00
;;
--clean)
shift && [[ -n $* ]] && SHELL_HELP
REMOVE_CACHE
;;
--check)
shift && [[ -n $* ]] && SHELL_HELP
2021-07-13 05:24:30 +00:00
CHECK_DEPENDS bash x86:gzip x86:wget-ssl uclient-fetch curl wget openssl which
;;
--env)
shift
[[ -z $* ]] && LIST_ENV 0 && EXIT 0
case "$1" in
1 | 2)
LIST_ENV $1
;;
*)
SHELL_HELP
;;
esac
EXIT 0
;;
--log)
2021-06-14 03:11:25 +00:00
shift
AutoUpdate_LOG $*
2021-06-13 09:46:34 +00:00
;;
--random)
shift
[[ $# != 1 || ! $1 =~ [0-9] || $1 == 0 || $1 -gt 30 ]] && SHELL_HELP || {
RANDOM $1
EXIT 0
}
2021-06-13 09:46:34 +00:00
;;
--sleep)
shift
sleep $1
EXIT 0
2021-06-13 09:46:34 +00:00
;;
--var)
shift
[[ $# != 1 ]] && SHELL_HELP
SHOW_VARIABLE=$(GET_VARIABLE "$1" ${Custom_Variable})
[[ -z ${SHOW_VARIABLE} ]] && SHOW_VARIABLE=$(GET_VARIABLE "$1" ${Default_Variable})
echo "${SHOW_VARIABLE}"
[[ $? == 0 ]] && EXIT 0 || EXIT 1
2021-06-13 09:46:34 +00:00
;;
--var-rm)
shift
[[ $# != 1 ]] && SHELL_HELP
EDIT_VARIABLE rm ${Custom_Variable} $1
[[ $? == 0 ]] && EXIT 0 || EXIT 1
2021-06-13 09:46:34 +00:00
;;
-x)
2021-07-13 05:24:30 +00:00
shift
2021-06-13 09:46:34 +00:00
while [[ $1 ]];do
case "$1" in
2021-07-13 05:24:30 +00:00
url=* | path=/*)
:
;;
*)
SHELL_HELP
;;
esac
if [[ $1 =~ url= ]];then
2021-06-13 09:46:34 +00:00
[[ $1 =~ url= ]] && {
2021-06-25 13:48:54 +00:00
[[ -z $(echo $1 | cut -d "=" -f2) ]] && ECHO r "脚本地址不能为空!" && EXIT 1
AutoUpdate_Script_URL="$(echo $1 | cut -d "=" -f2)"
2021-06-13 09:46:34 +00:00
}
fi
[[ $1 =~ path= ]] && {
[[ -z $(echo $1 | cut -d "=" -f2) ]] && ECHO r "保存路径不能为空!" && EXIT 1
2021-06-13 09:46:34 +00:00
SH_SAVE_PATH="$(echo $1 | cut -d "=" -f2)"
}
2021-06-13 09:46:34 +00:00
shift
done
LOGGER "Downloader: ${Downloader}"
2021-06-13 09:46:34 +00:00
[[ -z ${SH_SAVE_PATH} ]] && SH_SAVE_PATH=/bin
UPDATE_SCRIPT ${SH_SAVE_PATH} ${AutoUpdate_Script_URL}
2021-06-13 09:46:34 +00:00
;;
-B)
shift
[[ ${TARGET_BOARD} != x86 ]] && EXIT 1
CHANGE_BOOT $1
2021-06-13 09:46:34 +00:00
;;
-C)
shift
CHANGE_GITHUB $1
2021-06-13 09:46:34 +00:00
;;
-E)
shift
[[ -z $* ]] && GET_FW_LOG local
case "$1" in
[Cc]loud)
GET_FW_LOG $1
;;
*)
[[ -z $* ]] && EXIT 0
[[ $(FW_VERSION_CHECK $1) == true ]] && GET_FW_LOG -v $1 || {
ECHO r "固件版本号合法性检查失败!"
EXIT 1
}
;;
esac
EXIT
;;
-H | --[Hh]elp)
SHELL_HELP
2021-06-13 09:46:34 +00:00
;;
-L | --[Ll]ist)
shift && [[ -n $* ]] && SHELL_HELP
SHOW_VARIABLE
2021-06-13 09:46:34 +00:00
;;
-Q)
2021-06-13 09:46:34 +00:00
shift
[[ -z $* ]] && {
echo ${CURRENT_Version}
2021-06-14 03:11:25 +00:00
EXIT 0
}
case "$1" in
[Cc]loud)
GET_CLOUD_VERSION
[[ -z ${CLOUD_Firmware_Version} ]] && echo "未知" || echo "${CLOUD_Firmware_Version}"
;;
esac
EXIT 0
2021-06-13 09:46:34 +00:00
;;
-V)
2021-06-13 09:46:34 +00:00
shift
case "$1" in
[Cc]loud)
Result="$(${Downloader} - ${AutoUpdate_Script_URL} | egrep -o "V[0-9].+")"
;;
*)
Result=${Version}
esac
[[ -z ${Result} ]] && echo "未知" || {
LOGGER "Command Result: ${Result}"
echo "${Result}"
EXIT 0
}
2021-06-13 09:46:34 +00:00
;;
*)
SHELL_HELP
;;
esac
2021-06-08 06:22:26 +00:00
shift
2021-06-13 09:46:34 +00:00
done
}
Version=V6.4.6
2021-06-25 13:48:54 +00:00
AutoUpdate_Path=/tmp/AutoUpdate
AutoUpdate_Log_Path=/tmp
AutoUpdate_Script_URL=https://ghproxy.com/https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh
Default_Variable=/etc/AutoBuild/Default_Variable
Custom_Variable=/etc/AutoBuild/Custom_Variable
2021-06-25 13:48:54 +00:00
[[ -n $* ]] && Run_Command="$0 $*" || Run_Command="$0"
White="\e[0m"
Yellow="\e[33m"
Red="\e[31m"
Blue="\e[34m"
Grey="\e[36m"
Green="\e[32m"
2021-06-23 02:36:03 +00:00
AutoUpdate_Main $*