pub struct Secp256k1;
Expand description
secp256k1 (K-256) elliptic curve.
Specified in Certicom’s SECG in “SEC 2: Recommended Elliptic Curve Domain Parameters”:
https://www.secg.org/sec2-v2.pdf
The curve’s equation is y² = x³ + 7
over a ~256-bit prime field.
It’s primarily notable for usage in Bitcoin and other cryptocurrencies, particularly in conjunction with the Elliptic Curve Digital Signature Algorithm (ECDSA).
Trait Implementations§
source§impl AffineArithmetic for Secp256k1
impl AffineArithmetic for Secp256k1
§type AffinePoint = AffinePoint
type AffinePoint = AffinePoint
Elliptic curve point in affine coordinates.
source§impl AffineXCoordinate<Secp256k1> for AffinePoint
impl AffineXCoordinate<Secp256k1> for AffinePoint
source§fn x(&self) -> FieldBytes
fn x(&self) -> FieldBytes
Get the affine x-coordinate as a serialized field element.
source§impl DecompactPoint<Secp256k1> for AffinePoint
impl DecompactPoint<Secp256k1> for AffinePoint
Decompaction using Taproot conventions as described in BIP 340.
source§fn decompact(x_bytes: &FieldBytes) -> CtOption<Self>
fn decompact(x_bytes: &FieldBytes) -> CtOption<Self>
Attempt to decompact an elliptic curve point
source§impl DecompressPoint<Secp256k1> for AffinePoint
impl DecompressPoint<Secp256k1> for AffinePoint
source§fn decompress(x_bytes: &FieldBytes, y_is_odd: Choice) -> CtOption<Self>
fn decompress(x_bytes: &FieldBytes, y_is_odd: Choice) -> CtOption<Self>
Attempt to decompress an elliptic curve point.
source§impl DigestPrimitive for Secp256k1
impl DigestPrimitive for Secp256k1
§type Digest = CoreWrapper<CtVariableCoreWrapper<Sha256VarCore, UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B0>, OidSha256>>
type Digest = CoreWrapper<CtVariableCoreWrapper<Sha256VarCore, UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B0>, OidSha256>>
Preferred digest to use when computing ECDSA signatures for this
elliptic curve. This is typically a member of the SHA-2 family.
source§fn prehash_to_field_bytes(
prehash: &[u8]
) -> Result<GenericArray<u8, <Self::UInt as ArrayEncoding>::ByteSize>, Error>
fn prehash_to_field_bytes( prehash: &[u8] ) -> Result<GenericArray<u8, <Self::UInt as ArrayEncoding>::ByteSize>, Error>
Compute field bytes for a prehash (message digest), either zero-padding
or truncating if the prehash size does not match the field size.
source§impl FromEncodedPoint<Secp256k1> for AffinePoint
impl FromEncodedPoint<Secp256k1> for AffinePoint
source§fn from_encoded_point(encoded_point: &EncodedPoint) -> CtOption<Self>
fn from_encoded_point(encoded_point: &EncodedPoint) -> CtOption<Self>
Attempts to parse the given EncodedPoint
as an SEC1-encoded AffinePoint
.
Returns
None
value if encoded_point
is not on the secp256k1 curve.
source§impl FromEncodedPoint<Secp256k1> for ProjectivePoint
impl FromEncodedPoint<Secp256k1> for ProjectivePoint
source§fn from_encoded_point(p: &EncodedPoint) -> CtOption<Self>
fn from_encoded_point(p: &EncodedPoint) -> CtOption<Self>
Deserialize the type this trait is impl’d on from an
EncodedPoint
.source§impl Ord for Secp256k1
impl Ord for Secp256k1
source§impl PartialEq<Secp256k1> for Secp256k1
impl PartialEq<Secp256k1> for Secp256k1
source§impl PartialOrd<Secp256k1> for Secp256k1
impl PartialOrd<Secp256k1> for Secp256k1
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
This method tests less than or equal to (for
self
and other
) and is used by the <=
operator. Read moresource§impl PointCompression for Secp256k1
impl PointCompression for Secp256k1
source§const COMPRESS_POINTS: bool = true
const COMPRESS_POINTS: bool = true
secp256k1 points are typically compressed.
source§impl PrimeCurveArithmetic for Secp256k1
impl PrimeCurveArithmetic for Secp256k1
§type CurveGroup = ProjectivePoint
type CurveGroup = ProjectivePoint
Prime order elliptic curve group.
source§impl ProjectiveArithmetic for Secp256k1
impl ProjectiveArithmetic for Secp256k1
§type ProjectivePoint = ProjectivePoint
type ProjectivePoint = ProjectivePoint
Elliptic curve point in projective coordinates. Read more
source§impl SignPrimitive<Secp256k1> for Scalar
impl SignPrimitive<Secp256k1> for Scalar
source§fn try_sign_prehashed<K>(
&self,
ephemeral_scalar: K,
z: FieldBytes
) -> Result<(Signature, Option<RecoveryId>), Error>where
K: Borrow<Scalar> + Invert<Output = CtOption<Scalar>>,
fn try_sign_prehashed<K>( &self, ephemeral_scalar: K, z: FieldBytes ) -> Result<(Signature, Option<RecoveryId>), Error>where K: Borrow<Scalar> + Invert<Output = CtOption<Scalar>>,
Try to sign the prehashed message. Read more
source§fn try_sign_prehashed_rfc6979<D>(
&self,
z: GenericArray<u8, <<C as Curve>::UInt as ArrayEncoding>::ByteSize>,
ad: &[u8]
) -> Result<(Signature<C>, Option<RecoveryId>), Error>where
Self: From<ScalarCore<C>>,
<C as Curve>::UInt: for<'a> From<&'a Self>,
D: Digest<OutputSize = <<C as Curve>::UInt as ArrayEncoding>::ByteSize> + BlockSizeUser + FixedOutput + FixedOutputReset,
fn try_sign_prehashed_rfc6979<D>( &self, z: GenericArray<u8, <<C as Curve>::UInt as ArrayEncoding>::ByteSize>, ad: &[u8] ) -> Result<(Signature<C>, Option<RecoveryId>), Error>where Self: From<ScalarCore<C>>, <C as Curve>::UInt: for<'a> From<&'a Self>, D: Digest<OutputSize = <<C as Curve>::UInt as ArrayEncoding>::ByteSize> + BlockSizeUser + FixedOutput + FixedOutputReset,
source§fn try_sign_digest_rfc6979<D>(
&self,
msg_digest: D,
ad: &[u8]
) -> Result<(Signature<C>, Option<RecoveryId>), Error>where
Self: From<ScalarCore<C>>,
<C as Curve>::UInt: for<'a> From<&'a Self>,
D: Digest<OutputSize = <<C as Curve>::UInt as ArrayEncoding>::ByteSize> + BlockSizeUser + FixedOutput + FixedOutputReset,
fn try_sign_digest_rfc6979<D>( &self, msg_digest: D, ad: &[u8] ) -> Result<(Signature<C>, Option<RecoveryId>), Error>where Self: From<ScalarCore<C>>, <C as Curve>::UInt: for<'a> From<&'a Self>, D: Digest<OutputSize = <<C as Curve>::UInt as ArrayEncoding>::ByteSize> + BlockSizeUser + FixedOutput + FixedOutputReset,
Try to sign the given digest instance using the method described in
RFC6979.
source§impl ToEncodedPoint<Secp256k1> for AffinePoint
impl ToEncodedPoint<Secp256k1> for AffinePoint
source§fn to_encoded_point(&self, compress: bool) -> EncodedPoint
fn to_encoded_point(&self, compress: bool) -> EncodedPoint
Serialize this value as a SEC1
EncodedPoint
, optionally applying
point compression.source§impl ToEncodedPoint<Secp256k1> for ProjectivePoint
impl ToEncodedPoint<Secp256k1> for ProjectivePoint
source§fn to_encoded_point(&self, compress: bool) -> EncodedPoint
fn to_encoded_point(&self, compress: bool) -> EncodedPoint
Serialize this value as a SEC1
EncodedPoint
, optionally applying
point compression.source§impl ToEncodedPoint<Secp256k1> for VerifyingKey
impl ToEncodedPoint<Secp256k1> for VerifyingKey
source§fn to_encoded_point(&self, compress: bool) -> EncodedPoint
fn to_encoded_point(&self, compress: bool) -> EncodedPoint
Serialize this value as a SEC1
EncodedPoint
, optionally applying
point compression.source§impl VerifyPrimitive<Secp256k1> for AffinePoint
impl VerifyPrimitive<Secp256k1> for AffinePoint
source§fn verify_prehashed(&self, z: FieldBytes, signature: &Signature) -> Result<()>
fn verify_prehashed(&self, z: FieldBytes, signature: &Signature) -> Result<()>
Verify the prehashed message against the provided signature Read more
source§fn verify_digest<D>(
&self,
msg_digest: D,
sig: &Signature<C>
) -> Result<(), Error>where
D: FixedOutput<OutputSize = <<C as Curve>::UInt as ArrayEncoding>::ByteSize>,
fn verify_digest<D>( &self, msg_digest: D, sig: &Signature<C> ) -> Result<(), Error>where D: FixedOutput<OutputSize = <<C as Curve>::UInt as ArrayEncoding>::ByteSize>,
Verify message digest against the provided signature.
impl Copy for Secp256k1
impl Eq for Secp256k1
impl PrimeCurve for Secp256k1
impl StructuralEq for Secp256k1
impl StructuralPartialEq for Secp256k1
Auto Trait Implementations§
impl RefUnwindSafe for Secp256k1
impl Send for Secp256k1
impl Sync for Secp256k1
impl Unpin for Secp256k1
impl UnwindSafe for Secp256k1
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
Mutably borrows from an owned value. Read more
source§impl<C> ValidatePublicKey for Cwhere
C: Curve + ProjectiveArithmetic,
<C as AffineArithmetic>::AffinePoint: FromEncodedPoint<C> + ToEncodedPoint<C>,
<<C as Curve>::UInt as ArrayEncoding>::ByteSize: ModulusSize,
impl<C> ValidatePublicKey for Cwhere C: Curve + ProjectiveArithmetic, <C as AffineArithmetic>::AffinePoint: FromEncodedPoint<C> + ToEncodedPoint<C>, <<C as Curve>::UInt as ArrayEncoding>::ByteSize: ModulusSize,
source§fn validate_public_key(
secret_key: &SecretKey<C>,
public_key: &EncodedPoint<<<C as Curve>::UInt as ArrayEncoding>::ByteSize>
) -> Result<(), Error>
fn validate_public_key( secret_key: &SecretKey<C>, public_key: &EncodedPoint<<<C as Curve>::UInt as ArrayEncoding>::ByteSize> ) -> Result<(), Error>
Validate that the given
EncodedPoint
is a valid public key for the
provided secret value.