Codec

Struct Codec 

Source
pub struct Codec { /* private fields */ }
Expand description

Core encoder/decoder.

Implementations§

Source§

impl Codec

Source

pub fn new(name: &str, config: &Config) -> Codec

Creates a new Codec instance with the given name and key.

The name is used as a prefix in the encoded output and to derive a prefix-specifc key together with the master key.

Security note: In order to be secure, you must provide a secure random key with sufficient entropy, and manage it appropriately.

§Arguments
  • name - A string slice that holds the name of the codec.
  • key - A byte slice that holds the master key for encryption and MAC.
§Returns

A new instance of Codec.

§Examples
use cryptid_rs::{Config, Codec};

let codec = Codec::new("example", &Config::new(b"your-secure-key"));
Source

pub fn encode(&self, num: u64) -> String

Encodes a given numeric value into a secure string representation.

This method applies format-preserving encryption to the number and then encodes it into a base62 string with a prefix. It also appends an HMAC for integrity verification.

§Arguments
  • num - The 64-bit unsigned integer to be encoded.
§Returns

A Result which is Ok containing the encoded string if successful, or an Error if encoding fails.

§Examples
use cryptid_rs::{Codec, Config};

let codec = Codec::new("example", &Config::new(b"your-secure-key"));
let encoded = codec.encode(12345);

assert_eq!(encoded, "example_VgwPy6rwatl");
Source

pub fn encode_uuid(&self, num: u64) -> Uuid

Encrypts num into an UUID. This is useful in situations where using an UUID is forced by some interface. Otherwise you should use the default type safe strings.

Source

pub fn decode_uuid(&self, uuid: Uuid) -> Result<u64, Error>

Decodes a previously encrypted UUID back into its original numeric value.

§Arguments
  • uuid - The UUID to be decoded.
§Returns

A Result which is Ok containing the decoded 64-bit unsigned integer if successful, or an Error if decoding fails.

§Examples
use cryptid_rs::{Codec, Config};
use uuid::Uuid;

let codec = Codec::new("test", &Config::new(b"Test key here"));
let uuid = codec.encode_uuid(0);
let decoded = codec.decode_uuid(uuid).unwrap();

assert_eq!(decoded, 0);
Source

pub fn decode(&self, encoded: &str) -> Result<u64, Error>

Decodes a previously encoded string back into its original numeric value.

This method first verifies the integrity of the encoded data using HMAC, and then applies format-preserving decryption to retrieve the original number. It expects the encoded data to start with the correct prefix.

§Arguments
  • encoded - A string slice representing the encoded data.
§Returns

A Result which is Ok containing the decoded 64-bit unsigned integer if successful, or an Error if decoding fails.

§Examples
use cryptid_rs::{Codec, Config};

let codec = Codec::new("example", &Config::new(b"your-secure-key"));
let decoded = codec.decode("example_VgwPy6rwatl").unwrap();

assert_eq!(decoded, 12345);

Auto Trait Implementations§

§

impl Freeze for Codec

§

impl RefUnwindSafe for Codec

§

impl Send for Codec

§

impl Sync for Codec

§

impl Unpin for Codec

§

impl UnwindSafe for Codec

Blanket Implementations§

Source§

impl<T> AggregateExpressionMethods for T

Source§

fn aggregate_distinct(self) -> Self::Output
where Self: DistinctDsl,

DISTINCT modifier for aggregate functions Read more
Source§

fn aggregate_all(self) -> Self::Output
where Self: AllDsl,

ALL modifier for aggregate functions Read more
Source§

fn aggregate_filter<P>(self, f: P) -> Self::Output
where P: AsExpression<Bool>, Self: FilterDsl<<P as AsExpression<Bool>>::Expression>,

Add an aggregate function filter Read more
Source§

fn aggregate_order<O>(self, o: O) -> Self::Output
where Self: OrderAggregateDsl<O>,

Add an aggregate function order Read more
Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
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> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSend for T
where T: Any + Send,

Source§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Sync + Send>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> IntoSql for T

Source§

fn into_sql<T>(self) -> Self::Expression

Convert self to an expression for Diesel’s query builder. Read more
Source§

fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
where &'a Self: AsExpression<T>, T: SqlType + TypedExpressionType,

Convert &self to an expression for Diesel’s query builder. Read more
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.
Source§

impl<T> WindowExpressionMethods for T

Source§

fn over(self) -> Self::Output
where Self: OverDsl,

Turn a function call into a window function call Read more
Source§

fn window_filter<P>(self, f: P) -> Self::Output
where P: AsExpression<Bool>, Self: FilterDsl<<P as AsExpression<Bool>>::Expression>,

Add a filter to the current window function Read more
Source§

fn partition_by<E>(self, expr: E) -> Self::Output
where Self: PartitionByDsl<E>,

Add a partition clause to the current window function Read more
Source§

fn window_order<E>(self, expr: E) -> Self::Output
where Self: OrderWindowDsl<E>,

Add a order clause to the current window function Read more
Source§

fn frame_by<E>(self, expr: E) -> Self::Output
where Self: FrameDsl<E>,

Add a frame clause to the current window function Read more