mirror of
https://github.com/juewuy/ShellCrash.git
synced 2026-03-12 00:11:31 +00:00
Merge branch 'dev' of https://github.com/juewuy/ShellCrash into dev
This commit is contained in:
@@ -261,112 +261,120 @@ EOF
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
setproxies(){ #自定义clash节点
|
# 自定义clash节点
|
||||||
set_proxy_type(){
|
setproxies() {
|
||||||
echo "-----------------------------------------------"
|
set_proxy_type() {
|
||||||
echo -e "\033[33m注意节点格式必须是单行,不包括括号,name:必须写在最前,例如:\033[0m"
|
echo "-----------------------------------------------"
|
||||||
echo -e "\033[36m【name: \"test\", server: 192.168.1.1, port: 12345, type: socks5, udp: true】\033[0m"
|
echo -e "\033[33m注意节点格式必须是单行,不包括括号,name:必须写在最前,例如:\033[0m"
|
||||||
echo -e "更多写法请参考:\033[32m https://juewuy.github.io/ \033[0m"
|
echo -e "\033[36m【name: \"test\", server: 192.168.1.1, port: 12345, type: socks5, udp: true】\033[0m"
|
||||||
read -p "请输入节点 > " proxy_state_set
|
echo -e "更多写法请参考:\033[32m https://juewuy.github.io/ \033[0m"
|
||||||
if [ -n "$(echo $proxy_state_set | grep "#" )" ];then
|
read -pr "请输入节点 > " proxy_state_set
|
||||||
echo -e "\033[33m绝对禁止包含【#】号!!!\033[0m"
|
if echo "$proxy_state_set" | grep -q "#"; then
|
||||||
elif [ -n "$(echo $proxy_state_set | grep -E "^name:" )" ];then
|
echo -e "\033[33m绝对禁止包含【#】号!!!\033[0m"
|
||||||
set_group_add
|
elif echo "$proxy_state_set" | grep -Eq "^name:"; then
|
||||||
else
|
set_group_add
|
||||||
errornum
|
else
|
||||||
fi
|
errornum
|
||||||
}
|
sleep 1
|
||||||
set_group_add(){
|
fi
|
||||||
echo "-----------------------------------------------"
|
}
|
||||||
echo -e "\033[36m请选择想要将节点添加到的策略组\033[0m"
|
|
||||||
echo -e "\033[32m如需添加到多个策略组,请一次性输入多个数字并用空格隔开\033[0m"
|
set_group_add() {
|
||||||
echo -e "\033[33m如需自定义策略组,请先使用【管理自定义策略组功能】添加\033[0m"
|
echo "-----------------------------------------------"
|
||||||
echo "-----------------------------------------------"
|
echo -e "\033[36m请选择想要将节点添加到的策略组\033[0m"
|
||||||
echo $proxy_group | awk -F '#' '{for(i=1;i<=NF;i++){print i" "$i}}'
|
echo -e "\033[32m如需添加到多个策略组,请一次性输入多个数字并用空格隔开\033[0m"
|
||||||
echo "-----------------------------------------------"
|
echo -e "\033[33m如需自定义策略组,请先使用【管理自定义策略组功能】添加\033[0m"
|
||||||
echo -e " 0 返回上级菜单"
|
echo "-----------------------------------------------"
|
||||||
read -p "请输入对应数字(多个用空格隔开) > " char
|
echo "$proxy_group" | awk -F '#' '{for(i=1;i<=NF;i++){print i" "$i}}'
|
||||||
case "$char" in
|
echo "-----------------------------------------------"
|
||||||
0) ;;
|
echo -e " 0 返回上级菜单"
|
||||||
*)
|
read -pr "请输入对应数字(多个用空格隔开) > " char
|
||||||
for num in $char;do
|
case "$char" in
|
||||||
rule_group_set=$(echo $proxy_group|cut -d'#' -f$num)
|
"" | 0) ;;
|
||||||
rule_group_add="${rule_group_add}#${rule_group_set}"
|
*)
|
||||||
done
|
for num in $char; do
|
||||||
if [ -n "$rule_group_add" ];then
|
rule_group_set=$(echo "$proxy_group" | cut -d'#' -f"$num")
|
||||||
echo "- {$proxy_state_set}$rule_group_add" >> "$YAMLSDIR"/proxies.yaml
|
rule_group_add="${rule_group_add}#${rule_group_set}"
|
||||||
echo "-----------------------------------------------"
|
done
|
||||||
echo -e "\033[32m添加成功!\033[0m"
|
if [ -n "$rule_group_add" ]; then
|
||||||
unset rule_group_add
|
echo "- {$proxy_state_set}$rule_group_add" >>"$YAMLSDIR"/proxies.yaml
|
||||||
else
|
echo "-----------------------------------------------"
|
||||||
errornum
|
echo -e "\033[32m添加成功!\033[0m"
|
||||||
fi
|
unset rule_group_add
|
||||||
;;
|
else
|
||||||
esac
|
errornum
|
||||||
}
|
sleep 1
|
||||||
echo "-----------------------------------------------"
|
fi
|
||||||
echo -e "\033[33m你可以在这里快捷管理自定义节点\033[0m"
|
;;
|
||||||
echo -e "\033[36m如需批量操作,请手动编辑:$YAMLSDIR/proxies.yaml\033[0m"
|
esac
|
||||||
echo "-----------------------------------------------"
|
}
|
||||||
echo -e " 1 添加自定义节点"
|
|
||||||
echo -e " 2 管理自定义节点"
|
while true; do
|
||||||
echo -e " 3 清空自定义节点"
|
echo "-----------------------------------------------"
|
||||||
echo -e " 4 配置节点绕过: \033[36m$proxies_bypass\033[0m"
|
echo -e "\033[33m你可以在这里快捷管理自定义节点\033[0m"
|
||||||
echo -e " 0 返回上级菜单"
|
echo -e "\033[36m如需批量操作,请手动编辑:$YAMLSDIR/proxies.yaml\033[0m"
|
||||||
read -p "请输入对应数字 > " num
|
echo "-----------------------------------------------"
|
||||||
case "$num" in
|
echo -e " 1 添加自定义节点"
|
||||||
0)
|
echo -e " 2 管理自定义节点"
|
||||||
;;
|
echo -e " 3 清空自定义节点"
|
||||||
1)
|
echo -e " 4 配置节点绕过: \033[36m$proxies_bypass\033[0m"
|
||||||
proxy_type="DOMAIN-SUFFIX DOMAIN-KEYWORD IP-CIDR SRC-IP-CIDR DST-PORT SRC-PORT GEOIP GEOSITE IP-CIDR6 DOMAIN MATCH"
|
echo -e " 0 返回上级菜单"
|
||||||
proxy_group="$(cat "$YAMLSDIR"/proxy-groups.yaml "$YAMLSDIR"/config.yaml 2>/dev/null | sed "/#自定义策略组开始/,/#自定义策略组结束/d" | grep -Ev '^#' | grep -o '\- name:.*' | sed 's/#.*//' | sed 's/- name: /#/g' | tr -d '\n' | sed 's/#//')"
|
read -pr "请输入对应数字 > " num
|
||||||
set_proxy_type
|
case "$num" in
|
||||||
setproxies
|
"" | 0)
|
||||||
;;
|
break
|
||||||
2)
|
;;
|
||||||
echo "-----------------------------------------------"
|
1)
|
||||||
sed -i '/^ *$/d' "$YAMLSDIR"/proxies.yaml 2>/dev/null
|
proxy_type="DOMAIN-SUFFIX DOMAIN-KEYWORD IP-CIDR SRC-IP-CIDR DST-PORT SRC-PORT GEOIP GEOSITE IP-CIDR6 DOMAIN MATCH"
|
||||||
if [ -s "$YAMLSDIR"/proxies.yaml ];then
|
proxy_group="$(cat "$YAMLSDIR"/proxy-groups.yaml "$YAMLSDIR"/config.yaml 2>/dev/null | sed "/#自定义策略组开始/,/#自定义策略组结束/d" | grep -Ev '^#' | grep -o '\- name:.*' | sed 's/#.*//' | sed 's/- name: /#/g' | tr -d '\n' | sed 's/#//')"
|
||||||
echo -e "当前已添加的自定义节点为:"
|
set_proxy_type
|
||||||
cat "$YAMLSDIR"/proxies.yaml | grep -Ev '^#' | awk -F '[,,}]' '{print NR, $1, $NF}' | sed 's/- {//g'
|
;;
|
||||||
echo "-----------------------------------------------"
|
2)
|
||||||
echo -e "\033[33m输入节点对应数字可以移除对应节点\033[0m"
|
echo "-----------------------------------------------"
|
||||||
read -p "请输入对应数字 > " num
|
sed -i '/^ *$/d' "$YAMLSDIR"/proxies.yaml 2>/dev/null
|
||||||
if [ $num -le $(cat "$YAMLSDIR"/proxies.yaml | grep -Ev '^#' | wc -l) ];then
|
if [ -s "$YAMLSDIR"/proxies.yaml ]; then
|
||||||
sed -i "$num{/^\s*[^#]/d}" "$YAMLSDIR"/proxies.yaml
|
echo -e "当前已添加的自定义节点为:"
|
||||||
else
|
cat "$YAMLSDIR"/proxies.yaml | grep -Ev '^#' | awk -F '[,,}]' '{print NR, $1, $NF}' | sed 's/- {//g'
|
||||||
errornum
|
echo "-----------------------------------------------"
|
||||||
fi
|
echo -e "\033[33m输入节点对应数字可以移除对应节点\033[0m"
|
||||||
else
|
read -pr "请输入对应数字 > " num
|
||||||
echo -e "请先添加自定义节点!"
|
if [ "$num" -le $(cat "$YAMLSDIR"/proxies.yaml | grep -Ev '^#' | wc -l) ]; then
|
||||||
sleep 1
|
sed -i "$num{/^\s*[^#]/d}" "$YAMLSDIR"/proxies.yaml
|
||||||
fi
|
else
|
||||||
setproxies
|
errornum
|
||||||
;;
|
fi
|
||||||
3)
|
else
|
||||||
read -p "确认清空全部自定义节点?(1/0) > " res
|
echo -e "请先添加自定义节点!"
|
||||||
[ "$res" = "1" ] && sed -i '/^\s*[^#]/d' "$YAMLSDIR"/proxies.yaml 2>/dev/null
|
sleep 1
|
||||||
setproxies
|
fi
|
||||||
;;
|
;;
|
||||||
4)
|
3)
|
||||||
echo "-----------------------------------------------"
|
read -pr "确认清空全部自定义节点?(1/0) > " res
|
||||||
if [ "$proxies_bypass" = "OFF" ];then
|
[ "$res" = "1" ] && sed -i '/^\s*[^#]/d' "$YAMLSDIR"/proxies.yaml 2>/dev/null
|
||||||
echo -e "\033[33m本功能会自动将当前配置文件中的节点域名或IP设置为直连规则以防止出现双重流量!\033[0m"
|
;;
|
||||||
echo -e "\033[33m请确保下游设备使用的节点与ShellCrash中使用的节点相同,否则无法生效!\033[0m"
|
4)
|
||||||
read -p "启用节点绕过?(1/0) > " res
|
echo "-----------------------------------------------"
|
||||||
[ "$res" = "1" ] && proxies_bypass=ON
|
if [ "$proxies_bypass" = "OFF" ]; then
|
||||||
else
|
echo -e "\033[33m本功能会自动将当前配置文件中的节点域名或IP设置为直连规则以防止出现双重流量!\033[0m"
|
||||||
proxies_bypass=OFF
|
echo -e "\033[33m请确保下游设备使用的节点与ShellCrash中使用的节点相同,否则无法生效!\033[0m"
|
||||||
fi
|
read -pr "启用节点绕过?(1/0) > " res
|
||||||
setconfig proxies_bypass $proxies_bypass
|
[ "$res" = "1" ] && proxies_bypass=ON
|
||||||
sleep 1
|
else
|
||||||
setrules
|
proxies_bypass=OFF
|
||||||
;;
|
fi
|
||||||
*)
|
setconfig proxies_bypass "$proxies_bypass"
|
||||||
errornum
|
sleep 1
|
||||||
;;
|
setrules
|
||||||
esac
|
break
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
errornum
|
||||||
|
sleep 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
gen_clash_providers(){ #生成clash的providers配置文件
|
gen_clash_providers(){ #生成clash的providers配置文件
|
||||||
gen_clash_providers_txt(){
|
gen_clash_providers_txt(){
|
||||||
if [ -n "$(echo $2|grep -E '^./')" ];then
|
if [ -n "$(echo $2|grep -E '^./')" ];then
|
||||||
|
|||||||
Reference in New Issue
Block a user