Documentation ¶
Overview ¶
Package dns is a generated protocol buffer package.
It is generated from these files:
v2ray.com/core/app/dns/config.proto
It has these top-level messages:
Config
Index ¶
- Constants
- type ARecord
- type CacheServer
- type CacheServerFactory
- type Config
- func (*Config) Descriptor() ([]byte, []int)
- func (m *Config) GetHosts() map[string]*v2ray_core_common_net.IPOrDomain
- func (v *Config) GetInternalHosts() map[string]net.IP
- func (m *Config) GetNameServers() []*v2ray_core_common_net2.Endpoint
- func (*Config) ProtoMessage()
- func (m *Config) Reset()
- func (m *Config) String() string
- type DomainRecord
- type LocalNameServer
- type NameServer
- type PendingRequest
- type Server
- type UDPNameServer
- func (v *UDPNameServer) AssignUnusedID(response chan<- *ARecord) uint16
- func (v *UDPNameServer) BuildQueryA(domain string, id uint16) *buf.Buffer
- func (v *UDPNameServer) Cleanup()
- func (v *UDPNameServer) DispatchQuery(payload *buf.Buffer)
- func (v *UDPNameServer) HandleResponse(dest v2net.Destination, payload *buf.Buffer)
- func (v *UDPNameServer) QueryA(domain string) <-chan *ARecord
Constants ¶
View Source
const ( DefaultTTL = uint32(3600) CleanupInterval = time.Second * 120 CleanupThreshold = 512 )
View Source
const (
APP_ID = app.ID(2)
)
View Source
const (
QueryTimeout = time.Second * 8
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CacheServer ¶
func NewCacheServer ¶
func NewCacheServer(space app.Space, config *Config) *CacheServer
func (*CacheServer) GetCached ¶
func (v *CacheServer) GetCached(domain string) []net.IP
Private: Visible for testing.
func (*CacheServer) Release ¶
func (v *CacheServer) Release()
type CacheServerFactory ¶
type CacheServerFactory struct{}
func (CacheServerFactory) AppId ¶
func (v CacheServerFactory) AppId() app.ID
func (CacheServerFactory) Create ¶
func (v CacheServerFactory) Create(space app.Space, config interface{}) (app.Application, error)
type Config ¶
type Config struct { // Nameservers used by this DNS. Only traditional UDP servers are support at the moment. // A special value 'localhost' as a domain address can be set to use DNS on local system. NameServers []*v2ray_core_common_net2.Endpoint `protobuf:"bytes,1,rep,name=NameServers" json:"NameServers,omitempty"` // Static hosts. Domain to IP. Hosts map[string]*v2ray_core_common_net.IPOrDomain `` /* 130-byte string literal not displayed */ }
func (*Config) Descriptor ¶
func (*Config) GetHosts ¶
func (m *Config) GetHosts() map[string]*v2ray_core_common_net.IPOrDomain
func (*Config) GetNameServers ¶
func (m *Config) GetNameServers() []*v2ray_core_common_net2.Endpoint
func (*Config) ProtoMessage ¶
func (*Config) ProtoMessage()
type DomainRecord ¶
type DomainRecord struct {
A *ARecord
}
type LocalNameServer ¶
type LocalNameServer struct { }
func (*LocalNameServer) QueryA ¶
func (v *LocalNameServer) QueryA(domain string) <-chan *ARecord
type NameServer ¶
type PendingRequest ¶
type PendingRequest struct {
// contains filtered or unexported fields
}
type UDPNameServer ¶
func NewUDPNameServer ¶
func NewUDPNameServer(address v2net.Destination, dispatcher dispatcher.PacketDispatcher) *UDPNameServer
func (*UDPNameServer) AssignUnusedID ¶
func (v *UDPNameServer) AssignUnusedID(response chan<- *ARecord) uint16
Private: Visible for testing.
func (*UDPNameServer) BuildQueryA ¶
func (v *UDPNameServer) BuildQueryA(domain string, id uint16) *buf.Buffer
func (*UDPNameServer) DispatchQuery ¶
func (v *UDPNameServer) DispatchQuery(payload *buf.Buffer)
func (*UDPNameServer) HandleResponse ¶
func (v *UDPNameServer) HandleResponse(dest v2net.Destination, payload *buf.Buffer)
Private: Visible for testing.
func (*UDPNameServer) QueryA ¶
func (v *UDPNameServer) QueryA(domain string) <-chan *ARecord
Click to show internal directories.
Click to hide internal directories.