12 个重大版本

0.13.0 2024年7月17日
0.12.1 2023年4月12日
0.12.0 2023年2月13日
0.11.1 2022年6月21日
0.2.0 2021年2月22日

#1131 in Rust 模式

Download history 19/week @ 2024-04-22 14/week @ 2024-04-29 14/week @ 2024-05-06 26/week @ 2024-05-13 13/week @ 2024-05-20 40/week @ 2024-05-27 14/week @ 2024-06-03 17/week @ 2024-06-10 13/week @ 2024-06-17 22/week @ 2024-06-24 36/week @ 2024-07-01 2/week @ 2024-07-08 147/week @ 2024-07-15 7/week @ 2024-07-22 136/week @ 2024-07-29 14/week @ 2024-08-05

304 每月下载量
用于 8 crates

MIT 许可证

36KB
704

法语

安全感知线协议解析库。

此库包含各种线协议的解析器,并旨在用于网络安全传感器。

每个解析器都公开了一个通用接口,允许传感器引擎将字节输入解析器并接收解析后的元数据。字节应在会话层,因此引擎负责将传输层数据组装成会话有效载荷,然后将其输入此库。

此库旨在具有弹性,并尽可能多地解析野外看到的消息。如果消息无效或不符合规范,解析器不应丢弃该消息。解析器将在消息失败验证时设置标志,而不是返回错误。

每个解析器的接口都是统一和简单的,仅由几个函数组成

  • 测试负载是否为所讨论的协议(例如,这是 Modbus 吗?)
  • 向解析器提供更多字节
  • 设置回调以在协议元数据事件上调用(待办事项)
  • 指示某些字节不可用(即通知数据包丢失)(待办事项)
  • 指示会话已结束(待办事项)

该库公开了 Rust 和 C 绑定,以便轻松集成到现有的和未来的网络安全传感器平台。(待办事项)

用法

通过在项目的 Cargo.toml 依赖关系中包含解析器开始使用 SAWP。还需要基本库来使用常见类型。

最低支持的 rustc 版本为 1.63.0

示例

[dependencies]
sawp-modbus = "0.13.0"
sawp = "0.13.0"

FFI 支持

一些解析器为C/C++项目提供了外部函数接口。可以通过构建时启用ffi功能来启用FFI支持。

还提供了一个Makefile,以简化构建过程。请参阅此文件以获取更深入的文档。

# Install cbindgen which is required to generate headers
cargo install --force cbindgen

# Build headers and shared objects
make

贡献

此项目正在积极维护并接受开源贡献。有关详细信息,请参阅CONTRIBUTING

依赖关系

约2.5MB
约52K SLoC