aboutsummaryrefslogtreecommitdiffstats
path: root/util/ip.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2016-01-08 16:21:05 +0100
committerKim Alvefur <zash@zash.se>2016-01-08 16:21:05 +0100
commit8cdd08825d3ab4afddc12ddf75dc9af1924e8518 (patch)
treeb72ea8b35e4dae603543a1b490f959f32b930870 /util/ip.lua
parent3d0f3a9db092d06daa782135077acfaf9b40b69c (diff)
parentb3d9c810676d288d193e4dcc3d95456e8a050f0e (diff)
downloadprosody-8cdd08825d3ab4afddc12ddf75dc9af1924e8518.tar.gz
prosody-8cdd08825d3ab4afddc12ddf75dc9af1924e8518.zip
Merge 0.10->trunk
Diffstat (limited to 'util/ip.lua')
-rw-r--r--util/ip.lua6
1 files changed, 5 insertions, 1 deletions
diff --git a/util/ip.lua b/util/ip.lua
index 7dcace5c..ec3b4d7e 100644
--- a/util/ip.lua
+++ b/util/ip.lua
@@ -25,6 +25,10 @@ local function new_ip(ipStr, proto)
elseif proto ~= "IPv4" and proto ~= "IPv6" then
return nil, "invalid protocol";
end
+ local zone;
+ if proto == "IPv6" and ipStr:find('%', 1, true) then
+ ipStr, zone = ipStr:match("^(.-)%%(.*)");
+ end
if proto == "IPv6" and ipStr:find('.', 1, true) then
local changed;
ipStr, changed = ipStr:gsub(":(%d+)%.(%d+)%.(%d+)%.(%d+)$", function(a,b,c,d)
@@ -33,7 +37,7 @@ local function new_ip(ipStr, proto)
if changed ~= 1 then return nil, "invalid-address"; end
end
- return setmetatable({ addr = ipStr, proto = proto }, ip_mt);
+ return setmetatable({ addr = ipStr, proto = proto, zone = zone }, ip_mt);
end
local function toBits(ip)