mirror of
https://github.com/samuelhbne/server-xray.git
synced 2025-12-16 20:07:06 +03:00
161 lines
4.7 KiB
Bash
Executable File
161 lines
4.7 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
usage() {
|
|
echo "Usage: server-mtt <xconf=xray-config-file>,<certpath=cert-path-root>,<port=443>,<domain=mydomain.com>,<user=xxx-xxx[:0[:a@mail.com]]>[,fallback=www.baidu.com:443:/html][,fallback=:2443:/websocket2]"
|
|
}
|
|
|
|
options=(`echo $1 |tr ',' ' '`)
|
|
for option in "${options[@]}"
|
|
do
|
|
kv=(`echo $option |tr '=' ' '`)
|
|
case "${kv[0]}" in
|
|
x|xconf)
|
|
xconf="${kv[1]}"
|
|
;;
|
|
c|certpath)
|
|
certpath+=("${kv[1]}")
|
|
;;
|
|
p|port)
|
|
port="${kv[1]}"
|
|
;;
|
|
d|domain)
|
|
domain="${kv[1]}"
|
|
;;
|
|
u|user)
|
|
xuser+=("${kv[1]}")
|
|
;;
|
|
f|fallback)
|
|
fallback+=("${kv[1]}")
|
|
;;
|
|
esac
|
|
done
|
|
|
|
if [ -z "${certpath}" ]; then
|
|
echo "Error: certpath undefined."
|
|
usage
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${xconf}" ]; then
|
|
echo "Error: xconf undefined."
|
|
usage
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${port}" ]; then
|
|
echo "Error: port undefined."
|
|
usage
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${domain}" ]; then
|
|
echo "Error: domain undefined."
|
|
usage
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${xuser}" ]; then
|
|
echo "Error: user undefined."
|
|
usage
|
|
exit 1
|
|
fi
|
|
|
|
XCONF=$xconf
|
|
cat $XCONF |jq --arg port "${port}" '.inbounds +=[{"port":($port|tonumber), "protocol":"vmess", "settings":{"clients":[]}}]' |sponge $XCONF
|
|
|
|
for xu in "${xuser[@]}"
|
|
do
|
|
IFS=':'
|
|
uopt=(${xu})
|
|
uopt=(${uopt[@]})
|
|
|
|
if [ -z "${uopt[0]}" ]; then
|
|
echo "Incorrect user format: ${xu}"
|
|
echo "Correct user format: user=<uuid>[:level:email]"
|
|
echo "Like: user=805b2209-c26f-48d6-ba52-07b7d894f962:0:me@g.cn"
|
|
echo "Like: user=805b2209-c26f-48d6-ba52-07b7d894f962::me@g.cn"
|
|
echo "user=805b2209-c26f-48d6-ba52-07b7d894f962:0"
|
|
echo "user=805b2209-c26f-48d6-ba52-07b7d894f962"
|
|
exit 1
|
|
fi
|
|
if [ -z "${uopt[1]}" ]; then
|
|
uopt[1]=0
|
|
fi
|
|
if [ -z "${uopt[2]}" ]; then
|
|
uopt[2]="nobody@g.cn"
|
|
fi
|
|
cat $XCONF |jq --arg port "${port}" --arg uid "${uopt[0]}" --arg level "${uopt[1]}" --arg email "${uopt[2]}" \
|
|
'( .inbounds[] | select(.port == ($port|tonumber)) | .settings.clients ) += [ {"id":$uid, "level":($level|tonumber), "email":$email} ] ' \
|
|
|sponge $XCONF
|
|
done
|
|
|
|
cat $XCONF |jq --arg port "${port}" \
|
|
'( .inbounds[] | select(.port == ($port|tonumber)) | .settings.decryption ) += "none" ' \
|
|
|sponge $XCONF
|
|
|
|
for fb in "${fallback[@]}"
|
|
do
|
|
IFS=':'
|
|
fopt=(${fb})
|
|
fopt=(${fopt[@]})
|
|
|
|
fhost="${fopt[0]}"
|
|
fport="${fopt[1]}"
|
|
fpath="${fopt[2]}"
|
|
|
|
if [ -z "${fport}" ]; then
|
|
echo "Incorrect fallback format: ${fb}"
|
|
echo "Correct fallback: fallback=[host]<:port>[:path]"
|
|
echo "Like: fallback=baidu.com:443:/websocket"
|
|
echo "Like: fallback=:1443:/websocket"
|
|
echo "Like: fallback=:1443"
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${fhost}" ]; then
|
|
if [ -z "${fpath}" ]; then
|
|
Jfallback=`echo '{}' |jq --arg fport "${fport}" --arg fpath "${fpath}" '. += {"dest":($fport|tonumber), "xver":1}'`
|
|
else
|
|
Jfallback=`echo '{}' |jq --arg fport "${fport}" --arg fpath "${fpath}" '. += {"dest":($fport|tonumber), "path":$fpath, "xver":1}'`
|
|
fi
|
|
else
|
|
if [ -z "${fpath}" ]; then
|
|
fdest="${fhost}:${fport}"
|
|
Jfallback=`echo '{}' |jq --arg fdest "${fdest}" --arg fpath "${fpath}" '. += {"dest":$fdest, "xver":1}'`
|
|
else
|
|
Jfallback=`echo '{}' |jq --arg fdest "${fdest}" --arg fpath "${fpath}" '. += {"dest":$fdest, "path":$fpath, "xver":1}'`
|
|
fi
|
|
fi
|
|
|
|
cat $XCONF |jq --arg port "${port}" --argjson jfallback "$Jfallback" \
|
|
'( .inbounds[] | select(.port == ($port|tonumber)) | .settings.fallbacks ) += [ $jfallback ] ' \
|
|
|sponge $XCONF
|
|
done
|
|
|
|
cat $XCONF |jq --arg port "${port}" \
|
|
'( .inbounds[] | select(.port == ($port|tonumber)) | .streamSettings ) += {"network":"tcp", "security":"tls" } ' \
|
|
|sponge $XCONF
|
|
|
|
cat $XCONF |jq --arg port "${port}" \
|
|
'( .inbounds[] | select(.port == ($port|tonumber)) | .streamSettings ) += {"tlsSettings":{"alpn":["http/1.1"]} } ' \
|
|
|sponge $XCONF
|
|
|
|
for certroot in "${certpath[@]}"
|
|
do
|
|
if [ -f "${certroot}/${domain}/fullchain.cer" ] && [ -f "${certroot}/${domain}/${domain}.key" ]; then
|
|
fullchain="${certroot}/${domain}/fullchain.cer"
|
|
prvkey="${certroot}/${domain}/${domain}.key"
|
|
break
|
|
fi
|
|
done
|
|
|
|
if [ ! -f "${fullchain}" ] || [ ! -f "${prvkey}" ]; then
|
|
echo "TLS cert missing?"
|
|
echo "Abort."
|
|
exit 2
|
|
fi
|
|
|
|
cat $XCONF |jq --arg port "${port}" --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
|
'( .inbounds[] | select(.port == ($port|tonumber)) | .streamSettings.tlsSettings ) += {"certificates":[{"certificateFile":$fullchain, "keyFile":$prvkey}]} ' \
|
|
|sponge $XCONF
|