nps/server/proxy/udp.go

81 lines
2.0 KiB
Go
Raw Normal View History

2019-02-12 19:54:00 +00:00
package proxy
2018-12-11 08:37:12 +00:00
import (
2019-08-10 03:15:25 +00:00
"net"
"strings"
2020-01-08 13:57:14 +00:00
"ehang.io/nps/bridge"
"ehang.io/nps/lib/common"
"ehang.io/nps/lib/conn"
"ehang.io/nps/lib/file"
2019-08-10 03:15:25 +00:00
"github.com/astaxie/beego/logs"
2018-12-11 08:37:12 +00:00
)
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
if s.task.ServerIp == "" {
s.task.ServerIp = "0.0.0.0"
}
s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP(s.task.ServerIp), s.task.Port, ""})
2018-12-11 08:37:12 +00:00
if err != nil {
return err
}
buf := common.BufPoolUdp.Get().([]byte)
2018-12-11 08:37:12 +00:00
for {
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
}
logs.Trace("New udp connection,client %d,remote address %s", s.task.Client.Id, addr)
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()
2019-04-08 09:01:08 +00:00
link := conn.NewLink(common.CONN_UDP, s.task.Target.TargetStr, s.task.Client.Cnf.Crypt, s.task.Client.Cnf.Compress, addr.String(), s.task.Target.LocalProxy)
2020-01-15 13:55:20 +00:00
if clientConn, err := s.bridge.SendLinkInfo(s.task.Client.Id, link, s.task); err != nil {
2018-12-11 08:37:12 +00:00
return
} else {
2020-01-15 13:55:20 +00:00
target := conn.GetConn(clientConn, s.task.Client.Cnf.Crypt, s.task.Client.Cnf.Compress, nil, true)
2020-01-15 14:32:41 +00:00
defer target.Close()
s.task.Flow.Add(int64(len(data)), 0)
buf := common.BufPoolUdp.Get().([]byte)
defer common.BufPoolUdp.Put(buf)
target.Write(data)
2019-03-15 06:03:49 +00:00
s.task.Flow.Add(int64(len(data)), 0)
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()
}