9 releases (breaking)

0.6.1 Apr 13, 2023
0.5.1 Oct 27, 2021
0.5.0 Jul 31, 2021
0.4.0 Jan 27, 2021
0.1.0 Jul 31, 2018

#577 in Cryptography

Download history 6619/week @ 2024-07-25 6079/week @ 2024-08-01 6744/week @ 2024-08-08 6405/week @ 2024-08-15 7334/week @ 2024-08-22 5244/week @ 2024-08-29 6125/week @ 2024-09-05 5051/week @ 2024-09-12 4930/week @ 2024-09-19 7388/week @ 2024-09-26 5300/week @ 2024-10-03 6286/week @ 2024-10-10 6070/week @ 2024-10-17 6239/week @ 2024-10-24 6055/week @ 2024-10-31 6029/week @ 2024-11-07

25,505 downloads per month
Used in 37 crates (8 directly)

MIT/Apache

61KB
1K SLoC

fpe Crates.io

This crate contains pure-Rust implementations of format-preserving encryption algorithms.

The following algorithms are implemented:

This crate requires Rust version 1.56 or greater.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.


lib.rs:

Format-preserving encryption algorithms.

Example

extern crate aes;
extern crate fpe;

use aes::Aes256;
use fpe::ff1::{BinaryNumeralString, FF1};

let key = [0; 32];
let radix = 2;
let pt = [0xab, 0xcd, 0xef];

let ff = FF1::<Aes256>::new(&key, radix).unwrap();
let ct = ff.encrypt(&[], &BinaryNumeralString::from_bytes_le(&pt)).unwrap();
assert_eq!(ct.to_bytes_le(), [0x75, 0xfb, 0x62]);

let p2 = ff.decrypt(&[], &ct).unwrap();
assert_eq!(p2.to_bytes_le(), pt);

Dependencies

~1MB
~20K SLoC