SHOW:
|
|
- or go back to the newest paste.
| 1 | -- ############################################################################ | |
| 2 | -- Continuing our Dissector example at [1], let's say we wanted to print the value | |
| 3 | -- of `foo.str` for packets whose `foo.num` field is >= sqrt(5) (I picked a | |
| 4 | -- condition that couldn't already be achieved with display filters). | |
| 5 | -- | |
| 6 | -- This Wireshark Lua script implements a listener for this purpose. | |
| 7 | -- | |
| 8 | -- [1]: http://pastebin.com/8j0LhVTQ | |
| 9 | -- ############################################################################ | |
| 10 | ||
| 11 | -- 1. Declare the tap with the `Listener()` function | |
| 12 | local tap = Listener.new(nil, 'foo') | |
| 13 | ||
| 14 | -- 2. Declare field extractors to pull values of named fields from the current packet | |
| 15 | local f_str = Field.new('foo.str')
| |
| 16 | local f_num = Field.new('foo.num')
| |
| 17 | ||
| 18 | -- 3. Declare the tap's packet function | |
| 19 | function tap.packet(pinfo, buf) | |
| 20 | ||
| 21 | -- check if at least one instance of foo.num is >= sqrt(5) | |
| 22 | local gt_sqrt5 = false | |
| 23 | for _,v in ipairs({ f_num() }) do
| |
| 24 | if v >= math.sqrt(5) then | |
| 25 | gt_sqrt5 = true | |
| 26 | break | |
| 27 | end | |
| 28 | end | |
| 29 | ||
| 30 | if gt_sqrt5 then | |
| 31 | -- print all instances of foo.str from the current packet | |
| 32 | for _,v in ipairs({ f_str() }) do
| |
| 33 | - | print(pinfo.number, 'foo.str', v) |
| 33 | + | info(pinfo.number..'foo.str'..v) |
| 34 | end | |
| 35 | end | |
| 36 | end |