mirror of
https://github.com/233boy/sing-box.git
synced 2026-05-03 14:24:40 +08:00
Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
03e905e79d | ||
|
|
2d94cc34f9 | ||
|
|
e97302b57a | ||
|
|
3750157987 | ||
|
|
7c9622df74 | ||
|
|
4ebcb332bc | ||
|
|
62c5871ddc | ||
|
|
93d550ace3 | ||
|
|
a6c37635fe |
14
install.sh
14
install.sh
@@ -34,9 +34,9 @@ warn() {
|
|||||||
# root
|
# root
|
||||||
[[ $EUID != 0 ]] && err "当前非 ${yellow}ROOT用户.${none}"
|
[[ $EUID != 0 ]] && err "当前非 ${yellow}ROOT用户.${none}"
|
||||||
|
|
||||||
# yum or apt-get, ubuntu/debian/centos
|
# apt-get, yum or zypper, ubuntu/debian/centos/suse
|
||||||
cmd=$(type -P apt-get || type -P yum)
|
cmd=$(type -P apt-get || type -P yum || type -P zypper)
|
||||||
[[ ! $cmd ]] && err "此脚本仅支持 ${yellow}(Ubuntu or Debian or CentOS)${none}."
|
[[ ! $cmd ]] && err "此脚本仅支持 ${yellow}(Ubuntu or Debian or CentOS or SUSE)${none}."
|
||||||
|
|
||||||
# systemd
|
# systemd
|
||||||
[[ ! $(type -P systemctl) ]] && {
|
[[ ! $(type -P systemctl) ]] && {
|
||||||
@@ -144,7 +144,11 @@ install_pkg() {
|
|||||||
$cmd install -y $pkg &>/dev/null
|
$cmd install -y $pkg &>/dev/null
|
||||||
if [[ $? != 0 ]]; then
|
if [[ $? != 0 ]]; then
|
||||||
[[ $cmd =~ yum ]] && yum install epel-release -y &>/dev/null
|
[[ $cmd =~ yum ]] && yum install epel-release -y &>/dev/null
|
||||||
$cmd update -y &>/dev/null
|
if [[ $cmd =~ zypper ]]; then
|
||||||
|
$cmd --non-interactive refresh &>/dev/null
|
||||||
|
else
|
||||||
|
$cmd update -y &>/dev/null
|
||||||
|
fi
|
||||||
$cmd install -y $pkg &>/dev/null
|
$cmd install -y $pkg &>/dev/null
|
||||||
[[ $? == 0 ]] && >$is_pkg_ok
|
[[ $? == 0 ]] && >$is_pkg_ok
|
||||||
else
|
else
|
||||||
@@ -198,7 +202,7 @@ check_status() {
|
|||||||
# dependent pkg install fail
|
# dependent pkg install fail
|
||||||
[[ ! -f $is_pkg_ok ]] && {
|
[[ ! -f $is_pkg_ok ]] && {
|
||||||
msg err "安装依赖包失败"
|
msg err "安装依赖包失败"
|
||||||
msg err "请尝试手动安装依赖包: $cmd update -y; $cmd install -y $pkg"
|
msg err "请尝试手动安装依赖包: $cmd update -y; $cmd install -y $is_pkg"
|
||||||
is_fail=1
|
is_fail=1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
args=$@
|
args=$@
|
||||||
is_sh_ver=v1.10
|
is_sh_ver=v1.15
|
||||||
|
|
||||||
. /etc/sing-box/sh/src/init.sh
|
. /etc/sing-box/sh/src/init.sh
|
||||||
15
src/core.sh
15
src/core.sh
@@ -467,7 +467,7 @@ change() {
|
|||||||
1)
|
1)
|
||||||
# new port
|
# new port
|
||||||
is_new_port=$3
|
is_new_port=$3
|
||||||
[[ $host && ! $is_caddy || $is_no_auto_tls ]] && err "($is_config_file) 不支持更改端口, 因为没啥意义."
|
[[ $host && ! $is_caddy || $is_no_auto_tls ]] && err "($is_config_file) 不支持更改端口, 因为没啥意义."
|
||||||
if [[ $is_new_port && ! $is_auto ]]; then
|
if [[ $is_new_port && ! $is_auto ]]; then
|
||||||
[[ ! $(is_test port $is_new_port) ]] && err "请输入正确的端口, 可选(1-65535)"
|
[[ ! $(is_test port $is_new_port) ]] && err "请输入正确的端口, 可选(1-65535)"
|
||||||
[[ $is_new_port != 443 && $(is_test port_used $is_new_port) ]] && err "无法使用 ($is_new_port) 端口"
|
[[ $is_new_port != 443 && $(is_test port_used $is_new_port) ]] && err "无法使用 ($is_new_port) 端口"
|
||||||
@@ -655,7 +655,7 @@ del() {
|
|||||||
[[ ! $old_host ]] && return # no host exist or not set new host;
|
[[ ! $old_host ]] && return # no host exist or not set new host;
|
||||||
is_del_host=$old_host
|
is_del_host=$old_host
|
||||||
}
|
}
|
||||||
[[ $is_del_host && $host != $old_host && ! $is_no_auto_tls ]] && {
|
[[ $is_del_host && $host != $old_host && -f $is_caddy_conf/$is_del_host.conf ]] && {
|
||||||
rm -rf $is_caddy_conf/$is_del_host.conf $is_caddy_conf/$is_del_host.conf.add
|
rm -rf $is_caddy_conf/$is_del_host.conf $is_caddy_conf/$is_del_host.conf.add
|
||||||
[[ ! $is_new_json ]] && manage restart caddy &
|
[[ ! $is_new_json ]] && manage restart caddy &
|
||||||
}
|
}
|
||||||
@@ -680,7 +680,7 @@ uninstall() {
|
|||||||
manage stop &>/dev/null
|
manage stop &>/dev/null
|
||||||
manage disable &>/dev/null
|
manage disable &>/dev/null
|
||||||
rm -rf $is_core_dir $is_log_dir $is_sh_bin ${is_sh_bin/$is_core/sb} /lib/systemd/system/$is_core.service
|
rm -rf $is_core_dir $is_log_dir $is_sh_bin ${is_sh_bin/$is_core/sb} /lib/systemd/system/$is_core.service
|
||||||
sed -i "/alias $is_core=/d" /root/.bashrc
|
sed -i "/$is_core/d" /root/.bashrc
|
||||||
# uninstall caddy; 2 is ask result
|
# uninstall caddy; 2 is ask result
|
||||||
if [[ $REPLY == '2' ]]; then
|
if [[ $REPLY == '2' ]]; then
|
||||||
manage stop caddy &>/dev/null
|
manage stop caddy &>/dev/null
|
||||||
@@ -1199,7 +1199,11 @@ get() {
|
|||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
ssss | ss2022)
|
ssss | ss2022)
|
||||||
$is_core_bin generate rand 32 --base64
|
if [[ $(grep 128 <<<$ss_method) ]]; then
|
||||||
|
$is_core_bin generate rand 16 --base64
|
||||||
|
else
|
||||||
|
$is_core_bin generate rand 32 --base64
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
ping)
|
ping)
|
||||||
# is_ip_type="-4"
|
# is_ip_type="-4"
|
||||||
@@ -1532,7 +1536,8 @@ is_main_menu() {
|
|||||||
_try_enable_bbr
|
_try_enable_bbr
|
||||||
;;
|
;;
|
||||||
2)
|
2)
|
||||||
get log
|
load log.sh
|
||||||
|
log_set
|
||||||
;;
|
;;
|
||||||
3)
|
3)
|
||||||
get test-run
|
get test-run
|
||||||
|
|||||||
32
src/dns.sh
32
src/dns.sh
@@ -8,6 +8,9 @@ is_dns_list=(
|
|||||||
none
|
none
|
||||||
)
|
)
|
||||||
dns_set() {
|
dns_set() {
|
||||||
|
if [[ $(echo -e "1.11.99\n$is_core_ver" | sort -V | head -n1) == '1.11.99' ]]; then
|
||||||
|
is_dns_new=1
|
||||||
|
fi
|
||||||
if [[ $1 ]]; then
|
if [[ $1 ]]; then
|
||||||
case ${1,,} in
|
case ${1,,} in
|
||||||
11 | 1111)
|
11 | 1111)
|
||||||
@@ -46,11 +49,34 @@ dns_set() {
|
|||||||
ask string is_dns_use "请输入 DNS: "
|
ask string is_dns_use "请输入 DNS: "
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
is_dns_use_bak=$is_dns_use
|
||||||
if [[ $is_dns_use == "none" ]]; then
|
if [[ $is_dns_use == "none" ]]; then
|
||||||
cat <<<$(jq '.dns={}' $is_config_json) >$is_config_json
|
cat <<<$(jq '.|.dns={}|del(.route.default_domain_resolver)' $is_config_json) >$is_config_json
|
||||||
else
|
else
|
||||||
cat <<<$(jq '.dns.servers=[{address:"'$is_dns_use'",address_resolver:"local"},{tag:"local",address:"local"}]' $is_config_json) >$is_config_json
|
if [[ $is_dns_new ]]; then
|
||||||
|
dns_set_server $is_dns_use
|
||||||
|
cat <<<$(jq '.|.dns.servers=[{tag:"dns",type:"'$is_dns_type'",server:"'$is_dns_use'",domain_resolver:"local"},{tag:"local",type:"local"}]|.route.default_domain_resolver="dns"' $is_config_json) >$is_config_json
|
||||||
|
else
|
||||||
|
cat <<<$(jq '.dns.servers=[{address:"'$is_dns_use'",address_resolver:"local"},{tag:"local",address:"local"}]' $is_config_json) >$is_config_json
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
manage restart &
|
manage restart &
|
||||||
msg "\n已更新 DNS 为: $(_green $is_dns_use)\n"
|
msg "\n已更新 DNS 为: $(_green $is_dns_use_bak)\n"
|
||||||
|
}
|
||||||
|
dns_set_server() {
|
||||||
|
if [[ $(grep '://' <<<$1) ]]; then
|
||||||
|
is_tmp_dns_set=($(awk -F '://|/' '{print $1, $2}' <<<${1,,}))
|
||||||
|
case ${is_tmp_dns_set[0]} in
|
||||||
|
tcp | udp | tls | https | quic | h3)
|
||||||
|
is_dns_use=${is_tmp_dns_set[1]}
|
||||||
|
is_dns_type=${is_tmp_dns_set[0]}
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
err "无法识别 DNS 类型!"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
else
|
||||||
|
is_dns_use=$1
|
||||||
|
is_dns_type=udp
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
@@ -58,8 +58,8 @@ _wget() {
|
|||||||
wget --no-check-certificate "$@"
|
wget --no-check-certificate "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
# yum or apt-get
|
# apt-get, yum or zypper
|
||||||
cmd=$(type -P apt-get || type -P yum)
|
cmd=$(type -P apt-get || type -P yum || type -P zypper)
|
||||||
|
|
||||||
# x64
|
# x64
|
||||||
case $(arch) in
|
case $(arch) in
|
||||||
|
|||||||
Reference in New Issue
Block a user