Adding support for a new fully EVM-compatible chain to Wallet Core requires only a few changes, follow the steps here. For more complex chain integrations, see general new blockchain docs.
ChainID
. EVM chains have a unique ChainID, such as8217
.Derivation path
used. Most EVM chains use Ethereum derivation path,"m/44'/60'/0'/0/0"
(but not all).CoinID
. Most EVM chains do not have a SLIP 44 CoinID, but some do. We'll see below what to use if one is not available.
- Start with an up-to-date workspace (more info).
- Add chain information to
registry.json
. Some notable fields:- blockchain: "Ethereum",
- coinId: If own coinID is available, use that. Otherwise, use:
10000000 + chainID
, such as10008217
.
- Run
cd codegen-v2 && cargo run -- new-evmchain <chain>
to generate template source files, where is the chainid
from registry. - The result will be a new line in
TWCoinType.h
and a new test filetests/<Chain>/TWCoinTypeTests.cpp
. - There are some test cases test derivation for all coins. Extend these with the new chain. If the new chain reuses Ethereum address, it can reuse the Ethereum case in the switch statements.
rust/tw_any_coin/tests/coin_address_derivation_test.rs
tests/common/CoinAddressDerivationTests.cpp
android/app/src/androidTest/java/com/trustwallet/core/app/blockchains/CoinAddressDerivationTests.kt
kotlin/wallet-core-kotlin/src/commonTest/kotlin/com/trustwallet/core/test/CoinAddressDerivationTests.kt
swift/Tests/CoinAddressDerivationTests.swift
- Update generated sources, build the project, execute unit tests (see building):
./tools/build-and-test
- If all is fine, create a PR with the changes.