package noise

  1. Overview
  2. Docs
The Noise Protocol Framework

Install

Dune Dependency

Authors

Maintainers

Sources

noise-0.1.0.tbz
sha256=6809bc260f7069faadb5cc75223eaa200295bf50bd0cae59a1c0eac244889461
md5=774071c77e418b5c6ab6a08840b2fa73

README.md.html

ocaml-noise

OCaml implementation of the Noise Protocol Framework.

Not ready for primetime.

More precisely, some primitives are implemented in an ad hoc manner. This passes a good amount of test vectors, but this has not been properly fuzzed and there are no countermeasures with respect to side channel attacks.

What is this NOT?

This is not an implementation of a full cryptographic protocol that you can drop into your application and have secure channels.

What is this?

This is an implementation of the Noise Protocol Framework. It consists of building bricks that can be used to create a secure cryptographic protocol.

Because of the way Noise works, it is possible to process messages in full without dealing with I/O or buffering. So, this library only deals with the handshake and encrypting/decrypting payloads.

How to use this?

Refer to the examples in test/examples/ for an example, but basically:

  • pick a protocol

  • import or generate the relevant keys on each side

  • create initial states using Noise.State.make and Noise.Protocol.initialize

  • drive the handshake using Noise.Protocol.read_message and Noise.Protocol.write_message

  • check that the handshake is completed (see Noise.State.handshake_hash)

  • send transport messages using Noise.Protocol.read_message and Noise.Protocol.write_message

Resources

OCaml

Innovation. Community. Security.