1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2024-07-05 21:45:24 +00:00
v2fly/features/dns/client.go

60 lines
1.3 KiB
Go
Raw Normal View History

2018-10-11 20:34:31 +00:00
package dns
import (
"v2ray.com/core/common/errors"
2018-10-11 21:09:15 +00:00
"v2ray.com/core/common/net"
"v2ray.com/core/common/serial"
2018-10-11 20:34:31 +00:00
"v2ray.com/core/features"
)
// Client is a V2Ray feature for querying DNS information.
2018-12-03 21:44:42 +00:00
//
// v2ray:api:stable
2018-10-11 20:34:31 +00:00
type Client interface {
features.Feature
2018-10-12 21:57:56 +00:00
// LookupIP returns IP address for the given domain. IPs may contain IPv4 and/or IPv6 addresses.
LookupIP(domain string) ([]net.IP, error)
2018-10-12 21:57:56 +00:00
}
2018-10-21 08:27:13 +00:00
// IPv4Lookup is an optional feature for querying IPv4 addresses only.
2018-12-03 21:44:42 +00:00
//
// v2ray:api:beta
type IPv4Lookup interface {
LookupIPv4(domain string) ([]net.IP, error)
2018-10-21 08:27:13 +00:00
}
// IPv6Lookup is an optional feature for querying IPv6 addresses only.
2018-12-03 21:44:42 +00:00
//
// v2ray:api:beta
type IPv6Lookup interface {
LookupIPv6(domain string) ([]net.IP, error)
}
2018-10-21 08:27:13 +00:00
// ClientType returns the type of Client interface. Can be used for implementing common.HasType.
2018-12-03 21:44:42 +00:00
//
// v2ray:api:beta
func ClientType() interface{} {
return (*Client)(nil)
2018-10-21 08:27:13 +00:00
}
// ErrEmptyResponse indicates that DNS query succeeded but no answer was returned.
var ErrEmptyResponse = errors.New("empty response")
type RCodeError uint16
func (e RCodeError) Error() string {
return serial.Concat("rcode: ", uint16(e))
}
func RCodeFromError(err error) uint16 {
if err == nil {
return 0
}
cause := errors.Cause(err)
if r, ok := cause.(RCodeError); ok {
return uint16(r)
}
return 0
}