Added functionality to import/export in raw bytes

This commit is contained in:
K Shiva Kiran 2024-03-28 20:04:19 +05:30
parent 6286051e12
commit e69cd8c2a7
3 changed files with 55 additions and 38 deletions

View File

@ -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);

View File

@ -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)
}
} }

View File

@ -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)
}
} }