{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
module Cardano.Crypto.KES.Class (
KESAlgorithm (..),
genKeyKES,
updateKES,
forgetSignKeyKES,
Period,
OptimizedKESAlgorithm (..),
verifyOptimizedKES,
sizeVerKeyKES,
sizeSignKeyKES,
sizeSigKES,
SignKeyWithPeriodKES (..),
updateKESWithPeriod,
SignedKES (..),
signedKES,
verifySignedKES,
encodeVerKeyKES,
decodeVerKeyKES,
encodeSigKES,
decodeSigKES,
encodeSignedKES,
decodeSignedKES,
encodedVerKeyKESSizeExpr,
encodedSignKeyKESSizeExpr,
encodedSigKESSizeExpr,
verKeySizeKES,
sigSizeKES,
signKeySizeKES,
seedSizeKES,
UnsoundKESAlgorithm (..),
encodeSignKeyKES,
decodeSignKeyKES,
rawDeserialiseSignKeyKES,
UnsoundPureKESAlgorithm (..),
unsoundPureSignedKES,
encodeUnsoundPureSignKeyKES,
decodeUnsoundPureSignKeyKES,
hashPairOfVKeys,
mungeName,
unsoundPureSignKeyKESToSoundSignKeyKESViaSer,
)
where
import Control.Monad.Class.MonadST (MonadST)
import Control.Monad.Class.MonadThrow (MonadThrow)
import Control.Monad.Trans.Maybe (MaybeT (..), runMaybeT)
import Data.ByteString (ByteString)
import qualified Data.ByteString as BS
import Data.Kind (Type)
import Data.Proxy (Proxy (..))
import Data.Typeable (Typeable)
import GHC.Exts (Constraint)
import GHC.Generics (Generic)
import GHC.Stack
import GHC.TypeLits (ErrorMessage (..), KnownNat, Nat, TypeError, natVal)
import NoThunks.Class (NoThunks)
import Cardano.Binary (Decoder, Encoding, Size, decodeBytes, encodeBytes, withWordSize)
import Cardano.Crypto.DSIGN.Class (failSizeCheck)
import Cardano.Crypto.Hash.Class (Hash, HashAlgorithm, hashWith)
import Cardano.Crypto.Libsodium (MLockedAllocator, mlockedMalloc)
import Cardano.Crypto.Libsodium.MLockedSeed
import Cardano.Crypto.Seed
import Cardano.Crypto.Util (Empty)
{-# DEPRECATED SizeVerKeyKES "In favor of `VerKeySizeKES`" #-}
{-# DEPRECATED SizeSignKeyKES "In favor of `SignKeySizeKES`" #-}
{-# DEPRECATED SizeSigKES "In favor of `SigSizeKES`" #-}
class
( Typeable v
, Show (VerKeyKES v)
, Eq (VerKeyKES v)
, Show (SigKES v)
, Eq (SigKES v)
, NoThunks (SigKES v)
, NoThunks (SignKeyKES v)
, NoThunks (VerKeyKES v)
, KnownNat (SeedSizeKES v)
, KnownNat (VerKeySizeKES v)
, KnownNat (SignKeySizeKES v)
, KnownNat (SigSizeKES v)
) =>
KESAlgorithm v
where
data VerKeyKES v :: Type
data SigKES v :: Type
data SignKeyKES v :: Type
type SeedSizeKES v :: Nat
type VerKeySizeKES v :: Nat
type SignKeySizeKES v :: Nat
type SigSizeKES v :: Nat
type SizeVerKeyKES v :: Nat
type SizeVerKeyKES v = VerKeySizeKES v
type SizeSignKeyKES v :: Nat
type SizeSignKeyKES v = SignKeySizeKES v
type SizeSigKES v :: Nat
type SizeSigKES v = SigSizeKES v
algorithmNameKES :: proxy v -> String
hashVerKeyKES :: HashAlgorithm h => VerKeyKES v -> Hash h (VerKeyKES v)
hashVerKeyKES = (VerKeyKES v -> ByteString) -> VerKeyKES v -> Hash h (VerKeyKES v)
forall h a. HashAlgorithm h => (a -> ByteString) -> a -> Hash h a
hashWith VerKeyKES v -> ByteString
forall v. KESAlgorithm v => VerKeyKES v -> ByteString
rawSerialiseVerKeyKES
type ContextKES v :: Type
type ContextKES v = ()
type Signable v :: Type -> Constraint
type Signable v = Empty
verifyKES ::
(Signable v a, HasCallStack) =>
ContextKES v ->
VerKeyKES v ->
Period ->
a ->
SigKES v ->
Either String ()
totalPeriodsKES ::
proxy v -> Word
rawSerialiseVerKeyKES :: VerKeyKES v -> ByteString
rawSerialiseSigKES :: SigKES v -> ByteString
rawDeserialiseVerKeyKES :: ByteString -> Maybe (VerKeyKES v)
rawDeserialiseSigKES :: ByteString -> Maybe (SigKES v)
deriveVerKeyKES :: (MonadST m, MonadThrow m) => SignKeyKES v -> m (VerKeyKES v)
signKES ::
forall a m.
(Signable v a, MonadST m, MonadThrow m) =>
ContextKES v ->
Period ->
a ->
SignKeyKES v ->
m (SigKES v)
updateKESWith ::
(MonadST m, MonadThrow m) =>
MLockedAllocator m ->
ContextKES v ->
SignKeyKES v ->
Period ->
m (Maybe (SignKeyKES v))
genKeyKESWith ::
(MonadST m, MonadThrow m) =>
MLockedAllocator m ->
MLockedSeed (SeedSizeKES v) ->
m (SignKeyKES v)
forgetSignKeyKESWith ::
(MonadST m, MonadThrow m) =>
MLockedAllocator m ->
SignKeyKES v ->
m ()
verKeySizeKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
verKeySizeKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
verKeySizeKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (VerKeySizeKES v) -> Integer
forall (n :: Nat) (proxy :: Nat -> *).
KnownNat n =>
proxy n -> Integer
natVal (forall (t :: Nat). Proxy t
forall {k} (t :: k). Proxy t
Proxy @(VerKeySizeKES v)))
sigSizeKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sigSizeKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sigSizeKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (SigSizeKES v) -> Integer
forall (n :: Nat) (proxy :: Nat -> *).
KnownNat n =>
proxy n -> Integer
natVal (forall (t :: Nat). Proxy t
forall {k} (t :: k). Proxy t
Proxy @(SigSizeKES v)))
signKeySizeKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
signKeySizeKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
signKeySizeKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (SignKeySizeKES v) -> Integer
forall (n :: Nat) (proxy :: Nat -> *).
KnownNat n =>
proxy n -> Integer
natVal (forall (t :: Nat). Proxy t
forall {k} (t :: k). Proxy t
Proxy @(SignKeySizeKES v)))
{-# DEPRECATED sizeVerKeyKES "In favor of `verKeySizeKES`" #-}
sizeVerKeyKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sizeVerKeyKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeVerKeyKES = proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
verKeySizeKES
{-# DEPRECATED sizeSignKeyKES "In favor of `signKeySizeKES`" #-}
sizeSignKeyKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sizeSignKeyKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSignKeyKES = proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
signKeySizeKES
{-# DEPRECATED sizeSigKES "In favor of `sigSizeKES`" #-}
sizeSigKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sizeSigKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSigKES = proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sigSizeKES
seedSizeKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
seedSizeKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
seedSizeKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (SeedSizeKES v) -> Integer
forall (n :: Nat) (proxy :: Nat -> *).
KnownNat n =>
proxy n -> Integer
natVal (forall (t :: Nat). Proxy t
forall {k} (t :: k). Proxy t
Proxy @(SeedSizeKES v)))
forgetSignKeyKES ::
(KESAlgorithm v, MonadST m, MonadThrow m) =>
SignKeyKES v ->
m ()
forgetSignKeyKES :: forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
SignKeyKES v -> m ()
forgetSignKeyKES = MLockedAllocator m -> SignKeyKES v -> m ()
forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
MLockedAllocator m -> SignKeyKES v -> m ()
forall (m :: * -> *).
(MonadST m, MonadThrow m) =>
MLockedAllocator m -> SignKeyKES v -> m ()
forgetSignKeyKESWith MLockedAllocator m
forall (m :: * -> *). MonadST m => MLockedAllocator m
mlockedMalloc
genKeyKES ::
forall v m.
(KESAlgorithm v, MonadST m, MonadThrow m) =>
MLockedSeed (SeedSizeKES v) ->
m (SignKeyKES v)
genKeyKES :: forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
MLockedSeed (SeedSizeKES v) -> m (SignKeyKES v)
genKeyKES = MLockedAllocator m
-> MLockedSeed (SeedSizeKES v) -> m (SignKeyKES v)
forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
MLockedAllocator m
-> MLockedSeed (SeedSizeKES v) -> m (SignKeyKES v)
forall (m :: * -> *).
(MonadST m, MonadThrow m) =>
MLockedAllocator m
-> MLockedSeed (SeedSizeKES v) -> m (SignKeyKES v)
genKeyKESWith MLockedAllocator m
forall (m :: * -> *). MonadST m => MLockedAllocator m
mlockedMalloc
updateKES ::
forall v m.
(KESAlgorithm v, MonadST m, MonadThrow m) =>
ContextKES v ->
SignKeyKES v ->
Period ->
m (Maybe (SignKeyKES v))
updateKES :: forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
ContextKES v -> SignKeyKES v -> Word -> m (Maybe (SignKeyKES v))
updateKES = MLockedAllocator m
-> ContextKES v -> SignKeyKES v -> Word -> m (Maybe (SignKeyKES v))
forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
MLockedAllocator m
-> ContextKES v -> SignKeyKES v -> Word -> m (Maybe (SignKeyKES v))
forall (m :: * -> *).
(MonadST m, MonadThrow m) =>
MLockedAllocator m
-> ContextKES v -> SignKeyKES v -> Word -> m (Maybe (SignKeyKES v))
updateKESWith MLockedAllocator m
forall (m :: * -> *). MonadST m => MLockedAllocator m
mlockedMalloc
class
( KESAlgorithm v
, NoThunks (UnsoundPureSignKeyKES v)
) =>
UnsoundPureKESAlgorithm v
where
data UnsoundPureSignKeyKES v :: Type
unsoundPureSignKES ::
forall a.
Signable v a =>
ContextKES v ->
Period ->
a ->
UnsoundPureSignKeyKES v ->
SigKES v
unsoundPureUpdateKES ::
ContextKES v ->
UnsoundPureSignKeyKES v ->
Period ->
Maybe (UnsoundPureSignKeyKES v)
unsoundPureGenKeyKES ::
Seed ->
UnsoundPureSignKeyKES v
unsoundPureDeriveVerKeyKES ::
UnsoundPureSignKeyKES v ->
VerKeyKES v
unsoundPureSignKeyKESToSoundSignKeyKES ::
(MonadST m, MonadThrow m) =>
UnsoundPureSignKeyKES v ->
m (SignKeyKES v)
rawSerialiseUnsoundPureSignKeyKES :: UnsoundPureSignKeyKES v -> ByteString
rawDeserialiseUnsoundPureSignKeyKES :: ByteString -> Maybe (UnsoundPureSignKeyKES v)
class KESAlgorithm v => UnsoundKESAlgorithm v where
rawDeserialiseSignKeyKESWith ::
(MonadST m, MonadThrow m) =>
MLockedAllocator m ->
ByteString ->
m (Maybe (SignKeyKES v))
rawSerialiseSignKeyKES :: (MonadST m, MonadThrow m) => SignKeyKES v -> m ByteString
rawDeserialiseSignKeyKES ::
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
ByteString ->
m (Maybe (SignKeyKES v))
rawDeserialiseSignKeyKES :: forall v (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
ByteString -> m (Maybe (SignKeyKES v))
rawDeserialiseSignKeyKES = MLockedAllocator m -> ByteString -> m (Maybe (SignKeyKES v))
forall v (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
MLockedAllocator m -> ByteString -> m (Maybe (SignKeyKES v))
forall (m :: * -> *).
(MonadST m, MonadThrow m) =>
MLockedAllocator m -> ByteString -> m (Maybe (SignKeyKES v))
rawDeserialiseSignKeyKESWith MLockedAllocator m
forall (m :: * -> *). MonadST m => MLockedAllocator m
mlockedMalloc
unsoundPureSignKeyKESToSoundSignKeyKESViaSer ::
(MonadST m, MonadThrow m, UnsoundKESAlgorithm k, UnsoundPureKESAlgorithm k) =>
UnsoundPureSignKeyKES k ->
m (SignKeyKES k)
unsoundPureSignKeyKESToSoundSignKeyKESViaSer :: forall (m :: * -> *) k.
(MonadST m, MonadThrow m, UnsoundKESAlgorithm k,
UnsoundPureKESAlgorithm k) =>
UnsoundPureSignKeyKES k -> m (SignKeyKES k)
unsoundPureSignKeyKESToSoundSignKeyKESViaSer UnsoundPureSignKeyKES k
sk =
m (SignKeyKES k)
-> (SignKeyKES k -> m (SignKeyKES k))
-> Maybe (SignKeyKES k)
-> m (SignKeyKES k)
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (String -> m (SignKeyKES k)
forall a. HasCallStack => String -> a
error String
"unsoundPureSignKeyKESToSoundSignKeyKES: deserialisation failure") SignKeyKES k -> m (SignKeyKES k)
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return
(Maybe (SignKeyKES k) -> m (SignKeyKES k))
-> m (Maybe (SignKeyKES k)) -> m (SignKeyKES k)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< (ByteString -> m (Maybe (SignKeyKES k))
forall v (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
ByteString -> m (Maybe (SignKeyKES v))
rawDeserialiseSignKeyKES (ByteString -> m (Maybe (SignKeyKES k)))
-> (UnsoundPureSignKeyKES k -> ByteString)
-> UnsoundPureSignKeyKES k
-> m (Maybe (SignKeyKES k))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. UnsoundPureSignKeyKES k -> ByteString
forall v.
UnsoundPureKESAlgorithm v =>
UnsoundPureSignKeyKES v -> ByteString
rawSerialiseUnsoundPureSignKeyKES (UnsoundPureSignKeyKES k -> m (Maybe (SignKeyKES k)))
-> UnsoundPureSignKeyKES k -> m (Maybe (SignKeyKES k))
forall a b. (a -> b) -> a -> b
$ UnsoundPureSignKeyKES k
sk)
class KESAlgorithm v => OptimizedKESAlgorithm v where
verifySigKES ::
(Signable v a, HasCallStack) =>
ContextKES v ->
Period ->
a ->
SigKES v ->
Either String ()
verKeyFromSigKES ::
ContextKES v ->
Period ->
SigKES v ->
VerKeyKES v
verifyOptimizedKES ::
(OptimizedKESAlgorithm v, Signable v a, HasCallStack) =>
ContextKES v ->
VerKeyKES v ->
Period ->
a ->
SigKES v ->
Either String ()
verifyOptimizedKES :: forall v a.
(OptimizedKESAlgorithm v, Signable v a, HasCallStack) =>
ContextKES v
-> VerKeyKES v -> Word -> a -> SigKES v -> Either String ()
verifyOptimizedKES ContextKES v
ctx VerKeyKES v
vk Word
t a
a SigKES v
sig = do
ContextKES v -> Word -> a -> SigKES v -> Either String ()
forall v a.
(OptimizedKESAlgorithm v, Signable v a, HasCallStack) =>
ContextKES v -> Word -> a -> SigKES v -> Either String ()
forall a.
(Signable v a, HasCallStack) =>
ContextKES v -> Word -> a -> SigKES v -> Either String ()
verifySigKES ContextKES v
ctx Word
t a
a SigKES v
sig
let vk' :: VerKeyKES v
vk' = ContextKES v -> Word -> SigKES v -> VerKeyKES v
forall v.
OptimizedKESAlgorithm v =>
ContextKES v -> Word -> SigKES v -> VerKeyKES v
verKeyFromSigKES ContextKES v
ctx Word
t SigKES v
sig
if VerKeyKES v
vk' VerKeyKES v -> VerKeyKES v -> Bool
forall a. Eq a => a -> a -> Bool
== VerKeyKES v
vk
then () -> Either String ()
forall a. a -> Either String a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
else String -> Either String ()
forall a b. a -> Either a b
Left String
"KES verification failed"
instance
( TypeError ('Text "Ord not supported for signing keys, use the hash instead")
, Eq (SignKeyKES v)
) =>
Ord (SignKeyKES v)
where
compare :: SignKeyKES v -> SignKeyKES v -> Ordering
compare = String -> SignKeyKES v -> SignKeyKES v -> Ordering
forall a. HasCallStack => String -> a
error String
"unsupported"
instance
( TypeError ('Text "Ord not supported for verification keys, use the hash instead")
, KESAlgorithm v
) =>
Ord (VerKeyKES v)
where
compare :: VerKeyKES v -> VerKeyKES v -> Ordering
compare = String -> VerKeyKES v -> VerKeyKES v -> Ordering
forall a. HasCallStack => String -> a
error String
"unsupported"
encodeVerKeyKES :: KESAlgorithm v => VerKeyKES v -> Encoding
encodeVerKeyKES :: forall v. KESAlgorithm v => VerKeyKES v -> Encoding
encodeVerKeyKES = ByteString -> Encoding
encodeBytes (ByteString -> Encoding)
-> (VerKeyKES v -> ByteString) -> VerKeyKES v -> Encoding
forall b c a. (b -> c) -> (a -> b) -> a -> c
. VerKeyKES v -> ByteString
forall v. KESAlgorithm v => VerKeyKES v -> ByteString
rawSerialiseVerKeyKES
encodeUnsoundPureSignKeyKES :: UnsoundPureKESAlgorithm v => UnsoundPureSignKeyKES v -> Encoding
encodeUnsoundPureSignKeyKES :: forall v.
UnsoundPureKESAlgorithm v =>
UnsoundPureSignKeyKES v -> Encoding
encodeUnsoundPureSignKeyKES = ByteString -> Encoding
encodeBytes (ByteString -> Encoding)
-> (UnsoundPureSignKeyKES v -> ByteString)
-> UnsoundPureSignKeyKES v
-> Encoding
forall b c a. (b -> c) -> (a -> b) -> a -> c
. UnsoundPureSignKeyKES v -> ByteString
forall v.
UnsoundPureKESAlgorithm v =>
UnsoundPureSignKeyKES v -> ByteString
rawSerialiseUnsoundPureSignKeyKES
encodeSigKES :: KESAlgorithm v => SigKES v -> Encoding
encodeSigKES :: forall v. KESAlgorithm v => SigKES v -> Encoding
encodeSigKES = ByteString -> Encoding
encodeBytes (ByteString -> Encoding)
-> (SigKES v -> ByteString) -> SigKES v -> Encoding
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SigKES v -> ByteString
forall v. KESAlgorithm v => SigKES v -> ByteString
rawSerialiseSigKES
encodeSignKeyKES ::
forall v m.
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
SignKeyKES v ->
m Encoding
encodeSignKeyKES :: forall v (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
SignKeyKES v -> m Encoding
encodeSignKeyKES = (ByteString -> Encoding) -> m ByteString -> m Encoding
forall a b. (a -> b) -> m a -> m b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ByteString -> Encoding
encodeBytes (m ByteString -> m Encoding)
-> (SignKeyKES v -> m ByteString) -> SignKeyKES v -> m Encoding
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SignKeyKES v -> m ByteString
forall v (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
SignKeyKES v -> m ByteString
forall (m :: * -> *).
(MonadST m, MonadThrow m) =>
SignKeyKES v -> m ByteString
rawSerialiseSignKeyKES
decodeVerKeyKES :: forall v s. KESAlgorithm v => Decoder s (VerKeyKES v)
decodeVerKeyKES :: forall v s. KESAlgorithm v => Decoder s (VerKeyKES v)
decodeVerKeyKES = do
ByteString
bs <- Decoder s ByteString
forall s. Decoder s ByteString
decodeBytes
case ByteString -> Maybe (VerKeyKES v)
forall v. KESAlgorithm v => ByteString -> Maybe (VerKeyKES v)
rawDeserialiseVerKeyKES ByteString
bs of
Just VerKeyKES v
vk -> VerKeyKES v -> Decoder s (VerKeyKES v)
forall a. a -> Decoder s a
forall (m :: * -> *) a. Monad m => a -> m a
return VerKeyKES v
vk
Maybe (VerKeyKES v)
Nothing -> String -> String -> ByteString -> Word -> Decoder s (VerKeyKES v)
forall (m :: * -> *) a.
MonadFail m =>
String -> String -> ByteString -> Word -> m a
failSizeCheck String
"decodeVerKeyKES" String
"key" ByteString
bs (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
verKeySizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v))
{-# INLINE decodeVerKeyKES #-}
decodeUnsoundPureSignKeyKES ::
forall v s. UnsoundPureKESAlgorithm v => Decoder s (UnsoundPureSignKeyKES v)
decodeUnsoundPureSignKeyKES :: forall v s.
UnsoundPureKESAlgorithm v =>
Decoder s (UnsoundPureSignKeyKES v)
decodeUnsoundPureSignKeyKES = do
ByteString
bs <- Decoder s ByteString
forall s. Decoder s ByteString
decodeBytes
case ByteString -> Maybe (UnsoundPureSignKeyKES v)
forall v.
UnsoundPureKESAlgorithm v =>
ByteString -> Maybe (UnsoundPureSignKeyKES v)
rawDeserialiseUnsoundPureSignKeyKES ByteString
bs of
Just UnsoundPureSignKeyKES v
vk -> UnsoundPureSignKeyKES v -> Decoder s (UnsoundPureSignKeyKES v)
forall a. a -> Decoder s a
forall (m :: * -> *) a. Monad m => a -> m a
return UnsoundPureSignKeyKES v
vk
Maybe (UnsoundPureSignKeyKES v)
Nothing -> String
-> String
-> ByteString
-> Word
-> Decoder s (UnsoundPureSignKeyKES v)
forall (m :: * -> *) a.
MonadFail m =>
String -> String -> ByteString -> Word -> m a
failSizeCheck String
"decodeUnsoundPureSignKeyKES" String
"key" ByteString
bs (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
signKeySizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v))
{-# INLINE decodeUnsoundPureSignKeyKES #-}
decodeSigKES :: forall v s. KESAlgorithm v => Decoder s (SigKES v)
decodeSigKES :: forall v s. KESAlgorithm v => Decoder s (SigKES v)
decodeSigKES = do
ByteString
bs <- Decoder s ByteString
forall s. Decoder s ByteString
decodeBytes
case ByteString -> Maybe (SigKES v)
forall v. KESAlgorithm v => ByteString -> Maybe (SigKES v)
rawDeserialiseSigKES ByteString
bs of
Just SigKES v
sig -> SigKES v -> Decoder s (SigKES v)
forall a. a -> Decoder s a
forall (m :: * -> *) a. Monad m => a -> m a
return SigKES v
sig
Maybe (SigKES v)
Nothing -> String -> String -> ByteString -> Word -> Decoder s (SigKES v)
forall (m :: * -> *) a.
MonadFail m =>
String -> String -> ByteString -> Word -> m a
failSizeCheck String
"decodeSigKES" String
"signature" ByteString
bs (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sigSizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v))
{-# INLINE decodeSigKES #-}
decodeSignKeyKES ::
forall v s m.
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
Decoder s (m (Maybe (SignKeyKES v)))
decodeSignKeyKES :: forall v s (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
Decoder s (m (Maybe (SignKeyKES v)))
decodeSignKeyKES = do
ByteString
bs <- Decoder s ByteString
forall s. Decoder s ByteString
decodeBytes
let expected :: Int
expected = forall a b. (Integral a, Num b) => a -> b
fromIntegral @Word @Int (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
signKeySizeKES (forall t. Proxy t
forall {k} (t :: k). Proxy t
Proxy @v))
actual :: Int
actual = ByteString -> Int
BS.length ByteString
bs
if Int
actual Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
/= Int
expected
then
String -> Decoder s (m (Maybe (SignKeyKES v)))
forall a. String -> Decoder s a
forall (m :: * -> *) a. MonadFail m => String -> m a
fail
( String
"decodeSignKeyKES: wrong length, expected "
String -> String -> String
forall a. [a] -> [a] -> [a]
++ Int -> String
forall a. Show a => a -> String
show Int
expected
String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
" bytes but got "
String -> String -> String
forall a. [a] -> [a] -> [a]
++ Int -> String
forall a. Show a => a -> String
show Int
actual
)
else m (Maybe (SignKeyKES v)) -> Decoder s (m (Maybe (SignKeyKES v)))
forall a. a -> Decoder s a
forall (m :: * -> *) a. Monad m => a -> m a
return (m (Maybe (SignKeyKES v)) -> Decoder s (m (Maybe (SignKeyKES v))))
-> m (Maybe (SignKeyKES v)) -> Decoder s (m (Maybe (SignKeyKES v)))
forall a b. (a -> b) -> a -> b
$ ByteString -> m (Maybe (SignKeyKES v))
forall v (m :: * -> *).
(UnsoundKESAlgorithm v, MonadST m, MonadThrow m) =>
ByteString -> m (Maybe (SignKeyKES v))
rawDeserialiseSignKeyKES ByteString
bs
type Period = Word
newtype SignedKES v a = SignedKES {forall v a. SignedKES v a -> SigKES v
getSig :: SigKES v}
deriving ((forall x. SignedKES v a -> Rep (SignedKES v a) x)
-> (forall x. Rep (SignedKES v a) x -> SignedKES v a)
-> Generic (SignedKES v a)
forall x. Rep (SignedKES v a) x -> SignedKES v a
forall x. SignedKES v a -> Rep (SignedKES v a) x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
forall v a x. Rep (SignedKES v a) x -> SignedKES v a
forall v a x. SignedKES v a -> Rep (SignedKES v a) x
$cfrom :: forall v a x. SignedKES v a -> Rep (SignedKES v a) x
from :: forall x. SignedKES v a -> Rep (SignedKES v a) x
$cto :: forall v a x. Rep (SignedKES v a) x -> SignedKES v a
to :: forall x. Rep (SignedKES v a) x -> SignedKES v a
Generic)
deriving instance KESAlgorithm v => Show (SignedKES v a)
deriving instance KESAlgorithm v => Eq (SignedKES v a)
instance KESAlgorithm v => NoThunks (SignedKES v a)
signedKES ::
(KESAlgorithm v, Signable v a, MonadST m, MonadThrow m) =>
ContextKES v ->
Period ->
a ->
SignKeyKES v ->
m (SignedKES v a)
signedKES :: forall v a (m :: * -> *).
(KESAlgorithm v, Signable v a, MonadST m, MonadThrow m) =>
ContextKES v -> Word -> a -> SignKeyKES v -> m (SignedKES v a)
signedKES ContextKES v
ctxt Word
time a
a SignKeyKES v
key = SigKES v -> SignedKES v a
forall v a. SigKES v -> SignedKES v a
SignedKES (SigKES v -> SignedKES v a) -> m (SigKES v) -> m (SignedKES v a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ContextKES v -> Word -> a -> SignKeyKES v -> m (SigKES v)
forall v a (m :: * -> *).
(KESAlgorithm v, Signable v a, MonadST m, MonadThrow m) =>
ContextKES v -> Word -> a -> SignKeyKES v -> m (SigKES v)
forall a (m :: * -> *).
(Signable v a, MonadST m, MonadThrow m) =>
ContextKES v -> Word -> a -> SignKeyKES v -> m (SigKES v)
signKES ContextKES v
ctxt Word
time a
a SignKeyKES v
key
verifySignedKES ::
(KESAlgorithm v, Signable v a) =>
ContextKES v ->
VerKeyKES v ->
Period ->
a ->
SignedKES v a ->
Either String ()
verifySignedKES :: forall v a.
(KESAlgorithm v, Signable v a) =>
ContextKES v
-> VerKeyKES v -> Word -> a -> SignedKES v a -> Either String ()
verifySignedKES ContextKES v
ctxt VerKeyKES v
vk Word
j a
a (SignedKES SigKES v
sig) = ContextKES v
-> VerKeyKES v -> Word -> a -> SigKES v -> Either String ()
forall v a.
(KESAlgorithm v, Signable v a, HasCallStack) =>
ContextKES v
-> VerKeyKES v -> Word -> a -> SigKES v -> Either String ()
forall a.
(Signable v a, HasCallStack) =>
ContextKES v
-> VerKeyKES v -> Word -> a -> SigKES v -> Either String ()
verifyKES ContextKES v
ctxt VerKeyKES v
vk Word
j a
a SigKES v
sig
unsoundPureSignedKES ::
(UnsoundPureKESAlgorithm v, Signable v a) =>
ContextKES v ->
Period ->
a ->
UnsoundPureSignKeyKES v ->
SignedKES v a
unsoundPureSignedKES :: forall v a.
(UnsoundPureKESAlgorithm v, Signable v a) =>
ContextKES v
-> Word -> a -> UnsoundPureSignKeyKES v -> SignedKES v a
unsoundPureSignedKES ContextKES v
ctxt Word
time a
a UnsoundPureSignKeyKES v
key = SigKES v -> SignedKES v a
forall v a. SigKES v -> SignedKES v a
SignedKES (SigKES v -> SignedKES v a) -> SigKES v -> SignedKES v a
forall a b. (a -> b) -> a -> b
$ ContextKES v -> Word -> a -> UnsoundPureSignKeyKES v -> SigKES v
forall v a.
(UnsoundPureKESAlgorithm v, Signable v a) =>
ContextKES v -> Word -> a -> UnsoundPureSignKeyKES v -> SigKES v
forall a.
Signable v a =>
ContextKES v -> Word -> a -> UnsoundPureSignKeyKES v -> SigKES v
unsoundPureSignKES ContextKES v
ctxt Word
time a
a UnsoundPureSignKeyKES v
key
encodeSignedKES :: KESAlgorithm v => SignedKES v a -> Encoding
encodeSignedKES :: forall v a. KESAlgorithm v => SignedKES v a -> Encoding
encodeSignedKES (SignedKES SigKES v
s) = SigKES v -> Encoding
forall v. KESAlgorithm v => SigKES v -> Encoding
encodeSigKES SigKES v
s
decodeSignedKES :: KESAlgorithm v => Decoder s (SignedKES v a)
decodeSignedKES :: forall v s a. KESAlgorithm v => Decoder s (SignedKES v a)
decodeSignedKES = SigKES v -> SignedKES v a
forall v a. SigKES v -> SignedKES v a
SignedKES (SigKES v -> SignedKES v a)
-> Decoder s (SigKES v) -> Decoder s (SignedKES v a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Decoder s (SigKES v)
forall v s. KESAlgorithm v => Decoder s (SigKES v)
decodeSigKES
{-# INLINE decodeSignedKES #-}
data SignKeyWithPeriodKES v = SignKeyWithPeriodKES
{ forall v. SignKeyWithPeriodKES v -> SignKeyKES v
skWithoutPeriodKES :: !(SignKeyKES v)
, forall v. SignKeyWithPeriodKES v -> Word
periodKES :: !Period
}
deriving ((forall x.
SignKeyWithPeriodKES v -> Rep (SignKeyWithPeriodKES v) x)
-> (forall x.
Rep (SignKeyWithPeriodKES v) x -> SignKeyWithPeriodKES v)
-> Generic (SignKeyWithPeriodKES v)
forall x. Rep (SignKeyWithPeriodKES v) x -> SignKeyWithPeriodKES v
forall x. SignKeyWithPeriodKES v -> Rep (SignKeyWithPeriodKES v) x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
forall v x.
Rep (SignKeyWithPeriodKES v) x -> SignKeyWithPeriodKES v
forall v x.
SignKeyWithPeriodKES v -> Rep (SignKeyWithPeriodKES v) x
$cfrom :: forall v x.
SignKeyWithPeriodKES v -> Rep (SignKeyWithPeriodKES v) x
from :: forall x. SignKeyWithPeriodKES v -> Rep (SignKeyWithPeriodKES v) x
$cto :: forall v x.
Rep (SignKeyWithPeriodKES v) x -> SignKeyWithPeriodKES v
to :: forall x. Rep (SignKeyWithPeriodKES v) x -> SignKeyWithPeriodKES v
Generic)
deriving instance (KESAlgorithm v, Eq (SignKeyKES v)) => Eq (SignKeyWithPeriodKES v)
deriving instance (KESAlgorithm v, Show (SignKeyKES v)) => Show (SignKeyWithPeriodKES v)
instance KESAlgorithm v => NoThunks (SignKeyWithPeriodKES v)
updateKESWithPeriod ::
(KESAlgorithm v, MonadST m, MonadThrow m) =>
ContextKES v ->
SignKeyWithPeriodKES v ->
m (Maybe (SignKeyWithPeriodKES v))
updateKESWithPeriod :: forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
ContextKES v
-> SignKeyWithPeriodKES v -> m (Maybe (SignKeyWithPeriodKES v))
updateKESWithPeriod ContextKES v
c (SignKeyWithPeriodKES SignKeyKES v
sk Word
t) = MaybeT m (SignKeyWithPeriodKES v)
-> m (Maybe (SignKeyWithPeriodKES v))
forall (m :: * -> *) a. MaybeT m a -> m (Maybe a)
runMaybeT (MaybeT m (SignKeyWithPeriodKES v)
-> m (Maybe (SignKeyWithPeriodKES v)))
-> MaybeT m (SignKeyWithPeriodKES v)
-> m (Maybe (SignKeyWithPeriodKES v))
forall a b. (a -> b) -> a -> b
$ do
SignKeyKES v
sk' <- m (Maybe (SignKeyKES v)) -> MaybeT m (SignKeyKES v)
forall (m :: * -> *) a. m (Maybe a) -> MaybeT m a
MaybeT (m (Maybe (SignKeyKES v)) -> MaybeT m (SignKeyKES v))
-> m (Maybe (SignKeyKES v)) -> MaybeT m (SignKeyKES v)
forall a b. (a -> b) -> a -> b
$ ContextKES v -> SignKeyKES v -> Word -> m (Maybe (SignKeyKES v))
forall v (m :: * -> *).
(KESAlgorithm v, MonadST m, MonadThrow m) =>
ContextKES v -> SignKeyKES v -> Word -> m (Maybe (SignKeyKES v))
updateKES ContextKES v
c SignKeyKES v
sk Word
t
SignKeyWithPeriodKES v -> MaybeT m (SignKeyWithPeriodKES v)
forall a. a -> MaybeT m a
forall (m :: * -> *) a. Monad m => a -> m a
return (SignKeyWithPeriodKES v -> MaybeT m (SignKeyWithPeriodKES v))
-> SignKeyWithPeriodKES v -> MaybeT m (SignKeyWithPeriodKES v)
forall a b. (a -> b) -> a -> b
$ SignKeyKES v -> Word -> SignKeyWithPeriodKES v
forall v. SignKeyKES v -> Word -> SignKeyWithPeriodKES v
SignKeyWithPeriodKES SignKeyKES v
sk' (Word -> Word
forall a. Enum a => a -> a
succ Word
t)
encodedVerKeyKESSizeExpr :: forall v. KESAlgorithm v => Proxy (VerKeyKES v) -> Size
encodedVerKeyKESSizeExpr :: forall v. KESAlgorithm v => Proxy (VerKeyKES v) -> Size
encodedVerKeyKESSizeExpr Proxy (VerKeyKES v)
_proxy =
forall a b. (Integral a, Num b) => a -> b
fromIntegral @Integer @Size (Word -> Integer
forall s a. (Integral s, Integral a) => s -> a
withWordSize (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
verKeySizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v)))
Size -> Size -> Size
forall a. Num a => a -> a -> a
+ forall a b. (Integral a, Num b) => a -> b
fromIntegral @Word @Size (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
verKeySizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v))
encodedSignKeyKESSizeExpr :: forall v. KESAlgorithm v => Proxy (SignKeyKES v) -> Size
encodedSignKeyKESSizeExpr :: forall v. KESAlgorithm v => Proxy (SignKeyKES v) -> Size
encodedSignKeyKESSizeExpr Proxy (SignKeyKES v)
_proxy =
forall a b. (Integral a, Num b) => a -> b
fromIntegral @Integer @Size (Word -> Integer
forall s a. (Integral s, Integral a) => s -> a
withWordSize (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
signKeySizeKES (forall t. Proxy t
forall {k} (t :: k). Proxy t
Proxy @v)))
Size -> Size -> Size
forall a. Num a => a -> a -> a
+ forall a b. (Integral a, Num b) => a -> b
fromIntegral @Word @Size (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
signKeySizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v))
encodedSigKESSizeExpr :: forall v. KESAlgorithm v => Proxy (SigKES v) -> Size
encodedSigKESSizeExpr :: forall v. KESAlgorithm v => Proxy (SigKES v) -> Size
encodedSigKESSizeExpr Proxy (SigKES v)
_proxy =
forall a b. (Integral a, Num b) => a -> b
fromIntegral @Integer @Size (Word -> Integer
forall s a. (Integral s, Integral a) => s -> a
withWordSize (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sigSizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v)))
Size -> Size -> Size
forall a. Num a => a -> a -> a
+ forall a b. (Integral a, Num b) => a -> b
fromIntegral @Word @Size (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sigSizeKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v))
hashPairOfVKeys ::
(KESAlgorithm d, HashAlgorithm h) =>
(VerKeyKES d, VerKeyKES d) ->
Hash h (VerKeyKES d, VerKeyKES d)
hashPairOfVKeys :: forall d h.
(KESAlgorithm d, HashAlgorithm h) =>
(VerKeyKES d, VerKeyKES d) -> Hash h (VerKeyKES d, VerKeyKES d)
hashPairOfVKeys =
((VerKeyKES d, VerKeyKES d) -> ByteString)
-> (VerKeyKES d, VerKeyKES d) -> Hash h (VerKeyKES d, VerKeyKES d)
forall h a. HashAlgorithm h => (a -> ByteString) -> a -> Hash h a
hashWith (((VerKeyKES d, VerKeyKES d) -> ByteString)
-> (VerKeyKES d, VerKeyKES d) -> Hash h (VerKeyKES d, VerKeyKES d))
-> ((VerKeyKES d, VerKeyKES d) -> ByteString)
-> (VerKeyKES d, VerKeyKES d)
-> Hash h (VerKeyKES d, VerKeyKES d)
forall a b. (a -> b) -> a -> b
$ \(VerKeyKES d
a, VerKeyKES d
b) ->
VerKeyKES d -> ByteString
forall v. KESAlgorithm v => VerKeyKES v -> ByteString
rawSerialiseVerKeyKES VerKeyKES d
a ByteString -> ByteString -> ByteString
forall a. Semigroup a => a -> a -> a
<> VerKeyKES d -> ByteString
forall v. KESAlgorithm v => VerKeyKES v -> ByteString
rawSerialiseVerKeyKES VerKeyKES d
b
mungeName :: String -> String
mungeName :: String -> String
mungeName String
basename
| (String
name, Char
'^' : String
nstr) <- (Char -> Bool) -> String -> (String, String)
forall a. (a -> Bool) -> [a] -> ([a], [a])
span (Char -> Char -> Bool
forall a. Eq a => a -> a -> Bool
/= Char
'^') String
basename
, [(Word
n, String
"")] <- ReadS Word
forall a. Read a => ReadS a
reads String
nstr =
String
name String -> String -> String
forall a. [a] -> [a] -> [a]
++ Char
'^' Char -> String -> String
forall a. a -> [a] -> [a]
: Word -> String
forall a. Show a => a -> String
show (Word
n Word -> Word -> Word
forall a. Num a => a -> a -> a
+ Word
1 :: Word)
| Bool
otherwise =
String
basename String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
"_2^1"