Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joushx/kaitai-to-wireshark
Converts a Kaitai Struct file description to a Wireshark LUA plugin
https://github.com/joushx/kaitai-to-wireshark
Last synced: 3 months ago
JSON representation
Converts a Kaitai Struct file description to a Wireshark LUA plugin
- Host: GitHub
- URL: https://github.com/joushx/kaitai-to-wireshark
- Owner: joushx
- License: mit
- Created: 2016-09-20T13:06:53.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-04-07T15:33:13.000Z (almost 3 years ago)
- Last Synced: 2024-10-18T15:12:14.837Z (3 months ago)
- Language: Lua
- Size: 33.2 KB
- Stars: 38
- Watchers: 4
- Forks: 7
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-kaitai - Repository - *deprecated* (Converter / CI)
README
# kaitai-to-wireshark
Converts a [Kaitai Struct](https://github.com/kaitai-io/kaitai_struct) binary file description to a Wireshark LUA dissector.## Usage
``./convert.py description.ksy > plugin.lua``
Please note that the result is not a finished wireshark plugin but rather a prototype for further customization. For instance it always uses the `bytes` type for fields.
Please replace `` with the port to register the dissector for.
## Example
A Kaitai Struct file:
```yaml
meta:
id: gif
file-extension: gif
endian: le
seq:
- id: header
type: header
- id: logical_screen
type: logical_screen
types:
header:
seq:
- id: magic
contents: 'GIF'
- id: version
size: 3
logical_screen:
seq:
- id: image_width
type: u2
- id: image_height
type: u2
- id: flags
type: u1
- id: bg_color_index
type: u1
- id: pixel_aspect_ratio
type: u1
```The resulting lua file to be used with Wireshark:
```lua
gif_proto = Proto("gif","gif file")local f = gif_proto.fields
-- field declaration
f.header = ProtoField.bytes("gif.header", "header")
f.logical_screen = ProtoField.bytes("gif.logical_screen", "logical_screen")
f.magic = ProtoField.bytes("gif.header.magic", "magic")
f.version = ProtoField.bytes("gif.header.version", "version")
f.image_width = ProtoField.bytes("gif.logical_screen.image_width", "image_width")
f.image_height = ProtoField.bytes("gif.logical_screen.image_height", "image_height")
f.flags = ProtoField.bytes("gif.logical_screen.flags", "flags")
f.bg_color_index = ProtoField.bytes("gif.logical_screen.bg_color_index", "bg_color_index")
f.pixel_aspect_ratio = ProtoField.bytes("gif.logical_screen.pixel_aspect_ratio", "pixel_aspect_ratio")-- main function
function modes_proto.dissector(buffer,pinfo,tree)
pinfo.cols.protocol = "gif"main = tree:add(gif_proto, "gif file")
local header = main:add(f.header,"header")
header:add(buffer(0,3), f.magic)
header:add(buffer(3,3), f.version)
local logical_screen = main:add(f.logical_screen,"logical_screen")
logical_screen:add(buffer(0,2), f.image_width)
logical_screen:add(buffer(2,2), f.image_height)
logical_screen:add(buffer(4,1), f.flags)
logical_screen:add(buffer(5,1), f.bg_color_index)
logical_screen:add(buffer(6,1), f.pixel_aspect_ratio)
endtcp_table = DissectorTable.get("tcp.port")
tcp_table:add(, gif_proto)
```## Limitations
Currently the script is just a proof-of-concept, very hacky and only converts a few basic data types: `u1`, `u2`, `u3`, fields with `contents` and fields with `size`. It is basically a template that gets filled with data.