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

fix: move system contract to contracts folder #352

Merged
merged 3 commits into from
Sep 16, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 21 additions & 21 deletions v2/contracts/zevm/GatewayZEVM.sol
Original file line number Diff line number Diff line change
Expand Up @@ -28,18 +28,18 @@ contract GatewayZEVM is
/// @notice Error indicating a zero address was provided.
error ZeroAddress();

/// @notice The constant address of the Fungible module.
address public constant FUNGIBLE_MODULE_ADDRESS = 0x735b14BB79463307AAcBED86DAf3322B1e6226aB;
/// @notice The constant address of the protocol
address public constant PROTOCOL_ADDRESS = 0x735b14BB79463307AAcBED86DAf3322B1e6226aB;
lumtis marked this conversation as resolved.
Show resolved Hide resolved
/// @notice The address of the Zeta token.
address public zetaToken;

/// @notice New role identifier for pauser role.
bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

/// @dev Only Fungible module address allowed modifier.
modifier onlyFungible() {
if (msg.sender != FUNGIBLE_MODULE_ADDRESS) {
revert CallerIsNotFungibleModule();
/// @dev Only protocol address allowed modifier.
modifier onlyProtocol() {
if (msg.sender != PROTOCOL_ADDRESS) {
revert CallerIsNotProtocol();
}
_;
}
Expand Down Expand Up @@ -71,7 +71,7 @@ contract GatewayZEVM is

/// @dev Receive function to receive ZETA from WETH9.withdraw().
receive() external payable whenNotPaused {
if (msg.sender != zetaToken && msg.sender != FUNGIBLE_MODULE_ADDRESS) revert OnlyWZETAOrFungible();
if (msg.sender != zetaToken && msg.sender != PROTOCOL_ADDRESS) revert OnlyWZETAOrProtocol();
}

/// @notice Pause contract.
Expand Down Expand Up @@ -100,7 +100,7 @@ contract GatewayZEVM is
/// @return The gas fee for the withdrawal.
function _withdrawZRC20WithGasLimit(uint256 amount, address zrc20, uint256 gasLimit) internal returns (uint256) {
(address gasZRC20, uint256 gasFee) = IZRC20(zrc20).withdrawGasFeeWithGasLimit(gasLimit);
if (!IZRC20(gasZRC20).transferFrom(msg.sender, FUNGIBLE_MODULE_ADDRESS, gasFee)) {
if (!IZRC20(gasZRC20).transferFrom(msg.sender, PROTOCOL_ADDRESS, gasFee)) {
revert GasFeeTransferFailed();
}

Expand Down Expand Up @@ -210,7 +210,7 @@ contract GatewayZEVM is
if (receiver.length == 0) revert ZeroAddress();
if (amount == 0) revert InsufficientZetaAmount();

_transferZETA(amount, FUNGIBLE_MODULE_ADDRESS);
_transferZETA(amount, PROTOCOL_ADDRESS);
emit Withdrawn(msg.sender, chainId, receiver, address(zetaToken), amount, 0, 0, "", 0, revertOptions);
}

Expand All @@ -234,7 +234,7 @@ contract GatewayZEVM is
if (receiver.length == 0) revert ZeroAddress();
if (amount == 0) revert InsufficientZetaAmount();

_transferZETA(amount, FUNGIBLE_MODULE_ADDRESS);
_transferZETA(amount, PROTOCOL_ADDRESS);
emit Withdrawn(msg.sender, chainId, receiver, address(zetaToken), amount, 0, 0, message, 0, revertOptions);
}

Expand All @@ -259,7 +259,7 @@ contract GatewayZEVM is
if (message.length == 0) revert EmptyMessage();

(address gasZRC20, uint256 gasFee) = IZRC20(zrc20).withdrawGasFeeWithGasLimit(gasLimit);
if (!IZRC20(gasZRC20).transferFrom(msg.sender, FUNGIBLE_MODULE_ADDRESS, gasFee)) {
if (!IZRC20(gasZRC20).transferFrom(msg.sender, PROTOCOL_ADDRESS, gasFee)) {
revert GasFeeTransferFailed();
}

Expand All @@ -270,11 +270,11 @@ contract GatewayZEVM is
/// @param zrc20 The address of the ZRC20 token.
/// @param amount The amount of tokens to deposit.
/// @param target The target address to receive the deposited tokens.
function deposit(address zrc20, uint256 amount, address target) external onlyFungible whenNotPaused {
function deposit(address zrc20, uint256 amount, address target) external onlyProtocol whenNotPaused {
if (zrc20 == address(0) || target == address(0)) revert ZeroAddress();
if (amount == 0) revert InsufficientZRC20Amount();

if (target == FUNGIBLE_MODULE_ADDRESS || target == address(this)) revert InvalidTarget();
if (target == PROTOCOL_ADDRESS || target == address(this)) revert InvalidTarget();

if (!IZRC20(zrc20).deposit(target, amount)) revert ZRC20DepositFailed();
}
Expand All @@ -293,7 +293,7 @@ contract GatewayZEVM is
bytes calldata message
)
external
onlyFungible
onlyProtocol
whenNotPaused
{
if (zrc20 == address(0) || target == address(0)) revert ZeroAddress();
Expand All @@ -315,12 +315,12 @@ contract GatewayZEVM is
bytes calldata message
)
external
onlyFungible
onlyProtocol
whenNotPaused
{
if (zrc20 == address(0) || target == address(0)) revert ZeroAddress();
if (amount == 0) revert InsufficientZRC20Amount();
if (target == FUNGIBLE_MODULE_ADDRESS || target == address(this)) revert InvalidTarget();
if (target == PROTOCOL_ADDRESS || target == address(this)) revert InvalidTarget();

if (!IZRC20(zrc20).deposit(target, amount)) revert ZRC20DepositFailed();
UniversalContract(target).onCrossChainCall(context, zrc20, amount, message);
Expand All @@ -338,12 +338,12 @@ contract GatewayZEVM is
bytes calldata message
)
external
onlyFungible
onlyProtocol
whenNotPaused
{
if (target == address(0)) revert ZeroAddress();
if (amount == 0) revert InsufficientZetaAmount();
if (target == FUNGIBLE_MODULE_ADDRESS || target == address(this)) revert InvalidTarget();
if (target == PROTOCOL_ADDRESS || target == address(this)) revert InvalidTarget();

_transferZETA(amount, target);
UniversalContract(target).onCrossChainCall(context, zetaToken, amount, message);
Expand All @@ -352,7 +352,7 @@ contract GatewayZEVM is
/// @notice Revert a user-specified contract on ZEVM.
/// @param target The target contract to call.
/// @param revertContext Revert context to pass to onRevert.
function executeRevert(address target, RevertContext calldata revertContext) external onlyFungible whenNotPaused {
function executeRevert(address target, RevertContext calldata revertContext) external onlyProtocol whenNotPaused {
if (target == address(0)) revert ZeroAddress();

UniversalContract(target).onRevert(revertContext);
Expand All @@ -370,12 +370,12 @@ contract GatewayZEVM is
RevertContext calldata revertContext
)
external
onlyFungible
onlyProtocol
whenNotPaused
{
if (zrc20 == address(0) || target == address(0)) revert ZeroAddress();
if (amount == 0) revert InsufficientZRC20Amount();
if (target == FUNGIBLE_MODULE_ADDRESS || target == address(this)) revert InvalidTarget();
if (target == PROTOCOL_ADDRESS || target == address(this)) revert InvalidTarget();

if (!IZRC20(zrc20).deposit(target, amount)) revert ZRC20DepositFailed();
UniversalContract(target).onRevert(revertContext);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
// SPDX-License-Identifier: MIT
pragma solidity 0.8.26;

import "../../contracts/zevm/interfaces/IZRC20.sol";
import "../../contracts/zevm/interfaces/UniversalContract.sol";
import "./interfaces/IZRC20.sol";
import "./interfaces/UniversalContract.sol";

/**
* @dev Custom errors for SystemContract
Expand Down
8 changes: 4 additions & 4 deletions v2/contracts/zevm/interfaces/IGatewayZEVM.sol
Original file line number Diff line number Diff line change
Expand Up @@ -72,17 +72,17 @@ interface IGatewayZEVMErrors {
/// @notice Error indicating a failure to transfer gas fee.
error GasFeeTransferFailed();

/// @notice Error indicating that the caller is not the Fungible module.
error CallerIsNotFungibleModule();
/// @notice Error indicating that the caller is not the protocol account.
error CallerIsNotProtocol();

/// @notice Error indicating an invalid target address.
error InvalidTarget();

/// @notice Error indicating a failure to send ZETA tokens.
error FailedZetaSent();

/// @notice Error indicating that only WZETA or the Fungible module can call the function.
error OnlyWZETAOrFungible();
/// @notice Error indicating that only WZETA or the protocol address can call the function.
error OnlyWZETAOrProtocol();

/// @notice Error indicating call method received empty message as argument.
error EmptyMessage();
Expand Down
4 changes: 2 additions & 2 deletions v2/pkg/gatewayevmzevm.t.sol/gatewayevmzevmtest.go

Large diffs are not rendered by default.

60 changes: 30 additions & 30 deletions v2/pkg/gatewayzevm.sol/gatewayzevm.go

Large diffs are not rendered by default.

Loading
Loading