Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add SerialiseAsRawBytes instances for PolicyId and AssetName #2270

Merged
merged 2 commits into from
Jan 12, 2021
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
46 changes: 39 additions & 7 deletions cardano-api/src/Cardano/Api/Value.hs
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
{-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE DerivingVia #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}

-- | Currency values
--
@@ -40,6 +41,9 @@ module Cardano.Api.Value
, fromShelleyLovelace
, toMaryValue
, fromMaryValue

-- * Data family instances
, AsType(..)
) where

import Prelude
@@ -48,11 +52,13 @@ import Data.Aeson hiding (Value)
import qualified Data.Aeson as Aeson
import Data.Aeson.Types (Parser, toJSONKeyText)
import Data.ByteString (ByteString)
import qualified Data.ByteString as BS
import qualified Data.ByteString.Char8 as BSC
import qualified Data.HashMap.Strict as HashMap
import qualified Data.Map.Merge.Strict as Map
import Data.Map.Strict (Map)
import qualified Data.Map.Strict as Map
import Data.String (IsString)
import Data.String (IsString(..))
import Data.Text (Text)
import qualified Data.Text as Text
import qualified Data.Text.Encoding as Text
@@ -64,8 +70,9 @@ import qualified Cardano.Ledger.Mary.Value as Mary

import Ouroboros.Consensus.Shelley.Protocol.Crypto (StandardCrypto)

import Cardano.Api.HasTypeProxy
import Cardano.Api.Script
import Cardano.Api.SerialiseRaw (deserialiseFromRawBytesHex, serialiseToRawBytesHex)
import Cardano.Api.SerialiseRaw


-- ----------------------------------------------------------------------------
@@ -118,12 +125,37 @@ quantityToLovelace (Quantity x) = Lovelace x


newtype PolicyId = PolicyId ScriptHash
deriving stock (Show)
deriving newtype (Eq, Ord, IsString)
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex PolicyId

instance HasTypeProxy PolicyId where
data AsType PolicyId = AsPolicyId
proxyToAsType _ = AsPolicyId

instance SerialiseAsRawBytes PolicyId where
serialiseToRawBytes (PolicyId sh) = serialiseToRawBytes sh
deserialiseFromRawBytes AsPolicyId bs =
PolicyId <$> deserialiseFromRawBytes AsScriptHash bs

newtype AssetName = AssetName ByteString
deriving stock (Show)
deriving newtype (Eq, Ord, IsString)
deriving stock (Eq, Ord)
deriving newtype (Show)

instance IsString AssetName where
fromString s
| let bs = Text.encodeUtf8 (Text.pack s)
, BS.length bs <= 32 = AssetName (BSC.pack s)
| otherwise = error "fromString: AssetName over 32 bytes"

instance HasTypeProxy AssetName where
data AsType AssetName = AsAssetName
proxyToAsType _ = AsAssetName

instance SerialiseAsRawBytes AssetName where
serialiseToRawBytes (AssetName bs) = bs
deserialiseFromRawBytes AsAssetName bs
| BS.length bs <= 32 = Just (AssetName bs)
| otherwise = Nothing

instance ToJSON AssetName where
toJSON (AssetName an) = Aeson.String $ Text.decodeUtf8 an