tunnel.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  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. if !verify(string(vval)) {
  76. log.Println("当前客户端连接校验错误,关闭此客户端:", c.conn.RemoteAddr())
  77. s.verifyError(c)
  78. return err
  79. }
  80. c.conn.(*net.TCPConn).SetReadDeadline(time.Time{})
  81. //做一个判断 添加到对应的channel里面以供使用
  82. if flag, err := c.ReadFlag(); err != nil {
  83. return err
  84. } else {
  85. return s.typeDeal(flag, c, string(vval))
  86. }
  87. }
  88. //tcp连接类型区分
  89. func (s *Tunnel) typeDeal(typeVal string, c *Conn, cFlag string) error {
  90. switch typeVal {
  91. case WORK_MAIN:
  92. s.addList(s.signalList, c, cFlag)
  93. case WORK_CHAN:
  94. s.addList(s.tunnelList, c, cFlag)
  95. default:
  96. return errors.New("无法识别")
  97. }
  98. c.SetAlive()
  99. return nil
  100. }
  101. //加到对应的list中
  102. func (s *Tunnel) addList(m map[string]*list, c *Conn, cFlag string) {
  103. s.Lock()
  104. if v, ok := m[cFlag]; ok {
  105. v.Add(c)
  106. } else {
  107. l := newList()
  108. l.Add(c)
  109. m[cFlag] = l
  110. }
  111. s.Unlock()
  112. }
  113. //新建隧道
  114. func (s *Tunnel) newChan(cFlag string) error {
  115. if err := s.wait(s.signalList, cFlag); err != nil {
  116. return err
  117. }
  118. retry:
  119. connPass := s.signalList[cFlag].Pop()
  120. _, err := connPass.conn.Write([]byte("chan"))
  121. if err != nil {
  122. log.Println(err)
  123. goto retry
  124. }
  125. s.signalList[cFlag].Add(connPass)
  126. return nil
  127. }
  128. //得到一个tcp隧道
  129. func (s *Tunnel) GetTunnel(cFlag string, en, de int, crypt bool) (c *Conn, err error) {
  130. if v, ok := s.tunnelList[cFlag]; !ok || v.Len() < 10 { //新建通道
  131. go s.newChan(cFlag)
  132. }
  133. retry:
  134. if err = s.wait(s.tunnelList, cFlag); err != nil {
  135. return
  136. }
  137. c = s.tunnelList[cFlag].Pop()
  138. if _, err := c.wTest(); err != nil {
  139. c.Close()
  140. goto retry
  141. }
  142. c.WriteConnInfo(en, de, crypt)
  143. return
  144. }
  145. //得到一个通信通道
  146. func (s *Tunnel) GetSignal(cFlag string) (err error, conn *Conn) {
  147. if v, ok := s.signalList[cFlag]; !ok || v.Len() == 0 {
  148. err = errors.New("客户端未连接")
  149. return
  150. }
  151. conn = s.signalList[cFlag].Pop()
  152. return
  153. }
  154. //重回slice 复用
  155. func (s *Tunnel) ReturnSignal(conn *Conn, cFlag string) {
  156. if v, ok := s.signalList[cFlag]; ok {
  157. v.Add(conn)
  158. }
  159. }
  160. //删除通信通道
  161. func (s *Tunnel) DelClientSignal(cFlag string) {
  162. s.delClient(cFlag, s.signalList)
  163. }
  164. //删除隧道
  165. func (s *Tunnel) DelClientTunnel(cFlag string) {
  166. s.delClient(cFlag, s.tunnelList)
  167. }
  168. func (s *Tunnel) delClient(cFlag string, l map[string]*list) {
  169. if t := l[getverifyval(cFlag)]; t != nil {
  170. for {
  171. if t.Len() <= 0 {
  172. break
  173. }
  174. t.Pop().Close()
  175. }
  176. delete(l, getverifyval(cFlag))
  177. }
  178. }
  179. //等待
  180. func (s *Tunnel) wait(m map[string]*list, cFlag string) error {
  181. ticker := time.NewTicker(time.Millisecond * 100)
  182. stop := time.After(time.Second * 10)
  183. loop:
  184. for {
  185. select {
  186. case <-ticker.C:
  187. if _, ok := m[cFlag]; ok {
  188. ticker.Stop()
  189. break loop
  190. }
  191. case <-stop:
  192. return errors.New("client key: " + cFlag + ",err: get client conn timeout")
  193. }
  194. }
  195. return nil
  196. }