Change the if-elif-else condition to a case-esac condition, and improve

the echo output.
This commit is contained in:
name1ess
2025-12-14 22:39:29 +08:00
parent ac8915c77b
commit 083ef90a9f
6 changed files with 4959 additions and 4937 deletions

View File

@@ -43,14 +43,14 @@ error_down() {
} }
#安装及初始化 #安装及初始化
set_alias() { set_alias() {
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "\033[36m请选择一个别名或使用自定义别名\033[0m" $echo "\033[36m请选择一个别名或使用自定义别名\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo " 1 【\033[32mcrash\033[0m】" $echo " 1 【\033[32mcrash\033[0m】"
$echo " 2 【\033[32m sc \033[0m】" $echo " 2 【\033[32m sc \033[0m】"
$echo " 3 【\033[32m mm \033[0m】" $echo " 3 【\033[32m mm \033[0m】"
$echo " 0 退出安装" $echo " 0 退出安装"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字或自定义别名 > " res read -p "请输入相应数字或自定义别名 > " res
case "$res" in case "$res" in
1) my_alias=crash ;; 1) my_alias=crash ;;
@@ -74,7 +74,7 @@ gettar() {
else else
$CRASHDIR/start.sh stop 2>/dev/null $CRASHDIR/start.sh stop 2>/dev/null
#解压 #解压
echo ----------------------------------------------- echo "-----------------------------------------------"
echo 开始解压文件! echo 开始解压文件!
mkdir -p $CRASHDIR >/dev/null mkdir -p $CRASHDIR >/dev/null
tar -zxf '/tmp/ShellCrash.tar.gz' -C $CRASHDIR/ || tar -zxf '/tmp/ShellCrash.tar.gz' --no-same-owner -C $CRASHDIR/ tar -zxf '/tmp/ShellCrash.tar.gz' -C $CRASHDIR/ || tar -zxf '/tmp/ShellCrash.tar.gz' --no-same-owner -C $CRASHDIR/
@@ -112,7 +112,7 @@ setdir() {
fi fi
} }
set_cust_dir() { set_cust_dir() {
echo ----------------------------------------------- echo "-----------------------------------------------"
echo '可用路径 剩余空间:' echo '可用路径 剩余空间:'
df -h | awk '{print $6,$4}' | sed 1d df -h | awk '{print $6,$4}' | sed 1d
echo '路径是必须带 / 的格式,注意写入虚拟内存(/tmp,/opt,/sys...)的文件会在重启后消失!!!' echo '路径是必须带 / 的格式,注意写入虚拟内存(/tmp,/opt,/sys...)的文件会在重启后消失!!!'
@@ -122,7 +122,7 @@ setdir() {
set_cust_dir set_cust_dir
fi fi
} }
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "\033[33m注意安装ShellCrash至少需要预留约1MB的磁盘空间\033[0m" $echo "\033[33m注意安装ShellCrash至少需要预留约1MB的磁盘空间\033[0m"
if [ -n "$systype" ]; then if [ -n "$systype" ]; then
[ "$systype" = "Padavan" ] && dir=/etc/storage [ "$systype" = "Padavan" ] && dir=/etc/storage
@@ -133,7 +133,7 @@ setdir() {
[ -d /data/other_vol ] && $echo " 3 安装到 /data/other_vol 目录,剩余空间:$(dir_avail /data/other_vol -h)(支持软固化功能)" [ -d /data/other_vol ] && $echo " 3 安装到 /data/other_vol 目录,剩余空间:$(dir_avail /data/other_vol -h)(支持软固化功能)"
$echo " 4 安装到自定义目录(不推荐,不明勿用!)" $echo " 4 安装到自定义目录(不推荐,不明勿用!)"
$echo " 0 退出安装" $echo " 0 退出安装"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
case "$num" in case "$num" in
1) 1)
@@ -159,7 +159,7 @@ setdir() {
$echo " 2 基于自启脚本安装(仅支持梅林及部分非koolshare官改固件)" $echo " 2 基于自启脚本安装(仅支持梅林及部分非koolshare官改固件)"
$echo " 3 基于U盘+下载大师安装(支持所有固件限ARM设备须插入U盘或移动硬盘)" $echo " 3 基于U盘+下载大师安装(支持所有固件限ARM设备须插入U盘或移动硬盘)"
$echo " 0 退出安装" $echo " 0 退出安装"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
case "$num" in case "$num" in
1) 1)
@@ -190,27 +190,31 @@ setdir() {
$echo " 4 在\033[32m外置存储\033[0m中安装" $echo " 4 在\033[32m外置存储\033[0m中安装"
$echo " 5 手动设置安装目录" $echo " 5 手动设置安装目录"
$echo " 0 退出安装" $echo " 0 退出安装"
echo ----------------------------------------------- echo "----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
#设置目录 #设置目录
if [ -z $num ]; then case "$num" in
echo 安装已取消 1)
exit 1
elif [ "$num" = "1" ]; then
dir=/etc dir=/etc
elif [ "$num" = "2" ]; then ;;
2)
dir=/usr/share dir=/usr/share
elif [ "$num" = "3" ]; then ;;
3)
dir=~/.local/share dir=~/.local/share
mkdir -p ~/.config/systemd/user mkdir -p ~/.config/systemd/user
elif [ "$num" = "4" ]; then ;;
4)
set_usb_dir set_usb_dir
elif [ "$num" = "5" ]; then ;;
5)
set_cust_dir set_cust_dir
else ;;
echo 安装已取消!!! *)
echo "安装已取消"
exit 1 exit 1
fi ;;
esac
fi fi
if [ ! -w $dir ]; then if [ ! -w $dir ]; then
@@ -222,25 +226,25 @@ setdir() {
fi fi
} }
install() { install() {
echo ----------------------------------------------- echo "-----------------------------------------------"
echo 开始从服务器获取安装文件! echo 开始从服务器获取安装文件!
echo ----------------------------------------------- echo "-----------------------------------------------"
gettar gettar
echo ----------------------------------------------- echo "-----------------------------------------------"
echo ShellCrash 已经安装成功! echo "ShellCrash 已经安装成功!"
[ "$profile" = "~/.bashrc" ] && echo "请执行【. ~/.bashrc > /dev/null】命令以加载环境变量" [ "$profile" = "~/.bashrc" ] && echo "请执行【. ~/.bashrc > /dev/null】命令以加载环境变量"
[ -n "$(ls -l /bin/sh | grep -oE 'zsh')" ] && echo "请执行【. ~/.zshrc > /dev/null】命令以加载环境变量" [ -n "$(ls -l /bin/sh | grep -oE 'zsh')" ] && echo "请执行【. ~/.zshrc > /dev/null】命令以加载环境变量"
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "\033[33m输入\033[30;47m $my_alias \033[0;33m命令即可管理\033[0m" $echo "\033[33m输入\033[30;47m $my_alias \033[0;33m命令即可管理\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
} }
setversion() { setversion() {
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "\033[33m请选择想要安装的版本\033[0m" $echo "\033[33m请选择想要安装的版本\033[0m"
$echo " 1 \033[32m公测版(推荐)\033[0m" $echo " 1 \033[32m公测版(推荐)\033[0m"
$echo " 2 \033[36m稳定版\033[0m" $echo " 2 \033[36m稳定版\033[0m"
$echo " 3 \033[31m开发版\033[0m" $echo " 3 \033[31m开发版\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
case "$num" in case "$num" in
2) 2)
@@ -269,7 +273,7 @@ setversion() {
if [ "$USER" != "root" -a -z "$systype" ]; then if [ "$USER" != "root" -a -z "$systype" ]; then
echo 当前用户:$USER echo 当前用户:$USER
$echo "\033[31m请尽量使用root用户不要直接使用sudo命令执行安装!\033[0m" $echo "\033[31m请尽量使用root用户不要直接使用sudo命令执行安装!\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "仍要安装?可能会产生未知错误!(1/0) > " res read -p "仍要安装?可能会产生未知错误!(1/0) > " res
[ "$res" != "1" ] && exit 1 [ "$res" != "1" ] && exit 1
fi fi
@@ -284,32 +288,37 @@ rm -rf /tmp/version
#输出 #输出
$echo "最新版本:\033[32m$versionsh\033[0m" $echo "最新版本:\033[32m$versionsh\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "\033[44m如遇问题请加TG群反馈\033[42;30m t.me/ShellClash \033[0m" $echo "\033[44m如遇问题请加TG群反馈\033[42;30m t.me/ShellClash \033[0m"
$echo "\033[37m支持各种基于openwrt的路由器设备" $echo "\033[37m支持各种基于openwrt的路由器设备"
$echo "\033[33m支持Debian、Centos等标准Linux系统\033[0m" $echo "\033[33m支持Debian、Centos等标准Linux系统\033[0m"
if [ -n "$CRASHDIR" ]; then if [ -n "$CRASHDIR" ]; then
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "检测到旧的安装目录\033[36m$CRASHDIR\033[0m是否覆盖安装" $echo "检测到旧的安装目录\033[36m$CRASHDIR\033[0m是否覆盖安装"
$echo "\033[32m覆盖安装时不会移除配置文件\033[0m" $echo "\033[32m覆盖安装时不会移除配置文件\033[0m"
read -p "覆盖安装/卸载旧版本?(1/0) > " res read -p "覆盖安装/卸载旧版本?(1/0) > " res
if [ "$res" = "1" ]; then case "$res" in
1)
install install
elif [ "$res" = "0" ]; then ;;
0)
rm -rf $CRASHDIR rm -rf $CRASHDIR
echo ----------------------------------------------- echo "-----------------------------------------------"
$echo "\033[31m 旧版本文件已卸载!\033[0m" $echo "\033[31m 旧版本文件已卸载!\033[0m"
setdir setdir
install install
elif [ "$res" = "9" ]; then ;;
echo 测试模式,变更安装位置 9)
echo "测试模式,变更安装位置"
setdir setdir
install install
else ;;
*)
$echo "\033[31m输入错误已取消安装\033[0m" $echo "\033[31m输入错误已取消安装\033[0m"
exit 1 exit 1
fi ;;
esac
else else
setdir setdir
install install

View File

@@ -28,17 +28,17 @@ setdir() {
fi fi
} }
set_cust_dir() { set_cust_dir() {
echo ----------------------------------------------- echo "-----------------------------------------------"
echo '可用路径 剩余空间:' echo "可用路径 剩余空间:"
df -h | awk '{print $6,$4}' | sed 1d df -h | awk '{print $6,$4}' | sed 1d
echo '路径是必须带 / 的格式,注意写入虚拟内存(/tmp,/opt,/sys...)的文件会在重启后消失!!!' echo "路径是必须带 / 的格式,注意写入虚拟内存(/tmp,/opt,/sys...)的文件会在重启后消失!!!"
read -p "请输入自定义路径 > " dir read -p "请输入自定义路径 > " dir
if [ "$(dir_avail $dir)" = 0 ] || [ -n "$(echo $dir | grep -E 'tmp|opt|sys')" ]; then if [ "$(dir_avail $dir)" = 0 ] || [ -n "$(echo $dir | grep -E 'tmp|opt|sys')" ]; then
echo "\033[31m路径错误请重新设置\033[0m" echo "\033[31m路径错误请重新设置\033[0m"
set_cust_dir set_cust_dir
fi fi
} }
echo ----------------------------------------------- echo "-----------------------------------------------"
if [ -n "$systype" ]; then if [ -n "$systype" ]; then
[ "$systype" = "Padavan" ] && dir=/etc/storage [ "$systype" = "Padavan" ] && dir=/etc/storage
[ "$systype" = "mi_snapshot" ] && { [ "$systype" = "mi_snapshot" ] && {
@@ -48,7 +48,7 @@ setdir() {
[ -d /data/other_vol ] && $echo " 3 安装到 /data/other_vol 目录,剩余空间:$(dir_avail /data/other_vol -h)(支持软固化功能)" [ -d /data/other_vol ] && $echo " 3 安装到 /data/other_vol 目录,剩余空间:$(dir_avail /data/other_vol -h)(支持软固化功能)"
$echo " 4 安装到自定义目录(不推荐,不明勿用!)" $echo " 4 安装到自定义目录(不推荐,不明勿用!)"
echo " 0 退出安装" echo " 0 退出安装"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
case "$num" in case "$num" in
1) 1)
@@ -74,7 +74,7 @@ setdir() {
echo -e " 2 基于自启脚本安装(仅支持梅林及部分非koolshare官改固件)" echo -e " 2 基于自启脚本安装(仅支持梅林及部分非koolshare官改固件)"
echo -e " 3 基于U盘+下载大师安装(支持所有固件限ARM设备须插入U盘或移动硬盘)" echo -e " 3 基于U盘+下载大师安装(支持所有固件限ARM设备须插入U盘或移动硬盘)"
echo -e " 0 退出安装" echo -e " 0 退出安装"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
case "$num" in case "$num" in
1) 1)
@@ -106,35 +106,39 @@ setdir() {
echo -e " 4 在\033[32m外置存储\033[0m中安装" echo -e " 4 在\033[32m外置存储\033[0m中安装"
echo -e " 5 手动设置安装目录" echo -e " 5 手动设置安装目录"
echo -e " 0 退出安装" echo -e " 0 退出安装"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入相应数字 > " num read -p "请输入相应数字 > " num
#设置目录 #设置目录
if [ -z $num ]; then case "$num" in
echo 安装已取消 1)
exit 1
elif [ "$num" = "1" ]; then
dir=/etc dir=/etc
elif [ "$num" = "2" ]; then ;;
2)
dir=/usr/share dir=/usr/share
elif [ "$num" = "3" ]; then ;;
3)
dir=~/.local/share dir=~/.local/share
mkdir -p ~/.config/systemd/user mkdir -p ~/.config/systemd/user
elif [ "$num" = "4" ]; then ;;
4)
set_usb_dir set_usb_dir
elif [ "$num" = "5" ]; then ;;
echo ----------------------------------------------- 5)
echo '可用路径 剩余空间:' echo "-----------------------------------------------"
echo "可用路径 剩余空间:"
df -h | awk '{print $6,$4}' | sed 1d df -h | awk '{print $6,$4}' | sed 1d
echo '路径是必须带 / 的格式,注意写入虚拟内存(/tmp,/opt,/sys...)的文件会在重启后消失!!!' echo "路径是必须带 / 的格式,注意写入虚拟内存(/tmp,/opt,/sys...)的文件会在重启后消失!!!"
read -p "请输入自定义路径 > " dir read -p "请输入自定义路径 > " dir
if [ -z "$dir" ]; then if [ -z "$dir" ]; then
echo -e "\033[31m路径错误请重新设置\033[0m" echo -e "\033[31m路径错误请重新设置\033[0m"
setdir setdir
fi fi
else ;;
echo 安装已取消!!! *)
echo "安装已取消"
exit 1 exit 1
fi ;;
esac
fi fi
if [ ! -w $dir ]; then if [ ! -w $dir ]; then

File diff suppressed because it is too large Load Diff

View File

@@ -255,28 +255,28 @@ check_clash_config() { #检查clash配置文件
#检测节点或providers #检测节点或providers
sed -n "/^proxies:/,/^[a-z]/ { /^[a-z]/d; p; }" "$core_config_new" >"$TMPDIR"/proxies.yaml sed -n "/^proxies:/,/^[a-z]/ { /^[a-z]/d; p; }" "$core_config_new" >"$TMPDIR"/proxies.yaml
if ! grep -Eq 'server:|server":|server'\'':' "$TMPDIR"/proxies.yaml && ! grep -q 'proxy-providers:' "$core_config_new"; then if ! grep -Eq 'server:|server":|server'\'':' "$TMPDIR"/proxies.yaml && ! grep -q 'proxy-providers:' "$core_config_new"; then
echo ----------------------------------------------- echo "-----------------------------------------------"
logger "获取到了配置文件【$core_config_new】,但似乎并不包含正确的节点信息!" 31 logger "获取到了配置文件【$core_config_new】,但似乎并不包含正确的节点信息!" 31
cat "$TMPDIR"/proxies.yaml cat "$TMPDIR"/proxies.yaml
sleep 1 sleep 1
echo ----------------------------------------------- echo "-----------------------------------------------"
echo "请尝试使用6-2或者6-3的方式生成配置文件" echo "请尝试使用6-2或者6-3的方式生成配置文件"
exit 1 exit 1
fi fi
rm -rf "$TMPDIR"/proxies.yaml rm -rf "$TMPDIR"/proxies.yaml
#检测旧格式 #检测旧格式
if cat "$core_config_new" | grep 'Proxy Group:' >/dev/null; then if cat "$core_config_new" | grep 'Proxy Group:' >/dev/null; then
echo ----------------------------------------------- echo "-----------------------------------------------"
logger "已经停止对旧格式配置文件的支持!!!" 31 logger "已经停止对旧格式配置文件的支持!!!" 31
echo -e "请使用新格式或者使用【在线生成配置文件】功能!" echo -e "请使用新格式或者使用【在线生成配置文件】功能!"
echo ----------------------------------------------- echo "-----------------------------------------------"
exit 1 exit 1
fi fi
#检测不支持的加密协议 #检测不支持的加密协议
if cat "$core_config_new" | grep 'cipher: chacha20,' >/dev/null; then if cat "$core_config_new" | grep 'cipher: chacha20,' >/dev/null; then
echo ----------------------------------------------- echo "-----------------------------------------------"
logger "已停止支持chacha20加密请更换更安全的节点加密协议" 31 logger "已停止支持chacha20加密请更换更安全的节点加密协议" 31
echo ----------------------------------------------- echo "-----------------------------------------------"
exit 1 exit 1
fi fi
#检测并去除无效策略组 #检测并去除无效策略组
@@ -292,7 +292,7 @@ check_clash_config() { #检查clash配置文件
check_singbox_config() { #检查singbox配置文件 check_singbox_config() { #检查singbox配置文件
#检测节点或providers #检测节点或providers
if ! grep -qE '"(socks|http|shadowsocks(r)?|vmess|trojan|wireguard|hysteria(2)?|vless|shadowtls|tuic|ssh|tor|providers|anytls|soduku)"' "$core_config_new"; then if ! grep -qE '"(socks|http|shadowsocks(r)?|vmess|trojan|wireguard|hysteria(2)?|vless|shadowtls|tuic|ssh|tor|providers|anytls|soduku)"' "$core_config_new"; then
echo ----------------------------------------------- echo "-----------------------------------------------"
logger "获取到了配置文件【$core_config_new】,但似乎并不包含正确的节点信息!" 31 logger "获取到了配置文件【$core_config_new】,但似乎并不包含正确的节点信息!" 31
echo "请尝试使用6-2或者6-3的方式生成配置文件" echo "请尝试使用6-2或者6-3的方式生成配置文件"
exit 1 exit 1
@@ -341,7 +341,7 @@ get_core_config() { #下载内核配置文件
url_type=true url_type=true
fi fi
#输出 #输出
echo ----------------------------------------------- echo "-----------------------------------------------"
logger 正在连接服务器获取【${target}】配置文件………… logger 正在连接服务器获取【${target}】配置文件…………
echo -e "链接地址为:\033[4;32m$Https\033[0m" echo -e "链接地址为:\033[4;32m$Https\033[0m"
echo 可以手动复制该链接到浏览器打开并查看数据是否正常! echo 可以手动复制该链接到浏览器打开并查看数据是否正常!
@@ -351,10 +351,10 @@ get_core_config() { #下载内核配置文件
$0 webget "$core_config_new" "$Https" echoon rediron skipceron "$user_agent" $0 webget "$core_config_new" "$Https" echoon rediron skipceron "$user_agent"
if [ "$?" = "1" ]; then if [ "$?" = "1" ]; then
if [ -z "$url_type" ]; then if [ -z "$url_type" ]; then
echo ----------------------------------------------- echo "-----------------------------------------------"
logger "配置文件获取失败!" 31 logger "配置文件获取失败!" 31
echo -e "\033[31m请尝试使用【在线生成配置文件】功能\033[0m" echo -e "\033[31m请尝试使用【在线生成配置文件】功能\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
exit 1 exit 1
else else
if [ "$retry" -ge 3 ]; then if [ "$retry" -ge 3 ]; then
@@ -714,8 +714,8 @@ EOF
#防泄露设置 #防泄露设置
[ "$dns_protect" = "OFF" ] && sed -i 's/"server": "dns_proxy"/"server": "dns_direct"/g' "$TMPDIR"/jsons/route.json [ "$dns_protect" = "OFF" ] && sed -i 's/"server": "dns_proxy"/"server": "dns_direct"/g' "$TMPDIR"/jsons/route.json
#生成add_rule_set.json #生成add_rule_set.json
[ "$dns_mod" = "mix" ] || [ "$dns_mod" = "route" ] && \ [ "$dns_mod" = "mix" ] || [ "$dns_mod" = "route" ] &&
[ -z "$(cat "$CRASHDIR"/jsons/*.json | grep -Ei '"tag" *: *"cn"')" ] && \ [ -z "$(cat "$CRASHDIR"/jsons/*.json | grep -Ei '"tag" *: *"cn"')" ] &&
cat >"$TMPDIR"/jsons/add_rule_set.json <<EOF cat >"$TMPDIR"/jsons/add_rule_set.json <<EOF
{ {
"route": { "route": {
@@ -1817,7 +1817,7 @@ core_exchange() { #升级为高级内核
rm -rf "$BINDIR"/CrashCore.tar.gz rm -rf "$BINDIR"/CrashCore.tar.gz
crashcore="$1" crashcore="$1"
setconfig crashcore "$1" setconfig crashcore "$1"
echo ----------------------------------------------- echo "-----------------------------------------------"
} }
clash_check() { #clash启动前检查 clash_check() { #clash启动前检查
#检测vless/hysteria协议 #检测vless/hysteria协议

View File

@@ -195,7 +195,7 @@ set_cron(){
[ -z $week ] && week=* [ -z $week ] && week=*
[ -z $hour ] && hour=* [ -z $hour ] && hour=*
[ -z $min ] && min=0 [ -z $min ] && min=0
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "\033[33m$cron_time\033[0m执行任务:\033[36m$task_name\033[0m" echo -e "\033[33m$cron_time\033[0m执行任务:\033[36m$task_name\033[0m"
read -p "是否确认添加定时任务?(1/0) > " res read -p "是否确认添加定时任务?(1/0) > " res
if [ "$res" = '1' ]; then if [ "$res" = '1' ]; then
@@ -223,7 +223,7 @@ set_service(){
} }
#任务界面 #任务界面
task_user_add(){ #自定义命令添加 task_user_add(){ #自定义命令添加
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "\033[33m命令可包含空格请确保命令可执行\033[0m" echo -e "\033[33m命令可包含空格请确保命令可执行\033[0m"
echo -e "\033[36m此处不要添加执行条件请在添加完成后返回添加具体执行条件\033[0m" echo -e "\033[36m此处不要添加执行条件请在添加完成后返回添加具体执行条件\033[0m"
echo -e "也可以手动编辑\033[32m${CRASHDIR}/task/task.user\033[0m添加" echo -e "也可以手动编辑\033[32m${CRASHDIR}/task/task.user\033[0m添加"
@@ -246,14 +246,14 @@ task_user_add(){ #自定义命令添加
fi fi
} }
task_user_del(){ #自定义命令删除 task_user_del(){ #自定义命令删除
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "请输入对应ID移除对应自定义任务(不会影响内置任务)" echo -e "请输入对应ID移除对应自定义任务(不会影响内置任务)"
echo -e "也可以手动编辑\033[32m${CRASHDIR}/task/task.user\033[0m" echo -e "也可以手动编辑\033[32m${CRASHDIR}/task/task.user\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
cat ${CRASHDIR}/task/task.user 2>/dev/null | grep -Ev '^#' | awk -F '#' '{print $1" "$3}' cat ${CRASHDIR}/task/task.user 2>/dev/null | grep -Ev '^#' | awk -F '#' '{print $1" "$3}'
echo ----------------------------------------------- echo "-----------------------------------------------"
echo 0 返回上级菜单 echo 0 返回上级菜单
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "请输入对应数字 > " num read -p "请输入对应数字 > " num
if [ -n "$num" ];then if [ -n "$num" ];then
sed -i "/^$num#/d" ${CRASHDIR}/task/task.user 2>/dev/null sed -i "/^$num#/d" ${CRASHDIR}/task/task.user 2>/dev/null
@@ -264,12 +264,12 @@ task_user_del(){ #自定义命令删除
fi fi
} }
task_add(){ #任务添加 task_add(){ #任务添加
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "\033[36m请选择需要添加的任务\033[0m" echo -e "\033[36m请选择需要添加的任务\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
#输出任务列表 #输出任务列表
cat ${CRASHDIR}/task/task.list ${CRASHDIR}/task/task.user 2>/dev/null | grep -Ev '^(#|$)' | awk -F '#' '{print " "NR" "$3}' cat ${CRASHDIR}/task/task.list ${CRASHDIR}/task/task.user 2>/dev/null | grep -Ev '^(#|$)' | awk -F '#' '{print " "NR" "$3}'
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 0 返回上级菜单" echo -e " 0 返回上级菜单"
read -p "请输入对应数字 > " num read -p "请输入对应数字 > " num
case "$num" in case "$num" in
@@ -301,9 +301,9 @@ task_del(){ #任务删除
sed -i "/$1/d" ${CRASHDIR}/task/affirewall 2>/dev/null sed -i "/$1/d" ${CRASHDIR}/task/affirewall 2>/dev/null
} }
task_type(){ #任务条件选择菜单 task_type(){ #任务条件选择菜单
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "请选择任务\033[36m【$task_name】\033[0m执行条件" echo -e "请选择任务\033[36m【$task_name】\033[0m执行条件"
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 1 定时任务\033[32m每周执行\033[0m" echo -e " 1 定时任务\033[32m每周执行\033[0m"
echo -e " 2 定时任务\033[32m每日执行\033[0m" echo -e " 2 定时任务\033[32m每日执行\033[0m"
echo -e " 3 定时任务\033[32m每小时执行\033[0m" echo -e " 3 定时任务\033[32m每小时执行\033[0m"
@@ -312,7 +312,7 @@ task_type(){ #任务条件选择菜单
echo -e " 6 服务\033[33m启动后执行\033[0m" echo -e " 6 服务\033[33m启动后执行\033[0m"
echo -e " 7 服务\033[33m运行时每分钟执行\033[0m" echo -e " 7 服务\033[33m运行时每分钟执行\033[0m"
echo -e " 8 防火墙服务\033[33m重启后执行\033[0m" echo -e " 8 防火墙服务\033[33m重启后执行\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 0 返回上级菜单" echo -e " 0 返回上级菜单"
read -p "请输入对应数字 > " num read -p "请输入对应数字 > " num
case "$num" in case "$num" in
@@ -321,37 +321,37 @@ task_type(){ #任务条件选择菜单
return 1 return 1
;; ;;
1) 1)
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 输入 1-7 对应\033[33m每周的指定某天\033[0m运行(7=周日)" echo -e " 输入 1-7 对应\033[33m每周的指定某天\033[0m运行(7=周日)"
echo -e " 输入 1,4,0 代表\033[36m每周一、周四、周日\033[0m运行" echo -e " 输入 1,4,0 代表\033[36m每周一、周四、周日\033[0m运行"
echo -e " 输入 1-5 代表\033[36m周一至周五\033[0m运行" echo -e " 输入 1-5 代表\033[36m周一至周五\033[0m运行"
read -p "在每周哪天执行? > " week read -p "在每周哪天执行? > " week
week=`echo ${week/7/0}` #把7换成0 week=`echo ${week/7/0}` #把7换成0
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "想在该日的具体哪个小时执行0-23 > " hour read -p "想在该日的具体哪个小时执行0-23 > " hour
cron_time="在每周$week的$hour点整" cron_time="在每周$week的$hour点整"
cron_time=`echo ${cron_time/周0/周日}` #把0换成日 cron_time=`echo ${cron_time/周0/周日}` #把0换成日
[ -n "$week" ] && [ -n "$hour" ] && set_cron [ -n "$week" ] && [ -n "$hour" ] && set_cron
;; ;;
2) 2)
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 输入 1,7,15 代表\033[36m每到1,7,15点\033[0m运行" echo -e " 输入 1,7,15 代表\033[36m每到1,7,15点\033[0m运行"
echo -e " 输入 6-18 代表\033[36m早6点至晚18点间每小时\033[0m运行" echo -e " 输入 6-18 代表\033[36m早6点至晚18点间每小时\033[0m运行"
read -p "想在每日的具体哪个小时执行0-23 > " hour read -p "想在每日的具体哪个小时执行0-23 > " hour
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "想在具体哪分钟执行0-59的整数 > " min read -p "想在具体哪分钟执行0-59的整数 > " min
cron_time="在每日的$hour点$min分" cron_time="在每日的$hour点$min分"
[ -n "$min" ] && [ -n "$hour" ] && set_cron [ -n "$min" ] && [ -n "$hour" ] && set_cron
;; ;;
3) 3)
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "想每隔多少小时执行一次1-23的整数 > " num read -p "想每隔多少小时执行一次1-23的整数 > " num
hour="*/$num" hour="*/$num"
cron_time="每隔$num小时" cron_time="每隔$num小时"
[ -n "$hour" ] && set_cron [ -n "$hour" ] && set_cron
;; ;;
4) 4)
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "想每隔多少分钟执行一次1-59的整数 > " num read -p "想每隔多少分钟执行一次1-59的整数 > " num
min="*/$num" min="*/$num"
cron_time="每隔$num分钟" cron_time="每隔$num分钟"
@@ -364,7 +364,7 @@ task_type(){ #任务条件选择菜单
set_service afstart "$task_id" "服务启动后$task_name" set_service afstart "$task_id" "服务启动后$task_name"
;; ;;
7) 7)
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 输入10即每隔10分钟运行一次1440即每隔24小时运行一次" echo -e " 输入10即每隔10分钟运行一次1440即每隔24小时运行一次"
echo -e " 大于60分钟的数值将按小时取整,且按当前时区记时" echo -e " 大于60分钟的数值将按小时取整,且按当前时区记时"
read -p "想每隔多少分钟执行一次1-1440的整数 > " num read -p "想每隔多少分钟执行一次1-1440的整数 > " num
@@ -391,7 +391,7 @@ task_type(){ #任务条件选择菜单
esac esac
} }
task_manager(){ #任务管理列表 task_manager(){ #任务管理列表
echo ----------------------------------------------- echo "-----------------------------------------------"
#抽取并生成临时列表 #抽取并生成临时列表
croncmd -l > ${TMPDIR}/task_cronlist croncmd -l > ${TMPDIR}/task_cronlist
cat ${TMPDIR}/task_cronlist ${CRASHDIR}/task/running 2>/dev/null | sort -u | grep -oE "task/task.sh .*" | awk -F ' ' '{print $2" "$3}' > ${TMPDIR}/task_list cat ${TMPDIR}/task_cronlist ${CRASHDIR}/task/running 2>/dev/null | sort -u | grep -oE "task/task.sh .*" | awk -F ' ' '{print $2" "$3}' > ${TMPDIR}/task_list
@@ -405,9 +405,9 @@ task_manager(){ #任务管理列表
sleep 1 sleep 1
else else
echo -e "\033[33m已添加的任务:\033[0m" echo -e "\033[33m已添加的任务:\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
cat ${TMPDIR}/task_list | awk '{print " " NR " " $2}' cat ${TMPDIR}/task_list | awk '{print " " NR " " $2}'
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " a 清空旧版任务" echo -e " a 清空旧版任务"
echo -e " d 清空任务列表" echo -e " d 清空任务列表"
echo -e " 0 返回上级菜单" echo -e " 0 返回上级菜单"
@@ -440,13 +440,13 @@ task_manager(){ #任务管理列表
else else
task_des=$(echo $task_txt | awk '{print $2}') task_des=$(echo $task_txt | awk '{print $2}')
task_name=$(cat ${CRASHDIR}/task/task.list ${CRASHDIR}/task/task.user 2>/dev/null | grep "$task_id" | awk -F '#' '{print $3}') task_name=$(cat ${CRASHDIR}/task/task.list ${CRASHDIR}/task/task.user 2>/dev/null | grep "$task_id" | awk -F '#' '{print $3}')
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "当前任务为:\033[36m $task_des\033[0m" echo -e "当前任务为:\033[36m $task_des\033[0m"
echo -e " 1 \033[33m修改\033[0m当前任务" echo -e " 1 \033[33m修改\033[0m当前任务"
echo -e " 2 \033[31m删除\033[0m当前任务" echo -e " 2 \033[31m删除\033[0m当前任务"
echo -e " 3 \033[32m立即执行\033[0m一次" echo -e " 3 \033[32m立即执行\033[0m一次"
echo -e " 4 查看\033[33m执行记录\033[0m" echo -e " 4 查看\033[33m执行记录\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 0 返回上级菜单" echo -e " 0 返回上级菜单"
read -p "请选择需要执行的操作 > " num read -p "请选择需要执行的操作 > " num
case "$num" in case "$num" in
@@ -465,7 +465,7 @@ task_manager(){ #任务管理列表
sleep 1 sleep 1
;; ;;
4) 4)
echo ----------------------------------------------- echo "-----------------------------------------------"
if [ -n "$(cat ${TMPDIR}/ShellCrash.log | grep "$task_name")" ];then if [ -n "$(cat ${TMPDIR}/ShellCrash.log | grep "$task_name")" ];then
cat ${TMPDIR}/ShellCrash.log | grep "$task_name" cat ${TMPDIR}/ShellCrash.log | grep "$task_name"
else else
@@ -487,13 +487,13 @@ task_manager(){ #任务管理列表
fi fi
} }
task_recom(){ #任务推荐 task_recom(){ #任务推荐
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "\033[32m启用推荐的自动任务配置这包括\033[0m" echo -e "\033[32m启用推荐的自动任务配置这包括\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "每隔10分钟自动保存面板配置" echo -e "每隔10分钟自动保存面板配置"
echo -e "服务启动后自动同步ntp时间" echo -e "服务启动后自动同步ntp时间"
echo -e "在每日的3点0分重启服务" echo -e "在每日的3点0分重启服务"
echo ----------------------------------------------- echo "-----------------------------------------------"
read -p "是否启用?(1/0) > " res read -p "是否启用?(1/0) > " res
[ "$res" = 1 ] && { [ "$res" = 1 ] && {
set_service running "106" "运行时每10分钟自动保存面板配置" "*/10 * * * *" set_service running "106" "运行时每10分钟自动保存面板配置" "*/10 * * * *"
@@ -505,9 +505,9 @@ task_recom(){ #任务推荐
task_menu(){ #任务菜单 task_menu(){ #任务菜单
#检测并创建自定义任务文件 #检测并创建自定义任务文件
[ -f ${CRASHDIR}/task/task.user ] || echo '#任务ID(必须>200并顺序排列)#任务命令#任务说明(#号隔开,任务命令和说明中都不允许包含#号)' > ${CRASHDIR}/task/task.user [ -f ${CRASHDIR}/task/task.user ] || echo '#任务ID(必须>200并顺序排列)#任务命令#任务说明(#号隔开,任务命令和说明中都不允许包含#号)' > ${CRASHDIR}/task/task.user
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "\033[30;47m欢迎使用自动任务功能\033[0m" echo -e "\033[30;47m欢迎使用自动任务功能\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 1 添加\033[32m自动任务\033[0m" echo -e " 1 添加\033[32m自动任务\033[0m"
echo -e " 2 管理\033[33m任务列表\033[0m" echo -e " 2 管理\033[33m任务列表\033[0m"
echo -e " 3 查看\033[36m任务日志\033[0m" echo -e " 3 查看\033[36m任务日志\033[0m"
@@ -515,7 +515,7 @@ task_menu(){ #任务菜单
echo -e " 5 添加\033[33m自定义任务\033[0m" echo -e " 5 添加\033[33m自定义任务\033[0m"
echo -e " 6 删除\033[33m自定义任务\033[0m" echo -e " 6 删除\033[33m自定义任务\033[0m"
echo -e " 7 使用\033[32m推荐设置\033[0m" echo -e " 7 使用\033[32m推荐设置\033[0m"
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e " 0 返回上级菜单" echo -e " 0 返回上级菜单"
read -p "请输入对应数字 > " num read -p "请输入对应数字 > " num
case "$num" in case "$num" in
@@ -532,7 +532,7 @@ task_menu(){ #任务菜单
;; ;;
3) 3)
if [ -n "$(cat ${TMPDIR}/ShellCrash.log | grep '任务【')" ];then if [ -n "$(cat ${TMPDIR}/ShellCrash.log | grep '任务【')" ];then
echo ----------------------------------------------- echo "-----------------------------------------------"
cat ${TMPDIR}/ShellCrash.log | grep '任务【' cat ${TMPDIR}/ShellCrash.log | grep '任务【'
else else
echo -e "\033[31m未找到任务相关执行日志\033[0m" echo -e "\033[31m未找到任务相关执行日志\033[0m"
@@ -541,7 +541,7 @@ task_menu(){ #任务菜单
task_menu task_menu
;; ;;
4) 4)
echo ----------------------------------------------- echo "-----------------------------------------------"
echo -e "\033[36m请在日志工具中配置相关推送通道及推送开关\033[0m" echo -e "\033[36m请在日志工具中配置相关推送通道及推送开关\033[0m"
log_pusher log_pusher
task_menu task_menu
@@ -581,4 +581,3 @@ case "$1" in
$1 $1
;; ;;
esac esac

File diff suppressed because it is too large Load Diff