tcp.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. package server
  2. import (
  3. "errors"
  4. "github.com/astaxie/beego"
  5. "github.com/cnlh/nps/bridge"
  6. "github.com/cnlh/nps/lib"
  7. "net"
  8. "path/filepath"
  9. "strings"
  10. )
  11. type TunnelModeServer struct {
  12. server
  13. process process
  14. listener *net.TCPListener
  15. }
  16. //tcp|http|host
  17. func NewTunnelModeServer(process process, bridge *bridge.Bridge, task *lib.Tunnel) *TunnelModeServer {
  18. s := new(TunnelModeServer)
  19. s.bridge = bridge
  20. s.process = process
  21. s.task = task
  22. s.config = lib.DeepCopyConfig(task.Config)
  23. return s
  24. }
  25. //开始
  26. func (s *TunnelModeServer) Start() error {
  27. var err error
  28. s.listener, err = net.ListenTCP("tcp", &net.TCPAddr{net.ParseIP("0.0.0.0"), s.task.TcpPort, ""})
  29. if err != nil {
  30. return err
  31. }
  32. for {
  33. conn, err := s.listener.AcceptTCP()
  34. if err != nil {
  35. if strings.Contains(err.Error(), "use of closed network connection") {
  36. break
  37. }
  38. lib.Println(err)
  39. continue
  40. }
  41. go s.process(lib.NewConn(conn), s)
  42. }
  43. return nil
  44. }
  45. //与客户端建立通道
  46. func (s *TunnelModeServer) dealClient(c *lib.Conn, cnf *lib.Config, addr string, method string, rb []byte) error {
  47. link := lib.NewLink(s.task.Client.GetId(), lib.CONN_TCP, addr, cnf.CompressEncode, cnf.CompressDecode, cnf.Crypt, c, s.task.Flow, nil, s.task.Client.Rate, nil)
  48. if tunnel, err := s.bridge.SendLinkInfo(s.task.Client.Id, link); err != nil {
  49. c.Close()
  50. return err
  51. } else {
  52. s.linkCopy(link, c, rb, tunnel, s.task.Flow)
  53. }
  54. return nil
  55. }
  56. //close
  57. func (s *TunnelModeServer) Close() error {
  58. return s.listener.Close()
  59. }
  60. //web管理方式
  61. type WebServer struct {
  62. server
  63. }
  64. //开始
  65. func (s *WebServer) Start() error {
  66. p, _ := beego.AppConfig.Int("httpport")
  67. if !lib.TestTcpPort(p) {
  68. lib.Fatalln("web管理端口", p, "被占用!")
  69. }
  70. beego.BConfig.WebConfig.Session.SessionOn = true
  71. lib.Println("web管理启动,访问端口为", beego.AppConfig.String("httpport"))
  72. beego.SetStaticPath("/static", filepath.Join(lib.GetRunPath(), "web", "static"))
  73. beego.SetViewsPath(filepath.Join(lib.GetRunPath(), "web", "views"))
  74. beego.Run()
  75. return errors.New("web管理启动失败")
  76. }
  77. //new
  78. func NewWebServer(bridge *bridge.Bridge) *WebServer {
  79. s := new(WebServer)
  80. s.bridge = bridge
  81. return s
  82. }
  83. //host
  84. type HostServer struct {
  85. server
  86. }
  87. //开始
  88. func (s *HostServer) Start() error {
  89. return nil
  90. }
  91. func NewHostServer(task *lib.Tunnel) *HostServer {
  92. s := new(HostServer)
  93. s.task = task
  94. s.config = lib.DeepCopyConfig(task.Config)
  95. return s
  96. }
  97. //close
  98. func (s *HostServer) Close() error {
  99. return nil
  100. }
  101. type process func(c *lib.Conn, s *TunnelModeServer) error
  102. //tcp隧道模式
  103. func ProcessTunnel(c *lib.Conn, s *TunnelModeServer) error {
  104. if !s.ResetConfig() {
  105. c.Close()
  106. return errors.New("流量超出")
  107. }
  108. return s.dealClient(c, s.config, s.task.Target, "", nil)
  109. }
  110. //http代理模式
  111. func ProcessHttp(c *lib.Conn, s *TunnelModeServer) error {
  112. if !s.ResetConfig() {
  113. c.Close()
  114. return errors.New("流量超出")
  115. }
  116. method, addr, rb, err, r := c.GetHost()
  117. if err != nil {
  118. c.Close()
  119. return err
  120. }
  121. if err := s.auth(r, c, s.config.U, s.config.P); err != nil {
  122. return err
  123. }
  124. return s.dealClient(c, s.config, addr, method, rb)
  125. }