pub struct DecryptBufReader<A, B, R, S>where
A: AeadInPlace + KeyInit,
S: StreamPrimitive<A> + NewStream<A>,
A::NonceSize: Sub<S::NonceOverhead>,
NonceSize<A, S>: ArrayLength<u8>,{ /* private fields */ }Expand description
A wrapper around a Read object and a StreamPrimitive
providing a Read interface which automatically decrypts the underlying stream when
reading
Implementations§
Source§impl<A, B, R, S> DecryptBufReader<A, B, R, S>where
A: AeadInPlace + KeyInit,
B: ResizeBuffer + CappedBuffer,
S: StreamPrimitive<A> + NewStream<A>,
A::NonceSize: Sub<S::NonceOverhead>,
NonceSize<A, S>: ArrayLength<u8>,
impl<A, B, R, S> DecryptBufReader<A, B, R, S>where
A: AeadInPlace + KeyInit,
B: ResizeBuffer + CappedBuffer,
S: StreamPrimitive<A> + NewStream<A>,
A::NonceSize: Sub<S::NonceOverhead>,
NonceSize<A, S>: ArrayLength<u8>,
Sourcepub fn new(key: &Key<A>, buffer: B, reader: R) -> Result<Self, InvalidCapacity>
pub fn new(key: &Key<A>, buffer: B, reader: R) -> Result<Self, InvalidCapacity>
Constructs a new Reader using an AEAD key, buffer and reader
Sourcepub fn from_aead(aead: A, buffer: B, reader: R) -> Result<Self, InvalidCapacity>
pub fn from_aead(aead: A, buffer: B, reader: R) -> Result<Self, InvalidCapacity>
Constructs a new Reader using an AEAD primitive, buffer and reader
Sourcepub fn into_inner(self) -> R
pub fn into_inner(self) -> R
Consumes the Reader and returns the inner reader
Trait Implementations§
Source§impl<A, B, R, S> Read for DecryptBufReader<A, B, R, S>where
A: AeadInPlace + KeyInit,
B: ResizeBuffer + CappedBuffer,
R: Read,
R::Error: Into<Error>,
S: StreamPrimitive<A> + NewStream<A>,
A::NonceSize: Sub<S::NonceOverhead>,
NonceSize<A, S>: ArrayLength<u8>,
impl<A, B, R, S> Read for DecryptBufReader<A, B, R, S>where
A: AeadInPlace + KeyInit,
B: ResizeBuffer + CappedBuffer,
R: Read,
R::Error: Into<Error>,
S: StreamPrimitive<A> + NewStream<A>,
A::NonceSize: Sub<S::NonceOverhead>,
NonceSize<A, S>: ArrayLength<u8>,
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
Pull some bytes from this source into the specified buffer, returning
how many bytes were read. Read more
1.36.0 · Source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
Like
read, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
Reads all bytes until EOF in this source, placing them into
buf. Read more1.0.0 · Source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
Reads all bytes until EOF in this source, appending them to
buf. Read more1.6.0 · Source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
Reads the exact number of bytes required to fill
buf. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf)Pull some bytes from this source into the specified buffer. Read more
Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf)Reads the exact number of bytes required to fill
cursor. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Creates a “by reference” adaptor for this instance of
Read. Read moreAuto Trait Implementations§
impl<A, B, R, S> Freeze for DecryptBufReader<A, B, R, S>where
<<A as AeadCore>::NonceSize as Sub<<S as StreamPrimitive<A>>::NonceOverhead>>::Output: Sized,
B: Freeze,
R: Freeze,
A: Freeze,
S: Freeze,
<S as StreamPrimitive<A>>::Counter: Freeze,
impl<A, B, R, S> RefUnwindSafe for DecryptBufReader<A, B, R, S>where
<<A as AeadCore>::NonceSize as Sub<<S as StreamPrimitive<A>>::NonceOverhead>>::Output: Sized,
B: RefUnwindSafe,
R: RefUnwindSafe,
A: RefUnwindSafe,
S: RefUnwindSafe,
<S as StreamPrimitive<A>>::Counter: RefUnwindSafe,
impl<A, B, R, S> Send for DecryptBufReader<A, B, R, S>where
<<A as AeadCore>::NonceSize as Sub<<S as StreamPrimitive<A>>::NonceOverhead>>::Output: Sized,
B: Send,
R: Send,
A: Send,
S: Send,
<S as StreamPrimitive<A>>::Counter: Send,
impl<A, B, R, S> Sync for DecryptBufReader<A, B, R, S>where
<<A as AeadCore>::NonceSize as Sub<<S as StreamPrimitive<A>>::NonceOverhead>>::Output: Sized,
B: Sync,
R: Sync,
A: Sync,
S: Sync,
<S as StreamPrimitive<A>>::Counter: Sync,
impl<A, B, R, S> Unpin for DecryptBufReader<A, B, R, S>where
<<A as AeadCore>::NonceSize as Sub<<S as StreamPrimitive<A>>::NonceOverhead>>::Output: Sized,
B: Unpin,
R: Unpin,
A: Unpin,
S: Unpin,
<S as StreamPrimitive<A>>::Counter: Unpin,
impl<A, B, R, S> UnwindSafe for DecryptBufReader<A, B, R, S>where
<<A as AeadCore>::NonceSize as Sub<<S as StreamPrimitive<A>>::NonceOverhead>>::Output: Sized,
B: UnwindSafe,
R: UnwindSafe,
A: UnwindSafe,
S: UnwindSafe,
<S as StreamPrimitive<A>>::Counter: 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
Mutably borrows from an owned value. Read more