TokenBridge
Contract to manage cross-chain ERC20 bridging.
CONTRACT_VERSION
string CONTRACT_VERSION
This is the ABI version and not the reinitialize version.
SET_MESSAGE_SERVICE_ROLE
bytes32 SET_MESSAGE_SERVICE_ROLE
Role used for setting the message service address.
SET_REMOTE_TOKENBRIDGE_ROLE
bytes32 SET_REMOTE_TOKENBRIDGE_ROLE
Role used for setting the remote token bridge address.
SET_RESERVED_TOKEN_ROLE
bytes32 SET_RESERVED_TOKEN_ROLE
Role used for setting a reserved token address.
REMOVE_RESERVED_TOKEN_ROLE
bytes32 REMOVE_RESERVED_TOKEN_ROLE
Role used for removing a reserved token address.
SET_CUSTOM_CONTRACT_ROLE
bytes32 SET_CUSTOM_CONTRACT_ROLE
Role used for setting a custom token contract address.
EMPTY
address EMPTY
EMPTY means a token is not present in the mapping.
RESERVED_STATUS
address RESERVED_STATUS
RESERVED means a token is reserved and cannot be bridged.
NATIVE_STATUS
address NATIVE_STATUS
NATIVE means a token is native to the current local chain.
DEPLOYED_STATUS
address DEPLOYED_STATUS
DEPLOYED means the bridged token contract has been deployed on the remote chain.
_PERMIT_SELECTOR
bytes4 _PERMIT_SELECTOR
The permit selector to be used when decoding the permit.
tokenBeacon
address tokenBeacon
The token beacon for deployed tokens.
nativeToBridgedToken
mapping(uint256 => mapping(address => address)) nativeToBridgedToken
The chainId mapped to a native token address which is then mapped to the bridged token address.
bridgedToNativeToken
mapping(address => address) bridgedToNativeToken
The bridged token address mapped to the native token address.
sourceChainId
uint256 sourceChainId
The current layer's chainId from where the bridging is triggered.
targetChainId
uint256 targetChainId
The targeted layer's chainId where the bridging is received.
isNewToken
modifier isNewToken(address _token)
Ensures the token has not been bridged before.
nonZeroAddress
modifier nonZeroAddress(address _addr)
Ensures the address is not address(0).
Parameters
Name | Type | Description |
---|---|---|
_addr | address | Address to check. |
nonZeroAmount
modifier nonZeroAmount(uint256 _amount)
Ensures the amount is not 0.
Parameters
Name | Type | Description |
---|---|---|
_amount | uint256 | amount to check. |
constructor
constructor() public
Disable constructor for safety
initialize
function initialize(struct ITokenBridge.InitializationData _initializationData) external
Initializes TokenBridge and underlying service dependencies - used for new networks only.
Contract will be used as proxy implementation.
Parameters
Name | Type | Description |
---|---|---|
_initializationData | struct ITokenBridge.InitializationData | The initial data used for initializing the TokenBridge contract. |
reinitializePauseTypesAndPermissions
function reinitializePauseTypesAndPermissions(address _defaultAdmin, struct IPermissionsManager.RoleAddress[] _roleAddresses, struct IPauseManager.PauseTypeRole[] _pauseTypeRoles, struct IPauseManager.PauseTypeRole[] _unpauseTypeRoles) external
Sets permissions for a list of addresses and their roles as well as initialises the PauseManager pauseType:role mappings.
This function is a reinitializer and can only be called once per version. Should be called using an upgradeAndCall transaction to the ProxyAdmin.
Parameters
Name | Type | Description |
---|---|---|
_defaultAdmin | address | The default admin account's address. |
_roleAddresses | struct IPermissionsManager.RoleAddress[] | The list of addresses and roles to assign permissions to. |
_pauseTypeRoles | struct IPauseManager.PauseTypeRole[] | The list of pause types to associate with roles. |
_unpauseTypeRoles | struct IPauseManager.PauseTypeRole[] | The list of unpause types to associate with roles. |
bridgeToken
function bridgeToken(address _token, uint256 _amount, address _recipient) public payable
This function is the single entry point to bridge tokens to the other chain, both for native and already bridged tokens. You can use it to bridge any ERC20. If the token is bridged for the first time an ERC20 (BridgedToken.sol) will be automatically deployed on the target chain.
User should first allow the bridge to transfer tokens on his behalf. Alternatively, you can use BridgeTokenWithPermit to do so in a single transaction. If you want the transfer to be automatically executed on the destination chain. You should send enough ETH to pay the postman fees. Note that Linea can reserve some tokens (which use a dedicated bridge). In this case, the token cannot be bridged. Linea can only reserve tokens that have not been bridged yet. Linea can pause the bridge for security reason. In this case new bridge transaction would revert. Note: If, when bridging an unbridged token and decimals are unknown, the call will revert to prevent mismatched decimals. Only those ERC20s, with a decimals function are supported.
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the token to be bridged. |
_amount | uint256 | The amount of the token to be bridged. |
_recipient | address | The address that will receive the tokens on the other chain. |
bridgeTokenWithPermit
function bridgeTokenWithPermit(address _token, uint256 _amount, address _recipient, bytes _permitData) external payable
Similar to bridgeToken
function but allows to pass additional
permit data to do the ERC20 approval in a single transaction.
_permit can fail silently, don't rely on this function passing as a form
of authentication
There is no need for validation at this level as the validation on pausing, and empty values exists on the "bridgeToken" call.
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the token to be bridged. |
_amount | uint256 | The amount of the token to be bridged. |
_recipient | address | The address that will receive the tokens on the other chain. |
_permitData | bytes | The permit data for the token, if applicable. |
completeBridging
function completeBridging(address _nativeToken, uint256 _amount, address _recipient, uint256 _chainId, bytes _tokenMetadata) external
It can only be called from the Message Service. To finalize the bridging
process, a user or postman needs to use the claimMessage
function of the
Message Service to trigger the transaction.
Parameters
Name | Type | Description |
---|---|---|
_nativeToken | address | The address of the token on its native chain. |
_amount | uint256 | The amount of the token to be received. |
_recipient | address | The address that will receive the tokens. |
_chainId | uint256 | The token's origin layer chaindId |
_tokenMetadata | bytes | Additional data used to deploy the bridged token if it doesn't exist already. |
setMessageService
function setMessageService(address _messageService) external
Change the address of the Message Service. SET_MESSAGE_SERVICE_ROLE is required to execute.
Parameters
Name | Type | Description |
---|---|---|
_messageService | address | The address of the new Message Service. |
confirmDeployment
function confirmDeployment(address[] _tokens) external payable
Change the status to DEPLOYED to the tokens passed in parameter Will call the method setDeployed on the other chain using the message Service
Parameters
Name | Type | Description |
---|---|---|
_tokens | address[] | Array of bridged tokens that have been deployed. |
setDeployed
function setDeployed(address[] _nativeTokens) external
Change the status of tokens to DEPLOYED. New bridge transaction will not
contain token metadata, which save gas.
Can only be called from the Message Service. A user or postman needs to use
the claimMessage
function of the Message Service to trigger the transaction.
Parameters
Name | Type | Description |
---|---|---|
_nativeTokens | address[] | Array of native tokens for which the DEPLOYED status must be set. |
setRemoteTokenBridge
function setRemoteTokenBridge(address _remoteTokenBridge) external
Sets the address of the remote token bridge. Can only be called once. SET_REMOTE_TOKENBRIDGE_ROLE is required to execute.
Parameters
Name | Type | Description |
---|---|---|
_remoteTokenBridge | address | The address of the remote token bridge to be set. |
deployBridgedToken
function deployBridgedToken(address _nativeToken, bytes _tokenMetadata, uint256 _chainId) internal returns (address bridgedTokenAddress)
Deploy a new EC20 contract for bridged token using a beacon proxy pattern. To adapt to future requirements, Linea can update the implementation of all (existing and future) contracts by updating the beacon. This update is subject to a delay by a time lock. Contracts are deployed using CREATE2 so deployment address is deterministic.
Parameters
Name | Type | Description |
---|---|---|
_nativeToken | address | The address of the native token on the source chain. |
_tokenMetadata | bytes | The encoded metadata for the token. |
_chainId | uint256 | The chain id on which the token will be deployed, used to calculate the salt |
Return Values
Name | Type | Description |
---|---|---|
bridgedTokenAddress | address | The address of the newly deployed BridgedToken contract. |
setReserved
function setReserved(address _token) external
Make sure that _token is native to the current chain where you are calling this function from
Linea can reserve tokens. In this case, the token cannot be bridged. Linea can only reserve tokens that have not been bridged before. SET_RESERVED_TOKEN_ROLE is required to execute.
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the token to be set as reserved. |
removeReserved
function removeReserved(address _token) external
Removes a token from the reserved list. REMOVE_RESERVED_TOKEN_ROLE is required to execute.
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the token to be removed from the reserved list. |
setCustomContract
function setCustomContract(address _nativeToken, address _targetContract) external
Linea can set a custom ERC20 contract for specific ERC20. For security purpose, Linea can only call this function if the token has not been bridged yet. SET_CUSTOM_CONTRACT_ROLE is required to execute.
Parameters
Name | Type | Description |
---|---|---|
_nativeToken | address | The address of the token on the source chain. |
_targetContract | address | The address of the custom contract. |
_safeName
function _safeName(address _token) internal view returns (string tokenName)
Provides a safe ERC20.name version which returns 'NO_NAME' as fallback string.
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the ERC-20 token contract |
Return Values
Name | Type | Description |
---|---|---|
tokenName | string | Returns the string of the token name. |
_safeSymbol
function _safeSymbol(address _token) internal view returns (string symbol)
Provides a safe ERC20.symbol version which returns 'NO_SYMBOL' as fallback string
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the ERC-20 token contract |
Return Values
Name | Type | Description |
---|---|---|
symbol | string | Returns the string of the symbol. |
_safeDecimals
function _safeDecimals(address _token) internal view returns (uint8)
Provides a safe ERC20.decimals version which reverts when decimals are unknown Note Tokens with (decimals > 255) are not supported
Parameters
Name | Type | Description |
---|---|---|
_token | address | The address of the ERC-20 token contract |
Return Values
Name | Type | Description |
---|---|---|
[0] | uint8 | Returns the token's decimals value. |
_returnDataToString
function _returnDataToString(bytes _data) internal pure returns (string decodedString)
Converts returned data to string. Returns 'NOT_VALID_ENCODING' as fallback value.
Parameters
Name | Type | Description |
---|---|---|
_data | bytes | returned data. |
Return Values
Name | Type | Description |
---|---|---|
decodedString | string | The decoded string data. |
_permit
function _permit(address _token, bytes _permitData) internal
Call the token permit method of extended ERC20 Only support tokens implementing ERC-2612
Parameters
Name | Type | Description |
---|---|---|
_token | address | ERC20 token address |
_permitData | bytes | Raw data of the call permit of the token |