|
|
@@ -2,7 +2,6 @@ package net
|
|
|
|
|
|
import (
|
|
|
"net"
|
|
|
- "strconv"
|
|
|
|
|
|
"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, not both. This interface doesn't resolve IP address for a given domain.
|
|
|
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
|
|
|
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 {
|
|
|
switch len(ip) {
|
|
|
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:
|
|
|
if allZeros(ip[0:10]) && ip[10] == 0xff && ip[11] == 0xff {
|
|
|
return IPAddress(ip[12:16], port)
|
|
|
}
|
|
|
- return IPv6Address{
|
|
|
- PortAddress: PortAddress{port: port},
|
|
|
+ return &IPv6Address{
|
|
|
+ port: Port(port),
|
|
|
ip: [16]byte{
|
|
|
ip[0], ip[1], ip[2], ip[3],
|
|
|
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.
|
|
|
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 {
|
|
|
- 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[:])
|
|
|
}
|
|
|
|
|
|
-func (addr IPv4Address) Domain() string {
|
|
|
+func (this *IPv4Address) Port() Port {
|
|
|
+ return this.port
|
|
|
+}
|
|
|
+
|
|
|
+func (addr *IPv4Address) Domain() string {
|
|
|
panic("Calling Domain() on an IPv4Address.")
|
|
|
}
|
|
|
|
|
|
-func (addr IPv4Address) IsIPv4() bool {
|
|
|
+func (addr *IPv4Address) IsIPv4() bool {
|
|
|
return true
|
|
|
}
|
|
|
|
|
|
-func (addr IPv4Address) IsIPv6() bool {
|
|
|
+func (addr *IPv4Address) IsIPv6() bool {
|
|
|
return false
|
|
|
}
|
|
|
|
|
|
-func (addr IPv4Address) IsDomain() bool {
|
|
|
+func (addr *IPv4Address) IsDomain() bool {
|
|
|
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 {
|
|
|
- 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[:])
|
|
|
}
|
|
|
|
|
|
-func (addr IPv6Address) Domain() string {
|
|
|
+func (this *IPv6Address) Port() Port {
|
|
|
+ return this.port
|
|
|
+}
|
|
|
+
|
|
|
+func (addr *IPv6Address) Domain() string {
|
|
|
panic("Calling Domain() on an IPv6Address.")
|
|
|
}
|
|
|
|
|
|
-func (addr IPv6Address) IsIPv4() bool {
|
|
|
+func (addr *IPv6Address) IsIPv4() bool {
|
|
|
return false
|
|
|
}
|
|
|
|
|
|
-func (addr IPv6Address) IsIPv6() bool {
|
|
|
+func (addr *IPv6Address) IsIPv6() bool {
|
|
|
return true
|
|
|
}
|
|
|
|
|
|
-func (addr IPv6Address) IsDomain() bool {
|
|
|
+func (addr *IPv6Address) IsDomain() bool {
|
|
|
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 {
|
|
|
- PortAddress
|
|
|
+ port Port
|
|
|
domain string
|
|
|
}
|
|
|
|
|
|
-func (addr DomainAddressImpl) IP() net.IP {
|
|
|
+func (addr *DomainAddressImpl) IP() net.IP {
|
|
|
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
|
|
|
}
|
|
|
|
|
|
-func (addr DomainAddressImpl) IsIPv4() bool {
|
|
|
+func (addr *DomainAddressImpl) IsIPv4() bool {
|
|
|
return false
|
|
|
}
|
|
|
|
|
|
-func (addr DomainAddressImpl) IsIPv6() bool {
|
|
|
+func (addr *DomainAddressImpl) IsIPv6() bool {
|
|
|
return false
|
|
|
}
|
|
|
|
|
|
-func (addr DomainAddressImpl) IsDomain() bool {
|
|
|
+func (addr *DomainAddressImpl) IsDomain() bool {
|
|
|
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()
|
|
|
}
|