Zff

crate Docs Apache2/MIT licensed Rust Version website

Zff version 2 is in the testing stage. It has only been tested by me internally so far and requires further independent testing. Corresponding tools can also be used for testing (see table below).

Zff (Z forensic file format) is a completely new designed file format to store and handle the contents and structure of a partial or entire disk image, physical memory or logical file/folder structures. The focus of zff is on speed, security and modularity in concert with forensic requirements. The modular design promises high maintainability and scalability. Zff is an alternative to the ewf and aff file formats and is not compatible with them.

You can learn more about the file format and its specifications at https://zff.dev.

Features included in Zff(v2) (most of them are optional)

Zff tools and libraries

There are several tools (and this library) to work with zff containers (or acquire them). All tools and libraries are written in pure Rust.

| Name | Type | Description | Crates.io | MRSV |------|:----:|:------------|:---------:|:----:| | zff | library | Library to handle the zff format | crates.io | 1.58.1 | | zffacquire | binary | Tool to acquire disk images in zff format | crates.io | 1.58.1 | | zffanalyze | binary | Tool to get information about a zff container | crates.io | 1.58.1 | | zffmount | binary | Tool to mount a zff container with FUSE (similar to xmount) | crates.io | 1.58.1 |

Benchmarks

The following benchmarks were all run on a notebook, which has the following specifications: - Dell XPS 13 9310 2-in-1 - 11th Gen Intel(R) Core(TM) i7-1165G7 @ 2.80GHz - 32GB LPDDR4x 4267 Mhz - KBG40ZPZ1T02 NVMe KIOXIA 1024GB\ The installed operating system was Gentoo Linux.\ Input and output storage device was the internal NVMe.

The following benchmark was created for a \~20GB prebuilt image, which was generated using this script.

Acquisition time \ ¹Using Guymager 0.8.12, with the default guymager.cfg, MD5 hash calculation, without "HashVerifyDest".\ ²Using Guymager 0.8.12, with enabled Aff support and Aff compression level 1 in guymager.cfg, with MD5 hash calculation, without "HashVerifyDest".\ ³using zffacquire physical -i raw/example01.dd -o zff_lz4 -z lz4\ ⁴using zffacquire physical -i raw/example01.dd -o zff -S per_chunk_signatures\ ⁵using zffacquire physical -i raw/example01.dd -o zff -p 123\ ⁶using zffacquire physical -i raw/example01.dd -o zff\ ⁷using ewfacquire example01.dd -t example01_ewf -f encase7-v2 -b 64 -c fast -S 7.9EiB -u\ ⁸using ewfacquire example01.dd -t example01_ewf -b 64 -c fast -S 7.9EiB -u, using ewfacquire 20171104.\

As you can see, zffacquire is in most cases much faster than the other tools - even if you store the data encrypted. Using zffacquire with the default values gives no performance disadvantage. The situation is different, of course, with an additional signature operation (but the same would also apply to Guymager with "HashVerifyDest" and/or "HashVerifySrc" enabled).\ \ Two of the acquired images (The Guymager-e01-image at number 1, acquired in the benchmark process above and the zff-z01-image acquired with the default options of zffacquire, see above at number 6), the acquired Ex01-image (number 7) and the acquired Aff-image (by Guymager, see number 2), were used as the basis for the read speed benchmark. For the benchmark, xmount and zffmount was used to FUSE mount the appropriate images. Next, dd was used to benchmark the read speed.

Read speed \ ¹The following commands were used: bash zffmount -i zff.z01 -m /tmp/zffmount dd if=/tmp/zffmount/zff_image.dd of=/dev/null bs=1M ²The following commands were used: bash affuse aff_image.aff /tmp/affmount dd if=/tmp/affmount/aff_example01.aff.raw of=/dev/null bs=1M ³The following commands were used: bash xmount --in aff aff_image.aff /tmp/affmount dd if=/tmp/affmount/aff_image.dd of=/dev/null bs=1M ⁴The following commands were used: bash xmount --in ewf ewfacquired.Ex01 /tmp/ewfmount dd if=/tmp/ewfmount/ewfacquired.dd of=/dev/null bs=1M ⁵The following commands were used: bash xmount --in ewf guymager.e01 /tmp/ewfmount dd if=/tmp/ewfmount/guymager.dd of=/dev/null b=1M

Zff layout

See the website for further information.

License

Zff is open source and Apache 2.0 and MIT licensed. This should ensure compliance to use with both open source and commercial software.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.