| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
Crypto.PubKey.ECC.ECDSA
Description
WARNING: Signature operations may leak the private key. Signature verification should be safe.
- data Signature = Signature {}
- type PublicPoint = Point
- data PublicKey = PublicKey {}
- type PrivateNumber = Integer
- data PrivateKey = PrivateKey {}
- data KeyPair = KeyPair Curve PublicPoint PrivateNumber
- toPublicKey :: KeyPair -> PublicKey
- toPrivateKey :: KeyPair -> PrivateKey
- signWith :: (ByteArrayAccess msg, HashAlgorithm hash) => Integer -> PrivateKey -> hash -> msg -> Maybe Signature
- sign :: (ByteArrayAccess msg, HashAlgorithm hash, MonadRandom m) => PrivateKey -> hash -> msg -> m Signature
- verify :: (ByteArrayAccess msg, HashAlgorithm hash) => hash -> PublicKey -> Signature -> msg -> Bool
Documentation
Represent a ECDSA signature namely R and S.
type PublicPoint = Point Source #
ECC Public Point
ECDSA Public Key.
Constructors
| PublicKey | |
| Fields 
 | |
type PrivateNumber = Integer Source #
ECC Private Number
ECDSA Key Pair.
Constructors
| KeyPair Curve PublicPoint PrivateNumber | 
toPublicKey :: KeyPair -> PublicKey Source #
Public key of a ECDSA Key pair.
toPrivateKey :: KeyPair -> PrivateKey Source #
Private key of a ECDSA Key pair.
Arguments
| :: (ByteArrayAccess msg, HashAlgorithm hash) | |
| => Integer | k random number | 
| -> PrivateKey | private key | 
| -> hash | hash function | 
| -> msg | message to sign | 
| -> Maybe Signature | 
Sign message using the private key and an explicit k number.
WARNING: Vulnerable to timing attacks.
sign :: (ByteArrayAccess msg, HashAlgorithm hash, MonadRandom m) => PrivateKey -> hash -> msg -> m Signature Source #
Sign message using the private key.
WARNING: Vulnerable to timing attacks.
verify :: (ByteArrayAccess msg, HashAlgorithm hash) => hash -> PublicKey -> Signature -> msg -> Bool Source #
Verify a bytestring using the public key.