From a85c7d401f0d814eabbc72577a4b24b9ff2dda41 Mon Sep 17 00:00:00 2001
From: satoshiotomakan <127754187+satoshiotomakan@users.noreply.github.com>
Date: Wed, 5 Jun 2024 07:11:52 +0200
Subject: [PATCH] feat(zkLink): Add zkLink Nova Mainnet EVM chain (#3881)
---
.../blockchains/CoinAddressDerivationTests.kt | 2 +-
docs/registry.md | 1 +
include/TrustWalletCore/TWCoinType.h | 1 +
.../core/test/CoinAddressDerivationTests.kt | 2 +-
registry.json | 31 +++++++++++++++++++
.../tests/coin_address_derivation_test.rs | 1 +
swift/Tests/CoinAddressDerivationTests.swift | 3 +-
tests/chains/ZkLinkNova/TWCoinTypeTests.cpp | 29 +++++++++++++++++
tests/common/CoinAddressDerivationTests.cpp | 1 +
9 files changed, 68 insertions(+), 3 deletions(-)
create mode 100644 tests/chains/ZkLinkNova/TWCoinTypeTests.cpp
diff --git a/android/app/src/androidTest/java/com/trustwallet/core/app/blockchains/CoinAddressDerivationTests.kt b/android/app/src/androidTest/java/com/trustwallet/core/app/blockchains/CoinAddressDerivationTests.kt
index 3fa855cc07b..243b33df519 100644
--- a/android/app/src/androidTest/java/com/trustwallet/core/app/blockchains/CoinAddressDerivationTests.kt
+++ b/android/app/src/androidTest/java/com/trustwallet/core/app/blockchains/CoinAddressDerivationTests.kt
@@ -47,7 +47,7 @@ class CoinAddressDerivationTests {
FANTOM, CELO, CRONOSCHAIN, SMARTBITCOINCASH, KUCOINCOMMUNITYCHAIN, BOBA, METIS,
AURORA, EVMOS, MOONRIVER, MOONBEAM, KAVAEVM, KLAYTN, METER, OKXCHAIN, POLYGONZKEVM, SCROLL,
CONFLUXESPACE, ACALAEVM, OPBNB, NEON, BASE, LINEA, GREENFIELD, MANTLE, ZENEON, MANTAPACIFIC,
- ZETAEVM, MERLIN, LIGHTLINK, BLAST, BOUNCEBIT,
+ ZETAEVM, MERLIN, LIGHTLINK, BLAST, BOUNCEBIT, ZKLINKNOVA,
-> assertEquals("0x8f348F300873Fd5DA36950B2aC75a26584584feE", address)
RONIN -> assertEquals("ronin:8f348F300873Fd5DA36950B2aC75a26584584feE", address)
diff --git a/docs/registry.md b/docs/registry.md
index ad4c51171a7..b278eaba2a0 100644
--- a/docs/registry.md
+++ b/docs/registry.md
@@ -104,6 +104,7 @@ This list is generated from [./registry.json](../registry.json)
| 81457 | Blast | ETH | | |
| 105105 | Stratis | STRAX | | |
| 534352 | Scroll | ETH | | |
+| 810180 | zkLink Nova Mainnet | ETH | | |
| 5718350 | Wanchain | WAN | | |
| 5741564 | Waves | WAVES | | |
| 10000025 | Cronos Chain | CRO | | |
diff --git a/include/TrustWalletCore/TWCoinType.h b/include/TrustWalletCore/TWCoinType.h
index ce3f2aa0d20..0726ca25b44 100644
--- a/include/TrustWalletCore/TWCoinType.h
+++ b/include/TrustWalletCore/TWCoinType.h
@@ -185,6 +185,7 @@ enum TWCoinType {
TWCoinTypeLightlink = 1890,
TWCoinTypeBlast = 81457,
TWCoinTypeBounceBit = 6001,
+ TWCoinTypeZkLinkNova = 810180,
// end_of_tw_coin_type_marker_do_not_modify
};
diff --git a/kotlin/wallet-core-kotlin/src/commonTest/kotlin/com/trustwallet/core/test/CoinAddressDerivationTests.kt b/kotlin/wallet-core-kotlin/src/commonTest/kotlin/com/trustwallet/core/test/CoinAddressDerivationTests.kt
index 1714a611aba..39f84b264cd 100644
--- a/kotlin/wallet-core-kotlin/src/commonTest/kotlin/com/trustwallet/core/test/CoinAddressDerivationTests.kt
+++ b/kotlin/wallet-core-kotlin/src/commonTest/kotlin/com/trustwallet/core/test/CoinAddressDerivationTests.kt
@@ -40,7 +40,7 @@ class CoinAddressDerivationTests {
Fantom, Celo, CronosChain, SmartBitcoinCash, KuCoinCommunityChain, Boba, Metis,
Aurora, Evmos, Moonriver, Moonbeam, KavaEvm, Klaytn, Meter, OKXChain, PolygonzkEVM, Scroll,
ConfluxeSpace, AcalaEVM, OpBNB, Neon, Base, Linea, Greenfield, Mantle, ZenEON, MantaPacific,
- ZetaEVM, Merlin, Lightlink, Blast, BounceBit,
+ ZetaEVM, Merlin, Lightlink, Blast, BounceBit, ZkLinkNova,
-> "0x8f348F300873Fd5DA36950B2aC75a26584584feE"
Ronin -> "ronin:8f348F300873Fd5DA36950B2aC75a26584584feE"
diff --git a/registry.json b/registry.json
index c4953ef0313..d1c60580978 100644
--- a/registry.json
+++ b/registry.json
@@ -4749,5 +4749,36 @@
"rpc": "https://fullnode-mainnet.bouncebitapi.com",
"documentation": "https://docs.bouncebit.io"
}
+ },
+ {
+ "id": "zklinknova",
+ "name": "ZkLinkNova",
+ "displayName": "zkLink Nova Mainnet",
+ "coinId": 810180,
+ "symbol": "ETH",
+ "decimals": 18,
+ "blockchain": "Ethereum",
+ "derivation": [
+ {
+ "path": "m/44'/60'/0'/0/0"
+ }
+ ],
+ "curve": "secp256k1",
+ "publicKeyType": "secp256k1Extended",
+ "chainId": "810180",
+ "addressHasher": "keccak256",
+ "explorer": {
+ "url": "https://explorer.zklink.io",
+ "txPath": "/tx/",
+ "accountPath": "/address/",
+ "sampleTx": "0xeb5eb8710369c89115a83f3e744c15c9d388030cfce2fd3a653dbd18f2947400",
+ "sampleAccount": "0xF95115BaD9a4585B3C5e2bfB50579f17163A45aA"
+ },
+ "info": {
+ "url": "https://zklink.io",
+ "source": "https://github.com/zkLinkProtocol",
+ "rpc": "https://rpc.zklink.io",
+ "documentation": "https://docs.zklink.io"
+ }
}
]
diff --git a/rust/tw_any_coin/tests/coin_address_derivation_test.rs b/rust/tw_any_coin/tests/coin_address_derivation_test.rs
index 2e9c4b0c018..ab873f5d3df 100644
--- a/rust/tw_any_coin/tests/coin_address_derivation_test.rs
+++ b/rust/tw_any_coin/tests/coin_address_derivation_test.rs
@@ -90,6 +90,7 @@ fn test_coin_address_derivation() {
| CoinType::Lightlink
| CoinType::Blast
| CoinType::BounceBit
+ | CoinType::ZkLinkNova
// end_of_evm_address_derivation_tests_marker_do_not_modify
=> "0xAc1ec44E4f0ca7D172B7803f6836De87Fb72b309",
CoinType::Bitcoin
diff --git a/swift/Tests/CoinAddressDerivationTests.swift b/swift/Tests/CoinAddressDerivationTests.swift
index e6cda80b29a..7e17c1f3503 100644
--- a/swift/Tests/CoinAddressDerivationTests.swift
+++ b/swift/Tests/CoinAddressDerivationTests.swift
@@ -118,7 +118,8 @@ class CoinAddressDerivationTests: XCTestCase {
.merlin,
.lightlink,
.blast,
- .bounceBit:
+ .bounceBit,
+ .zkLinkNova:
let expectedResult = "0x8f348F300873Fd5DA36950B2aC75a26584584feE"
assertCoinDerivation(coin, expectedResult, derivedAddress, address)
case .ronin:
diff --git a/tests/chains/ZkLinkNova/TWCoinTypeTests.cpp b/tests/chains/ZkLinkNova/TWCoinTypeTests.cpp
new file mode 100644
index 00000000000..933ab752af8
--- /dev/null
+++ b/tests/chains/ZkLinkNova/TWCoinTypeTests.cpp
@@ -0,0 +1,29 @@
+// SPDX-License-Identifier: Apache-2.0
+//
+// Copyright © 2017 Trust Wallet.
+
+#include "TestUtilities.h"
+#include
+#include
+
+TEST(TWZkLinkNovaCoinType, TWCoinType) {
+ const auto coin = TWCoinTypeZkLinkNova;
+ const auto symbol = WRAPS(TWCoinTypeConfigurationGetSymbol(coin));
+ const auto id = WRAPS(TWCoinTypeConfigurationGetID(coin));
+ const auto name = WRAPS(TWCoinTypeConfigurationGetName(coin));
+ const auto txId = WRAPS(TWStringCreateWithUTF8Bytes("0xeb5eb8710369c89115a83f3e744c15c9d388030cfce2fd3a653dbd18f2947400"));
+ const auto txUrl = WRAPS(TWCoinTypeConfigurationGetTransactionURL(coin, txId.get()));
+ const auto accId = WRAPS(TWStringCreateWithUTF8Bytes("0xF95115BaD9a4585B3C5e2bfB50579f17163A45aA"));
+ const auto accUrl = WRAPS(TWCoinTypeConfigurationGetAccountURL(coin, accId.get()));
+
+ assertStringsEqual(id, "zklinknova");
+ assertStringsEqual(name, "zkLink Nova Mainnet");
+ assertStringsEqual(symbol, "ETH");
+ ASSERT_EQ(TWCoinTypeConfigurationGetDecimals(coin), 18);
+ ASSERT_EQ(TWCoinTypeBlockchain(coin), TWBlockchainEthereum);
+ ASSERT_EQ(TWCoinTypeP2pkhPrefix(coin), 0);
+ ASSERT_EQ(TWCoinTypeP2shPrefix(coin), 0);
+ ASSERT_EQ(TWCoinTypeStaticPrefix(coin), 0);
+ assertStringsEqual(txUrl, "https://explorer.zklink.io/tx/0xeb5eb8710369c89115a83f3e744c15c9d388030cfce2fd3a653dbd18f2947400");
+ assertStringsEqual(accUrl, "https://explorer.zklink.io/address/0xF95115BaD9a4585B3C5e2bfB50579f17163A45aA");
+}
diff --git a/tests/common/CoinAddressDerivationTests.cpp b/tests/common/CoinAddressDerivationTests.cpp
index 351b5dd4954..96ceb19b711 100644
--- a/tests/common/CoinAddressDerivationTests.cpp
+++ b/tests/common/CoinAddressDerivationTests.cpp
@@ -88,6 +88,7 @@ TEST(Coin, DeriveAddress) {
case TWCoinTypeLightlink:
case TWCoinTypeBlast:
case TWCoinTypeBounceBit:
+ case TWCoinTypeZkLinkNova:
// end_of_evm_address_derivation_tests_marker_do_not_modify
EXPECT_EQ(address, "0x9d8A62f656a8d1615C1294fd71e9CFb3E4855A4F");
break;