pub struct Secret<S: Suite> {
pub scalar: ScalarField<S>,
pub public: Public<S>,
}Expand description
Secret key for VRF operations.
Contains the private scalar and cached public key. Implements automatic zeroization on drop.
Fields§
§scalar: ScalarField<S>§public: Public<S>Implementations§
Source§impl<S: Suite> Secret<S>
impl<S: Suite> Secret<S>
Sourcepub fn from_scalar(scalar: ScalarField<S>) -> Self
pub fn from_scalar(scalar: ScalarField<S>) -> Self
Construct a Secret from the given scalar.
Sourcepub fn from_seed(seed: &[u8]) -> Self
pub fn from_seed(seed: &[u8]) -> Self
Derives a Secret scalar deterministically from a seed.
The seed is hashed using Suite::Hasher, and the output is reduced
modulo the curve’s order to produce a valid scalar in the range
[1, n - 1]. No clamping or multiplication by the cofactor is
performed, regardless of the curve.
The caller is responsible for ensuring that the resulting scalar is used safely with respect to the target curve’s cofactor and subgroup properties.
Trait Implementations§
Source§impl<S: Suite> CanonicalDeserialize for Secret<S>
impl<S: Suite> CanonicalDeserialize for Secret<S>
Source§fn deserialize_with_mode<R: Read>(
reader: R,
compress: Compress,
validate: Validate,
) -> Result<Self, SerializationError>
fn deserialize_with_mode<R: Read>( reader: R, compress: Compress, validate: Validate, ) -> Result<Self, SerializationError>
fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_compressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
Source§impl<S: Suite> CanonicalSerialize for Secret<S>
impl<S: Suite> CanonicalSerialize for Secret<S>
Source§fn serialize_with_mode<W: Write>(
&self,
writer: W,
compress: Compress,
) -> Result<(), SerializationError>
fn serialize_with_mode<W: Write>( &self, writer: W, compress: Compress, ) -> Result<(), SerializationError>
fn serialized_size(&self, compress: Compress) -> usize
fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn compressed_size(&self) -> usize
fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn uncompressed_size(&self) -> usize
Source§impl<S: IetfSuite> Prover<S> for Secret<S>
impl<S: IetfSuite> Prover<S> for Secret<S>
Source§fn prove(
&self,
input: Input<S>,
output: Output<S>,
ad: impl AsRef<[u8]>,
) -> Proof<S>
fn prove( &self, input: Input<S>, output: Output<S>, ad: impl AsRef<[u8]>, ) -> Proof<S>
Implements the IETF VRF proving algorithm.
This follows the procedure specified in RFC-9381 section 5.1, with extensions to support binding additional data to the proof:
- Generate a deterministic nonce
kbased on the secret key and input - Compute nonce commitments
k_bandk_h - Compute the challenge
cusing all public values, nonce commitments and the additional data - Compute the response
s = k + c * secret
Source§impl<S: PedersenSuite> Prover<S> for Secret<S>
impl<S: PedersenSuite> Prover<S> for Secret<S>
Source§impl<S: Suite> Valid for Secret<S>
impl<S: Suite> Valid for Secret<S>
fn check(&self) -> Result<(), SerializationError>
fn batch_check<'a>(
batch: impl Iterator<Item = &'a Self> + Send,
) -> Result<(), SerializationError>where
Self: 'a,
impl<S: Suite> StructuralPartialEq for Secret<S>
Auto Trait Implementations§
impl<S> Freeze for Secret<S>
impl<S> RefUnwindSafe for Secret<S>where
<<S as Suite>::Affine as AffineRepr>::ScalarField: RefUnwindSafe,
<S as Suite>::Affine: RefUnwindSafe,
impl<S> Send for Secret<S>
impl<S> Sync for Secret<S>
impl<S> Unpin for Secret<S>
impl<S> UnwindSafe for Secret<S>where
<<S as Suite>::Affine as AffineRepr>::ScalarField: UnwindSafe,
<S as Suite>::Affine: 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
Source§impl<T> CanonicalSerializeHashExt for Twhere
T: CanonicalSerialize,
impl<T> CanonicalSerializeHashExt for Twhere
T: CanonicalSerialize,
fn hash<H>(&self) -> GenericArray<u8, <H as OutputSizeUser>::OutputSize>where
H: Digest,
fn hash_uncompressed<H>(
&self,
) -> GenericArray<u8, <H as OutputSizeUser>::OutputSize>where
H: Digest,
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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