tcp.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package proxy
  2. import (
  3. "errors"
  4. "github.com/cnlh/nps/bridge"
  5. "github.com/cnlh/nps/lib/common"
  6. "github.com/cnlh/nps/lib/conn"
  7. "github.com/cnlh/nps/lib/file"
  8. "github.com/cnlh/nps/lib/lg"
  9. "github.com/cnlh/nps/vender/github.com/astaxie/beego"
  10. "net"
  11. "path/filepath"
  12. "strings"
  13. )
  14. type TunnelModeServer struct {
  15. server
  16. process process
  17. listener *net.TCPListener
  18. }
  19. //tcp|http|host
  20. func NewTunnelModeServer(process process, bridge *bridge.Bridge, task *file.Tunnel) *TunnelModeServer {
  21. s := new(TunnelModeServer)
  22. s.bridge = bridge
  23. s.process = process
  24. s.task = task
  25. return s
  26. }
  27. //开始
  28. func (s *TunnelModeServer) Start() error {
  29. var err error
  30. s.listener, err = net.ListenTCP("tcp", &net.TCPAddr{net.ParseIP("0.0.0.0"), s.task.Port, ""})
  31. if err != nil {
  32. return err
  33. }
  34. for {
  35. c, err := s.listener.AcceptTCP()
  36. if err != nil {
  37. if strings.Contains(err.Error(), "use of closed network connection") {
  38. break
  39. }
  40. lg.Println(err)
  41. continue
  42. }
  43. go s.process(conn.NewConn(c), s)
  44. }
  45. return nil
  46. }
  47. //与客户端建立通道
  48. func (s *TunnelModeServer) dealClient(c *conn.Conn, cnf *file.Config, addr string, method string, rb []byte) error {
  49. link := conn.NewLink(s.task.Client.GetId(), common.CONN_TCP, addr, cnf.CompressEncode, cnf.CompressDecode, cnf.Crypt, c, s.task.Flow, nil, s.task.Client.Rate, nil)
  50. if tunnel, err := s.bridge.SendLinkInfo(s.task.Client.Id, link, c.Conn.RemoteAddr().String()); err != nil {
  51. c.Close()
  52. return err
  53. } else {
  54. s.linkCopy(link, c, rb, tunnel, s.task.Flow)
  55. }
  56. return nil
  57. }
  58. //close
  59. func (s *TunnelModeServer) Close() error {
  60. return s.listener.Close()
  61. }
  62. //web管理方式
  63. type WebServer struct {
  64. server
  65. }
  66. //开始
  67. func (s *WebServer) Start() error {
  68. p, _ := beego.AppConfig.Int("httpport")
  69. if !common.TestTcpPort(p) {
  70. lg.Fatalf("Web management port %d is occupied", p)
  71. }
  72. beego.BConfig.WebConfig.Session.SessionOn = true
  73. lg.Println("Web management start, access port is", p)
  74. beego.SetStaticPath("/static", filepath.Join(common.GetRunPath(), "web", "static"))
  75. beego.SetViewsPath(filepath.Join(common.GetRunPath(), "web", "views"))
  76. beego.Run()
  77. return errors.New("Web management startup failure")
  78. }
  79. //new
  80. func NewWebServer(bridge *bridge.Bridge) *WebServer {
  81. s := new(WebServer)
  82. s.bridge = bridge
  83. return s
  84. }
  85. type process func(c *conn.Conn, s *TunnelModeServer) error
  86. //tcp隧道模式
  87. func ProcessTunnel(c *conn.Conn, s *TunnelModeServer) error {
  88. return s.dealClient(c, s.task.Client.Cnf, s.task.Target, "", nil)
  89. }
  90. //http代理模式
  91. func ProcessHttp(c *conn.Conn, s *TunnelModeServer) error {
  92. method, addr, rb, err, r := c.GetHost()
  93. if err != nil {
  94. c.Close()
  95. lg.Println(err)
  96. return err
  97. }
  98. if r.Method == "CONNECT" {
  99. c.Write([]byte("HTTP/1.1 200 Connection Established\r\n"))
  100. rb = nil //reset
  101. }
  102. if err := s.auth(r, c, s.task.Client.Cnf.U, s.task.Client.Cnf.P); err != nil {
  103. return err
  104. }
  105. return s.dealClient(c, s.task.Client.Cnf, addr, method, rb)
  106. }