Skip to main content

The Flow VM bridge is the account and series of smart contracts that manage how assets are safely bridged between the Cadence and EVM Flow Environments.

NetworkContract Address
Emulator0xf8d6e0586b0a20c7
Cadence Testing Framework0x0000000000000001
Testnet0xdfc20aee650fcbdf
Mainnet0x1e4aa0b87d10b141

Contracts

There are many important contracts deployed to the bridge account. You should refer to the bridge repo and the bridge guides for more detailed information about the bridge and tutorials for how to use the bridge properly.

Here is a list of each Cadence contract used for the bridge:

ContractPurpose
CrossVMNFTContract defining cross-VM NFT-related interfaces
CrossVMTokenContract defining cross-VM Fungible Token Vault interface
FlowEVMBridgeHandlerInterfacesDefines interface for custom bridged token handlers
IBridgePermissionsDefines an interface to prevent bridging for a specific token
ICrossVMDefines an interface to get EVM contract addresses
ICrossVMAssetDefines an interface to represent a Cadence bridged version of an EVM asset
IEVMBridgeNFTMinterDefines an interface that allows the bridge to mint NFTs
IEVMBridgeTokenMinterDefines an interface that allows the bridge to mint FTs
IFlowEVMNFTBridgeDefines core methods for bridging NFTs
IFlowEVMTokenBridgeDefines core methods for bridging FTs
FlowEVMBridgeThe main entrypoint for briding tokens across Flow VMs
FlowEVMBridgeAccessorDefines methods to route bridge requests from the EVM contract to the Flow-EVM bridge contract
FlowEVMBridgeConfigUsed to store configuration options for the VM Bridge
FlowEVMBridgeCustomAssociationsStores configuration information about custom bridged asset configurations
FlowEVMBridgeCustomAssociationTypesDefines interfaces used to specify custom bridged asset associations
FlowEVMBridgeHandlersDefines mechanisms for handling assets with custom associations (Deprecated)
FlowEVMBridgeNFTEscrowHandles locking of NFTs that are bridged from Flow to EVM and back
FlowEVMBridgeResolverDefines methods to resolve Metadata Views for bridged assets
FlowEVMBridgeTemplatesServes Cadence code from chunked templates for bridge-deployed assets
FlowEVMBridgeTokenEscrowHandles locking of FTs that are bridged from Flow to EVM and back
FlowEVMBridgeUtilsDefines many different utility methods that are used by bridge contracts
ArrayUtilsProvides useful utility functions for manipulating arrays
ScopedFTProvidersProvides utilities for creating provider capabilities for tokens that are restricted to a specific amount
SerializeProvides utilities for serializing common types to json-compatible strings
SerializeMetadataProvides methods for serializing NFT metadata as a JSON compatible string
StringUtilsProvides useful utility functions for manipulating strings

EVM Bridge Solidity Contracts

There are also Solidity contracts that are deployed in Flow EVM that are needed for the bridge. Here are their addresses:

ContractsTestnetMainnet
FlowEVMBridgeFactory.sol0xf8146b4aef631853f0eb98dbe28706d029e52c520x1c6dea788ee774cf15bcd3d7a07ede892ef0be40
FlowEVMBridgeDeploymentRegistry.sol0x8781d15904d7e161f421400571dea24cc0db69380x8fdec2058535a2cb25c2f8cec65e8e0d0691f7b0
FlowEVMBridgedERC20Deployer.sol0x4d45CaD104A71D19991DE3489ddC5C7B284cf2630x49631Eac7e67c417D036a4d114AD9359c93491e7
FlowEVMBridgedERC721Deployer.sol0x1B852d242F9c4C4E9Bb91115276f659D1D1f7c560xe7c2B80a9de81340AE375B3a53940E9aeEAd79Df

And below are the bridge escrow's EVM addresses. These addresses are CadenceOwnedAccounts (COA) and they are stored stored in the same Flow account as you'll find the Cadence contracts (see above).

NetworkAddress
Testnet0x0000000000000000000000023f946ffbc8829bfd
Mainnet0x00000000000000000000000249250a5c27ecab3b