As someone who has personal projects that take untrusted zips as input, it is important to me to be able to fuzz the zip project to simulate possible inputs and to ensure the projects are not vulnerable. This commit adds a cargo fuzz module for reading and extracting input. The `fuzz` directory was scaffolded with a `cargo fuzz init` I added a CI step to guard against the fuzz module decaying over time.
98 lines
2.4 KiB
Markdown
98 lines
2.4 KiB
Markdown
zip-rs
|
|
======
|
|
|
|
[](https://github.com/zip-rs/zip/actions?query=branch%3Amaster+workflow%3ACI)
|
|
[](https://crates.io/crates/zip)
|
|
[](https://discord.gg/rQ7H9cSsF4)
|
|
|
|
[Documentation](https://docs.rs/zip/0.6.2/zip/)
|
|
|
|
> PSA: This version of the ZIP crate will not gain any new features,
|
|
> and will only be updated if major security issues are found.
|
|
|
|
Info
|
|
----
|
|
|
|
|
|
A zip library for rust which supports reading and writing of simple ZIP files.
|
|
|
|
Supported compression formats:
|
|
|
|
* stored (i.e. none)
|
|
* deflate
|
|
* bzip2
|
|
* zstd
|
|
|
|
Currently unsupported zip extensions:
|
|
|
|
* Encryption
|
|
* Multi-disk
|
|
|
|
Usage
|
|
-----
|
|
|
|
With all default features:
|
|
|
|
```toml
|
|
[dependencies]
|
|
zip = "0.6.2"
|
|
```
|
|
|
|
Without the default features:
|
|
|
|
```toml
|
|
[dependencies]
|
|
zip = { version = "0.6.2", default-features = false }
|
|
```
|
|
|
|
The features available are:
|
|
|
|
* `aes-crypto`: Enables decryption of files which were encrypted with AES. Supports AE-1 and AE-2 methods.
|
|
* `deflate`: Enables the deflate compression algorithm, which is the default for zip files.
|
|
* `bzip2`: Enables the BZip2 compression algorithm.
|
|
* `time`: Enables features using the [time](https://github.com/rust-lang-deprecated/time) crate.
|
|
* `zstd`: Enables the Zstandard compression algorithm.
|
|
|
|
All of these are enabled by default.
|
|
|
|
MSRV
|
|
----
|
|
|
|
Our current Minimum Supported Rust Version is **1.54.0**. When adding features,
|
|
we will follow these guidelines:
|
|
|
|
- We will always support the latest four minor Rust versions. This gives you a 6
|
|
month window to upgrade your compiler.
|
|
- Any change to the MSRV will be accompanied with a **minor** version bump
|
|
- While the crate is pre-1.0, this will be a change to the PATCH version.
|
|
|
|
Examples
|
|
--------
|
|
|
|
See the [examples directory](examples) for:
|
|
* How to write a file to a zip.
|
|
* How to write a directory of files to a zip (using [walkdir](https://github.com/BurntSushi/walkdir)).
|
|
* How to extract a zip file.
|
|
* How to extract a single file from a zip.
|
|
* How to read a zip from the standard input.
|
|
|
|
Fuzzing
|
|
-------
|
|
|
|
Fuzzing support is through [cargo fuzz](https://github.com/rust-fuzz/cargo-fuzz). To install cargo fuzz:
|
|
|
|
```bash
|
|
cargo install cargo-fuzz
|
|
```
|
|
|
|
To list fuzz targets:
|
|
|
|
```bash
|
|
cargo +nightly fuzz list
|
|
```
|
|
|
|
To start fuzzing zip extraction:
|
|
|
|
```bash
|
|
cargo +nightly fuzz run fuzz_read
|
|
```
|