High Level Flow
Deposit ETH (1 step process)
The deposit function is to be invoked where the tokens get deposited to the Polygon contract, and are available for use in the Polygon network.
Once you have funds on Polygon, you can use those funds to send to others instantly.
Withdraw ETH (3 step process)
- Withdrawal of funds is initiated from Polygon. A checkpoint interval of 30 mins(For testnets wait for ~10 minutes) is set, where all the blocks on the Polygon block layer are validated since the last checkpoint.
- Once the checkpoint is submitted to the mainchain ERC20 contract, an NFT Exit (ERC721) token is created of equivalent value. Users need to wait for a 7 day challenge period (For testnets wait for ~5 minutes for)
- Once the challenge period is complete, the withdrawn funds can be claimed back to your ERC20 acccount from the mainchain contract using a process-exit procedure.
For now, just go with the fact that the challenge period for withdrawals is an important part of the Plasma framework to ensure security of your transactions. Later, once you get to know the system better, the reason for the 7-day withdrawal window will become clear to you.
Configuring Matic SDK
Install Matic SDK (2.0.2)
Initiating Maticjs client
Create a new file in root directory name it process.env
deposit: Deposit can be done by calling depositEther on depositManagerContract contract.
Note that token needs to be mapped and approved for transfer beforehand.
depositEther method to make this call.
NOTE: Deposits from Ethereum to Polygon happen using a state sync mechanism and takes about ~5-7 minutes. After waiting for this time interval, it is recommended to check the balance using web3.js/matic.js library or using Metamask. The explorer will show the balance only if at least one asset transfer has happened on the child chain. This link explains how to track the deposit events.
ETH on Polygon network is a WETH(ERC20 Token).
recipientis the receiver’s address, to whom the funds are supposed to be sent.
User can call withdraw function of getERC20TokenContract child token contract. This function should burn the tokens. Polygon Plasma client exposes startWithdraw method to make this call.
User can call startExitWithBurntTokens function of erc20Predicate contract. This function should burn the tokens. Polygon Plasma client exposes withdraw method to make this call. This function can be called only after the checkpoint is included in the main chain. The checkpoint inclusion can be tracked by following this guide.
3. Process Exit
Once the Challenge Period has been passed for the transaction present in checkpoint, user should call the processExits function of withdrawManager contract and submit the proof of burn. Upon submitting valid proof tokens are transferred to the user. Polygon Plasma client exposes processExits method to make this call.
Note: A checkpoint, which is a representation of all transactions happening on Polygon to the Ethereum chain every ~5 minutes, is submitted to the mainchain Ethereum contract.