Commit 31df9397 authored by Denis Bilenko's avatar Denis Bilenko

evdns.pxi: raise IOError if evdns functions return nonzero; add dns_err_to_string

parent 04feef8c
__all__ += ['dns_init', 'dns_shutdown', 'dns_resolve_ipv4', 'dns_resolve_ipv6', __all__ += ['dns_init', 'dns_shutdown', 'dns_err_to_string',
'dns_resolve_reverse', 'dns_resolve_reverse_ipv6', 'dns_shutdown'] 'dns_resolve_ipv4', 'dns_resolve_ipv6',
'dns_resolve_reverse', 'dns_resolve_reverse_ipv6']
cdef extern from "netinet/in.h": cdef extern from "netinet/in.h":
cdef enum: cdef enum:
...@@ -22,19 +23,14 @@ cdef extern from "arpa/inet.h": ...@@ -22,19 +23,14 @@ cdef extern from "arpa/inet.h":
char *inet_ntop(int af, void *src, char *dst, socklen_t size) char *inet_ntop(int af, void *src, char *dst, socklen_t size)
cdef extern from "libevent.h": cdef extern from "libevent.h":
ctypedef void (*evdns_handler)(int result, char t, int count, int ttl, ctypedef void (*evdns_handler)(int result, char t, int count, int ttl, void *addrs, void *arg)
void *addrs, void *arg)
int evdns_init() int evdns_init()
char *evdns_err_to_string(int err) char *evdns_err_to_string(int err)
int evdns_resolve_ipv4(char *name, int flags, evdns_handler callback, int evdns_resolve_ipv4(char *name, int flags, evdns_handler callback, void *arg)
void *arg) int evdns_resolve_ipv6(char *name, int flags, evdns_handler callback, void *arg)
int evdns_resolve_ipv6(char *name, int flags, evdns_handler callback, int evdns_resolve_reverse(in_addr *ip, int flags, evdns_handler callback, void *arg)
void *arg) int evdns_resolve_reverse_ipv6(in6_addr *ip, int flags, evdns_handler callback, void *arg)
int evdns_resolve_reverse(in_addr *ip, int flags, evdns_handler callback,
void *arg)
int evdns_resolve_reverse_ipv6(in6_addr *ip, int flags, evdns_handler callback,
void *arg)
void evdns_shutdown(int fail_requests) void evdns_shutdown(int fail_requests)
# Result codes # Result codes
...@@ -50,19 +46,29 @@ DNS_ERR_TIMEOUT = 67 ...@@ -50,19 +46,29 @@ DNS_ERR_TIMEOUT = 67
DNS_ERR_SHUTDOWN = 68 DNS_ERR_SHUTDOWN = 68
# Types # Types
DNS_IPv4_A = 1 DNS_IPv4_A = 1
DNS_PTR = 2 DNS_PTR = 2
DNS_IPv6_AAAA = 3 DNS_IPv6_AAAA = 3
# Flags # Flags
DNS_QUERY_NO_SEARCH = 1 DNS_QUERY_NO_SEARCH = 1
def dns_init(): def dns_init():
"""Initialize async DNS resolver.""" """Initialize async DNS resolver."""
evdns_init() evdns_init()
cdef void __evdns_callback(int result, char t, int count, int ttl,
void *addrs, void *arg) with gil: def dns_shutdown(int fail_requests=0):
"""Shutdown the async DNS resolver and terminate all active requests."""
evdns_shutdown(fail_requests)
def dns_err_to_string(int err):
return evdns_err_to_string(err)
cdef void __evdns_callback(int result, char t, int count, int ttl, void *addrs, void *arg) with gil:
cdef int i cdef int i
cdef char str[INET6_ADDRSTRLEN] cdef char str[INET6_ADDRSTRLEN]
ctx = <tuple>(arg) ctx = <tuple>(arg)
...@@ -82,11 +88,11 @@ cdef void __evdns_callback(int result, char t, int count, int ttl, ...@@ -82,11 +88,11 @@ cdef void __evdns_callback(int result, char t, int count, int ttl,
else: else:
x = None x = None
try: try:
callback(result, t, ttl, x, args) callback(result, t, ttl, x, *args)
except: except:
traceback.print_exc() traceback.print_exc()
def dns_resolve_ipv4(char *name, int flags, callback, *args): def dns_resolve_ipv4(char *name, int flags, callback, *args):
"""Lookup an A record for a given name. """Lookup an A record for a given name.
...@@ -96,8 +102,11 @@ def dns_resolve_ipv4(char *name, int flags, callback, *args): ...@@ -96,8 +102,11 @@ def dns_resolve_ipv4(char *name, int flags, callback, *args):
- *args* -- option callback arguments - *args* -- option callback arguments
""" """
t = (callback, args) t = (callback, args)
cdef int result = evdns_resolve_ipv4(name, flags, __evdns_callback, <void *>t)
if result:
raise IOError('evdns_resolve_ipv4(%r, %r) returned %s' % (name, flags, result, ))
Py_INCREF(t) Py_INCREF(t)
evdns_resolve_ipv4(name, flags, __evdns_callback, <void *>t)
def dns_resolve_ipv6(char *name, int flags, callback, *args): def dns_resolve_ipv6(char *name, int flags, callback, *args):
"""Lookup an AAAA record for a given name. """Lookup an AAAA record for a given name.
...@@ -108,8 +117,11 @@ def dns_resolve_ipv6(char *name, int flags, callback, *args): ...@@ -108,8 +117,11 @@ def dns_resolve_ipv6(char *name, int flags, callback, *args):
- *args* -- option callback arguments - *args* -- option callback arguments
""" """
t = (callback, args) t = (callback, args)
cdef int result = evdns_resolve_ipv6(name, flags, __evdns_callback, <void *>t)
if result:
raise IOError('evdns_resolve_ip6(%r, %r) returned %s' % (name, flags, result, ))
Py_INCREF(t) Py_INCREF(t)
evdns_resolve_ipv6(name, flags, __evdns_callback, <void *>t)
def dns_resolve_reverse(char *ip, int flags, callback, *args): def dns_resolve_reverse(char *ip, int flags, callback, *args):
"""Lookup a PTR record for a given IPv4 address. """Lookup a PTR record for a given IPv4 address.
...@@ -120,10 +132,13 @@ def dns_resolve_reverse(char *ip, int flags, callback, *args): ...@@ -120,10 +132,13 @@ def dns_resolve_reverse(char *ip, int flags, callback, *args):
- *args* -- option callback arguments - *args* -- option callback arguments
""" """
t = (callback, args) t = (callback, args)
Py_INCREF(t)
cdef in_addr addr cdef in_addr addr
inet_aton(ip, &addr) inet_aton(ip, &addr)
evdns_resolve_reverse(&addr, flags, __evdns_callback, <void *>t) cdef int result = evdns_resolve_reverse(&addr, flags, __evdns_callback, <void *>t)
if result:
raise IOError('evdns_resolve_reverse(%r, %r) returned %s' % (ip, flags, result, ))
Py_INCREF(t)
def dns_resolve_reverse_ipv6(char *ip, int flags, callback, *args): def dns_resolve_reverse_ipv6(char *ip, int flags, callback, *args):
"""Lookup a PTR record for a given IPv6 address. """Lookup a PTR record for a given IPv6 address.
...@@ -134,12 +149,10 @@ def dns_resolve_reverse_ipv6(char *ip, int flags, callback, *args): ...@@ -134,12 +149,10 @@ def dns_resolve_reverse_ipv6(char *ip, int flags, callback, *args):
- *args* -- option callback arguments - *args* -- option callback arguments
""" """
t = (callback, args) t = (callback, args)
Py_INCREF(t)
cdef in6_addr addr cdef in6_addr addr
inet_pton(AF_INET6, ip, &addr) inet_pton(AF_INET6, ip, &addr)
evdns_resolve_reverse_ipv6(&addr, flags, __evdns_callback, <void *>t) cdef int result = evdns_resolve_reverse_ipv6(&addr, flags, __evdns_callback, <void *>t)
if result:
def dns_shutdown(int fail_requests=0): raise IOError('evdns_resolve_reverse_ipv6(%r, %r) returned %s' % (ip, flags, result, ))
"""Shutdown the async DNS resolver and terminate all active requests.""" Py_INCREF(t)
evdns_shutdown(fail_requests)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment