mirror of
https://github.com/samuelhbne/server-xray.git
synced 2025-12-17 04:14:40 +03:00
Port number issue fix, streamSettings position fix
This commit is contained in:
@@ -58,7 +58,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -75,14 +75,14 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg serviceName "${serviceName}" '.settings.streamSettings += {"network":"grpc","grpcSettings":{"serviceName":$serviceName}}'`
|
inbound=`echo $inbound| jq -c --arg serviceName "${serviceName}" '.streamSettings += {"network":"grpc","grpcSettings":{"serviceName":$serviceName}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"none"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"none"}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -84,7 +84,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -101,28 +101,28 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg serviceName "${serviceName}" '.settings.streamSettings += {"network":"grpc","grpcSettings":{"serviceName":$serviceName}}'`
|
inbound=`echo $inbound| jq -c --arg serviceName "${serviceName}" '.streamSettings += {"network":"grpc","grpcSettings":{"serviceName":$serviceName}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"reality"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"reality"}'`
|
||||||
|
|
||||||
# Reality settings
|
# Reality settings
|
||||||
inbound=`echo $inbound| jq -c --arg dest "${dest}" --arg pubkey "${pubkey}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg dest "${dest}" --arg pubkey "${pubkey}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.realitySettings += {"show":true,"dest":"\($dest):443","serverNames":[$dest],"privateKey":$prvkey,"publicKey":$pubkey}'`
|
'.streamSettings.realitySettings += {"show":true,"dest":"\($dest):443","serverNames":[$dest],"privateKey":$prvkey,"publicKey":$pubkey}'`
|
||||||
|
|
||||||
# serverNames settings
|
# serverNames settings
|
||||||
if [ -n "${serverNames}" ]; then
|
if [ -n "${serverNames}" ]; then
|
||||||
JserverNames=`printf '%s\n' "${serverNames[@]}"|jq -R|jq -sc`
|
JserverNames=`printf '%s\n' "${serverNames[@]}"|jq -R|jq -sc`
|
||||||
inbound=`echo $inbound| jq -c --argjson JserverNames "${JserverNames}" '.settings.streamSettings.realitySettings.serverNames += $JserverNames'`
|
inbound=`echo $inbound| jq -c --argjson JserverNames "${JserverNames}" '.streamSettings.realitySettings.serverNames += $JserverNames'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# shortIds settings
|
# shortIds settings
|
||||||
JshortIds=`printf '%s\n' "${shortIds[@]}"|jq -R|jq -sc`
|
JshortIds=`printf '%s\n' "${shortIds[@]}"|jq -R|jq -sc`
|
||||||
inbound=`echo $inbound| jq -c --argjson JshortIds "${JshortIds}" '.settings.streamSettings.realitySettings.shortIds += $JshortIds'`
|
inbound=`echo $inbound| jq -c --argjson JshortIds "${JshortIds}" '.streamSettings.realitySettings.shortIds += $JshortIds'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -94,16 +94,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg serviceName "${serviceName}" '.settings.streamSettings += {"network":"grpc","grpcSettings":{"serviceName":$serviceName}}'`
|
inbound=`echo $inbound| jq -c --arg serviceName "${serviceName}" '.streamSettings += {"network":"grpc","grpcSettings":{"serviceName":$serviceName}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -75,14 +75,14 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg webpath "${webpath}" '.settings.streamSettings += {"network":"splithttp","splithttpSettings":{"path":$webpath}}'`
|
inbound=`echo $inbound| jq -c --arg webpath "${webpath}" '.streamSettings += {"network":"splithttp","splithttpSettings":{"path":$webpath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"none"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"none"}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -94,16 +94,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg webpath "${webpath}" '.settings.streamSettings += {"network":"splithttp","splithttpSettings":{"path":$webpath}}'`
|
inbound=`echo $inbound| jq -c --arg webpath "${webpath}" '.streamSettings += {"network":"splithttp","splithttpSettings":{"path":$webpath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -93,28 +93,28 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"network":"tcp"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"network":"tcp"}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"reality"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"reality"}'`
|
||||||
|
|
||||||
# Reality settings
|
# Reality settings
|
||||||
inbound=`echo $inbound| jq -c --arg dest "${dest}" --arg pubkey "${pubkey}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg dest "${dest}" --arg pubkey "${pubkey}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.realitySettings += {"show":true,"dest":"\($dest):443","serverNames":[$dest],"privateKey":$prvkey,"publicKey":$pubkey}'`
|
'.streamSettings.realitySettings += {"show":true,"dest":"\($dest):443","serverNames":[$dest],"privateKey":$prvkey,"publicKey":$pubkey}'`
|
||||||
|
|
||||||
# serverNames settings
|
# serverNames settings
|
||||||
if [ -n "${serverNames}" ]; then
|
if [ -n "${serverNames}" ]; then
|
||||||
JserverNames=`printf '%s\n' "${serverNames[@]}"|jq -R|jq -sc`
|
JserverNames=`printf '%s\n' "${serverNames[@]}"|jq -R|jq -sc`
|
||||||
inbound=`echo $inbound| jq -c --argjson JserverNames "${JserverNames}" '.settings.streamSettings.realitySettings.serverNames += $JserverNames'`
|
inbound=`echo $inbound| jq -c --argjson JserverNames "${JserverNames}" '.streamSettings.realitySettings.serverNames += $JserverNames'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# shortIds settings
|
# shortIds settings
|
||||||
JshortIds=`printf '%s\n' "${shortIds[@]}"|jq -R|jq -sc`
|
JshortIds=`printf '%s\n' "${shortIds[@]}"|jq -R|jq -sc`
|
||||||
inbound=`echo $inbound| jq -c --argjson JshortIds "${JshortIds}" '.settings.streamSettings.realitySettings.shortIds += $JshortIds'`
|
inbound=`echo $inbound| jq -c --argjson JshortIds "${JshortIds}" '.streamSettings.realitySettings.shortIds += $JshortIds'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -86,16 +86,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"network":"tcp"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"network":"tcp"}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -75,14 +75,14 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.settings.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"none"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"none"}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vless","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vless","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -94,16 +94,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.settings.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vmess","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vmess","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -86,16 +86,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"network":"tcp"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"network":"tcp"}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo "Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo "Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vmess","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vmess","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -75,14 +75,14 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.settings.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"none"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"none"}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"vmess","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"vmess","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -94,16 +94,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.settings.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo -e "Error: Port number must be numeric.\n"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"trojan","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"trojan","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -86,16 +86,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"network":"tcp"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"network":"tcp"}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ fi
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo "Port number must be numeric"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo "Port number must be numeric"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"trojan","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"trojan","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -75,14 +75,14 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.settings.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"none"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"none"}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ if [ ! -f "${prvkey}" ]; then >&2 echo "Warning, Private key not found: ${prvkey
|
|||||||
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo "Port number must be numeric"; exit 1; fi
|
if ! [ "${port}" -eq "${port}" ] 2>/dev/null; then >&2 echo "Port number must be numeric"; exit 1; fi
|
||||||
|
|
||||||
# inbound frame
|
# inbound frame
|
||||||
inbound=`jq -nc --arg port "${port}" '{"port":$port,"protocol":"trojan","settings":{"decryption":"none"}}'`
|
inbound=`jq -nc --arg port "${port}" '{"port":($port|tonumber),"protocol":"trojan","settings":{"decryption":"none"}}'`
|
||||||
|
|
||||||
# User settings
|
# User settings
|
||||||
for user in "${xuser[@]}"
|
for user in "${xuser[@]}"
|
||||||
@@ -94,16 +94,16 @@ done
|
|||||||
|
|
||||||
# StreamSettings
|
# StreamSettings
|
||||||
if [ -n "${acceptProxyProtocol}" ]; then
|
if [ -n "${acceptProxyProtocol}" ]; then
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
inbound=`echo $inbound| jq -c '.streamSettings.sockopt += {"acceptProxyProtocol":true}'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network settings
|
# Network settings
|
||||||
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.settings.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
inbound=`echo $inbound| jq -c --arg wspath "${wspath}" '.streamSettings += {"network":"ws","wsSettings":{"path":$wspath}}'`
|
||||||
|
|
||||||
# Security settings
|
# Security settings
|
||||||
inbound=`echo $inbound| jq -c '.settings.streamSettings += {"security":"tls"}'`
|
inbound=`echo $inbound| jq -c '.streamSettings += {"security":"tls"}'`
|
||||||
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
inbound=`echo $inbound| jq -c --arg fullchain "${fullchain}" --arg prvkey "${prvkey}" \
|
||||||
'.settings.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
'.streamSettings.tlsSettings += {"certificates":[{"certificateFile":$fullchain,"keyFile":$prvkey}]}'`
|
||||||
|
|
||||||
# Fallback settings
|
# Fallback settings
|
||||||
for fb in "${fallback[@]}"
|
for fb in "${fallback[@]}"
|
||||||
|
|||||||
Reference in New Issue
Block a user