aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2014-10-30 12:28:07 +0100
committerKim Alvefur <zash@zash.se>2014-10-30 12:28:07 +0100
commitce6a2af78f81381026b4aee05638a624ec8eba5e (patch)
treee0e14cfbf313274a9af863bb8bb05760bf1a4488
parenta5b90711b7e2638c4e735ec6545bea5b4462e9c4 (diff)
downloadprosody-ce6a2af78f81381026b4aee05638a624ec8eba5e.tar.gz
prosody-ce6a2af78f81381026b4aee05638a624ec8eba5e.zip
net.dns: Try next server if peer name can not be set (thanks wirehack7)
-rw-r--r--net/dns.lua16
1 files changed, 10 insertions, 6 deletions
diff --git a/net/dns.lua b/net/dns.lua
index 55622fc8..13417cee 100644
--- a/net/dns.lua
+++ b/net/dns.lua
@@ -622,7 +622,7 @@ function resolver:getsocket(servernum) -- - - - - - - - - - - - - getsocket
local sock = self.socket[servernum];
if sock then return sock; end
- local err;
+ local ok, err;
sock, err = socket.udp();
if sock and self.socket_wrapper then sock, err = self.socket_wrapper(sock, self); end
if not sock then
@@ -630,10 +630,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(self.server[servernum], 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(self.server[servernum], 53);
+ if not ok then return self:servfail(sock, err); end
return sock;
end
@@ -781,7 +785,7 @@ 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]
@@ -804,7 +808,7 @@ function resolver:servfail(sock)
--print('timeout');
queries[question] = nil;
else
- sock = self:getsocket(o.server);
+ sock, err = self:getsocket(o.server);
if sock then sock:send(o.packet); end
end
end
@@ -821,7 +825,7 @@ function resolver:servfail(sock)
self.best_server = 1;
end
end
- return sock;
+ return sock, err;
end
function resolver:settimeout(seconds)