From 184f8dfab54cdf859f9f82cdef18a02bb90f3a40 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Wed, 18 Dec 2024 08:57:53 +0700 Subject: [PATCH 01/12] feat: announcement banner on deposit/withdraw screens --- .github/markets/pr_template.md | 23 +++++++++----- config.schema.json | 55 ++++++++++++++++++++++++++++++++++ configs/devnet.json | 5 ++++ configs/mainnet.json | 9 ++++-- configs/testnet.json | 5 ++++ scripts/check_configs.ts | 55 ++++++++++++++++++++++++++++++++-- 6 files changed, 140 insertions(+), 12 deletions(-) diff --git a/.github/markets/pr_template.md b/.github/markets/pr_template.md index 6ecb128..158c99e 100644 --- a/.github/markets/pr_template.md +++ b/.github/markets/pr_template.md @@ -26,7 +26,7 @@ Each json file under the [configs](../../configs) folder correspond to their res |`wswth_contract` |`string` |false |wSWTH ERC-20 contract. | |`market_banners` |`MarketBanner[]` |true |market banner configs. | | `native_token_contracts_map` | `object` | false | Map of token denoms to their respective contract addresses on the native chain. | | -| `native_depositor_contracts_map` | `object` | false | Map of axelar connection ids to their respective native depositor contract addresses +| `native_depositor_contracts_map` | `object` | false | Map of axelar connection ids to their respective native depositor contract addresses |`market_promo` |`MarketPromo` |false |Map of Objects that contains market promo parameters for each market |If the `market_promo` property is omitted, no promo will be shown. The key of each entry is the ids of the market with existing promo. | |`spot_pool_config` |`SpotPoolConfig` |false |Object that contains the config parameters for the [Spot Pools](https://app.dem.exchange/pools/spot) page on Demex | @@ -94,19 +94,19 @@ Each json file under the [configs](../../configs) folder correspond to their res |---|---|---|---|---| |`perp_pool_id` |`string` |true |Perp pool id where the banner will be shown. |Perp pool id **MUST** match one of the existing perp pool ids from the PerpPool PoolInfoAll RPC call.

To view the values of PoolInfoAll RPC call, simply run `yarn get-perp-pool-ids [network]` on the command line. Sample for mainnet: `yarn get-perp-pool-ids mainnet` | |`show_from` |`string` |false |The date and time when the perp pool banner is scheduled to begin displaying. |If not provided, the banner will be shown immediately.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | -|`show_until` |`string` |false |The date and time when the perp pool banner is scheduled to stop displaying. |If not provided, the banner will continue to display indefinitely.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | -|`title` |`string` |true |The title shown on the perp pool banner. | +|`show_until` |`string` |false |The date and time when the perp pool banner is scheduled to stop displaying. |If not provided, the banner will continue to display indefinitely.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | +|`title` |`string` |true |The title shown on the perp pool banner. | |`removed_markets` |`string` |false |The message describing markets being removed, shown below the perp-pool banner title. | e.g. "BTCETH Perp will be removed on 6 Mar, 09:00AM UTC". If the field is omitted, no message describing markets being removed will be shown. | -|`added_markets` |`string` |false |The message describing markets being added, shown below the markets being removed (if any). | e.g. "ATOM Perp & SOL Perp will be added on 8 Mar, 12:00AM UTC". If the field is omitted, no message describing markets being added will be shown. | -|`subtext` |`string` |false |The subtext shown on the perp pool banner (below the removed and added market descriptions). | +|`added_markets` |`string` |false |The message describing markets being added, shown below the markets being removed (if any). | e.g. "ATOM Perp & SOL Perp will be added on 8 Mar, 12:00AM UTC". If the field is omitted, no message describing markets being added will be shown. | +|`subtext` |`string` |false |The subtext shown on the perp pool banner (below the removed and added market descriptions). | ## MarketBanner |Field |Type |Required |Description |Notes | |---|---|---|---|---| |`market_id` |`string` |true |Market id where the banner will be shown. |Market id **MUST** match one of the existing market ids from the Market MarketAll RPC call.

To view the values of MarketAll RPC call, simply run `yarn get-market-ids [network]` on the command line. Sample for mainnet: `yarn get-market-ids mainnet` | |`show_from` |`string` |false |The date and time when the market banner is scheduled to begin displaying. |If not provided, the banner will be shown immediately.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | -|`show_until` |`string` |false |The date and time when the market banner is scheduled to stop displaying. |If not provided, the banner will continue to display indefinitely.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | -|`content` |`string` |true |The content shown on the market banner. | +|`show_until` |`string` |false |The date and time when the market banner is scheduled to stop displaying. |If not provided, the banner will continue to display indefinitely.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | +|`content` |`string` |true |The content shown on the market banner. | |`hideable` |`boolean` |false |Indicates if user can hide the banner by clicking on the close button |If set to `false`, the close button will not be rendered on the banner, and user will not be able to dismiss the banner. | ## MarketPromo Data Structure @@ -119,4 +119,11 @@ Each json file under the [configs](../../configs) folder correspond to their res ## SpotPoolConfig Data Structure |Field |Type |Required |Description |Notes | |---|---|---|---|---| -|`show_apr_tooltip` |`boolean` |true |Indicates whether or not to show the Annual Percentage Returns (APR) tooltip on [Spot Pools](https://app.dem.exchange/pools/spot) page | \ No newline at end of file +|`show_apr_tooltip` |`boolean` |true |Indicates whether or not to show the Annual Percentage Returns (APR) tooltip on [Spot Pools](https://app.dem.exchange/pools/spot) page | + +## TransferBanner Data Structure +|Field |Type |Required |Description |Notes | +|---|---|---|---|---| +|`no_longer_supported_tokens` |`array` |false |List of tokens are no longer supported | +|`temporary_disabled_transfer_tokens` |`TransferBanner` |false |List of tokens for which deposits and withdrawals have been temporarily disabled | +|`temporary_disabled_bridges` |`TransferBanner` |false |List of bridges for which deposits and withdrawals have been temporarily disabled | diff --git a/config.schema.json b/config.schema.json index 683a082..0542a1a 100644 --- a/config.schema.json +++ b/config.schema.json @@ -515,6 +515,61 @@ "description": "Indicates whether or not to show APR tooltip on Spot Pools page" } } + }, + "transfer_banner": { + "type": "object", + "description": "Config parameters to show banner for deposit and withdraw screens", + "properties": { + "no_longer_supported_tokens": { + "type": "array", + "description": "List of tokens are no longer supported", + "items": { + "type": "string" + } + }, + "temporary_disabled_transfer_tokens": { + "type": "object", + "description": "List of tokens for which deposits and withdrawals have been temporarily disabled", + "patternProperties": { + ".*": { + "type": "object", + "required": [ + "start", + "end" + ], + "properties": { + "start": { + "$ref": "#/$defs/start" + }, + "end": { + "$ref": "#/$defs/end" + } + } + } + } + }, + "temporary_disabled_bridges": { + "type": "object", + "description": "List of bridges for which deposits and withdrawals have been temporarily disabled", + "patternProperties": { + ".*": { + "type": "object", + "required": [ + "start", + "end" + ], + "properties": { + "start": { + "$ref": "#/$defs/start" + }, + "end": { + "$ref": "#/$defs/end" + } + } + } + } + } + } } } } diff --git a/configs/devnet.json b/configs/devnet.json index 86d3aff..f199c0b 100644 --- a/configs/devnet.json +++ b/configs/devnet.json @@ -45,5 +45,10 @@ ], "spot_pool_config": { "show_apr_tooltip": false + }, + "transfer_banner": { + "no_longer_supported_tokens": [], + "temporary_disabled_transfer_tokens": {}, + "temporary_disabled_bridges": {} } } \ No newline at end of file diff --git a/configs/mainnet.json b/configs/mainnet.json index 94b3eaf..b871920 100644 --- a/configs/mainnet.json +++ b/configs/mainnet.json @@ -500,5 +500,10 @@ "label_denom": "brdg/a02afc2c1edf77cc023eefa25fc036c184612faf9365cda9c1daa3b1675ebf8f", "target_denom": "brdg/a02afc2c1edf77cc023eefa25fc036c184612faf9365cda9c1daa3b1675ebf8f" } - ] -} \ No newline at end of file + ], + "transfer_banner": { + "no_longer_supported_tokens": [], + "temporary_disabled_transfer_tokens": {}, + "temporary_disabled_bridges": {} + } +} diff --git a/configs/testnet.json b/configs/testnet.json index 2d3c393..732779f 100644 --- a/configs/testnet.json +++ b/configs/testnet.json @@ -59,5 +59,10 @@ }, "spot_pool_config": { "show_apr_tooltip": false + }, + "transfer_banner": { + "no_longer_supported_tokens": [], + "temporary_disabled_transfer_tokens": {}, + "temporary_disabled_bridges": {} } } diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index c13f7d3..be01174 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -34,6 +34,7 @@ interface ConfigJSON { market_banners?: MarketBanner[]; market_promo?: {[marketId: string]: MarketPromo}; spot_pool_config?: SpotPoolConfig; + transfer_banner?: TransferBanner; } interface InvalidEntry { @@ -132,6 +133,22 @@ interface SpotPoolConfig { show_apr_tooltip: boolean; } +interface TransferBanner { + no_longer_supported_tokens: [], + temporary_disabled_transfer_tokens: { + [denom: string]: { + start: string, + end: string + } + }, + temporary_disabled_bridges: { + [bridgeAddress: string]: { + start: string, + end: string + } + } +} + type OutcomeMap = { [key in CarbonSDK.Network]: boolean }; // true = success, false = failure const outcomeMap: OutcomeMap = { @@ -201,7 +218,7 @@ function joinEntriesIntoStr(entriesArr: string[]): string { : entriesArr[0]; } -// check list of markets to ensure that it does not have blacklisted markets +// check list of markets to ensure that it does not have blacklisted markets function checkBlacklistedMarkets(marketData: string[], blacklistedMarkets: string[]): InvalidEntry { let overlappingMarkets: string[] = []; marketData.forEach(market => { @@ -420,6 +437,35 @@ function isValidMarketPromo(marketPromo: {[marketId: string]: MarketPromo}, netw return true; } +function isValidTransferBanner(transferBanner: TransferBanner, network: CarbonSDK.Network): boolean { + const { temporary_disabled_transfer_tokens, temporary_disabled_bridges } = transferBanner; + if (Object.keys(temporary_disabled_transfer_tokens).length > 0) { + Object.keys(temporary_disabled_transfer_tokens).map((key) => { + const { start, end } = temporary_disabled_transfer_tokens[key]; + const startTime = new Date(start); + const endTime = new Date(end); + if (endTime < startTime) { + console.error(`ERROR: ${network}.json has invalid end time (${end}) is before start time (${start}) for token denom ${key}.`); + return false; + } + }); + } + + if (Object.keys(temporary_disabled_bridges).length > 0) { + Object.keys(temporary_disabled_bridges).map((key) => { + const { start, end } = temporary_disabled_bridges[key]; + const startTime = new Date(start); + const endTime = new Date(end); + if (endTime < startTime) { + console.error(`ERROR: ${network}.json has invalid end time (${end}) is before start time (${start}) for bridge address ${key}.`); + return false; + } + }); + } + + return true +} + async function main() { for (const net of myArgs) { let network: CarbonSDK.Network; @@ -752,7 +798,7 @@ async function main() { if(jsonData.market_promo && !isValidMarketPromo(jsonData.market_promo, network, marketIds)) { outcomeMap[network] = false; } - + // check for spot pool config if (jsonData.spot_pool_config) { const spotPoolConfig = jsonData.spot_pool_config @@ -775,6 +821,11 @@ async function main() { const isDemexTradingLeagueConfigValid = isValidDemexTradingLeagueConfig(jsonData.demex_trading_league_config, network, marketIds, jsonData.blacklisted_markets, perpPoolIds, tokenSymbols) if (!isDemexTradingLeagueConfigValid) outcomeMap[network] = false; } + + // transfer banner check + if (jsonData.transfer_banner && !isValidTransferBanner(jsonData.transfer_banner, network)) { + outcomeMap[network] = false; + } } } const outcomeArr = Object.values(outcomeMap); From 082cf635ca87706c2302e0ad155dd34e049df93b Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Wed, 18 Dec 2024 15:23:20 +0700 Subject: [PATCH 02/12] fix: update filed type --- .github/markets/pr_template.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/markets/pr_template.md b/.github/markets/pr_template.md index b7f8257..f31178a 100644 --- a/.github/markets/pr_template.md +++ b/.github/markets/pr_template.md @@ -131,6 +131,6 @@ Each json file under the [configs](../../configs) folder correspond to their res ## TransferBanner Data Structure |Field |Type |Required |Description |Notes | |---|---|---|---|---| -|`no_longer_supported_tokens` |`array` |false |List of tokens are no longer supported | -|`temporary_disabled_transfer_tokens` |`TransferBanner` |false |List of tokens for which deposits and withdrawals have been temporarily disabled | -|`temporary_disabled_bridges` |`TransferBanner` |false |List of bridges for which deposits and withdrawals have been temporarily disabled | +|`no_longer_supported_tokens` |`string[]` |false |List of tokens are no longer supported | +|`temporary_disabled_transfer_tokens` |`object` |false |List of tokens for which deposits and withdrawals have been temporarily disabled | +|`temporary_disabled_bridges` |`object` |false |List of bridges for which deposits and withdrawals have been temporarily disabled | From a2bdf9f2ea1212ec6630cc460935a5ed9a3640b5 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Wed, 18 Dec 2024 15:27:15 +0700 Subject: [PATCH 03/12] chore: update README.md --- README.md | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index ccb3137..6ec3429 100644 --- a/README.md +++ b/README.md @@ -90,7 +90,7 @@ More metadata will be added in the future if required by the Demex frontend. Ple "baseDenom": "denom_3", "chainRoutes": ["blockchain_5", "blockchain_6"], "denomOnCarbon": "carbon_denom_1" - }], + }], "demex_trading_league_config": { "promoMarkets": [ "promo_market_1", @@ -99,6 +99,21 @@ More metadata will be added in the future if required by the Demex frontend. Ple ], "currentPrizeSymbol": "market_symbol", "currentCompPerpPoolId": 1 + }, + "transfer_banner": { + "no_longer_supported_tokens": ["denom_1", "denom_2"], + "temporary_disabled_transfer_tokens": { + "denom_1": { + "start": "", + "end": "" + } + }, + "temporary_disabled_bridges": { + "bridge_address_1": { + "start": "", + "end": "" + } + } } } ``` From ab2d7ae405208ba8b5202ca529a52a69e8b164ec Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Fri, 20 Dec 2024 11:21:04 +0700 Subject: [PATCH 04/12] fix: addressed reviewer comments --- .github/markets/pr_template.md | 8 ++--- README.md | 6 ++-- config.schema.json | 66 +++++++++++++++------------------- configs/devnet.json | 8 ++--- configs/mainnet.json | 8 ++--- configs/testnet.json | 8 ++--- scripts/check_configs.ts | 63 +++++++++++++++++--------------- 7 files changed, 83 insertions(+), 84 deletions(-) diff --git a/.github/markets/pr_template.md b/.github/markets/pr_template.md index f31178a..4a043cf 100644 --- a/.github/markets/pr_template.md +++ b/.github/markets/pr_template.md @@ -30,7 +30,7 @@ Each json file under the [configs](../../configs) folder correspond to their res |`market_promo` |`MarketPromo` |false |Map of Objects that contains market promo parameters for each market |If the `market_promo` property is omitted, no promo will be shown. The key of each entry is the ids of the market with existing promo. | |`spot_pool_config` |`SpotPoolConfig` |false |Object that contains the config parameters for the [Spot Pools](https://app.dem.exchange/pools/spot) page on Demex | |`quick_select_tokens` |`QuickSelectToken[]` |true |List of quick select tokens for deposit and withdrawal forms. | - +|`disabled_transfer_banner_config` |`DisabledTransferBannerConfig` |false |Config parameters for displaying banner to inform users that transfers for the relevant tokens are disabled | ## TransferDisabledTokens Data Structure |Field |Type |Required |Description |Notes | |---|---|---|---|---| @@ -131,6 +131,6 @@ Each json file under the [configs](../../configs) folder correspond to their res ## TransferBanner Data Structure |Field |Type |Required |Description |Notes | |---|---|---|---|---| -|`no_longer_supported_tokens` |`string[]` |false |List of tokens are no longer supported | -|`temporary_disabled_transfer_tokens` |`object` |false |List of tokens for which deposits and withdrawals have been temporarily disabled | -|`temporary_disabled_bridges` |`object` |false |List of bridges for which deposits and withdrawals have been temporarily disabled | +|`unsupported_tokens` |`string[]` |false |List of tokens that are no longer supported | The token denoms listed here **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000) | +|`temp_disabled_transfer_tokens` |`object` |false |List of tokens for which deposits and withdrawals have been temporarily disabled | The token denoms listed in this object **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000) | +|`temp_disabled_bridges` |`object` |false |List of bridges for which deposits and withdrawals have been temporarily disabled | Blockchain network listed here **MUST** match the valid chainName of the bridges listed under BridgeAll RPC call.

To view the values of BridgeAll RPC call, simply run yarn get-bridges [network]on the command line. Sample for mainnet:yarn get-bridges mainnet`` | diff --git a/README.md b/README.md index 6ec3429..f741db7 100644 --- a/README.md +++ b/README.md @@ -101,14 +101,14 @@ More metadata will be added in the future if required by the Demex frontend. Ple "currentCompPerpPoolId": 1 }, "transfer_banner": { - "no_longer_supported_tokens": ["denom_1", "denom_2"], - "temporary_disabled_transfer_tokens": { + "unsupported_tokens": ["denom_1", "denom_2"], + "temp_disabled_transfer_tokens": { "denom_1": { "start": "", "end": "" } }, - "temporary_disabled_bridges": { + "temp_disabled_bridges": { "bridge_address_1": { "start": "", "end": "" diff --git a/config.schema.json b/config.schema.json index 4ce71a9..7ceb6e6 100644 --- a/config.schema.json +++ b/config.schema.json @@ -377,12 +377,12 @@ }, "start": { "type": "string", - "description": "The start time of perp pool promo", + "description": "The start time of the relevant program (in timestamp format)", "pattern": "^\\d{4}(-\\d\\d(-\\d\\d(T\\d\\d:\\d\\d(:\\d\\d)?(\\.\\d+)?(([+-]\\d\\d:\\d\\d)|Z)?)?)?)?$" }, "end": { "type": "string", - "description": "The end time of perp pool promo", + "description": "The end time of the relevant program (in timestamp format)", "pattern": "^\\d{4}(-\\d\\d(-\\d\\d(T\\d\\d:\\d\\d(:\\d\\d)?(\\.\\d+)?(([+-]\\d\\d:\\d\\d)|Z)?)?)?)?$" }, "perpPoolDepositBoost": { @@ -516,27 +516,45 @@ } } }, - "transfer_banner": { + "quick_select_token": { + "type": "object", + "description": "Token denom for quick select in transfer form", + "required": ["label_denom", "target_denom"], + "properties": { + "label_denom": { + "type": "string", + "description": "Token denom to show on UI" + }, + "target_denom": { + "type": "string", + "description": "Token denom to use in transfer" + } + } + }, + "quick_select_tokens": { + "type": "array", + "description": "List of tokens for quick select in transfer form", + "items": { + "$ref": "#/$defs/quick_select_token" + } + }, + "disabled_transfer_banner_config": { "type": "object", - "description": "Config parameters to show banner for deposit and withdraw screens", + "description": "Config parameters for displaying banner to inform users that transfers for the relevant tokens are disabled", "properties": { - "no_longer_supported_tokens": { + "unsupported_tokens": { "type": "array", "description": "List of tokens are no longer supported", "items": { "type": "string" } }, - "temporary_disabled_transfer_tokens": { + "temp_disabled_transfer_tokens": { "type": "object", "description": "List of tokens for which deposits and withdrawals have been temporarily disabled", "patternProperties": { ".*": { "type": "object", - "required": [ - "start", - "end" - ], "properties": { "start": { "$ref": "#/$defs/start" @@ -548,16 +566,12 @@ } } }, - "temporary_disabled_bridges": { + "temp_disabled_bridges": { "type": "object", "description": "List of bridges for which deposits and withdrawals have been temporarily disabled", "patternProperties": { ".*": { "type": "object", - "required": [ - "start", - "end" - ], "properties": { "start": { "$ref": "#/$defs/start" @@ -570,28 +584,6 @@ } } } - }, - "quick_select_token": { - "type": "object", - "description": "Token denom for quick select in transfer form", - "required": ["label_denom", "target_denom"], - "properties": { - "label_denom": { - "type": "string", - "description": "Token denom to show on UI" - }, - "target_denom": { - "type": "string", - "description": "Token denom to use in transfer" - } - } - }, - "quick_select_tokens": { - "type": "array", - "description": "List of tokens for quick select in transfer form", - "items": { - "$ref": "#/$defs/quick_select_token" - } } } } diff --git a/configs/devnet.json b/configs/devnet.json index a923f6b..a8733ac 100644 --- a/configs/devnet.json +++ b/configs/devnet.json @@ -64,9 +64,9 @@ "target_denom" : "dai" } ], - "transfer_banner": { - "no_longer_supported_tokens": [], - "temporary_disabled_transfer_tokens": {}, - "temporary_disabled_bridges": {} + "disabled_transfer_banner_config": { + "unsupported_tokens": [], + "temp_disabled_transfer_tokens": {}, + "temp_disabled_bridges": {} } } \ No newline at end of file diff --git a/configs/mainnet.json b/configs/mainnet.json index b871920..916398c 100644 --- a/configs/mainnet.json +++ b/configs/mainnet.json @@ -501,9 +501,9 @@ "target_denom": "brdg/a02afc2c1edf77cc023eefa25fc036c184612faf9365cda9c1daa3b1675ebf8f" } ], - "transfer_banner": { - "no_longer_supported_tokens": [], - "temporary_disabled_transfer_tokens": {}, - "temporary_disabled_bridges": {} + "disabled_transfer_banner_config": { + "unsupported_tokens": [], + "temp_disabled_transfer_tokens": {}, + "temp_disabled_bridges": {} } } diff --git a/configs/testnet.json b/configs/testnet.json index 3d65668..9f0b35c 100644 --- a/configs/testnet.json +++ b/configs/testnet.json @@ -78,9 +78,9 @@ "target_denom" : "dai" } ], - "transfer_banner": { - "no_longer_supported_tokens": [], - "temporary_disabled_transfer_tokens": {}, - "temporary_disabled_bridges": {} + "disabled_transfer_banner_config": { + "unsupported_tokens": [], + "temp_disabled_transfer_tokens": {}, + "temp_disabled_bridges": {} } } diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index a2fbde1..9f2993f 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -34,7 +34,7 @@ interface ConfigJSON { market_banners?: MarketBanner[]; market_promo?: {[marketId: string]: MarketPromo}; spot_pool_config?: SpotPoolConfig; - transfer_banner?: TransferBanner; + disabled_transfer_banner_config?: DisabledTransferBannerConfig; quick_select_deposit_options?: QuickSelectToken[]; } @@ -134,18 +134,18 @@ interface SpotPoolConfig { show_apr_tooltip: boolean; } -interface TransferBanner { - no_longer_supported_tokens: [], - temporary_disabled_transfer_tokens: { +interface DisabledTransferBannerConfig { + unsupported_tokens?: [], + temp_disabled_transfer_tokens?: { [denom: string]: { - start: string, - end: string + start?: string, + end?: string } }, - temporary_disabled_bridges: { + temp_disabled_bridges?: { [bridgeAddress: string]: { - start: string, - end: string + start?: string, + end?: string } } } @@ -443,28 +443,35 @@ function isValidMarketPromo(marketPromo: {[marketId: string]: MarketPromo}, netw return true; } -function isValidTransferBanner(transferBanner: TransferBanner, network: CarbonSDK.Network): boolean { - const { temporary_disabled_transfer_tokens, temporary_disabled_bridges } = transferBanner; - if (Object.keys(temporary_disabled_transfer_tokens).length > 0) { - Object.keys(temporary_disabled_transfer_tokens).map((key) => { - const { start, end } = temporary_disabled_transfer_tokens[key]; - const startTime = new Date(start); - const endTime = new Date(end); - if (endTime < startTime) { - console.error(`ERROR: ${network}.json has invalid end time (${end}) is before start time (${start}) for token denom ${key}.`); - return false; +function isValidTransferBanner(transferBanner: DisabledTransferBannerConfig, network: CarbonSDK.Network): boolean { + const { temp_disabled_transfer_tokens = {}, temp_disabled_bridges = {} } = transferBanner; + const disabledTokenKeys = Object.keys(temp_disabled_transfer_tokens) + + if (disabledTokenKeys.length > 0) { + disabledTokenKeys.map((key) => { + const { start, end } = temp_disabled_transfer_tokens[key]; + if (end && start) { + const startTime = new Date(start); + const endTime = new Date(end); + if (endTime < startTime) { + console.error(`ERROR: ${network}.json has an invalid end time (${end}) as it is before start time (${start}) for token denom ${key}.`); + return false; + } } }); } - if (Object.keys(temporary_disabled_bridges).length > 0) { - Object.keys(temporary_disabled_bridges).map((key) => { - const { start, end } = temporary_disabled_bridges[key]; - const startTime = new Date(start); - const endTime = new Date(end); - if (endTime < startTime) { - console.error(`ERROR: ${network}.json has invalid end time (${end}) is before start time (${start}) for bridge address ${key}.`); - return false; + const disabledBridgeKeys = Object.keys(temp_disabled_bridges) + if (disabledBridgeKeys.length > 0) { + disabledBridgeKeys.map((key) => { + const { start, end } = temp_disabled_bridges[key]; + if (start && end) { + const startTime = new Date(start); + const endTime = new Date(end); + if (endTime < startTime) { + console.error(`ERROR: ${network}.json has an invalid end time (${end}) as it is before start time (${start}) for bridge ${key}.`); + return false; + } } }); } @@ -855,7 +862,7 @@ async function main() { } // transfer banner check - if (jsonData.transfer_banner && !isValidTransferBanner(jsonData.transfer_banner, network)) { + if (jsonData.disabled_transfer_banner_config && !isValidTransferBanner(jsonData.disabled_transfer_banner_config, network)) { outcomeMap[network] = false; } From 3762bb7985fd0cb5ab2041658098a8c1989c6638 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Thu, 26 Dec 2024 15:32:54 +0700 Subject: [PATCH 05/12] chore: add config key validation --- configs/devnet.json | 7 +----- configs/mainnet.json | 7 +----- configs/testnet.json | 7 +----- scripts/check_configs.ts | 46 +++++++++++++++++++++++++++++++++++----- 4 files changed, 44 insertions(+), 23 deletions(-) diff --git a/configs/devnet.json b/configs/devnet.json index e771cf7..6e151c1 100644 --- a/configs/devnet.json +++ b/configs/devnet.json @@ -70,10 +70,5 @@ "label_denom": "dai", "target_denom" : "dai" } - ], - "disabled_transfer_banner_config": { - "unsupported_tokens": [], - "temp_disabled_transfer_tokens": {}, - "temp_disabled_bridges": {} - } + ] } \ No newline at end of file diff --git a/configs/mainnet.json b/configs/mainnet.json index ee6196a..862465d 100644 --- a/configs/mainnet.json +++ b/configs/mainnet.json @@ -507,10 +507,5 @@ "label_denom": "brdg/a02afc2c1edf77cc023eefa25fc036c184612faf9365cda9c1daa3b1675ebf8f", "target_denom": "brdg/a02afc2c1edf77cc023eefa25fc036c184612faf9365cda9c1daa3b1675ebf8f" } - ], - "disabled_transfer_banner_config": { - "unsupported_tokens": [], - "temp_disabled_transfer_tokens": {}, - "temp_disabled_bridges": {} - } + ] } diff --git a/configs/testnet.json b/configs/testnet.json index 2d4af77..cc830b8 100644 --- a/configs/testnet.json +++ b/configs/testnet.json @@ -84,10 +84,5 @@ "label_denom": "dai", "target_denom" : "dai" } - ], - "disabled_transfer_banner_config": { - "unsupported_tokens": [], - "temp_disabled_transfer_tokens": {}, - "temp_disabled_bridges": {} - } + ] } diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index 5a77d26..e54df1c 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -1,5 +1,6 @@ -import { BlockchainUtils, CarbonSDK } from "carbon-js-sdk"; +import { CarbonSDK } from "carbon-js-sdk"; import { PageRequest } from "carbon-js-sdk/lib/codec/cosmos/base/query/v1beta1/pagination"; +import { BridgeMap } from "carbon-js-sdk/lib/util/blockchain"; import * as fs from "fs"; import Long from "long"; @@ -466,11 +467,29 @@ function isValidMarketPromo(marketPromo: {[marketId: string]: MarketPromo}, netw return true; } -function isValidTransferBanner(transferBanner: DisabledTransferBannerConfig, network: CarbonSDK.Network): boolean { - const { temp_disabled_transfer_tokens = {}, temp_disabled_bridges = {} } = transferBanner; - const disabledTokenKeys = Object.keys(temp_disabled_transfer_tokens) +function isValidDisabledTransferBannerConfig(transferBanner: DisabledTransferBannerConfig, denoms: string[], bridges: string[], network: CarbonSDK.Network): boolean { + const { unsupported_tokens = [], temp_disabled_transfer_tokens = {}, temp_disabled_bridges = {} } = transferBanner; + + if (unsupported_tokens.length > 0) { + const validUnsupportedTokensOutcome = checkValidEntries(unsupported_tokens, denoms); + if (validUnsupportedTokensOutcome.status && isErrorOutcome(validUnsupportedTokensOutcome)) { + const invalidUnsupportedTokensStr = joinEntriesIntoStr(validUnsupportedTokensOutcome.entry!); + console.error(`[ERROR] disabled_transfer_banner_config.unsupported_tokens of ${network}.json has the following invalid token denoms: ${invalidUnsupportedTokensStr}. Please make sure to input only valid token denoms.`); + return false + } + } + + const disabledTokenKeys = Object.keys(temp_disabled_transfer_tokens) if (disabledTokenKeys.length > 0) { + const validDisabledTknsOutcome = checkValidEntries(disabledTokenKeys, denoms); + + if (validDisabledTknsOutcome.status && isErrorOutcome(validDisabledTknsOutcome)) { + const invalidDissabedTokensStr = joinEntriesIntoStr(validDisabledTknsOutcome.entry!); + console.error(`[ERROR] disabled_transfer_banner_config.temp_disabled_transfer_tokens of ${network}.json has the following invalid token denoms: ${invalidDissabedTokensStr}. Please make sure to input only valid token denoms.`); + return false + } + disabledTokenKeys.map((key) => { const { start, end } = temp_disabled_transfer_tokens[key]; if (end && start) { @@ -486,6 +505,13 @@ function isValidTransferBanner(transferBanner: DisabledTransferBannerConfig, net const disabledBridgeKeys = Object.keys(temp_disabled_bridges) if (disabledBridgeKeys.length > 0) { + const validDisableBridgesOutcome = checkValidEntries(disabledBridgeKeys, bridges); + if (validDisableBridgesOutcome.status && isErrorOutcome(validDisableBridgesOutcome)) { + const invalidDissabedBridgesStr = joinEntriesIntoStr(validDisableBridgesOutcome.entry!); + console.error(`[ERROR] disabled_transfer_banner_config.temp_disabled_bridges of ${network}.json has the following invalid bridge addreses: ${invalidDissabedBridgesStr}. Please make sure to input only valid bridge addresses.`); + return false + } + disabledBridgeKeys.map((key) => { const { start, end } = temp_disabled_bridges[key]; if (start && end) { @@ -649,6 +675,16 @@ async function main() { outcomeMap[network] = false; } + // query all bridges + const bridgesMap: BridgeMap | undefined = sdk?.token?.bridges + let bridgesArr: string[] = [] + + if (bridgesMap && bridgesMap.ibc.length && bridgesMap.polynetwork.length) { + const polynetworkBridges = bridgesMap.polynetwork.map((bridge) => bridge.bridgeAddresses).flat() + const ibcBridges = bridgesMap.ibc.map((bridge) => bridge.bridgeAddresses).flat() + bridgesArr = polynetworkBridges.concat(ibcBridges) + } + // transfer disabled tokens object check const isTransferDisabledTokensValid = isValidTransferDisabledTokens(jsonData.transfer_disabled_tokens, tokens, network); if (!isTransferDisabledTokensValid) outcomeMap[network] = false; @@ -889,7 +925,7 @@ async function main() { } // transfer banner check - if (jsonData.disabled_transfer_banner_config && !isValidTransferBanner(jsonData.disabled_transfer_banner_config, network)) { + if (jsonData.disabled_transfer_banner_config && !isValidDisabledTransferBannerConfig(jsonData.disabled_transfer_banner_config, tokens, bridgesArr, network)) { outcomeMap[network] = false; } From 8a0fd9f361ea033fc6e5f6395c30da85dd5f34a2 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Thu, 26 Dec 2024 15:42:49 +0700 Subject: [PATCH 06/12] chore: update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index f741db7..42b0af7 100644 --- a/README.md +++ b/README.md @@ -100,7 +100,7 @@ More metadata will be added in the future if required by the Demex frontend. Ple "currentPrizeSymbol": "market_symbol", "currentCompPerpPoolId": 1 }, - "transfer_banner": { + "disabled_transfer_banner_config": { "unsupported_tokens": ["denom_1", "denom_2"], "temp_disabled_transfer_tokens": { "denom_1": { From 201b82662d0995e485235a338de005eb62844016 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Mon, 30 Dec 2024 22:23:53 +0700 Subject: [PATCH 07/12] fix: addressed reviewer comments --- .github/markets/pr_template.md | 6 +++--- README.md | 4 +++- scripts/check_configs.ts | 34 +++++++++++++++++++++++----------- 3 files changed, 29 insertions(+), 15 deletions(-) diff --git a/.github/markets/pr_template.md b/.github/markets/pr_template.md index 68922ba..6b7edbe 100644 --- a/.github/markets/pr_template.md +++ b/.github/markets/pr_template.md @@ -127,8 +127,8 @@ Each json file under the [configs](../../configs) folder correspond to their res |Field |Type |Required |Description |Notes | |---|---|---|---|---| |`show_from` |`string` |false |The date and time when the market banner is scheduled to begin displaying. |If not provided, the banner will be shown immediately.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | -|`show_until` |`string` |false |The date and time when the market banner is scheduled to stop displaying. |If not provided, the banner will continue to display indefinitely.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | -|`content` |`string` |true |The content shown on the market banner. | +|`show_until` |`string` |false |The date and time when the market banner is scheduled to stop displaying. |If not provided, the banner will continue to display indefinitely.

This field **MUST** follow the valid ISO 8601 format
e.g. *2024-01-23T09:00+00:00* (23 Jan 2024, 9am UTC) | +|`content` |`string` |true |The content shown on the market banner. | |`hideable` |`boolean` |false |Indicates if user can hide the banner by clicking on the close button |If set to `false`, the close button will not be rendered on the banner, and user will not be able to dismiss the banner. | |`show_only_on` |`string[]` |true |Default is empty list, then banner will be shown on all pages |If list has specified path(s), the banner will be shown on these/that path(s) only, sample: `['/rewards', '/nitron']` | @@ -138,7 +138,7 @@ Each json file under the [configs](../../configs) folder correspond to their res |`label_denom` |`string` |true |The default token will be show on UI deposit/withdrawal forms | |`target_denom` |`string` |true |The default token will be use to transfer in deposit/withdrawal | -## TransferBanner Data Structure +## DisabledTransferBannerConfig Data Structure |Field |Type |Required |Description |Notes | |---|---|---|---|---| |`unsupported_tokens` |`string[]` |false |List of tokens that are no longer supported | The token denoms listed here **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000) | diff --git a/README.md b/README.md index 42b0af7..3c47d50 100644 --- a/README.md +++ b/README.md @@ -112,7 +112,9 @@ More metadata will be added in the future if required by the Demex frontend. Ple "bridge_address_1": { "start": "", "end": "" - } + }, + "src_channel": {}, // for ibcBridges + "connectionId": {} // for axelarBridges } } } diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index e54df1c..0a7a84f 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -485,18 +485,18 @@ function isValidDisabledTransferBannerConfig(transferBanner: DisabledTransferBan const validDisabledTknsOutcome = checkValidEntries(disabledTokenKeys, denoms); if (validDisabledTknsOutcome.status && isErrorOutcome(validDisabledTknsOutcome)) { - const invalidDissabedTokensStr = joinEntriesIntoStr(validDisabledTknsOutcome.entry!); - console.error(`[ERROR] disabled_transfer_banner_config.temp_disabled_transfer_tokens of ${network}.json has the following invalid token denoms: ${invalidDissabedTokensStr}. Please make sure to input only valid token denoms.`); + const invalidDisabledTokensStr = joinEntriesIntoStr(validDisabledTknsOutcome.entry!); + console.error(`[ERROR] disabled_transfer_banner_config.temp_disabled_transfer_tokens of ${network}.json has the following invalid token denoms: ${invalidDisabledTokensStr}. Please make sure to input only valid token denoms.`); return false } - disabledTokenKeys.map((key) => { + disabledTokenKeys.forEach((key) => { const { start, end } = temp_disabled_transfer_tokens[key]; if (end && start) { const startTime = new Date(start); const endTime = new Date(end); if (endTime < startTime) { - console.error(`ERROR: ${network}.json has an invalid end time (${end}) as it is before start time (${start}) for token denom ${key}.`); + console.error(`ERROR: disabled_transfer_banner_config.temp_disabled_transfer_tokens on ${network}.json has an invalid end time (${end}) for denom ${key} as it is before start time (${start}).`); return false; } } @@ -505,20 +505,20 @@ function isValidDisabledTransferBannerConfig(transferBanner: DisabledTransferBan const disabledBridgeKeys = Object.keys(temp_disabled_bridges) if (disabledBridgeKeys.length > 0) { - const validDisableBridgesOutcome = checkValidEntries(disabledBridgeKeys, bridges); - if (validDisableBridgesOutcome.status && isErrorOutcome(validDisableBridgesOutcome)) { - const invalidDissabedBridgesStr = joinEntriesIntoStr(validDisableBridgesOutcome.entry!); - console.error(`[ERROR] disabled_transfer_banner_config.temp_disabled_bridges of ${network}.json has the following invalid bridge addreses: ${invalidDissabedBridgesStr}. Please make sure to input only valid bridge addresses.`); + const validDisabledBridgesOutcome = checkValidEntries(disabledBridgeKeys, bridges); + if (validDisabledBridgesOutcome.status && isErrorOutcome(validDisabledBridgesOutcome)) { + const invalidDisabledBridgesStr = joinEntriesIntoStr(validDisabledBridgesOutcome.entry!); + console.error(`[ERROR] disabled_transfer_banner_config.temp_disabled_bridges of ${network}.json has the following invalid bridge addresses: ${invalidDisabledBridgesStr}. Please make sure to input only valid bridge addresses.`); return false } - disabledBridgeKeys.map((key) => { + disabledBridgeKeys.forEach((key) => { const { start, end } = temp_disabled_bridges[key]; if (start && end) { const startTime = new Date(start); const endTime = new Date(end); if (endTime < startTime) { - console.error(`ERROR: ${network}.json has an invalid end time (${end}) as it is before start time (${start}) for bridge ${key}.`); + console.error(`ERROR: disabled_transfer_banner_config.temp_disabled_bridges on ${network}.json has an invalid end time (${end}) for bridge ${key} as it is before start time (${start}).`); return false; } } @@ -681,10 +681,22 @@ async function main() { if (bridgesMap && bridgesMap.ibc.length && bridgesMap.polynetwork.length) { const polynetworkBridges = bridgesMap.polynetwork.map((bridge) => bridge.bridgeAddresses).flat() - const ibcBridges = bridgesMap.ibc.map((bridge) => bridge.bridgeAddresses).flat() + const ibcBridges = bridgesMap.ibc.map((bridge) => bridge.channels.src_channel) bridgesArr = polynetworkBridges.concat(ibcBridges) } + const res = await sdk.query.bridge.ConnectionAll({ + bridgeId: new Long(0), + pagination: PageRequest.fromPartial({ + limit: new Long(100000), + }), + }) + const axelarBridges: string[] = res.connections.map(bridge => bridge.connectionId) + + if (axelarBridges.length > 0) { + bridgesArr = bridgesArr.concat(axelarBridges) + } + // transfer disabled tokens object check const isTransferDisabledTokensValid = isValidTransferDisabledTokens(jsonData.transfer_disabled_tokens, tokens, network); if (!isTransferDisabledTokensValid) outcomeMap[network] = false; From 5b34c9aa43e5a62856660da48054492a27cea1a3 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Mon, 30 Dec 2024 23:16:50 +0700 Subject: [PATCH 08/12] chore: refactor code --- scripts/check_configs.ts | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index 0a7a84f..76de5dc 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -680,8 +680,15 @@ async function main() { let bridgesArr: string[] = [] if (bridgesMap && bridgesMap.ibc.length && bridgesMap.polynetwork.length) { - const polynetworkBridges = bridgesMap.polynetwork.map((bridge) => bridge.bridgeAddresses).flat() - const ibcBridges = bridgesMap.ibc.map((bridge) => bridge.channels.src_channel) + const { polynetwork, ibc } = bridgesMap; + const polynetworkBridges = polynetwork.reduce((acc: string[], bridge) => { + if (bridge.enabled) acc.push(...bridge.bridgeAddresses) + return acc + }, []) + const ibcBridges = ibc.reduce((acc: string[], bridge) => { + if (bridge.enabled) acc.push(bridge.channels.src_channel) + return acc + }, []); bridgesArr = polynetworkBridges.concat(ibcBridges) } @@ -691,7 +698,10 @@ async function main() { limit: new Long(100000), }), }) - const axelarBridges: string[] = res.connections.map(bridge => bridge.connectionId) + const axelarBridges: string[] = res.connections.reduce((acc: string[], bridge) => { + if (bridge.isEnabled) acc.push(bridge.connectionId); + return acc; + }, []); if (axelarBridges.length > 0) { bridgesArr = bridgesArr.concat(axelarBridges) From 4d5f0f52dc65a78d0ed993e05229e1d20ae26f7c Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Tue, 31 Dec 2024 10:13:50 +0700 Subject: [PATCH 09/12] chore: remove transfer_disabled_tokens configure --- .github/markets/pr_template.md | 1 - README.md | 5 ----- config.schema.json | 22 -------------------- configs/devnet.json | 4 ---- configs/mainnet.json | 26 ----------------------- configs/testnet.json | 4 ---- scripts/check_configs.ts | 38 ---------------------------------- 7 files changed, 100 deletions(-) diff --git a/.github/markets/pr_template.md b/.github/markets/pr_template.md index 6b7edbe..0189a29 100644 --- a/.github/markets/pr_template.md +++ b/.github/markets/pr_template.md @@ -10,7 +10,6 @@ Each json file under the [configs](../../configs) folder correspond to their res |`blacklisted_markets` |`string[]` |true |The array of market names that are blacklisted. A market can be blacklisted for a number of reasons, such as it being invalid/duplicate/wrongly-added/etc. |The market names listed here **MUST** match the market names listed under the Carbon [Markets API](https://api.carbon.network/carbon/market/v1/markets?pagination.limit=10000). The market names listed here **CANNOT** be under the `prelaunch_markets` field at the same time. | |`blacklisted_pools` |`string[]` |true |The array of pool ids that are blacklisted. A pool can be blacklisted for a number of reasons, such as it being invalid/duplicate/wrongly-added/etc. |The pool ids listed here **MUST** match the pool ids listed under the Carbon [Liquidity Pool API](https://api.carbon.network/carbon/liquiditypool/v1/pools?pagination.limit=10000). | |`blacklisted_tokens` |`string[]` |true |The array of token denoms that are blacklisted. A token can be blacklisted for a number of reasons, such as it being invalid/deprecated/etc. |The token denoms listed here **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000). | -| `transfer_disabled_tokens` |`TransferDisabledTokens` |true |Object that contains tokens for which deposits and withdrawals are temporarily disabled | | | `token_name_override_map` |`object` |true |Object that contains token denoms and their respective token name overrides. This is used if we need to override the full token name of the tokens listed here. |The token denoms listed here **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000). | |`transfer_options` |`object` |true |A collection of blockchain networks along with their associated priority numbers, used to establish their order in the transfer options list for deposit and withdrawal forms. |Blockchain network listed here **MUST** match the valid chainName of the bridges listed under BridgeAll RPC call.

To view the values of BridgeAll RPC call, simply run `yarn get-bridges [network]` on the command line. Sample for mainnet: `yarn get-bridges mainnet`| |`network_fees` |`object` |true |List of token denoms along with their associated priority numbers, used to establish their default order in the network fees preference list. |Token denoms listed here **MUST** match the valid denoms listed under MinGasPriceAll RPC call.

To view the values of MinGasPriceAll RPC call, simply run `yarn get-min-gas-prices [network]` on the command line. Sample for mainnet: `yarn get-min-gas-prices mainnet`| diff --git a/README.md b/README.md index 3c47d50..e00971a 100644 --- a/README.md +++ b/README.md @@ -49,11 +49,6 @@ More metadata will be added in the future if required by the Demex frontend. Ple "blacklisted_token_2", "blacklisted_token_3" ], - "transfer_disabled_tokens": [ - "transfer_disabled_token_1", - "transfer_disabled_token_2", - "transfer_disabled_token_3" - ], "token_name_override_map": { "token_1": "token_name_override_1", "token_2": "token_name_override_2" diff --git a/config.schema.json b/config.schema.json index 769cecf..6488c9d 100644 --- a/config.schema.json +++ b/config.schema.json @@ -8,7 +8,6 @@ "blacklisted_markets", "blacklisted_pools", "blacklisted_tokens", - "transfer_disabled_tokens", "token_name_override_map", "transfer_options", "network_fees", @@ -53,27 +52,6 @@ "$ref": "#/$defs/blacklisted_token" } }, - "transfer_disabled_tokens": { - "type": "object", - "description": "Object containing tokens for which deposits and withdrawals have been temporarily disabled", - "required": ["deposit", "withdraw"], - "properties": { - "deposit": { - "type": "array", - "description": "List of tokens for which deposits have been temporarily disabled", - "items": { - "type": "string" - } - }, - "withdraw": { - "type": "array", - "description": "List of tokens for which withdrawals have been temporarily disabled", - "items": { - "type": "string" - } - } - } - }, "token_name_override_map": { "type": "object", "description": "Object that contains token denoms and their respective token name overrides.", diff --git a/configs/devnet.json b/configs/devnet.json index 6e151c1..6e8711a 100644 --- a/configs/devnet.json +++ b/configs/devnet.json @@ -8,10 +8,6 @@ ], "blacklisted_pools": [], "blacklisted_tokens": [], - "transfer_disabled_tokens": { - "deposit": [], - "withdraw": [] - }, "token_name_override_map": {}, "transfer_options": {}, "network_fees": { diff --git a/configs/mainnet.json b/configs/mainnet.json index 450437f..151f8a8 100644 --- a/configs/mainnet.json +++ b/configs/mainnet.json @@ -17,32 +17,6 @@ "usdc.1.6.e70e14", "bit.1.2.9d68c4" ], - "transfer_disabled_tokens": { - "deposit": [ - "nex.1.17.59c1ba", - "gmx.1.19.70275d", - "wbnb.1.6.ad598c", - "blur.1.2.0c0069", - "brdg/0b02ac3efc9df2e80d00f141133c180cdaee0122f92d3e2e310f704e82425a18", - "brdg/1768794901f8a19c2ec795a5402653cef6cbfe6b3ec6398d39fc37de963cb667", - "brdg/a8bbd91ae3dda9de2e50926a0d93be4d0d5cea34f3080014e5c0c0db6eaf61a4", - "bnb.1.6.773edb", - "zbnb.1.18.c406be", - "usdc.1.17.851a3a" - ], - "withdraw": [ - "nex.1.17.59c1ba", - "gmx.1.19.70275d", - "wbnb.1.6.ad598c", - "blur.1.2.0c0069", - "brdg/0b02ac3efc9df2e80d00f141133c180cdaee0122f92d3e2e310f704e82425a18", - "brdg/1768794901f8a19c2ec795a5402653cef6cbfe6b3ec6398d39fc37de963cb667", - "brdg/a8bbd91ae3dda9de2e50926a0d93be4d0d5cea34f3080014e5c0c0db6eaf61a4", - "bnb.1.6.773edb", - "zbnb.1.18.c406be", - "usdc.1.17.851a3a" - ] - }, "token_name_override_map": { "brdg/1299d2e94c483e72f64100088886b8a5b7c13595047e53e032c9938d07a98c20": "Ether (Arbitrum)", "brdg/e3877e2c8ed05e404e04417747e2f430285c11dc839663b943b39ff7cbb56377": "Ether (Ethereum)" diff --git a/configs/testnet.json b/configs/testnet.json index 3d76c22..5f212a7 100644 --- a/configs/testnet.json +++ b/configs/testnet.json @@ -10,10 +10,6 @@ ], "blacklisted_pools": [], "blacklisted_tokens": [], - "transfer_disabled_tokens": { - "deposit": [], - "withdraw": [] - }, "token_name_override_map": {}, "transfer_options": {}, "network_fees": { diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index 76de5dc..d2050e4 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -13,7 +13,6 @@ interface ConfigJSON { blacklisted_markets: string[]; blacklisted_pools: string[]; blacklisted_tokens: string[]; - transfer_disabled_tokens: TransferDisabledTokensObj; token_name_override_map: TokenNameOverrideMap; transfer_options: { [chainKey: string]: number; @@ -250,39 +249,6 @@ function checkBlacklistedMarkets(marketData: string[], blacklistedMarkets: strin }; } -function isValidTransferDisabledTokens(transferDisabledTokens: TransferDisabledTokensObj, denoms: string[], network: CarbonSDK.Network): boolean { - const dupDepositTknsOutcome = checkDuplicateEntries(transferDisabledTokens.deposit); - const dupWithdrawTknsOutcome = checkDuplicateEntries(transferDisabledTokens.withdraw); - - if (dupDepositTknsOutcome.status || dupWithdrawTknsOutcome.status) { - if (isErrorOutcome(dupDepositTknsOutcome)) { - const duplicateDepositTokensStr = joinEntriesIntoStr(dupDepositTknsOutcome.entry!); - console.error(`[ERROR] transfer_disabled_tokens.deposit of ${network}.json has the following duplicate token denoms: ${duplicateDepositTokensStr}. Please make sure to input each denom only once.`); - } - if (isErrorOutcome(dupWithdrawTknsOutcome)) { - const duplicateWithdrawTokensStr = joinEntriesIntoStr(dupWithdrawTknsOutcome.entry!); - console.error(`[ERROR] transfer_disabled_tokens.withdraw of ${network}.json has the following duplicate token denoms: ${duplicateWithdrawTokensStr}. Please make sure to input each denom only once.`); - } - return false; - } - - const validDepositTknsOutcome = checkValidEntries(transferDisabledTokens.deposit, denoms); - const validWithdrawTknsOutcome = checkValidEntries(transferDisabledTokens.withdraw, denoms); - if (validDepositTknsOutcome.status || dupWithdrawTknsOutcome.status) { - if (isErrorOutcome(validDepositTknsOutcome)) { - const invalidDepositTokensStr = joinEntriesIntoStr(validDepositTknsOutcome.entry!); - console.error(`[ERROR] transfer_disabled_tokens.deposit of ${network}.json has the following invalid token denoms: ${invalidDepositTokensStr}. Please make sure to input only valid token denoms.`); - } - if (isErrorOutcome(validWithdrawTknsOutcome)) { - const invalidWithdrawTokensStr = joinEntriesIntoStr(validWithdrawTknsOutcome.entry!); - console.error(`[ERROR] transfer_disabled_tokens.withdraw of ${network}.json has the following invalid token denoms: ${invalidWithdrawTokensStr}. Please make sure to input only valid token denoms.`); - } - return false; - } - - return true; -} - function isValidTokenNameOverrideMap(tokenNameOverrideMap: TokenNameOverrideMap, denoms: string[], network: CarbonSDK.Network): boolean { const denomKeysArr = Object.keys(tokenNameOverrideMap); const invalidDenomsOutcome = checkValidEntries(denomKeysArr, denoms); @@ -707,10 +673,6 @@ async function main() { bridgesArr = bridgesArr.concat(axelarBridges) } - // transfer disabled tokens object check - const isTransferDisabledTokensValid = isValidTransferDisabledTokens(jsonData.transfer_disabled_tokens, tokens, network); - if (!isTransferDisabledTokensValid) outcomeMap[network] = false; - // token_name_override_map check const isTokenNameOverrideMapValid = isValidTokenNameOverrideMap(jsonData.token_name_override_map, tokens, network); if (!isTokenNameOverrideMapValid) outcomeMap[network] = false; From 836cfc181188a493ddb9b08a97f8d87dedf3b108 Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Tue, 31 Dec 2024 11:13:16 +0700 Subject: [PATCH 10/12] fix: addressed reviewer comments --- scripts/check_configs.ts | 43 +++++++++++++--------------------------- 1 file changed, 14 insertions(+), 29 deletions(-) diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index d2050e4..8556a10 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -62,11 +62,6 @@ interface PerpPoolBanner { subtext?: string; } -interface TransferDisabledTokensObj { - deposit: string[]; - withdraw: string[]; -} - type TokenNameOverrideMap = { [denom: string]: string; } @@ -645,33 +640,23 @@ async function main() { const bridgesMap: BridgeMap | undefined = sdk?.token?.bridges let bridgesArr: string[] = [] - if (bridgesMap && bridgesMap.ibc.length && bridgesMap.polynetwork.length) { - const { polynetwork, ibc } = bridgesMap; - const polynetworkBridges = polynetwork.reduce((acc: string[], bridge) => { - if (bridge.enabled) acc.push(...bridge.bridgeAddresses) - return acc - }, []) - const ibcBridges = ibc.reduce((acc: string[], bridge) => { - if (bridge.enabled) acc.push(bridge.channels.src_channel) - return acc - }, []); - bridgesArr = polynetworkBridges.concat(ibcBridges) - } + const { polynetwork = [], ibc = [], axelar = [] } = bridgesMap ?? {} + const polynetworkBridges = polynetwork.reduce((acc: string[], bridge) => { + if (bridge.enabled) acc.push(...bridge.bridgeAddresses) + return acc + }, []) - const res = await sdk.query.bridge.ConnectionAll({ - bridgeId: new Long(0), - pagination: PageRequest.fromPartial({ - limit: new Long(100000), - }), - }) - const axelarBridges: string[] = res.connections.reduce((acc: string[], bridge) => { - if (bridge.isEnabled) acc.push(bridge.connectionId); - return acc; + const axelarBridges = axelar.reduce((acc: string[], bridge) => { + if (bridge.enabled) acc.push(...bridge.bridgeAddresses) + return acc }, []); - if (axelarBridges.length > 0) { - bridgesArr = bridgesArr.concat(axelarBridges) - } + const ibcBridges = ibc.reduce((acc: string[], bridge) => { + if (bridge.enabled) acc.push(bridge.channels.src_channel) + return acc + }, []); + + bridgesArr = polynetworkBridges.concat(ibcBridges).concat(axelarBridges) // token_name_override_map check const isTokenNameOverrideMapValid = isValidTokenNameOverrideMap(jsonData.token_name_override_map, tokens, network); From ed8a5c9482f99123262dc281e38f5c57466ed9cf Mon Sep 17 00:00:00 2001 From: kylehoang92 Date: Tue, 31 Dec 2024 14:48:21 +0700 Subject: [PATCH 11/12] fix: addressed reviewer comments --- .github/markets/pr_template.md | 6 ------ scripts/check_configs.ts | 2 +- 2 files changed, 1 insertion(+), 7 deletions(-) diff --git a/.github/markets/pr_template.md b/.github/markets/pr_template.md index 0189a29..a625be0 100644 --- a/.github/markets/pr_template.md +++ b/.github/markets/pr_template.md @@ -30,12 +30,6 @@ Each json file under the [configs](../../configs) folder correspond to their res |`spot_pool_config` |`SpotPoolConfig` |false |Object that contains the config parameters for the [Spot Pools](https://app.dem.exchange/pools/spot) page on Demex | |`quick_select_tokens` |`QuickSelectToken[]` |true |List of quick select tokens for deposit and withdrawal forms. | |`disabled_transfer_banner_config` |`DisabledTransferBannerConfig` |false |Config parameters for displaying banner to inform users that transfers for the relevant tokens are disabled | -## TransferDisabledTokens Data Structure -|Field |Type |Required |Description |Notes | -|---|---|---|---|---| -|`deposit` |`string[]` |true |List of tokens for which deposits are temporarily disabled |The token denoms listed here **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000). | -|`withdraw` |`string[]` |true |List of tokens for which withdrawals are temporarily disabled |The token denoms listed here **MUST** match the token denoms listed under the Carbon [Tokens API](https://api.carbon.network/carbon/coin/v1/tokens?pagination.limit=10000). | -|`announcement_banner` |`AnnouncementBanner` |false |Custom announcement banner through all or only on specificed paths | ## Maintenance Data Structure |Field |Type |Required |Description |Notes | diff --git a/scripts/check_configs.ts b/scripts/check_configs.ts index 8556a10..81168cf 100644 --- a/scripts/check_configs.ts +++ b/scripts/check_configs.ts @@ -647,7 +647,7 @@ async function main() { }, []) const axelarBridges = axelar.reduce((acc: string[], bridge) => { - if (bridge.enabled) acc.push(...bridge.bridgeAddresses) + if (bridge.enabled) acc.push(bridge.bridgeAddress) return acc }, []); From 7ddd0d00d1984cfd848f8a33281c59fc80a33d00 Mon Sep 17 00:00:00 2001 From: Thong Yuan Yu Sarah Date: Thu, 2 Jan 2025 18:23:10 +0800 Subject: [PATCH 12/12] Fix get all bridges script --- scripts/get_all_bridges.ts | 32 ++++++++++++++++++++++++++++---- 1 file changed, 28 insertions(+), 4 deletions(-) diff --git a/scripts/get_all_bridges.ts b/scripts/get_all_bridges.ts index 96b2e4e..d7b69b1 100644 --- a/scripts/get_all_bridges.ts +++ b/scripts/get_all_bridges.ts @@ -1,5 +1,6 @@ -import { CarbonSDK } from "carbon-js-sdk"; +import { Carbon, CarbonSDK } from "carbon-js-sdk"; import { PageRequest } from "carbon-js-sdk/lib/codec/cosmos/base/query/v1beta1/pagination"; +import { BRIDGE_IDS } from "carbon-js-sdk/lib/util/blockchain"; import Long from "long"; const myArgs = process.argv.slice(2); @@ -22,10 +23,33 @@ const myArgs = process.argv.slice(2); } const sdk = await CarbonSDK.instance({ network }); - const bridges = await sdk.query.coin.BridgeAll({ + const legacyBridges = await sdk.query.coin.BridgeAll({ pagination: PageRequest.fromPartial({ limit: new Long(10000), }), - }) - console.log(bridges) + }); + const axelarBridges = await sdk.query.bridge.ConnectionAll( + Carbon.Bridge.QueryAllConnectionsRequest.fromPartial({ + pagination: PageRequest.fromPartial({ + limit: new Long(10000), + }), + }) + ); + + console.log("Chain Name | Bridge Name | Bridge Address(es)") + + legacyBridges.bridges.forEach((bridge: Carbon.Coin.Bridge) => { + if (!bridge.enabled) return; + + let bridgeAddressStr = JSON.stringify(bridge.bridgeAddresses); + if (bridge.bridgeId.eq(BRIDGE_IDS.ibc)) { + bridgeAddressStr = `channel-${bridge.chainId.subtract(1).toString(10)}`; + } + console.log(`${bridge.chainName} | ${bridge.bridgeName} | ${bridgeAddressStr}`); + }); + + axelarBridges.connections.forEach((bridge: Carbon.Bridge.Connection) => { + if (!bridge.isEnabled) return; + console.log(`${bridge.chainDisplayName} | Axelar | ${bridge.connectionId}`); + }); })().catch(console.error).finally(() => process.exit(0));