pub struct Key(/* private fields */);Expand description
A cryptographic master key to sign or encrypt cookies.
Implementations§
source§impl Key
impl Key
sourcepub fn from(key: &[u8]) -> Key
pub fn from(key: &[u8]) -> Key
Creates a new Key from a 512-bit cryptographically random string.
The supplied key must be at least 512-bits (64 bytes). For security, the master key must be cryptographically random.
§Panics
Panics if key is less than 64 bytes in length.
For a non-panicking version, use Key::try_from() or generate a key with
Key::generate() or Key::try_generate().
§Example
use biscotti::Key;
let key = { /* a cryptographically random key >= 64 bytes */ };
let key = Key::from(key);sourcepub fn generate() -> Key
pub fn generate() -> Key
Generates signing/encryption keys from a secure, random source. Keys are generated nondeterministically.
§Panics
Panics if randomness cannot be retrieved from the operating system. See
Key::try_generate() for a non-panicking version.
§Example
use biscotti::Key;
let key = Key::generate();sourcepub fn try_generate() -> Option<Key>
pub fn try_generate() -> Option<Key>
Attempts to generate signing/encryption keys from a secure, random
source. Keys are generated nondeterministically. If randomness cannot be
retrieved from the underlying operating system, returns None.
§Example
use biscotti::Key;
let key = Key::try_generate();sourcepub fn signing(&self) -> &[u8] ⓘ
pub fn signing(&self) -> &[u8] ⓘ
Returns the raw bytes of a key suitable for signing cookies. Guaranteed to be at least 32 bytes.
§Example
use biscotti::Key;
let key = Key::generate();
let signing_key = key.signing();sourcepub fn encryption(&self) -> &[u8] ⓘ
pub fn encryption(&self) -> &[u8] ⓘ
Returns the raw bytes of a key suitable for encrypting cookies. Guaranteed to be at least 32 bytes.
§Example
use biscotti::Key;
let key = Key::generate();
let encryption_key = key.encryption();Trait Implementations§
source§impl<'de> Deserialize<'de> for Key
impl<'de> Deserialize<'de> for Key
source§fn deserialize<D>(deserializer: D) -> Result<Key, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Key, D::Error>where
D: Deserializer<'de>,
source§impl PartialEq for Key
impl PartialEq for Key
source§impl TryFrom<&[u8]> for Key
impl TryFrom<&[u8]> for Key
source§fn try_from(key: &[u8]) -> Result<Self, Self::Error>
fn try_from(key: &[u8]) -> Result<Self, Self::Error>
A fallible version of Key::from().
Succeeds when Key::from() succeds and returns an error where
Key::from() panics, namely, if key is too short.
§Example
use biscotti::Key;
let key = { /* a cryptographically random key >= 64 bytes */ };
assert!(Key::try_from(key).is_ok());
// A key that's far too short to use.
let key = &[1, 2, 3, 4][..];
assert!(Key::try_from(key).is_err());impl Eq for Key
Auto Trait Implementations§
impl RefUnwindSafe for Key
impl Send for Key
impl Sync for Key
impl Unpin for Key
impl UnwindSafe for Key
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.