Struct fuzzytags::FuzzySecretKey [−][src]
The complete secret key. Can't directly be used for testing. Instead you will need to generate a FuzzyDetectionKey using extract
Implementations
impl FuzzySecretKey
[src]
pub fn generate(gamma: usize) -> FuzzySecretKey
[src]
Generate a new Key Pair given a security parameter gamma
. Tags generated for a given
FuzzyPublicKey::flag
will pass the FuzzyDetectionKey::test
for other public
keys with probability $ 2 ^ -8 $
Example:
use fuzzytags::{FuzzySecretKey}; let secret_key = FuzzySecretKey::generate(5);
pub fn extract(&self, n: usize) -> FuzzyDetectionKey
[src]
extract a detection key for a given false positive (p = 2^-n) Example:
use fuzzytags::{FuzzySecretKey}; let secret_key = FuzzySecretKey::generate(24); let detection_key = secret_key.extract(2);
pub fn public_key(&self) -> FuzzyPublicKey
[src]
derive the public key for this key Example:
use fuzzytags::FuzzySecretKey; let secret_key = FuzzySecretKey::generate(24); let public_key = secret_key.public_key();
Trait Implementations
impl Debug for FuzzySecretKey
[src]
impl<'de> Deserialize<'de> for FuzzySecretKey
[src]
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
[src]
__D: Deserializer<'de>,
impl Serialize for FuzzySecretKey
[src]
Auto Trait Implementations
impl RefUnwindSafe for FuzzySecretKey
[src]
impl Send for FuzzySecretKey
[src]
impl Sync for FuzzySecretKey
[src]
impl Unpin for FuzzySecretKey
[src]
impl UnwindSafe for FuzzySecretKey
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> DeserializeOwned for T where
T: for<'de> Deserialize<'de>,
[src]
T: for<'de> Deserialize<'de>,
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,