From 0f6b43a4f035328072f05bc178b91a774510033b Mon Sep 17 00:00:00 2001 From: Daniel Firth Date: Sun, 19 May 2024 13:19:25 +0000 Subject: [PATCH] cardano-node: 8.9 -> 8.11.0-pre --- CHANGELOG.md | 4 + cardano-api-classy/cardano-api-classy.cabal | 10 +- docs/docs/tutorial/index.md | 4 +- flake.lock | 129 ++++++++---------- flake.nix | 2 +- hydra-cardano-api/hydra-cardano-api.cabal | 32 ++--- hydra-cardano-api/src/Hydra/Cardano/Api/Tx.hs | 14 +- .../src/Hydra/Cardano/Api/TxBody.hs | 4 +- .../config/devnet/genesis-conway.json | 6 +- hydra-cluster/test/Test/CardanoNodeSpec.hs | 2 +- hydra-node/hydra-node.cabal | 10 +- hydra-node/src/Hydra/Chain/Direct/Tx.hs | 26 +++- hydra-node/src/Hydra/Chain/Direct/Wallet.hs | 18 +-- .../src/Hydra/Ledger/Cardano/Evaluate.hs | 5 +- .../Hydra/Chain/Direct/Contract/Mutation.hs | 18 +-- hydra-node/test/Hydra/Chain/Direct/TxSpec.hs | 2 +- .../test/Hydra/Chain/Direct/WalletSpec.hs | 3 +- .../src/Hydra/Plutus/Orphans.hs | 6 +- hydra-plutus/hydra-plutus.cabal | 8 +- plutus-cbor/bench/Main.hs | 8 +- plutus-cbor/exe/encoding-cost/Main.hs | 8 +- .../test/Plutus/Codec/CBOR/EncodingSpec.hs | 4 +- 22 files changed, 168 insertions(+), 155 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index eba76dff580..14a2b8fcec5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 As a minor extension, we also keep a semantic version for the `UNRELEASED` changes. +## Unreleased + +- Tested with `cardano-node 8.11.0` and `cardano-cli 8.23.1.0`. + ## [0.17.0] - 2024-05-20 - **BREAKING** Change `hydra-node` API `/commit` endpoint for committing from scripts [#1380](https://github.com/input-output-hk/hydra/pull/1380): diff --git a/cardano-api-classy/cardano-api-classy.cabal b/cardano-api-classy/cardano-api-classy.cabal index ac54aea9259..fc966c1b695 100644 --- a/cardano-api-classy/cardano-api-classy.cabal +++ b/cardano-api-classy/cardano-api-classy.cabal @@ -50,9 +50,11 @@ library Cardano.Api.Class.ToAlonzoScript Cardano.Api.Classy + -- NOTE: We only use an upper bound on cardano-api and have the other + -- dependencies on cardano-ledger* follow. build-depends: , base >=4.16 - , cardano-api >=8.42.0 && <8.43 - , cardano-ledger-alonzo >=1.6 && <1.7 - , cardano-ledger-conway >=1.12 && <1.13 - , cardano-ledger-core >=1.10 && <1.11 + , cardano-api ^>=8.46 + , cardano-ledger-alonzo + , cardano-ledger-conway + , cardano-ledger-core diff --git a/docs/docs/tutorial/index.md b/docs/docs/tutorial/index.md index 8c990e3a77b..b1c1cc18566 100644 --- a/docs/docs/tutorial/index.md +++ b/docs/docs/tutorial/index.md @@ -40,7 +40,7 @@ mkdir -p bin version=0.17.0 curl -L -O https://github.com/input-output-hk/hydra/releases/download/${version}/hydra-x86_64-linux-${version}.zip unzip -d bin hydra-x86_64-linux-${version}.zip -curl -L -o - https://github.com/input-output-hk/cardano-node/releases/download/8.9.0/cardano-node-8.9.0-linux.tar.gz \ +curl -L -o - https://github.com/IntersectMBO/cardano-node/releases/download/8.11.0/cardano-node-8.11.0-linux.tar.gz \ | tar xz ./bin/cardano-node ./bin/cardano-cli curl -L -o - https://github.com/input-output-hk/mithril/releases/download/2412.0/mithril-2412.0-linux-x64.tar.gz \ | tar xz -C bin mithril-client @@ -55,7 +55,7 @@ mkdir -p bin version=0.17.0 curl -L -O https://github.com/input-output-hk/hydra/releases/download/${version}/hydra-aarch64-darwin-${version}.zip unzip -d bin hydra-aarch64-darwin-${version}.zip -curl -L -o - https://github.com/input-output-hk/cardano-node/releases/download/8.9.0/cardano-node-8.9.0-macos.tar.gz \ +curl -L -o - https://github.com/IntersectMBO/cardano-node/releases/download/8.11.0/cardano-node-8.11.0-macos.tar.gz \ | tar xz --wildcards ./bin/cardano-node ./bin/cardano-cli './bin/*.dylib' curl -L -o - https://github.com/input-output-hk/mithril/releases/download/2412.0/mithril-2412.0-macos-x64.tar.gz \ | tar xz -C bin diff --git a/flake.lock b/flake.lock index 17d6f0dd5cc..bc33157c951 100644 --- a/flake.lock +++ b/flake.lock @@ -20,11 +20,11 @@ "CHaP_2": { "flake": false, "locked": { - "lastModified": 1709731402, - "narHash": "sha256-7h4/ns3WRI3BtK1FbUEm6nMqW1ahNNehiHr7eQ03muk=", + "lastModified": 1715690409, + "narHash": "sha256-+PWaq7ngq5d601d+GBNggNuzT+jXSV7Dl2IrMNCY1KQ=", "owner": "intersectmbo", "repo": "cardano-haskell-packages", - "rev": "8e4f211a8e537c8c939b65e887556bd7441c774c", + "rev": "0ce6797192cbbab051cd8fe5b7516b55273229f1", "type": "github" }, "original": { @@ -305,16 +305,16 @@ "utils": "utils_2" }, "locked": { - "lastModified": 1709733493, - "narHash": "sha256-chcwbks+HyImFk7FpbkC7FFmfpScMx5T7K0TzTkGAww=", + "lastModified": 1715793024, + "narHash": "sha256-BoTWJKRc7gWSzptEuk32A/uV6MRkRx7vKdz34k8IPY8=", "owner": "intersectmbo", "repo": "cardano-node", - "rev": "0d98405a60d57e1c8e13406d51cce0e34356bd64", + "rev": "38c7f1cf2db12dff9c814ad10049f411a4b30448", "type": "github" }, "original": { "owner": "intersectmbo", - "ref": "8.9.0", + "ref": "8.11.0-pre", "repo": "cardano-node", "type": "github" } @@ -843,11 +843,11 @@ "ghc910X": { "flake": false, "locked": { - "lastModified": 1714520650, - "narHash": "sha256-4uz6RA1hRr0RheGNDM49a/B3jszqNNU8iHIow4mSyso=", + "lastModified": 1711543129, + "narHash": "sha256-MUI07CxYOng7ZwHnMCw0ugY3HmWo2p/f4r07CGV7OAM=", "ref": "ghc-9.10", - "rev": "2c6375b9a804ac7fca1e82eb6fcfc8594c67c5f5", - "revCount": 62663, + "rev": "6ecd5f2ff97af53c7334f2d8581651203a2c6b7d", + "revCount": 62607, "submodules": true, "type": "git", "url": "https://gitlab.haskell.org/ghc/ghc" @@ -859,51 +859,51 @@ "url": "https://gitlab.haskell.org/ghc/ghc" } }, - "ghc911": { + "ghc910X_2": { "flake": false, "locked": { - "lastModified": 1714817013, - "narHash": "sha256-m2je4UvWfkgepMeUIiXHMwE6W+iVfUY38VDGkMzjCcc=", - "ref": "refs/heads/master", - "rev": "fc24c5cf6c62ca9e3c8d236656e139676df65034", - "revCount": 62816, + "lastModified": 1714520650, + "narHash": "sha256-4uz6RA1hRr0RheGNDM49a/B3jszqNNU8iHIow4mSyso=", + "ref": "ghc-9.10", + "rev": "2c6375b9a804ac7fca1e82eb6fcfc8594c67c5f5", + "revCount": 62663, "submodules": true, "type": "git", "url": "https://gitlab.haskell.org/ghc/ghc" }, "original": { + "ref": "ghc-9.10", "submodules": true, "type": "git", "url": "https://gitlab.haskell.org/ghc/ghc" } }, - "ghc98X": { + "ghc911": { "flake": false, "locked": { - "lastModified": 1696643148, - "narHash": "sha256-E02DfgISH7EvvNAu0BHiPvl1E5FGMDi0pWdNZtIBC9I=", - "ref": "ghc-9.8", - "rev": "443e870d977b1ab6fc05f47a9a17bc49296adbd6", - "revCount": 61642, + "lastModified": 1711538967, + "narHash": "sha256-KSdOJ8seP3g30FaC2du8QjU9vumMnmzPR5wfkVRXQMk=", + "ref": "refs/heads/master", + "rev": "0acfe391583d77a72051d505f05fab0ada056c49", + "revCount": 62632, "submodules": true, "type": "git", "url": "https://gitlab.haskell.org/ghc/ghc" }, "original": { - "ref": "ghc-9.8", "submodules": true, "type": "git", "url": "https://gitlab.haskell.org/ghc/ghc" } }, - "ghc99": { + "ghc911_2": { "flake": false, "locked": { - "lastModified": 1701580282, - "narHash": "sha256-drA01r3JrXnkKyzI+owMZGxX0JameMzjK0W5jJE/+V4=", + "lastModified": 1714817013, + "narHash": "sha256-m2je4UvWfkgepMeUIiXHMwE6W+iVfUY38VDGkMzjCcc=", "ref": "refs/heads/master", - "rev": "f5eb0f2982e9cf27515e892c4bdf634bcfb28459", - "revCount": 62197, + "rev": "fc24c5cf6c62ca9e3c8d236656e139676df65034", + "revCount": 62816, "submodules": true, "type": "git", "url": "https://gitlab.haskell.org/ghc/ghc" @@ -952,11 +952,11 @@ "hackageNix": { "flake": false, "locked": { - "lastModified": 1709684582, - "narHash": "sha256-+rC8Vpaxdd4Nw2fJIn9wzAnzW5arILly5AkTG6chRAw=", + "lastModified": 1711412520, + "narHash": "sha256-48Aw1X7IuXZR6Wi2WOlvj9HpoUHty/JW1MqAehgnoHo=", "owner": "input-output-hk", "repo": "hackage.nix", - "rev": "c2ed9aa79252ed67a1fb694b3fffaf7dd7ead6d2", + "rev": "fc84d1170ccc83d50db7b71a6edd090b2cef7657", "type": "github" }, "original": { @@ -974,8 +974,8 @@ "cardano-shell": "cardano-shell", "flake-compat": "flake-compat_3", "ghc-8.6.5-iohk": "ghc-8.6.5-iohk", - "ghc98X": "ghc98X", - "ghc99": "ghc99", + "ghc910X": "ghc910X", + "ghc911": "ghc911", "hackage": [ "cardano-node", "hackageNix" @@ -990,7 +990,6 @@ "hpc-coveralls": "hpc-coveralls", "hydra": "hydra", "iserv-proxy": "iserv-proxy", - "nix-tools-static": "nix-tools-static", "nixpkgs": [ "cardano-node", "nixpkgs" @@ -1007,11 +1006,11 @@ "stackage": "stackage" }, "locked": { - "lastModified": 1708911681, - "narHash": "sha256-QGkzPN1HUYxgMU2EwiwjMvR2gQF0ffUdxALq1+bOdcY=", + "lastModified": 1712278203, + "narHash": "sha256-L4eFUxnID2EYYtONE3fmZxPQdgPlB6XbAfIjlZi4c+U=", "owner": "input-output-hk", "repo": "haskell.nix", - "rev": "5031fa0b8346fcc533c33073530ca87b8390add3", + "rev": "57938c23a4d40e5a746f05f2b71af11a7273a133", "type": "github" }, "original": { @@ -1029,8 +1028,8 @@ "cardano-shell": "cardano-shell_2", "flake-compat": "flake-compat_5", "ghc-8.6.5-iohk": "ghc-8.6.5-iohk_2", - "ghc910X": "ghc910X", - "ghc911": "ghc911", + "ghc910X": "ghc910X_2", + "ghc911": "ghc911_2", "hackage": "hackage", "hls-1.10": "hls-1.10_2", "hls-2.0": "hls-2.0_2", @@ -1539,15 +1538,16 @@ "sodium": "sodium" }, "locked": { - "lastModified": 1709083850, - "narHash": "sha256-6DQ89ktt8rRVV1pXEyX2JwPjaqS0mQkelkmJmka04rg=", + "lastModified": 1715311504, + "narHash": "sha256-Jxma8/3WMb++2V1sp/iMF+6azv8cBR+ZbkLr61p2R24=", "owner": "input-output-hk", "repo": "iohk-nix", - "rev": "1c793a53ac0bd99b795c2180eb23d37e8389a74b", + "rev": "47727032a26ed92438afef6bdd45c95cd7399694", "type": "github" }, "original": { "owner": "input-output-hk", + "ref": "node-8.11", "repo": "iohk-nix", "type": "github" } @@ -1555,18 +1555,18 @@ "iserv-proxy": { "flake": false, "locked": { - "lastModified": 1691634696, - "narHash": "sha256-MZH2NznKC/gbgBu8NgIibtSUZeJ00HTLJ0PlWKCBHb0=", - "ref": "hkm/remote-iserv", - "rev": "43a979272d9addc29fbffc2e8542c5d96e993d73", - "revCount": 14, - "type": "git", - "url": "https://gitlab.haskell.org/hamishmack/iserv-proxy.git" + "lastModified": 1708894040, + "narHash": "sha256-Rv+PajrnuJ6AeyhtqzMN+bcR8z9+aEnrUass+N951CQ=", + "owner": "stable-haskell", + "repo": "iserv-proxy", + "rev": "2f2a318fd8837f8063a0d91f329aeae29055fba9", + "type": "github" }, "original": { - "ref": "hkm/remote-iserv", - "type": "git", - "url": "https://gitlab.haskell.org/hamishmack/iserv-proxy.git" + "owner": "stable-haskell", + "ref": "iserv-syms", + "repo": "iserv-proxy", + "type": "github" } }, "iserv-proxy_2": { @@ -1797,23 +1797,6 @@ "type": "github" } }, - "nix-tools-static": { - "flake": false, - "locked": { - "lastModified": 1706266250, - "narHash": "sha256-9t+GRk3eO9muCtKdNAwBtNBZ5dH1xHcnS17WaQyftwA=", - "owner": "input-output-hk", - "repo": "haskell-nix-example", - "rev": "580cb6db546a7777dad3b9c0fa487a366c045c4e", - "type": "github" - }, - "original": { - "owner": "input-output-hk", - "ref": "nix", - "repo": "haskell-nix-example", - "type": "github" - } - }, "nix2container": { "inputs": { "flake-utils": "flake-utils_2", @@ -2848,11 +2831,11 @@ "stackage": { "flake": false, "locked": { - "lastModified": 1708906175, - "narHash": "sha256-KJDF0CO077Jx4GjjPK6pNkx6NkY7p1x5RMPfaIe8nl4=", + "lastModified": 1712276009, + "narHash": "sha256-KlRJ+CGXRueyz2VRLDwra5JBNaI2GkltNJAjHa7fowE=", "owner": "input-output-hk", "repo": "stackage.nix", - "rev": "bfa4778050cf69fe50f91d39dcefbb9005d6d0d0", + "rev": "758035379a5ac4390879e4cd5164abe0c96fcea7", "type": "github" }, "original": { diff --git a/flake.nix b/flake.nix index 8e7f60894bb..add6f85dec1 100644 --- a/flake.nix +++ b/flake.nix @@ -18,7 +18,7 @@ url = "github:cardano-scaling/haskell-language-server?ref=2.6-patched"; flake = false; }; - cardano-node.url = "github:intersectmbo/cardano-node/8.9.0"; + cardano-node.url = "github:intersectmbo/cardano-node/8.11.0-pre"; mithril.url = "github:input-output-hk/mithril/2418.1"; nix-npm-buildpackage.url = "github:serokell/nix-npm-buildpackage"; }; diff --git a/hydra-cardano-api/hydra-cardano-api.cabal b/hydra-cardano-api/hydra-cardano-api.cabal index c61133a2fb7..f46274b5aa4 100644 --- a/hydra-cardano-api/hydra-cardano-api.cabal +++ b/hydra-cardano-api/hydra-cardano-api.cabal @@ -75,30 +75,30 @@ library Hydra.Cardano.Api.VerificationKey Hydra.Cardano.Api.Witness - -- NOTE: We use very narrow bounds on cardano libraries as they tend to break - -- their interfaces often. + -- NOTE: We only use an upper bound on cardano-api and have the other + -- dependencies on cardano-ledger* and plutus-ledger-api follow. build-depends: , aeson >=2 , base >=4.16 , base16-bytestring , bytestring - , cardano-api >=8.42.0 && <8.43 + , cardano-api ^>=8.46 , cardano-api-classy - , cardano-binary >=1.7.0 && <1.8 - , cardano-crypto-class >=2.1.1 && <2.2 - , cardano-ledger-allegra >=1.3 && <1.4 - , cardano-ledger-alonzo >=1.6 && <1.7 - , cardano-ledger-api >=1.8 && <1.9 - , cardano-ledger-babbage >=1.6 && <1.7 - , cardano-ledger-binary >=1.3 && <1.4 - , cardano-ledger-byron >=1.0.0 && <1.1 - , cardano-ledger-conway >=1.12 && <1.13 - , cardano-ledger-core >=1.10 && <1.11 - , cardano-ledger-mary >=1.5 && <1.6 - , cardano-ledger-shelley >=1.9 && <1.10 + , cardano-binary + , cardano-crypto-class + , cardano-ledger-allegra + , cardano-ledger-alonzo + , cardano-ledger-api + , cardano-ledger-babbage + , cardano-ledger-binary + , cardano-ledger-byron + , cardano-ledger-conway + , cardano-ledger-core + , cardano-ledger-mary + , cardano-ledger-shelley , containers , lens - , plutus-ledger-api >=1.21 && <1.22 + , plutus-ledger-api , QuickCheck , serialise , text >=2 diff --git a/hydra-cardano-api/src/Hydra/Cardano/Api/Tx.hs b/hydra-cardano-api/src/Hydra/Cardano/Api/Tx.hs index a38accdc1af..49202994012 100644 --- a/hydra-cardano-api/src/Hydra/Cardano/Api/Tx.hs +++ b/hydra-cardano-api/src/Hydra/Cardano/Api/Tx.hs @@ -10,7 +10,7 @@ import Cardano.Ledger.Alonzo.TxAuxData (translateAlonzoTxAuxData) import Cardano.Ledger.Alonzo.TxWits qualified as Ledger import Cardano.Ledger.Api ( AlonzoPlutusPurpose (..), - AsIndex (..), + AsIx (..), ConwayPlutusPurpose (..), EraTx (mkBasicTx), addrTxOutL, @@ -143,13 +143,13 @@ convertConwayTx = $ Map.toList redeemerMap translatePlutusPurpose :: - Conway.ConwayPlutusPurpose Ledger.AsIndex (Ledger.ConwayEra StandardCrypto) -> - Maybe (Ledger.AlonzoPlutusPurpose Ledger.AsIndex (Ledger.BabbageEra StandardCrypto)) + Conway.ConwayPlutusPurpose Ledger.AsIx (Ledger.ConwayEra StandardCrypto) -> + Maybe (Ledger.AlonzoPlutusPurpose Ledger.AsIx (Ledger.BabbageEra StandardCrypto)) translatePlutusPurpose = \case - ConwaySpending (AsIndex ix) -> Just $ AlonzoSpending (AsIndex ix) - ConwayMinting (AsIndex ix) -> Just $ AlonzoMinting (AsIndex ix) - ConwayCertifying (AsIndex ix) -> Just $ AlonzoCertifying (AsIndex ix) - ConwayRewarding (AsIndex ix) -> Just $ AlonzoRewarding (AsIndex ix) + ConwaySpending (AsIx ix) -> Just $ AlonzoSpending (AsIx ix) + ConwayMinting (AsIx ix) -> Just $ AlonzoMinting (AsIx ix) + ConwayCertifying (AsIx ix) -> Just $ AlonzoCertifying (AsIx ix) + ConwayRewarding (AsIx ix) -> Just $ AlonzoRewarding (AsIx ix) ConwayVoting{} -> Nothing ConwayProposing{} -> Nothing diff --git a/hydra-cardano-api/src/Hydra/Cardano/Api/TxBody.hs b/hydra-cardano-api/src/Hydra/Cardano/Api/TxBody.hs index 54c13e21d3c..f83a35d43f2 100644 --- a/hydra-cardano-api/src/Hydra/Cardano/Api/TxBody.hs +++ b/hydra-cardano-api/src/Hydra/Cardano/Api/TxBody.hs @@ -3,7 +3,7 @@ module Hydra.Cardano.Api.TxBody where import Hydra.Cardano.Api.Prelude import Cardano.Ledger.Alonzo.TxWits qualified as Ledger -import Cardano.Ledger.Api (AlonzoPlutusPurpose (..), AsIndex, AsItem (..), PlutusPurpose) +import Cardano.Ledger.Api (AlonzoPlutusPurpose (..), AsItem (..), AsIx, PlutusPurpose) import Cardano.Ledger.Babbage.Core (redeemerPointer) import Cardano.Ledger.BaseTypes (strictMaybeToMaybe) import Cardano.Ledger.Core qualified as Ledger @@ -53,7 +53,7 @@ findScriptMinting (getTxBody -> ShelleyTxBody _ _ scripts _ _ _) pid = do lookupRedeemer :: Plutus.FromData a => - PlutusPurpose AsIndex LedgerEra -> + PlutusPurpose AsIx LedgerEra -> TxBodyScriptData Era -> Maybe a lookupRedeemer ptr scriptData = do diff --git a/hydra-cluster/config/devnet/genesis-conway.json b/hydra-cluster/config/devnet/genesis-conway.json index 4410964d59f..7bccdf13f3c 100644 --- a/hydra-cluster/config/devnet/genesis-conway.json +++ b/hydra-cluster/config/devnet/genesis-conway.json @@ -34,6 +34,8 @@ "committee": { "members": { }, - "quorum": 0 - } + "threshold": 0 + }, + "minFeeRefScriptCostPerByte": 0, + "plutusV3CostModel":[] } diff --git a/hydra-cluster/test/Test/CardanoNodeSpec.hs b/hydra-cluster/test/Test/CardanoNodeSpec.hs index 970508038a7..20e3ad0d041 100644 --- a/hydra-cluster/test/Test/CardanoNodeSpec.hs +++ b/hydra-cluster/test/Test/CardanoNodeSpec.hs @@ -23,7 +23,7 @@ spec = do -- false positives test errors in case someone uses an "untested" / -- different than in shell.nix version of cardano-node and cardano-cli. it "has expected cardano-node version available" $ - getCardanoNodeVersion >>= (`shouldContain` "8.9.0") + getCardanoNodeVersion >>= (`shouldContain` "8.11.0") around (failAfter 5 . setupTracerAndTempDir) $ do it "withCardanoNodeDevnet does start a block-producing devnet within 5 seconds" $ \(tr, tmp) -> diff --git a/hydra-node/hydra-node.cabal b/hydra-node/hydra-node.cabal index 6ec3f0ab656..ffb44a8cd51 100644 --- a/hydra-node/hydra-node.cabal +++ b/hydra-node/hydra-node.cabal @@ -151,11 +151,11 @@ library , optparse-applicative , ouroboros-consensus , ouroboros-consensus-cardano - , ouroboros-network-api >=0.1.0.0 - , ouroboros-network-framework >=0.3.0.0 - , ouroboros-network-protocols >=0.3.0.0 - , plutus-core >=1.21 && <1.22 - , plutus-ledger-api >=1.21 && <1.22 + , ouroboros-network-api ^>=0.7.1 + , ouroboros-network-framework + , ouroboros-network-protocols ^>=0.8 + , plutus-core >=1.21 + , plutus-ledger-api >=1.21 , prometheus , QuickCheck , quickcheck-instances diff --git a/hydra-node/src/Hydra/Chain/Direct/Tx.hs b/hydra-node/src/Hydra/Chain/Direct/Tx.hs index fa6173f963d..3c52e355676 100644 --- a/hydra-node/src/Hydra/Chain/Direct/Tx.hs +++ b/hydra-node/src/Hydra/Chain/Direct/Tx.hs @@ -13,12 +13,13 @@ import Hydra.Cardano.Api import Hydra.Prelude import Cardano.Api.UTxO qualified as UTxO +import Cardano.Ledger.Alonzo.Core (AsIxItem (..)) import Cardano.Ledger.Alonzo.Scripts (ExUnits (..)) +import Cardano.Ledger.Alonzo.Tx (AlonzoTx) import Cardano.Ledger.Alonzo.TxAuxData (AlonzoTxAuxData (..)) import Cardano.Ledger.Api ( AlonzoPlutusPurpose (..), - AsIndex (..), - AsItem (..), + AsIx (..), EraTxAuxData (hashTxAuxData), Redeemers (..), auxDataHashTxBodyL, @@ -35,6 +36,8 @@ import Cardano.Ledger.Api ( ) import Cardano.Ledger.Babbage.Core (redeemerPointerInverse) import Cardano.Ledger.BaseTypes (StrictMaybe (..)) +import Cardano.Ledger.Plutus.Data (Data) +import Cardano.Ledger.TxIn qualified import Control.Lens ((.~), (<>~), (^.)) import Data.Aeson qualified as Aeson import Data.ByteString qualified as BS @@ -78,6 +81,7 @@ import Hydra.Party (Party, partyFromChain, partyToChain) import Hydra.Plutus.Extras (posixFromUTCTime, posixToUTCTime) import Hydra.Plutus.Orphans () import Hydra.Snapshot (Snapshot (..), SnapshotNumber, fromChainSnapshot) +import Ouroboros.Consensus.Cardano.Block (StandardBabbage) import PlutusLedgerApi.V2 (CurrencySymbol (CurrencySymbol), fromBuiltin, getPubKeyHash, toBuiltin) import PlutusLedgerApi.V2 qualified as Plutus import Test.QuickCheck (vectorOf) @@ -259,6 +263,10 @@ commitTx networkId scriptRegistry headId party commitBlueprintTx (initialInput, & bodyTxL . mintTxBodyL .~ mempty & addMetadata (mkHydraHeadV1TxName "CommitTx") where + addMetadata :: + TxMetadata -> + AlonzoTx StandardBabbage -> + AlonzoTx StandardBabbage addMetadata (TxMetadata newMetadata) tx = let newMetadataMap = toShelleyMetadata newMetadata @@ -272,6 +280,9 @@ commitTx networkId scriptRegistry headId party commitBlueprintTx (initialInput, & auxDataTxL .~ SJust newAuxData & bodyTxL . auxDataHashTxBodyL .~ SJust (hashTxAuxData newAuxData) + spendFromInitial :: + AlonzoTx StandardBabbage -> + AlonzoTx StandardBabbage spendFromInitial tx = let newRedeemers = resolveSpendingRedeemers tx @@ -283,6 +294,10 @@ commitTx networkId scriptRegistry headId party commitBlueprintTx (initialInput, & witsTxL . rdmrsTxWitsL .~ mkRedeemers newRedeemers newInputs -- Make redeemers (with zeroed units) from a TxIn -> Data map and a set of transaction inputs + mkRedeemers :: + Map (Cardano.Ledger.TxIn.TxIn StandardCrypto) (Data StandardBabbage) -> + Set (Cardano.Ledger.TxIn.TxIn StandardCrypto) -> + Redeemers StandardBabbage mkRedeemers resolved inputs = Redeemers . Map.fromList $ foldl' @@ -291,18 +306,21 @@ commitTx networkId scriptRegistry headId party commitBlueprintTx (initialInput, in case Map.lookup txin resolved of Nothing -> newRedeemerData Just d -> - (AlonzoSpending (AsIndex ix), (d, ExUnits 0 0)) : newRedeemerData + (AlonzoSpending (AsIx ix), (d, ExUnits 0 0)) : newRedeemerData ) [] inputs -- Create a TxIn -> Data map of all spending redeemers + resolveSpendingRedeemers :: + AlonzoTx StandardBabbage -> + Map (Cardano.Ledger.TxIn.TxIn StandardCrypto) (Data StandardBabbage) resolveSpendingRedeemers tx = Map.foldMapWithKey ( \p (d, _ex) -> -- XXX: Should soon be available through cardano-ledger-api again case redeemerPointerInverse (tx ^. bodyTxL) p of - SJust (AlonzoSpending (AsItem txIn)) -> Map.singleton txIn d + SJust (AlonzoSpending (AsIxItem _ txIn)) -> Map.singleton txIn d _ -> mempty ) (unRedeemers $ tx ^. witsTxL . rdmrsTxWitsL) diff --git a/hydra-node/src/Hydra/Chain/Direct/Wallet.hs b/hydra-node/src/Hydra/Chain/Direct/Wallet.hs index 230aab8a788..0fc6092e052 100644 --- a/hydra-node/src/Hydra/Chain/Direct/Wallet.hs +++ b/hydra-node/src/Hydra/Chain/Direct/Wallet.hs @@ -14,10 +14,10 @@ import Cardano.Ledger.Alonzo.Plutus.Context (ContextError) import Cardano.Ledger.Alonzo.Scripts ( AlonzoEraScript (..), AlonzoPlutusPurpose (AlonzoSpending), - AsIndex (..), + AsIx (..), ExUnits (ExUnits), plutusScriptLanguage, - unAsIndex, + unAsIx, ) import Cardano.Ledger.Alonzo.TxWits ( AlonzoTxWits (..), @@ -239,7 +239,7 @@ data ErrCoverFee = ErrNotEnoughFunds ChangeError | ErrNoFuelUTxOFound | ErrUnknownInput {input :: TxIn} - | ErrScriptExecutionFailed {scriptFailure :: (PlutusPurpose AsIndex LedgerEra, TransactionScriptFailure LedgerEra)} + | ErrScriptExecutionFailed {scriptFailure :: (PlutusPurpose AsIx LedgerEra, TransactionScriptFailure LedgerEra)} | ErrTranslationError (ContextError LedgerEra) deriving stock (Show) @@ -307,7 +307,7 @@ coverFee_ pparams systemStart epochInfo lookupUTxO walletUTxO partialTx@Babbage. -- Compute fee using a body with selected txOut to pay fees (= full change) -- and an aditional witness (we will sign this tx later) - let fee = estimateMinFeeTx pparams costingTx additionalWitnesses 0 + let fee = estimateMinFeeTx pparams costingTx additionalWitnesses 0 0 costingTx = unbalancedTx & bodyTxL . outputsTxBodyL %~ (|> feeTxOut) @@ -366,7 +366,7 @@ coverFee_ pparams systemStart epochInfo lookupUTxO walletUTxO partialTx@Babbage. changeOut = totalIn <> invert totalOut refScript = SNothing - adjustRedeemers :: Set TxIn -> Set TxIn -> Map (PlutusPurpose AsIndex LedgerEra) ExUnits -> Redeemers LedgerEra -> Redeemers LedgerEra + adjustRedeemers :: Set TxIn -> Set TxIn -> Map (PlutusPurpose AsIx LedgerEra) ExUnits -> Redeemers LedgerEra -> Redeemers LedgerEra adjustRedeemers initialInputs finalInputs estimatedCosts (Redeemers initialRedeemers) = Redeemers $ Map.fromList $ map adjustOne $ Map.toList initialRedeemers where @@ -377,12 +377,12 @@ coverFee_ pparams systemStart epochInfo lookupUTxO walletUTxO partialTx@Babbage. adjustOne (ptr, (d, _exUnits)) = case ptr of AlonzoSpending idx - | fromIntegral (unAsIndex idx) `elem` differences -> - (AlonzoSpending (AsIndex (unAsIndex idx + 1)), (d, executionUnitsFor ptr)) + | fromIntegral (unAsIx idx) `elem` differences -> + (AlonzoSpending (AsIx (unAsIx idx + 1)), (d, executionUnitsFor ptr)) _ -> (ptr, (d, executionUnitsFor ptr)) - executionUnitsFor :: PlutusPurpose AsIndex LedgerEra -> ExUnits + executionUnitsFor :: PlutusPurpose AsIx LedgerEra -> ExUnits executionUnitsFor ptr = let ExUnits maxMem maxCpu = pparams ^. ppMaxTxExUnitsL ExUnits totalMem totalCpu = foldMap identity estimatedCosts @@ -418,7 +418,7 @@ estimateScriptsCost :: Map TxIn TxOut -> -- | The pre-constructed transaction Babbage.AlonzoTx LedgerEra -> - Either ErrCoverFee (Map (PlutusPurpose AsIndex LedgerEra) ExUnits) + Either ErrCoverFee (Map (PlutusPurpose AsIx LedgerEra) ExUnits) estimateScriptsCost pparams systemStart epochInfo utxo tx = do case result of Left translationError -> diff --git a/hydra-node/src/Hydra/Ledger/Cardano/Evaluate.hs b/hydra-node/src/Hydra/Ledger/Cardano/Evaluate.hs index 486e6e19bdb..7dd3a0a2c52 100644 --- a/hydra-node/src/Hydra/Ledger/Cardano/Evaluate.hs +++ b/hydra-node/src/Hydra/Ledger/Cardano/Evaluate.hs @@ -62,6 +62,7 @@ import Hydra.Cardano.Api ( import Hydra.Cardano.Api.Pretty (renderTxWithUTxO) import Hydra.ContestationPeriod (ContestationPeriod (UnsafeContestationPeriod)) import Hydra.Ledger.Cardano.Time (slotNoFromUTCTime, slotNoToUTCTime) +import Ouroboros.Consensus.Block (GenesisWindow (..)) import Ouroboros.Consensus.Cardano.Block (CardanoEras) import Ouroboros.Consensus.HardFork.History ( Bound (Bound, boundEpoch, boundSlot, boundTime), @@ -218,7 +219,7 @@ prepareTxScripts tx utxo = do Right x -> pure x -- Fully applied UPLC programs which we could run using the cekMachine - programs <- forM results $ \(PlutusWithContext protocolVersion script arguments _exUnits _costModel) -> do + programs <- forM results $ \(PlutusWithContext protocolVersion script _ arguments _exUnits _costModel) -> do (PlutusRunnable x) <- case script of Right runnable -> pure runnable @@ -319,6 +320,7 @@ eraHistoryWithHorizonAt slotNo@(SlotNo n) = , -- NOTE: unused if the 'eraEnd' is already defined, but would be used to -- extend the last era accordingly in the real cardano-node eraSafeZone = UnsafeIndefiniteSafeZone + , eraGenesisWin = GenesisWindow 1 } eraHistoryWithoutHorizon :: EraHistory @@ -341,6 +343,7 @@ eraHistoryWithoutHorizon = , -- NOTE: unused if the 'eraEnd' is already defined, but would be used to -- extend the last era accordingly in the real cardano-node eraSafeZone = UnsafeIndefiniteSafeZone + , eraGenesisWin = GenesisWindow 1 } epochSize :: EpochSize diff --git a/hydra-node/test/Hydra/Chain/Direct/Contract/Mutation.hs b/hydra-node/test/Hydra/Chain/Direct/Contract/Mutation.hs index 2b86a72cb14..6095529d4db 100644 --- a/hydra-node/test/Hydra/Chain/Direct/Contract/Mutation.hs +++ b/hydra-node/test/Hydra/Chain/Direct/Contract/Mutation.hs @@ -133,7 +133,7 @@ import Hydra.Cardano.Api import Cardano.Api.UTxO qualified as UTxO import Cardano.Ledger.Alonzo.Scripts qualified as Ledger import Cardano.Ledger.Alonzo.TxWits qualified as Ledger -import Cardano.Ledger.Api (AllegraEraTxBody (vldtTxBodyL), AlonzoPlutusPurpose (..), AsIndex (..), inputsTxBodyL, mintTxBodyL, outputsTxBodyL, reqSignerHashesTxBodyL) +import Cardano.Ledger.Api (AllegraEraTxBody (vldtTxBodyL), AlonzoPlutusPurpose (..), AsIx (..), inputsTxBodyL, mintTxBodyL, outputsTxBodyL, reqSignerHashesTxBodyL) import Cardano.Ledger.Core qualified as Ledger import Cardano.Ledger.Credential (Credential (..)) import Cardano.Ledger.Mary.Value qualified as Ledger @@ -304,13 +304,13 @@ applyMutation mutation (tx@(Tx body wits), utxo) = case mutation of | isHeadOutput (resolveInput ix) = (Ledger.Data (toData newRedeemer), units) | otherwise = (dat, units) - resolveInput :: Ledger.AlonzoPlutusPurpose AsIndex w -> TxOut CtxUTxO + resolveInput :: Ledger.AlonzoPlutusPurpose AsIx w -> TxOut CtxUTxO resolveInput ix = let k = case ix of - AlonzoSpending i -> unAsIndex i - AlonzoCertifying i -> unAsIndex i - AlonzoRewarding i -> unAsIndex i - AlonzoMinting i -> unAsIndex i + AlonzoSpending i -> unAsIx i + AlonzoCertifying i -> unAsIx i + AlonzoRewarding i -> unAsIx i + AlonzoMinting i -> unAsIx i txIn = Set.elemAt (fromIntegral k) ledgerInputs -- NOTE: calls 'error' if out of bounds in case UTxO.resolve (fromLedgerTxIn txIn) utxo of Nothing -> error $ "txIn not resolvable: " <> show txIn @@ -571,7 +571,7 @@ ensureDatums outs scriptData = -- | Alter a transaction's redeemers map given some mapping function. alterRedeemers :: - ( Ledger.PlutusPurpose Ledger.AsIndex LedgerEra -> + ( Ledger.PlutusPurpose Ledger.AsIx LedgerEra -> (Ledger.Data LedgerEra, Ledger.ExUnits) -> (Ledger.Data LedgerEra, Ledger.ExUnits) ) -> @@ -614,7 +614,7 @@ alterTxIns fn tx = rebuiltSpendingRedeemers = Map.fromList $ flip mapMaybe (zip [0 ..] newSortedInputs) $ \(i, (_, mRedeemer)) -> mRedeemer <&> \d -> - (Ledger.AlonzoSpending (AsIndex i), (toLedgerData d, Ledger.ExUnits 0 0)) + (Ledger.AlonzoSpending (AsIx i), (toLedgerData d, Ledger.ExUnits 0 0)) -- NOTE: This needs to be ordered, such that we can calculate the redeemer -- pointers correctly. @@ -630,7 +630,7 @@ alterTxIns fn tx = resolveRedeemers :: [TxIn] -> [(TxIn, Maybe HashableScriptData)] resolveRedeemers txInputs = zip txInputs [0 ..] <&> \(txIn, i) -> - case Map.lookup (Ledger.AlonzoSpending (AsIndex i)) redeemersMap of + case Map.lookup (Ledger.AlonzoSpending (AsIx i)) redeemersMap of Nothing -> (txIn, Nothing) Just (redeemerData, _exUnits) -> (txIn, Just $ fromLedgerData redeemerData) diff --git a/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs b/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs index 934c8e84453..906104f6f6e 100644 --- a/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs +++ b/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs @@ -186,7 +186,7 @@ spec = ErrTranslationError{} -> "Transaction context translation error" ) Right ledgerTx -> - let actualExecutionCost = getMinFeeTx pparams ledgerTx + let actualExecutionCost = getMinFeeTx pparams ledgerTx 0 fee = txFee' apiTx apiTx = fromLedgerTx ledgerTx in actualExecutionCost > Coin 0 && fee > actualExecutionCost diff --git a/hydra-node/test/Hydra/Chain/Direct/WalletSpec.hs b/hydra-node/test/Hydra/Chain/Direct/WalletSpec.hs index c9c2ecf8b02..c6fa4e8626e 100644 --- a/hydra-node/test/Hydra/Chain/Direct/WalletSpec.hs +++ b/hydra-node/test/Hydra/Chain/Direct/WalletSpec.hs @@ -259,7 +259,8 @@ hasLowFees pparams tx = actualFee = tx ^. bodyTxL . feeTxBodyL - minFee = getMinFeeTx pparams tx + minFee :: Coin + minFee = getMinFeeTx pparams tx 0 isBalanced :: Map TxIn TxOut -> Tx LedgerEra -> Tx LedgerEra -> Property isBalanced utxo originalTx balancedTx = diff --git a/hydra-plutus-extras/src/Hydra/Plutus/Orphans.hs b/hydra-plutus-extras/src/Hydra/Plutus/Orphans.hs index e6476a718b1..95a9faeaec0 100644 --- a/hydra-plutus-extras/src/Hydra/Plutus/Orphans.hs +++ b/hydra-plutus-extras/src/Hydra/Plutus/Orphans.hs @@ -12,7 +12,7 @@ import Data.ByteString qualified as BS import Data.ByteString.Base16 qualified as Base16 import PlutusLedgerApi.V2 (CurrencySymbol, POSIXTime (..), PubKeyHash (..), TokenName, TxId (..), TxOutRef (..), UpperBound, Value, upperBound) import PlutusTx.AssocMap qualified as AssocMap -import PlutusTx.Prelude (BuiltinByteString, fromBuiltin, toBuiltin) +import PlutusTx.Prelude (BuiltinByteString, Eq, fromBuiltin, toBuiltin) import Test.QuickCheck (choose, vectorOf) import Test.QuickCheck.Instances.ByteString () @@ -31,8 +31,8 @@ instance Arbitrary Value where arbitrary = genericArbitrary shrink = genericShrink -instance (Arbitrary k, Arbitrary v) => Arbitrary (AssocMap.Map k v) where - arbitrary = AssocMap.fromList <$> arbitrary +instance (PlutusTx.Prelude.Eq k, Arbitrary k, Arbitrary v) => Arbitrary (AssocMap.Map k v) where + arbitrary = AssocMap.safeFromList <$> arbitrary instance Arbitrary POSIXTime where arbitrary = POSIXTime <$> arbitrary diff --git a/hydra-plutus/hydra-plutus.cabal b/hydra-plutus/hydra-plutus.cabal index 3a11478cf5a..9241554dd6f 100644 --- a/hydra-plutus/hydra-plutus.cabal +++ b/hydra-plutus/hydra-plutus.cabal @@ -69,10 +69,10 @@ library , hydra-cardano-api , hydra-plutus-extras , hydra-prelude - , plutus-core >=1.21 && <1.22 - , plutus-ledger-api >=1.21 && <1.22 - , plutus-tx >=1.21 && <1.22 - , plutus-tx-plugin >=1.21 && <1.22 + , plutus-core >=1.21 + , plutus-ledger-api >=1.21 + , plutus-tx >=1.21 + , plutus-tx-plugin >=1.21 , QuickCheck , serialise , template-haskell diff --git a/plutus-cbor/bench/Main.hs b/plutus-cbor/bench/Main.hs index 105d735739b..ac0b14039ef 100644 --- a/plutus-cbor/bench/Main.hs +++ b/plutus-cbor/bench/Main.hs @@ -133,16 +133,16 @@ genValue = do assetName <- genTokenName pure $ Plutus.Value $ - Plutus.Map.fromList - [(policyId, Plutus.Map.fromList [(assetName, n)])] + Plutus.Map.safeFromList + [(policyId, Plutus.Map.safeFromList [(assetName, n)])] genAdaOnlyValue :: Gen Plutus.Value genAdaOnlyValue = do n <- genAssetQuantity pure $ Plutus.Value $ - Plutus.Map.fromList - [(Plutus.adaSymbol, Plutus.Map.fromList [(Plutus.adaToken, n)])] + Plutus.Map.safeFromList + [(Plutus.adaSymbol, Plutus.Map.safeFromList [(Plutus.adaToken, n)])] genAssetQuantity :: Gen Integer genAssetQuantity = choose (1, 4_294_967_296) -- NOTE: 2**32 diff --git a/plutus-cbor/exe/encoding-cost/Main.hs b/plutus-cbor/exe/encoding-cost/Main.hs index ea4beb7abf3..bb1dcb52ec7 100644 --- a/plutus-cbor/exe/encoding-cost/Main.hs +++ b/plutus-cbor/exe/encoding-cost/Main.hs @@ -119,16 +119,16 @@ genValue = do assetName <- genTokenName pure $ Plutus.Value $ - Plutus.Map.fromList - [(policyId, Plutus.Map.fromList [(assetName, n)])] + Plutus.Map.safeFromList + [(policyId, Plutus.Map.safeFromList [(assetName, n)])] genAdaOnlyValue :: Gen Plutus.Value genAdaOnlyValue = do n <- genAssetQuantity pure $ Plutus.Value $ - Plutus.Map.fromList - [(Plutus.adaSymbol, Plutus.Map.fromList [(Plutus.adaToken, n)])] + Plutus.Map.safeFromList + [(Plutus.adaSymbol, Plutus.Map.safeFromList [(Plutus.adaToken, n)])] genAssetQuantity :: Gen Integer genAssetQuantity = choose (1, 4_294_967_296) -- NOTE: 2**32 diff --git a/plutus-cbor/test/Plutus/Codec/CBOR/EncodingSpec.hs b/plutus-cbor/test/Plutus/Codec/CBOR/EncodingSpec.hs index 386f4794187..7257a7aa5dd 100644 --- a/plutus-cbor/test/Plutus/Codec/CBOR/EncodingSpec.hs +++ b/plutus-cbor/test/Plutus/Codec/CBOR/EncodingSpec.hs @@ -185,7 +185,7 @@ genSomeValue = encodeMap (\(SomeValue k _ _ encodeKey) -> encodeKey k) (\(SomeValue v _ _ encodeValue) -> encodeValue v) - . Plutus.Map.fromList + . Plutus.Map.unsafeFromList return $ SomeValue val shrinkMap encodeCborg encodeOurs genSomeMapIndef :: Int -> Gen SomeValue @@ -206,7 +206,7 @@ genSomeValue = encodeMapIndef (\(SomeValue k _ _ encodeKey) -> encodeKey k) (\(SomeValue v _ _ encodeValue) -> encodeValue v) - . Plutus.Map.fromList + . Plutus.Map.unsafeFromList return $ SomeValue val shrinkMap encodeCborg encodeOurs genSomeTag :: Gen SomeValue