#!/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 </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 <"$YAMLSDIR"/others.yaml <