diff options
author | Florian Zeitz <florob@babelmonkeys.de> | 2013-06-18 23:02:20 +0200 |
---|---|---|
committer | Florian Zeitz <florob@babelmonkeys.de> | 2013-06-18 23:02:20 +0200 |
commit | 15c9e030d7a54bb5a3c1acc77eb4dca3b1a9f28b (patch) | |
tree | 7d058ee401748716da701e2c93624d338a5706a4 | |
parent | 8e6f8d978c961c37f2ccb306de43f35de885f370 (diff) | |
download | prosody-15c9e030d7a54bb5a3c1acc77eb4dca3b1a9f28b.tar.gz prosody-15c9e030d7a54bb5a3c1acc77eb4dca3b1a9f28b.zip |
net.dns: Support IPv6 addresses in resolv.conf
-rw-r--r-- | net/dns.lua | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/net/dns.lua b/net/dns.lua index 89b50255..bd42db73 100644 --- a/net/dns.lua +++ b/net/dns.lua @@ -14,6 +14,7 @@ local socket = require "socket"; local timer = require "util.timer"; +local new_ip = require "util.ip".new_ip; local _, windows = pcall(require, "util.windows"); local is_windows = (_ and windows) or os.getenv("WINDIR"); @@ -597,11 +598,12 @@ function resolver:adddefaultnameservers() -- - - - - adddefaultnameservers if resolv_conf then for line in resolv_conf:lines() do line = line:gsub("#.*$", "") - :match('^%s*nameserver%s+(.*)%s*$'); + :match('^%s*nameserver%s+([%x:%.]*)%s*$'); if line then - line:gsub("%f[%d.](%d+%.%d+%.%d+%.%d+)%f[^%d.]", function (address) - self:addnameserver(address) - end); + local ip = new_ip(line); + if ip then + self:addnameserver(ip.addr); + end end end end @@ -621,7 +623,12 @@ function resolver:getsocket(servernum) -- - - - - - - - - - - - - getsocket if sock then return sock; end local err; - sock, err = socket.udp(); + local peer = self.server[servernum]; + if peer:find(":") then + sock, err = socket.udp6(); + else + sock, err = socket.udp(); + end if not sock then return nil, err; end @@ -629,7 +636,7 @@ function resolver:getsocket(servernum) -- - - - - - - - - - - - - getsocket sock:settimeout(0); -- todo: attempt to use a random port, fallback to 0 sock:setsockname('*', 0); - sock:setpeername(self.server[servernum], 53); + sock:setpeername(peer, 53); self.socket[servernum] = sock; self.socketset[sock] = servernum; return sock; |