1
0
mirror of https://github.com/nitezs/sub2sing-box.git synced 2024-12-23 21:44:41 -05:00

🐛 Fix cannot parse shadowsocks with base64 encoded

This commit is contained in:
Nite07 2024-10-09 11:37:28 +08:00
parent 5a7bce6fda
commit 15a6f586a5

View File

@ -15,7 +15,24 @@ func ParseShadowsocks(proxy string) (model.Outbound, error) {
if !strings.HasPrefix(proxy, constant.ShadowsocksPrefix) { if !strings.HasPrefix(proxy, constant.ShadowsocksPrefix) {
return model.Outbound{}, &ParseError{Type: ErrInvalidPrefix, Raw: proxy} return model.Outbound{}, &ParseError{Type: ErrInvalidPrefix, Raw: proxy}
} }
needDecode := true
if !strings.Contains(proxy, "@") {
s := strings.SplitN(proxy, "#", 2)
d, err := util.DecodeBase64(strings.TrimPrefix(s[0], "ss://"))
if err != nil {
return model.Outbound{}, &ParseError{
Type: ErrInvalidStruct,
Message: "url parse error",
Raw: proxy,
}
}
if len(s) == 2 {
proxy = "ss://" + d + "#" + s[1]
} else {
proxy = "ss://" + d
}
needDecode = false
}
link, err := url.Parse(proxy) link, err := url.Parse(proxy)
if err != nil { if err != nil {
return model.Outbound{}, &ParseError{ return model.Outbound{}, &ParseError{
@ -50,6 +67,9 @@ func ParseShadowsocks(proxy string) (model.Outbound, error) {
} }
} }
method := ""
password := ""
if needDecode {
user, err := util.DecodeBase64(link.User.Username()) user, err := util.DecodeBase64(link.User.Username())
if err != nil { if err != nil {
return model.Outbound{}, &ParseError{ return model.Outbound{}, &ParseError{
@ -58,7 +78,6 @@ func ParseShadowsocks(proxy string) (model.Outbound, error) {
Raw: proxy, Raw: proxy,
} }
} }
if user == "" { if user == "" {
return model.Outbound{}, &ParseError{ return model.Outbound{}, &ParseError{
Type: ErrInvalidStruct, Type: ErrInvalidStruct,
@ -74,8 +93,12 @@ func ParseShadowsocks(proxy string) (model.Outbound, error) {
Raw: proxy, Raw: proxy,
} }
} }
method := methodAndPass[0] method = methodAndPass[0]
password := methodAndPass[1] password = methodAndPass[1]
} else {
method = link.User.Username()
password, _ = link.User.Password()
}
query := link.Query() query := link.Query()
pluginStr := query.Get("plugin") pluginStr := query.Get("plugin")