address.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. package net
  2. import (
  3. "bytes"
  4. "context"
  5. "net"
  6. "strings"
  7. "github.com/xtls/xray-core/common/errors"
  8. )
  9. var (
  10. // LocalHostIP is a constant value for localhost IP in IPv4.
  11. LocalHostIP = IPAddress([]byte{127, 0, 0, 1})
  12. // AnyIP is a constant value for any IP in IPv4.
  13. AnyIP = IPAddress([]byte{0, 0, 0, 0})
  14. // LocalHostDomain is a constant value for localhost domain.
  15. LocalHostDomain = DomainAddress("localhost")
  16. // LocalHostIPv6 is a constant value for localhost IP in IPv6.
  17. LocalHostIPv6 = IPAddress([]byte{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1})
  18. // AnyIPv6 is a constant value for any IP in IPv6.
  19. AnyIPv6 = IPAddress([]byte{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0})
  20. )
  21. // AddressFamily is the type of address.
  22. type AddressFamily byte
  23. const (
  24. // AddressFamilyIPv4 represents address as IPv4
  25. AddressFamilyIPv4 = AddressFamily(0)
  26. // AddressFamilyIPv6 represents address as IPv6
  27. AddressFamilyIPv6 = AddressFamily(1)
  28. // AddressFamilyDomain represents address as Domain
  29. AddressFamilyDomain = AddressFamily(2)
  30. )
  31. // IsIPv4 returns true if current AddressFamily is IPv4.
  32. func (af AddressFamily) IsIPv4() bool {
  33. return af == AddressFamilyIPv4
  34. }
  35. // IsIPv6 returns true if current AddressFamily is IPv6.
  36. func (af AddressFamily) IsIPv6() bool {
  37. return af == AddressFamilyIPv6
  38. }
  39. // IsIP returns true if current AddressFamily is IPv6 or IPv4.
  40. func (af AddressFamily) IsIP() bool {
  41. return af == AddressFamilyIPv4 || af == AddressFamilyIPv6
  42. }
  43. // IsDomain returns true if current AddressFamily is Domain.
  44. func (af AddressFamily) IsDomain() bool {
  45. return af == AddressFamilyDomain
  46. }
  47. // Address represents a network address to be communicated with. It may be an IP address or domain
  48. // address, not both. This interface doesn't resolve IP address for a given domain.
  49. type Address interface {
  50. IP() net.IP // IP of this Address
  51. Domain() string // Domain of this Address
  52. Family() AddressFamily
  53. String() string // String representation of this Address
  54. }
  55. func isAlphaNum(c byte) bool {
  56. return (c >= '0' && c <= '9') || (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')
  57. }
  58. // ParseAddress parses a string into an Address. The return value will be an IPAddress when
  59. // the string is in the form of IPv4 or IPv6 address, or a DomainAddress otherwise.
  60. func ParseAddress(addr string) Address {
  61. // Handle IPv6 address in form as "[2001:4860:0:2001::68]"
  62. lenAddr := len(addr)
  63. if lenAddr > 0 && addr[0] == '[' && addr[lenAddr-1] == ']' {
  64. addr = addr[1 : lenAddr-1]
  65. lenAddr -= 2
  66. }
  67. if lenAddr > 0 && (!isAlphaNum(addr[0]) || !isAlphaNum(addr[len(addr)-1])) {
  68. addr = strings.TrimSpace(addr)
  69. }
  70. ip := net.ParseIP(addr)
  71. if ip != nil {
  72. return IPAddress(ip)
  73. }
  74. return DomainAddress(addr)
  75. }
  76. var bytes0 = []byte{0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
  77. // IPAddress creates an Address with given IP.
  78. func IPAddress(ip []byte) Address {
  79. switch len(ip) {
  80. case net.IPv4len:
  81. var addr ipv4Address = [4]byte{ip[0], ip[1], ip[2], ip[3]}
  82. return addr
  83. case net.IPv6len:
  84. if bytes.Equal(ip[:10], bytes0) && ip[10] == 0xff && ip[11] == 0xff {
  85. return IPAddress(ip[12:16])
  86. }
  87. var addr ipv6Address = [16]byte{
  88. ip[0], ip[1], ip[2], ip[3],
  89. ip[4], ip[5], ip[6], ip[7],
  90. ip[8], ip[9], ip[10], ip[11],
  91. ip[12], ip[13], ip[14], ip[15],
  92. }
  93. return addr
  94. default:
  95. errors.LogError(context.Background(), "invalid IP format: ", ip)
  96. return nil
  97. }
  98. }
  99. // DomainAddress creates an Address with given domain.
  100. // This is an internal function that forcibly converts a string to domain.
  101. // It's mainly used in test files and mux.
  102. // Unless you have a specific reason, use net.ParseAddress instead,
  103. // as this function does not check whether the input is an IP address.
  104. // Otherwise, you will get strange results like domain: 1.1.1.1
  105. func DomainAddress(domain string) Address {
  106. return domainAddress(domain)
  107. }
  108. type ipv4Address [4]byte
  109. func (a ipv4Address) IP() net.IP {
  110. return net.IP(a[:])
  111. }
  112. func (ipv4Address) Domain() string {
  113. panic("Calling Domain() on an IPv4Address.")
  114. }
  115. func (ipv4Address) Family() AddressFamily {
  116. return AddressFamilyIPv4
  117. }
  118. func (a ipv4Address) String() string {
  119. return a.IP().String()
  120. }
  121. type ipv6Address [16]byte
  122. func (a ipv6Address) IP() net.IP {
  123. return net.IP(a[:])
  124. }
  125. func (ipv6Address) Domain() string {
  126. panic("Calling Domain() on an IPv6Address.")
  127. }
  128. func (ipv6Address) Family() AddressFamily {
  129. return AddressFamilyIPv6
  130. }
  131. func (a ipv6Address) String() string {
  132. return "[" + a.IP().String() + "]"
  133. }
  134. type domainAddress string
  135. func (domainAddress) IP() net.IP {
  136. panic("Calling IP() on a DomainAddress.")
  137. }
  138. func (a domainAddress) Domain() string {
  139. return string(a)
  140. }
  141. func (domainAddress) Family() AddressFamily {
  142. return AddressFamilyDomain
  143. }
  144. func (a domainAddress) String() string {
  145. return a.Domain()
  146. }
  147. // AsAddress translates IPOrDomain to Address.
  148. func (d *IPOrDomain) AsAddress() Address {
  149. if d == nil {
  150. return nil
  151. }
  152. switch addr := d.Address.(type) {
  153. case *IPOrDomain_Ip:
  154. return IPAddress(addr.Ip)
  155. case *IPOrDomain_Domain:
  156. return DomainAddress(addr.Domain)
  157. }
  158. panic("Common|Net: Invalid address.")
  159. }
  160. // NewIPOrDomain translates Address to IPOrDomain
  161. func NewIPOrDomain(addr Address) *IPOrDomain {
  162. switch addr.Family() {
  163. case AddressFamilyDomain:
  164. return &IPOrDomain{
  165. Address: &IPOrDomain_Domain{
  166. Domain: addr.Domain(),
  167. },
  168. }
  169. case AddressFamilyIPv4, AddressFamilyIPv6:
  170. return &IPOrDomain{
  171. Address: &IPOrDomain_Ip{
  172. Ip: addr.IP(),
  173. },
  174. }
  175. default:
  176. panic("Unknown Address type.")
  177. }
  178. }