Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lekensteyn/wireguard-dissector
Wireshark dissector (written in Lua) for dissecting the WireGuard tunneling protocol.
https://github.com/lekensteyn/wireguard-dissector
libgcrypt lua wireguard wireshark wireshark-dissector
Last synced: 3 months ago
JSON representation
Wireshark dissector (written in Lua) for dissecting the WireGuard tunneling protocol.
- Host: GitHub
- URL: https://github.com/lekensteyn/wireguard-dissector
- Owner: Lekensteyn
- License: gpl-2.0
- Created: 2017-02-28T17:18:29.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-08-26T16:23:50.000Z (over 6 years ago)
- Last Synced: 2024-11-01T01:42:12.316Z (3 months ago)
- Topics: libgcrypt, lua, wireguard, wireshark, wireshark-dissector
- Language: Lua
- Size: 1.44 MB
- Stars: 46
- Watchers: 7
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Wireshark dissector for the WireGuard tunnel protocol
Wireshark dissector (written in Lua) for dissecting the [WireGuard][1] tunneling
protocol.**This dissector is obsolete, an improved version is included in Wireshark
2.9.x.** See [this comment][5] for more further instructions.![Screenshot of Wireshark with WireGuard traffic](wireshark-wg.png)
Requirements:
- Wireshark 2.0.2 or newer (tested with Wireshark 2.3.x).
- [luagcrypt][2] and Libgcrypt 1.7 for (optional) decryption support.~~The plan is to eventually rewrite this prototype into a dissector that is
included with the main Wireshark sources.~~ An improved version is included with
the current development version (git master, 2.9.x).## Installation and usage
Install [wg.lua](wg.lua) in the [Wireshark plugins folder][4] (usually
`~/.config/wireshark/plugins/` or `~/.wireshark/plugins/`).
For decryption support, install [luagcrypt][2] in the Lua library path
(usually `/usr/lib/lua/5.2/luagcrypt.so`).Now try the sample packet capture [pcaps/8-trace.pcap](pcaps/8-trace.pcap)
and its corresponding keylog file [pcaps/8-trace.keys](pcaps/8-trace.keys)
(configure via *Protocol Preferences* → *Keylog file*).As alternative to installing files globally, copy luagcrypt.so to the current
working directory and run:wireshark -Xlua_script:wg.lua -r pcaps/8-trace.pcap -owg.keylog_file:pcaps/8-trace.keys
Since WireGuard does not have a default port number, it is recommended to enable
the UDP protocol preference *Try heuristic sub-dissectors first* (via the menu
Edit → Preferences, Protocols → UDP).## Obtaining handshake and traffic secrets through key-probe.sh and key-extract.py
The [key-probe.sh](key-probe.sh) script enables tracing WireGuard function calls
using [*kprobes*][3]. This raw data must be post-processed with
[key-extract.py](key-extract.py) to produce a keylog file with handshake and
traffic secrets. A kernel with `CONFIG_KPROBE_EVENT=y` is required (most distros
satisfy this requirement).To get started, enable the required tracepoints:
sudo ./key-probe.sh
Next, obtain the trace output and extract keys from it. A one-shot approach that
can be executed periodically:sudo cat /sys/kernel/debug/tracing/trace > trace.txt
./key-extract.py < trace.txt > trace.keysTo continuously update the keylog file (useful for live captures, but note that
this will erase traces that are read from the file):sudo cat /sys/kernel/debug/tracing/trace_pipe | ./key-extract.py > trace.keys
To stop logging more keys, disable the tracepoints with:
sudo ./key-noprobe.sh
## Obtaining traffic secrets through extract-keys
The `extract-keys` utility included with WireGuard can extract traffic secrets
(for active sessions only) and requires the `CONFIG_DEVKMEM=y` option (many
distros such as Arch Linux Linux, Debian and Ubuntu have it disabled).
See `contrib/examples/extract-keys` in the WireGuard sources for more details.## License
Copyright (C) 2017 Peter Wu ([email protected])This project is licensed under the GPLv2 (or any later version) license.
See [LICENSE.txt](LICENSE.txt) for more details.[1]: https://www.wireguard.io/
[2]: https://github.com/Lekensteyn/luagcrypt
[3]: https://www.kernel.org/doc/Documentation/trace/kprobetrace.txt
[4]: https://www.wireshark.org/docs/wsug_html_chunked/ChAppFilesConfigurationSection.html
[5]: https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=15011#c18