|  | @@ -2,7 +2,6 @@ package net
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  import (
 |  |  import (
 | 
											
												
													
														|  |  	"net"
 |  |  	"net"
 | 
											
												
													
														|  | -	"strconv"
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	"github.com/v2ray/v2ray-core/common/log"
 |  |  	"github.com/v2ray/v2ray-core/common/log"
 | 
											
												
													
														|  |  )
 |  |  )
 | 
											
										
											
												
													
														|  | @@ -10,10 +9,9 @@ import (
 | 
											
												
													
														|  |  // Address represents a network address to be communicated with. It may be an IP address or domain
 |  |  // Address represents a network address to be communicated with. It may be an IP address or domain
 | 
											
												
													
														|  |  // address, not both. This interface doesn't resolve IP address for a given domain.
 |  |  // address, not both. This interface doesn't resolve IP address for a given domain.
 | 
											
												
													
														|  |  type Address interface {
 |  |  type Address interface {
 | 
											
												
													
														|  | -	IP() net.IP        // IP of this Address
 |  | 
 | 
											
												
													
														|  | -	Domain() string    // Domain of this Address
 |  | 
 | 
											
												
													
														|  | -	Port() uint16      // Port of this Address
 |  | 
 | 
											
												
													
														|  | -	PortBytes() []byte // Port in bytes, network byte order
 |  | 
 | 
											
												
													
														|  | 
 |  | +	IP() net.IP     // IP of this Address
 | 
											
												
													
														|  | 
 |  | +	Domain() string // Domain of this Address
 | 
											
												
													
														|  | 
 |  | +	Port() Port     // Port of this Address
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	IsIPv4() bool   // True if this Address is an IPv4 address
 |  |  	IsIPv4() bool   // True if this Address is an IPv4 address
 | 
											
												
													
														|  |  	IsIPv6() bool   // True if this Address is an IPv6 address
 |  |  	IsIPv6() bool   // True if this Address is an IPv6 address
 | 
											
										
											
												
													
														|  | @@ -35,16 +33,16 @@ func allZeros(data []byte) bool {
 | 
											
												
													
														|  |  func IPAddress(ip []byte, port uint16) Address {
 |  |  func IPAddress(ip []byte, port uint16) Address {
 | 
											
												
													
														|  |  	switch len(ip) {
 |  |  	switch len(ip) {
 | 
											
												
													
														|  |  	case net.IPv4len:
 |  |  	case net.IPv4len:
 | 
											
												
													
														|  | -		return IPv4Address{
 |  | 
 | 
											
												
													
														|  | -			PortAddress: PortAddress{port: port},
 |  | 
 | 
											
												
													
														|  | -			ip:          [4]byte{ip[0], ip[1], ip[2], ip[3]},
 |  | 
 | 
											
												
													
														|  | 
 |  | +		return &IPv4Address{
 | 
											
												
													
														|  | 
 |  | +			port: Port(port),
 | 
											
												
													
														|  | 
 |  | +			ip:   [4]byte{ip[0], ip[1], ip[2], ip[3]},
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  |  	case net.IPv6len:
 |  |  	case net.IPv6len:
 | 
											
												
													
														|  |  		if allZeros(ip[0:10]) && ip[10] == 0xff && ip[11] == 0xff {
 |  |  		if allZeros(ip[0:10]) && ip[10] == 0xff && ip[11] == 0xff {
 | 
											
												
													
														|  |  			return IPAddress(ip[12:16], port)
 |  |  			return IPAddress(ip[12:16], port)
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  | -		return IPv6Address{
 |  | 
 | 
											
												
													
														|  | -			PortAddress: PortAddress{port: port},
 |  | 
 | 
											
												
													
														|  | 
 |  | +		return &IPv6Address{
 | 
											
												
													
														|  | 
 |  | +			port: Port(port),
 | 
											
												
													
														|  |  			ip: [16]byte{
 |  |  			ip: [16]byte{
 | 
											
												
													
														|  |  				ip[0], ip[1], ip[2], ip[3],
 |  |  				ip[0], ip[1], ip[2], ip[3],
 | 
											
												
													
														|  |  				ip[4], ip[5], ip[6], ip[7],
 |  |  				ip[4], ip[5], ip[6], ip[7],
 | 
											
										
											
												
													
														|  | @@ -60,107 +58,107 @@ func IPAddress(ip []byte, port uint16) Address {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // DomainAddress creates an Address with given domain and port.
 |  |  // DomainAddress creates an Address with given domain and port.
 | 
											
												
													
														|  |  func DomainAddress(domain string, port uint16) Address {
 |  |  func DomainAddress(domain string, port uint16) Address {
 | 
											
												
													
														|  | -	return DomainAddressImpl{
 |  | 
 | 
											
												
													
														|  | -		domain:      domain,
 |  | 
 | 
											
												
													
														|  | -		PortAddress: PortAddress{port: port},
 |  | 
 | 
											
												
													
														|  | 
 |  | +	return &DomainAddressImpl{
 | 
											
												
													
														|  | 
 |  | +		domain: domain,
 | 
											
												
													
														|  | 
 |  | +		port:   Port(port),
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -type PortAddress struct {
 |  | 
 | 
											
												
													
														|  | -	port uint16
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -func (addr PortAddress) Port() uint16 {
 |  | 
 | 
											
												
													
														|  | -	return addr.port
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -func (addr PortAddress) PortBytes() []byte {
 |  | 
 | 
											
												
													
														|  | -	return []byte{byte(addr.port >> 8), byte(addr.port)}
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |  type IPv4Address struct {
 |  |  type IPv4Address struct {
 | 
											
												
													
														|  | -	PortAddress
 |  | 
 | 
											
												
													
														|  | -	ip [4]byte
 |  | 
 | 
											
												
													
														|  | 
 |  | +	port Port
 | 
											
												
													
														|  | 
 |  | +	ip   [4]byte
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv4Address) IP() net.IP {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv4Address) IP() net.IP {
 | 
											
												
													
														|  |  	return net.IP(addr.ip[:])
 |  |  	return net.IP(addr.ip[:])
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv4Address) Domain() string {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (this *IPv4Address) Port() Port {
 | 
											
												
													
														|  | 
 |  | +	return this.port
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv4Address) Domain() string {
 | 
											
												
													
														|  |  	panic("Calling Domain() on an IPv4Address.")
 |  |  	panic("Calling Domain() on an IPv4Address.")
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv4Address) IsIPv4() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv4Address) IsIPv4() bool {
 | 
											
												
													
														|  |  	return true
 |  |  	return true
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv4Address) IsIPv6() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv4Address) IsIPv6() bool {
 | 
											
												
													
														|  |  	return false
 |  |  	return false
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv4Address) IsDomain() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv4Address) IsDomain() bool {
 | 
											
												
													
														|  |  	return false
 |  |  	return false
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv4Address) String() string {
 |  | 
 | 
											
												
													
														|  | -	return addr.IP().String() + ":" + strconv.Itoa(int(addr.PortAddress.port))
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (this *IPv4Address) String() string {
 | 
											
												
													
														|  | 
 |  | +	return this.IP().String() + ":" + this.port.String()
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  type IPv6Address struct {
 |  |  type IPv6Address struct {
 | 
											
												
													
														|  | -	PortAddress
 |  | 
 | 
											
												
													
														|  | -	ip [16]byte
 |  | 
 | 
											
												
													
														|  | 
 |  | +	port Port
 | 
											
												
													
														|  | 
 |  | +	ip   [16]byte
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv6Address) IP() net.IP {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv6Address) IP() net.IP {
 | 
											
												
													
														|  |  	return net.IP(addr.ip[:])
 |  |  	return net.IP(addr.ip[:])
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv6Address) Domain() string {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (this *IPv6Address) Port() Port {
 | 
											
												
													
														|  | 
 |  | +	return this.port
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv6Address) Domain() string {
 | 
											
												
													
														|  |  	panic("Calling Domain() on an IPv6Address.")
 |  |  	panic("Calling Domain() on an IPv6Address.")
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv6Address) IsIPv4() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv6Address) IsIPv4() bool {
 | 
											
												
													
														|  |  	return false
 |  |  	return false
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv6Address) IsIPv6() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv6Address) IsIPv6() bool {
 | 
											
												
													
														|  |  	return true
 |  |  	return true
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv6Address) IsDomain() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *IPv6Address) IsDomain() bool {
 | 
											
												
													
														|  |  	return false
 |  |  	return false
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr IPv6Address) String() string {
 |  | 
 | 
											
												
													
														|  | -	return "[" + addr.IP().String() + "]:" + strconv.Itoa(int(addr.PortAddress.port))
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (this *IPv6Address) String() string {
 | 
											
												
													
														|  | 
 |  | +	return "[" + this.IP().String() + "]:" + this.port.String()
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  type DomainAddressImpl struct {
 |  |  type DomainAddressImpl struct {
 | 
											
												
													
														|  | -	PortAddress
 |  | 
 | 
											
												
													
														|  | 
 |  | +	port   Port
 | 
											
												
													
														|  |  	domain string
 |  |  	domain string
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr DomainAddressImpl) IP() net.IP {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *DomainAddressImpl) IP() net.IP {
 | 
											
												
													
														|  |  	panic("Calling IP() on a DomainAddress.")
 |  |  	panic("Calling IP() on a DomainAddress.")
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr DomainAddressImpl) Domain() string {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (this *DomainAddressImpl) Port() Port {
 | 
											
												
													
														|  | 
 |  | +	return this.port
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +func (addr *DomainAddressImpl) Domain() string {
 | 
											
												
													
														|  |  	return addr.domain
 |  |  	return addr.domain
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr DomainAddressImpl) IsIPv4() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *DomainAddressImpl) IsIPv4() bool {
 | 
											
												
													
														|  |  	return false
 |  |  	return false
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr DomainAddressImpl) IsIPv6() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *DomainAddressImpl) IsIPv6() bool {
 | 
											
												
													
														|  |  	return false
 |  |  	return false
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr DomainAddressImpl) IsDomain() bool {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (addr *DomainAddressImpl) IsDomain() bool {
 | 
											
												
													
														|  |  	return true
 |  |  	return true
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (addr DomainAddressImpl) String() string {
 |  | 
 | 
											
												
													
														|  | -	return addr.domain + ":" + strconv.Itoa(int(addr.PortAddress.port))
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (this *DomainAddressImpl) String() string {
 | 
											
												
													
														|  | 
 |  | +	return this.domain + ":" + this.port.String()
 | 
											
												
													
														|  |  }
 |  |  }
 |