Search for projects by name
Poly Bridge allows users to transfer assets between different blockchains using Lock-Mint swap.
Poly Bridge allows users to transfer assets between different blockchains using Lock-Mint swap.
Poly Bridge allows users to transfer assets between different blockchains using Lock-Mint swap.
It uses a PolyNetwork chain to verify and coordinate message passing between Relayers on supported chains. Each chain has a set of Relayers, while PolyNetwork chain has a set of Keepers that sign cross-chain messages. Chains integrated with Poly Bridge need to support light client verification, since validation of cross-chain messages includes verifying block headers and transactions via Merkle proofs. Some of the smart contracts used by the bridge infrastructure are not verified on Etherscan.
Poly Bridge operation is centered around PolyNetwork chain that acts as a type of a light client for all supported chains. Each supported chain has a set or Relayers that transmit successive block headers to the PolyNetwork chain, as well as lock or burn events. Those events, after passing verification on PolyNetwork chain, are relayed to the destination chain by Relayers that are responsible for the destination chain. Relayers on the destination chain pass messages to appropriate contracts that mint or release corresponding tokens to the user after verifying validity of the message.
Funds can be frozen if contract Owner pauses one of the bridge contracts.
Each supported chain has a set of Relayers that are responsible for sending successive block headers since pre-specified origin to the PolyNetwork chain, which stores these blocks after validating their aspects, such as structure, difficulty, consistency with previous blocks, etc. When user locks or burns an asset for a cross-chain swap, an event is relayed by Relayer to the PolyNetwork chain with a Merkle proof of that transaction being included in a block. The PolyNetwork chain is able to verify Merkle proof using block headers that it keeps. PolyNetwork chain itself uses a set of Keepers to sign transactions after checking their validity. Once a cross-chain transaction is verified on PolyNetwork, an event is emitted that is picked by Relayers on the destination chain. The block header and Merkle proof for a transaction on a source chain is validated by a contract on the destination chain (if it supports such verification) and the asset is minted or released to the recipient.
Users can be censored if chain Relayers decide to not pass certain transactions to the destination chain.
Funds can be stolen if a fake block header is relayed through the PolyNetwork chain that allows to prove a burn/mint transaction that never occurred on the source chain.
Funds can be frozen if chain Relayers don't relay messages.
Funds can be frozen if the PolyNetwork Keepers don't sign messages.
Can pause the contracts and update implementation of EthCrossChainData contract.
Can update address of EthCrossChainManagerProxy contract.
Entrypoint contract for the bridge. It proxies requests to LockProxy.
Escrow and proxy contract for the Bridge. This contract can store any token.
Escrow and proxy contract for the Bridge.
Escrow and proxy contract for the Bridge. The source code of this contract is not verified on Etherscan.
Escrow and proxy contract for the Bridge. This contract stores the following tokens: ETH.
Escrow and proxy contract for the Bridge.
Escrow and proxy contract for the Bridge. The source code of this contract is not verified on Etherscan.
Escrow and proxy contract for the Bridge.
Escrow and proxy contract for the Bridge.
Contract responsible for building cross-chain messages and validating incoming messages, including Merkle proofs. The contract is pausable by EthCrossChainManager.
Used to store Keepers’ signatures and other parameters used by EthCrossChainManager.
Used to proxy requests from LockProxy to EthCrossChainManager. The contract is pausable by EthCrossChainManager.
The current deployment carries some associated risks:
Funds can be stolen if a contract receives a malicious code upgrade. There is no delay on code upgrades (CRITICAL).
Funds can be stolen if the source code of unverified contracts contains malicious code (CRITICAL).