{-# 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,
SignKeyWithPeriodKES (..),
updateKESWithPeriod,
SignedKES (..),
signedKES,
verifySignedKES,
encodeVerKeyKES,
decodeVerKeyKES,
encodeSigKES,
decodeSigKES,
encodeSignedKES,
decodeSignedKES,
encodedVerKeyKESSizeExpr,
encodedSignKeyKESSizeExpr,
encodedSigKESSizeExpr,
sizeVerKeyKES,
sizeSigKES,
sizeSignKeyKES,
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)
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 (SizeVerKeyKES v)
, KnownNat (SizeSignKeyKES v)
, KnownNat (SizeSigKES v)
) =>
KESAlgorithm v
where
data VerKeyKES v :: Type
data SigKES v :: Type
data SignKeyKES v :: Type
type SeedSizeKES v :: Nat
type SizeVerKeyKES v :: Nat
type SizeSignKeyKES v :: Nat
type SizeSigKES v :: Nat
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 ()
sizeVerKeyKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sizeVerKeyKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeVerKeyKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (SizeVerKeyKES 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 @(SizeVerKeyKES v)))
sizeSigKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sizeSigKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSigKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (SizeSigKES 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 @(SizeSigKES v)))
sizeSignKeyKES :: forall v proxy. KESAlgorithm v => proxy v -> Word
sizeSignKeyKES :: forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSignKeyKES proxy v
_ = Integer -> Word
forall a. Num a => Integer -> a
fromInteger (Proxy (SizeSignKeyKES 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 @(SizeSignKeyKES v)))
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
sizeVerKeyKES (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
sizeSignKeyKES (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
sizeSigKES (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 = Word -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSignKeyKES (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 =
Integer -> Size
forall a b. (Integral a, Num b) => a -> b
fromIntegral ((Word -> Integer
forall s a. (Integral s, Integral a) => s -> a
withWordSize :: Word -> Integer) (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeVerKeyKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v)))
Size -> Size -> Size
forall a. Num a => a -> a -> a
+ Word -> Size
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeVerKeyKES (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 =
Integer -> Size
forall a b. (Integral a, Num b) => a -> b
fromIntegral ((Word -> Integer
forall s a. (Integral s, Integral a) => s -> a
withWordSize :: Word -> Integer) (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSignKeyKES (forall t. Proxy t
forall {k} (t :: k). Proxy t
Proxy @v)))
Size -> Size -> Size
forall a. Num a => a -> a -> a
+ Word -> Size
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSignKeyKES (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 =
Integer -> Size
forall a b. (Integral a, Num b) => a -> b
fromIntegral ((Word -> Integer
forall s a. (Integral s, Integral a) => s -> a
withWordSize :: Word -> Integer) (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSigKES (Proxy v
forall {k} (t :: k). Proxy t
Proxy :: Proxy v)))
Size -> Size -> Size
forall a. Num a => a -> a -> a
+ Word -> Size
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Proxy v -> Word
forall v (proxy :: * -> *). KESAlgorithm v => proxy v -> Word
sizeSigKES (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"