From 988cfd4cd40d0f3fc72b6c080ec19a0acf1b55b4 Mon Sep 17 00:00:00 2001 From: Hitansh Madan Date: Thu, 5 Oct 2023 19:50:51 +0530 Subject: [PATCH] feat(statics): add Berachain & Haqq Ticket: WIN-458 --- modules/bitgo/test/v2/unit/keychains.ts | 2 + modules/statics/src/base.ts | 6 +++ modules/statics/src/coins.ts | 40 +++++++++++++++++++ modules/statics/src/networks.ts | 28 +++++++++++++ .../unit/fixtures/expectedColdFeatures.ts | 4 ++ 5 files changed, 80 insertions(+) diff --git a/modules/bitgo/test/v2/unit/keychains.ts b/modules/bitgo/test/v2/unit/keychains.ts index 012699a36c..a014bb2da4 100644 --- a/modules/bitgo/test/v2/unit/keychains.ts +++ b/modules/bitgo/test/v2/unit/keychains.ts @@ -61,6 +61,8 @@ describe('V2 Keychains', function () { n.asset !== UnderlyingAsset.ETHW && n.asset !== UnderlyingAsset.KAVA && n.asset !== UnderlyingAsset.CORE && + n.asset !== UnderlyingAsset.BERA && + n.asset !== UnderlyingAsset.ISLM && coinFamilyValues.includes(n.name) ); diff --git a/modules/statics/src/base.ts b/modules/statics/src/base.ts index cbeb060072..f96312c32c 100644 --- a/modules/statics/src/base.ts +++ b/modules/statics/src/base.ts @@ -27,6 +27,7 @@ export enum CoinFamily { AVAXP = 'avaxp', BCH = 'bch', BCHA = 'bcha', + BERA = 'bera', BLD = 'bld', // Agoric BSC = 'bsc', BSV = 'bsv', @@ -47,6 +48,7 @@ export enum CoinFamily { HASH = 'hash', // Provenance HBAR = 'hbar', INJECTIVE = 'injective', + ISLM = 'islm', KAVA = 'kava', LTC = 'ltc', POLYGON = 'polygon', @@ -248,6 +250,7 @@ export enum UnderlyingAsset { AXLV2 = 'axlv2', BCH = 'bch', BCHA = 'bcha', + BERA = 'bera', BLD = 'bld', // Agoric BSC = 'bsc', BSV = 'bsv', @@ -272,6 +275,7 @@ export enum UnderlyingAsset { HASH = 'hash', // Provenance HBAR = 'hbar', // Hedera main coin INJECTIVE = 'injective', + ISLM = 'islm', KAVA = 'kava', LTC = 'ltc', NEAR = 'near', @@ -1376,6 +1380,8 @@ export enum BaseUnit { KAVA = 'ukava', CORE = 'ucore', TESTCORE = 'utestcore', // Coreum testnet uses different name for native coin + BERA = 'abera', + ISLM = 'aISLM', } export interface BaseCoinConstructorOptions { diff --git a/modules/statics/src/coins.ts b/modules/statics/src/coins.ts index c0c74bbcf5..c413e4e075 100644 --- a/modules/statics/src/coins.ts +++ b/modules/statics/src/coins.ts @@ -979,6 +979,46 @@ export const coins = CoinMap.fromCoins([ BaseUnit.TESTCORE, COSMOS_SIDECHAIN_FEATURES ), + account( + 'd367b226-5b38-4aa4-918c-df1859647d6d', + 'bera', + 'Bera', + Networks.main.bera, + 0, + UnderlyingAsset.BERA, + BaseUnit.BERA, + COSMOS_SIDECHAIN_FEATURES + ), + account( + '6d262f34-b21b-4b35-9a5d-94103ff1f168', + 'tbera', + 'Testnet Bera', + Networks.test.bera, + 0, + UnderlyingAsset.BERA, + BaseUnit.BERA, + COSMOS_SIDECHAIN_FEATURES + ), + account( + 'b473d5f0-1590-4edf-bc9f-813aff515a23', + 'islm', + 'Islamic Coin', + Networks.main.islm, + 18, + UnderlyingAsset.ISLM, + BaseUnit.ISLM, + COSMOS_SIDECHAIN_FEATURES.filter((f) => f !== CoinFeature.SHA256_WITH_ECDSA_TSS) + ), + account( + '02eced2c-cf1d-4660-832c-858685ae7107', + 'tislm', + 'Testnet Islamic Coin', + Networks.test.islm, + 18, + UnderlyingAsset.ISLM, + BaseUnit.ISLM, + COSMOS_SIDECHAIN_FEATURES.filter((f) => f !== CoinFeature.SHA256_WITH_ECDSA_TSS) + ), account( 'e48baabf-5cc9-4011-b67e-6f6425753df2', 'near', diff --git a/modules/statics/src/networks.ts b/modules/statics/src/networks.ts index 91f65333a4..a0019553b6 100644 --- a/modules/statics/src/networks.ts +++ b/modules/statics/src/networks.ts @@ -693,6 +693,30 @@ class CoreTestnet extends Testnet implements AccountNetwork { explorerUrl = 'https://explorer.testnet-1.coreum.dev/coreum/transactions/'; } +class Bera extends Mainnet implements AccountNetwork { + name = 'Berachain'; + family = CoinFamily.BERA; + explorerUrl = undefined; +} + +class BeraTestnet extends Testnet implements AccountNetwork { + name = 'BerachainTestnet'; + family = CoinFamily.BERA; + explorerUrl = undefined; +} + +class Islm extends Mainnet implements AccountNetwork { + name = 'Haqq'; + family = CoinFamily.ISLM; + explorerUrl = 'https://ping.pub/haqq/tx/'; +} + +class IslmTestnet extends Testnet implements AccountNetwork { + name = 'HaqqTestnet'; + family = CoinFamily.ISLM; + explorerUrl = 'https://testnet.ping.pub/haqq/tx/'; +} + class Stx extends Mainnet implements StacksNetwork { name = 'Stx'; family = CoinFamily.STX; @@ -840,6 +864,7 @@ export const Networks = { bitcoinCash: Object.freeze(new BitcoinCash()), bitcoinGold: Object.freeze(new BitcoinGold()), bitcoinSV: Object.freeze(new BitcoinSV()), + bera: Object.freeze(new Bera()), bld: Object.freeze(new Bld()), bsc: Object.freeze(new BinanceSmartChain()), casper: Object.freeze(new Casper()), @@ -858,6 +883,7 @@ export const Networks = { hash: Object.freeze(new Hash()), hedera: Object.freeze(new Hedera()), injective: Object.freeze(new Injective()), + islm: Object.freeze(new Islm()), kava: Object.freeze(new Kava()), litecoin: Object.freeze(new Litecoin()), polygon: Object.freeze(new Polygon()), @@ -889,6 +915,7 @@ export const Networks = { bitcoinCash: Object.freeze(new BitcoinCashTestnet()), bitcoinGold: Object.freeze(new BitcoinGoldTestnet()), bitcoinSV: Object.freeze(new BitcoinSVTestnet()), + bera: Object.freeze(new BeraTestnet()), bld: Object.freeze(new BldTestnet()), bsc: Object.freeze(new BinanceSmartChainTestnet()), casper: Object.freeze(new CasperTestnet()), @@ -904,6 +931,7 @@ export const Networks = { hash: Object.freeze(new HashTestnet()), hedera: Object.freeze(new HederaTestnet()), injective: Object.freeze(new InjectiveTestnet()), + islm: Object.freeze(new IslmTestnet()), kava: Object.freeze(new KavaTestnet()), kovan: Object.freeze(new Kovan()), goerli: Object.freeze(new Goerli()), diff --git a/modules/statics/test/unit/fixtures/expectedColdFeatures.ts b/modules/statics/test/unit/fixtures/expectedColdFeatures.ts index 67c6587786..335aedee77 100644 --- a/modules/statics/test/unit/fixtures/expectedColdFeatures.ts +++ b/modules/statics/test/unit/fixtures/expectedColdFeatures.ts @@ -50,11 +50,13 @@ export const expectedColdFeatures = { justTSS: [ 'ada', 'atom', + 'bera', 'bld', 'bsc', 'core', 'dot', 'hash', + 'islm', 'injective', 'kava', 'near', @@ -65,12 +67,14 @@ export const expectedColdFeatures = { 'zeta', 'tada', 'tatom', + 'tbera', 'tbld', 'tbsc', 'tcore', 'tdot', 'thash', 'tia', + 'tislm', 'tinjective', 'tkava', 'tnear',