140 breaking releases

new 0.146.0 Jan 9, 2025
0.145.0 Dec 12, 2024
0.144.0 Dec 5, 2024
0.143.0 Nov 30, 2024
0.4.0 Mar 23, 2021

#174 in Cryptography

Download history 353/week @ 2024-09-24 25/week @ 2024-10-01 10/week @ 2024-10-08 417/week @ 2024-10-15 536/week @ 2024-10-22 23/week @ 2024-10-29 15/week @ 2024-11-05 131/week @ 2024-11-12 20/week @ 2024-11-19 274/week @ 2024-11-26 186/week @ 2024-12-03 226/week @ 2024-12-10 15/week @ 2024-12-17 133/week @ 2025-01-07

153 downloads per month
Used in 3 crates

Apache-2.0

1.5MB
36K SLoC

ockam

crate docs license discuss

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

End-to-end encrypted, mutually authenticated, secure communication.

A hands-on guide 👉.

Data, within modern distributed applications, are rarely exchanged over a single point-to-point transport connection. Application messages routinely flow over complex, multi-hop, multi-protocol routes — across data centers, through queues and caches, via gateways and brokers — before reaching their end destination.

Transport layer security protocols are unable to protect application messages because their protection is constrained by the length and duration of the underlying transport connection.

Ockam makes it simple for our applications to guarantee end-to-end integrity, authenticity, and confidentiality of data. We no longer have to implicitly depend on the defenses of every machine or application within the same, usually porous, network boundary. Our application's messages don't have to be vulnerable at every point, along their journey, where a transport connection terminates.

Instead, our application can have a strikingly smaller vulnerability surface and easily make granular authorization decisions about all incoming information and commands.

Features

  • End-to-end encrypted, mutually authenticated secure channels.
  • Multi-hop, multi-transport, application layer routing.
  • Key establishment, rotation, and revocation - for fleets, at scale.
  • Lightweight, Concurrent, Stateful Workers that enable simple APIs.
  • Attribute-based Access Control - credentials with selective disclosure.
  • Add-ons for a variety of operating environments, transport protocols, and cryptographic hardware.

Documentation

Tutorials, examples and reference guides are available at docs.ockam.io.

Usage

Add this to your Cargo.toml:

[dependencies]
ockam = "0.146.0"

License

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

Dependencies

~15–49MB
~1M SLoC