Merge pull request #208 from arugal/master

support multi account auth with socks5
This commit is contained in:
he liu 2019-09-20 13:00:59 +08:00 committed by GitHub
commit 02be614149
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 70 additions and 19 deletions

View File

@ -538,11 +538,13 @@ vkey=123
[socks5] [socks5]
mode=socks5 mode=socks5
server_port=9004 server_port=9004
multi_account=multi_account.conf
``` ```
项 | 含义 项 | 含义
---|--- ---|---
mode | socks5 mode | socks5
server_port | 在服务端的代理端口 server_port | 在服务端的代理端口
multi_account | socks5多账号配置文件可选
##### 私密代理模式 ##### 私密代理模式
```ini ```ini

View File

@ -488,6 +488,7 @@ loop:
tl.Password = t.Password tl.Password = t.Password
tl.LocalPath = t.LocalPath tl.LocalPath = t.LocalPath
tl.StripPre = t.StripPre tl.StripPre = t.StripPre
tl.MultiAccount = t.MultiAccount
if !client.HasTunnel(tl) { if !client.HasTunnel(tl) {
if err := file.GetDb().NewTask(tl); err != nil { if err := file.GetDb().NewTask(tl); err != nil {
logs.Notice("Add task error ", err.Error()) logs.Notice("Add task error ", err.Error())

2
conf/multi_account.conf Normal file
View File

@ -0,0 +1,2 @@
# key -> user | value -> pwd
npc=npc.pwd

View File

@ -40,6 +40,7 @@ server_port=10000
[socks5] [socks5]
mode=socks5 mode=socks5
server_port=19009 server_port=19009
multi_account=multi_account.conf
[file] [file]
mode=file mode=file

View File

@ -239,12 +239,37 @@ func dealTunnel(s string) *file.Tunnel {
t.LocalPath = item[1] t.LocalPath = item[1]
case "strip_pre": case "strip_pre":
t.StripPre = item[1] t.StripPre = item[1]
case "multi_account":
t.MultiAccount = &file.MultiAccount{}
if b, err := common.ReadAllFromFile(item[1]); err != nil {
panic(err)
} else {
if content, err := common.ParseStr(string(b)); err != nil {
panic(err)
} else {
t.MultiAccount.AccountMap = dealMultiUser(content)
}
}
} }
} }
return t return t
} }
func dealMultiUser(s string) map[string]string {
multiUserMap := make(map[string]string)
for _, v := range splitStr(s) {
item := strings.Split(v, "=")
if len(item) == 0 {
continue
} else if len(item) == 1 {
item = append(item, "")
}
multiUserMap[strings.TrimSpace(item[0])] = item[1]
}
return multiUserMap
}
func delLocalService(s string) *LocalServer { func delLocalService(s string) *LocalServer {
l := new(LocalServer) l := new(LocalServer)
for _, v := range splitStr(s) { for _, v := range splitStr(s) {

View File

@ -140,6 +140,7 @@ type Tunnel struct {
LocalPath string LocalPath string
StripPre string StripPre string
Target *Target Target *Target
MultiAccount *MultiAccount
Health Health
sync.RWMutex sync.RWMutex
} }
@ -184,6 +185,10 @@ type Target struct {
sync.RWMutex sync.RWMutex
} }
type MultiAccount struct {
AccountMap map[string]string // multi account and pwd
}
func (s *Target) GetRandomTarget() (string, error) { func (s *Target) GetRandomTarget() (string, error) {
if s.TargetArr == nil { if s.TargetArr == nil {
s.TargetArr = strings.Split(s.TargetStr, "\n") s.TargetArr = strings.Split(s.TargetStr, "\n")

View File

@ -199,7 +199,7 @@ func (s *Sock5ModeServer) handleConn(c net.Conn) {
c.Close() c.Close()
return return
} }
if s.task.Client.Cnf.U != "" && s.task.Client.Cnf.P != "" { if (s.task.Client.Cnf.U != "" && s.task.Client.Cnf.P != "") || (s.task.MultiAccount != nil && len(s.task.MultiAccount.AccountMap) > 0) {
buf[1] = UserPassAuth buf[1] = UserPassAuth
c.Write(buf) c.Write(buf)
if err := s.Auth(c); err != nil { if err := s.Auth(c); err != nil {
@ -236,7 +236,22 @@ func (s *Sock5ModeServer) Auth(c net.Conn) error {
if _, err := io.ReadAtLeast(c, pass, passLen); err != nil { if _, err := io.ReadAtLeast(c, pass, passLen); err != nil {
return err return err
} }
if string(user) == s.task.Client.Cnf.U && string(pass) == s.task.Client.Cnf.P {
var U, P string
if s.task.MultiAccount != nil {
// enable multi user auth
U = string(user)
var ok bool
P, ok = s.task.MultiAccount.AccountMap[U]
if !ok {
return errors.New("验证不通过")
}
} else {
U = s.task.Client.Cnf.U
P = s.task.Client.Cnf.P
}
if string(user) == U && string(pass) == P {
if _, err := c.Write([]byte{userAuthVersion, authSuccess}); err != nil { if _, err := c.Write([]byte{userAuthVersion, authSuccess}); err != nil {
return err return err
} }