#nonce #encryption #symmetric #anything #generated #randomly #perform

simplestcrypt

Simplest way to perform a symmetric encryption, using a preshared key. Very small wrapper around aes-siv crate, with randomly generated nonces, for anything more advanced, use aes-siv instead

4 releases

0.1.3 Mar 24, 2022
0.1.2 Nov 19, 2020
0.1.1 Nov 18, 2020
0.1.0 Nov 18, 2020

#986 in Cryptography

Download history 7/week @ 2023-12-17 10/week @ 2024-02-18 9/week @ 2024-02-25 9/week @ 2024-03-03 12/week @ 2024-03-10 1/week @ 2024-03-17 54/week @ 2024-03-31

69 downloads per month

MIT license

8KB
77 lines

simplestcrypt

Simplest way to perform a symmetric encryption, using a preshared key. Very small wrapper around aes-siv crate, with randomly generated nonces, for anything more advanced, use aes-siv instead

Example

use std::str;
fn main() {
    let payload = "Hello world!".as_bytes();
    let password = b"hello wooooooooo";

    let encrypted = simplestcrypt::encrypt_and_serialize(&password[..], &payload).unwrap();
    let plain = simplestcrypt::deserialize_and_decrypt(&password[..], &encrypted).unwrap();

    println!("{:?}", str::from_utf8(&plain));
}

Serialization notes

Bincode adds 8 bytes in between the serialized nonce and the serialized ciphertext so it looks like:

Bytes Description
0 - 15 Nonce used when encrypting the ciphertext
16 - 23 The lenght of the cyphertext
24 - .. Cyphertext

This needs to be taken into account when interoperating with other libraries

Dependencies

~1.8–2.5MB
~55K SLoC