2019-02-12 19:54:00 +00:00
|
|
|
package proxy
|
2018-12-11 08:37:12 +00:00
|
|
|
|
|
|
|
import (
|
2019-02-03 04:40:43 +00:00
|
|
|
"github.com/cnlh/nps/bridge"
|
2019-02-09 09:07:47 +00:00
|
|
|
"github.com/cnlh/nps/lib/common"
|
|
|
|
"github.com/cnlh/nps/lib/conn"
|
|
|
|
"github.com/cnlh/nps/lib/file"
|
|
|
|
"github.com/cnlh/nps/lib/pool"
|
2019-02-23 15:29:48 +00:00
|
|
|
"github.com/cnlh/nps/vender/github.com/astaxie/beego/logs"
|
2018-12-11 08:37:12 +00:00
|
|
|
"net"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
type UdpModeServer struct {
|
2019-02-23 15:29:48 +00:00
|
|
|
BaseServer
|
2019-01-05 19:16:46 +00:00
|
|
|
listener *net.UDPConn
|
2018-12-11 08:37:12 +00:00
|
|
|
}
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
func NewUdpModeServer(bridge *bridge.Bridge, task *file.Tunnel) *UdpModeServer {
|
2018-12-11 08:37:12 +00:00
|
|
|
s := new(UdpModeServer)
|
|
|
|
s.bridge = bridge
|
2019-01-26 09:27:28 +00:00
|
|
|
s.task = task
|
2018-12-11 08:37:12 +00:00
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
//开始
|
|
|
|
func (s *UdpModeServer) Start() error {
|
2019-01-09 12:33:00 +00:00
|
|
|
var err error
|
2019-02-12 19:54:00 +00:00
|
|
|
s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP("0.0.0.0"), s.task.Port, ""})
|
2018-12-11 08:37:12 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2019-02-09 09:07:47 +00:00
|
|
|
buf := pool.BufPoolUdp.Get().([]byte)
|
2018-12-11 08:37:12 +00:00
|
|
|
for {
|
2019-01-31 18:06:30 +00:00
|
|
|
n, addr, err := s.listener.ReadFromUDP(buf)
|
2018-12-11 08:37:12 +00:00
|
|
|
if err != nil {
|
|
|
|
if strings.Contains(err.Error(), "use of closed network connection") {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
continue
|
|
|
|
}
|
2019-03-01 09:23:14 +00:00
|
|
|
logs.Trace("New udp connection,client %d,remote address %s", s.task.Client.Id, addr)
|
2019-01-31 18:06:30 +00:00
|
|
|
go s.process(addr, buf[:n])
|
2018-12-11 08:37:12 +00:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
|
2019-03-23 14:19:59 +00:00
|
|
|
if err := s.CheckFlowAndConnNum(s.task.Client); err != nil {
|
|
|
|
logs.Warn("client id %d, task id %d,error %s, when udp connection", s.task.Client.Id, s.task.Id, err.Error())
|
2019-02-12 19:54:00 +00:00
|
|
|
return
|
|
|
|
}
|
2019-03-23 14:19:59 +00:00
|
|
|
defer s.task.Client.AddConn()
|
|
|
|
link := conn.NewLink(common.CONN_UDP, s.task.Target, s.task.Client.Cnf.Crypt, s.task.Client.Cnf.Compress, addr.String())
|
2019-03-02 09:43:21 +00:00
|
|
|
if target, err := s.bridge.SendLinkInfo(s.task.Client.Id, link, addr.String(), s.task); err != nil {
|
2018-12-11 08:37:12 +00:00
|
|
|
return
|
2019-01-31 18:06:30 +00:00
|
|
|
} else {
|
2019-03-01 09:23:14 +00:00
|
|
|
s.task.Flow.Add(int64(len(data)), 0)
|
|
|
|
buf := pool.BufPoolUdp.Get().([]byte)
|
|
|
|
defer pool.BufPoolUdp.Put(buf)
|
|
|
|
target.Write(data)
|
2019-03-15 06:03:49 +00:00
|
|
|
s.task.Flow.Add(int64(len(data)), 0)
|
2019-03-01 09:23:14 +00:00
|
|
|
if n, err := target.Read(buf); err != nil {
|
|
|
|
logs.Warn(err)
|
|
|
|
return
|
|
|
|
} else {
|
|
|
|
s.listener.WriteTo(buf[:n], addr)
|
|
|
|
s.task.Flow.Add(0, int64(n))
|
|
|
|
}
|
2019-01-06 17:52:54 +00:00
|
|
|
}
|
2018-12-11 08:37:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *UdpModeServer) Close() error {
|
|
|
|
return s.listener.Close()
|
|
|
|
}
|