2020-09-13 19:33:39 +08:00
|
|
|
|
#!/bin/bash
|
2020-08-06 17:20:45 +08:00
|
|
|
|
# Copyright (C) Juewuy
|
|
|
|
|
|
2020-08-24 19:39:50 +08:00
|
|
|
|
linkconfig(){
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[44m 实验性功能,遇问题请加TG群反馈:\033[42;30m t.me/clashfm \033[0m"
|
|
|
|
|
echo 当前使用规则为:$rule_link
|
2020-09-29 19:02:28 +08:00
|
|
|
|
echo 1 ACL4SSR通用版无去广告(推荐)
|
|
|
|
|
echo 2 ACL4SSR精简全能版(推荐)
|
|
|
|
|
echo 3 ACL4SSR通用版+去广告加强
|
|
|
|
|
echo 4 ACL4SSR精简版+去广告加强
|
|
|
|
|
echo 5 ACL4SSR重度全分组+奈飞分流
|
|
|
|
|
echo 6 ACL4SSR重度全分组+去广告加强
|
|
|
|
|
echo 7 洞主规则精简版(推荐)
|
|
|
|
|
echo 8 洞主规则重度完整版
|
|
|
|
|
echo 9 神机规则高级版
|
|
|
|
|
echo 10 神机规则-回国专用
|
|
|
|
|
echo 11 李哥规则-墙洞专用
|
|
|
|
|
echo 12 基础规则-仅Geoip CN+Final
|
|
|
|
|
echo 13 网易云解锁-仅规则分组
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo 0 返回上级菜单
|
|
|
|
|
read -p "请输入对应数字 > " num
|
2020-09-29 19:02:28 +08:00
|
|
|
|
if [ -z "$num" ] || [[ $num -gt 13 ]];then
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
elif [[ "$num" = 0 ]];then
|
|
|
|
|
echo
|
2020-09-29 19:02:28 +08:00
|
|
|
|
elif [[ $num -le 13 ]];then
|
2020-08-24 19:39:50 +08:00
|
|
|
|
#将对应标记值写入mark
|
|
|
|
|
sed -i '/rule_link*/'d $ccfg
|
|
|
|
|
sed -i "4i\rule_link="$num"" $ccfg
|
|
|
|
|
rule_link=$num
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[32m设置成功!返回上级菜单\033[0m"
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
linkserver(){
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[44m 实验性功能,遇问题请加TG群反馈:\033[42;30m t.me/clashfm \033[0m"
|
|
|
|
|
echo 当前使用后端为:$server_link
|
|
|
|
|
echo 1 subconverter-web.now.sh
|
|
|
|
|
echo 2 subconverter.herokuapp.com
|
|
|
|
|
echo 3 subcon.py6.pw
|
|
|
|
|
echo 4 api.dler.io
|
|
|
|
|
echo 5 api.wcc.best
|
|
|
|
|
echo 6 skapi.cool
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo 0 返回上级菜单
|
|
|
|
|
read -p "请输入对应数字 > " num
|
|
|
|
|
if [ -z "$num" ] || [[ $num -gt 6 ]];then
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
elif [[ "$num" = 0 ]];then
|
|
|
|
|
echo
|
|
|
|
|
elif [[ $num -le 6 ]];then
|
|
|
|
|
#将对应标记值写入mark
|
|
|
|
|
sed -i '/server_link*/'d $ccfg
|
|
|
|
|
sed -i "4i\server_link="$num"" $ccfg
|
|
|
|
|
server_link=$num
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[32m设置成功!返回上级菜单\033[0m"
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
linkfilter(){
|
|
|
|
|
[ -z "$exclude" ] && exclude="未设置"
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[44m 实验性功能,遇问题请加TG群反馈:\033[42;30m t.me/clashfm \033[0m"
|
|
|
|
|
echo -e "\033[33m当前过滤关键字:\033[47;30m$exclude\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e "\033[36m匹配关键字的节点会在导入时被屏蔽\033[0m"
|
|
|
|
|
echo -e "多个关键字可以用\033[30;47m | \033[0m号分隔"
|
2020-10-01 18:45:26 +08:00
|
|
|
|
echo -e "\033[32m支持正则表达式\033[0m,空格请使用\033[30;47m + \033[0m号替代"
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e " 000 \033[31m删除\033[0m关键字"
|
|
|
|
|
echo -e " 回车 取消输入并返回上级菜单"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
read -p "请输入关键字 > " exclude
|
|
|
|
|
if [ -z "$exclude" ]; then
|
|
|
|
|
linkset
|
|
|
|
|
elif [ "$exclude" = '000' ]; then
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
exclude=''
|
|
|
|
|
echo -e "\033[31m 已删除节点过滤关键字!!!\033[0m"
|
|
|
|
|
fi
|
|
|
|
|
sed -i '/exclude=*/'d $ccfg
|
2020-08-29 16:09:52 +08:00
|
|
|
|
sed -i "1i\exclude=\'$exclude\'" $ccfg
|
2020-08-24 19:39:50 +08:00
|
|
|
|
linkset
|
|
|
|
|
}
|
|
|
|
|
linkset(){
|
|
|
|
|
if [ -n $Url ];then
|
2020-09-28 20:56:00 +08:00
|
|
|
|
[ -z "$skip_cert" ] && skip_cert=已开启
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[47;30m请检查输入的链接是否正确:\033[0m"
|
|
|
|
|
echo -e "\033[32;4m$Url\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e " 1 \033[32m生成配置文件(原文件将被备份)\033[0m"
|
|
|
|
|
echo -e " 2 \033[36m添加/修改节点过滤关键字 \033[47;30m$exclude\033[0m"
|
|
|
|
|
echo -e " 3 \033[33m选取配置规则模版\033[0m"
|
|
|
|
|
echo -e " 4 \033[0m选取在线生成服务器\033[0m"
|
2020-09-28 20:56:00 +08:00
|
|
|
|
echo -e " 5 \033[0m跳过本地证书验证: \033[36m$skip_cert\033[0m ————自建tls节点务必开启"
|
2020-09-08 18:12:18 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo -e " 0 \033[31m取消导入\033[0m并返回上级菜单"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
read -p "请输入对应数字 > " num
|
|
|
|
|
if [ -z "$num" ]; then
|
|
|
|
|
clashlink
|
|
|
|
|
elif [ "$num" = '0' ]; then
|
|
|
|
|
clashlink
|
|
|
|
|
elif [ "$num" = '1' ]; then
|
|
|
|
|
#将用户链接写入mark
|
|
|
|
|
sed -i '/Url=*/'d $ccfg
|
|
|
|
|
sed -i '/Https=*/'d $ccfg
|
|
|
|
|
sed -i "6i\Url=\'$Url\'" $ccfg
|
|
|
|
|
Https=""
|
|
|
|
|
#获取在线yaml文件
|
2020-09-29 19:02:28 +08:00
|
|
|
|
$clashdir/start.sh getyaml
|
|
|
|
|
start_over
|
|
|
|
|
exit;
|
2020-08-24 19:39:50 +08:00
|
|
|
|
elif [ "$num" = '2' ]; then
|
|
|
|
|
linkfilter
|
|
|
|
|
linkset
|
|
|
|
|
elif [ "$num" = '3' ]; then
|
|
|
|
|
linkconfig
|
|
|
|
|
linkset
|
|
|
|
|
elif [ "$num" = '4' ]; then
|
|
|
|
|
linkserver
|
|
|
|
|
linkset
|
2020-09-08 18:12:18 +08:00
|
|
|
|
elif [ "$num" = '5' ]; then
|
|
|
|
|
sed -i '/skip_cert*/'d $ccfg
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
if [ "$skip_cert" = "未开启" ] > /dev/null 2>&1; then
|
|
|
|
|
sed -i "1i\skip_cert=已开启" $ccfg
|
|
|
|
|
#echo -e "\033[33m已设为开启跳过本地证书验证!!\033[0m"
|
|
|
|
|
skip_cert=已开启
|
|
|
|
|
else
|
|
|
|
|
sed -i "1i\skip_cert=未开启" $ccfg
|
|
|
|
|
#echo -e "\033[33m已设为禁止跳过本地证书验证!!\033[0m"
|
|
|
|
|
skip_cert=未开启
|
|
|
|
|
fi
|
|
|
|
|
linkset
|
2020-08-24 19:39:50 +08:00
|
|
|
|
else
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
linkset
|
|
|
|
|
fi
|
|
|
|
|
clashlink
|
|
|
|
|
fi
|
|
|
|
|
}
|
2020-08-06 17:20:45 +08:00
|
|
|
|
getlink(){
|
|
|
|
|
#设置输入循环
|
|
|
|
|
i=1
|
2020-08-10 20:24:28 +08:00
|
|
|
|
while [ $i -le 99 ]
|
2020-08-06 17:20:45 +08:00
|
|
|
|
do
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[44m 遇问题请加TG群反馈:\033[42;30m t.me/clashfm \033[0m"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -e "支持批量导入\033[30;46m Http/Https/Clash \033[0m等格式的订阅链接"
|
2020-09-28 20:56:00 +08:00
|
|
|
|
echo -e "以及\033[30;42m Vmess/SSR/SS/Trojan \033[0m等格式的节点链接"
|
|
|
|
|
echo -e "自建Trojan节点链接格式为:trojan://密码@host地址:443"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-18 20:30:05 +08:00
|
|
|
|
echo -e "多个较短的链接可以用\033[30;47m | \033[0m号分隔以一次性输入"
|
|
|
|
|
echo -e "多个较长的链接可分次输入,支持多达\033[30;47m 99 \033[0m次输入"
|
|
|
|
|
echo -----------------------------------------------
|
2020-10-02 09:43:46 +08:00
|
|
|
|
echo -e " 0 \033[31m撤销输入\033[0m"
|
|
|
|
|
echo -e "回车 \033[32m完成输入\033[0m并\033[33m开始导入\033[0m配置文件!"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
read -p "请输入第"$i"个链接 > " url
|
|
|
|
|
test=$(echo $url | grep "://")
|
|
|
|
|
url=`echo ${url/\ \(*\)/''}` #删除恶心的超链接内容
|
|
|
|
|
url=`echo ${url/*\&url\=/""}` #将clash完整链接还原成单一链接
|
|
|
|
|
url=`echo ${url/\&config\=*/""}` #将clash完整链接还原成单一链接
|
|
|
|
|
url=`echo ${url//\&/\%26}` #将分隔符 & 替换成urlcode:%26
|
|
|
|
|
if [[ "$test" != "" ]];then
|
2020-10-01 18:45:26 +08:00
|
|
|
|
if [ -z "$Url" ];then
|
2020-08-09 13:51:37 +08:00
|
|
|
|
Url="$url"
|
|
|
|
|
else
|
|
|
|
|
Url="$Url"\|"$url"
|
|
|
|
|
fi
|
|
|
|
|
i=$(($i+1))
|
|
|
|
|
elif [ -z $url ];then
|
2020-10-01 18:45:26 +08:00
|
|
|
|
[ -n "$Url" ] && linkset
|
2020-08-09 13:51:37 +08:00
|
|
|
|
elif [[ $url == 0 ]];then
|
2020-10-02 09:43:46 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[31m已撤销并删除所有已输入的链接!!!\033[0m"
|
2020-10-01 18:45:26 +08:00
|
|
|
|
Url=""
|
2020-10-02 09:43:46 +08:00
|
|
|
|
sleep 1
|
2020-08-09 13:51:37 +08:00
|
|
|
|
clashlink
|
2020-08-06 17:20:45 +08:00
|
|
|
|
else
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "\033[31m请输入正确的订阅/分享链接!!!\033[0m"
|
2020-08-06 17:20:45 +08:00
|
|
|
|
fi
|
|
|
|
|
done
|
2020-08-09 13:51:37 +08:00
|
|
|
|
####
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo 输入太多啦,可能会导致订阅失败!
|
|
|
|
|
echo "多个较短的链接请尽量用“|”分隔以一次性输入!"
|
2020-08-24 19:39:50 +08:00
|
|
|
|
clashlink
|
2020-08-06 17:20:45 +08:00
|
|
|
|
}
|
|
|
|
|
getlink2(){
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-09-29 19:02:28 +08:00
|
|
|
|
echo -e "\033[30;47m 此功能不明勿用!\033[0m"
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-29 16:09:52 +08:00
|
|
|
|
echo -e "\033[33m仅限导入完整clash链接!!!\033[0m"
|
|
|
|
|
echo -e "可以使用\033[32m https://acl4ssr.netlify.app \033[0m在线转换"
|
2020-08-19 14:29:55 +08:00
|
|
|
|
echo -e "\033[36m导入后如无法运行,请使用【导入节点/订阅链接】功能"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo -e "\033[33m0 返回上级菜单\033[0m"
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
read -p "请输入完整链接 > " Https
|
2020-08-09 13:51:37 +08:00
|
|
|
|
test=$(echo $Https | grep "://")
|
|
|
|
|
Https=`echo ${Https/\ \(*\)/''}` #删除恶心的超链接内容
|
|
|
|
|
#Https=`echo ${Https//\&/\%26}` #将分隔符 & 替换成Httpscode:%26
|
|
|
|
|
if [ -n $Https ];then
|
|
|
|
|
if [ -n $test ];then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-06 19:57:28 +08:00
|
|
|
|
echo -e 请检查输入的链接是否正确:
|
|
|
|
|
echo -e "\033[4m$Https\033[0m"
|
|
|
|
|
read -p "确认导入配置文件?原配置文件将被更名为config.yaml.bak![1/0] > " res
|
|
|
|
|
if [ "$res" = '1' ]; then
|
2020-08-09 13:51:37 +08:00
|
|
|
|
#将用户链接写入mark
|
|
|
|
|
sed -i '/Url=*/'d $ccfg
|
|
|
|
|
sed -i '/Https=*/'d $ccfg
|
|
|
|
|
sed -i "6i\Https=\'$Https\'" $ccfg
|
|
|
|
|
#获取在线yaml文件
|
2020-09-19 16:32:50 +08:00
|
|
|
|
$clashdir/start.sh getyaml
|
2020-09-29 19:02:28 +08:00
|
|
|
|
start_over
|
|
|
|
|
exit;
|
2020-08-06 19:57:28 +08:00
|
|
|
|
fi
|
|
|
|
|
clashlink
|
|
|
|
|
fi
|
2020-08-09 13:51:37 +08:00
|
|
|
|
elif [[ $Https == 0 ]];then
|
|
|
|
|
clashlink
|
|
|
|
|
else
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "\033[31m请输入正确的链接地址!!!\033[0m"
|
|
|
|
|
fi
|
2020-08-06 17:20:45 +08:00
|
|
|
|
}
|
2020-09-21 23:51:03 +08:00
|
|
|
|
gettar(){
|
|
|
|
|
result=$(curl -w %{http_code} -kLo /tmp/clashfm.tar.gz $tarurl)
|
2020-08-09 13:51:37 +08:00
|
|
|
|
[ "$result" != "200" ] && echo "文件下载失败!" && exit 1
|
|
|
|
|
#解压
|
2020-09-21 23:51:03 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo 开始解压文件!
|
2020-08-10 20:46:10 +08:00
|
|
|
|
mkdir -p $clashdir > /dev/null
|
2020-09-21 23:51:03 +08:00
|
|
|
|
tar -zxvf '/tmp/clashfm.tar.gz' -C $clashdir/
|
2020-08-09 13:51:37 +08:00
|
|
|
|
[ $? -ne 0 ] && echo "文件解压失败!" && exit 1
|
2020-09-21 23:51:03 +08:00
|
|
|
|
#初始化文件目录
|
|
|
|
|
[ -f "$clashdir/mark" ] || echo '#标识clash运行状态的文件,不明勿动!' > $clashdir/mark
|
2020-09-18 21:09:06 +08:00
|
|
|
|
#判断系统类型写入不同的启动文件
|
2020-09-20 17:57:21 +08:00
|
|
|
|
if [ -f /etc/rc.common ];then
|
2020-09-21 23:51:03 +08:00
|
|
|
|
#设为init.d方式启动
|
|
|
|
|
mv $clashdir/clashservice /etc/init.d/clash
|
|
|
|
|
chmod 777 /etc/init.d/clash
|
2020-09-18 21:09:06 +08:00
|
|
|
|
else
|
|
|
|
|
[ -d /etc/systemd/system ] && sysdir=/etc/systemd/system
|
|
|
|
|
[ -d /usr/lib/systemd/system/ ] && sysdir=/usr/lib/systemd/system/
|
2020-09-20 17:57:21 +08:00
|
|
|
|
if [ -n "$sysdir" ];then
|
2020-09-21 23:51:03 +08:00
|
|
|
|
#设为systemd方式启动
|
|
|
|
|
mv $clashdir/clash.service $sysdir/clash.service
|
|
|
|
|
sed -i "s%/etc/clash%$clashdir%g" $sysdir/clash.service
|
|
|
|
|
systemctl daemon-reload
|
|
|
|
|
rm -rf /etc/init.d/clash
|
2020-09-20 17:57:21 +08:00
|
|
|
|
else
|
2020-09-21 23:51:03 +08:00
|
|
|
|
#设为保守模式启动
|
2020-09-20 17:57:21 +08:00
|
|
|
|
sed -i '/start_old=*/'d $clashdir/mark
|
|
|
|
|
sed -i "1i\start_old=已开启" $clashdir/mark
|
|
|
|
|
fi
|
2020-09-18 21:09:06 +08:00
|
|
|
|
fi
|
2020-09-19 16:46:22 +08:00
|
|
|
|
#修饰文件及版本号
|
|
|
|
|
shtype=sh && [ -n "$(ls -l /bin/sh|grep -o dash)" ] && shtype=bash
|
|
|
|
|
sed -i "s%#!/bin/sh%#!/bin/$shtype%g" $clashdir/start.sh
|
|
|
|
|
chmod 777 $clashdir/start.sh
|
2020-09-21 23:51:03 +08:00
|
|
|
|
sed -i '/versionsh_l=*/'d $clashdir/mark
|
|
|
|
|
sed -i "1i\versionsh_l=$release_new" $clashdir/mark
|
|
|
|
|
#设置环境变量
|
|
|
|
|
sed -i '/alias clash=*/'d /etc/profile
|
|
|
|
|
echo "alias clash=\"$shtype $clashdir/clash.sh\"" >> /etc/profile #设置快捷命令环境变量
|
|
|
|
|
sed -i '/export clashdir=*/'d /etc/profile
|
|
|
|
|
echo "export clashdir=\"$clashdir\"" >> /etc/profile #设置clash路径环境变量
|
2020-08-09 13:51:37 +08:00
|
|
|
|
#删除临时文件
|
|
|
|
|
rm -rf /tmp/clashfm.tar.gz
|
2020-09-21 23:51:03 +08:00
|
|
|
|
rm -rf $clashdir/clashservice
|
|
|
|
|
rm -rf $clashdir/clash.service
|
|
|
|
|
}
|
|
|
|
|
getsh(){
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e "当前脚本版本为:\033[33m $versionsh_l \033[0m"
|
|
|
|
|
echo -e "最新脚本版本为:\033[32m $release_new \033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
read -p "是否更新脚本?[1/0] > " res
|
|
|
|
|
if [ "$res" = '1' ]; then
|
|
|
|
|
tarurl=$update_url/bin/clashfm.tar.gz
|
|
|
|
|
#下载更新
|
|
|
|
|
gettar
|
2020-08-09 13:51:37 +08:00
|
|
|
|
#提示
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e "\033[32m管理脚本更新成功!\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
exit;
|
2020-09-21 23:51:03 +08:00
|
|
|
|
else
|
|
|
|
|
update
|
2020-08-09 13:51:37 +08:00
|
|
|
|
fi
|
2020-08-06 17:20:45 +08:00
|
|
|
|
}
|
|
|
|
|
getcore(){
|
2020-10-02 09:16:12 +08:00
|
|
|
|
#source $ccfg
|
2020-08-06 17:20:45 +08:00
|
|
|
|
#获取核心及版本信息
|
|
|
|
|
if [ ! -f $clashdir/clash ]; then
|
|
|
|
|
clashcore=没有安装核心!
|
2020-08-09 13:51:37 +08:00
|
|
|
|
clashv=''
|
2020-08-06 17:20:45 +08:00
|
|
|
|
fi
|
2020-08-09 13:51:37 +08:00
|
|
|
|
clashcore_n=$clashcore
|
2020-08-14 16:42:52 +08:00
|
|
|
|
#获取设备处理器架构
|
2020-09-28 21:10:37 +08:00
|
|
|
|
cputype=$(uname -ms | tr ' ' '_' | tr '[A-Z]' '[a-z]')
|
|
|
|
|
[ -n "$(echo $cputype | grep -E "linux.*armv.*")" ] && cpucore="armv5"
|
|
|
|
|
[ -n "$(echo $cputype | grep -E "linux.*armv7.*")" ] && cpucore="armv7"
|
|
|
|
|
[ -n "$(echo $cputype | grep -E "linux.*aarch64.*")" ] && cpucore="armv8"
|
|
|
|
|
[ -n "$(echo $cputype | grep -E "linux.*armv8.*")" ] && cpucore="armv8"
|
|
|
|
|
[ -n "$(echo $cputype | grep -E "linux.*x86.*")" ] && cpucore="386"
|
|
|
|
|
[ -n "$(echo $cputype | grep -E "linux.*x86_64.*")" ] && cpucore="amd64"
|
|
|
|
|
if [ -n "$(echo $cputype | grep -E "linux.*mips.*")" ];then
|
2020-09-28 20:56:00 +08:00
|
|
|
|
cpucore="mipsle-softfloat"
|
2020-09-28 22:05:18 +08:00
|
|
|
|
[ -n "$(uname -a | grep -E "M2100")" ] && cpucore="mipsle-hardfloat"
|
2020-09-28 20:56:00 +08:00
|
|
|
|
fi
|
2020-08-14 16:42:52 +08:00
|
|
|
|
###
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "当前clash核心:\033[47;30m $clashcore \033[46;30m$clashv\033[0m"
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo -e "\033[32m请选择需要下载的核心版本!\033[0m"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-17 14:03:06 +08:00
|
|
|
|
echo "1 clash: 稳定,内存占用小,推荐!"
|
2020-10-02 09:16:12 +08:00
|
|
|
|
echo "(官方正式版) 不支持Tun模式、混合模式"
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo
|
2020-09-21 16:51:14 +08:00
|
|
|
|
echo "2 clashpre: 支持Tun模式、混合模式"
|
|
|
|
|
echo "(高级预览版) 内存占用更高"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo 0 返回上级菜单
|
|
|
|
|
read -p "请输入对应数字 > " num
|
2020-08-09 13:51:37 +08:00
|
|
|
|
if [ -z $num ]; then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
update
|
|
|
|
|
elif [[ $num == 0 ]]; then
|
2020-08-06 17:20:45 +08:00
|
|
|
|
update
|
|
|
|
|
elif [[ $num == 1 ]]; then
|
|
|
|
|
clashcore=clash
|
|
|
|
|
elif [[ $num == 2 ]]; then
|
|
|
|
|
clashcore=clashpre
|
2020-09-21 16:51:14 +08:00
|
|
|
|
elif [[ $num == 3 ]]; then
|
|
|
|
|
clashcore=clashr
|
2020-08-06 17:20:45 +08:00
|
|
|
|
else
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-06 17:20:45 +08:00
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
update
|
|
|
|
|
fi
|
2020-08-09 13:51:37 +08:00
|
|
|
|
#生成链接
|
2020-08-06 17:20:45 +08:00
|
|
|
|
corelink="$update_url/bin/$clashcore/clash-linux-$cpucore"
|
|
|
|
|
versionlink="$update_url/bin/$clashcore/version"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
#检测版本
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "\033[33m正在检查更新!\033[0m"
|
|
|
|
|
result=$(curl -w %{http_code} -skLo /tmp/clashversion $versionlink)
|
|
|
|
|
[ "$result" != "200" ] && echo "检查更新失败!" && exit 1
|
|
|
|
|
source /tmp/clashversion
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "当前clash核心:\033[0m $clashcore_n \033[33m$clashv\033[0m"
|
|
|
|
|
echo -e "最新clash核心:\033[32m $clashcore \033[36m$version\033[0m"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
read -p "是否更新?[1/0] > " res
|
|
|
|
|
if [ "$res" = '1' ]; then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo 正在连接服务器获取clash核心文件…………链接地址为:
|
|
|
|
|
echo -e "\033[4;32m$corelink\033[0m"
|
|
|
|
|
echo 如无法正常下载可以手动复制到浏览器下载核心文件!
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -e "\033[36m~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "| |"
|
|
|
|
|
echo -e "| 需要一点时间,请耐心等待! |"
|
|
|
|
|
echo -e "| \033[0m如长时间没有数据请用ctrl+c退出 |"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -e "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\033[0m"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
#获取在线clash核心文件
|
|
|
|
|
result=$(curl -w %{http_code} -kLo /tmp/clash.new $corelink)
|
2020-08-06 17:20:45 +08:00
|
|
|
|
if [ "$result" != "200" ];then
|
2020-08-06 19:57:28 +08:00
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e "\033[31m核心文件下载失败!\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
getcore
|
2020-08-06 17:20:45 +08:00
|
|
|
|
else
|
2020-08-06 19:57:28 +08:00
|
|
|
|
echo -e "\033[32m$clashcore核心下载成功,正在替换!\033[0m"
|
|
|
|
|
mv /tmp/clash.new $clashdir/clash
|
|
|
|
|
chmod 777 $clashdir/clash #授予权限
|
2020-08-09 13:51:37 +08:00
|
|
|
|
sed -i '/clashcore=*/'d $ccfg
|
2020-08-06 19:57:28 +08:00
|
|
|
|
sed -i "1i\clashcore=$clashcore" $ccfg
|
2020-08-09 13:51:37 +08:00
|
|
|
|
sed -i '/clashv=*/'d $ccfg
|
|
|
|
|
sed -i "1i\clashv=$version" $ccfg
|
|
|
|
|
rm -rf /tmp/clashversion
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-06 19:57:28 +08:00
|
|
|
|
echo -e "\033[32m$clashcore核心替换成功,请手动启动clash服务!\033[0m"
|
|
|
|
|
clashsh
|
2020-08-06 17:20:45 +08:00
|
|
|
|
fi
|
2020-08-09 13:51:37 +08:00
|
|
|
|
else
|
|
|
|
|
getcore
|
|
|
|
|
fi
|
2020-08-06 17:20:45 +08:00
|
|
|
|
}
|
|
|
|
|
getgeo(){
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-22 19:05:02 +08:00
|
|
|
|
echo -e "\033[33m正在检查更新!\033[0m"
|
2020-10-02 09:16:12 +08:00
|
|
|
|
#echo $update_url
|
2020-08-22 19:05:02 +08:00
|
|
|
|
result=$(curl -w %{http_code} -skLo /tmp/clashversion $update_url/bin/version)
|
|
|
|
|
[ "$result" != "200" ] && echo "检查更新失败!" && exit 1
|
|
|
|
|
source /tmp/clashversion
|
2020-08-07 19:18:14 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-09-12 16:42:57 +08:00
|
|
|
|
echo -e "当前GeoIP版本为:\033[33m $Geo_v \033[0m"
|
|
|
|
|
echo -e "最新GeoIP版本为:\033[32m $GeoIP_v \033[0m"
|
2020-08-22 19:05:02 +08:00
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
read -p "是否更新数据库文件?[1/0] > " res
|
|
|
|
|
if [ "$res" = '1' ]; then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-07 19:18:14 +08:00
|
|
|
|
echo 正在从服务器获取数据库文件…………
|
2020-08-22 19:05:02 +08:00
|
|
|
|
result=$(curl -w %{http_code} -kLo /tmp/Country.mmdb $update_url/bin/Country.mmdb)
|
2020-08-07 19:18:14 +08:00
|
|
|
|
if [ "$result" != "200" ];then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-07 19:18:14 +08:00
|
|
|
|
echo -e "\033[31m文件下载失败!\033[0m"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-07 19:18:14 +08:00
|
|
|
|
getgeo
|
|
|
|
|
else
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-07 19:18:14 +08:00
|
|
|
|
echo -e "\033[32mGeoIP数据库文件下载成功!\033[0m"
|
2020-08-22 19:05:02 +08:00
|
|
|
|
mv /tmp/Country.mmdb $clashdir/Country.mmdb
|
|
|
|
|
sed -i '/Geo_v=*/'d $ccfg
|
|
|
|
|
sed -i "1i\Geo_v=$GeoIP_v" $ccfg
|
|
|
|
|
rm -rf /tmp/clashversion
|
|
|
|
|
clashsh
|
2020-08-07 19:18:14 +08:00
|
|
|
|
fi
|
2020-08-22 19:05:02 +08:00
|
|
|
|
else
|
|
|
|
|
clashsh
|
|
|
|
|
fi
|
2020-08-07 19:18:14 +08:00
|
|
|
|
}
|
|
|
|
|
getdb(){
|
2020-09-18 21:09:06 +08:00
|
|
|
|
#host=$(ubus call network.interface.lan status | grep \"address\" | grep -oE '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}';)
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-07 19:18:14 +08:00
|
|
|
|
echo -e "\033[36m安装本地版dashboard管理面板\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e "\033[32m打开管理面板的速度更快且更稳定"
|
2020-08-22 22:01:58 +08:00
|
|
|
|
echo -e "\033[33m需要占用约500kb的本地空间\033[0m"
|
2020-08-07 19:18:14 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-22 22:01:58 +08:00
|
|
|
|
echo " 1 在/www/clash目录安装(http://$host/clash,可能安装失败!)"
|
2020-08-22 22:54:31 +08:00
|
|
|
|
echo " 2 在$clashdir/ui目录安装(http://$host:9999/ui,安装后需重启clash)"
|
2020-08-22 22:01:58 +08:00
|
|
|
|
echo -----------------------------------------------
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo " 0 返回上级菜单"
|
2020-08-22 22:01:58 +08:00
|
|
|
|
read -p "请输入对应数字 > " num
|
|
|
|
|
|
|
|
|
|
if [ -z "$num" ];then
|
|
|
|
|
update
|
|
|
|
|
elif [ "$num" = '1' ]; then
|
|
|
|
|
dbdir=/www/clash
|
2020-08-22 22:54:31 +08:00
|
|
|
|
hostdir='/clash\033[0;36m访问面板'
|
2020-08-22 22:01:58 +08:00
|
|
|
|
elif [ "$num" = '2' ]; then
|
|
|
|
|
dbdir=$clashdir/ui
|
2020-08-22 22:54:31 +08:00
|
|
|
|
hostdir=':9999/ui\033[0;36m访问面板(需重启clash服务!)'
|
2020-08-22 22:01:58 +08:00
|
|
|
|
else
|
|
|
|
|
update
|
|
|
|
|
fi
|
|
|
|
|
#下载及安装
|
|
|
|
|
if [ -d /www/clash -o -d $clashdir/ui ];then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "\033[31m检测到您已经安装过本地面板了!\033[0m"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
read -p "是否覆盖安装?[1/0] > " res
|
|
|
|
|
if [ -z "$res" ]; then
|
|
|
|
|
update
|
|
|
|
|
elif [ "$res" = 1 ]; then
|
|
|
|
|
rm -rf /www/clash
|
2020-08-22 22:01:58 +08:00
|
|
|
|
rm -rf $clashdir/ui
|
2020-08-07 19:18:14 +08:00
|
|
|
|
else
|
|
|
|
|
update
|
|
|
|
|
fi
|
2020-08-09 13:51:37 +08:00
|
|
|
|
fi
|
|
|
|
|
dblink="$update_url/bin/clashdb.tar.gz"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo 正在连接服务器获取安装文件…………
|
|
|
|
|
result=$(curl -w %{http_code} -kLo /tmp/clashdb.tar.gz $dblink)
|
|
|
|
|
if [ "$result" != "200" ];then
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
echo -e "\033[31m文件下载失败!\033[0m"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-09 13:51:37 +08:00
|
|
|
|
getdb
|
|
|
|
|
else
|
|
|
|
|
echo -e "\033[33m下载成功,正在解压文件!\033[0m"
|
2020-08-22 22:01:58 +08:00
|
|
|
|
mkdir -p $dbdir > /dev/null
|
|
|
|
|
tar -zxvf '/tmp/clashdb.tar.gz' -C $dbdir > /dev/null
|
2020-08-09 13:51:37 +08:00
|
|
|
|
[ $? -ne 0 ] && echo "文件解压失败!" && exit 1
|
2020-08-17 12:44:55 +08:00
|
|
|
|
#修改默认host和端口
|
2020-08-22 22:01:58 +08:00
|
|
|
|
sed -i "s/127.0.0.1/$host/g" $dbdir/js/*.js
|
|
|
|
|
sed -i "s/9090/9999/g" $dbdir/js/*.js
|
2020-08-17 12:44:55 +08:00
|
|
|
|
#
|
|
|
|
|
echo -e "\033[32m面板安装成功!\033[0m"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-22 22:54:31 +08:00
|
|
|
|
echo -e "\033[36m请使用\033[32;4mhttp://$host$hostdir\033[0m"
|
2020-08-09 13:51:37 +08:00
|
|
|
|
rm -rf /tmp/clashdb.tar.gz
|
|
|
|
|
update
|
|
|
|
|
fi
|
2020-08-22 22:01:58 +08:00
|
|
|
|
|
2020-08-06 17:20:45 +08:00
|
|
|
|
update
|
|
|
|
|
}
|
2020-09-08 18:12:18 +08:00
|
|
|
|
catpac(){
|
|
|
|
|
#检测目录
|
|
|
|
|
[ ! -d /www/clash -a ! -d $clashdir/ui ]&&echo 未检测到本地Dashboard面板,请先安装面板!&&sleep 1&&getdb
|
2020-09-18 21:09:06 +08:00
|
|
|
|
#host=$(ubus call network.interface.lan status | grep \"address\" | grep -oE '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}';)
|
2020-09-08 18:12:18 +08:00
|
|
|
|
[ -d /www/clash ]&&dir="/www/clash"&&pac=http://$host/clash/pac
|
|
|
|
|
[ -d $clashdir/ui ]&&dir="$clashdir/ui"&&pac=http://$host:9999/ui/pac
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[30;47m生成用于设备WIFI或浏览器的自动PAC代理文件\033[0m"
|
|
|
|
|
echo -e "\033[33m非纯净模式不推荐使用此功能\033[0m"
|
|
|
|
|
[ -f $dir/pac ]&&echo -e "PAC地址:\033[32m$pac\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e " 1 生成PAC文件"
|
|
|
|
|
echo -e " 2 清除PAC文件"
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e " 0 返回上级菜单"
|
|
|
|
|
read -p "请输入对应数字 > " num
|
|
|
|
|
if [ "$num" = '1' ]; then
|
|
|
|
|
echo 'function FindProxyForURL(url, host) {' > $dir/pac
|
2020-09-08 18:35:49 +08:00
|
|
|
|
echo " return \"SOCKS $host:7890; PROXY $host:7890; DIRECT;\"" >> $dir/pac
|
2020-09-08 18:12:18 +08:00
|
|
|
|
echo '}' >> $dir/pac
|
|
|
|
|
echo -e "\033[33mPAC文件已生成!\033[0m"
|
|
|
|
|
echo -e "PAC地址:\033[32m$pac\033[0m"
|
|
|
|
|
echo "使用教程:https://baike.baidu.com/item/PAC/16292100"
|
|
|
|
|
sleep 2
|
|
|
|
|
elif [[ $num == 2 ]]; then
|
|
|
|
|
rm -rf $dir/pac
|
|
|
|
|
echo -----------------------------------------------
|
|
|
|
|
echo -e "\033[33mPAC文件已清除!\033[0m"
|
|
|
|
|
sleep 1
|
|
|
|
|
fi
|
|
|
|
|
}
|
2020-08-10 20:24:28 +08:00
|
|
|
|
setserver(){
|
|
|
|
|
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[30;47m您可以在此处切换在线更新时使用的资源地址\033[0m"
|
|
|
|
|
echo -e "当前源:\033[4;32m$update_url\033[0m"
|
|
|
|
|
echo -----------------------------------------------
|
2020-10-02 09:16:12 +08:00
|
|
|
|
echo -e " 1 Github源(直连美国服务器)"
|
|
|
|
|
echo -e " 2 Jsdelivr-CDN源(仅同步最新release版本)"
|
2020-09-17 14:50:29 +08:00
|
|
|
|
echo -e " 3 Github源+clash代理(需开启clash服务)"
|
2020-08-11 10:17:00 +08:00
|
|
|
|
echo -e " 4 自定义输入(请务必确保路径正确)"
|
2020-08-10 20:24:28 +08:00
|
|
|
|
echo -e " 0 返回上级菜单"
|
|
|
|
|
read -p "请输入对应数字 > " num
|
|
|
|
|
if [ -z $num ]; then
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
update
|
|
|
|
|
elif [[ $num == 1 ]]; then
|
2020-09-17 14:50:29 +08:00
|
|
|
|
update_url='--resolve raw.githubusercontent.com:443:199.232.68.133 https://raw.githubusercontent.com/juewuy/ShellClash/master'
|
2020-08-10 20:24:28 +08:00
|
|
|
|
elif [[ $num == 2 ]]; then
|
2020-10-02 09:16:12 +08:00
|
|
|
|
update_url='https://cdn.jsdelivr.net/gh/juewuy/ShellClash'
|
2020-08-10 20:24:28 +08:00
|
|
|
|
elif [[ $num == 3 ]]; then
|
2020-09-17 14:50:29 +08:00
|
|
|
|
update_url='-x 127.0.0.1:7890 https://raw.githubusercontent.com/juewuy/ShellClash/master'
|
2020-08-10 20:24:28 +08:00
|
|
|
|
elif [[ $num == 4 ]]; then
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
read -p "请输入个人源路径 > " update_url
|
2020-08-11 10:17:00 +08:00
|
|
|
|
if [ -n $update_url ];then
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-08-24 19:39:50 +08:00
|
|
|
|
echo -e "\033[31m取消输入,返回上级菜单\033[0m"
|
2020-08-11 10:17:00 +08:00
|
|
|
|
update
|
|
|
|
|
fi
|
2020-09-17 14:50:29 +08:00
|
|
|
|
elif [[ $num == 9 ]]; then
|
2020-09-18 21:09:06 +08:00
|
|
|
|
update_url='http://127.0.0.1:8080/clash-for-Miwifi'
|
2020-08-10 20:24:28 +08:00
|
|
|
|
else
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[31m请输入正确的数字!\033[0m"
|
|
|
|
|
update
|
|
|
|
|
fi
|
|
|
|
|
#写入mark文件
|
|
|
|
|
sed -i '/update_url*/'d $ccfg
|
|
|
|
|
sed -i "1i\update_url=\'$update_url\'" $ccfg
|
|
|
|
|
echo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
echo -e "\033[32m源地址更新成功!\033[0m"
|
2020-09-29 19:31:12 +08:00
|
|
|
|
release_new=""
|
2020-08-10 20:24:28 +08:00
|
|
|
|
update
|
|
|
|
|
}
|