address.go 4.7 KB

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