Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cloudflare/wirefilter
An execution engine for Wireshark-like filters
https://github.com/cloudflare/wirefilter
compiler engine filters firewall firewall-configuration firewall-rules rust wireshark
Last synced: 3 days ago
JSON representation
An execution engine for Wireshark-like filters
- Host: GitHub
- URL: https://github.com/cloudflare/wirefilter
- Owner: cloudflare
- License: mit
- Created: 2019-02-18T17:40:37.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-12-27T14:04:31.000Z (15 days ago)
- Last Synced: 2025-01-02T01:05:39.781Z (10 days ago)
- Topics: compiler, engine, filters, firewall, firewall-configuration, firewall-rules, rust, wireshark
- Language: Rust
- Homepage: https://blog.cloudflare.com/building-fast-interpreters-in-rust/
- Size: 587 KB
- Stars: 966
- Watchers: 22
- Forks: 89
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-network-stuff - **499**星 - like filters (<a id="6fa0e0d1f898fba299b2566a33602841"></a>Wireshark)
README
# Wirefilter
[![Build status](https://img.shields.io/travis/com/cloudflare/wirefilter/master.svg)](https://travis-ci.com/cloudflare/wirefilter)
[![Crates.io](https://img.shields.io/crates/v/wirefilter-engine.svg)](https://crates.io/crates/wirefilter-engine)
[![License](https://img.shields.io/github/license/cloudflare/wirefilter.svg)](LICENSE)This is an execution engine for [Wireshark®](https://www.wireshark.org/)-like filters.
It contains public APIs for parsing filter syntax, compiling them into
an executable IR and, finally, executing filters against provided values.## Example
```rust
use wirefilter::{ExecutionContext, Scheme, Type};fn main() -> Result<(), Box> {
// Create a map of possible filter fields.
let scheme = Scheme! {
http.method: Bytes,
http.ua: Bytes,
port: Int,
};// Parse a Wireshark-like expression into an AST.
let ast = scheme.parse(r#"
http.method != "POST" &&
not http.ua matches "(googlebot|facebook)" &&
port in {80 443}
"#)?;println!("Parsed filter representation: {:?}", ast);
// Compile the AST into an executable filter.
let filter = ast.compile();// Set runtime field values to test the filter against.
let mut ctx = ExecutionContext::new(&scheme);ctx.set_field_value(scheme.get_field("http.method").unwrap(), "GET")?;
ctx.set_field_value(
scheme.get_field("http.ua").unwrap(),
"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:66.0) Gecko/20100101 Firefox/66.0",
)?;ctx.set_field_value(scheme.get_field("port").unwrap(), 443)?;
// Execute the filter with given runtime values.
println!("Filter matches: {:?}", filter.execute(&ctx)?); // true// Amend one of the runtime values and execute the filter again.
ctx.set_field_value(scheme.get_field("port").unwrap(), 8080)?;println!("Filter matches: {:?}", filter.execute(&ctx)?); // false
Ok(())
}
```## Fuzzing
There are fuzz tests in the fuzz directory.
Install afl:
```
cargo install afl --force
```Build `bytes` fuzz test:
```
cd fuzz/bytes
cargo afl build
```Run fuzz test (from inside `fuzz/bytes` directory):
```
cargo afl fuzz -i in -o out ../../target/debug/fuzz-bytes
```If you see an error like:
```
Looks like the target binary is not instrumented!
```Try deleting the compiled binary and re-building with `cargo afl build`.
## Licensing
Licensed under the MIT license. See the [LICENSE](LICENSE) file for details.