551 lines
18 KiB
Bash
551 lines
18 KiB
Bash
#!/bin/sh
|
||
# Copyright (C) Juewuy
|
||
|
||
[ -n "$__IS_MODULE_OVERRIDE" ] && return
|
||
__IS_MODULE_OVERRIDE=1
|
||
load_lang override
|
||
|
||
YAMLSDIR="$CRASHDIR"/yamls
|
||
JSONSDIR="$CRASHDIR"/jsons
|
||
|
||
# 配置文件覆写
|
||
override() {
|
||
while true; do
|
||
[ -z "$rule_link" ] && rule_link=1
|
||
[ -z "$server_link" ] && server_link=1
|
||
comp_box "\033[30;47m $OVR_TITLE\033[0m"
|
||
content_line "$OVR_MENU_2"
|
||
echo "$crashcore" | grep -q 'singbox' || {
|
||
content_line "$OVR_MENU_3"
|
||
content_line "$OVR_MENU_4"
|
||
}
|
||
content_line "$OVR_MENU_5"
|
||
[ "$disoverride" != 1 ] && content_line "$OVR_MENU_9"
|
||
content_line ""
|
||
content_line "$OVR_BACK"
|
||
separator_line "="
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0)
|
||
break
|
||
;;
|
||
2)
|
||
setrules
|
||
;;
|
||
3)
|
||
setproxies
|
||
;;
|
||
4)
|
||
setgroups
|
||
;;
|
||
5)
|
||
if echo "$crashcore" | grep -q 'singbox'; then
|
||
set_singbox_adv
|
||
else
|
||
set_clash_adv
|
||
fi
|
||
sleep 3
|
||
;;
|
||
9)
|
||
comp_box "\033[33m$OVR_WARN_1\033[0m" \
|
||
"\033[33m$OVR_WARN_2\033[0m" \
|
||
"\033[33m$OVR_WARN_3\033[0m"
|
||
sleep 2
|
||
btm_box "$OVR_WARN_CONFIRM" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$COMMON_INPUT> " res
|
||
[ "$res" = '1' ] && {
|
||
disoverride=1
|
||
if setconfig disoverride $disoverride; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
}
|
||
;;
|
||
*)
|
||
errornum
|
||
;;
|
||
esac
|
||
done
|
||
}
|
||
|
||
# 自定义规则
|
||
setrules() {
|
||
set_rule_type() {
|
||
comp_box "\033[33m$OVR_RULES_TYPE\033[0m"
|
||
printf '%s\n' "$rule_type" |
|
||
awk '{for (i = 1; i <= NF; i++) print i") " $i}' |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
btm_box "" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0) ;;
|
||
[0-9]*)
|
||
if [ "$num" -gt $(echo $rule_type | awk -F " " '{print NF}') ]; then
|
||
errornum
|
||
else
|
||
rule_type_set=$(echo "$rule_type" | cut -d' ' -f"$num")
|
||
comp_box "\033[33m$OVR_RULES_ADD_RULE\033[0m"
|
||
read -r -p "$OVR_RULES_INPUT_RULE" rule_state_set
|
||
if [ -n "$rule_state_set" ]; then
|
||
set_group_type
|
||
else
|
||
errornum
|
||
fi
|
||
fi
|
||
;;
|
||
*)
|
||
errornum
|
||
;;
|
||
esac
|
||
}
|
||
|
||
set_group_type() {
|
||
comp_box "\033[36m$OVR_RULES_GROUP\033[0m" \
|
||
"\033[33m$OVR_RULES_EXIST_WARN\033[0m"
|
||
printf '%s\n' "$rule_group" |
|
||
awk -F '#' '{for (i = 1; i <= NF; i++) print i") " $i}' |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
btm_box "" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0) ;;
|
||
[0-9]*)
|
||
if [ "$num" -gt "$(echo "$rule_group" | awk -F "#" '{print NF}')" ]; then
|
||
errornum
|
||
else
|
||
rule_group_set=$(echo "$rule_group" | cut -d'#' -f"$num")
|
||
rule_all="- ${rule_type_set},${rule_state_set},${rule_group_set}"
|
||
echo "IP-CIDR SRC-IP-CIDR IP-CIDR6" | grep -q -- "$rule_type_set" && rule_all="${rule_all},no-resolve"
|
||
echo "$rule_all" >>"$YAMLSDIR"/rules.yaml
|
||
msg_alert "\033[32m$OVR_RULES_ADD_OK\033[0m"
|
||
fi
|
||
;;
|
||
*)
|
||
errornum
|
||
;;
|
||
esac
|
||
}
|
||
|
||
del_rule_type() {
|
||
while true; do
|
||
comp_box "$OVR_RULES_DEL_HINT"
|
||
sed -i '/^ *$/d; /^#/d' "$YAMLSDIR"/rules.yaml
|
||
awk -F '#' '!/^#/ {print NR") "$1 $2 $3}' "$YAMLSDIR/rules.yaml" |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
btm_box "" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0)
|
||
break
|
||
;;
|
||
*)
|
||
if [ "$num" -le "$(wc -l <"$YAMLSDIR"/rules.yaml)" ]; then
|
||
if sed -i "${num}d" "$YAMLSDIR"/rules.yaml; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
sleep 1
|
||
else
|
||
errornum
|
||
fi
|
||
;;
|
||
esac
|
||
done
|
||
}
|
||
|
||
get_rule_group() {
|
||
. "$CRASHDIR"/libs/web_save.sh
|
||
get_save http://127.0.0.1:${db_port}/proxies | sed 's/:{/!/g' | awk -F '!' '{for(i=1;i<=NF;i++) print $i}' | grep -aE '"Selector|URLTest|LoadBalance"' | grep -aoE '"name":.*"now":".*",' | awk -F '"' '{print "#"$4}' | tr -d '\n'
|
||
}
|
||
|
||
while true; do
|
||
comp_box "\033[33m$OVR_RULES_MENU_HINT\033[0m" \
|
||
"$OVR_RULES_MANUAL" \
|
||
"\033[33m$OVR_RULES_SHARED\033[0m" \
|
||
"$OVR_RULES_WARN"
|
||
content_line "$OVR_RULES_ADD"
|
||
content_line "$OVR_RULES_DEL"
|
||
content_line "$OVR_RULES_CLEAR"
|
||
echo "$crashcore" | grep -q 'singbox' || content_line "$OVR_RULES_BYPASS \033[36m$proxies_bypass\033[0m"
|
||
content_line ""
|
||
content_line "$OVR_BACK"
|
||
separator_line "="
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0)
|
||
break
|
||
;;
|
||
1)
|
||
rule_type="DOMAIN-SUFFIX DOMAIN-KEYWORD IP-CIDR SRC-IP-CIDR DST-PORT SRC-PORT GEOIP GEOSITE IP-CIDR6 DOMAIN PROCESS-NAME"
|
||
rule_group="DIRECT#REJECT$(get_rule_group)"
|
||
set_rule_type
|
||
;;
|
||
2)
|
||
if [ -s "$YAMLSDIR"/rules.yaml ]; then
|
||
del_rule_type
|
||
else
|
||
msg_alert "$OVR_RULES_NO_RULES"
|
||
fi
|
||
;;
|
||
3)
|
||
comp_box "$OVR_RULES_CLEAR_CONFIRM"
|
||
btm_box "$OVR_CONFIRM_YES" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$COMMON_INPUT> " res
|
||
if [ "$res" = "1" ]; then
|
||
if sed -i '/^\s*[^#]/d' "$YAMLSDIR"/rules.yaml; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
fi
|
||
;;
|
||
4)
|
||
if [ "$proxies_bypass" = "OFF" ]; then
|
||
comp_box "\033[33m$OVR_RULES_BYPASS_WARN1\033[0m" \
|
||
"\033[33m$OVR_RULES_BYPASS_WARN2\033[0m" \
|
||
"" \
|
||
"$OVR_RULES_BYPASS_PROMPT"
|
||
btm_box "$OVR_CONFIRM_YES" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$COMMON_INPUT> " res
|
||
if [ "$res" = "1" ]; then
|
||
proxies_bypass=ON
|
||
else
|
||
continue
|
||
fi
|
||
else
|
||
proxies_bypass=OFF
|
||
fi
|
||
|
||
if setconfig proxies_bypass "$proxies_bypass"; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
;;
|
||
*)
|
||
errornum
|
||
;;
|
||
esac
|
||
done
|
||
}
|
||
|
||
# 自定义clash策略组
|
||
setgroups() {
|
||
set_group_type() {
|
||
comp_box "\033[33m$OVR_GROUPS_WARN1\033[0m" \
|
||
"\033[33m$OVR_GROUPS_WARN2\033[0m" \
|
||
"\033[33m$OVR_GROUPS_WARN3\033[0m"
|
||
btm_box "\033[36m$OVR_GROUPS_INPUT_NAME\033[0m" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$OVR_PROMPT" new_group_name
|
||
|
||
comp_box "\033[32m$OVR_GROUPS_CHOOSE_TYPE【$new_group_name】\033[0m"
|
||
printf '%s\n' "$group_type_cn" |
|
||
awk '{for (i = 1; i <= NF; i++) print i") " $i}' |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
separator_line "="
|
||
read -r -p "$OVR_GROUPS_INPUT_NUM" num
|
||
new_group_type=$(echo "$group_type" | awk '{print $'"$num"'}')
|
||
if [ "$num" = "1" ]; then
|
||
unset new_group_url interval
|
||
else
|
||
comp_box "$OVR_GROUPS_URL" \
|
||
"$OVR_GROUPS_URL_HINT"
|
||
read -r -p "$OVR_PROMPT" new_group_url
|
||
[ -z "$new_group_url" ] && new_group_url=https://www.gstatic.com/generate_204
|
||
new_group_url="url: '$new_group_url'"
|
||
interval="interval: 300"
|
||
fi
|
||
set_group_add
|
||
# 添加自定义策略组
|
||
cat >>"$YAMLSDIR"/proxy-groups.yaml <<EOF
|
||
- name: $new_group_name
|
||
type: $new_group_type
|
||
$new_group_url
|
||
$interval
|
||
proxies:
|
||
- DIRECT
|
||
EOF
|
||
sed -i "/^ *$/d" "$YAMLSDIR"/proxy-groups.yaml
|
||
msg_alert "\033[32m$OVR_GROUPS_ADD_OK\033[0m"
|
||
|
||
}
|
||
|
||
set_group_add() {
|
||
comp_box "\033[36m$OVR_PROXIES_ADD_HINT\033[0m" \
|
||
"\033[32m$OVR_PROXIES_MULTI_HINT\033[0m"
|
||
printf '%s\n' "$proxy_group" |
|
||
awk -F '#' '{for (i = 1; i <= NF; i++) print i") " $i}' |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
content_line ""
|
||
content_line "$OVR_GROUPS_SKIP"
|
||
separator_line "="
|
||
read -r -p "$OVR_PROMPT" char
|
||
case "$char" in
|
||
"" | 0) ;;
|
||
*)
|
||
for num in $char; do
|
||
rule_group_set=$(echo "$proxy_group" | cut -d'#' -f"$num")
|
||
rule_group_add="${rule_group_add}#${rule_group_set}"
|
||
done
|
||
if [ -n "$rule_group_add" ]; then
|
||
new_group_name="$new_group_name$rule_group_add"
|
||
unset rule_group_add
|
||
else
|
||
errornum
|
||
fi
|
||
;;
|
||
esac
|
||
}
|
||
|
||
while true; do
|
||
comp_box "\033[33m$OVR_GROUPS_MENU_HINT\033[0m" \
|
||
"\033[36m$OVR_GROUPS_MANUAL\033[0m"
|
||
btm_box "$OVR_GROUPS_ADD" \
|
||
"$OVR_GROUPS_VIEW" \
|
||
"$OVR_GROUPS_CLEAR" \
|
||
"" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0)
|
||
break
|
||
;;
|
||
1)
|
||
group_type="select url-test fallback load-balance"
|
||
group_type_cn="$OVR_GROUP_TYPE_CN"
|
||
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/#//')"
|
||
set_group_type
|
||
;;
|
||
2)
|
||
line_break
|
||
echo "==========================================================="
|
||
cat "$YAMLSDIR"/proxy-groups.yaml
|
||
echo ""
|
||
echo "==========================================================="
|
||
;;
|
||
3)
|
||
comp_box "$OVR_GROUPS_CLEAR_CONFIRM"
|
||
btm_box "$OVR_CONFIRM_YES" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$COMMON_INPUT> " res
|
||
if [ "$res" = "1" ]; then
|
||
if echo '#用于添加自定义策略组' >"$YAMLSDIR"/proxy-groups.yaml; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
fi
|
||
;;
|
||
*)
|
||
errornum
|
||
;;
|
||
esac
|
||
done
|
||
}
|
||
|
||
# 自定义clash节点
|
||
setproxies() {
|
||
|
||
set_proxy_type() {
|
||
while true; do
|
||
comp_box "\033[33m$OVR_PROXIES_WARN1\033[0m" \
|
||
"\033[36m【name: \"test\", server: 192.168.1.1, port: 12345, type: socks5, udp: true】\033[0m" \
|
||
"$OVR_PROXIES_WARN2"
|
||
btm_box "\033[36m$OVR_PROXIES_INPUT\033[0m" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$OVR_PROMPT" proxy_state_set
|
||
if [ "$proxy_state_set" = 0 ]; then
|
||
break
|
||
elif echo "$proxy_state_set" | grep -q "#"; then
|
||
msg_alert "\033[33m$OVR_PROXIES_BLOCK_HASH\033[0m"
|
||
elif echo "$proxy_state_set" | grep -Eq "^name:"; then
|
||
set_group_add
|
||
else
|
||
errornum
|
||
fi
|
||
done
|
||
}
|
||
|
||
set_group_add() {
|
||
comp_box "\033[36m$OVR_PROXIES_ADD_HINT\033[0m" \
|
||
"\033[32m$OVR_PROXIES_MULTI_HINT\033[0m" \
|
||
"\033[33m$OVR_PROXIES_GROUP_HINT\033[0m"
|
||
printf '%s\n' "$proxy_group" |
|
||
awk -F '#' '{for (i = 1; i <= NF; i++) print i") " $i}' |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
btm_box "" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_PROMPT" char
|
||
case "$char" in
|
||
"" | 0) ;;
|
||
*)
|
||
for num in $char; do
|
||
rule_group_set=$(echo "$proxy_group" | cut -d'#' -f"$num")
|
||
rule_group_add="${rule_group_add}#${rule_group_set}"
|
||
done
|
||
if [ -n "$rule_group_add" ]; then
|
||
echo "- {$proxy_state_set}$rule_group_add" >>"$YAMLSDIR"/proxies.yaml
|
||
msg_alert "\033[32m$OVR_PROXIES_ADD_OK\033[0m"
|
||
unset rule_group_add
|
||
else
|
||
errornum
|
||
fi
|
||
;;
|
||
esac
|
||
}
|
||
|
||
while true; do
|
||
comp_box "\033[33m$OVR_PROXIES_MENU_HINT\033[0m" \
|
||
"\033[36m$OVR_PROXIES_MANUAL\033[0m"
|
||
btm_box "$OVR_PROXIES_ADD" \
|
||
"$OVR_PROXIES_MANAGE" \
|
||
"$OVR_PROXIES_CLEAR" \
|
||
"$OVR_PROXIES_BYPASS \033[36m$proxies_bypass\033[0m" \
|
||
"" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
case "$num" in
|
||
"" | 0)
|
||
break
|
||
;;
|
||
1)
|
||
proxy_type="DOMAIN-SUFFIX DOMAIN-KEYWORD IP-CIDR SRC-IP-CIDR DST-PORT SRC-PORT GEOIP GEOSITE IP-CIDR6 DOMAIN MATCH"
|
||
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/#//')"
|
||
set_proxy_type
|
||
;;
|
||
2)
|
||
sed -i '/^ *$/d' "$YAMLSDIR"/proxies.yaml 2>/dev/null
|
||
if [ -s "$YAMLSDIR"/proxies.yaml ]; then
|
||
comp_box "\033[33m$OVR_PROXIES_EXIST_HINT\033[0m" \
|
||
"$OVR_PROXIES_EXIST_TITLE"
|
||
grep -Ev '^#' "$YAMLSDIR/proxies.yaml" |
|
||
awk -F '[,}]' '{print NR") " $1 " " $NF}' |
|
||
sed 's/- {//g' |
|
||
while IFS= read -r line; do
|
||
content_line "$line"
|
||
done
|
||
btm_box "" \
|
||
"$OVR_BACK"
|
||
read -r -p "$OVR_INPUT_NUM" num
|
||
if [ "$num" = 0 ]; then
|
||
continue
|
||
elif [ "$num" -le $(cat "$YAMLSDIR"/proxies.yaml | grep -Ev '^#' | wc -l) ]; then
|
||
if sed -i "$num{/^\s*[^#]/d}" "$YAMLSDIR"/proxies.yaml; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
else
|
||
errornum
|
||
fi
|
||
else
|
||
msg_alert "$OVR_PROXIES_NO_PROXY"
|
||
fi
|
||
;;
|
||
3)
|
||
comp_box "$OVR_PROXIES_CLEAR_CONFIRM"
|
||
btm_box "$OVR_CONFIRM_YES" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$COMMON_INPUT> " res
|
||
if [ "$res" = "1" ]; then
|
||
if sed -i '/^\s*[^#]/d' "$YAMLSDIR"/proxies.yaml 2>/dev/null; then
|
||
common_success
|
||
else
|
||
common_failed
|
||
fi
|
||
else
|
||
continue
|
||
fi
|
||
;;
|
||
4)
|
||
if [ "$proxies_bypass" = "OFF" ]; then
|
||
comp_box "\033[33m$OVR_PROXIES_BYPASS_WARN1\033[0m" \
|
||
"\033[33m$OVR_PROXIES_BYPASS_WARN2\033[0m" \
|
||
"" \
|
||
"$OVR_PROXIES_BYPASS_PROMPT"
|
||
btm_box "$OVR_CONFIRM_YES" \
|
||
"$OVR_CONFIRM_NO"
|
||
read -r -p "$COMMON_INPUT> " res
|
||
if [ "$res" = "1" ]; then
|
||
proxies_bypass=ON
|
||
else
|
||
continue
|
||
fi
|
||
else
|
||
proxies_bypass=OFF
|
||
fi
|
||
setconfig proxies_bypass "$proxies_bypass"
|
||
sleep 1
|
||
setrules
|
||
break
|
||
;;
|
||
*)
|
||
errornum
|
||
;;
|
||
esac
|
||
done
|
||
}
|
||
|
||
# 自定义clash高级规则
|
||
set_clash_adv() {
|
||
[ ! -f "$YAMLSDIR"/user.yaml ] && cat >"$YAMLSDIR"/user.yaml <<EOF
|
||
#用于编写自定义设定(可参考https://lancellc.gitbook.io/clash/clash-config-file/general 或 https://docs.metacubex.one/function/general)
|
||
#端口之类请在脚本中修改,否则不会加载
|
||
#port: 7890
|
||
EOF
|
||
[ ! -f "$YAMLSDIR"/others.yaml ] && cat >"$YAMLSDIR"/others.yaml <<EOF
|
||
#用于编写自定义的锚点、入站、proxy-providers、sub-rules、rule-set、script等功能
|
||
#可参考 https://github.com/MetaCubeX/Clash.Meta/blob/Meta/docs/config.yaml 或 https://lancellc.gitbook.io/clash/clash-config-file/an-example-configuration-file
|
||
#此处内容会被添加在配置文件的“proxy-group:”模块的末尾与“rules:”模块之前的位置
|
||
#例如:
|
||
#proxy-providers:
|
||
#rule-providers:
|
||
#sub-rules:
|
||
#tunnels:
|
||
#script:
|
||
#listeners:
|
||
EOF
|
||
|
||
comp_box "\033[32m$OVR_ADV_USER_CREATED1\033[0m" \
|
||
"\033[33m$OVR_ADV_USER_CREATED2\033[0m" \
|
||
"" \
|
||
"\033[32m$OVR_ADV_USER_CREATED3\033[0m" \
|
||
"\033[33m$OVR_ADV_USER_CREATED4\033[0m"
|
||
|
||
btm_box "\033[33m$OVR_ADV_WIN\033[0m" \
|
||
"\033[33m$OVR_ADV_MAC\033[0m" \
|
||
"\033[33m$OVR_ADV_LIN\033[0m"
|
||
}
|
||
|
||
# s自定义singbox配置文件
|
||
set_singbox_adv() {
|
||
comp_box "\033[33m$OVR_SING_TITLE1\033[0m" \
|
||
"\033[36mlog dns ntp certificate experimental\033[0m" \
|
||
"\033[33m$OVR_SING_TITLE2\033[0m" \
|
||
"\033[36mendpoints inbounds outbounds providers route services\033[0m" \
|
||
"$OVR_SING_TITLE3" \
|
||
"" \
|
||
"$OVR_SING_TITLE4"
|
||
}
|