From 4dda65a636574df51e3728bd9a85b2b91b741a38 Mon Sep 17 00:00:00 2001 From: wyx2685 Date: Mon, 24 Jun 2024 18:55:04 +0900 Subject: [PATCH] =?UTF-8?q?Fix:=E4=BF=AE=E5=A4=8DXray=E5=86=85=E6=A0=B8VMe?= =?UTF-8?q?ss/VLess=E7=9A=84Websocket=E4=BC=A0=E8=BE=93=E6=96=B9=E5=BC=8F?= =?UTF-8?q?=E5=8F=82=E6=95=B0=E8=AE=BE=E7=BD=AE=E9=94=99=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- core/xray/inbound.go | 46 ++++++++++++++++++++++++++++++++++++++------ 1 file changed, 40 insertions(+), 6 deletions(-) diff --git a/core/xray/inbound.go b/core/xray/inbound.go index 93aab0f..8408775 100644 --- a/core/xray/inbound.go +++ b/core/xray/inbound.go @@ -26,8 +26,12 @@ func buildInbound(option *conf.Options, nodeInfo *panel.NodeInfo, tag string) (* err = buildV2ray(option, nodeInfo, in) network = nodeInfo.VAllss.Network case "trojan": - err = buildTrojan(option, in) - network = "tcp" + err = buildTrojan(option, nodeInfo, in) + if nodeInfo.Trojan.Network != "" { + network = nodeInfo.Trojan.Network + } else { + network = "tcp" + } case "shadowsocks": err = buildShadowsocks(option, nodeInfo, in) network = "tcp" @@ -69,8 +73,13 @@ func buildInbound(option *conf.Options, nodeInfo *panel.NodeInfo, tag string) (* in.StreamSetting.TCPSettings = tcpSetting } case "ws": - in.StreamSetting.WSSettings = &coreConf.WebSocketConfig{ - AcceptProxyProtocol: option.XrayOptions.EnableProxyProtocol} //Enable proxy protocol + if in.StreamSetting.WSSettings != nil { + in.StreamSetting.WSSettings.AcceptProxyProtocol = option.XrayOptions.EnableProxyProtocol + } else { + in.StreamSetting.WSSettings = &coreConf.WebSocketConfig{ + AcceptProxyProtocol: option.XrayOptions.EnableProxyProtocol, + } //Enable proxy protocol + } default: socketConfig := &coreConf.SocketConfig{ AcceptProxyProtocol: option.XrayOptions.EnableProxyProtocol, @@ -131,6 +140,7 @@ func buildInbound(option *conf.Options, nodeInfo *panel.NodeInfo, tag string) (* MaxTimeDiff: uint64(mtd.Microseconds()), ShortIds: []string{v.TlsSettings.ShortId}, } + default: break } in.Tag = tag @@ -204,8 +214,9 @@ func buildV2ray(config *conf.Options, nodeInfo *panel.NodeInfo, inbound *coreCon return nil } -func buildTrojan(config *conf.Options, inbound *coreConf.InboundDetourConfig) error { +func buildTrojan(config *conf.Options, nodeInfo *panel.NodeInfo, inbound *coreConf.InboundDetourConfig) error { inbound.Protocol = "trojan" + v := nodeInfo.Trojan if config.XrayOptions.EnableFallback { // Set fallback fallbackConfigs, err := buildTrojanFallbacks(config.XrayOptions.FallBackConfigs) @@ -223,8 +234,31 @@ func buildTrojan(config *conf.Options, inbound *coreConf.InboundDetourConfig) er s := []byte("{}") inbound.Settings = (*json.RawMessage)(&s) } - t := coreConf.TransportProtocol("tcp") + network := v.Network + if network == "" { + network = "tcp" + } + t := coreConf.TransportProtocol(network) inbound.StreamSetting = &coreConf.StreamConfig{Network: &t} + switch network { + case "tcp": + err := json.Unmarshal(v.NetworkSettings, &inbound.StreamSetting.TCPSettings) + if err != nil { + return fmt.Errorf("unmarshal tcp settings error: %s", err) + } + case "ws": + err := json.Unmarshal(v.NetworkSettings, &inbound.StreamSetting.WSSettings) + if err != nil { + return fmt.Errorf("unmarshal ws settings error: %s", err) + } + case "grpc": + err := json.Unmarshal(v.NetworkSettings, &inbound.StreamSetting.GRPCConfig) + if err != nil { + return fmt.Errorf("unmarshal grpc settings error: %s", err) + } + default: + return errors.New("the network type is not vail") + } return nil }