Module:IP validator
Documentation for this module may be created at Module:IP validator/doc
--[[
* Questo modulo serve per validare un indirizzo IP.
* È necessario un algoritmo iterativo in quanto le espressioni regolari di Lua non sono sufficientemente espressive.
]]
local p = {}
-- =============================================================================
-- Funzioni per moduli
-- =============================================================================
-- Questa funzione ritorna '1' se la stringa in input corrisponde allo standard IPv4, altrimenti un valore nullo.
function p._is_ipv4(s)
s = s:gsub("/[0-9]$", ""):gsub("/[12][0-9]$", ""):gsub("/[3][0-2]$", "")
if not s:find("^%d+%.%d+%.%d+%.%d+$") then
return nil
end
for substr in s:gmatch("(%d+)") do
if not substr:find("^[1-9]?[0-9]$")
and not substr:find("^1[0-9][0-9]$")
and not substr:find( "^2[0-4][0-9]$")
and not substr:find("^25[0-5]$") then
return nil
end
end
return '1'
end
-- Questa funzione ritorna '1' se la stringa in input corrisponde allo standard IPv6, altrimenti un valore nullo.
function p._is_ipv6(s)
if not (s:find("^%w+:%w+:%w+:%w+:%w+:%w+:%w+:%w+$") -- caso in cui ci sono esattamente sette ":"
or (s:find("^%w*:%w*:%w*:?%w*:?%w*:?%w*:?%w*$") -- altrimenti devono esserci fra i due e i sei ":"
and s:find("::"))) -- e dev'esserci la sottostringa "::"
or s:find("::.*::") -- ma non possono mai esserci due sottostringhe "::"
or s:find(":::") then -- né una sottostringa ":::"
return nil
end
for substr in s:gmatch("(%w+)") do
if not substr:find("^[0-9A-Fa-f][0-9A-Fa-f]?[0-9A-Fa-f]?[0-9A-Fa-f]?$") then
return nil
end
end
return '1'
end
-- Questa funzione ritorna '1' se la stringa in input corrisponde allo standard IPv4 o IPv6, altrimenti un valore nullo.
function p._is_ip(s)
return p._is_ipv4(s) or p._is_ipv6(s)
end
-- =============================================================================
-- Funzioni per template
-- =============================================================================
function p.is_ipv4(frame) return p._is_ipv4(frame.args[1] or '') end --Uso: {{#invoke:IP validator|is_ipv4|stringa}}
function p.is_ipv6(frame) return p._is_ipv6(frame.args[1] or '') end --Uso: {{#invoke:IP validator|is_ipv6|stringa}}
function p.is_ip (frame) return p._is_ip (frame.args[1] or '') end --Uso: {{#invoke:IP validator|is_ip|stringa}}
return p