Build
Protocol Contracts
ZetaChain and EVM

Git Source (opens in a new tab)

The GatewayEVM contract is the endpoint to call smart contracts on external chains.

The contract doesn't hold any funds and should never have active allowances.

State Variables

custody

The address of the custody contract.

address public custody;

tssAddress

The address of the TSS (Threshold Signature Scheme) contract.

address public tssAddress;

zetaConnector

The address of the ZetaConnector contract.

address public zetaConnector;

zetaToken

The address of the Zeta token contract.

address public zetaToken;

additionalActionFeeWei

Fee charged for additional cross-chain actions within the same transaction.

The first action in a transaction is free, subsequent actions incur this fee.

This is configurable by the admin role to allow for fee adjustments.

uint256 public additionalActionFeeWei;

TSS_ROLE

New role identifier for tss role.

bytes32 public constant TSS_ROLE = keccak256("TSS_ROLE");

ASSET_HANDLER_ROLE

New role identifier for asset handler role.

bytes32 public constant ASSET_HANDLER_ROLE = keccak256("ASSET_HANDLER_ROLE");

PAUSER_ROLE

New role identifier for pauser role.

bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

MAX_PAYLOAD_SIZE

Max size of payload + revertOptions revert message.

uint256 public constant MAX_PAYLOAD_SIZE = 2880;

_TRANSACTION_ACTION_COUNT_KEY

Storage slot key for tracking transaction action count.

Uses transient storage (tload/tstore) for gas efficiency.

Value 0x01 is used as a unique identifier for this storage slot.

uint256 private constant _TRANSACTION_ACTION_COUNT_KEY = 0x01;

Functions

constructor

Note: oz-upgrades-unsafe-allow: constructor

constructor();

initialize

Initialize with tss address. address of zeta token and admin account set as DEFAULT_ADMIN_ROLE.

Using admin to authorize upgrades and pause, and tss for tss role.

function initialize(address tssAddress_, address zetaToken_, address admin_) public initializer;

_authorizeUpgrade

Authorizes the upgrade of the contract, sender must be owner.

function _authorizeUpgrade(address newImplementation) internal override onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newImplementationaddressAddress of the new implementation.

updateTSSAddress

Update tss address

function updateTSSAddress(address newTSSAddress) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newTSSAddressaddressnew tss address

pause

Pause contract.

function pause() external onlyRole(PAUSER_ROLE);

unpause

Unpause contract.

function unpause() external onlyRole(PAUSER_ROLE);

updateAdditionalActionFee

Update the additional action fee.

Only callable by admin role. This allows for fee adjustments based on network conditions.

Setting fee to 0 disables additional action fees entirely.

Fee should be adjusted based on the chain's native token decimals.

function updateAdditionalActionFee(uint256 newFeeWei) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newFeeWeiuint256The new fee amount in wei for additional actions in the same transaction.

executeRevert

Transfers msg.value to destination contract and executes it's onRevert function.

This function can only be called by the TSS address and it is payable.

function executeRevert(
    address destination,
    bytes calldata data,
    RevertContext calldata revertContext
)
    public
    payable
    nonReentrant
    onlyRole(TSS_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
destinationaddressAddress to call.
databytesCalldata to pass to the call.
revertContextRevertContext

execute

Executes a call to a destination address without ERC20 tokens.

This function can only be called by the TSS address and it is payable.

function execute(
    MessageContext calldata messageContext,
    address destination,
    bytes calldata data
)
    external
    payable
    nonReentrant
    onlyRole(TSS_ROLE)
    whenNotPaused
    returns (bytes memory);

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender.
destinationaddressAddress to call.
databytesCalldata to pass to the call.

Returns

NameTypeDescription
<none>bytesThe result of the call.

executeWithERC20

Executes a call to a destination contract using ERC20 tokens.

This function can only be called by the custody or connector address. It uses the ERC20 allowance system, resetting gateway allowance at the end.

function executeWithERC20(
    MessageContext calldata messageContext,
    address token,
    address to,
    uint256 amount,
    bytes calldata data
)
    public
    nonReentrant
    onlyRole(ASSET_HANDLER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender.
tokenaddressAddress of the ERC20 token.
toaddressAddress of the contract to call.
amountuint256Amount of tokens to transfer.
databytesCalldata to pass to the call.

revertWithERC20

Directly transfers ERC20 tokens and calls onRevert.

This function can only be called by the custody or connector address.

function revertWithERC20(
    address token,
    address to,
    uint256 amount,
    bytes calldata data,
    RevertContext calldata revertContext
)
    external
    nonReentrant
    onlyRole(ASSET_HANDLER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
tokenaddressAddress of the ERC20 token.
toaddressAddress of the contract to call.
amountuint256Amount of tokens to transfer.
databytesCalldata to pass to the call.
revertContextRevertContextRevert context to pass to onRevert.

deposit

Deposits ETH to the TSS address.

This function only works for the first action in a transaction (backward compatibility).

For subsequent actions, use the overloaded version with amount parameter.

function deposit(address receiver, RevertOptions calldata revertOptions) external payable whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
revertOptionsRevertOptionsRevert options.

deposit

Deposits ETH to the TSS address with specified amount.

msg.value must equal amount + required fee for the action.

function deposit(
    address receiver,
    uint256 amount,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of ETH to deposit (excluding fees).
revertOptionsRevertOptionsRevert options.

deposit

Deposits ERC20 tokens to the custody or connector contract.

function deposit(
    address receiver,
    uint256 amount,
    address asset,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of tokens to deposit.
assetaddressAddress of the ERC20 token.
revertOptionsRevertOptionsRevert options.

depositAndCall

Deposits ETH to the TSS address and calls an omnichain smart contract.

This function only works for the first action in a transaction (backward compatibility).

For subsequent actions, use the overloaded version with amount parameter.

function depositAndCall(
    address receiver,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

depositAndCall

Deposits ETH to the TSS address and calls an omnichain smart contract with specified amount.

msg.value must equal amount + required fee for the action.

function depositAndCall(
    address receiver,
    uint256 amount,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of ETH to deposit (excluding fees).
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

depositAndCall

Deposits ERC20 tokens to the custody or connector contract and calls an omnichain smart contract.

function depositAndCall(
    address receiver,
    uint256 amount,
    address asset,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of tokens to deposit.
assetaddressAddress of the ERC20 token.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

call

Calls an omnichain smart contract without asset transfer.

function call(
    address receiver,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

setCustody

Sets the custody contract address.

function setCustody(address custody_) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
custody_addressAddress of the custody contract.

setConnector

Sets the connector contract address.

function setConnector(address zetaConnector_) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
zetaConnector_addressAddress of the connector contract.

_resetApproval

Resets the approval of a token for a specified address. This is used to ensure that the approval is set to zero before setting it to a new value.

function _resetApproval(address token, address to) private returns (bool);

Parameters

NameTypeDescription
tokenaddressAddress of the ERC20 token.
toaddressAddress to reset the approval for.

Returns

NameTypeDescription
<none>boolTrue if the approval reset was successful or if the token reverts on zero approval.

_transferFromToAssetHandler

Transfers tokens from the sender to the asset handler. This function handles the transfer of tokens to either the connector or custody contract based on the asset type.

function _transferFromToAssetHandler(address from, address token, uint256 amount) private;

Parameters

NameTypeDescription
fromaddressAddress of the sender.
tokenaddressAddress of the ERC20 token.
amountuint256Amount of tokens to transfer.

_transferToAssetHandler

Transfers tokens to the asset handler. This function handles the transfer of tokens to either the connector or custody contract based on the asset type.

function _transferToAssetHandler(address token, uint256 amount) private;

Parameters

NameTypeDescription
tokenaddressAddress of the ERC20 token.
amountuint256Amount of tokens to transfer.

_executeArbitraryCall

Private function to execute an arbitrary call to a destination address.

function _executeArbitraryCall(address destination, bytes calldata data) private returns (bytes memory);

Parameters

NameTypeDescription
destinationaddressAddress to call.
databytesCalldata to pass to the call.

Returns

NameTypeDescription
<none>bytesThe result of the call.

_executeAuthenticatedCall

Private function to execute an authenticated call to a destination address.

function _executeAuthenticatedCall(
    MessageContext calldata messageContext,
    address destination,
    bytes calldata data
)
    private
    returns (bytes memory);

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender and arbitrary call flag.
destinationaddressAddress to call.
databytesCalldata to pass to the call.

Returns

NameTypeDescription
<none>bytesThe result of the call.

_revertIfOnCallOrOnRevert

function _revertIfOnCallOrOnRevert(bytes calldata data) private pure;

_processFee

Processes fee collection for cross-chain actions within a transaction.

The first action in a transaction is free, subsequent actions incur ADDITIONAL_ACTION_FEE_WEI.

If fee is 0, the entire functionality is disabled and will revert.

function _processFee() internal returns (uint256);

Returns

NameTypeDescription
<none>uint256The fee amount actually charged (0 for first action, ADDITIONAL_ACTION_FEE_WEI for subsequent actions).

_validateChargedFeeForERC20

Validates fee payment for ERC20 operations (deposit, depositAndCall, call).

Validates that msg.value equals the required fee (no excess ETH allowed).

function _validateChargedFeeForERC20(uint256 feeCharged) internal view;

Parameters

NameTypeDescription
feeChargeduint256The fee amount that was charged.

_validateChargedFeeForETHWithAmount

Validates fee payment for ETH operations with specified amount.

Validates that msg.value equals amount + feeCharged.

function _validateChargedFeeForETHWithAmount(uint256 amount, uint256 feeCharged) internal view;

Parameters

NameTypeDescription
amountuint256The amount to deposit (excluding fees).
feeChargeduint256The fee amount that was charged.

_getNextActionIndex

Gets and increments the transaction action counter using transient storage.

Uses assembly for gas efficiency with tload/tstore operations.

Transient storage is transaction-scoped and automatically cleared after each transaction.

function _getNextActionIndex() internal returns (uint256 currentIndex);

Returns

NameTypeDescription
currentIndexuint256The current action index within the transaction (0-based).

Git Source (opens in a new tab)

The GatewayZEVM contract is the endpoint to call smart contracts on omnichain.

The contract doesn't hold any funds and should never have active allowances.

State Variables

PROTOCOL_ADDRESS

The constant address of the protocol

address public constant PROTOCOL_ADDRESS = 0x735b14BB79463307AAcBED86DAf3322B1e6226aB;

PAUSER_ROLE

New role identifier for pauser role.

bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

zetaToken

The address of the Zeta token.

address public zetaToken;

registry

The address of the registry contract on ZetaChain

address public registry;

Functions

onlyProtocol

Only protocol address allowed modifier.

modifier onlyProtocol();

constructor

Note: oz-upgrades-unsafe-allow: constructor

constructor();

initialize

Initialize with address of zeta token and admin account set as DEFAULT_ADMIN_ROLE.

Using admin to authorize upgrades and pause.

function initialize(address zetaToken_, address admin_) public initializer;

_authorizeUpgrade

Authorizes the upgrade of the contract.

function _authorizeUpgrade(address newImplementation) internal override onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newImplementationaddressThe address of the new implementation.

receive

Receive function to receive ZETA from WETH9.withdraw().

receive() external payable whenNotPaused;

pause

Pause contract.

function pause() external onlyRole(PAUSER_ROLE);

unpause

Unpause contract.

function unpause() external onlyRole(PAUSER_ROLE);

setRegistryAddress

Set registry address, callable only by DEFAULT_ADMIN_ROLE.

function setRegistryAddress(address _registry) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
_registryaddressThe address of the registry contract.

_safeTransferFrom

Helper function to safely execute transferFrom

function _safeTransferFrom(address zrc20, address from, address to, uint256 amount) private returns (bool);

Parameters

NameTypeDescription
zrc20addressThe ZRC20 token address
fromaddressThe sender address
toaddressThe recipient address
amountuint256The amount to transfer

Returns

NameTypeDescription
<none>boolTrue if the transfer was successful, false otherwise.

_safeBurn

function _safeBurn(address zrc20, uint256 amount) private returns (bool);

_safeDeposit

function _safeDeposit(address zrc20, address target, uint256 amount) private returns (bool);

_burnProtocolFees

Helper function to burn gas fees.

function _burnProtocolFees(address gasZRC20, uint256 gasFee) private;

Parameters

NameTypeDescription
gasZRC20addressThe address of the gas ZRC20 token.
gasFeeuint256The amount of gasZRC20 that should be burned.

_burnZRC20ProtocolFees

Helper function to burn gas fees for ZRC20s withdrawals.

function _burnZRC20ProtocolFees(address zrc20, uint256 gasLimit) private returns (uint256);

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token.
gasLimituint256Gas limit.

_withdrawZRC20WithGasLimit

Private function to withdraw ZRC20 tokens with gas limit.

function _withdrawZRC20WithGasLimit(uint256 amount, address zrc20, uint256 gasLimit) private returns (uint256);

Parameters

NameTypeDescription
amountuint256The amount of tokens to withdraw.
zrc20addressThe address of the ZRC20 token.
gasLimituint256Gas limit.

Returns

NameTypeDescription
<none>uint256The gas fee for the withdrawal.

_getGasLimitForZETATransfer

Helper function to get gas limit for the ZETA transfer to the external chain.

function _getGasLimitForZETATransfer(uint256 chainId) private view returns (uint256 gasLimit);

Parameters

NameTypeDescription
chainIduint256Chain id of the external chain.

Returns

NameTypeDescription
gasLimituint256The gas limit.

_getProtocolFlatFeeFromRegistry

Helper function to get protocol flat fee for the external chain.

function _getProtocolFlatFeeFromRegistry(uint256 chainId) private view returns (uint256 protocolFlatFee);

Parameters

NameTypeDescription
chainIduint256Chain id of the external chain.

Returns

NameTypeDescription
protocolFlatFeeuint256The protocol flat fee.

_computeAndPayFeesForZETAWithdrawals

Helper function to burn gas fees for ZETA withdrawals.

function _computeAndPayFeesForZETAWithdrawals(
    uint256 chainId,
    uint256 gasLimit
)
    private
    returns (uint256 gasFee, uint256 protocolFlatFee, uint256 gasLimit_);

Parameters

NameTypeDescription
chainIduint256Chain id of the external chain.
gasLimituint256The gas limit.

Returns

NameTypeDescription
gasFeeuint256The gas fee for the withdrawal.
protocolFlatFeeuint256The protocol flat fee.
gasLimit_uint256The gas limit used for the withdrawal.

_transferZETA

Private function to transfer ZETA tokens.

function _transferZETA(uint256 amount, address to) private;

Parameters

NameTypeDescription
amountuint256The amount of tokens to transfer.
toaddressThe address to transfer the tokens to.

withdraw

Withdraw ZRC20 tokens to an external chain.

function withdraw(
    bytes memory receiver,
    uint256 amount,
    address zrc20,
    RevertOptions calldata revertOptions
)
    external
    whenNotPaused;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
amountuint256The amount of tokens to withdraw.
zrc20addressThe address of the ZRC20 token.
revertOptionsRevertOptionsRevert options.

withdraw

Withdraw ZRC20 tokens to an external chain with custom gas limit.

Use this function for simple gas ZRC20 withdrawals to the receivers that are either smart contract accounts or smart contracts with custom receive/fallback implementations.

function withdraw(
    bytes memory receiver,
    uint256 amount,
    address zrc20,
    uint256 gasLimit,
    RevertOptions calldata revertOptions
)
    external
    whenNotPaused;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
amountuint256The amount of tokens to withdraw.
zrc20addressThe address of the ZRC20 token.
gasLimituint256The custom gas limit for the withdrawal (must be >= MIN_GAS_LIMIT).
revertOptionsRevertOptionsRevert options.

withdrawAndCall

Withdraw ZRC20 tokens and call a smart contract on an external chain.

function withdrawAndCall(
    bytes memory receiver,
    uint256 amount,
    address zrc20,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    external
    whenNotPaused;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
amountuint256The amount of tokens to withdraw.
zrc20addressThe address of the ZRC20 token.
messagebytesThe calldata to pass to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

withdraw

Withdraw ZETA tokens to an external chain.

function withdraw(
    bytes memory receiver,
    uint256 chainId,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused
    nonReentrant;

withdrawAndCall

Withdraw ZETA tokens and call a smart contract on an external chain.

function withdrawAndCall(
    bytes memory receiver,
    uint256 chainId,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    external
    payable
    whenNotPaused
    nonReentrant;

call

Call a smart contract on an external chain without asset transfer.

function call(
    bytes memory receiver,
    address zrc20,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    external
    whenNotPaused;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
zrc20addressAddress of zrc20 to pay fees.
messagebytesThe calldata to pass to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

_call

function _call(
    bytes memory receiver,
    address zrc20,
    bytes calldata message,
    CallOptions memory callOptions,
    RevertOptions memory revertOptions
)
    private;

deposit

Deposit foreign coins into ZRC20.

function deposit(address zrc20, uint256 amount, address target) external onlyProtocol whenNotPaused;

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to deposit.
targetaddressThe target address to receive the deposited tokens.

deposit

Deposit native ZETA.

function deposit(address target) external payable nonReentrant onlyProtocol whenNotPaused;

Parameters

NameTypeDescription
targetaddressThe target address to receive the ZETA.

execute

Execute a user-specified contract on ZEVM.

function execute(
    MessageContext calldata context,
    address zrc20,
    uint256 amount,
    address target,
    bytes calldata message
)
    external
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
contextMessageContextThe context of the cross-chain call.
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to transfer.
targetaddressThe target contract to call.
messagebytesThe calldata to pass to the contract call.

depositAndCall

Deposit foreign coins into ZRC20 and call a user-specified contract on ZEVM.

function depositAndCall(
    MessageContext calldata context,
    address zrc20,
    uint256 amount,
    address target,
    bytes calldata message
)
    external
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
contextMessageContextThe context of the cross-chain call.
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to transfer.
targetaddressThe target contract to call.
messagebytesThe calldata to pass to the contract call.

depositAndCall

Deposit native ZETA and call a user-specified contract on ZEVM.

function depositAndCall(
    MessageContext calldata context,
    address target,
    bytes calldata message
)
    external
    payable
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
contextMessageContextThe context of the cross-chain call.
targetaddressThe target contract to call.
messagebytesThe calldata to pass to the contract call.

executeRevert

Revert a user-specified contract on ZEVM.

function executeRevert(
    address target,
    RevertContext calldata revertContext
)
    external
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
targetaddressThe target contract to call.
revertContextRevertContextRevert context to pass to onRevert.

depositAndRevert

Deposit foreign coins into ZRC20 and revert a user-specified contract on ZEVM.

function depositAndRevert(
    address zrc20,
    uint256 amount,
    address target,
    RevertContext calldata revertContext
)
    external
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to revert.
targetaddressThe target contract to call.
revertContextRevertContextRevert context to pass to onRevert.

depositAndRevert

Deposit native ZETA and revert a user-specified contract on ZEVM.

function depositAndRevert(
    address target,
    RevertContext calldata revertContext
)
    external
    payable
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
targetaddressThe target contract to call.
revertContextRevertContextRevert context to pass to onRevert.

executeAbort

Call onAbort on a user-specified contract on ZEVM. this function doesn't deposit the asset to the target contract. This operation is done directly by the protocol. the assets are deposited to the target contract even if onAbort reverts.

function executeAbort(
    address target,
    AbortContext calldata abortContext
)
    external
    nonReentrant
    onlyProtocol
    whenNotPaused;

Parameters

NameTypeDescription
targetaddressThe target contract to call.
abortContextAbortContextAbort context to pass to onAbort.

getMaxMessageSize

Returns the maximum message size.

function getMaxMessageSize() external pure returns (uint256);

Returns

NameTypeDescription
<none>uint256The maximum message size.

getMinGasLimit

Returns the minimum gas limit allowed.

function getMinGasLimit() external pure returns (uint256);

Returns

NameTypeDescription
<none>uint256The minimum gas limit.

getMaxRevertGasLimit

Returns the maximum revert gas limit allowed.

function getMaxRevertGasLimit() external pure returns (uint256);

Returns

NameTypeDescription
<none>uint256The maximum revert gas limit.

Git Source (opens in a new tab)

Interface for contracts that with non supported methods.

Errors

CallOnRevertNotSupported

error CallOnRevertNotSupported();

Git Source (opens in a new tab)

Holds the ERC20 tokens deposited on ZetaChain and includes functionality to call a contract.

This contract does not call smart contracts directly, it passes through the Gateway contract.

State Variables

gateway

Gateway contract.

IGatewayEVM public gateway;

whitelisted

Mapping of whitelisted tokens => true/false.

mapping(address => bool) public whitelisted;

tssAddress

The address of the TSS (Threshold Signature Scheme) contract.

address public tssAddress;

supportsLegacy

Used to flag if contract supports legacy methods (eg. deposit).

bool public supportsLegacy;

PAUSER_ROLE

New role identifier for pauser role.

bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

WITHDRAWER_ROLE

New role identifier for withdrawer role.

bytes32 public constant WITHDRAWER_ROLE = keccak256("WITHDRAWER_ROLE");

WHITELISTER_ROLE

New role identifier for whitelister role.

bytes32 public constant WHITELISTER_ROLE = keccak256("WHITELISTER_ROLE");

Functions

initialize

Initializer for ERC20Custody.

Set admin as default admin and pauser, and tssAddress as tss role.

function initialize(address gateway_, address tssAddress_, address admin_) public initializer;

_authorizeUpgrade

Authorizes the upgrade of the contract, sender must be owner.

function _authorizeUpgrade(address newImplementation) internal override onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newImplementationaddressAddress of the new implementation.

pause

Pause contract.

function pause() external onlyRole(PAUSER_ROLE);

unpause

Unpause contract.

function unpause() external onlyRole(PAUSER_ROLE);

updateTSSAddress

Update tss address

function updateTSSAddress(address newTSSAddress) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newTSSAddressaddressnew tss address

setSupportsLegacy

Unpause contract.

function setSupportsLegacy(bool _supportsLegacy) external onlyRole(DEFAULT_ADMIN_ROLE);

whitelist

Whitelist ERC20 token.

function whitelist(address token) external onlyRole(WHITELISTER_ROLE);

Parameters

NameTypeDescription
tokenaddressaddress of ERC20 token

unwhitelist

Unwhitelist ERC20 token.

function unwhitelist(address token) external onlyRole(WHITELISTER_ROLE);

Parameters

NameTypeDescription
tokenaddressaddress of ERC20 token

withdraw

Withdraw directly transfers the tokens to the destination address without contract call.

This function can only be called by the TSS address.

function withdraw(
    address to,
    address token,
    uint256 amount
)
    external
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
toaddressDestination address for the tokens.
tokenaddressAddress of the ERC20 token.
amountuint256Amount of tokens to withdraw.

withdrawAndCall

WithdrawAndCall transfers tokens to Gateway and call a contract through the Gateway.

This function can only be called by the TSS address.

function withdrawAndCall(
    MessageContext calldata messageContext,
    address to,
    address token,
    uint256 amount,
    bytes calldata data
)
    public
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender.
toaddressAddress of the contract to call.
tokenaddressAddress of the ERC20 token.
amountuint256Amount of tokens to withdraw.
databytesCalldata to pass to the contract call.

withdrawAndRevert

WithdrawAndRevert transfers tokens to Gateway and call a contract with a revert functionality through the Gateway.

This function can only be called by the TSS address.

function withdrawAndRevert(
    address to,
    address token,
    uint256 amount,
    bytes calldata data,
    RevertContext calldata revertContext
)
    public
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
toaddressAddress of the contract to call.
tokenaddressAddress of the ERC20 token.
amountuint256Amount of tokens to withdraw.
databytesCalldata to pass to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

deposit

Deposits asset to custody and pay fee in zeta erc20.

Note: deprecated: This method is deprecated.

function deposit(
    bytes calldata recipient,
    IERC20 asset,
    uint256 amount,
    bytes calldata message
)
    external
    nonReentrant
    whenNotPaused;

Git Source (opens in a new tab)

Functions

whitelisted

Mapping of whitelisted tokens => true/false.

function whitelisted(address token) external view returns (bool);

withdraw

Withdraw directly transfers the tokens to the destination address without contract call.

This function can only be called by the TSS address.

function withdraw(address token, address to, uint256 amount) external;

Parameters

NameTypeDescription
tokenaddressAddress of the ERC20 token.
toaddressDestination address for the tokens.
amountuint256Amount of tokens to withdraw.

withdrawAndCall

WithdrawAndCall transfers tokens to Gateway and call a contract through the Gateway.

This function can only be called by the TSS address.

function withdrawAndCall(
    MessageContext calldata messageContext,
    address token,
    address to,
    uint256 amount,
    bytes calldata data
)
    external;

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender.
tokenaddressAddress of the ERC20 token.
toaddressAddress of the contract to call.
amountuint256Amount of tokens to withdraw.
databytesCalldata to pass to the contract call.

withdrawAndRevert

WithdrawAndRevert transfers tokens to Gateway and call a contract with a revert functionality through the Gateway.

This function can only be called by the TSS address.

function withdrawAndRevert(
    address token,
    address to,
    uint256 amount,
    bytes calldata data,
    RevertContext calldata revertContext
)
    external;

Parameters

NameTypeDescription
tokenaddressAddress of the ERC20 token.
toaddressAddress of the contract to call.
amountuint256Amount of tokens to withdraw.
databytesCalldata to pass to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

Git Source (opens in a new tab)

Interface for the errors used in the ERC20 custody contract.

Errors

ZeroAddress

Error for zero address input.

error ZeroAddress();

NotWhitelisted

Error for not whitelisted ERC20 token

error NotWhitelisted();

LegacyMethodsNotSupported

Error for calling not supported legacy methods.

error LegacyMethodsNotSupported();

Git Source (opens in a new tab)

Interface for the events emitted by the ERC20 custody contract.

Events

Withdrawn

Emitted when tokens are withdrawn.

event Withdrawn(address indexed to, address indexed token, uint256 amount);

Parameters

NameTypeDescription
toaddressThe address receiving the tokens.
tokenaddressThe address of the ERC20 token.
amountuint256The amount of tokens withdrawn.

WithdrawnAndCalled

Emitted when tokens are withdrawn and a contract call is made.

event WithdrawnAndCalled(address indexed to, address indexed token, uint256 amount, bytes data);

Parameters

NameTypeDescription
toaddressThe address receiving the tokens.
tokenaddressThe address of the ERC20 token.
amountuint256The amount of tokens withdrawn.
databytesThe calldata passed to the contract call.

WithdrawnAndReverted

Emitted when tokens are withdrawn and a revertable contract call is made.

event WithdrawnAndReverted(
    address indexed to, address indexed token, uint256 amount, bytes data, RevertContext revertContext
);

Parameters

NameTypeDescription
toaddressThe address receiving the tokens.
tokenaddressThe address of the ERC20 token.
amountuint256The amount of tokens withdrawn.
databytesThe calldata passed to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

Whitelisted

Emitted when ERC20 token is whitelisted

event Whitelisted(address indexed token);

Parameters

NameTypeDescription
tokenaddressaddress of ERC20 token.

Unwhitelisted

Emitted when ERC20 token is unwhitelisted

event Unwhitelisted(address indexed token);

Parameters

NameTypeDescription
tokenaddressaddress of ERC20 token.

Deposited

Emitted in legacy deposit method.

event Deposited(bytes recipient, IERC20 indexed asset, uint256 amount, bytes message);

UpdatedCustodyTSSAddress

Emitted when tss address is updated

event UpdatedCustodyTSSAddress(address oldTSSAddress, address newTSSAddress);

Parameters

NameTypeDescription
oldTSSAddressaddressold tss address
newTSSAddressaddressnew tss address

Git Source (opens in a new tab)

Interface implemented by contracts receiving authenticated calls.

Functions

onCall

function onCall(MessageContext calldata context, bytes calldata message) external payable returns (bytes memory);

Git Source (opens in a new tab)

Interface for the GatewayEVM contract.

Functions

executeWithERC20

Executes a call to a contract using ERC20 tokens.

function executeWithERC20(
    MessageContext calldata messageContext,
    address token,
    address to,
    uint256 amount,
    bytes calldata data
)
    external;

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender and arbitrary call flag.
tokenaddressThe address of the ERC20 token.
toaddressThe address of the contract to call.
amountuint256The amount of tokens to transfer.
databytesThe calldata to pass to the contract call.

executeRevert

Transfers msg.value to destination contract and executes it's onRevert function.

This function can only be called by the TSS address and it is payable.

function executeRevert(
    address destination,
    bytes calldata data,
    RevertContext calldata revertContext
)
    external
    payable;

Parameters

NameTypeDescription
destinationaddressAddress to call.
databytesCalldata to pass to the call.
revertContextRevertContextRevert context to pass to onRevert.

execute

Executes a call to a destination address without ERC20 tokens.

This function can only be called by the TSS address and it is payable.

function execute(
    MessageContext calldata messageContext,
    address destination,
    bytes calldata data
)
    external
    payable
    returns (bytes memory);

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender and arbitrary call flag.
destinationaddressAddress to call.
databytesCalldata to pass to the call.

Returns

NameTypeDescription
<none>bytesThe result of the call.

revertWithERC20

Executes a revertable call to a contract using ERC20 tokens.

function revertWithERC20(
    address token,
    address to,
    uint256 amount,
    bytes calldata data,
    RevertContext calldata revertContext
)
    external;

Parameters

NameTypeDescription
tokenaddressThe address of the ERC20 token.
toaddressThe address of the contract to call.
amountuint256The amount of tokens to transfer.
databytesThe calldata to pass to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

deposit

Deposits ETH to the TSS address.

function deposit(address receiver, RevertOptions calldata revertOptions) external payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
revertOptionsRevertOptionsRevert options.

deposit

Deposits ETH to the TSS address with specified amount.

function deposit(address receiver, uint256 amount, RevertOptions calldata revertOptions) external payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of ETH to deposit.
revertOptionsRevertOptionsRevert options.

deposit

Deposits ERC20 tokens to the custody or connector contract.

function deposit(
    address receiver,
    uint256 amount,
    address asset,
    RevertOptions calldata revertOptions
)
    external
    payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of tokens to deposit.
assetaddressAddress of the ERC20 token.
revertOptionsRevertOptionsRevert options.

depositAndCall

Deposits ETH to the TSS address and calls an omnichain smart contract.

function depositAndCall(
    address receiver,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

depositAndCall

Deposits ETH to the TSS address and calls an omnichain smart contract with specified amount.

function depositAndCall(
    address receiver,
    uint256 amount,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of ETH to deposit.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

depositAndCall

Deposits ERC20 tokens to the custody or connector contract and calls an omnichain smart contract.

function depositAndCall(
    address receiver,
    uint256 amount,
    address asset,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    external
    payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
amountuint256Amount of tokens to deposit.
assetaddressAddress of the ERC20 token.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

call

Calls an omnichain smart contract without asset transfer.

function call(address receiver, bytes calldata payload, RevertOptions calldata revertOptions) external payable;

Parameters

NameTypeDescription
receiveraddressAddress of the receiver.
payloadbytesCalldata to pass to the call.
revertOptionsRevertOptionsRevert options.

Git Source (opens in a new tab)

Interface for the errors used in the GatewayEVM contract.

Errors

ExecutionFailed

Error for failed execution.

error ExecutionFailed();

DepositFailed

Error for failed deposit.

error DepositFailed();

InsufficientEVMAmount

Error for insufficient token amount.

error InsufficientEVMAmount();

ZeroAddress

Error for zero address input.

error ZeroAddress();

ApprovalFailed

Error for failed token approval.

error ApprovalFailed(address token, address spender);

Parameters

NameTypeDescription
tokenaddressThe address of the token for which approval failed.
spenderaddressThe address that was supposed to be approved to spend the tokens.

CustodyInitialized

Error for already initialized custody.

error CustodyInitialized();

ConnectorInitialized

Error for already initialized connector.

error ConnectorInitialized();

NotWhitelistedInCustody

Error when trying to transfer not whitelisted token to custody.

error NotWhitelistedInCustody(address token);

Parameters

NameTypeDescription
tokenaddressThe address of the token that is not whitelisted in custody.

NotAllowedToCallOnCall

Error when trying to call onCall method using arbitrary call.

error NotAllowedToCallOnCall();

NotAllowedToCallOnRevert

Error when trying to call onRevert method using arbitrary call.

error NotAllowedToCallOnRevert();

PayloadSizeExceeded

Error indicating payload size exceeded in external functions.

error PayloadSizeExceeded(uint256 provided, uint256 maximum);

Parameters

NameTypeDescription
provideduint256The size of the payload that was provided.
maximumuint256The maximum allowed payload size.

FeeTransferFailed

Error thrown when fee transfer to TSS address fails.

This error occurs when the low-level call to transfer fees fails.

error FeeTransferFailed();

InsufficientFee

Error thrown when insufficient fee is provided for additional actions.

error InsufficientFee(uint256 required, uint256 provided);

Parameters

NameTypeDescription
requireduint256The fee amount required for the action.
provideduint256The fee amount actually provided by the caller.

ExcessETHProvided

Error thrown when excess ETH is sent for non-ETH operations.

error ExcessETHProvided(uint256 required, uint256 provided);

Parameters

NameTypeDescription
requireduint256The fee amount required for the action.
provideduint256The ETH amount actually provided by the caller.

AdditionalActionDisabled

Error thrown when additional action functionality is disabled (fee set to 0).

error AdditionalActionDisabled();

IncorrectValueProvided

Error thrown when msg.value doesn't match expected amount + fee.

error IncorrectValueProvided(uint256 expected, uint256 provided);

Parameters

NameTypeDescription
expecteduint256The expected value (amount + fee).
provideduint256The actual msg.value provided.

Git Source (opens in a new tab)

Interface for the events emitted by the GatewayEVM contract.

Events

Executed

Emitted when a contract call is executed.

event Executed(address indexed destination, uint256 value, bytes data);

Parameters

NameTypeDescription
destinationaddressThe address of the contract called.
valueuint256The amount of ETH sent with the call.
databytesThe calldata passed to the contract call.

Reverted

Emitted when a contract call is reverted.

event Reverted(address indexed to, address indexed token, uint256 amount, bytes data, RevertContext revertContext);

Parameters

NameTypeDescription
toaddressThe address of the contract called.
tokenaddressThe address of the ERC20 token, empty if gas token
amountuint256The amount of ETH sent with the call.
databytesThe calldata passed to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

ExecutedWithERC20

Emitted when a contract call with ERC20 tokens is executed.

event ExecutedWithERC20(address indexed token, address indexed to, uint256 amount, bytes data);

Parameters

NameTypeDescription
tokenaddressThe address of the ERC20 token.
toaddressThe address of the contract called.
amountuint256The amount of tokens transferred.
databytesThe calldata passed to the contract call.

Deposited

Emitted when a deposit is made.

event Deposited(
    address indexed sender,
    address indexed receiver,
    uint256 amount,
    address asset,
    bytes payload,
    RevertOptions revertOptions
);

Parameters

NameTypeDescription
senderaddressThe address of the sender.
receiveraddressThe address of the receiver.
amountuint256The amount of ETH or tokens deposited.
assetaddressThe address of the ERC20 token (zero address if ETH).
payloadbytesThe calldata passed with the deposit. No longer used. Kept to maintain compatibility.
revertOptionsRevertOptionsRevert options.

DepositedAndCalled

Emitted when a deposit and call is made.

event DepositedAndCalled(
    address indexed sender,
    address indexed receiver,
    uint256 amount,
    address asset,
    bytes payload,
    RevertOptions revertOptions
);

Parameters

NameTypeDescription
senderaddressThe address of the sender.
receiveraddressThe address of the receiver.
amountuint256The amount of ETH or tokens deposited.
assetaddressThe address of the ERC20 token (zero address if ETH).
payloadbytesThe calldata passed with the deposit.
revertOptionsRevertOptionsRevert options.

Called

Emitted when an omnichain smart contract call is made without asset transfer.

event Called(address indexed sender, address indexed receiver, bytes payload, RevertOptions revertOptions);

Parameters

NameTypeDescription
senderaddressThe address of the sender.
receiveraddressThe address of the receiver.
payloadbytesThe calldata passed to the call.
revertOptionsRevertOptionsRevert options.

UpdatedGatewayTSSAddress

Emitted when tss address is updated

event UpdatedGatewayTSSAddress(address oldTSSAddress, address newTSSAddress);

Parameters

NameTypeDescription
oldTSSAddressaddressold tss address
newTSSAddressaddressnew tss address

UpdatedAdditionalActionFee

event UpdatedAdditionalActionFee(uint256 oldFeeWei, uint256 newFeeWei);

Git Source (opens in a new tab)

Message context passed to execute function.

struct MessageContext {
    address sender;
}

Properties

NameTypeDescription
senderaddressSender from omnichain contract.

Git Source (opens in a new tab)

Structs

ChainMetadataEntry

Structure for metadata entries used during bootstrapping

struct ChainMetadataEntry {
    uint256 chainId;
    string key;
    bytes value;
}

ContractConfigEntry

Structure for contract configuration entries used during bootstrapping

struct ContractConfigEntry {
    uint256 chainId;
    string contractType;
    string key;
    bytes value;
}

Git Source (opens in a new tab)

Interface for the events emitted by the ZetaConnector contracts.

Events

Withdrawn

Emitted when tokens are withdrawn.

event Withdrawn(address indexed to, uint256 amount);

Parameters

NameTypeDescription
toaddressThe address to which the tokens are withdrawn.
amountuint256The amount of tokens withdrawn.

WithdrawnAndCalled

Emitted when tokens are withdrawn and a contract is called.

event WithdrawnAndCalled(address indexed to, uint256 amount, bytes data);

Parameters

NameTypeDescription
toaddressThe address to which the tokens are withdrawn.
amountuint256The amount of tokens withdrawn.
databytesThe calldata passed to the contract call.

WithdrawnAndReverted

Emitted when tokens are withdrawn and a contract is called with a revert callback.

event WithdrawnAndReverted(address indexed to, uint256 amount, bytes data, RevertContext revertContext);

Parameters

NameTypeDescription
toaddressThe address to which the tokens are withdrawn.
amountuint256The amount of tokens withdrawn.
databytesThe calldata passed to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

UpdatedZetaConnectorTSSAddress

Emitted when tss address is updated

event UpdatedZetaConnectorTSSAddress(address oldTSSAddress, address newTSSAddress);

Parameters

NameTypeDescription
oldTSSAddressaddressold tss address
newTSSAddressaddressnew tss address

Git Source (opens in a new tab)

IZetaNonEthNew is a mintable / burnable version of IERC20.

Functions

burnFrom

Burns the specified amount of tokens from the specified account.

Emits a {Transfer} event with to set to the zero address.

function burnFrom(address account, uint256 amount) external;

Parameters

NameTypeDescription
accountaddressThe address of the account from which tokens will be burned.
amountuint256The amount of tokens to burn.

mint

Mints the specified amount of tokens to the specified account.

Emits a {Transfer} event with from set to the zero address.

function mint(address mintee, uint256 value, bytes32 internalSendHash) external;

Parameters

NameTypeDescription
minteeaddressThe address of the account to which tokens will be minted.
valueuint256The amount of tokens to mint.
internalSendHashbytes32A hash used for internal tracking of the minting transaction.

Git Source (opens in a new tab)

Interface with connector custom errors

Errors

CallerIsNotPauser

error CallerIsNotPauser(address caller);

CallerIsNotTss

error CallerIsNotTss(address caller);

CallerIsNotTssUpdater

error CallerIsNotTssUpdater(address caller);

CallerIsNotTssOrUpdater

error CallerIsNotTssOrUpdater(address caller);

ZetaTransferError

error ZetaTransferError();

ExceedsMaxSupply

error ExceedsMaxSupply(uint256 maxSupply);

Git Source (opens in a new tab)

IZetaNonEthInterface.sol is a mintable / burnable version of IERC20

Functions

burnFrom

function burnFrom(address account, uint256 amount) external;

mint

function mint(address mintee, uint256 value, bytes32 internalSendHash) external;

Git Source (opens in a new tab)

Main abstraction of ZetaConnector. This contract manages interactions between TSS and different chains. There's an instance of this contract on each chain supported by ZetaChain.

State Variables

zetaToken

address public immutable zetaToken;

pauserAddress

Multisig contract to pause incoming transactions. The responsibility of pausing outgoing transactions is left to the protocol for more flexibility.

address public pauserAddress;

tssAddress

Collectively held by ZetaChain validators.

address public tssAddress;

tssAddressUpdater

This address will start pointing to a multisig contract, then it will become the TSS address itself.

address public tssAddressUpdater;

Functions

constructor

Constructor requires initial addresses. zetaToken address is the only immutable one, while others can be updated.

constructor(address zetaToken_, address tssAddress_, address tssAddressUpdater_, address pauserAddress_);

onlyPauser

Modifier to restrict actions to pauser address.

modifier onlyPauser();

onlyTssAddress

Modifier to restrict actions to TSS address.

modifier onlyTssAddress();

onlyTssUpdater

Modifier to restrict actions to TSS updater address.

modifier onlyTssUpdater();

updatePauserAddress

Update the pauser address. The only address allowed to do that is the current pauser.

function updatePauserAddress(address pauserAddress_) external onlyPauser;

updateTssAddress

Update the TSS address. The address can be updated by the TSS updater or the TSS address itself.

function updateTssAddress(address tssAddress_) external;

renounceTssAddressUpdater

Changes the ownership of tssAddressUpdater to be the one held by the ZetaChain TSS Signer nodes.

function renounceTssAddressUpdater() external onlyTssUpdater;

pause

Pause the input (send) transactions.

function pause() external onlyPauser;

unpause

Unpause the contract to allow transactions again.

function unpause() external onlyPauser;

send

Entrypoint to send data and value through ZetaChain.

function send(ZetaInterfaces.SendInput calldata input) external virtual;

onReceive

Handler to receive data from other chain. This method can be called only by TSS. Access validation is in implementation.

function onReceive(
    bytes calldata zetaTxSenderAddress,
    uint256 sourceChainId,
    address destinationAddress,
    uint256 zetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    virtual;

onRevert

Handler to receive errors from other chain. This method can be called only by TSS. Access validation is in implementation.

function onRevert(
    address zetaTxSenderAddress,
    uint256 sourceChainId,
    bytes calldata destinationAddress,
    uint256 destinationChainId,
    uint256 remainingZetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    virtual;

Events

ZetaSent

event ZetaSent(
    address sourceTxOriginAddress,
    address indexed zetaTxSenderAddress,
    uint256 indexed destinationChainId,
    bytes destinationAddress,
    uint256 zetaValueAndGas,
    uint256 destinationGasLimit,
    bytes message,
    bytes zetaParams
);

ZetaReceived

event ZetaReceived(
    bytes zetaTxSenderAddress,
    uint256 indexed sourceChainId,
    address indexed destinationAddress,
    uint256 zetaValue,
    bytes message,
    bytes32 indexed internalSendHash
);

ZetaReverted

event ZetaReverted(
    address zetaTxSenderAddress,
    uint256 sourceChainId,
    uint256 indexed destinationChainId,
    bytes destinationAddress,
    uint256 remainingZetaValue,
    bytes message,
    bytes32 indexed internalSendHash
);

TSSAddressUpdated

event TSSAddressUpdated(address callerAddress, address newTssAddress);

TSSAddressUpdaterUpdated

event TSSAddressUpdaterUpdated(address callerAddress, address newTssUpdaterAddress);

PauserAddressUpdated

event PauserAddressUpdated(address callerAddress, address newTssAddress);

Git Source (opens in a new tab)

ETH implementation of ZetaConnector. This contract manages interactions between TSS and different chains. This version is only for Ethereum network because in the other chains we mint and burn and in this one we lock and unlock.

Functions

constructor

constructor(
    address zetaToken_,
    address tssAddress_,
    address tssAddressUpdater_,
    address pauserAddress_
)
    ZetaConnectorBase(zetaToken_, tssAddress_, tssAddressUpdater_, pauserAddress_);

getLockedAmount

function getLockedAmount() external view returns (uint256);

send

Entrypoint to send data through ZetaChain This call locks the token on the contract and emits an event with all the data needed by the protocol.

function send(ZetaInterfaces.SendInput calldata input) external override whenNotPaused;

onReceive

Handler to receive data from other chain. This method can be called only by TSS. Transfers the Zeta tokens to destination and calls onZetaMessage if it's needed.

function onReceive(
    bytes calldata zetaTxSenderAddress,
    uint256 sourceChainId,
    address destinationAddress,
    uint256 zetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    override
    onlyTssAddress;

onRevert

Handler to receive errors from other chain. This method can be called only by TSS. Transfers the Zeta tokens to destination and calls onZetaRevert if it's needed.

function onRevert(
    address zetaTxSenderAddress,
    uint256 sourceChainId,
    bytes calldata destinationAddress,
    uint256 destinationChainId,
    uint256 remainingZetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    override
    whenNotPaused
    onlyTssAddress;

Git Source (opens in a new tab)

Non ETH implementation of ZetaConnector. This contract manages interactions between TSS and different chains. This version is for every chain but Etherum network because in the other chains we mint and burn and in Etherum we lock and unlock

State Variables

maxSupply

uint256 public maxSupply = 2 ** 256 - 1;

Functions

constructor

constructor(
    address zetaTokenAddress_,
    address tssAddress_,
    address tssAddressUpdater_,
    address pauserAddress_
)
    ZetaConnectorBase(zetaTokenAddress_, tssAddress_, tssAddressUpdater_, pauserAddress_);

getLockedAmount

function getLockedAmount() external view returns (uint256);

setMaxSupply

function setMaxSupply(uint256 maxSupply_) external onlyTssAddress;

send

Entry point to send data to protocol This call burn the token and emit an event with all the data needed by the protocol

function send(ZetaInterfaces.SendInput calldata input) external override whenNotPaused;

onReceive

Handler to receive data from other chain. This method can be called only by TSS. Transfer the Zeta tokens to destination and calls onZetaMessage if it's needed. To perform the transfer mint new tokens, validating first the maxSupply allowed in the current chain.

function onReceive(
    bytes calldata zetaTxSenderAddress,
    uint256 sourceChainId,
    address destinationAddress,
    uint256 zetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    override
    onlyTssAddress;

onRevert

Handler to receive errors from other chain. This method can be called only by TSS. Transfer the Zeta tokens to destination and calls onZetaRevert if it's needed. To perform the transfer mint new tokens, validating first the maxSupply allowed in the current chain.

function onRevert(
    address zetaTxSenderAddress,
    uint256 sourceChainId,
    bytes calldata destinationAddress,
    uint256 destinationChainId,
    uint256 remainingZetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    override
    whenNotPaused
    onlyTssAddress;

Events

MaxSupplyUpdated

event MaxSupplyUpdated(address callerAddress, uint256 newMaxSupply);

Git Source (opens in a new tab)

Common custom errors

Errors

CallerIsNotTss

error CallerIsNotTss(address caller);

CallerIsNotConnector

error CallerIsNotConnector(address caller);

CallerIsNotTssUpdater

error CallerIsNotTssUpdater(address caller);

CallerIsNotTssOrUpdater

error CallerIsNotTssOrUpdater(address caller);

InvalidAddress

error InvalidAddress();

ZetaTransferError

error ZetaTransferError();

Git Source (opens in a new tab)

Ethereum is the origin and native chain of the ZETA token deployment (native)

ZetaEth.sol is an implementation of OpenZeppelin's ERC20

Functions

constructor

constructor(address creator, uint256 initialSupply);

Git Source (opens in a new tab)

Errors

InvalidAddress

error InvalidAddress();

Git Source (opens in a new tab)

Functions

send

Sending value and data cross-chain is as easy as calling connector.send(SendInput)

function send(ZetaInterfaces.SendInput calldata input) external;

Git Source (opens in a new tab)

Structs

SendInput

Use SendInput to interact with the Connector: connector.send(SendInput)

struct SendInput {
    uint256 destinationChainId;
    bytes destinationAddress;
    uint256 destinationGasLimit;
    bytes message;
    uint256 zetaValueAndGas;
    bytes zetaParams;
}

ZetaMessage

Our Connector calls onZetaMessage with this struct as argument

struct ZetaMessage {
    bytes zetaTxSenderAddress;
    uint256 sourceChainId;
    address destinationAddress;
    uint256 zetaValue;
    bytes message;
}

ZetaRevert

Our Connector calls onZetaRevert with this struct as argument

struct ZetaRevert {
    address zetaTxSenderAddress;
    uint256 sourceChainId;
    bytes destinationAddress;
    uint256 destinationChainId;
    uint256 remainingZetaValue;
    bytes message;
}

Git Source (opens in a new tab)

Functions

onZetaMessage

onZetaMessage is called when a cross-chain message reaches a contract

function onZetaMessage(ZetaInterfaces.ZetaMessage calldata zetaMessage) external;

onZetaRevert

onZetaRevert is called when a cross-chain message reverts. It's useful to rollback to the original state

function onZetaRevert(ZetaInterfaces.ZetaRevert calldata zetaRevert) external;

Git Source (opens in a new tab)

*ZetaTokenConsumer makes it easier to handle the following situations:

  • Getting Zeta using native coin (to pay for destination gas while using connector.send)
  • Getting Zeta using a token (to pay for destination gas while using connector.send)
  • Getting native coin using Zeta (to return unused destination gas when onZetaRevert is executed)
  • Getting a token using Zeta (to return unused destination gas when onZetaRevert is executed)*

The interface can be implemented using different strategies, like UniswapV2, UniswapV3, etc

Functions

getZetaFromEth

function getZetaFromEth(address destinationAddress, uint256 minAmountOut) external payable returns (uint256);

getZetaFromToken

function getZetaFromToken(
    address destinationAddress,
    uint256 minAmountOut,
    address inputToken,
    uint256 inputTokenAmount
)
    external
    returns (uint256);

getEthFromZeta

function getEthFromZeta(
    address destinationAddress,
    uint256 minAmountOut,
    uint256 zetaTokenAmount
)
    external
    returns (uint256);

getTokenFromZeta

function getTokenFromZeta(
    address destinationAddress,
    uint256 minAmountOut,
    address outputToken,
    uint256 zetaTokenAmount
)
    external
    returns (uint256);

hasZetaLiquidity

function hasZetaLiquidity() external view returns (bool);

Events

EthExchangedForZeta

event EthExchangedForZeta(uint256 amountIn, uint256 amountOut);

TokenExchangedForZeta

event TokenExchangedForZeta(address token, uint256 amountIn, uint256 amountOut);

ZetaExchangedForEth

event ZetaExchangedForEth(uint256 amountIn, uint256 amountOut);

ZetaExchangedForToken

event ZetaExchangedForToken(address token, uint256 amountIn, uint256 amountOut);

Git Source (opens in a new tab)

On non-native (non-Ethereum) chains, ZETA tokens are minted and burned after the initial deployment on Ethereum.

State Variables

connectorAddress

address public connectorAddress;

tssAddress

Collectively held by Zeta blockchain validators

address public tssAddress;

tssAddressUpdater

Initially a multi-sig, eventually held by Zeta blockchain validators (via renounceTssAddressUpdater)

address public tssAddressUpdater;

Functions

constructor

constructor(address tssAddress_, address tssAddressUpdater_) ERC20("Zeta", "ZETA");

updateTssAndConnectorAddresses

function updateTssAndConnectorAddresses(address tssAddress_, address connectorAddress_) external;

renounceTssAddressUpdater

Sets tssAddressUpdater to be tssAddress

function renounceTssAddressUpdater() external;

mint

function mint(address mintee, uint256 value, bytes32 internalSendHash) external override;

burnFrom

function burnFrom(address account, uint256 amount) public override(IZetaNonEthInterface, ERC20Burnable);

Events

Minted

event Minted(address indexed mintee, uint256 amount, bytes32 indexed internalSendHash);

Burnt

event Burnt(address indexed burnee, uint256 amount);

TSSAddressUpdated

event TSSAddressUpdated(address callerAddress, address newTssAddress);

TSSAddressUpdaterUpdated

event TSSAddressUpdaterUpdated(address callerAddress, address newTssUpdaterAddress);

ConnectorAddressUpdated

event ConnectorAddressUpdated(address callerAddress, address newConnectorAddress);

Git Source (opens in a new tab)

Library containing validation functions for GatewayEVM contract.

This library provides common validation logic used across GatewayEVM contract.

State Variables

MAX_PAYLOAD_SIZE

Maximum payload size constant.

uint256 internal constant MAX_PAYLOAD_SIZE = 2880;

Functions

validateNonZeroAddress

Validates that an address is not zero.

function validateNonZeroAddress(address addr) internal pure;

Parameters

NameTypeDescription
addraddressThe address to validate.

validateAmount

Validates that amount is not zero.

function validateAmount(uint256 amount) internal pure;

Parameters

NameTypeDescription
amountuint256The amount to validate.

validatePayloadSize

Validates payload size constraints.

function validatePayloadSize(uint256 payloadLength, uint256 revertMessageLength) internal pure;

Parameters

NameTypeDescription
payloadLengthuint256The length of the main payload.
revertMessageLengthuint256The length of the revert message.

validateGasLimitRevertOptions

Validates on revert gas limit.

function validateGasLimitRevertOptions(RevertOptions calldata revertOptions) internal pure;

Parameters

NameTypeDescription
revertOptionsRevertOptionsThe revert options to validate.

validateRevertMessageLength

Validates on revert message length.

function validateRevertMessageLength(RevertOptions calldata revertOptions) internal pure;

Parameters

NameTypeDescription
revertOptionsRevertOptionsThe revert options to validate.

validateCallRevertOptions

Validates revert options for call operations (includes callOnRevert check).

function validateCallRevertOptions(RevertOptions calldata revertOptions) internal pure;

Parameters

NameTypeDescription
revertOptionsRevertOptionsThe revert options to validate.

validateDepositParams

Validates standard deposit parameters.

function validateDepositParams(address receiver, uint256 amount, RevertOptions calldata revertOptions) internal pure;

Parameters

NameTypeDescription
receiveraddressThe receiver address.
amountuint256The amount to deposit.
revertOptionsRevertOptionsThe revert options.

validateDepositAndCallParams

Validates deposit and call parameters.

function validateDepositAndCallParams(
    address receiver,
    uint256 amount,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    internal
    pure;

Parameters

NameTypeDescription
receiveraddressThe receiver address.
amountuint256The amount to deposit.
payloadbytesThe payload to send.
revertOptionsRevertOptionsThe revert options.

validateCallParams

Validates call parameters.

function validateCallParams(
    address receiver,
    bytes calldata payload,
    RevertOptions calldata revertOptions
)
    internal
    pure;

Parameters

NameTypeDescription
receiveraddressThe receiver address.
payloadbytesThe payload to send.
revertOptionsRevertOptionsThe revert options.

Git Source (opens in a new tab)

Satellite registry contract for connected chains, receiving updates from CoreRegistry.

This contract is deployed on every connected chain and maintains a synchronized view of the registry.

State Variables

GATEWAY_ROLE

Identifier for the gateway role

bytes32 public constant GATEWAY_ROLE = keccak256("GATEWAY_ROLE");

gatewayEVM

GatewayEVM contract that will call this contract with messages from CoreRegistry

IGatewayEVM public gatewayEVM;

coreRegistry

Represents the address of the CoreRegistry contract on the ZetaChain

address public coreRegistry;

Functions

onlyRegistry

Restricts function calls to only be made by this contract itself

Only registry address allowed modifier.

This is used to ensure functions receiving cross-chain messages can only be called through the onCall function using a self-call pattern, preventing direct external calls to these functions

modifier onlyRegistry();

initialize

Initialize the Registry contract

function initialize(
    address admin_,
    address registryManager_,
    address gatewayEVM_,
    address coreRegistry_
)
    public
    initializer;

Parameters

NameTypeDescription
admin_addressAddress with DEFAULT_ADMIN_ROLE, authorized for upgrades and pausing actions
registryManager_addressAddress with REGISTRY_MANAGER_ROLE, authorized for all registry write actions.
gatewayEVM_addressAddress of the GatewayEVM contract for cross-chain messaging
coreRegistry_addressAddress of the CoreRegistry contract deployed on ZetaChain

onCall

onCall is called by the GatewayEVM when a cross-chain message is received

function onCall(
    MessageContext calldata context,
    bytes calldata data
)
    external
    onlyRole(GATEWAY_ROLE)
    whenNotPaused
    returns (bytes memory);

Parameters

NameTypeDescription
contextMessageContextInformation about the cross-chain message
databytesThe encoded function call to execute

changeChainStatus

Changes status of the chain to activated/deactivated

Only callable through onCall from CoreRegistry

function changeChainStatus(
    uint256 chainId,
    address gasZRC20,
    bytes calldata registry,
    bool activation
)
    external
    onlyRegistry
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain being activated/deactivated.
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytesAddress of the Registry contract on the connected chain.
activationboolWhether activate or deactivate the chain

updateChainMetadata

Updates chain metadata, only for the active chains

Only callable through onCall from CoreRegistry

function updateChainMetadata(
    uint256 chainId,
    string calldata key,
    bytes calldata value
)
    external
    onlyRegistry
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain
keystringThe metadata key to update
valuebytesThe new value for the metadata

registerContract

Registers a new contract address for a specific chain

Only callable through onCall from CoreRegistry

function registerContract(
    uint256 chainId,
    string calldata contractType,
    bytes calldata addressBytes
)
    external
    onlyRegistry
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestringThe type of the contract (e.g., "connector", "gateway")
addressBytesbytesThe address of the contract

updateContractConfiguration

Updates contract configuration

Only callable through onCall from CoreRegistry

function updateContractConfiguration(
    uint256 chainId,
    string calldata contractType,
    string calldata key,
    bytes calldata value
)
    external
    onlyRegistry
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestringThe type of the contract
keystringThe configuration key to update
valuebytesThe new value for the configuration

setContractActive

Sets a contract's active status

Only callable through onCall from CoreRegistry

function setContractActive(uint256 chainId, string calldata contractType, bool active) external onlyRegistry;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestringThe type of the contract
activeboolWhether the contract should be active

registerZRC20Token

Registers a new ZRC20 token in the registry

Only callable through onCall from CoreRegistry

function registerZRC20Token(
    address address_,
    string calldata symbol,
    uint256 originChainId,
    bytes calldata originAddress,
    string calldata coinType,
    uint8 decimals
)
    external
    onlyRegistry
    whenNotPaused;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token on ZetaChain
symbolstringThe symbol of the token
originChainIduint256The ID of the foreign chain where the original asset exists
originAddressbytesThe address or identifier of the asset on its native chain
coinTypestringThe type of the original coin
decimalsuint8The number of decimals the token uses

setZRC20TokenActive

Updates ZRC20 token active status

Only callable through onCall from CoreRegistry

function setZRC20TokenActive(address address_, bool active) external onlyRegistry whenNotPaused;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token
activeboolWhether the token should be active

bootstrapChains

Bootstrap the registry with chain data

This function can only be called by an address with the REGISTRY_MANAGER_ROLE.

function bootstrapChains(
    ChainInfoDTO[] calldata chains,
    ChainMetadataEntry[] calldata metadataEntries
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
chainsChainInfoDTO[]Array of chain data structures to bootstrap
metadataEntriesChainMetadataEntry[]Array of chain metadata entries

bootstrapContracts

Bootstrap the registry with contract data

This function can only be called by an address with the REGISTRY_MANAGER_ROLE.

function bootstrapContracts(
    ContractInfoDTO[] calldata contracts,
    ContractConfigEntry[] calldata configEntries
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
contractsContractInfoDTO[]Array of contract data structures to bootstrap
configEntriesContractConfigEntry[]Array of contract configuration entries

bootstrapZRC20Tokens

Bootstrap the registry with ZRC20 token data

This function can only be called by an address with the REGISTRY_MANAGER_ROLE.

function bootstrapZRC20Tokens(ZRC20Info[] calldata tokens) external onlyRole(REGISTRY_MANAGER_ROLE) whenNotPaused;

Parameters

NameTypeDescription
tokensZRC20Info[]Array of ZRC20 token data structures to bootstrap

Git Source (opens in a new tab)

Abstract base contract for ZetaConnector.

This contract implements basic functionality for handling tokens and interacting with the Gateway contract.

State Variables

gateway

The Gateway contract used for executing cross-chain calls.

IGatewayEVM public gateway;

zetaToken

The address of the Zeta token.

address public zetaToken;

tssAddress

The address of the TSS (Threshold Signature Scheme) contract.

address public tssAddress;

WITHDRAWER_ROLE

New role identifier for withdrawer role.

bytes32 public constant WITHDRAWER_ROLE = keccak256("WITHDRAWER_ROLE");

PAUSER_ROLE

New role identifier for pauser role.

bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

TSS_ROLE

New role identifier for tss role.

bytes32 public constant TSS_ROLE = keccak256("TSS_ROLE");

Functions

constructor

Note: oz-upgrades-unsafe-allow: constructor

constructor();

initialize

Initializer for ZetaConnectors.

Set admin as default admin and pauser, and tssAddress as tss role.

function initialize(
    address gateway_,
    address zetaToken_,
    address tssAddress_,
    address admin_
)
    public
    virtual
    onlyInitializing;

_authorizeUpgrade

Authorizes the upgrade of the contract, sender must be owner.

function _authorizeUpgrade(address newImplementation) internal override onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newImplementationaddressAddress of the new implementation.

updateTSSAddress

Update tss address

function updateTSSAddress(address newTSSAddress) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newTSSAddressaddressnew tss address

pause

Pause contract.

function pause() external onlyRole(PAUSER_ROLE);

unpause

Unpause contract.

function unpause() external onlyRole(PAUSER_ROLE);

deposit

Handle received tokens.

function deposit(uint256 amount) external virtual;

Parameters

NameTypeDescription
amountuint256The amount of tokens received.

Errors

ZeroAddress

Error indicating that a zero address was provided.

error ZeroAddress();

Git Source (opens in a new tab)

Implementation of ZetaConnectorBase for native token handling.

This contract directly transfers Zeta tokens and interacts with the Gateway contract.

Functions

initialize

Initializer for ZetaConnectorNative.

function initialize(
    address gateway_,
    address zetaToken_,
    address tssAddress_,
    address admin_
)
    public
    override
    initializer;

withdraw

Withdraw tokens to a specified address.

This function can only be called by the TSS address.

function withdraw(address to, uint256 amount) external nonReentrant onlyRole(WITHDRAWER_ROLE) whenNotPaused;

Parameters

NameTypeDescription
toaddressThe address to withdraw tokens to.
amountuint256The amount of tokens to withdraw.

withdrawAndCall

Withdraw tokens and call a contract through Gateway.

This function can only be called by the TSS address.

function withdrawAndCall(
    MessageContext calldata messageContext,
    address to,
    uint256 amount,
    bytes calldata data
)
    external
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender.
toaddressThe address to withdraw tokens to.
amountuint256The amount of tokens to withdraw.
databytesThe calldata to pass to the contract call.

withdrawAndRevert

Withdraw tokens and call a contract with a revert callback through Gateway.

This function can only be called by the TSS address.

function withdrawAndRevert(
    address to,
    uint256 amount,
    bytes calldata data,
    RevertContext calldata revertContext
)
    external
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
toaddressThe address to withdraw tokens to.
amountuint256The amount of tokens to withdraw.
databytesThe calldata to pass to the contract call.
revertContextRevertContextRevert context to pass to onRevert.

deposit

Handle received tokens.

function deposit(uint256 amount) external override whenNotPaused;

Parameters

NameTypeDescription
amountuint256The amount of tokens received.

Git Source (opens in a new tab)

Implementation of ZetaConnectorBase for non-native token handling.

This contract mints and burns Zeta tokens and interacts with the Gateway contract.

State Variables

maxSupply

Max supply for minting.

uint256 public maxSupply;

Functions

initialize

Initializer for ZetaConnectorNonNative.

function initialize(
    address gateway_,
    address zetaToken_,
    address tssAddress_,
    address admin_
)
    public
    override
    initializer;

setMaxSupply

Set max supply for minting.

This function can only be called by the TSS address.

function setMaxSupply(uint256 maxSupply_) external onlyRole(TSS_ROLE) whenNotPaused;

Parameters

NameTypeDescription
maxSupply_uint256New max supply.

withdraw

Withdraw tokens to a specified address.

This function can only be called by the TSS address.

function withdraw(
    address to,
    uint256 amount,
    bytes32 internalSendHash
)
    external
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
toaddressThe address to withdraw tokens to.
amountuint256The amount of tokens to withdraw.
internalSendHashbytes32A hash used for internal tracking of the transaction.

withdrawAndCall

Withdraw tokens and call a contract through Gateway.

This function can only be called by the TSS address, and mints if supply is not reached.

function withdrawAndCall(
    MessageContext calldata messageContext,
    address to,
    uint256 amount,
    bytes calldata data,
    bytes32 internalSendHash
)
    external
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
messageContextMessageContextMessage context containing sender.
toaddressThe address to withdraw tokens to.
amountuint256The amount of tokens to withdraw.
databytesThe calldata to pass to the contract call.
internalSendHashbytes32A hash used for internal tracking of the transaction.

withdrawAndRevert

Withdraw tokens and call a contract with a revert callback through Gateway.

This function can only be called by the TSS address, and mints if supply is not reached.

function withdrawAndRevert(
    address to,
    uint256 amount,
    bytes calldata data,
    bytes32 internalSendHash,
    RevertContext calldata revertContext
)
    external
    nonReentrant
    onlyRole(WITHDRAWER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
toaddressThe address to withdraw tokens to.
amountuint256The amount of tokens to withdraw.
databytesThe calldata to pass to the contract call.
internalSendHashbytes32A hash used for internal tracking of the transaction.
revertContextRevertContextRevert context to pass to onRevert.

deposit

Handle received tokens and burn them.

function deposit(uint256 amount) external override whenNotPaused;

Parameters

NameTypeDescription
amountuint256The amount of tokens received.

_mintTo

mints to provided account and checks if totalSupply will be exceeded

function _mintTo(address to, uint256 amount, bytes32 internalSendHash) private;

Events

MaxSupplyUpdated

Event triggered when max supply is updated.

event MaxSupplyUpdated(uint256 maxSupply);

Parameters

NameTypeDescription
maxSupplyuint256New max supply.

Errors

ExceedsMaxSupply

error ExceedsMaxSupply();

Git Source (opens in a new tab)

State Variables

PAUSER_ROLE

New role identifier for pauser role.

bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

REGISTRY_MANAGER_ROLE

New role identifier for registry manager role.

bytes32 public constant REGISTRY_MANAGER_ROLE = keccak256("REGISTRY_MANAGER_ROLE");

admin

Address with DEFAULT_ADMIN_ROLE, authorized for upgrades and pausing actions.

address public admin;

registryManager

Address with REGISTRY_MANAGER_ROLE, authorized for all registry write actions.

address public registryManager;

_activeChains

Active chains in the registry.

uint256[] internal _activeChains;

_allChains

Array of all chain IDs in the registry (active and inactive).

uint256[] internal _allChains;

_allContracts

Array to store all contracts as chainId and contractType pairs.

ContractIdentifier[] internal _allContracts;

_allZRC20Addresses

Array of all ZRC20 token addresses.

address[] internal _allZRC20Addresses;

_chains

Maps chain IDs to their information.

mapping(uint256 => ChainInfo) internal _chains;

_contracts

Maps chain ID -> contract type -> ContractInfo

mapping(uint256 => mapping(string => ContractInfo)) internal _contracts;

_zrc20Tokens

Maps ZRC20 token address to their information

mapping(address => ZRC20Info) internal _zrc20Tokens;

_zrc20SymbolToAddress

Maps token symbol to ZRC20 address.

mapping(string => address) internal _zrc20SymbolToAddress;

_originAssetToZRC20

Maps origin chain ID and origin address to ZRC20 token address.

mapping(uint256 => mapping(bytes => address)) internal _originAssetToZRC20;

Functions

constructor

Note: oz-upgrades-unsafe-allow: constructor

constructor();

_authorizeUpgrade

Authorizes the upgrade of the contract, sender must be admin.

function _authorizeUpgrade(address newImplementation) internal override onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newImplementationaddressAddress of the new implementation,

pause

Pause contract.

function pause() external onlyRole(PAUSER_ROLE);

unpause

Unpause contract.

function unpause() external onlyRole(DEFAULT_ADMIN_ROLE);

changeAdmin

Changes the admin address and transfers DEFAULT_ADMIN_ROLE and PAUSER_ROLE.

Only callable by current admin.

function changeAdmin(address newAdmin) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newAdminaddressThe address of the new admin.

changeRegistryManager

Changes the registry manager address and transfers REGISTRY_MANAGER_ROLE and PAUSER_ROLE.

Only callable by admin.

function changeRegistryManager(address newRegistryManager) external onlyRole(DEFAULT_ADMIN_ROLE);

Parameters

NameTypeDescription
newRegistryManageraddressThe address of the new registry manager.

_changeChainStatus

Changes status of the chain to activated/deactivated.

function _changeChainStatus(uint256 chainId, address gasZRC20, bytes calldata registry, bool activation) internal;

Parameters

NameTypeDescription
chainIduint256The ID of the chain to activate.
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytesAddress of the Registry contract on the connected chain.
activationboolWhether activate or deactivate the chain

_updateChainMetadata

Updates chain metadata, only for the active chains.

function _updateChainMetadata(uint256 chainId, string calldata key, bytes calldata value) internal;

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
keystringThe metadata key to update.
valuebytesThe new value for the metadata.

_registerContract

Registers a new contract address for a specific chain.

function _registerContract(uint256 chainId, string calldata contractType, bytes calldata addressBytes) internal;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract (e.g., "connector", "gateway").
addressBytesbytesThe bytes representation of the non-EVM address.

_updateContractConfiguration

Updates contract configuration.

function _updateContractConfiguration(
    uint256 chainId,
    string calldata contractType,
    string calldata key,
    bytes calldata value
)
    internal;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
keystringThe configuration key to update.
valuebytesThe new value for the configuration.

_setContractActive

Sets a contract's active status

function _setContractActive(uint256 chainId, string calldata contractType, bool active) internal;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
activeboolWhether the contract should be active.

_registerZRC20Token

Registers a new ZRC20 token in the registry.

function _registerZRC20Token(
    address address_,
    string calldata symbol,
    uint256 originChainId,
    bytes calldata originAddress,
    string calldata coinType,
    uint8 decimals
)
    internal;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token on ZetaChain.
symbolstringThe symbol of the token.
originChainIduint256The ID of the foreign chain where the original asset exists.
originAddressbytesThe address or identifier of the asset on its native chain.
coinTypestringThe type of the original coin.
decimalsuint8The number of decimals the token uses.

_setZRC20TokenActive

Updates ZRC20 token active status.

function _setZRC20TokenActive(address address_, bool active) internal;

getChainInfo

Gets information about a specific chain.

function getChainInfo(uint256 chainId) external view returns (address gasZRC20, bytes memory registry);

Parameters

NameTypeDescription
chainIduint256The ID of the chain.

Returns

NameTypeDescription
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytesThe registry address deployed on the chain.

getChainMetadata

Gets chain-specific metadata

function getChainMetadata(uint256 chainId, string calldata key) external view returns (bytes memory);

Parameters

NameTypeDescription
chainIduint256The ID of the chain
keystringThe metadata key to retrieve

Returns

NameTypeDescription
<none>bytesThe value of the requested metadata

getContractInfo

Gets information about a specific contract

function getContractInfo(
    uint256 chainId,
    string calldata contractType
)
    external
    view
    returns (bool active, bytes memory addressBytes);

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestringThe type of the contract

Returns

NameTypeDescription
activeboolWhether the contract is active
addressBytesbytesThe address of the contract

getContractConfiguration

Gets contract-specific configuration

function getContractConfiguration(
    uint256 chainId,
    string calldata contractType,
    string calldata key
)
    external
    view
    returns (bytes memory);

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestringThe type of the contract
keystringThe configuration key to retrieve

Returns

NameTypeDescription
<none>bytesThe value of the requested configuration

getZRC20TokenInfo

Gets information about a specific ZRC20 token

function getZRC20TokenInfo(address address_)
    external
    view
    returns (
        bool active,
        string memory symbol,
        uint256 originChainId,
        bytes memory originAddress,
        string memory coinType,
        uint8 decimals
    );

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token

Returns

NameTypeDescription
activeboolWhether the token is active
symbolstringThe symbol of the token
originChainIduint256The ID of the foreign chain where the original asset exists
originAddressbytesThe address or identifier of the asset on its native chain
coinTypestringThe type of the original coin
decimalsuint8The number of decimals the token uses

getZRC20AddressByForeignAsset

Gets the ZRC20 token address for a specific asset on a foreign chain.

function getZRC20AddressByForeignAsset(
    uint256 originChainId,
    bytes calldata originAddress
)
    external
    view
    returns (address);

Parameters

NameTypeDescription
originChainIduint256The ID of the foreign chain
originAddressbytesThe address or identifier of the asset on its native chain.

Returns

NameTypeDescription
<none>addressThe address of the corresponding ZRC20 token on ZetaChain.

getActiveChains

Gets all active chains in the registry.

function getActiveChains() external view returns (uint256[] memory);

Returns

NameTypeDescription
<none>uint256[]Array of chain IDs for all active chains.

getAllChains

Returns information for all chains (active and inactive) in the registry.

function getAllChains() external view returns (ChainInfoDTO[] memory chainsInfo);

Returns

NameTypeDescription
chainsInfoChainInfoDTO[]Array of ChainInfoDTO structs containing information about all chains.

getAllContracts

Returns information for all contracts in the registry.

function getAllContracts() external view returns (ContractInfoDTO[] memory contractsInfo);

Returns

NameTypeDescription
contractsInfoContractInfoDTO[]Array of ContractInfoDTO structs containing information about all contracts.

getAllZRC20Tokens

Returns information for all ZRC20 tokens in the registry.

function getAllZRC20Tokens() external view returns (ZRC20Info[] memory tokensInfo);

Returns

NameTypeDescription
tokensInfoZRC20Info[]Array of ZRC20Info structs containing information about all ZRC20 tokens.

_removeFromActiveChains

Removes a chain ID from the active chains array.

function _removeFromActiveChains(uint256 chainId) private;

Parameters

NameTypeDescription
chainIduint256The ID of the chain to remove.

Git Source (opens in a new tab)

Interface for the BaseRegistry contract.

Functions

changeChainStatus

Changes status of the chain to activated/deactivated.

function changeChainStatus(uint256 chainId, address gasZRC20, bytes calldata registry, bool activation) external;

Parameters

NameTypeDescription
chainIduint256The ID of the chain to activate.
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytes
activationboolWhether activate or deactivate a chain

updateChainMetadata

Updates chain metadata.

function updateChainMetadata(uint256 chainId, string calldata key, bytes calldata value) external;

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
keystringThe metadata key to update.
valuebytesThe new value for the metadata.

registerContract

Registers a new contract address for a specific chain.

function registerContract(uint256 chainId, string calldata contractType, bytes calldata addressBytes) external;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract (e.g., "connector", "gateway").
addressBytesbytesThe bytes representation of the non-EVM address.

updateContractConfiguration

Updates contract configuration.

function updateContractConfiguration(
    uint256 chainId,
    string calldata contractType,
    string calldata key,
    bytes calldata value
)
    external;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
keystringThe configuration key to update.
valuebytesThe new value for the configuration.

setContractActive

function setContractActive(uint256 chainId, string calldata contractType, bool active) external;

registerZRC20Token

Registers a new ZRC20 token in the registry.

function registerZRC20Token(
    address address_,
    string calldata symbol,
    uint256 originChainId,
    bytes calldata originAddress,
    string calldata coinType,
    uint8 decimals
)
    external;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token on ZetaChain.
symbolstringThe symbol of the token.
originChainIduint256The ID of the foreign chain where the original asset exists.
originAddressbytesThe address or identifier of the asset on its native chain.
coinTypestring
decimalsuint8

setZRC20TokenActive

Updates ZRC20 token information.

function setZRC20TokenActive(address address_, bool active) external;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token.
activeboolWhether the token should be active.

getChainInfo

Gets information about a specific chain.

function getChainInfo(uint256 chainId) external view returns (address gasZRC20, bytes memory registry);

Parameters

NameTypeDescription
chainIduint256The ID of the chain.

Returns

NameTypeDescription
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytesThe registry address deployed on the chain.

getChainMetadata

Gets chain-specific metadata.

function getChainMetadata(uint256 chainId, string calldata key) external view returns (bytes memory);

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
keystringThe metadata key to retrieve.

Returns

NameTypeDescription
<none>bytesThe value of the requested metadata.

getContractInfo

Gets information about a specific contract.

function getContractInfo(
    uint256 chainId,
    string calldata contractType
)
    external
    view
    returns (bool active, bytes memory addressBytes);

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.

Returns

NameTypeDescription
activeboolWhether the contract is active.
addressBytesbytesThe address of the contract.

getContractConfiguration

Gets contract-specific configuration.

function getContractConfiguration(
    uint256 chainId,
    string calldata contractType,
    string calldata key
)
    external
    view
    returns (bytes memory);

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
keystringThe configuration key to retrieve.

Returns

NameTypeDescription
<none>bytesThe value of the requested configuration.

getZRC20TokenInfo

Gets information about a specific ZRC20 token.

function getZRC20TokenInfo(address address_)
    external
    view
    returns (
        bool active,
        string memory symbol,
        uint256 originChainId,
        bytes memory originAddress,
        string memory coinType,
        uint8 decimals
    );

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token.

Returns

NameTypeDescription
activeboolWhether the token is active.
symbolstringThe symbol of the token
originChainIduint256The ID of the foreign chain where the original asset exists.
originAddressbytesThe address or identifier of the asset on its native chain.
coinTypestringThe type of the original coin.
decimalsuint8The number of decimals the token uses.

getZRC20AddressByForeignAsset

Gets the ZRC20 token address for a specific asset on a foreign chain.

function getZRC20AddressByForeignAsset(
    uint256 originChainId,
    bytes calldata originAddress
)
    external
    view
    returns (address);

Parameters

NameTypeDescription
originChainIduint256The ID of the foreign chain.
originAddressbytesThe address or identifier of the asset on its native chain.

Returns

NameTypeDescription
<none>addressThe address of the corresponding ZRC20 token on ZetaChain.

getActiveChains

Gets all active chains in the registry.

function getActiveChains() external view returns (uint256[] memory);

Returns

NameTypeDescription
<none>uint256[]Array of chain IDs for all active chains.

getAllChains

Returns information for all chains (active and inactive) in the registry.

function getAllChains() external view returns (ChainInfoDTO[] memory);

Returns

NameTypeDescription
<none>ChainInfoDTO[]chainsInfo Array of ChainInfoDTO structs containing information about all chains.

getAllContracts

Returns information for all contracts in the registry.

function getAllContracts() external view returns (ContractInfoDTO[] memory);

Returns

NameTypeDescription
<none>ContractInfoDTO[]contractsInfo Array of ContractInfoDTO structs containing information about all contracts.

getAllZRC20Tokens

Gets all active chains in the registry.

function getAllZRC20Tokens() external view returns (ZRC20Info[] memory);

Returns

NameTypeDescription
<none>ZRC20Info[]tokensInfo Array of ZRC20Info structs containing information about all ZRC20 tokens.

Git Source (opens in a new tab)

Interface for the errors used by the BaseRegistry contract.

Errors

ZeroAddress

Error thrown when a zero address is provided where a non-zero address is required.

error ZeroAddress();

InvalidSender

Error thrown when the sender is invalid

error InvalidSender();

TransferFailed

Error thrown when a ZRC20 token transfer failed.

error TransferFailed();

ChainActive

Error thrown when a chain is already active.

error ChainActive(uint256 chainId);

Parameters

NameTypeDescription
chainIduint256The ID of the chain that is already active.

ChainNonActive

Error thrown when a chain is not active.

error ChainNonActive(uint256 chainId);

Parameters

NameTypeDescription
chainIduint256The ID of the chain that is not active.

InvalidContractType

Error thrown when a contract type is invalid.

error InvalidContractType(string message);

Parameters

NameTypeDescription
messagestringDescribes why error happened

ContractAlreadyRegistered

Error thrown when a contract is already registered.

error ContractAlreadyRegistered(uint256 chainId, string contractType, bytes addressBytes);

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
contractTypestringThe type of the contract.
addressBytesbytesThe address of the contract.

ContractNotFound

Error thrown when a contract is not found in the registry.

error ContractNotFound(uint256 chainId, string contractType);

Parameters

NameTypeDescription
chainIduint256The ID of the chain,
contractTypestringThe type of the contract.

ZRC20AlreadyRegistered

Error thrown when a ZRC20 token is already registered.

error ZRC20AlreadyRegistered(address address_);

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token.

ZRC20SymbolAlreadyInUse

Error thrown when a ZRC20 token symbol is already in use.

error ZRC20SymbolAlreadyInUse(string symbol);

Parameters

NameTypeDescription
symbolstringThe symbol that is already in use.

Git Source (opens in a new tab)

Interface for the events emitted by the BaseRegistry contract.

Events

ChainStatusChanged

Emitted when a chain status has changed.

event ChainStatusChanged(uint256 indexed chainId, bool newStatus);

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
newStatusboolThe new chain status (is active or not).

ChainMetadataUpdated

Emitted when a chain metadata is set.

event ChainMetadataUpdated(uint256 indexed chainId, string key, bytes value);

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
keystringThe metadata key to update.
valuebytesThe new value for the metadata.

ContractRegistered

Emitted when a new contract is registered.

event ContractRegistered(uint256 indexed chainId, string indexed contractType, bytes addressBytes);

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract (e.g. "connector", "gateway", "tss").
addressBytesbytesThe contract address in bytes representation.

ContractStatusChanged

Emitted when a contract status has changed.

event ContractStatusChanged(bytes addressBytes);

Parameters

NameTypeDescription
addressBytesbytesThe contract address in bytes representation.

ContractConfigurationUpdated

Emitted when a contract configuration is updated.

event ContractConfigurationUpdated(uint256 indexed chainId, string contractType, string key, bytes value);

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
keystringThe configuration key to update.
valuebytesThe new value for the configuration.

ZRC20TokenRegistered

Emitted when a ZRC20 token is registered.

event ZRC20TokenRegistered(
    bytes indexed originAddress, address indexed address_, uint8 decimals, uint256 originChainId, string symbol
);

Parameters

NameTypeDescription
originAddressbytesThe address of the asset on its native chain.
address_addressThe address of the ZRC20 token on ZetaChain.
decimalsuint8The number of decimals the token uses.
originChainIduint256The ID of the foreign chain where the original asset exists.
symbolstringThe symbol of the token.

ZRC20TokenUpdated

Emitted when a ZRC20 token is updated.

event ZRC20TokenUpdated(address address_, bool active);

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token.
activeboolWhether the token should be active.

AdminChanged

Emitted when admin address is changed.

event AdminChanged(address oldAdmin, address newAdmin);

Parameters

NameTypeDescription
oldAdminaddressThe previous admin address.
newAdminaddressThe new admin address.

RegistryManagerChanged

Emitted when registry manager address is changed.

event RegistryManagerChanged(address oldRegistryManager, address newRegistryManager);

Parameters

NameTypeDescription
oldRegistryManageraddressThe previous registry manager address.
newRegistryManageraddressThe new registry manager address.

Git Source (opens in a new tab)

Structure that contains information about a chain.

struct ChainInfo {
    bool active;
    uint256 chainId;
    address gasZRC20;
    bytes registry;
    mapping(string => bytes) metadata;
}

Git Source (opens in a new tab)

Structure that contains information about a chain, used for data retrieving.

struct ChainInfoDTO {
    bool active;
    uint256 chainId;
    address gasZRC20;
    bytes registry;
}

Git Source (opens in a new tab)

Each entry consists of: chainId (uint256) and contractType (string)

struct ContractIdentifier {
    uint256 chainId;
    string contractType;
}

Git Source (opens in a new tab)

Structure that contains information about a contract registered in the system.

struct ContractInfo {
    bool active;
    bytes addressBytes;
    string contractType;
    mapping(string => bytes) configuration;
}

Git Source (opens in a new tab)

Structure that contains information about a contract registered in the system, used for data retrieving.

struct ContractInfoDTO {
    bool active;
    bytes addressBytes;
    string contractType;
    uint256 chainId;
}

Git Source (opens in a new tab)

Structure that contains information about a ZRC20 token.

struct ZRC20Info {
    bool active;
    address address_;
    bytes originAddress;
    uint256 originChainId;
    string symbol;
    string coinType;
    uint8 decimals;
}

Git Source (opens in a new tab)

MAX_REVERT_GAS_LIMIT

uint256 constant MAX_REVERT_GAS_LIMIT = 2_000_000;

Git Source (opens in a new tab)

Error indicating revert gas limit exceeds maximum allowed

error RevertGasLimitExceeded(uint256 provided, uint256 maximum);

Parameters

NameTypeDescription
provideduint256The gas limit provided for revert operation.
maximumuint256The maximum allowed gas limit for revert operation.

Git Source (opens in a new tab)

Interface for contracts that support abortable calls.

Functions

onAbort

Called when a revertable call is aborted.

function onAbort(AbortContext calldata abortContext) external;

Parameters

NameTypeDescription
abortContextAbortContextAbort context to pass to onAbort.

Git Source (opens in a new tab)

Interface for contracts that support revertable calls.

Functions

onRevert

Called when a revertable call is made.

function onRevert(RevertContext calldata revertContext) external payable;

Parameters

NameTypeDescription
revertContextRevertContextRevert context to pass to onRevert.

Git Source (opens in a new tab)

Struct containing abort context passed to onAbort.

struct AbortContext {
    bytes sender;
    address asset;
    uint256 amount;
    bool outgoing;
    uint256 chainID;
    bytes revertMessage;
}

Properties

NameTypeDescription
senderbytesAddress of account that initiated smart contract call. bytes is used as the crosschain transaction can be initiated from a non-EVM chain.
assetaddressAddress of asset. On a connected chain, it contains the fungible token address or is empty if it's a gas token. On ZetaChain, it contains the address of the ZRC20.
amountuint256Amount specified with the transaction.
outgoingboolFlag to indicate if the crosschain transaction was outgoing: from ZetaChain to connected chain. if false, the transaction was incoming: from connected chain to ZetaChain.
chainIDuint256Chain ID of the connected chain.
revertMessagebytesArbitrary data specified in the RevertOptions object when initating the crosschain transaction.

Git Source (opens in a new tab)

Struct containing revert context passed to onRevert.

struct RevertContext {
    address sender;
    address asset;
    uint256 amount;
    bytes revertMessage;
}

Properties

NameTypeDescription
senderaddressAddress of account that initiated smart contract call.
assetaddressAddress of asset. On a connected chain, it contains the fungible token address or is empty if it's a gas token. On ZetaChain, it contains the address of the ZRC20.
amountuint256Amount specified with the transaction.
revertMessagebytesArbitrary data sent back in onRevert.

Git Source (opens in a new tab)

Struct containing revert options

struct RevertOptions {
    address revertAddress;
    bool callOnRevert;
    address abortAddress;
    bytes revertMessage;
    uint256 onRevertGasLimit;
}

Properties

NameTypeDescription
revertAddressaddressAddress to receive revert.
callOnRevertboolFlag if onRevert hook should be called.
abortAddressaddressAddress to receive funds if aborted.
revertMessagebytesArbitrary data sent back in onRevert.
onRevertGasLimituint256Gas limit for revert tx, unused on GatewayZEVM methods

Git Source (opens in a new tab)

Central registry for ZetaChain, managing chain info, ZRC20 data, and contract addresses across all chains.

The contract doesn't hold any funds and should never have active allowances.

State Variables

CROSS_CHAIN_GAS_LIMIT

Cross-chain message gas limit

uint256 public constant CROSS_CHAIN_GAS_LIMIT = 500_000;

gatewayZEVM

Instance of the GatewayZEVM contract for cross-chain communication

IGatewayZEVM public gatewayZEVM;

Functions

initialize

Initialize the CoreRegistry contract.

function initialize(address admin_, address registryManager_, address gatewayZEVM_) public initializer;

Parameters

NameTypeDescription
admin_addressAddress with DEFAULT_ADMIN_ROLE, authorized for upgrades and pausing actions.
registryManager_addressAddress with REGISTRY_MANAGER_ROLE, authorized for all registry write actions.
gatewayZEVM_addressAddress of the GatewayZEVM contract for cross-chain messaging

changeChainStatus

Changes status of the chain to activated/deactivated.

function changeChainStatus(
    uint256 chainId,
    address gasZRC20,
    bytes calldata registry,
    bool activation
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain to activate.
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytesAddress of the Registry contract on the connected chain.
activationboolWhether activate or deactivate the chain

updateChainMetadata

Updates chain metadata, only for the active chains.

function updateChainMetadata(
    uint256 chainId,
    string calldata key,
    bytes calldata value
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain.
keystringThe metadata key to update.
valuebytesThe new value for the metadata.

registerContract

Registers a new contract address for a specific chain.

function registerContract(
    uint256 chainId,
    string calldata contractType,
    bytes calldata addressBytes
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract (e.g., "connector", "gateway").
addressBytesbytesThe bytes representation of the non-EVM address.

updateContractConfiguration

Updates contract configuration.

function updateContractConfiguration(
    uint256 chainId,
    string calldata contractType,
    string calldata key,
    bytes calldata value
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
keystringThe configuration key to update.
valuebytesThe new value for the configuration.

setContractActive

Sets a contract's active status

function setContractActive(
    uint256 chainId,
    string calldata contractType,
    bool active
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed.
contractTypestringThe type of the contract.
activeboolWhether the contract should be active.

registerZRC20Token

Registers a new ZRC20 token in the registry.

function registerZRC20Token(
    address address_,
    string calldata symbol,
    uint256 originChainId,
    bytes calldata originAddress,
    string calldata coinType,
    uint8 decimals
)
    external
    onlyRole(REGISTRY_MANAGER_ROLE)
    whenNotPaused;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token on ZetaChain.
symbolstringThe symbol of the token.
originChainIduint256The ID of the foreign chain where the original asset exists.
originAddressbytesThe address or identifier of the asset on its native chain.
coinTypestringThe type of the original coin.
decimalsuint8The number of decimals the token uses.

setZRC20TokenActive

Updates ZRC20 token active status.

function setZRC20TokenActive(address address_, bool active) external onlyRole(REGISTRY_MANAGER_ROLE) whenNotPaused;

_broadcastChainActivation

Broadcast chain activation update to all satellite registries.

function _broadcastChainActivation(
    uint256 chainId,
    address gasZRC20,
    bytes calldata registry,
    bool activation
)
    internal;

Parameters

NameTypeDescription
chainIduint256The ID of the chain being activated/deactivated.
gasZRC20addressThe address of the ZRC20 token that represents gas token for the chain.
registrybytesAddress of the Registry contract on the connected chain.
activationboolWhether activate or deactivate the chain

_broadcastChainMetadataUpdate

Broadcast chain metadata to all satellite registries

function _broadcastChainMetadataUpdate(uint256 chainId, string calldata key, bytes calldata value) private;

Parameters

NameTypeDescription
chainIduint256The ID of the chain whose metadata is being updated
keystringThe metadata key being updated
valuebytesThe new value for the metadata

_broadcastContractRegistration

Broadcast contract registration to all satellite registries

contractType The type of the contract

addressBytes The bytes representation of the non-EVM address

function _broadcastContractRegistration(
    uint256 chainId,
    string calldata contractType,
    bytes calldata addressBytes
)
    private;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestring
addressBytesbytes

_broadcastContractConfigUpdate

Broadcast contract configuration update to all satellite registries

contractType The type of the contract

key The configuration key being updated

value The new value for the configuration

function _broadcastContractConfigUpdate(
    uint256 chainId,
    string calldata contractType,
    string calldata key,
    bytes calldata value
)
    private;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestring
keystring
valuebytes

_broadcastContractStatusUpdate

Broadcast contract status update to all satellite registries

contractType The type of the contract

active Whether the contract should be active

function _broadcastContractStatusUpdate(uint256 chainId, string calldata contractType, bool active) private;

Parameters

NameTypeDescription
chainIduint256The ID of the chain where the contract is deployed
contractTypestring
activebool

_broadcastZRC20Registration

Broadcast ZRC20 token registration to all satellite registries

function _broadcastZRC20Registration(
    address address_,
    string calldata symbol,
    uint256 originChainId,
    bytes calldata originAddress,
    string calldata coinType,
    uint8 decimals
)
    private;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token on ZetaChain
symbolstringThe symbol of the token
originChainIduint256The ID of the foreign chain where the original asset exists
originAddressbytesThe address or identifier of the asset on its native chain
coinTypestringThe type of the original coin
decimalsuint8The number of decimals the token uses

_broadcastZRC20Update

Broadcast ZRC20 token update to all satellite registries

function _broadcastZRC20Update(address address_, bool active) private;

Parameters

NameTypeDescription
address_addressThe address of the ZRC20 token
activeboolWhether the token should be active

_broadcastToAllChains

Generic function to broadcast encoded messages to all satellite registries

function _broadcastToAllChains(bytes memory encodedMessage) private;

Parameters

NameTypeDescription
encodedMessagebytesThe fully encoded function call to broadcast

_sendCrossChainMessage

Sends a cross-chain message to the Registry contract on a target chain.

function _sendCrossChainMessage(uint256 targetChainId, bytes memory message) private;

Parameters

NameTypeDescription
targetChainIduint256The ID of the chain to send the message to.
messagebytesThe encoded function call to execute on the target chain.

Git Source (opens in a new tab)

Functions

gatewayZEVM

function gatewayZEVM() external returns (address);

Git Source (opens in a new tab)

Interface for the GatewayZEVM contract.

Defines functions for cross-chain interactions and token handling.

Functions

withdraw

Withdraw ZRC20 tokens to an external chain.

function withdraw(
    bytes memory receiver,
    uint256 amount,
    address zrc20,
    RevertOptions calldata revertOptions
)
    external;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
amountuint256The amount of tokens to withdraw.
zrc20addressThe address of the ZRC20 token.
revertOptionsRevertOptionsRevert options.

withdraw

Withdraw ZETA tokens to an external chain.

function withdraw(bytes memory receiver, uint256 chainId, RevertOptions calldata revertOptions) external payable;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
chainIduint256
revertOptionsRevertOptionsRevert options.

withdrawAndCall

Withdraw ZRC20 tokens and call a smart contract on an external chain.

function withdrawAndCall(
    bytes memory receiver,
    uint256 amount,
    address zrc20,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    external;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
amountuint256The amount of tokens to withdraw.
zrc20addressThe address of the ZRC20 token.
messagebytesThe calldata to pass to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

withdrawAndCall

Withdraw ZETA tokens and call a smart contract on an external chain.

function withdrawAndCall(
    bytes memory receiver,
    uint256 chainId,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    external
    payable;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
chainIduint256Chain id of the external chain.
messagebytesThe calldata to pass to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

call

Call a smart contract on an external chain without asset transfer.

function call(
    bytes memory receiver,
    address zrc20,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    external;

Parameters

NameTypeDescription
receiverbytesThe receiver address on the external chain.
zrc20addressAddress of zrc20 to pay fees.
messagebytesThe calldata to pass to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

deposit

Deposit foreign coins into ZRC20.

function deposit(address zrc20, uint256 amount, address target) external;

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to deposit.
targetaddressThe target address to receive the deposited tokens.

deposit

Deposit native ZETA.

function deposit(address target) external payable;

Parameters

NameTypeDescription
targetaddressThe target address to receive the ZETA.

execute

Execute a user-specified contract on ZEVM.

function execute(
    MessageContext calldata context,
    address zrc20,
    uint256 amount,
    address target,
    bytes calldata message
)
    external;

Parameters

NameTypeDescription
contextMessageContextThe context of the cross-chain call.
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to transfer.
targetaddressThe target contract to call.
messagebytesThe calldata to pass to the contract call.

depositAndCall

Deposit foreign coins into ZRC20 and call a user-specified contract on ZEVM.

function depositAndCall(
    MessageContext calldata context,
    address zrc20,
    uint256 amount,
    address target,
    bytes calldata message
)
    external;

Parameters

NameTypeDescription
contextMessageContextThe context of the cross-chain call.
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to transfer.
targetaddressThe target contract to call.
messagebytesThe calldata to pass to the contract call.

depositAndCall

Deposit native ZETA and call a user-specified contract on ZEVM.

function depositAndCall(MessageContext calldata context, address target, bytes calldata message) external payable;

Parameters

NameTypeDescription
contextMessageContextThe context of the cross-chain call.
targetaddressThe target contract to call.
messagebytesThe calldata to pass to the contract call.

executeRevert

Revert a user-specified contract on ZEVM.

function executeRevert(address target, RevertContext calldata revertContext) external;

Parameters

NameTypeDescription
targetaddressThe target contract to call.
revertContextRevertContextRevert context to pass to onRevert.

depositAndRevert

Deposit foreign coins into ZRC20 and revert a user-specified contract on ZEVM.

function depositAndRevert(
    address zrc20,
    uint256 amount,
    address target,
    RevertContext calldata revertContext
)
    external;

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token.
amountuint256The amount of tokens to revert.
targetaddressThe target contract to call.
revertContextRevertContextRevert context to pass to onRevert.

Git Source (opens in a new tab)

Interface for the errors used in the GatewayZEVM contract.

Errors

WithdrawalFailed

Error indicating a withdrawal failure.

error WithdrawalFailed(address token, address recipient, uint256 amount);

Parameters

NameTypeDescription
tokenaddressThe address of the token that failed to withdraw.
recipientaddressThe address that was supposed to receive the tokens.
amountuint256The amount of tokens that failed to withdraw.

InsufficientAmount

Error indicating an insufficient token amount.

error InsufficientAmount();

ZRC20BurnFailed

Error indicating a failure to burn ZRC20 tokens.

error ZRC20BurnFailed(address zrc20, uint256 amount);

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token that failed to burn.
amountuint256The amount of tokens that failed to burn.

ZRC20TransferFailed

Error indicating a failure to transfer ZRC20 tokens.

error ZRC20TransferFailed(address zrc20, address from, address to, uint256 amount);

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token that failed to transfer.
fromaddressThe address sending the tokens.
toaddressThe address receiving the tokens.
amountuint256The amount of tokens that failed to transfer.

ZRC20DepositFailed

Error indicating a failure to deposit ZRC20 tokens.

error ZRC20DepositFailed(address zrc20, address to, uint256 amount);

Parameters

NameTypeDescription
zrc20addressThe address of the ZRC20 token that failed to deposit.
toaddressThe address that was supposed to receive the deposit.
amountuint256The amount of tokens that failed to deposit.

GasFeeTransferFailed

Error indicating a failure to transfer gas fee.

error GasFeeTransferFailed(address token, address to, uint256 amount);

Parameters

NameTypeDescription
tokenaddressThe address of the token used for gas fee.
toaddressThe address that was supposed to receive the gas fee.
amountuint256The amount of gas fee that failed to transfer.

CallerIsNotProtocol

Error indicating that the caller is not the protocol account.

error CallerIsNotProtocol();

InvalidTarget

Error indicating an invalid target address.

error InvalidTarget();

FailedZetaSent

Error indicating a failure to send ZETA tokens.

error FailedZetaSent(address recipient, uint256 amount);

Parameters

NameTypeDescription
recipientaddressThe address that was supposed to receive the ZETA tokens.
amountuint256The amount of ZETA tokens that failed to send.

OnlyWZETAOrProtocol

Error indicating that only WZETA or the protocol address can call the function.

error OnlyWZETAOrProtocol();

InsufficientGasLimit

Error indicating an insufficient gas limit.

error InsufficientGasLimit();

MessageSizeExceeded

Error indicating message size exceeded in external functions.

error MessageSizeExceeded(uint256 provided, uint256 maximum);

Parameters

NameTypeDescription
provideduint256The size of the message that was provided.
maximumuint256The maximum allowed message size.

ZeroGasPrice

Error indicating an invalid gas price.

error ZeroGasPrice();

Git Source (opens in a new tab)

Interface for the events emitted by the GatewayZEVM contract.

Events

Called

Emitted when a cross-chain call is made.

event Called(
    address indexed sender,
    address indexed zrc20,
    bytes receiver,
    bytes message,
    CallOptions callOptions,
    RevertOptions revertOptions
);

Parameters

NameTypeDescription
senderaddressThe address of the sender.
zrc20addressAddress of zrc20 to pay fees.
receiverbytesThe receiver address on the external chain.
messagebytesThe calldata passed to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

Withdrawn

Emitted when a withdrawal is made.

event Withdrawn(
    address indexed sender,
    uint256 indexed chainId,
    bytes receiver,
    address zrc20,
    uint256 value,
    uint256 gasfee,
    uint256 protocolFlatFee,
    bytes message,
    CallOptions callOptions,
    RevertOptions revertOptions
);

Parameters

NameTypeDescription
senderaddressThe address from which the tokens are withdrawn.
chainIduint256Chain id of external chain.
receiverbytesThe receiver address on the external chain.
zrc20addressThe address of the ZRC20 token.
valueuint256The amount of tokens withdrawn.
gasfeeuint256The gas fee for the withdrawal.
protocolFlatFeeuint256The protocol flat fee for the withdrawal.
messagebytesThe calldata passed with the withdraw. No longer used. Kept to maintain compatibility.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

WithdrawnAndCalled

Emitted when a withdraw and call is made.

event WithdrawnAndCalled(
    address indexed sender,
    uint256 indexed chainId,
    bytes receiver,
    address zrc20,
    uint256 value,
    uint256 gasfee,
    uint256 protocolFlatFee,
    bytes message,
    CallOptions callOptions,
    RevertOptions revertOptions
);

Parameters

NameTypeDescription
senderaddressThe address from which the tokens are withdrawn.
chainIduint256Chain id of external chain.
receiverbytesThe receiver address on the external chain.
zrc20addressThe address of the ZRC20 token.
valueuint256The amount of tokens withdrawn.
gasfeeuint256The gas fee for the withdrawal.
protocolFlatFeeuint256The protocol flat fee for the withdrawal.
messagebytesThe calldata passed to the contract call.
callOptionsCallOptionsCall options including gas limit and arbirtrary call flag.
revertOptionsRevertOptionsRevert options.

Git Source (opens in a new tab)

CallOptions struct passed to call and withdrawAndCall functions.

struct CallOptions {
    uint256 gasLimit;
    bool isArbitraryCall;
}

Properties

NameTypeDescription
gasLimituint256Gas limit.
isArbitraryCallboolIndicates if call should be arbitrary or authenticated.

Git Source (opens in a new tab)

Interface for the System contract.

Defines functions for system contract callable by fungible module.

Functions

FUNGIBLE_MODULE_ADDRESS

function FUNGIBLE_MODULE_ADDRESS() external view returns (address);

wZetaContractAddress

function wZetaContractAddress() external view returns (address);

uniswapv2FactoryAddress

function uniswapv2FactoryAddress() external view returns (address);

gasPriceByChainId

function gasPriceByChainId(uint256 chainID) external view returns (uint256);

gasCoinZRC20ByChainId

function gasCoinZRC20ByChainId(uint256 chainID) external view returns (address);

gasZetaPoolByChainId

function gasZetaPoolByChainId(uint256 chainID) external view returns (address);

Git Source (opens in a new tab)

Interface for the Weth9 contract.

Functions

totalSupply

function totalSupply() external view returns (uint256);

balanceOf

function balanceOf(address owner) external view returns (uint256);

allowance

function allowance(address owner, address spender) external view returns (uint256);

approve

function approve(address spender, uint256 wad) external returns (bool);

transfer

function transfer(address to, uint256 wad) external returns (bool);

transferFrom

function transferFrom(address from, address to, uint256 wad) external returns (bool);

deposit

function deposit() external payable;

withdraw

function withdraw(uint256 wad) external;

Events

Approval

event Approval(address indexed owner, address indexed spender, uint256 value);

Transfer

event Transfer(address indexed from, address indexed to, uint256 value);

Deposit

event Deposit(address indexed dst, uint256 wad);

Withdrawal

event Withdrawal(address indexed src, uint256 wad);

Git Source (opens in a new tab)

Coin types for ZRC20. Zeta value should not be used.

enum CoinType {
    Zeta,
    Gas,
    ERC20
}

Git Source (opens in a new tab)

Interface for the ZRC20 token contract.

Functions

totalSupply

function totalSupply() external view returns (uint256);

balanceOf

function balanceOf(address account) external view returns (uint256);

transfer

function transfer(address recipient, uint256 amount) external returns (bool);

allowance

function allowance(address owner, address spender) external view returns (uint256);

approve

function approve(address spender, uint256 amount) external returns (bool);

transferFrom

function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);

deposit

function deposit(address to, uint256 amount) external returns (bool);

burn

function burn(uint256 amount) external returns (bool);

withdraw

function withdraw(bytes memory to, uint256 amount) external returns (bool);

withdrawGasFee

function withdrawGasFee() external view returns (address, uint256);

withdrawGasFeeWithGasLimit

function withdrawGasFeeWithGasLimit(uint256 gasLimit) external view returns (address, uint256);

PROTOCOL_FLAT_FEE

Name is in upper case to maintain compatibility with ZRC20.sol v1

function PROTOCOL_FLAT_FEE() external view returns (uint256);

GAS_LIMIT

Name is in upper case to maintain compatibility with ZRC20.sol v1

function GAS_LIMIT() external view returns (uint256);

SYSTEM_CONTRACT_ADDRESS

Name is in upper case to maintain compatibility with ZRC20.sol v1

function SYSTEM_CONTRACT_ADDRESS() external view returns (address);

setName

function setName(string memory newName) external;

setSymbol

function setSymbol(string memory newSymbol) external;

Git Source (opens in a new tab)

Interface for the ZRC20 metadata.

Functions

name

function name() external view returns (string memory);

symbol

function symbol() external view returns (string memory);

decimals

function decimals() external view returns (uint8);

Git Source (opens in a new tab)

Interface for the ZRC20 events.

Events

Transfer

event Transfer(address indexed from, address indexed to, uint256 value);

Approval

event Approval(address indexed owner, address indexed spender, uint256 value);

Deposit

event Deposit(bytes from, address indexed to, uint256 value);

Withdrawal

event Withdrawal(address indexed from, bytes to, uint256 value, uint256 gasFee, uint256 protocolFlatFee);

UpdatedSystemContract

event UpdatedSystemContract(address systemContract);

UpdatedGateway

event UpdatedGateway(address gateway);

UpdatedGasLimit

event UpdatedGasLimit(uint256 gasLimit);

UpdatedProtocolFlatFee

event UpdatedProtocolFlatFee(uint256 protocolFlatFee);

Git Source (opens in a new tab)

Abstract contract for contracts that can receive cross-chain calls on ZetaChain.

Contracts extending this abstract contract can handle incoming cross-chain messages and execute logic based on the provided context, token, and message payload.

State Variables

registry

Reference to the ZetaChain Registry contract

ICoreRegistry public constant registry = ICoreRegistry(0x7CCE3Eb018bf23e1FE2a32692f2C77592D110394);

gateway

Reference to the ZetaChain Gateway contract

IGatewayZEVM public immutable gateway;

Functions

onlyGateway

Restricts function access to only the gateway contract

Used on functions that process cross-chain messages to ensure they're only called through the Gateway, where message validation occurs. Important for security in functions like onCall() and onRevert() that handle incoming cross-chain operations.

modifier onlyGateway();

constructor

Initializes the contract by retrieving the gateway address from the registry

Fetches the gateway contract address for the current chain from the registry. If the gateway is not active or not found, the gateway will remain uninitialized (address(0)).

constructor();

onCall

Function to handle cross-chain calls with native ZETA transfers

function onCall(MessageContext calldata context, bytes calldata message) external payable virtual;

onCall

Function to handle cross-chain calls with ZRC20 token transfers

function onCall(
    MessageContext calldata context,
    address zrc20,
    uint256 amount,
    bytes calldata message
)
    external
    virtual;

Errors

Unauthorized

Error thrown when a function is called by an unauthorized address

error Unauthorized();

Git Source (opens in a new tab)

Note: deprecated: should be removed once v2 SystemContract is not used anymore. UniversalContract should be used

Functions

onCrossChainCall

function onCrossChainCall(zContext calldata context, address zrc20, uint256 amount, bytes calldata message) external;

Git Source (opens in a new tab)

Provides contextual information when executing a cross-chain call on ZetaChain.

This struct helps identify the sender of the message across different blockchain environments.

struct MessageContext {
    bytes sender;
    address senderEVM;
    uint256 chainID;
}

Git Source (opens in a new tab)

Note: deprecated: should be removed once v2 SystemContract is not used anymore. MessageContext should be used

struct zContext {
    bytes origin;
    address sender;
    uint256 chainID;
}

Git Source (opens in a new tab)

State Variables

wzeta

WZETA token address.

address public wzeta;

FUNGIBLE_MODULE_ADDRESS

Fungible module address.

address public constant FUNGIBLE_MODULE_ADDRESS = payable(0x735b14BB79463307AAcBED86DAf3322B1e6226aB);

Functions

onlyFungibleModule

Modifier to restrict actions to fungible module.

modifier onlyFungibleModule();

constructor

constructor(address wzeta_);

receive

Receive function to receive ZETA from WETH9.withdraw().

receive() external payable;

setWzetaAddress

function setWzetaAddress(address wzeta_) external onlyFungibleModule;

send

Sends ZETA and bytes messages (to execute it) crosschain.

function send(ZetaInterfaces.SendInput calldata input) external;

Parameters

NameTypeDescription
inputZetaInterfaces.SendInput

onReceive

Handler to receive data from other chain. This method can be called only by Fungible Module. Transfer the Zeta tokens to destination and calls onZetaMessage if it's needed. To perform the transfer wrap the new tokens

function onReceive(
    bytes calldata zetaTxSenderAddress,
    uint256 sourceChainId,
    address destinationAddress,
    uint256 zetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    payable
    onlyFungibleModule;

onRevert

Handler to receive errors from other chain. This method can be called only by Fungible Module. Transfer the Zeta tokens to destination and calls onZetaRevert if it's needed.

function onRevert(
    address zetaTxSenderAddress,
    uint256 sourceChainId,
    bytes calldata destinationAddress,
    uint256 destinationChainId,
    uint256 remainingZetaValue,
    bytes calldata message,
    bytes32 internalSendHash
)
    external
    payable
    onlyFungibleModule;

Events

SetWZETA

event SetWZETA(address wzeta_);

ZetaSent

event ZetaSent(
    address sourceTxOriginAddress,
    address indexed zetaTxSenderAddress,
    uint256 indexed destinationChainId,
    bytes destinationAddress,
    uint256 zetaValueAndGas,
    uint256 destinationGasLimit,
    bytes message,
    bytes zetaParams
);

ZetaReceived

event ZetaReceived(
    bytes zetaTxSenderAddress,
    uint256 indexed sourceChainId,
    address indexed destinationAddress,
    uint256 zetaValue,
    bytes message,
    bytes32 indexed internalSendHash
);

ZetaReverted

event ZetaReverted(
    address zetaTxSenderAddress,
    uint256 sourceChainId,
    uint256 indexed destinationChainId,
    bytes destinationAddress,
    uint256 remainingZetaValue,
    bytes message,
    bytes32 indexed internalSendHash
);

Errors

OnlyWZETAOrFungible

Contract custom errors.

error OnlyWZETAOrFungible();

WZETATransferFailed

error WZETATransferFailed();

OnlyFungibleModule

error OnlyFungibleModule();

FailedZetaSent

error FailedZetaSent();

WrongValue

error WrongValue();

Git Source (opens in a new tab)

Structs

SendInput

Use SendInput to interact with the Connector: connector.send(SendInput)

struct SendInput {
    uint256 destinationChainId;
    bytes destinationAddress;
    uint256 destinationGasLimit;
    bytes message;
    uint256 zetaValueAndGas;
    bytes zetaParams;
}

ZetaMessage

Our Connector calls onZetaMessage with this struct as argument

struct ZetaMessage {
    bytes zetaTxSenderAddress;
    uint256 sourceChainId;
    address destinationAddress;
    uint256 zetaValue;
    bytes message;
}

ZetaRevert

Our Connector calls onZetaRevert with this struct as argument

struct ZetaRevert {
    address zetaTxSenderAddress;
    uint256 sourceChainId;
    bytes destinationAddress;
    uint256 destinationChainId;
    uint256 remainingZetaValue;
    bytes message;
}

Git Source (opens in a new tab)

Functions

onZetaMessage

onZetaMessage is called when a cross-chain message reaches a contract

function onZetaMessage(ZetaInterfaces.ZetaMessage calldata zetaMessage) external;

onZetaRevert

onZetaRevert is called when a cross-chain message reverts. It's useful to rollback to the original state

function onZetaRevert(ZetaInterfaces.ZetaRevert calldata zetaRevert) external;

Git Source (opens in a new tab)

Library containing validation functions for GatewayZEVM contract

This library provides common validation logic used across GatewayZEVM contract

State Variables

MAX_MESSAGE_SIZE

Maximum message size constant

uint256 internal constant MAX_MESSAGE_SIZE = 2880;

MIN_GAS_LIMIT

Minimum gas limit constant

uint256 internal constant MIN_GAS_LIMIT = 100_000;

Functions

validateNonZeroAddress

Validates that an address is not zero

function validateNonZeroAddress(address addr) internal pure;

Parameters

NameTypeDescription
addraddressThe address to validate

validateReceiver

Validates that receiver bytes are not empty

function validateReceiver(bytes memory receiver) internal pure;

Parameters

NameTypeDescription
receiverbytesThe receiver bytes to validate

validateAmount

Validates that amount is not zero

function validateAmount(uint256 amount) internal pure;

Parameters

NameTypeDescription
amountuint256The amount to validate

validateGasLimit

Validates that gas limit meets minimum requirement

function validateGasLimit(uint256 gasLimit) internal pure;

Parameters

NameTypeDescription
gasLimituint256The gas limit to validate

validateTarget

Validates that target address is not restricted

function validateTarget(address target, address protocolAddress, address contractAddress) private pure;

Parameters

NameTypeDescription
targetaddressThe target address to validate
protocolAddressaddressThe protocol address to check against
contractAddressaddressThe contract address to check against

validateMessageSize

Validates message size constraints

function validateMessageSize(uint256 messageLength, uint256 revertMessageLength) internal pure;

Parameters

NameTypeDescription
messageLengthuint256The length of the main message
revertMessageLengthuint256The length of the revert message

validateRevertOptions

Validates revert options

function validateRevertOptions(RevertOptions calldata revertOptions) internal pure;

Parameters

NameTypeDescription
revertOptionsRevertOptionsThe revert options to validate

validateCallAndRevertOptions

Validates call options and revert options together

function validateCallAndRevertOptions(
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions,
    uint256 messageLength
)
    internal
    pure;

Parameters

NameTypeDescription
callOptionsCallOptionsThe call options to validate
revertOptionsRevertOptionsThe revert options to validate
messageLengthuint256The length of the message

validateWithdrawalParams

Validates standard withdrawal parameters

function validateWithdrawalParams(
    bytes memory receiver,
    uint256 amount,
    RevertOptions calldata revertOptions
)
    internal
    pure;

Parameters

NameTypeDescription
receiverbytesThe receiver address
amountuint256The amount to withdraw
revertOptionsRevertOptionsThe revert options

validateWithdrawalAndCallParams

Validates withdrawal and call parameters

function validateWithdrawalAndCallParams(
    bytes memory receiver,
    uint256 amount,
    bytes calldata message,
    CallOptions calldata callOptions,
    RevertOptions calldata revertOptions
)
    internal
    pure;

Parameters

NameTypeDescription
receiverbytesThe receiver address
amountuint256The amount to withdraw
messagebytesThe message to send
callOptionsCallOptionsThe call options
revertOptionsRevertOptionsThe revert options

validateDepositParams

Validates deposit parameters

function validateDepositParams(
    address zrc20,
    uint256 amount,
    address target,
    address protocolAddress,
    address contractAddress
)
    internal
    pure;

Parameters

NameTypeDescription
zrc20addressThe ZRC20 token address
amountuint256The amount to deposit
targetaddressThe target address
protocolAddressaddressThe protocol address
contractAddressaddressThe contract address

validateExecuteParams

Validates execute parameters

function validateExecuteParams(address zrc20, address target) internal pure;

Parameters

NameTypeDescription
zrc20addressThe ZRC20 token address
targetaddressThe target address

validateZetaDepositParams

Validates ZETA deposit and call parameters

function validateZetaDepositParams(
    uint256 amount,
    address target,
    address protocolAddress,
    address contractAddress
)
    internal
    pure;

Parameters

NameTypeDescription
amountuint256The amount to deposit
targetaddressThe target address
protocolAddressaddressThe protocol address
contractAddressaddressThe contract address

Errors

EmptyAddress

Error indicating a empty address was provided.

error EmptyAddress();

Git Source (opens in a new tab)

The system contract it's called by the protocol to interact with the blockchain. Also includes a lot of tools to make easier to interact with ZetaChain.

State Variables

gasPriceByChainId

Map to know the gas price of each chain given a chain id.

mapping(uint256 => uint256) public gasPriceByChainId;

gasCoinZRC20ByChainId

Map to know the ZRC20 address of a token given a chain id, ex zETH, zBNB etc.

mapping(uint256 => address) public gasCoinZRC20ByChainId;

gasZetaPoolByChainId

mapping(uint256 => address) public gasZetaPoolByChainId;

FUNGIBLE_MODULE_ADDRESS

Fungible address is always the same, it's on protocol level.

address public constant FUNGIBLE_MODULE_ADDRESS = 0x735b14BB79463307AAcBED86DAf3322B1e6226aB;

uniswapv2FactoryAddress

Uniswap V2 addresses.

address public immutable uniswapv2FactoryAddress;

uniswapv2Router02Address

address public immutable uniswapv2Router02Address;

wZetaContractAddress

Address of the wrapped ZETA to interact with Uniswap V2.

address public wZetaContractAddress;

zetaConnectorZEVMAddress

Address of ZEVM Zeta Connector.

address public zetaConnectorZEVMAddress;

Functions

constructor

Only fungible module can deploy a system contract.

constructor(address wzeta_, address uniswapv2Factory_, address uniswapv2Router02_);

depositAndCall

Deposit foreign coins into ZRC20 and call user specified contract on zEVM.

function depositAndCall(
    zContext calldata context,
    address zrc20,
    uint256 amount,
    address target,
    bytes calldata message
)
    external;

Parameters

NameTypeDescription
contextzContext
zrc20address
amountuint256
targetaddress
messagebytes

sortTokens

Sort token addresses lexicographically. Used to handle return values from pairs sorted in the order.

function sortTokens(address tokenA, address tokenB) internal pure returns (address token0, address token1);

Parameters

NameTypeDescription
tokenAaddress
tokenBaddress

Returns

NameTypeDescription
token0addresstoken1, returns sorted token addresses,.
token1address

uniswapv2PairFor

Calculates the CREATE2 address for a pair without making any external calls.

function uniswapv2PairFor(address factory, address tokenA, address tokenB) public pure returns (address pair);

Parameters

NameTypeDescription
factoryaddress
tokenAaddress
tokenBaddress

Returns

NameTypeDescription
pairaddresstokens pair address.

setGasPrice

Fungible module updates the gas price oracle periodically.

function setGasPrice(uint256 chainID, uint256 price) external;

Parameters

NameTypeDescription
chainIDuint256
priceuint256

setGasCoinZRC20

Setter for gasCoinZRC20ByChainId map.

function setGasCoinZRC20(uint256 chainID, address zrc20) external;

Parameters

NameTypeDescription
chainIDuint256
zrc20address

setGasZetaPool

Set the pool wzeta/erc20 address.

function setGasZetaPool(uint256 chainID, address erc20) external;

Parameters

NameTypeDescription
chainIDuint256
erc20address

setWZETAContractAddress

Setter for wrapped ZETA address.

function setWZETAContractAddress(address addr) external;

Parameters

NameTypeDescription
addraddress

setConnectorZEVMAddress

Setter for zetaConnector ZEVM Address

function setConnectorZEVMAddress(address addr) external;

Parameters

NameTypeDescription
addraddress

Events

SystemContractDeployed

Custom SystemContract errors.

event SystemContractDeployed();

SetGasPrice

event SetGasPrice(uint256, uint256);

SetGasCoin

event SetGasCoin(uint256, address);

SetGasZetaPool

event SetGasZetaPool(uint256, address);

SetWZeta

event SetWZeta(address);

SetConnectorZEVM

event SetConnectorZEVM(address);

Git Source (opens in a new tab)

Custom errors for SystemContract

Errors

CallerIsNotFungibleModule

error CallerIsNotFungibleModule();

InvalidTarget

error InvalidTarget();

CantBeIdenticalAddresses

error CantBeIdenticalAddresses();

CantBeZeroAddress

error CantBeZeroAddress();

ZeroAddress

error ZeroAddress();

Git Source (opens in a new tab)

State Variables

name

string public name = "Wrapped Ether";

symbol

string public symbol = "WETH";

decimals

uint8 public decimals = 18;

balanceOf

mapping(address => uint256) public balanceOf;

allowance

mapping(address => mapping(address => uint256)) public allowance;

Functions

receive

receive() external payable;

deposit

function deposit() public payable;

withdraw

function withdraw(uint256 wad) public;

totalSupply

function totalSupply() public view returns (uint256);

approve

function approve(address guy, uint256 wad) public returns (bool);

transfer

function transfer(address dst, uint256 wad) public returns (bool);

transferFrom

function transferFrom(address src, address dst, uint256 wad) public returns (bool);

Events

Approval

event Approval(address indexed src, address indexed guy, uint256 wad);

Transfer

event Transfer(address indexed src, address indexed dst, uint256 wad);

Deposit

event Deposit(address indexed dst, uint256 wad);

Withdrawal

event Withdrawal(address indexed src, uint256 wad);

Git Source (opens in a new tab)

State Variables

FUNGIBLE_MODULE_ADDRESS

Fungible address is always the same, maintained at the protocol level

address public constant FUNGIBLE_MODULE_ADDRESS = 0x735b14BB79463307AAcBED86DAf3322B1e6226aB;

CHAIN_ID

Chain id.abi

uint256 public immutable CHAIN_ID;

COIN_TYPE

Coin type, checkout Interfaces.sol.

CoinType public immutable COIN_TYPE;

SYSTEM_CONTRACT_ADDRESS

System contract address.

Name is in upper case to maintain compatibility with ZRC20.sol v1

address public SYSTEM_CONTRACT_ADDRESS;

GAS_LIMIT

Gas limit.

Name is in upper case to maintain compatibility with ZRC20.sol v1

uint256 public GAS_LIMIT;

PROTOCOL_FLAT_FEE

Protocol flat fee.

Name is in upper case to maintain compatibility with ZRC20.sol v1

uint256 public override PROTOCOL_FLAT_FEE;

_balances

mapping(address => uint256) private _balances;

_allowances

mapping(address => mapping(address => uint256)) private _allowances;

_totalSupply

uint256 private _totalSupply;

_name

string private _name;

_symbol

string private _symbol;

_decimals

uint8 private _decimals;

gatewayAddress

Gateway contract address.

This variable is added at last position to maintain storage layout with ZRC20.sol v1

address public gatewayAddress;

Functions

_msgSender

function _msgSender() internal view virtual returns (address);

onlyFungible

Only fungible module modifier.

modifier onlyFungible();

constructor

The only one allowed to deploy new ZRC20 is fungible address.

constructor(
    string memory name_,
    string memory symbol_,
    uint8 decimals_,
    uint256 chainid_,
    CoinType coinType_,
    uint256 gasLimit_,
    address systemContractAddress_,
    address gatewayAddress_
);

name

ZRC20 name

function name() public view virtual override returns (string memory);

Returns

NameTypeDescription
<none>stringname as string

setName

Name can be updated by fungible module account.

function setName(string memory newName) external override onlyFungible;

setSymbol

Symbol can be updated by fungible module account.

function setSymbol(string memory newSymbol) external override onlyFungible;

symbol

ZRC20 symbol.

function symbol() public view virtual override returns (string memory);

Returns

NameTypeDescription
<none>stringsymbol as string.

decimals

ZRC20 decimals.

function decimals() public view virtual override returns (uint8);

Returns

NameTypeDescription
<none>uint8returns uint8 decimals.

totalSupply

ZRC20 total supply.

function totalSupply() public view virtual override returns (uint256);

Returns

NameTypeDescription
<none>uint256returns uint256 total supply.

balanceOf

Returns ZRC20 balance of an account.

function balanceOf(address account) public view virtual override returns (uint256);

Parameters

NameTypeDescription
accountaddress

Returns

NameTypeDescription
<none>uint256uint256 account balance.

transfer

Returns ZRC20 balance of an account.

function transfer(address recipient, uint256 amount) public virtual override returns (bool);

Parameters

NameTypeDescription
recipientaddress
amountuint256

Returns

NameTypeDescription
<none>booltrue/false if transfer succeeded/failed.

allowance

Returns token allowance from owner to spender.

function allowance(address owner, address spender) public view virtual override returns (uint256);

Parameters

NameTypeDescription
owneraddress
spenderaddress

Returns

NameTypeDescription
<none>uint256uint256 allowance.

approve

Approves amount transferFrom for spender.

function approve(address spender, uint256 amount) public virtual override returns (bool);

Parameters

NameTypeDescription
spenderaddress
amountuint256

Returns

NameTypeDescription
<none>booltrue/false if succeeded/failed.

transferFrom

Transfers tokens from sender to recipient.

function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool);

Parameters

NameTypeDescription
senderaddress
recipientaddress
amountuint256

Returns

NameTypeDescription
<none>booltrue/false if succeeded/failed.

burn

Burns an amount of tokens.

function burn(uint256 amount) external override returns (bool);

Parameters

NameTypeDescription
amountuint256

Returns

NameTypeDescription
<none>booltrue/false if succeeded/failed.

_transfer

function _transfer(address sender, address recipient, uint256 amount) internal virtual;

_mint

function _mint(address account, uint256 amount) internal virtual;

_burn

function _burn(address account, uint256 amount) internal virtual;

_approve

function _approve(address owner, address spender, uint256 amount) internal virtual;

deposit

Deposits corresponding tokens from external chain, only callable by Fungible module.

function deposit(address to, uint256 amount) external override returns (bool);

Parameters

NameTypeDescription
toaddress
amountuint256

Returns

NameTypeDescription
<none>booltrue/false if succeeded/failed.

withdrawGasFee

Withdraws gas fees.

function withdrawGasFee() public view override returns (address, uint256);

Returns

NameTypeDescription
<none>addressreturns the ZRC20 address for gas on the same chain of this ZRC20, and calculates the gas fee for withdraw()
<none>uint256

withdrawGasFeeWithGasLimit

Withdraws gas fees with specified gasLimit

function withdrawGasFeeWithGasLimit(uint256 gasLimit) public view override returns (address, uint256);

Returns

NameTypeDescription
<none>addressreturns the ZRC20 address for gas on the same chain of this ZRC20, and calculates the gas fee for withdraw()
<none>uint256

withdraw

Withraws ZRC20 tokens to external chains, this function causes cctx module to send out outbound tx to the outbound chain this contract should be given enough allowance of the gas ZRC20 to pay for outbound tx gas fee.

function withdraw(bytes memory to, uint256 amount) external override returns (bool);

Parameters

NameTypeDescription
tobytes
amountuint256

Returns

NameTypeDescription
<none>booltrue/false if succeeded/failed.

updateSystemContractAddress

Updates system contract address. Can only be updated by the fungible module.

function updateSystemContractAddress(address addr) external onlyFungible;

Parameters

NameTypeDescription
addraddress

updateGatewayAddress

Updates gateway contract address. Can only be updated by the fungible module.

function updateGatewayAddress(address addr) external onlyFungible;

Parameters

NameTypeDescription
addraddress

updateGasLimit

Updates gas limit. Can only be updated by the fungible module.

function updateGasLimit(uint256 gasLimit_) external onlyFungible;

Parameters

NameTypeDescription
gasLimit_uint256

updateProtocolFlatFee

Updates protocol flat fee. Can only be updated by the fungible module.

function updateProtocolFlatFee(uint256 protocolFlatFee_) external onlyFungible;

Parameters

NameTypeDescription
protocolFlatFee_uint256

Git Source (opens in a new tab)

Custom errors for ZRC20

Errors

CallerIsNotFungibleModule

error CallerIsNotFungibleModule();

InvalidSender

error InvalidSender();

GasFeeTransferFailed

error GasFeeTransferFailed();

ZeroGasCoin

error ZeroGasCoin();

ZeroGasPrice

error ZeroGasPrice();

LowAllowance

error LowAllowance();

LowBalance

error LowBalance();

ZeroAddress

error ZeroAddress();