{-# LANGUAGE DeriveAnyClass #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE TemplateHaskell #-} -- | -- Module : Network.Polkadot.Metadata.V9 -- Copyright : Aleksandr Krupenkin 2016-2021 -- License : Apache-2.0 -- -- Maintainer : mail@akru.me -- Stability : experimental -- Portability : portable -- -- Metadata version 9 definitions. -- module Network.Polkadot.Metadata.V9 where import Codec.Scale (Decode, Encode, Generic) import Data.Aeson (Options (constructorTagModifier, fieldLabelModifier, sumEncoding), SumEncoding (ObjectWithSingleField), defaultOptions) import Data.Aeson.TH (deriveJSON) import Data.ByteArray.HexString (HexString) import Data.Char (toLower) import Data.Text (Text) import qualified GHC.Generics as GHC (Generic) import Lens.Micro (_head, over) import Network.Polkadot.Metadata.Type (Type) data FunctionArgumentMetadata = FunctionArgumentMetadata { argumentName :: !Text , argumentType :: !Type } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 8 }) ''FunctionArgumentMetadata) data FunctionMetadata = FunctionMetadata { functionName :: !Text , functionArgs :: ![FunctionArgumentMetadata] , functionDocs :: ![Text] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 8 }) ''FunctionMetadata) data EventMetadata = EventMetadata { eventName :: !Text , eventArgs :: ![Type] , eventDocs :: ![Text] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 5 }) ''EventMetadata) data ModuleConstantMetadata = ModuleConstantMetadata { constantName :: !Text , constantType :: !Type , constantValue :: !HexString , constantDocs :: ![Text] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 8 }) ''ModuleConstantMetadata) data ErrorMetadata = ErrorMetadata { errorName :: !Text , errorDocs :: ![Text] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 5 }) ''ErrorMetadata) data StorageHasher = Blake2_128 | Blake2_256 | Twox128 | Twox256 | Twox64Concat deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON defaultOptions ''StorageHasher) data MapType = MapType { mapHasher :: !StorageHasher , mapKey :: !Type , mapValue :: !Type , mapLinked :: !Bool } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 3 }) ''MapType) data DoubleMapType = DoubleMapType { doubleMapHasher :: !StorageHasher , doubleMapKey1 :: !Type , doubleMapKey2 :: !Type , doubleMapValue :: !Type , doubleMapKey2Hasher :: !StorageHasher } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 9 }) ''DoubleMapType) data StorageEntryType = Plain !Type | Map !MapType | DoubleMap !DoubleMapType deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { constructorTagModifier = over _head toLower, sumEncoding = ObjectWithSingleField }) ''StorageEntryType) data StorageEntryModifier = Optional | Default | Required deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON defaultOptions ''StorageEntryModifier) data StorageEntryMetadata = StorageEntryMetadata { entryName :: !Text , entryModifier :: !StorageEntryModifier , entryType :: !StorageEntryType , entryFallback :: !HexString , entryDocs :: ![Text] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 5 }) ''StorageEntryMetadata) data StorageMetadata = StorageMetadata { storagePrefix :: !Text , storageItems :: ![StorageEntryMetadata] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 7 }) ''StorageMetadata) data ModuleMetadata = ModuleMetadata { moduleName :: !Text , moduleStorage :: !(Maybe StorageMetadata) , moduleCalls :: !(Maybe [FunctionMetadata]) , moduleEvents :: !(Maybe [EventMetadata]) , moduleConstants :: ![ModuleConstantMetadata] , moduleErrors :: ![ErrorMetadata] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON (defaultOptions { fieldLabelModifier = over _head toLower . drop 6 }) ''ModuleMetadata) data Metadata = Metadata { modules :: ![ModuleMetadata] } deriving (Eq, Show, Generic, GHC.Generic, Encode, Decode) $(deriveJSON defaultOptions ''Metadata)