#binary-parser #binary-tree #security #extract #cargo #json #auditable

auditable-info

High-level crate to extract the dependency trees embedded in binaries by cargo auditable

12 unstable releases (4 breaking)

0.9.0 Nov 11, 2024
0.8.0 Jul 30, 2024
0.7.2 May 8, 2024
0.7.0 Apr 27, 2023
0.5.0-alpha.4 Sep 18, 2022

#257 in Encoding

Download history 10155/week @ 2024-09-26 10319/week @ 2024-10-03 14144/week @ 2024-10-10 11589/week @ 2024-10-17 11439/week @ 2024-10-24 13793/week @ 2024-10-31 10372/week @ 2024-11-07 11331/week @ 2024-11-14 11771/week @ 2024-11-21 12140/week @ 2024-11-28 13055/week @ 2024-12-05 17346/week @ 2024-12-12 16532/week @ 2024-12-19 14380/week @ 2024-12-26 22126/week @ 2025-01-02 27683/week @ 2025-01-09

84,787 downloads per month
Used in 3 crates

MIT/Apache

30KB
379 lines

High-level crate to extract the dependency trees embedded in binaries by cargo auditable.

Deserializes them to a JSON string or Rust data structures, at your option.

Features

  • Binary parsing designed from the ground up for resilience to malicious inputs.
  • 100% memory-safe Rust, including all dependencies. (There is some unsafe in serde_json and its dependencies, but only in serialization, which isn't used here).
  • Cross-platform, portable, easy to cross-compile. Runs on any Rust target with std.
  • Parses binaries from any supported platform, not just the platform it's running on.
  • Supports setting size limits for both input and output, to protect against OOMs and zip bombs.

Usage

// Uses the default limits: 1GiB input file size, 8MiB audit data size
let info = audit_info_from_file(&PathBuf::from("path/to/file"), Default::default())?;

Functions to load the data from a Read instance or from &[u8] are also provided, see the documentation.

Alternatives

rust-audit-info is a command-line interface to this crate.

If you need a lower-level interface than the one provided by this crate, use the auditable-extract and auditable-serde crates.

Dependencies

~225–780KB
~16K SLoC