#ockam #p2p #encryption #cryptography #crypto

ockam_ebpf

eBPF program used by Ockam Privileged Portals

2 unstable releases

0.6.0 Dec 4, 2024
0.5.0 Nov 26, 2024

#393 in Network programming

Download history 883/week @ 2024-11-23 1211/week @ 2024-11-30 1152/week @ 2024-12-07

3,246 downloads per month
Used in 3 crates (via ockam_transport_tcp)

Apache-2.0

23KB
507 lines

ockam_ebpf

crate docs license discuss

Ockam is a library for building devices that communicate securely, privately and trustfully with cloud services and other devices.

This crate contains the eBPF part of Ockam Reliable TCP Portals.

Build

This crate exposes eBPF binary through the EBPF_BINARY static constant in the root of the crate. That binary can be used to attach Ockam eBPF to network devices.

Features

By default, this crate ships a prebuilt eBPF binary downloaded from the corresponding GitHub release artifacts. This allows to build Ockam without all the dependencies that are required to build eBPF.

  • build - build the eBPF locally instead of downloading the prebuilt binary. This might be useful during development and debugging.
  • logging - this will enable logs for eBPF. Note that eBPF sends logs to the user space using AsyncPerfEventArray, therefore it implies performance penalty.
cargo build

Requirements to build eBPF

Please refer to ockam_ebpf_impl/README.md

Requirements to use eBPF

Using ockam with eBPFs requires:

  • Linux
  • root (CAP_BPF, CAP_NET_RAW, CAP_NET_ADMIN, CAP_SYS_ADMIN)

Usage

Add this to your Cargo.toml:

[dependencies]
ockam_ebpf = "0.5.0"

License

This code is licensed under the terms of the Apache License 2.0.

No runtime deps

~0–1.5MB
~19K SLoC