udp.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package server
  2. import (
  3. "github.com/cnlh/nps/bridge"
  4. "github.com/cnlh/nps/lib/common"
  5. "github.com/cnlh/nps/lib/conn"
  6. "github.com/cnlh/nps/lib/file"
  7. "github.com/cnlh/nps/lib/pool"
  8. "net"
  9. "strings"
  10. )
  11. type UdpModeServer struct {
  12. server
  13. listener *net.UDPConn
  14. udpMap map[string]*conn.Conn
  15. }
  16. func NewUdpModeServer(bridge *bridge.Bridge, task *file.Tunnel) *UdpModeServer {
  17. s := new(UdpModeServer)
  18. s.bridge = bridge
  19. s.udpMap = make(map[string]*conn.Conn)
  20. s.task = task
  21. s.config = file.DeepCopyConfig(task.Config)
  22. return s
  23. }
  24. //开始
  25. func (s *UdpModeServer) Start() error {
  26. var err error
  27. s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP("0.0.0.0"), s.task.TcpPort, ""})
  28. if err != nil {
  29. return err
  30. }
  31. buf := pool.BufPoolUdp.Get().([]byte)
  32. for {
  33. n, addr, err := s.listener.ReadFromUDP(buf)
  34. if err != nil {
  35. if strings.Contains(err.Error(), "use of closed network connection") {
  36. break
  37. }
  38. continue
  39. }
  40. if !s.ResetConfig() {
  41. continue
  42. }
  43. go s.process(addr, buf[:n])
  44. }
  45. return nil
  46. }
  47. func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
  48. link := conn.NewLink(s.task.Client.GetId(), common.CONN_UDP, s.task.Target, s.config.CompressEncode, s.config.CompressDecode, s.config.Crypt, nil, s.task.Flow, s.listener, s.task.Client.Rate, addr)
  49. if tunnel, err := s.bridge.SendLinkInfo(s.task.Client.Id, link); err != nil {
  50. return
  51. } else {
  52. s.task.Flow.Add(len(data), 0)
  53. tunnel.SendMsg(data, link)
  54. pool.PutBufPoolUdp(data)
  55. }
  56. }
  57. func (s *UdpModeServer) Close() error {
  58. return s.listener.Close()
  59. }