#windows-registry #registry #windows #winapi #cybersecurity #forensics #parser

frnsc-liveregistry-rs

Implements RegistryReader from forensic-rs using the Windows API to access the registry of a live system

11 releases (6 breaking)

0.13.0 Apr 5, 2024
0.9.1 Feb 22, 2024
0.7.0 Nov 13, 2023
0.2.0 Feb 23, 2023
0.1.0 Sep 27, 2022

#114 in Windows APIs

Download history 16/week @ 2024-09-23 19/week @ 2024-09-30 4/week @ 2024-10-14 2/week @ 2024-10-28 2/week @ 2024-11-04 64/week @ 2024-12-09

64 downloads per month
Used in 3 crates

MIT license

22KB
437 lines

Windows Registry Reader

crates.io documentation MIT License Rust

Implements RegistryReader using the Windows API to access the registry of a live system.

Usage

fn test_reg(reg : &mut Box<dyn RegistryReader>) {
    let keys = reg.enumerate_keys(HkeyCurrentUser).unwrap();
    assert!(keys.contains("SOFTWARE"));
    assert!(keys.contains("Microsoft"));
}

let registry = Box::new(LiveRegistryReader::new());
let key = registry.open_key(HkeyCurrentUser, "Volatile Environment").unwrap();
let value : String = registry.read_value(key, "USERNAME").unwrap().try_into().unwrap();
assert!(value.len() > 1);
let values : Vec<String> = registry.enumerate_values(key).unwrap();

test_reg(&mut registry);

Dependencies

~0.3–35MB
~537K SLoC