Skip to content

Commit

Permalink
Implement more decoders for Hydra messages
Browse files Browse the repository at this point in the history
- Stub for TxValid decoder by using empty values (apart from txId)
- Add confirmedTransactionIds parsing for Snapshot
  • Loading branch information
v0d1ch authored and ch1bo committed Sep 25, 2023
1 parent 2ebd33f commit 09e560e
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 3 deletions.
32 changes: 29 additions & 3 deletions src/Kupo/Data/Hydra.hs
Original file line number Diff line number Diff line change
Expand Up @@ -22,11 +22,15 @@ import Kupo.Data.Cardano
)
import Kupo.Data.PartialBlock
( PartialBlock (..)
, PartialTransaction
, PartialTransaction (PartialTransaction, datums, id, inputs, metadata, outputs, scripts)
)

import qualified Data.Aeson.Types as Json
import qualified Data.ByteString.Builder as BS
import qualified Data.Map.Strict as Map
import Kupo.Data.Ogmios
( decodeTransactionId
)

-- Types

Expand Down Expand Up @@ -71,12 +75,34 @@ decodeHydraMessage =
tag <- o .: "tag"
case tag of
("HeadIsOpen" :: Text) -> pure HeadIsOpen
("TxValid" :: Text) -> TxValid <$> undefined
("TxValid" :: Text) -> TxValid <$> decodeTxValid o
("SnapshotConfirmed" :: Text) -> SnapshotConfirmed <$> decodeSnapshotConfirmed o
_ -> pure SomethingElse

decodeTxValid :: Json.Object -> Json.Parser PartialTransaction
decodeTxValid o = do
tx <- o .: "transaction"
id <- tx .: "id" >>= decodeTransactionId
let inputs = [] -- TODO
let outputs = [] -- TODO
let datums = Map.empty -- TODO
let scripts = Map.empty -- TODO
let metadata = Nothing -- TODO
pure PartialTransaction
{ id
, inputs
, outputs
, datums
, scripts
, metadata
}

decodeSnapshotConfirmed :: Json.Object -> Json.Parser Snapshot
decodeSnapshotConfirmed o = do
snapshot <- o .: "snapshot"
number <- snapshot .: "snapshotNumber"
pure $ Snapshot { number, confirmedTransactionIds = undefined }
confirmedTransactionIds <- snapshot .: "confirmedTransactions" >>= mapM decodeTransactionId
pure Snapshot
{ number
, confirmedTransactionIds
}
2 changes: 2 additions & 0 deletions src/Kupo/Data/Ogmios.hs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ module Kupo.Data.Ogmios

, decodeFindIntersectionResponse
, decodeNextBlockResponse
-- ** Cardano decoders
, decodeTransactionId
) where

import Kupo.Prelude
Expand Down

0 comments on commit 09e560e

Please sign in to comment.