1
0

tunnel.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. package lib
  2. import (
  3. "errors"
  4. "log"
  5. "net"
  6. "sync"
  7. "time"
  8. )
  9. type list struct {
  10. connList chan *Conn
  11. }
  12. func (l *list) Add(c *Conn) {
  13. l.connList <- c
  14. }
  15. func (l *list) Pop() *Conn {
  16. return <-l.connList
  17. }
  18. func (l *list) Len() int {
  19. return len(l.connList)
  20. }
  21. func newList() *list {
  22. l := new(list)
  23. l.connList = make(chan *Conn, 100)
  24. return l
  25. }
  26. type Tunnel struct {
  27. tunnelPort int //通信隧道端口
  28. listener *net.TCPListener //server端监听
  29. signalList map[string]*list //通信
  30. tunnelList map[string]*list //隧道
  31. sync.Mutex
  32. }
  33. func newTunnel(tunnelPort int) *Tunnel {
  34. t := new(Tunnel)
  35. t.tunnelPort = tunnelPort
  36. t.signalList = make(map[string]*list)
  37. t.tunnelList = make(map[string]*list)
  38. return t
  39. }
  40. func (s *Tunnel) StartTunnel() error {
  41. var err error
  42. s.listener, err = net.ListenTCP("tcp", &net.TCPAddr{net.ParseIP("0.0.0.0"), s.tunnelPort, ""})
  43. if err != nil {
  44. return err
  45. }
  46. go s.tunnelProcess()
  47. return nil
  48. }
  49. //tcp server
  50. func (s *Tunnel) tunnelProcess() error {
  51. var err error
  52. for {
  53. conn, err := s.listener.Accept()
  54. if err != nil {
  55. log.Println(err)
  56. continue
  57. }
  58. go s.cliProcess(NewConn(conn))
  59. }
  60. return err
  61. }
  62. //验证失败,返回错误验证flag,并且关闭连接
  63. func (s *Tunnel) verifyError(c *Conn) {
  64. c.conn.Write([]byte(VERIFY_EER))
  65. c.conn.Close()
  66. }
  67. func (s *Tunnel) cliProcess(c *Conn) error {
  68. c.conn.(*net.TCPConn).SetReadDeadline(time.Now().Add(time.Duration(5) * time.Second))
  69. vval := make([]byte, 32)
  70. if _, err := c.conn.Read(vval); err != nil {
  71. log.Println("客户端读超时。客户端地址为::", c.conn.RemoteAddr())
  72. c.conn.Close()
  73. return err
  74. }
  75. //TODO:暂时取消
  76. if !verify(string(vval)) {
  77. log.Println("当前客户端连接校验错误,关闭此客户端:", c.conn.RemoteAddr())
  78. s.verifyError(c)
  79. return err
  80. }
  81. c.conn.(*net.TCPConn).SetReadDeadline(time.Time{})
  82. //做一个判断 添加到对应的channel里面以供使用
  83. if flag, err := c.ReadFlag(); err != nil {
  84. return err
  85. } else {
  86. return s.typeDeal(flag, c, string(vval))
  87. }
  88. }
  89. //tcp连接类型区分
  90. func (s *Tunnel) typeDeal(typeVal string, c *Conn, cFlag string) error {
  91. switch typeVal {
  92. case WORK_MAIN:
  93. s.addList(s.signalList, c, cFlag)
  94. case WORK_CHAN:
  95. s.addList(s.tunnelList, c, cFlag)
  96. default:
  97. return errors.New("无法识别")
  98. }
  99. c.SetAlive()
  100. return nil
  101. }
  102. //加到对应的list中
  103. func (s *Tunnel) addList(m map[string]*list, c *Conn, cFlag string) {
  104. s.Lock()
  105. if v, ok := m[cFlag]; ok {
  106. v.Add(c)
  107. } else {
  108. l := newList()
  109. l.Add(c)
  110. m[cFlag] = l
  111. }
  112. s.Unlock()
  113. }
  114. //新建隧道
  115. func (s *Tunnel) newChan(cFlag string) {
  116. s.wait(s.signalList, cFlag)
  117. retry:
  118. connPass := s.signalList[cFlag].Pop()
  119. _, err := connPass.conn.Write([]byte("chan"))
  120. if err != nil {
  121. log.Println(err)
  122. goto retry
  123. }
  124. s.signalList[cFlag].Add(connPass)
  125. }
  126. //得到一个tcp隧道
  127. func (s *Tunnel) GetTunnel(cFlag string, en, de int) *Conn {
  128. if v, ok := s.tunnelList[cFlag]; !ok || v.Len() < 10 { //新建通道
  129. go s.newChan(cFlag)
  130. }
  131. retry:
  132. s.wait(s.tunnelList, cFlag)
  133. c := s.tunnelList[cFlag].Pop()
  134. if _, err := c.wTest(); err != nil {
  135. c.Close()
  136. goto retry
  137. }
  138. c.WriteCompressType(en, de)
  139. return c
  140. }
  141. //得到一个通信通道
  142. func (s *Tunnel) GetSignal(cFlag string) (err error, conn *Conn) {
  143. if v, ok := s.signalList[cFlag]; !ok || v.Len() == 0 {
  144. err = errors.New("客户端未连接")
  145. return
  146. }
  147. conn = s.signalList[cFlag].Pop()
  148. return
  149. }
  150. //重回slice 复用
  151. func (s *Tunnel) ReturnSignal(conn *Conn, cFlag string) {
  152. if v, ok := s.signalList[cFlag]; ok {
  153. v.Add(conn)
  154. }
  155. }
  156. //等待
  157. func (s *Tunnel) wait(m map[string]*list, cFlag string) {
  158. ticker := time.NewTicker(time.Millisecond * 100)
  159. for {
  160. <-ticker.C
  161. if _, ok := m[cFlag]; ok {
  162. ticker.Stop()
  163. break
  164. }
  165. }
  166. }