netpackager.go 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  1. package common
  2. import (
  3. "bytes"
  4. "encoding/binary"
  5. "encoding/json"
  6. "errors"
  7. "io"
  8. "io/ioutil"
  9. "net"
  10. "strconv"
  11. "strings"
  12. )
  13. type NetPackager interface {
  14. Pack(writer io.Writer) (err error)
  15. UnPack(reader io.Reader) (err error)
  16. }
  17. type BasePackager struct {
  18. Length uint16
  19. Content []byte
  20. }
  21. func (Self *BasePackager) NewPac(contents ...interface{}) (err error) {
  22. Self.clean()
  23. for _, content := range contents {
  24. switch content.(type) {
  25. case nil:
  26. Self.Content = Self.Content[:0]
  27. case []byte:
  28. err = Self.appendByte(content.([]byte))
  29. case string:
  30. err = Self.appendByte([]byte(content.(string)))
  31. if err != nil {
  32. return
  33. }
  34. err = Self.appendByte([]byte(CONN_DATA_SEQ))
  35. default:
  36. err = Self.marshal(content)
  37. }
  38. }
  39. Self.setLength()
  40. return
  41. }
  42. func (Self *BasePackager) appendByte(data []byte) (err error) {
  43. m := len(Self.Content)
  44. n := m + len(data)
  45. if n <= cap(Self.Content) {
  46. Self.Content = Self.Content[0:n] // grow the length for copy
  47. copy(Self.Content[m:n], data)
  48. return nil
  49. } else {
  50. return errors.New("pack content too large")
  51. }
  52. }
  53. //似乎这里涉及到父类作用域问题,当子类调用父类的方法时,其struct仅仅为父类的
  54. func (Self *BasePackager) Pack(writer io.Writer) (err error) {
  55. err = binary.Write(writer, binary.LittleEndian, Self.Length)
  56. if err != nil {
  57. return
  58. }
  59. err = binary.Write(writer, binary.LittleEndian, Self.Content)
  60. return
  61. }
  62. //Unpack 会导致传入的数字类型转化成float64!!
  63. //主要原因是json unmarshal并未传入正确的数据类型
  64. func (Self *BasePackager) UnPack(reader io.Reader) (n uint16, err error) {
  65. Self.clean()
  66. n += 2 // uint16
  67. err = binary.Read(reader, binary.LittleEndian, &Self.Length)
  68. if err != nil {
  69. return
  70. }
  71. if int(Self.Length) > cap(Self.Content) {
  72. err = errors.New("unpack err, content length too large")
  73. }
  74. Self.Content = Self.Content[:int(Self.Length)]
  75. //n, err := io.ReadFull(reader, Self.Content)
  76. //if n != int(Self.Length) {
  77. // err = io.ErrUnexpectedEOF
  78. //}
  79. err = binary.Read(reader, binary.LittleEndian, Self.Content)
  80. n += Self.Length
  81. return
  82. }
  83. func (Self *BasePackager) marshal(content interface{}) (err error) {
  84. tmp, err := json.Marshal(content)
  85. if err != nil {
  86. return err
  87. }
  88. err = Self.appendByte(tmp)
  89. return
  90. }
  91. func (Self *BasePackager) Unmarshal(content interface{}) (err error) {
  92. err = json.Unmarshal(Self.Content, content)
  93. if err != nil {
  94. return err
  95. }
  96. return
  97. }
  98. func (Self *BasePackager) setLength() {
  99. Self.Length = uint16(len(Self.Content))
  100. return
  101. }
  102. func (Self *BasePackager) clean() {
  103. Self.Length = 0
  104. Self.Content = Self.Content[:0] // reset length
  105. }
  106. func (Self *BasePackager) Split() (strList []string) {
  107. n := bytes.IndexByte(Self.Content, 0)
  108. strList = strings.Split(string(Self.Content[:n]), CONN_DATA_SEQ)
  109. strList = strList[0 : len(strList)-1]
  110. return
  111. }
  112. type ConnPackager struct {
  113. // Todo
  114. ConnType uint8
  115. BasePackager
  116. }
  117. func (Self *ConnPackager) NewPac(connType uint8, content ...interface{}) (err error) {
  118. Self.ConnType = connType
  119. err = Self.BasePackager.NewPac(content...)
  120. return
  121. }
  122. func (Self *ConnPackager) Pack(writer io.Writer) (err error) {
  123. err = binary.Write(writer, binary.LittleEndian, Self.ConnType)
  124. if err != nil {
  125. return
  126. }
  127. err = Self.BasePackager.Pack(writer)
  128. return
  129. }
  130. func (Self *ConnPackager) UnPack(reader io.Reader) (n uint16, err error) {
  131. err = binary.Read(reader, binary.LittleEndian, &Self.ConnType)
  132. if err != nil && err != io.EOF {
  133. return
  134. }
  135. n, err = Self.BasePackager.UnPack(reader)
  136. n += 2
  137. return
  138. }
  139. type MuxPackager struct {
  140. Flag uint8
  141. Id int32
  142. Window uint32
  143. ReadLength uint32
  144. BasePackager
  145. }
  146. func (Self *MuxPackager) NewPac(flag uint8, id int32, content ...interface{}) (err error) {
  147. Self.Flag = flag
  148. Self.Id = id
  149. switch flag {
  150. case MUX_PING_FLAG, MUX_PING_RETURN, MUX_NEW_MSG, MUX_NEW_MSG_PART:
  151. Self.Content = WindowBuff.Get()
  152. err = Self.BasePackager.NewPac(content...)
  153. //logs.Warn(Self.Length, string(Self.Content))
  154. case MUX_MSG_SEND_OK:
  155. // MUX_MSG_SEND_OK contains two data
  156. switch content[0].(type) {
  157. case int:
  158. Self.Window = uint32(content[0].(int))
  159. case uint32:
  160. Self.Window = content[0].(uint32)
  161. }
  162. switch content[1].(type) {
  163. case int:
  164. Self.ReadLength = uint32(content[1].(int))
  165. case uint32:
  166. Self.ReadLength = content[1].(uint32)
  167. }
  168. }
  169. return
  170. }
  171. func (Self *MuxPackager) Pack(writer io.Writer) (err error) {
  172. err = binary.Write(writer, binary.LittleEndian, Self.Flag)
  173. if err != nil {
  174. return
  175. }
  176. err = binary.Write(writer, binary.LittleEndian, Self.Id)
  177. if err != nil {
  178. return
  179. }
  180. switch Self.Flag {
  181. case MUX_NEW_MSG, MUX_NEW_MSG_PART, MUX_PING_FLAG, MUX_PING_RETURN:
  182. err = Self.BasePackager.Pack(writer)
  183. WindowBuff.Put(Self.Content)
  184. case MUX_MSG_SEND_OK:
  185. err = binary.Write(writer, binary.LittleEndian, Self.Window)
  186. if err != nil {
  187. return
  188. }
  189. err = binary.Write(writer, binary.LittleEndian, Self.ReadLength)
  190. }
  191. return
  192. }
  193. func (Self *MuxPackager) UnPack(reader io.Reader) (n uint16, err error) {
  194. err = binary.Read(reader, binary.LittleEndian, &Self.Flag)
  195. if err != nil {
  196. return
  197. }
  198. err = binary.Read(reader, binary.LittleEndian, &Self.Id)
  199. if err != nil {
  200. return
  201. }
  202. switch Self.Flag {
  203. case MUX_NEW_MSG, MUX_NEW_MSG_PART, MUX_PING_FLAG, MUX_PING_RETURN:
  204. Self.Content = WindowBuff.Get() // need get a window buf from pool
  205. Self.BasePackager.clean() // also clean the content
  206. n, err = Self.BasePackager.UnPack(reader)
  207. //logs.Warn("unpack", Self.Length, string(Self.Content))
  208. case MUX_MSG_SEND_OK:
  209. err = binary.Read(reader, binary.LittleEndian, &Self.Window)
  210. if err != nil {
  211. return
  212. }
  213. n += 4 // uint32
  214. err = binary.Read(reader, binary.LittleEndian, &Self.ReadLength)
  215. n += 4 // uint32
  216. }
  217. n += 5 //uint8 int32
  218. return
  219. }
  220. const (
  221. ipV4 = 1
  222. domainName = 3
  223. ipV6 = 4
  224. )
  225. type UDPHeader struct {
  226. Rsv uint16
  227. Frag uint8
  228. Addr *Addr
  229. }
  230. func NewUDPHeader(rsv uint16, frag uint8, addr *Addr) *UDPHeader {
  231. return &UDPHeader{
  232. Rsv: rsv,
  233. Frag: frag,
  234. Addr: addr,
  235. }
  236. }
  237. type Addr struct {
  238. Type uint8
  239. Host string
  240. Port uint16
  241. }
  242. func (addr *Addr) String() string {
  243. return net.JoinHostPort(addr.Host, strconv.Itoa(int(addr.Port)))
  244. }
  245. func (addr *Addr) Decode(b []byte) error {
  246. addr.Type = b[0]
  247. pos := 1
  248. switch addr.Type {
  249. case ipV4:
  250. addr.Host = net.IP(b[pos:pos+net.IPv4len]).String()
  251. pos += net.IPv4len
  252. case ipV6:
  253. addr.Host = net.IP(b[pos:pos+net.IPv6len]).String()
  254. pos += net.IPv6len
  255. case domainName:
  256. addrlen := int(b[pos])
  257. pos++
  258. addr.Host = string(b[pos : pos+addrlen])
  259. pos += addrlen
  260. default:
  261. return errors.New("decode error")
  262. }
  263. addr.Port = binary.BigEndian.Uint16(b[pos:])
  264. return nil
  265. }
  266. func (addr *Addr) Encode(b []byte) (int, error) {
  267. b[0] = addr.Type
  268. pos := 1
  269. switch addr.Type {
  270. case ipV4:
  271. ip4 := net.ParseIP(addr.Host).To4()
  272. if ip4 == nil {
  273. ip4 = net.IPv4zero.To4()
  274. }
  275. pos += copy(b[pos:], ip4)
  276. case domainName:
  277. b[pos] = byte(len(addr.Host))
  278. pos++
  279. pos += copy(b[pos:], []byte(addr.Host))
  280. case ipV6:
  281. ip16 := net.ParseIP(addr.Host).To16()
  282. if ip16 == nil {
  283. ip16 = net.IPv6zero.To16()
  284. }
  285. pos += copy(b[pos:], ip16)
  286. default:
  287. b[0] = ipV4
  288. copy(b[pos:pos+4], net.IPv4zero.To4())
  289. pos += 4
  290. }
  291. binary.BigEndian.PutUint16(b[pos:], addr.Port)
  292. pos += 2
  293. return pos, nil
  294. }
  295. func (h *UDPHeader) Write(w io.Writer) error {
  296. b := BufPoolUdp.Get().([]byte)
  297. defer BufPoolUdp.Put(b)
  298. binary.BigEndian.PutUint16(b[:2], h.Rsv)
  299. b[2] = h.Frag
  300. addr := h.Addr
  301. if addr == nil {
  302. addr = &Addr{}
  303. }
  304. length, _ := addr.Encode(b[3:])
  305. _, err := w.Write(b[:3+length])
  306. return err
  307. }
  308. type UDPDatagram struct {
  309. Header *UDPHeader
  310. Data []byte
  311. }
  312. func ReadUDPDatagram(r io.Reader) (*UDPDatagram, error) {
  313. b := BufPoolUdp.Get().([]byte)
  314. defer BufPoolUdp.Put(b)
  315. // when r is a streaming (such as TCP connection), we may read more than the required data,
  316. // but we don't know how to handle it. So we use io.ReadFull to instead of io.ReadAtLeast
  317. // to make sure that no redundant data will be discarded.
  318. n, err := io.ReadFull(r, b[:5])
  319. if err != nil {
  320. return nil, err
  321. }
  322. header := &UDPHeader{
  323. Rsv: binary.BigEndian.Uint16(b[:2]),
  324. Frag: b[2],
  325. }
  326. atype := b[3]
  327. hlen := 0
  328. switch atype {
  329. case ipV4:
  330. hlen = 10
  331. case ipV6:
  332. hlen = 22
  333. case domainName:
  334. hlen = 7 + int(b[4])
  335. default:
  336. return nil, errors.New("addr not support")
  337. }
  338. dlen := int(header.Rsv)
  339. if dlen == 0 { // standard SOCKS5 UDP datagram
  340. extra, err := ioutil.ReadAll(r) // we assume no redundant data
  341. if err != nil {
  342. return nil, err
  343. }
  344. copy(b[n:], extra)
  345. n += len(extra) // total length
  346. dlen = n - hlen // data length
  347. } else { // extended feature, for UDP over TCP, using reserved field as data length
  348. if _, err := io.ReadFull(r, b[n:hlen+dlen]); err != nil {
  349. return nil, err
  350. }
  351. n = hlen + dlen
  352. }
  353. header.Addr = new(Addr)
  354. if err := header.Addr.Decode(b[3:hlen]); err != nil {
  355. return nil, err
  356. }
  357. data := make([]byte, dlen)
  358. copy(data, b[hlen:n])
  359. d := &UDPDatagram{
  360. Header: header,
  361. Data: data,
  362. }
  363. return d, nil
  364. }
  365. func NewUDPDatagram(header *UDPHeader, data []byte) *UDPDatagram {
  366. return &UDPDatagram{
  367. Header: header,
  368. Data: data,
  369. }
  370. }
  371. func (d *UDPDatagram) Write(w io.Writer) error {
  372. h := d.Header
  373. if h == nil {
  374. h = &UDPHeader{}
  375. }
  376. buf := bytes.Buffer{}
  377. if err := h.Write(&buf); err != nil {
  378. return err
  379. }
  380. if _, err := buf.Write(d.Data); err != nil {
  381. return err
  382. }
  383. _, err := buf.WriteTo(w)
  384. return err
  385. }
  386. func ToSocksAddr(addr net.Addr) *Addr {
  387. host := "0.0.0.0"
  388. port := 0
  389. if addr != nil {
  390. h, p, _ := net.SplitHostPort(addr.String())
  391. host = h
  392. port, _ = strconv.Atoi(p)
  393. }
  394. return &Addr{
  395. Type: ipV4,
  396. Host: host,
  397. Port: uint16(port),
  398. }
  399. }