Skip to content

SecurityRonin/udf-forensic

Repository files navigation

Crates.io docs.rs License: Apache-2.0 CI Sponsor

Pure-Rust forensic UDF (ECMA-167 / OSTA) reader — volume recognition, partition-map classification, File Entry and directory traversal, and file data over any Read + Seek.

Reads the UDF filesystem on DVD, Blu-ray, and packet-written optical media, with no unsafe. Type-2 partitions (Virtual/VAT, Sparable, Metadata) are detected and reported rather than silently mis-read.

Install

[dependencies]
udf-forensic = "0.1"

Quick start

use std::fs::File;

let mut f = File::open("disc.udf")?;
if udf_forensic::detect_udf(&mut f) {
    if let Some(st) = udf_forensic::parse_udf_state(&mut f) {
        println!("{:?}, {} partition map(s)", st.partition_kind, st.partition_map_count);
        if let Some(entries) =
            udf_forensic::read_dir_at_lba(&mut f, st.partition_start, st.root_fe_lba)
        {
            for e in entries {
                println!("  {}  {}  {} bytes", if e.is_dir { "dir " } else { "file" }, e.name, e.size);
            }
        }
    }
}

What it parses

Capability Notes
Volume recognition NSR02 / NSR03 sequence detection
Partition maps Physical (Type 1); Virtual / Sparable / Metadata (Type 2) classified + reported
Directory traversal File Entry + File Identifier Descriptors, OSTA CS0 names
File data short/long extent reading from the File Entry

Validation

Production code is #![forbid(unsafe_code)] with bounds-checked reads, and the bootstrap path distinguishes a genuine read failure (Err) from a structural "not UDF" negative (Ok(None)). Partition-map classification is validated against real mkudffs-authored images committed to tests/data/, cross-checked by the independent udfinfo (udftools) decoder: the tests assert that VAT (cdr/1.50) and Sparable (dvdrw/2.01) images classify correctly and that the resolved partition-space start matches udfinfo's reported PSPACE block (Tier 1). Volume-recognition and directory/file-data oracles (isoinfo / mount -t udf) remain named gaps. The full evidence tiers, oracles, and gaps are documented at validation.

Features

  • serde — derive Serialize/Deserialize for partition-kind and entry types.

Related

Part of the Security Ronin forensic toolkit. Sibling filesystems: hfsplus-forensic, ext4fs-forensic, ntfs-forensic. Consumed by iso9660-forensic for optical UDF/bridge discs.


Privacy Policy · Terms of Service · © 2026 Security Ronin Ltd

About

Forensic-grade UDF (ECMA-167/OSTA) reader — volume recognition, partition maps, File Entry/FID traversal, file data

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages