Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: integrate authenticated calls smart contract functionality into protocol #2904

Merged
merged 34 commits into from
Sep 27, 2024

Conversation

skosito
Copy link
Contributor

@skosito skosito commented Sep 20, 2024

Description

Integrates this zeta-chain/protocol-contracts#344 into protocol, this PR should be merged after smart contract changes are merged, but this is ready for first pass.

Also e2e tests to call zevm->evm, using call and withdrawAndCall and authenticated sender, with checking if sender is properly forwarded, so destination contract can use it as authentication.

How Has This Been Tested?

  • Tested CCTX in localnet
  • Tested in development environment
  • Go unit tests
  • Go integration tests
  • Tested via GitHub Actions

Summary by CodeRabbit

  • New Features

    • Introduced new test cases for Ethereum and ZEVM authenticated calls, enhancing the testing framework.
    • Added new functions in the TestDAppV2 contract for improved message handling and sender management.
    • New TestGatewayZEVMCaller contract facilitates interactions with a gateway on the ZEVM.
  • Bug Fixes

    • Updated function signatures to improve parameter handling and streamline event processing.
  • Documentation

    • Updated comments and descriptions to clarify new functionalities and parameters across various files.
  • Chores

    • Updated dependency versions in go.mod for improved stability and performance.

Copy link
Contributor

coderabbitai bot commented Sep 20, 2024

Important

Review skipped

Auto incremental reviews are disabled on this repository.

Please check the settings in the CodeRabbit UI or the .coderabbit.yaml file in this repository. To trigger a single review, invoke the @coderabbitai review command.

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

📝 Walkthrough
📝 Walkthrough
📝 Walkthrough
📝 Walkthrough
📝 Walkthrough
📝 Walkthrough
📝 Walkthrough
📝 Walkthrough

Walkthrough

The pull request introduces significant enhancements to the testing framework for the V2 smart contract functionality within the application. It adds multiple new test cases focused on authenticated calls for both ETH and ZEVM transactions, expands the capabilities of the E2ERunner struct, and modifies several related files to accommodate these changes. Additionally, the contract's ABI and implementation files are updated to support new functionalities related to message handling and sender validation.

Changes

File Path Change Summary
cmd/zetae2e/local/v2.go Added new test cases to startV2Tests for ETH and ZEVM authenticated calls.
e2e/e2etests/e2etests.go Introduced new tests for ETH withdrawals and ZEVM calls, expanding the existing test suite.
e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call.go Added a test function to validate ETH withdrawal and authenticated calls.
e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call_through_contract.go Implemented a test for ETH withdrawal through a contract, including success and failure scenarios.
e2e/e2etests/test_v2_zevm_to_evm_authenticated_call.go Added a test for authenticated calls from ZEVM to EVM, validating sender and message handling.
e2e/e2etests/test_v2_zevm_to_evm_authenticated_call_through_contract.go Created a test for authenticated calls through a contract, checking sender validation and revert scenarios.
e2e/e2etests/test_v2_zevm_to_evm_call.go Updated comments to reflect changes in terminology from "withdraw" to "call."
e2e/runner/v2_zevm.go Added new methods for authenticated ETH withdrawals and calls, enhancing the E2ERunner functionality.
go.mod Updated dependency versions and added new dependencies related to the project.
pkg/contracts/testdappv2/TestDAppV2.abi Expanded the contract's ABI with new functions for message handling and sender validation.
pkg/contracts/testdappv2/TestDAppV2.go Introduced new methods and structures for managing message contexts and expected senders.
pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.abi Added ABI definitions for new contract functions related to gateway interactions.
pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.go Provided Go bindings for the new contract, enabling interactions with the gateway.
proto/zetachain/zetacore/crosschain/cross_chain_tx.proto Added a new boolean field is_arbitrary_call to the OutboundParams message.
x/crosschain/types/message_vote_inbound.go Updated the NewMsgVoteInbound function to include a new boolean parameter for message handling.
zetaclient/chains/evm/signer/v2_sign.go Modified the signGatewayExecute function to handle different scenarios based on the IsArbitraryCall property.

Possibly related PRs

Suggested labels

E2E, V2_MIGRATION_TESTS, ADMIN_TESTS

Suggested reviewers

  • kingpinXD
  • fbac
  • swift1337
  • lumtis
  • brewmaster012
  • ws4charlie

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@skosito skosito changed the title e2e tests and modifications for authenticated call [draft] feat: authenticated zevm -> evm call and e2e tests [draft] Sep 20, 2024
@skosito skosito added the V2_TESTS Run make start-v2-test label Sep 20, 2024
go.mod Show resolved Hide resolved
@skosito skosito changed the title feat: authenticated zevm -> evm call and e2e tests [draft] feat: authenticated zevm -> evm call and e2e tests Sep 20, 2024
@skosito skosito marked this pull request as ready for review September 20, 2024 18:41
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 33

Outside diff range and nitpick comments (14)
zetaclient/chains/evm/observer/v2_inbound.go (2)

194-194: Consider using a more descriptive name for the boolean parameter.

The newly added boolean parameter is named false, which doesn't convey its purpose. Consider renaming it to something more descriptive, such as isArbitraryCall, to improve code readability and maintainability.


329-329: Consider using a more descriptive name for the boolean parameter.

Similar to the previous comment, the newly added boolean parameter is named false, which doesn't convey its purpose. Consider renaming it to something more descriptive, such as isArbitraryCall, to improve code readability and maintainability.

x/crosschain/keeper/evm_hooks.go (2)

209-209: LGTM! Consider adding a comment to explain the new parameter.

The additional boolean parameter true does not affect the current functionality but may be used for future enhancements or clarity in the function's intent. To improve code readability and maintainability, consider adding a comment to explain the purpose of the new parameter.

msg := types.NewMsgVoteInbound(
	"",
	emittingContract.Hex(),
	senderChain.ChainId,
	txOrigin,
	toAddr,
	foreignCoin.ForeignChainId,
	math.NewUintFromBigInt(event.Value),
	"",
	event.Raw.TxHash.String(),
	event.Raw.BlockNumber,
	gasLimit.Uint64(),
	foreignCoin.CoinType,
	foreignCoin.Asset,
	event.Raw.Index,
	types.ProtocolContractVersion_V1,
+	true, // TODO: Add a comment to explain the purpose of this parameter
)

290-290: LGTM! Consider adding a comment to explain the new parameter.

The additional boolean parameter true does not affect the current functionality but may be used for future enhancements or clarity in the function's intent. To improve code readability and maintainability, consider adding a comment to explain the purpose of the new parameter.

msg := types.NewMsgVoteInbound(
	"",
	emittingContract.Hex(),
	senderChain.ChainId,
	txOrigin, toAddr,
	receiverChain.ChainId,
	amount,
	messageString,
	event.Raw.TxHash.String(),
	event.Raw.BlockNumber,
	90000,
	coin.CoinType_Zeta,
	"",
	event.Raw.Index,
	types.ProtocolContractVersion_V1,
+	true, // TODO: Add a comment to explain the purpose of this parameter
)
e2e/e2etests/test_v2_zevm_to_evm_authenticated_call_through_contract.go (2)

15-15: Consider shortening the constant name for readability

The constant payloadMessageEVMAuthenticatedCallThroughContract is quite long, which may affect readability. Consider using a shorter, yet descriptive name.

For example:

-const payloadMessageEVMAuthenticatedCallThroughContract = "this is a test EVM authenticated call payload through contract"
+const testPayloadMessage = "this is a test EVM authenticated call payload through contract"

And update its usage accordingly throughout the code.


32-32: Define transfer amount as a constant for clarity

The transfer amount 100000000000000000 is hard to read and understand. Defining it as a constant with a descriptive name would improve code readability and maintainability.

For example, define the constant at the top of the file:

const transferAmount = big.NewInt(100000000000000000) // 0.1 ETH in wei

Then update the code:

-tx, err = r.ETHZRC20.Transfer(r.ZEVMAuth, gatewayCallerAddr, big.NewInt(100000000000000000))
+tx, err = r.ETHZRC20.Transfer(r.ZEVMAuth, gatewayCallerAddr, transferAmount)
e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call_through_contract.go (3)

15-15: Consider simplifying the constant name for readability.

The constant payloadMessageAuthenticatedWithdrawETHThroughContract is quite lengthy, which may affect code readability. Shortening it can make the code easier to read and maintain without losing clarity.

Consider renaming it to something more concise:

-const payloadMessageAuthenticatedWithdrawETHThroughContract = "this is a test ETH withdraw and authenticated call payload through contract"
+const payloadMsgAuthWithdrawETHThroughContract = "this is a test ETH withdraw and authenticated call payload through contract"

39-39: Define constants for large numerical values to enhance clarity.

The literal 100000000000000000 is a large numeric value that can be hard to read and prone to errors. Defining it as a constant with a descriptive name improves readability and maintainability.

Consider adding a constant:

const transferAmount = 100_000_000_000_000_000 // 0.1 ETH in wei

And update the code:

-	tx, err = r.ETHZRC20.Transfer(r.ZEVMAuth, gatewayCallerAddr, big.NewInt(100000000000000000))
+	tx, err = r.ETHZRC20.Transfer(r.ZEVMAuth, gatewayCallerAddr, big.NewInt(transferAmount))

62-68: Simplify the retrieval of senderForMsg by handling the error inline.

For brevity and improved readability, you can handle the error inline when calling SenderWithMessage, reducing the number of lines and keeping related code together.

Apply this diff to streamline the code:

-senderForMsg, err := r.TestDAppV2EVM.SenderWithMessage(
-	&bind.CallOpts{},
-	[]byte(payloadMessageAuthenticatedWithdrawETHThroughContract),
-)
+senderForMsg, err := r.TestDAppV2EVM.SenderWithMessage(&bind.CallOpts{}, []byte(payloadMessageAuthenticatedWithdrawETHThroughContract))
 require.NoError(r, err)
e2e/runner/v2_zevm.go (4)

55-56: Update function comment to match method name

The comment for V2ETHWithdrawAndAuthenticatedCall mentions V2ETHWithdrawAndCall, which is inconsistent with the method name. Please update the comment to accurately reflect the method name for clarity.

Apply this diff to correct the comment:

-// V2ETHWithdrawAndCall calls WithdrawAndCall of Gateway with gas token on ZEVM using authenticated call
+// V2ETHWithdrawAndAuthenticatedCall calls WithdrawAndCall2 of Gateway with gas token on ZEVM using authenticated call

79-81: Align function comment with method name

The comment for V2ETHWithdrawAndAuthenticatedCallThroughContract refers to V2ETHWithdrawAndCall, which does not match the method name. Please update the comment to reflect the correct method name to avoid confusion.

Apply this diff to correct the comment:

-// V2ETHWithdrawAndCall calls WithdrawAndCall of Gateway with gas token on ZEVM using authenticated call
+// V2ETHWithdrawAndAuthenticatedCallThroughContract calls WithdrawAndCall of Gateway with gas token on ZEVM using authenticated call
 // through contract

158-159: Update function comment to reflect method usage

The comment for V2ZEVMToEMVCall mentions that it calls Call of Gateway on ZEVM, but the method now uses Call0. Please update the comment to accurately describe the method being called.

Apply this diff to correct the comment:

-// V2ZEVMToEMVCall calls Call of Gateway on ZEVM
+// V2ZEVMToEMVCall calls Call0 of Gateway on ZEVM

10-11: Organize imports for clarity

To improve readability, consider grouping and ordering the import statements according to Go conventions: standard library packages first, then third-party packages, and finally local packages.

Apply this diff to organize the imports:

 package runner

+import (
+	"math/big"
+
+	ethcommon "github.com/ethereum/go-ethereum/common"
+	ethtypes "github.com/ethereum/go-ethereum/core/types"
+	"github.com/stretchr/testify/require"
+)
+
+import (
+	gatewayzevm "github.com/zeta-chain/protocol-contracts/v2/pkg/gatewayzevm.sol"
+	testgatewayzevmcaller "github.com/zeta-chain/node/pkg/contracts/testgatewayzevmcaller"
+)
e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call.go (1)

17-60: Enhance Test Readability with Inline Comments

Adding explanatory comments at key steps within the TestV2ETHWithdrawAndAuthenticatedCall function can improve clarity and assist future maintainers in understanding the test logic.

Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

Commits

Files that changed from the base of the PR and between 9b704a5 and 614df83.

Files ignored due to path filters (5)
  • go.sum is excluded by !**/*.sum
  • pkg/contracts/testdappv2/TestDAppV2.bin is excluded by !**/*.bin
  • pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.bin is excluded by !**/*.bin
  • x/crosschain/types/cross_chain_tx.pb.go is excluded by !**/*.pb.go, !**/*.pb.go
  • x/crosschain/types/tx.pb.go is excluded by !**/*.pb.go, !**/*.pb.go
Files selected for processing (30)
  • cmd/zetae2e/local/v2.go (1 hunks)
  • e2e/e2etests/e2etests.go (3 hunks)
  • e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call.go (1 hunks)
  • e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call_through_contract.go (1 hunks)
  • e2e/e2etests/test_v2_zevm_to_evm_authenticated_call.go (1 hunks)
  • e2e/e2etests/test_v2_zevm_to_evm_authenticated_call_through_contract.go (1 hunks)
  • e2e/e2etests/test_v2_zevm_to_evm_call.go (1 hunks)
  • e2e/runner/v2_zevm.go (4 hunks)
  • go.mod (2 hunks)
  • pkg/contracts/testdappv2/TestDAppV2.abi (3 hunks)
  • pkg/contracts/testdappv2/TestDAppV2.go (6 hunks)
  • pkg/contracts/testdappv2/TestDAppV2.json (4 hunks)
  • pkg/contracts/testdappv2/TestDAppV2.sol (2 hunks)
  • pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.abi (1 hunks)
  • pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.go (1 hunks)
  • pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.json (1 hunks)
  • pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.sol (1 hunks)
  • pkg/contracts/testgatewayzevmcaller/bindings.go (1 hunks)
  • proto/zetachain/zetacore/crosschain/cross_chain_tx.proto (1 hunks)
  • proto/zetachain/zetacore/crosschain/tx.proto (1 hunks)
  • x/crosschain/client/cli/tx_vote_inbound.go (1 hunks)
  • x/crosschain/keeper/evm_hooks.go (2 hunks)
  • x/crosschain/keeper/v2_zevm_inbound.go (7 hunks)
  • x/crosschain/types/cctx.go (1 hunks)
  • x/crosschain/types/message_vote_inbound.go (2 hunks)
  • x/crosschain/types/message_vote_inbound_test.go (11 hunks)
  • zetaclient/chains/evm/observer/v2_inbound.go (2 hunks)
  • zetaclient/chains/evm/signer/v2_sign.go (2 hunks)
  • zetaclient/chains/evm/signer/v2_signer.go (1 hunks)
  • zetaclient/zetacore/tx.go (1 hunks)
Additional context used
Path-based instructions (23)
cmd/zetae2e/local/v2.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/e2etests/e2etests.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call_through_contract.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/e2etests/test_v2_zevm_to_evm_authenticated_call.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/e2etests/test_v2_zevm_to_evm_authenticated_call_through_contract.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/e2etests/test_v2_zevm_to_evm_call.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

e2e/runner/v2_zevm.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

pkg/contracts/testdappv2/TestDAppV2.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

pkg/contracts/testgatewayzevmcaller/bindings.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

proto/zetachain/zetacore/crosschain/cross_chain_tx.proto (1)

Pattern **/*.proto: Review the Protobuf definitions, point out issues relative to compatibility, and expressiveness.

proto/zetachain/zetacore/crosschain/tx.proto (1)

Pattern **/*.proto: Review the Protobuf definitions, point out issues relative to compatibility, and expressiveness.

x/crosschain/client/cli/tx_vote_inbound.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

x/crosschain/keeper/evm_hooks.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

x/crosschain/keeper/v2_zevm_inbound.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

x/crosschain/types/cctx.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

x/crosschain/types/message_vote_inbound.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

x/crosschain/types/message_vote_inbound_test.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

zetaclient/chains/evm/observer/v2_inbound.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

zetaclient/chains/evm/signer/v2_sign.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

zetaclient/chains/evm/signer/v2_signer.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

zetaclient/zetacore/tx.go (1)

Pattern **/*.go: Review the Go code, point out issues relative to principles of clean code, expressiveness, and performance.

Additional comments not posted (49)
pkg/contracts/testgatewayzevmcaller/bindings.go (1)

6-8: LGTM!

The package declaration and the empty variable declaration are correct and follow the Go best practices. The empty variable declaration ensures that the package is imported and the generated bindings are included in the final binary.

e2e/e2etests/test_v2_zevm_to_evm_call.go (1)

24-24: LGTM!

The change in comment from "perform the withdraw" to "perform the call" improves the clarity and consistency of the code by aligning the comment with the actual operation being performed in the V2ZEVMToEMVCall function.

zetaclient/chains/evm/signer/v2_signer.go (1)

30-30: Approve the change and verify the impact on the destination contract.

The change correctly passes the sender's address from the inbound parameters to the signGatewayExecute function, enabling authenticated calls for the OutboundTypeGasWithdrawAndCall and OutboundTypeCall cases. This aligns with the PR objective of implementing authenticated calls between zevm and evm.

Please ensure that the corresponding changes have been made in the destination contract to handle the additional sender information for verification purposes.

Run the following script to verify the usage of the sender's address in the destination contract:

cmd/zetae2e/local/v2.go (1)

23-27: LGTM!

The addition of these test cases significantly enhances the coverage of the V2 tests by including scenarios that involve authenticated calls for both ETH and ZEVM transactions. The test names are descriptive and follow a consistent naming convention, making the test suite more comprehensive and maintainable.

These tests will help ensure the reliability and correctness of the V2 smart contract functionality, improving the overall quality of the application.

proto/zetachain/zetacore/crosschain/cross_chain_tx.proto (1)

82-82: The new field addition looks good.

The boolean field is_arbitrary_call with tag number 24 is a valid and backwards-compatible addition to the OutboundParams message. It can be used by new clients to indicate if the outbound call is arbitrary while existing clients will simply ignore it.

proto/zetachain/zetacore/crosschain/tx.proto (1)

178-179: The new field is_arbitrary_call is a valid addition to the MsgVoteInbound message.

The boolean field is correctly defined with the appropriate syntax and tag number. It appears to be used to indicate the nature of the call, providing more flexibility to the message structure. The field addition maintains compatibility with the existing message definition.

x/crosschain/keeper/v2_zevm_inbound.go (2)

Line range hint 71-213: LGTM!

The changes to the newWithdrawalInbound function improve the correctness and clarity of the code:

  • The sender's address is now correctly derived from the event parameter, addressing the past review comment.
  • The gas limit retrieval has been updated to use a more appropriate source.
  • The inclusion of event.CallOptions.IsArbitraryCall enhances the information provided by the function.

Note: The function signature change is a breaking change and may require updates to existing code that relies on the old signature.


Line range hint 247-275: LGTM!

The changes to the newCallInbound function improve the correctness and clarity of the code:

  • The sender's address is now correctly derived from the event parameter.
  • The gas limit retrieval has been updated to use a more appropriate source.
  • The inclusion of event.CallOptions.IsArbitraryCall enhances the information provided by the function.

Note: The function signature change is a breaking change and may require updates to existing code that relies on the old signature.

x/crosschain/types/cctx.go (1)

244-244: LGTM!

The addition of the IsArbitraryCall field to the outboundParams struct is a valid change that captures relevant information for the cross-chain transaction context. The field is correctly set to the value of msg.IsArbitraryCall.

x/crosschain/types/message_vote_inbound_test.go (7)

Line range hint 8-186: LGTM!

The test function TestNewMsgVoteInbound is well-structured and covers the important scenarios for testing the NewMsgVoteInbound function. The sub-tests are logically separated and test the behavior of the RevertOptions for different scenarios.


Line range hint 188-314: LGTM!

The test function TestMsgVoteInbound_ValidateBasic is well-structured and covers the important scenarios for testing the ValidateBasic method of the MsgVoteInbound struct. The table-driven test is a good approach for testing multiple scenarios in a concise manner.


Line range hint 316-424: LGTM!

The test function TestMsgVoteInbound_Digest is well-structured and covers all the important fields of the MsgVoteInbound struct. The test function ensures that the Digest method behaves as expected when different fields of the struct are modified.


Line range hint 426-462: LGTM!

The test function TestMsgVoteInbound_GetSigners is well-structured and covers the important scenarios for testing the GetSigners method of the MsgVoteInbound struct. The table-driven test is a good approach for testing multiple scenarios in a concise manner.


Line range hint 464-471: LGTM!

The test function TestMsgVoteInbound_Type is simple and straightforward. It ensures that the Type method of the MsgVoteInbound struct returns the expected result.


Line range hint 473-480: LGTM!

The test function TestMsgVoteInbound_Route is simple and straightforward. It ensures that the Route method of the MsgVoteInbound struct returns the expected result.


Line range hint 482-489: LGTM!

The test function TestMsgVoteInbound_GetSignBytes is simple and straightforward. It ensures that the GetSignBytes method of the MsgVoteInbound struct does not panic.

pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.json (4)

3-18: Constructor looks good.

The constructor correctly sets the GatewayZEVM and WZETA addresses as state variables.


91-97: depositWZETA function looks good.

The function correctly forwards the received Ether to the deposit function of the WZETA token contract.


98-173: Avoid hardcoding the token approval amount.

As mentioned in the comment on callGatewayZEVM, approving a large hardcoded amount of tokens to the GatewayZEVM is risky.

Please calculate the exact amount being withdrawn and approve only that before calling withdrawAndCallZEVM.


175-250: Avoid hardcoding the token approval amount.

This overload also has the issue of approving a hardcoded amount of tokens to the GatewayZEVM.

As suggested for the other functions, please dynamically calculate and approve the exact amount being withdrawn.

pkg/contracts/testdappv2/TestDAppV2.json (5)

64-76: LGTM!

The expectedOnCallSender function is a simple getter that returns an address. The implementation is correct and follows the Solidity conventions.


128-158: LGTM!

The onCall function is implemented correctly and follows the Solidity conventions. The introduction of the MessageContext struct is a good design choice that enhances the contract's message handling capabilities.


234-252: LGTM!

The senderWithMessage function is a simple getter that returns an address associated with a message. The implementation is correct and follows the Solidity conventions.


253-265: LGTM!

The setExpectedOnCallSender function is a simple setter that updates the expectedOnCallSender address. The implementation is correct and follows the Solidity conventions.


131-137: LGTM!

The introduction of the MessageContext struct is a good design choice that enhances the contract's message handling capabilities. The struct definition is correct and follows the Solidity conventions.

go.mod (2)

63-63: Ensure the corresponding smart contract changes are finalized before merging.

The version update to github.com/zeta-chain/protocol-contracts is acknowledged. However, as mentioned in the previous review comment, please ensure that the corresponding smart contract changes have been finalized before merging this PR to maintain consistency between the node and the contracts.


338-341: Provide more context on the new dependencies and ensure they are safe to use.

Two new dependencies, github.com/showa-93/go-mask and github.com/tonkeeper/tongo, have been added to the project. Could you please provide more information on the purpose and necessity of these packages?

Additionally, to mitigate potential security risks, I recommend running a dependency vulnerability scan using tools like go list -json -m all | nancy sleuth to ensure that the new dependencies do not introduce any known vulnerabilities.

e2e/e2etests/e2etests.go (6)

135-135: LGTM!

The test name TestV2ETHWithdrawAndAuthenticatedCallName is descriptive and follows the established naming convention. It clearly conveys the purpose of testing Ether withdrawal from ZEVM with an authenticated call using the V2 contract.


136-136: LGTM!

The test name TestV2ETHWithdrawAndAuthenticatedCallThroughContractName is descriptive and follows the established naming convention. It clearly conveys the purpose of testing Ether withdrawal from ZEVM with an authenticated call through an intermediary contract using the V2 contract.


148-148: LGTM!

The test name TestV2ZEVMToEVMAuthenticatedCallName is descriptive and follows the established naming convention. It clearly conveys the purpose of testing an authenticated call from ZEVM to EVM using the V2 contract.


149-149: LGTM!

The test name TestV2ZEVMToEVMAuthenticatedCallThroughContractName is descriptive and follows the established naming convention. It clearly conveys the purpose of testing an authenticated call from ZEVM to EVM through an intermediary contract using the V2 contract.


745-760: LGTM!

The new test runner definitions for the authenticated call tests are correctly added to the AllE2ETests array under the "V2 smart contract tests" section. They follow the established structure, providing the test name, description, argument definitions, and test function.


847-858: LGTM!

The new test runner definitions for the authenticated call tests are correctly added to the AllE2ETests array under the "V2 smart contract tests" section. They follow the established structure, providing the test name, description, argument definitions, and test function.

e2e/e2etests/test_v2_zevm_to_evm_authenticated_call.go (1)

8-8: Verify the import path for gatewayzevm.sol.

The import statement includes a .sol file extension, which is unconventional in Go imports. Please ensure that the import path is correct and that the package is accessible. This might cause issues during compilation.

e2e/e2etests/test_v2_zevm_to_evm_authenticated_call_through_contract.go (1)

17-83: Code implementation is well-structured and follows best practices

The test function is well-organized with clear steps and proper error handling. The use of descriptive variable names and comments enhances readability. The code adheres to clean code principles and effectively tests the authenticated call functionality.

pkg/contracts/testdappv2/TestDAppV2.sol (2)

25-30: Definition of MessageContext Struct is Appropriate

The MessageContext struct is properly defined with a clear documentation of its purpose and parameters. This enhances the clarity and maintainability of the code.


31-31: Declaration of expectedOnCallSender

The addition of the public address expectedOnCallSender is correctly implemented, allowing the contract to store the expected sender's address for authentication purposes.

e2e/runner/v2_zevm.go (3)

88-100: Ensure correct usage of WithdrawAndCallGatewayZEVM method

In V2ETHWithdrawAndAuthenticatedCallThroughContract, you are calling gatewayZEVMCaller.WithdrawAndCallGatewayZEVM. Please verify that this method exists in the TestGatewayZEVMCaller contract and that it behaves as expected.

To verify the method's existence and correctness, run the following script:

#!/bin/bash
# Description: Verify that WithdrawAndCallGatewayZEVM is defined in TestGatewayZEVMCaller.sol.

# Test: Search for the definition of WithdrawAndCallGatewayZEVM.
# Expect: The method WithdrawAndCallGatewayZEVM should be defined.
ast-grep --lang solidity --pattern $'function WithdrawAndCallGatewayZEVM($_) public' 

Line range hint 158-165: Verify the change from Call to Call0

The method V2ZEVMToEMVCall now uses r.GatewayZEVM.Call0 instead of r.GatewayZEVM.Call. Please confirm that Call0 is the correct method to use and that this change aligns with the intended functionality.

To ensure that Call0 is appropriate, run the following script:

#!/bin/bash
# Description: Verify the definition and usage of Call0 in GatewayZEVM.

# Test: Search for the definition of Call0.
# Expect: The method Call0 should be defined.
ast-grep --lang solidity --pattern $'function Call0($_) public' 

# Test: Check for any references to Call0 in the codebase to understand its usage.
rg --type solidity 'Call0' 

62-74: Confirm the use of WithdrawAndCall2 method

In V2ETHWithdrawAndAuthenticatedCall, you are using WithdrawAndCall2. Please ensure that this is the intended method and that it is correctly implemented in the GatewayZEVM contract. Verify that all necessary changes have been made to support this new method.

To confirm the availability and correctness of WithdrawAndCall2, run the following script:

zetaclient/chains/evm/signer/v2_sign.go (1)

20-24: Ensure all callers of signGatewayExecute include the new sender parameter

The function signature of signGatewayExecute has been updated to include a new parameter sender string. Please verify that all calls to this function have been updated accordingly to include the sender argument, ensuring consistency and preventing potential runtime errors.

Run the following script to locate all usages of signGatewayExecute and check their parameters:

Verification successful

Verification successful: signGatewayExecute usage is correct

The call to signGatewayExecute in zetaclient/chains/evm/signer/v2_signer.go has been correctly updated to include the new sender parameter. The function is called with cctx.InboundParams.Sender as the argument for the sender parameter, which appears to be the appropriate source for this information.

No further action is required regarding this change.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Find all usages of 'signGatewayExecute' to ensure the new 'sender' parameter is included.

# Search for function calls to 'signGatewayExecute(' and display surrounding lines for context.
rg --type go -A 2 -B 2 'signGatewayExecute\('

Length of output: 901

pkg/contracts/testdappv2/TestDAppV2.abi (2)

63-75: Confirm Implementation of expectedOnCallSender Function

The addition of the expectedOnCallSender view function in the ABI appears correct. Ensure that the corresponding implementation in the Solidity contract correctly returns the expected address and adheres to the intended logic.


127-157: Verify Struct Definition and Usage in onCall Function

The onCall function introduces a payable function that accepts a MessageContext struct and a bytes message, returning a bytes output. Ensure that:

  • The MessageContext struct is properly defined in the contract with the sender field of type address.
  • The function correctly handles the message input and any associated business logic.
  • Proper validation and security checks are in place to prevent misuse or unexpected behavior.

To confirm the struct definition and function implementation, consider running:

Verification successful

Verification Successful: MessageContext Struct and onCall Function Implemented Correctly

The implementation of the MessageContext struct and onCall function in the TestDAppV2.sol contract aligns precisely with the ABI definition. Key observations:

  • The MessageContext struct is correctly defined with a single address sender field.
  • The onCall function signature matches the ABI, accepting MessageContext calldata and bytes calldata message as inputs.
  • The function is payable and returns bytes memory, as specified.

Notably, the implementation includes robust security measures:

  • Sender authentication: require(messageContext.sender == expectedOnCallSender, "unauthenticated sender")
  • State updates based on input: setCalledWithMessage(string(message)) and setAmountWithMessage(string(message), msg.value)

The implementation demonstrates a production-grade approach to handling cross-chain messages securely and efficiently.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the definition of MessageContext struct and its usage in the contract.

# Test: Search for the struct definition. Expect: Struct with an address field named 'sender'.
rg --type solidity $'struct MessageContext {\\s*address sender;\\s*}'

# Test: Search for the 'onCall' function implementation.
rg --type solidity 'function onCall\\(MessageContext memory messageContext, bytes memory message\\)'

Length of output: 355


Script:

#!/bin/bash
# Description: Verify the definition of MessageContext struct and its usage in the contract.

# Test: Search for the struct definition with simplified regex
rg -C 3 "struct MessageContext"

# Test: Search for the 'onCall' function implementation
rg -C 5 "function onCall"

# Test: Search for usage of MessageContext in function parameters
rg -C 3 "MessageContext.*memory"

Length of output: 4550

pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.abi (1)

169-172: Verify the duplicate definitions of withdrawAndCallGatewayZEVM function

There are two definitions of the withdrawAndCallGatewayZEVM function with different parameters at lines 169-172 and 246-249. Please confirm that this overloading is intentional and correctly handled in the ABI. Overloaded functions can cause issues if the ABI or interfacing tools do not support function overloading properly.

To ensure that the ABI accurately represents these overloaded functions and to identify any unintended duplicates, you can run the following script:

Also applies to: 246-249

Verification successful

Function overloading for withdrawAndCallGatewayZEVM verified

The duplicate definitions of withdrawAndCallGatewayZEVM are confirmed to be intentional function overloads with distinct signatures:

  1. withdrawAndCallGatewayZEVM(bytes,uint256,address,bytes,tuple,tuple)
  2. withdrawAndCallGatewayZEVM(bytes,uint256,uint256,bytes,tuple,tuple)

These overloads differ in the third parameter (address vs. uint256), indicating a deliberate design choice. While this overloading is valid and correctly represented in the ABI, it is advisable to conduct a brief review of the implementation to ensure both overloads are utilized appropriately and their purposes are well-documented.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Identify functions with duplicate names in the ABI file

# Expected Result: List of function names that appear more than once
jq -r '.[] | select(.type=="function") | .name' pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.abi | sort | uniq -c | awk '$1 > 1 {print $2 " appears " $1 " times"}'

Length of output: 221


Script:

#!/bin/bash
# Description: Extract full function signatures for 'withdrawAndCallGatewayZEVM'

# Expected Result: Detailed function signatures including parameter types
jq -r '.[] | select(.type=="function" and .name=="withdrawAndCallGatewayZEVM") | "\(.name)(\(.inputs | map(.type) | join(",")))"' pkg/contracts/testgatewayzevmcaller/TestGatewayZEVMCaller.abi

Length of output: 329

pkg/contracts/testdappv2/TestDAppV2.go (4)

286-316: Implementation of ExpectedOnCallSender is correct

The function ExpectedOnCallSender is correctly implemented and aligns with the corresponding Solidity contract method. The binding handles the return value accurately.


379-409: Implementation of SenderWithMessage is accurate

The function SenderWithMessage correctly binds to the contract method senderWithMessage. It appropriately handles the input parameters and return value.


452-471: Implementation of OnCall method is appropriate

The OnCall method is properly implemented as a payable transaction binding. It correctly passes the messageContext and message parameters to the contract.


515-535: Implementation of SetExpectedOnCallSender is correct

The method SetExpectedOnCallSender accurately binds to the contract function, correctly handling the transaction and the _expectedOnCallSender parameter.

e2e/e2etests/test_v2_eth_withdraw_and_authenticated_call.go (1)

43-43: Confirm Zero Value for OnRevertGasLimit

Setting OnRevertGasLimit to zero may result in insufficient gas for revert operations. Verify that this is intentional and consider providing a minimal gas limit if necessary.

pkg/contracts/testgatewayzevmcaller/bindings.go Outdated Show resolved Hide resolved
x/crosschain/client/cli/tx_vote_inbound.go Outdated Show resolved Hide resolved
zetaclient/zetacore/tx.go Outdated Show resolved Hide resolved
x/crosschain/types/message_vote_inbound.go Show resolved Hide resolved
pkg/contracts/testdappv2/TestDAppV2.go Show resolved Hide resolved
@skosito skosito requested review from lumtis and kingpinXD September 24, 2024 14:31
@skosito skosito changed the title feat: authenticated zevm -> evm call and e2e tests feat: integrate authenticated calls smart contract functionality into protocol Sep 24, 2024
Copy link
Member

@lumtis lumtis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

e2e/runner/v2_zevm.go Show resolved Hide resolved
@lumtis lumtis added V2_MIGRATION_TESTS Run make start-upgrade-v2-migration-test UPGRADE_TESTS Run make start-upgrade-tests and removed V2_MIGRATION_TESTS Run make start-upgrade-v2-migration-test labels Sep 25, 2024
@lumtis lumtis added UPGRADE_TESTS Run make start-upgrade-tests and removed UPGRADE_TESTS Run make start-upgrade-tests labels Sep 25, 2024
@lumtis
Copy link
Member

lumtis commented Sep 25, 2024

Upgrade test likely to fail because of #2921

I think it should be trivial I will also have a look

@skosito
Copy link
Contributor Author

skosito commented Sep 26, 2024

Upgrade test likely to fail because of #2921

I think it should be trivial I will also have a look

fixed

@skosito skosito enabled auto-merge September 27, 2024 11:38
@skosito skosito added this pull request to the merge queue Sep 27, 2024
Merged via the queue into develop with commit 1712cb0 Sep 27, 2024
27 checks passed
@skosito skosito deleted the authenticated-call-sc-support branch September 27, 2024 11:54
@coderabbitai coderabbitai bot mentioned this pull request Sep 27, 2024
5 tasks
morde08 pushed a commit that referenced this pull request Oct 2, 2024
… protocol (#2904)

* e2e tests and modifications for authenticated call

* extend test with sender check and revert case

* separate tests into separate files

* cleanup

* withdraw and call support and tests

* bump protocol contracts

* split tests into separate files

* small cleanup

* fmt

* generate

* lint

* changelog

* PR  comments

* fix case in proto

* bump vote inbound gas limit in zetaclient

* fix test

* generate

* fixing tests

* call options non empty

* generate

* test fix

* rename gateway caller

* pr comments rename tests

* PR comment

* generate

* tests

* update tests fixes

* tests fixes

* fix

* test fix
@coderabbitai coderabbitai bot mentioned this pull request Oct 3, 2024
5 tasks
github-merge-queue bot pushed a commit that referenced this pull request Oct 3, 2024
…guration (#2953)

* update artillery config

* more fixes

* feat: integrate authenticated calls smart contract functionality into protocol (#2904)

* e2e tests and modifications for authenticated call

* extend test with sender check and revert case

* separate tests into separate files

* cleanup

* withdraw and call support and tests

* bump protocol contracts

* split tests into separate files

* small cleanup

* fmt

* generate

* lint

* changelog

* PR  comments

* fix case in proto

* bump vote inbound gas limit in zetaclient

* fix test

* generate

* fixing tests

* call options non empty

* generate

* test fix

* rename gateway caller

* pr comments rename tests

* PR comment

* generate

* tests

* update tests fixes

* tests fixes

* fix

* test fix

* feat!: bank precompile (#2860)

* feat: bank precompile

* feat: add deposit

* feat: extend deposit

* PoC: spend amount on behalf of EOA

* feat: expand deposit with transferFrom

* use CallEVM instead on ZRC20 bindings

* divide the contract into different files

* initialize e2e testing

* remove duplicated funding

* add codecov

* expand e2e

* fix: wait for deposit tx to be mined

* apply first round of reviews

* cover al error types test

* fixes using time.Since

* Include CallContract interface

* fix eth events in deposit precompile method

* emit Deposit event

* add withdraw function

* finalize withdraw

* pack event arguments generically

* add high level event function

* first round of review fixes

* second round of reviews

* create bank account when instantiating bank

* e2e: add good and bad scenarios

* modify fmt

* chore: group input into eventData struct

* docs: document bank's methods

* chore: generate files with suffix .gen.go

* chore: assert errors with errorIs

* chore: reset e2e test by resetting allowance

* test: add first batch of unit test

* test: cover all cases

* test: complete unit test cases

* include review suggestions

* include e2e through contract

* test: add e2e through contract complete

* test: revert balance between tests

* Update precompiles/bank/const.go

Co-authored-by: Lucas Bertrand <[email protected]>

* fix: changed coin denom

---------

Co-authored-by: skosito <[email protected]>
Co-authored-by: Lucas Bertrand <[email protected]>

* feat: add sender to revert context (#2919)

* e2e tests and modifications for authenticated call

* extend test with sender check and revert case

* separate tests into separate files

* cleanup

* withdraw and call support and tests

* bump protocol contracts

* split tests into separate files

* small cleanup

* fmt

* generate

* lint

* changelog

* PR  comments

* fix case in proto

* bump vote inbound gas limit in zetaclient

* fix test

* generate

* fixing tests

* call options non empty

* generate

* test fix

* rename gateway caller

* pr comments rename tests

* PR comment

* generate

* tests

* add sender in test contract

* extend e2e tests

* generate

* changelog

* PR comment

* generate

* update tests fixes

* tests fixes

* fix

* test fix

* gas limit fixes

* PR comment fix

* fix bad merge

* ci: add option to enable monitoring stack (#2927)

* ci: add option to enable monitoring stack

* start prometheus faster

* update

* ci: add rpcimportable test (#2817)

* ci: add rpcimportable test

* add ci

* fmt

* use github.com/btcsuite/btcd/btcutil in pkg/chains

* remove app imports types tests

* use standalone sdkconfig package

* fix policies test

* move crosschain keeper tests from types to keeper

* never seal config in tests

* use zeta-chain/ethermint#126

* add some comments

* use merged ethermint hash

* show resulting go.mod

* ci: Add SARIF upload to GitHub Security Dashboard (#2929)

* add semgrep sarif upload to GHAS

* added comment to clairfy the usage of the utility script

* use ghcr.io instead

* add tag to image

* bad org name

---------

Co-authored-by: jkan2 <[email protected]>

* fix: add recover to InitChainer to diplay informative message when starting a node from block 1 (#2925)

* add recover to InitChainer

* generate files

* add docs link to error message

* move InitChainErrorMessage to app.go

* Update app/app.go

Co-authored-by: Francisco de Borja Aranda Castillejo <[email protected]>

* use const for message

---------

Co-authored-by: Francisco de Borja Aranda Castillejo <[email protected]>

* test: add wait for block to tss migration test (#2931)

* add wait for block to tss migration test

* add comments

* refactor identifiers

* rename checkNumberOfTssGenerated to checkNumberOfTSSGenerated

* chore: allow full zetaclient config overlay (#2945)

* test(e2e): add gateway upgrade in upgrade test (#2932)

* add gateway upgrade

* change reference

* add v2 setup for all tests

* test v2 in light upgrade

* refactor setup to use custody v2 directly

* chore: improve localnet build performance (#2928)

* chore: improve localnet build performance

* propagate NODE_VERSION and NODE_COMMIT

* update hashes

---------

Co-authored-by: skosito <[email protected]>
Co-authored-by: Francisco de Borja Aranda Castillejo <[email protected]>
Co-authored-by: Lucas Bertrand <[email protected]>
Co-authored-by: Alex Gartner <[email protected]>
Co-authored-by: jkan2 <[email protected]>
Co-authored-by: jkan2 <[email protected]>
Co-authored-by: Tanmay <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
breaking:cli breaking:proto UPGRADE_TESTS Run make start-upgrade-tests V2_TESTS Run make start-v2-test
Projects
None yet
Development

Successfully merging this pull request may close these issues.

CCTX v2: parse the callOptions from inbound and set messageContext in onCall receiver
4 participants