Canto Onboarding UX Improvement Feature

Hi. I am Hyung from B-Harvest.

We are doing various R&D for Canto contribution, including Liquid Staking development, Ethermint R&D and also this topic.

We are suggesting the second CPIP candidate to improve Canto onboarding UX from Ethereum.

Please feel free to drop any feedback so that we can suggest improved version of the document.


Canto Onboarding UX Improvement Feature

Introduction

B-Harvest suggests to implement below functionality on Canto-SDK to

  • Improve the UX for onboarding Canto by solving problem having no Canto for gas usage
  • Allow transferring Ethereum assets to Canto EVM by single transaction on Ethereum

Problem

When users onboard to Canto from Ethereum, they need little amount of Canto for gas. However, since they don’t have any Canto, they are unable to proceed:

  • Create an address on Canto EVM
  • Convert their sdk assets to ERC20 on Canto EVM
  • Swap their Ethereum assets to Canto for gas usage

Suggested Solution

When users transfer assets to the Canto network through Gravity Bridge, the IBC transfer automatically triggers swap and conversion to Canto ERC20 via IBC middleware.

Entire Process Description

  • IBC arrival from Gravity Bridge → (if users do not have more than 4 Canto) swap necessary portion of arrived tokens to get 4 Canto → convert rest of arrived tokens to Canto ERC20
  • The process is non-atomic, meaning that even if the swap or conversion fails, it does not revert IBC transfer

Swap Process

  • Process
    • IBC middleware hooks swap msg upon IBC arrival from Gravity Bridge
    • If the address has less Canto than certain amount(4 Canto), swap proportion of transferred assets to Canto
      • Using exactOut swap, user gets exactly 4 Canto
  • The AMM
    • For AMM, we uses existing Coinswap v1.6 (link) AMM module (basic XYK) from IrisNet including following changes:
      • Whitelist of token pairs which can be created
        • Pool creation fails if the token pair is not in the whitelist
        • Initial whitelist : Canto/USDC.grv, Canto/USDT.grv, Canto/ETH.grv
      • Limit number of Canto for each pool
        • Deposit fails when amount of Canto for the pool exceeds 10,000 Canto
      • Disable double swap
  • Risk Management
    • Swap fails when:
      • input coin amount exceeds pre-defined limit ( 10 USDC, 10 USDT, 0.01 ETH)
      • swap amount limit is not defined

Conversion Process

  • Auto convert transferred asset to Canto ERC20
  • Evmos reference (link)

Rejected Alternative Solution

Modify the AnteHandler to set transaction fees to zero under certain conditions, such as account state, transaction types, destination EVM contracts, and others.

  • This solution enables users to perform the onboarding process without incurring additional gas consumption
  • Opening up zero transaction fees increases the possibility of spamming attacks
8 Likes

TK from Plex here. We’ve been working closely with B-Harvest to design this solution to improve the onboarding user flow for Canto. We’re ready to support in any way possible, including making updates to the canto.io bridge interface to accommodate this feature.

6 Likes

I am currently trying to move my assets from Ethereum to Canto and am unable to proceed because I don’t have CANTO for gas.

I can’t believe it is this hard to get onboarded - makes me as an Ethereum user question whether I want to use Canto instead of a layer-2 network in the first place.

Anything to make the process easier would dramatically increase usage for Canto. Let’s prioritize this!!

2 Likes

I moved my assets from ETH to Canto, however I cant do any other transactions because of limited gas to swap to canto or any other tokens. This is a huge problem for people to use canto. And I believe majority of people who is trying use Canto have this kinda problem as well. So please help us fix this issue or else our assets will be stuck there and cant do anything forever.

2 Likes

development of this feature is completed already by B-Harvest.

we will push for the governance proposal to include the feature in next upgrade soon.

thank you for sharing your thoughts and experience!

2 Likes