本文整理匯總了Python中twisted.names.dns.PORT屬性的典型用法代碼示例。如果您正苦於以下問題:Python dns.PORT屬性的具體用法?Python dns.PORT怎麽用?Python dns.PORT使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類twisted.names.dns
的用法示例。
在下文中一共展示了dns.PORT屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: opt_secondary
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def opt_secondary(self, ip_domain):
"""Act as secondary for the specified domain, performing
zone transfers from the specified IP (IP/domain)
"""
args = ip_domain.split('/', 1)
if len(args) != 2:
raise usage.UsageError("Argument must be of the form IP[:port]/domain")
address = args[0].split(':')
if len(address) == 1:
address = (address[0], dns.PORT)
else:
try:
port = int(address[1])
except ValueError:
raise usage.UsageError(
"Specify an integer port number, not %r" % (address[1],))
address = (address[0], port)
self.secondaries.append((address, [args[1]]))
示例2: parseConfig
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def parseConfig(self, resolvConf):
servers = []
for L in resolvConf:
L = L.strip()
if L.startswith('nameserver'):
resolver = (L.split()[1], dns.PORT)
servers.append(resolver)
log.msg("Resolver added %r to server list" % (resolver,))
elif L.startswith('domain'):
try:
self.domain = L.split()[1]
except IndexError:
self.domain = ''
self.search = None
elif L.startswith('search'):
try:
self.search = L.split()[1:]
except IndexError:
self.search = ''
self.domain = None
if not servers:
servers.append(('127.0.0.1', dns.PORT))
self.dynServers = servers
示例3: __init__
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def __init__(self):
# Merge rdns_servers entries from local and bridge configs.
servers = set()
try:
import dtella.local_config as local
servers.update(local.rdns_servers)
except (ImportError, AttributeError):
pass
try:
import dtella.bridge_config as cfg
servers.update(cfg.rdns_servers)
except (ImportError, AttributeError):
pass
# Convert to list, and randomize.
servers = list(servers)
random.shuffle(servers)
self.resolver = client.Resolver(
servers=[(ip, dns.PORT) for ip in servers],
timeout=(1,2,3))
示例4: _roots
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def _roots(self):
"""
Return a list of two-tuples representing the addresses of the root
servers, as defined by C{self.hints}.
"""
return [(ip, dns.PORT) for ip in self.hints]
示例5: extractRecord
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def extractRecord(resolver, name, answers, level=10):
if not level:
return None
if hasattr(socket, 'inet_ntop'):
for r in answers:
if r.name == name and r.type == dns.A6:
return socket.inet_ntop(socket.AF_INET6, r.payload.address)
for r in answers:
if r.name == name and r.type == dns.AAAA:
return socket.inet_ntop(socket.AF_INET6, r.payload.address)
for r in answers:
if r.name == name and r.type == dns.A:
return socket.inet_ntop(socket.AF_INET, r.payload.address)
for r in answers:
if r.name == name and r.type == dns.CNAME:
result = extractRecord(
resolver, r.payload.name, answers, level - 1)
if not result:
return resolver.getHostByName(
str(r.payload.name), effort=level - 1)
return result
# No answers, but maybe there's a hint at who we should be asking about
# this
for r in answers:
if r.type == dns.NS:
from twisted.names import client
r = client.Resolver(servers=[(str(r.payload.name), dns.PORT)])
return r.lookupAddress(str(name)
).addCallback(
lambda records: extractRecord(
r, name,
records[_ANS] + records[_AUTH] + records[_ADD],
level - 1))
示例6: test_secondary
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def test_secondary(self):
"""
An argument of the form C{"ip/domain"} is parsed by L{Options} for the
I{--secondary} option and added to its list of secondaries, using the
default DNS port number.
"""
options = Options()
options.parseOptions(['--secondary', '1.2.3.4/example.com'])
self.assertEqual(
[(('1.2.3.4', PORT), ['example.com'])], options.secondaries)
示例7: discoveredAuthority
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def discoveredAuthority(self, auth, name, cls, type, timeout):
warnings.warn(
'twisted.names.root.Resolver.discoveredAuthority is deprecated since '
'Twisted 10.0. Use twisted.names.client.Resolver directly, instead.',
category=DeprecationWarning, stacklevel=2)
from twisted.names import client
q = dns.Query(name, type, cls)
r = client.Resolver(servers=[(auth, dns.PORT)])
d = r.queryUDP([q], timeout)
d.addCallback(r.filterAnswers)
return d
示例8: lookupNameservers
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def lookupNameservers(host, atServer, p=None):
warnings.warn(
'twisted.names.root.lookupNameservers is deprecated since Twisted '
'10.0. Use twisted.names.root.Resolver.lookupNameservers instead.',
category=DeprecationWarning, stacklevel=2)
# print 'Nameserver lookup for', host, 'at', atServer, 'with', p
if p is None:
p = dns.DNSDatagramProtocol(_DummyController())
p.noisy = False
return retry(
(1, 3, 11, 45), # Timeouts
p, # Protocol instance
(atServer, dns.PORT), # Server to query
[dns.Query(host, dns.NS, dns.IN)] # Question to ask
)
示例9: lookupAddress
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def lookupAddress(host, atServer, p=None):
warnings.warn(
'twisted.names.root.lookupAddress is deprecated since Twisted '
'10.0. Use twisted.names.root.Resolver.lookupAddress instead.',
category=DeprecationWarning, stacklevel=2)
# print 'Address lookup for', host, 'at', atServer, 'with', p
if p is None:
p = dns.DNSDatagramProtocol(_DummyController())
p.noisy = False
return retry(
(1, 3, 11, 45), # Timeouts
p, # Protocol instance
(atServer, dns.PORT), # Server to query
[dns.Query(host, dns.A, dns.IN)] # Question to ask
)
示例10: transfer
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def transfer(self):
if self.transferring:
return
self.transfering = True
return client.Resolver(servers=[(self.primary, dns.PORT)]
).lookupZone(self.domain
).addCallback(self._cbZone
).addErrback(self._ebZone
)
示例11: extractRecord
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def extractRecord(resolver, name, answers, level=10):
if not level:
return None
if hasattr(socket, 'inet_ntop'):
for r in answers:
if r.name == name and r.type == dns.A6:
return socket.inet_ntop(socket.AF_INET6, r.payload.address)
for r in answers:
if r.name == name and r.type == dns.AAAA:
return socket.inet_ntop(socket.AF_INET6, r.payload.address)
for r in answers:
if r.name == name and r.type == dns.A:
return socket.inet_ntop(socket.AF_INET, r.payload.address)
for r in answers:
if r.name == name and r.type == dns.CNAME:
result = extractRecord(
resolver, r.payload.name, answers, level - 1)
if not result:
return resolver.getHostByName(
str(r.payload.name), effort=level - 1)
return result
# No answers, but maybe there's a hint at who we should be asking about
# this
for r in answers:
if r.type == dns.NS:
from twisted.names import client
r = client.Resolver(servers=[(str(r.payload.name), dns.PORT)])
return r.lookupAddress(str(name)
).addCallback(
lambda (ans, auth, add):
extractRecord(r, name, ans + auth + add, level - 1))
示例12: discoveredAuthority
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def discoveredAuthority(self, auth, name, cls, type, timeout):
from twisted.names import client
q = dns.Query(name, type, cls)
r = client.Resolver(servers=[(auth, dns.PORT)])
d = r.queryUDP([q], timeout)
d.addCallback(r.filterAnswers)
return d
示例13: lookupNameservers
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def lookupNameservers(host, atServer, p=None):
# print 'Nameserver lookup for', host, 'at', atServer, 'with', p
if p is None:
p = dns.DNSDatagramProtocol(_DummyController())
p.noisy = False
return retry(
(1, 3, 11, 45), # Timeouts
p, # Protocol instance
(atServer, dns.PORT), # Server to query
[dns.Query(host, dns.NS, dns.IN)] # Question to ask
)
示例14: lookupAddress
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def lookupAddress(host, atServer, p=None):
# print 'Address lookup for', host, 'at', atServer, 'with', p
if p is None:
p = dns.DNSDatagramProtocol(_DummyController())
p.noisy = False
return retry(
(1, 3, 11, 45), # Timeouts
p, # Protocol instance
(atServer, dns.PORT), # Server to query
[dns.Query(host, dns.A, dns.IN)] # Question to ask
)
示例15: __init__
# 需要導入模塊: from twisted.names import dns [as 別名]
# 或者: from twisted.names.dns import PORT [as 別名]
def __init__(self, servers, hostname):
self.servers = list(servers)
self.hostname = hostname
random.shuffle(servers)
self.resolver = client.Resolver(
servers=[(ip, dns.PORT) for ip in servers],
timeout=(1,2,3))