#encryption #encryption-key #symmetric

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

5 releases

0.1.4 Aug 21, 2024
0.1.3 Mar 24, 2022
0.1.2 Nov 19, 2020
0.1.1 Nov 18, 2020
0.1.0 Nov 18, 2020

#553 in Cryptography

Download history 11/week @ 2024-07-19 45/week @ 2024-07-26 11/week @ 2024-08-02 1/week @ 2024-08-09 118/week @ 2024-08-16 19/week @ 2024-08-23 7/week @ 2024-08-30 17/week @ 2024-09-06 24/week @ 2024-09-13 35/week @ 2024-09-20 81/week @ 2024-09-27 29/week @ 2024-10-04

174 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.5–2.3MB
~48K SLoC