lua:quic
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
lua:quic [2018/12/13 23:38] – [Network Security Monitoring for QUIC] veera | lua:quic [2024/06/04 16:58] (current) – [QUIC protocol analysis using the Trisul Scripting API] thiyagu | ||
---|---|---|---|
Line 2: | Line 2: | ||
- | QUIC (Quick UDP Internet Connection) is a protocol championed by Google to speed up web services by replacing the traditional TCP/HTTP network layer with a new UDP based protocol. | + | QUIC (Quick UDP Internet Connection) is a protocol championed by Google to speed up web services by replacing the traditional TCP/HTTP network layer with a new UDP based protocol. |
semantics on the UDP based QUIC and call the new thing HTTP/ | semantics on the UDP based QUIC and call the new thing HTTP/ | ||
This article describes how you can pull out key indicators from QUIC into Trisul using the [[https:// | This article describes how you can pull out key indicators from QUIC into Trisul using the [[https:// | ||
+ | |||
+ | < | ||
+ | **UPDATES** | ||
+ | < | ||
The QUIC analysis LUA scripts can be found here in the [[https:// | The QUIC analysis LUA scripts can be found here in the [[https:// | ||
+ | </ | ||
+ | |||
+ | |||
===== Network Security Monitoring for QUIC ===== | ===== Network Security Monitoring for QUIC ===== | ||
Line 25: | Line 32: | ||
==== Explaining the scripts ==== | ==== Explaining the scripts ==== | ||
+ | The scripts are on Github at [[https:// | ||
- | - A new protocol_hanlder called | + | - A new [[https:// |
- | - A Trisul simple_counter script that calls for every QUIC packet ( quic-simplecounter.lua ) | + | - A Trisul |
- | - The actual QUIC dissector , which returns a LUA table with all fields filled in ( quic-dissect.lua ) | + | - The actual QUIC dissector , which returns a LUA table with all fields filled in ( '' |
- A QUIC certificate decompressor using LuaJIT FFI into zlib | - A QUIC certificate decompressor using LuaJIT FFI into zlib | ||
- | The quic-dissect.lua script is where the real stuff happens, the rest of the files are plumbing into the Trisul platform. Start from there. | + | The [[https:// |
==== Output of the QUIC analysis ==== | ==== Output of the QUIC analysis ==== | ||
Line 47: | Line 55: | ||
===== Flow Tags ===== | ===== Flow Tags ===== | ||
- | If you want to pull out all QUIC flows , then go to Tools > Explore Flows > then search for tag=QUIC | + | To pull out all QUIC flows go to Tools > Explore Flows > then search for tag=QUIC |
+ | |||
+ | Click to zoom the image, you can see the QUIC flows tagged with QUIC, ConnectionID, | ||
Line 57: | Line 67: | ||
===== Extract X.509 Certificate in QUIC ===== | ===== Extract X.509 Certificate in QUIC ===== | ||
- | Just as we do for all SSL flows, we pull out the certificates from the server. | + | Just as we do for all SSL flows, we pull out the certificates |
This took a while for me to get the certificate extraction right due to the following issues. | This took a while for me to get the certificate extraction right due to the following issues. | ||
Line 65: | Line 75: | ||
* the certificate spans multiple UDP packets hence needs some reassembly. Put together a very naive reassembly code in quic-dissect.lua | * the certificate spans multiple UDP packets hence needs some reassembly. Put together a very naive reassembly code in quic-dissect.lua | ||
- | This is the result of the extracted certificate. | + | |
+ | Go to Resources > SSL Certs > press ENTER or search | ||
lua/quic.1544724504.txt.gz · Last modified: 2018/12/13 23:38 by veera