#packets #vpn #tracing #trace #ts #target #hash

ya-packet-trace

Utility library for tracking VPN packets in yagna

1 unstable release

0.1.0 May 23, 2023

#39 in #packets

Download history 85/week @ 2024-11-15 97/week @ 2024-11-22 82/week @ 2024-11-29 89/week @ 2024-12-06 85/week @ 2024-12-13 62/week @ 2024-12-20 52/week @ 2024-12-27 114/week @ 2025-01-03 158/week @ 2025-01-10 151/week @ 2025-01-17 114/week @ 2025-01-24 119/week @ 2025-01-31 264/week @ 2025-02-07 250/week @ 2025-02-14 294/week @ 2025-02-21 290/week @ 2025-02-28

1,115 downloads per month
Used in 4 crates (2 directly)

GPL-3.0 license

22KB
221 lines

ya-packet-trace

Utility for tracing VPN packets

Usage

At any interesting point in the flow of VPN packets, invoke the macro like so:

packet_trace!(
    "possibly-slow-subsystem-before",
    {
        // code returning AsRef<[u8]> corresponding to the packet payload
    }
);

packet_trace_maybe!(
    "whatever",
    {
        // code returning Option<AsRef<[u8]>> corresponding to the packet payload
    }
);

Then, if the ya-packet-trace is compiled with the enabled feature, a log like possibly-slow-subsystem-before,<HASH>,<TS> will be printed at TRACE level to target packet-trace.

  • <HASH> is 16-character, 0-padded hex-digest of FxHash output
  • <TS> is current datetime as formatted by chrono with the following format string: %Y-%m-%dT%H:%M:%S%.6f%z.

Dependencies

~1.5MB
~22K SLoC