address.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. package protocol
  2. import (
  3. "io"
  4. "unsafe"
  5. "v2ray.com/core/common"
  6. "v2ray.com/core/common/buf"
  7. "v2ray.com/core/common/net"
  8. "v2ray.com/core/common/serial"
  9. "v2ray.com/core/common/stack"
  10. )
  11. type AddressOption func(*option)
  12. func PortThenAddress() AddressOption {
  13. return func(p *option) {
  14. p.portFirst = true
  15. }
  16. }
  17. func AddressFamilyByte(b byte, f net.AddressFamily) AddressOption {
  18. if b >= 16 {
  19. panic("address family byte too big")
  20. }
  21. return func(p *option) {
  22. p.addrTypeMap[b] = f
  23. p.addrByteMap[f] = b
  24. }
  25. }
  26. type AddressTypeParser func(byte) byte
  27. func WithAddressTypeParser(atp AddressTypeParser) AddressOption {
  28. return func(p *option) {
  29. p.typeParser = atp
  30. }
  31. }
  32. type AddressSerializer interface {
  33. ReadAddressPort(buffer *buf.Buffer, input io.Reader) (net.Address, net.Port, error)
  34. WriteAddressPort(writer io.Writer, addr net.Address, port net.Port) error
  35. }
  36. const afInvalid = 255
  37. type option struct {
  38. addrTypeMap [16]net.AddressFamily
  39. addrByteMap [16]byte
  40. portFirst bool
  41. typeParser AddressTypeParser
  42. }
  43. // NewAddressParser creates a new AddressParser
  44. func NewAddressParser(options ...AddressOption) AddressSerializer {
  45. var o option
  46. for i := range o.addrByteMap {
  47. o.addrByteMap[i] = afInvalid
  48. }
  49. for i := range o.addrTypeMap {
  50. o.addrTypeMap[i] = net.AddressFamily(afInvalid)
  51. }
  52. for _, opt := range options {
  53. opt(&o)
  54. }
  55. ap := &addressParser{
  56. addrByteMap: o.addrByteMap,
  57. addrTypeMap: o.addrTypeMap,
  58. }
  59. if o.typeParser != nil {
  60. ap.typeParser = o.typeParser
  61. }
  62. if o.portFirst {
  63. return portFirstAddressParser{ap: ap}
  64. }
  65. return portLastAddressParser{ap: ap}
  66. }
  67. type portFirstAddressParser struct {
  68. ap *addressParser
  69. }
  70. func (p portFirstAddressParser) ReadAddressPort(buffer *buf.Buffer, input io.Reader) (net.Address, net.Port, error) {
  71. if buffer == nil {
  72. buffer = buf.New()
  73. defer buffer.Release()
  74. }
  75. port, err := readPort(buffer, input)
  76. if err != nil {
  77. return nil, 0, err
  78. }
  79. addr, err := p.ap.readAddress(buffer, input)
  80. if err != nil {
  81. return nil, 0, err
  82. }
  83. return addr, port, nil
  84. }
  85. func (p portFirstAddressParser) WriteAddressPort(writer io.Writer, addr net.Address, port net.Port) error {
  86. if err := writePort(writer, port); err != nil {
  87. return err
  88. }
  89. return p.ap.writeAddress(writer, addr)
  90. }
  91. type portLastAddressParser struct {
  92. ap *addressParser
  93. }
  94. func (p portLastAddressParser) ReadAddressPort(buffer *buf.Buffer, input io.Reader) (net.Address, net.Port, error) {
  95. if buffer == nil {
  96. buffer = buf.New()
  97. defer buffer.Release()
  98. }
  99. addr, err := p.ap.readAddress(buffer, input)
  100. if err != nil {
  101. return nil, 0, err
  102. }
  103. port, err := readPort(buffer, input)
  104. if err != nil {
  105. return nil, 0, err
  106. }
  107. return addr, port, nil
  108. }
  109. func (p portLastAddressParser) WriteAddressPort(writer io.Writer, addr net.Address, port net.Port) error {
  110. if err := p.ap.writeAddress(writer, addr); err != nil {
  111. return err
  112. }
  113. return writePort(writer, port)
  114. }
  115. func readPort(b *buf.Buffer, reader io.Reader) (net.Port, error) {
  116. if _, err := b.ReadFullFrom(reader, 2); err != nil {
  117. return 0, err
  118. }
  119. return net.PortFromBytes(b.BytesFrom(-2)), nil
  120. }
  121. func writePort(writer io.Writer, port net.Port) error {
  122. return common.Error2(serial.WriteUint16(writer, port.Value()))
  123. }
  124. func maybeIPPrefix(b byte) bool {
  125. return b == '[' || (b >= '0' && b <= '9')
  126. }
  127. func isValidDomain(d string) bool {
  128. for _, c := range d {
  129. if !((c >= '0' && c <= '9') || (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z') || c == '-' || c == '.' || c == '_') {
  130. return false
  131. }
  132. }
  133. return true
  134. }
  135. type addressParser struct {
  136. addrTypeMap [16]net.AddressFamily
  137. addrByteMap [16]byte
  138. typeParser AddressTypeParser
  139. }
  140. func (p *addressParser) readAddress(b *buf.Buffer, reader io.Reader) (net.Address, error) {
  141. if _, err := b.ReadFullFrom(reader, 1); err != nil {
  142. return nil, err
  143. }
  144. addrType := b.Byte(b.Len() - 1)
  145. if p.typeParser != nil {
  146. addrType = p.typeParser(addrType)
  147. }
  148. if addrType >= 16 {
  149. return nil, newError("unknown address type: ", addrType)
  150. }
  151. addrFamily := p.addrTypeMap[addrType]
  152. if addrFamily == net.AddressFamily(afInvalid) {
  153. return nil, newError("unknown address type: ", addrType)
  154. }
  155. switch addrFamily {
  156. case net.AddressFamilyIPv4:
  157. if _, err := b.ReadFullFrom(reader, 4); err != nil {
  158. return nil, err
  159. }
  160. return net.IPAddress(b.BytesFrom(-4)), nil
  161. case net.AddressFamilyIPv6:
  162. if _, err := b.ReadFullFrom(reader, 16); err != nil {
  163. return nil, err
  164. }
  165. return net.IPAddress(b.BytesFrom(-16)), nil
  166. case net.AddressFamilyDomain:
  167. if _, err := b.ReadFullFrom(reader, 1); err != nil {
  168. return nil, err
  169. }
  170. domainLength := int32(b.Byte(b.Len() - 1))
  171. if _, err := b.ReadFullFrom(reader, domainLength); err != nil {
  172. return nil, err
  173. }
  174. domain := string(b.BytesFrom(-domainLength))
  175. if maybeIPPrefix(domain[0]) {
  176. addr := net.ParseAddress(domain)
  177. if addr.Family().IsIPv4() || addr.Family().IsIPv6() {
  178. return addr, nil
  179. }
  180. }
  181. if !isValidDomain(domain) {
  182. return nil, newError("invalid domain name: ", domain)
  183. }
  184. return net.DomainAddress(domain), nil
  185. default:
  186. panic("impossible case")
  187. }
  188. }
  189. func (p *addressParser) writeAddress(writer io.Writer, address net.Address) error {
  190. tb := p.addrByteMap[address.Family()]
  191. if tb == afInvalid {
  192. return newError("unknown address family", address.Family())
  193. }
  194. switch address.Family() {
  195. case net.AddressFamilyIPv4, net.AddressFamilyIPv6:
  196. var bytes stack.TwoBytes
  197. s := bytes[:1]
  198. s[0] = tb
  199. p := uintptr(unsafe.Pointer(&s))
  200. v := (*[]byte)(unsafe.Pointer(p))
  201. if _, err := writer.Write(*v); err != nil {
  202. return err
  203. }
  204. if _, err := writer.Write(address.IP()); err != nil {
  205. return err
  206. }
  207. case net.AddressFamilyDomain:
  208. domain := address.Domain()
  209. if isDomainTooLong(domain) {
  210. return newError("Super long domain is not supported: ", domain)
  211. }
  212. var bytes stack.TwoBytes
  213. s := bytes[:]
  214. s[0] = tb
  215. s[1] = byte(len(domain))
  216. p := uintptr(unsafe.Pointer(&s))
  217. v := (*[]byte)(unsafe.Pointer(p))
  218. if _, err := writer.Write(*v); err != nil {
  219. return err
  220. }
  221. if _, err := io.WriteString(writer, domain); err != nil {
  222. return err
  223. }
  224. default:
  225. panic("Unknown family type.")
  226. }
  227. return nil
  228. }