aboutsummaryrefslogtreecommitdiffstats
path: root/net/dns.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2014-11-09 20:30:04 +0100
committerKim Alvefur <zash@zash.se>2014-11-09 20:30:04 +0100
commit486335f3dbc84dacf253120f544f1d2ee026cf94 (patch)
tree97f78b366acac27667ddfb525a3a5aeabd37ddcf /net/dns.lua
parent090d1d01f4336cb3171631a429c40ec286065642 (diff)
parentc68bed48e932da73335c40f3721656dab067cf98 (diff)
downloadprosody-486335f3dbc84dacf253120f544f1d2ee026cf94.tar.gz
prosody-486335f3dbc84dacf253120f544f1d2ee026cf94.zip
Merge 0.9 -> 0.10
Diffstat (limited to 'net/dns.lua')
-rw-r--r--net/dns.lua19
1 files changed, 12 insertions, 7 deletions
diff --git a/net/dns.lua b/net/dns.lua
index 2b03caf6..2cb677f6 100644
--- a/net/dns.lua
+++ b/net/dns.lua
@@ -624,7 +624,7 @@ function resolver:getsocket(servernum) -- - - - - - - - - - - - - getsocket
local sock = self.socket[servernum];
if sock then return sock; end
- local err;
+ local ok, err;
local peer = self.server[servernum];
if peer:find(":") then
sock, err = socket.udp6();
@@ -637,10 +637,14 @@ function resolver:getsocket(servernum) -- - - - - - - - - - - - - getsocket
end
sock:settimeout(0);
-- todo: attempt to use a random port, fallback to 0
- sock:setsockname('*', 0);
- sock:setpeername(peer, 53);
self.socket[servernum] = sock;
self.socketset[sock] = servernum;
+ -- set{sock,peer}name can fail, eg because of local routing table
+ -- if so, try the next server
+ ok, err = sock:setsockname('*', 0);
+ if not ok then return self:servfail(sock, err); end
+ ok, err = sock:setpeername(peer, 53);
+ if not ok then return self:servfail(sock, err); end
return sock;
end
@@ -788,13 +792,13 @@ function resolver:query(qname, qtype, qclass) -- - - - - - - - - - -- query
return true;
end
-function resolver:servfail(sock)
+function resolver:servfail(sock, err)
-- Resend all queries for this server
local num = self.socketset[sock]
-- Socket is dead now
- self:voidsocket(sock);
+ sock = self:voidsocket(sock);
-- Find all requests to the down server, and retry on the next server
self.time = socket.gettime();
@@ -811,8 +815,8 @@ function resolver:servfail(sock)
--print('timeout');
queries[question] = nil;
else
- local _a = self:getsocket(o.server);
- if _a then _a:send(o.packet); end
+ sock, err = self:getsocket(o.server);
+ if sock then sock:send(o.packet); end
end
end
end
@@ -828,6 +832,7 @@ function resolver:servfail(sock)
self.best_server = 1;
end
end
+ return sock, err;
end
function resolver:settimeout(seconds)