erc20
Abstract
This document specifies the internal x/erc20
module of the BlockX Chain.
The x/erc20
module enables the BlockX Chain to support a trustless, on-chain bidirectional internal conversion of tokens between BlockX' EVM and Cosmos runtimes, specifically the x/evm
and x/bank
modules.
This allows token holders on BlockX to instantaneously convert their native Cosmos sdk.Coins
(in this document referred to as "Coin(s)") to ERC-20 (aka "Token(s)") and vice versa, while retaining fungibility with the original asset on the issuing environment/runtime (EVM or Cosmos) and preserving ownership of the ERC-20 contract.
This conversion functionality is fully governed by native $BCX token holders who manage the canonical TokenPair
registrations (ie, ERC20 ←→ Coin mappings). This governance functionality is implemented using the Cosmos-SDK gov
module with custom proposal types for registering and updating the canonical mappings respectively.
Why is this important? Cosmos and the EVM are two runtimes that are not compatible by default. The native Cosmos Coins cannot be used in applications that require the ERC-20 standard. Cosmos coins are held on the x/bank
module (with access to module methods like querying the supply or balances) and ERC-20 Tokens live on smart contracts. This problem is similar to wETH, with the difference, that it not only applies to gas tokens (like $BCX), but to all Cosmos Coins (IBC vouchers, staking and gov coins, etc.) as well.
With the x/erc20
users on BlockX can
use existing native cosmos assets (like $OSMO or $ATOM) on EVM-based chains, e.g. for Trading IBC tokens on DeFi protocols, buying NFT, etc.
transfer existing tokens on Ethereum and other EVM-based chains to BlockX to take advantage of application-specific chains in the Cosmos ecosystem
build new applications that are based on ERC-20 smart contracts and have access to the Cosmos ecosystem.