Added a multi-sig validator at Agora.MultiSig

This commit is contained in:
Riley Kilgore 2022-03-05 05:31:11 -08:00
parent e81f0910b7
commit b67a992278
3 changed files with 64 additions and 0 deletions

52
src/Agora/MultiSig.hs Normal file
View file

@ -0,0 +1,52 @@
{- |
Module : Agora.MultiSig
Maintainer : riley_kilgore@outlook.com
Description: A basic N of M multisignature validator.
-}
module Agora.MultiSig (
multiSigValidator,
MultiSig (..),
) where
import Plutarch.Api.V1 (
PPubKeyHash,
PScriptContext (..),
)
import Plutarch.Monadic qualified as P
--------------------------------------------------------------------------------
import Agora.Utils (passert)
--------------------------------------------------------------------------------
import GHC.Generics qualified as GHC
import Generics.SOP (Generic)
import Prelude
--------------------------------------------------------------------------------
{- | A MultiSig represents a proof that a particular set of signatures
are present on a transaction.
-}
data MultiSig (s :: S) = MultiSig
{ keys :: PList PPubKeyHash s
-- ^ List of PubKeyHashes that must be present in the list of signatories.
, minSigs :: Integer
} deriving stock (GHC.Generic)
deriving anyclass (Generic)
--------------------------------------------------------------------------------
-- | Validator given 'MultiSig' params.
multiSigValidator :: MultiSig s -> Term s (PData :--> PData :--> PScriptContext :--> PUnit)
multiSigValidator params =
plam $ \_datum _redeemer ctx' -> P.do
ctx <- pletFields @'["txInfo", "purpose"] ctx'
let signatories = pfield @"signatories" # ctx.txInfo
passert "The amount of required signatures is not met."
((fromInteger params.minSigs) #<= (plength #$ pfilter
# (plam $ \a ->
(pelem # pdata a # pfromData signatories))
# pcon params.keys))
(pconstant ())