update: vless,vmess parser

This commit is contained in:
2024-03-21 00:59:47 +08:00
committed by Nite07
parent 1a7944f7a1
commit f545848ce1
2 changed files with 22 additions and 35 deletions

View File

@@ -69,34 +69,24 @@ func ParseVless(proxy string) (model.Outbound, error) {
} }
result.VLESSOptions.OutboundTLSOptionsContainer = model.OutboundTLSOptionsContainer{ result.VLESSOptions.OutboundTLSOptionsContainer = model.OutboundTLSOptionsContainer{
TLS: &model.OutboundTLSOptions{ TLS: &model.OutboundTLSOptions{
Enabled: true, Enabled: true,
ALPN: alpn, ALPN: alpn,
Insecure: params.Get("allowInsecure") == "1", ServerName: params.Get("sni"),
Insecure: params.Get("allowInsecure") == "1",
}, },
} }
if params.Get("fp") != "" {
result.VLESSOptions.OutboundTLSOptionsContainer.TLS.UTLS = &model.OutboundUTLSOptions{
Enabled: true,
Fingerprint: params.Get("fp"),
}
}
} }
if params.Get("security") == "reality" { if params.Get("security") == "reality" {
var alpn []string result.VLESSOptions.OutboundTLSOptionsContainer.TLS.Reality = &model.OutboundRealityOptions{
if strings.Contains(params.Get("alpn"), ",") { Enabled: true,
alpn = strings.Split(params.Get("alpn"), ",") PublicKey: params.Get("pbk"),
} else { ShortID: params.Get("sid"),
alpn = nil
}
result.VLESSOptions.OutboundTLSOptionsContainer = model.OutboundTLSOptionsContainer{
TLS: &model.OutboundTLSOptions{
Enabled: true,
ServerName: params.Get("sni"),
UTLS: &model.OutboundUTLSOptions{
Enabled: params.Get("fp") != "",
Fingerprint: params.Get("fp"),
},
Reality: &model.OutboundRealityOptions{
Enabled: true,
PublicKey: params.Get("pbk"),
ShortID: params.Get("sid"),
},
ALPN: alpn,
},
} }
} }
if params.Get("type") == "ws" { if params.Get("type") == "ws" {
@@ -115,11 +105,6 @@ func ParseVless(proxy string) (model.Outbound, error) {
Type: "quic", Type: "quic",
QUICOptions: model.V2RayQUICOptions{}, QUICOptions: model.V2RayQUICOptions{},
} }
result.VLESSOptions.OutboundTLSOptionsContainer = model.OutboundTLSOptionsContainer{
TLS: &model.OutboundTLSOptions{
Enabled: true,
},
}
} }
if params.Get("type") == "grpc" { if params.Get("type") == "grpc" {
result.VLESSOptions.Transport = &model.V2RayTransportOptions{ result.VLESSOptions.Transport = &model.V2RayTransportOptions{

View File

@@ -79,9 +79,16 @@ func ParseVmess(proxy string) (model.Outbound, error) {
UTLS: &model.OutboundUTLSOptions{ UTLS: &model.OutboundUTLSOptions{
Fingerprint: vmess.Fp, Fingerprint: vmess.Fp,
}, },
ALPN: alpn, ALPN: alpn,
ServerName: vmess.Sni,
}, },
} }
if vmess.Fp != "" {
result.VMessOptions.OutboundTLSOptionsContainer.TLS.UTLS = &model.OutboundUTLSOptions{
Enabled: true,
Fingerprint: vmess.Fp,
}
}
} }
if vmess.Net == "ws" { if vmess.Net == "ws" {
@@ -108,11 +115,6 @@ func ParseVmess(proxy string) (model.Outbound, error) {
Type: "quic", Type: "quic",
QUICOptions: quic, QUICOptions: quic,
} }
result.VMessOptions.OutboundTLSOptionsContainer = model.OutboundTLSOptionsContainer{
TLS: &model.OutboundTLSOptions{
Enabled: true,
},
}
} }
if vmess.Net == "grpc" { if vmess.Net == "grpc" {