Added functionality to import/export in raw bytes
This commit is contained in:
parent
6286051e12
commit
e69cd8c2a7
|
@ -10,16 +10,18 @@ fn main() {
|
||||||
let msg2 = "This is another message";
|
let msg2 = "This is another message";
|
||||||
let key2 = fb.add(msg2.as_bytes());
|
let key2 = fb.add(msg2.as_bytes());
|
||||||
|
|
||||||
// Export
|
// Export as base64
|
||||||
let cipher = fb.export_cipher();
|
let cipher = fb.export_cipher();
|
||||||
let keybase = fb.export_keybase();
|
let keybase = fb.export_keybase();
|
||||||
let key1_exp = key1.export();
|
let key1_exp = key1.export();
|
||||||
let key2_exp = key2.export();
|
// Or as raw bytes
|
||||||
|
let key2_exp = key2.to_bytes();
|
||||||
|
|
||||||
// Import
|
// Import from base64
|
||||||
let fb_new = FB128::import(&cipher, &keybase).unwrap();
|
let fb_new = FB128::import(&cipher, &keybase).unwrap();
|
||||||
let key1_imp = FBKey::import(&key1_exp).unwrap();
|
let key1_imp = FBKey::import(&key1_exp).unwrap();
|
||||||
let key2_imp = FBKey::import(&key2_exp).unwrap();
|
// Or as raw bytes
|
||||||
|
let key2_imp = FBKey::from_bytes(&key2_exp).unwrap();
|
||||||
|
|
||||||
// Decryption
|
// Decryption
|
||||||
let decr1 = fb_new.decrypt(&key1_imp).unwrap();
|
let decr1 = fb_new.decrypt(&key1_imp).unwrap();
|
||||||
|
@ -30,7 +32,7 @@ fn main() {
|
||||||
CipherText: \n{cipher}\n
|
CipherText: \n{cipher}\n
|
||||||
KeyBase: \n{keybase}\n
|
KeyBase: \n{keybase}\n
|
||||||
Key 1: {key1_exp}
|
Key 1: {key1_exp}
|
||||||
Key 2: {key2_exp}
|
Key 2: {key2_exp:?}
|
||||||
");
|
");
|
||||||
|
|
||||||
assert_eq!(msg1.as_bytes(), decr1);
|
assert_eq!(msg1.as_bytes(), decr1);
|
||||||
|
|
|
@ -4,39 +4,38 @@ use base64::{prelude::BASE64_STANDARD, Engine};
|
||||||
|
|
||||||
pub trait Encode<T>
|
pub trait Encode<T>
|
||||||
where
|
where
|
||||||
Self: FBObjTrait<T>,
|
Self: FBObjTrait<T>,
|
||||||
T: ArrayEncoding + Bounded,
|
T: ArrayEncoding + Bounded,
|
||||||
{
|
{
|
||||||
fn export_cipher(&self) -> String {
|
fn to_bytes_cipher(&self) -> Vec<u8> {
|
||||||
let c_bytes: Vec<u8> = self.cipher().iter()
|
self.cipher().iter()
|
||||||
.flat_map(|bigint| bigint.to_le_byte_array())
|
.flat_map(|bigint| bigint.to_le_byte_array())
|
||||||
.collect();
|
.collect()
|
||||||
|
|
||||||
BASE64_STANDARD.encode(c_bytes)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn export_keybase(&self) -> String {
|
fn to_bytes_keybase(&self) -> Vec<u8> {
|
||||||
let r_bytes: Vec<u8> = self.keybase().iter()
|
self.keybase().iter()
|
||||||
.flat_map(|bigint| bigint.to_le_byte_array())
|
.flat_map(|bigint| bigint.to_le_byte_array())
|
||||||
.collect();
|
.collect()
|
||||||
|
}
|
||||||
|
|
||||||
BASE64_STANDARD.encode(r_bytes)
|
fn export_cipher(&self) -> String {
|
||||||
}
|
BASE64_STANDARD.encode(self.to_bytes_cipher())
|
||||||
|
}
|
||||||
|
|
||||||
fn import(cipher: &str, keybase: &str) -> Result<FBObj<T>, FBError> {
|
fn export_keybase(&self) -> String {
|
||||||
let c_bytes = BASE64_STANDARD.decode(cipher)
|
BASE64_STANDARD.encode(self.to_bytes_keybase())
|
||||||
.map_err(|_| FBError::DecodeError)?;
|
}
|
||||||
let r_bytes = BASE64_STANDARD.decode(keybase)
|
|
||||||
.map_err(|_| FBError::DecodeError)?;
|
|
||||||
|
|
||||||
let chunk_to_uint = |chunk| {
|
fn from_bytes(cipher: &[u8], keybase: &[u8]) -> Result<FBObj<T>, FBError> {
|
||||||
T::from_le_byte_array(
|
let chunk_to_uint = |chunk| {
|
||||||
GenericArray::clone_from_slice(chunk)
|
T::from_le_byte_array(
|
||||||
)};
|
GenericArray::clone_from_slice(chunk)
|
||||||
let c: Vec<T> = c_bytes.chunks_exact(T::BYTES)
|
)};
|
||||||
|
let c: Vec<T> = cipher.chunks_exact(T::BYTES)
|
||||||
.map(chunk_to_uint)
|
.map(chunk_to_uint)
|
||||||
.collect();
|
.collect();
|
||||||
let r: Vec<T> = r_bytes.chunks_exact(T::BYTES)
|
let r: Vec<T> = keybase.chunks_exact(T::BYTES)
|
||||||
.map(chunk_to_uint)
|
.map(chunk_to_uint)
|
||||||
.collect();
|
.collect();
|
||||||
if r.len() > c.len() || r.len() < 2 {
|
if r.len() > c.len() || r.len() < 2 {
|
||||||
|
@ -45,4 +44,13 @@ where
|
||||||
|
|
||||||
Ok(FBObj {c, r})
|
Ok(FBObj {c, r})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn import(cipher: &str, keybase: &str) -> Result<FBObj<T>, FBError> {
|
||||||
|
let c_bytes = BASE64_STANDARD.decode(cipher)
|
||||||
|
.map_err(|_| FBError::DecodeError)?;
|
||||||
|
let r_bytes = BASE64_STANDARD.decode(keybase)
|
||||||
|
.map_err(|_| FBError::DecodeError)?;
|
||||||
|
|
||||||
|
Self::from_bytes(&c_bytes, &r_bytes)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
25
src/fbkey.rs
25
src/fbkey.rs
|
@ -8,19 +8,19 @@ pub struct FBKey {
|
||||||
|
|
||||||
impl FBKey {
|
impl FBKey {
|
||||||
|
|
||||||
pub fn export(&self) -> String {
|
pub fn to_bytes(&self) -> Vec<u8> {
|
||||||
let binc = DefaultOptions::new();
|
let binc = DefaultOptions::new();
|
||||||
let indice_bytes = binc.serialize(&self.indices)
|
binc.serialize(&self.indices)
|
||||||
.unwrap();
|
.expect("Should be fine")
|
||||||
|
|
||||||
BASE64_STANDARD.encode(&indice_bytes)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn import(key_str: &str) -> Result<FBKey, FBError> {
|
pub fn export(&self) -> String {
|
||||||
|
BASE64_STANDARD.encode(&self.to_bytes())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn from_bytes(fbkey: &[u8]) -> Result<FBKey, FBError> {
|
||||||
let binc = DefaultOptions::new();
|
let binc = DefaultOptions::new();
|
||||||
let indice_bytes = BASE64_STANDARD.decode(key_str)
|
let indices: Vec<_> = binc.deserialize(&fbkey)
|
||||||
.map_err(|_| FBError::DecodeError)?;
|
|
||||||
let indices: Vec<_> = binc.deserialize(&indice_bytes)
|
|
||||||
.map_err(|_| FBError::DecodeError)?;
|
.map_err(|_| FBError::DecodeError)?;
|
||||||
if indices.len() < 2 {
|
if indices.len() < 2 {
|
||||||
return Err(FBError::DecodeError);
|
return Err(FBError::DecodeError);
|
||||||
|
@ -28,4 +28,11 @@ impl FBKey {
|
||||||
|
|
||||||
Ok (FBKey {indices})
|
Ok (FBKey {indices})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn import(key_str: &str) -> Result<FBKey, FBError> {
|
||||||
|
let indice_bytes = BASE64_STANDARD.decode(key_str)
|
||||||
|
.map_err(|_| FBError::DecodeError)?;
|
||||||
|
|
||||||
|
Self::from_bytes(&indice_bytes)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue