Skip to main content

StreamingDecryptingKey

Struct StreamingDecryptingKey 

pub struct StreamingDecryptingKey { /* private fields */ }
Expand description

A key for streaming decryption operations.

Implementations§

§

impl StreamingDecryptingKey

pub fn update<'a>( &mut self, input: &[u8], output: &'a mut [u8], ) -> Result<BufferUpdate<'a>, Unspecified>

Updates the internal state of the key with the provided ciphertext input, potentially also writing bytes of plaintext to output. The number of bytes written to output can be up to input.len() plus the block length of the cipher algorithm (e.g., Algorithm::block_len) minus one.

§Errors
  • Returns an error if the output buffer is smaller than the length of the input plus the algorithm’s block length minus one.
  • May return an error if the length of input plus the algorithm’s block length is larger than i32::MAX.

pub fn less_safe_update<'a>( &mut self, input: &[u8], output: &'a mut [u8], ) -> Result<BufferUpdate<'a>, Unspecified>

Updates the internal state of the key with the provided ciphertext input, potentially writing bytes of plaintext to output.

This function has looser output buffer size requirements than Self::update, calculating the minimum required size based on the total bytes of output generated and the cipher’s block length. This is considered “less safe” because it’s based on assumptions about the state of the underlying operations.

The minimum output buffer size is calculated based on how many bytes are needed to reach the next block boundary after processing the input. If next_total is the sum of bytes already generated plus input.len(), then the minimum size is: input.len() + ((block_len - (next_total % block_len)) % block_len)

§Errors

Returns an error if the output buffer is smaller than the calculated minimum size, if the total output length overflows, or if the length of input is larger than i32::MAX.

§Panics

Panics if the number of bytes written by the cipher operation exceeds the output buffer length.

pub fn finish(self, output: &mut [u8]) -> Result<BufferUpdate<'_>, Unspecified>

Finishes the decryption operation, writing the remaining plaintext to output. The number of bytes written to output can be up to the block length of the cipher algorithm (e.g., Algorithm::block_len).

§Errors
  • Returns an error if the output buffer is smaller than the algorithm’s block length.

pub fn mode(&self) -> OperatingMode

Returns the cipher operating mode.

pub fn algorithm(&self) -> &'static Algorithm

Returns the cipher algorithm

pub fn ctr( key: UnboundCipherKey, context: DecryptionContext, ) -> Result<StreamingDecryptingKey, Unspecified>

Constructs a StreamingDecryptingKey for decrypting using the CTR cipher mode. The resulting plaintext will be the same length as the ciphertext.

§Errors

Returns an error on an internal failure.

pub fn cbc_pkcs7( key: UnboundCipherKey, context: DecryptionContext, ) -> Result<StreamingDecryptingKey, Unspecified>

Constructs a StreamingDecryptingKey for decrypting using the CBC cipher mode. The resulting plaintext will be shorter than the ciphertext.

§Errors

Returns an error on an internal failure.

pub fn cfb128( key: UnboundCipherKey, context: DecryptionContext, ) -> Result<StreamingDecryptingKey, Unspecified>

The resulting plaintext will be the same length as the ciphertext.

§Errors

Returns an error on an internal failure.

pub fn ecb_pkcs7( key: UnboundCipherKey, context: DecryptionContext, ) -> Result<StreamingDecryptingKey, Unspecified>

Constructs a StreamingDecryptingKey for decrypting using the ECB cipher mode. The resulting plaintext will be the same length as the ciphertext.

§☠️ ️️️DANGER ☠️

Offered for computability purposes only. This is an extremely dangerous mode, and very likely not what you want to use.

§Errors

Returns an error on an internal failure.

Trait Implementations§

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FutureExt for T

§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a rama_grpc::Request
§

impl<L> LayerExt<L> for L

§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
§

impl<T, U> RamaFrom<T> for U
where U: From<T>,

§

fn rama_from(value: T) -> U

§

impl<T, U, CrateMarker> RamaInto<U, CrateMarker> for T
where U: RamaFrom<T, CrateMarker>,

§

fn rama_into(self) -> U

§

impl<T, U> RamaTryFrom<T> for U
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

§

fn rama_try_from(value: T) -> Result<U, <U as RamaTryFrom<T>>::Error>

§

impl<T, U, CrateMarker> RamaTryInto<U, CrateMarker> for T
where U: RamaTryFrom<T, CrateMarker>,

§

type Error = <U as RamaTryFrom<T, CrateMarker>>::Error

§

fn rama_try_into(self) -> Result<U, <U as RamaTryFrom<T, CrateMarker>>::Error>

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more