-- | Transaction queries

module Blockfrost.Client.Cardano.Transactions
  ( getTx
  , getTxUtxos
  , getTxRedeemers
  , getTxStakes
  , getTxDelegations
  , getTxWithdrawals
  , getTxMirs
  , getTxPoolUpdates
  , getTxPoolRetiring
  , getTxMetadataJSON
  , getTxMetadataCBOR
  , submitTx
  ) where

import Blockfrost.API
import Blockfrost.Client.Types
import Blockfrost.Types

transactionsClient :: MonadBlockfrost m => Project -> TransactionsAPI (AsClientT m)
transactionsClient :: Project -> TransactionsAPI (AsClientT m)
transactionsClient = ((((TxHash -> m Transaction) :<|> (TxHash -> m TransactionUtxos))
  :<|> ((TxHash -> m [TransactionRedeemer])
        :<|> ((TxHash -> m [TransactionStake])
              :<|> (TxHash -> m [TransactionDelegation]))))
 :<|> (((TxHash -> m [TransactionWithdrawal])
        :<|> ((TxHash -> m [TransactionMir])
              :<|> (TxHash -> m [TransactionPoolUpdate])))
       :<|> ((TxHash -> m [TransactionPoolRetiring])
             :<|> ((TxHash -> m [TransactionMetaJSON])
                   :<|> (TxHash -> m [TransactionMetaCBOR])))))
-> TransactionsAPI (AsClientT m)
forall (routes :: * -> *) mode.
GenericServant routes mode =>
ToServant routes mode -> routes mode
fromServant (((((TxHash -> m Transaction) :<|> (TxHash -> m TransactionUtxos))
   :<|> ((TxHash -> m [TransactionRedeemer])
         :<|> ((TxHash -> m [TransactionStake])
               :<|> (TxHash -> m [TransactionDelegation]))))
  :<|> (((TxHash -> m [TransactionWithdrawal])
         :<|> ((TxHash -> m [TransactionMir])
               :<|> (TxHash -> m [TransactionPoolUpdate])))
        :<|> ((TxHash -> m [TransactionPoolRetiring])
              :<|> ((TxHash -> m [TransactionMetaJSON])
                    :<|> (TxHash -> m [TransactionMetaCBOR])))))
 -> TransactionsAPI (AsClientT m))
-> (Project
    -> (((TxHash -> m Transaction) :<|> (TxHash -> m TransactionUtxos))
        :<|> ((TxHash -> m [TransactionRedeemer])
              :<|> ((TxHash -> m [TransactionStake])
                    :<|> (TxHash -> m [TransactionDelegation]))))
       :<|> (((TxHash -> m [TransactionWithdrawal])
              :<|> ((TxHash -> m [TransactionMir])
                    :<|> (TxHash -> m [TransactionPoolUpdate])))
             :<|> ((TxHash -> m [TransactionPoolRetiring])
                   :<|> ((TxHash -> m [TransactionMetaJSON])
                         :<|> (TxHash -> m [TransactionMetaCBOR])))))
-> Project
-> TransactionsAPI (AsClientT m)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CardanoAPI (AsClientT m)
-> (((TxHash -> m Transaction) :<|> (TxHash -> m TransactionUtxos))
    :<|> ((TxHash -> m [TransactionRedeemer])
          :<|> ((TxHash -> m [TransactionStake])
                :<|> (TxHash -> m [TransactionDelegation]))))
   :<|> (((TxHash -> m [TransactionWithdrawal])
          :<|> ((TxHash -> m [TransactionMir])
                :<|> (TxHash -> m [TransactionPoolUpdate])))
         :<|> ((TxHash -> m [TransactionPoolRetiring])
               :<|> ((TxHash -> m [TransactionMetaJSON])
                     :<|> (TxHash -> m [TransactionMetaCBOR]))))
forall route.
CardanoAPI route
-> route
   :- ("txs"
       :> (Tag "Cardano \187 Transactions"
           :> ToServantApi TransactionsAPI))
_transactions (CardanoAPI (AsClientT m)
 -> (((TxHash -> m Transaction) :<|> (TxHash -> m TransactionUtxos))
     :<|> ((TxHash -> m [TransactionRedeemer])
           :<|> ((TxHash -> m [TransactionStake])
                 :<|> (TxHash -> m [TransactionDelegation]))))
    :<|> (((TxHash -> m [TransactionWithdrawal])
           :<|> ((TxHash -> m [TransactionMir])
                 :<|> (TxHash -> m [TransactionPoolUpdate])))
          :<|> ((TxHash -> m [TransactionPoolRetiring])
                :<|> ((TxHash -> m [TransactionMetaJSON])
                      :<|> (TxHash -> m [TransactionMetaCBOR])))))
-> (Project -> CardanoAPI (AsClientT m))
-> Project
-> (((TxHash -> m Transaction) :<|> (TxHash -> m TransactionUtxos))
    :<|> ((TxHash -> m [TransactionRedeemer])
          :<|> ((TxHash -> m [TransactionStake])
                :<|> (TxHash -> m [TransactionDelegation]))))
   :<|> (((TxHash -> m [TransactionWithdrawal])
          :<|> ((TxHash -> m [TransactionMir])
                :<|> (TxHash -> m [TransactionPoolUpdate])))
         :<|> ((TxHash -> m [TransactionPoolRetiring])
               :<|> ((TxHash -> m [TransactionMetaJSON])
                     :<|> (TxHash -> m [TransactionMetaCBOR]))))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> CardanoAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> CardanoAPI (AsClientT m)
cardanoClient

getTx_ :: MonadBlockfrost m => Project -> TxHash -> m Transaction
getTx_ :: Project -> TxHash -> m Transaction
getTx_ = TransactionsAPI (AsClientT m) -> TxHash -> m Transaction
forall route.
TransactionsAPI route
-> route
   :- (Summary "Specific transaction"
       :> (Description "Return content of the requested transaction."
           :> (Capture "hash" TxHash :> Get '[JSON] Transaction)))
_tx (TransactionsAPI (AsClientT m) -> TxHash -> m Transaction)
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m Transaction
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get specific transaction
getTx :: MonadBlockfrost m => TxHash -> m Transaction
getTx :: TxHash -> m Transaction
getTx TxHash
t = (Project -> m Transaction) -> m Transaction
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m Transaction
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m Transaction
`getTx_` TxHash
t)

getTxUtxos_ :: MonadBlockfrost m => Project -> TxHash -> m TransactionUtxos
getTxUtxos_ :: Project -> TxHash -> m TransactionUtxos
getTxUtxos_ = TransactionsAPI (AsClientT m) -> TxHash -> m TransactionUtxos
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction UTXOs"
       :> (Description
             "Return the inputs and UTXOs of the specific transaction."
           :> (Capture "hash" TxHash
               :> ("utxos" :> Get '[JSON] TransactionUtxos))))
_txUtxos (TransactionsAPI (AsClientT m) -> TxHash -> m TransactionUtxos)
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m TransactionUtxos
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction UTXOs
getTxUtxos :: MonadBlockfrost m => TxHash -> m TransactionUtxos
getTxUtxos :: TxHash -> m TransactionUtxos
getTxUtxos TxHash
t = (Project -> m TransactionUtxos) -> m TransactionUtxos
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m TransactionUtxos
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m TransactionUtxos
`getTxUtxos_` TxHash
t)

getTxRedeemers_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionRedeemer]
getTxRedeemers_ :: Project -> TxHash -> m [TransactionRedeemer]
getTxRedeemers_ = TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionRedeemer]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction redeemers"
       :> (Description "Obtain the transaction redeemers."
           :> (Capture "hash" TxHash
               :> ("redeemers" :> Get '[JSON] [TransactionRedeemer]))))
_txRedeemers (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionRedeemer])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionRedeemer]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction redeemers
getTxRedeemers :: MonadBlockfrost m => TxHash -> m [TransactionRedeemer]
getTxRedeemers :: TxHash -> m [TransactionRedeemer]
getTxRedeemers TxHash
t = (Project -> m [TransactionRedeemer]) -> m [TransactionRedeemer]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionRedeemer]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionRedeemer]
`getTxRedeemers_` TxHash
t)

getTxStakes_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionStake]
getTxStakes_ :: Project -> TxHash -> m [TransactionStake]
getTxStakes_ = TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionStake]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction stake addresses certificates "
       :> (Description
             "Obtain information about (de)registration of stake addresses within a transaction."
           :> (Capture "hash" TxHash
               :> ("stakes" :> Get '[JSON] [TransactionStake]))))
_txStakes (TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionStake])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionStake]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction UTXOs
getTxStakes :: MonadBlockfrost m => TxHash -> m [TransactionStake]
getTxStakes :: TxHash -> m [TransactionStake]
getTxStakes TxHash
t = (Project -> m [TransactionStake]) -> m [TransactionStake]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionStake]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionStake]
`getTxStakes_` TxHash
t)

getTxDelegations_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionDelegation]
getTxDelegations_ :: Project -> TxHash -> m [TransactionDelegation]
getTxDelegations_ = TransactionsAPI (AsClientT m)
-> TxHash -> m [TransactionDelegation]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction delegation certificates"
       :> (Description
             "Obtain information about delegation certificates of a specific transaction."
           :> (Capture "hash" TxHash
               :> ("delegations" :> Get '[JSON] [TransactionDelegation]))))
_txDelegations (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionDelegation])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionDelegation]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction delegation certificates
getTxDelegations :: MonadBlockfrost m => TxHash -> m [TransactionDelegation]
getTxDelegations :: TxHash -> m [TransactionDelegation]
getTxDelegations TxHash
t = (Project -> m [TransactionDelegation]) -> m [TransactionDelegation]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionDelegation]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionDelegation]
`getTxDelegations_` TxHash
t)

getTxWithdrawals_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionWithdrawal]
getTxWithdrawals_ :: Project -> TxHash -> m [TransactionWithdrawal]
getTxWithdrawals_ = TransactionsAPI (AsClientT m)
-> TxHash -> m [TransactionWithdrawal]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction withdrawal"
       :> (Description
             "Obtain information about withdrawals of a specific transaction."
           :> (Capture "hash" TxHash
               :> ("withdrawals" :> Get '[JSON] [TransactionWithdrawal]))))
_txWithdrawals (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionWithdrawal])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionWithdrawal]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction withdrawals
getTxWithdrawals :: MonadBlockfrost m => TxHash -> m [TransactionWithdrawal]
getTxWithdrawals :: TxHash -> m [TransactionWithdrawal]
getTxWithdrawals TxHash
t = (Project -> m [TransactionWithdrawal]) -> m [TransactionWithdrawal]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionWithdrawal]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionWithdrawal]
`getTxWithdrawals_` TxHash
t)

getTxMirs_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionMir]
getTxMirs_ :: Project -> TxHash -> m [TransactionMir]
getTxMirs_ = TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionMir]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction MIRs"
       :> (Description
             "Obtain information about Move Instantaneous Rewards (MIRs) of a specific transaction."
           :> (Capture "hash" TxHash
               :> ("mirs" :> Get '[JSON] [TransactionMir]))))
_txMirs (TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionMir])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionMir]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction MIRs (Move Instantaneous Rewards)
getTxMirs :: MonadBlockfrost m => TxHash -> m [TransactionMir]
getTxMirs :: TxHash -> m [TransactionMir]
getTxMirs TxHash
t = (Project -> m [TransactionMir]) -> m [TransactionMir]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionMir]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionMir]
`getTxMirs_` TxHash
t)

getTxPoolUpdates_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionPoolUpdate]
getTxPoolUpdates_ :: Project -> TxHash -> m [TransactionPoolUpdate]
getTxPoolUpdates_ = TransactionsAPI (AsClientT m)
-> TxHash -> m [TransactionPoolUpdate]
forall route.
TransactionsAPI route
-> route
   :- (Summary
         "Transaction stake pool registration and update certificates"
       :> (Description
             "Obtain information about stake pool registration and update certificates of a specific transaction."
           :> (Capture "hash" TxHash
               :> ("pool_updates" :> Get '[JSON] [TransactionPoolUpdate]))))
_txPoolUpdates (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionPoolUpdate])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionPoolUpdate]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction stake pool registration and update certificates
getTxPoolUpdates :: MonadBlockfrost m => TxHash -> m [TransactionPoolUpdate]
getTxPoolUpdates :: TxHash -> m [TransactionPoolUpdate]
getTxPoolUpdates TxHash
t = (Project -> m [TransactionPoolUpdate]) -> m [TransactionPoolUpdate]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionPoolUpdate]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionPoolUpdate]
`getTxPoolUpdates_` TxHash
t)

getTxPoolRetiring_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionPoolRetiring]
getTxPoolRetiring_ :: Project -> TxHash -> m [TransactionPoolRetiring]
getTxPoolRetiring_ = TransactionsAPI (AsClientT m)
-> TxHash -> m [TransactionPoolRetiring]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction stake pool retirement certificates"
       :> (Description
             "Obtain information about stake pool retirements within a specific transaction."
           :> (Capture "hash" TxHash
               :> ("pool_retires" :> Get '[JSON] [TransactionPoolRetiring]))))
_txPoolRetiring (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionPoolRetiring])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionPoolRetiring]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction stake pool retirement certificates
getTxPoolRetiring :: MonadBlockfrost m => TxHash -> m [TransactionPoolRetiring]
getTxPoolRetiring :: TxHash -> m [TransactionPoolRetiring]
getTxPoolRetiring TxHash
t = (Project -> m [TransactionPoolRetiring])
-> m [TransactionPoolRetiring]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionPoolRetiring]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionPoolRetiring]
`getTxPoolRetiring_` TxHash
t)

getTxMetadataJSON_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionMetaJSON]
getTxMetadataJSON_ :: Project -> TxHash -> m [TransactionMetaJSON]
getTxMetadataJSON_ = TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionMetaJSON]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction metadata"
       :> (Description "Obtain the transaction metadata."
           :> (Capture "hash" TxHash
               :> ("metadata" :> Get '[JSON] [TransactionMetaJSON]))))
_txMetadataJSON (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionMetaJSON])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionMetaJSON]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction metadata in JSON
getTxMetadataJSON :: MonadBlockfrost m => TxHash -> m [TransactionMetaJSON]
getTxMetadataJSON :: TxHash -> m [TransactionMetaJSON]
getTxMetadataJSON TxHash
t = (Project -> m [TransactionMetaJSON]) -> m [TransactionMetaJSON]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionMetaJSON]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionMetaJSON]
`getTxMetadataJSON_` TxHash
t)

getTxMetadataCBOR_ :: MonadBlockfrost m => Project -> TxHash -> m [TransactionMetaCBOR]
getTxMetadataCBOR_ :: Project -> TxHash -> m [TransactionMetaCBOR]
getTxMetadataCBOR_ = TransactionsAPI (AsClientT m) -> TxHash -> m [TransactionMetaCBOR]
forall route.
TransactionsAPI route
-> route
   :- (Summary "Transaction metadata in CBOR"
       :> (Description "Obtain the transaction metadata in CBOR."
           :> (Capture "hash" TxHash
               :> ("metadata" :> ("cbor" :> Get '[JSON] [TransactionMetaCBOR])))))
_txMetadataCBOR (TransactionsAPI (AsClientT m)
 -> TxHash -> m [TransactionMetaCBOR])
-> (Project -> TransactionsAPI (AsClientT m))
-> Project
-> TxHash
-> m [TransactionMetaCBOR]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> TransactionsAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TransactionsAPI (AsClientT m)
transactionsClient

-- | Get transaction metadata in CBOR
getTxMetadataCBOR :: MonadBlockfrost m => TxHash -> m [TransactionMetaCBOR]
getTxMetadataCBOR :: TxHash -> m [TransactionMetaCBOR]
getTxMetadataCBOR TxHash
t = (Project -> m [TransactionMetaCBOR]) -> m [TransactionMetaCBOR]
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> TxHash -> m [TransactionMetaCBOR]
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> TxHash -> m [TransactionMetaCBOR]
`getTxMetadataCBOR_` TxHash
t)

submitTx_ :: MonadBlockfrost m => Project -> CBORString -> m TxHash
submitTx_ :: Project -> CBORString -> m TxHash
submitTx_ = CardanoAPI (AsClientT m) -> CBORString -> m TxHash
forall route.
CardanoAPI route
-> route
   :- (Summary "Submit a transaction"
       :> (Description
             "Submit an already serialized transaction to the network."
           :> (Tag "Cardano \187 Transactions"
               :> ("tx"
                   :> ("submit"
                       :> (ReqBody '[CBOR] CBORString :> Post '[JSON] TxHash))))))
_txSubmit (CardanoAPI (AsClientT m) -> CBORString -> m TxHash)
-> (Project -> CardanoAPI (AsClientT m))
-> Project
-> CBORString
-> m TxHash
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Project -> CardanoAPI (AsClientT m)
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> CardanoAPI (AsClientT m)
cardanoClient

-- | Submit an already serialized transaction to the network.
submitTx :: MonadBlockfrost m => CBORString -> m TxHash
submitTx :: CBORString -> m TxHash
submitTx CBORString
txCbor = (Project -> m TxHash) -> m TxHash
forall (m :: * -> *) a.
MonadBlockfrost m =>
(Project -> m a) -> m a
go (Project -> CBORString -> m TxHash
forall (m :: * -> *).
MonadBlockfrost m =>
Project -> CBORString -> m TxHash
`submitTx_` CBORString
txCbor)