nps/server/udp.go

86 lines
2.0 KiB
Go
Raw Normal View History

2019-01-09 12:33:00 +00:00
package server
2018-12-11 08:37:12 +00:00
import (
2019-01-09 12:33:00 +00:00
"github.com/cnlh/easyProxy/bridge"
"github.com/cnlh/easyProxy/utils"
2018-12-11 08:37:12 +00:00
"io"
"log"
"net"
"strings"
)
type UdpModeServer struct {
server
2019-01-05 19:16:46 +00:00
listener *net.UDPConn
2019-01-09 12:33:00 +00:00
udpMap map[string]*utils.Conn
2018-12-11 08:37:12 +00:00
}
func NewUdpModeServer(bridge *bridge.Tunnel, cnf *utils.ServerConfig) *UdpModeServer {
2018-12-11 08:37:12 +00:00
s := new(UdpModeServer)
s.bridge = bridge
2019-01-09 12:33:00 +00:00
s.udpMap = make(map[string]*utils.Conn)
2019-01-05 19:16:46 +00:00
s.config = cnf
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-01-05 19:16:46 +00:00
s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP("0.0.0.0"), s.config.TcpPort, ""})
2018-12-11 08:37:12 +00:00
if err != nil {
return err
}
data := make([]byte, 1472) //udp数据包大小
for {
n, addr, err := s.listener.ReadFromUDP(data)
if err != nil {
if strings.Contains(err.Error(), "use of closed network connection") {
break
}
continue
}
s.ResetConfig()
2018-12-11 08:37:12 +00:00
go s.process(addr, data[:n])
}
return nil
}
//TODO:效率问题有待解决
func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
conn, err := s.bridge.GetTunnel(s.config.ClientId, s.config.CompressEncode, s.config.CompressDecode, s.config.Crypt, s.config.Mux)
2018-12-30 14:36:15 +00:00
if err != nil {
log.Println(err)
return
}
2019-01-09 12:33:00 +00:00
if _, err := conn.WriteHost(utils.CONN_UDP, s.config.Target); err != nil {
2018-12-11 08:37:12 +00:00
conn.Close()
return
}
2019-01-06 17:52:54 +00:00
if flag, err := conn.ReadFlag(); err == nil {
2019-01-07 16:21:02 +00:00
defer func() {
2019-01-12 16:09:12 +00:00
if conn != nil && s.config.Mux {
2019-01-10 01:33:05 +00:00
conn.WriteTo([]byte(utils.IO_EOF), s.config.CompressEncode, s.config.Crypt)
s.bridge.ReturnTunnel(conn, s.config.ClientId)
2019-01-07 16:21:02 +00:00
} else {
2019-01-06 17:52:54 +00:00
conn.Close()
2019-01-07 16:21:02 +00:00
}
}()
2019-01-09 12:33:00 +00:00
if flag == utils.CONN_SUCCESS {
in, _ := conn.WriteTo(data, s.config.CompressEncode, s.config.Crypt)
buf := utils.BufPoolUdp.Get().([]byte)
out, err := conn.ReadFrom(buf, s.config.CompressDecode, s.config.Crypt)
2019-01-07 16:21:02 +00:00
if err != nil || err == io.EOF {
log.Println("revieve error:", err)
return
}
s.listener.WriteToUDP(buf[:out], addr)
s.FlowAdd(int64(in), int64(out))
utils.BufPoolUdp.Put(buf)
2018-12-11 08:37:12 +00:00
}
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()
}