上传文件至 xray1.8.4
This commit is contained in:
parent
20233a5d9e
commit
c38705786f
133
xray1.8.4/xray.init
Normal file
133
xray1.8.4/xray.init
Normal file
|
@ -0,0 +1,133 @@
|
|||
#!/bin/sh
|
||||
|
||||
#chkconfig: 2345 99 99
|
||||
### BEGIN INIT INFO
|
||||
# Provides: xray
|
||||
# Required-Start: $all
|
||||
# Required-Stop: $all
|
||||
# Default-Start: 2 3 4 5
|
||||
# Default-Stop: 0 1 6
|
||||
# Short-Description: Start xray daemon at boot time
|
||||
# Description: Start xray daemon at boot time
|
||||
### END INIT INFO
|
||||
START=99
|
||||
EXTRA_COMMANDS="status"
|
||||
|
||||
usage()
|
||||
{
|
||||
if type systemctl && [ -z "$(systemctl --failed|grep -q 'Host is down')" ]; then
|
||||
us="systemctl [start|stop|status|restart] xray.service"
|
||||
else
|
||||
if [ "$0" = '/etc/rc.common' ]; then
|
||||
us="/etc/init.d/xray [start|stop|status|restart]"\
|
||||
else
|
||||
us="$0 [start|stop|status|restart]"
|
||||
fi
|
||||
fi &>/dev/null
|
||||
echo "Usage:
|
||||
$us
|
||||
Config file is [xray_install_directory]/xray.json"
|
||||
} 2>/dev/null
|
||||
|
||||
status()
|
||||
{
|
||||
grep -q xray /proc/`cat [xray_install_directory]/run.pid`/comm && \
|
||||
echo "xray is running..." || \
|
||||
echo "xray is stopped..."
|
||||
} 2>/dev/null
|
||||
|
||||
start()
|
||||
{
|
||||
status | grep "xray is running..." && return 0
|
||||
echo -n "Starting xray:"
|
||||
echo 3 >/proc/sys/net/ipv4/tcp_fastopen
|
||||
ulimit -n 1048576
|
||||
cd "[xray_install_directory]"
|
||||
(while :; do
|
||||
./xray run -config xray.json &
|
||||
echo $! >[xray_install_directory]/run.pid
|
||||
sleep 3
|
||||
while grep -q xray /proc/`cat [xray_install_directory]/run.pid`/comm; do
|
||||
sleep 3
|
||||
done
|
||||
done >/dev/null &
|
||||
echo $! >[xray_install_directory]/drun.pid)
|
||||
count=0
|
||||
while [ ! -f "[xray_install_directory]/run.pid" ] && [ "$count" -le 5 ]; do
|
||||
sleep 1
|
||||
count=$((count + 1))
|
||||
done
|
||||
sleep 1
|
||||
for server_port in [xray_tcp_port_list]; do
|
||||
iptables -I INPUT -p 6 --dport $server_port -j ACCEPT
|
||||
ip6tables -I INPUT -p 6 --dport $server_port -j ACCEPT
|
||||
done
|
||||
for server_port in [xray_udp_port_list]; do
|
||||
iptables -I INPUT -p 17 --dport $server_port -j ACCEPT
|
||||
ip6tables -I INPUT -p 17 --dport $server_port -j ACCEPT
|
||||
done
|
||||
grep -q xray /proc/`cat [xray_install_directory]/run.pid`/comm && \
|
||||
echo -e "\033[60G[\033[32m OK \033[0m]" || \
|
||||
echo -e "\033[60G[\033[31mFAILED\033[0m]"
|
||||
} 2>/dev/null
|
||||
|
||||
stop()
|
||||
{
|
||||
for server_port in [xray_tcp_port_list]; do
|
||||
iptables -D INPUT -p 6 --dport $server_port -j ACCEPT
|
||||
ip6tables -D INPUT -p 6 --dport $server_port -j ACCEPT
|
||||
done
|
||||
for server_port in [xray_udp_port_list]; do
|
||||
iptables -D INPUT -p 17 --dport $server_port -j ACCEPT
|
||||
ip6tables -D INPUT -p 17 --dport $server_port -j ACCEPT
|
||||
done
|
||||
status | grep "xray is stopped..." && return 0
|
||||
echo -n "Stopping xray:"
|
||||
kill -9 `cat [xray_install_directory]/drun.pid`
|
||||
kill -9 `cat [xray_install_directory]/run.pid`
|
||||
sleep 1
|
||||
grep -q xray /proc/`cat [xray_install_directory]/run.pid`/comm && \
|
||||
echo -e "\033[60G[\033[31mFAILED\033[0m]" || \
|
||||
echo -e "\033[60G[\033[32m OK \033[0m]"
|
||||
} 2>/dev/null
|
||||
|
||||
restart()
|
||||
{
|
||||
stop
|
||||
start
|
||||
} 2>/dev/null
|
||||
|
||||
systemdStart()
|
||||
{
|
||||
status | grep running && return 0
|
||||
cd "[xray_install_directory]"
|
||||
for server_port in [xray_tcp_port_list]; do
|
||||
iptables -I INPUT -p 6 --dport $server_port -j ACCEPT
|
||||
ip6tables -I INPUT -p 6 --dport $server_port -j ACCEPT
|
||||
done
|
||||
for server_port in [xray_udp_port_list]; do
|
||||
iptables -I INPUT -p 17 --dport $server_port -j ACCEPT
|
||||
ip6tables -I INPUT -p 17 --dport $server_port -j ACCEPT
|
||||
done
|
||||
ulimit -n 1048576
|
||||
cd "[xray_install_directory]"
|
||||
(while :; do
|
||||
./xray run -config xray.json &
|
||||
echo $! >[xray_install_directory]/run.pid
|
||||
sleep 3
|
||||
while grep -q xray /proc/`cat [xray_install_directory]/run.pid`/comm; do
|
||||
sleep 3
|
||||
done
|
||||
done >/dev/null &
|
||||
echo $! >[xray_install_directory]/drun.pid)
|
||||
} 2>/dev/null
|
||||
|
||||
systemdRestart()
|
||||
{
|
||||
stop
|
||||
systemdStart
|
||||
} 2>/dev/null
|
||||
|
||||
if [ -z "$initscript" ]; then
|
||||
${1:-usage}
|
||||
fi
|
16
xray1.8.4/xray.service
Normal file
16
xray1.8.4/xray.service
Normal file
|
@ -0,0 +1,16 @@
|
|||
[Unit]
|
||||
Description=xray - Project V
|
||||
Documentation=https://github.com/XTLS/Xray-core
|
||||
|
||||
[Service]
|
||||
Type=forking
|
||||
PIDFile=[xray_install_directory]/run.pid
|
||||
ExecStart=[xray_install_directory]/xray.init systemdStart
|
||||
ExecReload=[xray_install_directory]/xray.init systemdRestart
|
||||
ExecStop=[xray_install_directory]/xray.init stop
|
||||
PrivateTmp=true
|
||||
KillMode=control-group
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
||||
|
510
xray1.8.4/xray.sh
Normal file
510
xray1.8.4/xray.sh
Normal file
|
@ -0,0 +1,510 @@
|
|||
#!/bin/bash
|
||||
|
||||
#Stop xray & delete xray files.
|
||||
Delete() {
|
||||
systemctl disable xray.service
|
||||
rm -rf /etc/init.d/xray /lib/systemd/system/xray.service
|
||||
if [ -f "${xray_install_directory:=/usr/local/xray}/xray.init" ]; then
|
||||
"$xray_install_directory"/xray.init stop
|
||||
rm -rf "$xray_install_directory"
|
||||
fi
|
||||
}
|
||||
|
||||
#Print error message and exit.
|
||||
Error() {
|
||||
echo $echo_e_arg "\033[41;37m$1\033[0m"
|
||||
echo -n "remove xray?[y]: "
|
||||
read remove
|
||||
echo "$remove"|grep -qi 'n' || Delete
|
||||
exit 1
|
||||
}
|
||||
|
||||
makeTcpInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local protocol="$3"
|
||||
local flow="$4"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"sockopt": {
|
||||
"tcpFastOpen": '$tcpFastOpen'
|
||||
},
|
||||
"network": "tcp"'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeTcpHttpInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local protocol="$3"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"sockopt": {
|
||||
"tcpFastOpen": '$tcpFastOpen'
|
||||
},
|
||||
"network": "tcp",
|
||||
"tcpSettings": {
|
||||
"header": {
|
||||
"type": "http"
|
||||
}
|
||||
}'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeWSInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local url="$3"
|
||||
local protocol="$4"
|
||||
local flow="$5"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"sockopt": {
|
||||
"tcpFastOpen": '$tcpFastOpen'
|
||||
},
|
||||
"network": "ws",
|
||||
"wsSettings": {
|
||||
"path": "'$url'"
|
||||
}'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeMkcpInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local headerType="$3"
|
||||
local protocol="$4"
|
||||
local flow="$5"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"network": "kcp",
|
||||
"kcpSettings": {
|
||||
"header": {
|
||||
"type": "'$headerType'"
|
||||
}
|
||||
}'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeTrojanInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local flow="$3"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "trojan",
|
||||
"settings": {
|
||||
"clients": [{
|
||||
"password": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0
|
||||
}]
|
||||
},
|
||||
"streamSettings": {
|
||||
"netowork": "tcp"'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
#Input xray.json
|
||||
Config() {
|
||||
clear
|
||||
uuid=`cat /proc/sys/kernel/random/uuid`
|
||||
tcpFastOpen=`[ -f /proc/sys/net/ipv4/tcp_fastopen ] && echo -n 'true' || echo -n 'false'`
|
||||
if [ -z "$xray_install_directory" ]; then
|
||||
echo -n "Please input xray install directory(default is /usr/local/xray): "
|
||||
read xray_install_directory
|
||||
echo $echo_e_arg "options(TLS default self signed certificate, if necessary, please change it yourself.):
|
||||
\r1. tcp http (vmess)
|
||||
\r2. tcp tls (vmess)
|
||||
\r3. tcp reality (vless)
|
||||
\r4. websocket (vmess)
|
||||
\r5. websocket tls (vmess)
|
||||
\r6. websocket tls (vless)
|
||||
\r7. mkcp (vmess)
|
||||
\r8. mkcp tls (vmess)
|
||||
\r9. mkcp tls (vless)
|
||||
\r10. trojan tls
|
||||
\rPlease input your options(Separate multiple options with spaces):"
|
||||
read xray_inbounds_options
|
||||
for opt in $xray_inbounds_options; do
|
||||
case $opt in
|
||||
1)
|
||||
echo -n "Please input vmess tcp http server port: "
|
||||
read vmess_tcp_http_port
|
||||
;;
|
||||
2)
|
||||
echo -n "Please input vmess tcp tls server port: "
|
||||
read vmess_tcp_tls_port
|
||||
;;
|
||||
3)
|
||||
echo -n "Please input vless tcp reality server port: "
|
||||
read vless_tcp_reality_port
|
||||
;;
|
||||
4)
|
||||
echo -n "Please input vmess websocket server port: "
|
||||
read vmess_ws_port
|
||||
echo -n "Please input vmess websocket Path(default is '/'): "
|
||||
read vmess_ws_path
|
||||
vmess_ws_path=${vmess_ws_path:-/}
|
||||
;;
|
||||
5)
|
||||
echo -n "Please input vmess websocket tls server port: "
|
||||
read vmess_ws_tls_port
|
||||
echo -n "Please input vmess websocket tls Path(default is '/'): "
|
||||
read vmess_ws_tls_path
|
||||
vmess_ws_tls_path=${vmess_ws_tls_path:-/}
|
||||
;;
|
||||
6)
|
||||
echo -n "Please input vless websocket tls server port: "
|
||||
read vless_ws_tls_port
|
||||
echo -n "Please input vless websocket tls Path(default is '/'): "
|
||||
read vless_ws_tls_path
|
||||
vless_ws_tls_path=${vless_ws_tls_path:-/}
|
||||
;;
|
||||
7)
|
||||
echo -n "Please input vmess mKCP server port: "
|
||||
read vmess_mkcp_port
|
||||
;;
|
||||
8)
|
||||
echo -n "Please input vmess mKCP tls server port: "
|
||||
read vmess_mkcp_tls_port
|
||||
;;
|
||||
9)
|
||||
echo -n "Please input vless mKCP tls server port: "
|
||||
read vless_mkcp_tls_port
|
||||
;;
|
||||
10)
|
||||
echo -n "Please input trojan tls server port: "
|
||||
read trojan_tls_port
|
||||
;;
|
||||
esac
|
||||
done
|
||||
echo -n "Install UPX compress version?[n]: "
|
||||
read xray_UPX
|
||||
fi
|
||||
echo "$xray_UPX"|grep -qi '^y' && xray_UPX="upx" || xray_UPX=""
|
||||
}
|
||||
|
||||
GetAbi() {
|
||||
machine=`uname -m`
|
||||
if echo "$machine"|grep -q 'mips64'; then
|
||||
shContent=`cat "$SHELL"`
|
||||
[ "${shContent:5:1}" = `echo $echo_e_arg "\x01"` ] && machine='mips64le' || machine='mips64'
|
||||
elif echo "$machine"|grep -q 'mips'; then
|
||||
shContent=`cat "$SHELL"`
|
||||
[ "${shContent:5:1}" = `echo $echo_e_arg "\x01"` ] && machine='mipsle' || machine='mips'
|
||||
elif echo "$machine"|grep -Eq 'i686|i386'; then
|
||||
machine='386'
|
||||
elif echo "$machine"|grep -Eq 'armv7|armv6'; then
|
||||
machine='arm'
|
||||
elif echo "$machine"|grep -Eq 'armv8|aarch64'; then
|
||||
machine='arm64'
|
||||
elif echo "$machine"|grep -q 's390x'; then
|
||||
machine='s390x'
|
||||
else
|
||||
machine='amd64'
|
||||
fi
|
||||
}
|
||||
|
||||
#install xray xray.init xray.service
|
||||
InstallFile() {
|
||||
GetAbi
|
||||
if echo "$machine" | grep -q '^mips'; then
|
||||
cat /proc/cpuinfo | grep -qiE 'fpu|neon|vfp|softfp|asimd' || softfloat='_softfloat'
|
||||
fi
|
||||
mkdir -p "${xray_install_directory:=/usr/local/xray}" || Error "Create xray install directory failed."
|
||||
cd "$xray_install_directory" || Error "Create cns install directory failed."
|
||||
#install xray
|
||||
$download_tool_cmd xray http://binary.quicknet.cyou/xray/${xray_UPX}/linux_${machine}${softfloat} || Error "xray download failed."
|
||||
$download_tool_cmd xray.init http://binary.quicknet.cyou/xray/xray.init || Error "xray.init download failed."
|
||||
[ -f '/etc/rc.common' ] && rcCommon='/etc/rc.common'
|
||||
sed -i "s~#!/bin/sh~#!$SHELL $rcCommon~" xray.init
|
||||
sed -i "s~\[xray_install_directory\]~$xray_install_directory~g" xray.init
|
||||
sed -i "s~\[xray_tcp_port_list\]~$xray_http_port $xray_http_tls_port $vmess_ws_port $vmess_ws_tls_port $trojan_tls_port $xray_trojan_xtls_port~g" xray.init
|
||||
sed -i "s~\[xray_udp_port_list\]~$vmess_mkcp_port $xray_mkcp_xtls_port~g" xray.init
|
||||
ln -s "$xray_install_directory/xray.init" /etc/init.d/xray
|
||||
chmod -R +rwx "$xray_install_directory" /etc/init.d/xray
|
||||
if which systemctl && [ -z "$(systemctl --failed|grep -q 'Host is down')" ]; then
|
||||
$download_tool_cmd /lib/systemd/system/xray.service http://binary.quicknet.cyou/xray/xray.service || Error "xray.service download failed."
|
||||
chmod +rwx /lib/systemd/system/xray.service
|
||||
sed -i "s~\[xray_install_directory\]~$xray_install_directory~g" /lib/systemd/system/xray.service
|
||||
systemctl daemon-reload
|
||||
fi
|
||||
#make json config
|
||||
realityKey=`./xray x25519`
|
||||
realityPvk=`echo "$realityKey"|grep 'Private key: '`
|
||||
realityPvk=${realityPvk#*: }
|
||||
realityPbk=`echo "$realityKey"|grep 'Public key: '`
|
||||
realityPbk=${realityPbk#*: }
|
||||
sid=${uuid##*-}
|
||||
realitySni='www.apple.com'
|
||||
realityServerNames='"www.apple.com", "images.apple.com"'
|
||||
local realityConfig=',
|
||||
"security": "reality",
|
||||
"realitySettings": {
|
||||
"show": false,
|
||||
"dest": "'$realitySni':443",
|
||||
"xver": 0,
|
||||
"serverNames": [
|
||||
'$realityServerNames'
|
||||
],
|
||||
"privateKey": "'$realityPvk'",
|
||||
"shortIds": [
|
||||
"'${sid}'"
|
||||
]
|
||||
}'
|
||||
local tlsConfig=',
|
||||
"security": "tls",
|
||||
"tlsSettings": {
|
||||
"certificates": ['"`./xray tls cert`"']
|
||||
}'
|
||||
for opt in $xray_inbounds_options; do
|
||||
[ -n "$in_networks" ] && in_networks="$in_networks, "
|
||||
case $opt in
|
||||
1) in_networks="$in_networks"`makeTcpHttpInbound "$vmess_tcp_http_port" "" 'vmess' ''`;;
|
||||
2) in_networks="$in_networks"`makeTcpInbound "$vmess_tcp_tls_port" "$tlsConfig" 'vmess' ''`;;
|
||||
3) in_networks="$in_networks"`makeTcpInbound "$vless_tcp_reality_port" "$realityConfig" 'vless' 'xtls-rprx-vision'`;;
|
||||
4) in_networks="$in_networks"`makeWSInbound "$vmess_ws_port" "" "$vmess_ws_path" 'vmess' ''`;;
|
||||
5) in_networks="$in_networks"`makeWSInbound "$vmess_ws_tls_port" "$tlsConfig" "$vmess_ws_tls_path" 'vmess' ''`;;
|
||||
6) in_networks="$in_networks"`makeWSInbound "$vless_ws_tls_port" "$tlsConfig" "$vless_ws_tls_path" 'vless' ''`;;
|
||||
7) in_networks="$in_networks"`makeMkcpInbound "$vmess_mkcp_port" "" "utp" 'vmess' ''`;;
|
||||
8) in_networks="$in_networks"`makeMkcpInbound "$vmess_mkcp_tls_port" "$tlsConfig" "none" 'vmess' ''`;;
|
||||
9) in_networks="$in_networks"`makeMkcpInbound "$vless_mkcp_tls_port" "$tlsConfig" "none" 'vless' ''`;;
|
||||
10) in_networks="$in_networks"`makeTrojanInbound "$trojan_tls_port" "$tlsConfig" ''`;;
|
||||
esac
|
||||
done
|
||||
echo $echo_E_arg '
|
||||
{
|
||||
"log" : {
|
||||
"loglevel": "none"
|
||||
},
|
||||
"inbounds": ['"$in_networks"'],
|
||||
"outbounds": [{
|
||||
"protocol": "freedom"
|
||||
}]
|
||||
}
|
||||
' >xray.json
|
||||
}
|
||||
|
||||
#install initialization
|
||||
InstallInit() {
|
||||
echo -n "make a update?[n]: "
|
||||
read update
|
||||
PM=`which apt-get || which yum`
|
||||
echo "$update"|grep -qi 'y' && $PM -y update
|
||||
$PM -y install curl wget #unzip
|
||||
type curl && download_tool_cmd='curl -L --connect-timeout 7 -ko' || download_tool_cmd='wget -T 60 --no-check-certificate -O'
|
||||
getip_urls="http://myip.quicknet.cyou http://myip.dnsomatic.com/ http://ip.sb/"
|
||||
for url in $getip_urls; do
|
||||
ip=`$download_tool_cmd - "$url" | grep -E '([0-9]{1,3}\.){3}[0-9]{1,3}|:'`
|
||||
[ -n "$ip" ] && break
|
||||
done
|
||||
}
|
||||
|
||||
outputLink() {
|
||||
[ -z "$ip" ] && return
|
||||
for opt in $xray_inbounds_options; do
|
||||
case $opt in
|
||||
1)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": '$vmess_tcp_http_port', "aid": "0", "host": "obfs.domain", "id": "'$uuid'", "net": "tcp", "path": "/", "ps": "vmess_tcp_http_'$ip:$vmess_tcp_http_port'", "tls": "", "type": "http", "v": "2"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess tcp http:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
2)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": '$vmess_tcp_tls_port', "aid": "0", "host": "", "id": "'$uuid'", "net": "tcp", "path": "", "ps": "vmess_tcp_tls_'$ip:$vmess_tcp_tls_port'", "tls": "tls", "type": "none", "v": "2", "fp": "chrome"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess tcp tls:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
3)
|
||||
echo $echo_e_arg "\033[45;37m\rvless tcp reality:\033[0m\n\t\033[4;35mvless://${uuid}@${ip}:${vless_tcp_reality_port}?security=reality&sni=${realitySni}&encryption=none&headerType=none&type=tcp&fp=chrome&flow=xtls-rprx-vision&sid=${sid}&pbk=$realityPbk&spx=/iphone-14-pro#vless_tcp_reality${ip}:${vless_tcp_reality_port}\033[0m"
|
||||
;;
|
||||
4)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_ws_port'", "aid": "0", "host": "obfs.domain", "id": "'$uuid'", "net": "ws", "path": "'$vmess_ws_path'", "ps": "ws_'$ip:$vmess_ws_port'", "tls": "", "type": "none", "v": "2"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess ws:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
5)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_ws_tls_port'", "aid": "0", "host": "obfs.domain", "id": "'$uuid'", "net": "ws", "path": "'$vmess_ws_tls_path'", "ps": "ws_tls_'$ip:$vmess_ws_tls_port'", "tls": "tls", "type": "none", "v": "2", "fp": "chrome"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess ws tls:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
6)
|
||||
echo $echo_e_arg "\033[45;37m\r vless ws tls:\033[0m\n\t\033[4;35mvless://${uuid}@${ip}:${vless_ws_tls_port}?security=tls&sni=obfs.domain&encryption=none&type=ws&path=$vless_ws_tls_path&host=obfs.domain&fp=chrome`date +%s`#vless_ws_tls${ip}:${vless_ws_tls_port}\033[0m"
|
||||
;;
|
||||
7)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_mkcp_port'", "aid": "0", "host": "", "id": "'$uuid'", "net": "kcp", "path": "", "ps": "vmess_mkcp_'$ip:$vmess_mkcp_port'", "tls": "", "type": "utp", "v": "2"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess mkcp:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
8)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_mkcp_tls_port'", "aid": "0", "host": "", "id": "'$uuid'", "net": "kcp", "path": "", "ps": "vmess_mkcp_tls_'$ip:$vmess_mkcp_port'", "tls": "tls", "type": "none", "v": "2", "fp": "chrome"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess mkcp tls:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
9)
|
||||
echo $echo_e_arg "\033[45;37m\r vless mkcp tls:\033[0m\n\t\033[4;35mvless://${uuid}@${ip}:${vless_mkcp_tls_port}?security=tls&sni=obfs.domain&encryption=none&type=kcp&headerType=none&fp=chrome`date +%s`#vless_ws_tls${ip}:${vless_mkcp_tls_port}\033[0m"
|
||||
;;
|
||||
10)
|
||||
echo $echo_e_arg "\033[45;37m\rtrojan tls:\033[0m\n\t\033[4;35mtrojan://${uuid}@${ip}:${trojan_tls_port}?security=tls&sni=obfs.domain#trojan_tls_${ip}:${trojan_tls_port}\033[0m"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
AddAutoStart() {
|
||||
if [ -n "$rcCommon" ]; then
|
||||
if /etc/init.d/xray enable; then
|
||||
echo 'Autostart enabled, if you need to close it, run: /etc/init.d/xray disable'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if type systemctl &>/dev/null && [ -z "$(systemctl --failed|grep -q 'Host is down')" ]; then
|
||||
if systemctl enable xray &>/dev/null; then
|
||||
echo 'Autostart enabled, if you need to close it, run: systemctl disable xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if type chkconfig &>/dev/null; then
|
||||
if chkconfig --add xray &>/dev/null && chkconfig xray on &>/dev/null; then
|
||||
echo 'Autostart enabled, if you need to close it, run: chkconfig xray off'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if [ -d '/etc/rc.d/rc5.d' -a -f '/etc/init.d/xray' ]; then
|
||||
if ln -s '/etc/init.d/xray' '/etc/rc.d/rc5.d/S99xray'; then
|
||||
echo 'Autostart enabled, if you need to close it, run: rm -f /etc/rc.d/rc5.d/S99xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if [ -d '/etc/rc5.d' -a -f '/etc/init.d/xray' ]; then
|
||||
if ln -s '/etc/init.d/xray' '/etc/rc5.d/S99xray'; then
|
||||
echo 'Autostart enabled, if you need to close it, run: rm -f /etc/rc5.d/S99xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if [ -d '/etc/rc.d' -a -f '/etc/init.d/xray' ]; then
|
||||
if ln -s '/etc/init.d/xray' '/etc/rc.d/S99xray'; then
|
||||
echo 'Autostart enabled, if you need to close it, run: rm -f /etc/rc.d/S99xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
echo 'Autostart disabled'
|
||||
}
|
||||
|
||||
Install() {
|
||||
Config
|
||||
Delete >/dev/null 2>&1
|
||||
InstallInit
|
||||
InstallFile
|
||||
"$xray_install_directory/xray.init" start|grep -q FAILED && Error "xray install failed."
|
||||
which systemctl && [ -z "$(systemctl --failed|grep -q 'Host is down')" ] && systemctl restart xray &>/dev/null
|
||||
echo $echo_e_arg \
|
||||
"\033[44;37mxray install success.\033[0;34m
|
||||
`
|
||||
for opt in $xray_inbounds_options; do
|
||||
case $opt in
|
||||
1)
|
||||
echo $echo_e_arg "\r vmess tcp http server:\033[34G port=${vmess_tcp_http_port}";;
|
||||
2)
|
||||
echo $echo_e_arg "\r vmess tcp tls server:\033[34G port=${vmess_tcp_tls_port}";;
|
||||
3)
|
||||
echo $echo_e_arg "\r vless tcp reality server:\033[34G port=${vless_tcp_reality_port}"
|
||||
echo $echo_e_arg "\r flow:\033[34G xtls-rprx-vision"
|
||||
echo $echo_e_arg "\r serverName:\033[34G ${realitySni}"
|
||||
echo $echo_e_arg "\r publicKey:\033[34G ${realityPbk}"
|
||||
echo $echo_e_arg "\r shortId:\033[34G ${sid}"
|
||||
;;
|
||||
4)
|
||||
echo $echo_e_arg "\r vmess ws server:\033[34G port=${vmess_ws_port} path=${vmess_ws_path}";;
|
||||
5)
|
||||
echo $echo_e_arg "\r vmess ws tls server:\033[34G port=${vmess_ws_tls_port} path=${vmess_ws_tls_path}";;
|
||||
6)
|
||||
echo $echo_e_arg "\r vless ws tls server:\033[34G port=${vless_ws_tls_port} path=${vless_ws_tls_path}";;
|
||||
7)
|
||||
echo $echo_e_arg "\r vmess mkcp server:\033[34G port=${vmess_mkcp_port} type=utp";;
|
||||
8)
|
||||
echo $echo_e_arg "\r vmess mkcp tls server:\033[34G port=${vmess_mkcp_tls_port} type=none";;
|
||||
9)
|
||||
echo $echo_e_arg "\r vless mkcp tls server:\033[34G port=${vless_mkcp_tls_port} type=none";;
|
||||
10)
|
||||
echo $echo_e_arg "\r trojan tls server:\033[34G port=${trojan_tls_port}";;
|
||||
esac
|
||||
done
|
||||
`
|
||||
\r uuid:\033[35G$uuid
|
||||
\r alterId:\033[35G0
|
||||
\r`[ -f /etc/init.d/xray ] && /etc/init.d/xray usage || \"$xray_install_directory/xray.init\" usage`
|
||||
\r`AddAutoStart`
|
||||
`outputLink`\033[0m"
|
||||
}
|
||||
|
||||
Uninstall() {
|
||||
if [ -z "$xray_install_directory" ]; then
|
||||
echo -n "Please input xray install directory(default is /usr/local/xray): "
|
||||
read xray_install_directory
|
||||
fi
|
||||
Delete &>/dev/null && \
|
||||
echo $echo_e_arg "\n\033[44;37mxray uninstall success.\033[0m" || \
|
||||
echo $echo_e_arg "\n\033[41;37mxray uninstall failed.\033[0m"
|
||||
}
|
||||
|
||||
#script initialization
|
||||
ScriptInit() {
|
||||
emulate bash 2>/dev/null #zsh emulation mode
|
||||
if echo -e ''|grep -q 'e'; then
|
||||
echo_e_arg=''
|
||||
echo_E_arg=''
|
||||
else
|
||||
echo_e_arg='-e'
|
||||
echo_E_arg='-E'
|
||||
fi
|
||||
}
|
||||
|
||||
ScriptInit
|
||||
echo $*|grep -qi uninstall && Uninstall || Install
|
513
xray1.8.4/xray1.sh
Normal file
513
xray1.8.4/xray1.sh
Normal file
|
@ -0,0 +1,513 @@
|
|||
#!/bin/bash
|
||||
|
||||
#Stop xray & delete xray files.
|
||||
Delete() {
|
||||
systemctl disable xray.service
|
||||
rm -rf /etc/init.d/xray /lib/systemd/system/xray.service
|
||||
if [ -f "${xray_install_directory:=/usr/local/xray}/xray.init" ]; then
|
||||
"$xray_install_directory"/xray.init stop
|
||||
rm -rf "$xray_install_directory"
|
||||
fi
|
||||
}
|
||||
|
||||
#Print error message and exit.
|
||||
Error() {
|
||||
echo $echo_e_arg "\033[41;37m$1\033[0m"
|
||||
echo -n "remove xray?[y]: "
|
||||
read remove
|
||||
echo "$remove"|grep -qi 'n' || Delete
|
||||
exit 1
|
||||
}
|
||||
|
||||
makeTcpInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local protocol="$3"
|
||||
local flow="$4"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"sockopt": {
|
||||
"tcpFastOpen": '$tcpFastOpen'
|
||||
},
|
||||
"network": "tcp"'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeTcpHttpInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local protocol="$3"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"sockopt": {
|
||||
"tcpFastOpen": '$tcpFastOpen'
|
||||
},
|
||||
"network": "tcp",
|
||||
"tcpSettings": {
|
||||
"header": {
|
||||
"type": "http"
|
||||
}
|
||||
}'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeWSInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local url="$3"
|
||||
local protocol="$4"
|
||||
local flow="$5"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"sockopt": {
|
||||
"tcpFastOpen": '$tcpFastOpen'
|
||||
},
|
||||
"network": "ws",
|
||||
"wsSettings": {
|
||||
"path": "'$url'"
|
||||
}'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeMkcpInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local headerType="$3"
|
||||
local protocol="$4"
|
||||
local flow="$5"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "'$protocol'",
|
||||
"settings": {
|
||||
"udp": true,
|
||||
"clients": [{
|
||||
"id": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0,
|
||||
"alterId": 0
|
||||
}],
|
||||
"decryption": "none"
|
||||
},
|
||||
"streamSettings": {
|
||||
"network": "kcp",
|
||||
"kcpSettings": {
|
||||
"header": {
|
||||
"type": "'$headerType'"
|
||||
}
|
||||
}'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
makeTrojanInbound() {
|
||||
local port="$1"
|
||||
local securityConfig="$2"
|
||||
local flow="$3"
|
||||
echo '{
|
||||
"port": "'$port'",
|
||||
"protocol": "trojan",
|
||||
"settings": {
|
||||
"clients": [{
|
||||
"password": "'$uuid'",
|
||||
"flow": "'$flow'",
|
||||
"level": 0
|
||||
}]
|
||||
},
|
||||
"streamSettings": {
|
||||
"netowork": "tcp"'$securityConfig'
|
||||
}
|
||||
}'
|
||||
}
|
||||
|
||||
#Input xray.json
|
||||
Config() {
|
||||
clear
|
||||
uuid=`cat /proc/sys/kernel/random/uuid`
|
||||
tcpFastOpen=`[ -f /proc/sys/net/ipv4/tcp_fastopen ] && echo -n 'true' || echo -n 'false'`
|
||||
if [ -z "$xray_install_directory" ]; then
|
||||
echo -n "Please input xray install directory(default is /usr/local/xray): "
|
||||
read xray_install_directory
|
||||
echo $echo_e_arg "options(TLS default self signed certificate, if necessary, please change it yourself.):
|
||||
\r1. tcp http (vmess)
|
||||
\r2. tcp tls (vmess)
|
||||
\r3. tcp reality (vless)
|
||||
\r4. websocket (vmess)
|
||||
\r5. websocket tls (vmess)
|
||||
\r6. websocket tls (vless)
|
||||
\r7. mkcp (vmess)
|
||||
\r8. mkcp tls (vmess)
|
||||
\r9. mkcp tls (vless)
|
||||
\r10. trojan tls
|
||||
\rPlease input your options(Separate multiple options with spaces):"
|
||||
read xray_inbounds_options
|
||||
for opt in $xray_inbounds_options; do
|
||||
case $opt in
|
||||
1)
|
||||
echo -n "Please input vmess tcp http server port: "
|
||||
read vmess_tcp_http_port
|
||||
;;
|
||||
2)
|
||||
echo -n "Please input vmess tcp tls server port: "
|
||||
read vmess_tcp_tls_port
|
||||
;;
|
||||
3)
|
||||
echo -n "Please input vless tcp reality server port: "
|
||||
read vless_tcp_reality_port
|
||||
;;
|
||||
4)
|
||||
echo -n "Please input vmess websocket server port: "
|
||||
read vmess_ws_port
|
||||
echo -n "Please input vmess websocket Path(default is '/'): "
|
||||
read vmess_ws_path
|
||||
vmess_ws_path=${vmess_ws_path:-/}
|
||||
;;
|
||||
5)
|
||||
echo -n "Please input vmess websocket tls server port: "
|
||||
read vmess_ws_tls_port
|
||||
echo -n "Please input vmess websocket tls Path(default is '/'): "
|
||||
read vmess_ws_tls_path
|
||||
vmess_ws_tls_path=${vmess_ws_tls_path:-/}
|
||||
;;
|
||||
6)
|
||||
echo -n "Please input vless websocket tls server port: "
|
||||
read vless_ws_tls_port
|
||||
echo -n "Please input vless websocket tls Path(default is '/'): "
|
||||
read vless_ws_tls_path
|
||||
vless_ws_tls_path=${vless_ws_tls_path:-/}
|
||||
;;
|
||||
7)
|
||||
echo -n "Please input vmess mKCP server port: "
|
||||
read vmess_mkcp_port
|
||||
;;
|
||||
8)
|
||||
echo -n "Please input vmess mKCP tls server port: "
|
||||
read vmess_mkcp_tls_port
|
||||
;;
|
||||
9)
|
||||
echo -n "Please input vless mKCP tls server port: "
|
||||
read vless_mkcp_tls_port
|
||||
;;
|
||||
10)
|
||||
echo -n "Please input trojan tls server port: "
|
||||
read trojan_tls_port
|
||||
;;
|
||||
esac
|
||||
done
|
||||
echo -n "Install UPX compress version?[n]: "
|
||||
read xray_UPX
|
||||
fi
|
||||
echo "$xray_UPX"|grep -qi '^y' && xray_UPX="upx" || xray_UPX=""
|
||||
}
|
||||
|
||||
GetAbi() {
|
||||
machine=`uname -m`
|
||||
if echo "$machine"|grep -q 'mips64'; then
|
||||
shContent=`cat "$SHELL"`
|
||||
[ "${shContent:5:1}" = `echo $echo_e_arg "\x01"` ] && machine='mips64le' || machine='mips64'
|
||||
elif echo "$machine"|grep -q 'mips'; then
|
||||
shContent=`cat "$SHELL"`
|
||||
[ "${shContent:5:1}" = `echo $echo_e_arg "\x01"` ] && machine='mipsle' || machine='mips'
|
||||
elif echo "$machine"|grep -Eq 'i686|i386'; then
|
||||
machine='386'
|
||||
elif echo "$machine"|grep -q 'armv7'; then
|
||||
machine='armv7'
|
||||
elif echo "$machine"|grep -q 'armv6'; then
|
||||
machine='armv6'
|
||||
elif echo "$machine"|grep -Eq 'armv8|aarch64'; then
|
||||
machine='arm64'
|
||||
elif echo "$machine"|grep -q 's390x'; then
|
||||
machine='s390x'
|
||||
else
|
||||
machine='amd64'
|
||||
fi
|
||||
}
|
||||
|
||||
#install xray xray.init xray.service
|
||||
InstallFile() {
|
||||
GetAbi
|
||||
mkdir -p "${xray_install_directory:=/usr/local/xray}" || Error "Create xray install directory failed."
|
||||
cd "$xray_install_directory" || Error "Create cns install directory failed."
|
||||
#install xray
|
||||
$download_tool_cmd xray.tar.gz https://jihulab.com/hepingcaizi/sao/-/raw/main/v2ray/xray_1.8.4/xray-linux-${machine}.tar.gz || Error "xray download failed."
|
||||
tar -zxvf xray.tar.gz && rm -f xray.tar.gz
|
||||
if echo "$machine" | grep -q '^mips'; then
|
||||
cat /proc/cpuinfo | grep -qiE 'fpu|neon|vfp|softfp|asimd' || mv -f xray_softfloat xray
|
||||
fi
|
||||
$download_tool_cmd xray.init https://jihulab.com/hepingcaizi/sao/-/raw/main/v2ray/xray_1.8.4/xray.init || Error "xray.init download failed."
|
||||
[ -f '/etc/rc.common' ] && rcCommon='/etc/rc.common'
|
||||
sed -i "s~#!/bin/sh~#!$SHELL $rcCommon~" xray.init
|
||||
sed -i "s~\[xray_install_directory\]~$xray_install_directory~g" xray.init
|
||||
sed -i "s~\[xray_tcp_port_list\]~$xray_http_port $xray_http_tls_port $vmess_ws_port $vmess_ws_tls_port $trojan_tls_port $xray_trojan_xtls_port~g" xray.init
|
||||
sed -i "s~\[xray_udp_port_list\]~$vmess_mkcp_port $xray_mkcp_xtls_port~g" xray.init
|
||||
ln -s "$xray_install_directory/xray.init" /etc/init.d/xray
|
||||
chmod -R +rwx "$xray_install_directory" /etc/init.d/xray
|
||||
if which systemctl && [ -z "$(systemctl --failed|grep -q 'Host is down')" ]; then
|
||||
$download_tool_cmd /lib/systemd/system/xray.service https://jihulab.com/hepingcaizi/sao/-/raw/main/v2ray/xray_1.8.4/xray.service || Error "xray.service download failed."
|
||||
chmod +rwx /lib/systemd/system/xray.service
|
||||
sed -i "s~\[xray_install_directory\]~$xray_install_directory~g" /lib/systemd/system/xray.service
|
||||
systemctl daemon-reload
|
||||
fi
|
||||
#make json config
|
||||
realityKey=`./xray x25519`
|
||||
realityPvk=`echo "$realityKey"|grep 'Private key: '`
|
||||
realityPvk=${realityPvk#*: }
|
||||
realityPbk=`echo "$realityKey"|grep 'Public key: '`
|
||||
realityPbk=${realityPbk#*: }
|
||||
sid=${uuid##*-}
|
||||
realitySni='www.apple.com'
|
||||
realityServerNames='"www.apple.com", "images.apple.com"'
|
||||
local realityConfig=',
|
||||
"security": "reality",
|
||||
"realitySettings": {
|
||||
"show": false,
|
||||
"dest": "'$realitySni':443",
|
||||
"xver": 0,
|
||||
"serverNames": [
|
||||
'$realityServerNames'
|
||||
],
|
||||
"privateKey": "'$realityPvk'",
|
||||
"shortIds": [
|
||||
"'${sid}'"
|
||||
]
|
||||
}'
|
||||
local tlsConfig=',
|
||||
"security": "tls",
|
||||
"tlsSettings": {
|
||||
"certificates": ['"`./xray tls cert`"']
|
||||
}'
|
||||
for opt in $xray_inbounds_options; do
|
||||
[ -n "$in_networks" ] && in_networks="$in_networks, "
|
||||
case $opt in
|
||||
1) in_networks="$in_networks"`makeTcpHttpInbound "$vmess_tcp_http_port" "" 'vmess' ''`;;
|
||||
2) in_networks="$in_networks"`makeTcpInbound "$vmess_tcp_tls_port" "$tlsConfig" 'vmess' ''`;;
|
||||
3) in_networks="$in_networks"`makeTcpInbound "$vless_tcp_reality_port" "$realityConfig" 'vless' 'xtls-rprx-vision'`;;
|
||||
4) in_networks="$in_networks"`makeWSInbound "$vmess_ws_port" "" "$vmess_ws_path" 'vmess' ''`;;
|
||||
5) in_networks="$in_networks"`makeWSInbound "$vmess_ws_tls_port" "$tlsConfig" "$vmess_ws_tls_path" 'vmess' ''`;;
|
||||
6) in_networks="$in_networks"`makeWSInbound "$vless_ws_tls_port" "$tlsConfig" "$vless_ws_tls_path" 'vless' ''`;;
|
||||
7) in_networks="$in_networks"`makeMkcpInbound "$vmess_mkcp_port" "" "utp" 'vmess' ''`;;
|
||||
8) in_networks="$in_networks"`makeMkcpInbound "$vmess_mkcp_tls_port" "$tlsConfig" "none" 'vmess' ''`;;
|
||||
9) in_networks="$in_networks"`makeMkcpInbound "$vless_mkcp_tls_port" "$tlsConfig" "none" 'vless' ''`;;
|
||||
10) in_networks="$in_networks"`makeTrojanInbound "$trojan_tls_port" "$tlsConfig" ''`;;
|
||||
esac
|
||||
done
|
||||
echo $echo_E_arg '
|
||||
{
|
||||
"log" : {
|
||||
"loglevel": "none"
|
||||
},
|
||||
"inbounds": ['"$in_networks"'],
|
||||
"outbounds": [{
|
||||
"protocol": "freedom"
|
||||
}]
|
||||
}
|
||||
' >xray.json
|
||||
}
|
||||
|
||||
#install initialization
|
||||
InstallInit() {
|
||||
echo -n "make a update?[n]: "
|
||||
read update
|
||||
PM=`which apt-get || which yum`
|
||||
echo "$update"|grep -qi 'y' && $PM -y update
|
||||
$PM -y install curl wget #unzip
|
||||
type curl && download_tool_cmd='curl -L --connect-timeout 7 -ko' || download_tool_cmd='wget -T 60 --no-check-certificate -O'
|
||||
getip_urls="http://myip.quicknet.cyou http://myip.dnsomatic.com/ http://ip.sb/"
|
||||
for url in $getip_urls; do
|
||||
ip=`$download_tool_cmd - "$url" | grep -E '([0-9]{1,3}\.){3}[0-9]{1,3}|:'`
|
||||
[ -n "$ip" ] && break
|
||||
done
|
||||
}
|
||||
|
||||
outputLink() {
|
||||
[ -z "$ip" ] && return
|
||||
for opt in $xray_inbounds_options; do
|
||||
case $opt in
|
||||
1)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": '$vmess_tcp_http_port', "aid": "0", "host": "obfs.domain", "id": "'$uuid'", "net": "tcp", "path": "/", "ps": "vmess_tcp_http_'$ip:$vmess_tcp_http_port'", "tls": "", "type": "http", "v": "2"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess tcp http:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
2)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": '$vmess_tcp_tls_port', "aid": "0", "host": "", "id": "'$uuid'", "net": "tcp", "path": "", "ps": "vmess_tcp_tls_'$ip:$vmess_tcp_tls_port'", "tls": "tls", "type": "none", "v": "2", "fp": "chrome"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess tcp tls:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
3)
|
||||
echo $echo_e_arg "\033[45;37m\rvless tcp reality:\033[0m\n\t\033[4;35mvless://${uuid}@${ip}:${vless_tcp_reality_port}?security=reality&sni=${realitySni}&encryption=none&headerType=none&type=tcp&fp=chrome&flow=xtls-rprx-vision&sid=${sid}&pbk=$realityPbk&spx=/iphone-14-pro#vless_tcp_reality${ip}:${vless_tcp_reality_port}\033[0m"
|
||||
;;
|
||||
4)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_ws_port'", "aid": "0", "host": "obfs.domain", "id": "'$uuid'", "net": "ws", "path": "'$vmess_ws_path'", "ps": "ws_'$ip:$vmess_ws_port'", "tls": "", "type": "none", "v": "2"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess ws:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
5)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_ws_tls_port'", "aid": "0", "host": "obfs.domain", "id": "'$uuid'", "net": "ws", "path": "'$vmess_ws_tls_path'", "ps": "ws_tls_'$ip:$vmess_ws_tls_port'", "tls": "tls", "type": "none", "v": "2", "fp": "chrome"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess ws tls:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
6)
|
||||
echo $echo_e_arg "\033[45;37m\r vless ws tls:\033[0m\n\t\033[4;35mvless://${uuid}@${ip}:${vless_ws_tls_port}?security=tls&sni=obfs.domain&encryption=none&type=ws&path=$vless_ws_tls_path&host=obfs.domain&fp=chrome`date +%s`#vless_ws_tls${ip}:${vless_ws_tls_port}\033[0m"
|
||||
;;
|
||||
7)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_mkcp_port'", "aid": "0", "host": "", "id": "'$uuid'", "net": "kcp", "path": "", "ps": "vmess_mkcp_'$ip:$vmess_mkcp_port'", "tls": "", "type": "utp", "v": "2"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess mkcp:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
8)
|
||||
link=`echo -n $echo_E_arg '{"add": "'$ip'", "port": "'$vmess_mkcp_tls_port'", "aid": "0", "host": "", "id": "'$uuid'", "net": "kcp", "path": "", "ps": "vmess_mkcp_tls_'$ip:$vmess_mkcp_port'", "tls": "tls", "type": "none", "v": "2", "fp": "chrome"}'|base64 -w 0`
|
||||
echo $echo_e_arg "\033[45;37m\rvmess mkcp tls:\033[0m\n\t\033[4;35mvmess://$link\033[0m"
|
||||
;;
|
||||
9)
|
||||
echo $echo_e_arg "\033[45;37m\r vless mkcp tls:\033[0m\n\t\033[4;35mvless://${uuid}@${ip}:${vless_mkcp_tls_port}?security=tls&sni=obfs.domain&encryption=none&type=kcp&headerType=none&fp=chrome`date +%s`#vless_ws_tls${ip}:${vless_mkcp_tls_port}\033[0m"
|
||||
;;
|
||||
10)
|
||||
echo $echo_e_arg "\033[45;37m\rtrojan tls:\033[0m\n\t\033[4;35mtrojan://${uuid}@${ip}:${trojan_tls_port}?security=tls&sni=obfs.domain#trojan_tls_${ip}:${trojan_tls_port}\033[0m"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
AddAutoStart() {
|
||||
if [ -n "$rcCommon" ]; then
|
||||
if /etc/init.d/xray enable; then
|
||||
echo 'Autostart enabled, if you need to close it, run: /etc/init.d/xray disable'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if type systemctl &>/dev/null && [ -z "$(systemctl --failed|grep -q 'Host is down')" ]; then
|
||||
if systemctl enable xray &>/dev/null; then
|
||||
echo 'Autostart enabled, if you need to close it, run: systemctl disable xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if type chkconfig &>/dev/null; then
|
||||
if chkconfig --add xray &>/dev/null && chkconfig xray on &>/dev/null; then
|
||||
echo 'Autostart enabled, if you need to close it, run: chkconfig xray off'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if [ -d '/etc/rc.d/rc5.d' -a -f '/etc/init.d/xray' ]; then
|
||||
if ln -s '/etc/init.d/xray' '/etc/rc.d/rc5.d/S99xray'; then
|
||||
echo 'Autostart enabled, if you need to close it, run: rm -f /etc/rc.d/rc5.d/S99xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if [ -d '/etc/rc5.d' -a -f '/etc/init.d/xray' ]; then
|
||||
if ln -s '/etc/init.d/xray' '/etc/rc5.d/S99xray'; then
|
||||
echo 'Autostart enabled, if you need to close it, run: rm -f /etc/rc5.d/S99xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
if [ -d '/etc/rc.d' -a -f '/etc/init.d/xray' ]; then
|
||||
if ln -s '/etc/init.d/xray' '/etc/rc.d/S99xray'; then
|
||||
echo 'Autostart enabled, if you need to close it, run: rm -f /etc/rc.d/S99xray'
|
||||
return
|
||||
fi
|
||||
fi
|
||||
echo 'Autostart disabled'
|
||||
}
|
||||
|
||||
Install() {
|
||||
Config
|
||||
Delete >/dev/null 2>&1
|
||||
InstallInit
|
||||
InstallFile
|
||||
"$xray_install_directory/xray.init" start|grep -q FAILED && Error "xray install failed."
|
||||
which systemctl && [ -z "$(systemctl --failed|grep -q 'Host is down')" ] && systemctl restart xray &>/dev/null
|
||||
echo $echo_e_arg \
|
||||
"\033[44;37mxray install success.\033[0;34m
|
||||
`
|
||||
for opt in $xray_inbounds_options; do
|
||||
case $opt in
|
||||
1)
|
||||
echo $echo_e_arg "\r vmess tcp http server:\033[34G port=${vmess_tcp_http_port}";;
|
||||
2)
|
||||
echo $echo_e_arg "\r vmess tcp tls server:\033[34G port=${vmess_tcp_tls_port}";;
|
||||
3)
|
||||
echo $echo_e_arg "\r vless tcp reality server:\033[34G port=${vless_tcp_reality_port}"
|
||||
echo $echo_e_arg "\r flow:\033[34G xtls-rprx-vision"
|
||||
echo $echo_e_arg "\r serverName:\033[34G ${realitySni}"
|
||||
echo $echo_e_arg "\r publicKey:\033[34G ${realityPbk}"
|
||||
echo $echo_e_arg "\r shortId:\033[34G ${sid}"
|
||||
;;
|
||||
4)
|
||||
echo $echo_e_arg "\r vmess ws server:\033[34G port=${vmess_ws_port} path=${vmess_ws_path}";;
|
||||
5)
|
||||
echo $echo_e_arg "\r vmess ws tls server:\033[34G port=${vmess_ws_tls_port} path=${vmess_ws_tls_path}";;
|
||||
6)
|
||||
echo $echo_e_arg "\r vless ws tls server:\033[34G port=${vless_ws_tls_port} path=${vless_ws_tls_path}";;
|
||||
7)
|
||||
echo $echo_e_arg "\r vmess mkcp server:\033[34G port=${vmess_mkcp_port} type=utp";;
|
||||
8)
|
||||
echo $echo_e_arg "\r vmess mkcp tls server:\033[34G port=${vmess_mkcp_tls_port} type=none";;
|
||||
9)
|
||||
echo $echo_e_arg "\r vless mkcp tls server:\033[34G port=${vless_mkcp_tls_port} type=none";;
|
||||
10)
|
||||
echo $echo_e_arg "\r trojan tls server:\033[34G port=${trojan_tls_port}";;
|
||||
esac
|
||||
done
|
||||
`
|
||||
\r uuid:\033[35G$uuid
|
||||
\r alterId:\033[35G0
|
||||
\r`[ -f /etc/init.d/xray ] && /etc/init.d/xray usage || \"$xray_install_directory/xray.init\" usage`
|
||||
\r`AddAutoStart`
|
||||
`outputLink`\033[0m"
|
||||
}
|
||||
|
||||
Uninstall() {
|
||||
if [ -z "$xray_install_directory" ]; then
|
||||
echo -n "Please input xray install directory(default is /usr/local/xray): "
|
||||
read xray_install_directory
|
||||
fi
|
||||
Delete &>/dev/null && \
|
||||
echo $echo_e_arg "\n\033[44;37mxray uninstall success.\033[0m" || \
|
||||
echo $echo_e_arg "\n\033[41;37mxray uninstall failed.\033[0m"
|
||||
}
|
||||
|
||||
#script initialization
|
||||
ScriptInit() {
|
||||
emulate bash 2>/dev/null #zsh emulation mode
|
||||
if echo -e ''|grep -q 'e'; then
|
||||
echo_e_arg=''
|
||||
echo_E_arg=''
|
||||
else
|
||||
echo_e_arg='-e'
|
||||
echo_E_arg='-E'
|
||||
fi
|
||||
}
|
||||
|
||||
ScriptInit
|
||||
echo $*|grep -qi uninstall && Uninstall || Install
|
Loading…
Reference in New Issue
Block a user