#p2p #chat #networking #secret-key #crypto #cli

app yume

yume - An encrypted peer-to-peer IPv6 UDP messaging terminal client

3 unstable releases

0.2.0 May 31, 2020
0.1.1 May 8, 2020
0.1.0 Apr 12, 2020

#68 in #secret-key

MIT license

33KB
733 lines

yume Build Status

An encrypted peer-to-peer IPv6 UDP messaging terminal client built with Rust

Installation

cargo install yume

Usage

To establish a connection between two peers, you need to start the client and provide your IPv6 and the one of the peer you want to reach:

yume 2001:3984:3989::10 2001:3984:3989::20

The first peer needs to follow the instructions and press enter to get a new secret key. It's up to you to share this key in a secure way, the client does not share the key with the other connected peer!

yume - An encrypted peer-to-peer IPv6 UDP messaging terminal client
Version 0.1.0

Enter secret key or press enter to generate a new one:

6uVsz9uK3KGqEfX0yg9CUpYk8TusSsnnNYmcSnmyhxwvWllFtFAqm1N7i5JYEysDELDq5EyuMYQwPPwgE2/0eg==

You can start typing!

The second peer, when prompted, should paste or enter the secret key manually.

Available commands - in progress

/help
/quit

Security

This crate uses the ChaCha20Poly1305 - Authenticated Encryption with Associated Data (AEAD) - see https://github.com/RustCrypto/AEADs/tree/master/chacha20poly1305. Every message is encrypted with the secret key (not shared) and sent via UDP to the remote peer. The remote peer verifies the signature and the nonce to decrypt the message.

Dependencies

~15–27MB
~510K SLoC