net.dns: Try next server if peer name can not be set (thanks wirehack7)
authorKim Alvefur <zash@zash.se>
Thu, 30 Oct 2014 12:28:07 +0100
changeset 6512 7cb69eba3e95
parent 6511 4a28b8320d7f
child 6513 8273236a995f
child 6525 46cf369d3eb5
net.dns: Try next server if peer name can not be set (thanks wirehack7)
net/dns.lua
--- a/net/dns.lua	Thu Oct 30 12:10:15 2014 +0100
+++ b/net/dns.lua	Thu Oct 30 12:28:07 2014 +0100
@@ -622,7 +622,7 @@
 	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 @@
 	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 @@
 	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 @@
 					--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 @@
 			self.best_server = 1;
 		end
 	end
-	return sock;
+	return sock, err;
 end
 
 function resolver:settimeout(seconds)