Crates.io | sawp |
lib.rs | sawp |
version | 0.13.1 |
source | src |
created_at | 2021-01-18 20:52:09.663619 |
updated_at | 2024-10-02 19:19:48.42271 |
description | Security Aware Wire Protocol parsing library |
homepage | https://github.com/CybercentreCanada/sawp |
repository | https://github.com/CybercentreCanada/sawp |
max_upload_size | |
id | 343669 |
size | 17,155 |
This library contains parsers for various wire protocols, and is intended to be used in network security sensors.
Each parser exposes a common interface that allows the sensor engine to feed bytes into the parser and receive parsed metadata back. The bytes are expected to be at the session layer, so the engine is responsible for assembling transport layer data into a session payload, which is then fed into this library.
This library aims to be resilient and parse as many messages as possible that are seen in the wild. If a message is invalid or out-of-spec, it should not be discarded by the parser. Parsers will set flags on the message when it fails validation instead of returning an error.
The interface to each parser is uniform and simple, consisting of only a few functions to:
The library exposes Rust and C bindings for easy integration into existing and future network security sensor platforms. (todo)
Start using SAWP by including a parser in your project's Cargo.toml
dependencies. The base library will also be required for using common
types.
The minimum supported version of rustc
is 1.63.0
.
[dependencies]
sawp-modbus = "0.13.1"
sawp = "0.13.1"
Some parsers have a foreign function interface for use in C/C++ projects.
FFI Support can be enabled by building with the ffi
feature.
A Makefile is also provided to ease the build process. Please refer to this file for more in-depth documentation.
# Install cbindgen which is required to generate headers
cargo install --force cbindgen
# Build headers and shared objects
make
This project is actively maintained and accepting open source contributions. See CONTRIBUTING for more details.