mirror of
https://github.com/Proxmark/proxmark3.git
synced 2024-11-21 04:50:14 -08:00
67 lines
1.6 KiB
Lua
67 lines
1.6 KiB
Lua
-- The getopt-functionality is loaded from pm3/getopt.lua
|
|
-- Have a look there for further details
|
|
getopt = require('getopt')
|
|
bin = require('bin')
|
|
dumplib = require('html_dumplib')
|
|
|
|
example = "script run htmldump -o mifarecard_foo.html"
|
|
author = "Martin Holst Swende"
|
|
usage = "script run htmldump [-i <file>] [-o <file>]"
|
|
desc =[[
|
|
This script takes a dumpfile and produces a html based dump, which is a
|
|
bit more easily analyzed.
|
|
|
|
Arguments:
|
|
-h This help
|
|
-i <file> Specifies the dump-file (input). If omitted, 'dumpdata.bin' is used
|
|
-o <filename> Speciies the output file. If omitted, <curtime>.html is used.
|
|
|
|
]]
|
|
|
|
-------------------------------
|
|
-- Some utilities
|
|
-------------------------------
|
|
|
|
---
|
|
-- A debug printout-function
|
|
function dbg(args)
|
|
if DEBUG then
|
|
print("###", args)
|
|
end
|
|
end
|
|
---
|
|
-- This is only meant to be used when errors occur
|
|
function oops(err)
|
|
print("ERROR: ",err)
|
|
end
|
|
|
|
|
|
---
|
|
-- Usage help
|
|
function help()
|
|
print(desc)
|
|
print("Example usage")
|
|
print(example)
|
|
end
|
|
|
|
local function main(args)
|
|
|
|
local input = "dumpdata.bin"
|
|
local output = os.date("%Y-%m-%d_%H%M%S.html");
|
|
for o, a in getopt.getopt(args, 'i:o:h') do
|
|
if o == "h" then return help() end
|
|
if o == "i" then input = a end
|
|
if o == "o" then output = a end
|
|
end
|
|
local filename, err = dumplib.convert_bin_to_html(input,output,16)
|
|
if err then return oops(err) end
|
|
|
|
print(("Wrote a HTML dump to the file %s"):format(filename))
|
|
end
|
|
|
|
--[[
|
|
In the future, we may implement so that scripts are invoked directly
|
|
into a 'main' function, instead of being executed blindly. For future
|
|
compatibility, I have done so, but I invoke my main from here.
|
|
--]]
|
|
main(args) |