Skip to content

Commit

Permalink
Add conversions of ChainPoint to/from ouroboros types
Browse files Browse the repository at this point in the history
  • Loading branch information
HeinrichApfelmus committed Apr 16, 2024
1 parent aec5d98 commit 7609210
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 0 deletions.
1 change: 1 addition & 0 deletions lib/network-layer/cardano-wallet-network-layer.cabal
Expand Up @@ -47,6 +47,7 @@ library
Cardano.Wallet.Network.Implementation
Cardano.Wallet.Network.Implementation.Ouroboros
Cardano.Wallet.Network.Implementation.UnliftIO
Cardano.Wallet.Network.Implementation.Types
Cardano.Wallet.Network.Light
Cardano.Wallet.Network.LocalStateQuery
Cardano.Wallet.Network.LocalStateQuery.Extra
Expand Down
@@ -0,0 +1,65 @@
{-|
Copyright: © 2024 Cardano Foundation
License: Apache-2.0
Conversions between types from @ouroboros-consensus@
and "Cardano.Wallet.Read".
-}
module Cardano.Wallet.Network.Implementation.Types
( fromOuroborosPoint
, toOuroborosPoint
) where

import Prelude

import Cardano.Wallet.Read
( BHeader
, ChainPoint (..)
, SlotNo (..)
)
import Cardano.Wallet.Read.Hash
( Blake2b_256
, Hash
, hashFromBytesShort
, hashToBytesShort
)
import Data.Maybe
( fromJust
)
import Ouroboros.Consensus.Cardano.Block
( CardanoBlock
, CardanoEras
)
import Ouroboros.Consensus.HardFork.Combinator
( OneEraHash (..)
)

import qualified Ouroboros.Network.Block as O

{-----------------------------------------------------------------------------
ChainPoint conversions
------------------------------------------------------------------------------}

toOuroborosPoint :: ChainPoint -> O.Point (CardanoBlock sc)
toOuroborosPoint GenesisPoint =
O.GenesisPoint
toOuroborosPoint (BlockPoint slot h) =
O.BlockPoint (toCardanoSlotNo slot) (toCardanoHash h)

toCardanoSlotNo :: SlotNo -> O.SlotNo
toCardanoSlotNo (SlotNo slot) = O.SlotNo (toEnum $ fromEnum slot)

toCardanoHash :: Hash Blake2b_256 BHeader -> OneEraHash (CardanoEras sc)
toCardanoHash = OneEraHash . hashToBytesShort

fromOuroborosPoint :: O.Point (CardanoBlock sc) -> ChainPoint
fromOuroborosPoint O.GenesisPoint =
GenesisPoint
fromOuroborosPoint (O.BlockPoint slot h) =
BlockPoint (fromCardanoSlotNo slot) (fromCardanoHash h)

fromCardanoSlotNo :: O.SlotNo -> SlotNo
fromCardanoSlotNo (O.SlotNo slot) = SlotNo (fromIntegral slot)

fromCardanoHash :: OneEraHash (CardanoEras sc) -> Hash Blake2b_256 BHeader
fromCardanoHash = fromJust . hashFromBytesShort . getOneEraHash

0 comments on commit 7609210

Please sign in to comment.