From cfa06529cd4c1e5de9e731f20cbbe5ca6c63d73a Mon Sep 17 00:00:00 2001 From: taiko-bot <160625009+taiko-kitty@users.noreply.github.com> Date: Wed, 18 Dec 2024 06:11:08 -0800 Subject: [PATCH 01/29] chore(main): release bridge-ui 2.13.0 (#18430) --- .release-please-manifest.json | 2 +- packages/bridge-ui/CHANGELOG.md | 28 ++++++++++++++++++++++++++++ packages/bridge-ui/package.json | 2 +- 3 files changed, 30 insertions(+), 2 deletions(-) diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 462e52e6c57..8e80b86f84d 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -1,5 +1,5 @@ { - "packages/bridge-ui": "2.12.0", + "packages/bridge-ui": "2.13.0", "packages/docs-site": "1.20.3", "packages/eventindexer": "0.13.0", "packages/fork-diff": "0.6.1", diff --git a/packages/bridge-ui/CHANGELOG.md b/packages/bridge-ui/CHANGELOG.md index fb544b962ea..95b3a0b3280 100644 --- a/packages/bridge-ui/CHANGELOG.md +++ b/packages/bridge-ui/CHANGELOG.md @@ -1,5 +1,33 @@ # Changelog +## [2.13.0](https://github.com/taikoxyz/taiko-mono/compare/bridge-ui-v2.12.0...bridge-ui-v2.13.0) (2024-12-17) + + +### Features + +* **bridge-ui:** add curve ([#18549](https://github.com/taikoxyz/taiko-mono/issues/18549)) ([fd6feef](https://github.com/taikoxyz/taiko-mono/commit/fd6feef545c2432eea8e71c68dc3f3964fe65c17)) +* **bridge-ui:** add padding when claiming to smart contract ([#18141](https://github.com/taikoxyz/taiko-mono/issues/18141)) ([ce5d485](https://github.com/taikoxyz/taiko-mono/commit/ce5d4859a77631ec406ccb5d571efcd91e5fd2f8)) +* **bridge-ui:** more detailed transactions view ([#17899](https://github.com/taikoxyz/taiko-mono/issues/17899)) ([6fe7c44](https://github.com/taikoxyz/taiko-mono/commit/6fe7c447b7c9c13b5868c65c69a9ddfeb968901a)) +* **bridge-ui:** remove fee padding ([#18546](https://github.com/taikoxyz/taiko-mono/issues/18546)) ([3966bb1](https://github.com/taikoxyz/taiko-mono/commit/3966bb1cea358923284de74b81e3ce512b8291dd)) + + +### Bug Fixes + +* **bridge-ui:** balance visually not updating correctly when switching chains ([#17832](https://github.com/taikoxyz/taiko-mono/issues/17832)) ([f495e40](https://github.com/taikoxyz/taiko-mono/commit/f495e406633fc9349e8d3a125c463c0be1e15b66)) +* **bridge-ui:** increase pagesize ([#17886](https://github.com/taikoxyz/taiko-mono/issues/17886)) ([9e38a33](https://github.com/taikoxyz/taiko-mono/commit/9e38a33cd361dc6bd2e2e77a8017151eb08400f3)) + + +### Workflow + +* **protocol:** trigger patch release (1.10.1) ([#18358](https://github.com/taikoxyz/taiko-mono/issues/18358)) ([f4f4796](https://github.com/taikoxyz/taiko-mono/commit/f4f4796488059b02c79d6fb15170df58dd31dc4e)) + + +### Build + +* **deps-dev:** bump @sveltejs/kit from 2.5.7 to 2.5.21 ([#17901](https://github.com/taikoxyz/taiko-mono/issues/17901)) ([7a32ac4](https://github.com/taikoxyz/taiko-mono/commit/7a32ac40a654521c82cb3ff5b6f5af87d0a915a4)) +* **deps:** bump github.com/stretchr/testify from 1.9.0 to 1.10.0 ([#18539](https://github.com/taikoxyz/taiko-mono/issues/18539)) ([79f3fab](https://github.com/taikoxyz/taiko-mono/commit/79f3fab5f1d1ec1bb4ee18afb9268b622e894780)) +* **deps:** bump golang.org/x/sync from 0.9.0 to 0.10.0 ([#18560](https://github.com/taikoxyz/taiko-mono/issues/18560)) ([3d51970](https://github.com/taikoxyz/taiko-mono/commit/3d51970aa0953bbfecaeebf76ea7e664c875c0e4)) + ## [2.12.0](https://github.com/taikoxyz/taiko-mono/compare/bridge-ui-v2.11.0...bridge-ui-v2.12.0) (2024-07-18) diff --git a/packages/bridge-ui/package.json b/packages/bridge-ui/package.json index c44dfca11bd..601c5923d39 100644 --- a/packages/bridge-ui/package.json +++ b/packages/bridge-ui/package.json @@ -1,6 +1,6 @@ { "name": "bridge-ui", - "version": "2.12.0", + "version": "2.13.0", "private": true, "scripts": { "dev": "vite dev", From cbe43c355096c537e8740348ce48b8e785b653d5 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Thu, 19 Dec 2024 01:43:11 +0000 Subject: [PATCH 02/29] build(deps): bump codecov/codecov-action from 4 to 5 (#18543) Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- .github/workflows/eventindexer.yml | 2 +- .github/workflows/guardian-prover-health-check.yml | 2 +- .github/workflows/relayer.yml | 2 +- .github/workflows/taiko-client--test.yml | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/eventindexer.yml b/.github/workflows/eventindexer.yml index 778faa42143..6158d07fdb2 100644 --- a/.github/workflows/eventindexer.yml +++ b/.github/workflows/eventindexer.yml @@ -55,7 +55,7 @@ jobs: run: go test `go list ./... | grep -v ./contracts | grep -v ./mock | grep -v ./cmd` -coverprofile=coverage.txt -covermode=atomic - name: eventindexer - Upload coverage to Codecov - uses: codecov/codecov-action@v4 + uses: codecov/codecov-action@v5 with: files: ./packages/eventindexer/coverage.txt flags: eventindexer diff --git a/.github/workflows/guardian-prover-health-check.yml b/.github/workflows/guardian-prover-health-check.yml index ff6b6f45ba9..7bd6a886357 100644 --- a/.github/workflows/guardian-prover-health-check.yml +++ b/.github/workflows/guardian-prover-health-check.yml @@ -51,7 +51,7 @@ jobs: run: go test `go list ./... | grep -v ./contracts | grep -v ./mock | grep -v ./cmd` -coverprofile=coverage.txt -covermode=atomic - name: guardian-prover-health-check - Upload coverage to Codecov - uses: codecov/codecov-action@v4 + uses: codecov/codecov-action@v5 with: files: ./packages/guardian-prover-health-check/coverage.txt flags: guardian-prover-health-check diff --git a/.github/workflows/relayer.yml b/.github/workflows/relayer.yml index 81238a9a8c1..9c0fe4d683a 100644 --- a/.github/workflows/relayer.yml +++ b/.github/workflows/relayer.yml @@ -55,7 +55,7 @@ jobs: run: go test `go list ./... | grep -v ./contracts | grep -v ./mock | grep -v ./cmd` -coverprofile=coverage.txt -covermode=atomic - name: relayer - Upload coverage to Codecov - uses: codecov/codecov-action@v4 + uses: codecov/codecov-action@v5 with: files: ./packages/relayer/coverage.txt flags: relayer diff --git a/.github/workflows/taiko-client--test.yml b/.github/workflows/taiko-client--test.yml index 0df43a2b887..69b5c0046cf 100644 --- a/.github/workflows/taiko-client--test.yml +++ b/.github/workflows/taiko-client--test.yml @@ -68,6 +68,6 @@ jobs: run: make test - name: Codecov.io - uses: codecov/codecov-action@v4 + uses: codecov/codecov-action@v5 with: files: packages/taiko-client/coverage.out From 431435e6e74799caea94f53438238c63831cf07c Mon Sep 17 00:00:00 2001 From: Gavin Yu Date: Thu, 19 Dec 2024 12:36:30 +0800 Subject: [PATCH 03/29] feat(protocol): adjust the zk ratio(risc0 & sp1) (#18613) --- .../contracts/layer1/mainnet/rollup/MainnetTierRouter.sol | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/protocol/contracts/layer1/mainnet/rollup/MainnetTierRouter.sol b/packages/protocol/contracts/layer1/mainnet/rollup/MainnetTierRouter.sol index 0499226f1ce..331a3bee38f 100644 --- a/packages/protocol/contracts/layer1/mainnet/rollup/MainnetTierRouter.sol +++ b/packages/protocol/contracts/layer1/mainnet/rollup/MainnetTierRouter.sol @@ -35,8 +35,8 @@ contract MainnetTierRouter is ITierRouter, TierProviderBase { /// @inheritdoc ITierProvider function getMinTier(address _proposer, uint256 _rand) public view override returns (uint16) { if (_proposer == DAO_FALLBACK_PROPOSER) { - if (_rand % 200 == 0) return LibTiers.TIER_ZKVM_RISC0; - else if (_rand % 40 == 1) return LibTiers.TIER_ZKVM_SP1; + if (_rand % 1000 == 0) return LibTiers.TIER_ZKVM_RISC0; + else if (_rand % 1000 < 99) return LibTiers.TIER_ZKVM_SP1; else return LibTiers.TIER_SGX; } return LibTiers.TIER_SGX; From b2ca63cd4ed7eca385c317d9a6ade794bf156c79 Mon Sep 17 00:00:00 2001 From: David Date: Fri, 20 Dec 2024 09:29:40 +0800 Subject: [PATCH 04/29] feat(protocol): update `RollupAddressCache` with new `MainnetTierRouter` address (#18619) --- .../contracts/layer1/mainnet/addrcache/RollupAddressCache.sol | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/protocol/contracts/layer1/mainnet/addrcache/RollupAddressCache.sol b/packages/protocol/contracts/layer1/mainnet/addrcache/RollupAddressCache.sol index 3f92804e7e3..003cc333e52 100644 --- a/packages/protocol/contracts/layer1/mainnet/addrcache/RollupAddressCache.sol +++ b/packages/protocol/contracts/layer1/mainnet/addrcache/RollupAddressCache.sol @@ -37,7 +37,7 @@ contract RollupAddressCache is AddressCache { return (true, 0x06a9Ab27c7e2255df1815E6CC0168d7755Feb19a); } if (_name == LibStrings.B_TIER_ROUTER) { - return (true, 0x394E30d83d020469a1F8b16E89D7fD5FdB1935b0); + return (true, 0x8a4c692F12d3a9750E744A4CE24a1d351bE52E66); } if (_name == LibStrings.B_TIER_SGX) { return (true, 0xb0f3186FC1963f774f52ff455DC86aEdD0b31F81); From 06128e8f64b7bf2997b70959c78ab256404ebab3 Mon Sep 17 00:00:00 2001 From: Daniel Wang <99078276+dantaik@users.noreply.github.com> Date: Fri, 20 Dec 2024 09:53:12 +0800 Subject: [PATCH 05/29] chore(protocol): delete gas debug event (#18620) --- .../contracts/layer1/based/TaikoL1.sol | 21 ------------------- 1 file changed, 21 deletions(-) diff --git a/packages/protocol/contracts/layer1/based/TaikoL1.sol b/packages/protocol/contracts/layer1/based/TaikoL1.sol index 1ce30755442..0a1175e5fce 100644 --- a/packages/protocol/contracts/layer1/based/TaikoL1.sol +++ b/packages/protocol/contracts/layer1/based/TaikoL1.sol @@ -25,13 +25,6 @@ contract TaikoL1 is EssentialContract, ITaikoL1, TaikoEvents { uint256[50] private __gap; - /// @dev Emitted to assist with future gas optimizations. - /// @param isProposeBlock True if measuring gas for proposing a block, false if measuring gas - /// for proving a block. - /// @param gasUsed The average gas used per block, including verifications. - /// @param batchSize The number of blocks proposed or proved. - event DebugGasPerBlock(bool isProposeBlock, uint256 gasUsed, uint256 batchSize); - error L1_FORK_HEIGHT_ERROR(); modifier whenProvingNotPaused() { @@ -44,16 +37,6 @@ contract TaikoL1 is EssentialContract, ITaikoL1, TaikoEvents { emit StateVariablesUpdated(state.slotB); } - modifier measureGasUsed(bool _isProposeBlock, uint256 _batchSize) { - uint256 gas = gasleft(); - _; - unchecked { - if (_batchSize > 0) { - emit DebugGasPerBlock(_isProposeBlock, gas - gasleft() / _batchSize, _batchSize); - } - } - } - /// @notice Initializes the contract. /// @param _owner The owner of this contract. msg.sender will be used if this value is zero. /// @param _rollupAddressManager The address of the {AddressManager} contract. @@ -90,7 +73,6 @@ contract TaikoL1 is EssentialContract, ITaikoL1, TaikoEvents { bytes calldata _txList ) external - measureGasUsed(true, 1) whenNotPaused nonReentrant emitEventForClient @@ -106,7 +88,6 @@ contract TaikoL1 is EssentialContract, ITaikoL1, TaikoEvents { bytes[] calldata _txListArr ) external - measureGasUsed(true, _paramsArr.length) whenNotPaused nonReentrant emitEventForClient @@ -122,7 +103,6 @@ contract TaikoL1 is EssentialContract, ITaikoL1, TaikoEvents { bytes calldata _input ) external - measureGasUsed(false, 1) whenNotPaused whenProvingNotPaused nonReentrant @@ -138,7 +118,6 @@ contract TaikoL1 is EssentialContract, ITaikoL1, TaikoEvents { bytes calldata _batchProof ) external - measureGasUsed(false, _blockIds.length) whenNotPaused whenProvingNotPaused nonReentrant From becffb7cc81c6f17436985a81750a5eef7f980e1 Mon Sep 17 00:00:00 2001 From: Roger <50648015+RogerLamTd@users.noreply.github.com> Date: Fri, 20 Dec 2024 13:25:41 +0800 Subject: [PATCH 06/29] chore(docs-site): update proof tier graphic (#18617) --- .../proof-tier-config-mn.webp | Bin 281210 -> 279749 bytes .../network-reference/mainnet-addresses.md | 2 +- .../network-configuration.mdx | 2 +- 3 files changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/docs-site/src/assets/content/docs/network-reference/proof-tier-config-mn.webp b/packages/docs-site/src/assets/content/docs/network-reference/proof-tier-config-mn.webp index 42b50901739ff6845c8757310e67e00136334c48..bedfb3c43b425dc7c5820e1e61c87e590ca2fe16 100644 GIT binary patch delta 173413 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 G2mB9ZIWOh_ diff --git a/packages/docs-site/src/content/docs/network-reference/mainnet-addresses.md b/packages/docs-site/src/content/docs/network-reference/mainnet-addresses.md index 4e3bab65088..e98c0898edd 100644 --- a/packages/docs-site/src/content/docs/network-reference/mainnet-addresses.md +++ b/packages/docs-site/src/content/docs/network-reference/mainnet-addresses.md @@ -23,7 +23,7 @@ description: Network reference page describing various important addresses on Ta | ------------------------------- | -------------------------------------------- | -------------------------- | | TaikoL1 | `0x06a9Ab27c7e2255df1815E6CC0168d7755Feb19a` | based.taiko.eth | | RollupAddressManager | `0x579f40D0BE111b823962043702cabe6Aaa290780` | ram.based.taiko.eth | -| TierRouter | `0x394E30d83d020469a1F8b16E89D7fD5FdB1935b0` | N/A | +| TierRouter | `0x8a4c692F12d3a9750E744A4CE24a1d351bE52E66` | N/A | | GuardianProver | `0xE3D777143Ea25A6E031d1e921F396750885f43aC` | guardians.based.taiko.eth | | GuardianProverMinority | `0x579A8d63a2Db646284CBFE31FE5082c9989E985c` | guardians1.based.taiko.eth | | AssignmentHook | `0x537a2f0D3a5879b41BCb5A2afE2EA5c4961796F6` | N/A | diff --git a/packages/docs-site/src/content/docs/network-reference/network-configuration.mdx b/packages/docs-site/src/content/docs/network-reference/network-configuration.mdx index 7ea3687d077..e615b575524 100644 --- a/packages/docs-site/src/content/docs/network-reference/network-configuration.mdx +++ b/packages/docs-site/src/content/docs/network-reference/network-configuration.mdx @@ -26,7 +26,7 @@ You can find all the corresponding values below in the [deployed TierProviderBas ## Tier configuration (Mainnet) -You can view the full `MainnetTierRouter` tier configuration [here](https://etherscan.io/address/0x394E30d83d020469a1F8b16E89D7fD5FdB1935b0#code): +You can view the full `MainnetTierRouter` tier configuration [here](https://etherscan.io/address/0x8a4c692F12d3a9750E744A4CE24a1d351bE52E66#code): ![mainnet proof tiers](~/assets/content/docs/network-reference/proof-tier-config-mn.webp) From 4a2931e8344ac252dac92207d1f0b69b967e9fbe Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 22 Dec 2024 09:48:05 +0800 Subject: [PATCH 07/29] build(deps): bump github.com/labstack/echo/v4 from 4.13.2 to 4.13.3 (#18623) Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- go.mod | 4 ++-- go.sum | 8 ++++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/go.mod b/go.mod index 48a32be8479..7367450f164 100644 --- a/go.mod +++ b/go.mod @@ -21,7 +21,7 @@ require ( github.com/gorilla/websocket v1.5.3 github.com/joho/godotenv v1.5.1 github.com/labstack/echo-contrib v0.17.1 - github.com/labstack/echo/v4 v4.13.2 + github.com/labstack/echo/v4 v4.13.3 github.com/labstack/gommon v0.4.2 github.com/modern-go/reflect2 v1.0.2 github.com/morkid/paginate v1.1.8 @@ -206,7 +206,7 @@ require ( go.uber.org/multierr v1.11.0 // indirect golang.org/x/crypto v0.31.0 // indirect golang.org/x/mod v0.20.0 // indirect - golang.org/x/net v0.32.0 // indirect + golang.org/x/net v0.33.0 // indirect golang.org/x/oauth2 v0.21.0 // indirect golang.org/x/sys v0.28.0 // indirect golang.org/x/term v0.27.0 // indirect diff --git a/go.sum b/go.sum index 07551b265e8..3daa2235653 100644 --- a/go.sum +++ b/go.sum @@ -379,8 +379,8 @@ github.com/labstack/echo-contrib v0.17.1 h1:7I/he7ylVKsDUieaGRZ9XxxTYOjfQwVzHzUY github.com/labstack/echo-contrib v0.17.1/go.mod h1:SnsCZtwHBAZm5uBSAtQtXQHI3wqEA73hvTn0bYMKnZA= github.com/labstack/echo/v4 v4.0.0/go.mod h1:tZv7nai5buKSg5h/8E6zz4LsD/Dqh9/91Mvs7Z5Zyno= github.com/labstack/echo/v4 v4.1.15/go.mod h1:GWO5IBVzI371K8XJe50CSvHjQCafK6cw8R/moLhEU6o= -github.com/labstack/echo/v4 v4.13.2 h1:9aAt4hstpH54qIcqkuUXRLTf+v7yOTfMPWzDtuqLmtA= -github.com/labstack/echo/v4 v4.13.2/go.mod h1:uc9gDtHB8UWt3FfbYx0HyxcCuvR4YuPYOxF/1QjoV/c= +github.com/labstack/echo/v4 v4.13.3 h1:pwhpCPrTl5qry5HRdM5FwdXnhXSLSY+WE+YQSeCaafY= +github.com/labstack/echo/v4 v4.13.3/go.mod h1:o90YNEeQWjDozo584l7AwhJMHN0bOC4tAfg+Xox9q5g= github.com/labstack/gommon v0.2.8/go.mod h1:/tj9csK2iPSBvn+3NLM9e52usepMtrd5ilFYA+wQNJ4= github.com/labstack/gommon v0.3.0/go.mod h1:MULnywXg0yavhxWKc+lOruYdAhDwPK9wf0OL7NoOu+k= github.com/labstack/gommon v0.4.2 h1:F8qTUNXgG1+6WQmqoUWnz8WiEU60mXVVw0P4ht1WRA0= @@ -716,8 +716,8 @@ golang.org/x/net v0.0.0-20220906165146-f3363e06e74c/go.mod h1:YDH+HFinaLZZlnHAfS golang.org/x/net v0.2.0/go.mod h1:KqCZLdyyvdV855qA2rE3GC2aiw5xGR5TEjj8smXukLY= golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= golang.org/x/net v0.8.0/go.mod h1:QVkue5JL9kW//ek3r6jTKnTFis1tRmNAW2P1shuFdJc= -golang.org/x/net v0.32.0 h1:ZqPmj8Kzc+Y6e0+skZsuACbx+wzMgo5MQsJh9Qd6aYI= -golang.org/x/net v0.32.0/go.mod h1:CwU0IoeOlnQQWJ6ioyFrfRuomB8GKF6KbYXZVyeXNfs= +golang.org/x/net v0.33.0 h1:74SYHlV8BIgHIFC/LrYkOGIwL19eTYXQ5wc6TBuO36I= +golang.org/x/net v0.33.0/go.mod h1:HXLR5J+9DxmrqMwG9qjGCxZ+zKXxBru04zlTvWlWuN4= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.21.0 h1:tsimM75w1tF/uws5rbeHzIWxEqElMehnc+iW793zsZs= golang.org/x/oauth2 v0.21.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI= From fe33db19b236284c98d9cfff65709ccdbc597812 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 22 Dec 2024 01:54:58 +0000 Subject: [PATCH 08/29] build(deps): bump github.com/pressly/goose/v3 from 3.23.0 to 3.24.0 (#18624) Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- go.mod | 2 +- go.sum | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/go.mod b/go.mod index 7367450f164..3acc6c5e52a 100644 --- a/go.mod +++ b/go.mod @@ -28,7 +28,7 @@ require ( github.com/patrickmn/go-cache v2.1.0+incompatible github.com/phayes/freeport v0.0.0-20220201140144-74d24b5ae9f5 github.com/pkg/errors v0.9.1 - github.com/pressly/goose/v3 v3.23.0 + github.com/pressly/goose/v3 v3.24.0 github.com/prometheus/client_golang v1.20.5 github.com/prysmaticlabs/prysm/v5 v5.1.2 github.com/rabbitmq/amqp091-go v1.10.0 diff --git a/go.sum b/go.sum index 3daa2235653..8adf07121f6 100644 --- a/go.sum +++ b/go.sum @@ -424,8 +424,8 @@ github.com/mfridman/interpolate v0.0.2/go.mod h1:p+7uk6oE07mpE/Ik1b8EckO0O4ZXiGA github.com/microcosm-cc/bluemonday v1.0.4/go.mod h1:8iwZnFn2CDDNZ0r6UXhF4xawGvzaqzCRa1n3/lO3W2w= github.com/microcosm-cc/bluemonday v1.0.26 h1:xbqSvqzQMeEHCqMi64VAs4d8uy6Mequs3rQ0k/Khz58= github.com/microcosm-cc/bluemonday v1.0.26/go.mod h1:JyzOCs9gkyQyjs+6h10UEVSe02CGwkhd72Xdqh78TWs= -github.com/microsoft/go-mssqldb v1.7.2 h1:CHkFJiObW7ItKTJfHo1QX7QBBD1iV+mn1eOyRP3b/PA= -github.com/microsoft/go-mssqldb v1.7.2/go.mod h1:kOvZKUdrhhFQmxLZqbwUV0rHkNkZpthMITIb2Ko1IoA= +github.com/microsoft/go-mssqldb v1.8.0 h1:7cyZ/AT7ycDsEoWPIXibd+aVKFtteUNhDGf3aobP+tw= +github.com/microsoft/go-mssqldb v1.8.0/go.mod h1:6znkekS3T2vp0waiMhen4GPU1BiAsrP+iXHcE7a7rFo= github.com/minio/highwayhash v1.0.2 h1:Aak5U0nElisjDCfPSG79Tgzkn2gl66NxOMspRrKnA/g= github.com/minio/highwayhash v1.0.2/go.mod h1:BQskDq+xkJ12lmlUUi7U0M5Swg3EWR+dLTk+kldvVxY= github.com/minio/sha256-simd v1.0.1 h1:6kaan5IFmwTNynnKKpDHe6FWHohJOHhCPchzK49dzMM= @@ -510,8 +510,8 @@ github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 h1:Jamvg5psRI github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/power-devops/perfstat v0.0.0-20210106213030-5aafc221ea8c h1:ncq/mPwQF4JjgDlrVEn3C11VoGHZN7m8qihwgMEtzYw= github.com/power-devops/perfstat v0.0.0-20210106213030-5aafc221ea8c/go.mod h1:OmDBASR4679mdNQnz2pUhc2G8CO2JrUAVFDRBDP/hJE= -github.com/pressly/goose/v3 v3.23.0 h1:57hqKos8izGek4v6D5+OXBa+Y4Rq8MU//+MmnevdpVA= -github.com/pressly/goose/v3 v3.23.0/go.mod h1:rpx+D9GX/+stXmzKa+uh1DkjPnNVMdiOCV9iLdle4N8= +github.com/pressly/goose/v3 v3.24.0 h1:sFbNms7Bd++2VMq6HSgDHDLWa7kHz1qXzPb3ZIU72VU= +github.com/pressly/goose/v3 v3.24.0/go.mod h1:rEWreU9uVtt0DHCyLzF9gRcWiiTF/V+528DV+4DORug= github.com/prometheus/client_golang v1.20.5 h1:cxppBPuYhUnsO6yo/aoRol4L7q7UFfdm+bR9r+8l63Y= github.com/prometheus/client_golang v1.20.5/go.mod h1:PIEt8X02hGcP8JWbeHyeZ53Y/jReSnHgO035n//V5WE= github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= From 45603f720436927340ef216afe2082a20efa54f0 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 22 Dec 2024 02:52:52 +0000 Subject: [PATCH 09/29] build(deps): bump github.com/prysmaticlabs/prysm/v5 from 5.1.2 to 5.2.0 (#18625) Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- go.mod | 2 +- go.sum | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/go.mod b/go.mod index 3acc6c5e52a..a0a0da99120 100644 --- a/go.mod +++ b/go.mod @@ -30,7 +30,7 @@ require ( github.com/pkg/errors v0.9.1 github.com/pressly/goose/v3 v3.24.0 github.com/prometheus/client_golang v1.20.5 - github.com/prysmaticlabs/prysm/v5 v5.1.2 + github.com/prysmaticlabs/prysm/v5 v5.2.0 github.com/rabbitmq/amqp091-go v1.10.0 github.com/shopspring/decimal v1.4.0 github.com/stretchr/testify v1.10.0 diff --git a/go.sum b/go.sum index 8adf07121f6..0ef42eb764b 100644 --- a/go.sum +++ b/go.sum @@ -529,8 +529,8 @@ github.com/prysmaticlabs/gohashtree v0.0.4-beta.0.20240624100937-73632381301b h1 github.com/prysmaticlabs/gohashtree v0.0.4-beta.0.20240624100937-73632381301b/go.mod h1:HRuvtXLZ4WkaB1MItToVH2e8ZwKwZPY5/Rcby+CvvLY= github.com/prysmaticlabs/protoc-gen-go-cast v0.0.0-20230228205207-28762a7b9294 h1:q9wE0ZZRdTUAAeyFP/w0SwBEnCqlVy2+on6X2/e+eAU= github.com/prysmaticlabs/protoc-gen-go-cast v0.0.0-20230228205207-28762a7b9294/go.mod h1:ZVEbRdnMkGhp/pu35zq4SXxtvUwWK0J1MATtekZpH2Y= -github.com/prysmaticlabs/prysm/v5 v5.1.2 h1:ib9D7Drh7QPoetJPnYXAHaArmjIreXPZ0FboW9EMzT8= -github.com/prysmaticlabs/prysm/v5 v5.1.2/go.mod h1:ykj3Bl9dHv35cC7fRw6Cd1aCd9l+eNvInHY6gsPbEig= +github.com/prysmaticlabs/prysm/v5 v5.2.0 h1:JqKKK5aqehZN9GiSOSSw4M57NpbvG0nIxqFK5KpPnRw= +github.com/prysmaticlabs/prysm/v5 v5.2.0/go.mod h1:cQc+NIMKaHjPvY566HsYcuni763nzuUWnDsDbk45bbs= github.com/rabbitmq/amqp091-go v1.10.0 h1:STpn5XsHlHGcecLmMFCtg7mqq0RnD+zFr4uzukfVhBw= github.com/rabbitmq/amqp091-go v1.10.0/go.mod h1:Hy4jKW5kQART1u+JkDTF9YYOQUHXqMuhrgxOEeS7G4o= github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec h1:W09IVJc94icq4NjY3clb7Lk8O1qJ8BdBEF8z0ibU0rE= From c3865896523712afa108be810e75b511e7ecc0c4 Mon Sep 17 00:00:00 2001 From: David Date: Mon, 23 Dec 2024 09:24:02 +0800 Subject: [PATCH 10/29] feat(taiko-client): improve `ProofBuffer` (#18627) --- packages/taiko-client/cmd/flags/prover.go | 4 +- packages/taiko-client/prover/config.go | 8 +- packages/taiko-client/prover/init.go | 1 + .../prover/proof_submitter/interface.go | 1 + .../prover/proof_submitter/proof_buffer.go | 44 +++++++--- .../prover/proof_submitter/proof_submitter.go | 84 ++++++++++++------- .../proof_submitter/proof_submitter_test.go | 3 + packages/taiko-client/prover/prover.go | 25 ++---- 8 files changed, 103 insertions(+), 67 deletions(-) diff --git a/packages/taiko-client/cmd/flags/prover.go b/packages/taiko-client/cmd/flags/prover.go index d9c13f1ce1d..2de5bbc1422 100644 --- a/packages/taiko-client/cmd/flags/prover.go +++ b/packages/taiko-client/cmd/flags/prover.go @@ -212,7 +212,7 @@ var ( Category: proverCategory, EnvVars: []string{"PROVER_ZKVM_BATCH_SIZE"}, } - ForceProveInterval = &cli.DurationFlag{ + ForceBatchProvingInterval = &cli.DurationFlag{ Name: "prover.forceBatchProvingInterval", Usage: "Time interval to prove blocks even the number of pending proof do not exceed prover.batchSize, " + "this flag only works post Ontake fork", @@ -254,5 +254,5 @@ var ProverFlags = MergeFlags(CommonFlags, []cli.Flag{ RaikoZKVMHostEndpoint, SGXBatchSize, ZKVMBatchSize, - ForceProveInterval, + ForceBatchProvingInterval, }, TxmgrFlags) diff --git a/packages/taiko-client/prover/config.go b/packages/taiko-client/prover/config.go index 552ecfac231..cab66a38db6 100644 --- a/packages/taiko-client/prover/config.go +++ b/packages/taiko-client/prover/config.go @@ -62,7 +62,7 @@ type Config struct { PrivateTxmgrConfigs *txmgr.CLIConfig SGXProofBufferSize uint64 ZKVMProofBufferSize uint64 - ForceProveInterval time.Duration + ForceBatchProvingInterval time.Duration } // NewConfigFromCliContext creates a new config instance from command line flags. @@ -186,8 +186,8 @@ func NewConfigFromCliContext(c *cli.Context) (*Config, error) { l1ProverPrivKey, c, ), - SGXProofBufferSize: c.Uint64(flags.SGXBatchSize.Name), - ZKVMProofBufferSize: c.Uint64(flags.ZKVMBatchSize.Name), - ForceProveInterval: c.Duration(flags.ForceProveInterval.Name), + SGXProofBufferSize: c.Uint64(flags.SGXBatchSize.Name), + ZKVMProofBufferSize: c.Uint64(flags.ZKVMBatchSize.Name), + ForceBatchProvingInterval: c.Duration(flags.ForceBatchProvingInterval.Name), }, nil } diff --git a/packages/taiko-client/prover/init.go b/packages/taiko-client/prover/init.go index dc2e4cb40eb..61faf0f66fc 100644 --- a/packages/taiko-client/prover/init.go +++ b/packages/taiko-client/prover/init.go @@ -159,6 +159,7 @@ func (p *Prover) initProofSubmitters( p.IsGuardianProver(), p.cfg.GuardianProofSubmissionDelay, bufferSize, + p.cfg.ForceBatchProvingInterval, ); err != nil { return err } diff --git a/packages/taiko-client/prover/proof_submitter/interface.go b/packages/taiko-client/prover/proof_submitter/interface.go index 26971fc8587..b60ec9c3919 100644 --- a/packages/taiko-client/prover/proof_submitter/interface.go +++ b/packages/taiko-client/prover/proof_submitter/interface.go @@ -19,6 +19,7 @@ type Submitter interface { Producer() proofProducer.ProofProducer Tier() uint16 BufferSize() uint64 + AggregationEnabled() bool } // Contester is the interface for contesting proofs of the L2 blocks. diff --git a/packages/taiko-client/prover/proof_submitter/proof_buffer.go b/packages/taiko-client/prover/proof_submitter/proof_buffer.go index b21e992aa37..8f2d6d0cb72 100644 --- a/packages/taiko-client/prover/proof_submitter/proof_buffer.go +++ b/packages/taiko-client/prover/proof_submitter/proof_buffer.go @@ -3,6 +3,7 @@ package submitter import ( "errors" "sync" + "time" producer "github.com/taikoxyz/taiko-mono/packages/taiko-client/prover/proof_producer" ) @@ -14,16 +15,19 @@ var ( // ProofBuffer caches all single proof with a fixed size. type ProofBuffer struct { - MaxLength uint64 - buffer []*producer.ProofWithHeader - mutex sync.RWMutex + MaxLength uint64 + buffer []*producer.ProofWithHeader + lastUpdatedAt time.Time + isAggregating bool + mutex sync.RWMutex } // NewProofBuffer creates a new ProofBuffer instance. func NewProofBuffer(maxLength uint64) *ProofBuffer { return &ProofBuffer{ - buffer: make([]*producer.ProofWithHeader, 0, maxLength), - MaxLength: maxLength, + buffer: make([]*producer.ProofWithHeader, 0, maxLength), + lastUpdatedAt: time.Now(), + MaxLength: maxLength, } } @@ -37,6 +41,7 @@ func (pb *ProofBuffer) Write(item *producer.ProofWithHeader) (int, error) { } pb.buffer = append(pb.buffer, item) + pb.lastUpdatedAt = time.Now() return len(pb.buffer), nil } @@ -65,11 +70,14 @@ func (pb *ProofBuffer) Len() int { return len(pb.buffer) } -// Clear clears all buffer. -func (pb *ProofBuffer) Clear() { - pb.mutex.Lock() - defer pb.mutex.Unlock() - pb.buffer = pb.buffer[:0] +// LastUpdatedAt returns the last updated time of the buffer. +func (pb *ProofBuffer) LastUpdatedAt() time.Time { + return pb.lastUpdatedAt +} + +// LastUpdatedAt returns the last updated time of the buffer. +func (pb *ProofBuffer) UpdateLastUpdatedAt() { + pb.lastUpdatedAt = time.Now() } // ClearItems clears items that has given block ids in the buffer. @@ -94,5 +102,21 @@ func (pb *ProofBuffer) ClearItems(blockIDs ...uint64) int { } pb.buffer = newBuffer + pb.isAggregating = false return clearedCount } + +// MarkAggregating marks the proofs in this buffer are aggregating. +func (pb *ProofBuffer) MarkAggregating() { + pb.isAggregating = true +} + +// IsAggregating returns if the proofs in this buffer are aggregating. +func (pb *ProofBuffer) IsAggregating() bool { + return pb.isAggregating +} + +// Enabled returns if the buffer is enabled. +func (pb *ProofBuffer) Enabled() bool { + return pb.MaxLength > 1 +} diff --git a/packages/taiko-client/prover/proof_submitter/proof_submitter.go b/packages/taiko-client/prover/proof_submitter/proof_submitter.go index ba1cb8bad0d..60648aeda3f 100644 --- a/packages/taiko-client/prover/proof_submitter/proof_submitter.go +++ b/packages/taiko-client/prover/proof_submitter/proof_submitter.go @@ -53,7 +53,8 @@ type ProofSubmitter struct { isGuardian bool submissionDelay time.Duration // Batch proof related - proofBuffer *ProofBuffer + proofBuffer *ProofBuffer + forceBatchProvingInterval time.Duration } // NewProofSubmitter creates a new ProofSubmitter instance. @@ -74,6 +75,7 @@ func NewProofSubmitter( isGuardian bool, submissionDelay time.Duration, proofBufferSize uint64, + forceBatchProvingInterval time.Duration, ) (*ProofSubmitter, error) { anchorValidator, err := validator.New(taikoL2Address, rpcClient.L2.ChainID, rpcClient) if err != nil { @@ -81,22 +83,23 @@ func NewProofSubmitter( } return &ProofSubmitter{ - rpc: rpcClient, - proofProducer: proofProducer, - resultCh: resultCh, - batchResultCh: batchResultCh, - aggregationNotify: aggregationNotify, - anchorValidator: anchorValidator, - txBuilder: builder, - sender: transaction.NewSender(rpcClient, txmgr, privateTxmgr, proverSetAddress, gasLimit), - proverAddress: txmgr.From(), - proverSetAddress: proverSetAddress, - taikoL2Address: taikoL2Address, - graffiti: rpc.StringToBytes32(graffiti), - tiers: tiers, - isGuardian: isGuardian, - submissionDelay: submissionDelay, - proofBuffer: NewProofBuffer(proofBufferSize), + rpc: rpcClient, + proofProducer: proofProducer, + resultCh: resultCh, + batchResultCh: batchResultCh, + aggregationNotify: aggregationNotify, + anchorValidator: anchorValidator, + txBuilder: builder, + sender: transaction.NewSender(rpcClient, txmgr, privateTxmgr, proverSetAddress, gasLimit), + proverAddress: txmgr.From(), + proverSetAddress: proverSetAddress, + taikoL2Address: taikoL2Address, + graffiti: rpc.StringToBytes32(graffiti), + tiers: tiers, + isGuardian: isGuardian, + submissionDelay: submissionDelay, + proofBuffer: NewProofBuffer(proofBufferSize), + forceBatchProvingInterval: forceBatchProvingInterval, }, nil } @@ -143,7 +146,7 @@ func (s *ProofSubmitter) RequestProof(ctx context.Context, meta metadata.TaikoBl Graffiti: common.Bytes2Hex(s.graffiti[:]), GasUsed: header.GasUsed, ParentGasUsed: parent.GasUsed(), - Compressed: s.proofBuffer.MaxLength > 1, + Compressed: s.proofBuffer.Enabled(), } // If the prover set address is provided, we use that address as the prover on chain. @@ -159,9 +162,9 @@ func (s *ProofSubmitter) RequestProof(ctx context.Context, meta metadata.TaikoBl log.Error("Failed to request proof, context is canceled", "blockID", opts.BlockID, "error", ctx.Err()) return nil } - // Check if the proof buffer is full - if s.proofBuffer.MaxLength > 1 && s.proofBuffer.MaxLength == uint64(s.proofBuffer.Len()) { - log.Debug("Buffer is full now", "blockID", meta.GetBlockID()) + // Check if the proof buffer is full. + if s.proofBuffer.Enabled() && uint64(s.proofBuffer.Len()) >= s.proofBuffer.MaxLength { + log.Warn("Proof buffer is full now", "blockID", meta.GetBlockID()) return errBufferOverflow } // Check if there is a need to generate proof @@ -198,21 +201,30 @@ func (s *ProofSubmitter) RequestProof(ctx context.Context, meta metadata.TaikoBl } return fmt.Errorf("failed to request proof (id: %d): %w", meta.GetBlockID(), err) } - if meta.IsOntakeBlock() && s.proofBuffer.MaxLength > 1 { + if meta.IsOntakeBlock() && s.proofBuffer.Enabled() { bufferSize, err := s.proofBuffer.Write(result) if err != nil { - return fmt.Errorf("failed to add proof into buffer (id: %d)(current buffer size: %d): %w", + return fmt.Errorf( + "failed to add proof into buffer (id: %d) (current buffer size: %d): %w", meta.GetBlockID(), bufferSize, err, ) } - log.Debug("Succeed to generate proof", + log.Info( + "Proof generated", "blockID", meta.GetBlockID(), "bufferSize", bufferSize, + "maxBufferSize", s.proofBuffer.MaxLength, + "bufferIsAggregating", s.proofBuffer.IsAggregating(), + "bufferLastUpdatedAt", s.proofBuffer.lastUpdatedAt, ) - if s.proofBuffer.MaxLength == uint64(bufferSize) { + // Check if we need to aggregate proofs. + if !s.proofBuffer.IsAggregating() && + (uint64(bufferSize) >= s.proofBuffer.MaxLength || + time.Since(s.proofBuffer.lastUpdatedAt) > s.forceBatchProvingInterval) { s.aggregationNotify <- s.Tier() + s.proofBuffer.MarkAggregating() } } else { s.resultCh <- result @@ -344,7 +356,8 @@ func (s *ProofSubmitter) BatchSubmitProofs(ctx context.Context, batchProof *proo ) var ( invalidBlockIDs []uint64 - latestProvenBlockID = big.NewInt(0) + latestProvenBlockID = common.Big0 + uint64BlockIDs []uint64 ) if len(batchProof.Proofs) == 0 { return proofProducer.ErrInvalidLength @@ -369,19 +382,20 @@ func (s *ProofSubmitter) BatchSubmitProofs(ctx context.Context, batchProof *proo return err } for i, proof := range batchProof.Proofs { + uint64BlockIDs = append(uint64BlockIDs, proof.BlockID.Uint64()) // Check if this proof is still needed to be submitted. ok, err := s.sender.ValidateProof(ctx, proof, new(big.Int).SetUint64(stateVars.B.LastVerifiedBlockId)) if err != nil { return err } if !ok { - log.Error("a valid proof for block is already submitted", "blockId", proof.BlockID) + log.Error("A valid proof for block is already submitted", "blockId", proof.BlockID) invalidBlockIDs = append(invalidBlockIDs, proof.BlockID.Uint64()) continue } if proofStatus[i].IsSubmitted && !proofStatus[i].Invalid { - log.Error("a valid proof for block is already submitted", "blockId", proof.BlockID) + log.Error("A valid proof for block is already submitted", "blockId", proof.BlockID) invalidBlockIDs = append(invalidBlockIDs, proof.BlockID.Uint64()) continue } @@ -389,7 +403,8 @@ func (s *ProofSubmitter) BatchSubmitProofs(ctx context.Context, batchProof *proo // Get the corresponding L2 block. block, err := s.rpc.L2.BlockByHash(ctx, proof.Header.Hash()) if err != nil { - log.Error("failed to get L2 block with given hash", + log.Error( + "Failed to get L2 block with given hash", "hash", proof.Header.Hash(), "error", err, ) @@ -415,7 +430,7 @@ func (s *ProofSubmitter) BatchSubmitProofs(ctx context.Context, batchProof *proo } if len(invalidBlockIDs) > 0 { - log.Warn("Detected invalid proofs", "blockIds", invalidBlockIDs) + log.Warn("Invalid proofs in batch", "blockIds", invalidBlockIDs) s.proofBuffer.ClearItems(invalidBlockIDs...) return ErrInvalidProof } @@ -435,7 +450,9 @@ func (s *ProofSubmitter) BatchSubmitProofs(ctx context.Context, batchProof *proo metrics.ProverSentProofCounter.Add(float64(len(batchProof.BlockIDs))) metrics.ProverLatestProvenBlockIDGauge.Set(float64(latestProvenBlockID.Uint64())) - s.proofBuffer.Clear() + s.proofBuffer.ClearItems(uint64BlockIDs...) + // Each time we submit a batch proof, we should update the LastUpdatedAt() of the buffer. + s.proofBuffer.UpdateLastUpdatedAt() return nil } @@ -511,3 +528,8 @@ func (s *ProofSubmitter) Tier() uint16 { func (s *ProofSubmitter) BufferSize() uint64 { return s.proofBuffer.MaxLength } + +// AggregationEnabled returns whether the proof submitter's aggregation feature is enabled. +func (s *ProofSubmitter) AggregationEnabled() bool { + return s.proofBuffer.Enabled() +} diff --git a/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go b/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go index 3a7cbde8a12..be076f01efb 100644 --- a/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go +++ b/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go @@ -100,6 +100,7 @@ func (s *ProofSubmitterTestSuite) SetupTest() { false, 0*time.Second, 0, + 30*time.Minute, ) s.Nil(err) s.contester = NewProofContester( @@ -199,6 +200,7 @@ func (s *ProofSubmitterTestSuite) TestGetRandomBumpedSubmissionDelay() { false, time.Duration(0), 0, + 30*time.Minute, ) s.Nil(err) @@ -223,6 +225,7 @@ func (s *ProofSubmitterTestSuite) TestGetRandomBumpedSubmissionDelay() { false, 1*time.Hour, 0, + 30*time.Minute, ) s.Nil(err) delay, err = submitter2.getRandomBumpedSubmissionDelay(time.Now()) diff --git a/packages/taiko-client/prover/prover.go b/packages/taiko-client/prover/prover.go index 237a7f44937..a157a59bc6e 100644 --- a/packages/taiko-client/prover/prover.go +++ b/packages/taiko-client/prover/prover.go @@ -279,15 +279,7 @@ func (p *Prover) eventLoop() { default: } } - // reqAggregation requests performing a aggregate operation, won't block - // if we are already aggregating. - reqAggregation := func() { - select { - // 0 means aggregating all tier proofs - case p.aggregationNotify <- 0: - default: - } - } + // Call reqProving() right away to catch up with the latest state. reqProving() @@ -297,9 +289,6 @@ func (p *Prover) eventLoop() { forceProvingTicker := time.NewTicker(15 * time.Second) defer forceProvingTicker.Stop() - forceAggregatingTicker := time.NewTicker(p.cfg.ForceProveInterval) - defer forceAggregatingTicker.Stop() - // Channels chBufferSize := p.protocolConfigs.BlockMaxProposals blockProposedCh := make(chan *bindings.TaikoL1ClientBlockProposed, chBufferSize) @@ -347,9 +336,7 @@ func (p *Prover) eventLoop() { log.Error("Prove new blocks error", "error", err) } case tier := <-p.aggregationNotify: - p.withRetry(func() error { - return p.aggregateOp(tier) - }) + p.withRetry(func() error { return p.aggregateOp(tier) }) case e := <-blockVerifiedCh: p.blockVerifiedHandler.Handle(encoding.BlockVerifiedEventToV2(e)) case e := <-transitionProvedCh: @@ -389,8 +376,6 @@ func (p *Prover) eventLoop() { reqProving() case <-forceProvingTicker.C: reqProving() - case <-forceAggregatingTicker.C: - reqAggregation() } } } @@ -422,10 +407,10 @@ func (p *Prover) aggregateOp(tier uint16) error { g, gCtx := errgroup.WithContext(p.ctx) for _, submitter := range p.proofSubmitters { g.Go(func() error { - if submitter.BufferSize() > 1 && - (tier == 0 || submitter.Tier() == tier) { + if submitter.AggregationEnabled() && submitter.Tier() == tier { if err := submitter.AggregateProofs(gCtx); err != nil { - log.Error("Failed to aggregate proofs", + log.Error( + "Failed to aggregate proofs", "error", err, "tier", submitter.Tier(), ) From 2a82c945a2f6436a36f393105621bb011d8a4325 Mon Sep 17 00:00:00 2001 From: taiko-bot <160625009+taiko-kitty@users.noreply.github.com> Date: Sun, 22 Dec 2024 17:29:45 -0800 Subject: [PATCH 11/29] chore(main): release taiko-client 0.40.0 (#18436) --- .release-please-manifest.json | 2 +- packages/taiko-client/CHANGELOG.md | 55 ++++++++++++++++++++++++++++++ packages/taiko-client/package.json | 2 +- 3 files changed, 57 insertions(+), 2 deletions(-) diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 8e80b86f84d..4cdffaa51c7 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -9,7 +9,7 @@ "packages/relayer": "0.12.0", "packages/snaefell-ui": "1.1.0", "packages/supplementary-contracts": "1.0.0", - "packages/taiko-client": "0.39.2", + "packages/taiko-client": "0.40.0", "packages/taikoon-ui": "1.3.0", "packages/ui-lib": "1.0.0" } diff --git a/packages/taiko-client/CHANGELOG.md b/packages/taiko-client/CHANGELOG.md index 99eceb0e43e..bf15b7faff9 100644 --- a/packages/taiko-client/CHANGELOG.md +++ b/packages/taiko-client/CHANGELOG.md @@ -1,5 +1,60 @@ # Changelog +## [0.40.0](https://github.com/taikoxyz/taiko-mono/compare/taiko-client-v0.39.2...taiko-client-v0.40.0) (2024-12-23) + + +### Features + +* **protocol:** propose a batch blocks conditionally ([#18570](https://github.com/taikoxyz/taiko-mono/issues/18570)) ([e846f62](https://github.com/taikoxyz/taiko-mono/commit/e846f6289fea0b046ddcfcdfaf46f3727efbdf11)) +* **taiko-client:** add chain ID to `TryDecompress()` ([#18444](https://github.com/taikoxyz/taiko-mono/issues/18444)) ([10d99d5](https://github.com/taikoxyz/taiko-mono/commit/10d99d50d3866a6e233d9e3749ea5eb753335815)) +* **taiko-client:** client changes based on [#18150](https://github.com/taikoxyz/taiko-mono/issues/18150) ([#18350](https://github.com/taikoxyz/taiko-mono/issues/18350)) ([ddc6473](https://github.com/taikoxyz/taiko-mono/commit/ddc647327e8d58f5a2def5b902ad06800982544b)) +* **taiko-client:** compatible changes for `lastProposedIn` ([#18442](https://github.com/taikoxyz/taiko-mono/issues/18442)) ([28f32a7](https://github.com/taikoxyz/taiko-mono/commit/28f32a790cc680ecb3e6345221e4183af4f34b2e)) +* **taiko-client:** enable proof aggregation (batch proofs) ([#18163](https://github.com/taikoxyz/taiko-mono/issues/18163)) ([7642961](https://github.com/taikoxyz/taiko-mono/commit/7642961a9031840183f4d00d0a4c19fdb8a68058)) +* **taiko-client:** improve `ProofBuffer` ([#18627](https://github.com/taikoxyz/taiko-mono/issues/18627)) ([c386589](https://github.com/taikoxyz/taiko-mono/commit/c3865896523712afa108be810e75b511e7ecc0c4)) +* **taiko-client:** make p2p-sync required ([#18571](https://github.com/taikoxyz/taiko-mono/issues/18571)) ([de92b28](https://github.com/taikoxyz/taiko-mono/commit/de92b28c03b747845a8a1aa26991307d1ed47fd0)) +* **taiko-client:** revert pr 18442 ([#18450](https://github.com/taikoxyz/taiko-mono/issues/18450)) ([0706f0a](https://github.com/taikoxyz/taiko-mono/commit/0706f0aee9c318d8de298f98480a46de6337937c)) +* **taiko-client:** update Go contract bindings ([#18381](https://github.com/taikoxyz/taiko-mono/issues/18381)) ([71cfc5c](https://github.com/taikoxyz/taiko-mono/commit/71cfc5ce1ef06dcf099a4ce9b22bea6100406148)) +* **taiko-client:** update Go contract bindings ([#18384](https://github.com/taikoxyz/taiko-mono/issues/18384)) ([8dd14a1](https://github.com/taikoxyz/taiko-mono/commit/8dd14a1b4b21ce77ed3aac935b1d2c950e11e729)) +* **taiko-client:** update Go contract bindings ([#18462](https://github.com/taikoxyz/taiko-mono/issues/18462)) ([bc0ee99](https://github.com/taikoxyz/taiko-mono/commit/bc0ee9952234cc6722d3a0e9d9ebd92bca706999)) + + +### Bug Fixes + +* **taiko-client:** valid status check in `BatchGetBlocksProofStatus` ([#18595](https://github.com/taikoxyz/taiko-mono/issues/18595)) ([ec5f599](https://github.com/taikoxyz/taiko-mono/commit/ec5f5999750f70efe58cc061c5856250dcef5ce2)) + + +### Chores + +* **taiko-client:** add `BaseFeeConfig.SharingPctg` to mainnet protocol config ([#18341](https://github.com/taikoxyz/taiko-mono/issues/18341)) ([75d14a7](https://github.com/taikoxyz/taiko-mono/commit/75d14a7afac83b4578a3c32456a28ae70373d5cb)) +* **taiko-client:** update CI badge and path ([#18441](https://github.com/taikoxyz/taiko-mono/issues/18441)) ([6aef03e](https://github.com/taikoxyz/taiko-mono/commit/6aef03e87eaf3cdbfb7637bd6122525f75c611f0)) +* **taiko-client:** update docker-compose config ([#18330](https://github.com/taikoxyz/taiko-mono/issues/18330)) ([74e4ca4](https://github.com/taikoxyz/taiko-mono/commit/74e4ca4aaef07af4958a7b61c95e385022b1cf3c)) +* **taiko-client:** update Go contract bindings generation script ([#18324](https://github.com/taikoxyz/taiko-mono/issues/18324)) ([4f698a0](https://github.com/taikoxyz/taiko-mono/commit/4f698a02bb1714caf527629a637323a9964cdb11)) + + +### Code Refactoring + +* **taiko-client:** move `utils` package from `internal/` to `pkg/` ([#18516](https://github.com/taikoxyz/taiko-mono/issues/18516)) ([b674857](https://github.com/taikoxyz/taiko-mono/commit/b67485732832fb90849179a7a8c8093f2228eb5a)) + + +### Tests + +* **taiko-client:** fix some lint issues for `taiko-client` ([#18517](https://github.com/taikoxyz/taiko-mono/issues/18517)) ([ac7eba6](https://github.com/taikoxyz/taiko-mono/commit/ac7eba69bfe13f026bc6e08074ebaec5dcb067eb)) +* **taiko-client:** introduce TestTxPoolContentWithMinTip test case ([#18285](https://github.com/taikoxyz/taiko-mono/issues/18285)) ([d572f4c](https://github.com/taikoxyz/taiko-mono/commit/d572f4c412e59094ea9a4c5ff0b0667c9c04bd66)) +* **taiko-client:** skip `TestCheckL1ReorgToSameHeightFork` temporarily ([#18522](https://github.com/taikoxyz/taiko-mono/issues/18522)) ([385fed2](https://github.com/taikoxyz/taiko-mono/commit/385fed2ce273d131635c54e99a11704a4ed385b8)) + + +### Workflow + +* **protocol:** trigger patch release (1.10.1) ([#18358](https://github.com/taikoxyz/taiko-mono/issues/18358)) ([f4f4796](https://github.com/taikoxyz/taiko-mono/commit/f4f4796488059b02c79d6fb15170df58dd31dc4e)) +* **repo:** change to trigger hive test manually ([#18514](https://github.com/taikoxyz/taiko-mono/issues/18514)) ([63dec66](https://github.com/taikoxyz/taiko-mono/commit/63dec6695b3e330ba7bd69857743741d7608e2a4)) +* **repo:** update go mod and use random port ([#18515](https://github.com/taikoxyz/taiko-mono/issues/18515)) ([3c2e943](https://github.com/taikoxyz/taiko-mono/commit/3c2e943ab2d6ff636ad69dc7e93df34d8f549c4d)) + + +### Build + +* **deps:** bump github.com/stretchr/testify from 1.9.0 to 1.10.0 ([#18539](https://github.com/taikoxyz/taiko-mono/issues/18539)) ([79f3fab](https://github.com/taikoxyz/taiko-mono/commit/79f3fab5f1d1ec1bb4ee18afb9268b622e894780)) +* **deps:** bump golang.org/x/sync from 0.9.0 to 0.10.0 ([#18560](https://github.com/taikoxyz/taiko-mono/issues/18560)) ([3d51970](https://github.com/taikoxyz/taiko-mono/commit/3d51970aa0953bbfecaeebf76ea7e664c875c0e4)) + ## [0.39.2](https://github.com/taikoxyz/taiko-mono/compare/taiko-client-v0.39.1...taiko-client-v0.39.2) (2024-10-24) diff --git a/packages/taiko-client/package.json b/packages/taiko-client/package.json index 53409674e4f..210f57be4da 100644 --- a/packages/taiko-client/package.json +++ b/packages/taiko-client/package.json @@ -1,5 +1,5 @@ { "name": "taiko-client", - "version": "0.39.2", + "version": "0.40.0", "private": true } From 73944585586686ad1ce5548ce59e9ea583c4b2ee Mon Sep 17 00:00:00 2001 From: Daniel Wang <99078276+dantaik@users.noreply.github.com> Date: Mon, 23 Dec 2024 12:51:51 +0800 Subject: [PATCH 12/29] ci(protocol): make the storage layout table clearer (#18633) Co-authored-by: dantaik --- packages/protocol/contract_layout_layer1.md | 3070 +++++++++---------- packages/protocol/contract_layout_layer2.md | 1436 ++++----- packages/protocol/script/gen-layouts.sh | 10 +- 3 files changed, 2262 insertions(+), 2254 deletions(-) diff --git a/packages/protocol/contract_layout_layer1.md b/packages/protocol/contract_layout_layer1.md index b7deb791879..45bda27324b 100644 --- a/packages/protocol/contract_layout_layer1.md +++ b/packages/protocol/contract_layout_layer1.md @@ -1,1047 +1,1047 @@ ## ERC1155Vault ╭--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[48] | 303 | 0 | 1536 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 351 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 401 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 451 | 0 | 1600 | ERC1155Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| __gap | uint256[48] | 303 | 0 | 1536 | +| +| __gap | uint256[50] | 351 | 0 | 1600 | +| +| __gap | uint256[50] | 401 | 0 | 1600 | +| +| __gap | uint256[50] | 451 | 0 | 1600 | ╰--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------╯ ## ERC20Vault ╭--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct ERC20Vault.CanonicalERC20) | 301 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| btokenDenylist | mapping(address => bool) | 303 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| lastMigrationStart | mapping(uint256 => mapping(address => uint256)) | 304 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[46] | 305 | 0 | 1472 | ERC20Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct ERC20Vault.CanonicalERC20) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| btokenDenylist | mapping(address => bool) | 303 | 0 | 32 | +| +| lastMigrationStart | mapping(uint256 => mapping(address => uint256)) | 304 | 0 | 32 | +| +| __gap | uint256[46] | 305 | 0 | 1472 | ╰--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------╯ ## ERC721Vault ╭--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[48] | 303 | 0 | 1536 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 351 | 0 | 1600 | ERC721Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| __gap | uint256[48] | 303 | 0 | 1536 | +| +| __gap | uint256[50] | 351 | 0 | 1600 | ╰--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------╯ ## BridgedERC20 ╭------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _balances | mapping(address => uint256) | 251 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _totalSupply | uint256 | 253 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _name | string | 254 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _symbol | string | 255 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[45] | 256 | 0 | 1440 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| srcToken | address | 301 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __srcDecimals | uint8 | 301 | 20 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| srcChainId | uint256 | 302 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| migratingAddress | address | 303 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| migratingInbound | bool | 303 | 20 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[47] | 304 | 0 | 1504 | BridgedERC20 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _balances | mapping(address => uint256) | 251 | 0 | 32 | +| +| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | +| +| _totalSupply | uint256 | 253 | 0 | 32 | +| +| _name | string | 254 | 0 | 32 | +| +| _symbol | string | 255 | 0 | 32 | +| +| __gap | uint256[45] | 256 | 0 | 1440 | +| +| srcToken | address | 301 | 0 | 20 | +| +| __srcDecimals | uint8 | 301 | 20 | 1 | +| +| srcChainId | uint256 | 302 | 0 | 32 | +| +| migratingAddress | address | 303 | 0 | 20 | +| +| migratingInbound | bool | 303 | 20 | 1 | +| +| __gap | uint256[47] | 304 | 0 | 1504 | ╰------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╯ ## BridgedERC20V2 ╭------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _balances | mapping(address => uint256) | 251 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _totalSupply | uint256 | 253 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _name | string | 254 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _symbol | string | 255 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[45] | 256 | 0 | 1440 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcToken | address | 301 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __srcDecimals | uint8 | 301 | 20 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcChainId | uint256 | 302 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| migratingAddress | address | 303 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| migratingInbound | bool | 303 | 20 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[47] | 304 | 0 | 1504 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _hashedName | bytes32 | 351 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _hashedVersion | bytes32 | 352 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _name | string | 353 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _version | string | 354 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[48] | 355 | 0 | 1536 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 404 | 0 | 1568 | BridgedERC20V2 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _balances | mapping(address => uint256) | 251 | 0 | 32 | +| +| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | +| +| _totalSupply | uint256 | 253 | 0 | 32 | +| +| _name | string | 254 | 0 | 32 | +| +| _symbol | string | 255 | 0 | 32 | +| +| __gap | uint256[45] | 256 | 0 | 1440 | +| +| srcToken | address | 301 | 0 | 20 | +| +| __srcDecimals | uint8 | 301 | 20 | 1 | +| +| srcChainId | uint256 | 302 | 0 | 32 | +| +| migratingAddress | address | 303 | 0 | 20 | +| +| migratingInbound | bool | 303 | 20 | 1 | +| +| __gap | uint256[47] | 304 | 0 | 1504 | +| +| _hashedName | bytes32 | 351 | 0 | 32 | +| +| _hashedVersion | bytes32 | 352 | 0 | 32 | +| +| _name | string | 353 | 0 | 32 | +| +| _version | string | 354 | 0 | 32 | +| +| __gap | uint256[48] | 355 | 0 | 1536 | +| +| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | +| +| __gap | uint256[49] | 404 | 0 | 1568 | ╰------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------╯ ## BridgedERC721 ╭--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _name | string | 301 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _symbol | string | 302 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _owners | mapping(uint256 => address) | 303 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _balances | mapping(address => uint256) | 304 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _tokenApprovals | mapping(uint256 => address) | 305 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _operatorApprovals | mapping(address => mapping(address => bool)) | 306 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[44] | 307 | 0 | 1408 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| srcToken | address | 351 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| srcChainId | uint256 | 352 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[48] | 353 | 0 | 1536 | BridgedERC721 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| _name | string | 301 | 0 | 32 | +| +| _symbol | string | 302 | 0 | 32 | +| +| _owners | mapping(uint256 => address) | 303 | 0 | 32 | +| +| _balances | mapping(address => uint256) | 304 | 0 | 32 | +| +| _tokenApprovals | mapping(uint256 => address) | 305 | 0 | 32 | +| +| _operatorApprovals | mapping(address => mapping(address => bool)) | 306 | 0 | 32 | +| +| __gap | uint256[44] | 307 | 0 | 1408 | +| +| srcToken | address | 351 | 0 | 20 | +| +| srcChainId | uint256 | 352 | 0 | 32 | +| +| __gap | uint256[48] | 353 | 0 | 1536 | ╰--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------╯ ## BridgedERC1155 ╭--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _balances | mapping(uint256 => mapping(address => uint256)) | 301 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _operatorApprovals | mapping(address => mapping(address => bool)) | 302 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _uri | string | 303 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[47] | 304 | 0 | 1504 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcToken | address | 351 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcChainId | uint256 | 352 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| symbol | string | 353 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| name | string | 354 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[46] | 355 | 0 | 1472 | BridgedERC1155 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| _balances | mapping(uint256 => mapping(address => uint256)) | 301 | 0 | 32 | +| +| _operatorApprovals | mapping(address => mapping(address => bool)) | 302 | 0 | 32 | +| +| _uri | string | 303 | 0 | 32 | +| +| __gap | uint256[47] | 304 | 0 | 1504 | +| +| srcToken | address | 351 | 0 | 20 | +| +| srcChainId | uint256 | 352 | 0 | 32 | +| +| symbol | string | 353 | 0 | 32 | +| +| name | string | 354 | 0 | 32 | +| +| __gap | uint256[46] | 355 | 0 | 1472 | ╰--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------╯ ## Bridge ╭------------------+-----------------------------------------+------+--------+-------+-------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| _owner | address | 51 | 0 | 20 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| addressManager | address | 151 | 0 | 20 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reserved1 | uint64 | 251 | 0 | 8 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| nextMessageId | uint64 | 251 | 8 | 8 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| messageStatus | mapping(bytes32 => enum IBridge.Status) | 252 | 0 | 32 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __ctx | struct IBridge.Context | 253 | 0 | 64 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reserved2 | uint256 | 255 | 0 | 32 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reserved3 | uint256 | 256 | 0 | 32 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[44] | 257 | 0 | 1408 | Bridge | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __reserved1 | uint64 | 251 | 0 | 8 | +| +| nextMessageId | uint64 | 251 | 8 | 8 | +| +| messageStatus | mapping(bytes32 => enum IBridge.Status) | 252 | 0 | 32 | +| +| __ctx | struct IBridge.Context | 253 | 0 | 64 | +| +| __reserved2 | uint256 | 255 | 0 | 32 | +| +| __reserved3 | uint256 | 256 | 0 | 32 | +| +| __gap | uint256[44] | 257 | 0 | 1408 | ╰------------------+-----------------------------------------+------+--------+-------+-------------------------------------------╯ ## QuotaManager ╭------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| tokenQuota | mapping(address => struct QuotaManager.Quota) | 251 | 0 | 32 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| quotaPeriod | uint24 | 252 | 0 | 3 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | QuotaManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| tokenQuota | mapping(address => struct QuotaManager.Quota) | 251 | 0 | 32 | +| +| quotaPeriod | uint24 | 252 | 0 | 3 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------╯ ## AddressManager ╭------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | AddressManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╯ ## AddressResolver ╭----------------+-------------+------+--------+-------+-------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +====================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | AddressResolver | -|----------------+-------------+------+--------+-------+-------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | AddressResolver | -|----------------+-------------+------+--------+-------+-------------------------------------------------------------| -| addressManager | address | 0 | 2 | 20 | AddressResolver | -|----------------+-------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 1 | 0 | 1568 | AddressResolver | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| addressManager | address | 0 | 2 | 20 | +| +| __gap | uint256[49] | 1 | 0 | 1568 | ╰----------------+-------------+------+--------+-------+-------------------------------------------------------------╯ ## EssentialContract ╭------------------+-------------+------+--------+-------+-----------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==========================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | EssentialContract | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | ╰------------------+-------------+------+--------+-------+-----------------------------------------------------------------╯ ## SignalService ╭------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +====================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| topBlockId | mapping(uint64 => mapping(bytes32 => uint64)) | 251 | 0 | 32 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| isAuthorized | mapping(address => bool) | 252 | 0 | 32 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | SignalService | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| topBlockId | mapping(uint64 => mapping(bytes32 => uint64)) | 251 | 0 | 32 | +| +| isAuthorized | mapping(address => bool) | 252 | 0 | 32 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------╯ ## TaikoToken ╭-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _owner | address | 51 | 0 | 20 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __slots_previously_used_by_ERC20SnapshotUpgradeable | uint256[50] | 251 | 0 | 1600 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _balances | mapping(address => uint256) | 301 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _allowances | mapping(address => mapping(address => uint256)) | 302 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _totalSupply | uint256 | 303 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _name | string | 304 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _symbol | string | 305 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[45] | 306 | 0 | 1440 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _hashedName | bytes32 | 351 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _hashedVersion | bytes32 | 352 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _name | string | 353 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _version | string | 354 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[48] | 355 | 0 | 1536 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _PERMIT_TYPEHASH_DEPRECATED_SLOT | bytes32 | 404 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 405 | 0 | 1568 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _delegates | mapping(address => address) | 454 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _checkpoints | mapping(address => struct ERC20VotesUpgradeable.Checkpoint[]) | 455 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| _totalSupplyCheckpoints | struct ERC20VotesUpgradeable.Checkpoint[] | 456 | 0 | 32 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[47] | 457 | 0 | 1504 | TaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[50] | 504 | 0 | 1600 | TaikoToken | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __slots_previously_used_by_ERC20SnapshotUpgradeable | uint256[50] | 251 | 0 | 1600 | +| +| _balances | mapping(address => uint256) | 301 | 0 | 32 | +| +| _allowances | mapping(address => mapping(address => uint256)) | 302 | 0 | 32 | +| +| _totalSupply | uint256 | 303 | 0 | 32 | +| +| _name | string | 304 | 0 | 32 | +| +| _symbol | string | 305 | 0 | 32 | +| +| __gap | uint256[45] | 306 | 0 | 1440 | +| +| _hashedName | bytes32 | 351 | 0 | 32 | +| +| _hashedVersion | bytes32 | 352 | 0 | 32 | +| +| _name | string | 353 | 0 | 32 | +| +| _version | string | 354 | 0 | 32 | +| +| __gap | uint256[48] | 355 | 0 | 1536 | +| +| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | +| +| _PERMIT_TYPEHASH_DEPRECATED_SLOT | bytes32 | 404 | 0 | 32 | +| +| __gap | uint256[49] | 405 | 0 | 1568 | +| +| _delegates | mapping(address => address) | 454 | 0 | 32 | +| +| _checkpoints | mapping(address => struct ERC20VotesUpgradeable.Checkpoint[]) | 455 | 0 | 32 | +| +| _totalSupplyCheckpoints | struct ERC20VotesUpgradeable.Checkpoint[] | 456 | 0 | 32 | +| +| __gap | uint256[47] | 457 | 0 | 1504 | +| +| __gap | uint256[50] | 504 | 0 | 1600 | ╰-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+--------------------------------------------------╯ ## ComposeVerifier ╭------------------+-------------+------+--------+-------+------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ComposeVerifier | -|------------------+-------------+------+--------+-------+------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ComposeVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+------------------------------------------------------------------------╯ ## TeeAnyVerifier ╭------------------+-------------+------+--------+-------+----------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | TeeAnyVerifier | -|------------------+-------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | TeeAnyVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+----------------------------------------------------------------------╯ ## ZkAndTeeVerifier ╭------------------+-------------+------+--------+-------+--------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | ZkAndTeeVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+--------------------------------------------------------------------------╯ ## ZkAnyVerifier ╭------------------+-------------+------+--------+-------+--------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=============================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ZkAnyVerifier | -|------------------+-------------+------+--------+-------+--------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | ZkAnyVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+--------------------------------------------------------------------╯ ## Risc0Verifier ╭------------------+--------------------------+------+--------+-------+------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| isImageTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | Risc0Verifier | -|------------------+--------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | Risc0Verifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| isImageTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+--------------------------+------+--------+-------+------------------------------------------------------------╯ ## SP1Verifier ╭------------------+--------------------------+------+--------+-------+--------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==============================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| isProgramTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | SP1Verifier | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | SP1Verifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| isProgramTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+--------------------------+------+--------+-------+--------------------------------------------------------╯ ## SgxVerifier ╭-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +======================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| nextInstanceId | uint256 | 251 | 0 | 32 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| instances | mapping(uint256 => struct SgxVerifier.Instance) | 252 | 0 | 32 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| addressRegistered | mapping(address => bool) | 253 | 0 | 32 | SgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------| -| __gap | uint256[47] | 254 | 0 | 1504 | SgxVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| nextInstanceId | uint256 | 251 | 0 | 32 | +| +| instances | mapping(uint256 => struct SgxVerifier.Instance) | 252 | 0 | 32 | +| +| addressRegistered | mapping(address => bool) | 253 | 0 | 32 | +| +| __gap | uint256[47] | 254 | 0 | 1504 | ╰-------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------╯ ## AutomataDcapV3Attestation ╭-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===================================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| sigVerifyLib | contract ISigVerifyLib | 251 | 0 | 20 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| pemCertLib | contract IPEMCertChainLib | 252 | 0 | 20 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| checkLocalEnclaveReport | bool | 252 | 20 | 1 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| trustedUserMrEnclave | mapping(bytes32 => bool) | 253 | 0 | 32 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| trustedUserMrSigner | mapping(bytes32 => bool) | 254 | 0 | 32 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| serialNumIsRevoked | mapping(uint256 => mapping(bytes => bool)) | 255 | 0 | 32 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| tcbInfo | mapping(string => struct TCBInfoStruct.TCBInfo) | 256 | 0 | 32 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| qeIdentity | struct EnclaveIdStruct.EnclaveId | 257 | 0 | 128 | AutomataDcapV3Attestation | -|-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[39] | 261 | 0 | 1248 | AutomataDcapV3Attestation | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| sigVerifyLib | contract ISigVerifyLib | 251 | 0 | 20 | +| +| pemCertLib | contract IPEMCertChainLib | 252 | 0 | 20 | +| +| checkLocalEnclaveReport | bool | 252 | 20 | 1 | +| +| trustedUserMrEnclave | mapping(bytes32 => bool) | 253 | 0 | 32 | +| +| trustedUserMrSigner | mapping(bytes32 => bool) | 254 | 0 | 32 | +| +| serialNumIsRevoked | mapping(uint256 => mapping(bytes => bool)) | 255 | 0 | 32 | +| +| tcbInfo | mapping(string => struct TCBInfoStruct.TCBInfo) | 256 | 0 | 32 | +| +| qeIdentity | struct EnclaveIdStruct.EnclaveId | 257 | 0 | 128 | +| +| __gap | uint256[39] | 261 | 0 | 1248 | ╰-------------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------------------------------------------╯ ## TaikoL1 ╭------------------+------------------------+------+--------+-------+--------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| _owner | address | 51 | 0 | 20 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| addressManager | address | 151 | 0 | 20 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| state | struct TaikoData.State | 251 | 0 | 1600 | TaikoL1 | -|------------------+------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | TaikoL1 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| state | struct TaikoData.State | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+------------------------+------+--------+-------+--------------------------------------------╯ ## HeklaTaikoL1 ╭------------------+------------------------+------+--------+-------+------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==========================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| state | struct TaikoData.State | 251 | 0 | 1600 | HeklaTaikoL1 | -|------------------+------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | HeklaTaikoL1 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| state | struct TaikoData.State | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+------------------------+------+--------+-------+------------------------------------------------------╯ ## HeklaTierRouter ╭------+------+------+--------+-------+----------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================+ ╰------+------+------+--------+-------+----------╯ @@ -1049,265 +1049,265 @@ ## MainnetBridge ╭------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __reserved1 | uint64 | 251 | 0 | 8 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| nextMessageId | uint64 | 251 | 8 | 8 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| messageStatus | mapping(bytes32 => enum IBridge.Status) | 252 | 0 | 32 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __ctx | struct IBridge.Context | 253 | 0 | 64 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __reserved2 | uint256 | 255 | 0 | 32 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __reserved3 | uint256 | 256 | 0 | 32 | MainnetBridge | -|------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------| -| __gap | uint256[44] | 257 | 0 | 1408 | MainnetBridge | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __reserved1 | uint64 | 251 | 0 | 8 | +| +| nextMessageId | uint64 | 251 | 8 | 8 | +| +| messageStatus | mapping(bytes32 => enum IBridge.Status) | 252 | 0 | 32 | +| +| __ctx | struct IBridge.Context | 253 | 0 | 64 | +| +| __reserved2 | uint256 | 255 | 0 | 32 | +| +| __reserved3 | uint256 | 256 | 0 | 32 | +| +| __gap | uint256[44] | 257 | 0 | 1408 | ╰------------------+-----------------------------------------+------+--------+-------+----------------------------------------------------------------------╯ ## MainnetSignalService ╭------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| topBlockId | mapping(uint64 => mapping(bytes32 => uint64)) | 251 | 0 | 32 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| isAuthorized | mapping(address => bool) | 252 | 0 | 32 | MainnetSignalService | -|------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | MainnetSignalService | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| topBlockId | mapping(uint64 => mapping(bytes32 => uint64)) | 251 | 0 | 32 | +| +| isAuthorized | mapping(address => bool) | 252 | 0 | 32 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+-----------------------------------------------+------+--------+-------+------------------------------------------------------------------------------------╯ ## MainnetERC20Vault ╭--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct ERC20Vault.CanonicalERC20) | 301 | 0 | 32 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| btokenDenylist | mapping(address => bool) | 303 | 0 | 32 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| lastMigrationStart | mapping(uint256 => mapping(address => uint256)) | 304 | 0 | 32 | MainnetERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------| -| __gap | uint256[46] | 305 | 0 | 1472 | MainnetERC20Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct ERC20Vault.CanonicalERC20) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| btokenDenylist | mapping(address => bool) | 303 | 0 | 32 | +| +| lastMigrationStart | mapping(uint256 => mapping(address => uint256)) | 304 | 0 | 32 | +| +| __gap | uint256[46] | 305 | 0 | 1472 | ╰--------------------+------------------------------------------------------+------+--------+-------+------------------------------------------------------------------------------╯ ## MainnetERC1155Vault ╭--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +======================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[48] | 303 | 0 | 1536 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[50] | 351 | 0 | 1600 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[50] | 401 | 0 | 1600 | MainnetERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------| -| __gap | uint256[50] | 451 | 0 | 1600 | MainnetERC1155Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| __gap | uint256[48] | 303 | 0 | 1536 | +| +| __gap | uint256[50] | 351 | 0 | 1600 | +| +| __gap | uint256[50] | 401 | 0 | 1600 | +| +| __gap | uint256[50] | 451 | 0 | 1600 | ╰--------------------+------------------------------------------------------+------+--------+-------+----------------------------------------------------------------------------------╯ ## MainnetERC721Vault ╭--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +====================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[48] | 303 | 0 | 1536 | MainnetERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------| -| __gap | uint256[50] | 351 | 0 | 1600 | MainnetERC721Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| __gap | uint256[48] | 303 | 0 | 1536 | +| +| __gap | uint256[50] | 351 | 0 | 1600 | ╰--------------------+------------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------╯ ## MainnetSharedAddressManager ╭------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | MainnetSharedAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | MainnetSharedAddressManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+-------------------------------------------------+------+--------+-------+--------------------------------------------------------------------------------------------------╯ ## RollupAddressCache ╭------+------+------+--------+-------+----------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================+ ╰------+------+------+--------+-------+----------╯ @@ -1315,7 +1315,7 @@ ## SharedAddressCache ╭------+------+------+--------+-------+----------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================+ ╰------+------+------+--------+-------+----------╯ @@ -1323,7 +1323,7 @@ ## AddressCache ╭------+------+------+--------+-------+----------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================+ ╰------+------+------+--------+-------+----------╯ @@ -1331,356 +1331,356 @@ ## MainnetSgxVerifier ╭-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| nextInstanceId | uint256 | 251 | 0 | 32 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| instances | mapping(uint256 => struct SgxVerifier.Instance) | 252 | 0 | 32 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| addressRegistered | mapping(address => bool) | 253 | 0 | 32 | MainnetSgxVerifier | -|-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[47] | 254 | 0 | 1504 | MainnetSgxVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| nextInstanceId | uint256 | 251 | 0 | 32 | +| +| instances | mapping(uint256 => struct SgxVerifier.Instance) | 252 | 0 | 32 | +| +| addressRegistered | mapping(address => bool) | 253 | 0 | 32 | +| +| __gap | uint256[47] | 254 | 0 | 1504 | ╰-------------------+-------------------------------------------------+------+--------+-------+-------------------------------------------------------------------------------------╯ ## MainnetSP1Verifier ╭------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| isProgramTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | MainnetSP1Verifier | -|------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | MainnetSP1Verifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| isProgramTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+--------------------------+------+--------+-------+-------------------------------------------------------------------------------------╯ ## MainnetZkAnyVerifier ╭------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | MainnetZkAnyVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | MainnetZkAnyVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------╯ ## MainnetRisc0Verifier ╭------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| isImageTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | MainnetRisc0Verifier | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | MainnetRisc0Verifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| isImageTrusted | mapping(bytes32 => bool) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------------------------╯ ## MainnetZkAndTeeVerifier ╭------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | MainnetZkAndTeeVerifier | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | MainnetZkAndTeeVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+-----------------------------------------------------------------------------------------------╯ ## MainnetTeeAnyVerifier ╭------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +====================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | MainnetTeeAnyVerifier | -|------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | MainnetTeeAnyVerifier | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+-------------+------+--------+-------+-------------------------------------------------------------------------------------------╯ ## MainnetGuardianProver ╭-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=====================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| guardianIds | mapping(address => uint256) | 251 | 0 | 32 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| approvals | mapping(uint256 => mapping(bytes32 => uint256)) | 252 | 0 | 32 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| guardians | address[] | 253 | 0 | 32 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| version | uint32 | 254 | 0 | 4 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| minGuardians | uint32 | 254 | 4 | 4 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| provingAutoPauseEnabled | bool | 254 | 8 | 1 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| latestProofHash | mapping(uint256 => mapping(uint256 => bytes32)) | 255 | 0 | 32 | MainnetGuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------| -| __gap | uint256[45] | 256 | 0 | 1440 | MainnetGuardianProver | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| guardianIds | mapping(address => uint256) | 251 | 0 | 32 | +| +| approvals | mapping(uint256 => mapping(bytes32 => uint256)) | 252 | 0 | 32 | +| +| guardians | address[] | 253 | 0 | 32 | +| +| version | uint32 | 254 | 0 | 4 | +| +| minGuardians | uint32 | 254 | 4 | 4 | +| +| provingAutoPauseEnabled | bool | 254 | 8 | 1 | +| +| latestProofHash | mapping(uint256 => mapping(uint256 => bytes32)) | 255 | 0 | 32 | +| +| __gap | uint256[45] | 256 | 0 | 1440 | ╰-------------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------╯ ## MainnetTaikoL1 ╭------------------+------------------------+------+--------+-------+-------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=======================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| state | struct TaikoData.State | 251 | 0 | 1600 | MainnetTaikoL1 | -|------------------+------------------------+------+--------+-------+-------------------------------------------------------------------| -| __gap | uint256[50] | 301 | 0 | 1600 | MainnetTaikoL1 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| state | struct TaikoData.State | 251 | 0 | 1600 | +| +| __gap | uint256[50] | 301 | 0 | 1600 | ╰------------------+------------------------+------+--------+-------+-------------------------------------------------------------------╯ ## MainnetRollupAddressManager ╭------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==========================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | MainnetRollupAddressManager | -|------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | MainnetRollupAddressManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------------------------------------╯ ## MainnetTierRouter ╭------+------+------+--------+-------+----------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================+ ╰------+------+------+--------+-------+----------╯ @@ -1688,191 +1688,191 @@ ## MainnetProverSet ╭------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=============================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| isProver | mapping(address => bool) | 251 | 0 | 32 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| admin | address | 252 | 0 | 20 | MainnetProverSet | -|------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | MainnetProverSet | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| isProver | mapping(address => bool) | 251 | 0 | 32 | +| +| admin | address | 252 | 0 | 20 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+--------------------------+------+--------+-------+-----------------------------------------------------------------------╯ ## TokenUnlock ╭------------------+--------------------------+------+--------+-------+---------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=====================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| amountVested | uint256 | 251 | 0 | 32 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| recipient | address | 252 | 0 | 20 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| tgeTimestamp | uint64 | 252 | 20 | 8 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| isProverSet | mapping(address => bool) | 253 | 0 | 32 | TokenUnlock | -|------------------+--------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[47] | 254 | 0 | 1504 | TokenUnlock | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| amountVested | uint256 | 251 | 0 | 32 | +| +| recipient | address | 252 | 0 | 20 | +| +| tgeTimestamp | uint64 | 252 | 20 | 8 | +| +| isProverSet | mapping(address => bool) | 253 | 0 | 32 | +| +| __gap | uint256[47] | 254 | 0 | 1504 | ╰------------------+--------------------------+------+--------+-------+---------------------------------------------------------------╯ ## ProverSet ╭------------------+--------------------------+------+--------+-------+--------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +========================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| isProver | mapping(address => bool) | 251 | 0 | 32 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| admin | address | 252 | 0 | 20 | ProverSet | -|------------------+--------------------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | ProverSet | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| isProver | mapping(address => bool) | 251 | 0 | 32 | +| +| admin | address | 252 | 0 | 20 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+--------------------------+------+--------+-------+--------------------------------------------------╯ ## GuardianProver ╭-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| guardianIds | mapping(address => uint256) | 251 | 0 | 32 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| approvals | mapping(uint256 => mapping(bytes32 => uint256)) | 252 | 0 | 32 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| guardians | address[] | 253 | 0 | 32 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| version | uint32 | 254 | 0 | 4 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| minGuardians | uint32 | 254 | 4 | 4 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| provingAutoPauseEnabled | bool | 254 | 8 | 1 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| latestProofHash | mapping(uint256 => mapping(uint256 => bytes32)) | 255 | 0 | 32 | GuardianProver | -|-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[45] | 256 | 0 | 1440 | GuardianProver | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| guardianIds | mapping(address => uint256) | 251 | 0 | 32 | +| +| approvals | mapping(uint256 => mapping(bytes32 => uint256)) | 252 | 0 | 32 | +| +| guardians | address[] | 253 | 0 | 32 | +| +| version | uint32 | 254 | 0 | 4 | +| +| minGuardians | uint32 | 254 | 4 | 4 | +| +| provingAutoPauseEnabled | bool | 254 | 8 | 1 | +| +| latestProofHash | mapping(uint256 => mapping(uint256 => bytes32)) | 255 | 0 | 32 | +| +| __gap | uint256[45] | 256 | 0 | 1440 | ╰-------------------------+-------------------------------------------------+------+--------+-------+------------------------------------------------------------╯ ## ForkManager ╭---------------+-------------+------+--------+-------+---------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=========================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ForkManager | -|---------------+-------------+------+--------+-------+---------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ForkManager | -|---------------+-------------+------+--------+-------+---------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ForkManager | -|---------------+-------------+------+--------+-------+---------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ForkManager | -|---------------+-------------+------+--------+-------+---------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ForkManager | -|---------------+-------------+------+--------+-------+---------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ForkManager | -|---------------+-------------+------+--------+-------+---------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ForkManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | ╰---------------+-------------+------+--------+-------+---------------------------------------------------╯ diff --git a/packages/protocol/contract_layout_layer2.md b/packages/protocol/contract_layout_layer2.md index 661a1d4c2a9..fd6476114df 100644 --- a/packages/protocol/contract_layout_layer2.md +++ b/packages/protocol/contract_layout_layer2.md @@ -1,844 +1,844 @@ ## ERC1155Vault ╭--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[48] | 303 | 0 | 1536 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 351 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 401 | 0 | 1600 | ERC1155Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 451 | 0 | 1600 | ERC1155Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| __gap | uint256[48] | 303 | 0 | 1536 | +| +| __gap | uint256[50] | 351 | 0 | 1600 | +| +| __gap | uint256[50] | 401 | 0 | 1600 | +| +| __gap | uint256[50] | 451 | 0 | 1600 | ╰--------------------+------------------------------------------------------+------+--------+-------+-----------------------------------------------------------╯ ## ERC20Vault ╭--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct ERC20Vault.CanonicalERC20) | 301 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| btokenDenylist | mapping(address => bool) | 303 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| lastMigrationStart | mapping(uint256 => mapping(address => uint256)) | 304 | 0 | 32 | ERC20Vault | -|--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[46] | 305 | 0 | 1472 | ERC20Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct ERC20Vault.CanonicalERC20) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| btokenDenylist | mapping(address => bool) | 303 | 0 | 32 | +| +| lastMigrationStart | mapping(uint256 => mapping(address => uint256)) | 304 | 0 | 32 | +| +| __gap | uint256[46] | 305 | 0 | 1472 | ╰--------------------+------------------------------------------------------+------+--------+-------+-------------------------------------------------------╯ ## ERC721Vault ╭--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[48] | 303 | 0 | 1536 | ERC721Vault | -|--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 351 | 0 | 1600 | ERC721Vault | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| bridgedToCanonical | mapping(address => struct BaseNFTVault.CanonicalNFT) | 301 | 0 | 32 | +| +| canonicalToBridged | mapping(uint256 => mapping(address => address)) | 302 | 0 | 32 | +| +| __gap | uint256[48] | 303 | 0 | 1536 | +| +| __gap | uint256[50] | 351 | 0 | 1600 | ╰--------------------+------------------------------------------------------+------+--------+-------+---------------------------------------------------------╯ ## BridgedERC20 ╭------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _balances | mapping(address => uint256) | 251 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _totalSupply | uint256 | 253 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _name | string | 254 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _symbol | string | 255 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[45] | 256 | 0 | 1440 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| srcToken | address | 301 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __srcDecimals | uint8 | 301 | 20 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| srcChainId | uint256 | 302 | 0 | 32 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| migratingAddress | address | 303 | 0 | 20 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| migratingInbound | bool | 303 | 20 | 1 | BridgedERC20 | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[47] | 304 | 0 | 1504 | BridgedERC20 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _balances | mapping(address => uint256) | 251 | 0 | 32 | +| +| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | +| +| _totalSupply | uint256 | 253 | 0 | 32 | +| +| _name | string | 254 | 0 | 32 | +| +| _symbol | string | 255 | 0 | 32 | +| +| __gap | uint256[45] | 256 | 0 | 1440 | +| +| srcToken | address | 301 | 0 | 20 | +| +| __srcDecimals | uint8 | 301 | 20 | 1 | +| +| srcChainId | uint256 | 302 | 0 | 32 | +| +| migratingAddress | address | 303 | 0 | 20 | +| +| migratingInbound | bool | 303 | 20 | 1 | +| +| __gap | uint256[47] | 304 | 0 | 1504 | ╰------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╯ ## BridgedERC20V2 ╭------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _balances | mapping(address => uint256) | 251 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _totalSupply | uint256 | 253 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _name | string | 254 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _symbol | string | 255 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[45] | 256 | 0 | 1440 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcToken | address | 301 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __srcDecimals | uint8 | 301 | 20 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcChainId | uint256 | 302 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| migratingAddress | address | 303 | 0 | 20 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| migratingInbound | bool | 303 | 20 | 1 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[47] | 304 | 0 | 1504 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _hashedName | bytes32 | 351 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _hashedVersion | bytes32 | 352 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _name | string | 353 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _version | string | 354 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[48] | 355 | 0 | 1536 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | BridgedERC20V2 | -|------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 404 | 0 | 1568 | BridgedERC20V2 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _balances | mapping(address => uint256) | 251 | 0 | 32 | +| +| _allowances | mapping(address => mapping(address => uint256)) | 252 | 0 | 32 | +| +| _totalSupply | uint256 | 253 | 0 | 32 | +| +| _name | string | 254 | 0 | 32 | +| +| _symbol | string | 255 | 0 | 32 | +| +| __gap | uint256[45] | 256 | 0 | 1440 | +| +| srcToken | address | 301 | 0 | 20 | +| +| __srcDecimals | uint8 | 301 | 20 | 1 | +| +| srcChainId | uint256 | 302 | 0 | 32 | +| +| migratingAddress | address | 303 | 0 | 20 | +| +| migratingInbound | bool | 303 | 20 | 1 | +| +| __gap | uint256[47] | 304 | 0 | 1504 | +| +| _hashedName | bytes32 | 351 | 0 | 32 | +| +| _hashedVersion | bytes32 | 352 | 0 | 32 | +| +| _name | string | 353 | 0 | 32 | +| +| _version | string | 354 | 0 | 32 | +| +| __gap | uint256[48] | 355 | 0 | 1536 | +| +| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | +| +| __gap | uint256[49] | 404 | 0 | 1568 | ╰------------------+--------------------------------------------------------+------+--------+-------+---------------------------------------------------------------╯ ## BridgedERC721 ╭--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _name | string | 301 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _symbol | string | 302 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _owners | mapping(uint256 => address) | 303 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _balances | mapping(address => uint256) | 304 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _tokenApprovals | mapping(uint256 => address) | 305 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| _operatorApprovals | mapping(address => mapping(address => bool)) | 306 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[44] | 307 | 0 | 1408 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| srcToken | address | 351 | 0 | 20 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| srcChainId | uint256 | 352 | 0 | 32 | BridgedERC721 | -|--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[48] | 353 | 0 | 1536 | BridgedERC721 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| _name | string | 301 | 0 | 32 | +| +| _symbol | string | 302 | 0 | 32 | +| +| _owners | mapping(uint256 => address) | 303 | 0 | 32 | +| +| _balances | mapping(address => uint256) | 304 | 0 | 32 | +| +| _tokenApprovals | mapping(uint256 => address) | 305 | 0 | 32 | +| +| _operatorApprovals | mapping(address => mapping(address => bool)) | 306 | 0 | 32 | +| +| __gap | uint256[44] | 307 | 0 | 1408 | +| +| srcToken | address | 351 | 0 | 20 | +| +| srcChainId | uint256 | 352 | 0 | 32 | +| +| __gap | uint256[48] | 353 | 0 | 1536 | ╰--------------------+----------------------------------------------+------+--------+-------+-------------------------------------------------------------╯ ## BridgedERC1155 ╭--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==============================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[50] | 251 | 0 | 1600 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _balances | mapping(uint256 => mapping(address => uint256)) | 301 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _operatorApprovals | mapping(address => mapping(address => bool)) | 302 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| _uri | string | 303 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[47] | 304 | 0 | 1504 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcToken | address | 351 | 0 | 20 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| srcChainId | uint256 | 352 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| symbol | string | 353 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| name | string | 354 | 0 | 32 | BridgedERC1155 | -|--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------| -| __gap | uint256[46] | 355 | 0 | 1472 | BridgedERC1155 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __gap | uint256[50] | 251 | 0 | 1600 | +| +| _balances | mapping(uint256 => mapping(address => uint256)) | 301 | 0 | 32 | +| +| _operatorApprovals | mapping(address => mapping(address => bool)) | 302 | 0 | 32 | +| +| _uri | string | 303 | 0 | 32 | +| +| __gap | uint256[47] | 304 | 0 | 1504 | +| +| srcToken | address | 351 | 0 | 20 | +| +| srcChainId | uint256 | 352 | 0 | 32 | +| +| symbol | string | 353 | 0 | 32 | +| +| name | string | 354 | 0 | 32 | +| +| __gap | uint256[46] | 355 | 0 | 1472 | ╰--------------------+-------------------------------------------------+------+--------+-------+---------------------------------------------------------------╯ ## Bridge ╭------------------+-----------------------------------------+------+--------+-------+-------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| _owner | address | 51 | 0 | 20 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| addressManager | address | 151 | 0 | 20 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reserved1 | uint64 | 251 | 0 | 8 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| nextMessageId | uint64 | 251 | 8 | 8 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| messageStatus | mapping(bytes32 => enum IBridge.Status) | 252 | 0 | 32 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __ctx | struct IBridge.Context | 253 | 0 | 64 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reserved2 | uint256 | 255 | 0 | 32 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __reserved3 | uint256 | 256 | 0 | 32 | Bridge | -|------------------+-----------------------------------------+------+--------+-------+-------------------------------------------| -| __gap | uint256[44] | 257 | 0 | 1408 | Bridge | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __reserved1 | uint64 | 251 | 0 | 8 | +| +| nextMessageId | uint64 | 251 | 8 | 8 | +| +| messageStatus | mapping(bytes32 => enum IBridge.Status) | 252 | 0 | 32 | +| +| __ctx | struct IBridge.Context | 253 | 0 | 64 | +| +| __reserved2 | uint256 | 255 | 0 | 32 | +| +| __reserved3 | uint256 | 256 | 0 | 32 | +| +| __gap | uint256[44] | 257 | 0 | 1408 | ╰------------------+-----------------------------------------+------+--------+-------+-------------------------------------------╯ ## QuotaManager ╭------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| tokenQuota | mapping(address => struct QuotaManager.Quota) | 251 | 0 | 32 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| quotaPeriod | uint24 | 252 | 0 | 3 | QuotaManager | -|------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | QuotaManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| tokenQuota | mapping(address => struct QuotaManager.Quota) | 251 | 0 | 32 | +| +| quotaPeriod | uint24 | 252 | 0 | 3 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+-----------------------------------------------+------+--------+-------+-------------------------------------------------------╯ ## AddressManager ╭------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +========================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | AddressManager | -|------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------| -| __gap | uint256[49] | 252 | 0 | 1568 | AddressManager | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __addresses | mapping(uint256 => mapping(bytes32 => address)) | 251 | 0 | 32 | +| +| __gap | uint256[49] | 252 | 0 | 1568 | ╰------------------+-------------------------------------------------+------+--------+-------+-----------------------------------------------------------╯ ## AddressResolver ╭----------------+-------------+------+--------+-------+-------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +====================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | AddressResolver | -|----------------+-------------+------+--------+-------+-------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | AddressResolver | -|----------------+-------------+------+--------+-------+-------------------------------------------------------------| -| addressManager | address | 0 | 2 | 20 | AddressResolver | -|----------------+-------------+------+--------+-------+-------------------------------------------------------------| -| __gap | uint256[49] | 1 | 0 | 1568 | AddressResolver | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| addressManager | address | 0 | 2 | 20 | +| +| __gap | uint256[49] | 1 | 0 | 1568 | ╰----------------+-------------+------+--------+-------+-------------------------------------------------------------╯ ## EssentialContract ╭------------------+-------------+------+--------+-------+-----------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==========================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | EssentialContract | -|------------------+-------------+------+--------+-------+-----------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | EssentialContract | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | ╰------------------+-------------+------+--------+-------+-----------------------------------------------------------------╯ ## SignalService ╭------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +====================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| topBlockId | mapping(uint64 => mapping(bytes32 => uint64)) | 251 | 0 | 32 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| isAuthorized | mapping(address => bool) | 252 | 0 | 32 | SignalService | -|------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | SignalService | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| topBlockId | mapping(uint64 => mapping(bytes32 => uint64)) | 251 | 0 | 32 | +| +| isAuthorized | mapping(address => bool) | 252 | 0 | 32 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+-----------------------------------------------+------+--------+-------+---------------------------------------------------------╯ ## BridgedTaikoToken ╭-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +==============================================================================================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __slots_previously_used_by_ERC20SnapshotUpgradeable | uint256[50] | 251 | 0 | 1600 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _balances | mapping(address => uint256) | 301 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _allowances | mapping(address => mapping(address => uint256)) | 302 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _totalSupply | uint256 | 303 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _name | string | 304 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _symbol | string | 305 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[45] | 306 | 0 | 1440 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _hashedName | bytes32 | 351 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _hashedVersion | bytes32 | 352 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _name | string | 353 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _version | string | 354 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[48] | 355 | 0 | 1536 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _PERMIT_TYPEHASH_DEPRECATED_SLOT | bytes32 | 404 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[49] | 405 | 0 | 1568 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _delegates | mapping(address => address) | 454 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _checkpoints | mapping(address => struct ERC20VotesUpgradeable.Checkpoint[]) | 455 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| _totalSupplyCheckpoints | struct ERC20VotesUpgradeable.Checkpoint[] | 456 | 0 | 32 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[47] | 457 | 0 | 1504 | BridgedTaikoToken | -|-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------| -| __gap | uint256[50] | 504 | 0 | 1600 | BridgedTaikoToken | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| __slots_previously_used_by_ERC20SnapshotUpgradeable | uint256[50] | 251 | 0 | 1600 | +| +| _balances | mapping(address => uint256) | 301 | 0 | 32 | +| +| _allowances | mapping(address => mapping(address => uint256)) | 302 | 0 | 32 | +| +| _totalSupply | uint256 | 303 | 0 | 32 | +| +| _name | string | 304 | 0 | 32 | +| +| _symbol | string | 305 | 0 | 32 | +| +| __gap | uint256[45] | 306 | 0 | 1440 | +| +| _hashedName | bytes32 | 351 | 0 | 32 | +| +| _hashedVersion | bytes32 | 352 | 0 | 32 | +| +| _name | string | 353 | 0 | 32 | +| +| _version | string | 354 | 0 | 32 | +| +| __gap | uint256[48] | 355 | 0 | 1536 | +| +| _nonces | mapping(address => struct CountersUpgradeable.Counter) | 403 | 0 | 32 | +| +| _PERMIT_TYPEHASH_DEPRECATED_SLOT | bytes32 | 404 | 0 | 32 | +| +| __gap | uint256[49] | 405 | 0 | 1568 | +| +| _delegates | mapping(address => address) | 454 | 0 | 32 | +| +| _checkpoints | mapping(address => struct ERC20VotesUpgradeable.Checkpoint[]) | 455 | 0 | 32 | +| +| _totalSupplyCheckpoints | struct ERC20VotesUpgradeable.Checkpoint[] | 456 | 0 | 32 | +| +| __gap | uint256[47] | 457 | 0 | 1504 | +| +| __gap | uint256[50] | 504 | 0 | 1600 | ╰-----------------------------------------------------+---------------------------------------------------------------+------+--------+-------+----------------------------------------------------------------╯ ## DelegateOwner ╭------------------+-------------+------+--------+-------+--------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===========================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| _owner | address | 51 | 0 | 20 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| remoteChainId | uint64 | 251 | 0 | 8 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| admin | address | 251 | 8 | 20 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| nextTxId | uint64 | 252 | 0 | 8 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| remoteOwner | address | 252 | 8 | 20 | DelegateOwner | -|------------------+-------------+------+--------+-------+--------------------------------------------------| -| __gap | uint256[48] | 253 | 0 | 1536 | DelegateOwner | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| remoteChainId | uint64 | 251 | 0 | 8 | +| +| admin | address | 251 | 8 | 20 | +| +| nextTxId | uint64 | 252 | 0 | 8 | +| +| remoteOwner | address | 252 | 8 | 20 | +| +| __gap | uint256[48] | 253 | 0 | 1536 | ╰------------------+-------------+------+--------+-------+--------------------------------------------------╯ ## TaikoL2 ╭------------------+-----------------------------+------+--------+-------+--------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=====================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| _owner | address | 51 | 0 | 20 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| addressManager | address | 151 | 0 | 20 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| _blockhashes | mapping(uint256 => bytes32) | 251 | 0 | 32 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| publicInputHash | bytes32 | 252 | 0 | 32 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| parentGasExcess | uint64 | 253 | 0 | 8 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| lastSyncedBlock | uint64 | 253 | 8 | 8 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| parentTimestamp | uint64 | 253 | 16 | 8 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| parentGasTarget | uint64 | 253 | 24 | 8 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| l1ChainId | uint64 | 254 | 0 | 8 | TaikoL2 | -|------------------+-----------------------------+------+--------+-------+--------------------------------------------| -| __gap | uint256[46] | 255 | 0 | 1472 | TaikoL2 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _blockhashes | mapping(uint256 => bytes32) | 251 | 0 | 32 | +| +| publicInputHash | bytes32 | 252 | 0 | 32 | +| +| parentGasExcess | uint64 | 253 | 0 | 8 | +| +| lastSyncedBlock | uint64 | 253 | 8 | 8 | +| +| parentTimestamp | uint64 | 253 | 16 | 8 | +| +| parentGasTarget | uint64 | 253 | 24 | 8 | +| +| l1ChainId | uint64 | 254 | 0 | 8 | +| +| __gap | uint256[46] | 255 | 0 | 1472 | ╰------------------+-----------------------------+------+--------+-------+--------------------------------------------╯ ## HeklaTaikoL2 ╭------------------+-----------------------------+------+--------+-------+------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +===============================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| _blockhashes | mapping(uint256 => bytes32) | 251 | 0 | 32 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| publicInputHash | bytes32 | 252 | 0 | 32 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| parentGasExcess | uint64 | 253 | 0 | 8 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| lastSyncedBlock | uint64 | 253 | 8 | 8 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| parentTimestamp | uint64 | 253 | 16 | 8 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| parentGasTarget | uint64 | 253 | 24 | 8 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| l1ChainId | uint64 | 254 | 0 | 8 | HeklaTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------| -| __gap | uint256[46] | 255 | 0 | 1472 | HeklaTaikoL2 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _blockhashes | mapping(uint256 => bytes32) | 251 | 0 | 32 | +| +| publicInputHash | bytes32 | 252 | 0 | 32 | +| +| parentGasExcess | uint64 | 253 | 0 | 8 | +| +| lastSyncedBlock | uint64 | 253 | 8 | 8 | +| +| parentTimestamp | uint64 | 253 | 16 | 8 | +| +| parentGasTarget | uint64 | 253 | 24 | 8 | +| +| l1ChainId | uint64 | 254 | 0 | 8 | +| +| __gap | uint256[46] | 255 | 0 | 1472 | ╰------------------+-----------------------------+------+--------+-------+------------------------------------------------------╯ ## MainnetTaikoL2 ╭------------------+-----------------------------+------+--------+-------+------------------------------------------------------------╮ -| Name | Type | Slot | Offset | Bytes | Contract | +| Name | Type | Slot | Offset | Bytes | +=====================================================================================================================================+ -| _initialized | uint8 | 0 | 0 | 1 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| _initializing | bool | 0 | 1 | 1 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[50] | 1 | 0 | 1600 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| _owner | address | 51 | 0 | 20 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 52 | 0 | 1568 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| _pendingOwner | address | 101 | 0 | 20 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 102 | 0 | 1568 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| addressManager | address | 151 | 0 | 20 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 152 | 0 | 1568 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __reentry | uint8 | 201 | 0 | 1 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __paused | uint8 | 201 | 1 | 1 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __lastUnpausedAt | uint64 | 201 | 2 | 8 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[49] | 202 | 0 | 1568 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| _blockhashes | mapping(uint256 => bytes32) | 251 | 0 | 32 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| publicInputHash | bytes32 | 252 | 0 | 32 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| parentGasExcess | uint64 | 253 | 0 | 8 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| lastSyncedBlock | uint64 | 253 | 8 | 8 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| parentTimestamp | uint64 | 253 | 16 | 8 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| parentGasTarget | uint64 | 253 | 24 | 8 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| l1ChainId | uint64 | 254 | 0 | 8 | MainnetTaikoL2 | -|------------------+-----------------------------+------+--------+-------+------------------------------------------------------------| -| __gap | uint256[46] | 255 | 0 | 1472 | MainnetTaikoL2 | +| _initialized | uint8 | 0 | 0 | 1 | +| +| _initializing | bool | 0 | 1 | 1 | +| +| __gap | uint256[50] | 1 | 0 | 1600 | +| +| _owner | address | 51 | 0 | 20 | +| +| __gap | uint256[49] | 52 | 0 | 1568 | +| +| _pendingOwner | address | 101 | 0 | 20 | +| +| __gap | uint256[49] | 102 | 0 | 1568 | +| +| addressManager | address | 151 | 0 | 20 | +| +| __gap | uint256[49] | 152 | 0 | 1568 | +| +| __reentry | uint8 | 201 | 0 | 1 | +| +| __paused | uint8 | 201 | 1 | 1 | +| +| __lastUnpausedAt | uint64 | 201 | 2 | 8 | +| +| __gap | uint256[49] | 202 | 0 | 1568 | +| +| _blockhashes | mapping(uint256 => bytes32) | 251 | 0 | 32 | +| +| publicInputHash | bytes32 | 252 | 0 | 32 | +| +| parentGasExcess | uint64 | 253 | 0 | 8 | +| +| lastSyncedBlock | uint64 | 253 | 8 | 8 | +| +| parentTimestamp | uint64 | 253 | 16 | 8 | +| +| parentGasTarget | uint64 | 253 | 24 | 8 | +| +| l1ChainId | uint64 | 254 | 0 | 8 | +| +| __gap | uint256[46] | 255 | 0 | 1472 | ╰------------------+-----------------------------+------+--------+-------+------------------------------------------------------------╯ diff --git a/packages/protocol/script/gen-layouts.sh b/packages/protocol/script/gen-layouts.sh index a6a774285b4..f3e74433b8d 100755 --- a/packages/protocol/script/gen-layouts.sh +++ b/packages/protocol/script/gen-layouts.sh @@ -92,7 +92,7 @@ for contract in "${contracts[@]}"; do echo "inspect ${contract}" echo "## ${contract}" >> $output_file - FOUNDRY_PROFILE=${profile} forge inspect -C ./contracts/${profile} -o ./out/${profile} ${contract} storagelayout --pretty >> $output_file + FORGE_DISPLAY=plain FOUNDRY_PROFILE=${profile} forge inspect -C ./contracts/${profile} -o ./out/${profile} ${contract} storagelayout --pretty >> $output_file echo "" >> $output_file done @@ -103,3 +103,11 @@ if [[ "$(uname -s)" == "Darwin" ]]; then else sed -i "$sed_pattern" "$output_file" fi + +# Use awk to remove the last column and write to a temporary file +temp_file="${output_file}_temp" +while IFS= read -r line; do + # Remove everything behind the second-to-last "|" + echo "$line" | sed -E 's/\|[^|]*\|[^|]*$/|/' +done < "$output_file" > "$temp_file" +mv "$temp_file" "$output_file" \ No newline at end of file From 08b2c49f19b25643b4570642d1612b15d5d71290 Mon Sep 17 00:00:00 2001 From: swarna1101 Date: Mon, 23 Dec 2024 22:18:20 +0530 Subject: [PATCH 13/29] feat(docs-site): add doc for SGX Verifier. (#18579) --- packages/docs-site/astro.config.ts | 1 + .../codebase-analysis/sgxverifier-contract.md | 108 ++++++++++++++++++ 2 files changed, 109 insertions(+) create mode 100644 packages/docs-site/src/content/docs/taiko-protocol/codebase-analysis/sgxverifier-contract.md diff --git a/packages/docs-site/astro.config.ts b/packages/docs-site/astro.config.ts index 71087619c0d..0c4eeda19e7 100644 --- a/packages/docs-site/astro.config.ts +++ b/packages/docs-site/astro.config.ts @@ -92,6 +92,7 @@ export default defineConfig({ items: [ {label: "TaikoL1 Contract", link: "/taiko-protocol/codebase-analysis/taikol1-contract"}, {label: "TaikoL2 Contract", link: "/taiko-protocol/codebase-analysis/taikol2-contract"}, + {label: "SGXVerifier Contract", link: "/taiko-protocol/codebase-analysis/sgxverifier-contract"}, ], }, { label: "Block states", link: "/taiko-protocol/block-states" }, diff --git a/packages/docs-site/src/content/docs/taiko-protocol/codebase-analysis/sgxverifier-contract.md b/packages/docs-site/src/content/docs/taiko-protocol/codebase-analysis/sgxverifier-contract.md new file mode 100644 index 00000000000..3f9c832fb4d --- /dev/null +++ b/packages/docs-site/src/content/docs/taiko-protocol/codebase-analysis/sgxverifier-contract.md @@ -0,0 +1,108 @@ +--- +title: SGXVerifier +description: Taiko protocol page for "SGXVerifier.sol". +--- + +The `SGXVerifier` smart contract implements SGX (Software Guard Extensions) signature proof verification on-chain. This verification ensures integrity and security of rollup state transitions by validating SGX-generated signatures. It also enables management and tracking of SGX instances through registration and replacement. + +--- + +## Core Purpose + +1. **Instance Registry**: + +- Each SGX instance is uniquely identified by its Ethereum address (derived from an ECDSA public-private key pair generated in the SGX enclave). +- The registry ensures: + - Only valid instances are allowed. + - Instances are valid for a predefined duration (`INSTANCE_EXPIRY`). + +2. **Instance Lifecycle**: + +- **Addition**: SGX instances can be added via the `addInstances` function or the `registerInstance` method (following attestation verification). +- **Replacement**: Old SGX instances can be replaced with new ones to maintain security. +- **Deletion**: Instances can be removed using the `deleteInstances` function. + +--- + +## Key Functions + +### `addInstances` + +- **Purpose**: Adds new SGX instances to the registry. +- **Input**: + - `_instances`: Array of Ethereum addresses corresponding to the SGX instances. +- **Output**: Returns an array of assigned instance IDs. +- **Access Control**: Restricted to the owner. + +--- + +### `deleteInstances` + +- **Purpose**: Removes SGX instances from the registry. +- **Input**: + - `_ids`: Array of instance IDs to be removed. +- **Access Control**: Restricted to the owner or the `SGX_WATCHDOG` role. + +--- + +### `registerInstance` + +- **Purpose**: Registers an SGX instance by verifying its attestation off-chain and adding it to the registry. +- **Input**: + - `_attestation`: Parsed attestation quote containing SGX enclave report details. +- **Output**: Returns the assigned instance ID. +- **Access Control**: Open to external calls. + +--- + +### `verifyProof` + +- **Purpose**: Validates the SGX signature proof for a single block state transition. +- **Input**: + - `_ctx`: Context of the proof. + - `_tran`: Transition data. + - `_proof`: SGX signature proof. +- **Mechanism**: + - Validates the instance ID and signature. + - Ensures the SGX instance is valid and replaces it if needed. + +--- + +### `verifyBatchProof` + +- **Purpose**: Validates SGX signature proofs for multiple block state transitions in a batch. +- **Input**: + - `_ctxs`: Array of contexts for the batch. + - `_proof`: SGX batch signature proof. +- **Mechanism**: + - Verifies the signature against public inputs for all blocks. + - Replaces the SGX instance if necessary. + +--- + +## Key Events + +1. **`InstanceAdded`**: + +- Emitted when a new SGX instance is added or an old instance is replaced. +- Parameters: + - `id`: ID of the SGX instance. + - `instance`: Address of the new SGX instance. + - `replaced`: Address of the replaced instance (if any). + - `validSince`: Timestamp indicating when the instance became valid. + +2. **`InstanceDeleted`**: + +- Emitted when an SGX instance is removed from the registry. +- Parameters: + - `id`: ID of the SGX instance. + - `instance`: Address of the removed instance. + +--- + +## Constants + +1. **`INSTANCE_EXPIRY`**: Duration (365 days) for which an SGX instance remains valid. +2. **`INSTANCE_VALIDITY_DELAY`**: Delay before an SGX instance becomes valid after registration. + +--- From 44c4d358ab5c5311554e7f643201e580fa966458 Mon Sep 17 00:00:00 2001 From: taiko-bot <160625009+taiko-kitty@users.noreply.github.com> Date: Mon, 23 Dec 2024 08:52:11 -0800 Subject: [PATCH 14/29] chore(main): release docs-site 1.21.0 (#18592) --- .release-please-manifest.json | 2 +- packages/docs-site/CHANGELOG.md | 20 ++++++++++++++++++++ packages/docs-site/package.json | 2 +- 3 files changed, 22 insertions(+), 2 deletions(-) diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 4cdffaa51c7..1a80f9fb51f 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -1,6 +1,6 @@ { "packages/bridge-ui": "2.13.0", - "packages/docs-site": "1.20.3", + "packages/docs-site": "1.21.0", "packages/eventindexer": "0.13.0", "packages/fork-diff": "0.6.1", "packages/guardian-prover-health-check": "0.1.0", diff --git a/packages/docs-site/CHANGELOG.md b/packages/docs-site/CHANGELOG.md index e6d11b67417..d06f345cc23 100644 --- a/packages/docs-site/CHANGELOG.md +++ b/packages/docs-site/CHANGELOG.md @@ -1,5 +1,25 @@ # Changelog +## [1.21.0](https://github.com/taikoxyz/taiko-mono/compare/docs-site-v1.20.3...docs-site-v1.21.0) (2024-12-23) + + +### Features + +* **docs-site:** add doc for SGX Verifier. ([#18579](https://github.com/taikoxyz/taiko-mono/issues/18579)) ([08b2c49](https://github.com/taikoxyz/taiko-mono/commit/08b2c49f19b25643b4570642d1612b15d5d71290)) + + +### Chores + +* **docs-site:** fix broken link ([#18585](https://github.com/taikoxyz/taiko-mono/issues/18585)) ([38bbb55](https://github.com/taikoxyz/taiko-mono/commit/38bbb55dc076a03751871dde5d61729282a68d9a)) +* **docs-site:** fix typos in node operator guides ([#18586](https://github.com/taikoxyz/taiko-mono/issues/18586)) ([b4bd23c](https://github.com/taikoxyz/taiko-mono/commit/b4bd23ca0798ab239730765a4ca1d8e49ef6e52e)) +* **docs-site:** update proof tier graphic ([#18617](https://github.com/taikoxyz/taiko-mono/issues/18617)) ([becffb7](https://github.com/taikoxyz/taiko-mono/commit/becffb7cc81c6f17436985a81750a5eef7f980e1)) + + +### Build + +* **deps:** bump github.com/stretchr/testify from 1.9.0 to 1.10.0 ([#18539](https://github.com/taikoxyz/taiko-mono/issues/18539)) ([79f3fab](https://github.com/taikoxyz/taiko-mono/commit/79f3fab5f1d1ec1bb4ee18afb9268b622e894780)) +* **deps:** bump golang.org/x/sync from 0.9.0 to 0.10.0 ([#18560](https://github.com/taikoxyz/taiko-mono/issues/18560)) ([3d51970](https://github.com/taikoxyz/taiko-mono/commit/3d51970aa0953bbfecaeebf76ea7e664c875c0e4)) + ## [1.20.3](https://github.com/taikoxyz/taiko-mono/compare/docs-site-v1.20.2...docs-site-v1.20.3) (2024-12-09) diff --git a/packages/docs-site/package.json b/packages/docs-site/package.json index 1328c3be706..de59304b68e 100644 --- a/packages/docs-site/package.json +++ b/packages/docs-site/package.json @@ -1,7 +1,7 @@ { "name": "docs-site", "type": "module", - "version": "1.20.3", + "version": "1.21.0", "scripts": { "dev": "astro dev", "start": "astro dev", From eb542bf67dea51fd42c0f5c40ee987e5acadc3fd Mon Sep 17 00:00:00 2001 From: David Date: Tue, 24 Dec 2024 10:48:47 +0800 Subject: [PATCH 15/29] docs(protocol): update mainnet deployment docs (#18621) --- .../deployments/mainnet-contract-logs-L1.md | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/packages/protocol/deployments/mainnet-contract-logs-L1.md b/packages/protocol/deployments/mainnet-contract-logs-L1.md index e084844b82d..feb4fddbf2b 100644 --- a/packages/protocol/deployments/mainnet-contract-logs-L1.md +++ b/packages/protocol/deployments/mainnet-contract-logs-L1.md @@ -175,14 +175,14 @@ - ens: `ram.based.taiko.eth` - proxy: `0x579f40D0BE111b823962043702cabe6Aaa290780` -- impl: `0x52CA3c5566d779b3c6bb5c4f760Ea39E294Fc788` +- impl: `0x0079a79E5d8DDA67029051d505E5A11DE279B36D` - names: - bond_token: `0x10dea67478c5F8C5E2D90e5E9B26dBe60c54d800` - taiko_token: `0x10dea67478c5F8C5E2D90e5E9B26dBe60c54d800` - signal_service: `0x9e0a24964e5397B566c1ed39258e21aB5E35C77C` - bridge: `0xd60247c6848B7Ca29eDdF63AA924E53dB6Ddd8EC` - taiko: `0x06a9Ab27c7e2255df1815E6CC0168d7755Feb19a` - - tier_router: `0x394E30d83d020469a1F8b16E89D7fD5FdB1935b0` + - tier_router: `0x8a4c692F12d3a9750E744A4CE24a1d351bE52E66` - tier_sgx: `0xb0f3186FC1963f774f52ff455DC86aEdD0b31F81` - risc0_groth16_verifier: `0xcF706D99C265fC2349AE43c5f6BFD7931FE5308D` - tier_zkvm_risc0: `0x55902b2D3DF2A65370A89C86Ae9dd71Ecd508edc` @@ -217,12 +217,13 @@ - upgraded from `0x3202Fc255aE09F91DbbD5b000b87dA4A2E04eE37` to `0x190D5d50D98D2202a618f75B2fD9986e60E096be` @commit`4fd7b59` @tx`0xf26d0526aa4b8225c603720ce0dc016803188b959c50677d5446087d1f2c4e60` - upgraded from `0x190D5d50D98D2202a618f75B2fD9986e60E096be` to `0x6D8e6e1a061791AD17A55De5e15a111c58f6Fb3D` @commit`2625c60` @tx`0x5d46840df79d8df508880675e7ea549e9b46137f597ca520c3e0c979439441d1` - upgraded from `0x6D8e6e1a061791AD17A55De5e15a111c58f6Fb3D` to `0x52CA3c5566d779b3c6bb5c4f760Ea39E294Fc788` @commit`9ae9a5e` @tx`0x43353a74df973d8f6a379b5c8815ac80935a5099f8ab93a4aa204eb5ef2c663e` + - upgraded from `0x52CA3c5566d779b3c6bb5c4f760Ea39E294Fc788` to `0x0079a79E5d8DDA67029051d505E5A11DE279B36D` @commit`06128e8` @tx`0xe66aba9f8bfcd86dc0ae32416862ca61a51c47f8ec747799e65f155ef27eeb20` #### taikoL1 - ens: `based.taiko.eth` - proxy: `0x06a9Ab27c7e2255df1815E6CC0168d7755Feb19a` -- impl: `0xe7c4B445D3C7C8E4D68afb85A068F9fAa18e9A5B` +- impl: `0xd4896d4537c6425aC5d89B9f122d4E4ac4D65e1c` - owner: `admin.taiko.eth` - logs: - deployed on May 1, 2024 @commit`56dddf2b6` @@ -243,16 +244,19 @@ - Upgrade to `0x4229d14F520848aa83760Cf748abEB8A69cdaB2d` @commit`9345f14` @tx`0x13ea4d044a313cf667d16514465e6b96227ef7198bda7b19c70eefee44e9bccd` - Upgrade to `0xA3E75eDA1Be2114816f388A5cF53EbA142DCDB17` @commit`ea0158f` @tx`0x78ca7c7d9c7e5aa9c5e6ab80e0229289a8d3bc8df2c2b9ba6baa74a0f60a0703` - Upgrade to `0xe7c4B445D3C7C8E4D68afb85A068F9fAa18e9A5B` @commit`ea0158f` with new `RollupAddressManagerCache` @commit `9ae9a5e` @tx`0x5eb57ab352b3e3c1ddbc3fe468d582901b88c6a137ce49b0d70857d5218d626d` + - Upgrade to `0xb74A66b6CF50AD63E29669F0BDE4354E11758162` @commit`06128e8` @tx`0xe66aba9f8bfcd86dc0ae32416862ca61a51c47f8ec747799e65f155ef27eeb20` + - Upgrade to `0xd4896d4537c6425aC5d89B9f122d4E4ac4D65e1c` @commit`ea0158f` with new `RollupAddressManagerCache` @commit `7394458` @tx`0x9c2f36af40c0004110041fc45d980b73b0c8dde8064713a55aeb6f69fca77a99` #### tier_router -- impl: `0x394E30d83d020469a1F8b16E89D7fD5FdB1935b0` +- impl: `0x8a4c692F12d3a9750E744A4CE24a1d351bE52E66` - logs: - deployed on Oct 24, 2024 @commit`7334b1d` - deployed on Nov 1, 2024 @commit`f4f4796` - deployed on Nov 2, 2024 @commit`9182fba` - deployed on Nov 8, 2024 @commit`1fee7bb` without changes in [PR #18371](https://github.com/taikoxyz/taiko-mono/pull/18371) - deployed on Nov 10, 2024 @commit`f24a908` without changes in [PR #18371](https://github.com/taikoxyz/taiko-mono/pull/18371) + - deployed on Dec 20, 2024 @commit`06128e8` without changes in [PR #18371](https://github.com/taikoxyz/taiko-mono/pull/18371) #### tier_sgx @@ -395,7 +399,7 @@ - ens: `labprover.taiko.eth` - proxy: `0x68d30f47F19c07bCCEf4Ac7FAE2Dc12FCa3e0dC9` -- impl: `0x3022Ed0346CCE0c08268c8ad081458AfD95E8763` +- impl: `0xd0d3f025D83D7122de7eC43e86331C57c8A4F30B` - enabled provers: - `0x000000629FBCf27A347d1AEbA658435230D74a5f` - `0x000000633b68f5d8d3a86593ebb815b4663bcbe0` @@ -412,12 +416,13 @@ - upgraded from `0x518845daA8870bE2C59E49620Fc262AD48953C9a` to `0x74828E5fe803072AF9Df512B3911B4223572D652` @commit`bb2abc5` @tx`0xc1f91c375713f601b99cf6d2cdb80c129e036a7c9ec5f75871c4d13216dbbb5c` - upgraded from `0x74828E5fe803072AF9Df512B3911B4223572D652` to `0xCE5a119479337a153CA3bd1b2bF9755c78F2B15A` @commit`be34059` @tx`0x170617251f2345eda4bcbd29e316caa0b014602a44244c60b963382ac7da7748` - upgraded from `0xCE5a119479337a153CA3bd1b2bF9755c78F2B15A` to `0x3022Ed0346CCE0c08268c8ad081458AfD95E8763` @commit`9345f14` @tx`0x13ea4d044a313cf667d16514465e6b96227ef7198bda7b19c70eefee44e9bccd` + - upgraded from `0x3022Ed0346CCE0c08268c8ad081458AfD95E8763` to `0xd0d3f025D83D7122de7eC43e86331C57c8A4F30B` @commit`06128e8` @tx`0xe66aba9f8bfcd86dc0ae32416862ca61a51c47f8ec747799e65f155ef27eeb20` ### labcontester.taiko.eth - ens: `labcontester.taiko.eth` - proxy: `0xa01d464ca3982DAa97B19fa7F8a232eB11A9DDb3` -- impl: `0x3022Ed0346CCE0c08268c8ad081458AfD95E8763` +- impl: `0xd0d3f025D83D7122de7eC43e86331C57c8A4F30B` - enabled provers: - `0x00000027F51a57E7FcBC4b481d15fcE5BE68b30B` - logs: @@ -428,3 +433,4 @@ - upgraded from `0x518845daA8870bE2C59E49620Fc262AD48953C9a` to `0x74828E5fe803072AF9Df512B3911B4223572D652` @commit`bb2abc5` @tx`0xc1f91c375713f601b99cf6d2cdb80c129e036a7c9ec5f75871c4d13216dbbb5c` - upgraded from `0x74828E5fe803072AF9Df512B3911B4223572D652` to `0xCE5a119479337a153CA3bd1b2bF9755c78F2B15A` @commit`be34059` @tx`0x170617251f2345eda4bcbd29e316caa0b014602a44244c60b963382ac7da7748` - upgraded from `0xCE5a119479337a153CA3bd1b2bF9755c78F2B15A` to `0x3022Ed0346CCE0c08268c8ad081458AfD95E8763` @commit`9345f14` @tx`0x13ea4d044a313cf667d16514465e6b96227ef7198bda7b19c70eefee44e9bccd` + - upgraded from `0x3022Ed0346CCE0c08268c8ad081458AfD95E8763` to `0xd0d3f025D83D7122de7eC43e86331C57c8A4F30B` @commit`06128e8` @tx`0xe66aba9f8bfcd86dc0ae32416862ca61a51c47f8ec747799e65f155ef27eeb20` From 8e53a6e6a2654b8a599fe1df187e2fd88c22d96e Mon Sep 17 00:00:00 2001 From: dionysuz <13951458+dionysuzx@users.noreply.github.com> Date: Mon, 23 Dec 2024 21:58:07 -0500 Subject: [PATCH 16/29] chore(repo): fix broken links (#18635) --- .github/workflows/protocol-monitors.yml | 1 + .github/workflows/repo--check-links.yml | 20 ++++++++++ .github/workflows/taiko-client--test.yml | 1 + README.md | 40 +++++++++++-------- lychee.toml | 1 + .../software-releases-and-deployments.md | 10 ++--- packages/monitors/README.md | 3 ++ packages/taiko-client/README.md | 2 +- 8 files changed, 55 insertions(+), 23 deletions(-) create mode 100644 .github/workflows/repo--check-links.yml create mode 100644 lychee.toml create mode 100644 packages/monitors/README.md diff --git a/.github/workflows/protocol-monitors.yml b/.github/workflows/protocol-monitors.yml index ad640962afe..00c96440f94 100644 --- a/.github/workflows/protocol-monitors.yml +++ b/.github/workflows/protocol-monitors.yml @@ -5,6 +5,7 @@ on: types: [opened, synchronize, reopened, ready_for_review] paths: - "packages/monitors/**" + - "!packages/monitors/**/*.md" branches-ignore: - release-please--branches--** diff --git a/.github/workflows/repo--check-links.yml b/.github/workflows/repo--check-links.yml new file mode 100644 index 00000000000..b6a2af1050d --- /dev/null +++ b/.github/workflows/repo--check-links.yml @@ -0,0 +1,20 @@ +name: Check links + +on: + push: + paths: + - '**/README.md' + - docs/** + +jobs: + check-links: + runs-on: ubuntu-latest + + steps: + - name: Checkout repository + uses: actions/checkout@v4 + + - name: Check links + uses: lycheeverse/lychee-action@v2 + with: + args: --no-progress --verbose '**/README.md' diff --git a/.github/workflows/taiko-client--test.yml b/.github/workflows/taiko-client--test.yml index 69b5c0046cf..f83ff6ed172 100644 --- a/.github/workflows/taiko-client--test.yml +++ b/.github/workflows/taiko-client--test.yml @@ -7,6 +7,7 @@ on: - "packages/taiko-client/**" - "go.mod" - "go.sum" + - "!**/*.md" branches-ignore: - release-please--branches--** diff --git a/README.md b/README.md index 22b5ba5f8c8..991d0e3a23b 100644 --- a/README.md +++ b/README.md @@ -32,23 +32,29 @@ Get started with Taiko: ## Packages > [!TIP] -> Make sure your node is using the latest version tags for taiko-client and taiko-geth. Check out the [node releases page](https://docs.taiko.xyz/network-reference/node-releases)! - -| Package | Description | Release notes | -| :---------------------------------------------------------------------------- | :------------------------------------------------------ | :-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| [bridge-ui](./packages/bridge-ui) | Bridge UI. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=bridge-ui*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/bridge-ui/CHANGELOG.md) | -| [docs-site](./packages/docs-site) | End user documentation site. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=docs-site*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/docs-site/CHANGELOG.md) | -| [eventindexer](./packages/eventindexer) | Event indexer. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=eventindexer*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/eventindexer/CHANGELOG.md) | -| [fork-diff](./packages/fork-diff) | Fork diff page. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=fork-diff*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/fork-diff/CHANGELOG.md) | -| [guardian-prover-health-check](./packages/guardian-prover-health-check) | Guardian prover health check service. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=guardian-prover-health-check*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/guardian-prover-health-check/CHANGELOG.md) | -| [guardian-prover-health-check-ui](./packages/guardian-prover-health-check-ui) | Guardian prover health check UI. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=guardian-prover-health-check-ui*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/guardian-prover-health-check-ui/CHANGELOG.md) | -| [protocol](./packages/protocol) | Taiko protocol smart contracts. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=protocol*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/protocol/CHANGELOG.md) | -| [relayer](./packages/relayer) | Bridge backend relayer. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=relayer*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/relayer/CHANGELOG.md) | -| [snaefell-ui](./packages/snaefell-ui) | Snaefell UI. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=snaefell-ui*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/snaefell-ui/CHANGELOG.md) | -| [supplementary-contracts](./packages/supplementary-contracts) | Supplementary contracts not part of the Taiko protocol. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=supplementary-contracts*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/supplementary-contracts/CHANGELOG.md) | -| [taiko-client](./packages/taiko-client) | Taiko client implementation in Go. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=taiko-client*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/taiko-client/CHANGELOG.md) | -| [taikoon-ui](./packages/taikoon-ui) | Taikoon UI. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=taikoon-ui*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/taikoon-ui/CHANGELOG.md) | -| [ui-lib](./packages/ui-lib) | UI library. | [![GitHub Release](https://img.shields.io/github/v/release/taikoxyz/taiko-mono?filter=ui-lib*&label=)](https://github.com/taikoxyz/taiko-mono/blob/main/packages/ui-lib/CHANGELOG.md) | +> Make sure your node is using the latest version tags for taiko-client and taiko-geth. Check out the [node releases page](https://docs.taiko.xyz/network-reference/software-releases-and-deployments)! + +| Package | Description | +| :---------------------------------------------------------------------------- | :------------------------------------------------------ | +| [balance-monitor](./packages/balance-monitor) | Service that monitors Ethereum L1/L2 addresses and token balances. | +| [blobstorage](./packages/blobstorage) | Service for storing and retrieving blob data. | +| [bridge-ui](./packages/bridge-ui) | Bridge UI. | +| [docs-site](./packages/docs-site) | End user documentation site. | +| [eventindexer](./packages/eventindexer) | Event indexer. | +| [fork-diff](./packages/fork-diff) | Fork diff page. | +| [geth-rpc-gateway](./packages/geth-rpc-gateway) | RPC gateway for geth nodes. | +| [guardian-prover-health-check](./packages/guardian-prover-health-check) | Guardian prover health check service. | +| [guardian-prover-health-check-ui](./packages/guardian-prover-health-check-ui) | Guardian prover health check UI. | +| [monitors](./packages/monitors) | Monitoring and alerting services. | +| [nfts](./packages/nfts) | NFT-related smart contracts and utilities. | +| [protocol](./packages/protocol) | Taiko protocol smart contracts. | +| [relayer](./packages/relayer) | Bridge backend relayer. | +| [snaefell-ui](./packages/snaefell-ui) | Snaefell UI. | +| [supplementary-contracts](./packages/supplementary-contracts) | Supplementary contracts not part of the Taiko protocol. | +| [taiko-client](./packages/taiko-client) | Taiko client implementation in Go. | +| [taikoon-ui](./packages/taikoon-ui) | Taikoon UI. | +| [ui-lib](./packages/ui-lib) | UI library. | + ## Issues diff --git a/lychee.toml b/lychee.toml new file mode 100644 index 00000000000..c95a4fac4cd --- /dev/null +++ b/lychee.toml @@ -0,0 +1 @@ +exclude_path = ["node_modules"] diff --git a/packages/docs-site/src/content/docs/network-reference/software-releases-and-deployments.md b/packages/docs-site/src/content/docs/network-reference/software-releases-and-deployments.md index 336964cf320..f07a85dd624 100644 --- a/packages/docs-site/src/content/docs/network-reference/software-releases-and-deployments.md +++ b/packages/docs-site/src/content/docs/network-reference/software-releases-and-deployments.md @@ -1,9 +1,9 @@ --- -title: Software releases and Deployments -description: Network reference page displaying the latest software versions. +title: Software releases and deployments +description: Reference page showing the latest Taiko software versions and deployments. --- -## Software Releases +## Software releases It is **highly recommended** you use the latest software. You can find the latest versions here: @@ -15,12 +15,12 @@ It is **highly recommended** you use the latest software. You can find the lates | [simple-taiko-node](https://github.com/taikoxyz/simple-taiko-node/tree/main) | [![Github Release](https://img.shields.io/github/v/release/taikoxyz/simple-taiko-node?label=)](https://github.com/taikoxyz/simple-taiko-node/blob/main/CHANGELOG.md) | | [raiko](https://github.com/taikoxyz/raiko/tree/main) | [![Github Release](https://img.shields.io/github/v/release/taikoxyz/raiko?label=)](https://github.com/taikoxyz/raiko/blob/main/CHANGELOG.md) | -## Mainnet Deployment Logs +## Mainnet deployment logs You can find the contract addresses of the latest smart contract deployments of the Taiko Protocol on Ethereum [here](https://github.com/taikoxyz/taiko-mono/blob/main/packages/protocol/deployments/mainnet-contract-logs-L1.md). You can find the smart contract addresses of L2 contracts for the Taiko Protocol on Mainnet [here](https://github.com/taikoxyz/taiko-mono/blob/main/packages/protocol/deployments/mainnet-contract-logs-L2.md). -## Hekla Deployment Logs +## Hekla deployment logs You can find the all L1 and L2 contract addresses of the latest smart contract deployments of the Taiko Protocol [here](https://github.com/taikoxyz/taiko-mono/blob/main/packages/protocol/deployments/hekla-contract-logs.md). diff --git a/packages/monitors/README.md b/packages/monitors/README.md new file mode 100644 index 00000000000..43f6628df45 --- /dev/null +++ b/packages/monitors/README.md @@ -0,0 +1,3 @@ +# Monitors + +This package contains monitoring and alerting services for the Taiko protocol. It uses OpenZeppelin Defender for monitoring smart contracts and setting up automated alerts. diff --git a/packages/taiko-client/README.md b/packages/taiko-client/README.md index 2f2bdd812f0..70ff96eadbe 100644 --- a/packages/taiko-client/README.md +++ b/packages/taiko-client/README.md @@ -5,7 +5,7 @@ -Taiko protocol's client software implementation in Go. Learn more about Taiko nodes with [the docs](https://docs.taiko.xyz/core-concepts/taiko-nodes/). +Taiko protocol's client software implementation in Go. Learn more about Taiko nodes with [the docs](https://docs.taiko.xyz/taiko-protocol/taiko-nodes). ## Project structure From 53a61b657c1740d6511e91988861578090bbf92b Mon Sep 17 00:00:00 2001 From: dionysuz <13951458+dionysuzx@users.noreply.github.com> Date: Mon, 23 Dec 2024 22:00:18 -0500 Subject: [PATCH 17/29] chore(repo): improve license (#18634) --- LICENSE | 21 +++++++++++++++++++++ LICENSE.md | 9 --------- 2 files changed, 21 insertions(+), 9 deletions(-) create mode 100644 LICENSE delete mode 100644 LICENSE.md diff --git a/LICENSE b/LICENSE new file mode 100644 index 00000000000..876c140821d --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2023–present Taiko Labs + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/LICENSE.md b/LICENSE.md deleted file mode 100644 index 8ccef57ef1d..00000000000 --- a/LICENSE.md +++ /dev/null @@ -1,9 +0,0 @@ -MIT License - -Copyright 2023 Taiko Labs - -Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. From cd2d9180d313af6c858f7059b01851bd8e3290da Mon Sep 17 00:00:00 2001 From: Daniel Wang <99078276+dantaik@users.noreply.github.com> Date: Tue, 24 Dec 2024 11:22:56 +0800 Subject: [PATCH 18/29] docs(repo): fix links to LICENSE file (#18641) --- README.md | 41 ++++++++++++------------ packages/eventindexer/docs/docs.go | 2 +- packages/eventindexer/docs/swagger.json | 2 +- packages/eventindexer/docs/swagger.yaml | 2 +- packages/eventindexer/pkg/http/server.go | 2 +- packages/relayer/docs/docs.go | 2 +- packages/relayer/docs/swagger.json | 2 +- packages/relayer/docs/swagger.yaml | 2 +- packages/relayer/pkg/http/server.go | 2 +- 9 files changed, 28 insertions(+), 29 deletions(-) diff --git a/README.md b/README.md index 991d0e3a23b..ff647347278 100644 --- a/README.md +++ b/README.md @@ -17,7 +17,7 @@ [![YouTube](https://img.shields.io/youtube/channel/subscribers/UCxd_ARE9LtAEdnRQA6g1TaQ)](https://www.youtube.com/@taikoxyz) [![GitPOAP Badge](https://public-api.gitpoap.io/v1/repo/taikoxyz/taiko-mono/badge)](https://www.gitpoap.io/gh/taikoxyz/taiko-mono) -[![License](https://img.shields.io/github/license/taikoxyz/taiko-mono)](https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md) +[![License](https://img.shields.io/github/license/taikoxyz/taiko-mono)](https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE) @@ -34,27 +34,26 @@ Get started with Taiko: > [!TIP] > Make sure your node is using the latest version tags for taiko-client and taiko-geth. Check out the [node releases page](https://docs.taiko.xyz/network-reference/software-releases-and-deployments)! -| Package | Description | -| :---------------------------------------------------------------------------- | :------------------------------------------------------ | +| Package | Description | +| :---------------------------------------------------------------------------- | :----------------------------------------------------------------- | | [balance-monitor](./packages/balance-monitor) | Service that monitors Ethereum L1/L2 addresses and token balances. | -| [blobstorage](./packages/blobstorage) | Service for storing and retrieving blob data. | -| [bridge-ui](./packages/bridge-ui) | Bridge UI. | -| [docs-site](./packages/docs-site) | End user documentation site. | -| [eventindexer](./packages/eventindexer) | Event indexer. | -| [fork-diff](./packages/fork-diff) | Fork diff page. | -| [geth-rpc-gateway](./packages/geth-rpc-gateway) | RPC gateway for geth nodes. | -| [guardian-prover-health-check](./packages/guardian-prover-health-check) | Guardian prover health check service. | -| [guardian-prover-health-check-ui](./packages/guardian-prover-health-check-ui) | Guardian prover health check UI. | -| [monitors](./packages/monitors) | Monitoring and alerting services. | -| [nfts](./packages/nfts) | NFT-related smart contracts and utilities. | -| [protocol](./packages/protocol) | Taiko protocol smart contracts. | -| [relayer](./packages/relayer) | Bridge backend relayer. | -| [snaefell-ui](./packages/snaefell-ui) | Snaefell UI. | -| [supplementary-contracts](./packages/supplementary-contracts) | Supplementary contracts not part of the Taiko protocol. | -| [taiko-client](./packages/taiko-client) | Taiko client implementation in Go. | -| [taikoon-ui](./packages/taikoon-ui) | Taikoon UI. | -| [ui-lib](./packages/ui-lib) | UI library. | - +| [blobstorage](./packages/blobstorage) | Service for storing and retrieving blob data. | +| [bridge-ui](./packages/bridge-ui) | Bridge UI. | +| [docs-site](./packages/docs-site) | End user documentation site. | +| [eventindexer](./packages/eventindexer) | Event indexer. | +| [fork-diff](./packages/fork-diff) | Fork diff page. | +| [geth-rpc-gateway](./packages/geth-rpc-gateway) | RPC gateway for geth nodes. | +| [guardian-prover-health-check](./packages/guardian-prover-health-check) | Guardian prover health check service. | +| [guardian-prover-health-check-ui](./packages/guardian-prover-health-check-ui) | Guardian prover health check UI. | +| [monitors](./packages/monitors) | Monitoring and alerting services. | +| [nfts](./packages/nfts) | NFT-related smart contracts and utilities. | +| [protocol](./packages/protocol) | Taiko protocol smart contracts. | +| [relayer](./packages/relayer) | Bridge backend relayer. | +| [snaefell-ui](./packages/snaefell-ui) | Snaefell UI. | +| [supplementary-contracts](./packages/supplementary-contracts) | Supplementary contracts not part of the Taiko protocol. | +| [taiko-client](./packages/taiko-client) | Taiko client implementation in Go. | +| [taikoon-ui](./packages/taikoon-ui) | Taikoon UI. | +| [ui-lib](./packages/ui-lib) | UI library. | ## Issues diff --git a/packages/eventindexer/docs/docs.go b/packages/eventindexer/docs/docs.go index 561b1402938..abed8494ff4 100644 --- a/packages/eventindexer/docs/docs.go +++ b/packages/eventindexer/docs/docs.go @@ -17,7 +17,7 @@ const docTemplate = `{ }, "license": { "name": "MIT", - "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md" + "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE" }, "version": "{{.Version}}" }, diff --git a/packages/eventindexer/docs/swagger.json b/packages/eventindexer/docs/swagger.json index aec099185a7..4f663dda8c8 100644 --- a/packages/eventindexer/docs/swagger.json +++ b/packages/eventindexer/docs/swagger.json @@ -10,7 +10,7 @@ }, "license": { "name": "MIT", - "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md" + "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE" }, "version": "1.0" }, diff --git a/packages/eventindexer/docs/swagger.yaml b/packages/eventindexer/docs/swagger.yaml index 434d1128ca0..14e7e96df6d 100644 --- a/packages/eventindexer/docs/swagger.yaml +++ b/packages/eventindexer/docs/swagger.yaml @@ -123,7 +123,7 @@ info: url: https://community.taiko.xyz/ license: name: MIT - url: https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md + url: https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE termsOfService: http://swagger.io/terms/ title: Taiko Event Indexer API version: "1.0" diff --git a/packages/eventindexer/pkg/http/server.go b/packages/eventindexer/pkg/http/server.go index 4626bf590d4..707f3a8075d 100644 --- a/packages/eventindexer/pkg/http/server.go +++ b/packages/eventindexer/pkg/http/server.go @@ -23,7 +23,7 @@ import ( // @contact.email info@taiko.xyz // @license.name MIT -// @license.url https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md +// @license.url https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE // @host eventindexer.hekla.taiko.xyz // Server represents an eventindexer http server instance. diff --git a/packages/relayer/docs/docs.go b/packages/relayer/docs/docs.go index 622106df9d1..dde35e98426 100644 --- a/packages/relayer/docs/docs.go +++ b/packages/relayer/docs/docs.go @@ -17,7 +17,7 @@ const docTemplate = `{ }, "license": { "name": "MIT", - "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md" + "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE" }, "version": "{{.Version}}" }, diff --git a/packages/relayer/docs/swagger.json b/packages/relayer/docs/swagger.json index 028b3a5e083..42ff334167b 100644 --- a/packages/relayer/docs/swagger.json +++ b/packages/relayer/docs/swagger.json @@ -10,7 +10,7 @@ }, "license": { "name": "MIT", - "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md" + "url": "https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE" }, "version": "1.0" }, diff --git a/packages/relayer/docs/swagger.yaml b/packages/relayer/docs/swagger.yaml index 8e35602519f..1760c3aab6f 100644 --- a/packages/relayer/docs/swagger.yaml +++ b/packages/relayer/docs/swagger.yaml @@ -47,7 +47,7 @@ info: url: https://community.taiko.xyz/ license: name: MIT - url: https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md + url: https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE termsOfService: http://swagger.io/terms/ title: Taiko Bridge Relayer API version: "1.0" diff --git a/packages/relayer/pkg/http/server.go b/packages/relayer/pkg/http/server.go index c3739197f9f..b64dc6e74d3 100644 --- a/packages/relayer/pkg/http/server.go +++ b/packages/relayer/pkg/http/server.go @@ -38,7 +38,7 @@ type ethClient interface { // @contact.email info@taiko.xyz // @license.name MIT -// @license.url https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE.md +// @license.url https://github.com/taikoxyz/taiko-mono/blob/main/LICENSE // @host relayer.hekla.taiko.xyz // Server represents an relayer http server instance. From 75359cc1f76151cdb2e087d0000ad9052f50e3c4 Mon Sep 17 00:00:00 2001 From: taiko-bot <160625009+taiko-kitty@users.noreply.github.com> Date: Mon, 23 Dec 2024 19:51:21 -0800 Subject: [PATCH 19/29] chore(main): release protocol 1.11.0 (#18433) Co-authored-by: Daniel Wang <99078276+dantaik@users.noreply.github.com> --- .github/workflows/repo--check-links.yml | 2 +- .release-please-manifest.json | 2 +- packages/protocol/CHANGELOG.md | 76 +++++++++++++++++++++++++ packages/protocol/package.json | 2 +- 4 files changed, 79 insertions(+), 3 deletions(-) diff --git a/.github/workflows/repo--check-links.yml b/.github/workflows/repo--check-links.yml index b6a2af1050d..c7d64802bd6 100644 --- a/.github/workflows/repo--check-links.yml +++ b/.github/workflows/repo--check-links.yml @@ -17,4 +17,4 @@ jobs: - name: Check links uses: lycheeverse/lychee-action@v2 with: - args: --no-progress --verbose '**/README.md' + args: --no-progress --verbose --user-agent 'Mozilla/5.0 (compatible; TaikoLinkChecker/1.0; +https://taiko.xyz)' '**/README.md' diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 1a80f9fb51f..f175c355e98 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -5,7 +5,7 @@ "packages/fork-diff": "0.6.1", "packages/guardian-prover-health-check": "0.1.0", "packages/guardian-prover-health-check-ui": "0.2.0", - "packages/protocol": "1.10.0", + "packages/protocol": "1.11.0", "packages/relayer": "0.12.0", "packages/snaefell-ui": "1.1.0", "packages/supplementary-contracts": "1.0.0", diff --git a/packages/protocol/CHANGELOG.md b/packages/protocol/CHANGELOG.md index d1b9a102079..1e9434fed09 100644 --- a/packages/protocol/CHANGELOG.md +++ b/packages/protocol/CHANGELOG.md @@ -1,5 +1,81 @@ # Changelog +## [1.11.0](https://github.com/taikoxyz/taiko-mono/compare/protocol-v1.10.0...protocol-v1.11.0) (2024-12-24) + + +### Features + +* **protocol:** add `lastProposedIn` to slotB ([#18379](https://github.com/taikoxyz/taiko-mono/issues/18379)) ([96b380a](https://github.com/taikoxyz/taiko-mono/commit/96b380a452f1055da960146b4bf1e94c1842da73)) +* **protocol:** adjust the zk ratio(risc0 & sp1) ([#18613](https://github.com/taikoxyz/taiko-mono/issues/18613)) ([431435e](https://github.com/taikoxyz/taiko-mono/commit/431435e6e74799caea94f53438238c63831cf07c)) +* **protocol:** allow `local.params.parentMetaHash` to remain as 0 ([#18451](https://github.com/taikoxyz/taiko-mono/issues/18451)) ([94185fe](https://github.com/taikoxyz/taiko-mono/commit/94185feb207b9a2e74fb05a4898d25ce2008f826)) +* **protocol:** allow any ERC20 tokens or Ether to be used as bonds ([#18380](https://github.com/taikoxyz/taiko-mono/issues/18380)) ([1920521](https://github.com/taikoxyz/taiko-mono/commit/1920521a2478d1e31745742f1ddbb296cdd98f6f)) +* **protocol:** change HeklaTaikoToken's clock mode to timestamp to test the DAO ([#18597](https://github.com/taikoxyz/taiko-mono/issues/18597)) ([ccc9500](https://github.com/taikoxyz/taiko-mono/commit/ccc9500d861d5cc666f038ddb8ceed00a353ee94)) +* **protocol:** decrease the rate of risc0 in Hekla ([#18553](https://github.com/taikoxyz/taiko-mono/issues/18553)) ([57d20db](https://github.com/taikoxyz/taiko-mono/commit/57d20db59ffa23f7038ad80a4322634cc71251ea)) +* **protocol:** increase risc0 frequency in Hekla ([#18407](https://github.com/taikoxyz/taiko-mono/issues/18407)) ([350264c](https://github.com/taikoxyz/taiko-mono/commit/350264c98d6a96ea11d5b1cef684a81605d3826b)) +* **protocol:** increase zk(risc0 & sp1) rate in mainnet ([#18481](https://github.com/taikoxyz/taiko-mono/issues/18481)) ([f24a908](https://github.com/taikoxyz/taiko-mono/commit/f24a908e60c062ad789a34765de5a1037bdb1ff0)) +* **protocol:** introduce ForkManager to improve protocol fork management ([#18508](https://github.com/taikoxyz/taiko-mono/issues/18508)) ([ff5c196](https://github.com/taikoxyz/taiko-mono/commit/ff5c1964a303e21dfeb87f8f9c01fc82ef43a03e)) +* **protocol:** measure gas per block using a debug event ([#18470](https://github.com/taikoxyz/taiko-mono/issues/18470)) ([e84e472](https://github.com/taikoxyz/taiko-mono/commit/e84e472e4a0479301d5ce1d4268d964705dcbbd0)) +* **protocol:** propose a batch blocks conditionally ([#18570](https://github.com/taikoxyz/taiko-mono/issues/18570)) ([e846f62](https://github.com/taikoxyz/taiko-mono/commit/e846f6289fea0b046ddcfcdfaf46f3727efbdf11)) +* **protocol:** request zk proofs(risc0 & sp1) in mainnet ([#18467](https://github.com/taikoxyz/taiko-mono/issues/18467)) ([1fab427](https://github.com/taikoxyz/taiko-mono/commit/1fab427005708036c981f2b8fb47d9aa408e0d94)) +* **protocol:** tolerate invalid BaseFeeConfig on L2 ([#18338](https://github.com/taikoxyz/taiko-mono/issues/18338)) ([f9f5d15](https://github.com/taikoxyz/taiko-mono/commit/f9f5d156f9fef622d921f6e007ecb43ded0130ad)) +* **protocol:** update `B_TIER_ROUTER` in `RollupAddressCache` ([#18370](https://github.com/taikoxyz/taiko-mono/issues/18370)) ([9748ae5](https://github.com/taikoxyz/taiko-mono/commit/9748ae527a75124f8674bb66280b9161ce79d046)) +* **protocol:** update `RollupAddressCache` with new `MainnetTierRouter` address ([#18619](https://github.com/taikoxyz/taiko-mono/issues/18619)) ([b2ca63c](https://github.com/taikoxyz/taiko-mono/commit/b2ca63cd4ed7eca385c317d9a6ade794bf156c79)) +* **protocol:** update sp1 to 3.0.0 prod version ([#18465](https://github.com/taikoxyz/taiko-mono/issues/18465)) ([0b11101](https://github.com/taikoxyz/taiko-mono/commit/0b1110159201f94ff5a4df528eab60b306d4fb25)) + + +### Bug Fixes + +* **protocol:** fix debitBond bug and add additional tests ([#18443](https://github.com/taikoxyz/taiko-mono/issues/18443)) ([75ff1f8](https://github.com/taikoxyz/taiko-mono/commit/75ff1f87412c763e6ed3431d13689a629a2dd668)) +* **protocol:** revert `B_TIER_OPTIMISTIC` back to `""` ([#18446](https://github.com/taikoxyz/taiko-mono/issues/18446)) ([9549e7f](https://github.com/taikoxyz/taiko-mono/commit/9549e7f3e899b22ff8c9ff7d731aa3ce250fd071)) + + +### Chores + +* **main:** fix misspelled ([#18581](https://github.com/taikoxyz/taiko-mono/issues/18581)) ([3687c4e](https://github.com/taikoxyz/taiko-mono/commit/3687c4e060b4b316fb185c649e9b089b97d53eda)) +* **protocol:** change bond amounts, proving windows, and cooldown windows ([#18371](https://github.com/taikoxyz/taiko-mono/issues/18371)) ([fac5c16](https://github.com/taikoxyz/taiko-mono/commit/fac5c167357f430cfb030e7ceaa41bb8e4b938d4)) +* **protocol:** delete gas debug event ([#18620](https://github.com/taikoxyz/taiko-mono/issues/18620)) ([06128e8](https://github.com/taikoxyz/taiko-mono/commit/06128e8f64b7bf2997b70959c78ab256404ebab3)) +* **protocol:** fix typos in documentation files ([#18490](https://github.com/taikoxyz/taiko-mono/issues/18490)) ([8d1f9ea](https://github.com/taikoxyz/taiko-mono/commit/8d1f9eab8e02b1868f2e24005699a8ed1d2937fa)) +* **protocol:** optimize Taiko L1 gas cost ([#18376](https://github.com/taikoxyz/taiko-mono/issues/18376)) ([ea0158f](https://github.com/taikoxyz/taiko-mono/commit/ea0158f0cbaa974f90f9174410c705e6cbdc48aa)) +* **protocol:** remove repetitive words in audit report ([#18584](https://github.com/taikoxyz/taiko-mono/issues/18584)) ([8092ee5](https://github.com/taikoxyz/taiko-mono/commit/8092ee56e00ed3e422471a9ed85c42fad6c19a13)) +* **protocol:** restore proving window changes ([#18368](https://github.com/taikoxyz/taiko-mono/issues/18368)) ([9182fba](https://github.com/taikoxyz/taiko-mono/commit/9182fbaf05d309f9827310f3616992c0cc88a22d)) +* **repo:** improve documentation and changelog ([#18489](https://github.com/taikoxyz/taiko-mono/issues/18489)) ([c7b9b4f](https://github.com/taikoxyz/taiko-mono/commit/c7b9b4f01098d4fab337b9ff456ce394cdaf3a79)) + + +### Documentation + +* **protocol:** add mainnet zkVM verifiers deployment ([#18454](https://github.com/taikoxyz/taiko-mono/issues/18454)) ([3481b68](https://github.com/taikoxyz/taiko-mono/commit/3481b68e8d377c1ae6fc5a1a0e08d8411f94c613)) +* **protocol:** add Ontake fork audit report from OpenZeppelin ([#18491](https://github.com/taikoxyz/taiko-mono/issues/18491)) ([e83adc0](https://github.com/taikoxyz/taiko-mono/commit/e83adc06ac4ce8ebe7e34feaad5691176dba27e2)) +* **protocol:** update Hekla deployments ([#18598](https://github.com/taikoxyz/taiko-mono/issues/18598)) ([a095c69](https://github.com/taikoxyz/taiko-mono/commit/a095c69a240d64606b09a26f2e80ad6daf18c273)) +* **protocol:** update mainnet deployment docs ([#18366](https://github.com/taikoxyz/taiko-mono/issues/18366)) ([bbd69ca](https://github.com/taikoxyz/taiko-mono/commit/bbd69ca583257ade30ac9ea2601509af5bc0789a)) +* **protocol:** update mainnet deployment docs ([#18482](https://github.com/taikoxyz/taiko-mono/issues/18482)) ([9da8499](https://github.com/taikoxyz/taiko-mono/commit/9da849989249072e3a03e611b9c08b00295cf42c)) +* **protocol:** update mainnet deployment docs ([#18621](https://github.com/taikoxyz/taiko-mono/issues/18621)) ([eb542bf](https://github.com/taikoxyz/taiko-mono/commit/eb542bf67dea51fd42c0f5c40ee987e5acadc3fd)) +* **protocol:** upgrade sp1 remote verifier in Hekla ([#18469](https://github.com/taikoxyz/taiko-mono/issues/18469)) ([051b619](https://github.com/taikoxyz/taiko-mono/commit/051b619c6ce93a09c7e14dd8fafc99681c9261ad)) +* **protocol:** upgrade verifiers to support proof aggregation in Hekla ([#18453](https://github.com/taikoxyz/taiko-mono/issues/18453)) ([bfb0386](https://github.com/taikoxyz/taiko-mono/commit/bfb03864ee83ccc3bce989f3e9fd2309eb90c277)) +* **repo:** improve grammar and readability ([#18501](https://github.com/taikoxyz/taiko-mono/issues/18501)) ([61994ff](https://github.com/taikoxyz/taiko-mono/commit/61994ffefcf29981beb567b84a3a55706300cf13)) + + +### Code Refactoring + +* **protocol:** extra a new function in LibProposing ([#18456](https://github.com/taikoxyz/taiko-mono/issues/18456)) ([5b4b0cd](https://github.com/taikoxyz/taiko-mono/commit/5b4b0cd271534aa72d865afa5fc55e0ee4b16b73)) +* **protocol:** remove unused code post Ontake fork ([#18150](https://github.com/taikoxyz/taiko-mono/issues/18150)) ([8543cec](https://github.com/taikoxyz/taiko-mono/commit/8543cecdef9d10d038bc5a7313230006acd26e22)) +* **protocol:** slightly improve EssentialContract ([#18445](https://github.com/taikoxyz/taiko-mono/issues/18445)) ([3d077f8](https://github.com/taikoxyz/taiko-mono/commit/3d077f8ee520a116028711391c323c7badd1f2c6)) + + +### Tests + +* **protocol:** check LibEIP1559 function results in fuzz tests ([#18475](https://github.com/taikoxyz/taiko-mono/issues/18475)) ([06e190c](https://github.com/taikoxyz/taiko-mono/commit/06e190c01bc4c4aae25664e8c2c154d8cf46efa5)) + + +### Workflow + +* **protocol:** make the storage layout table clearer ([#18633](https://github.com/taikoxyz/taiko-mono/issues/18633)) ([7394458](https://github.com/taikoxyz/taiko-mono/commit/73944585586686ad1ce5548ce59e9ea583c4b2ee)) + + +### Build + +* **deps:** bump github.com/stretchr/testify from 1.9.0 to 1.10.0 ([#18539](https://github.com/taikoxyz/taiko-mono/issues/18539)) ([79f3fab](https://github.com/taikoxyz/taiko-mono/commit/79f3fab5f1d1ec1bb4ee18afb9268b622e894780)) +* **deps:** bump golang.org/x/sync from 0.9.0 to 0.10.0 ([#18560](https://github.com/taikoxyz/taiko-mono/issues/18560)) ([3d51970](https://github.com/taikoxyz/taiko-mono/commit/3d51970aa0953bbfecaeebf76ea7e664c875c0e4)) + ## [1.10.0](https://github.com/taikoxyz/taiko-mono/compare/protocol-v1.9.0...protocol-v1.10.0) (2024-11-01) diff --git a/packages/protocol/package.json b/packages/protocol/package.json index f8a526c81c2..cf9f5272977 100644 --- a/packages/protocol/package.json +++ b/packages/protocol/package.json @@ -1,6 +1,6 @@ { "name": "@taiko/protocol", - "version": "1.10.0", + "version": "1.11.0", "private": true, "scripts": { "buildMerkle": "ts-node ./utils/airdrop/buildMerkleTree.ts ./utils/airdrop/airdrop_db/example_claimList.json", From 59d4f107edc1aaac5716067634735bad03e75269 Mon Sep 17 00:00:00 2001 From: David Date: Wed, 25 Dec 2024 08:39:01 +0800 Subject: [PATCH 20/29] docs(protocol): update mainnet deployment docs (#18645) --- packages/protocol/deployments/mainnet-contract-logs-L1.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/packages/protocol/deployments/mainnet-contract-logs-L1.md b/packages/protocol/deployments/mainnet-contract-logs-L1.md index feb4fddbf2b..89b083c9496 100644 --- a/packages/protocol/deployments/mainnet-contract-logs-L1.md +++ b/packages/protocol/deployments/mainnet-contract-logs-L1.md @@ -223,7 +223,7 @@ - ens: `based.taiko.eth` - proxy: `0x06a9Ab27c7e2255df1815E6CC0168d7755Feb19a` -- impl: `0xd4896d4537c6425aC5d89B9f122d4E4ac4D65e1c` +- impl: `0xe7c4B445D3C7C8E4D68afb85A068F9fAa18e9A5B` - owner: `admin.taiko.eth` - logs: - deployed on May 1, 2024 @commit`56dddf2b6` @@ -246,6 +246,7 @@ - Upgrade to `0xe7c4B445D3C7C8E4D68afb85A068F9fAa18e9A5B` @commit`ea0158f` with new `RollupAddressManagerCache` @commit `9ae9a5e` @tx`0x5eb57ab352b3e3c1ddbc3fe468d582901b88c6a137ce49b0d70857d5218d626d` - Upgrade to `0xb74A66b6CF50AD63E29669F0BDE4354E11758162` @commit`06128e8` @tx`0xe66aba9f8bfcd86dc0ae32416862ca61a51c47f8ec747799e65f155ef27eeb20` - Upgrade to `0xd4896d4537c6425aC5d89B9f122d4E4ac4D65e1c` @commit`ea0158f` with new `RollupAddressManagerCache` @commit `7394458` @tx`0x9c2f36af40c0004110041fc45d980b73b0c8dde8064713a55aeb6f69fca77a99` + - Upgrade to `0xe7c4B445D3C7C8E4D68afb85A068F9fAa18e9A5B` @commit`ea0158f` with new `RollupAddressManagerCache` @commit `9ae9a5e` @tx`0x5eb57ab352b3e3c1ddbc3fe468d582901b88c6a137ce49b0d70857d5218d626d` #### tier_router From 98a98fd4636e3cd5f3ec019493a72880e141f494 Mon Sep 17 00:00:00 2001 From: Gavin Yu Date: Wed, 25 Dec 2024 09:14:12 +0800 Subject: [PATCH 21/29] feat(taiko-client): catch raiko deserialization errors (#18644) --- packages/taiko-client/prover/proof_producer/sgx_producer.go | 6 +++++- .../taiko-client/prover/proof_producer/zkvm_producer.go | 6 +++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/packages/taiko-client/prover/proof_producer/sgx_producer.go b/packages/taiko-client/prover/proof_producer/sgx_producer.go index 3f4861fd933..91ca16064f3 100644 --- a/packages/taiko-client/prover/proof_producer/sgx_producer.go +++ b/packages/taiko-client/prover/proof_producer/sgx_producer.go @@ -308,6 +308,9 @@ func (s *SGXProofProducer) requestBatchProof( return nil, fmt.Errorf("failed to get batch proof, msg: %s", output.ErrorMessage) } + if output.Data == nil { + return nil, fmt.Errorf("unexpected structure error, response: %s", string(resBytes)) + } if output.Data.Status == ErrProofInProgress.Error() { return nil, ErrProofInProgress } @@ -315,7 +318,8 @@ func (s *SGXProofProducer) requestBatchProof( return nil, ErrRetry } - if len(output.Data.Proof.Proof) == 0 { + if output.Data.Proof == nil || + len(output.Data.Proof.Proof) == 0 { return nil, errEmptyProof } proof = common.Hex2Bytes(output.Data.Proof.Proof[2:]) diff --git a/packages/taiko-client/prover/proof_producer/zkvm_producer.go b/packages/taiko-client/prover/proof_producer/zkvm_producer.go index 3e2711a1962..98f8529acc5 100644 --- a/packages/taiko-client/prover/proof_producer/zkvm_producer.go +++ b/packages/taiko-client/prover/proof_producer/zkvm_producer.go @@ -479,6 +479,10 @@ func (s *ZKvmProofProducer) requestBatchProof( if len(output.ErrorMessage) > 0 || len(output.Error) > 0 { return nil, fmt.Errorf("failed to get batch proof, msg: %s", output.ErrorMessage) } + if output.Data == nil { + return nil, fmt.Errorf("unexpected structure error, response: %s", string(resBytes)) + } + if output.Data.Status == ErrProofInProgress.Error() { return nil, ErrProofInProgress } @@ -486,7 +490,7 @@ func (s *ZKvmProofProducer) requestBatchProof( return nil, ErrRetry } - if len(output.Data.Proof.Proof) == 0 { + if output.Data.Proof == nil || len(output.Data.Proof.Proof) == 0 { return nil, errEmptyProof } proof = common.Hex2Bytes(output.Data.Proof.Proof[2:]) From 688a42646d185694c7cfd2bc091084dd782782f5 Mon Sep 17 00:00:00 2001 From: Gavin Yu Date: Wed, 25 Dec 2024 09:22:27 +0800 Subject: [PATCH 22/29] feat(taiko-client): optimize aggregation loggingain (#18643) --- .../prover/proof_submitter/proof_submitter.go | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/packages/taiko-client/prover/proof_submitter/proof_submitter.go b/packages/taiko-client/prover/proof_submitter/proof_submitter.go index 60648aeda3f..b87f992772c 100644 --- a/packages/taiko-client/prover/proof_submitter/proof_submitter.go +++ b/packages/taiko-client/prover/proof_submitter/proof_submitter.go @@ -477,7 +477,16 @@ func (s *ProofSubmitter) AggregateProofs(ctx context.Context) error { startTime, ) if err != nil { - log.Error("Failed to request proof aggregation", "err", err) + if errors.Is(err, proofProducer.ErrProofInProgress) || + errors.Is(err, proofProducer.ErrRetry) { + log.Info("Aggregating proofs", + "status", err, + "length", len(buffer), + "tier", s.Tier(), + ) + } else { + log.Error("Failed to request proof aggregation", "err", err) + } return err } s.batchResultCh <- result From b577b3b40f51bf35efe46151e459d37b87548614 Mon Sep 17 00:00:00 2001 From: David Date: Thu, 26 Dec 2024 11:25:33 +0800 Subject: [PATCH 23/29] test(taiko-client): cleanup pre-ontake tests (#18647) --- .../driver/chain_syncer/blob/syncer_test.go | 27 +++--- .../txlist_decompressor_test.go | 1 - .../taiko-client/internal/testutils/helper.go | 73 ++++------------ .../taiko-client/proposer/proposer_test.go | 82 +----------------- .../proof_producer/dummy_producer_test.go | 2 +- .../proof_producer/guardian_producer_test.go | 8 +- .../optimistic_producer_test.go | 4 +- .../proof_producer/sgx_producer_test.go | 2 +- .../proof_submitter/proof_contester_test.go | 2 +- .../proof_submitter/proof_submitter_test.go | 6 +- packages/taiko-client/prover/prover_test.go | 86 +++++-------------- 11 files changed, 69 insertions(+), 224 deletions(-) diff --git a/packages/taiko-client/driver/chain_syncer/blob/syncer_test.go b/packages/taiko-client/driver/chain_syncer/blob/syncer_test.go index 55492b03e19..5ac39a757ec 100644 --- a/packages/taiko-client/driver/chain_syncer/blob/syncer_test.go +++ b/packages/taiko-client/driver/chain_syncer/blob/syncer_test.go @@ -65,12 +65,12 @@ func (s *BlobSyncerTestSuite) TestProcessL1BlocksReorg() { func (s *BlobSyncerTestSuite) TestOnBlockProposed() { s.Nil(s.s.onBlockProposed( context.Background(), - &metadata.TaikoDataBlockMetadataLegacy{TaikoDataBlockMetadata: bindings.TaikoDataBlockMetadata{Id: 0}}, + &metadata.TaikoDataBlockMetadataOntake{TaikoDataBlockMetadataV2: bindings.TaikoDataBlockMetadataV2{Id: 0}}, func() {}, )) s.NotNil(s.s.onBlockProposed( context.Background(), - &metadata.TaikoDataBlockMetadataLegacy{TaikoDataBlockMetadata: bindings.TaikoDataBlockMetadata{Id: 1}}, + &metadata.TaikoDataBlockMetadataOntake{TaikoDataBlockMetadataV2: bindings.TaikoDataBlockMetadataV2{Id: 1}}, func() {}, )) } @@ -80,18 +80,21 @@ func (s *BlobSyncerTestSuite) TestInsertNewHead() { s.Nil(err) l1Head, err := s.s.rpc.L1.BlockByNumber(context.Background(), nil) s.Nil(err) + protocolConfigs, err := s.s.rpc.TaikoL1.GetConfig(nil) + s.Nil(err) _, err = s.s.insertNewHead( context.Background(), - &metadata.TaikoDataBlockMetadataLegacy{ - TaikoDataBlockMetadata: bindings.TaikoDataBlockMetadata{ - Id: 1, - L1Height: l1Head.NumberU64(), - L1Hash: l1Head.Hash(), - Coinbase: common.BytesToAddress(testutils.RandomBytes(1024)), - BlobHash: testutils.RandomHash(), - Difficulty: testutils.RandomHash(), - GasLimit: utils.RandUint32(nil), - Timestamp: uint64(time.Now().Unix()), + &metadata.TaikoDataBlockMetadataOntake{ + TaikoDataBlockMetadataV2: bindings.TaikoDataBlockMetadataV2{ + Id: 1, + AnchorBlockId: l1Head.NumberU64(), + AnchorBlockHash: l1Head.Hash(), + Coinbase: common.BytesToAddress(testutils.RandomBytes(1024)), + BlobHash: testutils.RandomHash(), + Difficulty: testutils.RandomHash(), + GasLimit: utils.RandUint32(nil), + Timestamp: uint64(time.Now().Unix()), + BaseFeeConfig: protocolConfigs.BaseFeeConfig, }, Log: types.Log{ BlockNumber: l1Head.Number().Uint64(), diff --git a/packages/taiko-client/driver/txlist_decompressor/txlist_decompressor_test.go b/packages/taiko-client/driver/txlist_decompressor/txlist_decompressor_test.go index e93ccdd8d30..4888dd48bce 100644 --- a/packages/taiko-client/driver/txlist_decompressor/txlist_decompressor_test.go +++ b/packages/taiko-client/driver/txlist_decompressor/txlist_decompressor_test.go @@ -80,7 +80,6 @@ func rlpEncodedTransactionBytes(l int, signed bool) []byte { var tx *types.Transaction if signed { txData := &types.LegacyTx{Nonce: 1, To: &testAddr, GasPrice: common.Big256, Value: common.Big1, Gas: 10} - tx = types.MustSignNewTx(testKey, types.LatestSigner(¶ms.ChainConfig{ChainID: chainID}), txData) } else { tx = types.NewTransaction(1, testAddr, common.Big1, 10, new(big.Int).SetUint64(10*params.GWei), nil) diff --git a/packages/taiko-client/internal/testutils/helper.go b/packages/taiko-client/internal/testutils/helper.go index 873f5ad74ab..b7d94b8b8c5 100644 --- a/packages/taiko-client/internal/testutils/helper.go +++ b/packages/taiko-client/internal/testutils/helper.go @@ -34,22 +34,14 @@ func (s *ClientTestSuite) ProposeAndInsertEmptyBlocks( l1Head, err := s.RPCClient.L1.HeaderByNumber(context.Background(), nil) s.Nil(err) - sink := make(chan *bindings.TaikoL1ClientBlockProposed) - sub, err := s.RPCClient.TaikoL1.WatchBlockProposed(nil, sink, nil, nil) + sink := make(chan *bindings.TaikoL1ClientBlockProposedV2) + sub, err := s.RPCClient.TaikoL1.WatchBlockProposedV2(nil, sink, nil) s.Nil(err) defer func() { sub.Unsubscribe() close(sink) }() - sink2 := make(chan *bindings.TaikoL1ClientBlockProposedV2) - sub2, err := s.RPCClient.TaikoL1.WatchBlockProposedV2(nil, sink2, nil) - s.Nil(err) - defer func() { - sub2.Unsubscribe() - close(sink2) - }() - // RLP encoded empty list s.Nil(proposer.ProposeTxLists(context.Background(), []types.Transactions{{}})) s.Nil(blobSyncer.ProcessL1Blocks(context.Background())) @@ -64,14 +56,9 @@ func (s *ClientTestSuite) ProposeAndInsertEmptyBlocks( var txHash common.Hash for i := 0; i < 3; i++ { - select { - case event := <-sink: - metadataList = append(metadataList, metadata.NewTaikoDataBlockMetadataLegacy(event)) - txHash = event.Raw.TxHash - case event := <-sink2: - metadataList = append(metadataList, metadata.NewTaikoDataBlockMetadataOntake(event)) - txHash = event.Raw.TxHash - } + event := <-sink + metadataList = append(metadataList, metadata.NewTaikoDataBlockMetadataOntake(event)) + txHash = event.Raw.TxHash } _, isPending, err := s.RPCClient.L1.TransactionByHash(context.Background(), txHash) @@ -97,19 +84,13 @@ func (s *ClientTestSuite) ProposeAndInsertValidBlock( s.Nil(err) // Propose txs in L2 execution engine's mempool - sink := make(chan *bindings.TaikoL1ClientBlockProposed) - sub, err := s.RPCClient.TaikoL1.WatchBlockProposed(nil, sink, nil, nil) - s.Nil(err) - - sink2 := make(chan *bindings.TaikoL1ClientBlockProposedV2) - sub2, err := s.RPCClient.TaikoL1.WatchBlockProposedV2(nil, sink2, nil) + sink := make(chan *bindings.TaikoL1ClientBlockProposedV2) + sub, err := s.RPCClient.TaikoL1.WatchBlockProposedV2(nil, sink, nil) s.Nil(err) defer func() { sub.Unsubscribe() - sub2.Unsubscribe() close(sink) - close(sink2) }() nonce, err := s.RPCClient.L2.PendingNonceAt(context.Background(), s.TestAddr) @@ -130,18 +111,10 @@ func (s *ClientTestSuite) ProposeAndInsertValidBlock( s.Nil(proposer.ProposeOp(context.Background())) var ( - txHash common.Hash - meta metadata.TaikoBlockMetaData - ) - select { - case event := <-sink: - txHash = event.Raw.TxHash - meta = metadata.NewTaikoDataBlockMetadataLegacy(event) - case event := <-sink2: + event = <-sink txHash = event.Raw.TxHash - meta = metadata.NewTaikoDataBlockMetadataOntake(event) - } - + meta = metadata.NewTaikoDataBlockMetadataOntake(event) + ) _, isPending, err := s.RPCClient.L1.TransactionByHash(context.Background(), txHash) s.Nil(err) s.False(isPending) @@ -157,9 +130,7 @@ func (s *ClientTestSuite) ProposeAndInsertValidBlock( ctx, cancel := context.WithTimeout(context.Background(), time.Minute) defer cancel() - s.Nil(backoff.Retry(func() error { - return blobSyncer.ProcessL1Blocks(ctx) - }, backoff.NewExponentialBackOff())) + s.Nil(backoff.Retry(func() error { return blobSyncer.ProcessL1Blocks(ctx) }, backoff.NewExponentialBackOff())) s.Nil(s.RPCClient.WaitTillL2ExecutionEngineSynced(context.Background())) @@ -182,20 +153,12 @@ func (s *ClientTestSuite) ProposeValidBlock( s.Nil(err) // Propose txs in L2 execution engine's mempool - sink := make(chan *bindings.TaikoL1ClientBlockProposed) - sink2 := make(chan *bindings.TaikoL1ClientBlockProposedV2) - - sub, err := s.RPCClient.TaikoL1.WatchBlockProposed(nil, sink, nil, nil) - s.Nil(err) - - sub2, err := s.RPCClient.TaikoL1.WatchBlockProposedV2(nil, sink2, nil) + sink := make(chan *bindings.TaikoL1ClientBlockProposedV2) + sub, err := s.RPCClient.TaikoL1.WatchBlockProposedV2(nil, sink, nil) s.Nil(err) - defer func() { sub.Unsubscribe() - sub2.Unsubscribe() close(sink) - close(sink2) }() ontakeForkHeight, err := s.RPCClient.TaikoL2.OntakeForkHeight(nil) @@ -231,14 +194,10 @@ func (s *ClientTestSuite) ProposeValidBlock( s.Nil(proposer.ProposeOp(context.Background())) - var txHash common.Hash - select { - case event := <-sink: - txHash = event.Raw.TxHash - case event := <-sink2: + var ( + event = <-sink txHash = event.Raw.TxHash - } - + ) _, isPending, err := s.RPCClient.L1.TransactionByHash(context.Background(), txHash) s.Nil(err) s.False(isPending) diff --git a/packages/taiko-client/proposer/proposer_test.go b/packages/taiko-client/proposer/proposer_test.go index afe34def3c3..c81bfa2415a 100644 --- a/packages/taiko-client/proposer/proposer_test.go +++ b/packages/taiko-client/proposer/proposer_test.go @@ -16,23 +16,17 @@ import ( "github.com/ethereum/go-ethereum/common/math" "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/crypto" - "github.com/ethereum/go-ethereum/log" "github.com/ethereum/go-ethereum/miner" - "github.com/ethereum/go-ethereum/rlp" "github.com/stretchr/testify/suite" "github.com/taikoxyz/taiko-mono/packages/taiko-client/bindings" - "github.com/taikoxyz/taiko-mono/packages/taiko-client/bindings/encoding" "github.com/taikoxyz/taiko-mono/packages/taiko-client/bindings/metadata" "github.com/taikoxyz/taiko-mono/packages/taiko-client/driver/chain_syncer/beaconsync" "github.com/taikoxyz/taiko-mono/packages/taiko-client/driver/chain_syncer/blob" "github.com/taikoxyz/taiko-mono/packages/taiko-client/driver/state" "github.com/taikoxyz/taiko-mono/packages/taiko-client/internal/testutils" - "github.com/taikoxyz/taiko-mono/packages/taiko-client/pkg/config" "github.com/taikoxyz/taiko-mono/packages/taiko-client/pkg/jwt" "github.com/taikoxyz/taiko-mono/packages/taiko-client/pkg/rpc" - "github.com/taikoxyz/taiko-mono/packages/taiko-client/pkg/utils" - builder "github.com/taikoxyz/taiko-mono/packages/taiko-client/proposer/transaction_builder" ) type ProposerTestSuite struct { @@ -244,58 +238,6 @@ func (s *ProposerTestSuite) TestTxPoolContentWithMinTip() { s.Nil(s.s.ProcessL1Blocks(context.Background())) } -func (s *ProposerTestSuite) TestProposeTxLists() { - p := s.p - ctx := p.ctx - cfg := s.p.Config - - txBuilder := builder.NewBlobTransactionBuilder( - p.rpc, - p.L1ProposerPrivKey, - cfg.TaikoL1Address, - cfg.ProverSetAddress, - cfg.L2SuggestedFeeRecipient, - cfg.ProposeBlockTxGasLimit, - cfg.ExtraData, - config.NewChainConfig(s.p.protocolConfigs), - false, - ) - - emptyTxListBytes, err := rlp.EncodeToBytes(types.Transactions{}) - s.Nil(err) - txListsBytes := [][]byte{emptyTxListBytes} - txCandidates := make([]txmgr.TxCandidate, len(txListsBytes)) - for i, txListBytes := range txListsBytes { - compressedTxListBytes, err := utils.Compress(txListBytes) - if err != nil { - log.Warn("Failed to compress transactions list", "index", i, "error", err) - break - } - - candidate, err := txBuilder.BuildLegacy( - p.ctx, - p.IncludeParentMetaHash, - compressedTxListBytes, - ) - if err != nil { - log.Warn("Failed to build TaikoL1.proposeBlock transaction", "error", err) - break - } - - // trigger the error - candidate.GasLimit = 10_000_000 - - txCandidates[i] = *candidate - } - - for _, txCandidate := range txCandidates { - txMgr, _ := p.txmgrSelector.Select() - receipt, err := txMgr.Send(ctx, txCandidate) - s.Nil(err) - s.Nil(encoding.TryParsingCustomErrorFromReceipt(ctx, p.rpc.L1, p.proposerAddress, receipt)) - } -} - func (s *ProposerTestSuite) TestProposeOpNoEmptyBlock() { // TODO: Temporarily skip this test case when using l2_reth node. if os.Getenv("L2_NODE") == "l2_reth" { @@ -363,24 +305,14 @@ func (s *ProposerTestSuite) TestName() { func (s *ProposerTestSuite) TestProposeOp() { // Propose txs in L2 execution engine's mempool - sink := make(chan *bindings.TaikoL1ClientBlockProposed) - - sub, err := s.p.rpc.TaikoL1.WatchBlockProposed(nil, sink, nil, nil) + sink := make(chan *bindings.TaikoL1ClientBlockProposedV2) + sub, err := s.p.rpc.TaikoL1.WatchBlockProposedV2(nil, sink, nil) s.Nil(err) defer func() { sub.Unsubscribe() close(sink) }() - sink2 := make(chan *bindings.TaikoL1ClientBlockProposedV2) - - sub2, err := s.p.rpc.TaikoL1.WatchBlockProposedV2(nil, sink2, nil) - s.Nil(err) - defer func() { - sub2.Unsubscribe() - close(sink2) - }() - to := common.BytesToAddress(testutils.RandomBytes(32)) _, err = testutils.SendDynamicFeeTx(s.p.rpc.L2, s.TestAddrPrivKey, &to, common.Big1, nil) s.Nil(err) @@ -388,15 +320,9 @@ func (s *ProposerTestSuite) TestProposeOp() { s.Nil(s.p.ProposeOp(context.Background())) var ( - meta metadata.TaikoBlockMetaData + event = <-sink + meta = metadata.NewTaikoDataBlockMetadataOntake(event) ) - select { - case event := <-sink: - meta = metadata.NewTaikoDataBlockMetadataLegacy(event) - case event := <-sink2: - meta = metadata.NewTaikoDataBlockMetadataOntake(event) - } - s.Equal(meta.GetCoinbase(), s.p.L2SuggestedFeeRecipient) _, isPending, err := s.p.rpc.L1.TransactionByHash(context.Background(), meta.GetTxHash()) diff --git a/packages/taiko-client/prover/proof_producer/dummy_producer_test.go b/packages/taiko-client/prover/proof_producer/dummy_producer_test.go index e2361ae9cc8..4977e2c6c75 100644 --- a/packages/taiko-client/prover/proof_producer/dummy_producer_test.go +++ b/packages/taiko-client/prover/proof_producer/dummy_producer_test.go @@ -37,7 +37,7 @@ func TestDummyProducerRequestProof(t *testing.T) { res, err := producer.RequestProof( &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, tier, time.Now(), diff --git a/packages/taiko-client/prover/proof_producer/guardian_producer_test.go b/packages/taiko-client/prover/proof_producer/guardian_producer_test.go index 85d0663e000..1697e763ad7 100644 --- a/packages/taiko-client/prover/proof_producer/guardian_producer_test.go +++ b/packages/taiko-client/prover/proof_producer/guardian_producer_test.go @@ -40,7 +40,7 @@ func TestGuardianProducerRequestProof(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) @@ -79,7 +79,7 @@ func TestGuardianProducerRequestProofReturnLivenessBond(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) @@ -118,7 +118,7 @@ func TestMinorityRequestProof(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) @@ -156,7 +156,7 @@ func TestRequestMinorityProofReturnLivenessBond(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) diff --git a/packages/taiko-client/prover/proof_producer/optimistic_producer_test.go b/packages/taiko-client/prover/proof_producer/optimistic_producer_test.go index f5d756fff6d..372de77a2b4 100644 --- a/packages/taiko-client/prover/proof_producer/optimistic_producer_test.go +++ b/packages/taiko-client/prover/proof_producer/optimistic_producer_test.go @@ -41,7 +41,7 @@ func TestOptimisticRequestProof(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) @@ -79,7 +79,7 @@ func TestProofCancel(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) diff --git a/packages/taiko-client/prover/proof_producer/sgx_producer_test.go b/packages/taiko-client/prover/proof_producer/sgx_producer_test.go index 6b68cd57e09..19114cb4eec 100644 --- a/packages/taiko-client/prover/proof_producer/sgx_producer_test.go +++ b/packages/taiko-client/prover/proof_producer/sgx_producer_test.go @@ -39,7 +39,7 @@ func TestSGXProducerRequestProof(t *testing.T) { context.Background(), &ProofRequestOptions{}, blockID, - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, header, time.Now(), ) diff --git a/packages/taiko-client/prover/proof_submitter/proof_contester_test.go b/packages/taiko-client/prover/proof_submitter/proof_contester_test.go index feaee51a60c..6c836a2b5f3 100644 --- a/packages/taiko-client/prover/proof_submitter/proof_contester_test.go +++ b/packages/taiko-client/prover/proof_submitter/proof_contester_test.go @@ -17,7 +17,7 @@ func (s *ProofSubmitterTestSuite) TestSubmitContestNoTransition() { common.Big256, common.Big1, testutils.RandomHash(), - &metadata.TaikoDataBlockMetadataLegacy{}, + &metadata.TaikoDataBlockMetadataOntake{}, encoding.TierOptimisticID, ), ) diff --git a/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go b/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go index be076f01efb..bbf390dc088 100644 --- a/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go +++ b/packages/taiko-client/prover/proof_submitter/proof_submitter_test.go @@ -245,7 +245,7 @@ func (s *ProofSubmitterTestSuite) TestProofSubmitterRequestProofDeadlineExceeded s.ErrorContains( s.submitter.RequestProof( ctx, - &metadata.TaikoDataBlockMetadataLegacy{TaikoDataBlockMetadata: bindings.TaikoDataBlockMetadata{Id: 256}}, + &metadata.TaikoDataBlockMetadataOntake{TaikoDataBlockMetadataV2: bindings.TaikoDataBlockMetadataV2{Id: 256}}, ), "context deadline exceeded", ) @@ -256,7 +256,7 @@ func (s *ProofSubmitterTestSuite) TestProofSubmitterSubmitProofMetadataNotFound( s.submitter.SubmitProof( context.Background(), &producer.ProofWithHeader{ BlockID: common.Big256, - Meta: &metadata.TaikoDataBlockMetadataLegacy{}, + Meta: &metadata.TaikoDataBlockMetadataOntake{}, Header: &types.Header{}, Opts: &producer.ProofRequestOptions{}, Proof: bytes.Repeat([]byte{0xff}, 100), @@ -289,7 +289,7 @@ func (s *ProofSubmitterTestSuite) TestProofSubmitterRequestProofCancelled() { s.ErrorContains( s.submitter.RequestProof( ctx, - &metadata.TaikoDataBlockMetadataLegacy{TaikoDataBlockMetadata: bindings.TaikoDataBlockMetadata{Id: 256}}, + &metadata.TaikoDataBlockMetadataOntake{TaikoDataBlockMetadataV2: bindings.TaikoDataBlockMetadataV2{Id: 256}}, ), "context canceled", ) diff --git a/packages/taiko-client/prover/prover_test.go b/packages/taiko-client/prover/prover_test.go index 638dc9b7aec..377e9816c92 100644 --- a/packages/taiko-client/prover/prover_test.go +++ b/packages/taiko-client/prover/prover_test.go @@ -182,7 +182,7 @@ func (s *ProverTestSuite) TestSubmitProofOp() { s.p.withRetry(func() error { return s.p.submitProofOp(&producer.ProofWithHeader{ BlockID: common.Big1, - Meta: &metadata.TaikoDataBlockMetadataLegacy{}, + Meta: &metadata.TaikoDataBlockMetadataOntake{}, Header: &types.Header{}, Proof: []byte{}, Tier: encoding.TierOptimisticID, @@ -194,7 +194,7 @@ func (s *ProverTestSuite) TestSubmitProofOp() { s.p.withRetry(func() error { return s.p.submitProofOp(&producer.ProofWithHeader{ BlockID: common.Big1, - Meta: &metadata.TaikoDataBlockMetadataLegacy{}, + Meta: &metadata.TaikoDataBlockMetadataOntake{}, Header: &types.Header{}, Proof: []byte{}, Tier: encoding.TierOptimisticID, @@ -229,24 +229,15 @@ func (s *ProverTestSuite) TestContestWrongBlocks() { s.Nil(s.p.initEventHandlers()) // Submit a wrong proof at first. - sink := make(chan *bindings.TaikoL1ClientTransitionProved) header, err := s.p.rpc.L2.HeaderByNumber(context.Background(), m.GetBlockID()) s.Nil(err) - - sub, err := s.p.rpc.TaikoL1.WatchTransitionProved(nil, sink, nil) + sink := make(chan *bindings.TaikoL1ClientTransitionProvedV2) + sub, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink, nil) s.Nil(err) defer func() { sub.Unsubscribe() close(sink) }() - - sink2 := make(chan *bindings.TaikoL1ClientTransitionProvedV2) - sub2, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink2, nil) - s.Nil(err) - defer func() { - sub2.Unsubscribe() - close(sink2) - }() s.Nil(s.p.proveOp()) req := <-s.p.proofSubmissionCh s.Nil(s.p.requestProofOp(req.Meta, req.Tier)) @@ -254,34 +245,20 @@ func (s *ProverTestSuite) TestContestWrongBlocks() { proofWithHeader.Opts.BlockHash = testutils.RandomHash() s.Nil(s.p.selectSubmitter(m.GetMinTier()).SubmitProof(context.Background(), proofWithHeader)) - var event *bindings.TaikoL1ClientTransitionProvedV2 - select { - case e := <-sink: - blockInfo, err := s.p.rpc.TaikoL1.GetBlock(nil, e.BlockId.Uint64()) - s.Nil(err) - event = encoding.TransitionProvedEventToV2(e, blockInfo.ProposedIn) - case e := <-sink2: - event = e - } + event := <-sink s.Equal(header.Number.Uint64(), event.BlockId.Uint64()) s.Equal(common.BytesToHash(proofWithHeader.Opts.BlockHash[:]), common.BytesToHash(event.Tran.BlockHash[:])) s.NotEqual(header.Hash(), common.BytesToHash(event.Tran.BlockHash[:])) s.Equal(header.ParentHash, common.BytesToHash(event.Tran.ParentHash[:])) // Contest the transition. - contestedSink := make(chan *bindings.TaikoL1ClientTransitionContested) - contestedSink2 := make(chan *bindings.TaikoL1ClientTransitionContestedV2) - - contestedSub, err := s.p.rpc.TaikoL1.WatchTransitionContested(nil, contestedSink, nil) - s.Nil(err) - contestedSub2, err := s.p.rpc.TaikoL1.WatchTransitionContestedV2(nil, contestedSink2, nil) + contestedSink := make(chan *bindings.TaikoL1ClientTransitionContestedV2) + contestedSub, err := s.p.rpc.TaikoL1.WatchTransitionContestedV2(nil, contestedSink, nil) s.Nil(err) defer func() { contestedSub.Unsubscribe() close(contestedSink) - contestedSub2.Unsubscribe() - close(contestedSink2) }() contesterKey, err := crypto.ToECDSA(common.FromHex(os.Getenv("L1_CONTRACT_OWNER_PRIVATE_KEY"))) @@ -295,15 +272,7 @@ func (s *ProverTestSuite) TestContestWrongBlocks() { contestReq := <-s.p.proofContestCh s.Nil(s.p.contestProofOp(contestReq)) - var contestedEvent *bindings.TaikoL1ClientTransitionContestedV2 - select { - case e := <-contestedSink: - blockInfo, err := s.p.rpc.TaikoL1.GetBlock(nil, e.BlockId.Uint64()) - s.Nil(err) - contestedEvent = encoding.TransitionContestedEventToV2(e, blockInfo.ProposedIn) - case e := <-contestedSink2: - contestedEvent = e - } + contestedEvent := <-contestedSink s.Equal(header.Number.Uint64(), contestedEvent.BlockId.Uint64()) s.Equal(header.Hash(), common.BytesToHash(contestedEvent.Tran.BlockHash[:])) s.Equal(header.ParentHash, common.BytesToHash(contestedEvent.Tran.ParentHash[:])) @@ -376,18 +345,12 @@ func (s *ProverTestSuite) TestProveOp() { header, err := s.p.rpc.L2.HeaderByNumber(context.Background(), m.GetBlockID()) s.Nil(err) - sink := make(chan *bindings.TaikoL1ClientTransitionProved) - sink2 := make(chan *bindings.TaikoL1ClientTransitionProvedV2) - - sub, err := s.p.rpc.TaikoL1.WatchTransitionProved(nil, sink, nil) - s.Nil(err) - sub2, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink2, nil) + sink := make(chan *bindings.TaikoL1ClientTransitionProvedV2) + sub, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink, nil) s.Nil(err) defer func() { sub.Unsubscribe() - sub2.Unsubscribe() close(sink) - close(sink2) }() s.Nil(s.p.proveOp()) @@ -395,13 +358,8 @@ func (s *ProverTestSuite) TestProveOp() { s.Nil(s.p.requestProofOp(req.Meta, req.Tier)) s.Nil(s.p.selectSubmitter(m.GetMinTier()).SubmitProof(context.Background(), <-s.p.proofGenerationCh)) - var tran bindings.TaikoDataTransition - select { - case event := <-sink: - tran = event.Tran - case event := <-sink2: - tran = event.Tran - } + event := <-sink + tran := event.Tran s.Equal(header.Hash(), common.BytesToHash(tran.BlockHash[:])) s.Equal(header.ParentHash, common.BytesToHash(tran.ParentHash[:])) } @@ -521,12 +479,12 @@ func (s *ProverTestSuite) TestAggregateProofsAlreadyProved() { _ = s.ProposeAndInsertValidBlock(s.proposer, s.d.ChainSyncer().BlobSyncer()) } - sink2 := make(chan *bindings.TaikoL1ClientTransitionProvedV2, batchSize) - sub2, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink2, nil) + sink := make(chan *bindings.TaikoL1ClientTransitionProvedV2, batchSize) + sub, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink, nil) s.Nil(err) defer func() { - sub2.Unsubscribe() - close(sink2) + sub.Unsubscribe() + close(sink) }() s.Nil(s.p.proveOp()) @@ -545,7 +503,7 @@ func (s *ProverTestSuite) TestAggregateProofsAlreadyProved() { proofSubmitter.ErrInvalidProof, ) for i := 0; i < batchSize; i++ { - <-sink2 + <-sink } } @@ -581,12 +539,12 @@ func (s *ProverTestSuite) TestAggregateProofs() { _ = s.ProposeAndInsertValidBlock(s.proposer, s.d.ChainSyncer().BlobSyncer()) } - sink2 := make(chan *bindings.TaikoL1ClientTransitionProvedV2, batchSize) - sub2, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink2, nil) + sink := make(chan *bindings.TaikoL1ClientTransitionProvedV2, batchSize) + sub, err := s.p.rpc.TaikoL1.WatchTransitionProvedV2(nil, sink, nil) s.Nil(err) defer func() { - sub2.Unsubscribe() - close(sink2) + sub.Unsubscribe() + close(sink) }() s.Nil(batchProver.proveOp()) @@ -598,7 +556,7 @@ func (s *ProverTestSuite) TestAggregateProofs() { s.Nil(batchProver.aggregateOp(tier)) s.Nil(batchProver.selectSubmitter(tier).BatchSubmitProofs(context.Background(), <-batchProver.batchProofGenerationCh)) for i := 0; i < batchSize; i++ { - <-sink2 + <-sink } } From 842f8122305f8cbf3153bb645e3107abb4af3cf4 Mon Sep 17 00:00:00 2001 From: Gavin Yu Date: Thu, 26 Dec 2024 16:14:48 +0800 Subject: [PATCH 24/29] feat(taiko-client): revert pr-18571 (#18648) --- packages/taiko-client/cmd/flags/driver.go | 10 +++++++++- .../driver/chain_syncer/chain_syncer.go | 16 ++++++++++++---- .../driver/chain_syncer/chain_syncer_test.go | 1 + packages/taiko-client/driver/config.go | 9 ++++++--- packages/taiko-client/driver/config_test.go | 4 ++++ packages/taiko-client/driver/driver.go | 3 ++- 6 files changed, 34 insertions(+), 9 deletions(-) diff --git a/packages/taiko-client/cmd/flags/driver.go b/packages/taiko-client/cmd/flags/driver.go index 67ddc823fbe..3c28dc7571a 100644 --- a/packages/taiko-client/cmd/flags/driver.go +++ b/packages/taiko-client/cmd/flags/driver.go @@ -8,6 +8,14 @@ import ( // Optional flags used by driver. var ( + P2PSync = &cli.BoolFlag{ + Name: "p2p.sync", + Usage: "Try P2P syncing blocks between L2 execution engines, " + + "will be helpful to bring a new node online quickly", + Value: false, + Category: driverCategory, + EnvVars: []string{"P2P_SYNC"}, + } P2PSyncTimeout = &cli.DurationFlag{ Name: "p2p.syncTimeout", Usage: "P2P syncing timeout, if no sync progress is made within this time span, " + @@ -19,7 +27,6 @@ var ( CheckPointSyncURL = &cli.StringFlag{ Name: "p2p.checkPointSyncUrl", Usage: "HTTP RPC endpoint of another synced L2 execution engine node", - Required: true, Category: driverCategory, EnvVars: []string{"P2P_CHECK_POINT_SYNC_URL"}, } @@ -53,6 +60,7 @@ var DriverFlags = MergeFlags(CommonFlags, []cli.Flag{ L2WSEndpoint, L2AuthEndpoint, JWTSecret, + P2PSync, P2PSyncTimeout, CheckPointSyncURL, MaxExponent, diff --git a/packages/taiko-client/driver/chain_syncer/chain_syncer.go b/packages/taiko-client/driver/chain_syncer/chain_syncer.go index ab9f36b43d6..6e17215d73d 100644 --- a/packages/taiko-client/driver/chain_syncer/chain_syncer.go +++ b/packages/taiko-client/driver/chain_syncer/chain_syncer.go @@ -32,6 +32,10 @@ type L2ChainSyncer struct { // Sync mode syncMode string + + // If this flag is activated, will try P2P beacon sync if current node is behind of the protocol's + // the latest verified block head + p2pSync bool } // New creates a new chain syncer instance. @@ -39,6 +43,7 @@ func New( ctx context.Context, rpc *rpc.Client, state *state.State, + p2pSync bool, p2pSyncTimeout time.Duration, maxRetrieveExponent uint64, blobServerEndpoint *url.URL, @@ -73,6 +78,7 @@ func New( blobSyncer: blobSyncer, progressTracker: tracker, syncMode: syncMode, + p2pSync: p2pSync, }, nil } @@ -98,6 +104,7 @@ func (s *L2ChainSyncer) Sync() error { if s.progressTracker.Triggered() { log.Info( "Switch to insert pending blocks one by one", + "p2pEnabled", s.p2pSync, "p2pOutOfSync", s.progressTracker.OutOfSync(), ) @@ -163,12 +170,13 @@ func (s *L2ChainSyncer) AheadOfHeadToSync(heightToSync uint64) bool { // needNewBeaconSyncTriggered checks whether the current L2 execution engine needs to trigger // another new beacon sync, the following conditions should be met: -// 1. The protocol's latest verified block head is not zero. -// 2. The L2 execution engine's chain is behind of the protocol's latest verified block head. -// 3. The L2 execution engine's chain has met a sync timeout issue. +// 1. The `P2PSync` flag is set. +// 2. The protocol's latest verified block head is not zero. +// 3. The L2 execution engine's chain is behind of the protocol's latest verified block head. +// 4. The L2 execution engine's chain has met a sync timeout issue. func (s *L2ChainSyncer) needNewBeaconSyncTriggered() (uint64, bool, error) { // If the flag is not set or there was a finished beacon sync, we simply return false. - if s.progressTracker.Finished() { + if !s.p2pSync || s.progressTracker.Finished() { return 0, false, nil } diff --git a/packages/taiko-client/driver/chain_syncer/chain_syncer_test.go b/packages/taiko-client/driver/chain_syncer/chain_syncer_test.go index f18e10b7b23..5327317f02e 100644 --- a/packages/taiko-client/driver/chain_syncer/chain_syncer_test.go +++ b/packages/taiko-client/driver/chain_syncer/chain_syncer_test.go @@ -39,6 +39,7 @@ func (s *ChainSyncerTestSuite) SetupTest() { context.Background(), s.RPCClient, state, + false, 1*time.Hour, 0, nil, diff --git a/packages/taiko-client/driver/config.go b/packages/taiko-client/driver/config.go index 418e3c8a7a6..3eb3b95e236 100644 --- a/packages/taiko-client/driver/config.go +++ b/packages/taiko-client/driver/config.go @@ -17,6 +17,7 @@ import ( // Config contains the configurations to initialize a Taiko driver. type Config struct { *rpc.ClientConfig + P2PSync bool P2PSyncTimeout time.Duration RetryInterval time.Duration MaxExponent uint64 @@ -33,10 +34,11 @@ func NewConfigFromCliContext(c *cli.Context) (*Config, error) { } var ( + p2pSync = c.Bool(flags.P2PSync.Name) l2CheckPoint = c.String(flags.CheckPointSyncURL.Name) ) - if len(l2CheckPoint) == 0 { + if p2pSync && len(l2CheckPoint) == 0 { return nil, errors.New("empty L2 check point URL") } @@ -63,8 +65,8 @@ func NewConfigFromCliContext(c *cli.Context) (*Config, error) { } } - if beaconEndpoint == "" { - return nil, errors.New("empty L1 beacon endpoint") + if beaconEndpoint == "" && blobServerEndpoint == nil && socialScanEndpoint == nil { + return nil, errors.New("empty L1 beacon endpoint, blob server and Social Scan endpoint") } var timeout = c.Duration(flags.RPCTimeout.Name) @@ -81,6 +83,7 @@ func NewConfigFromCliContext(c *cli.Context) (*Config, error) { Timeout: timeout, }, RetryInterval: c.Duration(flags.BackOffRetryInterval.Name), + P2PSync: p2pSync, P2PSyncTimeout: c.Duration(flags.P2PSyncTimeout.Name), MaxExponent: c.Uint64(flags.MaxExponent.Name), BlobServerEndpoint: blobServerEndpoint, diff --git a/packages/taiko-client/driver/config_test.go b/packages/taiko-client/driver/config_test.go index 829501f038c..f65359467dd 100644 --- a/packages/taiko-client/driver/config_test.go +++ b/packages/taiko-client/driver/config_test.go @@ -34,6 +34,7 @@ func (s *DriverTestSuite) TestNewConfigFromCliContext() { s.Equal(taikoL2, c.TaikoL2Address.String()) s.Equal(120*time.Second, c.P2PSyncTimeout) s.NotEmpty(c.JwtSecret) + s.True(c.P2PSync) s.Equal(l2CheckPoint, c.L2CheckPoint) s.Nil(new(Driver).InitFromCli(context.Background(), ctx)) @@ -51,6 +52,7 @@ func (s *DriverTestSuite) TestNewConfigFromCliContext() { "--" + flags.JWTSecret.Name, os.Getenv("JWT_SECRET"), "--" + flags.P2PSyncTimeout.Name, "120s", "--" + flags.RPCTimeout.Name, "5s", + "--" + flags.P2PSync.Name, "--" + flags.CheckPointSyncURL.Name, l2CheckPoint, })) } @@ -68,6 +70,7 @@ func (s *DriverTestSuite) TestNewConfigFromCliContextEmptyL2CheckPoint() { s.ErrorContains(app.Run([]string{ "TestNewConfigFromCliContext", "--" + flags.JWTSecret.Name, os.Getenv("JWT_SECRET"), + "--" + flags.P2PSync.Name, "--" + flags.L2WSEndpoint.Name, "", }), "empty L2 check point URL") } @@ -82,6 +85,7 @@ func (s *DriverTestSuite) SetupApp() *cli.App { &cli.StringFlag{Name: flags.TaikoL1Address.Name}, &cli.StringFlag{Name: flags.TaikoL2Address.Name}, &cli.StringFlag{Name: flags.JWTSecret.Name}, + &cli.BoolFlag{Name: flags.P2PSync.Name}, &cli.DurationFlag{Name: flags.P2PSyncTimeout.Name}, &cli.DurationFlag{Name: flags.RPCTimeout.Name}, &cli.StringFlag{Name: flags.CheckPointSyncURL.Name}, diff --git a/packages/taiko-client/driver/driver.go b/packages/taiko-client/driver/driver.go index 50bba29e016..a5990139dcb 100644 --- a/packages/taiko-client/driver/driver.go +++ b/packages/taiko-client/driver/driver.go @@ -69,7 +69,7 @@ func (d *Driver) InitFromConfig(ctx context.Context, cfg *Config) (err error) { return err } - if peers == 0 { + if cfg.P2PSync && peers == 0 { log.Warn("P2P syncing verified blocks enabled, but no connected peer found in L2 execution engine") } @@ -77,6 +77,7 @@ func (d *Driver) InitFromConfig(ctx context.Context, cfg *Config) (err error) { d.ctx, d.rpc, d.state, + cfg.P2PSync, cfg.P2PSyncTimeout, cfg.MaxExponent, cfg.BlobServerEndpoint, From 5b5dc4657619886ac07bd6fab22d9ff6ab96e166 Mon Sep 17 00:00:00 2001 From: David Date: Thu, 26 Dec 2024 18:48:42 +0800 Subject: [PATCH 25/29] ci(taiko-client): release client as `"taiko-alethia-client"` (#18651) --- .release-please-manifest.json | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.release-please-manifest.json b/.release-please-manifest.json index f175c355e98..0bd96c987db 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -9,7 +9,10 @@ "packages/relayer": "0.12.0", "packages/snaefell-ui": "1.1.0", "packages/supplementary-contracts": "1.0.0", - "packages/taiko-client": "0.40.0", + "packages/taiko-client": { + "component": "taiko-alethia-client", + "version": "0.40.0" + }, "packages/taikoon-ui": "1.3.0", "packages/ui-lib": "1.0.0" } From 304d9487cd5a6901f55179bef4d91efbd753a278 Mon Sep 17 00:00:00 2001 From: Daniel Wang <99078276+dantaik@users.noreply.github.com> Date: Thu, 26 Dec 2024 19:39:21 +0800 Subject: [PATCH 26/29] ci(protocol): improve check-links (#18652) --- .github/workflows/repo--check-links.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/repo--check-links.yml b/.github/workflows/repo--check-links.yml index c7d64802bd6..2c85b712486 100644 --- a/.github/workflows/repo--check-links.yml +++ b/.github/workflows/repo--check-links.yml @@ -3,7 +3,7 @@ name: Check links on: push: paths: - - '**/README.md' + - "**/README.md" - docs/** jobs: @@ -17,4 +17,4 @@ jobs: - name: Check links uses: lycheeverse/lychee-action@v2 with: - args: --no-progress --verbose --user-agent 'Mozilla/5.0 (compatible; TaikoLinkChecker/1.0; +https://taiko.xyz)' '**/README.md' + args: --no-progress --verbose --max-retries 3 --retry-delay 2 --exclude "etherscan.io" --user-agent 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3' '**/README.md' From 4de2f7cc6121309fc426b53b0f48417e64b4a584 Mon Sep 17 00:00:00 2001 From: dionysuz <13951458+dionysuzx@users.noreply.github.com> Date: Thu, 26 Dec 2024 21:14:29 -0500 Subject: [PATCH 27/29] fix(repo): improve link checking (#18653) --- .github/workflows/repo--check-links.yml | 2 +- lychee.toml | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/repo--check-links.yml b/.github/workflows/repo--check-links.yml index 2c85b712486..44be99f6d9a 100644 --- a/.github/workflows/repo--check-links.yml +++ b/.github/workflows/repo--check-links.yml @@ -17,4 +17,4 @@ jobs: - name: Check links uses: lycheeverse/lychee-action@v2 with: - args: --no-progress --verbose --max-retries 3 --retry-delay 2 --exclude "etherscan.io" --user-agent 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3' '**/README.md' + args: --no-progress --verbose "**/README.md" diff --git a/lychee.toml b/lychee.toml index c95a4fac4cd..9ba6633e075 100644 --- a/lychee.toml +++ b/lychee.toml @@ -1 +1,2 @@ exclude_path = ["node_modules"] +exclude = ["etherscan.io"] From fd9fe97b4a400e34a3dd3bc77e4865f84e4c552f Mon Sep 17 00:00:00 2001 From: dionysuz <13951458+dionysuzx@users.noreply.github.com> Date: Thu, 26 Dec 2024 21:19:44 -0500 Subject: [PATCH 28/29] ci(repo): fix release-please (#18654) Co-authored-by: Daniel Wang <99078276+dantaik@users.noreply.github.com> --- .release-please-manifest.json | 5 +---- release-please-config.json | 8 ++++++-- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 0bd96c987db..f175c355e98 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -9,10 +9,7 @@ "packages/relayer": "0.12.0", "packages/snaefell-ui": "1.1.0", "packages/supplementary-contracts": "1.0.0", - "packages/taiko-client": { - "component": "taiko-alethia-client", - "version": "0.40.0" - }, + "packages/taiko-client": "0.40.0", "packages/taikoon-ui": "1.3.0", "packages/ui-lib": "1.0.0" } diff --git a/release-please-config.json b/release-please-config.json index 2d69ef058de..fff43beb15e 100644 --- a/release-please-config.json +++ b/release-please-config.json @@ -22,9 +22,13 @@ "packages/fork-diff": {}, "packages/guardian-prover-health-check": {}, "packages/guardian-prover-health-check-ui": {}, - "packages/protocol": {}, + "packages/protocol": { + "package-name": "taiko-alethia-protocol" + }, "packages/relayer": {}, - "packages/taiko-client": {}, + "packages/taiko-client": { + "package-name": "taiko-alethia-client" + }, "packages/ui-lib": {} } } From 8d2cca11180bd615420e9bb3287f31a9ddf18df8 Mon Sep 17 00:00:00 2001 From: Daniel Wang <99078276+dantaik@users.noreply.github.com> Date: Fri, 27 Dec 2024 10:26:44 +0800 Subject: [PATCH 29/29] docs(repo): update `README` (#18650) Co-authored-by: dionysuz <13951458+dionysuzx@users.noreply.github.com> --- README.md | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index ff647347278..8ba1fea61f9 100644 --- a/README.md +++ b/README.md @@ -3,11 +3,11 @@

- Taiko + Taiko Alethia

- A based rollup. + The first based rollup.

@@ -23,11 +23,11 @@ ## Documentation -Get started with Taiko: +Get started with Taiko Alethia: -- [Taiko docs](https://docs.taiko.xyz) — High-level concepts, guides, resources, and reference pages for getting started. -- [Protocol specs](./packages/protocol/docs/README.md) — In-depth specifications of the Taiko protocol for deeper understanding. -- [Smart contracts](./packages/protocol/contracts/) — Taiko protocol smart contracts, fully documented with NatSpec. +- [Taiko Alethia docs](https://docs.taiko.xyz) — High-level concepts, guides, resources, and reference pages for getting started. +- [Protocol specs](./packages/protocol/docs/README.md) — In-depth specifications of the Taiko Alethia protocol for deeper understanding. +- [Smart contracts](./packages/protocol/contracts/) — Taiko Alethia protocol smart contracts, fully documented with NatSpec. ## Packages @@ -47,11 +47,11 @@ Get started with Taiko: | [guardian-prover-health-check-ui](./packages/guardian-prover-health-check-ui) | Guardian prover health check UI. | | [monitors](./packages/monitors) | Monitoring and alerting services. | | [nfts](./packages/nfts) | NFT-related smart contracts and utilities. | -| [protocol](./packages/protocol) | Taiko protocol smart contracts. | +| [protocol](./packages/protocol) | Taiko Alethia protocol smart contracts. | | [relayer](./packages/relayer) | Bridge backend relayer. | | [snaefell-ui](./packages/snaefell-ui) | Snaefell UI. | -| [supplementary-contracts](./packages/supplementary-contracts) | Supplementary contracts not part of the Taiko protocol. | -| [taiko-client](./packages/taiko-client) | Taiko client implementation in Go. | +| [supplementary-contracts](./packages/supplementary-contracts) | Supplementary contracts not part of the Taiko Alethia protocol. | +| [taiko-client](./packages/taiko-client) | Taiko Alethia client implementation in Go. | | [taikoon-ui](./packages/taikoon-ui) | Taikoon UI. | | [ui-lib](./packages/ui-lib) | UI library. |