4 releases (2 breaking)

0.5.1 Oct 31, 2023
0.5.0 Oct 22, 2023
0.4.0 Oct 17, 2023
0.3.2 Oct 8, 2023

#389 in Images

Download history 942/week @ 2024-09-02 779/week @ 2024-09-09 667/week @ 2024-09-16 795/week @ 2024-09-23 1198/week @ 2024-09-30 870/week @ 2024-10-07 919/week @ 2024-10-14 755/week @ 2024-10-21 1182/week @ 2024-10-28 1347/week @ 2024-11-04 1220/week @ 2024-11-11 1161/week @ 2024-11-18 364/week @ 2024-11-25 1123/week @ 2024-12-02 670/week @ 2024-12-09 828/week @ 2024-12-16

2,993 downloads per month

MIT license

145KB
3K SLoC

webpsan   Fuzzing Status

A Rust WebP format "sanitizer".

The sanitizer currently simply checks the validity of a WebP file input, so that passing malformed files to an unsafe parser can be avoided.

Usage

The main entry points to the sanitizer are sanitize, which take a Read + Skip input. The Skip trait represents a subset of the Seek trait; an input stream which can be skipped forward, but not necessarily seeked to arbitrary positions.

let example_input = b"RIFF\x14\0\0\0WEBPVP8L\x08\0\0\0\x2f\0\0\0\0\x88\x88\x08";
webpsan::sanitize(std::io::Cursor::new(example_input)).unwrap();

The parse module also contains a less stable and undocumented API which can be used to parse individual WebP chunk types.

API Documentation
Private Documentation

Contributing Bug Reports

GitHub is the project's bug tracker. Please search for similar existing issues before submitting a new one.

Testing

libwebp-based verification of webpsan tests can be enabled using the webpsan-test/libwebp feature. libwebp is linked statically, so does not need to be installed for the tests.

The test_data integration test runs on sample data files in the private test-data submodule. If you have access to this repo, you may check out the submodule manually:

$ git submodule update --init --checkout

Fuzz Testing

Fuzz testing via both cargo afl and cargo fuzz is supported. See the Rust Fuzz Book for more details. To run AFL-based fuzzing:

$ cargo install cargo-afl
$ cd fuzz-afl
$ ./fuzz $num_cpus

To run libFuzzer-based fuzzing:

$ cargo +nightly install cargo-fuzz
$ cargo +nightly fuzz run sanitize -- -dict=fuzz/webp.dict -seed_inputs=fuzz/input/smallest-possible.webp

OSS-Fuzz

Continuous fuzz testing is also provided by OSS-Fuzz.

Build Status
Code Coverage
Bugs Found

License

Licensed under MIT.

Dependencies

~4MB
~79K SLoC