1
0
mirror of https://github.com/nitezs/sub2clash.git synced 2024-12-23 21:44:41 -05:00
This commit is contained in:
Nite07 2024-10-09 11:08:24 +08:00
parent 98ef93c7bb
commit 6bb2d16e4b

View File

@ -13,7 +13,24 @@ func ParseShadowsocks(proxy string) (model.Proxy, error) {
if !strings.HasPrefix(proxy, constant.ShadowsocksPrefix) { if !strings.HasPrefix(proxy, constant.ShadowsocksPrefix) {
return model.Proxy{}, &ParseError{Type: ErrInvalidPrefix, Raw: proxy} return model.Proxy{}, &ParseError{Type: ErrInvalidPrefix, Raw: proxy}
} }
needDecode := true
if !strings.Contains(proxy, "@") {
s := strings.SplitN(proxy, "#", 2)
d, err := DecodeBase64(strings.TrimPrefix(s[0], "ss://"))
if err != nil {
return model.Proxy{}, &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.Proxy{}, &ParseError{ return model.Proxy{}, &ParseError{
@ -48,6 +65,9 @@ func ParseShadowsocks(proxy string) (model.Proxy, error) {
} }
} }
method := ""
password := ""
if needDecode {
user, err := DecodeBase64(link.User.Username()) user, err := DecodeBase64(link.User.Username())
if err != nil { if err != nil {
return model.Proxy{}, &ParseError{ return model.Proxy{}, &ParseError{
@ -56,7 +76,6 @@ func ParseShadowsocks(proxy string) (model.Proxy, error) {
Raw: proxy, Raw: proxy,
} }
} }
if user == "" { if user == "" {
return model.Proxy{}, &ParseError{ return model.Proxy{}, &ParseError{
Type: ErrInvalidStruct, Type: ErrInvalidStruct,
@ -72,8 +91,12 @@ func ParseShadowsocks(proxy string) (model.Proxy, 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()
}
remarks := link.Fragment remarks := link.Fragment
if remarks == "" { if remarks == "" {