mirror of
https://gitee.com/IrisVega/frp.git
synced 2024-11-01 22:31:29 +08:00
utils/conn: add func joinMore
This commit is contained in:
parent
b6212afb03
commit
45c21b2705
@ -11,4 +11,4 @@ log_level = debug
|
|||||||
[test1]
|
[test1]
|
||||||
passwd = 123
|
passwd = 123
|
||||||
local_ip = 127.0.0.1
|
local_ip = 127.0.0.1
|
||||||
local_port = 8000
|
local_port = 22
|
||||||
|
@ -82,8 +82,7 @@ func (p *ProxyClient) StartTunnel(serverAddr string, serverPort int64) (err erro
|
|||||||
log.Debug("Join two conns, (l[%s] r[%s]) (l[%s] r[%s])", localConn.GetLocalAddr(), localConn.GetRemoteAddr(),
|
log.Debug("Join two conns, (l[%s] r[%s]) (l[%s] r[%s])", localConn.GetLocalAddr(), localConn.GetRemoteAddr(),
|
||||||
remoteConn.GetLocalAddr(), remoteConn.GetRemoteAddr())
|
remoteConn.GetLocalAddr(), remoteConn.GetRemoteAddr())
|
||||||
// go conn.Join(localConn, remoteConn)
|
// go conn.Join(localConn, remoteConn)
|
||||||
go conn.PipeEncryptoWriter(localConn.TcpConn, remoteConn.TcpConn, p.Passwd)
|
go conn.JoinMore(localConn, remoteConn, p.Passwd)
|
||||||
go conn.PipeDecryptoReader(remoteConn.TcpConn, localConn.TcpConn, p.Passwd)
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -133,8 +133,7 @@ func (p *ProxyServer) Start() (err error) {
|
|||||||
log.Debug("Join two conns, (l[%s] r[%s]) (l[%s] r[%s])", cliConn.GetLocalAddr(), cliConn.GetRemoteAddr(),
|
log.Debug("Join two conns, (l[%s] r[%s]) (l[%s] r[%s])", cliConn.GetLocalAddr(), cliConn.GetRemoteAddr(),
|
||||||
userConn.GetLocalAddr(), userConn.GetRemoteAddr())
|
userConn.GetLocalAddr(), userConn.GetRemoteAddr())
|
||||||
// go conn.Join(cliConn, userConn)
|
// go conn.Join(cliConn, userConn)
|
||||||
go conn.PipeEncryptoWriter(userConn.TcpConn, cliConn.TcpConn, p.Passwd)
|
go conn.JoinMore(userConn, cliConn, p.Passwd)
|
||||||
go conn.PipeDecryptoReader(cliConn.TcpConn, userConn.TcpConn, p.Passwd)
|
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
@ -164,49 +164,72 @@ func Join(c1 *Conn, c2 *Conn) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// decrypto msg from reader, then write into writer
|
func JoinMore(local *Conn, remote *Conn, cryptoKey string) {
|
||||||
func PipeDecryptoReader(r net.Conn, w net.Conn, key string) {
|
var wait sync.WaitGroup
|
||||||
defer r.Close()
|
encrypPipe := func(from *Conn, to *Conn, key string) {
|
||||||
defer w.Close()
|
defer from.Close()
|
||||||
|
defer to.Close()
|
||||||
|
defer wait.Done()
|
||||||
|
|
||||||
|
err := PipeEncryptoWriter(from.TcpConn, to.TcpConn, key)
|
||||||
|
if err != nil {
|
||||||
|
log.Warn("join conns error, %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
decryptoPipe := func(to *Conn, from *Conn, key string) {
|
||||||
|
defer from.Close()
|
||||||
|
defer to.Close()
|
||||||
|
defer wait.Done()
|
||||||
|
|
||||||
|
err := PipeDecryptoReader(to.TcpConn, from.TcpConn, key)
|
||||||
|
if err != nil {
|
||||||
|
log.Warn("join conns error, %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wait.Add(2)
|
||||||
|
go encrypPipe(local, remote, cryptoKey)
|
||||||
|
go decryptoPipe(remote, local, cryptoKey)
|
||||||
|
wait.Wait()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// decrypto msg from reader, then write into writer
|
||||||
|
func PipeDecryptoReader(r net.Conn, w net.Conn, key string) error {
|
||||||
laes := new(pcrypto.Pcrypto)
|
laes := new(pcrypto.Pcrypto)
|
||||||
if err := laes.Init([]byte(key)); err != nil {
|
if err := laes.Init([]byte(key)); err != nil {
|
||||||
log.Error("Pcrypto Init error, [%v]", err)
|
log.Error("Pcrypto Init error: %v", err)
|
||||||
return
|
return fmt.Errorf("Pcrypto Init error: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
nreader := bufio.NewReader(r)
|
nreader := bufio.NewReader(r)
|
||||||
|
|
||||||
for {
|
for {
|
||||||
buf, err := nreader.ReadBytes('\n')
|
buf, err := nreader.ReadBytes('\n')
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("Conn ReadBytes error, [%v]", err)
|
return err
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
res, err := laes.Decrypto(buf)
|
res, err := laes.Decrypto(buf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("Decrypto error, [%s] [%s]", err, string(buf))
|
log.Error("Decrypto [%s] error, %v", string(buf), err)
|
||||||
return
|
return fmt.Errorf("Decrypto [%s] error: %v", string(buf), err)
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = w.Write(res)
|
_, err = w.Write(res)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("net.Conn Write error, [%v]", err)
|
return err
|
||||||
return
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// recvive msg from reader, then encrypto msg into write
|
// recvive msg from reader, then encrypto msg into write
|
||||||
func PipeEncryptoWriter(r net.Conn, w net.Conn, key string) {
|
func PipeEncryptoWriter(r net.Conn, w net.Conn, key string) error {
|
||||||
defer r.Close()
|
|
||||||
defer w.Close()
|
|
||||||
|
|
||||||
laes := new(pcrypto.Pcrypto)
|
laes := new(pcrypto.Pcrypto)
|
||||||
if err := laes.Init([]byte(key)); err != nil {
|
if err := laes.Init([]byte(key)); err != nil {
|
||||||
log.Error("Pcrypto Init error, [%v]", err)
|
log.Error("Pcrypto Init error: %v", err)
|
||||||
return
|
return fmt.Errorf("Pcrypto Init error: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
nreader := bufio.NewReader(r)
|
nreader := bufio.NewReader(r)
|
||||||
@ -215,20 +238,19 @@ func PipeEncryptoWriter(r net.Conn, w net.Conn, key string) {
|
|||||||
for {
|
for {
|
||||||
n, err := nreader.Read(buf)
|
n, err := nreader.Read(buf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("Conn ReadLine error, [%v]", err)
|
return err
|
||||||
return
|
|
||||||
}
|
}
|
||||||
res, err := laes.Encrypto(buf[:n])
|
res, err := laes.Encrypto(buf[:n])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("Encrypto error, [%v]", err)
|
log.Error("Encrypto error: %v", err)
|
||||||
return
|
return fmt.Errorf("Encrypto error: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
res = append(res, '\n')
|
res = append(res, '\n')
|
||||||
_, err = w.Write(res)
|
_, err = w.Write(res)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("net.Conn Write error, [%v]", err)
|
return err
|
||||||
return
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user