mirror of
https://github.com/nmap/nmap.git
synced 2025-12-09 14:11:29 +00:00
174 lines
4.0 KiB
Lua
174 lines
4.0 KiB
Lua
-- See nmaps COPYING for licence
|
|
|
|
local assert = assert;
|
|
local tonumber = tonumber;
|
|
local concat = table.concat;
|
|
local nmap = require"nmap";
|
|
|
|
module(... or "stdnse");
|
|
|
|
print_debug = function(level, fmt, ...)
|
|
local verbosity = tonumber(level);
|
|
if verbosity then
|
|
nmap.print_debug_unformatted(verbosity, fmt:format(...));
|
|
else
|
|
nmap.print_debug_unformatted(1, level:format(...));
|
|
end
|
|
end
|
|
|
|
-- Concat the contents of the parameter list,
|
|
-- separated by the string delimiter (just like in perl)
|
|
-- example: strjoin(", ", {"Anna", "Bob", "Charlie", "Dolores"})
|
|
function strjoin(delimiter, list)
|
|
return concat(list, delimiter);
|
|
end
|
|
|
|
-- Split text into a list consisting of the strings in text,
|
|
-- separated by strings matching delimiter (which may be a pattern).
|
|
-- example: strsplit(",%s*", "Anna, Bob, Charlie,Dolores")
|
|
function strsplit(delimiter, text)
|
|
local list, pos = {}, 1;
|
|
|
|
assert(delimiter ~= "", "delimiter matches empty string!");
|
|
|
|
while true do
|
|
local first, last, match = text:find(delimiter, pos);
|
|
if first then -- found?
|
|
list[#list+1] = text:sub(pos, first-1);
|
|
pos = last+1;
|
|
else
|
|
list[#list+1] = text:sub(pos);
|
|
break;
|
|
end
|
|
end
|
|
return list;
|
|
end
|
|
|
|
-- Generic buffer implementation using lexical closures
|
|
--
|
|
-- Pass make_buffer a socket and a separator lua pattern [1].
|
|
--
|
|
-- Returns a function bound to your provided socket with behaviour identical
|
|
-- to receive_lines() except it will return AT LEAST ONE [2] and AT MOST ONE
|
|
-- "line" at a time.
|
|
--
|
|
-- [1] Use the pattern "\r?\n" for regular newlines
|
|
-- [2] Except where there is trailing "left over" data not terminated by a
|
|
-- pattern (in which case you get the data anyways)
|
|
-- [3] The data is returned WITHOUT the pattern/newline on the end.
|
|
-- [4] Empty "lines" are returned as "". With the pattern in [1] you will
|
|
-- receive a "" for each newline in the stream.
|
|
-- [5] Errors/EOFs are delayed until all "lines" have been processed.
|
|
--
|
|
-- -Doug, June, 2007
|
|
|
|
--[[ function make_buffer(socket, sep)
|
|
local point, pattern, buffer = 1, "([^"..sep.."]-)"..sep.."?";
|
|
local function self(lines)
|
|
lines = lines or 1;
|
|
if not buffer then
|
|
local status, str = socket:receive_lines(lines);
|
|
if not status then
|
|
if buffer then
|
|
return buffer:sub(point);
|
|
else
|
|
return status, str;
|
|
end
|
|
else
|
|
buffer = str;
|
|
return self(lines);
|
|
end
|
|
else
|
|
local _, j, str = buffer:find(pattern, point);
|
|
if j then
|
|
point = j + 1;
|
|
return str;
|
|
else
|
|
point, buffer = 1, nil;
|
|
return self(lines);
|
|
end
|
|
end
|
|
end
|
|
return self;
|
|
end --]]
|
|
|
|
make_buffer = function(sd, sep)
|
|
local self, result
|
|
local buf = ""
|
|
|
|
self = function()
|
|
local i, j, status, value
|
|
|
|
i, j = buf:find(sep)
|
|
|
|
if i then
|
|
if i == 1 then -- empty line
|
|
buf = buf:sub(j+1, -1)
|
|
--return self() -- skip empty, tail
|
|
return true, "" -- return empty
|
|
else
|
|
value = buf:sub(1, i-1)
|
|
buf = buf:sub(j+1, -1)
|
|
return true, value
|
|
end
|
|
end
|
|
|
|
if result then
|
|
if #buf > 0 then -- left over data with no terminating pattern
|
|
value = buf
|
|
buf = ""
|
|
return true, value
|
|
end
|
|
return nil, result
|
|
end
|
|
|
|
status, value = sd:receive()
|
|
|
|
if status then
|
|
buf = buf .. value
|
|
else
|
|
result = value
|
|
end
|
|
|
|
return self() -- tail
|
|
end
|
|
|
|
return self
|
|
end
|
|
|
|
do
|
|
local t = {
|
|
["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"
|
|
};
|
|
|
|
function tobinary(n)
|
|
assert(tonumber(n), "number expected");
|
|
return (("%x"):format(n):gsub("%w", t):gsub("^0*", ""));
|
|
end
|
|
end
|
|
|
|
function tooctal(n)
|
|
assert(tonumber(n), "number expected");
|
|
return ("%o"):format(n)
|
|
end
|
|
|
|
function tohex(n)
|
|
assert(tonumber(n), "number expected");
|
|
return ("%x"):format(n);
|
|
end
|