util.ip: Automatically determine protocol of IP address if none specified. Return...
authorMatthew Wild <mwild1@gmail.com>
Fri, 17 May 2013 13:52:52 +0000 (14:52 +0100)
committerMatthew Wild <mwild1@gmail.com>
Fri, 17 May 2013 13:52:52 +0000 (14:52 +0100)
util/ip.lua

index 856bf03498261860db5796afccac66258c33beae..226432ccff8887464b7f92b39fe432008ce22b6d 100644 (file)
@@ -12,7 +12,15 @@ local ip_mt = { __index = function (ip, key) return (ip_methods[key])(ip); end,
 local hex2bits = { ["0"] = "0000", ["1"] = "0001", ["2"] = "0010", ["3"] = "0011", ["4"] = "0100", ["5"] = "0101", ["6"] = "0110", ["7"] = "0111", ["8"] = "1000", ["9"] = "1001", ["A"] = "1010", ["B"] = "1011", ["C"] = "1100", ["D"] = "1101", ["E"] = "1110", ["F"] = "1111" };
 
 local function new_ip(ipStr, proto)
-       if proto ~= "IPv4" and proto ~= "IPv6" then
+       if not proto then
+               local sep = ipStr:match("^%x+(.)");
+               if sep == ":" then proto = "IPv6"
+               elseif sep == "." then proto = "IPv4"
+               end
+               if not proto then
+                       return nil, "invalid address";
+               end
+       elseif proto ~= "IPv4" and proto ~= "IPv6" then
                return nil, "invalid protocol";
        end
        if proto == "IPv6" and ipStr:find('.', 1, true) then