mirror of
				https://github.com/bestnite/sub2clash.git
				synced 2025-10-26 09:11:01 +00:00 
			
		
		
		
	🐛 #46
This commit is contained in:
		| @@ -13,7 +13,24 @@ func ParseShadowsocks(proxy string) (model.Proxy, error) { | ||||
| 	if !strings.HasPrefix(proxy, constant.ShadowsocksPrefix) { | ||||
| 		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) | ||||
| 	if err != nil { | ||||
| 		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()) | ||||
| 		if err != nil { | ||||
| 			return model.Proxy{}, &ParseError{ | ||||
| @@ -56,7 +76,6 @@ func ParseShadowsocks(proxy string) (model.Proxy, error) { | ||||
| 				Raw:     proxy, | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if user == "" { | ||||
| 			return model.Proxy{}, &ParseError{ | ||||
| 				Type:    ErrInvalidStruct, | ||||
| @@ -72,8 +91,12 @@ func ParseShadowsocks(proxy string) (model.Proxy, error) { | ||||
| 				Raw:     proxy, | ||||
| 			} | ||||
| 		} | ||||
| 	method := methodAndPass[0] | ||||
| 	password := methodAndPass[1] | ||||
| 		method = methodAndPass[0] | ||||
| 		password = methodAndPass[1] | ||||
| 	} else { | ||||
| 		method = link.User.Username() | ||||
| 		password, _ = link.User.Password() | ||||
| 	} | ||||
|  | ||||
| 	remarks := link.Fragment | ||||
| 	if remarks == "" { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user