pub struct XORCryptor<T> { /* private fields */ }Implementations§
Source§impl XORCryptor<V2>
impl XORCryptor<V2>
pub fn new_v2(seed: Option<usize>) -> Self
Sourcepub fn update_cipher(&mut self, key: &[u8], spice_seed: usize) -> XRCResult<()>
pub fn update_cipher(&mut self, key: &[u8], spice_seed: usize) -> XRCResult<()>
Used to for updating [cipher::Cipher] with
key and spice_seed.
spice_seed is multiplied by seed used
with XORCryptor::new_v2.
DO NOT call this if you don’t know what you are doing.
Sourcepub fn encrypt_vec(&mut self, key: &[u8], buffer: Vec<u8>) -> XRCResult<Vec<u8>>
pub fn encrypt_vec(&mut self, key: &[u8], buffer: Vec<u8>) -> XRCResult<Vec<u8>>
Encrypts the vector by randomizing cipher generation from keys.
Slower throughput due to chaining randomized cipher.
Sourcepub fn encrypt_v2(key: &[u8], buffer: Vec<u8>) -> XRCResult<Vec<u8>>
pub fn encrypt_v2(key: &[u8], buffer: Vec<u8>) -> XRCResult<Vec<u8>>
Encrypts the vector by randomizing cipher generation from keys.
Slower throughput due to chaining randomized cipher.
pub fn decrypt_vec(&mut self, key: &[u8], buffer: Vec<u8>) -> XRCResult<Vec<u8>>
Source§impl<T: XrcVersion> XORCryptor<T>
impl<T: XrcVersion> XORCryptor<T>
pub fn get_cipher(&self) -> &[usize]
Source§impl XORCryptor<V1>
impl XORCryptor<V1>
pub fn new_bytes(key: &[u8]) -> XRCResult<Self>
Sourcepub fn encrypt_vec(&self, buffer: Vec<u8>) -> Vec<u8> ⓘ
👎Deprecated
pub fn encrypt_vec(&self, buffer: Vec<u8>) -> Vec<u8> ⓘ
Encrypts the vector
IMPORTANT!
This method is NOT suitable for production use as it uses ECB. Hence, takes advantage of parallelism for higher through put
[Breaking Change]: Use Self::encrypt_v2 for more secure and suitable for production use
Sourcepub fn decrypt_vec(&self, buffer: Vec<u8>) -> Vec<u8> ⓘ
👎Deprecated
pub fn decrypt_vec(&self, buffer: Vec<u8>) -> Vec<u8> ⓘ
Decrypts the vector
IMPORTANT!
This method is NOT suitable for production use.
[Breaking Change]: Use Self::decrypt_v2.
Auto Trait Implementations§
impl<T> Freeze for XORCryptor<T>
impl<T> RefUnwindSafe for XORCryptor<T>where
T: RefUnwindSafe,
impl<T> Send for XORCryptor<T>where
T: Send,
impl<T> Sync for XORCryptor<T>where
T: Sync,
impl<T> Unpin for XORCryptor<T>where
T: Unpin,
impl<T> UnsafeUnpin for XORCryptor<T>
impl<T> UnwindSafe for XORCryptor<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more