From ecde46d09133a46253c4a878be2cc69afd858352 Mon Sep 17 00:00:00 2001 From: Michael Feng Date: Thu, 26 Jan 2023 20:56:23 -0800 Subject: [PATCH] (feat) initial commit from hummingbot repo --- .dockerignore | 6 + .eslintignore | 2 + .eslintrc.js | 24 + .gitignore | 9 + .prettierignore | 5 + .prettierrc | 5 + Changelog.md | 130 + Dockerfile | 40 + LICENSE | 201 - README.md | 128 + bin/docker-start.sh | 9 + docs/swagger/amm-liquidity-routes.yml | 101 + docs/swagger/amm-routes.yml | 221 + docs/swagger/connectors-routes.yml | 10 + docs/swagger/cosmos-routes.yml | 57 + docs/swagger/definitions.yml | 1580 + docs/swagger/evm-routes.yml | 104 + docs/swagger/main-routes.yml | 37 + docs/swagger/near-routes.yml | 63 + docs/swagger/network-routes.yml | 82 + docs/swagger/swagger.yml | 40 + docs/swagger/wallet-routes.yml | 46 + docs/testing.md | 196 + hooks/README.md | 5 + hooks/build | 7 + jest.config.js | 39 + manual-tests/curl.sh | 205 + manual-tests/requests/add_avalanche_key.json | 5 + manual-tests/requests/add_bsc_key.json | 5 + manual-tests/requests/add_cronos_key.json | 5 + manual-tests/requests/add_ethereum_key.json | 5 + manual-tests/requests/add_near_key.json | 6 + manual-tests/requests/avalanche_approve.json | 7 + manual-tests/requests/avalanche_nonce.json | 5 + .../avalanche_traderjoe_allowances.json | 7 + .../requests/avalanche_traderjoe_trade.json | 11 + manual-tests/requests/bsc_approve.json | 7 + manual-tests/requests/bsc_balances.json | 6 + manual-tests/requests/bsc_nonce.json | 5 + .../requests/bsc_pancakeswap_trade.json | 10 + .../requests/bsc_sushiswap_trade.json | 10 + manual-tests/requests/config_update.json | 4 + manual-tests/requests/cronos_approve.json | 7 + manual-tests/requests/cronos_balances.json | 6 + manual-tests/requests/cronos_mmf_trade.json | 10 + manual-tests/requests/cronos_nonce.json | 5 + manual-tests/requests/cronos_vvs_trade.json | 10 + manual-tests/requests/eth_allowances.json | 7 + manual-tests/requests/eth_approve.json | 7 + .../requests/eth_approve_with_fees.json | 7 + .../requests/eth_approve_with_nonce.json | 7 + manual-tests/requests/eth_balances.json | 4 + manual-tests/requests/eth_nonce.json | 5 + manual-tests/requests/eth_perp_approve.json | 7 + manual-tests/requests/eth_poll.json | 3 + .../requests/eth_remove_allowance.json | 6 + .../requests/eth_uniswap_add_liquidity.json | 13 + .../requests/eth_uniswap_pool_price.json | 10 + .../requests/eth_uniswap_position.json | 7 + manual-tests/requests/eth_uniswap_price.json | 6 + manual-tests/requests/eth_uniswap_trade.json | 10 + .../requests/eth_uniswap_trade_with_fees.json | 9 + manual-tests/requests/harmony_dfk_trade.json | 10 + .../harmony_testnet_defira_trade.json | 10 + .../mmf_cronos_mainnet_allowance.json | 7 + .../requests/near_mainnet_ref_trade.json | 10 + .../requests/near_network_balances.json | 6 + manual-tests/requests/near_post_poll.json | 5 + manual-tests/requests/network_balances.json | 6 + manual-tests/requests/network_poll.json | 5 + manual-tests/requests/perp_position.json | 8 + manual-tests/requests/perp_prices.json | 7 + manual-tests/requests/perp_trade_open.json | 10 + .../requests/price_bsc_pancakeswap.json | 9 + manual-tests/requests/price_defira.json | 9 + manual-tests/requests/price_dfk.json | 9 + manual-tests/requests/price_mad_meerkat.json | 9 + manual-tests/requests/price_pangolin.json | 9 + manual-tests/requests/price_ref.json | 9 + manual-tests/requests/price_traderjoe.json | 9 + manual-tests/requests/price_uniswap.json | 9 + manual-tests/requests/price_vvs.json | 9 + .../requests/remove_avalanche_key.json | 4 + manual-tests/requests/remove_bsc_key.json | 4 + manual-tests/requests/remove_cronos_key.json | 4 + .../requests/remove_ethereum_key.json | 4 + manual-tests/requests/remove_near_key.json | 4 + manual-tests/requests/status_request.json | 4 + nodemon.json | 11 + package.json | 141 + setup/generate_conf.sh | 22 + src/@types/buffer-layout.d.ts | 8 + src/@types/cycle.d.ts | 3 + src/amm/amm.controllers.ts | 252 + src/amm/amm.requests.ts | 238 + src/amm/amm.routes.ts | 284 + src/amm/amm.validators.ts | 339 + src/app.ts | 175 + src/chains/avalanche/avalanche.ts | 128 + src/chains/avalanche/avalanche.validators.ts | 42 + .../avalanche/avalanche_tokens_fuji.json | 37 + src/chains/avalanche/avanlanche_tokens.json | 1573 + .../bep20_tokens_mainnet.json | 990 + .../bep20_tokens_testnet.json | 53 + .../binance-smart-chain.ts | 116 + src/chains/cosmos/cosmos-middlewares.ts | 15 + src/chains/cosmos/cosmos.config.ts | 39 + src/chains/cosmos/cosmos.controllers.ts | 87 + src/chains/cosmos/cosmos.requests.ts | 37 + src/chains/cosmos/cosmos.routes.ts | 74 + src/chains/cosmos/cosmos.ts | 87 + src/chains/cosmos/cosmos.validators.ts | 36 + src/chains/cronos/cronos.ts | 114 + src/chains/cronos/mainnet_beta.json | 720 + src/chains/cronos/testnet.json | 48 + src/chains/ethereum/arbitrum_one_tokens.json | 2798 ++ .../ethereum/arbitrum_rinkeby_tokens.json | 152 + .../ethereum/balancer/balancer.config.ts | 19 + src/chains/ethereum/erc20_tokens_goerli.json | 148 + src/chains/ethereum/erc20_tokens_kovan.json | 83 + src/chains/ethereum/erc20_tokens_mainnet.json | 37707 ++++++++++++++++ src/chains/ethereum/erc20_tokens_ropsten.json | 17 + src/chains/ethereum/ethereum.config.ts | 60 + src/chains/ethereum/ethereum.controllers.ts | 449 + src/chains/ethereum/ethereum.requests.ts | 117 + src/chains/ethereum/ethereum.ts | 195 + src/chains/ethereum/ethereum.validators.ts | 133 + src/chains/ethereum/optimism_tokens.json | 3152 ++ src/chains/harmony/harmony.config.ts | 57 + src/chains/harmony/harmony.ts | 169 + src/chains/harmony/harmony.validators.ts | 107 + src/chains/harmony/harmony_tokens_defira.json | 93 + .../harmony_tokens_defira_testnet.json | 29 + .../harmony/harmony_tokens_sushiswap.json | 1050 + .../harmony_tokens_sushiswap_testnet.json | 70 + src/chains/near/near.abi.json | 4 + src/chains/near/near.base.ts | 344 + src/chains/near/near.config.ts | 47 + src/chains/near/near.controllers.ts | 169 + src/chains/near/near.requests.ts | 54 + src/chains/near/near.routes.ts | 81 + src/chains/near/near.ts | 102 + src/chains/near/near.validators.ts | 64 + src/chains/near/near_testnet_tokens.json | 1494 + src/chains/near/near_tokens.json | 2018 + src/chains/polygon/polygon.ts | 90 + src/chains/polygon/polygon.validators.ts | 42 + .../polygon/polygon_tokens_mainnet.json | 25880 +++++++++++ src/chains/polygon/polygon_tokens_mumbai.json | 23 + src/connectors/connectors.routes.ts | 102 + ...cronos-base-uniswapish-connector.config.ts | 38 + .../cronos-base-uniswapish-connector.ts | 386 + .../defikingdoms/defikingdoms.config.ts | 31 + src/connectors/defikingdoms/defikingdoms.ts | 291 + .../defikingdoms/defikingdoms_router_abi.json | 1625 + src/connectors/defira/defira.config.ts | 36 + src/connectors/defira/defira.ts | 322 + .../defira/defira_v2_router_abi.json | 985 + src/connectors/mad_meerkat/abi.json | 1080 + .../mad_meerkat/mad_meerkat.config.ts | 10 + src/connectors/mad_meerkat/mad_meerkat.ts | 136 + src/connectors/openocean/openocean.config.ts | 29 + src/connectors/openocean/openocean.ts | 412 + .../pancakeswap/pancakeswap.config.ts | 31 + src/connectors/pancakeswap/pancakeswap.ts | 316 + .../pancakeswap/pancakeswap_router_abi.json | 975 + src/connectors/pangolin/IPangolinRouter.json | 962 + src/connectors/pangolin/pangolin.config.ts | 31 + src/connectors/pangolin/pangolin.ts | 295 + src/connectors/perp/perp.config.ts | 18 + src/connectors/perp/perp.controllers.ts | 229 + src/connectors/perp/perp.ts | 293 + src/connectors/quickswap/quickswap.config.ts | 29 + src/connectors/quickswap/quickswap.ts | 294 + src/connectors/ref/ref.config.ts | 35 + src/connectors/ref/ref.controllers.ts | 315 + src/connectors/ref/ref.helper.ts | 131 + src/connectors/ref/ref.ts | 316 + src/connectors/sushiswap/sushiswap.config.ts | 39 + src/connectors/sushiswap/sushiswap.ts | 300 + .../sushiswap/sushiswap_router.json | 1924 + src/connectors/traderjoe/IJoeRouter02.json | 437 + src/connectors/traderjoe/traderjoe.config.ts | 31 + src/connectors/traderjoe/traderjoe.ts | 295 + src/connectors/uniswap/uniswap.config.ts | 58 + src/connectors/uniswap/uniswap.controllers.ts | 630 + src/connectors/uniswap/uniswap.lp.helper.ts | 466 + .../uniswap/uniswap.lp.interfaces.ts | 52 + src/connectors/uniswap/uniswap.lp.ts | 257 + src/connectors/uniswap/uniswap.ts | 323 + .../uniswap/uniswap_v2_router_abi.json | 1924 + src/connectors/vvs/abi.json | 973 + src/connectors/vvs/vvs.config.ts | 7 + src/connectors/vvs/vvs.ts | 136 + src/evm/evm.requests.ts | 58 + src/evm/evm.routes.ts | 119 + src/https.ts | 41 + src/index.ts | 3 + src/network/network.controllers.ts | 166 + src/network/network.requests.ts | 57 + src/network/network.routes.ts | 110 + src/paths.ts | 17 + src/services/base.ts | 114 + src/services/common-interfaces.ts | 680 + .../config-manager-cert-passphrase.ts | 27 + src/services/config-manager-types.ts | 4 + src/services/config-manager-v2.ts | 452 + src/services/config-migration/migrations.ts | 17 + src/services/config/config.requests.ts | 4 + src/services/config/config.routes.ts | 48 + src/services/config/config.validators.ts | 83 + src/services/connection-manager.ts | 126 + src/services/cosmos-base.ts | 367 + src/services/error-handler.ts | 207 + src/services/ethereum-base.ts | 393 + src/services/ethereum.abi.json | 600 + src/services/evm.nonce.ts | 546 + src/services/evm.tx-storage.ts | 70 + src/services/local-storage.ts | 87 + src/services/logger.ts | 92 + src/services/refcounting-closeable.ts | 179 + .../schema/configuration-root-schema.json | 28 + src/services/schema/cosmos-schema.json | 30 + .../schema/cronos-connector-schema.json | 25 + src/services/schema/database-schema.json | 10 + src/services/schema/defikingdoms-schema.json | 25 + src/services/schema/defira-schema.json | 31 + .../schema/ethereum-gas-station-schema.json | 12 + src/services/schema/ethereum-schema.json | 34 + src/services/schema/harmony-schema.json | 36 + src/services/schema/logging-schema.json | 10 + src/services/schema/openocean-schema.json | 30 + src/services/schema/pangolin-schema.json | 25 + src/services/schema/perp-schema.json | 10 + src/services/schema/quickswap-schema.json | 30 + src/services/schema/ref-schema.json | 25 + src/services/schema/server-schema.json | 13 + src/services/schema/ssl-schema.json | 11 + src/services/schema/sushiswap-schema.json | 36 + src/services/schema/telemetry-schema.json | 8 + src/services/schema/traderjoe-schema.json | 30 + src/services/schema/uniswap-schema.json | 36 + src/services/swagger-manager.ts | 59 + src/services/telemetry-transport.ts | 104 + src/services/validators.ts | 182 + src/services/wallet/wallet.controllers.ts | 176 + src/services/wallet/wallet.requests.ts | 20 + src/services/wallet/wallet.routes.ts | 57 + src/services/wallet/wallet.validators.ts | 131 + src/templates/avalanche.yml | 19 + src/templates/binance-smart-chain.yml | 19 + src/templates/cosmos.yml | 13 + src/templates/cronos.yml | 19 + src/templates/database.yml | 2 + src/templates/defikingdoms.yml | 14 + src/templates/defira.yml | 18 + src/templates/ethereum.yml | 37 + src/templates/harmony.yml | 20 + src/templates/logging.yml | 6 + src/templates/mad_meerkat.yml | 14 + src/templates/near.yml | 19 + src/templates/openocean.yml | 14 + src/templates/pancakeswap.yml | 16 + src/templates/pangolin.yml | 16 + src/templates/perp.yml | 6 + src/templates/polygon.yml | 17 + src/templates/quickswap.yml | 16 + src/templates/ref.yml | 16 + src/templates/root.yml | 109 + src/templates/server.yml | 10 + src/templates/ssl.yml | 8 + src/templates/sushiswap.yml | 26 + src/templates/telemetry.yml | 2 + src/templates/traderjoe.yml | 16 + src/templates/uniswap.yml | 37 + src/templates/vvs.yml | 14 + startup.sh | 7 + test-scripts/README.md | 6 + test-scripts/cosmos.test.ts | 73 + test-scripts/ethereum.test.base.ts | 133 + test-scripts/harmony.test.ts | 176 + test-scripts/test.base.ts | 72 + test-scripts/uniswap.v2.test.ts | 124 + test/amm/amm.validators.test.ts | 192 + test/app.test.ts | 37 + .../chains/avalanche/avalanche.routes.test.ts | 379 + test/chains/avalanche/avalanche.test.ts | 56 + .../avalanche/avalanche.validators.test.ts | 42 + .../openocean/openocean.routes.test.ts | 705 + .../avalanche/openocean/openocean.test.ts | 83 + .../pangolin/pangolin.routes.test.ts | 561 + .../avalanche/pangolin/pangolin.test.ts | 148 + .../avalanche/traderjoe/traderjoe.test.ts | 148 + .../binance-smart-chain.routes.test.ts | 376 + .../pancakeswap/pancakeswap.routes.test.ts | 561 + .../pancakeswap/pancakeswap.test.ts | 141 + test/chains/cosmos/cosmos.routes.test.ts | 127 + test/chains/cosmos/cosmos.validators.test.ts | 51 + .../cosmos/fixtures/getTransaction.json | 1 + test/chains/cronos/cronos.routes.test.ts | 371 + .../mad_meerkat/mad-meerkat.routes.test.ts | 560 + .../cronos/mad_meerkat/mad-meerkat.test.ts | 146 + test/chains/cronos/vvs/vvs.routes.test.ts | 560 + test/chains/cronos/vvs/vvs.test.ts | 146 + .../ethereum/ethereum.controllers.test.ts | 292 + test/chains/ethereum/ethereum.routes.test.ts | 634 + .../ethereum/ethereum.validators.test.ts | 196 + test/chains/ethereum/evm.nonce.test.ts | 331 + .../transaction-out-of-gas-receipt.json | 18 + .../fixtures/transaction-out-of-gas.json | 21 + .../transaction-succesful-receipt.json | 55 + .../fixtures/transaction-succesful.json | 31 + test/chains/ethereum/perp/perp.routes.test.ts | 356 + test/chains/ethereum/perp/perp.test.ts | 187 + .../sushiswap/sushiswap.routes.test.ts | 669 + .../ethereum/sushiswap/sushiswap.test.ts | 135 + .../uniswap/uniswap.lp.routes.test.ts | 442 + .../ethereum/uniswap/uniswap.lp.test.ts | 285 + .../ethereum/uniswap/uniswap.routes.test.ts | 678 + test/chains/ethereum/uniswap/uniswap.test.ts | 156 + .../defikingdoms/defikingdoms.routes.test.ts | 669 + .../harmony/defikingdoms/defikingdoms.test.ts | 151 + .../harmony/defira/defira.routes.test.ts | 669 + test/chains/harmony/defira/defira.test.ts | 182 + .../harmony/harmony.controllers.test.ts | 276 + test/chains/harmony/harmony.routes.test.ts | 389 + test/chains/harmony/harmony.test.ts | 62 + .../chains/harmony/harmony.validators.test.ts | 203 + test/chains/near/fixtures/getTokenList.json | 47 + test/chains/near/fixtures/getTransaction.json | 86 + test/chains/near/near.controllers.test.ts | 124 + test/chains/near/near.routes.test.ts | 196 + test/chains/near/near.validators.test.ts | 159 + test/chains/near/ref/ref.route.test.ts | 708 + test/chains/near/ref/ref.test.ts | 339 + test/chains/polygon/polygon.test.ts | 44 + .../chains/polygon/polygon.validators.test.ts | 57 + .../polygon/quickswap/quickswap.route.test.ts | 561 + .../polygon/quickswap/quickswap.test.ts | 146 + test/config.util.ts | 47 + test/connectors/connectors.routes.test.ts | 13 + test/evm.nonce.mock.ts | 22 + test/network/network.routes.test.ts | 347 + .../EthereumV2.postman_collection.json | 105 + ...penocean-GatewayV2.postman_collection.json | 57 + .../Uniswap-GatewayV2.postman_collection.json | 72 + .../GatewayV2.postman_environment.json | 24 + test/services/base.test.ts | 70 + .../config-manager-cert-passphrase.test.ts | 39 + test/services/config-manager-v2.test.ts | 238 + test/services/config-validators.test.ts | 142 + .../data/config-manager-v2/test1/defira.yaml | 15 + .../data/config-manager-v2/test1/ethereum.yml | 15 + .../test1/invalid-defira.yml | 18 + .../test1/invalid-root-2.yml | 8 + .../test1/invalid-root-3.yml | 8 + .../test1/invalid-root-4.yml | 8 + .../test1/invalid-root-defira.yml | 5 + .../config-manager-v2/test1/invalid-root.yml | 11 + .../config-manager-v2/test1/invalid-ssl.yml | 4 + .../data/config-manager-v2/test1/root.yml | 61 + .../data/config-manager-v2/test1/root2.yml | 14 + .../data/config-manager-v2/test1/ssl.yml | 3 + .../config-manager-v2/test1/telemetry.yml | 2 + test/services/error-handler.test.ts | 154 + test/services/evm.nonce.test.ts | 182 + test/services/evm.tx-storage.test.ts | 121 + test/services/local-storage.test.ts | 92 + test/services/logger.test.ts | 32 + test/services/patch.test.ts | 141 + test/services/patch.ts | 80 + test/services/refcounting-closeable.test.ts | 180 + test/services/swagger-manager.test.ts | 134 + test/services/validators.test.ts | 199 + .../wallet/wallet.controllers.test.ts | 385 + test/services/wallet/wallet.routes.test.ts | 308 + .../services/wallet/wallet.validators.test.ts | 299 + test/setup.ts | 7 + test/setupTests.js | 2 + test/teardown.ts | 6 + tsconfig.json | 36 + yarn.lock | 15149 +++++++ 382 files changed, 144680 insertions(+), 201 deletions(-) create mode 100644 .dockerignore create mode 100644 .eslintignore create mode 100644 .eslintrc.js create mode 100644 .gitignore create mode 100644 .prettierignore create mode 100644 .prettierrc create mode 100644 Changelog.md create mode 100644 Dockerfile delete mode 100644 LICENSE create mode 100644 README.md create mode 100755 bin/docker-start.sh create mode 100644 docs/swagger/amm-liquidity-routes.yml create mode 100644 docs/swagger/amm-routes.yml create mode 100644 docs/swagger/connectors-routes.yml create mode 100644 docs/swagger/cosmos-routes.yml create mode 100644 docs/swagger/definitions.yml create mode 100644 docs/swagger/evm-routes.yml create mode 100644 docs/swagger/main-routes.yml create mode 100644 docs/swagger/near-routes.yml create mode 100644 docs/swagger/network-routes.yml create mode 100644 docs/swagger/swagger.yml create mode 100644 docs/swagger/wallet-routes.yml create mode 100644 docs/testing.md create mode 100644 hooks/README.md create mode 100644 hooks/build create mode 100644 jest.config.js create mode 100644 manual-tests/curl.sh create mode 100644 manual-tests/requests/add_avalanche_key.json create mode 100644 manual-tests/requests/add_bsc_key.json create mode 100644 manual-tests/requests/add_cronos_key.json create mode 100644 manual-tests/requests/add_ethereum_key.json create mode 100644 manual-tests/requests/add_near_key.json create mode 100644 manual-tests/requests/avalanche_approve.json create mode 100644 manual-tests/requests/avalanche_nonce.json create mode 100644 manual-tests/requests/avalanche_traderjoe_allowances.json create mode 100644 manual-tests/requests/avalanche_traderjoe_trade.json create mode 100644 manual-tests/requests/bsc_approve.json create mode 100644 manual-tests/requests/bsc_balances.json create mode 100644 manual-tests/requests/bsc_nonce.json create mode 100644 manual-tests/requests/bsc_pancakeswap_trade.json create mode 100644 manual-tests/requests/bsc_sushiswap_trade.json create mode 100644 manual-tests/requests/config_update.json create mode 100644 manual-tests/requests/cronos_approve.json create mode 100644 manual-tests/requests/cronos_balances.json create mode 100644 manual-tests/requests/cronos_mmf_trade.json create mode 100644 manual-tests/requests/cronos_nonce.json create mode 100644 manual-tests/requests/cronos_vvs_trade.json create mode 100644 manual-tests/requests/eth_allowances.json create mode 100644 manual-tests/requests/eth_approve.json create mode 100644 manual-tests/requests/eth_approve_with_fees.json create mode 100644 manual-tests/requests/eth_approve_with_nonce.json create mode 100644 manual-tests/requests/eth_balances.json create mode 100644 manual-tests/requests/eth_nonce.json create mode 100644 manual-tests/requests/eth_perp_approve.json create mode 100644 manual-tests/requests/eth_poll.json create mode 100644 manual-tests/requests/eth_remove_allowance.json create mode 100644 manual-tests/requests/eth_uniswap_add_liquidity.json create mode 100644 manual-tests/requests/eth_uniswap_pool_price.json create mode 100644 manual-tests/requests/eth_uniswap_position.json create mode 100644 manual-tests/requests/eth_uniswap_price.json create mode 100644 manual-tests/requests/eth_uniswap_trade.json create mode 100644 manual-tests/requests/eth_uniswap_trade_with_fees.json create mode 100644 manual-tests/requests/harmony_dfk_trade.json create mode 100644 manual-tests/requests/harmony_testnet_defira_trade.json create mode 100644 manual-tests/requests/mmf_cronos_mainnet_allowance.json create mode 100644 manual-tests/requests/near_mainnet_ref_trade.json create mode 100644 manual-tests/requests/near_network_balances.json create mode 100644 manual-tests/requests/near_post_poll.json create mode 100644 manual-tests/requests/network_balances.json create mode 100644 manual-tests/requests/network_poll.json create mode 100644 manual-tests/requests/perp_position.json create mode 100644 manual-tests/requests/perp_prices.json create mode 100644 manual-tests/requests/perp_trade_open.json create mode 100644 manual-tests/requests/price_bsc_pancakeswap.json create mode 100644 manual-tests/requests/price_defira.json create mode 100644 manual-tests/requests/price_dfk.json create mode 100644 manual-tests/requests/price_mad_meerkat.json create mode 100644 manual-tests/requests/price_pangolin.json create mode 100644 manual-tests/requests/price_ref.json create mode 100644 manual-tests/requests/price_traderjoe.json create mode 100644 manual-tests/requests/price_uniswap.json create mode 100644 manual-tests/requests/price_vvs.json create mode 100644 manual-tests/requests/remove_avalanche_key.json create mode 100644 manual-tests/requests/remove_bsc_key.json create mode 100644 manual-tests/requests/remove_cronos_key.json create mode 100644 manual-tests/requests/remove_ethereum_key.json create mode 100644 manual-tests/requests/remove_near_key.json create mode 100644 manual-tests/requests/status_request.json create mode 100644 nodemon.json create mode 100644 package.json create mode 100755 setup/generate_conf.sh create mode 100644 src/@types/buffer-layout.d.ts create mode 100644 src/@types/cycle.d.ts create mode 100644 src/amm/amm.controllers.ts create mode 100644 src/amm/amm.requests.ts create mode 100644 src/amm/amm.routes.ts create mode 100644 src/amm/amm.validators.ts create mode 100644 src/app.ts create mode 100644 src/chains/avalanche/avalanche.ts create mode 100644 src/chains/avalanche/avalanche.validators.ts create mode 100644 src/chains/avalanche/avalanche_tokens_fuji.json create mode 100644 src/chains/avalanche/avanlanche_tokens.json create mode 100755 src/chains/binance-smart-chain/bep20_tokens_mainnet.json create mode 100755 src/chains/binance-smart-chain/bep20_tokens_testnet.json create mode 100644 src/chains/binance-smart-chain/binance-smart-chain.ts create mode 100644 src/chains/cosmos/cosmos-middlewares.ts create mode 100644 src/chains/cosmos/cosmos.config.ts create mode 100644 src/chains/cosmos/cosmos.controllers.ts create mode 100644 src/chains/cosmos/cosmos.requests.ts create mode 100644 src/chains/cosmos/cosmos.routes.ts create mode 100644 src/chains/cosmos/cosmos.ts create mode 100644 src/chains/cosmos/cosmos.validators.ts create mode 100755 src/chains/cronos/cronos.ts create mode 100755 src/chains/cronos/mainnet_beta.json create mode 100755 src/chains/cronos/testnet.json create mode 100644 src/chains/ethereum/arbitrum_one_tokens.json create mode 100644 src/chains/ethereum/arbitrum_rinkeby_tokens.json create mode 100644 src/chains/ethereum/balancer/balancer.config.ts create mode 100644 src/chains/ethereum/erc20_tokens_goerli.json create mode 100644 src/chains/ethereum/erc20_tokens_kovan.json create mode 100644 src/chains/ethereum/erc20_tokens_mainnet.json create mode 100644 src/chains/ethereum/erc20_tokens_ropsten.json create mode 100644 src/chains/ethereum/ethereum.config.ts create mode 100644 src/chains/ethereum/ethereum.controllers.ts create mode 100644 src/chains/ethereum/ethereum.requests.ts create mode 100644 src/chains/ethereum/ethereum.ts create mode 100644 src/chains/ethereum/ethereum.validators.ts create mode 100644 src/chains/ethereum/optimism_tokens.json create mode 100644 src/chains/harmony/harmony.config.ts create mode 100644 src/chains/harmony/harmony.ts create mode 100644 src/chains/harmony/harmony.validators.ts create mode 100644 src/chains/harmony/harmony_tokens_defira.json create mode 100644 src/chains/harmony/harmony_tokens_defira_testnet.json create mode 100644 src/chains/harmony/harmony_tokens_sushiswap.json create mode 100644 src/chains/harmony/harmony_tokens_sushiswap_testnet.json create mode 100644 src/chains/near/near.abi.json create mode 100644 src/chains/near/near.base.ts create mode 100644 src/chains/near/near.config.ts create mode 100644 src/chains/near/near.controllers.ts create mode 100644 src/chains/near/near.requests.ts create mode 100644 src/chains/near/near.routes.ts create mode 100644 src/chains/near/near.ts create mode 100644 src/chains/near/near.validators.ts create mode 100644 src/chains/near/near_testnet_tokens.json create mode 100644 src/chains/near/near_tokens.json create mode 100644 src/chains/polygon/polygon.ts create mode 100644 src/chains/polygon/polygon.validators.ts create mode 100644 src/chains/polygon/polygon_tokens_mainnet.json create mode 100644 src/chains/polygon/polygon_tokens_mumbai.json create mode 100644 src/connectors/connectors.routes.ts create mode 100644 src/connectors/cronos-base/cronos-base-uniswapish-connector.config.ts create mode 100644 src/connectors/cronos-base/cronos-base-uniswapish-connector.ts create mode 100644 src/connectors/defikingdoms/defikingdoms.config.ts create mode 100644 src/connectors/defikingdoms/defikingdoms.ts create mode 100644 src/connectors/defikingdoms/defikingdoms_router_abi.json create mode 100644 src/connectors/defira/defira.config.ts create mode 100644 src/connectors/defira/defira.ts create mode 100644 src/connectors/defira/defira_v2_router_abi.json create mode 100644 src/connectors/mad_meerkat/abi.json create mode 100644 src/connectors/mad_meerkat/mad_meerkat.config.ts create mode 100644 src/connectors/mad_meerkat/mad_meerkat.ts create mode 100644 src/connectors/openocean/openocean.config.ts create mode 100644 src/connectors/openocean/openocean.ts create mode 100644 src/connectors/pancakeswap/pancakeswap.config.ts create mode 100644 src/connectors/pancakeswap/pancakeswap.ts create mode 100644 src/connectors/pancakeswap/pancakeswap_router_abi.json create mode 100644 src/connectors/pangolin/IPangolinRouter.json create mode 100644 src/connectors/pangolin/pangolin.config.ts create mode 100644 src/connectors/pangolin/pangolin.ts create mode 100644 src/connectors/perp/perp.config.ts create mode 100644 src/connectors/perp/perp.controllers.ts create mode 100644 src/connectors/perp/perp.ts create mode 100644 src/connectors/quickswap/quickswap.config.ts create mode 100644 src/connectors/quickswap/quickswap.ts create mode 100644 src/connectors/ref/ref.config.ts create mode 100644 src/connectors/ref/ref.controllers.ts create mode 100644 src/connectors/ref/ref.helper.ts create mode 100644 src/connectors/ref/ref.ts create mode 100644 src/connectors/sushiswap/sushiswap.config.ts create mode 100644 src/connectors/sushiswap/sushiswap.ts create mode 100644 src/connectors/sushiswap/sushiswap_router.json create mode 100644 src/connectors/traderjoe/IJoeRouter02.json create mode 100644 src/connectors/traderjoe/traderjoe.config.ts create mode 100644 src/connectors/traderjoe/traderjoe.ts create mode 100644 src/connectors/uniswap/uniswap.config.ts create mode 100644 src/connectors/uniswap/uniswap.controllers.ts create mode 100644 src/connectors/uniswap/uniswap.lp.helper.ts create mode 100644 src/connectors/uniswap/uniswap.lp.interfaces.ts create mode 100644 src/connectors/uniswap/uniswap.lp.ts create mode 100644 src/connectors/uniswap/uniswap.ts create mode 100644 src/connectors/uniswap/uniswap_v2_router_abi.json create mode 100644 src/connectors/vvs/abi.json create mode 100644 src/connectors/vvs/vvs.config.ts create mode 100644 src/connectors/vvs/vvs.ts create mode 100644 src/evm/evm.requests.ts create mode 100644 src/evm/evm.routes.ts create mode 100644 src/https.ts create mode 100644 src/index.ts create mode 100644 src/network/network.controllers.ts create mode 100644 src/network/network.requests.ts create mode 100644 src/network/network.routes.ts create mode 100644 src/paths.ts create mode 100644 src/services/base.ts create mode 100644 src/services/common-interfaces.ts create mode 100644 src/services/config-manager-cert-passphrase.ts create mode 100644 src/services/config-manager-types.ts create mode 100644 src/services/config-manager-v2.ts create mode 100644 src/services/config-migration/migrations.ts create mode 100644 src/services/config/config.requests.ts create mode 100644 src/services/config/config.routes.ts create mode 100644 src/services/config/config.validators.ts create mode 100644 src/services/connection-manager.ts create mode 100644 src/services/cosmos-base.ts create mode 100644 src/services/error-handler.ts create mode 100644 src/services/ethereum-base.ts create mode 100644 src/services/ethereum.abi.json create mode 100644 src/services/evm.nonce.ts create mode 100644 src/services/evm.tx-storage.ts create mode 100644 src/services/local-storage.ts create mode 100644 src/services/logger.ts create mode 100644 src/services/refcounting-closeable.ts create mode 100644 src/services/schema/configuration-root-schema.json create mode 100644 src/services/schema/cosmos-schema.json create mode 100644 src/services/schema/cronos-connector-schema.json create mode 100644 src/services/schema/database-schema.json create mode 100644 src/services/schema/defikingdoms-schema.json create mode 100644 src/services/schema/defira-schema.json create mode 100644 src/services/schema/ethereum-gas-station-schema.json create mode 100644 src/services/schema/ethereum-schema.json create mode 100644 src/services/schema/harmony-schema.json create mode 100644 src/services/schema/logging-schema.json create mode 100644 src/services/schema/openocean-schema.json create mode 100644 src/services/schema/pangolin-schema.json create mode 100644 src/services/schema/perp-schema.json create mode 100644 src/services/schema/quickswap-schema.json create mode 100644 src/services/schema/ref-schema.json create mode 100644 src/services/schema/server-schema.json create mode 100644 src/services/schema/ssl-schema.json create mode 100644 src/services/schema/sushiswap-schema.json create mode 100644 src/services/schema/telemetry-schema.json create mode 100644 src/services/schema/traderjoe-schema.json create mode 100644 src/services/schema/uniswap-schema.json create mode 100644 src/services/swagger-manager.ts create mode 100644 src/services/telemetry-transport.ts create mode 100644 src/services/validators.ts create mode 100644 src/services/wallet/wallet.controllers.ts create mode 100644 src/services/wallet/wallet.requests.ts create mode 100644 src/services/wallet/wallet.routes.ts create mode 100644 src/services/wallet/wallet.validators.ts create mode 100644 src/templates/avalanche.yml create mode 100644 src/templates/binance-smart-chain.yml create mode 100644 src/templates/cosmos.yml create mode 100644 src/templates/cronos.yml create mode 100644 src/templates/database.yml create mode 100644 src/templates/defikingdoms.yml create mode 100644 src/templates/defira.yml create mode 100644 src/templates/ethereum.yml create mode 100644 src/templates/harmony.yml create mode 100644 src/templates/logging.yml create mode 100644 src/templates/mad_meerkat.yml create mode 100644 src/templates/near.yml create mode 100644 src/templates/openocean.yml create mode 100644 src/templates/pancakeswap.yml create mode 100644 src/templates/pangolin.yml create mode 100644 src/templates/perp.yml create mode 100644 src/templates/polygon.yml create mode 100644 src/templates/quickswap.yml create mode 100644 src/templates/ref.yml create mode 100644 src/templates/root.yml create mode 100644 src/templates/server.yml create mode 100644 src/templates/ssl.yml create mode 100644 src/templates/sushiswap.yml create mode 100644 src/templates/telemetry.yml create mode 100644 src/templates/traderjoe.yml create mode 100644 src/templates/uniswap.yml create mode 100644 src/templates/vvs.yml create mode 100644 startup.sh create mode 100644 test-scripts/README.md create mode 100644 test-scripts/cosmos.test.ts create mode 100644 test-scripts/ethereum.test.base.ts create mode 100644 test-scripts/harmony.test.ts create mode 100644 test-scripts/test.base.ts create mode 100644 test-scripts/uniswap.v2.test.ts create mode 100644 test/amm/amm.validators.test.ts create mode 100644 test/app.test.ts create mode 100644 test/chains/avalanche/avalanche.routes.test.ts create mode 100644 test/chains/avalanche/avalanche.test.ts create mode 100644 test/chains/avalanche/avalanche.validators.test.ts create mode 100644 test/chains/avalanche/openocean/openocean.routes.test.ts create mode 100644 test/chains/avalanche/openocean/openocean.test.ts create mode 100644 test/chains/avalanche/pangolin/pangolin.routes.test.ts create mode 100644 test/chains/avalanche/pangolin/pangolin.test.ts create mode 100644 test/chains/avalanche/traderjoe/traderjoe.test.ts create mode 100644 test/chains/binance-smart-chain/binance-smart-chain.routes.test.ts create mode 100644 test/chains/binance-smart-chain/pancakeswap/pancakeswap.routes.test.ts create mode 100644 test/chains/binance-smart-chain/pancakeswap/pancakeswap.test.ts create mode 100644 test/chains/cosmos/cosmos.routes.test.ts create mode 100644 test/chains/cosmos/cosmos.validators.test.ts create mode 100644 test/chains/cosmos/fixtures/getTransaction.json create mode 100644 test/chains/cronos/cronos.routes.test.ts create mode 100644 test/chains/cronos/mad_meerkat/mad-meerkat.routes.test.ts create mode 100644 test/chains/cronos/mad_meerkat/mad-meerkat.test.ts create mode 100644 test/chains/cronos/vvs/vvs.routes.test.ts create mode 100644 test/chains/cronos/vvs/vvs.test.ts create mode 100644 test/chains/ethereum/ethereum.controllers.test.ts create mode 100644 test/chains/ethereum/ethereum.routes.test.ts create mode 100644 test/chains/ethereum/ethereum.validators.test.ts create mode 100644 test/chains/ethereum/evm.nonce.test.ts create mode 100644 test/chains/ethereum/fixtures/transaction-out-of-gas-receipt.json create mode 100644 test/chains/ethereum/fixtures/transaction-out-of-gas.json create mode 100644 test/chains/ethereum/fixtures/transaction-succesful-receipt.json create mode 100644 test/chains/ethereum/fixtures/transaction-succesful.json create mode 100644 test/chains/ethereum/perp/perp.routes.test.ts create mode 100644 test/chains/ethereum/perp/perp.test.ts create mode 100644 test/chains/ethereum/sushiswap/sushiswap.routes.test.ts create mode 100644 test/chains/ethereum/sushiswap/sushiswap.test.ts create mode 100644 test/chains/ethereum/uniswap/uniswap.lp.routes.test.ts create mode 100644 test/chains/ethereum/uniswap/uniswap.lp.test.ts create mode 100644 test/chains/ethereum/uniswap/uniswap.routes.test.ts create mode 100644 test/chains/ethereum/uniswap/uniswap.test.ts create mode 100644 test/chains/harmony/defikingdoms/defikingdoms.routes.test.ts create mode 100644 test/chains/harmony/defikingdoms/defikingdoms.test.ts create mode 100644 test/chains/harmony/defira/defira.routes.test.ts create mode 100644 test/chains/harmony/defira/defira.test.ts create mode 100644 test/chains/harmony/harmony.controllers.test.ts create mode 100644 test/chains/harmony/harmony.routes.test.ts create mode 100644 test/chains/harmony/harmony.test.ts create mode 100644 test/chains/harmony/harmony.validators.test.ts create mode 100644 test/chains/near/fixtures/getTokenList.json create mode 100644 test/chains/near/fixtures/getTransaction.json create mode 100644 test/chains/near/near.controllers.test.ts create mode 100644 test/chains/near/near.routes.test.ts create mode 100644 test/chains/near/near.validators.test.ts create mode 100644 test/chains/near/ref/ref.route.test.ts create mode 100644 test/chains/near/ref/ref.test.ts create mode 100644 test/chains/polygon/polygon.test.ts create mode 100644 test/chains/polygon/polygon.validators.test.ts create mode 100644 test/chains/polygon/quickswap/quickswap.route.test.ts create mode 100644 test/chains/polygon/quickswap/quickswap.test.ts create mode 100644 test/config.util.ts create mode 100644 test/connectors/connectors.routes.test.ts create mode 100644 test/evm.nonce.mock.ts create mode 100644 test/network/network.routes.test.ts create mode 100644 test/postman/collections/EthereumV2.postman_collection.json create mode 100644 test/postman/collections/Openocean-GatewayV2.postman_collection.json create mode 100644 test/postman/collections/Uniswap-GatewayV2.postman_collection.json create mode 100644 test/postman/enviroments/GatewayV2.postman_environment.json create mode 100644 test/services/base.test.ts create mode 100644 test/services/config-manager-cert-passphrase.test.ts create mode 100644 test/services/config-manager-v2.test.ts create mode 100644 test/services/config-validators.test.ts create mode 100644 test/services/data/config-manager-v2/test1/defira.yaml create mode 100644 test/services/data/config-manager-v2/test1/ethereum.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-defira.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-root-2.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-root-3.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-root-4.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-root-defira.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-root.yml create mode 100644 test/services/data/config-manager-v2/test1/invalid-ssl.yml create mode 100644 test/services/data/config-manager-v2/test1/root.yml create mode 100644 test/services/data/config-manager-v2/test1/root2.yml create mode 100644 test/services/data/config-manager-v2/test1/ssl.yml create mode 100644 test/services/data/config-manager-v2/test1/telemetry.yml create mode 100644 test/services/error-handler.test.ts create mode 100644 test/services/evm.nonce.test.ts create mode 100644 test/services/evm.tx-storage.test.ts create mode 100644 test/services/local-storage.test.ts create mode 100644 test/services/logger.test.ts create mode 100644 test/services/patch.test.ts create mode 100644 test/services/patch.ts create mode 100644 test/services/refcounting-closeable.test.ts create mode 100644 test/services/swagger-manager.test.ts create mode 100644 test/services/validators.test.ts create mode 100644 test/services/wallet/wallet.controllers.test.ts create mode 100644 test/services/wallet/wallet.routes.test.ts create mode 100644 test/services/wallet/wallet.validators.test.ts create mode 100644 test/setup.ts create mode 100644 test/setupTests.js create mode 100644 test/teardown.ts create mode 100644 tsconfig.json create mode 100644 yarn.lock diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000000..8536796986 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,6 @@ +/db +/certs +/conf +/logs +/gateway.level +/transactions.level diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000000..3950c73f79 --- /dev/null +++ b/.eslintignore @@ -0,0 +1,2 @@ +# turn off specific file for eslint +/node_modules \ No newline at end of file diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 0000000000..1930749473 --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,24 @@ +module.exports = { + parser: '@typescript-eslint/parser', + plugins: ['@typescript-eslint', 'prettier'], + env: { + node: true, + }, + extends: [ + 'eslint:recommended', + 'plugin:@typescript-eslint/eslint-recommended', + 'plugin:@typescript-eslint/recommended', + 'prettier', + ], + rules: { + 'no-console': 'off', + '@typescript-eslint/no-explicit-any': 'off', + '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }], + semi: [2, 'always'], + 'prettier/prettier': 'error', + '@typescript-eslint/no-var-requires': 'off', + '@typescript-eslint/explicit-module-boundary-types': 'off', + '@typescript-eslint/no-inferrable-types': 'off', + '@typescript-eslint/no-namespace': 'off', + }, +}; diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000000..9853649c9f --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +/conf +/logs +/dist +/db +/.idea +package-lock.json +/certs +/node_modules +**/.DS_Store diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000000..286e1edfa0 --- /dev/null +++ b/.prettierignore @@ -0,0 +1,5 @@ +certs +*.md +*.yml +coverage +dist \ No newline at end of file diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000000..1d296fb672 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,5 @@ +{ + "semi": true, + "singleQuote": true, + "tabWidth": 2 +} diff --git a/Changelog.md b/Changelog.md new file mode 100644 index 0000000000..c47a20c3f0 --- /dev/null +++ b/Changelog.md @@ -0,0 +1,130 @@ +# Changelog for gateway +All notable changes to gateway should be added to this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + +## [0.1.9] - 2021-08-27 + +### Added + +- `/config` returns current config values. + +### Changed + +- `/` and `/config/update` return JSON responses. + +- Added a version number to the config file. + +- Cleaned up extraneous options in package.json. + +- Make unit tests work and they no longer run the scripts. + +## [0.1.8] - 2021-08-18 + +### Added + +- Added uniswap routes: + - `/` + - `/price` + - `/trade` + +## [0.1.7] - 2021-08-16 + +### Added + +- A uniswap service class. + +## [0.1.6] - 2021-08-12 + +### Added + +- create an test script that uses all of the ethereum routes. Can be run with `yarn test-scripts`. + +## [0.1.5] - 2021-08-11 + +### Added + +- /config/update to update the config file and reload the server + +## [0.1.4] - 2021-08-09 + +### Added + +- run gateway with https as default + +- hidden option to run in http. This is unsafe and should only be done in development mode. + +- manual/curl-with-private-key.sh to test routes while using https + +## [0.1.3] - 2021-07-29 + +### Added + +- Added ethereum routes: + - `/eth` + - `/eth/balances` + - `/eth/approve` + - `/eth/poll` + +- Simple express error handler (to be improved in future PRs) + +- Add approvedSpenders to Ethereum. + +- Add getTokenBySymbol to Ethereum. + +- uniswap.config.ts with Uniswap addresses. + +- balancer.config.ts with Balancer addresses + +## [0.1.2] - 2021-07-27 + +### Added + +- Tests for config-manager.ts. + +### Changed + +- Drop EthTransactionReceipt, use providers.TransactionReceipt for getTransactionReceipt. + +- Trade yaml for js-yaml because it has types. + +- Add a Config type to ConfigManager. + +- Ethereum extends EthereumBase and has custom behavior for the ethereum gas price. + + +## [0.1.1] - 2021-07-26 + +### Added + +- Add src/services/gateway-config.ts based on the file from gateway-api, but + much simpler and without file watching (the API should be responsible for + restarting the service if there is a change to the config file). + +- Add src/services/base.ts to hold types and functions common to all services. + +### Changed + +- Update src/services/ethereum-base.ts to be an implementation using what was in + src/chains/ethereum/ethereum.ts. + +### Removed + +- Delete all code in src/chains/ethereum/ethereum.ts since it was moved + to ethereum-base.ts. In a future PR this will become a class that inherits + from EthereumBase. + +## [0.1.0] - 2021-07-22 + +### Added + +- Initate a new repo for gateway. This will replace [gateway-api](https://github.com/CoinAlpha/gateway-api) and eventually be added to [hummingbot](https://github.com/CoinAlpha/hummingbot) to form a monorepo. + +- Add libraries for TypeScript, eslint, express and uniswap. + +- Create dirs and files according to Mike's architecture proposal. + +- Create a test dir with a single set of unit tests. + +- Create ethereum base class, config and service. diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000000..81553f9cbe --- /dev/null +++ b/Dockerfile @@ -0,0 +1,40 @@ +FROM node:18.10.0 + +# Set labels +LABEL application="gateway-v2" +LABEL branch=${BRANCH} +LABEL commit=${COMMIT} +LABEL date=${BUILD_DATE} + +# Set ENV variables +ENV COMMIT_BRANCH=${BRANCH} +ENV COMMIT_SHA=${COMMIT} +ENV BUILD_DATE=${DATE} + +# Add hummingbot user and group +RUN groupadd -g 8211 hummingbot && \ + useradd -m -s /bin/bash -u 8211 -g 8211 hummingbot + +# Install gosu +RUN apt-get update && \ + DEBIAN_FRONTEND=noninteractive apt-get install -y gosu && \ + rm -rf /var/lib/apt/lists/* + +# app directory +WORKDIR /usr/src/app + +# create app writable directory for db files +RUN mkdir /var/lib/gateway +RUN chown -R hummingbot /var/lib/gateway + +# copy pwd file to container +COPY . . + +# install dependencies +RUN yarn install --frozen-lockfile + +EXPOSE 15888 + +RUN yarn build + +CMD ["bin/docker-start.sh"] diff --git a/LICENSE b/LICENSE deleted file mode 100644 index 261eeb9e9f..0000000000 --- a/LICENSE +++ /dev/null @@ -1,201 +0,0 @@ - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. diff --git a/README.md b/README.md new file mode 100644 index 0000000000..c58412e4c3 --- /dev/null +++ b/README.md @@ -0,0 +1,128 @@ +![Hummingbot](https://i.ibb.co/X5zNkKw/blacklogo-with-text.png) + +# Hummingbot Gateway + +--- + +Hummingbot Gateway is a REST API that exposes connections to various blockchains (wallet, node & chain interaction) and decentralized exchanges (pricing, trading & liquidity provision). It is written in Typescript and takes advantage of existing blockchain and DEX SDKs. The advantage of using gateway is it provideds a programming language agnostic approach to interacting with blockchains and DEXs. + +Gateway may be used alongside the main Hummingbot client to enable trading on DEXs, or as a standalone module by external developers. + +## Connectors + +This is a list of DEX connections currently supported by Gateway. + +| Connector | Blockchain | Trading Interface | +| ----------- | ------------------- | ----------------- | +| UniswapV2 | Ethereum | AMM | +| Sushiswap | Ethereum | AMM | +| UniswapV3 | Ethereum | EVM_Range_AMM | +| Pangolin | Avalanche | AMM | +| PancakeSwap | Binance Smart Chain | AMM | +| Traderjoe | Avalanche | AMM | +| Quickswap | Polygon | AMM | +| Perp | Ethereum | EVM_Perpetual | +| Mad Meerkat | Cronos | AMM | +| VVS | Cronos | AMM | + + +## Contributing + +There are a number of ways to contribute to gateway. + +- Add a new blockchain. + +- Add a new connector/DEX. + +- Fix a bug. + +- File an issue at [hummingbot issues](https://github.com/hummingbot/hummingbot/issues) + +- Make a PR for anything useful on [hummingbot](https://github.com/hummingbot/hummingbot/). + +- Vote on a snapshot proposal: [Hummingbot PRP](https://snapshot.org/#/hbot-prp.eth), [Hummingbot Foundation - HGP](https://snapshot.org/#/hbot.eth), [Hummingbot Improvement Proposals](https://snapshot.org/#/hbot-ip.eth). + +## Configuration + +Before running gateway, you need to setup some configs. You can start by copying all of the yml files from [src/templates](./src/templates) to [conf](./conf). The format of this files are dictated by [src/services/config-manager-v2.ts](./src/services/config-manager-v2.ts) and the corresponding schema files in [src/services/schema](./src/services/schema) . + +### Useful configuration options + +- If you want to turn off `https`, set `unsafeDevModeWithHTTP` to `true` in [conf/server.yml](./conf/server.yml). + +- If you gateway to log to standard out, set `logToStdOut` to `true` in [conf/logging.yml](./conf/logging.yml). + +- Edit the path to the SSL files in [conf/ssl.yml](./conf/ssl.yml). This can be generated by hummingbot with `gateway generate-certs`. + +The hummingbot client is also able to edit this config files. + +## Install and run locally + +Compile the Typescript code with `npm` or `yarn` . + +```bash +yarn +yarn build +yarn dev --passphrase= +# the passphrase can be anything if unsafeDevModeWithHTTP is true +``` + +## Documentation + +The API is documented using swagger: [gateway swagger docs](./docs/swagger). You can run the gateway swagger UI by starting gateway and visiting [localhost:8080](localhost:8080). + +You can follow details about [trading interfaces](https://hummingbot.notion.site/Gateway-v2-Trading-Interfaces-482e2684d48c450ebcfff5401ba806aa) + +Also, we maintain docs on the official website about gateway [here](https://hummingbot.org/protocols/gateway/). + +### Files to read + +Here are some files we recommend you look at in order to get familiar with the gateway code base. + +- [src/services/ethereum-base.ts](./src/services/ethereum-base.ts) is a base class for EVM chains. + +- [src/connectors/uniswap/uniswap.ts](./src/connectors/uniswap/uniswap.ts) has functionality for interacting with Uniswap V2. + +- [src/services/validator.ts](./src/services/validator.ts) defines functions for validating request payloads. + + +### Testing + +When making a PR, there are unit test coverage requirements. Look at our [github workflow](../.github/workflows/workflow.yml) for the exact definition. There are some more + +#### Unit tests + +Read this document for more details about how to write unit test in gateway: [How we write unit tests for gateway](./docs/testing.md). + +Run all unit tests. + +```bash +yarn test:unit +``` + +Run an individual test file. + +```bash +yarn jest test/app.test.ts +``` + +#### Manual tests + +We have found it is useful to test individual endpoints with `curl` commands. We have a collection of prepared curl calls. POST bodies are stored in JSON files. Take a look at the [curl calls for gateway](./manual-tests/curl.sh). Note that some environment variables are expected. + +## Linting + +This repo uses `eslint` and `prettier`. When you run `git commit` it will trigger the `pre-commit` hook. This will run `eslint` on the `src` and `test` directories. + +You can lint before committing with: + +```bash +yarn run lint +``` + +You can run the prettifier before committing with: + +```bash +yarn run prettier +``` + diff --git a/bin/docker-start.sh b/bin/docker-start.sh new file mode 100755 index 0000000000..85bd3332a6 --- /dev/null +++ b/bin/docker-start.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +mkdir -p /usr/src/app/gateway.level /usr/src/app/transactions.level \ + /usr/src/app/db +chown -R hummingbot:hummingbot /usr/src/app/logs /usr/src/app/conf \ + /usr/src/app/gateway.level /usr/src/app/transactions.level \ + /usr/src/app/db + +gosu hummingbot:hummingbot yarn run start diff --git a/docs/swagger/amm-liquidity-routes.yml b/docs/swagger/amm-liquidity-routes.yml new file mode 100644 index 0000000000..7a7c447c4b --- /dev/null +++ b/docs/swagger/amm-liquidity-routes.yml @@ -0,0 +1,101 @@ +paths: + /amm/liquidity/price: + post: + tags: + - 'amm/liquidity' + summary: 'Get the historical pool prices for a pair' + operationId: 'historical' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/LiquidityPriceRequest' + responses: + '200': + schema: + $ref: '#/definitions/LiquidityPriceResponse' + /amm/liquidity/add: + post: + tags: + - 'amm/liquidity' + summary: 'Add liquidity to pool' + operationId: 'add' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/LiquidityAddRequest' + responses: + '200': + schema: + $ref: '#/definitions/LiquidityAddResponse' + /amm/liquidity/remove: + post: + tags: + - 'amm/liquidity' + summary: 'Remove liquidity to pool' + operationId: 'remove' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/LiquidityRemoveRequest' + responses: + '200': + schema: + $ref: '#/definitions/LiquidityRemoveResponse' + /amm/liquidity/collect_fees: + post: + tags: + - 'amm/liquidity' + summary: 'Collect earned fees' + operationId: 'collect' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/LiquidityCollectRequest' + responses: + '200': + schema: + $ref: '#/definitions/LiquidityCollectResponse' + /amm/liquidity/position: + post: + tags: + - 'amm/liquidity' + summary: 'Get details about position' + operationId: 'position' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/LiquidityPositionRequest' + responses: + '200': + schema: + $ref: '#/definitions/LiquidityPositionResponse' diff --git a/docs/swagger/amm-routes.yml b/docs/swagger/amm-routes.yml new file mode 100644 index 0000000000..7e4a7a276f --- /dev/null +++ b/docs/swagger/amm-routes.yml @@ -0,0 +1,221 @@ +paths: + /amm/price: + post: + tags: + - 'amm' + summary: 'Get the price for a quote base pair on an AMM' + operationId: 'poll' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PriceRequest' + responses: + '200': + schema: + $ref: '#/definitions/PriceResponse' + /amm/trade: + post: + tags: + - 'amm' + summary: 'Perform a trade on an AMM' + operationId: 'trade' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/TradeRequest' + responses: + '200': + schema: + $ref: '#/definitions/TradeResponse' + /amm/estimateGas: + post: + tags: + - 'amm' + summary: 'Estimate the total gas costs for sending an AMM order' + operationId: 'estimateGas' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NetworkSelectionRequest' + responses: + '200': + schema: + $ref: '#/definitions/EstimateGasResponse' + /amm/perp/market-prices: + post: + tags: + - 'amm' + summary: 'Get market prices for a quote base pair on perp curie' + operationId: 'perpPrices' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpPriceRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpPriceResponse' + /amm/perp/market-status: + post: + tags: + - 'amm' + summary: 'Get the status for a quote base pair market' + operationId: 'marketStatus' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpPriceRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpStatusResponse' + /amm/perp/pairs: + post: + tags: + - 'amm' + summary: 'Get a list of all available pairs on perp curie' + operationId: 'perpPairs' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpPairsRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpPairsResponse' + /amm/perp/position: + post: + tags: + - 'amm' + summary: 'Get poision data for a quote base pair' + operationId: 'perpPosition' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpPositionRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpPositionResponse' + /amm/perp/balance: + post: + tags: + - 'amm' + summary: 'Get account value' + operationId: 'perpBalance' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpBalanceRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpBalanceResponse' + /amm/perp/open: + post: + tags: + - 'amm' + summary: 'Open/increase position on specified market' + operationId: 'perpPositionOpen' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpOpenRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpOpenResponse' + /amm/perp/close: + post: + tags: + - 'amm' + summary: 'Close postion on specified market' + operationId: 'perpPositionClose' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PerpCloseRequest' + responses: + '200': + schema: + $ref: '#/definitions/PerpCloseResponse' + /amm/perp/estimateGas: + post: + tags: + - 'amm' + summary: 'Estimate the total gas costs for sending a perp order' + operationId: 'estimateGas' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NetworkSelectionRequest' + responses: + '200': + schema: + $ref: '#/definitions/EstimateGasResponse' \ No newline at end of file diff --git a/docs/swagger/connectors-routes.yml b/docs/swagger/connectors-routes.yml new file mode 100644 index 0000000000..76a504df70 --- /dev/null +++ b/docs/swagger/connectors-routes.yml @@ -0,0 +1,10 @@ +paths: + /connectors: + get: + tags: + - 'system' + summary: 'Show list of available connectors and networks' + operationId: 'get' + produces: + - 'application/json' + responses: '200' diff --git a/docs/swagger/cosmos-routes.yml b/docs/swagger/cosmos-routes.yml new file mode 100644 index 0000000000..38d44d4f28 --- /dev/null +++ b/docs/swagger/cosmos-routes.yml @@ -0,0 +1,57 @@ +paths: + /cosmos: + get: + tags: + - 'cosmos' + summary: 'View the Cosmos network and RPC URL that gateway is configured to use' + description: 'The user can change this by editing src/chains/cosmos/cosmos.config.ts' + operationId: 'root' + produces: + - 'application/json' + responses: + '200': + description: 'Cosmos config' + schema: + $ref: '#/definitions/CosmosConfigResponse' + + /cosmos/balances: + post: + tags: + - 'cosmos' + summary: 'Get the balances of a Cosmos wallet' + operationId: 'balances' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/CosmosBalanceRequest' + responses: + '200': + schema: + $ref: '#/definitions/BalancesResponse' + + /cosmos/poll: + post: + tags: + - 'cosmos' + summary: 'Poll the status of a Cosmos transaction' + operationId: 'poll' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/CosmosPollRequest' + responses: + '200': + schema: + $ref: '#/definitions/CosmosPollResponse' diff --git a/docs/swagger/definitions.yml b/docs/swagger/definitions.yml new file mode 100644 index 0000000000..410cb794f9 --- /dev/null +++ b/docs/swagger/definitions.yml @@ -0,0 +1,1580 @@ +definitions: + EthereumConfigResponse: + type: 'object' + required: + - 'network' + - 'rpcUrl' + - 'connection' + - 'timestamp' + properties: + network: + type: 'string' + example: 'mainnet' + rpcUrl: + type: 'string' + example: 'https://mainnet.infura.io/v3/' + connection: + type: 'boolean' + example: true + timestamp: + type: 'integer' + example: 1636368085740 + + NonceRequest: + type: 'object' + required: + - 'privateKey' + - 'chain' + - 'network' + properties: + privateKey: + type: 'string' + example: '6078d949c953351685fd2026646028f2a862e6148d25d504967ba63898d720c0' # noqa: documentation + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + NonceResponse: + type: 'object' + required: + - 'nonce' + properties: + privateKey: + type: 'integer' + example: 123 + + AllowancesRequest: + type: 'object' + required: + - 'privateKey' + - 'spender' + - 'tokenSymbols' + - 'chain' + - 'network' + properties: + privateKey: + type: 'string' + example: '6078d949c953351685fd2026646028f2a862e6148d25d504967ba63898d720c0' # noqa: documentation + spender: + type: 'string' + example: 'uniswap' + tokenSymbols: + type: 'array' + items: 'string' + example: ['WETH', 'DAI'] + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + AllowancesResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'spender' + - 'approvals' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + spender: + type: 'string' + example: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D' + approvals: + type: 'object' + properties: + id: + type: 'string' + name: + type: 'string' + example: '{"WETH": "100","DAI": "300"}' + + BalancesRequest: + type: 'object' + required: + - 'privateKey' + - 'tokenSymbols' + - 'chain' + - 'network' + properties: + privateKey: + type: 'string' + example: '6078d949c953351685fd2026646028f2a862e6148d25d504967ba63898d720c0' # noqa: documentation + tokenSymbols: + type: 'array' + items: 'string' + example: ['WETH', 'DAI'] + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + BalancesResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'balances' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + balances: + type: 'object' + properties: + id: + type: 'string' + name: + type: 'string' + example: '{"ETH": "1.5", "WETH": "100","DAI": "300"}' + + ApproveRequest: + type: 'object' + required: + - 'privateKey' + - 'spender' + - 'token' + - 'chain' + - 'network' + properties: + privateKey: + type: 'string' + example: '6078d949c953351685fd2026646028f2a862e6148d25d504967ba63898d720c0' # noqa: documentation + spender: + type: 'string' + example: 'uniswap' + token: + type: 'string' + example: 'WETH' + amount: + type: 'string' + example: '0' + nonce: + type: 'number' + example: 123 + maxFeePerGas: + type: 'string' + example: '5000000000' + maxPriorityFeePerGas: + type: 'string' + example: '5000000000' + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + ApproveResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'tokenAddress' + - 'spender' + - 'amount' + - 'nonce' + - 'approval' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 1.526 + tokenAddress: + type: 'string' + example: '0xd0A1E359811322d97991E03f863a0C30C2cF029C' + spender: + type: 'string' + example: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D' + amount: + type: 'string' + example: '100' + nonce: + type: 'number' + example: 124 + approval: + type: 'object' + example: '{"type": 2,"chainId": 42,"nonce": 129,"maxPriorityFeePerGas": "94000000000","maxFeePerGas": "94000000000","gasPrice": null,"gasLimit": "100000","to": "0xd0A1E359811322d97991E03f863a0C30C2cF029C","value": "0","data": "0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff","accessList": [],"hash": "0xa321bbe8888c3bc88ecb1ad4f03f22a71e6f5715dfcb19e0a2dca9036c981b6d","v": 1,"r": "0x47c517271885b7041d81bcd65cd050a5d6be3fbd67a8f1660ac8d7e68fc8221f","s": "0x7c62e114b2cb0eae6236b597fb4aacb01c51e56afd7f734e6039d83aa400ba82","from": "0xFaA12FD102FE8623C9299c72B03E45107F2772B5","confirmations": 0}' # noqa: documentation + + PollRequest: + type: 'object' + required: + - 'txHash' + - 'chain' + - 'network' + properties: + txHash: + type: 'string' + example: '0xa321bbe8888c3bc88ecb1ad4f03f22a71e6f5715dfcb19e0a2dca9036c981b6d' # noqa: documentation + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + PollResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'currentBlock' + - 'txHash' + - 'txStatus' + - 'txBlock' + - 'txData' + - 'txReceipt' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + currentBlock: + type: 'integer' + example: 28243911 + txHash: + type: 'string' + example: '0xa321bbe8888c3bc88ecb1ad4f03f22a71e6f5715dfcb19e0a2dca9036c981b6d' # noqa: documentation + txStatus: + type: 'number' + example: 1 + txBlock: + type: 'number' + example: 28243800 + txData: + type: 'object' + txReceipt: + type: 'object' + + UniswapConfigResponse: + type: 'object' + required: + - 'network' + - 'uniswap_router' + - 'connection' + - 'timestamp' + properties: + network: + type: 'string' + example: 'mainnet' + uniswap_router: + type: 'string' + example: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D' + connection: + type: 'boolean' + example: true + timestamp: + type: 'integer' + example: 1636368085740 + + PriceRequest: + type: 'object' + required: + - 'quote' + - 'base' + - 'amount' + - 'side' + - 'chain' + - 'network' + properties: + quote: + type: 'string' + example: 'WETH' + base: + type: 'string' + example: 'DAI' + amount: + type: 'string' + example: '10' + side: + type: 'string' + example: 'BUY' + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + PriceResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'quote' + - 'amount' + - 'expectedAmount' + - 'price' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + base: + type: 'string' + example: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa' + quote: + type: 'string' + example: '0xd0A1E359811322d97991E03f863a0C30C2cF029C' + amount: + type: 'string' + example: '10' + expectedAmount: + type: 'string' + example: '0.000000000000000001' + price: + type: 'string' + gasPrice: + type: 'number' + example: 96 + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'number' + example: 150688 + gasCost: + type: 'string' + example: '0.014466048000000000' + + TradeRequest: + type: 'object' + required: + - 'quote' + - 'base' + - 'amount' + - 'side' + - 'chain' + - 'network' + - 'connector' + properties: + quote: + type: 'string' + example: 'WETH' + base: + type: 'string' + example: 'DAI' + amount: + type: 'string' + example: '10' + side: + type: 'string' + example: 'BUY' + limitPrice: + type: 'string' + nonce: + type: number + maxFeePerGas: + type: number + maxPriorityFeePerGas: + type: number + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswap' + + TradeResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'quote' + - 'amount' + - 'price' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + - 'nonce' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + base: + type: 'string' + example: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa' + quote: + type: 'string' + example: '0xd0A1E359811322d97991E03f863a0C30C2cF029C' + amount: + type: 'string' + example: '10' + expectedIn: + type: 'string' + expectedOut: + type: 'string' + price: + type: 'string' + gasPrice: + type: 'string' + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'string' + gasCost: + type: 'string' + nonce: + type: 'string' + txHash: + type: 'string' + + CancelRequest: + type: 'object' + required: + - 'nonce' + - 'address' + - 'chain' + - 'network' + properties: + nonce: + type: 'integer' + example: 123 + address: + type: 'string' + example: '0xd0A1E359811322d97991E03f863a0C30C2cF029C' + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + + CancelResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + txHash: + type: 'string' + example: '0xa321bbe8888c3bc88ecb1ad4f03f22a71e6f5715dfcb19e0a2dca9036c981b6d' # noqa: documentation + + AddWalletRequest: + type: 'object' + required: + - 'chainName' + - 'privateKey' + properties: + chainName: + type: 'string' + example: 'ethereum' + privateKey: + type: 'string' + example: '6078d949c953351685fd2026646028f2a862e6148d25d504967ba63898d720c0' # noqa: documentation + + RemoveWalletRequest: + type: 'object' + required: + - 'chainName' + - 'address' + properties: + chainName: + type: 'string' + example: 'ethereum' + address: + type: 'string' + example: '0xd0A1E359811322d97991E03f863a0C30C2cF029C' + + GetWalletResponse: + type: 'object' + required: + - 'chain' + - 'walletAddresses' + properties: + chain: + type: 'string' + tokenSymbols: + type: 'array' + items: 'string' + example: ['0xd0A1E359811322d97991E03f863a0C30C2cF029C', '0xd0A1E359811322d97991E03f863a0C30C2XXXXXX'] + + ConfigUpdateRequest: + type: 'object' + required: + - 'configPath' + - 'configValue' + properties: + configPath: + type: 'string' + configValue: + OneOf: + - type: 'boolean' + - type: 'number' + + CosmosConfigResponse: + type: 'object' + required: + - 'network' + - 'rpcUrl' + - 'connection' + - 'timestamp' + properties: + network: + type: 'string' + example: 'mainnet' + rpcUrl: + type: 'string' + example: 'https://rpc.cosmos.network/' + connection: + type: 'boolean' + example: true + timestamp: + type: 'integer' + example: 1641889489132 + + CosmosBalanceRequest: + type: 'object' + required: + - 'address' + - 'tokenSymbols' + properties: + address: + type: 'string' + example: 'cosmos1pc8m5m7n0z8xe7sx2tawkvc0v6qkjql83js0dr' + tokenSymbols: + type: 'array' + items: 'string' + example: ['ATOM', 'NETA'] + + CosmosPollRequest: + type: 'object' + required: + - 'txHash' + properties: + txHash: + type: 'string' + example: 'E0E02A6C27A75F4442B0746676BDAF5F66AFF1E71928C54624A35B48D5A4B3AF' + + CosmosPollResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'txHash' + - 'currentBlock' + - 'txBlock' + - 'gasUsed' + - 'gasWanted' + - 'txData' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + currentBlock: + type: 'integer' + example: 112646487 + txHash: + type: 'string' + example: 'oaMWkrYr1g9JBcDUPRqz21cJBxowM4CEbDy2FsCgNK569CjZSr4wa51d4k9DpTRJU8GUHfp3e9YX2pGXaBS5Tta' + txBlock: + type: 'number' + example: 11581899 + gasUsed: + type: 'number' + example: 89054 + gasWanted: + type: 'number' + example: 130000 + txData: + $ref: '#/definitions/CosmosTransaction' + + TokensResponse: + type: 'object' + required: + - 'tokens' + properties: + tokens: + type: 'object' + example: ' + { + tokens: [ + { + "address": "0x006BeA43Baa3f7A6f765F14f10A1a1b08334EF45", + "chainId": "1", + "name": "Stox", + "symbol": "STX", + "decimals": "18", + "logoURI": "https://tokens.1inch.io/0x006bea43baa3f7a6f765f14f10a1a1b08334ef45.png" + }, + { + "address": "0x0327112423F3A68efdF1fcF402F6c5CB9f7C33fd", + "chainId": "1", + "name": "PieDAOBTC", + "symbol": "BTC", + "decimals": "18", + "logoURI": "https://tokens.1inch.io/0x0327112423f3a68efdf1fcf402f6c5cb9f7c33fd.png" + } + ] + }' + + NetworkSelectionRequest: + type: 'object' + required: + - 'chain' + - 'network' + - 'connector' + properties: + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswap' + + EstimateGasResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + gasPrice: + type: 'number' + example: 96 + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'number' + example: 150688 + gasCost: + type: 'string' + example: '0.014466048000000000' + + LiquidityAddRequest: + type: 'object' + required: + - 'address' + - 'token0' + - 'token1' + - 'amount0' + - 'amount1' + - 'fee' + - 'lowerPrice' + - 'upperPrice' + properties: + address: + type: 'string' + example: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D' + token0: + type: 'string' + example: 'DAI' + token1: + type: 'string' + example: 'WETH' + amount0: + type: 'string' + example: '10' + amount1: + type: 'string' + example: '10' + lowerPrice: + type: 'number' + example: 1 + upperPrice: + type: number + example: 5 + maxFeePerGas: + type: number + maxPriorityFeePerGas: + type: number + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswapLP' + + LiquidityAddResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'token0' + - 'token1' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + - 'nonce' + properties: + network: + type: 'string' + example: 'kovan' + timestamp: + type: 'integer' + example: 1636368085740 + token0: + type: 'string' + example: 'DAI' + token1: + type: 'string' + example: 'WETH' + gasPrice: + type: 'string' + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'string' + gasCost: + type: 'string' + nonce: + type: 'string' + txHash: + type: 'string' + example: '0x0000000000000000000000000000000000000000' + + LiquidityRemoveRequest: + type: 'object' + required: + - 'address' + - 'tokenId' + properties: + address: + type: 'string' + example: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D' + tokenId: + type: 'number' + example: 12 + maxFeePerGas: + type: number + maxPriorityFeePerGas: + type: number + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswapLP' + + LiquidityRemoveResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'tokenId' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + - 'nonce' + properties: + network: + type: 'string' + example: 'kovan' + timestamp: + type: 'integer' + example: 1636368085740 + tokenId: + type: 'number' + example: 12 + gasPrice: + type: 'string' + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'string' + gasCost: + type: 'string' + nonce: + type: 'string' + txHash: + type: 'string' + example: '0x0000000000000000000000000000000000000000' + + LiquidityCollectRequest: + type: 'object' + required: + - 'address' + - 'tokenId' + properties: + address: + type: 'string' + example: '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D' + tokenId: + type: 'number' + example: 12 + maxFeePerGas: + type: number + maxPriorityFeePerGas: + type: number + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswapLP' + + LiquidityCollectResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'tokenId' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + - 'nonce' + properties: + network: + type: 'string' + example: 'kovan' + timestamp: + type: 'integer' + example: 1636368085740 + tokenId: + type: 'number' + example: 12 + gasPrice: + type: 'string' + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'string' + gasCost: + type: 'string' + nonce: + type: 'string' + txHash: + type: 'string' + example: '0x0000000000000000000000000000000000000000' + + LiquidityPositionRequest: + type: 'object' + required: + - 'tokenId' + properties: + tokenId: + type: 'number' + example: 12 + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswapLP' + + LiquidityPositionResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'tokenId' + - 'token0' + - 'token1' + - 'fee' + - 'lowerPrice' + - 'upperPrice' + - 'amount0' + - 'amount1' + - 'unclaimedToken0' + - 'unclaimedToken1' + properties: + network: + type: 'string' + example: 'kovan' + timestamp: + type: 'integer' + example: 1636368085740 + tokenId: + type: 'number' + example: 12 + token0: + type: 'string' + example: 'DAI' + token1: + type: 'string' + example: 'WETH' + fee: + type: 'string' + example: 'LOW' + lowerPrice: + type: 'string' + example: '1' + upperPrice: + type: 'string' + example: '5' + amount0: + type: 'string' + example: '1' + amount1: + type: 'string' + example: '1' + unclaimedToken0: + type: 'string' + example: '2' + unclaimedToken1: + type: 'string' + example: '2' + + LiquidityPriceRequest: + type: 'object' + required: + - 'token0' + - 'token1' + - 'fee' + - 'period' + - 'interval' + properties: + token0: + type: 'string' + example: 'DAI' + token1: + type: 'string' + example: 'WETH' + fee: + type: 'string' + example: 'LOW' + period: + type: 'number' + example: 60 + interval: + type: 'number' + example: 5 + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'kovan' + connector: + type: 'string' + example: 'uniswapLP' + + LiquidityPriceResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'token0' + - 'token1' + - 'fee' + - 'period' + - 'interval' + properties: + network: + type: 'string' + example: 'kovan' + timestamp: + type: 'integer' + example: 1636368085740 + token0: + type: 'string' + example: 'DAI' + token1: + type: 'string' + example: 'WETH' + fee: + type: 'string' + example: 'LOW' + period: + type: 'number' + example: 60 + interval: + type: 'number' + example: 5 + prices: + type: 'object' + example: ['1', '2', '3'] + + + PerpPairsRequest: + type: 'object' + required: + - 'chain' + - 'network' + - 'connector' + properties: + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'optimism' + connector: + type: 'string' + example: 'perp' + + PerpPairsResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'pairs' + properties: + network: + type: 'string' + example: 'optimism' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 1 + pairs: + type: 'array' + items: 'string' + example: ['AAVEUSD', 'PERPUSD', 'BTCUSD'] + + PerpPriceRequest: + type: 'object' + required: + - 'chain' + - 'network' + - 'connector' + - 'base' + - 'quote' + properties: + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'optimism' + connector: + type: 'string' + example: 'perp' + base: + type: 'string' + example: 'AAVE' + quote: + type: 'string' + example: 'USD' + + PerpPriceResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'quote' + - 'markPrice' + - 'indexPrice' + - 'indexTwapPrice' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 1 + base: + type: 'string' + example: 'AAVE' + quote: + type: 'string' + example: 'USD' + markPrice: + type: 'string' + example: '0.1' + indexPrice: + type: 'string' + example: '0.2' + indexTwapPrice: + type: 'string' + example: '0.3' + + PerpStatusResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'quote' + - 'isActive' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 1 + base: + type: 'string' + example: 'AAVE' + quote: + type: 'string' + example: 'USD' + isActive: + type: 'boolean' + example: 'true' + + PerpPositionRequest: + type: 'object' + required: + - 'chain' + - 'network' + - 'connector' + - 'base' + - 'quote' + - 'address' + properties: + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'optimism' + connector: + type: 'string' + example: 'perp' + base: + type: 'string' + example: 'AAVE' + quote: + type: 'string' + example: 'USD' + address: + type: 'string' + example: '0x...' + + PerpPositionResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'quote' + - 'positionAmt' + - 'positionSide' + - 'unrealizedProfit' + - 'leverage' + - 'entryPrice' + - 'tickerSymbol' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 1 + base: + type: 'string' + example: 'AAVE' + quote: + type: 'string' + example: 'USD' + positionAmt: + type: 'string' + example: '0.1' + positionSide: + type: 'string' + example: 'LONG' + unrealizedProfit: + type: 'string' + example: '0.3' + leverage: + type: 'string' + example: '1' + entryPrice: + type: 'string' + example: '100.3' + tickerSymbol: + type: 'string' + example: 'AAVEUSD' + + PerpBalanceRequest: + type: 'object' + required: + - 'chain' + - 'network' + - 'connector' + - 'address' + properties: + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'optimism' + connector: + type: 'string' + example: 'perp' + address: + type: 'string' + example: '0x...' + + PerpBalanceResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'balance' + + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 1 + balance: + type: 'string' + example: '100' + + PerpOpenRequest: + type: 'object' + required: + - 'quote' + - 'base' + - 'amount' + - 'side' + - 'chain' + - 'network' + - 'connector' + - 'address' + properties: + quote: + type: 'string' + example: 'AAVE' + base: + type: 'string' + example: 'USD' + amount: + type: 'string' + example: '10' + side: + type: 'string' + example: 'LONG' + nonce: + type: number + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'optimism' + connector: + type: 'string' + example: 'perp' + address: + type: 'string' + example: '0x...' + + PerpOpenResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'quote' + - 'amount' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + - 'nonce' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + base: + type: 'string' + example: 'AAVE' + quote: + type: 'string' + example: 'USD' + amount: + type: 'string' + example: '10' + gasPrice: + type: 'string' + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'string' + gasCost: + type: 'string' + nonce: + type: 'string' + txHash: + type: 'string' + + PerpCloseRequest: + type: 'object' + required: + - 'quote' + - 'base' + - 'chain' + - 'network' + - 'connector' + - 'address' + properties: + quote: + type: 'string' + example: 'AAVE' + base: + type: 'string' + example: 'USD' + nonce: + type: number + chain: + type: 'string' + example: 'ethereum' + network: + type: 'string' + example: 'optimism' + connector: + type: 'string' + example: 'perp' + address: + type: 'string' + example: '0x...' + + PerpCloseResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'base' + - 'gasPrice' + - 'gasPriceToken' + - 'gasLimit' + - 'gasCost' + - 'nonce' + properties: + network: + type: 'string' + example: 'mainnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + base: + type: 'string' + example: 'AAVE' + gasPrice: + type: 'string' + gasPriceToken: + type: 'string' + example: 'ETH' + gasLimit: + type: 'string' + gasCost: + type: 'string' + nonce: + type: 'string' + txHash: + type: 'string' + + NearBalancesRequest: + type: 'object' + required: + - 'address' + - 'tokenSymbols' + - 'chain' + - 'network' + properties: + privateKey: + type: 'string' + example: 'hummingbot.near' + tokenSymbols: + type: 'array' + items: 'string' + example: ["NEAR", "ETH", "AURORA"] + chain: + type: 'string' + example: 'near' + network: + type: 'string' + example: 'testnet' + + NearBalancesResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'latency' + - 'balances' + properties: + network: + type: 'string' + example: 'testnet' + timestamp: + type: 'integer' + example: 1636368085740 + latency: + type: 'number' + example: 0.5 + balances: + type: 'object' + properties: + id: + type: 'string' + name: + type: 'string' + example: '{"NEAR": "1.5", "ETH": "100", "AURORA": "300"}' + + NearPollRequest: + type: 'object' + required: + - 'address' + - 'txHash' + - 'chain' + - 'network' + properties: + address: + type: 'string' + example: 'hummingbot.near' + txHash: + type: 'string' + example: 'HnpRwb8PjrtLjExxz4YxdiyJ2AwuRFhZHKa9WUASwyxk' + chain: + type: 'string' + example: 'near' + network: + type: 'string' + example: 'testnet' + + NearPollResponse: + type: 'object' + required: + - 'network' + - 'timestamp' + - 'currentBlock' + - 'txHash' + - 'txStatus' + - 'txReceipt' + properties: + network: + type: 'string' + example: 'testnet' + timestamp: + type: 'integer' + example: 1636368085740 + currentBlock: + type: 'integer' + example: 28243911 + txHash: + type: 'string' + example: 'HnpRwb8PjrtLjExxz4YxdiyJ2AwuRFhZHKa9WUASwyxk' + txStatus: + type: 'number' + example: 1 + txReceipt: + type: 'object' + diff --git a/docs/swagger/evm-routes.yml b/docs/swagger/evm-routes.yml new file mode 100644 index 0000000000..6e7a292af2 --- /dev/null +++ b/docs/swagger/evm-routes.yml @@ -0,0 +1,104 @@ +paths: + /evm/nonce: + post: + tags: + - 'evm' + summary: 'Get the current nonce for the provided private key' + operationId: 'nonce' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NonceRequest' + responses: + '200': + schema: + $ref: '#/definitions/NonceResponse' + + /evm/nextNonce: + post: + tags: + - 'evm' + summary: 'Get the next nonce for the provided private key' + operationId: 'nonce' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NonceRequest' + responses: + '200': + schema: + $ref: '#/definitions/NonceResponse' + + /evm/allowances: + post: + tags: + - 'evm' + summary: 'Get the ERC20 allowances for a spender on a given private key' + operationId: 'allowances' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/AllowancesRequest' + responses: + '200': + schema: + $ref: '#/definitions/AllowancesResponse' + /evm/approve: + post: + tags: + - 'evm' + summary: 'Create an ERC20 approval for a spender on an private key' + operationId: 'approve' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/ApproveRequest' + responses: + '200': + schema: + $ref: '#/definitions/ApproveResponse' + + /evm/cancel: + post: + tags: + - 'evm' + summary: 'Cancel transaction' + operationId: 'cancel' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/CancelRequest' + responses: + '200': + schema: + $ref: '#/definitions/CancelResponse' diff --git a/docs/swagger/main-routes.yml b/docs/swagger/main-routes.yml new file mode 100644 index 0000000000..181f30085f --- /dev/null +++ b/docs/swagger/main-routes.yml @@ -0,0 +1,37 @@ +paths: + /: + get: + tags: + - 'system' + summary: 'Ping the server to see that it is running' + produces: + - 'application/json' + responses: '200' + /restart: + post: + tags: + - 'system' + summary: 'Restart gateway. It is recommended to call this route after calling /config/update succesfully' + description: 'Restart the gateway server.' + operationId: 'restart' + parameters: + - in: 'body' + name: 'body' + required: false + responses: '200' + /config/update: + post: + tags: + - 'system' + summary: 'Updates Gateway configuration' + description: 'Many changes will not have an effect until the gateway server is restarted. Try calling /restart afterwards.' + operationId: 'update' + consumes: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/ConfigUpdateRequest' + responses: '200' diff --git a/docs/swagger/near-routes.yml b/docs/swagger/near-routes.yml new file mode 100644 index 0000000000..cafdd30f30 --- /dev/null +++ b/docs/swagger/near-routes.yml @@ -0,0 +1,63 @@ +paths: + /near/balances: + get: + tags: + - 'near' + summary: 'Get the balances of an Near private key' + operationId: 'near.balances' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NearBalancesRequest' + responses: + '200': + schema: + $ref: '#/definitions/NearBalancesResponse' + + /near/tokens: + get: + tags: + - 'near' + summary: 'Request token information and balance of requested token symbol' + operationId: 'near.token' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NetworkSelectionRequest' + responses: + '200': + schema: + $ref: '#/definitions/TokensResponse' + + /near/poll: + post: + tags: + - 'near' + summary: 'Poll the status of a Near transaction' + operationId: 'near.poll' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/NearPollRequest' + responses: + '200': + schema: + $ref: '#/definitions/NearPollResponse' diff --git a/docs/swagger/network-routes.yml b/docs/swagger/network-routes.yml new file mode 100644 index 0000000000..71196c060e --- /dev/null +++ b/docs/swagger/network-routes.yml @@ -0,0 +1,82 @@ +paths: + /network/config: + get: + tags: + - 'network' + summary: 'Get every gateway configuration option' + produces: + - 'application/json' + responses: '200' + /network/status: + get: + tags: + - 'network' + summary: 'Returns a list of the currently connected networks' + produces: + - 'application/json' + responses: '200' + /network/poll: + post: + tags: + - 'network' + summary: 'Poll the status of a transaction' + operationId: 'poll' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/PollRequest' + responses: + '200': + schema: + $ref: '#/definitions/PollResponse' + /network/balances: + post: + tags: + - 'network' + summary: 'Get the balances of a private key' + operationId: 'balances' + consumes: + - 'application/json' + produces: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/BalancesRequest' + responses: + '200': + schema: + $ref: '#/definitions/BalancesResponse' + /network/tokens: + get: + tags: + - 'network' + summary: 'Returns a list of tokens available on the specified network' + produces: + - 'application/json' + parameters: + - in: 'query' + name: 'chain' + required: true + type: 'string' + example: 'ethereum' + - in: 'query' + name: 'network' + required: true + type: 'string' + example: 'kovan' + - in: 'query' + name: 'tokenSymbols' + required: false + responses: + '200': + schema: + $ref: '#/definitions/TokensResponse' diff --git a/docs/swagger/swagger.yml b/docs/swagger/swagger.yml new file mode 100644 index 0000000000..09ad5d067d --- /dev/null +++ b/docs/swagger/swagger.yml @@ -0,0 +1,40 @@ +swagger: '2.0' + +info: + description: 'Gateway allows clients to interoperate with blockchains and DeFi protocols via a REST API. This allows for a language agnostic way to use official SDKs for blockchains.' + version: '1.0.0' + title: 'gateway' + contact: + email: 'dev@hummingbot.io' + license: + name: 'Apache 2.0' + url: 'http://www.apache.org/licenses/LICENSE-2.0.html' + +host: 'localhost:15888' + +tags: + - name: 'system' + description: 'Get information about the currently running Gateway program' + - name: 'network' + description: 'Get information about specific networks' + - name: 'wallet' + description: 'Manage private keys available for use in Gateway' + - name: 'amm' + description: 'Interact with AMM decentralized exchanges' + - name: 'clob' + description: 'Interact with CLOB decentralized exchanges' + - name: 'amm/liquidity' + description: 'Interact with AMM LP contracts' + - name: 'evm' + description: 'Interact with EVM based blockchains' + - name: 'cosmos' + description: 'Interact with the Cosmos blockchain' + - name: 'near' + description: 'Interact with the Near blockchain' + +schemes: + - 'http' + +externalDocs: + description: 'Find out more about gateway' + url: 'https://github.com/hummingbot/hummingbot' diff --git a/docs/swagger/wallet-routes.yml b/docs/swagger/wallet-routes.yml new file mode 100644 index 0000000000..795a19cb75 --- /dev/null +++ b/docs/swagger/wallet-routes.yml @@ -0,0 +1,46 @@ +paths: + /wallet: + get: + tags: + - 'wallet' + summary: 'Get list of all added wallets and chains' + operationId: 'get' + produces: + - 'application/json' + responses: + '200': + description: 'Wallet list' + schema: + $ref: '#/definitions/GetWalletResponse' + + /wallet/add: + post: + tags: + - 'wallet' + summary: 'Add wallet to gateway' + operationId: 'add' + consumes: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/AddWalletRequest' + responses: '200' + + /wallet/remove: + delete: + tags: + - 'wallet' + summary: 'Removes a wallet from gateway' + operationId: 'delete' + consumes: + - 'application/json' + parameters: + - in: 'body' + name: 'body' + required: true + schema: + $ref: '#/definitions/RemoveWalletRequest' + responses: '200' diff --git a/docs/testing.md b/docs/testing.md new file mode 100644 index 0000000000..d3068e380a --- /dev/null +++ b/docs/testing.md @@ -0,0 +1,196 @@ +# Unit tests for gateway + +Gateway is written in [TypeScript](https://www.typescriptlang.org/) for a NodeJS environment. +The majority of block chain SDKs we use have type annotations for TypeScript so they integrate +smoothly into this project. + +Our main tool for unit testing is [jest](https://jestjs.io). Our configurations +for jest are located [here](../jest.config.js). + +We use [prettier](https://prettier.io/) for formatting. Configuration file +[here](../.prettierrc). + +We use [ESLint](https://eslint.org/) for linting. Configuration file +[here](../.eslintrc.js). + +## Running the unit tests + +We primarily use `yarn` for development, but `npm` should work as well. + +First install dependencies: + +``` +yarn install --frozen-lockfile +``` + +Then build the gateway package: + +``` +yarn build +``` + +Then you can run the unit tests: + +``` +yarn test:unit +``` + +You do not actually need to build before running, but if you have any compiler +errors, the unit tests will crash, so in practice if you make changes, it is +best to run build first. + +## Run individual unit test file + +`yarn test:unit` runs all of the tests. Alternatively, you can run the unit tests +from a single file with `yarn jest path/to/test`. For example: + +``` +yarn jest test/chains/ethereum/ethereum.controller.test.ts +``` + +## Test coverage + +Our github repository has requirements for test coverage. These requirements may +change, so specifically look at our [workflow file](../../.github/workflows/workflow.yml) +and find the section for gateway unit tests. If you are interested in merging a PR, +you will need to make sure unit test coverage meets the requirements. + +To see the current coverage, run the following: + +``` +yarn test:cov +``` + +This will produce a table with absolute numbers, percentages and line numbers that +are not being tested. These are helpful for knowing where to increment tests. + +### Coverage areas + +When you run test coverage, you will see a table of information with the following +concepts: + +function coverage: the percentage of declared functions that are tested (this +ignores details of how much internal function code is run). + +branch coverage: percentage of decision conditions like loop, if/else, while that +are called. + +statement coverage: the percentage of executable statements this includes function calls, +assignment, branches that are called + +line coverage: the percentage of lines of declared code that are called. + +uncovered lines: the line numbers of code that is not called + + +## Jest: describe, it, before, after + +The main tools from Jest we use are `describe` and `it`. + +`describe` is a collection of one or more related unit tests. For example, +the expected result of adding one to different numbers. You should include a +description. + + +`it` is an individual unit test with a description. + +```TypeScript +describe('addition', () => { + it('1+1=2', () => { + expect(1+1).toEqual(2); + }); + + it('1+2=3', () => { + expect(1+2).toEqual(3); + }); +}); + +``` + +Some useful tools to reduce repetition are: + +- `beforeAll`: run code before any test in the file is run. +- `afterAll`: run code after all the tests in a file are run. +- `beforeEach`: run code before every test in scope. +- `afterEach`: run code after every test in scope. + +## Testing for Failure + +Not only do we want to test that things work properly, we also want to +test when we expect things to fail. Consider adding expected error throwing +to your unit test code. + +## Network Calls and Mock Values + +Our philosophy for unit testing is to avoid any outside network calls. Unit tests +requiring calls to APIs may be fragile and slow. Instead we try to mock the values that +would be returned from an API. This will allow us to test the logic of the code, without +worrying about the value returned from a network call. + +### patch and unpatch + +We designed our own patching system in [patch.ts](../test/services/patch.ts) since we +did not find a good tool for TypeScript or JavaScript. The main idea is to mock values +and function return values on objects, namespaces and modules, and remove these changes +after a test. + +Here is an example: + +```TypeScript + patch(eth, 'getWallet', () => { + return { + address: '0...', + }; + }); +``` + +Normally `eth.getWallet` would take a private key and return a `Wallet` object +with some information from the Ethereum block chain. This would require a network +call. Instead, we only need the address. + +Generally you will find in our unit tests the following code: + +```TypeScript + afterEach(() => { + unpatch(); + }); +``` + +This means after each test `it`, remove any applied patch. This way there will not +be unexpected patches applied in other tests. + +Please keep in mind that [patch.ts](../test/services/patch.ts) was only designed +for our current use cases, and may not support patching all TypeScript data types. + +## Testing Non-Network I/0, Files, etc. + +Other than network calls, we generally allow system I/O for testing, for example: +[local-storage.test.ts](../test/services/local-storage.test.s) tests how we use leveldb, +and [config-manager-v2.test.ts](../test/services/config-manager-v2.test.s) creates +temporary files. The general rule of thumb is to store files with `mkdtemp` and +remove them when they are no longer needed. + +# Manual Testing + +We also do a lot of manual testing of gateway to ensure API endpoints behave +correctly. It is best to start doing these tests on test networks to ensure +you do not lose valuable cryptocurrencies. + +The main source of testing is a [curl file](../manual-tests/curl.sh). This outlines +a number of curl commands that are paired with JSON request bodies stored in files. +By storing them in files, they are easier to edit. + +Currently the following env varables are expected, depending on the route: + +```bash +AVALANCHE_ADDRESSS='0000...' +ETH_ADDRESS='000...' +GATEWAY_CERT='/absolute/path/to/certs/client_cert.pem' +GATEWAY_KEY='/absolut/path/to/certs/client_key.pem' +``` + +You may also replace these values with hard coded ones if you like. Please be +careful when storing private keys in the environment or in a file. Never commit +these values to a git repository. + +If you add new routes to gateway, add a corresponding curl call in [curl.sh](../manual-tests/curl.sh). diff --git a/hooks/README.md b/hooks/README.md new file mode 100644 index 0000000000..3f4e8340dc --- /dev/null +++ b/hooks/README.md @@ -0,0 +1,5 @@ +# Docker Autobuild Hooks + +This folder containers hooks for docker autobuild. + +[Hummingbot builds](https://hub.docker.com/r/coinalpha/hummingbot/builds) \ No newline at end of file diff --git a/hooks/build b/hooks/build new file mode 100644 index 0000000000..165ae1ded3 --- /dev/null +++ b/hooks/build @@ -0,0 +1,7 @@ +#!/usr/bin/env sh + +# Get the build time stamp +BUILD_DATE=$(date -u +"%Y-%m-%dT%H:%M:%SZ") +# IMAGE_NAME=gateway-v2-image + +docker build --build-arg COMMIT=$GIT_TAG --build-arg BRANCH=$SOURCE_BRANCH --build-arg BUILD_DATE=$BUILD_DATE -t $IMAGE_NAME -f Dockerfile . \ No newline at end of file diff --git a/jest.config.js b/jest.config.js new file mode 100644 index 0000000000..06dc1a0f89 --- /dev/null +++ b/jest.config.js @@ -0,0 +1,39 @@ +module.exports = { + preset: 'ts-jest', + testEnvironment: 'node', + forceExit: true, + coveragePathIgnorePatterns: [ + 'src/app.ts', + 'src/https.ts', + 'src/paths.ts', + 'src/services/ethereum-base.ts', + 'src/services/cosmos-base.ts', + 'src/services/telemetry-transport.ts', + 'src/chains/cronos/cronos.ts', + 'src/chains/binance-smart-chain/binance-smart-chain.ts', + 'src/chains/ethereum/ethereum.ts', + 'src/chains/avalanche/avalanche.ts', + 'src/chains/avalanche/pangolin/pangolin.ts', + 'src/chains/cosmos/cosmos.ts', + 'src/chains/near/near.ts', + 'src/chains/near/near.base.ts', + 'src/connectors/uniswap/uniswap.config.ts', + 'src/connectors/uniswap/uniswap.ts', + 'src/connectors/uniswap/uniswap.lp.helper.ts', + 'src/connectors/defikingdoms/defikingdoms.ts', + 'src/connectors/defira/defira.ts', + 'src/connectors/openocean/openocean.ts', + 'src/connectors/pangolin/pangolin.ts', + 'src/connectors/quickswap/quickswap.ts', + 'src/connectors/sushiswap/sushiswap.ts', + 'src/connectors/traderjoe/traderjoe.ts', + 'src/network/network.controllers.ts', + 'src/services/ethereum-base.ts', + 'src/services/telemetry-transport.ts', + 'test/*', + ], + modulePathIgnorePatterns: ['/dist/'], + setupFilesAfterEnv: ['/test/setupTests.js'], + globalSetup: '/test/setup.ts', + globalTeardown: '/test/teardown.ts', +}; diff --git a/manual-tests/curl.sh b/manual-tests/curl.sh new file mode 100644 index 0000000000..d1a0fe6ac0 --- /dev/null +++ b/manual-tests/curl.sh @@ -0,0 +1,205 @@ +# you need to install to programs: curl and envsubst + +# You must the following values in your command line +# export ETH_ADDRESS='' +# export AVALANCHE_ADDRESS='' +# export NEAR_ADDRESS='/dev/null 2>&1 ; pwd -P )/../conf" + +TEMPLATE_DIR="$( cd -- "$(dirname "$0")" >/dev/null 2>&1 ; pwd -P )/../src/templates" + +echo "HOST_CONF_PATH=$HOST_CONF_PATH" + +mkdir $HOST_CONF_PATH + +# copy the following files + +cp $TEMPLATE_DIR/**.yml $HOST_CONF_PATH +echo "All configuration files have been created." \ No newline at end of file diff --git a/src/@types/buffer-layout.d.ts b/src/@types/buffer-layout.d.ts new file mode 100644 index 0000000000..69ceddae11 --- /dev/null +++ b/src/@types/buffer-layout.d.ts @@ -0,0 +1,8 @@ +declare module 'buffer-layout' { + export class Blob {} + // eslint-disable-next-line @typescript-eslint/no-unused-vars + export class Layout {} + export class Structure {} + export class UInt {} + export class Union {} +} diff --git a/src/@types/cycle.d.ts b/src/@types/cycle.d.ts new file mode 100644 index 0000000000..cb407def96 --- /dev/null +++ b/src/@types/cycle.d.ts @@ -0,0 +1,3 @@ +declare module 'cycle' { + export const cycle: any; +} diff --git a/src/amm/amm.controllers.ts b/src/amm/amm.controllers.ts new file mode 100644 index 0000000000..dd9ab9b52b --- /dev/null +++ b/src/amm/amm.controllers.ts @@ -0,0 +1,252 @@ +import { + EstimateGasResponse, + PerpAvailablePairsResponse, + PerpCreateTakerRequest, + PerpCreateTakerResponse, + PerpMarketRequest, + PerpMarketResponse, + PerpPositionRequest, + PerpPositionResponse, + PerpPricesResponse, + PriceRequest, + PriceResponse, + TradeRequest, + TradeResponse, + AddLiquidityRequest, + AddLiquidityResponse, + RemoveLiquidityRequest, + RemoveLiquidityResponse, + CollectEarnedFeesRequest, + PositionRequest, + PositionResponse, + PoolPriceRequest, + PoolPriceResponse, + PerpBalanceRequest, + PerpBalanceResponse, +} from './amm.requests'; +import { + price as uniswapPrice, + trade as uniswapTrade, + addLiquidity as uniswapV3AddLiquidity, + removeLiquidity as uniswapV3RemoveLiquidity, + collectEarnedFees as uniswapV3CollectEarnedFees, + positionInfo as uniswapV3PositionInfo, + poolPrice as uniswapV3PoolPrice, + estimateGas as uniswapEstimateGas, +} from '../connectors/uniswap/uniswap.controllers'; +import { + price as refPrice, + trade as refTrade, + estimateGas as refEstimateGas, +} from '../connectors/ref/ref.controllers'; +import { + getPriceData as perpPriceData, + createTakerOrder, + estimateGas as perpEstimateGas, + getPosition, + getAvailablePairs, + checkMarketStatus, + getAccountValue, +} from '../connectors/perp/perp.controllers'; +import { getChain, getConnector } from '../services/connection-manager'; +import { + Ethereumish, + Nearish, + NetworkSelectionRequest, + Perpish, + RefAMMish, + Uniswapish, + UniswapLPish, +} from '../services/common-interfaces'; + +export async function price(req: PriceRequest): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Uniswapish | RefAMMish = await getConnector< + Uniswapish | RefAMMish + >(req.chain, req.network, req.connector); + + // we currently use the presence of routerAbi to distinguish Uniswapish from RefAMMish + if ('routerAbi' in connector) { + return uniswapPrice(chain, connector, req); + } else { + return refPrice(chain, connector, req); + } +} + +export async function trade(req: TradeRequest): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Uniswapish | RefAMMish = await getConnector< + Uniswapish | RefAMMish + >(req.chain, req.network, req.connector); + + // we currently use the presence of routerAbi to distinguish Uniswapish from RefAMMish + if ('routerAbi' in connector) { + return uniswapTrade(chain, connector, req); + } else { + return refTrade(chain, connector, req); + } +} + +export async function addLiquidity( + req: AddLiquidityRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: UniswapLPish = await getConnector( + req.chain, + req.network, + req.connector + ); + + return uniswapV3AddLiquidity(chain, connector, req); +} + +export async function reduceLiquidity( + req: RemoveLiquidityRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: UniswapLPish = await getConnector( + req.chain, + req.network, + req.connector + ); + + return uniswapV3RemoveLiquidity(chain, connector, req); +} + +export async function collectFees( + req: CollectEarnedFeesRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: UniswapLPish = await getConnector( + req.chain, + req.network, + req.connector + ); + return uniswapV3CollectEarnedFees(chain, connector, req); +} + +export async function positionInfo( + req: PositionRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: UniswapLPish = await getConnector( + req.chain, + req.network, + req.connector + ); + return uniswapV3PositionInfo(chain, connector, req); +} + +export async function poolPrice( + req: PoolPriceRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: UniswapLPish = await getConnector( + req.chain, + req.network, + req.connector + ); + return uniswapV3PoolPrice(chain, connector, req); +} + +export async function estimateGas( + req: NetworkSelectionRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Uniswapish | RefAMMish = await getConnector< + Uniswapish | RefAMMish + >(req.chain, req.network, req.connector); + + // we currently use the presence of routerAbi to distinguish Uniswapish from RefAMMish + if ('routerAbi' in connector) { + return uniswapEstimateGas(chain, connector); + } else { + return refEstimateGas(chain, connector); + } +} + +// perp +export async function perpMarketPrices( + req: PriceRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = await getConnector( + req.chain, + req.network, + req.connector + ); + return perpPriceData(chain, connector, req); +} + +export async function perpOrder( + req: PerpCreateTakerRequest, + isOpen: boolean +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = await getConnector( + req.chain, + req.network, + req.connector, + req.address + ); + return createTakerOrder(chain, connector, req, isOpen); +} + +export async function perpPosition( + req: PerpPositionRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = await getConnector( + req.chain, + req.network, + req.connector, + req.address + ); + return getPosition(chain, connector, req); +} + +export async function perpBalance( + req: PerpBalanceRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = ( + await getConnector(req.chain, req.network, req.connector, req.address) + ); + return getAccountValue(chain, connector); +} + +export async function perpPairs( + req: NetworkSelectionRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = await getConnector( + req.chain, + req.network, + req.connector + ); + return getAvailablePairs(chain, connector); +} + +export async function getMarketStatus( + req: PerpMarketRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = await getConnector( + req.chain, + req.network, + req.connector + ); + return checkMarketStatus(chain, connector, req); +} + +export async function estimatePerpGas( + req: NetworkSelectionRequest +): Promise { + const chain = await getChain(req.chain, req.network); + const connector: Perpish = await getConnector( + req.chain, + req.network, + req.connector + ); + return perpEstimateGas(chain, connector); +} diff --git a/src/amm/amm.requests.ts b/src/amm/amm.requests.ts new file mode 100644 index 0000000000..d22d2b5e24 --- /dev/null +++ b/src/amm/amm.requests.ts @@ -0,0 +1,238 @@ +import { PerpPosition } from '../connectors/perp/perp'; +import { + NetworkSelectionRequest, + PositionInfo as LPPositionInfo, +} from '../services/common-interfaces'; +export type Side = 'BUY' | 'SELL'; +export type PerpSide = 'LONG' | 'SHORT'; + +export interface PriceRequest extends NetworkSelectionRequest { + quote: string; + base: string; + amount: string; + side: Side; + allowedSlippage?: string; +} + +export interface PriceResponse { + base: string; + quote: string; + amount: string; + rawAmount: string; + expectedAmount: string; + price: string; + network: string; + timestamp: number; + latency: number; + gasPrice: number; + gasPriceToken: string; + gasLimit: number; + gasCost: string; +} + +export interface PoolPriceRequest extends NetworkSelectionRequest { + token0: string; + token1: string; + fee: string; + period: number; + interval: number; +} + +export interface PoolPriceResponse { + token0: string; + token1: string; + fee: string; + period: number; + interval: number; + prices: string[]; + network: string; + timestamp: number; + latency: number; +} + +export interface TradeRequest extends NetworkSelectionRequest { + quote: string; + base: string; + amount: string; + address: string; + side: Side; + limitPrice?: string; // integer as string + nonce?: number; + maxFeePerGas?: string; + maxPriorityFeePerGas?: string; + allowedSlippage?: string; +} + +export interface TradeResponse { + network: string; + timestamp: number; + latency: number; + base: string; + quote: string; + amount: string; + rawAmount: string; + expectedIn?: string; + expectedOut?: string; + price: string; + gasPrice: number; + gasPriceToken: string; + gasLimit: number; + gasCost: string; + nonce?: number; + txHash: string | any | undefined; +} + +export interface AddLiquidityRequest extends NetworkSelectionRequest { + address: string; + token0: string; + token1: string; + amount0: string; + amount1: string; + fee: string; + lowerPrice: string; // integer as string + upperPrice: string; // integer as string + tokenId?: number; + nonce?: number; + maxFeePerGas?: string; + maxPriorityFeePerGas?: string; +} + +export interface AddLiquidityResponse { + network: string; + timestamp: number; + latency: number; + token0: string; + token1: string; + fee: string; + tokenId: number; + gasPrice: number; + gasPriceToken: string; + gasLimit: number; + gasCost: string; + nonce: number; + txHash: string | undefined; +} + +export interface CollectEarnedFeesRequest extends NetworkSelectionRequest { + address: string; + tokenId: number; + nonce?: number; + maxFeePerGas?: string; + maxPriorityFeePerGas?: string; +} + +export interface RemoveLiquidityRequest extends CollectEarnedFeesRequest { + decreasePercent?: number; +} + +export interface RemoveLiquidityResponse { + network: string; + timestamp: number; + latency: number; + tokenId: number; + gasPrice: number; + gasPriceToken: string; + gasLimit: number; + gasCost: string; + nonce: number; + txHash: string | undefined; +} + +export interface PositionRequest extends NetworkSelectionRequest { + tokenId: number; +} + +export interface PositionResponse extends LPPositionInfo { + network: string; + timestamp: number; + latency: number; +} + +export interface EstimateGasResponse { + network: string; + timestamp: number; + gasPrice: number; + gasPriceToken: string; + gasLimit: number; + gasCost: string; +} + +export interface PerpPricesResponse { + base: string; + quote: string; + network: string; + timestamp: number; + latency: number; + markPrice: string; + indexPrice: string; + indexTwapPrice: string; +} + +export interface PerpMarketRequest extends NetworkSelectionRequest { + quote: string; + base: string; +} + +export interface PerpMarketResponse { + network: string; + timestamp: number; + latency: number; + base: string; + quote: string; + isActive: boolean; +} + +export interface PerpBalanceRequest extends NetworkSelectionRequest { + address: string; +} + +export interface PerpBalanceResponse { + network: string; + timestamp: number; + latency: number; + balance: string; +} + +export interface PerpPositionRequest extends PerpMarketRequest { + address: string; +} + +export interface PerpPositionResponse extends PerpPosition { + network: string; + timestamp: number; + latency: number; + base: string; + quote: string; +} + +export interface PerpAvailablePairsResponse { + network: string; + timestamp: number; + latency: number; + pairs: string[]; +} + +export interface PerpCreateTakerRequest extends NetworkSelectionRequest { + quote: string; + base: string; + address: string; + amount?: string; + side?: PerpSide; + allowedSlippage?: string; + nonce?: number; +} + +export interface PerpCreateTakerResponse { + network: string; + timestamp: number; + latency: number; + base: string; + quote: string; + amount: string; + gasPrice: number; + gasPriceToken: string; + gasLimit: number; + gasCost: string; + nonce: number; + txHash: string | undefined; +} diff --git a/src/amm/amm.routes.ts b/src/amm/amm.routes.ts new file mode 100644 index 0000000000..702f0b8354 --- /dev/null +++ b/src/amm/amm.routes.ts @@ -0,0 +1,284 @@ +/* eslint-disable no-inner-declarations */ +/* eslint-disable @typescript-eslint/ban-types */ +import { Router, Request, Response } from 'express'; +import { asyncHandler } from '../services/error-handler'; +import { + price, + trade, + estimatePerpGas, + perpMarketPrices, + perpOrder, + getMarketStatus, + perpPosition, + perpPairs, + positionInfo, + addLiquidity, + reduceLiquidity, + collectFees, + poolPrice, + estimateGas, + perpBalance, +} from './amm.controllers'; +import { + EstimateGasResponse, + PerpAvailablePairsResponse, + PerpCreateTakerRequest, + PerpCreateTakerResponse, + PerpMarketRequest, + PerpMarketResponse, + PerpPositionRequest, + PerpPositionResponse, + PerpPricesResponse, + PriceRequest, + PriceResponse, + TradeRequest, + TradeResponse, + AddLiquidityRequest, + AddLiquidityResponse, + RemoveLiquidityRequest, + RemoveLiquidityResponse, + CollectEarnedFeesRequest, + PositionRequest, + PositionResponse, + PoolPriceRequest, + PoolPriceResponse, + PerpBalanceRequest, + PerpBalanceResponse, +} from './amm.requests'; +import { + validateEstimateGasRequest, + validatePerpCloseTradeRequest, + validatePerpMarketStatusRequest, + validatePerpOpenTradeRequest, + validatePerpPairsRequest, + validatePerpPositionRequest, + validatePriceRequest, + validateTradeRequest, + validateAddLiquidityRequest, + validateRemoveLiquidityRequest, + validateCollectFeeRequest, + validatePositionRequest, + validatePoolPriceRequest, + validatePerpBalanceRequest, +} from './amm.validators'; +import { NetworkSelectionRequest } from '../services/common-interfaces'; + +export namespace AmmRoutes { + export const router = Router(); + + router.post( + '/price', + asyncHandler( + async ( + req: Request<{}, {}, PriceRequest>, + res: Response + ) => { + validatePriceRequest(req.body); + res.status(200).json(await price(req.body)); + } + ) + ); + + router.post( + '/trade', + asyncHandler( + async ( + req: Request<{}, {}, TradeRequest>, + res: Response + ) => { + validateTradeRequest(req.body); + res.status(200).json(await trade(req.body)); + } + ) + ); + + router.post( + '/estimateGas', + asyncHandler( + async ( + req: Request<{}, {}, NetworkSelectionRequest>, + res: Response + ) => { + validateEstimateGasRequest(req.body); + res.status(200).json(await estimateGas(req.body)); + } + ) + ); +} + +export namespace AmmLiquidityRoutes { + export const router = Router(); + + router.post( + '/position', + asyncHandler( + async ( + req: Request<{}, {}, PositionRequest>, + res: Response + ) => { + validatePositionRequest(req.body); + res.status(200).json(await positionInfo(req.body)); + } + ) + ); + + router.post( + '/add', + asyncHandler( + async ( + req: Request<{}, {}, AddLiquidityRequest>, + res: Response + ) => { + validateAddLiquidityRequest(req.body); + res.status(200).json(await addLiquidity(req.body)); + } + ) + ); + + router.post( + '/remove', + asyncHandler( + async ( + req: Request<{}, {}, RemoveLiquidityRequest>, + res: Response + ) => { + validateRemoveLiquidityRequest(req.body); + res.status(200).json(await reduceLiquidity(req.body)); + } + ) + ); + + router.post( + '/collect_fees', + asyncHandler( + async ( + req: Request<{}, {}, CollectEarnedFeesRequest>, + res: Response + ) => { + validateCollectFeeRequest(req.body); + res.status(200).json(await collectFees(req.body)); + } + ) + ); + + router.post( + '/price', + asyncHandler( + async ( + req: Request<{}, {}, PoolPriceRequest>, + res: Response + ) => { + validatePoolPriceRequest(req.body); + res.status(200).json(await poolPrice(req.body)); + } + ) + ); +} + +export namespace PerpAmmRoutes { + export const router = Router(); + + router.post( + '/market-prices', + asyncHandler( + async ( + req: Request<{}, {}, PriceRequest>, + res: Response + ) => { + validatePerpMarketStatusRequest(req.body); + res.status(200).json(await perpMarketPrices(req.body)); + } + ) + ); + + router.post( + '/market-status', + asyncHandler( + async ( + req: Request<{}, {}, PerpMarketRequest>, + res: Response + ) => { + validatePerpMarketStatusRequest(req.body); + res.status(200).json(await getMarketStatus(req.body)); + } + ) + ); + + router.post( + '/pairs', + asyncHandler( + async ( + req: Request<{}, {}, NetworkSelectionRequest>, + res: Response + ) => { + validatePerpPairsRequest(req.body); + res.status(200).json(await perpPairs(req.body)); + } + ) + ); + + router.post( + '/position', + asyncHandler( + async ( + req: Request<{}, {}, PerpPositionRequest>, + res: Response + ) => { + validatePerpPositionRequest(req.body); + res.status(200).json(await perpPosition(req.body)); + } + ) + ); + + router.post( + '/balance', + asyncHandler( + async ( + req: Request<{}, {}, PerpBalanceRequest>, + res: Response + ) => { + validatePerpBalanceRequest(req.body); + res.status(200).json(await perpBalance(req.body)); + } + ) + ); + + router.post( + '/open', + asyncHandler( + async ( + req: Request<{}, {}, PerpCreateTakerRequest>, + res: Response + ) => { + validatePerpOpenTradeRequest(req.body); + res.status(200).json(await perpOrder(req.body, true)); + } + ) + ); + + router.post( + '/close', + asyncHandler( + async ( + req: Request<{}, {}, PerpCreateTakerRequest>, + res: Response + ) => { + validatePerpCloseTradeRequest(req.body); + res.status(200).json(await perpOrder(req.body, false)); + } + ) + ); + + router.post( + '/estimateGas', + asyncHandler( + async ( + req: Request<{}, {}, NetworkSelectionRequest>, + res: Response + ) => { + validateEstimateGasRequest(req.body); + res.status(200).json(await estimatePerpGas(req.body)); + } + ) + ); +} diff --git a/src/amm/amm.validators.ts b/src/amm/amm.validators.ts new file mode 100644 index 0000000000..329b5609c2 --- /dev/null +++ b/src/amm/amm.validators.ts @@ -0,0 +1,339 @@ +import { + isFloatString, + isFractionString, + mkValidator, + mkRequestValidator, + RequestValidator, + Validator, +} from '../services/validators'; + +import { + validateChain, + validateNetwork, + validateNonce, + validateAddress, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, +} from '../chains/ethereum/ethereum.validators'; + +import { FeeAmount } from '@uniswap/v3-sdk'; + +export const invalidConnectorError: string = + 'The connector param is not a string.'; + +export const invalidQuoteError: string = 'The quote param is not a string.'; + +export const invalidBaseError: string = 'The base param is not a string.'; + +export const invalidTokenError: string = + 'One of the token params is not a string.'; + +export const invalidAmountError: string = + 'The amount param must be a string of a non-negative integer.'; + +export const invalidSideError: string = + 'The side param must be a string of "BUY" or "SELL".'; + +export const invalidPerpSideError: string = + 'The side param must be a string of "LONG" or "SHORT".'; + +export const invalidFeeTier: string = 'Incorrect fee tier'; + +export const invalidLimitPriceError: string = + 'The limitPrice param may be null or a string of a float or integer number.'; + +export const invalidLPPriceError: string = + 'One of the LP prices may be null or a string of a float or integer number.'; + +export const invalidTokenIdError: string = + 'If tokenId is included it must be a non-negative integer.'; + +export const invalidTimeError: string = + 'Period or interval has to be a non-negative integer.'; + +export const invalidDecreasePercentError: string = + 'If decreasePercent is included it must be a non-negative integer.'; + +export const invalidAllowedSlippageError: string = + 'The allowedSlippage param may be null or a string of a fraction.'; + +export const validateConnector: Validator = mkValidator( + 'connector', + invalidConnectorError, + (val) => typeof val === 'string' +); + +export const validateQuote: Validator = mkValidator( + 'quote', + invalidQuoteError, + (val) => typeof val === 'string' +); + +export const validateBase: Validator = mkValidator( + 'base', + invalidBaseError, + (val) => typeof val === 'string' +); + +export const validateToken0: Validator = mkValidator( + 'token0', + invalidTokenError, + (val) => typeof val === 'string' +); + +export const validateToken1: Validator = mkValidator( + 'token1', + invalidTokenError, + (val) => typeof val === 'string' +); + +export const validateAmount: Validator = mkValidator( + 'amount', + invalidAmountError, + (val) => typeof val === 'string' && isFloatString(val) +); + +export const validateAmount0: Validator = mkValidator( + 'amount0', + invalidAmountError, + (val) => typeof val === 'string' +); + +export const validateAmount1: Validator = mkValidator( + 'amount1', + invalidAmountError, + (val) => typeof val === 'string' +); + +export const validateSide: Validator = mkValidator( + 'side', + invalidSideError, + (val) => typeof val === 'string' && (val === 'BUY' || val === 'SELL') +); + +export const validatePerpSide: Validator = mkValidator( + 'side', + invalidPerpSideError, + (val) => typeof val === 'string' && (val === 'LONG' || val === 'SHORT') +); + +export const validateFee: Validator = mkValidator( + 'fee', + invalidFeeTier, + (val) => + typeof val === 'string' && + Object.keys(FeeAmount).includes(val.toUpperCase()) +); + +export const validateLowerPrice: Validator = mkValidator( + 'lowerPrice', + invalidLPPriceError, + (val) => typeof val === 'string' && isFloatString(val), + true +); + +export const validateUpperPrice: Validator = mkValidator( + 'upperPrice', + invalidLPPriceError, + (val) => typeof val === 'string' && isFloatString(val), + true +); + +export const validateLimitPrice: Validator = mkValidator( + 'limitPrice', + invalidLimitPriceError, + (val) => typeof val === 'string' && isFloatString(val), + true +); + +export const validateTokenId: Validator = mkValidator( + 'tokenId', + invalidTokenIdError, + (val) => + typeof val === 'undefined' || + (typeof val === 'number' && val >= 0 && Number.isInteger(val)), + true +); + +export const validatePeriod: Validator = mkValidator( + 'period', + invalidTimeError, + (val) => typeof val === 'number' && val >= 0 && Number.isInteger(val), + true +); + +export const validateInterval: Validator = mkValidator( + 'interval', + invalidTimeError, + (val) => typeof val === 'number' && val >= 0 && Number.isInteger(val), + true +); + +export const validateDecreasePercent: Validator = mkValidator( + 'decreasePercent', + invalidDecreasePercentError, + (val) => + typeof val === 'undefined' || + (typeof val === 'number' && val >= 0 && Number.isFinite(val)), + true +); + +export const validateAllowedSlippage: Validator = mkValidator( + 'allowedSlippage', + invalidAllowedSlippageError, + (val) => typeof val === 'string' && isFractionString(val), + true +); + +export const validatePriceRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateQuote, + validateBase, + validateAmount, + validateSide, + validateAllowedSlippage, +]); + +export const validateTradeRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateQuote, + validateBase, + validateAmount, + validateSide, + validateLimitPrice, + validateNonce, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, + validateAllowedSlippage, +]); + +export const validatePerpPositionRequest: RequestValidator = mkRequestValidator( + [ + validateConnector, + validateChain, + validateNetwork, + validateQuote, + validateBase, + validateAddress, + ] +); + +export const validatePerpBalanceRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateAddress, +]); + +export const validatePerpMarketStatusRequest: RequestValidator = + mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateQuote, + validateBase, + ]); + +export const validatePerpPairsRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, +]); + +export const validatePerpOpenTradeRequest: RequestValidator = + mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateQuote, + validateBase, + validateAmount, + validateAddress, + validatePerpSide, + validateNonce, + validateAllowedSlippage, + ]); + +export const validatePerpCloseTradeRequest: RequestValidator = + mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateQuote, + validateBase, + validateAddress, + validateNonce, + validateAllowedSlippage, + ]); + +export const validateEstimateGasRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, +]); + +export const validateAddLiquidityRequest: RequestValidator = mkRequestValidator( + [ + validateConnector, + validateChain, + validateNetwork, + validateToken0, + validateToken1, + validateAmount0, + validateAmount1, + validateAddress, + validateFee, + validateUpperPrice, + validateLowerPrice, + validateTokenId, + validateNonce, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, + ] +); + +export const validateRemoveLiquidityRequest: RequestValidator = + mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateAddress, + validateTokenId, + validateDecreasePercent, + validateNonce, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, + ]); + +export const validateCollectFeeRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateAddress, + validateTokenId, + validateNonce, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, +]); + +export const validatePositionRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateTokenId, +]); + +export const validatePoolPriceRequest: RequestValidator = mkRequestValidator([ + validateConnector, + validateChain, + validateNetwork, + validateToken0, + validateToken1, + validateFee, + validateInterval, + validatePeriod, +]); diff --git a/src/app.ts b/src/app.ts new file mode 100644 index 0000000000..49a8508fe0 --- /dev/null +++ b/src/app.ts @@ -0,0 +1,175 @@ +/* eslint-disable @typescript-eslint/ban-types */ +import express from 'express'; +import { Request, Response, NextFunction } from 'express'; +import { ConfigRoutes } from './services/config/config.routes'; +import { CosmosRoutes } from './chains/cosmos/cosmos.routes'; +import { WalletRoutes } from './services/wallet/wallet.routes'; +import { logger } from './services/logger'; +import { addHttps } from './https'; +import { + asyncHandler, + HttpException, + NodeError, + gatewayErrorMiddleware, +} from './services/error-handler'; +import { ConfigManagerV2 } from './services/config-manager-v2'; +import { SwaggerManager } from './services/swagger-manager'; +import { NetworkRoutes } from './network/network.routes'; +import { ConnectorsRoutes } from './connectors/connectors.routes'; +import { EVMRoutes } from './evm/evm.routes'; +import { AmmRoutes, AmmLiquidityRoutes, PerpAmmRoutes } from './amm/amm.routes'; +import { MadMeerkatConfig } from './connectors/mad_meerkat/mad_meerkat.config'; +import { PangolinConfig } from './connectors/pangolin/pangolin.config'; +import { QuickswapConfig } from './connectors/quickswap/quickswap.config'; +import { TraderjoeConfig } from './connectors/traderjoe/traderjoe.config'; +import { UniswapConfig } from './connectors/uniswap/uniswap.config'; +import { OpenoceanConfig } from './connectors/openocean/openocean.config'; +import { VVSConfig } from './connectors/vvs/vvs.config'; +import { AvailableNetworks } from './services/config-manager-types'; +import morgan from 'morgan'; +import { SushiswapConfig } from './connectors/sushiswap/sushiswap.config'; +import { DefikingdomsConfig } from './connectors/defikingdoms/defikingdoms.config'; +import { PancakeSwapConfig } from './connectors/pancakeswap/pancakeswap.config'; + +import swaggerUi from 'swagger-ui-express'; +import { NearRoutes } from './chains/near/near.routes'; + +export const gatewayApp = express(); + +// parse body for application/json +gatewayApp.use(express.json()); + +// parse url for application/x-www-form-urlencoded +gatewayApp.use(express.urlencoded({ extended: true })); + +// logging middleware +// skip logging path '/' or `/network/status` +gatewayApp.use( + morgan('combined', { + skip: function (req, _res) { + return ( + req.originalUrl === '/' || req.originalUrl.includes('/network/status') + ); + }, + }) +); + +// mount sub routers +gatewayApp.use('/config', ConfigRoutes.router); +gatewayApp.use('/network', NetworkRoutes.router); +gatewayApp.use('/evm', EVMRoutes.router); +gatewayApp.use('/connectors', ConnectorsRoutes.router); + +gatewayApp.use('/amm', AmmRoutes.router); +gatewayApp.use('/amm/perp', PerpAmmRoutes.router); +gatewayApp.use('/amm/liquidity', AmmLiquidityRoutes.router); +gatewayApp.use('/wallet', WalletRoutes.router); +gatewayApp.use('/cosmos', CosmosRoutes.router); +gatewayApp.use('/near', NearRoutes.router); + +// a simple route to test that the server is running +gatewayApp.get('/', (_req: Request, res: Response) => { + res.status(200).json({ status: 'ok' }); +}); + +interface ConnectorsResponse { + [key: string]: Array; +} + +gatewayApp.get( + '/connectors', + asyncHandler(async (_req, res: Response) => { + res.status(200).json({ + uniswap: UniswapConfig.config.availableNetworks, + pangolin: PangolinConfig.config.availableNetworks, + quickswap: QuickswapConfig.config.availableNetworks, + sushiswap: SushiswapConfig.config.availableNetworks, + openocean: OpenoceanConfig.config.availableNetworks, + traderjoe: TraderjoeConfig.config.availableNetworks, + defikingdoms: DefikingdomsConfig.config.availableNetworks, + mad_meerkat: MadMeerkatConfig.config.availableNetworks, + vvs: VVSConfig.config.availableNetworks, + pancakeswap: PancakeSwapConfig.config.availableNetworks, + }); + }) +); + +gatewayApp.post( + '/restart', + asyncHandler(async (_req, res) => { + // kill the current process and trigger the exit event + process.exit(1); + // this is only to satisfy the compiler, it will never be called. + res.status(200).json(); + }) +); + +// handle any error thrown in the gateway api route +gatewayApp.use( + ( + err: Error | NodeError | HttpException, + _req: Request, + res: Response, + _next: NextFunction + ) => { + const response = gatewayErrorMiddleware(err); + logger.error(err); + return res.status(response.httpErrorCode).json(response); + } +); + +export const swaggerDocument = SwaggerManager.generateSwaggerJson( + './docs/swagger/swagger.yml', + './docs/swagger/definitions.yml', + [ + './docs/swagger/main-routes.yml', + './docs/swagger/connectors-routes.yml', + './docs/swagger/wallet-routes.yml', + './docs/swagger/amm-routes.yml', + './docs/swagger/amm-liquidity-routes.yml', + './docs/swagger/evm-routes.yml', + './docs/swagger/network-routes.yml', + './docs/swagger/near-routes.yml', + './docs/swagger/cosmos-routes.yml', + ] +); + +export const startSwagger = async () => { + const swaggerApp = express(); + const swaggerPort = 8080; + + logger.info( + `⚡️ Swagger listening on port ${swaggerPort}. Read the Gateway API documentation at 127.0.0.1:${swaggerPort}` + ); + + swaggerApp.use('/', swaggerUi.serve, swaggerUi.setup(swaggerDocument)); + + await swaggerApp.listen(swaggerPort); +}; + +export const startGateway = async () => { + const port = ConfigManagerV2.getInstance().get('server.port'); + if (!ConfigManagerV2.getInstance().get('server.id')) { + ConfigManagerV2.getInstance().set( + 'server.id', + Math.random().toString(16).substr(2, 14) + ); + } + logger.info(`⚡️ Starting Gateway API on port ${port}...`); + if (ConfigManagerV2.getInstance().get('server.unsafeDevModeWithHTTP')) { + logger.info('Running in UNSAFE HTTP! This could expose private keys.'); + await gatewayApp.listen(port); + } else { + try { + await addHttps(gatewayApp).listen(port); + logger.info('The gateway server is secured behind HTTPS.'); + } catch (e) { + logger.error( + `Failed to start the server with https. Confirm that the SSL certificate files exist and are correct. Error: ${e}` + ); + process.exit(); + } + } + + await startSwagger(); +}; diff --git a/src/chains/avalanche/avalanche.ts b/src/chains/avalanche/avalanche.ts new file mode 100644 index 0000000000..c903fff874 --- /dev/null +++ b/src/chains/avalanche/avalanche.ts @@ -0,0 +1,128 @@ +import abi from '../../services/ethereum.abi.json'; +import { logger } from '../../services/logger'; +import { Contract, Transaction, Wallet } from 'ethers'; +import { EthereumBase } from '../../services/ethereum-base'; +import { getEthereumConfig as getAvalancheConfig } from '../ethereum/ethereum.config'; +import { Provider } from '@ethersproject/abstract-provider'; +import { TraderjoeConfig } from '../../connectors/traderjoe/traderjoe.config'; +import { PangolinConfig } from '../../connectors/pangolin/pangolin.config'; +import { OpenoceanConfig } from '../../connectors/openocean/openocean.config'; +import { Ethereumish } from '../../services/common-interfaces'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export class Avalanche extends EthereumBase implements Ethereumish { + private static _instances: { [name: string]: Avalanche }; + private _gasPrice: number; + private _gasPriceRefreshInterval: number | null; + private _nativeTokenSymbol: string; + private _chain: string; + + private constructor(network: string) { + const config = getAvalancheConfig('avalanche', network); + super( + 'avalanche', + config.network.chainID, + config.network.nodeURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.nonceDbPath'), + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = config.network.name; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + + this._gasPrice = config.manualGasPrice; + + this._gasPriceRefreshInterval = + config.network.gasPriceRefreshInterval !== undefined + ? config.network.gasPriceRefreshInterval + : null; + + this.updateGasPrice(); + } + + public static getInstance(network: string): Avalanche { + if (Avalanche._instances === undefined) { + Avalanche._instances = {}; + } + if (!(network in Avalanche._instances)) { + Avalanche._instances[network] = new Avalanche(network); + } + + return Avalanche._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Avalanche } { + return Avalanche._instances; + } + + // getters + + public get gasPrice(): number { + return this._gasPrice; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get chain(): string { + return this._chain; + } + + getContract(tokenAddress: string, signerOrProvider?: Wallet | Provider) { + return new Contract(tokenAddress, abi.ERC20Abi, signerOrProvider); + } + + getSpender(reqSpender: string): string { + let spender: string; + if (reqSpender === 'pangolin') { + spender = PangolinConfig.config.routerAddress(this._chain); + } else if (reqSpender === 'openocean') { + spender = OpenoceanConfig.config.routerAddress(this._chain); + } else if (reqSpender === 'traderjoe') { + spender = TraderjoeConfig.config.routerAddress(this._chain); + } else { + spender = reqSpender; + } + return spender; + } + + // cancel transaction + async cancelTx(wallet: Wallet, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return super.cancelTxWithGasPrice(wallet, nonce, this._gasPrice * 2); + } + + /** + * Automatically update the prevailing gas price on the network. + */ + async updateGasPrice(): Promise { + if (this._gasPriceRefreshInterval === null) { + return; + } + + const gasPrice = await this.getGasPrice(); + if (gasPrice !== null) { + this._gasPrice = gasPrice; + } else { + logger.info('gasPrice is unexpectedly null.'); + } + + setTimeout( + this.updateGasPrice.bind(this), + this._gasPriceRefreshInterval * 1000 + ); + } + + async close() { + await super.close(); + if (this._chain in Avalanche._instances) { + delete Avalanche._instances[this._chain]; + } + } +} diff --git a/src/chains/avalanche/avalanche.validators.ts b/src/chains/avalanche/avalanche.validators.ts new file mode 100644 index 0000000000..a1f2ca2c52 --- /dev/null +++ b/src/chains/avalanche/avalanche.validators.ts @@ -0,0 +1,42 @@ +import { + mkRequestValidator, + mkValidator, + RequestValidator, + Validator, + validateAmount, + validateToken, + validateTokenSymbols, +} from '../../services/validators'; +import { + isAddress, + validateNonce, + validateAddress, +} from '../ethereum/ethereum.validators'; + +export const invalidSpenderError: string = + 'The spender param is not a valid Avalanche address (0x followed by 40 hexidecimal characters).'; + +// given a request, look for a key called spender that is 'uniswap' or an Ethereum address +export const validateSpender: Validator = mkValidator( + 'spender', + invalidSpenderError, + + (val) => + typeof val === 'string' && + (val === 'pangolin' || + val === 'traderjoe' || + val === 'openocean' || + isAddress(val)) +); + +export const validateAvalancheApproveRequest: RequestValidator = + mkRequestValidator([ + validateAddress, + validateSpender, + validateToken, + validateAmount, + validateNonce, + ]); + +export const validateAvalancheAllowancesRequest: RequestValidator = + mkRequestValidator([validateAddress, validateSpender, validateTokenSymbols]); diff --git a/src/chains/avalanche/avalanche_tokens_fuji.json b/src/chains/avalanche/avalanche_tokens_fuji.json new file mode 100644 index 0000000000..bdda0dc6b1 --- /dev/null +++ b/src/chains/avalanche/avalanche_tokens_fuji.json @@ -0,0 +1,37 @@ +{ + "name": "Fuji Token List", + "logoURI": "https://i.imgur.com/tt0vG2N.png", + "version": { + "major": 0, + "minor": 2, + "patch": 0 + }, + "keywords": [], + "timestamp": "2022-02-21T00:00:00+00:00", + "tokens": [ + { + "address": "0x2058ec2791dD28b6f67DB836ddf87534F4Bbdf22", + "chainId": 43113, + "name": "The Fuji stablecoin", + "symbol": "FUJISTABLE", + "decimals": 6, + "logoURI": "https://i.imgur.com/LPZDXoT.png" + }, + { + "address": "0x97132C109c6816525F7f338DCb7435E1412A7668", + "chainId": 43113, + "name": "To the Moon", + "symbol": "FUJIMOON", + "decimals": 9, + "logoURI": "https://i.imgur.com/jNTqyQA.png" + }, + { + "address": "0xF561800EdedF4CE146ED427Cacf1Fb8aB3B2D452", + "chainId": 43113, + "name": "Wrapped WAGMI", + "symbol": "WWAGMI", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/antiyro/WagmiTokenList/master/wagmi.png" + } + ] +} diff --git a/src/chains/avalanche/avanlanche_tokens.json b/src/chains/avalanche/avanlanche_tokens.json new file mode 100644 index 0000000000..b9a5053ee8 --- /dev/null +++ b/src/chains/avalanche/avanlanche_tokens.json @@ -0,0 +1,1573 @@ +{ + "name": "Pangolin Tokenlist", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x60781C2586D68229fde47564546784ab3fACA982/logo_48.png", + "keywords": [], + "version": { + "major": 3, + "minor": 11, + "patch": 1 + }, + "timestamp": "2022-12-15T12:00:00+00:00", + "tokens": [ + { + "chainId": 114, + "address": "0x6169CD307Be7E24152dF23a7A945A1ea3eC7b438", + "decimals": 18, + "name": "Pangolin Coston2", + "symbol": "PCT2", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/114/0x6169CD307Be7E24152dF23a7A945A1ea3eC7b438/logo_24.png" + }, + { + "chainId": 296, + "address": "0x0000000000000000000000000000000002DfA5b2", + "decimals": 8, + "name": "Wrapped Hedera", + "symbol": "WHBAR", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/296/0x0000000000000000000000000000000002DfA5b2/logo_24.png" + }, + { + "chainId": 296, + "address": "0x0000000000000000000000000000000002D9E4F8", + "decimals": 6, + "name": "USDC", + "symbol": "USDC", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/296/0x0000000000000000000000000000000002D9E4F8/logo_24.png" + }, + { + "chainId": 296, + "address": "0x0000000000000000000000000000000002Db0600", + "decimals": 8, + "name": "Pangolin Hedera", + "symbol": "PBAR", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/296/0x0000000000000000000000000000000002Db0600/logo_24.png" + }, + { + "chainId": 296, + "address": "0x0000000000000000000000000000000002bE71e8", + "decimals": 6, + "name": "Sauce", + "symbol": "SAUCE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/296/0x0000000000000000000000000000000002bE71e8/logo_24.png" + }, + { + "chainId": 16, + "address": "0x0A8744c2a48b0e09a3e4C3A381A8E0d8d900bAFe", + "decimals": 18, + "name": "Pangolin", + "symbol": "PCT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/16/0x0A8744c2a48b0e09a3e4C3A381A8E0d8d900bAFe/logo_24.png" + }, + { + "chainId": 11111, + "address": "0xbdf33c7128fBB220fc0e4Be277697cEeef8BdfF5", + "decimals": 18, + "name": "Pangolin", + "symbol": "wagmiPNG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/11111/0xbdf33c7128fBB220fc0e4Be277697cEeef8BdfF5/logo_24.png" + }, + { + "chainId": 11111, + "address": "0x3Ee7094DADda15810F191DD6AcF7E4FFa37571e4", + "decimals": 18, + "name": "Wrapped WAGMI", + "symbol": "wWAGMI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/11111/0x3Ee7094DADda15810F191DD6AcF7E4FFa37571e4/logo_24.png" + }, + { + "chainId": 11111, + "address": "0xf1db872E6454D553686b088c1Ea3889cF2FE3ABe", + "decimals": 18, + "name": "OG", + "symbol": "OG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/11111/0xf1db872E6454D553686b088c1Ea3889cF2FE3ABe/logo_24.png" + }, + { + "chainId": 11111, + "address": "0x4eaA03A9C9c9CE745517538d262653B9e43c51f2", + "decimals": 18, + "name": "staySAFU", + "symbol": "staySAFU", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/11111/0x4eaA03A9C9c9CE745517538d262653B9e43c51f2/logo_24.png" + }, + { + "chainId": 19, + "address": "0x02f0826ef6aD107Cfc861152B32B52fD11BaB9ED", + "decimals": 18, + "name": "Wrapped Songbird", + "symbol": "WSGB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0x02f0826ef6aD107Cfc861152B32B52fD11BaB9ED/logo_24.png" + }, + { + "chainId": 19, + "address": "0xb2987753D1561570f726Aa373F48E77e27aa5FF4", + "decimals": 18, + "name": "Pangolin Songbird", + "symbol": "PSB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0xb2987753D1561570f726Aa373F48E77e27aa5FF4/logo_24.png" + }, + { + "chainId": 19, + "address": "0x697bb3B5E1eCf4fEbE6016321b0648d3d6C270B6", + "decimals": 18, + "name": "sDOOD Token", + "symbol": "sDOOD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0x697bb3B5E1eCf4fEbE6016321b0648d3d6C270B6/logo_24.png" + }, + { + "chainId": 19, + "address": "0x8d32E20d119d936998575B4AAff66B9999011D27", + "decimals": 18, + "name": "CanaryX", + "symbol": "CNYX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0x8d32E20d119d936998575B4AAff66B9999011D27/logo_24.png" + }, + { + "chainId": 19, + "address": "0xD7565b16b65376e2Ddb6c71E7971c7185A7Ff3Ff", + "decimals": 18, + "name": "OracleSwap", + "symbol": "ORACLE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0xD7565b16b65376e2Ddb6c71E7971c7185A7Ff3Ff/logo_24.png" + }, + { + "chainId": 19, + "address": "0xC348F894d0E939FE72c467156E6d7DcbD6f16e21", + "decimals": 18, + "name": "Experimental Finance Token", + "symbol": "EXFI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0xC348F894d0E939FE72c467156E6d7DcbD6f16e21/logo_24.png" + }, + { + "chainId": 19, + "address": "0x9E2E6c16803878C18E54Ed74F05AeafCCe464626", + "decimals": 18, + "name": "sFortuna", + "symbol": "SFORT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0x9E2E6c16803878C18E54Ed74F05AeafCCe464626/logo_24.png" + }, + { + "chainId": 19, + "address": "0x9dC8639bff70B019088f0b7D960561654269B5BE", + "decimals": 18, + "name": "Honey Stick", + "symbol": "HS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0x9dC8639bff70B019088f0b7D960561654269B5BE/logo_24.png" + }, + { + "chainId": 19, + "address": "0xe4671844Fcb3cA9A80A1224B6f9A0A6c2Ba2a7d5", + "decimals": 18, + "name": "Cootie Coin", + "symbol": "COOT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0xe4671844Fcb3cA9A80A1224B6f9A0A6c2Ba2a7d5/logo_24.png" + }, + { + "chainId": 19, + "address": "0x671ee7ac6ef2803776dD1711e577540A6007cC25", + "decimals": 18, + "name": "Ocean", + "symbol": "OCN", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0x671ee7ac6ef2803776dD1711e577540A6007cC25/logo_24.png" + }, + { + "chainId": 19, + "address": "0xd46bd7A5EBE52199BD6f0EfD59a1d7CeF7f35eae", + "decimals": 18, + "name": "Infinty Token", + "symbol": "INFT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/19/0xd46bd7A5EBE52199BD6f0EfD59a1d7CeF7f35eae/logo_24.png" + }, + { + "chainId": 11111, + "address": "0x21cf0eB2E3Ab483a67C900b27dA8F34185991982", + "decimals": 18, + "name": "Wrapped AVAX", + "symbol": "WAVAX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/11111/0x21cf0eB2E3Ab483a67C900b27dA8F34185991982/logo_24.png" + }, + { + "chainId": 43113, + "address": "0x2058ec2791dD28b6f67DB836ddf87534F4Bbdf22", + "name": "The Fuji stablecoin", + "symbol": "FUJISTABLE", + "decimals": 6, + "logoURI": "https://i.imgur.com/LPZDXoT.png" + }, + { + "chainId": 43113, + "address": "0x97132C109c6816525F7f338DCb7435E1412A7668", + "name": "To the Moon", + "symbol": "FUJIMOON", + "decimals": 9, + "logoURI": "https://i.imgur.com/jNTqyQA.png" + }, + { + "chainId": 43113, + "address": "0xF561800EdedF4CE146ED427Cacf1Fb8aB3B2D452", + "name": "Wrapped WAGMI", + "symbol": "WWAGMI", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43113/0xF561800EdedF4CE146ED427Cacf1Fb8aB3B2D452/logo_24.png" + }, + { + "chainId": 43113, + "address": "0x224695Ba2a98E4a096a519B503336E06D9116E48", + "name": "The Crypt", + "symbol": "RIP", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/antiyro/WagmiTokenList/master/wagmi.png" + }, + { + "chainId": 43113, + "address": "0xAF5D473b3f8F96A5B21c6bbB97e09b491335acb9", + "name": "Fuji PNG", + "symbol": "fujiPNG", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43113/0xAF5D473b3f8F96A5B21c6bbB97e09b491335acb9/logo_24.png" + }, + { + "chainId": 43113, + "address": "0x0a8c21858aC24e1305BaFBDdf4DfB73a2CC9ddBC", + "name": "JAWZ Fuji TestNet", + "symbol": "JAWZ", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43113/0x0a8c21858aC24e1305BaFBDdf4DfB73a2CC9ddBC/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x60781C2586D68229fde47564546784ab3fACA982", + "decimals": 18, + "name": "Pangolin", + "symbol": "PNG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x60781C2586D68229fde47564546784ab3fACA982/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7", + "decimals": 18, + "name": "Wrapped AVAX", + "symbol": "WAVAX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x78ea17559B3D2CF85a7F9C2C704eda119Db5E6dE", + "decimals": 18, + "name": "Avaware", + "symbol": "AVE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x78ea17559B3D2CF85a7F9C2C704eda119Db5E6dE/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xdb333724fAE72b4253FC3d44c8270CBBC86d147b", + "decimals": 18, + "name": "Cabbage.Cash", + "symbol": "CABAG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xdb333724fAE72b4253FC3d44c8270CBBC86d147b/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x488F73cddDA1DE3664775fFd91623637383D6404", + "decimals": 18, + "name": "YetiSwap", + "symbol": "YTS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x488F73cddDA1DE3664775fFd91623637383D6404/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xC38f41A296A4493Ff429F1238e030924A1542e50", + "decimals": 18, + "name": "Snowball", + "symbol": "SNOB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xC38f41A296A4493Ff429F1238e030924A1542e50/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x6e7f5C0b9f4432716bDd0a77a3601291b9D9e985", + "decimals": 9, + "name": "Spore", + "symbol": "SPORE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x6e7f5C0b9f4432716bDd0a77a3601291b9D9e985/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xe896CDeaAC9615145c0cA09C8Cd5C25bced6384c", + "decimals": 18, + "name": "PenguinToken", + "symbol": "PEFI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xe896CDeaAC9615145c0cA09C8Cd5C25bced6384c/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xC931f61B1534EB21D8c11B24f3f5Ab2471d4aB50", + "decimals": 8, + "name": "Blocknet", + "symbol": "aaBLOCK", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xC931f61B1534EB21D8c11B24f3f5Ab2471d4aB50/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x4C9B4E1AC6F24CdE3660D5E4Ef1eBF77C710C084", + "decimals": 18, + "name": "LydiaFinance Token", + "symbol": "LYD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4C9B4E1AC6F24CdE3660D5E4Ef1eBF77C710C084/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x846D50248BAf8b7ceAA9d9B53BFd12d7D7FBB25a", + "decimals": 18, + "name": "VersoToken", + "symbol": "VSO", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x846D50248BAf8b7ceAA9d9B53BFd12d7D7FBB25a/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x1ECd47FF4d9598f89721A2866BFEb99505a413Ed", + "decimals": 18, + "name": "AVME", + "symbol": "AVME", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x1ECd47FF4d9598f89721A2866BFEb99505a413Ed/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x65378b697853568dA9ff8EaB60C13E1Ee9f4a654", + "decimals": 18, + "name": "Husky", + "symbol": "HUSKY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x65378b697853568dA9ff8EaB60C13E1Ee9f4a654/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xD606199557c8Ab6F4Cc70bD03FaCc96ca576f142", + "decimals": 18, + "name": "Gondola", + "symbol": "GDL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xD606199557c8Ab6F4Cc70bD03FaCc96ca576f142/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x81440C939f2C1E34fc7048E518a637205A632a74", + "decimals": 18, + "name": "Cycle Token", + "symbol": "CYCLE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x81440C939f2C1E34fc7048E518a637205A632a74/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xd1c3f94DE7e5B45fa4eDBBA472491a9f4B166FC4", + "decimals": 18, + "name": "Avalaunch", + "symbol": "XAVA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xd1c3f94DE7e5B45fa4eDBBA472491a9f4B166FC4/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x8D88e48465F30Acfb8daC0b3E35c9D6D7d36abaf", + "decimals": 18, + "name": "Canary", + "symbol": "CNR", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x8D88e48465F30Acfb8daC0b3E35c9D6D7d36abaf/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xa5E59761eBD4436fa4d20E1A27cBa29FB2471Fc6", + "decimals": 18, + "name": "Sherpa", + "symbol": "SHERPA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xa5E59761eBD4436fa4d20E1A27cBa29FB2471Fc6/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x961C8c0B1aaD0c0b10a51FeF6a867E3091BCef17", + "decimals": 18, + "name": "Dypius", + "symbol": "DYP", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x961C8c0B1aaD0c0b10a51FeF6a867E3091BCef17/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x264c1383EA520f73dd837F915ef3a732e204a493", + "decimals": 18, + "name": "Binance", + "symbol": "BNB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x264c1383EA520f73dd837F915ef3a732e204a493/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xB1466d4cf0DCfC0bCdDcf3500F473cdACb88b56D", + "decimals": 18, + "name": "Weble Ecosystem Token", + "symbol": "WET", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xB1466d4cf0DCfC0bCdDcf3500F473cdACb88b56D/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x59414b3089ce2AF0010e7523Dea7E2b35d776ec7", + "decimals": 18, + "name": "Yak Token", + "symbol": "YAK", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x59414b3089ce2AF0010e7523Dea7E2b35d776ec7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x8729438EB15e2C8B576fCc6AeCdA6A148776C0F5", + "decimals": 18, + "name": "BENQI", + "symbol": "QI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x8729438EB15e2C8B576fCc6AeCdA6A148776C0F5/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x9E037dE681CaFA6E661e6108eD9c2bd1AA567Ecd", + "decimals": 18, + "name": "Wrapped AllianceBlock Token", + "symbol": "WALBT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x9E037dE681CaFA6E661e6108eD9c2bd1AA567Ecd/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x21c5402C3B7d40C89Cc472C9dF5dD7E51BbAb1b1", + "decimals": 18, + "name": "TundraToken", + "symbol": "TUNDRA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x21c5402C3B7d40C89Cc472C9dF5dD7E51BbAb1b1/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x595c8481c48894771CE8FaDE54ac6Bf59093F9E8", + "decimals": 18, + "name": "Gaj Finance", + "symbol": "GAJ", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x595c8481c48894771CE8FaDE54ac6Bf59093F9E8/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x094bd7B2D99711A1486FB94d4395801C6d0fdDcC", + "decimals": 18, + "name": "TEDDY", + "symbol": "TEDDY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x094bd7B2D99711A1486FB94d4395801C6d0fdDcC/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x6e84a6216eA6dACC71eE8E6b0a5B7322EEbC0fDd", + "decimals": 18, + "name": "JoeToken", + "symbol": "JOE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x6e84a6216eA6dACC71eE8E6b0a5B7322EEbC0fDd/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x9Fda7cEeC4c18008096C2fE2B85F05dc300F94d0", + "decimals": 18, + "name": "MarginSwap", + "symbol": "MFI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x9Fda7cEeC4c18008096C2fE2B85F05dc300F94d0/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x440aBbf18c54b2782A4917b80a1746d3A2c2Cce1", + "decimals": 18, + "name": "SHIBAVAX", + "symbol": "SHIBX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x440aBbf18c54b2782A4917b80a1746d3A2c2Cce1/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xD67de0e0a0Fd7b15dC8348Bb9BE742F3c5850454", + "decimals": 18, + "name": "Frax Share", + "symbol": "FXS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xD67de0e0a0Fd7b15dC8348Bb9BE742F3c5850454/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xc12e249FaBe1c5Eb7C558E5F50D187687a244E31", + "decimals": 18, + "name": "Blue Token", + "symbol": "BLUE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xc12e249FaBe1c5Eb7C558E5F50D187687a244E31/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x01C2086faCFD7aA38f69A6Bd8C91BEF3BB5adFCa", + "decimals": 18, + "name": "YAY Games", + "symbol": "YAY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x01C2086faCFD7aA38f69A6Bd8C91BEF3BB5adFCa/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x397bBd6A0E41bdF4C3F971731E180Db8Ad06eBc1", + "decimals": 6, + "name": "Avaxtars Token", + "symbol": "AVXT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x397bBd6A0E41bdF4C3F971731E180Db8Ad06eBc1/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xae9d2385Ff2E2951Dd4fA061e74c4d3deDD24347", + "decimals": 8, + "name": "TOK", + "symbol": "TOK", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xae9d2385Ff2E2951Dd4fA061e74c4d3deDD24347/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xb54f16fB19478766A268F172C9480f8da1a7c9C3", + "decimals": 9, + "name": "Time", + "symbol": "TIME", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xb54f16fB19478766A268F172C9480f8da1a7c9C3/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x90842eb834cFD2A1DB0b1512B254a18E4D396215", + "decimals": 9, + "name": "Good Bridging", + "symbol": "GB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x90842eb834cFD2A1DB0b1512B254a18E4D396215/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x0ebd9537A25f56713E34c45b38F421A1e7191469", + "decimals": 18, + "name": "OpenOcean", + "symbol": "OOE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x0ebd9537A25f56713E34c45b38F421A1e7191469/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x3709E8615E02C15B096f8a9B460ccb8cA8194e86", + "decimals": 18, + "name": "Vee", + "symbol": "VEE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x3709E8615E02C15B096f8a9B460ccb8cA8194e86/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x938FE3788222A74924E062120E7BFac829c719Fb", + "decimals": 18, + "name": "Ape In", + "symbol": "APEIN", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x938FE3788222A74924E062120E7BFac829c719Fb/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xfC108f21931576a21D0b4b301935DAc80d9E5086", + "decimals": 18, + "name": "Iron Finance ICE Token", + "symbol": "IronICE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xfC108f21931576a21D0b4b301935DAc80d9E5086/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xA384Bc7Cdc0A93e686da9E7B8C0807cD040F4E0b", + "decimals": 18, + "name": "WOWSwap", + "symbol": "WOW", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xA384Bc7Cdc0A93e686da9E7B8C0807cD040F4E0b/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xCE1bFFBD5374Dac86a2893119683F4911a2F7814", + "decimals": 18, + "name": "Spell Token", + "symbol": "SPELL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xCE1bFFBD5374Dac86a2893119683F4911a2F7814/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xb27c8941a7Df8958A1778c0259f76D1F8B711C35", + "decimals": 18, + "name": "Kalao Token", + "symbol": "KLO", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xb27c8941a7Df8958A1778c0259f76D1F8B711C35/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x027dbcA046ca156De9622cD1e2D907d375e53aa7", + "decimals": 9, + "name": "Ampleforth", + "symbol": "AMPL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x027dbcA046ca156De9622cD1e2D907d375e53aa7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x8B1d98A91F853218ddbb066F20b8c63E782e2430", + "decimals": 18, + "name": "OrcaDAO", + "symbol": "ORCA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x8B1d98A91F853218ddbb066F20b8c63E782e2430/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x544c42fBB96B39B21DF61cf322b5EDC285EE7429", + "decimals": 18, + "name": "INSUR Token", + "symbol": "INSUR", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x544c42fBB96B39B21DF61cf322b5EDC285EE7429/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x6C6f910A79639dcC94b4feEF59Ff507c2E843929", + "decimals": 18, + "name": "Ankr Avalanche Reward Earning Bond", + "symbol": "aAVAXb", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x6C6f910A79639dcC94b4feEF59Ff507c2E843929/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xB00F1ad977a949a3CCc389Ca1D1282A2946963b0", + "decimals": 18, + "name": "Boo Finance Token", + "symbol": "BOOFI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xB00F1ad977a949a3CCc389Ca1D1282A2946963b0/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x45C13620B55C35A5f539d26E88247011Eb10fDbd", + "decimals": 18, + "name": "Hurricane Token", + "symbol": "HCT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x45C13620B55C35A5f539d26E88247011Eb10fDbd/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x214DB107654fF987AD859F34125307783fC8e387", + "decimals": 18, + "name": "Frax Share", + "symbol": "FXS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x214DB107654fF987AD859F34125307783fC8e387/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xb2a85C5ECea99187A977aC34303b80AcbDdFa208", + "decimals": 18, + "name": "ROCO", + "symbol": "ROCO", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xb2a85C5ECea99187A977aC34303b80AcbDdFa208/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xeA6887e4a9CdA1B77E70129E5Fba830CdB5cdDef", + "decimals": 18, + "name": "IMX", + "symbol": "IMX.a", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xeA6887e4a9CdA1B77E70129E5Fba830CdB5cdDef/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x340fE1D898ECCAad394e2ba0fC1F93d27c7b717A", + "decimals": 18, + "name": "Orbs", + "symbol": "ORBS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x340fE1D898ECCAad394e2ba0fC1F93d27c7b717A/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xA32608e873F9DdEF944B24798db69d80Bbb4d1ed", + "decimals": 18, + "name": "CRA", + "symbol": "CRA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xA32608e873F9DdEF944B24798db69d80Bbb4d1ed/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x885d748C00A279B67A7749EC6b03301700dd0455", + "decimals": 18, + "name": "Maximus", + "symbol": "MAXI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x885d748C00A279B67A7749EC6b03301700dd0455/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x7C08413cbf02202a1c13643dB173f2694e0F73f0", + "decimals": 9, + "name": "Maximizer", + "symbol": "MAXI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x7C08413cbf02202a1c13643dB173f2694e0F73f0/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x4f60a160D8C2DDdaAfe16FCC57566dB84D674BD6", + "decimals": 18, + "name": "Jewels", + "symbol": "JEWEL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4f60a160D8C2DDdaAfe16FCC57566dB84D674BD6/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x8aE8be25C23833e0A01Aa200403e826F611f9CD2", + "decimals": 18, + "name": "CRAFT", + "symbol": "CRAFT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x8aE8be25C23833e0A01Aa200403e826F611f9CD2/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x321E7092a180BB43555132ec53AaA65a5bF84251", + "decimals": 18, + "name": "Governance OHM", + "symbol": "gOHM", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x321E7092a180BB43555132ec53AaA65a5bF84251/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x637afeff75ca669fF92e4570B14D6399A658902f", + "decimals": 18, + "name": "Poly-Peg COOK", + "symbol": "COOK", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x637afeff75ca669fF92e4570B14D6399A658902f/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x9E3Ca00f2d4A9E5d4f0add0900de5f15050812cF", + "decimals": 18, + "name": "NFTrade Token", + "symbol": "NFTD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x9E3Ca00f2d4A9E5d4f0add0900de5f15050812cF/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xec3492a2508DDf4FDc0cD76F31f340b30d1793e6", + "decimals": 18, + "name": "Colony Token", + "symbol": "CLY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xec3492a2508DDf4FDc0cD76F31f340b30d1793e6/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xf69c2fcd9128d49DfA22348C69177f9380438eB8", + "decimals": 6, + "name": "NFTSoccerGames", + "symbol": "NFSG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xf69c2fcd9128d49DfA22348C69177f9380438eB8/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x483416eB3aFA601B9C6385f63CeC0C82B6aBf1fb", + "decimals": 18, + "name": "Skill Token", + "symbol": "SKILL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x483416eB3aFA601B9C6385f63CeC0C82B6aBf1fb/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xBD100d061E120b2c67A24453CF6368E63f1Be056", + "decimals": 18, + "name": "iDeFiYieldProtocol", + "symbol": "iDYP", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xBD100d061E120b2c67A24453CF6368E63f1Be056/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x22d4002028f537599bE9f666d1c4Fa138522f9c8", + "decimals": 18, + "name": "Platypus", + "symbol": "PTP", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x22d4002028f537599bE9f666d1c4Fa138522f9c8/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xcA220F1e486A8e35d6F1DCD62073Ad8DD04659ED", + "decimals": 6, + "name": "BiAltin", + "symbol": "GLDB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xcA220F1e486A8e35d6F1DCD62073Ad8DD04659ED/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x7086e045b78E1e72F741F25231c08d238812CF8a", + "decimals": 18, + "name": "RaceX", + "symbol": "RACEX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x7086e045b78E1e72F741F25231c08d238812CF8a/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xb84527D59b6Ecb96F433029ECc890D4492C5dCe1", + "decimals": 18, + "name": "Tomb", + "symbol": "TOMB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xb84527D59b6Ecb96F433029ECc890D4492C5dCe1/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xbca7f1998Dc9FFB70b086543a808960a460aBcA7", + "decimals": 18, + "name": "Kitty", + "symbol": "KITTY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xbca7f1998Dc9FFB70b086543a808960a460aBcA7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x721C299E6BF7D6a430d9bEA3364Ea197314bcE09", + "decimals": 18, + "name": "MilkyWay Token by SpaceSwap v2", + "symbol": "MILK2", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x721C299E6BF7D6a430d9bEA3364Ea197314bcE09/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xC1d02E488a9Ce2481BFdcd797d5373Dd2E70a9C2", + "decimals": 18, + "name": "SHAKE token by SpaceSwap v2", + "symbol": "SHAKE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xC1d02E488a9Ce2481BFdcd797d5373Dd2E70a9C2/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x47EB6F7525C1aA999FBC9ee92715F5231eB1241D", + "decimals": 18, + "name": "Defrost Finance Token", + "symbol": "MELT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x47EB6F7525C1aA999FBC9ee92715F5231eB1241D/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xe0Ce60AF0850bF54072635e66E79Df17082A1109", + "decimals": 18, + "name": "IceToken", + "symbol": "ICE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xe0Ce60AF0850bF54072635e66E79Df17082A1109/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xf693248F96Fe03422FEa95aC0aFbBBc4a8FdD172", + "decimals": 18, + "name": "Treasure Under Sea", + "symbol": "TUS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xf693248F96Fe03422FEa95aC0aFbBBc4a8FdD172/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xF891214fdcF9cDaa5fdC42369eE4F27F226AdaD6", + "decimals": 18, + "name": "Imperium Empires Token", + "symbol": "IME", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xF891214fdcF9cDaa5fdC42369eE4F27F226AdaD6/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xB15f02F9Da8CD1f99E9dd375F21dc96D25ddd82C", + "decimals": 18, + "name": "HERMES", + "symbol": "HERMES", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xB15f02F9Da8CD1f99E9dd375F21dc96D25ddd82C/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xfa4B6db72A650601E7Bd50a0A9f537c9E98311B2", + "decimals": 18, + "name": "HERMES Shares", + "symbol": "HSHARES", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xfa4B6db72A650601E7Bd50a0A9f537c9E98311B2/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x1DB749847C4abB991d8B6032102383e6BfD9B1c7", + "decimals": 18, + "name": "Dogeon Token", + "symbol": "DON", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x1DB749847C4abB991d8B6032102383e6BfD9B1c7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x3EeFb18003D033661f84e48360eBeCD181A84709", + "decimals": 18, + "name": "Islander", + "symbol": "ISA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x3EeFb18003D033661f84e48360eBeCD181A84709/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x7f041ce89A2079873693207653b24C15B5e6A293", + "decimals": 18, + "name": "LOOT", + "symbol": "LOOT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x7f041ce89A2079873693207653b24C15B5e6A293/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xE6B9d092223f39013656702A40dbE6B7DeCc5746", + "decimals": 18, + "name": "ANGLE", + "symbol": "ANGLE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xE6B9d092223f39013656702A40dbE6B7DeCc5746/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x921f99719Eb6C01b4B8f0BA7973A7C24891e740A", + "decimals": 18, + "name": "MetaBrands", + "symbol": "MAGE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x921f99719Eb6C01b4B8f0BA7973A7C24891e740A/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x9C8E99eb130AED653Ef90fED709D9C3E9cC8b269", + "decimals": 18, + "name": "Hertz Token", + "symbol": "HTZ", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x9C8E99eb130AED653Ef90fED709D9C3E9cC8b269/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x0fEc6d8A84A85b79A1FFE0E28c1902E08b653EFE", + "decimals": 18, + "name": "Hoopoe Ventures", + "symbol": "HOOP", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x0fEc6d8A84A85b79A1FFE0E28c1902E08b653EFE/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xC7f4debC8072e23fe9259A5C0398326d8EfB7f5c", + "decimals": 18, + "name": "HeroesChained", + "symbol": "HeC", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xC7f4debC8072e23fe9259A5C0398326d8EfB7f5c/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x7b2B702706D9b361dfE3f00bD138C0CFDA7FB2Cf", + "decimals": 18, + "name": "Pollen", + "symbol": "PLN", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x7b2B702706D9b361dfE3f00bD138C0CFDA7FB2Cf/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x7761E2338B35bCEB6BdA6ce477EF012bde7aE611", + "decimals": 18, + "name": "chikn egg", + "symbol": "EGG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x7761E2338B35bCEB6BdA6ce477EF012bde7aE611/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xab592d197ACc575D16C3346f4EB70C703F308D1E", + "decimals": 18, + "name": "chikn feed", + "symbol": "FEED", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xab592d197ACc575D16C3346f4EB70C703F308D1E/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x100Cc3a819Dd3e8573fD2E46D1E66ee866068f30", + "decimals": 18, + "name": "Dragon Crypto Aurum", + "symbol": "DCAU", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x100Cc3a819Dd3e8573fD2E46D1E66ee866068f30/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x120AD3e5A7c796349e591F1570D9f7980F4eA9cb", + "decimals": 6, + "name": "Axelar Wrapped LUNA", + "symbol": "LUNA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x120AD3e5A7c796349e591F1570D9f7980F4eA9cb/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xf32398dae246C5f672B52A54e9B413dFFcAe1A44", + "decimals": 18, + "name": "Kassandra", + "symbol": "KACY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xf32398dae246C5f672B52A54e9B413dFFcAe1A44/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x402FD175049e95CeF2cC9ca1FECdb6d9736e690d", + "decimals": 18, + "name": "Catoshi", + "symbol": "CATS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x402FD175049e95CeF2cC9ca1FECdb6d9736e690d/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x1fE4751d9bDabaC8D90067056cB45AB6823d2C12", + "decimals": 18, + "name": "ArgonToken", + "symbol": "ARGON", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x1fE4751d9bDabaC8D90067056cB45AB6823d2C12/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x7F29e7086453ed97283893E763aE0989F4B70f8d", + "decimals": 6, + "name": "DGC Token", + "symbol": "DGC", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x7F29e7086453ed97283893E763aE0989F4B70f8d/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x164334Ed9E63FbEdC8B52E6dbD408Af4F051419f", + "decimals": 6, + "name": "ENXT Token", + "symbol": "ENXT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x164334Ed9E63FbEdC8B52E6dbD408Af4F051419f/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xE06fba763C2104dB5027F57f6A5Be0a0D86308af", + "decimals": 18, + "name": "Akitavax", + "symbol": "AKITAX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xE06fba763C2104dB5027F57f6A5Be0a0D86308af/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xf03Dccaec9A28200A6708c686cf0b8BF26dDc356", + "decimals": 18, + "name": "YDragon", + "symbol": "YDR", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xf03Dccaec9A28200A6708c686cf0b8BF26dDc356/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xEd2b42D3C9c6E97e11755BB37df29B6375ede3EB", + "decimals": 18, + "name": "HonToken", + "symbol": "HON", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xEd2b42D3C9c6E97e11755BB37df29B6375ede3EB/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xd9D90f882CDdD6063959A9d837B05Cb748718A05", + "decimals": 18, + "name": "More Token", + "symbol": "MORE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xd9D90f882CDdD6063959A9d837B05Cb748718A05/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x312eE43Df66d1Fd1EA28e5b28F355Da84dCA13C2", + "decimals": 12, + "name": "SwapXI Token", + "symbol": "SWAPXI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x312eE43Df66d1Fd1EA28e5b28F355Da84dCA13C2/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xfcc6CE74f4cd7eDEF0C5429bB99d38A3608043a5", + "decimals": 18, + "name": "FIRE", + "symbol": "FIRE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xfcc6CE74f4cd7eDEF0C5429bB99d38A3608043a5/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xCe2fbed816E320258161CeD52c2d0CEBcdFd8136", + "decimals": 18, + "name": "BRIBE", + "symbol": "BRIBE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xCe2fbed816E320258161CeD52c2d0CEBcdFd8136/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xe19A1684873faB5Fb694CfD06607100A632fF21c", + "decimals": 18, + "name": "BavaToken", + "symbol": "BAVA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xe19A1684873faB5Fb694CfD06607100A632fF21c/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x63a72806098Bd3D9520cC43356dD78afe5D386D9", + "decimals": 18, + "name": "Aave Token", + "symbol": "AAVE.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x63a72806098Bd3D9520cC43356dD78afe5D386D9/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x5947BB275c521040051D82396192181b413227A3", + "decimals": 18, + "name": "Chainlink Token", + "symbol": "LINK.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x5947BB275c521040051D82396192181b413227A3/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x37B608519F91f70F2EeB0e5Ed9AF4061722e4F76", + "decimals": 18, + "name": "SushiToken", + "symbol": "SUSHI.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x37B608519F91f70F2EeB0e5Ed9AF4061722e4F76/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x50b7545627a5162F82A992c33b87aDc75187B218", + "decimals": 8, + "name": "Wrapped BTC", + "symbol": "WBTC.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x50b7545627a5162F82A992c33b87aDc75187B218/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x152b9d0FdC40C096757F570A51E494bd4b943E50", + "decimals": 8, + "name": "Bitcoin", + "symbol": "BTC.b", + "logoURI": "https://raw.githubusercontent.com/traderjoe-xyz/joe-tokenlists/main/logos/0x152b9d0FdC40C096757F570A51E494bd4b943E50/logo.png" + }, + { + "chainId": 43114, + "address": "0x49D5c2BdFfac6CE2BFdB6640F4F80f226bc10bAB", + "decimals": 18, + "name": "Wrapped Ether", + "symbol": "WETH.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x49D5c2BdFfac6CE2BFdB6640F4F80f226bc10bAB/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x00EE200Df31b869a321B10400Da10b561F3ee60d", + "decimals": 18, + "name": "Arable Protocol", + "symbol": "ACRE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x00EE200Df31b869a321B10400Da10b561F3ee60d/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x2b2C81e08f1Af8835a78Bb2A90AE924ACE0eA4bE", + "decimals": 18, + "name": "Staked AVAX", + "symbol": "sAVAX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x2b2C81e08f1Af8835a78Bb2A90AE924ACE0eA4bE/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x0659133127749Cc0616Ed6632912ddF7cc8D7545", + "decimals": 18, + "name": "DefiLaunch Token", + "symbol": "DLAUNCH", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x0659133127749Cc0616Ed6632912ddF7cc8D7545/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xb67a9374Da03d4114a6FB8f0E7F2b82b5cB34ee3", + "decimals": 18, + "name": "Augmented Finance", + "symbol": "AGF", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xb67a9374Da03d4114a6FB8f0E7F2b82b5cB34ee3/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xB0a6e056B587D0a85640b39b1cB44086F7a26A1E", + "decimals": 18, + "name": "OddzToken", + "symbol": "ODDZ", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xB0a6e056B587D0a85640b39b1cB44086F7a26A1E/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xf3EC49ACb3084618121741e4BBB20996D383E9b2", + "decimals": 18, + "name": "KING", + "symbol": "KING", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xf3EC49ACb3084618121741e4BBB20996D383E9b2/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x94d649E017625dE1Aa04733aA046dE0161DF18eF", + "decimals": 18, + "name": "King Shares", + "symbol": "KSHARE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x94d649E017625dE1Aa04733aA046dE0161DF18eF/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x4960bc6032351ab87627B8F36b37B4938A44C7eF", + "decimals": 18, + "name": "RICH", + "symbol": "RICH", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4960bc6032351ab87627B8F36b37B4938A44C7eF/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x44754455564474A89358B2C2265883DF993b12F0", + "decimals": 18, + "name": "ZeroSwapToken", + "symbol": "ZEE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x44754455564474A89358B2C2265883DF993b12F0/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xD4d026322C88C2d49942A75DfF920FCfbC5614C1", + "decimals": 18, + "name": "DEAPCOIN", + "symbol": "DEP", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xD4d026322C88C2d49942A75DfF920FCfbC5614C1/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x15c841043e13fFAA9a99FabEa236D40F45615623", + "decimals": 18, + "name": "BUSINESSES", + "symbol": "BUSINESSES", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x15c841043e13fFAA9a99FabEa236D40F45615623/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x4B322765D761984C0f9E72200B62a9b445F38caC", + "decimals": 18, + "name": "dolla", + "symbol": "DOLLA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4B322765D761984C0f9E72200B62a9b445F38caC/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xc69Eba65e87889f0805dB717Af06797055A0BA07", + "decimals": 18, + "name": "NitroNetwork", + "symbol": "ncash", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xc69Eba65e87889f0805dB717Af06797055A0BA07/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x979fFD8eEd7a43629eA29581DF4Bfe2b3F224e47", + "decimals": 18, + "name": "Omlira", + "symbol": "OML", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x979fFD8eEd7a43629eA29581DF4Bfe2b3F224e47/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xE16253892F126D068E711C2fdde6DB56969dBCf6", + "decimals": 18, + "name": "Splash Token", + "symbol": "SPLASH", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4ec58f9D205F9c919920313932cc71EC68d123C7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xbc6f589171d6d66EB44ebCC92dFFb570Db4208da", + "decimals": 18, + "name": "Wave Token", + "symbol": "WAVE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xbc6f589171d6d66EB44ebCC92dFFb570Db4208da/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x97E7044ab98B7891546485f5f66EDcc2F58be106", + "decimals": 18, + "name": "EMERALD", + "symbol": "EM", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x97E7044ab98B7891546485f5f66EDcc2F58be106/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x80D18b1c9Ab0c9B5D6A6d5173575417457d00a12", + "decimals": 6, + "name": "Axelar Wrapped ATOM", + "symbol": "axlATOM", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x80D18b1c9Ab0c9B5D6A6d5173575417457d00a12/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x449674B82F05d498E126Dd6615a1057A9c088f2C", + "decimals": 18, + "name": "LostToken", + "symbol": "LOST", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x449674B82F05d498E126Dd6615a1057A9c088f2C/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x1B88D7aD51626044Ec62eF9803EA264DA4442F32", + "decimals": 18, + "name": "ZooToken", + "symbol": "ZOO", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x1B88D7aD51626044Ec62eF9803EA264DA4442F32/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x056D114fF1e01dE3BCA30F0Efa3655DF42880e5B", + "decimals": 18, + "name": "KyteOne", + "symbol": "KTE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x056D114fF1e01dE3BCA30F0Efa3655DF42880e5B/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x1111111111182587795eF1098ac7da81a108C97a", + "decimals": 18, + "name": "Bold Point Token", + "symbol": "BPT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x1111111111182587795eF1098ac7da81a108C97a/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xd13eB71515DC48a8a367D12F844e5737bab415dF", + "decimals": 18, + "name": "Spice", + "symbol": "SFI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xd13eB71515DC48a8a367D12F844e5737bab415dF/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x5a15Bdcf9a3A8e799fa4381E666466a516F2d9C8", + "decimals": 18, + "name": "Snail Trail", + "symbol": "SLIME", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x5a15Bdcf9a3A8e799fa4381E666466a516F2d9C8/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x714f020C54cc9D104B6F4f6998C63ce2a31D1888", + "decimals": 18, + "name": "STEP.APP", + "symbol": "FITFI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x714f020C54cc9D104B6F4f6998C63ce2a31D1888/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x4156F18bF7C1ef04248632C66Aa119De152D8f2E", + "decimals": 18, + "name": "Zeus Node Finance", + "symbol": "ZEUS", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4156F18bF7C1ef04248632C66Aa119De152D8f2E/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xc7198437980c041c805A1EDcbA50c1Ce5db95118", + "decimals": 6, + "name": "Tether USD", + "symbol": "USDT.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xc7198437980c041c805A1EDcbA50c1Ce5db95118/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xA7D7079b0FEaD91F3e65f86E8915Cb59c1a4C664", + "decimals": 6, + "name": "USD Coin", + "symbol": "USDC.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xA7D7079b0FEaD91F3e65f86E8915Cb59c1a4C664/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xd586E7F844cEa2F87f50152665BCbc2C279D8d70", + "decimals": 18, + "name": "Dai Stablecoin", + "symbol": "DAI.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xd586E7F844cEa2F87f50152665BCbc2C279D8d70/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x564A341Df6C126f90cf3ECB92120FD7190ACb401", + "decimals": 6, + "name": "BiLira", + "symbol": "TRYB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x564A341Df6C126f90cf3ECB92120FD7190ACb401/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x19860CCB0A68fd4213aB9D8266F7bBf05A8dDe98", + "decimals": 18, + "name": "Binance USD", + "symbol": "BUSD.e", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x19860CCB0A68fd4213aB9D8266F7bBf05A8dDe98/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x4fbf0429599460D327BD5F55625E30E4fC066095", + "decimals": 18, + "name": "TSD Stablecoin", + "symbol": "TSD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x4fbf0429599460D327BD5F55625E30E4fC066095/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x130966628846BFd36ff31a822705796e8cb8C18D", + "decimals": 18, + "name": "Magic Internet Money", + "symbol": "MIM", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x130966628846BFd36ff31a822705796e8cb8C18D/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x783C08b5F26E3daf8C4681F3bf49844e425b6393", + "decimals": 18, + "name": "Avaware USD", + "symbol": "AUSD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x783C08b5F26E3daf8C4681F3bf49844e425b6393/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x346A59146b9b4a77100D369a3d18E8007A9F46a6", + "decimals": 18, + "name": "AVAI", + "symbol": "AVAI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x346A59146b9b4a77100D369a3d18E8007A9F46a6/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xD24C2Ad096400B6FBcd2ad8B24E7acBc21A1da64", + "decimals": 18, + "name": "Frax", + "symbol": "FRAX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xD24C2Ad096400B6FBcd2ad8B24E7acBc21A1da64/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x5c49b268c9841AFF1Cc3B0a418ff5c3442eE3F3b", + "decimals": 18, + "name": "miMatic", + "symbol": "MAI", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x5c49b268c9841AFF1Cc3B0a418ff5c3442eE3F3b/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x026187BdbC6b751003517bcb30Ac7817D5B766f8", + "decimals": 18, + "name": "Defrost Finance H2O", + "symbol": "H2O", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x026187BdbC6b751003517bcb30Ac7817D5B766f8/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E", + "decimals": 6, + "name": "USD Coin", + "symbol": "USDC", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x6feFd97F328342a8A840546A55FDcfEe7542F9A8", + "decimals": 18, + "name": "agEUR", + "symbol": "agEUR", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x6feFd97F328342a8A840546A55FDcfEe7542F9A8/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x260Bbf5698121EB85e7a74f2E45E16Ce762EbE11", + "decimals": 6, + "name": "Axelar Wrapped UST", + "symbol": "axlUST", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x260Bbf5698121EB85e7a74f2E45E16Ce762EbE11/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x9702230A8Ea53601f5cD2dc00fDBc13d4dF4A8c7", + "decimals": 6, + "name": "TetherToken", + "symbol": "USDT", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x9702230A8Ea53601f5cD2dc00fDBc13d4dF4A8c7/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x0f577433Bf59560Ef2a79c124E9Ff99fCa258948", + "decimals": 18, + "name": "Moremoney USD", + "symbol": "MONEY", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x0f577433Bf59560Ef2a79c124E9Ff99fCa258948/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x431D5dfF03120AFA4bDf332c61A6e1766eF37BDB", + "decimals": 18, + "name": "JPY Coin", + "symbol": "JPYC", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x431D5dfF03120AFA4bDf332c61A6e1766eF37BDB/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xb599c3590F42f8F995ECfa0f85D2980B76862fc1", + "decimals": 6, + "name": "Wormhole UST", + "symbol": "UST", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xb599c3590F42f8F995ECfa0f85D2980B76862fc1/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x61eCd63e42C27415696e10864d70ecEA4aA11289", + "decimals": 18, + "name": "Rugpull Prevention", + "symbol": "RUGPULL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x61eCd63e42C27415696e10864d70ecEA4aA11289/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xcF8419A615c57511807236751c0AF38Db4ba3351", + "decimals": 18, + "name": "AxialToken", + "symbol": "AXIAL", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xcF8419A615c57511807236751c0AF38Db4ba3351/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x491a4eB4f1FC3BfF8E1d2FC856a6A46663aD556f", + "decimals": 4, + "name": "BRZ", + "symbol": "BRZ", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x491a4eB4f1FC3BfF8E1d2FC856a6A46663aD556f/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x827eb4bada6cb76c90f887969b3fe5faD585FFe3", + "decimals": 18, + "name": "XETA", + "symbol": "XETA", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x827eb4bada6cb76c90f887969b3fe5faD585FFe3/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x6B56Ec4a92765203508FB40feC9fa23E549B705a", + "decimals": 18, + "name": "Unbound Dollar", + "symbol": "UND", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x6B56Ec4a92765203508FB40feC9fa23E549B705a/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xF915fDDa4c882731C0456a4214548Cd13A822886", + "decimals": 18, + "name": "Unbound", + "symbol": "UNB", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xF915fDDa4c882731C0456a4214548Cd13A822886/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x51e48670098173025C477D9AA3f0efF7BF9f7812", + "decimals": 18, + "name": "DegenX", + "symbol": "DGNX", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x51e48670098173025C477D9AA3f0efF7BF9f7812/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xcf799767d366d789e8B446981C2D578E241fa25c", + "decimals": 18, + "name": "Decentralized USD", + "symbol": "USDD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xcf799767d366d789e8B446981C2D578E241fa25c/logo_24.png" + }, + { + "chainId": 43114, + "address": "0x9C9e5fD8bbc25984B178FdCE6117Defa39d2db39", + "decimals": 18, + "name": "BUSD Token", + "symbol": "BUSD", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0x9C9e5fD8bbc25984B178FdCE6117Defa39d2db39/logo_24.png" + }, + { + "chainId": 43114, + "address": "0xbBAAA0420D474B34Be197f95A323C2fF3829E811", + "decimals": 18, + "name": "LODE Token", + "symbol": "LODE", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/43114/0xbBAAA0420D474B34Be197f95A323C2fF3829E811/logo_24.png" + }, + { + "chainId": 80001, + "address": "0x4828a3D98E428e73184374845f23C40eB76bA695", + "decimals": 18, + "name": "Pangolin", + "symbol": "mumbaiPNG", + "logoURI": "https://raw.githubusercontent.com/pangolindex/tokens/main/assets/80001/0x4828a3D98E428e73184374845f23C40eB76bA695/logo_24.png" + } + ] + } \ No newline at end of file diff --git a/src/chains/binance-smart-chain/bep20_tokens_mainnet.json b/src/chains/binance-smart-chain/bep20_tokens_mainnet.json new file mode 100755 index 0000000000..a01e11ca3f --- /dev/null +++ b/src/chains/binance-smart-chain/bep20_tokens_mainnet.json @@ -0,0 +1,990 @@ +{ + "name": "PancakeSwap Default List", + "timestamp": "2021-03-17T09:56:23Z", + "version": { + "major": 2, + "minor": 0, + "patch": 1 + }, + "tags": {}, + "logoURI": "https://exchange.pancakeswap.finance/images/pancakeswap.png", + "keywords": ["pancake", "default"], + "tokens": [ + { + "name": "WBNB Token", + "symbol": "WBNB", + "address": "0xbb4cdb9cbd36b01bd1cbaebf2de08d9173bc095c", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbb4cdb9cbd36b01bd1cbaebf2de08d9173bc095c.png" + }, + { + "name": "Bakery Token", + "symbol": "BAKE", + "address": "0xe02df9e3e622debdd69fb838bb799e3f168902c5", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xe02df9e3e622debdd69fb838bb799e3f168902c5.png" + }, + { + "name": "BUSD Token", + "symbol": "BUSD", + "address": "0xe9e7cea3dedca5984780bafc599bd69add087d56", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xe9e7cea3dedca5984780bafc599bd69add087d56.png" + }, + { + "name": "Ethereum Token", + "symbol": "ETH", + "address": "0x2170ed0880ac9a755fd29b2688956bd959f933f8", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x2170ed0880ac9a755fd29b2688956bd959f933f8.png" + }, + { + "name": "BTCB Token", + "symbol": "BTCB", + "address": "0x7130d2a12b9bcbfae4f2634d864a1ee1ce3ead9c", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x7130d2a12b9bcbfae4f2634d864a1ee1ce3ead9c.png" + }, + { + "name": "BAND Protocol Token", + "symbol": "BAND", + "address": "0xad6caeb32cd2c308980a548bd0bc5aa4306c6c18", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xad6caeb32cd2c308980a548bd0bc5aa4306c6c18.png" + }, + { + "name": "EOS Token", + "symbol": "EOS", + "address": "0x56b6fb708fc5732dec1afc8d8556423a2edccbd6", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x56b6fb708fc5732dec1afc8d8556423a2edccbd6.png" + }, + { + "name": "Tether USD", + "symbol": "USDT", + "address": "0x55d398326f99059ff775485246999027b3197955", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x55d398326f99059ff775485246999027b3197955.png" + }, + { + "name": "XRP Token", + "symbol": "XRP", + "address": "0x1d2f0da169ceb9fc7b3144628db156f3f6c60dbe", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1d2f0da169ceb9fc7b3144628db156f3f6c60dbe.png" + }, + { + "name": "Bitcoin Cash Token", + "symbol": "BCH", + "address": "0x8ff795a6f4d97e7887c79bea79aba5cc76444adf", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x8ff795a6f4d97e7887c79bea79aba5cc76444adf.png" + }, + { + "name": "Litecoin Token", + "symbol": "LTC", + "address": "0x4338665cbb7b2485a8855a139b75d5e34ab0db94", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x4338665cbb7b2485a8855a139b75d5e34ab0db94.png" + }, + { + "name": "Cardano Token", + "symbol": "ADA", + "address": "0x3ee2200efb3400fabb9aacf31297cbdd1d435d47", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x3ee2200efb3400fabb9aacf31297cbdd1d435d47.png" + }, + { + "name": "Cosmos Token", + "symbol": "ATOM", + "address": "0x0eb3a705fc54725037cc9e008bdede697f62f335", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x0eb3a705fc54725037cc9e008bdede697f62f335.png" + }, + { + "name": "Tezos Token", + "symbol": "XTZ", + "address": "0x16939ef78684453bfdfb47825f8a5f714f12623a", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x16939ef78684453bfdfb47825f8a5f714f12623a.png" + }, + { + "name": "Ontology Token", + "symbol": "ONT", + "address": "0xfd7b3a77848f1c2d67e05e54d78d174a0c850335", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xfd7b3a77848f1c2d67e05e54d78d174a0c850335.png" + }, + { + "name": "Zcash Token", + "symbol": "ZEC", + "address": "0x1ba42e5193dfa8b03d15dd1b86a3113bbbef8eeb", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1ba42e5193dfa8b03d15dd1b86a3113bbbef8eeb.png" + }, + { + "name": "Dai Token", + "symbol": "DAI", + "address": "0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3.png" + }, + { + "name": "YFII.finance Token", + "symbol": "YFII", + "address": "0x7f70642d88cf1c4a3a7abb072b53b929b653eda5", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x7f70642d88cf1c4a3a7abb072b53b929b653eda5.png" + }, + { + "name": "Cream", + "symbol": "CREAM", + "address": "0xd4cb328a82bdf5f03eb737f37fa6b370aef3e888", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xd4cb328a82bdf5f03eb737f37fa6b370aef3e888.png" + }, + { + "name": "Prometeus", + "symbol": "PROM", + "address": "0xaf53d56ff99f1322515e54fdde93ff8b3b7dafd5", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xaf53d56ff99f1322515e54fdde93ff8b3b7dafd5.png" + }, + { + "name": "CanYaCoin", + "symbol": "CAN", + "address": "0x007ea5c0ea75a8df45d288a4debdd5bb633f9e56", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x007ea5c0ea75a8df45d288a4debdd5bb633f9e56.png" + }, + { + "name": "Polkadot Token", + "symbol": "DOT", + "address": "0x7083609fce4d1d8dc0c979aab8c869ea2c873402", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x7083609fce4d1d8dc0c979aab8c869ea2c873402.png" + }, + { + "name": "PancakeSwap Token", + "symbol": "CAKE", + "address": "0x0e09fabb73bd3ade0a17ecc321fd13a19e81ce82", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x0e09fabb73bd3ade0a17ecc321fd13a19e81ce82.png" + }, + { + "name": "Streamity", + "symbol": "STM", + "address": "0x90df11a8cce420675e73922419e3f4f3fe13cccb", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x90df11a8cce420675e73922419e3f4f3fe13cccb.png" + }, + { + "name": "Ankr", + "symbol": "ANKR", + "address": "0xf307910a4c7bbc79691fd374889b36d8531b08e3", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf307910a4c7bbc79691fd374889b36d8531b08e3.png" + }, + { + "name": "ChainLink Token", + "symbol": "LINK", + "address": "0xf8a0bf9cf54bb92f17374d9e9a321e6a111a51bd", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf8a0bf9cf54bb92f17374d9e9a321e6a111a51bd.png" + }, + { + "name": "Burger Swap", + "symbol": "BURGER", + "address": "0xae9269f27437f0fcbc232d39ec814844a51d6b8f", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xae9269f27437f0fcbc232d39ec814844a51d6b8f.png" + }, + { + "name": "Dice.finance Token", + "symbol": "DICE", + "address": "0x748ad98b14c814b28812eb42ad219c8672909879", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x748ad98b14c814b28812eb42ad219c8672909879.png" + }, + { + "name": "JNTR/b", + "symbol": "JNTR/b", + "address": "0x3c037c4c2296f280bb318d725d0b454b76c199b9", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x3c037c4c2296f280bb318d725d0b454b76c199b9.png" + }, + { + "name": "SPARTAN PROTOCOL TOKEN", + "symbol": "SPART", + "address": "0xe4ae305ebe1abe663f261bc00534067c80ad677c", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xe4ae305ebe1abe663f261bc00534067c80ad677c.png" + }, + { + "name": "Trust Wallet", + "symbol": "TWT", + "address": "0x4b0f1812e5df2a09796481ff14017e6005508003", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x4b0f1812e5df2a09796481ff14017e6005508003.png" + }, + { + "name": "Venus", + "symbol": "XVS", + "address": "0xcf6bb5389c92bdda8a3747ddb454cb7a64626c63", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xcf6bb5389c92bdda8a3747ddb454cb7a64626c63.png" + }, + { + "name": "Beer Garden", + "symbol": "Beer", + "address": "0xbb8db5e17bbe9c90da8e3445e335b82d7cc53575", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbb8db5e17bbe9c90da8e3445e335b82d7cc53575.png" + }, + { + "name": "AlphaToken", + "symbol": "ALPHA", + "address": "0xa1faa113cbe53436df28ff0aee54275c13b40975", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xa1faa113cbe53436df28ff0aee54275c13b40975.png" + }, + { + "name": "Beefy.finance", + "symbol": "BIFI", + "address": "0xCa3F508B8e4Dd382eE878A314789373D80A5190A", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xCa3F508B8e4Dd382eE878A314789373D80A5190A.png" + }, + { + "name": "yearn.finance", + "symbol": "YFI", + "address": "0x88f1a5ae2a3bf98aeaf342d26b30a79438c9142e", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x88f1a5ae2a3bf98aeaf342d26b30a79438c9142e.png" + }, + { + "name": "Uniswap", + "symbol": "UNI", + "address": "0xbf5140a22578168fd562dccf235e5d43a02ce9b1", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbf5140a22578168fd562dccf235e5d43a02ce9b1.png" + }, + { + "name": "fry.world", + "symbol": "FRIES", + "address": "0x393B312C01048b3ed2720bF1B090084C09e408A1", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x393B312C01048b3ed2720bF1B090084C09e408A1.png" + }, + { + "name": "StableXSwap", + "symbol": "STAX", + "address": "0x0da6ed8b13214ff28e9ca979dd37439e8a88f6c4", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x0da6ed8b13214ff28e9ca979dd37439e8a88f6c4.png" + }, + { + "name": "Filecoin", + "symbol": "FIL", + "address": "0x0d8ce2a99bb6e3b7db580ed848240e4a0f9ae153", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x0d8ce2a99bb6e3b7db580ed848240e4a0f9ae153.png" + }, + { + "name": "KAVA", + "symbol": "KAVA", + "address": "0x5F88AB06e8dfe89DF127B2430Bba4Af600866035", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x5F88AB06e8dfe89DF127B2430Bba4Af600866035.png" + }, + { + "name": "USDX", + "symbol": "USDX", + "address": "0x1203355742e76875154c0d13eb81dcd7711dc7d9", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1203355742e76875154c0d13eb81dcd7711dc7d9.png" + }, + { + "name": "Injective Protocol", + "symbol": "INJ", + "address": "0xa2B726B1145A4773F68593CF171187d8EBe4d495", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xa2B726B1145A4773F68593CF171187d8EBe4d495.png" + }, + { + "name": "Swipe", + "symbol": "SXP", + "address": "0x47bead2563dcbf3bf2c9407fea4dc236faba485a", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x47bead2563dcbf3bf2c9407fea4dc236faba485a.png" + }, + { + "name": "Binance-Peg USD Coin", + "symbol": "USDC", + "address": "0x8ac76a51cc950d9822d68b83fe1ad97b32cd580d", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x8ac76a51cc950d9822d68b83fe1ad97b32cd580d.png" + }, + { + "name": "CertiK Token", + "symbol": "CTK", + "address": "0xa8c2b8eec3d368c0253ad3dae65a5f2bbb89c929", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xa8c2b8eec3d368c0253ad3dae65a5f2bbb89c929.png" + }, + { + "name": "NAR Token", + "symbol": "NAR", + "address": "0xa1303e6199b319a891b79685f0537d289af1fc83", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xa1303e6199b319a891b79685f0537d289af1fc83.png" + }, + { + "name": "Nyanswop Token", + "symbol": "NYA", + "address": "0xbfa0841f7a90c4ce6643f651756ee340991f99d5", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbfa0841f7a90c4ce6643f651756ee340991f99d5.png" + }, + { + "name": "DANGO", + "symbol": "DANGO", + "address": "0x0957c57c9eb7744850dcc95db5a06ed4a246236e", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x0957c57c9eb7744850dcc95db5a06ed4a246236e.png" + }, + { + "name": "HARD", + "symbol": "HARD", + "address": "0xf79037f6f6be66832de4e7516be52826bc3cbcc4", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf79037f6f6be66832de4e7516be52826bc3cbcc4.png" + }, + { + "name": "ROOBEE", + "symbol": "bROOBEE", + "address": "0xe64f5cb844946c1f102bd25bbd87a5ab4ae89fbe", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xe64f5cb844946c1f102bd25bbd87a5ab4ae89fbe.png" + }, + { + "name": "Unifi Token", + "symbol": "UNFI", + "address": "0x728C5baC3C3e370E372Fc4671f9ef6916b814d8B", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x728C5baC3C3e370E372Fc4671f9ef6916b814d8B.png" + }, + { + "name": "BLINk", + "symbol": "BLK", + "address": "0x63870A18B6e42b01Ef1Ad8A2302ef50B7132054F", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x63870A18B6e42b01Ef1Ad8A2302ef50B7132054F.png" + }, + { + "name": "QUSD Stablecoin", + "symbol": "QUSD", + "address": "0xb8C540d00dd0Bf76ea12E4B4B95eFC90804f924E", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xb8C540d00dd0Bf76ea12E4B4B95eFC90804f924E.png" + }, + { + "name": "Qian Governance Token", + "symbol": "KUN", + "address": "0x1A2fb0Af670D0234c2857FaD35b789F8Cb725584", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1A2fb0Af670D0234c2857FaD35b789F8Cb725584.png" + }, + { + "name": "VAI Stablecoin", + "symbol": "VAI", + "address": "0x4bd17003473389a42daf6a0a729f6fdb328bbbd7", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x4bd17003473389a42daf6a0a729f6fdb328bbbd7.png" + }, + { + "name": "Juventus", + "symbol": "JUV", + "address": "0xc40c9a843e1c6d01b7578284a9028854f6683b1b", + "chainId": 56, + "decimals": 2, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xc40c9a843e1c6d01b7578284a9028854f6683b1b.png" + }, + { + "name": "Paris Saint-Germain", + "symbol": "PSG", + "address": "0xbc5609612b7c44bef426de600b5fd1379db2ecf1", + "chainId": 56, + "decimals": 2, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbc5609612b7c44bef426de600b5fd1379db2ecf1.png" + }, + { + "name": "Ditto", + "symbol": "DITTO", + "address": "0x233d91A0713155003fc4DcE0AFa871b508B3B715", + "chainId": 56, + "decimals": 9, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x233d91A0713155003fc4DcE0AFa871b508B3B715.png" + }, + { + "name": "Math", + "symbol": "MATH", + "address": "0xf218184af829cf2b0019f8e6f0b2423498a36983", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf218184af829cf2b0019f8e6f0b2423498a36983.png" + }, + { + "name": "Fuel", + "symbol": "FUEL", + "address": "0x2090c8295769791ab7A3CF1CC6e0AA19F35e441A", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x2090c8295769791ab7A3CF1CC6e0AA19F35e441A.png" + }, + { + "name": "Nuls", + "symbol": "NULS", + "address": "0x8cd6e29d3686d24d3c2018cee54621ea0f89313b", + "chainId": 56, + "decimals": 8, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x8cd6e29d3686d24d3c2018cee54621ea0f89313b.png" + }, + { + "name": "NerveNetwork", + "symbol": "NVT", + "address": "0xf0e406c49c63abf358030a299c0e00118c4c6ba5", + "chainId": 56, + "decimals": 8, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf0e406c49c63abf358030a299c0e00118c4c6ba5.png" + }, + { + "name": "Reef", + "symbol": "REEF", + "address": "0xf21768ccbc73ea5b6fd3c687208a7c2def2d966e", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf21768ccbc73ea5b6fd3c687208a7c2def2d966e.png" + }, + { + "name": "OG", + "symbol": "OG", + "address": "0xf05e45ad22150677a017fbd94b84fbb63dc9b44c", + "chainId": 56, + "decimals": 2, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf05e45ad22150677a017fbd94b84fbb63dc9b44c.png" + }, + { + "name": "Atletico de Madrid", + "symbol": "ATM", + "address": "0x25e9d05365c867e59c1904e7463af9f312296f9e", + "chainId": 56, + "decimals": 2, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x25e9d05365c867e59c1904e7463af9f312296f9e.png" + }, + { + "name": "AS Roma", + "symbol": "ASR", + "address": "0x80d5f92c2c8c682070c95495313ddb680b267320", + "chainId": 56, + "decimals": 2, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x80d5f92c2c8c682070c95495313ddb680b267320.png" + }, + { + "name": "AllianceBlock", + "symbol": "bALBT", + "address": "0x72faa679e1008ad8382959ff48e392042a8b06f7", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x72faa679e1008ad8382959ff48e392042a8b06f7.png" + }, + { + "name": "Tenet", + "symbol": "TEN", + "address": "0xdff8cb622790b7f92686c722b02cab55592f152c", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xdff8cb622790b7f92686c722b02cab55592f152c.png" + }, + { + "name": "Helmet.insure", + "symbol": "Helmet", + "address": "0x948d2a81086a075b3130bac19e4c6dee1d2e3fe8", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x948d2a81086a075b3130bac19e4c6dee1d2e3fe8.png" + }, + { + "name": "BSCEX", + "symbol": "BSCX", + "address": "0x5ac52ee5b2a633895292ff6d8a89bb9190451587", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x5ac52ee5b2a633895292ff6d8a89bb9190451587.png" + }, + { + "name": "Standard BTC Hashrate Token", + "symbol": "BTCST", + "address": "0x78650b139471520656b9e7aa7a5e9276814a38e9", + "chainId": 56, + "decimals": 17, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x78650b139471520656b9e7aa7a5e9276814a38e9.png" + }, + { + "name": "Frontier Token", + "symbol": "FRONT", + "address": "0x928e55daB735aa8260AF3cEDadA18B5f70C72f1b", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x928e55daB735aa8260AF3cEDadA18B5f70C72f1b.png" + }, + { + "name": "Soteria", + "symbol": "wSOTE", + "address": "0x541e619858737031a1244a5d0cd47e5ef480342c", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x541e619858737031a1244a5d0cd47e5ef480342c.png" + }, + { + "name": "Mirror TSLA Token", + "symbol": "mTSLA", + "address": "0xF215A127A196e3988C09d052e16BcFD365Cd7AA3", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xF215A127A196e3988C09d052e16BcFD365Cd7AA3.png" + }, + { + "name": "Mirror AMZN Token", + "symbol": "mAMZN", + "address": "0x3947B992DC0147D2D89dF0392213781b04B25075", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x3947B992DC0147D2D89dF0392213781b04B25075.png" + }, + { + "name": "Mirror NFLX Token", + "symbol": "mNFLX", + "address": "0xa04F060077D90Fe2647B61e4dA4aD1F97d6649dc", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xa04F060077D90Fe2647B61e4dA4aD1F97d6649dc.png" + }, + { + "name": "Mirror GOOGL Token", + "symbol": "mGOOGL", + "address": "0x62D71B23bF15218C7d2D7E48DBbD9e9c650B173f", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x62D71B23bF15218C7d2D7E48DBbD9e9c650B173f.png" + }, + { + "name": "UST Token", + "symbol": "UST", + "address": "0x23396cF899Ca06c4472205fC903bDB4de249D6fC", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x23396cF899Ca06c4472205fC903bDB4de249D6fC.png" + }, + { + "name": "b.earnfi", + "symbol": "BFI", + "address": "0x81859801b01764D4f0Fa5E64729f5a6C3b91435b", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x81859801b01764D4f0Fa5E64729f5a6C3b91435b.png" + }, + { + "name": "bDollar", + "symbol": "BDO", + "address": "0x190b589cf9Fb8DDEabBFeae36a813FFb2A702454", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x190b589cf9Fb8DDEabBFeae36a813FFb2A702454.png" + }, + { + "name": "bDollar Share", + "symbol": "sBDO", + "address": "0x0d9319565be7f53CeFE84Ad201Be3f40feAE2740", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x0d9319565be7f53CeFE84Ad201Be3f40feAE2740.png" + }, + { + "name": "Elrond", + "symbol": "EGLD", + "address": "0xbf7c81fff98bbe61b40ed186e4afd6ddd01337fe", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbf7c81fff98bbe61b40ed186e4afd6ddd01337fe.png" + }, + { + "name": "AUTOv2", + "symbol": "AUTO", + "address": "0xa184088a740c695e156f91f5cc086a06bb78b827", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xa184088a740c695e156f91f5cc086a06bb78b827.png" + }, + { + "name": "Hedget", + "symbol": "HGET", + "address": "0xC7d8D35EBA58a0935ff2D5a33Df105DD9f071731", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xC7d8D35EBA58a0935ff2D5a33Df105DD9f071731.png" + }, + { + "name": "Litentry", + "symbol": "LIT", + "address": "0xb59490ab09a0f526cc7305822ac65f2ab12f9723", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xb59490ab09a0f526cc7305822ac65f2ab12f9723.png" + }, + { + "name": "Linear Finance", + "symbol": "LINA", + "address": "0x762539b45a1dcce3d36d080f74d1aed37844b878", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x762539b45a1dcce3d36d080f74d1aed37844b878.png" + }, + { + "name": "Beacon ETH", + "symbol": "BETH", + "address": "0x250632378e573c6be1ac2f97fcdf00515d0aa91b", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x250632378e573c6be1ac2f97fcdf00515d0aa91b.png" + }, + { + "name": "lUSD", + "symbol": "lUSD", + "address": "0x23e8a70534308a4AAF76fb8C32ec13d17a3BD89e", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x23e8a70534308a4AAF76fb8C32ec13d17a3BD89e.png" + }, + { + "name": "SafePal Token", + "symbol": "SFP", + "address": "0xd41fdb03ba84762dd66a0af1a6c8540ff1ba5dfb", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xd41fdb03ba84762dd66a0af1a6c8540ff1ba5dfb.png" + }, + { + "name": "Compound Finance", + "symbol": "COMP", + "address": "0x52ce071bd9b1c4b00a0b92d298c512478cad67e8", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x52ce071bd9b1c4b00a0b92d298c512478cad67e8.png" + }, + { + "name": "Swirge Pay", + "symbol": "SWGb", + "address": "0xe40255c5d7fa7ceec5120408c78c787cecb4cfdb", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xe40255c5d7fa7ceec5120408c78c787cecb4cfdb.png" + }, + { + "name": "renBTC", + "symbol": "renBTC", + "address": "0xfCe146bF3146100cfe5dB4129cf6C82b0eF4Ad8c", + "chainId": 56, + "decimals": 8, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xfCe146bF3146100cfe5dB4129cf6C82b0eF4Ad8c.png" + }, + { + "name": "renDOGE", + "symbol": "renDOGE", + "address": "0xc3fed6eb39178a541d274e6fc748d48f0ca01cc3", + "chainId": 56, + "decimals": 8, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xc3fed6eb39178a541d274e6fc748d48f0ca01cc3.png" + }, + { + "name": "anyMTLX", + "symbol": "anyMTLX", + "address": "0x5921dee8556c4593eefcfad3ca5e2f618606483b", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x5921dee8556c4593eefcfad3ca5e2f618606483b.png" + }, + { + "name": "ZeroSwapToken", + "symbol": "ZEE", + "address": "0x44754455564474a89358b2c2265883df993b12f0", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x44754455564474a89358b2c2265883df993b12f0.png" + }, + { + "name": "Berry", + "symbol": "BRY", + "address": "0xf859Bf77cBe8699013d6Dbc7C2b926Aaf307F830", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xf859Bf77cBe8699013d6Dbc7C2b926Aaf307F830.png" + }, + { + "name": "Swingby", + "symbol": "SWINGBY", + "address": "0x71DE20e0C4616E7fcBfDD3f875d568492cBE4739", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x71DE20e0C4616E7fcBfDD3f875d568492cBE4739.png" + }, + { + "name": "Dodo", + "symbol": "DODO", + "address": "0x67ee3cb086f8a16f34bee3ca72fad36f7db929e2", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x67ee3cb086f8a16f34bee3ca72fad36f7db929e2.png" + }, + { + "name": "Sushi", + "symbol": "SUSHI", + "address": "0x947950bcc74888a40ffa2593c5798f11fc9124c4", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x947950bcc74888a40ffa2593c5798f11fc9124c4.png" + }, + { + "name": "OPEN Governance Token", + "symbol": "bOPEN", + "address": "0xF35262a9d427F96d2437379eF090db986eaE5d42", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xF35262a9d427F96d2437379eF090db986eaE5d42.png" + }, + { + "name": "BoringDAO", + "symbol": "BOR", + "address": "0x92d7756c60dcfd4c689290e8a9f4d263b3b32241", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x92d7756c60dcfd4c689290e8a9f4d263b3b32241.png" + }, + { + "name": "renZEC", + "symbol": "renZEC", + "address": "0x695FD30aF473F2960e81Dc9bA7cB67679d35EDb7", + "chainId": 56, + "decimals": 8, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x695FD30aF473F2960e81Dc9bA7cB67679d35EDb7.png" + }, + { + "name": "Multiplier", + "symbol": "bMXX", + "address": "0x4131b87f74415190425ccd873048c708f8005823", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x4131b87f74415190425ccd873048c708f8005823.png" + }, + { + "name": "IoTeX", + "symbol": "IOTX", + "address": "0x9678e42cebeb63f23197d726b29b1cb20d0064e5", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x9678e42cebeb63f23197d726b29b1cb20d0064e5.png" + }, + { + "name": "xMARK", + "symbol": "xMARK", + "address": "0x26a5dfab467d4f58fb266648cae769503cec9580", + "chainId": 56, + "decimals": 9, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x26a5dfab467d4f58fb266648cae769503cec9580.png" + }, + { + "name": "TokenPocket", + "symbol": "TPT", + "address": "0xeca41281c24451168a37211f0bc2b8645af45092", + "chainId": 56, + "decimals": 4, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xeca41281c24451168a37211f0bc2b8645af45092.png" + }, + { + "name": "Yieldwatch", + "symbol": "WATCH", + "address": "0x7a9f28eb62c791422aa23ceae1da9c847cbec9b0", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x7a9f28eb62c791422aa23ceae1da9c847cbec9b0.png" + }, + { + "name": "Bella Protocol", + "symbol": "BEL", + "address": "0x8443f091997f06a61670b735ed92734f5628692f", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x8443f091997f06a61670b735ed92734f5628692f.png" + }, + { + "name": "DeXe", + "symbol": "DEXE", + "address": "0x039cb485212f996a9dbb85a9a75d898f94d38da6", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x039cb485212f996a9dbb85a9a75d898f94d38da6.png" + }, + { + "name": "Ramp DEFI", + "symbol": "RAMP", + "address": "0x8519ea49c997f50ceffa444d240fb655e89248aa", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x8519ea49c997f50ceffa444d240fb655e89248aa.png" + }, + { + "name": "Belt", + "symbol": "BELT", + "address": "0xE0e514c71282b6f4e823703a39374Cf58dc3eA4f", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xE0e514c71282b6f4e823703a39374Cf58dc3eA4f.png" + }, + { + "name": "Basic Attention Token", + "symbol": "BAT", + "address": "0x101d82428437127bf1608f699cd651e6abf9766e", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x101d82428437127bf1608f699cd651e6abf9766e.png" + }, + { + "name": "BUX", + "symbol": "BUX", + "address": "0x211ffbe424b90e25a15531ca322adf1559779e45", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x211ffbe424b90e25a15531ca322adf1559779e45.png" + }, + { + "name": "ForTube", + "symbol": "FOR", + "address": "0x658A109C5900BC6d2357c87549B651670E5b0539", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x658A109C5900BC6d2357c87549B651670E5b0539.png" + }, + { + "name": "My Neigbor Alice", + "symbol": "ALICE", + "address": "0xac51066d7bec65dc4589368da368b212745d63e8", + "chainId": 56, + "decimals": 6, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xac51066d7bec65dc4589368da368b212745d63e8.png" + }, + { + "name": "Pancake Bunny", + "symbol": "BUNNY", + "address": "0xc9849e6fdb743d08faee3e34dd2d1bc69ea11a51", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xc9849e6fdb743d08faee3e34dd2d1bc69ea11a51.png" + }, + { + "name": "Dego.Finance", + "symbol": "DEGO", + "address": "0x3fda9383a84c05ec8f7630fe10adf1fac13241cc", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x3fda9383a84c05ec8f7630fe10adf1fac13241cc.png" + }, + { + "name": "LTO Network", + "symbol": "LTO", + "address": "0x857b222fc79e1cbbf8ca5f78cb133d1b7cf34bbd", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x857b222fc79e1cbbf8ca5f78cb133d1b7cf34bbd.png" + }, + { + "name": "Contentos", + "symbol": "COS", + "address": "0x96dd399f9c3afda1f194182f71600f1b65946501", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x96dd399f9c3afda1f194182f71600f1b65946501.png" + }, + { + "name": "Tixl", + "symbol": "TXL", + "address": "0x1ffd0b47127fdd4097e54521c9e2c7f0d66aafc5", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1ffd0b47127fdd4097e54521c9e2c7f0d66aafc5.png" + }, + { + "name": "Alpaca", + "symbol": "ALPACA", + "address": "0x8f0528ce5ef7b51152a59745befdd91d97091d2f", + "chainId": 56, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x8f0528ce5ef7b51152a59745befdd91d97091d2f.png" + } + ] +} diff --git a/src/chains/binance-smart-chain/bep20_tokens_testnet.json b/src/chains/binance-smart-chain/bep20_tokens_testnet.json new file mode 100755 index 0000000000..1f1b094fb6 --- /dev/null +++ b/src/chains/binance-smart-chain/bep20_tokens_testnet.json @@ -0,0 +1,53 @@ +{ + "name": "BSC Testnet Token List", + "logoURI": "https://bsctokenlists.org/static/media/color.657056ae.png", + "version": { + "major": 0, + "minor": 2, + "patch": 0 + }, + "keywords": [], + "timestamp": "2022-07-15T00:00:00+00:00", + "tokens": [ + { + "name": "WBNB Token", + "symbol": "WBNB", + "address": "0xae13d989dac2f0debff460ac112a837c89baa7cd", + "chainId": 97, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xbb4cdb9cbd36b01bd1cbaebf2de08d9173bc095c.png" + }, + { + "name": "BUSD Token", + "symbol": "BUSD", + "address": "0x78867BbEeF44f2326bF8DDd1941a4439382EF2A7", + "chainId": 97, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0xe9e7cea3dedca5984780bafc599bd69add087d56.png" + }, + { + "name": "Ethereum Token", + "symbol": "ETH", + "address": "0x8babbb98678facc7342735486c851abd7a0d17ca", + "chainId": 97, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x2170ed0880ac9a755fd29b2688956bd959f933f8.png" + }, + { + "name": "Tether USD", + "symbol": "USDT", + "address": "0x7ef95a0fee0dd31b22626fa2e10ee6a223f8a684", + "chainId": 97, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x55d398326f99059ff775485246999027b3197955.png" + }, + { + "name": "Dai Token", + "symbol": "DAI", + "address": "0x8a9424745056Eb399FD19a0EC26A14316684e274", + "chainId": 97, + "decimals": 18, + "logoURI": "https://exchange.pancakeswap.finance/images/coins/0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3.png" + } + ] +} diff --git a/src/chains/binance-smart-chain/binance-smart-chain.ts b/src/chains/binance-smart-chain/binance-smart-chain.ts new file mode 100644 index 0000000000..117a78f6c7 --- /dev/null +++ b/src/chains/binance-smart-chain/binance-smart-chain.ts @@ -0,0 +1,116 @@ +import abi from '../../services/ethereum.abi.json'; +import { logger } from '../../services/logger'; +import { Contract, Transaction, Wallet } from 'ethers'; +import { EthereumBase } from '../../services/ethereum-base'; +import { getEthereumConfig as getBinanceSmartChainConfig } from '../ethereum/ethereum.config'; +import { Provider } from '@ethersproject/abstract-provider'; +import { Ethereumish } from '../../services/common-interfaces'; +import { PancakeSwapConfig } from '../../connectors/pancakeswap/pancakeswap.config'; +import { SushiswapConfig } from '../../connectors/sushiswap/sushiswap.config'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export class BinanceSmartChain extends EthereumBase implements Ethereumish { + private static _instances: { [name: string]: BinanceSmartChain }; + private _chain: string; + private _gasPrice: number; + private _gasPriceRefreshInterval: number | null; + private _nativeTokenSymbol: string; + + private constructor(network: string) { + const config = getBinanceSmartChainConfig('binance-smart-chain', network); + super( + 'binance-smart-chain', + config.network.chainID, + config.network.nodeURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.nonceDbPath'), + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = config.network.name; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + this._gasPrice = config.manualGasPrice; + this._gasPriceRefreshInterval = + config.network.gasPriceRefreshInterval !== undefined + ? config.network.gasPriceRefreshInterval + : null; + + this.updateGasPrice(); + } + + public static getInstance(network: string): BinanceSmartChain { + if (BinanceSmartChain._instances === undefined) { + BinanceSmartChain._instances = {}; + } + if (!(network in BinanceSmartChain._instances)) { + BinanceSmartChain._instances[network] = new BinanceSmartChain(network); + } + + return BinanceSmartChain._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: BinanceSmartChain } { + return BinanceSmartChain._instances; + } + + /** + * Automatically update the prevailing gas price on the network from the connected RPC node. + */ + async updateGasPrice(): Promise { + if (this._gasPriceRefreshInterval === null) { + return; + } + + const gasPrice: number = (await this.provider.getGasPrice()).toNumber(); + + this._gasPrice = gasPrice * 1e-9; + + setTimeout( + this.updateGasPrice.bind(this), + this._gasPriceRefreshInterval * 1000 + ); + } + + // getters + + public get gasPrice(): number { + return this._gasPrice; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get chain(): string { + return this._chain; + } + + getContract(tokenAddress: string, signerOrProvider?: Wallet | Provider) { + return new Contract(tokenAddress, abi.ERC20Abi, signerOrProvider); + } + + getSpender(reqSpender: string): string { + let spender: string; + if (reqSpender === 'pancakeswap') { + spender = PancakeSwapConfig.config.routerAddress(this._chain); + } else if (reqSpender === 'sushiswap') { + spender = SushiswapConfig.config.sushiswapRouterAddress( + this.chainName, + this._chain + ); + } else { + spender = reqSpender; + } + return spender; + } + + // cancel transaction + async cancelTx(wallet: Wallet, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return super.cancelTxWithGasPrice(wallet, nonce, this._gasPrice * 2); + } +} diff --git a/src/chains/cosmos/cosmos-middlewares.ts b/src/chains/cosmos/cosmos-middlewares.ts new file mode 100644 index 0000000000..f252de081b --- /dev/null +++ b/src/chains/cosmos/cosmos-middlewares.ts @@ -0,0 +1,15 @@ +import { Cosmos } from './cosmos'; +import { NextFunction, Request, Response } from 'express'; +import { CosmosConfig } from './cosmos.config'; + +export const verifyCosmosIsAvailable = async ( + _req: Request, + _res: Response, + next: NextFunction +) => { + const cosmos = Cosmos.getInstance(CosmosConfig.config.network.name); + if (!cosmos.ready()) { + await cosmos.init(); + } + return next(); +}; diff --git a/src/chains/cosmos/cosmos.config.ts b/src/chains/cosmos/cosmos.config.ts new file mode 100644 index 0000000000..9204ed1e29 --- /dev/null +++ b/src/chains/cosmos/cosmos.config.ts @@ -0,0 +1,39 @@ +import { TokenListType } from '../../services/base'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +export interface NetworkConfig { + name: string; + rpcURL: string; + tokenListType: TokenListType; + tokenListSource: string; +} + +export interface Config { + network: NetworkConfig; + nativeCurrencySymbol: string; + manualGasPrice: number; +} + +export namespace CosmosConfig { + export const config: Config = getCosmosConfig('cosmos'); +} + +export function getCosmosConfig(chainName: string): Config { + const configManager = ConfigManagerV2.getInstance(); + const network = configManager.get(chainName + '.network'); + return { + network: { + name: network, + rpcURL: configManager.get(chainName + '.networks.' + network + '.rpcURL'), + tokenListType: configManager.get( + chainName + '.networks.' + network + '.tokenListType' + ), + tokenListSource: configManager.get( + chainName + '.networks.' + network + '.tokenListSource' + ), + }, + nativeCurrencySymbol: configManager.get( + chainName + '.nativeCurrencySymbol' + ), + manualGasPrice: configManager.get(chainName + '.manualGasPrice'), + }; +} diff --git a/src/chains/cosmos/cosmos.controllers.ts b/src/chains/cosmos/cosmos.controllers.ts new file mode 100644 index 0000000000..3444650d25 --- /dev/null +++ b/src/chains/cosmos/cosmos.controllers.ts @@ -0,0 +1,87 @@ +import { Cosmos } from './cosmos'; +import { + CosmosBalanceRequest, + CosmosBalanceResponse, + CosmosPollRequest, + CosmosPollResponse, +} from './cosmos.requests'; +import { latency, TokenValue, tokenValueToString } from '../../services/base'; +import { + HttpException, + TOKEN_NOT_SUPPORTED_ERROR_CODE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, +} from '../../services/error-handler'; + +const { decodeTxRaw } = require('@cosmjs/proto-signing'); + +export async function balances( + cosmosish: Cosmos, + req: CosmosBalanceRequest +): Promise { + const initTime = Date.now(); + + const wallet = await cosmosish.getWallet(req.address, 'cosmos'); + + const { tokenSymbols } = req; + + tokenSymbols.forEach((symbol: string) => { + const token = cosmosish.getTokenForSymbol(symbol); + + if (!token) { + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + symbol, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + } + }); + + const balances = await cosmosish.getBalances(wallet); + const filteredBalances = toCosmosBalances(balances, tokenSymbols); + + return { + network: cosmosish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + balances: filteredBalances, + }; +} + +export const toCosmosBalances = ( + balances: Record, + tokenSymbols: Array +): Record => { + const walletBalances: Record = {}; + + tokenSymbols.forEach((symbol) => { + let balance = '0.0'; + + if (balances[symbol]) { + balance = tokenValueToString(balances[symbol]); + } + + walletBalances[symbol] = balance; + }); + + return walletBalances; +}; + +export async function poll( + cosmos: Cosmos, + req: CosmosPollRequest +): Promise { + const initTime = Date.now(); + const transaction = await cosmos.getTransaction(req.txHash); + const currentBlock = await cosmos.getCurrentBlockNumber(); + + return { + network: cosmos.chain, + timestamp: initTime, + txHash: req.txHash, + currentBlock, + txBlock: transaction.height, + gasUsed: transaction.gasUsed, + gasWanted: transaction.gasWanted, + txData: decodeTxRaw(transaction.tx), + }; +} diff --git a/src/chains/cosmos/cosmos.requests.ts b/src/chains/cosmos/cosmos.requests.ts new file mode 100644 index 0000000000..3329dab41d --- /dev/null +++ b/src/chains/cosmos/cosmos.requests.ts @@ -0,0 +1,37 @@ +import { DecodedTxRaw } from '@cosmjs/proto-signing'; +export interface CosmosBalanceRequest { + address: string; // the user's Cosmos address as Bech32 + tokenSymbols: string[]; // a list of token symbol +} + +export interface CosmosBalanceResponse { + network: string; + timestamp: number; + latency: number; + balances: Record; +} + +export interface CosmosTokenRequest { + address: string; + token: string; +} + +export interface CosmosPollRequest { + txHash: string; +} + +export enum TransactionResponseStatusCode { + FAILED = -1, + CONFIRMED = 1, +} + +export interface CosmosPollResponse { + network: string; + timestamp: number; + txHash: string; + currentBlock: number; + txBlock: number; + gasUsed: number; + gasWanted: number; + txData: DecodedTxRaw | null; +} diff --git a/src/chains/cosmos/cosmos.routes.ts b/src/chains/cosmos/cosmos.routes.ts new file mode 100644 index 0000000000..9d1b514017 --- /dev/null +++ b/src/chains/cosmos/cosmos.routes.ts @@ -0,0 +1,74 @@ +/* eslint-disable @typescript-eslint/ban-types */ +import { NextFunction, Router, Request, Response } from 'express'; +import { verifyCosmosIsAvailable } from './cosmos-middlewares'; +import { asyncHandler } from '../../services/error-handler'; +import { Cosmos } from './cosmos'; +import { balances, poll } from './cosmos.controllers'; +import { + CosmosBalanceResponse, + CosmosBalanceRequest, + CosmosPollRequest, + CosmosPollResponse, +} from './cosmos.requests'; +import { + validateCosmosBalanceRequest, + validateCosmosPollRequest, +} from './cosmos.validators'; + +export namespace CosmosRoutes { + export const router = Router(); + export const getCosmos = async (request: Request) => { + const cosmos = await Cosmos.getInstance(request.body.network); + await cosmos.init(); + + return cosmos; + }; + + router.use(asyncHandler(verifyCosmosIsAvailable)); + + router.get( + '/', + asyncHandler(async (_req: Request, res: Response) => { + const { rpcUrl, chain } = await getCosmos(_req); + + res.status(200).json({ + network: chain, + rpcUrl: rpcUrl, + connection: true, + timestamp: Date.now(), + }); + }) + ); + + // Get balance for wallet + router.post( + '/balances', + asyncHandler( + async ( + req: Request<{}, {}, CosmosBalanceRequest>, + res: Response, + _next: NextFunction + ) => { + const cosmos = await getCosmos(req); + validateCosmosBalanceRequest(req.body); + res.status(200).json(await balances(cosmos, req.body)); + } + ) + ); + + // Gets status information about given transaction hash + router.post( + '/poll', + asyncHandler( + async ( + req: Request<{}, {}, CosmosPollRequest>, + res: Response + ) => { + const cosmos = await getCosmos(req); + + validateCosmosPollRequest(req.body); + res.status(200).json(await poll(cosmos, req.body)); + } + ) + ); +} diff --git a/src/chains/cosmos/cosmos.ts b/src/chains/cosmos/cosmos.ts new file mode 100644 index 0000000000..3954130892 --- /dev/null +++ b/src/chains/cosmos/cosmos.ts @@ -0,0 +1,87 @@ +import { Cosmosish } from '../../services/common-interfaces'; +import { CosmosBase } from '../../services/cosmos-base'; +import { getCosmosConfig } from './cosmos.config'; +import { logger } from '../../services/logger'; + +export class Cosmos extends CosmosBase implements Cosmosish { + private static _instances: { [name: string]: Cosmos }; + private _gasPrice: number; + private _nativeTokenSymbol: string; + private _chain: string; + private _requestCount: number; + private _metricsLogInterval: number; + + private constructor(network: string) { + const config = getCosmosConfig('cosmos'); + super( + 'cosmos', + config.network.rpcURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice + ); + this._chain = network; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + + this._gasPrice = config.manualGasPrice; + + this._requestCount = 0; + this._metricsLogInterval = 300000; // 5 minutes + + setInterval(this.metricLogger.bind(this), this.metricsLogInterval); + } + + public static getInstance(network: string): Cosmos { + if (Cosmos._instances === undefined) { + Cosmos._instances = {}; + } + if (!(network in Cosmos._instances)) { + Cosmos._instances[network] = new Cosmos(network); + } + return Cosmos._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Cosmos } { + return Cosmos._instances; + } + + public requestCounter(msg: any): void { + if (msg.action === 'request') this._requestCount += 1; + } + + public metricLogger(): void { + logger.info( + this.requestCount + + ' request(s) sent in last ' + + this.metricsLogInterval / 1000 + + ' seconds.' + ); + this._requestCount = 0; // reset + } + + public get gasPrice(): number { + return this._gasPrice; + } + + public get chain(): string { + return this._chain; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get requestCount(): number { + return this._requestCount; + } + + public get metricsLogInterval(): number { + return this._metricsLogInterval; + } + + async close() { + if (this._chain in Cosmos._instances) { + delete Cosmos._instances[this._chain]; + } + } +} diff --git a/src/chains/cosmos/cosmos.validators.ts b/src/chains/cosmos/cosmos.validators.ts new file mode 100644 index 0000000000..c913931ffd --- /dev/null +++ b/src/chains/cosmos/cosmos.validators.ts @@ -0,0 +1,36 @@ +import { + validateTokenSymbols, + mkValidator, + mkRequestValidator, + RequestValidator, + Validator, + validateTxHash, +} from '../../services/validators'; +import { normalizeBech32 } from '@cosmjs/encoding'; + +export const invalidCosmosAddressError: string = + 'The spender param is not a valid Cosmos address. (Bech32 format)'; + +export const isValidCosmosAddress = (str: string): boolean => { + try { + normalizeBech32(str); + + return true; + } catch (e) { + return false; + } +}; + +// given a request, look for a key called address that is a Cosmos address +export const validatePublicKey: Validator = mkValidator( + 'address', + invalidCosmosAddressError, + (val) => typeof val === 'string' && isValidCosmosAddress(val) +); + +export const validateCosmosBalanceRequest: RequestValidator = + mkRequestValidator([validatePublicKey, validateTokenSymbols]); + +export const validateCosmosPollRequest: RequestValidator = mkRequestValidator([ + validateTxHash, +]); diff --git a/src/chains/cronos/cronos.ts b/src/chains/cronos/cronos.ts new file mode 100755 index 0000000000..9b2ae7eee9 --- /dev/null +++ b/src/chains/cronos/cronos.ts @@ -0,0 +1,114 @@ +import abi from '../../services/ethereum.abi.json'; +import { logger } from '../../services/logger'; +import { Contract, Transaction, Wallet } from 'ethers'; +import { EthereumBase } from '../../services/ethereum-base'; +import { getEthereumConfig as getCronosConfig } from '../ethereum/ethereum.config'; +import { Provider } from '@ethersproject/abstract-provider'; +import { Ethereumish } from '../../services/common-interfaces'; +import { MadMeerkatConfig } from '../../connectors/mad_meerkat/mad_meerkat.config'; +import { VVSConfig } from '../../connectors/vvs/vvs.config'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export class Cronos extends EthereumBase implements Ethereumish { + private static _instances: { [name: string]: Cronos }; + private _gasPrice: number; + private _gasPriceRefreshInterval: number | null; + private _nativeTokenSymbol: string; + private _chain: string; + + private constructor(network: string) { + const config = getCronosConfig('cronos', network); + super( + 'cronos', + config.network.chainID, + config.network.nodeURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.nonceDbPath'), + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = config.network.name; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + this._gasPrice = config.manualGasPrice; + + this._gasPriceRefreshInterval = + config.network.gasPriceRefreshInterval !== undefined + ? config.network.gasPriceRefreshInterval + : null; + + this.updateGasPrice(); + } + + public static getInstance(network: string): Cronos { + if (Cronos._instances === undefined) { + Cronos._instances = {}; + } + if (!(network in Cronos._instances)) { + Cronos._instances[network] = new Cronos(network); + } + + return Cronos._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Cronos } { + return Cronos._instances; + } + + /** + * Automatically update the prevailing gas price on the network from the connected RPC node. + */ + async updateGasPrice(): Promise { + if (this._gasPriceRefreshInterval === null) { + return; + } + + const gasPrice: number = (await this.provider.getGasPrice()).toNumber(); + + this._gasPrice = gasPrice * 1e-9; + + setTimeout( + this.updateGasPrice.bind(this), + this._gasPriceRefreshInterval * 1000 + ); + } + + // getters + + public get gasPrice(): number { + return this._gasPrice; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get chain(): string { + return this._chain; + } + + getContract(tokenAddress: string, signerOrProvider?: Wallet | Provider) { + return new Contract(tokenAddress, abi.ERC20Abi, signerOrProvider); + } + + getSpender(reqSpender: string): string { + let spender: string; + if (reqSpender === 'mad_meerkat') { + spender = MadMeerkatConfig.config.routerAddress(this._chain); + } else if (reqSpender == 'vvs') { + spender = VVSConfig.config.routerAddress(this._chain); + } else { + spender = reqSpender; + } + return spender; + } + + // cancel transaction + async cancelTx(wallet: Wallet, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return super.cancelTxWithGasPrice(wallet, nonce, this._gasPrice * 2); + } +} diff --git a/src/chains/cronos/mainnet_beta.json b/src/chains/cronos/mainnet_beta.json new file mode 100755 index 0000000000..6b74571ba5 --- /dev/null +++ b/src/chains/cronos/mainnet_beta.json @@ -0,0 +1,720 @@ +{ + "name": "Cronos Mainnet Beta Token List", + "URI": "https://github.com/crypto-org-chain/cronos-docs/blob/gitbook/for-dapp-developers/cronos-smart-contract/token-contract-addresses.md", + "tokens": [ + { + "name": "", + "symbol": "WCRO", + "address": "0x5C7F8A570d578ED84E63fdFA7b1eE72dEae1AE23", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "WETH", + "address": "0xe44Fd7fCb2b1581822D0c862B68222998a0c299a", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "WBTC", + "address": "0x062E66477Faf219F25D27dCED647BF57C3107d52", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "USDC", + "address": "0xc21223249CA28397B4B6541dfFaEcC539BfF0c59", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "USDT", + "address": "0x66e428c3f67a68878562e79A0234c1F83c208770", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "DAI", + "address": "0xF2001B145b43032AAF5Ee2884e456CCd805F677D", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SHIB", + "address": "0xbED48612BC69fA1CaB67052b42a95FB30C1bcFee", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "DOGE", + "address": "0x1a8E39ae59e5556B56b76fCBA98d22c9ae557396", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "ATOM", + "address": "0xB888d8Dd1733d72681b30c00ee76BDE93ae7aa93", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "LINK", + "address": "0xBc6f24649CCd67eC42342AccdCECCB2eFA27c9d9", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "ENJ", + "address": "0x0A92ea8a197919aCb9BC26660Ed0D43D01ed26b7", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "ELON", + "address": "0x02DCcaf514C98451320a9365C5b46C61d3246ff3", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "TUSD", + "address": "0x87EFB3ec1576Dec8ED47e58B832bEdCd86eE186e", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "LUNC", + "address": "0x9278C8693e7328bef49804BacbFb63253565dffD", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "DOT", + "address": "0x994047FE66406CbD646cd85B990E11D7F5dB8fC7", + "decimals": 10, + "chainId": 25 + }, + { + "name": "", + "symbol": "ADA", + "address": "0x0e517979C2c1c1522ddB0c73905e0D39b3F990c0", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "RADAR", + "address": "0xa58e3AeAeA3292c3E260378e55E9684C59E7A27a", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "DERC", + "address": "0x98616a1427a1734DaEbA1E1894db48051244A065", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "PENDLE", + "address": "0x49c3bBB239f4FB44327073510f4bA72D207a81D6", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "TUSD", + "address": "0x87EFB3ec1576Dec8ED47e58B832bEdCd86eE186e", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "XLM", + "address": "0x747d6C858168B8cD6e537160320b5dE58FD3367C", + "decimals": 7, + "chainId": 25 + }, + { + "name": "", + "symbol": "EOS", + "address": "0xA37caA841072a305a0799718aFA16cd504C52118", + "decimals": 4, + "chainId": 25 + }, + { + "name": "", + "symbol": "QRDO", + "address": "0x70BB395F1A824D9a3F9D510C25e699cEaf603dEc", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "ALI", + "address": "0x45C135C1CDCE8d25A3B729A28659561385C52671", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "APE", + "address": "0x9C62F89a8C9907582f21205Ce90443730361EA05", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "MATIC", + "address": "0xf78a326ACd53651F8dF5D8b137295e434B7c8ba5", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "FTM", + "address": "0x63888BaFc5975630E4E5CF50c3845a3250115F64", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "AKT", + "address": "0x39a65A74Dc5A778Ff93d1765Ea51F57BC49c81B3", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "CRV", + "address": "0xfEf44a0C77eca218F443382d3128a7A251a8C542", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "ALICE", + "address": "0x46EfE38eC0558C48352e2eBc85AF3bd2E87Fb2A1", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "AXS", + "address": "0xE27753e456AbA584f10aCEf0B4e367EF38f01e14", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "GALA", + "address": "0x7A887D4f8a3221e1aaFA2f4435b774D51429A3e1", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "LTC", + "address": "0x9d97Be214b68C7051215BB61059B4e299Cd792c3", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "ICP", + "address": "0x8Bf3E654075E269c1C415e4889C12D9837452be0", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "SAND", + "address": "0x9097eA65B55dfC7383A7EFB465e8fFC18D46e784", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "BCH", + "address": "0x7589B70aBb83427bb7049e08ee9fC6479ccB7a23", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "ALGO", + "address": "0x2fEfe47989214c2e74A6319076c138d395681407", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "MANA", + "address": "0x6Ed8c99E5c6B2c551e012E4272d8f3d1DF23a71A", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "UNI", + "address": "0x16aD43896f7C47a5d9Ee546c44A22205738B329c", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SOL", + "address": "0xc9DE0F3e08162312528FF72559db82590b481800", + "decimals": 9, + "chainId": 25 + }, + { + "name": "", + "symbol": "AVAX", + "address": "0x8d58088D4E8Ffe75A8b6357ba5ff17B93B912640", + "decimals": 9, + "chainId": 25 + }, + { + "name": "", + "symbol": "ZIL", + "address": "0xc70ed252E55d68A7020A754Fb92Fa5c68e3c199f", + "decimals": 12, + "chainId": 25 + }, + { + "name": "", + "symbol": "FLOW", + "address": "0x22EF9d73EA90E774CfB21fADDF84b37BD54FE7a6", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "IMX", + "address": "0x8f27dB0E597B67F33d5Fb58D5EEcD6A3CC780942", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "OMG", + "address": "0x5a56509C61ad80680caF5b3B980E6C88319eeE33", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "AAVE", + "address": "0xE657b115bc45c0786274c824f83e3e02CE809185", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "LRC", + "address": "0xAF760dE3201fEeD80FEeA59FB16A8360C8c4d1a2", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "DAR", + "address": "0x5893915Fe3d15e4004F7232c80036bFa92aCa564", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "GRT", + "address": "0x4c523222Cd0DE11616F7aD685f24145B9FaF7996", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "CHZ", + "address": "0x4E4F362170bFb88D3c9378FF7818d93fC2fbd257", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "INJ", + "address": "0x4E05F3C7ee6155e3add224470E1c4583D4F424A3", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "KNC", + "address": "0xd73EBf885C4157D3E88c6D87ad3b8018B4a32fEF", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "XTZ", + "address": "0x9D5a7d02D51Dc523197e62c2865907dbB53642Af", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "RUNE", + "address": "0x171C8AAA57D0107d0187f54Ccf4CC03406E76a4E", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "KSM", + "address": "0x0BD48A8A9565385649D9d7f1c945D1d0C4543E26", + "decimals": 12, + "chainId": 25 + }, + { + "name": "", + "symbol": "HNT", + "address": "0x61426C150207AbF8a215f3377a0819dDcA842aF3", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "YFI", + "address": "0x7bDF81a86f4AA8B442Ca05670Cbf296BB22Bc7bB", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SUSHI", + "address": "0xdb3de0AAC8A39490932FA19c2e32F179368Ab840", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "QNT", + "address": "0x7d54F4E05f273a9317f723997612Ed64eF53C900", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "MKR", + "address": "0xab9Cf8C5A9B6Cf5215c82D088D37d04bB146704A", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "HOT", + "address": "0xc4010CfB5172D82A348bcBC8cD543733c1e9BF89", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "QTUM", + "address": "0x32529346958711B3beF92B96507C14821e50C9c8", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "CELR", + "address": "0xfA0235feF8644C107f7e531Fa9CFe0613Fbe8909", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "REN", + "address": "0x2b4eE166a125E01Aba019885932C944cEfED2932", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "BAT", + "address": "0x2F712E0a6f92e3f865EaEb86f07BAFc67974d26c", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SRM", + "address": "0xB858e614779f148992949A3b15E6127dDA204ca4", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "DYDX", + "address": "0x4442C740cc5B47F032983106E66E3C9dC945676C", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "UMA", + "address": "0x33564807CC70c6422124d867B344D7b90bF21A76", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "CHR", + "address": "0xcdee9300A1527E0000b054320D371A9C8c4a8AF6", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "EFI", + "address": "0x47E16f9EE811d3651D979941325c545Da6385daF", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "STX", + "address": "0x30BBA7b57952E7028c47d5c6AB295D0Da7139eF9", + "decimals": 6, + "chainId": 25 + }, + { + "name": "", + "symbol": "ENS", + "address": "0xA0913e0D7A85954e89452e7Ccb8d1235db74C330", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "PLA", + "address": "0x044597363b0054986aE4289d25CD7D0D451766Fc", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "AGLD", + "address": "0xD3BB5C6961157eB4eb03658Dc5D4144808828168", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SNX", + "address": "0x9Aa8F72dd2C06EAff0113bD0380255E1fbDAeaC4", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SPELL", + "address": "0xB37e6457C17A370b2eAEb40849d20dcaEa5f7e92", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "XYO", + "address": "0x211153266F15F9314B214A7dd614d90f850a8D6a", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "HBAR", + "address": "0xe0C7226a58f54db71eDc6289Ba2dc80349B41974", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "AURORA", + "address": "0xB4f1D9A65816da7e112F11C9A2900b8C5beeD525", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "RNDR", + "address": "0xEaEA1a708DaB6f732E35F06588293204318ac48F", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "1INCH", + "address": "0xEea900FE18F77593C7D7C105fBa9bd714164AC95", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "JASMY", + "address": "0x227EdF65f866255A0ED4B5b453fe43A41182EC3A", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "COMP", + "address": "0x4Fb1af9D09DB3fbbda96071EaE0aeae6E871F9AC", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "ANKR", + "address": "0x1FE0f470736548794b47AFe5613d3A309d964d3c", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "YGG", + "address": "0xfF9620d9F80F80056cbE4Bb84403a9E9C5174213", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "PAXG", + "address": "0x81749e7258f9e577f61f49ABeeB426b70F561b89", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "OGN", + "address": "0x78E9974A74d6c980De4E3F8039248320c5A2d714", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "AR ", + "address": "0xeB6B3AEdA7A2705fAC5e2350fA4D71a64b393b37", + "decimals": 12, + "chainId": 25 + }, + { + "name": "", + "symbol": "GLMR", + "address": "0x268B344bF8bbCd9Dd4e4FA68264309B05F15820a", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "ACA", + "address": "0x213E6fb02009c13692bAA23C63FdE8D623d22705", + "decimals": 12, + "chainId": 25 + }, + { + "name": "", + "symbol": "SPS", + "address": "0x1B554fda68bA95924E5bbD0BaF8e769F039e775B", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "CKB", + "address": "0x5dEED46f39c485bA03b61d83763d0f6357dc4737", + "decimals": 8, + "chainId": 25 + }, + { + "name": "", + "symbol": "VOXEL", + "address": "0x5fdbFE38E050829374001630B8710BDd05Ea55C0", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "MMF", + "address": "0x97749c9B61F878a880DfE312d2594AE07AEd7656", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "KRL", + "address": "0x62E622fa4E180C391f2E089FC1d5eA7AdCB96575", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "3MM", + "address": "0x74759c8BCb6787ef25eD2ff432FE33ED57CcCB0D", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "MUSD", + "address": "0x95aEaF383E2e86A47c11CffdE1F7944eCB2C38C2", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "VVS", + "address": "0x2D03bECE6747ADC00E1a131BBA1469C15fD11e03", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "BIFI", + "address": "0xe6801928061CDbE32AC5AD0634427E140EFd05F9", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "TONIC", + "address": "0xdd73dea10abc2bff99c60882ec5b2b81bb1dc5b2", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "SINGLE", + "address": "0x0804702a4e749d39a35fde73d1df0b1f1d6b8347", + "decimals": 18, + "chainId": 25 + }, + { + "name": "", + "symbol": "LUNA", + "address": "0x9278C8693e7328bef49804BacbFb63253565dffD", + "decimals": 18, + "chainId": 25 + } + ] +} diff --git a/src/chains/cronos/testnet.json b/src/chains/cronos/testnet.json new file mode 100755 index 0000000000..0305774907 --- /dev/null +++ b/src/chains/cronos/testnet.json @@ -0,0 +1,48 @@ +{ + "name": "Cronos Testnet Beta Token List", + "URI": "https://github.com/crypto-org-chain/cronos-docs/blob/gitbook/for-dapp-developers/cronos-smart-contract/token-contract-addresses.md", + "tokens": [ + { + "name": "", + "symbol": "WCRO", + "address": "0x6a3173618859C7cd40fAF6921b5E9eB6A76f1fD4", + "decimals": 18, + "chainId": 338 + }, + { + "name": "", + "symbol": "WETH", + "address": "0x796135E94527c38433e9c42f4Cd91ca931E5e6A6", + "decimals": 18, + "chainId": 338 + }, + { + "name": "", + "symbol": "WBTC", + "address": "0xEE200f25d7B1B9518AC944fd60b113d39bee209c", + "decimals": 8, + "chainId": 338 + }, + { + "name": "", + "symbol": "USDC", + "address": "0x25f0965F285F03d6F6B3B21c8EC3367412Fd0ef6", + "decimals": 6, + "chainId": 338 + }, + { + "name": "", + "symbol": "USDT", + "address": "0xa144617Afd9205AF1ceDE3Cc671da1a409A82c5a", + "decimals": 6, + "chainId": 338 + }, + { + "name": "", + "symbol": "DAI", + "address": "0x8662A8111daEC7570a1bDF3dbd3E163d41563904", + "decimals": 18, + "chainId": 338 + } + ] +} diff --git a/src/chains/ethereum/arbitrum_one_tokens.json b/src/chains/ethereum/arbitrum_one_tokens.json new file mode 100644 index 0000000000..e8031c1cdd --- /dev/null +++ b/src/chains/ethereum/arbitrum_one_tokens.json @@ -0,0 +1,2798 @@ +{ + "name": "Arb Whitelist Era", + "timestamp": "2022-03-01T22:44:18.339Z", + "version": { + "major": 4, + "minor": 2, + "patch": 1 + }, + "tokens": [ + { + "logoURI": "https://assets.coingecko.com/coins/images/4454/thumb/0xbtc.png?1561603765", + "chainId": 42161, + "address": "0x7cb16cb78ea464aD35c8a50ABF95dff3c9e09d5d", + "name": "0xBitcoin Token", + "symbol": "0xBTC", + "decimals": 8, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xb6ed7644c69416d67b522e20bc294a9a9b405b31", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xb6ed7644c69416d67b522e20bc294a9a9b405b31", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0x03b95f1C84Af0607afd5dD87ca1FDE7572aa827F", + "name": "Agave", + "symbol": "AGVE", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0b006e475620af076915257c6a9e40635abdbbad", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0b006e475620af076915257c6a9e40635abdbbad", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14719/thumb/sbEW5W8.png?1617939648", + "chainId": 42161, + "address": "0x0e15258734300290a651FdBAe8dEb039a8E7a2FA", + "name": "Alchemy", + "symbol": "ALCH", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0000a1c00009a619684135b824ba02f7fbf3a572", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0000a1c00009a619684135b824ba02f7fbf3a572", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14379/thumb/uaLoLU8c_400x400_%281%29.png?1627873106", + "chainId": 42161, + "address": "0x9b3fa2A7C3EB36d048A5d38d81E7fAFC6bc47B25", + "name": "Aluna", + "symbol": "ALN", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x8185bc4757572da2a610f887561c32298f1a5748", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x8185bc4757572da2a610f887561c32298f1a5748", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/2165/thumb/Auc_Discord_Avatar1.png?1618983355", + "chainId": 42161, + "address": "0xea986d33eF8a20A96120ecc44dBdD49830192043", + "name": "Auctus Token", + "symbol": "AUC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xc12d099be31567add4e4e4d0d45691c3f58f5663", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xc12d099be31567add4e4e4d0d45691c3f58f5663", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13246/thumb/BAC.png?1613231642", + "chainId": 42161, + "address": "0x6F67043201C903bbCBC129750CB3b328Dd56a0a5", + "name": "BAC", + "symbol": "BAC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x3449fc1cd036255ba1eb19d65ff4ba2b8903a69a", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x3449fc1cd036255ba1eb19d65ff4ba2b8903a69a", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/badger_32.png", + "chainId": 42161, + "address": "0xBfa641051Ba0a0Ad1b0AcF549a89536A0D76472E", + "name": "Badger", + "symbol": "BADGER", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x3472a5a71965499acd81997a54bba8d852c6e53d", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x3472a5a71965499acd81997a54bba8d852c6e53d", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/balancer-bal-logo.png", + "chainId": 42161, + "address": "0x040d1EdC9569d4Bab2D15287Dc5A4F10F56a56B8", + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xba100000625a3754423978a60c9317c58a424e3d", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xba100000625a3754423978a60c9317c58a424e3d", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0xBbFbde08Bf1BE235a3Fa97d6A27fFfA19Ac4a8a8", + "name": "BarkCoin", + "symbol": "BARK", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x5bd7ef7113a32b56127ac32272609c42c97849ff", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x5bd7ef7113a32b56127ac32272609c42c97849ff", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/blanktoken_32.png", + "chainId": 42161, + "address": "0xA5eC9d64b64b8B9E94FEaA7538c084b38117E7Ba", + "name": "GoBlank Token", + "symbol": "BLANK", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x41a3dba3d677e573636ba691a70ff2d606c29666", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x41a3dba3d677e573636ba691a70ff2d606c29666", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/barnbridge-bond-logo.png", + "chainId": 42161, + "address": "0x0D81E50bC677fa67341c44D7eaA9228DEE64A4e1", + "name": "BarnBridge Governance Token", + "symbol": "BOND", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0391d2021f89dc339f60fff84546ea23e337750f", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0391d2021f89dc339f60fff84546ea23e337750f", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/boostcoin_32.png", + "chainId": 42161, + "address": "0xd44e8F8768D4ed25119921a53802D8758A5b20dD", + "name": "Boost", + "symbol": "BOOST", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x4e0fca55a6c3a94720ded91153a27f60e26b9aa8", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x4e0fca55a6c3a94720ded91153a27f60e26b9aa8", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/btu_32.png", + "chainId": 42161, + "address": "0xBA9a5Dd807c9F072850bE15a52dF3408BA25Fd18", + "name": "BTU Protocol", + "symbol": "BTU", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xb683d83a532e2cb7dfa5275eed3698436371cc9f", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xb683d83a532e2cb7dfa5275eed3698436371cc9f", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/11775/thumb/CAP.png?1594083244", + "chainId": 42161, + "address": "0x031d35296154279DC1984dCD93E392b1f946737b", + "name": "Cap", + "symbol": "CAP", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x43044f861ec040db59a7e324c40507addb673142", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x43044f861ec040db59a7e324c40507addb673142", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/4379/thumb/Celr.png?1554705437", + "chainId": 42161, + "address": "0x3a8B787f78D775AECFEEa15706D4221B40F345AB", + "name": "CelerToken", + "symbol": "CELR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x4f9254c83eb525f9fcf346490bbb3ed28a81c667", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x4f9254c83eb525f9fcf346490bbb3ed28a81c667", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/cryptionnetwork_32.png", + "chainId": 42161, + "address": "0x989D099d29F62b839C8CbD41c82c6554a5515752", + "name": "Cryption Network Token", + "symbol": "CNT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x429876c4a6f89fb470e92456b8313879df98b63c", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x429876c4a6f89fb470e92456b8313879df98b63c", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/10775/thumb/COMP.png?1592625425", + "chainId": 42161, + "address": "0x354A6dA3fcde098F8389cad84b0182725c6C91dE", + "name": "Compound", + "symbol": "COMP", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xc00e94cb662c3520282e6f5717214004a7f26888", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xc00e94cb662c3520282e6f5717214004a7f26888", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/coti-coti-logo.png", + "chainId": 42161, + "address": "0x6FE14d3CC2f7bDdffBa5CdB3BBE7467dd81ea101", + "name": "COTI Token", + "symbol": "COTI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xddb3422497e61e13543bea06989c0789117555c5", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xddb3422497e61e13543bea06989c0789117555c5", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/cream-finance-cream-logo.png", + "chainId": 42161, + "address": "0xf4D48Ce3ee1Ac3651998971541bAdbb9A14D7234", + "name": "Cream", + "symbol": "CREAM", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x2ba592f78db6436527729929aaf6c908497cb200", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x2ba592f78db6436527729929aaf6c908497cb200", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/curve-dao-token-crv-logo.png", + "chainId": 42161, + "address": "0x11cDb42B0EB46D95f990BeDD4695A6e3fA034978", + "name": "Curve DAO Token", + "symbol": "CRV", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xd533a949740bb3306d119cc777fa900ba034cd52", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xd533a949740bb3306d119cc777fa900ba034cd52", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/9956/thumb/4943.png?1636636734", + "chainId": 42161, + "address": "0xDA10009cBd5D07dd0CeCc66161FC93D7c9000da1", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6b175474e89094c44da98b954eedeac495271d0f", + "originBridgeAddress": "0x467194771dae2967aef3ecbedd3bf9a310c76c65", + "destBridgeAddress": "0xd3b5b60020504bc3489d6949d545893982ba3011" + } + }, + "l1Address": "0x6b175474e89094c44da98b954eedeac495271d0f", + "l2GatewayAddress": "0x467194771dae2967aef3ecbedd3bf9a310c76c65", + "l1GatewayAddress": "0xd3b5b60020504bc3489d6949d545893982ba3011" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13691/thumb/thGDKHo.png?1610959947", + "chainId": 42161, + "address": "0xdeBa25AF35e4097146d7629055E0EC3C71706324", + "name": "DEFI Top 5 Tokens Index", + "symbol": "DEFI5", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xfa6de2697d59e88ed7fc4dfe5a33dac43565ea41", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xfa6de2697d59e88ed7fc4dfe5a33dac43565ea41", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14143/thumb/alpha_logo.png?1614651244", + "chainId": 42161, + "address": "0xAE6e3540E97b0b9EA8797B157B510e133afb6282", + "name": "DEGEN Index", + "symbol": "DEGEN", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x126c121f99e1e211df2e5f8de2d96fa36647c855", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x126c121f99e1e211df2e5f8de2d96fa36647c855", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/9709/thumb/xlGxxIjI_400x400.jpg?1571006794", + "chainId": 42161, + "address": "0xaE6aab43C4f3E0cea4Ab83752C278f8dEbabA689", + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x431ad2ff6a9c365805ebad47ee021148d6f7dbe0", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x431ad2ff6a9c365805ebad47ee021148d6f7dbe0", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dfynnetwork_32.png", + "chainId": 42161, + "address": "0x1D54Aa7E322e02A0453c0F2fA21505cE7F2E9E93", + "name": "DFYN Token", + "symbol": "DFYN", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x9695e0114e12c0d3a3636fab5a18e6b737529023", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x9695e0114e12c0d3a3636fab5a18e6b737529023", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dHedge_32.png", + "chainId": 42161, + "address": "0x8038F3C971414FD1FC220bA727F2D4A0fC98cb65", + "name": "dHedge DAO Token", + "symbol": "DHT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xca1207647ff814039530d7d35df0e1dd2e91fa84", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xca1207647ff814039530d7d35df0e1dd2e91fa84", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dodo_32.png", + "chainId": 42161, + "address": "0x69Eb4FA4a2fbd498C257C57Ea8b7655a2559A581", + "name": "DODO bird", + "symbol": "DODO", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x43dfc4159d86f3a37a5a4b3d4580b888ad7d4ddd", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x43dfc4159d86f3a37a5a4b3d4580b888ad7d4ddd", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/thedogenft_32.png", + "chainId": 42161, + "address": "0x4425742F1EC8D98779690b5A3A6276Db85Ddc01A", + "name": "The Doge NFT", + "symbol": "DOG", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xbaac2b4491727d78d2b78815144570b9f2fe8899", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xbaac2b4491727d78d2b78815144570b9f2fe8899", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dopexgovernance_32.png", + "chainId": 42161, + "address": "0x6C2C06790b3E3E3c38e12Ee22F8183b37a13EE55", + "name": "Dopex Governance Token", + "symbol": "DPX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xeec2be5c91ae7f8a338e1e5f3b5de49d07afdc81", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xeec2be5c91ae7f8a338e1e5f3b5de49d07afdc81", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/17482/thumb/photo_2021-08-03_09-24-16.png?1627953917", + "chainId": 42161, + "address": "0xE212f5E733257ed5628a2FeBcEdBc9222e535F51", + "name": "Digital Standard Unit", + "symbol": "DSU", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x605d26fbd5be761089281d5cec2ce86eea667109", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x605d26fbd5be761089281d5cec2ce86eea667109", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dvf_32.png", + "chainId": 42161, + "address": "0xA7Aa2921618e3D63dA433829d448b58C9445A4c3", + "name": "DeversiFi Token", + "symbol": "DVF", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xdddddd4301a082e62e84e43f474f044423921918", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xdddddd4301a082e62e84e43f474f044423921918", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/11148/thumb/dxdao.png?1607999331", + "chainId": 42161, + "address": "0xC3Ae0333F0F34aa734D5493276223d95B8F9Cb37", + "name": "DXdao", + "symbol": "DXD", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xa1d65e8fb6e87b60feccbc582f7f97804b725521", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xa1d65e8fb6e87b60feccbc582f7f97804b725521", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/17481/thumb/photo_2021-08-03_03-26-29.png?1627953584", + "chainId": 42161, + "address": "0xCE32aA8d60807182c0003Ef9cc1976Fa10E5d312", + "name": "Empty Set Share", + "symbol": "ESS", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dforceeur_32.png", + "chainId": 42161, + "address": "0x969131D8ddC06C2Be11a13e6E7fACF22CF57d95e", + "name": "dForce EUR", + "symbol": "EUX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xb986f3a2d91d3704dc974a24fb735dcc5e3c1e70", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xb986f3a2d91d3704dc974a24fb735dcc5e3c1e70", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/11756/thumb/fluxres.png?1593748917", + "chainId": 42161, + "address": "0xF80D589b3Dbe130c270a69F1a69D050f268786Df", + "name": "Flux", + "symbol": "FLUX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x469eda64aed3a3ad6f868c44564291aa415cb1d9", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x469eda64aed3a3ad6f868c44564291aa415cb1d9", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/zel-flux-logo.png", + "chainId": 42161, + "address": "0x2338a5d62E9A766289934e8d2e83a443e8065b83", + "name": "Flux Protocol", + "symbol": "FLUX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x7645ddfeeceda57e41f92679c4acd83c56a81d14", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x7645ddfeeceda57e41f92679c4acd83c56a81d14", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/8242/thumb/for.png?1606195375", + "chainId": 42161, + "address": "0x3816e40c1eB106c8fb7c05f901cfD58C7292D051", + "name": "The Force Token", + "symbol": "FOR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x1fcdce58959f536621d76f5b7ffb955baa5a672f", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x1fcdce58959f536621d76f5b7ffb955baa5a672f", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/futureswap2_32.png", + "chainId": 42161, + "address": "0x488cc08935458403a0458e45E20c0159c8AB2c92", + "name": "Futureswap Token", + "symbol": "FST", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0e192d382a36de7011f795acc4391cd302003606", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0e192d382a36de7011f795acc4391cd302003606", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/10347/thumb/vUXKHEe.png?1601523640", + "chainId": 42161, + "address": "0xBDeF0E9ef12E689F366fe494A7A7D0dad25D9286", + "name": "Fuse Token", + "symbol": "FUSE", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x970b9bb2c0444f5e81e9d0efb84c8ccdcdcaf84d", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x970b9bb2c0444f5e81e9d0efb84c8ccdcdcaf84d", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0xfc5A1A6EB076a2C7aD06eD22C90d7E710E35ad0a", + "name": "GMX", + "symbol": "GMX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xbc30049adc73de06d7a98a5189203aac66b2c830", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xbc30049adc73de06d7a98a5189203aac66b2c830", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/662/thumb/logo_square_simple_300px.png?1609402668", + "chainId": 42161, + "address": "0xa0b862F60edEf4452F25B4160F177db44DeB6Cf1", + "name": "Gnosis Token", + "symbol": "GNO", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6810e776880c02933d47db1b9fc05908e5386b96", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x6810e776880c02933d47db1b9fc05908e5386b96", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13875/thumb/GOVI.png?1612451531", + "chainId": 42161, + "address": "0x07E49d5dE43DDA6162Fa28D24d5935C151875283", + "name": "GOVI", + "symbol": "GOVI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xeeaa40b28a2d1b0b08f6f97bb1dd4b75316c6107", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xeeaa40b28a2d1b0b08f6f97bb1dd4b75316c6107", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0x9623063377AD1B27544C965cCd7342f7EA7e88C7", + "name": "Graph Token", + "symbol": "GRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13397/thumb/Graph_Token.png?1608145566", + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xc944e90c64b2c07662a292be6244bdf05cda44a7", + "originBridgeAddress": "0x65E1a5e8946e7E87d9774f5288f41c30a99fD302", + "destBridgeAddress": "0x01cdc91b0a9ba741903aa3699bf4ce31d6c5cc06" + } + }, + "l1Address": "0xc944e90c64b2c07662a292be6244bdf05cda44a7", + "l2GatewayAddress": "0x65E1a5e8946e7E87d9774f5288f41c30a99fD302", + "l1GatewayAddress": "0x01cdc91b0a9ba741903aa3699bf4ce31d6c5cc06" + } + }, + { + "logoURI": "https://etherscan.io/token/images/impermax_32.png", + "chainId": 42161, + "address": "0x9c67eE39e3C4954396b9142010653F17257dd39C", + "name": "Impermax", + "symbol": "IMX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x7b35ce522cb72e4077baeb96cb923a5529764a00", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x7b35ce522cb72e4077baeb96cb923a5529764a00", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13177/thumb/kun_logo.png?1605923919", + "chainId": 42161, + "address": "0x04cb2d263a7489f02d813eaaB9Ba1bb8466347F2", + "name": "QIAN governance token", + "symbol": "KUN", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x65d9bc970aa9b2413027fa339f7f179b3f3f2604", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x65d9bc970aa9b2413027fa339f7f179b3f3f2604", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/farmland_32.png", + "chainId": 42161, + "address": "0x3CD1833Ce959E087D0eF0Cb45ed06BffE60F23Ba", + "name": "Land", + "symbol": "LAND", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x3258cd8134b6b28e814772dd91d5ecceea512818", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x3258cd8134b6b28e814772dd91d5ecceea512818", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/877/thumb/chainlink-new-logo.png?1547034700", + "chainId": 42161, + "address": "0xf97f4df75117a78c1A5a0DBb814Af92458539FB4", + "name": "ChainLink Token", + "symbol": "LINK", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x514910771af9ca656af840dff83e8264ecf986ca", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x514910771af9ca656af840dff83e8264ecf986ca", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/loopring-lrc-logo.png", + "chainId": 42161, + "address": "0x46d0cE7de6247b0A95f67b43B589b4041BaE7fbE", + "name": "LoopringCoin V2", + "symbol": "LRC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xbbbbca6a901c926f240b89eacb641d8aec7aeafd", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xbbbbca6a901c926f240b89eacb641d8aec7aeafd", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/18623/thumb/Magic.png?1635755672", + "chainId": 42161, + "address": "0x539bdE0d7Dbd336b79148AA742883198BBF60342", + "name": "MAGIC", + "symbol": "MAGIC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xb0c7a3ba49c7a6eaba6cd4a96c55a1391070ac9a", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xb0c7a3ba49c7a6eaba6cd4a96c55a1391070ac9a", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0xAA086809EFA469631DD90D8C6cB267bAb107E958", + "name": "My Alpha Leaderboard", + "symbol": "MAL", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6619078bdd8324e01e9a8d4b3d761b050e5ecf06", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x6619078bdd8324e01e9a8d4b3d761b050e5ecf06", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/11335/thumb/2020-05-19-token-200.png?1589940590", + "chainId": 42161, + "address": "0x99F40b01BA9C469193B360f72740E416B17Ac332", + "name": "MATH Token", + "symbol": "MATH", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x08d967bb0134f2d07f7cfb6e246680c53927dd30", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x08d967bb0134f2d07f7cfb6e246680c53927dd30", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/antimatter_32.png", + "chainId": 42161, + "address": "0xaaA62D9584Cbe8e4D68A43ec91BfF4fF1fAdB202", + "name": "Antimatter.Finance Governance Token", + "symbol": "MATTER", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x9b99cca871be05119b2012fd4474731dd653febe", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x9b99cca871be05119b2012fd4474731dd653febe", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/11796/thumb/mcb.png?1594355515", + "chainId": 42161, + "address": "0x4e352cF164E64ADCBad318C3a1e222E9EBa4Ce42", + "name": "MCDEX Token", + "symbol": "MCB", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x4e352cf164e64adcbad318c3a1e222e9eba4ce42", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x4e352cf164e64adcbad318c3a1e222e9eba4ce42", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/maker-mkr-logo.png", + "chainId": 42161, + "address": "0x2e9a6Df78E42a30712c10a9Dc4b1C8656f8F2879", + "name": "Maker", + "symbol": "MKR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/11846/thumb/mStable.png?1594950533", + "chainId": 42161, + "address": "0x5298Ee77A8f9E226898403eBAC33e68a62F770A0", + "name": "Meta", + "symbol": "MTA", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xa3bed4e1c75d00fa6f4e5e6922db7261b5e9acd2", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xa3bed4e1c75d00fa6f4e5e6922db7261b5e9acd2", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13546/thumb/indexed-light.74bb5471.png?1609712728", + "chainId": 42161, + "address": "0xB965029343D55189c25a7f3e0c9394DC0F5D41b1", + "name": "Indexed", + "symbol": "NDX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x86772b1409b61c639eaac9ba0acfbb6e238e5f83", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x86772b1409b61c639eaac9ba0acfbb6e238e5f83", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0xd67D9F7E018B4e7613b0251BBe3Ba3988Baf7C16", + "name": "New era", + "symbol": "NEC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x1353a77abd236207d0588bcbbb52bc3087f85351", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x1353a77abd236207d0588bcbbb52bc3087f85351", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/feistydoge_32.png", + "chainId": 42161, + "address": "0xc9c2B86CD4cdbAB70cd65D22EB044574c3539F6c", + "name": "Feisty Doge NFT", + "symbol": "NFD", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xdfdb7f72c1f195c5951a234e8db9806eb0635346", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xdfdb7f72c1f195c5951a234e8db9806eb0635346", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12594/thumb/octofi-256x256-radius-22percent.png?1610679969", + "chainId": 42161, + "address": "0x52f5d9B3a2bB89D3aEC5829A3415c21115aCD633", + "name": "Octo.fi", + "symbol": "OCTO", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x7240ac91f01233baaf8b064248e80feaa5912ba3", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x7240ac91f01233baaf8b064248e80feaa5912ba3", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14483/thumb/token_OHM_%281%29.png?1628311611", + "chainId": 42161, + "address": "0x6E6a3D8F1AfFAc703B1aEF1F43B8D2321bE40043", + "name": "Olympus", + "symbol": "OHM", + "decimals": 9, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x383518188c0c6d7730d91b2c03a03c837814a899", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x383518188c0c6d7730d91b2c03a03c837814a899", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13429/thumb/ovr_logo.png?1608518911", + "chainId": 42161, + "address": "0x55704A0e9E2eb59E176C5b69655DbD3DCDCFc0F0", + "name": "OVR", + "symbol": "OVR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x21bfbda47a0b4b5b1248c767ee49f7caa9b23697", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x21bfbda47a0b4b5b1248c767ee49f7caa9b23697", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12381/thumb/60d18e06844a844ad75901a9_mark_only_03.png?1628674771", + "chainId": 42161, + "address": "0x753D224bCf9AAFaCD81558c32341416df61D3DAC", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xbc396689893d065f41bc2c6ecbee5e0085233447", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xbc396689893d065f41bc2c6ecbee5e0085233447", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/pickle_32.png", + "chainId": 42161, + "address": "0x965772e0E9c84b6f359c8597C891108DcF1c5B1A", + "name": "PickleToken", + "symbol": "PICKLE", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x429881672b9ae42b8eba0e26cd9c73711b891ca5", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x429881672b9ae42b8eba0e26cd9c73711b891ca5", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0x3642c0680329ae3e103E2B5AB29DDfed4d43CBE5", + "name": "Plenny", + "symbol": "PL2", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x3642c0680329ae3e103e2b5ab29ddfed4d43cbe5", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x3642c0680329ae3e103e2b5ab29ddfed4d43cbe5", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13962/thumb/apple-touch-icon.png?1623679482", + "chainId": 42161, + "address": "0x51fC0f6660482Ea73330E414eFd7808811a57Fa2", + "name": "Premia", + "symbol": "PREMIA", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6399c842dd2be3de30bf99bc7d1bbf6fa3650e70", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x6399c842dd2be3de30bf99bc7d1bbf6fa3650e70", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/raireflexindex_32.png", + "chainId": 42161, + "address": "0xaeF5bbcbFa438519a5ea80B4c7181B4E78d419f2", + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x03ab458634910aad20ef5f1c8ee96f1d6ac54919", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x03ab458634910aad20ef5f1c8ee96f1d6ac54919", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dopexrebate_32.png", + "chainId": 42161, + "address": "0x32Eb7902D4134bf98A28b963D26de779AF92A212", + "name": "Dopex Rebate Token", + "symbol": "RDPX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0ff5a8451a839f5f0bb3562689d9a44089738d11", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x0ff5a8451a839f5f0bb3562689d9a44089738d11", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://etherscan.io/token/images/RariGovernanceToken_32.png", + "chainId": 42161, + "address": "0xef888bcA6AB6B1d26dbeC977C455388ecd794794", + "name": "Rari Governance Token", + "symbol": "RGT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xd291e7a03283640fdc51b121ac401383a46cc623", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xd291e7a03283640fdc51b121ac401383a46cc623", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13709/thumb/route_token_200x200-19.png?1611057698", + "chainId": 42161, + "address": "0x5298060A95205BE6Dd4aBc21910A4bB23D6DCD8b", + "name": "Route", + "symbol": "ROUTE", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x16eccfdbb4ee1a85a33f3a9b21175cd7ae753db4", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x16eccfdbb4ee1a85a33f3a9b21175cd7ae753db4", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12428/thumb/sake.png?1599777402", + "chainId": 42161, + "address": "0x552E4e96A0Ce6D36d161b63984848c8dAC471ea2", + "name": "SakeToken", + "symbol": "SAKE", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x066798d9ef0833ccc719076dab77199ecbd178b0", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x066798d9ef0833ccc719076dab77199ecbd178b0", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/13724/thumb/stakedao_logo.jpg?1611195011", + "chainId": 42161, + "address": "0x7bA4a00d54A07461D9DB2aEF539e91409943AdC9", + "name": "Stake DAO Token", + "symbol": "SDT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x73968b9a57c6e53d41345fd57a6e6ae27d6cdb2f", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x73968b9a57c6e53d41345fd57a6e6ae27d6cdb2f", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 42161, + "address": "0x5575552988A3A80504bBaeB1311674fCFd40aD4B", + "name": "Sperax", + "symbol": "SPA", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x2a95fe4c7e64e09856989f9ea0b57b9ab5f770cb", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0x2a95fe4c7e64e09856989f9ea0b57b9ab5f770cb", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://etherscan.io/token/images/spelltoken_32.png", + "chainId": 42161, + "address": "0x3E6648C5a70A150A88bCE65F4aD4d506Fe15d2AF", + "name": "Spell Token", + "symbol": "SPELL", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x090185f2135308bad17527004364ebcc2d37e5f6", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x090185f2135308bad17527004364ebcc2d37e5f6", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/strips_32.png", + "chainId": 42161, + "address": "0x326c33FD1113c1F29B35B4407F3d6312a8518431", + "name": "Strips Token", + "symbol": "STRP", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x97872eafd79940c7b24f7bcc1eadb1457347adc9", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x97872eafd79940c7b24f7bcc1eadb1457347adc9", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/sumswap_32.png", + "chainId": 42161, + "address": "0x20f9628a485ebCc566622314f6e07E7Ee61fF332", + "name": "SUM", + "symbol": "SUM", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x043c308bb8a5ae96d0093444be7f56459f1340b1", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x043c308bb8a5ae96d0093444be7f56459f1340b1", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/sushiswap-sushi-logo.png", + "chainId": 42161, + "address": "0xd4d42F0b6DEF4CE0383636770eF773390d85c61A", + "name": "SushiToken", + "symbol": "SUSHI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6b3595068778dd592e39a122f4f5a5cf09c90fe2", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x6b3595068778dd592e39a122f4f5a5cf09c90fe2", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/18740/thumb/swapr.jpg?1633516501", + "chainId": 42161, + "address": "0xdE903E2712288A1dA82942DDdF2c20529565aC30", + "name": "Swapr", + "symbol": "SWPR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6cacdb97e3fc8136805a9e7c342d866ab77d0957", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x6cacdb97e3fc8136805a9e7c342d866ab77d0957", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/tkdcoop_32.png", + "chainId": 42161, + "address": "0xFa51B42d4C9EA35F1758828226AaEdBeC50DD54E", + "name": "Taekwondo Access Credit", + "symbol": "TAC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xdeeb6091a5adc78fa0332bee5a38a8908b6b566e", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xdeeb6091a5adc78fa0332bee5a38a8908b6b566e", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/18271/thumb/tracer_logo.png?1631176676", + "chainId": 42161, + "address": "0xA72159FC390f0E3C6D415e658264c7c4051E9b87", + "name": "Tracer", + "symbol": "TCR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x9c4a4204b79dd291d6b6571c5be8bbcd0622f050", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x9c4a4204b79dd291d6b6571c5be8bbcd0622f050", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://images.prismic.io/tusd-homepage/fb4d581a-95ed-404c-b9de-7ab1365c1386_%E5%9B%BE%E5%B1%82+1.png", + "chainId": 42161, + "address": "0x4D15a3A2286D883AF0AA1B3f21367843FAc63E07", + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0000000000085d4780b73119b644ae5ecd22b376", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0000000000085d4780b73119b644ae5ecd22b376", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/2707/thumb/UnibrightLogo_colorful_500x500_preview.png?1547036916", + "chainId": 42161, + "address": "0x2aD62674A64E698C24831Faf824973C360430140", + "name": "UniBright", + "symbol": "UBT", + "decimals": 8, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x8400d94a5cb0fa0d041a3788e395285d61c9ee5e", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x8400d94a5cb0fa0d041a3788e395285d61c9ee5e", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14545/thumb/unlock.jpg?1616948136", + "chainId": 42161, + "address": "0xd5d3aA404D7562d09a848F96a8a8d5D65977bF90", + "name": "Unlock Discount Token", + "symbol": "UDT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x90de74265a416e1393a450752175aed98fe11517", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x90de74265a416e1393a450752175aed98fe11517", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12504/thumb/uniswap-uni.png?1600306604", + "chainId": 42161, + "address": "0xFa7F8980b0f1E64A2062791cc3b0871572f1F7f0", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/unitynetwork_32.png", + "chainId": 42161, + "address": "0x250F471385894fc81183a99d6fDe8CE9C5B142d6", + "name": "Unity Network", + "symbol": "UNT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x8d610e20481f4c4f3acb87bba9c46bef7795fdfe", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x8d610e20481f4c4f3acb87bba9c46bef7795fdfe", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/6319/thumb/USD_Coin_icon.png?1547042389", + "chainId": 42161, + "address": "0xFF970A61A04b1cA14834A43f5dE4533eBDDB5CC8", + "name": "USD Coin (Arb1)", + "symbol": "USDC", + "decimals": 6, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/325/thumb/Tether-logo.png?1598003707", + "chainId": 42161, + "address": "0xFd086bC7CD5C481DCC9C85ebE478A1C0b69FCbb9", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xdac17f958d2ee523a2206206994597c13d831ec7", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0xdac17f958d2ee523a2206206994597c13d831ec7", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "logoURI": "https://etherscan.io/token/images/dforceusd_32.png", + "chainId": 42161, + "address": "0xcd14C3A2ba27819B352aae73414A26e2b366dC50", + "name": "dForce USD", + "symbol": "USX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0a5e677a6a24b2f1a2bf4f3bffc443231d2fdec8", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0a5e677a6a24b2f1a2bf4f3bffc443231d2fdec8", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://etherscan.io/token/images/validator_32.png", + "chainId": 42161, + "address": "0x8d1c89DcF613e3e709AfE9Abecae591D0e2B64Ca", + "name": "Validator", + "symbol": "VALX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x27c4af9a860c4cadc358005f8b48140b2e434a7b", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x27c4af9a860c4cadc358005f8b48140b2e434a7b", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14381/thumb/visor_logo.png?1615782828", + "chainId": 42161, + "address": "0x995C235521820f2637303Ca1970c7c044583df44", + "name": "VISOR", + "symbol": "VISR", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xf938424f7210f31df2aee3011291b658f872e91e", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xf938424f7210f31df2aee3011291b658f872e91e", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12880/thumb/BSensIa.png?1603261093", + "chainId": 42161, + "address": "0x2eD14d1788dfB780fD216706096AeD018514ECcd", + "name": "Vox.Finance", + "symbol": "VOX", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x12d102f06da35cc0111eb58017fd2cd28537d0e1", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x12d102f06da35cc0111eb58017fd2cd28537d0e1", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/7598/thumb/wrapped_bitcoin_wbtc.png?1548822744", + "chainId": 42161, + "address": "0x2f2a2543B76A4166549F7aaB2e75Bef0aefC5B0f", + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x2260fac5e5542a773aa44fbcfedf7c193bc2c599", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x2260fac5e5542a773aa44fbcfedf7c193bc2c599", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/2091/thumb/xaya_logo-1.png?1547036406", + "chainId": 42161, + "address": "0xA64eCCe74F8CdB7a940766B71f1b108BAC69851a", + "name": "Wrapped CHI", + "symbol": "WCHI", + "decimals": 8, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x6dc02164d75651758ac74435806093e421b64605", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x6dc02164d75651758ac74435806093e421b64605", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/2518/thumb/weth.png?1628852295", + "chainId": 42161, + "address": "0x82aF49447D8a07e3bd95BD0d56f35241523fBab1", + "name": "Wrapped Ether", + "symbol": "WETH", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2", + "originBridgeAddress": "0x6c411ad3e74de3e7bd422b94a27770f5b86c623b", + "destBridgeAddress": "0xd92023E9d9911199a6711321D1277285e6d4e2db" + } + }, + "l1Address": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2", + "l2GatewayAddress": "0x6c411ad3e74de3e7bd422b94a27770f5b86c623b", + "l1GatewayAddress": "0xd92023E9d9911199a6711321D1277285e6d4e2db" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12921/thumb/w2UiemF__400x400.jpg?1603670367", + "chainId": 42161, + "address": "0xcAFcD85D8ca7Ad1e1C6F82F651fA15E33AEfD07b", + "name": "Wootrade Network", + "symbol": "WOO", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x4691937a7508860f876c9c0a2a617e7d9e945d4b", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x4691937a7508860f876c9c0a2a617e7d9e945d4b", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/14089/thumb/xToken.png?1614226407", + "chainId": 42161, + "address": "0xF0A5717Ec0883eE56438932b0fe4A20822735fBa", + "name": "xToken", + "symbol": "XTK", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x7f3edcdd180dbe4819bd98fee8929b5cedb3adeb", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x7f3edcdd180dbe4819bd98fee8929b5cedb3adeb", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://cryptologos.cc/logos/yearn-finance-yfi-logo.png", + "chainId": 42161, + "address": "0x82e3A8F066a6989666b031d916c43672085b1582", + "name": "yearn.finance", + "symbol": "YFI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x0bc529c00c6401aef6d220be8c6ea1667f6ad93e", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x0bc529c00c6401aef6d220be8c6ea1667f6ad93e", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/4302/thumb/zippie.jpg?1547039665", + "chainId": 42161, + "address": "0x0F61B24272AF65EACF6adFe507028957698e032F", + "name": "Zippie", + "symbol": "ZIPT", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xedd7c94fd7b4971b916d15067bc454b9e1bad980", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xedd7c94fd7b4971b916d15067bc454b9e1bad980", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/15500/thumb/ibbtc.png?1621077589", + "chainId": 42161, + "address": "0x9Ab3FD50FcAe73A1AEDa959468FD0D662c881b42", + "name": "Interest-Bearing Bitcoin", + "symbol": "ibBTC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xc4e15973e6ff2a35cc804c2cf9d2a1b817a8b40f", + "originBridgeAddress": "0x096760f208390250649e3e8763348e783aef5562", + "destBridgeAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + "l1Address": "0xc4e15973e6ff2a35cc804c2cf9d2a1b817a8b40f", + "l2GatewayAddress": "0x096760f208390250649e3e8763348e783aef5562", + "l1GatewayAddress": "0xcEe284F754E854890e311e3280b767F80797180d" + } + }, + { + "chainId": 42161, + "address": "0x4f947b40BEEB9D8130437781a560E5c7D089730f", + "name": "KAKI USDC", + "symbol": "kUSDC", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0xa124ff1e97e7f3e4a796f6a2d3bf5d0e2d41973d", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0xa124ff1e97e7f3e4a796f6a2d3bf5d0e2d41973d", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/5013/thumb/sUSD.png?1616150765", + "chainId": 42161, + "address": "0xA970AF1a584579B618be4d69aD6F73459D112F95", + "name": "Synth sUSD", + "symbol": "sUSD", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "1": { + "tokenAddress": "0x57ab1ec28d129707052df4df418d58a2d46d5f51", + "originBridgeAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "destBridgeAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + "l1Address": "0x57ab1ec28d129707052df4df418d58a2d46d5f51", + "l2GatewayAddress": "0x09e9222e96e7b4ae2a407b98d48e330053351eee", + "l1GatewayAddress": "0xa3A7B6F88361F48403514059F1F16C8E78d60EeC" + } + }, + { + "chainId": 1, + "name": "0xBitcoin", + "address": "0xb6ed7644c69416d67b522e20bc294a9a9b405b31", + "symbol": "0xBTC", + "decimals": 8, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2837.png" + }, + { + "chainId": 1, + "name": "Agave", + "address": "0x0b006e475620af076915257c6a9e40635abdbbad", + "symbol": "AGVE", + "decimals": 18 + }, + { + "chainId": 1, + "name": "Alchemy", + "address": "0x0000a1c00009a619684135b824ba02f7fbf3a572", + "symbol": "ALCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14719/thumb/sbEW5W8.png?1617939648" + }, + { + "chainId": 1, + "name": "Aluna.Social", + "address": "0x8185bc4757572da2a610f887561c32298f1a5748", + "symbol": "ALN", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5544.png" + }, + { + "chainId": 1, + "name": "Auctus", + "address": "0xc12d099be31567add4e4e4d0d45691c3f58f5663", + "symbol": "AUC", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2653.png" + }, + { + "chainId": 1, + "name": "Basis Cash", + "address": "0x3449FC1Cd036255BA1EB19d65fF4BA2b8903A69a", + "symbol": "BAC", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7813.png" + }, + { + "chainId": 1, + "name": "Badger DAO", + "address": "0x3472a5a71965499acd81997a54bba8d852c6e53d", + "symbol": "BADGER", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7859.png" + }, + { + "chainId": 1, + "name": "Balancer", + "address": "0xba100000625a3754423978a60c9317c58a424e3D", + "symbol": "BAL", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5728.png" + }, + { + "chainId": 1, + "name": "BarkCoin", + "address": "0x5bd7ef7113a32b56127ac32272609c42c97849ff", + "symbol": "BARK", + "decimals": 18 + }, + { + "chainId": 1, + "name": "BlockWallet", + "address": "0x41a3dba3d677e573636ba691a70ff2d606c29666", + "symbol": "BLANK", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8695.png" + }, + { + "chainId": 1, + "name": "BarnBridge", + "address": "0x0391D2021f89DC339F60Fff84546EA23E337750f", + "symbol": "BOND", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7440.png" + }, + { + "chainId": 1, + "name": "Boost Coin", + "address": "0x4e0fca55a6c3a94720ded91153a27f60e26b9aa8", + "symbol": "BOOST", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11216.png" + }, + { + "chainId": 1, + "name": "BTU Protocol", + "address": "0xb683d83a532e2cb7dfa5275eed3698436371cc9f", + "symbol": "BTU", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/3737.png" + }, + { + "chainId": 1, + "name": "Cap", + "address": "0x43044f861ec040DB59A7e324c40507adDb673142", + "symbol": "CAP", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5809.png" + }, + { + "chainId": 1, + "name": "Celer Network", + "address": "0x4f9254c83eb525f9fcf346490bbb3ed28a81c667", + "symbol": "CELR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/3814.png" + }, + { + "chainId": 1, + "name": "Cryption Network", + "address": "0x429876c4a6f89fb470e92456b8313879df98b63c", + "symbol": "CNT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/9747.png" + }, + { + "chainId": 1, + "name": "Compound", + "address": "0xc00e94cb662c3520282e6f5717214004a7f26888", + "symbol": "COMP", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5692.png" + }, + { + "chainId": 1, + "name": "COTI", + "address": "0xDDB3422497E61e13543BeA06989C0789117555c5", + "symbol": "COTI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/3992.png" + }, + { + "chainId": 1, + "name": "Cream Finance", + "address": "0x2ba592f78db6436527729929aaf6c908497cb200", + "symbol": "CREAM", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/6193.png" + }, + { + "chainId": 1, + "name": "Curve DAO Token", + "address": "0xD533a949740bb3306d119CC777fa900bA034cd52", + "symbol": "CRV", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/6538.png" + }, + { + "chainId": 1, + "name": "Dai", + "address": "0x6b175474e89094c44da98b954eedeac495271d0f", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/4943.png" + }, + { + "chainId": 1, + "name": "DEFI Top 5 Tokens Index", + "address": "0xfa6de2697d59e88ed7fc4dfe5a33dac43565ea41", + "symbol": "DEFI5", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8430.png" + }, + { + "chainId": 1, + "name": "DEGEN Index", + "address": "0x126c121f99e1e211df2e5f8de2d96fa36647c855", + "symbol": "DEGEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14143/thumb/alpha_logo.png?1614651244" + }, + { + "chainId": 1, + "name": "dForce", + "address": "0x431ad2ff6a9c365805ebad47ee021148d6f7dbe0", + "symbol": "DF", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/4758.png" + }, + { + "chainId": 1, + "name": "Dfyn Network", + "address": "0x9695e0114e12c0d3a3636fab5a18e6b737529023", + "symbol": "DFYN", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/9511.png" + }, + { + "chainId": 1, + "name": "dHedge DAO", + "address": "0xca1207647ff814039530d7d35df0e1dd2e91fa84", + "symbol": "DHT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7094.png" + }, + { + "chainId": 1, + "name": "DODO", + "address": "0x43dfc4159d86f3a37a5a4b3d4580b888ad7d4ddd", + "symbol": "DODO", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7224.png" + }, + { + "chainId": 1, + "name": "The Doge NFT", + "address": "0xbaac2b4491727d78d2b78815144570b9f2fe8899", + "symbol": "DOG", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11557.png" + }, + { + "chainId": 1, + "name": "Dopex", + "address": "0xeec2be5c91ae7f8a338e1e5f3b5de49d07afdc81", + "symbol": "DPX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11188.png" + }, + { + "chainId": 1, + "name": "Digital Standard Unit", + "address": "0x605d26fbd5be761089281d5cec2ce86eea667109", + "symbol": "DSU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17482/thumb/photo_2021-08-03_09-24-16.png?1627953917" + }, + { + "chainId": 1, + "name": "DeversiFi", + "address": "0xdddddd4301a082e62e84e43f474f044423921918", + "symbol": "DVF", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/10759.png" + }, + { + "chainId": 1, + "name": "DXdao", + "address": "0xa1d65e8fb6e87b60feccbc582f7f97804b725521", + "symbol": "DXD", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5589.png" + }, + { + "chainId": 1, + "name": "Empty Set Share", + "address": "0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e", + "symbol": "ESS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17481/thumb/photo_2021-08-03_03-26-29.png?1627953584" + }, + { + "chainId": 1, + "name": "dForce EUR", + "address": "0xb986f3a2d91d3704dc974a24fb735dcc5e3c1e70", + "symbol": "EUX", + "decimals": 18, + "logoURI": "https://etherscan.io/token/images/dforceeur_32.png" + }, + { + "chainId": 1, + "name": "Datamine FLUX", + "address": "0x469eda64aed3a3ad6f868c44564291aa415cb1d9", + "symbol": "FLUX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5876.png" + }, + { + "chainId": 1, + "name": "Flux Protocol", + "address": "0x7645DdfEecedA57e41f92679c4aCd83c56A81D14", + "symbol": "FLUX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/9837.png" + }, + { + "chainId": 1, + "name": "ForTube", + "address": "0x1fcdce58959f536621d76f5b7ffb955baa5a672f", + "symbol": "FOR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/4118.png" + }, + { + "chainId": 1, + "name": "Futureswap", + "address": "0x0e192d382a36de7011f795acc4391cd302003606", + "symbol": "FST", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8961.png" + }, + { + "chainId": 1, + "name": "Fuse Network", + "address": "0x970b9bb2c0444f5e81e9d0efb84c8ccdcdcaf84d", + "symbol": "FUSE", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5634.png" + }, + { + "chainId": 1, + "name": "GMX", + "address": "0xbc30049adc73de06d7a98a5189203aac66b2c830", + "symbol": "GMX", + "decimals": 18 + }, + { + "chainId": 1, + "name": "Gnosis", + "address": "0x6810e776880c02933d47db1b9fc05908e5386b96", + "symbol": "GNO", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/1659.png" + }, + { + "chainId": 1, + "name": "Govi", + "address": "0xeeaa40b28a2d1b0b08f6f97bb1dd4b75316c6107", + "symbol": "GOVI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8408.png" + }, + { + "chainId": 1, + "name": "The Graph", + "address": "0xc944e90c64b2c07662a292be6244bdf05cda44a7", + "symbol": "GRT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/6719.png" + }, + { + "chainId": 1, + "name": "Impermax", + "address": "0x7b35ce522cb72e4077baeb96cb923a5529764a00", + "symbol": "IMX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/9532.png" + }, + { + "chainId": 1, + "name": "Chemix Ecology Governance Token", + "address": "0x65d9bC970aA9B2413027fA339F7f179B3F3f2604", + "symbol": "KUN", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7721.png" + }, + { + "chainId": 1, + "name": "Land", + "address": "0x3258cd8134b6b28e814772dd91d5ecceea512818", + "symbol": "LAND", + "decimals": 18, + "logoURI": "https://etherscan.io/token/images/farmland_32.png" + }, + { + "chainId": 1, + "name": "Chainlink", + "address": "0x514910771af9ca656af840dff83e8264ecf986ca", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/1975.png" + }, + { + "chainId": 1, + "name": "Loopring", + "address": "0xbbbbca6a901c926f240b89eacb641d8aec7aeafd", + "symbol": "LRC", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/1934.png" + }, + { + "chainId": 1, + "name": "MAGIC", + "address": "0xb0c7a3ba49c7a6eaba6cd4a96c55a1391070ac9a", + "symbol": "MAGIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18623/thumb/Magic.png?1635755672" + }, + { + "chainId": 1, + "name": "My Alpha Leaderboard", + "address": "0x6619078bdd8324e01e9a8d4b3d761b050e5ecf06", + "symbol": "MAL", + "decimals": 18 + }, + { + "chainId": 1, + "name": "MATH", + "address": "0x08d967bb0134f2d07f7cfb6e246680c53927dd30", + "symbol": "MATH", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5616.png" + }, + { + "chainId": 1, + "name": "AntiMatter Governance Token", + "address": "0x9B99CcA871Be05119B2012fd4474731dd653FEBe", + "symbol": "MATTER", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8603.png" + }, + { + "chainId": 1, + "name": "MCDEX Token", + "address": "0x4e352cf164e64adcbad318c3a1e222e9eba4ce42", + "symbol": "MCB", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5956.png" + }, + { + "chainId": 1, + "name": "Maker", + "address": "0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2", + "symbol": "MKR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/1518.png" + }, + { + "chainId": 1, + "name": "Meta", + "address": "0xa3bed4e1c75d00fa6f4e5e6922db7261b5e9acd2", + "symbol": "MTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11846/thumb/mStable.png?1594950533" + }, + { + "chainId": 1, + "name": "Indexed Finance", + "address": "0x86772b1409b61c639eaac9ba0acfbb6e238e5f83", + "symbol": "NDX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8260.png" + }, + { + "chainId": 1, + "name": "New era", + "address": "0x1353a77abd236207d0588bcbbb52bc3087f85351", + "symbol": "NEC", + "decimals": 18 + }, + { + "chainId": 1, + "name": "Feisty Doge NFT", + "address": "0xDFDb7f72c1F195C5951a234e8DB9806EB0635346", + "symbol": "NFD", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11368.png" + }, + { + "chainId": 1, + "name": "OctoFi", + "address": "0x7240aC91f01233BaAf8b064248E80feaA5912BA3", + "symbol": "OCTO", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7202.png" + }, + { + "chainId": 1, + "name": "Olympus v1", + "address": "0x383518188c0c6d7730d91b2c03a03c837814a899", + "symbol": "OHM", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/16209.png" + }, + { + "chainId": 1, + "name": "OVR", + "address": "0x21bfbda47a0b4b5b1248c767ee49f7caa9b23697", + "symbol": "OVR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8144.png" + }, + { + "chainId": 1, + "name": "Perpetual Protocol", + "address": "0xbc396689893d065f41bc2c6ecbee5e0085233447", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/6950.png" + }, + { + "chainId": 1, + "name": "Pickle Finance", + "address": "0x429881672B9AE42b8EbA0E26cD9C73711b891Ca5", + "symbol": "PICKLE", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7022.png" + }, + { + "chainId": 1, + "name": "Plenny", + "address": "0x3642c0680329ae3e103e2b5ab29ddfed4d43cbe5", + "symbol": "PL2", + "decimals": 18 + }, + { + "chainId": 1, + "name": "Premia", + "address": "0x6399C842dD2bE3dE30BF99Bc7D1bBF6Fa3650E70", + "symbol": "PREMIA", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8476.png" + }, + { + "chainId": 1, + "name": "Rai Reflex Index", + "address": "0x03ab458634910aad20ef5f1c8ee96f1d6ac54919", + "symbol": "RAI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8525.png" + }, + { + "chainId": 1, + "name": "Dopex Rebate Token", + "address": "0x0ff5a8451a839f5f0bb3562689d9a44089738d11", + "symbol": "RDPX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/12057.png" + }, + { + "chainId": 1, + "name": "Rari Governance Token", + "address": "0xd291e7a03283640fdc51b121ac401383a46cc623", + "symbol": "RGT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7486.png" + }, + { + "chainId": 1, + "name": "Router Protocol", + "address": "0x16eccfdbb4ee1a85a33f3a9b21175cd7ae753db4", + "symbol": "ROUTE", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8292.png" + }, + { + "chainId": 1, + "name": "SakeToken", + "address": "0x066798d9ef0833ccc719076dab77199ecbd178b0", + "symbol": "SAKE", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/6997.png" + }, + { + "chainId": 1, + "name": "Stake DAO", + "address": "0x73968b9a57c6e53d41345fd57a6e6ae27d6cdb2f", + "symbol": "SDT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8299.png" + }, + { + "chainId": 1, + "name": "Spell Token", + "address": "0x090185f2135308bad17527004364ebcc2d37e5f6", + "symbol": "SPELL", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11289.png" + }, + { + "chainId": 1, + "name": "Strips Finance", + "address": "0x97872EAfd79940C7b24f7BCc1EADb1457347ADc9", + "symbol": "STRP", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11848.png" + }, + { + "chainId": 1, + "name": "SumSwap", + "address": "0x043c308bb8a5ae96d0093444be7f56459f1340b1", + "symbol": "SUM", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11208.png" + }, + { + "chainId": 1, + "name": "SushiSwap", + "address": "0x6b3595068778dd592e39a122f4f5a5cf09c90fe2", + "symbol": "SUSHI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/6758.png" + }, + { + "chainId": 1, + "name": "Swapr", + "address": "0x6cacdb97e3fc8136805a9e7c342d866ab77d0957", + "symbol": "SWPR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/12368.png" + }, + { + "chainId": 1, + "name": "Taekwondo Access Credit", + "address": "0xdeeb6091a5adc78fa0332bee5a38a8908b6b566e", + "symbol": "TAC", + "decimals": 18, + "logoURI": "https://etherscan.io/token/images/tkdcoop_32.png" + }, + { + "chainId": 1, + "name": "Tracer DAO", + "address": "0x9c4a4204b79dd291d6b6571c5be8bbcd0622f050", + "symbol": "TCR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/12341.png" + }, + { + "chainId": 1, + "name": "TrueUSD", + "address": "0x0000000000085d4780B73119b644AE5ecd22b376", + "symbol": "TUSD", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2563.png" + }, + { + "chainId": 1, + "name": "Unibright", + "address": "0x8400d94a5cb0fa0d041a3788e395285d61c9ee5e", + "symbol": "UBT", + "decimals": 8, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2758.png" + }, + { + "chainId": 1, + "name": "Unlock Protocol", + "address": "0x90de74265a416e1393a450752175aed98fe11517", + "symbol": "UDT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/9364.png" + }, + { + "chainId": 1, + "name": "Uniswap", + "address": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7083.png" + }, + { + "chainId": 1, + "name": "Unity Network", + "address": "0x8d610e20481f4c4f3acb87bba9c46bef7795fdfe", + "symbol": "UNT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/14602.png" + }, + { + "chainId": 1, + "name": "USD Coin", + "address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/3408.png" + }, + { + "chainId": 1, + "name": "Tether", + "address": "0xdac17f958d2ee523a2206206994597c13d831ec7", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/825.png" + }, + { + "chainId": 1, + "name": "dForce USD", + "address": "0x0a5e677a6a24b2f1a2bf4f3bffc443231d2fdec8", + "symbol": "USX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/13080.png" + }, + { + "chainId": 1, + "name": "Validator", + "address": "0x27c4af9a860c4cadc358005f8b48140b2e434a7b", + "symbol": "VALX", + "decimals": 18, + "logoURI": "https://etherscan.io/token/images/validator_32.png" + }, + { + "chainId": 1, + "name": "Visor.Finance", + "address": "0xf938424f7210f31df2aee3011291b658f872e91e", + "symbol": "VISR", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/9170.png" + }, + { + "chainId": 1, + "name": "Vox.Finance", + "address": "0x12D102F06da35cC0111EB58017fd2Cd28537d0e1", + "symbol": "VOX", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7465.png" + }, + { + "chainId": 1, + "name": "Wrapped Bitcoin", + "address": "0x2260fac5e5542a773aa44fbcfedf7c193bc2c599", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/3717.png" + }, + { + "chainId": 1, + "name": "Xaya", + "address": "0x6DC02164d75651758aC74435806093E421b64605", + "symbol": "CHI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5541.png" + }, + { + "chainId": 1, + "name": "WETH", + "address": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2", + "symbol": "WETH", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2396.png" + }, + { + "chainId": 1, + "name": "Sperax", + "address": "0x2a95FE4c7e64e09856989F9eA0b57B9AB5f770CB", + "symbol": "SPA", + "decimals": 18, + "logoURI": "https://etherscan.io/token/images/speraxtoken_32.png" + }, + { + "chainId": 1, + "name": "WOO Network", + "address": "0x4691937a7508860f876c9c0a2a617e7d9e945d4b", + "symbol": "WOO", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7501.png" + }, + { + "chainId": 1, + "name": "xToken", + "address": "0x7f3edcdd180dbe4819bd98fee8929b5cedb3adeb", + "symbol": "XTK", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/8599.png" + }, + { + "chainId": 1, + "name": "yearn.finance", + "address": "0x0bc529c00c6401aef6d220be8c6ea1667f6ad93e", + "symbol": "YFI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/5864.png" + }, + { + "chainId": 1, + "name": "Zippie", + "address": "0xedd7c94fd7b4971b916d15067bc454b9e1bad980", + "symbol": "ZIPT", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2724.png" + }, + { + "chainId": 1, + "name": "Interest-Bearing Bitcoin", + "address": "0xc4e15973e6ff2a35cc804c2cf9d2a1b817a8b40f", + "symbol": "ibBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15500/thumb/ibbtc.png?1621077589" + }, + { + "chainId": 1, + "name": "KAKI USDC", + "address": "0xa124ff1e97e7f3e4a796f6a2d3bf5d0e2d41973d", + "symbol": "kUSDC", + "decimals": 18 + }, + { + "chainId": 1, + "name": "sUSD", + "address": "0x57Ab1ec28D129707052df4dF418D58a2D46d5f51", + "symbol": "SUSD", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2927.png" + } + ], + "logoURI": "ipfs://QmTvWJ4kmzq9koK74WJQ594ov8Es1HHurHZmMmhU8VY68y" + } + \ No newline at end of file diff --git a/src/chains/ethereum/arbitrum_rinkeby_tokens.json b/src/chains/ethereum/arbitrum_rinkeby_tokens.json new file mode 100644 index 0000000000..a5e8cfd216 --- /dev/null +++ b/src/chains/ethereum/arbitrum_rinkeby_tokens.json @@ -0,0 +1,152 @@ +{ + "name": "ArbRinkeby", + "timestamp": "2022-03-01T22:29:12.223Z", + "version": { + "major": 2, + "minor": 0, + "patch": 0 + }, + "tokens": [ + { + "chainId": 421611, + "address": "0xf3f0384583d0574955Dccbb044A64Ad249cf9C3E", + "name": "Corn", + "symbol": "CORN", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "4": { + "tokenAddress": "0xd6a87faf418c818f93be9ae8b63d1d4fe3e7df45", + "originBridgeAddress": "0x9b014455acc2fe90c52803849d0002aeec184a06", + "destBridgeAddress": "0x917dc9a69F65dC3082D518192cd3725E1Fa96cA2" + } + } + } + }, + { + "chainId": 421611, + "address": "0x2f3C1B6A51A469051A22986aA0dDF98466cc8D3c", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "4": { + "tokenAddress": "0x6a9865ade2b6207daac49f8bcba9705deb0b0e6d", + "originBridgeAddress": "0x195c107f3f75c4c93eba7d9a1312f19305d6375f", + "destBridgeAddress": "0x91169Dbb45e6804743F94609De50D511C437572E" + } + } + } + }, + { + "chainId": 421611, + "address": "0x2E228ef2A59686cC5c6fF06cD46ee302a4134F00", + "name": "Land", + "symbol": "LAND", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "4": { + "tokenAddress": "0x393fd5b96f6459511d7368778318c31d719720ad", + "originBridgeAddress": "0x9b014455acc2fe90c52803849d0002aeec184a06", + "destBridgeAddress": "0x917dc9a69F65dC3082D518192cd3725E1Fa96cA2" + } + } + } + }, + { + "logoURI": "https://assets.coingecko.com/coins/images/12504/thumb/uniswap-uni.png?1600306604", + "chainId": 421611, + "address": "0x049251A7175071316e089D0616d8B6aaCD2c93b8", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "4": { + "tokenAddress": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "originBridgeAddress": "0x195c107f3f75c4c93eba7d9a1312f19305d6375f", + "destBridgeAddress": "0x91169Dbb45e6804743F94609De50D511C437572E" + } + } + } + }, + { + "chainId": 421611, + "address": "0x1E77ad77925Ac0075CF61Fb76bA35D884985019d", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "extensions": { + "bridgeInfo": { + "4": { + "tokenAddress": "0x4dbcdf9b62e891a7cec5a2568c3f4faf9e8abe2b", + "originBridgeAddress": "0x195c107f3f75c4c93eba7d9a1312f19305d6375f", + "destBridgeAddress": "0x91169Dbb45e6804743F94609De50D511C437572E" + } + } + } + }, + { + "chainId": 421611, + "address": "0xB47e6A5f8b33b3F17603C83a0535A9dcD7E32681", + "name": "Wrapped Ether", + "symbol": "WETH", + "decimals": 18, + "extensions": { + "bridgeInfo": { + "4": { + "tokenAddress": "0xc778417e063141139fce010982780140aa0cd5ab", + "originBridgeAddress": "0xf94bc045c4e926cc0b34e8d1c41cd7a043304ac9", + "destBridgeAddress": "0x81d1a19cf7071732D4313c75dE8DD5b8CF697eFD" + } + } + } + }, + { + "chainId": 4, + "name": "Corn", + "address": "0xd6a87faf418c818f93be9ae8b63d1d4fe3e7df45", + "symbol": "CORN", + "decimals": 18 + }, + { + "chainId": 4, + "name": "Dai Stablecoin", + "address": "0x6a9865ade2b6207daac49f8bcba9705deb0b0e6d", + "symbol": "DAI", + "decimals": 18 + }, + { + "chainId": 4, + "name": "Land", + "address": "0x393fd5b96f6459511d7368778318c31d719720ad", + "symbol": "LAND", + "decimals": 18 + }, + { + "chainId": 4, + "name": "Uniswap", + "address": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/7083.png" + }, + { + "chainId": 4, + "name": "USD Coin", + "address": "0x4DBCdF9B62e891a7cec5A2568C3F4FAF9E8Abe2b", + "symbol": "USDC", + "decimals": 6 + }, + { + "chainId": 4, + "name": "Wrapped Ether", + "address": "0xc778417e063141139fce010982780140aa0cd5ab", + "symbol": "WETH", + "decimals": 18 + } + ], + "logoURI": "ipfs://QmTvWJ4kmzq9koK74WJQ594ov8Es1HHurHZmMmhU8VY68y" + } \ No newline at end of file diff --git a/src/chains/ethereum/balancer/balancer.config.ts b/src/chains/ethereum/balancer/balancer.config.ts new file mode 100644 index 0000000000..2a78dffdf7 --- /dev/null +++ b/src/chains/ethereum/balancer/balancer.config.ts @@ -0,0 +1,19 @@ +export namespace BalancerConfig { + export interface NetworkConfig { + balancerAddress: string; + } + + export interface Config { + mainnet: NetworkConfig; + kovan: NetworkConfig; + } + + export const config: Config = { + mainnet: { + balancerAddress: '0x3E66B66Fd1d0b02fDa6C811Da9E0547970DB2f21', + }, + kovan: { + balancerAddress: '0x4e67bf5bD28Dd4b570FBAFe11D0633eCbA2754Ec', + }, + }; +} diff --git a/src/chains/ethereum/erc20_tokens_goerli.json b/src/chains/ethereum/erc20_tokens_goerli.json new file mode 100644 index 0000000000..31a58ce028 --- /dev/null +++ b/src/chains/ethereum/erc20_tokens_goerli.json @@ -0,0 +1,148 @@ +{ + "name": "goerli", + "tokens": [ + { + "name": "Wrapped Ether", + "address": "0xB4FBF271143F4FBf7B91A5ded31805e42b2208d6", + "symbol": "WETH", + "decimals": 18, + "chainId": 5, + "logoURI": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0xB4FBF271143F4FBf7B91A5ded31805e42b2208d6/logo.png" + }, + { + "name": "Uniswap", + "address": "0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984", + "symbol": "UNI", + "decimals": 18, + "chainId": 5, + "logoURI": "ipfs://QmXttGpZrECX5qCyXbBQiqgQNytVGeZW5Anewvh2jc4psg" + }, + { + "chainId": 5, + "address": "0xe4E81Fa6B16327D4B78CFEB83AAdE04bA7075165", + "name": "0x Protocol Token", + "symbol": "ZRX", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_ZRX.svg" + }, + { + "chainId": 5, + "address": "0xCEC4a43eBB02f9B80916F1c718338169d6d5C1F0", + "name": "Compound USD Coin", + "symbol": "cUSDC", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_usdc.svg" + }, + { + "chainId": 5, + "address": "0x822397d9a55d0fefd20F5c4bCaB33C5F65bd28Eb", + "name": "Compound Dai", + "symbol": "cDAI", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_dai.svg" + }, + { + "chainId": 5, + "address": "0xdc31Ee1784292379Fbb2964b3B9C4124D8F89C60", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_DAI.svg" + }, + { + "chainId": 5, + "address": "0xe16C7165C8FeA64069802aE4c4c9C320783f2b6e", + "name": "Compound", + "symbol": "COMP", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_COMP.svg" + }, + { + "chainId": 5, + "address": "0xCCaF265E7492c0d9b7C2f0018bf6382Ba7f0148D", + "name": "Compound Basic Attention Token", + "symbol": "cBAT", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_bat.svg" + }, + { + "chainId": 5, + "address": "0x70cBa46d2e933030E2f274AE58c951C800548AeF", + "name": "Basic Attention Token", + "symbol": "BAT", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_BAT.svg" + }, + { + "chainId": 5, + "address": "0x20572e4c090f15667cF7378e16FaD2eA0e2f3EfF", + "name": "Compound Ether", + "symbol": "cETH", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_eth.svg" + }, + { + "chainId": 5, + "address": "0xC04B0d3107736C32e19F1c62b2aF67BE61d63a05", + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8 + }, + { + "chainId": 5, + "address": "0x6CE27497A64fFFb5517AA4aeE908b1E7EB63B9fF", + "name": "Compound Wrapped BTC", + "symbol": "cWBTC", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_wbtc.svg" + }, + { + "chainId": 5, + "address": "0xA253295eC2157B8b69C44b2cb35360016DAa25b1", + "name": "Compound 0x", + "symbol": "cZRX", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_zrx.svg" + }, + { + "chainId": 5, + "address": "0xD87Ba7A50B2E7E660f678A895E4B72E7CB4CCd9C", + "name": "USD Coin USDC", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_USDC.svg" + }, + { + "chainId": 5, + "address": "0x1d70B01A2C3e3B2e56FcdcEfe50d5c5d70109a5D", + "name": "Compound Augur", + "symbol": "cREP", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_rep.svg" + }, + { + "chainId": 5, + "address": "0x183Faf58c4461972765f3F90c6272A4ecE66Bd96", + "name": "Reputation", + "symbol": "REP", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_REP.svg" + }, + { + "chainId": 5, + "address": "0x5D4373F8C1AF21C391aD7eC755762D8dD3CCA809", + "name": "Compound Sai", + "symbol": "cSAI", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/ctoken_sai.svg" + }, + { + "chainId": 5, + "address": "0x8e9192D6f9d903b1BEb3836F52a9f71E05846e42", + "name": "Sai Stablecoin v1.0", + "symbol": "SAI", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/compound-finance/token-list/master/assets/asset_SAI.svg" + } + ] +} diff --git a/src/chains/ethereum/erc20_tokens_kovan.json b/src/chains/ethereum/erc20_tokens_kovan.json new file mode 100644 index 0000000000..d236eb4773 --- /dev/null +++ b/src/chains/ethereum/erc20_tokens_kovan.json @@ -0,0 +1,83 @@ +{ + "name": "kovan", + "tokens": [ + { + "symbol": "BAT", + "chainId": 42, + "address": "0x1f1f156E0317167c11Aa412E3d1435ea29Dc3cCE", + "decimals": 18 + }, + { + "symbol": "WETH", + "chainId": 42, + "address": "0xd0A1E359811322d97991E03f863a0C30C2cF029C", + "decimals": 18 + }, + { + "symbol": "DAI", + "chainId": 42, + "address": "0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa", + "decimals": 18 + }, + { + "symbol": "MKR", + "chainId": 42, + "address": "0xef13C0c8abcaf5767160018d268f9697aE4f5375", + "decimals": 18 + }, + { + "symbol": "USDC", + "chainId": 42, + "address": "0x2F375e94FC336Cdec2Dc0cCB5277FE59CBf1cAe5", + "decimals": 6 + }, + { + "symbol": "REP", + "chainId": 42, + "address": "0x8c9e6c40d3402480ACE624730524fACC5482798c", + "decimals": 18 + }, + { + "symbol": "WBTC", + "chainId": 42, + "address": "0xe0C9275E44Ea80eF17579d33c55136b7DA269aEb", + "decimals": 18 + }, + { + "symbol": "SNX", + "chainId": 42, + "address": "0x86436BcE20258a6DcfE48C9512d4d49A30C4d8c4", + "decimals": 18 + }, + { + "symbol": "ANT", + "chainId": 42, + "address": "0x37f03a12241E9FD3658ad6777d289c3fb8512Bc9", + "decimals": 18 + }, + { + "symbol": "ZRX", + "chainId": 42, + "address": "0xccb0F4Cf5D3F97f4a55bb5f5cA321C3ED033f244", + "decimals": 18 + }, + { + "symbol": "COIN1", + "chainId": 42, + "address": "0x809F5A762e7b0CC75C42cd76098b85CB7BD2BA64", + "decimals": 18 + }, + { + "symbol": "COIN2", + "chainId": 42, + "address": "0x9866c4043bc6cf47eaf845c56f6ab221c204e0df", + "decimals": 8 + }, + { + "symbol": "COIN3", + "chainId": 42, + "address": "0x3D2097889B97A9eF23B3eA8FC10c626fbda29099", + "decimals": 18 + } + ] +} diff --git a/src/chains/ethereum/erc20_tokens_mainnet.json b/src/chains/ethereum/erc20_tokens_mainnet.json new file mode 100644 index 0000000000..d713c0d28f --- /dev/null +++ b/src/chains/ethereum/erc20_tokens_mainnet.json @@ -0,0 +1,37707 @@ +{ + "name": "CoinGecko", + "logoURI": "https://www.coingecko.com/assets/thumbnail-007177f3eca19695592f0b8b0eabbdae282b54154e1be912285c9034ea6cbaf2.png", + "keywords": [ + "defi" + ], + "timestamp": "2022-12-15T13:07:03.578+00:00", + "tokens": [ + { + "chainId": 1, + "address": "0xb5fe099475d3030dde498c3bb6f3854f762a48ad", + "name": "Fnk com", + "symbol": "FNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13483/thumb/fnk.png?1609039834" + }, + { + "chainId": 1, + "address": "0x213c53c96a01a89e6dcc5683cf16473203e17513", + "name": "Defi Shopping Stake", + "symbol": "DSS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12602/thumb/DSS.png?1601002204" + }, + { + "chainId": 1, + "address": "0x354e514c135c8603f840ffadb4c33cde6d2a37e0", + "name": "Unilock Network", + "symbol": "UNL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23576/thumb/unilock-logo.png?1650449646" + }, + { + "chainId": 1, + "address": "0x8720c8429b78df262360b0f39917a03f9b894746", + "name": "Frenzy", + "symbol": "FZY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11096/thumb/frenzy-singapore.jpg?1588212527" + }, + { + "chainId": 1, + "address": "0xe4f6d46c244bb7cf3e218cdfb5c35cf9a4d9c920", + "name": "Donkey", + "symbol": "DONK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15330/thumb/donkey_logo.jpg?1620549377" + }, + { + "chainId": 1, + "address": "0x3130c55d6138809687a1bfbe0f0cc258df37b81e", + "name": "Coil", + "symbol": "COIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27777/thumb/R1JruDU3_400x400.jpg?1665728793" + }, + { + "chainId": 1, + "address": "0xb48b7e5bf6563b3e0a85055821a83deb8cfc12f6", + "name": "NOVA", + "symbol": "NOVA", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/6545/thumb/N7d0x35q_400x400.jpg?1547042760" + }, + { + "chainId": 1, + "address": "0xd39a2cecba2657e125ba6a5c98ad2f6b6d7e83fd", + "name": "Luxo", + "symbol": "LUXO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25545/thumb/ik7UTHJR_400x400.jpg?1652327828" + }, + { + "chainId": 1, + "address": "0x08ad83d779bdf2bbe1ad9cc0f78aa0d24ab97802", + "name": "Robonomics Web Services", + "symbol": "RWS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11885/thumb/rws_logo.png?1595745253" + }, + { + "chainId": 1, + "address": "0xf552b656022c218c26dad43ad88881fc04116f76", + "name": "MORK", + "symbol": "MORK", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/12183/thumb/mork-logo.png?1597941710" + }, + { + "chainId": 1, + "address": "0x47b28f365bf4cb38db4b6356864bde7bc4b35129", + "name": "FNB Protocol", + "symbol": "FNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8157/thumb/FNB_protocol.jpg?1555650192" + }, + { + "chainId": 1, + "address": "0xbe393aa534f82c0ffac31bf06a23e283acb3352b", + "name": "TokenAsset", + "symbol": "NTB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13710/thumb/8284.png?1611097251" + }, + { + "chainId": 1, + "address": "0xae697f994fc5ebc000f8e22ebffee04612f98a0d", + "name": "LGCY Network", + "symbol": "LGCY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12181/thumb/LGCY_network.jpg?1597926587" + }, + { + "chainId": 1, + "address": "0x47e67ba66b0699500f18a53f94e2b9db3d47437e", + "name": "PlayGame", + "symbol": "PXG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7242/thumb/pxg-coin_3x.png?1547043841" + }, + { + "chainId": 1, + "address": "0x07e3c70653548b04f0a75970c1f81b4cbbfb606f", + "name": "Agrello", + "symbol": "DLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/900/thumb/delta_200x200.png?1616645398" + }, + { + "chainId": 1, + "address": "0x6bea7cfef803d1e3d5f7c0103f7ded065644e197", + "name": "Gamma Strategies", + "symbol": "GAMMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21975/thumb/gamma-token-200.png?1640566576" + }, + { + "chainId": 1, + "address": "0xe99de844ef3ef72806cf006224ef3b813e82662f", + "name": "YouMinter", + "symbol": "UMINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24564/thumb/xXlHazn__400x400.jpg?1648190269" + }, + { + "chainId": 1, + "address": "0x1500205f50bf3fd976466d0662905c9ff254fc9c", + "name": "BitBoost", + "symbol": "BBT", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/1194/thumb/bitboost.jpg?1547035224" + }, + { + "chainId": 1, + "address": "0x81dbc1c8e40c3095071949eda9800c2209a7279a", + "name": "Pupper", + "symbol": "PUP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16038/thumb/puppy.PNG?1622680387" + }, + { + "chainId": 1, + "address": "0x990e081a7b7d3ccba26a2f49746a68cc4ff73280", + "name": "KStarCoin", + "symbol": "KSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1630/thumb/ksc.png?1547035850" + }, + { + "chainId": 1, + "address": "0xa0cf46eb152656c7090e769916eb44a138aaa406", + "name": "Spheroid Universe", + "symbol": "SPH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11968/thumb/spheroid-sph-icon-400x400.png?1597307957" + }, + { + "chainId": 1, + "address": "0xf2051511b9b121394fa75b8f7d4e7424337af687", + "name": "DAOhaus", + "symbol": "HAUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14551/thumb/jN3kkqke_400x400.png?1616990048" + }, + { + "chainId": 1, + "address": "0xb045f7f363fe4949954811b113bd56d208c67b23", + "name": "Spider Tanks", + "symbol": "SILK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/28057/thumb/SILK_Logo.png?1667295996" + }, + { + "chainId": 1, + "address": "0x78b039921e84e726eb72e7b1212bb35504c645ca", + "name": "Sether", + "symbol": "SETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2101/thumb/sether.png?1548609212" + }, + { + "chainId": 1, + "address": "0x40e0a6ef9dbadfc83c5e0d15262feb4638588d77", + "name": "APE", + "symbol": "APE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20762/thumb/uXhjvO7.png?1637651257" + }, + { + "chainId": 1, + "address": "0x69fa0fee221ad11012bab0fdb45d444d3d2ce71c", + "name": "Thorstarter", + "symbol": "XRUNE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16835/thumb/thorstarter.jpg?1625279004" + }, + { + "chainId": 1, + "address": "0xdaab5e695bb0e8ce8384ee56ba38fa8290618e52", + "name": "CRDT", + "symbol": "CRDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11859/thumb/image_%281%29.png?1600937373" + }, + { + "chainId": 1, + "address": "0xa10740ff9ff6852eac84cdcff9184e1d6d27c057", + "name": "Wrapped Gen 0 CryptoKitties", + "symbol": "WG0", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12870/thumb/wg0_logo.png?1603176705" + }, + { + "chainId": 1, + "address": "0xe692c8d72bd4ac7764090d54842a305546dd1de5", + "name": "ANY Blocknet", + "symbol": "ABLOCK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14869/thumb/blocknet.jpg?1618816800" + }, + { + "chainId": 1, + "address": "0xcf58b4e4863c0d085bd1c65b3f2932e261547fab", + "name": "Lorde Edge", + "symbol": "EDGELON", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20006/thumb/edgelon.png?1636365734" + }, + { + "chainId": 1, + "address": "0x296233e84c1d7bff11121bf6d60f0ffa39c3f0cf", + "name": "No One", + "symbol": "NOONE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19393/thumb/logo-200x200_%289%29.png?1635150101" + }, + { + "chainId": 1, + "address": "0x12fd19dac0fab61bed5e0f09091b470c452d4d61", + "name": "Echoin", + "symbol": "EC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9354/thumb/L32_KzNQ_400x400.jpg?1566513096" + }, + { + "chainId": 1, + "address": "0x08f7be99ed83369541501d60f4e66f8e34c3f736", + "name": "Cryptoku", + "symbol": "CKU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25813/thumb/Cryptoku.png?1653988443" + }, + { + "chainId": 1, + "address": "0xa14ea0e11121e6e951e87c66afe460a00bcd6a16", + "name": "IdleDAI Risk Adjusted ", + "symbol": "IDLEDAISAFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11929/thumb/idledai-safe.png?1596263241" + }, + { + "chainId": 1, + "address": "0x0ff5a8451a839f5f0bb3562689d9a44089738d11", + "name": "Dopex Rebate", + "symbol": "RDPX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16659/thumb/rDPX_200x200_Coingecko.png?1624614475" + }, + { + "chainId": 1, + "address": "0x48be867b240d2ffaff69e0746130f2c027d8d3d2", + "name": "Elevate", + "symbol": "ELE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13802/thumb/elevate-logo.png?1611980666" + }, + { + "chainId": 1, + "address": "0xbbcd3e4eb43aa7f3f57286da31333d53b24d0d6a", + "name": "Laro", + "symbol": "LRC", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/25925/thumb/lorologo.png?1654673196" + }, + { + "chainId": 1, + "address": "0x5022cb6d39001cdd6f996e8a66500c86128f1cc4", + "name": "Shiwa", + "symbol": "SHIWA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28070/thumb/shiwa200.png?1667376980" + }, + { + "chainId": 1, + "address": "0x2b100be232f90dd33d3b6e4b9ad70d1e8ac0e208", + "name": "MarX", + "symbol": "MARX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16258/thumb/marx.PNG?1623402476" + }, + { + "chainId": 1, + "address": "0x187eff9690e1f1a61d578c7c492296eaab82701a", + "name": "Moar Finance", + "symbol": "MOAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15057/thumb/moar.PNG?1619589388" + }, + { + "chainId": 1, + "address": "0xb3bace433288645114fe8e8aa91f87659cbf665b", + "name": "Wallet Plus X", + "symbol": "WPX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10302/thumb/WPX_LOGO_200X200.png?1577693149" + }, + { + "chainId": 1, + "address": "0x19fdc290974b574065ff8db4303a0b76aecf223e", + "name": "AGPC", + "symbol": "AGPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17772/thumb/AGPC.jpg?1629441589" + }, + { + "chainId": 1, + "address": "0xde4c5a791913838027a2185709e98c5c6027ea63", + "name": "General Attention Currency", + "symbol": "XAC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9203/thumb/-LF1XcKS_400x400.png?1565131564" + }, + { + "chainId": 1, + "address": "0xbb70adbe39408cb1e5258702ea8ada7c81165b73", + "name": "AnteDAO", + "symbol": "ANTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25855/thumb/ante_symbol.png?1654151638" + }, + { + "chainId": 1, + "address": "0x3a92bd396aef82af98ebc0aa9030d25a23b11c6b", + "name": "Tokenbox", + "symbol": "TBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2644/thumb/tokenbox.png?1547036822" + }, + { + "chainId": 1, + "address": "0x81995ff7aee5c780192b47e0b42a7a86692d1415", + "name": "Speedcash", + "symbol": "SCS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2929/thumb/scs_logo_200x200.png?1606439865" + }, + { + "chainId": 1, + "address": "0x2aeccb42482cc64e087b6d2e5da39f5a7a7001f8", + "name": "Ruler Protocol", + "symbol": "RULER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14183/thumb/ruler_token.png?1614821796" + }, + { + "chainId": 1, + "address": "0xcb4d749fd1ff081d6fea3bd978de87603e098e63", + "name": "Jenny DAO V2", + "symbol": "JENNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28116/thumb/jenny.png?1667554356" + }, + { + "chainId": 1, + "address": "0xf1376bcef0f78459c0ed0ba5ddce976f1ddf51f4", + "name": "Universal ETH", + "symbol": "UNIETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28477/thumb/uniETH_200.png?1671004791" + }, + { + "chainId": 1, + "address": "0x0d8775f648430679a709e98d2b0cb6250d2887ef", + "name": "Basic Attention", + "symbol": "BAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/677/thumb/basic-attention-token.png?1547034427" + }, + { + "chainId": 1, + "address": "0x37e8789bb9996cac9156cd5f5fd32599e6b91289", + "name": "AidCoin", + "symbol": "AID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2144/thumb/aid.png?1547036449" + }, + { + "chainId": 1, + "address": "0xecacab6725ac1711d97e55df35d525b863b8b9f7", + "name": "Trillion", + "symbol": "TT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17216/thumb/EC65-CF15-3575-41-C7-8-D2-F-0-B2-FDC82-DF96.jpg?1626877437" + }, + { + "chainId": 1, + "address": "0x9cf77be84214beb066f26a4ea1c38ddcc2afbcf7", + "name": "Meta Shiba", + "symbol": "MSHIBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19962/thumb/mshiba.png?1636342508" + }, + { + "chainId": 1, + "address": "0x96ef7f9cf1b6ecc66e482a6598fc9f009e9277da", + "name": "Pomi", + "symbol": "POMI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/22428/thumb/pomilogo.png?1641821967" + }, + { + "chainId": 1, + "address": "0x36d076480eb31c717137f400f9761a5151124c4b", + "name": "FLYPE DAO", + "symbol": "FLYP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27283/thumb/FLYPE_LOGO_200X200.jpg?1663140374" + }, + { + "chainId": 1, + "address": "0x043c308bb8a5ae96d0093444be7f56459f1340b1", + "name": "SumSwap", + "symbol": "SUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17586/thumb/sunswap.PNG?1628570741" + }, + { + "chainId": 1, + "address": "0x66e5d4063219a54a8244078affb49e23982d9640", + "name": "UZURAS", + "symbol": "UZZ", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7306/thumb/uzura.png?1572096519" + }, + { + "chainId": 1, + "address": "0x398dc1c12a268b657abd0cd88999156228acb91a", + "name": "Peacockcoin ETH ", + "symbol": "PEKC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18373/thumb/pekc.jpg?1631679728" + }, + { + "chainId": 1, + "address": "0x672a1ad4f667fb18a333af13667aa0af1f5b5bdd", + "name": "Verify", + "symbol": "CRED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1349/thumb/verify.png?1548759755" + }, + { + "chainId": 1, + "address": "0x46e98ffe40e408ba6412beb670507e083c8b95ff", + "name": "Primate", + "symbol": "PRIMATE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25245/thumb/benji-logo-512x512.png?1651028701" + }, + { + "chainId": 1, + "address": "0x66bcd0c22bb15cd1ba7199c7a383dc89528f4427", + "name": "Buhund", + "symbol": "BUH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27835/thumb/CG.jpeg?1665996180" + }, + { + "chainId": 1, + "address": "0xc949fc82a15964fb5b97e5cf8f9ffed139086821", + "name": "PGPay", + "symbol": "PGPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6351/thumb/pgpay-logo.jpg?1582515723" + }, + { + "chainId": 1, + "address": "0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e", + "name": "Empty Set Share", + "symbol": "ESS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17481/thumb/photo_2021-08-03_03-26-29.png?1627953584" + }, + { + "chainId": 1, + "address": "0x1095d4a344a4760900071025d6103a17a361abad", + "name": "Erzurumspor Token", + "symbol": "ERZ", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24809/thumb/17059.png?1649024114" + }, + { + "chainId": 1, + "address": "0x514910771af9ca656af840dff83e8264ecf986ca", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/877/thumb/chainlink-new-logo.png?1547034700" + }, + { + "chainId": 1, + "address": "0x4d224452801aced8b2f0aebe155379bb5d594381", + "name": "ApeCoin", + "symbol": "APE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24383/thumb/apecoin.jpg?1647476455" + }, + { + "chainId": 1, + "address": "0x8be6a6158f6b8a19fe60569c757d16e546c2296d", + "name": "YFF Finance", + "symbol": "YFF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12578/thumb/5ymP5emT_400x400.jpg?1600913790" + }, + { + "chainId": 1, + "address": "0x3a82d3111ab5faf39d847d46023d9090261a658f", + "name": "Tycoon", + "symbol": "TYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15165/thumb/coingecko.png?1622177525" + }, + { + "chainId": 1, + "address": "0x07bac35846e5ed502aa91adf6a9e7aa210f2dcbe", + "name": "Sifchain", + "symbol": "EROWAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14044/thumb/EROWAN.png?1614656300" + }, + { + "chainId": 1, + "address": "0xee0f286776639cd363da810daf3e0623f82576b0", + "name": "Lung Protocol", + "symbol": "L2P", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11799/thumb/64280570.png?1594359841" + }, + { + "chainId": 1, + "address": "0x6d0f5149c502faf215c89ab306ec3e50b15e2892", + "name": "Portion", + "symbol": "PRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13617/thumb/OKeO2FI.png?1610327038" + }, + { + "chainId": 1, + "address": "0x19b58d95929586ad750893caad43e77aa6e8ce9e", + "name": "CelCoin", + "symbol": "CELC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6078/thumb/celcoin-logo.png?1547042055" + }, + { + "chainId": 1, + "address": "0x73d7c860998ca3c01ce8c808f5577d94d545d1b4", + "name": "IX Swap", + "symbol": "IXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18069/thumb/ixswap.PNG?1630375152" + }, + { + "chainId": 1, + "address": "0x214feebda3ae6bb842bd17d91a0f346eebcd7898", + "name": "Autentica", + "symbol": "AUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27154/thumb/coingecko_200x200.png?1662205740" + }, + { + "chainId": 1, + "address": "0xe2fe5e7e206e7b46cad6a5146320e5b4b9a18e97", + "name": "Bitcomo", + "symbol": "BM", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/4127/thumb/Webp.net-resizeimage_%2828%29.png?1547039349" + }, + { + "chainId": 1, + "address": "0xef7a985e4ff9b5dccd6eddf58577486887288711", + "name": "HOMT", + "symbol": "HOMT", + "decimals": 15, + "logoURI": "https://assets.coingecko.com/coins/images/11597/thumb/HOM-Token-Logo.jpg?1591668252" + }, + { + "chainId": 1, + "address": "0xe9fa21e671bcfb04e6868784b89c19d5aa2424ea", + "name": "Eurocoin ECTE", + "symbol": "ECTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7634/thumb/logotoken200x200.png?1550742362" + }, + { + "chainId": 1, + "address": "0x6d6554939d646f274d0fc3cecb7dab5d76bc908f", + "name": "Morphswap", + "symbol": "MS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28114/thumb/mslogo200.png?1668056773" + }, + { + "chainId": 1, + "address": "0x3ebb4a4e91ad83be51f8d596533818b246f4bee1", + "name": "Signata", + "symbol": "SATA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14704/thumb/logo.png?1617853256" + }, + { + "chainId": 1, + "address": "0x6769d86f9c430f5ac6d9c861a0173613f1c5544c", + "name": "KoaCombat", + "symbol": "KOACOMBAT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23827/thumb/jGYAi2LB_400x400.jpg?1645515278" + }, + { + "chainId": 1, + "address": "0xfffffffff15abf397da76f1dcc1a1604f45126db", + "name": "Falconswap", + "symbol": "FSW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12256/thumb/falconswap.png?1598534184" + }, + { + "chainId": 1, + "address": "0x0829d2d5cc09d3d341e813c821b0cfae272d9fb2", + "name": "Social Rocket", + "symbol": "ROCKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12994/thumb/logo-256x256-1.png?1604759401" + }, + { + "chainId": 1, + "address": "0xe9966c1184f8552fcb16f65addba9dd08fe8f4ea", + "name": "MY Ceremonial Event", + "symbol": "MYCE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19182/thumb/BuoVrgpA_400x400.png?1634613857" + }, + { + "chainId": 1, + "address": "0x4f2ab9d03ce5b8d0d3bca09259c78005d2775e08", + "name": "Mewtwo Inu", + "symbol": "MEWTWO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19562/thumb/mewtwo_update.png?1635422500" + }, + { + "chainId": 1, + "address": "0xed0889f7e1c7c7267407222be277e1f1ef4d4892", + "name": "MELX", + "symbol": "MEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15028/thumb/melx.jpeg?1637156878" + }, + { + "chainId": 1, + "address": "0xbf682bd31a615123d28d611b38b0ae3d2b675c2c", + "name": "OT PENDLE ETH", + "symbol": "OT-PE-29DEC2022", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18136/thumb/ot-pendle_eth_slp.573d443c.png?1630640424" + }, + { + "chainId": 1, + "address": "0x1f31dd60b84ea2a273cfc56876437e069ae80afd", + "name": "Shinji Inu", + "symbol": "SHINJI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22846/thumb/Attachment_1645539736.png?1646300191" + }, + { + "chainId": 1, + "address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/6319/thumb/USD_Coin_icon.png?1547042389" + }, + { + "chainId": 1, + "address": "0x70fadbe1f2cccbaf98ac88fdcf94a0509a48e46d", + "name": "Green Light", + "symbol": "GL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11015/thumb/greenlight.PNG?1587114464" + }, + { + "chainId": 1, + "address": "0xe0c8087ce1a17bdd5d6c12eb52f8d7eff7791987", + "name": "Linfinity", + "symbol": "LFC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5364/thumb/Linfinity-logo.jpg?1547040963" + }, + { + "chainId": 1, + "address": "0x00d8318e44780edeefcf3020a5448f636788883c", + "name": "dAppstore", + "symbol": "DAPPX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15780/thumb/large-logo.png?1621841062" + }, + { + "chainId": 1, + "address": "0x1dea979ae76f26071870f824088da78979eb91c8", + "name": "SPINDLE", + "symbol": "SPD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3714/thumb/spindle-core-logo.png?1547038741" + }, + { + "chainId": 1, + "address": "0x7d1356bfcaa08af4ab0d643af1b6b4cd75ccc2d0", + "name": "Arcade Canine", + "symbol": "OKINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27748/thumb/SwJ8JwH.png?1665645891" + }, + { + "chainId": 1, + "address": "0xad7ca17e23f13982796d27d1e6406366def6ee5f", + "name": "rHEGIC2", + "symbol": "RHEGIC2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13969/thumb/ezgif-4-b5306690cb32.jpg?1613385300" + }, + { + "chainId": 1, + "address": "0x76dbcba41e11784bfa95ce30e529fa533c3fa4ad", + "name": "Smart Marketing", + "symbol": "SMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21905/thumb/smt-logo.png?1640234993" + }, + { + "chainId": 1, + "address": "0xa8eda9d4aee0eb882f8752c6ba7e16d9233c9ad2", + "name": "LevelApp", + "symbol": "LVL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5588/thumb/n5DaGBqY_400x400.jpg?1559789019" + }, + { + "chainId": 1, + "address": "0x155ff1a85f440ee0a382ea949f24ce4e0b751c65", + "name": "Behodler", + "symbol": "EYE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12804/thumb/etherscan-eye-2-1.png?1629881415" + }, + { + "chainId": 1, + "address": "0xcdd2fa4c2b36a1a14edc41da1c9f9b2cb9f981aa", + "name": "Duzce", + "symbol": "DUZCE", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/25979/thumb/20569.png?1655113117" + }, + { + "chainId": 1, + "address": "0xe74dc43867e0cbeb208f1a012fc60dcbbf0e3044", + "name": "DeFIRE", + "symbol": "CWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15722/thumb/defire.PNG?1621635373" + }, + { + "chainId": 1, + "address": "0xeadd9b69f96140283f9ff75da5fd33bcf54e6296", + "name": "Crypto Carbon Energy", + "symbol": "CYCE", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/17806/thumb/cyceicon.png?1629464571" + }, + { + "chainId": 1, + "address": "0x1fbd3df007eb8a7477a1eab2c63483dcc24effd6", + "name": "Scaleswap", + "symbol": "SCA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16360/thumb/thumbnail_1170823958_vertical_logo_lateral_radiance.png?1623810516" + }, + { + "chainId": 1, + "address": "0x1e05f68b29b286fb3bbad3c688d7e2abda549b80", + "name": "Picipo", + "symbol": "PICIPO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18758/thumb/kEpQ95VG_400x400.jpg?1633350594" + }, + { + "chainId": 1, + "address": "0x8feef860e9fa9326ff9d7e0058f637be8579cc29", + "name": "Timers", + "symbol": "IPM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12649/thumb/logo200x200_%282%29.png?1601421807" + }, + { + "chainId": 1, + "address": "0xe0c05ec44775e4ad62cdc2eecdf337aa7a143363", + "name": "Mancium", + "symbol": "MANC", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/25084/thumb/IKpuMYuGaMHEE0nrDUwpf6DqLQ5zTfZ1sak6ZqeIe2snV4GqQbh4Eic6hHcPl_OpBmlhcrRJ5kqoGzwB1CezMiDYnwR6rDT08_l8zb3-y3aPhTv7_0x5g4IO9JpQXDViEIqTZ7gYzTXqkcP6MH_uCFxQF-l-ohR0-FdT8O-ZTmNUKm--OuqEf9DVa-miAFp4t2pN-kcJ5Jv8woPj51yk-zna8c.jpg?1650265130" + }, + { + "chainId": 1, + "address": "0x0258f474786ddfd37abce6df6bbb1dd5dfc4434a", + "name": "Orion Protocol", + "symbol": "ORN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11841/thumb/orion_logo.png?1594943318" + }, + { + "chainId": 1, + "address": "0xc278041fdd8249fe4c1aad1193876857eea3d68c", + "name": "IdleTUSD Best Yield ", + "symbol": "IDLETUSDYIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11935/thumb/idletusdv3mMaxyield_32.png?1596263719" + }, + { + "chainId": 1, + "address": "0x95b4ef2869ebd94beb4eee400a99824bf5dc325b", + "name": "cMKR", + "symbol": "CMKR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17528/thumb/cmkr.PNG?1628122490" + }, + { + "chainId": 1, + "address": "0xc8c424b91d8ce0137bab4b832b7f7d154156ba6c", + "name": "apM Coin", + "symbol": "APM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10069/thumb/PvDCvh5h_400x400.png?1575460334" + }, + { + "chainId": 1, + "address": "0x29cbd0510eec0327992cd6006e63f9fa8e7f33b7", + "name": "Tidal Finance", + "symbol": "TIDAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14460/thumb/Tidal-mono.png?1616233894" + }, + { + "chainId": 1, + "address": "0x9b8c184439245b7bb24a5b2ec51ec81c39589e8a", + "name": "KIMEX", + "symbol": "KMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8062/thumb/XSsfMr8.png?1554083098" + }, + { + "chainId": 1, + "address": "0x13b1e6b036ac0a1495f876313f92a0706cc10871", + "name": "ShipItPro", + "symbol": "SHPP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14687/thumb/photo_2020-12-28_16-37-33.jpg?1617785737" + }, + { + "chainId": 1, + "address": "0xa350da05405cc204e551c4eed19c3039646528d5", + "name": "Blocksport", + "symbol": "BSPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23735/thumb/lUjOcgBNs1fSMbGND5bmUMSKaVYybK5oDblEFgqX5Tvcg89_U3yzRRHzcR5UMpzObjlps5ZpumoYjtP9R2ddgsUkP0xyw3p5R_VMAh5qIQfUu8IGicH2xEzzwHM5ayPOh8PaO_BEFxjvYlYpt1Fknz6OdOhQrTBhh8kBfG0De1HEGZLe7dJGKnoLRzlyYkzYcIimMy-rzp2swB.jpg?1645174474" + }, + { + "chainId": 1, + "address": "0x6cf9464b2c628db187f2bc1ddc0c43fda72efdd5", + "name": "Sivasspor", + "symbol": "SIV", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/22043/thumb/16528.png?1640674444" + }, + { + "chainId": 1, + "address": "0x36ce7a52cda404b8fa87a98d0d17ec7dd0b144ed", + "name": "Pinkslip Finance", + "symbol": "PSLIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17960/thumb/MgCiNzk.png?1629943128" + }, + { + "chainId": 1, + "address": "0xc237868a9c5729bdf3173dddacaa336a0a5bb6e0", + "name": "Wagerr", + "symbol": "WGR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/759/thumb/syGKmAT.png?1619597241" + }, + { + "chainId": 1, + "address": "0x70edf1c215d0ce69e7f16fd4e6276ba0d99d4de7", + "name": "CHEQD Network", + "symbol": "CHEQ", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20855/thumb/79901197.png?1637791407" + }, + { + "chainId": 1, + "address": "0xc3ffbe26e9446ac52008ffc8c1191d60a12bdc48", + "name": "Medifakt", + "symbol": "FAKT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25248/thumb/fxOi9ZYI_400x400.png?1651031310" + }, + { + "chainId": 1, + "address": "0x4abb9cc67bd3da9eb966d1159a71a0e68bd15432", + "name": "KelVPN", + "symbol": "KEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14851/thumb/logokelvpn200x200.png?1618797379" + }, + { + "chainId": 1, + "address": "0xd26a9c3437f7d121098c8c05c7413f5cc70bb070", + "name": "Azuma Coin", + "symbol": "AZUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10483/thumb/WDncHJ5.png?1580161760" + }, + { + "chainId": 1, + "address": "0x5aaefe84e0fb3dd1f0fcff6fa7468124986b91bd", + "name": "Evedo", + "symbol": "EVED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7721/thumb/Variations-09.png?1549979992" + }, + { + "chainId": 1, + "address": "0x9d47894f8becb68b9cf3428d256311affe8b068b", + "name": "Rope", + "symbol": "ROPE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12567/thumb/Rope_Icon.jpg?1604038203" + }, + { + "chainId": 1, + "address": "0xa0b73e1ff0b80914ab6fe0444e65848c4c34450b", + "name": "Cronos", + "symbol": "CRO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7310/thumb/cro_token_logo.png?1669699773" + }, + { + "chainId": 1, + "address": "0xe0cca86b254005889ac3a81e737f56a14f4a38f5", + "name": "Alta Finance", + "symbol": "ALTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18713/thumb/AFN-token-Altafin-200.png?1633079552" + }, + { + "chainId": 1, + "address": "0xd81b71cbb89b2800cdb000aa277dc1491dc923c3", + "name": "NFTMart", + "symbol": "NMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15811/thumb/NFTMART.png?1624962351" + }, + { + "chainId": 1, + "address": "0x62359ed7505efc61ff1d56fef82158ccaffa23d7", + "name": "cVault finance", + "symbol": "CORE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12635/thumb/cvault.finance_logo.png?1601353499" + }, + { + "chainId": 1, + "address": "0xacf3d402e5e2c3edd5b8129e966017d293f12a4c", + "name": "BoxAxis", + "symbol": "BAXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7732/thumb/MaUNF_dJFGQujn1_y5zYWG_U1NCglt4yBsjyftdpPr5H7LqTsu0XEqcKnnRWcjTUA0DsOLCr1Ekhe37__Wpx83X29R-nbs0UTxz5eElpzw7Mcl0y8-ReYLck8dNYAxJpXG1k48pA4RousepQFj7H9JKq09h5Z4EzBwnJf2P6qFWALryESUUmAOmtByKUD5WoCWI4DIlRorsWSbbl6.jpg?1550108268" + }, + { + "chainId": 1, + "address": "0x4ca0654f4fc1025cf1a17b7459c20ac0479522ad", + "name": "Rigel Finance", + "symbol": "RIGEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13674/thumb/logo-200x200_%282%29.png?1610682780" + }, + { + "chainId": 1, + "address": "0xd796b8eff23d5c4c71f43c99ffd7d8a3119f7475", + "name": "Metaverse Exchange", + "symbol": "METACEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21179/thumb/metacex.png?1638707090" + }, + { + "chainId": 1, + "address": "0x87f5e8c3425218837f3cb67db941af0c01323e56", + "name": "BitCoin One", + "symbol": "BTCONE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5413/thumb/b-one.png?1574907888" + }, + { + "chainId": 1, + "address": "0x166f1a7ecae00bd43876a25b10a63c575e05c0e7", + "name": "VERA Exchange", + "symbol": "VERA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9766/thumb/hn9LRFGrVzyuPJrDIrVeCdUN2IfxIwWDk6mM5U9cGm_b0oPyENjOrXzTJ7vwHE65PIzM_H4nGlcHJHPBV5qHoQ8cfwRSud89RJHUngAGMnYIoLZ-UzEk9HuspfOmNu2Finm8RZW-UIM1_Jykw3Cj743iNPqjsqNxkuazLsa0h76oIwf61Sn3h9-IFiwgVLXyfRVuCO0bTY6q_aLJLwzE-P1OALNJfpLSVY52ygRlDGMZS1qj.jpg?1575358608" + }, + { + "chainId": 1, + "address": "0xbc19712feb3a26080ebf6f2f7849b417fdd792ca", + "name": "BoringDAO", + "symbol": "BORING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16429/thumb/Tjq3pXEH_400x400.jpg?1623997009" + }, + { + "chainId": 1, + "address": "0xaec65404ddc3af3c897ad89571d5772c1a695f22", + "name": "Phoenix Finance", + "symbol": "PHX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17675/thumb/phx_logo.png?1628832432" + }, + { + "chainId": 1, + "address": "0xa6e7dc135bdf4b3fee7183eab2e87c0bb9684783", + "name": "BIGOCOIN", + "symbol": "BIGO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10564/thumb/Bigocoin_1200px.jpg?1597463586" + }, + { + "chainId": 1, + "address": "0xb44377b74ef1773639b663d0754cb8410a847d02", + "name": "Dream", + "symbol": "DREAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24139/thumb/image0.jpeg?1659000537" + }, + { + "chainId": 1, + "address": "0xfd09911130e6930bf87f2b0554c44f400bd80d3e", + "name": "EthicHub", + "symbol": "ETHIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3031/thumb/ETHIX_icon_256x256-256.png?1622195164" + }, + { + "chainId": 1, + "address": "0x7aa46a51f717404d944051af3075bbcb49b2288b", + "name": "Genebank", + "symbol": "GNBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15963/thumb/Gene-Bank-500px.jpg?1622519558" + }, + { + "chainId": 1, + "address": "0x2af1df3ab0ab157e1e2ad8f88a7d04fbea0c7dc6", + "name": "Bankless BED Index", + "symbol": "BED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17175/thumb/BED_Logo_-_No_border.png?1626833695" + }, + { + "chainId": 1, + "address": "0xe4f726adc8e89c6a6017f01eada77865db22da14", + "name": "PieDAO Balanced Crypto Pie", + "symbol": "BCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13560/thumb/BCP.png?1609813753" + }, + { + "chainId": 1, + "address": "0xa13f0743951b4f6e3e3aa039f682e17279f52bc3", + "name": "Sentinel Chain", + "symbol": "SENC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2960/thumb/sentinel-chain.jpg?1547037201" + }, + { + "chainId": 1, + "address": "0xbc6669e7914a2b327ae428184086d8ac88d74efc", + "name": "Car Coin", + "symbol": "CCM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17119/thumb/CarCoin_icon_vector.png?1626356048" + }, + { + "chainId": 1, + "address": "0x6781a0f84c7e9e846dcb84a9a5bd49333067b104", + "name": "Zap", + "symbol": "ZAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2180/thumb/zap.png?1547036476" + }, + { + "chainId": 1, + "address": "0xcd2828fc4d8e8a0ede91bb38cf64b1a81de65bf6", + "name": "Oddz", + "symbol": "ODDZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14421/thumb/NewLogo.png?1645171454" + }, + { + "chainId": 1, + "address": "0xb37a769b37224449d92aac57de379e1267cd3b00", + "name": "Cova Unity", + "symbol": "COVA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4707/thumb/covalent.jpg?1547040005" + }, + { + "chainId": 1, + "address": "0x9e7cb236e43c4bd042fe463df6a175d4479ee186", + "name": "Halving", + "symbol": "HALV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12085/thumb/Halv-logo-200x200.png?1597009175" + }, + { + "chainId": 1, + "address": "0x5d64d850c8368008afb39224e92ad0dceff3cf38", + "name": "MINDOL", + "symbol": "MIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6366/thumb/mindol-logo.png?1547042468" + }, + { + "chainId": 1, + "address": "0x29239242a83479a4074cb1c9e2a3e6705a4a4455", + "name": "Tozex", + "symbol": "TOZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13772/thumb/Logo_toz_200x200.png?1611698823" + }, + { + "chainId": 1, + "address": "0xff44b937788215eca197baaf9af69dbdc214aa04", + "name": "Rocki", + "symbol": "ROCKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13465/thumb/rocki_logo.png?1608786767" + }, + { + "chainId": 1, + "address": "0x1ef6a7e2c966fb7c5403efefde38338b1a95a084", + "name": "Shield SLD ", + "symbol": "SLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16170/thumb/SLD_TOKEN.png?1656907214" + }, + { + "chainId": 1, + "address": "0x6f87d756daf0503d08eb8993686c7fc01dc44fb1", + "name": "Unitrade", + "symbol": "TRADE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11982/thumb/unitrade.PNG?1597009487" + }, + { + "chainId": 1, + "address": "0x74603e780545d02c4257e7d2be19c74de7be1952", + "name": "ETG Finance", + "symbol": "ETGF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13032/thumb/etgf_logo.png?1604482450" + }, + { + "chainId": 1, + "address": "0x130914e1b240a7f4c5d460b7d3a2fd3846b576fa", + "name": "Aureus Nummus Gold", + "symbol": "ANG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12134/thumb/AureusNummusGold-logo.png?1597462266" + }, + { + "chainId": 1, + "address": "0x46943113ae84e732bb510b5f7686d8b76ff56774", + "name": "UMI", + "symbol": "UMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16953/thumb/umi.PNG?1625793521" + }, + { + "chainId": 1, + "address": "0xa1e770be76bde604f8ebb66f640250a787b9422b", + "name": "Anduschain", + "symbol": "DEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20842/thumb/DEB.png?1637743593" + }, + { + "chainId": 1, + "address": "0xf70a642bd387f94380ffb90451c2c81d4eb82cbc", + "name": "Starbase", + "symbol": "STAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1449/thumb/starbase.png?1548610771" + }, + { + "chainId": 1, + "address": "0x12b19d3e2ccc14da04fae33e63652ce469b3f2fd", + "name": "GridPlus OLD ", + "symbol": "GRID", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/1106/thumb/grid.png?1547743150" + }, + { + "chainId": 1, + "address": "0x727e8260877f8507f8d61917e9778b6af8491e63", + "name": "Charizard Inu", + "symbol": "CHARIZARD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19415/thumb/QXjLCDl.png?1635212769" + }, + { + "chainId": 1, + "address": "0x81824663353a9d29b01b2de9dd9a2bb271d298cd", + "name": "Bitcoin Volatility Token", + "symbol": "BVOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11056/thumb/download_%2810%29.png?1587641855" + }, + { + "chainId": 1, + "address": "0xb3e6ee8d2c586fa03ab70aef96b8ae6d12d64ec7", + "name": "hiFIDENZA", + "symbol": "HIFIDENZA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28237/thumb/hifidenza.png?1668579144" + }, + { + "chainId": 1, + "address": "0xc37e8a31ba2d110c12f09f0239954a68b00bc599", + "name": "EUB Chain", + "symbol": "EUBC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6547/thumb/j2Lj7uGH_400x400.jpg?1547042762" + }, + { + "chainId": 1, + "address": "0x524ebc93beef838f70b4ae54b675d3e971d5884e", + "name": "Challenge Coin", + "symbol": "HERO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26567/thumb/bug-CC-200.png?1658812509" + }, + { + "chainId": 1, + "address": "0xbdbc2a5b32f3a5141acd18c39883066e4dab9774", + "name": "Emirex", + "symbol": "EMRX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9507/thumb/download.png?1568589320" + }, + { + "chainId": 1, + "address": "0x4332f8a38f14bd3d8d1553af27d7c7ac6c27278d", + "name": "Ape Finance", + "symbol": "APEFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25625/thumb/APEFI.png?1652857977" + }, + { + "chainId": 1, + "address": "0xc0ea83113038987d974fe667831a36e442e661e7", + "name": "Libfx", + "symbol": "LIBFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12225/thumb/libfx.png?1598306252" + }, + { + "chainId": 1, + "address": "0x4d67edef87a5ff910954899f4e5a0aaf107afd42", + "name": "BlueSparrow OLD ", + "symbol": "BLUESPARROW", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19995/thumb/bluesparrow.png?1636361716" + }, + { + "chainId": 1, + "address": "0x92a5b04d0ed5d94d7a193d1d334d3d16996f4e13", + "name": "Eristica", + "symbol": "ERT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6485/thumb/6.jpg?1595305071" + }, + { + "chainId": 1, + "address": "0xfcc5c47be19d06bf83eb04298b026f81069ff65b", + "name": "Yearn CRV", + "symbol": "YCRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27622/thumb/yearncrvnew_32.png?1664881722" + }, + { + "chainId": 1, + "address": "0xfec0cf7fe078a500abf15f1284958f22049c2c7e", + "name": "Maecenas", + "symbol": "ART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1025/thumb/maecenas.png?1547034953" + }, + { + "chainId": 1, + "address": "0xe5867608b51a2c9c78b9587355cc093140a49b0a", + "name": "Speed Mining Service", + "symbol": "SMS", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/1807/thumb/speed-mining-service.png?1548610827" + }, + { + "chainId": 1, + "address": "0xebe807bfdf8b2092e36e964c75463a8aaa642139", + "name": "New Paradigm Assets Solution", + "symbol": "NPAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24660/thumb/S3i9bI6n_400x400.jpg?1648529725" + }, + { + "chainId": 1, + "address": "0xf14b9adf84812ba463799357f4dc716b4384010b", + "name": "Pension Plan", + "symbol": "PP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/19670/thumb/pensionplan-logo-200CG2.png?1635738403" + }, + { + "chainId": 1, + "address": "0x4c2e59d098df7b6cbae0848d66de2f8a4889b9c3", + "name": "Fodl Finance", + "symbol": "FODL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19040/thumb/Fodl_Symbol_Gradient.png?1651644153" + }, + { + "chainId": 1, + "address": "0x167e2a574669b0eeb552aaf3da47c728cb348a41", + "name": "Spartan", + "symbol": "300", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/13371/thumb/spartan300-200x200.png?1607986424" + }, + { + "chainId": 1, + "address": "0xf519381791c03dd7666c142d4e49fd94d3536011", + "name": "Asia Coin", + "symbol": "ASIA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18589/thumb/Ou7mp_R1TQ5B9vsBiZ8oQnSv36M6hiA2hESxV_7YSw0.png?1632556422" + }, + { + "chainId": 1, + "address": "0xeffea57067e02999fdcd0bb45c0f1071a29472d9", + "name": "Zantepay", + "symbol": "ZANTEPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7122/thumb/984cSZaC_400x400.jpg?1547043619" + }, + { + "chainId": 1, + "address": "0xdd16ec0f66e54d453e6756713e533355989040e4", + "name": "Tokenomy", + "symbol": "TEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2286/thumb/logo_%281%29.png?1604543144" + }, + { + "chainId": 1, + "address": "0xe6b7743e2b9aa2d0a9b163c4e69186abb57817d9", + "name": "Kuky Star", + "symbol": "KUKY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7465/thumb/images_%283%29.jpeg?1547622295" + }, + { + "chainId": 1, + "address": "0xd0cd466b34a24fcb2f87676278af2005ca8a78c4", + "name": "Popcorn", + "symbol": "POP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21438/thumb/pop-1_200_x_200.png?1662607611" + }, + { + "chainId": 1, + "address": "0xe0b9bcd54bf8a730ea5d3f1ffce0885e911a502c", + "name": "ZUM", + "symbol": "ZUM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9721/thumb/zum256x256.png?1571264005" + }, + { + "chainId": 1, + "address": "0x80bb277f4355a43cdbb86a82f9876c946476d9eb", + "name": "DogDeFiCoin", + "symbol": "DOGDEFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12912/thumb/dogdefi_logo.jpg?1603425386" + }, + { + "chainId": 1, + "address": "0x146d8d942048ad517479c9bab1788712af180fde", + "name": "MIB Coin", + "symbol": "MIB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5691/thumb/mibcoin.png?1547041559" + }, + { + "chainId": 1, + "address": "0x7db5af2b9624e1b3b4bb69d6debd9ad1016a58ac", + "name": "Volt Inu", + "symbol": "VOLT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25201/thumb/logo200.png?1653635992" + }, + { + "chainId": 1, + "address": "0x1a403e1c96792dfedb8232cf56400eb72ab95acb", + "name": "Saltmarble", + "symbol": "SML", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27504/thumb/SML_200px.png?1664331670" + }, + { + "chainId": 1, + "address": "0xffe510a92434a0df346c5e72a3494b043cf249eb", + "name": "LUX BIO EXCHANGE COIN", + "symbol": "LBXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9482/thumb/sam7Fy3A_400x400.jpg?1568000741" + }, + { + "chainId": 1, + "address": "0xf8c17c840549974ec17c6573b3963f1e3046c0eb", + "name": "Prediqt", + "symbol": "PQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14407/thumb/57197945.png?1615936268" + }, + { + "chainId": 1, + "address": "0x4639cd8cd52ec1cf2e496a606ce28d8afb1c792f", + "name": "CBDAO", + "symbol": "BREE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12096/thumb/cbdao_logo.jpg?1597059848" + }, + { + "chainId": 1, + "address": "0x8c543aed163909142695f2d2acd0d55791a9edb9", + "name": "Velas", + "symbol": "VLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9651/thumb/logo_blue.png?1663764088" + }, + { + "chainId": 1, + "address": "0x747f564d258612ec5c4e24742c5fd4110bcbe46b", + "name": "Nodeseeds", + "symbol": "NDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14658/thumb/n1EiZLt.png?1618374330" + }, + { + "chainId": 1, + "address": "0xc71d8baaa436aa7e42da1f40bec48f11ab3c9e4a", + "name": "iEthereum", + "symbol": "IETH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1065/thumb/ieth.png?1600765203" + }, + { + "chainId": 1, + "address": "0x57c75eccc8557136d32619a191fbcdc88560d711", + "name": "VeriDocGlobal", + "symbol": "VDG", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/5604/thumb/VDG-ICON.png?1547041457" + }, + { + "chainId": 1, + "address": "0xd3e133a0a14bb8b595e5fbf9851c7c783685ba69", + "name": "Locker Token", + "symbol": "LKT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28269/thumb/Locker.jpeg?1668995910" + }, + { + "chainId": 1, + "address": "0x8765b1a0eb57ca49be7eacd35b24a574d0203656", + "name": "MetaGameHub DAO", + "symbol": "MGH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20625/thumb/mgh.PNG?1637318966" + }, + { + "chainId": 1, + "address": "0xd6327ce1fb9d6020e8c2c0e124a1ec23dcab7536", + "name": "Cuminu", + "symbol": "CUMINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15832/thumb/CUMINU.png?1628849016" + }, + { + "chainId": 1, + "address": "0x5e8422345238f34275888049021821e8e08caa1f", + "name": "Frax Ether", + "symbol": "FRXETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28284/thumb/JjqQ9ROz_400x400.jpeg?1669170320" + }, + { + "chainId": 1, + "address": "0x3e9bc21c9b189c09df3ef1b824798658d5011937", + "name": "Linear", + "symbol": "LINA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12509/thumb/1649227343-linalogo200px.png?1649229117" + }, + { + "chainId": 1, + "address": "0x8ca9a0fbd8db501f013f2e9e33a1b9dc129a48e0", + "name": "People s Punk", + "symbol": "DDDD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17973/thumb/unnamed_%284%29.png?1629956290" + }, + { + "chainId": 1, + "address": "0xe67f943af5eb6051ef56f05979cc30b732717fa6", + "name": "WATTTON", + "symbol": "WATT", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/27215/thumb/CG_WATT_LOGO.png?1662611245" + }, + { + "chainId": 1, + "address": "0xe49cb97091b5bde1e8b7043e3d5717e64fde825e", + "name": "KuramaInu", + "symbol": "KUNU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19520/thumb/robert199805_Order_FO41AEBD476C8_KZ00A_R00A%28SY%29_copy.png?1641439224" + }, + { + "chainId": 1, + "address": "0xee2b297408063e0967096bafdcfd1278d5bf1b8a", + "name": "Dosa", + "symbol": "DOSA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27587/thumb/ed15a1c1-e0c5-4b6d-8cc5-54e69e296f96.png?1664703528" + }, + { + "chainId": 1, + "address": "0xe1a4c5bbb704a92599fedb191f451e0d3a1ed842", + "name": "PolkaDomain", + "symbol": "NAME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14832/thumb/name.png?1618580733" + }, + { + "chainId": 1, + "address": "0x60c24407d01782c2175d32fe7c8921ed732371d1", + "name": "LemoChain", + "symbol": "LEMO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3108/thumb/lemochain.png?1547975597" + }, + { + "chainId": 1, + "address": "0x8e87f1811de0025d2335174dbc7338a43df6d7cc", + "name": "Virtual Goods", + "symbol": "VGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8889/thumb/1QdEK96k_400x400.png?1562574531" + }, + { + "chainId": 1, + "address": "0x11afe7fa792589dd1236257f99ba09f510460ad9", + "name": "LNKO", + "symbol": "LNKO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9199/thumb/logo_%289%29.png?1565077907" + }, + { + "chainId": 1, + "address": "0x8400d94a5cb0fa0d041a3788e395285d61c9ee5e", + "name": "Unibright", + "symbol": "UBT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2707/thumb/UnibrightLogo_colorful_500x500_preview.png?1547036916" + }, + { + "chainId": 1, + "address": "0xfbbe9b1142c699512545f47937ee6fae0e4b0aa9", + "name": "EDDASwap", + "symbol": "EDDA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14368/thumb/edda.png?1615732928" + }, + { + "chainId": 1, + "address": "0xe4ae84448db5cfe1daf1e6fb172b469c161cb85f", + "name": "Utopia Genesis Foundation", + "symbol": "UOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13428/thumb/logo_%2830%29.png?1608518506" + }, + { + "chainId": 1, + "address": "0x048eb9b9c08e2df45644cf0db1fcb3e866c401ad", + "name": "Live Swap Coin", + "symbol": "LSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15287/thumb/lsc.PNG?1620356318" + }, + { + "chainId": 1, + "address": "0x482b078486079d66334389b55ab974bc8282984b", + "name": "No Limit Ape", + "symbol": "NLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24299/thumb/nla200x200.png?1647268853" + }, + { + "chainId": 1, + "address": "0x77271813bd9167e75b5df9c230cf58d64f0a58fd", + "name": "Balkari", + "symbol": "BKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18662/thumb/BKR_log_200.png?1632818558" + }, + { + "chainId": 1, + "address": "0x153ed9cc1b792979d2bde0bbf45cc2a7e436a5f9", + "name": "XOVBank", + "symbol": "XOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5396/thumb/xov.jpg?1549857681" + }, + { + "chainId": 1, + "address": "0x5635ddeabf9cdda686995fe90beb5411831563fc", + "name": "TravelNote", + "symbol": "TVNT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7051/thumb/omwKldFY_400x400.jpg?1547043503" + }, + { + "chainId": 1, + "address": "0xb39185e33e8c28e0bb3dbbce24da5dea6379ae91", + "name": "PHUNK Vault NFTX ", + "symbol": "PHUNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17074/thumb/Phunks.png?1626152056" + }, + { + "chainId": 1, + "address": "0x0a58531518dba2009bdfbf1af79602bfd312fdf1", + "name": "Squawk", + "symbol": "SQUAWK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25850/thumb/SYp95hCy_400x400.jpg?1654150818" + }, + { + "chainId": 1, + "address": "0xe5ef42d0e5e4aa6b36c613d00db8dad303d505f3", + "name": "BTour Chain", + "symbol": "MSOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13141/thumb/BTour_Icon.png?1605595523" + }, + { + "chainId": 1, + "address": "0xce3f6f6672616c39d8b6858f8dac9902eca42c84", + "name": "DAO1", + "symbol": "DAO1", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16193/thumb/dao1.PNG?1623276970" + }, + { + "chainId": 1, + "address": "0x7ecbb21346c501fd07eb165e406120fa32381c16", + "name": "Ecoreal Estate", + "symbol": "ECOREAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6431/thumb/golden_leave_in_200_x_200.png?1655886676" + }, + { + "chainId": 1, + "address": "0x92830ef7c8d651ed3a708053c602e807bad7db22", + "name": "SGD Tracker", + "symbol": "BLUSGD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28417/thumb/SGD.png?1670457460" + }, + { + "chainId": 1, + "address": "0x2b1d36f5b61addaf7da7ebbd11b35fd8cfb0de31", + "name": "Interport Token", + "symbol": "ITP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28338/thumb/ITP_Logo_200.png?1669794314" + }, + { + "chainId": 1, + "address": "0xc0e6737a29de7a00e2f6011924eb257106cb082f", + "name": "Glosfer", + "symbol": "GLO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9237/thumb/ItBMqQKt_400x400.jpg?1565336364" + }, + { + "chainId": 1, + "address": "0x7a2bc711e19ba6aff6ce8246c546e8c4b4944dfd", + "name": "WAXE", + "symbol": "WAXE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13508/thumb/waxe_logo.png?1609232755" + }, + { + "chainId": 1, + "address": "0x4edd66235349e353eb8cb8e40596599644bfe91c", + "name": "Vanywhere", + "symbol": "VANY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2701/thumb/vany.png?1547036908" + }, + { + "chainId": 1, + "address": "0xdd1ad9a21ce722c151a836373babe42c868ce9a4", + "name": "Universal Basic Income", + "symbol": "UBI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15269/thumb/ubi.png?1620287853" + }, + { + "chainId": 1, + "address": "0x5d843fa9495d23de997c394296ac7b4d721e841c", + "name": "Relay Chain", + "symbol": "RELAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17816/thumb/relay-logo-200.png?1629339288" + }, + { + "chainId": 1, + "address": "0x0ae055097c6d159879521c384f1d2123d1f195e6", + "name": "STAKE", + "symbol": "STAKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11061/thumb/xdai.png?1587714165" + }, + { + "chainId": 1, + "address": "0x8e9a29e7ed21db7c5b2e1cd75e676da0236dfb45", + "name": "Minter Hub", + "symbol": "HUB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14639/thumb/hub200.png?1651724396" + }, + { + "chainId": 1, + "address": "0x028171bca77440897b824ca71d1c56cac55b68a3", + "name": "Aave DAI", + "symbol": "ADAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14242/thumb/aDAI.84b6c41f.png?1615528749" + }, + { + "chainId": 1, + "address": "0xb4272071ecadd69d933adcd19ca99fe80664fc08", + "name": "CryptoFranc", + "symbol": "XCHF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8465/thumb/WhuiuJBc_400x400.jpg?1558699947" + }, + { + "chainId": 1, + "address": "0x3209f98bebf0149b769ce26d71f7aea8e435efea", + "name": "Traxia", + "symbol": "TMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3312/thumb/tmt.png?1547037907" + }, + { + "chainId": 1, + "address": "0xe65cdb6479bac1e22340e4e755fae7e509ecd06c", + "name": "cAAVE", + "symbol": "CAAVE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17527/thumb/caave.PNG?1628122171" + }, + { + "chainId": 1, + "address": "0xea4931bfcf3260da6dbf0550e27f5c214e3c268b", + "name": "MozoX", + "symbol": "MOZOX", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/10798/thumb/Wd7sb8F7VxkzGIkjbIHd1KAaguILwTMnafTK5-aJSWnOylO0D9otRGafiDdS9WBzxKUvqbLeguGq5iTdNdYJp3QJvGI-l_AsXscfjJGiTmn4Bw4G5bi_902OtUeKyQwvGEukbFnNpeoDyCyQ3tAW5-37sIjjj9WcgL3u3gLgdDSne6h0aRG7sBXl1AuYMQb9W_JnnplkyBoA37ZrWMfZc.jpg?1583724469" + }, + { + "chainId": 1, + "address": "0x3e7804c51a70ba26e904c2e0ab440c5623a8a83f", + "name": "GPEX", + "symbol": "GPX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/22584/thumb/GPEX-E_200.png?1642142068" + }, + { + "chainId": 1, + "address": "0xf40edf22e4ab146a32ecd8d659cedc7a2a55cd43", + "name": "ONE PIECE", + "symbol": "ONEPIECE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19421/thumb/g842dxb.png?1635213981" + }, + { + "chainId": 1, + "address": "0x798d1be841a82a273720ce31c822c61a67a601c3", + "name": "DIGG", + "symbol": "DIGG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13737/thumb/digg.PNG?1611292196" + }, + { + "chainId": 1, + "address": "0xccb4dfdb4f95697ab5c389185f0ba9042a78576f", + "name": "NFTWiki", + "symbol": "NFTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21970/thumb/PfGXwOcW_400x400.jpg?1640560379" + }, + { + "chainId": 1, + "address": "0x7c8155909cd385f120a56ef90728dd50f9ccbe52", + "name": "Nahmii", + "symbol": "NII", + "decimals": 15, + "logoURI": "https://assets.coingecko.com/coins/images/9786/thumb/nahmii-sm_icon-full-color.png?1608513773" + }, + { + "chainId": 1, + "address": "0xdac4ae188ace3c8985765edc6c9b4739d4845ddc", + "name": "InterValue", + "symbol": "INVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4756/thumb/intervalue-logo.png?1547040078" + }, + { + "chainId": 1, + "address": "0x65032604dab202aff9adf89300cdb4bd0d059f55", + "name": "SOBA", + "symbol": "SOBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14673/thumb/soba-logo-black.png?1617680379" + }, + { + "chainId": 1, + "address": "0xb4a677b0e363c3815d46326954a4e4d2b1ace357", + "name": "THENODE", + "symbol": "THE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10292/thumb/thenode_logo.png?1577334103" + }, + { + "chainId": 1, + "address": "0xe0b7927c4af23765cb51314a0e0521a9645f0e2a", + "name": "DigixDAO", + "symbol": "DGD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/397/thumb/dgd.png?1547034124" + }, + { + "chainId": 1, + "address": "0x0947b0e6d821378805c9598291385ce7c791a6b2", + "name": "Lendingblock", + "symbol": "LND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2988/thumb/LB_Icon__L.png?1631625796" + }, + { + "chainId": 1, + "address": "0xbdc5bac39dbe132b1e030e898ae3830017d7d969", + "name": "Snovian Space", + "symbol": "SNOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1330/thumb/logo2.png?1547035355" + }, + { + "chainId": 1, + "address": "0x94eb98db969124178189bb765beaa2fd36f1c5a4", + "name": "Noblesscoin", + "symbol": "NBLS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26147/thumb/13-53-57-IMG-20220623-125356-998.jpg?1656040863" + }, + { + "chainId": 1, + "address": "0x51b0bcbeff204b39ce792d1e16767fe6f7631970", + "name": "Bitcoin Volatility Index Token", + "symbol": "BTCV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16717/thumb/logo_-_2021-06-28T092740.647.png?1624843667" + }, + { + "chainId": 1, + "address": "0xfc09c7cfd9c175dd9423ca02ae1249579ab12f12", + "name": "Totoro Inu", + "symbol": "TOTORO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20277/thumb/cLogo.png?1636708928" + }, + { + "chainId": 1, + "address": "0x3625b55f653f8c7c884ac668696881df43631d44", + "name": "Arti Project", + "symbol": "ARTI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/18878/thumb/arti.PNG?1633688264" + }, + { + "chainId": 1, + "address": "0x03c7a08451ed5c820958d64116d74de1f7b285d8", + "name": "BlackSwan Nodes", + "symbol": "SWAN", + "decimals": 9 + }, + { + "chainId": 1, + "address": "0xbd9908b0cdd50386f92efcc8e1d71766c2782df0", + "name": "DAOSquare", + "symbol": "RICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19084/thumb/tw5gu1dW_400x400.jpeg?1634389807" + }, + { + "chainId": 1, + "address": "0x9b31bb425d8263fa1b8b9d090b83cf0c31665355", + "name": "CoinsPaid", + "symbol": "CPD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18092/thumb/coinspaid.PNG?1630452234" + }, + { + "chainId": 1, + "address": "0x3b5e2df103a037509dcc8430e5462b9cd8f75f49", + "name": "GEMX", + "symbol": "GEMX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28437/thumb/525BA403-4DD8-4AB4-A3C1-0EFF8C8F3450.jpeg?1670568823" + }, + { + "chainId": 1, + "address": "0xeb4c2781e4eba804ce9a9803c67d0893436bb27d", + "name": "renBTC", + "symbol": "RENBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11370/thumb/Bitcoin.jpg?1628072791" + }, + { + "chainId": 1, + "address": "0x998b3b82bc9dba173990be7afb772788b5acb8bd", + "name": "Banca", + "symbol": "BANCA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2795/thumb/banca.png?1547036972" + }, + { + "chainId": 1, + "address": "0xe7c9c188138f7d70945d420d75f8ca7d8ab9c700", + "name": "Basis Dollar Share", + "symbol": "BSDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13411/thumb/bshare.png?1608267551" + }, + { + "chainId": 1, + "address": "0x9a794dc1939f1d78fa48613b89b8f9d0a20da00e", + "name": "Arbidex", + "symbol": "ABX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5541/thumb/arbidex.png?1547041334" + }, + { + "chainId": 1, + "address": "0xd0929d411954c47438dc1d871dd6081f5c5e149c", + "name": "Refereum", + "symbol": "RFR", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/2102/thumb/refereum.png?1548608001" + }, + { + "chainId": 1, + "address": "0xcee1d3c3a02267e37e6b373060f79d5d7b9e1669", + "name": "yffi finance", + "symbol": "YFFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11940/thumb/yffi-finance.jpg?1596289302" + }, + { + "chainId": 1, + "address": "0x1014613e2b3cbc4d575054d4982e580d9b99d7b1", + "name": "BitCapitalVendor", + "symbol": "BCV", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5326/thumb/hqQw2WGE_400x400.jpg?1547040893" + }, + { + "chainId": 1, + "address": "0xd0983dd6a0334c71d0478255d1f794508026b888", + "name": "EGG Protocol", + "symbol": "EGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18735/thumb/EGG_%281%29.png?1633308617" + }, + { + "chainId": 1, + "address": "0x6051c1354ccc51b4d561e43b02735deae64768b8", + "name": "yRise Finance", + "symbol": "YRISE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12853/thumb/logoyrise-200px.png?1603084410" + }, + { + "chainId": 1, + "address": "0x79126d32a86e6663f3aaac4527732d0701c1ae6c", + "name": "Dark Matter", + "symbol": "DMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14223/thumb/dmt.jpg?1615089067" + }, + { + "chainId": 1, + "address": "0x21d486f6b7eb7b556978c5a0c96c79a08eb841de", + "name": "Grok", + "symbol": "GROK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24574/thumb/ZtRMy9Z7_400x400.png?1648197386" + }, + { + "chainId": 1, + "address": "0x8b1f49491477e0fb46a29fef53f1ea320d13c349", + "name": "MicroMoney", + "symbol": "AMM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1356/thumb/micromoney.png?1548085045" + }, + { + "chainId": 1, + "address": "0x77252494c25444f8598a0c74ffc90adc535291a9", + "name": "Nemesis", + "symbol": "NMS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18904/thumb/NMS-150x150.jpg?1633849465" + }, + { + "chainId": 1, + "address": "0x3392d8a60b77f8d3eaa4fb58f09d835bd31add29", + "name": "IndiGG", + "symbol": "INDI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23857/thumb/https___bucketeer-e05bbc84-baa3-437e-9518-adb32be77984.s3.amazonaws.com_public_images_0cb39c1f-db6d-4dd9-9143-1f30ee38d74d_743x726.jpeg?1645594083" + }, + { + "chainId": 1, + "address": "0xc6dddb5bc6e61e0841c54f3e723ae1f3a807260b", + "name": "Aurox", + "symbol": "URUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14122/thumb/Aurox.png?1648524329" + }, + { + "chainId": 1, + "address": "0xa1d65e8fb6e87b60feccbc582f7f97804b725521", + "name": "DXdao", + "symbol": "DXD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11148/thumb/dxdao.png?1607999331" + }, + { + "chainId": 1, + "address": "0x0f8c45b896784a1e408526b9300519ef8660209c", + "name": "XMax", + "symbol": "XMX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4643/thumb/xmx.png?1574682262" + }, + { + "chainId": 1, + "address": "0x578b49c45961f98d8df92854b53f1641af0a5036", + "name": "LINKA", + "symbol": "LINKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9487/thumb/C2RRuVH6eVbXIDbew-0VJoGpPb_bMPjRjM9qlYud7tqtGgb1GskioTkIntKuugvXnX-Y3O54L-4zWeWWm_Fffo1kJiqJG5vE4Iu1FSvZ-N750y_tlB7yAGeYztAD-MDrwEPaF3Y9j6E94mPVyKuidqbxf9vBeR5r4GAya3friWZjMzpnJ_q9v0jiIBxEC5YAy1C0Zx6yqVoHJjiTW.jpg?1568013160" + }, + { + "chainId": 1, + "address": "0xfecba472b2540c5a2d3700b2c9e06f0aa7dc6462", + "name": "Pub Finance", + "symbol": "PINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14016/thumb/PINT.png?1614064578" + }, + { + "chainId": 1, + "address": "0x173e552bf97bbd50b455514ac52991ef639ba703", + "name": "Shido", + "symbol": "SHIDO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26674/thumb/Shido.png?1667361249" + }, + { + "chainId": 1, + "address": "0x4f5fa8f2d12e5eb780f6082dd656c565c48e0f24", + "name": "Gourmet Galaxy", + "symbol": "GUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13846/thumb/gum.png?1612320864" + }, + { + "chainId": 1, + "address": "0x82fdedfb7635441aa5a92791d001fa7388da8025", + "name": "Digital Ticks", + "symbol": "DTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4898/thumb/digital-ticks-logo.jpg?1533010074" + }, + { + "chainId": 1, + "address": "0x4de2573e27e648607b50e1cfff921a33e4a34405", + "name": "Lendroid Support", + "symbol": "LST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3485/thumb/lst-icon.png?1606992361" + }, + { + "chainId": 1, + "address": "0x6243d8cea23066d098a15582d81a598b4e8391f4", + "name": "Reflexer Ungovernance", + "symbol": "FLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14123/thumb/EAfYdwgd_400x400.jpg?1614564508" + }, + { + "chainId": 1, + "address": "0x51bb3ab03ab49ec5cb3883705949657838a015fd", + "name": "CRYN", + "symbol": "CRYN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/24601/thumb/cryn.png?1648365782" + }, + { + "chainId": 1, + "address": "0x2fe39f22eac6d3c1c86dd9d143640ebb94609fce", + "name": "JD Coin", + "symbol": "JDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9958/thumb/Cv-2ca6p_400x400.jpg?1575926305" + }, + { + "chainId": 1, + "address": "0xa2ef2757d2ed560c9e3758d1946d7bcccbd5a7fe", + "name": "Adventure", + "symbol": "TWA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13284/thumb/twa_logo.jpg?1606979012" + }, + { + "chainId": 1, + "address": "0x432a2c54de2dde941a36d2eb8c424ed666f74aef", + "name": "Merculet", + "symbol": "MVP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3483/thumb/feature_token.png?1547038223" + }, + { + "chainId": 1, + "address": "0x60e683c6514edd5f758a55b6f393bebbafaa8d5e", + "name": "Page", + "symbol": "PAGE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/19015/thumb/Page_Icon_LG.png?1634182470" + }, + { + "chainId": 1, + "address": "0xe8389374a482d031703ae0e4cb3fe34b045081ee", + "name": "Bal kesirspor Token", + "symbol": "BLKS", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24811/thumb/18434.png?1649024433" + }, + { + "chainId": 1, + "address": "0xb8c6ad2586bb71d518c2aaf510efe91f82022f58", + "name": "Gomics", + "symbol": "GOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9506/thumb/69581895_377122223186787_4719544883591774208_n.png?1568184472" + }, + { + "chainId": 1, + "address": "0xf0acf8949e705e0ebb6cb42c2164b0b986454223", + "name": "Barter", + "symbol": "BRTR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13401/thumb/BRTR.png?1612843022" + }, + { + "chainId": 1, + "address": "0xade6fdaba1643e4d1eef68da7170f234470938c6", + "name": "Harambe", + "symbol": "HARAMBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23489/thumb/unnamed.jpg?1644220775" + }, + { + "chainId": 1, + "address": "0xfac8f483877f42702aad3c4fcb508cfba09153b5", + "name": "Evident Proof Transaction", + "symbol": "EPTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22377/thumb/EPT.png?1641782531" + }, + { + "chainId": 1, + "address": "0xf8e1d008a98350abb4241139fbc851aaad51eda6", + "name": "Sleepy Shib", + "symbol": "SLEEPY-SHIB", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20321/thumb/OYfY70z.png?1636877246" + }, + { + "chainId": 1, + "address": "0xd1be6c91352e5afca7c0db69eaa390dbcbfca762", + "name": "Liquinity", + "symbol": "LQNTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26844/thumb/photo_5161276562430077559_x.jpg?1660391137" + }, + { + "chainId": 1, + "address": "0x00fc270c9cc13e878ab5363d00354bebf6f05c15", + "name": "VNX Exchange", + "symbol": "VNXLU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9945/thumb/vnx.PNG?1573639467" + }, + { + "chainId": 1, + "address": "0x4f7aff8f0c78b51c0e30f02f27a67b5a6a11552b", + "name": "Decentralized Business Systems", + "symbol": "DBS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/25489/thumb/27e0a1_7f0b762e0eeb4584af7cff0fdccedc8e_mv2.png?1652856877" + }, + { + "chainId": 1, + "address": "0x42edc1c5ff57ff5240c90e2d8dfa269d77d68013", + "name": "Bitnorm", + "symbol": "BN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14920/thumb/logo_2.71b730c9.png?1619043921" + }, + { + "chainId": 1, + "address": "0xcf81e6fdb8d7a743c3d4c3542a5356ff197ea1c0", + "name": "Global Gaming", + "symbol": "GMNG", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12792/thumb/output-onlinepngtools.png_small.png?1602581337" + }, + { + "chainId": 1, + "address": "0x36a28c7c9b3dea22f07f4df67833cbe764feeeb4", + "name": "Cryptonits", + "symbol": "CRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13392/thumb/logo-200x200.png?1608100148" + }, + { + "chainId": 1, + "address": "0x3ffffa8f3cc943e43f9f17a83cbb18f4bbb9f4ac", + "name": "Rewardiqa", + "symbol": "REW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11614/thumb/REW_medium.png?1594698840" + }, + { + "chainId": 1, + "address": "0xb63b606ac810a52cca15e44bb630fd42d8d1d83d", + "name": "MCO", + "symbol": "MCO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/739/thumb/1776.png?1648537078" + }, + { + "chainId": 1, + "address": "0x1a4f4d457786314668bd5de0e49f89fe6e2a4802", + "name": "The Ape", + "symbol": "TA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27950/thumb/THE_Ape.png?1666666627" + }, + { + "chainId": 1, + "address": "0xb24cd494fae4c180a89975f1328eab2a7d5d8f11", + "name": "Developer DAO", + "symbol": "CODE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27011/thumb/CHWxD9GV_400x400.jpeg?1661421133" + }, + { + "chainId": 1, + "address": "0x170b275ced089fffaebfe927f445a350ed9160dc", + "name": "OWNDATA", + "symbol": "OWN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3903/thumb/owndata.png?1548330403" + }, + { + "chainId": 1, + "address": "0xc18360217d8f7ab5e7c516566761ea12ce7f9d72", + "name": "Ethereum Name Service", + "symbol": "ENS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19785/thumb/acatxTm8_400x400.jpg?1635850140" + }, + { + "chainId": 1, + "address": "0xc2d3ae29c8309c14994d02ecd228cf86f3efde77", + "name": "CurrySwap", + "symbol": "CURRY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13656/thumb/curry_logo.jpg?1610581982" + }, + { + "chainId": 1, + "address": "0x8e14c88ab0644ef41bd7138ab91c0160d8c1583a", + "name": "FrenChain", + "symbol": "FREN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28113/thumb/200.png?1667550745" + }, + { + "chainId": 1, + "address": "0xffed56a180f23fd32bc6a1d8d3c09c283ab594a8", + "name": "Freeliquid", + "symbol": "FL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13698/thumb/freeliquid_logo.png?1610980336" + }, + { + "chainId": 1, + "address": "0xd64809f5f7d772d9112a6bd379de00a77188199e", + "name": "Lyfe Silver", + "symbol": "LSILVER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14939/thumb/LSILVER-Logo-200.png?1619082811" + }, + { + "chainId": 1, + "address": "0xd64126835cecaca345c8f137bda68e975f5ab790", + "name": "Yeni Malatyaspor Token", + "symbol": "YMS", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24815/thumb/Yeni_Malatyaspor_logo.svg.png?1649029086" + }, + { + "chainId": 1, + "address": "0xf0bc1ae4ef7ffb126a8347d06ac6f8add770e1ce", + "name": "1Million", + "symbol": "1MT", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/8495/thumb/1MTp.png?1586964391" + }, + { + "chainId": 1, + "address": "0xf6269e2e0c271fb6af35e7f8a539ebc7155e33bb", + "name": "Hayfever", + "symbol": "HAY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21063/thumb/Contagion_Crew_5-2.jpg?1651745521" + }, + { + "chainId": 1, + "address": "0x44dcf4dc9ec228b7748422c51b6c5c57f5f229ec", + "name": "Quannabu", + "symbol": "QBU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17892/thumb/HsYrOmEy_400x400.jpg?1629717802" + }, + { + "chainId": 1, + "address": "0x47b9f01b16e9c9cb99191dca68c9cc5bf6403957", + "name": "Onston", + "symbol": "ONSTON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20669/thumb/onston.PNG?1637547859" + }, + { + "chainId": 1, + "address": "0xcd46d92c46be1dbbd5ccc497e95611abe9d507bc", + "name": "FACE Vault NFTX ", + "symbol": "FACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17039/thumb/FACE.png?1626146356" + }, + { + "chainId": 1, + "address": "0x00281dfce4cfd72c0b6fda2aaaf077258743f9e8", + "name": "NuriFootBall", + "symbol": "NRFB", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/23360/thumb/pcMlP25e_400x400.jpg?1643945452" + }, + { + "chainId": 1, + "address": "0x95a4492f028aa1fd432ea71146b433e7b4446611", + "name": "APY Finance", + "symbol": "APY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13041/thumb/1*AvkD-OLocausbxqUzezZ0A.png?1604577922" + }, + { + "chainId": 1, + "address": "0x9c38688e5acb9ed6049c8502650db5ac8ef96465", + "name": "Lif", + "symbol": "LIF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1760/thumb/lif-logo.png?1622196538" + }, + { + "chainId": 1, + "address": "0x69d9905b2e5f6f5433212b7f3c954433f23c1572", + "name": "Onooks", + "symbol": "OOKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16281/thumb/onooks-logo.png?1623637635" + }, + { + "chainId": 1, + "address": "0x92925acf2771bc59143228499f9610fe5176eb9c", + "name": "SYLTARE", + "symbol": "SYL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26962/thumb/syl_tokenlogo.png?1661078949" + }, + { + "chainId": 1, + "address": "0x37cd4e8875e3edaffdfe9be63958f07effbd0bfd", + "name": "void cash", + "symbol": "VCASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26976/thumb/Avatar_v2.png?1661168692" + }, + { + "chainId": 1, + "address": "0x21d5678a62dfe63a47062469ebb2fac2817d8832", + "name": "YOLOCash", + "symbol": "YLC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4368/thumb/received_2320303067998561.png?1547039717" + }, + { + "chainId": 1, + "address": "0x1b2a76da77d03b7fc21189d9838f55bd849014af", + "name": "DeFiScale", + "symbol": "DFC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14974/thumb/logo200x200-2.png?1619214186" + }, + { + "chainId": 1, + "address": "0xfe5f141bf94fe84bc28ded0ab966c16b17490657", + "name": "Libra Credit", + "symbol": "LBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3673/thumb/libra-credit.png?1547975828" + }, + { + "chainId": 1, + "address": "0xddb3422497e61e13543bea06989c0789117555c5", + "name": "COTI", + "symbol": "COTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2962/thumb/Coti.png?1559653863" + }, + { + "chainId": 1, + "address": "0x93b1e78a3e652cd2e71c4a767595b77282344932", + "name": "BITO Coin", + "symbol": "BITO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7796/thumb/bitopro_28.png?1550628495" + }, + { + "chainId": 1, + "address": "0xc741f06082aa47f93729070ad0dd95e223bda091", + "name": "Education Ecosystem", + "symbol": "LEDU", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3451/thumb/LEDU-education-ecosystem.png?1547038165" + }, + { + "chainId": 1, + "address": "0x56b4f8c39e07d4d5d91692acf9d0f6d4d3493763", + "name": "Trism", + "symbol": "TRISM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13549/thumb/76106366.png?1609715454" + }, + { + "chainId": 1, + "address": "0x4c601dc69affb0d4fc8de1ac303705e432a4a27e", + "name": "Konnect", + "symbol": "KCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25756/thumb/EAO_5JhW_400x400.jpg?1653516279" + }, + { + "chainId": 1, + "address": "0x72b886d09c117654ab7da13a14d603001de0b777", + "name": "XDEFI", + "symbol": "XDEFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19524/thumb/xdefi.png?1637917251" + }, + { + "chainId": 1, + "address": "0xbe7a4f88c6b15a722aa960b487badf9880184ec5", + "name": "SupplyCon", + "symbol": "SPLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28192/thumb/SupplyCon_Logo_.png?1668327647" + }, + { + "chainId": 1, + "address": "0x505a84a03e382331a1be487b632cf357748b65d6", + "name": "SHIBGF", + "symbol": "SHIBGF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19699/thumb/shibgf_logo.png?1637293051" + }, + { + "chainId": 1, + "address": "0xc1f33e0cf7e40a67375007104b929e49a581bafe", + "name": "Spot", + "symbol": "SPOT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28426/thumb/ezgif.com-gif-maker_%285%29.jpg?1670547152" + }, + { + "chainId": 1, + "address": "0x62959c699a52ec647622c91e79ce73344e4099f5", + "name": "DeFine", + "symbol": "DFA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17579/thumb/define.PNG?1628558827" + }, + { + "chainId": 1, + "address": "0xe138fda441fc31b36171122397a8a11d6cd2c479", + "name": "Global Trust Coin", + "symbol": "GTC", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/7752/thumb/gtib.png?1550222444" + }, + { + "chainId": 1, + "address": "0x5166e09628b696285e3a151e84fb977736a83575", + "name": "Volatility Protocol", + "symbol": "VOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17374/thumb/volatility.PNG?1627448569" + }, + { + "chainId": 1, + "address": "0x80a2ae356fc9ef4305676f7a3e2ed04e12c33946", + "name": "cYFI", + "symbol": "CYFI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17530/thumb/cyfi.PNG?1628123155" + }, + { + "chainId": 1, + "address": "0xfc4b8ed459e00e5400be803a9bb3954234fd50e3", + "name": "Aave WBTC v1", + "symbol": "AWBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11734/thumb/aWBTC.png?1593087741" + }, + { + "chainId": 1, + "address": "0x228ba514309ffdf03a81a205a6d040e429d6e80c", + "name": "Global Social Chain", + "symbol": "GSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4304/thumb/global-social-chain.png?1547742843" + }, + { + "chainId": 1, + "address": "0x3d26dcd840fcc8e4b2193ace8a092e4a65832f9f", + "name": "Aave AMM UniUNIWETH", + "symbol": "AAMMUNIUNIWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17225/thumb/aAmmUniUNIWETH.png?1626881095" + }, + { + "chainId": 1, + "address": "0x1892f6ff5fbe11c31158f8c6f6f6e33106c5b10e", + "name": "MegaWorld", + "symbol": "MEGA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28456/thumb/Twitter_AVA1.jpg?1670810440" + }, + { + "chainId": 1, + "address": "0x5f02cf3c7ada49dfc4a3645fc85c8ae86808dd9b", + "name": "COST COIN ", + "symbol": "AKM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11705/thumb/akm.PNG?1592984686" + }, + { + "chainId": 1, + "address": "0x41545f8b9472d758bb669ed8eaeeecd7a9c4ec29", + "name": "Forta", + "symbol": "FORT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25060/thumb/Forta_lgo_%281%29.png?1655353696" + }, + { + "chainId": 1, + "address": "0x1a87077c4f834884691b8ba4fc808d2ec93a9f30", + "name": "Winry Inu", + "symbol": "WINRY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19420/thumb/winry.png?1640575013" + }, + { + "chainId": 1, + "address": "0x62199b909fb8b8cf870f97bef2ce6783493c4908", + "name": "pTokens BTC", + "symbol": "PBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25861/thumb/wMTpRljt_400x400.png?1654228097" + }, + { + "chainId": 1, + "address": "0x1dd80016e3d4ae146ee2ebb484e8edd92dacc4ce", + "name": "Lead", + "symbol": "LEAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12384/thumb/lead.jpg?1599491466" + }, + { + "chainId": 1, + "address": "0x11c1a6b3ed6bb362954b29d3183cfa97a0c806aa", + "name": "Starwire", + "symbol": "STR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18232/thumb/starwirelogo_%281%29.png?1631064145" + }, + { + "chainId": 1, + "address": "0xde74bb5a16000deea9eb26ef3941344325dbdb8c", + "name": "Fluffy Inu", + "symbol": "FLUFFY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21769/thumb/fluffy-logo-md.png?1639994182" + }, + { + "chainId": 1, + "address": "0x84f20bf5bb4be345d3ab37c565f732753435dbe3", + "name": "JustCarbon Removal", + "symbol": "JCR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25251/thumb/Just-Carbon-JCR-2.png?1651132559" + }, + { + "chainId": 1, + "address": "0x2dca19e944453e46d9130950ca135461b3bc0c30", + "name": "EYES Protocol", + "symbol": "EYES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9734/thumb/pTaAZUI6_400x400.jpg?1571308667" + }, + { + "chainId": 1, + "address": "0x34f797e7190c131cf630524655a618b5bd8738e7", + "name": "BaconDAO", + "symbol": "BACON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18059/thumb/xDV_bhdA_400x400.jpg?1630333329" + }, + { + "chainId": 1, + "address": "0x57652fc91f522f9eff0b38cdf1d51f5fb5764215", + "name": "Buddy", + "symbol": "BUD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4697/thumb/buddy.jpg?1554103368" + }, + { + "chainId": 1, + "address": "0x0a8b16b27d5219c8c6b57d5442ce31d81573eee4", + "name": "Wrapped ATROMG8", + "symbol": "WAG8", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15182/thumb/ag8.jpg?1620031331" + }, + { + "chainId": 1, + "address": "0xa92cdf011c895780733b2a6a6e15c4c1ed836148", + "name": "DeFi ch", + "symbol": "DFCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18842/thumb/defi200px.png?1633586754" + }, + { + "chainId": 1, + "address": "0xd1e94958defb1c56516329a21f072951b22301aa", + "name": "Shiboki", + "symbol": "SHIBOKI", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24620/thumb/Shiboki.jpeg?1648446706" + }, + { + "chainId": 1, + "address": "0xd2d9e0b2942943269d5224e0048bbc32380ac19b", + "name": "DoraemonInu", + "symbol": "DORAEMONINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19141/thumb/DI.jpg?1634528340" + }, + { + "chainId": 1, + "address": "0xf4c17bc4979c1dc7b4ca50115358dec58c67fd9d", + "name": "Omega Protocol Money", + "symbol": "OPM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12337/thumb/opm-200px.png?1599136480" + }, + { + "chainId": 1, + "address": "0x9e78b8274e1d6a76a0dbbf90418894df27cbceb5", + "name": "Covenants", + "symbol": "UNIFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12258/thumb/Unifi.png?1598548933" + }, + { + "chainId": 1, + "address": "0x4cf89ca06ad997bc732dc876ed2a7f26a9e7f361", + "name": "Mysterium", + "symbol": "MYST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/757/thumb/mysterium.png?1547034503" + }, + { + "chainId": 1, + "address": "0x8d26cca0d58913932157dd4b294d4c95066172df", + "name": "Millennium Sapphire", + "symbol": "MSTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24020/thumb/eliUfGAG_400x400.jpg?1646040397" + }, + { + "chainId": 1, + "address": "0x8b3870df408ff4d7c3a26df852d41034eda11d81", + "name": "IOI", + "symbol": "IOI", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/15952/thumb/IOI_new_logo.png?1636797701" + }, + { + "chainId": 1, + "address": "0x43567eb78638a55bbe51e9f9fb5b2d7ad1f125aa", + "name": "Hackspace Capital", + "symbol": "HAC", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/2336/thumb/hac.png?1547036543" + }, + { + "chainId": 1, + "address": "0x809826cceab68c387726af962713b64cb5cb3cca", + "name": "Nucleus Vision", + "symbol": "NCASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3135/thumb/nv.jpg?1547037544" + }, + { + "chainId": 1, + "address": "0x88aa4a6c5050b9a1b2aa7e34d0582025ca6ab745", + "name": "Vela Exchange", + "symbol": "DXP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25114/thumb/1_0w4P8R5heRFwRomJ4vPCWQ.png?1650348942" + }, + { + "chainId": 1, + "address": "0x2c756e74b7309d785b5e2960ef262c4f14a87930", + "name": "SPENDER X", + "symbol": "SPDX", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/9259/thumb/spdx.PNG?1565650786" + }, + { + "chainId": 1, + "address": "0x16f812be7fff02caf662b85d5d58a5da6572d4df", + "name": "United Traders", + "symbol": "UTT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1741/thumb/utt.png?1547036018" + }, + { + "chainId": 1, + "address": "0x24b20da7a2fa0d1d5afcd693e1c8afff20507efd", + "name": "Medi", + "symbol": "MEDI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23037/thumb/Medi_200_x_200.PNG?1643096227" + }, + { + "chainId": 1, + "address": "0x1c720999a4f8b2b0e9199039d353d2c9a77a73fc", + "name": "TigerQueen", + "symbol": "TQUEEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22531/thumb/Logo-Tiger-Queen.png?1641997189" + }, + { + "chainId": 1, + "address": "0x8b7c94bc9ec137d67fbddb203b2814f0f1f9b377", + "name": "WHALE Vault NFTX ", + "symbol": "WHALE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18347/thumb/whale.png?1631603573" + }, + { + "chainId": 1, + "address": "0x9dfc4b433d359024eb3e810d77d60fbe8b0d9b82", + "name": "Dandy Dego", + "symbol": "DANDY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12764/thumb/487ogltc_400x400.jpg?1602463048" + }, + { + "chainId": 1, + "address": "0xe5097d9baeafb89f9bcb78c9290d545db5f9e9cb", + "name": "Hummingbot", + "symbol": "HBOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21717/thumb/PDPuf0tJ_400x400.jpg?1639863782" + }, + { + "chainId": 1, + "address": "0x0b5326da634f9270fb84481dd6f94d3dc2ca7096", + "name": "Etho Protocol", + "symbol": "ETHO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5194/thumb/ether1new-transparent.png?1578298993" + }, + { + "chainId": 1, + "address": "0x9b99cca871be05119b2012fd4474731dd653febe", + "name": "AntiMatter", + "symbol": "MATTER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14112/thumb/antimatter_icon.png?1614395992" + }, + { + "chainId": 1, + "address": "0x0cf0ee63788a0849fe5297f3407f701e122cc023", + "name": "Streamr XDATA", + "symbol": "XDATA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1115/thumb/streamr.png?1547035101" + }, + { + "chainId": 1, + "address": "0x508626d9a29d13eba26f843a2bd7bf7b00a45be5", + "name": "Bluelight", + "symbol": "KALE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28031/thumb/kale.png?1667109844" + }, + { + "chainId": 1, + "address": "0xf17a3fe536f8f7847f1385ec1bc967b2ca9cae8d", + "name": "Alongside Crypto Market Index", + "symbol": "AMKT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28496/thumb/AMKT-Circle.png?1671108971" + }, + { + "chainId": 1, + "address": "0x834ce7ad163ab3be0c5fd4e0a81e67ac8f51e00c", + "name": "Polkainsure Finance", + "symbol": "PIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13544/thumb/Logo_Polkainsure___Final-200x200-01.png?1609686092" + }, + { + "chainId": 1, + "address": "0xa91464abd4625a23ab719e3f0fce84dadd54e546", + "name": "Inoovi", + "symbol": "IVI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10372/thumb/Bvp7U25U_400x400.jpg?1578674638" + }, + { + "chainId": 1, + "address": "0xbd356a39bff2cada8e9248532dd879147221cf76", + "name": "WOM Protocol", + "symbol": "WOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4559/thumb/wom_logo_small.png?1572098941" + }, + { + "chainId": 1, + "address": "0x86efc496dca70bcfd92d19194290e8457a375773", + "name": "Silent Notary", + "symbol": "UBSN", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/1599/thumb/silent-notary.png?1548609544" + }, + { + "chainId": 1, + "address": "0x3505f494c3f0fed0b594e01fa41dd3967645ca39", + "name": "Swarm Network", + "symbol": "SWM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/197/thumb/swarm.jpg?1547033949" + }, + { + "chainId": 1, + "address": "0x849ba2278cdae7fa7006c0661fea1c35d5af3336", + "name": "The Citadel", + "symbol": "THECITADEL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20445/thumb/B307-A646-EBD2-456-C-B29-D-1-B00-A470-F8-CE.jpg?1637041816" + }, + { + "chainId": 1, + "address": "0xa69f7a10df90c4d6710588bc18ad9bf08081f545", + "name": "Cexlt", + "symbol": "CLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13171/thumb/clt_logo.png?1605855281" + }, + { + "chainId": 1, + "address": "0x07ef9e82721ac16809d24dafbe1792ce01654db4", + "name": "Chimpion", + "symbol": "BNANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7522/thumb/banana-token-logo.jpg?1548167777" + }, + { + "chainId": 1, + "address": "0xd1cd47746b8e72359b28c1c84a4f6a19dc1a0ee5", + "name": "Sonic Suite", + "symbol": "SONIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28489/thumb/155EE8AF-26AA-4CEC-9EC5-18532E779474.jpeg?1671091323" + }, + { + "chainId": 1, + "address": "0x5b322514ff727253292637d9054301600c2c81e8", + "name": "DAD", + "symbol": "DAD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/9833/thumb/q_Vt0ajV_400x400.jpg?1572475136" + }, + { + "chainId": 1, + "address": "0xb73404280697080da0116cfac0e577fafdf44b37", + "name": "Quick Mining", + "symbol": "QM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15916/thumb/qm.PNG?1622427094" + }, + { + "chainId": 1, + "address": "0x0e8d2eb7d6bdf28393c25a1966385ad32ff0259a", + "name": "Streamer Inu", + "symbol": "STREAMERINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27994/thumb/logo.png?1666922914" + }, + { + "chainId": 1, + "address": "0x470ebf5f030ed85fc1ed4c2d36b9dd02e77cf1b7", + "name": "TempleDAO", + "symbol": "TEMPLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20040/thumb/LPK15ZOW_400x400.jpg?1636425070" + }, + { + "chainId": 1, + "address": "0xc05d14442a510de4d3d71a3d316585aa0ce32b50", + "name": "LINA", + "symbol": "LINA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5412/thumb/3083.png?1642981471" + }, + { + "chainId": 1, + "address": "0x7fc66500c84a76ad7e9c93437bfc5ac33e2ddae9", + "name": "Aave", + "symbol": "AAVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12645/thumb/AAVE.png?1601374110" + }, + { + "chainId": 1, + "address": "0x724dd18be5de3ed3d6ad7bb46d7387d867cdbdcc", + "name": "Avakus", + "symbol": "AVAK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18337/thumb/avakus.PNG?1631588881" + }, + { + "chainId": 1, + "address": "0xf7dd746a613fb6362d44ecedeb743f62ade6c3aa", + "name": "FIFTYONEFIFTY", + "symbol": "FIFTY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18207/thumb/5150icon.png?1630980446" + }, + { + "chainId": 1, + "address": "0xabbbb6447b68ffd6141da77c18c7b5876ed6c5ab", + "name": "DATx", + "symbol": "DATX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2942/thumb/datx.png?1547037168" + }, + { + "chainId": 1, + "address": "0x961c8c0b1aad0c0b10a51fef6a867e3091bcef17", + "name": "Dypius", + "symbol": "DYP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13480/thumb/DYP-200x200px.png?1670915896" + }, + { + "chainId": 1, + "address": "0x923108a439c4e8c2315c4f6521e5ce95b44e9b4c", + "name": "Devery", + "symbol": "EVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2681/thumb/devery.png?1547036885" + }, + { + "chainId": 1, + "address": "0x1cc481ce2bd2ec7bf67d1be64d4878b16078f309", + "name": "Iron Bank CHF", + "symbol": "IBCHF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18577/thumb/logo-128_%284%29.png?1632470239" + }, + { + "chainId": 1, + "address": "0x297d33e17e61c2ddd812389c2105193f8348188a", + "name": "Strudel Finance", + "symbol": "TRDL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13854/thumb/1614634281474-TRDL_LOGO_PNG.png?1614671874" + }, + { + "chainId": 1, + "address": "0x755eb14d2feff2939eb3026f5cad9d03775b9ff4", + "name": "Bunny", + "symbol": "BUNNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3185/thumb/bunnytoken.png?1547564097" + }, + { + "chainId": 1, + "address": "0xedc87cab8bd12ca39088deaf9fdfb63503f19f85", + "name": "Universe Coin", + "symbol": "UNIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10389/thumb/9lTQkX7d_400x400.jpg?1578868716" + }, + { + "chainId": 1, + "address": "0x331fa6c97c64e47475164b9fc8143b533c5ef529", + "name": "EXMR FDN", + "symbol": "EXMR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3285/thumb/exmr_transparent.png?1604655926" + }, + { + "chainId": 1, + "address": "0xb4fbed161bebcb37afb1cb4a6f7ca18b977ccb25", + "name": "Dogeswap", + "symbol": "DOGES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12763/thumb/20200926-220107.png?1622520018" + }, + { + "chainId": 1, + "address": "0x37a15c92e67686aa268df03d4c881a76340907e8", + "name": "Pixiu Finance", + "symbol": "PIXIU", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/17297/thumb/pixiu_picture_.png?1627264684" + }, + { + "chainId": 1, + "address": "0x87edffde3e14c7a66c9b9724747a1c5696b742e6", + "name": "SWAG Finance", + "symbol": "SWAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12805/thumb/photo_2020-10-14_23.17.02.jpeg?1602688642" + }, + { + "chainId": 1, + "address": "0x147faf8de9d8d8daae129b187f0d02d819126750", + "name": "GeoDB", + "symbol": "GEO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11130/thumb/geodb.png?1588941704" + }, + { + "chainId": 1, + "address": "0x1234567461d3f8db7496581774bd869c83d51c93", + "name": "BitClave", + "symbol": "CAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1585/thumb/bitclave.png?1547035768" + }, + { + "chainId": 1, + "address": "0x1cf4592ebffd730c7dc92c1bdffdfc3b9efcf29a", + "name": "Waves", + "symbol": "WAVES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/425/thumb/waves.png?1548386117" + }, + { + "chainId": 1, + "address": "0xc744df3419a8c9bd4d6b9852a503eb1c5308a326", + "name": "RED TOKEN", + "symbol": "RED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27153/thumb/red.png?1662204588" + }, + { + "chainId": 1, + "address": "0x02d3a27ac3f55d5d91fb0f52759842696a864217", + "name": "Charged Particles", + "symbol": "IONX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15836/thumb/DrKjSQMH_400x400.png?1622080222" + }, + { + "chainId": 1, + "address": "0xd5281bb2d1ee94866b03a0fccdd4e900c8cb5091", + "name": "Husky", + "symbol": "HUSKY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14842/thumb/husky_logo.png?1618634383" + }, + { + "chainId": 1, + "address": "0xeb9a4b185816c354db92db09cc3b50be60b901b6", + "name": "Origin Sport", + "symbol": "ORS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4646/thumb/origin-sport-logo.png?1547039912" + }, + { + "chainId": 1, + "address": "0x3afa1902b1f8a802abc18e5ad982d1bcd34afe22", + "name": "GrEarn", + "symbol": "GST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6193/thumb/GVlSl0Oi_400x400.jpg?1547042222" + }, + { + "chainId": 1, + "address": "0xaa61d5dec73971cd4a026ef2820bb87b4a4ed8d6", + "name": "CRE8R DAO", + "symbol": "CRE8R", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22568/thumb/cropped-FINALwithbrick-2-1-1.png?1642060468" + }, + { + "chainId": 1, + "address": "0xc5ec4f1fc86da45ae788ec98756ba70b57676409", + "name": "Oje", + "symbol": "OJE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19811/thumb/Hv-ROnYV_400x400.jpg?1635924634" + }, + { + "chainId": 1, + "address": "0x3d3a4098bca71f1fee2e28d0b9db9bbe0f708ea5", + "name": "Wellness Convertible", + "symbol": "WCV", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/24849/thumb/WCV-TOKEN-LOGO-Wellness-Group.png?1649131483" + }, + { + "chainId": 1, + "address": "0x011c5c4e4a86fc95a7a6d5c49a69cdf0cb1d0467", + "name": "HK Coin", + "symbol": "HKC", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/20747/thumb/HKC200x200.png?1637634544" + }, + { + "chainId": 1, + "address": "0x67cc621ab2d086a101cff3340df0a065ac75827c", + "name": "Floki Musk", + "symbol": "FLOKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18850/thumb/1632145919586.png?1633592006" + }, + { + "chainId": 1, + "address": "0x89551b940e2a8ed8eccf509935bac9213fe30584", + "name": "DoDreamChain", + "symbol": "DRM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10469/thumb/57414069_286321078958466_8377709696580059136_n.jpg?1579733292" + }, + { + "chainId": 1, + "address": "0x6b785a0322126826d8226d77e173d75dafb84d11", + "name": "Bankroll Vault", + "symbol": "VLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11638/thumb/vlt-200.png?1592272725" + }, + { + "chainId": 1, + "address": "0xf33121a2209609cadc7349acc9c40e41ce21c730", + "name": "Blockchain Adventurers Guild", + "symbol": "BAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14863/thumb/3iw7MAi.png?1618810870" + }, + { + "chainId": 1, + "address": "0x0b498ff89709d3838a063f1dfa463091f9801c2b", + "name": "BTC 2x Flexible Leverage Index", + "symbol": "BTC2X-FLI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15406/thumb/Copy_of_BTC2x-FLI_token_logo.png?1646749417" + }, + { + "chainId": 1, + "address": "0x69bbc3f8787d573f1bbdd0a5f40c7ba0aee9bcc9", + "name": "Yup", + "symbol": "YUP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12322/thumb/photo_2021-10-26_00-47-35.jpg?1635227479" + }, + { + "chainId": 1, + "address": "0x1ec184ec2db325140b041f9214f98a537f80e1a7", + "name": "Deploying More Capital", + "symbol": "DMC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27564/thumb/dmc-logo.png?1664520787" + }, + { + "chainId": 1, + "address": "0x3fab0bbaa03bceaf7c49e2b12877db0142be65fc", + "name": "Castello Coin", + "symbol": "CAST", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/25216/thumb/19705.png?1650866493" + }, + { + "chainId": 1, + "address": "0x48515e2baee5283e3b7cdc624f3c63caef13140a", + "name": "MarvinInu", + "symbol": "MARVIN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19028/thumb/ea3lTPa.png?1634193762" + }, + { + "chainId": 1, + "address": "0xcef46305d096fa876dd23048bf80f9345282e3fc", + "name": "Banque Universal", + "symbol": "CBU", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/8112/thumb/png_tr.png?1554952499" + }, + { + "chainId": 1, + "address": "0xc88f47067db2e25851317a2fdae73a22c0777c37", + "name": "Legacy oneBTC", + "symbol": "ONEBTC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15082/thumb/G9oJy1-R.png?1619660359" + }, + { + "chainId": 1, + "address": "0x910524678c0b1b23ffb9285a81f99c29c11cbaed", + "name": "Azuki", + "symbol": "AZUKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13091/thumb/bdUBSCo.png?1605169403" + }, + { + "chainId": 1, + "address": "0x42d6622dece394b54999fbd73d108123806f6a18", + "name": "SpankChain", + "symbol": "SPANK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1226/thumb/spankchain.png?1548610811" + }, + { + "chainId": 1, + "address": "0x28a06c02287e657ec3f8e151a13c36a1d43814b0", + "name": "BondAppetit Governance", + "symbol": "BAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14724/thumb/BAG2x.png?1618568573" + }, + { + "chainId": 1, + "address": "0xda86006036540822e0cd2861dbd2fd7ff9caa0e8", + "name": "TUBE2", + "symbol": "TUBE2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18754/thumb/Tube-2.png?1633328940" + }, + { + "chainId": 1, + "address": "0x63f88a2298a5c4aee3c216aa6d926b184a4b2437", + "name": "GameCredits", + "symbol": "GAME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/193/thumb/XlQmXoU.png?1595304945" + }, + { + "chainId": 1, + "address": "0xe172f366678ec7b559f6c2913a437baadfd4e6c8", + "name": "Kauri", + "symbol": "KAU", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17802/thumb/200%C3%97200-logo.png?1629291816" + }, + { + "chainId": 1, + "address": "0x881a7e25d44591c467a37da96adf3c3705e7251b", + "name": "Elynet", + "symbol": "ELYX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13326/thumb/KakaoTalk_20201208_102026847.png?1607483005" + }, + { + "chainId": 1, + "address": "0xc5bcc8ba3f33ab0d64f3473e861bdc0685b19ef5", + "name": "Mechanium", + "symbol": "MECHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24374/thumb/w4K4OOMo_400x400.jpg?1647940092" + }, + { + "chainId": 1, + "address": "0xf45f6c8bb3d77ea762175b8f7ca4d251941649fa", + "name": "Lemond", + "symbol": "LEMD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14964/thumb/D-smP_i-_400x400.png?1619166250" + }, + { + "chainId": 1, + "address": "0x38a94e92a19e970c144ded0b2dd47278ca11cc1f", + "name": "Falcon Nine", + "symbol": "F9", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16858/thumb/logo-f9.png?1625465513" + }, + { + "chainId": 1, + "address": "0xa7de94227eb6828497f4343b9923959e41ae9cd1", + "name": "MUNI", + "symbol": "MUNI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28166/thumb/I03PYZqO_400x400-removebg-preview.png?1668172860" + }, + { + "chainId": 1, + "address": "0xe857734840dc188b4283d5af14ab8685467ab87d", + "name": "ESG Chain", + "symbol": "ESGC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22085/thumb/logo-01.png?1640761969" + }, + { + "chainId": 1, + "address": "0x5c1a02211072d7633465c64a1ed115d98d987394", + "name": "GTraX", + "symbol": "GTRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27506/thumb/lcSVRB3TqwxffjniiK5S4n4C4lMRhx0wXIWA02iiQCHvz6sS96X69Iy_kb4YZXpe1OpmJTjE7518Bl6nmFh8BhpB_vTVWzk3pGiEjHJ4dHvQKkioP6xcO7VUCkwj2QqY6iN7j39OjzDp_FuBvN1ua4Ov1wVxxkeC6ozV37cLKcU5uuC0N5gFx6lioJyybw8QQ9rOwSEmdWPpJ5KAMgjr9ii-Hj4GwW3M6q8DsTZHy4gXXvH.jpeg?1664333232" + }, + { + "chainId": 1, + "address": "0x7cda79830faf07ed696fe220566116951ced36a7", + "name": "Maya Preferred", + "symbol": "MAYP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8081/thumb/2u0OXhT9_400x400.png?1554426529" + }, + { + "chainId": 1, + "address": "0x3fe7940616e5bc47b0775a0dccf6237893353bb4", + "name": "IdleDAI Best Yield ", + "symbol": "IDLEDAIYIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11901/thumb/idledai_32.png?1595990312" + }, + { + "chainId": 1, + "address": "0x9f76ff3336597feab30f5a66a053ae4a4a7ebe13", + "name": "Token Play", + "symbol": "TP3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17996/thumb/WyzcFow.png?1630047790" + }, + { + "chainId": 1, + "address": "0xf3a2ace8e48751c965ea0a1d064303aca53842b9", + "name": "HXY Money", + "symbol": "HXY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11225/thumb/hexmoneygradientsmall.png?1595305947" + }, + { + "chainId": 1, + "address": "0x358aa737e033f34df7c54306960a38d09aabd523", + "name": "Ares Protocol", + "symbol": "ARES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15153/thumb/Ares-logo.png?1620638611" + }, + { + "chainId": 1, + "address": "0x8c9e4cf756b9d01d791b95bc2d0913ef2bf03784", + "name": "AEROTOKEN", + "symbol": "AET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9772/thumb/sVM73x16_400x400.jpg?1571707385" + }, + { + "chainId": 1, + "address": "0x23ccc43365d9dd3882eab88f43d515208f832430", + "name": "Midas Protocol", + "symbol": "MAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4287/thumb/Bestand_000.png?1607560518" + }, + { + "chainId": 1, + "address": "0x872d63d889d4b445c89a0887dcdbcc179b026432", + "name": "Axus Coin", + "symbol": "AXUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20713/thumb/-rUSqDLk_400x400.png?1637575970" + }, + { + "chainId": 1, + "address": "0xff0e5e014cf97e0615cb50f6f39da6388e2fae6e", + "name": "Origo", + "symbol": "OGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4377/thumb/Origo_Logo_png.png?1580430001" + }, + { + "chainId": 1, + "address": "0x7b2df125567815ac9b57da04b620f50bc93b320c", + "name": "Archetypal Network", + "symbol": "ACTP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5946/thumb/logo_%284%29.png?1547041885" + }, + { + "chainId": 1, + "address": "0xa16a609ff4e1a15b6ccb469e7a5dd14e89305283", + "name": "Spume", + "symbol": "SPUME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27089/thumb/D6lMeW9k_400x400.jpeg?1661824399" + }, + { + "chainId": 1, + "address": "0xd85a6ae55a7f33b0ee113c234d2ee308edeaf7fd", + "name": "Cobak", + "symbol": "CBK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13459/thumb/cbk-128-128.png?1608760936" + }, + { + "chainId": 1, + "address": "0xd0345d30fd918d7682398acbcdf139c808998709", + "name": "Lixir Finance", + "symbol": "LIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15333/thumb/SVxrN7DF_400x400.jpg?1637855435" + }, + { + "chainId": 1, + "address": "0x4e4a47cac6a28a62dcc20990ed2cda9bc659469f", + "name": "I will poop it NFT", + "symbol": "SHIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25945/thumb/PCNoOl8.png?1654833800" + }, + { + "chainId": 1, + "address": "0x8d610e20481f4c4f3acb87bba9c46bef7795fdfe", + "name": "Unity Network", + "symbol": "UNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17143/thumb/unity.PNG?1626658763" + }, + { + "chainId": 1, + "address": "0xaa6e8127831c9de45ae56bb1b0d4d4da6e5665bd", + "name": "Index Coop ETH 2x Flexible Leverage I", + "symbol": "ETH2X-FLI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14392/thumb/ETH2x-FLI_%281%29.png?1615875910" + }, + { + "chainId": 1, + "address": "0xf6ec87dfe1ed3a7256cc0c38e3c8139103e9af3b", + "name": "Gene", + "symbol": "GENE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14145/thumb/logo.a60a0c80_%281%29.png?1614653629" + }, + { + "chainId": 1, + "address": "0x5c872500c00565505f3624ab435c222e558e9ff8", + "name": "CoTrader", + "symbol": "COT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4205/thumb/logo_black.png?1547039508" + }, + { + "chainId": 1, + "address": "0x111111111117dc0aa78b770fa6a738034120c302", + "name": "1inch", + "symbol": "1INCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13469/thumb/1inch-token.png?1608803028" + }, + { + "chainId": 1, + "address": "0x5c6ee304399dbdb9c8ef030ab642b10820db8f56", + "name": "Balancer 80 BAL 20 WETH", + "symbol": "B-80BAL-20WETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26452/thumb/0x5c6ee304399dbdb9c8ef030ab642b10820db8f56.png?1658113613" + }, + { + "chainId": 1, + "address": "0x301c755ba0fca00b1923768fffb3df7f4e63af31", + "name": "Global Digital Content", + "symbol": "GDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10122/thumb/Vp4L1x4Hu4HEuEPUl0gSocDaVifkXlCqSd8A72ml_Q0uwEc9uBWBTwjS43_NP8eiiZVveJDIQXguWUXYk3MLZiFOER-8CGO120I0NGU_L8aTJ8c50a-O_AbkY-4nUkPYhUTNgf3rkcqkXnKecixQwLfkJG2XTCLwNvo_ox05x0_hU1Z__FOT4O7AeU-PC6skc85NCVS68cnZjxcUBOY9K.jpg?1576124937" + }, + { + "chainId": 1, + "address": "0x34769d3e122c93547836addd3eb298035d68f1c3", + "name": "NumisMe", + "symbol": "NUME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24766/thumb/nume_token_logo.png?1648817270" + }, + { + "chainId": 1, + "address": "0xea7aa1edd21735a5ab05ee3e90869016191e274e", + "name": "Junca cash", + "symbol": "JCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12889/thumb/junca.jpg?1603279160" + }, + { + "chainId": 1, + "address": "0xc5bddf9843308380375a611c18b50fb9341f502a", + "name": "veCRV DAO yVault", + "symbol": "YVE-CRVDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13065/thumb/yearn_veCRV.png?1612862859" + }, + { + "chainId": 1, + "address": "0xf920e4f3fbef5b3ad0a25017514b769bdc4ac135", + "name": "BABB", + "symbol": "BAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2168/thumb/babb.png?1547036466" + }, + { + "chainId": 1, + "address": "0x5af28eb9dec75e86cdfbd2e41a474b54b211c1c2", + "name": "Tangle", + "symbol": "TNGL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18312/thumb/tangle.PNG?1631510159" + }, + { + "chainId": 1, + "address": "0x9724f51e3afb6b2ae0a5d86fd3b88c73283bc38f", + "name": "WAGMI", + "symbol": "WAGMI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20531/thumb/PbEXCkig.jpg?1637201496" + }, + { + "chainId": 1, + "address": "0x6307b25a665efc992ec1c1bc403c38f3ddd7c661", + "name": "Global Coin Research", + "symbol": "GCR", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/14815/thumb/gcr.jpeg?1641461197" + }, + { + "chainId": 1, + "address": "0x9c405acf8688afb61b3197421cdeec1a266c6839", + "name": "DogeYield", + "symbol": "DOGY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13734/thumb/dogy200px.png?1611266985" + }, + { + "chainId": 1, + "address": "0x1ccf27211e8bf052f6255329ed641b4e94e80603", + "name": "Metababy", + "symbol": "BABY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27175/thumb/7psZaqh0_400x400.jpeg?1662369176" + }, + { + "chainId": 1, + "address": "0x179e31fb25e433441a2839389a7b8ec9c4654b7b", + "name": "SynchroBitcoin", + "symbol": "SNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10727/thumb/Logosnb.png?1582667361" + }, + { + "chainId": 1, + "address": "0xd8c82fbc4d8ed0644a7ec04cf973e84c6153c1d7", + "name": "Rizen Coin Old ", + "symbol": "RZN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13373/thumb/Rizen_logo_black.png?1620206327" + }, + { + "chainId": 1, + "address": "0xcbeaec699431857fdb4d37addbbdc20e132d4903", + "name": "YOYOW", + "symbol": "YOYOW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1270/thumb/yoyow.png?1548761123" + }, + { + "chainId": 1, + "address": "0xa15690e9205de386ce849889831c1668c300c1ad", + "name": "pETH18C", + "symbol": "PETH18C", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14646/thumb/peth8a.png?1617489575" + }, + { + "chainId": 1, + "address": "0x9c354503c38481a7a7a51629142963f98ecc12d0", + "name": "Origin Dollar Governance", + "symbol": "OGV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26353/thumb/ogv-200x200.png?1657606918" + }, + { + "chainId": 1, + "address": "0x00d1793d7c3aae506257ba985b34c76aaf642557", + "name": "Tacos", + "symbol": "TACO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12108/thumb/photo_2020-08-12_05-50-46.jpg?1597217863" + }, + { + "chainId": 1, + "address": "0xadf0ac3059400edfb6131b9fe65feea6ca83ad76", + "name": "Turtle Shell Islands", + "symbol": "SHELL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26925/thumb/slogo.png?1660833387" + }, + { + "chainId": 1, + "address": "0x71dc40668682a124231301414167e4cf7f55383c", + "name": "Mimir", + "symbol": "MIMIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19551/thumb/xaq5Xlzg_400x400.jpg?1635401626" + }, + { + "chainId": 1, + "address": "0xe9cb6838902ccf711f16a9ea5a1170f8e9853c02", + "name": "StripCoin", + "symbol": "STRIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20242/thumb/um7swakg.png?1636696116" + }, + { + "chainId": 1, + "address": "0x97abee33cd075c58bfdd174e0885e08e8f03556f", + "name": "Sentiment", + "symbol": "SENT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16388/thumb/94SwpUOP_400x400.jpg?1623894898" + }, + { + "chainId": 1, + "address": "0x3b08c03fa8278cf81b9043b228183760376fcdbb", + "name": "Reptilian", + "symbol": "RPTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18989/thumb/rept.PNG?1634114856" + }, + { + "chainId": 1, + "address": "0xd38de88687172bde440755b5237987e4a87c23a7", + "name": "AEN Smart", + "symbol": "AENS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15163/thumb/x58-DmSw.png?1620007469" + }, + { + "chainId": 1, + "address": "0x30df7d7ee52c1b03cd009e656f00ab875adceed2", + "name": "MetaReset", + "symbol": "RESET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26631/thumb/logo.png?1659325867" + }, + { + "chainId": 1, + "address": "0x93ecdfe316de6dc44c2104183b7f6736d83521c2", + "name": "Meta Inu Token", + "symbol": "META", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20466/thumb/META-INU.png?1637064437" + }, + { + "chainId": 1, + "address": "0x2341dd0a96a0dab62aa1efb93d59ff7f3bdb8932", + "name": "ProStarter", + "symbol": "PROT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15259/thumb/rpot.PNG?1620269970" + }, + { + "chainId": 1, + "address": "0x3802c218221390025bceabbad5d8c59f40eb74b8", + "name": "Guarded Ether", + "symbol": "GETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14001/thumb/guarda-shield-logo.png?1613603915" + }, + { + "chainId": 1, + "address": "0x2c9aceb63181cd08a093d052ec041e191f229692", + "name": "Angryb", + "symbol": "ANB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17270/thumb/AngryBlockchain.png?1627005396" + }, + { + "chainId": 1, + "address": "0x888888888888f195e27a2e0f98d712952ab9348e", + "name": "IPI Shorter", + "symbol": "IPISTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27002/thumb/box-1.png?1661329648" + }, + { + "chainId": 1, + "address": "0xb1a30851e3f7d841b231b086479608e17198363a", + "name": "Homeros", + "symbol": "HMR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11048/thumb/g1jAE5knZSlNUdLN8fEAQFMI4mTXCuNdrjj3i77rWhsIQADp3VWH2BHTkH7-oWwExxJk7Fu545LPeT3gMNzGlCZ63oX3-9sTjiqlSDo3fRLwHmhUgjD_jtKTl1AJ_F_UOOpsTqob9CxiWHXsSTlz0zODxOrjnqpMe4_cPT_C4EskSEVee_oooTasTQ6ONrv85Zcvc8Eeb8cHLsV.jpg?1587532938" + }, + { + "chainId": 1, + "address": "0xc944e90c64b2c07662a292be6244bdf05cda44a7", + "name": "The Graph", + "symbol": "GRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13397/thumb/Graph_Token.png?1608145566" + }, + { + "chainId": 1, + "address": "0xa86a0da9d05d0771955df05b44ca120661af16de", + "name": "OTCBTC", + "symbol": "OTB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5246/thumb/otcbtc-token.jpg?1547040734" + }, + { + "chainId": 1, + "address": "0xd9af2d11d788da0097076f4eb21bd1c5533743d9", + "name": "Legal Block", + "symbol": "LBK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9524/thumb/62783498_2399147633483417_3919658167318872064_n.jpg?1568605802" + }, + { + "chainId": 1, + "address": "0x833e4c02c47b7e38f5b9a80b26eb07d23d1961f4", + "name": "The Bitcoin Family", + "symbol": "FAMILY", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/13776/thumb/the_bitcoin_family.png?1611712529" + }, + { + "chainId": 1, + "address": "0xb3207935ff56120f3499e8ad08461dd403bf16b8", + "name": "dAMM", + "symbol": "DAMM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28082/thumb/dAMM_logo_round_-_dark.png?1667443628" + }, + { + "chainId": 1, + "address": "0x29a5c1db7321c5c9eae57f9366ee8eef00ca11fb", + "name": "SHKOOBY INU", + "symbol": "SHKOOBY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19790/thumb/shkooby.png?1645255468" + }, + { + "chainId": 1, + "address": "0xadb2437e6f65682b85f814fbc12fec0508a7b1d0", + "name": "UniCrypt", + "symbol": "UNCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12871/thumb/unicrypt_logo.png?1603178739" + }, + { + "chainId": 1, + "address": "0x434cb4fc4b952872967914d430878eee53ebd502", + "name": "ALLPAYCOIN", + "symbol": "APCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26836/thumb/apcg.png?1660299504" + }, + { + "chainId": 1, + "address": "0x0a3bb08b3a15a19b4de82f8acfc862606fb69a2d", + "name": "iZUMi Bond USD", + "symbol": "IUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25388/thumb/iusd-logo-symbol-10k%E5%A4%A7%E5%B0%8F.png?1651660620" + }, + { + "chainId": 1, + "address": "0x08037036451c768465369431da5c671ad9b37dbc", + "name": "NFT Stars", + "symbol": "NFTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16141/thumb/j2KHi8zR_400x400.png?1623116004" + }, + { + "chainId": 1, + "address": "0x96c645d3d3706f793ef52c19bbace441900ed47d", + "name": "Mt Pelerin Shares", + "symbol": "MPS", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/11471/thumb/MPS.png?1590319120" + }, + { + "chainId": 1, + "address": "0xe2e109f1b4eaa8915655fe8fdefc112a34acc5f0", + "name": "Dust", + "symbol": "DUST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19086/thumb/WdTDLpcA_400x400.png?1634420382" + }, + { + "chainId": 1, + "address": "0xe2d310cb8992b3fa1051ba4710f41c43eb5bba5d", + "name": "Crypto Wrestling Inu", + "symbol": "CWI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25350/thumb/logo.png?1651304842" + }, + { + "chainId": 1, + "address": "0xb487d0328b109e302b9d817b6f46cbd738ea08c2", + "name": "TattooMoney", + "symbol": "TAT2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24772/thumb/logo_200x200.png?1649835408" + }, + { + "chainId": 1, + "address": "0x5cb888182fbffdb62c08fb4b5a343914f00fdfee", + "name": "Moneybrain BiPS", + "symbol": "BIPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15556/thumb/bips_logo_200x200_Trans.png?1621204965" + }, + { + "chainId": 1, + "address": "0x8606a8f28e1e2fd50b9074d65c01548b1f040b32", + "name": "Cryptrust", + "symbol": "CTRT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6110/thumb/cryptrust.png?1547042119" + }, + { + "chainId": 1, + "address": "0xd2e5decc08a80be6538f89f9ab8ff296e2f724df", + "name": "STIMA", + "symbol": "STIMA", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/26101/thumb/STIMA_200x200.png?1655867272" + }, + { + "chainId": 1, + "address": "0x4ad7a056191f4c9519facd6d75fa94ca26003ace", + "name": "GoldPesa Option", + "symbol": "GPO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23813/thumb/15462.png?1645513212" + }, + { + "chainId": 1, + "address": "0x5a98fcbea516cf06857215779fd812ca3bef1b32", + "name": "Lido DAO", + "symbol": "LDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13573/thumb/Lido_DAO.png?1609873644" + }, + { + "chainId": 1, + "address": "0xbf6ff49ffd3d104302ef0ab0f10f5a84324c091c", + "name": "Nftfy", + "symbol": "NFTFY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15292/thumb/nfty.PNG?1620365235" + }, + { + "chainId": 1, + "address": "0x177ba0cac51bfc7ea24bad39d81dcefd59d74faa", + "name": "KittenFinance", + "symbol": "KIF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12340/thumb/SnQPkABT_400x400.png?1599173267" + }, + { + "chainId": 1, + "address": "0x27778e14ce36d3b85e1effeb43816a17bbb7088a", + "name": "Lyfe Gold", + "symbol": "LGOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14938/thumb/LGOLD-Logo-200.png?1619082558" + }, + { + "chainId": 1, + "address": "0x697ef32b4a3f5a4c39de1cb7563f24ca7bfc5947", + "name": "Insula", + "symbol": "ISLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10884/thumb/isla.PNG?1585522028" + }, + { + "chainId": 1, + "address": "0xf41e5fbc2f6aac200dd8619e121ce1f05d150077", + "name": "CRYCASH", + "symbol": "CRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1945/thumb/crycash.png?1547790664" + }, + { + "chainId": 1, + "address": "0x6a8fee0e33cb65a7e8d21badca62e87639ef74b3", + "name": "PDX Coin", + "symbol": "PDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25095/thumb/vBi23nWw_400x400.jpg?1650271510" + }, + { + "chainId": 1, + "address": "0xf51ccb15d3f2d304ae6c409303e8b3a3e397a80b", + "name": "Open Proprietary Protocol", + "symbol": "OPP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27417/thumb/1_YTzF4KXNbEMRykWKGgKpwg.jpeg?1663858531" + }, + { + "chainId": 1, + "address": "0x645c52cf6c5c58aa4064494f5b5ffe9c7ec0d7d4", + "name": "Huckleberry Inu", + "symbol": "HKBY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28495/thumb/IMG_20221214_073842_547_%283%29_%281%29.png?1671108300" + }, + { + "chainId": 1, + "address": "0x456ae45c0ce901e2e7c99c0718031cec0a7a59ff", + "name": "Vision Network", + "symbol": "VSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9029/thumb/photo_2020-08-14_20-34-55.jpg?1606133699" + }, + { + "chainId": 1, + "address": "0x284b59cf2539544559c6efa11e2795e06d535345", + "name": "DAOvc", + "symbol": "DAOVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18259/thumb/daovc.PNG?1631156207" + }, + { + "chainId": 1, + "address": "0x6f2a550259532f7429530dcb93d86269629e3f2a", + "name": "Cloud Protocol", + "symbol": "CPRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21594/thumb/o8UiNqFg_400x400.jpg?1639546169" + }, + { + "chainId": 1, + "address": "0xaa3573cc3761133375b0c504146b93f6827f945a", + "name": "All Time High", + "symbol": "ATH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28304/thumb/ath200.png?1669276766" + }, + { + "chainId": 1, + "address": "0x3ecab35b64345bfc472477a653e4a3abe70532d9", + "name": "EnterButton", + "symbol": "ENTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19677/thumb/ENTC_symbol.png?1635740712" + }, + { + "chainId": 1, + "address": "0xbb6cd639724417a20a7db0f45c1fb2fe532f490a", + "name": "Hidigital btc", + "symbol": "HDBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27024/thumb/20220824_132403.png?1661485211" + }, + { + "chainId": 1, + "address": "0x8b6cda5cc518c904e8844f445e1a7c7d2db0ff16", + "name": "SF Capital", + "symbol": "SFCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6239/thumb/36952079_1621155091328297_7456989147790573568_n.jpg?1547042274" + }, + { + "chainId": 1, + "address": "0xc4a86561cb0b7ea1214904f26e6d50fd357c7986", + "name": "Charg Coin", + "symbol": "CHG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2159/thumb/charg-coin.png?1547036459" + }, + { + "chainId": 1, + "address": "0x7025bab2ec90410de37f488d1298204cd4d6b29d", + "name": "Xriba", + "symbol": "XRA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5639/thumb/xriba.png?1548761095" + }, + { + "chainId": 1, + "address": "0x6d52dfefb16bb9cdc78bfca09061e44574886626", + "name": "CPUcoin", + "symbol": "CPU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9544/thumb/uaz.ms.png?1624024119" + }, + { + "chainId": 1, + "address": "0x2920f7d6134f4669343e70122ca9b8f19ef8fa5d", + "name": "MonoX", + "symbol": "MONO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20901/thumb/e51c6UaU_400x400.png?1637879085" + }, + { + "chainId": 1, + "address": "0x42a0d24cb5c423eaaf926ce3984aaff0c4ff6fe2", + "name": "Imperial Obelisk OLD ", + "symbol": "IMP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19083/thumb/imp_logo.png?1634377746" + }, + { + "chainId": 1, + "address": "0xb622400807765e73107b7196f444866d7edf6f62", + "name": "Heros", + "symbol": "HEROS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20381/thumb/200x200.png?1658719987" + }, + { + "chainId": 1, + "address": "0x3fb8d8a28aff053ccf446bc075eecb7a0ef65d0c", + "name": "StarPlay", + "symbol": "STPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9705/thumb/8fp5wsxp_400x400.png?1570920359" + }, + { + "chainId": 1, + "address": "0x805856f176625843d14097017618e224f4607d2d", + "name": "battle esports coin", + "symbol": "BES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22866/thumb/9R4ImfBo_400x400.jpg?1642755223" + }, + { + "chainId": 1, + "address": "0x6e0dade58d2d89ebbe7afc384e3e4f15b70b14d8", + "name": "QuiverX", + "symbol": "QRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12916/thumb/qrx_logo.png?1603550478" + }, + { + "chainId": 1, + "address": "0x2965395f71b7d97ede251e9b63e44dfa9647cc0a", + "name": "Shinshu Inu", + "symbol": "SHINSHU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28093/thumb/shinshu200.png?1667536301" + }, + { + "chainId": 1, + "address": "0x8c15ef5b4b21951d50e53e4fbda8298ffad25057", + "name": "Function X", + "symbol": "FX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8186/thumb/47271330_590071468072434_707260356350705664_n.jpg?1556096683" + }, + { + "chainId": 1, + "address": "0x0bc529c00c6401aef6d220be8c6ea1667f6ad93e", + "name": "yearn finance", + "symbol": "YFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11849/thumb/yfi-192x192.png?1598325330" + }, + { + "chainId": 1, + "address": "0xba93ef534094f8b7001ece2691168140965341ab", + "name": "Beauty Bakery Linked Operation Transact", + "symbol": "LOTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27688/thumb/LOTT.jpg?1665217304" + }, + { + "chainId": 1, + "address": "0x68b1cadb8d5ab0c97fe9d9fbe0eb60acb329fe3f", + "name": "Unicly Mystic Axies Collection", + "symbol": "UAXIE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14921/thumb/uaxie-mystic.png?1619055573" + }, + { + "chainId": 1, + "address": "0x46d886887b6908183032c75dee1b731b26d653c6", + "name": "GreenCoin AI", + "symbol": "GRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18376/thumb/Untitled-design-2-removebg-preview.png?1631692214" + }, + { + "chainId": 1, + "address": "0xd9b312d77bc7bed9b9cecb56636300bed4fe5ce9", + "name": "Gains", + "symbol": "GAINS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14681/thumb/GAINS_Token_200x200.png?1617796172" + }, + { + "chainId": 1, + "address": "0xfe459828c90c0ba4bc8b42f5c5d44f316700b430", + "name": "BBS Network", + "symbol": "BBS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23715/thumb/Ni13Pg1K_400x400.jpg?1645110585" + }, + { + "chainId": 1, + "address": "0x3b604747ad1720c01ded0455728b62c0d2f100f0", + "name": "WAGMI Game", + "symbol": "WAGMIGAMES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25906/thumb/Eohd79rn_400x400.jpg?1654582966" + }, + { + "chainId": 1, + "address": "0xa891cf72aeda692570928efe1a832342e9783cdc", + "name": "Interfinex Bills", + "symbol": "IFEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13346/thumb/U6uYZry.png?1607662020" + }, + { + "chainId": 1, + "address": "0xc4e8a9d47000ab8e59c7031e311762c68215e467", + "name": "STARX", + "symbol": "STARX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8417/thumb/starworks.PNG?1640681958" + }, + { + "chainId": 1, + "address": "0xaa2d8c9a8bd0f7945143bfd509be3ff23dd78918", + "name": "Artizen", + "symbol": "ATNT", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/27263/thumb/ATNT-symbol_200.png?1663059371" + }, + { + "chainId": 1, + "address": "0x8ce9137d39326ad0cd6491fb5cc0cba0e089b6a9", + "name": "SXP", + "symbol": "SXP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9368/thumb/swipe.png?1566792311" + }, + { + "chainId": 1, + "address": "0x59321ace77c8087ff8cb9f94c8384807e4fd8a3c", + "name": "Xeniumx", + "symbol": "XEMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11094/thumb/AmoNWiZ_vx17KF3g6q5RQRaAYrXBXXWjRH5sU2m-1JYt3rJ4c88yo-KS9qKh43lfN2QkuS6AVuYAxcpQQSHQMjqwh-6HsdCyF-yi0xH9Dio5E6UdvNlh0fAMe-RSzp6x2UN6RhAorfUp_wMDDDnHSANWR9iOmVKtemiBLwpUyF-NbY3xdhW5hHAfbARvdnGODq14ujlFu0MJuLi.jpg?1588212665" + }, + { + "chainId": 1, + "address": "0xf3ae5d769e153ef72b4e3591ac004e89f48107a1", + "name": "Deeper Network", + "symbol": "DPR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14748/thumb/deeper.png?1618094356" + }, + { + "chainId": 1, + "address": "0x30c2a84aed6db30e31cf4d7059b1836c12c68068", + "name": "Unicly Aavegotchi Astronauts Collection", + "symbol": "UGOTCHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14901/thumb/uGOTCHI.jpg?1618936478" + }, + { + "chainId": 1, + "address": "0xe4dae00bc1c46ea2f44ae71b1beb8b171c15d812", + "name": "PREMA", + "symbol": "PRMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27600/thumb/prmx.png?1664715769" + }, + { + "chainId": 1, + "address": "0xa1a88cea335edaf30ce90f103f1434a773ea46bd", + "name": "Deku Inu", + "symbol": "DEKU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18434/thumb/logo_382.png?1631944724" + }, + { + "chainId": 1, + "address": "0x33840024177a7daca3468912363bed8b425015c5", + "name": "Ebox", + "symbol": "EBOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14528/thumb/ebox.png?1639203519" + }, + { + "chainId": 1, + "address": "0x6fc5af63990aa9e5c5543f5cd8ed148bfa6d9d19", + "name": "Saint Inu", + "symbol": "SAINT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19724/thumb/saint_inu.png?1648269236" + }, + { + "chainId": 1, + "address": "0xeabb8996ea1662cad2f7fb715127852cd3262ae9", + "name": "Connect Financial", + "symbol": "CNFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13592/thumb/cf-logo-iconic-black.png?1644479524" + }, + { + "chainId": 1, + "address": "0x87931e7ad81914e7898d07c68f145fc0a553d8fb", + "name": "WIZARD Vault NFTX ", + "symbol": "WIZARD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17068/thumb/Wizards.png?1626151233" + }, + { + "chainId": 1, + "address": "0x33d203fa03bb30b133de0fe2d6533c268ba286b6", + "name": "MandoX", + "symbol": "MANDOX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24968/thumb/NmqN8g7.png?1649917431" + }, + { + "chainId": 1, + "address": "0x9416ba76e88d873050a06e5956a3ebf10386b863", + "name": "Virtue", + "symbol": "VIRTUE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25834/thumb/discord.png?1654067486" + }, + { + "chainId": 1, + "address": "0xc58f53a8adff2fb4eb16ed56635772075e2ee123", + "name": "Aave AMM UniWBTCWETH", + "symbol": "AAMMUNIWBTCWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17231/thumb/aAmmUniWBTCWETH.png?1626921113" + }, + { + "chainId": 1, + "address": "0x9b62ec1453cea5dde760aaf662048ca6eeb66e7f", + "name": "Consensus Cell Network", + "symbol": "ECELL", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/12624/thumb/ecell_logo_128.png?1643188699" + }, + { + "chainId": 1, + "address": "0x5f944b0c4315cb7c3a846b025ab4045da44abf6c", + "name": "Pancake Games", + "symbol": "GCAKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20217/thumb/6oc-L2UC_400x400.png?1636671365" + }, + { + "chainId": 1, + "address": "0x3d9233f15bb93c78a4f07b5c5f7a018630217cb3", + "name": "Unicly Genesis Collection", + "symbol": "UUNICLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14903/thumb/Unicly_%28unicly%29.jpg?1618937278" + }, + { + "chainId": 1, + "address": "0xe0c8b298db4cffe05d1bea0bb1ba414522b33c1b", + "name": "Nuco Cloud", + "symbol": "NCDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8932/thumb/nucloud_logo.png?1650524741" + }, + { + "chainId": 1, + "address": "0x746dda2ea243400d5a63e0700f190ab79f06489e", + "name": "BOSAGORA", + "symbol": "BOA", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/9202/thumb/boaLogo.png?1565231346" + }, + { + "chainId": 1, + "address": "0x73374ea518de7addd4c2b624c0e8b113955ee041", + "name": "Juggernaut", + "symbol": "JGN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12761/thumb/juggernaut_logo.png?1602428976" + }, + { + "chainId": 1, + "address": "0x72108a8cc3254813c6be2f1b77be53e185abfdd9", + "name": "Era Swap", + "symbol": "ES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6031/thumb/era_swap.PNG?1570920926" + }, + { + "chainId": 1, + "address": "0x6be61833fc4381990e82d7d4a9f4c9b3f67ea941", + "name": "Hotbit", + "symbol": "HTB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5990/thumb/hotbit-token.png?1547041932" + }, + { + "chainId": 1, + "address": "0x13c99770694f07279607a6274f28a28c33086424", + "name": "Material", + "symbol": "MTRL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22069/thumb/square-200x200.png?1640749501" + }, + { + "chainId": 1, + "address": "0xe61f6e39711cec14f8d6c637c2f4568baa9ff7ee", + "name": "Hey", + "symbol": "HEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28092/thumb/HEY-logo-2-1024x1024.png?1667534940" + }, + { + "chainId": 1, + "address": "0xdffc63f92c939deb112d88735ade3b4d21b6d491", + "name": "Devour Token", + "symbol": "RESTAURANTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22817/thumb/Devour-200x200-2.png?1645602391" + }, + { + "chainId": 1, + "address": "0x467719ad09025fcc6cf6f8311755809d45a5e5f3", + "name": "Axelar", + "symbol": "AXL", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/27277/thumb/V-65_xQ1_400x400.jpeg?1663121730" + }, + { + "chainId": 1, + "address": "0xa150db9b1fa65b44799d4dd949d922c0a33ee606", + "name": "Digital Reserve Currency", + "symbol": "DRC", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/12802/thumb/DRC_Logo.jpg?1654229818" + }, + { + "chainId": 1, + "address": "0xcb94be6f13a1182e4a4b6140cb7bf2025d28e41b", + "name": "WeTrust", + "symbol": "TRST", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/645/thumb/wetrust.png?1547034370" + }, + { + "chainId": 1, + "address": "0x03042482d64577a7bdb282260e2ea4c8a89c064b", + "name": "Centaur", + "symbol": "CNTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12743/thumb/logo_%2898%29.png?1602630445" + }, + { + "chainId": 1, + "address": "0xd3c89cac4a4283edba6927e2910fd1ebc14fe006", + "name": "Moona ", + "symbol": "MOOI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14125/thumb/mooi.png?1617866132" + }, + { + "chainId": 1, + "address": "0xc6db556fd9ec09bab6dfea320e52d8476f61d424", + "name": "Cool Monke Banana", + "symbol": "CMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23385/thumb/cmb-200x200.png?1643965383" + }, + { + "chainId": 1, + "address": "0x139cec55d1ec47493dfa25ca77c9208aba4d3c68", + "name": "Parasset", + "symbol": "ASET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19395/thumb/token_200.png?1635151501" + }, + { + "chainId": 1, + "address": "0x7102dc82ef61bfb0410b1b1bf8ea74575bf0a105", + "name": "X7102", + "symbol": "X7102", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28420/thumb/X7102_LOGO_black_back_200_x_200_px.png?1670460752" + }, + { + "chainId": 1, + "address": "0x7237c0b30b1355f1b76355582f182f6f04b08740", + "name": "MetaGaming Guild", + "symbol": "MGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23287/thumb/mgg.png?1643543010" + }, + { + "chainId": 1, + "address": "0xa9f9acb92e4e2f16410511d56839a5bd1d630a60", + "name": "BLOCK E", + "symbol": "BLOCK-E", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26905/thumb/photo_2022-09-07_10.17.08.jpeg?1664065816" + }, + { + "chainId": 1, + "address": "0x7e00b63483c92975a3be0a71432277935326a618", + "name": "DroneFly", + "symbol": "KDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17243/thumb/dronefly_symbol_200x200.png?1626936898" + }, + { + "chainId": 1, + "address": "0xf5f06ffa53ad7f5914f493f16e57b56c8dd2ea80", + "name": "Jelly", + "symbol": "JELLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25386/thumb/200x200Jtokenlogo.png?1651641389" + }, + { + "chainId": 1, + "address": "0x97aa8e14db0bc073cc7e2d42ac715427717d6042", + "name": "SPUNK Vault NFTX ", + "symbol": "SPUNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17063/thumb/Spunks_%281%29.png?1626150896" + }, + { + "chainId": 1, + "address": "0xaaaebe6fe48e54f431b0c390cfaf0b017d09d42d", + "name": "Celsius Network", + "symbol": "CEL", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/3263/thumb/CEL_logo.png?1609598753" + }, + { + "chainId": 1, + "address": "0x7a73839bd0e5cded853cb01aa9773f8989381065", + "name": "UpBots", + "symbol": "UBXN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12476/thumb/UBXT.png?1600132967" + }, + { + "chainId": 1, + "address": "0xd780ae2bf04cd96e577d3d014762f831d97129d0", + "name": "Envion", + "symbol": "EVN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1547/thumb/envion.jpg?1547035704" + }, + { + "chainId": 1, + "address": "0xb399511642fe1666c6a07f83483e6e4feaed9a00", + "name": "Standard Euro", + "symbol": "SEURO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28201/thumb/sEuroLogo.png?1670480816" + }, + { + "chainId": 1, + "address": "0xe59d2ff6995a926a574390824a657eed36801e55", + "name": "Aave AMM UniAAVEWETH", + "symbol": "AAMMUNIAAVEWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17232/thumb/aAmmUniAAVEWETH.png?1626921301" + }, + { + "chainId": 1, + "address": "0x17ce5a8187c817d659b21083455455a092a173bb", + "name": "World Bet Inu", + "symbol": "WBI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28279/thumb/WBIlogo.png?1669107582" + }, + { + "chainId": 1, + "address": "0x2a69655c22eda32ff48d315bb26ed45f150700b4", + "name": "StakerDAO Wrapped Tezos", + "symbol": "WXTZ", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14763/thumb/wXTZ-token-FullColor.png?1618281765" + }, + { + "chainId": 1, + "address": "0x3c4b6e6e1ea3d4863700d7f76b36b7f3d3f13e3d", + "name": "Voyager VGX", + "symbol": "VGX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/794/thumb/Voyager-vgx.png?1575693595" + }, + { + "chainId": 1, + "address": "0x4fadc7a98f2dc96510e42dd1a74141eeae0c1543", + "name": "Wrapped AR", + "symbol": "WAR", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/17093/thumb/war.PNG?1626224053" + }, + { + "chainId": 1, + "address": "0xb1f871ae9462f1b2c6826e88a7827e76f86751d4", + "name": "GNY", + "symbol": "GNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5300/thumb/icon_gny.jpg?1601926183" + }, + { + "chainId": 1, + "address": "0xb29663aa4e2e81e425294193616c1b102b70a158", + "name": "Ludena Protocol", + "symbol": "LDN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13372/thumb/LudenaProtocol_symbol_200x200.png?1607999831" + }, + { + "chainId": 1, + "address": "0x0239d3a3485ec54511bee9d77d92695e443bf060", + "name": "Bill", + "symbol": "BILL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18480/thumb/photo_2021-08-16_23-27-37.jpg?1632151517" + }, + { + "chainId": 1, + "address": "0x504cde95dbc5d90d09b802f43b371971adbecf79", + "name": "Centralex", + "symbol": "CENX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16025/thumb/Centralex_Logo.png?1622618498" + }, + { + "chainId": 1, + "address": "0x220b71671b649c03714da9c621285943f3cbcdc6", + "name": "TosDis", + "symbol": "DIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13745/thumb/Tosdis-black.png?1611379744" + }, + { + "chainId": 1, + "address": "0x3c2a309d9005433c1bc2c92ef1be06489e5bf258", + "name": "Wrapped Paycoin", + "symbol": "WPCI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/24390/thumb/new_logo_square_%281%29.png?1648792416" + }, + { + "chainId": 1, + "address": "0xfa93660c3f6a848556bb8e265f994160a1f2b289", + "name": "Community Business Token", + "symbol": "CBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14701/thumb/CBT-Token-Small.png?1617838284" + }, + { + "chainId": 1, + "address": "0xea47b64e1bfccb773a0420247c0aa0a3c1d2e5c5", + "name": "BAYC Vault NFTX ", + "symbol": "BAYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17035/thumb/BAYC.png?1626142944" + }, + { + "chainId": 1, + "address": "0x9d0b65a76274645b29e4cc41b8f23081fa09f4a3", + "name": "iMe Lab", + "symbol": "LIME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16243/thumb/lim_200.2.png?1623376205" + }, + { + "chainId": 1, + "address": "0x5003b168b457b663c3c18ffcf5b6a24bee8f59c7", + "name": "Musk", + "symbol": "MUSK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6614/thumb/1aCM-fLB_400x400.jpg?1547042815" + }, + { + "chainId": 1, + "address": "0xec79e0efa4ae3d8b3c9fbcee21683c7f2e507b66", + "name": "Dengba Planet", + "symbol": "DBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9042/thumb/FVNxxLbx_400x400.jpg?1563833177" + }, + { + "chainId": 1, + "address": "0x26fb86579e371c7aedc461b2ddef0a8628c93d3b", + "name": "BORA", + "symbol": "BORA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7646/thumb/mqFw8hxm_400x400.jpeg?1656657343" + }, + { + "chainId": 1, + "address": "0xa8b0f154a688c22142e361707df64277e0a0be66", + "name": "Rake Finance", + "symbol": "RAK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13078/thumb/rake-logo-200x200.png?1604931839" + }, + { + "chainId": 1, + "address": "0x661ab0ed68000491d98c796146bcf28c20d7c559", + "name": "Shadows", + "symbol": "DOWS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14160/thumb/C3E49eZx_400x400.jpg?1614689301" + }, + { + "chainId": 1, + "address": "0x97fb6fc2ad532033af97043b563131c5204f8a35", + "name": "Plus Coin", + "symbol": "NPLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4686/thumb/plus-coin-logo.png?1547039959" + }, + { + "chainId": 1, + "address": "0x63b4f3e3fa4e438698ce330e365e831f7ccd1ef4", + "name": "CyberFi", + "symbol": "CFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13112/thumb/cyberfi_logo.jpeg?1605283367" + }, + { + "chainId": 1, + "address": "0x7866e48c74cbfb8183cd1a929cd9b95a7a5cb4f4", + "name": "DexKit", + "symbol": "KIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13187/thumb/7739.png?1643187354" + }, + { + "chainId": 1, + "address": "0x1934e252f840aa98dfce2b6205b3e45c41aef830", + "name": "Cabin", + "symbol": "CABIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23874/thumb/z8CMVDb8_400x400.jpg?1645600167" + }, + { + "chainId": 1, + "address": "0xac0968a3e2020ac8ca83e60ccf69081ebc6d3bc3", + "name": "Cindrum", + "symbol": "CIND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20449/thumb/1_sbv9l6ArIn7oYIhi0oQWoQ.png?1637043983" + }, + { + "chainId": 1, + "address": "0xe304283c3e60cefaf7ea514007cf4e8fdc3d869d", + "name": "Gecoin", + "symbol": "GEC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25646/thumb/62162f0d583e5a047dc02e7e_gecoin_200x200.png?1653019356" + }, + { + "chainId": 1, + "address": "0x2bdc0d42996017fce214b21607a515da41a9e0c5", + "name": "SkinCoin", + "symbol": "SKIN", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/830/thumb/skincoin.png?1547034622" + }, + { + "chainId": 1, + "address": "0x090185f2135308bad17527004364ebcc2d37e5f6", + "name": "Spell", + "symbol": "SPELL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15861/thumb/abracadabra-3.png?1622544862" + }, + { + "chainId": 1, + "address": "0xa456b515303b2ce344e9d2601f91270f8c2fea5e", + "name": "Cornichon", + "symbol": "CORN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13235/thumb/cornichon.png?1606629943" + }, + { + "chainId": 1, + "address": "0x874cb28a655e0ef827d810e211ae4b9cbcbaf614", + "name": "Gain DAO", + "symbol": "GAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26570/thumb/GAIN_listing_200.png?1658816125" + }, + { + "chainId": 1, + "address": "0xf6c2a37acc8ba45874808837486110dc0afc63c8", + "name": "MetaX", + "symbol": "X1", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/27411/thumb/pNi9ej83_400x400.png?1663853065" + }, + { + "chainId": 1, + "address": "0x350d3f0f41b5b21f0e252fe2645ae9d55562150a", + "name": "BananaClubToken", + "symbol": "BCT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26634/thumb/IMG_20220729_203534_044.jpg?1659327556" + }, + { + "chainId": 1, + "address": "0x0f00f1696218eaefa2d2330df3d6d1f94813b38f", + "name": "SEDO POW", + "symbol": "SEDO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6866/thumb/sedocoin-logo.jpg?1547043199" + }, + { + "chainId": 1, + "address": "0xf9d4daae1300cff251979722c4a3c45857973079", + "name": "bitcastle", + "symbol": "CASTLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26551/thumb/blue_logo03.png?1658753049" + }, + { + "chainId": 1, + "address": "0xe89c20096b636ffec9fd26d1a623f42a33ead309", + "name": "Oogear", + "symbol": "OG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23970/thumb/og.png?1645869076" + }, + { + "chainId": 1, + "address": "0x36f3fd68e7325a35eb768f1aedaae9ea0689d723", + "name": "Empty Set Dollar", + "symbol": "ESD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12440/thumb/esd_logo_circle.png?1603676421" + }, + { + "chainId": 1, + "address": "0xbc194e6f748a222754c3e8b9946922c09e7d4e91", + "name": "Lever Network", + "symbol": "LEV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15323/thumb/lever.PNG?1620513101" + }, + { + "chainId": 1, + "address": "0xdf0041891bda1f911c4243f328f7cf61b37f965b", + "name": "BOOSTO", + "symbol": "BST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3448/thumb/Untitled2222.png?1547038159" + }, + { + "chainId": 1, + "address": "0xff2b3353c3015e9f1fbf95b9bda23f58aa7ce007", + "name": "BitScreener", + "symbol": "BITX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4241/thumb/bitx.png?1547039570" + }, + { + "chainId": 1, + "address": "0xe910c2a090516fb7a7be07f96a464785f2d5dc18", + "name": "CheckMate Token", + "symbol": "CMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28382/thumb/cmt.png?1669974415" + }, + { + "chainId": 1, + "address": "0xdd0020b1d5ba47a54e2eb16800d73beb6546f91a", + "name": "Moola", + "symbol": "AXPR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2682/thumb/6QRknY7.png?1657767443" + }, + { + "chainId": 1, + "address": "0x98ddc72bd02d448f68c4226f26122c66c5bd711e", + "name": "Non Fungible TOKE", + "symbol": "TOKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17969/thumb/toke.PNG?1629947405" + }, + { + "chainId": 1, + "address": "0x940bdcb99a0ee5fb008a606778ae87ed9789f257", + "name": "JFIN Coin", + "symbol": "JFIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13370/thumb/JFin-Coin-Logo.png?1607984823" + }, + { + "chainId": 1, + "address": "0x95392f142af1c12f6e39897ff9b09c599666b50c", + "name": "Impostors Blood", + "symbol": "BLOOD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25527/thumb/RV4nKK2RDO47XzfSLgGs_llgXivhdfpI3tso0.png?1652240523" + }, + { + "chainId": 1, + "address": "0x848592388097d2a3ca9e285f445e5b92b6af52ad", + "name": "Dwagon", + "symbol": "BABYTSUKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27480/thumb/photo_2022-09-25_21-37-24.jpg?1664242733" + }, + { + "chainId": 1, + "address": "0x0a50c93c762fdd6e56d86215c24aaad43ab629aa", + "name": "LGO", + "symbol": "LGO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2353/thumb/2_JNnfVRPMBuA1hwnRubH72A.png?1595311622" + }, + { + "chainId": 1, + "address": "0x4fe83213d56308330ec302a8bd641f1d0113a4cc", + "name": "NuCypher", + "symbol": "NU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3318/thumb/photo1198982838879365035.jpg?1547037916" + }, + { + "chainId": 1, + "address": "0x8c6bf16c273636523c29db7db04396143770f6a0", + "name": "Moon Rabbit", + "symbol": "AAA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17310/thumb/logo_moon_no_inscriptions-01.png?1627275874" + }, + { + "chainId": 1, + "address": "0x196c81385bc536467433014042788eb707703934", + "name": "CryptoTask", + "symbol": "CTASK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13965/thumb/cryptotask_logo.png?1613372242" + }, + { + "chainId": 1, + "address": "0x2f9f363685ffecc8d7bed0486d8c2b21232bdc5a", + "name": "Adventure Inu", + "symbol": "ADINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20036/thumb/Adventure200x200.png?1636424176" + }, + { + "chainId": 1, + "address": "0x5228a22e72ccc52d415ecfd199f99d0665e7733b", + "name": "pTokens BTC OLD ", + "symbol": "PBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10805/thumb/J51iIea.png?1583891599" + }, + { + "chainId": 1, + "address": "0x8a732bc91c33c167f868e0af7e6f31e0776d0f71", + "name": "Litecoin LTK", + "symbol": "LTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7573/thumb/LTK.jpg?1550626784" + }, + { + "chainId": 1, + "address": "0x0e58ed58e150dba5fd8e5d4a49f54c7e1e880124", + "name": "Relite Finance", + "symbol": "RELI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14906/thumb/xPZRuspj_400x400.jpg?1618983798" + }, + { + "chainId": 1, + "address": "0x3d79abb948bc76794ff4a0bcd60170a741f26360", + "name": "Tails", + "symbol": "TAILS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19065/thumb/Tails_LOGO.png?1634266919" + }, + { + "chainId": 1, + "address": "0xb90cb79b72eb10c39cbdf86e50b1c89f6a235f2e", + "name": "Auditchain", + "symbol": "AUDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6398/thumb/auditchain.png?1547042519" + }, + { + "chainId": 1, + "address": "0x94d8db14831c2c08943798542c450df2844913e5", + "name": "Zuplo", + "symbol": "ZLP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13066/thumb/logo2x56_Mesa_de_trabajo_1.png?1604886987" + }, + { + "chainId": 1, + "address": "0xcb5f72d37685c3d5ad0bb5f982443bc8fcdf570e", + "name": "Rootkit", + "symbol": "ROOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13151/thumb/rootkit_logo.png?1605712875" + }, + { + "chainId": 1, + "address": "0x0ae8b74cd2d566853715800c9927f879d6b76a37", + "name": "Momento", + "symbol": "MOMENTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18532/thumb/momento.png?1632295065" + }, + { + "chainId": 1, + "address": "0xbc7942054f77b82e8a71ace170e4b00ebae67eb6", + "name": "Serenity Financial", + "symbol": "SRNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7334/thumb/serenity.jpg?1547043996" + }, + { + "chainId": 1, + "address": "0xd16fd95d949f996e3808eeea0e3881c59e76ef1e", + "name": "Para", + "symbol": "PARA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24652/thumb/para.jpg?1662464045" + }, + { + "chainId": 1, + "address": "0xa31f7a32db329f270a0e6b59558823e64d8ef0a6", + "name": "Q8E20 Token", + "symbol": "Q8E20", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10427/thumb/F366Xq9.png?1579215048" + }, + { + "chainId": 1, + "address": "0x8e0fe2947752be0d5acf73aae77362daf79cb379", + "name": "NFTrade", + "symbol": "NFTD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18578/thumb/nftrade.png?1632486088" + }, + { + "chainId": 1, + "address": "0x2c644c3bbea053ed95a6bc04a94c9ce928ff9881", + "name": "Lance Coin", + "symbol": "LCE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14707/thumb/logo200x200_%282%29.png?1617873370" + }, + { + "chainId": 1, + "address": "0x033e223870f766644f7f7a4b7dc2e91573707d06", + "name": "Zin", + "symbol": "ZIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13250/thumb/coingecko_logo.png?1606716375" + }, + { + "chainId": 1, + "address": "0xb19dd661f076998e3b0456935092a233e12c2280", + "name": "Continuum World", + "symbol": "UM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18798/thumb/Moneda.png?1633474110" + }, + { + "chainId": 1, + "address": "0x80c8c3dcfb854f9542567c8dac3f44d709ebc1de", + "name": "Spaceswap MILK2", + "symbol": "MILK2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12771/thumb/milk.png?1633423719" + }, + { + "chainId": 1, + "address": "0xd61143652af94f570c7d9429356662dd859ca6ec", + "name": "Fintropy", + "symbol": "FINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21222/thumb/quExJXdW_400x400.png?1638740691" + }, + { + "chainId": 1, + "address": "0xb0c7a3ba49c7a6eaba6cd4a96c55a1391070ac9a", + "name": "Magic", + "symbol": "MAGIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18623/thumb/magic.png?1656052146" + }, + { + "chainId": 1, + "address": "0xe74be071f3b62f6a4ac23ca68e5e2a39797a3c30", + "name": "Recharge", + "symbol": "RCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18120/thumb/thecharge.PNG?1630559768" + }, + { + "chainId": 1, + "address": "0x3703f712945f8111fe2c5f9ae155a52560e2065c", + "name": "Bamboonium", + "symbol": "BAMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25193/thumb/bamb_logo.png?1650608279" + }, + { + "chainId": 1, + "address": "0x23b608675a2b2fb1890d3abbd85c5775c51691d5", + "name": "Unisocks", + "symbol": "SOCKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10717/thumb/qFrcoiM.png?1582525244" + }, + { + "chainId": 1, + "address": "0x968cbe62c830a0ccf4381614662398505657a2a9", + "name": "Thrupenny", + "symbol": "TPY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26799/thumb/rsz_1mpmojfho_400x400.png?1660189540" + }, + { + "chainId": 1, + "address": "0x47481c1b44f2a1c0135c45aa402ce4f4dde4d30e", + "name": "Meetple", + "symbol": "MPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14323/thumb/Tqlsvhn1_400x400.png?1615427198" + }, + { + "chainId": 1, + "address": "0x3fd8f39a962efda04956981c31ab89fab5fb8bc8", + "name": "Rotharium", + "symbol": "RTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2030/thumb/L7kpRMda_400x400.jpg?1547036314" + }, + { + "chainId": 1, + "address": "0x8689d850cdf3b74a1f6a5eb60302c785b71c2fc7", + "name": "Crypto Phoenix", + "symbol": "CPHX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17942/thumb/xEO0oeVz_400x400.jpg?1629881740" + }, + { + "chainId": 1, + "address": "0x0f7f961648ae6db43c75663ac7e5414eb79b5704", + "name": "Blockzero Labs", + "symbol": "XIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10029/thumb/blockzero.jpg?1611110205" + }, + { + "chainId": 1, + "address": "0x89dcff5fd892f2bfc8b75dba12804b651f769579", + "name": "Staker DAO", + "symbol": "STKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14535/thumb/stakerdao_logo.png?1616812877" + }, + { + "chainId": 1, + "address": "0x56de8bc61346321d4f2211e3ac3c0a7f00db9b76", + "name": "RENA Finance", + "symbol": "RENA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15667/thumb/photo_2021-05-21_17-31-35.png?1621825861" + }, + { + "chainId": 1, + "address": "0xa7de087329bfcda5639247f96140f9dabe3deed1", + "name": "Statera", + "symbol": "STA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11472/thumb/Statera.png?1590415353" + }, + { + "chainId": 1, + "address": "0x232fb065d9d24c34708eedbf03724f2e95abe768", + "name": "Sheesha Finance ERC20 ", + "symbol": "SHEESHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23053/thumb/MLBmh4z0.png?1643113057" + }, + { + "chainId": 1, + "address": "0x7458fd786b2fe8cd801c0381f88b61c5071a006f", + "name": "LOA Protocol", + "symbol": "LOA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11164/thumb/1a67ac81c1803ee172b7ce8805b5da3d-full.jpg?1589411408" + }, + { + "chainId": 1, + "address": "0x47dac6bd80f024575a6d367af5ba8e89202a09fc", + "name": "OXO Farm", + "symbol": "OXO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15107/thumb/OXO200.png?1619734005" + }, + { + "chainId": 1, + "address": "0x56015bbe3c01fe05bc30a8a9a9fd9a88917e7db3", + "name": "Mooncat CAT", + "symbol": "CAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12177/thumb/happy2-2.jpg?1619593488" + }, + { + "chainId": 1, + "address": "0xa9e201a4e269d6cd5e9f0fcbcb78520cf815878b", + "name": "Aave AMM UniRENWETH", + "symbol": "AAMMUNIRENWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17223/thumb/aAmmUniRENWETH.png?1626880629" + }, + { + "chainId": 1, + "address": "0x60a16b9efd33bb45c18833aed45ca66045b3b714", + "name": "i9X Coin", + "symbol": "I9X", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14124/thumb/unnamed_%282%29.jpg?1614565794" + }, + { + "chainId": 1, + "address": "0x72377f31e30a405282b522d588aebbea202b4f23", + "name": "Varen", + "symbol": "VRN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17633/thumb/vrn.png?1636075314" + }, + { + "chainId": 1, + "address": "0x4a8f44be523580a11cdb20e2c7c470adf44ec9bb", + "name": "Bit Miner Chain", + "symbol": "BTMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6177/thumb/9ecCxf_s_400x400.jpg?1547042203" + }, + { + "chainId": 1, + "address": "0x1735db6ab5baa19ea55d0adceed7bcdc008b3136", + "name": "UREEQA", + "symbol": "URQA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14605/thumb/R_O2enOX_400x400.png?1617243310" + }, + { + "chainId": 1, + "address": "0x79256db1bdb6259315a1a3d7dd237f69cadfd8fc", + "name": "Typhoon Cash", + "symbol": "PHOON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13730/thumb/photo_2021-01-21_19-05-27.jpg?1611227665" + }, + { + "chainId": 1, + "address": "0x0913ddae242839f8995c0375493f9a1a3bddc977", + "name": "Marshall Inu", + "symbol": "MRI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23784/thumb/mri.png?1647693409" + }, + { + "chainId": 1, + "address": "0x48bef6bd05bd23b5e6800cf0406e524b517af250", + "name": "Chubbies", + "symbol": "CHUBBIES20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17857/thumb/unnamed_%281%29.gif?1629681572" + }, + { + "chainId": 1, + "address": "0xa0ed3c520dc0632657ad2eaaf19e26c4fd431a84", + "name": "Hippo Wallet", + "symbol": "HPO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28089/thumb/b77170dd-1dd1-4581-91b2-e352794fa045.jpg?1667446200" + }, + { + "chainId": 1, + "address": "0xef5b32486ed432b804a51d129f4d2fbdf18057ec", + "name": "Pirate Inu", + "symbol": "PINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19959/thumb/pinu.png?1636341206" + }, + { + "chainId": 1, + "address": "0x667088b212ce3d06a1b553a7221e1fd19000d9af", + "name": "Wings", + "symbol": "WINGS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/648/thumb/wings.png?1548760631" + }, + { + "chainId": 1, + "address": "0xd9d01d4cb824219a8f482a0fad479cb971fd0628", + "name": "EnterCoin", + "symbol": "ENTRC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8163/thumb/entrc-logo200.png?1555901482" + }, + { + "chainId": 1, + "address": "0x947aeb02304391f8fbe5b25d7d98d649b57b1788", + "name": "Mandala Exchange", + "symbol": "MDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13736/thumb/png-cmc.png?1611288725" + }, + { + "chainId": 1, + "address": "0x202f1877e1db1120ca3e9a98c5d505e7f035c249", + "name": "ZUZ Protocol", + "symbol": "ZUZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14444/thumb/ZUZ_Icon2-100.png?1616115188" + }, + { + "chainId": 1, + "address": "0x072987d5b36ad8d45552aed98879a7101ccdd749", + "name": "BunnyVerse", + "symbol": "BNV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21846/thumb/Screenshot-2021-12-21-at-11-11-46.png?1640130263" + }, + { + "chainId": 1, + "address": "0x67776f14e5e9e7845e33fb0c2a3c709d259d01eb", + "name": "Era", + "symbol": "ERA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27718/thumb/ERA_logo.jpg?1665459246" + }, + { + "chainId": 1, + "address": "0xdec41db0c33f3f6f3cb615449c311ba22d418a8d", + "name": "Lobis", + "symbol": "LOBI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20813/thumb/0tOZIQ0B_400x400.jpg?1637718276" + }, + { + "chainId": 1, + "address": "0x193408ca0576b73156ed42a2ea7d6fd3f6507162", + "name": "Infinity Esaham", + "symbol": "INFS", + "decimals": 1, + "logoURI": "https://assets.coingecko.com/coins/images/10716/thumb/WBUD9cx.png?1582524776" + }, + { + "chainId": 1, + "address": "0x2e1e15c44ffe4df6a0cb7371cd00d5028e571d14", + "name": "Mettalex", + "symbol": "MTLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12730/thumb/nrEqFTEW_400x400.jpg?1602063980" + }, + { + "chainId": 1, + "address": "0xb67beb26ebeb0dceec354ae0942256d03c01771b", + "name": "DeStorage", + "symbol": "DS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15984/thumb/DS_LOG_Transparent_200x200.png?1622535280" + }, + { + "chainId": 1, + "address": "0xb668473944d2e25b6af6d46917eb0233dbac53ae", + "name": "Neton", + "symbol": "NTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25418/thumb/lqT0CJNj_400x400.jpg?1651735850" + }, + { + "chainId": 1, + "address": "0x4d0f56d728c5232ab07faa0bdcba23670a35451f", + "name": "Aggregated Finance", + "symbol": "AGFI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26332/thumb/79LDzdib_400x400_%281%29.jpg?1657269938" + }, + { + "chainId": 1, + "address": "0xeec2be5c91ae7f8a338e1e5f3b5de49d07afdc81", + "name": "Dopex", + "symbol": "DPX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16652/thumb/DPX_%281%29.png?1624598630" + }, + { + "chainId": 1, + "address": "0x2559813bbb508c4c79e9ccce4703bcb1f149edd7", + "name": "Hourglass", + "symbol": "WAIT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27516/thumb/Hourglass-Logo.png?1664353478" + }, + { + "chainId": 1, + "address": "0x55a290f08bb4cae8dcf1ea5635a3fcfd4da60456", + "name": "BITTO", + "symbol": "BITTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2814/thumb/BITTO.jpg?1547036986" + }, + { + "chainId": 1, + "address": "0x5978708d6cce1cc9640eed47422d64c91bbd5171", + "name": "LOLTOKEN", + "symbol": "LOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8551/thumb/logo100.png?1596534732" + }, + { + "chainId": 1, + "address": "0x17525e4f4af59fbc29551bc4ece6ab60ed49ce31", + "name": "PieDAO Yearn Ecosystem Pie", + "symbol": "YPIE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13572/thumb/YPIE.png?1610437730" + }, + { + "chainId": 1, + "address": "0xac3211a5025414af2866ff09c23fc18bc97e79b1", + "name": "Dovu", + "symbol": "DOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1072/thumb/Dovu_Earth_72x72_leaf_blue.png?1615259361" + }, + { + "chainId": 1, + "address": "0xbcd8756ea481608ea3dd5a555493305cf0a79640", + "name": "Paparazzi", + "symbol": "PAZZI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11558/thumb/jMJC4g9m_400x400.jpg?1591079702" + }, + { + "chainId": 1, + "address": "0x0ea20e7ffb006d4cfe84df2f72d8c7bd89247db0", + "name": "Aave AMM UniCRVWETH", + "symbol": "AAMMUNICRVWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17220/thumb/aAmmUniCRVWETH.png?1626879022" + }, + { + "chainId": 1, + "address": "0xf1b8762a7fa8c244e36f7234edf40cfae24394e3", + "name": "GoldFarm", + "symbol": "GOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16108/thumb/rVUV_photo_2021-06-03_13-37-31.png?1623020895" + }, + { + "chainId": 1, + "address": "0x605d26fbd5be761089281d5cec2ce86eea667109", + "name": "Digital Standard Unit", + "symbol": "DSU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17482/thumb/photo_2021-08-03_09-24-16.png?1627953917" + }, + { + "chainId": 1, + "address": "0x3f7aff0ef20aa2e646290dfa4e67611b2220c597", + "name": "Volt Inu OLD ", + "symbol": "VOLT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21832/thumb/nl250.png?1643191234" + }, + { + "chainId": 1, + "address": "0x73a9fb46e228628f8f9bb9004eca4f4f529d3998", + "name": "Wrapped LEO", + "symbol": "WLEO", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/12626/thumb/4XfO3w3.png?1601286769" + }, + { + "chainId": 1, + "address": "0x4aa41bc1649c9c3177ed16caaa11482295fc7441", + "name": "Xfit", + "symbol": "XFIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14904/thumb/xfit_logo.png?1618967174" + }, + { + "chainId": 1, + "address": "0xd98f75b1a3261dab9eed4956c93f33749027a964", + "name": "Share", + "symbol": "SHR", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/3609/thumb/74586729_2443914875881351_2785018663453851648_n.png?1574898410" + }, + { + "chainId": 1, + "address": "0xc67b12049c2d0cf6e476bc64c7f82fc6c63cffc5", + "name": "Globe Derivative Exchange", + "symbol": "GDT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15335/thumb/gdt.PNG?1620597146" + }, + { + "chainId": 1, + "address": "0x370adc71f67f581158dc56f539df5f399128ddf9", + "name": "Aave AMM UniMKRWETH", + "symbol": "AAMMUNIMKRWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17222/thumb/aAmmUniMKRWETH.png?1626880292" + }, + { + "chainId": 1, + "address": "0x01c0987e88f778df6640787226bc96354e1a9766", + "name": "UltrAlpha", + "symbol": "UAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9300/thumb/UltrAlpha.png?1565882277" + }, + { + "chainId": 1, + "address": "0xc7ff1e126cc81e816915ff48c940ed9d4e6d05d6", + "name": "IjasCoin", + "symbol": "IJC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14099/thumb/Ijascode-Flat-Logo-2-24-2021.png?1614304358" + }, + { + "chainId": 1, + "address": "0x5644bb2b594fcf6f74384d2ad26c68f02a47981c", + "name": "SuperMegaHyperDoge", + "symbol": "SMHDOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21217/thumb/alUgvzB7_400x400.jpg?1638670544" + }, + { + "chainId": 1, + "address": "0xcc6f15be8573cb8243c42d300565566d328213dd", + "name": "OWN Token", + "symbol": "OWN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10950/thumb/cropped-WhatsApp-Image-2020-04-04-at-9.04.01-PM.jpeg?1586305520" + }, + { + "chainId": 1, + "address": "0x369b77bbeeee50e6ea206dcf41ee670c47360055", + "name": "Kiki", + "symbol": "KIKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22289/thumb/A8oLUJW8_400x400.jpg?1641367572" + }, + { + "chainId": 1, + "address": "0x408e41876cccdc0f92210600ef50372656052a38", + "name": "REN", + "symbol": "REN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3139/thumb/REN.png?1589985807" + }, + { + "chainId": 1, + "address": "0xd15ecdcf5ea68e3995b2d0527a0ae0a3258302f8", + "name": "Machi X", + "symbol": "MCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11329/thumb/MachiX.png?1589926940" + }, + { + "chainId": 1, + "address": "0x8af078d5a3e4a18ff62e3aeed4b1c448ab90b304", + "name": "TouchCon", + "symbol": "TOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8003/thumb/touchcon.png?1629088447" + }, + { + "chainId": 1, + "address": "0x21f15966e07a10554c364b988e91dab01d32794a", + "name": "SmartMesh", + "symbol": "SMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1346/thumb/smartmesh.png?1548609531" + }, + { + "chainId": 1, + "address": "0xc4cb5793bd58bad06bf51fb37717b86b02cbe8a4", + "name": "PROXI DeFi", + "symbol": "CREDIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12212/thumb/_credit.png?1598235420" + }, + { + "chainId": 1, + "address": "0x1287c0509df9a475ef178471ab2132b9dfd312b3", + "name": "LADZ", + "symbol": "LADZ", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/13315/thumb/ladz_logo.jpg?1607408640" + }, + { + "chainId": 1, + "address": "0x6d2c508fc4a588a41713ff59212f85489291d244", + "name": "Bloomzed Loyalty Club Ticket", + "symbol": "BLCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10810/thumb/esRodCO5_400x400.jpg?1583906706" + }, + { + "chainId": 1, + "address": "0x4d8046b2f7986feb5a4b0781ebf5fa2d7a808617", + "name": "DogeZilla Token", + "symbol": "DOGEZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20511/thumb/dogezilla.png?1637807027" + }, + { + "chainId": 1, + "address": "0x7e9c15c43f0d6c4a12e6bdff7c7d55d0f80e3e23", + "name": "Astra DAO", + "symbol": "ASTRA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27255/thumb/astra200x200px_blue_%282%29.png?1663035884" + }, + { + "chainId": 1, + "address": "0x3209d14ff61766359e64aceff91877cec2ad968e", + "name": "CouponBay", + "symbol": "CUP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24696/thumb/logo_200.png?1648625906" + }, + { + "chainId": 1, + "address": "0x0316eb71485b0ab14103307bf65a021042c6d380", + "name": "Huobi BTC", + "symbol": "HBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12407/thumb/Unknown-5.png?1599624896" + }, + { + "chainId": 1, + "address": "0xeb58343b36c7528f23caae63a150240241310049", + "name": "Nimbus", + "symbol": "NBU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14517/thumb/EQMLlI52Dhm7DPe4QPt81MiqPTUa0X7YOZV9G1ki_OpZe6rtVUtmIn5XbQHeMHyuTkX4Y1qU-K8lAn4juL3KnVQLR7WeeJ_r6jI5nrjGgvt4DgMSAnuTrT15AREqbB0wUkosE8NVhjKpPUvvaALnpO0BtFUt4Bo9tsOTsfQDAEFrpH0uhVkEqJG_u09ehkX88hkYKJcm5RkvIgq.jpg?1616654587" + }, + { + "chainId": 1, + "address": "0x2c0da41c89adb5a1d4430e5761b9b400911426b0", + "name": "DAMA", + "symbol": "DAMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23636/thumb/img-token-dama.png?1644907682" + }, + { + "chainId": 1, + "address": "0x0168703872fa06741ecaa9dff7803168e83f7ae0", + "name": "Mirocana", + "symbol": "MIRO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1651/thumb/mirocana.jpg?1547035896" + }, + { + "chainId": 1, + "address": "0x2786f9c443f323f590de1881d7215db305ab846e", + "name": "Nukplan", + "symbol": "NKPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28182/thumb/logo_200x200.png?1668255855" + }, + { + "chainId": 1, + "address": "0x7b39917f9562c8bc83c7a6c2950ff571375d505d", + "name": "LeagueDAO Governance", + "symbol": "LEAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19130/thumb/leag_token_icon.png?1634523084" + }, + { + "chainId": 1, + "address": "0x2c5bcad9ade17428874855913def0a02d8be2324", + "name": "pSTAKE Staked ETH", + "symbol": "STKETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25798/thumb/Ethereum.png?1653921854" + }, + { + "chainId": 1, + "address": "0xa92c49c403386111c1629aee00936eed2a9e74a6", + "name": "Kollector", + "symbol": "KLTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19926/thumb/kbase_logo.jpg?1636302934" + }, + { + "chainId": 1, + "address": "0x4db2c02831c9ac305ff9311eb661f80f1df61e07", + "name": "oneICHI", + "symbol": "ONEICHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25908/thumb/74116843.png?1654585863" + }, + { + "chainId": 1, + "address": "0xe9f1d62c671efe99896492766c0b416bd3fb9e52", + "name": "XOYCoin", + "symbol": "XOY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26641/thumb/xoycoin_logo.png?1659347530" + }, + { + "chainId": 1, + "address": "0x8af22fbdefe01b4dc7960ec04ec73e8502f4a6b0", + "name": "Biokkoin", + "symbol": "BKKG", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13125/thumb/7F-imH-r_400x400.png?1605496322" + }, + { + "chainId": 1, + "address": "0x8e870d67f660d95d5be530380d0ec0bd388289e1", + "name": "Pax Dollar", + "symbol": "USDP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6013/thumb/Pax_Dollar.png?1629877204" + }, + { + "chainId": 1, + "address": "0xcae636167db2369bd746f2bcba79a6e8b0d4e000", + "name": "Education Assessment Cult", + "symbol": "EAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25466/thumb/eac.png?1651915165" + }, + { + "chainId": 1, + "address": "0x77132bb08b02a7a87732ec289efab45edf49884f", + "name": "Relic", + "symbol": "RELIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26424/thumb/EQiM831z_400x400.png?1657930563" + }, + { + "chainId": 1, + "address": "0xe64b47931f28f89cc7a0c6965ecf89eadb4975f5", + "name": "Ludos Protocol", + "symbol": "LUD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5118/thumb/Ludos_Protocol.jpg?1557216263" + }, + { + "chainId": 1, + "address": "0x9ac5c63ddcb93612e316ab31dfc8192bc8961988", + "name": "Adora", + "symbol": "ARA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17713/thumb/Adora-200px-200px_rostsy.png?1629083234" + }, + { + "chainId": 1, + "address": "0x47140a767a861f7a1f3b0dd22a2f463421c28814", + "name": "All me", + "symbol": "ME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5497/thumb/all.me-logo.jpg?1547041239" + }, + { + "chainId": 1, + "address": "0x1673a63aa0047294d75954226f3f2f98de77b16f", + "name": "GENES Chain", + "symbol": "GENES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8857/thumb/logo256_%281%29.png?1562205433" + }, + { + "chainId": 1, + "address": "0x3e9e371f8d2e9fca315fb0a747533ced8a3fcbcb", + "name": "BIXCPRO", + "symbol": "BIXCPRO", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/7893/thumb/download.jpg?1551429825" + }, + { + "chainId": 1, + "address": "0x1da4858ad385cc377165a298cc2ce3fce0c5fd31", + "name": "CloutContracts", + "symbol": "CCS", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/19072/thumb/200.png?1634829111" + }, + { + "chainId": 1, + "address": "0xf725f73caee250ae384ec38bb2c77c38ef2cccea", + "name": "Ape In Records", + "symbol": "AIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24194/thumb/gCZZdeR.jpeg?1646830675" + }, + { + "chainId": 1, + "address": "0x9d1089802ee608ba84c5c98211afe5f37f96b36c", + "name": "Fluid USDC", + "symbol": "FUSDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/28471/thumb/fUSDC-200x200.png?1671002126" + }, + { + "chainId": 1, + "address": "0x5cb3ce6d081fb00d5f6677d196f2d70010ea3f4a", + "name": "Busy", + "symbol": "BUSY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14966/thumb/busy.PNG?1619165503" + }, + { + "chainId": 1, + "address": "0x7a8ca2f815a260660158a38c34ca321a3605ecfe", + "name": "BIZZCOIN", + "symbol": "BIZZ", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10979/thumb/bizzcoin.PNG?1586766076" + }, + { + "chainId": 1, + "address": "0xe1005bfbbc9a17d5d844c7a4371cbf6b2b387380", + "name": "GRN Grid", + "symbol": "G", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26126/thumb/MQrn5TGl_400x400.jpg?1655954068" + }, + { + "chainId": 1, + "address": "0x8578530205cecbe5db83f7f29ecfeec860c297c2", + "name": "smARTOFGIVING", + "symbol": "AOG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6050/thumb/logo_%286%29.png?1547042007" + }, + { + "chainId": 1, + "address": "0x9e46a38f5daabe8683e10793b06749eef7d733d1", + "name": "PolySwarm", + "symbol": "NCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2843/thumb/ImcYCVfX_400x400.jpg?1628519767" + }, + { + "chainId": 1, + "address": "0x2509ee05b8df07ec75046e24bbf1cfcdb8b2a183", + "name": "Amaten", + "symbol": "AMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11010/thumb/0_%283%29.png?1587104344" + }, + { + "chainId": 1, + "address": "0x2f4eb100552ef93840d5adc30560e5513dfffacb", + "name": "Balancer Boosted Aave USDT", + "symbol": "BB-A-USDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25826/thumb/0x2bbf681cc4eb09218bee85ea2a5d3d13fa40fc0c.png?1654063979" + }, + { + "chainId": 1, + "address": "0x5d43b66da68706d39f6c97f7f1415615672b446b", + "name": "ROGin AI", + "symbol": "ROG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25922/thumb/20490.png?1654672163" + }, + { + "chainId": 1, + "address": "0x60ef10edff6d600cd91caeca04caed2a2e605fe5", + "name": "Mochi Inu", + "symbol": "MOCHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20164/thumb/4DileY_b_400x400.jpg?1636598711" + }, + { + "chainId": 1, + "address": "0xa64dfe8d86963151e6496bee513e366f6e42ed79", + "name": "Goku", + "symbol": "GOKU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17947/thumb/goku.png?1642919069" + }, + { + "chainId": 1, + "address": "0xaa843f65872a25d6e9552ea0b360fb1d5e333124", + "name": "Eco Value Coin", + "symbol": "EVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7868/thumb/temp_1524073947125.-325764774.png?1561602099" + }, + { + "chainId": 1, + "address": "0x4c25bdf026ea05f32713f00f73ca55857fbf6342", + "name": "Font", + "symbol": "FONT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14085/thumb/font.png?1614183855" + }, + { + "chainId": 1, + "address": "0x4b34c0cbeef271f895d339c5f76322d71a60782b", + "name": "Yearn Finance Management", + "symbol": "YEFIM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12836/thumb/jOVGT0Y.png?1602886889" + }, + { + "chainId": 1, + "address": "0x16484d73ac08d2355f466d448d2b79d2039f6ebb", + "name": "FortKnoxster", + "symbol": "FKX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5050/thumb/fkx.png?1644048298" + }, + { + "chainId": 1, + "address": "0x0f17bc9a994b87b5225cfb6a2cd4d667adb4f20b", + "name": "Jarvis Synthetic Euro", + "symbol": "JEUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15725/thumb/jEUR.png?1634046044" + }, + { + "chainId": 1, + "address": "0x491604c0fdf08347dd1fa4ee062a822a5dd06b5d", + "name": "Cartesi", + "symbol": "CTSI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11038/thumb/cartesi.png?1592288021" + }, + { + "chainId": 1, + "address": "0x6fe56c0bcdd471359019fcbc48863d6c3e9d4f41", + "name": "Props", + "symbol": "PROPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6735/thumb/photo-2017-10-10-03-32-02.png?1595168186" + }, + { + "chainId": 1, + "address": "0x8290333cef9e6d528dd5618fb97a76f268f3edd4", + "name": "Ankr", + "symbol": "ANKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4324/thumb/U85xTl2.png?1608111978" + }, + { + "chainId": 1, + "address": "0x3a4cab3dcfab144fe7eb2b5a3e288cc03dc07659", + "name": "OnGo", + "symbol": "FTG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20154/thumb/IMG-20220728-WA0004.jpg?1669792759" + }, + { + "chainId": 1, + "address": "0xaedf386b755465871ff874e3e37af5976e247064", + "name": "Fasttoken", + "symbol": "FTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28478/thumb/lightenicon_200x200.png?1671006114" + }, + { + "chainId": 1, + "address": "0xdf5e0e81dff6faf3a7e52ba697820c5e32d806a8", + "name": "LP yCurve", + "symbol": "YCURVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11858/thumb/yCrv.png?1595203628" + }, + { + "chainId": 1, + "address": "0x8752bf7ad53d25a4165b9370f2becc22dd8ae838", + "name": "BlockNoteX", + "symbol": "BNOX", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/11066/thumb/bnox-color-h256.png?1587777583" + }, + { + "chainId": 1, + "address": "0x3ea50b7ef6a7eaf7e966e2cb72b519c16557497c", + "name": "Rocket Bunny", + "symbol": "BUNNY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14350/thumb/n8TgW06A_400x400.jpg?1615514406" + }, + { + "chainId": 1, + "address": "0x36919a60a2b67b6d2329863093d180d23d5a0308", + "name": "Kusunoki Samurai", + "symbol": "KUSUNOKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24688/thumb/68747470733a2f2f7777772e6b7573756e6f6b6973616d757261692e636f6d2f696d616765732f6b7573756e6f6b692d30312e706e67.png?1648604014" + }, + { + "chainId": 1, + "address": "0xe5bf6790d138b154f1df3db8d245be46a5d05ee4", + "name": "Lyfe Land", + "symbol": "LLAND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14940/thumb/LLAND-Logo-200.png?1619083033" + }, + { + "chainId": 1, + "address": "0x77607588222e01bf892a29abab45796a2047fc7b", + "name": "Unagii ETH", + "symbol": "UETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14624/thumb/uETH.png?1617294107" + }, + { + "chainId": 1, + "address": "0xa829f97373069ee5d23175e4105df8fd49238be7", + "name": "Opennity", + "symbol": "OPNN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9358/thumb/53672059_554715805021197_5765693264996859904_n.jpg?1566526789" + }, + { + "chainId": 1, + "address": "0xe9d0331ad47148925c5009d33a428ee301c9d534", + "name": "HRDGCOIN", + "symbol": "HRDG", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/22769/thumb/hrdg_logo_200X200.png?1642576030" + }, + { + "chainId": 1, + "address": "0xe0b9a2c3e9f40cf74b2c7f591b2b0cca055c3112", + "name": "Genesis Shards", + "symbol": "GS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14784/thumb/gs.png?1618408218" + }, + { + "chainId": 1, + "address": "0x241ba672574a78a3a604cdd0a94429a73a84a324", + "name": "4New", + "symbol": "KWATT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4975/thumb/4new.png?1547040398" + }, + { + "chainId": 1, + "address": "0x627e2ee3dbda546e168eaaff25a2c5212e4a95a0", + "name": "Inverse Bitcoin Volatility", + "symbol": "IBVOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11057/thumb/download_%2810%29.png?1587642128" + }, + { + "chainId": 1, + "address": "0xde4ce5447ce0c67920a1371605a39187cb6847c8", + "name": "Deesse", + "symbol": "LOVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22524/thumb/GaqpKHEP_400x400.jpg?1641975550" + }, + { + "chainId": 1, + "address": "0x1d37986f252d0e349522ea6c3b98cb935495e63e", + "name": "ChartEx", + "symbol": "CHART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12523/thumb/chartex.png?1600499406" + }, + { + "chainId": 1, + "address": "0xb9e7f8568e08d5659f5d29c4997173d84cdf2607", + "name": "Swarm City", + "symbol": "SWT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/621/thumb/swarm-city.png?1548611426" + }, + { + "chainId": 1, + "address": "0xd2d6158683aee4cc838067727209a0aaf4359de3", + "name": "Bounty0x", + "symbol": "BNTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1444/thumb/bounty0x.png?1547562674" + }, + { + "chainId": 1, + "address": "0x47c1178f49140ecdbfbdf0ae2935cdb640d579f9", + "name": "Phantasma Energy", + "symbol": "KCAL", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/25447/thumb/Screenshot_from_2022-05-06_09-46-03.png?1651801573" + }, + { + "chainId": 1, + "address": "0x6f0f28ceee6ae686ee0f939375674c01b156365a", + "name": "Elena Protocol", + "symbol": "ELENA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15078/thumb/elena.png?1619648619" + }, + { + "chainId": 1, + "address": "0x48a58fdf91ab56b5700d853733b860b4cde08b26", + "name": "MetaMerce Token", + "symbol": "MMTKN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27467/thumb/MMTKNLogo.png?1664178229" + }, + { + "chainId": 1, + "address": "0x2336c10a1d3100343fa9911a2c57b77c333599a3", + "name": "tMATIC", + "symbol": "TMATIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26971/thumb/tenderMATIC.png?1661152567" + }, + { + "chainId": 1, + "address": "0x37c997b35c619c21323f3518b9357914e8b99525", + "name": "Unipilot", + "symbol": "PILOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17235/thumb/QmSjCnb74Q88o9gcTMMYNggj6BDkFEPukAZ5nWrhPaRxoW.png?1626923517" + }, + { + "chainId": 1, + "address": "0x604026696fdb3c6720ae3049c46d59ac604dea0a", + "name": "eXciting Japan Coin", + "symbol": "XJP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11963/thumb/XJP_LOGO.png?1596453963" + }, + { + "chainId": 1, + "address": "0x0f51bb10119727a7e5ea3538074fb341f56b09ad", + "name": "DAO Maker", + "symbol": "DAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13915/thumb/4.png?1612838831" + }, + { + "chainId": 1, + "address": "0x00000000000045166c45af0fc6e4cf31d9e14b9a", + "name": "TopBidder", + "symbol": "BID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14820/thumb/topbidder_logo_square_256.png?1618556813" + }, + { + "chainId": 1, + "address": "0xa8b12cc90abf65191532a12bb5394a714a46d358", + "name": "pBTC35A", + "symbol": "PBTC35A", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13653/thumb/pBTC35A.png?1610574940" + }, + { + "chainId": 1, + "address": "0xd90e69f67203ebe02c917b5128629e77b4cd92dc", + "name": "One Cash", + "symbol": "ONC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13529/thumb/onc_logo.png?1609406029" + }, + { + "chainId": 1, + "address": "0xf98ab0874b13a7fdc39d7295dedd49850a5d426b", + "name": "KIRA", + "symbol": "KIRA", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/28196/thumb/KIRA_CMC.png?1668334302" + }, + { + "chainId": 1, + "address": "0x104f3152d8ebfc3f679392977356962ff36566ac", + "name": "ChainPort", + "symbol": "PORTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24490/thumb/VE-tUL-q_400x400.png?1647855096" + }, + { + "chainId": 1, + "address": "0x8a34d707189fbfa46930abfde3d22abdc48ab73d", + "name": "Unkai", + "symbol": "UNKAI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27458/thumb/2022-09-24_005337-removebg-preview_%281%29.png?1664107395" + }, + { + "chainId": 1, + "address": "0x0ec78ed49c2d27b315d462d43b5bab94d2c79bf8", + "name": "Zero Tech", + "symbol": "ZERO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21530/thumb/UlyJW87D_400x400.jpg?1639384115" + }, + { + "chainId": 1, + "address": "0xf0dc76c22139ab22618ddfb498be1283254612b1", + "name": "Wrapped Star", + "symbol": "WSTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23972/thumb/wstr.png?1645870711" + }, + { + "chainId": 1, + "address": "0x2e6a8306286600e564c16aa0b7a93fced09d586a", + "name": "Protectors of the Realm", + "symbol": "WER1", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27805/thumb/WeR1logo200x200.png?1667293518" + }, + { + "chainId": 1, + "address": "0x4df812f6064def1e5e029f1ca858777cc98d2d81", + "name": "Xaurum", + "symbol": "XAUR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/461/thumb/xaurum.png?1548761197" + }, + { + "chainId": 1, + "address": "0x865ec58b06bf6305b886793aa20a2da31d034e68", + "name": "Mossland", + "symbol": "MOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2374/thumb/moc.png?1547036557" + }, + { + "chainId": 1, + "address": "0x2e2364966267b5d7d2ce6cd9a9b5bd19d9c7c6a9", + "name": "Voice", + "symbol": "VOICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12926/thumb/OjCQtdL.png?1614780024" + }, + { + "chainId": 1, + "address": "0xd8446236fa95b9b5f9fd0f8e7df1a944823c683d", + "name": "NEEO", + "symbol": "NEEO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26060/thumb/ZbD8a9pz_400x400.jpg?1655455842" + }, + { + "chainId": 1, + "address": "0x9b00e6e8d787b13756eb919786c9745054db64f9", + "name": "Sienna ERC 20 ", + "symbol": "WSIENNA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15420/thumb/sienna.jpeg?1620782072" + }, + { + "chainId": 1, + "address": "0xf7b098298f7c69fc14610bf71d5e02c60792894c", + "name": "Guppy", + "symbol": "GUP", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/683/thumb/matchpool.png?1547034437" + }, + { + "chainId": 1, + "address": "0x012e0e6342308b247f36ee500ecb14dc77a7a8c1", + "name": "Sukhavati Network", + "symbol": "SKT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17674/thumb/logo2.png?1628830203" + }, + { + "chainId": 1, + "address": "0x9250e33f8ae7b9fe02fb9af97a0c55b42a5ad9d8", + "name": "Cino Games", + "symbol": "CINO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24157/thumb/cino.png?1646575256" + }, + { + "chainId": 1, + "address": "0x594207c791afd06a8d087d84d99d1da53ccbd45f", + "name": "Buzzshow", + "symbol": "GLDY", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/2585/thumb/lLY2uKBE_400x400.jpg?1583447824" + }, + { + "chainId": 1, + "address": "0x426567f78e74577f8a6233b635970eb729631e05", + "name": "Staker", + "symbol": "STR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5122/thumb/staker-logo.png?1547040513" + }, + { + "chainId": 1, + "address": "0x7105e64bf67eca3ae9b123f0e5ca2b83b2ef2da0", + "name": "X7DAO", + "symbol": "X7DAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27709/thumb/X7DAO.png?1665314516" + }, + { + "chainId": 1, + "address": "0x69948cc03f478b95283f7dbf1ce764d0fc7ec54c", + "name": "Aave REN v1", + "symbol": "AREN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12483/thumb/aREN.png?1600188492" + }, + { + "chainId": 1, + "address": "0xc32cc5b70bee4bd54aa62b9aefb91346d18821c4", + "name": "Iteration Syndicate", + "symbol": "ITS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13297/thumb/1_LOssD4ENHv72I5e9PAsndA_%281%29.png?1607223580" + }, + { + "chainId": 1, + "address": "0x79650799e7899a802cb96c0bc33a6a8d4ce4936c", + "name": "AICHAIN", + "symbol": "AIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2525/thumb/aichain.png?1547036638" + }, + { + "chainId": 1, + "address": "0x39cacb4dcd57c0eb0c1446d9c16a26ed43718b44", + "name": "Boruto Inu", + "symbol": "BORUTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17926/thumb/Doge-Boruto-200x200.png?1629808980" + }, + { + "chainId": 1, + "address": "0x3affcca64c2a6f4e3b6bd9c64cd2c969efd1ecbe", + "name": "DSLA Protocol", + "symbol": "DSLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6694/thumb/dsla_logo-squared_200x200.png?1569571063" + }, + { + "chainId": 1, + "address": "0x5e031a5bc1c6b6e86a49e0b0f2e757800f1d0fff", + "name": "DaFIN", + "symbol": "DAF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17378/thumb/dafin.PNG?1627454158" + }, + { + "chainId": 1, + "address": "0x967da4048cd07ab37855c090aaf366e4ce1b9f48", + "name": "Ocean Protocol", + "symbol": "OCEAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3687/thumb/ocean-protocol-logo.jpg?1547038686" + }, + { + "chainId": 1, + "address": "0xcc0014ccb39f6e86b1be0f17859a783b6722722f", + "name": "Showcase", + "symbol": "SHO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15084/thumb/icon_%284%29.png?1619662298" + }, + { + "chainId": 1, + "address": "0x429876c4a6f89fb470e92456b8313879df98b63c", + "name": "Cryption Network", + "symbol": "CNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16171/thumb/Cryption_Logo_Gradient_White_Text.png?1623191284" + }, + { + "chainId": 1, + "address": "0x0e5f00da8aaef196a719d045db89b5da8f371b32", + "name": "Connectome", + "symbol": "CNTM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8528/thumb/200_200_CNTM-LOGO-07.png?1600751947" + }, + { + "chainId": 1, + "address": "0x3b7f247f21bf3a07088c2d3423f64233d4b069f7", + "name": "Dynamite", + "symbol": "DYNMT", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/8951/thumb/dynamite_logo.jpg?1598851224" + }, + { + "chainId": 1, + "address": "0xb4b9dc1c77bdbb135ea907fd5a08094d98883a35", + "name": "Sweatcoin Sweat Economy", + "symbol": "SWEAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25057/thumb/fhD9Xs16_400x400.jpg?1649947000" + }, + { + "chainId": 1, + "address": "0xb4bebd34f6daafd808f73de0d10235a92fbb6c3d", + "name": "Yearn Ecosystem Index", + "symbol": "YETI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13332/thumb/yeti.png?1607563342" + }, + { + "chainId": 1, + "address": "0x1e1eed62f8d82ecfd8230b8d283d5b5c1ba81b55", + "name": "Gamma", + "symbol": "GAMMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18642/thumb/6CVBUY5.png?1632753323" + }, + { + "chainId": 1, + "address": "0x1a57367c6194199e5d9aea1ce027431682dfb411", + "name": "MatrixETF", + "symbol": "MDF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18538/thumb/MDF.png?1632304949" + }, + { + "chainId": 1, + "address": "0x05bbe7240de66f6480c9aeda77c1376b13393f83", + "name": "Xeno", + "symbol": "XNO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13830/thumb/XNO_logo_200x200.png?1612168285" + }, + { + "chainId": 1, + "address": "0x2c33b28527a63cdf13c0b24ce4cf5bf9c9fb3bc6", + "name": "Schrodinger", + "symbol": "KITTYDINGER", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19649/thumb/kitty_dinger.png?1636332557" + }, + { + "chainId": 1, + "address": "0x3a810ff7211b40c4fa76205a14efe161615d0385", + "name": "AI Network", + "symbol": "AIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13211/thumb/AI_Network_Logo_200x200.png?1606205615" + }, + { + "chainId": 1, + "address": "0xd85ad783cc94bd04196a13dc042a3054a9b52210", + "name": "TribeOne", + "symbol": "HAKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16575/thumb/USqW1QX.png?1625577555" + }, + { + "chainId": 1, + "address": "0x7f0c8b125040f707441cad9e5ed8a8408673b455", + "name": "CSP DAO Network", + "symbol": "NEBO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13436/thumb/csp_dao.png?1608535699" + }, + { + "chainId": 1, + "address": "0x946551dd05c5abd7cc808927480225ce36d8c475", + "name": "One", + "symbol": "ONE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4960/thumb/Screenshot_39.png?1561103318" + }, + { + "chainId": 1, + "address": "0x76960dccd5a1fe799f7c29be9f19ceb4627aeb2f", + "name": "Red", + "symbol": "RED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4523/thumb/red.png?1548607994" + }, + { + "chainId": 1, + "address": "0xa98ed1fd277ead2c00d143cbe1465f59e65a0066", + "name": "Thx ", + "symbol": "THX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9134/thumb/dtUHCa05GdIeMwiuO1Vdhpxe8f3xbPP_lIwFrnw2ic800CB3fhlk2eOp8hAGg-EUwrCTHwcQQqv3N3ikf5qWOKmbJePX5iK333iXdIlVF4UyAHb7ZsCi8nYBqBCJ7KZ6BwYcdlbguRPth6YSDWL5EBDIJQGmmkWEb-qTX7rnYEqS-9crxEkQJujPBnCVUV1qz87RgHV9KOvWL5HW6twlwJ.jpg?1564611313" + }, + { + "chainId": 1, + "address": "0x1e4746dc744503b53b4a082cb3607b169a289090", + "name": "IPOR", + "symbol": "IPOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28373/thumb/IPOR-token-200x200.png?1670480793" + }, + { + "chainId": 1, + "address": "0xdb69c3f8977f78952303987e87153c1988cf65a9", + "name": "PugLife", + "symbol": "PUGL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16105/thumb/puglife.png?1625756103" + }, + { + "chainId": 1, + "address": "0xb41380174d0b06181513a5677b60200b93b5efb4", + "name": "Chainsquare", + "symbol": "CHS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14858/thumb/chainsquare.png?1618804636" + }, + { + "chainId": 1, + "address": "0x4a8f5f96d5436e43112c2fbc6a9f70da9e4e16d4", + "name": "Internxt", + "symbol": "INXT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/986/thumb/inxt.png?1639651885" + }, + { + "chainId": 1, + "address": "0x4cd0c43b0d53bc318cc5342b77eb6f124e47f526", + "name": "FreeRossDAO", + "symbol": "FREE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21648/thumb/free.jpg?1639639586" + }, + { + "chainId": 1, + "address": "0x43ab765ee05075d78ad8aa79dcb1978ca3079258", + "name": "POW", + "symbol": "POW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22333/thumb/16963.png?1641515902" + }, + { + "chainId": 1, + "address": "0x9f549ebfd4974cd4ed4a1550d40394b44a7382aa", + "name": "LinkCoin", + "symbol": "LKN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6098/thumb/vWhhedXQ.png?1547042094" + }, + { + "chainId": 1, + "address": "0x86b4dbe5d203e634a12364c0e428fa242a3fba98", + "name": "poundtoken", + "symbol": "GBPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26591/thumb/gbpt.jpeg?1658958061" + }, + { + "chainId": 1, + "address": "0xc45dbdf28844fdb1482c502897d433ac08d6ccd0", + "name": "BitNautic", + "symbol": "BTNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2875/thumb/Logobit.jpg?1547037044" + }, + { + "chainId": 1, + "address": "0xf04a8ac553fcedb5ba99a64799155826c136b0be", + "name": "Flixxo", + "symbol": "FLIXX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1261/thumb/flixxo.png?1547483809" + }, + { + "chainId": 1, + "address": "0xbe1dbe6741fb988fb571ab1e28cffb36e3c62629", + "name": "Massive Protocol", + "symbol": "MAV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25134/thumb/logo.png?1650431353" + }, + { + "chainId": 1, + "address": "0xa499648fd0e80fd911972bbeb069e4c20e68bf22", + "name": "Jenny DAO V1", + "symbol": "UJENNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15453/thumb/ujenny.png?1620870247" + }, + { + "chainId": 1, + "address": "0x348b7f3106b5da47405332534d06069ff9ce4d1b", + "name": "Elongate Deluxe", + "symbol": "ELONGD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15487/thumb/tT2g66pd.jpg?1623764695" + }, + { + "chainId": 1, + "address": "0x744dc59f30ac1992b28564287970441441def136", + "name": "The Real Tsygan", + "symbol": "TSYGAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26812/thumb/qscBke9-_400x400.jpg?1660273459" + }, + { + "chainId": 1, + "address": "0x925f2c11b99c1a4c46606898ee91ed3d450cfeda", + "name": "Chow Chow Finance", + "symbol": "CHOW", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14275/thumb/chow-logo.png?1620787242" + }, + { + "chainId": 1, + "address": "0xeda8b016efa8b1161208cf041cd86972eee0f31e", + "name": "IHT Real Estate Protocol", + "symbol": "IHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3158/thumb/iht-real-estate-protocol.png?1547744404" + }, + { + "chainId": 1, + "address": "0xe6f1966d04cfcb9cd1b1dc4e8256d8b501b11cba", + "name": "SafeEarth", + "symbol": "SAFEEARTH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15449/thumb/SafeEarthLogo2000.png?1620833647" + }, + { + "chainId": 1, + "address": "0x410e7696df8be2a123df2cf88808c6ddab2ae2bf", + "name": "Gr33n", + "symbol": "BUILD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26932/thumb/Screen-Shot-2022-08-18-at-12-15-03-PM_%281%29.png?1660887525" + }, + { + "chainId": 1, + "address": "0x5eb87caa0105a63aa87a36c7bd2573bd13e84fae", + "name": "Blockchain Quotations Index", + "symbol": "BQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5814/thumb/blockchain-quotations-index-token.png?1547351058" + }, + { + "chainId": 1, + "address": "0xb8fa12f8409da31a4fc43d15c4c78c33d8213b9b", + "name": "CaliCoin", + "symbol": "CALI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14998/thumb/cropped-Logo-transparent-background-1.png?1619392357" + }, + { + "chainId": 1, + "address": "0x8c4e7f814d40f8929f9112c5d09016f923d34472", + "name": "XCELTOKEN PLUS", + "symbol": "XLAB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8508/thumb/CXQJPNyO_400x400.jpg?1559030200" + }, + { + "chainId": 1, + "address": "0xc2544a32872a91f4a553b404c6950e89de901fdb", + "name": "Frax Price Index Share", + "symbol": "FPIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24944/thumb/fpis.png?1649485832" + }, + { + "chainId": 1, + "address": "0xf14922001a2fb8541a433905437ae954419c2439", + "name": "Direct Insurance", + "symbol": "DIT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4220/thumb/Direct_Insurance_Token.jpg?1547039537" + }, + { + "chainId": 1, + "address": "0xac00797df10e825589d8b53e715393be4e617459", + "name": "Bubble Network", + "symbol": "BBL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13443/thumb/bubble_network_logo.png?1608612666" + }, + { + "chainId": 1, + "address": "0x118b552725e1892137740cb4d29390d952709639", + "name": "Nyx", + "symbol": "NYXT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22174/thumb/NYX-logo-medium-size.png?1641174126" + }, + { + "chainId": 1, + "address": "0x1af2eaeaf2b1d9dda800861268e6bbb3995a6c3b", + "name": "1eco", + "symbol": "1ECO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22118/thumb/mgrOT_dx_400x400.png?1640847402" + }, + { + "chainId": 1, + "address": "0x1a23a6bfbadb59fa563008c0fb7cf96dfcf34ea1", + "name": "CoFiX", + "symbol": "COFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12781/thumb/dnPnSkfa_400x400.png?1602885321" + }, + { + "chainId": 1, + "address": "0xd2adc1c84443ad06f0017adca346bd9b6fc52cab", + "name": "dFund", + "symbol": "DFND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15286/thumb/1zbdX36.png?1620355973" + }, + { + "chainId": 1, + "address": "0x883a158c9b28f8d626acfcfbe1028f49e70c9d75", + "name": "CNG Casino", + "symbol": "CNG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11573/thumb/cng_casino.png?1591230675" + }, + { + "chainId": 1, + "address": "0x23581767a106ae21c074b2276d25e5c3e136a68b", + "name": "Moonbirds NFT Index by MEXC", + "symbol": "NMOON", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/25209/thumb/8nZJL9eQ_400x400_%281%29.jpg?1650788143" + }, + { + "chainId": 1, + "address": "0x260d5f9688353af138d35ece6f0cd9c80ef982dd", + "name": "Shinuri", + "symbol": "SHINURI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26640/thumb/CG.png?1659347370" + }, + { + "chainId": 1, + "address": "0xc4199fb6ffdb30a829614beca030f9042f1c3992", + "name": "snglsDAO Governance", + "symbol": "SGT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11823/thumb/SGT-icon.png?1594681863" + }, + { + "chainId": 1, + "address": "0x2dd1b9410c73e16b60240e529e38e30425f00d4e", + "name": "Kay Pacha", + "symbol": "PACHA", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/27194/thumb/0_Lzf-8HxwOnPjYWi-.jpeg?1662539360" + }, + { + "chainId": 1, + "address": "0x34f0915a5f15a66eba86f6a58be1a471fb7836a7", + "name": "PulseDogecoin", + "symbol": "PLSD", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/25327/thumb/token-icon-200x200.png?1651234941" + }, + { + "chainId": 1, + "address": "0xd337382da15d12bb6e56498e91df64f86c8f1ea8", + "name": "Aelysir", + "symbol": "AEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12955/thumb/ael_logo.png?1603794538" + }, + { + "chainId": 1, + "address": "0xdc98c5543f3004debfaad8966ec403093d0aa4a8", + "name": "Etherrock 72", + "symbol": "PEBBLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17963/thumb/Screen-Shot-2021-08-25-at-8-42-22-PM.png?1629943788" + }, + { + "chainId": 1, + "address": "0x5c761c1a21637362374204000e383204d347064c", + "name": "Sewer Rat Social Club CHIZ Token", + "symbol": "CHIZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19147/thumb/ZXb2HoUG_400x400.jpg?1634534839" + }, + { + "chainId": 1, + "address": "0x40897c872214303b6f479a37e549ee1516b264a2", + "name": "FLETA", + "symbol": "FLETA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7865/thumb/Fleta_new_logo_%282%29.png?1623520180" + }, + { + "chainId": 1, + "address": "0xedd8da5c20eb014e550008df3304213dde5e29f0", + "name": "Mars Network", + "symbol": "MARS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12828/thumb/Mars-logo-2.jpg?1602832489" + }, + { + "chainId": 1, + "address": "0x5dc74029509752f4ed9a609c2bb52216275e4c1d", + "name": "Game City", + "symbol": "GMCI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7121/thumb/gamecity.jpg?1612234592" + }, + { + "chainId": 1, + "address": "0x72955ecff76e48f2c8abcce11d54e5734d6f3657", + "name": "TrustVerse", + "symbol": "TRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8793/thumb/trv_256px.png?1623928469" + }, + { + "chainId": 1, + "address": "0x8d2bffcbb19ff14a698c424fbcdcfd17aab9b905", + "name": "Unicly CryptoPunks Collection", + "symbol": "UPUNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14905/thumb/cryptopunk7804.png?1618978888" + }, + { + "chainId": 1, + "address": "0x3b9e094d56103611f0acefdab43182347ba60df4", + "name": "PANTHEON X", + "symbol": "XPN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8297/thumb/Hr9wHItp_400x400.jpg?1557307478" + }, + { + "chainId": 1, + "address": "0x0954906da0bf32d5479e25f46056d22f08464cab", + "name": "Index Cooperative", + "symbol": "INDEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12729/thumb/index.png?1634894321" + }, + { + "chainId": 1, + "address": "0x19e2a43fbbc643c3b2d9667d858d49cad17bc2b5", + "name": "BNS", + "symbol": "BNS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/25150/thumb/bitbns_logo.png?1650450366" + }, + { + "chainId": 1, + "address": "0xfe4beb9217cddf2422d4bd65449b76d807b30fe1", + "name": "White Ethereum", + "symbol": "WHITE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26667/thumb/IMG_2923.PNG?1659500526" + }, + { + "chainId": 1, + "address": "0xc77d7e0dd7b2a01b990e866feb21d031f1418c2e", + "name": "Littlesesame", + "symbol": "LSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8893/thumb/5yIumMGs_400x400.png?1562579316" + }, + { + "chainId": 1, + "address": "0xb16d3ed603d62b125c6bd45519eda40829549489", + "name": "Insureum", + "symbol": "ISR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4888/thumb/insureum.png?1547974141" + }, + { + "chainId": 1, + "address": "0x35b08722aa26be119c1608029ccbc976ac5c1082", + "name": "Eminer", + "symbol": "EM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9155/thumb/KDbQPKIu_400x400.png?1564735775" + }, + { + "chainId": 1, + "address": "0xa1a36d3537bbe375cc9694795f663ddc8d516db9", + "name": "Polinate", + "symbol": "POLI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18096/thumb/Polinate_Games___Guilds_Elements-05.png?1648806645" + }, + { + "chainId": 1, + "address": "0xbf9e72eeb5adb8b558334c8672950b7a379d4266", + "name": "CubToken", + "symbol": "CUBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26197/thumb/photo-2022-04-20-13-35-28.jpg?1656471496" + }, + { + "chainId": 1, + "address": "0x9b8e9d523d1d6bc8eb209301c82c7d64d10b219e", + "name": "The Plant Dao", + "symbol": "SPROUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22455/thumb/56z0x6j.png?1641867803" + }, + { + "chainId": 1, + "address": "0xd80776bbf68cde466900a7214c772a7d179c420f", + "name": "Etherean Socks", + "symbol": "ETH2SOCKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17714/thumb/Q4NQZWp.png?1629083998" + }, + { + "chainId": 1, + "address": "0x797de1dc0b9faf5e25c1f7efe8df9599138fa09d", + "name": "Genesis Pool", + "symbol": "GPOOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18122/thumb/GP_BRAND_GREEN_Main_Icon_.png?1630562175" + }, + { + "chainId": 1, + "address": "0xc691bc298a304d591ad9b352c7a8d216de9f2ced", + "name": "Polaris Share", + "symbol": "POLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13817/thumb/tHQrxdYQ_400x400.png?1612051098" + }, + { + "chainId": 1, + "address": "0x9303eabc860a743aabcc3a1629014cabcc3f8d36", + "name": "Aave AMM UniDAIWETH", + "symbol": "AAMMUNIDAIWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17230/thumb/aAmmUniDAIWETH.png?1626920804" + }, + { + "chainId": 1, + "address": "0xe3a64a3c4216b83255b53ec7ea078b13f21a7dad", + "name": "DeFi Gold", + "symbol": "DFGL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12883/thumb/defi_gold.jpg?1603281766" + }, + { + "chainId": 1, + "address": "0xf85feea2fdd81d51177f6b8f35f0e6734ce45f5f", + "name": "CyberMiles", + "symbol": "CMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1300/thumb/cybermiles.png?1547035327" + }, + { + "chainId": 1, + "address": "0x3cf19ba410fa07e20854e8520227f756c8afd655", + "name": "ShibaTsuka", + "symbol": "STSUKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27495/thumb/tsuka200.png?1664269591" + }, + { + "chainId": 1, + "address": "0x42b4df7e402a71eae743c6c5410ce3bbb63aef22", + "name": "HDPUNK Vault NFTX ", + "symbol": "HDPUNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17069/thumb/HDPunks.png?1626151243" + }, + { + "chainId": 1, + "address": "0x89509aa1d14a8e1e5364ec4c3b041213bcdbe08d", + "name": "ZURRENCY", + "symbol": "ZURR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22240/thumb/logo.png?1641274307" + }, + { + "chainId": 1, + "address": "0x49b4f92431c5b8cf260f983c4d3ed28e1fd0b991", + "name": "JoJos Adventure", + "symbol": "JOJO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27369/thumb/jojo.png?1663722472" + }, + { + "chainId": 1, + "address": "0xfb444c1f2b718ddfc385cb8fd9f2d1d776b24668", + "name": "Elamachain", + "symbol": "ELAMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5650/thumb/Elamachain.png?1584505477" + }, + { + "chainId": 1, + "address": "0x0bf0d26a527384bcc4072a6e2bca3fc79e49fa2d", + "name": "Mytrade", + "symbol": "MYT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24134/thumb/transparent_logo.png?1646543530" + }, + { + "chainId": 1, + "address": "0x9f91d9f9070b0478abb5a9918c79b5dd533f672c", + "name": "Centurion Inu", + "symbol": "CENT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18493/thumb/cent.png?1632207211" + }, + { + "chainId": 1, + "address": "0xcafe27178308351a12fffffdeb161d9d730da082", + "name": "HotDollars", + "symbol": "HDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8505/thumb/pvGh4E0b_400x400.jpg?1559026304" + }, + { + "chainId": 1, + "address": "0x3402e15b3ea0f1aec2679c4be4c6d051cef93953", + "name": "QAO", + "symbol": "127760", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17159/thumb/qao.PNG?1626672944" + }, + { + "chainId": 1, + "address": "0x67c597624b17b16fb77959217360b7cd18284253", + "name": "Benchmark Protocol", + "symbol": "MARK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13212/thumb/benchmark_protocol.jpg?1606267583" + }, + { + "chainId": 1, + "address": "0x1426cc6d52d1b14e2b3b1cb04d57ea42b39c4c7c", + "name": "Jomon Shiba", + "symbol": "JSHIBA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15395/thumb/Jomon.png?1622960557" + }, + { + "chainId": 1, + "address": "0x30c084890fc07d78f3499ffc818b3225bc8812ea", + "name": "PUNKS Comic", + "symbol": "PUNKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22337/thumb/PunksIcon_Small.png?1641520641" + }, + { + "chainId": 1, + "address": "0x8315472bae77f9a2b856a67eb0796480aafcd51c", + "name": "MMAON", + "symbol": "MMAON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14645/thumb/MMAON.png?1618295603" + }, + { + "chainId": 1, + "address": "0xc0f1728d9513efc316d0e93a0758c992f88b0809", + "name": "SWTCoin", + "symbol": "SWAT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5985/thumb/swtcoin.jpg?1547041927" + }, + { + "chainId": 1, + "address": "0x30dcba0405004cf124045793e1933c798af9e66a", + "name": "Yieldification", + "symbol": "YDF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26699/thumb/logo.png?1659609811" + }, + { + "chainId": 1, + "address": "0xd32641191578ea9b208125ddd4ec5e7b84fcab4c", + "name": "MDsquare", + "symbol": "TMED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8558/thumb/bAdnHTWUIl4rFB4EfbH2L50BW7xi2T9ubci7v6xfYDipXkrG8Wb4LS8g6eAiMsSKqLJfV-FjH5TrYALqACw4MM2A9NfK_L6Ujnddhw1uEgL0hmVQnY96xZeL0C4kkFRJalreK9wUBzjZ4pRhZLdQf9h1drSTF7NE9moAdQ7KtuOvJqommn_q-TjQpF8GUB7J2Ejs7zIvhXXsUHGI1.jpg?1559198882" + }, + { + "chainId": 1, + "address": "0x329cf160f30d21006bcd24b67eade561e54cde4c", + "name": "CareCoin", + "symbol": "CARE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28378/thumb/46FD299C-3DA4-43E6-A6A2-27F492FC7E4D.jpeg?1669971342" + }, + { + "chainId": 1, + "address": "0x9c32185b81766a051e08de671207b34466dd1021", + "name": "BTC Proxy", + "symbol": "BTCPX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/22630/thumb/MB1aYO7T_400x400.jpg?1642342656" + }, + { + "chainId": 1, + "address": "0x4463e6a3ded0dbe3f6e15bc8420dfc55e5fea830", + "name": "TXA", + "symbol": "TXA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17746/thumb/jwjcN5Kx_400x400.jpg?1646381259" + }, + { + "chainId": 1, + "address": "0xb683d83a532e2cb7dfa5275eed3698436371cc9f", + "name": "BTU Protocol", + "symbol": "BTU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3697/thumb/btuprotocol.jpeg?1549597021" + }, + { + "chainId": 1, + "address": "0xd7f5cabdf696d7d1bf384d7688926a4bdb092c67", + "name": "DRC Mobility", + "symbol": "DRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13457/thumb/drc_symbol.png?1608759323" + }, + { + "chainId": 1, + "address": "0x38b7bf4eecf3eb530b1529c9401fc37d2a71a912", + "name": "ClayStack Staked MATIC", + "symbol": "CSMATIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28352/thumb/csMatic.png?1669771887" + }, + { + "chainId": 1, + "address": "0x19de6b897ed14a376dda0fe53a5420d2ac828a28", + "name": "Bitget Token", + "symbol": "BGB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11610/thumb/photo_2022-01-24_14-08-03.jpg?1643019457" + }, + { + "chainId": 1, + "address": "0x6aeb95f06cda84ca345c2de0f3b7f96923a44f4c", + "name": "Rentberry", + "symbol": "BERRY", + "decimals": 14, + "logoURI": "https://assets.coingecko.com/coins/images/1787/thumb/rentberry.png?1548608046" + }, + { + "chainId": 1, + "address": "0xd1b624f07a4d9b3e3746e33cb58f42df079b5444", + "name": "NKCL Classic", + "symbol": "NKCLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17893/thumb/w02Nksm-.png?1629718144" + }, + { + "chainId": 1, + "address": "0xd8e3fb3b08eba982f2754988d70d57edc0055ae6", + "name": "Zoracles", + "symbol": "ZORA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13255/thumb/zora.png?1606747018" + }, + { + "chainId": 1, + "address": "0xd47bdf574b4f76210ed503e0efe81b58aa061f3d", + "name": "TRVL", + "symbol": "TRVL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20911/thumb/trvl.jpeg?1649390006" + }, + { + "chainId": 1, + "address": "0x887168120cb89fb06f3e74dc4af20d67df0977f6", + "name": "Sekuritance", + "symbol": "SKRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15495/thumb/skrt.png?1621053881" + }, + { + "chainId": 1, + "address": "0xda23d301761e4e2bf474951f978f6dfb6f3c9f14", + "name": "Tsuki Inu", + "symbol": "TKINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15681/thumb/tkinu.png?1621508357" + }, + { + "chainId": 1, + "address": "0x8a40c222996f9f3431f63bf80244c36822060f12", + "name": "FINXFLO", + "symbol": "FXF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13916/thumb/raVh1Iw.png?1618978607" + }, + { + "chainId": 1, + "address": "0xb04dfdb8271ed2d5e13858562c44a77d3ceb9e57", + "name": "BuildUp", + "symbol": "BUP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13206/thumb/BUP_-_LOGO.png?1606199462" + }, + { + "chainId": 1, + "address": "0xc36b4311b21fc0c2ead46f1ea6ce97c9c4d98d3d", + "name": "Creaticles", + "symbol": "CRE8", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21115/thumb/logo-v3-small.png?1638339957" + }, + { + "chainId": 1, + "address": "0x82698aecc9e28e9bb27608bd52cf57f704bd1b83", + "name": "Balancer Boosted Aave USDC", + "symbol": "BB-A-USDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25780/thumb/bb-a-usdc.png?1653735108" + }, + { + "chainId": 1, + "address": "0xeff3f1b9400d6d0f1e8805bdde592f61535f5ecd", + "name": "Squawk OLD ", + "symbol": "SQUAWK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25087/thumb/soo.png?1650534077" + }, + { + "chainId": 1, + "address": "0xc5fb36dd2fb59d3b98deff88425a3f425ee469ed", + "name": "Dejitaru Tsuka", + "symbol": "TSUKA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26405/thumb/Tsuka_200x200.png?1657923568" + }, + { + "chainId": 1, + "address": "0x25b6325f5bb1c1e03cfbc3e53f470e1f1ca022e3", + "name": "Link Machine Learning", + "symbol": "LML", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7238/thumb/LML.png?1626237501" + }, + { + "chainId": 1, + "address": "0xd5147bc8e386d91cc5dbe72099dac6c9b99276f5", + "name": "renFIL", + "symbol": "RENFIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13375/thumb/Filecoin.jpg?1628072923" + }, + { + "chainId": 1, + "address": "0xbb97e381f1d1e94ffa2a5844f6875e6146981009", + "name": "WiBX", + "symbol": "WBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11009/thumb/wibx_new_logo.png?1632122685" + }, + { + "chainId": 1, + "address": "0x26487ec318b0138dcf6cd1f43ee68927756dbc1d", + "name": "Futura", + "symbol": "FUTURA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26802/thumb/62f22c02295fa13e56e5e7c9_futura-logo.png?1660205551" + }, + { + "chainId": 1, + "address": "0x32e6c34cd57087abbd59b5a4aecc4cb495924356", + "name": "BitBase Token", + "symbol": "BTBS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17414/thumb/btbs.PNG?1627596633" + }, + { + "chainId": 1, + "address": "0x5d2c6545d16e3f927a25b4567e39e2cf5076bef4", + "name": "Kappa", + "symbol": "KAPPA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18643/thumb/Wp3ALed.png?1632753579" + }, + { + "chainId": 1, + "address": "0xa130e3a33a4d84b04c3918c4e5762223ae252f80", + "name": "Swash", + "symbol": "SWASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18774/thumb/swash.png?1634089759" + }, + { + "chainId": 1, + "address": "0x9ed8e7c9604790f7ec589f99b94361d8aab64e5e", + "name": "Unistake", + "symbol": "UNISTAKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12813/thumb/unistake.png?1612346684" + }, + { + "chainId": 1, + "address": "0x8167d3b1024cb51a2dd1b4d889ddf7023420796a", + "name": "Noku", + "symbol": "NOKU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1577/thumb/Noku_Logo_round_coingeko.png?1643171688" + }, + { + "chainId": 1, + "address": "0x86d1d12523b65203851c571fcc029bf90903fb6d", + "name": "Bintex Futures", + "symbol": "BNTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12117/thumb/Bintexfutures_Icon_Logo.png?1597272672" + }, + { + "chainId": 1, + "address": "0x3656bd0f3f07623bb7f429b390d208f894e44ece", + "name": "INFLIV", + "symbol": "IFV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5279/thumb/INFLIV_LOGO_PNG.png?1550657927" + }, + { + "chainId": 1, + "address": "0x7d8daff6d70cead12c6f077048552cf89130a2b1", + "name": "ARCS", + "symbol": "ARX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10068/thumb/arcs.png?1575426741" + }, + { + "chainId": 1, + "address": "0x9dfad1b7102d46b1b197b90095b5c4e9f5845bba", + "name": "Botto", + "symbol": "BOTTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18892/thumb/bottos_logo.jpg?1633791571" + }, + { + "chainId": 1, + "address": "0xa5ef74068d04ba0809b7379dd76af5ce34ab7c57", + "name": "LunaChow", + "symbol": "LUCHOW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18805/thumb/J-MwYfhD_400x400.jpg?1633475157" + }, + { + "chainId": 1, + "address": "0xaf5f584d79701d5bdc9ca045e66ae130b67a68ad", + "name": "CryBet", + "symbol": "CBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10973/thumb/d4zbv0h.jpg?1586743861" + }, + { + "chainId": 1, + "address": "0x94e9eb8b5ab9fd6b9ea3169d55ffade62a01702e", + "name": "BreederDAO", + "symbol": "BREED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25203/thumb/BreederDAO-Breed_Token-FINAL.png?1650638916" + }, + { + "chainId": 1, + "address": "0x8fb6c8a44a4e23fd1f5a936818b39083b4cdc865", + "name": "BitOnyx", + "symbol": "BTNYX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13684/thumb/token-logo-200px.png?1610860892" + }, + { + "chainId": 1, + "address": "0xa3ad8c7ab6b731045b5b16e3fdf77975c71abe79", + "name": "Dinerobet", + "symbol": "DINERO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28248/thumb/CABA1DE1-2CB1-46D3-97BC-20305EA67FBB.png?1668656923" + }, + { + "chainId": 1, + "address": "0x794baab6b878467f93ef17e2f2851ce04e3e34c8", + "name": "YIN Finance", + "symbol": "YIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18272/thumb/e37387ae6ee756fd.jpg?1631176921" + }, + { + "chainId": 1, + "address": "0xc05a4ed46ef5b0678d56fff5a877b4b6b32077bb", + "name": "Qfora", + "symbol": "QUROZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25827/thumb/20386.png?1654064350" + }, + { + "chainId": 1, + "address": "0xe50365f5d679cb98a1dd62d6f6e58e59321bcddf", + "name": "LA", + "symbol": "LA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1051/thumb/LA_token.png?1605772040" + }, + { + "chainId": 1, + "address": "0x68909e586eeac8f47315e84b4c9788dd54ef65bb", + "name": "EvenCoin", + "symbol": "EVN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4634/thumb/evencoin.png?1548125647" + }, + { + "chainId": 1, + "address": "0xa4cb3ef5f41a4d89d6fced22ea8a1c57957629aa", + "name": "Meta Ruffy", + "symbol": "MR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27831/thumb/1tRmvYZ8_400x400.jpeg?1665993865" + }, + { + "chainId": 1, + "address": "0xe7ae6d0c56cacaf007b7e4d312f9af686a9e9a04", + "name": "Vabble", + "symbol": "VAB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17508/thumb/vabble_tplogo_200_x_200.png?1628508875" + }, + { + "chainId": 1, + "address": "0xb840d10d840ef47c233fec1fd040f5b145a6dfa5", + "name": "STREETH", + "symbol": "STREETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24954/thumb/streeth.png?1649507723" + }, + { + "chainId": 1, + "address": "0x2167fb82309cf76513e83b25123f8b0559d6b48f", + "name": "CoinLion", + "symbol": "LION", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1917/thumb/Coinlion_Brandmark_Color.png?1620706193" + }, + { + "chainId": 1, + "address": "0xf5238462e7235c7b62811567e63dd17d12c2eaa0", + "name": "CACHE Gold", + "symbol": "CGT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11601/thumb/cache-gold-icon-200x200.png?1591755874" + }, + { + "chainId": 1, + "address": "0xff743a38efcf6f46fc0768b46a5bdc264f7e92b3", + "name": "AMDG", + "symbol": "AMDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24545/thumb/amdg-logo.png?1648127822" + }, + { + "chainId": 1, + "address": "0x50ec35d1e18d439f02fa895746fc3e1bef311780", + "name": "Epanus", + "symbol": "EPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12295/thumb/SBqy8NapjZHtkIb4gkQrAXfxFI-j5G4mvfTxCVb2b1HuNGVv0m_6JTq4Ika8BOSHgbWBm0zKSH1dSohftNOaMI00Nb9hW_q5wnMoMi78BIbqTmf810zAHJPpXlFuMhZJ1Q1pUIjyKhb476mFwn5fys_EIF_26GhEE_n9TgAuyMI71hnYDCguzD-ZA7SsMoq.jpg?1598924999" + }, + { + "chainId": 1, + "address": "0xa9639160481b625ba43677be753e0a70bf58c647", + "name": "RBXSamurai", + "symbol": "RBXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22342/thumb/rbxs.jpg?1641536586" + }, + { + "chainId": 1, + "address": "0xf5bb30ebc95dca53e3320eb05d3d1bcab806b9bf", + "name": "Rizespor Token", + "symbol": "RIZE", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24027/thumb/mqQwSHB__400x400.jpg?1646113446" + }, + { + "chainId": 1, + "address": "0x7d14b842630cbc2530cb288109e5719e0c4d67d7", + "name": "Innovation Blockchain Payment", + "symbol": "IBP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12903/thumb/ibp.?1603347704" + }, + { + "chainId": 1, + "address": "0xbd668ec47e10d3bf23b1d68139e545162a0dfcfa", + "name": "GranX Chain", + "symbol": "GRANX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18658/thumb/granx-002.png?1632812430" + }, + { + "chainId": 1, + "address": "0x24ec2ca132abf8f6f8a6e24a1b97943e31f256a7", + "name": "dotmoovs", + "symbol": "MOOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15817/thumb/dotmoovs-symbol-gradient.png?1635332626" + }, + { + "chainId": 1, + "address": "0xb5c578947de0fd71303f71f2c3d41767438bd0de", + "name": "DeHorizon", + "symbol": "DEVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21373/thumb/A3RjDqet_400x400.jpg?1639031847" + }, + { + "chainId": 1, + "address": "0xfc1e690f61efd961294b3e1ce3313fbd8aa4f85d", + "name": "Aave DAI v1", + "symbol": "ADAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10843/thumb/aDAI.png?1584698791" + }, + { + "chainId": 1, + "address": "0xfbeea1c75e4c4465cb2fccc9c6d6afe984558e20", + "name": "DuckDaoDime", + "symbol": "DDIM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12146/thumb/token_DDIM-01.png?1606982032" + }, + { + "chainId": 1, + "address": "0x95efd1fe6099f65a7ed524def487483221094947", + "name": "CryptoBonusMiles", + "symbol": "CBM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9302/thumb/CryptoBonusMiles.png?1565865043" + }, + { + "chainId": 1, + "address": "0x25b539b1c179fbe2af92abdfdc7e152cbc97addc", + "name": "Incooom Genesis", + "symbol": "COOOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18988/thumb/cooom.png?1634112193" + }, + { + "chainId": 1, + "address": "0xfeb2d480019bc605a2ce20903a90db3f554f1e1c", + "name": "Izanagi", + "symbol": "NAGI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24129/thumb/photo_2022-03-04_23-02-56.jpg?1646481376" + }, + { + "chainId": 1, + "address": "0x686f2404e77ab0d9070a46cdfb0b7fecdd2318b0", + "name": "LORDS", + "symbol": "LORDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22171/thumb/Frame_1.png?1642334107" + }, + { + "chainId": 1, + "address": "0xf56408077487cb879c992909c5b5c66d68c02eb4", + "name": "Riot Racers", + "symbol": "RIOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19238/thumb/jyxvIbmJ_400x400.png?1634774849" + }, + { + "chainId": 1, + "address": "0x48c1b2f3efa85fbafb2ab951bf4ba860a08cdbb7", + "name": "ShowHand", + "symbol": "HAND", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/5554/thumb/showhand.png?1548609179" + }, + { + "chainId": 1, + "address": "0xa3ec7df93090f4de46faea09f73cc40ebe7dd714", + "name": "Monkey King", + "symbol": "WUKONG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27238/thumb/wukong.png?1662877212" + }, + { + "chainId": 1, + "address": "0xe88f8313e61a97cec1871ee37fbbe2a8bf3ed1e4", + "name": "Sora Validator", + "symbol": "VAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13299/thumb/val-gold-256.png?1607242927" + }, + { + "chainId": 1, + "address": "0x1f3ce12f7d9c589bf825cec15642bc37eae9e89e", + "name": "Atauro", + "symbol": "ATR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/22021/thumb/output-onlinepngtools.png?1640607268" + }, + { + "chainId": 1, + "address": "0x64609a845ad463d07ee51e91a88d1461c3dc3165", + "name": "Ridge", + "symbol": "RIDGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20487/thumb/logo_200x200_%289%29.png?1637119058" + }, + { + "chainId": 1, + "address": "0xf1e345ea7c33fd6c05f5512a780eb5839ee31674", + "name": "Telefy", + "symbol": "TELE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26485/thumb/WhatsApp_Image_2022-07-20_at_2.51.42_AM.jpeg?1658281111" + }, + { + "chainId": 1, + "address": "0x3adfc4999f77d04c8341bac5f3a76f58dff5b37a", + "name": "Privatix", + "symbol": "PRIX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1183/thumb/dZZrRl8.png?1547035211" + }, + { + "chainId": 1, + "address": "0xaf91e8afbe87642dc628786188a54b78580a4d76", + "name": "Fund Of Yours", + "symbol": "FOY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16648/thumb/foy200.png?1624591862" + }, + { + "chainId": 1, + "address": "0x0c90c57aaf95a3a87eadda6ec3974c99d786511f", + "name": "HanChain", + "symbol": "HAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27374/thumb/logo_200.png?1663732819" + }, + { + "chainId": 1, + "address": "0xe0e05c43c097b0982db6c9d626c4eb9e95c3b9ce", + "name": "Unslashed Finance", + "symbol": "USF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14177/thumb/Unslashed.jpeg?1614793365" + }, + { + "chainId": 1, + "address": "0x0222be1f1b8413b2d7d76ebfc9e0285c1300692f", + "name": "Glox Finance", + "symbol": "GLOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13312/thumb/glox_finance.png?1607395418" + }, + { + "chainId": 1, + "address": "0x10c71515602429c19d53011ea7040b87a4894838", + "name": "Diamond Platform", + "symbol": "DPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8309/thumb/RSCL14XL_400x400.jpg?1557400596" + }, + { + "chainId": 1, + "address": "0x8fc9b6354e839ab1c8b31f4afa53607092b8c2e5", + "name": "ECOSC", + "symbol": "ECU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10989/thumb/ecosc-logo.png?1586914826" + }, + { + "chainId": 1, + "address": "0x5833dbb0749887174b254ba4a5df747ff523a905", + "name": "XRun", + "symbol": "XRUN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25272/thumb/19787.png?1651118626" + }, + { + "chainId": 1, + "address": "0x29c56e7cb9c840d2b2371b17e28bab44ad3c3ead", + "name": "EsportsPro", + "symbol": "ESPRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14187/thumb/logo.jpg?1614830245" + }, + { + "chainId": 1, + "address": "0x7169ba45cf03e0377b464462aacbccdf1f721125", + "name": "1peco", + "symbol": "1PECO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22312/thumb/1PECO_200x200.png?1641467088" + }, + { + "chainId": 1, + "address": "0x75739d5944534115d7c54ee8c73f186d793bae02", + "name": "Collective", + "symbol": "CO2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14542/thumb/the_collective_logo.png?1616912000" + }, + { + "chainId": 1, + "address": "0xb8db81b84d30e2387de0ff330420a4aaa6688134", + "name": "Aave AMM UniLINKWETH", + "symbol": "AAMMUNILINKWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17221/thumb/aAmmUniLINKWETH.png?1626879669" + }, + { + "chainId": 1, + "address": "0xde075d9adbd0240b4462f124af926452ad0bac91", + "name": "Bubblefong", + "symbol": "BBF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24634/thumb/BBF-Token-200x200.png?1648460352" + }, + { + "chainId": 1, + "address": "0x0b569fa433faa7f01f3ea880193de38044b41de0", + "name": "GenCoin Capital", + "symbol": "GENCAP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22282/thumb/200x200_logo.png?1641364979" + }, + { + "chainId": 1, + "address": "0x436f0f3a982074c4a05084485d421466a994fe53", + "name": "Rate3", + "symbol": "RTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3342/thumb/rate3-logo.png?1547037953" + }, + { + "chainId": 1, + "address": "0x8f081eb884fd47b79536d28e2dd9d4886773f783", + "name": "bePAY Finance", + "symbol": "BECOIN", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21275/thumb/logo-becoin.png?1638861929" + }, + { + "chainId": 1, + "address": "0xcacc19c5ca77e06d6578decac80408cc036e0499", + "name": "Monfter", + "symbol": "MON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2546/thumb/monft.PNG?1641281398" + }, + { + "chainId": 1, + "address": "0x13572851103bed49ff743af4c4bb5ace88b22e2f", + "name": "Recharge Finance", + "symbol": "R3FI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14036/thumb/IMG_20210518_073652_114.png?1623833528" + }, + { + "chainId": 1, + "address": "0x37e808f084101f75783612407e7c3f5f92d8ee3f", + "name": "Xiotri RI", + "symbol": "RI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12536/thumb/Ri_logo_512x512.png?1601775196" + }, + { + "chainId": 1, + "address": "0xa13c75387c6677362f540f432bd8928c014e4892", + "name": "Sky Bandit Coin", + "symbol": "SBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27868/thumb/SBC.png?1666154249" + }, + { + "chainId": 1, + "address": "0x97a9bac06f90940bce9caec2b880ff17707519e4", + "name": "Minato", + "symbol": "MNTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24622/thumb/MNTO_200x200.png?1648448664" + }, + { + "chainId": 1, + "address": "0x226f7b842e0f0120b7e194d05432b3fd14773a9d", + "name": "UNION Protocol Governance", + "symbol": "UNN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13408/thumb/unn_finance.png?1608262290" + }, + { + "chainId": 1, + "address": "0x2edf094db69d6dcd487f1b3db9febe2eec0dd4c5", + "name": "ZeroSwap", + "symbol": "ZEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12861/thumb/logo.?1666110579" + }, + { + "chainId": 1, + "address": "0xbdbf245c690d54b67c6e610a28486a2c6de08be6", + "name": "Sunder Goverance", + "symbol": "SUNDER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16287/thumb/logo.d2250592.png?1623657219" + }, + { + "chainId": 1, + "address": "0xf0d243ee0d7517b1fcf2445ab624ded2dbe3ba54", + "name": "Engine Token", + "symbol": "ENGN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20492/thumb/200x200_%2842%29.png?1637129962" + }, + { + "chainId": 1, + "address": "0x68d57c9a1c35f63e2c83ee8e49a64e9d70528d25", + "name": "Sirin Labs", + "symbol": "SRN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1872/thumb/sirin-labs-token.png?1548609584" + }, + { + "chainId": 1, + "address": "0xd35ce4fd815522ff52243eb587020d557617f4db", + "name": "DFE Finance", + "symbol": "DFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13682/thumb/200x200DFE.png?1610835715" + }, + { + "chainId": 1, + "address": "0x9e10f61749c4952c320412a6b26901605ff6da1d", + "name": "Theos", + "symbol": "THEOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18150/thumb/theos_logo.png?1630714224" + }, + { + "chainId": 1, + "address": "0x4fd5b9b5dcc9a5d5931d007ba4ae573e760d9b64", + "name": "MO", + "symbol": "MO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12961/thumb/Group-9.png?1649143210" + }, + { + "chainId": 1, + "address": "0xa9b1eb5908cfc3cdf91f9b8b3a74108598009096", + "name": "Bounce", + "symbol": "AUCTION", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13860/thumb/1_KtgpRIJzuwfHe0Rl0avP_g.jpeg?1612412025" + }, + { + "chainId": 1, + "address": "0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2", + "name": "Maker", + "symbol": "MKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1364/thumb/Mark_Maker.png?1585191826" + }, + { + "chainId": 1, + "address": "0x976bf616f61685e0e7e36419aee3f7cde24b0dc9", + "name": "Fable Of The Shiba", + "symbol": "SYRANT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28372/thumb/syrant200.jpg?1669954925" + }, + { + "chainId": 1, + "address": "0xf3b3cad094b89392fce5fafd40bc03b80f2bc624", + "name": "Patron", + "symbol": "PAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3169/thumb/patron.png?1548330790" + }, + { + "chainId": 1, + "address": "0xa2085073878152ac3090ea13d1e41bd69e60dc99", + "name": "Escoin", + "symbol": "ELG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13566/thumb/escoin-200.png?1609833886" + }, + { + "chainId": 1, + "address": "0xe831f96a7a1dce1aa2eb760b1e296c6a74caa9d5", + "name": "Nexum", + "symbol": "NEXM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/23472/thumb/200_-_200_coinmarketcap.png?1644218225" + }, + { + "chainId": 1, + "address": "0xa51fc71422a30fa7ffa605b360c3b283501b5bf6", + "name": "AurusDeFi", + "symbol": "AWX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12684/thumb/2021-12-06-Aurus-tokens-for-coingecko-AWX-flat-color-v1-r1-AS.png?1640223413" + }, + { + "chainId": 1, + "address": "0x407a3e019c655b779ccd098ff50377e4c5f1c334", + "name": "OtherDAO", + "symbol": "OTHR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25882/thumb/othr.png?1654334543" + }, + { + "chainId": 1, + "address": "0x696acc2de564b48682d71d0847b3632f87c9a402", + "name": "AurusGOLD", + "symbol": "AWG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11594/thumb/2021-12-06-Aurus-tokens-for-coingecko-AWG-flat-color-v1-r1-AS.png?1640223324" + }, + { + "chainId": 1, + "address": "0xe1a178b681bd05964d3e3ed33ae731577d9d96dd", + "name": "BOX Token", + "symbol": "BOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6511/thumb/box-token.png?1547563043" + }, + { + "chainId": 1, + "address": "0x6aac8cb9861e42bf8259f5abdc6ae3ae89909e11", + "name": "Bitcoin Red", + "symbol": "BTCRED", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1054/thumb/bitcoin-red.png?1547034993" + }, + { + "chainId": 1, + "address": "0xae37d54ae477268b9997d4161b96b8200755935c", + "name": "Balancer Boosted Aave DAI", + "symbol": "BB-A-DAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25883/thumb/bb-a-dai.png?1654347111" + }, + { + "chainId": 1, + "address": "0x0a0e3bfd5a8ce610e735d4469bc1b3b130402267", + "name": "Entropyfi", + "symbol": "ERP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19633/thumb/erp.PNG?1635715161" + }, + { + "chainId": 1, + "address": "0x4af5ff1a60a6ef6c7c8f9c4e304cd9051fca3ec0", + "name": "Rigel Protocol", + "symbol": "RGP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15837/thumb/A_qRYvB2_400x400.png?1622080940" + }, + { + "chainId": 1, + "address": "0x90b831fa3bebf58e9744a14d638e25b4ee06f9bc", + "name": "Mimo Governance", + "symbol": "MIMO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16449/thumb/mimodefi.PNG?1624240539" + }, + { + "chainId": 1, + "address": "0x5e74c9036fb86bd7ecdcb084a0673efc32ea31cb", + "name": "sETH", + "symbol": "SETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8843/thumb/sETH.png?1616150207" + }, + { + "chainId": 1, + "address": "0x4b48068864f77261838c7849a12853fb94c77a91", + "name": "Lith Token", + "symbol": "LITX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26327/thumb/200x200px_LOGO.jpeg?1657768654" + }, + { + "chainId": 1, + "address": "0x913c9509b94d32ee38b0d98431c1ff109d24ff16", + "name": "AIPRO", + "symbol": "AIPRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28217/thumb/AIPro_logo_png.png?1668429140" + }, + { + "chainId": 1, + "address": "0x299698b4b44bd6d023981a7317798dee12860834", + "name": "New Frontier Presents", + "symbol": "NFP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24989/thumb/NFPLogoCoin.png?1649917308" + }, + { + "chainId": 1, + "address": "0x69af81e73a73b40adf4f3d4223cd9b1ece623074", + "name": "Mask Network", + "symbol": "MASK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14051/thumb/Mask_Network.jpg?1614050316" + }, + { + "chainId": 1, + "address": "0xdfbc9050f5b01df53512dcc39b4f2b2bbacd517a", + "name": "Jobchain", + "symbol": "JOB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9352/thumb/Logo_%283%29.png?1566510871" + }, + { + "chainId": 1, + "address": "0xb70835d7822ebb9426b56543e391846c107bd32c", + "name": "Game", + "symbol": "GTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2046/thumb/game.png?1547742459" + }, + { + "chainId": 1, + "address": "0x5b11aacb6bddb9ffab908fdce739bf4aed554327", + "name": "TrueDeck", + "symbol": "TDP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6567/thumb/truedeck.png?1548759129" + }, + { + "chainId": 1, + "address": "0x62406995cafd18f57e7375e8e0060725acebce58", + "name": "Firulais Wallet", + "symbol": "FIWT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20716/thumb/FIWT-Logo.png?1637584712" + }, + { + "chainId": 1, + "address": "0x4cf488387f035ff08c371515562cba712f9015d4", + "name": "WePower", + "symbol": "WPR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1951/thumb/wpr.png?1547036237" + }, + { + "chainId": 1, + "address": "0x96610186f3ab8d73ebee1cf950c750f3b1fb79c2", + "name": "Enjinstarter", + "symbol": "EJS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18732/thumb/l-R1nYA0_400x400.jpg?1633297242" + }, + { + "chainId": 1, + "address": "0x948c70dc6169bfb10028fdbe96cbc72e9562b2ac", + "name": "PolkaFantasy", + "symbol": "XP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18299/thumb/XP_Token_Icon.png?1631498467" + }, + { + "chainId": 1, + "address": "0x8640353cdc9778deab0df45d12fb3013deac079c", + "name": "DEVITA", + "symbol": "LIFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22268/thumb/divita.PNG?1641339910" + }, + { + "chainId": 1, + "address": "0x0af55d5ff28a3269d69b98680fd034f115dd53ac", + "name": "BankSocial", + "symbol": "BSL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15738/thumb/banksocial_small.png?1621685752" + }, + { + "chainId": 1, + "address": "0x11a605d7e12b64d713e93c487277d819a1d14b99", + "name": "Safe Shield", + "symbol": "SFSHLD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17673/thumb/Safe-Shield-SFSHLD-200x200-logo.png?1628830115" + }, + { + "chainId": 1, + "address": "0x83cee9e086a77e492ee0bb93c2b0437ad6fdeccc", + "name": "Goldmint", + "symbol": "MNTP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1944/thumb/goldmint.png?1547743002" + }, + { + "chainId": 1, + "address": "0x1a4743cf1af4c289351390a2b3fe7c13d2f7c235", + "name": "Castweet", + "symbol": "CTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9602/thumb/200x200color.png?1569479415" + }, + { + "chainId": 1, + "address": "0x973e52691176d36453868d9d86572788d27041a9", + "name": "DxChain", + "symbol": "DX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4700/thumb/VdZwy0Pv_400x400.png?1603089728" + }, + { + "chainId": 1, + "address": "0x3f4cd830543db25254ec0f05eac058d4d6e86166", + "name": "Jindoge", + "symbol": "JINDOGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15417/thumb/JINDOGE.png?1620774122" + }, + { + "chainId": 1, + "address": "0x5c1d9aa868a30795f92fae903edc9eff269044bf", + "name": "Changer", + "symbol": "CNG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21786/thumb/cng.png?1640327628" + }, + { + "chainId": 1, + "address": "0x19ebaa7f212b09de2aee2a32d40338553c70e2e3", + "name": "ARTM", + "symbol": "ARTM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21577/thumb/artm_token_logo.png?1639530067" + }, + { + "chainId": 1, + "address": "0xebd9d99a3982d547c5bb4db7e3b1f9f14b67eb83", + "name": "Everest", + "symbol": "ID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5209/thumb/Everest.jpg?1628042930" + }, + { + "chainId": 1, + "address": "0xb89903dde3899f0280b99913168ee833a7896b93", + "name": "AurusSILVER", + "symbol": "AWS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14965/thumb/2021-12-06-Aurus-tokens-for-coingecko-AWS-flat-color-v1-r1-AS.png?1640223368" + }, + { + "chainId": 1, + "address": "0xf83bf320a4a3f4bf365c3114b6f19fc3f6b1228c", + "name": "FXT", + "symbol": "FXT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14131/thumb/7rgEwxRT_400x400.jpg?1614588199" + }, + { + "chainId": 1, + "address": "0x0198f46f520f33cd4329bd4be380a25a90536cd5", + "name": "PlayChip", + "symbol": "PLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4567/thumb/pla.png?1547039851" + }, + { + "chainId": 1, + "address": "0x13a0599c493cc502ed8c4dd26f22f5cedc248fc4", + "name": "Export Motors Platform", + "symbol": "EMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24422/thumb/emp_logo_200.png?1647654574" + }, + { + "chainId": 1, + "address": "0x761d38e5ddf6ccf6cf7c55759d5210750b5d60f3", + "name": "Dogelon Mars", + "symbol": "ELON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14962/thumb/6GxcPRo3_400x400.jpg?1619157413" + }, + { + "chainId": 1, + "address": "0xe9e73e1ae76d17a16cc53e3e87a9a7da78834d37", + "name": "Camp", + "symbol": "CAMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13338/thumb/CampGlobal_256256.png?1607576849" + }, + { + "chainId": 1, + "address": "0x9fb9ec13a18eff7072ee8ca7ee7a2b295649e00d", + "name": "JAM Token", + "symbol": "JAM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26787/thumb/296706797_1760425707628456_5310396823145359110_n.jpg?1660102688" + }, + { + "chainId": 1, + "address": "0x2f7b618993cc3848d6c7ed9cdd5e835e4fe22b98", + "name": "Nami Corporation", + "symbol": "NAMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13729/thumb/nami_logo_256.png?1611224464" + }, + { + "chainId": 1, + "address": "0x33bfd20660eeaf952e8d5bc3236e1918701f17d0", + "name": "RCCC", + "symbol": "RCCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6627/thumb/rccc_token.png?1547042828" + }, + { + "chainId": 1, + "address": "0xaf691508ba57d416f895e32a1616da1024e882d2", + "name": "Pinknode", + "symbol": "PNODE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15469/thumb/icon-Logo-pink.png?1644476523" + }, + { + "chainId": 1, + "address": "0x456d8f0d25a4e787ee60c401f8b963a465148f70", + "name": "Cavapoo", + "symbol": "CAVA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16047/thumb/VimPINu.png?1622689097" + }, + { + "chainId": 1, + "address": "0x536a7bcdccfaff3a9a2aa765369631db2f247b09", + "name": "HydroLink", + "symbol": "HLNK", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/19664/thumb/200x-logo.png?1635736696" + }, + { + "chainId": 1, + "address": "0x5b0751713b2527d7f002c0c4e2a37e1219610a6b", + "name": "Ethorse", + "symbol": "HORSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2531/thumb/ethorse.png?1548125546" + }, + { + "chainId": 1, + "address": "0x159751323a9e0415dd3d6d42a1212fe9f4a0848c", + "name": "Insured Finance", + "symbol": "INFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13727/thumb/logo_%287%29.png?1611210296" + }, + { + "chainId": 1, + "address": "0xb8647e90c0645152fccf4d9abb6b59eb4aa99052", + "name": "KeyFi", + "symbol": "KEYFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15098/thumb/keyfi_logo.jpg?1619690054" + }, + { + "chainId": 1, + "address": "0x31fdd1c6607f47c14a2821f599211c67ac20fa96", + "name": "Burency", + "symbol": "BUY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12216/thumb/Ddphl9BD.png?1598238121" + }, + { + "chainId": 1, + "address": "0x40284109c3309a7c3439111bfd93bf5e0fbb706c", + "name": "MOTIV Protocol", + "symbol": "MOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11869/thumb/jvftnBL-_400x400.jpg?1595498693" + }, + { + "chainId": 1, + "address": "0xc8cac7672f4669685817cf332a33eb249f085475", + "name": "LivenPay", + "symbol": "LVN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9554/thumb/8PgKjhJn_400x400.jpg?1568837435" + }, + { + "chainId": 1, + "address": "0x5394794be8b6ed5572fcd6b27103f46b5f390e8f", + "name": "Aave AMM UniYFIWETH", + "symbol": "AAMMUNIYFIWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17258/thumb/aAmmUniYFIWETH.png?1626958146" + }, + { + "chainId": 1, + "address": "0x28c5805b64d163588a909012a628b5a03c1041f9", + "name": "Chopper Inu", + "symbol": "CHOPPER", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18644/thumb/Chopper-Inu-Logo.png?1632753815" + }, + { + "chainId": 1, + "address": "0x5af6ad286c8ed6633284f2f135c4716057d52669", + "name": "ImpactX", + "symbol": "IMPACTX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20433/thumb/gen-impact-logo-2-276x300.png?1637035516" + }, + { + "chainId": 1, + "address": "0x9ba60ba98413a60db4c651d4afe5c937bbd8044b", + "name": "Yearn Lazy Ape", + "symbol": "YLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14447/thumb/yla.png?1616128042" + }, + { + "chainId": 1, + "address": "0xed40834a13129509a89be39a9be9c0e96a0ddd71", + "name": "Warp Finance", + "symbol": "WARP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13910/thumb/601ed0ac35c687c6e07d17c2_warp_token.png?1612834360" + }, + { + "chainId": 1, + "address": "0x106d3c66d22d2dd0446df23d7f5960752994d600", + "name": "LabraCoin", + "symbol": "LABRA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15024/thumb/Labra_Coin.jpg?1622613634" + }, + { + "chainId": 1, + "address": "0x4dd672e77c795844fe3a464ef8ef0faae617c8fb", + "name": "CONUN", + "symbol": "CON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7480/thumb/conun.png?1547716938" + }, + { + "chainId": 1, + "address": "0x453660ec2b63f0453d42f72c808350c1e2c70153", + "name": "IdenDEFI", + "symbol": "ID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27851/thumb/2022-10-16_17-47-37.png?1666094387" + }, + { + "chainId": 1, + "address": "0x11a0762da58a487c075249b9b9edf9f7eb1bc9f5", + "name": "OriginDAO", + "symbol": "OG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27699/thumb/Origin.jpeg?1665303707" + }, + { + "chainId": 1, + "address": "0xc57d533c50bc22247d49a368880fb49a1caa39f7", + "name": "PowerTrade Fuel", + "symbol": "PTF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12590/thumb/powertrade_logo.jpg?1600944549" + }, + { + "chainId": 1, + "address": "0x37d299ef5548bf19503cb72c085799e331f9097d", + "name": "VeganNation GreenCoin", + "symbol": "GRNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21581/thumb/logo-green_%281%29.png?1639532854" + }, + { + "chainId": 1, + "address": "0xbdec45952b5e234eddc2981b43eed360826d5087", + "name": "Mogu", + "symbol": "MOGX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9687/thumb/UZpzCJc1_400x400.jpg?1570828056" + }, + { + "chainId": 1, + "address": "0xe53ec727dbdeb9e2d5456c3be40cff031ab40a55", + "name": "SuperVerse", + "symbol": "SUPER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14040/thumb/SuperVerse_Logo_200x200.png?1669963064" + }, + { + "chainId": 1, + "address": "0xbe30f684d62c9f7883a75a29c162c332c0d98f23", + "name": "Global Human Trust", + "symbol": "GHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12040/thumb/WechatIMG6648.png?1596700737" + }, + { + "chainId": 1, + "address": "0xa8580f3363684d76055bdc6660caefe8709744e1", + "name": "Folder Protocol", + "symbol": "FOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13755/thumb/folderlabs_logo.png?1611560881" + }, + { + "chainId": 1, + "address": "0x61fd1c62551850d0c04c76fce614cbced0094498", + "name": "IDK", + "symbol": "IDK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9301/thumb/idk-logo.png?1565861759" + }, + { + "chainId": 1, + "address": "0x1a4b46696b2bb4794eb3d4c26f1c55f9170fa4c5", + "name": "BitDAO", + "symbol": "BIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17627/thumb/rI_YptK8.png?1653983088" + }, + { + "chainId": 1, + "address": "0xa1116930326d21fb917d5a27f1e9943a9595fb47", + "name": "Staked Aave Balancer Pool Token", + "symbol": "STKABPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16789/thumb/StkABPT_2x.png?1625046066" + }, + { + "chainId": 1, + "address": "0x383b0b2ce2e1757b5e1d087d8f36013ea595541a", + "name": "Heal The World", + "symbol": "HEAL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24123/thumb/GJe1qAQS_400x400.jpg?1646461929" + }, + { + "chainId": 1, + "address": "0xaa0c5b3567fd1bac8a2a11eb16c3f81a49eea90f", + "name": "MetamonkeyAi", + "symbol": "MMAI", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/27208/thumb/metamonkey.jpeg?1662608488" + }, + { + "chainId": 1, + "address": "0xc5e86e01f8b63178ee2039bfe51a4f73dd10d402", + "name": "ShowTime Potocol", + "symbol": "STP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27509/thumb/D92uffI__400x400.jpeg?1664335190" + }, + { + "chainId": 1, + "address": "0x4104b135dbc9609fc1a9490e61369036497660c8", + "name": "APWine", + "symbol": "APW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15597/thumb/ApWine.png?1621340387" + }, + { + "chainId": 1, + "address": "0x05d3606d5c81eb9b7b18530995ec9b29da05faba", + "name": "TomoChain ERC 20", + "symbol": "TOMOE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12646/thumb/tomoe_logo.png?1601377449" + }, + { + "chainId": 1, + "address": "0x26cb3641aaa43911f1d4cb2ce544eb652aac7c47", + "name": "Crystal CYL", + "symbol": "CYL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6419/thumb/crystal-token.png?1547042585" + }, + { + "chainId": 1, + "address": "0x66e7ce35578a37209d01f99f3d2ff271f981f581", + "name": "PactSwap", + "symbol": "PACT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15265/thumb/pact.PNG?1620281262" + }, + { + "chainId": 1, + "address": "0x22222c03318440305ac3e8a7820563d6a9fd777f", + "name": "Clover", + "symbol": "CLV", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/12888/thumb/clover_logo.png?1603274615" + }, + { + "chainId": 1, + "address": "0xa1b0edf4460cc4d8bfaa18ed871bff15e5b57eb4", + "name": "Aave AMM UniBATWETH", + "symbol": "AAMMUNIBATWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17217/thumb/aAmmUniBATWETH.png?1626878218" + }, + { + "chainId": 1, + "address": "0xbf0741e995f469d39e4f96c0780f9a8e43f4b978", + "name": "i Money Crypto", + "symbol": "IMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20178/thumb/imc_Logo.png?1636604215" + }, + { + "chainId": 1, + "address": "0x553539d40ae81fd0d9c4b991b0b77be6f6bc030e", + "name": "Smolting Inu", + "symbol": "SMOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25420/thumb/awL5SVbh_400x400.jpg?1651736210" + }, + { + "chainId": 1, + "address": "0xf90c7f66eac7e2130bf677d69a250b2136cf6697", + "name": "HAKI Token", + "symbol": "HAKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7945/thumb/haki.png?1667030461" + }, + { + "chainId": 1, + "address": "0xc8ba3cf103e5a1658209c366153197ac7fa9c9b1", + "name": "Difo Network", + "symbol": "DFN", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/14504/thumb/difo.png?1616566305" + }, + { + "chainId": 1, + "address": "0x0b4680e848f842b86e4df38d9fa0d9f9419f37ec", + "name": "Beshare", + "symbol": "BST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16870/thumb/BST_symbol_transparent_background_200.png?1625476744" + }, + { + "chainId": 1, + "address": "0x614fd8f06ce4d93aa2361b342c86554eb5cb39f1", + "name": "Tianya", + "symbol": "TYT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/7568/thumb/images_%283%29.png?1548411643" + }, + { + "chainId": 1, + "address": "0x53884b61963351c283118a8e1fc05ba464a11959", + "name": "Monnos", + "symbol": "MNS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11640/thumb/logo_%2880%29.png?1592274153" + }, + { + "chainId": 1, + "address": "0xb2e20502c7593674509b8384ed9240a03869faf3", + "name": "Shiba Ramen", + "symbol": "SHIBARAMEN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16134/thumb/60bbdb756d4e3aea1bfa5478_image0_copy.jpeg?1623055808" + }, + { + "chainId": 1, + "address": "0xadc234a4e90e2045f353f5d4fcde66144d23b458", + "name": "Fluid USDT", + "symbol": "FUSDT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/28472/thumb/fUSDT-200x200.png?1671002181" + }, + { + "chainId": 1, + "address": "0x26ff6d16549a00ba8b36ce3159b5277e6e798d18", + "name": "Chihua", + "symbol": "CHIHUA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15655/thumb/chihua_token_icon_200x200.png?1622129847" + }, + { + "chainId": 1, + "address": "0x2653891204f463fb2a2f4f412564b19e955166ae", + "name": "Gold Fever Native Gold", + "symbol": "NGL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20633/thumb/2ypNydrG_400x400.jpg?1637338673" + }, + { + "chainId": 1, + "address": "0x25c7b64a93eb1261e130ec21a3e9918caa38b611", + "name": "Wrapped Virgin Gen 0 CryptoKittties", + "symbol": "WVG0", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12875/thumb/wvg0.png?1603211534" + }, + { + "chainId": 1, + "address": "0x51a673e060e1ea091b23b53d192058ffe0f2d6b6", + "name": "ZudgeZury", + "symbol": "ZZC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27336/thumb/ZZcoin200x200.jpg?1663483736" + }, + { + "chainId": 1, + "address": "0xa4c612296aa97057c160b95255f902f9dde6704c", + "name": "MemeCard", + "symbol": "MMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28096/thumb/IMG_20221102_023910_703.png?1667537410" + }, + { + "chainId": 1, + "address": "0xb4d930279552397bba2ee473229f89ec245bc365", + "name": "MahaDAO", + "symbol": "MAHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13404/thumb/MAHA_Token.png?1625651604" + }, + { + "chainId": 1, + "address": "0x9625ce7753ace1fa1865a47aae2c5c2ce4418569", + "name": "Kapital DAO", + "symbol": "KAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27682/thumb/KAP-200px.png?1665214016" + }, + { + "chainId": 1, + "address": "0x4824a7b64e3966b0133f4f4ffb1b9d6beb75fff7", + "name": "TokenClub", + "symbol": "TCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2455/thumb/tokenclub.png?1558012103" + }, + { + "chainId": 1, + "address": "0xb8919522331c59f5c16bdfaa6a121a6e03a91f62", + "name": "Bacon Protocol Home", + "symbol": "HOME", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/26185/thumb/homecoin_200.png?1656384254" + }, + { + "chainId": 1, + "address": "0x0fcbc31c503b4a9ed90e87f8ff46c318a4a14260", + "name": "Quantfury", + "symbol": "QTF", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14033/thumb/FtSOX9Vy_400x400.jpg?1613946524" + }, + { + "chainId": 1, + "address": "0xcaa9ed6d7502595b555113d4517668ae24038c8a", + "name": "Marvin Inu", + "symbol": "MARVIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22039/thumb/lVshyCp.png?1640669485" + }, + { + "chainId": 1, + "address": "0x66a0f676479cee1d7373f3dc2e2952778bff5bd6", + "name": "Wise", + "symbol": "WISE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13552/thumb/WISE-logo-1600x1280.png?1609727947" + }, + { + "chainId": 1, + "address": "0xbb0e17ef65f82ab018d8edd776e8dd940327b28b", + "name": "Axie Infinity", + "symbol": "AXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13029/thumb/axie_infinity_logo.png?1604471082" + }, + { + "chainId": 1, + "address": "0x287609a15a683640a5bbc4d93d4d5f4ed6bad3a0", + "name": "PICK", + "symbol": "PICK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12243/thumb/nZlFKAmk_400x400.jpg?1598444299" + }, + { + "chainId": 1, + "address": "0xc96df921009b790dffca412375251ed1a2b75c60", + "name": "Ormeus Coin", + "symbol": "ORME", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/964/thumb/ORMEUS_logo.png?1606557243" + }, + { + "chainId": 1, + "address": "0x9077f9e1efe0ea72867ac89046b2a6264cbcaef5", + "name": "WhaleStreet hrimp", + "symbol": "HRIMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17646/thumb/logo_-_2021-08-12T134059.988.png?1628746866" + }, + { + "chainId": 1, + "address": "0x59d1e836f7b7210a978b25a855085cc46fd090b5", + "name": "AssangeDAO", + "symbol": "JUSTICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23555/thumb/JUSTICE_token_logo.png?1644532689" + }, + { + "chainId": 1, + "address": "0x51fa2efd62ee56a493f24ae963eace7d0051929e", + "name": "Poseidon OCEAN", + "symbol": "PSDNOCEAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27859/thumb/psdnOCEAN.png?1666097011" + }, + { + "chainId": 1, + "address": "0xcb86c6a22cb56b6cf40cafedb06ba0df188a416e", + "name": "inSure DeFi", + "symbol": "SURE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10354/thumb/logo-grey-circle.png?1614910406" + }, + { + "chainId": 1, + "address": "0x5b7533812759b45c2b44c19e320ba2cd2681b542", + "name": "SingularityNET", + "symbol": "AGIX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2138/thumb/singularitynet.png?1548609559" + }, + { + "chainId": 1, + "address": "0x5ca135cb8527d76e932f34b5145575f9d8cbe08e", + "name": "Frax Price Index", + "symbol": "FPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24945/thumb/fpi.png?1649485834" + }, + { + "chainId": 1, + "address": "0xfa3118b34522580c35ae27f6cf52da1dbb756288", + "name": "Linkeye", + "symbol": "LET", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1814/thumb/linkeye.png?1547975964" + }, + { + "chainId": 1, + "address": "0x9f195617fa8fbad9540c5d113a99a0a0172aaedc", + "name": "Niobium Coin", + "symbol": "NBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4095/thumb/logo-niobium.png?1547039273" + }, + { + "chainId": 1, + "address": "0x1fdab294eda5112b7d066ed8f2e4e562d5bcc664", + "name": "SPICE", + "symbol": "SPICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13398/thumb/VUenmQt_%281%29.png?1624954218" + }, + { + "chainId": 1, + "address": "0x40d2025ed2e89632d3a41d8541df9ed2ac0e2b1c", + "name": "Connectico", + "symbol": "CON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22853/thumb/9005.png?1642750464" + }, + { + "chainId": 1, + "address": "0x4f5f2eea4ed3485e5e23a39704d5fd9d0a423886", + "name": "Torchain", + "symbol": "TOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8636/thumb/Z01mRB2BHvjsIsR95aZ4l8UTF87S5JVTgTvvdC5PVpEPaFXOoXuYwdKvEDiK3o5s-tx-o-S5KW1y2zgwn-9ftk6QUfNQsc_gnzrbvfbIgbm-_FYNoTG50PHc59XU32p6vihaXFYUnHZ9cMCHzGvq9fSqKRul9AEiUe0M9SkS65UNuL--P1ulJtc7r-rQTZpPZ3TS0VhXSGPsdwMglbhIHQDs_.jpg?1566612218" + }, + { + "chainId": 1, + "address": "0x8790f2fc7ca2e7db841307fb3f4e72a03baf7b47", + "name": "Spillways", + "symbol": "SPILLWAYS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28358/thumb/1669791775144_%281%29.png?1669794825" + }, + { + "chainId": 1, + "address": "0xacf8d5e515ed005655dfefa09c22673a37a7cdee", + "name": "FunFi", + "symbol": "FNF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25872/thumb/FNF-200x200.png?1654241524" + }, + { + "chainId": 1, + "address": "0xf344490abd414dafa97f34c8ca501b0aa5bf8873", + "name": "Webcoin", + "symbol": "WEB", + "decimals": 1, + "logoURI": "https://assets.coingecko.com/coins/images/3779/thumb/webcoin-logo.png?1547038866" + }, + { + "chainId": 1, + "address": "0x06f3cdabae564b0546529b4dd8fef1bcd4235753", + "name": "TilWiki", + "symbol": "TLW", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12915/thumb/89706561_1111490899211097_8975783115158978560_n.jpg?1603441976" + }, + { + "chainId": 1, + "address": "0xca5e32d44f1744001b5600dc2f5f5e0bbb6e9d3e", + "name": "Richverse", + "symbol": "RIV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26892/thumb/WechatIMG2340.jpeg?1660708132" + }, + { + "chainId": 1, + "address": "0xbd1e7f594600dcaf7f483af55deacec0159a064e", + "name": "Qobit", + "symbol": "QOB", + "decimals": 8 + }, + { + "chainId": 1, + "address": "0x0e7f79e89ba8c4a13431129fb2db0d4f444b5b9a", + "name": "Xank", + "symbol": "XANK", + "decimals": 16, + "logoURI": "https://assets.coingecko.com/coins/images/11599/thumb/9zAYweVj_400x400.png?1591671435" + }, + { + "chainId": 1, + "address": "0x3da932456d082cba208feb0b096d49b202bf89c8", + "name": "Dego Finance", + "symbol": "DEGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12503/thumb/c185FKx.png?1600298167" + }, + { + "chainId": 1, + "address": "0x13739cf9c9bc2fc1e06e74413c9c192757a65587", + "name": "Flash Inu", + "symbol": "FLASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24037/thumb/logo.png?1646118116" + }, + { + "chainId": 1, + "address": "0x4a5dec561de897c04062137e687db6093c3278b8", + "name": "GasBlock", + "symbol": "GSBL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28191/thumb/gasblock_logo_200xW.png?1668327478" + }, + { + "chainId": 1, + "address": "0x1b40183efb4dd766f11bda7a7c3ad8982e998421", + "name": "Vesper Finance", + "symbol": "VSP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13527/thumb/vesper_logo.jpg?1609399927" + }, + { + "chainId": 1, + "address": "0xa3bed4e1c75d00fa6f4e5e6922db7261b5e9acd2", + "name": "mStable Governance Meta", + "symbol": "MTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11846/thumb/mStable.png?1594950533" + }, + { + "chainId": 1, + "address": "0xd283ec9db7b3094ed5a2c87eb48d54f5fa96e96d", + "name": "FMONEY FINANCE", + "symbol": "FMON", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27808/thumb/logo_%281%29.png?1665906035" + }, + { + "chainId": 1, + "address": "0x71921c08586295b0b68e44a78a2dca1e3f259721", + "name": "PonyDAO", + "symbol": "PNYD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26843/thumb/ponydao.png?1660389977" + }, + { + "chainId": 1, + "address": "0x65f9a292f1aeed5d755aa2fd2fb17ab2e9431447", + "name": "SoMee Social", + "symbol": "SOMEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16406/thumb/SoMeeBallLogo200x200.png?1623920285" + }, + { + "chainId": 1, + "address": "0x3af5ba94c29a8407785f5f6d90ef5d69a8eb2436", + "name": "Unagii Wrapped Bitcoin", + "symbol": "UWBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14625/thumb/uBTC.png?1617294190" + }, + { + "chainId": 1, + "address": "0x2fc246aa66f0da5bb1368f688548ecbbe9bdee5d", + "name": "TEMCO", + "symbol": "TEMCO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6210/thumb/bSZ7HUuS_400x400.jpg?1549002381" + }, + { + "chainId": 1, + "address": "0x14c926f2290044b647e1bf2072e67b495eff1905", + "name": "Bethereum", + "symbol": "BETHER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2738/thumb/bethereum.png?1547036939" + }, + { + "chainId": 1, + "address": "0x39207d2e2feef178fbda8083914554c59d9f8c00", + "name": "MultiPlanetary Inus", + "symbol": "INUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22648/thumb/logo.png?1644479310" + }, + { + "chainId": 1, + "address": "0xbce7bd79558dda90b261506768f265c5543a9f90", + "name": "TKN", + "symbol": "TKNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12808/thumb/1_jLY3Tj0kuBTjZGHFCqkTGA.png?1602713481" + }, + { + "chainId": 1, + "address": "0xc888a0ab4831a29e6ca432babf52e353d23db3c2", + "name": "FastSwap", + "symbol": "FAST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13567/thumb/fastswap.jpeg?1622794717" + }, + { + "chainId": 1, + "address": "0x0aee8703d34dd9ae107386d3eff22ae75dd616d1", + "name": "Tranche Finance", + "symbol": "SLICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14119/thumb/slice.png?1635826973" + }, + { + "chainId": 1, + "address": "0x3593d125a4f7849a1b059e64f4517a86dd60c95d", + "name": "MANTRA", + "symbol": "OM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12151/thumb/OM_Token.png?1666056782" + }, + { + "chainId": 1, + "address": "0xe13ef257cf4d5df928ca11d230427c037666d466", + "name": "WITChain", + "symbol": "WIT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/6420/thumb/wit-logo.png?1547042587" + }, + { + "chainId": 1, + "address": "0xf411903cbc70a74d22900a5de66a2dda66507255", + "name": "Verasity", + "symbol": "VRA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14025/thumb/VRA.jpg?1613797653" + }, + { + "chainId": 1, + "address": "0x0b4bdc478791897274652dc15ef5c135cae61e60", + "name": "DAEX", + "symbol": "DAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4063/thumb/daex.png?1547791412" + }, + { + "chainId": 1, + "address": "0x45e007750cc74b1d2b4dd7072230278d9602c499", + "name": "pSTAKE Staked XPRT", + "symbol": "STKXPRT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/19219/thumb/stkXPRT_-_128px.png?1634977999" + }, + { + "chainId": 1, + "address": "0xa7a5c1058194af8f00c187adb7fcc0c95f1c6c2d", + "name": "SPACE iZ", + "symbol": "SPIZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12213/thumb/aEXTI0vf_400x400.jpg?1598236662" + }, + { + "chainId": 1, + "address": "0x7b69d465c0f9fb22affae56aa86149973e9b0966", + "name": "Protocol Finance", + "symbol": "PFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13810/thumb/17RgoN2.png?1612047312" + }, + { + "chainId": 1, + "address": "0xc40f23a3e9613e012944f7957edce97899fa920d", + "name": "dHealth", + "symbol": "DHP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20167/thumb/dHealth_Network_Icon_200w.png?1636601369" + }, + { + "chainId": 1, + "address": "0x7c32db0645a259fae61353c1f891151a2e7f8c1e", + "name": "Potentiam", + "symbol": "PTM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2349/thumb/ptm.png?1547036546" + }, + { + "chainId": 1, + "address": "0x77dce26c03a9b833fc2d7c31c22da4f42e9d9582", + "name": "DAOventures", + "symbol": "DVD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13971/thumb/DAOventures.co_final_icon_200x200.png?1613388224" + }, + { + "chainId": 1, + "address": "0x6c2adc2073994fb2ccc5032cc2906fa221e9b391", + "name": "Delphy", + "symbol": "DPY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1133/thumb/delphy.png?1547035133" + }, + { + "chainId": 1, + "address": "0xe7d324b2677440608fb871981b220eca062c3fbf", + "name": "Bullswap Protocol", + "symbol": "BVL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13195/thumb/4HPwA1D2_400x400.png?1606115706" + }, + { + "chainId": 1, + "address": "0x758b4684be769e92eefea93f60dda0181ea303ec", + "name": "Phonon DAO", + "symbol": "PHONON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22308/thumb/ezgif-2-e7fb84364d.png?1641449852" + }, + { + "chainId": 1, + "address": "0x64c1c9a38038ae73c3699b8dc347fefda2221e93", + "name": "Swiss NFT Fund", + "symbol": "SWISSNFTFUND", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28221/thumb/LogoSNF200x200.jpg?1669261184" + }, + { + "chainId": 1, + "address": "0x74edaf28fc4b9e6a1618d613839daaf6a9d075db", + "name": "G O A T", + "symbol": "GOAT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21537/thumb/IMG_1871.JPG?1639401972" + }, + { + "chainId": 1, + "address": "0x6c929cde908481f3d1d775008791f42b1b89dbb0", + "name": "Boolean", + "symbol": "BOOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9888/thumb/booleanSiteLogo.png?1572943862" + }, + { + "chainId": 1, + "address": "0x3137619705b5fc22a3048989f983905e456b59ab", + "name": "Everus", + "symbol": "EVR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1027/thumb/everus.png?1547395108" + }, + { + "chainId": 1, + "address": "0xc014186cf1ba36032aaec7f96088f09eb3934347", + "name": "WeCoOwn", + "symbol": "WCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14497/thumb/WCX-Token-Logo.png?1616555141" + }, + { + "chainId": 1, + "address": "0x8dae6cb04688c62d939ed9b68d32bc62e49970b1", + "name": "Aave CRV", + "symbol": "ACRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17250/thumb/aCRV_2x.png?1626941642" + }, + { + "chainId": 1, + "address": "0x2c36204a0712a2a50e54a62f7c4f01867e78cb53", + "name": "Taklimakan Network", + "symbol": "TAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1963/thumb/takli.png?1566738740" + }, + { + "chainId": 1, + "address": "0xdfdd3459d4f87234751696840092ee20c970fb07", + "name": "My bu", + "symbol": "MYOBU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16122/thumb/myobu.png?1623037167" + }, + { + "chainId": 1, + "address": "0xee059f0ca1507e4e20c689b20cff71b5e924f7bd", + "name": "Litecoin SV", + "symbol": "LSV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11100/thumb/1GyOsGG.png?1588749283" + }, + { + "chainId": 1, + "address": "0x03042ae6fcfd53e3a0baa1fab5ce70e0cb74e6fb", + "name": "Ten Best Coins", + "symbol": "TBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27312/thumb/tbc.png?1663312003" + }, + { + "chainId": 1, + "address": "0x7533d63a2558965472398ef473908e1320520ae2", + "name": "INTEXCOIN", + "symbol": "INTX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/11854/thumb/INTX.png?1595167044" + }, + { + "chainId": 1, + "address": "0x1321f1f1aa541a56c31682c57b80ecfccd9bb288", + "name": "ARC Governance", + "symbol": "ARCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15652/thumb/coingecko-arcx-400x400.png?1634285525" + }, + { + "chainId": 1, + "address": "0x40395044ac3c0c57051906da938b54bd6557f212", + "name": "MobileGo", + "symbol": "MGO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/768/thumb/mobilego.png?1548085237" + }, + { + "chainId": 1, + "address": "0xff69e48af1174da7f15d0c771861c33d3f19ed8a", + "name": "Tesla Inu", + "symbol": "TESINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17468/thumb/400_filter_nobg_60c70a3c5aae1.jpg?1628214173" + }, + { + "chainId": 1, + "address": "0x3383c5a8969dc413bfddc9656eb80a1408e4ba20", + "name": "Wrapped ANATHA", + "symbol": "WANATHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12690/thumb/CrZ8h9FV_400x400.png?1601678935" + }, + { + "chainId": 1, + "address": "0x6251e725cd45fb1af99354035a414a2c0890b929", + "name": "MixTrust", + "symbol": "MXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12148/thumb/MXT_LOGO_200_200.png?1597578983" + }, + { + "chainId": 1, + "address": "0xf8b358b3397a8ea5464f8cc753645d42e14b79ea", + "name": "Airbloc", + "symbol": "ABL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4393/thumb/airbloc-protocol-logo.png?1547039734" + }, + { + "chainId": 1, + "address": "0xaf4dce16da2877f8c9e00544c93b62ac40631f16", + "name": "Monetha", + "symbol": "MTH", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/902/thumb/LOGO-MTH-200-200.png?1656643069" + }, + { + "chainId": 1, + "address": "0x5a75a093747b72a0e14056352751edf03518031d", + "name": "EmiSwap", + "symbol": "ESW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17526/thumb/Emiswap_Logo_light_colour_horizontal.png?1628114900" + }, + { + "chainId": 1, + "address": "0xea1ea0972fa092dd463f2968f9bb51cc4c981d71", + "name": "Modefi", + "symbol": "MOD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13980/thumb/modefi_logo.png?1613453111" + }, + { + "chainId": 1, + "address": "0x3ecb96039340630c8b82e5a7732bc88b2aeade82", + "name": "bRing Finance", + "symbol": "BRNG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17836/thumb/bring_finance.PNG?1629417184" + }, + { + "chainId": 1, + "address": "0xbd04ccc050058a6a422851fa6c0f92bb65eb06ca", + "name": "Pre Retogeum", + "symbol": "PRTG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27397/thumb/IMG_20220921_123729_913.jpg?1663827688" + }, + { + "chainId": 1, + "address": "0x602f65bb8b8098ad804e99db6760fd36208cd967", + "name": "Mops", + "symbol": "MOPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26900/thumb/mops.png?1660724129" + }, + { + "chainId": 1, + "address": "0xf54b304e2e4b28c7e46619d1a340f9b2b72383d7", + "name": "Kranz", + "symbol": "KRZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17688/thumb/KRZ-Extra-Small-Logo-200x200-1.png?1654230602" + }, + { + "chainId": 1, + "address": "0x8c6fa66c21ae3fc435790e451946a9ea82e6e523", + "name": "MetaFabric", + "symbol": "FABRIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21233/thumb/LISTING-icon.png?1638758217" + }, + { + "chainId": 1, + "address": "0x40370aed88933021e20cf7c4d67e00417cda2202", + "name": "Xave", + "symbol": "XAV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28299/thumb/Xave_Logomark_%28Color%29_%281%29.png?1669265691" + }, + { + "chainId": 1, + "address": "0x16594930d16f3970e1a4317c6016555cb2e7b7fc", + "name": "TokenBot", + "symbol": "TKB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27106/thumb/tokenbot-logo-icon.png?1662007634" + }, + { + "chainId": 1, + "address": "0xd7d8f3b8bc8bc48d3acc37879eaba7b85889fa52", + "name": "ClearDAO", + "symbol": "CLH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22389/thumb/clh_small_logo_png.png?1643194446" + }, + { + "chainId": 1, + "address": "0x624d520bab2e4ad83935fa503fb130614374e850", + "name": "Smartshare", + "symbol": "SSP", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/4642/thumb/smartshare.png?1548609894" + }, + { + "chainId": 1, + "address": "0xe8d17542dfe79ff4fbd4b850f2d39dc69c4489a2", + "name": "KiloAmple", + "symbol": "KMPL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13449/thumb/kappa_logo.png?1608681544" + }, + { + "chainId": 1, + "address": "0x00ff902d4b2bfdbd0db38887412447c30b565aa0", + "name": "Tcoin fun", + "symbol": "TCO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13811/thumb/logo200_%289%29.png?1612047833" + }, + { + "chainId": 1, + "address": "0x5ce188b44266c7b4bbc67afa3d16b2eb24ed1065", + "name": "UWU Vault NFTX ", + "symbol": "UWU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18355/thumb/uwu.png?1631604745" + }, + { + "chainId": 1, + "address": "0x1f573d6fb3f13d689ff844b4ce37794d79a7ff1c", + "name": "Bancor Network", + "symbol": "BNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/736/thumb/bancor-bnt.png?1628822309" + }, + { + "chainId": 1, + "address": "0xe0955f26515d22e347b17669993fcefcc73c3a0a", + "name": "Stacker Ventures", + "symbol": "STACK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14218/thumb/stack.jpg?1615000614" + }, + { + "chainId": 1, + "address": "0xcaeaf8381d4b20b43afa42061d6f80319a8881f6", + "name": "R34P", + "symbol": "R34P", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13393/thumb/r34p_logo.png?1608100330" + }, + { + "chainId": 1, + "address": "0x4be40bc9681d0a7c24a99b4c92f85b9053fc2a45", + "name": "Dify Finance", + "symbol": "YFIII", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12628/thumb/zNTAjrF.png?1601294851" + }, + { + "chainId": 1, + "address": "0xd2f29748f8698606dca9f48b8967241b595ab9e5", + "name": "Icarus Network", + "symbol": "ICA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16325/thumb/Icarusnetwork_200-200.png?1623742696" + }, + { + "chainId": 1, + "address": "0xce391315b414d4c7555956120461d21808a69f3a", + "name": "Bao Finance V2", + "symbol": "BAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28287/thumb/BAOv2_128px.png?1669344588" + }, + { + "chainId": 1, + "address": "0x28dee01d53fed0edf5f6e310bf8ef9311513ae40", + "name": "BlitzPick", + "symbol": "XBP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2458/thumb/BlitzPredict.jpg?1547701183" + }, + { + "chainId": 1, + "address": "0xf61bf4d1a948487d61b8fa63808aac06bda55f98", + "name": "Tr3zor", + "symbol": "TR3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21980/thumb/9T9OoYXE_400x400.jpg?1640573690" + }, + { + "chainId": 1, + "address": "0x9ae380f0272e2162340a5bb646c354271c0f5cfc", + "name": "Conic", + "symbol": "CNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24747/thumb/MJEDO-OY_400x400.png?1648785199" + }, + { + "chainId": 1, + "address": "0x254417f7b56328a48f554b173dca7bdda7a2a0d2", + "name": "Simba", + "symbol": "SIMBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16060/thumb/200x200_%2819%29.png?1622710548" + }, + { + "chainId": 1, + "address": "0x36905fc93280f52362a1cbab151f25dc46742fb5", + "name": "Bottos", + "symbol": "BTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2048/thumb/bottos.png?1517478551" + }, + { + "chainId": 1, + "address": "0x584b44853680ee34a0f337b712a8f66d816df151", + "name": "AI Doctor", + "symbol": "AIDOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2449/thumb/aidoc.png?1547036587" + }, + { + "chainId": 1, + "address": "0xdf7ff54aacacbff42dfe29dd6144a69b629f8c9e", + "name": "Aave ZRX", + "symbol": "AZRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14264/thumb/aZRX.9be555a9.png?1615528286" + }, + { + "chainId": 1, + "address": "0x5e6b6d9abad9093fdc861ea1600eba1b355cd940", + "name": "IoT Chain", + "symbol": "ITC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1304/thumb/iot-chain-logo.png?1547035331" + }, + { + "chainId": 1, + "address": "0xbf494f02ee3fde1f20bee6242bce2d1ed0c15e47", + "name": "World", + "symbol": "WORLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13801/thumb/WORLD.png?1612843088" + }, + { + "chainId": 1, + "address": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", + "name": "Curve fi FRAX USDC", + "symbol": "CRVFRAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26829/thumb/W1sQNVWo_400x400.jpeg?1660294792" + }, + { + "chainId": 1, + "address": "0x11613b1f840bb5a40f8866d857e24da126b79d73", + "name": "Cappasity", + "symbol": "CAPP", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/1302/thumb/cappasity.png?1547564648" + }, + { + "chainId": 1, + "address": "0xa4e27ea37d18bb0f483779f9e75a6024efa5e73e", + "name": "Monastery Finance", + "symbol": "MONK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24563/thumb/s0vLTcH.png?1648189796" + }, + { + "chainId": 1, + "address": "0xc08515d77c8e20d5957df9ad492e426020be64fe", + "name": "Non Fungible Media Token", + "symbol": "NFMT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26880/thumb/6mZw77As_400x400.jpeg?1660636409" + }, + { + "chainId": 1, + "address": "0x0e8d6b471e332f140e7d9dbb99e5e3822f728da6", + "name": "Abyss", + "symbol": "ABYSS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2105/thumb/NrFmpxs.png?1600318377" + }, + { + "chainId": 1, + "address": "0x0352557b007a4aae1511c114409b932f06f9e2f4", + "name": "sRUNE", + "symbol": "SRUNE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14953/thumb/sRUNE.png?1619129376" + }, + { + "chainId": 1, + "address": "0x6ab4a7d75b0a42b6bc83e852dab9e121f9c610aa", + "name": "Elitium", + "symbol": "EUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7874/thumb/elitium-coin.png?1551864695" + }, + { + "chainId": 1, + "address": "0x721a1b990699ee9d90b6327faad0a3e840ae8335", + "name": "Lootex", + "symbol": "LOOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22895/thumb/loot.png?1642850037" + }, + { + "chainId": 1, + "address": "0xfb782396c9b20e564a64896181c7ac8d8979d5f4", + "name": "Divergence Protocol", + "symbol": "DIVER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18666/thumb/DIVER.jpg?1632837940" + }, + { + "chainId": 1, + "address": "0x903bef1736cddf2a537176cf3c64579c3867a881", + "name": "Legacy ICHI", + "symbol": "ICHI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26004/thumb/legacy.png?1655278844" + }, + { + "chainId": 1, + "address": "0x612e1726435fe38dd49a0b35b4065b56f49c8f11", + "name": "CryptoCart V2", + "symbol": "CCV2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15210/thumb/DP7-T6rox-400x400_%281%29.png?1638928576" + }, + { + "chainId": 1, + "address": "0xe95990825aab1a7f0af4cc648f76a3bcc99f25b2", + "name": "Zenswap Network ZNT", + "symbol": "ZNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6452/thumb/3CGDn4e.png?1547042648" + }, + { + "chainId": 1, + "address": "0x4b0f027d0b694aae2761ed2d426295d4f949f5d0", + "name": "Pollchain", + "symbol": "POLL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19034/thumb/pollchain.PNG?1634197337" + }, + { + "chainId": 1, + "address": "0x9af839687f6c94542ac5ece2e317daae355493a1", + "name": "Hydro Protocol", + "symbol": "HOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2570/thumb/Hydro-Protocol.png?1558069424" + }, + { + "chainId": 1, + "address": "0x22b6c31c2beb8f2d0d5373146eed41ab9ede3caf", + "name": "cocktailbar finance", + "symbol": "COC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13121/thumb/coc.png?1647079316" + }, + { + "chainId": 1, + "address": "0x21413c119b0c11c5d96ae1bd328917bc5c8ed67e", + "name": "GenomesDAO", + "symbol": "GENE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20807/thumb/1637683704200x200.png?1637708934" + }, + { + "chainId": 1, + "address": "0x0db8d8b76bc361bacbb72e2c491e06085a97ab31", + "name": "IQeon", + "symbol": "IQN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1736/thumb/IQN_logo_64x64.png?1547036010" + }, + { + "chainId": 1, + "address": "0xb620be8a1949aa9532e6a3510132864ef9bc3f82", + "name": "Lend Flare Dao", + "symbol": "LFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24846/thumb/e5x55-kU_400x400.jpg?1649116244" + }, + { + "chainId": 1, + "address": "0x107c4504cd79c5d2696ea0030a8dd4e92601b82e", + "name": "Bloom", + "symbol": "BLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2662/thumb/bloom.png?1547036854" + }, + { + "chainId": 1, + "address": "0xc81946c6e0e15163b14abd4b5008f3d900b2a736", + "name": "Sakaryaspor", + "symbol": "SKRY", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/22042/thumb/16529.png?1640674353" + }, + { + "chainId": 1, + "address": "0xa00055e6ee4d1f4169096ecb682f70caa8c29987", + "name": "WIVA", + "symbol": "WIVA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18142/thumb/n8Vu43vs.png?1630656531" + }, + { + "chainId": 1, + "address": "0x7e291890b01e5181f7ecc98d79ffbe12ad23df9e", + "name": "Unifty", + "symbol": "NIF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13726/thumb/logo_transparent.png?1628254980" + }, + { + "chainId": 1, + "address": "0x591127253e40d4f63bf29ccf3d81fd062a149c8c", + "name": "TTX Metaverse", + "symbol": "XMETA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23332/thumb/xmeta.png?1644907223" + }, + { + "chainId": 1, + "address": "0x9e6c59321ceb205d5d3bc6c539c017af6159b16c", + "name": "MindCell", + "symbol": "MDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17894/thumb/oemzNgO.png?1629720177" + }, + { + "chainId": 1, + "address": "0x4ee4f96838454e67fce92b2c53b0f1a97d047179", + "name": "MeebitsDAO Pool", + "symbol": "MBBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20986/thumb/ZgVuisG__400x400.jpg?1638168731" + }, + { + "chainId": 1, + "address": "0xeeee2a622330e6d2036691e983dee87330588603", + "name": "Asko", + "symbol": "ASKO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11773/thumb/ASKO.png?1662435680" + }, + { + "chainId": 1, + "address": "0xdd039990bd551ce7437d3bf54d155220b7988b71", + "name": "Degens", + "symbol": "DEGENS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14526/thumb/degens_logo.png?1616740013" + }, + { + "chainId": 1, + "address": "0xf79f9020560963422ecc9c0c04d3a21190bbf045", + "name": "Baby Saitama", + "symbol": "BABYSAITAMA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17584/thumb/babysaitama.png?1635907049" + }, + { + "chainId": 1, + "address": "0xedd7c94fd7b4971b916d15067bc454b9e1bad980", + "name": "Zippie", + "symbol": "ZIPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4302/thumb/zippie.jpg?1547039665" + }, + { + "chainId": 1, + "address": "0x7d1afa7b718fb893db30a3abc0cfc608aacfebb0", + "name": "Polygon", + "symbol": "MATIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4713/thumb/matic-token-icon.png?1624446912" + }, + { + "chainId": 1, + "address": "0xd31695a1d35e489252ce57b129fd4b1b05e6acac", + "name": "TOKPIE", + "symbol": "TKP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3731/thumb/tokpie-200x200.png?1562207865" + }, + { + "chainId": 1, + "address": "0xc73c167e7a4ba109e4052f70d5466d0c312a344d", + "name": "Sanshu Inu", + "symbol": "SANSHU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15370/thumb/m9DgRlXY.jpg?1623177779" + }, + { + "chainId": 1, + "address": "0x0f2d719407fdbeff09d87557abb7232601fd9f29", + "name": "Synapse", + "symbol": "SYN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18024/thumb/synapse_social_icon.png?1663921797" + }, + { + "chainId": 1, + "address": "0x10086399dd8c1e3de736724af52587a2044c9fa2", + "name": "The Midas Touch Gold", + "symbol": "TMTG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6255/thumb/the_midas_touch_gold.png?1547042292" + }, + { + "chainId": 1, + "address": "0x5bc25f649fc4e26069ddf4cf4010f9f706c23831", + "name": "DefiDollar", + "symbol": "DUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12333/thumb/defidollar_logo.png?1599116360" + }, + { + "chainId": 1, + "address": "0x97e6e31afb2d93d437301e006d9da714616766a5", + "name": "Midas", + "symbol": "MIDAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6453/thumb/OMrkHMb.png?1547042650" + }, + { + "chainId": 1, + "address": "0x89fb927240750c1b15d4743cd58440fc5f14a11c", + "name": "Attila", + "symbol": "ATT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11337/thumb/LOGO_%2874%29.png?1589942265" + }, + { + "chainId": 1, + "address": "0xdd2e93924bdd4e20c3cf4a8736e5955224fa450e", + "name": "Foho Coin", + "symbol": "FOHO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17933/thumb/FOHO.Coin_colour-02-1.png?1629859400" + }, + { + "chainId": 1, + "address": "0xb3999f658c0391d94a37f7ff328f3fec942bcadc", + "name": "Hashflow", + "symbol": "HFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26136/thumb/hashflow-icon-cmc.png?1668345672" + }, + { + "chainId": 1, + "address": "0x2c537e5624e4af88a7ae4060c022609376c8d0eb", + "name": "BiLira", + "symbol": "TRYB", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/10119/thumb/JBs9jiXO_400x400.jpg?1642668342" + }, + { + "chainId": 1, + "address": "0x8baef8c9568c21b1a2b2fd048f8b4da835691fd0", + "name": "USD ZEE", + "symbol": "USDZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24876/thumb/003.png?1649217016" + }, + { + "chainId": 1, + "address": "0xbbe761ea1447a20b75aa485b7bcad4837415d7d7", + "name": "Global Crypto Alliance", + "symbol": "CALL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10276/thumb/gca-favicon.png?1576969530" + }, + { + "chainId": 1, + "address": "0xe18024f4838962d61eb591982390dffc762f2cd7", + "name": "JoJo Inu", + "symbol": "JOJO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19149/thumb/jojo_logo_200.png?1634535364" + }, + { + "chainId": 1, + "address": "0x3fa400483487a489ec9b1db29c4129063eec4654", + "name": "Cryptokek", + "symbol": "KEK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13513/thumb/Cryptokek-Logo-256px.png?1609292074" + }, + { + "chainId": 1, + "address": "0xb1191f691a355b43542bea9b8847bc73e7abb137", + "name": "KIRO", + "symbol": "KIRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12688/thumb/logo_kirobo-04.png?1668683315" + }, + { + "chainId": 1, + "address": "0xe531642e9bb5d027e9c20e03284287b97919a9a5", + "name": "FaithCoin", + "symbol": "FAITH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3648/thumb/Y4u0Cl8.png?1547038612" + }, + { + "chainId": 1, + "address": "0x57c411e9a358e2d2d0a6b058cedb709175e8fd16", + "name": "Kodachi Token", + "symbol": "KODACHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26927/thumb/logo200_%282%29.png?1660874765" + }, + { + "chainId": 1, + "address": "0xa113b79c09f0794568b8864a24197e0b817041ea", + "name": "PINK PANTHER", + "symbol": "PINK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18822/thumb/logopp.png?1633520496" + }, + { + "chainId": 1, + "address": "0x7671904eed7f10808b664fc30bb8693fd7237abf", + "name": "Bitberry", + "symbol": "BBR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13673/thumb/1_AdMyBccrRv0e6rhW7UKJSw.png?1610681228" + }, + { + "chainId": 1, + "address": "0x3516415161c478df10adbb8bb884cc83fbd5f11a", + "name": "AlphaDex", + "symbol": "DEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12949/thumb/AlphaDex.png?1603779030" + }, + { + "chainId": 1, + "address": "0x8a854288a5976036a725879164ca3e91d30c6a1b", + "name": "GET Protocol", + "symbol": "GET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1927/thumb/GET_Protocol.png?1552893230" + }, + { + "chainId": 1, + "address": "0xdf7a6a1214b3cbd3f9812434437f61a0d4cbbe1f", + "name": "ALFweb3Project", + "symbol": "ALFW3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26643/thumb/ALFw3_200.png?1659351452" + }, + { + "chainId": 1, + "address": "0x9f9913853f749b3fe6d6d4e16a1cc3c1656b6d51", + "name": "BITT", + "symbol": "BITT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13783/thumb/BITT_Logo_256pixels.png?1611733961" + }, + { + "chainId": 1, + "address": "0x836a808d4828586a69364065a1e064609f5078c7", + "name": "pETH", + "symbol": "PETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28376/thumb/peth.png?1669968949" + }, + { + "chainId": 1, + "address": "0x740623d2c797b7d8d1ecb98e9b4afcf99ec31e14", + "name": "DoYourTip", + "symbol": "DYT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8936/thumb/image1.png?1578033515" + }, + { + "chainId": 1, + "address": "0x345dadb10a200f10814ad8523fca0f2d958c3370", + "name": "Kori Inu", + "symbol": "KORI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21555/thumb/kori.png?1639465507" + }, + { + "chainId": 1, + "address": "0xf45091f25d374bbe956c0bb64bb85e02d07aa741", + "name": "MNMCoin", + "symbol": "MNMC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11163/thumb/MNMC.png?1589280919" + }, + { + "chainId": 1, + "address": "0x6cfb6df56bbdb00226aeffcdb2cd1fe8da1abda7", + "name": "Komet", + "symbol": "KOMET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13196/thumb/komet_finance_logo.png?1606120745" + }, + { + "chainId": 1, + "address": "0xdaf88906ac1de12ba2b1d2f7bfc94e9638ac40c4", + "name": "EpiK Protocol", + "symbol": "EPK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15188/thumb/epk.PNG?1620078400" + }, + { + "chainId": 1, + "address": "0x6595b8fd9c920c81500dca94e53cdc712513fb1f", + "name": "Olyverse", + "symbol": "OLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13983/thumb/oly-logo.png?1613461530" + }, + { + "chainId": 1, + "address": "0xbcdfe338d55c061c084d81fd793ded00a27f226d", + "name": "Decentralized Machine Learning Protocol", + "symbol": "DML", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3297/thumb/decentralized-machine-learning.png?1547037880" + }, + { + "chainId": 1, + "address": "0x6ee0f7bb50a54ab5253da0667b0dc2ee526c30a8", + "name": "Aave BUSD v1", + "symbol": "ABUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11736/thumb/aBUSD.png?1593085489" + }, + { + "chainId": 1, + "address": "0xd04785c4d8195e4a54d9dec3a9043872875ae9e2", + "name": "Rotten", + "symbol": "ROT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12560/thumb/rot_logo.png?1600762626" + }, + { + "chainId": 1, + "address": "0x7fc3ec3574d408f3b59cd88709bacb42575ebf2b", + "name": "POP", + "symbol": "POP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14598/thumb/pop.png?1617195542" + }, + { + "chainId": 1, + "address": "0x24a6a37576377f63f194caa5f518a60f45b42921", + "name": "Float Protocol", + "symbol": "BANK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14116/thumb/FLOAT-Bank_LOGO-reduced_01.png?1616573606" + }, + { + "chainId": 1, + "address": "0xb78b3320493a4efaa1028130c5ba26f0b6085ef8", + "name": "Dracula", + "symbol": "DRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12758/thumb/DRC-LOGO.png?1648050189" + }, + { + "chainId": 1, + "address": "0x7e9d8f07a64e363e97a648904a89fb4cd5fb94cd", + "name": "Forefront", + "symbol": "FF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14659/thumb/N2kir6jx_400x400.jpg?1617608020" + }, + { + "chainId": 1, + "address": "0xfcf8eda095e37a41e002e266daad7efc1579bc0a", + "name": "FLEX Coin", + "symbol": "FLEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9108/thumb/coinflex_logo.png?1628750583" + }, + { + "chainId": 1, + "address": "0x049399a6b048d52971f7d122ae21a1532722285f", + "name": "Fire Lotto", + "symbol": "FLOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2201/thumb/fire-lotto.png?1548126078" + }, + { + "chainId": 1, + "address": "0x0d97fee619d955509e54b046c9992b6e9f5b0630", + "name": "PONY Index", + "symbol": "PONY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26131/thumb/pfemoji.png?1655964722" + }, + { + "chainId": 1, + "address": "0x7409856cae628f5d578b285b45669b36e7005283", + "name": "Jarvis Synthetic British Pound", + "symbol": "JGBP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15726/thumb/jGBP.png?1634046064" + }, + { + "chainId": 1, + "address": "0xa6586e19ef681b1ac0ed3d46413d199a555dbb95", + "name": "Lets Go Brandon", + "symbol": "LETSGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24034/thumb/3zKU0T83_400x400.jpeg?1646117523" + }, + { + "chainId": 1, + "address": "0xb6f43025b29196af2dddd69b0a58afba079cd600", + "name": "Intelligent Investment Chain", + "symbol": "IIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4307/thumb/intelligent-investment-chain.png?1547974303" + }, + { + "chainId": 1, + "address": "0x6839ac5ea8082688b706c773d5d2afd7d503fdd4", + "name": "Next Level", + "symbol": "NXL", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/15178/thumb/NXL-token-logo-200.png?1620026497" + }, + { + "chainId": 1, + "address": "0x64a77277e37d44957fe5815d6ff442ab8b16cc29", + "name": "SpaceDawgs", + "symbol": "DAWGS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17076/thumb/twitter-facebook-Instagram-pfp.png?1646792743" + }, + { + "chainId": 1, + "address": "0x1d96fd43ee07aa79f8fd003cbdf404fb5ce41ad2", + "name": "Qawalla", + "symbol": "QWLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15242/thumb/qwla.png?1648268288" + }, + { + "chainId": 1, + "address": "0xb3cc3d7e656893f22d2372b0ae57106f6b155cbe", + "name": "Dogger", + "symbol": "DOGGER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25460/thumb/GC94Zwub_400x400.jpg?1651822625" + }, + { + "chainId": 1, + "address": "0x076641af1b8f06b7f8c92587156143c109002cbe", + "name": "SoPay", + "symbol": "SOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6736/thumb/sopay.png?1548609877" + }, + { + "chainId": 1, + "address": "0xd01ef7c0a5d8c432fc2d1a85c66cf2327362e5c6", + "name": "Ankr Reward Earning Staked ETH", + "symbol": "AETHB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18777/thumb/aETHb.png?1633402302" + }, + { + "chainId": 1, + "address": "0x60f63b76e2fc1649e57a3489162732a90acf59fe", + "name": "Flurry Finance", + "symbol": "FLURRY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16235/thumb/flurry_logo_only_200x200.png?1623365114" + }, + { + "chainId": 1, + "address": "0xfc2c4d8f95002c14ed0a7aa65102cac9e5953b5e", + "name": "Rublix", + "symbol": "RBLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3253/thumb/rblx.png?1547037780" + }, + { + "chainId": 1, + "address": "0x014550a34149231b8432b8dd210fadd81b1d2668", + "name": "SHEESHETH", + "symbol": "SHEESH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26678/thumb/LOGO.png?1659522896" + }, + { + "chainId": 1, + "address": "0x29127fe04ffa4c32acac0ffe17280abd74eac313", + "name": "SIFU", + "symbol": "SIFU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24692/thumb/token_%283%29.png?1648620836" + }, + { + "chainId": 1, + "address": "0x1460a58096d80a50a2f1f956dda497611fa4f165", + "name": "WeOwn", + "symbol": "CHX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1943/thumb/ZlGXwUDv_400x400.jpg?1571388675" + }, + { + "chainId": 1, + "address": "0x5fc251c13c4ef172d87a32ab082897132b49435c", + "name": "Kayserispor", + "symbol": "KYSR", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/21930/thumb/YQKw1S0__400x400.jpg?1640299486" + }, + { + "chainId": 1, + "address": "0x04b5e13000c6e9a3255dc057091f3e3eeee7b0f0", + "name": "Unifund", + "symbol": "IFUND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12833/thumb/unifund_logo.png?1602859047" + }, + { + "chainId": 1, + "address": "0xd559f20296ff4895da39b5bd9add54b442596a61", + "name": "FintruX", + "symbol": "FTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1928/thumb/token-500x500.png?1547036223" + }, + { + "chainId": 1, + "address": "0x0a255f700b16c0acf5673565c757b94fb38b27f2", + "name": "NeoWorld Cash", + "symbol": "NASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6737/thumb/D7F231BA7E294954A0C2C4EBA6BCEFEB.png?1547042977" + }, + { + "chainId": 1, + "address": "0x189fc141854bfc6146777406d53fbc89f4e70407", + "name": "Ceji", + "symbol": "CEJI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26458/thumb/CEJI.png?1658129614" + }, + { + "chainId": 1, + "address": "0x42bedd647e387dabec65a7dc3a3babcc68bb664d", + "name": "BlockMason Link", + "symbol": "BLINK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8525/thumb/link-by-blockmason.jpg?1559103173" + }, + { + "chainId": 1, + "address": "0x8f3470a7388c05ee4e7af3d01d8c722b0ff52374", + "name": "Veritaseum", + "symbol": "VERI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/695/thumb/veritaseum.png?1547034460" + }, + { + "chainId": 1, + "address": "0x33d0568941c0c64ff7e0fb4fba0b11bd37deed9f", + "name": "RAMP OLD ", + "symbol": "RAMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12837/thumb/RAMP-Logo-v2-1000pxsq.png?1617952606" + }, + { + "chainId": 1, + "address": "0xe276056f924e15beac26f7b10b6d2805f9c64bb5", + "name": "Firulais", + "symbol": "FIRU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17564/thumb/firulais.jpg?1628321879" + }, + { + "chainId": 1, + "address": "0x9b75848172677042269c63365b57b0a51c21d031", + "name": "Options Market", + "symbol": "OSM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14562/thumb/OSM_Logo.png?1642667815" + }, + { + "chainId": 1, + "address": "0x14b40ad2eba6c1b31db2ba817b07578afb414415", + "name": "colR Coin", + "symbol": "COLR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26701/thumb/colverse.jpeg?1659662193" + }, + { + "chainId": 1, + "address": "0x0fe156436f203b114c6c562cb1a2a81aa2801090", + "name": "SKINCHAIN", + "symbol": "SKC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10878/thumb/8ZtRME2h_400x400.jpg?1585472542" + }, + { + "chainId": 1, + "address": "0xd1766a85b0d6f81185782dc07f15326d63c3cbaa", + "name": "TokenTuber", + "symbol": "TUBER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9617/thumb/Wlk5tQQe_400x400.png?1569853753" + }, + { + "chainId": 1, + "address": "0xdc524e3c6910257744c1f93cf15e9f472b5bd236", + "name": "Witch Token", + "symbol": "WITCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17205/thumb/download_%2829%29.png?1626848072" + }, + { + "chainId": 1, + "address": "0x79be75ffc64dd58e66787e4eae470c8a1fd08ba4", + "name": "Aave AMM DAI", + "symbol": "AAMMDAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17197/thumb/aAMMDAI_2x.png?1626940032" + }, + { + "chainId": 1, + "address": "0x12b6893ce26ea6341919fe289212ef77e51688c8", + "name": "Tamadoge", + "symbol": "TAMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27501/thumb/CaltNDWu_400x400.jpeg?1664329157" + }, + { + "chainId": 1, + "address": "0x011864d37035439e078d64630777ec518138af05", + "name": "Zerogoki", + "symbol": "REI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17015/thumb/iconZerogoki.png?1626618921" + }, + { + "chainId": 1, + "address": "0x896e145568624a498c5a909187363ae947631503", + "name": "WasabiX", + "symbol": "WASABI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14522/thumb/WASABI.299ec8f7.png?1616721315" + }, + { + "chainId": 1, + "address": "0xcccbf11ac3030ee8cd7a04cfe15a3718df6dd030", + "name": "Gan Punks", + "symbol": "GPUNKS20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17859/thumb/unnamed_%282%29.gif?1629683073" + }, + { + "chainId": 1, + "address": "0x0a41e6d4d4897e8cec819ce7d10b2d7cda61dc94", + "name": "YCLUB", + "symbol": "SYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28267/thumb/9DC88DDF-CAB3-410A-87BA-6AB98DCD1B86.jpeg?1668771177" + }, + { + "chainId": 1, + "address": "0x6c5ba91642f10282b576d91922ae6448c9d52f4e", + "name": "Phala Network", + "symbol": "PHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12451/thumb/phala.png?1600061318" + }, + { + "chainId": 1, + "address": "0xcf8829ae9384540c886a151fac3a865794cb9a01", + "name": "SyncDAO Governance", + "symbol": "SDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21085/thumb/SyncDAO-s-icon_1_200x200.png?1638312055" + }, + { + "chainId": 1, + "address": "0x90e2fa98dfc518317600dd3dc571de8d071a7238", + "name": "Token of Fire", + "symbol": "RHLLOR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28100/thumb/logo_200x.png?1667539104" + }, + { + "chainId": 1, + "address": "0xc2a81eb482cb4677136d8812cc6db6e0cb580883", + "name": "TFS", + "symbol": "TFS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21963/thumb/dOF2IBa.png?1640524604" + }, + { + "chainId": 1, + "address": "0xdf3f28189516647f8cd2414b6add5ac948f3fc41", + "name": "XAEA Xii", + "symbol": "XAEA-XII", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23325/thumb/xNXRIgWn_400x400.jpg?1643839082" + }, + { + "chainId": 1, + "address": "0x87b008e57f640d94ee44fd893f0323af933f9195", + "name": "Coin Artist", + "symbol": "COIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12375/thumb/coin_artist_logo.png?1599403918" + }, + { + "chainId": 1, + "address": "0x9c659cb48c4406cd2857aeceff1609b2db280d0e", + "name": "Alita Network", + "symbol": "ALITA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17329/thumb/2LbKO1Yk_400x400.jpg?1627340043" + }, + { + "chainId": 1, + "address": "0x31024a4c3e9aeeb256b825790f5cb7ac645e7cd5", + "name": "Xiotri", + "symbol": "XIOT", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/12182/thumb/xiot_logo_512x512.png?1601775223" + }, + { + "chainId": 1, + "address": "0x8642a849d0dcb7a15a974794668adcfbe4794b56", + "name": "Prosper", + "symbol": "PROS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13668/thumb/heD6cg22l3sF5VgPh4G1xC6lnKEWXJif-jbaqUpv8CDP6jbWaqn9UjBdkXWNrw1CewaQOxb8zXRdNeNJWWiUDjfsEl_d7E3bPLg4cFoilQF5TGKHfWyJlnpm3UYc9ytvRvOjxOevMuiu8-lusnNoOcwgsJpMkYWHqe322GAxLt0_30kFMVAcjEDUrOlkK6hUYi0m9P433mvNlOm.jpg?1610671732" + }, + { + "chainId": 1, + "address": "0x5dbe296f97b23c4a6aa6183d73e574d02ba5c719", + "name": "Level Up Coin", + "symbol": "LUC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1772/thumb/luc.png?1547036065" + }, + { + "chainId": 1, + "address": "0x9501bfc48897dceeadf73113ef635d2ff7ee4b97", + "name": "easyMine", + "symbol": "EMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1749/thumb/emt.png?1547036034" + }, + { + "chainId": 1, + "address": "0x009668a9691e456972c8ec4cc84e99486308b84d", + "name": "Terareum", + "symbol": "TERA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23880/thumb/Tera-200x200-1.png?1645600935" + }, + { + "chainId": 1, + "address": "0xf6832ea221ebfdc2363729721a146e6745354b14", + "name": "FRMx", + "symbol": "FRMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13082/thumb/frmx.png?1660311822" + }, + { + "chainId": 1, + "address": "0xf028adee51533b1b47beaa890feb54a457f51e89", + "name": "BMCHAIN", + "symbol": "BMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7419/thumb/bchain_logo.jpg?1547199925" + }, + { + "chainId": 1, + "address": "0xb0e99627bc29adef1178f16117bf495351e81997", + "name": "Dex Trade Coin", + "symbol": "DXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15025/thumb/R1A63oDx_400x400.jpg?1619489389" + }, + { + "chainId": 1, + "address": "0x5fbc3cb8b428cc00a04808870295d39962cc7fee", + "name": "Bitazza", + "symbol": "BTZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24597/thumb/BTZ_Logo_%28200x200%29.png?1649777047" + }, + { + "chainId": 1, + "address": "0xbc276f51184ec085cd1437601ecb4bbc3d981896", + "name": "Shibtama", + "symbol": "SHIBTAMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23362/thumb/shibtama.png?1643946565" + }, + { + "chainId": 1, + "address": "0x40d1f63b5d2048e67e9bedb1b4c2f1a9fb4b6817", + "name": "Golden Goose", + "symbol": "GOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7892/thumb/tsRcntSR_400x400.png?1611024068" + }, + { + "chainId": 1, + "address": "0xc86d054809623432210c107af2e3f619dcfbf652", + "name": "Sentinel Protocol", + "symbol": "UPP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3369/thumb/Sentinel_Protocol.jpg?1547700074" + }, + { + "chainId": 1, + "address": "0x00f29171d7bcdc464a0758cf3217fe83173772b9", + "name": "INU", + "symbol": "INU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16898/thumb/logo.png?1632227807" + }, + { + "chainId": 1, + "address": "0x5fa54fddf1870c344dbfabb37dfab8700ec0def1", + "name": "FrogeX", + "symbol": "FROGEX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14775/thumb/-p8cz7Bk_400x400.png?1618371907" + }, + { + "chainId": 1, + "address": "0xb8baa0e4287890a5f79863ab62b7f175cecbd433", + "name": "Swerve", + "symbol": "SWRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12361/thumb/swerve.png?1599278316" + }, + { + "chainId": 1, + "address": "0x9992ec3cf6a55b00978cddf2b27bc6882d88d1ec", + "name": "Polymath", + "symbol": "POLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2784/thumb/inKkF01.png?1605007034" + }, + { + "chainId": 1, + "address": "0x2a039b1d9bbdccbb91be28691b730ca893e5e743", + "name": "Rentible", + "symbol": "RNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15176/thumb/Rentible-Token-Logo.png?1620025850" + }, + { + "chainId": 1, + "address": "0x0371a82e4a9d0a4312f3ee2ac9c6958512891372", + "name": "bitJob", + "symbol": "STU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1172/thumb/bitjob.jpg?1547035202" + }, + { + "chainId": 1, + "address": "0x32fb2a84af5515f77515806ea5addb54c923237d", + "name": "SOLO Vault NFTX ", + "symbol": "SOLO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18349/thumb/solo.png?1631603899" + }, + { + "chainId": 1, + "address": "0xde522a2778e4554707e6a8df36a4871ce9967bb5", + "name": "FormulA", + "symbol": "FML", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6878/thumb/formula_token.png?1547043223" + }, + { + "chainId": 1, + "address": "0x81b1bfd6cb9ad42db395c2a27f73d4dcf5777e2d", + "name": "Rare", + "symbol": "RARE", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/12868/thumb/rare_logo.png?1603170092" + }, + { + "chainId": 1, + "address": "0xcfcecfe2bd2fed07a9145222e8a7ad9cf1ccd22a", + "name": "Adshares", + "symbol": "ADS", + "decimals": 11, + "logoURI": "https://assets.coingecko.com/coins/images/868/thumb/rnO9DyJ.png?1663921311" + }, + { + "chainId": 1, + "address": "0x46d473a0b3eeec9f55fade641bc576d5bc0b2246", + "name": "SurfExUtilityToken", + "symbol": "SURF", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10783/thumb/200x200-logo-blu-grey-bkg-4-e1583512409629.png?1583539501" + }, + { + "chainId": 1, + "address": "0xd2057d71fe3f5b0dc1e3e7722940e1908fc72078", + "name": "King Swap", + "symbol": "KING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13622/thumb/rsz_king_token_new.png?1610437757" + }, + { + "chainId": 1, + "address": "0xaa99199d1e9644b588796f3215089878440d58e0", + "name": "Alphr", + "symbol": "ALPHR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15029/thumb/alphr.jpg?1619495712" + }, + { + "chainId": 1, + "address": "0x000000000000d0151e748d25b766e77efe2a6c83", + "name": "XDEFI Governance", + "symbol": "XDEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14485/thumb/logo.png?1616472896" + }, + { + "chainId": 1, + "address": "0x996dc5dfc819408dd98cd92c9a76f64b0738dc3d", + "name": "Skillchain", + "symbol": "SKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3780/thumb/SKI.png?1589121168" + }, + { + "chainId": 1, + "address": "0x92ec47df1aa167806dfa4916d9cfb99da6953b8f", + "name": "Idavoll DAO", + "symbol": "IDV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14229/thumb/71922199.png?1615169236" + }, + { + "chainId": 1, + "address": "0x297e4e5e59ad72b1b0a2fd446929e76117be0e0a", + "name": "Smart Valor", + "symbol": "VALOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7231/thumb/smart_valor.png?1555925772" + }, + { + "chainId": 1, + "address": "0xa4e8c3ec456107ea67d3075bf9e3df3a75823db0", + "name": "Loom Network OLD ", + "symbol": "LOOMOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3387/thumb/1_K76UVoLq-FOL7l-_Fag-Qw_2x.png?1547038040" + }, + { + "chainId": 1, + "address": "0xe63684bcf2987892cefb4caa79bd21b34e98a291", + "name": "Chicken", + "symbol": "KFC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12569/thumb/download.png?1600840301" + }, + { + "chainId": 1, + "address": "0x368bf9f1a1ca767935e39f20439d9041707e2634", + "name": "Chainflix", + "symbol": "CFXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17671/thumb/Logo_200_%282%29.png?1628822696" + }, + { + "chainId": 1, + "address": "0x65a8fba02f641a13bb7b01d5e1129b0521004f52", + "name": "Amasa", + "symbol": "AMAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18799/thumb/agmqWjv8_400x400.png?1633473272" + }, + { + "chainId": 1, + "address": "0x2f29ce2a733983978c01ae3e3c7f224ed0ef7e72", + "name": "Music Infinity", + "symbol": "MIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26290/thumb/20882.png?1657158988" + }, + { + "chainId": 1, + "address": "0x5d48f293baed247a2d0189058ba37aa238bd4725", + "name": "NeuroChain", + "symbol": "NCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3367/thumb/neurochain.png?1548085917" + }, + { + "chainId": 1, + "address": "0xb0280743b44bf7db4b6be482b2ba7b75e5da096c", + "name": "Transcodium", + "symbol": "TNS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2071/thumb/transcodium.png?1548759093" + }, + { + "chainId": 1, + "address": "0xb9d99c33ea2d86ec5ec6b8a4dd816ebba64404af", + "name": "K21", + "symbol": "K21", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14466/thumb/k21-token.png?1616775801" + }, + { + "chainId": 1, + "address": "0x65ef703f5594d2573eb71aaf55bc0cb548492df4", + "name": "Multichain", + "symbol": "MULTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22087/thumb/1_Wyot-SDGZuxbjdkaOeT2-A.png?1640764238" + }, + { + "chainId": 1, + "address": "0x0f5d2fb29fb7d3cfee444a200298f468908cc942", + "name": "Decentraland", + "symbol": "MANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/878/thumb/decentraland-mana.png?1550108745" + }, + { + "chainId": 1, + "address": "0x6393e822874728f8afa7e1c9944e417d37ca5878", + "name": "Cryptoindex com 100", + "symbol": "CIX100", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6106/thumb/cix.png?1563780642" + }, + { + "chainId": 1, + "address": "0xae36155a55f04a696b8362777620027882b31db5", + "name": "Kishimoto", + "symbol": "KISHIMOTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28011/thumb/kishimoto.png?1666944015" + }, + { + "chainId": 1, + "address": "0xf278c1ca969095ffddded020290cf8b5c424ace2", + "name": "Ruff", + "symbol": "RUFF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2726/thumb/ruff.png?1548608556" + }, + { + "chainId": 1, + "address": "0xc74cb1bbc2a1bc6e0c9e35ee176f832ad7cdb3ab", + "name": "Anons Network", + "symbol": "ANONS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22095/thumb/ANONS.png?1640795860" + }, + { + "chainId": 1, + "address": "0xe1aee98495365fc179699c1bb3e761fa716bee62", + "name": "Bezant", + "symbol": "BZNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3825/thumb/bezant.png?1546240528" + }, + { + "chainId": 1, + "address": "0x6295ab2be04a617747481b292c390bfca592cf28", + "name": "TokenDesk", + "symbol": "TDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1821/thumb/tokendesk.png?1548758709" + }, + { + "chainId": 1, + "address": "0x4d953cf077c0c95ba090226e59a18fcf97db44ec", + "name": "Mini", + "symbol": "MINI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12298/thumb/IrTAVc_GqZ7iQucAa3fNYlh_Cqt3tY9wM_pmzOl5SifscRMpuzrp_dizMzGTiMr_NxDJPCKigBgz8THrzvO_DqT3JLzqZIYeytDBRw3qKI73dljS0BnFaaI2aLadpdCZah4RkhydddLIDDbQlGit77farlQRaq7qEgxdjVe0aqEeh4phE-DWAKi_KS_Yz-fFdDfjWgifVCKkZRBeNSWWQEplxxl.jpg?1598961320" + }, + { + "chainId": 1, + "address": "0xdfddf7a69716124bc346ba556d4b9f9e74c4a8bc", + "name": "Succession", + "symbol": "SCCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25377/thumb/sccn.png?1651410204" + }, + { + "chainId": 1, + "address": "0xaa19961b6b858d9f18a115f25aa1d98abc1fdba8", + "name": "LocalCoinSwap", + "symbol": "LCS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3998/thumb/LocalCoinSwap.png?1547039086" + }, + { + "chainId": 1, + "address": "0x8a8116a794744977941c7d3743517410969aacbb", + "name": "Shiba Punkz", + "symbol": "SPUNK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27163/thumb/shibapunkzlogo.JPG?1662283310" + }, + { + "chainId": 1, + "address": "0xad22f63404f7305e4713ccbd4f296f34770513f4", + "name": "Atomic Wallet Coin", + "symbol": "AWC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7430/thumb/Atomic_Wallet_Aeron_%281%29.png?1547274057" + }, + { + "chainId": 1, + "address": "0xfb83869f7ee52aebaddea254f647953afb1f99f8", + "name": "Lean Management", + "symbol": "LEAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19602/thumb/tIajRRh.png?1635491525" + }, + { + "chainId": 1, + "address": "0xcb56b52316041a62b6b5d0583dce4a8ae7a3c629", + "name": "Cigarette", + "symbol": "CIG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22145/thumb/cig.png?1640929916" + }, + { + "chainId": 1, + "address": "0x0ace32f6e87ac1457a5385f8eb0208f37263b415", + "name": "Habitat", + "symbol": "HBT", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/14456/thumb/habitat-logo.png?1625495825" + }, + { + "chainId": 1, + "address": "0x97a3bd8a445cc187c6a751f392e15c3b2134d695", + "name": "Blockster", + "symbol": "BXR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19857/thumb/bxr-left2.png?1636064209" + }, + { + "chainId": 1, + "address": "0x256f2d67e52fe834726d2ddcd8413654f5eb8b53", + "name": "Solv Protocol", + "symbol": "SOLV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27987/thumb/Solv-Logo5.png?1666863912" + }, + { + "chainId": 1, + "address": "0x380291a9a8593b39f123cf39cc1cc47463330b1f", + "name": "Elite Swap", + "symbol": "ELT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13715/thumb/logo_-_2021-01-20T105016.992.png?1611111027" + }, + { + "chainId": 1, + "address": "0xe8272210954ea85de6d2ae739806ab593b5d9c51", + "name": "Alpha5", + "symbol": "A5T", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13848/thumb/a5t.jpg?1614652988" + }, + { + "chainId": 1, + "address": "0x9506d37f70eb4c3d79c398d326c871abbf10521d", + "name": "Media Licensing Token", + "symbol": "MLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15659/thumb/milc_200x200.png?1621511031" + }, + { + "chainId": 1, + "address": "0x672ef7e4fe230b5ca1466c5fdd40588d30fdf90a", + "name": "Wolves of Wall Street", + "symbol": "WOWS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14365/thumb/wows_logo.png?1615704838" + }, + { + "chainId": 1, + "address": "0x010d14d36c3ea6570d240ae3ac9d660398f7c48e", + "name": "XCF Token", + "symbol": "XCF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10987/thumb/xcf-icon-01-1-flat.png?1622195426" + }, + { + "chainId": 1, + "address": "0x64b986211c0cc675143f895c437b79c3cadf364a", + "name": "Grapefruit Coin", + "symbol": "GRPFT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17002/thumb/logo-square-1.png?1626061191" + }, + { + "chainId": 1, + "address": "0xf3c6327b4c58e38a7986edb4a8f236031708f280", + "name": "Hatayspor Token", + "symbol": "HATAY", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24813/thumb/5pj7q96D_400x400.png?1649027829" + }, + { + "chainId": 1, + "address": "0xee9e5eff401ee921b138490d00ca8d1f13f67a72", + "name": "Asian Fintech", + "symbol": "AFIN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7519/thumb/Afinlogo-200x200.png?1630048356" + }, + { + "chainId": 1, + "address": "0x72953a5c32413614d24c29c84a66ae4b59581bbf", + "name": "CLever", + "symbol": "CLEV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27727/thumb/%E6%88%AA%E5%B1%8F2022-10-12_%E4%B8%8A%E5%8D%8810.40.19.png?1665550689" + }, + { + "chainId": 1, + "address": "0x436da116249044e8b4464f0cf21dd93311d88190", + "name": "Colizeum", + "symbol": "ZEUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24448/thumb/AB0cGpnx_400x400.jpg?1647681843" + }, + { + "chainId": 1, + "address": "0xc2bde1a2fa26890c8e6acb10c91cc6d9c11f4a73", + "name": "Hashmasks", + "symbol": "MASK20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17856/thumb/unnamed_%284%29.jpg?1629681381" + }, + { + "chainId": 1, + "address": "0x943ed852dadb5c3938ecdc6883718df8142de4c8", + "name": "FansTime", + "symbol": "FTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4952/thumb/fanstime.png?1547395397" + }, + { + "chainId": 1, + "address": "0x491e136ff7ff03e6ab097e54734697bb5802fc1c", + "name": "Kattana", + "symbol": "KTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14739/thumb/256-256-1.png?1638363577" + }, + { + "chainId": 1, + "address": "0x4ec1b60b96193a64acae44778e51f7bff2007831", + "name": "Edge", + "symbol": "EDGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1848/thumb/EDGE.png?1632300420" + }, + { + "chainId": 1, + "address": "0x83f873388cd14b83a9f47fabde3c9850b5c74548", + "name": "Zero Utility", + "symbol": "ZUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12706/thumb/logo.png?1605007113" + }, + { + "chainId": 1, + "address": "0x15eabb7500e44b7fdb6e4051ca8deca430cf9fb8", + "name": "Dexfin", + "symbol": "DXF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13660/thumb/dxf-symbol.png?1610599440" + }, + { + "chainId": 1, + "address": "0xef2e239b21a81719abaabc6239e2e90859b44d9b", + "name": "Talent TTX", + "symbol": "TTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12770/thumb/ttx.png?1640758151" + }, + { + "chainId": 1, + "address": "0xda0c94c73d127ee191955fb46bacd7ff999b2bcd", + "name": "Stakeborg DAO", + "symbol": "STANDARD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20119/thumb/stquY-WB_400x400.jpg?1636522705" + }, + { + "chainId": 1, + "address": "0xf0c5831ec3da15f3696b4dad8b21c7ce2f007f28", + "name": "AXIS", + "symbol": "AXIS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/16972/thumb/lUeFYUeu_400x400.png?1625815058" + }, + { + "chainId": 1, + "address": "0x18aa7c90d3ae4c5bb219d0a2813f441704084625", + "name": "Decentralize Currency", + "symbol": "DCA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7673/thumb/DCA.png?1573037394" + }, + { + "chainId": 1, + "address": "0x9d3ee6b64e69ebe12a4bf0b01d031cb80f556ee4", + "name": "Amun Polygon Ecosystem Index", + "symbol": "PECO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19270/thumb/amun-peco.png?1634868167" + }, + { + "chainId": 1, + "address": "0xf8e06e4e4a80287fdca5b02dccecaa9d0954840f", + "name": "Truegame", + "symbol": "TGAME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2974/thumb/tgame.png?1518620605" + }, + { + "chainId": 1, + "address": "0xe6d2c3cb986db66818c14c7032db05d1d2a6ee74", + "name": "Finexbox", + "symbol": "FNB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8419/thumb/p1WP-viw_400x400.jpg?1558395663" + }, + { + "chainId": 1, + "address": "0xacd8f2523a4613eee78904354187c81bb05ae2b8", + "name": "Stand Cash", + "symbol": "SAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13542/thumb/sac.jpg?1609648101" + }, + { + "chainId": 1, + "address": "0x196f4727526ea7fb1e17b2071b3d8eaa38486988", + "name": "Reserve", + "symbol": "RSV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10952/thumb/rsv.png?1637983297" + }, + { + "chainId": 1, + "address": "0x29ceddcf0da3c1d8068a7dfbd0fb06c2e438ff70", + "name": "Freela", + "symbol": "FREL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15856/thumb/freela.PNG?1622164474" + }, + { + "chainId": 1, + "address": "0x465e07d6028830124be2e4aa551fbe12805db0f5", + "name": "Wrapped XMR by BTSE", + "symbol": "WXMR", + "decimals": 18 + }, + { + "chainId": 1, + "address": "0x39fbbabf11738317a448031930706cd3e612e1b9", + "name": "Wrapped XRP", + "symbol": "WXRP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19952/thumb/WXRP_revision-256px.png?1648530664" + }, + { + "chainId": 1, + "address": "0xff5c69e8edc6446a1898698adcf9b1149d5e0306", + "name": "Kishiburno", + "symbol": "KISHIBURNO", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/26751/thumb/coing_gecko.jpg?1660020251" + }, + { + "chainId": 1, + "address": "0xd23ac27148af6a2f339bd82d0e3cff380b5093de", + "name": "Siren", + "symbol": "SI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13955/thumb/Siren_Logo_circle_256px.png?1645684572" + }, + { + "chainId": 1, + "address": "0x0809bd190c94f4408e691c410e67bff0df5d225d", + "name": "Cryptonia Poker", + "symbol": "CNP", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/3615/thumb/cpc.png?1547038522" + }, + { + "chainId": 1, + "address": "0xa4bdb11dc0a2bec88d24a3aa1e6bb17201112ebe", + "name": "Stably USDS", + "symbol": "USDS", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/7596/thumb/Stably_USDS_-_Icon_%28Standard%29.png?1663824111" + }, + { + "chainId": 1, + "address": "0xada86b1b313d1d5267e3fc0bb303f0a2b66d0ea7", + "name": "Covesting", + "symbol": "COV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1950/thumb/covesting.png?1547036237" + }, + { + "chainId": 1, + "address": "0xe632ea2ef2cfd8fc4a2731c76f99078aef6a4b31", + "name": "THX Network", + "symbol": "THX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21323/thumb/logo-thx-resized-200-200.png?1638945575" + }, + { + "chainId": 1, + "address": "0x796e47b85a0d759f300f1de96a3583004235d4d8", + "name": "Electrum Dark", + "symbol": "ELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6469/thumb/logo_%2817%29.png?1547042683" + }, + { + "chainId": 1, + "address": "0x9b20dabcec77f6289113e61893f7beefaeb1990a", + "name": "FairGame", + "symbol": "FAIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2456/thumb/fairgame.png?1547036592" + }, + { + "chainId": 1, + "address": "0x1c84656cb4c286daa16f27d8b305f1053b5a8771", + "name": "Bro", + "symbol": "BRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24119/thumb/bro-256.png?1646384412" + }, + { + "chainId": 1, + "address": "0x8326bf664704966c984a3a46fa37d7a80a52dcf4", + "name": "Dogu Inu", + "symbol": "DOGU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28492/thumb/Coingecko_Dogu_Inu_logo.jpg?1671093591" + }, + { + "chainId": 1, + "address": "0x27201232579491ce9b116ac6f37d354cc723a2f3", + "name": "Mesefa", + "symbol": "SEFA", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10977/thumb/Sefa_Pool_Logo_Bleu.png?1636769260" + }, + { + "chainId": 1, + "address": "0x9f4909cc95fb870bf48c128c1fdbb5f482797632", + "name": "Guzzler", + "symbol": "GZLR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20970/thumb/Screenshot-2021-11-27-at-22-57-22.png?1638153729" + }, + { + "chainId": 1, + "address": "0xd1e06952708771f71e6dd18f06ee418f6e8fc564", + "name": "GazeTV", + "symbol": "GAZE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14717/thumb/Gaze_Icon_Positive.png?1617937326" + }, + { + "chainId": 1, + "address": "0xac0c8da4a4748d8d821a0973d00b157aa78c473d", + "name": "YFIONE", + "symbol": "YFO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13670/thumb/256.png?1610676054" + }, + { + "chainId": 1, + "address": "0xe23311294467654e0cab14cd32a169a41be5ca8e", + "name": "Chronoly", + "symbol": "CRNO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27752/thumb/Chronoly.jpeg?1665651796" + }, + { + "chainId": 1, + "address": "0xf77f4810e7521298a6e2a04f82a6c3492706d74f", + "name": "CoinMeet", + "symbol": "MEET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2688/thumb/coinmeet.png?1547036895" + }, + { + "chainId": 1, + "address": "0xcfef8857e9c80e3440a823971420f7fa5f62f020", + "name": "Confetti", + "symbol": "CFTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24524/thumb/confetti_28.png?1648021097" + }, + { + "chainId": 1, + "address": "0x40821cd074dfecb1524286923bc69315075b5c89", + "name": "Quai Dao", + "symbol": "QUAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13815/thumb/QUIA_32x32.png?1656133041" + }, + { + "chainId": 1, + "address": "0xed0e2041bfb5a426e5ed426a73765624e08bbb75", + "name": "FANZY", + "symbol": "FX1", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11117/thumb/FX.png?1604900016" + }, + { + "chainId": 1, + "address": "0x58002a6b6e659a16de9f02f529b10536e307b0d9", + "name": "Crypto Holding Frank", + "symbol": "CHFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11184/thumb/chft.png?1589523711" + }, + { + "chainId": 1, + "address": "0x30bcd71b8d21fe830e493b30e90befba29de9114", + "name": "Penguin Party Fish", + "symbol": "FISH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14359/thumb/Screen-Shot-2021-03-10-at-1-05-40-AM.png?1615629402" + }, + { + "chainId": 1, + "address": "0xf2f9a7e93f845b3ce154efbeb64fb9346fcce509", + "name": "UniPower", + "symbol": "POWER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11618/thumb/unipower.png?1591943398" + }, + { + "chainId": 1, + "address": "0x537edd52ebcb9f48ff2f8a28c51fcdb9d6a6e0d4", + "name": "Small Doge", + "symbol": "SDOG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15377/thumb/small_dog.PNG?1620693455" + }, + { + "chainId": 1, + "address": "0x9b9fb226e98c4e90db2830c9aefa9cfcbe3b000a", + "name": "KITTY Vault NFTX ", + "symbol": "KITTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17037/thumb/KITTY.png?1626145386" + }, + { + "chainId": 1, + "address": "0xdfdb7f72c1f195c5951a234e8db9806eb0635346", + "name": "Feisty Doge NFT", + "symbol": "NFD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17834/thumb/doge-fractionalized.png?1629390495" + }, + { + "chainId": 1, + "address": "0x26ddf6cabadcbf4f013841bd8d914830beb0d984", + "name": "Kuai", + "symbol": "KT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5314/thumb/kuai-token.png?1547040868" + }, + { + "chainId": 1, + "address": "0xc48b4814faed1ccc885dd6fde62a6474aecbb19a", + "name": "CoinMerge ERC20 ", + "symbol": "CMERGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17146/thumb/cmerge.png?1642926825" + }, + { + "chainId": 1, + "address": "0x581911b360b6eb3a14ef295a83a91dc2bce2d6f7", + "name": "MileVerse", + "symbol": "MVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13146/thumb/kXSdwuxD_400x400.jpg?1605668418" + }, + { + "chainId": 1, + "address": "0x78f225869c08d478c34e5f645d07a87d3fe8eb78", + "name": "PieDAO DEFI Large Cap", + "symbol": "DEFI+L", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12731/thumb/DeFi_L.png?1602070128" + }, + { + "chainId": 1, + "address": "0x72e9d9038ce484ee986fea183f8d8df93f9ada13", + "name": "SmartCredit", + "symbol": "SMARTCREDIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13036/thumb/smartcredit_logo_02_white_a-1.png?1604545479" + }, + { + "chainId": 1, + "address": "0x595832f8fc6bf59c85c527fec3740a1b7a361269", + "name": "Power Ledger", + "symbol": "POWR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1104/thumb/power-ledger.png?1547035082" + }, + { + "chainId": 1, + "address": "0xd5a98e77d1feb091344096301ea336a5c07a6a41", + "name": "Alpha Capital", + "symbol": "ACAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24044/thumb/gfSKeO3.png?1646289796" + }, + { + "chainId": 1, + "address": "0xf32aa187d5bc16a2c02a6afb7df1459d0d107574", + "name": "HachikoInu", + "symbol": "INU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16392/thumb/hachikoinu-200px.png?1626355242" + }, + { + "chainId": 1, + "address": "0xd69f306549e9d96f183b1aeca30b8f4353c2ecc3", + "name": "MCH Coin", + "symbol": "MCHC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15399/thumb/MCHC.jpg?1620721307" + }, + { + "chainId": 1, + "address": "0xc8d07671afba9492da95819de4ad10859e00ab7f", + "name": "CryptoCoinPay", + "symbol": "CCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7127/thumb/T9ywgTGYuoYBFagC3PzdSVNKHxZSPB6Kmz.png?1647433798" + }, + { + "chainId": 1, + "address": "0xef6344de1fcfc5f48c30234c16c1389e8cdc572c", + "name": "EncrypGen", + "symbol": "DNA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1215/thumb/encrypgen.png?1547393601" + }, + { + "chainId": 1, + "address": "0x1ad82fac4dfe68e68f22df9cb892b018e4541dba", + "name": "MarblePrix", + "symbol": "MARBLEX7", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28322/thumb/Mp_logo_2.png?1669379614" + }, + { + "chainId": 1, + "address": "0x4ce4c025692b3142dbde1cd432ef55b9a8d18701", + "name": "Decanect", + "symbol": "DCNT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27309/thumb/200-x-200-jpeg.jpg?1663239875" + }, + { + "chainId": 1, + "address": "0x56322c14cb5f53531c231b8f9ab178bf5d893a5e", + "name": "AzaCoin", + "symbol": "AZA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28443/thumb/Azarus_Logo_Mark-XXL.png?1670664404" + }, + { + "chainId": 1, + "address": "0x97b65710d03e12775189f0d113202cc1443b0aa2", + "name": "AstroElon", + "symbol": "ELONONE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16082/thumb/AstroElon.png?1622791921" + }, + { + "chainId": 1, + "address": "0x1337def18c680af1f9f45cbcab6309562975b1dd", + "name": "Armor NXM", + "symbol": "ARNXM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13753/thumb/1_otmQ1sN0MgsT4idRsPsu3w.png?1611556043" + }, + { + "chainId": 1, + "address": "0x1111158f88410da5f92c7e34c01e7b8649bc0155", + "name": "Intercoin", + "symbol": "ITR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20180/thumb/VU72TTZ3zN3w.png?1636604639" + }, + { + "chainId": 1, + "address": "0xdc0804ed9aba9202e2b976c031d3144bb63a7990", + "name": "Kishutama", + "symbol": "KISHUTAMA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23483/thumb/Screenshot-2022-02-05-at-09-20-53.png?1644219727" + }, + { + "chainId": 1, + "address": "0x1fee5588cb1de19c70b6ad5399152d8c643fae7b", + "name": "Phun Token", + "symbol": "PHTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24773/thumb/2q6YoWkb_400x400.jpg?1648822416" + }, + { + "chainId": 1, + "address": "0x869dbe51dc214fcb663604b0f7b548592f8c71f5", + "name": "Okidoki Social", + "symbol": "DOKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27018/thumb/Okidoki_Logo.png?1661480220" + }, + { + "chainId": 1, + "address": "0x926be13b4d93f29ea254e4e518f33099e45d7f06", + "name": "POC Chain", + "symbol": "POCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7718/thumb/logo_%281%29.png?1549956313" + }, + { + "chainId": 1, + "address": "0x84da8e731172827fcb233b911678e2a82e27baf2", + "name": "ANKR Reward Earning KSM", + "symbol": "AKSMB", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/26028/thumb/a-ksm-b-99bb6bfd6eddad0ce2a44dac4667ec34.png?1655349825" + }, + { + "chainId": 1, + "address": "0x4a6ab9792e9f046c3ab22d8602450de5186be9a7", + "name": "Polka Ventures", + "symbol": "POLVEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14613/thumb/polven.png?1617253185" + }, + { + "chainId": 1, + "address": "0x6d614686550b9e1c1df4b2cd8f91c9d4df66c810", + "name": "Skeb", + "symbol": "SKEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27155/thumb/skebcoin-cmc.png?1662206072" + }, + { + "chainId": 1, + "address": "0x06e0feb0d74106c7ada8497754074d222ec6bcdf", + "name": "Bitball", + "symbol": "BTB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7039/thumb/btb.png?1637556233" + }, + { + "chainId": 1, + "address": "0x83984d6142934bb535793a82adb0a46ef0f66b6d", + "name": "Remme", + "symbol": "REM", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/2152/thumb/semme.png?1561622861" + }, + { + "chainId": 1, + "address": "0xa984a92731c088f1ea4d53b71a2565a399f7d8d5", + "name": "International CryptoX", + "symbol": "INCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4244/thumb/download_%2833%29.jpg?1547039576" + }, + { + "chainId": 1, + "address": "0x6c6ee5e31d828de241282b9606c8e98ea48526e2", + "name": "Holo", + "symbol": "HOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3348/thumb/Holologo_Profile.png?1547037966" + }, + { + "chainId": 1, + "address": "0x75231f58b43240c9718dd58b4967c5114342a86c", + "name": "OKB", + "symbol": "OKB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4463/thumb/WeChat_Image_20220118095654.png?1642471050" + }, + { + "chainId": 1, + "address": "0x4af698b479d0098229dc715655c667ceb6cd8433", + "name": "MaidCoin", + "symbol": "MAID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17571/thumb/610e48937e73535a83f92ae7_icon200.png?1628517343" + }, + { + "chainId": 1, + "address": "0x4b13a8a95da56773312ca0d4e0670530aa700fcf", + "name": "ZeroHybrid Network", + "symbol": "ZHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18692/thumb/LOGO1_%287%29.png?1635230502" + }, + { + "chainId": 1, + "address": "0xa89ac6e529acf391cfbbd377f3ac9d93eae9664e", + "name": "Keep4r", + "symbol": "KP4R", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13006/thumb/kp4r.png?1604368813" + }, + { + "chainId": 1, + "address": "0xa953736904e23fafb42e353d4122420899999999", + "name": "Forbitspace", + "symbol": "FBS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25541/thumb/FBS-forbitspace-logo.png?1652265910" + }, + { + "chainId": 1, + "address": "0x5d929aa919e489505ccaad8a199619c6dca0c2de", + "name": "BaaSid", + "symbol": "BAAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5463/thumb/baasid.png?1547041199" + }, + { + "chainId": 1, + "address": "0x799ebfabe77a6e34311eeee9825190b9ece32824", + "name": "Braintrust", + "symbol": "BTRST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18100/thumb/braintrust.PNG?1630475394" + }, + { + "chainId": 1, + "address": "0x7051faed0775f664a0286af4f75ef5ed74e02754", + "name": "ChangeX", + "symbol": "CHANGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26487/thumb/Changex-mark-200x200.png?1665655365" + }, + { + "chainId": 1, + "address": "0xc91a71a1ffa3d8b22ba615ba1b9c01b2bbbf55ad", + "name": "ZigZag", + "symbol": "ZZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26141/thumb/zig_zag.?1656248564" + }, + { + "chainId": 1, + "address": "0x3541a5c1b04adaba0b83f161747815cd7b1516bc", + "name": "CitaDAO", + "symbol": "KNIGHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22848/thumb/KNIGHT_TOKEN_LOGO.png?1643190758" + }, + { + "chainId": 1, + "address": "0xdad26bce7dcf59cd03a2455558e4dd73e1c07b66", + "name": "Trade win", + "symbol": "TWI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13060/thumb/Logo.png?1604821765" + }, + { + "chainId": 1, + "address": "0x006bea43baa3f7a6f765f14f10a1a1b08334ef45", + "name": "Stox", + "symbol": "STX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1230/thumb/stox-token.png?1547035256" + }, + { + "chainId": 1, + "address": "0x7dbbcae15d4db168e01673400d7844870cc1e36f", + "name": "WOLFY", + "symbol": "WOLFY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15742/thumb/Wofly.png?1621761884" + }, + { + "chainId": 1, + "address": "0x4efe8665e564bf454ccf5c90ee16817f7485d5cf", + "name": "BlackDragon", + "symbol": "BDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13426/thumb/Black-Dragon-Black.png?1608515220" + }, + { + "chainId": 1, + "address": "0xe581f272706581f9dcc362df3c7934e99192c492", + "name": "PURR Vault NFTX ", + "symbol": "PURR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18329/thumb/purr.png?1631557276" + }, + { + "chainId": 1, + "address": "0xf8c595d070d104377f58715ce2e6c93e49a87f3c", + "name": "DACC", + "symbol": "DACC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/4781/thumb/dacc-token.png?1547040122" + }, + { + "chainId": 1, + "address": "0xa29a8e360c0cba25a3719763fde43a1ee570271d", + "name": "OILage", + "symbol": "OIL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11232/thumb/download_%2812%29.png?1589767119" + }, + { + "chainId": 1, + "address": "0x6641b8df62e4b0e00d3b61f8eca63b2052404fd9", + "name": "Sanliurfaspor Token", + "symbol": "URFA", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24816/thumb/urfa.png?1649029396" + }, + { + "chainId": 1, + "address": "0x7f39c581f595b53c5cb19bd0b3f8da6c935e2ca0", + "name": "Wrapped stETH", + "symbol": "WSTETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18834/thumb/wstETH.png?1633565443" + }, + { + "chainId": 1, + "address": "0xaba8cac6866b83ae4eec97dd07ed254282f6ad8a", + "name": "YAM v2", + "symbol": "YAMV2", + "decimals": 24, + "logoURI": "https://assets.coingecko.com/coins/images/12179/thumb/YAM-v2.png?1597892396" + }, + { + "chainId": 1, + "address": "0x0642026e7f0b6ccac5925b4e7fa61384250e1701", + "name": "H2O", + "symbol": "H2O", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25315/thumb/h2o_32.png?1651215712" + }, + { + "chainId": 1, + "address": "0xd56dac73a4d6766464b38ec6d91eb45ce7457c44", + "name": "Panvala Pan", + "symbol": "PAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9543/thumb/pan-logo.png?1568674599" + }, + { + "chainId": 1, + "address": "0x06450dee7fd2fb8e39061434babcfc05599a6fb8", + "name": "XEN Crypto", + "symbol": "XEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27713/thumb/Xen.jpeg?1665453190" + }, + { + "chainId": 1, + "address": "0x4bcea5e4d0f6ed53cf45e7a28febb2d3621d7438", + "name": "Modex", + "symbol": "MODEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2851/thumb/LhWIeAg.png?1602566568" + }, + { + "chainId": 1, + "address": "0x382a1667c9062f0621362f49076ef6e4fe4c9ec7", + "name": "RushCoin", + "symbol": "RUSH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25053/thumb/Kax1yBSz_400x400.png?1649979044" + }, + { + "chainId": 1, + "address": "0x8a2279d4a90b6fe1c4b30fa660cc9f926797baa2", + "name": "Chromia", + "symbol": "CHR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/5000/thumb/Chromia.png?1559038018" + }, + { + "chainId": 1, + "address": "0x8f0921f30555624143d427b340b1156914882c10", + "name": "FlypMe", + "symbol": "FYP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1098/thumb/flypme.png?1548126453" + }, + { + "chainId": 1, + "address": "0xd7d05bda4bf5876ba1254b3eaaf8b47d2f5676eb", + "name": "STABLE ASSET", + "symbol": "STA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12313/thumb/stable_200x200.png?1599083938" + }, + { + "chainId": 1, + "address": "0x8716fc5da009d3a208f0178b637a50f4ef42400f", + "name": "Ultrain", + "symbol": "UGAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4684/thumb/ultrain.png?1547039956" + }, + { + "chainId": 1, + "address": "0x49642110b712c1fd7261bc074105e9e44676c68f", + "name": "DinoLFG", + "symbol": "DINO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28239/thumb/photo_2022-11-16_04-57-23.jpg?1668581540" + }, + { + "chainId": 1, + "address": "0xe4d75e9b493458d032a5c3cc1ee9b0712c1ece06", + "name": "Bitcci Cash", + "symbol": "BITCCA", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/25998/thumb/20574.png?1655276250" + }, + { + "chainId": 1, + "address": "0xe2db94e8d4e4144c336e45668a792d17d48a482c", + "name": "Nuvo Cash", + "symbol": "NUVO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11422/thumb/nuvo.png?1590109082" + }, + { + "chainId": 1, + "address": "0x2590f1fd14ef8bb0a46c7a889c4cbc146510f9c3", + "name": "Inverse Bitcoin Volatility Index Token", + "symbol": "IBTCV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16718/thumb/logo_-_2021-06-28T093119.133.png?1624843921" + }, + { + "chainId": 1, + "address": "0xa9aad2dc3a8315caeee5f458b1d8edc31d8467bd", + "name": "BTCMoon", + "symbol": "BTCM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1081/thumb/btcmoon.png?1547035045" + }, + { + "chainId": 1, + "address": "0x15492208ef531ee413bd24f609846489a082f74c", + "name": "PlayTreks", + "symbol": "TREKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21378/thumb/trekscoin-200x200-tr.png?1639033673" + }, + { + "chainId": 1, + "address": "0x67954768e721fad0f0f21e33e874497c73ed6a82", + "name": "KeKChain", + "symbol": "KEK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27061/thumb/20220816_155427.png?1661668348" + }, + { + "chainId": 1, + "address": "0x44564d0bd94343f72e3c8a0d22308b7fa71db0bb", + "name": "BasketDAO", + "symbol": "BASK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14636/thumb/BASK_200_CIRCLE.png?1617494952" + }, + { + "chainId": 1, + "address": "0xaec2e87e0a235266d9c5adc9deb4b2e29b54d009", + "name": "SingularDTV", + "symbol": "SNGLS", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/521/thumb/singulardtv.png?1547034199" + }, + { + "chainId": 1, + "address": "0x4ad0b81f92b16624bbcf46fc0030cfbbf8d02376", + "name": "Unagii Dai", + "symbol": "UDAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13782/thumb/uDAI.png?1611730113" + }, + { + "chainId": 1, + "address": "0x9d86b1b2554ec410eccffbf111a6994910111340", + "name": "Open Platform", + "symbol": "OPEN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2953/thumb/open-platform.png?1548330231" + }, + { + "chainId": 1, + "address": "0x6b74dd5d01f8320081247f5cf1f7a48324700db6", + "name": "UBU", + "symbol": "UBU", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10686/thumb/NFGYEIaA_400x400_%281%29.png?1586763969" + }, + { + "chainId": 1, + "address": "0xa02120696c7b8fe16c09c749e4598819b2b0e915", + "name": "WXT Token", + "symbol": "WXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8835/thumb/Wirex.jpg?1561970529" + }, + { + "chainId": 1, + "address": "0xbc5991ccd8caceba01edc44c2bb9832712c29cab", + "name": "Unagii USD Coin", + "symbol": "UUSDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13781/thumb/uUSDC.png?1611729843" + }, + { + "chainId": 1, + "address": "0xde72a052cbb212eff11a4a33d61df9c5a2de8dd1", + "name": "Shuna Inuverse", + "symbol": "SHUNAV2", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21526/thumb/Untitled-design-15.png?1639382131" + }, + { + "chainId": 1, + "address": "0x3a1bda28adb5b0a812a7cf10a1950c920f79bcd3", + "name": "Gameflip", + "symbol": "FLP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2173/thumb/flp.png?1547036470" + }, + { + "chainId": 1, + "address": "0x5bb29c33c4a3c29f56f8aca40b4db91d8a5fe2c5", + "name": "One Share", + "symbol": "ONS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13531/thumb/bss.a1671c75.png?1609452258" + }, + { + "chainId": 1, + "address": "0x981dc247745800bd2ca28a4bf147f0385eaa0bc0", + "name": "NutsDAO", + "symbol": "NUTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28165/thumb/NSD.png?1668171752" + }, + { + "chainId": 1, + "address": "0x4612021c75809160be60db21fbc9d6add0b32def", + "name": "Block Commerce Protocol", + "symbol": "BCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17562/thumb/BCP_200x200.png?1628234484" + }, + { + "chainId": 1, + "address": "0xe803178b48a0e560c2b19f3b3d4e504f79d229ce", + "name": "Bobcoin", + "symbol": "BOBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24264/thumb/bobc.png?1647171532" + }, + { + "chainId": 1, + "address": "0x46d0dac0926fa16707042cadc23f1eb4141fe86b", + "name": "SONM", + "symbol": "SNM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/861/thumb/sonm.png?1548609871" + }, + { + "chainId": 1, + "address": "0x43044f861ec040db59a7e324c40507addb673142", + "name": "Cap", + "symbol": "CAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11775/thumb/CAP.png?1594083244" + }, + { + "chainId": 1, + "address": "0xf3924df14812b3d3db29124aa9da4353ed5e04a3", + "name": "Easticoin", + "symbol": "ESTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12988/thumb/EST2.png?1604093746" + }, + { + "chainId": 1, + "address": "0x7fe8dac51394157811c71bbf74c133a224a9ff44", + "name": "LiquidSwap", + "symbol": "LQD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23323/thumb/Cq7F8wZr_400x400.jpg?1643836712" + }, + { + "chainId": 1, + "address": "0xd8c4ef2d99c9f962180008418a5665fcc4b99ecd", + "name": "Redux Protocol", + "symbol": "RDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26737/thumb/-L4oVsFB_400x400.png?1659935437" + }, + { + "chainId": 1, + "address": "0x22b48e1f20043d1db5f2a11cbf1d520a4f20b198", + "name": "Okuru", + "symbol": "XOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25473/thumb/xot.png?1652005616" + }, + { + "chainId": 1, + "address": "0x6e1a58e7e9e801f32bb82462636a8a2e7b65e036", + "name": "LCG", + "symbol": "LCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12851/thumb/LCG_token.jpg?1603083545" + }, + { + "chainId": 1, + "address": "0x66f73d0fd4161cfad4302dc145ff994375c13475", + "name": "DexGame", + "symbol": "DXGM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21084/thumb/dxgm-token.png?1638310949" + }, + { + "chainId": 1, + "address": "0x87a92428bbc876d463c21c8e51b903f127d9a9f4", + "name": "Advanced United Continent", + "symbol": "AUC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24369/thumb/200x200.png?1647441606" + }, + { + "chainId": 1, + "address": "0xca5d29b3e74d59ebcdf09111495d86f319886a40", + "name": "WHEY", + "symbol": "WHEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14883/thumb/WHEY_logo_black_0421_v1.png?1618893173" + }, + { + "chainId": 1, + "address": "0xcdf7028ceab81fa0c6971208e83fa7872994bee5", + "name": "Threshold Network", + "symbol": "T", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22228/thumb/nFPNiSbL_400x400.jpg?1641220340" + }, + { + "chainId": 1, + "address": "0xc434b27736a6882d33094d34792999702860a13c", + "name": "Savix", + "symbol": "SVX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14591/thumb/savix_200px.png?1617160141" + }, + { + "chainId": 1, + "address": "0x3d9ac8e7a9c9be11dfac1677dda901e28d44527f", + "name": "Palace", + "symbol": "PAA", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11141/thumb/da443cb2601f5fbdab9a2e176d62d6ce.png?1588911369" + }, + { + "chainId": 1, + "address": "0xa0b93b9e90ab887e53f9fb8728c009746e989b53", + "name": "The Standard Token", + "symbol": "TST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20598/thumb/TheStandard-logo_variation-01.png?1668676004" + }, + { + "chainId": 1, + "address": "0x0c572544a4ee47904d54aaa6a970af96b6f00e1b", + "name": "Wasder", + "symbol": "WAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15374/thumb/wasderBoxedLogoWhite-200x200.png?1659095342" + }, + { + "chainId": 1, + "address": "0x8ba6dcc667d3ff64c1a2123ce72ff5f0199e5315", + "name": "Alex", + "symbol": "ALEX", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/10972/thumb/ALEX.png?1586742545" + }, + { + "chainId": 1, + "address": "0x7c2e5b7ec572199d3841f6a38f7d4868bd0798f1", + "name": "Havy", + "symbol": "HAVY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6043/thumb/havy.png?1547041989" + }, + { + "chainId": 1, + "address": "0xcff20ce22e71ecf2ea89c86ecbd4a3cf513768c7", + "name": "Makes", + "symbol": "MKS", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13318/thumb/MKS200.png?1607412065" + }, + { + "chainId": 1, + "address": "0xbc17729fdf562723f0267f79ff25ade441056d87", + "name": "Karus Starter", + "symbol": "KST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18862/thumb/logo-only.png?1645962885" + }, + { + "chainId": 1, + "address": "0x7f0693074f8064cfbcf9fa6e5a3fa0e4f58ccccf", + "name": "we love gm", + "symbol": "GM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20284/thumb/froLiJ3p_400x400.jpg?1636808699" + }, + { + "chainId": 1, + "address": "0xcdc412f306e0c51e3249b88c65423cd16b322673", + "name": "Blockchain io", + "symbol": "BCIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4168/thumb/BCIO_logo_square_256px.png?1547039429" + }, + { + "chainId": 1, + "address": "0x0b8057c3cc676c329c25c1d0cd27776efa73762d", + "name": "Megaweapon", + "symbol": "WEAPON", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20833/thumb/weapon.png?1659792713" + }, + { + "chainId": 1, + "address": "0x9b9647431632af44be02ddd22477ed94d14aacaa", + "name": "KOK", + "symbol": "KOK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10502/thumb/logo_navy.png?1580250344" + }, + { + "chainId": 1, + "address": "0x178bf8fd04b47d2de3ef3f6b3d112106375ad584", + "name": "Unagii Tether USD", + "symbol": "UUSDT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13778/thumb/uUSDT.png?1611729448" + }, + { + "chainId": 1, + "address": "0x9d71ce49ab8a0e6d2a1e7bfb89374c9392fd6804", + "name": "NvirWorld", + "symbol": "NVIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21359/thumb/Nvir_symbol.png?1639013234" + }, + { + "chainId": 1, + "address": "0x2a3bff78b79a009976eea096a51a948a3dc00e34", + "name": "Wilder World", + "symbol": "WILD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15407/thumb/WWLogo_Gradient_Cirlce.png?1620743969" + }, + { + "chainId": 1, + "address": "0x60acd58d00b2bcc9a8924fdaa54a2f7c0793b3b2", + "name": "MEME LTD", + "symbol": "MEME20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17858/thumb/unnamed_%285%29.jpg?1629682905" + }, + { + "chainId": 1, + "address": "0xbec5938fd565cbec72107ee39cde1bc78049537d", + "name": "Swing DAO", + "symbol": "SWING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27779/thumb/aUQKFUM.png?1665731942" + }, + { + "chainId": 1, + "address": "0x6a68de599e8e0b1856e322ce5bd11c5c3c79712b", + "name": "iBetYou", + "symbol": "IBY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16423/thumb/qvrS5aNM_400x400.jpg?1623988397" + }, + { + "chainId": 1, + "address": "0xcdb9d30a3ba48cdfcb0ecbe19317e6cf783672f1", + "name": "Mondo Community Coin", + "symbol": "MNDCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18680/thumb/mndcc_bildmarke_256px.png?1632965673" + }, + { + "chainId": 1, + "address": "0x09617f6fd6cf8a71278ec86e23bbab29c04353a7", + "name": "Shardus", + "symbol": "ULT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8383/thumb/final_logo_photoshop.png?1557890272" + }, + { + "chainId": 1, + "address": "0xd031edafac6a6ae5425e77f936022e506444c242", + "name": "HERUKA TSANGNYON", + "symbol": "TSANGNYON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27611/thumb/81b3e527-f8a9-47f7-8d4d-10f754f501c2.png?1664853112" + }, + { + "chainId": 1, + "address": "0x77700005bea4de0a78b956517f099260c2ca9a26", + "name": "Root", + "symbol": "ROOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28366/thumb/root-200x200.png?1669907946" + }, + { + "chainId": 1, + "address": "0x4ece5c5cfb9b960a49aae739e15cdb6cfdcc5782", + "name": "Doont Buy", + "symbol": "DBUY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17895/thumb/VaxEiZ3.png?1629727429" + }, + { + "chainId": 1, + "address": "0x8eedefe828a0f16c8fc80e46a87bc0f1de2d960c", + "name": "DigiMetaverse", + "symbol": "DGMV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23701/thumb/DigiCorpLabs_token.png?1645081296" + }, + { + "chainId": 1, + "address": "0x6f620ec89b8479e97a6985792d0c64f237566746", + "name": "WePiggy Coin", + "symbol": "WPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21914/thumb/WPC200.png?1640262945" + }, + { + "chainId": 1, + "address": "0x664c6e221c77313307467b121528ad563107bd01", + "name": "Tax Haven Inu", + "symbol": "TAXHAVENINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27362/thumb/tax_haven_inu.png?1663665897" + }, + { + "chainId": 1, + "address": "0xc502002aeb1b9309fccb016adf50507987fc6c2b", + "name": "GNFT", + "symbol": "GNFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23532/thumb/gnft_200x200.png?1644386728" + }, + { + "chainId": 1, + "address": "0x7ae1d57b58fa6411f32948314badd83583ee0e8c", + "name": "Dope Wars Paper", + "symbol": "PAPER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18166/thumb/EQHGcBO__400x400.jpeg?1663726283" + }, + { + "chainId": 1, + "address": "0x679badc551626e01b23ceecefbc9b877ea18fc46", + "name": "Ccore", + "symbol": "CCO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1287/thumb/LOGO_CCO.png?1547035312" + }, + { + "chainId": 1, + "address": "0xfa14fa6958401314851a17d6c5360ca29f74b57b", + "name": "Saito", + "symbol": "SAITO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14750/thumb/SAITO.png?1626857406" + }, + { + "chainId": 1, + "address": "0xe884cc2795b9c45beeac0607da9539fd571ccf85", + "name": "Ultiledger", + "symbol": "ULT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6747/thumb/Ultiledger.jpeg?1547042996" + }, + { + "chainId": 1, + "address": "0xbcca60bb61934080951369a648fb03df4f96263c", + "name": "Aave USDC", + "symbol": "AUSDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14318/thumb/aUSDC.e260d492.png?1615527797" + }, + { + "chainId": 1, + "address": "0x2ccbff3a042c68716ed2a2cb0c544a9f1d1935e1", + "name": "DMarket", + "symbol": "DMT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1602/thumb/dmarket.png?1547223830" + }, + { + "chainId": 1, + "address": "0x712db54daa836b53ef1ecbb9c6ba3b9efb073f40", + "name": "Aave ENJ v1", + "symbol": "AENJ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12484/thumb/aENJ.png?1600189443" + }, + { + "chainId": 1, + "address": "0x6361f338ab8def2af3f2a1be7bd8a7db3156f7e7", + "name": "Probably Nothing", + "symbol": "PRBLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20193/thumb/pn.png?1645338665" + }, + { + "chainId": 1, + "address": "0x3d382228c54736d831fac2748f4734d9177c7332", + "name": "Aniverse", + "symbol": "ANV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16348/thumb/anv.PNG?1623794994" + }, + { + "chainId": 1, + "address": "0xfe76be9cec465ed3219a9972c21655d57d21aec6", + "name": "PalletOne", + "symbol": "PTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6669/thumb/palletone.png?1548330460" + }, + { + "chainId": 1, + "address": "0x61107a409fffe1965126aa456af679719695c69c", + "name": "Umi Digital", + "symbol": "UMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17874/thumb/Umi-200-x-200.png?1629700077" + }, + { + "chainId": 1, + "address": "0x17a79792fe6fe5c95dfe95fe3fcee3caf4fe4cb7", + "name": "Aave AMM USDT", + "symbol": "AAMMUSDT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/17200/thumb/aAMMUSDT_2x.png?1626873261" + }, + { + "chainId": 1, + "address": "0x2df488b8a4270bac5c2ce5ff467a0c5fd2aa49d6", + "name": "Sharity", + "symbol": "SHARI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21796/thumb/HHGyEDIv_400x400.jpg?1640060553" + }, + { + "chainId": 1, + "address": "0x74b1af114274335598da72f5c6ed7b954a016eed", + "name": "HitBTC", + "symbol": "HIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16395/thumb/JgMkz95.png?1623909204" + }, + { + "chainId": 1, + "address": "0xe1ba0fb44ccb0d11b80f92f4f8ed94ca3ff51d00", + "name": "Aave BAT v1", + "symbol": "ABAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11726/thumb/aBAT.png?1593086569" + }, + { + "chainId": 1, + "address": "0xe340b25fe32b1011616bb8ec495a4d503e322177", + "name": "Aave AMM UniDAIUSDC", + "symbol": "AAMMUNIDAIUSDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17218/thumb/aAmmUniDAIUSDC.png?1626878648" + }, + { + "chainId": 1, + "address": "0x7a939bb714fd2a48ebeb1e495aa9aaa74ba9fa68", + "name": "Electric Vehicle Zone", + "symbol": "EVZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9456/thumb/kLohzILUIln6mHFYOlecpWjINVIH-BVghP2vRTeuD0XteaQa7Lpn4sLcuPN4gHw8MU2pKWZCJRNwBmyyl1CYxplCLDcgSVihMC7vvfmkepY-_O_ImWBA27s4pKNlhcBnBYrc8y5WH0ZB2CjmqPh-32nPslrv329tqFWr2DAR8dl4R5LZGgeZ1ubCdtMoUua6gEL3umYShHBxrYLto.jpg?1567563510" + }, + { + "chainId": 1, + "address": "0x6226caa1857afbc6dfb6ca66071eb241228031a1", + "name": "LinkArt", + "symbol": "LAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8892/thumb/pB4iXZbU_400x400.jpg?1562579001" + }, + { + "chainId": 1, + "address": "0x2c9023bbc572ff8dc1228c7858a280046ea8c9e5", + "name": "Vivid Labs", + "symbol": "VID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3376/thumb/1638280236344.jpg?1645083911" + }, + { + "chainId": 1, + "address": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2", + "name": "WETH", + "symbol": "WETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2518/thumb/weth.png?1628852295" + }, + { + "chainId": 1, + "address": "0x7797c85b46f548eacc07c229f6cd207d6370442f", + "name": "Dog Tag", + "symbol": "TAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26418/thumb/TAG_PNG.png?1657926565" + }, + { + "chainId": 1, + "address": "0x9a54a39a8d78cd6031636628a11c890124b1b5cf", + "name": "NFracTion", + "symbol": "NFTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18693/thumb/nfta.png?1632984393" + }, + { + "chainId": 1, + "address": "0x476c5e26a75bd202a9683ffd34359c0cc15be0ff", + "name": "Serum", + "symbol": "SRM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/11970/thumb/serum-logo.png?1597121577" + }, + { + "chainId": 1, + "address": "0x556148562d5ddeb72545d7ec4b3ec8edc8f55ba7", + "name": "Predix Network", + "symbol": "PRDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12388/thumb/main-logo.png?1599531749" + }, + { + "chainId": 1, + "address": "0x8fa025e8342ead1037d2954b95333ff2bf57162b", + "name": "ShibaMax", + "symbol": "SMAX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16218/thumb/ShibaMax.png?1623652199" + }, + { + "chainId": 1, + "address": "0xf1d1a5306daae314af6c5d027a492b313e07e1a0", + "name": "Envoy", + "symbol": "ENV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19631/thumb/env.png?1638148461" + }, + { + "chainId": 1, + "address": "0x7cf74238d48ce383db00a1efff8da99303552cb0", + "name": "i9 Coin", + "symbol": "I9C", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12399/thumb/Vvm9V6YM_400x400.png?1599556271" + }, + { + "chainId": 1, + "address": "0xb131f337c45d386ceec234e194b2663d5c3d9dcf", + "name": "iCommunity", + "symbol": "ICOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23667/thumb/logo-icommunity.png?1644993652" + }, + { + "chainId": 1, + "address": "0xd7394087e1dbbe477fe4f1cf373b9ac9459565ff", + "name": "RealTract", + "symbol": "RET", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5955/thumb/200-01.png?1547041895" + }, + { + "chainId": 1, + "address": "0xf12ec0d3dab64ddefbdc96474bde25af3fe1b327", + "name": "Stacy", + "symbol": "STACY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12986/thumb/Stacy.png?1604384468" + }, + { + "chainId": 1, + "address": "0xa0008f510fe9ee696e7e320c9e5cbf61e27791ee", + "name": "GAMB", + "symbol": "GMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4497/thumb/gmb.png?1547039806" + }, + { + "chainId": 1, + "address": "0x920b73e4a8d27b9291efc762e88b3b676fcddaec", + "name": "Raise Finance", + "symbol": "RAISE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26393/thumb/RFI_Token_Logo.png?1657753383" + }, + { + "chainId": 1, + "address": "0x62dc4817588d53a056cbbd18231d91ffccd34b2a", + "name": "DeHive", + "symbol": "DHV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14926/thumb/logo_200x200.png?1626181831" + }, + { + "chainId": 1, + "address": "0x42476f744292107e34519f9c357927074ea3f75d", + "name": "Loom Network NEW ", + "symbol": "LOOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14735/thumb/LOOM.png?1617967111" + }, + { + "chainId": 1, + "address": "0x8e0e57dcb1ce8d9091df38ec1bfc3b224529754a", + "name": "Moon Tropica", + "symbol": "CAH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28470/thumb/MTLOGO.png?1671001371" + }, + { + "chainId": 1, + "address": "0xade00c28244d5ce17d72e40330b1c318cd12b7c3", + "name": "Ambire AdEx", + "symbol": "ADX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/847/thumb/Ambire_AdEx_Symbol_color.png?1655432540" + }, + { + "chainId": 1, + "address": "0x69b148395ce0015c13e36bffbad63f49ef874e03", + "name": "DATA", + "symbol": "DTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2604/thumb/data.png?1547036749" + }, + { + "chainId": 1, + "address": "0x817bbdbc3e8a1204f3691d14bb44992841e3db35", + "name": "Cudos", + "symbol": "CUDOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13651/thumb/CudosIconTransparent.png?1610631426" + }, + { + "chainId": 1, + "address": "0x372c95ce229a7af37d141f627d09f6df1dbaa741", + "name": "ShibRobi", + "symbol": "SHIBORG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23505/thumb/_-5o_lop_400x400.jpg?1644297264" + }, + { + "chainId": 1, + "address": "0x048aa6e69d5117bd665af4128383a6982b8367b3", + "name": "VoxNET", + "symbol": "VXON", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/28369/thumb/VoxNETlogo.png?1669947735" + }, + { + "chainId": 1, + "address": "0xdb2f2bcce3efa95eda95a233af45f3e0d4f00e2a", + "name": "Aegis", + "symbol": "AGS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12391/thumb/logo-3.png?1599540071" + }, + { + "chainId": 1, + "address": "0x666d875c600aa06ac1cf15641361dec3b00432ef", + "name": "BTSE Token", + "symbol": "BTSE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10807/thumb/BTSE_logo_Square.jpeg?1583965964" + }, + { + "chainId": 1, + "address": "0x95172ccbe8344fecd73d0a30f54123652981bd6f", + "name": "Meridian Network", + "symbol": "LOCK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11687/thumb/LOCK_cropped.png?1599614902" + }, + { + "chainId": 1, + "address": "0xd6a55c63865affd67e2fb9f284f87b7a9e5ff3bd", + "name": "Switch", + "symbol": "ESH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8608/thumb/Cco9sLN.png?1603676332" + }, + { + "chainId": 1, + "address": "0x1aabf9b575e4329b8c8f272428ad5e43ab4aefc8", + "name": "Bugg Inu", + "symbol": "BUGG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16413/thumb/bugg.PNG?1623971743" + }, + { + "chainId": 1, + "address": "0x525794473f7ab5715c81d06d10f52d11cc052804", + "name": "12Ships", + "symbol": "TSHP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9351/thumb/12ships.png?1566485390" + }, + { + "chainId": 1, + "address": "0xda446fad08277b4d2591536f204e018f32b6831c", + "name": "NZD Stablecoin", + "symbol": "NZDS", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/20394/thumb/nzds.png?1636964381" + }, + { + "chainId": 1, + "address": "0xcb17cd357c7acd594717d899ecb9df540f633f27", + "name": "CoinDeal Token", + "symbol": "CDL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9960/thumb/2ZP5JaIL_400x400.jpg?1574233581" + }, + { + "chainId": 1, + "address": "0xf56842af3b56fd72d17cb103f92d027bba912e89", + "name": "BambooDeFi", + "symbol": "BAMBOO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13856/thumb/Bamboo-token-logo-200.png?1612404311" + }, + { + "chainId": 1, + "address": "0xd23367155b55d67492dfdc0fc7f8bb1df7114fd9", + "name": "AmpliFi", + "symbol": "AMPLIFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26869/thumb/amplifi.jpg?1662611752" + }, + { + "chainId": 1, + "address": "0x804e26c4eff0bb196b805bdfb5b29ab828cf0b1f", + "name": "Whale Coin", + "symbol": "WHALE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10743/thumb/whalecoin200.png?1582835568" + }, + { + "chainId": 1, + "address": "0x626082f2c5ed30e228f9349a68ceb155c1c26e2d", + "name": "Lucky Shinu", + "symbol": "LUSHI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23645/thumb/output-onlinepngtools.png?1644910575" + }, + { + "chainId": 1, + "address": "0xa7f976c360ebbed4465c2855684d1aae5271efa9", + "name": "TrueFlip", + "symbol": "TFL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/940/thumb/tfl.png?1634521414" + }, + { + "chainId": 1, + "address": "0xd9a947789974bad9be77e45c2b327174a9c59d71", + "name": "Ystar", + "symbol": "YSR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11575/thumb/256_256.png?1600495476" + }, + { + "chainId": 1, + "address": "0x0edf9bc41bbc1354c70e2107f80c42cae7fbbca8", + "name": "Instrumental Finance", + "symbol": "STRM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21407/thumb/HRZ0RUOh_400x400.jpg?1639088027" + }, + { + "chainId": 1, + "address": "0x72e203a17add19a3099137c9d7015fd3e2b7dba9", + "name": "BlockchainPoland", + "symbol": "BCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8143/thumb/43Stz1Tw.png?1555551797" + }, + { + "chainId": 1, + "address": "0xc5019e129b75d380d3d837b8e609dec6c8f5d044", + "name": "GN", + "symbol": "GN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20207/thumb/gn_logo.png?1636911970" + }, + { + "chainId": 1, + "address": "0x4e432a62733a7ee38ad2e16b3cc0731457ea5b55", + "name": "QChain QDT", + "symbol": "QDT", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/26502/thumb/qdt_logo.png?1658366015" + }, + { + "chainId": 1, + "address": "0xb9eefc4b0d472a44be93970254df4f4016569d27", + "name": "DigitalBits", + "symbol": "XDB", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/8089/thumb/digitalbits-logo.jpg?1554454902" + }, + { + "chainId": 1, + "address": "0xa00425d3e2d3e9ff74f3e112b4d3a7978d7d88c2", + "name": "GoPower", + "symbol": "GPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2991/thumb/82EMDIqURn_Y_O021ulWgQ.png?1547037256" + }, + { + "chainId": 1, + "address": "0xbfc5c333b096c6a171baa43bb2dfb321e05967da", + "name": "mini Mongoose", + "symbol": "MINIMONGOOSE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21443/thumb/6fpRJII.jpeg?1639144809" + }, + { + "chainId": 1, + "address": "0xc626e0619ac79afea9281c8eb9b1a9f9d3fab532", + "name": "Freedom Reserve", + "symbol": "FR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13342/thumb/J6uNL2FS_400x400.jpg?1607589046" + }, + { + "chainId": 1, + "address": "0x592481a5f6b4f078cc303c2cde4337dfa2d76fa0", + "name": "Sting", + "symbol": "STN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13760/thumb/sting.png?1611612491" + }, + { + "chainId": 1, + "address": "0x9559aaa82d9649c7a7b220e7c461d2e74c9a3593", + "name": "rETH", + "symbol": "RETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14452/thumb/rETH.png?1616660903" + }, + { + "chainId": 1, + "address": "0x06f3c323f0238c72bf35011071f2b5b7f43a054c", + "name": "MASQ", + "symbol": "MASQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13699/thumb/masq.png?1648364813" + }, + { + "chainId": 1, + "address": "0x35b55c25731e9b05b1d8480ba39463d52c9d0211", + "name": "Stonk Swap", + "symbol": "STONK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11690/thumb/PNG_logo_200px.png?1622340402" + }, + { + "chainId": 1, + "address": "0xe8663a64a96169ff4d95b4299e7ae9a76b905b31", + "name": "DPRating", + "symbol": "RATING", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5383/thumb/dprating.png?1547224023" + }, + { + "chainId": 1, + "address": "0xb32ac3c79a94ac1eb258f3c830bbdbc676483c93", + "name": "OpenSwap", + "symbol": "OSWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15785/thumb/openswap.PNG?1621847093" + }, + { + "chainId": 1, + "address": "0xea7cc765ebc94c4805e3bff28d7e4ae48d06468a", + "name": "NearPad", + "symbol": "PAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18117/thumb/coin-on-white.png?1630553114" + }, + { + "chainId": 1, + "address": "0xf16cd087e1c2c747b2bdf6f9a5498aa400d99c24", + "name": "iBG Finance ETH ", + "symbol": "IBG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18756/thumb/ibg.png?1633337424" + }, + { + "chainId": 1, + "address": "0x8d75959f1e61ec2571aa72798237101f084de63a", + "name": "Substratum", + "symbol": "SUB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/950/thumb/substratum.png?1548611133" + }, + { + "chainId": 1, + "address": "0x205ed31c867bf715e4182137af95afe9177cd8e7", + "name": "DEFY", + "symbol": "DEFY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26877/thumb/8ybr83fb0ca45cm1yvrcaclwbvcp.jpeg?1660622066" + }, + { + "chainId": 1, + "address": "0xbcc66ed2ab491e9ae7bf8386541fb17421fa9d35", + "name": "Skull", + "symbol": "SKULL", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/10641/thumb/skull.png?1581339740" + }, + { + "chainId": 1, + "address": "0x24ccedebf841544c9e6a62af4e8c2fa6e5a46fde", + "name": "BlueSparrow", + "symbol": "BLUESPARROW", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26085/thumb/bluesparrow.?1655766000" + }, + { + "chainId": 1, + "address": "0xfc44ec51c80e35a87bc2140299b1636ec83dfb04", + "name": "Volt", + "symbol": "ACDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5321/thumb/vivo.png?1548760105" + }, + { + "chainId": 1, + "address": "0x66a64a8a9cdc54ef97e45a051ba1c8f3d4b41a1d", + "name": "Baby Shiba Coin", + "symbol": "BABYSHIBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22707/thumb/9CmjzSIW_400x400.jpg?1642457763" + }, + { + "chainId": 1, + "address": "0xe0a16435df493bd17a58cb2ee58675f5ea069517", + "name": "Greeneum Network", + "symbol": "GREEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3069/thumb/Logo_web.png?1629084636" + }, + { + "chainId": 1, + "address": "0x7cc62d8e80be9bea3947f3443ad136f50f75b505", + "name": "Knekted", + "symbol": "KNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6488/thumb/42318068_480165755801061_8741315709394485248_n.jpg?1565651343" + }, + { + "chainId": 1, + "address": "0x4838903d6319e483ab82ae3f09a1ec36489a4193", + "name": "Famous Coin", + "symbol": "FAMOUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14416/thumb/famouscoin.jpg?1615951801" + }, + { + "chainId": 1, + "address": "0x351caa9045d65107b9d311d922d15887cfd634e4", + "name": "Arowana", + "symbol": "ARW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17114/thumb/ARW_logo_final.jpg?1626616242" + }, + { + "chainId": 1, + "address": "0xce593a29905951e8fc579bc092eca72577da575c", + "name": "GROM", + "symbol": "GR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13216/thumb/gr.png?1606278269" + }, + { + "chainId": 1, + "address": "0xeadc218ac4cb7895a5a56e6484646b48f841c45a", + "name": "MetaFinance", + "symbol": "MFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17365/thumb/meta.PNG?1627435447" + }, + { + "chainId": 1, + "address": "0x38d1b0d157529bd5d936719a8a5f8379afb24faa", + "name": "DataKYC", + "symbol": "DKYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7123/thumb/1btu7Lp__400x400.jpg?1547043621" + }, + { + "chainId": 1, + "address": "0x8db90e3e7d04c875a51997092f9178fcac9defdb", + "name": "Portal", + "symbol": "PORTAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6626/thumb/Nljbrphf_400x400.jpg?1547042827" + }, + { + "chainId": 1, + "address": "0x949bed886c739f1a3273629b3320db0c5024c719", + "name": "AMIS", + "symbol": "AMIS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/8445/thumb/amis-newlogo.png?1559633345" + }, + { + "chainId": 1, + "address": "0xc011a73ee8576fb46f5e1c5751ca3b9fe0af2a6f", + "name": "Synthetix Network", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3406/thumb/SNX.png?1598631139" + }, + { + "chainId": 1, + "address": "0xc1a85faa09c7f7247899f155439c5488b43e8429", + "name": "Metagochi", + "symbol": "MGCHI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21403/thumb/Lw9uYzse_400x400.jpg?1639086534" + }, + { + "chainId": 1, + "address": "0x5e9997684d061269564f94e5d11ba6ce6fa9528c", + "name": "Vendit", + "symbol": "VNDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18101/thumb/vndt.PNG?1630475586" + }, + { + "chainId": 1, + "address": "0x79c5a1ae586322a07bfb60be36e1b31ce8c84a1e", + "name": "Freight Trust Network", + "symbol": "EDI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11074/thumb/e6YLf6kD_400x400.jpg?1587970897" + }, + { + "chainId": 1, + "address": "0xbeef3bb9da340ebdf0f5bae2e85368140d7d85d0", + "name": "BuyMORE", + "symbol": "MORE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26769/thumb/0BD4687E-6C18-43D2-87C7-C5BC144B49D0_200x200.jpeg?1660040979" + }, + { + "chainId": 1, + "address": "0x2d39ec4da54329d28d230b4973f5aa27886c3aee", + "name": "NFX Coin", + "symbol": "NFXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10694/thumb/nfx.png?1604656044" + }, + { + "chainId": 1, + "address": "0x3d658390460295fb963f54dc0899cfb1c30776df", + "name": "Circuits of Value", + "symbol": "COVAL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/588/thumb/coval-logo.png?1599493950" + }, + { + "chainId": 1, + "address": "0x59e7b5db9be0bdd26fa048d39e01fee456ab674e", + "name": "Yearn Finance Bit2", + "symbol": "YFB2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13064/thumb/yfb2_logo.png?1604884273" + }, + { + "chainId": 1, + "address": "0x6b175474e89094c44da98b954eedeac495271d0f", + "name": "Dai", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9956/thumb/4943.png?1636636734" + }, + { + "chainId": 1, + "address": "0x6f3009663470475f0749a6b76195375f95495fcb", + "name": "Hatch DAO", + "symbol": "HATCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12526/thumb/hatch-dao.jpg?1600480488" + }, + { + "chainId": 1, + "address": "0x9043d4d51c9d2e31e3f169de4551e416970c27ef", + "name": "Prime DAI", + "symbol": "PDAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12338/thumb/pdai-200px.png?1599136775" + }, + { + "chainId": 1, + "address": "0xf911a7ec46a2c6fa49193212fe4a2a9b95851c27", + "name": "Antiample", + "symbol": "XAMP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/11925/thumb/antiample.png?1596168983" + }, + { + "chainId": 1, + "address": "0x0c9b3ab1bd0cf0745625381f5c3aa1cd9bbc7abb", + "name": "Exeno Coin", + "symbol": "EXN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25845/thumb/20323.png?1654145185" + }, + { + "chainId": 1, + "address": "0xea01906843ea8d910658a2c485ffce7c104ab2b6", + "name": "Qtoken", + "symbol": "QTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26024/thumb/8QyOrTCm_400x400.jpg?1655332588" + }, + { + "chainId": 1, + "address": "0xc01a327e30b0fbf32861333f238b5c36a60abc09", + "name": "Again Project", + "symbol": "AGAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21384/thumb/-Jjz5ZxF_400x400.jpg?1639034594" + }, + { + "chainId": 1, + "address": "0xa9536b9c75a9e0fae3b56a96ac8edf76abc91978", + "name": "Amun DeFi Index", + "symbol": "DFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16817/thumb/dfi.png?1644656347" + }, + { + "chainId": 1, + "address": "0x412d397ddca07d753e3e0c61e367fb1b474b3e7d", + "name": "8X8 Protocol", + "symbol": "EXE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9466/thumb/8x8_symbol_512x.png?1574320199" + }, + { + "chainId": 1, + "address": "0x27ad8e47c48063b209fa5ca14c8c46ece49b82d2", + "name": "Active World Rewards", + "symbol": "AWRT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24800/thumb/awrt.png?1648982991" + }, + { + "chainId": 1, + "address": "0x853bb55c1f469902f088a629db8c8803a9be3857", + "name": "Stable 1inch", + "symbol": "ONE1INCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17934/thumb/one1INCH.png?1629859813" + }, + { + "chainId": 1, + "address": "0xc133529e57681b2999708f9458be5634e293995e", + "name": "Ethernaal", + "symbol": "NAAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19909/thumb/miso-ethernaal-logo-256.png?1636104593" + }, + { + "chainId": 1, + "address": "0xe6710e0cda178f3d921f456902707b0d4c4a332b", + "name": "JULIEN", + "symbol": "JULIEN", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/12954/thumb/julien_logo.jpg?1603792446" + }, + { + "chainId": 1, + "address": "0xf56b164efd3cfc02ba739b719b6526a6fa1ca32a", + "name": "Curio Governance", + "symbol": "CGT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13607/thumb/QLwpua7.png?1610273891" + }, + { + "chainId": 1, + "address": "0x852e5427c86a3b46dd25e5fe027bb15f53c4bcb8", + "name": "NiiFi", + "symbol": "NIIFI", + "decimals": 15, + "logoURI": "https://assets.coingecko.com/coins/images/16033/thumb/niifi.PNG?1622674467" + }, + { + "chainId": 1, + "address": "0x5c147e74d63b1d31aa3fd78eb229b65161983b2b", + "name": "Wrapped Flow", + "symbol": "WFLOW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24045/thumb/wrapped-flow.png?1646187143" + }, + { + "chainId": 1, + "address": "0x3475fc1d0d2e03761c19d5c7601fe476f0e02f80", + "name": "Beep", + "symbol": "BOTZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27583/thumb/photo_2022-10-06_01-05-39.png?1665139287" + }, + { + "chainId": 1, + "address": "0x272f97b7a56a387ae942350bbc7df5700f8a4576", + "name": "Aave BAL", + "symbol": "ABAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17242/thumb/aBAL_2x.png?1626940749" + }, + { + "chainId": 1, + "address": "0x72adadb447784dd7ab1f472467750fc485e4cb2d", + "name": "Worldcore", + "symbol": "WRC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1358/thumb/worldcore.png?1548761189" + }, + { + "chainId": 1, + "address": "0x24dcc881e7dd730546834452f21872d5cb4b5293", + "name": "Data Transaction XD", + "symbol": "XD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3460/thumb/xd_01.png?1560142295" + }, + { + "chainId": 1, + "address": "0x3758e00b100876c854636ef8db61988931bb8025", + "name": "Uniqly", + "symbol": "UNIQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14808/thumb/Hnet-com-image.png?1618538742" + }, + { + "chainId": 1, + "address": "0x74beef5283f7605be17bd0bb3b118ad6ae9200e5", + "name": "Spooky Uni", + "symbol": "SPKU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27702/thumb/Spooky-Uni200x200.png?1665307264" + }, + { + "chainId": 1, + "address": "0xe29c5b523590165795bbd7d52369c2895b18841f", + "name": "Esports com", + "symbol": "ERT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1684/thumb/esports.jpg?1547035941" + }, + { + "chainId": 1, + "address": "0x6b5dde2c94ecc10c93e8a44288befad2a89bd657", + "name": "BARFIGHT", + "symbol": "BFIGHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27491/thumb/Safeimagekit-resized-imgpng_%2819%29.png?1664256020" + }, + { + "chainId": 1, + "address": "0xf938424f7210f31df2aee3011291b658f872e91e", + "name": "Visor", + "symbol": "VISR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14381/thumb/visor_logo.png?1615782828" + }, + { + "chainId": 1, + "address": "0x11ebe21e9d7bf541a18e1e3ac94939018ce88f0b", + "name": "Pitch FXS", + "symbol": "PITCHFXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28414/thumb/pitch.png?1670399849" + }, + { + "chainId": 1, + "address": "0x35101c731b1548b5e48bb23f99edbc2f5c341935", + "name": "BlackHoleSwap Compound DAI USDC", + "symbol": "BHSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12347/thumb/blackhole.PNG?1599201917" + }, + { + "chainId": 1, + "address": "0xea319e87cf06203dae107dd8e5672175e3ee976c", + "name": "Surf Finance", + "symbol": "SURF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12982/thumb/surf_200x200.png?1604050261" + }, + { + "chainId": 1, + "address": "0xece8531550fc599ccb2c7734494fbc358d0a9483", + "name": "Phoenix Protocol", + "symbol": "PP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26883/thumb/newgoldPPlogotransparent.PNG?1670213168" + }, + { + "chainId": 1, + "address": "0xcaaa93712bdac37f736c323c93d4d5fdefcc31cc", + "name": "CRD Network", + "symbol": "CRD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2859/thumb/CRD.png?1623397651" + }, + { + "chainId": 1, + "address": "0x1a2277c83930b7a64c3e3d5544eaa8c4f946b1b7", + "name": "e Chat", + "symbol": "ECHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1535/thumb/e-chat.png?1547035686" + }, + { + "chainId": 1, + "address": "0xd6c67b93a7b248df608a653d82a100556144c5da", + "name": "ExNetwork", + "symbol": "EXNT", + "decimals": 16, + "logoURI": "https://assets.coingecko.com/coins/images/12328/thumb/exnt_logo.png?1599102916" + }, + { + "chainId": 1, + "address": "0x74232704659ef37c08995e386a2e26cc27a8d7b1", + "name": "Strike", + "symbol": "STRK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14607/thumb/Jw-36llq_400x400.jpg?1617243607" + }, + { + "chainId": 1, + "address": "0x73c9275c3a2dd84b5741fd59aebf102c91eb033f", + "name": "Bitball Treasure", + "symbol": "BTRS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7273/thumb/btrs.png?1637556868" + }, + { + "chainId": 1, + "address": "0x182f4c4c97cd1c24e1df8fc4c053e5c47bf53bef", + "name": "keyTango", + "symbol": "TANGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14349/thumb/2Fv6IUqc_400x400.jpg?1615513660" + }, + { + "chainId": 1, + "address": "0x793786e2dd4cc492ed366a94b88a3ff9ba5e7546", + "name": "Axia", + "symbol": "AXIAV3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12906/thumb/axia_200x200.png?1613988058" + }, + { + "chainId": 1, + "address": "0xc1ad0aa69454603a5dee55cf9bd9341e01328544", + "name": "hiGAZERS", + "symbol": "HIGAZERS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28316/thumb/higazers.png?1669358592" + }, + { + "chainId": 1, + "address": "0x12300ed54f65648524c1bfaf86712927da6cc6fc", + "name": "MOVE Network", + "symbol": "MOVD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19236/thumb/MOVD_logo.png?1634772468" + }, + { + "chainId": 1, + "address": "0x16587cf43f044aba0165ffa00acf412631194e4b", + "name": "Simracer Coin", + "symbol": "SRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13027/thumb/SimRacer-500px.png?1604456794" + }, + { + "chainId": 1, + "address": "0x805ea9c07b49dd23ce11ec66dc6d8a2957385035", + "name": "Transient", + "symbol": "TSCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19061/thumb/200x200_%2833%29.png?1634266319" + }, + { + "chainId": 1, + "address": "0xa31b1767e09f842ecfd4bc471fe44f830e3891aa", + "name": "Roobee", + "symbol": "ROOBEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8791/thumb/Group_11.png?1580344629" + }, + { + "chainId": 1, + "address": "0xb453f1f2ee776daf2586501361c457db70e1ca0f", + "name": "AGA Rewards", + "symbol": "AGAR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14207/thumb/AR256.png?1614931200" + }, + { + "chainId": 1, + "address": "0x47d49d010c03b40f88f422502d694ff49fe6c9c8", + "name": "Giresunspor Token", + "symbol": "GRS", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24810/thumb/18444.png?1649024268" + }, + { + "chainId": 1, + "address": "0xbede1f59fa4412556fef69f1b9969f2003e3f8c1", + "name": "Meta MVRS", + "symbol": "MVRS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22140/thumb/mvrs-200x200.png?1640926136" + }, + { + "chainId": 1, + "address": "0x88d50b466be55222019d71f9e8fae17f5f45fca1", + "name": "Cryptaur", + "symbol": "CPT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2481/thumb/n3w6Z9xW_400x400.jpg?1548224365" + }, + { + "chainId": 1, + "address": "0xff603f43946a3a28df5e6a73172555d8c8b02386", + "name": "OneRoot Network", + "symbol": "RNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2520/thumb/OneRootNetwork.PNG?1558014608" + }, + { + "chainId": 1, + "address": "0xe41d2489571d322189246dafa5ebde1f4699f498", + "name": "0x", + "symbol": "ZRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/863/thumb/0x.png?1547034672" + }, + { + "chainId": 1, + "address": "0x1c7bbadc81e18f7177a95eb1593e5f5f35861b10", + "name": "Auric Network", + "symbol": "AUSCM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13015/thumb/auric-1-high-res_icon_300_PNG.png?1604384136" + }, + { + "chainId": 1, + "address": "0x752efadc0a7e05ad1bcccda22c141d01a75ef1e4", + "name": "CompliFi", + "symbol": "COMFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15006/thumb/complifi.PNG?1619413977" + }, + { + "chainId": 1, + "address": "0xa3665c69213bb9affcf92ab90100fbe273e3ab74", + "name": "D RUNT", + "symbol": "DRNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28245/thumb/d-run_ticker_200x200.png?1668590995" + }, + { + "chainId": 1, + "address": "0x1c7ede23b1361acc098a1e357c9085d131b34a01", + "name": "ShineDAO", + "symbol": "SHN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20555/thumb/SHN-Logo.png?1653470622" + }, + { + "chainId": 1, + "address": "0x2904b9b16652d7d0408eccfa23a19d4a3358230f", + "name": "Puriever", + "symbol": "PURE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12600/thumb/200x200_pure_logo.png?1600999358" + }, + { + "chainId": 1, + "address": "0x9f978aa425148cdd9223eb175446a877b86727ff", + "name": "PayYoda", + "symbol": "YOT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13632/thumb/w_72D81R_400x400.png?1610492214" + }, + { + "chainId": 1, + "address": "0x7d4b8cce0591c9044a22ee543533b72e976e36c3", + "name": "Change", + "symbol": "CAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1021/thumb/200x200.png?1610766224" + }, + { + "chainId": 1, + "address": "0xe63d6b308bce0f6193aec6b7e6eba005f41e36ab", + "name": "Stone", + "symbol": "STN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14593/thumb/stone-logo.png?1617164796" + }, + { + "chainId": 1, + "address": "0x3983c6da8235f59e16a034ee773e60a69e8f14b2", + "name": "Fairmint", + "symbol": "FAIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27109/thumb/fairmint.png?1662881621" + }, + { + "chainId": 1, + "address": "0xf88b137cfa667065955abd17525e89edcf4d6426", + "name": "iTrust Governance", + "symbol": "ITG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16713/thumb/anchor.png?1624840761" + }, + { + "chainId": 1, + "address": "0x321c2fe4446c7c963dc41dd58879af648838f98d", + "name": "Cryptex Finance", + "symbol": "CTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14932/thumb/glossy_icon_-_C200px.png?1619073171" + }, + { + "chainId": 1, + "address": "0x2fd61567c29e7adb4ca17e60e1f4a3fcfe68acb8", + "name": "SymVerse", + "symbol": "SYM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9449/thumb/Picture1.png?1567551375" + }, + { + "chainId": 1, + "address": "0xa0f0546eb5e3ee7e8cfc5da12e5949f3ae622675", + "name": "Tokoin", + "symbol": "TOKO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8807/thumb/TOKOIN_LOGO_%28no_text%29.png?1646664093" + }, + { + "chainId": 1, + "address": "0xf8ed6c51762208ff26f8f3e4efd4e06af2da649c", + "name": "Alldex Alliance", + "symbol": "AXA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9438/thumb/alldex.png?1569122383" + }, + { + "chainId": 1, + "address": "0x0a6e18fb2842855c3af925310b0f50a4bfa17909", + "name": "CoinPoker", + "symbol": "CHP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1808/thumb/coinpoker.jpg?1547036113" + }, + { + "chainId": 1, + "address": "0x42726d074bba68ccc15200442b72afa2d495a783", + "name": "Isiklar Coin", + "symbol": "ISIKC", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/10992/thumb/logo_%2866%29.png?1586940186" + }, + { + "chainId": 1, + "address": "0x24692791bc444c5cd0b81e3cbcaba4b04acd1f3b", + "name": "Unikoin Gold", + "symbol": "UKG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1120/thumb/unikoin-gold.png?1548759441" + }, + { + "chainId": 1, + "address": "0x8207c1ffc5b6804f6024322ccf34f29c3541ae26", + "name": "Origin Protocol", + "symbol": "OGN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3296/thumb/op.jpg?1547037878" + }, + { + "chainId": 1, + "address": "0xba485b556399123261a5f9c95d413b4f93107407", + "name": "Gravitationally Bound AURA", + "symbol": "GRAVIAURA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26368/thumb/graviaura.png?1657606852" + }, + { + "chainId": 1, + "address": "0xcf9c692f7e62af3c571d4173fd4abf9a3e5330d0", + "name": "Onigiri", + "symbol": "ONIGIRI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12699/thumb/onigiri-coingecko.png?1601857724" + }, + { + "chainId": 1, + "address": "0x68a3637ba6e75c0f66b61a42639c4e9fcd3d4824", + "name": "MoonSwap", + "symbol": "MOON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12441/thumb/moon.jpg?1599880968" + }, + { + "chainId": 1, + "address": "0xdac17f958d2ee523a2206206994597c13d831ec7", + "name": "Tether", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/325/thumb/Tether.png?1668148663" + }, + { + "chainId": 1, + "address": "0x9f7fc686cfd64aa5ae15b351d03071e91533094b", + "name": "Trace Network Labs", + "symbol": "TRACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23266/thumb/Token_Icon_02.png?1655797843" + }, + { + "chainId": 1, + "address": "0x9b2b931d6ab97b6a887b2c5d8529537e6fe73ebe", + "name": "All In", + "symbol": "ALLIN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28411/thumb/IMG_20221206_124556_908.png?1670387132" + }, + { + "chainId": 1, + "address": "0x4fbb0b4cd8f960ac3428194f1c94c805d5b35836", + "name": "BigBang Game", + "symbol": "BBGC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7719/thumb/rxpRt7tH_400x400.jpg?1549957251" + }, + { + "chainId": 1, + "address": "0x3be7bf1a5f23bd8336787d0289b70602f1940875", + "name": "VIDT DAO", + "symbol": "VIDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27552/thumb/VIDTDAO_logo.png?1670333277" + }, + { + "chainId": 1, + "address": "0xd533a949740bb3306d119cc777fa900ba034cd52", + "name": "Curve DAO", + "symbol": "CRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12124/thumb/Curve.png?1597369484" + }, + { + "chainId": 1, + "address": "0x4e3fbd56cd56c3e72c1403e103b45db9da5b9d2b", + "name": "Convex Finance", + "symbol": "CVX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15585/thumb/convex.png?1621256328" + }, + { + "chainId": 1, + "address": "0x8ae340d333ffb274969f505a6520b91024bc856c", + "name": "The Dragon Gate", + "symbol": "KOI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26730/thumb/koi.png?1659882726" + }, + { + "chainId": 1, + "address": "0x0d02755a5700414b26ff040e1de35d337df56218", + "name": "BendDAO", + "symbol": "BEND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22829/thumb/benddao.PNG?1642664553" + }, + { + "chainId": 1, + "address": "0x24efe6b87bf1bfe9ea2ccb5a9d0a959c7172b364", + "name": "Global AEX", + "symbol": "GAT", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/7008/thumb/a3b65903bffb6e47b225bdd70c635701.png?1601426171" + }, + { + "chainId": 1, + "address": "0xf6c0aa7ebfe9992200c67e5388e4f42da49e1783", + "name": "Psyche", + "symbol": "USD1", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/13661/thumb/Psyche-logo-256.png?1610600682" + }, + { + "chainId": 1, + "address": "0xbea0000029ad1c77d3d5d23ba2d8893db9d1efab", + "name": "Bean", + "symbol": "BEAN", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/18447/thumb/bean-logo-coingecko.png?1632090495" + }, + { + "chainId": 1, + "address": "0x1da87b114f35e1dc91f72bf57fc07a768ad40bb0", + "name": "Equalizer", + "symbol": "EQZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14741/thumb/X2p5mb2f_400x400.png?1618005664" + }, + { + "chainId": 1, + "address": "0x9c7376b5060c47e555f5f53005aa3d5a7c66f2fb", + "name": "Swapify", + "symbol": "SWIFY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28402/thumb/photo_2022-12-04_03-17-07.jpg?1670300125" + }, + { + "chainId": 1, + "address": "0x547b2f82cecfab9c2b1d36fdda96ef9f58c63b8c", + "name": "Taxa Network", + "symbol": "TXT", + "decimals": 18 + }, + { + "chainId": 1, + "address": "0x8ef47555856f6ce2e0cd7c36aef4fab317d2e2e2", + "name": "PayAccept", + "symbol": "PAYT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12513/thumb/logo.png?1603801944" + }, + { + "chainId": 1, + "address": "0xefc996ce8341cd36c55412b51df5bbca429a7617", + "name": "Metaverse Index Token", + "symbol": "METAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22233/thumb/16782.png?1641247980" + }, + { + "chainId": 1, + "address": "0x0af44e2784637218dd1d32a322d44e603a8f0c6a", + "name": "MATRYX", + "symbol": "MTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1495/thumb/matryx.png?1547978542" + }, + { + "chainId": 1, + "address": "0x4c11249814f11b9346808179cf06e71ac328c1b5", + "name": "Oraichain", + "symbol": "ORAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12931/thumb/orai.png?1647077378" + }, + { + "chainId": 1, + "address": "0x41b3f18c6384dc9a39c33afeca60d9b8e61eaa9f", + "name": "Noah Decentralized State Coin", + "symbol": "NOAHP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3442/thumb/FvG3XweD.png?1610437675" + }, + { + "chainId": 1, + "address": "0x1378ec93ab2b07ba5a0eaef19cf354a33f64b9fd", + "name": "Yearn Finance Diamond", + "symbol": "YFDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12824/thumb/yfdt_logo.png?1602814305" + }, + { + "chainId": 1, + "address": "0x667102bd3413bfeaa3dffb48fa8288819e480a88", + "name": "Tokenize Xchange", + "symbol": "TKX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4984/thumb/Tokenize.png?1561602968" + }, + { + "chainId": 1, + "address": "0xc18c07a18198a6340cf4d94855fe5eb6dd33b46e", + "name": "QLINDO", + "symbol": "QLINDO", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/26851/thumb/21315.png?1660467490" + }, + { + "chainId": 1, + "address": "0x7707aada3ce7722ac63b91727daf1999849f6835", + "name": "Bankera", + "symbol": "BNK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1949/thumb/bankera.png?1650883375" + }, + { + "chainId": 1, + "address": "0x945facb997494cc2570096c74b5f66a3507330a1", + "name": "mStable BTC", + "symbol": "MBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13973/thumb/mbtc.png?1613485921" + }, + { + "chainId": 1, + "address": "0xd44bb6663936cab1310584a277f7daa6943d4904", + "name": "Winco", + "symbol": "WCO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3628/thumb/Webp.net-resizeimage_%281%29.png?1547038550" + }, + { + "chainId": 1, + "address": "0xf8eb56c7e4e3c885c905a19583bf41644d35aa0a", + "name": "PIXLS Vault NFTX ", + "symbol": "PIXLS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18351/thumb/pixls.png?1631604206" + }, + { + "chainId": 1, + "address": "0x0770e5018b71f5fbda00f42dd13507e03d101a90", + "name": "Niros", + "symbol": "NIROS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22409/thumb/oJEphc3R_400x400.jpg?1641797798" + }, + { + "chainId": 1, + "address": "0xc0a4df35568f116c370e6a6a6022ceb908eeddac", + "name": "Umee", + "symbol": "UMEE", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/20635/thumb/1Ab_Umee_Brand_Icon_Full_Color.png?1645018295" + }, + { + "chainId": 1, + "address": "0x68a9d92fe19399feebed6a9a0980a7ea7638074c", + "name": "Iqoniq", + "symbol": "IQQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14672/thumb/IQONIQ-Cointransparant.png?1617678461" + }, + { + "chainId": 1, + "address": "0x69fa8e7f6bf1ca1fb0de61e1366f7412b827cc51", + "name": "EnreachDAO", + "symbol": "NRCH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14694/thumb/enreachdao.jpg?1617813758" + }, + { + "chainId": 1, + "address": "0x607c794cda77efb21f8848b7910ecf27451ae842", + "name": "DeFiPie", + "symbol": "PIE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11956/thumb/98j5E_EG_400x400.png?1596644614" + }, + { + "chainId": 1, + "address": "0xfd4168e642ebd04c3684a6cdb3a5e86de85d3908", + "name": "The APIS", + "symbol": "API", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14055/thumb/Screenshot_2022-03-10_at_11.09.50_AM.png?1646882043" + }, + { + "chainId": 1, + "address": "0x986ee2b944c42d017f52af21c4c69b84dbea35d8", + "name": "BitMart", + "symbol": "BMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5236/thumb/bitmart-token.png?1548835017" + }, + { + "chainId": 1, + "address": "0xb13d747d783bf1a9f1d65df74c080c890045f17e", + "name": "Foundation", + "symbol": "FND", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/28099/thumb/ddsaaa.png?1667538993" + }, + { + "chainId": 1, + "address": "0x65def5029a0e7591e46b38742bfedd1fb7b24436", + "name": "Kanpeki", + "symbol": "KAE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18833/thumb/kanpeki-logo-square_2.png?1633628384" + }, + { + "chainId": 1, + "address": "0xc150bac3cd3678acb2c093e433bed40a6ef08542", + "name": "Shiny", + "symbol": "SHINY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20832/thumb/shiny-token-200px.png?1637734428" + }, + { + "chainId": 1, + "address": "0x7de91b204c1c737bcee6f000aaa6569cf7061cb7", + "name": "Robonomics Network", + "symbol": "XRT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/7024/thumb/Robonomics-Network-logo.png?1547043451" + }, + { + "chainId": 1, + "address": "0x5f20f15d40f24dae50a72be3b5edddddfb5a5bd0", + "name": "Bobamask", + "symbol": "BOBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24072/thumb/200_x_200_logo.png?1651220892" + }, + { + "chainId": 1, + "address": "0x5caf454ba92e6f2c929df14667ee360ed9fd5b26", + "name": "Dev Protocol", + "symbol": "DEV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11560/thumb/Dev_Protocol__CoinGecko_Logo___Jan.18.2021_.png?1611021474" + }, + { + "chainId": 1, + "address": "0xca3ea3061d638e02113aa960340c98343b5acd62", + "name": "Bittwatt", + "symbol": "BWT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4777/thumb/bittwatt.png?1547274101" + }, + { + "chainId": 1, + "address": "0x89bd2e7e388fab44ae88bef4e1ad12b4f1e0911c", + "name": "Peanut", + "symbol": "NUX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13958/thumb/2sAMZXpO_400x400.jpg?1613353972" + }, + { + "chainId": 1, + "address": "0xa5e412ba6fca1e07b15defcaa4236ff7b5a7f086", + "name": "Crypto Bank", + "symbol": "CBANK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13473/thumb/HHeUVDBF5clKgE4vW_dyCtcTZqWDRw_vDe1MA3lIJWI4wEZW2BwF5dHFbm_ZpJNTWf85sZxCBVl2R7u29kGg37bE8XkGh3CneW6SkVwbnQEe0r2WR6yy6THxMvzIMiicWza82-NyjMitEo84_2E_C5LCiBcdTPFrjNQiMs1DTSJuaRTNB81KRsdcXNW0p2j7PH8O7Xk3QrWVjPe.jpg?1608853514" + }, + { + "chainId": 1, + "address": "0x308564dc5217c39386f5eae96545159e1d396661", + "name": "HLP", + "symbol": "HLP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12668/thumb/simbolo-hlp-token.png?1601467816" + }, + { + "chainId": 1, + "address": "0xcc1c0fbaecf0fe1c4703d77ec284cdf8a06253c5", + "name": "Catcher DAO", + "symbol": "CDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26747/thumb/logo200.png?1660014948" + }, + { + "chainId": 1, + "address": "0x3c6da7763caa0e4b684bbc733f04a8ec08af3762", + "name": "MODEL X coin", + "symbol": "MODX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6603/thumb/LOGO-MODX.png?1547042808" + }, + { + "chainId": 1, + "address": "0x603778e5e07e180e300bd10df7fa626313a206b2", + "name": "WIZ Protocol", + "symbol": "WIZ", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/28069/thumb/logo_WIZ.png?1670297648" + }, + { + "chainId": 1, + "address": "0xe22020f47b7378dfedcedd2c81d4137c22fe1152", + "name": "My Liquidity Partner", + "symbol": "MLP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26204/thumb/4xZ5Nb52_400x400.jpg?1656491493" + }, + { + "chainId": 1, + "address": "0xb1e9157c2fdcc5a856c8da8b2d89b6c32b3c1229", + "name": "Zenfuse", + "symbol": "ZEFU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12796/thumb/zenfuse.jpg?1602640333" + }, + { + "chainId": 1, + "address": "0x1456688345527be1f37e9e627da0837d6f08c925", + "name": "USDP Stablecoin", + "symbol": "USDP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13234/thumb/USDP.png?1606579598" + }, + { + "chainId": 1, + "address": "0xf6af18f94d55b8888b557cb3da0ec623ba245f80", + "name": "SocialBlox", + "symbol": "SBLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24769/thumb/x86VE7oQ.png?1648817788" + }, + { + "chainId": 1, + "address": "0xeb7355c2f217b3485a591332fe13c8c5a76a581d", + "name": "Jubi Token", + "symbol": "JT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10994/thumb/Af5MFcVY_400x400.jpg?1586998222" + }, + { + "chainId": 1, + "address": "0x1e2d230c7a7f4c679fb1378f1f51dedeae85cd72", + "name": "PYROmatic", + "symbol": "PYRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26662/thumb/PYRO.png?1669792973" + }, + { + "chainId": 1, + "address": "0x102203517ce35ac5cab9a2cda80df03f26c7419b", + "name": "SUMOTEX", + "symbol": "SMTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27478/thumb/Sumotex_telegram_image_PNG.jpg?1664198249" + }, + { + "chainId": 1, + "address": "0xad6a626ae2b43dcb1b39430ce496d2fa0365ba9c", + "name": "PieDAO DEFI Small Cap", + "symbol": "DEFI+S", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12701/thumb/DefiS.png?1601862595" + }, + { + "chainId": 1, + "address": "0x76306f029f8f99effe509534037ba7030999e3cf", + "name": "Acreage Coin", + "symbol": "ACR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5100/thumb/acreage-coin.jpg?1547040494" + }, + { + "chainId": 1, + "address": "0x15d4c048f83bd7e37d49ea4c83a07267ec4203da", + "name": "GALA", + "symbol": "GALA", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12493/thumb/GALA-COINGECKO.png?1600233435" + }, + { + "chainId": 1, + "address": "0x2b591e99afe9f32eaa6214f7b7629768c40eeb39", + "name": "HEX", + "symbol": "HEX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10103/thumb/HEX-logo.png?1575942673" + }, + { + "chainId": 1, + "address": "0x6e0615a03ed9527a6013fcd5b556e36ef4dab1ff", + "name": "HNB Protocol", + "symbol": "HNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26182/thumb/HNB_200x200.png?1656383307" + }, + { + "chainId": 1, + "address": "0xca3fe04c7ee111f0bbb02c328c699226acf9fd33", + "name": "SEEN", + "symbol": "SEEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13052/thumb/seen_logo.png?1604678509" + }, + { + "chainId": 1, + "address": "0xff709449528b6fb6b88f557f7d93dece33bca78d", + "name": "ApeUSD", + "symbol": "APEUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25621/thumb/ApeUSD.png?1652857577" + }, + { + "chainId": 1, + "address": "0x15334dcb171e8b65d6650321581dca83be870115", + "name": "Wrapped BIND", + "symbol": "WBIND", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13055/thumb/o1w2cBW.png?1604720921" + }, + { + "chainId": 1, + "address": "0x7603de2ea4cbceb0250118de03fcb70fe1e8e935", + "name": "AMC Fight Night", + "symbol": "AMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17290/thumb/amc.PNG?1627252646" + }, + { + "chainId": 1, + "address": "0x77c07555af5ffdc946fb47ce15ea68620e4e7170", + "name": "Breezecoin", + "symbol": "BRZE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6727/thumb/breezecoin.png?1547563369" + }, + { + "chainId": 1, + "address": "0x2ee543b8866f46cc3dc93224c6742a8911a59750", + "name": "MetaVerse Dog", + "symbol": "MVDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23581/thumb/imgonline-com-ua-Resize-5J7DYgBqxK7I.png?1644646598" + }, + { + "chainId": 1, + "address": "0xb20043f149817bff5322f1b928e89abfc65a9925", + "name": "EXRT Network", + "symbol": "EXRT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5954/thumb/exrt.png?1616039881" + }, + { + "chainId": 1, + "address": "0xa49811140e1d6f653dec28037be0924c811c4538", + "name": "PR F Protocol", + "symbol": "PRUF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27482/thumb/prufu-200x200_1.png?1664246561" + }, + { + "chainId": 1, + "address": "0x374fb05c96c36348b92e38fb088b26b8511e3b3d", + "name": "CROWD", + "symbol": "CWD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24125/thumb/cwd.png?1646463219" + }, + { + "chainId": 1, + "address": "0xfc98e825a2264d890f9a1e68ed50e1526abccacd", + "name": "Moss Carbon Credit", + "symbol": "MCO2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14414/thumb/ENtxnThA_400x400.jpg?1615948522" + }, + { + "chainId": 1, + "address": "0x84bb947fcedba6b9c7dcead42df07e113bb03007", + "name": "Stater", + "symbol": "STR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14476/thumb/str.png?1639046202" + }, + { + "chainId": 1, + "address": "0x7a83ff237e7870d8d6c3485920ebe654d2841315", + "name": "hiOD", + "symbol": "HIOD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28238/thumb/hiod.png?1668579474" + }, + { + "chainId": 1, + "address": "0xb837b6467b4878fb5b3b81664042852593f15126", + "name": "BitValve", + "symbol": "BTV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20681/thumb/bitvalve-icon-200x200.png?1637551577" + }, + { + "chainId": 1, + "address": "0x95e40e065afb3059dcabe4aaf404c1f92756603a", + "name": "King DAG", + "symbol": "KDAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10809/thumb/3xcLUorv_400x400.jpg?1591000563" + }, + { + "chainId": 1, + "address": "0xa143ac515dca260a46c742c7251ef3b268639593", + "name": "Bulk Network", + "symbol": "BULK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15266/thumb/Bulk_whale_round.png?1620285364" + }, + { + "chainId": 1, + "address": "0x1da01e84f3d4e6716f274c987ae4bee5dc3c8288", + "name": "DeFi Bids", + "symbol": "BID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12344/thumb/IMG_20200919_115022_477.png?1600739441" + }, + { + "chainId": 1, + "address": "0x420412e765bfa6d85aaac94b4f7b708c89be2e2b", + "name": "Brazilian Digital", + "symbol": "BRZ", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/8472/thumb/2_vtiD3xwce9knG2COxtSMaQ.png?1597786961" + }, + { + "chainId": 1, + "address": "0x8c7e3b5e720b7a9bbcf15c38be5b657bb2b71dba", + "name": "GreenTek", + "symbol": "GTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21770/thumb/small-200x200-logo.png?1639994780" + }, + { + "chainId": 1, + "address": "0xed91879919b71bb6905f23af0a68d231ecf87b14", + "name": "DMM Governance", + "symbol": "DMG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11677/thumb/dmm.png?1592674690" + }, + { + "chainId": 1, + "address": "0x86696431d6aca9bae5ce6536ecf5d437f2e6dba2", + "name": "SoftChain", + "symbol": "SCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6613/thumb/FgUyfr6K_400x400.jpg?1547042814" + }, + { + "chainId": 1, + "address": "0xb893a8049f250b57efa8c62d51527a22404d7c9a", + "name": "American Shiba", + "symbol": "USHIBA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15650/thumb/american_shiba.PNG?1621476610" + }, + { + "chainId": 1, + "address": "0xf5717f5df41ea67ef67dfd3c1d02f9940bcf5d08", + "name": "SeChain", + "symbol": "SNN", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/11961/thumb/2AsGMTeI_400x400.jpg?1596453536" + }, + { + "chainId": 1, + "address": "0x24bcec1afda63e622a97f17cff9a61ffcfd9b735", + "name": "Crab Market", + "symbol": "CRAB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28356/thumb/200-icon.png?1669776793" + }, + { + "chainId": 1, + "address": "0x669db4c47f89f21554ebd825a744888725fd9491", + "name": "hiPENGUINS", + "symbol": "HIPENGUINS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28381/thumb/63856bebcd8c700001b23c42_hiPENGUINS-_Logo.png?1669974038" + }, + { + "chainId": 1, + "address": "0x6b3595068778dd592e39a122f4f5a5cf09c90fe2", + "name": "Sushi", + "symbol": "SUSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12271/thumb/512x512_Logo_no_chop.png?1606986688" + }, + { + "chainId": 1, + "address": "0xe49214e4c92dc9bcb3b56c1309afe0d626dd730e", + "name": "SynchroCoin", + "symbol": "SYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1469/thumb/ud643DVg.png?1621828021" + }, + { + "chainId": 1, + "address": "0xa66daa57432024023db65477ba87d4e7f5f95213", + "name": "Huobi Pool", + "symbol": "HPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6628/thumb/Huobi_pool_token.png?1547042829" + }, + { + "chainId": 1, + "address": "0xacfa209fb73bf3dd5bbfb1101b9bc999c49062a5", + "name": "EvidenZ", + "symbol": "BCDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2014/thumb/evidenz-512.png?1594871754" + }, + { + "chainId": 1, + "address": "0x320623b8e4ff03373931769a31fc52a4e78b5d70", + "name": "Reserve Rights", + "symbol": "RSR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8365/thumb/rsr.png?1637983320" + }, + { + "chainId": 1, + "address": "0x99d8a9c45b2eca8864373a26d1459e3dff1e17f3", + "name": "Magic Internet Money", + "symbol": "MIM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16786/thumb/mimlogopng.png?1624979612" + }, + { + "chainId": 1, + "address": "0xe1030b48b2033314979143766d7dc1f40ef8ce11", + "name": "The People s Coin", + "symbol": "PEEPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16777/thumb/CoinGecko_updated_200_by_200.png?1629548157" + }, + { + "chainId": 1, + "address": "0x0a0db74ef8b4480cc29b7d68647727feeb1ea4ec", + "name": "GLEX", + "symbol": "GLEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11609/thumb/1578901576974.png?1591777246" + }, + { + "chainId": 1, + "address": "0x0fbe9cc858d7ad6e246fe9d01aed22abd2a66f0b", + "name": "Danat Coin", + "symbol": "DNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13170/thumb/1528717728file.png?1605855085" + }, + { + "chainId": 1, + "address": "0x05fc938cc60fb71381514877d66478bab7e2e1ce", + "name": "SUPERCATS", + "symbol": "S-CATS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26675/thumb/Supercats_logo.png?1659517034" + }, + { + "chainId": 1, + "address": "0x7968bc6a03017ea2de509aaa816f163db0f35148", + "name": "Hedget", + "symbol": "HGET", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/12453/thumb/Hedget.png?1599944809" + }, + { + "chainId": 1, + "address": "0xba100000625a3754423978a60c9317c58a424e3d", + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11683/thumb/Balancer.png?1592792958" + }, + { + "chainId": 1, + "address": "0x328c4c80bc7aca0834db37e6600a6c49e12da4de", + "name": "Aave SNX v1", + "symbol": "ASNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11733/thumb/aSNX.png?1593085047" + }, + { + "chainId": 1, + "address": "0x7f1f2d3dfa99678675ece1c243d3f7bc3746db5d", + "name": "TapX", + "symbol": "TAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13942/thumb/tapx.png?1652444051" + }, + { + "chainId": 1, + "address": "0xc7bba5b765581efb2cdd2679db5bea9ee79b201f", + "name": "Gems", + "symbol": "GEM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3945/thumb/Webp.net-resizeimage_%2817%29.jpg?1547038970" + }, + { + "chainId": 1, + "address": "0xf680429328caaacabee69b7a9fdb21a71419c063", + "name": "Butterfly Protocol", + "symbol": "BFLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13882/thumb/ButterflyProtocolNoText_sm.png?1612492535" + }, + { + "chainId": 1, + "address": "0xc242eb8e4e27eae6a2a728a41201152f19595c83", + "name": "EcoFi", + "symbol": "ECO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14803/thumb/logo_-_2021-04-16T081409.817.png?1618532056" + }, + { + "chainId": 1, + "address": "0xd0c37cda48fe5d6ee7132181a90dc58206db5404", + "name": "INKz", + "symbol": "INKZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21860/thumb/INKZ_TOKEN.png?1640149351" + }, + { + "chainId": 1, + "address": "0xbf4a9a37ecfc21825011285222c36ab35de51f14", + "name": "Nyan V2", + "symbol": "NYAN-2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13093/thumb/v2-logo.png?1605067493" + }, + { + "chainId": 1, + "address": "0x952b65d976e8669c4ce92a17cce5b2586912adb5", + "name": "Etrade", + "symbol": "ETT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9111/thumb/NkGLvEO2_400x400.jpg?1564435046" + }, + { + "chainId": 1, + "address": "0xf0fac7104aac544e4a7ce1a55adf2b5a25c65bd1", + "name": "Pamp Network", + "symbol": "PAMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11546/thumb/pMqJaqDK_400x400.jpg?1595199126" + }, + { + "chainId": 1, + "address": "0x227c7df69d3ed1ae7574a1a7685fded90292eb48", + "name": "Milady Vault NFTX ", + "symbol": "MILADY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26540/thumb/256x256.png?1658730893" + }, + { + "chainId": 1, + "address": "0x5fdfe5ee55ae0fb7e0dba3481ea46f22fc92cbbb", + "name": "McDoge", + "symbol": "MCDOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23096/thumb/IL1fIBa.png?1643183135" + }, + { + "chainId": 1, + "address": "0xd6caf5bd23cf057f5fccce295dcc50c01c198707", + "name": "Evanesco Network", + "symbol": "EVA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16722/thumb/evan.PNG?1624849154" + }, + { + "chainId": 1, + "address": "0x71e368ed06814bf35d4e663eff946400a5bc8115", + "name": "Degrain", + "symbol": "DGRN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27570/thumb/degrain.jpeg?1664778517" + }, + { + "chainId": 1, + "address": "0x70e8de73ce538da2beed35d14187f6959a8eca96", + "name": "XSGD", + "symbol": "XSGD", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/12832/thumb/StraitsX_Singapore_Dollar_%28XSGD%29_Token_Logo.png?1633936813" + }, + { + "chainId": 1, + "address": "0x34748fedad669c788aabe4fb325a4587941f7b48", + "name": "Tosa Inu", + "symbol": "TOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27248/thumb/Capture6.JPG?1662891903" + }, + { + "chainId": 1, + "address": "0x1ffe8a8177d3c261600a8bd8080d424d64b7fbc2", + "name": "Metroverse", + "symbol": "MET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23303/thumb/met.png?1644054503" + }, + { + "chainId": 1, + "address": "0xf3eb8b90c763b8b2b53e7819ac27eca8f94c8ec2", + "name": "EtherSmart", + "symbol": "ETM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18019/thumb/ethersmart.PNG?1630281887" + }, + { + "chainId": 1, + "address": "0x00a7ec2f2b451cb0233e8adbf4c9a951027c2b02", + "name": "hiENS4", + "symbol": "HIENS4", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26921/thumb/62f9ec6fd1c44e000102051d_MicrosoftTeams-image.png?1660817481" + }, + { + "chainId": 1, + "address": "0xa11bd36801d8fa4448f0ac4ea7a62e3634ce8c7c", + "name": "Allbridge", + "symbol": "ABR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18690/thumb/abr.png?1640742053" + }, + { + "chainId": 1, + "address": "0x7b123f53421b1bf8533339bfbdc7c98aa94163db", + "name": "dfohub", + "symbol": "BUIDL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11131/thumb/buidllogo.png?1599577041" + }, + { + "chainId": 1, + "address": "0xf80d589b3dbe130c270a69f1a69d050f268786df", + "name": "Datamine", + "symbol": "DAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11695/thumb/qxsFH8W.png?1592880463" + }, + { + "chainId": 1, + "address": "0x294559fa758c88d639fd085751e463fee7806eab", + "name": "Metal Blockchain", + "symbol": "METAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27222/thumb/metal-chain.png?1662685566" + }, + { + "chainId": 1, + "address": "0x71a28feaee902966dc8d355e7b8aa427d421e7e0", + "name": "LunchDAO", + "symbol": "LUNCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25808/thumb/200x200.png?1653979480" + }, + { + "chainId": 1, + "address": "0x1e4ec900dd162ebaf6cf76cfe8a546f34d7a483d", + "name": "Tuzlaspor Token", + "symbol": "TUZLA", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24812/thumb/Tuzlaspors-Token-Supply-Started-at-Bitexen-980x400.png?1649024989" + }, + { + "chainId": 1, + "address": "0x6347978f54f75d76630b819897f9ce68c83ce2a2", + "name": "Cordium", + "symbol": "CORD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28013/thumb/IMG-20221026-WA0025.png?1666947806" + }, + { + "chainId": 1, + "address": "0x7105faa4a26ed1c67b8b2b41bec98f06ee21d105", + "name": "X7105", + "symbol": "X7105", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28423/thumb/X7105_LOGO_black_back_200_x_200_px.png?1670460916" + }, + { + "chainId": 1, + "address": "0x8a845fc339ceb022a695281554890429a34df120", + "name": "MangoChain", + "symbol": "MGP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11140/thumb/JJLGKTqL8jZunfdW5-gyQYxZBeCoHoLzoXfpaEwVYARssAaJoObmOxIRqz0f1oMRIbiMWP0Jfq1aM99-_aEI3fqoMvpUy2sD-d5ZGZAR3gxeY26OQrom9MmaY7GmONjoLebGcdA3r0IVlLxKhtcAO2XJrirbnXO6RxsJbImGPLlkE7c8KxH4Y1zjnAMqHi7xgv7PnV5iwpEiIUa.jpg?1588910984" + }, + { + "chainId": 1, + "address": "0xfae4ee59cdd86e3be9e8b90b53aa866327d7c090", + "name": "CPChain", + "symbol": "CPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2760/thumb/cpchain.png?1547036953" + }, + { + "chainId": 1, + "address": "0xd49374d1d6d2b2d793035a0116f2b0d19230de26", + "name": "Bishu Finance", + "symbol": "BISHUFI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19606/thumb/bishu.jpeg?1635492531" + }, + { + "chainId": 1, + "address": "0x3c72fca8523686fd9e5740b0826fa4bb376e0241", + "name": "300FIT", + "symbol": "FIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9690/thumb/6mkyI4Ss_400x400.png?1570832640" + }, + { + "chainId": 1, + "address": "0x336f646f87d9f6bc6ed42dd46e8b3fd9dbd15c22", + "name": "Crystal Clear", + "symbol": "CCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/995/thumb/crystal-clear.png?1547034897" + }, + { + "chainId": 1, + "address": "0xeb986da994e4a118d5956b02d8b7c3c7ce373674", + "name": "Gather", + "symbol": "GTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12458/thumb/Gather-Logo-Working-File.png?1599981686" + }, + { + "chainId": 1, + "address": "0x3432b6a60d23ca0dfca7761b7ab56459d9c964d0", + "name": "Frax Share", + "symbol": "FXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13423/thumb/ethCanonicalFXS.png?1669276861" + }, + { + "chainId": 1, + "address": "0x4e08f03079c5cd3083ea331ec61bcc87538b7665", + "name": "DoubleDice", + "symbol": "DODI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21035/thumb/crEjNfhF_400x400.jpg?1638250608" + }, + { + "chainId": 1, + "address": "0x5c59a5b139b0538cb106d775a022cad98dd14b5a", + "name": "XREATORS", + "symbol": "ORT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25678/thumb/XREATORS_ORT_Logo.png?1653548310" + }, + { + "chainId": 1, + "address": "0xa88842ae47dbe87116cf7001dddd1b246fcd8262", + "name": "hiENS3", + "symbol": "HIENS3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27262/thumb/hiens3.png?1663059024" + }, + { + "chainId": 1, + "address": "0x9ff58f4ffb29fa2266ab25e75e2a8b3503311656", + "name": "Aave WBTC", + "symbol": "AWBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14244/thumb/aWBTC.41453c2a.png?1615528721" + }, + { + "chainId": 1, + "address": "0xdecade1c6bf2cd9fb89afad73e4a519c867adcf5", + "name": "Experty Wisdom", + "symbol": "WIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13133/thumb/n0MTVBrm_400x400.jpg?1605543934" + }, + { + "chainId": 1, + "address": "0xddd6a0ecc3c6f6c102e5ea3d8af7b801d1a77ac8", + "name": "UniX", + "symbol": "UNIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20674/thumb/unix.png?1663499268" + }, + { + "chainId": 1, + "address": "0x25f8087ead173b73d6e8b84329989a8eea16cf73", + "name": "Yield Guild Games", + "symbol": "YGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17358/thumb/le1nzlO6_400x400.jpg?1632465691" + }, + { + "chainId": 1, + "address": "0xba3e5f8b4200a5eb856ff2c3e001ab29444491aa", + "name": "Minebase", + "symbol": "MBASE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27313/thumb/mbase.png?1663312352" + }, + { + "chainId": 1, + "address": "0x94d863173ee77439e4292284ff13fad54b3ba182", + "name": "Delphi", + "symbol": "ADEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12300/thumb/adel_on_white_10x.png?1598967061" + }, + { + "chainId": 1, + "address": "0x3b58c52c03ca5eb619eba171091c86c34d603e5f", + "name": "Cyclub", + "symbol": "CYCLUB", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/12524/thumb/mcicoin-logo.png?1600471686" + }, + { + "chainId": 1, + "address": "0xfdc4a3fc36df16a78edcaf1b837d3acaaedb2cb4", + "name": "SCIFI Index", + "symbol": "SCIFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13868/thumb/yaxtD4c.png?1624955109" + }, + { + "chainId": 1, + "address": "0x1be56412c9606e7285280f76a105eba56996e491", + "name": "Zinja", + "symbol": "Z", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24513/thumb/DPaP9wkr_400x400.jpg?1647950008" + }, + { + "chainId": 1, + "address": "0x73ee6d7e6b203125add89320e9f343d65ec7c39a", + "name": "Axioms", + "symbol": "AXI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12562/thumb/axioms_logo.png?1600772415" + }, + { + "chainId": 1, + "address": "0xc3eb2622190c57429aac3901808994443b64b466", + "name": "ORO", + "symbol": "ORO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13114/thumb/oro_logo.png?1605338447" + }, + { + "chainId": 1, + "address": "0x1370e3b7aa261dcbe19ee24c456e56ff186aec85", + "name": "Max Bidding", + "symbol": "MAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26936/thumb/BPIJ7HUN_400x400.jpg?1660901132" + }, + { + "chainId": 1, + "address": "0x04a6b6de116fb8bf57e5ee8b05e0293ea3639fe8", + "name": "Proof Of Memes Ethereum", + "symbol": "ETH20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27305/thumb/Screenshot_2022-09-22_173342-removebg-preview.png?1664112523" + }, + { + "chainId": 1, + "address": "0xa4cb0dce4849bdcad2d553e9e68644cf40e26cce", + "name": "Baked", + "symbol": "BAKED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19178/thumb/rebaked-logo-full.png?1634613132" + }, + { + "chainId": 1, + "address": "0x217bed0d3a967d063eb287445a1eccac5c2e09bc", + "name": "PowerFan", + "symbol": "PFAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25899/thumb/white_logo.png?1654500723" + }, + { + "chainId": 1, + "address": "0x429881672b9ae42b8eba0e26cd9c73711b891ca5", + "name": "Pickle Finance", + "symbol": "PICKLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12435/thumb/0M4W6Yr6_400x400.jpg?1643006080" + }, + { + "chainId": 1, + "address": "0x9c78ee466d6cb57a4d01fd887d2b5dfb2d46288f", + "name": "Must", + "symbol": "MUST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13688/thumb/must_logo.png?1610949645" + }, + { + "chainId": 1, + "address": "0xe1bad922f84b198a08292fb600319300ae32471b", + "name": "Firmachain", + "symbol": "FCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9892/thumb/6mHcLurm_400x400.jpg?1573160342" + }, + { + "chainId": 1, + "address": "0xe66b3aa360bb78468c00bebe163630269db3324f", + "name": "Merchant", + "symbol": "MTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17157/thumb/mto.PNG?1626672046" + }, + { + "chainId": 1, + "address": "0xcaabcaa4ca42e1d86de1a201c818639def0ba7a7", + "name": "Talken", + "symbol": "TALK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18146/thumb/4NNLx3BF_400x400.jpg?1630675291" + }, + { + "chainId": 1, + "address": "0xdef1da03061ddd2a5ef6c59220c135dec623116d", + "name": "Lepricon", + "symbol": "L3P", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14436/thumb/l3p.png?1636116065" + }, + { + "chainId": 1, + "address": "0x741b0428efdf4372a8df6fb54b018db5e5ab7710", + "name": "ARTX", + "symbol": "ARTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14652/thumb/logo_black_cmc.png?1617556500" + }, + { + "chainId": 1, + "address": "0xcf0c122c6b73ff809c693db761e7baebe62b6a2e", + "name": "FLOKI", + "symbol": "FLOKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16746/thumb/PNG_image.png?1643184642" + }, + { + "chainId": 1, + "address": "0x4674672bcddda2ea5300f5207e1158185c944bc0", + "name": "Gem Exchange and Trading", + "symbol": "GXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12226/thumb/a.png?1653378779" + }, + { + "chainId": 1, + "address": "0x87cdc02f0812f08cd50f946793706fad9c265e2d", + "name": "Storage Area Network Anywhere", + "symbol": "SANA", + "decimals": 16, + "logoURI": "https://assets.coingecko.com/coins/images/17666/thumb/20210811154811.png?1628815808" + }, + { + "chainId": 1, + "address": "0x36e43065e977bc72cb86dbd8405fae7057cdc7fd", + "name": "ArchAngel", + "symbol": "ARCHA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18814/thumb/ARCHA200x200.png?1633714225" + }, + { + "chainId": 1, + "address": "0x6e10aacb89a28d6fa0fe68790777fec7e7f01890", + "name": "SAV3", + "symbol": "SAV3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13132/thumb/sav3_logo.png?1605536471" + }, + { + "chainId": 1, + "address": "0x3a8d5bc8a8948b68dfc0ce9c14ac4150e083518c", + "name": "Paralink Network", + "symbol": "PARA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15789/thumb/para.PNG?1621893038" + }, + { + "chainId": 1, + "address": "0x473037de59cf9484632f4a27b509cfe8d4a31404", + "name": "STEPN Green Satoshi Token on ETH", + "symbol": "GST-ETH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26528/thumb/gst_eth.png?1658487279" + }, + { + "chainId": 1, + "address": "0xc86817249634ac209bc73fca1712bbd75e37407d", + "name": "1 UP", + "symbol": "1-UP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17376/thumb/1up.png?1636535847" + }, + { + "chainId": 1, + "address": "0x428dc22668e6f3468273634067e5545ed5417a3e", + "name": "MiraQle", + "symbol": "MQL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12278/thumb/2VTVSgXn_400x400.jpg?1598738364" + }, + { + "chainId": 1, + "address": "0x6524b87960c2d573ae514fd4181777e7842435d4", + "name": "Benzene", + "symbol": "BZN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17368/thumb/bzn-logo-200.png?1627437320" + }, + { + "chainId": 1, + "address": "0x2610f0bfc21ef389fe4d03cfb7de9ac1e6c99d6e", + "name": "Skyrim Finance", + "symbol": "SKYRIM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18003/thumb/Xo3oCb53_400x400.png?1630096304" + }, + { + "chainId": 1, + "address": "0xe75097d3ec88701361e670e065b8d5bc4dafbc9d", + "name": "Vanspor Token", + "symbol": "VAN", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/24814/thumb/E0t1GdwXMAcMoGD.png?1649028292" + }, + { + "chainId": 1, + "address": "0x75387e1287dd85482ab66102da9f6577e027f609", + "name": "Mindsync", + "symbol": "MAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7581/thumb/mindsync-logo.jpg?1548636745" + }, + { + "chainId": 1, + "address": "0xc5bbae50781be1669306b9e001eff57a2957b09d", + "name": "Gifto", + "symbol": "GTO", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/1359/thumb/gifto.png?1547742697" + }, + { + "chainId": 1, + "address": "0x466912baa9430a4a460b141ee8c580d817441449", + "name": "BLOCKMAX", + "symbol": "OCB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12315/thumb/200x200-01.png?1599086761" + }, + { + "chainId": 1, + "address": "0x8e964e35a76103af4c7d7318e1b1a82c682ae296", + "name": "Fellaz", + "symbol": "FLZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26169/thumb/NUERy1Wy_400x400.png?1656336115" + }, + { + "chainId": 1, + "address": "0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca", + "name": "LUSD3CRV f", + "symbol": "LUSD3CRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28321/thumb/curve-dao-token-crv-logo.png?1669372858" + }, + { + "chainId": 1, + "address": "0xf53c24f7729c88c110265929c7124e6259efccab", + "name": "Bobo Cash", + "symbol": "BOBO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17620/thumb/bobo_coingecko.png?1628667747" + }, + { + "chainId": 1, + "address": "0xcbccbb06f572df174a7da47684cdc28121fec421", + "name": "The Tale of Osaku", + "symbol": "OSAKU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26953/thumb/photo_2022-08-12_05-35-57.jpg?1660988433" + }, + { + "chainId": 1, + "address": "0xef53462838000184f35f7d991452e5f25110b207", + "name": "Knit Finance", + "symbol": "KFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15632/thumb/knit.jpg?1621396114" + }, + { + "chainId": 1, + "address": "0x469084939d1c20fae3c73704fe963941c51be863", + "name": "Envision", + "symbol": "VIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23907/thumb/J3JCKVq2.png?1645681725" + }, + { + "chainId": 1, + "address": "0xd0a2e008eb1f160fa6055a28d5224034d8f527f7", + "name": "Marosca Inu", + "symbol": "MAROSCA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27881/thumb/Cr3sFSxf_400x400.jpg?1666233042" + }, + { + "chainId": 1, + "address": "0x52a047ee205701895ee06a375492490ec9c597ce", + "name": "PulseMarkets", + "symbol": "PULSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19011/thumb/photo_2021-11-11_06-24-09.jpg?1636616734" + }, + { + "chainId": 1, + "address": "0x88800092ff476844f74dc2fc427974bbee2794ae", + "name": "Ambire Wallet", + "symbol": "WALLET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23154/thumb/wallet.PNG?1643352408" + }, + { + "chainId": 1, + "address": "0xd4342a57ecf2fe7ffa37c33cb8f63b1500e575e6", + "name": "Apron", + "symbol": "APN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14916/thumb/1_GOjoDhGzzpqnMPGpHGeWhg.png?1618998577" + }, + { + "chainId": 1, + "address": "0x805c2077f3ab224d889f9c3992b41b2f4722c787", + "name": "art Q NFT Investment Fund", + "symbol": "ARTEQ", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/23407/thumb/arteq.png?1644146442" + }, + { + "chainId": 1, + "address": "0x5273063725a43a323300c502478c22fbb4e92c2d", + "name": "My Identity Coin", + "symbol": "MYID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15063/thumb/MYID-LOGO.png?1619594142" + }, + { + "chainId": 1, + "address": "0xcda4e840411c00a614ad9205caec807c7458a0e3", + "name": "PureFi", + "symbol": "UFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17341/thumb/purefi.PNG?1627362147" + }, + { + "chainId": 1, + "address": "0xd049206fb408a611e543791f2d8f102a8bc253dc", + "name": "NFTDAO", + "symbol": "NAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22576/thumb/NAO.png?1642083280" + }, + { + "chainId": 1, + "address": "0x2b67d1a87a8d8b280a23e97bc55095215ee0ec53", + "name": "Crypto Price Index", + "symbol": "CPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12178/thumb/Z7x7eUa.png?1597886884" + }, + { + "chainId": 1, + "address": "0x383518188c0c6d7730d91b2c03a03c837814a899", + "name": "Olympus v1", + "symbol": "OHM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21496/thumb/OHM.jpg?1639620224" + }, + { + "chainId": 1, + "address": "0x147ab744f058a52e828bee84a9c58660f2ff5ff9", + "name": "n00dle", + "symbol": "N00D", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27850/thumb/%E8%9E%A2%E5%B9%95%E6%88%AA%E5%9C%96_2022-10-17_%E4%B8%8B%E5%8D%888.36.07.png?1666092864" + }, + { + "chainId": 1, + "address": "0xaa2ded323944b25c0b6f1f891bc96f010b65622c", + "name": "Radioreum", + "symbol": "THERADIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28485/thumb/Safeimagekit-resized-imgpng.png?1671077173" + }, + { + "chainId": 1, + "address": "0xa291b47efe802de81ac425c67d2b8d2925fa31a4", + "name": "MoveRich", + "symbol": "MVRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28176/thumb/MoveRich_logo%28200x200%29.png?1668247458" + }, + { + "chainId": 1, + "address": "0x9b4e2b4b13d125238aa0480dd42b4f6fc71b37cc", + "name": "MyToken", + "symbol": "MT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4109/thumb/2712.png?1547039296" + }, + { + "chainId": 1, + "address": "0x397deb686c72384fad502a81f4d7fdb89e1f1280", + "name": "XELS", + "symbol": "XELS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14729/thumb/Xels_logo_square_%281%29.png?1617957186" + }, + { + "chainId": 1, + "address": "0xabe580e7ee158da464b51ee1a83ac0289622e6be", + "name": "Offshift", + "symbol": "XFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11977/thumb/CsBrPiA.png?1614570441" + }, + { + "chainId": 1, + "address": "0x6c972b70c533e2e045f333ee28b9ffb8d717be69", + "name": "FoundryDAO Logistics", + "symbol": "FRY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12348/thumb/fry-icon.png?1614064283" + }, + { + "chainId": 1, + "address": "0x4161725d019690a3e0de50f6be67b07a86a9fae1", + "name": "TokenPocket Token", + "symbol": "TPT", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/7603/thumb/pocket.jpg?1658907018" + }, + { + "chainId": 1, + "address": "0xeb50455805ebf8396d9177bbc4a371a376d00ecc", + "name": "Bali Social Integrated", + "symbol": "BSI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19589/thumb/bsi.PNG?1635473270" + }, + { + "chainId": 1, + "address": "0xb2279b6769cfba691416f00609b16244c0cf4b20", + "name": "Waifu Genesis Card Collection", + "symbol": "WAIF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12100/thumb/Small-Waifu_token.png?1597120029" + }, + { + "chainId": 1, + "address": "0x866f8a50a64e68ca66e97e032c5da99538b3f942", + "name": "eBlockStock", + "symbol": "EBSO", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/18636/thumb/eBSO_logo_szines.png?1632730502" + }, + { + "chainId": 1, + "address": "0x0fe20e0fa9c78278702b05c333cc000034bb69e2", + "name": "ETH Max Yield Index", + "symbol": "ETHMAXY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24047/thumb/ethmaxy.png?1646194193" + }, + { + "chainId": 1, + "address": "0xaf5191b0de278c7286d6c7cc6ab6bb8a73ba2cd6", + "name": "Stargate Finance", + "symbol": "STG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24413/thumb/STG_LOGO.png?1647654518" + }, + { + "chainId": 1, + "address": "0x701c244b988a513c945973defa05de933b23fe1d", + "name": "OAX", + "symbol": "OAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/853/thumb/OAXlogo.png?1598686792" + }, + { + "chainId": 1, + "address": "0xe25b0bba01dc5630312b6a21927e578061a13f55", + "name": "ShipChain", + "symbol": "SHIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3997/thumb/shipchain.png?1548609236" + }, + { + "chainId": 1, + "address": "0x89303500a7abfb178b274fd89f2469c264951e1f", + "name": "Ref", + "symbol": "REF", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2575/thumb/reftoken.png?1548608011" + }, + { + "chainId": 1, + "address": "0xc382e04099a435439725bb40647e2b32dc136806", + "name": "Cogecoin", + "symbol": "COGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16791/thumb/Dog-Logo_1x.png?1625033809" + }, + { + "chainId": 1, + "address": "0x674c6ad92fd080e4004b2312b45f796a192d27a0", + "name": "Neutrino USD", + "symbol": "USDN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10117/thumb/78GWcZu.png?1600845716" + }, + { + "chainId": 1, + "address": "0x3540abe4f288b280a0740ad5121aec337c404d15", + "name": "TPRO", + "symbol": "TPRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26694/thumb/tpro-logo-200x200.png?1659607453" + }, + { + "chainId": 1, + "address": "0x1f3f677ecc58f6a1f9e2cf410df4776a8546b5de", + "name": "VNDC", + "symbol": "VNDC", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/9670/thumb/vndc-gold-coin.png?1571032826" + }, + { + "chainId": 1, + "address": "0x3d60f2bde6762ce9ce45945d05bc6846d12a140e", + "name": "Honey Badger", + "symbol": "HONEYBADGER", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21497/thumb/w9AapCgG_400x400.jpg?1639368909" + }, + { + "chainId": 1, + "address": "0x52a8845df664d76c69d2eea607cd793565af42b8", + "name": "ApeX", + "symbol": "APEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25266/thumb/CxpMECpk_400x400_%281%29.png?1651067984" + }, + { + "chainId": 1, + "address": "0x20c36f062a31865bed8a5b1e512d9a1a20aa333a", + "name": "DefiDollar DAO", + "symbol": "DFD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12959/thumb/DFD.jpg?1604415975" + }, + { + "chainId": 1, + "address": "0x56d811088235f11c8920698a204a5010a788f4b3", + "name": "bZx Protocol", + "symbol": "BZRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11811/thumb/bzrx.png?1594563172" + }, + { + "chainId": 1, + "address": "0xb6eda82597808c96969c21a88bf6c749b441c44a", + "name": "Smart Medical Coin", + "symbol": "SMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17327/thumb/smc.png?1627313618" + }, + { + "chainId": 1, + "address": "0x7fbec0bb6a7152e77c30d005b5d49cbc08a602c3", + "name": "disBalancer", + "symbol": "DDOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14791/thumb/communityIcon_o2yriheuszk61.png?1618463138" + }, + { + "chainId": 1, + "address": "0xc3dca8f61b275d1e88f3ea31b3e311c49f56b24b", + "name": "NPick Block", + "symbol": "NPICK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25151/thumb/Logo200_%281%29.png?1650459923" + }, + { + "chainId": 1, + "address": "0x6944d3e38973c4831da24e954fbd790c7e688bdd", + "name": "IZE", + "symbol": "IZE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11031/thumb/logo.png?1587294254" + }, + { + "chainId": 1, + "address": "0x5891599664ed15c6e88041b4f5bc08594f026f0e", + "name": "JPGoldCoin", + "symbol": "JPGC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27321/thumb/JPGC_LOGO-_Coingecko.png?1663319056" + }, + { + "chainId": 1, + "address": "0x1410434b0346f5be678d0fb554e5c7ab620f8f4a", + "name": "BitKan", + "symbol": "KAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4651/thumb/kan-token.png?1547039917" + }, + { + "chainId": 1, + "address": "0x7c5a0ce9267ed19b22f8cae653f198e3e8daf098", + "name": "Santiment Network", + "symbol": "SAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/797/thumb/santiment-network-token.png?1547034571" + }, + { + "chainId": 1, + "address": "0x01ff50f8b7f74e4f00580d9596cd3d0d6d6e326f", + "name": "BnkToTheFuture", + "symbol": "BFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3468/thumb/bnktothefuture.png?1547351865" + }, + { + "chainId": 1, + "address": "0x83869de76b9ad8125e22b857f519f001588c0f62", + "name": "EXMO Coin", + "symbol": "EXM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9154/thumb/200x200.png?1668998803" + }, + { + "chainId": 1, + "address": "0xac0104cca91d167873b8601d2e71eb3d4d8c33e0", + "name": "Seascape Crowns", + "symbol": "CWS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13835/thumb/crowns_logo.png?1612176905" + }, + { + "chainId": 1, + "address": "0x9d9e399e5385e2b9a58d4f775a1e16441b571afb", + "name": "Metano", + "symbol": "METANO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28183/thumb/logo200x.jpeg?1668256131" + }, + { + "chainId": 1, + "address": "0xac3e018457b222d93114458476f3e3416abbe38f", + "name": "Staked Frax Ether", + "symbol": "SFRXETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28285/thumb/JjqQ9ROz_400x400.jpeg?1669170466" + }, + { + "chainId": 1, + "address": "0xd3e4ba569045546d09cf021ecc5dfe42b1d7f6e4", + "name": "Morpheus Network", + "symbol": "MNW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2379/thumb/MRPH_CoinGecko.png?1635847791" + }, + { + "chainId": 1, + "address": "0x4a615bb7166210cce20e6642a6f8fb5d4d044496", + "name": "NAOS Finance", + "symbol": "NAOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15144/thumb/bafybeibkztkshitabrf7yqqkqtbjqestjknpgv7lsjfzdsa3ufspagqs2e.ipfs.infura-ipfs.io.png?1622176770" + }, + { + "chainId": 1, + "address": "0x4f9254c83eb525f9fcf346490bbb3ed28a81c667", + "name": "Celer Network", + "symbol": "CELR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4379/thumb/Celr.png?1554705437" + }, + { + "chainId": 1, + "address": "0xa41f142b6eb2b164f8164cae0716892ce02f311f", + "name": "Avocado DAO", + "symbol": "AVG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21102/thumb/logo192_%281%29.png?1640567889" + }, + { + "chainId": 1, + "address": "0xa6d5c720a9af5a405dfb6b9f44fc44fab5d4a58d", + "name": "Ezystayz", + "symbol": "EZY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9062/thumb/5521.png?1603333090" + }, + { + "chainId": 1, + "address": "0x91f529e972d6cf43d36abfa91c1118122ff7f16c", + "name": "Sapchain", + "symbol": "SAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9109/thumb/sap.PNG?1564433894" + }, + { + "chainId": 1, + "address": "0x544c42fbb96b39b21df61cf322b5edc285ee7429", + "name": "InsurAce", + "symbol": "INSUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14226/thumb/insur.png?1615124622" + }, + { + "chainId": 1, + "address": "0x5d60d8d7ef6d37e16ebabc324de3be57f135e0bc", + "name": "MyBit", + "symbol": "MYB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1240/thumb/mybit.png?1547035264" + }, + { + "chainId": 1, + "address": "0x329c6e459ffa7475718838145e5e85802db2a303", + "name": "MaidSafeCoin", + "symbol": "EMAID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/80/thumb/maidsafecoin.png?1547033750" + }, + { + "chainId": 1, + "address": "0x89ab32156e46f46d02ade3fecbe5fc4243b9aaed", + "name": "pNetwork", + "symbol": "PNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11659/thumb/pNetwork.png?1592411134" + }, + { + "chainId": 1, + "address": "0x3845badade8e6dff049820680d1f14bd3903a5d0", + "name": "The Sandbox", + "symbol": "SAND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12129/thumb/sandbox_logo.jpg?1597397942" + }, + { + "chainId": 1, + "address": "0x0f3a02baec9607f2b52b3ab629cbcea2047e1124", + "name": "XPOP", + "symbol": "XPOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26251/thumb/%EC%9E%90%EC%82%B0_1.png?1656936169" + }, + { + "chainId": 1, + "address": "0x670f9d9a26d3d42030794ff035d35a67aa092ead", + "name": "XBullion", + "symbol": "GOLD", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15658/thumb/WhatsApp_Image_2021-05-17_at_2.24.16_PM.jpeg?1621484245" + }, + { + "chainId": 1, + "address": "0x2863916c6ebdbbf0c6f02f87b7eb478509299868", + "name": "SIMBA Storage", + "symbol": "SST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11908/thumb/sst.png?1660381253" + }, + { + "chainId": 1, + "address": "0x139d9397274bb9e2c29a9aa8aa0b5874d30d62e3", + "name": "BoutsPro", + "symbol": "BOUTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4296/thumb/boutspro-ico-logo-300x300.jpg?1527072201" + }, + { + "chainId": 1, + "address": "0x12e951934246186f50146235d541d3bd1d463e4d", + "name": "Crypto International", + "symbol": "CRI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24700/thumb/logo200x200.png?1648641961" + }, + { + "chainId": 1, + "address": "0x6b4689e4514957699edeb2ee91c947f18e439806", + "name": "ZeuxCoin", + "symbol": "ZUC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9034/thumb/HVMZgdBY_400x400.jpg?1563831075" + }, + { + "chainId": 1, + "address": "0x1cbb83ebcd552d5ebf8131ef8c9cd9d9bab342bc", + "name": "Non Fungible Yearn", + "symbol": "NFY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12766/thumb/NFY_logo.png?1602686886" + }, + { + "chainId": 1, + "address": "0xed494c9e2f8e34e53bdd0ea9b4d80305cb15c5c2", + "name": "CryptoWorld VIP", + "symbol": "CWV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6570/thumb/s-ZJaJdw_400x400.jpg?1547042779" + }, + { + "chainId": 1, + "address": "0xaa7a9ca87d3694b5755f213b5d04094b8d0f0a6f", + "name": "OriginTrail", + "symbol": "TRAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1877/thumb/TRAC.jpg?1635134367" + }, + { + "chainId": 1, + "address": "0xc795fba221f7920f1c6ac0f1598886742d8ea661", + "name": "SaitamaX", + "symbol": "SAITAX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19419/thumb/6mrg5N1.png?1635213446" + }, + { + "chainId": 1, + "address": "0x73f2651ea38d48b3b808ffddbd398fd600ab5ba7", + "name": "Dukascoin", + "symbol": "DUK+", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/14374/thumb/dukascoin_200x200_silver.png?1615774652" + }, + { + "chainId": 1, + "address": "0xe28b3b32b6c345a34ff64674606124dd5aceca30", + "name": "Injective", + "symbol": "INJ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12882/thumb/Secondary_Symbol.png?1628233237" + }, + { + "chainId": 1, + "address": "0x9daef41e08bc88183572b03796c96a7ace1ec9d4", + "name": "Yofune Nushi", + "symbol": "KOYO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27697/thumb/Capture-removebg-preview_%283%29.png?1665303166" + }, + { + "chainId": 1, + "address": "0x5b71bee9d961b1b848f8485eec8d8787f80217f5", + "name": "Bitforex", + "symbol": "BF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5330/thumb/BitForex-Logo.png?1573808168" + }, + { + "chainId": 1, + "address": "0x84679bc467dc6c2c40ab04538813aff3796351f1", + "name": "Chonk", + "symbol": "CHONK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12899/thumb/a2LHjXZ.jpeg?1603418225" + }, + { + "chainId": 1, + "address": "0xab456bdb0a373bbac6c4a76176e9f159cacd5752", + "name": "Society of Galactic Exploration", + "symbol": "SGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15819/thumb/sge.png?1636253933" + }, + { + "chainId": 1, + "address": "0xe9f84de264e91529af07fa2c746e934397810334", + "name": "SAKE", + "symbol": "SAK3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15890/thumb/Sak3.jpg?1622219322" + }, + { + "chainId": 1, + "address": "0x84ba4aecfde39d69686a841bab434c32d179a169", + "name": "Method Finance", + "symbol": "MTHD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14619/thumb/mthd.PNG?1617262620" + }, + { + "chainId": 1, + "address": "0x87de305311d5788e8da38d19bb427645b09cb4e5", + "name": "Verox", + "symbol": "VRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13669/thumb/IMG-20210115-000024.png?1610675319" + }, + { + "chainId": 1, + "address": "0x33cf519030235f75a13f29afcff5d6ff4fd10350", + "name": "PEPE bet", + "symbol": "PEPEBET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27970/thumb/IMG_20221025_143614_101.jpg?1666771114" + }, + { + "chainId": 1, + "address": "0x65ad6a2288b2dd23e466226397c8f5d1794e58fc", + "name": "GamyFi", + "symbol": "GFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14559/thumb/circle-cropped_%281%29.png?1617008124" + }, + { + "chainId": 1, + "address": "0xf6ea0e60cee427b90aa36f327ee61d1d4cabc49f", + "name": "UniqueOne Photo", + "symbol": "FOTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14274/thumb/Symbol_Master-01_200x200_%281%29.png?1626868667" + }, + { + "chainId": 1, + "address": "0x69681f8fde45345c3870bcd5eaf4a05a60e7d227", + "name": "Iron Bank GBP", + "symbol": "IBGBP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18576/thumb/logo-128_%283%29.png?1632470148" + }, + { + "chainId": 1, + "address": "0xf6158bdfe9e013673269b4d1ca468e8efd77ca3f", + "name": "Teleport", + "symbol": "PORT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27342/thumb/logo.png?1663552195" + }, + { + "chainId": 1, + "address": "0x4fabb145d64652a948d72533023f6e7a623c7c53", + "name": "Binance USD", + "symbol": "BUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9576/thumb/BUSD.png?1568947766" + }, + { + "chainId": 1, + "address": "0x755be920943ea95e39ee2dc437b268917b580d6e", + "name": "VersoView", + "symbol": "VVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13380/thumb/HkfxEtWh_400x400.jpg?1608031723" + }, + { + "chainId": 1, + "address": "0x635f15eb7aa2e62d122f6b1f9f519fdccf4abdda", + "name": "hiMAYC", + "symbol": "HIMAYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27602/thumb/himayc.png?1664716538" + }, + { + "chainId": 1, + "address": "0xd4ca5c2aff1eefb0bea9e9eab16f88db2990c183", + "name": "XRP Classic", + "symbol": "XRPC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7259/thumb/xrpc.png?1572011410" + }, + { + "chainId": 1, + "address": "0x33bd66c334274989b673a8e8c8d1a3f1b8de5889", + "name": "hiODBS", + "symbol": "HIODBS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27296/thumb/hiodbs.png?1668579342" + }, + { + "chainId": 1, + "address": "0x63f584fa56e60e4d0fe8802b27c7e6e3b33e007f", + "name": "ContentBox", + "symbol": "BOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4929/thumb/contentbox.png?1547740046" + }, + { + "chainId": 1, + "address": "0xf66cd2f8755a21d3c8683a10269f795c0532dd58", + "name": "coreDAO", + "symbol": "COREDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23745/thumb/coredao.png?1645273627" + }, + { + "chainId": 1, + "address": "0x668f7dfb8c8d716839fa5dbea317d8723ebe6110", + "name": "SMSCodes", + "symbol": "SMSCT", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/16014/thumb/logo200_%2813%29.png?1622609030" + }, + { + "chainId": 1, + "address": "0xae86f48c0b00f2a3eaef4ba4c23d17368f0f63f4", + "name": "Amatsu Mikaboshi", + "symbol": "MIKABOSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27048/thumb/photo_2022-08-25_23-44-10.jpg?1661504716" + }, + { + "chainId": 1, + "address": "0x72630b1e3b42874bf335020ba0249e3e9e47bafc", + "name": "Paypolitan", + "symbol": "EPAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13192/thumb/ava3.png?1606102032" + }, + { + "chainId": 1, + "address": "0x7995ab36bb307afa6a683c24a25d90dc1ea83566", + "name": "HitChain", + "symbol": "HIT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/5555/thumb/hitchain.png?1547041361" + }, + { + "chainId": 1, + "address": "0x2a2550e0a75acec6d811ae3930732f7f3ad67588", + "name": "PathDAO", + "symbol": "PATH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21146/thumb/thumbnail.png?1655283979" + }, + { + "chainId": 1, + "address": "0x93cfe232311f49b53d4285cd54d31261980496ba", + "name": "Diyarbekirspor", + "symbol": "DIYAR", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/22466/thumb/NHeXj778_400x400.jpg?1641883928" + }, + { + "chainId": 1, + "address": "0x38ec27c6f05a169e7ed03132bca7d0cfee93c2c5", + "name": "Wizards And Dragons", + "symbol": "GP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21162/thumb/GPGP.jpg?1638427072" + }, + { + "chainId": 1, + "address": "0xf42965f82f9e3171d1205c5e3058caf324a09432", + "name": "Alien Inu", + "symbol": "ALIEN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20719/thumb/alien_logo.png?1642675038" + }, + { + "chainId": 1, + "address": "0x35bd01fc9d6d5d81ca9e055db88dc49aa2c699a8", + "name": "Friends With Benefits Pro", + "symbol": "FWB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14391/thumb/xRGEXmQN_400x400.png?1615868085" + }, + { + "chainId": 1, + "address": "0x2d5c73f3597b07f23c2bb3f2422932e67eca4543", + "name": "Imperial Obelisk", + "symbol": "IMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27625/thumb/dxanVPfL_400x400.jpeg?1664935231" + }, + { + "chainId": 1, + "address": "0xe3fedaecd47aa8eab6b23227b0ee56f092c967a9", + "name": "Primas", + "symbol": "PST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/917/thumb/primas.png?1548331951" + }, + { + "chainId": 1, + "address": "0xedeec5691f23e4914cf0183a4196bbeb30d027a0", + "name": "Wrapped Statera", + "symbol": "WSTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13599/thumb/wsta_logo.png?1610011862" + }, + { + "chainId": 1, + "address": "0x116c4b65e14449947bc6fa1bbe844cb16a162d53", + "name": "BMAX", + "symbol": "BMAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26427/thumb/BMAX_logo.png?1657929623" + }, + { + "chainId": 1, + "address": "0x765f0c16d1ddc279295c1a7c24b0883f62d33f75", + "name": "DaTa eXchange DTX", + "symbol": "DTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2920/thumb/dtx.png?1578973961" + }, + { + "chainId": 1, + "address": "0x94d916873b22c9c1b53695f1c002f78537b9b3b2", + "name": "AlgoVest", + "symbol": "AVS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13874/thumb/icon-200.png?1626094416" + }, + { + "chainId": 1, + "address": "0x8ab893e33b2cfff425ff9c67b958036c938a2649", + "name": "Lilith Swap", + "symbol": "LLTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23499/thumb/-c-tn85C_400x400.jpeg?1644293485" + }, + { + "chainId": 1, + "address": "0x37c4822dfcea7211d1d9876dabd48c62d46dbaab", + "name": "MetaBET", + "symbol": "MBET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22778/thumb/y5TphxL.jpeg?1642577860" + }, + { + "chainId": 1, + "address": "0xaea46a60368a7bd060eec7df8cba43b7ef41ad85", + "name": "Fetch ai", + "symbol": "FET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5681/thumb/Fetch.jpg?1572098136" + }, + { + "chainId": 1, + "address": "0x6beb418fc6e1958204ac8baddcf109b8e9694966", + "name": "Linker Coin", + "symbol": "LNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3885/thumb/linker-coin.png?1547975979" + }, + { + "chainId": 1, + "address": "0xadf8b8050639b6236915f7516d69de714672f0bf", + "name": "Scanetchain", + "symbol": "SWC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6876/thumb/scanetchain.jpg?1547043219" + }, + { + "chainId": 1, + "address": "0x48592de8cded16f6bb56c896fe1affc37630889c", + "name": "PolkaParty", + "symbol": "POLP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17867/thumb/polp_logo.jpg?1641355239" + }, + { + "chainId": 1, + "address": "0x5de7cc4bcbca31c473f6d2f27825cfb09cc0bb16", + "name": "XBE", + "symbol": "XBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14480/thumb/xbe.png?1616462685" + }, + { + "chainId": 1, + "address": "0x0b5ecbb411d8fe829e5eac253ee1f2dc05d8d1ae", + "name": "KunoichiX", + "symbol": "KUNO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21847/thumb/94E3B862-B2ED-4D30-A1E4-1AFB560835F5.png?1640131932" + }, + { + "chainId": 1, + "address": "0x82ca5fcd9ef2d6ceeb49a057bb11c3e091560979", + "name": "Kiki Finance", + "symbol": "KIKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23151/thumb/DLq9z6qp_400x400.jpg?1643351049" + }, + { + "chainId": 1, + "address": "0x601938988f0fdd937373ea185c33751462b1d194", + "name": "Etherpay", + "symbol": "ETHPY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12417/thumb/Captura-de-Tela-2020-09-09-a-s-13-54-20.png?1599692074" + }, + { + "chainId": 1, + "address": "0x5380442d3c4ec4f5777f551f5edd2fa0f691a27c", + "name": "UkraineDAO Flag NFT", + "symbol": "LOVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24092/thumb/download_%282%29.png?1646344453" + }, + { + "chainId": 1, + "address": "0x33e18a092a93ff21ad04746c7da12e35d34dc7c4", + "name": "Metaverse NFT Index", + "symbol": "PLAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14590/thumb/PLAY.png?1618308275" + }, + { + "chainId": 1, + "address": "0x4b5f49487ea7b3609b1ad05459be420548789f1f", + "name": "LeverFi", + "symbol": "LEVER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26205/thumb/WI72SpBl_400x400.jpeg?1656494480" + }, + { + "chainId": 1, + "address": "0xbdab72602e9ad40fc6a6852caf43258113b8f7a5", + "name": "Sovryn", + "symbol": "SOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16248/thumb/sov.PNG?1623380748" + }, + { + "chainId": 1, + "address": "0xf8e386eda857484f5a12e4b5daa9984e06e73705", + "name": "Indorse", + "symbol": "IND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/848/thumb/indorse_token.png?1547034644" + }, + { + "chainId": 1, + "address": "0xff7e285b87e7f9247f0953cf8cf5cb24eede4b9c", + "name": " STIMMY", + "symbol": "STIMMY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20796/thumb/logo.gif?1637677225" + }, + { + "chainId": 1, + "address": "0xbba39fd2935d5769116ce38d46a71bde9cf03099", + "name": "Choise com", + "symbol": "CHO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25935/thumb/cho_%282%29.png?1663309407" + }, + { + "chainId": 1, + "address": "0x4a27e9aab8f8ba9de06766c8476ed1d16494e35f", + "name": "PEPEGOLD", + "symbol": "PEPE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26864/thumb/logo-200x200.png?1660533136" + }, + { + "chainId": 1, + "address": "0x628ab8b061fea2af1239b68efa5e46135d186666", + "name": "XBullion Silver", + "symbol": "SILV", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/24171/thumb/SILV_Logo_%28transparent_circle%29.png?1646816506" + }, + { + "chainId": 1, + "address": "0xd779eea9936b4e323cddff2529eb6f13d0a4d66e", + "name": "EnterDAO", + "symbol": "ENTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18684/thumb/entr.png?1635826690" + }, + { + "chainId": 1, + "address": "0x5cc56c266143f29a5054b9ae07f3ac3513a7965e", + "name": "ANKR Reward Earning DOT", + "symbol": "ADOTB", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/26029/thumb/a-dot-b-d58ca40f7b15ef03310fa1faa974a3b0.png?1655349902" + }, + { + "chainId": 1, + "address": "0xf9c53268e9de692ae1b2ea5216e24e1c3ad7cb1e", + "name": "Idexo", + "symbol": "IDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18523/thumb/qOiqm7T8_400x400.jpg?1632275628" + }, + { + "chainId": 1, + "address": "0xb6c3dc857845a713d3531cea5ac546f6767992f4", + "name": "Advertise Coin", + "symbol": "ADCO", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14344/thumb/advertisecoin200x200.png?1615503478" + }, + { + "chainId": 1, + "address": "0x558c7ebb10514a6786d83a26c322d0b53e39d603", + "name": "VIIIDA Gold", + "symbol": "AUV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25191/thumb/VG_-_LOGO_AUV.png?1650605583" + }, + { + "chainId": 1, + "address": "0xfa57f00d948bb6a28072f5416fcbf7836c3d62dd", + "name": "friesDAO", + "symbol": "FRIES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23951/thumb/friespng.png?1645772414" + }, + { + "chainId": 1, + "address": "0x9b5161a41b58498eb9c5febf89d60714089d2253", + "name": "Meta Finance", + "symbol": "MF1", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21954/thumb/eC1-dKKt_400x400.jpg?1640326512" + }, + { + "chainId": 1, + "address": "0x801de502c493aa9d3f9f79a0348fbc00521b3001", + "name": "Relaxable", + "symbol": "RELAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28129/thumb/6B1F96A9-E306-4328-862A-FBE9209D1C0D.jpeg?1667649137" + }, + { + "chainId": 1, + "address": "0x5f4361971667c8198706dec8c59cf7607e405c6e", + "name": "Fileshare Platform", + "symbol": "FSC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/28190/thumb/fsc.png?1668325601" + }, + { + "chainId": 1, + "address": "0x641927e970222b10b2e8cdbc96b1b4f427316f16", + "name": "MEEB Vault NFTX ", + "symbol": "MEEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17044/thumb/Meebs.png?1626147616" + }, + { + "chainId": 1, + "address": "0x70e36f6bf80a52b3b46b3af8e106cc0ed743e8e4", + "name": "cCOMP", + "symbol": "CCOMP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12840/thumb/1_z8UrVtod3bme4-J_pXAQQA_2x.png?1602936322" + }, + { + "chainId": 1, + "address": "0x03066da434e5264ef0b32f787923f974a5726fdc", + "name": "Basis Coin Share", + "symbol": "BCS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13530/thumb/Basiscoin_Share.png?1609406623" + }, + { + "chainId": 1, + "address": "0x6025f65f6b2f93d8ed1efedc752acfd4bdbcec3e", + "name": "eGold", + "symbol": "EGOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1105/thumb/egold.png?1547035084" + }, + { + "chainId": 1, + "address": "0xb8e2e2101ed11e9138803cd3e06e16dd19910647", + "name": "ArdCoin", + "symbol": "ARDX", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/9432/thumb/ARDC.png?1627466542" + }, + { + "chainId": 1, + "address": "0x639ae8f3eed18690bf451229d14953a5a5627b72", + "name": "Nimbus Governance", + "symbol": "GNBU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16391/thumb/gnbu.PNG?1623898676" + }, + { + "chainId": 1, + "address": "0xfb5453340c03db5ade474b27e68b6a9c6b2823eb", + "name": "Robot", + "symbol": "ROBOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13517/thumb/MF_Robot_200px.png?1609312481" + }, + { + "chainId": 1, + "address": "0x15ee120fd69bec86c1d38502299af7366a41d1a6", + "name": "BitANT", + "symbol": "BITANT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19055/thumb/BitANT.png?1634264861" + }, + { + "chainId": 1, + "address": "0x5ea82c27efc7634f1c5ad20a3561c453433a2f3a", + "name": "BTRIPS", + "symbol": "BTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19273/thumb/btr.png?1638182009" + }, + { + "chainId": 1, + "address": "0x6f8b23296394d20ec048fbdec8ebc0ca90f5c8f1", + "name": "TUF Token", + "symbol": "TUF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28410/thumb/2022-12-06_10.10.16.jpg?1670385344" + }, + { + "chainId": 1, + "address": "0xc0b182b2e06164568a3310ca1086e9bf19209e6c", + "name": "Pumptopia", + "symbol": "PTPA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24262/thumb/pinksale-200x200-1.jpg?1647171185" + }, + { + "chainId": 1, + "address": "0x4da9b813057d04baef4e5800e36083717b4a0341", + "name": "Aave TUSD v1", + "symbol": "ATUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11724/thumb/aTUSD.png?1593082700" + }, + { + "chainId": 1, + "address": "0x405ce8b2eaeea7d4ba5fc160848cb2a6569e03f0", + "name": "Metria Network", + "symbol": "METR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24870/thumb/Metria-logo_1.png?1649213114" + }, + { + "chainId": 1, + "address": "0xc00e94cb662c3520282e6f5717214004a7f26888", + "name": "Compound", + "symbol": "COMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10775/thumb/COMP.png?1592625425" + }, + { + "chainId": 1, + "address": "0xaf80951201a0eff85a0fd3adf4c7043db856d3e6", + "name": "Mobilian Coin", + "symbol": "MBN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12472/thumb/TqhkduvK_400x400.jpg?1600122610" + }, + { + "chainId": 1, + "address": "0x1c95b093d6c236d3ef7c796fe33f9cc6b8606714", + "name": "BOMB", + "symbol": "BOMB", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/7713/thumb/Bomb-token.png?1549944422" + }, + { + "chainId": 1, + "address": "0xbbeca80a4c99c3b1bd3c10e64595d0fc7dc26ee0", + "name": "hiMEEBITS", + "symbol": "HIMEEBITS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28126/thumb/himeebit.png?1667640906" + }, + { + "chainId": 1, + "address": "0x8c1bee08bdcb69e68fd23f1d02495a2d59f2a01a", + "name": "Safuchain", + "symbol": "SAFU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27381/thumb/QmZh4N7mpwJv9wRUffy9P4bc35k4DuzCRkmLD1fSYUKzpA.png?1663743589" + }, + { + "chainId": 1, + "address": "0x1997830b5beb723f5089bb8fc38766d419a0444d", + "name": "Newinu", + "symbol": "NEWINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16192/thumb/Newinu.png?1625583532" + }, + { + "chainId": 1, + "address": "0x69e8b9528cabda89fe846c67675b5d73d463a916", + "name": "OPEN Governance", + "symbol": "OPEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13233/thumb/opendao_logo.png?1606575207" + }, + { + "chainId": 1, + "address": "0x57db3ffca78dbbe0efa0ec745d55f62aa0cbd345", + "name": "Symmetric", + "symbol": "SYMM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18525/thumb/SYMM-Coin-2.png?1632276841" + }, + { + "chainId": 1, + "address": "0x618679df9efcd19694bb1daa8d00718eacfa2883", + "name": "Universe XYZ", + "symbol": "XYZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15809/thumb/universexyz.png?1621950483" + }, + { + "chainId": 1, + "address": "0xa64c3a85ddc4cd351eeb7aecebc6a44a64a76392", + "name": "Rice Wallet", + "symbol": "RICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17204/thumb/RICE-200x200.png?1626847877" + }, + { + "chainId": 1, + "address": "0xc221b7e65ffc80de234bbb6667abdd46593d34f0", + "name": "Wrapped Centrifuge", + "symbol": "WCFG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17106/thumb/WCFG.jpg?1626266462" + }, + { + "chainId": 1, + "address": "0x08711d3b02c8758f2fb3ab4e80228418a7f8e39c", + "name": "Edgeless", + "symbol": "EDG", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/635/thumb/Edgeless-Token.jpg?1631795809" + }, + { + "chainId": 1, + "address": "0xb4371da53140417cbb3362055374b10d97e420bb", + "name": "Carbon Protocol", + "symbol": "SWTH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3645/thumb/SWTH_Symbol_Origin.png?1645000262" + }, + { + "chainId": 1, + "address": "0x6ce21e5f5383c95691d243879a86a6025e0870c0", + "name": "Hintchain", + "symbol": "HINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9329/thumb/JwEnTYRktjoozNKeI6qtQ0CEuiwNhl_vWNoXvob7OO-ZJ7YsXqK6oUmBjdXy0XRTnLcOywgKyWP-3WPcpelcT2ZQyBYoYEGLXA4Q-n6utwbn43oTkW3Ro6Mm93tr9lC1lrb3E4vPTS17TYRvYDP_6c9KLulnS4y_E4FlU9u6Y2FkoYhFdrV9-XF1CPif17GxyVa9vr45xfgGmqmU5.jpg?1566284372" + }, + { + "chainId": 1, + "address": "0x4fd51cb87ffefdf1711112b5bd8ab682e54988ea", + "name": "WPT Investing Corp", + "symbol": "WPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26431/thumb/200200.png?1657934772" + }, + { + "chainId": 1, + "address": "0x9fc8f0ca1668e87294941b7f627e9c15ea06b459", + "name": "True PNL", + "symbol": "PNL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15282/thumb/256x256logo.png?1623230007" + }, + { + "chainId": 1, + "address": "0x8f6e8cdfa6cee7080864dcbb6b973d17d8d80a8f", + "name": "NFCore", + "symbol": "NFCR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25655/thumb/nfcr.png?1653048464" + }, + { + "chainId": 1, + "address": "0x515d7e9d75e2b76db60f8a051cd890eba23286bc", + "name": "Governor DAO", + "symbol": "GDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13140/thumb/GDAOlogo2-bird.png?1605591842" + }, + { + "chainId": 1, + "address": "0x54c9ea2e9c9e8ed865db4a4ce6711c2a0d5063ba", + "name": "BarterTrade", + "symbol": "BART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12142/thumb/200x200-transparent.png?1606958206" + }, + { + "chainId": 1, + "address": "0x9040e237c3bf18347bb00957dc22167d0f2b999d", + "name": "Standard Protocol", + "symbol": "STND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15100/thumb/standard.jpeg?1619691869" + }, + { + "chainId": 1, + "address": "0x0c37bcf456bc661c14d596683325623076d7e283", + "name": "Aeron", + "symbol": "ARNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1124/thumb/ARNX-token-logo-256x256.png?1602652111" + }, + { + "chainId": 1, + "address": "0xb62132e35a6c13ee1ee0f84dc5d40bad8d815206", + "name": "NEXO", + "symbol": "NEXO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3695/thumb/nexo.png?1548086057" + }, + { + "chainId": 1, + "address": "0xab93df617f51e1e415b5b4f8111f122d6b48e55c", + "name": "Delta Exchange", + "symbol": "DETO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14610/thumb/deto-logo.png?1617247295" + }, + { + "chainId": 1, + "address": "0x110fe5f21c1edd4f03a6e0de0d96d0c2eed0b9cc", + "name": "Tessla Coin", + "symbol": "TSLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13045/thumb/Tessla-Icon.png?1604630729" + }, + { + "chainId": 1, + "address": "0x26e43759551333e57f073bb0772f50329a957b30", + "name": "DegenVC", + "symbol": "DGVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12208/thumb/degen_vc_logo.png?1598186601" + }, + { + "chainId": 1, + "address": "0x8b39b70e39aa811b69365398e0aace9bee238aeb", + "name": "Firebird", + "symbol": "PKF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14422/thumb/LOGO_FB.png?1669460464" + }, + { + "chainId": 1, + "address": "0x586aa273f262909eef8fa02d90ab65f5015e0516", + "name": "Fixed Income Asset", + "symbol": "FIAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25477/thumb/fiat.png?1652007537" + }, + { + "chainId": 1, + "address": "0xe814aee960a85208c3db542c53e7d4a6c8d5f60f", + "name": "Chronologic", + "symbol": "DAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/951/thumb/Chronologic-network.png?1547034815" + }, + { + "chainId": 1, + "address": "0x343c6de13833bc7d9890eb6b1cd3fbebc730ebec", + "name": "Decentralized Activism", + "symbol": "DACT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27700/thumb/logodact200x200.png?1665305210" + }, + { + "chainId": 1, + "address": "0xf21661d0d1d76d3ecb8e1b9f1c923dbfffae4097", + "name": "Realio Network", + "symbol": "RIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12206/thumb/0.jpg?1598083003" + }, + { + "chainId": 1, + "address": "0x244517dc59943e8cdfbd424bdb3262c5f04a1387", + "name": "Fluid DAI", + "symbol": "FDAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28473/thumb/fDAI-200x200.png?1671002526" + }, + { + "chainId": 1, + "address": "0xda4dd9586d27202a338843dd6b9824d267006783", + "name": "Echain Network", + "symbol": "ECT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28133/thumb/1666808362379-8226c3c3451e049842cfe21d65cb91ad.png?1667719253" + }, + { + "chainId": 1, + "address": "0x1e797ce986c3cff4472f7d38d5c4aba55dfefe40", + "name": "BlockCDN", + "symbol": "BCDN", + "decimals": 15, + "logoURI": "https://assets.coingecko.com/coins/images/1301/thumb/blockcdn.png?1547350830" + }, + { + "chainId": 1, + "address": "0xadf86e75d8f0f57e0288d0970e7407eaa49b3cab", + "name": "Apollo Crypto", + "symbol": "APOLLO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22606/thumb/apollo-icon-green-black-w3-200.png?1656312049" + }, + { + "chainId": 1, + "address": "0x9669890e48f330acd88b78d63e1a6b3482652cd9", + "name": "Bincentive", + "symbol": "BCNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9661/thumb/bcnt.png?1640328324" + }, + { + "chainId": 1, + "address": "0xbed4ab0019ff361d83ddeb74883dac8a70f5ea1e", + "name": "MerchDAO", + "symbol": "MRCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14540/thumb/logo_256x256.png?1616891356" + }, + { + "chainId": 1, + "address": "0xc12d099be31567add4e4e4d0d45691c3f58f5663", + "name": "Auctus", + "symbol": "AUC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2165/thumb/Auc_Discord_Avatar1.png?1618983355" + }, + { + "chainId": 1, + "address": "0x99295f1141d58a99e939f7be6bbe734916a875b8", + "name": "LinkPool", + "symbol": "LPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14548/thumb/linkpool-logo-256x256.png?1616988567" + }, + { + "chainId": 1, + "address": "0x364fcd7325c035cc4f2cde8b6c8d7df5e7db6589", + "name": "Metalk", + "symbol": "META", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24801/thumb/meta.png?1648983422" + }, + { + "chainId": 1, + "address": "0x4b1e80cac91e2216eeb63e29b957eb91ae9c2be8", + "name": "Jupiter", + "symbol": "JUP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10351/thumb/logo512.png?1632480932" + }, + { + "chainId": 1, + "address": "0x255aa6df07540cb5d3d297f0d0d4d84cb52bc8e6", + "name": "Raiden Network", + "symbol": "RDN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1132/thumb/raiden-logo.jpg?1547035131" + }, + { + "chainId": 1, + "address": "0xdfc628a33c18e856cd1c59583cb5ace8db706f14", + "name": "Projekt Gold", + "symbol": "GOLD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16417/thumb/gold.png?1623982279" + }, + { + "chainId": 1, + "address": "0xf24d8651578a55b0c119b9910759a351a3458895", + "name": "Stake DAO Balancer", + "symbol": "SDBAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26224/thumb/6uqFPXny_400x400.jpg?1656642803" + }, + { + "chainId": 1, + "address": "0xba11d00c5f74255f56a5e366f4f77f5a186d7f55", + "name": "Band Protocol", + "symbol": "BAND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9545/thumb/Band_token_blue_violet_token.png?1625881431" + }, + { + "chainId": 1, + "address": "0x7101a9392eac53b01e7c07ca3baca945a56ee105", + "name": "X7101", + "symbol": "X7101", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28419/thumb/X7101_LOGO_black_back_200_x_200_px.png?1670460693" + }, + { + "chainId": 1, + "address": "0x4092678e4e78230f46a1534c0fbc8fa39780892b", + "name": "Odyssey", + "symbol": "OCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2559/thumb/ocn.png?1547036683" + }, + { + "chainId": 1, + "address": "0x5150956e082c748ca837a5dfa0a7c10ca4697f9c", + "name": "Zeedex", + "symbol": "ZDEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12412/thumb/Untitled-design-4.png?1599647173" + }, + { + "chainId": 1, + "address": "0xc56f38a1e1a14727d89eccdc97d23a59159b31bd", + "name": "Beavis and Butthead", + "symbol": "BBH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19213/thumb/bbh.jpeg?1634696594" + }, + { + "chainId": 1, + "address": "0x99534ef705df1fff4e4bd7bbaaf9b0dff038ebfe", + "name": "Ankr MATIC Reward Earning Bond", + "symbol": "AMATICB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26096/thumb/aMATICb.png?1658821076" + }, + { + "chainId": 1, + "address": "0x833850be8858722cfc5e5e75f2fe6275e055d888", + "name": "DecentraBNB", + "symbol": "DBNB", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26544/thumb/Screenshot_2022-07-22_at_18.16.11.png?1658735503" + }, + { + "chainId": 1, + "address": "0xe5feeac09d36b18b3fa757e5cf3f8da6b8e27f4c", + "name": "NFT Index", + "symbol": "NFTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14215/thumb/nfti.png?1614992905" + }, + { + "chainId": 1, + "address": "0x8db253a1943dddf1af9bcf8706ac9a0ce939d922", + "name": "Unbound Finance", + "symbol": "UNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21412/thumb/Unbound_icon_png.png?1639091708" + }, + { + "chainId": 1, + "address": "0x888888888889c00c67689029d7856aac1065ec11", + "name": "Opium", + "symbol": "OPIUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13758/thumb/opium-token-black_%281%29.png?1611767960" + }, + { + "chainId": 1, + "address": "0x2cad4991f62fc6fcd8ec219f37e7de52b688b75a", + "name": "Schain Wallet", + "symbol": "SCHA", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/12135/thumb/schain.png?1597462731" + }, + { + "chainId": 1, + "address": "0x44108f0223a3c3028f5fe7aec7f9bb2e66bef82f", + "name": "Across Protocol", + "symbol": "ACX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28161/thumb/across-200x200.png?1668168201" + }, + { + "chainId": 1, + "address": "0xd33526068d116ce69f19a9ee46f0bd304f21a51f", + "name": "Rocket Pool", + "symbol": "RPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2090/thumb/rocket_pool_%28RPL%29.png?1637662441" + }, + { + "chainId": 1, + "address": "0x74159651a992952e2bf340d7628459aa4593fc05", + "name": "Tenet", + "symbol": "TEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13545/thumb/iMqC3F_p_400x400.png?1609711856" + }, + { + "chainId": 1, + "address": "0xbf776e4fca664d791c4ee3a71e2722990e003283", + "name": "Smoothy", + "symbol": "SMTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15039/thumb/dDxKgwPN_400x400.jpg?1619507030" + }, + { + "chainId": 1, + "address": "0xcec2387e04f9815bf12670dbf6cf03bba26df25f", + "name": "YFILEND FINANCE", + "symbol": "YFILD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12414/thumb/ylend.png?1599684775" + }, + { + "chainId": 1, + "address": "0x01b23286ff60a543ec29366ae8d6b6274ca20541", + "name": "Brother Music Platform", + "symbol": "BMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13207/thumb/BMP_logo.png?1606199707" + }, + { + "chainId": 1, + "address": "0x7c5d5100b339fe7d995a893af6cb496b9474373c", + "name": "Loon Network", + "symbol": "LOON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11673/thumb/ErUvUA2D4Q8hPWXxZBIuiI8MD0nrU2rDEY56d6EtVzJDTqlflAFXa2bgJ_kFwb8OtotfAvESvm-dik7d_SeJJh23f6RosUJ0AzU64QcKk5H3fu300KOJjFDFsntpRWARFKI5S4Cc8F3pcRPBkFIw6oPF58mKi83sa2DJPl-E5JMqmj6rJh5acb7Fvi80kfziWv3DHhhpg1YJYMP.jpg?1592536236" + }, + { + "chainId": 1, + "address": "0xb64fde8f199f073f41c132b9ec7ad5b61de0b1b7", + "name": "Incognito", + "symbol": "PRV", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21971/thumb/50738351.png?1640560573" + }, + { + "chainId": 1, + "address": "0x6a6aa13393b7d1100c00a57c76c39e8b6c835041", + "name": "OpenAI ERC", + "symbol": "OPENAIERC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28412/thumb/OpenAI.jpeg?1670387260" + }, + { + "chainId": 1, + "address": "0x410e731c2970dce3add351064acf5ce9e33fdbf0", + "name": "ONBUFF", + "symbol": "ONIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12252/thumb/d4suDHSzEZjDXc0uxFGPZXfDFp0L1tfoEusBx03zB1bvMLLbxa7Yq5naXAOutkirIlLXacFRRebX_hF2Ez69_fIPUfr2LuN0Z_UrXTLYds4aT95C6eHGXsZnezMHKAaOmjLpKto0xPTiYkXExvEvXrqL7O_J1wecb4eJsgwCoVprMLpm89BdKO9IyMmpNsfbW7JJFMiHgL8vq9fPhaeEi.jpg?1598519096" + }, + { + "chainId": 1, + "address": "0x3633f95e4d5900cb7525f5801639aeabc998c750", + "name": "ProjectFeenixv2", + "symbol": "FEENIXV2", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22768/thumb/Project-Feenix-Logo_32x32.png?1642575940" + }, + { + "chainId": 1, + "address": "0x179cd91631d96e8fafee6a744eac6ffdbb923520", + "name": "IxiCash", + "symbol": "IXI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8368/thumb/ixi.png?1565866972" + }, + { + "chainId": 1, + "address": "0xbea98c05eeae2f3bc8c3565db7551eb738c8ccab", + "name": "Geyser", + "symbol": "GYSR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12995/thumb/logo_padded_shifted.png?1636633987" + }, + { + "chainId": 1, + "address": "0xa518c9f3724cced4715e6813858dc2ce9b21ed78", + "name": "ShibRWD", + "symbol": "SRWD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21777/thumb/SRWD-LOGO-1.png?1643186506" + }, + { + "chainId": 1, + "address": "0x467bccd9d29f223bce8043b84e8c8b282827790f", + "name": "Telcoin", + "symbol": "TEL", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/1899/thumb/tel.png?1547036203" + }, + { + "chainId": 1, + "address": "0x6a7260e44789aef24fdaf72d80ecdc253aaa079e", + "name": "Corra Finance", + "symbol": "CORA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15684/thumb/Corra_C_Logo.png?1631116498" + }, + { + "chainId": 1, + "address": "0xd33d0eb1c0c0295c3a2409a9101dd511823bf217", + "name": "Unique Fans", + "symbol": "FANS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14715/thumb/fans_200X200.png?1617922576" + }, + { + "chainId": 1, + "address": "0x1453dbb8a29551ade11d89825ca812e05317eaeb", + "name": "Tendies", + "symbol": "TEND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11924/thumb/aaaaa.jpg?1596645622" + }, + { + "chainId": 1, + "address": "0xb5be7557fe8f69a2b5707d25fa0aee80dfda512e", + "name": "POLYSPORTS", + "symbol": "PS1", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25070/thumb/L-T2x_cG_400x400.jpg?1650024620" + }, + { + "chainId": 1, + "address": "0x7697b462a7c4ff5f8b55bdbc2f4076c2af9cf51a", + "name": "Sarcophagus", + "symbol": "SARCO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15091/thumb/E2S2-CcUcAAyNxD.jpeg?1622519884" + }, + { + "chainId": 1, + "address": "0xf4cd3d3fda8d7fd6c5a500203e38640a70bf9577", + "name": "YfDAI finance", + "symbol": "YF-DAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12385/thumb/1619048513068.png?1622193581" + }, + { + "chainId": 1, + "address": "0x340d2bde5eb28c1eed91b2f790723e3b160613b7", + "name": "BLOCKv", + "symbol": "VEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1266/thumb/blockv.png?1547351380" + }, + { + "chainId": 1, + "address": "0x656c00e1bcd96f256f224ad9112ff426ef053733", + "name": "Efinity", + "symbol": "EFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16558/thumb/efi-200px_%281%29.png?1624439132" + }, + { + "chainId": 1, + "address": "0x7051620d11042c4335069aaa4f10cd3b4290c681", + "name": "TCASH", + "symbol": "TCASH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6574/thumb/jiPkVuI7_400x400.jpg?1547042782" + }, + { + "chainId": 1, + "address": "0xd68cb7a643079311b8645ed90f2d5267cfa6ea26", + "name": "Wall Street Inu", + "symbol": "WALLSTREETINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20551/thumb/logo-coingecko.png?1637767297" + }, + { + "chainId": 1, + "address": "0x1955d744f9435522be508d1ba60e3c12d0690b6a", + "name": "WPP Token", + "symbol": "WPP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8103/thumb/WzdD53fh_400x400.jpg?1554860792" + }, + { + "chainId": 1, + "address": "0x7dd1a71898dd122b4613a12d897f7b64c4ccac64", + "name": "Mars Protocol", + "symbol": "MARS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27469/thumb/MARSlogo-200x200.png?1664186518" + }, + { + "chainId": 1, + "address": "0x7dbdd9dafdc4c1c03d67925a4f85daa398af32b0", + "name": "Anchor Neural World", + "symbol": "ANW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11104/thumb/logo_scan.png?1588567155" + }, + { + "chainId": 1, + "address": "0x488e0369f9bc5c40c002ea7c1fe4fd01a198801c", + "name": "Golff", + "symbol": "GOF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12445/thumb/_x-AmLBv_400x400.jpg?1599902833" + }, + { + "chainId": 1, + "address": "0xd15a1a2a3211b58113e45809f05934252e34e2f8", + "name": "Woozoo Music", + "symbol": "WZM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21891/thumb/logo_200_200_%281%29.png?1640228330" + }, + { + "chainId": 1, + "address": "0xed0439eacf4c4965ae4613d77a5c2efe10e5f183", + "name": "Niftyx Protocol", + "symbol": "SHROOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12341/thumb/niftyx_logo.jpg?1617784430" + }, + { + "chainId": 1, + "address": "0x8947da500eb47f82df21143d0c01a29862a8c3c5", + "name": "Thales", + "symbol": "THALES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18388/thumb/CLVZJN_C_400x400.png?1631758808" + }, + { + "chainId": 1, + "address": "0x48fb253446873234f2febbf9bdeaa72d9d387f94", + "name": "Bancor Governance", + "symbol": "VBNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14053/thumb/bancorvbnt_32.png?1614048819" + }, + { + "chainId": 1, + "address": "0xa1d0e215a23d7030842fc67ce582a6afa3ccab83", + "name": "DFI money", + "symbol": "YFII", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11902/thumb/YFII-logo.78631676.png?1598677348" + }, + { + "chainId": 1, + "address": "0x674c964ac0e89d847d6b0abd144b797bf78ba56b", + "name": "GreenWorld", + "symbol": "GWD", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/27771/thumb/200x200logo.png?1665737292" + }, + { + "chainId": 1, + "address": "0xa9d2927d3a04309e008b6af6e2e282ae2952e7fd", + "name": "Zipper Network", + "symbol": "ZIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4524/thumb/zip_token_logo.png?1547039822" + }, + { + "chainId": 1, + "address": "0xc82e3db60a52cf7529253b4ec688f631aad9e7c2", + "name": "Arc", + "symbol": "ARC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24235/thumb/arc.png?1647694270" + }, + { + "chainId": 1, + "address": "0x409c4d8cd5d2924b9bc5509230d16a61289c8153", + "name": "TONStarter", + "symbol": "TOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17878/thumb/tos.PNG?1629703380" + }, + { + "chainId": 1, + "address": "0x7104d1f179cc9cc7fb5c79be6da846e3fbc4c105", + "name": "X7104", + "symbol": "X7104", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28422/thumb/X7104_LOGO_black_back_200_x_200_px.png?1670460882" + }, + { + "chainId": 1, + "address": "0x69beab403438253f13b6e92db91f7fb849258263", + "name": "Neuro NTK", + "symbol": "NTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3028/thumb/neurotoken.png?1547037334" + }, + { + "chainId": 1, + "address": "0x7659ce147d0e714454073a5dd7003544234b6aa0", + "name": "XCAD Network", + "symbol": "XCAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15857/thumb/logoWhiteX.jpg?1666230966" + }, + { + "chainId": 1, + "address": "0x88400f09934f817baf7e5e5be3b88961a501eead", + "name": "Zappay", + "symbol": "ZAPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26535/thumb/zappay200.png?1658715592" + }, + { + "chainId": 1, + "address": "0x638f24096ff33e047e05e59fabc76325207090dc", + "name": "SquishiVerse", + "symbol": "SLIME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25004/thumb/19481.png?1649759045" + }, + { + "chainId": 1, + "address": "0xc97232527b62efb0d8ed38cf3ea103a6cca4037e", + "name": "LP Yearn CRV Vault", + "symbol": "LP-YCRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27624/thumb/yearncrvlp_32.png?1664885596" + }, + { + "chainId": 1, + "address": "0xa2cd3d43c775978a96bdbf12d733d5a1ed94fb18", + "name": "Chain", + "symbol": "XCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24210/thumb/Chain_icon_200x200.png?1646895054" + }, + { + "chainId": 1, + "address": "0x1bf7fd22709733ccd7c45ab27dd02c7ec8e50078", + "name": "Quiztok", + "symbol": "QTCON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8208/thumb/QTCON.png?1587543372" + }, + { + "chainId": 1, + "address": "0x2942e3b38e33123965bfbc21e802be943a76bbc6", + "name": "EHash", + "symbol": "EHASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14180/thumb/ehash.png?1614820416" + }, + { + "chainId": 1, + "address": "0x90f36d7bfba633f17eccc62ec31c58a9a3c04c2a", + "name": "PulseFloki", + "symbol": "PLSF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26833/thumb/Pulse_Floki_Transparant.PNG?1660298457" + }, + { + "chainId": 1, + "address": "0xf6fd82dedbbe0ffadb5e1ecc2a283ab52b9ed2b0", + "name": "Etheal", + "symbol": "HEAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3267/thumb/heal.png?1547037807" + }, + { + "chainId": 1, + "address": "0x85ca6710d0f1d511d130f6935edda88acbd921bd", + "name": "Pledgecamp", + "symbol": "PLG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5120/thumb/pledgecamop.png?1550204115" + }, + { + "chainId": 1, + "address": "0xcda2f16c6aa895d533506b426aff827b709c87f5", + "name": "Fairum", + "symbol": "FAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13894/thumb/logo-65ce48ea8d2b64b6478a42c0050214e2.png?1612645237" + }, + { + "chainId": 1, + "address": "0xd43be54c1aedf7ee4099104f2dae4ea88b18a249", + "name": "Traxx", + "symbol": "TRAXX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24441/thumb/TT.png?1658383110" + }, + { + "chainId": 1, + "address": "0x2be1e42bf263aab47d27ba92e72c14823e101d7c", + "name": "Fluid FRAX", + "symbol": "FFRAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28475/thumb/fFRAX-200x200.png?1671002588" + }, + { + "chainId": 1, + "address": "0x0b319db00d07c8fadfaaef13c910141a5da0aa8f", + "name": "Fluid TUSD", + "symbol": "FTUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28474/thumb/fTUSD-200x200.png?1671002558" + }, + { + "chainId": 1, + "address": "0xd7efb00d12c2c13131fd319336fdf952525da2af", + "name": "Proton", + "symbol": "XPR", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/10941/thumb/Proton-Icon.png?1588283737" + }, + { + "chainId": 1, + "address": "0x324af2d5353f2dd138e234b359d30d67c64b1b20", + "name": "Oracle System", + "symbol": "ORC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12517/thumb/www.oraclesystem.io-home-org-logo.png?1600382654" + }, + { + "chainId": 1, + "address": "0xc0ba369c8db6eb3924965e5c4fd0b4c1b91e305f", + "name": "DLP Duck", + "symbol": "DUCK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13440/thumb/DLP_Duck_Token.png?1612840740" + }, + { + "chainId": 1, + "address": "0x6e98e5401adcb0d76f4debfc3d794b3031f48790", + "name": "Aurix", + "symbol": "AUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14372/thumb/gold-brown-2.png?1615769158" + }, + { + "chainId": 1, + "address": "0x1122b6a0e00dce0563082b6e2953f3a943855c1f", + "name": "CENNZnet", + "symbol": "CENNZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3408/thumb/CENNZ_ticker.png?1650943548" + }, + { + "chainId": 1, + "address": "0x187d1018e8ef879be4194d6ed7590987463ead85", + "name": "FUZE", + "symbol": "FUZE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8941/thumb/logo-fuze-fix-big.png?1563117524" + }, + { + "chainId": 1, + "address": "0xf92364c2369a2633ffcd7db1b18d1fafff6bcbab", + "name": "BABIL TOKEN", + "symbol": "BABIL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27252/thumb/PKUhX3jRL.png?1666258453" + }, + { + "chainId": 1, + "address": "0x922105fad8153f516bcfb829f56dc097a0e1d705", + "name": "Yee", + "symbol": "YEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2576/thumb/YeeCo-logo.png?1598519113" + }, + { + "chainId": 1, + "address": "0x9d93692e826a4bd9e903e2a27d7fbd1e116efdad", + "name": "POLY Maximus", + "symbol": "POLY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28236/thumb/photo_2022-11-09_12-53-56.jpg?1668576107" + }, + { + "chainId": 1, + "address": "0xcbcc0f036ed4788f63fc0fee32873d6a7487b908", + "name": "Humaniq", + "symbol": "HMQ", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/647/thumb/humaniq.jpg?1547034375" + }, + { + "chainId": 1, + "address": "0x2370f9d504c7a6e775bf6e14b3f12846b594cd53", + "name": "JPY Coin v1", + "symbol": "JPYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17277/thumb/WoZ8rruL_400x400.png?1627016492" + }, + { + "chainId": 1, + "address": "0xa80f2c8f61c56546001f5fc2eb8d6e4e72c45d4c", + "name": "Unique Utility", + "symbol": "UNQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23382/thumb/D31DBA6B-FB7E-4ACB-82B4-98E255C1C483.jpg?1643962784" + }, + { + "chainId": 1, + "address": "0x0abdace70d3790235af448c88547603b945604ea", + "name": "district0x", + "symbol": "DNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/849/thumb/district0x.png?1547223762" + }, + { + "chainId": 1, + "address": "0xa58a4f5c4bb043d2cc1e170613b74e767c94189b", + "name": "UTU Coin", + "symbol": "UTU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12831/thumb/Aa5nmbkJ_400x400.png?1602884636" + }, + { + "chainId": 1, + "address": "0xe3278df3eb2085ba9b6899812a99a10f9ca5e0df", + "name": "Tourist", + "symbol": "TOTO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5271/thumb/tourist-token.png?1548759070" + }, + { + "chainId": 1, + "address": "0xfdbc1adc26f0f8f8606a5d63b7d3a3cd21c22b23", + "name": "1World", + "symbol": "1WO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3443/thumb/unnamed.png?1547038151" + }, + { + "chainId": 1, + "address": "0x4f3afec4e5a3f2a6a1a411def7d7dfe50ee057bf", + "name": "Digix Gold", + "symbol": "DGX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/4171/thumb/DGX_Token.png?1547039436" + }, + { + "chainId": 1, + "address": "0x6fb0855c404e09c47c3fbca25f08d4e41f9f062f", + "name": "Aave ZRX v1", + "symbol": "AZRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11735/thumb/aZRX.png?1593085371" + }, + { + "chainId": 1, + "address": "0x9e32b13ce7f2e80a01932b42553652e053d6ed8e", + "name": "Metis", + "symbol": "METIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15595/thumb/metis.jpeg?1660285312" + }, + { + "chainId": 1, + "address": "0xe3818504c1b32bf1557b16c238b2e01fd3149c17", + "name": "Pillar", + "symbol": "PLR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/809/thumb/v2logo-1.png?1624906282" + }, + { + "chainId": 1, + "address": "0xdac657ffd44a3b9d8aba8749830bf14beb66ff2d", + "name": "humanDAO", + "symbol": "HDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21138/thumb/Untitled-2.jpg?1645163749" + }, + { + "chainId": 1, + "address": "0xb1e93236ab6073fdac58ada5564897177d4bcc43", + "name": "Seele", + "symbol": "SEELE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3294/thumb/Seele.png?1649325804" + }, + { + "chainId": 1, + "address": "0x04e0af0af1b7f0023c6b12af5a94df59b0e8cf59", + "name": "Sensitrust", + "symbol": "SETS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15035/thumb/SETS-token-logo-200.png?1619503990" + }, + { + "chainId": 1, + "address": "0x054d64b73d3d8a21af3d764efd76bcaa774f3bb2", + "name": "Plasma Finance", + "symbol": "PPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13340/thumb/Hi9sEGAD.png?1607586849" + }, + { + "chainId": 1, + "address": "0x138c2f1123cf3f82e4596d097c118eac6684940b", + "name": "AlphaCoin", + "symbol": "ALPHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22199/thumb/coingeckologo.png?1641193441" + }, + { + "chainId": 1, + "address": "0x2932624ff57f5920ce498bb343385c0332ec6e40", + "name": "Slay To Earn", + "symbol": "SLAY2EARN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26257/thumb/cmc-logo.png?1657600932" + }, + { + "chainId": 1, + "address": "0xb31ef9e52d94d4120eb44fe1ddfde5b4654a6515", + "name": "DOSE", + "symbol": "DOSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18847/thumb/dose.PNG?1633590548" + }, + { + "chainId": 1, + "address": "0x1e0b2992079b620aa13a7c2e7c88d2e1e18e46e9", + "name": "KOMPETE Token", + "symbol": "KOMPETE", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/24298/thumb/KOMPETE_LOGO.?1669463130" + }, + { + "chainId": 1, + "address": "0x2f57430a6ceda85a67121757785877b4a71b8e6d", + "name": "DefiPlaza", + "symbol": "DFP2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19552/thumb/profile-round.png?1654153498" + }, + { + "chainId": 1, + "address": "0x77f0cc420dea0ae726db6bef1460a4b69176a8ea", + "name": "KONG Land Alpha Citizenship", + "symbol": "CITIZEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17751/thumb/QmQmZNp7JNdvYAA8ichVr5bVZUUTfU83zJ8hTZoQfb9YBh.png?1629175195" + }, + { + "chainId": 1, + "address": "0x6b0956258ff7bd7645aa35369b55b61b8e6d6140", + "name": "Maximus LUCKY", + "symbol": "LUCKY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27685/thumb/IMG_1129.PNG?1665214648" + }, + { + "chainId": 1, + "address": "0x66fd97a78d8854fec445cd1c80a07896b0b4851f", + "name": "Lunch Money", + "symbol": "LMY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4149/thumb/IMG_2073.png?1612754752" + }, + { + "chainId": 1, + "address": "0x39317b8a1ae06c30bb615d88cdc5522781499f1c", + "name": "Brainiac", + "symbol": "BRAINS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21356/thumb/CVIaisb.png?1639006193" + }, + { + "chainId": 1, + "address": "0x01fb70ea8acfdd5435c8e8bd1531d96d57ced0ec", + "name": "Smart Electrum", + "symbol": "SELECT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25131/thumb/NRKjS5Cm_400x400.jpg?1650420526" + }, + { + "chainId": 1, + "address": "0xc3d088842dcf02c13699f936bb83dfbbc6f721ab", + "name": "Voucher ETH", + "symbol": "VETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14484/thumb/veth_logo_uniswap_200x200.png?1616471309" + }, + { + "chainId": 1, + "address": "0x22143217662334f073652da5e2f1e0ae7349240c", + "name": "Crown CWT", + "symbol": "CWT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24201/thumb/Crown_Token_JPG_%282%29.jpg?1646838419" + }, + { + "chainId": 1, + "address": "0xd9016a907dc0ecfa3ca425ab20b6b785b42f2373", + "name": "GAMEE", + "symbol": "GMEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14716/thumb/gmee-200x200.png?1621827468" + }, + { + "chainId": 1, + "address": "0x440238cc07186adea6653a2e8cb9a24737615609", + "name": "Shibmerican", + "symbol": "SHIBMERICAN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17008/thumb/60e1bb9c402f36243557ca79_200.png?1626066342" + }, + { + "chainId": 1, + "address": "0xc14830e53aa344e8c14603a91229a0b925b0b262", + "name": "Populous XBRL", + "symbol": "PXT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6207/thumb/populous.jpg?1564992440" + }, + { + "chainId": 1, + "address": "0x044d078f1c86508e13328842cc75ac021b272958", + "name": "Peercoin", + "symbol": "PPC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/4/thumb/peercoin-icon-green-transparent_6x.png?1547033591" + }, + { + "chainId": 1, + "address": "0x09fe5f0236f0ea5d930197dce254d77b04128075", + "name": "Wrapped CryptoKitties", + "symbol": "WCK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8797/thumb/WCK.png?1561705836" + }, + { + "chainId": 1, + "address": "0x865c77b13a882cc264d0506f85e58dd8231d0d73", + "name": "KList Protocol", + "symbol": "LIST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24645/thumb/MrZr9nsN_400x400.jpg?1648479425" + }, + { + "chainId": 1, + "address": "0x0c23a0ce478ada00df4e3c951b8fa6ffe7f1c56b", + "name": "Floki Chain", + "symbol": "FLOKICHAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27180/thumb/photo_2022-09-05_07-15-54.jpg?1662426957" + }, + { + "chainId": 1, + "address": "0xfc1c93a2507975e98b9d0e9260ded61a00152bf1", + "name": "Atlas Navi", + "symbol": "NAVI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28389/thumb/token_icon_-_logo_ATLAS_NAVI_200x200_transparent.png?1670070012" + }, + { + "chainId": 1, + "address": "0xab2a7b5876d707e0126b3a75ef7781c77c8877ee", + "name": "Quadency", + "symbol": "QUAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21364/thumb/GkMXE_7A_400x400.png?1639014399" + }, + { + "chainId": 1, + "address": "0xd34c9281585866a9fb2af0931adb1fa35ed44039", + "name": "Be Gaming Coin", + "symbol": "BGC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13503/thumb/logo_%2897%29.png?1614982763" + }, + { + "chainId": 1, + "address": "0x6069c9223e8a5da1ec49ac5525d4bb757af72cd8", + "name": "MUSK Gold", + "symbol": "MUSK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21696/thumb/musk-icon-200x200.png?1649329802" + }, + { + "chainId": 1, + "address": "0xd7d6ab522fa41caae78f6edeb46a14954ae0c772", + "name": "Chipz", + "symbol": "CHPZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17598/thumb/chipz-logo-22.png?1628591100" + }, + { + "chainId": 1, + "address": "0x3a529a8d4f2ea64d206339fa12a3af4d431f53c3", + "name": "Vendetta Finance", + "symbol": "VEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26601/thumb/VF-Logo.png?1663768906" + }, + { + "chainId": 1, + "address": "0xdefa4e8a7bcba345f687a2f1456f5edd9ce97202", + "name": "Kyber Network Crystal", + "symbol": "KNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14899/thumb/RwdVsGcw_400x400.jpg?1618923851" + }, + { + "chainId": 1, + "address": "0x1a6921f7b92113c79306f1a9e148d83445ac42bc", + "name": "MoonRock V2", + "symbol": "ROCK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25147/thumb/96251267.png?1650438435" + }, + { + "chainId": 1, + "address": "0xdcb5645eda1ed34c5641d81b927d33ebae9cf2a4", + "name": "PayB", + "symbol": "PAYB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25805/thumb/logo_payb_200_x_200.png?1653978259" + }, + { + "chainId": 1, + "address": "0x56e0b2c7694e6e10391e870774daa45cf6583486", + "name": "DUO Network", + "symbol": "DUO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4653/thumb/Duo_Network.png?1556593318" + }, + { + "chainId": 1, + "address": "0xc92276872cd1907d2e00b58a81a9bbd275b0a4ba", + "name": "Collateral Pay Governance", + "symbol": "COLLG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17026/thumb/collg.PNG?1626138703" + }, + { + "chainId": 1, + "address": "0x9e04f519b094f5f8210441e285f603f4d2b50084", + "name": "EarthFund", + "symbol": "1EARTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20822/thumb/earthfund.PNG?1637722232" + }, + { + "chainId": 1, + "address": "0xc66cdac744916afb6811c71c277d88de90ce8d5b", + "name": "CDbio", + "symbol": "MCD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26957/thumb/mcd.png?1660998546" + }, + { + "chainId": 1, + "address": "0x4461cfd640da24d1a4642fa5f9ea3e6da966b831", + "name": "Cosmostarter", + "symbol": "CSMS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19875/thumb/cosmosstarter.PNG?1636083064" + }, + { + "chainId": 1, + "address": "0xc56c2b7e71b54d38aab6d52e94a04cbfa8f604fa", + "name": "ZUSD", + "symbol": "ZUSD", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14192/thumb/icon_zusd_200_200.png?1614843297" + }, + { + "chainId": 1, + "address": "0x5136c98a80811c3f46bdda8b5c4555cfd9f812f0", + "name": "indaHash", + "symbol": "IDH", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1909/thumb/indahash.png?1547973902" + }, + { + "chainId": 1, + "address": "0xe33f363351186e185470f35f6deb94aba44347d8", + "name": "Basid Coin", + "symbol": "BASID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12566/thumb/basid-logo.png?1600827668" + }, + { + "chainId": 1, + "address": "0x6bff2fe249601ed0db3a87424a2e923118bb0312", + "name": "Fyooz", + "symbol": "FYZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12202/thumb/fyooz.png?1598017956" + }, + { + "chainId": 1, + "address": "0x5b09a0371c1da44a8e24d36bf5deb1141a84d875", + "name": "MADNetwork", + "symbol": "MAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2031/thumb/Logo.png?1606984567" + }, + { + "chainId": 1, + "address": "0xb74755f2896e088790f81205f7f3746e2a4b358b", + "name": "SYBC Coin", + "symbol": "SYBC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12901/thumb/sybc.png?1603346599" + }, + { + "chainId": 1, + "address": "0xa799c4adcf62e025ce4d8abe6a77cebc487d772a", + "name": "LuxFi", + "symbol": "LXF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20095/thumb/LPue04PB_400x400_%281%29.png?1636494545" + }, + { + "chainId": 1, + "address": "0x259ab9b9eab62b0fd98729b97be121073d5b3479", + "name": "Erica Social Token", + "symbol": "EST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24076/thumb/EST.png?1646632592" + }, + { + "chainId": 1, + "address": "0x5fdaa123bf828d0d6a1c4ae62a95a6b3bade57c6", + "name": "Sweep Capital", + "symbol": "SWEEP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24007/thumb/logo_sweep_CG.png?1646028643" + }, + { + "chainId": 1, + "address": "0xe61fdaf474fac07063f2234fb9e60c1163cfa850", + "name": "Coin", + "symbol": "COIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2394/thumb/coindefi.png?1629442922" + }, + { + "chainId": 1, + "address": "0xf8c3527cc04340b208c854e985240c02f7b7793f", + "name": "Frontier", + "symbol": "FRONT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12479/thumb/frontier_logo.png?1600145472" + }, + { + "chainId": 1, + "address": "0xf8e9f10c22840b613cda05a0c5fdb59a4d6cd7ef", + "name": "Dogs Of Elon", + "symbol": "DOE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19942/thumb/doe.png?1636336026" + }, + { + "chainId": 1, + "address": "0x24ffe459f51ea20c5d8ad49843529fc33654e7e4", + "name": "Pomeranian ETH", + "symbol": "POM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28246/thumb/Pom.jpeg?1668591756" + }, + { + "chainId": 1, + "address": "0xd46ba6d942050d489dbd938a2c909a5d5039a161", + "name": "Ampleforth", + "symbol": "AMPL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/4708/thumb/Ampleforth.png?1561684250" + }, + { + "chainId": 1, + "address": "0xf4134146af2d511dd5ea8cdb1c4ac88c57d60404", + "name": "SunContract", + "symbol": "SNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1166/thumb/suncontract.png?1548611174" + }, + { + "chainId": 1, + "address": "0x9d37f31a4e8c6af7f64f1ce6241d24f5cacd391c", + "name": "Viral", + "symbol": "VIRAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25036/thumb/4iT-NXVI_400x400.jpg?1649853009" + }, + { + "chainId": 1, + "address": "0x62a8c2818bd7034dc24cd22368c3e53e8eb47c18", + "name": "InnitForTheTECH", + "symbol": "INNIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26724/thumb/INNITlogo.jpg?1659876626" + }, + { + "chainId": 1, + "address": "0x28cb7e841ee97947a86b06fa4090c8451f64c0be", + "name": "YF Link", + "symbol": "YFL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12081/thumb/YFLink.png?1596987945" + }, + { + "chainId": 1, + "address": "0x1b8568fbb47708e9e9d31ff303254f748805bf21", + "name": "Scarcity", + "symbol": "SCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19064/thumb/scx_gecko.png?1634266881" + }, + { + "chainId": 1, + "address": "0xb9eceb9f717852ad0d936b46155cb0c0f43cbe8e", + "name": "Ubiner", + "symbol": "UBIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12190/thumb/ubin.PNG?1597965582" + }, + { + "chainId": 1, + "address": "0x2c2f7e7c5604d162d75641256b80f1bf6f4dc796", + "name": "Polkarare", + "symbol": "PRARE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15388/thumb/Image_from_iOS.png?1621145396" + }, + { + "chainId": 1, + "address": "0x3c6ff50c9ec362efa359317009428d52115fe643", + "name": "PeerEx Network", + "symbol": "PERX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12091/thumb/2AyoUJyQ_400x400.jpg?1597273390" + }, + { + "chainId": 1, + "address": "0x35f6b052c598d933d69a4eec4d04c73a191fe6c2", + "name": "Aave SNX", + "symbol": "ASNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14265/thumb/aSNX.3238f3e7.png?1615528264" + }, + { + "chainId": 1, + "address": "0xa4cf2afd3b165975afffbf7e487cdd40c894ab6b", + "name": "Shibaken Finance", + "symbol": "SHIBAKEN", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/15413/thumb/shibak.png?1660902286" + }, + { + "chainId": 1, + "address": "0x58fcaa970339a9b1f8c0a5b4f3fcd7af2ba3075e", + "name": "Polar Sync", + "symbol": "POLAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18102/thumb/polar-sync-logo-200.jpeg?1668595860" + }, + { + "chainId": 1, + "address": "0xf970b8e36e23f7fc3fd752eea86f8be8d83375a6", + "name": "Ripio Credit Network", + "symbol": "RCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1057/thumb/ripio-credit-network.png?1548608361" + }, + { + "chainId": 1, + "address": "0xc6e145421fd494b26dcf2bfeb1b02b7c5721978f", + "name": "Crypto Perx", + "symbol": "CPRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20768/thumb/8iQSd5YY_400x400.jpg?1637655996" + }, + { + "chainId": 1, + "address": "0x6ca88cc8d9288f5cad825053b6a1b179b05c76fc", + "name": "Universal Protocol Token", + "symbol": "UPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10136/thumb/yS35aK0t_400x400_%281%29.jpg?1576191179" + }, + { + "chainId": 1, + "address": "0x910c4da718caf4ee38ce5c2490cddaeca689204e", + "name": "Waste Digital Coin", + "symbol": "WACO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19035/thumb/waco.png?1634197749" + }, + { + "chainId": 1, + "address": "0x538a151dd910c1d1227719bd400d6c4f99ea06d0", + "name": "Cryptochrome", + "symbol": "CHM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13028/thumb/cryptochrome_logo.png?1604461218" + }, + { + "chainId": 1, + "address": "0xf74941046389c78f12fe44784c0ec9ca7ceb7dc2", + "name": "Dreamr Platform", + "symbol": "DMR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18307/thumb/DMR_SYMBOL_OFFICIAL_200X200.png?1631508227" + }, + { + "chainId": 1, + "address": "0x0a9f693fce6f00a51a8e0db4351b5a8078b4242e", + "name": "Resfinex Token", + "symbol": "RES", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/10026/thumb/logo_%281%29.png?1588935633" + }, + { + "chainId": 1, + "address": "0xa1817b6d8d890f3943b61648992730373b71f156", + "name": "Mongoose", + "symbol": "MONGOOSE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21456/thumb/61b142508fba4235f29d57eb_Frame_24_%281%29.png?1639291023" + }, + { + "chainId": 1, + "address": "0x728f30fa2f100742c7949d1961804fa8e0b1387d", + "name": "GamerCoin", + "symbol": "GHX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14714/thumb/ghx_icon.png?1618819440" + }, + { + "chainId": 1, + "address": "0xbe9ab37a414c517b2be2bfa5945665bb07379054", + "name": "TomTomCoin", + "symbol": "TOMS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22864/thumb/toms_logo_200.png?1642753016" + }, + { + "chainId": 1, + "address": "0xf03a7eb46d01d9ecaa104558c732cf82f6b6b645", + "name": "Stader MaticX", + "symbol": "MATICX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25383/thumb/6GWyFVHD_400x400.jpg?1651615396" + }, + { + "chainId": 1, + "address": "0x0cdf9acd87e940837ff21bb40c9fd55f68bba059", + "name": "Public Mint", + "symbol": "MINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14106/thumb/Public_Mint_Icon_200x200.png?1614333027" + }, + { + "chainId": 1, + "address": "0x84f7c44b6fed1080f647e354d552595be2cc602f", + "name": "Bigbom", + "symbol": "BBO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3795/thumb/bigbom-logo.png?1547038875" + }, + { + "chainId": 1, + "address": "0x9c5673002d854de18e9f6feb7f9825f88c5bf1e4", + "name": "Terraform DAO", + "symbol": "TERRAFORM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26742/thumb/tf-logo-200x200.png?1660005166" + }, + { + "chainId": 1, + "address": "0xfb7b4564402e5500db5bb6d63ae671302777c75a", + "name": "DexTools", + "symbol": "DEXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11603/thumb/dext.png?1605790188" + }, + { + "chainId": 1, + "address": "0xff44b5719f0b77a9951636fc5e69d3a1fc9e7d73", + "name": "4ART Coin", + "symbol": "4ART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4690/thumb/0_%284%29.png?1595544690" + }, + { + "chainId": 1, + "address": "0x6f259637dcd74c767781e37bc6133cd6a68aa161", + "name": "Huobi", + "symbol": "HT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2822/thumb/huobi-token-logo.png?1547036992" + }, + { + "chainId": 1, + "address": "0x8d96b4ab6c741a4c8679ae323a100d74f085ba8f", + "name": "Bazaars", + "symbol": "BZR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26392/thumb/bazaars_logo-color-black-icon.png?1657753265" + }, + { + "chainId": 1, + "address": "0x5224f552f110ec78e6e0468138950ae5f3040942", + "name": "Anomus Coin", + "symbol": "ANOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20865/thumb/w07_TWqn_400x400.png?1637807012" + }, + { + "chainId": 1, + "address": "0x90de74265a416e1393a450752175aed98fe11517", + "name": "Unlock Protocol", + "symbol": "UDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14545/thumb/unlock.jpg?1616948136" + }, + { + "chainId": 1, + "address": "0x94501b6a153c8973fd1f321fcc8188d40dc5d72d", + "name": "DigiDinar Token", + "symbol": "DDRT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10415/thumb/8WbpGRw.png?1579128643" + }, + { + "chainId": 1, + "address": "0x16b0a1a87ae8af5c792fabc429c4fe248834842b", + "name": "Algory", + "symbol": "ALG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12231/thumb/logo-2.png?1605256312" + }, + { + "chainId": 1, + "address": "0xe6602b34d8510b033e000975b3322537c7172441", + "name": "Frontrow", + "symbol": "FRR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21658/thumb/uZsO4yI7_400x400.jpg?1639697777" + }, + { + "chainId": 1, + "address": "0x423b5f62b328d0d6d44870f4eee316befa0b2df5", + "name": "GoNetwork", + "symbol": "GOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3291/thumb/gonetwork.png?1547743011" + }, + { + "chainId": 1, + "address": "0x5319e86f0e41a06e49eb37046b8c11d78bcad68c", + "name": "Zelwin", + "symbol": "ZLW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11547/thumb/5614.png?1590991128" + }, + { + "chainId": 1, + "address": "0xa6dd98031551c23bb4a2fbe2c4d524e8f737c6f7", + "name": "Tokenfy", + "symbol": "TKNFY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22901/thumb/tknfy.png?1642859030" + }, + { + "chainId": 1, + "address": "0x486f4641ef2b50cc130dadbd27b6f271723873b8", + "name": "Adventurer Gold", + "symbol": "GOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28427/thumb/anon-npc-pixel.png?1670548056" + }, + { + "chainId": 1, + "address": "0xf136d7b0b7ae5b86d21e7b78dfa95375a7360f19", + "name": "Toshimon", + "symbol": "TOSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14019/thumb/9E1K1PIZ_400x400.png?1613716582" + }, + { + "chainId": 1, + "address": "0x050d94685c6b0477e1fc555888af6e2bb8dfbda5", + "name": "Inu ", + "symbol": "INU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26259/thumb/inulogo_200x200.png?1656941363" + }, + { + "chainId": 1, + "address": "0xa95592dcffa3c080b4b40e459c5f5692f67db7f8", + "name": "Elysian", + "symbol": "ELY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3558/thumb/elysian.png?1548124914" + }, + { + "chainId": 1, + "address": "0xbce0665b20164d6cd6d15e70fed1e094ad4a44f0", + "name": "Meta Capital", + "symbol": "MCAP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22320/thumb/EMWN_Ybl_400x400.jpg?1641454816" + }, + { + "chainId": 1, + "address": "0x44086035439e676c02d411880fccb9837ce37c57", + "name": "unified Stable Dollar", + "symbol": "USD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12259/thumb/Uniswap_State_Dollar.png?1598550804" + }, + { + "chainId": 1, + "address": "0x61e90a50137e1f645c9ef4a0d3a4f01477738406", + "name": "League of Kingdoms", + "symbol": "LOKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22572/thumb/loka_64pix.png?1642643271" + }, + { + "chainId": 1, + "address": "0xff20817765cb7f73d4bde2e66e067e58d11095c2", + "name": "Amp", + "symbol": "AMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12409/thumb/amp-200x200.png?1599625397" + }, + { + "chainId": 1, + "address": "0x045414e728067ab3da4bceafc0d992d59183463a", + "name": "B watch Box", + "symbol": "BOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25324/thumb/Screenshot_from_2022-04-29_17-04-42.png?1651223108" + }, + { + "chainId": 1, + "address": "0x2af5d2ad76741191d15dfe7bf6ac92d4bd912ca3", + "name": "LEO Token", + "symbol": "LEO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8418/thumb/leo-token.png?1558326215" + }, + { + "chainId": 1, + "address": "0x6a4c76874e686a7d080d173987a35a9c48905583", + "name": "Luxurious Pro Network", + "symbol": "LPNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14126/thumb/logo_%2894%29.png?1614570735" + }, + { + "chainId": 1, + "address": "0x6ec8a24cabdc339a06a172f8223ea557055adaa5", + "name": "Genaro Network", + "symbol": "GNX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/1361/thumb/genaro-network.png?1547035387" + }, + { + "chainId": 1, + "address": "0xb14ebf566511b9e6002bb286016ab2497b9b9c9d", + "name": "Hypersign Identity", + "symbol": "HID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16158/thumb/hypersign_ONLYlogo_Yellow.png?1623140987" + }, + { + "chainId": 1, + "address": "0x9ccf191169a613eca433a249d3f40131178caebc", + "name": "MicroChains Gov Token", + "symbol": "MCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26663/thumb/B2QwV0BL_400x400.jpeg?1659449087" + }, + { + "chainId": 1, + "address": "0x39aa39c021dfbae8fac545936693ac917d5e7563", + "name": "cUSDC", + "symbol": "CUSDC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9442/thumb/Compound_USDC.png?1567581577" + }, + { + "chainId": 1, + "address": "0x0b4c2708f052dca413600e237675e4d6778a9375", + "name": "CoinClaim", + "symbol": "CLM", + "decimals": 16, + "logoURI": "https://assets.coingecko.com/coins/images/6687/thumb/coinclaim.jpg?1547042891" + }, + { + "chainId": 1, + "address": "0x65b678936c489a2639036755aa2107ec09569198", + "name": "ITEN", + "symbol": "ITEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12314/thumb/logo-light_%281%29.png?1599084234" + }, + { + "chainId": 1, + "address": "0xbcd4b7de6fde81025f74426d43165a5b0d790fdd", + "name": "SpiderDAO", + "symbol": "SPDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13378/thumb/spiderdao_logo.png?1608029180" + }, + { + "chainId": 1, + "address": "0xb46eda6219ba121ce9280388e7afb7dc84be3ff2", + "name": "The Youth Pay", + "symbol": "TYP", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/27412/thumb/8xJB5QnY_400x400.jpeg?1663855027" + }, + { + "chainId": 1, + "address": "0x3e780920601d61cedb860fe9c4a90c9ea6a35e78", + "name": "Boosted Finance", + "symbol": "BOOST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12329/thumb/boosted.jpg?1599105606" + }, + { + "chainId": 1, + "address": "0x56123908aca89bf60ce9659ae9f4589e46c8d2cf", + "name": "Mushe", + "symbol": "XMU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27965/thumb/2.png?1666762043" + }, + { + "chainId": 1, + "address": "0x0ecc0e963625e0c5504718ec460116176b3aa06c", + "name": "NBLH", + "symbol": "NBLH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27077/thumb/nblh.png?1661756906" + }, + { + "chainId": 1, + "address": "0xe54b3458c47e44c37a267e7c633afef88287c294", + "name": "Artfinity", + "symbol": "AT", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/8339/thumb/artfinity.png?1557604049" + }, + { + "chainId": 1, + "address": "0x8d137e3337eb1b58a222fef2b2cc7c423903d9cf", + "name": "SQGL Vault NFTX ", + "symbol": "SQGL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17041/thumb/SQGL.png?1626147070" + }, + { + "chainId": 1, + "address": "0x49184e6dae8c8ecd89d8bdc1b950c597b8167c90", + "name": "LIBERTAS", + "symbol": "LIBERTAS", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/11928/thumb/logo200x200_%281%29.png?1596409240" + }, + { + "chainId": 1, + "address": "0x6c3be406174349cfa4501654313d97e6a31072e1", + "name": "CNNS", + "symbol": "CNNS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8362/thumb/cnns.png?1557992686" + }, + { + "chainId": 1, + "address": "0x767fe9edc9e0df98e07454847909b5e959d7ca0e", + "name": "Illuvium", + "symbol": "ILV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14468/thumb/ILV.JPG?1617182121" + }, + { + "chainId": 1, + "address": "0x04969cd041c0cafb6ac462bd65b536a5bdb3a670", + "name": "Wrapped ECOMI", + "symbol": "WOMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14675/thumb/ecomi.jpg?1617689100" + }, + { + "chainId": 1, + "address": "0xe477292f1b3268687a29376116b0ed27a9c76170", + "name": "HEROcoin", + "symbol": "PLAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2221/thumb/herocoin.png?1547744781" + }, + { + "chainId": 1, + "address": "0x2f6081e3552b1c86ce4479b80062a1dda8ef23e3", + "name": "Dollars", + "symbol": "USDX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/12377/thumb/rCdP56C.png?1599445426" + }, + { + "chainId": 1, + "address": "0x2791bfd60d232150bff86b39b7146c0eaaa2ba81", + "name": "BiFi", + "symbol": "BIFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13671/thumb/ysYIu7Q.png?1610679337" + }, + { + "chainId": 1, + "address": "0xfdb15e5e6799be72798b1ccfaecbf186bf73a0c4", + "name": "NitroEX", + "symbol": "NTX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13976/thumb/ntx-icon.png?1613435774" + }, + { + "chainId": 1, + "address": "0xf3281c539716a08c754ec4c8f2b4cee0fab64bb9", + "name": "Markaccy", + "symbol": "MKCY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12522/thumb/e2eLPzTF_400x400.png?1600499534" + }, + { + "chainId": 1, + "address": "0xb4a3b0faf0ab53df58001804dda5bfc6a3d59008", + "name": "Sperax", + "symbol": "SPA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12232/thumb/sperax_logo.jpg?1598342904" + }, + { + "chainId": 1, + "address": "0x6589fe1271a0f29346796c6baf0cdf619e25e58e", + "name": "Grain", + "symbol": "GRAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13331/thumb/784594063499853904.png?1607531032" + }, + { + "chainId": 1, + "address": "0xfca59cd816ab1ead66534d82bc21e7515ce441cf", + "name": "Rarible", + "symbol": "RARI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11845/thumb/Rari.png?1594946953" + }, + { + "chainId": 1, + "address": "0x44197a4c44d6a059297caf6be4f7e172bd56caaf", + "name": "Eltcoin", + "symbol": "ELTCOIN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1118/thumb/eltcoin.png?1547958349" + }, + { + "chainId": 1, + "address": "0x31903e333809897ee57af57567f4377a1a78756c", + "name": "CryptoPunt", + "symbol": "PUN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19230/thumb/cryptopunt.PNG?1634767637" + }, + { + "chainId": 1, + "address": "0x17d2628d30f8e9e966c9ba831c9b9b01ea8ea75c", + "name": "ISKRA Token", + "symbol": "ISK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27428/thumb/ISKRA_logo.png?1663919121" + }, + { + "chainId": 1, + "address": "0x7b3d36eb606f873a75a6ab68f8c999848b04f935", + "name": "LootBox io", + "symbol": "LOOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13414/thumb/ezgif-2-c057c84f38.jpg?1643246914" + }, + { + "chainId": 1, + "address": "0x1f22ad99c334e6689bae751cc225bcc38fe54f82", + "name": "CryptoMoonShots", + "symbol": "CMS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18730/thumb/UEYC0ty.png?1633251229" + }, + { + "chainId": 1, + "address": "0x5c62da804298d5972a323c80b539b8e7517a0dde", + "name": "VENJOCOIN", + "symbol": "VJC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8088/thumb/vjc-logo.jpg?1554454773" + }, + { + "chainId": 1, + "address": "0x77e20fc7f2f4084b74284e1190810fca3679aea0", + "name": "Dev Doing Something", + "symbol": "DEV", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26805/thumb/200x200.png?1660208225" + }, + { + "chainId": 1, + "address": "0xd75f1f81b69bdd4df8efbb70e9c6f4609009d753", + "name": "YASHA", + "symbol": "YASHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24040/thumb/oX9E7Q7.png?1646119331" + }, + { + "chainId": 1, + "address": "0xd137561c20be8e870d62e2ae92269f0950702f77", + "name": "Exp", + "symbol": "EXP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24263/thumb/explogo.png?1648627774" + }, + { + "chainId": 1, + "address": "0xf527d24391c767b86b8e91385e1ce9c54d230a2b", + "name": "Tsuzuki Inu", + "symbol": "TZKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19437/thumb/tzki.png?1635470570" + }, + { + "chainId": 1, + "address": "0x111111517e4929d3dcbdfa7cce55d30d4b6bc4d6", + "name": "ICHI", + "symbol": "ICHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13119/thumb/ICHI_%28Round%29.jpg?1614308761" + }, + { + "chainId": 1, + "address": "0xd109b2a304587569c84308c55465cd9ff0317bfb", + "name": "Aave AMM BptBALWETH", + "symbol": "AAMMBPTBALWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17261/thumb/aAmmBptBALWETH.png?1626959531" + }, + { + "chainId": 1, + "address": "0x7103ebdbf1f89be2d53eff9b3cf996c9e775c105", + "name": "X7103", + "symbol": "X7103", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28421/thumb/X7103_LOGO_black_back_200_x_200_px.png?1670460779" + }, + { + "chainId": 1, + "address": "0x31c2415c946928e9fd1af83cdfa38d3edbd4326f", + "name": "MADworld", + "symbol": "UMAD", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/20939/thumb/UMAD_.png?1638238294" + }, + { + "chainId": 1, + "address": "0x738865301a9b7dd80dc3666dd48cf034ec42bdda", + "name": "Agoras Currency of Tau", + "symbol": "AGRS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/399/thumb/agrs.png?1639622234" + }, + { + "chainId": 1, + "address": "0xfdfe8b7ab6cf1bd1e3d14538ef40686296c42052", + "name": "Skraps", + "symbol": "SKRP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7987/thumb/60EnDfxK_400x400.jpg?1552888803" + }, + { + "chainId": 1, + "address": "0x103c3a209da59d3e7c4a89307e66521e081cfdf0", + "name": "Genesis Vision", + "symbol": "GVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1173/thumb/Genesis-vision.png?1558045005" + }, + { + "chainId": 1, + "address": "0x15874d65e649880c2614e7a480cb7c9a55787ff6", + "name": "EthereumMax", + "symbol": "EMAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15540/thumb/EMAX-Coin-Final2000x.png?1639402630" + }, + { + "chainId": 1, + "address": "0x16756ec1deb89a2106c35e0b586a799d0a61837d", + "name": "Chedda", + "symbol": "CHEDDA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22654/thumb/cMckil70_400x400.jpg?1642400459" + }, + { + "chainId": 1, + "address": "0xaa4e3edb11afa93c41db59842b29de64b72e355b", + "name": "Marginswap", + "symbol": "MFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13899/thumb/marginswap_logo.png?1612756590" + }, + { + "chainId": 1, + "address": "0x3b9be07d622accaed78f479bc0edabfd6397e320", + "name": "Lossless", + "symbol": "LSS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15917/thumb/Group_57.png?1623046307" + }, + { + "chainId": 1, + "address": "0xf7413489c474ca4399eee604716c72879eea3615", + "name": "APYSwap", + "symbol": "APYS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14163/thumb/apys.png?1635831990" + }, + { + "chainId": 1, + "address": "0x06a6fc23e6ec8a2b2aeeefd70d772dc3d6b45010", + "name": "CryptoProfile", + "symbol": "CP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7350/thumb/CryptoProfile-logo.png?1547044024" + }, + { + "chainId": 1, + "address": "0x441761326490cacf7af299725b6292597ee822c2", + "name": "Unifi Protocol DAO", + "symbol": "UNFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13152/thumb/logo-2.png?1605748967" + }, + { + "chainId": 1, + "address": "0xb57420fad6731b004309d5a0ec7c6c906adb8df7", + "name": "DotOracle", + "symbol": "DTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19527/thumb/84438129.png?1635371187" + }, + { + "chainId": 1, + "address": "0x1856bc58f5511269afe2ca1e89bf08cbdcd01100", + "name": "Black Dragon Society", + "symbol": "BDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28413/thumb/black_dragon_society_logo_200x200.png?1670387609" + }, + { + "chainId": 1, + "address": "0x95ad61b0a150d79219dcf64e1e6cc01f0b64c4ce", + "name": "Shiba Inu", + "symbol": "SHIB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11939/thumb/shiba.png?1622619446" + }, + { + "chainId": 1, + "address": "0x9a1997c130f4b2997166975d9aff92797d5134c2", + "name": "BondAppetite USD", + "symbol": "USDAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14874/thumb/USDap_%281%29.png?1618822197" + }, + { + "chainId": 1, + "address": "0x2260fac5e5542a773aa44fbcfedf7c193bc2c599", + "name": "Wrapped Bitcoin", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7598/thumb/wrapped_bitcoin_wbtc.png?1548822744" + }, + { + "chainId": 1, + "address": "0x9d65ff81a3c488d585bbfb0bfe3c7707c7917f54", + "name": "SSV Network", + "symbol": "SSV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19155/thumb/ssv.png?1638181902" + }, + { + "chainId": 1, + "address": "0xbebdab6da046bc49ffbb61fbd7b33157eb270d05", + "name": "Shard Coin", + "symbol": "SHARD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3527/thumb/8680493537c30f81917d034613b289e9.png?1547038326" + }, + { + "chainId": 1, + "address": "0xf3b9569f82b18aef890de263b84189bd33ebe452", + "name": "A Hunters Dream", + "symbol": "CAW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25130/thumb/x-Logo-color-10x.png?1665831216" + }, + { + "chainId": 1, + "address": "0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359", + "name": "Sai", + "symbol": "SAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1442/thumb/dai.png?1547035520" + }, + { + "chainId": 1, + "address": "0x508df5aa4746be37b5b6a69684dfd8bdc322219d", + "name": "Crafting Finance", + "symbol": "CRF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21559/thumb/tokenlogo.png?1639611564" + }, + { + "chainId": 1, + "address": "0xb2a63a5dd36c91ec2da59b188ff047f66fac122a", + "name": "Alpha Impact", + "symbol": "FOLO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19988/thumb/folo.PNG?1636357322" + }, + { + "chainId": 1, + "address": "0xdab396ccf3d84cf2d07c4454e10c8a6f5b008d2b", + "name": "Goldfinch", + "symbol": "GFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19081/thumb/GOLDFINCH.png?1634369662" + }, + { + "chainId": 1, + "address": "0x998ffe1e43facffb941dc337dd0468d52ba5b48a", + "name": "Rupiah", + "symbol": "IDRT", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/9441/thumb/57421944_1371636006308255_3647136573922738176_n.jpg?1567462531" + }, + { + "chainId": 1, + "address": "0x9ba00d6856a4edf4665bca2c2309936572473b7e", + "name": "Aave USDC v1", + "symbol": "AUSDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/11674/thumb/aUSDC.png?1592546449" + }, + { + "chainId": 1, + "address": "0xe469c4473af82217b30cf17b10bcdb6c8c796e75", + "name": "EXRNchain", + "symbol": "EXRN", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/1049/thumb/exrn.png?1616039914" + }, + { + "chainId": 1, + "address": "0x0bb217e40f8a5cb79adf04e1aab60e5abd0dfc1e", + "name": "SWFTCOIN", + "symbol": "SWFTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2346/thumb/SWFTCoin.jpg?1618392022" + }, + { + "chainId": 1, + "address": "0x1966d718a565566e8e202792658d7b5ff4ece469", + "name": "nDEX", + "symbol": "NDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5576/thumb/nDEX-logo.png?1547041405" + }, + { + "chainId": 1, + "address": "0xfeeeef4d7b4bf3cc8bd012d02d32ba5fd3d51e31", + "name": "Tail", + "symbol": "TAIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28260/thumb/IMG_20221210_122215_723.jpg?1670744910" + }, + { + "chainId": 1, + "address": "0xf5a56bd9ee4a3e2d493ab8e072658794b38b6d19", + "name": "Shibcraft", + "symbol": "SHFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28401/thumb/ShibcraftLogo200x200.png?1670299854" + }, + { + "chainId": 1, + "address": "0xe4e822c0d5b329e8bb637972467d2e313824efa0", + "name": "Dfinance", + "symbol": "XFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14002/thumb/7223.png?1613579385" + }, + { + "chainId": 1, + "address": "0xa0a9c16856c96d5e9d80a8696eea5e02b2dc3398", + "name": "DumpBuster", + "symbol": "GTFO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24344/thumb/logo2.png?1647412138" + }, + { + "chainId": 1, + "address": "0x17ef75aa22dd5f6c2763b8304ab24f40ee54d48a", + "name": "Revolution Populi", + "symbol": "RVP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14772/thumb/vsd0Wnc2_400x400.png?1618369912" + }, + { + "chainId": 1, + "address": "0x3a1311b8c404629e38f61d566cefefed083b9670", + "name": "Piccolo Inu", + "symbol": "PINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19335/thumb/Piccolo-Inu.png?1643191682" + }, + { + "chainId": 1, + "address": "0x98585dfc8d9e7d48f0b1ae47ce33332cf4237d96", + "name": "New Order", + "symbol": "NEWO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21440/thumb/new-order-icon-256px.png?1639125759" + }, + { + "chainId": 1, + "address": "0x095797fd4297fb79883cc912a5ba6313b15c445d", + "name": "GOLCOIN", + "symbol": "GOLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27341/thumb/logo_in_the_middle_.png?1663551501" + }, + { + "chainId": 1, + "address": "0x2ec3275f7ace4044e499823f511cd58250be8e3d", + "name": "Privilege", + "symbol": "PRVG", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27585/thumb/prvg.png?1664701884" + }, + { + "chainId": 1, + "address": "0x33d6064f0dfb62462a74049f30909ddd4f683ba2", + "name": "Serenity", + "symbol": "SEREN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23412/thumb/seren.png?1644151893" + }, + { + "chainId": 1, + "address": "0x22987407fd1fc5a971e3fda3b3e74c88666cda91", + "name": "Smart Reward Token", + "symbol": "SRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25035/thumb/me-44EyS_400x400.jpg?1649852504" + }, + { + "chainId": 1, + "address": "0xae6e307c3fe9e922e5674dbd7f830ed49c014c6b", + "name": "Credefi", + "symbol": "CREDI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21396/thumb/e1QbZ4qQ_400x400.jpg?1639042835" + }, + { + "chainId": 1, + "address": "0xd7c49cee7e9188cca6ad8ff264c1da2e69d4cf3b", + "name": "Nexus Mutual", + "symbol": "NXM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11810/thumb/nexus-mutual.jpg?1594547726" + }, + { + "chainId": 1, + "address": "0xc0eb85285d83217cd7c891702bcbc0fc401e2d9d", + "name": "Hiveterminal", + "symbol": "HVN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/899/thumb/Hiveterminal_token.jpg?1547034726" + }, + { + "chainId": 1, + "address": "0xf063fe1ab7a291c5d06a86e14730b00bf24cb589", + "name": "DxSale Network", + "symbol": "SALE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12250/thumb/dx-light.png?1613965390" + }, + { + "chainId": 1, + "address": "0xda9fdab21bc4a5811134a6e0ba6ca06624e67c07", + "name": "Quidd", + "symbol": "QUIDD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19725/thumb/quidd.png?1637303435" + }, + { + "chainId": 1, + "address": "0x850aab69f0e0171a9a49db8be3e71351c8247df4", + "name": "Konomi Network", + "symbol": "KONO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14406/thumb/konomi.jpg?1615907763" + }, + { + "chainId": 1, + "address": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12504/thumb/uniswap-uni.png?1600306604" + }, + { + "chainId": 1, + "address": "0x6bffa07a1b0cebc474ce6833eaf2be6326252449", + "name": "BAEPAY", + "symbol": "BAEPAY", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/13101/thumb/baepay_logo.png?1605150696" + }, + { + "chainId": 1, + "address": "0x5d858bcd53e085920620549214a8b27ce2f04670", + "name": "POP Network", + "symbol": "POP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7281/thumb/Logo_%28Light_Mode%29_%281%29.png?1644482888" + }, + { + "chainId": 1, + "address": "0x3cbf23c081faa5419810ce0f6bc1ecb73006d848", + "name": "Digible", + "symbol": "DIGI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14960/thumb/RE3Fiua.png?1619148839" + }, + { + "chainId": 1, + "address": "0x19ac2659599fd01c853de846919544276ad26f50", + "name": "Covenant", + "symbol": "COVN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22280/thumb/16837.png?1641364060" + }, + { + "chainId": 1, + "address": "0x1f56ae850930460d076e8c2177d92daa6dd046c3", + "name": "Woof Token", + "symbol": "WOOF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22518/thumb/S2s77NqfYuMOh7r8xno5JmkkeqdX_wMsNlCbKU5on2CWnyd3FHb92aDb15CrVaz1zedzKUqyNcs8V4mXhBsfZqQQkeduUQyj6yVSXAkgTrW8itxKOqn3TMQtip4Ca__DPHuaW_Dyt_TmqYxeeIp6CU-lMFGjUlVPKz6pRFd2r0XRFrei77gK1iddcY6LGy0WdF_6lvdscHVkm-.jpg?1641969715" + }, + { + "chainId": 1, + "address": "0xed35af169af46a02ee13b9d79eb57d6d68c1749e", + "name": "ECOMI", + "symbol": "OMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4428/thumb/ECOMI.png?1557928886" + }, + { + "chainId": 1, + "address": "0x7121d00b4fa18f13da6c2e30d19c04844e6afdc8", + "name": "Luffy", + "symbol": "LUFFY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17736/thumb/LUFFY_LOGO.png?1668675291" + }, + { + "chainId": 1, + "address": "0xe481f2311c774564d517d015e678c2736a25ddd3", + "name": "DefHold", + "symbol": "DEFO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13168/thumb/defhold_logo.png?1605849148" + }, + { + "chainId": 1, + "address": "0x99d36e97676a68313ffdc627fd6b56382a2a08b6", + "name": "Baby Trump", + "symbol": "BABYTRUMP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18014/thumb/Baby_Trump_Transpa.png?1630237728" + }, + { + "chainId": 1, + "address": "0xa92e7c82b11d10716ab534051b271d2f6aef7df5", + "name": "Ara", + "symbol": "ARA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13877/thumb/ara-icon-200.png?1628171321" + }, + { + "chainId": 1, + "address": "0x0dde6f6e345bfd23f3f419f0dfe04e93143b44fb", + "name": "SOTA Finance", + "symbol": "SOTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14067/thumb/sota_logo.png?1614132527" + }, + { + "chainId": 1, + "address": "0xe9615071341c6f0392a5dfde1645ad01b810cb43", + "name": "ShibVinci", + "symbol": "SHIV", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24703/thumb/gk-logo.png?1648645069" + }, + { + "chainId": 1, + "address": "0x19ea630bcbc1a511a16e65b6ecd447c92e1c087c", + "name": "CARAT", + "symbol": "CARAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6434/thumb/carat.png?1547738711" + }, + { + "chainId": 1, + "address": "0x459086f2376525bdceba5bdda135e4e9d3fef5bf", + "name": "renBCH", + "symbol": "RENBCH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11563/thumb/Bitcoin_Cash.jpg?1628072890" + }, + { + "chainId": 1, + "address": "0xbaa70614c7aafb568a93e62a98d55696bcc85dfe", + "name": "Unicap Finance", + "symbol": "UCAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13300/thumb/unicap256.png?1607308439" + }, + { + "chainId": 1, + "address": "0xd7dcd9b99787c619b4d57979521258d1a7267ad7", + "name": "Evrynet", + "symbol": "EVRY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19194/thumb/evry.png?1634637970" + }, + { + "chainId": 1, + "address": "0xc719d010b63e5bbf2c0551872cd5316ed26acd83", + "name": "Etherisc DIP", + "symbol": "DIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4586/thumb/dip.png?1547039863" + }, + { + "chainId": 1, + "address": "0xe33ae4e795114279721047484e5ad5cc7df24fcb", + "name": "MCFinance", + "symbol": "MCF", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/17608/thumb/arFRQ0b.png?1628650181" + }, + { + "chainId": 1, + "address": "0xbbbbca6a901c926f240b89eacb641d8aec7aeafd", + "name": "Loopring", + "symbol": "LRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/913/thumb/LRC.png?1572852344" + }, + { + "chainId": 1, + "address": "0x3d1f5e133c2988d14a0c13bdd2b58d260e74ef9a", + "name": "Omega Finance", + "symbol": "OMG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26511/thumb/1D23BCAF-AD7E-4176-B652-DFC5AE943191.png?1658448874" + }, + { + "chainId": 1, + "address": "0xcb0d82f4dfa503c9e3b8abc7a3caa01175b2da39", + "name": "AurusX", + "symbol": "AX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27871/thumb/AurusX_token_2D.jpg?1666165444" + }, + { + "chainId": 1, + "address": "0xf2cdf38e24738ba379ffa38d47bc88a941df5627", + "name": "Ally", + "symbol": "ALY", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/9619/thumb/BTf_sTXi_400x400.jpg?1569854715" + }, + { + "chainId": 1, + "address": "0x6369c3dadfc00054a42ba8b2c09c48131dd4aa38", + "name": "Morpher", + "symbol": "MPH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12619/thumb/morpher_200_200.png?1601524084" + }, + { + "chainId": 1, + "address": "0x043827a6dcfffb7fe21953d3bad32a1c74bb73bf", + "name": "JPEX Coin", + "symbol": "JPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27717/thumb/200_200_JPEX_LOGO_transparent.png?1665453898" + }, + { + "chainId": 1, + "address": "0xfb19075d77a0f111796fb259819830f4780f1429", + "name": "Fenerbah e", + "symbol": "FB", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/17711/thumb/FB_Logo.png?1629082961" + }, + { + "chainId": 1, + "address": "0x979aca85ba37c675e78322ed5d97fa980b9bdf00", + "name": "FUSION", + "symbol": "FSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2515/thumb/Fusion_200x200.png?1639629907" + }, + { + "chainId": 1, + "address": "0xcfeb09c3c5f0f78ad72166d55f9e6e9a60e96eec", + "name": "vEmpire DDAO", + "symbol": "VEMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18074/thumb/Ay5nuny.png?1630380510" + }, + { + "chainId": 1, + "address": "0x616ef40d55c0d2c506f4d6873bda8090b79bf8fc", + "name": "Kounotori", + "symbol": "KTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21251/thumb/KTO.png?1650528876" + }, + { + "chainId": 1, + "address": "0x8064d9ae6cdf087b1bcd5bdf3531bd5d8c537a68", + "name": "BoringDAO BTC", + "symbol": "OBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13525/thumb/gWzm2dr.png?1609390713" + }, + { + "chainId": 1, + "address": "0x3c9d6c1c73b31c837832c72e04d3152f051fc1a9", + "name": "BoringDAO OLD ", + "symbol": "BOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12917/thumb/bor_logo.png?1603607502" + }, + { + "chainId": 1, + "address": "0x903904cb39bac33d4983ead3b3f573d720c7965e", + "name": "Dogus", + "symbol": "DOGUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19196/thumb/rsZ3wmA.png?1634643309" + }, + { + "chainId": 1, + "address": "0x9275e8386a5bdda160c0e621e9a6067b8fd88ea2", + "name": "Nobunaga", + "symbol": "NBNG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16798/thumb/nbng.jpeg?1625056917" + }, + { + "chainId": 1, + "address": "0xf6650117017ffd48b725b4ec5a00b414097108a7", + "name": "Xido Finance", + "symbol": "XIDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16161/thumb/KJw4clj.png?1623141959" + }, + { + "chainId": 1, + "address": "0x7dac25b1a665e1c70f25f1fc37d88c99274984ed", + "name": "Shibnobi", + "symbol": "SHINJA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20545/thumb/SibnoboMainIcon3_3x.png?1670664729" + }, + { + "chainId": 1, + "address": "0x4691937a7508860f876c9c0a2a617e7d9e945d4b", + "name": "WOO Network", + "symbol": "WOO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12921/thumb/w2UiemF__400x400.jpg?1603670367" + }, + { + "chainId": 1, + "address": "0xe83d5fb2c60b3a2597452e248cf7b2f52a7e731e", + "name": "ARTIC Foundation", + "symbol": "ARTIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24279/thumb/Artic_logo_02.png?1647181452" + }, + { + "chainId": 1, + "address": "0x13119e34e140097a507b07a5564bde1bc375d9e6", + "name": "Money IMT", + "symbol": "IMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2955/thumb/imt.png?1547037191" + }, + { + "chainId": 1, + "address": "0x4618519de4c304f3444ffa7f812dddc2971cc688", + "name": "Kind Ads", + "symbol": "KIND", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5302/thumb/kind-ads-token.png?1547975306" + }, + { + "chainId": 1, + "address": "0x49e833337ece7afe375e44f4e3e8481029218e5c", + "name": "Value DeFi", + "symbol": "VALUE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12525/thumb/value_logo_-_500x500.png?1601478115" + }, + { + "chainId": 1, + "address": "0xe48972fcd82a274411c01834e2f031d4377fa2c0", + "name": "2key network", + "symbol": "2KEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6090/thumb/2key.png?1591591830" + }, + { + "chainId": 1, + "address": "0x60f5672a271c7e39e787427a18353ba59a4a3578", + "name": "Pika", + "symbol": "PIKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14419/thumb/pika-logo-2022-nbg.png?1641971069" + }, + { + "chainId": 1, + "address": "0xbd2f0cd039e0bfcf88901c98c0bfac5ab27566e3", + "name": "Dynamic Set Dollar", + "symbol": "DSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13249/thumb/DSD.jpg?1606713628" + }, + { + "chainId": 1, + "address": "0xa808b22ffd2c472ad1278088f16d4010e6a54d5f", + "name": "Reimagined Finance", + "symbol": "REFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21543/thumb/refi.PNG?1639451123" + }, + { + "chainId": 1, + "address": "0xa918897bd10d6dee614470c24a061b78b021b3a9", + "name": "Universal Coin", + "symbol": "UCOIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13650/thumb/UCOIN_LOGO-min.png?1610549326" + }, + { + "chainId": 1, + "address": "0xc3f65b1c45b0d42a472cd0fbd37dd6678aef667a", + "name": "Cinnamoon", + "symbol": "CIMO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28465/thumb/D7287693-BFD2-4E5B-9A52-BBA8749F2B7D.png?1670911437" + }, + { + "chainId": 1, + "address": "0x1b5036bec1b82d44d52fa953a370b3c6cd9328b5", + "name": "Elan", + "symbol": "ELAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27635/thumb/%D0%97%D0%BD%D1%96%D0%BC%D0%BE%D0%BA_%D0%B5%D0%BA%D1%80%D0%B0%D0%BD%D0%B0_2022-10-04_%D0%BE_17.23.34.png?1664961737" + }, + { + "chainId": 1, + "address": "0xeb6026d3beaa308d5822c44cdd2ca8c7714237ec", + "name": "All Sports", + "symbol": "SOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25629/thumb/auC_SL79_400x400.jpg?1652863712" + }, + { + "chainId": 1, + "address": "0xcbee6459728019cb1f2bb971dde2ee3271bc7617", + "name": "WemergeToken", + "symbol": "MRG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6833/thumb/wemerge200.png?1547043144" + }, + { + "chainId": 1, + "address": "0x657b83a0336561c8f64389a6f5ade675c04b0c3b", + "name": "Playcent", + "symbol": "PCNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14335/thumb/1_B5bFcgBld5poUj_c-_K1Jw.png?1615444831" + }, + { + "chainId": 1, + "address": "0x6d60a8dfb16d09f67d46fcd36a0cd310078257ca", + "name": "Centurion Invest", + "symbol": "CIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28483/thumb/PHOTO-2022-05-27-11-34-42.jpg?1671073667" + }, + { + "chainId": 1, + "address": "0xe5b826ca2ca02f09c1725e9bd98d9a8874c30532", + "name": "ZEON Network", + "symbol": "ZEON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4247/thumb/XZqXYc2j_400x400.jpg?1547039580" + }, + { + "chainId": 1, + "address": "0x1e053d89e08c24aa2ce5c5b4206744dc2d7bd8f5", + "name": "ThunderCore", + "symbol": "TT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4375/thumb/ThunderCore_Logo_Mark_Gradient_%283%29.png?1650455349" + }, + { + "chainId": 1, + "address": "0x260e63d91fccc499606bae3fe945c4ed1cf56a56", + "name": "MoonTools", + "symbol": "MOONS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12793/thumb/moontools-token-logo.png?1602588060" + }, + { + "chainId": 1, + "address": "0x315dc1b524de57ae8e809a2e97699dbc895b8a21", + "name": "Pist Trust", + "symbol": "PIST", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16397/thumb/main_img01_pc.png?1623910650" + }, + { + "chainId": 1, + "address": "0x8b79656fc38a04044e495e22fad747126ca305c4", + "name": "AgaveCoin", + "symbol": "AGVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7056/thumb/G4TML4cb_400x400.jpg?1547043511" + }, + { + "chainId": 1, + "address": "0x1e9d0bb190ac34492aa11b80d28c1c86487a341f", + "name": "The Neko", + "symbol": "NEKO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22692/thumb/FL6SU9b5_400x400.jpg?1642409749" + }, + { + "chainId": 1, + "address": "0xc9b6a17ebb43491635f603a01f8bb3e4b5d22228", + "name": "MAGA Coin ETH", + "symbol": "MAGA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27455/thumb/rsz_jimerkya_400x400.png?1664090952" + }, + { + "chainId": 1, + "address": "0x320d31183100280ccdf69366cd56180ea442a3e8", + "name": "Lightcoin", + "symbol": "LHC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/16381/thumb/lhc.PNG?1623835248" + }, + { + "chainId": 1, + "address": "0xcbe7142f5c16755d8683ba329efa1abf7b54482d", + "name": "MedicalVeda", + "symbol": "MVEDA", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13069/thumb/medicalveda_new_logo_final_%281%29.png?1604894690" + }, + { + "chainId": 1, + "address": "0x73a058da53220d25bcb2c4cb8ff8520626ea26e7", + "name": "Scro", + "symbol": "SCROH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26882/thumb/SCRO.png?1660646485" + }, + { + "chainId": 1, + "address": "0x35156b404c3f9bdaf45ab65ba315419bcde3775c", + "name": "Chihiro Inu", + "symbol": "CHIRO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19721/thumb/chiro200x200.png?1642166355" + }, + { + "chainId": 1, + "address": "0x9f6f91078a5072a8b54695dafa2374ab3ccd603b", + "name": "KRAUSE", + "symbol": "KRAUSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21022/thumb/-HEQTtGz_400x400.png?1638193269" + }, + { + "chainId": 1, + "address": "0x32c4adb9cf57f972bc375129de91c897b4f364f1", + "name": "Flowchain", + "symbol": "FLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7446/thumb/logo_%2889%29.png?1597459811" + }, + { + "chainId": 1, + "address": "0x4cd4441f169e472dd7ea462167ba93180b6e6074", + "name": "CURE Chain", + "symbol": "CHAIN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27291/thumb/cure_chain_logo.png?1663147515" + }, + { + "chainId": 1, + "address": "0xfec82a1b2638826bfe53ae2f87cfd94329cde60d", + "name": "Adana Demirspor", + "symbol": "DEMIR", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/21789/thumb/16300.png?1640051015" + }, + { + "chainId": 1, + "address": "0x6d1dc3928604b00180bb570bdae94b9698d33b79", + "name": "UnitedCrowd", + "symbol": "UCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14956/thumb/eUvRU9wm.png?1619142511" + }, + { + "chainId": 1, + "address": "0x7f3141c4d6b047fb930991b450f1ed996a51cb26", + "name": "X", + "symbol": "X", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22334/thumb/x.PNG?1641519663" + }, + { + "chainId": 1, + "address": "0x2af72850c504ddd3c1876c66a914caee7ff8a46a", + "name": "WhaleRoom", + "symbol": "WHL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14328/thumb/ArEX8tkV_400x400.png?1615432175" + }, + { + "chainId": 1, + "address": "0xe87e15b9c7d989474cb6d8c56b3db4efad5b21e8", + "name": "Hokkaido Inu", + "symbol": "HOKK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14985/thumb/hokk.png?1662706232" + }, + { + "chainId": 1, + "address": "0xef19f4e48830093ce5bc8b3ff7f903a0ae3e9fa1", + "name": "BOTXCOIN", + "symbol": "BOTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6827/thumb/botx.jpg?1548317786" + }, + { + "chainId": 1, + "address": "0xb56a1f3310578f23120182fb2e58c087efe6e147", + "name": "All Coins Yield Capital", + "symbol": "ACYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21109/thumb/acyc.png?1639990309" + }, + { + "chainId": 1, + "address": "0xc4ee0aa2d993ca7c9263ecfa26c6f7e13009d2b6", + "name": "Hoichi", + "symbol": "HOICHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27227/thumb/3dBs4VvW_400x400.jpeg?1662711951" + }, + { + "chainId": 1, + "address": "0xd0660cd418a64a1d44e9214ad8e459324d8157f1", + "name": "Woofy", + "symbol": "WOOFY", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/15410/thumb/woofy.png?1622566328" + }, + { + "chainId": 1, + "address": "0x3a3a65aab0dd2a17e3f1947ba16138cd37d08c04", + "name": "Aave ETH v1", + "symbol": "AETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11619/thumb/aETH_2x.png?1591976597" + }, + { + "chainId": 1, + "address": "0xc0114f14638a333a4d5c3b04f09b96372348a842", + "name": "Keisuke Inu", + "symbol": "KEI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15797/thumb/realicon.png?1628170332" + }, + { + "chainId": 1, + "address": "0x4289c043a12392f1027307fb58272d8ebd853912", + "name": "AiLink", + "symbol": "ALI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5917/thumb/ailink-token.png?1547041855" + }, + { + "chainId": 1, + "address": "0x368c5290b13caa10284db58b4ad4f3e9ee8bf4c9", + "name": "KKO Protocol", + "symbol": "KKO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15366/thumb/kko-coingecko.png?1658982821" + }, + { + "chainId": 1, + "address": "0x9b5c2be869a19e84bdbcb1386dad83a2ec8dae82", + "name": "Stream Protocol", + "symbol": "STPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13277/thumb/STPL.png?1606897574" + }, + { + "chainId": 1, + "address": "0x159a1dfae19057de57dfffcbb3da1ae784678965", + "name": "Reflex", + "symbol": "RFX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12745/thumb/2MKGMRCT_400x400.png?1602194456" + }, + { + "chainId": 1, + "address": "0xc1322d8ae3b0e2e437e0ae36388d0cfd2c02f1c9", + "name": "DAO PlayMarket 2 0", + "symbol": "PMT", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/1514/thumb/pmt.png?1547035648" + }, + { + "chainId": 1, + "address": "0x142a774e8b52550e88e196cedd7a5835acb646d0", + "name": "SaitaRealty", + "symbol": "SRLTY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27289/thumb/s_mksCdB_400x400.jpeg?1663145048" + }, + { + "chainId": 1, + "address": "0x6888a16ea9792c15a4dcf2f6c623d055c8ede792", + "name": "Signal SIG", + "symbol": "SIG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3508/thumb/5906667d95a2d43d31378ce7_60x60logo.png?1547038276" + }, + { + "chainId": 1, + "address": "0x03cf23efdb2a6cf6cf6eb8b5a3383966f5c6b6d5", + "name": "YAKUSHIMA", + "symbol": "FOREST", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26984/thumb/photo_2022-08-20_23-40-23.jpg?1661181326" + }, + { + "chainId": 1, + "address": "0x0ab87046fbb341d058f17cbc4c1133f25a20a52f", + "name": "Governance OHM", + "symbol": "GOHM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21129/thumb/token_wsOHM_logo.png?1638764900" + }, + { + "chainId": 1, + "address": "0x3684b581db1f94b721ee0022624329feb16ab653", + "name": "GUNTHY", + "symbol": "GUNTHY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7869/thumb/GUNTHY_128.png?1562130711" + }, + { + "chainId": 1, + "address": "0xea068fba19ce95f12d252ad8cb2939225c4ea02d", + "name": "Fief", + "symbol": "FIEF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23710/thumb/61f837d2703b649ab0213d45_Black_logo_-_no_background-p-500.png?1645083867" + }, + { + "chainId": 1, + "address": "0xb7c2fcd6d7922eddd2a7a9b0524074a60d5b472c", + "name": "VentiSwap", + "symbol": "VST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25591/thumb/output-onlinepngtools-2_2.png?1652862384" + }, + { + "chainId": 1, + "address": "0xcbfa5f7e44d7cd08666766c2935e2fdaa953178f", + "name": "Meta Farmer Finance", + "symbol": "MFF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23800/thumb/RGJiUIeo_400x400.jpg?1645442711" + }, + { + "chainId": 1, + "address": "0x28cca76f6e8ec81e4550ecd761f899110b060e97", + "name": "ArGoApp", + "symbol": "ARGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15477/thumb/Group_118.png?1647877401" + }, + { + "chainId": 1, + "address": "0x64b78325d7495d6d4be92f234fa3f3b8d8964b8b", + "name": "Shopping io", + "symbol": "SHOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27242/thumb/shop.png?1663123573" + }, + { + "chainId": 1, + "address": "0x1bbf25e71ec48b84d773809b4ba55b6f4be946fb", + "name": "Vow", + "symbol": "VOW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18202/thumb/72Nd63R0_400x400.png?1630974351" + }, + { + "chainId": 1, + "address": "0x0aa7efe4945db24d95ca6e117bba65ed326e291a", + "name": "Ojamu", + "symbol": "OJA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18947/thumb/ojamu-icon-PNK.png?1634006741" + }, + { + "chainId": 1, + "address": "0x26524e35e44e265eb181c7ba6ec084983181aae3", + "name": "Cydotori", + "symbol": "DOTR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28109/thumb/dotr.png?1667545446" + }, + { + "chainId": 1, + "address": "0xa5b947687163fe88c3e6af5b17ae69896f4abccf", + "name": "Poseidon", + "symbol": "PSDN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25316/thumb/psdn_32.png?1651216148" + }, + { + "chainId": 1, + "address": "0x2ebd53d035150f328bd754d6dc66b99b0edb89aa", + "name": "Metronome", + "symbol": "MET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3249/thumb/metronome.png?1548084800" + }, + { + "chainId": 1, + "address": "0x1f0f468ee03a6d99cd8a09dd071494a83dc1c0e5", + "name": "SmartX", + "symbol": "SAT", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/11788/thumb/FZf8lPa3_400x400.jpg?1594018352" + }, + { + "chainId": 1, + "address": "0x0763fdccf1ae541a5961815c0872a8c5bc6de4d7", + "name": "SUKU", + "symbol": "SUKU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11969/thumb/suku-200.png?1655447745" + }, + { + "chainId": 1, + "address": "0x4e15361fd6b4bb609fa63c81a2be19d873717870", + "name": "Fantom", + "symbol": "FTM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4001/thumb/Fantom_round.png?1669652346" + }, + { + "chainId": 1, + "address": "0x6b1a8f210ec6b7b6643cea3583fb0c079f367898", + "name": "Baanx", + "symbol": "BXX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17108/thumb/BXX_Token_logo.png?1626311836" + }, + { + "chainId": 1, + "address": "0x3506424f91fd33084466f402d5d97f05f8e3b4af", + "name": "Chiliz", + "symbol": "CHZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8834/thumb/Chiliz.png?1561970540" + }, + { + "chainId": 1, + "address": "0x765baefcb5418fa9f7dddacb1ccc07bd0e890e4e", + "name": "Meteorite Network", + "symbol": "METEOR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14889/thumb/Meteor-token-200.png?1618900489" + }, + { + "chainId": 1, + "address": "0x4b1d0b9f081468d780ca1d5d79132b64301085d1", + "name": "Lumerin", + "symbol": "LMR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/24593/thumb/Lumerin-icon.png?1650688090" + }, + { + "chainId": 1, + "address": "0x08aa0ed0040736dd28d4c8b16ab453b368248d19", + "name": "Cryptobuyer", + "symbol": "XPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10845/thumb/XPT.png?1584775672" + }, + { + "chainId": 1, + "address": "0xc19b6a4ac7c7cc24459f08984bbd09664af17bd1", + "name": "SENSO", + "symbol": "SENSO", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/11064/thumb/senso.png?1587776458" + }, + { + "chainId": 1, + "address": "0x430ef9263e76dae63c84292c3409d61c598e9682", + "name": "Vulcan Forged", + "symbol": "PYR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14770/thumb/1617088937196.png?1619414736" + }, + { + "chainId": 1, + "address": "0x5a56da75c50aa2733f5fa9a2442aaefcbc60b2e6", + "name": "CortexDAO", + "symbol": "CXD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25224/thumb/cortex.jpg?1650979502" + }, + { + "chainId": 1, + "address": "0x7a5ce6abd131ea6b148a022cb76fc180ae3315a6", + "name": "bAlpha", + "symbol": "BALPHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14224/thumb/logo_bAlpha_200.png?1615089190" + }, + { + "chainId": 1, + "address": "0x7a9716685f852ee268feb86dffa562d214cc13db", + "name": "FANBI TOKEN", + "symbol": "FBT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/9828/thumb/logo1_%281%29.png?1572472211" + }, + { + "chainId": 1, + "address": "0xc07a150ecadf2cc352f5586396e344a6b17625eb", + "name": "Bio Passport", + "symbol": "BIOT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14167/thumb/logo_%2895%29.png?1614753428" + }, + { + "chainId": 1, + "address": "0x40eb746dee876ac1e78697b7ca85142d178a1fc8", + "name": "Iagon", + "symbol": "IAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3264/thumb/d8c5hLbX9u0GwYCKcZRbXS2vAQ0Vd-Hfjg-3zQ73ucSZQoFYsLH4NEKN8EQkwwBVR8OPJgrTRG-_dW_XVHL058ezYSvwsSB4bjYtHH7xjZNHBaAaX1NZl7axG8zm2FIRV6AUmgdmxcbP0BcuWvUJkcUKrYYEDf0Msx2_3arxgmS1V85YMb_1SVbWt6E3QnkpvLcGyC0SxN6rGTr.jpg?1627448798" + }, + { + "chainId": 1, + "address": "0xd6bd97a26232ba02172ff86b055d5d7be789335b", + "name": "Ormeus Cash", + "symbol": "OMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11798/thumb/Vooo8SX.png?1594359387" + }, + { + "chainId": 1, + "address": "0xf07376f0e3bff57116ed62e5e8e2bb1341e4b4c2", + "name": "JoorsChain", + "symbol": "JIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7128/thumb/H0kIwyNs_400x400.jpg?1547043626" + }, + { + "chainId": 1, + "address": "0xe44d9f88c84af1765b48bab1d09c0d9c39b01056", + "name": "Defun Gaming", + "symbol": "DEFUN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27906/thumb/trans.png?1666335908" + }, + { + "chainId": 1, + "address": "0xc36824905dff2eaaee7ecc09fcc63abc0af5abc5", + "name": "Basis Bond", + "symbol": "BAB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13961/thumb/bab_1.png?1613358492" + }, + { + "chainId": 1, + "address": "0xbd2949f67dcdc549c6ebe98696449fa79d988a9f", + "name": "Meter Governance mapped by Meter io", + "symbol": "EMTRG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12175/thumb/Dark-blue-icon-transparent-vector-white-icon200x200.png?1597819237" + }, + { + "chainId": 1, + "address": "0x191557728e4d8caa4ac94f86af842148c0fa8f7e", + "name": "Ormeus Ecosystem", + "symbol": "ECO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8923/thumb/logo_eco_low.png?1562902804" + }, + { + "chainId": 1, + "address": "0xbc6da0fe9ad5f3b0d58160288917aa56653660e9", + "name": "Alchemix USD", + "symbol": "ALUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14114/thumb/Alchemix_USD.png?1614410406" + }, + { + "chainId": 1, + "address": "0xb59490ab09a0f526cc7305822ac65f2ab12f9723", + "name": "Litentry", + "symbol": "LIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13825/thumb/logo_200x200.png?1612153317" + }, + { + "chainId": 1, + "address": "0xefe2afb5f2a9ea8ec6d8a57fe88febcfe29db813", + "name": "bUKHI", + "symbol": "BUKH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18401/thumb/bukh_new.png?1632739515" + }, + { + "chainId": 1, + "address": "0x6e765d26388a17a6e86c49a8e41df3f58abcd337", + "name": "Kangal", + "symbol": "KANGAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14241/thumb/logo-200.png?1622341641" + }, + { + "chainId": 1, + "address": "0x3a856d4effa670c54585a5d523e96513e148e95d", + "name": "TriasLab", + "symbol": "TRIAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13963/thumb/5ELqtwp__400x400_%281%29.jpg?1613527958" + }, + { + "chainId": 1, + "address": "0x047686fb287e7263a23873dea66b4501015a2226", + "name": "Blockchain Cuties Universe", + "symbol": "CUTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8328/thumb/bnLvIEl1_400x400.jpg?1557533240" + }, + { + "chainId": 1, + "address": "0xfa898efdb91e35bd311c45b9b955f742b6719aa2", + "name": "Baddest Alpha Ape Bundle", + "symbol": "APED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18874/thumb/bteKOcAH_400x400.jpg?1633658256" + }, + { + "chainId": 1, + "address": "0x4a220e6096b25eadb88358cb44068a3248254675", + "name": "Quant", + "symbol": "QNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3370/thumb/5ZOu7brX_400x400.jpg?1612437252" + }, + { + "chainId": 1, + "address": "0x74be64b45d394fa57816c1950e94dbb8d7a7b306", + "name": "Givewell Inu", + "symbol": "GINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28323/thumb/5FADC518-3EE8-4914-A627-602B9C3FAFB4.jpeg?1669445878" + }, + { + "chainId": 1, + "address": "0x5f0e628b693018f639d10e4a4f59bd4d8b2b6b44", + "name": "Whiteheart", + "symbol": "WHITE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13484/thumb/whiteheart.png?1609076548" + }, + { + "chainId": 1, + "address": "0x9cf4679c67bee8da2d6f58c64592fff6bee79330", + "name": "Yearn Cash", + "symbol": "YFIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24777/thumb/yfic.png?1648900564" + }, + { + "chainId": 1, + "address": "0xb26631c6dda06ad89b93c71400d25692de89c068", + "name": "Minds", + "symbol": "MINDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11517/thumb/Minds.png?1590580465" + }, + { + "chainId": 1, + "address": "0xa95c5ebb86e0de73b4fb8c47a45b792cfea28c23", + "name": "stake link", + "symbol": "SDL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28406/thumb/stake.png?1670334146" + }, + { + "chainId": 1, + "address": "0x9cb1aeafcc8a9406632c5b084246ea72f62d37b6", + "name": "LBK", + "symbol": "LBK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9492/thumb/lbk.jpeg?1586144855" + }, + { + "chainId": 1, + "address": "0x6bd361e10c1afed0d95259e7c0115f3a60e4ea99", + "name": "BollyCoin", + "symbol": "BOLLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21610/thumb/IMG-20211208-124337-701.jpg?1639579540" + }, + { + "chainId": 1, + "address": "0xba1ed22c69ad00739ee2b4abd70e270be9e87ee2", + "name": "WebFlix", + "symbol": "WFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8559/thumb/dr4OEbWK_400x400.jpg?1559199557" + }, + { + "chainId": 1, + "address": "0xd1b5651e55d4ceed36251c61c50c889b36f6abb5", + "name": "Stake DAO CRV", + "symbol": "SDCRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27756/thumb/scCRV-2.png?1665654580" + }, + { + "chainId": 1, + "address": "0xad5fe5b0b8ec8ff4565204990e4405b2da117d8e", + "name": "TronClassic", + "symbol": "TRXC", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/4626/thumb/trxc.png?1547039893" + }, + { + "chainId": 1, + "address": "0x3449fc1cd036255ba1eb19d65ff4ba2b8903a69a", + "name": "Basis Cash", + "symbol": "BAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13246/thumb/BAC.png?1613231642" + }, + { + "chainId": 1, + "address": "0x24b47299e756af0571f512232a3629e0dabb52ed", + "name": "concertVR", + "symbol": "CVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2914/thumb/cvt.png?1547037094" + }, + { + "chainId": 1, + "address": "0x35e78b3982e87ecfd5b3f3265b601c046cdbe232", + "name": "SideShift", + "symbol": "XAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15719/thumb/sideshift-icon_3x.png?1621595183" + }, + { + "chainId": 1, + "address": "0xffe136de12a2cd95f64cef9f36414c93e9003959", + "name": "DUCK Vault NFTX ", + "symbol": "DUCK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18346/thumb/duck.png?1631603088" + }, + { + "chainId": 1, + "address": "0x33d20575f20c6a1881f8ab08e69f6fbaffaeedf2", + "name": "BlueWizard", + "symbol": "WIZ", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/15261/thumb/BW.jpg?1620270880" + }, + { + "chainId": 1, + "address": "0x8dd4228605e467671941ffb4cae15cf7959c8d9d", + "name": "Ziticoin", + "symbol": "ZITI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15255/thumb/logo200x200_%284%29.png?1620267412" + }, + { + "chainId": 1, + "address": "0x34bdf48a8f753de4822a6cfb1fee275f9b4d662e", + "name": "FACTS", + "symbol": "BKC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8461/thumb/sFNOkmVx_400x400.jpg?1558690624" + }, + { + "chainId": 1, + "address": "0xf4d2888d29d722226fafa5d9b24f9164c092421e", + "name": "LooksRare", + "symbol": "LOOKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22173/thumb/circle-black-256.png?1641173160" + }, + { + "chainId": 1, + "address": "0x878cf148ccbb50426043a9affe54ba408221c7fa", + "name": "Crypto Kombat", + "symbol": "KOMBAT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15147/thumb/Kombat-token-logo-200.jpg?1619859575" + }, + { + "chainId": 1, + "address": "0x74faab6986560fd1140508e4266d8a7b87274ffd", + "name": "HyperDAO", + "symbol": "HDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10780/thumb/B7-ppPfE_400x400.png?1583467291" + }, + { + "chainId": 1, + "address": "0x6fb1e018f107d3352506c23777e4cd62e063584a", + "name": "Identity", + "symbol": "IDTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18384/thumb/identity.PNG?1631745919" + }, + { + "chainId": 1, + "address": "0x763fa6806e1acf68130d2d0f0df754c93cc546b2", + "name": "Lition", + "symbol": "LIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6580/thumb/Lition_ico.png?1547042787" + }, + { + "chainId": 1, + "address": "0x5d285f735998f36631f678ff41fb56a10a4d0429", + "name": "MixMarvel", + "symbol": "MIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8222/thumb/8878caf93b1e3b6cfb3b414bda3b5250.png?1613945432" + }, + { + "chainId": 1, + "address": "0x5dced3c2fab61e21b25177c6050d3f166f696110", + "name": "Tea", + "symbol": "TEA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14426/thumb/teachain-logo.png?1616031044" + }, + { + "chainId": 1, + "address": "0xa1a4e303e9c56962f201c5e834abc1e677a3c4f3", + "name": "CVNX", + "symbol": "CVNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/862/thumb/CVNX-logo.png?1649528798" + }, + { + "chainId": 1, + "address": "0x0f612a09ead55bb81b6534e80ed5a21bf0a27b16", + "name": "EUNOMIA", + "symbol": "ENTS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6524/thumb/eunomia.png?1548125623" + }, + { + "chainId": 1, + "address": "0x57b946008913b82e4df85f501cbaed910e58d26c", + "name": "Marlin", + "symbol": "POND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8903/thumb/POND_200x200.png?1622515451" + }, + { + "chainId": 1, + "address": "0xb3e2cb7cccfe139f8ff84013823bf22da6b6390a", + "name": "Iconic ICNQ", + "symbol": "ICNQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7830/thumb/2_Iconic_Holding_icon.png?1593396172" + }, + { + "chainId": 1, + "address": "0x7ff7a55a7c637e3953ab25569c335e04b96c475b", + "name": "Kondux OLD ", + "symbol": "KNDX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16987/thumb/bzYx6E41zeLl2gopOj9UqNmIdFgrGU2zSA.jpeg?1646104675" + }, + { + "chainId": 1, + "address": "0x85ffb35957203dfd12061eaecd708db623bd567c", + "name": "Ledgity", + "symbol": "LTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17939/thumb/ledgity.PNG?1629876428" + }, + { + "chainId": 1, + "address": "0x580c8520deda0a441522aeae0f9f7a5f29629afa", + "name": "Dawn Protocol", + "symbol": "DAWN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11555/thumb/dawn_protocol.png?1591060256" + }, + { + "chainId": 1, + "address": "0x10f44a834097469ac340592d28c479c442e99bfe", + "name": "Alcazar", + "symbol": "ALCAZAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28010/thumb/Alcazar.jpeg?1666943350" + }, + { + "chainId": 1, + "address": "0x6c58ee9794882c608e6015bde2802412b3d1377e", + "name": "Inescoin", + "symbol": "INES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26537/thumb/Piece_face_inescoin_1_3_bryefr.png?1658720155" + }, + { + "chainId": 1, + "address": "0x5552e5a89a70cb2ef5adbbc45a6be442fe7160ec", + "name": "Kawakami", + "symbol": "KAWA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16369/thumb/kawakami-2022-red-logo.png?1665374338" + }, + { + "chainId": 1, + "address": "0xdb298285fe4c5410b05390ca80e8fbe9de1f259b", + "name": "handle fi", + "symbol": "FOREX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18533/thumb/handle.fiFOREXLogoDark200x200.png?1632755675" + }, + { + "chainId": 1, + "address": "0x30cf203b48edaa42c3b4918e955fed26cd012a3f", + "name": "MetaGame", + "symbol": "SEED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13099/thumb/V8phEz8V.png?1612854078" + }, + { + "chainId": 1, + "address": "0x06874f973dc3c96dc22a10ef0d0609f877f335ea", + "name": "STOA Network", + "symbol": "STA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16710/thumb/RSloE6X1_400x400.jpeg?1624684021" + }, + { + "chainId": 1, + "address": "0xa8006e3ac1bd94e54e3136b8e5dd75db0163e6f4", + "name": "EveryonesCrypto", + "symbol": "EOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13081/thumb/logo_blue.png?1604976930" + }, + { + "chainId": 1, + "address": "0xf88951d7b676798705fd3a362ba5b1dbca2b233b", + "name": "Piction Network", + "symbol": "PXL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7870/thumb/4091.png?1562798644" + }, + { + "chainId": 1, + "address": "0x5ddafa0856f883a634051dcb4dd710863d85a0c1", + "name": "IlliquidDAO", + "symbol": "JPEGS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22498/thumb/sXd3uwVJ_400x400.png?1641951772" + }, + { + "chainId": 1, + "address": "0x89d3c0249307ae570a316030764d12f53bb191fd", + "name": "Xiglute Coin", + "symbol": "XGC", + "decimals": 14, + "logoURI": "https://assets.coingecko.com/coins/images/15240/thumb/256x256_%282%29.png?1620196016" + }, + { + "chainId": 1, + "address": "0x70e67ec0939ec87c3a77b089ca08e0443ea4a177", + "name": "Immortal Cat", + "symbol": "ICC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26397/thumb/l4P_a2cv_400x400.png?1657753905" + }, + { + "chainId": 1, + "address": "0xcc1f757e3fa67b70e761c71f4b75b1e9f72263af", + "name": "GET", + "symbol": "GET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27210/thumb/LOGO_%281%29.jpeg?1662609050" + }, + { + "chainId": 1, + "address": "0xa4ef4b0b23c1fc81d3f9ecf93510e64f58a4a016", + "name": "1MillionNFTs", + "symbol": "1MIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14990/thumb/4kQ8hRnU_400x400.jpg?1619334818" + }, + { + "chainId": 1, + "address": "0x41a3dba3d677e573636ba691a70ff2d606c29666", + "name": "BlockWallet", + "symbol": "BLANK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14209/thumb/blank.png?1614940842" + }, + { + "chainId": 1, + "address": "0xff19138b039d938db46bdda0067dc4ba132ec71c", + "name": "Snetwork", + "symbol": "SNET", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5382/thumb/snetwork.png?1548609904" + }, + { + "chainId": 1, + "address": "0x1788430620960f9a70e3dc14202a3a35dde1a316", + "name": "OpenAlexa Protocol", + "symbol": "OAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12400/thumb/256x256-OAP.png?1599556701" + }, + { + "chainId": 1, + "address": "0x0ccd5dd52dee42b171a623478e5261c1eaae092a", + "name": "DeFi on MCW", + "symbol": "DFM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13831/thumb/logo_200x200_%281%29.png?1612168790" + }, + { + "chainId": 1, + "address": "0x024b6e7dc26f4d5579bdd936f8d7bc31f2339999", + "name": "Mithril Share", + "symbol": "MIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13516/thumb/MIS.png?1609306996" + }, + { + "chainId": 1, + "address": "0xf629cbd94d3791c9250152bd8dfbdf380e2a3b9c", + "name": "Enjin Coin", + "symbol": "ENJ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1102/thumb/enjin-coin-logo.png?1547035078" + }, + { + "chainId": 1, + "address": "0x0ce6d5a093d4166237c7a9ff8e0553b0293214a1", + "name": "Decenturion", + "symbol": "DCNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6195/thumb/X5_20dt1_400x400.jpg?1547042224" + }, + { + "chainId": 1, + "address": "0x8254e26e453eb5abd29b3c37ac9e8da32e5d3299", + "name": "RBX", + "symbol": "RBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19253/thumb/output-onlinepngtools-9.png?1634801960" + }, + { + "chainId": 1, + "address": "0x29d578cec46b50fa5c88a99c6a4b70184c062953", + "name": "Everscale", + "symbol": "EVER", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/12783/thumb/everscale_badge_main_round_1x.png?1640050196" + }, + { + "chainId": 1, + "address": "0x777fd20c983d6658c1d50b3958b3a1733d1cd1e1", + "name": "PUBLISH", + "symbol": "NEWS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/9572/thumb/PUBLISH_Logo_280X280.png?1617605563" + }, + { + "chainId": 1, + "address": "0x045da4bfe02b320f4403674b3b7d121737727a36", + "name": "DeFi Franc", + "symbol": "DCHF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28108/thumb/22249.png?1667544891" + }, + { + "chainId": 1, + "address": "0x9aab071b4129b083b01cb5a0cb513ce7eca26fa5", + "name": "Hunt", + "symbol": "HUNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7989/thumb/HUNT.png?1571024256" + }, + { + "chainId": 1, + "address": "0x4740735aa98dc8aa232bd049f8f0210458e7fca3", + "name": "Ridotto", + "symbol": "RDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18671/thumb/200x200_%2832%29.png?1632875527" + }, + { + "chainId": 1, + "address": "0xea3983fc6d0fbbc41fb6f6091f68f3e08894dc06", + "name": "Unido", + "symbol": "UDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14176/thumb/unido.jpg?1614792353" + }, + { + "chainId": 1, + "address": "0x5592c5aa89492ea918d55b804e177b5ca7dccd5a", + "name": "Wrapped xBTC", + "symbol": "WXBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15688/thumb/XBTC-Logo-6.png?1621564837" + }, + { + "chainId": 1, + "address": "0xb6ee9668771a79be7967ee29a63d4184f8097143", + "name": "CargoX", + "symbol": "CXO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2580/thumb/cargox.png?1547738832" + }, + { + "chainId": 1, + "address": "0xf55a93b613d172b86c2ba3981a849dae2aecde2f", + "name": "Your Futures Exchange", + "symbol": "YFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15654/thumb/yfx.PNG?1621478455" + }, + { + "chainId": 1, + "address": "0x43dfc4159d86f3a37a5a4b3d4580b888ad7d4ddd", + "name": "DODO", + "symbol": "DODO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12651/thumb/dodo_logo.png?1601433025" + }, + { + "chainId": 1, + "address": "0xd2be3722b17b616c51ed9b8944a227d1ce579c24", + "name": "Dtube Coin", + "symbol": "DTUBE", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/13126/thumb/dtube_logo.png?1605500467" + }, + { + "chainId": 1, + "address": "0xefc1c73a3d8728dc4cf2a18ac5705fe93e5914ac", + "name": "MetricExchange", + "symbol": "METRIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12664/thumb/metric_exchange_logo.png?1601453711" + }, + { + "chainId": 1, + "address": "0x84fe25f3921f3426395c883707950d0c00367576", + "name": "Insight Protocol", + "symbol": "INX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11694/thumb/logo_%EC%B0%90%EB%B8%94%EB%A3%A8.png?1592879247" + }, + { + "chainId": 1, + "address": "0xf058501585023d040ea9493134ed72c083553eed", + "name": "Dymmax", + "symbol": "DMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13476/thumb/dmmx.png?1608934713" + }, + { + "chainId": 1, + "address": "0xc4c75f2a0cb1a9acc33929512dc9733ea1fd6fde", + "name": "Martin Shkreli Inu", + "symbol": "MSI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26365/thumb/jEYEUxUI_400x400.jpeg?1657600080" + }, + { + "chainId": 1, + "address": "0x6aedb157b9ca86e32200857aa2579d47098ace39", + "name": "Up Spiral", + "symbol": "SPIRAL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26615/thumb/200logo.png?1664098207" + }, + { + "chainId": 1, + "address": "0x2a1174d1cd4348cb1eaec3f00310908ca289e5be", + "name": "Exgold", + "symbol": "EXG", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14068/thumb/-HgHqzsy_400x400.png?1614137624" + }, + { + "chainId": 1, + "address": "0x14cc8dfaf2258e1b8b2869300dba1b734dc0fe43", + "name": "K Tune", + "symbol": "KTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13939/thumb/KakaoTalk_20220928_162525453.png?1664356062" + }, + { + "chainId": 1, + "address": "0xd07d9fe2d2cc067015e2b4917d24933804f42cfa", + "name": "Tolar", + "symbol": "TOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4487/thumb/tolar.png?1548759060" + }, + { + "chainId": 1, + "address": "0x7d92a06808b4c4833623f809218ed403e4a85fe1", + "name": "Universe Crystal Gene", + "symbol": "UCG", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/24619/thumb/19073.png?1648418625" + }, + { + "chainId": 1, + "address": "0xaae3cf9968d26925bdb73ce3864e0084a20f4687", + "name": "Farmland Protocol", + "symbol": "FAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13497/thumb/70059912.jpg?1609193763" + }, + { + "chainId": 1, + "address": "0x9469d013805bffb7d3debe5e7839237e535ec483", + "name": "Darwinia Network", + "symbol": "RING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9443/thumb/RING.png?1615271827" + }, + { + "chainId": 1, + "address": "0xecc0f1f860a82ab3b442382d93853c02d6384389", + "name": "Axis DeFi", + "symbol": "AXIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12199/thumb/YeLWZ3V.jpg?1597998424" + }, + { + "chainId": 1, + "address": "0x1af4f195a8aaa7ffd752c28a13b719b84056f0d6", + "name": "NFT Track Protocol", + "symbol": "NTP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27108/thumb/NTP_Symbol_CoinGecko.jpg?1662009323" + }, + { + "chainId": 1, + "address": "0xbeab712832112bd7664226db7cd025b153d3af55", + "name": "Bright Union", + "symbol": "BRIGHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17552/thumb/BrightToken_Token-only_200x200-1.png?1628227007" + }, + { + "chainId": 1, + "address": "0xbe601dd49da9ee1d2f64d422c4aecf8eb83c119f", + "name": "JustCarbon Governance", + "symbol": "JCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25701/thumb/Just-Carbon-JCG.png?1653451947" + }, + { + "chainId": 1, + "address": "0x7bec98609cb6378d6f995e8f8097ee78376fbec9", + "name": "LeisureMeta", + "symbol": "LM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25761/thumb/SVG_16533804486374586M.jpg?1653548604" + }, + { + "chainId": 1, + "address": "0x28b5e12cce51f15594b0b91d5b5adaa70f684a02", + "name": "Napoleon X", + "symbol": "NPX", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/1471/thumb/napoleon-x.jpg?1547035570" + }, + { + "chainId": 1, + "address": "0xac042d9284df95cc6bd35982f6a61e3e7a6f875b", + "name": "Lobby", + "symbol": "LBY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20699/thumb/6197f0a241be5b582742b263_lobbySocial256w.png?1637565411" + }, + { + "chainId": 1, + "address": "0xe7ab45162f5979f09b0bda1cc7dfc97c270ea3d5", + "name": "Dobermann", + "symbol": "DOBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16002/thumb/doberman.PNG?1622593349" + }, + { + "chainId": 1, + "address": "0xbf8fb919a8bbf28e590852aef2d284494ebc0657", + "name": "ABCC", + "symbol": "AT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5132/thumb/abcc-token.png?1547040523" + }, + { + "chainId": 1, + "address": "0x6149c26cd2f7b5ccdb32029af817123f6e37df5b", + "name": "Launchpool", + "symbol": "LPOOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14041/thumb/dGUvV0HQ_400x400.jpg?1613976219" + }, + { + "chainId": 1, + "address": "0x62d3c05b9c3d916fbc111819bbd3cee52906c1ae", + "name": "Every Game", + "symbol": "EGAME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20758/thumb/egame.png?1637648306" + }, + { + "chainId": 1, + "address": "0x927159670c50042109d7c0f4aed0cee89452433e", + "name": "DGPayment", + "symbol": "DGP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13291/thumb/dgpay-icon-logo.png?1607062736" + }, + { + "chainId": 1, + "address": "0x39c6b3e42d6a679d7d776778fe880bc9487c2eda", + "name": "Aave KNC", + "symbol": "AKNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14250/thumb/aKNC.42bcd2e3.png?1615528613" + }, + { + "chainId": 1, + "address": "0x764104dc24dadff01150253a58c82337984b4319", + "name": "hiCLONEX", + "symbol": "HICLONEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28436/thumb/hiclonex.png?1670568067" + }, + { + "chainId": 1, + "address": "0x28fda76721a8077a5de802ab0212849b8c38429e", + "name": "Artemis Vision", + "symbol": "ARV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23716/thumb/uUMU6_Cr_400x400.jpg?1645147096" + }, + { + "chainId": 1, + "address": "0x11c49e5ca7222f89909a6ec42d81eb6b2af5ff40", + "name": "BridgeCoin", + "symbol": "BRC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27334/thumb/brc.png?1663481808" + }, + { + "chainId": 1, + "address": "0x8bbe1a2961b41340468d0548c2cd5b7dfa9b684c", + "name": "Handy", + "symbol": "HANDY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21944/thumb/Handy_Token_symbol-01.png?1640313628" + }, + { + "chainId": 1, + "address": "0x0000000005c6b7c1fd10915a05f034f90d524d6e", + "name": "TRYC", + "symbol": "TRYC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21985/thumb/16357.png?1640577395" + }, + { + "chainId": 1, + "address": "0x054f76beed60ab6dbeb23502178c52d6c5debe40", + "name": "DeFiner", + "symbol": "FIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12780/thumb/PdaW8Lb.png?1602500407" + }, + { + "chainId": 1, + "address": "0x7c0853ab074f2f17e37c5482dcf6c5f6c1246e8b", + "name": "LondonCoinGold", + "symbol": "LDXG", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/24419/thumb/E9eOuH6W_400x400.jpg?1647611828" + }, + { + "chainId": 1, + "address": "0x1ca02dd95f3f1e33da7f5afe15ea866dab07af04", + "name": "King Arthur", + "symbol": "BKING", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16162/thumb/king-arthur.png?1623142524" + }, + { + "chainId": 1, + "address": "0x1cdd2eab61112697626f7b4bb0e23da4febf7b7c", + "name": "Tether USD Wormhole ", + "symbol": "USDTSO", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/22881/thumb/USDTso_wh_small.png?1644223113" + }, + { + "chainId": 1, + "address": "0x4e0fca55a6c3a94720ded91153a27f60e26b9aa8", + "name": "Boost", + "symbol": "BOOST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17657/thumb/02FjG1Og.png?1628757020" + }, + { + "chainId": 1, + "address": "0xbf52f2ab39e26e0951d2a02b49b7702abe30406a", + "name": "ODEM", + "symbol": "ODE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3752/thumb/odem.png?1548329893" + }, + { + "chainId": 1, + "address": "0xc53342fd7575f572b0ff4569e31941a5b821ac76", + "name": "Ethereum Volatility Index Token", + "symbol": "ETHV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16716/thumb/logo_-_2021-06-28T092549.772.png?1624843558" + }, + { + "chainId": 1, + "address": "0x0ea984e789302b7b612147e4e4144e64f21425eb", + "name": "Wale", + "symbol": "WTN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6404/thumb/waletoken_2_sosmed_Square.png?1547042539" + }, + { + "chainId": 1, + "address": "0x41e5560054824ea6b0732e656e3ad64e20e94e45", + "name": "Civic", + "symbol": "CVC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/788/thumb/civic-orange.png?1657246016" + }, + { + "chainId": 1, + "address": "0x0a76aad21948ea1ef447d26dee91a54370e151e0", + "name": "Ethereum Lite", + "symbol": "ELITE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1062/thumb/elite.png?1547035007" + }, + { + "chainId": 1, + "address": "0xba358b6f5b4c0215650444b8c30d870b55050d2d", + "name": "Hub", + "symbol": "HUB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13345/thumb/Hub-Logo-Transparent-BG-200x200_%281%29.png?1607661813" + }, + { + "chainId": 1, + "address": "0x57ab1ec28d129707052df4df418d58a2d46d5f51", + "name": "sUSD", + "symbol": "SUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5013/thumb/sUSD.png?1616150765" + }, + { + "chainId": 1, + "address": "0x1fe70be734e473e5721ea57c8b5b01e6caa52686", + "name": "BitRent", + "symbol": "RNTB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3499/thumb/photo.png?1547273521" + }, + { + "chainId": 1, + "address": "0x673a2722e5a8f614beaa66a2ba73384d98424d51", + "name": "Multi Strategies Capital", + "symbol": "MSC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23846/thumb/logo200.png?1645519048" + }, + { + "chainId": 1, + "address": "0x68749665ff8d2d112fa859aa293f07a622782f38", + "name": "Tether Gold", + "symbol": "XAUT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/10481/thumb/Tether_Gold.png?1668148656" + }, + { + "chainId": 1, + "address": "0xd0d6d6c5fe4a677d343cc433536bb717bae167dd", + "name": "adChain", + "symbol": "ADT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/778/thumb/adtoken.png?1547034537" + }, + { + "chainId": 1, + "address": "0x4485561db76614ff727f8e0a3ea95690b8b16022", + "name": "Invox Finance", + "symbol": "INVOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3200/thumb/invox.png?1547037651" + }, + { + "chainId": 1, + "address": "0x96b52b5bf8d902252d0714a1bd2651a785fd2660", + "name": "EtherBone", + "symbol": "ETHBN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11596/thumb/ETHBN.png?1615803426" + }, + { + "chainId": 1, + "address": "0x8a88f04e0c905054d2f33b26bb3a46d7091a039a", + "name": "IGT", + "symbol": "IG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5434/thumb/igtoken.png?1547041141" + }, + { + "chainId": 1, + "address": "0x2f4eb47a1b1f4488c71fc10e39a4aa56af33dd49", + "name": "UNCL", + "symbol": "UNCL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13102/thumb/uncl_logo.png?1605230945" + }, + { + "chainId": 1, + "address": "0xf6537fe0df7f0cc0985cf00792cc98249e73efa0", + "name": "GIV", + "symbol": "GIV", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8996/thumb/giv.png?1629952637" + }, + { + "chainId": 1, + "address": "0x30680ac0a8a993088223925265fd7a76beb87e7f", + "name": "ARAW", + "symbol": "ARAW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4281/thumb/araw.png?1547039642" + }, + { + "chainId": 1, + "address": "0x3e828ac5c480069d4765654fb4b8733b910b13b2", + "name": "Colony Network", + "symbol": "CLNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23269/thumb/Logo.png?1644482438" + }, + { + "chainId": 1, + "address": "0xd3c625f54dec647db8780dbbe0e880ef21ba4329", + "name": "HollaEx", + "symbol": "XHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16157/thumb/xGyZxK8.png?1623139610" + }, + { + "chainId": 1, + "address": "0x737fa0372c8d001904ae6acaf0552d4015f9c947", + "name": "MEDIBIT", + "symbol": "MEDIBIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6606/thumb/medibit.png?1547978632" + }, + { + "chainId": 1, + "address": "0x01022591fce0609b57670beba60102dfd2b95d77", + "name": "Hitop", + "symbol": "HITOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25959/thumb/20540.png?1654860802" + }, + { + "chainId": 1, + "address": "0x53dfea0a8cc2a2a2e425e1c174bc162999723ea0", + "name": "Jarvis Synthetic Swiss Franc", + "symbol": "JCHF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15727/thumb/jCHF.png?1634046084" + }, + { + "chainId": 1, + "address": "0x0ecdd783dc7bf820614044b51862ed29714d2ba5", + "name": "Medooza Ecosystem", + "symbol": "MDZA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13448/thumb/medooza-red-symbol-logo-exchange.png?1608681531" + }, + { + "chainId": 1, + "address": "0xd075e95423c5c4ba1e122cae0f4cdfa19b82881b", + "name": "OPES Wrapped PE ", + "symbol": "WPE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16647/thumb/opes.png?1625834316" + }, + { + "chainId": 1, + "address": "0xdf35988d795d90711e785b488bb2127692e6f956", + "name": "BabyFloki", + "symbol": "BABYFLOKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16712/thumb/floki.jpg?1624810144" + }, + { + "chainId": 1, + "address": "0xf5b1fd29d23e98db2d9ebb8435e1082e3b38fb65", + "name": "Kishimoto old ", + "symbol": "KISHIMOTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19188/thumb/cmclogo.png?1666922508" + }, + { + "chainId": 1, + "address": "0xda1e53e088023fe4d1dc5a418581748f52cbd1b8", + "name": "Aidi Inu", + "symbol": "AIDI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16339/thumb/aidi_200.png?1634199020" + }, + { + "chainId": 1, + "address": "0x78c292d1445e6b9558bf42e8bc369271ded062ea", + "name": "CyberMusic", + "symbol": "CYMT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6039/thumb/cybermusic.png?1547791125" + }, + { + "chainId": 1, + "address": "0xaaf37055188feee4869de63464937e683d61b2a1", + "name": "UChain", + "symbol": "UCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4254/thumb/UChain-logo.jpg?1547039592" + }, + { + "chainId": 1, + "address": "0x582d872a1b094fc48f5de31d3b73f2d9be47def1", + "name": "Toncoin", + "symbol": "TON", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17980/thumb/ton_symbol.png?1670498136" + }, + { + "chainId": 1, + "address": "0xeed3ae7b0f8b5b9bb8c035a9941382b1822671cd", + "name": "EveryCoin", + "symbol": "EVY", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/5629/thumb/TutkUC1x_400x400_%281%29.jpg?1547447105" + }, + { + "chainId": 1, + "address": "0x9f52c8ecbee10e00d9faaac5ee9ba0ff6550f511", + "name": "Sipher", + "symbol": "SIPHER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21070/thumb/SipherToken.png?1638312272" + }, + { + "chainId": 1, + "address": "0x9ce84f6a69986a83d92c324df10bc8e64771030f", + "name": "CHEX Token", + "symbol": "CHEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10349/thumb/1_0zxuLe6QnvfsZPFzOoUteQ.png?1578434355" + }, + { + "chainId": 1, + "address": "0x954b890704693af242613edef1b603825afcd708", + "name": "Cardstack", + "symbol": "CARD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3247/thumb/cardstack.png?1547037769" + }, + { + "chainId": 1, + "address": "0xc56b13ebbcffa67cfb7979b900b736b3fb480d78", + "name": "Social Activity", + "symbol": "SAT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2586/thumb/sat.png?1547036721" + }, + { + "chainId": 1, + "address": "0x04c17b9d3b29a78f7bd062a57cf44fc633e71f85", + "name": "IMPT", + "symbol": "IMPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28486/thumb/IMPT_logo.png?1671077901" + }, + { + "chainId": 1, + "address": "0xc8ef1460277ea47d179dec66d1c5f8b7f7ae5a28", + "name": "Rikkei Finance", + "symbol": "RIFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21309/thumb/rikkei-finance.jpeg?1638888855" + }, + { + "chainId": 1, + "address": "0x3abdff32f76b42e7635bdb7e425f0231a5f3ab17", + "name": "ConnectJob", + "symbol": "CJT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2207/thumb/connectjob.png?1547739980" + }, + { + "chainId": 1, + "address": "0x853d955acef822db058eb8505911ed77f175b99e", + "name": "Frax", + "symbol": "FRAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13422/thumb/ethCanonicalFRAX.png?1669277108" + }, + { + "chainId": 1, + "address": "0xcc7ab8d78dba187dc95bf3bb86e65e0c26d0041f", + "name": "Spacelens", + "symbol": "SPACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16979/thumb/SPACE___Spacelens.png?1625900475" + }, + { + "chainId": 1, + "address": "0xe6f143a0e0a8f24f6294ce3432ea10fad0206920", + "name": "PolkaEx", + "symbol": "PKEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18616/thumb/1024-1024-02.png?1632698540" + }, + { + "chainId": 1, + "address": "0x282d0ad1fa03dfbdb88243b958e77349c73737d1", + "name": "Protector Roge", + "symbol": "PROGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16993/thumb/Proge_200x200.png?1668677143" + }, + { + "chainId": 1, + "address": "0x50d1c9771902476076ecfc8b2a83ad6b9355a4c9", + "name": "FTX", + "symbol": "FTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9026/thumb/F.png?1609051564" + }, + { + "chainId": 1, + "address": "0xba745513acebcbb977497c569d4f7d340f2a936b", + "name": "Mainstream For The Underground", + "symbol": "MFTU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5519/thumb/Mainstream_for_the_underground.png?1534426154" + }, + { + "chainId": 1, + "address": "0x05ec93c0365baaeabf7aeffb0972ea7ecdd39cf1", + "name": "Aave BAT", + "symbol": "ABAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14246/thumb/aBAT.1fe436f7_-_Copy.png?1615528663" + }, + { + "chainId": 1, + "address": "0xdb262c7d67fe7336574f005db47b7c8e1df41852", + "name": "Naffiti", + "symbol": "NAFF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24057/thumb/Naffiti_1200x1200.png?1646203375" + }, + { + "chainId": 1, + "address": "0x8185bc4757572da2a610f887561c32298f1a5748", + "name": "Aluna", + "symbol": "ALN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14379/thumb/uaLoLU8c_400x400_%281%29.png?1627873106" + }, + { + "chainId": 1, + "address": "0x705ee96c1c160842c92c1aecfcffccc9c412e3d9", + "name": "ClearPoll", + "symbol": "POLL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1050/thumb/clearpoll.png?1547034985" + }, + { + "chainId": 1, + "address": "0x874d4c9b980f1a13dd44cbcdb912e24ef0671ed0", + "name": "Guider", + "symbol": "GDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8425/thumb/mROuNfEF_400x400.png?1571308333" + }, + { + "chainId": 1, + "address": "0x677ddbd918637e5f2c79e164d402454de7da8619", + "name": "Vesper V Dollar", + "symbol": "VUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16253/thumb/Vesper_Token_600.png?1623394697" + }, + { + "chainId": 1, + "address": "0x455f7ef6d8bcfc35f9337e85aee1b0600a59fabe", + "name": "Aloha", + "symbol": "ALOHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14048/thumb/aloha.png?1615527835" + }, + { + "chainId": 1, + "address": "0x68350d30d9f58c81aaaa41929f1bfc52fff4ea49", + "name": "Rapidz", + "symbol": "RPZX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7663/thumb/rapidzpay-logo.jpg?1549038850" + }, + { + "chainId": 1, + "address": "0x7a41e0517a5eca4fdbc7fbeba4d4c47b9ff6dc63", + "name": "Zeusshield", + "symbol": "ZSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1009/thumb/zeusshield.png?1548761440" + }, + { + "chainId": 1, + "address": "0xe8e8486228753e01dbc222da262aa706bd67e601", + "name": "Arch Ethereum Web3", + "symbol": "WEB3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26562/thumb/WEB3-TOKEN.png?1658798344" + }, + { + "chainId": 1, + "address": "0x6fc13eace26590b80cccab1ba5d51890577d83b2", + "name": "Umbrella Network", + "symbol": "UMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13913/thumb/Umbrella_Network_Logo-Vertical_Version.png?1612836176" + }, + { + "chainId": 1, + "address": "0x8a9c67fee641579deba04928c4bc45f66e26343a", + "name": "Jarvis Reward", + "symbol": "JRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10390/thumb/cfeii0y.png?1578868949" + }, + { + "chainId": 1, + "address": "0x4e12eb8e506ccd1427f6b8f7faa3e88fb698eb28", + "name": "Jack Token", + "symbol": "JACK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10991/thumb/Jacktoken200x200.png?1586938972" + }, + { + "chainId": 1, + "address": "0xa10ae543db5d967a73e9abcc69c81a18a7fc0a78", + "name": "BLOCKCLOUT", + "symbol": "CLOUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11870/thumb/communityIcon_nys28lije4b51.png?1595505057" + }, + { + "chainId": 1, + "address": "0xf947b0824c3995787efc899017a36bc9f281265e", + "name": "Lotoblock", + "symbol": "LOTO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6611/thumb/xkKemBDV_400x400.jpg?1547042813" + }, + { + "chainId": 1, + "address": "0x67a9099f0008c35c61c00042cd9fb03684451097", + "name": "Game Stars", + "symbol": "GST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4075/thumb/game-stars.png?1548126796" + }, + { + "chainId": 1, + "address": "0xc96c1609a1a45ccc667b2b7fa6508e29617f7b69", + "name": "2gether", + "symbol": "2GT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14516/thumb/m329Ic5i_400x400.jpg?1616647761" + }, + { + "chainId": 1, + "address": "0xf51ebf9a26dbc02b13f8b3a9110dac47a4d62d78", + "name": "APIX", + "symbol": "APIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10124/thumb/5sSKmtlA_400x400.png?1576126911" + }, + { + "chainId": 1, + "address": "0xe1bda0c3bfa2be7f740f0119b6a34f057bd58eba", + "name": "The Winkyverse", + "symbol": "WNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22260/thumb/wnk.png?1644053369" + }, + { + "chainId": 1, + "address": "0x8a7adc1b690e81c758f1bd0f72dfe27ae6ec56a5", + "name": "Bolide", + "symbol": "BLID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25548/thumb/BLID_token_logo_200x200.png?1652334831" + }, + { + "chainId": 1, + "address": "0x01cc4151fe5f00efb8df2f90ff833725d3a482a3", + "name": "SPECTRUM", + "symbol": "SPT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7688/thumb/SPT-Logo-200x200.png?1549596154" + }, + { + "chainId": 1, + "address": "0xa960d2ba7000d58773e7fa5754dec3bb40a069d5", + "name": "One DEX", + "symbol": "ODEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7712/thumb/WzsJ6pIr_400x400.jpg?1549940214" + }, + { + "chainId": 1, + "address": "0xbcfdaeb22ab6e10dfb99546e6240155edc1084f7", + "name": "Genexi", + "symbol": "GXI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7126/thumb/bR4FuOeq_400x400.jpg?1547043624" + }, + { + "chainId": 1, + "address": "0xea38eaa3c86c8f9b751533ba2e562deb9acded40", + "name": "Etherparty", + "symbol": "FUEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1082/thumb/etherparty.png?1547394573" + }, + { + "chainId": 1, + "address": "0x58f9102bf53cf186682bd9a281d3cd3c616eec41", + "name": "Triall", + "symbol": "TRL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18679/thumb/-B7ftfN8_400x400.png?1632964301" + }, + { + "chainId": 1, + "address": "0xda022ca91df99413e8cb0caab4d1cba4e9018bea", + "name": "JMTIME", + "symbol": "JMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7397/thumb/SQA_voBI.png?1555664534" + }, + { + "chainId": 1, + "address": "0x72e5390edb7727e3d4e3436451dadaff675dbcc0", + "name": "Hanu Yokia", + "symbol": "HANU", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/17161/thumb/Goji_Hanu_Logo_200x200.png?1627127472" + }, + { + "chainId": 1, + "address": "0x7495e5cc8f27e0bd5bd4cb86d17f0d841ca58ee4", + "name": "Arnoya classic", + "symbol": "ARNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28194/thumb/ARNC_200.png?1668332937" + }, + { + "chainId": 1, + "address": "0x425c5b7b55f9c981c71935418ed044e79d8080e2", + "name": "Mad Hatter Society", + "symbol": "MADHAT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27407/thumb/MADHAT_TOKEN_CROP.png?1663842237" + }, + { + "chainId": 1, + "address": "0x41a08648c3766f9f9d85598ff102a08f4ef84f84", + "name": "Aave Balancer Pool Token", + "symbol": "ABPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16788/thumb/ABPT_2x.png?1625046056" + }, + { + "chainId": 1, + "address": "0x36b00c4c6ce3653a091c7940fc98c3acb0043871", + "name": "Shibamon", + "symbol": "SHIBAMON", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19891/thumb/cm170VEL_400x400.jpg?1636093140" + }, + { + "chainId": 1, + "address": "0x4527a3b4a8a150403090a99b87effc96f2195047", + "name": "P2P solutions foundation", + "symbol": "P2PS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2798/thumb/p2ps.png?1547036973" + }, + { + "chainId": 1, + "address": "0x1977be49c33dfacf6590c16ca9a9cfa0463f663c", + "name": "DoRen", + "symbol": "DRE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16901/thumb/DoRen_project_whitepaper_v1_1_EN_pdf.png?1625572581" + }, + { + "chainId": 1, + "address": "0xe9a95d175a5f4c9369f3b74222402eb1b837693b", + "name": "ChangeNOW", + "symbol": "NOW", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8224/thumb/now.png?1660465450" + }, + { + "chainId": 1, + "address": "0x3f68e7b44e9bcb486c2feadb7a2289d9cdfc9088", + "name": "SportsIcon", + "symbol": "ICONS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20856/thumb/icons-coin-gold.png?1638349473" + }, + { + "chainId": 1, + "address": "0x1bdc5e5aa2749b4934c33441e050b8854b77a331", + "name": "First Inu", + "symbol": "FINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19705/thumb/finu.png?1638346534" + }, + { + "chainId": 1, + "address": "0xbf825207c74b6c3c01ab807c4f4a4fce26ebdf0f", + "name": "DaddyBezos", + "symbol": "DJBZ", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19782/thumb/tOyy80Z.png?1635846414" + }, + { + "chainId": 1, + "address": "0x8ae4bf2c33a8e667de34b54938b0ccd03eb8cc06", + "name": "Patientory", + "symbol": "PTOY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/746/thumb/patientory.png?1548330777" + }, + { + "chainId": 1, + "address": "0xdd3a88ef8535ff7b19178b735c52ea277ef25623", + "name": "DeFi ", + "symbol": "DFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28351/thumb/b3a69dfd-3250-4382-8fee-be61acc7c5de.png?1669771397" + }, + { + "chainId": 1, + "address": "0x400b1d8a7dd8c471026b2c8cbe1062b27d120538", + "name": "Limestone Network", + "symbol": "LIMEX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11907/thumb/nw1FE_f4_400x400.png?1596074376" + }, + { + "chainId": 1, + "address": "0xa7925aa2a6e4575ab0c74d169f3bc3e03d4c319a", + "name": "Better Money", + "symbol": "BETTER", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/12838/thumb/BETTER_MONEY_MASK_ICON.png?1602899651" + }, + { + "chainId": 1, + "address": "0x9ab7bb7fdc60f4357ecfef43986818a2a3569c62", + "name": "Guild of Guardians", + "symbol": "GOG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17362/thumb/V2QDNoLg_400x400.jpg?1640054187" + }, + { + "chainId": 1, + "address": "0xd7c9f0e536dc865ae858b0c0453fe76d13c3beac", + "name": "XAI Stablecoin", + "symbol": "XAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28254/thumb/Xai_logo.png?1668674085" + }, + { + "chainId": 1, + "address": "0x992d339532a9c42f1b0e59a57e95f38da38c66f6", + "name": "Soulsaver", + "symbol": "SOUL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27494/thumb/SOUL_LOGO.png?1664268950" + }, + { + "chainId": 1, + "address": "0x1829aa045e21e0d59580024a951db48096e01782", + "name": "FuzeX", + "symbol": "FXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3692/thumb/fuzex-token.png?1547038696" + }, + { + "chainId": 1, + "address": "0x9d91be44c06d373a8a226e1f3b146956083803eb", + "name": "Aave KNC v1", + "symbol": "AKNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11727/thumb/aKNC.png?1593083924" + }, + { + "chainId": 1, + "address": "0x3ed3b47dd13ec9a98b44e6204a523e766b225811", + "name": "Aave USDT", + "symbol": "AUSDT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14243/thumb/aUSDT.78f5faae.png?1615528400" + }, + { + "chainId": 1, + "address": "0xf9e5af7b42d31d51677c75bbbd37c1986ec79aee", + "name": "QuickX Protocol", + "symbol": "QCX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4971/thumb/qcx.png?1547040393" + }, + { + "chainId": 1, + "address": "0x4fabf135bcf8111671870d4399af739683198f96", + "name": "Xave Coin", + "symbol": "XVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24084/thumb/k8qjP9t9_400x400.jpg?1646292464" + }, + { + "chainId": 1, + "address": "0x184b6f31aeaa6a19eb207dfea01f4289629e0f0f", + "name": "FiveKM KMT", + "symbol": "KMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25410/thumb/logo-200.png?1651732812" + }, + { + "chainId": 1, + "address": "0x8727c112c712c4a03371ac87a74dd6ab104af768", + "name": "Jetcoin", + "symbol": "JET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2487/thumb/jetcoin.png?1547974820" + }, + { + "chainId": 1, + "address": "0x786e995a975c2ab7c1dd252a9019fb0c91c9ca83", + "name": "Landworld", + "symbol": "LWD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25642/thumb/v-MhJXeSQuKSjz5gJRpptF5E5v95862DXJhkSeVabQcVsbBxzryaaQQ-eqwp0hvjrXQQmQRUKYW3gFfzUi3zVjhWoZKg79rmFF5dL6igKT0iWWpDtfNRcr6XA1mL9WiLgg6EOqwfmuLNu1-qan38OQJve32FKgJ7FL_fAyZRHvSuuIwO4qmcLPVqWo08oYELCC5ParMmS7FfNsHtu38u6j0gxw.jpg?1652949037" + }, + { + "chainId": 1, + "address": "0x36ed7baad9a571b5dad55d096c0ed902188d6d3c", + "name": "Infinity Pad OLD ", + "symbol": "IPAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17302/thumb/ipad.jpg?1627268574" + }, + { + "chainId": 1, + "address": "0x1d6405138a335ce5fd7364086334efb3e4f28b59", + "name": "ClearCryptos", + "symbol": "CCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27900/thumb/3e88b61451995da1a5aa572cd4f48e78023e010c0bf984cd5456b2a7bd85f7a5.png?1666322609" + }, + { + "chainId": 1, + "address": "0x20be82943e8d9c682580e11d424ec15db95b4a24", + "name": "No Bull", + "symbol": "NB", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21366/thumb/Logo-E-2.png?1652944972" + }, + { + "chainId": 1, + "address": "0x4f4f0ef7978737ce928bff395529161b44e27ad9", + "name": "Your Finance Decentralized", + "symbol": "YFD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13225/thumb/YFD2.png?1613362452" + }, + { + "chainId": 1, + "address": "0xcf9fbffec9e0e5bbc62e79bf1965f5db76955661", + "name": "MeshBox", + "symbol": "MESH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6200/thumb/DPuEPJQ6_400x400.jpg?1547042229" + }, + { + "chainId": 1, + "address": "0x923b83c26b3809d960ff80332ed00aa46d7ed375", + "name": "Creator Platform", + "symbol": "CTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18252/thumb/logo_%281%29.png?1631137441" + }, + { + "chainId": 1, + "address": "0x8515cd0f00ad81996d24b9a9c35121a3b759d6cd", + "name": "BlockBurn", + "symbol": "BURN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8851/thumb/blockburn.JPG?1582774870" + }, + { + "chainId": 1, + "address": "0x54cb643ab007f47882e8120a8c57b639005c2688", + "name": "IMPACTXPRIME", + "symbol": "IXP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28128/thumb/IXP_LOGO.jpg?1667641972" + }, + { + "chainId": 1, + "address": "0xc29acac647c63dbd8618e817d41ea9de69174ae1", + "name": "NRGY Defi", + "symbol": "NRGY", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/18075/thumb/nrgy.jpeg?1630391703" + }, + { + "chainId": 1, + "address": "0x41dbecc1cdc5517c6f76f6a6e836adbee2754de3", + "name": "Medicalchain", + "symbol": "MTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2850/thumb/medicalchain.png?1547037019" + }, + { + "chainId": 1, + "address": "0xcbd55d4ffc43467142761a764763652b48b969ff", + "name": "AstroTools", + "symbol": "ASTRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12345/thumb/AT-flat-purple_logo.png?1599190828" + }, + { + "chainId": 1, + "address": "0xd1afbccc9a2c2187ea544363b986ea0ab6ef08b5", + "name": "Ethereum Yield", + "symbol": "ETHY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13191/thumb/rOIuPZM.png?1606101103" + }, + { + "chainId": 1, + "address": "0x08f5a9235b08173b7569f83645d2c7fb55e8ccd8", + "name": "Tierion", + "symbol": "TNT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/923/thumb/tierion.png?1547034767" + }, + { + "chainId": 1, + "address": "0x8a2ead49d2123edee893181fb69527a022235c36", + "name": "Max Revive", + "symbol": "MAXR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22402/thumb/17030.png?1641794243" + }, + { + "chainId": 1, + "address": "0x435d664f72d6f194ef67d63b5f3936650187b131", + "name": "Pocket Node", + "symbol": "NODE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10376/thumb/u1L_YtHS_400x400.jpg?1583377126" + }, + { + "chainId": 1, + "address": "0xc98d64da73a6616c42117b582e832812e7b8d57f", + "name": "RSS3", + "symbol": "RSS3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23575/thumb/RSS3.png?1644494645" + }, + { + "chainId": 1, + "address": "0xd4f6f9ae14399fd5eb8dfc7725f0094a1a7f5d80", + "name": "Bitsten OLD ", + "symbol": "BST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7335/thumb/bitsten.png?1589629209" + }, + { + "chainId": 1, + "address": "0x12e56851ec22874520dc4c7fa0a8a8d7dba1bac8", + "name": "GENART", + "symbol": "GENART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23055/thumb/token_logo.jpeg?1643151315" + }, + { + "chainId": 1, + "address": "0x92d6c1e31e14520e676a687f0a93788b716beff5", + "name": "dYdX", + "symbol": "DYDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17500/thumb/hjnIm9bV.jpg?1628009360" + }, + { + "chainId": 1, + "address": "0x6c8c6b02e7b2be14d4fa6022dfd6d75921d90e4e", + "name": "cBAT", + "symbol": "CBAT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10645/thumb/cBAT1.JPG?1581390910" + }, + { + "chainId": 1, + "address": "0xf25c91c87e0b1fd9b4064af0f427157aab0193a7", + "name": "BASIC", + "symbol": "BASIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11050/thumb/unTgJN6U_400x400.jpg?1587540882" + }, + { + "chainId": 1, + "address": "0x234d51ee02be808a0160b19b689660fb7bfa871b", + "name": "CoinScan", + "symbol": "SCAN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24254/thumb/scan.png?1647155535" + }, + { + "chainId": 1, + "address": "0x456125cd98107ae0480ba566f1b716d48ba31453", + "name": "Ultimate Champions", + "symbol": "CHAMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28091/thumb/champ.png?1667472074" + }, + { + "chainId": 1, + "address": "0x4946fcea7c692606e8908002e55a582af44ac121", + "name": "FOAM", + "symbol": "FOAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3345/thumb/K51lJQc.png?1547037959" + }, + { + "chainId": 1, + "address": "0x9d3e0892d11f19f5181d4a4c5d04187a9e0d7032", + "name": "Dragonbit", + "symbol": "DRGB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10123/thumb/drgb.PNG?1576125394" + }, + { + "chainId": 1, + "address": "0xbfd815347d024f449886c171f78fa5b8e6790811", + "name": "AMPnet", + "symbol": "AAPX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14303/thumb/AAPX.png?1615356946" + }, + { + "chainId": 1, + "address": "0x18aaa7115705e8be94bffebde57af9bfc265b998", + "name": "Audius", + "symbol": "AUDIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12913/thumb/AudiusCoinLogo_2x.png?1603425727" + }, + { + "chainId": 1, + "address": "0x7bef710a5759d197ec0bf621c3df802c2d60d848", + "name": "SHOPX", + "symbol": "SHOPX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14600/thumb/shopx_icon_.png?1646381164" + }, + { + "chainId": 1, + "address": "0x26ea1f595f6567b7050fbba24f6a66e19db4d560", + "name": "APE Punk", + "symbol": "APE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14510/thumb/ape-punk-shards.png?1616596505" + }, + { + "chainId": 1, + "address": "0x8cd480260a47f04589670a313d27a15b321ad266", + "name": "Swiftlance", + "symbol": "SWL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6052/thumb/swiftlance_qssxxz.png?1547042011" + }, + { + "chainId": 1, + "address": "0x5cf04716ba20127f1e2297addcf4b5035000c9eb", + "name": "NKN", + "symbol": "NKN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3375/thumb/nkn.png?1548329212" + }, + { + "chainId": 1, + "address": "0x567300e14f8d67e1f6720a95291dce2511a86723", + "name": "Helper Search", + "symbol": "HSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6463/thumb/hsn.png?1547042670" + }, + { + "chainId": 1, + "address": "0x7acb51e690301b114a2a65b2e557cc1b7e644ba8", + "name": "Expo", + "symbol": "EXPO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6548/thumb/t4GE48eH_400x400.png?1547042762" + }, + { + "chainId": 1, + "address": "0x84c722e6f1363e8d5c6db3ea600bef9a006da824", + "name": "Misbloc", + "symbol": "MSB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13021/thumb/xREV4lXV.png?1604396822" + }, + { + "chainId": 1, + "address": "0xfd5f65a7e4fae82778be1085ffd2f1de5b2de92c", + "name": "DCAP", + "symbol": "DCAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25478/thumb/dcap.png?1652007843" + }, + { + "chainId": 1, + "address": "0x389999216860ab8e0175387a0c90e5c52522c945", + "name": "FEG", + "symbol": "FEG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13878/thumb/F-Icon-FEG-200x200-288dpi-01_%281%29.png?1665641152" + }, + { + "chainId": 1, + "address": "0xbc647aad10114b89564c0a7aabe542bd0cf2c5af", + "name": "IONChain", + "symbol": "IONC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6572/thumb/3PD7ycbU_400x400.jpg?1547042781" + }, + { + "chainId": 1, + "address": "0xaee433adebe0fbb88daa47ef0c1a513caa52ef02", + "name": "Pontoon", + "symbol": "TOON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19575/thumb/pontoon.PNG?1635467899" + }, + { + "chainId": 1, + "address": "0xd2946be786f35c3cc402c29b323647abda799071", + "name": "Vikky", + "symbol": "VIKKY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5278/thumb/vikkytoken.png?1548760050" + }, + { + "chainId": 1, + "address": "0x2bba3cf6de6058cc1b4457ce00deb359e2703d7f", + "name": "HashCoin", + "symbol": "HSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4989/thumb/hashfuture-logo.png?1531741876" + }, + { + "chainId": 1, + "address": "0x45734927fa2f616fbe19e65f42a0ef3d37d1c80a", + "name": "Rogue Doge", + "symbol": "ROGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17440/thumb/njbVg2f.png?1645356462" + }, + { + "chainId": 1, + "address": "0x1712aad2c773ee04bdc9114b32163c058321cd85", + "name": "LimitSwap", + "symbol": "LIMIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12760/thumb/limit_swap_logo.png?1602347106" + }, + { + "chainId": 1, + "address": "0x3aadc3bce49724ce299fd9f3850211211c399c8c", + "name": "Coinstox", + "symbol": "CSX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14373/thumb/CSX-token-200.png?1615771653" + }, + { + "chainId": 1, + "address": "0xedb171c18ce90b633db442f2a6f72874093b49ef", + "name": "Wrapped Ampleforth", + "symbol": "WAMPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20825/thumb/photo_2021-11-25_02-05-11.jpg?1637811951" + }, + { + "chainId": 1, + "address": "0xda30f261a962d5aae94c9ecd170544600d193766", + "name": "Orbler", + "symbol": "ORBR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24056/thumb/fA2YATWT_400x400.jpg?1646203182" + }, + { + "chainId": 1, + "address": "0x1a7a8bd9106f2b8d977e08582dc7d24c723ab0db", + "name": "AppCoins", + "symbol": "APPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1876/thumb/appcoins.png?1547036186" + }, + { + "chainId": 1, + "address": "0xf1dc500fde233a4055e25e5bbf516372bc4f6871", + "name": "Saddle Finance", + "symbol": "SDL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20476/thumb/edit_saddle.png?1660734429" + }, + { + "chainId": 1, + "address": "0x7475c42f8bf2c19f4eaf12feaababa859fdc8914", + "name": "Accel Defi", + "symbol": "ACCEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22405/thumb/accel_new.png?1645426698" + }, + { + "chainId": 1, + "address": "0xea097a2b1db00627b2fa17460ad260c016016977", + "name": "Upfiring", + "symbol": "UFR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1170/thumb/upfiring.png?1548759693" + }, + { + "chainId": 1, + "address": "0x1e5193ccc53f25638aa22a940af899b692e10b09", + "name": "Alluo", + "symbol": "ALLUO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21484/thumb/logo-sm-wb.png?1649993895" + }, + { + "chainId": 1, + "address": "0x5f4c148d17effd165c2e2d46b46d2bd6e3ebdc3e", + "name": "5KM RUN", + "symbol": "RUN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26072/thumb/logo-200.png?1655621986" + }, + { + "chainId": 1, + "address": "0x1726b8d5dc3a93cc08fa079477d4ebe782b25bf7", + "name": "Shinjiro", + "symbol": "SHOX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25018/thumb/Shinjiro_200x200.png?1649830769" + }, + { + "chainId": 1, + "address": "0x10ba8c420e912bf07bedac03aa6908720db04e0c", + "name": "Raise", + "symbol": "RAISE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4411/thumb/Raise.png?1590671180" + }, + { + "chainId": 1, + "address": "0x030ba81f1c18d280636f32af80b9aad02cf0854e", + "name": "Aave WETH", + "symbol": "AWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17238/thumb/aWETH_2x.png?1626940782" + }, + { + "chainId": 1, + "address": "0x20b2d0a368d34adc544720c841281fa8a99f5a2e", + "name": "CoinGhost", + "symbol": "GST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25978/thumb/20568.png?1655112863" + }, + { + "chainId": 1, + "address": "0xd241d7b5cb0ef9fc79d9e4eb9e21f5e209f52f7d", + "name": "Hoo", + "symbol": "HOO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12968/thumb/LOGO1.jpeg?1654140098" + }, + { + "chainId": 1, + "address": "0x6faa826af0568d1866fca570da79b318ef114dab", + "name": "B21", + "symbol": "B21", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3510/thumb/B21_%283%29.png?1608706191" + }, + { + "chainId": 1, + "address": "0x6431fa4b812a2dcc062a38cb55cc7d18135adead", + "name": "RankerDao", + "symbol": "RANKER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23902/thumb/ranker.png?1645676549" + }, + { + "chainId": 1, + "address": "0x6f063c0fcda0ea6dcc01d5a7cb3066ed4f90d1a8", + "name": "EBSP", + "symbol": "EBSP", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/7650/thumb/mwlDkYEKIpcWAP00hfCU7KPQti7jgbew1OKea9RGlGwpdkwOTWp7shOWG5EAsXpUonAo8ZnQoVYoWIz0Tju71QcYMesj8-4Qz_CAyxUy12MTknHGjwfpITWwDaRtHXeTDCCGMvPRPR5ebXultUTIQAtB1x9gtvA03QAi5RVg4GkfX6kB_r04Qx6w2lxuLuyUAqd4x6zaQo_1Hy8NV333I.jpg?1549001856" + }, + { + "chainId": 1, + "address": "0xc0f9bd5fa5698b6505f643900ffa515ea5df54a9", + "name": "Donut", + "symbol": "DONUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7538/thumb/Donut.png?1548234345" + }, + { + "chainId": 1, + "address": "0x5c89736e9454200141b80c37eb28eaceca2ce8cb", + "name": "Cherry YT", + "symbol": "YT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8321/thumb/cherry.png?1557480352" + }, + { + "chainId": 1, + "address": "0xb009bfaaf85e53f55d8657781eb69feaaed83672", + "name": "EdgeSwap", + "symbol": "EGS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24878/thumb/egs.png?1649218020" + }, + { + "chainId": 1, + "address": "0x69ed89ecd35082e031fe52b75123f801db083306", + "name": "Kaeri", + "symbol": "KAERI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27977/thumb/63370e2a1f2bea31fc7f6977_512x512_v2-p-500-2.png?1666846544" + }, + { + "chainId": 1, + "address": "0x6628606c321faf52b7230a57b26c01b19aa68e82", + "name": "BitHash", + "symbol": "BT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13224/thumb/bt.png?1606358296" + }, + { + "chainId": 1, + "address": "0x09970aec766b6f3223aca9111555e99dc50ff13a", + "name": "Levolution", + "symbol": "LEVL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7370/thumb/L_Icon_Blue_200x200.png?1618983083" + }, + { + "chainId": 1, + "address": "0x7bfde33d790411a88d46e9e1be32fc86228891a4", + "name": "Shiba Universe", + "symbol": "SHIBU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25423/thumb/logocmc.png?1651737047" + }, + { + "chainId": 1, + "address": "0x7a647637e75d34a7798ba06bd1adf5c084bb5dd5", + "name": "Bestay", + "symbol": "BSY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12166/thumb/photo-2019-07-04-17-03-29.jpg?1597787199" + }, + { + "chainId": 1, + "address": "0xeb57bf569ad976974c1f861a5923a59f40222451", + "name": "Loomi", + "symbol": "LOOMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22919/thumb/C8miy1Qi_400x400.jpg?1643000828" + }, + { + "chainId": 1, + "address": "0x63f7b1b538a78cb699e5399621b3d2e047c40de4", + "name": "Maxity", + "symbol": "MAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26933/thumb/MAX_token_200.png?1666345433" + }, + { + "chainId": 1, + "address": "0x68c85b9f78f30a0df5ac5723e4e700037f185415", + "name": "AiWork", + "symbol": "AWO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15373/thumb/aiwork.PNG?1620691299" + }, + { + "chainId": 1, + "address": "0x4bb3205bf648b7f59ef90dee0f1b62f6116bc7ca", + "name": "Beyondfi", + "symbol": "BYN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14746/thumb/token_symbol.png?1669462137" + }, + { + "chainId": 1, + "address": "0x710aa623c2c881b0d7357bcf9aeedf660e606c22", + "name": "Hearts", + "symbol": "HEART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24121/thumb/heart.png?1646456042" + }, + { + "chainId": 1, + "address": "0x64cdf819d3e75ac8ec217b3496d7ce167be42e80", + "name": "InsurePal", + "symbol": "IPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1858/thumb/ipl.png?1547036172" + }, + { + "chainId": 1, + "address": "0x56bd0c900acaf04125ee26f546d6214634fd970f", + "name": "HubCoin", + "symbol": "HUB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25671/thumb/logo-200_%281%29.png?1653358021" + }, + { + "chainId": 1, + "address": "0xc969e16e63ff31ad4bcac3095c616644e6912d79", + "name": "Seed Venture", + "symbol": "SEED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10860/thumb/Seed.png?1585204998" + }, + { + "chainId": 1, + "address": "0x5a41290104b8f65ece9ed9d67a4d82f8080b7310", + "name": "Game Federation", + "symbol": "GFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26760/thumb/gft.png?1660311385" + }, + { + "chainId": 1, + "address": "0x65ccd72c0813ce6f2703593b633202a0f3ca6a0c", + "name": "Nestree", + "symbol": "EGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9362/thumb/nestree.png?1566529061" + }, + { + "chainId": 1, + "address": "0xbb1f24c0c1554b9990222f036b0aad6ee4caec29", + "name": "CryptoSoul", + "symbol": "SOUL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6723/thumb/cryptosoul.png?1547042952" + }, + { + "chainId": 1, + "address": "0x72f020f8f3e8fd9382705723cd26380f8d0c66bb", + "name": "PlotX", + "symbol": "PLOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12795/thumb/PlotX.png?1611109969" + }, + { + "chainId": 1, + "address": "0xb06b8186cc008a79fd6722b1eefad07c14e97da0", + "name": "Sign", + "symbol": "SIGN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26495/thumb/PWRjbqG9_400x400.png?1658303265" + }, + { + "chainId": 1, + "address": "0x274e7eb07b485cfde53d02270555213447570ac6", + "name": "SubDAO", + "symbol": "GOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28379/thumb/gov.png?1669972199" + }, + { + "chainId": 1, + "address": "0x485d17a6f1b8780392d53d64751824253011a260", + "name": "chrono tech", + "symbol": "TIME", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/604/thumb/time-32x32.png?1627130666" + }, + { + "chainId": 1, + "address": "0xbe1fa1303e2979ab4d4e5df3d1c6e3656acab027", + "name": "Dripto", + "symbol": "DRYP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25569/thumb/dryp.png?1652602736" + }, + { + "chainId": 1, + "address": "0x59c6900949ad1835f07a04321f4d9934a054e114", + "name": "TroveDAO", + "symbol": "TROVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24764/thumb/coin.png?1655723800" + }, + { + "chainId": 1, + "address": "0xbe0c826f17680d8da620855be89dd6544c034ca1", + "name": "BankEth", + "symbol": "BANKETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17401/thumb/BankEth_200x200.png?1627529730" + }, + { + "chainId": 1, + "address": "0x7ca5af5ba3472af6049f63c1abc324475d44efc1", + "name": "KONDUX", + "symbol": "KNDX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28244/thumb/kndx.png?1668587937" + }, + { + "chainId": 1, + "address": "0xac8e13ecc30da7ff04b842f21a62a1fb0f10ebd5", + "name": "BabyDoge ETH", + "symbol": "BABYDOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17166/thumb/logo_256px_%281%29.png?1626684127" + }, + { + "chainId": 1, + "address": "0x77a7b7defcc0c582dadb9d2375975e2a75fb4538", + "name": "Fan2Go", + "symbol": "FNTG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28180/thumb/ftgo_logo%28200x200%29.png?1668253761" + }, + { + "chainId": 1, + "address": "0x003e0af2916e598fa5ea5cb2da4edfda9aed9fde", + "name": "Basis Dollar", + "symbol": "BSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13409/thumb/bdollar_logo.png?1608263890" + }, + { + "chainId": 1, + "address": "0x68a118ef45063051eac49c7e647ce5ace48a68a5", + "name": "Based Money", + "symbol": "BASED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12115/thumb/Based.png?1597261198" + }, + { + "chainId": 1, + "address": "0x93c9175e26f57d2888c7df8b470c9eea5c0b0a93", + "name": "B cube ai", + "symbol": "BCUBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15948/thumb/bcube.PNG?1622511353" + }, + { + "chainId": 1, + "address": "0xef952363c1d990a2fa58f8b379a9fa33bad1dfd1", + "name": "LynKey", + "symbol": "LYNK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/25069/thumb/oOcTsBsg_400x400_%281%29.jpg?1650038695" + }, + { + "chainId": 1, + "address": "0x34364bee11607b1963d66bca665fde93fca666a8", + "name": "YOU Chain", + "symbol": "YOU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4649/thumb/youchain-logo.jpg?1547039915" + }, + { + "chainId": 1, + "address": "0x662b67d00a13faf93254714dd601f5ed49ef2f51", + "name": "Orbit Chain", + "symbol": "ORC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9782/thumb/-p1Br7oh_400x400.png?1571716593" + }, + { + "chainId": 1, + "address": "0x73484a262730d1d422610729e828346f9b2ff480", + "name": "BRCP", + "symbol": "BRCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14388/thumb/brcp-500x500-verde.png?1615855378" + }, + { + "chainId": 1, + "address": "0x686c650dbcfeaa75d09b883621ad810f5952bd5d", + "name": "AAX", + "symbol": "AAB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11073/thumb/GluwoJk__400x400.jpg?1587969347" + }, + { + "chainId": 1, + "address": "0xd70240dd62f4ea9a6a2416e0073d72139489d2aa", + "name": "GLYPH Vault NFTX ", + "symbol": "GLYPH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17050/thumb/Glyph.png?1626149071" + }, + { + "chainId": 1, + "address": "0x501e8726d06cdef66f3e0cb67f54924cca1cc894", + "name": "BRMV", + "symbol": "BRMV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14389/thumb/brmv-logo-256px.png?1615856173" + }, + { + "chainId": 1, + "address": "0xacfe45c352c902ae3a3f9b6bfe6ec994c5d791bf", + "name": "megaBonk", + "symbol": "MBONK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14996/thumb/Bonk_v2_gecko.png?1619391636" + }, + { + "chainId": 1, + "address": "0xa5f1dbb0e55bc31f32c6d032bee330288490e722", + "name": "Day By Day", + "symbol": "DBD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21691/thumb/DBD-icon_200x200_%281%29.png?1639721079" + }, + { + "chainId": 1, + "address": "0x3ecf9840deb8e3c395e1941fc39ceb662bf5a1dd", + "name": "New Year Resolution", + "symbol": "NYR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22201/thumb/Q-5kE0wd_400x400.jpg?1641193367" + }, + { + "chainId": 1, + "address": "0x4688a8b1f292fdab17e9a90c8bc379dc1dbd8713", + "name": "Cover Protocol", + "symbol": "COVER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13563/thumb/1_eWBbDaqpxXqt7WYPSP4qSw.jpeg?1609822578" + }, + { + "chainId": 1, + "address": "0xc3b5284b2c0cfa1871a6ac63b6d6ee43c08bdc79", + "name": "BGAN Vault NFTX ", + "symbol": "BGAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17051/thumb/bgan.png?1626149084" + }, + { + "chainId": 1, + "address": "0x3d3af44cf092a49280e316f09c8f20ecf97bc933", + "name": "UCX", + "symbol": "UCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10131/thumb/UCX_200200.png?1576186720" + }, + { + "chainId": 1, + "address": "0x69692d3345010a207b759a7d1af6fc7f38b35c5e", + "name": "CHADS VC", + "symbol": "CHADS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12455/thumb/Chad_VC.png?1599940044" + }, + { + "chainId": 1, + "address": "0x84f710bae3316a74fb0fcb01904d2578a4cc6a26", + "name": "PHILLIPS PAY COIN", + "symbol": "PPC", + "decimals": 1, + "logoURI": "https://assets.coingecko.com/coins/images/10311/thumb/ppc.PNG?1588127720" + }, + { + "chainId": 1, + "address": "0x6afcff9189e8ed3fcc1cffa184feb1276f6a82a5", + "name": "PolkaPet World", + "symbol": "PETS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19409/thumb/pets_polka.PNG?1635211453" + }, + { + "chainId": 1, + "address": "0x7b32e70e8d73ac87c1b342e063528b2930b15ceb", + "name": "Robo Inu Finance", + "symbol": "RBIF", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20821/thumb/O68Gs5SE_400x400.jpg?1654929220" + }, + { + "chainId": 1, + "address": "0x9b02dd390a603add5c07f9fd9175b7dabe8d63b7", + "name": "Shopping io OLD", + "symbol": "SPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13537/thumb/SPI_Token.png?1623763713" + }, + { + "chainId": 1, + "address": "0xaac41ec512808d64625576eddd580e7ea40ef8b2", + "name": "Gameswap", + "symbol": "GSWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13026/thumb/gameswap.jpg?1604456704" + }, + { + "chainId": 1, + "address": "0xeccf15a4b5976a1365baed5297058b4ca42777c0", + "name": "Nosturis", + "symbol": "NTRS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9990/thumb/47010860_203643113858754_2966343352238211072_n.jpg?1574373395" + }, + { + "chainId": 1, + "address": "0xdb5c3c46e28b53a39c255aa39a411dd64e5fed9c", + "name": "Neos Credits", + "symbol": "NCR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17935/thumb/s4C4tVi.png?1629860208" + }, + { + "chainId": 1, + "address": "0xb81d70802a816b5dacba06d708b5acf19dcd436d", + "name": "Dextoken Governance", + "symbol": "DEXG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12223/thumb/dextoken-logo-v2_200.png?1598408669" + }, + { + "chainId": 1, + "address": "0xada62f7ccd6af6cacff04accbc4f56f3d4ffd4ef", + "name": "PlayFuel", + "symbol": "PLF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10313/thumb/BNXcW4kq_400x400.jpg?1577833532" + }, + { + "chainId": 1, + "address": "0x171d76d931529384639bc9aad5b77b77041ed604", + "name": "MetaOctagon", + "symbol": "MOTG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26496/thumb/iJoylNuO_400x400.jpeg?1658304109" + }, + { + "chainId": 1, + "address": "0xba98c0fbebc892f5b07a42b0febd606913ebc981", + "name": "meh", + "symbol": "MEH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27714/thumb/mlogo.png?1665453127" + }, + { + "chainId": 1, + "address": "0xb3cb8d5aeff0f4d1f432f353309f47b885e404e3", + "name": "MEVerse", + "symbol": "MEV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24566/thumb/0sp1DWVw_400x400.png?1648191682" + }, + { + "chainId": 1, + "address": "0x2604fa406be957e542beb89e6754fcde6815e83f", + "name": "PlayKey", + "symbol": "PKT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2116/thumb/playkey.png?1548331394" + }, + { + "chainId": 1, + "address": "0x468ab3b1f63a1c14b361bc367c3cc92277588da1", + "name": "Yeld Finance", + "symbol": "YELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12389/thumb/X4bTDcZ.png?1622177749" + }, + { + "chainId": 1, + "address": "0xca47bc04ecfcd324b238ed411741efb65b3c777b", + "name": "Ecosystem Coin Network", + "symbol": "ECN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/18529/thumb/WeChat_Image_20210928174723.jpg?1632822490" + }, + { + "chainId": 1, + "address": "0xd73cab6a16c67cb79fc61f8c13dfec4f32f9dcbf", + "name": "Inusanity", + "symbol": "INUSANITY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27719/thumb/inusanity200.png?1665462344" + }, + { + "chainId": 1, + "address": "0x692accdd8b86692427e0aa4752ae917df01cc56f", + "name": "Sunrise", + "symbol": "SUNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17601/thumb/ticker_sunc_200_200.png?1628864229" + }, + { + "chainId": 1, + "address": "0xa9598333b99d14d90bc81cad8af82c4c70625e75", + "name": "Metis MTS", + "symbol": "MTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13218/thumb/1Vd_NuQU_400x400.jpg?1606292031" + }, + { + "chainId": 1, + "address": "0xe225aca29524bb65fd82c79a9602f3b4f9c6fe3f", + "name": "Tratok", + "symbol": "TRAT", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/6791/thumb/tratok.png?1547043075" + }, + { + "chainId": 1, + "address": "0xd9c2d319cd7e6177336b0a9c93c21cb48d84fb54", + "name": "HAPI", + "symbol": "HAPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14298/thumb/R9i2HjAL_400x400.jpg?1615332438" + }, + { + "chainId": 1, + "address": "0x8df586aa346c3d9d1c99a21316a2735d71355ec8", + "name": "Wallstreetbets com", + "symbol": "WSB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24170/thumb/18622.png?1646718687" + }, + { + "chainId": 1, + "address": "0x916c5de09cf63f6602d1e1793fb41f6437814a62", + "name": "JACY", + "symbol": "JACY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19740/thumb/tBwbvjZK_400x400.jpg?1641803022" + }, + { + "chainId": 1, + "address": "0x882e5b370d595e50c24b2a0e7a94e87cc32adda1", + "name": "X Consoles", + "symbol": "GAME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21616/thumb/photo_2021-12-25_01-03-14.jpg?1640519963" + }, + { + "chainId": 1, + "address": "0xd5930c307d7395ff807f2921f12c5eb82131a789", + "name": "Bolt", + "symbol": "BOLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4489/thumb/bolt.png?1555648257" + }, + { + "chainId": 1, + "address": "0x20f7a3ddf244dc9299975b4da1c39f8d5d75f05a", + "name": "Sapien", + "symbol": "SPN", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/2596/thumb/Sapien_Token_450x450.png?1607560493" + }, + { + "chainId": 1, + "address": "0x362bc4b0b2a8134d87ace9143d284a2eced3fd2a", + "name": "Dar afaka Sports Club", + "symbol": "DSK", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/25980/thumb/20572.png?1655113316" + }, + { + "chainId": 1, + "address": "0xceeb07dd26b36287b6d109f0b06d7e8202ce8c1d", + "name": "Got Guaranteed", + "symbol": "GOTG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26107/thumb/%EA%B0%93%EC%A7%80%EB%A1%9C%EA%B3%A0.png?1655882278" + }, + { + "chainId": 1, + "address": "0x98968f0747e0a261532cacc0be296375f5c08398", + "name": "MOONCAT Vault NFTX ", + "symbol": "MOONCAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17055/thumb/Mooncats.png?1626149563" + }, + { + "chainId": 1, + "address": "0xde1e0ae6101b46520cf66fdc0b1059c5cc3d106c", + "name": "DeltaChain", + "symbol": "DELTA", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5794/thumb/deltachain.png?1547041664" + }, + { + "chainId": 1, + "address": "0x5d5e244660ca05c42073c9a526616d99f2c99516", + "name": "Game Tree", + "symbol": "GTCOIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24719/thumb/hUEmunGU_400x400.jpg?1648696738" + }, + { + "chainId": 1, + "address": "0x0778cc2e8bbad3d483e82371606d100cc8604522", + "name": "LHCoin", + "symbol": "LHCOIN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6709/thumb/lhcoin.jpg?1547042926" + }, + { + "chainId": 1, + "address": "0xc713e5e149d5d0715dcd1c156a020976e7e56b88", + "name": "Aave MKR", + "symbol": "AMKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14248/thumb/aMKR.ac965178.png?1615528346" + }, + { + "chainId": 1, + "address": "0x50de6856358cc35f3a9a57eaaa34bd4cb707d2cd", + "name": "Razor Network", + "symbol": "RAZOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13797/thumb/icon.png?1611919354" + }, + { + "chainId": 1, + "address": "0xac51066d7bec65dc4589368da368b212745d63e8", + "name": "My Neighbor Alice", + "symbol": "ALICE", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14375/thumb/alice_logo.jpg?1615782968" + }, + { + "chainId": 1, + "address": "0x2e1368fe7b9cbb3f777c2d85e9e804f8f67d7074", + "name": "Shibboo Inu", + "symbol": "SHIBBOO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19601/thumb/shibboo.jpeg?1635491024" + }, + { + "chainId": 1, + "address": "0x86772b1409b61c639eaac9ba0acfbb6e238e5f83", + "name": "Indexed Finance", + "symbol": "NDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13546/thumb/indexed-light.74bb5471.png?1609712728" + }, + { + "chainId": 1, + "address": "0xa49d7499271ae71cd8ab9ac515e6694c755d400c", + "name": "Mute", + "symbol": "MUTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14331/thumb/MUTE.png?1617618967" + }, + { + "chainId": 1, + "address": "0xa3c4dc4a9ce2a6b40b57f25f8b50decc2c64dec2", + "name": "SeedSwap", + "symbol": "SNFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15300/thumb/ZkJWmP1.png?1629463853" + }, + { + "chainId": 1, + "address": "0xfb22ced41b1267da411f68c879f4defd0bd4796a", + "name": "Ziot", + "symbol": "ZIOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14546/thumb/1_iSvPXhw4frHgjyMejcmoKQ.png?1616973916" + }, + { + "chainId": 1, + "address": "0xb1f136a74e18e4e2921febbf25820d1bb65b5647", + "name": "hiPunks", + "symbol": "HIPUNKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26739/thumb/hipunks.png?1659946062" + }, + { + "chainId": 1, + "address": "0x6f40d4a6237c257fff2db00fa0510deeecd303eb", + "name": "Instadapp", + "symbol": "INST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14688/thumb/30hFM0-n_400x400.jpg?1617786420" + }, + { + "chainId": 1, + "address": "0x3cbc780d2934d55a06069e837fabd3e6fc23dab0", + "name": "DBX", + "symbol": "DBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15682/thumb/logo.png?1646903349" + }, + { + "chainId": 1, + "address": "0x24700a297960e8477ce3ca6c58b70a7af3410398", + "name": "Oasis City", + "symbol": "OSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7038/thumb/wJepb5N.png?1550038108" + }, + { + "chainId": 1, + "address": "0xb8366948b4a3f07bcbf14eb1739daa42a26b07c4", + "name": "VALOBIT", + "symbol": "VBIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12394/thumb/Untitled-design-3.png?1599550715" + }, + { + "chainId": 1, + "address": "0xe530441f4f73bdb6dc2fa5af7c3fc5fd551ec838", + "name": "GSENetwork", + "symbol": "GSE", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/4776/thumb/gsenetwork.png?1547743285" + }, + { + "chainId": 1, + "address": "0x08c32b0726c5684024ea6e141c50ade9690bbdcc", + "name": "Stratos", + "symbol": "STOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16213/thumb/token_512x512.png?1623313898" + }, + { + "chainId": 1, + "address": "0x419b8ed155180a8c9c64145e76dad49c0a4efb97", + "name": "AltEstate", + "symbol": "ALT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3076/thumb/AltEstate_Token.jpg?1547037426" + }, + { + "chainId": 1, + "address": "0x3c48ca59bf2699e51d4974d4b6d284ae52076e5e", + "name": "Capital DAO Starter", + "symbol": "CDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20332/thumb/cds.png?1661762062" + }, + { + "chainId": 1, + "address": "0x6e9730ecffbed43fd876a264c982e254ef05a0de", + "name": "Nord Finance", + "symbol": "NORD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13630/thumb/nord.jpg?1610465136" + }, + { + "chainId": 1, + "address": "0x69570f3e84f51ea70b7b68055c8d667e77735a25", + "name": "Betswap gg", + "symbol": "BSGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22496/thumb/betswap.jpg?1641924550" + }, + { + "chainId": 1, + "address": "0x20910e5b5f087f6439dfcb0dda4e27d1014ac2b8", + "name": "BananaTok", + "symbol": "BNA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10289/thumb/sMCxdYBa_400x400.jpg?1577013480" + }, + { + "chainId": 1, + "address": "0xd714d91a169127e11d8fab3665d72e8b7ef9dbe2", + "name": "BlackHole Protocol", + "symbol": "BLACK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15124/thumb/blackhole.PNG?1620094580" + }, + { + "chainId": 1, + "address": "0x6ff1bfa14a57594a5874b37ff6ac5efbd9f9599a", + "name": "TotemFi", + "symbol": "TOTM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14680/thumb/TOTM.png?1617721704" + }, + { + "chainId": 1, + "address": "0x37fc4b48ce93469dbea9918468993c735049642a", + "name": "CropBytes", + "symbol": "CBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19907/thumb/cbx.png?1647698560" + }, + { + "chainId": 1, + "address": "0x40803cea2b2a32bda1be61d3604af6a814e70976", + "name": "Spool DAO", + "symbol": "SPOOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21532/thumb/spool.png?1639388809" + }, + { + "chainId": 1, + "address": "0x53c8395465a84955c95159814461466053dedede", + "name": "DeGate", + "symbol": "DG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14415/thumb/DG_token_brand_web_rgb_blue.png?1669460087" + }, + { + "chainId": 1, + "address": "0x15f0eedf9ce24fc4b6826e590a8292ce5524a1da", + "name": "Decentralized Nations", + "symbol": "DENA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22167/thumb/denations.PNG?1641166526" + }, + { + "chainId": 1, + "address": "0x07a858fc699f99ddf2b186bf162fd7f4d42f7f63", + "name": "ARTII", + "symbol": "ARTII", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20767/thumb/logo-img.png?1637654806" + }, + { + "chainId": 1, + "address": "0x8eb5bd8c9ab0f8ad28e94693f3c889f490be2ab0", + "name": "PoS 32", + "symbol": "POS32", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27358/thumb/90532f66-9158-4bd4-8928-bcb8ec012579.png?1663663764" + }, + { + "chainId": 1, + "address": "0x1c1c14a6b5074905ce5d367b0a7e098b58ebfd47", + "name": "FIDEX Exchange", + "symbol": "FEX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6843/thumb/1LC9qeLf_400x400.jpg?1547043159" + }, + { + "chainId": 1, + "address": "0x8b40761142b9aa6dc8964e61d0585995425c3d94", + "name": "Tripio", + "symbol": "TRIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4648/thumb/tripio-logo.jpg?1547039914" + }, + { + "chainId": 1, + "address": "0xa5f2211b9b8170f694421f2046281775e8468044", + "name": "THORSwap", + "symbol": "THOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19292/thumb/THORSwap_Logo-removebg-preview.png?1657210461" + }, + { + "chainId": 1, + "address": "0x6e36556b3ee5aa28def2a8ec3dae30ec2b208739", + "name": "BUILD Finance", + "symbol": "BUILD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12380/thumb/build.PNG?1599463828" + }, + { + "chainId": 1, + "address": "0x2f85e502a988af76f7ee6d83b7db8d6c0a823bf9", + "name": "LatiumX", + "symbol": "LATX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3500/thumb/latium.jpg?1547038261" + }, + { + "chainId": 1, + "address": "0x831091da075665168e01898c6dac004a867f1e1b", + "name": "Gains Farm", + "symbol": "GFARM2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13703/thumb/gfarm_v2.png?1611035398" + }, + { + "chainId": 1, + "address": "0xef497b970f50286a9805b91809b8615e6d0ef19b", + "name": "HARU", + "symbol": "HARU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26786/thumb/haru.png?1661062811" + }, + { + "chainId": 1, + "address": "0x2ba592f78db6436527729929aaf6c908497cb200", + "name": "Cream", + "symbol": "CREAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11976/thumb/Cream.png?1596593418" + }, + { + "chainId": 1, + "address": "0x5b685863494c33f344081f75e5430c260c224a32", + "name": "CORE MultiChain", + "symbol": "CMCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18848/thumb/O4IzY2CQ_400x400.png?1633590798" + }, + { + "chainId": 1, + "address": "0x7e8c149f70437eba6785f9059190a5b08abf03de", + "name": "MiniBitcoin", + "symbol": "MBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7180/thumb/logo_brown.png?1547043731" + }, + { + "chainId": 1, + "address": "0xc6065b9fc8171ad3d29bad510709249681758972", + "name": "Wallfair", + "symbol": "WFAIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18920/thumb/wallfair_logo.png?1633942136" + }, + { + "chainId": 1, + "address": "0x2162f572b25f7358db9376ab58a947a4e45cede1", + "name": "LABEL Foundation", + "symbol": "LBL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19202/thumb/tele_profile_%EB%8C%80%EC%A7%80_1_-_%282%29.png?1634680838" + }, + { + "chainId": 1, + "address": "0x243cacb4d5ff6814ad668c3e225246efa886ad5a", + "name": "Shina Inu", + "symbol": "SHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25208/thumb/coingecko-shina-purple-bg.png?1655266989" + }, + { + "chainId": 1, + "address": "0xd1420af453fd7bf940573431d416cace7ff8280c", + "name": "Answer Governance", + "symbol": "AGOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14383/thumb/AgoV_Logo1.png?1622448433" + }, + { + "chainId": 1, + "address": "0x419c4db4b9e25d6db2ad9691ccb832c8d9fda05e", + "name": "Dragonchain", + "symbol": "DRGN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1289/thumb/dragonchain.png?1547957761" + }, + { + "chainId": 1, + "address": "0xcfbf70e33d5163e25b0dad73955c1bd9e8cd8ba2", + "name": "WinStars Live", + "symbol": "WNL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4178/thumb/HEq48ZDOCvVTVFw8J8qws9les1E27b_8F_k34sVhpwULn3muT66wiQI9HjNNUhGLELkGGSi0daPgxt8YHjbRqHzX1uurAbySQdtr_FW0GRBNN3CEWGU03Vn_z9NdJiGHV193Y_RWPDAGlm69ISIMSdTxT34VycLZTMrgJeWaNXrblBrXpPprJXKDJCKsa_Wt1jofCsygfNLdWQ0j_.jpg?1563768641" + }, + { + "chainId": 1, + "address": "0x8cb1d155a5a1d5d667611b7710920fd9d1cd727f", + "name": "Aircoins", + "symbol": "AIRX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9201/thumb/Aircoins.png?1591615033" + }, + { + "chainId": 1, + "address": "0x9a24b8e8a6d4563c575a707b1275381119298e60", + "name": "EVNY", + "symbol": "EVNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14555/thumb/envy.jpg?1616999935" + }, + { + "chainId": 1, + "address": "0x7f280dac515121dcda3eac69eb4c13a52392cace", + "name": "Fancy Games", + "symbol": "FNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21367/thumb/fnc.png?1639025576" + }, + { + "chainId": 1, + "address": "0x31429d1856ad1377a8a0079410b297e1a9e214c2", + "name": "ANGLE", + "symbol": "ANGLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19060/thumb/ANGLE_Token-light.png?1666774221" + }, + { + "chainId": 1, + "address": "0x549e4d92285ff5a16c9484ff79211e4358b1f202", + "name": "Infinite Arcade TIC", + "symbol": "TIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25919/thumb/VNReVzc5Sg6NqHONgxEQ_4BI9yq3820sYQx0R.jpg?1654593140" + }, + { + "chainId": 1, + "address": "0x7869c4a1a3f6f8684fbcc422a21ad7abe3167834", + "name": "Pivot", + "symbol": "PVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8977/thumb/j5ovdTKP_400x400.png?1563405624" + }, + { + "chainId": 1, + "address": "0x4da34f8264cb33a5c9f17081b9ef5ff6091116f4", + "name": "ELYFI", + "symbol": "ELFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23733/thumb/elyfi_logo.png?1645691480" + }, + { + "chainId": 1, + "address": "0x106538cc16f938776c7c180186975bca23875287", + "name": "Basis Share", + "symbol": "BAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13251/thumb/BAS.png?1613231139" + }, + { + "chainId": 1, + "address": "0x8f1135ea4f8946949441716d66e5390c5a990df0", + "name": "MesChain", + "symbol": "MES", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9719/thumb/TtPovcoX_400x400.jpg?1571263455" + }, + { + "chainId": 1, + "address": "0x28fac5334c9f7262b3a3fe707e250e01053e07b5", + "name": "IdleUSDT Risk Adjusted ", + "symbol": "IDLEUSDTSAFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11931/thumb/idleusdt-safe.png?1596263270" + }, + { + "chainId": 1, + "address": "0x2001f2a0cf801ecfda622f6c28fb6e10d803d969", + "name": "CoinLoan", + "symbol": "CLT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1713/thumb/blue-logo-transparent-200x200.png?1595912819" + }, + { + "chainId": 1, + "address": "0x2c000c0093de75a8fa2fccd3d97b314e20b431c3", + "name": "Huobi Litecoin", + "symbol": "HLTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14110/thumb/HLTC.png?1614335967" + }, + { + "chainId": 1, + "address": "0x8a0cdfab62ed35b836dc0633482798421c81b3ec", + "name": "Spherium", + "symbol": "SPHRI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17787/thumb/Group_15.png?1629252159" + }, + { + "chainId": 1, + "address": "0xba21ef4c9f433ede00badefcc2754b8e74bd538a", + "name": "Swapfolio", + "symbol": "SWFL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12263/thumb/swapfolio-token-logo-icon-symbol-256-256.png?1598593097" + }, + { + "chainId": 1, + "address": "0x9135d92e3a34e2a94e4474b74b9dc2d51118eed5", + "name": "Ulgen Hash Power", + "symbol": "UHP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11897/thumb/download_%2816%29.png?1595892702" + }, + { + "chainId": 1, + "address": "0x965d79f1a1016b574a62986e13ca8ab04dfdd15c", + "name": "M2", + "symbol": "M2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18239/thumb/m2_%281%29.png?1631068956" + }, + { + "chainId": 1, + "address": "0xd4eb79a193e7e1a7b998202a9407e5ce3ff02b4f", + "name": "Web69", + "symbol": "WEB69", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26928/thumb/web69200x200.png?1660880767" + }, + { + "chainId": 1, + "address": "0x0b342c51d1592c41068d5d4b4da4a68c0a04d5a4", + "name": "OneSwap DAO", + "symbol": "ONES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12552/thumb/logo.png?1600682344" + }, + { + "chainId": 1, + "address": "0x5afff9876c1f98b7d2b53bcb69eb57e92408319f", + "name": "metavisa", + "symbol": "MESA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23246/thumb/twitteravatar_circle.png?1653551813" + }, + { + "chainId": 1, + "address": "0x07150e919b4de5fd6a63de1f9384828396f25fdc", + "name": "Base Protocol", + "symbol": "BASE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13265/thumb/200x200green.png?1607650121" + }, + { + "chainId": 1, + "address": "0xd2287a52287dd64ae2c690d74322e2e345dc8f69", + "name": "BabyWhale", + "symbol": "BBW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24168/thumb/babywhale_32.png?1646716918" + }, + { + "chainId": 1, + "address": "0x6692de64716a177c15360d8d010bc522bbc530a0", + "name": "Talent", + "symbol": "TNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25563/thumb/tnt.png?1652521166" + }, + { + "chainId": 1, + "address": "0x8916187112fd6e3624a80c42fa354cd9756e695f", + "name": "Shibird", + "symbol": "SHIRD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28074/thumb/CGLOGO-1.png?1667386097" + }, + { + "chainId": 1, + "address": "0x0ab39ac604f992aaec3c36de337c3cd3917a7d26", + "name": "KEEPs Coin", + "symbol": "KVERSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19622/thumb/keeps.PNG?1635498049" + }, + { + "chainId": 1, + "address": "0xb7c9e99da8a857ce576a830a9c19312114d9de02", + "name": "Maximus TEAM", + "symbol": "TEAM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27711/thumb/TEAM.png?1665451692" + }, + { + "chainId": 1, + "address": "0xa223e8a8d445b5b9a2f477c00ae79267a8f94225", + "name": "Meme Protocol", + "symbol": "MEME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27795/thumb/memeprotocol.png?1665821284" + }, + { + "chainId": 1, + "address": "0xc3dd23a0a854b4f9ae80670f528094e9eb607ccb", + "name": "Trendering", + "symbol": "TRND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11941/thumb/trnd-ico-200.png?1605147194" + }, + { + "chainId": 1, + "address": "0x358bd0d980e031e23eba9aa793926857703783bd", + "name": "Aave AMM BptWBTCWETH", + "symbol": "AAMMBPTWBTCWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17260/thumb/aAmmBptWBTCWETH.png?1626959325" + }, + { + "chainId": 1, + "address": "0xdef1ca1fb7fbcdc777520aa7f396b4e015f497ab", + "name": "CoW Protocol", + "symbol": "COW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24384/thumb/cow.png?1660960589" + }, + { + "chainId": 1, + "address": "0xaf1250fa68d7decd34fd75de8742bc03b29bd58e", + "name": "Invictus Hyperion Fund", + "symbol": "IHF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3747/thumb/ihp.png?1547038807" + }, + { + "chainId": 1, + "address": "0xe38b72d6595fd3885d1d2f770aa23e94757f91a1", + "name": "TecraCoin ERC20", + "symbol": "TCR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7836/thumb/tcr.jpg?1604903462" + }, + { + "chainId": 1, + "address": "0x61bfc979ea8160ede9b862798b7833a97bafa02a", + "name": "RELEASE", + "symbol": "REL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5387/thumb/release.jpg?1547041000" + }, + { + "chainId": 1, + "address": "0xe0df31d06d72b2f5231489af0edc422b372f49f1", + "name": "MarsX", + "symbol": "MX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19659/thumb/png256x256.png?1636908533" + }, + { + "chainId": 1, + "address": "0xd578779dbc9252218e12d18d628e3cb27e4a56f2", + "name": "Britto", + "symbol": "BRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22830/thumb/britto-coin-logo.jpg?1642664707" + }, + { + "chainId": 1, + "address": "0x0789dbae94fb18e5789b8e4489bcb7a1adb58622", + "name": "FISCO Coin", + "symbol": "FSCC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6507/thumb/AnyConv.com__fscc_icon_fin.png?1608779052" + }, + { + "chainId": 1, + "address": "0x8713d26637cf49e1b6b4a7ce57106aabc9325343", + "name": "Content Neutrality Network", + "symbol": "CNN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2787/thumb/cnn_logo_big.png?1547036967" + }, + { + "chainId": 1, + "address": "0x44f262622248027f8e2a8fb1090c4cf85072392c", + "name": "Planet Inverse", + "symbol": "XIV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14231/thumb/photo_2021-06-07_22-10-41.jpg?1623075271" + }, + { + "chainId": 1, + "address": "0x66079fb941c03f848f8d6601190c8b876461237a", + "name": "DIVI LAND", + "symbol": "DVLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25559/thumb/dvld.jpg?1652441515" + }, + { + "chainId": 1, + "address": "0x06a87f6afec4a739c367bef69eefe383d27106bd", + "name": "Scoobi Doge", + "symbol": "SCOOBI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16101/thumb/scoobi_doge.jpg?1622963978" + }, + { + "chainId": 1, + "address": "0x5ca5a5efb57dbaf4462edbd15da889448b1919ed", + "name": "RocketToken", + "symbol": "RKTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25052/thumb/5F8FyJDt_400x400.jpg?1649925450" + }, + { + "chainId": 1, + "address": "0xcfeaead4947f0705a14ec42ac3d44129e1ef3ed5", + "name": "Notional Finance", + "symbol": "NOTE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/20282/thumb/NOTE-340x340.png?1636821924" + }, + { + "chainId": 1, + "address": "0x3757232b55e60da4a8793183ac030cfce4c3865d", + "name": "YDragon", + "symbol": "YDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17807/thumb/icon.png?1629302175" + }, + { + "chainId": 1, + "address": "0xf52cdcd458bf455aed77751743180ec4a595fd3f", + "name": "IdleSUSD Yield ", + "symbol": "IDLESUSDYIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11934/thumb/idlesusdv3mmaxyield_32.png?1596263703" + }, + { + "chainId": 1, + "address": "0xdb792b1d8869a7cfc34916d6c845ff05a7c9b789", + "name": "Cross Chain BCH", + "symbol": "CCBCH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/19747/thumb/ccBCH.png?1635822615" + }, + { + "chainId": 1, + "address": "0x2e65e12b5f0fd1d58738c6f38da7d57f5f183d1c", + "name": "Tepleton", + "symbol": "TEP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9622/thumb/tep.PNG?1569856834" + }, + { + "chainId": 1, + "address": "0x0fd67b4ceb9b607ef206904ec73459c4880132c9", + "name": "ShoeFy", + "symbol": "SHOE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19082/thumb/SHOEFY.jpg?1634371392" + }, + { + "chainId": 1, + "address": "0xf0ee6b27b759c9893ce4f094b49ad28fd15a23e4", + "name": "Enigma", + "symbol": "ENG", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1007/thumb/enigma-logo.png?1547034914" + }, + { + "chainId": 1, + "address": "0xf6a9baef8c66e9b24152014222871c8e02d0ee97", + "name": "CelsiusX Wrapped BTC", + "symbol": "CXBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25535/thumb/cxBTC.png?1652252129" + }, + { + "chainId": 1, + "address": "0x058bc8ef040bd3971418e36aa88b64899378ccf4", + "name": "DONA", + "symbol": "DONA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18429/thumb/DONA.jpg?1631889823" + }, + { + "chainId": 1, + "address": "0xa42f266684ac2ad6ecb00df95b1c76efbb6f136c", + "name": "Cash Tech", + "symbol": "CATE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14529/thumb/CG.jpg?1624471293" + }, + { + "chainId": 1, + "address": "0xc7c36ee729968944a86e0cd504deccd3b0edbae1", + "name": "microNFT", + "symbol": "MNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27510/thumb/qEXG4boD_400x400.jpeg?1664349800" + }, + { + "chainId": 1, + "address": "0x0def8d8adde14c9ef7c2a986df3ea4bd65826767", + "name": "DefiCliq", + "symbol": "CLIQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13242/thumb/deficliq_logo.png?1606660146" + }, + { + "chainId": 1, + "address": "0x3ea8ea4237344c9931214796d9417af1a1180770", + "name": "FluxProtocol", + "symbol": "FLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21137/thumb/flux-flx.jpeg?1638372222" + }, + { + "chainId": 1, + "address": "0xed025a9fe4b30bcd68460bca42583090c2266468", + "name": "Ripio Coin", + "symbol": "RPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24901/thumb/624e429cffe3fe0001456cb8_01_rpc-icon.png?1649324477" + }, + { + "chainId": 1, + "address": "0x9f5f3cfd7a32700c93f971637407ff17b91c7342", + "name": "Scry info", + "symbol": "DDD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2569/thumb/Scry.info.jpg?1547036695" + }, + { + "chainId": 1, + "address": "0x96184d9c811ea0624fc30c80233b1d749b9e485b", + "name": "Dapp com", + "symbol": "DAPPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8282/thumb/dappt_logo.png?1593074788" + }, + { + "chainId": 1, + "address": "0x406b9dca8b52f08385014ec1ed1cf6a0d5c01289", + "name": "Meishu", + "symbol": "MEISHU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24112/thumb/LDtBuFcu_400x400.jpg?1646378468" + }, + { + "chainId": 1, + "address": "0x0327112423f3a68efdf1fcf402f6c5cb9f7c33fd", + "name": "PieDAO BTC ", + "symbol": "BTC++", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10959/thumb/BTC__.png?1586499443" + }, + { + "chainId": 1, + "address": "0x331a4589516eae384ea5f557853af6af73b9534e", + "name": "Token CashPay", + "symbol": "TCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11616/thumb/559059354_256256.png?1591932551" + }, + { + "chainId": 1, + "address": "0xd341d1680eeee3255b8c4c75bcce7eb57f144dae", + "name": "SoMee Social OLD ", + "symbol": "ONG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1286/thumb/So_Mee_logo_icons_11.png?1581305902" + }, + { + "chainId": 1, + "address": "0x70008f18fc58928dce982b0a69c2c21ff80dca54", + "name": "X7R", + "symbol": "X7R", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27710/thumb/X7R.png?1665314632" + }, + { + "chainId": 1, + "address": "0x5cac718a3ae330d361e39244bf9e67ab17514ce8", + "name": "Cosplay Token", + "symbol": "COT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21294/thumb/brave_ZxsjzUc8xn.png?1638874098" + }, + { + "chainId": 1, + "address": "0x5aa7c403c7de4b3bb0cc07079a03e389671a4771", + "name": "Ibiza", + "symbol": "IBZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19349/thumb/AZHnAHiY_400x400.jpg?1635127261" + }, + { + "chainId": 1, + "address": "0x593114f03a0a575aece9ed675e52ed68d2172b8c", + "name": "BidiPass", + "symbol": "BDP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3890/thumb/AxiFAoHc_400x400.jpg?1567461770" + }, + { + "chainId": 1, + "address": "0x82a77710495a35549d2add797412b4a4497d33ef", + "name": "Dogz", + "symbol": "DOGZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7544/thumb/dogz.png?1604655282" + }, + { + "chainId": 1, + "address": "0x74bff2018687b8a1ff7132e13cd4fdc763725bcf", + "name": "Credit Suisse Inu", + "symbol": "CSI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27612/thumb/Credit-Suisse-Inu.jpg?1664853199" + }, + { + "chainId": 1, + "address": "0x8af38d3530bbd802ff2d132ae361897aca004ec1", + "name": "PulseApeCoin", + "symbol": "PLSA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26891/thumb/2022-08-15_16.40.06.jpg?1660706016" + }, + { + "chainId": 1, + "address": "0x03806ce5ef69bd9780edfb04c29da1f23db96294", + "name": "Tesla TSL", + "symbol": "TSL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1222/thumb/energo.png?1547035249" + }, + { + "chainId": 1, + "address": "0x4b4b1d389d4f4e082b30f75c6319c0ce5acbd619", + "name": "Heart Number", + "symbol": "HTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9002/thumb/htn%28200x200%29.png?1600757668" + }, + { + "chainId": 1, + "address": "0xa8155cf81adaa78f9cec69d698be1859d4f3bf3b", + "name": "Hel Games", + "symbol": "HEL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26635/thumb/logo_%281%29.png?1659327747" + }, + { + "chainId": 1, + "address": "0x095cf7f3e82a1dcadbf0fbc59023f419883ea296", + "name": "Pocket Arena", + "symbol": "POC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8731/thumb/poc.png?1638521756" + }, + { + "chainId": 1, + "address": "0x4c6ec08cf3fc987c6c4beb03184d335a2dfc4042", + "name": "MurAll", + "symbol": "PAINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14103/thumb/paint_logo_200x200.png?1614325640" + }, + { + "chainId": 1, + "address": "0x8c661806f716652b637728355cc4e2620d428f99", + "name": "Delio DSP", + "symbol": "DSP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26236/thumb/4Wbz4ZFt_400x400.png?1656901850" + }, + { + "chainId": 1, + "address": "0x7e7e112a68d8d2e221e11047a72ffc1065c38e1a", + "name": "Badger Sett Digg", + "symbol": "BDIGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14503/thumb/DIGG.png?1616560407" + }, + { + "chainId": 1, + "address": "0x558ec3152e2eb2174905cd19aea4e34a23de9ad6", + "name": "Bread", + "symbol": "BRD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1440/thumb/bread.png?1547563238" + }, + { + "chainId": 1, + "address": "0x846c66cf71c43f80403b51fe3906b3599d63336f", + "name": "PumaPay", + "symbol": "PMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2307/thumb/pumapay_dark_rounded_256x256.png?1622176373" + }, + { + "chainId": 1, + "address": "0x9ceb84f92a0561fa3cc4132ab9c0b76a59787544", + "name": "Doki Doki", + "symbol": "DOKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12759/thumb/doki_logo.png?1602338064" + }, + { + "chainId": 1, + "address": "0x48783486ddd7fa85eca6b0c4ae8920bc25dfbcd7", + "name": "GoMoney2", + "symbol": "GOM2", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/10374/thumb/lvAhDIqmH0fh6U3NIiYLmKETR3uUBcySAv-K28eW6CCFm-ODhCdId71Ug5c4TCoEtxsre30Efe08muctK0MlK-JPdAbxilzZ7dHyiBNOCvcc_9AmJIo09TRLaiAafgqcFKsxpNOON2D28oTLnVTaqwxWL8zKSzjbI6ChKTCJKOiM2mq7VhQRZYe93StR30mf2O7DnkqmGEbZ5_i.jpg?1578675305" + }, + { + "chainId": 1, + "address": "0x24861414c8845b8115397302e9dcfaab3f239826", + "name": "Shield Protocol Token", + "symbol": "SHIELD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24014/thumb/Shield_Universal_Avatar_black.png?1646030958" + }, + { + "chainId": 1, + "address": "0x6247c86b016bc4d9ae141849c0a9eb38c004b742", + "name": "Hotelium", + "symbol": "HTL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8812/thumb/hotelium.PNG?1561539590" + }, + { + "chainId": 1, + "address": "0x6a27348483d59150ae76ef4c0f3622a78b0ca698", + "name": "BeeKan Beenews", + "symbol": "BKBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5004/thumb/beekan.png?1547040430" + }, + { + "chainId": 1, + "address": "0xdffa3a7f5b40789c7a437dbe7b31b47f9b08fe75", + "name": "CryptoPunk 7171", + "symbol": "HOODIE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17842/thumb/cryptopunk-hoodie.png?1629468579" + }, + { + "chainId": 1, + "address": "0x9e5bd9d9fad182ff0a93ba8085b664bcab00fa68", + "name": "Dinger", + "symbol": "DINGER", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19443/thumb/dinger.png?1661498131" + }, + { + "chainId": 1, + "address": "0xb269ab3b20e09e6fd17c3ed5b4cecf3dea1a5141", + "name": "Sakura Planet", + "symbol": "SAK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27225/thumb/SAK.?1662698993" + }, + { + "chainId": 1, + "address": "0x8ee325ae3e54e83956ef2d5952d3c8bc1fa6ec27", + "name": "Fable Of The Dragon", + "symbol": "TYRANT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27911/thumb/XX45VJKq_400x400.jpeg?1669956200" + }, + { + "chainId": 1, + "address": "0x3833dda0aeb6947b98ce454d89366cba8cc55528", + "name": "SophiaTX", + "symbol": "SPHTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1443/thumb/sophiatx.png?1548609885" + }, + { + "chainId": 1, + "address": "0x06576eb3b212d605b797dc15523d9dc9f4f66db4", + "name": "The Crypto Prophecies", + "symbol": "TCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15054/thumb/tcp.PNG?1619579195" + }, + { + "chainId": 1, + "address": "0xb4058411967d5046f3510943103805be61f0600e", + "name": "Stonk", + "symbol": "STONK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14805/thumb/f9YBOaOF_400x400.jpg?1618534520" + }, + { + "chainId": 1, + "address": "0x309c1b3282c49e4dc6796644417f8c76b7c8233c", + "name": "First Eleven", + "symbol": "F11", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21295/thumb/f11.PNG?1638875819" + }, + { + "chainId": 1, + "address": "0xe70ea90718fd21471db240f3bae343daece65f53", + "name": "The Americans NFT", + "symbol": "USACOIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26566/thumb/american_NFT.jpg?1658800655" + }, + { + "chainId": 1, + "address": "0xd13432fdd2ae4eed84c3a0233d6c5265087c96c3", + "name": "SatelStar", + "symbol": "STSR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28202/thumb/Satelstar_logo_200x.png?1668338911" + }, + { + "chainId": 1, + "address": "0x6c139349ee94ebaaff55ed52d382673c263b22d6", + "name": "Upper Euro", + "symbol": "EURU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12353/thumb/euru.png?1642929585" + }, + { + "chainId": 1, + "address": "0xc12ecee46ed65d970ee5c899fcc7ae133aff9b03", + "name": "Try Finance", + "symbol": "TRY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13865/thumb/try-logo.png?1612420128" + }, + { + "chainId": 1, + "address": "0x39795344cbcc76cc3fb94b9d1b15c23c2070c66d", + "name": "Seigniorage Shares", + "symbol": "SHARE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/12306/thumb/logo_%281%29.png?1607658707" + }, + { + "chainId": 1, + "address": "0x34f7da1243a4aaa69de3639a2f124fa56f4dd5cd", + "name": "Tesseract", + "symbol": "TESS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27966/thumb/photo_2022-10-20_10.54.55.jpeg?1666766468" + }, + { + "chainId": 1, + "address": "0x78a52e12c7b63d05c12f9608307587cf654ec3d0", + "name": "Crypto Village Accelerator", + "symbol": "CVA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10071/thumb/logo_tondo_%281%29.png?1575499784" + }, + { + "chainId": 1, + "address": "0x1b9baf2a3edea91ee431f02d449a1044d5726669", + "name": "Clifford Inu", + "symbol": "CLIFF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21624/thumb/Cliff-Logo-with-with-Circle-NO-Background.png?1655968797" + }, + { + "chainId": 1, + "address": "0xfd30c9bea1a952feeed2ef2c6b2ff8a8fc4aad07", + "name": "Kally", + "symbol": "KALLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15812/thumb/polkally.PNG?1621979722" + }, + { + "chainId": 1, + "address": "0xb2dbf14d0b47ed3ba02bdb7c954e05a72deb7544", + "name": "MobiFi", + "symbol": "MOFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14697/thumb/MOFI_Coin_Green_200x200.png?1634024056" + }, + { + "chainId": 1, + "address": "0x0cc9fccff81252f4bd8c5c6b359b14ae2ed851cf", + "name": "InnovativeBioresearchClassic", + "symbol": "INNBCL", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/7911/thumb/INNBCL.png?1551777826" + }, + { + "chainId": 1, + "address": "0x574f84108a98c575794f75483d801d1d5dc861a5", + "name": "Robotina", + "symbol": "ROX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3153/thumb/rox.png?1519831400" + }, + { + "chainId": 1, + "address": "0x560cc7de81b2a594f6518713cbe122bcf297a6e8", + "name": "ImpulseVen", + "symbol": "I7", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14514/thumb/Impulseven.png?1631092895" + }, + { + "chainId": 1, + "address": "0xa14c04dea16798aa8f25b1da583cd5fbbfd6579e", + "name": "Polychain Monsters Genesis", + "symbol": "PMLG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25396/thumb/19329.png?1651710855" + }, + { + "chainId": 1, + "address": "0xb8e103b60a33597136ea9511f46b6dbeb643a3a5", + "name": "SiamBitcoin", + "symbol": "SBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7089/thumb/image-62DF_5C05991C.jpg?1547043573" + }, + { + "chainId": 1, + "address": "0x790bfacae71576107c068f494c8a6302aea640cb", + "name": "CryptoBossCoin", + "symbol": "CBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7114/thumb/eqIkj-ZZ_400x400.jpg?1549521587" + }, + { + "chainId": 1, + "address": "0xe04491d64eaa464ec8fdf53c7a4c92bf5b2278cd", + "name": "WORLDPET", + "symbol": "WPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11707/thumb/worldpet3.png?1592986614" + }, + { + "chainId": 1, + "address": "0x1e18821e69b9faa8e6e75dffe54e7e25754beda0", + "name": "KIMCHI finance", + "symbol": "KIMCHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12302/thumb/VBa2Z60o_400x400.png?1598982471" + }, + { + "chainId": 1, + "address": "0x394a16744dcd805bb0ca7252e70691f0dcac56aa", + "name": "Trazable", + "symbol": "TRZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24851/thumb/Logo_TRZ-Token_200.png?1649133506" + }, + { + "chainId": 1, + "address": "0x4fb721ef3bf99e0f2c193847afa296b9257d3c30", + "name": "Tokenplace", + "symbol": "TOK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15779/thumb/output-onlinepngtools_%283%29.png?1621837855" + }, + { + "chainId": 1, + "address": "0xcfa0885131f602d11d4da248d2c65a62063567a9", + "name": "TORG", + "symbol": "TORG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17596/thumb/TORG_Logo_200x200.png?1628586056" + }, + { + "chainId": 1, + "address": "0xd909c5862cdb164adb949d92622082f0092efc3d", + "name": "Interest Protocol Token", + "symbol": "IPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27000/thumb/logo.white_%281%29.png?1661328083" + }, + { + "chainId": 1, + "address": "0xcf78c7dd70d6f30f6e3609e905e78305da98c863", + "name": "Ownix", + "symbol": "ONX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17469/thumb/200_200.jpg?1633360949" + }, + { + "chainId": 1, + "address": "0x1de5e000c41c8d35b9f1f4985c23988f05831057", + "name": "BonFi", + "symbol": "BNF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12862/thumb/bonfi_logo.png?1603114422" + }, + { + "chainId": 1, + "address": "0x02e7ac540409d32c90bfb51114003a9e1ff0249c", + "name": "JPG NFT Index", + "symbol": "JPG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25071/thumb/JPG-token-logo-01.png?1650242041" + }, + { + "chainId": 1, + "address": "0x8379f52d09b9998ecba731288ee4fe532fd91c0b", + "name": "Backed Protocol", + "symbol": "BAKT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16773/thumb/QXP11lB.png?1624945482" + }, + { + "chainId": 1, + "address": "0xc4e15973e6ff2a35cc804c2cf9d2a1b817a8b40f", + "name": "Badger Interest Bearing Bitcoin", + "symbol": "IBBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15500/thumb/ibbtc.png?1621077589" + }, + { + "chainId": 1, + "address": "0xfca47962d45adfdfd1ab2d972315db4ce7ccf094", + "name": "iXledger", + "symbol": "IXT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/814/thumb/ixledger.png?1547034602" + }, + { + "chainId": 1, + "address": "0x1864ce27e9f7517047933caae530674e8c70b8a7", + "name": "Pibble", + "symbol": "PIB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2972/thumb/pibble.jpg?1551683103" + }, + { + "chainId": 1, + "address": "0xd7631787b4dcc87b1254cfd1e5ce48e96823dee8", + "name": "Sociall", + "symbol": "SCL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/874/thumb/scl.png?1547034694" + }, + { + "chainId": 1, + "address": "0xcd1cb16a67937ff8af5d726e2681010ce1e9891a", + "name": "Themis", + "symbol": "MIS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13478/thumb/3uZAPv2CbXF5txM.png?1608947522" + }, + { + "chainId": 1, + "address": "0x19d97d8fa813ee2f51ad4b4e04ea08baf4dffc28", + "name": "Badger Sett Badger", + "symbol": "BBADGER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14502/thumb/BADGER_DAO.png?1616559959" + }, + { + "chainId": 1, + "address": "0x0e192d382a36de7011f795acc4391cd302003606", + "name": "Futureswap", + "symbol": "FST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14520/thumb/futureswap_logo.png?1634122916" + }, + { + "chainId": 1, + "address": "0xbaa9af8a83500ac4137c555b9e58ccb3e1f2269d", + "name": "ShinChan", + "symbol": "SHINNOSUKE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20134/thumb/shinchan.png?1636530348" + }, + { + "chainId": 1, + "address": "0xd91e9a0fef7c0fa4ebdaf4d0acf55888949a2a9b", + "name": "MCN Ventures", + "symbol": "MCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17580/thumb/mcn-logo-white-bg.png?1628561611" + }, + { + "chainId": 1, + "address": "0x2f109021afe75b949429fe30523ee7c0d5b27207", + "name": "OccamFi", + "symbol": "OCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14801/thumb/occfi.PNG?1618531140" + }, + { + "chainId": 1, + "address": "0x101cc05f4a51c0319f570d5e146a8c625198e636", + "name": "Aave TUSD", + "symbol": "ATUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14317/thumb/aTUSD.08592b49.png?1615528207" + }, + { + "chainId": 1, + "address": "0x824e35f7a75324f99300afac75ecf7354e17ea26", + "name": "TIA", + "symbol": "TIA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23994/thumb/tia.png?1645952362" + }, + { + "chainId": 1, + "address": "0x92e187a03b6cd19cb6af293ba17f2745fd2357d5", + "name": "Unit Protocol", + "symbol": "DUCK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13359/thumb/6f38719f-fe83-44ff-af30-7965fd23ac06.png?1660612730" + }, + { + "chainId": 1, + "address": "0xf7970499814654cd13cb7b6e7634a12a7a8a9abc", + "name": "TOM Finance", + "symbol": "TOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13173/thumb/TOM_logo.png?1605857896" + }, + { + "chainId": 1, + "address": "0x8c81121b15197fa0eeaee1dc75533419dcfd3151", + "name": "IdleWBTC Best Yield ", + "symbol": "IDLEWBTCYIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11936/thumb/idlewbtcv3maxyield_32.png?1596263736" + }, + { + "chainId": 1, + "address": "0x5afe3855358e112b5647b952709e6165e1c1eeee", + "name": "Safe Token", + "symbol": "SAFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27032/thumb/Artboard_1_copy_8circle-1.png?1661498342" + }, + { + "chainId": 1, + "address": "0xd7d706ed3598a354a4adfce5d8c5383df99a4461", + "name": "Dain", + "symbol": "DAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14811/thumb/%C2%B4%C3%99%C3%80%C3%8E%C2%B7%C3%8E%C2%B0%C3%AD.png?1618541340" + }, + { + "chainId": 1, + "address": "0xbb126042235e6bd38b17744cb31a8bf4a206c045", + "name": "fanC", + "symbol": "FANC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26500/thumb/hJ6MD49P_400x400.jpeg?1658356676" + }, + { + "chainId": 1, + "address": "0x26946ada5ecb57f3a1f91605050ce45c482c9eb1", + "name": "BitcoinSoV", + "symbol": "BSOV", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9205/thumb/bsov.png?1578020375" + }, + { + "chainId": 1, + "address": "0x53bd789f2cdb846b227d8ffc7b46ed4263231fdf", + "name": "SimbCoin Swap", + "symbol": "SMBSWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16808/thumb/smb.png?1625134960" + }, + { + "chainId": 1, + "address": "0x38c87aa89b2b8cd9b95b736e1fa7b612ea972169", + "name": "AMO Coin", + "symbol": "AMO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4009/thumb/amo-logomark_black.png?1547039106" + }, + { + "chainId": 1, + "address": "0x7b7983967409fce461ea8bbdf9ed37631b1d59c9", + "name": "KPOP Coin", + "symbol": "KPOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15923/thumb/kpop.PNG?1622431964" + }, + { + "chainId": 1, + "address": "0xeed4d7316a04ee59de3d301a384262ffbdbd589a", + "name": "Page Network", + "symbol": "PGX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26319/thumb/ICfb5Z0c_400x400.jpg?1657244779" + }, + { + "chainId": 1, + "address": "0xb30f5d11b94efbbfdeaa4de38edffceec0be6513", + "name": "Play It Forward DAO", + "symbol": "PIF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22904/thumb/pif.png?1642938913" + }, + { + "chainId": 1, + "address": "0xbbbbbbb5aa847a2003fbc6b5c16df0bd1e725f61", + "name": "B Protocol", + "symbol": "BPRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15110/thumb/66428641.jpg?1619749844" + }, + { + "chainId": 1, + "address": "0x2f9411088cef82fd9fb904eb8092f28eb485c8f6", + "name": "Athens", + "symbol": "ATH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24514/thumb/ATH-logo-round.png?1647951491" + }, + { + "chainId": 1, + "address": "0xfcc63e6459936216b7b887f6da5fcd90c0c62b7c", + "name": "Korea Entertainment Education Shoppin", + "symbol": "KEES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27513/thumb/lo2XCLcf_400x400.jpeg?1664351911" + }, + { + "chainId": 1, + "address": "0x6e1a19f235be7ed8e3369ef73b196c07257494de", + "name": "Wrapped Filecoin", + "symbol": "WFIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13238/thumb/WFIL.png?1623827165" + }, + { + "chainId": 1, + "address": "0xea26c4ac16d4a5a106820bc8aee85fd0b7b2b664", + "name": "QuarkChain", + "symbol": "QKC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3849/thumb/quarkchain.png?1548387524" + }, + { + "chainId": 1, + "address": "0xe7976c4efc60d9f4c200cc1bcef1a1e3b02c73e7", + "name": "MAX", + "symbol": "MAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6454/thumb/MAX_Token.jpg?1547042651" + }, + { + "chainId": 1, + "address": "0x0fd3822072ad001aac1c90a09d9506f097f24458", + "name": "NOA PLAY", + "symbol": "NOA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15723/thumb/XHFjmBTx_400x400.png?1621635644" + }, + { + "chainId": 1, + "address": "0xa1afffe3f4d611d252010e3eaf6f4d77088b0cd7", + "name": "reflect finance", + "symbol": "RFI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13189/thumb/reflect_finance_logo.png?1606098213" + }, + { + "chainId": 1, + "address": "0xbd0793332e9fb844a52a205a233ef27a5b34b927", + "name": "ZB", + "symbol": "ZB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4773/thumb/zb-token-logo.png?1547040106" + }, + { + "chainId": 1, + "address": "0xde30da39c46104798bb5aa3fe8b9e0e1f348163f", + "name": "Gitcoin", + "symbol": "GTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15810/thumb/gitcoin.png?1621992929" + }, + { + "chainId": 1, + "address": "0xc656b2279b0fdf761e832133b06ce607fbbcbceb", + "name": "Asuna Inu", + "symbol": "ASUNAINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19214/thumb/asuna-logo-200px.jpg?1642668987" + }, + { + "chainId": 1, + "address": "0x6de037ef9ad2725eb40118bb1702ebb27e4aeb24", + "name": "Render", + "symbol": "RNDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11636/thumb/rndr.png?1638840934" + }, + { + "chainId": 1, + "address": "0xe1fc4455f62a6e89476f1072530c20cf1a0622da", + "name": "Phuture", + "symbol": "PHTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16071/thumb/phtr.png?1655535400" + }, + { + "chainId": 1, + "address": "0x6dd4e4aad29a40edd6a409b9c1625186c9855b4d", + "name": "Parkgene", + "symbol": "GENE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2298/thumb/gene.png?1547036520" + }, + { + "chainId": 1, + "address": "0x86911b82bfa596e9377836838ac1f0d9ad4ecc19", + "name": "LCMS", + "symbol": "LCMS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17324/thumb/lcms.jpeg?1627309697" + }, + { + "chainId": 1, + "address": "0x9be89d2a4cd102d8fecc6bf9da793be995c22541", + "name": "Binance Wrapped BTC", + "symbol": "BBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14867/thumb/binance-btc_32.png?1618814666" + }, + { + "chainId": 1, + "address": "0xca7b3ba66556c4da2e2a9afef9c64f909a59430a", + "name": "WOLVERINU OLD ", + "symbol": "WOLVERINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19374/thumb/logo200.png?1643189122" + }, + { + "chainId": 1, + "address": "0x5e9f35e8163c44cd7e606bdd716abed32ad2f1c6", + "name": "Saitanobi", + "symbol": "SAITANOBI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23473/thumb/saitanobi.png?1645856764" + }, + { + "chainId": 1, + "address": "0x559ebc30b0e58a45cc9ff573f77ef1e5eb1b3e18", + "name": "Volt Protocol", + "symbol": "VOLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25218/thumb/200x200_Volt_logo.png?1650869138" + }, + { + "chainId": 1, + "address": "0xcd6adc6b8bd396e2d53ccd7d7257b4de55be4fbe", + "name": "CFL365 Finance", + "symbol": "CFL365", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17548/thumb/cfl365.PNG?1628218865" + }, + { + "chainId": 1, + "address": "0x865bb9a28041259b4badafd37799a288aabbfc8c", + "name": "Moma Protocol", + "symbol": "MOMAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16910/thumb/moma.PNG?1625618080" + }, + { + "chainId": 1, + "address": "0x0ada190c81b814548ddc2f6adc4a689ce7c1fe73", + "name": "yAxis", + "symbol": "YAXIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12620/thumb/Logo.png?1608310944" + }, + { + "chainId": 1, + "address": "0x9b8d5f3402f74c7a61d9f09c32d3ca07b45c1466", + "name": "Gimmer", + "symbol": "GMR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6693/thumb/gimmer_token.jpg?1547042897" + }, + { + "chainId": 1, + "address": "0x5fce9fc9b5d62af082a59d0823a062f7529efa5a", + "name": "Shaman", + "symbol": "SHAMAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25292/thumb/0v-V3FPz_400x400.jpg?1651139525" + }, + { + "chainId": 1, + "address": "0x7420b4b9a0110cdc71fb720908340c03f9bc03ec", + "name": "JasmyCoin", + "symbol": "JASMY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13876/thumb/JASMY200x200.jpg?1612473259" + }, + { + "chainId": 1, + "address": "0x51db5ad35c671a87207d88fc11d593ac0c8415bd", + "name": "Moeda Loyalty Points", + "symbol": "MDA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/895/thumb/moeda-loyalty-points.png?1547034720" + }, + { + "chainId": 1, + "address": "0x24e89bdf2f65326b94e36978a7edeac63623dafa", + "name": "Tiger King Coin", + "symbol": "TKING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15605/thumb/tigerking.png?1649149229" + }, + { + "chainId": 1, + "address": "0x4eeea7b48b9c3ac8f70a9c932a8b1e8a5cb624c7", + "name": "Membrana", + "symbol": "MBN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5117/thumb/membrana_logo.png?1565238625" + }, + { + "chainId": 1, + "address": "0x3a707d56d538e85b783e8ce12b346e7fb6511f90", + "name": "Inverse Ethereum Volatility Index Token", + "symbol": "IETHV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16715/thumb/logo_-_2021-06-28T085526.083.png?1624841740" + }, + { + "chainId": 1, + "address": "0x6286a9e6f7e745a6d884561d88f94542d6715698", + "name": "Cryptomeda", + "symbol": "TECH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17983/thumb/tech.png?1654330771" + }, + { + "chainId": 1, + "address": "0x777e2ae845272a2f540ebf6a3d03734a5a8f618e", + "name": "Ryoshis Vision", + "symbol": "RYOSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17614/thumb/OFFICIAL_RYOSHI_LOGO-removebg-preview_2_200x200.png?1629794604" + }, + { + "chainId": 1, + "address": "0xfcdc835939a23c5db3f056470341e1947bb7a552", + "name": "Husky VC", + "symbol": "HUSKY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27353/thumb/logo_husky200.png?1663659027" + }, + { + "chainId": 1, + "address": "0x015b94ab2b0a14a96030573fbcd0f3d3d763541f", + "name": "Zunami USD", + "symbol": "UZD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27621/thumb/UZD_Logo_200x200.png?1666428507" + }, + { + "chainId": 1, + "address": "0x5dc60c4d5e75d22588fa17ffeb90a63e535efce0", + "name": "dKargo", + "symbol": "DKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11875/thumb/bVD0g0dlmrEOPIkt943KZIBZ086eCshyY0jIQFti4zxYdOlFltU8tKa6uJlcA14HvNjX4bc7dxdMvlpoW5NFMND85oG4aiiCbFRhI6eowDfKEBY3BoSVY0IrBbA9SFGIxh_IYrkNC5uNdG-roZ0_TlGO3098now6Tbzga0p4IDqVk6lnaX3TuRC7pgnAYWZM15RD-uEIHr3O_3OoIIWP-.jpg?1595563347" + }, + { + "chainId": 1, + "address": "0xf83301c5cd1ccbb86f466a6b3c53316ed2f8465a", + "name": "COMSA", + "symbol": "CMS", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/2500/thumb/comsa-_xem_.png?1547036614" + }, + { + "chainId": 1, + "address": "0x6710c63432a2de02954fc0f851db07146a6c0312", + "name": "Smart MFG", + "symbol": "MFG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1842/thumb/Smart_MFG_Cropped_Logo.png?1621422155" + }, + { + "chainId": 1, + "address": "0xdcdc1c1cc33aa817cbdbe8f5e2390bf7cc43dc4b", + "name": "AVASTR Vault NFTX ", + "symbol": "AVASTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17034/thumb/AVASTR.png?1626142802" + }, + { + "chainId": 1, + "address": "0x7ccfeef4f0ff48b0e0abd19bbbebae90939f180d", + "name": "StarShip Stars", + "symbol": "STARS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17533/thumb/DhtU6Z.jpg?1628130727" + }, + { + "chainId": 1, + "address": "0xccf4429db6322d5c611ee964527d42e5d685dd6a", + "name": "cWBTC", + "symbol": "CWBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10823/thumb/cwbtc.png?1584331700" + }, + { + "chainId": 1, + "address": "0xc28e931814725bbeb9e670676fabbcb694fe7df2", + "name": "Quadrant Protocol", + "symbol": "EQUAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4462/thumb/equad.png?1547039783" + }, + { + "chainId": 1, + "address": "0xd24dff6117936b6ff97108cf26c1dd8865743d87", + "name": "MEDIUM", + "symbol": "MDM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9961/thumb/VEEFC4sG.png?1574293042" + }, + { + "chainId": 1, + "address": "0xcb056a2f3ca0b82ab69dcbd677875d68b74d6189", + "name": "The Akragas Decadrachm", + "symbol": "THEAD", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27078/thumb/200x200.PNG?1661761303" + }, + { + "chainId": 1, + "address": "0x0ef3b2024ae079e6dbc2b37435ce30d2731f0101", + "name": "UNIFI DeFi", + "symbol": "UNIFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12533/thumb/unifi_defi_logo.jpg?1600531278" + }, + { + "chainId": 1, + "address": "0x56a41eef4aba11292c58b39f61dabc82ed22c79b", + "name": "Space Link", + "symbol": "SPLINK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19609/thumb/splink.png?1635925515" + }, + { + "chainId": 1, + "address": "0x01e0e2e61f554ecaaec0cc933e739ad90f24a86d", + "name": "GTON CAPITAL", + "symbol": "GTON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15728/thumb/GC_logo_200x200.png?1642669327" + }, + { + "chainId": 1, + "address": "0xa4e9584daa093cb1205e17ba737c3fd015748087", + "name": "FOREXCOIN", + "symbol": "FOREX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6852/thumb/forex-logo.PNG?1547043174" + }, + { + "chainId": 1, + "address": "0x706cb9e741cbfee00ad5b3f5acc8bd44d1644a74", + "name": "YFOX Finance", + "symbol": "YFOX", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/12702/thumb/Yfox.png?1601865990" + }, + { + "chainId": 1, + "address": "0xe3a46b2bc1d83c731d58cab765d3b45bce789095", + "name": "DAYSTARTER", + "symbol": "DST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28006/thumb/daystarter_logo_200_200.png?1667148509" + }, + { + "chainId": 1, + "address": "0x51395ade06eae126f590e7b06dc8f6baf511f13f", + "name": "hiSQUIGGLE", + "symbol": "HISQUIGGLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28127/thumb/hisquiggle.png?1667641238" + }, + { + "chainId": 1, + "address": "0x00c2999c8b2adf4abc835cc63209533973718eb1", + "name": "New World Order", + "symbol": "STATE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27387/thumb/icon.png?1663812357" + }, + { + "chainId": 1, + "address": "0xdb05ea0877a2622883941b939f0bb11d1ac7c400", + "name": "Opacity", + "symbol": "OPCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7237/thumb/Opacity.jpg?1551843524" + }, + { + "chainId": 1, + "address": "0xf81421fc15300c5a8cca9afe12f5cbad502fa756", + "name": "Cardiocoin", + "symbol": "CRDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25135/thumb/gQiyJrGcTRjEN-6bI22FOtHOmYF8-_MMYS_U1gIlUm1wf6QxiGnZ64tIeGNNFk9z5xPPch5FMie2grAN4fXQfcjKI9L0EQDVzDEdYDfqWl8ch4ree_q4pypGPNHeSCxnynfOOLAvd9XbKguJHEJNTLAdSKnWCKu92Kho49SplFvDBplt2ruvOz1v5QB795cnjZg4ZemfgfAB_ipJU1YE4TA3uL.jpg?1650432016" + }, + { + "chainId": 1, + "address": "0x3bb86d867a9f3addf994cdadb210fa82f0d4157a", + "name": "Ghoul", + "symbol": "GHOUL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16455/thumb/rsz-ghoul2.png?1624249816" + }, + { + "chainId": 1, + "address": "0x5ecb025e51415dba9fd272c551076357cf4069f5", + "name": "Crespo", + "symbol": "CSO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9125/thumb/crespo.png?1564547729" + }, + { + "chainId": 1, + "address": "0x76851a93977bea9264c32255b6457882035c7501", + "name": "Fat Doge", + "symbol": "FOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15497/thumb/foge.png?1621057848" + }, + { + "chainId": 1, + "address": "0x33811d4edbcaed10a685254eb5d3c4e4398520d2", + "name": "YFE Money", + "symbol": "YFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12644/thumb/logo-round.png?1601373377" + }, + { + "chainId": 1, + "address": "0xe51b8ab09008285a0380dd2680cd9dd5e13924d3", + "name": "BallSwap", + "symbol": "BSP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14050/thumb/bsp.png?1637556507" + }, + { + "chainId": 1, + "address": "0xbf30461210b37012783957d90dc26b95ce3b6f2d", + "name": "Swivel Governance", + "symbol": "SWIV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24496/thumb/tKRKjCx.png?1647868486" + }, + { + "chainId": 1, + "address": "0x9e976f211daea0d652912ab99b0dc21a7fd728e4", + "name": "MAP Protocol", + "symbol": "MAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10085/thumb/53819931.png?1649044945" + }, + { + "chainId": 1, + "address": "0x70da48f4b7e83c386ef983d4cef4e58c2c09d8ac", + "name": "Quras", + "symbol": "XQC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10112/thumb/FZFHac2z_400x400.jpg?1575964560" + }, + { + "chainId": 1, + "address": "0x4270bb238f6dd8b1c3ca01f96ca65b2647c06d3c", + "name": "Fortuna", + "symbol": "FOTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2689/thumb/fortuna.png?1547483931" + }, + { + "chainId": 1, + "address": "0x579cea1889991f68acc35ff5c3dd0621ff29b0c9", + "name": "IQ", + "symbol": "IQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5010/thumb/YAIS3fUh.png?1626267646" + }, + { + "chainId": 1, + "address": "0xf974b5f9ac9c6632fee8b76c61b0242ce69c839d", + "name": "ZYX", + "symbol": "ZYX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11964/thumb/zyx.png?1596454904" + }, + { + "chainId": 1, + "address": "0xe5caef4af8780e59df925470b050fb23c43ca68c", + "name": "Ferrum Network", + "symbol": "FRM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/8251/thumb/FRM.png?1658819429" + }, + { + "chainId": 1, + "address": "0xf1f508c7c9f0d1b15a76fba564eef2d956220cf7", + "name": "Pepedex", + "symbol": "PPDEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13022/thumb/output-onlinepngtools-1.png?1604720841" + }, + { + "chainId": 1, + "address": "0xc324a2f6b05880503444451b8b27e6f9e63287cb", + "name": "Exchange Union", + "symbol": "XUC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1052/thumb/exchange-union.png?1548125817" + }, + { + "chainId": 1, + "address": "0x3810a4ddf41e586fa0dba1463a7951b748cecfca", + "name": "Menapay", + "symbol": "MPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6360/thumb/Menapay_ico.png?1547042454" + }, + { + "chainId": 1, + "address": "0x9b53e429b0badd98ef7f01f03702986c516a5715", + "name": "Hybrix", + "symbol": "HY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11518/thumb/Hybrix_PNG_200x200.png?1628770703" + }, + { + "chainId": 1, + "address": "0x6d57b2e05f26c26b549231c866bdd39779e4a488", + "name": "VNX Gold", + "symbol": "VNXAU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28019/thumb/wnxgold.png?1667026518" + }, + { + "chainId": 1, + "address": "0x249ca82617ec3dfb2589c4c17ab7ec9765350a18", + "name": "Verse", + "symbol": "VERSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28424/thumb/verselogo.png?1670461811" + }, + { + "chainId": 1, + "address": "0x5befbb272290dd5b8521d4a938f6c4757742c430", + "name": "Xfinance", + "symbol": "XFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12449/thumb/go.png?1599904281" + }, + { + "chainId": 1, + "address": "0xfe9a29ab92522d14fc65880d817214261d8479ae", + "name": "Snowswap", + "symbol": "SNOW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12751/thumb/uQBJL3A.png?1602237225" + }, + { + "chainId": 1, + "address": "0x15b7c0c907e4c6b9adaaaabc300c08991d6cea05", + "name": "Gelato", + "symbol": "GEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15026/thumb/Gelato_Icon_Logo_1024x1024.png?1619491717" + }, + { + "chainId": 1, + "address": "0x5d29011d843b0b1760c43e10d66f302174bccd1a", + "name": "RickMortyDoxx", + "symbol": "RICKMORTYDOXX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19148/thumb/cropped-IMG_20211203_223720_101.png?1643004811" + }, + { + "chainId": 1, + "address": "0x9783b81438c24848f85848f8df31845097341771", + "name": "Dog Collar", + "symbol": "COLLAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18324/thumb/dcLogo.png?1631532599" + }, + { + "chainId": 1, + "address": "0x34d6a0f5c2f5d0082141fe73d93b9dd00ca7ce11", + "name": "Golden", + "symbol": "GOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8939/thumb/4uf1Sim9_400x400.png?1563116366" + }, + { + "chainId": 1, + "address": "0xb551d08d2189ef67b4788be2c35c0743693625ca", + "name": "EAutocoin", + "symbol": "ATO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7132/thumb/ato.png?1547043631" + }, + { + "chainId": 1, + "address": "0xcdca1b81dbb543baa92c97b701396cd3ba315e5d", + "name": "Shuey Rhon Inu", + "symbol": "SHUEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24306/thumb/shuey.jpg?1647316292" + }, + { + "chainId": 1, + "address": "0x77c6e4a580c0dce4e5c7a17d0bc077188a83a059", + "name": "Swerve fi USD", + "symbol": "SWUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12918/thumb/swerve.png?1603631063" + }, + { + "chainId": 1, + "address": "0xd1ba9bac957322d6e8c07a160a3a8da11a0d2867", + "name": "HUMAN Protocol", + "symbol": "HMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16412/thumb/human_protocol.PNG?1623971316" + }, + { + "chainId": 1, + "address": "0xba75fbc4c7a553081f7a137b6e652520db444660", + "name": "MonstaVerse", + "symbol": "MONSTR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21887/thumb/yn3q0se.png?1640226777" + }, + { + "chainId": 1, + "address": "0xa67b8e40111a0edd30c3210b77aadb86ad234c43", + "name": "Banana Index", + "symbol": "BANDEX", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26700/thumb/6233e7f496c72994c313a50a_cactusboy90_%282%29-p-1080.png?1659616101" + }, + { + "chainId": 1, + "address": "0x05fcc72cfb4150abae415c885f7a433ff523296f", + "name": "YOKcoin", + "symbol": "YOK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12425/thumb/YOKcoin_200x200.png?1599732314" + }, + { + "chainId": 1, + "address": "0x8888801af4d980682e47f1a9036e589479e835c5", + "name": "88mph", + "symbol": "MPH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13137/thumb/yfU-_Tcj_400x400.png?1605581509" + }, + { + "chainId": 1, + "address": "0x5c3a228510d246b78a3765c20221cbf3082b44a4", + "name": "Storiqa", + "symbol": "STQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1929/thumb/storiqa.png?1548611108" + }, + { + "chainId": 1, + "address": "0x95b4e47025372ded4b73f9b5f0671b94a81445bc", + "name": "InfinityGaming", + "symbol": "PLAY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21804/thumb/ig.png?1640066214" + }, + { + "chainId": 1, + "address": "0xcc665390b03c5d324d8faf81c15ecee29a73bcb4", + "name": "Chainswap", + "symbol": "ASAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14945/thumb/chainswap_logo.png?1619109717" + }, + { + "chainId": 1, + "address": "0xacbd826394189cf2623c6df98a18b41fc8ffc16d", + "name": "NFTify", + "symbol": "N1", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16095/thumb/n1-token-logo-circle-200x200.png?1627130530" + }, + { + "chainId": 1, + "address": "0xc77b230f31b517f1ef362e59c173c2be6540b5e8", + "name": "VIDY", + "symbol": "VIDY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5088/thumb/vidy-logo.jpg?1547040486" + }, + { + "chainId": 1, + "address": "0xaf8a215e81faea7c180ce22b72483525121813bd", + "name": "Engine", + "symbol": "EGCC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4531/thumb/2852.png?1547039827" + }, + { + "chainId": 1, + "address": "0xd6a5ab46ead26f49b03bbb1f9eb1ad5c1767974a", + "name": "Ethermon", + "symbol": "EMON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15889/thumb/LtET0reH_400x400.jpg?1622213962" + }, + { + "chainId": 1, + "address": "0x426fc8be95573230f6e6bc4af91873f0c67b21b4", + "name": "BlackPearl", + "symbol": "BPLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8931/thumb/EJIpComQ_400x400.png?1584653141" + }, + { + "chainId": 1, + "address": "0x2781246fe707bb15cee3e5ea354e2154a2877b16", + "name": "ELYSIA", + "symbol": "EL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10887/thumb/CeyRVXPY_400x400.jpg?1585559128" + }, + { + "chainId": 1, + "address": "0x2b645a57e82123796c3ea7d78de27c3e3ff7f016", + "name": "Meta Miner", + "symbol": "MINER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26876/thumb/200x200.png?1660620947" + }, + { + "chainId": 1, + "address": "0xb087c2180e3134db396977065817aed91fea6ead", + "name": "Hellsing Inu", + "symbol": "HELLSING", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19795/thumb/hellsing.png?1638182960" + }, + { + "chainId": 1, + "address": "0x4a9d711100aff9a444a3c40284f70269bb3f0487", + "name": "Chellitcoin", + "symbol": "CHLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19192/thumb/chellit_ticker-01.png?1634632273" + }, + { + "chainId": 1, + "address": "0x2e922f84ec5bb9cedfbb1a99543b143aa43d94b6", + "name": "ThreeOh DAO", + "symbol": "3OH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26398/thumb/98052236.jpeg?1657770947" + }, + { + "chainId": 1, + "address": "0x2ef52ed7de8c5ce03a4ef0efbe9b7450f2d7edc9", + "name": "Revain", + "symbol": "REV", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1107/thumb/256x256.png?1587018647" + }, + { + "chainId": 1, + "address": "0x6006fc2a849fedaba8330ce36f5133de01f96189", + "name": "Spaceswap SHAKE", + "symbol": "SHAKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12765/thumb/shake.png?1633423725" + }, + { + "chainId": 1, + "address": "0x21cf09bc065082478dcc9ccb5fd215a978dc8d86", + "name": "Jem", + "symbol": "JEM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13044/thumb/itchiro-defi.png?1605892179" + }, + { + "chainId": 1, + "address": "0x7728cd70b3dd86210e2bd321437f448231b81733", + "name": "Envelop Niftsy ", + "symbol": "NIFTSY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19161/thumb/logo200x200.png?1643188130" + }, + { + "chainId": 1, + "address": "0x68bb81b3f67f7aab5fd1390ecb0b8e1a806f2465", + "name": "NFT Platform Index", + "symbol": "NFTP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14543/thumb/nftp-light-circular.c54a6825.png?1616935648" + }, + { + "chainId": 1, + "address": "0x34612903db071e888a4dadcaa416d3ee263a87b9", + "name": "Items", + "symbol": "ARTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11720/thumb/Arte.png?1607332372" + }, + { + "chainId": 1, + "address": "0x06b884e60794ce02aafab13791b59a2e6a07442f", + "name": "Unbanked", + "symbol": "UNBNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20171/thumb/logo_-_2021-11-11T115427.135.png?1636602880" + }, + { + "chainId": 1, + "address": "0x5d65d971895edc438f465c17db6992698a52318d", + "name": "Nebulas", + "symbol": "NAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2431/thumb/193394331.png?1597976208" + }, + { + "chainId": 1, + "address": "0x98af2e926206f1eb5af46aeddd144727267d0487", + "name": "QoinIQ", + "symbol": "QIQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17905/thumb/qiq.PNG?1629774762" + }, + { + "chainId": 1, + "address": "0x2edc01f6e8b2387e76872cbbe1b69407ec058f34", + "name": "semicon1", + "symbol": "SMC1", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27503/thumb/mvsyBzOGKm20JndbDQrD8jXwAVwVTIA87Xc1ULBqb7NcFCv0fnpN71bACOvyIbc798xCyssiXAtEmTyumW2APB_hdvz7E_wti4nFTHTSBclhMWXO5Osiilpb6haIfFFHp1VStEPZ-RiHJtIbiqzyqtnAoD7BE2flxQ1fBLYnzff8-_tQ9-olz-31m8kZQGMPvW7zDw9WFhm-xUGQUd8HJVsFo9_74cK_Ko3fb4sKLidVs0P.jpeg?1664331574" + }, + { + "chainId": 1, + "address": "0x509a38b7a1cc0dcd83aa9d06214663d9ec7c7f4a", + "name": "Blocksquare", + "symbol": "BST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23924/thumb/XpkkqPVR_400x400.jpg?1645689021" + }, + { + "chainId": 1, + "address": "0x9adc7710e9d1b29d8a78c04d52d32532297c2ef3", + "name": "Quadrans", + "symbol": "QDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26493/thumb/mu-N6mCY_400x400.png?1658285089" + }, + { + "chainId": 1, + "address": "0x492baa7a6450712d4bbcca01b87f029dee3ea3ec", + "name": "WAGIE", + "symbol": "WAGIE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28428/thumb/Screen_Shot_2022-08-12_at_12.56.08.png?1670548863" + }, + { + "chainId": 1, + "address": "0x739763a258640919981f9ba610ae65492455be53", + "name": "Node Runners", + "symbol": "NDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13400/thumb/ndr.jpg?1608172954" + }, + { + "chainId": 1, + "address": "0xe94b97b6b43639e238c851a7e693f50033efd75c", + "name": "HaloDAO", + "symbol": "RNBW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16754/thumb/RNBW-256x256.png?1624927932" + }, + { + "chainId": 1, + "address": "0x6b32022693210cd2cfc466b9ac0085de8fc34ea6", + "name": "Maximus DECI", + "symbol": "DECI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27693/thumb/Deci.png?1665222159" + }, + { + "chainId": 1, + "address": "0x7ddc52c4de30e94be3a6a0a2b259b2850f421989", + "name": "GMT", + "symbol": "GMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15662/thumb/gmt.png?1640069038" + }, + { + "chainId": 1, + "address": "0x91af0fbb28aba7e31403cb457106ce79397fd4e6", + "name": "Aergo", + "symbol": "AERGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4490/thumb/aergo.png?1647696770" + }, + { + "chainId": 1, + "address": "0xc4de189abf94c57f396bd4c52ab13b954febefd8", + "name": "B20", + "symbol": "B20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13803/thumb/b20.png?1611996305" + }, + { + "chainId": 1, + "address": "0xfe5f69dfa2d4501e78078266f6d430c079098f90", + "name": "Archie Neko", + "symbol": "ARCHIE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28234/thumb/photo1667927837.jpeg?1668575767" + }, + { + "chainId": 1, + "address": "0x8cb24ed2e4f7e2065f4eb2be5f6b0064b1919850", + "name": "ZARP Stablecoin", + "symbol": "ZARP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27333/thumb/zarp_coin.png?1669366653" + }, + { + "chainId": 1, + "address": "0xec681f28f4561c2a9534799aa38e0d36a83cf478", + "name": "YVS Finance", + "symbol": "YVS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13471/thumb/cu0LSzE.png?1608852718" + }, + { + "chainId": 1, + "address": "0x543ff227f64aa17ea132bf9886cab5db55dcaddf", + "name": "DAOstack", + "symbol": "GEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3479/thumb/gen.png?1547038215" + }, + { + "chainId": 1, + "address": "0x55c08ca52497e2f1534b59e2917bf524d4765257", + "name": "UwU Lend", + "symbol": "UWU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27408/thumb/uwu_logo_no-bg_1024.png?1663842922" + }, + { + "chainId": 1, + "address": "0xf55cd1e399e1cc3d95303048897a680be3313308", + "name": "Maximus TRIO", + "symbol": "TRIO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27684/thumb/IMG_1127.PNG?1665214637" + }, + { + "chainId": 1, + "address": "0xb113c6cf239f60d380359b762e95c13817275277", + "name": "BitMEX", + "symbol": "BMEX", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21831/thumb/bitmex-token.jpeg?1640081706" + }, + { + "chainId": 1, + "address": "0x579e5eafabae696aad762ad36e77a16ae9f0ef91", + "name": "Apex Predator", + "symbol": "APEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24837/thumb/apex.jpg?1649066165" + }, + { + "chainId": 1, + "address": "0x9b9087756eca997c5d595c840263001c9a26646d", + "name": "DogeFi", + "symbol": "DOGEFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12290/thumb/DOGEFI-Logo.png?1598868716" + }, + { + "chainId": 1, + "address": "0x6bc1f3a1ae56231dbb64d3e82e070857eae86045", + "name": "Xensor", + "symbol": "XSR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9224/thumb/Xensor_Logo_%28White__200x200px%29.png?1593570861" + }, + { + "chainId": 1, + "address": "0xd101dcc414f310268c37eeb4cd376ccfa507f571", + "name": "ResearchCoin", + "symbol": "RSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28146/thumb/RH_Logo_200x200.png?1668678529" + }, + { + "chainId": 1, + "address": "0xbbff34e47e559ef680067a6b1c980639eeb64d24", + "name": "Leverj Gluon", + "symbol": "L2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12950/thumb/Gluon256x256.png?1604048379" + }, + { + "chainId": 1, + "address": "0x83d60e7aed59c6829fb251229061a55f35432c4d", + "name": "Infinito", + "symbol": "INFT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/9461/thumb/5TOvk2A.png?1604885818" + }, + { + "chainId": 1, + "address": "0xed3d4e446a96dc3b181b64b75c3c70da41dc3cbe", + "name": "Vodra", + "symbol": "VDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19338/thumb/vdr.png?1635832496" + }, + { + "chainId": 1, + "address": "0xc962ad021a69d457564e985738c719ae3f79b707", + "name": "IFX24", + "symbol": "IFX24", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10444/thumb/lpFSaoD.png?1579475634" + }, + { + "chainId": 1, + "address": "0x3166c570935a7d8554c8f4ea792ff965d2efe1f2", + "name": "Q DAO Governance v1 0", + "symbol": "QDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8599/thumb/QDAO_logo_white_black.png?1562131656" + }, + { + "chainId": 1, + "address": "0x0e0989b1f9b8a38983c2ba8053269ca62ec9b195", + "name": "Po et", + "symbol": "POE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/910/thumb/poet.png?1548331583" + }, + { + "chainId": 1, + "address": "0xe6c3502997f97f9bde34cb165fbce191065e068f", + "name": "Klondike BTC", + "symbol": "KBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13789/thumb/klondike.jpg?1611759492" + }, + { + "chainId": 1, + "address": "0x3e1d5a855ad9d948373ae68e4fe1f094612b1322", + "name": "HyperQuant", + "symbol": "HQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4410/thumb/hqt.png?1547039746" + }, + { + "chainId": 1, + "address": "0xaec7d1069e3a914a3eb50f0bfb1796751f2ce48a", + "name": "S4FE", + "symbol": "S4F", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7405/thumb/logo_%284%29.png?1547085640" + }, + { + "chainId": 1, + "address": "0x9f9c8ec3534c3ce16f928381372bfbfbfb9f4d24", + "name": "GraphLinq Protocol", + "symbol": "GLQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14474/thumb/graphlinq_logo.jpg?1616397109" + }, + { + "chainId": 1, + "address": "0x0eb638648207d00b9025684d13b1cb53806debe4", + "name": "NIL", + "symbol": "NIL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/21612/thumb/nil.PNG?1639608851" + }, + { + "chainId": 1, + "address": "0x174afe7a032b5a33a3270a9f6c30746e25708532", + "name": "Humanscape", + "symbol": "HUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4243/thumb/Webp.net-resizeimage_%2836%29.png?1547039574" + }, + { + "chainId": 1, + "address": "0xf091cf09c51811819db705710e9634b8bf18f164", + "name": "Couchain", + "symbol": "COU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4529/thumb/couchain.png?1547039825" + }, + { + "chainId": 1, + "address": "0xf5555732b3925356964695578fefcffcd31bcbb8", + "name": "Promodio", + "symbol": "PMD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18423/thumb/pmd_%281%29.png?1631858128" + }, + { + "chainId": 1, + "address": "0x38a2fdc11f526ddd5a607c1f251c065f40fbf2f7", + "name": "PhoenixDAO", + "symbol": "PHNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11523/thumb/Token_Icon.png?1618447147" + }, + { + "chainId": 1, + "address": "0xa249de6948022783765fee4850d7b85e43118fcc", + "name": "Jarvis ", + "symbol": "JAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8774/thumb/3jmUWB3e_400x400.jpg?1561085148" + }, + { + "chainId": 1, + "address": "0x9b68bfae21df5a510931a262cecf63f41338f264", + "name": "DecentBet", + "symbol": "DBET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1168/thumb/decent-bet.jpg?1547035195" + }, + { + "chainId": 1, + "address": "0x68e9c0d9aa450254aed2cd102503d4dff6b3c37c", + "name": "CrownSterling", + "symbol": "WCSOV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25179/thumb/9kL0liy4_400x400.jpg?1650541820" + }, + { + "chainId": 1, + "address": "0x6a6c2ada3ce053561c2fbc3ee211f23d9b8c520a", + "name": "TON", + "symbol": "TON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12334/thumb/ton.jpg?1599128436" + }, + { + "chainId": 1, + "address": "0x8d1ce361eb68e9e05573443c407d4a3bed23b033", + "name": "PieDAO DEFI ", + "symbol": "DEFI++", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13304/thumb/piedao__.png?1607322674" + }, + { + "chainId": 1, + "address": "0x10be9a8dae441d276a5027936c3aaded2d82bc15", + "name": "UniMex Network", + "symbol": "UMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13615/thumb/sloYxHx.jpeg?1633154340" + }, + { + "chainId": 1, + "address": "0xe81d72d14b1516e68ac3190a46c93302cc8ed60f", + "name": "Coinlancer", + "symbol": "CL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2445/thumb/coinlancer.png?1516072576" + }, + { + "chainId": 1, + "address": "0x7e9e431a0b8c4d532c745b1043c7fa29a48d4fba", + "name": "eosDAC", + "symbol": "EOSDAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3878/thumb/2644.png?1547038931" + }, + { + "chainId": 1, + "address": "0x3106a0a076bedae847652f42ef07fd58589e001f", + "name": "Alkimi", + "symbol": "ADS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17979/thumb/Alkimi_Alternatives_PNG.png?1669458732" + }, + { + "chainId": 1, + "address": "0x2373c5dc96238a64ce4062e74000fd3dacfd3bf7", + "name": "Angel Inu", + "symbol": "ANGEL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21024/thumb/NMqevqZ.png?1638193979" + }, + { + "chainId": 1, + "address": "0x0e2ef8aecb3c01ad5d596f1b67134e178199984d", + "name": "LandBox", + "symbol": "LAND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14875/thumb/jmKvZDn7_400x400.jpg?1618826129" + }, + { + "chainId": 1, + "address": "0xe35f19e4457a114a951781aaf421ec5266ef25fe", + "name": "Vidiachange", + "symbol": "VIDA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14346/thumb/vidia.png?1615504632" + }, + { + "chainId": 1, + "address": "0x6911f552842236bd9e8ea8ddbb3fb414e2c5fa9d", + "name": "Synapse Network", + "symbol": "SNP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17962/thumb/Webp-net-resizeimage_%282%29.png?1629943450" + }, + { + "chainId": 1, + "address": "0x2731d151cbdf84a8a4c6d9d0bae74012db51e428", + "name": "IFT", + "symbol": "IFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14049/thumb/ift_200x200.jpg?1614046057" + }, + { + "chainId": 1, + "address": "0x60be1e1fe41c1370adaf5d8e66f07cf1c2df2268", + "name": "Perion", + "symbol": "PERC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23302/thumb/perion.png?1661498749" + }, + { + "chainId": 1, + "address": "0xf2ddae89449b7d26309a5d54614b1fc99c608af5", + "name": "ASTA", + "symbol": "ASTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11123/thumb/asta_logo.png?1588734656" + }, + { + "chainId": 1, + "address": "0x25b3e27f03fd51163818b111690066e1b088f800", + "name": "Multi Farm Capital", + "symbol": "MFC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20694/thumb/mfclogo.png?1637564399" + }, + { + "chainId": 1, + "address": "0x78132543d8e20d2417d8a07d9ae199d458a0d581", + "name": "Luna Inu", + "symbol": "LINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25623/thumb/output-onlinepngtools.png?1653983337" + }, + { + "chainId": 1, + "address": "0x251457b7c5d85251ca1ab384361c821330be2520", + "name": "Hati", + "symbol": "HATI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25736/thumb/hati-logo.png?1653461606" + }, + { + "chainId": 1, + "address": "0x8eef5a82e6aa222a60f009ac18c24ee12dbf4b41", + "name": "Autobahn Network", + "symbol": "TXL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12432/thumb/txl.png?1646463631" + }, + { + "chainId": 1, + "address": "0xa461258c192cb6057ad8729589b0d18b08ccace8", + "name": "Planet Inu", + "symbol": "PLANETINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21025/thumb/61a411c49069ade3e2229ae2_2021-11-29_00.32_1.png?1638196668" + }, + { + "chainId": 1, + "address": "0x4eed0fa8de12d5a86517f214c2f11586ba2ed88d", + "name": "DragonBite", + "symbol": "BITE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16386/thumb/dragonbite.PNG?1623893567" + }, + { + "chainId": 1, + "address": "0x0ebb614204e47c09b6c3feb9aaecad8ee060e23e", + "name": "Cryptopay", + "symbol": "CPAY", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/2216/thumb/cryptopay.png?1547036499" + }, + { + "chainId": 1, + "address": "0xadc3f2c3d728202658930860158c726d8180a38f", + "name": "StarkMeta", + "symbol": "SMETA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25851/thumb/logo_starkmeta.png?1654150866" + }, + { + "chainId": 1, + "address": "0x24e3794605c84e580eea4972738d633e8a7127c8", + "name": "Katalyo", + "symbol": "KTLYO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13347/thumb/katalyo_logo_aqua_256.png?1607762430" + }, + { + "chainId": 1, + "address": "0x048fe49be32adfc9ed68c37d32b5ec9df17b3603", + "name": "Skrumble Network", + "symbol": "SKM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3826/thumb/skrumble-network.png?1548609513" + }, + { + "chainId": 1, + "address": "0xb97048628db6b661d4c2aa833e95dbe1a905b280", + "name": "TenX", + "symbol": "PAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/775/thumb/TenX-Icon-CircleBlack.png?1553766360" + }, + { + "chainId": 1, + "address": "0xcdb7ecfd3403eef3882c65b761ef9b5054890a47", + "name": "Hurify", + "symbol": "HUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2705/thumb/Hurify.jpg?1547036915" + }, + { + "chainId": 1, + "address": "0x391e86e2c002c70dee155eaceb88f7a3c38f5976", + "name": "Aave AMM UniUSDCWETH", + "symbol": "AAMMUNIUSDCWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17219/thumb/aAmmUniUSDCWETH.png?1626879118" + }, + { + "chainId": 1, + "address": "0x9a0587eae7ef64b2b38a10442a44cfa43edd7d2a", + "name": "Welltrado", + "symbol": "WTL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3612/thumb/welltrado.png?1548760605" + }, + { + "chainId": 1, + "address": "0xd24946147829deaa935be2ad85a3291dbf109c80", + "name": "Aave AMM USDC", + "symbol": "AAMMUSDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/17226/thumb/aAMMUSDC_2x.png?1626939994" + }, + { + "chainId": 1, + "address": "0x2822f6d1b2f41f93f33d937bc7d84a8dfa4f4c21", + "name": "Poseidon Network", + "symbol": "QQQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8442/thumb/LNBLzKy2_400x400.jpg?1558562627" + }, + { + "chainId": 1, + "address": "0xb83c27805aaca5c7082eb45c868d955cf04c337f", + "name": "JungleKing TigerCoin", + "symbol": "TIGER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26494/thumb/jungleparty.png?1658300842" + }, + { + "chainId": 1, + "address": "0x1c4481750daa5ff521a2a7490d9981ed46465dbd", + "name": "Blockmason Credit Protocol", + "symbol": "BCPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1022/thumb/mason.jpg?1547034948" + }, + { + "chainId": 1, + "address": "0x2fdf40c484b1bd6f1c214acac737fedc8b03e5a8", + "name": "MCS", + "symbol": "MCS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18925/thumb/MCS.png?1633928135" + }, + { + "chainId": 1, + "address": "0x33e07f5055173cf8febede8b21b12d1e2b523205", + "name": "Etherland", + "symbol": "ELAND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14432/thumb/eland.png?1616044253" + }, + { + "chainId": 1, + "address": "0xc91c885580da11ac060bdd692bdaa7ee29cfc976", + "name": "ZKasino", + "symbol": "ZKAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26649/thumb/zkasino.jpeg?1659405528" + }, + { + "chainId": 1, + "address": "0x5d4d57cd06fa7fe99e26fdc481b468f77f05073c", + "name": "Netkoin", + "symbol": "NTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5162/thumb/NTK.png?1606878538" + }, + { + "chainId": 1, + "address": "0x2d94aa3e47d9d5024503ca8491fce9a2fb4da198", + "name": "Bankless DAO", + "symbol": "BANK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15227/thumb/j4WEJrwU.png?1622615796" + }, + { + "chainId": 1, + "address": "0xf4f618eff5ef36cde2fca4fbd86554c62fb1382b", + "name": "Astra Guild Ventures", + "symbol": "AGV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21603/thumb/astra_guild.PNG?1639551997" + }, + { + "chainId": 1, + "address": "0x2f6ad7743924b1901a0771746152dde44c5f11de", + "name": "SCARDust", + "symbol": "SCARD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22098/thumb/SCARDust-token-icon-full-color-transparent-bg.png?1640796874" + }, + { + "chainId": 1, + "address": "0xb7fbff4ce5200215c690cc95855e5d6c5236ee9f", + "name": "CCSwap", + "symbol": "CC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15037/thumb/NEW-Logo-1.png?1622196132" + }, + { + "chainId": 1, + "address": "0x8a6aca71a218301c7081d4e96d64292d3b275ce0", + "name": "S Finance", + "symbol": "SFG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12605/thumb/Z7D8B4b.png?1605346184" + }, + { + "chainId": 1, + "address": "0x2008e3057bd734e10ad13c9eae45ff132abc1722", + "name": "Zebi", + "symbol": "ZCO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2756/thumb/zebi.png?1548761131" + }, + { + "chainId": 1, + "address": "0xa361718326c15715591c299427c62086f69923d9", + "name": "Aave BUSD", + "symbol": "ABUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14245/thumb/aBUSD.346a65d7_-_Copy.png?1615528703" + }, + { + "chainId": 1, + "address": "0xa888d9616c2222788fa19f05f77221a290eef704", + "name": "Daruma", + "symbol": "DARUMA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27357/thumb/CGlogo.png?1663661942" + }, + { + "chainId": 1, + "address": "0x528b3e98c63ce21c6f680b713918e0f89dfae555", + "name": "DeepSpace DXO", + "symbol": "DXO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18068/thumb/dxo.png?1635638762" + }, + { + "chainId": 1, + "address": "0x8f12dfc7981de79a8a34070a732471f2d335eece", + "name": "Crypto Excellence", + "symbol": "CE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14809/thumb/New_logo_CE.jpg?1643879310" + }, + { + "chainId": 1, + "address": "0xc631be100f6cf9a7012c23de5a6ccb990eafc133", + "name": "Banana Task Force Ape", + "symbol": "BTFA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25032/thumb/ZZpipp8e_400x400.jpg?1649851881" + }, + { + "chainId": 1, + "address": "0x53263d9ef74db583b15fbc6d5d4e8b83833fa134", + "name": "LEAP Token", + "symbol": "LEAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27258/thumb/LEAPtoken_LOGO.png?1663053803" + }, + { + "chainId": 1, + "address": "0xe632e1ea781df32c60ab11052958744cbfbc439a", + "name": "BAKC Vault NFTX ", + "symbol": "BAKC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17052/thumb/BYAC.png?1626149096" + }, + { + "chainId": 1, + "address": "0xdf49c9f599a0a9049d97cff34d0c30e468987389", + "name": "SaTT", + "symbol": "SATT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4070/thumb/r3s9XKk.png?1623046839" + }, + { + "chainId": 1, + "address": "0x27b5739e22ad9033bcbf192059122d163b60349d", + "name": "Staked Yearn CRV Vault", + "symbol": "ST-YCRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27623/thumb/styearncrv_32.png?1664885292" + }, + { + "chainId": 1, + "address": "0xceb286c9604c542d3cc08b41aa6c9675b078a832", + "name": "Vortex DeFi", + "symbol": "VTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14120/thumb/vortex_defi.png?1614514332" + }, + { + "chainId": 1, + "address": "0x60bb16c4a931b1a0b8a7d945c651dd90f41d42cf", + "name": "Finance Blocks", + "symbol": "FBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24117/thumb/financeblocksshadow.png?1646380305" + }, + { + "chainId": 1, + "address": "0x3d371413dd5489f3a04c07c0c2ce369c20986ceb", + "name": "YOUcash", + "symbol": "YOUC", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/11152/thumb/round-400x400.png?1589162715" + }, + { + "chainId": 1, + "address": "0x8275ebf521dc217aa79c88132017a5bcef001dd9", + "name": "Jewel", + "symbol": "JWL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6996/thumb/jewelpay_token.jpg?1547043400" + }, + { + "chainId": 1, + "address": "0xabea7663c472648d674bd3403d94c858dfeef728", + "name": "PUDGY Vault NFTX ", + "symbol": "PUDGY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18330/thumb/pudgy.png?1631605038" + }, + { + "chainId": 1, + "address": "0x333a4823466879eef910a04d473505da62142069", + "name": "Nation3", + "symbol": "NATION", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25106/thumb/Orb_gradient.png?1650321118" + }, + { + "chainId": 1, + "address": "0xb1f66997a5760428d3a87d68b90bfe0ae64121cc", + "name": "LuaSwap", + "symbol": "LUA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12627/thumb/Screenshot_2020-09-28_at_6.24.59_PM.jpg?1601288721" + }, + { + "chainId": 1, + "address": "0x3af33bef05c2dcb3c7288b77fe1c8d2aeba4d789", + "name": "Kromatika", + "symbol": "KROM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20541/thumb/KROM_Transparent.png?1641398421" + }, + { + "chainId": 1, + "address": "0x09f098b155d561fc9f7bccc97038b7e3d20baf74", + "name": "ZooDAO", + "symbol": "ZOO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24305/thumb/Zt2BM_8D_400x400.jpg?1647305115" + }, + { + "chainId": 1, + "address": "0x813b428af3920226e059b68a62e4c04933d4ea7a", + "name": "Decentralized Asset Trading Platform", + "symbol": "DATP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6565/thumb/Decentralized_Asset_Trading_Platform.jpg?1547042776" + }, + { + "chainId": 1, + "address": "0x7e6c38d007740931e4b419bf15a68c79a0fb0c66", + "name": "Unicly Doki Doki Collection", + "symbol": "UDOKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14900/thumb/uDOKI.jpg?1618935840" + }, + { + "chainId": 1, + "address": "0x3ef389f264e07fff3106a3926f2a166d1393086f", + "name": "Sator", + "symbol": "SAO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19410/thumb/sator-logo-CMC.png?1635211626" + }, + { + "chainId": 1, + "address": "0xef8ba8cba86f81b3108f60186fce9c81b5096d5c", + "name": "YFII Gold", + "symbol": "YFIIG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12587/thumb/yfiigold_logo.png?1600937694" + }, + { + "chainId": 1, + "address": "0x5fa2e9ba5757504b3d6e8f6da03cc40d4ce19499", + "name": "NFT Tech", + "symbol": "NFTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19297/thumb/nft_tech.PNG?1634916467" + }, + { + "chainId": 1, + "address": "0x5046e860ff274fb8c66106b0ffb8155849fb0787", + "name": "JavaScript", + "symbol": "JS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1061/thumb/js.png?1511578998" + }, + { + "chainId": 1, + "address": "0x9efdfc77017cb9b878300ecdca21fab0529a22a0", + "name": "Akitsuki", + "symbol": "AKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27746/thumb/akitsuinu-200.png?1665644986" + }, + { + "chainId": 1, + "address": "0x681ecc5a0bfd18c308a1138ff607f818bac5e417", + "name": "Luckstar", + "symbol": "LST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7804/thumb/49211002_377935006115216_8098246624284770304_n.png?1550735229" + }, + { + "chainId": 1, + "address": "0x513c3200f227ebb62e3b3d00b7a83779643a71cf", + "name": "Uplift", + "symbol": "LIFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20666/thumb/logo-200x200.png?1657675050" + }, + { + "chainId": 1, + "address": "0xceb53519a2b891d33b36e3826962d2a48f878e45", + "name": "YellowHeart Protocol", + "symbol": "HRTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25304/thumb/HRTS.png?1652087596" + }, + { + "chainId": 1, + "address": "0x47da5456bc2e1ce391b645ce80f2e97192e4976a", + "name": "PL Gnet", + "symbol": "PLUG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15824/thumb/PLUG_token.png?1622007572" + }, + { + "chainId": 1, + "address": "0xab846fb6c81370327e784ae7cbb6d6a6af6ff4bf", + "name": "Paladin", + "symbol": "PAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24558/thumb/Circle-Logo.png?1648180728" + }, + { + "chainId": 1, + "address": "0x96eb50804d0ef2790f2e1a33670feff6040cf89d", + "name": "Space Xmitter", + "symbol": "SX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28335/thumb/X200.png?1669680704" + }, + { + "chainId": 1, + "address": "0xaffcdd96531bcd66faed95fc61e443d08f79efef", + "name": "Perth Mint Gold Token", + "symbol": "PMGT", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/10730/thumb/pmgt_logo_256x256.png?1582668331" + }, + { + "chainId": 1, + "address": "0x668dbf100635f593a3847c0bdaf21f0a09380188", + "name": "BNSD Finance", + "symbol": "BNSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12368/thumb/bnsd.png?1599358388" + }, + { + "chainId": 1, + "address": "0xe0a189c975e4928222978a74517442239a0b86ff", + "name": "Keys", + "symbol": "KEYS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20604/thumb/200x200_%2843%29.png?1637289427" + }, + { + "chainId": 1, + "address": "0xb67718b98d52318240c52e71a898335da4a28c42", + "name": "Innovative Bioresearch Coin", + "symbol": "INNBC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/4043/thumb/INNBC.png?1582800857" + }, + { + "chainId": 1, + "address": "0x64d91f12ece7362f91a6f8e7940cd55f05060b92", + "name": "ASH", + "symbol": "ASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15714/thumb/omnPqaTY.png?1622820503" + }, + { + "chainId": 1, + "address": "0x6100dd79fcaa88420750dcee3f735d168abcb771", + "name": "Ethereans", + "symbol": "OS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19592/thumb/newOS.png?1635474948" + }, + { + "chainId": 1, + "address": "0xee4458e052b533b1aabd493b5f8c4d85d7b263dc", + "name": "Blockpass", + "symbol": "PASS", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/5462/thumb/cQl0gX0.png?1604815859" + }, + { + "chainId": 1, + "address": "0xfa5b75a9e13df9775cf5b996a049d9cc07c15731", + "name": "28VCK", + "symbol": "VCK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20063/thumb/9435.png?1636446186" + }, + { + "chainId": 1, + "address": "0xd37ee7e4f452c6638c96536e68090de8cbcdb583", + "name": "Aave GUSD", + "symbol": "AGUSD", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/17246/thumb/aGUSD_2x.png?1626942603" + }, + { + "chainId": 1, + "address": "0xb439b8731ee047799019ef0b745a51d256b116af", + "name": "BullionFX", + "symbol": "BULL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19251/thumb/237813872_101246862292596_7969491648103245595_n.png?1634797631" + }, + { + "chainId": 1, + "address": "0x0107c4aaa31940ef88760acb1f32424ca8d8bd80", + "name": "Authencity", + "symbol": "AUTH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26960/thumb/1.png?1661062419" + }, + { + "chainId": 1, + "address": "0x86e44543164d9b97b14ef7f6f3ab7ba670cab346", + "name": "QUINADS", + "symbol": "QUIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7041/thumb/quinads-logo.png?1547043484" + }, + { + "chainId": 1, + "address": "0x6c16119b20fa52600230f074b349da3cb861a7e3", + "name": "Alkemi Network DAO", + "symbol": "ALK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18391/thumb/alkemi-logo-icon-256x256.png?1631760166" + }, + { + "chainId": 1, + "address": "0x2d64750ec85f6ec442e3093d74c7b1b0a133be6a", + "name": "Point Coin", + "symbol": "POINT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27295/thumb/point.png?1663150205" + }, + { + "chainId": 1, + "address": "0x1fc5ef0337aea85c5f9198853a6e3a579a7a6987", + "name": "ReapChain", + "symbol": "REAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13109/thumb/REAP.jpg?1605259422" + }, + { + "chainId": 1, + "address": "0x0142c3b2fc51819b5af5dfc4aa52df9722790851", + "name": "Paycent", + "symbol": "PYN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2008/thumb/paycentos-logo-maroon.png?1547036284" + }, + { + "chainId": 1, + "address": "0x06a01a4d579479dd5d884ebf61a31727a3d8d442", + "name": "Skey Network", + "symbol": "SKEY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13425/thumb/SKEY_Network_logo_black.png?1633421778" + }, + { + "chainId": 1, + "address": "0xcfaf8edcea94ebaa080dc4983c3f9be5701d6613", + "name": "Exponential Capital", + "symbol": "EXPO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23409/thumb/expo.png?1645856094" + }, + { + "chainId": 1, + "address": "0x15c9dd08fb16331b9749a8d7d16bcd71c985f190", + "name": "CC", + "symbol": "CC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11593/thumb/CC_logo_200.png?1591599112" + }, + { + "chainId": 1, + "address": "0x884ddbb5dc6c2cef77d3e74c6ccca315797d655b", + "name": "Carnomaly", + "symbol": "CARR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14403/thumb/tcjOTKE3_400x400.png?1615895296" + }, + { + "chainId": 1, + "address": "0x0c3ef32f802967db75b9d49fe1e76620151ccb81", + "name": "Whole Network", + "symbol": "NODE", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/9522/thumb/61410314_394870017826322_8137973916426567680_n.png?1568604555" + }, + { + "chainId": 1, + "address": "0xcd74cf66c43e45abd5703f3642f73d0675d6aff7", + "name": "Erugo World Coin", + "symbol": "EWC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21652/thumb/Swhwfr3G_400x400.jpg?1639650872" + }, + { + "chainId": 1, + "address": "0x25e1474170c4c0aa64fa98123bdc8db49d7802fa", + "name": "Bidao", + "symbol": "BID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12596/thumb/bidao.png?1600996485" + }, + { + "chainId": 1, + "address": "0x7e80e4d7d5725499791cf8b17a4586f1f0672a0c", + "name": "ZOGI", + "symbol": "ZOGI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28446/thumb/ZOGI_Token_Logo.png?1670659477" + }, + { + "chainId": 1, + "address": "0x03b155af3f4459193a276395dd76e357bb472da1", + "name": "Swace", + "symbol": "SWACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3727/thumb/swace-symbol.png?1564553792" + }, + { + "chainId": 1, + "address": "0x9af15d7b8776fa296019979e70a5be53c714a7ec", + "name": "Evolution Finance", + "symbol": "EVN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13932/thumb/Frame_63_2.png?1612936435" + }, + { + "chainId": 1, + "address": "0x905e337c6c8645263d3521205aa37bf4d034e745", + "name": "Doc com", + "symbol": "MTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4177/thumb/2711.png?1650864171" + }, + { + "chainId": 1, + "address": "0xc314b0e758d5ff74f63e307a86ebfe183c95767b", + "name": "Adappter", + "symbol": "ADP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14203/thumb/logo_on.png?1614909616" + }, + { + "chainId": 1, + "address": "0x8e1b448ec7adfc7fa35fc2e885678bd323176e34", + "name": "Egretia", + "symbol": "EGT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3614/thumb/egretia.png?1547224764" + }, + { + "chainId": 1, + "address": "0xd059c8a4c7f53c4352d933b059349ba492294ac9", + "name": "Apple Protocol", + "symbol": "AAPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13208/thumb/aapl.png?1606200126" + }, + { + "chainId": 1, + "address": "0x9d62526f5ce701950c30f2caca70edf70f9fbf0f", + "name": "Blocktanium", + "symbol": "BKT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16650/thumb/bkt.png?1624592883" + }, + { + "chainId": 1, + "address": "0xfc05987bd2be489accf0f509e44b0145d68240f7", + "name": "Essentia", + "symbol": "ESS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2483/thumb/Essentia-token.jpg?1547036604" + }, + { + "chainId": 1, + "address": "0x3700adfd26d5bc062cb8b8a77e68fbd43f58ecab", + "name": "hiDOODLES", + "symbol": "HIDOODLES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27427/thumb/hidoodles.png?1663918652" + }, + { + "chainId": 1, + "address": "0xb753428af26e81097e7fd17f40c88aaa3e04902c", + "name": "saffron finance", + "symbol": "SFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13117/thumb/sfi_red_250px.png?1606020144" + }, + { + "chainId": 1, + "address": "0xca1207647ff814039530d7d35df0e1dd2e91fa84", + "name": "dHEDGE DAO", + "symbol": "DHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12508/thumb/dht.png?1600752201" + }, + { + "chainId": 1, + "address": "0x0b44547be0a0df5dcd5327de8ea73680517c5a54", + "name": "DATACHAIN FOUNDATION", + "symbol": "DC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24783/thumb/dc.png?1648903780" + }, + { + "chainId": 1, + "address": "0x71fc860f7d3a592a4a98740e39db31d25db65ae8", + "name": "Aave USDT v1", + "symbol": "AUSDT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/11725/thumb/aUSDT.png?1593082796" + }, + { + "chainId": 1, + "address": "0x7777777777697cfeecf846a76326da79cc606517", + "name": "xSigma", + "symbol": "SIG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14090/thumb/logo_128.png?1619775781" + }, + { + "chainId": 1, + "address": "0x0ec72cd6690db40b16be166858299f19d4f8e5b0", + "name": "Teh Golden One", + "symbol": "GOLD1", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27290/thumb/teh_golden_one_200x200.png?1663147215" + }, + { + "chainId": 1, + "address": "0xd0d3ebcad6a20ce69bc3bc0e1ec964075425e533", + "name": "Ethereum Stake", + "symbol": "ETHYS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13328/thumb/eths_logo.png?1607494708" + }, + { + "chainId": 1, + "address": "0x8e57c27761ebbd381b0f9d09bb92ceb51a358abb", + "name": "extraDNA", + "symbol": "XDNA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12667/thumb/Logo_coin_black.png?1601463830" + }, + { + "chainId": 1, + "address": "0x9280abf1af455d6228def9c93b5e6d85f3f1ecc8", + "name": "Film Coin", + "symbol": "FLIKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25117/thumb/Filmcoin_icon_32x32.png?1650349948" + }, + { + "chainId": 1, + "address": "0x686c77609afe6a2fac50421888530288b441fbd6", + "name": "Capital Aggregator", + "symbol": "CAT+", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24794/thumb/cat_.png?1648977982" + }, + { + "chainId": 1, + "address": "0x20d4db1946859e2adb0e5acc2eac58047ad41395", + "name": "Moon DAO", + "symbol": "MOONEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22905/thumb/cVWTHdA.png?1645690722" + }, + { + "chainId": 1, + "address": "0x0000000000b3f879cb30fe243b4dfee438691c04", + "name": "GasToken", + "symbol": "GST2", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/10779/thumb/gas.png?1583466756" + }, + { + "chainId": 1, + "address": "0x3543638ed4a9006e4840b105944271bcea15605d", + "name": "U Network", + "symbol": "UUU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3877/thumb/2645.png?1547038930" + }, + { + "chainId": 1, + "address": "0x7ca62545a380e7d71f8f5cfa14b9211002075930", + "name": "GivingToServices SVS", + "symbol": "SVS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16436/thumb/9UbufKC.png?1655180835" + }, + { + "chainId": 1, + "address": "0xe75ad3aab14e4b0df8c5da4286608dabb21bd864", + "name": "Double A Chain", + "symbol": "AAC", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/2577/thumb/acute-angle-cloud.png?1547036708" + }, + { + "chainId": 1, + "address": "0xa96f31f1c187c28980176c3a27ba7069f48abde4", + "name": "Ethereum Gold Project", + "symbol": "ETGP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7337/thumb/llxg4bqE_400x400.jpg?1547044001" + }, + { + "chainId": 1, + "address": "0xcc802c45b55581713cecd1eb17be9ab7fccb0844", + "name": "SBU Honey", + "symbol": "BHNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26079/thumb/honey.png?1655694712" + }, + { + "chainId": 1, + "address": "0xfd020998a1bb316dfe7b136fe59ae4b365d79978", + "name": "Golden Goal", + "symbol": "GDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26345/thumb/3kmKPRHZ_400x400.jpeg?1657586811" + }, + { + "chainId": 1, + "address": "0xa06bc25b5805d5f8d82847d191cb4af5a3e873e0", + "name": "Aave LINK", + "symbol": "ALINK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14315/thumb/aLINK.412c6589.png?1615527827" + }, + { + "chainId": 1, + "address": "0xbdcfbf5c4d91abc0bc9709c7286d00063c0e6f22", + "name": "PeerGuess", + "symbol": "GUESS", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/1743/thumb/guess.png?1547036022" + }, + { + "chainId": 1, + "address": "0x4ba6ddd7b89ed838fed25d208d4f644106e34279", + "name": "Vether", + "symbol": "VETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11375/thumb/vether-symbol-coingecko.png?1622341592" + }, + { + "chainId": 1, + "address": "0xf3db5fa2c66b7af3eb0c0b782510816cbe4813b8", + "name": "Everex", + "symbol": "EVX", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/997/thumb/everex.png?1548125695" + }, + { + "chainId": 1, + "address": "0xc813ea5e3b48bebeedb796ab42a30c5599b01740", + "name": "Autonio", + "symbol": "NIOX", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/1122/thumb/NewLogo.png?1597298450" + }, + { + "chainId": 1, + "address": "0x539efe69bcdd21a83efd9122571a64cc25e0282b", + "name": "Blue Protocol", + "symbol": "BLUE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1036/thumb/blue-protocol.jpg?1547034969" + }, + { + "chainId": 1, + "address": "0x1f4cb968b76931c494ff92ed80ccb169ad641cb1", + "name": "Structure Finance", + "symbol": "STF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18409/thumb/v4RAXKdq_400x400_%281%29.jpg?1631797904" + }, + { + "chainId": 1, + "address": "0xf921ae2dac5fa128dc0f6168bf153ea0943d2d43", + "name": "Fire Protocol", + "symbol": "FIRE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13495/thumb/fire.jpg?1609165121" + }, + { + "chainId": 1, + "address": "0x970cf867ca0530a989f222be01fdd67c1ab5b2bf", + "name": "Basan", + "symbol": "BASAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27988/thumb/BigBasanLogo_%281%29.png?1666864518" + }, + { + "chainId": 1, + "address": "0x9f7229af0c4b9740e207ea283b9094983f78ba04", + "name": "Tadpole", + "symbol": "TAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13134/thumb/9DmF_cs3_400x400.jpg?1605574755" + }, + { + "chainId": 1, + "address": "0x539f3615c1dbafa0d008d87504667458acbd16fa", + "name": "Fera", + "symbol": "FERA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12143/thumb/IMG_20200908_085545_557.jpg?1599563732" + }, + { + "chainId": 1, + "address": "0x8cb924583681cbfe487a62140a994a49f833c244", + "name": "SWAPP Protocol", + "symbol": "SWAPP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16216/thumb/swapp.png?1634259998" + }, + { + "chainId": 1, + "address": "0x035df12e0f3ac6671126525f1015e47d79dfeddf", + "name": "0xMonero", + "symbol": "0XMR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11035/thumb/0xmnr.PNG?1587357680" + }, + { + "chainId": 1, + "address": "0xcdeee767bed58c5325f68500115d4b722b3724ee", + "name": "Carbon", + "symbol": "CRBN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13262/thumb/carbon.png?1662693418" + }, + { + "chainId": 1, + "address": "0x0e5c8c387c5eba2ecbc137ad012aed5fe729e251", + "name": "Rangers Protocol", + "symbol": "RPG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18791/thumb/tO8MlqiM_400x400.png?1633421196" + }, + { + "chainId": 1, + "address": "0x083d41d6dd21ee938f0c055ca4fb12268df0efac", + "name": "GogolCoin", + "symbol": "GOL", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/14824/thumb/GOL.png?1618559300" + }, + { + "chainId": 1, + "address": "0x80ce3027a70e0a928d9268994e9b85d03bd4cdcf", + "name": "Lokr", + "symbol": "LKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14692/thumb/lokr.png?1648886932" + }, + { + "chainId": 1, + "address": "0xe5a733681bbe6cd8c764bb8078ef8e13a576dd78", + "name": "Devour", + "symbol": "DPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27191/thumb/dpay.png?1665907874" + }, + { + "chainId": 1, + "address": "0xab37e1358b639fd877f015027bb62d3ddaa7557e", + "name": "Lien", + "symbol": "LIEN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12224/thumb/Lien.png?1598262819" + }, + { + "chainId": 1, + "address": "0xe516d78d784c77d479977be58905b3f2b1111126", + "name": "Bitspawn", + "symbol": "SPWN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16513/thumb/token_logo.png?1631603192" + }, + { + "chainId": 1, + "address": "0xdc47f2ba852669b178699449e50682d6ceaf8c07", + "name": "Ston", + "symbol": "STON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13001/thumb/ston-v2-200x200.png?1604284194" + }, + { + "chainId": 1, + "address": "0x1ccaa0f2a7210d76e1fdec740d5f323e2e1b1672", + "name": "Faceter", + "symbol": "FACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4383/thumb/faceter-logo.png?1547039727" + }, + { + "chainId": 1, + "address": "0xee1ae38be4ce0074c4a4a8dc821cc784778f378c", + "name": "VYNK Chain", + "symbol": "VYNC", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/17743/thumb/vynk_chain.PNG?1629150126" + }, + { + "chainId": 1, + "address": "0x514cdb9cd8a2fb2bdcf7a3b8ddd098caf466e548", + "name": "RedPanda Earth", + "symbol": "REDPANDA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15736/thumb/N-52GutZ_400x400.jpg?1621684353" + }, + { + "chainId": 1, + "address": "0x0aacfbec6a24756c20d41914f2caba817c0d8521", + "name": "YAM", + "symbol": "YAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12530/thumb/YAM-icon.png?1600495536" + }, + { + "chainId": 1, + "address": "0xf720e38f678b29b243f7d53b56acbf5de98f2385", + "name": "Upfire", + "symbol": "UPR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20562/thumb/UPR256.png?1637214757" + }, + { + "chainId": 1, + "address": "0x7a3c45f34ea5df6fe5f6af710ec8a04d388a71d1", + "name": "Pando", + "symbol": "PANDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14150/thumb/pando_logo.png?1614667045" + }, + { + "chainId": 1, + "address": "0x9cf98eb8a8b28c83e8612046cf55701ce3eb0063", + "name": "Unreal Finance", + "symbol": "UGT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17943/thumb/11292.png?1629883358" + }, + { + "chainId": 1, + "address": "0x66186008c1050627f979d464eabb258860563dbe", + "name": "MediShares", + "symbol": "MDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1343/thumb/medishares.png?1547978625" + }, + { + "chainId": 1, + "address": "0xaa602de53347579f86b996d2add74bb6f79462b2", + "name": "Zipmex", + "symbol": "ZMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13866/thumb/ZMT_Token.png?1637241562" + }, + { + "chainId": 1, + "address": "0x4fbb350052bca5417566f188eb2ebce5b19bc964", + "name": "RigoBlock", + "symbol": "GRG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1532/thumb/Symbol-RigoblockRGB.png?1547035682" + }, + { + "chainId": 1, + "address": "0x310c8f00b9de3c31ab95ea68feb6c877538f7947", + "name": "Undead Blocks", + "symbol": "UNDEAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25382/thumb/AB0Uemhlw6jR.png?1651488079" + }, + { + "chainId": 1, + "address": "0x6a969d379700b2e5ea4e684d273d63c1c050ba49", + "name": "Pacific", + "symbol": "PAF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20915/thumb/paf.png?1637922989" + }, + { + "chainId": 1, + "address": "0xd83ae04c9ed29d6d3e6bf720c71bc7beb424393e", + "name": "InsureDAO", + "symbol": "INSURE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23913/thumb/InsureDAO_-_Final_Logo_%28solo%29.png?1645682885" + }, + { + "chainId": 1, + "address": "0x0173661769325565d4f011b2e5cda688689cc87c", + "name": "Quantland", + "symbol": "QLT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24536/thumb/8jYfKBTk_400x400.jpg?1648051247" + }, + { + "chainId": 1, + "address": "0xbbd900e05b4af2124390d206f70bc4e583b1be85", + "name": "MintySwap", + "symbol": "MINTYS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17975/thumb/Minty-logo-200x200.png?1629966728" + }, + { + "chainId": 1, + "address": "0xac6df26a590f08dcc95d5a4705ae8abbc88509ef", + "name": "Aave ENJ", + "symbol": "AENJ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14251/thumb/aENJ.ed76293b.png?1615528574" + }, + { + "chainId": 1, + "address": "0xd945d2031b4c63c0e363304fb771f709b502dc0a", + "name": "BountyMarketCap", + "symbol": "BMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13472/thumb/bmc-logo-200.png?1608852915" + }, + { + "chainId": 1, + "address": "0x39d30828a163713d91c4eadbba2c497a9139ec5c", + "name": "Happy Birthday Coin", + "symbol": "HBDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12814/thumb/%EC%A7%84%ED%92%88.png?1630840854" + }, + { + "chainId": 1, + "address": "0xbe428c3867f05dea2a89fc76a102b544eac7f772", + "name": "CyberVein", + "symbol": "CVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3886/thumb/CyberVein_LOGO.png?1616062326" + }, + { + "chainId": 1, + "address": "0x66761fa41377003622aee3c7675fc7b5c1c2fac5", + "name": "Clearpool", + "symbol": "CPOOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19252/thumb/photo_2022-08-31_12.45.02.jpeg?1662105063" + }, + { + "chainId": 1, + "address": "0x99c6e435ec259a7e8d65e1955c9423db624ba54c", + "name": "Finminity", + "symbol": "FMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14696/thumb/finminity.png?1617834914" + }, + { + "chainId": 1, + "address": "0x6765fdd028be3d7874bc2bb3d7d5ca01c1bf14b2", + "name": "Talaria Inu", + "symbol": "TALI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21849/thumb/200_%2815%29.png?1640137716" + }, + { + "chainId": 1, + "address": "0x6f4ee03ca6c942c9397d2ba5f8f83ea58f918f47", + "name": "CashBackPro", + "symbol": "CBP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12893/thumb/logo_%2818%29.png?1603766120" + }, + { + "chainId": 1, + "address": "0x4be10da47a07716af28ad199fbe020501bddd7af", + "name": "XT com", + "symbol": "XT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8391/thumb/XT_token.jpg?1557979399" + }, + { + "chainId": 1, + "address": "0x3c4008eca800ec1283e4cf500e68d06bfabc00a8", + "name": "HistoryDAO", + "symbol": "HAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27318/thumb/5961657012978_.pic.jpg?1663316216" + }, + { + "chainId": 1, + "address": "0xd49efa7bc0d339d74f487959c573d518ba3f8437", + "name": "Coliquidity", + "symbol": "COLI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15813/thumb/sign_dark_200x200.png?1646641417" + }, + { + "chainId": 1, + "address": "0x1b980e05943de3db3a459c72325338d327b6f5a9", + "name": "Bitgear", + "symbol": "GEAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12127/thumb/bitgear_logo.png?1597377982" + }, + { + "chainId": 1, + "address": "0xb1f233835de2440620332267ba729bfe74fa2cfd", + "name": "SoloxCoin", + "symbol": "SL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25704/thumb/22223333333.png?1653460112" + }, + { + "chainId": 1, + "address": "0x9d5963ba32e877871dff3e2e697283dc64066271", + "name": "Edcoin", + "symbol": "EDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13872/thumb/EDCOIN-1.png?1612447671" + }, + { + "chainId": 1, + "address": "0x630d98424efe0ea27fb1b3ab7741907dffeaad78", + "name": "PEAKDEFI", + "symbol": "PEAK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9626/thumb/PEAKDEFI_Logo_250x250.png?1603094772" + }, + { + "chainId": 1, + "address": "0x3391bc034f2935ef0e1e41619445f998b2680d35", + "name": "IdleUSDC Risk Adjusted ", + "symbol": "IDLEUSDCSAFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11930/thumb/idleusdc-safe.png?1596263257" + }, + { + "chainId": 1, + "address": "0x1e4e46b7bf03ece908c88ff7cc4975560010893a", + "name": "Internet of Energy Network", + "symbol": "IOEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19095/thumb/12799.png?1634422996" + }, + { + "chainId": 1, + "address": "0x963035453633f6f7433032c958f82eb3043d8cd2", + "name": "USD Freedom", + "symbol": "USDF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26920/thumb/USDF_200x200.png?1660815930" + }, + { + "chainId": 1, + "address": "0xa803778ab953d3ffe4fbd20cfa0042ecefe8319d", + "name": "Totem", + "symbol": "CTZN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21558/thumb/ctzn.png?1642930817" + }, + { + "chainId": 1, + "address": "0xd31a59c85ae9d8edefec411d448f90841571b89c", + "name": "SOL Wormhole ", + "symbol": "SOL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22876/thumb/SOL_wh_small.png?1644224316" + }, + { + "chainId": 1, + "address": "0xdfe691f37b6264a90ff507eb359c45d55037951c", + "name": "Karma DAO", + "symbol": "KARMA", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/11884/thumb/Karma.png?1597042574" + }, + { + "chainId": 1, + "address": "0x9590d8c06ba451bbad0893f2ef0d2a8b5acc67d3", + "name": "SCORCHER", + "symbol": "SCOR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/26683/thumb/SCORCHER_LOGO_-_200.png?1659594039" + }, + { + "chainId": 1, + "address": "0xc9bc48c72154ef3e5425641a3c747242112a46af", + "name": "Aave RAI", + "symbol": "ARAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17245/thumb/aRAI_2x.png?1626942652" + }, + { + "chainId": 1, + "address": "0x1afb69dbc9f54d08dab1bd3436f8da1af819e647", + "name": "Melos Studio", + "symbol": "MELOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24411/thumb/18551.png?1647558428" + }, + { + "chainId": 1, + "address": "0x26cbc7008cd879f4b63b69a915378f2d9b17bbf0", + "name": "Natural Farm Union Protocol", + "symbol": "NFUP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21052/thumb/logo_-_2021-11-30T163428.088.png?1638261294" + }, + { + "chainId": 1, + "address": "0x95a1796437bad6502d1c1cce165cd76e522409a9", + "name": "Official Crypto Cowboy", + "symbol": "OCCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20302/thumb/OCCT-SPROCCT_200x200.PNG?1644480861" + }, + { + "chainId": 1, + "address": "0xc4d5545392f5fc57eba3af8981815669bb7e2a48", + "name": "HEdpAY", + "symbol": "HDP", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/7496/thumb/icon_hedpay.png?1555485710" + }, + { + "chainId": 1, + "address": "0x939a7a577d93ad29b64c1595b1284ce660a479b9", + "name": "Jejudoge", + "symbol": "JEJUDOGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15983/thumb/jejudoge.png?1634782252" + }, + { + "chainId": 1, + "address": "0x4576e6825b462b6916d2a41e187626e9090a92c6", + "name": "Donkey DON", + "symbol": "DON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18257/thumb/Donkey_Logo_CMC.png?1631154862" + }, + { + "chainId": 1, + "address": "0xdae5add81b1fa1b04c0df225f0c3a029b93cb91b", + "name": "3gg", + "symbol": "3GG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27864/thumb/%E8%9E%A2%E5%B9%95%E6%88%AA%E5%9C%96_2022-10-17_%E4%B8%8B%E5%8D%888.28.14.png?1666151176" + }, + { + "chainId": 1, + "address": "0x3abf2a4f8452ccc2cf7b4c1e4663147600646f66", + "name": "Juicebox", + "symbol": "JBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21120/thumb/CCeIEmvE_400x400.jpg?1638341224" + }, + { + "chainId": 1, + "address": "0xe09216f1d343dd39d6aa732a08036fee48555af0", + "name": "Contribute", + "symbol": "TRIB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12576/thumb/New_logo_circle.png?1604214723" + }, + { + "chainId": 1, + "address": "0x7deb5e830be29f91e298ba5ff1356bb7f8146998", + "name": "Aave MKR v1", + "symbol": "AMKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11731/thumb/aMKR.png?1593084715" + }, + { + "chainId": 1, + "address": "0xd49ff13661451313ca1553fd6954bd1d9b6e02b9", + "name": "Electrify Asia", + "symbol": "ELEC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3415/thumb/d45b1d82743c749d05697da200179874.jpg?1547038096" + }, + { + "chainId": 1, + "address": "0x52928c95c4c7e934e0efcfab08853a0e4558861d", + "name": "Hara", + "symbol": "HART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5138/thumb/hara.jpg?1547040533" + }, + { + "chainId": 1, + "address": "0x8b98df4dff429e64e9a56fc6eebe2380c6c3409c", + "name": "Si14Bet", + "symbol": "SI14", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14973/thumb/logo-si14.png?1619213479" + }, + { + "chainId": 1, + "address": "0xc0ec8caec55f37d47fbfa595727418868a21fd48", + "name": "EcoG9coin", + "symbol": "EGC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8038/thumb/Screenshot_2019-12-05_at_7.14.34_AM.png?1575501284" + }, + { + "chainId": 1, + "address": "0xa6a1cc527d48585538b137e6abc14b2a55489d11", + "name": "Linework Coin", + "symbol": "LWC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27739/thumb/Linework-logo_coin_200px-01.png?1665578755" + }, + { + "chainId": 1, + "address": "0xc1d9b5a0776d7c8b98b8a838e5a0dd1bc5fdd53c", + "name": "GridZone io", + "symbol": "ZONE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18098/thumb/Gridzone_logo_V2.png?1630468285" + }, + { + "chainId": 1, + "address": "0x1341a2257fa7b770420ef70616f888056f90926c", + "name": "Zoo", + "symbol": "ZOOT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15629/thumb/gyzERsO.png?1621394316" + }, + { + "chainId": 1, + "address": "0xb26c4b3ca601136daf98593feaeff9e0ca702a8d", + "name": "Aladdin DAO", + "symbol": "ALD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18277/thumb/78200839.png?1631234134" + }, + { + "chainId": 1, + "address": "0x93ed3fbe21207ec2e8f2d3c3de6e058cb73bc04d", + "name": "Kleros", + "symbol": "PNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3833/thumb/kleros.png?1547975322" + }, + { + "chainId": 1, + "address": "0x0e29e5abbb5fd88e28b2d355774e73bd47de3bcd", + "name": "Hakka Finance", + "symbol": "HAKKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12163/thumb/Hakka-icon.png?1597746776" + }, + { + "chainId": 1, + "address": "0x26db5439f651caf491a87d48799da81f191bdb6b", + "name": "CBC network", + "symbol": "CBC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2477/thumb/Icon_for_White_Bg_75x75.png?1637155730" + }, + { + "chainId": 1, + "address": "0xb9ef770b6a5e12e45983c5d80545258aa38f3b78", + "name": "Zus", + "symbol": "ZCN", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/4934/thumb/200x200_transparent.png?1669366739" + }, + { + "chainId": 1, + "address": "0x3bbd4cb91442d8aeaeb0523a5f99540658a685ea", + "name": "Elden Knights", + "symbol": "KNIGHTS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27406/thumb/Eldenknights-LOGO.png?1663842018" + }, + { + "chainId": 1, + "address": "0x534d1f5e617e0f72a6b06a04aa599839af776a5e", + "name": "Blockswap Network", + "symbol": "BSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27023/thumb/BSN_brandmark_in_black_circle_preview.png?1661484890" + }, + { + "chainId": 1, + "address": "0x1900e8b5619a3596745f715d0427fe617c729ba9", + "name": "Chainbing", + "symbol": "CBG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18052/thumb/j3saoPU.png?1630330010" + }, + { + "chainId": 1, + "address": "0xdfd8d604951ebf1b2297285f1b68de140c43992b", + "name": "Metasens", + "symbol": "MSU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24418/thumb/Metasens-3d-LOGO.png?1647611333" + }, + { + "chainId": 1, + "address": "0x6570ffe19da7e2b425329b157d9109b87f18304b", + "name": "UNIUM", + "symbol": "UNM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24567/thumb/Unium_logo.png?1648195706" + }, + { + "chainId": 1, + "address": "0x3f5294df68f871241c4b18fcf78ebd8ac18ab654", + "name": "99Starz", + "symbol": "STZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21467/thumb/stz.png?1639651623" + }, + { + "chainId": 1, + "address": "0xff8be4b22cedc440591dcb1e641eb2a0dd9d25a5", + "name": "Uranus", + "symbol": "URAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4683/thumb/Leood48Z_400x400.jpg?1563118461" + }, + { + "chainId": 1, + "address": "0x653430560be843c4a3d143d0110e896c2ab8ac0d", + "name": "Molecular Future", + "symbol": "MOF", + "decimals": 16, + "logoURI": "https://assets.coingecko.com/coins/images/2607/thumb/molecular_future.png?1547036754" + }, + { + "chainId": 1, + "address": "0xf256cc7847e919fac9b808cc216cac87ccf2f47a", + "name": "Aave XSUSHI", + "symbol": "AXSUSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17256/thumb/aXSUSHI_2x.png?1626957111" + }, + { + "chainId": 1, + "address": "0x957891c11616d3e0b0a76a76fb42724c382e0ef3", + "name": "Collateral Pay", + "symbol": "COLL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14682/thumb/cpay.jpg?1617767452" + }, + { + "chainId": 1, + "address": "0x1f19f83fc9a25f3c861260143e36c17706257986", + "name": "DAO Invest", + "symbol": "VEST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17901/thumb/logo-round-200.png?1629773511" + }, + { + "chainId": 1, + "address": "0x3231cb76718cdef2155fc47b5286d82e6eda273f", + "name": "Monerium EUR emoney", + "symbol": "EURE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23354/thumb/eur.png?1643926562" + }, + { + "chainId": 1, + "address": "0xcc12abe4ff81c9378d670de1b57f8e0dd228d77a", + "name": "Aave REN", + "symbol": "AREN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14249/thumb/aREN.382be386.png?1615528633" + }, + { + "chainId": 1, + "address": "0x2a54ba2964c8cd459dc568853f79813a60761b58", + "name": "Interest Protocol USDi", + "symbol": "USDI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25999/thumb/20598.png?1655277115" + }, + { + "chainId": 1, + "address": "0xb9d7cb55f463405cdfbe4e90a6d2df01c2b92bf1", + "name": "Aave UNI", + "symbol": "AUNI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17247/thumb/aUNI_2x.png?1626942594" + }, + { + "chainId": 1, + "address": "0x2baac9330cf9ac479d819195794d79ad0c7616e3", + "name": "adbank", + "symbol": "ADB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2806/thumb/adbank.png?1547036978" + }, + { + "chainId": 1, + "address": "0x9319820ad5447180d0cbb76c1c06c870562aef93", + "name": "Oceidon Blox", + "symbol": "OBLOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23708/thumb/Oceidon-Blox-Logo-Square-GC.png?1645083132" + }, + { + "chainId": 1, + "address": "0x4e3bddd468abfc6c88bc25daa5d894380ced5bc8", + "name": "NSS Coin", + "symbol": "NSS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9501/thumb/adddcf817f.png?1568108247" + }, + { + "chainId": 1, + "address": "0x26a9c0c6f28ae2e69270bc39f13db87a27db4ce5", + "name": "Defi Bomb", + "symbol": "DBOMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27946/thumb/IMG_8762E9D638E0-1.jpeg?1666606436" + }, + { + "chainId": 1, + "address": "0x035bfe6057e15ea692c0dfdcab3bb41a64dd2ad4", + "name": "Universal Liquidity Union", + "symbol": "ULU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12376/thumb/ulu_finance_logo.ico?1599444401" + }, + { + "chainId": 1, + "address": "0x0275e1001e293c46cfe158b3702aade0b99f88a5", + "name": "Oiler", + "symbol": "OIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15249/thumb/oiler.png?1620237607" + }, + { + "chainId": 1, + "address": "0xa54d2ebfd977ad836203c85f18db2f0a0cf88854", + "name": "Bacon Coin", + "symbol": "BACON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25173/thumb/bacon-200.png?1650526720" + }, + { + "chainId": 1, + "address": "0xb624fde1a972b1c89ec1dad691442d5e8e891469", + "name": "SporkDAO", + "symbol": "SPORK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23358/thumb/sporkdao.PNG?1643942687" + }, + { + "chainId": 1, + "address": "0x0557e0d15aec0b9026dd17aa874fdf7d182a2ceb", + "name": "CFX Quantum", + "symbol": "CFXQ", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/15031/thumb/CFXQ_TOKEN_LOGO_200x200.png?1619500058" + }, + { + "chainId": 1, + "address": "0x4fc15c91a9c4a9efb404174464687e8e128730c2", + "name": "STAT", + "symbol": "STAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26602/thumb/stat.png?1667291701" + }, + { + "chainId": 1, + "address": "0x3a0b022f32b3191d44e5847da12dc0b63fb07c91", + "name": "Spellfire", + "symbol": "SPELLFIRE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23107/thumb/17316.png?1643261163" + }, + { + "chainId": 1, + "address": "0xed03ed872159e199065401b6d0d487d78d9464aa", + "name": "Mexican Peso Tether", + "symbol": "MXNT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/26087/thumb/MXNT_green.jpg?1655772424" + }, + { + "chainId": 1, + "address": "0x433fce7dfbec729a79999eaf056cb073b2153eba", + "name": "CoinWealth", + "symbol": "CNW", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/23769/thumb/cw_logo-4955f59a5c8079f246fa07ac71b2541870ca7d906ca1d9c26d74a3870fafef2f_%281%29.png?1645425522" + }, + { + "chainId": 1, + "address": "0x114f1388fab456c4ba31b1850b244eedcd024136", + "name": "COOL Vault NFTX ", + "symbol": "COOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17032/thumb/COOL.png?1626142075" + }, + { + "chainId": 1, + "address": "0xa2a54f1ec1f09316ef12c1770d32ed8f21b1fb6a", + "name": "DigiFinex", + "symbol": "DFT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4819/thumb/digifinextoken.png?1547040187" + }, + { + "chainId": 1, + "address": "0x737f98ac8ca59f2c68ad658e3c3d8c8963e40a4c", + "name": "Amon", + "symbol": "AMN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2369/thumb/amon.png?1547036554" + }, + { + "chainId": 1, + "address": "0xf722b7b4876cbba560846556dd1f5932eb503de2", + "name": "Alpha Pad", + "symbol": "APAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24324/thumb/Untitled-design-1.png?1647357411" + }, + { + "chainId": 1, + "address": "0x0d15009896efe9972f8e086bdd3bcba5c1f74bf3", + "name": "SonoCoin", + "symbol": "SONO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7230/thumb/MeWTs09-_400x400.jpg?1582700314" + }, + { + "chainId": 1, + "address": "0x4b7ee45f30767f36f06f79b32bf1fca6f726deda", + "name": "Ethereum Wrapped Filecoin", + "symbol": "EFIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18231/thumb/output-onlinepngtools_%287%29.png?1631060559" + }, + { + "chainId": 1, + "address": "0x72de803b67b6ab05b61efab2efdcd414d16ebf6d", + "name": "LedgerScore", + "symbol": "LED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16144/thumb/photo-2021-06-05-07-45-06.jpg?1623119314" + }, + { + "chainId": 1, + "address": "0x35a18000230da775cac24873d00ff85bccded550", + "name": "cUNI", + "symbol": "CUNI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12696/thumb/compound-uni.png?1601789718" + }, + { + "chainId": 1, + "address": "0x8af5fedc0f263841c18f31d9dbcc97a47e1ab462", + "name": "MESSIER", + "symbol": "M87", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25957/thumb/MESSIERlogonew_%281%29.png?1666773848" + }, + { + "chainId": 1, + "address": "0x9d561d63375672abd02119b9bc4fb90eb9e307ca", + "name": "Ally Direct", + "symbol": "DRCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16807/thumb/ally_icon.png?1625148232" + }, + { + "chainId": 1, + "address": "0xeaf61fc150cd5c3bea75744e830d916e60ea5a9f", + "name": "Typerium", + "symbol": "TYPE", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/4019/thumb/type.png?1547039124" + }, + { + "chainId": 1, + "address": "0x38e491a71291cd43e8de63b7253e482622184894", + "name": "Aave AMM UniSNXWETH", + "symbol": "AAMMUNISNXWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17224/thumb/aAmmUniSNXWETH.png?1626880874" + }, + { + "chainId": 1, + "address": "0x900db999074d9277c5da2a43f252d74366230da0", + "name": "Giveth", + "symbol": "GIV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21792/thumb/GIVToken_200x200.png?1640055088" + }, + { + "chainId": 1, + "address": "0xf8497f1dab075a3674363b5609ba679f7dc9c885", + "name": "Sodatsu", + "symbol": "SODATSU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28061/thumb/SODATSU_Token_Logo_-_200x200.png?1667300564" + }, + { + "chainId": 1, + "address": "0x375abb85c329753b1ba849a601438ae77eec9893", + "name": "ParagonsDAO", + "symbol": "PDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22642/thumb/6_Ms7ltG_400x400.jpg?1642395792" + }, + { + "chainId": 1, + "address": "0x58f7345b5295e43aa454911571f13be186655be9", + "name": "Garlicoin", + "symbol": "GRLC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2699/thumb/garlicoin.png?1548126827" + }, + { + "chainId": 1, + "address": "0xf9fb4ad91812b704ba883b11d2b576e890a6730a", + "name": "Aave AMM WETH", + "symbol": "AAMMWETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17259/thumb/aAMMWETH_2x.png?1626958225" + }, + { + "chainId": 1, + "address": "0x5d3a4f62124498092ce665f865e0b38ff6f5fbea", + "name": "Ideaology", + "symbol": "IDEA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13938/thumb/idea_logo.png?1613022658" + }, + { + "chainId": 1, + "address": "0x6876eba317272fe221c67405c5e8eb3b24535547", + "name": "MicroTuber", + "symbol": "MCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15489/thumb/mct.PNG?1621040638" + }, + { + "chainId": 1, + "address": "0x549044000a94870ab7c5017cd8fb0aefa9239a13", + "name": "UCONetwork", + "symbol": "UCOIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27633/thumb/logo.png?1664961037" + }, + { + "chainId": 1, + "address": "0x9332dfc361763d58565139da819c86e773e17249", + "name": "UniPlay", + "symbol": "UNP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27768/thumb/yHxDwXCN_400x400.png?1665721111" + }, + { + "chainId": 1, + "address": "0xe00639a1f59b52773b7d39d9f9bef07f6248dbae", + "name": "The DAOX Index", + "symbol": "DAOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25042/thumb/200px-DAOx.png?1649911875" + }, + { + "chainId": 1, + "address": "0xebf4ca5319f406602eeff68da16261f1216011b5", + "name": "Yobit", + "symbol": "YO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9231/thumb/ybx_logo.gif?1565306320" + }, + { + "chainId": 1, + "address": "0x4e114d405b9ba2f59524941733e505ae03fb1fb5", + "name": "Joystick", + "symbol": "JOY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27666/thumb/awKbFbPi_400x400.jpg?1665140248" + }, + { + "chainId": 1, + "address": "0x009178997aff09a67d4caccfeb897fb79d036214", + "name": "1Sol", + "symbol": "1SOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21615/thumb/YyGDie9f_400x400.jpg?1639610633" + }, + { + "chainId": 1, + "address": "0xdfc3829b127761a3218bfcee7fc92e1232c9d116", + "name": "PRivaCY Coin", + "symbol": "PRCY", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14151/thumb/prcy.png?1614666991" + }, + { + "chainId": 1, + "address": "0x59e9261255644c411afdd00bd89162d09d862e38", + "name": "ETHA Lend", + "symbol": "ETHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14141/thumb/etha_logo200x200.png?1614646986" + }, + { + "chainId": 1, + "address": "0xbbff862d906e348e9946bfb2132ecb157da3d4b4", + "name": "Sharder protocol", + "symbol": "SS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2921/thumb/sharder-200px.png?1595305234" + }, + { + "chainId": 1, + "address": "0xed1480d12be41d92f36f5f7bdd88212e381a3677", + "name": "Fiat DAO", + "symbol": "FDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20388/thumb/MLamPGZI_400x400.jpg?1636960965" + }, + { + "chainId": 1, + "address": "0x42f3a4901b2b2c5e2d6bc8dadb8c1d8d5afd2618", + "name": "Durham Inu", + "symbol": "RBI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24016/thumb/wk9djJpG_400x400.jpg?1646032297" + }, + { + "chainId": 1, + "address": "0x97fef38b79640ee95eaef250aaf8733c70007a58", + "name": "MemeNFT Official", + "symbol": "MNFT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26773/thumb/MNFT-ICON-NO-BAKGROUND.png?1660048771" + }, + { + "chainId": 1, + "address": "0x40fd72257597aa14c7231a7b1aaa29fce868f677", + "name": "Sora", + "symbol": "XOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11093/thumb/sora_logo_cg_white.png?1588284194" + }, + { + "chainId": 1, + "address": "0x4057db5bd9f67a566aa10e5587b1a964affc6a16", + "name": "Truefeedback", + "symbol": "TFBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8842/thumb/5rd7a55q_400x400.png?1562902557" + }, + { + "chainId": 1, + "address": "0x12d102f06da35cc0111eb58017fd2cd28537d0e1", + "name": "Vox Finance", + "symbol": "VOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12880/thumb/BSensIa.png?1603261093" + }, + { + "chainId": 1, + "address": "0x4c1e085d8c2d2a8377834d0d7b38f12cc5b86898", + "name": "SilkChain", + "symbol": "SILK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3810/thumb/2.png?1561537249" + }, + { + "chainId": 1, + "address": "0xf4fe95603881d0e07954fd7605e0e9a916e42c44", + "name": "WhenHub", + "symbol": "WHEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4136/thumb/when.png?1547039367" + }, + { + "chainId": 1, + "address": "0x3496b523e5c00a4b4150d6721320cddb234c3079", + "name": "NUM Token", + "symbol": "NUM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20495/thumb/NP_Social_media_profile_pic.png?1664026542" + }, + { + "chainId": 1, + "address": "0x4156d3342d5c385a87d264f90653733592000581", + "name": "SALT", + "symbol": "SALT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/962/thumb/salt.png?1548608746" + }, + { + "chainId": 1, + "address": "0x75ecb52e403c617679fbd3e77a50f9d10a842387", + "name": "CSR", + "symbol": "CSR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25585/thumb/CSR-LOGO-200x200-1.png?1652767956" + }, + { + "chainId": 1, + "address": "0xd3cdc4e75750dc1e59f8342200742b6b29490e70", + "name": "Decurian", + "symbol": "ECU", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/10988/thumb/ECU-LOGO-200x200.png?1586914495" + }, + { + "chainId": 1, + "address": "0x72430a612adc007c50e3b6946dbb1bb0fd3101d1", + "name": "Thingschain", + "symbol": "TIC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5320/thumb/thingschain-logo.png?1547040881" + }, + { + "chainId": 1, + "address": "0x7220e92d418e2eb59d0c25d195fa004bfd3afc42", + "name": "Ad Flex", + "symbol": "ADF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5620/thumb/ad-flex-token.png?1547041485" + }, + { + "chainId": 1, + "address": "0x7d48fbe0a877bb1f511fcf9b57f12420c75841e9", + "name": "DOOR", + "symbol": "DOOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16885/thumb/door256.png?1625548384" + }, + { + "chainId": 1, + "address": "0x1961b3331969ed52770751fc718ef530838b6dee", + "name": "BitDegree", + "symbol": "BDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1653/thumb/bitdegree.jpg?1547035900" + }, + { + "chainId": 1, + "address": "0x5abf88cf3444611d13f6d1b39f3f3ee8575c91a2", + "name": "Super Athletes Token", + "symbol": "SAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27761/thumb/SAT_200.png?1665658758" + }, + { + "chainId": 1, + "address": "0xf9a7e47f6d00a75be08bb23a804f4153c01a1636", + "name": "DeGEM", + "symbol": "DGM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27449/thumb/556.JPG?1664017738" + }, + { + "chainId": 1, + "address": "0x8a6d4c8735371ebaf8874fbd518b56edd66024eb", + "name": "BLOCKS", + "symbol": "BLOCKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19666/thumb/BLOCKS_200x200_logo_%282%29..png?1635738258" + }, + { + "chainId": 1, + "address": "0xf8a4a419c2d7140e49ef952a7e7ae1bd4a8b6b9c", + "name": "Lith OLD ", + "symbol": "LITH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16199/thumb/200x200px_LOGO.png?1657177574" + }, + { + "chainId": 1, + "address": "0xde5ea375ffbdc8b25a80fe13d631e8ba0ab4bb02", + "name": "Gera Coin", + "symbol": "GERA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13686/thumb/GeraCoin_Logo-icon-1000px.png?1610919942" + }, + { + "chainId": 1, + "address": "0xedadeb5faa413e6c8623461849dfd0b7c3790c32", + "name": "Obortech", + "symbol": "OBOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14929/thumb/OBORTECH_200.png?1619070515" + }, + { + "chainId": 1, + "address": "0xcb4e8cafeda995da5cedfda5205bd5664a12b848", + "name": "Shabu Shabu", + "symbol": "KOBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13577/thumb/shabu_shabu_logo.jpg?1609901993" + }, + { + "chainId": 1, + "address": "0x2365a4890ed8965e564b7e2d27c38ba67fec4c6f", + "name": "Aave AMM UniWBTCUSDC", + "symbol": "AAMMUNIWBTCUSDC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17255/thumb/aAmmUniWBTCUSDC.png?1626956709" + }, + { + "chainId": 1, + "address": "0xf3dcbc6d72a4e1892f7917b7c43b74131df8480e", + "name": "Big Data Protocol", + "symbol": "BDP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14222/thumb/logo_BDP_200.png?1615088501" + }, + { + "chainId": 1, + "address": "0x4dd28568d05f09b02220b09c2cb307bfd837cb95", + "name": "FingerprintsDAO", + "symbol": "PRINTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18143/thumb/prints.png?1634698868" + }, + { + "chainId": 1, + "address": "0x16c52ceece2ed57dad87319d91b5e3637d50afa4", + "name": "Total Crypto Market Cap", + "symbol": "TCAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14703/thumb/tcap.png?1617860242" + }, + { + "chainId": 1, + "address": "0xaad54c9f27b876d2538455dda69207279ff673a5", + "name": "Davinci Coin", + "symbol": "DAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5494/thumb/dac.png?1644149184" + }, + { + "chainId": 1, + "address": "0x946112efab61c3636cbd52de2e1392d7a75a6f01", + "name": "Hydro", + "symbol": "HYDRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3678/thumb/New_Hydro_logo.png?1625473878" + }, + { + "chainId": 1, + "address": "0x8355dbe8b0e275abad27eb843f3eaf3fc855e525", + "name": "Wolf Game Wool", + "symbol": "WOOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20760/thumb/KM3RwIVx_400x400.jpg?1637650093" + }, + { + "chainId": 1, + "address": "0xae353daeed8dcc7a9a12027f7e070c0a50b7b6a4", + "name": "InnovaMinex", + "symbol": "MINX", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/7116/thumb/innovaminex.jpg?1547043613" + }, + { + "chainId": 1, + "address": "0xf91ac30e9b517f6d57e99446ee44894e6c22c032", + "name": "LOL", + "symbol": "LOL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20354/thumb/lollogo.png?1648442855" + }, + { + "chainId": 1, + "address": "0xbfce0e06dedcbea3e170ba4df2a6793334cac5ef", + "name": "Naruto Inu", + "symbol": "NARUTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20509/thumb/6HHkduP.jpeg?1637153210" + }, + { + "chainId": 1, + "address": "0x94804dc4948184ffd7355f62ccbb221c9765886f", + "name": "Rage Fan", + "symbol": "RAGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14585/thumb/Copy_of_RAGE_FAN_LOGO_ONLY.png?1627476357" + }, + { + "chainId": 1, + "address": "0x5f64ab1544d28732f0a24f4713c2c8ec0da089f0", + "name": "Domani Protocol", + "symbol": "DEXTF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12634/thumb/0qgT0aMu_400x400.jpg?1639175406" + }, + { + "chainId": 1, + "address": "0xdc0327d50e6c73db2f8117760592c8bbf1cdcf38", + "name": "Stronger", + "symbol": "STRNGR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24922/thumb/200x200_logo.png?1650609989" + }, + { + "chainId": 1, + "address": "0xe23faefcdaae646527eb86b1c746a25ae4a36f75", + "name": "WGMI", + "symbol": "WGMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20330/thumb/new_WGMI_logo-01.png?1650534006" + }, + { + "chainId": 1, + "address": "0x41875c2332b0877cdfaa699b641402b7d4642c32", + "name": "FUTURAX", + "symbol": "FTXT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5796/thumb/futurax.png?1547484031" + }, + { + "chainId": 1, + "address": "0x9d409a0a012cfba9b15f6d4b36ac57a46966ab9a", + "name": "Yearn Compounding veCRV yVault", + "symbol": "YVBOOST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15152/thumb/yvBOOST.png?1619978216" + }, + { + "chainId": 1, + "address": "0x8ffe40a3d0f80c0ce6b203d5cdc1a6a86d9acaea", + "name": "IG Gold", + "symbol": "IGG", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/7697/thumb/N7aEdYrY_400x400.png?1561587437" + }, + { + "chainId": 1, + "address": "0xde4ee8057785a7e8e800db58f9784845a5c2cbd6", + "name": "DeXe", + "symbol": "DEXE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12713/thumb/logo_%2814%29.png?1601952779" + }, + { + "chainId": 1, + "address": "0xbc4171f45ef0ef66e76f979df021a34b46dcc81d", + "name": "Dora Factory", + "symbol": "DORA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14478/thumb/dora_logo.jpg?1616410086" + }, + { + "chainId": 1, + "address": "0xa8e7ad77c60ee6f30bac54e2e7c0617bd7b5a03e", + "name": "zLOT", + "symbol": "ZLOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13073/thumb/z-LOT-logo-transparent.png?1604900416" + }, + { + "chainId": 1, + "address": "0xcadc0acd4b445166f12d2c07eac6e2544fbe2eef", + "name": "CAD Coin", + "symbol": "CADC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14149/thumb/cadc_2.png?1614666625" + }, + { + "chainId": 1, + "address": "0x70efdc485a10210b056ef8e0a32993bc6529995e", + "name": "Blaze Network", + "symbol": "BLZN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12248/thumb/A8JOuPSJ_400x400.jpg?1598511402" + }, + { + "chainId": 1, + "address": "0x9ea3b5b4ec044b70375236a281986106457b20ef", + "name": "Delta Financial", + "symbol": "DELTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14564/thumb/Delta_logo.png?1619067341" + }, + { + "chainId": 1, + "address": "0x89020f0d5c5af4f3407eb5fe185416c457b0e93e", + "name": "Edenchain", + "symbol": "EDN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3292/thumb/Eden.png?1574126935" + }, + { + "chainId": 1, + "address": "0xc1f976b91217e240885536af8b63bc8b5269a9be", + "name": "Public Index Network", + "symbol": "PIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/241/thumb/pin.jpeg?1623054253" + }, + { + "chainId": 1, + "address": "0xfc4913214444af5c715cc9f7b52655e788a569ed", + "name": "Icosa", + "symbol": "ICSA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27708/thumb/icsa.e2b79cbc.png?1665314034" + }, + { + "chainId": 1, + "address": "0x9ab165d795019b6d8b3e971dda91071421305e5a", + "name": "Aurora Chain", + "symbol": "AOA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4755/thumb/aurora-logo.png?1547040076" + }, + { + "chainId": 1, + "address": "0xc08512927d12348f6620a698105e1baac6ecd911", + "name": "GYEN", + "symbol": "GYEN", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14191/thumb/icon_gyen_200_200.png?1614843343" + }, + { + "chainId": 1, + "address": "0x3819f64f282bf135d62168c1e513280daf905e06", + "name": "Hedron", + "symbol": "HDRN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24208/thumb/hdrn.png?1647079428" + }, + { + "chainId": 1, + "address": "0x622dffcc4e83c64ba959530a5a5580687a57581b", + "name": "Cube Intelligence", + "symbol": "AUTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3503/thumb/2559.png?1547038267" + }, + { + "chainId": 1, + "address": "0x4da08a1bff50be96bded5c7019227164b49c2bfc", + "name": "Mononoke Inu", + "symbol": "MONONOKE-INU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18769/thumb/z9YDK0f.png?1633357322" + }, + { + "chainId": 1, + "address": "0x41a03e41ef555392c9f0ad60f4f61e263078bf10", + "name": "Upper Dollar", + "symbol": "USDU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12332/thumb/usdu.png?1642929548" + }, + { + "chainId": 1, + "address": "0x069f967be0ca21c7d793d8c343f71e597d9a49b3", + "name": "HZM Coin", + "symbol": "HZM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/18032/thumb/hzm.PNG?1630296878" + }, + { + "chainId": 1, + "address": "0x175ab41e2cedf3919b2e4426c19851223cf51046", + "name": "BaconSwap", + "symbol": "BACON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12336/thumb/bacon_swap_logo.png?1599133231" + }, + { + "chainId": 1, + "address": "0x88ff74676591faa8317494df556bf45757c567a1", + "name": "Tsukuyomi no Mikoto", + "symbol": "MIKOTO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27189/thumb/output-onlinepngtools_%285%29.png?1662440321" + }, + { + "chainId": 1, + "address": "0xb98d4c97425d9908e66e53a6fdf673acca0be986", + "name": "Arcblock", + "symbol": "ABT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2341/thumb/arcblock.png?1547036543" + }, + { + "chainId": 1, + "address": "0x475db18d764df7fadfbd3e73fccbbc1e14342ab3", + "name": "ApolloFi", + "symbol": "APO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26451/thumb/apo.png?1660311541" + }, + { + "chainId": 1, + "address": "0x4b0181102a0112a2ef11abee5563bb4a3176c9d7", + "name": "cSUSHI", + "symbol": "CSUSHI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17529/thumb/csushi.PNG?1628122792" + }, + { + "chainId": 1, + "address": "0xc5b3d3231001a776123194cf1290068e8b0c783b", + "name": "LIT", + "symbol": "LIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21344/thumb/LitLogo_CG.png?1639990605" + }, + { + "chainId": 1, + "address": "0x4cd988afbad37289baaf53c13e98e2bd46aaea8c", + "name": "Key", + "symbol": "KEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4182/thumb/bihu-key-token.png?1547039459" + }, + { + "chainId": 1, + "address": "0xce13abce0db5a8224616ef24d3979d466f19cf90", + "name": "Rebit", + "symbol": "KEYT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9891/thumb/rebit.PNG?1573119183" + }, + { + "chainId": 1, + "address": "0xdf290b162a7d3e0a328cf198308d421954f08b94", + "name": "Beyond Protocol", + "symbol": "BP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4732/thumb/b-logo-200x200.png?1633423345" + }, + { + "chainId": 1, + "address": "0x27ed129c298c5df130364083f491e2920e5a2f29", + "name": "Upper Pound", + "symbol": "GBPU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12357/thumb/gbpu.png?1642929642" + }, + { + "chainId": 1, + "address": "0x37e83a94c6b1bdb816b59ac71dd02cf154d8111f", + "name": "PhotoChromic", + "symbol": "PHCR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23640/thumb/L7vabJibqXHHmGtsIfIEQRaR3SjaE94QSaKWGlqYU7fpuz--nKsWG4BlB6Ddhn5-tGPWo-MDhfZPVAYG7ZM2vpWrVZlSx1Euw78tZcNey6FvpKX6a8w26qBWYeV7wxFzvW7VKieijrMXQ0BkISpt8d6jrCMBvx2ZFKVxF1x31_2X7WhRyqAgIG3epFPNz7v0j0ECaS7HmE0_sTHM4RS3CW1d0a.jpg?1644908390" + }, + { + "chainId": 1, + "address": "0xf4d861575ecc9493420a3f5a14f85b13f0b50eb3", + "name": "Fractal", + "symbol": "FCL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14096/thumb/fractal_logo.png?1614264502" + }, + { + "chainId": 1, + "address": "0x625ae63000f46200499120b906716420bd059240", + "name": "Aave SUSD v1", + "symbol": "ASUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11723/thumb/aSUSD.png?1593082612" + }, + { + "chainId": 1, + "address": "0x07f9702ce093db82dfdc92c2c6e578d6ea8d5e22", + "name": "Oobit", + "symbol": "OBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19855/thumb/obt.png?1636062272" + }, + { + "chainId": 1, + "address": "0x08ba718f288c3b12b01146816bef9fa03cc635bc", + "name": "Centaurify", + "symbol": "CENT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20512/thumb/GTU5RBD0.png?1645205770" + }, + { + "chainId": 1, + "address": "0xb6ff96b8a8d214544ca0dbc9b33f7ad6503efd32", + "name": "Sync Network", + "symbol": "SYNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13231/thumb/sync_network.png?1629777103" + }, + { + "chainId": 1, + "address": "0x80fb784b7ed66730e8b1dbd9820afd29931aab03", + "name": "Aave OLD ", + "symbol": "LEND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1365/thumb/ethlend.png?1547394586" + }, + { + "chainId": 1, + "address": "0x327673ae6b33bd3d90f0096870059994f30dc8af", + "name": "Lympo Market", + "symbol": "LMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15155/thumb/coin_%282%29.png?1619995483" + }, + { + "chainId": 1, + "address": "0xa64bd6c70cb9051f6a9ba1f163fdc07e0dfb5f84", + "name": "Aave LINK v1", + "symbol": "ALINK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11729/thumb/aLINK.png?1593084323" + }, + { + "chainId": 1, + "address": "0x0b63128c40737b13647552e0c926bcfeccc35f93", + "name": "wLITI", + "symbol": "WLITI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16810/thumb/liticapital_real.png?1625151260" + }, + { + "chainId": 1, + "address": "0x83031984b45553070a088273f341bff7fb4f2f46", + "name": "hiBAYC", + "symbol": "HIBAYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26623/thumb/hibayc.png?1659150840" + }, + { + "chainId": 1, + "address": "0x5dbcf33d8c2e976c6b560249878e6f1491bca25c", + "name": "yUSD", + "symbol": "YVAULT-LP-YCURVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12210/thumb/yUSD.png?1600166557" + }, + { + "chainId": 1, + "address": "0xfde57fee4bcca80485714bd640d6e5afe8ac4d66", + "name": "StellarInu", + "symbol": "STELLARINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20615/thumb/Screenshot-2021-11-18-at-20-09-23.png?1637307533" + }, + { + "chainId": 1, + "address": "0x1c7e83f8c581a967940dbfa7984744646ae46b29", + "name": "The RandomDAO", + "symbol": "RND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24256/thumb/rnd.png?1647160021" + }, + { + "chainId": 1, + "address": "0x04dc37b220a055c5f93680815f670babcd912c2c", + "name": "Eiichiro Oda Inu", + "symbol": "ODA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19546/thumb/oda.png?1635390942" + }, + { + "chainId": 1, + "address": "0x2d77f5b3efa51821ad6483adaf38ea4cb1824cc5", + "name": "Genesis Mana", + "symbol": "MANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19031/thumb/genesis-icon.png?1634196000" + }, + { + "chainId": 1, + "address": "0x461b71cff4d4334bba09489ace4b5dc1a1813445", + "name": "Hoard", + "symbol": "HRD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27300/thumb/hoard.png?1663212320" + }, + { + "chainId": 1, + "address": "0x2d80f5f5328fdcb6eceb7cacf5dd8aedaec94e20", + "name": "AGA", + "symbol": "AGA", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/12180/thumb/aga-logo.png?1597937396" + }, + { + "chainId": 1, + "address": "0x5d3a536e4d6dbd6114cc1ead35777bab948e3643", + "name": "cDAI", + "symbol": "CDAI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9281/thumb/cDAI.png?1576467585" + }, + { + "chainId": 1, + "address": "0x4086e77c5e993fdb90a406285d00111a974f877a", + "name": "Blockchain Brawlers", + "symbol": "BRWL", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/24701/thumb/fuDdvI8Y_400x400.png?1648642627" + }, + { + "chainId": 1, + "address": "0xa23c1194d421f252b4e6d5edcc3205f7650a4ebe", + "name": "LaunchBlock", + "symbol": "LBP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24181/thumb/S6z_-9GB_400x400.jpg?1646786017" + }, + { + "chainId": 1, + "address": "0xb05097849bca421a3f51b249ba6cca4af4b97cb9", + "name": "Float Protocol Float", + "symbol": "FLOAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15502/thumb/FLOAT_LOGO-reduced_01.png?1621081152" + }, + { + "chainId": 1, + "address": "0x5b0f6ad5875da96ac224ba797c6f362f4c3a2b3b", + "name": "Nerdy Inu", + "symbol": "NERDY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19517/thumb/nerdy.jpeg?1635322382" + }, + { + "chainId": 1, + "address": "0xc9859fccc876e6b4b3c749c5d29ea04f48acb74f", + "name": "Ino Coin", + "symbol": "INO", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/4096/thumb/inologo.jpg?1547039275" + }, + { + "chainId": 1, + "address": "0x35872fea6a4843facbcdbce99e3b69596a3680b8", + "name": "1337", + "symbol": "1337", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/13348/thumb/logo.png?1607791847" + }, + { + "chainId": 1, + "address": "0x2b1fe2cea92436e8c34b7c215af66aaa2932a8b2", + "name": "Sakhalin Husky", + "symbol": "SAHU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15750/thumb/HUSKY_H-1024x683-1.png?1621785464" + }, + { + "chainId": 1, + "address": "0x668c50b1c7f46effbe3f242687071d7908aab00a", + "name": "CoShi Inu", + "symbol": "COSHI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15219/thumb/200.jpg?1620119215" + }, + { + "chainId": 1, + "address": "0x15dd37a83564559927bbdcdbfcf85f60a2c6a419", + "name": "StonkLeague", + "symbol": "AEGIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26294/thumb/iShot_2022-07-07_10.44.16.png?1657161870" + }, + { + "chainId": 1, + "address": "0x9b06d48e0529ecf05905ff52dd426ebec0ea3011", + "name": "XSwap", + "symbol": "XSP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12541/thumb/256x256_%282%29.png?1600645409" + }, + { + "chainId": 1, + "address": "0x03ab458634910aad20ef5f1c8ee96f1d6ac54919", + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14004/thumb/RAI-logo-coin.png?1613592334" + }, + { + "chainId": 1, + "address": "0x4a1d542b52a95ad01ddc70c2e7df0c7bbaadc56f", + "name": "Niftify", + "symbol": "NIFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20558/thumb/AWPDLxLK_400x400.jpg?1637209747" + }, + { + "chainId": 1, + "address": "0xbcf91e60a6719eb3e9308addf1f7c6185c2af889", + "name": "ExenPay", + "symbol": "EXENP", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/18975/thumb/LlydYS1w_400x400.png?1634094918" + }, + { + "chainId": 1, + "address": "0x0557df767419296474c3f551bb0a0ed4c2dd3380", + "name": "Universal Gold", + "symbol": "UPXAU", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/13534/thumb/UPXAU-1.png?1609540908" + }, + { + "chainId": 1, + "address": "0xe6cc10ef4de1ccfb821c99c04abfe1859d8eab8f", + "name": "Exen", + "symbol": "EXEN", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/19036/thumb/Exen_Logo_f1f7d970fd.png?1634201249" + }, + { + "chainId": 1, + "address": "0x2c974b2d0ba1716e644c1fc59982a89ddd2ff724", + "name": "Viberate", + "symbol": "VIB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/983/thumb/Viberate.png?1547034873" + }, + { + "chainId": 1, + "address": "0x9a0aba393aac4dfbff4333b06c407458002c6183", + "name": "ACoconut", + "symbol": "AC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12779/thumb/ac_logo.png?1602500084" + }, + { + "chainId": 1, + "address": "0xd5e7d22362bcc9881d06512d3189eae79dd98d70", + "name": "Miyazaki Inu", + "symbol": "MIYAZAKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19889/thumb/DzuUGOg.png?1636091545" + }, + { + "chainId": 1, + "address": "0xc91b523a59acc63a64f61fc7bbfb4bfc82dd25f2", + "name": "Multiverse", + "symbol": "AI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16329/thumb/multiverse_logo_full_color_rgb_200px_72ppi.png?1652011384" + }, + { + "chainId": 1, + "address": "0x0fd10b9899882a6f2fcb5c371e17e70fdee00c38", + "name": "Pundi X", + "symbol": "PUNDIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14571/thumb/vDyefsXq_400x400.jpg?1617085003" + }, + { + "chainId": 1, + "address": "0xd83c569268930fadad4cde6d0cb64450fef32b65", + "name": "Invictus Capital", + "symbol": "ICAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18334/thumb/ICAP-logo-icon.png?1631584746" + }, + { + "chainId": 1, + "address": "0x823556202e86763853b40e9cde725f412e294689", + "name": "Altered State Machine", + "symbol": "ASTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24893/thumb/ASTO.png?1649303806" + }, + { + "chainId": 1, + "address": "0xa0bed124a09ac2bd941b10349d8d224fe3c955eb", + "name": "DePay", + "symbol": "DEPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13183/thumb/DEPAY.png?1650615816" + }, + { + "chainId": 1, + "address": "0x4ee438be38f8682abb089f2bfea48851c5e71eaf", + "name": "Cryptonovae", + "symbol": "YAE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14693/thumb/yae.png?1640337904" + }, + { + "chainId": 1, + "address": "0xfb9553afa2b5c19c5f8e5b8ee175fc01abd1555f", + "name": "Hybrid Bank Cash", + "symbol": "HBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12489/thumb/hb_logo.png?1600208518" + }, + { + "chainId": 1, + "address": "0x3fa729b4548becbad4eab6ef18413470e6d5324c", + "name": "Mover", + "symbol": "MOVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13719/thumb/o0KIvs7T_400x400.jpg?1617672818" + }, + { + "chainId": 1, + "address": "0xa8262eb913fccea4c3f77fc95b8b4043b384cfbb", + "name": "Krypton Galaxy Coin", + "symbol": "KGC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9152/thumb/krypton.PNG?1564733517" + }, + { + "chainId": 1, + "address": "0x5faa989af96af85384b8a938c2ede4a7378d9875", + "name": "Galxe", + "symbol": "GAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24530/thumb/galaxy.jpg?1662517258" + }, + { + "chainId": 1, + "address": "0x8254c1c134436f74047f79eaaea97e3324ef78b5", + "name": "Ichigo Inu", + "symbol": "ICHIGO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19243/thumb/ichigoinu.png?1634779236" + }, + { + "chainId": 1, + "address": "0x996229d0c6a485c7f4b52e092eaa907cb2def5c6", + "name": "BuckHath Coin", + "symbol": "BHIG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7821/thumb/logstex.PNG?1585121237" + }, + { + "chainId": 1, + "address": "0x0ff6ffcfda92c53f615a4a75d982f399c989366b", + "name": "UniLayer", + "symbol": "LAYER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12164/thumb/Unilayer.jpg?1597779313" + }, + { + "chainId": 1, + "address": "0x3597bfd533a99c9aa083587b074434e61eb0a258", + "name": "Dent", + "symbol": "DENT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1152/thumb/gLCEA2G.png?1604543239" + }, + { + "chainId": 1, + "address": "0x8cc0f052fff7ead7f2edcccac895502e884a8a71", + "name": "ARTH", + "symbol": "ARTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16876/thumb/ARTH_Token.png?1625651538" + }, + { + "chainId": 1, + "address": "0x0d86eb9f43c57f6ff3bc9e23d8f9d82503f0e84b", + "name": "Maximus DAO", + "symbol": "MAXI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/25126/thumb/maxilogo200.png?1650372648" + }, + { + "chainId": 1, + "address": "0x43a96962254855f16b925556f9e97be436a43448", + "name": "Hord", + "symbol": "HORD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14972/thumb/Avatar_white.png?1619513849" + }, + { + "chainId": 1, + "address": "0xa6a840e50bcaa50da017b91a0d86b8b2d41156ee", + "name": "EchoLink", + "symbol": "EKO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2437/thumb/echolink.png?1547224598" + }, + { + "chainId": 1, + "address": "0x8eb1779a32678452eb273a22d413207299904d90", + "name": "Pochi Inu", + "symbol": "POCHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23816/thumb/logo-gold.png?1645513711" + }, + { + "chainId": 1, + "address": "0xa5b46ff9a887180c8fb2d97146398ddfc5fef1cd", + "name": "SuperSkyNet", + "symbol": "SSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8944/thumb/p3dTwXMK_400x400.jpg?1563153164" + }, + { + "chainId": 1, + "address": "0x36ac219f90f5a6a3c77f2a7b660e3cc701f68e25", + "name": "Coinmetro", + "symbol": "XCM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3125/thumb/XCM_Token_Logo_.png?1646280053" + }, + { + "chainId": 1, + "address": "0x355a824bea1adc22733978a3748271e1bbb34130", + "name": "Metanept", + "symbol": "NEPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26798/thumb/OH1UiJ16_400x400.jpeg?1660202251" + }, + { + "chainId": 1, + "address": "0x69a95185ee2a045cdc4bcd1b1df10710395e4e23", + "name": "Poolz Finance", + "symbol": "POOLZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13679/thumb/poolz_logo.png?1610806091" + }, + { + "chainId": 1, + "address": "0x5f0bc16d50f72d10b719dbf6845de2e599eb5624", + "name": "Vent Finance", + "symbol": "VENT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17925/thumb/Artboard_29.png?1629804982" + }, + { + "chainId": 1, + "address": "0x2e95cea14dd384429eb3c4331b776c4cfbb6fcd9", + "name": "Throne", + "symbol": "THN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16965/thumb/aXhD3i_g_400x400.jpg?1625804145" + }, + { + "chainId": 1, + "address": "0x98d8d146e644171cd47ff8588987b7bdeef72a87", + "name": "Blockchain Exchange Alliance", + "symbol": "BXA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7842/thumb/images.png?1551144999" + }, + { + "chainId": 1, + "address": "0xdb0acc14396d108b3c5574483acb817855c9dc8d", + "name": "Overline Emblem", + "symbol": "EMB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3335/thumb/czcuIce.png?1621842831" + }, + { + "chainId": 1, + "address": "0xb13de094cc5cee6c4cc0a3737bf0290166d9ca5d", + "name": "GoWithMi", + "symbol": "GMAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7162/thumb/qXNbxVny_400x400.png?1564433322" + }, + { + "chainId": 1, + "address": "0xd82df0abd3f51425eb15ef7580fda55727875f14", + "name": "DAV Network", + "symbol": "DAV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2842/thumb/DAV-Network-logo.jpg?1547037011" + }, + { + "chainId": 1, + "address": "0x8013266cb5c9dd48be3ad7d1ce832874d64b3ce1", + "name": "Boop", + "symbol": "BOOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27918/thumb/boop.png?1666351418" + }, + { + "chainId": 1, + "address": "0xcccf837f40d334f8602f031e64b52ad4cd2b6601", + "name": "Unicly Fewocious Collection", + "symbol": "UFEWO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16387/thumb/uFEWO.png?1623894677" + }, + { + "chainId": 1, + "address": "0x5e6ffe7b174a50c81ff3f3c54c04fd3c11e20830", + "name": "DragonVein", + "symbol": "DVC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8263/thumb/LrDC1OmYiqq05_-E3PFLO6oJou6HOvVMFpjEqbYdcvaIPgQp7mF52lpj_rCmQW1FhAoBg5E2Z9o16L3Z7n8SQrMIp1YZNEGHRzc3P0P3jOZnyKvHNuTXQx9q13_kxXG1oMzaN3HfWdUnTMAfKRwghCa7BX67W9pSV-AJkcQ4-5Qy_qlAN28UCUgVnM0k6ZXlNWZo7Vi00CD7657qw.jpg?1557125797" + }, + { + "chainId": 1, + "address": "0x31d939dc09a6bb55642fcbf9d56166ebc0bdec9a", + "name": "Peach Finance", + "symbol": "PEECH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15376/thumb/PEECH-token-logo-200.png?1620692908" + }, + { + "chainId": 1, + "address": "0xbe6c8f2810ef39420d2dc2901b8414c8c45fee6d", + "name": "Micromines", + "symbol": "MICRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7000/thumb/micromines.png?1548085033" + }, + { + "chainId": 1, + "address": "0x108a850856db3f85d0269a2693d896b394c80325", + "name": "THORWallet DEX", + "symbol": "TGT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21843/thumb/tgt_logo.png?1641568708" + }, + { + "chainId": 1, + "address": "0x5e3845a1d78db544613edbe43dc1ea497266d3b8", + "name": "LNX Protocol", + "symbol": "LNX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8776/thumb/Linix.png?1561103529" + }, + { + "chainId": 1, + "address": "0x426ca1ea2406c07d75db9585f22781c096e3d0e0", + "name": "Minereum", + "symbol": "MNE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/702/thumb/mne.png?1587615060" + }, + { + "chainId": 1, + "address": "0x53fd2342b43ecd24aef1535bc3797f509616ce8c", + "name": "Anarchy", + "symbol": "ANARCHY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26583/thumb/90EWu8yp_400x400.jpg?1658891996" + }, + { + "chainId": 1, + "address": "0x63b8b7d4a3efd0735c4bffbd95b332a55e4eb851", + "name": "DigiCol", + "symbol": "DGCL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13519/thumb/DigiCol_Logo-01.png?1609372199" + }, + { + "chainId": 1, + "address": "0x42a501903afaa1086b5975773375c80e363f4063", + "name": "Cryptyk", + "symbol": "CTK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2729/thumb/th.jpg?1667122361" + }, + { + "chainId": 1, + "address": "0x1ab052db3216835182926a6d516762b0f1634661", + "name": "The Path Of Light", + "symbol": "YORI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27734/thumb/yori_icon200.png?1665563891" + }, + { + "chainId": 1, + "address": "0x356a5160f2b34bc8d88fb084745465ebbbed0174", + "name": "INVI", + "symbol": "INVI", + "decimals": 13, + "logoURI": "https://assets.coingecko.com/coins/images/17363/thumb/INVI-Ticker.png?1627374966" + }, + { + "chainId": 1, + "address": "0xa774ffb4af6b0a91331c084e1aebae6ad535e6f3", + "name": "flexUSD", + "symbol": "FLEXUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13323/thumb/flexUSD_2x.png?1607480702" + }, + { + "chainId": 1, + "address": "0x090fc4d5436d98e13473c4d6109de6a18bcfb0d4", + "name": "SkyToken", + "symbol": "SKY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28037/thumb/sky.png?1667129732" + }, + { + "chainId": 1, + "address": "0xea5edef1287afdf9eb8a46f9773abfc10820c61c", + "name": "EASE", + "symbol": "EASE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27228/thumb/ease_symbol-200x200.png?1664098304" + }, + { + "chainId": 1, + "address": "0x0335a7610d817aeca1bebbefbd392ecc2ed587b8", + "name": "Nitro League", + "symbol": "NITRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21668/thumb/_X6vYBDM_400x400.jpg?1639705848" + }, + { + "chainId": 1, + "address": "0xba6b0dbb2ba8daa8f5d6817946393aef8d3a4487", + "name": "Hillstone Finance", + "symbol": "HSF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22335/thumb/logo_-_2022-01-07T094430.368.png?1641519883" + }, + { + "chainId": 1, + "address": "0x3136ef851592acf49ca4c825131e364170fa32b3", + "name": "CoinFi", + "symbol": "COFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1709/thumb/coinfi.png?1547035969" + }, + { + "chainId": 1, + "address": "0x5892f5d533e81f9df91cd4a61886d555bae6b166", + "name": "ETHDOX", + "symbol": "ETHDOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25352/thumb/ethdox.png?1651311929" + }, + { + "chainId": 1, + "address": "0x1c5db575e2ff833e46a2e9864c22f4b22e0b37c2", + "name": "renZEC", + "symbol": "RENZEC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11564/thumb/Zcash.jpg?1628072865" + }, + { + "chainId": 1, + "address": "0x120a3879da835a5af037bb2d1456bebd6b54d4ba", + "name": "Revest Finance", + "symbol": "RVST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18622/thumb/Qma94n6waADECpde1ukBBS8iNiECcdVcxjfgubnWPE9ZT7.png?1632701737" + }, + { + "chainId": 1, + "address": "0x3918c42f14f2eb1168365f911f63e540e5a306b5", + "name": "Neural Protocol", + "symbol": "NRP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6313/thumb/neural-protocol.png?1548085897" + }, + { + "chainId": 1, + "address": "0x6fc2f1044a3b9bb3e43a43ec8f840843ed753061", + "name": "Robo", + "symbol": "ROBO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14611/thumb/rlogo200.jpg?1617247446" + }, + { + "chainId": 1, + "address": "0xb3ed706b564bba9cab64042f4e1b391be7bebce5", + "name": "Augmented Finance", + "symbol": "AGF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20077/thumb/200x200-agf.png?1636452467" + }, + { + "chainId": 1, + "address": "0x044727e50ff30db57fad06ff4f5846eab5ea52a2", + "name": "Kitty Inu", + "symbol": "KITTY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19385/thumb/2Hy412Bd_400x400.png?1635146893" + }, + { + "chainId": 1, + "address": "0x7af89c8a06719271a96e62e290ea9ed192e73fc1", + "name": "Gold Mining Members", + "symbol": "GMM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11660/thumb/gmm_logo_token.png?1592432359" + }, + { + "chainId": 1, + "address": "0x2223bf1d7c19ef7c06dab88938ec7b85952ccd89", + "name": "Kryxivia Game", + "symbol": "KXA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21225/thumb/kxa.png?1638742914" + }, + { + "chainId": 1, + "address": "0xded2583b3fbf4b381851f5031188a5a3562ab2cd", + "name": "IAB", + "symbol": "IAB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6549/thumb/iabchain.png?1547042763" + }, + { + "chainId": 1, + "address": "0x4a64515e5e1d1073e83f30cb97bed20400b66e10", + "name": "Wrapped Zcash", + "symbol": "WZEC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13239/thumb/WZEC.png?1623827266" + }, + { + "chainId": 1, + "address": "0x0407b4c4eaed35ce3c5b852bdfa1640b09eeedf4", + "name": "BlockWRK", + "symbol": "WRK", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/17282/thumb/blkwr.png?1635470283" + }, + { + "chainId": 1, + "address": "0xfd6c31bb6f05fc8db64f4b740ab758605c271fd8", + "name": "Contracoin", + "symbol": "CTCN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10801/thumb/Contracoin-symbol.png?1583881685" + }, + { + "chainId": 1, + "address": "0x20a68f9e34076b2dc15ce726d7eebb83b694702d", + "name": "DefiVille Island", + "symbol": "ISLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14471/thumb/256.png?1616384288" + }, + { + "chainId": 1, + "address": "0x9aeb50f542050172359a0e1a25a9933bc8c01259", + "name": "OIN Finance", + "symbol": "OIN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12339/thumb/OIN_FInance_-_cLogo-01.png?1631796334" + }, + { + "chainId": 1, + "address": "0xc775c0c30840cb9f51e21061b054ebf1a00acc29", + "name": "Pastel", + "symbol": "PSL", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/14293/thumb/A4qGwEij_400x400.jpg?1615290394" + }, + { + "chainId": 1, + "address": "0x49d72e3973900a195a155a46441f0c08179fdb64", + "name": "Cream ETH 2", + "symbol": "CRETH2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13568/thumb/creth2.png?1609837099" + }, + { + "chainId": 1, + "address": "0xe7094edf87a4e307590d011fb2db50219131d9ed", + "name": "World Cup Willie", + "symbol": "WILLIE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27948/thumb/YiFf3bWN_400x400.jpg?1666611450" + }, + { + "chainId": 1, + "address": "0x910dfc18d6ea3d6a7124a6f8b5458f281060fa4c", + "name": "X8X", + "symbol": "X8X", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1912/thumb/x8x.png?1547036213" + }, + { + "chainId": 1, + "address": "0x2991341d28eaea277785d20e1d878d478c7ba4c7", + "name": "FM Gallery", + "symbol": "FMG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14527/thumb/FR44th_I_400x400.jpg?1616742157" + }, + { + "chainId": 1, + "address": "0x43d4a3cd90ddd2f8f4f693170c9c8098163502ad", + "name": "Prime", + "symbol": "D2D", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21609/thumb/RJD82RrV_400x400.jpg?1639559164" + }, + { + "chainId": 1, + "address": "0xb892249939adbf6d7851864ca9a5c7d2d537af97", + "name": "Gambler Shiba", + "symbol": "GSHIBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17130/thumb/RHzOHCyb_400x400.jpg?1626410775" + }, + { + "chainId": 1, + "address": "0x16f78145ad0b9af58747e9a97ebd99175378bd3d", + "name": "GroupDao", + "symbol": "GDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22204/thumb/logo.png?1641194137" + }, + { + "chainId": 1, + "address": "0x249e38ea4102d0cf8264d3701f1a0e39c4f2dc3b", + "name": "UFO Gaming", + "symbol": "UFO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16801/thumb/ufo.png?1644048038" + }, + { + "chainId": 1, + "address": "0x8a6f3bf52a26a21531514e23016eeae8ba7e7018", + "name": "Multiplier", + "symbol": "MXX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12119/thumb/MXXlogo.png?1597306184" + }, + { + "chainId": 1, + "address": "0x00b7db6b4431e345eee5cc23d21e8dbc1d5cada3", + "name": "CyberTronchain", + "symbol": "CTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13391/thumb/zNdoAnW.png?1608095358" + }, + { + "chainId": 1, + "address": "0xeeaa40b28a2d1b0b08f6f97bb1dd4b75316c6107", + "name": "CVI", + "symbol": "GOVI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13875/thumb/GOVI.png?1612451531" + }, + { + "chainId": 1, + "address": "0x0f71b8de197a1c84d31de0f1fa7926c365f052b3", + "name": "Arcona", + "symbol": "ARCONA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4312/thumb/icon_ARCONA_%281%29.png?1651823900" + }, + { + "chainId": 1, + "address": "0xe6716b29900a5776df4bae51338f78f102333a79", + "name": "BunnyRocket", + "symbol": "BUNNYROCKET", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19140/thumb/OvhRGGx.png?1634527738" + }, + { + "chainId": 1, + "address": "0x135783b60cf5d71daff7a377f9eb7db8d2deab9e", + "name": "Ctrl X", + "symbol": "CUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28068/thumb/logo.png?1667567710" + }, + { + "chainId": 1, + "address": "0x6f80310ca7f2c654691d1383149fa1a57d8ab1f8", + "name": "Silo Finance", + "symbol": "SILO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21454/thumb/y0iYKZOv_400x400.png?1639269432" + }, + { + "chainId": 1, + "address": "0x9af4f26941677c706cfecf6d3379ff01bb85d5ab", + "name": "DomRaider", + "symbol": "DRT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1030/thumb/domraider.png?1547223934" + }, + { + "chainId": 1, + "address": "0xc8d3dcb63c38607cb0c9d3f55e8ecce628a01c36", + "name": "Matrix Labs", + "symbol": "MATRIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18297/thumb/matrixlabs.png?1643277367" + }, + { + "chainId": 1, + "address": "0xaaaf91d9b90df800df4f55c205fd6989c977e73a", + "name": "Monolith", + "symbol": "TKN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/675/thumb/Monolith.png?1566296607" + }, + { + "chainId": 1, + "address": "0x70401dfd142a16dc7031c56e862fc88cb9537ce0", + "name": "Bird Money", + "symbol": "BIRD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13260/thumb/favicon-180x180.png?1611546646" + }, + { + "chainId": 1, + "address": "0xad32a8e6220741182940c5abf610bde99e737b2d", + "name": "PieDAO DOUGH v2", + "symbol": "DOUGH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12693/thumb/DOUGH2v.png?1602655308" + }, + { + "chainId": 1, + "address": "0xcbe771323587ea16dacb6016e269d7f08a7acc4e", + "name": "Spores Network", + "symbol": "SPO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17431/thumb/SPO_token.png?1627619762" + }, + { + "chainId": 1, + "address": "0xd7f0cc50ad69408ae58be033f4f85d2367c2e468", + "name": "Vera", + "symbol": "VERA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18519/thumb/JJXTVFOE_400x400.png?1632273174" + }, + { + "chainId": 1, + "address": "0xd567b5f02b9073ad3a982a099a23bf019ff11d1c", + "name": "Gamestarter", + "symbol": "GAME", + "decimals": 5, + "logoURI": "https://assets.coingecko.com/coins/images/17604/thumb/gpMi14-r_400x400.jpg?1628647205" + }, + { + "chainId": 1, + "address": "0xe796d6ca1ceb1b022ece5296226bf784110031cd", + "name": "Blind Boxes", + "symbol": "BLES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14537/thumb/BLES-Logo-BW.png?1637158078" + }, + { + "chainId": 1, + "address": "0x634239cfa331df0291653139d1a6083b9cf705e3", + "name": "DeSpace Protocol", + "symbol": "DES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18517/thumb/NQQu-EsT_400x400.jpg?1632267572" + }, + { + "chainId": 1, + "address": "0x300a902513815028e97fc79e92082ce6a98d3b74", + "name": "Ethersocks", + "symbol": "SOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14943/thumb/LOGO-for-CMC-V1.png?1619429911" + }, + { + "chainId": 1, + "address": "0x6b9f031d718dded0d681c20cb754f97b3bb81b78", + "name": "GEEQ", + "symbol": "GEEQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11953/thumb/GeeqLogoPNGTransparent-1.png?1596421769" + }, + { + "chainId": 1, + "address": "0xbc298dfaa2edda095b924f1390cc38fb7c5f6250", + "name": "Nezuko Inu", + "symbol": "NEZUKO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18652/thumb/O7TBGRA.png?1632759790" + }, + { + "chainId": 1, + "address": "0x2327590bb709f1505b64d1e4573d7c0dcea4350c", + "name": "Shibgeki", + "symbol": "SHIBGEKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24032/thumb/Untitled-design-1.png?1646116490" + }, + { + "chainId": 1, + "address": "0xdcd85914b8ae28c1e62f1c488e1d968d5aaffe2b", + "name": "TOP Network", + "symbol": "TOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7058/thumb/topnetwork-logo.png?1547043514" + }, + { + "chainId": 1, + "address": "0xbd4b60a138b3fce3584ea01f50c0908c18f9677a", + "name": "FinTab", + "symbol": "FNTB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3773/thumb/300x300_%281%29.png?1547038862" + }, + { + "chainId": 1, + "address": "0x23894dc9da6c94ecb439911caf7d337746575a72", + "name": "Geojam", + "symbol": "JAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24648/thumb/200px_Transparent_Bubble_Token_Icon.png?1668597490" + }, + { + "chainId": 1, + "address": "0x4c19596f5aaff459fa38b0f7ed92f11ae6543784", + "name": "TrueFi", + "symbol": "TRU", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13180/thumb/truefi_glyph_color.png?1617610941" + }, + { + "chainId": 1, + "address": "0x683239a4cab49642c6e025cf81d283f9c87bc07d", + "name": "Unicly MoonCats Collection", + "symbol": "UMOON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15674/thumb/MoonCats.jpg?1621498102" + }, + { + "chainId": 1, + "address": "0xaecc217a749c2405b5ebc9857a16d58bdc1c367f", + "name": "Pawthereum", + "symbol": "PAWTH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19275/thumb/pawth.png?1635127429" + }, + { + "chainId": 1, + "address": "0xfc1cb4920dc1110fd61afab75cf085c1f871b8c6", + "name": "EdenLoop", + "symbol": "ELT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24746/thumb/voRjghoA_400x400.jpg?1648784263" + }, + { + "chainId": 1, + "address": "0x00059ae69c1622a7542edc15e8d17b060fe307b6", + "name": "AmonD", + "symbol": "AMON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8952/thumb/AmonD_512x512.png?1563227436" + }, + { + "chainId": 1, + "address": "0x94e0bab2f6ab1f19f4750e42d7349f2740513ad5", + "name": "Unicly", + "symbol": "UNIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14720/thumb/Unicly.png?1621132059" + }, + { + "chainId": 1, + "address": "0x1b957dc4aefeed3b4a2351a6a6d5cbfbba0cecfa", + "name": "HOQU", + "symbol": "HQX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1793/thumb/hqx.png?1547036096" + }, + { + "chainId": 1, + "address": "0xf5b5efc906513b4344ebabcf47a04901f99f09f3", + "name": "UBIX Network", + "symbol": "UBX", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/13000/thumb/UBIX.jpg?1626406542" + }, + { + "chainId": 1, + "address": "0x05d27cdd23e22ca63e7f9c7c6d1b79ede9c4fcf5", + "name": "Yearn Finance Passive Income", + "symbol": "YFPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12640/thumb/200.png?1601369185" + }, + { + "chainId": 1, + "address": "0x14da7b27b2e0fedefe0a664118b0c9bc68e2e9af", + "name": "Blockchain Cuties Universe Governance", + "symbol": "BCUG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14425/thumb/bcug_logo.png?1616022820" + }, + { + "chainId": 1, + "address": "0xc690f7c7fcffa6a82b79fab7508c466fefdfc8c5", + "name": "Lympo", + "symbol": "LYM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2620/thumb/lympo_token.png?1547036775" + }, + { + "chainId": 1, + "address": "0x24c19f7101c1731b85f1127eaa0407732e36ecdd", + "name": "SharedStake Governance v2", + "symbol": "SGTV2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13948/thumb/sgt-png.png?1615189100" + }, + { + "chainId": 1, + "address": "0x83e9f223e1edb3486f876ee888d76bfba26c475a", + "name": "BlockchainSpace", + "symbol": "GUILD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21271/thumb/BednjMw.png?1638857799" + }, + { + "chainId": 1, + "address": "0xf961a1fa7c781ecd23689fe1d0b7f3b6cbb2f972", + "name": "Wrapped Moon Cats", + "symbol": "MCAT20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14387/thumb/MCAT20.png?1615803341" + }, + { + "chainId": 1, + "address": "0xa3ee21c306a700e682abcdfe9baa6a08f3820419", + "name": "Creditcoin", + "symbol": "CTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10569/thumb/ctc.png?1644650695" + }, + { + "chainId": 1, + "address": "0x0a913bead80f321e7ac35285ee10d9d922659cb7", + "name": "DOS Network", + "symbol": "DOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7991/thumb/DOS.png?1552900889" + }, + { + "chainId": 1, + "address": "0x995a6c0944322b7285d0712824acf0cf9bf3993a", + "name": "First Ever NFT", + "symbol": "FEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24336/thumb/FEN_TOKEN_COIN_edited.png?1647361805" + }, + { + "chainId": 1, + "address": "0x7be00ed6796b21656732e8f739fc1b8f1c53da0d", + "name": "ACDX Exchange", + "symbol": "ACXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13293/thumb/ACDX_Original_05.png?1607064933" + }, + { + "chainId": 1, + "address": "0x0affa06e7fbe5bc9a764c979aa66e8256a631f02", + "name": "Polybius", + "symbol": "PLBT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/766/thumb/polybius.png?1547034516" + }, + { + "chainId": 1, + "address": "0x31ea0de8119307aa264bb4b38727aab4e36b074f", + "name": "Bit Store", + "symbol": "STORE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20463/thumb/bit_store.PNG?1637064215" + }, + { + "chainId": 1, + "address": "0x944eee930933be5e23b690c8589021ec8619a301", + "name": "Munch", + "symbol": "MUNCH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14804/thumb/logo_-_2021-04-16T082627.266.png?1618532828" + }, + { + "chainId": 1, + "address": "0x9c197c4b58527faaab67cb35e3145166b23d242e", + "name": "HashNet BitEco", + "symbol": "HNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8126/thumb/GyEELaxS_400x400.jpg?1555226121" + }, + { + "chainId": 1, + "address": "0x3e5d9d8a63cc8a88748f229999cf59487e90721e", + "name": "MetalSwap", + "symbol": "XMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22075/thumb/Logo_COIN_-_Gradiente.png?1670579810" + }, + { + "chainId": 1, + "address": "0xe8ff5c9c75deb346acac493c463c8950be03dfba", + "name": "VIBE", + "symbol": "VIBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/948/thumb/vibe.png?1547034809" + }, + { + "chainId": 1, + "address": "0x89b69f2d1adffa9a253d40840b6baa7fc903d697", + "name": "Dione", + "symbol": "DIONE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26931/thumb/dione_200x200.png?1660886063" + }, + { + "chainId": 1, + "address": "0x6400b5522f8d448c0803e6245436dd1c81df09ce", + "name": "Conscious Value Network", + "symbol": "CVNT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5158/thumb/cvnt.png?1634711407" + }, + { + "chainId": 1, + "address": "0xe7f4c89032a2488d327323548ab0459676269331", + "name": "WAIFU Vault NFTX ", + "symbol": "WAIFU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17045/thumb/waifu.png?1626147639" + }, + { + "chainId": 1, + "address": "0x997507cc49fbf0cd6ce5e1ee543218556fafdebc", + "name": "Bitenium", + "symbol": "BT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14618/thumb/BT-token-logo-200.png?1617262055" + }, + { + "chainId": 1, + "address": "0x4fee21439f2b95b72da2f9f901b3956f27fe91d5", + "name": "FrogSwap", + "symbol": "FROG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21449/thumb/logo.54d7099f.png?1639174332" + }, + { + "chainId": 1, + "address": "0xa5e85cfb2c6db032dad992516a6f48529581cba3", + "name": "ONTPAY", + "symbol": "ONTP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27496/thumb/ezgif.com-gif-maker.jpg?1664271339" + }, + { + "chainId": 1, + "address": "0x02f2d4a04e6e01ace88bd2cd632875543b2ef577", + "name": "PKG", + "symbol": "PKG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5422/thumb/pkg-token.png?1548331357" + }, + { + "chainId": 1, + "address": "0x0af5855a348c58a8bbf65bcc7b9bbacd0e7e2238", + "name": "Ulanco", + "symbol": "UAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20662/thumb/udacity_logo_icon_169367.png?1637545628" + }, + { + "chainId": 1, + "address": "0x066798d9ef0833ccc719076dab77199ecbd178b0", + "name": "SakeSwap", + "symbol": "SAKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12428/thumb/sake.png?1599777402" + }, + { + "chainId": 1, + "address": "0x1beef31946fbbb40b877a72e4ae04a8d1a5cee06", + "name": "Parachute", + "symbol": "PAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7590/thumb/Parachute_Logo.png?1560918207" + }, + { + "chainId": 1, + "address": "0x635d081fd8f6670135d8a3640e2cf78220787d56", + "name": "Add xyz NEW ", + "symbol": "ADD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14351/thumb/ADDBK.png?1622444542" + }, + { + "chainId": 1, + "address": "0xa26cbb76156090f4b40a1799a220fc4c946afb3c", + "name": "Young", + "symbol": "YNG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26390/thumb/YNG.png?1657752304" + }, + { + "chainId": 1, + "address": "0x9301466c40b94942af9ba63cbaea1c784ff219b2", + "name": "eCeltron", + "symbol": "ECTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27511/thumb/vW1LS7PgPcq9R39knqB_zb9bsVoI8yknrUQ5yIA3mVQp9gJDjSP7C-CMjZeVhavUoPSI32aCLlIwtvlyIXOdk8oKppSqEQ6ZckU9DO4Z429LUJV2vfAnsknft6Gl8bkKjktX2nZXYRHagLRfCgvcVvjDbr-EcmNi3gqgBN2liRqHNmaXJ809xCnnzIxA1Yf2fKX-PlZqxShwMSL7VICFLYo61S23HvL5nK3f4kb-94IQ5cd.jpeg?1664350712" + }, + { + "chainId": 1, + "address": "0xcdeeeaaf2e96c25c679155e3854169c2f336b931", + "name": "MetaverseAir", + "symbol": "MVRS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21426/thumb/mvrs.jpg?1639117594" + }, + { + "chainId": 1, + "address": "0x2c9c19ce3b15ae77c6d80aec3c1194cfd6f7f3fa", + "name": "2crazyNFT", + "symbol": "2CRZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16797/thumb/2crz.png?1635525909" + }, + { + "chainId": 1, + "address": "0x84119cb33e8f590d75c2d6ea4e6b0741a7494eda", + "name": "Giga Watt", + "symbol": "WTT", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/907/thumb/wtt.png?1547034739" + }, + { + "chainId": 1, + "address": "0x2e6539edc3b76f1e21b71d214527faba875f70f3", + "name": "Yearn Finance DOT", + "symbol": "YFDOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12791/thumb/logo_%2815%29.png?1602580328" + }, + { + "chainId": 1, + "address": "0xb8f78ae3df5c541657161194ddbd0c5b44d1bee9", + "name": "Harmony Token", + "symbol": "HARM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27237/thumb/Untitled_design_%2815%29.png?1664068375" + }, + { + "chainId": 1, + "address": "0x744d70fdbe2ba4cf95131626614a1763df805b9e", + "name": "Status", + "symbol": "SNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/779/thumb/status.png?1548610778" + }, + { + "chainId": 1, + "address": "0xf009f5531de69067435e32c4b9d36077f4c4a673", + "name": "Unvest", + "symbol": "UNV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18119/thumb/unvest.PNG?1630554868" + }, + { + "chainId": 1, + "address": "0x77777777772cf0455fb38ee0e75f38034dfa50de", + "name": "XY Finance", + "symbol": "XY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21541/thumb/xy.png?1639913622" + }, + { + "chainId": 1, + "address": "0x6c3f90f043a72fa612cbac8115ee7e52bde6e490", + "name": "LP 3pool Curve", + "symbol": "3CRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12972/thumb/3pool_128.png?1603948039" + }, + { + "chainId": 1, + "address": "0x695106ad73f506f9d0a9650a78019a93149ae07c", + "name": "BNS Token OLD ", + "symbol": "BNS", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11926/thumb/HS7eNJdt_400x400.jpg?1596170654" + }, + { + "chainId": 1, + "address": "0x9ee91f9f426fa633d227f7a9b000e28b9dfd8599", + "name": "Lido Staked Matic", + "symbol": "STMATIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24185/thumb/stMATIC.png?1646789287" + }, + { + "chainId": 1, + "address": "0xfd957f21bd95e723645c07c48a2d8acb8ffb3794", + "name": "Ethereum Meta", + "symbol": "ETHM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6586/thumb/ethereum-meta.png?1548125409" + }, + { + "chainId": 1, + "address": "0x3b544e6fcf6c8dce9d8b45a4fdf21c9b02f9fda9", + "name": "Giftedhands", + "symbol": "GHD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12540/thumb/K-8uHktJ.png?1600644856" + }, + { + "chainId": 1, + "address": "0x8c3ee4f778e282b59d42d693a97b80b1ed80f4ee", + "name": "SatoPay", + "symbol": "STOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12220/thumb/stop.png?1598241582" + }, + { + "chainId": 1, + "address": "0x464ebe77c293e473b48cfe96ddcf88fcf7bfdac0", + "name": "KRYLL", + "symbol": "KRL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2807/thumb/krl.png?1547036979" + }, + { + "chainId": 1, + "address": "0xd4fa1460f537bb9085d22c7bccb5dd450ef28e3a", + "name": "Populous", + "symbol": "PPT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/753/thumb/populous.png?1548331905" + }, + { + "chainId": 1, + "address": "0xde2f7766c8bf14ca67193128535e5c7454f8387c", + "name": "Metadium", + "symbol": "META", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5247/thumb/META_Logo_black.png?1548833790" + }, + { + "chainId": 1, + "address": "0x888888435fde8e7d4c54cab67f206e4199454c60", + "name": "DFX Finance", + "symbol": "DFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14091/thumb/DFX.png?1614320944" + }, + { + "chainId": 1, + "address": "0xc2dd7a72f16cfa5dd8f9f5b49d251b2fd2163ff6", + "name": "SocialxClub", + "symbol": "SXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27819/thumb/coingesxc.png?1665977868" + }, + { + "chainId": 1, + "address": "0x606ce698aea1dca5a2627a4583da13a340667f09", + "name": "SaveBritney", + "symbol": "SBRT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17140/thumb/4NqipCv__400x400_%281%29.jpg?1626589552" + }, + { + "chainId": 1, + "address": "0xd487892bb4c57edbe7ab401d9fe801c8fe6473f5", + "name": "Uhive", + "symbol": "HVE2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3811/thumb/hve2.png?1639045485" + }, + { + "chainId": 1, + "address": "0x16980b3b4a3f9d89e33311b5aa8f80303e5ca4f8", + "name": "KIRA Network", + "symbol": "KEX", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13232/thumb/avatar.png?1622601779" + }, + { + "chainId": 1, + "address": "0xb19189fb36c816f3e0f16065057b07b790998fdc", + "name": "Serum SER", + "symbol": "SER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27757/thumb/Untitled_design_%2810%29.png?1665824038" + }, + { + "chainId": 1, + "address": "0x309627af60f0926daa6041b8279484312f2bf060", + "name": "USD Bancor", + "symbol": "USDB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10619/thumb/busd.png?1581026228" + }, + { + "chainId": 1, + "address": "0x04a020325024f130988782bd5276e53595e8d16e", + "name": "Herbalist", + "symbol": "HERB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6892/thumb/herbalist-token-twitter.png?1547043247" + }, + { + "chainId": 1, + "address": "0x20cd2e7ec8f5d8b337fe46a4f565ccef1561b9a9", + "name": "ESG", + "symbol": "ESG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24932/thumb/esg.png?1649397514" + }, + { + "chainId": 1, + "address": "0x7c81542ed859a2061538fee22b6544a235b9557d", + "name": "Combo", + "symbol": "COMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13053/thumb/7zYe50X.png?1604703767" + }, + { + "chainId": 1, + "address": "0x5845cd0205b5d43af695412a79cf7c1aeddb060f", + "name": "ShardingDAO", + "symbol": "SHD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14700/thumb/I1QLkPTq_400x400.png?1617836174" + }, + { + "chainId": 1, + "address": "0x4b4701f3f827e1331fb22ff8e2beac24b17eb055", + "name": "DistX", + "symbol": "DISTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12291/thumb/DISTX-icon.png?1598885812" + }, + { + "chainId": 1, + "address": "0x58aab16f5ba19827505bb4fe0a867fa0b7977e72", + "name": "Icel Idman Yurdu", + "symbol": "MIY", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/25981/thumb/20570.png?1655113476" + }, + { + "chainId": 1, + "address": "0xcccd1ba9f7acd6117834e0d28f25645decb1736a", + "name": "ECOx", + "symbol": "ECOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27962/thumb/_ECOx.png?1666751574" + }, + { + "chainId": 1, + "address": "0x9064c91e51d7021a85ad96817e1432abf6624470", + "name": "ShineChain", + "symbol": "SHE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6035/thumb/shinechain.png?1547041982" + }, + { + "chainId": 1, + "address": "0x00166a5b93fd4f87eca1c267d31d82df3f133a7f", + "name": "Incube Chain", + "symbol": "ICB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26323/thumb/photo_2022-07-06_16-58-56.jpg?1657248479" + }, + { + "chainId": 1, + "address": "0xb2617246d0c6c0087f18703d576831899ca94f01", + "name": "Zignaly", + "symbol": "ZIG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14796/thumb/zignaly.jpg?1618496339" + }, + { + "chainId": 1, + "address": "0x5e92624ff08194ad65c982861f69889b07c3d3e8", + "name": "LuxTTO", + "symbol": "LXTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26001/thumb/luxtto_logo%28200x200%29.png?1655277426" + }, + { + "chainId": 1, + "address": "0xcbfef8fdd706cde6f208460f2bf39aa9c785f05d", + "name": "Kine Protocol", + "symbol": "KINE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14339/thumb/kine.jpg?1615474456" + }, + { + "chainId": 1, + "address": "0x1c65c261cb89178b02cf2aee20058b992787d770", + "name": "TORQ Coin", + "symbol": "TORQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3486/thumb/torq-coin.png?1547038229" + }, + { + "chainId": 1, + "address": "0x442bc47357919446eabc18c7211e57a13d983469", + "name": "BeeChat", + "symbol": "CHAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14386/thumb/ezgif-6-b78b8423d870.png?1615803294" + }, + { + "chainId": 1, + "address": "0x8811e4dd5ec5eb8764b97cc814b1339089717ada", + "name": "Bithachi", + "symbol": "BITH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11765/thumb/bith3.png?1593656342" + }, + { + "chainId": 1, + "address": "0xca75c43f8c9afd356c585ce7aa4490b48a95c466", + "name": "Inari", + "symbol": "INARI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16795/thumb/token_logo_%281%29.png?1625036828" + }, + { + "chainId": 1, + "address": "0xbb340a2eaf55c5e67a5a05fe5ceed9b9702d76f4", + "name": "BolttCoin", + "symbol": "BOLTT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3928/thumb/Ticker.jpeg?1551231549" + }, + { + "chainId": 1, + "address": "0xf1290473e210b2108a85237fbcd7b6eb42cc654f", + "name": "HedgeTrade", + "symbol": "HEDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7196/thumb/to3Vj4EZ_400x400.jpg?1547043758" + }, + { + "chainId": 1, + "address": "0x6b4fc67b7866121036b7e36ba202b0c6bab8cd82", + "name": "VendettaDAO", + "symbol": "V", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27029/thumb/Vendetta-DAO-200x200.png?1661493958" + }, + { + "chainId": 1, + "address": "0x4730fb1463a6f1f44aeb45f6c5c422427f37f4d0", + "name": "4thpillar technologies", + "symbol": "FOUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3434/thumb/four-ticker-2021-256x256.png?1617702287" + }, + { + "chainId": 1, + "address": "0x1559fa1b8f28238fd5d76d9f434ad86fd20d1559", + "name": "EDEN", + "symbol": "EDEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17470/thumb/Iyc0XM5-_400x400.jpg?1628254655" + }, + { + "chainId": 1, + "address": "0x83d4cf08be796a08041a71152b653c828211c866", + "name": "LilFlokiCeo", + "symbol": "LILFLOKICEO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19860/thumb/ceo.jpeg?1636076347" + }, + { + "chainId": 1, + "address": "0x2c4e8f2d746113d0696ce89b35f0d8bf88e0aeca", + "name": "OST", + "symbol": "OST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1367/thumb/ost.jpg?1547035393" + }, + { + "chainId": 1, + "address": "0x6e5970dbd6fc7eb1f29c6d2edf2bc4c36124c0c1", + "name": "Polytrade", + "symbol": "TRADE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16416/thumb/Logo_colored_200.png?1623979654" + }, + { + "chainId": 1, + "address": "0x93dfaf57d986b9ca77df9376c50878e013d9c7c8", + "name": "Unique One", + "symbol": "RARE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13458/thumb/Logo_Unique.png?1612757355" + }, + { + "chainId": 1, + "address": "0x06677dc4fe12d3ba3c7ccfd0df8cd45e4d4095bf", + "name": "Work Quest", + "symbol": "WQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14662/thumb/WQT-1_%281%29.png?1627652762" + }, + { + "chainId": 1, + "address": "0xdd690d8824c00c84d64606ffb12640e932c1af56", + "name": "Tavittcoin", + "symbol": "TAVITT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5155/thumb/tavitt-logo.png?1547040566" + }, + { + "chainId": 1, + "address": "0xd31a9d28d66a1f7e62b5565416ea14607690f788", + "name": "HealthChainUS", + "symbol": "HCUT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11868/thumb/60633927_588600498303961_3291974703035449344_n.png?1595496238" + }, + { + "chainId": 1, + "address": "0xfc3718cd921549a2cb67636b82a01d067726c428", + "name": "Its Not Art", + "symbol": "NA", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/27039/thumb/NA.png?1661501367" + }, + { + "chainId": 1, + "address": "0x4c38d0e726b6c86f64c1b281348e725973542043", + "name": "Stand Share", + "symbol": "SAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13543/thumb/sac.jpg?1609648278" + }, + { + "chainId": 1, + "address": "0xdc732972811d25de61808b3d6e0d2ac44a7f036f", + "name": "GOSH Realm", + "symbol": "GOSH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24768/thumb/Untitled.png?1648817598" + }, + { + "chainId": 1, + "address": "0xb6ed7644c69416d67b522e20bc294a9a9b405b31", + "name": "0xBitcoin", + "symbol": "0XBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4454/thumb/0xbtc.png?1561603765" + }, + { + "chainId": 1, + "address": "0x9ad37205d608b8b219e6a2573f922094cec5c200", + "name": "Izumi Finance", + "symbol": "IZI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21791/thumb/izumi-logo-symbol.png?1640053924" + }, + { + "chainId": 1, + "address": "0x115ec79f1de567ec68b7ae7eda501b406626478e", + "name": "Carry", + "symbol": "CRE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3994/thumb/Carry.png?1592402610" + }, + { + "chainId": 1, + "address": "0xeca82185adce47f39c684352b0439f030f860318", + "name": "PERL eco", + "symbol": "PERL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4682/thumb/PERL.eco-Icon-green_6x.png?1624365340" + }, + { + "chainId": 1, + "address": "0x70bef3bb2f001da2fddb207dae696cd9faff3f5d", + "name": "Ninja Squad", + "symbol": "NST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22248/thumb/unnamed.jpg?1641277417" + }, + { + "chainId": 1, + "address": "0x9b6db7597a74602a5a806e33408e7e2dafa58193", + "name": "Spice DAO", + "symbol": "SPICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21086/thumb/KfMQkToD_400x400.jpg?1638312662" + }, + { + "chainId": 1, + "address": "0x2ed2cc2c858a8a8219fd2f2d9e170285dbd02756", + "name": "Sports Bet", + "symbol": "SBET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25312/thumb/sbet_logo_256.png?1651214220" + }, + { + "chainId": 1, + "address": "0x0eb3032bcac2be1fa95e296442f225edb80fc3cd", + "name": "Aster", + "symbol": "ATC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17325/thumb/atc.png?1627311439" + }, + { + "chainId": 1, + "address": "0x20bc832ca081b91433ff6c17f85701b6e92486c5", + "name": "rETH2", + "symbol": "RETH2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16570/thumb/red256.png?1624495231" + }, + { + "chainId": 1, + "address": "0x12aef5c60c2c86c8ecd3079f22f285f326371340", + "name": "hiSAND33", + "symbol": "HISAND33", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27006/thumb/logo.ab86781.png?1661337838" + }, + { + "chainId": 1, + "address": "0x75b02aa1084a12b8729f5acbe1078bd450abe552", + "name": "ASEC Frontier", + "symbol": "ASEC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15939/thumb/58947b_49a936ef42ab4b7da4d2beb95852d49a_mv2.png?1622459327" + }, + { + "chainId": 1, + "address": "0x91a5de30e57831529a3c1af636a78a7e4e83f3aa", + "name": "Hulk Inu", + "symbol": "HULK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26358/thumb/HULKINU_LOGO.png?1657593698" + }, + { + "chainId": 1, + "address": "0xabe9b2e4bbd5a8c718752c41254ed81aae7d98bf", + "name": "P2P", + "symbol": "P2P", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/12486/thumb/p2p.png?1600207324" + }, + { + "chainId": 1, + "address": "0xf7e40af830a2ecbfe72c5210c1ca272e3aa7ca1b", + "name": "Cultiplan", + "symbol": "CTPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15798/thumb/Cultiplan_200x200_logo.png?1621927264" + }, + { + "chainId": 1, + "address": "0xf2354f740f31704820f6fcfba70b9da065459b62", + "name": "Istardust", + "symbol": "ISDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12568/thumb/istardust.png?1600840530" + }, + { + "chainId": 1, + "address": "0x77f9cf0bd8c500cffdf420e72343893aecc2ec0b", + "name": "Laika", + "symbol": "LAIKA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26717/thumb/Laikacmcfinal.png?1659857807" + }, + { + "chainId": 1, + "address": "0x6c862f803ff42a97d4a483ab761256ad8c90f4f8", + "name": "ELIS", + "symbol": "XLS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13613/thumb/Elis-Symbol-Green.png?1610285892" + }, + { + "chainId": 1, + "address": "0x78223d31298107f3e310b09797b07967832046a6", + "name": "ROYAL SMART FUTURE TOKEN", + "symbol": "RSFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26630/thumb/RSF200x200.png?1659325435" + }, + { + "chainId": 1, + "address": "0x2da719db753dfa10a62e140f436e1d67f2ddb0d6", + "name": "Cere Network", + "symbol": "CERE", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/20008/thumb/cere.png?1636366576" + }, + { + "chainId": 1, + "address": "0x65d9bc970aa9b2413027fa339f7f179b3f3f2604", + "name": "Chemix Ecology Governance", + "symbol": "KUN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13177/thumb/kun_logo.png?1605923919" + }, + { + "chainId": 1, + "address": "0x3e8ffc8c3cb0db3081df85dec91b63abbbe99f71", + "name": "Mixsome", + "symbol": "SOME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15005/thumb/mixsome.PNG?1619412351" + }, + { + "chainId": 1, + "address": "0x190fb342aa6a15eb82903323ae78066ff8616746", + "name": "Umbrella Coin", + "symbol": "UMC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1700/thumb/umbrellacoin.jpg?1547035958" + }, + { + "chainId": 1, + "address": "0xb5588c411ba0bb7d38865fdc51d082d004e519f7", + "name": "WAIT", + "symbol": "WAIT", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/26860/thumb/wait_etherscan_logo.png?1660529678" + }, + { + "chainId": 1, + "address": "0x4290563c2d7c255b5eec87f2d3bd10389f991d68", + "name": "UnlimitedIP", + "symbol": "UIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2642/thumb/unlimitedip.png?1547036818" + }, + { + "chainId": 1, + "address": "0xe84d9e32dc8ce819b8d6c83e50edafd46c6354db", + "name": "Koi Network", + "symbol": "KOI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26221/thumb/KXc9agT1_400x400.jpeg?1656641746" + }, + { + "chainId": 1, + "address": "0x865377367054516e17014ccded1e7d814edc9ce4", + "name": "Dola", + "symbol": "DOLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14287/thumb/dola.png?1667738374" + }, + { + "chainId": 1, + "address": "0xc528c28fec0a90c083328bc45f587ee215760a0f", + "name": "Endor Protocol", + "symbol": "EDR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3683/thumb/0b805574-ef0d-41dc-b518-8d6148bf4716.png?1547038680" + }, + { + "chainId": 1, + "address": "0x155040625d7ae3e9cada9a73e3e44f76d3ed1409", + "name": "Revomon", + "symbol": "REVO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14759/thumb/revomon.jpeg?1618243538" + }, + { + "chainId": 1, + "address": "0xc0ae17eb994fa828540ffa53776b3830233a1b02", + "name": "Element Black", + "symbol": "ELT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25160/thumb/4TCtUKHs_400x400.jpg?1650464346" + }, + { + "chainId": 1, + "address": "0x601a0ee18e9dcdc70658d8b87a748e11344d3a45", + "name": "APEX Protocol", + "symbol": "APXP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21542/thumb/APXP-logo_200x200.png?1639448329" + }, + { + "chainId": 1, + "address": "0xdd2a36ae937bc134ea694d77fc7e2e36f5d86de0", + "name": "WELD", + "symbol": "WELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18544/thumb/weld.png?1661497968" + }, + { + "chainId": 1, + "address": "0xe44aa0354341f02d51c14fe2248b005b2e3372d4", + "name": "Dejitaru Kaida", + "symbol": "KAIDA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27867/thumb/Dejitaru_Kaida.jpeg?1666153265" + }, + { + "chainId": 1, + "address": "0xb12494c8824fc069757f47d177e666c571cd49ae", + "name": "ImpactXP", + "symbol": "IMPACTXP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21118/thumb/TJpEKVBW_400x400.jpg?1638340573" + }, + { + "chainId": 1, + "address": "0x33f391f4c4fe802b70b77ae37670037a92114a7c", + "name": "Burp", + "symbol": "BURP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17317/thumb/Big_Town_Chef_-__BURP_-_Avatar_3x.png?1646202255" + }, + { + "chainId": 1, + "address": "0xd38bb40815d2b0c2d2c866e0c72c5728ffc76dd9", + "name": "Symbiosis Finance", + "symbol": "SIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20805/thumb/SymbiosisFinance_logo-150x150.jpeg?1637707064" + }, + { + "chainId": 1, + "address": "0x55d1d16fb42fce47b899010c996a3a31f6db8fd6", + "name": "Bully Inu", + "symbol": "BINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22155/thumb/gM-mFn7L_400x400.jpg?1640941304" + }, + { + "chainId": 1, + "address": "0x6c22b815904165f3599f0a4a092d458966bd8024", + "name": "Bit Public Talent Network", + "symbol": "BPTN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8412/thumb/7f346702db390a289f5770f008563173.png?1558077057" + }, + { + "chainId": 1, + "address": "0x01597e397605bf280674bf292623460b4204c375", + "name": "Bent Finance", + "symbol": "BENT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21274/thumb/bent-logo-200x200.png?1638861325" + }, + { + "chainId": 1, + "address": "0x8dbf9a4c99580fc7fd4024ee08f3994420035727", + "name": "ECO", + "symbol": "ECO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27961/thumb/_ECO.png?1666751247" + }, + { + "chainId": 1, + "address": "0x07d9e49ea402194bf48a8276dafb16e4ed633317", + "name": "Dalecoin", + "symbol": "DALC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/932/thumb/dalecoin.png?1547791491" + }, + { + "chainId": 1, + "address": "0x1bc9f31c327ce04b6fa9d56fd84c14cc0b0a4f47", + "name": "Hygenercoin", + "symbol": "HG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8817/thumb/60762471_431874227611586_5376521021266329600_n.png?1561551785" + }, + { + "chainId": 1, + "address": "0x9bf02cf6b0435a0523e6f6e0d2f35a920144f5fa", + "name": "DeFi11", + "symbol": "D11", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18174/thumb/wjuVH0sC_400x400.jpg?1631267074" + }, + { + "chainId": 1, + "address": "0x785c34312dfa6b74f6f1829f79ade39042222168", + "name": "Bumper", + "symbol": "BUMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17822/thumb/Bumper-Icon-Inverse-200.png?1629344025" + }, + { + "chainId": 1, + "address": "0xfa99a87b14b02e2240c79240c5a20f945ca5ef76", + "name": "GG", + "symbol": "GGTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13666/thumb/ggtk.png?1629348879" + }, + { + "chainId": 1, + "address": "0x6fe355c62c6faf6946ce888ffaba9fd12355ae27", + "name": "HashBX", + "symbol": "HBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7091/thumb/46489646-905693182887642-8012727636373536768-n.png?1550724892" + }, + { + "chainId": 1, + "address": "0x7f3edcdd180dbe4819bd98fee8929b5cedb3adeb", + "name": "xToken", + "symbol": "XTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14089/thumb/xtk.png?1659278233" + }, + { + "chainId": 1, + "address": "0x9afb950948c2370975fb91a441f36fdc02737cd4", + "name": "Huobi Fil", + "symbol": "HFIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14109/thumb/HFIL.png?1614334127" + }, + { + "chainId": 1, + "address": "0x016396044709eb3edc69c44f4d5fa6996917e4e8", + "name": "KingXChain", + "symbol": "KXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5690/thumb/kingxchain.png?1547975313" + }, + { + "chainId": 1, + "address": "0x40986a85b4cfcdb054a6cbfb1210194fee51af88", + "name": "UniFarm", + "symbol": "UFARM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15247/thumb/ufarm.jpeg?1620218765" + }, + { + "chainId": 1, + "address": "0xf98e38c3f287304a1f2d4879e741d2bf55474e84", + "name": "Shaman King Inu OLD ", + "symbol": "SHAMAN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20189/thumb/shamna.png?1636611907" + }, + { + "chainId": 1, + "address": "0xcfe4f03c3afbb9857b29fc706180bf0044900d59", + "name": "Golden Ratio Coin", + "symbol": "GOLDR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10363/thumb/original_GRO-768x768.png?1578612119" + }, + { + "chainId": 1, + "address": "0xa6422e3e219ee6d4c1b18895275fe43556fd50ed", + "name": "Stobox", + "symbol": "STBU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12637/thumb/exchange.png?1623764906" + }, + { + "chainId": 1, + "address": "0xe8e06a5613dc86d459bc8fb989e173bb8b256072", + "name": "Feyorra", + "symbol": "FEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13689/thumb/1_XiKKk5_400x400.jpg?1610953208" + }, + { + "chainId": 1, + "address": "0x68037790a0229e9ce6eaa8a99ea92964106c4703", + "name": "Parallel", + "symbol": "PAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14153/thumb/par_round_200.png?1614670422" + }, + { + "chainId": 1, + "address": "0x47110d43175f7f2c2425e7d15792acc5817eb44f", + "name": "Bankless DeFi Innovation Index", + "symbol": "GMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22238/thumb/GMI_LOGO-07.png?1641266293" + }, + { + "chainId": 1, + "address": "0x92cfbec26c206c90aee3b7c66a9ae673754fab7e", + "name": "OpenLeverage", + "symbol": "OLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26098/thumb/256x256_OLE_Token_Logo.png?1655859035" + }, + { + "chainId": 1, + "address": "0x419d0d8bdd9af5e606ae2232ed285aff190e711b", + "name": "FUN Token", + "symbol": "FUN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/761/thumb/funfair.png?1592404368" + }, + { + "chainId": 1, + "address": "0x9a96e767bfcce8e80370be00821ed5ba283d4a17", + "name": "GOGO Finance", + "symbol": "GOGO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13857/thumb/gogofinance.png?1612404853" + }, + { + "chainId": 1, + "address": "0xa12d7e5319f5b43476ef19d1569e10097cacdfe2", + "name": "Myth", + "symbol": "MYTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17593/thumb/GT_Logo-01.png?1628581478" + }, + { + "chainId": 1, + "address": "0xc7283b66eb1eb5fb86327f08e1b5816b0720212b", + "name": "Tribe", + "symbol": "TRIBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14575/thumb/tribe.PNG?1617487954" + }, + { + "chainId": 1, + "address": "0x92e52a1a235d9a103d970901066ce910aacefd37", + "name": "U CASH", + "symbol": "UCASH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2901/thumb/ucash.png?1547037074" + }, + { + "chainId": 1, + "address": "0x018fb5af9d015af25592a014c4266a84143de7a0", + "name": "MP3", + "symbol": "MP3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13897/thumb/1_sq13-ssNvv2APEFcy8dWJg.png?1612690862" + }, + { + "chainId": 1, + "address": "0x9cb2f26a23b8d89973f08c957c4d7cdf75cd341c", + "name": "Digital Rand", + "symbol": "DZAR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/9841/thumb/logo200_%281%29.png?1572577311" + }, + { + "chainId": 1, + "address": "0xb17548c7b510427baac4e267bea62e800b247173", + "name": "Swarm Markets", + "symbol": "SMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17488/thumb/swarm-SMT-token-symbol_200x200.png?1655373659" + }, + { + "chainId": 1, + "address": "0xe5597f0723eeaba1b26948e06f008bf0fc1e37e6", + "name": "GM", + "symbol": "GM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20066/thumb/PQ29R4D.png?1636768949" + }, + { + "chainId": 1, + "address": "0x86ed939b500e121c0c5f493f399084db596dad20", + "name": "SpaceChain ERC 20 ", + "symbol": "SPC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6659/thumb/Spacechain.jpg?1547042861" + }, + { + "chainId": 1, + "address": "0xddf7fd345d54ff4b40079579d4c4670415dbfd0a", + "name": "SocialGood", + "symbol": "SG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3948/thumb/logo_200.png?1596589686" + }, + { + "chainId": 1, + "address": "0x549020a9cb845220d66d3e9c6d9f9ef61c981102", + "name": "Sidus", + "symbol": "SIDUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21401/thumb/SIDUS_coin_logo.png?1639405031" + }, + { + "chainId": 1, + "address": "0xca1308e38340c69e848061aa2c3880daeb958187", + "name": "Hackerlabs DAO", + "symbol": "HLD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24670/thumb/YFYHhGlJ_400x400.jpg?1648540176" + }, + { + "chainId": 1, + "address": "0xb827f14c95c32ae2375618ea5e505b65b5e3914d", + "name": "Webpay", + "symbol": "PAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26429/thumb/logo.jpg?1657930482" + }, + { + "chainId": 1, + "address": "0xba41ddf06b7ffd89d1267b5a93bfef2424eb2003", + "name": "Mythos", + "symbol": "MYTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28045/thumb/Mythos_Logos_200x200.png?1667269609" + }, + { + "chainId": 1, + "address": "0xdae6f68da3bab6866742a7f4050366f6ac48760d", + "name": "GUSS ONE", + "symbol": "GUSS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8509/thumb/gussone_mid.png?1559030931" + }, + { + "chainId": 1, + "address": "0x687bfc3e73f6af55f0ccca8450114d107e781a0e", + "name": "QChi", + "symbol": "QCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5392/thumb/qchi.png?1548607478" + }, + { + "chainId": 1, + "address": "0x9ffc3bcde7b68c46a6dc34f0718009925c1867cb", + "name": "Huobi Polkadot", + "symbol": "HDOT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14107/thumb/hdot.png?1614333466" + }, + { + "chainId": 1, + "address": "0xc9fe6e1c76210be83dc1b5b20ec7fd010b0b1d15", + "name": "Fringe Finance", + "symbol": "FRIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13222/thumb/frin.png?1642932787" + }, + { + "chainId": 1, + "address": "0x10633216e7e8281e33c86f02bf8e565a635d9770", + "name": "Dvision Network", + "symbol": "DVI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13020/thumb/WGAhHOLv_400x400.png?1604396086" + }, + { + "chainId": 1, + "address": "0x6e8908cfa881c9f6f2c64d3436e7b80b1bf0093f", + "name": "Bistroo", + "symbol": "BIST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15645/thumb/bistroo.png?1659342030" + }, + { + "chainId": 1, + "address": "0x47d920a911cb9a0ad4618698ba3fef800abc868d", + "name": "The Golden Dog", + "symbol": "DOG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26542/thumb/DOG-200x200.png?1658733855" + }, + { + "chainId": 1, + "address": "0xdc8af07a7861bedd104b8093ae3e9376fc8596d2", + "name": "RocketX exchange", + "symbol": "RVF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14728/thumb/avatar-correct-size-official.png?1668391022" + }, + { + "chainId": 1, + "address": "0x5a9bf6badcd24fe0d58e1087290c2fe2c728736a", + "name": "Block 18", + "symbol": "18C", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7605/thumb/block_18.jpg?1548828772" + }, + { + "chainId": 1, + "address": "0x04a5198063e45d84b1999516d3228167146417a6", + "name": "ShiraINU", + "symbol": "SHR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20244/thumb/3234bad559608.png?1638363295" + }, + { + "chainId": 1, + "address": "0xc6bdb96e29c38dc43f014eed44de4106a6a8eb5f", + "name": "Inu Inu", + "symbol": "INUINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26391/thumb/logo_square_200.png?1657752596" + }, + { + "chainId": 1, + "address": "0x009c43b42aefac590c719e971020575974122803", + "name": "Bibox", + "symbol": "BIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1441/thumb/bibox-token.png?1547035519" + }, + { + "chainId": 1, + "address": "0x69e58172575de6ff336adb116a820b2d9a347a32", + "name": "Kongtama", + "symbol": "KONGTAMA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24313/thumb/Nl7zwYj.jpeg?1647353276" + }, + { + "chainId": 1, + "address": "0x0000000000095413afc295d19edeb1ad7b71c952", + "name": "Tokenlon", + "symbol": "LON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13454/thumb/lon_logo.png?1608701720" + }, + { + "chainId": 1, + "address": "0x8d3e855f3f55109d473735ab76f753218400fe96", + "name": "Bundles", + "symbol": "BUND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13219/thumb/Bundles_Bet_-_Master-_plain_green_jpeg-01.jpg?1651131621" + }, + { + "chainId": 1, + "address": "0x286bda1413a2df81731d4930ce2f862a35a609fe", + "name": "Wabi", + "symbol": "WABI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1338/thumb/Tael.png?1547035364" + }, + { + "chainId": 1, + "address": "0x19e98c4921aab7e3f5fd2adca36cfb669c63e926", + "name": "Cola", + "symbol": "COLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18806/thumb/colawork_logo_200x200.png?1633479503" + }, + { + "chainId": 1, + "address": "0xa823e6722006afe99e91c30ff5295052fe6b8e32", + "name": "Neumark", + "symbol": "NEU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2218/thumb/neumark.png?1547036501" + }, + { + "chainId": 1, + "address": "0x9b83f827928abdf18cf1f7e67053572b9bceff3a", + "name": "Artem", + "symbol": "ARTEM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21998/thumb/ARTM_Logo_MAIN_%281%29.png?1644469331" + }, + { + "chainId": 1, + "address": "0x305de070488c8469dfac957226c9c900c4bfba22", + "name": "More", + "symbol": "MORE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/742/thumb/1722.png?1620080666" + }, + { + "chainId": 1, + "address": "0xf65b5c5104c4fafd4b709d9d60a185eae063276c", + "name": "Truebit Protocol", + "symbol": "TRU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15053/thumb/Truebit.png?1623296246" + }, + { + "chainId": 1, + "address": "0x8a9c4dfe8b9d8962b31e4e16f8321c44d48e246e", + "name": "Name Change", + "symbol": "NCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13826/thumb/hashmasks-nct.png?1612879286" + }, + { + "chainId": 1, + "address": "0x6988a804c74fd04f37da1ea4781cea68c9c00f86", + "name": "Tribal Token", + "symbol": "TRIBL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27774/thumb/TRIBL_Logo_200x200.png?1665724961" + }, + { + "chainId": 1, + "address": "0x7ca4408137eb639570f8e647d9bd7b7e8717514a", + "name": "Alpaca City", + "symbol": "ALPA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13070/thumb/alpaca_logo.png?1604895862" + }, + { + "chainId": 1, + "address": "0x8d2fab1ff34f1c545673a816f1438b02d0a2e32d", + "name": "AISF", + "symbol": "AGT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12859/thumb/AISF_token.jpg?1603095207" + }, + { + "chainId": 1, + "address": "0x1b6c5864375b34af3ff5bd2e5f40bc425b4a8d79", + "name": "TopChain", + "symbol": "TOPC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/2547/thumb/topchain.png?1516372992" + }, + { + "chainId": 1, + "address": "0xeea9ae787f3a620072d13b2cdc8cabffb9c0ab96", + "name": "Yearn Secure", + "symbol": "YSEC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12993/thumb/ysec.png?1604212852" + }, + { + "chainId": 1, + "address": "0x16987c021c14ca1045cd0afebb33c124a58bf16c", + "name": "Voyager", + "symbol": "VGR", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/7381/thumb/PKQbxUtP_400x400.jpg?1547044079" + }, + { + "chainId": 1, + "address": "0x6731827cb6879a2091ce3ab3423f7bf20539b579", + "name": "Empower", + "symbol": "MPWR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25456/thumb/MPWR_200x200.png?1651815610" + }, + { + "chainId": 1, + "address": "0xa3e53fe692eeda3502cf5ccfd8a535e1f93d23dd", + "name": "Celeb", + "symbol": "CELEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16402/thumb/celeb.PNG?1623914565" + }, + { + "chainId": 1, + "address": "0x8810c63470d38639954c6b41aac545848c46484a", + "name": "Aditus", + "symbol": "ADI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1867/thumb/adi.png?1514446309" + }, + { + "chainId": 1, + "address": "0x7abc60b3290f68c85f495fd2e0c3bd278837a313", + "name": "Cyber Movie Chain", + "symbol": "CMCT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6497/thumb/cyber-movie-chain.png?1547791095" + }, + { + "chainId": 1, + "address": "0x250050acd30e382a39b00f2d172058160050a9e4", + "name": "The k0de", + "symbol": "K0DE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26788/thumb/logo200x200.png?1660103280" + }, + { + "chainId": 1, + "address": "0xf256f3ac4176126f55af7c6e25fa5f3cdf518b38", + "name": "CEDARS", + "symbol": "CEDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12255/thumb/cedars.png?1598522772" + }, + { + "chainId": 1, + "address": "0x5ef227f7ce4e96c9ce90e32d4850545a6c5d099b", + "name": "BLUECHIPS", + "symbol": "BCHIP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7119/thumb/xIh2PBdp_400x400.jpg?1547043616" + }, + { + "chainId": 1, + "address": "0xb1f1f47061a7be15c69f378cb3f69423bd58f2f8", + "name": "Flashstake", + "symbol": "FLASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13533/thumb/FLASH.png?1615182275" + }, + { + "chainId": 1, + "address": "0x0000000de40dfa9b17854cbc7869d80f9f98d823", + "name": "delta theta", + "symbol": "DLTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15697/thumb/logo-DT-square.png?1621570627" + }, + { + "chainId": 1, + "address": "0x6226e00bcac68b0fe55583b90a1d727c14fab77f", + "name": "MultiVAC", + "symbol": "MTV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4937/thumb/MultiVAC.png?1558598585" + }, + { + "chainId": 1, + "address": "0xc631120155621ee625835ec810b9885cdd764cd6", + "name": "Goldex", + "symbol": "GLDX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17814/thumb/gldx-logo-200x200.png?1629337485" + }, + { + "chainId": 1, + "address": "0x0e1fe60bc4ac0e3102343752ae7e49d01d444c0b", + "name": "Havens Nook", + "symbol": "HXN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14876/thumb/havennook.PNG?1618881827" + }, + { + "chainId": 1, + "address": "0x32ea3dc70e2962334864a9665254d2433e4ddbfd", + "name": "Sportzchain", + "symbol": "SPN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24915/thumb/Sportzchain_logo_195_195.png?1650240200" + }, + { + "chainId": 1, + "address": "0xa4f779074850d320b5553c9db5fc6a8ab15bd34a", + "name": "YFIX finance", + "symbol": "YFIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12554/thumb/yfix-icon-200.png?1600739144" + }, + { + "chainId": 1, + "address": "0x3f09400313e83d53366147e3ea0e4e2279d80850", + "name": "Kush Finance", + "symbol": "KSEED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12545/thumb/kush.finance-512.png?1600844515" + }, + { + "chainId": 1, + "address": "0xb48e0f69e6a3064f5498d495f77ad83e0874ab28", + "name": "CXN Network", + "symbol": "CXN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12622/thumb/Webp.net-resizeimage.png?1601282522" + }, + { + "chainId": 1, + "address": "0xeed9e4f2450035d6426276a8aa2084966ee3b1bb", + "name": "Steaks Finance", + "symbol": "STEAK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12672/thumb/MtZuJ_Gq6mqy4BaGacnKNMKmviA1xeDWg2wUiPMqZ-1MzfSiTiAbEzfclWWsU4FF3QxYJcrs5ia_DSWAvdwNYbROJEkm-UK9mZRBPK_z61JciH4XhqMEDpYParjxnkEDqIoobaGaW9bOzPPN_YYHYcv0A1LxjnzdPZF47ZigVuAoOa46YZNFJ_IkM-e-Cuf_-XCpbS2EtbMYvCEhbSuzrI.jpg?1601518956" + }, + { + "chainId": 1, + "address": "0x750c83707112e9acc452692c190cb55e30f42510", + "name": "WenMoon", + "symbol": "WM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20263/thumb/Wen-Moon200x200.png?1636704100" + }, + { + "chainId": 1, + "address": "0x26c8afbbfe1ebaca03c2bb082e69d0476bffe099", + "name": "Cellframe", + "symbol": "CELL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14465/thumb/cellframe-coingecko.png?1644483414" + }, + { + "chainId": 1, + "address": "0xe541504417670fb76b612b41b4392d967a1956c7", + "name": "Bitsonic", + "symbol": "BSC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9238/thumb/image.png?1604295837" + }, + { + "chainId": 1, + "address": "0xc3c221fe28c33814c28c822b631fd76047ef1a63", + "name": "Millimeter", + "symbol": "MM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12941/thumb/mm%EB%A1%9C%EA%B3%A0-2.png?1603765868" + }, + { + "chainId": 1, + "address": "0xe7eaec9bca79d537539c00c58ae93117fb7280b9", + "name": "Doge Protocol", + "symbol": "DOGEP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23689/thumb/LjhKBldd_400x400.png?1645079751" + }, + { + "chainId": 1, + "address": "0xe5a3229ccb22b6484594973a03a3851dcd948756", + "name": "Receive Access Ecosystem", + "symbol": "RAE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9428/thumb/Copy_of_raetoken.png?1567290545" + }, + { + "chainId": 1, + "address": "0xa6f7645ed967faf708a614a2fca8d4790138586f", + "name": "MoonieNFT", + "symbol": "MNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18226/thumb/sq8oK6mX_400x400.png?1631026813" + }, + { + "chainId": 1, + "address": "0x96e61422b6a9ba0e068b6c5add4ffabc6a4aae27", + "name": "Iron Bank EURO", + "symbol": "IBEUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17285/thumb/Iron_Bank_Euro.png?1627900506" + }, + { + "chainId": 1, + "address": "0x09ce2b746c32528b7d864a1e3979bd97d2f095ab", + "name": "DeFIL", + "symbol": "DFL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17708/thumb/defillogo200200.png?1629080381" + }, + { + "chainId": 1, + "address": "0x2be5e8c109e2197d077d13a82daead6a9b3433c5", + "name": "Tokamak Network", + "symbol": "TON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12260/thumb/D919x5-s_400x400.png?1598568068" + }, + { + "chainId": 1, + "address": "0x48c3399719b582dd63eb5aadf12a40b4c3f52fa2", + "name": "StakeWise", + "symbol": "SWISE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15044/thumb/stakewise200.png?1619520721" + }, + { + "chainId": 1, + "address": "0x98e0438d3ee1404fea48e38e92853bb08cfa68bd", + "name": "TVT", + "symbol": "TVT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8388/thumb/g8hXw4QX_400x400.jpg?1557973343" + }, + { + "chainId": 1, + "address": "0x2a03a891add2dc6d0f7b94419086630ba5cb65b6", + "name": "Dreamverse", + "symbol": "DV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21554/thumb/dv.png?1639464955" + }, + { + "chainId": 1, + "address": "0x15bda08c3afbf5955d6e9b235fd55a1fd0dbc829", + "name": "Alpha Coin", + "symbol": "APC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/6725/thumb/alpha-coin.png?1547042955" + }, + { + "chainId": 1, + "address": "0x05079687d35b93538cbd59fe5596380cae9054a9", + "name": "BitSong", + "symbol": "BTSG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5041/thumb/logo_-_2021-01-10T210801.390.png?1610284134" + }, + { + "chainId": 1, + "address": "0x6e109e9dd7fa1a58bc3eff667e8e41fc3cc07aef", + "name": "CNH Tether", + "symbol": "CNHT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/5251/thumb/cny-tether-logo.png?1547040741" + }, + { + "chainId": 1, + "address": "0x0c93b616933b0cd03b201b29cd8a22681dd9e0d9", + "name": "HollyGold", + "symbol": "HGOLD", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13652/thumb/QnfGCea3aO_Qb-Gd9n6MSFE_eBVAr87WPoxAzf0gKdcGOEL4K5J6A5cpGinzLvHclj_UHkCnw9XTlGoNYd0H8T_Ebe8voLS49MAZO2NIknCxytaYFtt5_u12RQg-kpmWHcETzAFlDgk9iNXAL-88fB_l-DRi8WEsgSJzXXjztKzQlpXuET6d4_98pykED6uyq1-4PMVg05P7tUN.jpg?1610574345" + }, + { + "chainId": 1, + "address": "0x275f5ad03be0fa221b4c6649b8aee09a42d9412a", + "name": "Monavale", + "symbol": "MONA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13298/thumb/monavale_logo.jpg?1607232721" + }, + { + "chainId": 1, + "address": "0x2730d6fdc86c95a74253beffaa8306b40fedecbb", + "name": "UNICORN", + "symbol": "UNI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9383/thumb/54231438.png?1566777314" + }, + { + "chainId": 1, + "address": "0x21f54372c07b930b79c5c2d9bb0eaaca86c3b298", + "name": "Banana Finance", + "symbol": "BANANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13419/thumb/bananacoin.png?1608446599" + }, + { + "chainId": 1, + "address": "0x37f74e99794853777a10ea1dc08a64c86958f06a", + "name": "D Community", + "symbol": "DILI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9485/thumb/BYf_d6kekNWOY34VLGPvf7RcVj8SeRi7P65Nk0W7ji1jir_qSLfssffnNW0ZzQSWzhhsNRkMCL7qcX4CCaMTbgKb0D7b5yNeStKVMm2deZd9cONMuItgoKUXxIYkHElfk1PW2uiNZbg6a2K0OHtZTvkt1xo8YVKuthskXaryOkM6Ax-MXQlHOfbjwCcnQQjHxAucufrCZJfDgrY.jpg?1571685571" + }, + { + "chainId": 1, + "address": "0x8503a7b00b4b52692cc6c14e5b96f142e30547b7", + "name": "Meeds DAO", + "symbol": "MEED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24281/thumb/s-YfFWYu_400x400.png?1647218173" + }, + { + "chainId": 1, + "address": "0x22bb7d3f4dcf074b979021ca4e214361e14c6b26", + "name": "JoinBlocks", + "symbol": "BLOCKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26320/thumb/BLOCKS-DISCORD.png?1657245114" + }, + { + "chainId": 1, + "address": "0xd55236d48606c295adebf129dad04fc74bfaa708", + "name": "CardWallet", + "symbol": "CW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17820/thumb/cardwallet%28circle%29.png?1629341892" + }, + { + "chainId": 1, + "address": "0xa2881f7f441267042f9778ffa0d4f834693426be", + "name": "The HUSL", + "symbol": "HUSL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18619/thumb/W8ZIHKU.png?1650437671" + }, + { + "chainId": 1, + "address": "0x9f300b4ac0bf94cad77e7e2d3f850352b8bb264c", + "name": "Talent Coin", + "symbol": "TLNT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13771/thumb/TLNT.png?1611698474" + }, + { + "chainId": 1, + "address": "0x3c8d2fce49906e11e71cb16fa0ffeb2b16c29638", + "name": "Nifty League", + "symbol": "NFTL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19224/thumb/NFTL-256x256.png?1634713638" + }, + { + "chainId": 1, + "address": "0xdc4c9bfbb37c7cdeebc53c0ba5c7474fea5e106d", + "name": "Frank Inu", + "symbol": "FRANK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24474/thumb/frank.png?1647771278" + }, + { + "chainId": 1, + "address": "0x0563dce613d559a47877ffd1593549fb9d3510d6", + "name": "SuperBid", + "symbol": "SUPERBID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14179/thumb/sign_super_bid.png?1617964829" + }, + { + "chainId": 1, + "address": "0xa93d5cfaa41193b13321c035b4bdd2b534172762", + "name": "Dream Swap", + "symbol": "DREAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13033/thumb/dream_32.png?1604503082" + }, + { + "chainId": 1, + "address": "0xa8b61cff52564758a204f841e636265bebc8db9b", + "name": "Yield Protocol", + "symbol": "YIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14220/thumb/yield.png?1615030969" + }, + { + "chainId": 1, + "address": "0x4f14cdbd815b79e9624121f564f24685c6b1211b", + "name": "Angry Doge", + "symbol": "ANFD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25921/thumb/angry-doge-anfd.png?1654653373" + }, + { + "chainId": 1, + "address": "0x4bdcb66b968060d9390c1d12bd29734496205581", + "name": "Acquire Fi", + "symbol": "ACQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27199/thumb/ACQisotypeSept2022_1000x1000px.png?1662566695" + }, + { + "chainId": 1, + "address": "0xa44e5137293e855b1b7bc7e2c6f8cd796ffcb037", + "name": "Sentinel OLD ", + "symbol": "DVPN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3625/thumb/Sentinel_512X512.png?1622174555" + }, + { + "chainId": 1, + "address": "0x73b708e84837ffccde2933e3a1531fe61d5e80ef", + "name": "Betero", + "symbol": "BTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25153/thumb/B_green200.png?1650461529" + }, + { + "chainId": 1, + "address": "0x1a3496c18d558bd9c6c8f609e1b129f67ab08163", + "name": "DEAPCOIN", + "symbol": "DEP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10970/thumb/DEAPcoin_01.png?1586741677" + }, + { + "chainId": 1, + "address": "0xcd1faff6e578fa5cac469d2418c95671ba1a62fe", + "name": "Torum", + "symbol": "XTM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18393/thumb/torum-transparent-cmc.png?1631760805" + }, + { + "chainId": 1, + "address": "0xdf2c7238198ad8b389666574f2d8bc411a4b7428", + "name": "Hifi Finance", + "symbol": "MFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3293/thumb/hifi_logo.png?1613102742" + }, + { + "chainId": 1, + "address": "0xfbe878ced08132bd8396988671b450793c44bc12", + "name": "Fox Trading", + "symbol": "FOXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5182/thumb/foxtrading-logo.png?1547040619" + }, + { + "chainId": 1, + "address": "0x18b52f500e6d9c8b0455ec3483846d9f8edd7e1b", + "name": "Monopoly Meta", + "symbol": "MPM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26965/thumb/TkA1Iou8_400x400.jpeg?1661081008" + }, + { + "chainId": 1, + "address": "0x5ca381bbfb58f0092df149bd3d243b08b9a8386e", + "name": "MXC", + "symbol": "MXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4604/thumb/mxc.png?1655534336" + }, + { + "chainId": 1, + "address": "0x83e2be8d114f9661221384b3a50d24b96a5653f5", + "name": "0xcert", + "symbol": "ZXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4552/thumb/0xcert.png?1547039841" + }, + { + "chainId": 1, + "address": "0xe9f84d418b008888a992ff8c6d22389c2c3504e0", + "name": "Maximus BASE", + "symbol": "BASE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/27683/thumb/IMG_1131.PNG?1665214262" + }, + { + "chainId": 1, + "address": "0x8daebade922df735c38c80c7ebd708af50815faa", + "name": "tBTC", + "symbol": "TBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11224/thumb/tBTC.png?1589620754" + }, + { + "chainId": 1, + "address": "0x4297394c20800e8a38a619a243e9bbe7681ff24e", + "name": "Hot Cross", + "symbol": "HOTCROSS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15706/thumb/Hotcross.png?1632197570" + }, + { + "chainId": 1, + "address": "0x7240ac91f01233baaf8b064248e80feaa5912ba3", + "name": "OctoFi", + "symbol": "OCTO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12594/thumb/octofi-256x256-radius-22percent.png?1610679969" + }, + { + "chainId": 1, + "address": "0x1045f5ccb01daea4f8eab055f5fcbb7c0e7c89f0", + "name": "DeFiato", + "symbol": "DFIAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13386/thumb/Defiato.png?1608085873" + }, + { + "chainId": 1, + "address": "0x5eaa69b29f99c84fe5de8200340b4e9b4ab38eac", + "name": "Raze Network", + "symbol": "RAZE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14767/thumb/logo-2.png?1623867120" + }, + { + "chainId": 1, + "address": "0x4daeb4a06f70f4b1a5c329115731fe4b89c0b227", + "name": "Quasacoin", + "symbol": "QUA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21965/thumb/coin_200.png?1643454438" + }, + { + "chainId": 1, + "address": "0x34be5b8c30ee4fde069dc878989686abe9884470", + "name": "SENATE", + "symbol": "SENATE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21272/thumb/siIBOmcs.png?1638857898" + }, + { + "chainId": 1, + "address": "0xcb84d72e61e383767c4dfeb2d8ff7f4fb89abc6e", + "name": "Vega Protocol", + "symbol": "VEGA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15870/thumb/vega.PNG?1622178218" + }, + { + "chainId": 1, + "address": "0x12f649a9e821f90bb143089a6e56846945892ffb", + "name": "Hyprr", + "symbol": "UDOO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3078/thumb/HYPRR-WIDGET-CIRCLE-ONBLACK-1.jpg?1646752306" + }, + { + "chainId": 1, + "address": "0x8530b66ca3ddf50e0447eae8ad7ea7d5e62762ed", + "name": "Meta Doge", + "symbol": "METADOGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19656/thumb/metadoge.png?1636333901" + }, + { + "chainId": 1, + "address": "0x0cec1a9154ff802e7934fc916ed7ca50bde6844e", + "name": "PoolTogether", + "symbol": "POOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14003/thumb/PoolTogether.png?1613585632" + }, + { + "chainId": 1, + "address": "0xcafe001067cdef266afb7eb5a286dcfd277f3de5", + "name": "ParaSwap", + "symbol": "PSP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20403/thumb/ep7GqM19_400x400.jpg?1636979120" + }, + { + "chainId": 1, + "address": "0xd4c435f5b09f855c3317c8524cb1f586e42795fa", + "name": "Cindicator", + "symbol": "CND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1006/thumb/cindicator.png?1547034913" + }, + { + "chainId": 1, + "address": "0x6bba316c48b49bd1eac44573c5c871ff02958469", + "name": "Gas DAO", + "symbol": "GAS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22086/thumb/SjrgK6sf_400x400.jpg?1640763291" + }, + { + "chainId": 1, + "address": "0xaac679720204aaa68b6c5000aa87d789a3ca0aa5", + "name": "Huobi Bitcoin Cash", + "symbol": "HBCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14105/thumb/HBCh.png?1614330789" + }, + { + "chainId": 1, + "address": "0x374cb8c27130e2c9e04f44303f3c8351b9de61c1", + "name": "Bao Finance", + "symbol": "BAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13547/thumb/BaoLogo.png?1615342483" + }, + { + "chainId": 1, + "address": "0x353e41e66f58ce91d07d778520685473f38a7125", + "name": "Metaverse DAO", + "symbol": "MDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23242/thumb/ezgif.com-gif-maker_%281%29.jpg?1664937350" + }, + { + "chainId": 1, + "address": "0x3d0293f06daf4311b482564330d57c8db6c10893", + "name": "Y Coin", + "symbol": "YCO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14128/thumb/BIG-POTAT-200x200-removebg-preview.png?1614576159" + }, + { + "chainId": 1, + "address": "0x307d45afbb7e84f82ef3d251a6bb0f00edf632e4", + "name": "PLANET", + "symbol": "PLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9279/thumb/LOGO_BLACK.png?1565731302" + }, + { + "chainId": 1, + "address": "0x7b35ce522cb72e4077baeb96cb923a5529764a00", + "name": "Impermax OLD ", + "symbol": "IMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15126/thumb/Copy_of_200px.png?1619761475" + }, + { + "chainId": 1, + "address": "0x68257309fcdfe1e6edb592da97ac8215fe583908", + "name": "Gorilla Inu", + "symbol": "GORILLAINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19426/thumb/gorilla_logo.png?1635216321" + }, + { + "chainId": 1, + "address": "0xff56cc6b1e6ded347aa0b7676c85ab0b3d08b0fa", + "name": "Orbs", + "symbol": "ORBS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4630/thumb/Orbs.jpg?1547039896" + }, + { + "chainId": 1, + "address": "0xb8d313068891137952e7dff19d8afaa64dbc6fcb", + "name": "RedPill", + "symbol": "RPILL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27879/thumb/3177f501-401e-418d-a4bc-f72fdf9fe5d7.png?1666230108" + }, + { + "chainId": 1, + "address": "0xa71d0588eaf47f12b13cf8ec750430d21df04974", + "name": "Shiba Predator", + "symbol": "QOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24430/thumb/l1KzMcL.png?1647660619" + }, + { + "chainId": 1, + "address": "0x4a527d8fc13c5203ab24ba0944f4cb14658d1db6", + "name": "Morpheus Labs", + "symbol": "MITX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3164/thumb/mitx.png?1604888269" + }, + { + "chainId": 1, + "address": "0xe50006781f435ae43096288334afd9ae5ba50065", + "name": "Corgi Inu", + "symbol": "CORGI", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/15646/thumb/mWum355Y_400x400.jpg?1621422930" + }, + { + "chainId": 1, + "address": "0x7cc97bf17c5adabe25f9d19d15a1ec8a1ad65f14", + "name": "Wolverinu", + "symbol": "WOLVERINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27872/thumb/LOGO3232.jpg?1666166703" + }, + { + "chainId": 1, + "address": "0x23352036e911a22cfc692b5e2e196692658aded9", + "name": "Friendz", + "symbol": "FDZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3685/thumb/download_%2812%29.png?1547038682" + }, + { + "chainId": 1, + "address": "0x1cc30e2eac975416060ec6fe682041408420d414", + "name": "Kollect", + "symbol": "KOL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18664/thumb/kol.png?1632827164" + }, + { + "chainId": 1, + "address": "0xb5f1457d6fba1956fb8d31b0b7caca14bde0be4b", + "name": "Stilton", + "symbol": "STILT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26132/thumb/2vfQHbe9_400x400.png?1655969754" + }, + { + "chainId": 1, + "address": "0xc229c69eb3bb51828d0caa3509a05a51083898dd", + "name": "Pintu", + "symbol": "PTU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20281/thumb/image_1_8dd79a68aa.png?1636733599" + }, + { + "chainId": 1, + "address": "0xf59257e961883636290411c11ec5ae622d19455e", + "name": "FloorDAO", + "symbol": "FLOOR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/24026/thumb/icon-floor_2x.png?1646102857" + }, + { + "chainId": 1, + "address": "0x956f47f50a910163d8bf957cf5846d573e7f87ca", + "name": "Fei USD", + "symbol": "FEI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14570/thumb/ZqsF51Re_400x400.png?1617082206" + }, + { + "chainId": 1, + "address": "0x33d63ba1e57e54779f7ddaeaa7109349344cf5f1", + "name": "Data Economy Index", + "symbol": "DATA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18500/thumb/data_32.png?1632209427" + }, + { + "chainId": 1, + "address": "0xeef9f339514298c6a857efcfc1a762af84438dee", + "name": "Hermez Network", + "symbol": "HEZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12826/thumb/hermez_logo.png?1602826556" + }, + { + "chainId": 1, + "address": "0x37fe0f067fa808ffbdd12891c0858532cfe7361d", + "name": "Civilization", + "symbol": "CIV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17626/thumb/civ-200x200.png?1628674350" + }, + { + "chainId": 1, + "address": "0xc834fa996fa3bec7aad3693af486ae53d8aa8b50", + "name": "Convergence", + "symbol": "CONV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14519/thumb/Convergence_Logo_%28Final%29.png?1616667041" + }, + { + "chainId": 1, + "address": "0xa0246c9032bc3a600820415ae600c6388619a14d", + "name": "Harvest Finance", + "symbol": "FARM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12304/thumb/Harvest.png?1613016180" + }, + { + "chainId": 1, + "address": "0xbc46d9961a3932f7d6b64abfdec80c1816c4b835", + "name": "LITEX", + "symbol": "LXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5133/thumb/litex-logo.png?1547040525" + }, + { + "chainId": 1, + "address": "0x6123b0049f904d730db3c36a31167d9d4121fa6b", + "name": "Ribbon Finance", + "symbol": "RBN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15823/thumb/RBN_64x64.png?1633529723" + }, + { + "chainId": 1, + "address": "0x9008064e6cf73e27a3aba4b10e69f855a4f8efcc", + "name": "Gemie", + "symbol": "GEM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27745/thumb/icon-transparent.png?1665632270" + }, + { + "chainId": 1, + "address": "0x5d21ef5f25a985380b65c8e943a0082feda0db84", + "name": "Ethereum Cash", + "symbol": "ECASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1010/thumb/ethereumcash.png?1510040235" + }, + { + "chainId": 1, + "address": "0xcae72a7a0fd9046cf6b165ca54c9e3a3872109e0", + "name": "AnRKey X", + "symbol": "ANRX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13415/thumb/anrkey.jpg?1608311301" + }, + { + "chainId": 1, + "address": "0x0b452278223d3954f4ac050949d7998e373e7e43", + "name": "Shita kiri Suzume", + "symbol": "SUZUME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26813/thumb/shitakiri_cmc.png?1660275049" + }, + { + "chainId": 1, + "address": "0xa487bf43cf3b10dffc97a9a744cbb7036965d3b9", + "name": "Deri Protocol", + "symbol": "DERI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13931/thumb/200vs200.jpg?1627649443" + }, + { + "chainId": 1, + "address": "0x60eb57d085c59932d5faa6c6026268a4386927d0", + "name": "LOCGame", + "symbol": "LOCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15175/thumb/LOC_GAME.png?1620025060" + }, + { + "chainId": 1, + "address": "0xd0d7a9f2021958e51d60d6966b7bbed9d1cb22b5", + "name": "ENEX", + "symbol": "ENX", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/15070/thumb/ENEXpng200.png?1619621442" + }, + { + "chainId": 1, + "address": "0x03be5c903c727ee2c8c4e9bc0acc860cca4715e2", + "name": "Ternoa", + "symbol": "CAPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15921/thumb/e55393fa-7b4d-40f5-9f36-9a8a6bdcb570.png?1622430581" + }, + { + "chainId": 1, + "address": "0xa849eaae994fb86afa73382e9bd88c2b6b18dc71", + "name": "MVL", + "symbol": "MVL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3476/thumb/mass-vehicle-ledger.png?1547978299" + }, + { + "chainId": 1, + "address": "0xfb378115726a9ab2e0dccebbe2d53dc625ae201b", + "name": "Kitsune Inu", + "symbol": "KITSUNE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27661/thumb/200pxtranparent.png?1665102751" + }, + { + "chainId": 1, + "address": "0x081f67afa0ccf8c7b17540767bbe95df2ba8d97f", + "name": "CoinEx", + "symbol": "CET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4817/thumb/coinex-token.png?1547040183" + }, + { + "chainId": 1, + "address": "0xb9d7dddca9a4ac480991865efef82e01273f79c3", + "name": "Boosted LUSD", + "symbol": "BLUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27681/thumb/bLUSD_logo.png?1665213755" + }, + { + "chainId": 1, + "address": "0xdb25f211ab05b1c97d595516f45794528a807ad8", + "name": "STASIS EURO", + "symbol": "EURS", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/5164/thumb/EURS_300x300.png?1550571779" + }, + { + "chainId": 1, + "address": "0xaeb813653bb20d5fa4798dc4fc63af9cad4f3f67", + "name": "The Commission", + "symbol": "CMSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24993/thumb/pGaXc6eB_400x400.jpg?1649719689" + }, + { + "chainId": 1, + "address": "0x71eeba415a523f5c952cc2f06361d5443545ad28", + "name": "XDAO", + "symbol": "XDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27363/thumb/XDAO_Token_img.png?1665738325" + }, + { + "chainId": 1, + "address": "0x808507121b80c02388fad14726482e061b8da827", + "name": "Pendle", + "symbol": "PENDLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15069/thumb/Pendle_Logo_Normal-03.png?1634196276" + }, + { + "chainId": 1, + "address": "0x177d39ac676ed1c67a2b268ad7f1e58826e5b0af", + "name": "Blox", + "symbol": "CDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1231/thumb/Blox_Staking_Logo_2.png?1609117544" + }, + { + "chainId": 1, + "address": "0x04abeda201850ac0124161f037efd70c74ddc74c", + "name": "Nest Protocol", + "symbol": "NEST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11284/thumb/52954052.png?1589868539" + }, + { + "chainId": 1, + "address": "0xc3cab0d0918c39e29088c495a077ecd022758798", + "name": "Kitsune Mask", + "symbol": "KMASK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27866/thumb/kitsun.png?1666152169" + }, + { + "chainId": 1, + "address": "0x6c936d4ae98e6d2172db18c16c4b601c99918ee6", + "name": "Life Crypto", + "symbol": "LIFE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18245/thumb/communityIcon_t3kzc5skazh81.png?1666058038" + }, + { + "chainId": 1, + "address": "0x0c7d5ae016f806603cb1782bea29ac69471cab9c", + "name": "Bifrost", + "symbol": "BFC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4639/thumb/bifrost_32.png?1608520677" + }, + { + "chainId": 1, + "address": "0xc28e27870558cf22add83540d2126da2e4b464c2", + "name": "Sashimi", + "symbol": "SASHIMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12427/thumb/SashimiSwap-200x200.png?1601347413" + }, + { + "chainId": 1, + "address": "0xbbab3bdb291b0f22bc9881895ff488a5db67bec8", + "name": "CUBE", + "symbol": "ITAMCUBE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22396/thumb/CoinGecko_Logo_%281%29.jpg?1648792005" + }, + { + "chainId": 1, + "address": "0x8806926ab68eb5a7b909dcaf6fdbe5d93271d6e2", + "name": "Uquid Coin", + "symbol": "UQC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1341/thumb/uquid-coin.png?1548759712" + }, + { + "chainId": 1, + "address": "0x2ba8349123de45e931a8c8264c332e6e9cf593f9", + "name": "Blockchain Monster Hunt", + "symbol": "BCMC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19045/thumb/bcmc-coin-200x200.png?1641398990" + }, + { + "chainId": 1, + "address": "0x34950ff2b487d9e5282c5ab342d08a2f712eb79f", + "name": "Efforce", + "symbol": "WOZX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13310/thumb/rZ6Oe3dm_400x400.jpg?1607331889" + }, + { + "chainId": 1, + "address": "0xdf574c24545e5ffecb9a659c229253d4111d87e1", + "name": "HUSD", + "symbol": "HUSD", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9567/thumb/HUSD.jpg?1568889385" + }, + { + "chainId": 1, + "address": "0xde7d85157d9714eadf595045cc12ca4a5f3e2adb", + "name": "STP", + "symbol": "STPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8713/thumb/STP.png?1560262664" + }, + { + "chainId": 1, + "address": "0x466a756e9a7401b5e2444a3fcb3c2c12fbea0a54", + "name": "PUSd", + "symbol": "PUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25858/thumb/PUSd.png?1654161232" + }, + { + "chainId": 1, + "address": "0x7884f51dc1410387371ce61747cb6264e1daee0b", + "name": "Binance Wrapped DOT", + "symbol": "BDOT", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/23268/thumb/binance-dot_32.png?1643414783" + }, + { + "chainId": 1, + "address": "0xccc8cb5229b0ac8069c51fd58367fd1e622afd97", + "name": "Gods Unchained", + "symbol": "GODS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17139/thumb/10631.png?1635718182" + }, + { + "chainId": 1, + "address": "0xc4c7ea4fab34bd9fb9a5e1b1a98df76e26e6407c", + "name": "COCOS BCX", + "symbol": "COCOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4932/thumb/_QPpjoUi_400x400.jpg?1566430520" + }, + { + "chainId": 1, + "address": "0xeef37d7bd4ae03fd8ee1c44491987e422b53ed25", + "name": "KryptoPets", + "symbol": "KPETS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23337/thumb/kyTyD2Fi_400x400.jpg?1643882890" + }, + { + "chainId": 1, + "address": "0x226bb599a12c826476e3a771454697ea52e9e220", + "name": "Propy", + "symbol": "PRO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/869/thumb/propy.png?1548332100" + }, + { + "chainId": 1, + "address": "0xe0bceef36f3a6efdd5eebfacd591423f8549b9d5", + "name": "Defactor", + "symbol": "FACTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19201/thumb/jFLSu4U9_400x400.png?1650437050" + }, + { + "chainId": 1, + "address": "0xb49fa25978abf9a248b8212ab4b87277682301c0", + "name": "RAI Finance", + "symbol": "SOFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14686/thumb/sofi.png?1640249595" + }, + { + "chainId": 1, + "address": "0x3aada3e213abf8529606924d8d1c55cbdc70bf74", + "name": "XMON", + "symbol": "XMON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14008/thumb/xmon_logo.png?1613615094" + }, + { + "chainId": 1, + "address": "0x27c70cd1946795b66be9d954418546998b546634", + "name": "Doge Killer", + "symbol": "LEASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15802/thumb/Leash.png?1621931543" + }, + { + "chainId": 1, + "address": "0x73968b9a57c6e53d41345fd57a6e6ae27d6cdb2f", + "name": "Stake DAO", + "symbol": "SDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13724/thumb/stakedao_logo.jpg?1611195011" + }, + { + "chainId": 1, + "address": "0x727f064a78dc734d33eec18d5370aef32ffd46e4", + "name": "Orion Money", + "symbol": "ORION", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18630/thumb/YtrqPIWc.png?1632710781" + }, + { + "chainId": 1, + "address": "0xdc6104b7993e997ca5f08acab7d3ae86e13d20a6", + "name": "ParaState", + "symbol": "STATE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23707/thumb/vertical.png?1645082931" + }, + { + "chainId": 1, + "address": "0x9355372396e3f6daf13359b7b607a3374cc638e0", + "name": "WHALE", + "symbol": "WHALE", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/11797/thumb/WHALE.png?1595004706" + }, + { + "chainId": 1, + "address": "0x8c088775e4139af116ac1fa6f281bbf71e8c1c73", + "name": "PUMLx", + "symbol": "PUMLX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27253/thumb/pumlx.png?1665154140" + }, + { + "chainId": 1, + "address": "0xbd1848e1491d4308ad18287a745dd4db2a4bd55b", + "name": "Mochi Market", + "symbol": "MOMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14993/thumb/mochi.PNG?1619390399" + }, + { + "chainId": 1, + "address": "0xf5581dfefd8fb0e4aec526be659cfab1f8c781da", + "name": "HOPR", + "symbol": "HOPR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14061/thumb/Shared_HOPR_logo_512px.png?1614073468" + }, + { + "chainId": 1, + "address": "0xa806b3fed6891136940cf81c4085661500aa2709", + "name": "Sport and Leisure", + "symbol": "SNL", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/7762/thumb/745ba052-73b7-4735-a0bf-e75474def055.png?1550456328" + }, + { + "chainId": 1, + "address": "0x3d6f0dea3ac3c607b3998e6ce14b6350721752d9", + "name": "Cardstarter", + "symbol": "CARDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14612/thumb/CARDSx200.png?1617252006" + }, + { + "chainId": 1, + "address": "0xe4815ae53b124e7263f08dcdbbb757d41ed658c6", + "name": "ZKSpace", + "symbol": "ZKS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13585/thumb/zkspace_logo.png?1644486208" + }, + { + "chainId": 1, + "address": "0xf418588522d5dd018b425e472991e52ebbeeeeee", + "name": "Push Protocol", + "symbol": "PUSH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14769/thumb/aiOxYOJI_400x400.jpeg?1664499790" + }, + { + "chainId": 1, + "address": "0xfb130d93e49dca13264344966a611dc79a456bc5", + "name": "DogeGF", + "symbol": "DOGEGF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18651/thumb/dogf.png?1632758659" + }, + { + "chainId": 1, + "address": "0x41d5d79431a913c4ae7d69a668ecdfe5ff9dfb68", + "name": "Inverse Finance", + "symbol": "INV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14205/thumb/inverse_finance.jpg?1614921871" + }, + { + "chainId": 1, + "address": "0x5e3346444010135322268a4630d2ed5f8d09446c", + "name": "LockTrip", + "symbol": "LOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1357/thumb/LOC_Transparent_New.png?1579491094" + }, + { + "chainId": 1, + "address": "0xf34b1db61aca1a371fe97bad2606c9f534fb9d7d", + "name": "ArbiSmart", + "symbol": "RBIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21906/thumb/imgonline-com-ua-Resize-cMjOYOwg12bLazt.png?1640235509" + }, + { + "chainId": 1, + "address": "0xc4c2614e694cf534d407ee49f8e44d125e4681c4", + "name": "Chain Games", + "symbol": "CHAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12257/thumb/chain-logo-centered-500x500.png?1599617244" + }, + { + "chainId": 1, + "address": "0xd084b83c305dafd76ae3e1b4e1f1fe2ecccb3988", + "name": "The Virtua Kolect", + "symbol": "TVK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13330/thumb/virtua_original.png?1656043619" + }, + { + "chainId": 1, + "address": "0x8fac8031e079f409135766c7d5de29cf22ef897c", + "name": "Humans ai", + "symbol": "HEART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21273/thumb/h_logo_1x.png?1638858402" + }, + { + "chainId": 1, + "address": "0x675bbc7514013e2073db7a919f6e4cbef576de37", + "name": "Coldstack", + "symbol": "CLS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15499/thumb/logo_200x200.png?1621072403" + }, + { + "chainId": 1, + "address": "0x5ba19d656b65f1684cfea4af428c23b9f3628f97", + "name": "AAG", + "symbol": "AAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21382/thumb/aag-token-icon.png?1661849633" + }, + { + "chainId": 1, + "address": "0x3a8cccb969a61532d1e6005e2ce12c200caece87", + "name": "TitanSwap", + "symbol": "TITAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12606/thumb/nqGlQzdz_400x400.png?1601019805" + }, + { + "chainId": 1, + "address": "0x450e7f6e3a2f247a51b98c39297a9a5bfbdb3170", + "name": "Elon GOAT", + "symbol": "EGT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22301/thumb/ElonGoat.jpg?1641438513" + }, + { + "chainId": 1, + "address": "0x27054b13b1b798b345b591a4d22e6562d47ea75a", + "name": "AirSwap", + "symbol": "AST", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/1019/thumb/Airswap.png?1630903484" + }, + { + "chainId": 1, + "address": "0xba5bde662c17e2adff1075610382b9b691296350", + "name": "SuperRare", + "symbol": "RARE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17753/thumb/RARE.jpg?1629220534" + }, + { + "chainId": 1, + "address": "0xf293d23bf2cdc05411ca0eddd588eb1977e8dcd4", + "name": "Sylo", + "symbol": "SYLO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6430/thumb/SYLO.svg?1589527756" + }, + { + "chainId": 1, + "address": "0x9c2dc0c3cc2badde84b0025cf4df1c5af288d835", + "name": "Coreto", + "symbol": "COR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12856/thumb/COR.png?1620210966" + }, + { + "chainId": 1, + "address": "0x5c8c8d560048f34e5f7f8ad71f2f81a89dbd273e", + "name": "CryptoArt Ai", + "symbol": "CART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17583/thumb/logo-64.png?1629277823" + }, + { + "chainId": 1, + "address": "0xb17c88bda07d28b3838e0c1de6a30eafbcf52d85", + "name": "Shyft Network", + "symbol": "SHFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14534/thumb/TOKEN-Gradient.png?1616768352" + }, + { + "chainId": 1, + "address": "0xd13cfd3133239a3c73a9e535a5c4dadee36b395c", + "name": "Vaiot", + "symbol": "VAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13981/thumb/VAIOT_logo.png?1613456546" + }, + { + "chainId": 1, + "address": "0x5ca9a71b1d01849c0a95490cc00559717fcf0d1d", + "name": "Aeternity", + "symbol": "AE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1091/thumb/aeternity.png?1547035060" + }, + { + "chainId": 1, + "address": "0xae1eaae3f627aaca434127644371b67b18444051", + "name": "Yield Optimization Platform Protocol", + "symbol": "YOP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13678/thumb/J7zykPx.jpg?1610802162" + }, + { + "chainId": 1, + "address": "0x7eaf9c89037e4814dc0d9952ac7f888c784548db", + "name": "Royale", + "symbol": "ROYA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13602/thumb/roya.png?1636031771" + }, + { + "chainId": 1, + "address": "0xeb953eda0dc65e3246f43dc8fa13f35623bdd5ed", + "name": "Rainicorn", + "symbol": "RAINI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14491/thumb/logo-200x200.png?1633314246" + }, + { + "chainId": 1, + "address": "0x89a64014d429509cffda1aebc7eb36b9435794bd", + "name": "LULZ", + "symbol": "LULZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17439/thumb/qHQiwr1I_400x400.jpg?1629882056" + }, + { + "chainId": 1, + "address": "0xfc979087305a826c2b2a0056cfaba50aad3e6439", + "name": "Dafi Protocol", + "symbol": "DAFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14428/thumb/Dafi_Black_Icon.png?1616040406" + }, + { + "chainId": 1, + "address": "0x725c263e32c72ddc3a19bea12c5a0479a81ee688", + "name": "Bridge Mutual", + "symbol": "BMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13808/thumb/bmi_logo.png?1612009598" + }, + { + "chainId": 1, + "address": "0xe6fd75ff38adca4b97fbcd938c86b98772431867", + "name": "Elastos", + "symbol": "ELA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2780/thumb/Elastos.png?1597048112" + }, + { + "chainId": 1, + "address": "0x91dfbee3965baaee32784c2d546b7a0c62f268c9", + "name": "Forj", + "symbol": "BONDLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13322/thumb/FORJ_twitter_twitter-linked_in_profile_%281%29.png?1653026729" + }, + { + "chainId": 1, + "address": "0xd291e7a03283640fdc51b121ac401383a46cc623", + "name": "Rari Governance", + "symbol": "RGT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12900/thumb/Rari_Logo_Transparent.png?1613978014" + }, + { + "chainId": 1, + "address": "0x618e75ac90b12c6049ba3b27f5d5f8651b0037f6", + "name": "QASH", + "symbol": "QASH", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/1220/thumb/qash.jpeg?1547035247" + }, + { + "chainId": 1, + "address": "0x5f474906637bdcda05f29c74653f6962bb0f8eda", + "name": "DeFinity", + "symbol": "DEFX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15875/thumb/definity-listing-logo.png?1622414896" + }, + { + "chainId": 1, + "address": "0x8a3d77e9d6968b780564936d15b09805827c21fa", + "name": "Archethic", + "symbol": "UCO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12330/thumb/Archethic_logo.png?1665916980" + }, + { + "chainId": 1, + "address": "0x1337def16f9b486faed0293eb623dc8395dfe46a", + "name": "ARMOR", + "symbol": "ARMOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13748/thumb/armor.png?1611425846" + }, + { + "chainId": 1, + "address": "0x221657776846890989a759ba2973e427dff5c9bb", + "name": "Augur", + "symbol": "REP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/309/thumb/REP.png?1596339859" + }, + { + "chainId": 1, + "address": "0x52662717e448be36cb54588499d5a8328bd95292", + "name": "Tenshi", + "symbol": "TENSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17170/thumb/TENSHI.png?1628739569" + }, + { + "chainId": 1, + "address": "0x3f382dbd960e3a9bbceae22651e88158d2791550", + "name": "Aavegotchi", + "symbol": "GHST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12467/thumb/ghst_200.png?1600750321" + }, + { + "chainId": 1, + "address": "0xcc4304a31d09258b0029ea7fe63d032f52e44efe", + "name": "Trustswap", + "symbol": "SWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11795/thumb/Untitled_design-removebg-preview.png?1626926355" + }, + { + "chainId": 1, + "address": "0x3a880652f47bfaa771908c07dd8673a787daed3a", + "name": "DerivaDAO", + "symbol": "DDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13453/thumb/ddx_logo.png?1608741641" + }, + { + "chainId": 1, + "address": "0x536381a8628dbcc8c70ac9a30a7258442eab4c92", + "name": "Pantos", + "symbol": "PAN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/9639/thumb/Pantos-logo-compact.png?1619079883" + }, + { + "chainId": 1, + "address": "0xaa7fb1c8ce6f18d4fd4aabb61a2193d4d441c54f", + "name": "ShitCoin", + "symbol": "SHIT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/9472/thumb/ShitCoin_200x200.png?1567723695" + }, + { + "chainId": 1, + "address": "0xe529b502fec3ff0ea86fe63da505ec62fdf4f387", + "name": "Three Kingdoms", + "symbol": "RTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25987/thumb/un_8XpAR_400x400.jpg?1655178518" + }, + { + "chainId": 1, + "address": "0x49bf0220c9ce17e52dcca3d217231746d676085b", + "name": "Vixco", + "symbol": "VIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15405/thumb/vixco.png?1620811916" + }, + { + "chainId": 1, + "address": "0x445d711c8974d80643745a4666803d255a589390", + "name": "BoredMemes", + "symbol": "BOREDM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27934/thumb/pIhAX2u-_400x400.png?1666509284" + }, + { + "chainId": 1, + "address": "0x0de05f6447ab4d22c8827449ee4ba2d5c288379b", + "name": "Ooki", + "symbol": "OOKI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21719/thumb/Ooki_Token.png?1669772543" + }, + { + "chainId": 1, + "address": "0x30f271c9e86d2b7d00a6376cd96a1cfbd5f0b9b3", + "name": "Decentr", + "symbol": "DEC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11816/thumb/Decentr.png?1594637985" + }, + { + "chainId": 1, + "address": "0xc55c2175e90a46602fd42e931f62b3acc1a013ca", + "name": "Mogul Productions", + "symbol": "STARS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14975/thumb/STARS_LOGO_PNG.png?1619214520" + }, + { + "chainId": 1, + "address": "0x1614f18fc94f47967a3fbe5ffcd46d4e7da3d787", + "name": "PAID Network", + "symbol": "PAID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13761/thumb/512.png?1648630881" + }, + { + "chainId": 1, + "address": "0xd433138d12beb9929ff6fd583dc83663eea6aaa5", + "name": "Bitrue Coin", + "symbol": "BTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8873/thumb/Bittrue_logo.png?1637142758" + }, + { + "chainId": 1, + "address": "0x4e0df4560cedfda5d793f607cefa30383bda7327", + "name": "Qatar Inu Token", + "symbol": "QATAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27894/thumb/2022-10-18_20.39.03.jpg?1666254735" + }, + { + "chainId": 1, + "address": "0x446c9033e7516d820cc9a2ce2d0b7328b579406f", + "name": "SOLVE", + "symbol": "SOLVE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/1768/thumb/Solve.Token_logo_200_200_wiyhout_BG.png?1575869846" + }, + { + "chainId": 1, + "address": "0xebf2096e01455108badcbaf86ce30b6e5a72aa52", + "name": "XIDR", + "symbol": "XIDR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21126/thumb/XIDR_Logo_256_X_256.png?1638343133" + }, + { + "chainId": 1, + "address": "0x9eb6be354d88fd88795a04de899a57a77c545590", + "name": "GameStop Finance", + "symbol": "GME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13820/thumb/gamestop_logo.jpg?1612070725" + }, + { + "chainId": 1, + "address": "0xaa2ce7ae64066175e0b90497ce7d9c190c315db4", + "name": "Suterusu", + "symbol": "SUTER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9830/thumb/p-NFlBlw_400x400.jpg?1572472860" + }, + { + "chainId": 1, + "address": "0x85f6eb2bd5a062f5f8560be93fb7147e16c81472", + "name": "Franklin", + "symbol": "FLY", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/14810/thumb/fly_logo_sq_bArtboard_4.png?1626420796" + }, + { + "chainId": 1, + "address": "0x6dca182ac5e3f99985bc4ee0f726d6472ab1ec55", + "name": "Ushi", + "symbol": "USHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27865/thumb/photo_2022-10-17_22-21-01.jpg?1666151494" + }, + { + "chainId": 1, + "address": "0xb705268213d593b8fd88d3fdeff93aff5cbdcfae", + "name": "IDEX", + "symbol": "IDEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2565/thumb/logomark-purple-286x286.png?1638362736" + }, + { + "chainId": 1, + "address": "0x32353a6c91143bfd6c7d363b546e62a9a2489a20", + "name": "Adventure Gold", + "symbol": "AGLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18125/thumb/lpgblc4h_400x400.jpg?1630570955" + }, + { + "chainId": 1, + "address": "0xbf2179859fc6d5bee9bf9158632dc51678a4100e", + "name": "aelf", + "symbol": "ELF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1371/thumb/aelf-logo.png?1547035397" + }, + { + "chainId": 1, + "address": "0x7c84e62859d0715eb77d1b1c4154ecd6abb21bec", + "name": "Shping", + "symbol": "SHPING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2588/thumb/000103_Shping_Logos_Shping_Secondary_Logo.png?1661141481" + }, + { + "chainId": 1, + "address": "0x09a3ecafa817268f77be1283176b946c4ff2e608", + "name": "Mirror Protocol", + "symbol": "MIR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13295/thumb/mirror_logo_transparent.png?1611554658" + }, + { + "chainId": 1, + "address": "0x236d53148f83706c3d670064809577385f923a75", + "name": "Siberian Husky", + "symbol": "SHUSKY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16711/thumb/shusky.png?1624782891" + }, + { + "chainId": 1, + "address": "0x40a11f82a8469c8dc015ba74438536584978d63c", + "name": "Galileo", + "symbol": "GALI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28007/thumb/gali.jpg?1666939897" + }, + { + "chainId": 1, + "address": "0x7f969c4d388ca0ae39a4fddb1a6f89878ca2fbf8", + "name": "Global Game Coin", + "symbol": "GGC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10301/thumb/ggcoin_200.png?1577690908" + }, + { + "chainId": 1, + "address": "0x557b933a7c2c45672b610f8954a3deb39a51a8ca", + "name": "REVV", + "symbol": "REVV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12373/thumb/REVV_TOKEN_Refined_2021_%281%29.png?1627652390" + }, + { + "chainId": 1, + "address": "0x72dd4b6bd852a3aa172be4d6c5a6dbec588cf131", + "name": "NAGA", + "symbol": "NGC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1439/thumb/naga.jpg?1547035515" + }, + { + "chainId": 1, + "address": "0x3c03b4ec9477809072ff9cc9292c9b25d4a8e6c6", + "name": "CoverCompared", + "symbol": "CVR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13720/thumb/cvr.png?1635416411" + }, + { + "chainId": 1, + "address": "0xf433089366899d83a9f26a773d59ec7ecf30355e", + "name": "Metal DAO", + "symbol": "MTL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/763/thumb/Metal.png?1592195010" + }, + { + "chainId": 1, + "address": "0x77fba179c79de5b7653f68b5039af940ada60ce0", + "name": "Ampleforth Governance", + "symbol": "FORTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14917/thumb/photo_2021-04-22_00.00.03.jpeg?1619020835" + }, + { + "chainId": 1, + "address": "0x64df3aab3b21cc275bb76c4a581cf8b726478ee0", + "name": "Cramer Coin", + "symbol": "CRAMER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27463/thumb/cramercoin.jpg?1664176668" + }, + { + "chainId": 1, + "address": "0x20a8cec5fffea65be7122bcab2ffe32ed4ebf03a", + "name": "DinoX", + "symbol": "DNXC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17321/thumb/asset_icon_dnxc_200.png?1627292452" + }, + { + "chainId": 1, + "address": "0x1c48f86ae57291f7686349f12601910bd8d470bb", + "name": "USDK", + "symbol": "USDK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8824/thumb/usdk.png?1563418517" + }, + { + "chainId": 1, + "address": "0xec5483804e637d45cde22fa0869656b64b5ab1ab", + "name": "Acent", + "symbol": "ACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15211/thumb/acent-logo.png?1620108963" + }, + { + "chainId": 1, + "address": "0x2e9d63788249371f1dfc918a52f8d799f4a38c94", + "name": "Tokemak", + "symbol": "TOKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17495/thumb/tokemak-avatar-200px-black.png?1628131614" + }, + { + "chainId": 1, + "address": "0x27702a26126e0b3702af63ee09ac4d1a084ef628", + "name": "Aleph im", + "symbol": "ALEPH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11676/thumb/Monochram-aleph.png?1608483725" + }, + { + "chainId": 1, + "address": "0x88a9a52f944315d5b4e917b9689e65445c401e83", + "name": "FEAR", + "symbol": "FEAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15825/thumb/fear-logo-400-400.png?1625552865" + }, + { + "chainId": 1, + "address": "0x3d3d35bb9bec23b06ca00fe472b50e7a4c692c30", + "name": "Vidya", + "symbol": "VIDYA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12219/thumb/VIDYA_TOKEN.png?1598240425" + }, + { + "chainId": 1, + "address": "0x8f693ca8d21b157107184d29d398a8d082b38b76", + "name": "Streamr", + "symbol": "DATA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17869/thumb/DATA_new_symbol_3x.png?1629692324" + }, + { + "chainId": 1, + "address": "0x70d2b7c19352bb76e4409858ff5746e500f2b67c", + "name": "Pawtocol", + "symbol": "UPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12186/thumb/pawtocol.jpg?1597962008" + }, + { + "chainId": 1, + "address": "0xaaca86b876ca011844b5798eca7a67591a9743c8", + "name": "0x nodes", + "symbol": "BIOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15600/thumb/BIOS_01.png?1621737736" + }, + { + "chainId": 1, + "address": "0x8f8221afbb33998d8584a2b05749ba73c37a938a", + "name": "Request", + "symbol": "REQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1031/thumb/Request_icon_green.png?1643250951" + }, + { + "chainId": 1, + "address": "0xdbdd6f355a37b94e6c7d32fef548e98a280b8df5", + "name": "UniWhales", + "symbol": "UWL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13166/thumb/uniwhale.png?1611967645" + }, + { + "chainId": 1, + "address": "0x083dfb3566bde80380446718eeda55b800464636", + "name": "AllStars", + "symbol": "ASX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27492/thumb/asx.png?1667044777" + }, + { + "chainId": 1, + "address": "0x269616d549d7e8eaa82dfb17028d0b212d11232a", + "name": "Punk Vault NFTX ", + "symbol": "PUNK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17018/thumb/Punk.png?1626086346" + }, + { + "chainId": 1, + "address": "0x87d73e916d7057945c9bcd8cdd94e42a6f47f776", + "name": "NFTX", + "symbol": "NFTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13574/thumb/NFTX_%28Real%29.jpg?1613449530" + }, + { + "chainId": 1, + "address": "0xc7a8b45e184138114e6085c82936a8db93dd156a", + "name": "MASK Vault NFTX ", + "symbol": "MASK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17046/thumb/Hashie.png?1626147674" + }, + { + "chainId": 1, + "address": "0x4bd70556ae3f8a6ec6c4080a0c327b24325438f3", + "name": "Hxro", + "symbol": "HXRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7805/thumb/Hxro_Profile_Transparent.png?1622443308" + }, + { + "chainId": 1, + "address": "0xdd974d5c2e2928dea5f71b9825b8b646686bd200", + "name": "Kyber Network Crystal Legacy", + "symbol": "KNCL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/947/thumb/logo-kncl.png?1618984814" + }, + { + "chainId": 1, + "address": "0x2f141ce366a2462f02cea3d12cf93e4dca49e4fd", + "name": "FREEdom coin", + "symbol": "FREE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5585/thumb/free.png?1639547764" + }, + { + "chainId": 1, + "address": "0x0391d2021f89dc339f60fff84546ea23e337750f", + "name": "BarnBridge", + "symbol": "BOND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12811/thumb/barnbridge.jpg?1602728853" + }, + { + "chainId": 1, + "address": "0xfa5047c9c78b8877af97bdcb85db743fd7313d4a", + "name": "Rook", + "symbol": "ROOK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13005/thumb/keeper_dao_logo.jpg?1604316506" + }, + { + "chainId": 1, + "address": "0xdf96bde075d59e9143b325c75af38e208c986e6f", + "name": "YetiCoin", + "symbol": "YETIC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20493/thumb/yetic.png?1647695460" + }, + { + "chainId": 1, + "address": "0x67b6d479c7bb412c54e03dca8e1bc6740ce6b99c", + "name": "Kylin Network", + "symbol": "KYL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14164/thumb/kyl_logo.jpg?1647507720" + }, + { + "chainId": 1, + "address": "0x0acc0fee1d86d2cd5af372615bf59b298d50cd69", + "name": "Invest Like Stakeborg Index", + "symbol": "ILSI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21788/thumb/16292.png?1640048590" + }, + { + "chainId": 1, + "address": "0xa1d6df714f91debf4e0802a542e13067f31b8262", + "name": "RFOX", + "symbol": "RFOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12956/thumb/rfox.png?1642926902" + }, + { + "chainId": 1, + "address": "0x1494ca1f11d487c2bbe4543e90080aeba4ba3c2b", + "name": "DeFi Pulse Index", + "symbol": "DPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12465/thumb/defi_pulse_index_set.png?1600051053" + }, + { + "chainId": 1, + "address": "0x71fc1f555a39e0b698653ab0b475488ec3c34d57", + "name": "Rainmaker Games", + "symbol": "RAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21485/thumb/Final-Flip-Rain-Makers-44-1.png?1639362827" + }, + { + "chainId": 1, + "address": "0xa52bffad02b1fe3f86a543a4e81962d3b3bb01a7", + "name": "Duckereum", + "symbol": "DUCKER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26325/thumb/coin.png?1669981187" + }, + { + "chainId": 1, + "address": "0xbc6e06778708177a18210181b073da747c88490a", + "name": "MOBLAND", + "symbol": "SYNR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22868/thumb/FullML_Yellow_200px.png?1648031600" + }, + { + "chainId": 1, + "address": "0x88df592f8eb5d7bd38bfef7deb0fbc02cf3778a0", + "name": "Tellor", + "symbol": "TRB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9644/thumb/Blk_icon_current.png?1584980686" + }, + { + "chainId": 1, + "address": "0x76c5449f4950f6338a393f53cda8b53b0cd3ca3a", + "name": "BT Finance", + "symbol": "BT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13824/thumb/BT-logo.324f553c.png?1612152632" + }, + { + "chainId": 1, + "address": "0x3cbb7f5d7499af626026e96a2f05df806f2200dc", + "name": "PandaDAO", + "symbol": "PANDA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24926/thumb/PandaDAO_logo_512.png?1649388983" + }, + { + "chainId": 1, + "address": "0xeeeeeeeee2af8d0e1940679860398308e0ef24d6", + "name": "Ethverse", + "symbol": "ETHV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12076/thumb/logo_%2888%29.png?1596751504" + }, + { + "chainId": 1, + "address": "0xc25a3a3b969415c80451098fa907ec722572917f", + "name": "LP sCurve", + "symbol": "SCURVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11899/thumb/Curvefi_sCrv_32.png?1595931870" + }, + { + "chainId": 1, + "address": "0x362bc847a3a9637d3af6624eec853618a43ed7d2", + "name": "PARSIQ", + "symbol": "PRQ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11973/thumb/DsNgK0O.png?1596590280" + }, + { + "chainId": 1, + "address": "0x11eef04c884e24d9b7b4760e7476d06ddf797f36", + "name": "MX", + "symbol": "MX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8545/thumb/MEXC_GLOBAL_LOGO.jpeg?1670213280" + }, + { + "chainId": 1, + "address": "0x2b89bf8ba858cd2fcee1fada378d5cd6936968be", + "name": "Secret ERC20 ", + "symbol": "WSCRT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13767/thumb/Secret_S_Black_Coingecko.png?1611667298" + }, + { + "chainId": 1, + "address": "0xb1cd6e4153b2a390cf00a6556b0fc1458c4a5533", + "name": "ETHBNT Relay", + "symbol": "ETHBNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10664/thumb/ETHBNT_Relay.png?1581486882" + }, + { + "chainId": 1, + "address": "0x47252a63c723889814aebcac0683e615624cec64", + "name": "Nil DAO", + "symbol": "NIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19667/thumb/_AoPtxGt_400x400.jpg?1635737598" + }, + { + "chainId": 1, + "address": "0x418d75f65a02b3d53b2418fb8e1fe493759c7605", + "name": "Binance Coin Wormhole ", + "symbol": "BNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22884/thumb/BNB_wh_small.png?1644224553" + }, + { + "chainId": 1, + "address": "0x0000000000085d4780b73119b644ae5ecd22b376", + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3449/thumb/tusd.png?1618395665" + }, + { + "chainId": 1, + "address": "0x40a9d39aa50871df092538c5999b107f34409061", + "name": "Instadapp DAI", + "symbol": "IDAI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25821/thumb/iDAI_100x100.png?1654055549" + }, + { + "chainId": 1, + "address": "0x734c90044a0ba31b3f2e640c10dc5d3540499bfd", + "name": "TradeStars", + "symbol": "TSX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15229/thumb/WsO9siKG_400x400.png?1620167669" + }, + { + "chainId": 1, + "address": "0x909e34d3f6124c324ac83dcca84b74398a6fa173", + "name": "Panther Protocol", + "symbol": "ZKP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18611/thumb/panther.jpg?1670986454" + }, + { + "chainId": 1, + "address": "0x1abaea1f7c830bd89acc67ec4af516284b1bc33c", + "name": "Euro Coin", + "symbol": "EUROC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/26045/thumb/euro-coin.png?1655394420" + }, + { + "chainId": 1, + "address": "0xd71ecff9342a5ced620049e616c5035f1db98620", + "name": "sEUR", + "symbol": "SEUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13637/thumb/sEUR.png?1610609277" + }, + { + "chainId": 1, + "address": "0x5eeaa2dcb23056f4e8654a349e57ebe5e76b5e6e", + "name": "Virtue Poker Points", + "symbol": "VPP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3386/thumb/vp-logo-200x200.png?1622068750" + }, + { + "chainId": 1, + "address": "0xc4f6e93aeddc11dc22268488465babcaf09399ac", + "name": "hi Dollar", + "symbol": "HI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17618/thumb/unnamed_%281%29.png?1628665739" + }, + { + "chainId": 1, + "address": "0xd9fcd98c322942075a5c3860693e9f4f03aae07b", + "name": "Euler", + "symbol": "EUL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26149/thumb/YCvKDfl8_400x400.jpeg?1656041509" + }, + { + "chainId": 1, + "address": "0x7cca2e1c9b0519f52029467914a15e782bf66971", + "name": "Captain Inu", + "symbol": "CPTINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21600/thumb/200x200-transparent-logo.png?1639548692" + }, + { + "chainId": 1, + "address": "0x431ad2ff6a9c365805ebad47ee021148d6f7dbe0", + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9709/thumb/xlGxxIjI_400x400.jpg?1571006794" + }, + { + "chainId": 1, + "address": "0x2620638eda99f9e7e902ea24a285456ee9438861", + "name": "Crust Shadow", + "symbol": "CSM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16037/thumb/2_mnCYZfHmLg2bFrjM3vKtPw.png?1622680217" + }, + { + "chainId": 1, + "address": "0x3301ee63fb29f863f2333bd4466acb46cd8323e6", + "name": "Akita Inu", + "symbol": "AKITA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14115/thumb/akita.png?1661666578" + }, + { + "chainId": 1, + "address": "0x7e794ed35788b698ae60cefc98ee48015c4876da", + "name": "Shintama", + "symbol": "SHINTAMA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23405/thumb/shintama.png?1644145782" + }, + { + "chainId": 1, + "address": "0xd4c64f0fe38ecdaf0baefd7859e18185a73b9aa3", + "name": "Uzumaki Inu", + "symbol": "UZUMAKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18585/thumb/XjTLLU9c_400x400.jpg?1637157360" + }, + { + "chainId": 1, + "address": "0xee6b9cf11d968e0bac7bfff547577b8ae35b8065", + "name": "Meme Kong", + "symbol": "MKONG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23448/thumb/ssynFLdjk2SIPSop_i8_8tCRn4rnV9hILMl8AnIFx3DtMIHRVoQ48QHOoqYwGuW9DSbZSJWoaPM0NEypRmrU3ZSXf_ZC16p3YBdT7mbP5vhnGyZMDvVoYm8GwKMYgvEeS9kzqlrNZ3bPWFasbdZD3TKh37BvLgUQiDchz5NiAVpUtrew5Frmox4CoEu_TOSvAV_OvG6A2RYeudy0bY0LUCfuU2.jpg?1644213902" + }, + { + "chainId": 1, + "address": "0x7a58c0be72be218b41c608b7fe7c5bb630736c71", + "name": "ConstitutionDAO", + "symbol": "PEOPLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20612/thumb/GN_UVm3d_400x400.jpg?1637294355" + }, + { + "chainId": 1, + "address": "0x8db1d28ee0d822367af8d220c0dc7cb6fe9dc442", + "name": "ETHPad", + "symbol": "ETHPAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17520/thumb/tHAbIBQK_400x400.jpg?1628075612" + }, + { + "chainId": 1, + "address": "0x1a2933fba0c6e959c9a2d2c933f3f8ad4aa9f06e", + "name": "PARMA", + "symbol": "PARMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23847/thumb/200_%281%29.png?1645519586" + }, + { + "chainId": 1, + "address": "0xd478161c952357f05f0292b56012cd8457f1cfbf", + "name": "Polkamarkets", + "symbol": "POLK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14084/thumb/polkamarkets.jpg?1614179979" + }, + { + "chainId": 1, + "address": "0x08d32b0da63e2c3bcf8019c9c5d849d7a9d791e6", + "name": "Dentacoin", + "symbol": "DCN", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/850/thumb/dentacoin.png?1547034647" + }, + { + "chainId": 1, + "address": "0x64a60493d888728cf42616e034a0dfeae38efcf0", + "name": "OneLedger", + "symbol": "OLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3422/thumb/One_Ledger.jpeg?1547038108" + }, + { + "chainId": 1, + "address": "0x295b42684f90c77da7ea46336001010f2791ec8c", + "name": "Xi", + "symbol": "XI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18640/thumb/v5NMxPo.png?1632751046" + }, + { + "chainId": 1, + "address": "0xb3ad645db386d7f6d753b2b9c3f4b853da6890b8", + "name": "Concentrator", + "symbol": "CTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26364/thumb/%E6%9C%AA%E5%91%BD%E5%90%8D%E7%9A%84%E8%AE%BE%E8%AE%A1.jpg?1657596066" + }, + { + "chainId": 1, + "address": "0x16cda4028e9e872a38acb903176719299beaed87", + "name": "MARS4", + "symbol": "MARS4", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18709/thumb/mars4_logo.jpg?1633070237" + }, + { + "chainId": 1, + "address": "0x1796ae0b0fa4862485106a0de9b654efe301d0b2", + "name": "Polychain Monsters", + "symbol": "PMON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14604/thumb/polkamon.png?1617238350" + }, + { + "chainId": 1, + "address": "0xe0ad1806fd3e7edf6ff52fdb822432e847411033", + "name": "OnX Finance", + "symbol": "ONX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13445/thumb/onxlogo-1.png?1608629659" + }, + { + "chainId": 1, + "address": "0x1fe24f25b1cf609b9c4e7e12d802e3640dfa5e43", + "name": "Chain Guardians", + "symbol": "CGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14326/thumb/cgg_logo.png?1615429976" + }, + { + "chainId": 1, + "address": "0xa3c56427683a19f7574b9fc219cfd27d5d6e87fa", + "name": "Saitoki Inu", + "symbol": "SAITOKI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23586/thumb/saitoki_200.png?1667467076" + }, + { + "chainId": 1, + "address": "0x005d1123878fc55fbd56b54c73963b234a64af3c", + "name": "Kiba Inu", + "symbol": "KIBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19525/thumb/kiba.png?1648549322" + }, + { + "chainId": 1, + "address": "0x3218a02f8f8b5c3894ce30eb255f10bcba13e654", + "name": "MegaCryptoPolis", + "symbol": "MEGA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12971/thumb/mcp_icon_200.png?1603943441" + }, + { + "chainId": 1, + "address": "0xead482da0793b00bbae0e34c8cfae6daf29a44b2", + "name": "Versailles Heroes", + "symbol": "VRH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27860/thumb/VRH___200-200.png?1667467208" + }, + { + "chainId": 1, + "address": "0xa59e341e8047498700ed244814b01b34547fb21b", + "name": "Medal of Honour", + "symbol": "MOH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27861/thumb/MOH___200-200.png?1667467198" + }, + { + "chainId": 1, + "address": "0x88acdd2a6425c3faae4bc9650fd7e27e0bebb7ab", + "name": "Alchemist", + "symbol": "MIST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14655/thumb/79158662.png?1617589045" + }, + { + "chainId": 1, + "address": "0xe1747a23c44f445062078e3c528c9f4c28c50a51", + "name": "Eterna Hybrid Exchange", + "symbol": "EHX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24825/thumb/_0VJF4cs_400x400.jpg?1649042250" + }, + { + "chainId": 1, + "address": "0xf001937650bb4f62b57521824b2c20f5b91bea05", + "name": "Taraxa", + "symbol": "TARA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4372/thumb/CPuCDZX.jpg?1616391360" + }, + { + "chainId": 1, + "address": "0x72e364f2abdc788b7e918bc238b21f109cd634d7", + "name": "Metaverse Index", + "symbol": "MVI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14684/thumb/MVI_logo.png?1617776444" + }, + { + "chainId": 1, + "address": "0x84cffa78b2fbbeec8c37391d2b12a04d2030845e", + "name": "Digital Fitness", + "symbol": "DEFIT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14699/thumb/Defit.png?1623738365" + }, + { + "chainId": 1, + "address": "0xcd7492db29e2ab436e819b249452ee1bbdf52214", + "name": "SafeMoon Inu", + "symbol": "SMI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/16091/thumb/SMI.png?1622801787" + }, + { + "chainId": 1, + "address": "0x75858677e27c930fb622759feaffee2b754af07f", + "name": "Phantasma", + "symbol": "SOUL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4130/thumb/phantasma.png?1548331035" + }, + { + "chainId": 1, + "address": "0x9695e0114e12c0d3a3636fab5a18e6b737529023", + "name": "Dfyn Network", + "symbol": "DFYN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15368/thumb/SgqhfWz4_400x400_%281%29.jpg?1620666919" + }, + { + "chainId": 1, + "address": "0xd6929179d752d5d25c5efe2d9729eb77d7138a80", + "name": "Goons of Balatroon", + "symbol": "GOB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27104/thumb/q1_hZykF_400x400.jpeg?1662006909" + }, + { + "chainId": 1, + "address": "0xa1b26b9918b350e9657d9ab43a45088805d65e4e", + "name": "Kings Coin", + "symbol": "KINGS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27643/thumb/photo_2022-10-05_10.01.29.jpeg?1665019588" + }, + { + "chainId": 1, + "address": "0x5a666c7d92e5fa7edcb6390e4efd6d0cdd69cf37", + "name": "Unmarshal", + "symbol": "MARSH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14554/thumb/img_circle_256x256.png?1616997706" + }, + { + "chainId": 1, + "address": "0x4575f41308ec1483f3d399aa9a2826d74da13deb", + "name": "Orchid Protocol", + "symbol": "OXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3916/thumb/download_%285%29.png?1576624060" + }, + { + "chainId": 1, + "address": "0x2e85ae1c47602f7927bcabc2ff99c40aa222ae15", + "name": "Katana Inu", + "symbol": "KATA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21872/thumb/Katana_Inu512.png?1640236880" + }, + { + "chainId": 1, + "address": "0x6368e1e18c4c419ddfc608a0bed1ccb87b9250fc", + "name": "Tap", + "symbol": "XTP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10291/thumb/0_3SJYkk_400x400.jpg?1577229220" + }, + { + "chainId": 1, + "address": "0xefab7248d36585e2340e5d25f8a8d243e6e3193f", + "name": "Dacxi", + "symbol": "DACXI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4466/thumb/dacxi.png?1639042471" + }, + { + "chainId": 1, + "address": "0x30d20208d987713f46dfd34ef128bb16c404d10f", + "name": "Stader", + "symbol": "SD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20658/thumb/sd.png?1642927667" + }, + { + "chainId": 1, + "address": "0x84d821f7fbdd595c4c4a50842913e6b1e07d7a53", + "name": "BNPL Pay", + "symbol": "BNPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18543/thumb/Untitled_%28200_%C3%97_200_px%29_%281%29.png?1667541672" + }, + { + "chainId": 1, + "address": "0xffbf315f70e458e49229654dea4ce192d26f9b25", + "name": "Voltage", + "symbol": "VOLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18515/thumb/volt.png?1632219924" + }, + { + "chainId": 1, + "address": "0xaa9d866666c2a3748d6b23ff69e63e52f08d9ab4", + "name": "Fundamenta", + "symbol": "FMTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12983/thumb/fundamenta.png?1604065939" + }, + { + "chainId": 1, + "address": "0x0000000000004946c0e9f43f4dee607b0ef1fa1c", + "name": "Chi Gas", + "symbol": "CHI", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/11583/thumb/chi.png?1591331659" + }, + { + "chainId": 1, + "address": "0xe95a203b1a91a908f9b9ce46459d101078c2c3cb", + "name": "Ankr Reward Bearing Staked ETH", + "symbol": "AETHC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13403/thumb/aETHc.png?1625756490" + }, + { + "chainId": 1, + "address": "0x06fcbf38e823efc1e609b9491aab546334c6ee69", + "name": "Stilton Musk OLD ", + "symbol": "STILTON", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/23572/thumb/2022-02-09_11.32.27-removebg-preview.png?1644475684" + }, + { + "chainId": 1, + "address": "0x44e2dec86b9f0e0266e9aa66e10323a2bd69cf9a", + "name": "Attrace", + "symbol": "ATTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4395/thumb/attrace.png?1624466360" + }, + { + "chainId": 1, + "address": "0x4e352cf164e64adcbad318c3a1e222e9eba4ce42", + "name": "MUX Protocol", + "symbol": "MCB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11796/thumb/mux.jpg?1660125796" + }, + { + "chainId": 1, + "address": "0xedf6568618a00c6f0908bf7758a16f76b6e04af9", + "name": "Arianee", + "symbol": "ARIA20", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5054/thumb/Aria_Logo_256.png?1610097866" + }, + { + "chainId": 1, + "address": "0x8052327f1baf94a9dc8b26b9100f211ee3774f54", + "name": "A2DAO", + "symbol": "ATD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14509/thumb/8926.png?1645686353" + }, + { + "chainId": 1, + "address": "0x26a604dffe3ddab3bee816097f81d3c4a2a4cf97", + "name": "CorionX", + "symbol": "CORX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13129/thumb/x_log.png?1605515405" + }, + { + "chainId": 1, + "address": "0x14da230d6726c50f759bc1838717f8ce6373509c", + "name": "Kambria", + "symbol": "KAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4784/thumb/kambria.png?1547040127" + }, + { + "chainId": 1, + "address": "0xd502f487e1841fdc805130e13eae80c61186bc98", + "name": "Integral", + "symbol": "ITGR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18381/thumb/icon.png?1650331643" + }, + { + "chainId": 1, + "address": "0x9c4a4204b79dd291d6b6571c5be8bbcd0622f050", + "name": "Tracer DAO", + "symbol": "TCR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18271/thumb/tracer_logo.png?1631176676" + }, + { + "chainId": 1, + "address": "0x95aa5d2dbd3c16ee3fdea82d5c6ec3e38ce3314f", + "name": "PointPay", + "symbol": "PXP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8950/thumb/6f9823ed-464a-4413-8940-72aa61d30b43.png?1645271610" + }, + { + "chainId": 1, + "address": "0x3a4f40631a4f906c2bad353ed06de7a5d3fcb430", + "name": "PlayDapp", + "symbol": "PLA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14316/thumb/54023228.png?1615366911" + }, + { + "chainId": 1, + "address": "0xc770eefad204b5180df6a14ee197d99d808ee52d", + "name": "ShapeShift FOX", + "symbol": "FOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9988/thumb/FOX.png?1574330622" + }, + { + "chainId": 1, + "address": "0x6e605c269e0c92e70beeb85486f1fc550f9380bd", + "name": "Catex", + "symbol": "CATT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6353/thumb/catex.png?1548733307" + }, + { + "chainId": 1, + "address": "0x0cba60ca5ef4d42f92a5070a8fedd13be93e2861", + "name": "The Protocol", + "symbol": "THE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27849/thumb/cSar5sDM_400x400.jpg?1666085191" + }, + { + "chainId": 1, + "address": "0xd52aae39a2b5cc7812f7b9450ebb61dfef702b15", + "name": "MetaBrands", + "symbol": "MAGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21244/thumb/MAGE-CG.png?1638766340" + }, + { + "chainId": 1, + "address": "0xc538143202f3b11382d8606aae90a96b042a19db", + "name": "Coinsbit Token", + "symbol": "CNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10340/thumb/cbicon.png?1578637386" + }, + { + "chainId": 1, + "address": "0xc666081073e8dff8d3d1c2292a29ae1a2153ec09", + "name": "Digitex", + "symbol": "DGTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2188/thumb/DGTX.png?1616385887" + }, + { + "chainId": 1, + "address": "0xbd3de9a069648c84d27d74d701c9fa3253098b15", + "name": "EQIFi", + "symbol": "EQX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17490/thumb/EQIFI_Logo_Color.png?1627968404" + }, + { + "chainId": 1, + "address": "0x037a54aab062628c9bbae1fdb1583c195585fe41", + "name": "LCX", + "symbol": "LCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9985/thumb/zRPSu_0o_400x400.jpg?1574327008" + }, + { + "chainId": 1, + "address": "0x1776e1f26f98b1a5df9cd347953a26dd3cb46671", + "name": "Numeraire", + "symbol": "NMR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/752/thumb/numeraire.png?1592538976" + }, + { + "chainId": 1, + "address": "0x722f97a435278b7383a1e3c47f41773bebf3232c", + "name": "UCROWDME", + "symbol": "UCM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12079/thumb/UKm2qXh.png?1605346168" + }, + { + "chainId": 1, + "address": "0x0c9c7712c83b3c70e7c5e11100d33d9401bdf9dd", + "name": "Wombat", + "symbol": "WOMBAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26430/thumb/Project_Page_Icon.png?1657930951" + }, + { + "chainId": 1, + "address": "0x1e4ede388cbc9f4b5c79681b7f94d36a11abebc9", + "name": "X2Y2", + "symbol": "X2Y2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23633/thumb/logo-60b81ff87b40b11739105acf5ad1e075.png?1644903256" + }, + { + "chainId": 1, + "address": "0x81f8f0bb1cb2a06649e51913a151f0e7ef6fa321", + "name": "VitaDAO", + "symbol": "VITA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16580/thumb/QmRjwywiAfpzSfQTuWM3zCTghSHN7G6ohQaar7Ht6WANUp.png?1624506420" + }, + { + "chainId": 1, + "address": "0x33349b282065b0284d756f0577fb39c158f935e6", + "name": "Maple", + "symbol": "MPL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14097/thumb/Maple_Logo_Mark_Maple_Orange.png?1653381382" + }, + { + "chainId": 1, + "address": "0x2602278ee1882889b946eb11dc0e810075650983", + "name": "Vader Protocol", + "symbol": "VADER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20497/thumb/AcF08Jk1_400x400.jpg?1637131991" + }, + { + "chainId": 1, + "address": "0x3b484b82567a09e2588a13d54d032153f0c0aee0", + "name": "OpenDAO", + "symbol": "SOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21956/thumb/fo42wXI6_400x400.jpg?1640373810" + }, + { + "chainId": 1, + "address": "0x1df7aa5551e801e280007dc0fc0454e2d06c1a89", + "name": "BKEX Chain", + "symbol": "BKK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7734/thumb/b8a9c996583ee19c2a98dca34b92a26.png?1646290715" + }, + { + "chainId": 1, + "address": "0xf4b5470523ccd314c6b9da041076e7d79e0df267", + "name": "blockbank", + "symbol": "BBANK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15081/thumb/blockbank.jpg?1667183379" + }, + { + "chainId": 1, + "address": "0xc8871267e07408b89aa5aecc58adca5e574557f8", + "name": "Instadapp USDC", + "symbol": "IUSDC", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/25820/thumb/iUSDC_100x100.png?1654055475" + }, + { + "chainId": 1, + "address": "0xd528cf2e081f72908e086f8800977df826b5a483", + "name": "Paribus", + "symbol": "PBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18410/thumb/paribus.PNG?1631828570" + }, + { + "chainId": 1, + "address": "0x1a7e4e63778b4f12a199c062f3efdd288afcbce8", + "name": "agEUR", + "symbol": "AGEUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19479/thumb/agEUR.png?1635283566" + }, + { + "chainId": 1, + "address": "0xf9fbe825bfb2bf3e387af0dc18cac8d87f29dea8", + "name": "Radar", + "symbol": "RADAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13909/thumb/RADAR.png?1634183461" + }, + { + "chainId": 1, + "address": "0xbb1ee07d6c7baeb702949904080eb61f5d5e7732", + "name": "Dogey Inu", + "symbol": "DINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16374/thumb/512x512_dinu_logo.jpg?1623919813" + }, + { + "chainId": 1, + "address": "0xdddddd4301a082e62e84e43f474f044423921918", + "name": "Rhino fi", + "symbol": "DVF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16414/thumb/rhinofii.jpg?1657812510" + }, + { + "chainId": 1, + "address": "0x99ea4db9ee77acd40b119bd1dc4e33e1c070b80d", + "name": "Quantstamp", + "symbol": "QSP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1219/thumb/0_E0kZjb4dG4hUnoDD_.png?1604815917" + }, + { + "chainId": 1, + "address": "0x40955d77f87123b71b145098358a60573ac7be96", + "name": "Daisy Protocol", + "symbol": "DAISY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17844/thumb/daisy.PNG?1629497116" + }, + { + "chainId": 1, + "address": "0x2ab6bb8408ca3199b8fa6c92d5b455f820af03c4", + "name": "TE FOOD", + "symbol": "TONE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2325/thumb/tec.png?1547036538" + }, + { + "chainId": 1, + "address": "0xc146b7cdbaff065090077151d391f4c96aa09e0c", + "name": "Multi Chain Capital", + "symbol": "MCC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21621/thumb/mcc.png?1639622572" + }, + { + "chainId": 1, + "address": "0x01ba67aac7f75f647d94220cc98fb30fcc5105bf", + "name": "Lyra Finance", + "symbol": "LYRA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21490/thumb/Add-a-heading-26.png?1639364177" + }, + { + "chainId": 1, + "address": "0xff75ced57419bcaebe5f05254983b013b0646ef5", + "name": "Cook", + "symbol": "COOK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14603/thumb/logo-200x200.jpg?1622448330" + }, + { + "chainId": 1, + "address": "0x4674a4f24c5f63d53f22490fb3a08eaaad739ff8", + "name": "Brokoli", + "symbol": "BRKL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18763/thumb/brkl.png?1633356263" + }, + { + "chainId": 1, + "address": "0x347a96a5bd06d2e15199b032f46fb724d6c73047", + "name": "ASIC Token", + "symbol": "ASIC", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/27952/thumb/ASIC_Token_Logo.png?1666668286" + }, + { + "chainId": 1, + "address": "0xc22b30e4cce6b78aaaadae91e44e73593929a3e9", + "name": "RAC", + "symbol": "RAC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12675/thumb/rac_logo_%281%29.jpg?1601526417" + }, + { + "chainId": 1, + "address": "0xa68dd8cb83097765263adad881af6eed479c4a33", + "name": "Fees wtf", + "symbol": "WTF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22581/thumb/feeswtf.jpg?1642120508" + }, + { + "chainId": 1, + "address": "0x5274891bec421b39d23760c04a6755ecb444797c", + "name": "IdleUSDC Yield ", + "symbol": "IDLEUSDCYIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11932/thumb/idleusdcv3_32.png?1596263673" + }, + { + "chainId": 1, + "address": "0x821144518dfe9e7b44fcf4d0824e15e8390d4637", + "name": "Atlantis ATIS", + "symbol": "ATIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12112/thumb/atis_token_logo.png?1600097654" + }, + { + "chainId": 1, + "address": "0x39ea10e507720783c27edd5f96bf2d6e199579b8", + "name": "DeltaFlare", + "symbol": "HONR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28059/thumb/DF_Logo_200x200.png?1667298738" + }, + { + "chainId": 1, + "address": "0xf34842d05a1c888ca02769a633df37177415c2f8", + "name": "IdleUSDT Yield ", + "symbol": "IDLEUSDTYIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11933/thumb/idleusdtv3maxyield_32.png?1596263688" + }, + { + "chainId": 1, + "address": "0xface851a4921ce59e912d19329929ce6da6eb0c7", + "name": "cLINK", + "symbol": "CLINK", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/23943/thumb/iShot2022-02-25_14.35.54.png?1645770966" + }, + { + "chainId": 1, + "address": "0xffc97d72e13e01096502cb8eb52dee56f74dad7b", + "name": "Aave AAVE", + "symbol": "AAAVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17248/thumb/amAAVE_2x.png?1626941140" + }, + { + "chainId": 1, + "address": "0x616e8bfa43f920657b3497dbf40d6b1a02d4608d", + "name": "Aura BAL", + "symbol": "AURABAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26538/thumb/auraBAL.png?1658721102" + }, + { + "chainId": 1, + "address": "0xae78736cd615f374d3085123a210448e74fc6393", + "name": "Rocket Pool ETH", + "symbol": "RETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20764/thumb/reth.png?1637652366" + }, + { + "chainId": 1, + "address": "0x10bc518c32fbae5e38ecb50a612160571bd81e44", + "name": "VeraOne", + "symbol": "VRO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11112/thumb/wsBaVF.png?1588639964" + }, + { + "chainId": 1, + "address": "0x501ace9c35e60f03a2af4d484f49f9b1efde9f40", + "name": "SOLACE", + "symbol": "SOLACE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21277/thumb/IMG_6599.png?1638862378" + }, + { + "chainId": 1, + "address": "0x9d38f670d15c14716be1f109a4f453e966a2b6d4", + "name": "Quid Ika", + "symbol": "QUID", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18995/thumb/PcJP5nK.png?1634126273" + }, + { + "chainId": 1, + "address": "0x26607ac599266b21d13c7acf7942c7701a8b699c", + "name": "Power Index Pool", + "symbol": "PIPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13281/thumb/pipt_logo.jpg?1606910642" + }, + { + "chainId": 1, + "address": "0x3ab6ed69ef663bd986ee59205ccad8a20f98b4c2", + "name": "Drep", + "symbol": "DREP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14578/thumb/KotgsCgS_400x400.jpg?1617094445" + }, + { + "chainId": 1, + "address": "0x841fb148863454a3b3570f515414759be9091465", + "name": "Shih Tzu", + "symbol": "SHIH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15309/thumb/shit.PNG?1620374274" + }, + { + "chainId": 1, + "address": "0xabd4dc8fde9848cbc4ff2c0ee81d4a49f4803da4", + "name": "Squeeze", + "symbol": "SQUEEZE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18554/thumb/squeeze.png?1632377096" + }, + { + "chainId": 1, + "address": "0x56a86d648c435dc707c8405b78e2ae8eb4e60ba4", + "name": "StackOS", + "symbol": "STACK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14989/thumb/stackos.jpg?1661420187" + }, + { + "chainId": 1, + "address": "0x1b073382e63411e3bcffe90ac1b9a43fefa1ec6f", + "name": "Bitpanda Ecosystem", + "symbol": "BEST", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/8738/thumb/BEST-Coin-Logo.png?1619079782" + }, + { + "chainId": 1, + "address": "0x4cff49d0a19ed6ff845a9122fa912abcfb1f68a6", + "name": "WadzPay", + "symbol": "WTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13083/thumb/200xWadzToken.png?1604984329" + }, + { + "chainId": 1, + "address": "0x1fcdce58959f536621d76f5b7ffb955baa5a672f", + "name": "ForTube", + "symbol": "FOR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8242/thumb/for.png?1606195375" + }, + { + "chainId": 1, + "address": "0x3f9bec82c776c47405bcb38070d2395fd18f89d3", + "name": "Phantom Protocol", + "symbol": "PHM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18253/thumb/phm.PNG?1631137732" + }, + { + "chainId": 1, + "address": "0x4a621d9f1b19296d1c0f87637b3a8d4978e9bf82", + "name": "CyberFM", + "symbol": "CYFM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5476/thumb/cyberfm.png?1547041216" + }, + { + "chainId": 1, + "address": "0x5c6ff62552a25d68d453277dd3693f94c7e8c964", + "name": "Fit Beat", + "symbol": "FTB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18871/thumb/ftb.png?1638183072" + }, + { + "chainId": 1, + "address": "0x4da0c48376c277cdbd7fc6fdc6936dee3e4adf75", + "name": "Epik Prime", + "symbol": "EPIK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17907/thumb/EPIK_Prime_LOGO.jpg?1630738458" + }, + { + "chainId": 1, + "address": "0x0ec9f76202a7061eb9b3a7d6b59d36215a7e37da", + "name": "BlackPool", + "symbol": "BPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15887/thumb/uyO7dQzR_400x400.jpg?1622199432" + }, + { + "chainId": 1, + "address": "0xf8ad7dfe656188a23e89da09506adf7ad9290d5d", + "name": "Blocery", + "symbol": "BLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12095/thumb/Blocery_logo_200x200_.png?1597046107" + }, + { + "chainId": 1, + "address": "0x9196e18bc349b1f64bc08784eae259525329a1ad", + "name": "Pussy Financial", + "symbol": "PUSSY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15213/thumb/pussytoken.png?1620110339" + }, + { + "chainId": 1, + "address": "0x19062190b1925b5b6689d7073fdfc8c2976ef8cb", + "name": "Swarm", + "symbol": "BZZ", + "decimals": 16, + "logoURI": "https://assets.coingecko.com/coins/images/16509/thumb/Swarm_Logo_1_%E2%97%8B_1_200px.png?1628508564" + }, + { + "chainId": 1, + "address": "0xf8483e2d6560585c02d46bf7b3186bf154a96166", + "name": "IdeaChain", + "symbol": "ICH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11053/thumb/4fJlFzca_400x400.jpg?1587609361" + }, + { + "chainId": 1, + "address": "0xb1abd7aba7d99bbefb33d1dfc66b0dd522335350", + "name": "Euro Stable Token", + "symbol": "EURST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20988/thumb/AF3E1D9F-4817-4FC4-BC80-FFF30A3E1B91.PNG?1638169603" + }, + { + "chainId": 1, + "address": "0x5d30ad9c6374bf925d0a75454fa327aacf778492", + "name": "PERI Finance", + "symbol": "PERI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15313/thumb/6xVEMS1.png?1620375905" + }, + { + "chainId": 1, + "address": "0xfc0d6cf33e38bce7ca7d89c0e292274031b7157a", + "name": "Netvrk", + "symbol": "NTVRK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15721/thumb/netvrk_icon.png?1627536091" + }, + { + "chainId": 1, + "address": "0x940a2db1b7008b6c776d4faaca729d6d4a4aa551", + "name": "DUSK Network", + "symbol": "DUSK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5217/thumb/D_ticker_purple_on_circle_%282%29.png?1563781659" + }, + { + "chainId": 1, + "address": "0xb7cb1c96db6b22b0d3d9536e0108d062bd488f74", + "name": "Waltonchain", + "symbol": "WTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1093/thumb/ggx6nnW.png?1604815811" + }, + { + "chainId": 1, + "address": "0xe7f58a92476056627f9fdb92286778abd83b285f", + "name": "DecentraWeb", + "symbol": "DWEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18971/thumb/dweb-logo-transparent.png?1634082358" + }, + { + "chainId": 1, + "address": "0x1ea48b9965bb5086f3b468e50ed93888a661fc17", + "name": "Defi Franc Moneta", + "symbol": "MON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27493/thumb/logo-moneta.png?1664268389" + }, + { + "chainId": 1, + "address": "0xd794dd1cada4cf79c9eebaab8327a1b0507ef7d4", + "name": "Hyve", + "symbol": "HYVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13072/thumb/bAe1G-lD_400x400.png?1654056255" + }, + { + "chainId": 1, + "address": "0x83249c6794bca5a77eb8c0af9f1a86e055459cea", + "name": "GigaSwap", + "symbol": "GIGA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26919/thumb/final_62fcaacdbcc9640975d3fb7c_822256.png?1660815521" + }, + { + "chainId": 1, + "address": "0x3f3cd642e81d030d7b514a2ab5e3a5536beb90ec", + "name": "Rho", + "symbol": "RHO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25540/thumb/Rho-icon-03.png?1652265700" + }, + { + "chainId": 1, + "address": "0x48c276e8d03813224bb1e55f953adb6d02fd3e02", + "name": "Kuma Inu", + "symbol": "KUMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15526/thumb/kuma_inu.PNG?1621128824" + }, + { + "chainId": 1, + "address": "0xa8b919680258d369114910511cc87595aec0be6d", + "name": "LUKSO", + "symbol": "LYXE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11423/thumb/1_QAHTciwVhD7SqVmfRW70Pw.png?1590110612" + }, + { + "chainId": 1, + "address": "0xc50ef449171a51fbeafd7c562b064b6471c36caa", + "name": "Zombie Inu", + "symbol": "ZINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19516/thumb/zinu.jpeg?1635321575" + }, + { + "chainId": 1, + "address": "0xc9f1016d336ef77aee75fc11ad64c5ecf9121332", + "name": "SoMee Advertising", + "symbol": "SAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16040/thumb/SoMee.png?1622683511" + }, + { + "chainId": 1, + "address": "0xa67e9f021b9d208f7e3365b2a155e3c55b27de71", + "name": "KleeKai", + "symbol": "KLEE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15548/thumb/Klee-Kai-Logo.png?1628258448" + }, + { + "chainId": 1, + "address": "0x35f67c1d929e106fdff8d1a55226afe15c34dbe2", + "name": "Beta", + "symbol": "BETA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25539/thumb/Beta-47.png?1652265414" + }, + { + "chainId": 1, + "address": "0xffffffff2ba8f66d4e51811c5190992176930278", + "name": "Furucombo", + "symbol": "COMBO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13629/thumb/COMBO_token_ol.png?1610701537" + }, + { + "chainId": 1, + "address": "0xbd0a4bf098261673d5e6e600fd87ddcd756e6764", + "name": "Hina Inu", + "symbol": "HINA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15993/thumb/download.png?1622549919" + }, + { + "chainId": 1, + "address": "0x3f5dd1a1538a4f9f82e543098f01f22480b0a3a8", + "name": "KumaDex Token", + "symbol": "DKUMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26693/thumb/dkumaOG02_CoinGecko.png?1660618296" + }, + { + "chainId": 1, + "address": "0xf4dc48d260c93ad6a96c5ce563e70ca578987c74", + "name": "Babylon Finance", + "symbol": "BABL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20049/thumb/favicon-260x260.png?1636426809" + }, + { + "chainId": 1, + "address": "0xd5525d397898e5502075ea5e830d8914f6f0affe", + "name": "Meme", + "symbol": "MEME", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12140/thumb/meme-coin.jpeg?1619249191" + }, + { + "chainId": 1, + "address": "0x990f341946a3fdb507ae7e52d17851b87168017c", + "name": "Strong", + "symbol": "STRONG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12092/thumb/STRONG-Token-256x256.png?1597823573" + }, + { + "chainId": 1, + "address": "0xc477d038d5420c6a9e0b031712f61c5120090de9", + "name": "Boson Protocol", + "symbol": "BOSON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14710/thumb/boson_logo.png?1617882472" + }, + { + "chainId": 1, + "address": "0x6b4c7a5e3f0b99fcd83e9c089bddd6c7fce5c611", + "name": "Million", + "symbol": "MM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16825/thumb/logo200x200.png?1625834139" + }, + { + "chainId": 1, + "address": "0xaa8330fb2b4d5d07abfe7a72262752a8505c6b37", + "name": "Polkacity", + "symbol": "POLC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14066/thumb/vykih1Nq_400x400.png?1614130959" + }, + { + "chainId": 1, + "address": "0x9b39a0b97319a9bd5fed217c1db7b030453bac91", + "name": "TigerCash", + "symbol": "TCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4956/thumb/tigercash-logo.png?1547040378" + }, + { + "chainId": 1, + "address": "0x875773784af8135ea0ef43b5a374aad105c5d39e", + "name": "IDLE", + "symbol": "IDLE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13286/thumb/image.png?1655284075" + }, + { + "chainId": 1, + "address": "0xca0e7269600d353f70b14ad118a49575455c0f2f", + "name": "AMLT Network", + "symbol": "AMLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2703/thumb/amlt.png?1563794756" + }, + { + "chainId": 1, + "address": "0xba8a621b4a54e61c442f5ec623687e2a942225ef", + "name": "Sandclock", + "symbol": "QUARTZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19368/thumb/sandclock.jpg?1635132501" + }, + { + "chainId": 1, + "address": "0x21bfbda47a0b4b5b1248c767ee49f7caa9b23697", + "name": "Ovr", + "symbol": "OVR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13429/thumb/ovr_logo.png?1608518911" + }, + { + "chainId": 1, + "address": "0x6bb61215298f296c55b19ad842d3df69021da2ef", + "name": "Drops Ownership Power", + "symbol": "DOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15696/thumb/dop.png?1640325078" + }, + { + "chainId": 1, + "address": "0xdf347911910b6c9a4286ba8e2ee5ea4a39eb2134", + "name": "Bob s Repair", + "symbol": "BOB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3550/thumb/PNG_BOB_Token_Large.png?1547038375" + }, + { + "chainId": 1, + "address": "0xa36fdbbae3c9d55a1d67ee5821d53b50b63a1ab9", + "name": "Tempus", + "symbol": "TEMP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20547/thumb/Tempus_CoinGecko_200x200.png?1657674634" + }, + { + "chainId": 1, + "address": "0x056354f3ff20743aa4c0da365603871c7000b081", + "name": "TriumphX", + "symbol": "TRIX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12270/thumb/TRIX_Logo_transparent.png?1598619314" + }, + { + "chainId": 1, + "address": "0x6810e776880c02933d47db1b9fc05908e5386b96", + "name": "Gnosis", + "symbol": "GNO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/662/thumb/logo_square_simple_300px.png?1609402668" + }, + { + "chainId": 1, + "address": "0xa4eed63db85311e22df4473f87ccfc3dadcfa3e3", + "name": "Rubic", + "symbol": "RBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12629/thumb/200x200.png?1607952509" + }, + { + "chainId": 1, + "address": "0x8037b1b69d6fa63a9cc053c25f7e168e6e6d857a", + "name": "Parts of Four Coin", + "symbol": "P4C", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20774/thumb/Artboard_1_copy_2x.png?1637660521" + }, + { + "chainId": 1, + "address": "0x74b988156925937bd4e082f0ed7429da8eaea8db", + "name": "Meme Inu", + "symbol": "MEME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20755/thumb/photo_2021-11-20_13-39-45.jpg?1637638928" + }, + { + "chainId": 1, + "address": "0x584bc13c7d411c00c01a62e8019472de68768430", + "name": "Hegic", + "symbol": "HEGIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12454/thumb/new.png?1628668523" + }, + { + "chainId": 1, + "address": "0xbaac2b4491727d78d2b78815144570b9f2fe8899", + "name": "The Doge NFT", + "symbol": "DOG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18111/thumb/Doge.png?1630696110" + }, + { + "chainId": 1, + "address": "0xd01409314acb3b245cea9500ece3f6fd4d70ea30", + "name": "LTO Network", + "symbol": "LTO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6068/thumb/lto.png?1638855565" + }, + { + "chainId": 1, + "address": "0x1d2d542e6d9d85a712deb4d1a7d96a16ce00b8ce", + "name": "Proof Of Apes", + "symbol": "POA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27896/thumb/POA.png?1666318268" + }, + { + "chainId": 1, + "address": "0x8971f9fd7196e5cee2c1032b50f656855af7dd26", + "name": "Lambda", + "symbol": "LAMB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4703/thumb/lambda_200.png?1666431649" + }, + { + "chainId": 1, + "address": "0xfeeb4d0f5463b1b04351823c246bdb84c4320cc2", + "name": "Gold Retriever", + "symbol": "GLDN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27529/thumb/33406C30-2F50-45D8-9F75-5B7EAEB23038.jpeg?1664371749" + }, + { + "chainId": 1, + "address": "0x15b543e986b8c34074dfc9901136d9355a537e7e", + "name": "Student Coin", + "symbol": "STC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6260/thumb/logo_in_circle_%281%29.png?1667725082" + }, + { + "chainId": 1, + "address": "0x131157c6760f78f7ddf877c0019eba175ba4b6f6", + "name": "BigShortBets", + "symbol": "BIGSB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18235/thumb/bigsb-token-logo.png?1631065645" + }, + { + "chainId": 1, + "address": "0x471d113059324321749e097705197a2b44a070fc", + "name": "Kanga Exchange", + "symbol": "KNG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21188/thumb/kanga.PNG?1638514737" + }, + { + "chainId": 1, + "address": "0x8ab7404063ec4dbcfd4598215992dc3f8ec853d7", + "name": "Akropolis", + "symbol": "AKRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3328/thumb/Akropolis.png?1547037929" + }, + { + "chainId": 1, + "address": "0x5732046a883704404f284ce41ffadd5b007fd668", + "name": "Bluzelle", + "symbol": "BLZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2848/thumb/ColorIcon_3x.png?1622516510" + }, + { + "chainId": 1, + "address": "0x949d48eca67b17269629c7194f4b727d4ef9e5d6", + "name": "Merit Circle", + "symbol": "MC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19304/thumb/Db4XqML.png?1634972154" + }, + { + "chainId": 1, + "address": "0xa01199c61841fce3b3dafb83fefc1899715c8756", + "name": "Cirus", + "symbol": "CIRUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17798/thumb/8p0Bvi90_400x400.jpg?1629281912" + }, + { + "chainId": 1, + "address": "0x83c141ee88c502cb9654de93598e9f16555082a8", + "name": "The Genesis Block", + "symbol": "GENBLOK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27471/thumb/6313c6043c13ed270ede4600_aaaa-p-500.jpg?1664195154" + }, + { + "chainId": 1, + "address": "0x970b9bb2c0444f5e81e9d0efb84c8ccdcdcaf84d", + "name": "Fuse", + "symbol": "FUSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10347/thumb/vUXKHEe.png?1601523640" + }, + { + "chainId": 1, + "address": "0x38d9eb07a7b8df7d86f440a4a5c4a4c1a27e1a08", + "name": "bloXmove", + "symbol": "BLXM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19310/thumb/blxm_200x200.png?1635238192" + }, + { + "chainId": 1, + "address": "0xd5d86fc8d5c0ea1ac1ac5dfab6e529c9967a45e9", + "name": "NFT Worlds", + "symbol": "WRLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22112/thumb/ZyBrRgfO.jpg?1640842284" + }, + { + "chainId": 1, + "address": "0x77777feddddffc19ff86db637967013e6c6a116c", + "name": "Tornado Cash", + "symbol": "TORN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13496/thumb/ZINt8NSB_400x400.jpg?1609193407" + }, + { + "chainId": 1, + "address": "0x00a8b738e453ffd858a7edf03bccfe20412f0eb0", + "name": "AllianceBlock", + "symbol": "ALBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12392/thumb/alliance_block_logo.jpg?1599546617" + }, + { + "chainId": 1, + "address": "0x1c9922314ed1415c95b9fd453c3818fd41867d0b", + "name": "Tower", + "symbol": "TOWER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14134/thumb/tower-circular-1000.png?1632195469" + }, + { + "chainId": 1, + "address": "0x3b1a3c5d9d5c60651d4841c7814aa0fbb45a863d", + "name": "Laeeb Inu ERC", + "symbol": "LAEEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27905/thumb/LaeebLogo200x200.png?1666335729" + }, + { + "chainId": 1, + "address": "0x49849c98ae39fff122806c06791fa73784fb3675", + "name": "LP renBTC Curve", + "symbol": "RENBTCCURVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11957/thumb/Curvefi_renCrv_32.png?1596435739" + }, + { + "chainId": 1, + "address": "0x814e0908b12a99fecf5bc101bb5d0b8b5cdf7d26", + "name": "Measurable Data", + "symbol": "MDT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2441/thumb/mdt_logo.png?1569813574" + }, + { + "chainId": 1, + "address": "0x03d1e72765545729a035e909edd9371a405f77fb", + "name": "Nabox", + "symbol": "NABOX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16445/thumb/NyemjVRA_400x400.png?1624235013" + }, + { + "chainId": 1, + "address": "0xf406f7a9046793267bc276908778b29563323996", + "name": "APY vision", + "symbol": "VISION", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13288/thumb/apyvisionlogo200circle.png?1607059042" + }, + { + "chainId": 1, + "address": "0x3ec8798b81485a254928b70cda1cf0a2bb0b74d7", + "name": "Gro DAO", + "symbol": "GRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18673/thumb/613f171979749061aaa1edf9_Icon-GRO-256x256-Square.png?1632876204" + }, + { + "chainId": 1, + "address": "0xa15c7ebe1f07caf6bff097d8a589fb8ac49ae5b3", + "name": "Pundi X OLD ", + "symbol": "NPXS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2170/thumb/pundi-x.png?1548386366" + }, + { + "chainId": 1, + "address": "0x0488401c3f535193fa8df029d9ffe615a06e74e6", + "name": "SparkPoint", + "symbol": "SRK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8371/thumb/SRK.png?1614675526" + }, + { + "chainId": 1, + "address": "0xb6c4267c4877bb0d6b1685cfd85b0fbe82f105ec", + "name": "Relevant", + "symbol": "REL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11586/thumb/Relevant.png?1591390081" + }, + { + "chainId": 1, + "address": "0x6a445e9f40e0b97c92d0b8a3366cef1d67f700bf", + "name": "Fidu", + "symbol": "FIDU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25944/thumb/GFI-asset-icon.png?1654827482" + }, + { + "chainId": 1, + "address": "0x37f04d2c3ae075fad5483bb918491f656b12bdb6", + "name": "VestChain", + "symbol": "VEST", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/6700/thumb/logo_200x200_%281%29.png?1547042908" + }, + { + "chainId": 1, + "address": "0xe5d2e173b120341face9e9970889c9fe64081ffd", + "name": "Bluejay", + "symbol": "BLU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28085/thumb/Bluejay.png?1667444163" + }, + { + "chainId": 1, + "address": "0x48af7b1c9dac8871c064f62fcec0d9d6f7c269f5", + "name": " Alpha", + "symbol": "ALPHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24340/thumb/alpha_icon.png?1647395407" + }, + { + "chainId": 1, + "address": "0xc62def1701309bb76e6b39b6ab8b5fac910a3c87", + "name": "MetaRare", + "symbol": "MTRA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24276/thumb/Logo_200x200_PNG.png?1647180519" + }, + { + "chainId": 1, + "address": "0x45804880de22913dafe09f4980848ece6ecbaf78", + "name": "PAX Gold", + "symbol": "PAXG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9519/thumb/paxg.PNG?1568542565" + }, + { + "chainId": 1, + "address": "0xf0d33beda4d734c72684b5f9abbebf715d0a7935", + "name": "NuNet", + "symbol": "NTX", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/20950/thumb/8Zb2W2Wi_400x400.png?1638137477" + }, + { + "chainId": 1, + "address": "0x9565c2036963697786705120fc59310f747bcfd0", + "name": "PoorPleb", + "symbol": "PP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28063/thumb/PP_TOKEN_LOGO.png?1669366801" + }, + { + "chainId": 1, + "address": "0xba9d4199fab4f26efe3551d490e3821486f135ba", + "name": "SwissBorg", + "symbol": "CHSB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2117/thumb/YJUrRy7r_400x400.png?1589794215" + }, + { + "chainId": 1, + "address": "0x626e8036deb333b408be468f951bdb42433cbf18", + "name": "AIOZ Network", + "symbol": "AIOZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14631/thumb/aioz-logo-200.png?1649237507" + }, + { + "chainId": 1, + "address": "0x55296f69f40ea6d20e478533c15a6b08b654e758", + "name": "XYO Network", + "symbol": "XYO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4519/thumb/XYO_Network-logo.png?1547039819" + }, + { + "chainId": 1, + "address": "0x51fe2e572e97bfeb1d719809d743ec2675924edc", + "name": "VLaunch", + "symbol": "VPAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20838/thumb/vlaunch_22.png?1637738535" + }, + { + "chainId": 1, + "address": "0xee586e7eaad39207f0549bc65f19e336942c992f", + "name": "Celo Euro Wormhole ", + "symbol": "CEUR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27870/thumb/5ETdHxeE_400x400.jpeg?1666164533" + }, + { + "chainId": 1, + "address": "0x9f009d03e1b7f02065017c90e8e0d5cb378eb015", + "name": "Fortune", + "symbol": "FORTUNE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20374/thumb/TZcfq5b_%281%29.png?1636949601" + }, + { + "chainId": 1, + "address": "0xfe3e6a25e6b192a42a44ecddcd13796471735acf", + "name": "Reef", + "symbol": "REEF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13504/thumb/Group_10572.png?1610534130" + }, + { + "chainId": 1, + "address": "0x84342e932797fc62814189f01f0fb05f52519708", + "name": "Neighbourhoods", + "symbol": "NHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22055/thumb/social_media_logo_black_bg.png?1640682530" + }, + { + "chainId": 1, + "address": "0xe66747a101bff2dba3697199dcce5b743b454759", + "name": "Gate", + "symbol": "GT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8183/thumb/gt.png?1556085624" + }, + { + "chainId": 1, + "address": "0xaf9f549774ecedbd0966c52f250acc548d3f36e5", + "name": "RioDeFi", + "symbol": "RFUEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12623/thumb/RFUEL_SQR.png?1602481093" + }, + { + "chainId": 1, + "address": "0xfad45e47083e4607302aa43c65fb3106f1cd7607", + "name": "Hoge Finance", + "symbol": "HOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14360/thumb/hoge.jpg?1615641604" + }, + { + "chainId": 1, + "address": "0xf7920b0768ecb20a123fac32311d07d193381d6f", + "name": "Time New Bank", + "symbol": "TNB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1265/thumb/time-new-bank.png?1547035290" + }, + { + "chainId": 1, + "address": "0xdacd69347de42babfaecd09dc88958378780fb62", + "name": "Atari", + "symbol": "ATRI", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/12992/thumb/AtariLogoPS_200x200_%281%29.png?1643189483" + }, + { + "chainId": 1, + "address": "0xbbc2ae13b23d715c30720f079fcd9b4a74093505", + "name": "Ethernity Chain", + "symbol": "ERN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14238/thumb/LOGO_HIGH_QUALITY.png?1647831402" + }, + { + "chainId": 1, + "address": "0x1c4853ec0d55e420002c5efabc7ed8e0ba7a4121", + "name": "Kanagawa Nami", + "symbol": "OKINAMI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/26629/thumb/KANAGAWA_%284%29.png?1659324703" + }, + { + "chainId": 1, + "address": "0x79a06acb8bdd138beeecce0f1605971f3ac7c09b", + "name": "Lasrever", + "symbol": "LSVR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26681/thumb/E312D296-5EB2-4CF1-B98C-A2E47736BA37.jpeg?1659538133" + }, + { + "chainId": 1, + "address": "0xad996a45fd2373ed0b10efa4a8ecb9de445a4302", + "name": "Shirtum", + "symbol": "SHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16955/thumb/4fWlpC0.png?1625794164" + }, + { + "chainId": 1, + "address": "0x2de509bf0014ddf697b220be628213034d320ece", + "name": "Don t Buy Inu", + "symbol": "DBI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28058/thumb/1Artboard_1_%282%29.png?1667298091" + }, + { + "chainId": 1, + "address": "0xe76c6c83af64e4c60245d8c7de953df673a7a33d", + "name": "Railgun", + "symbol": "RAIL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16840/thumb/railgun.jpeg?1625322775" + }, + { + "chainId": 1, + "address": "0xbe1a001fe942f96eea22ba08783140b9dcc09d28", + "name": "Beta Finance", + "symbol": "BETA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18715/thumb/beta_finance.jpg?1633087053" + }, + { + "chainId": 1, + "address": "0x6dea81c8171d0ba574754ef6f8b412f2ed88c54d", + "name": "Liquity", + "symbol": "LQTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14665/thumb/200-lqty-icon.png?1617631180" + }, + { + "chainId": 1, + "address": "0x892a6f9df0147e5f079b0993f486f9aca3c87881", + "name": "xFUND", + "symbol": "XFUND", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/13770/thumb/xfund.png?1611697744" + }, + { + "chainId": 1, + "address": "0xe4cfe9eaa8cdb0942a80b7bc68fd8ab0f6d44903", + "name": "Xend Finance", + "symbol": "XEND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14496/thumb/WeChat_Image_20210325163206.png?1616661216" + }, + { + "chainId": 1, + "address": "0xf59ae934f6fe444afc309586cc60a84a0f89aaea", + "name": "Polkadex", + "symbol": "PDEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14833/thumb/dIze5Ztl_400x400.jpg?1618610724" + }, + { + "chainId": 1, + "address": "0x6cacdb97e3fc8136805a9e7c342d866ab77d0957", + "name": "Swapr", + "symbol": "SWPR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18740/thumb/swapr.jpg?1633516501" + }, + { + "chainId": 1, + "address": "0xee573a945b01b788b9287ce062a0cfc15be9fd86", + "name": "Exeedme", + "symbol": "XED", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13518/thumb/exeedme.png?1610669597" + }, + { + "chainId": 1, + "address": "0xe80c0cd204d654cebe8dd64a4857cab6be8345a3", + "name": "JPEG d", + "symbol": "JPEG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24025/thumb/et_43CNi_400x400.jpg?1646100264" + }, + { + "chainId": 1, + "address": "0xf16e81dce15b08f326220742020379b855b87df9", + "name": "Popsicle Finance", + "symbol": "ICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14586/thumb/ice.png?1617188825" + }, + { + "chainId": 1, + "address": "0x04fa0d235c4abf4bcf4787af4cf447de572ef828", + "name": "UMA", + "symbol": "UMA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10951/thumb/UMA.png?1586307916" + }, + { + "chainId": 1, + "address": "0x5dd57da40e6866c9fcc34f4b6ddc89f1ba740dfe", + "name": "BrightID", + "symbol": "BRIGHT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18415/thumb/bright.PNG?1631841211" + }, + { + "chainId": 1, + "address": "0x525a8f6f3ba4752868cde25164382bfbae3990e1", + "name": "Nym", + "symbol": "NYM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/24488/thumb/NYM_Token.png?1649926353" + }, + { + "chainId": 1, + "address": "0x4521c9ad6a3d4230803ab752ed238be11f8b342f", + "name": "Sanin Inu", + "symbol": "SANI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25222/thumb/B7r0ocfQ_400x400.jpg?1650892157" + }, + { + "chainId": 1, + "address": "0x788b6d2b37aa51d916f2837ae25b05f0e61339d1", + "name": "Metavault DAO", + "symbol": "MVD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23899/thumb/mvd.png?1660680251" + }, + { + "chainId": 1, + "address": "0xa91ac63d040deb1b7a5e4d4134ad23eb0ba07e14", + "name": "Bella Protocol", + "symbol": "BEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12478/thumb/Bella.png?1602230054" + }, + { + "chainId": 1, + "address": "0x431d5dff03120afa4bdf332c61a6e1766ef37bdb", + "name": "JPY Coin", + "symbol": "JPYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25971/thumb/JPYC_logo_3D_cmyk_0-1_%282%29.jpg?1667467959" + }, + { + "chainId": 1, + "address": "0x20945ca1df56d237fd40036d47e866c7dccd2114", + "name": "Nsure Network", + "symbol": "NSURE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12948/thumb/Nsure_token.png?1603778876" + }, + { + "chainId": 1, + "address": "0x8770b7dd89e5f759ee3b226e0c45e890f87ddc48", + "name": "Made In Real Life", + "symbol": "MIRL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28021/thumb/mirl.png?1667028324" + }, + { + "chainId": 1, + "address": "0x4b13006980acb09645131b91d259eaa111eaf5ba", + "name": "Mycelium", + "symbol": "MYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26874/thumb/MYC_Token.png?1665971552" + }, + { + "chainId": 1, + "address": "0xc13f4f0f865bac08f62654b57e38669ebc4747a3", + "name": "Creds", + "symbol": "CREDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22122/thumb/creds.png?1640848447" + }, + { + "chainId": 1, + "address": "0x3f17cfad23c2014c5a32722557df87dff46819da", + "name": "Amplify", + "symbol": "AMPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23695/thumb/ampt_pictogram_color_1920px_2.png?1645080512" + }, + { + "chainId": 1, + "address": "0x3adb04e127b9c0a5d36094125669d4603ac52a0c", + "name": "Gro Vault", + "symbol": "GVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18628/thumb/613f170fa75cd0ec6fd17f50_Icon-Vault-256x256-Square.png?1632980198" + }, + { + "chainId": 1, + "address": "0x469eda64aed3a3ad6f868c44564291aa415cb1d9", + "name": "Datamine FLUX", + "symbol": "FLUX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11756/thumb/fluxres.png?1593748917" + }, + { + "chainId": 1, + "address": "0x1f8a626883d7724dbd59ef51cbd4bf1cf2016d13", + "name": "Jigstack", + "symbol": "STAK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14978/thumb/jigstack.PNG?1619216498" + }, + { + "chainId": 1, + "address": "0x39fa206c1648944f92e8f7b626e1cbdf78d7e9db", + "name": "DXY Finance", + "symbol": "DXY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12839/thumb/dxy_finance.png?1602903489" + }, + { + "chainId": 1, + "address": "0x80d55c03180349fff4a229102f62328220a96444", + "name": "Opulous", + "symbol": "OPUL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16548/thumb/opulous.PNG?1624418744" + }, + { + "chainId": 1, + "address": "0xd0d42005e7b3c0812b1268f0e5faf97ff2423651", + "name": "KOROMARU", + "symbol": "KOROMARU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19884/thumb/koromaru.png?1642838436" + }, + { + "chainId": 1, + "address": "0xe9b076b476d8865cdf79d1cf7df420ee397a7f75", + "name": "Unification", + "symbol": "FUND", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/7845/thumb/DV80FOp.png?1554953278" + }, + { + "chainId": 1, + "address": "0x632806bf5c8f062932dd121244c9fbe7becb8b48", + "name": "Phuture DeFi Index", + "symbol": "PDI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25772/thumb/2.PDI_logo_solid_blue_-_Circle_3x.png?1665022360" + }, + { + "chainId": 1, + "address": "0x08389495d7456e1951ddf7c3a1314a4bfb646d8b", + "name": "Crypterium", + "symbol": "CRPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1901/thumb/crypt.png?1547036205" + }, + { + "chainId": 1, + "address": "0x37e1160184f7dd29f00b78c050bf13224780b0b0", + "name": "Yuan Chain Coin", + "symbol": "YCC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/5328/thumb/G5gCEo-J_400x400.jpg?1547040897" + }, + { + "chainId": 1, + "address": "0x519c1001d550c0a1dae7d1fc220f7d14c2a521bb", + "name": "Polkaswap", + "symbol": "PSWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15475/thumb/pswap-token-logomark-ticker-icon-200px-transparent-optimized.png?1622447028" + }, + { + "chainId": 1, + "address": "0x000000007a58f5f58e697e51ab0357bc9e260a04", + "name": "Concave", + "symbol": "CNV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24492/thumb/concave.jpg?1648795376" + }, + { + "chainId": 1, + "address": "0x1f3f9d3068568f8040775be2e8c03c103c61f3af", + "name": "Archer DAO Governance", + "symbol": "ARCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13188/thumb/archer_logo.png?1606097487" + }, + { + "chainId": 1, + "address": "0x52f4d5ee6c91e01be67ca1f64b11ed0ee370817d", + "name": "CIA", + "symbol": "CIA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21569/thumb/Untitled-design-24.png?1641975750" + }, + { + "chainId": 1, + "address": "0x14a32f050facf226ec60882398a9bf36d91dbac2", + "name": "Kyoko", + "symbol": "KYOKO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24454/thumb/kyoko.png?1649576935" + }, + { + "chainId": 1, + "address": "0x4f640f2529ee0cf119a2881485845fa8e61a782a", + "name": "ORE Network", + "symbol": "ORE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18917/thumb/ORE_FullColor.png?1633921977" + }, + { + "chainId": 1, + "address": "0xe52e8876fbe83d6091df4ac3e9adc13be6533849", + "name": "ArtCoin", + "symbol": "AC", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/26127/thumb/ngiBSUT7_400x400.png?1655954442" + }, + { + "chainId": 1, + "address": "0xb6ca7399b4f9ca56fc27cbff44f4d2e4eef1fc81", + "name": "Muse DAO", + "symbol": "MUSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13230/thumb/muse_logo.png?1606460453" + }, + { + "chainId": 1, + "address": "0x881ba05de1e78f549cc63a8f6cabb1d4ad32250d", + "name": "00 Token", + "symbol": "00", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27742/thumb/200x200.png?1665623317" + }, + { + "chainId": 1, + "address": "0x7d4b1d793239707445305d8d2456d2c735f6b25b", + "name": "BlockSwap Network OLD ", + "symbol": "CBSN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14781/thumb/bsn_dp_high.png?1618865566" + }, + { + "chainId": 1, + "address": "0x67b66c99d3eb37fa76aa3ed1ff33e8e39f0b9c7a", + "name": "Interest Bearing ETH", + "symbol": "IBETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13131/thumb/7675.png?1605535879" + }, + { + "chainId": 1, + "address": "0xaaaaaa20d9e0e2461697782ef11675f668207961", + "name": "Aurora", + "symbol": "AURORA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20582/thumb/aurora.jpeg?1637250883" + }, + { + "chainId": 1, + "address": "0xa393473d64d2f9f026b60b6df7859a689715d092", + "name": "Lattice", + "symbol": "LTX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13050/thumb/Lattice.jpg?1613976295" + }, + { + "chainId": 1, + "address": "0x0944d5848bd9f60a34ba92aea300d4286696eb76", + "name": "Palette", + "symbol": "PLT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22153/thumb/262aoVTp_400x400.jpg?1640940192" + }, + { + "chainId": 1, + "address": "0xa20f77b7ad5a88badc48800c56507b7274c06fdc", + "name": "Cherry Network", + "symbol": "CHER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21855/thumb/cherry.PNG?1640144127" + }, + { + "chainId": 1, + "address": "0x1117ac6ad6cdf1a3bc543bad3b133724620522d5", + "name": "MODA DAO", + "symbol": "MODA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20870/thumb/ModaDAO__logomark-primary_3x.png?1637809145" + }, + { + "chainId": 1, + "address": "0xaaef88cea01475125522e117bfe45cf32044e238", + "name": "GuildFi", + "symbol": "GF", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20933/thumb/guildfi-logo-200.png?1638003537" + }, + { + "chainId": 1, + "address": "0x99fe3b1391503a1bc1788051347a1324bff41452", + "name": "SX Network", + "symbol": "SX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13779/thumb/sx.png?1636034699" + }, + { + "chainId": 1, + "address": "0x45080a6531d671ddff20db42f93792a489685e32", + "name": "Finance Vote", + "symbol": "FVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13181/thumb/finance.png?1606015010" + }, + { + "chainId": 1, + "address": "0x95b3497bbcccc46a8f45f5cf54b0878b39f8d96c", + "name": "UniDex", + "symbol": "UNIDX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13178/thumb/unidx.png?1634888975" + }, + { + "chainId": 1, + "address": "0x4ddc2d193948926d02f9b1fe9e1daa0718270ed5", + "name": "cETH", + "symbol": "CETH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10643/thumb/ceth2.JPG?1581389598" + }, + { + "chainId": 1, + "address": "0x42dbbd5ae373fea2fc320f62d44c058522bb3758", + "name": "Memecoin", + "symbol": "MEM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16370/thumb/mem_gold_200x200_copy.png?1623821100" + }, + { + "chainId": 1, + "address": "0xc383a3833a87009fd9597f8184979af5edfad019", + "name": "Instadapp ETH", + "symbol": "IETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25822/thumb/iETH_100x100.png?1654055637" + }, + { + "chainId": 1, + "address": "0xf650c3d88d12db855b8bf7d11be6c55a4e07dcc9", + "name": "cUSDT", + "symbol": "CUSDT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11621/thumb/cUSDT.png?1592113270" + }, + { + "chainId": 1, + "address": "0x62b9c7356a2dc64a1969e19c23e4f579f9810aa7", + "name": "Convex CRV", + "symbol": "CVXCRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15586/thumb/convex-crv.png?1621255952" + }, + { + "chainId": 1, + "address": "0xff742d05420b6aca4481f635ad8341f81a6300c2", + "name": "AscendEx", + "symbol": "ASD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5003/thumb/bitmax.png?1621310871" + }, + { + "chainId": 1, + "address": "0xf203ca1769ca8e9e8fe1da9d147db68b6c919817", + "name": "Wrapped NCG", + "symbol": "WNCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17747/thumb/WNCG.png?1629167703" + }, + { + "chainId": 1, + "address": "0x678e840c640f619e17848045d23072844224dd37", + "name": "Cratos", + "symbol": "CRTS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17322/thumb/cratos.png?1627301460" + }, + { + "chainId": 1, + "address": "0x16cc8367055ae7e9157dbcb9d86fd6ce82522b31", + "name": "Voxel X Network", + "symbol": "VXL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21419/thumb/Voxel-Logo-200x200-Transparent.png?1639093664" + }, + { + "chainId": 1, + "address": "0xe1c7e30c42c24582888c758984f6e382096786bd", + "name": "Curate", + "symbol": "XCUR", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13327/thumb/400x400_%281%29_%283%29_%282%29.png?1613998208" + }, + { + "chainId": 1, + "address": "0x4123a133ae3c521fd134d7b13a2dec35b56c2463", + "name": "Qredo", + "symbol": "QRDO", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17541/thumb/qrdo.png?1630637735" + }, + { + "chainId": 1, + "address": "0x10010078a54396f62c96df8532dc2b4847d47ed3", + "name": "Hundred Finance", + "symbol": "HND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18445/thumb/hnd.PNG?1632054703" + }, + { + "chainId": 1, + "address": "0xb53ecf1345cabee6ea1a65100ebb153cebcac40f", + "name": "Childhoods End", + "symbol": "O", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25670/thumb/photo_2022-05-27_12-45-29.jpg?1653626809" + }, + { + "chainId": 1, + "address": "0x9f284e1337a815fe77d2ff4ae46544645b20c5ff", + "name": "Darwinia Commitment", + "symbol": "KTON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11895/thumb/KTON.png?1615271813" + }, + { + "chainId": 1, + "address": "0xdc5864ede28bd4405aa04d93e05a0531797d9d59", + "name": "Falcon Project", + "symbol": "FNT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/11579/thumb/falcon_ava_black.png?1591317863" + }, + { + "chainId": 1, + "address": "0x126c121f99e1e211df2e5f8de2d96fa36647c855", + "name": "DEGEN Index", + "symbol": "DEGEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14143/thumb/alpha_logo.png?1614651244" + }, + { + "chainId": 1, + "address": "0xcf3c8be2e2c42331da80ef210e9b1b307c03d36a", + "name": "BEPRO Network", + "symbol": "BEPRO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/10251/thumb/logo.png?1610592699" + }, + { + "chainId": 1, + "address": "0xdc349913d53b446485e98b76800b6254f43df695", + "name": "Bezoge Earth", + "symbol": "BEZOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15639/thumb/token-logo.png?1621408212" + }, + { + "chainId": 1, + "address": "0x474021845c4643113458ea4414bdb7fb74a01a77", + "name": "Uno Re", + "symbol": "UNO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15073/thumb/c0vbqVE.png?1632814516" + }, + { + "chainId": 1, + "address": "0x7ae0d42f23c33338de15bfa89c7405c068d9dc0a", + "name": "Shibaverse", + "symbol": "VERSE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18407/thumb/logo_200.png?1631795328" + }, + { + "chainId": 1, + "address": "0x3212b29e33587a00fb1c83346f5dbfa69a458923", + "name": "The Tokenized Bitcoin", + "symbol": "IMBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10702/thumb/imbtc.png?1585124381" + }, + { + "chainId": 1, + "address": "0xf0f9d895aca5c8678f706fb8216fa22957685a13", + "name": "Cult DAO", + "symbol": "CULT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23331/thumb/quxZPrbC_400x400.jpg?1643880172" + }, + { + "chainId": 1, + "address": "0xd8912c10681d8b21fd3742244f44658dba12264e", + "name": "Pluton", + "symbol": "PLU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1241/thumb/pluton.png?1548331624" + }, + { + "chainId": 1, + "address": "0xc5102fe9359fd9a28f877a67e36b0f050d81a3cc", + "name": "Hop Protocol", + "symbol": "HOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25445/thumb/hop.png?1665541677" + }, + { + "chainId": 1, + "address": "0x44017598f2af1bd733f9d87b5017b4e7c1b28dde", + "name": "pSTAKE Staked ATOM", + "symbol": "STKATOM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/18484/thumb/stkATOM_-_128px.png?1634978065" + }, + { + "chainId": 1, + "address": "0xa8c8cfb141a3bb59fea1e2ea6b79b5ecbcd7b6ca", + "name": "Syntropy", + "symbol": "NOIA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3269/thumb/Component_1.png?1608275724" + }, + { + "chainId": 1, + "address": "0xa3c22370de5f9544f0c4de126b1e46ceadf0a51b", + "name": "Stratis", + "symbol": "STRAX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/531/thumb/stratis.png?1547034209" + }, + { + "chainId": 1, + "address": "0xd084944d3c05cd115c09d072b9f44ba3e0e45921", + "name": "Manifold Finance", + "symbol": "FOLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15928/thumb/Manifold.png?1622439811" + }, + { + "chainId": 1, + "address": "0x58b6a8a3302369daec383334672404ee733ab239", + "name": "Livepeer", + "symbol": "LPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7137/thumb/logo-circle-green.png?1619593365" + }, + { + "chainId": 1, + "address": "0xddac9c604ba6bc4acec0fbb485b83f390ecf2f31", + "name": "CyOp Protocol", + "symbol": "CYOP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20672/thumb/cyop.png?1637549090" + }, + { + "chainId": 1, + "address": "0x40615b82999b8aa46803f11493bedab0314eb5e7", + "name": "Honey Deluxe", + "symbol": "HONEYD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21164/thumb/honeyd.png?1638530042" + }, + { + "chainId": 1, + "address": "0xfe18be6b3bd88a2d2a7f928d00292e7a9963cfc6", + "name": "sBTC", + "symbol": "SBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8838/thumb/sBTC.png?1616149734" + }, + { + "chainId": 1, + "address": "0x56694577564fdd577a0abb20fe95c1e2756c2a11", + "name": "AdaSwap", + "symbol": "ASW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24453/thumb/rA5cmPtX_400x400.jpg?1647677878" + }, + { + "chainId": 1, + "address": "0x16eccfdbb4ee1a85a33f3a9b21175cd7ae753db4", + "name": "Router Protocol", + "symbol": "ROUTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13709/thumb/route_token_200x200-19.png?1611057698" + }, + { + "chainId": 1, + "address": "0xcbc1aa6961b28cccb11e1cddd84ad8b42ec920b1", + "name": "ZEUS10000", + "symbol": "ZEUS10000", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/22559/thumb/2022-01-11_22.10.11.jpg?1642056602" + }, + { + "chainId": 1, + "address": "0x58fad9e3c3ae54c9ba98c3f0e4bf88ab3e8cf3c5", + "name": "SpaceY 2025", + "symbol": "SPAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20499/thumb/spacey2025.PNG?1637132488" + }, + { + "chainId": 1, + "address": "0x038a68ff68c393373ec894015816e33ad41bd564", + "name": "Glitch Protocol", + "symbol": "GLCH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13712/thumb/glitch_logo.jpeg?1611100011" + }, + { + "chainId": 1, + "address": "0x32a7c02e79c4ea1008dd6564b35f131428673c41", + "name": "Crust Network", + "symbol": "CRU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12549/thumb/sAB3KVzD_400x400.jpg?1600680411" + }, + { + "chainId": 1, + "address": "0x3832d2f059e55934220881f831be501d180671a7", + "name": "renDOGE", + "symbol": "RENDOGE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13796/thumb/Dogecoin.jpg?1628072827" + }, + { + "chainId": 1, + "address": "0x64aa3364f17a4d01c6f1751fd97c2bd3d7e7f1d5", + "name": "Olympus", + "symbol": "OHM", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14483/thumb/token_OHM_%281%29.png?1628311611" + }, + { + "chainId": 1, + "address": "0xcd17fa52528f37facb3028688e62ec82d9417581", + "name": "Materium", + "symbol": "MTRM", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/24613/thumb/mtrm.png?1648373908" + }, + { + "chainId": 1, + "address": "0x44709a920fccf795fbc57baa433cc3dd53c44dbe", + "name": "DappRadar", + "symbol": "RADAR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20894/thumb/radar.png?1640306268" + }, + { + "chainId": 1, + "address": "0xec363faa5c4dd0e51f3d9b5d0101263760e7cdeb", + "name": "Instadapp WBTC", + "symbol": "IWBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/25784/thumb/iWBTC-100x100.png?1654055142" + }, + { + "chainId": 1, + "address": "0xb3319f5d18bc0d84dd1b4825dcde5d5f7266d407", + "name": "c0x", + "symbol": "CZRX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10644/thumb/czrx1.JPG?1581390510" + }, + { + "chainId": 1, + "address": "0x13b2f6928d7204328b0e8e4bcd0379aa06ea21fa", + "name": "Aave AMM WBTC", + "symbol": "AAMMWBTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17215/thumb/aAMMWBTC_2x.png?1626879028" + }, + { + "chainId": 1, + "address": "0x0100546f2cd4c9d97f798ffc9755e47865ff7ee6", + "name": "Alchemix ETH", + "symbol": "ALETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16271/thumb/uS04dyYy_400x400.jpeg?1663051098" + }, + { + "chainId": 1, + "address": "0x4d4f3715050571a447fffa2cd4cf091c7014ca5c", + "name": "Summer", + "symbol": "SUMMER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25365/thumb/summer.png?1651317403" + }, + { + "chainId": 1, + "address": "0x4f81c790581b240a5c948afd173620ecc8c71c8d", + "name": "Decentral Games Governance", + "symbol": "XDG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21176/thumb/xDG_Logo.png?1638508706" + }, + { + "chainId": 1, + "address": "0x73a83269b9bbafc427e76be0a2c1a1db2a26f4c2", + "name": "Civfund Stone", + "symbol": "0NE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25156/thumb/stone.png?1650462014" + }, + { + "chainId": 1, + "address": "0xbe9895146f7af43049ca1c1ae358b0541ea49704", + "name": "Coinbase Wrapped Staked ETH", + "symbol": "CBETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27008/thumb/cbeth.png?1661390066" + }, + { + "chainId": 1, + "address": "0x94e496474f1725f1c1824cb5bdb92d7691a4f03a", + "name": "Banana", + "symbol": "BANANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17521/thumb/banana-token-cg.png?1646285527" + }, + { + "chainId": 1, + "address": "0x1982b2f5814301d4e9a8b0201555376e62f82428", + "name": "Aave Interest Bearing STETH", + "symbol": "ASTETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24163/thumb/steth.jpg?1646634315" + }, + { + "chainId": 1, + "address": "0x075b1bb99792c9e1041ba13afef80c91a1e70fb3", + "name": "Curve fi renBTC wBTC sBTC", + "symbol": "CRVRENWSBTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11958/thumb/Curvefi_sbtcCrv_32.png?1596436054" + }, + { + "chainId": 1, + "address": "0xd2877702675e6ceb975b4a1dff9fb7baf4c91ea9", + "name": "Wrapped Terra Classic", + "symbol": "LUNC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13628/thumb/wluna.png?1610448334" + }, + { + "chainId": 1, + "address": "0x8798249c2e607446efb7ad49ec89dd1865ff4272", + "name": "xSUSHI", + "symbol": "XSUSHI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13725/thumb/xsushi.png?1612538526" + }, + { + "chainId": 1, + "address": "0x3155ba85d5f96b2d030a4966af206230e46849cb", + "name": "THORChain ERC20 ", + "symbol": "RUNE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13677/thumb/IMG_20210123_132049_458.png?1612179252" + }, + { + "chainId": 1, + "address": "0xa4bbe66f151b22b167127c770016b15ff97dd35c", + "name": "Umbria Network", + "symbol": "UMBR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14712/thumb/RX7VJg6.png?1617891954" + }, + { + "chainId": 1, + "address": "0x0d438f3b5175bebc262bf23753c1e53d03432bde", + "name": "Wrapped NXM", + "symbol": "WNXM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11890/thumb/wrapped-nexus-mutual.jpg?1595811559" + }, + { + "chainId": 1, + "address": "0x5198625a8abf34a0d2a1f262861ff3b3079302bf", + "name": "DeFi Forge", + "symbol": "FORGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28047/thumb/ForgeLogo200x200.jpg?1667274359" + }, + { + "chainId": 1, + "address": "0x21381e026ad6d8266244f2a583b35f9e4413fa2a", + "name": "Formation FI", + "symbol": "FORM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16145/thumb/FORM.png?1623119824" + }, + { + "chainId": 1, + "address": "0xfeb6d5238ed8f1d59dcab2db381aa948e625966d", + "name": "Doge TV", + "symbol": "DGTV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28050/thumb/532a5b9e-8294-4be1-be18-f04a2cf5f0a9.png?1667280533" + }, + { + "chainId": 1, + "address": "0xe7f72bc0252ca7b16dbb72eeee1afcdb2429f2dd", + "name": "NFTLaunch", + "symbol": "NFTL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18140/thumb/nftl.PNG?1630652662" + }, + { + "chainId": 1, + "address": "0xc6d1f1d5a46de07e73091f1c8793293b203f01a1", + "name": "Mission Helios", + "symbol": "HELIOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18295/thumb/helios.png?1644049696" + }, + { + "chainId": 1, + "address": "0x31c8eacbffdd875c74b94b077895bd78cf1e64a3", + "name": "Radicle", + "symbol": "RAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14013/thumb/radicle.png?1614402918" + }, + { + "chainId": 1, + "address": "0xce3f08e664693ca792cace4af1364d5e220827b2", + "name": "Saitama", + "symbol": "SAITAMA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16353/thumb/SOIKDUWf_400x400.jpeg?1661170022" + }, + { + "chainId": 1, + "address": "0x97872eafd79940c7b24f7bcc1eadb1457347adc9", + "name": "Strips Finance", + "symbol": "STRP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18327/thumb/Logo-Strips-200-x-200px---without-words.png?1631543556" + }, + { + "chainId": 1, + "address": "0x3893b9422cd5d70a81edeffe3d5a1c6a978310bb", + "name": "Mithril", + "symbol": "MITH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3484/thumb/mithril.png?1548085086" + }, + { + "chainId": 1, + "address": "0xfb559ce67ff522ec0b9ba7f5dc9dc7ef6c139803", + "name": "Probit", + "symbol": "PROB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6765/thumb/ProBit-Exchange-logo.png?1547043029" + }, + { + "chainId": 1, + "address": "0x7d29a64504629172a429e64183d6673b9dacbfce", + "name": "Vectorspace AI", + "symbol": "VXV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2063/thumb/vectorspace-ai-logo.jpeg?1547036362" + }, + { + "chainId": 1, + "address": "0x888e88e71378133b7ada5a90c08bc97d772a0a28", + "name": "SheBollETH Commerce", + "symbol": "SBECOM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18186/thumb/sbe.PNG?1630905841" + }, + { + "chainId": 1, + "address": "0xf94b5c5651c888d928439ab6514b93944eee6f48", + "name": "Yield App", + "symbol": "YLD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13365/thumb/Google_Play_Store_Icon.png?1657012535" + }, + { + "chainId": 1, + "address": "0xfa372ff1547fa1a283b5112a4685f1358ce5574d", + "name": "Bonded dAMM", + "symbol": "BDAMM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27646/thumb/t9rbdwlR_400x400.jpg?1665022129" + }, + { + "chainId": 1, + "address": "0x2a9bdcff37ab68b95a53435adfd8892e86084f93", + "name": "Alpha Quark", + "symbol": "AQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12872/thumb/alpha_quark_logo.png?1605169527" + }, + { + "chainId": 1, + "address": "0xb056c38f6b7dc4064367403e26424cd2c60655e1", + "name": "CEEK Smart VR", + "symbol": "CEEK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2581/thumb/ceek-smart-vr-token-logo.png?1547036714" + }, + { + "chainId": 1, + "address": "0xf5cfbc74057c610c8ef151a439252680ac68c6dc", + "name": "Octopus Network", + "symbol": "OCT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18025/thumb/octopus_network.png?1630290273" + }, + { + "chainId": 1, + "address": "0xd13c7342e1ef687c5ad21b27c2b65d772cab5c8c", + "name": "Ultra", + "symbol": "UOS", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/4480/thumb/Ultra.png?1563356418" + }, + { + "chainId": 1, + "address": "0xcb8d1260f9c92a3a545d409466280ffdd7af7042", + "name": "NFT Protocol", + "symbol": "NFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12174/thumb/nftprotocol_32.png?1597818115" + }, + { + "chainId": 1, + "address": "0x7d5121505149065b562c789a0145ed750e6e8cdd", + "name": "Victoria VR", + "symbol": "VR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21178/thumb/vr.png?1638496975" + }, + { + "chainId": 1, + "address": "0x6b0b3a982b4634ac68dd83a4dbf02311ce324181", + "name": "Artificial Liquid Intelligence", + "symbol": "ALI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22062/thumb/alethea-logo-transparent-colored.png?1642748848" + }, + { + "chainId": 1, + "address": "0x71ab77b7dbb4fa7e017bc15090b2163221420282", + "name": "Highstreet", + "symbol": "HIGH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18973/thumb/logosq200200Coingecko.png?1634090470" + }, + { + "chainId": 1, + "address": "0x1e2f15302b90edde696593607b6bd444b64e8f02", + "name": "Shiryo", + "symbol": "SHIRYO-INU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19652/thumb/shiryo_inu.png?1648267828" + }, + { + "chainId": 1, + "address": "0xfc82bb4ba86045af6f327323a46e80412b91b27d", + "name": "Prom", + "symbol": "PROM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8825/thumb/Ticker.png?1657632943" + }, + { + "chainId": 1, + "address": "0x056fd409e1d7a124bd7017459dfea2f387b6d5cd", + "name": "Gemini Dollar", + "symbol": "GUSD", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/5992/thumb/gemini-dollar-gusd.png?1536745278" + }, + { + "chainId": 1, + "address": "0x723cbfc05e2cfcc71d3d89e770d32801a5eef5ab", + "name": "Bitcoin Pro", + "symbol": "BTCP", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3545/thumb/DSiD9ZhWsAE_8cS.png?1547038353" + }, + { + "chainId": 1, + "address": "0x2f0f622a93c85c43fd47f4ab119360f5846026c4", + "name": "MatsuSwap", + "symbol": "MATSUSWAP", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/28041/thumb/200x200-1.png?1667202469" + }, + { + "chainId": 1, + "address": "0x6adb2e268de2aa1abf6578e4a8119b960e02928f", + "name": "ShibaDoge", + "symbol": "SHIBDOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22018/thumb/5HMWoFW0_400x400.jpg?1640596392" + }, + { + "chainId": 1, + "address": "0x85eee30c52b0b379b046fb0f85f4f3dc3009afec", + "name": "Keep Network", + "symbol": "KEEP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3373/thumb/IuNzUb5b_400x400.jpg?1589526336" + }, + { + "chainId": 1, + "address": "0x7c07f7abe10ce8e33dc6c5ad68fe033085256a84", + "name": "Interest Compounding ETH Index", + "symbol": "ICETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24483/thumb/icETH-token-logo.png?1647826356" + }, + { + "chainId": 1, + "address": "0xc581b735a1688071a1746c968e0798d642ede491", + "name": "Euro Tether", + "symbol": "EURT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/17385/thumb/Tether_full_logo_dm.png?1627537298" + }, + { + "chainId": 1, + "address": "0x37941b3fdb2bd332e667d452a58be01bcacb923e", + "name": "FREN", + "symbol": "FREN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20259/thumb/5oR6DSf.png?1636702537" + }, + { + "chainId": 1, + "address": "0x2596825a84888e8f24b747df29e11b5dd03c81d7", + "name": "Faith Tribe", + "symbol": "FTRB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23939/thumb/ym1Hf4x2_400x400.jpg?1645766940" + }, + { + "chainId": 1, + "address": "0x42bbfa2e77757c645eeaad1655e0911a7553efbc", + "name": "Boba Network", + "symbol": "BOBA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20285/thumb/BOBA.png?1636811576" + }, + { + "chainId": 1, + "address": "0x3472a5a71965499acd81997a54bba8d852c6e53d", + "name": "Badger DAO", + "symbol": "BADGER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13287/thumb/badger_dao_logo.jpg?1607054976" + }, + { + "chainId": 1, + "address": "0x4cc19356f2d37338b9802aa8e8fc58b0373296e7", + "name": "SelfKey", + "symbol": "KEY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2034/thumb/selfkey.png?1548608934" + }, + { + "chainId": 1, + "address": "0x6c28aef8977c9b773996d0e8376d2ee379446f2f", + "name": "Quickswap OLD ", + "symbol": "QUICK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13970/thumb/1_pOU6pBMEmiL-ZJVb0CYRjQ.png?1613386659" + }, + { + "chainId": 1, + "address": "0x20e7125677311fca903a8897042b9983f22ea295", + "name": "Freeway", + "symbol": "FWT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13012/thumb/S5h7MHR.png?1652862323" + }, + { + "chainId": 1, + "address": "0xed04915c23f00a313a544955524eb7dbd823143d", + "name": "Alchemy Pay", + "symbol": "ACH", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/12390/thumb/ACH_%281%29.png?1599691266" + }, + { + "chainId": 1, + "address": "0xdf801468a808a32656d2ed2d2d80b72a129739f4", + "name": "Somnium Space CUBEs", + "symbol": "CUBE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/10687/thumb/CUBE_icon.png?1617026861" + }, + { + "chainId": 1, + "address": "0x217ddead61a42369a266f1fb754eb5d3ebadc88a", + "name": "Don key", + "symbol": "DON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15482/thumb/donkey_logo.jpg?1621012824" + }, + { + "chainId": 1, + "address": "0xec213f83defb583af3a000b1c0ada660b1902a0f", + "name": "Presearch", + "symbol": "PRE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1299/thumb/presearch.png?1548331942" + }, + { + "chainId": 1, + "address": "0xcb8fb2438a805664cd8c3e640b85ac473da5be87", + "name": "ClinTex CTi", + "symbol": "CTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13266/thumb/CTI.png?1606817542" + }, + { + "chainId": 1, + "address": "0xee06a81a695750e71a662b51066f2c74cf4478a0", + "name": "Decentral Games Old ", + "symbol": "DG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13267/thumb/%28Old%29_DG.png?1639209538" + }, + { + "chainId": 1, + "address": "0xda007777d86ac6d989cc9f79a73261b3fc5e0da0", + "name": "DAppNode", + "symbol": "NODE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17187/thumb/36789279.png?1626828678" + }, + { + "chainId": 1, + "address": "0x6fb3e0a217407efff7ca062d46c26e5d60a14d69", + "name": "IoTeX", + "symbol": "IOTX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/3334/thumb/iotex-logo.png?1547037941" + }, + { + "chainId": 1, + "address": "0x9fa69536d1cda4a04cfb50688294de75b505a9ae", + "name": "DeRace", + "symbol": "DERC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17438/thumb/DERC_logo_coingecko.png?1665714278" + }, + { + "chainId": 1, + "address": "0xf57e7e7c23978c3caec3c3548e3d615c346e79ff", + "name": "ImmutableX", + "symbol": "IMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17233/thumb/immutableX-symbol-BLK-RGB.png?1665110648" + }, + { + "chainId": 1, + "address": "0xc64500dd7b0f1794807e67802f8abbf5f8ffb054", + "name": "Locus Chain", + "symbol": "LOCUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6903/thumb/32169759_2050428658545017_7287666225423843328_n.jpg?1547043264" + }, + { + "chainId": 1, + "address": "0x2565ae0385659badcada1031db704442e1b69982", + "name": "Assemble Protocol", + "symbol": "ASM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11605/thumb/gpvrlkSq_400x400_%281%29.jpg?1591775789" + }, + { + "chainId": 1, + "address": "0x8e30ea2329d95802fd804f4291220b0e2f579812", + "name": "Decentralized Vulnerability Platform", + "symbol": "DVP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9424/thumb/4520.png?1568598223" + }, + { + "chainId": 1, + "address": "0x5aa158404fed6b4730c13f49d3a7f820e14a636f", + "name": "ULTRON", + "symbol": "ULX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26977/thumb/ULX.png?1661168951" + }, + { + "chainId": 1, + "address": "0xf0939011a9bb95c3b791f0cb546377ed2693a574", + "name": "0 exchange", + "symbol": "ZERO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13706/thumb/0.exchange_%28logo%29.jpg?1617070530" + }, + { + "chainId": 1, + "address": "0xfaba6f8e4a5e8ab82f62fe7c39859fa577269be3", + "name": "Ondo Finance", + "symbol": "ONDO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26580/thumb/YUBxfjcj_400x400.jpg?1658888594" + }, + { + "chainId": 1, + "address": "0xf941d3aabf2ee0f5589e68ba6047b8329592b366", + "name": "Good Dog", + "symbol": "HEEL", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27138/thumb/Heel_Circle.png?1662029905" + }, + { + "chainId": 1, + "address": "0x188e817b02e635d482ae4d81e25dda98a97c4a42", + "name": "Lithium Finance", + "symbol": "LITH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17278/thumb/Lithium_Logo-03200x200.png?1627018557" + }, + { + "chainId": 1, + "address": "0x08d967bb0134f2d07f7cfb6e246680c53927dd30", + "name": "MATH", + "symbol": "MATH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11335/thumb/2020-05-19-token-200.png?1589940590" + }, + { + "chainId": 1, + "address": "0xba50933c268f567bdc86e1ac131be072c6b0b71a", + "name": "ARPA", + "symbol": "ARPA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8506/thumb/9u0a23XY_400x400.jpg?1559027357" + }, + { + "chainId": 1, + "address": "0x6399c842dd2be3de30bf99bc7d1bbf6fa3650e70", + "name": "Premia", + "symbol": "PREMIA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13962/thumb/apple-touch-icon.png?1623679482" + }, + { + "chainId": 1, + "address": "0x6ef6610d24593805144d73b13d4405e00a4e4ac7", + "name": "Die Protocol", + "symbol": "DIE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27903/thumb/newlogo.jpg?1666334549" + }, + { + "chainId": 1, + "address": "0x993864e43caa7f7f12953ad6feb1d1ca635b875f", + "name": "SingularityDAO", + "symbol": "SDAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15385/thumb/200x200_logo.png?1665743635" + }, + { + "chainId": 1, + "address": "0x001a8ffcb0f03e99141652ebcdecdb0384e3bd6c", + "name": "Polker", + "symbol": "PKR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16803/thumb/200x200-PKR_Chip.png?1625589565" + }, + { + "chainId": 1, + "address": "0x72a66e54b66892ae3bbe54df7bb7dd5ae927a6f9", + "name": "Crypto Village Accelerator CVAG", + "symbol": "CVAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17124/thumb/cvag.PNG?1626401266" + }, + { + "chainId": 1, + "address": "0xadd5e881984783dd432f80381fb52f45b53f3e70", + "name": "Vite", + "symbol": "VITE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4513/thumb/Vite.png?1558014583" + }, + { + "chainId": 1, + "address": "0x7815bda662050d84718b988735218cffd32f75ea", + "name": "Yel Finance", + "symbol": "YEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17429/thumb/Logo200.png?1627613989" + }, + { + "chainId": 1, + "address": "0xee9e7bb7e55bbc86414047b61d65c9c0d91ffbd0", + "name": "Fracton Protocol", + "symbol": "FT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26809/thumb/CtH9UlRl_400x400.jpeg?1660227771" + }, + { + "chainId": 1, + "address": "0xf1ca9cb74685755965c7458528a36934df52a3ef", + "name": "AVINOC", + "symbol": "AVINOC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4659/thumb/qX7fh69Q_400x400-1.jpg?1636680685" + }, + { + "chainId": 1, + "address": "0xc8807f0f5ba3fa45ffbdc66928d71c5289249014", + "name": "Ispolink", + "symbol": "ISP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15283/thumb/isolink.PNG?1620352267" + }, + { + "chainId": 1, + "address": "0xde5ed76e7c05ec5e4572cfc88d1acea165109e44", + "name": "DEUS Finance", + "symbol": "DEUS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18778/thumb/DEUS-logo-200x200.png?1646318385" + }, + { + "chainId": 1, + "address": "0xdbdb4d16eda451d0503b854cf79d55697f90c8df", + "name": "Alchemix", + "symbol": "ALCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14113/thumb/Alchemix.png?1614409874" + }, + { + "chainId": 1, + "address": "0x84ca8bc7997272c7cfb4d0cd3d55cd942b3c9419", + "name": "DIA", + "symbol": "DIA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11955/thumb/Token_Logo.png?1669981526" + }, + { + "chainId": 1, + "address": "0x464fdb8affc9bac185a7393fd4298137866dcfb8", + "name": "Realm", + "symbol": "REALM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18366/thumb/realm.PNG?1631665838" + }, + { + "chainId": 1, + "address": "0x00aba6fe5557de1a1d565658cbddddf7c710a1eb", + "name": "EasyFi V2", + "symbol": "EZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12742/thumb/Logo_Icon.png?1624471467" + }, + { + "chainId": 1, + "address": "0x00c83aecc790e8a4453e5dd3b0b4b3680501a7a7", + "name": "SKALE", + "symbol": "SKL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13245/thumb/SKALE_token_300x300.png?1606789574" + }, + { + "chainId": 1, + "address": "0x4ae2cd1f5b8806a973953b76f9ce6d5fab9cdcfd", + "name": "eHive", + "symbol": "EHIVE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27239/thumb/ehive_200x200.png?1662714434" + }, + { + "chainId": 1, + "address": "0x0d88ed6e74bbfd96b831231638b66c05571e824f", + "name": "Aventus", + "symbol": "AVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/901/thumb/Aventus.png?1625122968" + }, + { + "chainId": 1, + "address": "0xc5a9bc46a7dbe1c6de493e84a18f02e70e2c5a32", + "name": "WORLD CUP INU", + "symbol": "WCI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27489/thumb/2022-09-26_20.55.02-removebg-preview.png?1664253723" + }, + { + "chainId": 1, + "address": "0x8e6cd950ad6ba651f6dd608dc70e5886b1aa6b24", + "name": "StarLink", + "symbol": "STARL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16824/thumb/ZxJbRWJ.png?1625177900" + }, + { + "chainId": 1, + "address": "0x1571ed0bed4d987fe2b498ddbae7dfa19519f651", + "name": "iFARM", + "symbol": "IFARM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14472/thumb/ifarm.png?1616389133" + }, + { + "chainId": 1, + "address": "0x5b1d655c93185b06b00f7925791106132cb3ad75", + "name": "DarkMatter", + "symbol": "DMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23989/thumb/dmt.png?1645948367" + }, + { + "chainId": 1, + "address": "0x50bc2ecc0bfdf5666640048038c1aba7b7525683", + "name": "carVertical", + "symbol": "CV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2098/thumb/carvertical.png?1547738903" + }, + { + "chainId": 1, + "address": "0x607f4c5bb672230e8672085532f7e901544a7375", + "name": "iExec RLC", + "symbol": "RLC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/646/thumb/pL1VuXm.png?1604543202" + }, + { + "chainId": 1, + "address": "0xccba0b2bc4babe4cbfb6bd2f1edc2a9e86b7845f", + "name": "Winter", + "symbol": "WINTER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25367/thumb/winter.png?1651317666" + }, + { + "chainId": 1, + "address": "0x505b5eda5e25a67e1c24a2bf1a527ed9eb88bf04", + "name": "Coinweb", + "symbol": "CWEB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21607/thumb/Logo_200x200.png?1641566717" + }, + { + "chainId": 1, + "address": "0x4c3bae16c79c30eeb1004fb03c878d89695e3a99", + "name": "Autumn", + "symbol": "AUTUMN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25366/thumb/autumn.png?1651317533" + }, + { + "chainId": 1, + "address": "0xc55126051b22ebb829d00368f4b12bde432de5da", + "name": "Redacted", + "symbol": "BTRFLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26745/thumb/redacted_v2.jpg?1660011507" + }, + { + "chainId": 1, + "address": "0xf04af3f4e4929f7cd25a751e6149a3318373d4fe", + "name": "Spring", + "symbol": "SPRING", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25364/thumb/spring.png?1651317225" + }, + { + "chainId": 1, + "address": "0xf17e65822b568b3903685a7c9f496cf7656cc6c2", + "name": "Biconomy", + "symbol": "BICO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21061/thumb/biconomy_logo.jpg?1638269749" + }, + { + "chainId": 1, + "address": "0x6468e79a80c0eab0f9a2b574c8d5bc374af59414", + "name": "e Radix", + "symbol": "EXRD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13145/thumb/exrd_logo.png?1605662677" + }, + { + "chainId": 1, + "address": "0x4b520c812e8430659fc9f12f6d0c39026c83588d", + "name": "Decentral Games", + "symbol": "DG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21173/thumb/Decentral_Games_Logo-1.png?1638441275" + }, + { + "chainId": 1, + "address": "0xf05e58fcea29ab4da01a495140b349f8410ba904", + "name": "CLever CVX", + "symbol": "CLEVCVX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27902/thumb/%E6%88%AA%E5%B1%8F2022-10-21_%E4%B8%8A%E5%8D%8812.43.46.png?1666334411" + }, + { + "chainId": 1, + "address": "0xfe2e637202056d30016725477c5da089ab0a043a", + "name": "sETH2", + "symbol": "SETH2", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16569/thumb/emerald256.png?1624494960" + }, + { + "chainId": 1, + "address": "0xe2f2a5c287993345a840db3b0845fbc70f5935a5", + "name": "mStable USD", + "symbol": "MUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11576/thumb/mStable_USD.png?1595591803" + }, + { + "chainId": 1, + "address": "0x3dd98c8a089dbcff7e8fc8d4f532bd493501ab7f", + "name": "Town Star", + "symbol": "TOWN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/19581/thumb/town.png?1635840875" + }, + { + "chainId": 1, + "address": "0x888888848b652b3e3a0f34c96e00eec0f3a23f72", + "name": "Alien Worlds", + "symbol": "TLM", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/14676/thumb/kY-C4o7RThfWrDQsLCAG4q4clZhBDDfJQVhWUEKxXAzyQYMj4Jmq1zmFwpRqxhAJFPOa0AsW_PTSshoPuMnXNwq3rU7Imp15QimXTjlXMx0nC088mt1rIwRs75GnLLugWjSllxgzvQ9YrP4tBgclK4_rb17hjnusGj_c0u2fx0AvVokjSNB-v2poTj0xT9BZRCbzRE3-lF1.jpg?1617700061" + }, + { + "chainId": 1, + "address": "0x5218e472cfcfe0b64a064f055b43b4cdc9efd3a6", + "name": "unFederalReserve", + "symbol": "ERSDL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12975/thumb/logo_eRSDL.png?1625755665" + }, + { + "chainId": 1, + "address": "0x5f98805a4e8be255a32880fdec7f6728c6568ba0", + "name": "Liquity USD", + "symbol": "LUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14666/thumb/Group_3.png?1617631327" + }, + { + "chainId": 1, + "address": "0xc0c293ce456ff0ed870add98a0828dd4d2903dbf", + "name": "Aura Finance", + "symbol": "AURA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25942/thumb/logo.png?1654784187" + }, + { + "chainId": 1, + "address": "0x66c0dded8433c9ea86c8cf91237b14e10b4d70b7", + "name": "Mars", + "symbol": "MARS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13654/thumb/MARS.png?1610575403" + }, + { + "chainId": 1, + "address": "0x298d492e8c1d909d3f63bc4a36c66c64acb3d695", + "name": "PolkaBridge", + "symbol": "PBR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13744/thumb/symbol-whitebg200x200.png?1611377553" + }, + { + "chainId": 1, + "address": "0x80c62fe4487e1351b47ba49809ebd60ed085bf52", + "name": "Clover Finance", + "symbol": "CLV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15278/thumb/photo_2022-03-24_10-22-33.jpg?1648531786" + }, + { + "chainId": 1, + "address": "0x5165d24277cd063f5ac44efd447b27025e888f37", + "name": "Aave YFI", + "symbol": "AYFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17257/thumb/aYFI_2x.png?1626957974" + }, + { + "chainId": 1, + "address": "0xa685a61171bb30d4072b338c80cb7b2c865c873e", + "name": "Aave MANA", + "symbol": "AMANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14267/thumb/aMANA.f89a1098.png?1615528680" + }, + { + "chainId": 1, + "address": "0x6fce4a401b6b80ace52baaefe4421bd188e76f6f", + "name": "Aave MANA v1", + "symbol": "AMANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11730/thumb/aMANA.png?1593084474" + }, + { + "chainId": 1, + "address": "0xd417144312dbf50465b1c641d016962017ef6240", + "name": "Covalent", + "symbol": "CQT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14168/thumb/covalent-cqt.png?1624545218" + }, + { + "chainId": 1, + "address": "0x6c5024cd4f8a59110119c56f8933403a539555eb", + "name": "Aave SUSD", + "symbol": "ASUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14266/thumb/aSUSD.9b00ffc6.png?1615528241" + }, + { + "chainId": 1, + "address": "0xfb5c6815ca3ac72ce9f5006869ae67f18bf77006", + "name": "pSTAKE Finance", + "symbol": "PSTAKE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23931/thumb/PSTAKE_Dark.png?1645709930" + }, + { + "chainId": 1, + "address": "0x8686525d6627a25c68de82c228448f43c97999f2", + "name": "Lilly Token", + "symbol": "LY", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23787/thumb/jQlMieu.png?1645437427" + }, + { + "chainId": 1, + "address": "0x06a00715e6f92210af9d7680b584931faf71a833", + "name": "Chronicle", + "symbol": "XNL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18413/thumb/xnl_logo.png?1633517024" + }, + { + "chainId": 1, + "address": "0xa62cc35625b0c8dc1faea39d33625bb4c15bd71c", + "name": "StormX", + "symbol": "STMX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1369/thumb/StormX.png?1603113002" + }, + { + "chainId": 1, + "address": "0xed0d5747a9ab03a75fbfec3228cd55848245b75d", + "name": "e Money", + "symbol": "NGM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13722/thumb/logo-200x200.jpg?1626095888" + }, + { + "chainId": 1, + "address": "0xd26114cd6ee289accf82350c8d8487fedb8a0c07", + "name": "OMG Network", + "symbol": "OMG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/776/thumb/OMG_Network.jpg?1591167168" + }, + { + "chainId": 1, + "address": "0xf1f955016ecbcd7321c7266bccfb96c68ea5e49b", + "name": "Rally", + "symbol": "RLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12843/thumb/image.png?1611212077" + }, + { + "chainId": 1, + "address": "0x7865af71cf0b288b4e7f654f4f7851eb46a2b7f8", + "name": "Sentivate", + "symbol": "SNTVT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7383/thumb/2x9veCp.png?1598409975" + }, + { + "chainId": 1, + "address": "0x429d83bb0dcb8cdd5311e34680adc8b12070a07f", + "name": "PlatonCoin", + "symbol": "PLTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7178/thumb/PLTC.png?1616126045" + }, + { + "chainId": 1, + "address": "0xe13879194578c6f1a591a96c45b65022c43cec07", + "name": "The meme finance", + "symbol": "MEFI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27837/thumb/57678426-EC89-4BA2-87AB-301B7D915F1B.jpeg?1666056561" + }, + { + "chainId": 1, + "address": "0x0b38210ea11411557c13457d4da7dc6ea731b88a", + "name": "API3", + "symbol": "API3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13256/thumb/api3.jpg?1606751424" + }, + { + "chainId": 1, + "address": "0xae7ab96520de3a18e5e111b5eaab095312d7fe84", + "name": "Lido Staked Ether", + "symbol": "STETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/13442/thumb/steth_logo.png?1608607546" + }, + { + "chainId": 1, + "address": "0xa1faa113cbe53436df28ff0aee54275c13b40975", + "name": "Alpha Venture DAO", + "symbol": "ALPHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12738/thumb/AlphaToken_256x256.png?1617160876" + }, + { + "chainId": 1, + "address": "0x3085154623f51b00dedfc6ceeb5197277a66b17b", + "name": "NFTY DeFi Protocol", + "symbol": "NFTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18584/thumb/nfty_logo.png?1632551145" + }, + { + "chainId": 1, + "address": "0xf1b99e3e573a1a9c5e6b2ce818b617f0e664e86b", + "name": "Opyn Squeeth", + "symbol": "OSQTH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22806/thumb/DyVT5XPV_400x400.jpg?1642656239" + }, + { + "chainId": 1, + "address": "0x7dd9c5cba05e151c895fde1cf355c9a1d5da6429", + "name": "Golem", + "symbol": "GLM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/542/thumb/Golem_Submark_Positive_RGB.png?1606392013" + }, + { + "chainId": 1, + "address": "0x92868a5255c628da08f550a858a802f5351c5223", + "name": "Cross Chain Bridge", + "symbol": "BRIDGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20223/thumb/0x92868A5255C628dA08F550a858A802f5351C5223.png?1636684446" + }, + { + "chainId": 1, + "address": "0x66d28cb58487a7609877550e1a34691810a6b9fc", + "name": "Koinos", + "symbol": "KOIN", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/13116/thumb/koinos-mark-circle-250px.png?1614870541" + }, + { + "chainId": 1, + "address": "0xfa05a73ffe78ef8f1a739473e462c54bae6567d9", + "name": "Lunyr", + "symbol": "LUN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/735/thumb/lunyr.png?1547976492" + }, + { + "chainId": 1, + "address": "0xb64ef51c888972c908cfacf59b47c1afbc0ab8ac", + "name": "Storj", + "symbol": "STORJ", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/949/thumb/storj.png?1547034811" + }, + { + "chainId": 1, + "address": "0xa2120b9e674d3fc3875f415a7df52e382f141225", + "name": "Automata", + "symbol": "ATA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15985/thumb/ATA.jpg?1622535745" + }, + { + "chainId": 1, + "address": "0x9813037ee2218799597d83d4a5b6f3b6778218d9", + "name": "Bone ShibaSwap", + "symbol": "BONE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16916/thumb/bone_icon.png?1625625505" + }, + { + "chainId": 1, + "address": "0xf2cee90309418353a57717eca26c4f8754f0d84e", + "name": "BitcoinBrand", + "symbol": "BTCB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6607/thumb/y76xcDSr_400x400.jpg?1547042811" + }, + { + "chainId": 1, + "address": "0x51cb253744189f11241becb29bedd3f1b5384fdb", + "name": "Dimitra", + "symbol": "DMTR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18530/thumb/HqEiru32_400x400.jpg?1632293527" + }, + { + "chainId": 1, + "address": "0xaaa7a10a8ee237ea61e8ac46c50a8db8bcc1baaa", + "name": "QANplatform", + "symbol": "QANX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15977/thumb/qanx.png?1637574290" + }, + { + "chainId": 1, + "address": "0xa117000000f279d81a1d3cc75430faa017fa5a2e", + "name": "Aragon", + "symbol": "ANT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/681/thumb/JelZ58cv_400x400.png?1601449653" + }, + { + "chainId": 1, + "address": "0xec67005c4e498ec7f55e092bd1d35cbc47c91892", + "name": "Enzyme", + "symbol": "MLN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/605/thumb/Enzyme_Icon_Secondary.png?1611576629" + }, + { + "chainId": 1, + "address": "0x1ceb5cb57c4d4e2b2433641b95dd330a33185a44", + "name": "Keep3rV1", + "symbol": "KP3R", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12966/thumb/kp3r_logo.jpg?1607057458" + }, + { + "chainId": 1, + "address": "0xc52c326331e9ce41f04484d3b5e5648158028804", + "name": "Unizen", + "symbol": "ZCX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14830/thumb/7xjpHaG.png?1618564961" + }, + { + "chainId": 1, + "address": "0x2a8e1e676ec238d8a992307b495b45b3feaa5e86", + "name": "Origin Dollar", + "symbol": "OUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12589/thumb/ousd-logo-200x200.png?1600943287" + }, + { + "chainId": 1, + "address": "0x38e4adb44ef08f22f5b5b76a8f0c2d0dcbe7dca1", + "name": "PowerPool Concentrated Voting Power", + "symbol": "CVP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12266/thumb/Powerpool.jpg?1598621373" + }, + { + "chainId": 1, + "address": "0x83e6f1e41cdd28eaceb20cb649155049fac3d5aa", + "name": "Polkastarter", + "symbol": "POLS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12648/thumb/polkastarter.png?1609813702" + }, + { + "chainId": 1, + "address": "0xdc9ac3c20d1ed0b540df9b1fedc10039df13f99c", + "name": "Utrust", + "symbol": "UTK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1824/thumb/300x300_logo.png?1570520533" + }, + { + "chainId": 1, + "address": "0x0202be363b8a4820f3f4de7faf5224ff05943ab1", + "name": "UniLend Finance", + "symbol": "UFT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12819/thumb/UniLend_Finance_logo_PNG.png?1602748658" + }, + { + "chainId": 1, + "address": "0xe1d7c7a4596b038ced2a84bf65b8647271c53208", + "name": "NFTY Labs", + "symbol": "NFTY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18741/thumb/logo_%281%29.png?1643188469" + }, + { + "chainId": 1, + "address": "0xbc396689893d065f41bc2c6ecbee5e0085233447", + "name": "Perpetual Protocol", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12381/thumb/60d18e06844a844ad75901a9_mark_only_03.png?1628674771" + }, + { + "chainId": 1, + "address": "0xa2b4c0af19cc16a6cfacce81f192b024d625817d", + "name": "Kishu Inu", + "symbol": "KISHU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14890/thumb/uVLzCoP.png?1622445866" + }, + { + "chainId": 1, + "address": "0xd7c302fc3ac829c7e896a32c4bd126f3e8bd0a1f", + "name": "Bit2Me", + "symbol": "B2M", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19848/thumb/b2m-circle-solid-default.png?1636036332" + }, + { + "chainId": 1, + "address": "0x490e3f4af13e1616ec97a8c6600c1061a8d0253e", + "name": "Terran Coin", + "symbol": "TRR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15351/thumb/TERRAN-500px.png?1620626066" + }, + { + "chainId": 1, + "address": "0x849a226f327b89e3133d9930d927f9eb9346f8c9", + "name": "Crypto Global United", + "symbol": "CGU", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/20751/thumb/2022_CGU-MG_RGB.png?1666606977" + }, + { + "chainId": 1, + "address": "0xa670d7237398238de01267472c6f13e5b8010fd1", + "name": "Sommelier", + "symbol": "SOMM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/23308/thumb/somm_new.png?1650884424" + }, + { + "chainId": 1, + "address": "0xd9063a24630f24cd4dc99a9c7abe73f82fc6b722", + "name": "Arenum", + "symbol": "ARNM", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/24393/thumb/6253dcf123d4f40001e9c793_CryptoCoin_1024.png?1649733527" + }, + { + "chainId": 1, + "address": "0xf68d4d917592f3a62417ace42592f15296cc33a0", + "name": "COINHUB", + "symbol": "CHB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26818/thumb/4DBF1DAE-0930-4925-BD70-1A446F267546.jpeg?1660278721" + }, + { + "chainId": 1, + "address": "0xe4174143f0d6b1ebc0e25e1acd975c8f9fd06539", + "name": "Wrapped aRIA Currency", + "symbol": "WRIA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27066/thumb/wRIA-logo-200x200-1.png?1661673526" + }, + { + "chainId": 1, + "address": "0x772722b55cdc2a086abd064267a17855eb15e8b3", + "name": "MintMe com Coin", + "symbol": "MINTME", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/5127/thumb/MINTME_logo.png?1666845801" + }, + { + "chainId": 1, + "address": "0xe20b9e246db5a0d21bf9209e4858bc9a3ff7a034", + "name": "Banano", + "symbol": "BAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/6226/thumb/banano-transparent.png?1619589798" + }, + { + "chainId": 1, + "address": "0x5fab9761d60419c9eeebe3915a8fa1ed7e8d2e1b", + "name": "DIMO", + "symbol": "DIMO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28383/thumb/Token_Logo.png?1670052785" + }, + { + "chainId": 1, + "address": "0x37613d64258c0fe09d5e53eecb091da5b8fa8707", + "name": "Pi Protocol", + "symbol": "PIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27476/thumb/LOGO_%281%29.png?1664197877" + }, + { + "chainId": 1, + "address": "0xd3ac016b1b8c80eeadde4d186a9138c9324e4189", + "name": "Okcash", + "symbol": "OK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/274/thumb/ok-logo-200px.png?1665792994" + }, + { + "chainId": 1, + "address": "0xdd13dedecebda566322195bc4451d672a148752c", + "name": "PRIMAL", + "symbol": "PRIMAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28435/thumb/PRIMAL_ICON_200px.jpg?1670567426" + }, + { + "chainId": 1, + "address": "0xc7026a20a640bc71b9074f7aed52a00cd9147091", + "name": "Tegro", + "symbol": "TGR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26564/thumb/200x200.png?1658800017" + }, + { + "chainId": 1, + "address": "0xb990d93c308a31c737aa91839e8ba8eaf4017d7a", + "name": "PirateCash", + "symbol": "PIRATE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7155/thumb/logo_%281%29.png?1637683371" + }, + { + "chainId": 1, + "address": "0x5f1f11a3dd7a0c39da1baa3c7b8585b52a77f435", + "name": "ASAN VERSE", + "symbol": "ASAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28189/thumb/200200_copy.png?1668324848" + }, + { + "chainId": 1, + "address": "0x5bdc32663ec75e85ff4abc2cae7ae8b606a2cfca", + "name": "Cookies Protocol", + "symbol": "CP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/28432/thumb/IMG_20221207_200805_897.jpg?1670556204" + }, + { + "chainId": 1, + "address": "0x703d8574e19428d662a73c301d106dc236aa9bfc", + "name": "Teaswap Art", + "symbol": "TSA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17826/thumb/tsa.PNG?1629358290" + }, + { + "chainId": 1, + "address": "0x9348e94a447bf8b2ec11f374d3f055fd47d936df", + "name": "For Loot And Glory", + "symbol": "FLAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20726/thumb/token_logo.ico?1637595445" + }, + { + "chainId": 1, + "address": "0xc3589f56b6869824804a5ea29f2c9886af1b0fce", + "name": "Honey", + "symbol": "HNY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12895/thumb/hnys.png?1614100588" + }, + { + "chainId": 1, + "address": "0x377d552914e7a104bc22b4f3b6268ddc69615be7", + "name": "NEXT", + "symbol": "NEXT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/7014/thumb/NEXT.exchange_Logo.png?1569212613" + }, + { + "chainId": 1, + "address": "0xe2dc070524a6e305ddb64d8513dc444b6a1ec845", + "name": "Nash", + "symbol": "NEX", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/3246/thumb/nash.png?1653656442" + }, + { + "chainId": 1, + "address": "0x0f3adc247e91c3c50bc08721355a41037e89bc20", + "name": "Anchor Protocol", + "symbol": "ANC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14420/thumb/anchor_protocol_logo.jpg?1615965420" + }, + { + "chainId": 1, + "address": "0x499568c250ab2a42292261d6121525d70691894b", + "name": "KROWN", + "symbol": "KRW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16530/thumb/KRW_token_logo_200x200.png?1624343058" + }, + { + "chainId": 1, + "address": "0x36b679bd64ed73dbfd88909cdcb892cb66bd4cbb", + "name": "xMARK", + "symbol": "XMARK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14188/thumb/omPQ9-nF_400x400.jpg?1614830988" + }, + { + "chainId": 1, + "address": "0x1350fbe8ce27762ec19134bf8fc405a427fe9bf1", + "name": "Trips Community", + "symbol": "TRIPS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14648/thumb/trips_32.png?1617491133" + }, + { + "chainId": 1, + "address": "0xfeea0bdd3d07eb6fe305938878c0cadbfa169042", + "name": "8Pay", + "symbol": "8PAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14667/thumb/8pay.jpeg?1617639682" + }, + { + "chainId": 1, + "address": "0x6dc02164d75651758ac74435806093e421b64605", + "name": "XAYA", + "symbol": "WCHI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/2091/thumb/xaya200x200.png?1656561479" + }, + { + "chainId": 1, + "address": "0x71ba91dc68c6a206db0a6a92b4b1de3f9271432d", + "name": "MobieCoin", + "symbol": "MBX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12874/thumb/MBX_token.jpg?1603186697" + }, + { + "chainId": 1, + "address": "0x5a4623f305a8d7904ed68638af3b4328678eddbf", + "name": "dART Insurance", + "symbol": "DART", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14834/thumb/dart.PNG?1618611161" + }, + { + "chainId": 1, + "address": "0xfb62ae373aca027177d1c18ee0862817f9080d08", + "name": "My DeFi Pet", + "symbol": "DPET", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15321/thumb/mydefi.PNG?1620512455" + }, + { + "chainId": 1, + "address": "0x92a42db88ed0f02c71d439e55962ca7cab0168b5", + "name": "TRDGtoken", + "symbol": "TRDG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14371/thumb/trdg.png?1635830350" + }, + { + "chainId": 1, + "address": "0x3079f61704e9efa2bcf1db412f735d8d4cfa26f4", + "name": "HappyFans", + "symbol": "HAPPY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19027/thumb/O1pUoR8G_400x400.jpeg?1654248996" + }, + { + "chainId": 1, + "address": "0xee1cea7665ba7aa97e982edeaecb26b59a04d035", + "name": "ORAO Network", + "symbol": "ORAO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15189/thumb/orao.PNG?1620078596" + }, + { + "chainId": 1, + "address": "0x7b4328c127b85369d9f82ca0503b000d09cf9180", + "name": "Dogechain", + "symbol": "DC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26828/thumb/dogechain.jpeg?1660292741" + }, + { + "chainId": 1, + "address": "0x05fb86775fd5c16290f1e838f5caaa7342bd9a63", + "name": "Hacken HAI", + "symbol": "HAI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11081/thumb/logo_haken_vector.png?1593511379" + }, + { + "chainId": 1, + "address": "0xa771b49064da011df051052848477f18dba1d2ac", + "name": "Handshake", + "symbol": "HNS", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/10562/thumb/circle-handshakeLogo.png?1613668983" + }, + { + "chainId": 1, + "address": "0x5f6c5c2fb289db2228d159c69621215e354218d7", + "name": "Demodyfi", + "symbol": "DMOD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16262/thumb/Logo_coingecko_%281%29.png?1631796477" + }, + { + "chainId": 1, + "address": "0xc944273b805debd35c63011943abc5ab9eddb8e3", + "name": "Crypto Shield", + "symbol": "SHIELD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21614/thumb/14834.png?1639610437" + }, + { + "chainId": 1, + "address": "0x9d918ee39a356be8ef99734599c7e70160db4db6", + "name": "RealT 12405 Santa Rosa Dr Detroit M", + "symbol": "REALT-S-12405-SANTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16671/thumb/12405-Santa-Rosa-hero-1.jpg?1624627801" + }, + { + "chainId": 1, + "address": "0xdd833d0eef6d5d7cec781b03c19f3b425f3039df", + "name": "RealT 11957 Olga St Detroit MI 4821", + "symbol": "REALT-S-11957-OLGA-", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16672/thumb/11957-Olga-hero-1.jpg?1624628071" + }, + { + "chainId": 1, + "address": "0xf4657ab08681214bcb1893aa8e9c7613459250ec", + "name": "RealT 1617 S Avers Ave Chicago IL 6", + "symbol": "REALT-S-1617-SAVERS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16675/thumb/1617-S-Avers-hero-1.jpg?1624628860" + }, + { + "chainId": 1, + "address": "0xe7b6de709ffc3bd237c2f2c800e1002f97a760f3", + "name": "RealT 4852 4854 W Cortez St Chicago ", + "symbol": "REALT-S-4852-4854-W", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16670/thumb/Cortez-facade-1.jpg?1624627398" + }, + { + "chainId": 1, + "address": "0x8fcb39a25e639c8fbd28e8a018227d6570e02352", + "name": "RealT 1815 S Avers Ave Chicago IL 6", + "symbol": "REALT-S-1815-SAVERS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16674/thumb/1815-S-Avers-hero-1.5.jpg?1624628519" + }, + { + "chainId": 1, + "address": "0xe887dc4fcb5240c0c080aeab8870421d3ebd0b28", + "name": "RealT 14066 Santa Rosa Dr Detroit M", + "symbol": "REALT-S-14066-SANTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16677/thumb/14066-Santa-Rosa-hero-1.5.jpg?1624629250" + }, + { + "chainId": 1, + "address": "0x45fdb1b92a649fb6a64ef1511d3ba5bf60044838", + "name": "SpiceUSD", + "symbol": "USDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25697/thumb/USDS.png?1653440948" + }, + { + "chainId": 1, + "address": "0x8bcd06492416a749c9369009b3429861b7f27f6e", + "name": "BlackHat Coin", + "symbol": "BLKC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/15987/thumb/logo_light.png?1622537905" + }, + { + "chainId": 1, + "address": "0x7778360f035c589fce2f4ea5786cbd8b36e5396b", + "name": "OpenOcean", + "symbol": "OOE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17014/thumb/ooe_log.png?1626074195" + }, + { + "chainId": 1, + "address": "0x4e9a46ea6a22f3894abee2302ad42fd3b69e21e2", + "name": "Binance Smart Chain Girl", + "symbol": "BSCGIRL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/17271/thumb/icon_200px_16bit.png?1627005622" + }, + { + "chainId": 1, + "address": "0xae12c5930881c53715b369cec7606b70d8eb229f", + "name": "Coin98", + "symbol": "C98", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17117/thumb/logo.png?1626412904" + }, + { + "chainId": 1, + "address": "0xb8981acbbf7da95a8ff6df79aab935ce63434fc8", + "name": "Cfoforum", + "symbol": "CFO", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/17592/thumb/CFO_logo_200_200px.png?1628580306" + }, + { + "chainId": 1, + "address": "0x396ec402b42066864c406d1ac3bc86b575003ed8", + "name": "Buying com", + "symbol": "BUY", + "decimals": 2, + "logoURI": "https://assets.coingecko.com/coins/images/5290/thumb/buying_200x200.png?1628587856" + }, + { + "chainId": 1, + "address": "0x180dae91d6d56235453a892d2e56a3e40ba81df8", + "name": "DOJO", + "symbol": "DOJO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16396/thumb/074606deafab3872.png?1623910120" + }, + { + "chainId": 1, + "address": "0x8287c7b963b405b7b8d467db9d79eec40625b13a", + "name": "Swingby", + "symbol": "SWINGBY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/11861/thumb/swingby.png?1595822302" + }, + { + "chainId": 1, + "address": "0x1d7ca62f6af49ec66f6680b8606e634e55ef22c1", + "name": "Starter xyz", + "symbol": "START", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14301/thumb/logo_poly_sym.png?1624893386" + }, + { + "chainId": 1, + "address": "0x6c7b97c7e09e790d161769a52f155125fac6d5a1", + "name": "Polylauncher", + "symbol": "ANGEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17739/thumb/Polylauncher_-_200_x_200.png?1629121147" + }, + { + "chainId": 1, + "address": "0x31f69de127c8a0ff10819c0955490a4ae46fcc2a", + "name": "Obyte", + "symbol": "GBYTE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/561/thumb/byteball.png?1547564361" + }, + { + "chainId": 1, + "address": "0x8848812bd31aeee33313c10a840ffc3169078c5b", + "name": "CrossFi", + "symbol": "CRFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15162/thumb/11901619752967_.pic_hd.png?1620006681" + }, + { + "chainId": 1, + "address": "0x667fd83e24ca1d935d36717d305d54fa0cac991c", + "name": "Collector Coin", + "symbol": "AGS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16918/thumb/AGS.png?1625626120" + }, + { + "chainId": 1, + "address": "0x9393fdc77090f31c7db989390d43f454b1a6e7f3", + "name": "Dark Energy Crystals", + "symbol": "DEC", + "decimals": 3, + "logoURI": "https://assets.coingecko.com/coins/images/12923/thumb/DEC_token.png?1603683753" + }, + { + "chainId": 1, + "address": "0x1951ab088141e69a3713a351b0d55ba3acda192c", + "name": "Night Life Crypto", + "symbol": "NLIFE", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/16277/thumb/F6jp9eh.png?1623634100" + }, + { + "chainId": 1, + "address": "0x2aad9dbc82611485a52325923e1187734e951b78", + "name": "BYTZ", + "symbol": "BYTZ", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/4017/thumb/bytz.png?1584519997" + }, + { + "chainId": 1, + "address": "0x8861cff2366c1128fd699b68304ad99a0764ef9a", + "name": "Cyclone Protocol", + "symbol": "CYC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14065/thumb/b3_DFjFp_400x400.jpg?1614128740" + }, + { + "chainId": 1, + "address": "0x026e62dded1a6ad07d93d39f96b9eabd59665e0d", + "name": "Birdchain", + "symbol": "BIRD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/1994/thumb/MLSILOZA_400x400.png?1564971298" + }, + { + "chainId": 1, + "address": "0xdb726152680ece3c9291f1016f1d36f3995f6941", + "name": "Media Network", + "symbol": "MEDIA", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/15142/thumb/media50x50.png?1620122020" + }, + { + "chainId": 1, + "address": "0x34965f73cfa05bf8d8af37cb4af64fa950605ea8", + "name": "CoinWind", + "symbol": "COW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15766/thumb/logo.c3d2c062.png?1621827743" + }, + { + "chainId": 1, + "address": "0x9ac07635ddbde5db18648c360defb00f5f22537e", + "name": "Museum of Crypto Art", + "symbol": "MOCA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15829/thumb/photo_2021-06-04_09.36.16.jpeg?1622770606" + }, + { + "chainId": 1, + "address": "0xf9c2b386ff5df088ac717ab0010587bad3bc1ab1", + "name": "Inflation Adjusted USDS", + "symbol": "IUSDS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25698/thumb/iUSDS2.png?1653441251" + }, + { + "chainId": 1, + "address": "0x7645ddfeeceda57e41f92679c4acd83c56a81d14", + "name": "Flux Protocol", + "symbol": "FLUX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15002/thumb/logo.dabc411c.png?1619402947" + }, + { + "chainId": 1, + "address": "0xf99d58e463a2e07e5692127302c20a191861b4d6", + "name": "Anyswap", + "symbol": "ANY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12242/thumb/anyswap.jpg?1598443880" + }, + { + "chainId": 1, + "address": "0x9fda7ceec4c18008096c2fe2b85f05dc300f94d0", + "name": "Gaj Finance", + "symbol": "GAJ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15257/thumb/logo200x200.png?1629887093" + }, + { + "chainId": 1, + "address": "0xe0b0c16038845bed3fcf70304d3e167df81ce225", + "name": "CrossSwap", + "symbol": "CSWAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18002/thumb/cross.png?1630078540" + }, + { + "chainId": 1, + "address": "0x939b462ee3311f8926c047d2b576c389092b1649", + "name": "LiquidApps", + "symbol": "DAPP", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/8116/thumb/dapp-logo.jpg?1554996565" + }, + { + "chainId": 1, + "address": "0xef3a930e1ffffacd2fc13434ac81bd278b0ecc8d", + "name": "Stafi", + "symbol": "FIS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/12423/thumb/stafi_logo.jpg?1599730991" + }, + { + "chainId": 1, + "address": "0x154e35c2b0024b3e079c5c5e4fc31c979c189ccb", + "name": "Raid", + "symbol": "RAID", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18133/thumb/raid_200_oswlvz.png?1630631876" + }, + { + "chainId": 1, + "address": "0x9d79d5b61de59d882ce90125b18f74af650acb93", + "name": "Neutrino System Base", + "symbol": "NSBT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/13268/thumb/83005f7ab1.png?1606877707" + }, + { + "chainId": 1, + "address": "0x62d693fe5c13b5a5b24c9ec3f423e51c35f5624f", + "name": "SafeBitcoin", + "symbol": "SAFEBTC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14635/thumb/Logo_Black_200x200.png?1631160793" + }, + { + "chainId": 1, + "address": "0xdb0170e2d0c1cc1b2e7a90313d9b9afa4f250289", + "name": "ADAPad", + "symbol": "ADAPAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18273/thumb/EhSqPTtG_400x400.jpg?1631181091" + }, + { + "chainId": 1, + "address": "0xc2708a3a4ba7f64bddc1a49f92f941bc77cad23a", + "name": "Waves Ducks", + "symbol": "EGG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17298/thumb/200x200_pixel.png?1627288546" + }, + { + "chainId": 1, + "address": "0x8bbf1dccbedd5c70d8e793d432fb56b848dd1698", + "name": "Ape In", + "symbol": "APEIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18262/thumb/apein.PNG?1631158082" + }, + { + "chainId": 1, + "address": "0xb8e3bb633f7276cc17735d86154e0ad5ec9928c0", + "name": "VelasPad", + "symbol": "VLXPAD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18535/thumb/11654.png?1632297834" + }, + { + "chainId": 1, + "address": "0x9798df2f5d213a872c787bd03b2b91f54d0d04a1", + "name": "TeraBlock", + "symbol": "TBC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15622/thumb/tbc.png?1621345335" + }, + { + "chainId": 1, + "address": "0x3405a1bd46b85c5c029483fbecf2f3e611026e45", + "name": "WOWswap", + "symbol": "WOW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14101/thumb/Group-423.png?1614317472" + }, + { + "chainId": 1, + "address": "0x893700a1a86ee68b92536bf6fd4d3200d7369f7d", + "name": "Emanate", + "symbol": "EMT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4152/thumb/emanate.png?1558422824" + }, + { + "chainId": 1, + "address": "0x12bb890508c125661e03b09ec06e404bc9289040", + "name": "Radio Caca", + "symbol": "RACA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17841/thumb/ez44_BSs_400x400.jpg?1629464170" + }, + { + "chainId": 1, + "address": "0xca1262e77fb25c0a4112cfc9bad3ff54f617f2e6", + "name": "Jax Network", + "symbol": "WJXN", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/18737/thumb/photo.jpg?1633360887" + }, + { + "chainId": 1, + "address": "0x968f6f898a6df937fc1859b323ac2f14643e3fed", + "name": "Newscrypto Coin", + "symbol": "NWC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9805/thumb/Tu1_NI3s_%281%29.png?1614745476" + }, + { + "chainId": 1, + "address": "0x39ae6d231d831756079ec23589d2d37a739f2e89", + "name": "Zeptacoin", + "symbol": "ZPTC", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/19109/thumb/2000x2000zptc_square3_%281%29.png?1639667686" + }, + { + "chainId": 1, + "address": "0x5dbb9f64cd96e2dbbca58d14863d615b67b42f2e", + "name": "ok lets go ", + "symbol": "OKLG", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20377/thumb/Screenshot-2021-11-14-at-23-45-11.png?1636950187" + }, + { + "chainId": 1, + "address": "0x8a65b987d9813f0a97446eda0de918b2573ae406", + "name": "FomoETH", + "symbol": "FOMOETH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21934/thumb/qSCAqd6m_400x400.jpg?1640301488" + }, + { + "chainId": 1, + "address": "0xfbc4f3f645c4003a2e4f4e9b51077d2daa9a9341", + "name": "Zedxion", + "symbol": "ZEDXION", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18841/thumb/ZEDXION.png?1633585913" + }, + { + "chainId": 1, + "address": "0xdb85f6685950e285b1e611037bebe5b34e2b7d78", + "name": "Zano", + "symbol": "ZANO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/8370/thumb/zano.png?1638343828" + }, + { + "chainId": 1, + "address": "0x1da4858ad385cc377165a298cc2ce3fce0c5fd31", + "name": "CloutContracts", + "symbol": "CCS", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/19072/thumb/200.png?1634829111" + }, + { + "chainId": 1, + "address": "0xf32122561d51e891b823dec2b42f644884c1cd91", + "name": "DeFido", + "symbol": "DEFIDO", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/18861/thumb/defido.png?1635638445" + }, + { + "chainId": 1, + "address": "0xf268fe3d6909508dda90dccf2bf69050d19f4cdd", + "name": "Grow", + "symbol": "GROW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16049/thumb/grow-logo-200x200.png?1622691274" + }, + { + "chainId": 1, + "address": "0xf6719e1a8fcbb1b9c290019e37e004966a8916c9", + "name": "Polygen", + "symbol": "PGEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21476/thumb/polygen-logo_1.jpeg?1639350369" + }, + { + "chainId": 1, + "address": "0x2fd8bc03d9e827f77fac20b5130ee98b7f80149d", + "name": "CRB Coin", + "symbol": "CRB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/19399/thumb/crb.png?1635158925" + }, + { + "chainId": 1, + "address": "0x16ba8efe847ebdfef99d399902ec29397d403c30", + "name": "Oh Finance", + "symbol": "OH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19493/thumb/oh-token-logo-200.png?1635303795" + }, + { + "chainId": 1, + "address": "0xd373576a9e738f37dc6882328358ff69c4caf4c6", + "name": "Zam io", + "symbol": "ZAM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19522/thumb/zam.png?1635324134" + }, + { + "chainId": 1, + "address": "0x0106a1122fe94a9cf151097c1fe17229ec78ffad", + "name": "Eco DeFi", + "symbol": "ECOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19535/thumb/eco_global.PNG?1635374624" + }, + { + "chainId": 1, + "address": "0x773258b03c730f84af10dfcb1bfaa7487558b8ac", + "name": "Secret Finance", + "symbol": "SEFI", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/14601/thumb/_Icon___SVG__Primary_-_Metallic_Gold_in_Circle_%282%29.png?1635066611" + }, + { + "chainId": 1, + "address": "0x5f0366c9962193fa774cdce9602195593b49f23c", + "name": "Flash Loans", + "symbol": "FLASH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19827/thumb/flash.PNG?1635979476" + }, + { + "chainId": 1, + "address": "0x65e6b60ea01668634d68d0513fe814679f925bad", + "name": "PixelVerse", + "symbol": "PIXEL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19934/thumb/pixelverse.PNG?1636325521" + }, + { + "chainId": 1, + "address": "0x081131434f93063751813c619ecca9c4dc7862a3", + "name": "Mines of Dalarnia", + "symbol": "DAR", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/19837/thumb/dar.png?1636014223" + }, + { + "chainId": 1, + "address": "0x0c75dd36af9a59ba1d248a98fe91b2384cfea9be", + "name": "OmniWhirl", + "symbol": "WHIRL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17165/thumb/logo-200x.png?1626683241" + }, + { + "chainId": 1, + "address": "0xac57de9c1a09fec648e93eb98875b212db0d460b", + "name": "Baby Doge Coin", + "symbol": "BABYDOGE", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/16125/thumb/Baby_Doge.png?1623044048" + }, + { + "chainId": 1, + "address": "0x55af5865807b196bd0197e0902746f31fbccfa58", + "name": "Spookyswap", + "symbol": "BOO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15223/thumb/logo_200x200.png?1621992076" + }, + { + "chainId": 1, + "address": "0x9a257c90fa239fba07771ef7da2d554d148c2e89", + "name": "MEDIA EYE", + "symbol": "EYE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20643/thumb/eye.png?1656052464" + }, + { + "chainId": 1, + "address": "0x9fb83c0635de2e815fd1c21b3a292277540c2e8d", + "name": "RealFevr", + "symbol": "FEVR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17136/thumb/Fevr-Token.png?1626869849" + }, + { + "chainId": 1, + "address": "0xe0bcd056b6a8c7fd4983cb56c162799e498e85d3", + "name": "Toshinori Inu", + "symbol": "TOSHINORI", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21068/thumb/2Dp0LWna_400x400.jpg?1638279103" + }, + { + "chainId": 1, + "address": "0x0343131c0257ac21ea5a8dc83841f071efd9285c", + "name": "Zenith Chain", + "symbol": "ZENITH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21266/thumb/Jqtp-OVG_400x400.png?1638837643" + }, + { + "chainId": 1, + "address": "0xd8c1232fcd219286e341271385bd70601503b3d7", + "name": "Dogira", + "symbol": "DOGIRA", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/14634/thumb/IQgaRw0.png?1622439620" + }, + { + "chainId": 1, + "address": "0x747c4ce9622ea750ea8048423b38a746b096c8e8", + "name": "Baby Floki Doge", + "symbol": "BABYFD", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19543/thumb/babyfd.png?1635641884" + }, + { + "chainId": 1, + "address": "0xb6dd77fd132dcaa10f1858734e838a0fa7431580", + "name": "Filipcoin", + "symbol": "FCP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21354/thumb/filip.PNG?1639000706" + }, + { + "chainId": 1, + "address": "0x81c159f7abaa9139227aff62959b86b4141f6eb2", + "name": "Elon s Marvin", + "symbol": "MARVIN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20886/thumb/marvin.png?1637832213" + }, + { + "chainId": 1, + "address": "0x93e32efafd24973d45f363a76d73ccb9edf59986", + "name": "Bitlocus", + "symbol": "BTL", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/20913/thumb/btl.png?1637922710" + }, + { + "chainId": 1, + "address": "0x42baf1f659d765c65ade5bb7e08eb2c680360d9d", + "name": "Cornucopias", + "symbol": "COPI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21452/thumb/g56WwJDA_400x400.jpg?1639174968" + }, + { + "chainId": 1, + "address": "0xe1590a6fa0cff9c960181cb77d8a873601772f64", + "name": "WallStreetBets DApp", + "symbol": "WSB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15093/thumb/Pe1mrDu.png?1629882480" + }, + { + "chainId": 1, + "address": "0xdf09a216fac5adc3e640db418c0b956076509503", + "name": "Poken", + "symbol": "PKN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21574/thumb/G10VNBAR_400x400.jpg?1639490463" + }, + { + "chainId": 1, + "address": "0x45c2f8c9b4c0bdc76200448cc26c48ab6ffef83f", + "name": "Domi", + "symbol": "DOMI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21633/thumb/Transparent_Circle_Logo_2.png?1639627183" + }, + { + "chainId": 1, + "address": "0xa87135285ae208e22068acdbff64b11ec73eaa5a", + "name": "Lunr", + "symbol": "LUNR", + "decimals": 4, + "logoURI": "https://assets.coingecko.com/coins/images/19256/thumb/lunr.png?1639975807" + }, + { + "chainId": 1, + "address": "0x965b85d4674f64422c4898c8f8083187f02b32c0", + "name": "Filecoin Standard Full Hashrate", + "symbol": "SFIL", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/21669/thumb/_70BfuBY_400x400.jpg?1639706531" + }, + { + "chainId": 1, + "address": "0xa47c8bf37f92abed4a126bda807a7b7498661acd", + "name": "Wrapped USTC", + "symbol": "USTC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15462/thumb/ust.png?1620910058" + }, + { + "chainId": 1, + "address": "0x57cd5a91c18d21dedd72d3bcf255b60aef290f53", + "name": "SnapEx", + "symbol": "SNAP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21458/thumb/snap.png?1639291894" + }, + { + "chainId": 1, + "address": "0x2f25d402829ca4085b8ea4d3bc68bf203f5a9fab", + "name": "EagonSwap", + "symbol": "EAGON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20431/thumb/IMG-20210912-WA0003.jpg?1637035180" + }, + { + "chainId": 1, + "address": "0xaad483f97f13c6a20b9d05d07c397ce85c42c393", + "name": "Woonkly Power", + "symbol": "WOOP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14494/thumb/Icono_Infinito_Circular_Blanco_Fondo_Azul_2x.png?1658830979" + }, + { + "chainId": 1, + "address": "0xaf9db9e362e306688af48c4acb9618c06db38ac3", + "name": "ACY Finance", + "symbol": "ACY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21883/thumb/ubfPhcEK_400x400.jpg?1640214613" + }, + { + "chainId": 1, + "address": "0xbd100d061e120b2c67a24453cf6368e63f1be056", + "name": "iDeFiYieldProtocol", + "symbol": "IDYP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/21976/thumb/iDYP-200x200px.png?1671016252" + }, + { + "chainId": 1, + "address": "0x77a1f4e744d810239f465043e35d067ca33de259", + "name": "Voice Street", + "symbol": "VST", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23147/thumb/LbMUkaD9_400x400.jpg?1643348841" + }, + { + "chainId": 1, + "address": "0x507bde03a87a6aa134d16634545e3d79c11c137d", + "name": "UniArts", + "symbol": "UART", + "decimals": 12, + "logoURI": "https://assets.coingecko.com/coins/images/22092/thumb/3Rx82r_w_400x400.png?1640823145" + }, + { + "chainId": 1, + "address": "0x7118057ff0f4fd0994fb9d2d94de8231d5cca79e", + "name": "ReSource Protocol", + "symbol": "SOURCE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20740/thumb/source.png?1637749215" + }, + { + "chainId": 1, + "address": "0x9ab70e92319f0b9127df78868fd3655fb9f1e322", + "name": "WeWay", + "symbol": "WWY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22418/thumb/wwy.png?1661499324" + }, + { + "chainId": 1, + "address": "0x86d49fbd3b6f989d641e700a15599d3b165002ab", + "name": "HUH", + "symbol": "HUH", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21549/thumb/huh.png?1639462106" + }, + { + "chainId": 1, + "address": "0x25b24b3c47918b7962b3e49c4f468367f73cc0e0", + "name": "AXL INU", + "symbol": "AXL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22191/thumb/Original_Logo-01.png?1641188792" + }, + { + "chainId": 1, + "address": "0xbba6c7c7d673c48d90069ad2e9d2fe587fcb6bc3", + "name": "Lepasa", + "symbol": "LEPA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22745/thumb/lepasa.PNG?1642550975" + }, + { + "chainId": 1, + "address": "0xac8cc32fab2368a1a095722aaf760c45f578e17b", + "name": "CHEEMS INU", + "symbol": "CINU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/20924/thumb/Screenshot-2021-11-23-at-00-45-30.png?1637932412" + }, + { + "chainId": 1, + "address": "0xa693b19d2931d498c5b318df961919bb4aee87a5", + "name": "TerraUSD Wormhole ", + "symbol": "UST", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21150/thumb/UST_wh_small.png?1644223065" + }, + { + "chainId": 1, + "address": "0x845e2e8b42dced7dedcdba9bde32c9e338224f97", + "name": "Satozhi", + "symbol": "SATOZ", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/14786/thumb/0GeSrIaQ_400x400.jpg?1618416420" + }, + { + "chainId": 1, + "address": "0x2f75113b13d136f861d212fa9b572f2c79ac81c4", + "name": "Ekta", + "symbol": "EKTA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22350/thumb/token.jpg?1641882684" + }, + { + "chainId": 1, + "address": "0xc669928185dbce49d2230cc9b0979be6dc797957", + "name": "BitTorrent", + "symbol": "BTT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22457/thumb/btt_logo.png?1643857231" + }, + { + "chainId": 1, + "address": "0x4734baf528766ec4c420a6c13f8dba7bb1920181", + "name": "Elvantis", + "symbol": "ELV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23393/thumb/elvantis.PNG?1644116336" + }, + { + "chainId": 1, + "address": "0xcc8fa225d80b9c7d42f96e9570156c65d6caaa25", + "name": "Smooth Love Potion", + "symbol": "SLP", + "decimals": 0, + "logoURI": "https://assets.coingecko.com/coins/images/10366/thumb/SLP.png?1578640057" + }, + { + "chainId": 1, + "address": "0xc4bb7277a74678f053259cb1f96140347efbfd46", + "name": "Coin of the champions", + "symbol": "COC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18478/thumb/COC-Yellow-Transparent-1.png?1632148454" + }, + { + "chainId": 1, + "address": "0x9b17baadf0f21f03e35249e0e59723f34994f806", + "name": "NFTmall", + "symbol": "GEM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16217/thumb/Icon-1000x1000.png?1623316471" + }, + { + "chainId": 1, + "address": "0xee9801669c6138e84bd50deb500827b776777d28", + "name": "O3 Swap", + "symbol": "O3", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15460/thumb/o3.png?1620904316" + }, + { + "chainId": 1, + "address": "0x7825e833d495f3d1c28872415a4aee339d26ac88", + "name": "Wrapped Telos", + "symbol": "WTLOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23952/thumb/tL4cEmvt_400x400.png?1645772510" + }, + { + "chainId": 1, + "address": "0x2217e5921b7edfb4bb193a6228459974010d2198", + "name": "Qmall", + "symbol": "QMALL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23630/thumb/tjVN6bQ5_400x400.jpg?1644891636" + }, + { + "chainId": 1, + "address": "0xd3c51de3e6dd9b53d7f37699afb3ee3bf9b9b3f4", + "name": "MContent", + "symbol": "MCONTENT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/16781/thumb/Image_mcontent.jpeg?1653476766" + }, + { + "chainId": 1, + "address": "0x1f36fb2d91d9951cf58ae4c1956c0b77e224f1e9", + "name": "VCGamers", + "symbol": "VCG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22371/thumb/VCG-Token-Logo-PNG.png?1643187590" + }, + { + "chainId": 1, + "address": "0xe580074a10360404af3abfe2d524d5806d993ea3", + "name": "PayBolt", + "symbol": "PAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24175/thumb/logo.png?1646748269" + }, + { + "chainId": 1, + "address": "0x723bd1f87a327e94ceabf68d8f022e0f54b9cc1a", + "name": "Philcoin", + "symbol": "PHL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24178/thumb/2ZFyoMSk.png?1646901982" + }, + { + "chainId": 1, + "address": "0xc17fbe1d709ddf6c0b6665dd0591046815ac7554", + "name": "Polars", + "symbol": "POL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24220/thumb/alpha_logo_polars.png?1646919342" + }, + { + "chainId": 1, + "address": "0x22c5543d1a35178cb03b33f929a959145e538532", + "name": "The Wasted Lands", + "symbol": "WAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24273/thumb/Coin_WAL_%281%29.png?1647178350" + }, + { + "chainId": 1, + "address": "0x20d60c6eb195868d4643f2c9b0809e4de6cc003d", + "name": "PlayNity", + "symbol": "PLY", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21479/thumb/ply.png?1639651574" + }, + { + "chainId": 1, + "address": "0x809e130e10e787139c54e1d12d3d1971b7a675bf", + "name": "Minted", + "symbol": "MTD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26893/thumb/MTD_Token_%282%29.png?1660708482" + }, + { + "chainId": 1, + "address": "0xae1107fc7cef1294f09185ac475c9886527dcd8a", + "name": "Adalend", + "symbol": "ADAL", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24554/thumb/19012.png?1648134755" + }, + { + "chainId": 1, + "address": "0x1ab43204a195a0fd37edec621482afd3792ef90b", + "name": "Aurigami", + "symbol": "PLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24074/thumb/EbB5N8IN_400x400.jpg?1646230298" + }, + { + "chainId": 1, + "address": "0x525ef76138bf76118d786dbedeae5f87aabf4a81", + "name": "Scalara NFT Index", + "symbol": "NFTI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23647/thumb/NFTI-logo-white-bg.png?1644910969" + }, + { + "chainId": 1, + "address": "0xf655c8567e0f213e6c634cd2a68d992152161dc6", + "name": "Impermax", + "symbol": "IBEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27606/thumb/IqwOmX-c_400x400.jpeg?1664846656" + }, + { + "chainId": 1, + "address": "0x19193f450086d0442157b852081976d41657ad56", + "name": "Nunu Spirits", + "symbol": "NNT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24378/thumb/NNT_99cc33.png?1649120059" + }, + { + "chainId": 1, + "address": "0xc17c30e98541188614df99239cabd40280810ca3", + "name": "EverRise", + "symbol": "RISE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/16367/thumb/Logo_EverRise_Icon_logo.png?1642576670" + }, + { + "chainId": 1, + "address": "0x32462ba310e447ef34ff0d15bce8613aa8c4a244", + "name": "Dohrnii", + "symbol": "DHN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24966/thumb/dhn.png?1649586405" + }, + { + "chainId": 1, + "address": "0x198d14f2ad9ce69e76ea330b374de4957c3f850a", + "name": "APENFT", + "symbol": "NFT", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/15687/thumb/apenft.jpg?1621562368" + }, + { + "chainId": 1, + "address": "0x16b3e050e9e2f0ac4f1bea1b3e4fdc43d7f062dd", + "name": "Sombra", + "symbol": "SMBR", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/17884/thumb/sombra-200.png?1629710204" + }, + { + "chainId": 1, + "address": "0xb14784b2a56945aed7b8cd41661d68f8b6ccec8b", + "name": "Musk Melon", + "symbol": "MELON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25089/thumb/MepNVeU.png?1650269351" + }, + { + "chainId": 1, + "address": "0x446f2a8a39cc730ef378be759a3c57f1a3fe824c", + "name": "NanoByte", + "symbol": "NBT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23698/thumb/WpcmdLW.png?1645080885" + }, + { + "chainId": 1, + "address": "0xc84d8d03aa41ef941721a4d77b24bb44d7c7ac55", + "name": "Empire Capital", + "symbol": "ECC", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21221/thumb/2022-07-13_18.49.44.jpg?1657709418" + }, + { + "chainId": 1, + "address": "0x420a24c9c65bd44c48bfb1cc8d6cd1ea8b1ac840", + "name": "JumpToken", + "symbol": "JMPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22603/thumb/200x200.png?1642162597" + }, + { + "chainId": 1, + "address": "0x4550003152f12014558e5ce025707e4dd841100f", + "name": "Kaizen", + "symbol": "KZEN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24396/thumb/PKl5OVRv_400x400.png?1647522756" + }, + { + "chainId": 1, + "address": "0x0c10bf8fcb7bf5412187a595ab97a3609160b5c6", + "name": "USDD", + "symbol": "USDD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25380/thumb/UUSD.jpg?1651823371" + }, + { + "chainId": 1, + "address": "0xfceb206e1a80527908521121358b5e26caabaa75", + "name": "Main", + "symbol": "MAIN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25258/thumb/logo_circle.png?1651042603" + }, + { + "chainId": 1, + "address": "0x614d7f40701132e25fe6fc17801fbd34212d2eda", + "name": "SafeBlast", + "symbol": "BLAST", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/15686/thumb/safeblast.png?1621561206" + }, + { + "chainId": 1, + "address": "0x8fc8f8269ebca376d046ce292dc7eac40c8d358a", + "name": "DeFiChain", + "symbol": "DFI", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/11757/thumb/symbol-defi-blockchain_200.png?1597306538" + }, + { + "chainId": 1, + "address": "0xf6e06b54855eff198a2d9a8686113665499a6134", + "name": "Celestial", + "symbol": "CELT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18683/thumb/celt.png?1632966755" + }, + { + "chainId": 1, + "address": "0x9767203e89dcd34851240b3919d4900d3e5069f1", + "name": "A4 Finance", + "symbol": "A4", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/21992/thumb/ba384ad07217a4be75cb85314f5760f7.jpg?1640582786" + }, + { + "chainId": 1, + "address": "0xd35c06a2781f648c75290976ecf71e71582188b7", + "name": "Quarashi", + "symbol": "QUA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25589/thumb/Lk2A7ta.png?1652769197" + }, + { + "chainId": 1, + "address": "0x7a5d3a9dcd33cb8d527f7b5f96eb4fef43d55636", + "name": "RadioShack", + "symbol": "RADIO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25307/thumb/ZVoPiysPJq6dPIZm_Se-6vjmsBepwhHlTQfdYZRILbHyVVTRUYCO-wmJJ4zT10HXCGv1j-ZyWr2u2sBaVlap5Y-ILqeXZuIquWdBDxxG0E0qDpgH7omLqYdgWWLSM_TUK9d1PiiYdu6bERdCDaucgFjlqwmhVQK4uV4jyUiXzchVUnu8Qt6SnxlNxz88G0mQ_tfiwkFv_vKqtgb1CcPycVZVz9.jpg?1651211260" + }, + { + "chainId": 1, + "address": "0x26dcfbfa8bc267b250432c01c982eaf81cc5480c", + "name": "Ankr Reward Earning MATIC", + "symbol": "AMATICC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25742/thumb/a-matic-c-da4ec10dc9723e695700e25dbf8c8edf.png?1653462321" + }, + { + "chainId": 1, + "address": "0x9631be8566fc71d91970b10acfdee29f21da6c27", + "name": "Intelligent Monsters", + "symbol": "IMON", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26077/thumb/imonToken.png?1655690407" + }, + { + "chainId": 1, + "address": "0xafcdd4f666c84fed1d8bd825aa762e3714f652c9", + "name": "Vita Inu", + "symbol": "VINU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20594/thumb/vita-inu-head-wallet-icon-transparent.png?1637286122" + }, + { + "chainId": 1, + "address": "0x9e6b19874e97fe8e8cad77f2c0ab5e7a693e5dbf", + "name": "StrongHands Finance", + "symbol": "ISHND", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20158/thumb/ISHND_512x512px.png?1647512898" + }, + { + "chainId": 1, + "address": "0x2b95a1dcc3d405535f9ed33c219ab38e8d7e0884", + "name": "Aladdin cvxCRV", + "symbol": "ACRV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25395/thumb/Sv06cFHS_400x400.jpg?1651707422" + }, + { + "chainId": 1, + "address": "0x5f018e73c185ab23647c82bd039e762813877f0e", + "name": "Shack", + "symbol": "SHACK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25699/thumb/shack_no_bg_no_pad3.png?1653441433" + }, + { + "chainId": 1, + "address": "0x40fed5691e547885cabd7a2990de719dcc8497fc", + "name": "Safe Haven", + "symbol": "SHA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2584/thumb/safehaven.png?1620037471" + }, + { + "chainId": 1, + "address": "0x18a1ea69a50a85752b7bc204a2c45a95ce6e429d", + "name": "Spice Trade", + "symbol": "SPICE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25770/thumb/SPICE.png?1653607602" + }, + { + "chainId": 1, + "address": "0xcafe34bae6f1b23a6b575303edcc0578d2188131", + "name": "Minter Network", + "symbol": "BIP", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9982/thumb/Nvoj_6Mu_400x400.jpg?1587968303" + }, + { + "chainId": 1, + "address": "0x57d579f483854c62fef850b8a5332b0d8424b7e2", + "name": "OpenSwap One", + "symbol": "OPENX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/19274/thumb/X_color.png?1654833718" + }, + { + "chainId": 1, + "address": "0x80cd73badb406ea36b9a7cdeb8df06aefa7e12d9", + "name": "SleepFuture", + "symbol": "SLEEPEE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25469/thumb/sleepee.png?1651916574" + }, + { + "chainId": 1, + "address": "0x64875aaa68d1d5521666c67d692ee0b926b08b2f", + "name": "CelsiusX Wrapped ADA", + "symbol": "CXADA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23536/thumb/cxADA_128x128.png?1644388456" + }, + { + "chainId": 1, + "address": "0xf9e293d5d793ddc1ae4f778761e0b3e4aa7cf2dd", + "name": "CelsiusX Wrapped DOGE", + "symbol": "CXDOGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/23683/thumb/R2747rb.png?1644997607" + }, + { + "chainId": 1, + "address": "0x84fa8f52e437ac04107ec1768764b2b39287cb3e", + "name": "Grove", + "symbol": "GVR", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/25549/thumb/200x200.png?1652335189" + }, + { + "chainId": 1, + "address": "0x471ea49dd8e60e697f4cac262b5fafcc307506e4", + "name": "RMRK", + "symbol": "RMRK", + "decimals": 10, + "logoURI": "https://assets.coingecko.com/coins/images/18656/thumb/download_%281%29_%281%29.png?1632865271" + }, + { + "chainId": 1, + "address": "0x93581991f68dbae1ea105233b67f7fa0d6bdee7b", + "name": "Evmos", + "symbol": "EVMOS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24023/thumb/evmos.png?1653958927" + }, + { + "chainId": 1, + "address": "0x4c3a8eceb656ec63eae80a4ebd565e4887db6160", + "name": "SokuSwap", + "symbol": "SOKU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/18378/thumb/VCIEHaG.png?1653547690" + }, + { + "chainId": 1, + "address": "0x88536c9b2c4701b8db824e6a16829d5b5eb84440", + "name": "Atlas USV", + "symbol": "USV", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/22066/thumb/7iUyjg5t.png?1640744823" + }, + { + "chainId": 1, + "address": "0xeeeeeb57642040be42185f49c52f7e9b38f8eeee", + "name": "Elk Finance", + "symbol": "ELK", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17813/thumb/elk.png?1629336971" + }, + { + "chainId": 1, + "address": "0x2e7b0d4f9b2eaf782ed3d160e3a0a4b1a7930ada", + "name": "Ceres", + "symbol": "CERES", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/17959/thumb/sQLDgqx.png?1648442923" + }, + { + "chainId": 1, + "address": "0x06ebc9c542357e2129d16717cd02c02fbc835d33", + "name": "Coinage Finance", + "symbol": "CAGE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22300/thumb/Coinage_v2_200x200_white.png?1653464214" + }, + { + "chainId": 1, + "address": "0x7162469321ae5880f077d250b626f3271b21b903", + "name": "KillSwitch", + "symbol": "KSW", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20215/thumb/logo_%2824%29.png?1636670633" + }, + { + "chainId": 1, + "address": "0x3e362283b86c1b45097cc3fb02213b79cf6211df", + "name": "CatCoin com", + "symbol": "CATCOIN", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/25279/thumb/logo_%281%29.png?1651126078" + }, + { + "chainId": 1, + "address": "0x22ad96acf613539d7900b5ec6e0e65dbcc668d2a", + "name": "Xerium", + "symbol": "XERM", + "decimals": 7, + "logoURI": "https://assets.coingecko.com/coins/images/26284/thumb/Xerium_Logo_200x200_PNG.png?1657077128" + }, + { + "chainId": 1, + "address": "0x92df60c51c710a1b1c20e42d85e221f3a1bfc7f2", + "name": "ApeSwap", + "symbol": "BANANA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/14870/thumb/banana.png?1648887183" + }, + { + "chainId": 1, + "address": "0x1cd2528522a17b6be63012fb63ae81f3e3e29d97", + "name": "Mind Music", + "symbol": "MND", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/19104/thumb/logo-main_%282%29.png?1634506312" + }, + { + "chainId": 1, + "address": "0x6cdda72fc9d1a8aa0750ac640c5d6a8922de3b72", + "name": "Good Doge", + "symbol": "TREAT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27349/thumb/88.png?1663655057" + }, + { + "chainId": 1, + "address": "0xc72633f995e98ac3bb8a89e6a9c4af335c3d6e44", + "name": "Omnisea", + "symbol": "OSEA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26475/thumb/293837892_407994084681555_3167689470652146992_n.png?1658195766" + }, + { + "chainId": 1, + "address": "0xeea509c221c5c6979e974f4501b4829be0ab2f8c", + "name": "ENO", + "symbol": "ENO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26501/thumb/Eno_logo.png?1658364451" + }, + { + "chainId": 1, + "address": "0x2b867efd2de4ad2b583ca0cb3df9c4040ef4d329", + "name": "Lucky Block", + "symbol": "LBLOCK", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/23126/thumb/logo-200x200-LB-09.png?1643268144" + }, + { + "chainId": 1, + "address": "0xe3c408bd53c31c085a1746af401a4042954ff740", + "name": "STEPN", + "symbol": "GMT", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/23597/thumb/gmt.png?1644658792" + }, + { + "chainId": 1, + "address": "0x35609dc59e15d03c5c865507e1348fa5abb319a8", + "name": "GhostMarket", + "symbol": "GM", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/22765/thumb/gm.png?1642574907" + }, + { + "chainId": 1, + "address": "0x34d31446a522252270b89b09016296ec4c98e23d", + "name": "SAUDI SHIBA INU", + "symbol": "SAUDISHIB", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/26708/thumb/FvmN7Wa.png?1659666550" + }, + { + "chainId": 1, + "address": "0x4e568ab95f029e8df1e39b30c9d6d076eaa15945", + "name": "Flycoin FLY", + "symbol": "FLY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26596/thumb/flatArtboard_20tfr.png?1658974032" + }, + { + "chainId": 1, + "address": "0x2c4f1df9c7de0c59778936c9b145ff56813f3295", + "name": "AssetMantle", + "symbol": "MNTL", + "decimals": 6, + "logoURI": "https://assets.coingecko.com/coins/images/25181/thumb/thumbnail.png?1658821784" + }, + { + "chainId": 1, + "address": "0x37129b96896891e56bc099540fe7d1841005a367", + "name": "SpiceEURO", + "symbol": "EUROS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26443/thumb/E4B6C93A-E2A1-4F53-BB26-15D0FE802812.png?1658110215" + }, + { + "chainId": 1, + "address": "0xc87f0a3f3671f7d01278625561dc6e284b62dae9", + "name": "Inflation Adjusted EURO", + "symbol": "IEUROS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26442/thumb/894CE468-A364-42BA-83B0-60A7CA859614.png?1658110157" + }, + { + "chainId": 1, + "address": "0x57b59f981730c6257df57cf6f0d98283749a9eeb", + "name": "BUILD", + "symbol": "BUILD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26533/thumb/BUILD.png?1658714842" + }, + { + "chainId": 1, + "address": "0xde16ce60804a881e9f8c4ebb3824646edecd478d", + "name": "MagicCraft", + "symbol": "MCRT", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/21318/thumb/mcrt.png?1638932009" + }, + { + "chainId": 1, + "address": "0x839e71613f9aa06e5701cf6de63e303616b0dde3", + "name": "VVS Finance", + "symbol": "VVS", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/20210/thumb/8glAYOTM_400x400.jpg?1636667919" + }, + { + "chainId": 1, + "address": "0xe25bcec5d3801ce3a794079bf94adf1b8ccd802d", + "name": "Matrix AI Network", + "symbol": "MAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/2698/thumb/matrix-ai-network.png?1547978533" + }, + { + "chainId": 1, + "address": "0x8616e8ea83f048ab9a5ec513c9412dd2993bce3f", + "name": "handleUSD", + "symbol": "FXUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26954/thumb/fxUSDLogo_200px-200px.png?1660988882" + }, + { + "chainId": 1, + "address": "0xbfc43a35b3ae8f7463c5ac88a0c46107cfce6f67", + "name": "Octus Social Media Market", + "symbol": "OCTSMM", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27095/thumb/photo_2022-08-21_06.15.02.jpeg?1661998030" + }, + { + "chainId": 1, + "address": "0xb08ba4ad6bc291f4f1e79c4c7f9395141b8d5797", + "name": "INTDESTCOIN OLD ", + "symbol": "INTD", + "decimals": 17, + "logoURI": "https://assets.coingecko.com/coins/images/27134/thumb/INTD.png?1662025876" + }, + { + "chainId": 1, + "address": "0x256d1fce1b1221e8398f65f9b36033ce50b2d497", + "name": "Alvey Chain", + "symbol": "WALV", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26964/thumb/logo200x200.png?1661079637" + }, + { + "chainId": 1, + "address": "0xb28f803a8772e6584a65ab6dfc535ae6fef8a0b2", + "name": "Lunafi", + "symbol": "LFI", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24594/thumb/lfi.png?1648310927" + }, + { + "chainId": 1, + "address": "0x6cd13e1856286de773a435c8ba93a7c73a04f82d", + "name": "MIDA", + "symbol": "MIDA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27337/thumb/_MIDA_dark.png?1663499691" + }, + { + "chainId": 1, + "address": "0xc285b7e09a4584d027e5bc36571785b515898246", + "name": "Coin98 Dollar", + "symbol": "CUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26588/thumb/CUSD-01.png?1658909049" + }, + { + "chainId": 1, + "address": "0x2f32b39023da7d6a6486a85d12b346eb9c2a0d19", + "name": "Ferro", + "symbol": "FER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26111/thumb/FER_Token.png?1655887206" + }, + { + "chainId": 1, + "address": "0xaeeb517e65501bcd72399d639a5d993661efeb68", + "name": "INDESTCOIN", + "symbol": "INTD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27543/thumb/logoend.png?1668586274" + }, + { + "chainId": 1, + "address": "0xd6e460f70e1cf60e55b770f66e568b44bf3657d0", + "name": "Funex", + "symbol": "FUNEX", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26814/thumb/20220809_135138.png?1660276769" + }, + { + "chainId": 1, + "address": "0x8d6cebd76f18e1558d4db88138e2defb3909fad6", + "name": "MAI", + "symbol": "MIMATIC", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/15264/thumb/mimatic-red.png?1620281018" + }, + { + "chainId": 1, + "address": "0x7252d57ae4ec9af61db3b82a6eedab74eec5d1dc", + "name": "MondayClub", + "symbol": "MONDAY", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24767/thumb/token.png?1648817450" + }, + { + "chainId": 1, + "address": "0x97bbbc5d96875fb78d2f14b7ff8d7a3a74106f17", + "name": "Astrafer", + "symbol": "ASTRAFER", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/26246/thumb/ATSRA_Token.png?1657276411" + }, + { + "chainId": 1, + "address": "0xb0b195aefa3650a6908f15cdac7d92f8a5791b0b", + "name": "BOB", + "symbol": "BOB", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27266/thumb/Bob-logo.png?1663073030" + }, + { + "chainId": 1, + "address": "0x9a6469aac7cd70385bdca6fa9e9356acec9c5b16", + "name": "SNKRZ", + "symbol": "SKZ", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27657/thumb/skz_200_200.png?1665099924" + }, + { + "chainId": 1, + "address": "0xa719cb79af39a9c10eda2755e0938bce35e9de24", + "name": "Starfish Finance", + "symbol": "SEAN", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27533/thumb/SEAN_Token_icon.png?1664411041" + }, + { + "chainId": 1, + "address": "0x3b79a28264fc52c7b4cea90558aa0b162f7faf57", + "name": "Wonderful Memories", + "symbol": "WMEMO", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/22392/thumb/wMEMO.png?1665832927" + }, + { + "chainId": 1, + "address": "0x19b22dbadc298c359a1d1b59e35f352a2b40e33c", + "name": "tPLATINUM", + "symbol": "TXPT", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27830/thumb/tPLATINUM_token_2D.jpg?1666165908" + }, + { + "chainId": 1, + "address": "0xe4a6f23fb9e00fca037aa0ea0a6954de0a6c53bf", + "name": "tGOLD", + "symbol": "TXAU", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27828/thumb/tGOLD_token_2D.jpg?1666165789" + }, + { + "chainId": 1, + "address": "0x34abce75d2f8f33940c721dca0f562617787bff3", + "name": "tSILVER", + "symbol": "TXAG", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/27829/thumb/tSILVER_token_2D.jpg?1666165851" + }, + { + "chainId": 1, + "address": "0x967fb0d760ed3ce53afe2f0a071674cccae73550", + "name": "XANA", + "symbol": "XETA", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/24379/thumb/XANA_Logo_neon_pink.png?1658197388" + }, + { + "chainId": 1, + "address": "0x59a63e3bc9bc1ce9abfd7b928d13d02d98b818d6", + "name": "Golddoge Sachs", + "symbol": "GDS", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27022/thumb/IMG_20220824_194242_889.jpg?1661484378" + }, + { + "chainId": 1, + "address": "0xcb3c5438dae9fe30b18ea53da3dab0e7dcaa0e4b", + "name": "Risu", + "symbol": "RISU", + "decimals": 9, + "logoURI": "https://assets.coingecko.com/coins/images/27229/thumb/logo_%288%29.png?1667725134" + } + ], + "version": { + "major": 1143, + "minor": 1, + "patch": 0 + } + } \ No newline at end of file diff --git a/src/chains/ethereum/erc20_tokens_ropsten.json b/src/chains/ethereum/erc20_tokens_ropsten.json new file mode 100644 index 0000000000..af0126645c --- /dev/null +++ b/src/chains/ethereum/erc20_tokens_ropsten.json @@ -0,0 +1,17 @@ +{ + "name": "ropsten", + "tokens": [ + { + "symbol": "WETH", + "chainId": 3, + "address": "0xc778417e063141139fce010982780140aa0cd5ab", + "decimals": 18 + }, + { + "symbol": "DAI", + "chainId": 3, + "address": "0xad6d458402f60fd3bd25163575031acdce07538d", + "decimals": 18 + } + ] +} diff --git a/src/chains/ethereum/ethereum.config.ts b/src/chains/ethereum/ethereum.config.ts new file mode 100644 index 0000000000..af7294f28f --- /dev/null +++ b/src/chains/ethereum/ethereum.config.ts @@ -0,0 +1,60 @@ +import { TokenListType } from '../../services/base'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +export interface NetworkConfig { + name: string; + chainID: number; + nodeURL: string; + tokenListType: TokenListType; + tokenListSource: string; + gasPriceRefreshInterval: number | undefined; +} + +export interface EthereumGasStationConfig { + enabled: boolean; + gasStationURL: string; + APIKey: string; + gasLevel: string; +} + +export interface Config { + network: NetworkConfig; + nativeCurrencySymbol: string; + manualGasPrice: number; + gasLimitTransaction: number; +} + +export function getEthereumConfig( + chainName: string, + networkName: string +): Config { + const network = networkName; + return { + network: { + name: network, + chainID: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.chainID' + ), + nodeURL: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.nodeURL' + ), + tokenListType: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.tokenListType' + ), + tokenListSource: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.tokenListSource' + ), + gasPriceRefreshInterval: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.gasPriceRefreshInterval' + ), + }, + nativeCurrencySymbol: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.nativeCurrencySymbol' + ), + manualGasPrice: ConfigManagerV2.getInstance().get( + chainName + '.manualGasPrice' + ), + gasLimitTransaction: ConfigManagerV2.getInstance().get( + chainName + '.gasLimitTransaction' + ), + }; +} diff --git a/src/chains/ethereum/ethereum.controllers.ts b/src/chains/ethereum/ethereum.controllers.ts new file mode 100644 index 0000000000..5fb5767aff --- /dev/null +++ b/src/chains/ethereum/ethereum.controllers.ts @@ -0,0 +1,449 @@ +import ethers, { + constants, + Wallet, + utils, + BigNumber, + Transaction, +} from 'ethers'; +import { latency, bigNumberWithDecimalToStr } from '../../services/base'; +import { + HttpException, + OUT_OF_GAS_ERROR_CODE, + OUT_OF_GAS_ERROR_MESSAGE, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { tokenValueToString } from '../../services/base'; +import { TokenInfo } from '../../services/ethereum-base'; +import { getConnector } from '../../services/connection-manager'; + +import { + CustomTransactionReceipt, + CustomTransaction, + CustomTransactionResponse, +} from './ethereum.requests'; +import { + Ethereumish, + UniswapLPish, + Uniswapish, +} from '../../services/common-interfaces'; +import { + NonceRequest, + NonceResponse, + AllowancesRequest, + AllowancesResponse, + ApproveRequest, + ApproveResponse, + CancelRequest, + CancelResponse, +} from '../../evm/evm.requests'; +import { + PollRequest, + PollResponse, + BalanceRequest, + BalanceResponse, +} from '../../network/network.requests'; +import { logger } from '../../services/logger'; + +export async function nonce( + ethereum: Ethereumish, + req: NonceRequest +): Promise { + // get the address via the public key since we generally use the public + // key to interact with gateway and the address is not part of the user config + const wallet = await ethereum.getWallet(req.address); + const nonce = await ethereum.nonceManager.getNonce(wallet.address); + return { nonce }; +} + +export async function nextNonce( + ethereum: Ethereumish, + req: NonceRequest +): Promise { + // get the address via the public key since we generally use the public + // key to interact with gateway and the address is not part of the user config + const wallet = await ethereum.getWallet(req.address); + const nonce = await ethereum.nonceManager.getNextNonce(wallet.address); + return { nonce }; +} + +export const getTokenSymbolsToTokens = ( + ethereum: Ethereumish, + tokenSymbols: Array +): Record => { + const tokens: Record = {}; + + for (let i = 0; i < tokenSymbols.length; i++) { + const symbol = tokenSymbols[i]; + const token = ethereum.getTokenBySymbol(symbol); + if (token) tokens[symbol] = token; + } + + return tokens; +}; + +export async function allowances( + ethereumish: Ethereumish, + req: AllowancesRequest +): Promise { + const initTime = Date.now(); + const wallet = await ethereumish.getWallet(req.address); + const tokens = getTokenSymbolsToTokens(ethereumish, req.tokenSymbols); + const spender = ethereumish.getSpender(req.spender); + + const approvals: Record = {}; + await Promise.all( + Object.keys(tokens).map(async (symbol) => { + // instantiate a contract and pass in provider for read-only access + const contract = ethereumish.getContract( + tokens[symbol].address, + ethereumish.provider + ); + approvals[symbol] = tokenValueToString( + await ethereumish.getERC20Allowance( + contract, + wallet, + spender, + tokens[symbol].decimals + ) + ); + }) + ); + + return { + network: ethereumish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + spender: spender, + approvals: approvals, + }; +} + +export async function balances( + ethereumish: Ethereumish, + req: BalanceRequest +): Promise { + const initTime = Date.now(); + + let wallet: Wallet; + try { + wallet = await ethereumish.getWallet(req.address); + } catch (err) { + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + const tokens = getTokenSymbolsToTokens(ethereumish, req.tokenSymbols); + const balances: Record = {}; + if (req.tokenSymbols.includes(ethereumish.nativeTokenSymbol)) { + balances[ethereumish.nativeTokenSymbol] = tokenValueToString( + await ethereumish.getNativeBalance(wallet) + ); + } + await Promise.all( + Object.keys(tokens).map(async (symbol) => { + if (tokens[symbol] !== undefined) { + const address = tokens[symbol].address; + const decimals = tokens[symbol].decimals; + // instantiate a contract and pass in provider for read-only access + const contract = ethereumish.getContract(address, ethereumish.provider); + const balance = await ethereumish.getERC20Balance( + contract, + wallet, + decimals + ); + balances[symbol] = tokenValueToString(balance); + } + }) + ); + + if (!Object.keys(balances).length) { + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + } + + return { + network: ethereumish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + balances: balances, + }; +} + +const toEthereumTransaction = (transaction: Transaction): CustomTransaction => { + let maxFeePerGas = null; + if (transaction.maxFeePerGas) { + maxFeePerGas = transaction.maxFeePerGas.toString(); + } + let maxPriorityFeePerGas = null; + if (transaction.maxPriorityFeePerGas) { + maxPriorityFeePerGas = transaction.maxPriorityFeePerGas.toString(); + } + let gasLimit = null; + if (transaction.gasLimit) { + gasLimit = transaction.gasLimit.toString(); + } + return { + ...transaction, + maxPriorityFeePerGas, + maxFeePerGas, + gasLimit, + value: transaction.value.toString(), + }; +}; + +export async function approve( + ethereumish: Ethereumish, + req: ApproveRequest +): Promise { + const { amount, nonce, address, token, maxFeePerGas, maxPriorityFeePerGas } = + req; + + const spender = ethereumish.getSpender(req.spender); + const initTime = Date.now(); + let wallet: Wallet; + try { + wallet = await ethereumish.getWallet(address); + } catch (err) { + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + const fullToken = ethereumish.getTokenBySymbol(token); + if (!fullToken) { + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + token, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + } + const amountBigNumber = amount + ? utils.parseUnits(amount, fullToken.decimals) + : constants.MaxUint256; + + let maxFeePerGasBigNumber; + if (maxFeePerGas) { + maxFeePerGasBigNumber = BigNumber.from(maxFeePerGas); + } + let maxPriorityFeePerGasBigNumber; + if (maxPriorityFeePerGas) { + maxPriorityFeePerGasBigNumber = BigNumber.from(maxPriorityFeePerGas); + } + // instantiate a contract and pass in wallet, which act on behalf of that signer + const contract = ethereumish.getContract(fullToken.address, wallet); + + // convert strings to BigNumber + // call approve function + const approval = await ethereumish.approveERC20( + contract, + wallet, + spender, + amountBigNumber, + nonce, + maxFeePerGasBigNumber, + maxPriorityFeePerGasBigNumber, + ethereumish.gasPrice + ); + + if (approval.hash) { + await ethereumish.txStorage.saveTx( + ethereumish.chain, + ethereumish.chainId, + approval.hash, + new Date(), + ethereumish.gasPrice + ); + } + + return { + network: ethereumish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + tokenAddress: fullToken.address, + spender: spender, + amount: bigNumberWithDecimalToStr(amountBigNumber, fullToken.decimals), + nonce: approval.nonce, + approval: toEthereumTransaction(approval), + }; +} + +// TransactionReceipt from ethers uses BigNumber which is not easy to interpret directly from JSON. +// Transform those BigNumbers to string and pass the rest of the data without changes. + +const toEthereumTransactionReceipt = ( + receipt: ethers.providers.TransactionReceipt | null +): CustomTransactionReceipt | null => { + if (receipt) { + let effectiveGasPrice = null; + if (receipt.effectiveGasPrice) { + effectiveGasPrice = receipt.effectiveGasPrice.toString(); + } + return { + ...receipt, + gasUsed: receipt.gasUsed.toString(), + cumulativeGasUsed: receipt.cumulativeGasUsed.toString(), + effectiveGasPrice, + }; + } + + return null; +}; + +const toEthereumTransactionResponse = ( + response: ethers.providers.TransactionResponse | null +): CustomTransactionResponse | null => { + if (response) { + let gasPrice = null; + if (response.gasPrice) { + gasPrice = response.gasPrice.toString(); + } + return { + ...response, + gasPrice, + gasLimit: response.gasLimit.toString(), + value: response.value.toString(), + }; + } + + return null; +}; + +export function willTxSucceed( + txDuration: number, + txDurationLimit: number, + txGasPrice: number, + currentGasPrice: number +): boolean { + if (txDuration > txDurationLimit && currentGasPrice > txGasPrice) { + return false; + } + return true; +} + +// txStatus +// -1: not in the mempool or failed +// 1: succeeded +// 2: in the mempool and likely to succeed +// 3: in the mempool and likely to fail +// 0: in the mempool but we dont have data to guess its status +export async function poll( + ethereumish: Ethereumish, + req: PollRequest +): Promise { + const initTime = Date.now(); + const currentBlock = await ethereumish.getCurrentBlockNumber(); + const txData = await ethereumish.getTransaction(req.txHash); + let txBlock, txReceipt, txStatus; + if (!txData) { + // tx not found, didn't reach the mempool or it never existed + txBlock = -1; + txReceipt = null; + txStatus = -1; + } else { + txReceipt = await ethereumish.getTransactionReceipt(req.txHash); + if (txReceipt === null) { + // tx is in the mempool + txBlock = -1; + txReceipt = null; + txStatus = 0; + + const transactions = await ethereumish.txStorage.getTxs( + ethereumish.chain, + ethereumish.chainId + ); + + if (transactions[txData.hash]) { + const data: [Date, number] = transactions[txData.hash]; + const now = new Date(); + const txDuration = Math.abs(now.getTime() - data[0].getTime()); + if ( + willTxSucceed(txDuration, 60000 * 3, data[1], ethereumish.gasPrice) + ) { + txStatus = 2; + } else { + txStatus = 3; + } + } + } else { + // tx has been processed + txBlock = txReceipt.blockNumber; + txStatus = typeof txReceipt.status === 'number' ? 1 : -1; + if (txReceipt.status === 0) { + const gasUsed = BigNumber.from(txReceipt.gasUsed).toNumber(); + const gasLimit = BigNumber.from(txData.gasLimit).toNumber(); + if (gasUsed / gasLimit > 0.9) { + throw new HttpException( + 503, + OUT_OF_GAS_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_CODE + ); + } + } + // decode logs + if (req.connector) { + try { + const connector: Uniswapish | UniswapLPish = await getConnector< + Uniswapish | UniswapLPish + >(req.chain, req.network, req.connector); + txReceipt.logs = connector.abiDecoder?.decodeLogs(txReceipt.logs); + } catch (e) { + logger.error(e); + } + } + } + } + + logger.info( + `Poll ${ethereumish.chain}, txHash ${req.txHash}, status ${txStatus}.` + ); + return { + network: ethereumish.chain, + currentBlock, + timestamp: initTime, + txHash: req.txHash, + txBlock, + txStatus, + txData: toEthereumTransactionResponse(txData), + txReceipt: toEthereumTransactionReceipt(txReceipt), + }; +} + +export async function cancel( + ethereumish: Ethereumish, + req: CancelRequest +): Promise { + const initTime = Date.now(); + let wallet: Wallet; + try { + wallet = await ethereumish.getWallet(req.address); + } catch (err) { + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + + // call cancelTx function + const cancelTx = await ethereumish.cancelTx(wallet, req.nonce); + + logger.info( + `Cancelled transaction at nonce ${req.nonce}, cancel txHash ${cancelTx.hash}.` + ); + + return { + network: ethereumish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + txHash: cancelTx.hash, + }; +} diff --git a/src/chains/ethereum/ethereum.requests.ts b/src/chains/ethereum/ethereum.requests.ts new file mode 100644 index 0000000000..dbfa95a58f --- /dev/null +++ b/src/chains/ethereum/ethereum.requests.ts @@ -0,0 +1,117 @@ +import ethers, { Transaction } from 'ethers'; + +// gasUsed and cumulativeGasUsed are BigNumbers +// then need to be converted to strings before being +// passed to the client +export interface CustomTransactionReceipt + extends Omit< + ethers.providers.TransactionReceipt, + 'gasUsed' | 'cumulativeGasUsed' | 'effectiveGasPrice' + > { + gasUsed: string; + cumulativeGasUsed: string; + effectiveGasPrice: string | null; +} + +export interface CustomTransaction + extends Omit< + Transaction, + 'maxPriorityFeePerGas' | 'maxFeePerGas' | 'gasLimit' | 'value' + > { + maxPriorityFeePerGas: string | null; + maxFeePerGas: string | null; + gasLimit: string | null; + value: string; +} + +export interface CustomTransactionResponse + extends Omit< + ethers.providers.TransactionResponse, + 'gasPrice' | 'gasLimit' | 'value' + > { + gasPrice: string | null; + gasLimit: string; + value: string; +} + +export interface EthereumNonceRequest { + address: string; // the users public Ethereum key +} + +export interface EthereumNonceResponse { + nonce: number; // the user's nonce +} + +export interface EthereumAllowancesRequest { + address: string; // the users public Ethereum key + spender: string; // the spender address for whom approvals are checked + tokenSymbols: string[]; // a list of token symbol +} + +export interface EthereumAllowancesResponse { + network: string; + timestamp: number; + latency: number; + spender: string; + approvals: Record; +} + +export interface EthereumBalanceRequest { + address: string; // the users public Ethereum key + tokenSymbols: string[]; // a list of token symbol +} + +export interface EthereumBalanceResponse { + network: string; + timestamp: number; + latency: number; + balances: Record; // the balance should be a string encoded number +} + +export interface EthereumApproveRequest { + amount?: string; // the amount the spender will be approved to use + nonce?: number; // the address's next nonce + maxFeePerGas?: string; + maxPriorityFeePerGas?: string; + address: string; // the user's public Ethereum key + spender: string; // the address of the spend (or a pre-defined string like 'uniswap', 'balancer', etc.) + token: string; // the token symbol the spender will be approved for +} + +export interface EthereumApproveResponse { + network: string; + timestamp: number; + latency: number; + tokenAddress: string; + spender: string; + amount: string; + nonce: number; + approval: CustomTransaction; +} + +export interface PollRequest { + txHash: string; +} + +export interface PollResponse { + network: string; + timestamp: number; + currentBlock: number; + txHash: string; + txStatus: number; + txBlock: number; + txData: CustomTransactionResponse | null; + txReceipt: CustomTransactionReceipt | null; +} + +export interface EthereumCancelRequest { + nonce: number; // the nonce of the transaction to be canceled + address: string; // the user's public Ethereum key +} + +export interface EthereumCancelResponse { + network: string; + timestamp: number; + latency: number; + txHash: string | undefined; +} diff --git a/src/chains/ethereum/ethereum.ts b/src/chains/ethereum/ethereum.ts new file mode 100644 index 0000000000..a0e9903151 --- /dev/null +++ b/src/chains/ethereum/ethereum.ts @@ -0,0 +1,195 @@ +import abi from '../../services/ethereum.abi.json'; +import { logger } from '../../services/logger'; +import { BigNumber, Contract, Transaction, Wallet } from 'ethers'; +import { EthereumBase } from '../../services/ethereum-base'; +import { getEthereumConfig } from './ethereum.config'; +import { Provider } from '@ethersproject/abstract-provider'; +import { UniswapConfig } from '../../connectors/uniswap/uniswap.config'; +import { Perp } from '../../connectors/perp/perp'; +import { Ethereumish } from '../../services/common-interfaces'; +import { SushiswapConfig } from '../../connectors/sushiswap/sushiswap.config'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +// MKR does not match the ERC20 perfectly so we need to use a separate ABI. +const MKR_ADDRESS = '0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2'; + +export class Ethereum extends EthereumBase implements Ethereumish { + private static _instances: { [name: string]: Ethereum }; + private _gasPrice: number; + private _gasPriceRefreshInterval: number | null; + private _nativeTokenSymbol: string; + private _chain: string; + private _requestCount: number; + private _metricsLogInterval: number; + + private constructor(network: string) { + const config = getEthereumConfig('ethereum', network); + super( + 'ethereum', + config.network.chainID, + config.network.nodeURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.nonceDbPath'), + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = network; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + this._gasPrice = config.manualGasPrice; + this._gasPriceRefreshInterval = + config.network.gasPriceRefreshInterval !== undefined + ? config.network.gasPriceRefreshInterval + : null; + + this.updateGasPrice(); + + this._requestCount = 0; + this._metricsLogInterval = 300000; // 5 minutes + + this.onDebugMessage(this.requestCounter.bind(this)); + setInterval(this.metricLogger.bind(this), this.metricsLogInterval); + } + + public static getInstance(network: string): Ethereum { + if (Ethereum._instances === undefined) { + Ethereum._instances = {}; + } + if (!(network in Ethereum._instances)) { + Ethereum._instances[network] = new Ethereum(network); + } + + return Ethereum._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Ethereum } { + return Ethereum._instances; + } + + public requestCounter(msg: any): void { + if (msg.action === 'request') this._requestCount += 1; + } + + public metricLogger(): void { + logger.info( + this.requestCount + + ' request(s) sent in last ' + + this.metricsLogInterval / 1000 + + ' seconds.' + ); + this._requestCount = 0; // reset + } + + // getters + public get gasPrice(): number { + return this._gasPrice; + } + + public get chain(): string { + return this._chain; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get requestCount(): number { + return this._requestCount; + } + + public get metricsLogInterval(): number { + return this._metricsLogInterval; + } + + /** + * Automatically update the prevailing gas price on the network. + * + * Otherwise, it'll obtain the prevailing gas price from the connected + * ETH node. + */ + async updateGasPrice(): Promise { + if (this._gasPriceRefreshInterval === null) { + return; + } + + const gasPrice = await this.getGasPriceFromEthereumNode(); + if (gasPrice !== null) { + this._gasPrice = gasPrice; + } else { + logger.info('gasPrice is unexpectedly null.'); + } + + setTimeout( + this.updateGasPrice.bind(this), + this._gasPriceRefreshInterval * 1000 + ); + } + + /** + * Get the base gas fee and the current max priority fee from the Ethereum + * node, and add them together. + */ + async getGasPriceFromEthereumNode(): Promise { + const baseFee: BigNumber = await this.provider.getGasPrice(); + let priorityFee: BigNumber = BigNumber.from('0'); + if (this._chain === 'mainnet') { + priorityFee = BigNumber.from( + await this.provider.send('eth_maxPriorityFeePerGas', []) + ); + } + return baseFee.add(priorityFee).toNumber() * 1e-9; + } + + getContract( + tokenAddress: string, + signerOrProvider?: Wallet | Provider + ): Contract { + return tokenAddress === MKR_ADDRESS + ? new Contract(tokenAddress, abi.MKRAbi, signerOrProvider) + : new Contract(tokenAddress, abi.ERC20Abi, signerOrProvider); + } + + // TODO Check the possibility to use something similar for CLOB/Solana/Serum + // Use the following link: https://hummingbot.org/developers/gateway/building-gateway-connectors/#6-add-connector-to-spender-list + getSpender(reqSpender: string): string { + let spender: string; + if (reqSpender === 'uniswap') { + spender = UniswapConfig.config.uniswapV3SmartOrderRouterAddress( + this._chain + ); + } else if (reqSpender === 'sushiswap') { + spender = SushiswapConfig.config.sushiswapRouterAddress( + this.chainName, + this._chain + ); + } else if (reqSpender === 'uniswapLP') { + spender = UniswapConfig.config.uniswapV3NftManagerAddress(this._chain); + } else if (reqSpender === 'perp') { + const perp = Perp.getInstance(this._chain, 'optimism'); + if (!perp.ready()) { + perp.init(); + throw Error('Perp curie not ready'); + } + spender = perp.perp.contracts.vault.address; + } else { + spender = reqSpender; + } + return spender; + } + + // cancel transaction + async cancelTx(wallet: Wallet, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return this.cancelTxWithGasPrice(wallet, nonce, this._gasPrice * 2); + } + + async close() { + await super.close(); + if (this._chain in Ethereum._instances) { + delete Ethereum._instances[this._chain]; + } + } +} diff --git a/src/chains/ethereum/ethereum.validators.ts b/src/chains/ethereum/ethereum.validators.ts new file mode 100644 index 0000000000..1f86c9a0f0 --- /dev/null +++ b/src/chains/ethereum/ethereum.validators.ts @@ -0,0 +1,133 @@ +import { + isNaturalNumberString, + validateTokenSymbols, + mkValidator, + mkRequestValidator, + RequestValidator, + Validator, + validateToken, + validateAmount, +} from '../../services/validators'; + +// invalid parameter errors + +export const invalidAddressError: string = + 'The address param is not a valid Ethereum private key (64 hexidecimal characters).'; + +export const invalidSpenderError: string = + 'The spender param is not a valid Ethereum address (0x followed by 40 hexidecimal characters).'; + +export const invalidNonceError: string = + 'If nonce is included it must be a non-negative integer.'; + +export const invalidMaxFeePerGasError: string = + 'If maxFeePerGas is included it must be a string of a non-negative integer.'; + +export const invalidMaxPriorityFeePerGasError: string = + 'If maxPriorityFeePerGas is included it must be a string of a non-negative integer.'; + +export const invalidChainError: string = 'The chain param is not a string.'; + +export const invalidNetworkError: string = 'The network param is not a string.'; + +// test if a string matches the shape of an Ethereum address +export const isAddress = (str: string): boolean => { + return /^0x[a-fA-F0-9]{40}$/.test(str); +}; + +// given a request, look for a key called address that is an Ethereum wallet +export const validateAddress: Validator = mkValidator( + 'address', + invalidAddressError, + (val) => typeof val === 'string' && isAddress(val) +); + +// given a request, look for a key called spender that is 'uniswap' or an Ethereum address +export const validateSpender: Validator = mkValidator( + 'spender', + invalidSpenderError, + (val) => + typeof val === 'string' && + (val === 'uniswap' || + val === 'perp' || + val === 'uniswapLP' || + val === 'pangolin' || + val === 'traderjoe' || + val === 'sushiswap' || + val === 'viperswap' || + val === 'openocean' || + val === 'quickswap' || + val === 'defikingdoms' || + val === 'defira' || + val === 'mad_meerkat' || + val === 'vvs' || + val === 'pancakeswap' || + isAddress(val)) +); + +export const validateNonce: Validator = mkValidator( + 'nonce', + invalidNonceError, + (val) => + typeof val === 'undefined' || + (typeof val === 'number' && val >= 0 && Number.isInteger(val)), + true +); + +export const validateMaxFeePerGas: Validator = mkValidator( + 'maxFeePerGas', + invalidMaxFeePerGasError, + (val) => typeof val === 'string' && isNaturalNumberString(val), + true +); + +export const validateMaxPriorityFeePerGas: Validator = mkValidator( + 'maxPriorityFeePerGas', + invalidMaxPriorityFeePerGasError, + (val) => typeof val === 'string' && isNaturalNumberString(val), + true +); + +export const validateChain: Validator = mkValidator( + 'chain', + invalidChainError, + (val) => typeof val === 'string' +); + +export const validateNetwork: Validator = mkValidator( + 'network', + invalidNetworkError, + (val) => typeof val === 'string' +); + +// request types and corresponding validators + +export const validateNonceRequest: RequestValidator = mkRequestValidator([ + validateAddress, +]); + +export const validateAllowancesRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateSpender, + validateTokenSymbols, +]); + +export const validateBalanceRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateTokenSymbols, +]); + +export const validateApproveRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateSpender, + validateToken, + validateAmount, + validateNonce, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, +]); + +export const validateCancelRequest: RequestValidator = mkRequestValidator([ + validateNonce, + validateAddress, +]); diff --git a/src/chains/ethereum/optimism_tokens.json b/src/chains/ethereum/optimism_tokens.json new file mode 100644 index 0000000000..699f047e75 --- /dev/null +++ b/src/chains/ethereum/optimism_tokens.json @@ -0,0 +1,3152 @@ +{ + "name": "Optimism", + "logoURI": "https://ethereum-optimism.github.io/optimism.svg", + "keywords": [ + "scaling", + "layer2", + "infrastructure" + ], + "timestamp": "2022-12-14T18:10:34.303Z", + "tokens": [ + { + "chainId": 1, + "address": "0xb6ed7644c69416d67b522e20bc294a9a9b405b31", + "name": "0xBitcoin", + "symbol": "0xBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/0xBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xe0BB0D3DE8c10976511e5030cA403dBf4c25165B", + "name": "0xBitcoin", + "symbol": "0xBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/0xBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x24a19ee5a5c8757acdebe542a9436d9c796d1c9e", + "name": "0xBitcoin", + "symbol": "0xBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/0xBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x56B4F5f44d348EC3F07Bf1f31A3B566E5304BedE", + "name": "0xBitcoin", + "symbol": "0xBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/0xBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x7Fc66500c84A76Ad7e9c93437bFc5Ac33E2DDaE9", + "name": "Aave Token", + "symbol": "AAVE", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/AAVE/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x76FB31fb4af56892A25e32cFC43De717950c9278", + "name": "Aave Token", + "symbol": "AAVE", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/AAVE/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x9BE876c6DC42215B00d7efe892E2691C3bc35d10", + "name": "Aave Token", + "symbol": "AAVE", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/AAVE/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x76FB31fb4af56892A25e32cFC43De717950c9278", + "name": "Aave Token", + "symbol": "AAVE", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/AAVE/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x2b95a1dcc3d405535f9ed33c219ab38e8d7e0884", + "name": "AladdinCRV", + "symbol": "aCRV", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/aCRV/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x764ad60e1b81f6cacfec1a2926393d688d4493e6", + "name": "AladdinCRV", + "symbol": "aCRV", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/aCRV/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x12b1326459d72f2ab081116bf27ca46cd97762a0", + "name": "AladdinCRV", + "symbol": "aCRV", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/aCRV/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xf882ac9259a378e102f058f2fb093dffeca96437", + "name": "AladdinCRV", + "symbol": "aCRV", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/aCRV/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x44108f0223A3C3028F5Fe7AEC7f9bb2E66beF82F", + "name": "Across Protocol Token", + "symbol": "ACX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ACX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xff733b2a3557a7ed6697007ab5d11b79fdd1b76b", + "name": "Across Protocol Token", + "symbol": "ACX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ACX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x61BAADcF22d2565B0F471b291C475db5555e0b76", + "name": "Aelin Protocol", + "symbol": "AELIN", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/AELIN/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0100546f2cd4c9d97f798ffc9755e47865ff7ee6", + "name": "Alchemix ETH", + "symbol": "alETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/alETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x3e29d3a9316dab217754d13b28646b76607c5f04", + "name": "Alchemix ETH", + "symbol": "alETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/alETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xba100000625a3754423978a60c9317c58a424e3D", + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAL/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xFE8B128bA8C78aabC59d4c64cEE7fF28e9379921", + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAL/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x41286Bb1D3E870f3F750eB7E1C25d7E48c8A1Ac7", + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAL/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xc72751efd79B153D5bdC7E1a43b4b98aA2aA04C7", + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAL/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x2d94aa3e47d9d5024503ca8491fce9a2fb4da198", + "name": "Bankless Token", + "symbol": "BANK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BANK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x29FAF5905bfF9Cfcc7CF56a5ed91E0f091F8664B", + "name": "Bankless Token", + "symbol": "BANK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BANK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x91B08f4A7C1251dfCcF5440F8894F8DaA10c8De5", + "name": "BAXagent Coin", + "symbol": "BAXA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAXA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xDb9888b842408B0b8eFa1f5477bD9F351754999E", + "name": "BAXagent Coin", + "symbol": "BAXA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAXA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x0Fc18b0CB89611C03Fc1Ba6876bdfE22317924FE", + "name": "BAXagent Coin", + "symbol": "BAXA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAXA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xD7eA82D19f1f59FF1aE95F1945Ee6E6d86A25B96", + "name": "BAXagent Coin", + "symbol": "BAXA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BAXA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x15Ee120fD69BEc86C1d38502299af7366a41D1a6", + "name": "BitANT", + "symbol": "BitANT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitANT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x5029C236320b8f15eF0a657054B84d90bfBEDED3", + "name": "BitANT", + "symbol": "BitANT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitANT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x3Ef0aBa205134ba2f449Fa04A0A0673020c36270", + "name": "BitANT", + "symbol": "BitANT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitANT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x1f748732AF4442Cf508DEf0882ad9fcB5E5205a2", + "name": "BitANT", + "symbol": "BitANT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitANT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x3C513dB8Bdc3806e4489d62C3d549A5Aaf6A4e97", + "name": "BitBTC", + "symbol": "BitBTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0xaBA2c5F108F7E820C049D5Af70B16ac266c8f128" + } + }, + { + "chainId": 10, + "address": "0xc98B98d17435AA00830c87eA02474C5007E1f272", + "name": "BitBTC", + "symbol": "BitBTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x158F513096923fF2d3aab2BcF4478536de6725e2" + } + }, + { + "chainId": 42, + "address": "0xF6DD2A9B840826D53c9842207628502B79E6B8c2", + "name": "BitBTC", + "symbol": "BitBTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x0b651A42F32069d62d5ECf4f2a7e5Bd3E9438746" + } + }, + { + "chainId": 69, + "address": "0x83643C9eF0c5707A7815124754d0828c9A38be3a", + "name": "BitBTC", + "symbol": "BitBTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BitBTC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x0CFb46528a7002a7D8877a5F7a69b9AaF1A9058e" + } + }, + { + "chainId": 1, + "address": "0xB0B195aEFA3650A6908f15CdaC7D92F8a5791B0B", + "name": "BOB Token", + "symbol": "BOB", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BOB/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xB0B195aEFA3650A6908f15CdaC7D92F8a5791B0B", + "name": "BOB Token", + "symbol": "BOB", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BOB/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0391D2021f89DC339F60Fff84546EA23E337750f", + "name": "BarnBridge Governance Token", + "symbol": "BOND", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BOND/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x3e7eF8f50246f725885102E8238CBba33F276747", + "name": "BarnBridge Governance Token", + "symbol": "BOND", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BOND/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x521EE0CeDbed2a5A130B9218551fe492C5c402e4", + "name": "BarnBridge Governance Token", + "symbol": "BOND", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BOND/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x9e5AAC1Ba1a2e6aEd6b32689DFcF62A509Ca96f3", + "name": "BarnBridge Governance Token", + "symbol": "BOND", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/BOND/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xD533a949740bb3306d119CC777fa900bA034cd52", + "name": "Curve DAO Token", + "symbol": "CRV", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/CRV/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x0994206dfe8de6ec6920ff4d779b0d950605fb53", + "name": "Curve DAO Token", + "symbol": "CRV", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/CRV/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x491604c0FDF08347Dd1fa4Ee062a822A5DD06B5D", + "name": "Cartesi Token", + "symbol": "CTSI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/CTSI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xEc6adef5E1006bb305bB1975333e8fc4071295bf", + "name": "Cartesi Token", + "symbol": "CTSI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/CTSI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 69, + "address": "0xEc6adef5E1006bb305bB1975333e8fc4071295bf", + "name": "Cartesi Token", + "symbol": "CTSI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/CTSI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x6B175474E89094C44Da98b954EedeAC495271d0F", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x10E6593CDda8c58a1d0f14C5164B376352a55f2F" + } + }, + { + "chainId": 10, + "address": "0xDA10009cBd5D07dd0CeCc66161FC93D7c9000da1", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x467194771dAe2967Aef3ECbEDD3Bf9a310C76C65" + } + }, + { + "chainId": 42, + "address": "0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0xb415e822C4983ecD6B1c1596e8a5f976cf6CD9e3" + } + }, + { + "chainId": 69, + "address": "0xDA10009cBd5D07dd0CeCc66161FC93D7c9000da1", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x467194771dAe2967Aef3ECbEDD3Bf9a310C76C65" + } + }, + { + "chainId": 5, + "address": "0x11fE4B6AE13d2a6055C8D9cF65c55bac32B5d844", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x05a388Db09C2D44ec0b00Ee188cD42365c42Df23" + } + }, + { + "chainId": 420, + "address": "0xDA10009cBd5D07dd0CeCc66161FC93D7c9000da1", + "name": "Dai Stablecoin", + "symbol": "DAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x467194771dAe2967Aef3ECbEDD3Bf9a310C76C65" + } + }, + { + "chainId": 1, + "address": "0x08d32b0da63e2C3bcF8019c9c5d849d7a9d791e6", + "name": "Dentacoin", + "symbol": "DCN", + "decimals": 0, + "logoURI": "https://ethereum-optimism.github.io/data/DCN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x1da650c3b2daa8aa9ff6f661d4156ce24d08a062", + "name": "Dentacoin", + "symbol": "DCN", + "decimals": 0, + "logoURI": "https://ethereum-optimism.github.io/data/DCN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x001dedC8c67EF6D1f4BB66FB28581d466650Cd76", + "name": "Dentacoin", + "symbol": "DCN", + "decimals": 0, + "logoURI": "https://ethereum-optimism.github.io/data/DCN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xfd6ab60e0744e95c35fb17afda478eeae3835ddf", + "name": "Dentacoin", + "symbol": "DCN", + "decimals": 0, + "logoURI": "https://ethereum-optimism.github.io/data/DCN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x431ad2ff6a9C365805eBaD47Ee021148d6f7DBe0", + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DF/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x9e5AAC1Ba1a2e6aEd6b32689DFcF62A509Ca96f3", + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DF/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x79E40d67DA6eAE5eB4A93Fc6a56A7961625E15F3", + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DF/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x3e7eF8f50246f725885102E8238CBba33F276747", + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DF/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xca1207647Ff814039530D7d35df0e1Dd2e91Fa84", + "name": "dHEDGE DAO Token", + "symbol": "DHT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DHT/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xAF9fE3B5cCDAe78188B1F8b9a49Da7ae9510F151", + "name": "dHEDGE DAO Token", + "symbol": "DHT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DHT/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x865377367054516e17014CcdED1e7d814EDC9ce4", + "name": "Dola USD Stablecoin", + "symbol": "DOLA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DOLA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x8aE125E8653821E851F12A49F7765db9a9ce7384", + "name": "Dola USD Stablecoin", + "symbol": "DOLA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DOLA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x39445DEc9Ba7Fb3776E8E5f9922864ddb9089304", + "name": "Dola USD Stablecoin", + "symbol": "DOLA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DOLA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x0D760ee479401Bb4C40BDB7604b329FfF411b3f2", + "name": "Dola USD Stablecoin", + "symbol": "DOLA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DOLA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x92E187a03B6CD19CB6AF293ba17F2745Fd2357D5", + "name": "Unit protocol", + "symbol": "DUCK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DUCK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x0e49ca6ea763190084c846d3fc18f28bc2ac689a", + "name": "Unit protocol", + "symbol": "DUCK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/DUCK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xc18360217d8f7ab5e7c516566761ea12ce7f9d72", + "name": "Ethereum Name Service", + "symbol": "ENS", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ENS/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x65559aA14915a70190438eF90104769e5E890A00", + "name": "Ethereum Name Service", + "symbol": "ENS", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ENS/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x1da87b114f35e1dc91f72bf57fc07a768ad40bb0", + "name": "Equalizer", + "symbol": "EQZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/EQZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x81ab7e0d570b01411fcc4afd3d50ec8c241cb74b", + "name": "Equalizer", + "symbol": "EQZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/EQZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xea281a04cf517aa0d4645bdda0353b0958e4b1b4", + "name": "Equalizer", + "symbol": "EQZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/EQZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x8ee73c484a26e0a5df2ee2a4960b789967dd0415", + "name": "Equalizer", + "symbol": "EQZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/EQZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x259ab9b9eab62b0fd98729b97be121073d5b3479", + "name": "Erica Social Token", + "symbol": "EST", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/EST/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x7b0bcC23851bBF7601efC9E9FE532Bf5284F65d3", + "name": "Erica Social Token", + "symbol": "EST", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/EST/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0000000000000000000000000000000000000000", + "name": "Ether", + "symbol": "ETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xDeadDeAddeAddEAddeadDEaDDEAdDeaDDeAD0000", + "name": "Ether", + "symbol": "ETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x0000000000000000000000000000000000000000", + "name": "Ether", + "symbol": "ETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 5, + "address": "0x0000000000000000000000000000000000000000", + "name": "Ether", + "symbol": "ETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 69, + "address": "0xDeadDeAddeAddEAddeadDEaDDEAdDeaDDeAD0000", + "name": "Ether", + "symbol": "ETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 420, + "address": "0xDeadDeAddeAddEAddeadDEaDDEAdDeaDDeAD0000", + "name": "Ether", + "symbol": "ETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x50EB44e3a68f1963278b4c74c6c343508d31704C", + "name": "Tether EUR", + "symbol": "EURT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/EURT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x65e44970ebFe42f98F83c4B67062DE94B9f3Da7D", + "name": "Tether EUR", + "symbol": "EURT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/EURT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xB1f1F47061A7Be15C69f378CB3f69423bD58F2F8", + "name": "Flashstake", + "symbol": "FLASH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/FLASH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x86bEA60374f220dE9769b2fEf2db725bc1cDd335", + "name": "Flashstake", + "symbol": "FLASH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/FLASH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x853d955aCEf822Db058eb8505911ED77F175b99e", + "name": "FRAX", + "symbol": "FRAX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/FRAX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x2E3D870790dC77A83DD1d18184Acc7439A53f475", + "name": "FRAX", + "symbol": "FRAX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/FRAX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x3432B6A60D23Ca0dFCa7761B7ab56459D9C964D0", + "name": "FXS", + "symbol": "FXS", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/FXS/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x67CCEA5bb16181E7b4109c9c2143c24a1c2205Be", + "name": "FXS", + "symbol": "FXS", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/FXS/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x4FbB350052Bca5417566f188eB2EBCE5b19BC964", + "name": "Rigo Token", + "symbol": "GRG", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GRG/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xEcF46257ed31c329F204Eb43E254C609dee143B3", + "name": "Rigo Token", + "symbol": "GRG", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GRG/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xde30da39c46104798bb5aa3fe8b9e0e1f348163f", + "name": "Gitcoin", + "symbol": "GTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x1eba7a6a72c894026cd654ac5cdcf83a46445b08", + "name": "Gitcoin", + "symbol": "GTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xb7e230f904971724c600ad5217b88d219ddd1525", + "name": "Gitcoin", + "symbol": "GTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xaf8ca653fa2772d58f4368b0a71980e9e3ceb888", + "name": "Gitcoin", + "symbol": "GTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xbEa98c05eEAe2f3bC8c3565Db7551Eb738c8CCAb", + "name": "Geyser", + "symbol": "GYSR", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GYSR/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x117cFd9060525452db4A34d51c0b3b7599087f05", + "name": "Geyser", + "symbol": "GYSR", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GYSR/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xDA9b55DE6e04404F6c77673D4B243142a4efC6B8", + "name": "Geyser", + "symbol": "GYSR", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GYSR/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x197D38DC562DfB2490eC1A1d5C4CC4319d178Bb4", + "name": "Geyser", + "symbol": "GYSR", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/GYSR/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0c90C57aaf95A3A87eadda6ec3974c99D786511F", + "name": "HanChain", + "symbol": "HAN", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/HAN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x50Bce64397C75488465253c0A034b8097FeA6578", + "name": "HanChain", + "symbol": "HAN", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/HAN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x0c90C57aaf95A3A87eadda6ec3974c99D786511F", + "name": "HanChain", + "symbol": "HAN", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/HAN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x9e1028f5f1d5ede59748ffcee5532509976840e0", + "name": "HanChain", + "symbol": "HAN", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/HAN/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xF655C8567E0f213e6C634CD2A68d992152161dC6", + "name": "Impermax", + "symbol": "IBEX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/IBEX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xBB6BBaa0F6D839A00c82B10747aBc3b7E2eEcc82", + "name": "Impermax", + "symbol": "IBEX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/IBEX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x0C4a63D472120d7859E2842b7C2Bafbd8eDe8f44", + "name": "InsureToken", + "symbol": "INSURE", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/INSURE/logo.png", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0xeF26Ca2844b0b470AfC1b0aeF5F65e677dE6CD1f", + "name": "InsureToken", + "symbol": "INSURE", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/INSURE/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xdeFA4e8a7bcBA345F687a2f1456F5Edd9CE97202", + "name": "Kyber Network Crystal v2", + "symbol": "KNC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KNC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xa00E3A3511aAC35cA78530c85007AFCd31753819", + "name": "Kyber Network Crystal v2", + "symbol": "KNC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KNC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x4BC18Ae212F798FD7b0eae94dfCA18c0333157c4", + "name": "Kyber Network Crystal v2", + "symbol": "KNC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KNC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x83251BD7EbB55f9CED617030107cE32ef06F54f8", + "name": "Kyber Network Crystal v2", + "symbol": "KNC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KNC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x3af33bef05c2dcb3c7288b77fe1c8d2aeba4d789", + "name": "Kromatika", + "symbol": "KROM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KROM/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xf98dcd95217e15e05d8638da4c91125e59590b07", + "name": "Kromatika", + "symbol": "KROM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KROM/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x0436F489525c47C1A4877a06bE0BEaba2A2E2e2d", + "name": "Kromatika", + "symbol": "KROM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KROM/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x9e1028F5F1D5eDE59748FFceE5532509976840E0", + "name": "Kromatika", + "symbol": "KROM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/KROM/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xC13DD39606d4C2489ce5D9806d060FeD9a7d063d", + "name": "Land", + "symbol": "LAND", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LAND/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x2E2015aa4ac40B083189A03a75AD229dfB10172c", + "name": "Land", + "symbol": "LAND", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LAND/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x5A98FcBEA516Cf06857215779Fd812CA3beF1B32", + "name": "Lido DAO Token", + "symbol": "LDO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LDO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xFdb794692724153d1488CcdBE0C56c252596735F", + "name": "Lido DAO Token", + "symbol": "LDO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LDO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x56340274fB5a72af1A3C6609061c451De7961Bd4", + "name": "TEST Lido DAO Token", + "symbol": "TESTLDO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LDO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0xE265FC71d45fd791c9ebf3EE0a53FBB220Eb8f75", + "name": "TEST Lido DAO Token", + "symbol": "TESTLDO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LDO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x514910771af9ca656af840dff83e8264ecf986ca", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LINK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x350a791bfc2c21f9ed5d10980dad2e2638ffa7f6", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LINK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xa36085F69e2889c224210F603D836748e7dC0088", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LINK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LINK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x326C977E6efc84E512bB9C30f76E30c160eD06FB", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LINK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0xdc2CC710e42857672E7907CF474a69B63B93089f", + "name": "Chainlink", + "symbol": "LINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LINK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x102e941b77bcaa7e35d368cafe51ef8f79c8d1ef", + "name": "Theranos Coin", + "symbol": "LIZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LIZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x3bB4445D30AC020a84c1b5A8A2C6248ebC9779D0", + "name": "Theranos Coin", + "symbol": "LIZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LIZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x47Aa2a683b88E23c4d76f91Aa4181A59d0E4FBfb", + "name": "Theranos Coin", + "symbol": "LIZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LIZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x3bb4445d30ac020a84c1b5a8a2c6248ebc9779d0", + "name": "Theranos Coin", + "symbol": "LIZ", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LIZ/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x3650B69f86cB593f116e276C30666834336c0647", + "name": "Loopfi", + "symbol": "LPF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LPF/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x0B3e851cf6508A16266BC68A651ea68b31ef673b", + "name": "Loopfi", + "symbol": "LPF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LPF/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xBBbbCA6A901c926F240b89EacB641d8Aec7AEafD", + "name": "LoopringCoin V2", + "symbol": "LRC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LRC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xFEaA9194F9F8c1B65429E31341a103071464907E", + "name": "LoopringCoin V2", + "symbol": "LRC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LRC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x5f98805a4e8be255a32880fdec7f6728c6568ba0", + "name": "LUSD Stablecoin", + "symbol": "LUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LUSD/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xc40f949f8a4e094d1b49a23ea9241d289b7b2819", + "name": "LUSD Stablecoin", + "symbol": "LUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LUSD/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x01ba67aac7f75f647d94220cc98fb30fcc5105bf", + "name": "Lyra", + "symbol": "LYRA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LYRA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x50c5725949A6F0c72E6C4a641F24049A917DB0Cb", + "name": "Lyra", + "symbol": "LYRA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/LYRA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x69af81e73a73b40adf4f3d4223cd9b1ece623074", + "name": "Mask Network", + "symbol": "MASK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MASK/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x3390108E913824B8eaD638444cc52B9aBdF63798", + "name": "Mask Network", + "symbol": "MASK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MASK/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2", + "name": "Maker", + "symbol": "MKR", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MKR/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xab7badef82e9fe11f6f33f87bc9bc2aa27f2fcb5", + "name": "Maker", + "symbol": "MKR", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MKR/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x48B942C65a5991dD64360CdDE442792bD829Af80", + "name": "Mochi", + "symbol": "MOCHI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MOCHI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x7Af72aD5E8793023DC722d617fe3338ac6b5ccE9", + "name": "Mochi", + "symbol": "MOCHI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MOCHI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x1351986732367ff6B51784c6A75f63502dE13a9a", + "name": "Monetum", + "symbol": "MOM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MOM/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x5e70AfFE232e2919792f77EB94e566db0320fa88", + "name": "Monetum", + "symbol": "MOM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MOM/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0xd3D1c79D8a5F8316D07c4A391805E5006c71648C", + "name": "Monetum", + "symbol": "MOM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MOM/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x4621b7A9c75199271F773Ebd9A499dbd165c3191", + "name": "Monetum", + "symbol": "MOM", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/MOM/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x4200000000000000000000000000000000000042", + "name": "Optimism", + "symbol": "OP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/OP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 69, + "address": "0x4200000000000000000000000000000000000042", + "name": "Optimism", + "symbol": "OP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/OP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x32B3b2281717dA83463414af4E8CfB1970E56287", + "name": "OptimismUselessToken-Bridged", + "symbol": "OUTb", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/OUTb/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x3e7eF8f50246f725885102E8238CBba33F276747", + "name": "OptimismUselessToken-Bridged", + "symbol": "OUTb", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/OUTb/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x7ae1d57b58fa6411f32948314badd83583ee0e8c", + "name": "Paper", + "symbol": "PAPER", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PAPER/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x00F932F0FE257456b32dedA4758922E56A4F4b42", + "name": "Paper", + "symbol": "PAPER", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PAPER/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xbC396689893D065F41bc2C6EcbeE5e0085233447", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PERP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x9e1028F5F1D5eDE59748FFceE5532509976840E0", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PERP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x002be8a5961e0f352092d6693133a6944b7846ba", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PERP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x50c5725949A6F0c72E6C4a641F24049A917DB0Cb", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PERP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x29DdacF754877123157e0eeed26770736B304d0C", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PERP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x0994206dfE8De6Ec6920FF4D779B0d950605Fb53", + "name": "Perpetual", + "symbol": "PERP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PERP/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x1FEE5588cb1De19c70B6aD5399152D8C643FAe7b", + "name": "PhunToken", + "symbol": "PHTK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PHTK/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xFa956eB0c4b3E692aD5a6B2f08170aDE55999ACa", + "name": "PhunToken", + "symbol": "PHTK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PHTK/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0cec1a9154ff802e7934fc916ed7ca50bde6844e", + "name": "PoolTogether", + "symbol": "POOL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/POOL/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x395ae52bb17aef68c2888d941736a71dc6d4e125", + "name": "PoolTogether", + "symbol": "POOL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/POOL/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xd0cd466b34a24fcb2f87676278af2005ca8a78c4", + "name": "Popcorn", + "symbol": "POP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/POP/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x6F0fecBC276de8fC69257065fE47C5a03d986394", + "name": "Popcorn", + "symbol": "POP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/POP/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x6399c842dd2be3de30bf99bc7d1bbf6fa3650e70", + "name": "Premia", + "symbol": "PREMIA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PREMIA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x374Ad0f47F4ca39c78E5Cc54f1C9e426FF8f231A", + "name": "Premia", + "symbol": "PREMIA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/PREMIA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x03ab458634910AaD20eF5f1C8ee96F1D6ac54919", + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x7FB688CCf682d58f86D7e38e03f9D22e7705448B", + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x76b06a2f6dF6f0514e7BEC52a9AfB3f603b477CD", + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x743224e4822710a3e40d754244f3e0f1db2e5d8f", + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RAI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xae78736cd615f374d3085123a210448e74fc6393", + "name": "Rocket Pool ETH", + "symbol": "rETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/rETH/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x9bcef72be871e61ed4fbbc7630889bee758eb81d", + "name": "Rocket Pool ETH", + "symbol": "rETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/rETH/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x07FA101efde726E0956Edd2c4D5C8d3d1A5E9c53", + "name": "Respawn Finance Wrapped Staked Ethereum", + "symbol": "RFWSTETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RFWSTETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xeAeAdAC73baaF4cB8B024dE9D65B2eeFa722856C", + "name": "Respawn Finance Wrapped Staked Ethereum", + "symbol": "RFWSTETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RFWSTETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x891C46986708b3914A00883B72564AB76817799A", + "name": "Respawn Finance Wrapped Staked Ethereum", + "symbol": "RFWSTETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RFWSTETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x1696baFBe18EFB141823a041E22E43d12B144407", + "name": "Respawn Finance Wrapped Staked Ethereum", + "symbol": "RFWSTETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RFWSTETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xd291e7a03283640fdc51b121ac401383a46cc623", + "name": "Rari Governance Token", + "symbol": "RGT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RGT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xb548f63d4405466b36c0c0ac3318a22fdcec711a", + "name": "Rari Governance Token", + "symbol": "RGT", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/RGT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x7697b462a7c4ff5f8b55bdbc2f4076c2af9cf51a", + "name": "Sarcophagus", + "symbol": "SARCO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SARCO/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x7c6b91d9be155a6db01f749217d76ff02a7227f2", + "name": "Sarcophagus", + "symbol": "SARCO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SARCO/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x298B9B95708152ff6968aafd889c6586e9169f1D", + "name": "Synthetic Bitcoin", + "symbol": "sBTC", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/sBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xf1Dc500FdE233A4055e25e5BbF516372BC4F6871", + "name": "Saddle DAO", + "symbol": "SDL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SDL/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xAe31207aC34423C41576Ff59BFB4E036150f9cF7", + "name": "Saddle DAO", + "symbol": "SDL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SDL/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x2b7A5a5923ECa5C00c6572Cf3E8e08384F563F93", + "name": "Saddle DAO", + "symbol": "SDL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SDL/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xc96f4F893286137aC17e07Ae7F217fFca5db3AB6", + "name": "Saddle DAO", + "symbol": "SDL", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SDL/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0xE405de8F52ba7559f9df3C368500B6E6ae6Cee49", + "name": "Synthetic Ether", + "symbol": "sETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/sETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0xc5Db22719A06418028A40A9B5E9A7c02959D0d08", + "name": "Synthetic Chainlink", + "symbol": "sLINK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/sLINK/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xc011a73ee8576fb46f5e1c5751ca3b9fe0af2a6f", + "name": "Synthetix", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SNX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x39Ea01a0298C315d149a490E34B59Dbf2EC7e48F" + } + }, + { + "chainId": 10, + "address": "0x8700daec35af8ff88c16bdf0418774cb3d7599b4", + "name": "Synthetix", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SNX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x136b1EC699c62b0606854056f02dC7Bb80482d63" + } + }, + { + "chainId": 42, + "address": "0xc011a73ee8576fb46f5e1c5751ca3b9fe0af2a6f", + "name": "Synthetix", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SNX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0xc00E7C2Bd7B0Fb95DbBF10d2d336399A939099ee" + } + }, + { + "chainId": 69, + "address": "0x0064A673267696049938AA47595dD0B3C2e705A1", + "name": "Synthetix", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SNX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x5b643DFC67f9701929A0b55f23e0Af61df50E75D" + } + }, + { + "chainId": 5, + "address": "0x51f44ca59b867E005e48FA573Cb8df83FC7f7597", + "name": "Synthetix", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SNX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x1427Bc44755d9Aa317535B1feE38922760Aa4e65" + } + }, + { + "chainId": 420, + "address": "0x2E5ED97596a8368EB9E44B1f3F25B2E813845303", + "name": "Synthetix", + "symbol": "SNX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SNX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0xD2b3F0Ea40dB68088415412b0043F37B3088836D" + } + }, + { + "chainId": 1, + "address": "0x42d6622dece394b54999fbd73d108123806f6a18", + "name": "SPANK", + "symbol": "SPANK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SPANK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xcfD1D50ce23C46D3Cf6407487B2F8934e96DC8f9", + "name": "SPANK", + "symbol": "SPANK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SPANK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x2eA8f9B29AC1d70e01AE9D23d0451D2242e8d609", + "name": "SPANK", + "symbol": "SPANK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SPANK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xcfD1D50ce23C46D3Cf6407487B2F8934e96DC8f9", + "name": "SPANK", + "symbol": "SPANK", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SPANK/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0763fdccf1ae541a5961815c0872a8c5bc6de4d7", + "name": "SUKU", + "symbol": "SUKU", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SUKU/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xef6301da234fc7b0545c6e877d3359fe0b9e50a4", + "name": "SUKU", + "symbol": "SUKU", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SUKU/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xd35f5965b4b84382ca27072ff3b6b42e7053e672", + "name": "SUKU", + "symbol": "SUKU", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SUKU/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x871f2f2ff935fd1ed867842ff2a7bfd051a5e527", + "name": "SUKU", + "symbol": "SUKU", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/SUKU/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x8c6f28f2F1A3C87F0f938b96d27520d9751ec8d9", + "name": "Synthetix USD", + "symbol": "sUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/sUSD/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 69, + "address": "0xaA5068dC2B3AADE533d3e52C6eeaadC6a8154c57", + "name": "Synthetix USD", + "symbol": "sUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/sUSD/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 420, + "address": "0xeBaEAAD9236615542844adC5c149F86C36aD1136", + "name": "Synthetix USD", + "symbol": "sUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/sUSD/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x8947da500Eb47F82df21143D0C01A29862a8C3c5", + "name": "Optimistic Thales Token", + "symbol": "THALES", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/THALES/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x217D47011b23BB961eB6D93cA9945B7501a5BB11", + "name": "Optimistic Thales Token", + "symbol": "THALES", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/THALES/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xbb9bc244d798123fde783fcc1c72d3bb8c189413", + "name": "TheDAO", + "symbol": "TheDAO", + "decimals": 16, + "logoURI": "https://ethereum-optimism.github.io/data/TheDAO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xd8f365c2c85648f9b89d9f1bf72c0ae4b1c36cfd", + "name": "TheDAO", + "symbol": "TheDAO", + "decimals": 16, + "logoURI": "https://ethereum-optimism.github.io/data/TheDAO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x8274ea38fe9bea66f8e7c6f3ef742b85d86aeb5d", + "name": "TheDAO", + "symbol": "TheDAO", + "decimals": 16, + "logoURI": "https://ethereum-optimism.github.io/data/TheDAO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x35597dC6f8fDc81d71b311A9E4e2710ef6accb68", + "name": "TheDAO", + "symbol": "TheDAO", + "decimals": 16, + "logoURI": "https://ethereum-optimism.github.io/data/TheDAO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x88df592f8eb5d7bd38bfef7deb0fbc02cf3778a0", + "name": "Tellor", + "symbol": "TRB", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TRB/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xaf8ca653fa2772d58f4368b0a71980e9e3ceb888", + "name": "Tellor", + "symbol": "TRB", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TRB/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x7B8AC044ebce66aCdF14197E8De38C1Cc802dB4A", + "name": "Tellor", + "symbol": "TRB", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TRB/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x5e70affe232e2919792f77eb94e566db0320fa88", + "name": "Tellor", + "symbol": "TRB", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TRB/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0000000000085d4780B73119b644AE5ecd22b376", + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TUSD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xcB59a0A753fDB7491d5F3D794316F1adE197B21E", + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TUSD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x1794230aBe1995fcFe6B14865D4B6928121AB9d9", + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TUSD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xFa956eB0c4b3E692aD5a6B2f08170aDE55999ACa", + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/TUSD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xDd1Ad9A21Ce722C151A836373baBe42c868cE9a4", + "name": "Universal Basic Income", + "symbol": "UBI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UBI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xbb586ed34974b15049a876fd5366a4c2d1203115", + "name": "Universal Basic Income", + "symbol": "UBI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UBI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x1ac5F168C220De2515Af6068c5A153aFe2c76d36", + "name": "Universal Basic Income", + "symbol": "UBI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UBI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xbb586ed34974b15049a876fd5366a4c2d1203115", + "name": "Universal Basic Income", + "symbol": "UBI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UBI/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x04Fa0d235C4abf4BcF4787aF4CF447DE572eF828", + "name": "UMA Voting Token v1", + "symbol": "UMA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UMA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xE7798f023fC62146e8Aa1b36Da45fb70855a77Ea", + "name": "UMA Voting Token v1", + "symbol": "UMA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UMA/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UNI/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x6fd9d7ad17242c41f7131d257212c54a0e816691", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UNI/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UNI/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x5e31B81eaFba4b9371e77F34d6f3DA8091C3F2a0", + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/UNI/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x7F5c764cBc14f9669B88837ca1490cCa17c31607", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x50dC5200082d37d5dd34B4b0691f36e3632fE1A8", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x4e62882864fB8CE54AFfcAf8D899A286762B011B", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x07865c6E87B9F70255377e024ace6630C1Eaa37F", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x7E07E15D2a87A24492740D16f5bdF58c16db0c4E", + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDC/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0C10bF8FcB7Bf5412187A595ab97a3609160b5c6", + "name": "Decentralized USD", + "symbol": "USDD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USDD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x7113370218f31764C1B6353BDF6004d86fF6B9cc", + "name": "Decentralized USD", + "symbol": "USDD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USDD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xae73ddeafc00bc5ad03a96c2b268c3f5325c8d49", + "name": "Decentralized USD", + "symbol": "USDD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USDD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x1f9bd96ddb4bd07d6061f8933e9ba9ede9967550", + "name": "Decentralized USD", + "symbol": "USDD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USDD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x73cb180bf0521828d8849bc8CF2B920918e23032", + "name": "USD+", + "symbol": "USD+", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDplus/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xdac17f958d2ee523a2206206994597c13d831ec7", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x94b008aA00579c1307B0EF2c499aD98a8ce58e58", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0xe0BB0D3DE8c10976511e5030cA403dBf4c25165B", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x7F5c764cBc14f9669B88837ca1490cCa17c31607", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0xC2C527C0CACF457746Bd31B2a698Fe89de2b6d49", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x853eb4bA5D0Ba2B77a0A5329Fd2110d5CE149ECE", + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/USDT/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xa693b19d2931d498c5b318df961919bb4aee87a5", + "name": "UST (Wormhole)", + "symbol": "UST", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/UST/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xBA28feb4b6A6b81e3F26F08b83a19E715C4294fd", + "name": "UST (Wormhole)", + "symbol": "UST", + "decimals": 6, + "logoURI": "https://ethereum-optimism.github.io/data/UST/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0a5e677a6a24b2f1a2bf4f3bffc443231d2fdec8", + "name": "dForce USD", + "symbol": "USX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0xC5b1EC605738eF73a4EFc562274c1c0b6609cF59" + } + }, + { + "chainId": 10, + "address": "0xbfD291DA8A403DAAF7e5E9DC1ec0aCEaCd4848B9", + "name": "dForce USD", + "symbol": "USX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0xc76cbFbAfD41761279E3EDb23Fd831Ccb74D5D67" + } + }, + { + "chainId": 42, + "address": "0xf76ead4da04bbeb97d29f83e2ec3a621d0fb3c6e", + "name": "dForce USD", + "symbol": "USX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x40E862341b2416345F02c41Ac70df08525150dC7" + } + }, + { + "chainId": 69, + "address": "0xab7020476d814c52629ff2e4cebc7a8cdc04f18e", + "name": "dForce USD", + "symbol": "USX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/USX/logo.svg", + "extensions": { + "optimismBridgeAddress": "0xB4d37826b14Cd3CB7257A2A5094507d701fe715f" + } + }, + { + "chainId": 1, + "address": "0x27C4af9A860c4caDc358005F8b48140b2E434A7B", + "name": "Validator", + "symbol": "VALX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/VALX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x0A9AAa1c7542b42233AC7FfdA364E97adE21f160", + "name": "Validator", + "symbol": "VALX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/VALX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x6789D8a7a7871923Fc6430432A602879eCB6520a", + "name": "veKwenta", + "symbol": "veKWENTA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/veKWENTA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x678d8f4Ba8DFE6bad51796351824DcCECeAefF2B", + "name": "veKwenta", + "symbol": "veKWENTA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/veKWENTA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0xf36c9a9E8333663F8CA3608C5582916628E79e3f", + "name": "veKwenta", + "symbol": "veKWENTA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/veKWENTA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x3e52b5f840eafD79394c6359E93Bf3FfdAE89ee4", + "name": "veKwenta", + "symbol": "veKWENTA", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/veKWENTA/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x3c8B650257cFb5f272f799F5e2b4e65093a11a05", + "name": "Velodrome", + "symbol": "VELO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/VELO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x0B6F3c17e1626a7cBfA4302CE4E3c45522d23A83", + "name": "WardenSwap", + "symbol": "WAD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WAD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x703D57164CA270b0B330A87FD159CfEF1490c0a5", + "name": "WardenSwap", + "symbol": "WAD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WAD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x2C7A8122A1b512AdC848024cE72e837001EcB586", + "name": "WardenSwap", + "symbol": "WAD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WAD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0xD1917629B3E6A72E6772Aab5dBe58Eb7FA3C2F33", + "name": "WardenSwap", + "symbol": "WAD", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WAD/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x2260fac5e5542a773aa44fbcfedf7c193bc2c599", + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/WBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x68f180fcCe6836688e9084f035309E29Bf0A2095", + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/WBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 42, + "address": "0x68f180fcCe6836688e9084f035309E29Bf0A2095", + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/WBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x22F24361D548e5FaAfb36d1437839f080363982B" + } + }, + { + "chainId": 69, + "address": "0x2382a8f65b9120E554d1836a504808aC864E169d", + "name": "Wrapped BTC L2", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/WBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0xC04B0d3107736C32e19F1c62b2aF67BE61d63a05", + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/WBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0xe0a592353e81a94Db6E3226fD4A99F881751776a", + "name": "Wrapped BTC L2", + "symbol": "WBTC", + "decimals": 8, + "logoURI": "https://ethereum-optimism.github.io/data/WBTC/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 10, + "address": "0x4200000000000000000000000000000000000006", + "name": "Wrapped Ether", + "symbol": "WETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WETH/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 5, + "address": "0x753BD3E00B9585AC9a94Fdf287f41d8D51e5CF8b", + "name": "WAMP", + "symbol": "WMP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WMP/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x636Af16bf2f682dD3109e60102b8E1A089FedAa8" + } + }, + { + "chainId": 420, + "address": "0x35D48A789904E9b15705977192e5d95e2aF7f1D3", + "name": "WAMP", + "symbol": "WMP", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WMP/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x4691937a7508860F876c9c0a2a617E7d9E945D4B", + "name": "Wootrade Network", + "symbol": "WOO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WOO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0x871f2F2ff935FD1eD867842FF2a7bfD051A5E527", + "name": "Wootrade Network", + "symbol": "WOO", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/WOO/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0x7f39C581F595B53c5cb19bD0b3f8dA6c935E2Ca0", + "name": "Wrapped liquid staked Ether 2.0", + "symbol": "wstETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/wstETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x76943C0D61395d8F2edF9060e1533529cAe05dE6" + } + }, + { + "chainId": 10, + "address": "0x1F32b1c2345538c0c6f582fCB022739c4A194Ebb", + "name": "Wrapped liquid staked Ether 2.0", + "symbol": "wstETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/wstETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x8E01013243a96601a86eb3153F0d9Fa4fbFb6957" + } + }, + { + "chainId": 42, + "address": "0xa88751C0a08623E11ff38c6B70F2BbEe7865C17c", + "name": "Wrapped liquid staked Ether 2.0", + "symbol": "wstETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/wstETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x65321bf24210b81500230dCEce14Faa70a9f50a7" + } + }, + { + "chainId": 69, + "address": "0xF9C842dE4381a70eB265d10CF8D43DceFF5bA935", + "name": "Wrapped liquid staked Ether 2.0", + "symbol": "wstETH", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/wstETH/logo.svg", + "extensions": { + "optimismBridgeAddress": "0x2E34e7d705AfaC3C4665b6feF31Aa394A1c81c92" + } + }, + { + "chainId": 1, + "address": "0xB4272071eCAdd69d933AdcD19cA99fe80664fc08", + "name": "CryptoFranc", + "symbol": "XCHF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/XCHF/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xE4F27b04cC7729901876B44f4EAA5102EC150265", + "name": "CryptoFranc", + "symbol": "XCHF", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/XCHF/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + }, + { + "chainId": 1, + "address": "0xE41d2489571d322189246DaFA5ebDe1F4699F498", + "name": "0x Protocol Token", + "symbol": "ZRX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ZRX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x99C9fc46f92E8a1c0deC1b1747d010903E884bE1" + } + }, + { + "chainId": 10, + "address": "0xD1917629B3E6A72E6772Aab5dBe58Eb7FA3C2F33", + "name": "0x Protocol Token", + "symbol": "ZRX", + "decimals": 18, + "logoURI": "https://ethereum-optimism.github.io/data/ZRX/logo.png", + "extensions": { + "optimismBridgeAddress": "0x4200000000000000000000000000000000000010" + } + } + ], + "version": { + "major": 4, + "minor": 3, + "patch": 5 + } + } \ No newline at end of file diff --git a/src/chains/harmony/harmony.config.ts b/src/chains/harmony/harmony.config.ts new file mode 100644 index 0000000000..73804d8421 --- /dev/null +++ b/src/chains/harmony/harmony.config.ts @@ -0,0 +1,57 @@ +import { TokenListType } from '../../services/base'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +interface NetworkConfig { + name: string; + chainID: number; + nodeURL: string; + tokenListType: TokenListType; + tokenListSource: string; +} + +interface Config { + network: NetworkConfig; + nativeCurrencySymbol: string; + autoGasPrice: boolean; + manualGasPrice: number; + gasPricerefreshTime: number; + gasLimitTransaction: number; +} + +export function getHarmonyConfig( + chainName: string, + networkName: string +): Config { + const network = networkName; + return { + network: { + name: network, + chainID: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.chainID' + ), + nodeURL: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.nodeURL' + ), + tokenListType: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.tokenListType' + ), + tokenListSource: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.tokenListSource' + ), + }, + nativeCurrencySymbol: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.nativeCurrencySymbol' + ), + autoGasPrice: ConfigManagerV2.getInstance().get( + chainName + '.autoGasPrice' + ), + manualGasPrice: ConfigManagerV2.getInstance().get( + chainName + '.manualGasPrice' + ), + gasPricerefreshTime: ConfigManagerV2.getInstance().get( + chainName + '.gasPricerefreshTime' + ), + gasLimitTransaction: ConfigManagerV2.getInstance().get( + chainName + '.gasLimitTransaction' + ), + }; +} diff --git a/src/chains/harmony/harmony.ts b/src/chains/harmony/harmony.ts new file mode 100644 index 0000000000..df331d5dc1 --- /dev/null +++ b/src/chains/harmony/harmony.ts @@ -0,0 +1,169 @@ +import abi from '../../services/ethereum.abi.json'; +import axios, { AxiosRequestConfig } from 'axios'; +import { logger } from '../../services/logger'; +import { Contract, Transaction, Wallet } from 'ethers'; +import { EthereumBase } from '../../services/ethereum-base'; +import { getHarmonyConfig } from './harmony.config'; +import { Provider } from '@ethersproject/abstract-provider'; +import { Ethereumish } from '../../services/common-interfaces'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export class Harmony extends EthereumBase implements Ethereumish { + private static _instances: { [name: string]: Harmony }; + private _gasPrice: number; + private _gasPriceLastUpdated: Date | null; + private _nativeTokenSymbol: string; + private _chain: string; + private _requestCount: number; + private _metricsLogInterval: number; + + private constructor(network: string) { + const config = getHarmonyConfig('harmony', network); + super( + 'harmony', + config.network.chainID, + config.network.nodeURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.nonceDbPath'), + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = network; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + this._gasPrice = config.manualGasPrice; + this._gasPriceLastUpdated = null; + + this.updateGasPrice(); + + this._requestCount = 0; + this._metricsLogInterval = 300000; // 5 minutes + + this.onDebugMessage(this.requestCounter.bind(this)); + setInterval(this.metricLogger.bind(this), this.metricsLogInterval); + } + + public static getInstance(network: string): Harmony { + if (Harmony._instances === undefined) { + Harmony._instances = {}; + } + if (!(network in Harmony._instances)) { + Harmony._instances[network] = new Harmony(network); + } + + return Harmony._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Harmony } { + return Harmony._instances; + } + + public requestCounter(msg: any): void { + if (msg.action === 'request') this._requestCount += 1; + } + + public metricLogger(): void { + logger.info( + this.requestCount + + ' request(s) sent in last ' + + this.metricsLogInterval / 1000 + + ' seconds.' + ); + this._requestCount = 0; // reset + } + + // getters + public get gasPrice(): number { + return this._gasPrice; + } + + public get chain(): string { + return this._chain; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get gasPriceLastDated(): Date | null { + return this._gasPriceLastUpdated; + } + + public get requestCount(): number { + return this._requestCount; + } + + public get metricsLogInterval(): number { + return this._metricsLogInterval; + } + + async updateGasPrice(): Promise { + const harmonyConfig = getHarmonyConfig('harmony', this._chain); + + if (harmonyConfig.autoGasPrice) { + const jsonData = JSON.stringify({ + jsonrpc: '2.0', + id: 1, + method: 'hmyv2_gasPrice', + params: [], + }); + + const config: AxiosRequestConfig = { + method: 'post', + url: harmonyConfig.network.nodeURL, + headers: { + 'Content-Type': 'application/json', + }, + data: jsonData, + }; + + const { data } = await axios(config); + + // divide by 1e9 to convert it to Gwei + this._gasPrice = data['result'] / 1e9; + this._gasPriceLastUpdated = new Date(); + + setTimeout( + this.updateGasPrice.bind(this), + harmonyConfig.gasPricerefreshTime * 1000 + ); + } + } + + getContract(tokenAddress: string, signerOrProvider?: Wallet | Provider) { + return new Contract(tokenAddress, abi.ERC20Abi, signerOrProvider); + } + + getSpender(reqSpender: string): string { + // TODO: add SushiswapConfig and ViperswapConfig and Defira configs (or move `approve` to AMM) + let spender: string; + if (reqSpender === 'sushiswap') { + spender = '0x1b02da8cb0d097eb8d57a175b88c7d8b47997506'; + } else if (reqSpender === 'viperswap') { + spender = '0xf012702a5f0e54015362cbca26a26fc90aa832a3'; + } else if (reqSpender === 'defikingdoms') { + spender = '0x24ad62502d1C652Cc7684081169D04896aC20f30'; + } else if (reqSpender === 'defira') { + spender = '0x3C8BF7e25EbfAaFb863256A4380A8a93490d8065'; + } else { + spender = reqSpender; + } + return spender; + } + + // cancel transaction + async cancelTx(wallet: Wallet, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return this.cancelTxWithGasPrice(wallet, nonce, this._gasPrice * 2); + } + + async close() { + await super.close(); + if (this._chain in Harmony._instances) { + delete Harmony._instances[this._chain]; + } + } +} diff --git a/src/chains/harmony/harmony.validators.ts b/src/chains/harmony/harmony.validators.ts new file mode 100644 index 0000000000..57f42b981d --- /dev/null +++ b/src/chains/harmony/harmony.validators.ts @@ -0,0 +1,107 @@ +import { + isNaturalNumberString, + validateTokenSymbols, + mkValidator, + mkRequestValidator, + RequestValidator, + Validator, + validateToken, + validateAmount, + validateTxHash, +} from '../../services/validators'; + +import { isValidAddress } from '@harmony-js/utils'; + +// invalid parameter errors + +export const invalidAddressError: string = + 'The address param is not a valid Ethereum private key (64 hexidecimal characters).'; + +export const invalidSpenderError: string = + 'The spender param is not a valid Ethereum public key (0x followed by 40 hexidecimal characters).'; + +export const invalidNonceError: string = + 'If nonce is included it must be a non-negative integer.'; + +export const invalidMaxFeePerGasError: string = + 'If maxFeePerGas is included it must be a string of a non-negative integer.'; + +export const invalidMaxPriorityFeePerGasError: string = + 'If maxPriorityFeePerGas is included it must be a string of a non-negative integer.'; + +// given a request, look for a key called address that is an Ethereum private key +export const validateAddress: Validator = mkValidator( + 'address', + invalidAddressError, + (val) => typeof val === 'string' && isValidAddress(val) +); + +// given a request, look for a key called spender that is 'uniswap' or an Ethereum public key +export const validateSpender: Validator = mkValidator( + 'spender', + invalidSpenderError, + (val) => + typeof val === 'string' && + (val === 'sushiswap' || + val === 'viperswap' || + val === 'defikingdoms' || + val === 'defira' || + isValidAddress(val)) +); + +export const validateNonce: Validator = mkValidator( + 'nonce', + invalidNonceError, + (val) => typeof val === 'number' && val >= 0 && Number.isInteger(val), + true +); + +export const validateMaxFeePerGas: Validator = mkValidator( + 'maxFeePerGas', + invalidMaxFeePerGasError, + (val) => typeof val === 'string' && isNaturalNumberString(val), + true +); + +export const validateMaxPriorityFeePerGas: Validator = mkValidator( + 'maxPriorityFeePerGas', + invalidMaxPriorityFeePerGasError, + (val) => typeof val === 'string' && isNaturalNumberString(val), + true +); + +// request types and corresponding validators + +export const validateNonceRequest: RequestValidator = mkRequestValidator([ + validateAddress, +]); + +export const validateAllowancesRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateSpender, + validateTokenSymbols, +]); + +export const validateBalanceRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateTokenSymbols, +]); + +export const validateApproveRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateSpender, + validateToken, + validateAmount, + validateNonce, + validateMaxFeePerGas, + validateMaxPriorityFeePerGas, +]); + +export const validatePollRequest: RequestValidator = mkRequestValidator([ + validateTxHash, +]); + +export const validateCancelRequest: RequestValidator = mkRequestValidator([ + validateNonce, + validateAddress, +]); diff --git a/src/chains/harmony/harmony_tokens_defira.json b/src/chains/harmony/harmony_tokens_defira.json new file mode 100644 index 0000000000..77b1877c1c --- /dev/null +++ b/src/chains/harmony/harmony_tokens_defira.json @@ -0,0 +1,93 @@ +{ + "name": "Defira Token List", + "logoURI": "https://sushi.com/static/media/logo.dec926df.png", + "version": { + "major": 0, + "minor": 1, + "patch": 1 + }, + "keywords": [], + "timestamp": "2022-01-30T00:00:00+00:00", + "tokens": [ + { + "chainId": 1666600000, + "name": "Staked One", + "address": "0x22D62b19b7039333ad773b7185BB61294F3AdC19", + "symbol": "stONE", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x22D62b19b7039333ad773b7185BB61294F3AdC19/logo.png" + }, + { + "chainId": 1666600000, + "name": "Wrapped ONE", + "address": "0xcF664087a5bB0237a0BAd6742852ec6c8d69A27a", + "symbol": "WONE", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/one.jpg" + }, + { + "chainId": 1666600000, + "name": "Dai Stablecoin", + "address": "0xEf977d2f931C1978Db5F6747666fa1eACB0d0339", + "symbol": "1DAI", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/dai.jpg" + }, + { + "chainId": 1666600000, + "name": "Tether USDT", + "address": "0x3C2B8Be99c50593081EAA2A724F0B8285F5aba8f", + "symbol": "1USDT", + "decimals": 6, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/usdt.jpg" + }, + { + "chainId": 1666600000, + "name": "1ETH", + "address": "0x6983D1E6DEf3690C4d616b13597A09e6193EA013", + "symbol": "1ETH", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/eth.jpg" + }, + { + "chainId": 1666600000, + "name": "Wrapped BTC", + "address": "0x3095c7557bCb296ccc6e363DE01b760bA031F2d9", + "symbol": "1WBTC", + "decimals": 18, + "logoURI": "" + }, + { + "chainId": 1666600000, + "address": "0xdc54046c0451f9269FEe1840aeC808D36015697d", + "symbol": "1BTC", + "name": "1BTC", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0xdc54046c0451f9269FEe1840aeC808D36015697d/logo.png" + }, + { + "chainId": 1666600000, + "address": "0xE176EBE47d621b984a73036B9DA5d834411ef734", + "symbol": "BUSD", + "name": "Binance USD", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/busd.jpg" + }, + { + "chainId": 1666600000, + "address": "0x2A719aF848bf365489E548BE5edbEC1D65858e59", + "symbol": "FIRA", + "name": "Fira", + "decimals": 18, + "logoURI": "https://d2w69usg89gc0q.cloudfront.net/tokens/FIRA.png" + }, + { + "chainId": 1666600000, + "address": "0xCf1709Ad76A79d5a60210F23e81cE2460542A836", + "symbol": "TRANQ", + "name": "Tranquil", + "decimals": 18, + "logoURI": "https://d2w69usg89gc0q.cloudfront.net/tokens/TRANQ.png" + } + ] +} diff --git a/src/chains/harmony/harmony_tokens_defira_testnet.json b/src/chains/harmony/harmony_tokens_defira_testnet.json new file mode 100644 index 0000000000..98b2287e63 --- /dev/null +++ b/src/chains/harmony/harmony_tokens_defira_testnet.json @@ -0,0 +1,29 @@ +{ + "name": "Defira Token List", + "logoURI": "https://sushi.com/static/media/logo.dec926df.png", + "version": { + "major": 0, + "minor": 1, + "patch": 1 + }, + "keywords": [], + "timestamp": "2022-01-30T00:00:00+00:00", + "tokens": [ + { + "chainId": 1666700000, + "name": "OneETH", + "address": "0x1E120B3b4aF96e7F394ECAF84375b1C661830013", + "symbol": "1ETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/279/small/ethereum.png" + }, + { + "chainId": 1666700000, + "name": "Wrapped ONE", + "address": "0x7466d7d0C21Fa05F32F5a0Fa27e12bdC06348Ce2", + "symbol": "WONE74", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4344/small/Y88JAze.png" + } + ] +} diff --git a/src/chains/harmony/harmony_tokens_sushiswap.json b/src/chains/harmony/harmony_tokens_sushiswap.json new file mode 100644 index 0000000000..b13cb651be --- /dev/null +++ b/src/chains/harmony/harmony_tokens_sushiswap.json @@ -0,0 +1,1050 @@ +{ + "name": "Sushiswap Token List", + "logoURI": "https://sushi.com/static/media/logo.dec926df.png", + "version": { + "major": 0, + "minor": 1, + "patch": 1 + }, + "keywords": [], + "timestamp": "2022-01-30T00:00:00+00:00", + "tokens": [ + { + "chainId": 1666600000, + "address": "0x6e1bC01Cc52D165B357c42042cF608159A2B81c1", + "symbol": "DFKAMBRTFY", + "name": "Ambertaffy", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/ambertaffy.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x1771dEc8D9A29F30d82443dE0a69e7b6824e2F53", + "symbol": "DFKANTBLND", + "name": "Anti-blinding Potion", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/blindness-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xA1f8b0E88c51a45E152934686270DDF4E3356278", + "symbol": "DFKANTPSN", + "name": "Anti-poison Potion", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/antipoison-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x27dC6AaaD95580EdF25F8B9676f1B984e09e413d", + "symbol": "DFKATONECR", + "name": "Atonement Crystal", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/atonement-crystal-greater.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x78aED65A2Cc40C7D8B0dF1554Da60b38AD351432", + "symbol": "DFKBLOATER", + "name": "Bloater", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/bloater.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x9678518e04Fe02FB30b55e2D0e554E26306d0892", + "symbol": "DFKBLUEEGG", + "name": "Blue Pet Egg", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/pet-egg-blue.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xAC5c49Ff7E813dE1947DC74bbb1720c353079ac9", + "symbol": "DFKBLUESTEM", + "name": "Blue Stem", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/bluestem.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x68EA4640C5ce6cC0c9A1F17B7b882cB1cBEACcd7", + "symbol": "DFKDRKWD", + "name": "Darkweed", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/darkweed.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x87361363A75c9A6303ce813D0B2656c34B68FF52", + "symbol": "DFKFHLTHPTN", + "name": "Full Health", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/health-potion-large.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xDc2C698aF26Ff935cD1c50Eef3a4A933C62AF18D", + "symbol": "DFKFMNPTN", + "name": "Full Mana Potion", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/mana-potion-large.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x17f3B5240C4A71a3BBF379710f6fA66B9b51f224", + "symbol": "DFKGATONECR", + "name": "Greater Atonement Crystal", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/atonement-crystal-greater.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x600541aD6Ce0a8b5dae68f086D46361534D20E80", + "symbol": "DFKGLDVN", + "name": "Goldvein", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/goldvein.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x3a4EDcf3312f44EF027acfd8c21382a5259936e7", + "symbol": "DFKGOLD", + "name": "Gold", + "decimals": 3, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/gold-bag.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x9edb3Da18be4B03857f3d39F83e5C6AAD67bc148", + "symbol": "DFKGOLDEGG", + "name": "Golden Egg", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/pet-egg-golden.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x6d605303e9Ac53C59A3Da1ecE36C9660c7A71da5", + "symbol": "DFKGREENEGG", + "name": "Green Pet Egg", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/pet-egg-green.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x95d02C1Dc58F05A015275eB49E107137D9Ee81Dc", + "symbol": "DFKGREGG", + "name": "Grey Pet Egg", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/pet-egg-grey.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x2789F04d22a845dC854145d3c289240517f2BcF0", + "symbol": "DFKHLTHPTN", + "name": "Health", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/health-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xe4Cfee5bF05CeF3418DA74CFB89727D8E4fEE9FA", + "symbol": "DFKIRONSCALE", + "name": "Ironscale", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/ironscale.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x8Bf4A0888451C6b5412bCaD3D9dA3DCf5c6CA7BE", + "symbol": "DFKLANTERNEYE", + "name": "Lantern-Eye", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/lanterneye.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x1f3F655079b70190cb79cE5bc5AE5F19dAf2A6Cf", + "symbol": "DFKLATONECR", + "name": "Lesser Atonement Crystal", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/atonement-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x7e120334D9AFFc0982719A4eacC045F78BF41C68", + "symbol": "DFKMGCRSPTN", + "name": "Magic Resistance Potion", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/magic-resist-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xc0214b37FCD01511E6283Af5423CF24C96BB9808", + "symbol": "DFKMILKWEED", + "name": "Milk Weed", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/milkweed.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x19b020001AB0C12Ffa93e1FDeF90c7C37C8C71ef", + "symbol": "DFKMNPTN", + "name": "Mana Vial", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/mana-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x6B10Ad6E3b99090De20bF9f95F960addC35eF3E2", + "symbol": "DFKRCKRT", + "name": "Rockroot", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/rockroot.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x094243DfABfBB3E6F71814618ace53f07362a84c", + "symbol": "DFKRDLF", + "name": "Redleaf", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/redleaf.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xc5891912718ccFFcC9732D1942cCD98d5934C2e1", + "symbol": "DFKREDGILL", + "name": "Redgill", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/redgill.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x043F9bd9Bb17dFc90dE3D416422695Dd8fa44486", + "symbol": "DFKRGWD", + "name": "Ragweed", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/ragweed.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xb80A07e13240C31ec6dc0B5D72Af79d461dA3A70", + "symbol": "DFKSAILFISH", + "name": "Sailfish", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/sailfish.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x372CaF681353758f985597A35266f7b330a2A44D", + "symbol": "DFKSHIMMERSKIN", + "name": "ShimmerSkin", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/shimmerskin.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x66F5BfD910cd83d3766c4B39d13730C911b2D286", + "symbol": "DFKSHVAS", + "name": "Shvas Rune", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/shvas-rune.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x2493cfDAcc0f9c07240B5B1C4BE08c62b8eEff69", + "symbol": "DFKSILVERFIN", + "name": "Silverfin", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/silverfin.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x19B9F05cdE7A61ab7aae5b0ed91aA62FF51CF881", + "symbol": "DFKSPIDRFRT", + "name": "Spider Fruit", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/spider-fruit.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x959ba19508827d1ed2333B1b503Bd5ab006C710e", + "symbol": "DFKSTMNPTN", + "name": "Stamina Vial", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/stamina-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xCdfFe898E687E941b124dfB7d24983266492eF1d", + "symbol": "DFKSWFTHSL", + "name": "Swift-Thistle", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/swift-thistle.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x872dD1595544CE22ad1e0174449C7ECE6F0bb01b", + "symbol": "DFKSWFTPTN", + "name": "Swiftness Potion", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/swiftness-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x24eA0D436d3c2602fbfEfBe6a16bBc304C963D04", + "symbol": "DFKTEARS", + "name": "Gaia's Tears", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/gaias-tear.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xFb03c364969a0bB572Ce62b8Cd616A7DDEb4c09A", + "symbol": "DFKTFNSPTN", + "name": "Toughness Potion", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/toughness-potion.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x3dB1fd0Ad479A46216919758144FD15A21C3e93c", + "symbol": "DFKYELLOWEGG", + "name": "Yellow Pet Egg", + "decimals": 0, + "logoURI": "https://dfk-hv.b-cdn.net/art-assets/items/pet-egg-yellow.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x72Cb10C6bfA5624dD07Ef608027E366bd690048F", + "symbol": "JEWEL", + "name": "Jewel", + "decimals": 18, + "logoURI": "https://beta.defikingdoms.com/static/media/jewel-logo.88468185.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x8F655142104478724bbC72664042EA09EBbF7B38", + "symbol": "DFKMOKSHA", + "name": "Moksha Rune", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/moksha-rune.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x45B53E55b5c0A10fdd4fE2079a562d5702F3A033", + "symbol": "DFKCHSCR", + "name": "Chaos Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/chaos-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xa509c34306AdF6168268A213Cc47D336630bf101", + "symbol": "DFKLCHSCR", + "name": "Lesser Chaos Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/chaos-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x3633F956410163A98D58D2D928B38C64A488654e", + "symbol": "DFKCHSST", + "name": "Chaos Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/chaos-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x6D4f4bC32df561a35C05866051CbE9C92759Da29", + "symbol": "DFKLCHSST", + "name": "Lesser Chaos Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/chaos-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xc6A58eFc320A7aFDB1cD662eaf6de10Ee17103F2", + "symbol": "DFKFINCR", + "name": "Finesse Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/finesse-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x39927A2CEE5580d63A163bc402946C7600300373", + "symbol": "DFKLFINCR", + "name": "Lesser Finesse Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/finesse-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xD0B689Cb5DE0c15792Aa456C89D64038C1F2EedC", + "symbol": "DFKFINST", + "name": "Finesse Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/finesse-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xbb5614D466b77d50DdEd994892DFe6F0ACA4eEbb", + "symbol": "DFKLFINST", + "name": "Lesser Finesse Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/finesse-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x603919AEB55EB13F9CDE94274fC54ab2Bd2DecE7", + "symbol": "DFKFRTICR", + "name": "Fortitude Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortitude-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x3017609B9A59B77B708D783835B6fF94a3D9E337", + "symbol": "DFKLFRTICR", + "name": "Lesser Fortitude Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortitude-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x17Fa96ba9d9C29e4B96d29A7e89a4E7B240E3343", + "symbol": "DFKFRTIST", + "name": "Fortitude Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortitude-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x1f57eb682377f5Ad6276b9315412920BdF9530f6", + "symbol": "DFKLFRTIST", + "name": "Lesser Fortitude Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortitude-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x6D777C64f0320d8A5b31BE0FdeB694007Fc3ed45", + "symbol": "DFKFRTUCR", + "name": "Fortune Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortune-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x13AF184aEA970Fe79E3BB7A1B0B156B195fB1f40", + "symbol": "DFKLFRTUCR", + "name": "Lesser Fortune Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortune-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x5da2EffE9857DcEcB786E13566Ff37B92e1E6862", + "symbol": "DFKFRTUST", + "name": "Fortune Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortune-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x6D6eA1D2Dc1Df6Eaa2153f212d25Cf92d13Be628", + "symbol": "DFKLFRTUST", + "name": "Lesser Fortune Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/fortune-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x117E60775584CdfA4f414E22b075F31cC9c3207C", + "symbol": "DFKINSCR", + "name": "Insight Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/insight-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xc63b76f710e9973b8989678eb16234CfADc8D9DB", + "symbol": "DFKLINSCR", + "name": "Lesser Insight Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/insight-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x9D71Bb9C781FC2eBdD3d6cb709438e3c71200149", + "symbol": "DFKINSST", + "name": "Insight Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/insight-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x762b98B3758d0A5Eb95B3E4A1E2914Ce0A80D99c", + "symbol": "DFKLINSST", + "name": "Lesser Insight Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/insight-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xb368f69bE6eDa74700763672AEB2Ae63f3d20AE6", + "symbol": "DFKMGHTCR", + "name": "Might Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/might-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xaB464901AFBc61bAC440a97Fa568aC42885Da58B", + "symbol": "DFKLMGHTCR", + "name": "Lesser Might Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/might-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xE7F6ea1cE7BbEbC9F2Cf080010dd938d2D8D8B1b", + "symbol": "DFKMGHTST", + "name": "Might Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/might-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xe4E7C0c693d8A7FC159776a993495378705464A7", + "symbol": "DFKLMGHTST", + "name": "Lesser Might Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/might-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x5d7f20e3B0f1406Bf038175218eA7e9B4838908c", + "symbol": "DFKSWFTCR", + "name": "Swiftness Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/swiftness-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xf5c26F2F34E9245C3A9ea0B0e7Ea7B33E6404Da0", + "symbol": "DFKLSWFTCR", + "name": "Lesser Swiftness Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/swiftness-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x08f362517aD4119d93bBCd20825c2E4119abB495", + "symbol": "DFKSWFTST", + "name": "Swiftness Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/swiftness-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xd9A8abC0Ce1ADC23F1c1813986c9a9C21C9e7510", + "symbol": "DFKLSWFTST", + "name": "Lesser Swiftness Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/swiftness-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xBbA50bD111DC586Fd1f2B1476B6eC505800A3FD0", + "symbol": "DFKVGRCR", + "name": "Vigor Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/vigor-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x0d8403E47445DB9E316E36F476dacD5827220Bdd", + "symbol": "DFKLVGRCR", + "name": "Lesser Vigor Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/vigor-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x9df75917aC9747B4A70fa033E4b0182d85B62857", + "symbol": "DFKVGRST", + "name": "Vigor Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/vigor-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xB00CbF5Cd5e7b321436C2D3d8078773522D2F073", + "symbol": "DFKLVGRST", + "name": "Lesser Vigor Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/vigor-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x3619fc2386FbBC19DDC39d29A72457e758CFAD69", + "symbol": "DFKWITCR", + "name": "Wit Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/wit-crystal.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x17ff2016c9ecCFBF4Fc4DA6EF95Fe646D2c9104F", + "symbol": "DFKLWITCR", + "name": "Lesser Wit Crystal", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/wit-crystal-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x939Ea05C81aAC48F7C10BdB08615082B82C80c63", + "symbol": "DFKWITST", + "name": "Wit Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/wit-stone.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x4Ff7A020ec1100D36d5C81F3D4815F2e9C704b59", + "symbol": "DFKLWITST", + "name": "Lesser Wit Stone", + "decimals": 0, + "logoURI": "https://defi-kingdoms.b-cdn.net/art-assets/items/wit-stone-lesser.gif", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0xA9cE83507D872C5e1273E745aBcfDa849DAA654F", + "symbol": "xJEWEL", + "name": "xJewels", + "decimals": 18, + "logoURI": "https://beta.defikingdoms.com/static/media/jewel-logo.88468185.png", + "tags": ["harmony"] + }, + { + "chainId": 1666600000, + "address": "0x58f1b044d8308812881a1433d9Bbeff99975e70C", + "symbol": "1INCH", + "name": "1INCH Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/1inch.jpg" + }, + { + "chainId": 1666600000, + "address": "0xcF323Aad9E522B93F11c352CaA519Ad0E14eB40F", + "symbol": "AAVE", + "name": "Aave Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/aave.jpg" + }, + { + "chainId": 1666600000, + "address": "0x14A7B318fED66FfDcc80C1517C172c13852865De", + "symbol": "AXS", + "name": "Axie Infinity Shard", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x14A7B318fED66FfDcc80C1517C172c13852865De/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x3095c7557bCb296ccc6e363DE01b760bA031F2d9", + "symbol": "BTC", + "name": "Bitcoin", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/btc.jpg" + }, + { + "chainId": 1666600000, + "address": "0xE176EBE47d621b984a73036B9DA5d834411ef734", + "symbol": "BUSD", + "name": "Binance USD", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/busd.jpg" + }, + { + "chainId": 1666600000, + "address": "0xEf977d2f931C1978Db5F6747666fa1eACB0d0339", + "symbol": "DAI", + "name": "Dai Stablecoin", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/dai.jpg" + }, + { + "chainId": 1666600000, + "address": "0x6983D1E6DEf3690C4d616b13597A09e6193EA013", + "symbol": "ETH", + "name": "Ether", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/eth.jpg" + }, + { + "chainId": 1666600000, + "address": "0x2F459Dd7CBcC9D8323621f6Fb430Cd0555411E7B", + "symbol": "JENN", + "name": "TokenJenny", + "decimals": 18, + "logoURI": "https://d1xrz6ki9z98vb.cloudfront.net/venomswap/tokens/JENN.png" + }, + { + "chainId": 1666600000, + "address": "0x218532a12a389a4a92fC0C5Fb22901D1c19198aA", + "symbol": "LINK", + "name": "ChainLink Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/link.jpg" + }, + { + "chainId": 1666600000, + "address": "0x7d0546dBb1Dca8108d99Aa389A8e9Ce0C40B2370", + "symbol": "LMA", + "name": "LMA-Art-Gallery", + "decimals": 18, + "logoURI": "https://swoop-exchange.s3-us-west-1.amazonaws.com/tokens/LMA.png" + }, + { + "chainId": 1666600000, + "address": "0x301259f392B551CA8c592C9f676FCD2f9A0A84C5", + "symbol": "MATIC", + "name": "Matic Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/polygon.jpg" + }, + { + "chainId": 1666600000, + "address": "0x7b9c523d59AeFd362247Bd5601A89722e3774dD2", + "symbol": "SNX", + "name": "Synthetix Network Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/snx.jpg" + }, + { + "chainId": 1666600000, + "address": "0xBEC775Cb42AbFa4288dE81F387a9b1A3c4Bc552A", + "symbol": "SUSHI", + "name": "Sushi Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/sushi.jpg" + }, + { + "chainId": 1666600000, + "address": "0x90D81749da8867962c760414C1C25ec926E889b6", + "symbol": "UNI", + "name": "Uniswap", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/uni.jpg" + }, + { + "chainId": 1666600000, + "address": "0x985458E523dB3d53125813eD68c274899e9DfAb4", + "symbol": "USDC", + "name": "USD Coin", + "decimals": 6, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/usdc.jpg" + }, + { + "chainId": 1666600000, + "address": "0x3C2B8Be99c50593081EAA2A724F0B8285F5aba8f", + "symbol": "USDT", + "name": "Tether USD", + "decimals": 6, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/usdt.jpg" + }, + { + "chainId": 1666600000, + "address": "0x224e64ec1BDce3870a6a6c777eDd450454068FEC", + "symbol": "UST", + "name": "TerraUSD", + "decimals": 18, + "logoURI": "https://github.com/sushiswap/icons/blob/master/token/ust.jpg" + }, + { + "chainId": 1666600000, + "address": "0xB8E0497018c991E86311b64EFd9D57b06aEDbBAE", + "symbol": "VINCI", + "name": "DaVinci Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0xB8E0497018c991E86311b64EFd9D57b06aEDbBAE/logo.png" + }, + { + "chainId": 1666600000, + "address": "0xEa589E93Ff18b1a1F1e9BaC7EF3E86Ab62addc79", + "symbol": "VIPER", + "name": "Viper", + "decimals": 18, + "logoURI": "https://dvwecb5klcqus.cloudfront.net/venomswap/logos/venomswap-128x128.png" + }, + { + "chainId": 1666600000, + "address": "0xE7e3C4D1cFc722b45A428736845B6AfF862842a1", + "symbol": "WISE", + "name": "Wise Token", + "decimals": 18, + "logoURI": "https://d1xrz6ki9z98vb.cloudfront.net/venomswap/tokens/1WISE.png" + }, + { + "chainId": 1666600000, + "name": "Wrapped ONE", + "address": "0xcF664087a5bB0237a0BAd6742852ec6c8d69A27a", + "symbol": "WONE", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/one.jpg" + }, + { + "chainId": 1666600000, + "address": "0xa0dc05F84A27FcCBD341305839019aB86576bc07", + "symbol": "YFI", + "name": "yearn.finance", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/yfi.jpg" + }, + { + "chainId": 1666600000, + "address": "0x582617bD8Ca80d22D4432E63Fda52D74dcDCEe4c", + "symbol": "bscADA", + "name": "Cardano Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/ada.jpg" + }, + { + "chainId": 1666600000, + "address": "0x0aB43550A6915F9f67d0c454C2E90385E6497EaA", + "symbol": "bscBUSD", + "name": "BUSD Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/busd.jpg" + }, + { + "chainId": 1666600000, + "address": "0x08CB2917245BBE75C8C9c6Dc4a7B3765Dae02b31", + "symbol": "bscDOT", + "name": "Polkadot Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/icons/master/token/dot.jpg" + }, + { + "chainId": 1666600000, + "address": "0xeB6C08ccB4421b6088e581ce04fcFBed15893aC3", + "symbol": "FRAX", + "name": "Frax", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0xeB6C08ccB4421b6088e581ce04fcFBed15893aC3/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x775d7816afbEf935ea9c21a3aC9972F269A39004", + "symbol": "FXS", + "name": "Frax Share", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x775d7816afbEf935ea9c21a3aC9972F269A39004/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x63cf309500d8be0B9fDB8F1fb66C821236c0438c", + "symbol": "YGG", + "name": "Yield Guild Games Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x63cf309500d8be0B9fDB8F1fb66C821236c0438c/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x95CE547D730519A90dEF30d647F37D9E5359B6Ae", + "symbol": "LUNA", + "name": "Wrapped LUNA Token", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x95CE547D730519A90dEF30d647F37D9E5359B6Ae/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x40d2f81bD135B5282CB2aA18F19cF7098079D012", + "symbol": "IKURA", + "name": "Ikura", + "decimals": 9, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x40d2f81bD135B5282CB2aA18F19cF7098079D012/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x892D81221484F690C0a97d3DD18B9144A3ECDFB7", + "symbol": "MAGIC", + "name": "Magic", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x892D81221484F690C0a97d3DD18B9144A3ECDFB7/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x0159ED2E06DDCD46a25E74eb8e159Ce666B28687", + "symbol": "FOX", + "name": "FarmersOnly Token2", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x0159ED2E06DDCD46a25E74eb8e159Ce666B28687/logo.png" + }, + { + "chainId": 1666600000, + "address": "0xCf1709Ad76A79d5a60210F23e81cE2460542A836", + "symbol": "TRANQ", + "name": "Tranquil", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0xCf1709Ad76A79d5a60210F23e81cE2460542A836/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x1b2bc2683F85bFb9c4C90e8322d62A20B97cF87D", + "symbol": "MM", + "name": "Million", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x1b2bc2683F85bFb9c4C90e8322d62A20B97cF87D/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x6aB6d61428fde76768D7b45D8BFeec19c6eF91A8", + "symbol": "BIFI", + "name": "Beefy Finance", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x6aB6d61428fde76768D7b45D8BFeec19c6eF91A8/logo.png" + }, + { + "chainId": 1666600000, + "address": "0xdc54046c0451f9269FEe1840aeC808D36015697d", + "symbol": "1BTC", + "name": "1BTC", + "decimals": 8, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0xdc54046c0451f9269FEe1840aeC808D36015697d/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x947394294F75D7502977AC6813FD99f77C2931ec", + "symbol": "ODAO", + "name": "ODAO", + "decimals": 9, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x947394294F75D7502977AC6813FD99f77C2931ec/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x01A4b054110d57069c1658AFBC46730529A3E326", + "symbol": "OpenX", + "name": "OpenSwap", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x01A4b054110d57069c1658AFBC46730529A3E326/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x0D625029E21540aBdfAFa3BFC6FD44fB4e0A66d0", + "name": "ColonyToken", + "symbol": "CLNY", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x0D625029E21540aBdfAFa3BFC6FD44fB4e0A66d0/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x10010078a54396F62c96dF8532dc2B4847d47ED3", + "name": "Hundred Finance", + "symbol": "HND", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x10010078a54396F62c96dF8532dc2B4847d47ED3/logo.png" + }, + { + "chainId": 1666600000, + "address": "0xBbD83eF0c9D347C85e60F1b5D2c58796dBE1bA0d", + "name": "Cheese", + "symbol": "CHEEZ", + "decimals": 9, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0xBbD83eF0c9D347C85e60F1b5D2c58796dBE1bA0d/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x22D62b19b7039333ad773b7185BB61294F3AdC19", + "name": "Staked One", + "symbol": "stONE", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/sushiswap/assets/master/blockchains/harmony/assets/0x22D62b19b7039333ad773b7185BB61294F3AdC19/logo.png" + }, + { + "chainId": 1666600000, + "address": "0x2A719aF848bf365489E548BE5edbEC1D65858e59", + "symbol": "FIRA", + "name": "Fira", + "decimals": 18, + "logoURI": "https://d2w69usg89gc0q.cloudfront.net/tokens/FIRA.png" + } + ] +} diff --git a/src/chains/harmony/harmony_tokens_sushiswap_testnet.json b/src/chains/harmony/harmony_tokens_sushiswap_testnet.json new file mode 100644 index 0000000000..e9658bd80e --- /dev/null +++ b/src/chains/harmony/harmony_tokens_sushiswap_testnet.json @@ -0,0 +1,70 @@ +{ + "name": "Sushiswap Testnet Token List", + "logoURI": "https://sushi.com/static/media/logo.dec926df.png", + "version": { + "major": 0, + "minor": 1, + "patch": 1 + }, + "keywords": [], + "timestamp": "2022-01-30T00:00:00+00:00", + "tokens": [ + { + "chainId": 1666700000, + "address": "0x63882d0438AdA0dD76ed2E6B7C2D53A55284A557", + "symbol": "JEWEL", + "name": "Jewel", + "decimals": 18, + "logoURI": "https://beta.defikingdoms.com/static/media/jewel-logo.88468185.png", + "tags": ["harmony testnet"] + }, + { + "name": "Wrapped ONE", + "address": "0x7466d7d0C21Fa05F32F5a0Fa27e12bdC06348Ce2", + "symbol": "WONE74", + "decimals": 18, + "chainId": 1666700000, + "logoURI": "https://assets.coingecko.com/coins/images/4344/small/Y88JAze.png" + }, + { + "chainId": 1666700000, + "address": "0x0E80905676226159cC3FF62B1876C907C91F7395", + "symbol": "1BUSD", + "name": "OneBUSD", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/9576/small/BUSD.png" + }, + { + "chainId": 1666700000, + "address": "0x1E120B3b4aF96e7F394ECAF84375b1C661830013", + "symbol": "1ETH", + "name": "OneETH", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/279/small/ethereum.png" + }, + { + "chainId": 1666700000, + "address": "0x2C6e26B2faD89bc52d043e78E3D980A08af0Ce88", + "symbol": "1LINK", + "name": "OneChainlink", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/877/small/chainlink-new-logo.png" + }, + { + "chainId": 1666700000, + "address": "0x6c4387C4f570Aa8cAdcaFFc5E73ecb3D0F8Fc593", + "symbol": "WBTC", + "name": "Wrapped BTC", + "decimals": 8, + "logoURI": "https://assets.coingecko.com/coins/images/7598/small/wrapped_bitcoin_wbtc.png" + }, + { + "chainId": 1666700000, + "address": "0x7466d7d0C21Fa05F32F5a0Fa27e12bdC06348Ce2", + "symbol": "WONE", + "name": "Wrapped ONE", + "decimals": 18, + "logoURI": "https://assets.coingecko.com/coins/images/4344/small/Y88JAze.png" + } + ] +} diff --git a/src/chains/near/near.abi.json b/src/chains/near/near.abi.json new file mode 100644 index 0000000000..cd80cdce83 --- /dev/null +++ b/src/chains/near/near.abi.json @@ -0,0 +1,4 @@ +{ + "changeMethods": [], + "viewMethods": ["ft_balance_of"] +} diff --git a/src/chains/near/near.base.ts b/src/chains/near/near.base.ts new file mode 100644 index 0000000000..ae17d5df57 --- /dev/null +++ b/src/chains/near/near.base.ts @@ -0,0 +1,344 @@ +import { + Contract, + providers, + connect, + keyStores, + KeyPair, + Near, + transactions, +} from 'near-api-js'; +import { createCipheriv, createDecipheriv, randomBytes } from 'crypto'; +import axios from 'axios'; +import { promises as fs } from 'fs'; +import { TokenListType, TokenValue, walletPath } from '../../services/base'; +import NodeCache from 'node-cache'; +import { EvmTxStorage } from '../../services/evm.tx-storage'; +import fse from 'fs-extra'; +import { ConfigManagerCertPassphrase } from '../../services/config-manager-cert-passphrase'; +import { logger } from '../../services/logger'; +import { ReferenceCountingCloseable } from '../../services/refcounting-closeable'; +import path from 'path'; +import { rootPath } from '../../paths'; +import { Account } from 'near-api-js/lib/account'; +import { BigNumber } from 'ethers'; +import { NodeStatusResult, GasPrice } from 'near-api-js/lib/providers/provider'; +import BN from 'bn.js'; +import { baseDecode } from 'borsh'; + +// information about an Near token +export interface TokenInfo { + chainId: number; + address: string; + name: string; + symbol: string; + decimals: number; +} + +export type NewDebugMsgHandler = (msg: any) => void; + +export class NearBase { + private _provider: providers.JsonRpcProvider; + protected tokenList: any; + private _tokenMap: Record = {}; + // there are async values set in the constructor + private _ready: boolean = false; + private _initializing: boolean = false; + private _initPromise: Promise = Promise.resolve(); + private _keyStore: keyStores.InMemoryKeyStore; + private _connection: Near | undefined; + + public chainName; + public network; + public gasPriceConstant; + private _gasLimitTransaction; + public tokenListSource: string; + public tokenListType: TokenListType; + public cache: NodeCache; + public rpcUrl: string; + private readonly _refCountingHandle: string; + private readonly _txStorage: EvmTxStorage; + + constructor( + chainName: string, + rpcUrl: string, + network: string, + tokenListSource: string, + tokenListType: TokenListType, + gasPriceConstant: number, + gasLimitTransaction: number, + transactionDbPath: string + ) { + this._provider = new providers.JsonRpcProvider({ url: rpcUrl }); + this.rpcUrl = rpcUrl; + this.chainName = chainName; + this.network = network; + this.gasPriceConstant = gasPriceConstant; + this.tokenListSource = tokenListSource; + this.tokenListType = tokenListType; + + this._refCountingHandle = ReferenceCountingCloseable.createHandle(); + this.cache = new NodeCache({ stdTTL: 3600 }); // set default cache ttl to 1hr + this._gasLimitTransaction = gasLimitTransaction; + this._txStorage = EvmTxStorage.getInstance( + this.resolveDBPath(transactionDbPath), + this._refCountingHandle + ); + this._txStorage.declareOwnership(this._refCountingHandle); + this._keyStore = new keyStores.InMemoryKeyStore(); + } + + ready(): boolean { + return this._ready; + } + + public get provider() { + return this._provider; + } + + public get gasLimitTransaction() { + return this._gasLimitTransaction; + } + + public resolveDBPath(oldPath: string): string { + if (oldPath.charAt(0) === '/') return oldPath; + const dbDir: string = path.join(rootPath(), 'db/'); + fse.mkdirSync(dbDir, { recursive: true }); + return path.join(dbDir, oldPath); + } + + async init(): Promise { + if (!this.ready() && !this._initializing) { + this._initializing = true; + this._connection = await this.connectProvider(); + this._initPromise = this.loadTokens( + this.tokenListSource, + this.tokenListType + ).then(() => { + this._ready = true; + this._initializing = false; + }); + } + return this._initPromise; + } + + async connectProvider(): Promise { + return await connect({ + networkId: this.network, + keyStore: this._keyStore, + nodeUrl: this.rpcUrl, + }); + } + + async loadTokens( + tokenListSource: string, + tokenListType: TokenListType + ): Promise { + const tokenList = await this.getTokenList(tokenListSource, tokenListType); + if (tokenList) { + for (const [key, value] of Object.entries(tokenList)) { + this._tokenMap[value.symbol] = { + ...value, + address: key, + }; + } + } + this.tokenList = Object.values(this._tokenMap); + } + + // returns a Tokens for a given list source and list type + async getTokenList( + tokenListSource: string, + tokenListType: TokenListType + ): Promise { + let data; + if (tokenListType === 'URL') { + ({ data } = await axios.get(tokenListSource)); + } else { + ({ data } = JSON.parse(await fs.readFile(tokenListSource, 'utf8'))); + } + return data; + } + + public get txStorage(): EvmTxStorage { + return this._txStorage; + } + + public get storedTokenList(): TokenInfo[] { + return this.tokenList; + } + + // return the Token object for a symbol + getTokenForSymbol(symbol: string): TokenInfo | null { + return this._tokenMap[symbol] ? this._tokenMap[symbol] : null; + } + + async getWalletFromPrivateKey( + privateKey: string, + accountId: string + ): Promise { + if (!this._connection) { + await this.init(); + } + // creates a public / private key pair using the provided private key + const keyPair = KeyPair.fromString(privateKey); + + const accounts = await this._keyStore.getAccounts(this.network); + if (!accounts.includes(accountId)) { + // adds the keyPair you created to keyStore + await this._keyStore.setKey(this.network, accountId, keyPair); + } + return await this._connection?.account(accountId); + } + + async getWallet(address: string): Promise { + const path = `${walletPath}/${this.chainName}`; + + const encryptedPrivateKey: string = await fse.readFile( + `${path}/${address}.json`, + 'utf8' + ); + + const passphrase = ConfigManagerCertPassphrase.readPassphrase(); + if (!passphrase) { + throw new Error('missing passphrase'); + } + const privateKey = this.decrypt(encryptedPrivateKey, passphrase); + return await this.getWalletFromPrivateKey(privateKey, address); + } + + encrypt(privateKey: string, password: string): string { + const iv = randomBytes(16); + const key = Buffer.alloc(32); + key.write(password); + + const cipher = createCipheriv('aes-256-cbc', key, iv); + + const encrypted = Buffer.concat([ + cipher.update(privateKey), + cipher.final(), + ]); + + return `${iv.toString('hex')}:${encrypted.toString('hex')}`; + } + + decrypt(encryptedPrivateKey: string, password: string): string { + const [iv, encryptedKey] = encryptedPrivateKey.split(':'); + const key = Buffer.alloc(32); + key.write(password); + + const decipher = createDecipheriv( + 'aes-256-cbc', + key, + Buffer.from(iv, 'hex') + ); + + const decrpyted = Buffer.concat([ + decipher.update(Buffer.from(encryptedKey, 'hex')), + decipher.final(), + ]); + + return decrpyted.toString(); + } + + // returns the Native balance, convert BigNumber to string + async getNativeBalance(account: Account): Promise { + return (await account.getAccountBalance()).available; + } + + // returns the balance for an fungible token + async getFungibleTokenBalance(contract: Contract | any): Promise { + logger.info( + 'Requesting balance for owner ' + contract.account.accountId + '.' + ); + let balance: string; + try { + balance = await contract.ft_balance_of({ + account_id: contract.account.accountId, + }); + } catch (_e) { + balance = '0'; + } + logger.info( + `Raw balance of ${contract.contractId} for ` + + `${contract.account.accountId}: ${balance}` + ); + return balance; + } + + // returns the allowance for an FT (Fungible Token) token + async getFungibleTokenAllowance( + _contract: Contract, + _wallet: keyStores.InMemoryKeyStore, + _spender: string, + _decimals: number + ): Promise { + return { value: BigNumber.from('0'), decimals: 0 }; + } + + async getTransaction( + txHash: string, + accountId: string + ): Promise { + return await this._provider.txStatus(txHash, accountId); + } + + // adds allowance by spender to transfer the given amount of Token + async approveFungibleToken( + _contract: Contract, + _wallet: keyStores.InMemoryKeyStore, + _spender: string, + _amount: BigNumber + ): Promise { + return; + } + + public getTokenBySymbol(tokenSymbol: string): TokenInfo | undefined { + return this._tokenMap[tokenSymbol]; + } + + // returns the current block number + async getCurrentBlockNumber(): Promise { + const status: NodeStatusResult = await this._provider.status(); + return status.sync_info.latest_block_height; + } + + // cancel transaction + async cancelTx(account: Account, nonce: number): Promise { + const block = await account.connection.provider.block({ + finality: 'final', + }); + const blockHash = block.header.hash; + + const [txHash, signedTx] = await transactions.signTransaction( + account.accountId, + nonce, + [transactions.transfer(new BN(0))], + baseDecode(blockHash), + account.connection.signer, + account.accountId, + account.connection.networkId + ); + await account.connection.provider.sendTransaction(signedTx); + + return txHash.toString(); + } + + /** + * Get the gas fee. + */ + async getGasPrice(): Promise { + if (!this.ready) { + await this.init(); + } + const feeData: GasPrice = await this._provider.gasPrice(null); + if (feeData.gas_price !== null) { + return feeData.gas_price; + } else { + return null; + } + } + + async close() { + await this._txStorage.close(this._refCountingHandle); + } +} diff --git a/src/chains/near/near.config.ts b/src/chains/near/near.config.ts new file mode 100644 index 0000000000..abc63e373c --- /dev/null +++ b/src/chains/near/near.config.ts @@ -0,0 +1,47 @@ +import { TokenListType } from '../../services/base'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export interface NetworkConfig { + name: string; + nodeURL: string; + tokenListType: TokenListType; + tokenListSource: string; + gasPriceRefreshInterval: number | undefined; +} + +export interface Config { + network: NetworkConfig; + nativeCurrencySymbol: string; + manualGasPrice: number; + gasLimitTransaction: number; +} + +export function getNearConfig(chainName: string, networkName: string): Config { + const network = networkName; + return { + network: { + name: network, + nodeURL: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.nodeURL' + ), + tokenListType: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.tokenListType' + ), + tokenListSource: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.tokenListSource' + ), + gasPriceRefreshInterval: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.gasPriceRefreshInterval' + ), + }, + nativeCurrencySymbol: ConfigManagerV2.getInstance().get( + chainName + '.networks.' + network + '.nativeCurrencySymbol' + ), + manualGasPrice: ConfigManagerV2.getInstance().get( + chainName + '.manualGasPrice' + ), + gasLimitTransaction: ConfigManagerV2.getInstance().get( + chainName + '.gasLimitTransaction' + ), + }; +} diff --git a/src/chains/near/near.controllers.ts b/src/chains/near/near.controllers.ts new file mode 100644 index 0000000000..7244a4ee25 --- /dev/null +++ b/src/chains/near/near.controllers.ts @@ -0,0 +1,169 @@ +import { Account, providers, utils } from 'near-api-js'; +import { BigNumber, utils as ethersUtils } from 'ethers'; +import { latency } from '../../services/base'; +import { + HttpException, + OUT_OF_GAS_ERROR_CODE, + OUT_OF_GAS_ERROR_MESSAGE, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { TokenInfo } from './near.base'; + +import { + CancelRequest, + CancelResponse, + PollResponse, + BalanceRequest, + BalanceResponse, +} from './near.requests'; +import { logger } from '../../services/logger'; +import { Nearish } from '../../services/common-interfaces'; + +export const getTokenSymbolsToTokens = ( + near: Nearish, + tokenSymbols: Array +): Record => { + const tokens: Record = {}; + + for (let i = 0; i < tokenSymbols.length; i++) { + const symbol = tokenSymbols[i]; + const token = near.getTokenBySymbol(symbol); + if (token) tokens[symbol] = token; + } + + return tokens; +}; + +export async function balances( + nearish: Nearish, + req: BalanceRequest +): Promise { + const initTime = Date.now(); + + let account: Account; + try { + account = await nearish.getWallet(req.address); + } catch (err) { + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + const tokens = getTokenSymbolsToTokens(nearish, req.tokenSymbols); + const balances: Record = {}; + if (req.tokenSymbols.includes(nearish.nativeTokenSymbol)) { + balances[nearish.nativeTokenSymbol] = utils.format.formatNearAmount( + await nearish.getNativeBalance(account) + ); + } + await Promise.all( + Object.keys(tokens).map(async (symbol) => { + if ( + tokens[symbol] !== undefined && + symbol !== nearish.nativeTokenSymbol + ) { + const address = tokens[symbol].address; + const decimals = tokens[symbol].decimals; + // instantiate a contract and pass in provider for read-only access + const contract = nearish.getContract(address, account); + const balance: string = await nearish.getFungibleTokenBalance(contract); + balances[symbol] = ethersUtils + .formatUnits(BigNumber.from(balance), decimals) + .toString(); + } + }) + ); + + if (!Object.keys(balances).length) { + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + } + + return { + network: nearish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + balances: balances, + }; +} + +// txStatus +// -1: not in the mempool or failed +// 1: succeeded +export async function poll( + nearish: Nearish, + address: string, + txHash: string +): Promise { + const initTime = Date.now(); + const currentBlock = await nearish.getCurrentBlockNumber(); + const txReceipt: providers.FinalExecutionOutcome = + await nearish.getTransaction(txHash, address); + let txStatus = -1; + if ( + typeof txReceipt.status === 'object' && + 'SuccessValue' in txReceipt.status + ) { + txStatus = 1; + } + + if ( + txReceipt.transaction_outcome.outcome.gas_burnt / + nearish.gasLimitTransaction > + 0.9 + ) { + throw new HttpException( + 503, + OUT_OF_GAS_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_CODE + ); + } + + logger.info(`Poll ${nearish.chain}, txHash ${txHash}, status ${txStatus}.`); + return { + network: nearish.chain, + currentBlock, + timestamp: initTime, + txHash: txHash, + txStatus, + txReceipt, + }; +} + +export async function cancel( + nearish: Nearish, + req: CancelRequest +): Promise { + const initTime = Date.now(); + let account: Account; + try { + account = await nearish.getWallet(req.address); + } catch (err) { + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + + // call cancelTx function + const cancelTx = await nearish.cancelTx(account, req.nonce); + + logger.info( + `Cancelled transaction at nonce ${req.nonce}, cancel txHash ${cancelTx}.` + ); + + return { + network: nearish.chain, + timestamp: initTime, + latency: latency(initTime, Date.now()), + txHash: cancelTx, + }; +} diff --git a/src/chains/near/near.requests.ts b/src/chains/near/near.requests.ts new file mode 100644 index 0000000000..4bbdb8eeaa --- /dev/null +++ b/src/chains/near/near.requests.ts @@ -0,0 +1,54 @@ +import { providers } from 'near-api-js'; +import { NetworkSelectionRequest } from '../../services/common-interfaces'; + +export interface NonceRequest extends NetworkSelectionRequest { + address: string; // the user's Near account Id +} + +export interface NonceResponse { + nonce: number; // the user's nonce +} + +export interface NearBalanceRequest extends NetworkSelectionRequest { + address: string; // the user's Near account Id + tokenSymbols: string[]; // a list of token symbol +} + +export interface BalanceRequest extends NetworkSelectionRequest { + address: string; // the users Account Id + tokenSymbols: string[]; // a list of token symbol +} + +export interface BalanceResponse { + network: string; + timestamp: number; + latency: number; + balances: Record; // the balance should be a string encoded number +} + +export interface PollRequest { + network: string; // the target network of the chain (e.g. mainnet) + txHash: string; + address: string; +} + +export interface PollResponse { + network: string; + timestamp: number; + currentBlock: number; + txHash: string; + txStatus: number; + txReceipt: providers.FinalExecutionOutcome | null; +} + +export interface CancelRequest extends NetworkSelectionRequest { + nonce: number; // the nonce of the transaction to be canceled + address: string; // the user's Near account Id +} + +export interface CancelResponse { + network: string; + timestamp: number; + latency: number; + txHash: string | undefined; +} diff --git a/src/chains/near/near.routes.ts b/src/chains/near/near.routes.ts new file mode 100644 index 0000000000..6480defa88 --- /dev/null +++ b/src/chains/near/near.routes.ts @@ -0,0 +1,81 @@ +/* eslint-disable @typescript-eslint/ban-types */ +import { Router, Request, Response, NextFunction } from 'express'; +import { Nearish } from '../../services/common-interfaces'; +import { asyncHandler } from '../../services/error-handler'; + +import { getChain } from '../../services/connection-manager'; +import { BalanceResponse, PollRequest, PollResponse } from './near.requests'; +import { validateBalanceRequest } from './near.validators'; +import * as nearControllers from './near.controllers'; +import { getTokens } from '../../network/network.controllers'; +import { + validatePollRequest, + validateTokensRequest, +} from '../../network/network.routes'; +import { + BalanceRequest, + TokensRequest, + TokensResponse, +} from '../../network/network.requests'; + +export namespace NearRoutes { + export const router = Router(); + + router.post( + '/balances', + asyncHandler( + async ( + req: Request<{}, {}, BalanceRequest>, + res: Response, + _next: NextFunction + ) => { + validateBalanceRequest(req.body); + + const chain = await getChain('near', req.body.network); + + res + .status(200) + .json( + (await nearControllers.balances(chain, req.body)) as BalanceResponse + ); + } + ) + ); + + router.post( + '/poll', + asyncHandler( + async ( + req: Request<{}, {}, PollRequest>, + res: Response + ) => { + validatePollRequest(req.body); + + const chain = await getChain('near', req.body.network); + + res + .status(200) + .json( + await nearControllers.poll( + chain, + req.body.address, + req.body.txHash + ) + ); + } + ) + ); + + router.get( + '/tokens', + asyncHandler( + async ( + req: Request<{}, {}, {}, TokensRequest>, + res: Response + ) => { + validateTokensRequest(req.query); + res.status(200).json(await getTokens(req.query)); + } + ) + ); +} diff --git a/src/chains/near/near.ts b/src/chains/near/near.ts new file mode 100644 index 0000000000..bcb298492a --- /dev/null +++ b/src/chains/near/near.ts @@ -0,0 +1,102 @@ +import { Account, Contract } from 'near-api-js'; +import abi from './near.abi.json'; +import { logger } from '../../services/logger'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { NearBase } from './near.base'; +import { ContractMethods } from 'near-api-js/lib/contract'; +import { getNearConfig } from './near.config'; + +export class Near extends NearBase { + private static _instances: { [name: string]: Near }; + private _gasPrice: number; + private _gasPriceRefreshInterval: number | null; + private _nativeTokenSymbol: string; + private _chain: string; + + private constructor(network: string) { + const config = getNearConfig('near', network); + super( + 'near', + config.network.nodeURL, + network, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = config.network.name; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + this._gasPrice = config.manualGasPrice; + this._gasPriceRefreshInterval = + config.network.gasPriceRefreshInterval !== undefined + ? config.network.gasPriceRefreshInterval + : null; + + this.updateGasPrice(); + } + + public static getInstance(network: string): Near { + if (Near._instances === undefined) { + Near._instances = {}; + } + if (!(network in Near._instances)) { + Near._instances[network] = new Near(network); + } + + return Near._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Near } { + return Near._instances; + } + + public get gasPrice(): number { + return this._gasPrice; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get chain(): string { + return this._chain; + } + + getContract(tokenAddress: string, account: Account) { + return new Contract(account, tokenAddress, abi); + } + + getSpender(reqSpender: string): string { + return reqSpender; + } + + /** + * Automatically update the prevailing gas price on the network. + */ + async updateGasPrice(): Promise { + if (this._gasPriceRefreshInterval === null) { + return; + } + + const gasPrice = await this.getGasPrice(); + if (gasPrice !== null) { + this._gasPrice = Number(gasPrice); + } else { + logger.info('gasPrice is unexpectedly null.'); + } + + setTimeout( + this.updateGasPrice.bind(this), + this._gasPriceRefreshInterval * 1000 + ); + } + + // cancel transaction + async cancelTx(account: Account, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return super.cancelTx(account, nonce); + } +} diff --git a/src/chains/near/near.validators.ts b/src/chains/near/near.validators.ts new file mode 100644 index 0000000000..2eedb4321f --- /dev/null +++ b/src/chains/near/near.validators.ts @@ -0,0 +1,64 @@ +import { + validateTokenSymbols, + mkValidator, + mkRequestValidator, + RequestValidator, + Validator, +} from '../../services/validators'; + +// invalid parameter errors + +export const invalidAddressError: string = + 'The address param is not a valid Near private key.'; + +export const invalidSpenderError: string = + 'The spender param is not a valid Near address.'; + +export const invalidNonceError: string = + 'If nonce is included it must be a non-negative integer.'; + +export const invalidChainError: string = 'The chain param is not a string.'; + +export const invalidNetworkError: string = 'The network param is not a string.'; + +// given a request, look for a key called address that is an Ethereum wallet +export const validateAddress: Validator = mkValidator( + 'address', + invalidAddressError, + (val) => typeof val === 'string' +); + +// given a request, look for a key called spender that has a string value +export const validateSpender: Validator = mkValidator( + 'spender', + invalidSpenderError, + (val) => typeof val === 'string' +); + +export const validateNonce: Validator = mkValidator( + 'nonce', + invalidNonceError, + (val) => + typeof val === 'undefined' || + (typeof val === 'number' && val >= 0 && Number.isInteger(val)), + true +); + +export const validateChain: Validator = mkValidator( + 'chain', + invalidChainError, + (val) => typeof val === 'string' +); + +export const validateNetwork: Validator = mkValidator( + 'network', + invalidNetworkError, + (val) => typeof val === 'string' +); + +// request types and corresponding validators + +export const validateBalanceRequest: RequestValidator = mkRequestValidator([ + validateAddress, + validateTokenSymbols, +]); diff --git a/src/chains/near/near_testnet_tokens.json b/src/chains/near/near_testnet_tokens.json new file mode 100644 index 0000000000..d9e94a47d8 --- /dev/null +++ b/src/chains/near/near_testnet_tokens.json @@ -0,0 +1,1494 @@ +{ + "aurora.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Aurora", + "symbol": "AURORA", + "icon": "data:image/svg+xml,%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 288 288' style='enable-background:new 0 0 288 288;' xml:space='preserve'%3E %3Cstyle type='text/css'%3E .st0%7Bfill:%2370D44B;%7D .st1%7Bfill:%23FFFFFF;%7D %3C/style%3E %3Cpath class='st0' d='M144,0L144,0c79.5,0,144,64.5,144,144v0c0,79.5-64.5,144-144,144h0C64.5,288,0,223.5,0,144v0 C0,64.5,64.5,0,144,0z'/%3E %3Cpath class='st1' d='M144,58.8c7.6,0,14.5,4.3,17.9,11.1l56.2,112.5c4.9,9.9,0.9,21.9-9,26.8c-2.8,1.4-5.8,2.1-8.9,2.1H87.8 c-11,0-20-9-20-20c0-3.1,0.7-6.2,2.1-8.9l56.2-112.5C129.5,63,136.4,58.7,144,58.8 M144,45c-12.8,0-24.5,7.2-30.2,18.7L57.6,176.2 c-8.3,16.7-1.6,36.9,15.1,45.3c4.7,2.3,9.9,3.6,15.1,3.6h112.5c18.6,0,33.8-15.1,33.8-33.7c0-5.2-1.2-10.4-3.6-15.1L174.2,63.7 C168.5,52.2,156.8,45,144,45z'/%3E %3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "lana.nearlyfinished.testnet": { + "spec": "ft-1.0.0", + "name": "Lana Test Token", + "symbol": "LTEST", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1652538142137-68539457665982": { + "spec": "ft-1.0.0", + "name": "Eternal Lands Gold Token", + "symbol": "elGOLD", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "willa.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Willa Token", + "symbol": "WLT", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "maskedkids.testnet": { + "spec": "ft-1.0.0", + "name": "MASKED KIDS NFT", + "symbol": "MASK", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "pizza.dexterdev8.testnet": { + "spec": "ft-1.0.0", + "name": "Pizza", + "symbol": "PZZ", + "icon": " ubMrJM6D1Kamkg7+NZS0bFLRhNro/mWzbdwsk2y0QZDJ7N2daSYz4/ykaSk+FEEQwajgk+D/W8En IWqr7YstorRQogSDKPjQ+keh0hcJ67kzs7uTuGu9y9z55pzvfufec+7eC5C4LFuW3iUCLBquLeXT 4rPH5sTEOnTBfdANfdAtK46VKpUmARvjwr/a7e8gxt7X9rf3/2frrlBHAYjdhdisOMoi4mUA/hXF sl2ABEH7yAnXYvgJxDtsnCDiEsO1AFcYng/wss+ZkTKIX0UsKKqM/sTbiAfnI/ZaBAdz8NuOPDWo rSkiy0XJNquaTiPTvYP7f7ZF3WvE24NPj7MwfRTfA7j2lypyluGHEJ9V5Nx0iK8uabPFEP9luWkJ 8SMAXbu8hXIK8T7EY1V7vBzodKmqN9HAK6fUmWcQ34N4dcE8ysbuRPy1MV+cCnV+UpwM5g8eAODi Ki2wevcjHrBNaSqIy41XaDbH8oj4uOYWZgJ97i1naTrX0DmlZopBLO6L4/IRVqc+xFepnpdC/V8t txTGJT2GXpwMdMgwdfz1+nZXnZkI4pI5FwsajCUvVrXxQsh/V7UnpBBftnR/j+LcyE3bk8oBn7+f GuVQkx+T7Vw+xBWYjclAwYR57BUwYBNEkCAPaXxbYKOnChroaKHopWih+NXg7N/CKfn+ALdUav7I 6+jRMEKm/yPw0KrC72hVI7wMfnloq3XQCWZwI9QxSS9JkoP4HCKT5DAZIaMgkifJU2SMZNE6Sg41 x5Yic2TzudHUeQEjUp83i7yL6HdBxv5nZJjgtM/FSp83ENjP2M9rypXXbl46fW5Xi7tGVp+71nPp dCRnGmotdMja1J1yz//CX+fXsF/nN1oM/gd+A3/r21a3Nes0zFYKfbpvW8RH8z1OZD6lLVVsYbOj olk1VvoCH8sAfbl4uwhnBlv85PfJP5JryfeSHyZ/497kPuHOc59yn3HfgMhd4C5yX3JfcR9zn0dq 1HnvNGvur6OxCuZpl1Hcn0Ja2C08KGSFPcLDwmRLT+gVhoQJYS96djerE40XXbsGx7BvZKt9rIAX qXPsbqyz1uE/VEaWBid8puPvMwNObuOEI0k/GSKFbbt6hO31pnZ+Sz3ar4HGc/FsPAVifF98ND4U P8Jwgxnfi75R7PHUcumyyw7ijGmdtLWa6orDyeTjYgqvMioWDOXAoCjruui7HNGmDrWXaOUAsHsy OMJvSf79F9t5pWVznwY4/Cc791q2OQ/grAPQ+2jLNoBn473vAKw+pnj2UngnxGLfAjjVg8PBV08a z6sf6/VbeG4l3gDYfL1e//v9en3zA9TfALig/wP/JXgLtNfFGQAAACBjSFJNAAB6JgAAgIQAAPoA AACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAB+FBMVEXLjn76IRiOHCb1DGf4iNHcAPWFGmk2ABjN j379IgGPGh/4AGT6htDfAPaGGGk3ABjUlIL/JQCUEwD/AFb/fc3mAPyLEGo4ABiyfHPdGGZ+LFrX QIveoNzBMeF2LGUwEBdXPVN6AMpGSahqgdOM1vZhfqRCS1sZJBQAADwBAPEGVccAmvJL7v8AmnwJ V1UALBMAAEI1AOkfUsEAletd6f8AlIYeVFYHKhMGCkM8AOcjUb8Sk+lh5/8Vk4ghVFcKKhMGCkQ8 AOkgUcACk+lc5/8NkogfU1cEKhMGCkY8APAST8MAkehJ5f8AkIgTUlYAKRMFCDs8AM0/VrZKmu6P 7P9Gmok5WVggKhQBAh06LndtYZ2Uqvrl+v+JrIpiZVw/LBUAAAA5PCeAZ4+wsv////+jtItza11K LRY5OUB8ZpKqsP+esopwaV1ILRY5OEV7ZpOosP+dsopvaV1HLRYyNUV4YpSpsP+es4xvZl5IIgYA KUdtVJirs/+jtZBxWmFKAABDIwN2VT+aioaip9/i49+JqXtnilJBd1WJRwnXii7c0l6Qj22Ahm1H kUlRyyst4qmkVQv9oCL58UKGgQAcMwAAgx1D6AAe/8meUgr1myXz6kmJhAA+TAAQhypG4g4i/8Kd UgrzmiXx6EuJhQRFUQYYhy1H4BEj/8GwwjrcAAAAAWJLR0Rkwtq4CQAAAAlwSFlzAAALEwAACxMB AJqcGAAAAAd0SU1FB+YCGQIUD+aNB+AAAAQ6SURBVHja7dH39hByAMDRb0nJSPZoGWVLCUkoykr2 yAypjGxC9sjIHiGKUPSazvEGn99fdc69r3DHyCZlk7PDsinZ4dnUbFrWP4QIESJEiBAhQoQIESJE iBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAh QoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQI ESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEiBAhQoQIESJEyP8hR2TTsyOzo7Kjs2OyGdmx 2ZiZHZcdn52QnZidlJ2cnZKNU7PTstOzWdnsbE42N5uXjTOyM7OzsrOz+dmC7Jzs3Gycl52fXZBd mF2UXZwtzC7JxqJscXZptiS7LLs8uyJbmo0rs2XZVdny7OrsmuzabEUmRIgQIUKECBEiRIgQIUKE CBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEi RIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQ IUKECBEiRIgQIUKECBEiRIgQIUKECBEiRIgQIUKECBFycIWszK7Lrs9WZauzG7Ibs5uycXN2S7Ym uzVbm92W3Z7dkY07s7uyu7N7snuz+7L7s3XZeCB7MHsoezh7JHs0W589lo3HsyeyDdmT2cZsU7Y5 eyqbQMjT2TPZs1kP2ZI9lz2fTSDkhezF7KWsh7ycvZK9mgkRIkSIECFChAgRIkSIECFChAgRIkSI ECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFC hAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgR IkSIECFChAgRIkSIECFChAgRIkSIECFChBzqIa9lW7PXsx7yRvZmti2bQMhb2dvZO1kPeTd7L3s/ Gx9kH2YfZR9n27NPsk+zz7LxebYj+yL7Mvsq+zr7Jvs2G99l32c/ZD9mO7Ofsp+zX7KxK/s1+y3b ne3Jfs/+yPZm48/sr+zvbF+2P/sn+zc7kAkRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSI ECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFC hAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgRIkSIECFChAgR IkSIECFChAgRIkSIECFChAgRIkSIkImF/AfltMXr/n4MwAAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAy Mi0wMi0yNFQyMzoyMDoxNSswMzowMN6a5LYAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMjItMDItMjRU MjM6MjA6MTUrMDM6MDCvx1wKAAAAPXRFWHRpY2M6Y29weXJpZ2h0AENvcHlyaWdodCAyMDA3IEFw cGxlIEluYy4sIGFsbCByaWdodHMgcmVzZXJ2ZWQunmbcKQAAACN0RVh0aWNjOmRlc2NyaXB0aW9u AEdlbmVyaWMgUkdCIFByb2ZpbGUapziOAAAAAElFTkSuQmCC", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1652282573736-37357975462731": { + "spec": "ft-1.0.0", + "name": "Eternal Lands Gold Token", + "symbol": "elGOLD", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "potato_token.testnet": { + "spec": "ft-1.0.0", + "name": "Potato Token", + "symbol": "BATATA", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1651688419857-34712330736260": { + "spec": "ft-1.0.0", + "name": "Example NEAR fungible token", + "symbol": "EXAMPLE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "token13.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Music doge", + "symbol": "Mdoge", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "fartokens.fewandfar.testnet": { + "spec": "ft-1.0.0", + "name": "Few and Far", + "symbol": "FAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "dev-1651665723522-54152650554951": { + "spec": "ft-1.0.0", + "name": "potato", + "symbol": "PTO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "mdoge6.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Music doge", + "symbol": "Mdoge", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "mfight-xp.testnet": { + "spec": "ft-1.0.0", + "name": "Multiverse Fighters XP", + "symbol": "MFXP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "ft.nearlend-official.testnet": { + "spec": "ft-1.0.0", + "name": "Nearlend Dao", + "symbol": "NEL", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "fusotaot.testnet": { + "spec": "ft-1.0.0", + "name": "FUSOTAO", + "symbol": "TAO", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "usdt.itachicara.testnet": { + "spec": "ft-1.0.0", + "name": "USDT", + "symbol": "USDT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "usdt.nearlend.testnet": { + "spec": "ft-1.0.0", + "name": "Tether", + "symbol": "USDT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "dai.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Dai Stablecoin", + "symbol": "DAI", + "icon": "data:image/svg+xml,%3Csvg width='32' height='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Ccircle fill='%23F4B731' fill-rule='nonzero' cx='16' cy='16' r='16'/%3E%3Cpath d='M9.277 8h6.552c3.985 0 7.006 2.116 8.13 5.194H26v1.861h-1.611c.031.294.047.594.047.898v.046c0 .342-.02.68-.06 1.01H26v1.86h-2.08C22.767 21.905 19.77 24 15.83 24H9.277v-5.131H7v-1.86h2.277v-1.954H7v-1.86h2.277V8zm1.831 10.869v3.462h4.72c2.914 0 5.078-1.387 6.085-3.462H11.108zm11.366-1.86H11.108v-1.954h11.37c.041.307.063.622.063.944v.045c0 .329-.023.65-.067.964zM15.83 9.665c2.926 0 5.097 1.424 6.098 3.528h-10.82V9.666h4.72z' fill='%23FFF'/%3E%3C/g%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "dev-1650623538314-53746013589195": { + "spec": "ft-1.0.0", + "name": "KJK Token Name", + "symbol": "KJK", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "stnear.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Staked NEAR", + "symbol": "STNEAR", + "icon": "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 67.79 67.79' version='1.1'%3E%3Cpath style='fill:%23fff' d='M33.934.311a33.9 33.9 0 1 0 33.89 33.9 33.9 33.9 0 0 0-33.89-33.9z' id='path505'%3E%3C/path%3E%3Cpath style='fill:%23ffbd00;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;fill-opacity:1' d='m11.803 27.8 12.387.359 2.361 5.959 7.616 3.31 8.523-3.322 2.348-5.87 12.269.03L54.822 54.2 31.837 58.86 12.89 52.648z' id='path1051'%3E%3C/path%3E%3Cpath style='fill:%23a0a0ff;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;fill-opacity:1' d='m34.657 12.575-10.43 9.633 1.096 10.01 8.844 5.21 9.785-5.287 1.086-11.33z' id='path1815'%3E%3C/path%3E%3Cpath id='path928' style='fill:%23666;fill-opacity:1' d='M33.928 4.282a29.93 29.93 0 0 1 4.682.367 29.93 29.93 0 0 1 25.244 29.572 29.93 29.93 0 0 1-29.92 29.92 29.93 29.93 0 0 1-.006-59.86zm.729 8.293c-2.03 5.668-8.815 9.76-8.815 14.521 0 4.76 3.912 8.62 8.737 8.62 4.824 0 8.736-3.86 8.736-8.62s-6.707-8.697-8.658-14.521zM37.84 22.67a2.524 2.446 0 0 1 .246.012 2.524 2.446 0 0 1 .246.035 2.524 2.446 0 0 1 .24.059 2.524 2.446 0 0 1 .233.08 2.524 2.446 0 0 1 .225.104 2.524 2.446 0 0 1 .213.123 2.524 2.446 0 0 1 .197.142 2.524 2.446 0 0 1 .183.162 2.524 2.446 0 0 1 .168.178 2.524 2.446 0 0 1 .147.191 2.524 2.446 0 0 1 .127.207 2.524 2.446 0 0 1 .105.217 2.524 2.446 0 0 1 .084.227 2.524 2.446 0 0 1 .06.232 2.524 2.446 0 0 1 .038.237 2.524 2.446 0 0 1 .012.24 2.524 2.446 0 0 1-.086.633 2.524 2.446 0 0 1-.252.59 2.524 2.446 0 0 1-.403.507 2.524 2.446 0 0 1-.521.389 2.524 2.446 0 0 1-.61.244 2.524 2.446 0 0 1-.652.084 2.524 2.446 0 0 1-.654-.084 2.524 2.446 0 0 1-.607-.244 2.524 2.446 0 0 1-.524-.389 2.524 2.446 0 0 1-.4-.508 2.524 2.446 0 0 1-.252-.59 2.524 2.446 0 0 1-.086-.632 2.524 2.446 0 0 1 .086-.633 2.524 2.446 0 0 1 .252-.59 2.524 2.446 0 0 1 .4-.506A2.524 2.446 0 0 1 36.58 23a2.524 2.446 0 0 1 .607-.247 2.524 2.446 0 0 1 .654-.082zM24.19 28.16a16.579 2.485 0 0 0-6.502 1.965 16.579 2.485 0 0 0 7.635 2.093 10.483 10.6 0 0 1-1.133-4.058zm20.848.078a10.483 10.6 0 0 1-1.086 3.904 16.579 2.485 0 0 0 6.894-2.017 16.579 2.485 0 0 0-5.808-1.887zm6.925 3.21c-.455 1.177-4.097 2.154-9.273 2.659a10.483 10.6 0 0 1-8.072 3.861 10.483 10.6 0 0 1-8.067-3.85c-5.276-.506-8.978-1.498-9.398-2.64h-.049v5.17h.049a.69.69 0 0 0-.049.24c0 1.8 7.81 3.25 17.43 3.25 9.62 0 17.43-1.45 17.43-3.25a.69.69 0 0 0 0-.24zm.032 7.323c-.67 1.73-8.22 3.03-17.43 3.03-9.23 0-16.771-1.34-17.381-3h-.049v5.17h.049a.69.69 0 0 0-.049.24c0 1.8 7.81 3.25 17.43 3.25 9.62 0 17.43-1.45 17.43-3.25a.69.69 0 0 0 0-.24zm0 7.21c-.67 1.69-8.22 3.03-17.43 3.03-9.23 0-16.771-1.34-17.381-3h-.049v5.17h.049a.69.69 0 0 0-.049.24c0 1.8 7.81 3.25 17.43 3.25 9.62 0 17.43-1.45 17.43-3.25a.69.69 0 0 0 0-.24z'%3E%3C/path%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "token.pembrock.testnet": { + "spec": "ft-1.0.0", + "name": "PembRock", + "symbol": "PEM", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "azk.1741factory.gadillac.testnet": { + "spec": "nft141-ft-1.0.0", + "name": "Azuki", + "symbol": "AZK", + "icon": "https://ipfs.infura.io/ipfs/Qma9mRaodKPUsqRGJtKmeLSP8zTpU2exwUp7UqsNdwS3hh", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "token.durudex.testnet": { + "spec": "ft-1.0.0", + "name": "Durudex", + "symbol": "DUR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "mdoge5.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Music doge", + "symbol": "Mdoge", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "toke_b.ttnear.testnet": { + "spec": "ft-1.0.0", + "name": "toke_b", + "symbol": "TB", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "skyward.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Skyward Finance Token", + "symbol": "SKYWARD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "hbtc.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Huobi BTC", + "symbol": "HBTC", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ft.nekocoin.testnet": { + "spec": "ft-1.0.0", + "name": "NEKO", + "symbol": "NEK", + "icon": " AAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAABmJLR0QA/wD/AP+gvaeTAAAA CXBIWXMAAA7EAAAOxAGVKw4bAAAAB3RJTUUH5gMfBR8eco2eMAAAGINJREFUaN6tmnmQZVd93z9n udvbX6/TPfuMZkYjCSQkDRgMFqtZnMIGgsJWdgUMMQhChbhSOIljgymWGFJxjE3s4BjiYMCJDYSY LWAgYrFAQuuMNPtMT7d6e/26+213O0v+eK3NC0uSU3Xr3Vd169zf9/x+5/f7fn/nCn7C0bnns1z+ 9h8RJC2yzmVG66cJdj292l27fCzLhzc7Y25U3h4Tnt0CWkKIKIi0D6s6Hbhiq7BmyTrxIELeKXT0 g6g9d65/11+nydRB6nuuoRhs8NSX/wvmn/Lin8gu8eM+ePHeb7H0pX+LCOro7AK1G18l+/d85rgz wxd5n7/QFKMnKfKpOHA60RqlQoRMEDLAC42TAuMlhXGMCsMoz4q0zNbyrLzXZuKLQiZffv6HT53/ 2luO+Oa+6ykHXZ77q39GrT39/w/IZ951Kz/1bz7Nt2+7nmMveIccPfTHT1Uie30Qu5+rNPx8rDJk bxMGQ7wBIWOcrOJUFacqeBnhkSAUQiqc0HigtCWjNGV7u8d2r385K4rPeqn++DV/cOneT992Lee+ cooTb34tL/znn/h/A7Jw5gG+/IHXocKE/Mo9NOeOHpqou7fP7Qlf05pkqlIXBJGAYZ/84XXy7pDS BuRUyWxA4SOcSpBhiAwlWipCHaGDBCUVQoxf753DBlXK5kGuPHjHw1vLlz6Grv5+2VtemrjmRlyR 8fPv/vb/HZA7PvdR7vj4u9BJjWTP9bq4/P1XTE2JXz96LLl2ppXjswEC0K0mhQ1YfnCFlaWUYaFw KIQEKQSBFuhI4COBEwIvFEKFxGGVelKnHteIdMTkDS+hfd0L6C2f4fRffYLLJ+/8fl7mv/Ha/3Tp i1/6racDhhOv+h2mjv70jw/krz7+W9z3qQ8R1CdxQavps5V37tsfve26a6JqzWxiBkPQmlTW6PRC NtdLTJqTBJ5qDHEo0FogHze7d+A8GOcpnCd1MPJgZESztZtrXvh2pg/ciB2uka2dZuXsXZy5+6+7 2/3u++sH5n93dzKVteIaE7f8Cq1jt/xoIPd84ePc/h/fjk4mEEFt1uXdDx0+lrzm2iNCyO4arijJ VYXlfsz2lifxlkbFU6lIglggtUAqgZByZ3YBeLwHZz2u9JjMYguHNZ7MebYtFJUp5q59PgcO3Ugo SlzRZ7jVYenM/Sbx5vcb0wd/3aRbPe8srWf+CpPXPufvB7Jy+m6++J5/iPUKryuzLtv4yNXXVl52 bJ/BddZxCDpFwtK6JLSO6TpU6oogkkgtEFKAkgglEUohpEDI8VvG9wIEeOspR4Ziu6AYGkzuyEpH 13pcaw+Hr30Ws3OHUUGMimr0Fx70w6VzH3VB5VcxWc95y9E3ffoJQNTj/1xv70IIRZA0mna0/h+O XRPfemxPgetsYKXmyiBhZQ2mY8+uaUWlpQliiQwVMtDIKEDFIUElIqgnBPUYXY1QkUSFChXp8W+s CWshYT1ERwIhPdJBxQPpNlcePocRgqn548QT+0h2XSVcProx71xObFj/hvDG3vbyJ/Phz93/qO3y kZvP/uatqCChvv9GnfVW33ngcPjqo7sL3MYGVmgubEZsbzj2NQXTM5qwJpFaIsMAFUfoWkzYrhJN 1ggnqgT1CBUHSLXjdO/xzuG9H28WQEWKaKpCdVeF2kxE3NA0A8kul7P8wNc5dc9XMc6h4zatY08R lan2bQzW33z4jZ/E6YiHPvvOJ4bW+Tu/zqGbns2/f0lMpb33H83OuD+66RpXldtdLJKLWzH5EObb kmo7QOpx3MtQo5MIXYtQSYjUj64L3jlcafCmxDv3uGAWj71YCgQCEDjj8QaKfslgZcBwM2XFSWZv +gWe/MxbEcUCeeduOicvdYYD/2pZjL5qVxa47oNnH5vvv9z20xT9Dg59OAkGnzvxFH1tI+/gnGdx kNDbFsy3JM35KvFUDSElzhi8d+hqiAzUzkbY2QfeY7IMb8wPzf0egXOauFElSyEbWHQoqDTbbJ8b 0j1/io6M2HvieRw6Mo/PV0nXMzoXet9JjXi5kqwSt7nuTR9HPvC/PklQaTD7jF+SlIN/emC/vrbp e3jj2DIx/aFiti6oTCVEcxMsrVrOX8jYGoXoZhMdh7g8x6YpNs9wRYEtivE6K/XDUDDsCWRUod/J 6F7s0l/ZZunBLp2VCpMnXk3SnGTKF6zd9y06lx8Eo4nr09Qn28/QtnjD5NL38dUJRlurqKc3lhmt Xqa/cP/T2m37vmsOmIoYDihVyPIgpikdUU2hplr43LB5sUM5LBj2LIOuQwUBSTPCmQJvLTiHDAJU GCK03tke/ompUsBmx+BkTK3iGK33aMw3mD7QRKuYjcV1mgdPoFyfonMJaR3D1NKaPkAQTRJOHCLv 9Q5t+eRLctTd6C/chYzqE+x99j+Wkuz1+/aqqbAY4KVgy8aE1lOrSQoVEtUjzGaPuBJy6IYZrn36 DM2ZiCunt1lbLAiSyg7lEAgh8TuhJnWA1PoJiT5LHQ8vFtTbAaPOAKIq1akqQesIMze8irgS0l8+ S3VuN2FNE0qH3dxgfbWHmrmZ5PDzaVz1tIM60K+tbFxE1maR/aVzLHzzk8frdfEPdjVLvDEUKmKU SmraI2ONiBJC6cgKQW3PFK09LeJGzPyROvNH6jx8vsfmekkQR4DHlQXeGry1OGtwxsDjnHLlQkpU jQiFZTiAxq4aKmqjG88knLyJxvxx0o2zCNElboQEoSQwOesXzpC5CkI44npOmMhXpLPH5+3qSdRz pzfRcfUX9+3hFXONETjo5DFu5Gg0FU4FRBMNosCxvS2Y2t8gShTej+O8WlMoBUsXBtTaCXEjwj6S raz9Wxt+Y61gZdlw5EkTpBspulaluauBbt6Cql2PUCHFsENv8U6akxkmTXGlweWWYjjEC0Nsf4Bd u50izSfyzN9t8+37dfvos6q+f/GFs5MeiaPQIf2hpKUNQUUzzCSViibNC/rGsC+Wj4Lw1oI1zO5J 8B6unB1y6PoJKu0YWxTgHEj5aKL3DqIs54ZnThNIQxnGTOypoqrXoes3gQjBe4IoochyPAlBPaHo 5UhtCMqSh+/+AvWyShgIlEflZfKi8sDPflqbQedouymf1GpYJAGDIsTnhqilkFpivSSIJGubJYW3 aC3HYWItWIv3HqEkc4eb6HjEmbs7TM1VkUrgrAcBUo45mA4llUZCXNFIFZK0QMb70e3ngKrt1J8R vrjMcJBiTRNdjQiqIXpQEpSWvJexuVIyPROgvKM05sTo/P/eraPA3jQ5qaeiRCDQ9DYcEQ6dhHgg zR0I6A8N1voxd3IW7yx4N+ZUWoMQTM4l9Fd6bF/pAm7MeK0fY3ZgHCAVOgqotUKm9k4xfe3PIKNd O0XTYgf34tIHyLMCYxxRIAlqMUEvx2SOSDm6GwWTTYPyIBF78rx/nW7U1Y2TM0qrxGKcYjTq0dSg I4XzsDXM2OM9ZekRCITz49h3DiF3QEgBDorUMLtHgYvx3uOtxxYWk5bYbMx2jXVkpWGwnnF6KWXp 0l9w4ETK9OEbIL+I2bodYTOscTtABCoO0EmAGhriwLM9gjIvCQJBIMuqs+X1ut5Ux2sNAEdhwWZ2 TAQDifOetDCUpUFJgREe78wYhHoMhC08ncUhwmXUGowZ8COsNNEEjRCXW8yoxAxLotLRqAiyoqC7 fi/3f/4cu65+KvuPekLdxeQGb8e8zHsPQqAijVRjoVYMPVlm0UqihRFFnh3XSVXuDkSGz3KyIsQb hw4UUisE44nyzBLFikG/wBuH0I+Fk7OejaUBwqRUm393ERdCoCtjVmzqhmIzpeiXRNIx24becMDK /V8n7dQ5dmIanN9hYOALizd27HUhkFJgDKSpoxILhC9Js2yvlsK3RJHhZUFRKKQHFYw1hdJjpdfb yqjVA65cHlBaQRwH+J0lN6MhSZyiqo8zXCl0FCGUeoyyCAVIhBbomscaTzkoAc/kTML00TpOB5jC UZ2ps/9JljhWlJtDnLHY3GDNYxIqyy3OgPCCoigmpPc2xI2zj7MOKcZZSGqJTgLqNc366pBaRZNm gtX1ciyiBJgsw2Qpj6dUHk3UaBJUa4xSydqaJ8sEJjNY48ALEBIVaEAgK3Umju9l+vAEcS3g8ukt OqspB45PEmhBvjki30rJtwrKFB5hO8Z4rLF463DGhtp575FjRYffcakAoSUqDpiejHjg7JCs8Mzu qnHHdzcoCs/MtCTwj5sZKDKQcYIKAkxpWDq9xsOXRuzbGzA9Hex0U/SYyngwXlGdbhFUFM5Y1h5a 48qZHhdPBzzz5w6gi5x0M8N7KFKBKcep3I/lDc46xsnTo/PS5BaBUBolBH78GEIKZBTQnkpor+Sc eXCb40+ewfkeixe7tOIYXXmi5B/2Be2Gpiwso62MXRPQ1JqoPonN+tg8Q0UBQo9dOCwVzYoiz0qy fkmrKjgwp7jSk2x3M2omoxxZnJeYUuDcY/pfyXFRttaDV5nuZflmYZkVUhEEAr/T+hhrbEnSrHB4 f8mZsyNO3dVh154Ks1OSJHk8JfdY69nuOpIJw/riNg9fGnLdzS2md+9BtZ/B+nf+BJtvIVWJChVe CLZ6hla/YPXSFgvnB9x8yy4O7J+gPfRsbaTUI49zAmMEzu10YgDnHcGYWFNagfNyQ45Ks5gb8EIQ hgKkxDn/KFuVUUB7d4Orj8TMVg0bC3266+WjALz1uNLhUkM2zLn8wDq6zNl7pEF9fj/J/hczWDxH vt2hHBqyXsmwk5Fv5fjScvrOVczGgLm9FZJGTNSssLbQo7M8REUS5wTOCvy4/mKtx+OItAfvyUqB 9XJBWydODjP3fBCEWiBDiTHuMbYqBCqJaO5uECUDkrWcyVmJdx5vHK4ct3Z8aZltO7LU0R+ETE4m bG42GZ35Bmbh20STR6nuvhrbP4UrOggBV80rVpZSFh7O2T8VsrE8xG/16S9sUSQJQgm8l3gH3o1X trAeJR2hGps4ynHWyVPaC/WDfmoL50WoJcQVTVYUeOt29PV4AhmEWBVwebFPremRlRibW1xhcKXD ypD2gTppZ8jGasba6VWkXyZ2I4xuMvfU11GtbVGsn8ObJjiH8J7GVEA53GD11BrD0NOqQHsmYctp vPNjb7jHpPGo8FRii1JgnaCXqYHx6h4tVPSDQTpYKwx7Ei2o1zXdhzNcaXdS5SMxppBCYC30u0Ni CbZQeOMoctgYaeRESPtwg+r8BL2FdbLV8xQGlrOQ3eUipnsnvhyCc/gdviacYariqDuHDiStAw22 rUZ0Da70PNK38H6crYa5Yc+EQwBpIRhk6rIMqqdk0t53flRwz/bQAZJ2NaBAkg9LvHu8RBXoIKDV 1AxThSQHK/BWIrwn8AWLD25x5p4+W/4qJp/1dqae/npkMoHLB6zc9yVM2kU4C7bElwUmzdm6NKAc GYJI0j7cxCC5eP82zo15mrf+URBFCU6UNCvj3Lo1kuQmuONJb/n8snrxkWVDWG0Hwv/cdDNG4xlk ApOX1CcTRKAe093W4QtHYRs0aznCeWyhwDq0K9HOsN0Zcvbe+1i5dI547jiBHSH7i2xulfS2Crqd nIXLKQuXM4arGW67oDCgJ2Js6ehfHrDZh5kDCUFqGHUtXgi8E2ymhnpjxExz7Knz67rsFdX3r97+ ew/qpL0P68VXOv3BpVHuD9SUZlc75vJih9HagGRajNs9ApCSRiPEyDmGrko9vEg+FNgCbOGQ1jIZ QdKwdDbOcPqbW+zWXSJh8S5jtAx5aXFCIIxDVMFr2E4h3TDUhcXk4JSkVZeMzpmxN5ygtJC5jINt iwB6maA7DB6QUfP2oFJHNmev49XvPXUuHarPLK+VIBMalSq1SpPu0ohiK8UMC3xpYYeHJXLAqNyF ISFMcpxxOMOjVbY9f5ATv/B6rrvxGgJhUKEiloZ2aJhqaa4/0WT/LkUgx4W3NRGgawFTR5q4QNGY 1EQe0p7FeYFzkq2sZKKVU4vHjcrFrmJUhJ/snjm5/qQXvRV16y0z3P3f3wfEy/kof+l0u9aIwpik 2mS9MyQUJUrL8coYjyscPh2QZtAflrQnSoLGfvJeii0LWtc8j6mnvYb1iyfZPvl10tLTONAm1B4v BMF0DacVlUaIDiSVyRhRDTl1akhU11QnIyZnIrLVkmHXgZekpWMkBhzeXaIlbI8EZ1aik0a3f602 0eoVeR/1od//FL2lC7zsPd9YfekNEy2cu2V6skVUaaMmjrC+vEJMBtZjM4vNHZQWm26zuFpg1BT7 n/1moskjrC5dIg9a9C58j+zct9AYUhdSiggqGh9rBps5p08N6aceGyhM4THrOWXmWVzOmZ6PqUea 9TM5zgish2455OB8RqPiMR4eWgrsRlZ9d3/h8td+6rbf4yVvfC/qQx/+KK/86TlecX0dKZOHhr3B M2v1xp72wRtpP+VWctGge+YuAlvicje+SodwBrzlynLGKJPsuenF1Pdex+DsN/HLJ1E7VCdUnjwt 6SwPKPsFkw1Jq6kRSpBuZNhugTBQCRV7r6ozNZuwcn9KPvLgYSPPmJ7OmWuPCe2VdcnZlehLqjr/ m5XJdp51r/AXt58dHyt8/C9/wO0feAe6IgZeVZaGqX3J3ImXJZVdR2nOXUVvWNC7eB+Bs+NKbhze eZLAo4Th7KkHWbtyiV0H9jMz1UH6Lcp8LAuEc4RYYgndXBDP1EhaCc1GRJgZhIGoFjJzrEFjNmb1 5IhhZ9xC6uY59QnBwV0BQhi6fbjnol4Y2fqbzWjjoisG/JM/vG+sRAHe894P8M/e8XqCuMFL/t13 zt/zZx/06aD/nNmrrpdhpUFjEraH62ytrRO6ErzH7RwPJAHUE8Hawwucu/cOirTD1P4mEwcmqM7U SSarxM2YoB7hwgDnBEEgSSJJdTKkubdGZS5he2hZuX9ItmHxHrpFQX0y5uB8Ba1gmHvuPueH3azy q+tnl754/AW3sufqm/nEF7/3SLfpsfG5dz4Hk42QYRJnG4sf2H/jc952w4teIlT+XUTjeZy//x5W v/UxmuUmWiqc93jhkBIssDF0dPoeHWsm52tM7qpRqQdEsUIJh3cOUzqyUclgUDIaWgbbJfmmIckF FaUorGfblkzONtk920bJjDzrc/eZzXJxU75r9w0/+/7thQdskDT45Q9/83Hl+m+M//bWp4D3SBU1 smzrg/PHmr9843NfLBoHX4v3gqVzd3H+a3+IXjlJRXl2NBJSgtTjk9tBDoPMk5UwKjxFOfagQCA8 CAfCSSIlqQWaWqgRAvrGYALP7vkWE80mqArDLOWBMxfLpc3yg/Vdx95V9tdzIRS3ffzkE+z+W33/ 9//uH7F45xcppc1dvfnNTmcl3hpy88TcUVWpTdKYmGdyz1H6ecHGxiquSBmL1kfInSfWglokqGtJ I5A0A0Ur1EyEARNRwEQcMZGENKMArSSpNQx8RmPCcWhPlXqlAiqkOyy578zicHWrfE9t7sj7y95q jve89U8e+tsNjr+r63HxO5/lm5/8NWQUoVpT0aB79s3tuf3/8inPes30wUPPwPdXyLsX2Fx8kKWz P6C/soDMU0IBWkiEkAi/Q8F3KrP3j1xgnad0ntwbvMqp10pmWpJaEiJ0jVI0uLxecGahuzDI/a/P 3fDST3TP3W6dLXnluz/H3MFrfzwgAKe++3m+9z/+NTII+cV3f5+P/Kt9zw3q4W8cOvT0n7l6783U vcX2Vyn7S6T9Vba3N+j1BmTDHJNafMl44/hx7I1/HEiLCixxVFKPDbXIEWox7rLIiM004cyytQ9v FF82MvqNrTOLd+556k04U/KW/3zf32fuj/4W5U/f/2x0VGdt+bvoida0K/uvr1dab9o7eeDQ3uo0 NZsjbA9kitAlXnssntKNV975cWdSlDmqGKFthjIFvizHqdw6jBVsDRVXNhRLm+rkyOiPBPXp/1r2 lrf3nXgpg9WLvOF3vvFD7fyxPqr5n596M6e+/xHas8e5cPeD7Hvy/qPejV5d1eErp8Lq1bNJRU0k AdXq+Mx9fBStkKFESI8rCtxwhBsOcWmKTTPSYcHWtmFtE1Y2RbExCB5IbfBpGdc+tX35wsLM0atJ t1a4+gVv4Off9qEfaeOP/ZkTwJ/+wQuoNg6yuvBVFs9eYPfRQ/OuHD5bY19UkfLmZhTsbSRhtVGJ RFKJiCKNlODygqKfMtxM6W0UbHZL192yg+2BuJwZfYdX0RfCavtbnYdOrc9efYAXvONj3PXnv80v feAvf2zbfiIgj4xPf/SF1FtXsXLpK2SDZeZveKPqnP7cvC9G1ylrr9feHteSvVKKtvAitKUn3XZF r+M7w22xUJbqFCK4Vye1U7f89pnl29/W9LXJeW565Tu5dMfned37/vwntun/AFoS/oYm/3uWAAAA JXRFWHRkYXRlOmNyZWF0ZQAyMDIyLTAzLTMxVDA1OjMxOjI5KzAwOjAwwNofTAAAACV0RVh0ZGF0 ZTptb2RpZnkAMjAyMi0wMy0zMVQwNTozMToyOSswMDowMLGHp/AAAAAASUVORK5CYII='/%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "wnear.snails_fi.testnet": { + "spec": "ft-1.0.0", + "name": "Wrapped NEAR fungible token", + "symbol": "wNEAR", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "near.token-factory.tokenhub.testnet": { + "spec": "ft-1.0.0", + "name": "Near Tip", + "symbol": "NEAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1651721707474-21284748210345": { + "spec": "ft-1.0.0", + "name": "Example NEAR fungible token", + "symbol": "WGQ", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "unp.zus.testnet": { + "spec": "ft-1.0.0", + "name": "UPN", + "symbol": "UPN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "poop.tokens.testnet": { + "spec": "ft-1.0.0", + "name": "Poo Token", + "symbol": "POOP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "test_ft_token.denbite.testnet": { + "spec": "ft-1.0.0", + "name": "Example Fungible Token by @denbite", + "symbol": "EXMPL", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "protocol-token.1667369905.ttnear.testnet": { + "spec": "ft-1.0.0", + "name": "protocol token", + "symbol": "RES", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nearx.staderlabs.testnet": { + "spec": "ft-1.0.0", + "name": "NearX", + "symbol": "NearX", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "yti.1741factory.gadillac.testnet": { + "spec": "nft141-ft-1.0.0", + "name": "Yetis", + "symbol": "YTI", + "icon": "https://cdn-icons-png.flaticon.com/512/1137/1137074.png", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "wnear.qa.nearlend.testnet": { + "spec": "ft-1.0.0", + "name": "Wrapped Near", + "symbol": "WNEAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "usn.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "USN", + "symbol": "USN", + "icon": "data:image/svg+xml;charset=UTF-8,%3csvg width='245' height='245' viewBox='0 0 245 245' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='122.5' cy='122.5' r='122.5' fill='white'/%3e%3cpath d='M78 179V67H93.3342L152.668 154.935V67H167V179H151.666L92.3325 90.9891V179H78Z' fill='black'/%3e%3cpath d='M150 104C147.239 104 145 106.239 145 109C145 111.761 147.239 114 150 114V104ZM171 114C173.761 114 176 111.761 176 109C176 106.239 173.761 104 171 104V114ZM150 114H171V104H150V114Z' fill='black'/%3e%3cpath d='M150 125C147.239 125 145 127.239 145 130C145 132.761 147.239 135 150 135V125ZM171 135C173.761 135 176 132.761 176 130C176 127.239 173.761 125 171 125V135ZM150 135H171V125H150V135Z' fill='black'/%3e%3c/svg%3e", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "wagbo.1741factory.gadillac.testnet": { + "spec": "nft141-ft-1.0.0", + "name": "Okay Bears", + "symbol": "WAGBO", + "icon": "https://ipfs.infura.io/ipfs/QmYGAUiqhKp4PvzQpxkbjZ1M3sYAqWLsz3xhCG3NBqMccR", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "mdoge.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Music doge", + "symbol": "Mdoge", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dbio.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Debio", + "symbol": "DBIO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "gem.thegame.testnet": { + "spec": "ft-1.0.0", + "name": "Game GEM!!", + "symbol": "gGEM", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 4 + }, + "meta-v2.pool.testnet": { + "spec": "ft-1.0.0", + "name": "Staked NEAR?", + "symbol": "STNEAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "weth.nearlend.testnet": { + "spec": "ft-1.0.0", + "name": "Wrapped Ethereum", + "symbol": "WETH", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "flas.zeiris-test.testnet": { + "spec": "ft-1.0.0", + "name": "FLAS", + "symbol": "FLAS", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "aurora": { + "decimals": 18, + "icon": "", + "name": "Ether", + "reference": null, + "reference_hash": null, + "spec": "ft-1.0.0", + "symbol": "ETH" + }, + "gold4.thegame.testnet": { + "spec": "ft-1.0.0", + "name": "LandtoEmpire.com game GOLD!", + "symbol": "GOLD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "lnc.factory.tokenhub.testnet": { + "spec": "ft-1.0.0", + "name": "Learn NEAR Club", + "symbol": "LNC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "usdc.itachicara.testnet": { + "spec": "ft-1.0.0", + "name": "USDC", + "symbol": "USDC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "test_contract.testnet": { + "spec": "ft-1.0.0", + "name": "Test Token Demo", + "symbol": "TTD", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "token.infi-finance.testnet": { + "spec": "ft-1.0.0", + "name": "INFI FINANCE TOKEN", + "symbol": "INFI DEV", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "usn.testnet": "", + "dc.tokens.testnet": { + "spec": "ft-1.0.0", + "name": "DabnioCoin", + "symbol": "DC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "usdc.faucet.orderbook.testnet": { + "spec": "ft-1.0.0", + "name": "USD Coin (Tonic)", + "symbol": "USDC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "dev-1668149532445-37289092214188": { + "spec": "ft-1.0.0", + "name": "NEKO", + "symbol": "NEKO", + "icon": " AAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAABmJLR0QA/wD/AP+gvaeTAAAA CXBIWXMAAC4jAAAuIwF4pT92AAAAB3RJTUUH5gQVFS8KdqrjugAAE7dJREFUaN6dmnmQ3dV15z/3 /ra3d79e1K9b3Y260S7UsiQQmHWMsCFgwQQnMF7whLKcOA5xypSNpybBxGUnM2GSEkk5M2Q8NeUI TBJXGAw4GCwEBkuAkNECtNBGa+n99fr6rb/l3ps/XqtRG+HB/lXdrnqvfv1+n3Peued8z7lP8Gtc n7th7aLXRutYpKKVRpsrpJSXW7a9znGcTttxG6VlxQC00n4URTNhEAwppfu1YZ8QvGZb4rgQ1M7/ vEefP/KhWcSvC2y0Rhu9VCt9o+04t6UbspvbOrrbOro67VxHF9nWDpKpNI7jAZqwOkZ5cj8zY28w Nl5jZCyMxieifLGofxFF5ikpeVZIMSzPI/kwBvxK8EXAxmC07tBa3xVPJO/q6lm+Zv2lV8rVa1fS mhkkJs4gpQG3BxFbASbC1I5C9SCEeTAh2kCtZshPRhw76fPWkaoZHArfqdb0TinFI0IwIj6kAeLD QCOEE4XB7a4Xu2/56ks2Xb31ZtZsuIxk0oWZH2BKezAmQkWaINQEkYNSCmECbFviug6OY2FZ5z/O UK5o3jnus3dfmXcH/IN+YB60bfH/gOD/By9+FbQxBmNMzhh9f1t7190fu/m341uuuYFkugHULHr2 3yiO/JiR0VmGhuaYmixTrfjoSCEwSCGQlsTxHJLpGC2tKTo6MixpTRKPO2AAUTdg/4EqL+4pVcfz 4feFEN8WgtFz3r8QvPhgaI3RZq20rL9b+5HLtt76n+6mu2cFqClU6QCjJ5/j7YOvcfrUJEQRLRmX tmaPbMYjEbOwpQCtiUJFrRpRLIXMliIKPlgJj86eZlasaKGxIUbdAsPQSMRTzxU5crT2gtZ8RQj6 PwhefBC01maT47jfu/JjN27adufdpDMupvgyk2ee5fW9r3Py5DjNaY81FzfS2Z4mmXSRlgUCjKkv bcBog1YGHURE1YDaXI3ZmRqjswElIele0czaNa3EYzZgKFXg354v88rr5YNhxHYpOHAhePF+aIPR eq3tuI/8h9+6bdMn7/g9Yo5PNPkD+vf/mD173iXmWFzW18ZFnWlcx677y5j5/1+8tAFjxPw9oCND VA0IZqvMTdcYnqkRJW02bM7R3pZCYAgiwTMvVvnZ3srBKDJ3Xcjz1jnwvt7Wc+A5adnfu2rrzVfd 9pkvEnMq1Ea/z8s//SGvvHKG1T1Zrr+yi9ySJELUgd7bbu8HN0Ysfo1AOjZ20sONu6SkDWXNiYEZ jG3INnpYQtPb7VCpifbBkXC1MewSghLAmwMT74Gfl0EcrfV/W79hxZ133HUnSess1bHH2P3Mj+h/ e5zrtnSweX0brisvuNPrYO8ZoH8Zet5KraHia+Z8Q2BJXGGTjGzODhYJULQ0edhCc1GXw/iU6RnP q4SU7AJUX28rbw5MYJ//UKXMp3Jt7t3bbqiR8v+BYK7Eyy8c49jRCa7d0snS9gyD4zWCUNPU4NCU cRDi/JA437OLjTj3Xs3XvHF0jr1vVZkqxVEqpLvJ57reFLlYA2f7S1gWrOxtIGErbr7OJT8R3T2a j35uSfFP50LGei+26XBd+fe3fDzT1bfOweiAAweH2bdvkC0b2kkkEzz+wiRP7DG8fjLFnsNlxvIF upa4JGP2+8AXeXveAD/QPPXzKfae6mH5xt9h06Wf4KqP38HZqRh79h9gZYtHox1nZKxMosGQTtik YxrLtuwTp/XFSvFjISj29bZi9fW2og1obf5o9Qrvc9tuzOA4kpGROZ597jirerLkco3836enCBtv 5t4/3cFtd3yBjR/dxqmJDE/vOszS5oDWRg+tPyCu59cLv5jhWPEyNq6+muDxZ1jz+D8ze/woV/3h l3lnsMj4wDssX5LCUi6j0yWW5GwcS9DSYBgcM7n8tJlEsEcI5sG1WRqPy7/edlOmtbvLJfAVu54/ iQ4jrrx0KS8dKDAcXsHfPPQ/GTp0kEN/+RfMvHuSm7Z/kRXrt/JPT7xKW3qW5kYPrS8c12dGK+w9 fTHrV13H4Hcf5TMDR7iiUqBrcJB9o6Os/uxdPPeTZ+lrj+FIB79sUaXCkhYH1zLY0nDsNB2R4kkp mJPzm+Wm7k5nzarlLkZpBgamOHN6mkvXL8GxLQ4cD/nUnf+Z46/vY/gLX+Q/PvkkV3/3u7z06U+T TSe55788zE/f6mR8yl/YLwvxAWhtOHTKY8vVd3D2X3dxzeQ4y3WZUAgywLJXXiEWhrhNXUzPRSgt 8ESc8VMWM7M1tFKs6NR0tZnVWvNbAFJrYrYtbutbGxMJzxD4IYffHKU549LTlcEPNOXAo7Orizef eJrG2ZCYkHQIwa379nHg859H6og7f/9B9h7LMlfyKRR98tM1hvIVhsYrnDxbpKnn48jBGRJHBviI KiDnrTJC0F4qEY0M09TezXQpQiuJ1hJRTXHmdIhWmrijWLvMCNvmVm2I20qbVU1Ze/PKXhe0ZiJf YmiowEfXtxKLOehCDYSFEDA2OUdOukht0EBaCG4+dIifbN/OFY/+gI03fIMDb/wjXjxDJYwRRBY1 P2C2MIdx4cxLz9ISFTBRBTGfHgyQApicpKGphcqUQWuJUmBpj5FBi+U9AcmYxcUdmkzC2TxTFKts Y7gi12ovacmCVorTZ2YR2tDVnl6orUIIjDFUQ40vrYWiY4CMEHxi3z5e+ON7uH7nI2zech227SAt CykEBoOKFKVykdFPj3Lw1Vf5Xzt3snnPHm7WGlcIPEDOzBBPJwmVqHtcgdaC8kyc/ESBZUsFTSlD a6PdOj0nPiql4PKOnG27lib0IwaH52hOu2Qy3kIZl/PeEcYwJ13UeRJHA83AktdfZ2JkmEQijuva 2JZASrCkwHVtmrJZ1q1dy+e+8AXufeIJTt1/P3+bTlMwhhhgT00hpQVGolR9aS2JfI/RsbpTXUuR yypbCC6Xti3WtbVIhFFUqwHT01VaGmPYTl0NCAFSCixpYVsWU9KjJJ0FdGkM7zoO1S99id41a/gw V2tTE/c+8AC5B/87f5VJMQskp6fRUYglLJQSaC1QSmCUzeSkRRhECKNpbYiwLdZJxxadjWmBUYpy KaBWi2hMekgp58EFFgqhAlzHoSBdzth1MSSMYdDzOHPffVx3//3EXPdDgQNYQnD3HdvY9OU7+ZtE jKhQQFcrOMJG6brHjRGAoFy0qfkKozUNcYVtmU5pOyIb9wxoTaUaopUh7tkL8tS2JLb2YXyARCZF ZOCwm6VqJPlkkvyf/zlXf/ObJGOx+dSnyefzzM7O/krwt/v7+d7D/xvPgtbbr+eHYYCMIlzbPq+Q 1Vfg2/g1DbqeXWyLRmlJPFtqjFKEQYQxYM1vQGMgGZM0ZmD8yEE+cuUl+GmPU8Zlf+dK/P/xIBu/ /vUFT09OTvK1r32NG264ga9+9avs3r0brfX7oHft2sUnb7mF7/zDTvrdblpWXkKYy/B2/1skHHfB 08YIlDFoJQnDOqMlNJYwnjxXMYzWmPmHaPWeta4juWZTgp/seZFNq3J8csd/Ze29v0fnP/8jPX/4 ZVxrQRnz0EMPsWPHDlatWsW3vvUtoiji6NGji6BrtRoPPfQQZ86c4Z577uHPvvlNrvrU57lsVQ+z I4PzGeyc3jHz3hcYXWdknlEqjR9G9bGDLevpLwjMArw2sLYnSY0JJo4dZusVvXzm3rtYuWX9ovap VCqxe/duAK699lq6u7vp6+tjbGxsEXi1WmVkZITe3l6SySRhGFKqVOle0szFnW3kizXE/CcrDZE2 SGmw0BilCUNQGl9GkZmp+vW6H3PqKaxUVqjILIRLGBmSXoykLWDgMEyPgbAXAVmWRXNzMw888ADJ ZJLHHnuMhx9+mCiKFt2XyjRw7XXXsXPnTpLJJDfedBP3feWP6MnGubgzx3ixyrkCEum6x21b4UgN 2lDxIdJiVoahGZqdq38NcVfguZJCMSSomveUHpCMeSQSSVh7LfR8BGxnEVA8Hmf79u1s3bqVkZER PvvZz7J//342b9pEeXCQ2f2vMPf6ywRHD7P9t29jemqK559/nlOnTvG7t97CuhW9NKeTlIJoQV0G kUYbiHkBrmUwylAoW0RKDNmRon98ymzRGjwHGtM204UahYmI5rhbj7GaQIQRVd+n4byY/uVr27Zt 9Pf3k0gk2LFjB79zxx1EJ07ws+98m0tSeZoTGp3wWJbNku27nZV/dj/JVJKluTZ4cxeWWNwl+ZHC YGhI13CEQUUwOWcTadFva232jeTVXX6I7QhDR7PH4XyV0VMBpWmBiqBaMkRzVU4MDpEbH4Dmrnpl Ou8K/BoIQV9fH319fQvvH3vhRQpnh5jtlLQnNNI1CDWMyp+gc9X2hft0Ist0qYJnW4AgUIpQGZAR rdkawhj8QDBWcCJj2CeF4LXxCZWfLAgwms5WFy0jpko1ipOG0jREgaQlbrHvyAkYPgH50+/ztpCS /MgglVJxQSoAdFxzDS0bNnBizHBsVFMe86nOpHA2f2LB4JnpScanJhmcmKEh5mIMVEOF0hCPV1jS EIAyTJUsJkv2hBC8am3oXVIIQ65uaTCrupsDPEcwMuUzW9RkvQaMrmsG17I4eGaKdcsuIitqkG0H L7Foczqux9T4MHOFGYQAL5bAa2yg7bLLsDKNFGQjalkfDb/7ByQuvZbpyXEKM5NIIRDTYzzywx+x OpvGtSzmagGRNnR1TbC8rQYa3hpO8s548iXgYVtKaqEyT/a/az656SIj4q5hTVeMFydLzNVqpOwU SoNnOTS7VR7f+wZfzzXD2z+DvushmX1vgyaSdPWuQkUhQeBjjEEIQaqri/Vf+oN6HhZiQW0mUmka m5dgCcPLT75FpVQhu6yNoh8SaXC8Khd3FJEaqoHgWD5hIi2esqWpSgApeG4oL945MSQxWnFRq0Ou STBcmSSM6pVLKcnylgyH+t/hxbdOQmEcDu+GQn4BXEURE2NDTOZHcR0PUast7DZTLmMGBhBK1UNL KfADRgYHCI6/wb8+81N6GlP10UWo0MawtGOSJckIowwDkzGGC95RIfgJzPecAuaCSGb8gBtWL/WJ 2ZqkJzk2VgIdIy6SaC2whE3Skjx94Dg9HTk6UjZMDoLtQipLqVQCDI3ZFmzXRY+Ook+cgMlJzMgI wnHQAwMwM4MeHsFtbSFRzvPMY9/nR7tf46ruHKUgIlKQSM+yZXWepIBqINl9spl82d1hCfPMQrMs 6tJgYK5qXZ+OqfbOpoCUJ9BG8+5EkRhpbBNDa0HKdbGN4l9efRvb9VjZmsGaHYG5SbxUhnhTG5ZT 1y6ioQERj4NlI3t6kB3tiHQaMFhNKRg/xp6nH+evHnmSLbkmPNvGDzXCqbJh9RBdqQij4PBohjdG MocM4htSUASw3hyYODd+KyotCtNF65aLWnwnHVO0pOqbZKhQIU4DlnExQDbu0exZPPvGEfYeP4sw hkZdI1kYgdlR8MugItAK4bmIVByhAihOIcp5xOwZ8of38n8e/Rf+/vFdbGxpoDWVoBoqjAxZsXyQ 9W0VRARjRY9dA621km/fJ6V5RVCfHwpYPIJTWjy0uqP25dsvnSHpKSo1w8+P1xidSNEue/FIYDAI 6jri9HSR41MllOPS25ljQ28nqzrbyLU0kcmkcVxvPu35FObmODUyziv977LnrRNIP2BzRyuebeFH GiMDli0bYstFBdwIyqHk6RM5jk+nHpbC/AnzA/8F8PPhjSEnBI9euqy89cZLZnEtQ8U3vHbK5+x4 nFaxjASZBT0hqGeIuVrAcKHMSLFKIVQYaeG4No5t18t3GFHzA4RStMY8eprSpD0PP1JE2oBT4eKe YTa2F3EVBJFg95lWDow3vmAMnxOC0XPQAIuVUp1lTBv+5MCZ5E5H6k0fW1Ugbhuu6nFp8GocGTlO JeygUbRh46DnW+d0zGVNzGNNmyDSGj9U+JEiUBpjBLYUOPMNdKQ1tUhRDhQaRSw9zbreMVY2+Fgh +JHg58PNHMo3HNRGfEUIM/rLmAvC41ysz38FE9qIX4wW3MvKvmxfmvGJ24olKYuWpGZGzTLhz6G1 xDIOwlgLwkgbwAgsKXEsC9eysKRAmbr2qIYKP9JERiG8OZZ2DbNl+QTdsRARQjmw+NngEg7kGw9G Wn5RCHP4XFhccLB/gZDBwFop+LvlLdWt1y+fIZf2wUCIYcyPODYmmJhOoKqNWFEaS3sIU+/U9blG YH7V7VEYGeAmSrS1FFjeVibnRlhB/eRivBLjpeFW3i2kXpj3dP+FoC8Ivgi+/ienEfe3JMK7L+8q xC9pK5KwFdIxGMcw4xuGCjA2IykUXWo1DxW6GG2DmR9R2BGxWEhDyqet0SeXjGgQBunXpWolsuif bmB/vqk6XfO+LzDfRjD6QdAfCP5LmeZctrndsfQ3uhtqGze2z9HbWCZuK6QF0gbjGCIbagqqIUT1 AoltQcwGVxvswIBvMEF9nliNLE7NJTk0lWWwlDgYavmgJcxvflx4Ifh6NyQ6tOGumK0/n0v5a1Zk S6KnoULWC/AshRODeIvAcuvxLgCtDLUpTTCnURH4SjLju5wuJjlZSJuxSvwdX8tHBDwihBk+H+g3 OqD9QAPq5zhLteEmS5pbk47a3BwL2lrjvt0c82lpUWSyGlsahIBKwTCbFxRDh6maS74ai6Z9N1+O 7F8oLZ6SgmcFZvjDnij/WuAfED4YQ0wZsdIgrhCYyy1p1tnSdNqWyVrCeABKCT/SYjYyYlAZccQY 8ZoQZp8lzDHBb/4jhH8HsQSGthsv6IwAAAAldEVYdGRhdGU6Y3JlYXRlADIwMjItMDQtMjFUMjE6 NDc6MDgrMDA6MDDs4phyAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDIyLTA0LTIxVDIxOjQ3OjA5KzAw OjAwO8gregAAAABJRU5ErkJggg=='/%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "tax_rate": 500, + "decimals": 24 + }, + "wbtc.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Wrapped BTC", + "symbol": "WBTC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "nusdc.ft-fin.testnet": { + "spec": "ft-1.0.0", + "name": "NEAR Wrapped USDC", + "symbol": "nUSDC", + "icon": "https://s2.coinmarketcap.com/static/img/coins/64x64/3408.png", + "reference": null, + "reference_hash": null, + "decimals": 2 + }, + "token.bigprojects.testnet": { + "spec": "ft-1.0.0", + "name": "DeToken", + "symbol": "TEST", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "token_test02.supernova11.testnet": { + "version": "V_1", + "name": "Rare", + "symbol": "Rare", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 20 + }, + "dev-1669774757309-31633349373710": { + "spec": "ft-1.0.0", + "name": "PN", + "symbol": "PN", + "icon": "'/%3E%3C/defs%3E%3Cuse id='Background-Layer' xlink:href='%23image' x='0px' y='0px' width='46px' height='46px'/%3E%3C/svg%3E%0A", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "gem4.thegame.testnet": { + "spec": "ft-1.0.0", + "name": "LandtoEmpire.com game GEM!", + "symbol": "GEM", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "dev-1653557891931-71587257098750": { + "spec": "test", + "name": "test", + "symbol": "test", + "icon": "data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M6.18169 18.0234L5.94469 17.7027V16.2629L6.32518 15.9379L5.94469 16.0618V11.0351L5.11127 11.8686C5.02928 11.9505 5.02928 12.0835 5.11127 12.1655L5.68274 12.7369V14.2216L4.97194 13.5108L5.0942 13.0884L4.62741 13.1662L4.36897 12.9078C4.20658 12.7454 4.0978 12.5497 4.04261 12.3427L4.04559 12.3362L4.03914 12.3294C3.93293 11.9127 4.04287 11.4523 4.36897 11.1263L5.05112 10.4441H5.34496V10.1503L8.50787 6.98735H6.99447V8.13528L5.94469 9.18506V7.59159L6.32518 7.38946L5.94469 7.12088V5.93757H7.79345L8.08046 6.20407L8.58016 5.93757H9.55765L9.56015 5.93506L11.0448 5.93506L11.0423 5.93757H13.006L12.1726 5.10415C12.0906 5.02216 11.9577 5.02215 11.8757 5.10415L11.3073 5.67252H9.8227L11.1334 4.36184C11.3452 4.15005 11.6136 4.02943 11.8899 4L12.845 4.29694C12.8689 4.31753 12.8922 4.33916 12.9149 4.36184L13.1867 4.63366V4.72234L13.5743 5.42901L14.0636 5.51058L16.9807 8.42764V6.98735H15.9109L14.8611 5.93757H18.0305V6.34526L17.9055 6.47762L18.0305 6.76931V13.072L18.937 12.1655C19.019 12.0835 19.019 11.9505 18.937 11.8686L18.2925 11.224V9.73941L18.6344 10.0813L18.6805 10.1933L18.8269 10.2739L19.6793 11.1263C20.1713 11.6182 20.1713 12.4158 19.6793 12.9078L19.6367 12.9504L19.1364 13.0884V13.4507L15.6135 16.9736H16.9807V15.9694L18.0305 14.9196V18.0234H15.2939L15.1472 17.8983L14.793 18.0234H10.9691L11.8757 18.9299C11.9577 19.0119 12.0906 19.0119 12.1726 18.9299L12.8181 18.2844H14.2353V18.3518L13.3438 19.2433H13.1867L12.8932 19.6934C12.8617 19.7234 12.829 19.7515 12.7953 19.7777L11.704 20C11.4949 19.9453 11.2972 19.836 11.1334 19.6722L11.015 19.5538L10.474 18.8558V19.0128L6.99447 15.5333V16.9736H8.06699L9.11677 18.0234H7.24824L6.91787 17.8983L6.68572 18.0234H6.18169ZM16.9807 9.91225L14.0558 6.98735H9.99248L6.99447 9.98536V14.0487L9.91937 16.9736H14.1289L16.9807 14.1218V9.91225Z' fill='%23FFD378'/%3E%3Cg clip-path='url(%23clip0_5878_1589)'%3E%3Cpath d='M9.51221 8.49464C10.9949 10.6511 9.70598 10.4886 9.11497 10.6715C9.70476 11.4759 9.3666 12.2318 8.43848 12.7052C9.23653 13.0257 10.2968 13.1681 9.07733 14.8593C10.287 14.1749 11.125 14.1172 11.0098 15.6672C11.8884 14.7781 13.0322 14.33 14.1725 15.0815C14.0424 13.958 14.3649 13.4659 15.4931 13.9506C14.2834 12.8408 14.7833 12.1818 15.5001 11.5362C14.2613 11.4871 14.0876 10.5406 14.1332 9.4093C13.3855 10.2228 12.8183 10.1352 12.5522 8.54342C12.0384 9.71173 11.3463 10.4574 9.5122 8.49463L9.51221 8.49464ZM11.1901 10.1567C11.4348 10.1622 11.5787 10.3422 11.717 10.5319L10.8125 12.0986C10.5021 12.1288 10.2757 12.029 10.1773 11.7319L11.0819 10.1651C11.1112 10.1601 11.1392 10.1574 11.1661 10.1568C11.1742 10.1566 11.1822 10.1566 11.1901 10.1567V10.1567ZM12.2395 10.327C12.4842 10.3323 12.6281 10.5124 12.7665 10.7021L11.7494 12.5114C11.439 12.5416 11.2127 12.4417 11.1142 12.1447L12.1313 10.3353C12.1607 10.3303 12.1887 10.3276 12.2155 10.327C12.2236 10.3268 12.2316 10.3268 12.2395 10.3269L12.2395 10.327ZM13.1318 10.8141C13.3766 10.8196 13.5205 10.9996 13.6589 11.1892L12.6564 12.976C12.346 13.0061 12.1197 12.9064 12.0213 12.6093L13.0236 10.8225C13.053 10.8175 13.081 10.8148 13.1079 10.8142C13.1159 10.814 13.124 10.814 13.1319 10.8142L13.1318 10.8141ZM13.8363 11.6537C14.0912 11.6552 14.2428 11.8358 14.3889 12.0259L13.5444 13.4887C13.24 13.5084 13.0145 13.4071 12.9092 13.122L13.7538 11.6593C13.7824 11.6554 13.8099 11.6536 13.8363 11.6538L13.8363 11.6537ZM10.0561 12.2298L11.6648 12.9522C11.7106 13.2819 11.6225 13.5418 11.331 13.6956L9.72221 12.9732C9.65369 12.6446 9.84797 12.4338 10.056 12.2298H10.0561Z' fill='%23FFD378'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_5878_1589'%3E%3Crect width='7.7829' height='7.7829' fill='white' transform='translate(8.11719 8.09961)'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "gold.thegame.testnet": { + "spec": "ft-1.0.0", + "name": "Game Gold!!", + "symbol": "gGOLD", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 2 + }, + "dev-1645773481635-17615479205365": { + "spec": "ft-1.0.0", + "name": "Bitcoin", + "symbol": "BTC", + "icon": "data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSI2NHB4IiBoZWlnaHQ9IjY1cHgiIHZpZXdCb3g9IjAgMCA2NCA2NSIgdmVyc2lvbj0iMS4xIj48dGl0bGU+Qml0Y29pbjwvdGl0bGU+PGcgaWQ9IlBhZ2UtMSIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+PGcgaWQ9ImNyeXB0byIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTg2LjAwMDAwMCwgLTkzLjAwMDAwMCkiIGZpbGwtcnVsZT0ibm9uemVybyI+PGcgaWQ9IkJpdGNvaW4iIHRyYW5zZm9ybT0idHJhbnNsYXRlKDg2LjAwMDAwMCwgOTMuMDAwMDAwKSI+PGcgaWQ9Ikdyb3VwIj48Y2lyY2xlIGlkPSJPdmFsIiBmaWxsPSIjRjVCMzAwIiBjeD0iMzEuNyIgY3k9IjMyLjUiIHI9IjMxLjciLz48cGF0aCBkPSJNMjMuMSAxNi4zYzEuMS4zIDIuMi41IDMuMy44IDEuMS4zIDIuMi41IDMuMy44LjMuMS40IDAgLjUtLjMuNC0xLjcuOC0zLjMgMS4yLTUgLjEtLjMuMi0uNC41LS4zIDEgLjMgMS45LjUgMi45LjcuMy4xLjMuMi4yLjQtLjQgMS42LS44IDMuMy0xLjIgNC45IDAgLjEgMCAuMi0uMS40LjguMiAxLjcuNCAyLjUuNi4xIDAgLjItLjIuMy0uMy4zLTEuMy42LTIuNSAxLTMuOGwuMy0xLjJjMC0uMi4xLS4zLjMtLjIgMSAuMyAyIC41IDMuMS44LjEgMCAuMS4xLjIuMS0uMyAxLjMtLjYgMi41LS45IDMuNy0uMS41LS4yIDEtLjQgMS41LS4xLjMgMCAuNC4zLjVsMy4zIDEuNWMxIC42IDEuOSAxLjQgMi42IDIuNC45IDEuNSAxIDMuMS42IDQuNy0uMyAxLjEtLjcgMi4xLTEuNSAyLjktLjYuNi0xLjQgMS0yLjIgMS4zLS4xIDAtLjIuMS0uNC4xLjQuMy44LjUgMS4yLjggMS4yLjkgMiAyIDIuNCAzLjQuMiAxLjEuMSAyLjMtLjIgMy40LS40IDEuNC0uOSAyLjYtMS44IDMuNy0xLjEgMS4zLTIuNSAyLTQuMSAyLjItMi4xLjMtNC4xLjEtNi4xLS4yLS4zLS4xLS41IDAtLjYuMy0uNCAxLjYtLjggMy4zLTEuMiA0LjktLjEuNC0uMS41LS42LjMtLjktLjItMS45LS41LTIuOC0uNy0uMy0uMS0uMy0uMi0uMi0uNC40LTEuNy44LTMuNCAxLjMtNSAwLS4yLjEtLjMtLjEtLjQtLjgtLjItMS42LS40LTIuNS0uNi0uMi45LS41IDEuOC0uNyAyLjctLjIuOS0uNSAxLjgtLjcgMi43LS4xLjItLjEuMy0uNC4yLTEtLjMtMi0uNS0zLS43LS4zLS4xLS4zLS4yLS4yLS40LjQtMS43LjgtMy40IDEuMy01IDAtLjEuMS0uMi4xLS40LTIuMy0uNi00LjYtMS4yLTctMS44LjItLjQuMy0uNy41LTEuMS40LS45LjgtMS44IDEuMS0yLjYuMS0uMy4yLS4zLjUtLjMuNy4yIDEuNS40IDIuMi41LjguMiAxLjQtLjIgMS41LS45IDEuMy01LjEgMi42LTEwLjIgMy44LTE1LjQuMi0uOC0uMy0xLjctMS4yLTItLjktLjMtMS44LS41LTIuNi0uNy0uMiAwLS4zLS4xLS4yLS4zLjMtMS4xLjYtMi4zLjktMy40LS40LjMtLjQuMy0uMy4yek0yOC4yIDQxYy4xIDAgLjIuMS4yLjEgMS42LjQgMy4zLjkgNSAxIDEuMi4xIDIuMy4xIDMuNC0uMyAxLjktLjYgMi43LTMuMSAxLjYtNC43LS41LS44LTEuMy0xLjMtMi4xLTEuOC0xLjgtMS0zLjktMS40LTUuOS0xLjgtLjMtLjEtLjMgMC0uNC4zLS4yIDEtLjUgMS45LS43IDIuOS0uNCAxLjQtLjcgMi44LTEuMSA0LjN6bTguNC0xMC4yYy4yIDAgLjctLjEgMS4xLS4yIDEuOS0uNCAyLjktMi42IDEuOS00LjMtLjUtLjktMS40LTEuNS0yLjMtMS45LTEuNC0uNi0yLjgtLjktNC4zLTEuMy0uMy0uMS0uNCAwLS41LjMtLjUgMi4xLTEgNC4xLTEuNiA2LjItLjEuMiAwIC4zLjIuNC40LjEuNy4yIDEuMS4zIDEuNS4yIDIuOC41IDQuNC41eiIgaWQ9IlNoYXBlIiBmaWxsPSIjRkZGIi8+PC9nPjwvZz48L2c+PC9nPjxtZXRhZGF0YT48cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiIHhtbG5zOnJkZnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDEvcmRmLXNjaGVtYSMiIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyI+PHJkZjpEZXNjcmlwdGlvbiBhYm91dD0iaHR0cHM6Ly9pY29uc2NvdXQuY29tL2xlZ2FsI2xpY2Vuc2VzIiBkYzp0aXRsZT0iYml0Y29pbiIgZGM6ZGVzY3JpcHRpb249ImJpdGNvaW4iIGRjOnB1Ymxpc2hlcj0iSWNvbnNjb3V0IiBkYzpkYXRlPSIyMDE3LTA5LTE3IiBkYzpmb3JtYXQ9ImltYWdlL3N2Zyt4bWwiIGRjOmxhbmd1YWdlPSJlbiI+PGRjOmNyZWF0b3I+PHJkZjpCYWc+PHJkZjpsaT5WbGFkaXNsYXYgU2VyZ2VldjwvcmRmOmxpPjwvcmRmOkJhZz48L2RjOmNyZWF0b3I+PC9yZGY6RGVzY3JpcHRpb24+PC9yZGY6UkRGPjwvbWV0YWRhdGE+PC9zdmc+", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "usdc.map007.testnet": { + "spec": "ft-1.0.0", + "name": "", + "symbol": "", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 6 + }, + "xcorn.ver_1.csdev.testnet": { + "spec": "ft-1.0.0", + "name": "Staked CORN", + "symbol": "xCORN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "bolt-official.testnet": { + "spec": "ft-1.0.0", + "name": "BOLT", + "symbol": "BOLT", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "ulm.tokens.testnet": { + "spec": "ft-1.0.0", + "name": "ulimoney", + "symbol": "ulm", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "space-tret.huanlam2.testnet": { + "spec": "ft-1.0.0", + "name": "Space Tret Token", + "symbol": "SPTT", + "icon": "https://spacefintech.com/images/logofintech.png", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "mdoge2.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Music doge", + "symbol": "Mdoge", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "token2.map007.testnet": { + "spec": "ft-1.0.0", + "name": "", + "symbol": "", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwx.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Long Name Token", + "symbol": "LNT", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "v2-nearx.staderlabs.testnet": { + "spec": "ft-1.0.0", + "name": "NearX", + "symbol": "NearX", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1651510927087-21303959453558": { + "spec": "", + "name": "dev-1651510927087-21303959453558", + "symbol": "dev-1651510927087-21303959453558", + "icon": "", + "reference": "", + "reference_hash": "", + "decimals": 0 + }, + "nexp.testnet": { + "spec": "ft-1.0.0", + "name": "NEXP", + "symbol": "NEXP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 4 + }, + "usdn.testnet": { + "spec": "ft-1.0.0", + "name": "USN", + "symbol": "USN", + "icon": "data:image/svg+xml;charset=UTF-8,%3Csvg width='38' height='38' viewBox='0 0 38 38' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='38' height='38' rx='19' fill='black'/%3E%3Cpath d='M14.8388 10.6601C14.4203 10.1008 13.6748 9.86519 12.9933 10.0768C12.3119 10.2885 11.85 10.8991 11.85 11.5883V14.7648H8V17.9412H11.85V20.0589H8V23.2353H11.85V28H15.15V16.5108L23.1612 27.2165C23.5797 27.7758 24.3252 28.0114 25.0067 27.7997C25.6881 27.5881 26.15 26.9775 26.15 26.2882V23.2353H30V20.0589H26.15V17.9412H30V14.7648H26.15V10.0001H22.85V21.3658L14.8388 10.6601Z' fill='white'/%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "dev-1656877137694-34571929023079": { + "spec": "ft-1.0.0", + "name": "Stader and Near", + "symbol": "NEARX", + "icon": null, + "reference": "https://nearX.app", + "reference_hash": null, + "decimals": 24 + }, + "xcorn.corndao.testnet": { + "spec": "ft-1.0.0", + "name": "Staked CORN", + "symbol": "xCORN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "usdc.mocks.testnet": { + "spec": "ft-1.0.0", + "name": "USD Coin", + "symbol": "USDC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "dev-1647826409169-57002928574824": { + "spec": "ft-1.0.0", + "name": "VITAMIN C", + "symbol": "VCT", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "trc_contract.admin.tracer.testnet": { + "spec": "ft-1.0.0", + "name": "Tracer Utility Token", + "symbol": "TRC", + "icon": "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1514.28 1514.28'%3E%3Cdefs%3E%3ClinearGradient id='d' x1='102.19' y1='379.01' x2='1412.09' y2='1135.28' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%23c922ee'/%3E%3Cstop offset='.08' stop-color='%23bf20e9'/%3E%3Cstop offset='.2' stop-color='%23a61bdd'/%3E%3Cstop offset='.37' stop-color='%237c14ca'/%3E%3Cstop offset='.56' stop-color='%23430aaf'/%3E%3Cstop offset='.57' stop-color='%23400aae'/%3E%3Cstop offset='.87' stop-color='%239a1dd9'/%3E%3Cstop offset='.99' stop-color='%23b824e7'/%3E%3C/linearGradient%3E%3ClinearGradient id='e' x1='274.03' y1='1240.25' x2='1240.25' y2='274.03' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%232e048e'/%3E%3Cstop offset='.15' stop-color='%23280497'/%3E%3Cstop offset='.24' stop-color='%232404a0'/%3E%3Cstop offset='.45' stop-color='%233507a8'/%3E%3Cstop offset='.57' stop-color='%23400aae'/%3E%3Cstop offset='.87' stop-color='%239a1dd9'/%3E%3Cstop offset='.99' stop-color='%23b824e7'/%3E%3C/linearGradient%3E%3Cfilter id='f' filterUnits='userSpaceOnUse'%3E%3CfeOffset dx='7' dy='7'/%3E%3CfeGaussianBlur result='g' stdDeviation='5'/%3E%3CfeFlood flood-color='%23000' flood-opacity='.75'/%3E%3CfeComposite in2='g' operator='in'/%3E%3CfeComposite in='SourceGraphic'/%3E%3C/filter%3E%3Cstyle%3E.i%7Bstroke:%23140a96;stroke-miterlimit:10;fill:%23c821ed;stroke-width:4px%7D%3C/style%3E%3C/defs%3E%3Cg id='b'%3E%3Cg id='c'%3E%3Ccircle cx='757.14' cy='757.14' r='756.14' style='fill:url(%23d);stroke-width:2px;stroke:%23140a96;stroke-miterlimit:10'/%3E%3Ccircle cx='757.14' cy='757.14' r='683.22' style='stroke-width:2px;stroke:%23140a96;stroke-miterlimit:10;fill:url(%23e)'/%3E%3Ccircle class='i' cx='757.14' cy='757.14' r='614.9'/%3E%3Ccircle class='i' cx='757.14' cy='757.14' r='572.47'/%3E%3Cpath d='M1230.91 757.14c-373.28 55.5-418.27 100.5-473.77 473.77-55.5-373.28-100.5-418.27-473.77-473.77 373.28-55.5 418.27-100.5 473.77-473.77 55.5 373.28 100.5 418.27 473.77 473.77Z' style='fill:%23fff;filter:url(%23f)'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "usdtt.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Tether USD", + "symbol": "USDt", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "test4.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Meme Coin", + "symbol": "testNear", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "nusdt.ft-fin.testnet": { + "spec": "ft-1.0.0", + "name": "NEAR Wrapped Tether", + "symbol": "nUSDT", + "icon": "https://s2.coinmarketcap.com/static/img/coins/64x64/825.png", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "token-v3.cheddar.testnet": { + "spec": "ft-1.0.0", + "name": "Cheddar", + "symbol": "Cheddar", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "uxuu.leopollum.testnet": { + "spec": "ft-1.0.0", + "name": "Fluxus", + "symbol": "UXU", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "minimous35.testnet": { + "spec": "ft-1.0.0", + "name": "Banana Coin", + "symbol": "Banana", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1656503291173-39720893370899": { + "spec": "ft-1.0.0", + "name": "AppTestnet IDEA Token", + "symbol": "IDEA", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "tayadeamit1009.testnet": { + "spec": "ft-1.0.0", + "name": "DOJOTestCoin", + "symbol": "DOJOTWO", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "contract.gematest.testnet": { + "spec": "ft-1.0.0", + "name": "GEMATESTTOKENS", + "symbol": "GEM-T1", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "mak.zeiris-test.testnet": { + "spec": "ft-1.0.0", + "name": "MAK", + "symbol": "MAK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "usdt.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Tether USD", + "symbol": "USDT.e", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "token2.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Huong Token Name", + "symbol": "Huong", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dev-1652197859279-96214400725752": { + "spec": "ft-1.0.0", + "name": "Eternal Lands Gold Token", + "symbol": "elGOLD", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "yet.171factory.gadillac.testnet": "", + "ft-final.nekocoin.testnet": { + "spec": "ft-1.0.0", + "name": "NEKO", + "symbol": "NEKO", + "icon": " AAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAABmJLR0QA/wD/AP+gvaeTAAAA CXBIWXMAAC4jAAAuIwF4pT92AAAAB3RJTUUH5gQVFS8KdqrjugAAE7dJREFUaN6dmnmQ3dV15z/3 /ra3d79e1K9b3Y260S7UsiQQmHWMsCFgwQQnMF7whLKcOA5xypSNpybBxGUnM2GSEkk5M2Q8NeUI TBJXGAw4GCwEBkuAkNECtNBGa+n99fr6rb/l3ps/XqtRG+HB/lXdrnqvfv1+n3Peued8z7lP8Gtc n7th7aLXRutYpKKVRpsrpJSXW7a9znGcTttxG6VlxQC00n4URTNhEAwppfu1YZ8QvGZb4rgQ1M7/ vEefP/KhWcSvC2y0Rhu9VCt9o+04t6UbspvbOrrbOro67VxHF9nWDpKpNI7jAZqwOkZ5cj8zY28w Nl5jZCyMxieifLGofxFF5ikpeVZIMSzPI/kwBvxK8EXAxmC07tBa3xVPJO/q6lm+Zv2lV8rVa1fS mhkkJs4gpQG3BxFbASbC1I5C9SCEeTAh2kCtZshPRhw76fPWkaoZHArfqdb0TinFI0IwIj6kAeLD QCOEE4XB7a4Xu2/56ks2Xb31ZtZsuIxk0oWZH2BKezAmQkWaINQEkYNSCmECbFviug6OY2FZ5z/O UK5o3jnus3dfmXcH/IN+YB60bfH/gOD/By9+FbQxBmNMzhh9f1t7190fu/m341uuuYFkugHULHr2 3yiO/JiR0VmGhuaYmixTrfjoSCEwSCGQlsTxHJLpGC2tKTo6MixpTRKPO2AAUTdg/4EqL+4pVcfz 4feFEN8WgtFz3r8QvPhgaI3RZq20rL9b+5HLtt76n+6mu2cFqClU6QCjJ5/j7YOvcfrUJEQRLRmX tmaPbMYjEbOwpQCtiUJFrRpRLIXMliIKPlgJj86eZlasaKGxIUbdAsPQSMRTzxU5crT2gtZ8RQj6 PwhefBC01maT47jfu/JjN27adufdpDMupvgyk2ee5fW9r3Py5DjNaY81FzfS2Z4mmXSRlgUCjKkv bcBog1YGHURE1YDaXI3ZmRqjswElIele0czaNa3EYzZgKFXg354v88rr5YNhxHYpOHAhePF+aIPR eq3tuI/8h9+6bdMn7/g9Yo5PNPkD+vf/mD173iXmWFzW18ZFnWlcx677y5j5/1+8tAFjxPw9oCND VA0IZqvMTdcYnqkRJW02bM7R3pZCYAgiwTMvVvnZ3srBKDJ3Xcjz1jnwvt7Wc+A5adnfu2rrzVfd 9pkvEnMq1Ea/z8s//SGvvHKG1T1Zrr+yi9ySJELUgd7bbu8HN0Ysfo1AOjZ20sONu6SkDWXNiYEZ jG3INnpYQtPb7VCpifbBkXC1MewSghLAmwMT74Gfl0EcrfV/W79hxZ133HUnSess1bHH2P3Mj+h/ e5zrtnSweX0brisvuNPrYO8ZoH8Zet5KraHia+Z8Q2BJXGGTjGzODhYJULQ0edhCc1GXw/iU6RnP q4SU7AJUX28rbw5MYJ//UKXMp3Jt7t3bbqiR8v+BYK7Eyy8c49jRCa7d0snS9gyD4zWCUNPU4NCU cRDi/JA437OLjTj3Xs3XvHF0jr1vVZkqxVEqpLvJ57reFLlYA2f7S1gWrOxtIGErbr7OJT8R3T2a j35uSfFP50LGei+26XBd+fe3fDzT1bfOweiAAweH2bdvkC0b2kkkEzz+wiRP7DG8fjLFnsNlxvIF upa4JGP2+8AXeXveAD/QPPXzKfae6mH5xt9h06Wf4KqP38HZqRh79h9gZYtHox1nZKxMosGQTtik YxrLtuwTp/XFSvFjISj29bZi9fW2og1obf5o9Qrvc9tuzOA4kpGROZ597jirerLkco3836enCBtv 5t4/3cFtd3yBjR/dxqmJDE/vOszS5oDWRg+tPyCu59cLv5jhWPEyNq6+muDxZ1jz+D8ze/woV/3h l3lnsMj4wDssX5LCUi6j0yWW5GwcS9DSYBgcM7n8tJlEsEcI5sG1WRqPy7/edlOmtbvLJfAVu54/ iQ4jrrx0KS8dKDAcXsHfPPQ/GTp0kEN/+RfMvHuSm7Z/kRXrt/JPT7xKW3qW5kYPrS8c12dGK+w9 fTHrV13H4Hcf5TMDR7iiUqBrcJB9o6Os/uxdPPeTZ+lrj+FIB79sUaXCkhYH1zLY0nDsNB2R4kkp mJPzm+Wm7k5nzarlLkZpBgamOHN6mkvXL8GxLQ4cD/nUnf+Z46/vY/gLX+Q/PvkkV3/3u7z06U+T TSe55788zE/f6mR8yl/YLwvxAWhtOHTKY8vVd3D2X3dxzeQ4y3WZUAgywLJXXiEWhrhNXUzPRSgt 8ESc8VMWM7M1tFKs6NR0tZnVWvNbAFJrYrYtbutbGxMJzxD4IYffHKU549LTlcEPNOXAo7Orizef eJrG2ZCYkHQIwa379nHg859H6og7f/9B9h7LMlfyKRR98tM1hvIVhsYrnDxbpKnn48jBGRJHBviI KiDnrTJC0F4qEY0M09TezXQpQiuJ1hJRTXHmdIhWmrijWLvMCNvmVm2I20qbVU1Ze/PKXhe0ZiJf YmiowEfXtxKLOehCDYSFEDA2OUdOukht0EBaCG4+dIifbN/OFY/+gI03fIMDb/wjXjxDJYwRRBY1 P2C2MIdx4cxLz9ISFTBRBTGfHgyQApicpKGphcqUQWuJUmBpj5FBi+U9AcmYxcUdmkzC2TxTFKts Y7gi12ovacmCVorTZ2YR2tDVnl6orUIIjDFUQ40vrYWiY4CMEHxi3z5e+ON7uH7nI2zech227SAt CykEBoOKFKVykdFPj3Lw1Vf5Xzt3snnPHm7WGlcIPEDOzBBPJwmVqHtcgdaC8kyc/ESBZUsFTSlD a6PdOj0nPiql4PKOnG27lib0IwaH52hOu2Qy3kIZl/PeEcYwJ13UeRJHA83AktdfZ2JkmEQijuva 2JZASrCkwHVtmrJZ1q1dy+e+8AXufeIJTt1/P3+bTlMwhhhgT00hpQVGolR9aS2JfI/RsbpTXUuR yypbCC6Xti3WtbVIhFFUqwHT01VaGmPYTl0NCAFSCixpYVsWU9KjJJ0FdGkM7zoO1S99id41a/gw V2tTE/c+8AC5B/87f5VJMQskp6fRUYglLJQSaC1QSmCUzeSkRRhECKNpbYiwLdZJxxadjWmBUYpy KaBWi2hMekgp58EFFgqhAlzHoSBdzth1MSSMYdDzOHPffVx3//3EXPdDgQNYQnD3HdvY9OU7+ZtE jKhQQFcrOMJG6brHjRGAoFy0qfkKozUNcYVtmU5pOyIb9wxoTaUaopUh7tkL8tS2JLb2YXyARCZF ZOCwm6VqJPlkkvyf/zlXf/ObJGOx+dSnyefzzM7O/krwt/v7+d7D/xvPgtbbr+eHYYCMIlzbPq+Q 1Vfg2/g1DbqeXWyLRmlJPFtqjFKEQYQxYM1vQGMgGZM0ZmD8yEE+cuUl+GmPU8Zlf+dK/P/xIBu/ /vUFT09OTvK1r32NG264ga9+9avs3r0brfX7oHft2sUnb7mF7/zDTvrdblpWXkKYy/B2/1skHHfB 08YIlDFoJQnDOqMlNJYwnjxXMYzWmPmHaPWeta4juWZTgp/seZFNq3J8csd/Ze29v0fnP/8jPX/4 ZVxrQRnz0EMPsWPHDlatWsW3vvUtoiji6NGji6BrtRoPPfQQZ86c4Z577uHPvvlNrvrU57lsVQ+z I4PzGeyc3jHz3hcYXWdknlEqjR9G9bGDLevpLwjMArw2sLYnSY0JJo4dZusVvXzm3rtYuWX9ovap VCqxe/duAK699lq6u7vp6+tjbGxsEXi1WmVkZITe3l6SySRhGFKqVOle0szFnW3kizXE/CcrDZE2 SGmw0BilCUNQGl9GkZmp+vW6H3PqKaxUVqjILIRLGBmSXoykLWDgMEyPgbAXAVmWRXNzMw888ADJ ZJLHHnuMhx9+mCiKFt2XyjRw7XXXsXPnTpLJJDfedBP3feWP6MnGubgzx3ixyrkCEum6x21b4UgN 2lDxIdJiVoahGZqdq38NcVfguZJCMSSomveUHpCMeSQSSVh7LfR8BGxnEVA8Hmf79u1s3bqVkZER PvvZz7J//342b9pEeXCQ2f2vMPf6ywRHD7P9t29jemqK559/nlOnTvG7t97CuhW9NKeTlIJoQV0G kUYbiHkBrmUwylAoW0RKDNmRon98ymzRGjwHGtM204UahYmI5rhbj7GaQIQRVd+n4byY/uVr27Zt 9Pf3k0gk2LFjB79zxx1EJ07ws+98m0tSeZoTGp3wWJbNku27nZV/dj/JVJKluTZ4cxeWWNwl+ZHC YGhI13CEQUUwOWcTadFva232jeTVXX6I7QhDR7PH4XyV0VMBpWmBiqBaMkRzVU4MDpEbH4Dmrnpl Ou8K/BoIQV9fH319fQvvH3vhRQpnh5jtlLQnNNI1CDWMyp+gc9X2hft0Ist0qYJnW4AgUIpQGZAR rdkawhj8QDBWcCJj2CeF4LXxCZWfLAgwms5WFy0jpko1ipOG0jREgaQlbrHvyAkYPgH50+/ztpCS /MgglVJxQSoAdFxzDS0bNnBizHBsVFMe86nOpHA2f2LB4JnpScanJhmcmKEh5mIMVEOF0hCPV1jS EIAyTJUsJkv2hBC8am3oXVIIQ65uaTCrupsDPEcwMuUzW9RkvQaMrmsG17I4eGaKdcsuIitqkG0H L7Foczqux9T4MHOFGYQAL5bAa2yg7bLLsDKNFGQjalkfDb/7ByQuvZbpyXEKM5NIIRDTYzzywx+x OpvGtSzmagGRNnR1TbC8rQYa3hpO8s548iXgYVtKaqEyT/a/az656SIj4q5hTVeMFydLzNVqpOwU SoNnOTS7VR7f+wZfzzXD2z+DvushmX1vgyaSdPWuQkUhQeBjjEEIQaqri/Vf+oN6HhZiQW0mUmka m5dgCcPLT75FpVQhu6yNoh8SaXC8Khd3FJEaqoHgWD5hIi2esqWpSgApeG4oL945MSQxWnFRq0Ou STBcmSSM6pVLKcnylgyH+t/hxbdOQmEcDu+GQn4BXEURE2NDTOZHcR0PUast7DZTLmMGBhBK1UNL KfADRgYHCI6/wb8+81N6GlP10UWo0MawtGOSJckIowwDkzGGC95RIfgJzPecAuaCSGb8gBtWL/WJ 2ZqkJzk2VgIdIy6SaC2whE3Skjx94Dg9HTk6UjZMDoLtQipLqVQCDI3ZFmzXRY+Ook+cgMlJzMgI wnHQAwMwM4MeHsFtbSFRzvPMY9/nR7tf46ruHKUgIlKQSM+yZXWepIBqINl9spl82d1hCfPMQrMs 6tJgYK5qXZ+OqfbOpoCUJ9BG8+5EkRhpbBNDa0HKdbGN4l9efRvb9VjZmsGaHYG5SbxUhnhTG5ZT 1y6ioQERj4NlI3t6kB3tiHQaMFhNKRg/xp6nH+evHnmSLbkmPNvGDzXCqbJh9RBdqQij4PBohjdG MocM4htSUASw3hyYODd+KyotCtNF65aLWnwnHVO0pOqbZKhQIU4DlnExQDbu0exZPPvGEfYeP4sw hkZdI1kYgdlR8MugItAK4bmIVByhAihOIcp5xOwZ8of38n8e/Rf+/vFdbGxpoDWVoBoqjAxZsXyQ 9W0VRARjRY9dA621km/fJ6V5RVCfHwpYPIJTWjy0uqP25dsvnSHpKSo1w8+P1xidSNEue/FIYDAI 6jri9HSR41MllOPS25ljQ28nqzrbyLU0kcmkcVxvPu35FObmODUyziv977LnrRNIP2BzRyuebeFH GiMDli0bYstFBdwIyqHk6RM5jk+nHpbC/AnzA/8F8PPhjSEnBI9euqy89cZLZnEtQ8U3vHbK5+x4 nFaxjASZBT0hqGeIuVrAcKHMSLFKIVQYaeG4No5t18t3GFHzA4RStMY8eprSpD0PP1JE2oBT4eKe YTa2F3EVBJFg95lWDow3vmAMnxOC0XPQAIuVUp1lTBv+5MCZ5E5H6k0fW1Ugbhuu6nFp8GocGTlO JeygUbRh46DnW+d0zGVNzGNNmyDSGj9U+JEiUBpjBLYUOPMNdKQ1tUhRDhQaRSw9zbreMVY2+Fgh +JHg58PNHMo3HNRGfEUIM/rLmAvC41ysz38FE9qIX4wW3MvKvmxfmvGJ24olKYuWpGZGzTLhz6G1 xDIOwlgLwkgbwAgsKXEsC9eysKRAmbr2qIYKP9JERiG8OZZ2DbNl+QTdsRARQjmw+NngEg7kGw9G Wn5RCHP4XFhccLB/gZDBwFop+LvlLdWt1y+fIZf2wUCIYcyPODYmmJhOoKqNWFEaS3sIU+/U9blG YH7V7VEYGeAmSrS1FFjeVibnRlhB/eRivBLjpeFW3i2kXpj3dP+FoC8Ivgi+/ienEfe3JMK7L+8q xC9pK5KwFdIxGMcw4xuGCjA2IykUXWo1DxW6GG2DmR9R2BGxWEhDyqet0SeXjGgQBunXpWolsuif bmB/vqk6XfO+LzDfRjD6QdAfCP5LmeZctrndsfQ3uhtqGze2z9HbWCZuK6QF0gbjGCIbagqqIUT1 AoltQcwGVxvswIBvMEF9nliNLE7NJTk0lWWwlDgYavmgJcxvflx4Ifh6NyQ6tOGumK0/n0v5a1Zk S6KnoULWC/AshRODeIvAcuvxLgCtDLUpTTCnURH4SjLju5wuJjlZSJuxSvwdX8tHBDwihBk+H+g3 OqD9QAPq5zhLteEmS5pbk47a3BwL2lrjvt0c82lpUWSyGlsahIBKwTCbFxRDh6maS74ai6Z9N1+O 7F8oLZ6SgmcFZvjDnij/WuAfED4YQ0wZsdIgrhCYyy1p1tnSdNqWyVrCeABKCT/SYjYyYlAZccQY 8ZoQZp8lzDHBb/4jhH8HsQSGthsv6IwAAAAldEVYdGRhdGU6Y3JlYXRlADIwMjItMDQtMjFUMjE6 NDc6MDgrMDA6MDDs4phyAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDIyLTA0LTIxVDIxOjQ3OjA5KzAw OjAwO8gregAAAABJRU5ErkJggg=='/%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "usdt.mocks.testnet": { + "spec": "ft-1.0.0", + "name": "Tether USD", + "symbol": "USDT.e", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token11.duyhuongtest.testnet": { + "spec": "ft-1.0.0", + "name": "Huong2 Token Name", + "symbol": "Huong8", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "corn.wanwan.csdev.testnet": { + "spec": "ft-1.0.0", + "name": "Cornerstone", + "symbol": "CORN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "dev-1652660333908-53333239111308": { + "spec": "ft-1.0.0", + "name": "MFOX", + "symbol": "MFOX", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "light_token.testnet": { + "spec": "ft-1.0.0", + "name": "Light", + "symbol": "Light", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "paras.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "PARAS", + "symbol": "PARAS", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "oct.fakes.testnet": { + "spec": "ft-1.0.0", + "name": "Octopus Network Token", + "symbol": "OCT", + "icon": "data:image/svg+xml,%3Csvg version='1.1' id='O' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 113.39 113.39' style='enable-background:new 0 0 113.39 113.39;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23014299;%7D .st1%7Bfill:%23FFFFFF;%7D %3C/style%3E%3Ccircle class='st0' cx='56.69' cy='56.69' r='56.69'/%3E%3Cg%3E%3Cpath class='st1' d='M44.25,59.41c-1.43,0-2.59,1.16-2.59,2.59v20.28c0,1.43,1.16,2.59,2.59,2.59c1.43,0,2.59-1.16,2.59-2.59V62 C46.84,60.57,45.68,59.41,44.25,59.41z'/%3E%3Cpath class='st1' d='M56.69,59.41c-1.45,0-2.62,1.17-2.62,2.62v26.47c0,1.45,1.17,2.62,2.62,2.62s2.62-1.17,2.62-2.62V62.02 C59.31,60.58,58.14,59.41,56.69,59.41z'/%3E%3Cpath class='st1' d='M79.26,78.87c-0.33,0.15-0.64,0.28-0.95,0.38c0,0-0.01,0-0.01,0c-0.59,0.19-1.13,0.29-1.63,0.31h-0.06 c-1,0.03-1.84-0.27-2.59-0.75c-0.49-0.32-0.91-0.73-1.25-1.23c-0.3-0.43-0.53-0.93-0.71-1.51c0-0.01-0.01-0.02-0.01-0.03 c-0.22-0.74-0.34-1.61-0.34-2.59V62.02c0-1.45-1.17-2.62-2.62-2.62c-1.45,0-2.62,1.17-2.62,2.62v11.43c0,4.5,1.64,8.03,4.63,9.96 c1.5,0.97,3.21,1.45,5.04,1.45c1.68,0,3.45-0.41,5.25-1.22c1.32-0.59,1.9-2.14,1.31-3.46C82.13,78.86,80.57,78.27,79.26,78.87z'/%3E%3Cpath class='st1' d='M68.33,45.9c0-2.15-1.75-3.9-3.9-3.9c-2.15,0-3.9,1.75-3.9,3.9s1.75,3.9,3.9,3.9 C66.58,49.8,68.33,48.05,68.33,45.9z'/%3E%3Cpath class='st1' d='M48.96,41.99c-2.15,0-3.9,1.75-3.9,3.9s1.75,3.9,3.9,3.9s3.9-1.75,3.9-3.9S51.11,41.99,48.96,41.99z'/%3E%3Cpath class='st1' d='M56.69,22.28c-15.17,0-27.52,12.34-27.52,27.52v15.09c0,1.46,1.18,2.64,2.64,2.64s2.64-1.18,2.64-2.64V49.8 c0-12.26,9.98-22.24,22.24-22.24c12.26,0,22.24,9.98,22.24,22.24v15.09c0,1.46,1.18,2.64,2.64,2.64s2.64-1.18,2.64-2.64V49.8 C84.21,34.62,71.87,22.28,56.69,22.28z'/%3E%3C/g%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "corn.ver_1.csdev.testnet": { + "spec": "ft-1.0.0", + "name": "Cornerstone", + "symbol": "CORN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "wnear.qa.v1.nearlend.testnet": { + "spec": "ft-1.0.0", + "name": "Wrapped Near", + "symbol": "WNEAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + } + } \ No newline at end of file diff --git a/src/chains/near/near_tokens.json b/src/chains/near/near_tokens.json new file mode 100644 index 0000000000..1b5625034e --- /dev/null +++ b/src/chains/near/near_tokens.json @@ -0,0 +1,2018 @@ +{ + "1ab43204a195a0fd37edec621482afd3792ef90b.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Aurigami Token", + "symbol": "PLY", + "icon": "data:image/svg+xml,%3Csvg id='Layer_1' data-name='Layer 1' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1473.23 1500'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill:%2322bf5a;%7D.cls-2%7Bfill:%238cdea6;%7D%3C/style%3E%3C/defs%3E%3Cpath class='cls-1' d='M36.89,883.14,1435.12,3.9c19.28-12.13,43.36,5.95,37.1,27.85L1057.6,1482a24.84,24.84,0,0,1-36.35,14.65l-983.6-571A24.84,24.84,0,0,1,36.89,883.14Z'/%3E%3Cpath class='cls-2' d='M8.83,887.27c14.74,6.42,28.06-4.13,28.06-4.13l480-301.85L318.16,199.39c-9.81-18.84-37.21-17.47-45.09,2.25L4.2,874.22S.69,883.73,8.83,887.27Z'/%3E%3Cpath class='cls-1' d='M516.93,581.29l-480,301.85s-13.32,10.55-28.06,4.13c-8.14-3.54-4.63-13-4.63-13l-2.42,6.06A24.83,24.83,0,0,0,12.37,911l968.89,562.43Z'/%3E%3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "ft.metafoxonry.near": { + "spec": "ft-1.0.0", + "name": "MFOX", + "symbol": "MFOX", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "501ace9c35e60f03a2af4d484f49f9b1efde9f40.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "solace", + "symbol": "SOLACE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "hbsc.tkn.near": { + "spec": "ft-1.0.0", + "name": "HIBISCUS COIN", + "symbol": "HBSC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "whales.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEAR WHALES", + "symbol": "WHALES", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 4 + }, + "4691937a7508860f876c9c0a2a617e7d9e945d4b.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Wootrade Network", + "symbol": "WOO", + "icon": "", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "ust.token.a11bd.near": { + "spec": "ft-1.0.0", + "name": "TerraUSD", + "symbol": "UST", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "deip-token.near": { + "spec": "ft-1.0.0", + "name": "DEIP Token", + "symbol": "DEIP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "panda.tkn.near": { + "spec": "ft-1.0.0", + "name": "Panda Token", + "symbol": "PANDA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "magic.tkn.near": { + "spec": "ft-1.0.0", + "name": "Magic Token", + "symbol": "MAGIC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token.skyward.near": { + "spec": "ft-1.0.0", + "name": "Skyward Finance Token", + "symbol": "SKYWARD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ruct.tkn.near": { + "spec": "ft-1.0.0", + "name": "RUCT", + "symbol": "RUCT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "2260fac5e5542a773aa44fbcfedf7c193bc2c599.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Wrapped BTC", + "symbol": "WBTC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "cointiva.tamada.near": { + "spec": "ft-1.0.0", + "name": "Cointiva", + "symbol": "CTNEAR", + "icon": "data:image/svg+xml;base64, PHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCINCgkgdmlld0JveD0iMCAwIDI5MS43NjQgMjkxLjc2NCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMjkxLjc2NCAyOTEuNzY0OyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+DQo8Zz4NCgk8cGF0aCBzdHlsZT0iZmlsbDojRUZDNzVFOyIgZD0iTTE0NS44ODIsMGM4MC41NzMsMCwxNDUuODgyLDY1LjMxOSwxNDUuODgyLDE0NS44ODJzLTY1LjMxLDE0NS44ODItMTQ1Ljg4MiwxNDUuODgyDQoJCVMwLDIyNi40NDYsMCwxNDUuODgyUzY1LjMxLDAsMTQ1Ljg4MiwweiIvPg0KCTxwYXRoIHN0eWxlPSJmaWxsOiNDQzk5MzM7IiBkPSJNMTQ1Ljg4MiwyNy4zNTNjLTY1LjQ2NSwwLTExOC41MjksNTMuMDY1LTExOC41MjksMTE4LjUyOXM1My4wNjUsMTE4LjUyOSwxMTguNTI5LDExOC41MjkNCgkJczExOC41MjktNTMuMDY1LDExOC41MjktMTE4LjUyOVMyMTEuMzQ3LDI3LjM1MywxNDUuODgyLDI3LjM1M3ogTTE0NS44ODIsMjQ2LjE3NmMtNTUuMzksMC0xMDAuMjk0LTQ0LjkwNC0xMDAuMjk0LTEwMC4yOTQNCgkJUzkwLjQ5Myw0NS41ODgsMTQ1Ljg4Miw0NS41ODhzMTAwLjI5NCw0NC45MDQsMTAwLjI5NCwxMDAuMjk0UzIwMS4yODEsMjQ2LjE3NiwxNDUuODgyLDI0Ni4xNzZ6IE0xNTguMDA5LDEzOC4yNjkNCgkJYy01LjQ1Mi0yLjI4OS0yNS40OTMtNS40NTItMjUuNDkzLTE0LjIxNGMwLTYuNDY0LDcuNDk1LTguMzM0LDExLjk5LTguMzM0YzQuMDk0LDAsOC45OTksMS4yOTUsMTEuNTg5LDMuODc1DQoJCWMxLjY0MSwxLjU3NywyLjMxNiwyLjcyNiwyLjg1NCw0LjMxM2MwLjY4NCwxLjg2OSwxLjA5NCwzLjg3NSwzLjY4NCwzLjg3NWgxMy4zNTdjMy4xMzYsMCwzLjk1Ny0wLjU3NCwzLjk1Ny00LjAyMQ0KCQljMC0xNC43ODktMTEuNTg5LTIzLjEyMi0yNC44MDktMjUuOTk0Vjg2LjI4YzAtMi41OC0wLjgyMS00LjE2Ny0zLjk1Ny00LjE2N2gtMTAuNjRjLTMuMTM2LDAtMy45NTcsMS41NzctMy45NTcsNC4xNjd2MTEuMDUxDQoJCWMtMTQuMTc4LDIuNzI2LTI2LjAzMSwxMS42MzQtMjYuMDMxLDI3LjcxOGMwLDE4LjIzNSwxMi42ODMsMjMuOTc5LDI2LjQ0MSwyOC41NjZjMTEuNTg5LDMuODg0LDIzLjcyNCw0LjAyMSwyMy43MjQsMTIuMDYzDQoJCXMtNS45OSw5Ljc2NS0xMy4zNTcsOS43NjVjLTUuMDUxLDAtMTAuNjMxLTEuMzA0LTEzLjM2Ni00Ljc0MWMtMS43NjktMi4xNTItMi40NTMtNC4wMjEtMi41OC01Ljg5DQoJCWMtMC4yNzQtMy41OTItMS43NjktNC4wMjEtNC45MTQtNC4wMjFIMTEzLjI4Yy0zLjEzNiwwLTMuOTU3LDAuNzI5LTMuOTU3LDQuMDIxYzAsMTYuMzY2LDEzLjA5MywyNi4yODYsMjcuMjYyLDI5LjQ0MXYxMS4yMDYNCgkJYzAsMi41OCwwLjgyMSw0LjE2NywzLjk1Nyw0LjE2N2gxMC42NGMzLjEzNiwwLDMuOTU3LTEuNTg2LDMuOTU3LTQuMTY3di0xMC45MDVjMTYuMDg0LTIuNDUzLDI3LjEyNS0xMi4yMDksMjcuMTI1LTI5LjQ0MQ0KCQlDMTgyLjI4LDE0NS41OTEsMTY3LjgyOSwxNDEuNDI0LDE1OC4wMDksMTM4LjI2OXoiLz4NCjwvZz4NCjwvc3ZnPg0K", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "azerotha.near": { + "spec": "ft-1.0.0", + "name": "Flora", + "symbol": "FLA", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "v3.oin_finance.near": { + "spec": "ft-1.0.0", + "name": "nUSDO", + "symbol": "nUSDO", + "icon": "", + "reference": "", + "reference_hash": "", + "decimals": 8 + }, + "30d20208d987713f46dfd34ef128bb16c404d10f.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Stader", + "symbol": "SD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "runaid.near": { + "spec": "ft-1.0.0", + "name": "Literal Scam Token", + "symbol": "LST", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 9 + }, + "nvision.tkn.near": { + "spec": "ft-1.0.0", + "name": "NVISION", + "symbol": "NVISION", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "newfy-token.near": { + "spec": "ft-1.0.0", + "name": "NEWFY", + "symbol": "NEWFY", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "meritocracy.tkn.near": { + "spec": "ft-1.0.0", + "name": "MERITOCRACY", + "symbol": "MERITOCRACY", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "kvlad.tkn.near": { + "spec": "ft-1.0.0", + "name": "KryptoVlada", + "symbol": "KVLAD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "swear.tkn.near": { + "spec": "ft-1.0.0", + "name": "SWEAR", + "symbol": "SWEAR", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "metrop.near": { + "spec": "ft-1.0.0", + "name": "METROP", + "symbol": "METROP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "testing-stuff.staderlabs-test.near": { + "spec": "ft-1.0.0", + "name": "NearX", + "symbol": "NearX", + "icon": "", + "reference": "", + "reference_hash": "", + "decimals": 6 + }, + "nearpunk.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEARPUNK", + "symbol": "NEARPUNK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "flct.tkn.near": { + "spec": "ft-1.0.0", + "name": "Falcon Token", + "symbol": "FLCT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "0d8775f648430679a709e98d2b0cb6250d2887ef.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Basic Attention Token", + "symbol": "BAT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "wafi.tkn.near": { + "spec": "ft-1.0.0", + "name": "Water & Fire Token", + "symbol": "WAFI", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "ft.nekotoken.near": { + "spec": "ft-1.0.0", + "name": "NEKO(OLD)", + "symbol": "NEKO(OLD)", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "ctzn.tkn.near": { + "spec": "ft-1.0.0", + "name": "Citizen Token", + "symbol": "CTZN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "bones.tkn.near": { + "spec": "ft-1.0.0", + "name": "Chicken Bones", + "symbol": "bones", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "gear.enleap.near": { + "spec": "ft-1.0.0", + "name": "GEAR", + "symbol": "GEAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "gachi.tkn.near": { + "spec": "ft-1.0.0", + "name": "gachinuchi", + "symbol": "GACHI", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nativo-token.near": { + "spec": "ft-1.0.0", + "name": "Nativo Token", + "symbol": "$NTV", + "icon": "", + "reference": "https://nativonft.app", + "reference_hash": null, + "decimals": 24 + }, + "elixir.l2e.near": { + "spec": "ft-1.0.0", + "name": "LandtoEmpire.com game ELIXIR!", + "symbol": "ELIXIR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "linear-protocol.near": { + "spec": "ft-1.0.0", + "name": "LiNEAR", + "symbol": "LINEAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "pw.tkn.near": { + "spec": "ft-1.0.0", + "name": "Portis Wallet Token", + "symbol": "PW", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "1f9840a85d5af5bf1d1762f925bdaddc4201f984.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Uniswap", + "symbol": "UNI", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "hooba.tkn.near": { + "spec": "ft-1.0.0", + "name": "HOOBA", + "symbol": "HOOBA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "a4ef4b0b23c1fc81d3f9ecf93510e64f58a4a016.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "1MILNFT", + "symbol": "1MIL", + "icon": "data:image/svg+xml,%3Csvg version='1.1' id='O' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 146 146' xml:space='preserve'%3E %3Cpath style='fill:%23ff00c6; stroke:none;' d='M0 0L0 31L31 31L31 0L0 0z'/%3E %3Cpath style='fill:%23df01ae; stroke:none;' d='M31 0L31 31L32 31L31 0z'/%3E %3Cpath style='fill:%23000000; stroke:none;' d='M32 0L32 32L0 32L0 38L32 38L32 70L0 70L0 76L32 76L32 109L0 109L0 114L32 114L32 146L38 146L38 114L70 114L70 146L76 146L76 114C82.7843 114 102.446 110.653 107.397 115.603C112.241 120.448 109 139.378 109 146L114 146L114 114L146 114L146 109C139.378 109 120.448 112.241 115.603 107.397C110.653 102.446 114 82.7843 114 76L146 76L146 70L114 70L114 38L146 38L146 32C139.378 32 120.448 35.2414 115.603 30.3966C110.759 25.5518 114 6.6225 114 0L109 0L109 32L76 32L76 0L71 0L71 32L38 32L38 0L32 0z'/%3E %3Cpath style='fill:%23459f00; stroke:none;' d='M38 0L38 32L70 32L70 31L39 31L38 0z'/%3E %3Cpath style='fill:%236fff00; stroke:none;' d='M39 0L39 31L70 31L70 0L39 0z'/%3E %3Cpath style='fill:%230d2000; stroke:none;' d='M70 0L70 32L71 32L70 0z'/%3E %3Cpath style='fill:%233f0180; stroke:none;' d='M76 0L76 32L108 32L108 31L77 31L76 0z'/%3E %3Cpath style='fill:%237f00ff; stroke:none;' d='M77 0L77 31L108 31L108 0L77 0z'/%3E %3Cpath style='fill:%232f0060; stroke:none;' d='M108 0L108 32L109 32L108 0z'/%3E %3Cpath style='fill:%231d4101; stroke:none;' d='M114 0L114 31L115 31L114 0z'/%3E %3Cpath style='fill:%236fff00; stroke:none;' d='M115 0L115 31L146 31L146 0L115 0z'/%3E %3Cpath style='fill:%239f017c; stroke:none;' d='M0 31L0 32L32 32L0 31z'/%3E %3Cpath style='fill:%23459f00; stroke:none;' d='M115 31L115 32L146 32L115 31z'/%3E %3Cpath style='fill:%2300f0ff; stroke:none;' d='M0 38L0 69L31 69L31 38L0 38z'/%3E %3Cpath style='fill:%2300d2df; stroke:none;' d='M31 38L31 69L0 69L0 70L32 70L31 38z'/%3E %3Cpath style='fill:%23be0094; stroke:none;' d='M38 38L38 70L39 70L38 38z'/%3E %3Cpath style='fill:%23ff00c6; stroke:none;' d='M39 38L39 69L70 69L70 38L39 38z'/%3E %3Cpath style='fill:%23200018; stroke:none;' d='M70 38L70 70L71 70L70 38z'/%3E %3Cpath style='fill:%23007880; stroke:none;' d='M76 38L76 70L77 70L76 38z'/%3E %3Cpath style='fill:%2300f0ff; stroke:none;' d='M77 38L77 69L108 69L108 38L77 38z'/%3E %3Cpath style='fill:%23015a60; stroke:none;' d='M108 38L108 70L109 70L108 38z'/%3E %3Cpath style='fill:%23400032; stroke:none;' d='M114 38L114 70L115 70L114 38z'/%3E %3Cpath style='fill:%23de00ad; stroke:none;' d='M115 38L115 39L146 39L115 38z'/%3E %3Cpath style='fill:%23ff00c6; stroke:none;' d='M115 39L115 70L146 70L146 39L115 39z'/%3E %3Cpath style='fill:%23df01ae; stroke:none;' d='M39 69L39 70L70 70L39 69z'/%3E %3Cpath style='fill:%2300d2df; stroke:none;' d='M77 69L77 70L108 70L77 69z'/%3E %3Cpath style='fill:%2354bf00; stroke:none;' d='M0 76L0 77L32 77L0 76z'/%3E %3Cpath style='fill:%235f00be; stroke:none;' d='M38 76L38 108L39 108L39 77L70 77L38 76z'/%3E %3Cpath style='fill:%230f001f; stroke:none;' d='M70 76L70 108L71 108L70 76z'/%3E %3Cpath style='fill:%23388000; stroke:none;' d='M76 76L76 108L77 108L76 76z'/%3E %3Cpath style='fill:%2354bf00; stroke:none;' d='M77 76L77 77L108 77L77 76z'/%3E %3Cpath style='fill:%232a6000; stroke:none;' d='M108 76L108 108L109 108L108 76z'/%3E %3Cpath style='fill:%23003d40; stroke:none;' d='M114 76L114 108L115 108L114 76z'/%3E %3Cpath style='fill:%2300b4bf; stroke:none;' d='M115 76L115 77L146 77L115 76z'/%3E %3Cpath style='fill:%236fff00; stroke:none;' d='M0 77L0 108L32 108L32 77L0 77z'/%3E %3Cpath style='fill:%237f00ff; stroke:none;' d='M39 77L39 108L70 108L70 77L39 77z'/%3E %3Cpath style='fill:%236fff00; stroke:none;' d='M77 77L77 108L108 108L108 77L77 77z'/%3E %3Cpath style='fill:%2300f0ff; stroke:none;' d='M115 77L115 108L146 108L146 77L115 77z'/%3E %3Cpath style='fill:%230f2000; stroke:none;' d='M0 108L0 109L32 109L0 108M76 108L76 109L108 109L76 108z'/%3E %3Cpath style='fill:%23001e20; stroke:none;' d='M115 108L115 109L146 109L115 108z'/%3E %3Cpath style='fill:%23810064; stroke:none;' d='M0 114L0 115L32 115L0 114z'/%3E %3Cpath style='fill:%23398000; stroke:none;' d='M38 114L38 115L70 115L38 114z'/%3E %3Cpath style='fill:%23800063; stroke:none;' d='M76 114L76 146L77 146L77 115L108 115L76 114z'/%3E %3Cpath style='fill:%23200041; stroke:none;' d='M114 114L114 146L115 146L114 114z'/%3E %3Cpath style='fill:%23410080; stroke:none;' d='M115 114L115 115L146 115L115 114z'/%3E %3Cpath style='fill:%23ff00c6; stroke:none;' d='M0 115L0 146L31 146L31 115L0 115z'/%3E %3Cpath style='fill:%23df01ae; stroke:none;' d='M31 115L31 146L32 146L31 115z'/%3E %3Cpath style='fill:%2354bf00; stroke:none;' d='M38 115L38 146L39 146L38 115z'/%3E %3Cpath style='fill:%236fff00; stroke:none;' d='M39 115L39 146L70 146L70 115L39 115z'/%3E %3Cpath style='fill:%23ff00c6; stroke:none;' d='M77 115L77 146L108 146L108 115L77 115z'/%3E %3Cpath style='fill:%2360004a; stroke:none;' d='M108 115L108 146L109 146L108 115z'/%3E %3Cpath style='fill:%237f00ff; stroke:none;' d='M115 115L115 146L146 146L146 115L115 115z'/%3E %3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "shmeks.tkn.near": { + "spec": "ft-1.0.0", + "name": "Schmeckels", + "symbol": "SHMEKS", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "uniqueone-appchain-token.near": { + "spec": "ft-1.0.0", + "name": "Unique One Network", + "symbol": "UNET", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "firerune.tkn.near": { + "spec": "ft-1.0.0", + "name": "FIRE RUNE", + "symbol": "FIRERUNE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 9 + }, + "pixiv.tkn.near": { + "spec": "ft-1.0.0", + "name": "pixi", + "symbol": "pixiv", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "gza.tkn.near": { + "spec": "ft-1.0.0", + "name": "Gazua", + "symbol": "GZA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "sol.token.a11bd.near": { + "spec": "ft-1.0.0", + "name": "Solana", + "symbol": "SOL", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "fud.tkn.near": { + "spec": "ft-1.0.0", + "name": "Fudlow", + "symbol": "FUD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "mbga.tkn.near": { + "spec": "ft-1.0.0", + "name": "Make Blockchain Great Again", + "symbol": "MBGA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "dcity.tkn.near": { + "spec": "ft-1.0.0", + "name": "Decentricity Social Token", + "symbol": "DCITY", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "hongdou.tkn.near": { + "spec": "ft-1.0.0", + "name": "hongdou", + "symbol": "hongdou", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ngmi.tkn.near": { + "spec": "ft-1.0.0", + "name": "N.G.M.I.", + "symbol": "NGMI", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "socialmeet.tkn.near": { + "spec": "ft-1.0.0", + "name": "SOCIALMEET", + "symbol": "SOCIALMEET", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nearkat.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEARKAT", + "symbol": "NEARKAT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token.jumbo_exchange.near": { + "spec": "ft-1.0.0", + "name": "Jumbo Exchange", + "symbol": "JUMBO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "06a00715e6f92210af9d7680b584931faf71a833.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Chronicle", + "symbol": "XNL", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "wst.tkn.near": { + "spec": "ft-1.0.0", + "name": "Wolves Token", + "symbol": "WST", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "avrit.near": { + "spec": "ft-1.0.0", + "name": "Avrit fungible token", + "symbol": "AVRIT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "kongztoken.near": { + "spec": "ft-1.0.0", + "name": "KONGZ", + "symbol": "KONGZ", + "icon": "https://i.ibb.co/H2jc1Bk/kongztoken.png", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "tipjargon.near": { + "spec": "ft-1.0.0", + "name": "Jargon", + "symbol": "JAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 7 + }, + "koro.tkn.near": { + "spec": "ft-1.0.0", + "name": "Korosenai Coin", + "symbol": "KORO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "288f5c0fc03d073378d004201129bc145a4a82fc.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "GREATWANGJING", + "symbol": "GWJ", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "zod.near": { + "spec": "ft-1.0.0", + "name": "Zod Fungible Token", + "symbol": "ZOD", + "icon": " W0tFKgp2EHXIUJ0sFBVx1CoUoUKoFVp1MLn0C5o0JCkujoJrwcGPxaqDi7OuDq6CIPgB4ubmpOgi Jf4vKbSI8eC4H+/uPe7eAf5GhalmVxxQNctIJxNCNrcqhF4RRBj9iGNYYqY+J4opeI6ve/j4ehfj Wd7n/hy9St5kgE8gnmW6YRFvEE9vWjrnfeIIK0kK8TnxuEEXJH7kuuzyG+eiw36eGTEy6XniCLFQ 7GC5g1nJUImniKOKqlG+P+uywnmLs1qpsdY9+QvDeW1lmes0R5DEIpYgQoCMGsqowEKMVo0UE2na T3j4hxy/SC6ZXGUwciygChWS4wf/g9/dmoXJCTcpnACCL7b9MQqEdoFm3ba/j227eQIEnoErre2v NoCZT9LrbS16BPRtAxfXbU3eAy53gMEnXTIkRwrQ9BcKwPsZfVMOGLgFetbc3lr7OH0AMtRV6gY4 OATGipS97vHu7s7e/j3T6u8HenJyqk7w6GoAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADq YAAAOpgAABdwnLpRPAAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0 SU1FB+UFDBEPDnWv6NYAAAHBelRYdFJhdyBwcm9maWxlIHR5cGUgaWNjAAA4jaVTW44cIQz85xQ5 gvGzOU4PNFLuf4EYDPPa2UibWEKIMrbLpki/a02/hqlhgmF4glYlbUbANCFtehkbCrIxIsghRU4E sEvcPVYFyL6N+/mWNCsZGXAW93KFf7DuVQejvIFG2O7Mfmjph/ebsoqRRqGMC2ZI3hgYGodDl4PU zCcEGy9H4Jmd7+HjWPi5RoE1+TjnGMPRHgEv+FXvuD3hm5DjIxH7ywRVzLwqgAd8xr+5nwZVQ21x pu1gn4ULYLXg7F5w3rjt1jg5XE30/ZX2S1YVvUSEdsByewIfIXDx1YasUjSqQ2kuMnWH+qUxZGzr fMWdIQnBlQDfCaS/M8jng8EQ8yyGUWwWoSjC7Im0jw/hKz8YwONLPNlQMLwJ2DWlRITPgsxQOSKl XX0YocyzlcmwtwITv5157m1VolZnouosPjHQHp3R0SMhlY9MkUsPRv2Yr3HTyh8TYrHpt2Pu+WgO aHbZ3NscifbkUd1mXjwthiBlBlLIDE65vegujHYiOKnNQOEQGNc6L5ZSzlUhEnep3+luD/vt2WH/ uS/C+49Er0JMfwB+qCBJJHXXDAAAgABJREFUeNrs/Xm0ZVl21of+5lq7Oc3to4/IzMiM7LNaVVYj lQqVBCXLtiTjRsLYfjwPHrb0PGxayYCFLCQeFMLPYGMPPyOZYZv3jMFCNjbqwEqBOoSaqlJJ1WQ1 2UZm9BG3P93ee635/phr7XOiJDCgqoqsUqwcN8+Nc849ZzdrzTXnN7/5Tbg/7o/74/64P+6P++P+ uD/uj/vj/rg/7o/74/64P+6P++P+uD/uj/vj/rg/7o/74/64P+6P++P+uD/uj/vj/rg/7o/74/64 P+6P++P+uD/uj/vjy2jIvT6A++OLOz7zvX/0xNnuoQeLYvhA9O6caDzrungq3tg9ufvaSzsvTa9v 3oiTjbl2awKjqHGgShU1FjFGF2MkaIxRY4fGJsQ4DyFOQ4zHgh6GGA66GHZVw21Ub3Wq1zXGa6rx dVV97c+8fPPOvb4G98cXb9w3MF+GY++v/5VxRN/UdrOn5vPjJ2fTw8dDN3ssxPjI+nRj63S8iKsK BIgosWvxkxbZPeJ49xavH1/jctxnqi2CoBoJMdKFQIiRqLF/LsaAqtLFQIyKpte6rkOBNrb2PTGi MYLqfqf6cojxBUE/K/DpqHwK1U/8+dd3J/f62t0fn99x38B8iY/n/8vv2q6r4TuLonhHUVZvL4vq bUVRPi1ihqHtFsxmhywWR3SzBevTLU7qeXxREkWBiIZAVHBNhzuaEW4f8Nruq7wYbjOlA5QYI10M hBjoQiCqmqFJhge1x94YxWBGRSMh2vs1PaIQiagqqKKIGR/0+aj6aw75qKp+RDV+6PuvHuzd62t8 f/zzj/sG5stkfPwvfsf3V2X1J+rhGsPBmLKocd6ZkWkXzBeHLCZTRvsjToTTeBwqCiIoEB2oE+ha 3KKjuHHEi9c/ywvdDWa0SLTJ0oZA27WEGGhVkRhpY0CjGRJNHs7S2CSvJ0aUSOi9HCWqIqqE9HsM EXHJAKnmyfmrqvqLTuQfAf/w+6/sv3Svr/X98U8/7huYL7Pxif/yj37/eLT1J4ajDepygDgzMl27 YDY7ptrz7LTbiAZQECIqoOJQL+AgiuCCgyv7fPby87w+v8VMO6IGVKFrG6JqCpcsPGqTFxOSocke j2qEGOl6A6R3h1gKqhGHAkobImAGxgFRFI8Qkuejqp/wjp9R1Z9G+am/cO1w915f8/vjHz/uG5gv w/Hx/+IPfdvaeOcHxqNNymqAc84MQTOHg47tdgCuAQnLPxLAgeJQp+AdgiPebtm/fJPLN65ye7pP o5EmtMSuwyt0MdIQaLqOGANRI23oEI20K0YlxI4YLdQiGaeg9jtRiRLRCF0MeIE2KILiBEQghGQI ETNGCqiqE54T5P8E/t4Hrx587F5f+/vj7nHfwHyZjk/85T/0Q2vjnW8dDbcoqyHOgXaKb5Rh10Lb AA34NAUEwIGo/duBekFEiEHpjhdMrk+49vptbt7Z5XByRBNbUEWChT2LEGhioFMDfkPokjdjHk32 broUMkmMRMyD0WjfG2JARAkxGRE02xIEENSwG7FDjRbl2e/wISf8mIMf/XNXDz90r+/B/XHfwHxJ jB/+l36XfstP/NQ/87361H/9R3bX1k9sjwZbFNUA13lK5yjCFJlNUW2wlQo4QNNKzdMiGZvo7SkN kbZpmd9puPOr1/nU7dc4aBeUSgJ81fAYVfNyNNJ0ZoQyJtPFANHem4FgUSUSCQmTiWrfqxoJakZF FIJG+x3zZEjvcyRbRMZtBFV+RUT+d4X/7c9fPfjUvb6Hv13HfQPzBh1/4xu+VmPTMD+aM9s7pjo1 Zrg24Pc994/+qe/Zr/3Ff+/SaLT14traKYajTcp2SBUH+MEhNAdou0AQiA4VzMCAuQToijcjRKco EfGCU+Bgzo3PXuOTL1zmxv6UqBFCtIgnBgKBtussS5QwmC52tLEjxIg6qCoBr2iIhC7StpFm0aIh Z5fM2KgqEkGJOBFCjHiRFQ9HkPTefOhOJD0PqP64wg8r/NCfv3Z4PxX+RRz3DcwbZPx/v/FrVWYt YdHSTSYc7k4MtwBaIk4cCKydXmf97CaDQcn6zhrf9IM/8U+8h5/4r/6DD43Hp55dWzvBQLYYzLdw 7hiqXbQ7QmJI3oCzn36shE7OQhK88WYQxSFwPOd4b59rr9zmxmf2oXOUOJCIU090Do0R6TpaOqKL uDoipaJ0RNcRq0DQjqbrWDQts+OG3VnL3tGMZtb1maYUFVl4lB5zdKfZy3HSp8FXz0LTKSBcB/6m wt/4c1cPf/le3/PfDuO+gXkDjB9499t0fueQdjajiRFE6RDbjREQByIEIjhJ4GfJ5ol11k6PqNcG DEcV1aCkHJZ/6xv+8o/+nvzZH/1Lv/8Do+H2T66tn6Su1ikOStb9A8AttLoNukDcMrgwJNXdfYDO DoMiL1fzLsQ7pA0wmROOW3hVcLuCRAdFBaMBaAfNMRQt+AiVomWEsgEWtM2Co27OvJkR5i3tpOH2 bMLV4wk3Do65tTdl2hgY7BIOo8lzWT1KjdrPZicJm1G7dGaUkpeD2N8pP+bgf/oz1w7/5r2+/1/O 476B+SKP/+1bvuUDulj85OGdW9++f+3aDyzmM3P5naONlqJ1IkSk56ggQlRSlsceQ3rd8AeHoJR1 xfrGgI1T66yfGLG+Odr7F/8/P74D8In/7A9f2tw+/WKpNRv6ELVUUBygwxsQ54jm7zNgV6OkkClN kZTCtlVrBD2LRTCjJ4rOWrgV4CUPkwAxmDUYdVBFGAUYWDobgDKAxz4nRrQLNJOGcDAnHsy5fnTA p472ePnWPncOpjQaEVG8Sg/6KuCdEC3fna4fxGjXKYVIkI7YIfj0u4HD8msK/yPo//hnrh7u3+v5 8eU27huYL+L4n977NZcWx4cvTufHzKcTQtvawkhbaoYwFRBxBGwRRBWiWDalFEcUCCp0KKUIQW1R iXN4cXjvKMoCX3gGdcW4HHBi6wSnzpzl5NnTrA+3WR+covAl1eAItvehwJyljG0kS6ZBICZDIz6t 0giFggtmbJz9SEyGYhHhKvCqQgjIIMB2i/pof+OCeTM53Uy0axAjBIUOmANzRzPtuH7tOr/++ut8 4s4tjsOCDEMLELBDj6p4tM8qJZtiBmgFAhYniC5jKNVk4+A1Vf574K9+37XD1+/1XPlyGfcNzBd4 /Fdve1bjfILESOHM32jbBfP5nNA1KQkr/WMEonc4VaITXFRwBUEVJ3lZCR2WuTEj5HCAF0GdGACa n3eOcVWzvbbFqZ2TnNo5RTWo0RBh0nG6qzl16ST+TSUyzgswfU0OlTpQCvNoItClJalqxmbYIUVY ejddNO/lOMBVhcbeo2Ww2MW36epkTwjzanLeORu4VmBRQIBwfcbrL17luWuf4ZX2GFK6WlISTGI0 giA5s5TIeYBTszrZa3Hp0JNTaB6NgBOHxngrwn/n4Ae/9+rhq/d6/nypD3+vD+DLdXzwyac/9P7h 4AcmR7s0TYPzQuG9eSQx0IaWoJEuZUuUZUTiFFSEiCLi0yISArYIMo3eHmUlo2K4TUgLz4vDk0Mu 8K6gKDwCNKHlYH7E5cMbvPDaayw+u8/GNFA4W5TinM0OL+BTYglAIuJT6KMKrYPjAlkU4IP9SLIQ JbARYQCQSHU+0lsF+8DlatfkihXpewtnj8dzPnbjRVRa3lqfZrZYcLOb4lKM5FHzvJZIEiB459J3 WTbJyRJOAlYwHMWLZDM/dvA7RPl3vm69Xv+69frTP328OLrX8+lLddw3MJ/n8X2PP7X7vuHg+6f7 d87PuwVgi70uK7z35CLEpmuJQXFowgZIoZH0kYNVMhsmImp4S89+TaClw1mKOLHNAhFFKXDm8agt O4/gnaf0BSJCCIFZM2dvPuGonXJrfsBr1/e4eeUAnc0pQotrWmTRpYXvDNQtCigcUgjiFCEiEiEI 7FfQeKhbNBUviROo1UIq0klq7B2XnJ3COQORvYfCWzgm6XmU46Nj9toDdlzNSTfi+fkebQzmdcgS XwnRDKqVGeQiSjPYksLP/LWSDM/yee1fAxkLvB/41t+5Xtdfu17/2k8fL5p7Pb++1MZ9A/N5Gt/1 6JMfendV/sDR4Z3hrF2gkr0LKHxB4Ut8USRAMjFaQ0tHikbEFob9nqa9GF5QiDeSWkoRB2OIEFE6 jenfAVRY90O26w0cHo2BLrNBnIVQhS97lu1iMaddNITQ0RA5iB2HzYyrN4+48foeBwdTWr9gHubM ZhMWx0d0R8d0xzPiYoHGiC89Oihh4MyYTBzsluAVim6Z4i4wj8alrFiVfwooC/vdl/bjnP0Ebyw/ V7BTbllo1kYiLXthynHT0caYsGfFObfiaUkfGmUw3Kd/Z69OdVns6TJnxkh6vUcEsumEDwDf+HXr dfsPjhe/eq/n2pfSuI/B/BbHf3Lpid3Zwe52GxuCRry4Pp1apMk7rkrWh0MG9QjvHDF0LOYzZs2c GEKPBdBnj0iFiBbitKq00uGpqHxJExtatXDJScHQVawNRmyONzixeRINyovXX2KvOcSJhQriHGv1 iPFojUFV4ZynCx2LZtFrupTeE53hOOoE5xx14dk5O+DcpQ1GaxUehwuCqMc5T1lUVK5kKDXjeg03 WgNGMG3ROIGTE7TsEmcvYSwRewQDP2I6YQUaQRoSfRiYKzSYESpq4qeucOWzL7HbTXn9cI9PTm5w QEi8mKX3l5JbhATiKmaESJ6MfaP2v0fUQtP0Ac4JUSNOE3ZDH9n9hMJf/k+vHv69ez33vhTGfQPz zzm+4+HHtTveZ97MEZcmNLZ2irRLepQgjsp7NgcDRqMx3plnMZvPaBZzumAhiOCIojgneIWIM4gD M0A7g5NcOHEBEcd0McGlokTBMRoM2V7bZjhaYzY74uVrr/D64Q3MtzED452nLiuG9YCqqnHiTLel a1ENZMxC0o/3zgyYc5barRxbZ4dsXxhTD23JBrWl5wLUnbAuI9ZGW6xvbjOot0EKdLpARxPYnCA5 TIpqKz8CXZqCrSCzOuWYnYVabbIWRQGusNCqCXBzCrtzwvU7/Orrn+DvN6+wrx0OYxmLmBfoMwsY cOIJGikQnPNIVDR7g/k96dBIUFCKRNEEsGdQGXvLf4Pqf/E9145evNdz8Y087huYf47xH504rW2Y J3p6ykTkLU6VkhUgUYTKO+pqwMZoRF1VhBBZNHMWsykhJBKZA1VJpUH2OU1CYi5snOOb/4V/m+Go 5urrly330i7YO9zncHrEnf073D7aowkNrQZabQlEvPPps81YlGVBXdZ4V1g4o4oGq6gWZ5iN84Z9 GCBtIGkhzhasgJSO0XrJ+okB1cAhBZRFgTilC1bAuNXWPLB+ga0zDyGDApkHKCK6OYHRDDCpCIKY gYlA45DFABYlkdIAXBxoIHadGZ3CwjDponk2+wv0xoSf+uhP8QvN68w0UCSPRFziCGkm5Nl5FGKM ZUWNU6gRNJisVnpvzjJFFNSAc4+muijDdsS4PC85+Evffe3ov7nXc/KNOu4bmH+G8cceeWJ3sXd7 exFb416kaMYn5mhKuADLusHKCQ6hrgesjUaMq9rEmdqGxWJO14ZeCyXkSQ0ElA7lobULfNM3fCvr W9u89OnnefXKy9zev8Xu5JAmdlbzEy0jFXPtDkrhLPuEGFBcFA4nHu8LqqLoAc4QAw6HiKPwCRh2 FjgURWkYawrbsqFxgHMOX3uqhKtUQ085dHgvhK5jpJ7H/RkefPzNsFZC0p+hatGNKdSLZGQwrGXh kVnF7tUjjo4OWR+vsXXyBN2i5cbVq8wWDd55qqpktDZiNFyjLmpcEJpfe50f/fRP89HmJsE5Ciw1 rSJ9OVUpnkJcz+Q1QD2VICQ5iM7oi6kOys5bekKf0RkTZHxX6luj/m2B//x7rh/9wr2eo2+0cd/A /FOOP3jmnIbFrK8PIjFCvVvCCaAUK2S1vDa98wyqirXhiPVqiEokNh3tbAZdB1h2KIiBtrbuhAc2 LvCet301s+mEj33m17kzOyBoxzw0NBi4af5HSslI3qtTyjZ5IHkRucL290KSLEPCI0pxFM6hzuHF sk2aCCOVsxy1y9iFN6/I56yMaMqMmRfmCod4BYns+Jpn1h/i0fe+FZyHZrG8KGWLDuZQBPA10npu fPo6H/rlj3P9cNeurS+MoxKjhT/OUZYlVVFSlSWDesBoMGSjHDN97Qaf3X2VV/WI45RLEwWHoxTB S3FXKjuSGMFkx9OMfBcDWSJCoNeDiCl2kh4c1rtoOw52Efl/q+p/9qevH0XuD+C+gfm/HH/4gYe1 nR4SugbBSKYe6YFETYprXpaeDMnrLzA8JgqsVQPWB2uM6toWS9vSzOc0XYsGy/YEMa+lI3Cy2uGp i29m/2iXy7cvc9BMWcjS3RcswgALw7oeaxA0GlbgxKFq7A7vjSXsxIxIck0QMQOjJK8k/SDG21GM T4NYVstZ7GLFl2kh+n4W5UyM2gIncMlv8bve+m7ck6esLqkNmb8PVQWlY3G4y96tPT7ykY/zwq3r tLGj04Co6cV4FYqc3Um8n8JZRmxY1IxGQzbcADdvOVxMeK3Z54DGiIZi50xMHJnkgYkKTkwwyztL b2c2cQhmoAxT07u8mlVaZObRxFSMma7B30Hjf/anbxz/w3s9d98I476B+ceMP/LIE7vh4M52Gxa9 h7KilAKYoXFioGyuE3LQk928M6BRnGe9rNkYrjOuB8bXaBraxZxFOyeksGauAYcwcBVro01KV/Da 0Q2aaNmpoMHif2zHjYmMFxHKzPBXKJJDH1eOVxC8M+9FZFl35MVCuMIZB8U5Z9kWJ4TkuRTe35Xu zZ6PS9+ZSWouVTNLQkejRkrg4WKLdz7yONuXzkHtLV1dF1BVXHnlKh/50IfYPz5gfz6jCV2i9Ggv LJ7DEknkPpe+W0RwKhTeUbiKUTVkvRigYcHNxZRqMKKqK2btnOlixrRd9JiUF4fEXFqQa5XMmARV YggEojl6Ca9BTRMnM/xcykOZQ6NkfUBVve7g+//0jeO/fK/n8b0e93kwv8n4I+ce1Pbw9rCJ3bLc f6XuD0hut01w72yxFqn62YvJTTqUAk8hBeOiYlxUlEVB6TxBTWYyJOV9VBm4mo3BFlUx4GB+xO7i IO20jpBCp3w8QdI+KtJnNkRIi2Z1t7a/Mm/K4wQqPE7pyXgVhs8UCUMShC7xbDK2o0msO6YF53SJ 96haXVGMMeE6Skuk087Sxyo8EAes+dLeU0D0wisvvcw/+pUP8dm9q+y3s9RtwAomupQyXtYNKUUK PSXxhLLxaZMmcNMtmHYNAVivBmwOx5w7eZYzJ0+zPl5jWA16+c6ACWA5Z95cT7zL4a0kY5mlKRLw 7nr/ZWnQxVk9GMspsqbwL37dWvXI+8bV8z87aX7b9oK6b2BWxh9/7KkfeIe2P9I2s56Gn0euYSkR irTrZ66LGRMhmxUv+TV710gczhm46ooC5ywF3YSWLnbMQ8CJ59Ezj4J4bk9uMYuNlQcodNJDjkgq dsyhUoyaMBWIIclKJgxFULqoVOKo8FTiEF0GWS7hCE4tzDOSmRmNrifzWeo3FxNq71ksK6pDjBA1 yetaVwFUOeVq3rJ+gXecfYhT21vLHky+5Mbr1/mHH/0Il49uEVUpY86gpc/W7CGsFDZm8FVYWeYJ H3KGY7XasggtbdfRhI7YdoyHIx65+AhPPPEUW2ubhLaz6oQYabMnInZtJYG5ztnx9MWnyV1TyURI g7E0GXrfVz8syyAU3u7gvV8zru787KR5/l7P73sx7huYNP7I6XM6Pdp7VjX0kxjJRXC5KM48lUoc 3pYoPu1vmeafa10cLnkLKfMgIOJxhQdxlsEQawMiwGa9wXi4xu3DW+y2EyPkJUKGB2KizItYxkds ppsXYmrYVJIyRRgzlcQCLnHpuOyYfD6/lZIEZ0VSadEkndycllXFaRamSkQ0zb6G4mIGSk3Iu1bh sXKLr3nkGR57/BFGAaJEYlScRrSJPP/CZ7l8cMs6BkR6owL0anZ9jRb0x9LzU5JBX47MVRG89wQn NLHlqJkyPT5mbTDm/MMPcfr0eR5+6CJnT55BAzSLpgfOlobEDA6ajcwKSS/hQLkiVFIpRsbd0qH0 DwrnHHzT+8eV/Myk+bl7Pc+/2OO3vYH5jx976vvfLfqTTTPtxaQ9ubjPDEahCYvA8IaYPZXkrWRf xyOWxk3eQ35NVY1n4h2u8BTeWLCGpUQcns3hJruTA3abQ6LGxIVJi8kZo1cUMxbR4RVqcVQ480LE Uab1lvHKQjyikcL5xHJN6VVyeUIuAkzGpQ+REicHS5ejMalpLrMoImLhU4iQvJZWAzXwnvUH+eo3 vYX17THxYELsOmIIOIXSO3b39nn1znXmoaWmsMJpglWMp/uiKQuU08QiJNrgXX5lX2Zhi17wYudq ZQOmo7OIC7bqDR576zM0szmgrK1vcO7cBU6fPE1dVHSLhkVYpBAtAdoreFfmOPWsXmxDiSQWsEsl W/S2e1lPBqXC73z/qHr4/ePy4z87bffu9bz/Yo3f1gbmj114WNvDW+/runb5ZJo9Vq9CwlPMU/Bp elc4SjAD4ywL4xHEOWq3zFyICCHVGCFmZArncGWBT0WHpjerNF3HXnNI07VU4i1tnJaSizmUcb2a m0cSwz7ttmlT9UIqkEwY0LKmhkpM5kFWqpmL9BlOrHxIkvtfidX1+GR0I1ZwqYnPEmOwxZ8wmUY7 VDve5k7ynmffTnVhje72MTq3LJkkUSlfOF6+co2rkz1Kc5VoNdLEkBal9h5ALhTVZNh6aYaMLK0Y cmCZShe3zKg5ZewHPPHYk5x98lHL3LUNIkJVVaytb3Dy5FnOnb3AqB4yn82YLWapgFQTkiZETYTE 3rwkQ57qxZTsCClh1QzK0iApvF3hrV87rl7/2Wn78r2e/1+M8dvWwPyxs+e1newjaXf2iZ9RkPGW BNMqPb7icRQYGzRnImLGXMSlNHDWvU/ewQokqGjKelRUhaf0JU4dMUQOm2O60DGQIkk0SAJQoaQw MJkUocjSC4k5u5MMi1MDn70shZWyQfGqfRo9U+Ndrx2jBLEEc0hhktNUn6MZUI3GbGWZUYsYWW+A 8Gx5hve+51mGbz1NuHZI2J0g+aBDCngEXr19k735MYV4DnXBcWxpsYyRGbjYdxaApUfWp4tXCI09 TiLgpLjLe0GFTiKPnr7I2776PVRVmYykta7txGQ/69GArc0tTu6cZ3ttm9F4xOTokHm36GUvMu7k EmcmS2II3BUmeZHk7UmS7pTeKCWv+GGQr37/qDz42Wn7a/d6HXyhx287A/MfP/bkh96N/kC3mJo2 i8tsXJsQhrdk/ohli1zyYEpxBuqKM5mEu/RHYDmJ8l6cwVKlxHAT7z2DomDoauqipFBHiB1NaCjV IeKtRkYTtpHCtJgB2BwvCDi3kmEhabi47OVEAx4l1eeklGrhZGlckickksFToU1itjEZl776OOFP gS5R6lPvIunYlJp3bz/M1/yOd1J97UPQLoiXD4jHi3xZ+sUYNXLr4IBbi0N2WXAQG+bapf5IOSO1 IqqX7kn+oCy6tfRgZFm5DvjC9+eiXhm4ire8591ceNebibvH5m1EpZu2MG+RSYvuT+huTygOGs4U 65zfOcd4c4vp9JjpbEbSwiMnzGPePLKMjSwzjaryG/Ci2G8yWZZDdwS+4WtGdfjZafPz93pNfCHH bysD8ycvPqbzvRvnNXT9pDCvxFLLCUbtJ4dLz5euoOrDnlQMzGqJP/TOs1juJQtJIUJFQSkeL47a eWpfUZUVzhdW8RsD2ild7vNMJEaWflAGZJOvLbJS+5SA4KzMlrshxhRCZfZqPj+XlkqRdnnLzqyA mYmZK5r0VFDTe0l4SNdnbIXgAifciPc/8ATv/H3vQ951Am1bZNahBwvCpDVycT4OB6HpuHywy0uL fQ61pVNj6VrWrme8ANmDSsp0idjXpeWqYr8HgQKhcmW6N4afFOLxCE+cvMjTT7+V8igQr+yid6bo pIGDOX5vjtufI8cNbtKgh1Oa/SP8tOOBMw9x5sKD7B3scjDZJ6TrmrNGy2POx5vwocwKVsOMsvcr K+dlBkpK0A+8f1Rt/I5h+Us/N2sX93p9fCHGbxsD88cfekTnh7cti+GWUoleTOfWqWWMslYIKR1d O6th6eE6YDlVpP93/pnn3R/w4hm4gkp8+kyHF0tXV0VtYC/QhI6mbQi6bNPR4wnpG0IOi7z02SzI jGFJNzJ7O5p5cYCl0gs1X6hEUkqahAElDw6MxUsSGE8LOYvliYNGLRXsnP2dF2GnGPD0gw+y9sQJ ZK2yD7o5od1rkBCg9ESNiZSovH6wx0d3r3MzTHseTR9upHvQ9zlCja8iYt0iRfF4xr5i6AdsVSPW ByMePnOe01snGGlBFWAonnUpOVtt8K5H3sxWU9C8cJW4O0H3pzBpcLOAtukYQwonxa5v7ALh4Jjt epPtnR1uH93heDZL2TXDnTLwm0NZl0IjY1EvWccZBM4Zpzxy6BxVvwo4+75h+es/P2v37/U6+XyP 3xYG5j8+fUbj8X5idpAqbg2s9al+xwQLjEGvCKUIlfMW1kg2L7LMMpDDF1sIbVoomsDcgXhKV+DF J96MSwV3ULqCoihN4Q5sQncdGruUOVmKOebUp/bHZmCiEzMUyx1ymfVRAS8WElU4avVUOCqW7ONM b++zHeISmc7OIWfDSNooi6gEl49JqJ1j4AqOQ8e1m7fYuNpx4tkHkBAIn9xF9+fkT48oZbTd/LXZ AS8f73LYzey6qoVoIbN/7QztHB14KVgrKgauYLMa88D2GR5/+GGeeuxR3v2Ot/OOd7+DJ9/6NJce uMgjssHprmTUFewUI544+RA7ozE6XxC6COKX4jAR1IMmMF4ThpazURqV9njCiXqLja0T3D7e5Xgx TXiLsXYjOcvl+lS6/W0O78yiOL3bz821bC5hR6q83QkPfc2o+tTPzdob93q9fD7Hl72B+c6TJzUs Zv1u7nJIlJkhYqBppr1bLG0Yi9NsTNxK+hRiVsVOPJkOk6oUUWopGEhBgU3cKtPtc1ZGPL7wyYMp 7DNiIIYGDUtcZAkWJiW79N1WTOmSbu+ydUeWiITcYcS8mREFQxwD7BgcQie6kpmx77IQwOFSMyFZ MaMNSudSY3pnC2bgU01yyoTV4njokQu43RndlQMT/oZEmKMHebcfOUnjlMODKW00/d5GlTbhSxVQ UDAqSs6t7/Cmhy7ypscf5Sve8gzvevfbedObn+CB82fZ2dhgHAvKvRau7SNXDvDTjqEfsFGP2Vzb YHO8SYxWpW4XRcwVS8p3MaSiRbfqjwqIbSOK0k2nnNo4QbW5xqu3XqULXZ8t8qnOLKZCyRyyZnFx E01PuJzkUgQ1rg5L8Dr1V3halEvvG1Yv/fysfe1er5vP15Df+ke8Mcd/8ugTu+3+nW1tm6VBSGBr DhFUUnzvEoin2meKxBnXZOmrcBdoK8mVj0SaBExWUjBwRdqllEqEIilmZ7Zs4T2+LFkfrVFUFQBt 0zKZHtM1DYSQJ1wqYIwgkTYVLQaN5mGk80xTto/zvYDXlD5XYYCjTJmMIJGpRlqSAr9kb4i+BABv 16FRpXBmXFqx7828kJGUJu1gl44ywgODDX7XW9/KaKtmPm1scTm1rgihM6U6D9W5NWZbJbeOjnnh xdd4/sVXuD0/xgNnyzUeOH2KE+d32Dlzis2NEYOqxjlPLYKfAYctejQjTFu0DYmg59DWbIekZkgq VrQZwFyhvMqdkGNk0/pKtUXi7c6mqmmXODWCUI2GLLaGfOTWp/iFj/wC025mLVZyYWmqQ3IpRMqh n2kqLzNuZpdin5lMBRY94TGFnT8Xo37v9+9N//69XkOfj/FlaWD+5KXHtNu9RdSlHKV5LkZUs4J8 Awgzy9Ylnocn1+SYz5Jram1Xyg68XbaOSJdSqwWeWjxZwb4WSaxaSRiEkeXUe6qiYjwaUdY1ToTF YsFsZn2SnEa6YK1i+9g9GUZUkzdjhZELAm20bJJT4+OUKtQY2zin3Z2artNclIaOVul3UCUT2Cws aojGuiWR9ygQgWFRsVnWrJUVw6Ji5B1FSJmUYMb0wnDMydMnYVwRYpfWs8CiSzFoRKqSYn2IG5Ys ugWvHe9z9bUbuOOOh9Y22BlvUJ5ao37sDDryxBtHdHszwvECZhHXRetT3SavoUhavpantjsjHlwm OPpkYNxKOsr1QuoxRhP9coJWBXHgbXOpCmIhtC4ivmS8s0N5cpNf+ZWf57l/+FPMulkKfcwo5XlE CjMRsbqwflbGZX1TlBUingH62cinSfeLzvF9H7wz/bv3ei39VseXnYH57kce1cneLZwupYU0kcy8 CDFaiBOS6TBjY7hMiRHclqh/ps2DS+JEkWUM3mJ9iUZYAaOZI4dXxbmCcTFMHQQWiStjP1VZUo/H DKoBokLoGuaTKaFriWrSDY7cC83Yuj6ZygLoEjGt1WQs+jSwgbkVknAmZ5wNicxUmUpkQbBwLWU5 AnY9GlqiOGoKNuoRJzbW2RyPGbuCoXOslwPWy5I6hWclUIlHHbRtoAuBbtFSlp6qrm0tO6x6GrHH QWEp8JQKL9dHFNtDdNERjhr8ItLuTWmPp2jhKaoSFhENinYRIeJc0aehl1PYPBBzUpK34jLV37oO 4ApL40cz3lU9oCVy0M1oNVKuDRmf2aFaH6Ja8PLrL/HS1Vc5aiYQhY3ROo88eImHLz3G3/jh/x8v XHvRRMbQvm4t58Csk4H08h2a6b+67IJFxmVSEatLabwcXhXIL6+p/74/vnvw4/d6Tf1WRnGvD+Dz Ob774iPa7t/s6eWZ8Zp/VvsXZ6wvp24LHIVbZlg0TZCQvJeQwLzcFiTT1ocJKFa1osIcUq3XI9bq EcezyTIXlFLAeScVJ30bVFzyiFAq6Fu51pqkFCyINyA6wEAcnoLBSnjjsM8jUddFg2n7motGLZ5S LSMzIdJK18sQbJRrnNve5uT6OmdPbfPgmROMolC0wchCXYSmgzam9LBxXAmK1yRMNzAeTdQIoxq3 VqIDh1QFjAoYFuAcLtU9BLViTikKWPOEKIQTJcX+AN1rkCZd5ZiYwGI6xOkGLe+gAgRUPELAyrVz eXM00DwGXOnwJ7YIzvHC7hVevn2V42ZGcI7yuGKz2WF7c4cYIp998Xmu375JEwIxRGrnuHrtCq9f e53aeyopaKSzkgq7DBY2J5cloGjIbN9sD43o6HteEmRBsFw6mol7EX33SPz3/uKJJ+NX3vn0l6wn 82VjYL77oYvaHN6xvjjQZ1bKVOAXyXodKehJadEqwaGVT8zcyArPwjgtMdEwQgq5UgdpKkyKERL4 mkSMnIPN0TqikUW3AJd7H5lGiyZtWIn0MpdN7IgaqRRK53p+TimpctqYaCzBRECELtW/FMnnKswq 9h5YlxLapcAI2NCCIJ5DgbbwxMIxGNQ8fekh3vzkQ5QduDlwOCNOG9o0+2P+XjtotIuE1CrFeh+V +IFHBt4MyVYF49oWeqF94SAhkgRwyTnwPnvrPH5cwtoAORdg1sBeBwdzC7PmMQEnpJSaW7keEYnZ lcvAR/7eZJwLh3/kFBOZ8Quf+gzX9+6guexiX/HXXmNYVCgwb+YEjTZ/ioIuRnaPdjn49FHCT8yY ZspA1pTRzKhOnrP3FkZalszhxbzerPubNYD7cgIhETM925TvOue2v1e/5fs6+eE//dy9XmP/POPL wsB894UHtD3cRUgLPVUYl4m3kI2CyrKYzljrZlQKccaohaWwkBpekUn5JuSUeCIJ6PVSUKTsU6Ee xBLhG/UWw7Li4HifGDsT38bYr+KSUr9LQGPomMcWUdhwnjLVG/nEMHYr5cS5erh0kjpEelpiLyXg 1IgkmuL/DqVyqXCvhGHnOOcGbFYjtk/uUL/lNM16wWA8YDiqkesTur0Z7bwzKU9VS+OmxZoVGiSB 3NE5C33WKtgewLrJUfSBdwyIE7Qz/Kpn82XYM2/3mkOaYEZDWsNR1ipkVMHpEcw6dG8OewuYLlK7 k5AMTQTn0dLjqgJw6LSxmiznloYtChSwaFpCF1I3gaUkRBcDh4tpzzLK7WdFQxKmEkKSgug0WP/w JOeZIiA0GmfJpwwlamC9sXpjH45r2uhyRUQgkyeXh7rmaqhH7zkexD+9951/cb79n3/Hlxzr90s+ Tf29Fy/q4uiQPumnLhkao/sXjhUzkTEU4yCUiZtigGqilgmmmSvGbbHEijOqfzYuor2ItFNLPZua W2DgSp5++Enadsato927qHg4R+VLytqasJGasEnXMYpKFYy/4p0kdvEyvCuctRWpCtN0yURBp45B qqounQG8Lnk6QynYKCqqsmRrY52HHzjPpUcusvOW86x9xRnqE2OG44qy8khI2+mwQEqPLjroln6f ABIT2bAu0O0a98A6cnYEOwNkXIBPu7eoKb+lkSvT7R8rbDMyUEMm46wCFkucwjsoPbI2QE4ko9NF aBJzpSgoNke4M2vIyQ1b5EdTchsAEYsjLURap1of0C0art++xTyG/rBypbkmfKqLEDWYhGeIFmKr 0mkw7WS11L5l99L8UU0i6iRlwwTTZ/wlyZOKLkH23nvR5fMljuF4nTsPr3Fl/fihq4vrD/2bb3v6 E3/j1z557V6vuX+W8SUN8v7phy5qc7SfJA/MbfWJFu9JcXCKe7MX48id/VxSeJO76kXyPCdxW6Ia WU0lpY0lu7pW42OGpkBjoPAFb7n4BGujNT79yme4MzmidMYxQQTnC6qqYjAcUVQlBQ7tWpjNqFpr +eFW6OVmYAy3KYoCRExUqguWro5LZqm1g45pySr1YMSZc6fYeGALv1FRrI8ZrtWUhUtdFsWouWT6 bPYqFJ0FtAnE/QV6MCM2wVq6lg42B+h2jawX4H0fpdgFjn30ZqJTmTGsK55LfkiGJYmPL/U9swFa mZqS+Ct4623dKkwiHDUWSm7UUJS0LhK6iF4+RG8c2d0uTBoDwFUlfmcMo5qjtuGVg2t89NWXuHp0 J1VEJ15RAqFRtdqsmLKFmvCmLLoV83aV6A5E85pIGIsueS6eSNBclJpfM3yoZ0srPVBcScGFc+fZ evwifq0C66z7d7oo3/Fv/LW/88K9Xnv/tONL1sB878OXtN2/fVdNkN1Io8aHtKsA9KwREetZJFa4 6PAmeRBjv5vQs3OzoXEmFZkyT7kpYYkwlILKFZaNUuXSyQu87/3v5ed/9ud57fZ1nDi61DdanKcu SwajIdVgQOULJERC0+DnDWUwV9zS5UqZAGcvBUXlrSmaKiFE6wuky4rjGBQJ1mVgOBqxc/4EWxdP ML6wQTGqoCyt33PsoLE+QHQJT+lnN2lROTSChA4WgTiNtPMWrQpYr5BhidaGu2iroKGXmYQlm9WU 6bKRSeC26t03MeMyGYhJ15vca7tHkmy76BELo/haMaiCjCqKTuiOWtrrh8Qr+zAPUBR9SJraKtif iwcvaOm4Ntnj12+9xouTmxzHti8M7dRU+qJGY2j3tOeYoDDtq6pXG7M5rBOn016610JztaJMr/Sl JPm8M8Gv97DFijQffPhhtp+6AN6lbJRSePc/AX/kX/0f/s6XhAznlyQG832PPaHNnRvAEpeIGLOy IAthJ5wg7QpeMpiW//OJLp/2Laf4KL1wc+EsLOo00oCFS5jAt0+lBD7xXDoC26M1vuIr3sZsMmH3 cN+Ynt7WchQYFI56MGAwGBp5TCNt2yEhUMTYM2R9z58hGRgDe6WLhmnESIFLzb+g8I7R5oi1tTH1 5pD65JiNc5u4zTo1NGuhTSw0WBZI9mne2BcSWjwREGdXNgwcceSAgbUdqVMmLijaqr2vzxZr76Rk UuKyv3MuAEy8nkxQcysGp3/rkhF79wt++btG6CR3MYJJQ/Ql7riluH5EM2nAuSRylbCjwiMaoLO0 vbRCM2k4JQPetf4gW1Ly/PENrocJmryVkLKOq2S50GeAtJdlsOfNu22TGNfSY16eg0CSxFiqymQP 22uGolI/cu8Zrw1wXog+Cct7QaL+38SxC/zhe70O/2nGlxwG82eeeuZPtLeuf2DJKbBJ5tKiz8al Z0+m1LDP5PnMriVPlCRzKcud1juTmQxqFbstS1mGTKirpaB0woKWQgq+4sm38vR73s4v/oOf48bB noUzWbtEhMFgxMZ4zHAwovLeygPaFhc6asE6ECQDSTSuiIeEudiiKp1nOBwyWBuwNhqztjVm+8IW Jx49w6mnz7D+plMMzqwbTrJol6navJUSl9mbPHrvIyvkKx1C5xzqE1XX9akQa/+RxJ+WbNVsOGDV UVlKV7jeg8nPSe6PRH5P9mZSFug3da7z865/2RZ/tKxgVJgFmLTQpTnglv6BLyukLtC2s9DEexbd gkKFC4Nt1ik5bmZMY8s86//GpXBn7rzpMFwv8196eQaWXrRqagGc8OtMxDMPm95zywW3QbK+s4Xv G+M1di6do1yv8C7jNimMc/Kef/udT8e/8eFP/+y9Xo//V+NLzoMJu7e/P2rsvZGlPOTSk1kS6fOO kMsDtDcVue8NqOnfpp3Hr7BvWwJdAkwLNZB17ErLJmCktUYjD+3s8OzXv5ej6YzLN67RhobSF1Z6 4IW6rBiUFYN6SF0UJpwdlRgDzsWevzLwDo+nFKEoPNWgpKoTvOwcg40Bw40BvvDU45pqZwgbJdIF aBWdNEhftWlnmU5xCS5lNDHxSnLqIzpPqx2oEF2Suk5Snz13eWXhawZjM88tU8hiClolVxz7Pltk RsUtj2vVS+lv2RILspc+15tJ56XZyBihUrtAt+WR0Q6+EuTKMUUbCUFRl0pUN2v8mXXk5V3C0QKP oyoKmral046Lw5OsS80vH7zKpxZ3mEnXZ/KCnXQvzJWx6v46kFLMUWhVKbC2Mi6dkkuXW1Ywmhxu e2eyrJm17RAGGyPKjRq8vbdMTbdNUFBwov/pj/z733ztm/+7H/mr93pN/pPGl5SB+b4LF7SdHC3V zdLIkonhLtMCZJJd2qXbvimG75Xr6Cn5mMquQieRRq3OxVrEOobOM3RVYr8GGpRJXHCiWuOZt7+d 6uwW13/uw7TaLtedKM55fFFSVzWlNxp6l0KjoYfSVbigrA1q1sYjBmsD1k+ss3ZiTFkVxMKySjJw hqN0YQnOakSPmuSArIYbKaRY5c2s1GPZTF8u9M6JtU+R3hL11y/3AcpSmqvtx9JJmheZFpp4i5tU Y+/laA4r9HPCItL7Vr8z25WsSoel80X88v3pfkpZmMB34ghpG4i1Izy2Y/f+5oRyYbyjQAQXkVMD fLNJeOkW2nR4J1RlTUOkK5QthrxXH6I4ED7R3GKWcpAhlQD0JRa5bUsmOYq9x+bRUj4zIhQpxe3y c7oM1/vrk5m+KlR1Qb09ohh668UtxhpwomTxXxFK5933/MR/8Luv/Ev/7f/xE/d6bf7jxpeMgfmz jzys7f4+sHTDnZC0cXOZ/3LymlJbUt8n77C5h7QmUWfXh/1OkjZLLz6tvSRC7UoK51PtT0eT/KTG RS6cfYA3f+1XoTf3uP36dULMlU6JWeu8SRuUBeITR0OVcVGwNRowHtVsX9hm/exmL/bkyxSCBMWr VWnTBPu5K427qkuzsq0CiXxyt73oUzWWlO+iEEV7jocA+CKpGiTvpvBWOJg1czR7KAljSb1zNRpF vjcMUqbjUDTafh2jQkg+ZkzHUXqcKxJV3gyUGZBAbNPxlo7oS0DwMRBbqw5rQqTrUogWOypxjHxB N/RcW1duXd/jfKjYKdcZOI/enqPP30G2a/z2EL01I3YdzkX8yTFhWMArd1gfrPGW7hxHYcYL3T6L pL9g4O/SQJjCXyoXCNqLmBWOVJC93AZXix/tCmbFwFxwmgWrlKqqGW+McMuWmZTequXFaU8f8ioP 4vx3/9Qf+jdf/V3/1f/yyXu9Rn+z8SVhYD742OPa7N5O6mckbgrk2pzIMiUNWZ0uQbkCncKKE0+H MhCf8IYU16oR1hQrRiOlDwfiwcExJu0YCLSYCXlofIJ3v/Mr8GslRy/e5vWrrxtJjszoTT2UnCeK cVnKquLsqU3OnN9gbVxRuEAxKmxWhmBVukTo0s6e0qV9Ghm1WoG7BCQ+B1eBZXamxzXyYw5lhFBg YkuFZc68KyylW3m6LhDbgESPHxR0XaSZzphPFgao+wInymLWMVksIEScd5RFwaAuKWqfrqFSDQZ4 X6SMU2r1UilCCZVlrdpFR2wVGVXMj4648dotjo7nhBhpm5ZF0+Kdoyg8qjBtWm7fvsPNyQEhmrj5 +a0TPPPEE1x66iGa2PKzLz9PCB1Pjk7xlvXznBpvMbo+pblx2Etb4BwSA2UDMvZoXeIWyvnNHd7S TLh1NOE68/6iaso4FkgyNFlDJ+GBqoRohsKzZI17lb68xDwcoZAlSxyWG2U9qBiMB73RNywpSXRo 7A2Pw+EL/95BNfjuX/7ub/v97/6zP/iGU8V7wxuYP//0Mz80v34VNCY6vN1UMi0fq+HJGSURI9AZ tLiC/iccIf+/UzNJbZY99MuK6lIsPi6dI6AstGFCoIuZZwILF3n0gYtcfPOTcOUqty9f5c7+AUEi ZcrKFFlTxinDqmb71AlOnTvByXPr1GOgmUHTQNfCIifKsxeiK2FPXMmykKQCUmqjrxBeZcouPyJp CJAlCnJdEkC9VoJAe9wymy7QOGfWdNy5fczh4ZRF29EGZTFfMFvMadpIl1TDYwx00Tw6yyoLpXjz VNI9EjCphaJkVHmGgwHDwYDNjSEnT21TlCW7t/a5cXOXo8mMtmk5mE05bud0reWIOrVwVVMrFy+O 3JKt1YZFzO10hYMbMy7fvsXZTzzPxXPnuHDmDJ++epmPTK7wydkNTroxX7n9CM+sn2dGY8eZU9gH U4rFguAcQTs8wuOb57jaHrM3e52ZBvPQjAxMm6550NwvK5JF333KFMVsUBKD1ycD5EQQsbm0ZIan FjdAMSgZ7AwNW0+3L3eZzBPB+xLnCupygK+G/1bh/QvA99zr9fq54w1tYP7Cs+/Ynr/++rdGDWTR J9uIrbpYSGg+SiEQU/1OBn4VS3wkB6Y3Dgo02gGZom0wfyTVnjirY55rIDgIMRI1WNillgE56Qac f+A8nBwz+egrvPbqa8y6eV/7pGgSaCoYlBXnzp/lwWcfZ31ziMQWjvdhNjduCnElcE8nqUtmTg+K 9oCnLumfPSgaE1rowSe/LnNJRKGuzcDsz7ize0TTduy/MGd374jJdEHsIvO2ZTpvmTYNTWds1S5a S5KQCX1OEnFRiYn+32vBqTOtGjViWu6iIGohV5lS/1XhqIuKCMzaObO2NckEIpPUbrY0Cu4KvKu9 vcyBXoFQU6aFbazbgzjheG/G/vERF8+e45Hts7yyd53b7Zw7LDi6s2AWO57deoCuCyyaJuFGoG2H 8wbCB6CoKt6z8yjXbk74+OJ2z3VJTSiTtq4mDxoqzdIXkGU7OpIgO0sqhf3uyKINXpYolADVsKIc pqVp1KRE8EugsbPuoHVdUZZZuEz/1Ie/9z/49LPf+9/+9Xu9blfHG9rANDdu7OpiboxXDDtZ8l5S oWBfXyT9yawGD1kx37AX6Yse+4Aiv44So5FVnQpRrEthjJb+LNU0a1vpCBJ5y4VHeeyxh2Gyz+3r t3jt5m0j7SWwry4KTq6tcfbsaU5fOMuDb3qY4blNq0iedhYOSfrJR5u9kgzOutV/5zNawWD6u+jB lRACi8mcadMyn3W0XUeMStcGmhg5nDTs7x8znS1YdIH94xlHs5kxU5PxamKSD0j9mnMvZlUxTkY6 Fo/R2S11m6UsIoUKQcVqqjJPKekUL2LDHAgLJcyO7D6ILcycOaoSlSDzJ2yRpo0hnXaxEg0ahpaX +rKA9E5zyOxKwwM7p3lw4ySyf5vDsOBaN+Ef3PkMC2l5+/nHGLFGe3BI0zSJDBdwRUF0kXkXOVWP +MqTD3Ptzozd2TG45EAmcNamkG1wIaWdSYZAhd645OxQPuY8R3tVO00pbCR1/7TrlsXnQ9Degweh qit8UVNWJagSQ3Bdtzhzr9fs5443rIH5cw89pPHgIDU+I+2GrjcYRlpadiDy/T7KXTovOS2bd76A 9NyD3HYk00RKZ7e9FQuHMojqxDJJkjyH0lc8+danGJ3fIrx2m5uvXWO6mFK7gpaW0pVcOLnDm9/+ BA88+QBubQiutiK9XmVbsp9tbDz75W7vRVcEFZfMnmSUfMrPWxr41o0Drl/d49behL3DKUezeZKY EBYh0DQtk65lEZc7Zk7Rd7r0ijyeILZjZrIi5MK9JSM3axcjVk4B1jUyJ6Dv0jdxqTmZSr/gfE82 y4JeS2JLFr9a9TxXM9WZoZ1pBhk87Q2wuIS7KWujMQ9dvMD6K5f5xOWXOYoNt+OMv3/nRfbWHe+6 cIktraj2lbYzfQXpQpKUgONuwZNrZ/iGEn78yse5vZjiRW3BJ62ZDtsLvJME7kYapfemhcRx6SkC S2g+S13cjaBF+/5l5S2+gNgqznvEFfiipCxKE8qKgRCbvff82f/hL93rdfu54w1pYD742OMabt/s O/flRls2r6R3SXuK9gphS/qbt2x4BisEqJwO7Ber7bg5S4JTFjGklKOiqYAwU0a8CBfHJzhxagcq z+6dXW7d3jPVOnFsDAY8ePYMz7zlYU49eAJCC0fAyEFd0Os5SD6qbApX8JcMyPZhUlKR1mCIYFFA ZWno490jrlw54Feff43Lu0fMQ0ejsccsMinOmMHWXlY0JEMrELAgwy3FwzMV3qVwyDnLYITUt0gQ uqA4STq+yRJkpqtdi0RKEyx7lDGyFDaRCkw1ZWU8qbtAqo7ue0GzpM9nT1NW5kFBTveSQmdHR8Th eGDzFO949i2cf/oS5y+coQuBT1x5mYUGpu2Cf/TCx7l5sM/XPPwMj2yMYbKgbVtjTHe2B3ReCfMF b/YnWJx6kr93/Xn2uynOKUEDTj0SrXlfiKtUwOX86iVskveVs3b5de15RJDVlL1P14Y0aRV8bTwa XxSURUFROTQoIQS6bvHt93rd/mbjDWFg/uLv/PryO/7+T7YAH3zrm78tXLuxYjQwXkVKwWZNl9wq Ynkzly0+IqbSJgnpF8ltUW0iq0s6L1jXxMKRdFQtvAnRQq9M18/xfpBI6QuevHiRrY0hdAv27+xz cHxIITAeVlw8d4Yn33SRnfPbKSNkwtbE2o4sZaXwPrtRrPhbK+ecwaNkeAqBqki1LcJx13H1U9f4 5Y+9yvW9Iw67lr4cN01gn01siIg4ooRejLzQ3Ec7EmLCFlTwLhvtFZ6tphayqgSXw6Ql89epEjJT lySwlF6P0TySTLGPMZ1T+vCeE6irnhXJg8nNzrSvgs9ZuuwZdKm+LGqq4fQlElo2BmN+x+98L2cf OEd7a58TW9t83fu/iu6nAr92/WUjFyK8cOsKzcGUrz39OE+euIALJe1iQZx3aFSrrXQBH4R3FGdw mx0/tvs8u2GRQpaIOqtgz61IsgKiJGZ2FpQnGensoXkVk3ZIjN+oSlWWbG6vZRX3Xuc3XzBXOHzh reIdq+wPodkL2r0h9WLuuYH5P/7d71j/3X/tLx71T9y58wO0Tb9zGY1f+98dSUZhCaL0qb88NGuX yNKHUcn9aTJHxXG63OD01ilu7N9krzmy8nxrttx3DSycS72hjY8xLEsuvu1p3OYADo9ZzGcEhbXB gEsPX+CZdz7OeH1gzKiQDIcE82SyfokT80KcN8JEj0HEBPTGZXYon6cTYl2wf+2Az37yCh9/+SaX Dw9pYzRNEklpS8xV7/VjMsenFwqPvZxALUKXwhx1GAtXAXU4l2qdkmhJzoLk/lFBs7eT+h1GKwYt XarDiYqTlEdRk0LIyFHAxMBzAJi9FecdbQgJ3DVSXlzBurOoUw6nnORWvWZUg0aadoYTz4MnTnPq wQs475g3E2IZOHnxPG955imev3Y5aSlbR4cr8z0+dPNlNik5sbWFVNY7nMKhTUTnc1qN1BR85doD TBdTnjt+hcPQ4F3mtqTmJWphnyRssAd5JTc3IRmXZahvMJUZ1IefPMfOEyeSgLm9FkUMA3OmBeCL Apdy2zE2hNg+974P/i9793ot/2bjnhuYZj7548B/CvDBSw9r3N1Pryz7RC8DmiSDLct15/vbloBa Vgjlq7wz6Il0A614ywNP8+TjT/GZz36aSTcnEJJ7DlXKWWWiXXSWekRNaaw4MbYPm86ovfDA2RNc eOA0D1w6x3BrCIs5iV5KH950jRmZIlUDFwWUFXTz3hBl9uuyui4mmQRh78YRH/7p1/jU5ZvsTmfM YkcUoVTTvumzF6nhj0scDSvbudsbDMmTazUkIwoxOmtnohb6kDJFaGp67ywoceLSLsznsIeTZ7HC bo2JTJc7RWaymoWq0m8C2b52wZqrdZlqH13iLSXFvgxRZdyFlL5NvKjc7ldV+czV19j9q3+dr3vv u7n0zGPMjibotKEoHYOiZNItksflaDRyZXHA83vXeKxTTqyvU5QFbIzM+N1WWDS0almmt47Pc7iY 8YvxOkfaMUhGOKQqaZNgFVpSNizdG+PepVCyn8cpMymwfX6bU8+coVoriJpb4tp7nAjOlXhfURRl Mu6BEAL0JbpvvHFPDcxnvvO//hd++mPP/fG/+HVf+5eaOzd3w9XrrOIQS4d5iVDkFKEZDOl3QaN3 ZCqdvW4kU6tYasRUyS6MTvG2J97GU089w+WXX+SVGy8zjQtUjZw3QAzslRw2GRBKqlPacTW1dhAW 0LaceeAUJ87ssHV6hKs8zOfmqQAQ0pYdwDcQGtDS0shFAUVtgXVsk0BTXoVq3kxREDXw4kdv8Guf vsqLt3Y5jA2FCGPzQ4yijoUKmha1F6Vwrl+Ikhe5E1v0Cfx1blnV69Nkjs5qabLHoyldDIn9nAWo Uso249Umm6JJb3sZrGrSHM6ywktGqxUoxphJarGPCEtZpoA1gaVZvClLXArG4s7PtWmqePGIKgdx xsHhnOOf+Qe8+9Yub3/7mxGvHB5ZP6aOJQ+lFOFIG15c7PLwcIcutEhUfNshpzcoghJenyHe0Upg Y32Di+0pPtXuchyaXpfX4yBdx6xilyUxY/p3jy3lHlYpK4UIF546x+j0OE1/TZ9l867wBa6oKVyF SyTRGANRO7rY/a17uY7/SeOeGZi/9p7fVYZR9Z1NmFUS2g+0t27iuo683+ZWntmNvCvpwrIVCWRW 7zKDkXEAVWhpEWBNah48/QBf896v54FLj/CLf/85fvHjv8R+e5QWqslmli4Di5qyxKkzIVBrwYP1 JsMgJoNAZOP0mn1ZszBeS28Uk3HJu0sgeSs1Kkl5r64hDlBpYTFNaKZpvTCuYVDx4i+9yE//0gvc WsyJRDbF+gV4twQ8S4ytrElQXLCJG6JQon1876KpzVm63p7zTpYtNzQZVbGK6tzczXZS82ZCcjcc K9B6+oCcmdPei0mYV6bqwAp4nHRr3RKwzwLY6W1LbogsnaUi3XVrAZLT2EvqQSa3DaSgQ7kyOeSn P/Ir7O8d8uTTl7hzeMA0drRqoWKWUQ0xcrM55qVwwAm3RekL2r0J7sQacnYD2T1GmxaJjqrybFw4 iZ+9QpgcswipPIBkRCCVqFg/KTHEdqURQsrKrdANTlzY4dSDW/gU6we1UheHw/mawpd4X9qWqkoI HSEuiKH5sNz3YH7jWBtufsc0tl9f+pLpwf4P6aIhN6NaZb1ncl2nOY2aJ96SKwHZi7GLH1eM01Aq 1gfrvOPpd/Ce930dXdfxM3/3x/jQpz7MfphYMaQKdd+oK5oCXQJKuzQBiyic8QVnxhuUtEmwCZg3 3J1KTjc7p37TZ5nY0wyKKhWslPYzGNt7Y0DaedKN9WhUPvXrr/PzH36JV+cTRghDnzoSqprY90pG wifcyaV+QLmjomY8JmV0ll5N0shRTboqFopkd15ipMKn2jqhI5qPoZm1SvaNyBzUbASslUfySWRZ EmX/XHo+GlMVfDoGt9IZMatEWJiVYKtk0jTVl0VnVPvA8jJnb6iLpjo4wjOJc37lxU/w2q2bdGKB tCPLWCoNQiEwlZYPH7zG2eEmT26excdId/OY4uI21YMnWbx4HVTpupbTp06yubGJn+zhXaTErzT4 S7QKUkgUYx8aZWitB6kBXxecf/QUo4267+fknfnnrqgpigonVZ+0iKElakvbNHto+1LU8NzPfNc3 b7//gz/yhsNh7omB+c4TG1+xvnHyj82Pj6kDTK5fxUebZD2myd1LNjcZzwp2rg+IVquodVkRLCDq eOrCU3zVV30t5554kunuHf7uj/4v/PprnyQCdUqc+tQLKecqXPIGIpZ+HACbeNZjyWBUAV2yKSlD lLGWPMuJdz+XCSEt6OII8ZamNaHqEmEtVccBZSDO53zkl17k5z92mb3FzPgVKZ3ZB40roWIGPzNh RHIDssShyIC11VxZBs2lPlEZszCPIJqRicpAjJHsdJl2bROGorIUXsrsI/Mg7pZSykmy7LlkSyPJ 2vgEppvnsqLhC72OS491JxzHOjVGE+ZbPXZYCoypzYkqHXuhBSrKawc3UpeFpfGNKavTIYSoiC74 pVsvsVbUXNw6zfxwiu7XyMl15LJHm44YYXu/47H6BC+X1zhqFwlbktTYLxPv6GeVT2GcV7FGeSuG tnBCPSiMUYx5eIqjLGqcq3C+SvM/EhYtIbR0oSHG7rkYw98S4QNf8+d+5G/9w+/6V7a/+oN/5w1l ZO6JgRnX6390e+fUqeJwxuLqVVg0Kf+xDH9yOd+SOLeUYsgA7KpglAp9MZmknjtb1Trv+Zqv59wz z3D00mf5e//nj/GxK8/TkVvI2ueUmQKOrpBpleCMWTrWgkG0vs3N4Qxto3Fa5HMMSZbdz/9OWIpJ rgQkdlZIGQoIHtwAcYXFOG4DxhWLo30+9I8+zS9+8mUO2ganUKc8Z65CdpKarSEUK5mVngwHfbiR l7vFDwlXSQvSKPHa11Lmv6tS29wMn5vejhmbFiGk6mKVDLnm9h3pDiZvSTTdzZTRyrriMdV0aZI2 tQwV9Pq8ktmy1pLJXjIdlpVJYBktZ5+buzAoSwyojeZfVeTQzsJFUucGC7+ENklGeIROI5ebfT50 +xVqX3KiHiNHC3RQ4U9u0l2+iQZDcL5i4zyfOLjK83uv4fAUktsPLzNF5kknvAXpQ7IclmrSK8o4 GJJKXlxh9UapijzGQOgaQmjTY9hTDS+lwsnnAN5oxiXPnS/q+ENbw9+zPt78fYN6wPT2TQ5vXOsF u3NPsgyMZQOj/XPWIC0vmmUGV/oUtmBi3QNf8I5nnuXCo08wu32Hf/Dcj/HJ1z+FEqlIPY2cVWOr Su/Ga79jmhEa46nxBKccs+Dm7Rs0k4V1ae+NSfqR/KNLz0YVTRIO4rBs0vwY5kfQzs0LKitYW6Nj yMd+5Ra/fuWAuTgG4hmKw2sqoEvl+j1gmvRG8gTOPIxlzdYyPAlJ32KV3NZG0/XtxIxrl3beKhXs mZHou32k0NUq2n1Ku5qxW+JmksATScbEZV0YNRzLrq2shGsrIW3GXTQ3ZpQeyIfURWHFi8tzJZcO ZIZvFnlXZxmzLm0EXgpqZ018S8mC8FaUqmpheERZEPjs7A6/eOtFrs2PrB/T7gxODvvwdTqbcqob 8NjwBF58HwJGWer0Zs+xTOeSQdtMBUpJPsrCM1irrJo/OsMDnYmVW/1TIGbD0i3oQreHhpcQvaTC s070Az//p775WwF+/ru+efuLvab/SeOLamD+4OagdCJ/eHN9G20C0707aWnIXUajd5Zt1tLjAvnJ FAqQcJg+PUv2PoSt4TZvf/dXc+3Tn+Rv/89/hY+99imidJR4Kufs5qFJ5tHIdTksy534Bmr4zIKO uUbmRBZtQ9ibsPRaPhd/WWIvqql9h5qUAS6agWnmMDuC2SGEGdTQNYEXP3qT/Slsb57g3MYOa1VN 4Ry5jqWEJe+DTAo2vkiZ6lYKl0mGEUm/ZyGLTiONKC0RR6AUc57qlGHyiTDmE+lNEnbjk8B4GzqW yzulZJNRWcJm2hua3ktIwC6ifd2Oy6ERyTtixTCSd/a7BcSyf7g6T1bnjZcM+H9O+lqSZIJY/RTO QiJFes8rHwOAROEwLLg83eeF45vsLiYUhfVAovT2eQp6POPhsMbZYj2JWi0xmB5IJxm+RCfILYSN nWxhfFF4ilHSu/GJEuGMF+Rcauqmwfp9a0Akbifv65IIl1T02dyR9H0f/JG9N5KR+aKGSE74gwXu vRvjHVwXmc2PKX2Bj0t3vs8cQAIdl6FP3kVz3G8ex7LPNBhNvaSgKgp+9Zd+js+8/DxXjq6bG5+k M4vUOFlXiggzwOgBnKNIGh8d0VKWlFTOSgraoyksFrnEleXUt89CIzFGYjIuRZl00PJbugA6N+M5 LJheb7n8/B77h1MGg5qz2yc58oYyHR7v07bRwoF8nimMuEtQWZZilNlQ5qgtoP3fliwNtUtlBCYp YAWPVkqQe0zl1LQp5WtOrdq97Hv+5AyJT0Lb2UrYe5SlbpL06XAFKrHasMxuzaUBGWRWsePSpL4X yOUGyxH5jSMnCWRlTpUJw2nUKuNzxskIbFYuQjJIJuAdOaTh+YPreFewdXIL5kJ7aoxM5rgmMJUZ l4p13j08y08cvmhV/WrlJdmTjL0ns+RTdin8q0QoxQTcM0dIMi6VrqtpShsm5b2nI+BMruOSkrOd 8lLQ+Nw//FPf9K2oPCfCB37xu775ua98A4C+XzTR7z+4OXhARP5KXQy2nnnsWbbWdrh1/RWOju6w CPN+cqV7kEIVXTE4ri98NGMjfRiwzD4lHRYntG3LqzdeZW+xj0kbGZs1A6bWOiIVT+bWGmlHK9Iu kwvqxSkD59jQgiGeE2dPMD4z5jd6MNqnmUNoiU3Alx4pdRl7ZZxGFYrIdG/CR3/pZV67tYf3nkE5 oHQFReEti9W1ELq0KOz4ctO1TDjMOJWmq+cSfR6WWI15B5pCTEvHF7IEcEWSOBbgk3yBONdXCXca e43ZzIHxsgwtjVOTivSgl3rMdyxnt7IhAcsgedwSuJfllcw4SsaFMpaxakRh5dw0Z5Ay2Lv8vHyO ln6nFxkjnUtO2ctKb3LUnp9rYBYWIJ4HTp8jblbIpMPNGjqNrJUjNqRi1085jguadJ8kedrZQOe6 MO3vnc1nEDbXB5x78hRV8mLMMy1w3iXyp0usZYvArR0M83SF9tLnz9O3vuThpTeCcYEvqgej/yHI w8NqgGqk7WZUZYV3Bay4ltm4hLtccd97LKv7V1wBzFz/DkerStvNUIkJPLb9qhBL84YE6CHRSvTR fpGuutwiVmfTAa1Yh4EoIZHi4koqelW7RelCoJspvnBIvsJ36buQlKQ7Xv7UDT76mdcZjjcogNoV VEXFaDBO4V5gTyPTyRExdr1cQha6y0S7pIhrmjZJg6VMxkXT4gyqWXcKl9s6p+tZemvq5pNkoC98 4rNkpT+hYLkb9yBlap2aweWszUK/a68QW/r4h9Ry10KwUi0M6HQpbwAJt1AL7eA38dBEeklUZKmX a5mZxORWO6YWelypEDHVOZaN4laTfXZqSgzmO99ZTPjVmy+zdWqLi488jHv8nKno7R4za2ds1QO+ qXqcn928yuWjPfaPJjQpw1im1HKxYuwiYuESwrqUPOzXqcT1hJ9OodAOCd6KKcWEu0TqxFWKRJrt GFPGU/UlRJ7VqH/hvR/80TeEYcnji+LB/NHNwZuAv+JF6sJVDKshw2qIC3BwcIvj5rCvo8ng33Ip JrIReYdNfX779y1vYK5NzrueT2anTN0YzdVPtYa9SUpFaZK0YH1+1poI1iKoS3VJQRnh2KjHbDy+ g9TOao5yLJJmftd0xDbiK2faT6okSfkl+DssOLg94Vd+/TJXdg/Q0FGhlK6kqIwOXhUl3qfsWuyI oUWjLndmlwFT6XGGfJ2yl+3MjaB0CZjtPQv6NiO4DKSmrpew7NusubeUJjDdUsoZWM/eiRkt13tK OYWdQdpswPNOnO9vkXqDOzHAPX+H4RXGUM58mvw3y1C6PwJy4Lz6XWka9CPT8zV5RJLrqdzSw8h6 zbnCLbjkIcfI7cMDHr94ibWTO1YLNGthbmJca1LyxM5JTo6HhFnLpDFhVcSA5sBKFizVEQ2l4K1y gndUp5FHx4SNZfbUDF7sgfremGr2YCLaxQ9r5LkEVX74qz74ox/+Yqznf5bxRTEw7xkU3+NEfocA 87BgVA45vXWOEs/R4R0OZvs9tmBc3nyFLZVciPSZggxyhn46rTQNF3q3vEh3Jrd4zQWTiMXj9FPI Fp66rKJg07jA/q5yjhIzYIUIlQhx1rL92BmqEwOYponEMicc2kBoO3O5S2ehm8TlrHcOdfCJj13h V180OdBaI13X4kSoKtP6KLw9+txHqQuE2C6zuZp5IrakQwoRSsy4OpdxllS3k17PYUDmuPjMk0kk Rd8vNrOYQe7GR1bDl8zovdsDzNc2Z7foiX65La5koyRC4T219xTeM/CewpnQeIumrie6NIYsjRDp KFZTBPnZ1b7P2btbhaLvar2ky8/Ln5a9ZZf5Saq0XUMx6Tg/2qY6s40MK3TaEGcN6jzFTDl7XPAE J3iqOMkZP6LC02qb8CTb1koRKvGcZ8R7ijNsrq1x9HRFO8gUg3QG5sJatklsHqkKEkPyruJ5gaEo L4lw/t973xMf/qs/95k5b6DxBQ+R/ujm4Csi/D8zy9RpZDo/YjafsFGOKMuaEkdMNLtcLe0w+csy k8Gw3bpLYJ+57DZ1OpKsQkpPVitp50QNMxBPDJ/x6lKfaQMS+8UReyYHRVQqt1xIufPeoXbExTH7 r9xivFNmVJCewZO9FAErF0jV09bgxl4bF1z57C0+88INvEbGmD8fu5bj432893jnGY9celxD40kI AY0di8WcLnQmwZiMpNHtIUqkU2eZIRIGItCo0qhVXQ9wSTd2hXek1vHQAG/Xg8FOhEJzk7GlQetD pRW3QhOOkdeuptApL+QIqcYpFT8mYN2kRcUMCxYWBqybgkbwflkWkDNLUejDW8eSLJ9YUcmWx1TL xIqIltjuv/Lu1YzUahhjKXS7sOoCIQofee0zXFw7wyPVGFkb4B7YwTUtoWlpWkWlZDCsebAc82C3 xVtpOQjHXG+Oeb094kDnTKVlU2ve4U6wVQzw6+torUCz5COqggS6DorCWbZQrNQjik9lBIJKvJQA /Q+L8AHgDVWX9AU3ME74NhJVwVTYhS62LBZT/HCLsqxx4oga+v5EPUDJ6mTNJPKY9qpEMJPlvuTI 3gq94TBMxwyTE0epSzV4l0DjrMXbJ5lTzjNP4J4+l9rIHmjLrSt7nLy0Q701SOmUZZra0sWG+vdd WYvMGAOqkhdevMmV42PWxPdZlq7raGczJuxSeY8TGI83KMuStfEG2rXErqELHU3s6NKxVqKU6SK1 SJLu1P7r+v8no9IC9YpHYBM0eSJJ6Nwnw+KxxZl50wbspm6TJGkIZ/iNusT/yABn1qdJf12kb4u9 0UkbQVSa2KFJqCqoqfVkWYlc6gAQPf1ndUEpRehiLiPI9Wg5K+kQCVbwmuaFkSmXnky+Snmmubte SfIUTmmjhY8TbfjE5c9yohyxcWIHPxrAk+fg9gS9dkDbNnS0OI0U2jF2BevVNufcBo/VCw7DnMPQ MBTP6WJIORrDqS08U8S1Vv6RhKSzDc4lDYJxe0zxQ1GNezHynAiXAN75Z3/0T36h1/M/6/iCGpg/ tjV4K/DvQ0692YbWtQ1KZDgcMaxG/YRcboYOL6soyap2hqTJLUvtFkyq0Gct1JVjiAlv8NlYiCQw 0LIEpvPrEjEqdykgldqnGDJ9eUzZE3WBF1+/ytnbZzj7yCZcWylyXJUw8JoaZaWd3HlYq7jymZu8 cmXfhKITsBdJqdTQ0s4nHB44Cm/aH4PBiLKszMg0C0LbELSjC60pyGHGtU4dArNRzYYaVSqBSjy5 F3KnmsLPpM+SsAZzyIzRmrkqJQLqV4Bh6H2UdF+dz3VJ+StzV0j6XTnGFOL2Te/TPUpuhJI3IcPI QtLy7cNAdcZqToWOuGChZyK2aZLmRA1LyXm3jIgrSeZYcs5wSU7MEptZ16VY8ZwVA/rn2jFQz0uH 17h04yTPyIBQOxgVyOYILR1c3kNnC2LhaBw03QLEUTrPRrnORrFBq0qnLX40pjh3gubBdfzgBs43 hBBxPoJXNNgROl/gpGCZL+2JhNuCfiAGflCUDwN86Lu+cfudH/yxNwzQ+wU1MAp/gASRxJ6dqYTY EmKgrkfUoxG1HxJiawV8OUbPi9rmVrq0plRv7rF9g6T3OpZhkbFBU9yuVildSuxJTwVZIkATyUr6 9CaYGJKJg1sHSE1gatQsQifsdzOuv3yT00+eNJHmkEoF83n2lik53y5NdK988mNX2F1MGSRQNIog MSuiCbHraKfHHPmCsqoofYmvK/xgQL2+xXg+I7QNEmOfbSskYSs5bcwyNZ2p/D7hUh2WqQjpMS/2 jHP5ntlLwilzEzq3Eq6uypMuQ61evpJl6GHkOyu1cAiaey0nJrLvszd50bvUrtXC5S4BziIBUU8h zqqhxQyD5Cps7ScLmTelpjRmnR3Tsbi0CWRDkw/YslTLEM6nDJ0kjgrRil93Y8MLu9d4oNxmbW2d btbiBg5OrJt2zuXbxDake25GsHOOUEAxGhIKj/eOemsLfXAH2fQUgzllGfAhEmPoF4y4Au9KxFkw rF1EoxnePmwEnPAs8Lf+ccblr3zVo9pF5T/6pZeEL+L4ghmY79waXAL+QEzYSx/bqgkLhW6BQ6kH awwHaxxPDvsJ6nCpHaz29JFMZe8dhbQVaczcjOXiXqE19aBmIJHJkoHqwzFNO3SeTDg6MR37NqUZ fR/jm8uvyaBdv3yL8x+/xum3nYHDlZaxlYB4K2rMM18dWigHr97m+q09FhrZtkw5uVeOGbuUDQuB bj5herBHWQ2oi02895TDEetbO9AtcLFj0TZ90Vwv7ERuwL4EK5dWwMKpKqXzZ7qEQ5d8DUfthdob F8OJMCgLhqOKpovcuHPEIoY+zLSPN/NoUdESd1niQEs5DU9MmJEk45UgVl25L87uS4HSJk8m97/S GJJEZUjC2laGEVX6ZvNp/7HMTRZuSqLx5q2EdDttkykTSF6wUqme77nman7TE/YIr8/2eHn3Km+r n4DKwTzArSmcW7dJfvUA5jOyVoWKIFVBHFRIUZpUR12hBzOk8YyHG8QdpS0bYu411fertlURg/WH CtE6fJresbwkopei8tKH/tQ3f2uh7rlaS57+8z+899q//wd2Tw9Obv+9X/9ZPnHrFaLCX/3ap/Tf ++lPfdGMzBfMwCj8fgfjUlZSbymDowTmzZxmMaNwwqiqKaaSFMFcylhk5ujdDM7M2tVEpCrJu1Ui 22nSqJdcRiCErNovVhyYa1bAskSV2Hen6Wt/JaYzm72WnBCFZQ3M8WzK4a1jTlcXWOXBgOLKDHBE 2yoHApXjYx+9zP5sRhk11V+lquZEobfdUykkEroFs+kxxWSfoh4wGI2p6iHFOKDNjLaZW6fB0Pai RzkLEWISg3LS795BtEdl8/WsMJGmsvDUpacsCtZHFVs7I9bWa0brFesnxtRrFYUvWDSBD/+DF3j5 9TvG1ygKSl8mzkogBu2bsmWZzNy/egWuX8puaOLDYAoYq7UrFrI6hum1WumxOts4PHPiXThczq5l uoKHniCYi1ktLEwwcCp0dNmbIQuk9xJYtrlITIn3gJeSg7jg+nyfN01n+LFpz8h0gT+s8JdO040H NC/fhAOF2EDszDMJRl8oBOg6QtfA7oLhfoU+OWR2Fpq6sLA5F1XF2JcKdO0C1SYZGt1LhvmlkpL1 ofuhzbpksBhy/B/+UboFzGcL7hzvEWKkdI7p8Rc3yfQFMTB/fGuwDvy7Bpiu6LYkN6YLgen0gMl0 YilCX4FmHoz0cTFEkrRxX9eRd0OrfjW2a87o5V2nT4uyUlgmWXlNjAovNtEkyywmbCfm7IXAKKXI ky9F9qicGn9jVFQMN6uer7D0VuhB1p4eVkHTLPjMq7eYdgvqRPojc0acWy6uFB/GGGmbKd1kQjc4 hrLGVxX1YIRubLNo5mjsaObRtGzTVykgxYpX4gqCKrUzzyQbUy/C+rjm1Jl1TpweMV6vqbcG+EGB j4oL0XpFe2tzF2NLVZe88xufZP3nXuPFF28TioLhYIx3lkrvuo62WeDbBaHrlup+Qg+u5pLM1X+B NYlfppTtPHy6FmW6vE3KTAnLUpLVGrJEkVsKg0um7NMDvaq20XWauDu5kh7tQ1avK9XhaUQiVvdv H3a9m3CjPeaC206hmqI3DtFhSX1hm2JYs7i2T9jdRXUOowZdW/S4VVvV6M4aXL4Fu8eMPjLDnys4 elzoNukzkSF0hM6KHbvQELtAjBEvbMfISypc2okbl05vtbgyok2LHnaUOuL1O9c57ho7k6gsmo6/ +Y1v19/7Yx/9ongxXxAD4+H/rvDgyr9X0AijbDfNjMXi2NTukyZt5iBkI9H1EFsGFOlTITFpoPpE HNMscg3GF2DFxZVljYlLjdVajag6oouELKCcapOzTkqZLlCHJrlJ28NqXzJwBRubQ8r1OunvssJV vzv3Re2hVV799WvMFg0OTWUPyQi4HNpYXF0kIWmNStt1TI8PqOqSYT2gKEqKoqQerbG5tQNNQ2jb BHgLwVvtz/bagPGotD7Rw4L19ZKN7SHV0NM1kfmso649g60Bo6qwbFcWJJfY92CmC2gbrFl9BIqO clTypq95iO1zO7z22SPmOKpqaKn20DFvpiymExbTCV3XJK2X3IXg7hA2h4WqudZK+lDT7klODsQ0 f2JfIuGThEPo55l9R0i4Staj6YmJPpPrckZME9hvGJhPnSqL9DckIW7Xb3cGCi80UEvBbpjyUnOH 89UTFHFK10VeuPkau8dXuPjEIzy4fZri5Bqc9Ui5gPkMcQFftkx1wbyas3XqItqMiS/MYD6jmgjr dxyTRxxHDwtRzWgTW+g6YghWNmKg+Z4GfhDPt+nu4iV3oXyWqkWqAOcO4MUhVVGyWY85WEwM0+wC r1+588WwLcAXLkT6favdFVfXHqQ9JgS8wHR+xNHsjsW3yUQY9V1ZbRZuO5T0NzkgveL9Ui4q6ZKk AjNVTWiw9FKOmTdT4FZKErTHLxwm1lyo4HzKQGfwF1sclTgKD/M2Mp8sllqe2WtRw4gUrDBtWHE8 C3zy+SupR7aJOfkeZpb+81fTty1KGztcM2d2dMhssEY9HOFKT1kPWds4QaGRtcoxGkbcAI4mC9bW C85f3GRQFeZxeajrAj9Y8ipDSIJP3hq6h1aJbbeyYbsVQynLeEOhPewo1h0XnjjBeGeHm6/OODpu UxZHqMOIRTVk4kvm0wO6dkFM7QGyhkwmB2bnL0rul5Q2ldSGVvr3Zs2YnEo2Y5L5Ok1feX13cWX2 kpysmjWbUVnWMrOZu+ioJGN2KdTVTNrre0f2NIDj2HJzcUxoZhTe05bCp+e3+OiNawxvfpo3n32E rzz/BCfPbhK3PO1+C7OW6ANu7CjHgTC6jTxUgI7Qlzv0+BA/hfGuI+wJ+084ghixTjRaQ1ADq/be 9X0/spNO9LnX/x+/VzV6nE8zanOGPniL6rjireefpOkWXJse2LVedPzA+5/Wb/+Z57/gXszn3cB8 z/bgXxZ4T9BleBRWvqhXT4ktt668wq3D6xwvDvtFljsDuBRXF+QYOE2Z5N671MvIa9px0zYV0t9m HCdPsNxADF2hybPMTrmV/vIeoXKZB5NTrKkBnBgPAYS27WgO5zBfkGnhqGEC1oTLet74UpjdmnP7 YEpAGXq/BGDdsoNhTIugSOBkFqZcaGDSzJCjPfxwyPagZnNnk+H2CbQ5AfGA4WgCYUZzOKOoYLBR 5QuNdikrtIimTZNKCToEXawAUm6ZZl5Sz9Jjrj0A8JFu0lCOS7YvrDHYGLF7bcHxnQXzeUcoS5zP EpiBxQTDDrIJiJmebxwTciapD3EgK/xlc+LE9T2ESHNLxLJTPgG2mSUVE/isWTaUFUIhuS7IpYJX 7cmC5rmm89TQ0yMyYcip9Bhgp+ZbzUPD7ck+G6MxSM1R7DiKM/amEyavtRweH/L4tdO85dlHqDfX aOMBYbfFLWqqKGg1R9Zq3NNKt1nTftyjd46obns2DwUWjt0nHFrk/uR2Mr7jT77473zjpfpAXww1 e4O9gB60sJ50hwpFNycU23BBznD76AK7iwldClkPbh/wf/ze91763X/zF176fNuA1fF5LxX42mHx PQ7eKrIUInIr3gtYEV4VHfPZPkfNIbnZSC5EzBiLS/VDmia/jTwFHLkTYWafQjJkCQ9Roa+WzUZh uUykRwR9TkMiPdg3QJLHpL3tyGX0hTgK54gxsrkx4NSDm2kSRksBR/qUui8c0kVe/uR1Xnz9lmVR nRne0iWQWo06jyxPM5CU8vP3pkzKaFBz9uHTnHrrOUYXNhmcWWdweh1flnigGhrLs2ts14vRcCXN pLeMAvdZniUNP2dy7irgyddzZf9HzDCGENAuUq2VbJwdU49qtHN49ThXpBouJWqXqe1GG0jurery q6Lkhnj5/ltoElL2KBJSoadQihW/OnErlcnL+5Modr1/mKlJS13ipAWTNxlZNujTVDOWCdlZ9Go5 Q+wC5MTDhh9wcn0b7zyqgYP5lNuzQwIGdO/Np9w53qPdbzh34ST1ekVsO+SKwPEIiWMj64UGdIIM FtC0xJng55H6jhK9Mt8S4wtFy9S988/8yL/ynY8+setb8C3DcuYoTiqyE6y8InO2OiEc1bSh487x Hsdt0+s0l2Xxh//3l25+3xfArvTj8+rB/L+2BxeB3wtmXEK6qTFJIlghnTPJgNgyp+0ng0raSfpM wpJzoQlj6ad5zhCpXfQiufM+maPC/nwZm0vGfugV7yMxCStn4M+MSbXivUjSiLqbAggtwRjBUVk0 ic5d286c22hkiNCXntnRgquv7Vkz9CyLIGZoc1iQBZ1J5wukDJOdc4gdAwIPPVBy/vECKReExqdE bg3lDrpew2IC5QTXzaGdoWEBbbMS7rDU8O3TTned4oqlyRc/59OTkUnENRFBuzndYYRqwdqJddZO 7XB0O3B8c87goGZYlNRFwZErWMwmLNoFMUSTi/C+r5ju772zMgnnXGrNkaQXHHQhcjSfs4gtpSzb yhfJYEaygHk+Fek3j5iJc7rMoMXkDYtkAiC91yLOaodEu1TlLYm4p33hZ0dkFhvmbYuOhEm74MLG Dmu7NQfdNJVjBPa7ll+6+iL+54Wn3vUQmztr1FtrdLNtpF6DOwqdx/kZUjnkkZq4HoivKUwD28+D dMre446uFmh1D0BC0ouJDlEPC6WvTkUQ55Aq4kuofUmdemlngbCbN/f5X7/lPT/0b/zwL/2eLwkD U8DvScmZVB+k/QRwIokklfAP288S72PJ13VpsWfdkaXHkpm4SfAoTfYCz85ok/l8woKOQhxoIqDl qmIka2j0+7AR5+w5lwBXE45w/VoyfEB6jkXOJi2i4jQgqsz3Z0zvTNl4bJN43EJckQAQwCmzecPx ZGZtT71bEUIyo+dzG9cezrY1XbJsJrdWlLz1rWe4+JZ19PAOIURk7SRUa6brWw+QskQH6xAapJmi i2NkcYQ2U+hm1tnA2jAuiSK9R/O5lmblHFbSy32oJGqf55IwVRMIx4qUHeunN1l/aIPQeBa7U6a3 TzK5tcdkb5fp/gHzyZTxesXmyTVCpzhf4EtPVdfU4wHOWdZKfEFZlwzW1yiriunBnF//hY/x4uVX aUKH01QBj08ebFiCu3lDSjtIzEYiG+x8Omr1Tlk21SUQ2pNKJvBoip9dWDKAg1onyeN2xu7kgEd2 zhIjjP2QUTmgaH1f3Q8dLsAvXPksL8/3+eqvejMXn3iEcnwOndUwbdGDGj0siWWJG+wj52foRiBc dsht2Hk+Io1w52n59uD4QL5V0UHVeiM0d9nTyuxmwIMrYVDVVrqSrksUQZqOxaz91i+Ucfn8Gxjh W0gLJxsBFaHKXosslfFFM+l5CXDmnduxTFWrZKpR5rSYElqnineec1tnedtbn+VTv/YRrhxeX6Y3 U+Ox5cacHGbJqikrok0OCu2/0WpvVne1u0oQ7NgWdIgI1w6PGD5/lcdPD6ic1R4tv9Vu8vS45XjR JjYsvSxByrj2SnEuh2US+2xZi9HW3/zMWR5+20loGtrFAgkBFxXWou2CvgRfIkUNMobBBtIt0GaK LA7R+SHaTqFrQYMxjzXQK36DWdS7gtlVo5N+Xy2FQO1vovkONEYA0ySU5KsRo3NrjM6ssdOdRds5 2k6I3RzpFvhFQwxizRm8x3mbNYumo5l0FN4hTji4uU87a3DO88gTDxND5MXXL5suijqcs+vl1Eq+ rI2JGcGQ5loqo8Sn2iWXQvAocelpI/2mmAF3VW/p876uKmWhUih5EFv25ofWicGXFB7W6gHMnElp qdLY1SFox5XJIR9+6SobDz3OmTNDWCtgt0DEE4sCt1vBtCKu76LrE9yTgbgW4FVl68WAev3Aw3/r x37PK//6N6rMwamjiAVefCqdWCE5hogLgU6FYT1kWFT5svRY6OHR7AtpXz5/BuYv7QzeB7xbE8qv KtTicep6fkrePTKJzjyGDKQlGvlK1qgP+QWSbj4D5yhUiDSM3Ii3vOVdXHrmaa68/CJyeGPJas1T QZeGKrvAiCm+59YVOXzK68g5txR0WllekqOFZA4AruiM21euoZ+oecs7HsRHT7toTavFO2KnTI7m RA1ULpUnpVAJyK2c8FiIlzk4HqElUonwwOlNHn7GEgbtpDW8ppmgkwixQ8ctUo+Qcmh9l8QjZQHl AOo1GG5CM0W6qQmNdws0tNAt7Ec7I3PFzmL8mCSs4orBWRbx3M3x6T2cdCzdnLgQiIrUAamGSFHh qhJKD10J3TG0xgM6vLzLrcu7OF+wdXqL8dYaNy/f5spLN5jNGmaLpsdevPeUZYVzjrV6wLSZG96l 0bg9YshNIUJ0RqjMzeNInrElFpftavuq8Kh9CK85VR5zCYoj6gqOxRLLicBhM2fRtgzrIaKOypdm KGNH6YROrTyjIUAM7E9m3Lp8m62tPartbdjxICVO1lFfwF6J3inxm7tofYw8sCAMgReUjVfit17/ wDcqk4Kys/XlE0tcSl0JcdNj26KLOb6oKH3Rg+FlWnsHdw74G//yO/Tf+vGPfEEySp83A+NF/vWi rvCDIe54joRcXm56rrkZuMkxrAK2yVvRVLyYGLpxZSeNGq0JPR6feAy1lGyNNjh38SIyHlC4ggKh IdgEy2YhFcE5yRkb7eVxje0ry37QiQbiMijYc18An9xoYi+K5RAqYMMVPPDAjtW8hEBSQsSrMJvN OdqfpjIGw1T6LgFprbpMrHOxh0o0xfnb4yFveud56toTpm2ya8bs1CZCbJFuitYbMNywkKkaoUWF uALx1qpWqiEaNpMxCUho0NCYlxOMaUro0LZB2qkZsNCs9NhOhsR9zjz8XI8mNGiCfDS9rqp2HM6D r61VyMGCG5+4xbXPXuH4yK7PlRdv4JynCYF5s2ARIm0u0ohAcDCfUTgDsgtxOAcLXelnxcoiU4dI tD7PpIsdsxxqSj9rBnrpywBimj8iOWupPdAbEzKdN55I4CDMWMSOLVez0JZxUVOJy5qWxq9SWwfE lsPJMS9eeY1BNeChxy5RbW/BZolqaWFaeRrqinBnAIubuI0jODVD64j7tFLcCsShIsMCvKAhIgM1 WvaqcckucteiUvSN61aVG2OMzOfNF8K2fH4NzM6DD/6rfjREpguayS1cyqMYIKZ9b2FzQyVleFg2 Uk83MZOfst+Q2bseUzwrxap9FUVCJC7mCIHR2thkBBLQ50li0rJCrMImYCdLYC9jOTlk8aTqzCQd b17OSnGlLFmjISrrUvLo2R1OPrhNmC6IXUoTqiKVZ7bbcnA067/DkyUl6dvbrtbOKJmLE1kvK554 +jRb58bENiQuSZo/Aho7aCOqAboZujhA6nWo181rqcZQVFbV7DwiSZ40K6VlSczQpVx8QGIDiwk6 uQ3TXXR+1BdyLj2XfgWvZJjowV9CY/dHU1o8dkg9hmJA6IRmb8GdTx9w7ZUDDo7nhK5FIyyaBsTZ vEnM2DIFy5k8p6JW+tEbtojKElMSya1qlzo/dk1TEsFlXRjtD9/ueS4dyJ60JlHz5SagLsk3CL28 Z0CZhDm3J/ucXz+Nj46BryicJ0ahUUssdJlT0y24fbwP115lf3bM7Ts3edubn2Fw5ixsDEGsfYnz O0hVEW9VhJvX8CcU3Vigz0TCpyJy3NqBjYeGeg4V1iPilvV7fc9eoIstEkOfXVvyroT2C2hgPi9t S/72N/yOt/++j37m0nBr++t92+FCNi3a31ySocmymEv+wbLILvMUMhvBYZTuItHoe15K4mdMmwm7 16/BbM54fZ2qKAz/yaru2QWWpE6fP9elRuUpVelFUqMsm0AZA3I+ZRNy6lPuVk8LRNbrIacvnkgM y4QAiViYVTpmxwuOjmZ91sin9iA5GbOUeMxMZjN0I19w4dwGZx/ZILamA2zpZO2zQNb9MLdCmcBs Hz26Tjx8Hd17GT18HZ3cROdHhn+EheEu/d33iK+QwRpSj5HRFrJ+Btl5CDn9OLJ9ERluQVlylxdD z1bpN4ee2ANmwIKFS7QTZHEEiyPo5oTjBZNrU+aTiAxHVMPayhHEWpv07UMkJjJiUij01lzNO0nq buY/KEKhVttTOJP5KFaY0ctrbAp92as26U7rMFGLp9BUe54TC5pamaSJqFn1D9dXWmcco9GOy8e3 WMS2791d+gLvPKS5lbGRBmXSzrm5d4tPXXmZn/j1X+JnfvanmV9+CWYHaN1AXSB1hWxs4M6ewQ3O EW9uQiiRMbinPLIBGgLEGbIV8ScEWbOTvSvJgENLRxdaFl3be+eZJaYKs8mMH/6md34Ouv/5GZ8X D+Zf+3s/91GAf+3Hf/q5//XSw70OiMs7pNwt3JTdU8k7jgguJu8m3cyY+pclxkNica5mc+wCHR8f 0C4WrG+MGZYVx+10SWLLmE8qbVeycjy9m5sJeQ5N2rJJGW8Fdc7GiuSJkbVOVFhbq9h5YJO4aO2Y /QqYI8pi1jJt2tSozGQIjJFvxiHjTqmDfGIUK5vjAecubQHWW0mXegQ9z2eJYCevRAOiHYQFLA7R xSGUY7QYJoxmjBYV+MJSC75CfGFpTV8kt64AVyHFIOXeO9hrEii80pql3wnpjeJSMjsXRUUIC+Nd tN6wITek3hqy2W1bEWmzIMxbmjgjxpjS/KyEIEvuSa4jyrVp9KCs/RZTGraL0nvNMYFv2fkqkgec NzCfno9p8+u9yKRboxi+Y9+f+DGyDLlKHHNVrk/2aUNAvKeL2rdcsQJbxzSVXjhVYhc46ma4xQLv 4e+/OKXSyFc9+xUMzjyIyoaFkq4Ct2Hr6NqccLWB0x0y7PBPFnCtg7KjeMQhJxwy5C7nEgX1gis8 Mba0sUMlMZ11yW4Obcvx/vEXwr58fgzML3/7H3g5xO7hr/rv/pqMxmPT6Wjm1nKjs+nQYyqJi2JF aIl1qXeruZtAXA5pDAwmu6krSH7UyGK+QAV2HjrH+kfWuZPo0DbNbeFmFMElMlt+PZIbbrleTLsH fHMqVrOgdVpamuTDFSpxnDixwfj0Gs3eZLn48yIUIXZKF3NLlOV39O8Se77LfpIohXNsbNSs7wws jAyKy4ard5JWi/F0xZOIVmCoAvMOmil4j04r8JUZDV9DOUDKAVoMoBxCUVsGqhzY665G6k1YO2Oe UTMzMthvSpxZHSvHmQsd24Xt/N5TDQdUZ7dYW2wxurzGcN0xqh23r11nupgueTHpM/oCxhS29mF3 ek5jzkIKHYEuWhDg8mYkS1nR/kolztWySRtJdjNvIEvvZNnehJ4kGCJ9WKbJU7rTHXEwP+bU+jZF 6jGdehalpm8OJ5EW+s0iZ8H2uyN+/LMfpxzAs13H4MQDqNuBYojUFW59A5ozaDMn3pyhpzoYg3/c W33VKCKVpv652RxbBwkZQDEoCLcb5rFJRjRdE839wEDbli/E+C0zeT/6B//Dryuq6g97hd9//sI1 FzhflvV554ulxI8sATUny5OK/Q1OnNyERdiEME2YzND1ifptO5hDnfkwm8MNHnjySYYPXuDOiy+x u3+bLjU27g1N8oqyEn428IVz1qM6E9pyqgiWfJy81aUJLkn/JMbIuK55+MmzbDy0RThuewA01y75 tZq9q4dcvXYnVXg7C4/SxzmXMCdZttRQgbrwnD63wfaZcQ+SOpf1fultXz7Hz+koRWYV98YmJK8m LKCdIu0EmiMj5TVHsDiG5hhCC65EykESS7LKc+1DnHbFnsj/xSOfc0yAOKQoEKmRwYDqxJjRzrDH 1hbHc7rYrRQ8SmIx04eU5IWe9yvBsLesTJi+Z3UC9CxllkztImWHUjF+b0D6DUas5azqUiw9ZxFJ SQmHos5ZwaUGhlRc3DjLYTfjs4fXOQ5N36ea7HX12CO9lo6qEEPH3uyIc4OCE8MRURwSS6SqkLJA 6hIIaDtFmxluE9yORzaTfGktyEiQ3KUn43ulIFpz67VdXr51lRCt0tzLst94megT3/6uJ6/9z5+5 +nntTPBb9mCChm9wEbRpcU33gcFg9JxW1Q8Wg/rbXFk+2ywmLBYzmqalbZslnyClZkMSG3KZD5I8 hD4jyhIoyoYh79hRI9PZsfUeLmBzZ5vS1cziMRW+Z1xmIG/JGTc8p1RSJbP2Is85MtIUyuQ+P5oq sXuynlPWRjXjzQE672zi9IhWYkDl5s6kmN9lY7nkKmQJSwOYl7uxL4SicnQNEI3y73qVvLx+7sZF 7r5Kqws9g685MG2g8EhoIZTQTmBRoPNDW9CDkfFqRJKnM0aLGtqZpa5XFv1d3/EbjEv2qIAQoGvQ Zo76uWW4igq/ucHW04/gioLYRW5dvclsPiMLc+efmLKBPnWYtCzPsoAxy3X2FfWaN6tE5FzRKC5W THIfsuuq3IdJhsZ0DKWkzo8sy1Q0qQb79O+gkZf2X+crzjzBmfEOQ1fQSarFzpKe2Wjq3QZL0jFe Pzzm8rXrPL552q7esEJDjdQlUo0QTuPaA3Q6AWbISGwFe4HSOjD8Bs3YAty4pZUpTdf2SYzckaLH Q5uG2f7hDwA/+Fu1CavjtwzyzqZHx9Ojwx+cH+w9+u6/++O/RzW+5Ivy2+p6+IPjja1vH2/ssL5x gsFonfF4g2owoq4GFFVFWQ2oyppBWVMMasqiMJ5DWVKVJUVRUXqfeAjJtEhO65KqbROFbnLEqfNn ObG1ZRRzdNnOpI+zsxGQlMWRXj5RWNL1JRkTs3fJg+h31KwLoozHQ8bbI2gzcLrkhzgHLBoWsw6c JkDWjKsmINMl3RInWcEvCURpoJl2FLXNFl0RqZZ+cWRDs4LNfO7IKRBZfT1ZTlxKG1eGu8RopQXz QwONwS6Wrwz8rcdQlMmbW1khq5Wjv+G70vep8T/oFmg7gziH0CZ7X+I2t9h46hLn3/kM5y89yGg4 7K9/4UyQy8DxbKhZep0sM0G9ZKpmfGVZje/SZxi1IGvv2IZiiy51ShCl00AWh0CWyYG8YLwoZTrA LDMhCE0MHC0m1K5k4GuKxMPp1JQBtMcC7XgCS6UPEZtGv3b1Ji9ev4I7PkDnt4nziV07L7j1Ie7k KaTeAVfT9xTMLmDPfegXCkRBZwWzw0kSNVMqSBrN9lMLjESQdvFbNQe/YfyWPZj3/fd//c8C/PhX Pqt/921vYzY5oqrqv+Cq6qWirCjK4uvDcEQ1WvvJrl3QtA0hdHTRYlARlwxArhFKa0CVLkQIgTZ0 hK5LDc07VC2DM3QV5x95BK/K/guvUQwqHnv6aQ6PjrjTHODEp3V2NzkKMXHslSWQ1khe5CvHgSQF 96X35J3noY1tLj5zhnJc0i06xOWFnryQyjPfnTM7NN6G06TI71I5QLQF7NPcyNKiYOoPxwdz2kmg KB2BaG0rfoPbkGMGWUnbZsPzOZ6MrPxtPmFXGeYi3vCV0CLtMSyOkcGGvV4U6GADGe3A4jilnZNe XB8VfU76Wla+I/vq0bw8whzmE1QqxFeoKxApcRubjEcVxWiALwuufvZljmdTA2hxvRZylNiXcPjk xeTMo9NlqJn7Zudqfvps0qoMBWQx8HxZQvKw+0JMXYpDWFHkEpPxLBtK2OueAEwWU0LszGmUJUam CTcLCt4ZqNxhRiYX474+PeIXX7vM1tqYU2WF1htoN0BKA+Ddxiau2yZ2U7NILsAA8EmAPc0Fw3kc YeaIR0KYTK2TRDa+soz8LbOruG4lw/h5Gr8lD+Zvf+PX1QD/2/vfpYc3rnO0f5vD/TscHe3/ifls +pNf9VM/+RziKarhpfHa5l9Y2zzx6Dd99GOyfeLsoydOnv36k6fPf/23fOJTcvLkuUdPnjr/6InT 577+5Omz337y7LmvP3Hq/NefPHX2w1snTrO9dYLNjU1GwzGDaoh6CyNOrJ3ggUcvEbuWZjonBuXh Nz3KU08/xZqv6DQk7yPteqR08Mp6EJcnpXkn3mVZBmt05bPgN5GWjmFZ8tgj53jb+x/nxMVtwiLc LTiVZqqI4+hwwXTRUmDYi6TdXoyE05dS5D7Y9v22UzdN4Hh/jvOCL6X3pvoFnTwI27E1gxErOcrf hLOyYmzsGBySygukGNjFaOcw27NwSKM9V48tfb1+BqnWLAPVfy6f87vebVwyJpQJgqGDbpKyXBPL MmHiXxRDBg+e5dy7nuTC4w+xNhyRsze5Y2WR7ol3S8KC70H5JZXAJ8+HpPNjoufLkGa1M6X1GDLP tMthS++cLQmikjgyq5iOlb/knlGJtFlX+KJYIWTeTRzNXnWb5Ut7nSOYK3z8zh0+fPlVJsd7SLdP bGZ2K8QhwxFufRu3ObYaNOxA3VDusu8GFArMS46vHTFdzFJrYus+UYrpD9fJoykUfNfx0//CWz6v 6erfkgcTCf/GD3/T195srt9gMZmaxkjbsGjn1O2cn3zXO7VtFt9eDYaIc5fKov6hD33Tv3Ip+RQv ocIvf+PvfgkRoshzgl5S9KUYeUlwl1D9k8TAV/3dH3nu/3zf132gWUx/cjaf0s1gLXiefPNbKQcD QgjU22OrEvXw2NufYD6b8skXPs0szKlcmeLkkOa9mmZLShv3QGnKR/ucJneauDlK5QvWBwMuXDzF Y+96CDfwhFnq6uhWFlICaVRhMWnomraf7KqxD7Oyx5R73jhPHyYJrm9A75ygYSm7lDTve4Nxd+eo u2bYyuK/O728NEKxJ91lo6OhgekujE8i1ej/T92fB/uWXfd92Gftfc5vuNN79009oQc8zAAJDoAI UqRCUwKjWI5I0yQ1OCq77MiwS07iuCo24UocZ3AiulzlclyuuEi7Ijty2RJFDbZsyRJbBiVR4ggO IAli6m70+PqNd/4N55y9V/5Ya+9zboNKFRoAlVzg9n3vvnt/wzl7r73Wd32/3wXSIHEGezdtC8QW Tu96NtM7JsM/4vnf8tpKJtNvQVYQQt2ctDteCi5obt7g8Y++j5wyr37+y2wHowaLFiV6oM+5Zpo5 F6xN6/X1OGrYm6vjS0fHBs1R8Tng7qY6AACAAElEQVQj+JZrqxW/KdMrpiXSeAdGB8byEURoiDx+ 43GuPjpEz+7BRN+t03lQuOCwvAaK2bhy2vf8/Bt3uH5tj2/buUKzdwhpx0iT7Yxw5QqkqyjnBryX 7CXU/Bkkk3sh5gWP3vwiJ9u1+S/XeF8Cp4/LRYgpk06/vu3qrynAJCSGof+pfrUlpUQQ2KaM5IFh GBiGnnnX/cSi29LO5/9yO5s/H9v2EyJyu8LdZTGgt1X1RUP65eMicjuG5hPQ8ks/8CPPkzLf8d9/ SgD++nd8p948uMlT730vMo/QJcS9R7arNTtX9vi27/so81nkM5/7HS7ShpZYldWUmpmMaqzla1kk BfADK13a2PDs07d49+97huWVBapK2vTj/n0r7qD2vc1qy6ZLNKXHXZzUKBoXWxSqpY3p4UCVeRvZ uTqzfVmykaCXqpzyPsYN/o/6Osk0BIRsqX8eRrwlK5qzYSPbM2T1wJjAy6uWxbRLZP+WaZ2aBXr2 JnLxCNXt+Nj16+Vy8VJ2kzMqPTJsxiynKk6XaIhIs0Nz8xZPfSyRU8+dL73OdhgcqHXhLMK2gK6+ sYIWH5hiIG8lTxmNO9pg2mtRTCOkWqaFau0iFeZ2r7b5I5HsmGpfboPbkNjvZNZpy6P1CU+3Dfu7 +zQSGHIaZ3FpKb2M/lCwtOxCzeDlVBLlwXbNZ7/8gNtXHnH9yiG6v2eSjyYgYUmYXSMPp7DdoJLt NZeMBoVBEY2sH3bcefM1Uk62zimaK/uIvnajl5hsv744zNsOMH/hj3zvNRWWw8X6cDhfkYQa2TUl kq7pc2LbdVyszlgulj8RZzPa+ZLYxE+H0Hzy+372Z58H+Dvf+323qyAS+J/+7KeKy9Ynf/6P/ODH Q2w+HmL4+C/90R/5KYHbO3uHXH/6SbapYzFgZcTERHp9sWY2D3z4+76dnf0lv/Hrv8Xx5nzcApMF l7BpghFxGcJ0LwoxwrNP3eKD3/1umr2WtO3NQ1hdEvAWPkg906JlIbHMVmY8PSsfWOqB5pvAjhfJ xntpmjhmG2OP1h7hH9nBmeI0Y/9NpsVweeKhR3EbB9fJoAP0F3b6tgskRJMeSLC/xxtIMyOXLtPF QxNOltehMCpH64UsO9K+lUHTgARjIKuXKYQIYY6GFpod4q3HeMfvz6TNwL3X3qQbCvgamc0aGJI7 y1kmGCkzup3SjwUXMzgfz4Hs+EwBw5LY5IeyhjLmw1ymF0gpZTFV9IjrSC3Pkgr304rfePASj23e w87OHm0QNlkvOY8mtXIEmRiROypdmP2DwlKE5UUgv9kx7BwTDvaIVxYQFggt7F9F8k3Y9DCsDKNZ LkwOMmCHhSoPXv48FykxcxlNUONZ2SHn0xn8vUUPQJ/+ox/98Y/89V/5JMAL/+oP327m+/Lsf/Cf v/B7GmD+xN/4u4/+4g98L/12w3a9mVxEJ8/lzNBv6QfzlF2tz2naGbFtiNJ8JIbmZ37qA+9Dg/Do 4V2SX+2M8ue/6X0QG2ZNy4Oj+/zRn/+HNRP97X/2X9Lr73yOMG9JW/xUK9waT/M103Vbmijc/tZ3 s3+4y2/96md54/49Ok3uq6pVOtMJNKrgvIiCHmTg+v4+T7zrJs1uZFh3Hiym0WEaZMZChkG59fRV Ht074427R6agxkBC8YBS4kVxgSmWjQlBc/EpmXSgviKATMuft2QOVa1dgNbJj5VooyaWxG00qSpq 0O0JnNzBTTcsyIRojN/FFWttpg6GDbI5mwC//v7fWsmPJJLxdeYMYmRARRGJyCJAM7e2eM40e1d5 4lueY+g6Hrz5kCHb2BLNyqxpYBjoDaAwMZ+PiR38/V/OYGScQME45xzvMJHH6Y9VRe+prGpicCJL mQudtQ65IUqg04E3tg+5sz3ixuNPcvULVzg7vVsLrGIRUu3IRpx5LMuyQFQaafjw/hNc6XZI98/Q W48ITxxA29p12l0S4y1y14BurQycWxnFIIR2YDhakdu7XLv5FHmzYhi2oNmwJF97Bd9Sn7MUo/CR v/4rn7TAsvvj7XL/R2e7B/868B/+ngYYu2Dyl7rV9idyzmOWrkoO5aIpiUTOA1kC/dDDVog+vLuY KZf5M+XkMPVzJIhwPJvx577pvbpc7rC/d/X7V/3601fy8JHlbJe2EaL26Lqvrb/p6TkMSjsTbjxz i4/uzXjjxdd56Uuv8uDilMHGPpjWyIdx2XBO32sKbQjceuKQw2evkDp1prxeyhe+ctNbtpL6xO7h kiefu8bJ8QWbzs7E4KWQ7cWpsqkAfkobLcBszjt2ZrOxRPqK5/3duCcObIbJT1fAlbGesCerd9LA QgFtQLxUWh9bizn1sP8YsrxinaUQYbGP7FyHiwdo76NzvQ04djP8219RrmXGES9qc4O22ewqQ2Mc mdBAs4DlFXae7rjy2hHnR2dcrDd+tTNDym6bqd79sXEypXOfgvrETCvBClaTffZ1RglBXU7g2EQu +IxJCmyG0qhtG70KSyZq4aNzw6qkSorKe557juu/ccBrZxak9fKV9gyisHrtuWq16N2wnTizbuq6 I5+fkFdHxNkS5jvQRGgOCLO5vWgN0DZARKIiWQjpDteffDc7B7fo1+f0mzU59eScPHkzWKNkOwEl xsBL/9w36/Lqk7SHhzTtDs1857v+sQSYP/nf/uzRf/LOp1ylapyA4lVKEYcVtbRmhgySxSf0mVDA zH4CrTk1+fhSsel1IZK7gVXcstls6dLwM//Up35WfvFH/sSP7105/LHl/j43H7vObGeBDGaco0kt G7K5H3TbjhDhymNX2D3c4frjh7z2wmu8/tpdjjcrn30cnAdBnUYgAjcPD7h1+wbNrGVYd2MrWKZb +yuzC/WNo4Nw4+mrPHO05gtfvHOpWyST61R5Ng7CRMdeL443LK62BPcj+YqgUo49xxaKLLswkqsz Tk3LwgSzKV8LezCMwajy5Qd0ew7ypv1obGAWXa/UwmzHPt1wCZKDF5cDSvUC9I5OHdf61iCzOYM4 R5sWmXlZNtuBfIX9p29xeHQGdx7QdR29Zm9F5zoVs/izlFKnWC3U0bIeAGqn2j+jZ7SKGEM8F9Kj YzQF0A0jb7Bg+8NkjYuzwmdxxpVrN3jmief40usvc6HDeE0c2yns4fEqjSrwrNDnxBfP3uDxnatm G8I5eXOfkHcti1GfnB6WIx8GzHQpCVxkQt+we3CT5c4VcrLBb3novTXvRmGueNeJE2NoG9rrt4j7 B0hskCDf+XZjxNcUYP7Tb33/T63u3EOD0EogCza/prRNVU28qPVemouYgohVuGbDYHLGKGURmtOY Dc8yxzPdduSLNX/xO79dP/bTf0GATwL8wx/6kdui3e29Rfsz129c48bjV5k1LdvVyrs2Fqk3Fz0x Bm698xZXbuzQivDZL75EEmVWZASFOCVKGyJPPHuT/Zt7pC7VBVpwnin57VJwqXtLGLqBdq/l1nOH 3H39iLPNZpKauieMWGYUQqiBRwVySmxOt5D3kCZUBvGl1m+tsQq4Y99XGQM8fnqPpVH5+7SbJIW2 7I8d6zMBxsAdNmbnIGH82RCsyxQihMFazR7YLZPMYxDzCYq4olnDJKjhv9Ov0NUjpJmjYYbEBUiD xh2WTz3OzhtHnN4/ga43rZp45sIEPne7hyAQk1RCm4iOdhelfKznxdiZK8EqV3DX9+30etThOfZf w2V8ZnqMhCj0XccTjz3Be249w5cevcG5lyeFe5LVLChKJwfUPX9hhrBKib97cYfD4wO+ee8dhEUP HJM3d4g7AeJVoLXrnHJJh6BP6LmSXjkhr7cm4G3nMFt4QFFwCQRqgUXV52HrBDBvl5Yd2e15ZvP/ +k/ftfgX/6WvGof5mgLM9vT8R/s+0cRSj9q41cuNlVF5KpiPqZ1gNnxsJpEYAkmrmQK48jgLblCc kRyI2wzrnr/5ff/Ex//JTxlAfP/0we2jRw9+ZtisWbQNz73jSb75w+9n/3CPbnVhB6vbYeaU6NaZ MIs88e4nOL5/xN2TY1ClKdiJmFH0wc6SK0/sE2eBftXX16/qS3lK22fy55Id+EmZu8TulQWPP32N 9ZfeMDexUtc7F6M4rlnwsevXp8z6tHPcQ8sUj/GppmSe6diGGjjC5cBy6VMuB5sSe3T6u5NMKbbG l4mzsSWfkzvhD/6YPmVTx1KygsylPatjeXYZpDamiOaM9Ct0dWTCy7kxjaVdEG7cIC720dCM3P7S VECqD0zJJIRSqqtbRJpavnQISyepGEwVxbWW+JsmhqtFwV+ZCKP5N9hBkcRi5Dy0xBDZnJ+zt9jl 8cffwZ2TB1wMWzIGsKbyXH5AXCJx+usRzdzJF/zNky+yM2u5/fo19MYFeXUXZCDsrEB3GE4SGgZk 7tjRWtjcPeL04RFtXDJf7hDjjNC45NOzXns/IwhUBiLi+1jTUEunPCRSv/kI8HsbYNK2r8h40epk nfQuRGxGci07CkfBFkXBYtRrTtUwmfBnH8V5LmdFhg7ZdoQufxx4HuAH/87PPv+Xvuc7uNddcP/0 Hnd+6x4PHz3iO77jW7hx6yqSlDwMDDnbvORo/jLX33HIB77r/cgvfpFHJycGcvkriyFy6/Fr7B7u GAG1AJeXdsa0DTv98O85EWzoM7PdlptPX+XNVx6w7YfKgSl7v7z/6HYDQTM5w3bVsz3esrwxrxlh DWBlp04gFQ0laPhmL8HEM40SfETiGIgqXeCtpdOIDtHMTHEd4xg8c298lpLxhKYGHgk2zK1iLaWE m34dvRd8wfjJmnpkc4LGuQU2CV6a7bL79FPsvXaPLm0IeeMG6+L0+3FtCaaMrhwb8Q5/ydDKepWC /2l9SeWdG5VEKKhLwAzDp5VOzWadwNeIMJstaGdzIg1NbOm3a866NVlTHQoYKDOwlJyLD5LNTS+E OwnG23q1P+fTR6+w/4UlN9oF8u4LJCW2d864/9Ipdx+ds11boL8aI0/uX+Ps0V1e79bs7B6wt3+F 5e6BBZpmVsW6oljW4n7KFkwcFRUlyEBDQkmkbkO3Ov924Kd+TwPMoOX0sIuvqoyqnBEgi5h/ipi+ ngE7xUt6aIK/IrEvbbvxbpfyKmum7zu23frHgE/+4g/+yI9nyc9/11/7K/KXv/OjOlfleHPK51// Mtu/v+H3f/dHuHnzsLaxk9pF1MGGqV998pAP/YH38+pvvsKbb9znou8IqszbhhvPXKVZzum7LUQQ rUn4JKhM8YZSutTo6l+Mtr28Ouf6jX3efPOYYrdZ4kFJm8uNB5sqmVPm0cunPLF3nTCXSWZQNqR3 eGqwKNmIJ/ahqdmFUZLjmMWESTZTwvk0yEyjV7O0T2nH96kGBKNYAMCPcAmuymYEK4o4KI+Fcn2z ddO6zVcezMpzewrrGRpbJEYYhJ3nnuDqG4+4WJ0hSUnd1m02RiZsBne9w4NbqB68lqQFsqaarEnG XeqkkuoqniO5ThvIk9scsVbyaCKv7hQQuLrYZ3fngBADJ2dH3Ll/h3XqaoAqzQ+th+3YXerVSy1G eE0F7vUbzrs1hy/sEB4qmysrXrzzAr9x9w59n1lG69reycrFfMFclYf9ivPZjJPFguVil/lih6ad WwkXJjQHtRIJn7xJTmbudXCF9vGbhNmMfrVi2K6+9e3EiLcdYP7jD7xLVw+PSZ51NdimBalZzODr ZxB3iCupYG3HjjYO0T1vrdNo1PxIFQD7ND4l5cxmfcHf+p7/yY+nofvJdj77qZ//wR/65Hf9N39V /vJ3/T6dNTPO1ufcOX7I3/u5X+K7P/ZtPP3OWzYzhoSqnQyhB4nK7pUltz/yLO0s8vJLd+hTz+7u kuXhrhfL8hU6o7r5Lm12GVeFt0tt9QaGbSK2kafef4vjh+esth243AEd5zXVnCGMozFOH664dr7P cjlH1LpLJSrZ5XbJP8FPp5K1+LyKyi+JHlRitWLwgdTjzpkEqTFgBjMTny3990pcddtKccGkJPf1 BaIg2lONtMriLa+3BJ1C/qg6qaLTci7OunUJQ4u2C2RnyfLGTfav3uJ0syXnRBgGch71R1mKDwtV nV+AdHxjSQkmfilLazqBT290putXtNbxdWunfPJgUQSMs9BysHeV3b09+u2GL734OV4+ulsP0eig cbHzrPABVM6Nei0mwUr1pMqFdgw6EAicH2149bW7/NLxSxx1axbB9lejSheE0wBXQ2TbrUn9hrw9 Zzg/5lSiaeKKot8Tg3JYBPdvlaB2+D9smHdPM7t+SEqJ1Hcffjtx4m37wXx8d/f/NHSdK5bHEavl BCydDEQIBXfxdN0YkYFGY/VCLb9cOBSGnLudgpTixf47aKIX/Z7YNP9R08z+UtO0P/an3/e+j3z/ 83/nD/zp93/gj7bN7Mmmiay7LY/un7C7v8fh9X2/mJZAZ6+DQwPtvOXqY1eQTWLoEk8+c4trzxxa 9ybp5H3p73IlJt+b6oCmmUC2GzibR0SFzVnHkM0cvGhnFKWNwReAjqzjpPTnPTtXFsz229G8hOBd J0GTB5fo5YR4cAmN/b1xDCXYV6QZ/12c/h+aSSAa/yyxhdmuiR+bhZc22aYRbE8sWylvtWRDHjQu yaIqyFzAXRmzqNK6zgpaWqim/THLiLm1rucz9CIxnG4Yho7UbUiD+QUnB1tz7V6WMlQqAFymfJYp BXbLZFyb9W1MGuvO1i3ZXTUj83KrVIAzGprQ8p5n3sutJ9/BZ37r0/zy536d834NXvoUoLh8loZC 8b8pPjQWF43Xk1FaIh/Yuc7N3RvcvbjPpx++zJe7c5uM4cTMVqkq8N1Zw3nfMagPlxsGUk7kfkvf daS+Iw1bBv/MfUffdwzdltR3yNAZWXa+RBYtOWXykPY/8eF3/Wc/8ZkXzr6aOPG2MxjdduMNYzTX DmLoelInk6mSQ6hZMsHIREox1y4eJeNxUlLSglUUe0Ql0+UehsywOifE8MIf/tSnBPhjv/hDP/zj v/hDP/zjH/urf/mjAH/rD37vJ1b9+ie22w2f++2XCSHy1DM3oFuTukhwHY4mRSPM9+Y8823PcO3p Q3YPd6yOHwaqiemlj7JRpqfwJNhM/mz1vJDdU/fx911nvtvwxhfuc3Gx8WREnB8TLLAm6omHwOp0 y5u/9ZAnvuUmi8fmpLNhEtRsg2YiIUQgGkcijEFDStAgTMomvGQaA/ilUqncj9CYC15oxwCqoGmo j2cpfwCKebQHCwlmQl1r3PyW1x3GgFVLkOgdJ7PbZH3qwG5E0pz25h47N6+zXp3Rry/QIdENGyMm Umw1pU4JUJmws3U8LIqquMxEslc9wdrqQpevUGeXxKb4/i7igp12l5R75rMFL770RX7lt3+F4+0Z SLF51bHR42VWeYxiARqkbgcABnfjyyjbZB7Xp9sV9/uVcXnExhdvfdO0CKddz/2w4dn9q7xyekKX Mhpgls3svnhTW0mokKXMbbAWizca5ilB7ukH35+WBX4QeP2riRNvS039n3z4gx9JWetMoXHRjKdC yU5tk7mXuQg5qQNLhgOU61nsM/WS/8ZYKgnKIEqvSkoDfbdidX7GX/rotynAx/7qX/4kAr/4z/zI j//iP/MjP35wcPjiD/39X5I/8UufEZktv//Z//i/lgfHW9orh8z39gmzBaFpzSoyNPSd0i7n3Hj3 TeYH88mo2sLVqG+G4ntS/xdGl9ivAEgnG1YxZ7obt6/xzm99glu3rtI2kaF43VCAyKLmdsNxhfPj Dfc+e8T6zS2hadwpKPoJHMz3Q8Pot1uDS+vBwTx4LaMxAaOE1v+9cV+Y1rOZ1gl15XdmY7l1qUyU GrykPH5oxoxIYg1i1I7V1G1umv3B5YuMdar6FWzOLdCsVsTdlvmNqyz3r7I8vEGz3HGfmlD9Xupn UY37ay6m7E2QMXMZn80Nxb0PJUwU1xMgHa1rw+KjTVCPGPv2+OyE3/zcr/Lw4qjcUUpGWpZGZOzm m1VnpkzhQMZMHbVV1efM3dVDhrxhERvXl5qWbu3jinsspg8op13H3s3HeO7wCgFhMyidKn1WBgy6 SEnZJqXL5lWTsn2/z84VItP3CQ2WHQ4og8oHvtpY8bYyGE3pJ7JvFhsh4S7vntFMb5uKILn4jflG m9TAWco0Q69nPWupoJzCQGZwtm1hP6aU2GwuyKr81Ld/WHf29o8+9lf+8jWAn/+hH/p4iM3Hf+mH f/QTir74sb/8058EeO2LD4+GnsNrt/aZ7S4NUNRkiy8rmgf6NHhLNo9YQwU1B0pnZNKFn0AxU7JM rguyALe2ZxRJcPDkAcsrc/ZeXPDozimb1ZYhZZtYWcvM0uK3P58+uGD25Zblty3M9U/FOkfu6Sg4 J0Wc0i+Xgw0+T4gCAk/b1TBh9k5y9ZIB8db3ibfQW//mgOTG+C0F7PVshNJKr4HaH1+ZHNly+bHL hc3Z9ErruQkuly1x2TJb7rHYv0a3XdGlgaSZPBiTpFy3wmcxD16dRomKiwcfgZMpnSXDJ4YqTLSW cXCxXHl5tgWFmeNMq35DDA1feO3zPNic0OeE+9m5EXlpollWr75WkqhhLaVV7kxjJbhBudJJ5nOb Ex679xLD0HuZRzUty34tByl+wcprd17j5tUraDgmZdg4ThU9k6qHuighjXstRsOpZihD39H16Usq 8YsqfCl75/ar+ZCv9hcA/qP3vEtXp2cGYirm2+oRf8w+ymLSqmJFTVwoCAtpmYfGgk+YDLLylqI4 D8Oip2lGyqOXoViNgMSWpm2Zz+fs7OwxWy6ZzRbv+p89b4LJX/inf+gTEuS2Bb/0fBubnzp87Nrh lVt7LPfmNK11WEQK0SxZel4CC2q2BENvyuOhg7QlJ9fwlBMqjO/RSCueshcMyUYJeCctAb2NPJ0H +vOO+7/1gNOH5wzbwWEKIWR1BW5ZeMrOYs5jH7zO/rN7RnHPgq7ElLbLGTJrYeZZB42h56G1KQgy AXovcWGm2Zb/p+AfoUEWPmtJ/DxKnWmVVidWxgw2zI3c+7A2n0KQevvZMjmyDnHz4yO29lqyBxKs bermJ349HaeZ78DuDeK1J0nbwPnnH7I6OeL86B5n9++wuTii33aYDjXUjqZVZu4mZ89Qh94Xh7nS bMjZgNsh58rLUjK9jnOSiodLqizkSBta+myHw1YTnWOOSZRBc53OW/x9k58/CQsGEqwjW8qpVtWl NPa9HWl5Miy4RqDTjjNJrHWoXjXm8+JltZdVj80a9mYNR5stQ1Ia9z1qoGZ1RewYRG2crghttGBz 0EC3d8A/+csvy9//U3/43X/gv/xbX3o7seLtYTDJ/WmzD28PpQVcXLWsjqvubcWTlBHQCqJEzV7/ jWNNprigAXdaW4SlXi77YVAl5o5tN5CGnm2/pVnPaJvmhZ/+2LeymC04Oz9+1/d7sPn5H/qnPz6Q P3l899FPbFZbrj5+yMGNK8wXS8JsZtlWnNLpsdPf9TiaOrRboesTwuYcLdMPy2KbssdCNFHabInM zbnfDIJAhy10F+TuDNZbmibw5Edu8YQ8Rne0ZnV/4+Smgc1xR78ZSCmjKTMMmfM31+w+vUcI5uqh 0dEBDeYQFzx7cbBXKvA76SA5X+aSNGDK7C1fS1lliLT9XPbfD8ECQCydIQvUWn42lccauznACLBN r3PtLOXJ65h8v9/A5gS9mBP3bjG7vsN6dcZsucd8Z4/UbcmDGYzlCf0GLRvKb8ukZT2SQnXCMDBC njqMVLCRqp72YBRl5LD0ebCA4r67hUiqUF3rppejjMURf5Glg1gyqCJ+LUEyiHJ7ecDxdsWdoaPV WO0xB8eVer8totAGqwxSho1PTC1auy0TFbW/39L8DKoMWWiDslUh+6SB/m2lIV9DgMmuWxDXAZgS tiFIquxAcW6LgZUjX6PMpVYCKdgkYFV1if3Yqste9xX/juK/a+taqolyr3ZhOu2RzUDst/Qxsllf MGtmzObzF/7b7/w24mzBxfnx93/8Z372J4Gf/Ic//IO38zC8EGNgvr9DaBtb3z5q1STPXgI4mCuq SOpgfUbenCCrIxsqv10bd6MMu5CINDPY2ScsryF712C+g0hjiylvYXNCPr0PF/fR/qJmTLO9Ge2y MQp3dhZlp6TtQNradZ8dLO26uP9DWEQ0NbbBiWNwiYapaGg8yEy5MDIBe9+KF/lOCP4+4vwSwDtq sjxIhTIDaYo9hbHFmyzTqrLhGqwoKcX42NPgViJEEQD1a3R1iuzsExaBGBqa2YLZYpdte0rYNogk RNRfloOnledS5ld7vFMoc0RL9lCe00otM7mqlB0PCAHo/fsZX4ua6/SBFmHwcmTwt5yx12DdcveZ EanYnffRRnxH3W4CK1muLnbZU+H14YKBZCOU87hXth4ke4GF27Hutg3DZss6KfMg9GKcNM3uCzOp WssyCI7TtEEJrn/7g3/+7WUvbzvAFJq/HUruU6oAkRhsPnPCyHXBW4YarLYUoNUy3dDHXIogmlDX wAwF167Bq9wAbxk6PyB6WVIMmiOQ88CgCemFPm7Zdis2saVtWprZ7Gf+2nd9K+1szsnxw0+vL07f tTo//UQe+h+79e6nCPM5eZCxnKgiQctGzEKthXZJWB7A7iF5fWzGS9sLtLfJidLMkOU+sneTsH/d BtBHu9Sl88DigNDsGEB8NpC3K/tdESR6JhWcdYuCzr1tb9coDy7MC15mqBiQS1NBWwmNCQcLBlOz mEkHp27kcWNXFnBsLbgU75eyNdVLGTyD0UtmM14HZFeuRkLjKEfwa1hQgBRdnAe6zaPFf402pVvn z5t6m880bAiLHbP+GFribE4zWxDjmpTMs7lQ8Uc0pr4657fggKr9OfjBZyd6ET2Wvxci3YgJmgZJ ajAqxt+ltBIcDpg0O4K3q+vzMf69mADYVR6Nr3qUFmU3mFfxDR5yhE2TLMEnlxjupV8n0Iswa2f0 umLtwYusVRcpKFejsEkWBNWtLGZRSSrsKMSu46/+oQ9/4of+zmfe9qSBtxdgKnfA7QpDrKV19sAS J1wO9Zo0evoXMLCxDitHUPdFHUg1ko9DyiemhRP2a0lJyxCugtOUdDBm6HNPP/S0faTtAtvtjBAb 5k37kRx44fio4ez4Ad3pQ97xwWfR2QLtFkjbIk3rDm6tMUplZou9aZBmD+Y7xOUBunuIbs7dMX8w j9vFPrI8MDVwmXdSNo5Ez2jEHPb7tWM8DgwPbmM9ESCJANGnKxQuTGhc2GjdI5EGmqILCvY6g2dk oXw63lSwF3lLcBA8symdpTj+jOpkzlIe0wCffU10wD/bOY4L61CXLhRkv4DTNJ6ZJGSb0fPs+fik WC6SgoILDR26XtPs7jO/skO/2RLahti2TlAsgLcTJPNoN3pJ3V+yEt/4ZahbdNyvPLWAicTLqxKz newpiifIQclptHTI6AgSY9XMaPmQLauZYDG9R9YytqaowgesQZKisAiRJmSuSERVeT3jHBl7XRst TgaW8HVD5v5qzVlWtgqDB5fGajHmMXgSAOt+nHSRkgWZC4V5SjRd/zWNMnlbASaSyTEQVCw9FiFr Guna1UQ5OVboRDlXkplln/uxeupd5k57SHL6d/a0tZRWdsNSFTxZBE9SCGslBkmdcWO1pekuOmwQ WQyBPghBAxLg9OKEi7MjcnfKO97ztJUUbWPBJTaEZmYg43zXGK3twrKC2IAsLWNZXIECZhZjpuib U+30dWGTt3+jEch2b6CrY2vF5sFLpcJ/zDW7cPy58kuQETuwUqaZlHSNYzGzEUOpfJgSMAr2Muki XdIvlZIqTOqJ7O8hwxzPXBqQweZAUbpGjf9s8M8JucOkzY7V+C6fB2gj0ih6qrCWfwT/yOPc0BEa pb2xgDdBQiRIJDoNPuRc5yTZ2/JuTsFj9HJGUw6v4hVTjrNCVCjTIZOA5FzDX/JgljwmU9vOXFJ6 FyJlwEqjtvEyJEMnmeDaAOt6SbVvbVTp/eXGpGy7jqyB62HOwzRwzuBZl2ExAwbWLiNcqNJ3A2c+ sjaq0oj51iyDZTubohMMsE6Gj87ckmI9KMtW2HYDX8vH28xggtlL4m5rKjbo22va0YE9jEGC7GpW rfaD1SZw0kGMrhVJHioirm8qQQbrMOUiVpNRK1e7q3g0F/E00o6McnqlNJCyjxHJoINyv9vyW5/u ibnnsWduIG3jJm2KzpqalbDYJ+wdwmLfAlBwzCNEkPnYfcFfVE7QrdH1iWUqsUV2DyHs2qqc7SL7 N6A/R89tdhDJN3Fd5lP4u5zS3mXxDWB3M0LjgS/OPOBY0BmDi7OKKj+FGmwu2TvUEooyjsFWXix4 VFuDgKp3gfo0doQGD++1hcKkjT8xKVCMgBEVdhukU7RLb3nbE6BYM9oPkAfiYkYzi4SVl5VOgxdX BYtKXS9aqBS5bPoafUaMO5cxw6W0mg5u8/spWuUElMyk0Ba8TCnapCjGUcnOwSmwXkFVVczEXALj YLdi4yDFnMr2TH+x4sXtQ17SNd+me7wjzPl8Tqx9tlaPsnELi15hkzIhCgPW+So2IXNRUjKMBZ9T rXiL20HjgNB7I+bCr9ef+2Pf/wkyz/8LP/0zxc72GxdggggphDrYKnnENz2SLXyVbCM+y+nnJ3kj wkya8ebrqLYGG8FZfdidF1OrcXHwWCajIypIpZMzy24M6hqmCQ3cAGOpM4gsjbWg9uDslM/8+hf5 ptTz5HM37b3lgZAChLVlGbMj8uoI9q4Rdq74QLL5iG/UbohnLdsL8vkD87jtVvbzImZHEGe2+Xeu uUBwjq6PbExr7ixb+EcyCTzIlGlyTQFvJ1R/KXiM4zQS0RCpOMu0RV2CSWnTSShEC9v8TXnOaOVR amyzpmSvoZp8FUB3ChpPHl/KaylBDWgU1RYkwVLMeHqdfve3Xq5tP4DMaHfnhFP3rymcKlWbABka y3DzJCueVNqprD/KGhWfMjGuscHxklTwERHXO1mJlLKDuFLKLb8U6GRNl5ItE5qAZts7W6+VQrR9 MSSlK79bUJpszorHm2N+O5/x5dxxkw3vizuchcQLacNaMxstVAnYoqw9MFjrfMReNmqq7yZZAFu6 vcagxv3JWLY0Q0kR1mko7+HFP/1VBpe3H2CCGB270BEZnWGbiZARTa6idl6IQKOx8Hq9A2UpeBSh l+J7asHJ/mRx3DgM4+lTxLmNK7mredCkA1qGq9lBr5OTqGQ5DqkotKGhJ3P//JzPf+5Vrj12hd39 JWmr9vqTmhvYsEW6NbI+JS8PYOfA8JbZ0nQ7vgm0uMGtHqEXj2BzanyafmtzhnYOxm7VbA+5EmF+ gKyP0PN7Zqbdedn0u8SWih6W8ZVZrGQJNmSegh/FmQUWcfyl+MRMgxT+ONH5OsU7NBbcBP+cSApC 9JIulKhdIgBjydU6PuPGRQXbKYzh0u0CJBs3CC7g4hhdb6htkunjiq0rTQNhrrSHS3gj14aDuRPi qml3TgzCkA2ALTqfQqmogm5vEZdsuVE7OHP1xcm1hBEpUwKsFCqW5xIM60DMM7g0xyLG9pZY9HVq chAHoluUHG0tZ9S5PEbhaBGuSMOb2nGWB1aa+Fxe854w59uaXY5yz4tpqPyxxkmGvcKQMutkQaYX qUPpOu+mnRW9qhjM0HvHqxetlJCZ77kB+H/+yMdv/5mffv4bm8H8+Y/9vo+vj05q2iuaEU3FAszX YvZoHtwrVermV+c5lLZc9OylA7psrb5YGAklMNUypyxdD3CSL1EqindMUyjejtoXPVPwxVNS0Tpk 3R+3wWjbx+crzk837B4sK0ZUCNykhOa1Ecj6FayOLbi0C28Fi6XxqbNg0p2bZ20q41hXcPEI3blq WUwz90Cza8rhxR4y20HjDE7esBZ2wW5KeVH0OznYBK0pt0UDKvFySeSfYrMtjChRSo82jOMQjep5 OZKVrpdgV3BKgqt2D9NUw/VORbtUZApFOhAapHSmggeZ4n6nPdocw0UL63s2BXJa+05fVrJSfH5j STApfp3/XSaF2rkygDRV0ayTxyk2pA7nkbNNlsi5Cj8mcW3Mxq2jZOVPnTeNBRfrNFnZI7nIQyA0 bstZMPootEnpMOvP4FyxJtpq7QZogWfCkneEBWdqwUVUeKiJn0tn/MHmkO9t9ug18+Xcs/Xsp/UM dZ2VDYb3lCmUhrg5D0aVNTY+NgHr7BSnZNgPIlz1s+hf+Us/81WzeN9WgJGcb4tEN8fJ9eRsoM7f FZ8eX2rM5ItSs11MHDRT19oMqcwDdjTf24dBpPp3XCp/vFRCi0t7ueFu5lNp2OM0x1ABPqpkvXQN sthJpJifa1S4/8ZDrl7fpWkjaRgIBXkrBXtOaMpI2lqmERojmAm2CdXZwG7qU1IsTQnWJ3DypnV+ dg4tyIAFgfmuzQZC0WGDnA9oP+GoF+AiTIxYKzV/NJwyUDdYSVSYxLMA+xEWk6zD71Ulz43o5uT5 Ks/atmPl0ZSbMfkMc3ttzY6XgQuXK0xKuOiizGlwyuXpd2Ff4XyLrrMxp0stTKivrfjIhhCZLWc0 EunBCZ4B9WmbhukOiNj4XiiQudBIdCKna5eDklP2ca8jdFS0/Abyels6j1l06UKV6rIQln00NLRC klxtJbJPi0hOVi341MiKCKgniE/LkkMaXskrEzXmzFbghdxz2J/x+2YH/CHZ529157yau0oOXPpa TErdc8VqolVYeWk4w8rAwXGjIQt9tHJp5vSRr+Xjqw4wIcY/FJv476nqbTIfD4HDQc1uLzqgZ30Q yzo05wqxW/2a6NVGSTRijnfWjs1+UwriXs6gPLYey8lNwQvFB1+5A56n/jXb8OCBCO63ZrWoB7FY l1ppzihNiNy6eZXrN69YkBqyd2f9RCyynHKyZyy0puI5ixflU/R60qLWhA5rOL9nAahbwc4V81xp ZqAGKOvudaQztnCl3pfOUcnlFeOQNOUMtda0HZmtzRcqgOoiwGEDeyVFmQSWYhQ96Pi4UMHIr/go koivyCwixDky34d214PLRJ5Q04ESKHT8Kp5dxR1k9xa6ewHD2t53peV7XpH9WmfrUrY7bbH59v8H t1woKYaaJEXi5HWPM4+k3ht7fVHCqDCul6AgwcFnLvmtLzHeUGIXhnujOShNWzBKb5snNWI4VL8X ENRHGYjn/xavlY6BQMsj7VmrzfCyblTm1/oVMxU+unPAHyTxN7eZN3JPUrjb9+yEid+Mt7EbcJzH GAEdjlOq3X7UWt/Jf2YWJ/f3bXx81X4wP/LM0/8mQ/63AILIi8BSJCzV4Dl/Q+og6qgbUgzI0ijO PrRsATFVqJGSwoQlrqPYz9P3EZArsnzDg4JzCKz+duPmCc5Y6R0idXpAKPU6BdO0hTCThve86x08 +94nDUMd8qRM8gU5oZ5P1boyDSSMzz3pl9ZOiORkXaV+ZUEmJ58TbbiFdUT8GOs3FoyEym+x8mIG sx0PTktod5DZDrLYgdncsgmJyE4L11rYc+e5PAkQBXtpxI7kZlIzVumQt8ujfzNnA3c1e2vei3kC 0i5gtg/tzlusIUKNL/YYo1bJ/Skss0liLY2cbFrBsOGSh4EEaI3sWNjJeb1ldf8R3frCOkxqBt+j jaaMjSwZ7185pAp/q9xBdRJp9vKi8a5RVs+OnYlcZC7G0vUMwWOlhkxsxTEcJzurMPilyh6dyljz rGXUjNZYNgTIDLybJReauJs7+glXZ63KsSYWOfO+3UPCsOWVNNCpslJlkzOdB++pOrtgQ4LNqW6A rY6YUSO2mZ+cCe3Oku97z3P/4K9/+e5XDfDC28hg2ti+MITudgMvZpUXPejdDvDxrHIYfNP3aTDQ LQT3u43O5DXOTLlQEXy8JvUsEXclK2eMOmZS3PKLx3WRvSPmR2LfG7d5SW39oGdi+Fjr7hIwirAs C6w3W3Ia6sk2PcQLd8xio5+Bki/9zKVSo2BQJZMpkTFZq1WHLWwvoGAt4SnvNEVYHiDD49ZRWp1Y C7sAuMwRWVogaX3iXzuH3aWNtQgz2wizBq41sHu5FLkkCy7fLMLombppiY5HmYC7GtnPDx5kUikH p6poh9DLTtLSsvbAogMMW7QIJUOLzK9CPITkXab50nhHq6PJZQ2T62raLNGB+Y0lTYwOC02yE6fm lzVlretkJt8153Ev6TxKAwpGESQYkS0q4tfBRpVQcRhzz/OGRGlRh0xsTJ8nrqBQKObVdskUUnay nuNHmrUawYdg3LCH2rNG+f3xkDfylpdzR4/hJgKc6sA/GFbsXsDt+Q7PDR2fTT191trEiIVv5vhS 6aCtgXkqrXMnGpZkEeyQa1r+pU/9xtvCX95WgIkx/I9tbH4qS35eU/okUX4ypPQJJLyokiGHjyiZ EAIhQ1/R+qLVsBQwu9I0Y1m0anAwNjtfZeIpI1RKdMnYqpit4AAUejZVhl82dFkwmSq3rB8ZmyhQ SoycE3feeMhTz9zg6vWDEXOZRJgy0sIkBVrLtPEF1RrDyIT1r2OaXTd29smGmixzaXfQZma8m2aO 7l23rtDOMeTeQnKzBLw13i6oRJU2IovZ6GYUBa42sOtIXZ6WbGUlhfF71WVeLJgUmmj1B3AD2+CP s/ZSMGh1o9Nhg4QLMwVHx0CSOlDPVvLWgqYHWcLSFvRs315PlgnzOI5Bud4Dt84IvR1euw3NsvVB CKNDXZkSUB32Cs6h3uesJfVlmLqsFhwHHHywYFUhq1Z/3TFndyxGIDfWLMDb0+X6KR5A/DHrOeQl e0lgCsNXg63WY3qeaw54cpjzhk1UNw2emL7pQU787e2KH1H4QGz5wjCwdS/oUN8TNGVdFhhRlVPv r6uX+4VhPHiAmc1mbze2WLz4an/hL3755V/9408/8+OCfCgEvkeVT4vwPCJHEQ4T+qSIbBSWBUsZ DZcu385iTJW9bi5dnyCBpmQ+UkZ7jKbg6v4cxTLSJX4UUyu7pz4yNPiiE5cUhLEbFRkzovp6ELbD wKKZce3mAU0TyXVERgkUHgDfevUqm7g8oH+55Fo0qfmnhLyyadqIzJc2Eyg0VhLN58jigLC8iuxe QxZXkNk+0iyRMEMwxbTMWhv1ERyP2Y1wJY7lzltVype21fS16OWv4mmbseLsM2aTBjQDEgaQAbNb 8OWZO+jPYXsK22PojqE7gf4UunMrD9MWzb0FhmYXmV2BoXXGcmfZy+bMZBTlNRaWcfSOFCA5sX3z mPXJBWnoDQCeePaMBiJuelZKnfKYfooVrEXrao1+uNnvF5pEro9RSqbR2bHPoEnr2ixWEAWuC2IT MnIeO5tGHxrHyRainao1CZ9gyZ623Mkr7jFUELoEBlXoUHqEb5ov+fywZeUHYQGeC48sMEJtVtqZ 7GFwVm/EiNVzgef2ZrTLHb7n2SeW/93L995WFvO2PHn/5Dve+a8FYZltRvehL87nU21S6+0Ay9K1 KRtefKdldTW2jywpyyB4F0SCT50pNbJjM657JYbSMfLgEqSeDAW7rJvZDxCtuMw47Q8xyYJICS6F gKV0q47d5RX2Dw/cN2lsrxOCzZkZIxN1KP1k65YlXp5rmt0ULKkyiFxpbOBggGZRMQaRZtRFlZO9 eEH2/tit2KqIOq7Mq+FyjlpLI5085+QrvmvE05bKcyplUMFbBstQZIAwQByQNsEsIfOMzHtk1iPN Bmk2ELcQthD8d5mUTSgiLbQHSHsF8sxXvgeY9Yn9uX5MyIT+2kMIpE3H6v4p224LyZ3yGS0wx2cr +X85ucvgkhG0tb9HmthysHfAznKH7ZDYpr7OQppi/KWpMPj3VEe+TFYfuYPWGWlgvkDTwANOORK7 dSomqkSEG8y5mRtezCve1N53yxTeE+euKE/7lNSXUk/rB3hfNpnbq1Q8XNwfxv+5V1v/rQj7AZ7e nbHc2+dHPvVbf+DtxAl4m0S7pmk+mbJ8PKI/KvCjoKjKizHE51X1dgvPp8DHJethMU0OnsUUYEx8 cZRxokjwm21IfAwWbgtjpg7MKjErBNN+BJmcvdktIgrKX1xWJ4xiRtKeio2maLRgmKXUSpxuVnzp C19Gmhk3n7zqoOtgLc/iITsZJDYiyr7ua303drQug79yCZ9RQLqOfPwQOUqEJ4FrT8B83zktzqx1 pyJd9bDtbaPOMU5M71+jIMsWGufKlA1Vom/t3DCxSiiZihigDB5UPMhoAXVdU5V7wPEUSSAZCdkz GfsdjepZjtqxmNUYwCkZgpkS0k9sHfqSNb31Yxq2/fXpYI8RFCIsri9oFw2cFyPTcpnlUiljf5qG /3KHsjf/bOfNZwt29/Z57oMfYnV+wZ1P/0J9PLCEzgyf1M21cdzG28JKzXzBsCEbxFC8kUYIQCZB ppRIsZT8mtnknjM6TjSxIdO6ji+XEgy7xI808Yv9lg+3MxYIW4fVgrN0Gy/XC3cwiFRsf17kC/4+ WscYF+3XNNno7WUwf+q5dx2pcltE7mT0Qxn9rIp8OsDhv/Cbv/mT//Rjtw6z6m2FpagukYJZuOO7 jOLEMtdmvNVe54pP6yN4o9oxfvdBNeJTYVVKxV5KmhlKNiEjTCPO6oyFpi4FqCtZhlTwWETYdh3r 4w1NXLB35arRvFXJx2vSow0MSphHUzDXpVuOh7Kpp5WJ1K/yu13YPqMPNnC2QWIPeJeldFv6DWxW 6PExHD+C00eQTyCdg67tM22RNiEHvnLrqrm8neofazguWcvkz2XedA0wwxhgmASa7CNLcqqfWsDc 6vrnXKAGw4ZaMV7OIsCshbyPcAXDljCnvIsjWJ+OkwvKJZyOvlXL+kLbcP76CRenp86BGSd1FgWD 50tjZ1IvvXPLtD3A7ezs8453v5v3/BO/n5M793jx5c87qTNUfZGR5pzA5wdmMYgqftXWlVJvvNXi mKRlPvWoySrrpLwWw7SVazpDsvDlvOFUUy15wFkFhf8FnKpykRMnTpPoPXA0jNcA//nicDePwq3G KFJrtWt0NcDTV5aEpuUP3n7Hn/+rL705Qdu/wQHmv3rlpaP/xbO3AT1U1e9B+BDKEvToB27dOhLh RUEOAxwqPDk9M7Iqs9AYCKthlA34BSgLouIcYx7oP2PfaCRaOIrFg0NrJhBqeaSTdrRU3FMxUSVC TRlLaIsSHPexINH1HefHF3Srjtgu2Vns0r9xyubeCcPZhnQxmL3lXlOzsgICV/D5UjQZN3dtd3t5 Ihn0dECGZPC+muG1rk9gfQSrI/ToLty7iz66h26PgQskry1z0AFaIexFB3b9DVbmLWPAuQT0Tr8/ 6QqVwEKZedTZ88wy5M6mMKoDtZMsR6c+xuVr3eU63s+AHZXNHPo9hKuAj6cdOgswm2P3Qp5EmGmQ Ke3xIKzePOPi+IyckqmitYxlHYepMQ0ynsWqlrzVfm652OHpd72bZz/yrSyfeIJXPv0bvHLnFWtC OP5SXotSWtQWnAImCShBK2AKZ9EygbKUT+USuIouFFxExzImWIfqGjO6rLzBlrVq5XSV4BLrnrHX tPKMPzGC04WobQet1K7qDGEmcLOBZRBWWdgRZUfgqd0Zu9ev80/9D7/2v307cQK+hrElQeKnc8gE lU9oDoca+HjS8JNN5ON/6tc+85N/7sPf9JOqehuR25F4mIMVoFGC8V8cZ8k5utNXtouQlVSFiD7y IkhlRZaWnocrBoILK61VHf0mFnC5/G/UppaEu+idxput4toTB5aj40Fn2zO2r244OT7mxo1bXE0g vZBWG/rzLelsw3y1R/vkPtIG6IZxU4/J77hBptwEGZEbcz8IVnIwGCGv34yM3CjoeULPO8gB2Y2g S9tkgwkeJSRYlpq7lD0lZ+dSsB7LkbeAupcCTbKgkgfyegt9R952hAMhzJO91+xBSJMFl4LbfEUw mxzRBZNyxTotViJVEM2DyFdonPwGa3KfjsYeMAvS2mFS6AyF1v+VH8U50cs2vN1MYH9nn+c+/M08 +c3fxPzgCnqxYdhuvcoMdexr9fVl5I9INBfHseo0y4aghd2rl9YmlOmo9hHF7BSKG0EJylGFN3PH xlvMPaPAvcxa0jAKNYfiNOAP0QRfhbmcM1rHtoiBpSy9EzgXYSfAMgAh0i6WbzdEWJx4u7/4T/39 nzn6wZ/72eclxJ90FethE8OPI8Kf/9Zv+bixKeXFIPKiBDkCQWJD8NZLztmEkL6RQyVilaxGyD5G YjSkLzojpccCUdZkYl5H1AuHzGLQ2IIVbJCVyfZtHNc46GoMMskfuyDsRuaLdHng7ukDXnj5S9zb XDC7co3Zzh5koTvdsPnyCdvXzkibAWknVggTLgaTk2/8OnYvaKInPb5BkpUlOnRov0G3K+jW0HdY J8c3Z9CxVdUK2nAJRK3kHXmLhUL99zwJLiUT8axFzfA8b7fo+Zr+1VNWv3SX9S/eZbh3AdEyJ9Vh DC6VYzMNWDI+XwkWNXPy56O8RpzV24xg7qVrVjCwCekPO8CyjhiMetaaZeRGTb8aR8RmUSkwj3Oe ++Zv4p3f9VFmOwu68wu68xVp6OsIlNKlLLiOUSfU8KcgbkkysbPxeeuF+BmlGI5T3RkL8btohcrB kzHAFVGOdGDlBVm57baBzZLBOlq5YkHFi6YJ5p9khuZaD+2yrwoJdkesAVlY8QuBtm3oN9t/PAGm foi8iIRPF5tFkXBbYrgdghBCeF4kvAjhxSaGIxHzjdFsrWgrgUKVFQRPUwnqokfcK6MMMtfa1gb3 uBDz9bXOk5KK6nXy7gp0m/2CG+NXvAdVciH7yYDQqAPGZNNoiDrLOLDNPRf9hsW7n2b3ne+kWewh tKRuYPPCI7ovnaAXySwvG+ESAe3SRvmK64i0MjJro0z2pNafqV21RpBZsK5RKeKdginVbHWCr1Q7 hbfgLdNyphLm8tgtYkC7reFORxd0r5+xefmYs1+/z/k/uEc6WqPzZK3kPIx4j04zmMl7mH6U7/WY HWYojdsI4jOrmmLvMLl2VeyZGR2+bZRNLrqsS3j69Prjq2Ey7cFL9d29PZ744LsZNh39uWWO3cU5 fd+5r/T0dRcMRQ1UD6FagLS+ZtFSrlshNN3QScejxe6GGUZlZ6vHMCpCthm2JIwI4FnUxE1UFYJm b5FYaVgr8VxmadtrLmJLw2Dsl4ObUc38M2BfY4j8Lnftq/r4mgNMDOH5GONPhhA/LcjtGOUTQrgd Qvi4iLwYYvjJILxYMIAgQgw2IjVMbn4rNpmwTIv0RG50yfPnSx75w1sWrWYzDs/BHLoGKQZTYxnU lLq3aE78d7PjITUjF3sOk9wn5zpoZYpmDXBwhdmH3snuh97F/OZN462o0t07Y/Xb9xjur52DM7XL vJy5TBc86nqUZTTdUNlQtbIoR5YirSDzONKRC7axA7L058uTrtWl7GQSTKYZzBR7yZ5RqAO4YUBi TzpZsX39hNRvyf2W1ZeOOPsHd4HB2hhu9Ghg8CRY1W2kk5JHfHOLdcP6LWhXu1ASbCIDjRO9KjCh E52XHQ0iAsNA2g4umLUNm74ydbRCKARCDDVkZBKzdsbj73kny+vXSKlnGHpS1zFsN1ba6IQH418b UWJTuFa4oiKTEtXvqM9WeuNnRwYbDRK82+RlS1PKoslbVWzm9DmJgdHTpcdAY+Pvjd6+scIBchkw xmwcomctDW4hAV6qU8fjzFCfnaTMd3a4OL/g3//ub/7xtxsfvuoA8w//xD97e/r3H/h7n3oR5EUJ 4fkmhsMg8TAG+YQgt0MIt0W5bfaYvFiyhRCLaLysHe/gaKEqm/v5KHu0M0cvtXWDs9jLxhuDTvbA 0KP0noVYzewLyjEWG/bh+iS/HJZejidNuQGqI7m8Hzr61RZomb3jCZbvfyez6zchzMlZGc47Ni8d 099fE9ow0Su9BbG+tHEwHGEnwo6XWJUcJyObto0mFJkxsrRQiIoso32/ZCvT4DItl6b/Ni1j1Br4 FiDcvjNtoDHi3PBwRX96Qe4M4B26LRdfPGb1Kw9h4XVB4cHXgFUed/paytK3YKFD8plTK+tKFSA4 zmwedmioxi2XEH9fGVEYVj3dtnNwN9dsz/Ne7xra9MdyP5JILRkOr9/g2Y99O/1mQ+p6NA8M244Q W2JsDJtTrdgLAup0JK2XUukHx1aw5KplZPgWa9dSQimuAwUyoXZWiwQm+vtb61AP1YhPGpjA1gVm m66u0f9RnQejlRxY/m6C0WzulL5mZsEzGc92tB9IKX3i9yTAfPbP/ti/J7N49Nbv/9DP/ezzUeRF ETmyNxcOReS2EG43oSGG5vkQ4vN2vVwn7SSkUfVvKtYokdlksDve8itt3+R6j1zYvOqtPl+UwXrP Nfm0M9VKp6FkLlqsNw37abRAwTrBQaViRCWtLKDeanPB6uQMejFTbRqUSGh2CHEOITCcbxiOOwsI BWt4a8I5wT1LtqKN+7VAbaV+xc/PYyEq2CZKaiS7uY5V0SW0YRpY3gK+XsJjpt2jHtQ2GiGRtls2 r5+Stpa9pM7a58PFlrNfekj3+RPLYprJ8LQaSPJbggtjkEsK2+TSgY2XWo6pVD+bwOXALA6Y2mvX KGyO1nTrrWedeTx4ZFIOEVzIaIFiSB19Tlw/vMG7vusjhHnL9vTMht9JpJ3PzQYkDRN8r2RPMlaB TBI2P5AiSgxmJMWkg1N+rowLzh4hxMWSUSzrGQYLBjEKXWG4TxZCQi4dWSJlvVv2UYFspRpilQ5V MSmUeo/GjqaosrS8kIujI5qdXT75C5+99vbCy1fZRYoPuqvNP4J4o0FeFA3PB9EfHUSPQogfRyFp +skg8vEdDZ9IwTQYM4k0ZANx1XQbhRtjQ92iEZ7UZtwUu00VG4qeFJpSz7gK2kSVdoHjpZnZduMG 3K+03gSzcCiHYiykPy+cbS+PIKzUvyvb1PHyF36Hgxs32dndYfvyQ9LZ1iwaZQl5S9YNw6M16e6K eH1h3Iwinb1UHpXAUY40xuwFwR2hx3+XyWqdqm93o5PZcpHu+oqflGhf0UGaBKECtKpT/XVAU+84 TE/ebBnO1+gwkJNlN5oVzYn13QF9PnH1ezOL9+/Z8xaPSZ2+yfLV/5wVtuqvWc3ESyq5fsxkKig8 RmSL2X5dmsjZm8dsCiAprrCPZgeSNZu6WkEl0DQz5jESmivsXj/ksQ+8i73HrrN5eIyEyHx3xuZs xZ3Pf4l7r73OK3deNwtNHR97yN4xqseOVJKnBQ7PiV1IiZhNQ2e0ciu5JFf2buk8TeUDOZn7XOfB dJhs2HIIpnL/vfWsNcOykioLLEo245hQI0IQrVMRioDexr2UcstA4+1283Zjy1cfYHbeHG6ugrwA fEVEC8iLGZAgR1HDofqUAUS5IvMfe8fOU7wRznnj7HVS6gne8itaoC6rBY1gLbToGURSyz5CGE2c QRikEOaK8U+uWVChiZefdlKwkaC8jdfKCOya3azF/dFsueiZRh5BKaOQzP2jN3n5c5/l2atPMTw4 MWVvCAZORkuL00XH+kvHLLhCc31hbdE0RR913CR1Hzr3WGBCuBijQykRpfibqHeIPAMR36wy5lxf iX9MA8tbAF/vHFlwKUQ/s1aQkMmpI6eEZndMcauF9Z1z+FTixo130NyYwcVbgtv0fSgFebRagvKe 1QOaG8aWEuuymOvSI0oI6Kbj4mRFpz2IBZbY2iwrVSXEhti0iAjNYs5sZ49md8nerWvsPXGTlIX1 8QUhtiiJo9de49UvfJHX77zB2faCTjNRbYyIqpLcCqIwbtNkrdWY6gfm4OWadXLsnWZfY6HGWfut gJKyuhuEsW+HbE6PiZLBFDa8+kHrl0oNGWon+H4UYUfMh3edfeKjv87oRFbU2AF9FWT62lelbRfV 2/ftfnxVAWbRtg/np3r4D/+ZP3n79/+V//qSP8QP/L1PvfjXvud7nx9UbzdBPrJVPZLA7au6/Jl3 7j/Lez/6R7geTzj52f+K04sjj9RukxACTRXWhbFQKVABZhxlrW2zfTDqf7bJBapVkFbGXkmwUyKG 4CkzbtYD2b08spTpw8Hq5MkCkfq3cUvWx8ac0F5/9UVmFwM34w4p+0xpEWym0AIFhost2xdPjUF8 uLDgVzKZovgupVBhphZNxOitMCmwfXcWU53GI996gNMBlgMskqmhm0nbt4xPQS69o0vBpbB1Cws3 9Va6ZLdFlcFIbH3vioJUF6wCF29eMP+Fh1z9+C3jA/W8JQNhfC/42+sGRm4B4+sB3DRl/B0dN++Y X4JuB1TURpe0wa1/I6GJHDx2yOHtJ9i5fkBcmPK8P7eMJudAd7FBQksI8Oi113l05z5vvv46D8+P 2aTBWeRSwVKRojHSOka2FE4hOATlHc1ybQZV+mSCwiIhCU7Os2H1hvSqlPVD7SaJjo4ZpdlR7lwR LhYLiWq6WH5OlbkEsigbGS+vdai0XvONwkVWFjouq4XAcneHvHfl9y7AhP14v922yHZzG3jxrf8u Ep4Porczelvhxath7yPvv/Vh3vGtH6N57ll273yZawePcb4+ptNsaWpOdTKkOK+l3DINlh4GZyaW lZm9v5Q1Vh1TJZNJ4RW40ZWOBg2K4TGiUmehmUAyT/w9LDPK6IgrcnlxF+vadX/BcXfGzcceJzzo ncFabCsDobGMZTjbsPmisnjnVeKNuVXHabLZVS9FtkL8NtuS2tssD1vxB0WQlIwvMmT0qEMuIrrb wU5E5uKeu4ylV9msFaeZlEdO/dfcuwTAPwFNPbnzzEWVnNMYWvy15awc/9pDFrd3WX7TAdVdiclz 104QsM1omUIWyuso5D7GFnR5qeNK88vmZWCILA93WW+2VUXdzhsOnr3BjdtP2Ozqi57to3MbkKaB 5N1GHAe898IrfO4zv83J5sLwmWzEu7LZp1B5aRYUv2m1hzH6vxTKnv1sXxJLGRt7IpO5dePysgNX tI5vbWQ81EZ3JHuyotwr0zNanNGuZWSPZeynPnBt4UzhKIa/ZO+wthg8cOFLVzGQd//KPteffIK7 bz78vQswcbe5217Mibr+BPAV8m1f/LdF5cU/+Uu//NE3/7l/V2+9+5vg5hV01bPTRfb2ryL3I6o9 OYdab8ZG/E3bSZskG+qOuX5FwVzZc6YJwWnZmezniDIyfMtQc1VjxyYvuWwKJSBqmAwyMbrSSp8u Lb9imF/a6RLK45rpmqCcrE54tDnh2nKXYX1h8Ju4CZVGJC7RnOhPN+QvPWLRX6W5uZhUD6V0KUHG sQYR6guI4w7TID45EV8xEzA1D+i2Q3KAraAzYJaReQuzaKNNqpVvCS4FhC2g7iSwlE4SxjAaNj2a 86VDYEoVyFnpN3D2q0fMbs6Ih3MjcQCVD1SCZqf2b2WXDe68HxxDsqiGTjCOqtKbfGgWgkSaRUsz b0kp0cwbrj17gytP32J4Y8ObL95h/eAMHTLNcgfdaegE8iywTT3HD454eHLMNnV+dPkIkDKeyXGv 4GS1gsyJrymtb8vuWfLXmtTW9OBlSDm4it7JcBiIKu4vY6FroB5Trqr2A0VHbCd5QJp54yPhjGE8 gIw9EmKwTEexON5EW/NltlgPnCfbJweiXGuFvYMrzJdzNtuvjWj31WUw8/hmO4/ELv7o7/bvP/B3 P/Ui8McA7v4v/3298fhzpG1Hfvk16Dserb/EanaHdicwnAUGH/wkwcEy7whlySS/ACZiDN4OVIiR nHPVcExbddmzkCJiLIzOKm6cKMrEsQ8Pafb+mIBs/pijjGACmQCl77Tp1jy49zpXD571MsST5jKv WVqkWaD9irzu6d44Iywj8XCO9n5sjLMzSqi2TZUxJ7XSu6xJQB5ZPDU4eQYQkmmE+mirLCm6BZqM xOQkCFcht76Zo0sTcimJyteRz5L7wdu3HnAmmUWhD4gDWOcvnbH8wi77310CzO/SBdpmdFNSNr+o ybGjaRs9+0W/BLyMsLu9hMTQDSiwPNxh7/oBcqLc+fXPs16vGZIR8lSVfn3K9pFhG4TAuXas8pbe QX7cZW5Qi+95EkBLlmFzoGW89GKqZwsyNpLVjP/sdRYz+ql9tk4eN5W3j5lZtUFcYzTtXo73X1TN J0VMG3UkqQYQnQTAlOFqE+izstLqPDsOj/AD2UTDlrHPo7BoA7OdJc18Qfc1UuW+qgAjgdebtiHG /+9P+sqf/r/p3pXrbM5OWN35Mt31FbP3LkjLhzz27FXunTxALjpLN52MGiWQRAma6cnOyDR9hQb1 C6aVm2UnRLHItMVdpteNBpalJe6Lo5DvSmgXqVhQMfgZiQTeClXPerxjVf6tBJlBB063ZxxvT7g6 23PCUqIOkBex4Wq5AU0MZ1vyaqC5sbRpAZdeax67RXhrofNRsgtxpWaJenZ9VFyOo8kupgwQIpo6 ew09FkRSY/Ogi+1k8OcSN4uKLrAMbhalxViqhw76NzYk97utZk61RJgGAKVb92xe37CfvdVciXFe CnWKbqYEPA9CyTEjKUE6jz9yqRNWMCr7/rDpicvIwdNXmcWW7UvnrB+csRo29Jr9/ka7nJhhtqI0 BNps3izlgLo02qS0ktU2oXkHFXmK0Os4gUDEMu3kU0cRyxomfUMPAKWtbPcyeuBJKDF6yZM9EIQ6 rrzG3KL83xPhsdDwULO35otzopdZnu1cE+E0wqNkuX4z6a9OnR6Ll1IQaGdz5vM5IQiPP/0O4Ld/ rwKMvNrMAo38o3/tS//iv6NXrjwGwGpxn4sPPSLezGwPLxDJHB7sc3Bjh4vX1xAyOYJmJfrYhxwc f/A6s/AFCpiVUiaG4GVTId9ZHhM9QASVSW7jNzY747MSrUaDn+LdFGsWMQoRwf6tncZUXzhRQDSw Slvubh9xeHCTuO0YhvWY36IgPkIkmwVC9/o5YdkSb87R1TAJXP4f8cJMFe198NssujuQMYwLU8vG oiYri2TwkkocGhEIGYmOayQZwYCgI2M398Zf2UuwnBhKaYIlbF+84OKLZ/a8fl21eOIUlKC2T+wU 3dy5oPvyBbNndmFTxJ/+M5vs/dq6sGpLRbOO/IzCKp6mLzV5ETQ7D2oe2NnfZXPngu3dE06PTthq 7/ffMopij6AqND6vqw0tqoFtygx0fs2KeNGyZhMQWnDJonTZ/z7NkrXEWrsu5e8ZK+lLYCj3OHt2 lLJUrFDER5l7wPF+BzkV7ZCR4Yq7Y1JoCdwQ5a6TS6OM2E/JikTMLqia4HmmMmBuGer0jUGVBUbi W+4umS0X6JCIi/nbDi52Fb+aADNrX2mbRVqw4Bd++J/9Cnbfb/3xf01v3XwWQelubNm+8xHxvUq4 DhJ8Nm8jPPmBG+zeWJoXTDZZeSaPJCjGoKIGmpgBFc4u14n9g9+1sm+SGgZTmjKUIFTmYk9aceVE KXYPuSaXJTSZ9EuAlK3zUNic1SnAs6Hj7pTXTt+wrCu4fqZgDmoiOYkCTaA/27B58Zj0qEPmE0/c mgl4wMlWTOtUl1Ri0Oh4M5ZH2Tdk6f4MG/PE7Tf2OWzRYYPmjVlWDmsXUW5gs4b11gNLNwKuoqxf u2Dz4AK8G1cyC/XAXtjT5V0gwvasY/XyhXWzfAwSEeiw7GVa8lTSn5T2ByMpMI+ZDOWmMjbYotBo IL1yzskL9zk5Pmarwzh9xUHaTK52DFZ1WTfwymKfZZxXg6fgky5KOWTZjxk8dVl9repogRDLWhu5 JqoWDKp73iQuBjEztehBah6sYp3F0aoziDKLo71DUKVVG8pWRuOeaOYN7TmUyNJfc8lGROCKRK6I sJNhR2E+2ROlaA3ezbLzSs3JDmW2WLBYLtlstpydXfzeBZjdH/s/alwuX1rOdwgSPz79t1/7kT+j zz377TQaGK70bB5/Ez1Y+27wN+dkksfefcj1Z/aBYtJtdW3CFdIeGCSMXJlxgL3Uej/7hiwkofIc palY6lwJoSL96p2lUSVjZL/Cg0keaC5X3kzGXUwofAXPQehSz+snr/FgfWQBpgwW0yLes1aOiCBN YDjb0L10TN4q0oQRZyjSgDIxqxFkVmYLlSzAKe4Fi8gYm3copk9lJEhv7Ni0NbOqfm2an35tgWbY WBByb1yCl0XFA6bJ6JDp720Z+mw2Bbk0Zj0Y6xhUpjFj2CT6o60DuL6qO9CzZADvJFG3DCYWFStV bDn09p5KoJ52ohTTE+21rF8459Er9zkb1m6J7Wp5xjhmie7odZdRZgrXr95id7E36tEYJbAZdc/a TKejYl8RCzbZcI4sPmQhj4Bu1fiE0Yg+eqfT+GJqSufgZO9i+j1hMGS1RhwidtDm4jlj86fvpIGN KtdipPXuEaocSuC9TeQDTeTZVtgLUuN74WeW4nzI1kUq6eVeIyx295jNZmy3Hevh93jwWlwsX5jv dO+eny1+9Jd/9J//ldiGjyyaAx574oO0ccZ2eUH37COGeFzp/iIj7hEkEBbCrfdd4+5LR1w8KkxB 0w0Vo+8puGboe7TWdHYSmmhdREN2db/fmTLlEbd20LJAMcA4YerTECwNLoOxGkajIPGSSx2nKWPD ygI3ELgEPXvcgcyr56/ThpYrjsdAwsajRgppW4KVOf3pFl48YfH+Q6SNIyYT8BzXHd+aMKZblZhX cIJsLCnnXwiOk5QpADkgkrzdHSaodSnqB7M7iMmfx0unKFYefe6czWsrMlaG1Q07xt56RXQSNIYh 0d3fwgY4s9eoF9l6r/Vijj8vOTpG5KlhHkyflNwWtGZvI1gsUZAkPPjyPU6Hjf9ICSP+qrQMkvdM xu+p+jUKSWibca5ELBknlvUMFfsovoowaKrrTrykyh5c8PbvkAtM5E1mVQbx1rPkKjNr8Y6P2h8K Dlimw4iYur/3LLvHsw9go5lX08CTMXAUI6c5czUGnomRhcAmK4MGNg4jFBePUiknYIkTCD0YLJYL 5ssF0rZsuoGz4XeZjf4NDTCHe19anOsf3lsdkFL/kXm7ZL68Spy3DLuwffyYvrncOy/njs9iQ1V5 8gOHbI+e4lf/9gswmLdu4bIUkWHEzIw1F8maVsPvBhsJojolGIl3nApHQKsgUjydF4oOqpQYBRxW b+158VXSaKESraK6cfmkIVIWROEwrHTL3fV9Zs2cnThjyL11fbQIE6RuDk2Z4eEFwxsz2qf27I2U CV9g/jBNHo+zYoxTNlqyNrxskoHAgksSvBsTzbpAgx+zUlJ5D5GKZwrmhGc+FQrRcB1WyvrlFd3Z 1lr8JTZVbOtynlfLTj+lu+Oe4XMXNDstukroWUKuRjuy02R1VJKID2bSbEziYeuTHfOIT5VSqglo FvKdNav1hkQi0FR1MXXF+CD68lzOixCBlfasjk8Y0rauDXXszzorhmjkrLWUTowTBJIIKV0KuQzl VYqOTATcQlNs6Hzj66b8W3GdCHk8WzQZbtRrwXm8lBlXAFGEezpwqC3viJEuBJ6I1hh5lBInanfi QpQ2qFXPWPBqPFMvQS/4Plrs7hFnM2azlpyEf/mv/+1p++/3IMA8vvOFWQf7+Rq6GZg3C8JsQZ4P pGd7ej2aFhFWo3oZI5NSKUjgHe+9yau/dZ/7r51Uev/YARo5BwFIajVz9uhfuAJeIdSxJdXniZKJ GOeljMcsUSG6dqnsjGIhErzLVMdIaBmlQj0Fy7QELQvW3290UPekP+Vgc8Ji55aVRlo2T/AOEyAB iZCHbKDv3oyw146PF4CYq0HWpfKgDEYuzn9JkT47waEcneqb2LMTDEUcx7rr2N1x8y+aWP/eP9iS Vwntk4lNKe3oKXwyKYuK30jZACKszzse/MoDDj94yLxt3B7zsleL/a5MZMXZzunU2VA6Um332s4N Fm/EXqcK7O/v0h0PdAUbKp+avaS2wFEoRvbvwpaBB5tjzvEs2sfbllnOokLr3BWlsK3UQVatsrDO S6LShbK3LzUwhsZfQ6n0EMTLnTq3LvmIWb+9g1rgKaTKEMzZbp1HVjoo65x5IyeejIFDL4VeTYk7 ObFWuJ/NViJEoTdNzSTTs9czs5fPTgjMFwuaEGkXcx688ehriS3AV4nBADBvfic8tsv+kzfY2b/C fHeP+d5VZo/tk5oHLhvxzMBTi0JSwzOC+bDH8vU99t6Y8f4rz7A7n40bOktdoFNbSeMEWIlUpjeW xVLo3AXBmtbe4IlByUkrK3P0azUZxmULicLcsJR6HJ5WTsTio1odzuqWs4l+jzaPOO9XtHFhm4IG ZZrFFEV3IK0Gti+doNtsQ9ZcrGIyfBmDSVWYTzAbfNNtFTZpDC45U3U9VWdUDLrT6JZXgGHJsACW wvD6luEXzsi/eYFss5mdM2608jluPJxANsFogSFlzu6tOH7xhH6TkHm5B9NDUcZje1DvYHWWvQxd ZQ7XyAEIsWLQ4fqCvfffoJkvakCxtSH1z9OGeOk4lqTwjBUr7StIWoDZ6pShQhQ3SKj4sr2QPuWa saCjNmkCSVvXMhoWU/Vs2bKhwVUjJTnNCn0yrVNKY5s7Yd218lwFSzFsRnikmTdz5jRnPjcMfDln TtUMrAYZGxJlPYPjRP44nQ+Wm5Np53Nm8znL5S6PTs++5gDz1XvytvLZsGhob+7RXJmjJxFpdm2+ 8nFCWkVSrlaxBbMUAqGD2bBkNuxDd8F8fpP3fuhJ1sPAr7/4edbbfopj+r4K5lUxKWdKADBKdFE0 jeM5SvYSXAFbjKdSzrQhuELbhpEL9u8amcyq0bGVXU4mn3AQC6rsC6Jm7owMYEE5TSserR9yMD/w gBBRmVGGplSs0lpUpLOevMnEPRdrZgeVYrDRpaU0KM9XCbxaV49uMBPuViwb0ezYTxrbBxUjnZRI rcLBDEQZXlzR/dIJ+uYG2kBshTCM4bNuHo8i0zbt+ODjmJl+m9ieDaQh0cbZpGM2eSMZap3g20h9 gJpd5MtiRxpB2mh6o6tzlgctfPZN0tpbx7mAtOWlykTD46V1Nvbr47ObhCby5Yu7nGv3FhynvllK 2dyjtUPVBKH3jGLw8qX4S0cp3T97HY1HN1HLzIeBMVIz3tqslkH1FNq//Yz56BYvYVuzxTQqoTzM mQtsxvRaRqhrIZY49tlc68QhhvKu7PIabfVaA8u9PeaLGfHgKhdfI8Bb9ulX9wt/8Edfp5E7oY3I lTnxmTnh0AHcO0L7ZmR5FtjZ2kUVhXaI7Gx32LnYYZEO7ETY2yE/2dI+tcO73n+b5x6/ySyG2gK2 0iRUgFaL+tnZi+MNMTZsWZ/ZcZJiKKUT35ngIyeGTG2rWotb3CGshPVQA8bI7A0T6ytPEHyT1lmN HojsdxPnwymn2xOaOEeInsm0lsmEkd0qISBtQDslp5Jig8xbZNEQZo0FjGAjUqRtkEWDzJvRW9FH p+habfZEX7KZiXWDGi4jDU60s20n12fQKt0vnrD91EPSnbVlCNvMcLIlO6VfS1mVR+vFiiWUzNBt EcbYp8z222L4ejlQTDpD2VsmOmQ0lQFvvgMngL+hlWJiykUDy4b28V3muwsKqFsCocjY6q1hwrs9 CeVgfsBzH/oAu4fXfG66onnktmS1UqXTTMdYIklJn32tlOx5xEeklkMFewyuqCZb8hjyOE4lBsgp 27B6tRCbylfKLE2xThbeymbsomag18yJZrYojVquvB/NxSOonTkR62Q1DvgWjRWY/mhnuWS+mBOa hrR/leHr4Kj79qYKNPoZ2vCESDawcmFp9CzsMEuJsBtguabPawORGmGuMyTu2OmiA6Fp0S6TQ2Lv iUPe87738MbRCdvzC8hF5ew1tBYVdKFkS035Cm4TQyCLMRWTZi+5SqQeMYQYrYavTvCYqY9MyqUi IWgnpZjICByOTRyZZBbltLJ/DBJZpY77q4fszPdp2jlDvzYAU7wZKgOayjxMB22zEFIBmq1s0Kxo nyweiFPag9rPd4aTmI1mg8zcCGmlyEyLPZkFJgHtEnm1tY0xtzQxH/f0n1uz/cwJw3lHO28QnwG1 2gxshnTZgXOyYS1hKV46k3KkwCZRWFxfEGaRUa4nk2ATRuFj8s5XuejZw7sU0ot/ZC+nWn+oecO1 b32S1dGK0/Mzz2fj6O4P7t1idzj49b/2+JOc6ZqXH7zMOf1E0BD8oFCqGkq9y1nfu917s1WwVZjA sRl78ykb56WS98pbKoeZeBcK6FVYhoaBxCqV8YTualHXpT2zBZd86WeAaqQWg40iWXhTIARvKPrP NwLRmfJ9NlHtfgt7B1eYtTNi27C9uKBPl4q937sAo9r9OiH+YaN5mJZFdlfEeAG6sSgfGubMaXUw PksboOvRs4xxQzLkiDQQZnPW2tDuRbgYqeiF0GQiyFLjS704JtgqLUwn6klp9QmaEzF4UVJu9kRo JtEMw7OO85JK2xnvErxVk2hpqYyzk0qwc4xyOhO5l8Sj/hHNSeSpq08Tw8y6Dh7ASsDwopzhdGPM 3X4wIm/0rlDOlnZ5RlAGqQvqZvy2SML+jObaDNltDVvuakhEh0weMunRlvyos/e+16Ip0b+xojva OiExkJJ1n0I0P5PBM7Uq+q6A+eWxIOWP0zIqzhva/ZYwC+NOmD5QkWF0nlFVvcY0mo3dtwqeJAvI dqpEDn/wNnFnyZf/xm9xfHZKrwZsZylcnfHsjwQkNDx8cJ/+fGXJHEJfCZzFY2iMlNZiCCYzcLJl GbJWlCdICSjWlSxNv1RgMCD74VHwnh5lV4Qn9/a5PtvhhYsjLtbrql0q17SaTXkJVsqtSdWLijUz ZgF2vTNaMiicLK1a3PacWOjrfifAcn+P2WJO28x44wtfYDPkT/5jCTB5e/qrwgwkGt+i26DhAlmu QXp7Q0nQPCNq492Q3nQtTUY3AfKSMGsIfcu9N+/whZd/m6OjFToYm9JmHYGoq6dzpmgnpOhffPNk Mr0KMWfblH5AZnEvGClaE18s3npO3r5sRh41ZXKNtbgz2TsLihpjtGb31uEptbj9up8tjvxHAp30 3O8eMD9tuLVz1S02U0XzRQyvyEnpHqyR4QwZ7H0gwR3ruVzMOvgjIjUVE5R00TMcbYhXFzSHM+P3 Zc9auoR2Jj3QPlvmlFeQM0Of6hgZa1IpMiRU3RnZbQDKpsh+gcfg4hwYHXGP7JutWTY2x7stkxKm bahJVlJAjMbP2UvCT6l/Vgm1USYhGr9+yAxfOOfg9k3e/8Pfwev/w+d58+49OjXfyaxKKw0LWdAu F2gIdHlAEa6/9zYHp49x9Juf5kTXFRZJFOtL8XEilklLAbtF0Jzp8TlIIjRitAFVu+6pVHe+9lIB VPz6ILDbBD52/TGu7N3gM2+8wnHXUaxhDa1Tx1vKAVd3Aam0DdSCS0RtUKaUsslLI7GKGbGAOHMV tU0PsLb8tQA7B/uEJjJbLnjp85/j3/y5X//3/rEEGO1OP606s42eHfWfDYj0yFytxleBPppWJo2V pDY9spxDmhGZc37/Ab/z25/h4YMT0tZLG+e32P6ZdKJc0DU4RlPUpgUFCb4YqmJaFCQStKS20+6F tSElmHNYpNDCKWTwyokBAwoH3KlFxpa2tb/tcfOkCChdl6BCR8fDzUOuLHZZNA0ppZGxqcW2yOwn c2/HnRCRqN4E8vZ7sJKjpMrqGBfBfkZVYZ3QYc3waDMBgC3FElmCLP3CrtG0GdW3XjqKulNgVk67 DRd9X9P5qRjUDnedfG8EDvF/EwnEhed8cSKJqGQ5tbp38ADTlvKo9G518nxjeaWJCvCyaDj766/y 8mdeRucNz33vh3juT30Hj79wzMVrj7j40kPOjy9YHO7z+Pd8E+0z1xlOVujBApqG+f5V4hq228Sv f+7TrG3kvMsLRjV+n8UJblKH3JfsdexLji89q9KmSCORns7vnynkS7mzP2/52JNP8PiN2/z653+T F87PWKVcwnUNduY97djSyLWg9XsSvNQqB2TBDhuRmvkPniQGf7xGyp7K3Ihw/WCP+WJJiEb4OL5Y fa2x5e0HmNkP/9gL27/4469o0mfUh59LGmzixNyDSxSbC9R5+29wQLGxVDmGLemR8OqLr3P36BEX J1sbvhYMKDQPXsyaobSwa7tN3AumaEaoRKjgwaeclIV7mn1RhDAuilgHiJcVI+RchnVN5xmMozYt 7TZmZUNhVeqoxi3dZKQ+b1BY6ZaHF4+4uXeDJjTOJBXnW7iLXwUurCNmI36mdQkVs62EwJoRFP6O cWtK98wynQAyhzinaKSEHSTMLYuRDslDDZLrrmeVBtaaXKdVL49fKa3gIoxxYCyNHGwPwmxvZjOi ynuASRbjAWPQ0RirTI731tQlfLeC4oazbe5fMHtjy2uffZX762N03XD+N3+ZK792i6c/9h5ufP83 c+M7zMdGdmbE2Rx2d5l96B2wO7NpmBcJZru885/7QfKfi/z2F37FZhGhXNBXE6eIMEggOgZYInsZ dpbUHPlLPG80cqgzHmPJeqbcbVamvE7CyXbD1cWMb3v6Wa7sXuezX/wdfvPkiLMSXGQchzx16Sgl Vy6rSy1jmQc7iIMYqXtTXkOwPdQlZRCpGOVMxtnUAeFKhP0rV4lt40EycVplG/8YAox9pF/QlJ9B FGmzr1vvq0m2jkfAcrQBp0EH0wUppIueB3fv8dIrX+bR8RqcP1JdEidtYlSr6XKBWs1NuZwdxeDJ I7yDKhKiA3AenHJmyFo1Jzi2Y056Uge4jSGnQH7+jvHa2v0zTGJgq8rmzRimU1zSykmUgUGUVXdB v1rS7OxBaCzj02hQolNRCMHUxJMTEsdqJBe8xxfYhDav9flkzODwQCQLRHYQaUy4pwYgJxWS7CAa 6dIFF/2abU50pDqoSzxiFlxhCvtNN/+0o1ROTYmBdq91RuxY5tRfKEDDALLbQNtaxrZOZlORZBK1 C/dHiPM55ydnvPILb3JlO+dkdUF2msLpds3Zl1/h0b1HXH/iJR7/6Hs4+JZn2J6suPN3fpWTlx7w +O4Nrh5cZ+d9T8O3PAU3oP3wU7znf/WjzP6TOa996bPc7U+40MGn79p9bHD3CwlILnC+ZQkt0btr mZkKj7HD+9urPD67ynx3l9Nmy5lsuZh1xIMlj914nNVqza//5m/xmZNHnPZmK1UsREq2XLRDUrqp 1o8kq7LbCLMAc1EaMWLeFhOrD+UyZ5MXdHlk0hfshZxZBuFmhCs3rhObhhACm6T8mb/361+XCPP2 A4zqzxP0jyEWXKRQzXNGk5gzGX51oi+iENBBCUPg4tEFr7z4Mg/PTxm22YfNu25GbVtn38Jj/V+7 mrUccdt2a0VTUkLbjDIB4JIHqzjy3SEUP18Dvsoiteg+rXX9JvvmLsPTzRPVph1EIkGs1GICiloy Z4FvLYl5P2Ona9nOB1TmIL21ZXWOxIhKQgYfDRuKStZp7FlJQdEB1wcKpZM1zl4q8VkI0pBlxpAb cspkNtWNLkpk0ESXO/rcsxk6tnkg6VAvduEAlbZ0uWz2VcfWdUVnxgaQimH5zbJ1VquMN6/CK95B SmL91GUADZYN9sY0FFroMtoX/MzwuO6sZ328QjebmtUq0NCQJHOyOuX0S2e8+do9lv/jr5IUjo9O Od+cc09eYV93ufKFQ5598cPsf/eHISyI73+S2//Kj7LzF36G3d/4DLvrh9zRU45T7+/X74WqT0V0 iYjzbIacmEvLM2GHb2ke45mDx5nv7NLOFxxcnLHNa06HLeftnOOzY17+0ot87uyIi2Rwbrl7BWwO 5WTEyv3oZ7VtXB/x6kz5krTvResSVcG6jJ3QrMV7BpqszAMsgrLc22O5u0PbNsTYcO/8a5sk8PUJ MKL/AIEwB5l5EAmW9kvO6OCjUH3GpTTYxsiRvGq4f/cNXn31PqtT91EtWSfmaKe+SguTtxhQQUkR fWnnPHqzgHVpir81I+u3nOlal2Lx/Rg3aIUSRNE8jgLNjByct9jC1OwokelUaH0RxiKQmlToK+04 0jV00crARgz8HqxHEOLM3o8PjtMhVdMaJZNyZgjpUhYRwjiwq2ZqjCXaoJk+JxfuDfS5R0RoQwso fRroSSRNNWzWCYMlULzlPQM106zhRacyD2/wIAbwhrdkMKW3akQTrI8ePVPLsBBCMasikNcZjgfo ldBENhc9wzZxY/8Kx6sTupx8NEjJ4iINga0O3NscM6wf2kMn83V5pJn7eoKcH/Pgl0957o17XP3V d3H1W94H3/40j//Q93P1fmb7ws/zKmrm8BP2cfTOVHGxQzIpZfak5VsWj/EtB7e5uXtI27R0JO5t H/HSwxc47tckzfzOGyc8yFvIgdPBRsIWEWORpZRnayZ5RClrRJUm+BiebMHGzNdsixQHEMEyl8EB 5yCjYD04PnMgsNzdJbatAegx8ubx187gLR9vO8DM//i//cvdT/+f7xL0MZpstnTqmIF6K3pwvnvE jYNACJydrXjhS29ydrGh26SanZR6traF/TcKYaq03fxQ9RazlUt2emlViYoWjCYSglkRKvaL6lP6 hOJyVxiq2Uh6aizfgBHwWgkMYo/mHVwD14KVVWVoeeErtBKrNkoLHiEmhnwp3+GNfsayb3yIebKy KkaCyeBI7lwikshqj2oamFIO6lsWilTMorrSE1BdjVGngLAFxxq6GhymwRc1Yd7o1TvBQUqAnxyZ pctUnmPknihpSHTrgZ1b0dhkKY94EsAAucvIbMSdbBElU5Grn0oxUFzas5PkpA/ks56ztKXHRZ3Y 9ek0s2Wgx4yUMoVwV46l0ZDjxfyIV175RQ5f+Qzv+/X38Owr38P8A+8iPnGLkxcTZ9rV7mNiZPGm lJ1TIixouBZnfHT2FB9690eYL5Z0J494tDnmjYs3eensPm9sznklXXDBYPYPObP2bLJYMNgrc98k F0XaxRwBdMFsLRvUW/AmIWi94dG5YH3p/mSnLpIsthKhttONm3ktCnsH+4QQaJqGHBrudV+3+PK1 YDBA1L8rM/1j5eivSPkgJhcoBBHNziw1d7G7dx9wfHbKxdlQy41SihSoUJ3jIl5bju1R+/dQ6iYX eBWVqEhRxZZOj4soZQrleqdkctOKiXKB5bOOJ65i7mGq05tkR3uZtVTAOW9gM2gy2YCzgtUXei+Z Pm9Y+bs2VJ9LM5+EMdcKuLK5dL2Y5AIibnXo1p6A5lBB1SKRqOZYlMb+SIQv19/Eg3iCYS2rwh+p czKL3cEEfBn/7CxY5/ioKsOgrB91HD5XirxAvejgI2MF2Y0jU1nEgkouFhWxesJIDAxDpqWhvVDu rU7YjgUsCWVDoiP7MD/33sXkF8VwymYIGa9FPQi9rmc8fPAZ7v239/nwvT/E/rd9Mx959N2c/fbz vJCP/aiSOrCP0LCk4ZmwxzOLG9yYXeXqzhW64xPeSG9wb/2Qz6/e5OXujNOhY0vmXEyQWVjQk4uI d5FtJrRI7QSVmV6lW1roitZCt4/inR6C9VhmAW5EI3QPAqdSmg1uquZZEAq7yzk7e/t135xttjzq 8qe/TvHlawsw0uinEP5YPZGCFXoSvA2bBcQAzGJPuelWnG9P6PvBtHiiVnfnVLUcdhJb92gYjBlZ tdbTbkbZE2oIVtnsxV7BAFalNGKKvii7UCaIo/9iNptlLo0FkrKhpR6u4kSmS71aKTwEPINzApVa h6eZlAYqJqW/JIwum9SmcplswAHtCm6L+fmG0inS0WXTMjupvjUhWF8r59E2dOyU2WOWQDa+EAN9 ywiMsRUa/DWUXy2SgcuPVTLD+qUkKENidbrx6x0w/YHn/wNoBzZDagbtAolzKwddk6Slri5NAhSZ BbZHHY/unnKeh3pg9KpsJLnhlI0dKRkNZLqaBwanP2R34g9e/kRWZH5n+yZ3f+6v8Z7P/ybPfOCb +M4Pfg97n/9VTrpzHmeHhTTMw5yDdp/d2YJZWBAbOwrO+3O+ePoqX+ge8saw4lHu6HJi67zbVAad iRs92WWoeJ6Q3UiNCl9emjajmSZcLpt6vweDwh5wcybsB/Pf3SShdzW4UTpKpmvrdBZgsbPDYm+H 2DSIBB48POJ//Vee/+j/TwQYRP9HX+alEC+KLxsBmsvWEoiRYRg4Pz+CdmDIudbsudSyBFQHGm+3 lQymONqVLOESq0Wn86Q9G1F8NKZRvlPZFWojZpsSRJhs0rrpPXOojN4iCJtaQYyzr6X0D31jlecW YFBjXbZBvNuElWeerloSVnIIC7RBqY8O9WV7Y76UJuVfg/nf+CYSFVLFULyEcRORUn2MOIW/k9Iu Fir/qN4zP1PxLCrVv42f5ZqXxVssMlSFbsicPVgZIa6C0J6frwbYCuy2FlyaJTRL6sBnnygpKZK3 nb23BKFt6M9OObo4qwFDPYD0mp3cNlpjZrQCo+VniwO/bbZEIHpxCmt6Xk0nPHjjM7xxeoennnon t9/xbmb3VuylhqZtaJsFTWjJIpz2p7x6dpc3u2Pu9GfcGVaca2KjicGDmM1Gt6uVxJ3vKAYefvCQ awOirOdi4yq+rdpos6sLdUMYqU5R4FoLB9G6nChcCfCIQgIv/tX2dRngyQD7h1dpZzNCjEi7YL38 eoWWr0OAaf/n/5cv9P/dv/1rBL5tdMNR18mICSA6I1lpUtanZ2w3G1LOLHfnHMsGTbmmgDlbLT1o mvh2FDWoC8Z0pFGoK1Ob4KCjjJNZbcKeZVRNLH5rTq8u5ZH66M3aCiwdbuPDRC8/yjgJVbvBxb7B ToYRBS2mVFmhccwg+T+EkCtVeyxxxg1bBJqAk7HMA6Q4pGWkjGOzzEECoqHObFJtiqdUDR+1bVyZ uOUbUq9f7XRPCbRSfrb0iHzMV/L3I28tk+wxCyZQnjehrM47zt9ccfieQ9sFQzbsZQtIIOzMoZlD s7BPzUhOaGzNE6b4EntEDoMwXCQ2uXdSgNCVTXzpuR0TK611tftY4mwpb+26mMjQ8DS7iOfS89LF PfQV5f1PvJ8bV/Zgu6WRyNFwxv2LE+53x7ySzrg7rFnlnjMd6DQZ67aWPaO/nrpSuqwBm5prYW/a Qo619KZih1H8s7w3f6PlfLgxF641vv78PTYC26SeOStXorIfrS19oxEev3HI/tVDC1ZBaPb2eGXz tZl8f10DjO1k/rYq31bEG9V7ImS0M0MgHYQ8dGxXHd06oRnmu5H5InJ+OlS8wEx7jCQWKglO6Idc a2XRyWnp5KKSJmfNPivYgsSQTXMxEU5fAtQaq5tqx2VceNn4IqWvUsoKTzMLXIEDykFLe9o3mi92 KMzg0keqeUPND343pzi0UNGph37p1DDBmIC3lD/jbVFfvEX9OzoVl6A1zY7Gx2LyM9MIolrEVpMO n4yLvADwZTOX3GwYEg9eeMTBc1eJs2hq8c4/G/cqjiXItHZSxMYQyK0pzMl2gkgTbMhabIkSGHJP Rtjm7LgL1QyqEgT9nSbMuL2C0Yws8aKS7hxAF6BVI6at+47j04ekPGOdthytjrg3nHM3rbmfVqw0 kRwMF7WSeMjJFdF5vJzuAVOy5sglQf1YvjBqkMqML4MatXrGSAjEnI0iobDbGBemYOjFkuks2fMd RrgehavBJgcsIxxGYf/wKvNdY++27Yz1kLj76NHXrTyCr0OA0V7/FpEfEzCLRieMaJV/mg5JVzDb zMnnZ/TbgdgajTycmzFRKYFKuZX9hkQJDvKCsw6+oiwCSJoIhNrJESljhIo40e5a8g6SjaEwECQ4 xhMpWIbWky04EFhnB4fLJLrSQUliXafk3/dpRiM47V12cUBcPZUf259asyjxSOeStsrIDTXdkLG8 KhIKpLKP1emkU35I6ZAVBtH4fWpbumAtUjdnjS/+CicdvZJFlh9wrk+9L/5LQ1ZO7q/oN4m4Mzfj 79yZCn/WQCifreExkrw97RhSb0tCy0GwmDHb2SES6UXZ5FTvFx7MB5m8bhFyyvXxqmmWjmCvoM7p cxhajcnbEDlpBr6wvQN94qhb80Z/Ye1+FzyWDT34AddpoepPXfCo+F7Mag01irmfNTEKHiO+KZOM 3dIYGDVH2N7o/TRw62TmtVCd4oPCk61xXfYENlk4ThaolvM5y+UOs7ZlvtwhSOSl197gkz/1N79u AC98HQLM7Ef+3U9tf+rf+jLk5/CFXO3fAtA7jwFhnhYccMCD7tyc6dpgGzbZxi2O9amwSPFTR6yu HBdwOSFL69kzJU0QQkXXh2wljBS5j4f2ojVptaiAxMdraiVOtZiauvRdyttBJ32Vei8t3CQt3Xor b5KUgV0lGysBRSfBYqyzi/mzN+NqyVMWvW3skjJQw0SR4JmrWsFzKNGiXjE010Crk+9PKf7lyzTA lA87ZUuruowwKb+k9VqURCGI6bdWFx1pncaoNDNnv9C2EJwnE6JlLnjLuox9GcqbFdAAszm5jWzJ rEnjQHkpZZHPJcpeEnnkqViTX5tpGTe17shqZu8iwkqUi/6CYX3CRgeyZrbeBSpZd0Dos5LVsJ1k aCwF106Ti1vHkIi1lS2zcWpF1hFTkdEX3coiCwrVgFzLcQs70T6NeCfVvbENsKeG83QJ3szKo8Fk BNcj7Fw5YGd/r7J3BwIPwte3PIKvR4kE6Dr/9yj/agGmijBPM864CmhvA+evzK9yo1lxLhuj24tv itF1wTtDb13iWkuFnMdNIZkqIxCEnJQUjJ9geyqTBxv7EDxjMK6M0qnaz6kNwbI/2u4YhDplwBpH tiKsTNO6eIJYIJng27bts9YxLaUWj56ZxBjc8c0RfUZMpOiuPNGZdGUc4C4llY5Du0IBwmspViqr Yl0xWn4Ws67if1O7St4dq1mZ/10ngUr9OljnqgShEqQmod9Z/dl2A13qGNbJJgxsjSzHjudr0RoA 1qZu7ToPFnhyFoqy0IBiOzpyl8iFV+Vg/CBGKiwvt5zlmRITpV6DKU4zXV6B4LwZw522ebDA4kK2 rKPAVtSWdkdmq+M0x9JyLplGyUKm1WdwsM1gS6nDBcsyq4Q7D1KtjMrsYoAfRZiLchCLkZSxelvP xqKamnqd4bUejgbrtO0H2A+ws79H0zY0szndtmM4vMEXHn09osHlj6/dsgrIF/m/yyu1tmMnNjM9 iw19ScFBOlv8QeCJxXVuLK4Q21jnG6nbHJQNXIJM9jF41Q7A9UOBPGIhnvNmGfkdg44jY5NvmjLy RCkA2kiyUx1/t2hpkhailru6T8qf8rzjmDjfCL5IsgPSlnYXq0M7iZMLFrNzX5KOj5J1BCZLMHAT OZLrX8r4Dci13eqj6y5rherr9CDgpadqYdqO9X75HP8+cjEMUyqv2cpfc9efWAp4iSYRs5qowVXp u8zZm2fo3S16lMkdbmUfnejhwSNEK5faBTBHeg9wIVZPL1SIgzAnsCDSEi91FqfHUsWUyvXDiJwD E6mJlCFopT1sPrYX2rHOQy1Fiy1yGZPbZ/Ny6SbPoZPgknxlFKRAPbNpZfIqdRI4GGdMletuYkcd myDqNA4H4ecefKITPxdiAtzW1/da4XhQzv1AnrtUZk+Und092vmCtm1RMhebgX/rv/wLU9Th6/Lx dQkwO3/m3/8f0qP0knaC9gGGaJ/auKeIK2V9PNAsLnlu9iRP7VxluWeiyOSnfpAxIPR+w9VLpiKo KzcgTRZ+Ge1gJ0eurnWl3i7AZimPCmnOFQ62IP13ki/mclPRceOX8q1qO8qmU634T22VqpULyU+y 4j9TQEXTUNlKKy3V8plULfvKuX5Pa1dktHVUDAzObhNADV7ja0tkkoo7IIyn7Wi+NfXVtdO/dCKK /F/9NWUtTN7C9C+vSY2gWDKfPMoJhiHz8EtH9GcDcad1CYnJAOrQtdB4oJlBmNk22djcaMTHxdg0 embzlv2wQ8xi7w2tuFEpGrVkWZWQOY4uUXf4r8Fcy3RPs8bscvYArLUcSd5kSF4GJcbra4eBVu+W 8jt5ck1rhssEO5QpO9sCV+k0Nrjz3MiAsA0rxvEB2HPvF3BNsUsCWr93Q4KtZ3Kl+7QUWO7usbO3 y2zWMp/PkTjjt1+78/WOLV+/AAOQjtJfSw8EHVo0zaCfQWqQ3I6QoiNYaQb7sz0+vHgn75zd5MqB O8LXG+onYiVypVpCjKdqKcfG3kzOBR+gzlEuIOgYbOw3S2u6KHBKx6pQSHBwOHsplSiLqZg8e/tR ZRJkRvyoktU8UKVkiy/l0RGttlF1gihNA1r93iT1L5FAx66Ux6jKtK0L25+nZB416GQfbaolO5Lq bl++Fn9j+yz6KK3BNEmumVzGGj3J5/6UrlnOhYUtxFmLXF/A4RxpffJlwAKLlAymsXKJBhki5Oj3 2QORCHmTiHsty90dH76QfDJh8QsqfsEjRldGBlNBeAtcxZWwALFbMkPO9YDD11iRGxQuU11L1fFQ ayC+xMnybGXwSNur4YLFpLAcCnYo2u+XGeyom3QzwgHRD9socL11baiaZ7sC6wSrZM9zluFcoVFz gV4Ew3J2UA4fu8V8viDGBgmBux38iZ/+2uYffcMDjAh/RVegFy0MLZqjlUrlKMF4MRIgzJRultif H/Kt8X083u5z7bFd40VI2ayZxpH5oZ4wXDoSyhKYpvrZiRpJbFMnP43Eb27OZWNKnTtjv+HdGt+c vfoEPy9BqAFh2s72xTXJlkqZZ5tPDRfwYFE2fqpgn0+WLCdjppZkPrnE023bEOo1u9bAWy/FpMwZ g1Z5Z9mB5TJArGaCKjVzKn6yttCNap+z1lLKeEq2EQbsFC33JEdFg2m8TCAt9IP6sHbh8Moej33w cdobCzQ6P1UACY6tVM6qA70tmlsIMyTOEGnNasKD0TYnLlJHActFDJhti7GBCq2HhFj5IkZ6VL8f tZTOY6lomNbkSpasSKwUixJqOZ2xkrWbBKAa5P2+DJPgAOMBUMbLFnWz7Z+RulCSrtJiKAeBebsL yyjMvKQrQegswdpf+Qrl0aCuSxIOonVRG4HDBq5dv8FsPieGlradcfa1Dw/4xgeYg//rf/hzSPwl UiSvImxA+4Hcr8nZeo2aFHJCpUcWA+vZwP7ikG/X9/LM1Ws88ewBOqvxnwGt2M2QS0txxCQkZy+T xkWj5rPJGEZcEoAi7upuM7s8ja1LO1Nlhf4EwclZ6nV7KOBgCS4lWEhJccdkdtrGzfU0dGzDM4Qh T6woS5kxCaBJxyBSfM5qjV4DWikPx3JwfN4xm8m5AK/jqV46QSOeBDmU11E6LGOmo7hFCy4gFAsu RKm4S99n+i4TJXJlueSppx/j9kffyfLmHpoCkoMLMc3+sjZ6JSASESKSGyTuIMtdpJ37WI2AaiDE lhxgm3psRkOoCFQmEzQTyQyiFibre85EAjtxziI01U851Aw4Vy1ZMfouWq8GreREMOVzaRLU1jbU qGDZjX9rEnBG7pN1doY8oTr4z42dyjoRuHKdjG9lP9sr1b7haICtmiYd4NHg4nOgFWWGreVlFN4/ D+xd2adpWmIT0Gu3OHvHu75hAebr0kUqH6r8NHn4Du0DaZtAO2g6aJOlwAPkIZG7DNogO4FNm7g+ u8UH14ndd92n3Wl55XP36HqTCUgoWhpjeJbWMYCGy36xuP+LibjL0CmTtMWKrbjWJRQKvGDhTzwF HVfDWIJkH+E5Maryjm0sg778l7I6uY8y3nbS8fLTzgDFCX9l0j7NTsoS//lUukSWoNf02xajv/dA LQ0oeqcJ4DtmOiMRcnrT7Ge08nugDFIff0Qp8gY3FBVr7Wd3TQvZrTJ6WM7mPPv4Ld71LU/T3twl N5DSQB6U2AQzzsKtk6wNZu8uBBPqaETmO7B/SBh69PzMJlAkRRiY7+9y85nH4RXYDgNnbFlrYjMM DDn5tWmJreuyxDpE83ZG07Scr1Y83F5UA+/kJL3BNy1Znexp9zy4t3Mi05f3j2UUKTvZMpRJjDiP awT2p7wiU1l5lowh+MGtK8v00WJ0bx4zdvW5fPMAAGWfSURBVPGjZ7U4Ttn6Wn2zM7HjO5xTc67C WXJ7V6clLOwS80RQ3vHud7HY2aFpZ+weHPDFl9/gB/8f//k3pDz6ugcY0J/Kq+H/LnNtVDvy1kaA 0makNQsH7TPabyH1ZhUpM9ZB2UvXeZY5s/cFcup57QtHbId0iZLe46xUTwtTHjdGzrWT7D/jWIBn PoNvwqw2aUBU6QUiqYoacw1ewZXJIOVEx0bQjgppqac8NbfyVre/lgErGYJnLaUtrYz2h8W4uZyY JRBBSY+ldOgZnEhXyqRcnO0mZU8oWMCElDel6+ZC4mDsllk7PZtNQxqzs3rty+9SBJliqvny8Bn6 wSgD125e5YMffTdPPHadsGjQXSsrmmw6MM1CjpghGDak75K5jKufWcyReNVM0VH0eEUYErlX4mLO 09/8Xh67/Rzb8y3bmMnzhvuvvs5rX36V7ZDY29tl/8pV5oulzVEKDefHJ7z6xhusBrNgiCgDPiQt qxMzs8s/Cq+koY2RbRo467s6zljxaaPevh+y+60wXu4CrJbrPok/NUtBrdwZbNkBxf/c2spVXiKj yLG1OMOdzrCWAxdAdhk6rPxSEfYw3CYjLAK8Zw43Hn+c2LSEJtC+/5v4lf/iL36jYgvwdQ4w+//7 P/vy6b/zr/8FGfRP2Txkc6vPF52pNdsZmqwzol2HrhTVFpVIjDOunx+wev8p33TzOUQDr73wiNV2 IGiqlpCRQPJav9HgbmIZ8ekBtk5HQ2zx7kGYGAb1Cq1mS9XFyGtGQC7tSrPfFEfYamtb1MSE2Qx/ ahvcyxRboFK1Svb7YlNawF33rGzr1Q2C1NqdOOAYSl0+ARDLhzh9XX3WcpmjPQVksv/uOOq2bF6Z cFvGVSuehZT+u72fPOb4apldlqLkVhuDipdTCnlQGgLPfPAp3vcD38zhzQN40KPrhAZ3Fyxy+iYS m8bRZCAPNuA+J2+DlM7SzPuvCS5W0CY0D0g2RXZoGhaHS+ZXlHt33uTs3gN2r17hg7/vJufHZ5w8 uMeDe3fp+oE+DaxTz3bo6VMRbRbAVCpbNiqoBgPqg3A43+XJK1e4c3bKg7MLoPgHMSlnS0lsUwOm urbBM5fAW8pqLOvbQ3hPnDNH+Y20sQNpEoBErUyKodhnWsazVlNa9Ngaar3zukHYePa79CgYgHVW 9oNwdXeX5e4eTTTnuu7qDTah/f+fAAOQurP/mk7+VDOL6Cz7Qs+kviPkTB4SmjpSHkjrjnymsNml b85Z3eyZ7zUsYsOH/4ln2Lk654XfeJP1SulzIvqWi275bSFMnUoOI8vWAL1iP6Bkr9Vtcxot2zdo GOlppt4uXaXib4tv5JJRaLV5kIL4O+dFnaMjItX1rErtGTUiyVKj6kEz+q1kIw0WVMDr+0FKeaSV kWpjVfBySIrP+khSlNGBvmR2lQlsT2+aKwKFUGRdJB+z678b/b2W61uubcIAqJxg3rbc/vBzvP+P fpjlM/vWyliOQb5678YArSI5Qm8KbZWEpA6GDtLcWtFBoHVOQzcg86vIIkNaQd+BOuEQRWJkHme8 +eILHK/PWcQFXR646Lb0w2C4Wh67gFVQ6utj8Osjap4xPcaxurbY51vf/X5OTh5x/94ZIkozAehx GoU5KvvBVvAcT2HERYaDiJPfnHoB7Ejgm+KcD8SWL6ftqEfT8X51Dqot/H6hPj5KRo7PPNSE1DIY ZzDP8YxHLQDdbpQnn3maJkba+Yy9mzf5uf/8z/Gv/s2f/YaVR9+QAHP4Z/+zv/Hg3/jnf1FT8zHp fbqgCpo783tNaj2LnMnbge3xmrR/Qn5/JL937lR44eDGDh/4zqfYubLg9c/f486XT9n2vSuMszN/ Lb2e4hiaraSJVc5u7T7z/qAGpWbiVZrKQSRaO07FTqFBx0mMWtzwiu7H1d1aGLjjiVVA2cY3evGM KZlFDLl63pb3PCbQPgenYjMufvQVKKqj6XnpPqh339w9Pky4KurlIY5DhaI9AHIw74jkhKLSrrfI pNVnxgKel28+5nHI0CI8/dhjfPjb3k9c7CBnGd2qzY6egfPnbaXFYIHlZGNTJnajZTbbLRrXSJhD 65IB9WNZ5rB7gPQ6EjZzdtBXOb97nzuf/x1WZ8ek3HGWViS/5g2hBs4GM4rqRev0iSzQOCPaDKrs fQ5qIsff/vLnebResxkGCgJXdHZF7WwBw65ti5MzHfNQb+2XZK20HwPCE6HhHSFywsBdNckD/nuD g7JFuNt5hiqDrYiZr9vGf75kKyXIlBNNPKu+0QjP3rzGraeepGlbmlkLVw/5zBv3v5Gxxdb5N+JB /43f/6E5qn9EkpprmSRUvNmZ3IphMCR9cy3QfbBF3z2DxvkLbp0Z28jVWzssDxYEhfOHG3r//eCL qET8EtWzTMyqQwHMMLNov7mhZCblxKeoVrWCmdGzH/GyApz34Cd5SVlT/Ves5JCxdPJvjmbhpf0o b+GwjNVIzYLUH7+UfQVbUmQ8smTsUJXyx0aXltLRvl+AZg3OtA32nm0Ur3o7H+pANSZSA6wUEg9c tdsFpEG5trvPt37oA+zM5uiqs99sog2hW0YkNJbaNxHJAY479NHGDom5mz0pXhrNkNnStEq1RSaI uiDSp1LEZkbuO+5+/gu8/ju/w4MHd9A8ELPYvyM24cExqejldWnp2kw76w4JY6sXRtVyl3pOug1d GmixABXqXZ24BmCllfj3ENMDlbK1jJY1CYEVrFcJPB4aepRtzpyTOcJKZcfpKRwsGz8yXo55EPaD sGMEeRZifJhWPDC6w8Ac2InCThCem0eeetdtrt+6yc5yl+XeHif3HvB9/9Xf+IZmL/ANyGAAyPn/ raI/lpSntc9wMRB2gGYEZFcz4ey5BemqEa4CuJF+qnWuaVqEx569wu7+jLgT+fLnHnB+sraOhDo/ xMcGjGm83ajkBXGgoMB2OkQ1TGbwgFOEa9bXcOGijDqXJELjG3moFhFjd8DsIQrIKnVIYbFqyADJ syrxESmqpDC23cvgrJG5Oaq6i5VniXVaSjPs/WahTh+0et+zupqqG2alxbpC8Xa+wx+5PKaO78tf q0p2XKYAz+MkykjgiYNrXL1+jeHkAuki9EK8pejBDEligFdskE2Gkw69s0K3CTloYStWRg9b2JxD u2/tqEKnzpZuaROhFeTA2tsXL3+Zh5/9LR688gLnm3NEldbpCNFL1eRdl8EDt2QPAlADq+IGTvW9 mZdLFusEzlWLmR4pWyZRLzu22Xu/oDpJ1JwNYXOK1OZvJV93BwRuhIYLTWwRnhJhpib0rbBXYQL7 YyQdh9dfj8rTMzhKMPQWXJr6/Hb/FwIHwaY1LoNw7eYtbty6SZDA3rVr6LUb/Mxf+m++0bHlGxdg bv4Hf+Hs3v/mj/8XRP0/5JzQLjEcJzQqcr1hvRc5340McxvRSgIRozQmT+mN51JOWmV5ZcmHvvtZ 9naXfO4XXuP0ZOVpopKTj2Hzo7fkAKIZcqgnePQFkoudhAjZrTlLFjTiJk4c845SUVCXACQO1hUr wsKwTPU5Cv6j1f+3dHAqZbywpzxlN0sdw1OCs0+DjMerlBZqMd6CihmVAq3KGyS7Kb+JP8VFTTV4 1epr7FsX9lDJ3pIaEq110edadqGwH2cc7u7DuievBrRTom5spvdGyGc9bBPxcGHudUcb8nFnF6lp kLmnkQkInQWaYYuZfZvg0UB2gbnphYf1Eat7R6zOTtAm0sYGGRJZzbiscH3cnsj8WbxMHrBN2qmO VhqYWDXWstReXpRiuWFlc++bvfOAHvIouciYR3mf8Cmh1HvRYIEpAjdj5B3S8iAlXk09SwK7TWQm pQvpgWXSOXJBBbMAh0F5ZmYB5MXBgk4jRqYrHjiLKFxDeSzAboDFcsGNx26xd3BAjC1cv8n6/JzP HV08/3sRYL4hJRLA/+6D73uZoH+arLOcM2mV2N5NHDeBkxstaV6Uu7YZCqXcy1Tb4BkfV+IXPMPu NjB7OXGyWrEuxG9h4n87SfOdbxKkbCDGLAAqn6OMgo0OluJfx2axb3Bq5luepmIu+EA5ShdhQswC C0IlVsikxKl9gxIoZPqMtWz3S+I4E3jpNH2FTuE3VNqEx3H6PiZMYP+tnLzrVZ+r3JNiR6E+TcQF qOW6eb/1ynyX5564xW6ckYbkKvoIRPRoi/5/2nvzaNuyq7zvN9fa3elvf9+r9171DWqQBMjEQAA7 GIPpjI2RCcGYYRyS2PFwyHAySJwYE2MMtgk4NIPGjmMMjAwwtkxrI2EsOgmQUF8qlVRS9e/Va297 mr33Wit/zLX2Pq8ANzGqKpXuqvHqvXvvuefss89ec8/5zW9+33MLwolDFh7xgjtcEk5jtygIUuSY XC2ITZbFAckiClDFXoyP8LiDcHCMu34TvMPmRTfwGkIb3Rl6CkPKIFPpq5IfvSqcFX0JFfPWAGRi pmACnWunRe2+svQxhV7qMpVTFrqy2YhyYJIjo4mf08wYHrQlJggfdTXHqG5zLYGpCEd45WOFLt53 NiWVhTIE7ixVFvOpWqekC9Q9oBQtjZyHGbBrDdPckNmM2dYWexfOM5luMNvehMmU3/iVt/L1v/Sb Hzt23dr6mAWYv/+uD9z6xrse2DfCf0YItMct9TJQC7itjFDE+t4ncSoFxUKIF368iA2Ag7LxTBcN 2zlc2K4YnWRcP1mx8G03/6EfeswcIpCp1PDUSozZBawBJ0nROwpsd1stBZI+Q9DfM7GMWSvcSdgJ a7hNzCpiwIruUCrvsPb6aXOnUilBrP0UbiJ7JcJeXzoF+lIpxLciorsjTR93wSXm7SHiODob1Wcn IWLn65a3IbnNrWVHEZ8nALvVhHt29rFidARgYPVWe+rguFHxkVaHY8K8wS/amGIIUubY6QjJcjrC XWxjY8v4ucRJ/OMl/unn8DduqulZXpCVFVmpYtXGK7andULb4yyx3MvQoGFjxyWj9xcyMQNIU8sS M9EYpzXYmHR9RRxHktNtiCzfPqAZT5ctpeCWBThvcnYk41nfcCP4bjC2ALas4VrrWdEHF4nHm0ec 5WIO5wsdbtQxFj3Vg9htWjgth7Zj5lJmlswazl26yP6FO8izjOq+Bzg5OOJV3/0jH3PsJa2PDQYT V3vk/5Gbu78sVmyoA6sCmp2MNhcttdU2EGtTpyJyZV0g845q4cnFUxr9kApRAzdzIec1+/vsfGjE L7/1KZ4+PaEj3AU68/Yg2kRUXovp0tmUOQVJZhpRCEokyhz2zo2JIOfiY9U+WbqgYGOaDalN2fsG p5LLECKO0wsQhTV3rQ7PpA+AIe5yiaPejpQhaWCwUZkvtUjFSDQbDqnx1HU+gu/npTTe+T6YdaUS 3fmBDv6Is1sxeLpAEwlyNgiTwZBqUOLMWqmz8von1XABQqNgf5eh+YAtLDKteoCj8cp5WSyAOZQW ihx/Osc/fZ2wmCOxv27zAjFTbFZQVCPK8QbzG1eYH16nPj1itVwQnENcz5+CmLl0hLfQteD1/EZu THwbRewGuRgsDKFTmsvQblstPRelCfo4Z7RVPEB6kl0EZk+851ZQbliycDcSWAanRLzUeAgaSErR ptquBC6VMDSBudMWdK4df5Zey7ZSYMsIU4FJmVMWJXlVMdvaYjSeUJYVbO3wgbf+zsdyy/+u9THL YAC++7FHn/srd9x3PhBef7JVcHxnxWo3U7DRK70a6AAyAhRPL5ldWzE6bRjOWwbBY1eeLLFVRLsa JjPMdkvuuWfK/GrD1ZMFDiELyX0x8VA0eDlJspJ9aRNvVN3/9I4jEeDsg0Uap+/KHulFnXq9X+la 1RL64JHKodCVTjzvdyW2kJO6fAo2Kf2I4lXxZULonQUVrKUTtgI6NTkEQkOUaDA9vkXozkuaMeqf OwZ6o+TANOFOUDEn3+E1wkYx4r5zF9jcnKngVrLpjZEydVTwtuuKEdv9xoCQY3wBpRK9ghNtRS/i LFhWQBNwV27iDw7pZyJiADcGYy22qMiHY8rRlGI0IytKjM11Ujp1/byPWEYsaVLGEfESQzI7I05k p/KG6IWk59zGgJAIkiZmQwlDS5mTic2DxIvZxDAW4UpoOfY+kvEC48xQijYcjkJiAevzl0Y1uTYs PDiAkXhqhJMGbvn+2m2CxvOpgV2BSWkZTydgDTt7e+yc32c4HFO9+jUc3bjFg3/re16w7AU+xhkM wAp+6ORc+ReX5/OsKdIdOeqneD1NQTziwRw5hk+vGOQBqQRTCX4VsJXBu2it08RAkSvjaLJR8Mf/ 1D3M3lLytocv06LcBrqciDiwFqeGI7M2fUCdMpvoMKRIamOnQf5+ypoek9W5JVFEwydZzPicLqbb YY1yfpsWb+wuZIkZi3RSmG0qqdaGHoGeWBb9tL3ETM2Iuick3EqE0CrTV4N4Ane13tQpYH3t1KVI dX+IpnYSklSG8jES90d833nbGU/Znk3xzhOCw4plLSaShME7RDuYLtjaasi1jz7F8W++i60772Lr cz8ZpCUcreJ9f0nghHZxQHP1ljKs8yIS67JOnzeIxeY2BpqCYjxlsLHL+OSAxdENVoe3WJ4e0C4X NMuFzkO5ph/yTHQGiFP3IZZB0k3ntwTNYINmLkldzoiqx6X5pRWKzTToTcqgwXaIYd9mXA8NK3GU aFMhM8I4DzRN0iNSDaMU/Cq0PNrIFG/xxmAJ8fm1YVHHrGnTChMDo8wwmc0Qsfi6ZmNri+l0g7Is CdMNHv43v/pCxZVufUwzGIDve+LDV77qi16z5yyfnu7aaWw9gZcCSAvVI6cMDx3ZsEPgVCqkEExl kFwwRcw0IgIXBAaSceHeCWNTcPnyCce+1U6RhC4zSne+RLNPOEkH7saNnjhoVoiDlXF13Z/QZUUd B4eYqUgPMCfhpQTaSgfeyW1As0TLU71jprnuNVlM6YHklNqnoClZ/zxJQCm4QPCmz2RCKsGSxg49 9oL0jpJreKo3IMHHSeAYin3fOc7F8uD+HVzY2sE7vWlI0QPP6+ciEXEkGt1ba/GN4/HHHuXZk2dY 3rxBthIGGzPMoILTBqmhrVecfuRx6qNDlXQggkTdGextckUMxliMzcjKinw4oZzMqKabVJMtyvGM YjCiqCpsVZGXA2xekBcl1liyLNffpx8o1U3ci6ob+qxmPVOJMV6vGYjOi9phGiHs24xWtDQidhRL E9jIYWyExsUMJqoV5qKt59Io9oLAjUa7pSFoxjKM2dYyaJYzNbAlsLk5YTga0SyXjGcb3HXfvUxn G9h77uXq4Qmv+pZ/8IJmL/ACZDDoxf0DuPC1YmTqCR3tufGezArOBGQJ2dMNGEfwGeIiuuZVtFuy gGRKa5coDZAo1a0N5M7wutfvMRxk/Ktff4Kbq0XnGW0wHZPWBs2Y0l3IkAhkqimSFMbSwFnKl/sh wWRpazqxqyRuZOldFNf1+yG2tNEMgBCzrFjvJ+uVpFKvEFLqDEWfJiCBJdoWl44YZzBqBxIdNP1a 16QliSVJlw3FOWZAtV1sdBMMHWLsO1kHCGrISLwxiFDYjOlwSGYsTlokDvKIJVKFiSzcOIaQ0r4g 2KLiuaee4nBxQhuEY7fgynvey1TG2Fdcgmstq5PrHHHI/Mp1QmYYLBcU001sNcCWJTYrEZurjIOJ UhliOlkHMRkmy8irEdV0C9fWtMs5zfKUdrXA1UvaekVbr3D1kma5om1rmnpFu5rjnKNtXadgmPy3 9LpwqpsjgdY5aueoWxffcojgrg4wzowlE7jlG3JRgLiJAX5sNYgcEPEU+pvtQPRnBjiJ2HUThykN 2ik6EtgyMIoZ6KgsGE+ntHVDlufcdf+9jKZTTFnizl/ikTf+3AsdW4AXKMB8/rf/5Pvf9E1f+f1N 67/JWqhrj7WqvN+6QGgD5YlDjlpCpXdVSal9RDwljTcH6anvSKdV5ND88qFP3mSU5fzMWz7K06sT WgEbfOcWAHSexAQl1EW6h25iH7AmxDt76EBAYyRSzDVkOI1Qyq+JymI+aoq4yC8xJkoAxK3q0hyQ CK0oUS3N96R5opSyW+nxkY5vEQLGxBmk1qtjgVUOkPcJU4mlDVAnkDe6LcQ2kx5/yr4klmURqwix a5SsSdIIwroUpTGW3OYqShcCoaLP7dOHlab+YpcuBPQGkVuu3rzBQbuM82GG3Ft4/ICwNFBNOXr2 Ga7d+qjKJGRCu5hTHB2QzzYoxhvkgxG2rDA2w9gMMTpy0AUa0VIKGwhZhi1KsnJAOZ7hXYtrG0Lr cM1K/9Q1bbuiXS2pl4v4vYambaIanutuMG1wOOdo2obWtazqJcvVirp1LOtaxwoCbJkMI4aroSa3 CQvrO0yFwMzCDTTrLGImVIl2h/K1TKlYAw3H9NpEg3hj2rIwmYw0ExPDbGPG5t4ORVEg5+/g8oce 47/4gR99wbOXFyzAADjvv48Qvqp1creEgPOG1oXuIpZDh7QeNwe/ymAUyxUPbuUxY0vnE+20VJDk XpXSANFy6uIrx/wZ7ufXfvUp3rm4yUp8bFuqz5LS52JmEdPfdOMFiW4BYGw/X9R1WdJ4AqHLT1yU YzSWLmtyCewldKS7tI910M6QoZlQCL2Xj10btozbNU6D977UNpZRPspVpKylb3mHzo2gz0PQSWRj FMNIQTECoT6ofuP6++qEqBJoHUHeXCyZtb33Rt53jCQzelPI6JH7KIdhvFDPFxycHFMHh5GMVfCc 4vDLBm6tYHjCOAwJYZuj5haHzRFNs2Q1PyY/vkUxmVLMtOzJB2NMXmJtjlgtkbAmZpd6JjToeIxk 6ixhM2xe6Ib3jeoTtbX+HRzetXjvcE2Ld22kTkQFgNisd87j2oamXrFaLVgsTlks5pycHrE4nVM6 oGk4oKG0gSyoF1LSXy4MbFfCQOAgE55zgRLtGo2jDnq6wbQEbTuLWsHmKCaToTieiDAeDZlubWKt wQ4qdu+4g6ocYMsK7n2I9//jH3+htvnvWh9zDCatH/31Dxx9zWd+kjXwBUnHJW1oCYHswDF4doWs PGZkyUZGS6O4EWwhSL6Gv7iu96Ffg3JWgmYb492cO4sJG8/m3Gpr5tL2pDhSZyj+Gr3pWqKPF/3R 9Z0gUsdF+j/xOTTDSbuM7pGhwwmSzYi+RhbLrcQ+TZyXnmgXui6TXXtJE5nFJnVkQt96lzXyXXpv bu2LFOhM1pk9rEEba24Oa2EmQmUdP8MJFGK5/45zjDfHuNwR8d2YTabWd39uwGBthjUFTzzxFE9c fVYtVoPp1Ah3ZEQVSjwN2cJjV3ASTjn2c5x3uFVDs5rTLOfUqzmuraO4uyd4R3BOp7MjCzAdb/q0 O6A+BR6TPl2jwSnTwGPzkrwYkFdVxG1GFIOh/ns4ohyMKYdjquGEajRlMJ4yGm8wHE0YDSZsDEYM TcGpaQmZ2hobY8hR98WtStgbCFtjSynC0SJw6nSqfxbdXMoI+BhRsLc0wkbEZBIHKc3A3Tsbs3fh PKPJlMFgwGQ2Y2Nri8F4jJlMubZ5B5/y1/7Gi5K9wAuYwQC4lu/B+K/wgc/ERwGp2GZtBqqFElqh vuYozmUY03sE+SZgKkjm9KmgDbftdU1jPYCF8aeUvH5xjo3fqnh7e5UPcMhKHEmGvOeqSMfSTIM+ NWomb40qmon0Ore5SSZYoftdH82CJIqAp2ndNL6Q5oMgzQxJbJWaeF/suzVpbySl2rCG9SR4tu9x 0VnhJgX99CpZ/J6KScYWuQl4H9u3YmLqHxmxa0C2ZjzrADLdJLgrPKf1KdipziCmkYc1e0KxKXBJ BHf1tZ6+epUTtwIPddThWeFZNjUuq3GnHqkDK79kERraoICzD6qmtGpXZM2S1fKU+vSYYjijGI6x ZUlWVCqmlJfYPMfmOWKzXs60T/FiZhbPfFLeRsFoMYEQUhmdglPUHfYh6vwGPCV5W1FWnuFoht9o cYsFB0c34XTG8fFNVotj6mZFcA0D2zK2LaawmDyjXi7xXhPBEg1GFhX1y2PQH1hhiGeabhgp0/Zq Xr+zv8t4OqGsBgyHI0aTMWVVYQZDmG7w8DMf+4npf9d6QQPMl3z3v2h+7n/88n+A5zOJEoNBHIKw nFiuPzBk98MrOGxZPr1i+EDVZTFu7rEDQRL6FUAybVv7FrXCAMT2V5ETkM+0PFBtsPNYyZ1hwof8 EVcWC04Oa9UIDlb5D4Q+MERFzRRUJKYIUWVTpRvTJLX08ookPg+J5EbHfjVr5UpGknswGDKshMgz 8Xjpb702pvoS+Sm9J7asZWNRuS9lY6klRCKPRUA4Zn5iIicm5ic+ag9709/kgmiLu2vhx0MyCLY0 ZKVBhmivNCGPNmhaZNNB6o0jeMFkBsFy/cYNLs8POHGOkWSdCFMOHIcFo9UJplGB7Vo8p6HtVQwj OC4u0K6WGOdYLZfk5SHlcNyxe21WkBWaiRTDEVk1wti8S6bWb+UhBIJv8T5SJUVUF9hGUmNIfCcf S1bf/Z6eR83WrMnIyxwphKYYsDUaMq43mR9vc3J4k/n8FrglY1lC5nCrGpMZlm5B7ULkxOgxpe5k EBgLDCUwy+JMk1ftXR9gIIGdc7tMZlOKqqIqBwxGQ8rhkKKqkNGY5/Ix73vnoy/kFv9d6wUrkdL6 8bc+8v4/++kP3ReCvDaJIzmnrdHFLKO91TI7BHfswXiyaaY+xoB40SAjPShKEKQN+DrEtm0so2xM gwXkvFCdK7hzd8Klu8acu2fMdFpwfFxT144sxFS5ywd6zCXI2nxSBzVIN2HQE/ZkrSqIWU2Xiscl RLGsBAJrJpEyJR83vRUTA0P6PX2VDk8JPSnQx/IrpA7XWhHnYsllUr6Nnh+MiaZzkVsUg6qERPIz twWXEA+hHGRMJhV37m9z76V9ilGhmzNHb606itwrayEQlHnrxfDO9z7Mk0c3lKlKFt0MVKC7CZ4p OUMzwBYZc7/iqjtk4bWF1ZnQSbT+cI7WtYqDLBbUqwVNvaBezamXJ9SLOa5pomazOkF61+Jco12l ZkGzOo2PPaZZHlPPT2kWJ9TzU+r5CfXqRL+/OtFMZHlMPT+J3aglbbvCO6e0fsn0JmAMWZmTF5WW WUXJoKwYjQYMxwPyakCW5YiDw1PPzdp3Q4tpFs8AI1EXxq0sMLDqStp6bU0LgUuTIefvvpvRdKLB ZTygGgwZDIbIeEwz3eTfPnPM1/3tv/2ilUfwAmcwaTkv3wV8YZCwm8hozkG7cjwuC6x4zjcZzUca QhAG9+RIKbilwxwL2ayv80MWvYmutTRXA+Xd+tgODzDxot8LhBnstgM2peLO/TF33z3jkQ/c5EOP 3GS5iJofJuCCdC6ACX3xyZ0tzlN3U74CKgreDxJ2m5p089dMSAlcfScqEGh8IBNP8PHiEqsXUww2 qa0tJAA4dLIKbcQWQoykKZtK91oFlPWATABE5UZtYg3LmtC3UVFtlY9MXCGd43IhUBU5W5MxF/Y3 eM2DdzEdDRSkj6Y8YgNBefRR2yXEYBOwknNwvODxo+ucNA0jk7MUh/chktM811mxDJ5BPsDnBl9r qdmkp/F9wEsQD94jzmHaFtOuMKs5eV5grcXmOfVqSV0vKQZjvavb2Jx3Lb6ttV3drDQQeR+zGX3e EAKYeK7TiRTV9kUEY3JMVlBmQ8pywiorkKIkr0qsZBgRyrIiM4Z2UCJuDtLSNkt8aFhcvU42ytnx JyzqmuCdynkKWO8ZGc+GeCqrn/syaAOhMrBV5OxfuoPhZERZVeRFQVGWFGWFVBUymvJkKHnP+979 ky/G/l5fL3gGA/ATv/3Ila94/UNWgvwxQqCN7WPn4PDyLQ5PTim8YegyzCH4lcNsGsQKNJq9SBnv 1LH2NwirJxotRyZWM5hMfya5llBSxha3gUGRsTWpOH9xxHhacOXKKYum7TZnCMq27IhxsehJJUwP tEbMIlLT0wqB234vKdIpA7TXhRGhG15Mmi91SP0KJQAmfV99fenM0hJGAD1xTl93TeEPwZikc6tk viQWbroUL2VL0iuwheTkKEwHA+7d3+Y199zN/fedYziq9DzYOLel4E4PPMVyKXiwpsRgefiRx3j4 2mWcU92TVnQ2yQTTcZI2qdiyYzKbc9Iuudoec0Kt1iNBcEjHNWkjhaCN77L1HhccddvQOkfTtjSN Zipts9LMZnFKvThhlf4sT6mXS5p6Qbta0axW1PMjmvqUtpnTLk9omyXtakG7muPbVgOSa2lXS1jU yGLFwfEhx/NjDR7eadcqYnfGGLI8I68K7GCANTlZNYTW0JgBo0HFsKzI85IiK6myjEmRMbWGaS5Y axHnabza1M4E9u68wMbeHsPxlKIqKUqdOypHExgNOZ5s8ouPXuEbf+D7X/1i7O/19aIEGIA//WkP /qaE8Id9CPf1NX/g+MYJT926wXOyojaeXVdgDxWDybdyzRIa3b0mBRlRAoHJBH8aMCpB1gUZybQD ZXJBKlFmsBWywjAcZpw/P+KBSxu4JRyd1LTtut906oKLYiLQAaYdqzdlL5HCn6BYk8BkSccZU32I HaGeqZsmr9ftY8Pac/WyCsoTqrKMnWrMudGEQZUTrOrUSjAUUdXNhdAR0UJsTyfNX01otIMi0ZdI uTzS4ThDyblzc4fPfM1DvPrB+9jZH1MUNnafInkolWuxRNOMMVIBjCW3JU8/e4M3PfJubi1WGsxs wEVybtKv8R5KLGNfMM4qau+40hxxwJImSCfQ3ngf7Wo1yLQiOJMsbNWZsQ0O5z2Nb2gigW6xOGW5 PKWu56yWpzT1iqZpcK6lM2MTJXNKFLMVE+fSjNHWm2gQ9XVg0EJYea6fHnNwesRyfsRqcUi9PCW0 KzWoTFPYmTpbGpvp+fZC2xqCyRlWQwbViLwYMqgGTEcjpoMB06ogzzIE0XLQB8YCOxfuYOuOCwwm Y4ajMbbMKYqSshpgxmPY3uM97ZAv+5+/6UUtjdJ6UUokgK/+wZ9pfuzrv/TvY+VzQxsKzeQNYVqy quBwccKNsORmWPGH2WbvuYnOLj3gsROhue4JTSDb1hgpQH4+w26GHg3t2Le3t1AlUy4NkVOSScaF +8d8yc6AKx/Y5uH33OKDzx5y2NbKdE1ZTFjTeunU7Hz3+oJ0AtM2toGTzIMlCTX1diOW9eZGpNvF rpbpAk1fTlXGsjUacH57xt5gzDhUjKsCKQKrrKX2gdPrDasbDXW95LI/5oAlCwFrLF6SGLl2TozJ KCJ3pGlbrM3YFNgpp+xNJuzt77B5x5TZrIKZw4UG18ajjdYjwYK0a5oyCSgJgawccPPZE978nndy 5eQU4vtyRrV8Q+gHMFsCN33NQThhYzWksDlZsCxDxI07j/L0sSaQLGgiRWRsExDvVX4hCKZtWdR1 1BFX4UtjNPgZsYqZWIu1BhPJeiKqTRMiEBfiLJcRIawCQ5+xqGturk6YNy2ubTHiyeeGdn6AX9yi XR4z3NhmOJlQhYpQDvUYsxx/usR5Ic8LZU+bnJEtCa7G4jGuQUJDs1wgy1O85JjVKePNDbYuXaKa TKgGA/KyIMtzbbEPhjCd8Ww+41fe/MLPHP1+60XLYAD++TsffezLX/tgKSKfkyxd27bl6NYpq+WS hsBNVlxjyUwq9lcTVtdqVm1DVgl+oVdotmF0RikXzEAwpX5tCi0LJAPo77RiRMutSM4LojyWYmiY bVWc3xxxaTxkY54zWWadtUgtSYU/DsOJ9OVLGuQjtXbX0N0OrE2hIuEI0jGGk/CUZj5xLiq2kss8 59LWlFdcOscn3bnHXec22d0dMd4sKIaWapgzGZdMNws2dis2R0M2ZMSYkizPsLlhUlZslRPyLKc1 FiMZpeSUWUVpCzJr2TEjPn3vfh66eBf333WBzUsTqqGlzVe40Ggb3RLVreP5S+Bu6s84JQ4W+ZCb V094y/vfwyPXr9HEzpukbkmA4KXzyvbAlJwdKZmaIUVZcb0+5il/cltJtESFmpoug4l/07tONiRr Vn1sGx1AG++o25bGNTStMnob1yh/BtWNTr7h646YPgTaGuxSb2q35ifcmB8zb1a0TY1zDu8aMloM DW27wK0W+GaJwZHnpuveiTW08wWLRUPbrGgbR+N81KEJ5EbITKbWInlJIyXjqmCyvcP0wnmG05mW RYMBWVFgbEYxHMJowuFokze/7yn+0vd/70sie4EXMYNJyzv+rvPhMxA+L7iALUpsmSOoSPcKxxPM WfmnaVrPvc2Q5tEWd9mR7+eYK+AWgdFrCqSQjt8eiand3FPKYDqm3fM6PoiO15tNYWxLyjzjjgtj jj+y4pkPnvDE8QnPhiW3zIoFbZRV0As7dcZT0LDx402ez132Qj9X1ALEu2LqUKWuWrK22CwHXNzc YHtjyP7miI3NIVVlozh6xGmcslwaG7MfC3IeylnG3pMbjA5GnMoKiowyq1iIcCvUSDBRQtRgfCD3 sDvd4OKFcwRb0xYrPGrxSxaRVhHEKiBNFqAxUX8m4i61lpB5VnF4cMqvvO+9vOfKZRZ1xCRsmjTX wNT4yFBOn3XwZD5jNNjkpPA8FU6ZJ6W4mOl0HJ2YzWQxWidpSUJqmKkGbgrYNkTprujzJDgKI1hr aGgoEKS2WGMxRrMci46y+JUwDLBsPQerJadtjTiV6UxzENZCZhX9cvWKRdvi2xWFPyW3LT448sFE MyPvIDjqesVyuaLxHhsCudGDL4zFZxZMznSUMZjsUM7G2Dwjyy1ZnpFZIcssNiugKFht7fPuZ0/4 mu/4Oy+Z4JL2xIu+/uHXfsnnWwn/rA0yRQLPPvkcz330Gdpl3c/VBM8FhvxxOc89MuIkNHrBF4Id CqPXV0w+s0KKOBwZh4vWqqQOlwE6MSi/0AtEspTVQHBCe9PRXo1OWnNP84znuQ+e8sFbBzzhT7hu apZqdtFJM6TYlUWsRpIafAwqCqxKxF/060xM1BvRmaKAMMoyLm5ucN/WDnfuzBhtFZgKnHFRZW7t kwtp85NYeepa4AVqwT1h8Icq3mTyHDMYk5c5ITO0eNqmQXxgUlYUWwPqMEdkjs89MmqRzHdZnthA aAXJ9G8EHWQyEBrBGou1OTevHvEr7/0g7332MsfzmrwD4kPHijatEFwkJopa6r5GpnzB8H6G421+ 4/hDvG3+BG10WgzBd24MIU03eyW/dbKVxDtmnKeyETzPVOWqm3zOYumaiQo6JVU7QYF97w3BB1qn 2GDhDGUInLiapWv1evFelQ1FZRwyA4PSkItXLWVgmBumk5Jyuk21tUs53cVmA5oalivH8ckJJ6en uGaBDY6cQJllWCPYfEBVVQx3tym3NlW5L1dZiiyzKtdpQMoKplMecSNe+bVf/5LYz+vrRS2R0vrp dz/6kS97zYPiPJ/XOshsRts0zE/minPEu/+cFgfsUTAQ5VHQetwysLrq8EeeYs9ihibKOSjwC8TA QSTo9eVSqAP1VY9fBPwqbiABfPzaBSjAbAuTeyvu2Ryzu6hYLtrogaP+0ZEqoysCuBbbEfBSKWVN GjbsvY5Ml0sJe5Mhr93b47V7F7h4cYN82+Arj7ckHcheMyC+nopORQKijVPFpcUMCuxmqY6avkDK EQxzfGFwVtnHzmvLNliHKVsoVlB6zMgloRLNTjLiZHsg1Bpk8D311IrF5gU3rh/zb971MB+4fo3j eY1JfKRolZKAT6f1DC6WOxMsn1Fe5K7ZJd5++Ci/Mn+SZRSoaFHm9Cp2ubzoHE4ryvXxPrCK10nr 9WdOVOy7QQlqjdcJ+dTwwmhsDKKaLq0PLFvPae05XnlOV/rvZdOwcA3HvmXetr0FrPQsZyRaOXW9 PMhtoLI6xuLbVlvgdctiEWi8VdCaJIplsNZQ5hYrgslyqsIy3Nmh2tnFliWmyMmGQ7LhCFtVmLJE Jpuwtc3heJ87v/KrX3LBBV4CJVJarTff3rb+dYi8IatKJrvbnB6dcnpyAhDtQ+DDnDAj5zPDThxS jAzaY8fpB2v8KjD65JLqoRxTSaStS2Tt6siBP/RgIN+MwSj3uEOPZAGXBUwh3WsmXktAlFB2j+HS nTPOPzPhQ++8xW8dXONKWNKI+hx3bes4sS0hUvgi3V+SXUonCq4bJs8tFzcnvHZyjrv2Z8iexRdB ZSqsJKAndpV9P4CI6Uh3WKsAJSaKaFtkUGInFn8jI5zmUESmautwtWYvYjy2XOJMQ1YaGETL36DO BGKA1mp51AoUEFqD2IBvhMwKhoKr1474hd95B08fHnNwtCJLGaHpJSlEIDTgRFnLDpiR82WD+3jV 1r08d3yN31xe4WZool0LZOJVGjSVj36Ndhhb+yZiWSLaPQ++d2pIms8CzAOUTpVA8ixQO9S11qHX SBs6W19IFbeynQ2q5JkM6JsQ7USs0ATfEUZHNlDk0cJm2RLcAu8c88MFzWBBPt7DlkOIA5rFYAht gxXICVS5odyYkU/G3f4weY4tCrVgzgQZjGEyxQ2nPPPYcy/29v1910sigwH42fc+yp98zUMfDoTP 8V52s0xdHleHp7TJvTGCeANTcslOGQa9S0Gkpdee9jjg5wF36DFRFS/2lOOUmOBOHO5WoL3pUpGO n3uIBu7BB22Fdz6ha8OEsfbJNgy79414cDBlcjVj7h3LOIJmMGvymj0/JrWtg2gb2SLkRigHOdON kr3JmPvv3mKyW+LzCE5Her+Y2Ha3UaDKWP1jM5WILHIkL5Cs0DtePkDyIaYokTzHjFSdS0zADMCU HlMGyq2McrMiH1tk5NSiNXgaWnwWha+8wVgtuxJrV8c0DOINmck4ODnlF97+Lp46POLouI6jFVq7 WKstX2t6vRoXg/YWFV8yuI9XTS/hneNdR4/zHnfAMqkJxo2cWNNt7ChFGz9aJLp1pkl36TKcZCOy ik6MtdfnWrjAvA0sGjip4bQJ1F6zn1WcJav1bSoXKF4AJoqge+iE200s/VI2U5jAOI/4t0db7K1n WTdcPW04XtXMm4bW+cg/UndSzdQ9WQhU44psNMJYi8ksWTUgHw6wuVVeTFnBxoywscWz10554Gu/ 5iWZvcBLKMAA/Oz7Hr3yRa988LB14csRkWAy3LxmuVzE4KIXzLYZ8Npsn0wMTWi7HgwIvonZiBXc occdu0ilh1ArIBxqT1gGQg3+xOuAXbxiE27XMe5Y7/vEr5M8nRUGezl7lwZsHmZsnuYYgRUuEsC0 65S4KBrnjEowRuR5PM2ZzErGs4LZxYJsKAzKnDy33RyWZmE2clbQK93EuZksQ2JwMVmJ2PgnL6Ni fxbnpxzOL2lPT/FhjpMlpvLYWUa2YaCK0dU5RZZstBaRSFZ0thsFEKuqecFDYXIOD5a87QMf5rGD G9y8tezeq8khy7V8iIJ2OsNlNIjvUvF51QVeN7wAeB6+9Tjvbm4wwPKgGXNOSlwIHOFYJYZybFev IkGzl7ZUUaYmBoTUaWrivFMql9TJVklreg+JvtX0Jmst0WI4hDi0H1SjWPSeU3cjFVGGIYL5uYVR rmXBwsEqikWtPNxsAseN56RuWTY1q7qmrle4egWuJmtXSLPEtCtwLb5p8E1LMZ1QTqfYUrEX8gzK EvKKUwr2vvTLX7LBBV5iAQbg59//ofd+4Sc9mPnA52ZZRlEUrOanrNq6m2auccwk5/5iizYEXHIO IOIZHtoDh+QxqBwH3HEgrNQ32S9iqp8CRxJPSR/VWpEtkZsuoZ81SoLWElukMhCmF0tGPmN03bAt BdtSMTBZ1N0Vmoi5bISC+2TM3XbExc0p25Mx58+NuOOOCbuDEVuDijyLQwcRuBEr8e4paQozMpg1 i1GRJSXLSWYQidygYDrAMziHX65wpzXN/BQvC0wh2FGpxMTQ6p/IvvFBsDaypkWDpOrqosHFQWYy XCO867EneefTT3H1+iL6WAm2AFvE05pkN4iEuBa2KPiUwS6vKfYxCHXr8EaYSsGD2YxPzreZessT 7pRboaUOnjpOhbtunlIHPVOQaOMEfB1CN0ipwUKDi48DrW0svSSqFXY4zHqLm2QFq8HFxYQ2ZVOJ RRwtngDNXgwaWNr4+GWA4zawcNC4QB08beuom5q2XlA0cwbNCYVbsjo94tmjYw4OD5DjW1SzKeOd HYrxlGxQIYMhVBUMBxxVU97+9vfzI7/05m95sffsv2u95AIMwBd+0gO/AXJfCPLJkue4AKv5Ka3T GeATWq6HJdsMOJ9PMMbivcdFEw8BBRAPnHaJrEAb8OnqSHPIa6As6aJbP5AUg+IXYe17KWNKom0+ g+ycpcwyNq7n7FAwpWBTCrakYNPkbEjOeal4hUy4qxizOxpw5/0TNrcqZmXJudGIYZb3pLUU3ESn EsXE446OYiKGYKSz2lXToqB+sK4l+JrgG/AtElrEt7RHLf6kQfAU4wH5aIBkBu884loVv0ojkyFq 8sTAglE5DXGGXDJMm/HOx57gt554jMs3TrXTkxmyQsczEps1jYN5p5jNuVDwh8pzvCbfZ8SAjBwr lmk55Vy5xZZU2sb1DictJYaRGIooQQEq9dEGZfVaUfvVLIh+P75eF9BiMHAxO7UxcDjRsQyAxseg lCao4wxSEBUUCyLxMSog1gS1J3FBSZUmZtHrPlW1h1tt4LiFuQ+ahYk+doBnUxxTGopMcG3N8fEp z80XHC2WbNAy3d9jvLNNMRljRhMYjGAyY1UMeedb38vDv/mO1//xex96/xc/9Oqf+IUPPXzwYu/b 32u9ZEDe9fWNb/z51d//si/5Vk+4yxj5zNHGjJOjA1zTKP09wNWw4Ofrj3KLO/jUfJctJhy6U2q3 Uq5FMIQWmuuO5jCQbwvZVka+bcm2UWzGk1QkSWInaTiQNQW59UgTYhrl22gnMhTIYxs6g+GrShZT YfnwkvGhZcPlICZKpXiW1tGWgZMNx+TenGwG1cBgrKGVJH6rMpfaljWRWarKarLWughGRwMSqU8F v2vSEes/omIXBlqwmQeTY5uczA8wIev0c4PYSDZba1Kl2SKE0AjBQ2Ys4kseefwZ3vqRD/HRK0dq UpYLeQE2TxPfIc40CTgYuIzzDHhttccn233yJuOGm/Nkc4TzLWPRQULvHKFtyLG81u7wqdZQh5oj 13DEiut+xRW34kAanAQGZNTiuepXHAffdR07EzMRxGsrOcFxPj7A+aijG9SSJPEjXfzIO1sat+a7 FZ0bs0haXsXz5X3vHFkHqJ1mLrWHpdOfbVnYzmC3ELJcxzTqVQ0ECuMZh5qRFca7F8iswbgaQ5Q8 LQvq6TYfffdjfM43/3UB+L+++M98xrJuBy/2nv391ku6fvuOL/3iP+GD/GDTNJeOrz/HzetXqVdL BGiiSNBUCj43u4PPKe5gy1ZcWx1zoz1EDQ7X1eiUH2MqIZ8Zijszip1MyXk2XSD9BFLirBhvMC24 JYRVIDSeZuFpVh5Xe1biGL1mQL4Zy5Qo5tHMPfW1hsVzDatrLaGGYmyxQ4vNBTsxjB+oKLZ7aqu0 esV6F72BCIixZHkesxfp5RBSV8kkN8v4PsXHLovO7khyEnOROXvs8UcGQ0W1s0O2VyIDT7AN3i0J boELSgMUp6CyCRJLSkNucszS8sTT13jTh9/Do8/cUNmHQshykEy1lokYhXMB5wTbCPfJmNfZ80x8 xbJdcdws+FB7yvvdAa04BqJe1AWGTQwTcqaSMTM5U7EMTc7QZIwki5JAmkFcc3N+cXWV97enLCPx LU5lYAlR2TPE05yaybETFSKfRlQX18YMI0JsSvWJEauI3KkcVZ3LRSVGE6GvEpW2JCQtHi2Llj6w jI6Pd2TwQCXkZYVERT4EnYguSubHx5SDARce+iSmuztMtnfJt/dgex+3c4GPXq958Gv+7Et6366v l/yBftsXf/FfNML3nxwd5Tefu8zy9BjnPI1raeNFUwTDp9tdvrC4k3PZiLqpudkcswpK1LNYrd6V agsSkFzIphY7NZgiQCsYb1VsOSir10c+y9y1HC0bFnOHWcZ2puo1kGOxs4yNz6gY7OVavsQzG3wU xHIBN/fUN1vEGIqphUzIp5bqfKFJhk7vEWot5STapvYDidIrs8XWfPIiS1CSpNZ4mgJPrDwf1ISt Ftq5w59AZkYMtvYx4yGhCMigJpg5oV3gpOla6njB+BwbByiXpwUPP/ZR3vLYB3j6+hFZLmTR6RWj ZYWNbXPnA67RbE/mgaEvOG+H3KDmuXZOE/GTJnVhOoVBOiVAE6DCMsEwDoYdydiUgoERVkGFoK6G mve5OcfBRRngVApHAXcR2mhLnCRKhXjOUSQnk54BHP/qyHwuROV/0WCVTNsktsgTRQmi53Uk3wUP xy7QxGbBpoW7Ms1grLUYY9WGtiwZzzYohwOa5YpyOGT/7rsYT2eU2zsw2yTsXuCRI+HVX/d1L/k9 u74+Lg72W77wS/4iwf3wwfXnfvL45vWvdG1N27Y472IHQUuHmeT8EbPP51d3U2J5dnmTOqyigJNR iYHu6o25cFcOBDI0wCxwHIWWa9LwEeY84eeciiMDchFKsYwiiW6PAffYivFGyfbrRwzP5T0gC51s ZEq9QxNwK72wbS7kWxnZJFMgsfVIK1hndKanjeRANCtIs0tEkmCvCZFeK/TBJnJkQtBMhFZoV47m aEV7BNVog2pjj6zcUKC48IT8BGdPQBok6d0YyKWARc5z1w5555Mf4R1PPcm1w6XyNkohHyhXpxt5 jLNF7QLaldA6OrwkFZvJhyp1AJM9SOc3F4dE195dHKcISdUUgmBDoBLDKgTFU5ILhMTniH5CJr5m yl40gASSIYwKbcffjac1leOFUdtiFfAT8B6HBhEJUfU/LotyY7wLLLwS+IJAFgLnMzifCZmBIqhk yGAyYry5xXgyJctzrM0YjMfMtreptrdgtg2zLT7YlC9Jpu6/b70kQd7nr3/74Ud/54/e/1Bljbx+ uVze0Ta1brh4F0ETEBbB8+FwzG+1z0FoeU15DhcCV/2cgVjGIaMW12mqZMEwlRwfAgfS8Kg/5S3h Br/qb/AOf8B75YgnwoIjaVniWOA5CS1HoeGGNFwLNc+wYAncVVccPbdCRoZ8YjtV+3Qr7trNmWAL lY7AqHMlooZyxohmCiZBY/FW6yRKNvabMHRYjJZkIYnmxgwthBjcvMc1rdpsLGuaeUNoAsaWmFCA zxGfE2rBL4W29oQGpLGYuoB5xs3rC97xkcf4pQ8+zPueucLhvAaiB5SjY+o6p0Bq2wbaOawWyi9x eL2LSy8p2sPk0r2f5IiYAminrxNCF5wcRJ8ilaNwUcZCZR+8+lnFcx0kdDE4uUHovJfK94U4LkB8 zjTL1MY/EiCzcRQgdQ7R9reJT5zGQzpeDPqe5x5WMSMrIuG5inYkFlHf6bJkNJ0xiSLdWVlSDgaM ZzOG29sw3YTJJk/YCb/0lt/h597xWy/pjtHvtV6SIO/vtbzn72FGTTWYfn6zWtysm5V2VqIOSB4J Vm3wPBMW/Fz9DGD5gvJubi2W/Ly/zJ0M+CyzTR19fm5Iza+76zzOKSfiOPQNc/FrGreRyh9Sp2at fo8XfBscT3LCY1Jwz3zM9bed4NrA7K5SZ0YiAzW0cUQh/j6WztbEnbYQLPnERmp9LHOSPF0GNODr SNgrYocp+GhO7yBoPW8k09SbWOb5oKVLHBREwOQW2oA7qQntAmNzfGVxxpCtxuQMcNLwrmc+zPuv PckzB8ccLOesgksouH4oUTSrXgRMg75OJKz5Jm5ECbSRBhBC77Gd1AJTyzdZ2K7r6XS2rvQdPx0x M91xBBH1fwqBJjKmA5EsGTtJJoS1rCmeg4hdd52fSIxLFrGRGB2nM1KmFTpipxchSx0o9PdK9DlO Pd3jAkovIgiLoN2qTePJRyOK4QBTFPHaUkpAORgwmk5hNINiwNMr+MVfeTv/3Q+9sJ7Sf1Dr4yKD AXjLRz60+Oz7HvjA3/uNt1z/rDvv/at1vRgE5zsBJWRdYV9YiOMJf4IPnlfbLd7nbvGb/iZHtJyj 4t3hiF/2V3mHP+Q5WXEYWpYdm0aH3kR68/MktSBidHYEIUNFqJzAAS3jYNlzJYfP1lBAPraYXCeN gltrzfQ+Kz1Y2+jmTGJY3dUUd4lvwB0qpye0qpoW8Ko166MtqbEqbCS2107xsexw4LVWoT0IhKVB pKAwY+ygJB+McMHz5HNP896nHuPNj72P3376Izx+cIujdskq8u0N2g62YshiKGgB10YlPA91Gzri dLKs1YOhYzcnG1zffQ86DyrWA1Do2bR0D+yzkVgyOY36MYFLm1tfuYkvkjSNJQ6o2rXspQlazkjU SSZeS1UCZNBAiCgu0zk5kBwm9HlbYOlDhwVpZtVb5OwZmE3GVFVFNRgxGI4YjNTWdjSeMN3cwGzv w7k7eGa0y5t/7V18ww++dOQX/mPXx92B/69/9It3vu2Xf+76f/vKV4WTo+v4iMOEODuTyHFJSnEY Mv5zu8sDDHmTv8KVULNtCm64FQfSxmnoKL7dCziQyprue121o6VBnhTuhDjsKOyQ89myxaYpaG1g cL5g+5VDhhuZSiH5gC0Nkpv+zK9zb0QwpZBPMqxRar9vwJ0G3KFjddNx+qS6DmYbQnVnQT62YCCz lrwoMSbDtQ4fGnztVWM2KNBc36pZPLvCLSyljDl38RWM93a5Wh9zZX7IlWuXeeS5x3nm6Do3nXbr siDkopnYEGGAYZHM6vCc4juwNbVx0/kKIToerAURQk+/Nx0NPzowRHBE44HE8jeWR7KmmxNlPRN2 1sYJsPgjSLNDkozwEmaisT39LCFxzieudsRgUKA2lyh94303se19LyBm4+eHRPfOAEsPy6BawzYG uBCzm5mF11WGzZ1tsrxgNNGAMhqNGU8mjGdT7PYu7F3g2XKDX/jld/AN3/udH3d7dH19XB/81z9w Xzg5PVTB5k6kWsuCxLZtgpIZPl1mfJrd4Kf9czwR5kjQOaB0NzSiGrVh7e4FdDCgxO5AxxERo5q9 If4eKhi0LwM+w2yyTcHSOMgN0ztzJucGcSgQsllGvmF1hEBfhHUjON11hmKSq3/QTcfi8orTZ5Y0 ixY/18CRVYbqYkG1lVHtVtjcIqIuhN71CnB+FVjeaGiPWlY3Hfa04tz2JWb33s2j7oCPXHuGK0fX uTq/yc35CU1dE3xgTMYEy1QyzlFygYojVnwwLDmk5hYtx7iu9GljFFFXwlRU0LWNRaLlrnRvEh+k Gw53MaC4lLsk/6GQPKE0I0uSogrc6mtmIuQCS+c7omDy3/YhAq1oydb7SPXlWR5xloQBZR1jIXQZ kRV9/Y4jFPSaKNHAc+yT22IsrUKgQrGXUuBCBhcnIyaTCYPRiNn2FrPZBsPxmOnGDLO5DXsXuHxw ws//xsN8w4/9k4/r/Qkf5wEG4Ovuvyes5kcK/Hmd/2Gt1m9jCh1E2MQgQbgV3cFMBwIm9Tj9LY/K ZPZowJq8Q8IJROJdLAlopylpeNCMeZ1M2ZCcGgWVs8pSDCxVpsdQncuYffIQW6yVS8SSxkO7CKwu t1hjqFcNJ0+tYKVDmFryqPCT2NjuvqNgfE+BLU3c1NGV4DSwutnQHrfMn61hkbE1O8d4e5t3zy/z zsVl1RkJsKhXzBdzZnXgnjDgIlUHJLcSuMyKy6w4Co6brDgiZY8RQ+n7SNFrSLrMIDkRpmCk3L9k FKM/b1ycEkfBWpVL1/PifKTvxy79EMM4ZiireJcoEJbBcRR8R/X3qd0cZR666ev4cdv4maXW8rpw VSrPcqFz0AwhdJmLAYp4fTUIJ1EGz6PPVwSYGJhY9ZS+s8yYjEcMxiP29vfYOXcHZVUymU4xW3uw u8+NBn7ip/41//3P/szH/d7sr+qP8/V1994dlovjmOqmBuea6n6IM0NGEJ8sT2IrU5LTos6tWOIQ tSgFXWKab0Q621cTuSjW6IVvjWAxneh3BlyQik8xU/ZMRR2d10KADEMe77h2YNj7o1PKrTX+DPEu 7QL1gePm20+pjxQ5le7WKV2DKQQtJczIUmwbBrsFg3MFGKE9djSHjvqgZfHsirrxDCkZlEPeGw74 sJxSlAVlWSHAbCXcv8oompZDv+JJVlwLK27QcEQbGbBhjQmrG9d10hHJ7qTnoSR7akXKNHCkY08C UF0QCvreGxcibtH1rFEPbmEswiVT8oftkI1iyNKvuNzMeVez4AnfMA9OpyVELbPbmKGI9KWQYivR STEeS0bfIjcxkPmY1QQfVJAqZYTx2ikjGW/uAyeu73IJUAb1lJ4a2DRwwQqzzQ1G4zGTjQ129/eZ zGYMh0Py3X3YPYfb2eef/9gb+aof/fGXxb6El0mAAfhz99wVlvMjjDGRnu56NudaaZM4EIkQZpMN SKrf488TJ4/+W+TGdL8v0neEROgcByKki4hhSzJeZ6a8UsYciaPBqxCVETJ0tkZymL1yyPShSjWE 0/G1msksr7Zce9sJoU2u0V3Zv/Ypxl1qIR9Z8m1LMbaKCVxpWN2MAp0BcrEEES4z5ylbc1BazhVj 7pMxVd3y7PKIh5sDrrJiGZX2dYr99tfsS7vUIYI0e5HKF5HYTfG3/3KIoLxdfy4A0eDSutSO1o08 CDCJyn8TYxgbYe4Dh95Re08tgRPv9HhjO1ok4WZBLXRj0EgdJGK2UkSsZRUJcUECBdpaDvF3ExUi qRKW0ksTp+ASiJPcIkwEZgSmBkYG9g1MJ2O2trfZ2t1la2uL0WzGcDAgG49h/wL8oc/mX/3wP+GL v+f7XzZ78rbP9uWwvuaeu8JqcQRwW+eha96sgW5p5iisPQb6vdqVWCFEq1fNWNKFZhUBjs+b/lvD bkWBySGG++2IzzKblGI5UDNUDTQi5EExi2LTMnv1iDKygX2rL+RWjuMPLjl9su7eZyzauuMO6wB1 JMfZSggO3NL130c1aDyOZ6h5u5yyyoVZVjLBctLW3GyWHPmG1q//3u3nkcjS7ax144lQWct4pkPK Jvu2vtq/9PgWXYLS2+w6r6Vu+r66QMZNbUNXCp/6SKyLwSwzqSWsDojdMYvq8SbBv9SZ0mxSj6fx RGHw+D0UpB2sZT4+3qhMCFRGjewW3rP02qau488nAlsGRiYwIf67LNna2+XCpUtsbG0xmkyoqhI7 mcL+RU43d/mFN/4Sf/Yf/98vq/2YrpmX1fra++4Npye3gDj0JnL7mwz9xZyCTTIUtxHQTXRyS0x5 U5pCTBSM3oVNal0H6V4n6fPqY/WOlolwp6l4tYy4aIYYYB7xi0IMFkMuSrQrtyzV+ZJ8bPAtuIWn vtWyut7gm9/9fvWlTZd+rXHTumzHxHa4RU3fWjwfDnPewi1CZsnF4gnUzhGCjwzW0Nvn0j/X+r+V GK0s44R3hJQeRvyi5+7GTECSA2aIXSPfvYiPGZ76JPWlmJXosBhUVsG5lDnqcWax1A0hcVlCxwYo ItTc8V0iXpRmvZZeWMa2c5FKptgFymJLmviesxhgMrSMPo4T0qnMmwrsGtiwMCYwITAaDtnY3uL8 pYucu+NC15KWyRS291ls7fMv3/gm/qt/9I9ednsxnbeX3frqe+4Oy/kxPrSaSUCXNXSU83RhRLhA DejT4KAGhlz6LkfCE0wMLAlr0QtdYu2tQSaPX6cLr0FLsQ3JuEeG3CsV56TAGqFBcKKAaAKMrYCt DLbU7/iFx9cpJPZlWX/pE0nDOo2UAA4DZNiO97HEc0jLDWqe9is+HE5prHJ6lJSXgq6PG7an8qeg nDpTPfeof309uND5P/UM2ygR6pNmT6IC6WumlTpOKTN0oEOgEfdpneI0KQvp3FJi4GlCf6w2BLIo 6J3H503kSPA63e6FQ6fPPRDtMOX0pbLEdnxqWevzqkzDIgSOQz8aMEvBxcDMwCgEhsMBG9tbXLz7 Lnb3zzEcjSnGI9V0mW1zfecCb3rbw3zNt3/ry3Ifpo/nZbm+6t77Qrs8pXUr5UVE/VdZB/467IDb sxoiVZ10B5WuJRpifm/W2te26z71rgHJHZH4fEaEVlS9fl8KHpAB+1IwlIwRlkIMhckwkZeTDqoN 0EirVrFyexmGqBtiEYuOGk8bPCIKJHvggJpjVM7zlrRcdiuOxXHs28jh63MSdam8Petg7Zzom9HH G5Mytf5x3ic+Yj/N3BHqvJ4hnQvq9XP1/Eh3phJbOgUfT+im3NNn1YQev3GpSxh5KEm+MosYW5bo +vQ+3CGydes0MxViQKLP0iBmOaJBOwt07e1l8J3CXhUDy1g0SO0KzKwwGFRMNze4cOclzl24yGg8 VrxlMILxlGcne/z0Ox/nL3/7N79s9yC8jAMMwF945ae8vV4efdp8eUTdqOaGEsR6X2lIrUeJbcz+ jpv0dCVmNGmnaZkk3WazRg3YWqJBvUQ3wvi1ROZqp7SAbs6JCPtUnLMFO5SMRftZslayDTBUkqPW YMlCRLBBj19V2AJHNBzhVK4AxS1WBJ5kyVFoWaDKf2klHGc9wKSOWnqPvtvquhLeBIpp9OoWkasS cYiUlPiYntzGzF0DS21HSOlZtinj8b43QKMLIqnk6xnAaUYrfTypJS2xnLGig4q5CD4RAkP/nhIY nQzWevBaVxPFqohBzRI6VbuxwKZoxlIJbAhsZEI1qNje3eXCXXeyf/4OxtOZZi3jKWFzmw+FMT/1 1vfzv33vd7ys9x+8zANMWl/7qk/9wcXx9W+oV8cQLzJlYyZgVHGDpLkaokoaRrq7VnIB8Gtfm47F KbHjlDgzkpo63Sn26BBeSJtaUjmkP88iTpJHolqGkGO4ICWfajaYiokDdRKLHs+TYcljLHnGr1jg uswndHdx5eb4ruMV7/Kmz9xcSFPE+ojnd9NSZuPiv/O4k9v4dTo/XaMoYTHed2LZKXKnfCfhXJ36 W2wJ41Wr2IWeBKfnrm97r3cC+yIxEuHiYetgowa3UmBoVG6h9frZBn97A2B9ipu17xM0W3FowA7o zSknMELLoanRzGUCbBWGwWDAzrlzXLh0ifMXLlDMNmA4gmqI39jidxYFb3zTW/k7P/aDnxB77xPi Tab1NQ+8IhwdX2XV1hRiuk2TxU3jQ2KIajlCJNOtz52kjZuA3G4gksS80e/380QSafTSBTQkMVND x39REFK6jkvqxmQIE5Nxrwz4dDNly5RUWB4Nx/yMu84CtUUNMR8xXUenB2RTtpbeW9pc+n5iBtD3 dkjZTLL4Xi+EUvs3JIC3K6t66r3SBFJw6J/ZhxTgQifzqeTIEAcStVUsopkD9JIJ8ahiqz1+lSag QRnA8WsNYBpEcmBgNSg0fn1Oaa1bGNaxJf1Geu/dcGN8fAFsSWAi2uIeGpgSFHcZjzh38SKX7r6L 7Z1dytkGTKZIOaDZ2ObfXHf861/6Tb77p15+3aLfb33CvNG0/txDrw5Hh1ep22V3ApIdieKLvftg iAzftHFc3FCp25Ty8oSLJCzBdA4CvVWsPs/t29gYJfKlDYvREJUwCi3n9ALPMWyYggum5H6G3JKa 33BHNDgE0w3uEUu97pg6YptEIxDNjhoS7uQ71DjhUP2YRKLAxSnlGPi6jlLoz1VisKbMQxDNFtN5 Su85niWR2E6OwG8qjdY1Y1K5CimL0QzKRixnfVgyBYhEmFyfN5pEtTrn14cmI7t3LRB310N8L6vQ l4kSAqXAtihxbiCBgQhjgUlumEym7N1xnot33sne+fOY2QZUQ2S2ydFkm3/5nif583/jmz7h9tsn 3BsG+POv/JS3H9x69tOaZq6Wr5FslwhyqQg3hm5gz8jvJrlp50dbpBpEdGvatcf6VALFQJPFp3ex nkgl0m0tZWJetAYep0nhIggj0TnmZfC0sWskv8fzBEkbVDqAs5NzS49B29JWrPJaoBNociTCXA9c r2c0KYMBlcnwIXXpot/Pes+cNGoROiDYhQj+Ru3e1N4OJPC213NJ2UqStGxTl8qv4UWJSEffEs9D oDJpMDFmOEF5Kya2pCUi0um9SWwIpGxpU3SmSNByaCCwIYEpkJc5Wzvb3HHnXVy4eJHpzjYy3dDg sr3D+5uKN7/7cb7xO/73T8i99gn5pgG+7tWf9pUHN57+ibpdgPR3XaHPKDo6vARsYvF28GjaDGuy DinbCeBN33Z2caPZuFE1je87Ql74XQEsuUkm+Ym0V03wuI5zIx24ud6JSfhSh4Gs3aUFVOg87meD 4CJI2hEJ1/CIAGRJ3EuE1sV7eiqN1trGKcCsl1QhDT2GOJu0Lq4ef06gayG7iO+42J5ebxnf1qhf L3Xie1G2bt9hMijhrWMMxwxmGdR+BFFKv0E1nlPLOUPLn3FsP1/MAiMCpwi10+fdsEJVlWzu7nDp 7ru548IFBlvbWhINJzSzbX772pJfeOv7+Ns/8vErt/Cfuj5h33haf/LSxdCsjiPTtMcy1DIt3IZX KDApnZGbtq7T5o+gLf0dv2tlQ1dOGelZv1050mEyuowEENNtsDRoKSEOaJLKtNA/N/2cjacPVkkc 2yPPA1XpCGqCYkYq5rRGRFzrpqyXid6n4NtnTS70E87r5ZaP82GslT6SAlwMLtZEyxAPKx+6gEXo JTLXel0doU/iMUoKkLFN7WJ2UhEYRobvygVqtOxJrgN5UC3edOaHEhiJ4iwTUQ3dOzMV5F7rxuOd pxyUbO/scvcD93Hh7nugHMBwhExnPFdOeduVJX/qf/hLn/D76xP+BAB85f0PhfnpDdpmRZqT0WLH kLRKEuksIHpRJkuT28oTifyZvkukASICv7KWaXT4jZZoSYU+NY6NmK5E0WBlenJdF9w0YLmuBOnf k6z9fB2g7X4mUd8kBjDb8+hjkJHflYl41GheH9PnTYKWNBLUP8jG43SxK7QOonYBN4ROAze1uNVN 0UelPwVYO5B3rdPlvIK2A6OPUcwllpXxGLzX4CJEu9go3i0hUMSMrIgi3qVASWBDtN1sgaHAxQwG ZdF9rtYYbJZRVQM2Ezv3/AVk/xxUA2Rjk4/6AT/xq+/jf/nebz/bW5wFmNvWl995KSwXR8qDSffI RG6T/u6+nkGELjPQQGFFmbvRm5Ei4Six9dy1r6WXN5Du99NGhsyYrgOjg5nS7fYgIeZXkEoS6BIK xYVCnyFJxGOM3J6RAJ0mrZG0+WNgkRClE6IfdIg/XQtACQLufk9SSQQSAd4uAww942Y9mzEx8CQb 1xBrrtb13kUpYzExAOxmgQuFPv6xJRw7xZoy6Y3TbAxYre8Fq3xQsDfpsxTATAIbBDZstCOJ3aEC GBQ5RZ7pTcBajLWURcnu+XNcvPMSW3vnYHMTGY5hNOZJO+b/edM7+Zv/8LvO9lVcZyfieeurX/m6 m4cHz2429ZKWQBZN01IgSFIOxLECiSWL6l5rQEpBxKHSmynjSKe7A4ChC06p7BLSHTvmULcxg+NB xLt51/6l/yBvz2L67MV0Ly8x09B/W6F7D/0R9lwUQs+WTalPz7XtW/g2ZgUuHX96VBL/otdm8ak/ lVrRvg8yber0dIzelOEE9vPAQxUMrQaQZ+rAYystq3IjMUARJSSU6NfSg8sWGBstg6woA/ec1S5T JTDILGVREAK0bauOkWWJsZbMZgyGA7b39rlw6SKzzS3Y3kYmU5qNHX77RsPP/8q7+LZ/+n1ne2pt nZ2M32d9xX33h4Oj64TgOwC2yxRi2i8CYQ3MTY3SngKfiHRCblI50o8g6H5NJZP+z0jonqezPFpv 88rtGzvJN6ajS2S+hFqst5LT1DOBrvuVSiMbtL0LGr+cV5/mtFm57f33S7OpPuhAFNmWPlgZnldq RUwljQA0a+1jH+eKEojrg2YVDw0C9xaBqdXp56dWGlyut/p55GvntI2T1qksSy6MlYFhCIwt7Evg wQKGZQkhkGU55aCCEGjaFl83GGupBkPKsmAynbG9t8ve+XNUe+eR8ZQwHvGYq3jz+57i/Y88/o7v +5kfef2Lfd2+1NZZgPl3rP/yVZ/6gyeHz33DYnm8ttG7Jm3ESm4XHZfua9MFoUSWMWuAbcovFGzt cZg+2KTf61KXjj8Cve5M6HKjCP6uBbf09zqWkoY1tQ8vt2mkBNTPp4k4Rsqm1rVg+nefyqrQjT9Y 6fKWTq4yvXBvNxJJa1EYO2E1StcP/UgBiq+UBF45gFcNYFDmLBc1T67g0aXnqhNy6dvZnfV4zH7S qMDIaPlTic4cFQL7JrCfadeocdp6HuWWajTqBl7LasD2zjYb29tsbm0xnW1gtraQjU1uzfZ52wef 5q0feIZv/dGzrOX3W2cn5j9g/el7HwjzxQGuWcU7rUSNXlnDGaKFqOhs0m0rBR3S4GS8t3egq0o1 rGcmKQNIYHIi7nWYCtFLucNCYjeHXuM2cXs6hnB37B01tgeA6QPH84OTj0pwXbcqBgM1fY/vC6/v O/7MeB1RSAQ6EekU5brgEqOJe16pFFKAC4FPHQZeVenZO249T9bwwSXcchqMxiaJPfUSD4IGjgoF cauIqWSiw49Gei2YIn7tvIpy31da1ckdjZhtzNi/cJGtnW3y8Qimm7Qb27xvnvGbj13hL/3dv3m2 f/496+wE/UesL73rrrBYHuFc25Ub6xs8kc7SBrVdp0iXMaYraRJe0/32euCBrg1OfF4fIkkPLYG0 /FrDKZDbSpGeHdOXamnzJc2axJJdL3m0FX171kMIkRgYOolJk6IhyauIHrxdGx1IPBkdXIzkuD6+ KTs6sXClN0gzwIUs8KqBZh/PucBHl/BkrRosIXaWhuk8hfXZJQ0uG3EIMUvclrVCzqIjIlXsJs2M sGOFyWzGzv4eu/v7bO/uMJluYLe2aDf3eMLlvPdWy5/+a3/lbN/8B66zE/Ufud7witeEk6PrtG6J d05BTbpUhIx1LRi9Cydmr5jIGF4HWOndDFKpkej4PgawpBpnJJVVEeSVfq4ogac9+vK81njHgVkf hVgPQ+nnz58+0uWjxGUW32fKmFqAWNqkwJIAX81e4u9HGcFupEGUs2ICFCYwFm0NNyFw6lQoe88G TtrAwzUcOaj9WrCKXaUivkfxPUemFJgYnRfS7KV/L6ktbX1gZAJDEbYNTGcztnd32N7dZba1zfb2 Fnb/HKfjLY5XLR+4dsovfOBZvvP//cQYUvyDWmcn6//nesNDrw7HJ9dZ1ovbWLGdJEMMIp00AT2g mzKdTjApYTQpdY+ASAu09EOSntCNFoB0z3lbZvI8Dst6EBEiKGwg+LUyLD0ukme6EklCNJ4Lt4Wb rnTqJO/67GQdfE4taSO9hkuSY58YYcfqJk92MG0IHDTwTKv+Qq0PLJMCYVfORZxGAsXzAKaA6raM RcHgYWw5V7F9br3iL1MTmIqS6YbjEbOtLc1YdnaZbW8ymEwJ4wmXJ3u89bTkrb/4b3/yu372x9/w Yl9zH4/rLMD8J66veOhV4fjoBq5d4VFNWrsmb9AFhBiAUucobcbEsZGY+Vg0wJRGItGMnrTH7R2l 509H9XrCa/IMzws2yZE2KcOsVTpdRrU2rtQ1un0XkEJ3rGk6GkIX7HoeTF9npfIpveLAwPlMs5Qi ziY1AS7XgSdqpfKnyenEgUn4TR6DY1LpS1IPw5jNJD7MWGBqNVvJCAyBDM+Ogd0iYzAcMZlOmW1t srWzy+bONqPhGL93juvTXX79zb/G7ywrvv2fvTylLF+odXby/oDWG17x2nB8fJ3l6oR+w0f+hTHr iYqKS8vzN76sBZt+IlszjV4cK5U86ZfT8ybGcEehX2Pw6kPWSH1hPbCELvj1OcI6thRuyx7SSuTa 9e/btffDGg6TEUW8gKFVUtvI9C3lhYcbbeBWC0v69rU+TbSGTe8L7QT1anlQSuC81fLnxGmwmxjV xJ0aGBjVy92yho3NTWZbW0xmM8aTCaPJiJ3dPfwrXsdHL1/n137l7fyFf/FTZ/viD2idncg/4PWG V74mnJ4esFgc9xICYjDScz1UJU85NF2JsgYYr8/zdHIPQCp0UiaTSp51CYguTMTIowDv7e3q9a5T N4vEmubuulD6GiDbNcXXItd68dRxhdZYu53IVWxhV/FY5r7XAG5CoA49oa7LetIrr5VfKWPqBlHx TEQ4n2mgWXnNVrYsjCSwLYFxkTMcjZlubrC5s8Nsc5PxaMTWhQu0D7yKD7z3Q/zWOx/mv/6Xbzzb D3/A6+yEfozWG17x2rBYHtEuj1m6tgNS7drGT1II3UaXfn7oNpcCbu8EpdJqff1u4DZ+P/2RtfEB uf13gG6aOWFIXQdIntfKvq3DFLrvgwaH5MQA3OYP3YQ+ECUSXwpqSSrBBNXJLSCa2qkERItHgmZ9 Teg7WTYEilgeqdi2YiwjURnLLTxlNWBzZ4fNrU3G0xmjyZjZxgajC3fywSuH/MYjT/L1b/znZ/vg Y7TOTuzHeH31qz/l7Ufzw0+TdsmyXnSdEBPV8vwaNgOstbX1HzqUKF1J4o10ok09i7cPQM8HY+Mz dV+vTw8nWWEfOSfrj+tb7VrGaAs5BqcYqBIo3HlER3zHxyll0MetvA4k9llIT1IM3neZWAjaVRqb wMgK3gVOfGDZkf1629cKbUUPRCUZNgwMjTCRwJaBcjBkPJ0yHFRsbm2xsbnFaDZlsLHNs+M9nhru 8Is//aYf+rZ/9c/+mxf7Gnk5r7MA8wKub3jlA+Hp41Ma39K4tvNZBp3QXvdkCmFN/U6kCwap3Z02 WmLDdmMFaKB5Piu4A3LpcZ4kLp4mqruMAs06kgj2GnO/W+k4JQYFVe9Lh9uXNY3v7UT0ecLt2VXo Z48yiEOHoZvA9vE56lielWhXqBQ1NtswgbFR8e08zymqivF4zGxzg8lsg63tbbLhGPKS49ke7/Mj 3vbIU3zrP/2es2v/BVhnJ/lFWl9y7z3hdH6i2EyvqtRbpKQ2NKzp//ZDk93Ugu+ziUT7FyO3zeb0 5LK11nToMxpQbowyWvuuVAoGia3so1aLlb7FnjIaIbab9RdpA8yjPF4CtnlecOmIfrHUGcfWsvea 2a1c1OCNs0YDowJQQ6PaLbsCZWYpypJyMGA0GjGZzdjc3GQ4mZKXFeX+ed6fb/FbTx3ywcee+snv /dkfOWs3v4DrLMC8yOv/+COfEx6//AyXT47VgsR5rOnbw6o/I7cp4KWokUYA+pCwXv5oymNSbRPL oM5sPmnUEEsP6bObsBYFkjxDktJMBmRZyr5CciXQiLVE5SgbH25jBHd6MCHycLrSSjOgkdUp547n F90WhwID1Eh+MwaYMrPkZUlVVQyGA8qyYjydakk0njLc2+fR4T6PHHk++L4P8rfe+CNn1/mLtM5O /Etk/fXP/ryfmIzzr3zsicf50K3rvYuZKFW+a0evyWWmzk4/anA7yKvOjn0mk2aUEvaTEcuaoH9X kVqfshZYA3/pSyih13GB6B0UYB4HDmsXOmZyIh2GoFlI4sdk8WcJCC4lMIjfS0GlFNW+HQLloGI0 HFFUBWVZUVQleVYwnk7Y3t3Hbe/xZD7jw8ctH332JlcO5nz3G884LC/2OvsAXoLrWz7rM0IzP+J0 ccqTJ6fcaJXxkdwoO23fnkjbafimFnUISaYgDmaSsJ2eUJfF4GWN/rsUKE0cVkzYTejJefMAyygU 4+mDnYttZiXfoWVReg0UWzEBckmezxq0kqXrKGZPRez+zAwURUmRF5RVSVEWlEWJzXOGgyHj2ZTp xibNZIfHiilPrAzPXD3gyvVDvvNffOJYgnw8rLMP4yW8vuWPfVH45jf/vPxPr3tVOFkuuL5cclyv VGGu6zUlhquatoWuy9PbtxZGsDFAJUEsgyiYGiU+c+kV+31YG+Akmr4LLFx0NQyJnNcPOqYWdbEG Rmei1H2LGsuXKNaS1ORy0aHDMYEiL7A2p6wKhsMBeVFiRKgGQ/bOnaOsSuqs4qCY8pwZctAKTx7M +fCVW9/xfT/3I9/0Yn9WZ+v3XmcB5uNo/Z9f9EVh4GvmN57jYLnkRl1zUtfM24ZTF1jRk1bW29FZ /NoY1uaBbl+ddCa9BWwqb1KgWTctSyJOyU41gb1D4hAjqrGSi/JVctH2c4GQ5Rl5lpPnBWVZkBU5 RZYrP2UyRaoh5CVODCdeOKXkYLzFFZfxoY9e5tt/6ofPrtuPk3X2QX0cr3/wFW/4Bn944wcPb1zh fcen1K1jIIHGOyR4JHiaOM+UyHlGlFOSxgYinqpiTGu4SZ7MykIMTjErqQwdOJvKqmTzURoNJiZO NA/EY22mynBlyWBQkRUFmVX1uLwaUo4nlMMRQQxkBSfVjMftlENvOVy1/NXv+j/OrtGP43X24b3M 1nf+hb+yud0c3mxvPMfy+mWOTw+5vFpx4lRHpQ2B2gUIvht+LIR+0BLl0eQAqKJdKRGviSWNkLgo UImS3QrREsgYS1UNGA2HkGU4H8jyjMnmNpubm4RygEewwwmXR3s8fVJztGy5cbS49Td+9Pu2Xuzz d7b+YNdZgPkEWX/n8/9EMN4xqSxVaGluXaU9PaEclOAczeKUw9Yz955Tp5q2LQrEblttE2domTT3 GlA2DIwHQ4bTMSEE2tWKu+57gM3zFzkIOQetcETOUci5frK81dTtG4KVj3zTj/7AR17s83G2Xph1 FmA+gdc3/7Ev/YZvefPP/BDAt37Bn/y0rc3J28s8p4y8lqZu8N5TZpbMGkLrKDKDN1ZZtsbiioqA YFY1zghH2ejWX/7h7z7LRM7W2TpbZ+tsna2zdbbO1tk6W2frbJ2ts3W2ztbZOltn62ydrbN1ts7W 2TpbZ+tsna2zdbbO1tk6W2frbJ2ts3W2ztbZOltn62ydrbN1ts7W2TpbZ+tsna2zdbbO1ou//j/P aQVx+37BdwAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAyMS0wNS0xMlQxNzoxNToxNCswMDowMNoGto8A AAAldEVYdGRhdGU6bW9kaWZ5ADIwMjEtMDUtMTJUMTc6MTU6MTQrMDA6MDCrWw4zAAAAG3RFWHRp Y2M6Y29weXJpZ2h0AFB1YmxpYyBEb21haW62kTFbAAAAInRFWHRpY2M6ZGVzY3JpcHRpb24AR0lN UCBidWlsdC1pbiBzUkdCTGdBEwAAABV0RVh0aWNjOm1hbnVmYWN0dXJlcgBHSU1QTJ6QygAAAA50 RVh0aWNjOm1vZGVsAHNSR0JbYElDAAAAAElFTkSuQmCC' /%3E %3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "ft.soundsplash.near": { + "spec": "ft-1.0.0", + "name": "SPLASH", + "symbol": "$SPLASH", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "taliban.tkn.near": { + "spec": "ft-1.0.0", + "name": "Taliban Token", + "symbol": "TALIBAN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nearbit.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEARBIT", + "symbol": "NEARBIT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "gold.tkn.near": { + "spec": "ft-1.0.0", + "name": "Gold", + "symbol": "GOLD", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "token.sweat": { + "spec": "ft-1.0", + "name": "SWEAT", + "symbol": "SWEAT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token.stlb.near": { + "spec": "ft-1.0.0", + "name": "SeatlabNFT", + "symbol": "SEAT", + "icon": "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' version='1.1' x='0px' y='0px' width='32px' height='32px' viewBox='0 0 32 32' style='enable-background:new 0 0 32 32;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23050035;%7D .st1%7Bfill:url(%23SVGID_1_);%7D%0A%3C/style%3E%3Cg id='Layer_1'%3E%3Ccircle class='st0' cx='16' cy='16' r='16'/%3E%3C/g%3E%3Cg id='Isolation_Mode'%3E%3ClinearGradient id='SVGID_1_' gradientUnits='userSpaceOnUse' x1='6.2375' y1='16' x2='25.7625' y2='16'%3E%3Cstop offset='0' style='stop-color:%2300C2FF'/%3E%3Cstop offset='1' style='stop-color:%230067FF'/%3E%3C/linearGradient%3E%3Cpath class='st1' d='M14,6.1c-0.3,0-0.5,0.1-0.8,0.2L8.1,9.4L7.8,9.6L7.2,10c-0.5,0.3-0.9,0.6-0.9,1.7v4.1c0,0.9,0.3,1.6,0.9,1.9 l6.2,3.8c1,0.6,2.3-0.1,2.3-1.3v-2.9c0-0.7-0.4-1.4-1-1.8l-2.9-1.8l3-1.9c0.5-0.3,0.8-0.9,0.8-1.5V7.6C15.6,6.7,14.8,6.1,14,6.1z M14.7,10.4c0,0.3-0.2,0.6-0.4,0.8l-3.4,2.1l-1.8-1.1c-0.5-0.3-0.8-0.5-1.1-0.8c-0.3-0.3-0.2-0.8,0.2-1c0,0,0,0,0,0L13.7,7 C13.8,7,13.9,6.9,14,6.9c0.3,0,0.7,0.3,0.7,0.7V10.4z M24.9,14.3l-6.2-3.8c-1-0.6-2.3,0.1-2.3,1.3v2.9c0,0.7,0.4,1.4,1,1.8l2.9,1.8 l-3,1.9c-0.5,0.3-0.8,0.9-0.8,1.5v2.8c0,0.9,0.8,1.6,1.6,1.6c0.3,0,0.5-0.1,0.8-0.2l5.1-3.1l0.4-0.2l0.6-0.4 c0.5-0.3,0.9-0.6,0.9-1.7v-4.1C25.8,15.3,25.4,14.6,24.9,14.3z M23.8,21.6C23.8,21.6,23.8,21.6,23.8,21.6L18.3,25 c-0.1,0.1-0.2,0.1-0.4,0.1c-0.3,0-0.7-0.3-0.7-0.7v-2.8c0-0.3,0.2-0.6,0.4-0.8l3.4-2.1l1.8,1.1c0.5,0.3,0.8,0.5,1.1,0.8 C24.3,20.9,24.2,21.4,23.8,21.6z'/%3E%3C/g%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 5 + }, + "neir.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEIR", + "symbol": "NEIR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "elt.tkn.near": { + "spec": "ft-1.0.0", + "name": "Extemporaneous Life", + "symbol": "ELT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "padthai.near": { + "spec": "ft-1.0.0", + "name": "Padthai Protocol Token", + "symbol": "PADTHAI", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "dojos.near": { + "spec": "ft-1.0.0", + "name": "DOJO", + "symbol": "DOJO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "berryclub.ek.near": { + "spec": "ft-1.0.0", + "name": "Banana", + "symbol": "BANANA", + "icon": "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='256' height='256'%3E%3Cdefs%3E%3Ctext id='A' x='50' y='180' font-size='180'%3E🍌%3C/text%3E%3C/defs%3E%3Cuse xlink:href='%23A'/%3E%3C/svg%3E%0A", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "9aeb50f542050172359a0e1a25a9933bc8c01259.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "oinfinance", + "symbol": "OIN", + "icon": "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 974.66 974.66'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bisolation:isolate;%7D.cls-2%7Bfill:%235a8dff;%7D.cls-3%7Bfill:%23fff;%7D.cls-4,.cls-5%7Bfill:%231b57f6;%7D.cls-5%7Bmix-blend-mode:multiply;%7D%3C/style%3E%3C/defs%3E%3Cg class='cls-1'%3E%3Cg id='图层_1' data-name='图层 1'%3E%3Ccircle class='cls-2' cx='487.33' cy='484.76' r='473.82'/%3E%3Ccircle class='cls-3' cx='487.33' cy='484.76' r='358.99'/%3E%3Cpath class='cls-4' d='M487.33,98.08c-213.55,0-386.67,173.12-386.67,386.68S273.78,871.43,487.33,871.43,874,698.31,874,484.76,700.88,98.08,487.33,98.08ZM368.59,297.83a9,9,0,0,1,12.71-.14,287,287,0,0,0,137.53,75,110.56,110.56,0,0,1,51.78,28.2,9,9,0,0,1-12.49,12.93,92.54,92.54,0,0,0-43.3-23.61,304.9,304.9,0,0,1-146.09-79.66A9,9,0,0,1,368.59,297.83Zm216.7,197.36a9,9,0,0,1,17.93,1.3c-1.86,25.6-15.92,49.6-38.58,65.86-18.31,13.13-40.08,19.87-63.28,19.87a130.41,130.41,0,0,1-32.7-4.3,9,9,0,0,1,4.52-17.4c29.91,7.76,58.67,3.23,81-12.78C572.48,534.61,583.82,515.45,585.29,495.19Zm-9.7-47.57a15.39,15.39,0,1,1,12.8,17.6A15.39,15.39,0,0,1,575.59,447.62Zm-244-118.07a9,9,0,0,1,12.71,0,335.48,335.48,0,0,0,163.36,90.53c30.07,6.9,50.7,33.19,48,61.16-1.64,17.07-9.08,30.42-21.52,38.59-8.23,5.41-18.1,8.14-28.9,8.14a76.36,76.36,0,0,1-23.39-3.91,9,9,0,1,1,5.52-17.1c14.54,4.69,27.64,3.93,36.9-2.15,7.73-5.08,12.39-13.82,13.49-25.29,2-20.88-15.76-37.71-34.1-41.92a353.42,353.42,0,0,1-172.1-95.35A9,9,0,0,1,331.59,329.55Zm-30,41.34a9,9,0,0,1,12.71-.23c36.29,35,81.18,62.68,133.43,82.22a9,9,0,0,1-3.15,17.41,8.89,8.89,0,0,1-3.14-.58c-54.58-20.41-101.55-49.38-139.62-86.11A9,9,0,0,1,301.56,370.89ZM452.39,512.8a15.39,15.39,0,1,1-12.8-17.6A15.38,15.38,0,0,1,452.39,512.8ZM278.9,429.48a9,9,0,0,1,12.54-2.07c38.33,27.47,67.76,43.32,105.66,61.43a9,9,0,1,1-7.75,16.21c-38.8-18.53-69-34.79-108.38-63A9,9,0,0,1,278.9,429.48Zm-4.46,60.34A9,9,0,0,1,287,487.67c45.31,32,91.6,55,137.57,68.37a9,9,0,0,1-2.5,17.62,8.76,8.76,0,0,1-2.51-.36c-47.9-13.9-96-37.78-142.94-70.95A9,9,0,0,1,274.44,489.82Zm18.28,73.95a9,9,0,0,1,12.38-2.89c44.19,27.46,93.91,45,123.06,51.75,27.43,6.32,56.78,9,65.69,9,77.91,0,141.29-63.38,141.29-141.29,0-65.78-46.6-123.81-110.81-138L516,340.57l0-.24a257.48,257.48,0,0,1-100.58-53,9,9,0,1,1,11.69-13.66A239.17,239.17,0,0,0,528.3,324.87l8.22,1.9,0,.16c68.06,19,116.62,82.18,116.62,153.46,0,87.82-71.45,159.27-159.27,159.27-9.61,0-40.9-2.87-69.72-9.51-30.5-7-82.46-25.38-128.52-54A9,9,0,0,1,292.72,563.77ZM493.85,688.36l-9-.07c-5.35-.12-10.74-.42-16.1-.9a302.94,302.94,0,0,1-109.22-31.85,9,9,0,1,1,8.2-16,284.85,284.85,0,0,0,102.64,29.94,225.63,225.63,0,0,0,23.34.87l7.29-.11c101.46-3.78,182.84-87.49,182.84-189.86,0-89.16-63.2-167.31-150.26-185.83l-.12,0-.11,0a206.73,206.73,0,0,1-49.14-18.68A9,9,0,0,1,492.69,260,188.85,188.85,0,0,0,537.56,277h0c95.18,20.37,164.23,105.85,164.23,203.35C701.82,595.07,608.53,688.36,493.85,688.36Z'/%3E%3Cpath class='cls-5' d='M144.68,484.76c0-206.19,161.39-374.67,364.73-386-7.27-.41-14.58-.64-21.94-.64-213.56,0-386.68,173.12-386.68,386.68S273.91,871.43,487.47,871.43c7.36,0,14.67-.23,21.94-.64C306.07,859.42,144.68,690.94,144.68,484.76Z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 8 + }, + "nk.tkn.near": { + "spec": "ft-1.0.0", + "name": "NearKat", + "symbol": "NK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "syn.tkn.near": { + "spec": "ft-1.0.0", + "name": "WebSyndicate", + "symbol": "SYN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "hodl.tkn.near": { + "spec": "ft-1.0.0", + "name": "HODL", + "symbol": "HODL", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 1 + }, + "usn": { + "spec": "ft-1.0.0", + "name": "USN", + "symbol": "USN", + "icon": "data:image/svg+xml;charset=UTF-8,%3Csvg width='38' height='38' viewBox='0 0 38 38' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='38' height='38' rx='19' fill='black'/%3E%3Cpath d='M14.8388 10.6601C14.4203 10.1008 13.6748 9.86519 12.9933 10.0768C12.3119 10.2885 11.85 10.8991 11.85 11.5883V14.7648H8V17.9412H11.85V20.0589H8V23.2353H11.85V28H15.15V16.5108L23.1612 27.2165C23.5797 27.7758 24.3252 28.0114 25.0067 27.7997C25.6881 27.5881 26.15 26.9775 26.15 26.2882V23.2353H30V20.0589H26.15V17.9412H30V14.7648H26.15V10.0001H22.85V21.3658L14.8388 10.6601Z' fill='white'/%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "xcorn.v1.corn-staging.near": { + "spec": "ft-1.0.0", + "name": "Staked CORN", + "symbol": "xCORN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "v1.dacha-finance.near": { + "spec": "ft-1.0.0", + "name": "Potato 🥔", + "symbol": "POTATO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "bxf.tkn.near": { + "spec": "ft-1.0.0", + "name": "Super puper token", + "symbol": "BXF", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token.pumpopoly.near": { + "spec": "ft-1.0.0", + "name": "Pumpopoly fungible token", + "symbol": "PUMPOPOLY", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "duck.tkn.near": { + "spec": "ft-1.0.0", + "name": "DUCK", + "symbol": "DUCK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "cusd.token.a11bd.near": { + "spec": "ft-1.0.0", + "name": "Celo Dollar", + "symbol": "cUSD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "celo.token.a11bd.near": { + "spec": "ft-1.0.0", + "name": "Celo", + "symbol": "CELO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "bed4ab0019ff361d83ddeb74883dac8a70f5ea1e.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "MerchDAO", + "symbol": "MRCH", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "111111111117dc0aa78b770fa6a738034120c302.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "1INCH Token", + "symbol": "1INCH", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "ikenga.tkn.near": { + "spec": "ft-1.0.0", + "name": " DEDE", + "symbol": "IKENGA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "lts_token.near": { + "spec": "ft-1.0.0", + "name": "Lights", + "symbol": "LTS", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "token.pnx_test.near": { + "spec": "ft-1.0.0", + "name": "PNX", + "symbol": "PNX", + "icon": "data:/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAiIGhlaWdodD0iNDAiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGNpcmNsZSBjeD0iMjAiIGN5PSIyMCIgcj0iMjAiIGZpbGw9IiMwNzA2MzgiLz48cGF0aCBkPSJNMjguNDU1IDI5LjczMmMtMi41MTQgMi44NTUtNy4wNSA2LjEyLTExLjAxNyA2LjE1My0yLjUxNy0uMzI0LTQuODM3LTEuMTE2LTYuODE1LTIuMjYyIDIuNTAyLjE3NCA1LjUxNS0uMjc3IDguNDI3LTEuNzkgMS4zOTktLjYwNSAzLjYzMy0yLjIzOCAzLjcxOC0yLjI5Ny0uMDY2LjAzNy0yLjQ5IDEuNDgyLTMuOTQ2IDEuOTY1LTQuMzQ0IDEuNzkxLTguNjQ3IDEuMzEyLTEwLjc2Mi4yNzItMi40OTktMi4yMzgtNC4wMy01LjE4LTQuMDYtOC40MS4zMyAzLjEwMyA1Ljg4OCA2LjI1NCAxMS41NCA1LjEyNyA2LjQtMS4yNzcgMTAuNzM0LTcuNjQ1IDE1LjgzNC04LjQxNCAxLjE1OS0uMTc1IDIuNDY2LS4wNyAzLjM2Ny41MzggMS4wNzUuNzI2IDEuMjI3IDEuNTUgMS4yNTUgMi42NTIuMTc5IDYuNjktNi40MzUgMTIuMTc5LTE0LjYzIDEyLjczNCAyLjg4My0xLjQwOSA1LjQzNy0zLjg2NSA3LjA4OS02LjI2OFoiIGZpbGw9InVybCgjYSkiLz48cGF0aCBkPSJNMTEuNTQ1IDEwLjI2OGMyLjUxNC0yLjg1NSA3LjA1LTYuMTIgMTEuMDE3LTYuMTUzIDIuNTE3LjMyMyA0LjgzNyAxLjExNiA2LjgxNSAyLjI2Mi0yLjUwMi0uMTc0LTUuNTE1LjI3Ny04LjQyNyAxLjc5LTEuMzk5LjYwNS0zLjYzMyAyLjIzOC0zLjcxOCAyLjI5Ny4wNjYtLjAzNyAyLjQ5LTEuNDgyIDMuOTQ2LTEuOTY1IDQuMzQ0LTEuNzkxIDguNjQ4LTEuMzEyIDEwLjc2Mi0uMjcyIDIuNDk5IDIuMjM4IDQuMDMgNS4xOCA0LjA2IDguNDEtLjMzLTMuMTAzLTUuODg4LTYuMjU0LTExLjU0LTUuMTI3LTYuNCAxLjI3Ny0xMC43MzMgNy42NDUtMTUuODM0IDguNDE0LTEuMTU5LjE3NS0yLjQ2Ni4wNy0zLjM2Ny0uNTM4LTEuMDc1LS43MjYtMS4yMjctMS41NS0xLjI1NS0yLjY1Mi0uMTc5LTYuNjkgNi40MzUtMTIuMTggMTQuNjMtMTIuNzM0LTIuODgzIDEuNDA5LTUuNDM3IDMuODY1LTcuMDg5IDYuMjY4WiIgZmlsbD0idXJsKCNiKSIvPjxkZWZzPjxsaW5lYXJHcmFkaWVudCBpZD0iYSIgeDE9IjM2IiB5MT0iMjgiIHgyPSI5LjU1NiIgeTI9IjI4IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHN0b3Agc3RvcC1jb2xvcj0iIzAwRjhEQiIvPjxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iIzA4RjhDQyIvPjwvbGluZWFyR3JhZGllbnQ+PGxpbmVhckdyYWRpZW50IGlkPSJiIiB4MT0iNCIgeTE9IjEyIiB4Mj0iMzAuNDQ0IiB5Mj0iMTIiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj48c3RvcCBzdG9wLWNvbG9yPSIjMDBGOERCIi8+PHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjMDhGOENDIi8+PC9saW5lYXJHcmFkaWVudD48L2RlZnM+PC9zdmc+", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "aaaaaa20d9e0e2461697782ef11675f668207961.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Aurora", + "symbol": "AURORA", + "icon": "data:image/svg+xml,%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 288 288' style='enable-background:new 0 0 288 288;' xml:space='preserve'%3E %3Cstyle type='text/css'%3E .st0%7Bfill:%2370D44B;%7D .st1%7Bfill:%23FFFFFF;%7D %3C/style%3E %3Cpath class='st0' d='M144,0L144,0c79.5,0,144,64.5,144,144v0c0,79.5-64.5,144-144,144h0C64.5,288,0,223.5,0,144v0 C0,64.5,64.5,0,144,0z'/%3E %3Cpath class='st1' d='M144,58.8c7.6,0,14.5,4.3,17.9,11.1l56.2,112.5c4.9,9.9,0.9,21.9-9,26.8c-2.8,1.4-5.8,2.1-8.9,2.1H87.8 c-11,0-20-9-20-20c0-3.1,0.7-6.2,2.1-8.9l56.2-112.5C129.5,63,136.4,58.7,144,58.8 M144,45c-12.8,0-24.5,7.2-30.2,18.7L57.6,176.2 c-8.3,16.7-1.6,36.9,15.1,45.3c4.7,2.3,9.9,3.6,15.1,3.6h112.5c18.6,0,33.8-15.1,33.8-33.7c0-5.2-1.2-10.4-3.6-15.1L174.2,63.7 C168.5,52.2,156.8,45,144,45z'/%3E %3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "craftorium.tamada.near": { + "spec": "ft-1.0.0", + "name": "Сraftorium", + "symbol": "CRFT", + "icon": "data:image/svg+xml;base64, PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2NCA2NCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNjQgNjQiPjxwYXRoIGQ9Im0zMiAyYy0xNi41NjggMC0zMCAxMy40MzItMzAgMzBzMTMuNDMyIDMwIDMwIDMwIDMwLTEzLjQzMiAzMC0zMC0xMy40MzItMzAtMzAtMzBtNi4wMTYgNDQuNTA4bC04LjkzOS0xMi42NjYtMi45MjIgMi45NjF2OS43MDVoLTUuOTYzdi0yOS4wMTZoNS45NjN2MTEuOTU1bDExLjIxMS0xMS45NTVoNy44MzZsLTExLjkwOSAxMS45MzQgMTIuNTE4IDE3LjA4MmgtNy43OTUiIGZpbGw9IiMxZTg4ZTUiLz48L3N2Zz4K", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "putt.tkn.near": { + "spec": "ft-1.0.0", + "name": "Puttcoinz", + "symbol": "PUTT", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "mz.tkn.near": { + "spec": "ft-1.0.0", + "name": "Meinen Zutrunk!", + "symbol": "mz", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "neardoge.tkn.near": { + "spec": "ft-1.0.0", + "name": "neardoge", + "symbol": "neardoge", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "akaia.tkn.near": { + "spec": "ft-1.0.0", + "name": "Akaia", + "symbol": "AKAIA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "token.pembrock.near": { + "spec": "ft-1.0.0", + "name": "PembRock", + "symbol": "PEM", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "asc.tkn.near": { + "spec": "ft-1.0.0", + "name": "Art Stars Club", + "symbol": "ASC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "dan.tkn.near": { + "spec": "ft-1.0.0", + "name": "Danny Token", + "symbol": "dan", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "rimjob.tkn.near": { + "spec": "ft-1.0.0", + "name": "Simps 4 Rim", + "symbol": "RIMJOB", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "chf.tkn.near": { + "spec": "ft-1.0.0", + "name": "Helvetia", + "symbol": "CHF", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token.v2.ref-finance.near": { + "spec": "ft-1.0.0", + "name": "Ref Finance Token", + "symbol": "REF", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "bsa.tkn.near": { + "spec": "ft-1.0.0", + "name": "BigShortAlliance", + "symbol": "BSA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ralfusha.tkn.near": { + "spec": "ft-1.0.0", + "name": "Ralfusha token", + "symbol": "Ralfusha", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "c944e90c64b2c07662a292be6244bdf05cda44a7.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Graph Token", + "symbol": "GRT", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "flobo.tkn.near": { + "spec": "ft-1.0.0", + "name": "Flobo", + "symbol": "FLOBO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "apys.token.a11bd.near": { + "spec": "ft-1.0.0", + "name": "APYSwap", + "symbol": "APYS", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "0316eb71485b0ab14103307bf65a021042c6d380.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Huobi BTC", + "symbol": "HBTC", + "icon": "' width='24' height='24'/%3E%3C/g%3E%3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "nmeme.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEAR MEME DAILY", + "symbol": "nMEME", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "coin.asac.near": { + "spec": "ft-1.0.0", + "name": "Antisocial Ape Coin", + "symbol": "$ASAC", + "icon": "data:image/svg+xml,%3Csvg version='1.1' id='Level_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 800 800' style='enable-background:new 0 0 800 800;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23FFFFFF;%7D%0A%3C/style%3E%3Cg id='Path_1'%3E%3Ccircle cx='400.05' cy='399.58' r='400'/%3E%3C/g%3E%3Cpath id='Path_2' class='st0' d='M750.03,251.73c-19.13-45.23-46.52-85.85-81.4-120.73c-34.88-34.88-75.5-62.27-120.73-81.4 c-46.83-19.81-96.58-29.85-147.85-29.85S299.03,29.79,252.2,49.6c-45.23,19.13-85.85,46.52-120.73,81.4 c-34.88,34.88-62.27,75.5-81.4,120.73c-19.81,46.83-29.85,96.58-29.85,147.85S30.26,500.6,50.07,547.43 c19.13,45.23,46.52,85.85,81.4,120.73c34.88,34.88,75.5,62.27,120.73,81.4c46.83,19.81,96.58,29.85,147.85,29.85 s101.02-10.04,147.85-29.85c45.23-19.13,85.85-46.52,120.73-81.4c34.88-34.88,62.27-75.5,81.4-120.73 c19.81-46.83,29.85-96.58,29.85-147.85S769.84,298.56,750.03,251.73z M520.56,61.71c4.78,16.32,10.19,34.78,25.12,49.71 c14.94,14.94,33.4,20.35,49.69,25.12c16.18,4.74,31.43,9.21,43.9,21.68c12.48,12.48,16.95,27.74,21.68,43.89 c4.77,16.3,10.18,34.77,25.12,49.7c14.94,14.94,33.41,20.35,49.7,25.12c4.66,1.36,9.23,2.72,13.69,4.24 c9.99,29.48,16.34,60.64,18.54,92.94c-4.35-14-10.18-28.84-22.58-41.24c-14.94-14.94-33.41-20.35-49.7-25.12 c-16.16-4.73-31.42-9.2-43.9-21.68c-12.48-12.49-16.95-27.75-21.68-43.9c-4.77-16.29-10.18-34.76-25.12-49.7 c-14.94-14.94-33.4-20.35-49.7-25.11c-16.16-4.73-31.42-9.2-43.9-21.68c-12.47-12.48-16.95-27.74-21.68-43.89 c-4.77-16.3-10.17-34.76-25.12-49.7c-10.16-10.16-21.94-15.9-33.57-20.04c29.74,2.48,58.49,8.48,85.8,17.6 C518.17,53.59,519.36,57.62,520.56,61.71z M743.58,265.06c-1.33-0.4-2.67-0.8-3.98-1.18c-16.17-4.74-31.43-9.21-43.9-21.68 c-12.48-12.48-16.95-27.75-21.68-43.9c-4.77-16.29-10.18-34.76-25.12-49.7c-14.93-14.93-33.39-20.34-49.68-25.11 c-16.19-4.74-31.44-9.21-43.91-21.69c-12.48-12.48-16.94-27.74-21.68-43.89c-0.24-0.83-0.5-1.67-0.74-2.51 C629.17,92.59,705.93,169.01,743.58,265.06z M101.05,615.57c3.97,1.3,7.9,2.46,11.7,3.58c16.19,4.74,31.45,9.21,43.93,21.69 c12.48,12.48,16.95,27.74,21.68,43.9c1.19,4.06,2.42,8.25,3.83,12.49C151.07,674.41,123.67,646.83,101.05,615.57z M202.93,711.37 c-5.34-9.39-8.38-19.73-11.52-30.46c-4.77-16.3-10.18-34.76-25.11-49.69c-14.93-14.93-33.4-20.34-49.69-25.12 c-10.29-3.01-20.21-5.94-29.28-10.87c-28.74-45.84-47.67-98.44-53.88-154.88c9.7,3.58,18.77,8.28,26.7,16.22 c12.48,12.47,16.95,27.74,21.68,43.89c4.77,16.3,10.18,34.77,25.12,49.7c14.94,14.93,33.4,20.34,49.69,25.11 c16.17,4.74,31.43,9.21,43.9,21.68c12.48,12.48,16.95,27.74,21.68,43.9c4.77,16.29,10.18,34.76,25.12,49.7 c14.93,14.93,33.38,20.33,49.66,25.11c16.19,4.74,31.46,9.21,43.93,21.69c8.47,8.47,13.25,18.22,16.92,28.67 C301.36,759.59,248.73,740.38,202.93,711.37z M743.44,534.44c-14.32-4.27-27.76-9.02-38.97-20.23 c-12.47-12.47-16.94-27.72-21.67-43.87c-4.78-16.33-10.19-34.8-25.13-49.73c-12.06-12.06-26.43-17.91-40.09-22.23v14.3 c11.13,3.76,21.52,8.59,30.48,17.54c12.48,12.48,16.95,27.74,21.68,43.9c4.78,16.3,10.19,34.76,25.12,49.7 c13.03,13.03,28.74,18.8,43.35,23.23c-5.61,12.84-11.93,25.3-18.91,37.33c-5.01-1.74-9.98-3.22-14.76-4.62 c-16.2-4.74-31.46-9.21-43.94-21.69c-12.48-12.48-16.95-27.74-21.68-43.9c-4.34-14.83-9.24-31.45-21.34-45.58v25.31 c3.45,7.62,5.84,15.73,8.29,24.09c4.77,16.29,10.17,34.76,25.12,49.69c14.93,14.93,33.4,20.35,49.69,25.12 c3.87,1.13,7.68,2.26,11.42,3.48c-7.95,12.59-16.64,24.66-26.02,36.16c-8.55-3.84-17.27-6.42-25.44-8.81 c-16.16-4.73-31.42-9.21-43.9-21.68c-12.47-12.47-16.94-27.72-21.67-43.87c-0.38-1.31-0.77-2.64-1.17-3.97 c-3.96,1.73-8.26,2.82-12.77,3.15c-0.03,0.41-0.08,0.82-0.12,1.23c0.33,1.12,0.66,2.25,0.99,3.38 c4.78,16.31,10.19,34.78,25.12,49.71c14.94,14.93,33.4,20.34,49.69,25.11c6.91,2.02,13.65,4.02,20.09,6.59 c-10.47,11.88-21.69,23.08-33.59,33.53c-8.9-4.12-18.02-6.81-26.55-9.31c-16.17-4.74-31.43-9.2-43.9-21.68 c-12.48-12.47-16.95-27.74-21.68-43.89c-0.84-2.87-1.7-5.8-2.63-8.77c-1.25,0.21-2.51,0.37-3.8,0.47 c-0.44,6.12-2.3,11.85-5.23,16.87c4.5,15.06,10.2,31.44,23.71,44.95c14.94,14.94,33.41,20.35,49.7,25.12 c6.43,1.89,12.72,3.74,18.74,6.06c-13.5,10.91-27.79,20.88-42.76,29.82c-5.44-1.93-10.85-3.54-16.03-5.06 c-16.17-4.74-31.43-9.21-43.9-21.68c-12.48-12.48-16.95-27.74-21.68-43.89c-0.45-1.55-0.92-3.12-1.39-4.71 c-2.15,5.62-5.54,10.62-9.85,14.67c4.45,14.68,10.22,30.47,23.29,43.55c14.94,14.94,33.41,20.34,49.7,25.12 c1.25,0.37,2.48,0.73,3.71,1.1c-18.74,9.95-38.45,18.34-58.94,24.98c-10.47-3.68-20.24-8.46-28.72-16.94 c-12.48-12.48-16.95-27.74-21.68-43.9c-2.19-7.47-4.52-15.39-7.83-23.22h-14.92c4.24,8.46,6.93,17.59,9.7,27.04 c4.77,16.29,10.18,34.76,25.12,49.69c5.61,5.61,11.72,9.87,18.02,13.26c-19.62,5.12-39.87,8.68-60.62,10.51 c-6.57-10.35-10-22.02-13.34-33.42c-4.77-16.29-10.18-34.76-25.11-49.69c-14.94-14.93-33.4-20.35-49.7-25.12 c-16.17-4.74-31.43-9.21-43.9-21.68c-2.34-2.34-4.4-4.78-6.24-7.31c-7.79-1.03-14.88-4.35-20.55-9.26 c3.9,9.16,9.16,18.18,17.16,26.18c14.92,14.93,33.38,20.34,49.67,25.11c16.2,4.75,31.45,9.21,43.92,21.69 c12.48,12.48,16.95,27.74,21.68,43.9c2.88,9.82,6,20.45,11.3,30.61c-5.88,0.28-11.8,0.43-17.75,0.43c-9.21,0-18.35-0.34-27.4-1.01 c-4.31-13.54-10.15-27.73-22.09-39.67c-14.94-14.94-33.4-20.35-49.7-25.12c-16.16-4.73-31.42-9.2-43.9-21.68 c-12.47-12.47-16.94-27.73-21.68-43.88c-4.78-16.31-10.19-34.78-25.12-49.71c-14.94-14.94-33.41-20.35-49.7-25.12 c-16.16-4.73-31.42-9.21-43.9-21.68c-12.48-12.48-16.95-27.74-21.68-43.9c-4.77-16.29-10.18-34.76-25.12-49.7 c-11.35-11.35-24.73-17.19-37.65-21.44c-0.59-8.56-0.9-17.21-0.9-25.92c0-6.3,0.16-12.57,0.47-18.79 c9.5,4.64,19.31,7.54,28.44,10.21c16.16,4.73,31.42,9.21,43.9,21.68c12.47,12.47,16.94,27.72,21.67,43.87 c4.78,16.32,10.19,34.79,25.12,49.73c11.49,11.49,25.07,17.33,38.14,21.59c-0.82-3.15-1.26-6.45-1.26-9.86v-4.94 c-9.92-3.61-19.18-8.33-27.26-16.42c-12.48-12.47-16.95-27.73-21.68-43.88c-4.78-16.31-10.18-34.78-25.12-49.72 c-14.94-14.94-33.4-20.34-49.69-25.12c-10.6-3.11-21.44-6.29-31.22-12c1.82-20.09,5.24-39.71,10.15-58.74 c3.07,5.16,6.78,10.15,11.43,14.8c14.92,14.92,33.38,20.33,49.66,25.11c16.2,4.74,31.46,9.21,43.94,21.69 c1.23,1.23,2.36,2.49,3.44,3.78V353.7c-13.66-10.86-29.4-15.48-43.5-19.62c-16.18-4.74-31.44-9.21-43.92-21.68 c-7.38-7.38-11.95-15.74-15.44-24.68c6.52-20.52,14.79-40.27,24.64-59.06c4.76,16.25,10.19,34.61,25.05,49.48 c14.94,14.93,33.41,20.34,49.7,25.12c1.43,0.42,2.84,0.83,4.25,1.25c0.92-4.57,2.64-8.85,5-12.7c-1.83-0.55-3.64-1.08-5.43-1.61 c-16.16-4.73-31.42-9.2-43.9-21.68c-12.47-12.47-16.94-27.73-21.68-43.88c-1.18-4.05-2.42-8.23-3.82-12.45 c8.92-15.09,18.88-29.48,29.78-43.08c1.78,5.02,3.31,10.19,4.85,15.47c4.77,16.29,10.18,34.76,25.12,49.7 c14.84,14.83,33.15,20.27,49.36,25.02c2.07-4.41,4.93-8.37,8.41-11.7c-1.42-0.42-2.83-0.84-4.22-1.25 c-16.19-4.74-31.45-9.21-43.93-21.69c-12.48-12.48-16.95-27.74-21.68-43.9c-2.22-7.57-4.59-15.6-7.97-23.53 c10.38-11.9,21.51-23.13,33.33-33.61c2.04,5.53,3.75,11.25,5.46,17.1c4.78,16.31,10.19,34.77,25.12,49.7 c14.12,14.12,31.41,19.72,47.02,24.33c3.52-4.3,7.92-7.85,12.94-10.36c-2.17-0.66-4.33-1.29-6.44-1.91 c-16.16-4.73-31.42-9.2-43.9-21.68c-12.49-12.49-16.95-27.75-21.68-43.9c-2.13-7.27-4.41-14.97-7.58-22.6 c11.4-9.35,23.36-18.03,35.84-25.98c0.87,2.81,1.72,5.64,2.56,8.52c4.77,16.29,10.17,34.76,25.12,49.69 c14.26,14.26,31.72,19.83,47.45,24.46c6.39-4.48,14.16-7.11,22.54-7.11H300c-5.66-2.04-11.29-3.7-16.68-5.28 c-16.17-4.74-31.43-9.21-43.9-21.68c-12.48-12.48-16.95-27.74-21.68-43.9c-1.14-3.9-2.34-7.92-3.67-11.99 c11.99-7.01,24.41-13.37,37.21-19.02c4.34,13.84,10.17,28.43,22.4,40.66c14.93,14.93,33.4,20.34,49.69,25.11 c16.17,4.74,31.43,9.21,43.91,21.69c4.48,4.47,7.91,9.31,10.71,14.41h15.14c-3.8-8.41-8.85-16.65-16.23-24.03 c-14.94-14.94-33.41-20.35-49.7-25.12c-16.16-4.73-31.42-9.2-43.9-21.68c-10.51-10.51-15.34-23-19.42-36.32 c13.51-5.37,27.42-9.97,41.66-13.73c3.18,5.52,7.07,10.85,12.01,15.8c14.94,14.93,33.4,20.34,49.7,25.12 c16.17,4.74,31.43,9.2,43.9,21.68c12.48,12.48,16.95,27.73,21.68,43.89c1.37,4.67,2.8,9.51,4.47,14.4h14.43 c-2.22-5.86-4.02-11.96-5.85-18.2c-4.78-16.3-10.18-34.77-25.12-49.71c-14.92-14.92-33.38-20.33-49.66-25.1 c-16.2-4.75-31.46-9.21-43.94-21.69c-3.03-3.03-5.57-6.22-7.77-9.55c21.33-4.76,43.35-7.67,65.89-8.56 c8.67,3.94,17.53,6.55,25.83,8.98c16.16,4.73,31.42,9.2,43.9,21.68c12.48,12.48,16.95,27.74,21.68,43.9 c4.78,16.3,10.18,34.76,25.12,49.69c14.93,14.94,33.4,20.34,49.69,25.12c16.17,4.74,31.43,9.21,43.91,21.68 c12.48,12.49,16.95,27.75,21.68,43.9c4.77,16.29,10.18,34.76,25.12,49.7c14.92,14.92,33.38,20.33,49.66,25.11 c16.19,4.74,31.45,9.21,43.94,21.69c12.48,12.48,16.95,27.74,21.68,43.9c2.82,9.64,5.89,20.04,11.01,30.03 c-0.97,21.58-3.79,42.68-8.31,63.13c-4.16-2.51-8.12-5.5-11.83-9.21c-12.47-12.47-16.94-27.73-21.68-43.88 c-4.78-16.32-10.19-34.78-25.12-49.7c-14.94-14.94-33.4-20.35-49.69-25.12c-12.22-3.58-23.91-7.01-34.28-13.85v15.69 c10.11,5.24,20.67,8.35,30.44,11.22c16.18,4.74,31.43,9.21,43.91,21.68c12.47,12.47,16.94,27.73,21.67,43.88 c4.78,16.32,10.19,34.78,25.12,49.71c5.65,5.64,11.8,9.9,18.14,13.3C753.19,507.34,748.7,521.08,743.44,534.44z M578.23,266.59 h-11.95c-8.31,0-15.06-6.76-15.06-15.06v-11.95c0-5.16-4.19-9.35-9.35-9.35h-11.95c-8.31,0-15.06-6.76-15.06-15.06v-11.95 c0-5.16-4.19-9.35-9.35-9.35H299.79c-5.16,0-9.35,4.19-9.35,9.35v11.95c0,8.31-6.76,15.06-15.06,15.06h-11.95 c-5.16,0-9.35,4.19-9.35,9.35v11.95c0,8.31-6.76,15.06-15.06,15.06h-11.95c-5.16,0-9.35,4.19-9.35,9.35v11.95 c0,8.31-6.76,15.06-15.07,15.06H190.7c-5.16,0-9.35,4.19-9.35,9.35v96.62c0,5.16,4.19,9.35,9.35,9.35h11.95h0 c8.31,0,15.06,6.76,15.06,15.06v84.68c0,5.16,4.19,9.35,9.35,9.35h11.95c8.31,0,15.06,6.76,15.06,15.06v11.95 c0,5.16,4.19,9.35,9.35,9.35h11.95c8.31,0,15.06,6.76,15.06,15.06v11.95c0,5.16,4.19,9.35,9.35,9.35h48.31 c8.31,0,15.06,6.76,15.06,15.06v11.95c0,5.16,4.19,9.35,9.35,9.35h96.62c5.16,0,9.35-4.19,9.35-9.35v-11.95 c0-8.31,6.76-15.06,15.06-15.06h11.95c5.16,0,9.35-4.19,9.35-9.35V578.8c0-8.31,6.76-15.06,15.06-15.06h11.95 c5.16,0,9.35-4.19,9.35-9.35v-11.95c0-8.31,6.76-15.06,15.06-15.06h11.95c5.16,0,9.35-4.19,9.35-9.35V275.94 C587.58,270.79,583.39,266.59,578.23,266.59z M472.26,566.85v11.95c0,8.31-6.76,15.06-15.06,15.06h-72.73 c-8.31,0-15.06-6.76-15.06-15.06v-11.95c0-5.16-4.19-9.35-9.35-9.35h-48.31c-8.31,0-15.07-6.76-15.07-15.06v-11.95 c0-5.16-4.19-9.35-9.35-9.35h-11.95c-8.31,0-15.06-6.76-15.06-15.06V421.4c0-5.16-4.19-9.35-9.35-9.35h-11.95 c-8.31,0-15.06-6.76-15.06-15.06v-72.73c0-8.31,6.76-15.06,15.06-15.06h11.95c5.16,0,9.35-4.19,9.35-9.35v-11.95 c0-8.31,6.76-15.06,15.06-15.06h11.95c5.16,0,9.35-4.19,9.35-9.35v-11.95c0-8.31,6.76-15.06,15.07-15.06h181.82 c8.31,0,15.06,6.76,15.06,15.06v11.95c0,5.16,4.19,9.35,9.35,9.35h11.95c8.31,0,15.06,6.76,15.06,15.06v218.18 c0,8.31-6.76,15.06-15.06,15.06c-8.31,0-15.06-6.76-15.06-15.06v-11.95c0-5.16-4.19-9.35-9.35-9.35H384.46 c-8.31,0-15.06-6.76-15.06-15.06v-11.95c0-5.16-4.19-9.35-9.35-9.35h-23.9c-5.16,0-9.35,4.19-9.35,9.35v23.9 c0,5.16,4.19,9.35,9.35,9.35h11.95c8.31,0,15.06,6.76,15.06,15.06v11.95c0,5.16,4.19,9.35,9.35,9.35h121.04 c8.31,0,15.06,6.76,15.06,15.06c0,8.31-6.76,15.06-15.06,15.06h-11.95C476.45,557.5,472.26,561.7,472.26,566.85z M472.26,372.57 v-60.26c0-5.16,4.19-9.35,9.35-9.35h23.9c5.16,0,9.35,4.19,9.35,9.35v60.26c0,5.16-4.19,9.35-9.35,9.35h-23.9 C476.45,381.92,472.26,377.72,472.26,372.57z M363.17,372.57v-60.26c0-5.16,4.19-9.35,9.35-9.35h23.9c5.16,0,9.35,4.19,9.35,9.35 v60.26c0,5.16-4.19,9.35-9.35,9.35h-23.9C367.36,381.92,363.17,377.72,363.17,372.57z M408.88,412.05h23.9 c5.16,0,9.35,4.19,9.35,9.35v23.9c0,5.16-4.19,9.35-9.35,9.35h-23.9c-5.16,0-9.35-4.19-9.35-9.35v-23.9 C399.53,416.24,403.72,412.05,408.88,412.05z M472.26,445.29v-23.9c0-5.16,4.19-9.35,9.35-9.35h23.9c5.16,0,9.35,4.19,9.35,9.35 v23.9c0,5.16-4.19,9.35-9.35,9.35h-23.9C476.45,454.65,472.26,450.45,472.26,445.29z'/%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "marmaj.tkn.near": { + "spec": "ft-1.0.0", + "name": "marma j token", + "symbol": "marmaj", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "lgbt.tkn.near": { + "spec": "ft-1.0.0", + "name": "Hey👏hey👏Ho👏ho👏Homophobia's👏got👏to👏go👏", + "symbol": "LGBT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "wnear.mocks.near": { + "spec": "ft-1.0.0", + "name": "Mock Wrapped NEAR fungible token", + "symbol": "MOCK-wNEAR", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "test-token.staderlabs-test.near": { + "spec": "ft-1.0.0", + "name": "Test Token", + "symbol": "Test Token", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "dac17f958d2ee523a2206206994597c13d831ec7.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Tether USD", + "symbol": "USDT.e", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "514910771af9ca656af840dff83e8264ecf986ca.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "ChainLink Token", + "symbol": "LINK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "toes.tkn.near": { + "spec": "ft-1.0.0", + "name": "Camel Token", + "symbol": "TOES", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 13 + }, + "discovol-token.near": { + "spec": "ft-1.0.0", + "name": "DISCOVOL TOKEN", + "symbol": "DISC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 14 + }, + "token.shrm.near": { + "spec": "ft-1.0.0", + "name": "Shroom Kingdom", + "symbol": "SHRM", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Dai Stablecoin", + "symbol": "DAI", + "icon": "data:image/svg+xml,%3Csvg width='32' height='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Ccircle fill='%23F4B731' fill-rule='nonzero' cx='16' cy='16' r='16'/%3E%3Cpath d='M9.277 8h6.552c3.985 0 7.006 2.116 8.13 5.194H26v1.861h-1.611c.031.294.047.594.047.898v.046c0 .342-.02.68-.06 1.01H26v1.86h-2.08C22.767 21.905 19.77 24 15.83 24H9.277v-5.131H7v-1.86h2.277v-1.954H7v-1.86h2.277V8zm1.831 10.869v3.462h4.72c2.914 0 5.078-1.387 6.085-3.462H11.108zm11.366-1.86H11.108v-1.954h11.37c.041.307.063.622.063.944v.045c0 .329-.023.65-.067.964zM15.83 9.665c2.926 0 5.097 1.424 6.098 3.528h-10.82V9.666h4.72z' fill='%23FFF'/%3E%3C/g%3E%3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "b8919522331c59f5c16bdfaa6a121a6e03a91f62.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "bHome", + "symbol": "bHOME", + "icon": "data:image/svg+xml,%3C%3Fxml version='1.0' encoding='utf-8'%3F%3E%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 111.4 104.2' style='enable-background:new 0 0 111.4 104.2;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23FFF641;%7D .st1%7Bfill:%23FF9901;%7D .st2%7Bfill:%23FFFD79;%7D .st3%7Bfill:%23FFFFFF;%7D .st4%7Bfill:%23B70501;%7D .st5%7Bfill:%23660200;%7D .st6%7Bfill:%23EC5252;%7D%0A%3C/style%3E%3Cg transform='matrix( 0.6914520263671875, 0, 0, 0.6914520263671875, 76.05,55.3) '%3E%3Cg transform='matrix( 1, 0, 0, 1, 0,0) '%3E%3Cg%3E%3Cg id='B_coin_anim1_0_Layer1_0_FILL'%3E%3Cpath class='st0' d='M20.6,30.4h10v-20h-10V30.4 M20.6,40.4v-10h-10v10H20.6 M-9.4,40.4v10h20v-10H-9.4 M-49.4,50.4v10h40v-10 H-49.4 M-69.4,30.4h-10v10h10V30.4 M-79.4,30.4v-20h-10v20H-79.4 M-49.4,40.4h-20v10h20V40.4 M-69.4-59.6v10h20v-10H-69.4 M-69.4-49.6h-10v10h10V-49.6 M-9.4-59.6v-10h-40v10H-9.4 M-89.4-19.6h-10v30h10V-19.6 M-89.4-39.6v20h10v-20H-89.4 M40.6-19.6 h-10v30h10V-19.6 M30.6-39.6h-10v20h10V-39.6 M20.6-49.6h-10v10h10V-49.6 M10.6-49.6v-10h-20v10H10.6z'/%3E%3Cpath class='st1' d='M20.6,40.4h-10v10h10V40.4 M20.6,30.4v10h10v-10H20.6 M40.6,10.4h-10v20h10V10.4 M-89.4,30.4v-20h-10v20 H-89.4 M-9.4,50.4v10h20v-10H-9.4 M-49.4,60.4v-10h-20v10H-49.4 M-49.4,60.4v10h40v-10H-49.4 M-79.4,40.4v-10h-10v10H-79.4 M-69.4,40.4h-10v10h10V40.4 M-69.4-69.6v10h20v-10H-69.4 M-79.4-49.6h10v-10h-10V-49.6 M-9.4-69.6v-10h-40v10H-9.4 M-89.4-49.6 v10h10v-10H-89.4 M-99.4-19.6h-10v30h10V-19.6 M-89.4-19.6v-20h-10v20H-89.4 M50.6-19.6h-10v30h10V-19.6 M30.6-39.6v20h10v-20 H30.6 M10.6-59.6v-10h-20v10H10.6 M10.6-59.6v10h10v-10H10.6 M30.6-49.6h-10v10h10V-49.6z'/%3E%3Cpath class='st2' d='M-49.4,40.4v10h40v-10H-49.4 M-79.4-19.6h-10v30h10V-19.6 M-9.4-49.6v-10h-40v10H-9.4 M30.6-19.6h-10v30h10 V-19.6z'/%3E%3Cpath class='st3' d='M20.6-19.6v-20h-10v-10h-20h-40h-20v10h-10v20v30v20h10v10h20h40h20v-10h10v-20V-19.6z'/%3E%3C/g%3E%3C/g%3E%3C/g%3E%3Cg transform='matrix( 1, 0, 0, 1, 0,0) '%3E%3Cg%3E%3Cg id='B_coin_anim1_0_Layer0_0_FILL'%3E%3Cpath class='st4' d='M-49.4-19.6h5v30h-5v20h10v-20h5v-10v-10v-10h-5v-20h-10V-19.6z'/%3E%3Cpath class='st5' d='M-59.4-39.6h-10v20h5v30h-5v20h10v-20h5v-30h-5V-39.6z'/%3E%3Cpath class='st6' d='M-49.4-39.6h-10v20h5v30h-5v20h10v-20h5v-30h-5V-39.6z'/%3E%3Cpath d='M5.6-9.6h10v-20h-10v-10h-40v10h30v20h-30v10h30v20h-30v10h40v-10h10v-20h-10V-9.6z'/%3E%3C/g%3E%3C/g%3E%3C/g%3E%3C/g%3E%3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 6 + }, + "token.bwitter.near": { + "spec": "ft-1.0.0", + "name": "Bwitter Token", + "symbol": "BT", + "icon": "data:image/svg+xml,%3Csvg id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 256 256' style='enable-background:new 0 0 256 256;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23018BF7;%7D .st1%7Bfill:%23FFFFFF;%7D\n%3C/style%3E%3Ccircle class='st0' cx='128' cy='127.9' r='128'/%3E%3Cg%3E%3Cpath class='st1' d='M72.2,58.9c3.5,10.5,17.6,49.9,54.5,65.3c11.1,5.3,12.2,10.5,9.2,22.1c1.5,14.2,10.3,8,26.4,2.4 c6-1.4,8,3.2,8,3.2s4.6-0.2,5.1,3.7c-9.5-0.5-35.5,15.4-49.5,39.7c-7.3,3.5-6.9,0-6.9,0l0.4-3.1c0,0-1.4,2.6-4,3.8 c-2.5,1.3-8.8-0.5-8.8-0.5s6-3.2,4.6-6.7c-12.1,7-23.2,3.3-26.6,2.1c44.1-13.9,48.1-27.4,29.8-34.4c2.3-0.8,3.4-2,2.8-2.9 c-8.9-1-18.8-4.8-25.8-13.7c7.5,0.5,6.1-0.5,6.1-0.5s-25.6-16.5-27.7-34.2c5.5,4,6.2,5.3,10.5,6C66.7,86.5,67.4,64.3,72.2,58.9z'/%3E%3Cpath class='st1' d='M187,82.4c-36.5,31.2-17.1,38.9-44,69c10.4-1.6,20.1-5,23.1-7.1C187,130.3,171.9,107.5,187,82.4z'/%3E%3C/g%3E%3C/svg%3E", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "8.contract.portalbridge.near": { + "spec": "ft-1.0.0", + "name": "impactMarket", + "symbol": "PACT", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "meme.tkn.near": { + "spec": "ft-1.0.0", + "name": "MEME 💎🚀 Universal Idea Token", + "symbol": "MEME", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "token.burrow.near": { + "spec": "ft-1.0.0", + "name": "Burrow Token", + "symbol": "BRRR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "aurora": { + "decimals": 18, + "icon": "", + "name": "Ether", + "reference": null, + "reference_hash": null, + "spec": "ft-1.0.0", + "symbol": "ETH" + }, + "obs.openbisea.near": { + "spec": "ft-1.0.0", + "name": "OpenBiSea Token", + "symbol": "OBS", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ter.tkn.near": { + "spec": "ft-1.0.0", + "name": "SkyNet", + "symbol": "TER", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "fradao.tkn.near": { + "spec": "ft-1.0.0", + "name": "fraDAO", + "symbol": "fradao", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "indulgency.tkn.near": { + "spec": "ft-1.0.0", + "name": "Forgive Yourself", + "symbol": "Indulgency", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "fusotao-token.near": { + "spec": "ft-1.0.0", + "name": "FUSOTAO", + "symbol": "TAO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nvp.tkn.near": { + "spec": "ft-1.0.0", + "name": "NOVAPUNK", + "symbol": "NVP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "o.tkn.near": { + "spec": "ft-1.0.0", + "name": "Omicron", + "symbol": "O", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "gems.l2e.near": { + "spec": "ft-1.0.0", + "name": "LandtoEmpire.com game GEM!", + "symbol": "GEM", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 4 + }, + "kkd.tkn.near": { + "spec": "ft-1.0.0", + "name": "KalakendraDAO", + "symbol": "KKD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "mika.tkn.near": { + "spec": "ft-1.0.0", + "name": "Mikasa", + "symbol": "MIKA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "illiapolosukhin.tkn.near": { + "spec": "ft-1.0.0", + "name": "Illia Polosukhin", + "symbol": "IlliaPolosukhin", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "avb.tkn.near": { + "spec": "ft-1.0.0", + "name": "AVB", + "symbol": "AVB", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "stke.tkn.near": { + "spec": "ft-1.0.0", + "name": "sticky", + "symbol": "STKE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "jbouw.tkn.near": { + "spec": "ft-1.0.0", + "name": "The Original Joshua J. Bouw Cred Points", + "symbol": "JBOUW", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "lucky_nft.near": { + "spec": "ft-1.0.0", + "name": "Luck Token", + "symbol": "LUCK", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 2 + }, + "gold.l2e.near": { + "spec": "ft-1.0.0", + "name": "LandtoEmpire.com game GOLD!", + "symbol": "GOLD", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 0 + }, + "c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Wrapped Ether", + "symbol": "WETH", + "icon": null, + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "skyward-pixeltoken.near": { + "spec": "ft-1.0.0", + "name": "Skyward Wrapped Pixeltoken", + "symbol": "sPXT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "cheems.tkn.near": { + "spec": "ft-1.0.0", + "name": "cheems", + "symbol": "cheems", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nut.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEAR University Token", + "symbol": "NUT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "blaze.tkn.near": { + "spec": "ft-1.0.0", + "name": "BlazeN Fast", + "symbol": "BLAZE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "abr.a11bd.near": { + "spec": "ft-1.0.0", + "name": "ABR", + "symbol": "ABR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "groove.tkn.near": { + "spec": "ft-1.0.0", + "name": "Groove", + "symbol": "GROOVE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "3ea8ea4237344c9931214796d9417af1a1180770.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Flux Token", + "symbol": "FLX", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "token.serpius.near": { + "spec": "ft-1.0.0", + "name": "Serpius", + "symbol": "SER", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "meta-token.near": { + "spec": "ft-1.0.0", + "name": "Meta Token", + "symbol": "$META", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "myriadcore.near": { + "spec": "ft-1.0.0", + "name": "Myria", + "symbol": "MYRIA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "strw.burritobattle.near": { + "spec": "ft-1.0.0", + "name": "Straw Token", + "symbol": "STRW", + "icon": "", + "reference": "https://metapool.app", + "reference_hash": null, + "decimals": 24 + }, + "infinity.tkn.near": { + "spec": "ft-1.0.0", + "name": "🔴INFINITY", + "symbol": "INFINITY", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 10 + }, + "floki.tkn.near": { + "spec": "ft-1.0.0", + "name": "FLOKINEAR", + "symbol": "FLOKI", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ft.zomland.near": { + "spec": "ft-1.0.0", + "name": "ZomLand Token", + "symbol": "ZML", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 24 + }, + "fritz.tkn.near": { + "spec": "ft-1.0.0", + "name": "FRITZ", + "symbol": "FRITZ", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "czdog.tkn.near": { + "spec": "ft-1.0.0", + "name": "Crazy Dog", + "symbol": "CZDOG", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "themunkymonkey.near": { + "spec": "ft-1.0.0", + "name": "PISANG Coin", + "symbol": "PSNG", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "nearx.stader-labs.near": { + "spec": "ft-1.0.0", + "name": "NearX Classic", + "symbol": "NearXC", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "cat.tkn.near": { + "spec": "ft-1.0.0", + "name": "Catalyst", + "symbol": "CAT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "duello.near": { + "spec": "ft-1.0.0", + "name": "Duello", + "symbol": "DUO", + "icon": null, + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "data.tkn.near": { + "spec": "ft-1.0.0", + "name": "DATA", + "symbol": "DATA", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "atocha-token.near": { + "spec": "ft-1.0.0", + "name": "Atocha Coin", + "symbol": "ATO", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "net.tkn.near": { + "spec": "ft-1.0.0", + "name": "near express", + "symbol": "Net", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nd.tkn.near": { + "spec": "ft-1.0.0", + "name": "NearDog", + "symbol": "ND", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "hak.tkn.near": { + "spec": "ft-1.0.0", + "name": "Hakuna Matata", + "symbol": "HAK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "lfg.tkn.near": { + "spec": "ft-1.0.0", + "name": "L.F.G.!", + "symbol": "LFG", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "nexp.near": { + "spec": "ft-1.0.0", + "name": "NEXP", + "symbol": "NEXP", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 4 + }, + "token.paras.near": { + "spec": "ft-1.0.0", + "name": "PARAS", + "symbol": "PARAS", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "xtoken.ref-finance.near": { + "spec": "ft-1.0.0", + "name": "xRef Finance Token", + "symbol": "xREF", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "v2-nearx.stader-labs.near": { + "spec": "ft-1.0.0", + "name": "NearX", + "symbol": "NearX", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "d9c2d319cd7e6177336b0a9c93c21cb48d84fb54.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "HAPI", + "symbol": "HAPI", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "shit.tkn.near": { + "spec": "ft-1.0.0", + "name": "Pile of Shit (rare)", + "symbol": "SHIT", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "a0b86991c6218b36c1d19d4a2e9eb0ce3606eb48.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "USD Coin", + "symbol": "USDC.e", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "mrktng.tkn.near": { + "spec": "ft-1.0.0", + "name": "Marketing token", + "symbol": "MRKTNG", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 6 + }, + "testing-token.staderlabs-test.near": { + "spec": "ft-1.0.0", + "name": "testing", + "symbol": "testing", + "icon": null, + "reference": "https://nearX.app", + "reference_hash": null, + "decimals": 24 + }, + "usdt.mocks.near": { + "spec": "ft-1.0.0", + "name": "Mock Tether USD", + "symbol": "MOCK-USDT.e", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "cafe.devtest.near": { + "spec": "ft-1.0.0", + "name": "CAFE", + "symbol": "CAFE", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 12 + }, + "tamil.tkn.near": { + "spec": "ft-1.0.0", + "name": "TAMIL CRYPTO", + "symbol": "TAMIL", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ntrash.tkn.near": { + "spec": "ft-1.0.0", + "name": "NEAR TRASH", + "symbol": "nTRASH", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "utopia.secretskelliessociety.near": { + "spec": "ft-1.0.0", + "name": "Utopia", + "symbol": "UTO", + "icon": "data:image/svg+xml,%3Csvg id='Layer_1' data-name='Layer 1' xmlns='http://www.w3.org/2000/svg' viewBox='-40 -40 600 600'%3E%3Cdefs%3E%3Cstyle%3E .cls-1%7Bfill:%239f9f9f%7D.cls-2%7Bfill:%23fefefe%7D.cls-4%7Bfill:%23030303%7D %3C/style%3E%3C/defs%3E%3Cpath d='M371.65 15v23.92l-.47.71C368.82 41.48 366 41 363.36 41q-36.94.09-73.88 0h-176c-3.06 0-6.31.67-9.1-1.37l-.47-.71V15ZM55.21 355.33H31.66a2.81 2.81 0 0 1-.26-.3.82.82 0 0 1-.13-.37v-24H6.67V136.41h24.6l.69.44c2 2.64 1.38 5.75 1.39 8.67q.07 73.11 0 146.2c0 12.44.26 12.68 12.64 12.76 3 0 6-.29 8.85 1a3 3 0 0 1 1.23 1.1 12.38 12.38 0 0 1 1.18 6.17q.1 18 0 36.05c0 2.09.17 4.28-1.36 6.06ZM420.4 452.82v23.51c-3.87.66-178.64.93-195 .29v-23.8l.47-.71c2.79-2 6-1.37 9.1-1.37q75.33-.09 150.68 0c9.25 0 18.49-.06 27.74 0 2.25 0 4.6-.25 6.54 1.37ZM176.66 428H128v-23.83H79.16v-24.9l.39-.66c1.9-1.69 4.27-1.4 6.51-1.42 10.55-.08 21.09 0 31.63-.05 6.6-.05 7.89-1.5 8.12-8.1.16-4.52-.77-9.14 1.06-13.53a2.94 2.94 0 0 1 1.1-1.14 58.19 58.19 0 0 1 24.44-.12 3 3 0 0 1 1.2 1.07c1.29 2.36 1.19 4.95 1.2 7.5v30.75c.05 6.74 1.61 8.24 8.36 8.37 3.7.08 7.41-.1 11.1.23 2.23.2 3.9 1.14 4.1 3.54a107.23 107.23 0 0 1-.06 20 3.93 3.93 0 0 1-1 1.85c-.2.17-.43.31-.65.44Z'/%3E%3Cpath d='M225.4 452.82h-48.74V428c1.46-1.94 3.61-2 5.74-2.06 6.36-.1 12.72-.14 19.08.09 6.33-.23 12.67-.21 19-.07 1.93 0 4-.19 5.56 1.42 2.71 7.57 1.34 15.33 1 23-.04 1.09-.97 1.72-1.64 2.44ZM31.27 136.41V87.67h23.94l.7.45c1.36 1.51 1.34 3.39 1.35 5.22q.18 18.9 0 37.8a11.41 11.41 0 0 1-1 5 3.12 3.12 0 0 1-1.12 1.24c-7.1 2.15-14.32 1.17-21.51.74-1.03-.12-1.63-1.04-2.36-1.71Z'/%3E%3Cpath d='M55.21 87.67v-24.8h23.95l.69.44a3.53 3.53 0 0 1 1 1.84c.36 7.46 1.36 14.94-.69 22.33A3 3 0 0 1 79 88.65c-7.08 2-14.25 1.13-21.4.67-1.07-.06-1.67-.99-2.39-1.65ZM469.14 404.07V428h-24.8l-.71-.47a5.34 5.34 0 0 1-1.24-3.54q-.37-8.07 0-16.15a7 7 0 0 1 1.61-4.3 8.54 8.54 0 0 1 5.24-1.52c5-.13 10-.14 15 0 1.86.09 3.65.41 4.9 2.05Z'/%3E%3Cpath d='M79.16 62.87V38.92H104c.79.8 1.71 1.56 1.76 2.78.29 7 1.2 14-.69 20.86a3 3 0 0 1-1.13 1.23C96.52 66 89 64.92 81.56 64.53c-1.07-.06-1.68-1-2.4-1.66ZM444.34 428v24.8H420.4c-.67-.72-1.62-1.34-1.66-2.38-.33-7.7-1.67-15.44 1-23 1.15-1.33 2.78-1.33 4.32-1.4 5.11-.22 10.23-.18 15.35 0 1.9.03 3.68.36 4.93 1.98ZM79.16 379.27H55.21v-23.94c.52-.48.95-1.21 1.63-1.34a70.78 70.78 0 0 1 21.55-.16c1.55.19 2.36 1.57 2.5 3.09a109.82 109.82 0 0 1 0 19.53 4.76 4.76 0 0 1-1.73 2.82ZM444.34 111.61h24.8v73.54c-1.36 1.8-3.33 2-5.35 2-5 .13-9.94.18-14.9 0-5.5-.2-6.49-1.05-6.55-6.57-.18-14.62-.28-29.24.06-43.86-.24-6.35-.22-12.7-.12-19.06 0-2-.09-4 1.36-5.63ZM395.59 62.87h24.81v24.8c-.15.23-.3.46-.44.69a3.62 3.62 0 0 1-1.84 1c-7.43.4-14.88 1.3-22.25-.61a3 3 0 0 1-1.2-1.1c-1.72-8.12-2.21-16.24.23-24.32Z'/%3E%3Cpath d='M420.4 87.67h23.94v23.94c-.79.79-1.55 1.71-2.77 1.76-7 .29-14 1.2-20.87-.69a3.11 3.11 0 0 1-1.23-1.13c-2.14-7.1-1.16-14.3-.74-21.49.07-1.06 1-1.67 1.67-2.39ZM371.65 38.92h23.94v23.95c-.79.79-1.55 1.7-2.77 1.75-7 .3-14 1.2-20.87-.68a3.18 3.18 0 0 1-1.23-1.13c-2.13-7.1-1.16-14.31-.73-21.49.06-1.07 1.01-1.67 1.66-2.4Z'/%3E%3Cpath class='cls-1' d='M371.65 38.92v23.95c-.9 1.57-2.44 1.81-4 2-1.85.17-3.7.15-5.55.15q-124.27 0-248.55-.06c-3.25 0-6.93 1.15-9.57-2.05V38.92Z'/%3E%3Cpath class='cls-2' d='M104 62.87h267.65c1.92 1.47 2 3.6 2.07 5.74.1 3.68-.12 7.36.14 11 .28 4.05 1.77 5.54 5.81 5.83 3.53.25 7.07 0 10.6.14 2 .07 4 .3 5.32 2.07 1.93 1.47 2 3.6 2.08 5.74.11 3.53-.09 7.07.15 10.6.23 3.35 2 5.16 5.38 5.38 3.82.24 7.64 0 11.45.15 2.15.06 4.28.15 5.75 2.07 1.92 1.47 2 3.6 2.07 5.75.1 3.67-.12 7.35.13 11 .28 4 1.78 5.54 5.82 5.83 3.53.25 7.07 0 10.6.14 2 .06 4 .29 5.32 2.06v48.74h24.8v72.69c-1.25 1.62-3 2-4.92 2-3 .11-6 .06-9 .08-7.41.08-8.77 1.36-8.79 8.67-.05 14.34 0 28.68 0 43 0 3.27-.09 6.54 0 9.8.21 5.2 1.79 6.74 7.07 6.93 3.4.12 6.81 0 10.22.09 2 .06 4 .29 5.35 2.06v24.8c-1.45 1.93-3.59 2-5.71 2.05-6.32.1-12.64.16-19-.11-8 .24-16 .29-24 0-6.61.26-13.22.21-19.84.11a11 11 0 0 1-4.52-.85 3.53 3.53 0 0 1-1.28-.81c-1.44-2.28-1.36-4.85-1.38-7.4 0-3.11.09-6.23-.06-9.34-.22-4.62-1.65-6.06-6.2-6.29a67.32 67.32 0 0 0-7.65 0c-4.07.28-5.5 1.71-5.74 5.85-.22 3.68 0 7.37-.11 11.05-.06 2.4-.11 4.83-1.82 6.81-4.08 1.73-8.36.85-12.56 1s-8.19.09-12.28-.15c-6.36.26-12.72.22-19.08.12a11 11 0 0 1-4.54-.85 3.47 3.47 0 0 1-1.28-.82c-1.36-2.15-1.35-4.57-1.37-7 0-3.26.09-6.53-.07-9.79-.22-4.59-1.67-6-6.26-6.25-2.4-.12-4.82-.09-7.23 0-5.4.14-6.83 1.53-7 6.83-.11 3.54 0 7.09-.08 10.63-.07 2.27-.19 4.55-1.89 6.36-2.12 1.1-4.43.92-6.69.92q-29.41.09-58.84 0c-2.41 0-4.85.08-7.08-1.09-2.15-1.51-2.23-3.84-2.31-6.12-.14-3.56 0-7.12-.09-10.68-.17-5.33-1.6-6.72-7-6.86-2.13-.06-4.27-.09-6.41 0-4.58.25-6 1.68-6.19 6.35-.18 5.55.05 11.11-.27 16.67.34 6.24.22 12.48.14 18.72a11 11 0 0 1-1 4.55 2.94 2.94 0 0 1-1 1.19c-7.82 2.28-15.77 1.2-23.67.74-2.42-.14-2.95-2.34-3.11-4.45-.3-4 0-8-.22-11.93-.23-5.19-1.87-6.82-7-7-3.12-.14-6.25 0-9.38-.11-2-.07-4-.27-5.36-2.05-1.78-1.35-2-3.28-2.07-5.32-.09-3.82.1-7.65-.12-11.46-.24-4.14-1.67-5.57-5.75-5.83a69.87 69.87 0 0 0-8.92 0c-4.09.26-5.51 1.69-5.75 5.83-.23 3.81 0 7.64-.12 11.46 0 2-.29 4-2.07 5.32-.52.48-1 1.22-1.62 1.35a70.79 70.79 0 0 1-21.6.17c-2.15-.26-2.53-2.44-2.67-4.35-.32-4.26 0-8.53-.23-12.78-.22-5.2-1.85-6.83-7-7-4.26-.17-8.52 0-12.78-.2-3.1-.17-4.62-1.69-4.78-4.79-.22-4 0-8-.21-11.93-.23-5.18-1.86-6.8-7-7-3.12-.14-6.25 0-9.38-.11-2-.07-4-.28-5.36-2.05a5.39 5.39 0 0 1-2-4.1c-.09-1.71-.14-3.41-.14-5.12V145.58c0-3.16-.87-6.66 2.07-9.22 1.37-1.78 3.35-2 5.37-2 3.14-.11 6.27 0 9.4-.11 5.22-.22 6.91-1.8 7-7 .18-10.54 0-21.07.1-31.61 0-2.78-.52-5.79 2.08-7.93 1.47-1.93 3.6-2 5.74-2.08 3.68-.1 7.36.13 11-.13 4-.29 5.54-1.78 5.82-5.83.26-3.66 0-7.34.14-11 .15-2.2.21-4.33 2.21-5.8ZM469.14 404.07h-24.8l-.71-.47a5.84 5.84 0 0 1-1.28-3.92c-.19-5.76-.23-11.51 0-17.26.07-1.4.18-2.84 1.39-3.84 7.57-2.59 15.3-1.31 23-1 1 0 1.66 1 2.37 1.65Z'/%3E%3Cpath class='cls-1' d='M469.14 379.27h-24.8c-1.66-.8-1.87-2.36-1.95-3.92-.26-5.33-.25-10.66 0-16a5.23 5.23 0 0 1 1.95-4h24.8Z'/%3E%3Cpath d='M469.14 330.53h-24.36c-.65-3.68-.88-58.4-.29-72.69h24.65Z'/%3E%3Cpath class='cls-1' d='M55.21 136.41v170.18H31.72a2.76 2.76 0 0 1-.3-.29.64.64 0 0 1-.15-.36V136.41Z'/%3E%3Cpath d='M55.21 306.59H78.7a1.67 1.67 0 0 1 .31.28.73.73 0 0 1 .14.36v23.15h24.21a4.48 4.48 0 0 1 .45.45.8.8 0 0 1 .14.36v24.14h24v23.94H79.16v-23.94H55.21Z' fill='%23a1a1a1'/%3E%3Cpath class='cls-1' d='M420.4 428v24.8h-195V428c.7-1.53 2.11-1.78 3.55-1.94a48.57 48.57 0 0 1 5.12-.17h177.66c2.95.11 6.36-.98 8.67 2.11ZM152.71 355.33h23.49a1.72 1.72 0 0 1 .31.29.7.7 0 0 1 .14.36v23.29h24.8c2 1.24 2 3.31 2 5.26q.24 19.08 0 38.16c0 2-.25 4-2 5.33h-24.8v-23.5a1.7 1.7 0 0 0-.3-.3.62.62 0 0 0-.36-.14h-23.28Z'/%3E%3Cpath class='cls-1' d='M127.91 355.33V331a1.64 1.64 0 0 1 .29-.3.62.62 0 0 1 .36-.14h24.15v24.8Z'/%3E%3Cpath class='cls-2' d='M201.46 428v-48.73c1.48-1.95 3.64-2 5.79-2 6-.09 11.95-.17 17.92.12 7-.27 14-.31 20.93-.08 5.06.17 5.88 1.07 6.13 6.13.21 4-.06 8 .17 12 .27 4.69 1.92 6.25 6.65 6.56 11.72.77 13-.4 13-12.27 0-12.46 0-12.47 12.37-12.48h30.76c2.41 0 4.86-.13 7.15.88a3.53 3.53 0 0 1 1.27.77c2.32 4.12 1.32 8.63 1.39 13 .15 9.66.55 10.16 10.16 10.16h.85c7.68 0 8.7-1 8.75-8.55v-8.54a11.49 11.49 0 0 1 1.24-5.78 3 3 0 0 1 1.23-1 13.24 13.24 0 0 1 5.42-.92c14.31 0 28.63-.21 42.94.11 6.25-.24 12.51-.16 18.76-.12a14.32 14.32 0 0 1 6.23 1.14c1.93 1.13 1.76 3.1 1.84 4.9.2 4 0 7.93.14 11.88.2 5 1.73 6.58 6.68 6.8 3.26.15 6.51 0 9.77.1 2 .07 4 .29 5.33 2.06V428H201.46Z'/%3E%3Cpath class='cls-1' d='M79.16 87.67v48.74H55.21V87.67ZM104 62.87v24.8H79.16v-24.8ZM444.34 136.41H420.4v-24.8h23.94ZM395.59 87.67h-23.94v-24.8h23.94ZM420.4 111.61h-24.81V87.67h24.81Z'/%3E%3Cpath d='M322.9 379.27h-48.27a2.07 2.07 0 0 0-.31.27.68.68 0 0 0-.16.36v24h-23.67c.06.06-.06 0-.14-.14a.7.7 0 0 1-.14-.36v-24.15H225.4c-.46-.52-1.24-.92-1.33-1.59-.92-7.32-1.93-14.66.63-21.89l.7-.46h72.7c4-3.06 20.75-3.06 24.8 0 3.1 4.03 3.1 20.08 0 23.96ZM274.15 257.84H225.4V209.1c1.37-1.8 3.35-2 5.37-2q19-.19 38 0c2 0 4 .24 5.37 2 1.8 1.36 2 3.34 2 5.37q.19 19 0 38c.03 2.03-.14 4.01-1.99 5.37ZM395.59 257.84h-48.74V209.1c1.36-1.8 3.34-2 5.36-2q19-.19 38 0c2 0 4 .24 5.37 2 1.81 1.36 2 3.34 2 5.37q.21 19 0 38c.03 2.03-.18 4.01-1.99 5.37Z'/%3E%3Cpath class='cls-1' d='M395.59 257.84V209.1H420c.64 3.58.85 35.66.29 48.74Z'/%3E%3Cpath d='M444.34 404.07H420.4v-24.8c-3-4-3-19.92 0-23.94h23.94v48.74ZM395.59 379.27h-48.74c-.36-.45 0 .24-.35-.23-2.73-3.92-2.49-20 .35-23.71h24.8c4-3 19.93-3 23.94 0 3.04 4.02 3.04 19.93 0 23.94Z'/%3E%3Cpath class='cls-1' d='M274.15 209.1H225.4v-23.5c3.58-.64 35.65-.85 48.75-.3ZM395.59 209.1h-48.74v-23.5c3.58-.64 35.65-.85 48.74-.3ZM274.15 257.84V209.1h23.5c.64 3.58.85 35.65.3 48.74ZM322.9 355.33h-24.8V331a1.64 1.64 0 0 1 .29-.3.62.62 0 0 1 .36-.14h24.15ZM395.59 355.33h-23.94V331a1.64 1.64 0 0 1 .29-.3.62.62 0 0 1 .36-.14h23.29Z'/%3E%3Cpath d='M201.46 355.33V331a1.64 1.64 0 0 1 .29-.3.62.62 0 0 1 .36-.14h23.29v24.8c-4.01 3-19.93 3-23.94-.03Z'/%3E%3Cpath class='cls-1' d='M127.78 136.53v23.73h-23.64v-23.73ZM346.85 355.33v23.94c-4 3-19.93 3-24 0v-23.94ZM152.83 111.49V87.76h23.64v23.73Z'/%3E%3Cpath d='M322.9 379.27h24v24.35a2.07 2.07 0 0 1-.29.3.67.67 0 0 1-.37.15H322.9Z'/%3E%3Cpath class='cls-1' d='M127.79 136.27V111.7h24.91v24.57ZM201.45 379.25v-23.91h23.94v23.91ZM395.57 379.25v-23.91h24.86v23.91Z'/%3E%3Cpath class='cls-4' d='M469.17 404.08v-73.61h23.92v73.61ZM469.17 257.76v-72.61h23.92v72.61Z'/%3E%3C/svg%3E%0A", + "reference": null, + "reference_hash": null, + "decimals": 8 + }, + "f5cfbc74057c610c8ef151a439252680ac68c6dc.factory.bridge.near": { + "spec": "ft-1.0.0", + "name": "Octopus Network Token", + "symbol": "OCT", + "icon": "data:image/svg+xml,%3Csvg version='1.1' id='O' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 113.39 113.39' style='enable-background:new 0 0 113.39 113.39;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23014299;%7D .st1%7Bfill:%23FFFFFF;%7D %3C/style%3E%3Ccircle class='st0' cx='56.69' cy='56.69' r='56.69'/%3E%3Cg%3E%3Cpath class='st1' d='M44.25,59.41c-1.43,0-2.59,1.16-2.59,2.59v20.28c0,1.43,1.16,2.59,2.59,2.59c1.43,0,2.59-1.16,2.59-2.59V62 C46.84,60.57,45.68,59.41,44.25,59.41z'/%3E%3Cpath class='st1' d='M56.69,59.41c-1.45,0-2.62,1.17-2.62,2.62v26.47c0,1.45,1.17,2.62,2.62,2.62s2.62-1.17,2.62-2.62V62.02 C59.31,60.58,58.14,59.41,56.69,59.41z'/%3E%3Cpath class='st1' d='M79.26,78.87c-0.33,0.15-0.64,0.28-0.95,0.38c0,0-0.01,0-0.01,0c-0.59,0.19-1.13,0.29-1.63,0.31h-0.06 c-1,0.03-1.84-0.27-2.59-0.75c-0.49-0.32-0.91-0.73-1.25-1.23c-0.3-0.43-0.53-0.93-0.71-1.51c0-0.01-0.01-0.02-0.01-0.03 c-0.22-0.74-0.34-1.61-0.34-2.59V62.02c0-1.45-1.17-2.62-2.62-2.62c-1.45,0-2.62,1.17-2.62,2.62v11.43c0,4.5,1.64,8.03,4.63,9.96 c1.5,0.97,3.21,1.45,5.04,1.45c1.68,0,3.45-0.41,5.25-1.22c1.32-0.59,1.9-2.14,1.31-3.46C82.13,78.86,80.57,78.27,79.26,78.87z'/%3E%3Cpath class='st1' d='M68.33,45.9c0-2.15-1.75-3.9-3.9-3.9c-2.15,0-3.9,1.75-3.9,3.9s1.75,3.9,3.9,3.9 C66.58,49.8,68.33,48.05,68.33,45.9z'/%3E%3Cpath class='st1' d='M48.96,41.99c-2.15,0-3.9,1.75-3.9,3.9s1.75,3.9,3.9,3.9s3.9-1.75,3.9-3.9S51.11,41.99,48.96,41.99z'/%3E%3Cpath class='st1' d='M56.69,22.28c-15.17,0-27.52,12.34-27.52,27.52v15.09c0,1.46,1.18,2.64,2.64,2.64s2.64-1.18,2.64-2.64V49.8 c0-12.26,9.98-22.24,22.24-22.24c12.26,0,22.24,9.98,22.24,22.24v15.09c0,1.46,1.18,2.64,2.64,2.64s2.64-1.18,2.64-2.64V49.8 C84.21,34.62,71.87,22.28,56.69,22.28z'/%3E%3C/g%3E%3C/svg%3E", + "reference": "", + "reference_hash": "", + "decimals": 18 + }, + "damn.tkn.near": { + "spec": "ft-1.0.0", + "name": "DAMN", + "symbol": "DAMN", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "frigg.tkn.near": { + "spec": "ft-1.0.0", + "name": "frigg", + "symbol": "frigg", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "ndn.electrik.near": { + "spec": "ft-1.0.0", + "name": "ELECTRIK", + "symbol": "ELECTRIK", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 2 + }, + "d3g3n.tkn.near": { + "spec": "ft-1.0.0", + "name": "DEGENERATE PONZI SCAM SECOND DOG COIN", + "symbol": "D3G3N", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 18 + }, + "far.tkn.near": { + "spec": "ft-1.0.0", + "name": "FAR", + "symbol": "FAR", + "icon": "", + "reference": null, + "reference_hash": null, + "decimals": 8 + } +} \ No newline at end of file diff --git a/src/chains/polygon/polygon.ts b/src/chains/polygon/polygon.ts new file mode 100644 index 0000000000..c971b79196 --- /dev/null +++ b/src/chains/polygon/polygon.ts @@ -0,0 +1,90 @@ +import abi from '../../services/ethereum.abi.json'; +import { logger } from '../../services/logger'; +import { Contract, Transaction, Wallet } from 'ethers'; +import { EthereumBase } from '../../services/ethereum-base'; +import { getEthereumConfig as getPolygonConfig } from '../ethereum/ethereum.config'; +import { Provider } from '@ethersproject/abstract-provider'; +import { QuickswapConfig } from '../../connectors/quickswap/quickswap.config'; +import { UniswapConfig } from '../../connectors/uniswap/uniswap.config'; +import { Ethereumish } from '../../services/common-interfaces'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export class Polygon extends EthereumBase implements Ethereumish { + private static _instances: { [name: string]: Polygon }; + private _gasPrice: number; + private _nativeTokenSymbol: string; + private _chain: string; + + private constructor(network: string) { + const config = getPolygonConfig('polygon', network); + super( + 'polygon', + config.network.chainID, + config.network.nodeURL, + config.network.tokenListSource, + config.network.tokenListType, + config.manualGasPrice, + config.gasLimitTransaction, + ConfigManagerV2.getInstance().get('database.nonceDbPath'), + ConfigManagerV2.getInstance().get('database.transactionDbPath') + ); + this._chain = config.network.name; + this._nativeTokenSymbol = config.nativeCurrencySymbol; + this._gasPrice = config.manualGasPrice; + } + + public static getInstance(network: string): Polygon { + if (Polygon._instances === undefined) { + Polygon._instances = {}; + } + if (!(network in Polygon._instances)) { + Polygon._instances[network] = new Polygon(network); + } + + return Polygon._instances[network]; + } + + public static getConnectedInstances(): { [name: string]: Polygon } { + return Polygon._instances; + } + + public get gasPrice(): number { + return this._gasPrice; + } + + public get nativeTokenSymbol(): string { + return this._nativeTokenSymbol; + } + + public get chain(): string { + return this._chain; + } + + getContract(tokenAddress: string, signerOrProvider?: Wallet | Provider) { + return new Contract(tokenAddress, abi.ERC20Abi, signerOrProvider); + } + + getSpender(reqSpender: string): string { + let spender: string; + if (reqSpender === 'uniswap') { + spender = UniswapConfig.config.uniswapV3SmartOrderRouterAddress( + this._chain + ); + } else if (reqSpender === 'uniswapLP') { + spender = UniswapConfig.config.uniswapV3NftManagerAddress(this._chain); + } else if (reqSpender === 'quickswap') { + spender = QuickswapConfig.config.routerAddress(this._chain); + } else { + spender = reqSpender; + } + return spender; + } + + // cancel transaction + async cancelTx(wallet: Wallet, nonce: number): Promise { + logger.info( + 'Canceling any existing transaction(s) with nonce number ' + nonce + '.' + ); + return super.cancelTxWithGasPrice(wallet, nonce, this._gasPrice * 2); + } +} diff --git a/src/chains/polygon/polygon.validators.ts b/src/chains/polygon/polygon.validators.ts new file mode 100644 index 0000000000..cdd6ad9597 --- /dev/null +++ b/src/chains/polygon/polygon.validators.ts @@ -0,0 +1,42 @@ +import { + mkRequestValidator, + mkValidator, + RequestValidator, + Validator, + validateAmount, + validateToken, + validateTokenSymbols, +} from '../../services/validators'; +import { + isAddress, + validateNonce, + validateAddress, +} from '../ethereum/ethereum.validators'; + +export const invalidSpenderError: string = + 'The spender param is not a valid Polygon address (0x followed by 40 hexidecimal characters).'; + +// given a request, look for a key called spender that is 'uniswap', 'sushi' or an Ethereum address +export const validateSpender: Validator = mkValidator( + 'spender', + invalidSpenderError, + (val) => + typeof val === 'string' && + (val === 'uniswap' || + val === 'uniswapLP' || + val === 'sushi' || + val === 'quickswap' || + isAddress(val)) +); + +export const validatePolygonApproveRequest: RequestValidator = + mkRequestValidator([ + validateAddress, + validateSpender, + validateToken, + validateAmount, + validateNonce, + ]); + +export const validatePolygonAllowancesRequest: RequestValidator = + mkRequestValidator([validateAddress, validateSpender, validateTokenSymbols]); diff --git a/src/chains/polygon/polygon_tokens_mainnet.json b/src/chains/polygon/polygon_tokens_mainnet.json new file mode 100644 index 0000000000..bccb614261 --- /dev/null +++ b/src/chains/polygon/polygon_tokens_mainnet.json @@ -0,0 +1,25880 @@ +{ + "name": "Polygon Tokens", + "version": { + "major": 3, + "minor": 0, + "patch": 0 + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/matic.svg", + "keywords": [ + "polygon", + "default", + "tokens" + ], + "tags": { + "stablecoin": { + "name": "Stablecoin", + "description": "Tokens that are fixed to an external asset, e.g. the US dollar" + }, + "swapable": { + "name": "Swapable", + "description": "Tokens are eligible for swaps" + }, + "erc20": { + "name": "erc20", + "description": "Tokens are of ERC20 token type" + }, + "pos": { + "name": "PoS", + "description": "PoS tokens" + }, + "plasma": { + "name": "Plasma", + "description": "Plasma tokens" + }, + "metaTx": { + "name": "MetaTx", + "description": "Tokens are eligible for meta transactions" + }, + "customWithdrawEventSig": { + "name": "Custom Withdraw Event Signature", + "description": "The token has a custom withdraw event signature" + }, + "noDeposit": { + "name": "Deposit Disabled", + "description": "Tokens are not eligible for deposits" + }, + "noWithdraw": { + "name": "Withdraw Disabled", + "description": "Tokens are not eligible for withdraws" + } + }, + "timestamp": "2022-11-29T05:57:13.384Z", + "tokens": [ + { + "chainId": 137, + "name": "Ether - PoS", + "symbol": "ETH", + "decimals": 18, + "address": "0x7ceb23fd6bc0add59e62ac25578270cff1b9f619", + "logoURI": "https://wallet-asset.matic.network/img/tokens/eth.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee" + } + }, + { + "chainId": 137, + "name": "Ether - Plasma", + "symbol": "ETH", + "decimals": 18, + "address": "0x8cc8538d60901d19692f5ba22684732bc28f54a3", + "logoURI": "https://wallet-asset.matic.network/img/tokens/eth.svg", + "tags": [ + "plasma", + "erc20", + "noDeposit" + ], + "extensions": { + "rootAddress": "0xa45b966996374e9e65ab991c6fe4bfce3a56dde8" + } + }, + { + "chainId": 137, + "name": "Matic Token", + "symbol": "MATIC", + "decimals": 18, + "address": "0x0000000000000000000000000000000000001010", + "logoURI": "https://wallet-asset.matic.network/img/tokens/matic.svg", + "tags": [ + "plasma", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7d1afa7b718fb893db30a3abc0cfc608aacfebb0" + } + }, + { + "chainId": 137, + "name": "Wrapped Matic", + "decimals": 18, + "address": "0x0d500B1d8E8eF31E21C99d1Db9A6444d3ADf1270", + "symbol": "WMATIC" + }, + { + "chainId": 137, + "name": "USD Coin", + "symbol": "USDC", + "decimals": 6, + "address": "0x2791bca1f2de4661ed88a30c99a7a9449aa84174", + "logoURI": "https://wallet-asset.matic.network/img/tokens/usdc.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx", + "stablecoin" + ], + "extensions": { + "rootAddress": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48" + } + }, + { + "chainId": 137, + "name": "Tether USD", + "symbol": "USDT", + "decimals": 6, + "address": "0xc2132d05d31c914a87c6611c10748aeb04b58e8f", + "logoURI": "https://wallet-asset.matic.network/img/tokens/usdt.svg", + "tags": [ + "pos", + "stablecoin", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0xdac17f958d2ee523a2206206994597c13d831ec7" + } + }, + { + "chainId": 137, + "name": "Dai - PoS", + "symbol": "DAI", + "decimals": 18, + "address": "0x8f3cf7ad23cd3cadbd9735aff958023239c6a063", + "logoURI": "https://wallet-asset.matic.network/img/tokens/dai.svg", + "tags": [ + "pos", + "stablecoin", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x6b175474e89094c44da98b954eedeac495271d0f" + } + }, + { + "chainId": 137, + "name": "Dai - Plasma", + "symbol": "DAI", + "decimals": 18, + "address": "0x84000b263080bc37d1dd73a29d92794a6cf1564e", + "logoURI": "https://wallet-asset.matic.network/img/tokens/dai.svg", + "tags": [ + "plasma", + "stablecoin", + "erc20", + "noDeposit" + ], + "extensions": { + "rootAddress": "0x6b175474e89094c44da98b954eedeac495271d0f" + } + }, + { + "chainId": 137, + "name": "Aave", + "symbol": "AAVE", + "decimals": 18, + "address": "0xd6df932a45c0f255f85145f286ea0b292b21c90b", + "logoURI": "https://wallet-asset.matic.network/img/tokens/aave.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x7fc66500c84a76ad7e9c93437bfc5ac33e2ddae9" + } + }, + { + "chainId": 137, + "name": "ChainLink Token", + "symbol": "LINK", + "decimals": 18, + "address": "0x53e0bca35ec356bd5dddfebbd1fc0fd03fabad39", + "logoURI": "https://wallet-asset.matic.network/img/tokens/link.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x514910771AF9Ca656af840dff83E8264EcF986CA" + } + }, + { + "chainId": 137, + "name": "Wrapped BTC", + "symbol": "WBTC", + "decimals": 8, + "address": "0x1bfd67037b42cf73acf2047067bd4f2c47d9bfd6", + "logoURI": "https://wallet-asset.matic.network/img/tokens/wbtc.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x2260fac5e5542a773aa44fbcfedf7c193bc2c599" + } + }, + { + "chainId": 137, + "name": "Uniswap", + "symbol": "UNI", + "decimals": 18, + "address": "0xb33eaad8d922b1083446dc23f610c2567fb5180f", + "logoURI": "https://wallet-asset.matic.network/img/tokens/uni.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x1f9840a85d5af5bf1d1762f925bdaddc4201f984" + } + }, + { + "chainId": 137, + "name": "SushiToken", + "symbol": "SUSHI", + "decimals": 18, + "address": "0x0b3f868e0be5597d5db7feb59e1cadbb0fdda50a", + "logoURI": "https://wallet-asset.matic.network/img/tokens/sushi.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6b3595068778dd592e39a122f4f5a5cf09c90fe2" + } + }, + { + "chainId": 137, + "name": "Quickswap", + "symbol": "QUICK", + "decimals": 18, + "address": "0x831753dd7087cac61ab5644b308642cc1c33dc13", + "logoURI": "https://wallet-asset.matic.network/img/tokens/quick.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6c28AeF8977c9B773996d0e8376d2EE379446F2f" + } + }, + { + "chainId": 137, + "name": "QuickSwap - new", + "symbol": "QUICK", + "decimals": 18, + "address": "0xB5C064F955D8e7F38fE0460C556a72987494eE17", + "logoURI": "https://wallet-asset.matic.network/img/tokens/quick.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd2bA23dE8a19316A638dc1e7a9ADdA1d74233368" + } + }, + { + "chainId": 137, + "name": "Aavegotchi GHST Token", + "symbol": "GHST", + "decimals": 18, + "address": "0x385eeac5cb85a38a9a07a70c73e0a3271cfb54a7", + "logoURI": "https://polygonscan.com/token/images/aavegotchighst_32.png", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x3F382DbD960E3a9bbCeaE22651E88158d2791550" + } + }, + { + "chainId": 137, + "name": "Telcoin", + "symbol": "TEL", + "decimals": 2, + "address": "0xdf7837de1f2fa4631d716cf2502f8b230f1dcc32", + "logoURI": "https://wallet-asset.matic.network/img/tokens/tel.svg", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0x467bccd9d29f223bce8043b84e8c8b282827790f" + } + }, + { + "chainId": 137, + "name": "Balancer", + "symbol": "BAL", + "decimals": 18, + "address": "0x9a71012b13ca4d3d0cdc72a177df3ef03b0e76a3", + "logoURI": "https://wallet-asset.matic.network/img/tokens/bal.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xba100000625a3754423978a60c9317c58a424e3d" + } + }, + { + "chainId": 137, + "name": "EthermonToken", + "symbol": "EMON", + "decimals": 18, + "address": "0xd6a5ab46ead26f49b03bbb1f9eb1ad5c1767974a", + "logoURI": "https://polygonscan.com/token/images/ethermontoken2_32.png", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0xd6a5ab46ead26f49b03bbb1f9eb1ad5c1767974a" + } + }, + { + "chainId": 137, + "name": "Furucombo", + "symbol": "COMBO", + "decimals": 18, + "address": "0x6ddb31002abc64e1479fc439692f7ea061e78165", + "logoURI": "https://polygonscan.com/token/images/furucombo_32.png", + "tags": [ + "pos", + "erc20", + "swapable", + "metaTx" + ], + "extensions": { + "rootAddress": "0xffffffff2ba8f66d4e51811c5190992176930278" + } + }, + { + "chainId": 137, + "name": "Binance USD", + "symbol": "BUSD", + "decimals": 18, + "address": "0xdab529f40e671a1d4bf91361c21bf9f0c9712ab7", + "logoURI": "https://wallet-asset.matic.network/img/tokens/busd.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4fabb145d64652a948d72533023f6e7a623c7c53" + } + }, + { + "chainId": 137, + "name": "Mintopoly Money", + "symbol": "MM", + "decimals": 8, + "address": "0xf6a09deadf5a10aa7822d95e3228b2315de8f6fa", + "logoURI": "https://etherscan.io/token/images/mintopolymoney_32.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf6a09deadf5a10aa7822d95e3228b2315de8f6fa" + } + }, + { + "chainId": 137, + "name": "Revv", + "symbol": "REVV", + "decimals": 18, + "address": "0x70c006878a5a50ed185ac4c87d837633923de296", + "logoURI": "https://etherscan.io/token/images/revv_32.png", + "tags": [ + "pos", + "erc20", + "customWithdrawEventSig", + "swapable" + ], + "extensions": { + "rootAddress": "0x557b933a7c2c45672b610f8954a3deb39a51a8ca", + "withdrawEventSig": "0x7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5" + } + }, + { + "chainId": 137, + "name": "Decentral Games ICE", + "symbol": "ICE", + "decimals": 18, + "address": "0xc6C855AD634dCDAd23e64DA71Ba85b8C51E5aD7c", + "logoURI": "https://wallet-asset.matic.network/img/tokens/ice.svg", + "tags": [ + "pos", + "erc20", + "noDeposit", + "noWithdraw", + "swapable" + ], + "extensions": { + "rootAddress": "0x0000000000000000000000000000000000000000" + } + }, + { + "chainId": 137, + "name": "GAME Credits", + "symbol": "GAME", + "decimals": 18, + "address": "0x8d1566569d5b695d44a9a234540f68D393cDC40D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "logoURI": "https://svgshare.com/i/fJw.svg", + "extensions": { + "rootAddress": "0x63f88A2298a5c4AEE3c216Aa6D926B184a4b2437" + } + }, + { + "chainId": 137, + "name": "CoinPoker Chips", + "symbol": "CHP", + "decimals": 18, + "address": "0x59B5654a17Ac44F3068b3882F298881433bB07Ef", + "logoURI": "https://coinpoker.com/assets/img/logox2.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0a6E18fB2842855C3AF925310B0F50a4BfA17909" + } + }, + { + "chainId": 137, + "name": "Dreamr Platform Token", + "symbol": "DMR", + "decimals": 18, + "address": "0x955ce23f20217a6aa205620b40ede4c9e83d325f", + "logoURI": "https://gateway.pinata.cloud/ipfs/QmepiCxpZqks5sjB6r55gErgCXqhGdCsbXYpuauG5yxCyB", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf74941046389c78f12fe44784c0ec9ca7ceb7dc2" + } + }, + { + "chainId": 137, + "name": "Yup", + "symbol": "YUP", + "decimals": 18, + "address": "0x086373fad3447F7F86252fb59d56107e9E0FaaFa", + "logoURI": "https://i.imgur.com/QC2UG1G.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x69bbc3f8787d573f1bbdd0a5f40c7ba0aee9bcc9" + } + }, + { + "chainId": 137, + "name": "Paint", + "symbol": "PAINT", + "decimals": 18, + "address": "0x7c28F627eA3aEc8B882b51eb1935f66e5b875714", + "logoURI": "https://gateway.pinata.cloud/ipfs/QmSqt6RAgNYWq3kJRhEoLquY2xcZ7QXAJGovaeaxmZYCVJ", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4C6eC08CF3fc987c6C4BEB03184D335A2dFc4042" + } + }, + { + "chainId": 137, + "name": "Swash Token", + "symbol": "SWASH", + "decimals": 18, + "address": "0xbA3CB8329D442E6F9Eb70fafe1E214251df3D275", + "logoURI": "https://github.com/swashapp/token/blob/main/logo/Logo.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xA130E3a33a4d84b04c3918c4E5762223Ae252F80" + } + }, + { + "chainId": 137, + "name": "Angel", + "symbol": "ANGEL", + "decimals": 18, + "address": "0xa78da5d9f0c488c51b9712434f0498cbb7bff23d", + "logoURI": "https://i.imgur.com/I8S1GPZ.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x14d86EaeB7F669a6b84D51E1ac14b3F2723fA08D" + } + }, + { + "chainId": 137, + "name": "ExSports", + "symbol": "EXS", + "decimals": 18, + "address": "0x11928CFCbC0398b9206C6D57ff7D8201555D6773", + "logoURI": "https://img.ex-sports.io/imgs/icons/exs.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7331355e2DaD3b55f9ce0fd460D082558952099e" + } + }, + { + "chainId": 137, + "name": "Royale (PoS)", + "symbol": "ROYA", + "decimals": 18, + "address": "0x0bD820aD2d7Ab7305b5C9538ba824C9b9bEb0561", + "logoURI": "https://assets.coingecko.com/coins/images/13602/small/roya.png?1636031771", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7eaf9c89037e4814dc0d9952ac7f888c784548db" + } + }, + { + "chainId": 137, + "name": "PRUF", + "symbol": "PRUF", + "decimals": 18, + "address": "0xAdf72D32E511eE00c6E0FF5D62Cd5C7C40A6aDEA", + "logoURI": "https://pruf.io/assets/images/prufcircle-1200x1200.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa49811140e1d6f653dec28037be0924c811c4538" + } + }, + { + "chainId": 137, + "name": "Arch Ethereum Web3", + "symbol": "WEB3", + "decimals": 18, + "address": "0xBcD2C5C78000504EFBC1cE6489dfcaC71835406A", + "logoURI": "https://arch-finance-basket-logos.s3.amazonaws.com/ETHWEB3.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe8e8486228753E01Dbc222dA262Aa706Bd67e601" + } + }, + { + "chainId": 137, + "name": "Unlock Discount Token", + "symbol": "UDT", + "decimals": 18, + "address": "0xf7e78d9c4c74df889a83c8c8d6d05bf70ff75876", + "logoURI": "https://github.com/unlock-protocol/unlock/blob/master/design/brand/1808-Unlock-Identity_Unlock-LogoMark-Circle.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x90de74265a416e1393a450752175aed98fe11517" + } + }, + { + "chainId": 137, + "name": "Altafin", + "symbol": "AFN", + "decimals": 18, + "address": "0xB4A055786EE8B9c9a09156bb185EBA7B91540eE5", + "logoURI": "https://images.ctfassets.net/dj2ij87ekk1y/6QLADorHyGFcr804X0spbG/a11f3a582c9f6b40bc7b010d481c9242/AltaFin-Logo-Square-700x.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE46F290Cd59195a83e757891430d8D517d16b334" + } + }, + { + "chainId": 137, + "name": "UCT Cash", + "symbol": "UCTC", + "decimals": 18, + "address": "0xD4b42287F1EE04aF246aD792153C39D62733f826", + "logoURI": "https://www.uct-token.org/wp-content/uploads/2021/06/UCT-token-transp-500-500.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2707ab358B5383D087FE4736Da36c1C70179e3BD" + } + }, + { + "chainId": 137, + "name": "UCT Token", + "symbol": "UCT", + "decimals": 18, + "address": "0xfd5962484BE2c3574D70131BF5D452CcC7C69F67", + "logoURI": "https://www.uct-token.org/wp-content/uploads/2021/06/UCT-token-transp-500-500.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xCC7dCc3F649Cb3932857d4edC6268e0eF4960995" + } + }, + { + "chainId": 137, + "name": "IQ", + "symbol": "IQ", + "decimals": 18, + "address": "0xB9638272aD6998708de56BBC0A290a1dE534a578", + "logoURI": "https://www.dropbox.com/sh/g97lq77b9mv9lfz/AABRnKWx9aiv6x8KShkIgDgla/Brain%20Logo%20Design-03.png?dl=0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x579CEa1889991f68aCc35Ff5c3dd0621fF29b0C9" + } + }, + { + "chainId": 137, + "name": "Polytrade (PoS)", + "symbol": "TRADE", + "decimals": 18, + "address": "0x692AC1e363ae34b6B489148152b12e2785a3d8d6", + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/10465.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6e5970dbd6fc7eb1f29c6d2edf2bc4c36124c0c1" + } + }, + { + "chainId": 137, + "name": "Fleato coin", + "symbol": "FLEATO", + "decimals": 18, + "address": "0x6804b07d883d0169c05233332ccf17aa956424c5", + "logoURI": "https://www.fleato.com/images/flea120.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xAF4dE4076095A20A37E4E885B255C58f9917366e" + } + }, + { + "chainId": 137, + "name": "Efinity Token", + "symbol": "EFI", + "decimals": 18, + "address": "0x891254dbb6112cf938d16c1880540b8469df6c0e", + "logoURI": "https://cdn.efinity.io/static/logo.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x656c00e1bcd96f256f224ad9112ff426ef053733" + } + }, + { + "chainId": 137, + "name": "Pillar", + "symbol": "PLR", + "decimals": 18, + "address": "0xa6b37fC85d870711C56FbcB8afe2f8dB049AE774", + "logoURI": "https://etherscan.io/token/images/pillar_32.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe3818504c1B32bF1557b16C238B2E01Fd3149C17" + } + }, + { + "chainId": 137, + "name": "Equalizer", + "symbol": "EQZ", + "decimals": 18, + "address": "0xEAf631ac57F3CDDDd261770dD47F85066131a156", + "logoURI": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x1Da87b114f35E1DC91F72bF57fc07A768Ad40Bb0/logo.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1Da87b114f35E1DC91F72bF57fc07A768Ad40Bb0" + } + }, + { + "chainId": 137, + "name": "GoBlank Token", + "symbol": "BLANK", + "decimals": 18, + "address": "0xf4C83080E80AE530d6f8180572cBbf1Ac9D5d435", + "logoURI": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x41A3Dba3D677E573636BA691a70ff2D606c29666/logo.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x41A3Dba3D677E573636BA691a70ff2D606c29666" + } + }, + { + "chainId": 137, + "name": "Cryptopia Token", + "symbol": "CRT", + "decimals": 18, + "address": "0x7348565F0A5077252D310392C3CeCD8dB87a7704", + "logoURI": "https://cryptopia.com/images/icons/icon_CRT.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xABdD22dFE5Db2be20262050523470B650E91F246" + } + }, + { + "chainId": 137, + "name": "BTU Protocol", + "symbol": "BTU", + "decimals": 18, + "address": "0xfdc26cda2d2440d0e83cd1dee8e8be48405806dc", + "logoURI": "https://btu-protocol.com/images/log-BTU-256w.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb683D83a532e2Cb7DFa5275eED3698436371cc9f" + } + }, + { + "chainId": 137, + "name": "Trips", + "symbol": "TRIPS", + "decimals": 18, + "address": "0x77F0F7d657f362C4b703417B800B83B989a288a2", + "logoURI": "https://gateway.pinata.cloud/ipfs/QmVxZCAvxab8bUhaScwqw6NWABmqz4jmjJ3qnYUbdKweEf/trips_T_logo256x256.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1350fbe8ce27762ec19134bf8fc405a427fe9bf1" + } + }, + { + "chainId": 137, + "name": "0xMonero", + "symbol": "0xMR", + "decimals": 18, + "address": "0x52ede6bba83b7b4ba1d738df0df713d6a2036b71", + "logoURI": "https://avatars.githubusercontent.com/u/65775032?v=4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x035df12e0f3ac6671126525f1015e47d79dfeddf" + } + }, + { + "chainId": 137, + "name": "Ispolink", + "symbol": "ISP", + "decimals": 18, + "address": "0x1e289178612f5b6d32f692e312dcf783c74b2162", + "logoURI": "https://raw.githubusercontent.com/mikyjo/crypto_assets/main/tokens/ispolink/ispolink_icon_white_400x400.jpg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc8807f0f5ba3fa45ffbdc66928d71c5289249014" + } + }, + { + "chainId": 137, + "name": "Gistcoin", + "symbol": "GIST", + "decimals": 18, + "address": "0xF6db73D0495Fe4648d494046cCbdc5625F2740F0", + "logoURI": "https://etherscan.io/token/images/gistcoin_32.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6cd775540cce9adb01872db9f794142f53595c71" + } + }, + { + "chainId": 137, + "name": "Orbs Token", + "symbol": "ORBS", + "decimals": 18, + "address": "0x614389EaAE0A6821DC49062D56BDA3d9d45Fa2ff", + "logoURI": "https://raw.githubusercontent.com/orbs-network/graphical-assets/main/orbs/ethereum/token/logo256.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xff56Cc6b1E6dEd347aA0B7676C85AB0B3D08B0FA" + } + }, + { + "chainId": 137, + "name": "InsurAce", + "symbol": "INSUR", + "decimals": 18, + "address": "0x8a0e8b4b0903929f47C3ea30973940D4a9702067", + "logoURI": "https://app.insurace.io/asset/token/insur.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x544c42fBB96B39B21DF61cf322b5EDC285EE7429" + } + }, + { + "chainId": 137, + "name": "MASQ", + "symbol": "MASQ", + "decimals": 18, + "address": "0xee9a352f6aac4af1a5b9f467f6a93e0ffbe9dd35", + "logoURI": "https://github.com/MASQ-Project/MASQ-contract/raw/master/MASQ%20Logo%20Blue%20Solo%20Transparent.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x06F3C323f0238c72BF35011071f2b5B7F43A054c" + } + }, + { + "chainId": 137, + "name": "Voltage", + "symbol": "VOLT", + "decimals": 18, + "address": "0xe8a05e85883f9663b18a38d7aa89853deaba56e3", + "logoURI": "https://assets.coingecko.com/coins/images/18515/small/volt.png?1632219924", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xffbf315f70e458e49229654dea4ce192d26f9b25" + } + }, + { + "chainId": 137, + "name": "Pinjour", + "symbol": "PIN", + "decimals": 18, + "address": "0x1d5278cbd93ff50260fddc93282e2e67ca3317c9", + "logoURI": "https://d26jz7p3kula4l.cloudfront.net/static/img/pinjour-192x192.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x76c9a9583bda3ac6440fc153c7ffd89f99823a2c" + } + }, + { + "chainId": 137, + "name": "Candle", + "symbol": "CNDL", + "decimals": 18, + "address": "0x5423063af146F5abF88Eb490486E6B53FA135eC9", + "logoURI": "https://i.ibb.co/86yLQRZ/candlelogo.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbc138bD20C98186CC0342C8e380953aF0cb48BA8" + } + }, + { + "chainId": 137, + "name": "Tower Token", + "symbol": "TOWER", + "decimals": 18, + "address": "0x2bC07124D8dAc638E290f401046Ad584546BC47b", + "logoURI": "https://crazydefenseheroes.com/static/media/logo-tower.2bca4bdd.svg", + "tags": [ + "pos", + "erc20", + "customWithdrawEventSig", + "swapable" + ], + "extensions": { + "rootAddress": "0x1C9922314ED1415c95b9FD453c3818fd41867d0B", + "withdrawEventSig": "0x7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5" + } + }, + { + "chainId": 137, + "name": "Meeds", + "symbol": "MEED", + "decimals": 18, + "address": "0x6aca77cf3bab0c4e8210a09b57b07854a995289a", + "logoURI": "https://github.com/Meeds-io/.github/raw/main/profile/meeds-256x256.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8503a7b00b4b52692cc6c14e5b96f142e30547b7" + } + }, + { + "chainId": 137, + "name": "inSure DeFi", + "symbol": "SURE", + "decimals": 18, + "address": "0xF88332547c680F755481Bf489D890426248BB275", + "logoURI": "https://insuretoken.net/images/logo-grey-circle.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcb86c6a22cb56b6cf40cafedb06ba0df188a416e" + } + }, + { + "chainId": 137, + "name": "Beverage Token", + "symbol": "DRINK", + "decimals": 18, + "address": "0x366a39a2f73de32df17cc9bdd027aa054f6ba9cb", + "logoURI": "https://raw.githubusercontent.com/Beverage-Finance/beverage-docs/main/assets/beverage-token-logos/beverage-200X200.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9257fb8fab616867cEe67C3289547403617B1938" + } + }, + { + "chainId": 137, + "name": "Wrapped CHI", + "symbol": "WCHI", + "decimals": 8, + "address": "0xE79feAAA457ad7899357E8E2065a3267aC9eE601", + "logoURI": "https://arweave.net/cLtOpcOcgshTnA3aWe8a1lKRG0baZHfWGsi1mq5Cgt4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6DC02164d75651758aC74435806093E421b64605" + } + }, + { + "chainId": 137, + "name": "Indorse", + "symbol": "IND", + "decimals": 18, + "address": "0x9611452965b63cFeA2C9774e5386AB6D4F0abf16", + "logoURI": "https://drive.google.com/file/d/1Wbw4t_hibR5zMBdrLysvhfJvSIe34q9N/view?usp=sharing", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf8e386EDa857484f5a12e4B5DAa9984E06E73705" + } + }, + { + "chainId": 137, + "name": "Germoney", + "symbol": "GER", + "decimals": 2, + "address": "0x03a68f78107d102d26353e5476733b067950bab6", + "logoURI": "https://www.germoney.cash/static/media/logo.7c3abfc4.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x844Af22fBEC4D1bb9C062F33D29e4Ad8d0EFc01D" + } + }, + { + "chainId": 137, + "name": "ScaleSwapToken", + "symbol": "SCA", + "decimals": 18, + "address": "0x11a819Beb0AA3327E39f52F90d65Cc9bCA499F33", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1FbD3dF007eB8A7477A1Eab2c63483dCc24EfFD6" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sca.svg" + }, + { + "chainId": 137, + "name": "Megaverse", + "symbol": "MEGA", + "decimals": 18, + "address": "0xD87958D9Cc146aBe382Ee20D1EF278321E61ADe9", + "logoURI": "https://i.imgur.com/1pDWnjT.jpeg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xCF9b27399447f92462Dad69491edbA304a063591" + } + }, + { + "chainId": 137, + "name": "RocketX", + "symbol": "RVF", + "decimals": 18, + "address": "0x2ce13e4199443fdfff531abb30c9b6594446bbc7", + "logoURI": "https://drive.google.com/file/d/106QzWJ-42p2FVsgZQ4pVCw_cTTAudU39/view?usp=sharing", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdc8af07a7861bedd104b8093ae3e9376fc8596d2" + } + }, + { + "chainId": 137, + "name": "Forest Knight", + "symbol": "KNIGHT", + "decimals": 18, + "address": "0x4455eF8B4B4A007a93DaA12DE63a47EEAC700D9D", + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/11324.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4455eF8B4B4A007a93DaA12DE63a47EEAC700D9D" + } + }, + { + "chainId": 137, + "name": "Lepasa", + "symbol": "LEPA", + "decimals": 18, + "address": "0xF9a4BBAa7fA1DD2352F1A47d6d3fcfF259A6D05F", + "logoURI": "https://www.lepasa.com/assets/img/logo_256.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbBa6C7c7d673c48d90069ad2e9d2fE587fcB6bc3" + } + }, + { + "chainId": 137, + "name": "Civilization", + "symbol": "CIV", + "decimals": 18, + "address": "0x42F6bdCfd82547e89F1069Bf375aa60e6c6c063d", + "logoURI": "https://app.civfund.org/CIV_logo_txt_192x192.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x37fE0f067FA808fFBDd12891C0858532CFE7361d" + } + }, + { + "chainId": 137, + "name": "Move", + "symbol": "MOVE", + "decimals": 18, + "address": "0x521CddC0CBa84F14c69C1E99249F781AA73Ee0BC", + "logoURI": "https://assets.coingecko.com/coins/images/13719/small/o0KIvs7T_400x400.jpg?1617672818", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3fa729b4548becbad4eab6ef18413470e6d5324c" + } + }, + { + "chainId": 137, + "name": "Stacker Ventures Token", + "symbol": "STACK", + "decimals": 18, + "address": "0xccBe9B810d6574701d324fD6DbE0A1b68f9d5bf7", + "logoURI": "https://assets.coingecko.com/coins/images/14218/small/stack.jpg?1615000614", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe0955f26515d22e347b17669993fcefcc73c3a0a" + } + }, + { + "chainId": 137, + "name": "TRAXX", + "symbol": "TRAXX", + "decimals": 18, + "address": "0xd43be54c1aedf7ee4099104f2dae4ea88b18a249", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd43be54c1aedf7ee4099104f2dae4ea88b18a249" + } + }, + { + "chainId": 137, + "name": "NOIIRE COIN", + "symbol": "NOIIRE", + "decimals": 18, + "address": "0x92a33f4017eca323f00424a36b3c52598035fc16", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xee93b9479e2fdd9bf58d7c11474ad347f5b1eb09" + } + }, + { + "chainId": 137, + "name": "VAIOT Token", + "symbol": "VAI", + "decimals": 18, + "address": "0x51738017dc69f23deb5db8de97685cf3b7001e79", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x51738017dc69f23deb5db8de97685cf3b7001e79" + } + }, + { + "chainId": 137, + "name": "AdBank", + "symbol": "ADB", + "decimals": 18, + "address": "0xb92d60d0ecbef38dee6a125181825567fccd9dc7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2baac9330cf9ac479d819195794d79ad0c7616e3" + } + }, + { + "chainId": 137, + "name": "SatoMotive Token", + "symbol": "SV2X", + "decimals": 18, + "address": "0x9b9026901999e612bc396bb285e8fbe3dcc7b78e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x37810173b70e86b8435f8c28590e8faceff59044" + } + }, + { + "chainId": 137, + "name": "Sprocket", + "symbol": "SPROCKET", + "decimals": 18, + "address": "0x0d98eae620491d8f6836a39ac45e54b286fdd2d7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa9364d93a4a6d8dc51781236ded2dc4325b668b8" + } + }, + { + "chainId": 137, + "name": "UniCandy", + "symbol": "UCD", + "decimals": 18, + "address": "0x546c825f0109353ab4315139e82674f0d86e39d8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb1db366890eeb8f28c2813c6a6084353e0b90713" + } + }, + { + "chainId": 137, + "name": "CLIK", + "symbol": "CLIK", + "decimals": 18, + "address": "0x76b0ef26d41d55201a7d8c3437c21caef9857149", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf273e3bc6acdf27c01b8b1c35d39c33b067153dd" + } + }, + { + "chainId": 137, + "name": "Lockable", + "symbol": "LC", + "decimals": 18, + "address": "0x41a7e62e231bad6026b82952c78fab6e61d96958", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x41a7e62e231bad6026b82952c78fab6e61d96958" + } + }, + { + "chainId": 137, + "name": "Forta", + "symbol": "FORT", + "decimals": 18, + "address": "0x9ff62d1fc52a907b6dcba8077c2ddca6e6a9d3e1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41545f8b9472d758bb669ed8eaeeecd7a9c4ec29" + } + }, + { + "chainId": 137, + "name": "MetaMEMO", + "symbol": "MEMO", + "decimals": 18, + "address": "0x2710ed3f5d44268dcb89f549050718aa237c8a47", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xeb8eec5a2dbf6e6f4cc542ad31cce706f8f80419" + } + }, + { + "chainId": 137, + "name": "InventoryClub Token", + "symbol": "VNT", + "decimals": 18, + "address": "0x2c63b97ec0976e76098371f4300e7fe89f087a02", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe912b8ba2513d7e29b7b2e5b14398dbf77503fb4" + } + }, + { + "chainId": 137, + "name": "Kevin", + "symbol": "KEVIN", + "decimals": 9, + "address": "0x9720d05952cd56893fc5982aaec4508d46a589cb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc9f1b23074849d5d6de462af57dae5d3309a1ecc" + } + }, + { + "chainId": 137, + "name": "Hedron", + "symbol": "HDRN", + "decimals": 9, + "address": "0x0a436cfe3190c141c5e910fc217e3b27d44042f3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3819f64f282bf135d62168c1e513280daf905e06" + } + }, + { + "chainId": 137, + "name": "CERE Network", + "symbol": "CERE", + "decimals": 10, + "address": "0x2da719db753dfa10a62e140f436e1d67f2ddb0d6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2da719db753dfa10a62e140f436e1d67f2ddb0d6" + } + }, + { + "chainId": 137, + "name": "InnovaMinex", + "symbol": "MINX", + "decimals": 6, + "address": "0x4bf6daa0f3b2f8b338836b29f17b9e7ff0e68b53", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xae353daeed8dcc7a9a12027f7e070c0a50b7b6a4" + } + }, + { + "chainId": 137, + "name": "THUG", + "symbol": "THUG", + "decimals": 18, + "address": "0xb22ecdfe16bef29ce48a63cde0add3e8b536d122", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb22ecdfe16bef29ce48a63cde0add3e8b536d122" + } + }, + { + "chainId": 137, + "name": "Coorest", + "symbol": "CRST", + "decimals": 18, + "address": "0x91f0484f9b65dc5187e414dae5ed37ea7a4b8af4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x776aaca47ee579ff63f6c00a921377eb21359e59" + } + }, + { + "chainId": 137, + "name": "OMI Token", + "symbol": "OMI", + "decimals": 18, + "address": "0x9cd42aed7d44ee801c827a8e5dcf41df534e9e82", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xed35af169af46a02ee13b9d79eb57d6d68c1749e" + } + }, + { + "chainId": 137, + "name": "Minato", + "symbol": "MNTO", + "decimals": 18, + "address": "0x4c9f66b2806538cf00ef596e09fb05bcb0d17dc8", + "logoURI": "https://minatodao.com/wp-content/uploads/2022/03/pcs-96x96.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x97a9bac06f90940bce9caec2b880ff17707519e4" + } + }, + { + "chainId": 137, + "name": "Lucky Races Sliver", + "symbol": "$SLIVER", + "decimals": 18, + "address": "0xa95b410743e8c2f7b64f1373d3ca2b3454864a94", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf5112170ec586385333fbfa15e4a7a4aa9f82cfc" + } + }, + { + "chainId": 137, + "name": "$ZKP Token", + "symbol": "$ZKP", + "decimals": 18, + "address": "0x9a06db14d639796b25a6cec6a1bf614fd98815ec", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x909e34d3f6124c324ac83dcca84b74398a6fa173" + } + }, + { + "chainId": 137, + "name": "Banana", + "symbol": "BANANA", + "decimals": 18, + "address": "0xbc91347e80886453f3f8bbd6d7ac07c122d87735", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x94e496474f1725f1c1824cb5bdb92d7691a4f03a" + } + }, + { + "chainId": 137, + "name": "MetaBillionaireUtilityCoin", + "symbol": "MBUC", + "decimals": 18, + "address": "0xecd3c4f21dceebc8f308af7c3a7f1a4265bb52e9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xecaf45a19565fff9d058257b326e52a253343f78" + } + }, + { + "chainId": 137, + "name": "Akiverse Governance", + "symbol": "AKV", + "decimals": 18, + "address": "0xf0af7795765273aebfd8a908460b728bdc3fc937", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x08c38d80b45e4c1e3a6bece6b49312e5fc30b0fb" + } + }, + { + "chainId": 137, + "name": "BRIX Token", + "symbol": "BRIX", + "decimals": 18, + "address": "0xabffedaf784dc40a4c1947f9d5ddb3afe2075353", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8f10eb64923bf30215e7944c416e891d30e742a1" + } + }, + { + "chainId": 137, + "name": "CRIPTORO COIN", + "symbol": "CTRO", + "decimals": 10, + "address": "0x7dc06244536fc5a86123034ee6d9204e436a3e91", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb3ab2b676a1efdb16a227e151dc31f5bd3856744" + } + }, + { + "chainId": 137, + "name": "TiqCoin", + "symbol": "TIQ", + "decimals": 18, + "address": "0x124e383a31f871a91b923bbcdbf3b0fae625c691", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb8949b6de0869735d71d0f07d1e899e57f1076d6" + } + }, + { + "chainId": 137, + "name": "AssaultToken", + "symbol": "ASLT", + "decimals": 18, + "address": "0x4b2dc203d164702d6e453ab2abeccbcae95ee36b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2b8b09ce791a4b1036137cf8ac8260cd1e619f29" + } + }, + { + "chainId": 137, + "name": "Staked MATIC", + "symbol": "stMATIC", + "decimals": 18, + "address": "0x3a58a54c066fdc0f2d55fc9c89f0415c92ebf3c4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9ee91f9f426fa633d227f7a9b000e28b9dfd8599" + } + }, + { + "chainId": 137, + "name": "Metaverse Alliance DAO", + "symbol": "MAD", + "decimals": 18, + "address": "0x158dbdd4820f95698442eac7cd4f70d08f39b3c6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6e35ecbdc138e64a5029c2487296e83bbba6b77c" + } + }, + { + "chainId": 137, + "name": "BANX", + "symbol": "BANX", + "decimals": 18, + "address": "0x288e8ad3d61e6f931290a5df1ae31f16b8274770", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0e2e120f5e18f2d0a1afd0fab02b09aa37a17f7e" + } + }, + { + "chainId": 137, + "name": "Flame", + "symbol": "XFL", + "decimals": 18, + "address": "0x8ca608e14934c1e986429d0d3644b8ba3a3e279c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x469861bdfd02e7ebce7cdeb281e8eec53069cf5f" + } + }, + { + "chainId": 137, + "name": "CybeeDAO", + "symbol": "CBD", + "decimals": 18, + "address": "0x73a79f01c3365b6b50101b47860f428a8c3cebff", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9b812c65529ec7d20ab630235ae20fde022c8ad3" + } + }, + { + "chainId": 137, + "name": "Babycoin", + "symbol": "BABYCOIN", + "decimals": 18, + "address": "0xcfeda1807147dbbcb1808e2518edde0142f419f5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd2cb4366d8111d65ebff6c29852fef7a1628ae80" + } + }, + { + "chainId": 137, + "name": "Shina Inu", + "symbol": "SHI", + "decimals": 18, + "address": "0x4ede9608a5d6154cb349f472063f6f0a95f9afc1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x243cacb4d5ff6814ad668c3e225246efa886ad5a" + } + }, + { + "chainId": 137, + "name": "Democracy", + "symbol": "DEM", + "decimals": 18, + "address": "0xaddffb740019ddf9318699e9fd1be138a311f584", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc589d3d92ae2b4461e9bb2e689b36c4e3c9c4fa3" + } + }, + { + "chainId": 137, + "name": "PITCH", + "symbol": "PITCH", + "decimals": 9, + "address": "0x4f6b7ffb1427d6312305e23aebce6fc2994d8f91", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x87f56ee356b434187105b40f96b230f5283c0ab4" + } + }, + { + "chainId": 137, + "name": "EZDEX", + "symbol": "EZX", + "decimals": 18, + "address": "0xe2a1257ac6f49b767fce903686fcbd7713af4a5d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9e8bfe46f9af27c5ea5c9c72b86d71bb86953a0c" + } + }, + { + "chainId": 137, + "name": "Cask Token", + "symbol": "CASK", + "decimals": 18, + "address": "0xdc185ade9a3362f9203191f136499ffe512527c1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0645314c1afd4d9711d609e3e755265ababc95eb" + } + }, + { + "chainId": 137, + "name": "Rickle", + "symbol": "rkl", + "decimals": 18, + "address": "0x9fdc23fe295104ac55fef09363c56451d0e37cfa", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0ff80a1708191c0da8aa600fa487f7ac81d7818c" + } + }, + { + "chainId": 137, + "name": "Doge Pixel (239, 375)", + "symbol": "DOGPIX", + "decimals": 18, + "address": "0xff93b30c021beedab0f6e28a7a08bddd155b15a4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0332713aef01faedbf821473c165ae25079372e0" + } + }, + { + "chainId": 137, + "name": "MOONEY", + "symbol": "MOONEY", + "decimals": 18, + "address": "0x74ac7664abb1c8fa152d41bb60e311a663a41c7e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x20d4db1946859e2adb0e5acc2eac58047ad41395" + } + }, + { + "chainId": 137, + "name": "Orbler", + "symbol": "ORBR", + "decimals": 18, + "address": "0xc2fbfab885b9c98ad51edf3b03e2510ff97471b0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xda30f261a962d5aae94c9ecd170544600d193766" + } + }, + { + "chainId": 137, + "name": "BYTES", + "symbol": "BYTES", + "decimals": 18, + "address": "0x6735d8de3b8f81a08727a1860cc9a68e8ed93b96", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7d647b1a0dcd5525e9c6b3d14be58f27674f8c95" + } + }, + { + "chainId": 137, + "name": "tokenpartners", + "symbol": "TOE", + "decimals": 18, + "address": "0x32e10b5ae57c9eec97bf5e67e243bf29993c9e71", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcf44278fd9932b76df313f4a278c10618d7726d2" + } + }, + { + "chainId": 137, + "name": "EnoToken", + "symbol": "ENO", + "decimals": 18, + "address": "0x7f36c54da31b2dd355caffec0249f26da41e3fcd", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xeea509c221c5c6979e974f4501b4829be0ab2f8c" + } + }, + { + "chainId": 137, + "name": "ICHI", + "symbol": "ICHI", + "decimals": 18, + "address": "0x111111517e4929d3dcbdfa7cce55d30d4b6bc4d6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x111111517e4929d3dcbdfa7cce55d30d4b6bc4d6" + } + }, + { + "chainId": 137, + "name": "StripCoin", + "symbol": "STRIP", + "decimals": 18, + "address": "0x500ad628a390cd4ce8a062f07f68f63e9ef30362", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe9cb6838902ccf711f16a9ea5a1170f8e9853c02" + } + }, + { + "chainId": 137, + "name": "Egg n Partners", + "symbol": "EGGT", + "decimals": 18, + "address": "0x74c96c05d87c86cd640de3eeb7b073811006b991", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x096cc1544fe972039353f3401bce92f8e3978693" + } + }, + { + "chainId": 137, + "name": "CoinWealth", + "symbol": "CNW", + "decimals": 6, + "address": "0x0a307bd521701f9d70fb29bfa9e2e36dc998dadb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x433fce7dfbec729a79999eaf056cb073b2153eba" + } + }, + { + "chainId": 137, + "name": "Mytrade Token", + "symbol": "MYT", + "decimals": 18, + "address": "0x4535e52cdf3ab787b379b7b72b5990767e6747e4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0bf0d26a527384bcc4072a6e2bca3fc79e49fa2d" + } + }, + { + "chainId": 137, + "name": "!IdleCDO AA Tranche - idleDAIYield", + "symbol": "AA_idleDAIYield", + "decimals": 18, + "address": "0x36f514bfb1dec83910c8c46752ad2987b7c72c5b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe9ada97bdb86d827ecbaacca63ebcd8201d8b12e" + } + }, + { + "chainId": 137, + "name": "!IdleCDO BB Tranche - idleDAIYield", + "symbol": "BB_idleDAIYield", + "decimals": 18, + "address": "0x8db0b3ee49348be4e6f3eaab952de2aa7106f7ec", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x730348a54ba58f64295154f0662a08cbde1225c2" + } + }, + { + "chainId": 137, + "name": "Fancy Games", + "symbol": "FNC", + "decimals": 18, + "address": "0x7f280dac515121dcda3eac69eb4c13a52392cace", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7f280dac515121dcda3eac69eb4c13a52392cace" + } + }, + { + "chainId": 137, + "name": "solace", + "symbol": "SOLACE", + "decimals": 18, + "address": "0x2857686536f58dd835dbf43c9f549676296ef336", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x501ace9c35e60f03a2af4d484f49f9b1efde9f40" + } + }, + { + "chainId": 137, + "name": "Dataphora", + "symbol": "DATAPHORA", + "decimals": 18, + "address": "0x8da41a3bc942b19a44d6bdf0e30f058df3ab8ba9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8da41a3bc942b19a44d6bdf0e30f058df3ab8ba9" + } + }, + { + "chainId": 137, + "name": "VitaDAO Token", + "symbol": "VITA", + "decimals": 18, + "address": "0x6cb02c92611f001f605c891fbfde7d1a26de54b9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x81f8f0bb1cb2a06649e51913a151f0e7ef6fa321" + } + }, + { + "chainId": 137, + "name": "CubToken", + "symbol": "CUBT", + "decimals": 18, + "address": "0xebbe09afdab74872dbc975d7bda1ddf5595e4c8a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbf9e72eeb5adb8b558334c8672950b7a379d4266" + } + }, + { + "chainId": 137, + "name": "Medici Token", + "symbol": "MDC", + "decimals": 18, + "address": "0xe1cc4db580022b0185a0208d5830e5b64fa14b86", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x96f5094998a20008839487369012bb4d3c56eafc" + } + }, + { + "chainId": 137, + "name": "LandOrc", + "symbol": "LORC", + "decimals": 18, + "address": "0x5e2cfc52d1c9166202226fbb0b26b8dc16a8c4e0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x148958884544a8ad7c4895e6ffe2723932e0523a" + } + }, + { + "chainId": 137, + "name": "iNTROVERSE", + "symbol": "iNTRO", + "decimals": 8, + "address": "0x7df231024f80ca7f63032c25b6232b1cc655df77", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7912c3eff24cb62865e93dbc59264b1a293cc593" + } + }, + { + "chainId": 137, + "name": "Carchain Coin", + "symbol": "CCC", + "decimals": 18, + "address": "0xe81e0a387d2585fbc5353f56a57afd20331ef12d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb9c72a65cbd593b7942cd65992eca9108a6273a3" + } + }, + { + "chainId": 137, + "name": "Fweb3", + "symbol": "FWEB3", + "decimals": 18, + "address": "0x4a14ac36667b574b08443a15093e417db909d7a3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x95cd50f9d591630db85d95c932bbc704dc0ae92a" + } + }, + { + "chainId": 137, + "name": "Citizen Token", + "symbol": "CDAO", + "decimals": 18, + "address": "0x8a23d240763057432ce048a43f9a3a1b2cc22404", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x57ea7178505f7d33c2bdb4450e041561513dbd9b" + } + }, + { + "chainId": 137, + "name": "Kromatika", + "symbol": "KROM", + "decimals": 18, + "address": "0x14af1f2f02dccb1e43402339099a05a5e363b83c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3af33bef05c2dcb3c7288b77fe1c8d2aeba4d789" + } + }, + { + "chainId": 137, + "name": "PhunToken", + "symbol": "PHTK", + "decimals": 18, + "address": "0x322584098ea29e2127a81322b417ebba356d8f22", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1fee5588cb1de19c70b6ad5399152d8c643fae7b" + } + }, + { + "chainId": 137, + "name": "Bread Token", + "symbol": "BRD", + "decimals": 18, + "address": "0x11c3eba9851d245221e00e9a8e73e6f1439325d3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x558ec3152e2eb2174905cd19aea4e34a23de9ad6" + } + }, + { + "chainId": 137, + "name": "BOBL", + "symbol": "BOBL", + "decimals": 18, + "address": "0x9dbdc7b58b4dfcc73daf45fc386b266262d11c41", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xac3a44115560064adfc2d2e90b5bd34f9454cafd" + } + }, + { + "chainId": 137, + "name": "CoinCasso Exchange Token", + "symbol": "CCX", + "decimals": 18, + "address": "0x357e1bfb47911528965bb9c6916eeea622d4bb27", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x395dc9a82e3eef962b0355a3d4e6819e9af776d2" + } + }, + { + "chainId": 137, + "name": "Centaurify", + "symbol": "CENT", + "decimals": 18, + "address": "0x7b9c2d37fc0b45a5ec022d2023f18685fda832e7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x08ba718f288c3b12b01146816bef9fa03cc635bc" + } + }, + { + "chainId": 137, + "name": "The Myth Of America", + "symbol": "GUMP", + "decimals": 0, + "address": "0xaa3622e6c36a95ce8a8d3a66c166ac916a88d9c1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x496f0b5af74e24c6ffdb182d8945f116c7077aba" + } + }, + { + "chainId": 137, + "name": "Vufi.finance", + "symbol": "VUFI", + "decimals": 18, + "address": "0x5530aa1823573af28b6315d7e75138573eabf6e4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf036c451e6e5b3c89cc86fd6affa877b2809501f" + } + }, + { + "chainId": 137, + "name": "Syndicate Token", + "symbol": "SYNR", + "decimals": 18, + "address": "0xe6bd67b9e9c1171583d5e13edaaec6d93b05ce96", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbc6e06778708177a18210181b073da747c88490a" + } + }, + { + "chainId": 137, + "name": "Biznek", + "symbol": "BIZN", + "decimals": 18, + "address": "0x2c763b519ece33bb2c57e63c40e09465dbe7637b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd91d72087f747db1abfda6bda40f4abe034fd03a" + } + }, + { + "chainId": 137, + "name": "RED MWAT", + "symbol": "MWAT", + "decimals": 18, + "address": "0x2b160eea11604f81d5adbbd2dcfe5b6cd983652b", + "logoURI": "https://s2.coinmarketcap.com/static/img/coins/64x64/2533.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6425c6be902d692ae2db752b3c268afadb099d3b" + } + }, + { + "chainId": 137, + "name": "Bay Area Excitement", + "symbol": "BAE", + "decimals": 18, + "address": "0x3df5d4d3926d55df9c10683bf0b0bde7a2dc3851", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd3ba270f82cadabd0596d3d30233448621d561bb" + } + }, + { + "chainId": 137, + "name": "Kollect", + "symbol": "KOL", + "decimals": 18, + "address": "0xe31c6667537bbc819b1fd7017ed6703cfa8f1871", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1cc30e2eac975416060ec6fe682041408420d414" + } + }, + { + "chainId": 137, + "name": "Cryptoodles Toodle Token", + "symbol": "TODL", + "decimals": 18, + "address": "0xec97734ed00d65d05d10316d1641c09d1daab96f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x98933f2396dbaabf812b6e6d27da4df109c4c55f" + } + }, + { + "chainId": 137, + "name": "Wrapped XRP", + "symbol": "WXRP", + "decimals": 18, + "address": "0xaef23cee6c50930bae8b4843c9b35c4c293e8906", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x39fbbabf11738317a448031930706cd3e612e1b9" + } + }, + { + "chainId": 137, + "name": "Test137", + "symbol": "Test137", + "decimals": 18, + "address": "0xcbb975186a8d742561319ecf0e04a6eabeb1853c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3db715989da05c1d17441683b5b41d4510512722" + } + }, + { + "chainId": 137, + "name": "Zipmex Token", + "symbol": "ZMT", + "decimals": 18, + "address": "0x7d3daeb4ccd6cf0bf95c6420cac6d10438bd5116", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaa602de53347579f86b996d2add74bb6f79462b2" + } + }, + { + "chainId": 137, + "name": "Charge", + "symbol": "CHARGE", + "decimals": 18, + "address": "0x36778b659267e74d35dda15a51a5296b3fdaf7a7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0235a4fa8374fd49bb2f01ac953f99748756f3bd" + } + }, + { + "chainId": 137, + "name": "Biconomy Token", + "symbol": "BICO", + "decimals": 18, + "address": "0x91c89a94567980f0e9723b487b0bed586ee96aa7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf17e65822b568b3903685a7c9f496cf7656cc6c2" + } + }, + { + "chainId": 137, + "name": "NFTBunny", + "symbol": "BUN", + "decimals": 18, + "address": "0x97116250d81a937e41b70cee60a817705dd7960a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf70209f73aa9716c6a303080687550cccd6d69f5" + } + }, + { + "chainId": 137, + "name": "Bronze TOWER Chest", + "symbol": "TWR.BRNZ", + "decimals": 18, + "address": "0x3f3190628aaeea6c329559b37e60c6ab471e0a6a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0bb9a88920b6b4dd59c87afb5ee29d6e1c6c8942" + } + }, + { + "chainId": 137, + "name": "Silver TOWER Chest", + "symbol": "TWR.SLVR", + "decimals": 18, + "address": "0xaa3fbde8b65130bad47a987cfb2dd27e1d9ed75e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x129f772760d569fca9a301d3ed44450eac5fc7a5" + } + }, + { + "chainId": 137, + "name": "Gold TOWER Chest", + "symbol": "TWR.GOLD", + "decimals": 18, + "address": "0xb58869e737191b4b062dcb1b67c9f92d623c3006", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9b253a5655997e3896e518111f3595c0bd6fed1c" + } + }, + { + "chainId": 137, + "name": "Rai.Finance", + "symbol": "SOFI", + "decimals": 18, + "address": "0x7cb810ecbfd6125e65f451cfbd8ae657dffdd6b4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb49fa25978abf9a248b8212ab4b87277682301c0" + } + }, + { + "chainId": 137, + "name": "President Brandon Token", + "symbol": "XLVI", + "decimals": 2, + "address": "0x40dc7491cb56ff50a9913f7228feae802db99920", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9b3007568341382b2de292d056ff7e41870d0a0e" + } + }, + { + "chainId": 137, + "name": "Presearch", + "symbol": "PRE", + "decimals": 18, + "address": "0x2492e3626b7136be7afb67483a87d716925a61e5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xec213f83defb583af3a000b1c0ada660b1902a0f" + } + }, + { + "chainId": 137, + "name": "Kitty Party Reward Token", + "symbol": "KPT", + "decimals": 18, + "address": "0x7d369731e3d7f86417aa86ef4be26e309080bd2f", + "logoURI": "https://bafkreiawezzhlphckhopkolrkxsz4mtayjz4cjxz4bgsvvkjsclqacf2be.ipfs.nftstorage.link/", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x444f20a5d578862bf84b6d14ec3ca0c8be8e555f" + } + }, + { + "chainId": 137, + "name": "Friends With Benefits Pro", + "symbol": "FWB", + "decimals": 18, + "address": "0xcb016f83d242771a8cda42f9e391f18b93b6ae63", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x35bd01fc9d6d5d81ca9e055db88dc49aa2c699a8" + } + }, + { + "chainId": 137, + "name": "WIVA", + "symbol": "WIVA", + "decimals": 18, + "address": "0x784641e51c300120a8d15bfdb3b45375d4352748", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa00055e6ee4d1f4169096ecb682f70caa8c29987" + } + }, + { + "chainId": 137, + "name": "LooksRare Token", + "symbol": "LOOKS", + "decimals": 18, + "address": "0xc3d8222c2f1223df5db3a0ee845eafc3f67e76a3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf4d2888d29d722226fafa5d9b24f9164c092421e" + } + }, + { + "chainId": 137, + "name": "Chroma", + "symbol": "CHR", + "decimals": 6, + "address": "0x594c984e3318e91313f881b021a0c4203ff5e59f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8a2279d4a90b6fe1c4b30fa660cc9f926797baa2" + } + }, + { + "chainId": 137, + "name": "GaugeField", + "symbol": "GAUF", + "decimals": 18, + "address": "0x58171d74fc6526df600214ca18dc2ee4895c6f7b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8ce7386fe7688417885adebcbfc01a5445226b2c" + } + }, + { + "chainId": 137, + "name": "Bitcoin Stable", + "symbol": "BTST", + "decimals": 18, + "address": "0x53cf566cf80e1a26bfc16d055c866a72fdcbaee7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd70804c98ebe9749e3337621eaafbe366cbb1963" + } + }, + { + "chainId": 137, + "name": "Wrapped Hachiko", + "symbol": "WHachiko", + "decimals": 18, + "address": "0x4a63428963e18cc2411f43d49826ed09d1bfa0da", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf5ea35fa36bd111adc3b81eef82259d35d88d305" + } + }, + { + "chainId": 137, + "name": "Convex CRV", + "symbol": "cvxCRV", + "decimals": 18, + "address": "0x6220d3d80020a4023eb29a9f9e206100f7bb581e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x62b9c7356a2dc64a1969e19c23e4f579f9810aa7" + } + }, + { + "chainId": 137, + "name": "Gamma", + "symbol": "GAMMA", + "decimals": 18, + "address": "0x9620330926467ed3279ffcfba8327c24625732ea", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6bea7cfef803d1e3d5f7c0103f7ded065644e197" + } + }, + { + "chainId": 137, + "name": "FLIP Token", + "symbol": "FLP", + "decimals": 18, + "address": "0x22593803b4c628d8ee2537ac0ffb996ca104ad25", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3a1bda28adb5b0a812a7cf10a1950c920f79bcd3" + } + }, + { + "chainId": 137, + "name": "Flex Ungovernance Token", + "symbol": "FLX", + "decimals": 18, + "address": "0x0f6d1c52ba0bb9e68601632a74d9f4d07afb555f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6243d8cea23066d098a15582d81a598b4e8391f4" + } + }, + { + "chainId": 137, + "name": "DerivaDAO", + "symbol": "DDX", + "decimals": 18, + "address": "0x26f5fb1e6c8a65b3a873ff0a213fa16eff5a7828", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3a880652f47bfaa771908c07dd8673a787daed3a" + } + }, + { + "chainId": 137, + "name": "Inuyasha", + "symbol": "Inuyasha", + "decimals": 18, + "address": "0xed49826b1a5a147b612ad16e27f3961d3cdce218", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5bddbfdc228e1bbdb9ef5ca1dc56b54c4d6d6621" + } + }, + { + "chainId": 137, + "name": "Guzzler", + "symbol": "GZLR", + "decimals": 18, + "address": "0x6c6fcdec44990079baac5c3062e8f0dac5c4ba8e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9f4909cc95fb870bf48c128c1fdbb5f482797632" + } + }, + { + "chainId": 137, + "name": "BoneShards", + "symbol": "BONESHARDS", + "decimals": 18, + "address": "0x84cf3e9f5ec08a77bbc4c437eaea411b44673cfc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6c716bdb4289283e0ad1926c47b54412bd2c257b" + } + }, + { + "chainId": 137, + "name": "Temple", + "symbol": "TEMPLE", + "decimals": 18, + "address": "0xee55dd8d0ccbe835b8ef163590c9afeaace5978b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x470ebf5f030ed85fc1ed4c2d36b9dd02e77cf1b7" + } + }, + { + "chainId": 137, + "name": "Animal Concerts Token", + "symbol": "ANML", + "decimals": 18, + "address": "0xecc4176b90613ed78185f01bd1e42c5640c4f09d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x38b0e3a59183814957d83df2a97492aed1f003e2" + } + }, + { + "chainId": 137, + "name": "Hotpot Funds", + "symbol": "HPT", + "decimals": 18, + "address": "0xcc0ef74ae3ef3d2c0139558ba2bdafab98ade3ed", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x615d8e5e1344b36a95f6ecd8e6cda020e84dc25b" + } + }, + { + "chainId": 137, + "name": "OverOneGold", + "symbol": "OOG", + "decimals": 18, + "address": "0xec24c04868da7abba292c2ba46fe77788a3f5f74", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb72a91ac402eec1977a6b2bd02d3f0aa1a261b93" + } + }, + { + "chainId": 137, + "name": "WorldChainShare", + "symbol": "WCS", + "decimals": 0, + "address": "0xb72a91ac402eec1977a6b2bd02d3f0aa1a261b93", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfd2e95937a9a1b4a87b8c47fd3e9acc123314c0e" + } + }, + { + "chainId": 137, + "name": "EarnBet Token", + "symbol": "BET", + "decimals": 4, + "address": "0x134257dd9a557b8083c4a196b4a259bbbd1146a6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfdd4e938bb067280a52ac4e02aaf1502cc882ba6" + } + }, + { + "chainId": 137, + "name": "\"Ethereum Push Notification Service", + "symbol": "PUSH", + "decimals": 18, + "address": "0x58001cc1a9e17a20935079ab40b1b8f4fc19efd1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf418588522d5dd018b425e472991e52ebbeeeeee" + } + }, + { + "chainId": 137, + "name": "FeelGrid Token", + "symbol": "GFEE", + "decimals": 18, + "address": "0x19fcab6c824570c82a3508ee0b520686cde62fcc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa2d17610a0106f3106d8ff0e2d88ab7b9e51b71b" + } + }, + { + "chainId": 137, + "name": "Screenist Token", + "symbol": "NIS", + "decimals": 8, + "address": "0xfd2e95937a9a1b4a87b8c47fd3e9acc123314c0e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb316c4057202cfa2c94d01f06a2a930a4b0cd83b" + } + }, + { + "chainId": 137, + "name": "Convex FXS", + "symbol": "cvxFXS", + "decimals": 18, + "address": "0xe145524abf229cce1d536623d32bf4794bb02a61", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfeef77d3f69374f66429c91d732a244f074bdf74" + } + }, + { + "chainId": 137, + "name": "GratitudeCoin", + "symbol": "GRTFUL", + "decimals": 18, + "address": "0x01a8d35b2fd85dd2e73760d4e6300f1bdd47a118", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6563b5d8925ad3684bdb5923d56b0b24044eb90f" + } + }, + { + "chainId": 137, + "name": "Faith Tribe", + "symbol": "FTRB", + "decimals": 18, + "address": "0xc3f56d567e7663e8932e65d85ae4be7eb5575ca7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2596825a84888e8f24b747df29e11b5dd03c81d7" + } + }, + { + "chainId": 137, + "name": "Dopex Governance Token", + "symbol": "DPX", + "decimals": 18, + "address": "0x025a1405e9f917313a4e17fd365d0611cccf43e1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeec2be5c91ae7f8a338e1e5f3b5de49d07afdc81" + } + }, + { + "chainId": 137, + "name": "Tokemak", + "symbol": "TOKE", + "decimals": 18, + "address": "0xe1708abde4847b4929b70547e5197f1ba1db2250", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2e9d63788249371f1dfc918a52f8d799f4a38c94" + } + }, + { + "chainId": 137, + "name": "MarvelousNFT", + "symbol": "MNFT", + "decimals": 18, + "address": "0xd281af594cbb99e8469f3591d57a0c72eb725bdb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x33be7644c0e489b3a0c639d103392d4f3e338158" + } + }, + { + "chainId": 137, + "name": "Pupper", + "symbol": "PUP", + "decimals": 18, + "address": "0x2cbf640e8f0301e86392ecf8009a034178ef2415", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x81dbc1c8e40c3095071949eda9800c2209a7279a" + } + }, + { + "chainId": 137, + "name": "Polygon Dev Wrapper", + "symbol": "WDEV", + "decimals": 18, + "address": "0xa5577d1cec2583058a6bd6d5deac44797c205701", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4a5df63b0c37b38515e4ee51baf40edd420bf7d5" + } + }, + { + "chainId": 137, + "name": "The Rise Of The Aztecs - Gold", + "symbol": "ROAG", + "decimals": 18, + "address": "0xe465128cd5316c4a08e879c32cc89d8f794c02e4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe465128cd5316c4a08e879c32cc89d8f794c02e4" + } + }, + { + "chainId": 137, + "name": "Swee Token", + "symbol": "SWEE", + "decimals": 18, + "address": "0xd813b1500db50c755a37850ab29ca7a6ce24b25b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x83d7d7315b918bc002376f73fcd07ea0708e44ef" + } + }, + { + "chainId": 137, + "name": "YourGamify Token", + "symbol": "GAM", + "decimals": 18, + "address": "0x0fdfee86a85cf73c1eced1e2f8d8a358c5c7127d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x05e4de681283bdf7c35ef7de4b87e465e80a6216" + } + }, + { + "chainId": 137, + "name": "Aquest Token", + "symbol": "AQU", + "decimals": 18, + "address": "0xa68c10cb0bf5c45f223a9db23ffc1f5614388287", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7756edf05ef3c2b321a85d77b5cbf7c8a9a7c247" + } + }, + { + "chainId": 137, + "name": "EnkronosToken", + "symbol": "ENK", + "decimals": 18, + "address": "0xa810289daa9235aff550fbacc68703c2ffc3cd80", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x92b914f1ddcbb1d117a718e83c9ed7eb32fc44d1" + } + }, + { + "chainId": 137, + "name": "wxBTRFLY", + "symbol": "wxBTRFLY", + "decimals": 18, + "address": "0x3c7681320cc5d558480a8ff2f19a01c312535364", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x186e55c0bebd2f69348d94c4a27556d93c5bd36c" + } + }, + { + "chainId": 137, + "name": "NFT Worlds", + "symbol": "WRLD", + "decimals": 18, + "address": "0xd5d86fc8d5c0ea1ac1ac5dfab6e529c9967a45e9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd5d86fc8d5c0ea1ac1ac5dfab6e529c9967a45e9" + } + }, + { + "chainId": 137, + "name": "Sipher Token", + "symbol": "SIPHER", + "decimals": 18, + "address": "0x2eca05abf0adf9f208e973d4682503fb6ae8f942", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9f52c8ecbee10e00d9faaac5ee9ba0ff6550f511" + } + }, + { + "chainId": 137, + "name": "RAYS", + "symbol": "RAYS", + "decimals": 18, + "address": "0x2d027e55b85429e9f205930a8aff6d8e6c8c3021", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6db5f284660b3129ce2e8f563bf849c59f372f61" + } + }, + { + "chainId": 137, + "name": "ERC20", + "symbol": "ERC20", + "decimals": 18, + "address": "0x9300169b33a02f968e5c2a00607e0ece26248752", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc3761eb917cd790b30dad99f6cc5b4ff93c4f9ea" + } + }, + { + "chainId": 137, + "name": "SWARM", + "symbol": "SWM", + "decimals": 18, + "address": "0x3505f494c3f0fed0b594e01fa41dd3967645ca39", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3505f494c3f0fed0b594e01fa41dd3967645ca39" + } + }, + { + "chainId": 137, + "name": "ECX Token", + "symbol": "ECX", + "decimals": 18, + "address": "0x90b9597bbfdcbc86253d27d6b9a13079c5155f9f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9c8071c501c8226ab906a68d9ef9da6e0bd3a8ba" + } + }, + { + "chainId": 137, + "name": "B.Protocol", + "symbol": "BPRO", + "decimals": 18, + "address": "0x0c560bf15acccca2892053589b1805b5ef18a21f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbbbbbbb5aa847a2003fbc6b5c16df0bd1e725f61" + } + }, + { + "chainId": 137, + "name": "Arke Token", + "symbol": "ARKES", + "decimals": 18, + "address": "0x0784d958ee09ff8e876a82d3c6e798912c0f0a11", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaeab9861bd9479daaa538a2d7f57d5e1d1c86c5e" + } + }, + { + "chainId": 137, + "name": "unification.com/xfund", + "symbol": "xFUND", + "decimals": 9, + "address": "0x77a3840f78e4685afaf9c416b36e6eae6122567b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x892a6f9df0147e5f079b0993f486f9aca3c87881" + } + }, + { + "chainId": 137, + "name": "FiscoCoin", + "symbol": "FSCC", + "decimals": 8, + "address": "0x5ccfefd833ed1f648d227b32ff96f045a0d2fa8d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0789dbae94fb18e5789b8e4489bcb7a1adb58622" + } + }, + { + "chainId": 137, + "name": "Theranos Coin", + "symbol": "LIZ", + "decimals": 18, + "address": "0x6094a3ced47335b068efba7789ea578af1434947", + "logoURI": "https://www.theranosco.in/logo.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x102e941b77bcaa7e35d368cafe51ef8f79c8d1ef" + } + }, + { + "chainId": 137, + "name": "DePo Token", + "symbol": "DEPO", + "decimals": 18, + "address": "0xe854d408482319bae8e3e3965c2eee9135e936c2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa5def515cfd373d17830e7c1de1639cb3530a112" + } + }, + { + "chainId": 137, + "name": "DegenArts.com Coin", + "symbol": "DAC", + "decimals": 18, + "address": "0xbe69e683c56c2816d3eeec1183c882dd73ea5914", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8281ee37f164c0e26e6b6f87e7695baac256df07" + } + }, + { + "chainId": 137, + "name": "hyfi.token", + "symbol": "HyFi", + "decimals": 18, + "address": "0x5cf6e36dcf6e6132e251ca0f5590bb7c8055bb3d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x79a1ca1768fe91867be916efa2b1630c7fc83422" + } + }, + { + "chainId": 137, + "name": "Let's Go Brandon", + "symbol": "LGB", + "decimals": 18, + "address": "0xc712f8e6ffd1b6a40eb8735c8d2db2a55612268c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x21e783bcf445b515957a10e992ad3c8e9ff51288" + } + }, + { + "chainId": 137, + "name": "CXD Token", + "symbol": "CXD", + "decimals": 18, + "address": "0x178745ca4ba60b22e25cf92df47f177a7db7b4f8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xefa815c439c1697dbb6b88d1434153f67697e0b8" + } + }, + { + "chainId": 137, + "name": "Zenith", + "symbol": "ZENX", + "decimals": 18, + "address": "0x9cd44af7fb46a946484ebe377bb2712eabb610ad", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x67f7e5e9dbed6c52dc52d7a83ac3608ad2648e12" + } + }, + { + "chainId": 137, + "name": "YUGEN", + "symbol": "YGN", + "decimals": 18, + "address": "0xa33aaa07853038943ef2c32cde73a094cf993ee0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x397e10ee5e315f69b23cb6c8a913a589b5850c80" + } + }, + { + "chainId": 137, + "name": "Gas DAO", + "symbol": "GAS", + "decimals": 18, + "address": "0x7a9568ae827cd28bf8365fd51baa2dbcd7d3f465", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6bba316c48b49bd1eac44573c5c871ff02958469" + } + }, + { + "chainId": 137, + "name": "Domination Finance Token", + "symbol": "DOM", + "decimals": 18, + "address": "0xc8aaee7f1deac631259b8bf2c65e71207cc53b0c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xef5fa9f3dede72ec306dfff1a7ea0bb0a2f7046f" + } + }, + { + "chainId": 137, + "name": "PlannerDAO Opportunity Index", + "symbol": "PDAO", + "decimals": 18, + "address": "0x2b4fa97b84698dc1540d13d33754757bac3c8115", + "logoURI": "https://uploads-ssl.webflow.com/6096909a9f570cf818e33cf5/61e658c8fb13b00b5a4c40c2_Untitled%20design.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa025f41f1a973e6649931f3ac96979071bda4c9f" + } + }, + { + "chainId": 137, + "name": "Anime Coin", + "symbol": "ANME", + "decimals": 18, + "address": "0x60ff7b0744d5981d8a3dfb8b84716f381652508d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5c77583c1d729c94baac79579c26ff70c46145b5" + } + }, + { + "chainId": 137, + "name": "bHome", + "symbol": "bHOME", + "decimals": 6, + "address": "0x58743aabed5bb772845d1a779f7ea592ac744023", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb8919522331c59f5c16bdfaa6a121a6e03a91f62" + } + }, + { + "chainId": 137, + "name": "Bankless DeFi Innovation Index", + "symbol": "GMI", + "decimals": 18, + "address": "0x7fb27ee135db455de5ab1ccec66a24cbc82e712d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x47110d43175f7f2c2425e7d15792acc5817eb44f" + } + }, + { + "chainId": 137, + "name": "Plush", + "symbol": "PLSH", + "decimals": 18, + "address": "0x33044d2c29686795228b89b11d2d34727b8df9bc", + "logoURI": "https://raw.githubusercontent.com/PlushFamily/plush-design-assets/main/logos/plush/svg/plush-logo.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x26a22c97dd308657ada714d9ee0c08233b05fd48" + } + }, + { + "chainId": 137, + "name": "Diabolo", + "symbol": "DCASH", + "decimals": 10, + "address": "0x74ba6a10978f643a84c0b37fcb599081079811cb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcf8f32e032f432b02393636b2092a6bef975fbf9" + } + }, + { + "chainId": 137, + "name": "Venice Coin", + "symbol": "VENICE", + "decimals": 18, + "address": "0xc4b00de48c795666c2b0ad0ed4b9ac7e22fd10e1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf6d4fbc3b86811df25d829a14dae0269a3ee5462" + } + }, + { + "chainId": 137, + "name": "Spheroid", + "symbol": "SPH", + "decimals": 18, + "address": "0x2c9d233914f46b88e9ae08326fa60e40ea3faa12", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa0cf46eb152656c7090e769916eb44a138aaa406" + } + }, + { + "chainId": 137, + "name": "LogiTron", + "symbol": "LTR", + "decimals": 18, + "address": "0x7d29968f96d475186a479e4be99b43b8b8a20dbc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa4c7963b98838e8f958cf7b87a039249044fe2db" + } + }, + { + "chainId": 137, + "name": "XPOP Entertainment", + "symbol": "XPOP", + "decimals": 18, + "address": "0x0ae1daf8329923cce587e994df500a8f1dd5fc6f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0f3a02baec9607f2b52b3ab629cbcea2047e1124" + } + }, + { + "chainId": 137, + "name": "BIOS", + "symbol": "BIOS", + "decimals": 18, + "address": "0xe20d2df5041f8ed06976846470f727295cdd4d23", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaaca86b876ca011844b5798eca7a67591a9743c8" + } + }, + { + "chainId": 137, + "name": "Simracer Coin", + "symbol": "SRC", + "decimals": 18, + "address": "0xf0c3c4ac63be272a94712bccc39490a159cd0d7c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x16587cf43f044aba0165ffa00acf412631194e4b" + } + }, + { + "chainId": 137, + "name": "Nemesis Downfall", + "symbol": "NMSIS", + "decimals": 18, + "address": "0x3f5b2063e500492463589b17f9ea9cf2af9771cf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7b6bbbeac6a7f5681ec8e250b9aeb45a42bdc2cf" + } + }, + { + "chainId": 137, + "name": "Matic-PTY", + "symbol": "MPTY", + "decimals": 18, + "address": "0xfa8cf47d8bc10f6f7272f2b9b0ed042e8b8e120d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x959f71f60333d05856a35cb000fb42829b1ec1c1" + } + }, + { + "chainId": 137, + "name": "MOI", + "symbol": "MOI", + "decimals": 18, + "address": "0x42b171dee4a4a4c918eb53e438346df47b07c6f2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xce78fe539ef8b6c77b5726113c7b2e78f71dc6ab" + } + }, + { + "chainId": 137, + "name": "SENATE", + "symbol": "SENATE", + "decimals": 18, + "address": "0x18428bb593f8a1ec3fb80418e4844439b03f5001", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x34be5b8c30ee4fde069dc878989686abe9884470" + } + }, + { + "chainId": 137, + "name": "Vader", + "symbol": "VADER", + "decimals": 18, + "address": "0x13e5f8e18376d51203156a47a809254c717cf9b7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2602278ee1882889b946eb11dc0e810075650983" + } + }, + { + "chainId": 137, + "name": "Qawalla Token", + "symbol": "QWLA", + "decimals": 18, + "address": "0x4fafad147c8cd0e52f83830484d164e960bdc6c3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1d96fd43ee07aa79f8fd003cbdf404fb5ce41ad2" + } + }, + { + "chainId": 137, + "name": "ASYAGRO", + "symbol": "ASY", + "decimals": 18, + "address": "0x7e4413ed294a9fb86d6534edbcc46355a83c1ef7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x017b584acfd16d767541ae9e80cdc702f4527b0b" + } + }, + { + "chainId": 137, + "name": "SOS", + "symbol": "SOS", + "decimals": 18, + "address": "0x8c059898ca6274750b6bf1cf38f2848347c490cc", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3b484b82567a09e2588a13d54d032153f0c0aee0" + } + }, + { + "chainId": 137, + "name": "Polylend Token", + "symbol": "PCOIN", + "decimals": 18, + "address": "0x86589a8fa4945657a41ed013633ff26ca9a26a2b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x12393ba26e2c5dafeb81c803d0be7beb50971cc1" + } + }, + { + "chainId": 137, + "name": "LEEDO Project ERC20", + "symbol": "LEEDO", + "decimals": 18, + "address": "0x94576423d85b47575bba515a1f328a265e6318e6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3eede143adb9a80c6a44c63dad76269d33e2c8d1" + } + }, + { + "chainId": 137, + "name": "microETH", + "symbol": "uETH", + "decimals": 18, + "address": "0x40eebe8541ac5a232e5897226aa3491677bfa9dd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbb7be7cc5abb65d3a29d7982236481ddf4f10b09" + } + }, + { + "chainId": 137, + "name": "Black Abyss", + "symbol": "BLYS", + "decimals": 18, + "address": "0x0142666baa520bc49b32ad44c505421346c69164", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2e3dd59619efa2afa811236235648f0607e0ee66" + } + }, + { + "chainId": 137, + "name": "DogeGF", + "symbol": "DOGEGF", + "decimals": 18, + "address": "0x0e7252706393470ffb0629da2caa39fc9340f2d4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfb130d93e49dca13264344966a611dc79a456bc5" + } + }, + { + "chainId": 137, + "name": "Trazable", + "symbol": "TRZ", + "decimals": 18, + "address": "0x9d0be2730a8af6061f058ce2c951d52e4f886f18", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x394a16744dcd805bb0ca7252e70691f0dcac56aa" + } + }, + { + "chainId": 137, + "name": "renDGB", + "symbol": "renDGB", + "decimals": 8, + "address": "0x6d54d243f144e16b6489a295f100146e11286ec0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe3cb486f3f5c639e98ccbaf57d95369375687f80" + } + }, + { + "chainId": 137, + "name": "ScallopX", + "symbol": "SCLP", + "decimals": 18, + "address": "0x2fc711518aae7c87d7002566c5d43b0e5d2b1932", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3f6d1649a1366b0e82173d33e365953f9f1cc84c" + } + }, + { + "chainId": 137, + "name": "Amasa Token", + "symbol": "AMAS", + "decimals": 18, + "address": "0xc4d6d290bf5f28278fe30f5e28b0a482eac330f0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x65a8fba02f641a13bb7b01d5e1129b0521004f52" + } + }, + { + "chainId": 137, + "name": "TNodeOrange", + "symbol": "TNO", + "decimals": 8, + "address": "0x2ea3e8f750cbc55c293e6008e8b5a654ebbd0600", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x992d6ef73506a28d084dd092722f686fb5570e38" + } + }, + { + "chainId": 137, + "name": "Niftify", + "symbol": "NIFT", + "decimals": 18, + "address": "0x4a1d542b52a95ad01ddc70c2e7df0c7bbaadc56f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4a1d542b52a95ad01ddc70c2e7df0c7bbaadc56f" + } + }, + { + "chainId": 137, + "name": "Mondo Community Coin", + "symbol": "MNDCC", + "decimals": 18, + "address": "0x78c192f6b1260d53d7ff871d267364f334897f08", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcdb9d30a3ba48cdfcb0ecbe19317e6cf783672f1" + } + }, + { + "chainId": 137, + "name": "Rotharium", + "symbol": "RTH", + "decimals": 18, + "address": "0xb9abdd78a153b8b59d09dfc196254718145f3a20", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3fd8f39a962efda04956981c31ab89fab5fb8bc8" + } + }, + { + "chainId": 137, + "name": "Chase", + "symbol": "Chase", + "decimals": 6, + "address": "0x6484117fbdc339c99c973bde96650039f3469c09", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x77b9b390f88b5eafd7ceb8d233535cfd8e6b62a2" + } + }, + { + "chainId": 137, + "name": "Burp", + "symbol": "BURP", + "decimals": 18, + "address": "0x538d47d142f6993038a667e9d6210d3735749b36", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x33f391f4c4fe802b70b77ae37670037a92114a7c" + } + }, + { + "chainId": 137, + "name": "CannaSwap", + "symbol": "NOID", + "decimals": 18, + "address": "0x80387ff8b58c82fbaf385a3380d4627234763659", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x42624903735dc6396643200242f7f7b6c7b619ea" + } + }, + { + "chainId": 137, + "name": "ParaSwap", + "symbol": "PSP", + "decimals": 18, + "address": "0x42d61d766b85431666b39b89c43011f24451bff6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcafe001067cdef266afb7eb5a286dcfd277f3de5" + } + }, + { + "chainId": 137, + "name": "Terrapass Coin", + "symbol": "TPSC", + "decimals": 18, + "address": "0x0a2a95978ce57395dbf33696d34e222e1eacde4e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x88d8da2a8d0fa5b1f4e38030ac486ade0afa2798" + } + }, + { + "chainId": 137, + "name": "Outernet Players Token", + "symbol": "OPT", + "decimals": 18, + "address": "0x8338bd2dbcc83f1f0190be068779aca296380209", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0FaB50cfEf9919cA35D0831b376d4d96b033230e" + } + }, + { + "chainId": 137, + "name": "MetaBrands", + "symbol": "MAGE", + "decimals": 18, + "address": "0xb044d04c406952c0927579e153c49c222ef2c870", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd52aae39a2b5cc7812f7b9450ebb61dfef702b15" + } + }, + { + "chainId": 137, + "name": "Neighbourhoods Token", + "symbol": "NHT", + "decimals": 18, + "address": "0x84342e932797fc62814189f01f0fb05f52519708", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x84342e932797FC62814189f01F0Fb05F52519708" + } + }, + { + "chainId": 137, + "name": "GP", + "symbol": "GP", + "decimals": 18, + "address": "0xD10bCCDd789fa11239D903FeA93DB2C8c92CfbE7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x38Ec27c6F05a169e7eD03132bcA7d0cfeE93C2C5" + } + }, + { + "chainId": 137, + "name": "Whales Game Islands", + "symbol": "ISLAND", + "decimals": 18, + "address": "0x96f57e3f4f1e11b8c5fdc98ab45f5843ab66821f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xE0Be84ca5c7bEaA2051057f02449ECB0495Bf50e" + } + }, + { + "chainId": 137, + "name": "Wrapped Whales", + "symbol": "wWH", + "decimals": 18, + "address": "0xca69c315b644a45a35b25fe23fbaf6620599a063", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xD0c99622c3f0C09b4B08f5f13Dd28BeE13f6E3c7" + } + }, + { + "chainId": 137, + "name": "Wrapped Fishermen", + "symbol": "wFM", + "decimals": 18, + "address": "0xdeba42d0a9da63697eaf745b2863393e02505a3a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcE113e6e2386197917D70d58DDdE148bfA4F58Ca" + } + }, + { + "chainId": 137, + "name": "Swarm Markets", + "symbol": "SMT", + "decimals": 18, + "address": "0xE631DABeF60c37a37d70d3B4f812871df663226f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xB17548c7B510427baAc4e267BEa62e800b247173" + } + }, + { + "chainId": 137, + "name": "Mobilum Token", + "symbol": "MBM", + "decimals": 18, + "address": "0x5A98291b9A7643448f5366Fe4a4918f7cb566912", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x281F5B914b0D589F8193cd5e711c6920874E00C8" + } + }, + { + "chainId": 137, + "name": "Kounotori", + "symbol": "KTO", + "decimals": 9, + "address": "0xbf59a84274f57C6ab3a5F3aD4864dE0dF3faff4E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x616ef40d55c0d2c506f4d6873bda8090b79bf8fc" + } + }, + { + "chainId": 137, + "name": "EVE Exchange", + "symbol": "EVE", + "decimals": 18, + "address": "0xaE29AC47A9E3b0a52840E547aDf74B912999F7fc", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0f628641d0ea1ecab9341e58d4982c0018a51c6b" + } + }, + { + "chainId": 137, + "name": "Searching for Satoshi", + "symbol": "S4S", + "decimals": 18, + "address": "0x7bfC8637B8fDb2b13291639bA65C25A22A9e59f0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8091CBDF4bF6D449b0fCd3c797d4990E4229A820" + } + }, + { + "chainId": 137, + "name": "MYCE PLATFORM", + "symbol": "MYCE", + "decimals": 18, + "address": "0xDcC1F05C5Ad40972ce9FBaF2841cbedE6f933b07", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE9966C1184f8552Fcb16F65addba9Dd08fe8f4EA" + } + }, + { + "chainId": 137, + "name": "GenomesDAO Governance", + "symbol": "GNOME", + "decimals": 18, + "address": "0x6E8a8726639d12935b3219892155520bdC57366B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xE58Eb0Bb13a71d7B95c4C3cBE6Cb3DBb08f9cBFB" + } + }, + { + "chainId": 137, + "name": "GenomesDAO", + "symbol": "GENE", + "decimals": 18, + "address": "0x34667ED7C36cBBbF2d5d5c5c8d6Eb76a094EDb9F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x21413c119b0C11C5d96aE1bD328917bC5C8ED67E" + } + }, + { + "chainId": 137, + "name": "Nitro", + "symbol": "NITRO", + "decimals": 18, + "address": "0x695FC8B80F344411F34bDbCb4E621aA69AdA384b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0335A7610D817aeCA1bEBbEfbd392ecC2eD587B8" + } + }, + { + "chainId": 137, + "name": "PlannerDAO", + "symbol": "PLAN", + "decimals": 18, + "address": "0xaf28b7702e239e7ed107b6e036851f56e0415188", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8D7acC5d07818f187ab70b6033c690FD67C96D98" + } + }, + { + "chainId": 137, + "name": "Daniel Token 2", + "symbol": "DAN2", + "decimals": 6, + "address": "0xa35816AD75206102812363541dfb9C88E8bB1A8f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x55E9d73f7bF359Ab7C2e6F441f425E212aD615e8" + } + }, + { + "chainId": 137, + "name": "Materia", + "symbol": "GIL", + "decimals": 18, + "address": "0xBE6159775a9050E5c4CBF81718390818702bf801", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x020810d775fc019480cd56ecb960389d3477039d" + } + }, + { + "chainId": 137, + "name": "PYLNT", + "symbol": "PYLNT", + "decimals": 18, + "address": "0xE411D55Fb9D8d9d2A0b4161F08AdF768b23A584B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xD8924385CD46e6AF6F377871C732BDe2F8e9dD18" + } + }, + { + "chainId": 137, + "name": "Wurstcoin", + "symbol": "WURST", + "decimals": 18, + "address": "0xd71951630e7afb497ee6F9d9B4510a8614869A59", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x67e74603df95cabbebc6795478c2402a01ea1517" + } + }, + { + "chainId": 137, + "name": "MetaWorld", + "symbol": "METW", + "decimals": 18, + "address": "0x1B042246d67C44a745dc8BaD735c84059A1Fa0a7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x18cdc8ecad3DA54AcA6bE823B1eA29F514d4856d" + } + }, + { + "chainId": 137, + "name": "Metaverse", + "symbol": "MV", + "decimals": 18, + "address": "0xA3c322Ad15218fBFAEd26bA7f616249f7705D945", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xAE788F80F2756A86aa2F410C651F2aF83639B95b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mv.svg" + }, + { + "chainId": 137, + "name": "NFTWiki Token", + "symbol": "NFTK", + "decimals": 18, + "address": "0x514267D21BcB99b43657eF4Ed80b26E18ca9E8f0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xCCb4dFdb4f95697ab5c389185f0Ba9042A78576F" + } + }, + { + "chainId": 137, + "name": "Veritaseum", + "symbol": "VERI", + "decimals": 18, + "address": "0xA8FC7CD1ea3A65574368fAddB4B1190aa3Fd6560", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8f3470A7388c05eE4e7AF3d01D8C722b0FF52374" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/veri.svg" + }, + { + "chainId": 137, + "name": "ThunderDAO", + "symbol": "TDAO", + "decimals": 18, + "address": "0x6C3Ec80Fae6F067cC5F0222eFd957101b626291e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x13bb3586478f7725b0e7b404c97939cc2cbc530d" + } + }, + { + "chainId": 137, + "name": "Vufi Shares", + "symbol": "VUFIS", + "decimals": 18, + "address": "0xf0533E7Ef9d9aA5d5554be649e60315E528Ce3a7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x36417d9f5a927b3af2f03fe8c8d4fde715601b83" + } + }, + { + "chainId": 137, + "name": "Degen$ Farm Bags", + "symbol": "BAGZ", + "decimals": 0, + "address": "0x345DF42b1E4963d70909E09935b9a1f7ef832114", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xBABA0d970e735c7E48bba07C1164c4e0449AE9b8" + } + }, + { + "chainId": 137, + "name": "Genesis Mechanism", + "symbol": "GeM", + "decimals": 18, + "address": "0x2f911F789d9D599B34D403a2cFc0C5B3f7E8cE7a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xebc27d9bd8ac268934784dcdf1eaa10dfaf97a9f" + } + }, + { + "chainId": 137, + "name": "CosplayToken", + "symbol": "COT", + "decimals": 18, + "address": "0x8d520c8E66091cfD6743fe37Fbe3A09505616C4b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5cac718a3ae330d361e39244bf9e67ab17514ce8" + } + }, + { + "chainId": 137, + "name": "PAWER Network", + "symbol": "PAWR", + "decimals": 18, + "address": "0xd9ce16aC93B783e069353a57220bf0E9C5315daf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7693A7D03D35808b75742D33d6fbB000359E693c" + } + }, + { + "chainId": 137, + "name": "BitDegree Token", + "symbol": "BDG", + "decimals": 18, + "address": "0x293b3B56cCf37FCE9bd4d8A3E276ff6c24Bc72B4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1961B3331969eD52770751fC718ef530838b6dEE" + } + }, + { + "chainId": 137, + "name": "Smoke", + "symbol": "SMOKE", + "decimals": 18, + "address": "0xc54a5024b6c5e565772729b783021f60a8f9139c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x67725FB3751c257920a88c543ba9b4BA8CfbfA5D" + } + }, + { + "chainId": 137, + "name": "Ember NFT Index", + "symbol": "ENFTI", + "decimals": 18, + "address": "0xE50C778924604B2AA3e66Fb5C2D378D5FC15FcD5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3c6591ceDD3d60C022f6dA4F83B36d23A633b512" + } + }, + { + "chainId": 137, + "name": "GAMESTA", + "symbol": "GSG", + "decimals": 18, + "address": "0x778949e707A0eb6c32ca20b1F9E0Db9685d18024", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x55cd00764e85aa3b6b34130c983fff9eb458250c" + } + }, + { + "chainId": 137, + "name": "DecentraWeb", + "symbol": "DWEB", + "decimals": 18, + "address": "0x8839e639F210B80ffea73AedF51baed8DAc04499", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xE7f58A92476056627f9FdB92286778aBd83b285F" + } + }, + { + "chainId": 137, + "name": "Limelight", + "symbol": "LMLT", + "decimals": 18, + "address": "0x1F435c17d7Ff631218827F9BA43a696650a9D512", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5eA1dd3f3F3685C32D771B2E89A70d9c5cCf8A0C" + } + }, + { + "chainId": 137, + "name": "dHealth", + "symbol": "DHP", + "decimals": 18, + "address": "0x194Dd5b6b7225C9d2F2e2b2aF7a4FfC8e77fd479", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc40F23A3E9613E012944f7957edCe97899Fa920d" + } + }, + { + "chainId": 137, + "name": "ROTTSCHILD.com", + "symbol": "ROTTS", + "decimals": 9, + "address": "0x510379859D138d1854E925C7472674F4A827296a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfb40e79e56cc7d406707b66c4fd175e07eb2ae3c" + } + }, + { + "chainId": 137, + "name": "P125 Token", + "symbol": "P125", + "decimals": 18, + "address": "0x83000597e8420aD7e9EDD410b2883Df1b83823cF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xA9033952ac045168243A1A50c889516445247618" + } + }, + { + "chainId": 137, + "name": "Shiblon Moon", + "symbol": "SHIBLONMOON", + "decimals": 18, + "address": "0xbCC4a4dc490500161A4d91bC1ccE5929224EC385", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2cCEa629BA92490136B2206379809737C57AC409" + } + }, + { + "chainId": 137, + "name": "Ooki Token", + "symbol": "OOKI", + "decimals": 18, + "address": "0xCd150B1F528F326f5194c012f32Eb30135C7C2c9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0De05F6447ab4D22c8827449EE4bA2D5C288379B" + } + }, + { + "chainId": 137, + "name": "Moss Carbon Credit", + "symbol": "MCO2", + "decimals": 18, + "address": "0xaa7dbd1598251f856c12f63557a4c4397c253cea", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfc98e825a2264d890f9a1e68ed50e1526abccacd" + } + }, + { + "chainId": 137, + "name": "Element 69", + "symbol": "EL69", + "decimals": 18, + "address": "0xAC05696A96fbF947200876ABb8e71b9e18Ef3D6A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa1fF4Ee88b53124b73eE16b315F61623CDacc987" + } + }, + { + "chainId": 137, + "name": "Team Clean Seas", + "symbol": "TCS", + "decimals": 9, + "address": "0xCDCB83ff608E7DEcb66ff597dA9d438F8896BdB1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x592f77f18893c8657cbf7cfc93e3f7cf7b02662d" + } + }, + { + "chainId": 137, + "name": "Auditchain", + "symbol": "AUDT", + "decimals": 18, + "address": "0x91c5A5488c0dEcde1Eacd8a4F10e0942fb925067", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xB90cb79B72EB10c39CbDF86e50B1C89F6a235f2e" + } + }, + { + "chainId": 137, + "name": "Krill Token", + "symbol": "KRILL", + "decimals": 18, + "address": "0xDa9f97B9dE8509938c65DB0F0CB0ff9Ea425E9a0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf59BfEED034092E399Cc43Ff79EdAb15e2e18735" + } + }, + { + "chainId": 137, + "name": "Polygen", + "symbol": "PGEN", + "decimals": 18, + "address": "0x01d35cbC2070a3B76693Ce2b6364Eae24eb88591", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf6719e1A8fcBB1B9c290019E37e004966A8916C9" + } + }, + { + "chainId": 137, + "name": "Sunder Goverance Token", + "symbol": "Sunder", + "decimals": 18, + "address": "0xaE36Df61954A67c88ea8e0b8a9B0aF378abB013b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbDbf245c690d54b67C6e610A28486A2C6dE08bE6" + } + }, + { + "chainId": 137, + "name": "Gold Fever Native Gold", + "symbol": "NGL", + "decimals": 18, + "address": "0xF95c5f961CF676ae927DfF05342a0741b99E3564", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2653891204F463fb2a2F4f412564b19e955166aE" + } + }, + { + "chainId": 137, + "name": "Phantasma Stake", + "symbol": "SOUL", + "decimals": 8, + "address": "0xE79378Aaf2386452960a365fB8D720AC888c9614", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x79c75e2e8720b39e258f41c37cc4f309e0b0ff80" + } + }, + { + "chainId": 137, + "name": "Forsan Coin", + "symbol": "FORS", + "decimals": 18, + "address": "0x56a25375e6930114Fe0B428df5CCDc753db99898", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa5Bd86e212097F95415AfF92B7F0752BAe39F7e5" + } + }, + { + "chainId": 137, + "name": "$", + "symbol": "$", + "decimals": 18, + "address": "0x5B3dcB07244dCCBd22A42080AE8b35E7a7593ED3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xDd3892eacc10c3E6A56EB29Fa0cdC18C4E4bF9Ae" + } + }, + { + "chainId": 137, + "name": "Data Transaction Token", + "symbol": "XD", + "decimals": 18, + "address": "0x9a0e65942615DE1eb5f5dD0CCB89090719231410", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x24dcc881e7dd730546834452f21872d5cb4b5293" + } + }, + { + "chainId": 137, + "name": "Agrolot Token", + "symbol": "AGLT", + "decimals": 18, + "address": "0x136B7098a3FE98cbB8Eb00f5cfed393E96E317E3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x72c9Fb7ED19D3ce51cea5C56B3e023cd918baaDf" + } + }, + { + "chainId": 137, + "name": "UniX Gaming", + "symbol": "UNIX", + "decimals": 18, + "address": "0x8C4476DFEC8e7EEdf2DE3e9E9461B7c14C828d46", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xddd6a0ecc3c6f6c102e5ea3d8af7b801d1a77ac8" + } + }, + { + "chainId": 137, + "name": "Fodl", + "symbol": "FODL", + "decimals": 18, + "address": "0x5314bA045a459f63906Aa7C76d9F337DcB7d6995", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4c2e59d098df7b6cbae0848d66de2f8a4889b9c3" + } + }, + { + "chainId": 137, + "name": "MonoX Token", + "symbol": "MONO", + "decimals": 18, + "address": "0x05323017c00874198Cf1b0832922074BeEA0db83", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2920f7d6134f4669343e70122cA9b8f19Ef8fa5D" + } + }, + { + "chainId": 137, + "name": "KOROMARU", + "symbol": "KOROMARU", + "decimals": 9, + "address": "0x0b80BFcfd006c446aF4157b87aA7D7F13c8F549A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd0d42005e7b3c0812b1268f0e5faf97ff2423651" + } + }, + { + "chainId": 137, + "name": "Bluemel", + "symbol": "BLUEMEL", + "decimals": 18, + "address": "0x1F7826D9562F42e745823BdBB690902E00D995f6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe921401d18ed1ea4d64169d1576c32f9a7439694" + } + }, + { + "chainId": 137, + "name": "KwikTrust", + "symbol": "KTX", + "decimals": 18, + "address": "0x60E6895184448f3e8EF509D083e3cC3AC31F82Fd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6CA8F7f73599834FeE845EF884562bb5479318a0" + } + }, + { + "chainId": 137, + "name": "TattooMoney", + "symbol": "TAT2", + "decimals": 18, + "address": "0x2596A8B90D39EB89d5668ca5B6deE54E9ae3d4C0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb487d0328b109e302b9d817b6f46cbd738ea08c2" + } + }, + { + "chainId": 137, + "name": "Signata", + "symbol": "SATA", + "decimals": 18, + "address": "0x2E0f9A07d0ef445dB402d1c656ea6b71af81cb65", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3ebb4A4e91Ad83BE51F8d596533818b246F4bEe1" + } + }, + { + "chainId": 137, + "name": "Mechanium", + "symbol": "$MECHA", + "decimals": 18, + "address": "0xaCd4E2d936Be9B16c01848A3742A34B3D5A5bDfa", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc5bcc8ba3f33ab0d64f3473e861bdc0685b19ef5" + } + }, + { + "chainId": 137, + "name": "BeverageBar", + "symbol": "xDRINK", + "decimals": 18, + "address": "0x5a7aAdDD5F1d343fA4248c3e2A02d8a18626b9d0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf6344740921c858229c7b39be530d6cb2b704f7a" + } + }, + { + "chainId": 137, + "name": "ANGLE", + "symbol": "ANGLE", + "decimals": 18, + "address": "0x900F717EA076E1E7a484ad9DD2dB81CEEc60eBF1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x31429d1856ad1377a8a0079410b297e1a9e214c2" + } + }, + { + "chainId": 137, + "name": "agEUR", + "symbol": "agEUR", + "decimals": 18, + "address": "0xE0B52e49357Fd4DAf2c15e02058DCE6BC0057db4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1a7e4e63778b4f12a199c062f3efdd288afcbce8" + } + }, + { + "chainId": 137, + "name": "Decentral Games Governance", + "symbol": "xDG", + "decimals": 18, + "address": "0xc6480Da81151B2277761024599E8Db2Ad4C388C8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4f81c790581b240a5c948afd173620ecc8c71c8d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/xdg.svg" + }, + { + "chainId": 137, + "name": "DoubleDice Token", + "symbol": "DODI", + "decimals": 18, + "address": "0x5B03aC408938C97e50db3bC5675d182606A01377", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4E08F03079c5CD3083eA331Ec61bCC87538B7665" + } + }, + { + "chainId": 137, + "name": "Decentral Games", + "symbol": "DG", + "decimals": 18, + "address": "0xef938b6da8576a896f6E0321ef80996F4890f9c4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4b520c812e8430659fc9f12f6d0c39026c83588d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dg.svg" + }, + { + "chainId": 137, + "name": "AWACOIN", + "symbol": "AWA", + "decimals": 18, + "address": "0xb915894B10e0C30B8A9c8bf2a0c521961bb18593", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdeccdc7fc3f0959e9e384db33e87086208701e2c" + } + }, + { + "chainId": 137, + "name": "Hub Token", + "symbol": "HUB", + "decimals": 18, + "address": "0xA4f40Bd861431186aA0648B9c57aF0313d2d2f57", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xba358B6f5b4c0215650444B8C30D870B55050D2D" + } + }, + { + "chainId": 137, + "name": "Shibnobi", + "symbol": "SHINJA", + "decimals": 9, + "address": "0x184BC6A6040F139027e9659dC2b87BFcfde4a39e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xab167e816e4d76089119900e941befdfa37d6b32" + } + }, + { + "chainId": 137, + "name": "MultiChainCapital", + "symbol": "MCC", + "decimals": 9, + "address": "0xE499140A7362927bB23889c4D60A6B9b3347F8ca", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1a7981d87e3b6a95c1516eb820e223fe979896b3" + } + }, + { + "chainId": 137, + "name": "#The Wanderers — Down The Wormhole", + "symbol": "WDW", + "decimals": 18, + "address": "0x822c03792acd5274237B031EC8e48456f48E1211", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf021ed0785812c1b74365b7ee4395cd1b274d95b" + } + }, + { + "chainId": 137, + "name": "Reach Four the Stars", + "symbol": "R4S", + "decimals": 18, + "address": "0x1B0cC1A5D296fda5971d582dbb87B07fB120B92c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8c930c8574f9c3a6f1252e5a2e912dc69b463a0c" + } + }, + { + "chainId": 137, + "name": "X Guardian Marks the Spot", + "symbol": "XGMTS", + "decimals": 18, + "address": "0xD53cb20f90187636bbA1b08B4f96a018a141dE63", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2950f509ce6db2294e9a7f61b1e3d96bcd5b1138" + } + }, + { + "chainId": 137, + "name": "Sniper Squad 17", + "symbol": "SS17", + "decimals": 18, + "address": "0xC226374dd015445084A2b4c348Bde4aFfd950Ad9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc795ed2ab78ad1c451af4a6db87d878760b9072e" + } + }, + { + "chainId": 137, + "name": "Sniper Squad 16", + "symbol": "SS16", + "decimals": 18, + "address": "0xaEF7E3Da2bb3438D8540A6AbE27095EA89f3B3B0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa958f28358771ac95a570d2921cf410f51d176c2" + } + }, + { + "chainId": 137, + "name": "MAX Token", + "symbol": "MAX", + "decimals": 18, + "address": "0x9634aF3af2f392505369fCFe56691790CEa345B4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe7976c4efc60d9f4c200cc1bcef1a1e3b02c73e7" + } + }, + { + "chainId": 137, + "name": "BBGO", + "symbol": "BBG", + "decimals": 18, + "address": "0x3Afe98235d680e8d7A52e1458a59D60f45F935C0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3Afe98235d680e8d7A52e1458a59D60f45F935C0" + } + }, + { + "chainId": 137, + "name": "VMart Token", + "symbol": "VMC", + "decimals": 18, + "address": "0x2694e54166a1Aa849131781273Cd3bf214309642", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x715c218A882bb4fa3627D4CE15a6324716D3CDFA" + } + }, + { + "chainId": 137, + "name": "LUXY", + "symbol": "LUXY", + "decimals": 18, + "address": "0xD4945a3D0De9923035521687D4bf18cC9B0c7c2A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5e0fDcDb61Ec98D5Ed4E23b3d539Fb3722C940A6" + } + }, + { + "chainId": 137, + "name": "Simarglum", + "symbol": "GLUM", + "decimals": 8, + "address": "0x481791e5c37cF831Ed03742C7C5B5cFFA83A27D4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xddbe9cc1dfd7e305df1f70b69590ada38878024f" + } + }, + { + "chainId": 137, + "name": "Request Token", + "symbol": "REQ", + "decimals": 18, + "address": "0xAdf2F2Ed91755eA3f4bcC9107a494879f633ae7C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8f8221afbb33998d8584a2b05749ba73c37a938a" + } + }, + { + "chainId": 137, + "name": "Luffy Inu", + "symbol": "LUFFY", + "decimals": 9, + "address": "0x8449d85Fc7989Ad7F34F8dA986F512aEa9E6920E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc1bfccd4c29813ede019d00d2179eea838a67703" + } + }, + { + "chainId": 137, + "name": "PROTEIN", + "symbol": "PRTN", + "decimals": 18, + "address": "0x67561239d0fd07A37B5621ae7C2b2F1413491033", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfec2fa7edd428171103e8f81911af5be9d31eeba" + } + }, + { + "chainId": 137, + "name": "Unbox.Art", + "symbol": "UBA", + "decimals": 18, + "address": "0xE24C8E7c61d4545eB69f13Dc9b1f40Cff679bA07", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x817e2aDdceAA4907623666A7800b1553Ca21192d" + } + }, + { + "chainId": 137, + "name": "I Bet You", + "symbol": "IBY", + "decimals": 18, + "address": "0x059eb35959B5Ad5A37Ce9198726CAB84824fd690", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6a68de599e8e0b1856e322ce5bd11c5c3c79712b" + } + }, + { + "chainId": 137, + "name": "Lattice Token", + "symbol": "LTX", + "decimals": 8, + "address": "0x641675a002021f645117287c92A20059b6A347F9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa393473d64d2F9F026B60b6Df7859A689715d092" + } + }, + { + "chainId": 137, + "name": "Verse", + "symbol": "VERSE", + "decimals": 18, + "address": "0xa67C1CC2ADF4969667980811b65A456D204D7Ce5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe18841d7a75866688e291703bde66c3378bd74a3" + } + }, + { + "chainId": 137, + "name": "Aidi Inu", + "symbol": "AIDI", + "decimals": 9, + "address": "0x5BA499a413E6AfCAFc7a79A73AaCE4bd94a8a33A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xda1e53e088023fe4d1dc5a418581748f52cbd1b8" + } + }, + { + "chainId": 137, + "name": "Tuo Luo BlockChain", + "symbol": "TLBC", + "decimals": 2, + "address": "0x3FC98379bB51bBefDfb882bE2Bb928D118a1990A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3fca60965bb0035d38b95cb528ef231ed8905911" + } + }, + { + "chainId": 137, + "name": "TLB", + "symbol": "TLB", + "decimals": 8, + "address": "0xd4744644449c47FE07b110B53aB0c5415b2Ec346", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x317aB43DE10c70802De1A5e79E7C6A745520ceB0" + } + }, + { + "chainId": 137, + "name": "Refraction", + "symbol": "REFRACT", + "decimals": 18, + "address": "0x1c483C609fa8BB24a27d97752876a9Fb9FBDB749", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc6e86dad13ece397f23c6ab3ed85f894daab6884" + } + }, + { + "chainId": 137, + "name": "Sarcophagus", + "symbol": "SARCO", + "decimals": 18, + "address": "0x80Ae3B3847E4e8Bd27A389f7686486CAC9C3f3e8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7697b462a7c4ff5f8b55bdbc2f4076c2af9cf51a" + } + }, + { + "chainId": 137, + "name": "Follow", + "symbol": "FOLO", + "decimals": 18, + "address": "0xeF205F99bD869e74b16050199d54327a0eCd343D", + "logoURI": "https://etherscan.io/token/images/alphaimpact_32.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb2a63a5dd36c91ec2da59b188ff047f66fac122a" + } + }, + { + "chainId": 137, + "name": "SHAMAN KING INU", + "symbol": "SHAMAN", + "decimals": 9, + "address": "0x353bb01c07e5DcA9819bf7b004c2a3465D29851f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf98e38c3f287304a1f2d4879e741d2bf55474e84" + } + }, + { + "chainId": 137, + "name": "Hokage Inu", + "symbol": "HOKAGE", + "decimals": 9, + "address": "0x83CC0e81467ED905DfF9b3621f570D01906AcBd5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1a90bb2a0024b35b54c8b8c6b5313c32470c134b" + } + }, + { + "chainId": 137, + "name": "EtherDoge", + "symbol": "EDOGE", + "decimals": 18, + "address": "0x303B2d090E5aE3A9AAFAe3551F2fF3837820c296", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8a7b7b9b2f7d0c63f66171721339705a6188a7d5" + } + }, + { + "chainId": 137, + "name": "Edge", + "symbol": "EDGE", + "decimals": 18, + "address": "0x439207292E5452F82ABeD7D5b74089e2b46C85c5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4ec1b60b96193a64acae44778e51f7bff2007831" + } + }, + { + "chainId": 137, + "name": "Safe Shield", + "symbol": "SFSHLD", + "decimals": 9, + "address": "0xB08AdF932641B1E99250150ff3287f45B30685F0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x11a605d7e12b64d713e93c487277d819a1d14b99" + } + }, + { + "chainId": 137, + "name": "DeFI Trade Token", + "symbol": "DTT", + "decimals": 18, + "address": "0x1214D61f3dAA45Af4a5f301075C58fBE57c8E6d7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1214d61f3daa45af4a5f301075c58fbe57c8e6d7" + } + }, + { + "chainId": 137, + "name": "Vault Hill City", + "symbol": "VHC", + "decimals": 18, + "address": "0x51b5619F5180e333d18b6310C8D540AEa43a0371", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x60E14651d0Df26D114E5B55be970B76eC9f3eF74" + } + }, + { + "chainId": 137, + "name": "IGRY Coin", + "symbol": "IGRY", + "decimals": 18, + "address": "0xAFbABAa1591d1Afa0F62935E95265cb937C2facF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaeF9F1e06805201fc4644267ee05Ac0905F767b9" + } + }, + { + "chainId": 137, + "name": "Saitama Inu", + "symbol": "SAITAMA", + "decimals": 9, + "address": "0x7582a64734f40c1eAa23144Fc43cA1a748723527", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8B3192f5eEBD8579568A2Ed41E6FEB402f93f73F" + } + }, + { + "chainId": 137, + "name": "Wrapped Anchor UST Token", + "symbol": "aUST", + "decimals": 18, + "address": "0x522a3Bd54d5D6a9CC67592e31Cc1A745630daF50", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa8de3e3c934e2a1bb08b010104ccabbd4d6293ab" + } + }, + { + "chainId": 137, + "name": "PICIPO", + "symbol": "PICIPO", + "decimals": 18, + "address": "0xD49E6e4Ea56eB71e45809ff208eaFD053653D95C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1e05f68B29b286FB3BbAd3c688D7e2ABda549b80" + } + }, + { + "chainId": 137, + "name": "ZUG", + "symbol": "ZUG", + "decimals": 18, + "address": "0x9582b02d5AC3eb6940AE02E6d4ab220c3ca9d317", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfEE5F54e1070e7eD31Be341e0A5b1E847f6a84Ab" + } + }, + { + "chainId": 137, + "name": "Tiger King", + "symbol": "TKING", + "decimals": 18, + "address": "0xc79745bf7C00D7D78cF7A3713c798fAee8f7DC45", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x24e89bdf2f65326b94e36978a7edeac63623dafa" + } + }, + { + "chainId": 137, + "name": "Seed", + "symbol": "SEED", + "decimals": 18, + "address": "0xEAeCC18198a475c921B24b8A6c1C1f0f5F3F7EA0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x30cf203b48edaa42c3b4918e955fed26cd012a3f" + } + }, + { + "chainId": 137, + "name": "DOG COLLAR", + "symbol": "COLLAR", + "decimals": 18, + "address": "0xd5fa77A860FeA9cFf31DA91BbF9e0FaEa9538290", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9783b81438c24848f85848f8df31845097341771" + } + }, + { + "chainId": 137, + "name": "CANDI", + "symbol": "CANDI", + "decimals": 18, + "address": "0xa06657B69bD9462a468ad6533B4B819CAeE8B29E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3aa1bd53318a73d2fc41a1dd5de1aa9a0206a5d8" + } + }, + { + "chainId": 137, + "name": "Sustainable Opportunity Matrix", + "symbol": "SOM", + "decimals": 9, + "address": "0x10C5A602c7661E916a863B3BD164796D6CdD3d72", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4Cb5108603BC702F951A7a1D777Ee24E21303B95" + } + }, + { + "chainId": 137, + "name": "Zombie Inu", + "symbol": "ZINU", + "decimals": 9, + "address": "0xbF979592FB6B57B4293D0D7EEd0E093478a5C890", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc50ef449171a51fbeafd7c562b064b6471c36caa" + } + }, + { + "chainId": 137, + "name": "JAX Token", + "symbol": "JAX", + "decimals": 18, + "address": "0x5cfDF4CCa482d419dA979C10B70039c28F2a1f08", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xE34f533f537b0BdfC2FDDC6fF2a85fF0cb1A75D1" + } + }, + { + "chainId": 137, + "name": "BitcoinVend", + "symbol": "BCVT", + "decimals": 18, + "address": "0x07fcd81Bf6156e49c64f0ba70f962A9F5111D39d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8d717ab5eac1016b64c2a7fd04720fd2d27d1b86" + } + }, + { + "chainId": 137, + "name": "AXIA COIN", + "symbol": "AXC", + "decimals": 18, + "address": "0x83Ce0b442Ec51CfA62310Aa1789210CFE2c5556E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x37c430c2b5f9Ff85e534873C715871818Ab1623E" + } + }, + { + "chainId": 137, + "name": "Shiryo-Inu", + "symbol": "Shiryo-Inu", + "decimals": 9, + "address": "0xBB812fd66b98A38f2bF6A22759462f0993C1DBBE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1E2F15302B90EddE696593607b6bD444B64e8F02" + } + }, + { + "chainId": 137, + "name": "Dogs Of Elon", + "symbol": "DOE", + "decimals": 18, + "address": "0x07D496919669c88CCeC363c55df98d494fd4D796", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf8e9f10c22840b613cda05a0c5fdb59a4d6cd7ef" + } + }, + { + "chainId": 137, + "name": "Kitty Inu", + "symbol": "kitty", + "decimals": 9, + "address": "0xCBEa86af7581594d85d44469429bC6A273F9B562", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x044727e50ff30DB57fad06Ff4F5846eAb5eA52a2" + } + }, + { + "chainId": 137, + "name": "Ethereum Name Service", + "symbol": "ENS", + "decimals": 18, + "address": "0xbD7A5Cf51d22930B8B3Df6d834F9BCEf90EE7c4f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc18360217d8f7ab5e7c516566761ea12ce7f9d72" + } + }, + { + "chainId": 137, + "name": "WhaleStreet $hrimp Token", + "symbol": "$HRIMP", + "decimals": 18, + "address": "0xb8218785cb4d14dBdD94Bf314F361542579b4815", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9077f9e1efe0ea72867ac89046b2a6264cbcaef5" + } + }, + { + "chainId": 137, + "name": "SOCIETY OF GALACTIC EXPLORATION", + "symbol": "SGE", + "decimals": 9, + "address": "0x6041551eca4fDcB55e3Fb91fe8d9f460C4Ddeca7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xab456bdb0a373bbac6c4a76176e9f159cacd5752" + } + }, + { + "chainId": 137, + "name": "RDomainToken For 0xac2c11ea5d4a4826f418d3befbf0537de7f13572d2a433edfe4a7314ea5dc896", + "symbol": "ac2c11ea", + "decimals": 18, + "address": "0x31168476A4a722f639C2EDB69281E0B2585eefCF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc4911f7eed42aef8e4cf24020f63f5e8b7b56372" + } + }, + { + "chainId": 137, + "name": "National Bank of Coin", + "symbol": "NBC", + "decimals": 18, + "address": "0x4Fb19d9Cc639c556Db433e7cb63722ceB2289AF0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x96E12Ec9e0D333a52f87713ee03f23fB715FC228" + } + }, + { + "chainId": 137, + "name": "Finiko", + "symbol": "FNK", + "decimals": 18, + "address": "0x2ca402536721Db44286564dC0Dd807aeaB60cec5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb5fe099475d3030dde498c3bb6f3854f762a48ad" + } + }, + { + "chainId": 137, + "name": "Kiba Inu", + "symbol": "KIBA", + "decimals": 9, + "address": "0x73Bee5D745dA8b0c39437Df8EAf64CE0589A6575", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4b2c54b80b77580dc02a0f6734d3bad733f50900" + } + }, + { + "chainId": 137, + "name": "Gods Unchained", + "symbol": "GODS", + "decimals": 18, + "address": "0xF88fc6b493eda7650E4bcf7A290E8d108F677CfE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xccc8cb5229b0ac8069c51fd58367fd1e622afd97" + } + }, + { + "chainId": 137, + "name": "StarLink", + "symbol": "STARL", + "decimals": 18, + "address": "0xe8b6f80454B9c2e6905FE2b1BD5DB5223657Fa21", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8e6cd950ad6ba651f6dd608dc70e5886b1aa6b24" + } + }, + { + "chainId": 137, + "name": "Nolly Coin", + "symbol": "NOLLY", + "decimals": 18, + "address": "0x350c8db3E569D4445dD81AD0F1C628f7f6e0187f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb69096a89389638518725adfcf279f3f82efa2de" + } + }, + { + "chainId": 137, + "name": "Lith Token", + "symbol": "LITH", + "decimals": 18, + "address": "0xFd75cd593AacE53731f240F32Ec4756A957b3344", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf8a4a419c2d7140e49ef952a7e7ae1bd4a8b6b9c" + } + }, + { + "chainId": 137, + "name": "Dobermann", + "symbol": "DOBE", + "decimals": 18, + "address": "0x24705371bE6eE97E5780646fb60B8396058C1798", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe7ab45162f5979f09b0bda1cc7dfc97c270ea3d5" + } + }, + { + "chainId": 137, + "name": "BitSpawn Token", + "symbol": "SPWN", + "decimals": 18, + "address": "0xD882b0ac8cCc38c88eB1486B6Ce8486f102FE3Ac", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe516d78d784c77d479977be58905b3f2b1111126" + } + }, + { + "chainId": 137, + "name": "KickToken", + "symbol": "KICK", + "decimals": 10, + "address": "0xE64ACF4ec1dc9a112Ab705ad927ccB17427aEFb5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x824a50df33ac1b41afc52f4194e2e8356c17c3ac" + } + }, + { + "chainId": 137, + "name": "BankSocial", + "symbol": "BSL", + "decimals": 8, + "address": "0xE439273659B86e33716BCF7Ad22408B541df50B1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0af55d5ff28a3269d69b98680fd034f115dd53ac" + } + }, + { + "chainId": 137, + "name": "Somnium Space Cubes", + "symbol": "CUBE", + "decimals": 8, + "address": "0x276C9cbaa4BDf57d7109a41e67BD09699536FA3d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdf801468a808a32656d2ed2d2d80b72a129739f4" + } + }, + { + "chainId": 137, + "name": "Derived Ether", + "symbol": "dEth", + "decimals": 18, + "address": "0xB8e89dCd3025b05784cc5DaeA3108b697Ffb6697", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x51863Ec92BA14ede7B17fb2B053145C90E215A57" + } + }, + { + "chainId": 137, + "name": "Value Network Token", + "symbol": "VNTW", + "decimals": 18, + "address": "0xFBa8a25156c33FEcbE84f57c2d45C1d50f5afcd0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd0f05d3d4e4d1243ac826d8c6171180c58eaa9bc" + } + }, + { + "chainId": 137, + "name": "MatrixETF DAO Finance", + "symbol": "MDF", + "decimals": 18, + "address": "0x700B9dE93E2Fd5455cB91C474DAd6cfEa6598F64", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1a57367c6194199e5d9aea1ce027431682dfb411" + } + }, + { + "chainId": 137, + "name": "Illuvium", + "symbol": "ILV", + "decimals": 18, + "address": "0xFA46dAf9909e116DBc40Fe1cC95fC0Bb1f452aBE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x767fe9edc9e0df98e07454847909b5e959d7ca0e" + } + }, + { + "chainId": 137, + "name": "BlueSparrowToken", + "symbol": "BlueSparrow", + "decimals": 9, + "address": "0x3c6D9c9296f8a87BE0Cb639167E152D46c831087", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4d67edef87a5ff910954899f4e5a0aaf107afd42" + } + }, + { + "chainId": 137, + "name": "Phantasma Energy", + "symbol": "KCAL", + "decimals": 10, + "address": "0xEf101840250783B6F1004510333c7a6F37B1452a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x14EB60F5f270B059B0c788De0Ddc51Da86f8a06d" + } + }, + { + "chainId": 137, + "name": "Blastoise Inu", + "symbol": "BLAST", + "decimals": 9, + "address": "0x95f3B277b5A688f78Ab0047bD298f09fB263E089", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5167f7cdeb771417d8722e654ccc3e1734a01878" + } + }, + { + "chainId": 137, + "name": "Feisty Doge NFT", + "symbol": "NFD", + "decimals": 18, + "address": "0x0A5926027d407222F8fe20f24cB16e103f617046", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdfdb7f72c1f195c5951a234e8db9806eb0635346" + } + }, + { + "chainId": 137, + "name": "Alpha Fund", + "symbol": "AVA", + "decimals": 18, + "address": "0x422361E0E97CbfD5f95d5A50f50598A6fC4D8ce6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa16001dd47f505b7b7c5639c710a52209e4e8904" + } + }, + { + "chainId": 137, + "name": "the metaverse game hub", + "symbol": "MGH", + "decimals": 18, + "address": "0xc3C604F1943B8C619c5D65cd11A876e9C8eDCF10", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8765b1a0eb57ca49be7eacd35b24a574d0203656" + } + }, + { + "chainId": 137, + "name": "gameswap.org", + "symbol": "GSWAP", + "decimals": 18, + "address": "0xB6Ff0EAaC1b4b415a5175803f16896b09B2Db175", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaac41ec512808d64625576eddd580e7ea40ef8b2" + } + }, + { + "chainId": 137, + "name": "DefiOptions", + "symbol": "DOD", + "decimals": 18, + "address": "0x7E6663D14F058880FAD199BCb745a81c46407809", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfc7e3cFA47fbF90310ec203F46fEe1af2771548c" + } + }, + { + "chainId": 137, + "name": "THX Network", + "symbol": "THX", + "decimals": 18, + "address": "0x2934b36ca9A4B31E633C5BE670C8C8b28b6aA015", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe632ea2ef2cfd8fc4a2731c76f99078aef6a4b31" + } + }, + { + "chainId": 137, + "name": "Popcorn", + "symbol": "POP", + "decimals": 18, + "address": "0xC5B57e9a1E7914FDA753A88f24E5703e617Ee50c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd0cd466b34a24fcb2f87676278af2005ca8a78c4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pop.svg" + }, + { + "chainId": 137, + "name": "ChilliSwap Token", + "symbol": "CHLI", + "decimals": 18, + "address": "0x12b54baA8FFcFd6679CcF1AE618ca3006cFcc2aC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x12b54baA8FFcFd6679CcF1AE618ca3006cFcc2aC" + } + }, + { + "chainId": 137, + "name": "Piccolo Inu", + "symbol": "PINU", + "decimals": 9, + "address": "0x298018eEEC6D4A38Aa33AB73Bf4954b9D1af68fC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3a1311b8c404629e38f61d566cefefed083b9670" + } + }, + { + "chainId": 137, + "name": "Mononoke Inu", + "symbol": "Mononoke-Inu", + "decimals": 9, + "address": "0x0e857076EA922630C844A047f4bB7342f2ED59e2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4da08a1bff50be96bded5c7019227164b49c2bfc" + } + }, + { + "chainId": 137, + "name": "Wrapped Kagra", + "symbol": "WKGR", + "decimals": 18, + "address": "0xfAf25C39eA29c3Aa4A0bFbdbcf2dd99845192695", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xEb6D29A33D129407a734C2824288e6A0a6a5EF12" + } + }, + { + "chainId": 137, + "name": "GOL", + "symbol": "GOL", + "decimals": 8, + "address": "0x700481409de3f632F61a2AC9BFd76138357714da", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x48094ebe2266cb1cbe5d3ec81933784e2e9561d8" + } + }, + { + "chainId": 137, + "name": "THIS", + "symbol": "THIS", + "decimals": 18, + "address": "0x1b89c7E4C0967E7052144b446FA6cD4Ac94abd2B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xDe03B301C22613EAc93a74526d55D40D6a8B923b" + } + }, + { + "chainId": 137, + "name": "Sandclock", + "symbol": "QUARTZ", + "decimals": 18, + "address": "0xA91FE5a535967F52D3abEBDFFb3B306D964ace13", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbA8A621b4a54e61C442F5Ec623687e2a942225ef" + } + }, + { + "chainId": 137, + "name": "PIXA Token", + "symbol": "PIXA", + "decimals": 0, + "address": "0xcA8C6dEa40a6De9BE3b4C73a1AeFAafdb4754f73", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeaf211cD484118a23AD71C3F9073189C43d1311c" + } + }, + { + "chainId": 137, + "name": "sUKHI", + "symbol": "sUKH", + "decimals": 18, + "address": "0x6BD9da80D6A7AA03D739353096df36Ec18738C99", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x538429C057c8695c62194028c57B540C4Bf13a6c" + } + }, + { + "chainId": 137, + "name": "bUKHI", + "symbol": "bUKH", + "decimals": 18, + "address": "0xef3943736181F259A4e94D9D6D8658996fB9F785", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeFe2aFB5f2a9EA8Ec6D8a57FE88fEBCFE29db813" + } + }, + { + "chainId": 137, + "name": "MerchDAO", + "symbol": "MRCH", + "decimals": 18, + "address": "0x4dF071FB2D145bE595b767f997C91818694A6CE1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbed4ab0019ff361d83ddeb74883dac8a70f5ea1e" + } + }, + { + "chainId": 137, + "name": "holon", + "symbol": "HLN", + "decimals": 18, + "address": "0xfb57dc345cB5e155B0437A71B5e28557B557488a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1aAE3148F5B5F576159835c4C56fF844a7Da4f7e" + } + }, + { + "chainId": 137, + "name": "Nexity Network", + "symbol": "NXT", + "decimals": 18, + "address": "0x76B032370987e91c515d1b96eBD04DE059BeC534", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xebeef419bb5a347e3d98f7d2168055214d12cbdb" + } + }, + { + "chainId": 137, + "name": "Sesamers", + "symbol": "SESAME", + "decimals": 18, + "address": "0xadA94b6C6D263807070AB7378FCA3dfA45ec8E4c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x69d0391F9fE3f29BB226814c27896fc0558B370E" + } + }, + { + "chainId": 137, + "name": "ASIA COIN", + "symbol": "ASIA", + "decimals": 18, + "address": "0x50bCBC40306230713239Ae1BdDD5eefEEaa273Dc", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF519381791C03DD7666C142D4E49Fd94d3536011" + } + }, + { + "chainId": 137, + "name": "BitcoinSoV", + "symbol": "BSOV", + "decimals": 8, + "address": "0x955afB81880f439A2Db194f051aFEd078Fb2Ec2E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x26946ada5ecb57f3a1f91605050ce45c482c9eb1" + } + }, + { + "chainId": 137, + "name": "Nemesis", + "symbol": "NMS", + "decimals": 18, + "address": "0xf41DF3B8084f1bcbf8D72C8366392170E7a0cFFD", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x77252494c25444f8598a0c74ffc90adc535291a9" + } + }, + { + "chainId": 137, + "name": "Tribe", + "symbol": "TRIBE", + "decimals": 18, + "address": "0x8676815789211E799a6DC86d02748ADF9cF86836", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc7283b66eb1eb5fb86327f08e1b5816b0720212b" + } + }, + { + "chainId": 137, + "name": "Tanks", + "symbol": "TANKS", + "decimals": 18, + "address": "0xf4BF1B42181198c1c2E12e24e3e57c8d70b89411", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf604d1e51122592e0babe63ac334c0e647222f2d" + } + }, + { + "chainId": 137, + "name": "Crypto Nijigen", + "symbol": "NGN", + "decimals": 10, + "address": "0x4C2C04E6f0ec30EbD60b2fFbE11814C3d59910f7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2b5C21578594F7988C7c80D258d0C927C756a848" + } + }, + { + "chainId": 137, + "name": "Unique Utility Token", + "symbol": "UNQT", + "decimals": 18, + "address": "0x3bEeff1b01122F11149B11604a2bC4f9e33D77aF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa80f2C8f61c56546001f5FC2eb8D6E4e72c45d4C" + } + }, + { + "chainId": 137, + "name": "Mork", + "symbol": "MORK", + "decimals": 4, + "address": "0xa707734BD310883e133e0ca23F6C166AEB2A1A7a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf552b656022c218c26dad43ad88881fc04116f76" + } + }, + { + "chainId": 137, + "name": "UNCL", + "symbol": "UNCL", + "decimals": 18, + "address": "0x97C415D4c8ea982aaabCBb65506D37FA6631C351", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2f4eb47A1b1F4488C71fc10e39a4aa56AF33Dd49" + } + }, + { + "chainId": 137, + "name": "AGAIN", + "symbol": "AGAIN", + "decimals": 18, + "address": "0x05bE4f635b558E791b68B500FD9210f60E4f3Db8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc01a327e30b0fbf32861333f238b5c36a60abc09" + } + }, + { + "chainId": 137, + "name": "LikeCoin", + "symbol": "LIKE", + "decimals": 9, + "address": "0x522250b17AdcaECE287E9dA25dC1dDAd742213C0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7588fEFd8D087A7EE3F568087190209F7B449b28" + } + }, + { + "chainId": 137, + "name": "BakedToken", + "symbol": "BAKED", + "decimals": 18, + "address": "0x32515ffdc3a84cfbf9AD4dB14EF8f0A535c7Afd6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa4cb0dce4849bdcad2d553e9e68644cf40e26cce" + } + }, + { + "chainId": 137, + "name": "Sandalwood", + "symbol": "Sandalwood", + "decimals": 18, + "address": "0xe99e95ec6DCae4c85806F13CDf1351aE0FEf55Be", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4FA80013F5d13DB10f2c5DC2987081cb48c7c069" + } + }, + { + "chainId": 137, + "name": "BLOCKS", + "symbol": "BLOCKS", + "decimals": 18, + "address": "0x983C0083127b9b65000E918b10d65A0F5d7500F5", + "tags": [ + "pos", + "erc20" + ], + "logoURI": "https://changenow.io/images/sprite/currencies/blocks.svg", + "extensions": { + "rootAddress": "0x8a6d4c8735371ebaf8874fbd518b56edd66024eb" + } + }, + { + "chainId": 137, + "name": "Genesis Worlds", + "symbol": "GENESIS", + "decimals": 18, + "address": "0x51869836681BcE74a514625c856aFb697a013797", + "logoURI": "https://svgshare.com/i/fJk.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6b6F09997EbFa93F4E111c33825da3b938462FF1" + } + }, + { + "chainId": 137, + "name": "Euro Tether", + "symbol": "EURT", + "decimals": 6, + "address": "0x7BDF330f423Ea880FF95fC41A280fD5eCFD3D09f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc581b735a1688071a1746c968e0798d642ede491" + } + }, + { + "chainId": 137, + "name": "NZD Stablecoin", + "symbol": "NZDS", + "decimals": 6, + "address": "0xeaFE31Cd9e8E01C8f0073A2C974f728Fb80e9DcE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xDa446fAd08277B4D2591536F204E018f32B6831c" + } + }, + { + "chainId": 137, + "name": "Matic Mike Juice", + "symbol": "HGH", + "decimals": 18, + "address": "0xE97a60f5D34dA4f68bc1f1b9CE2C19Ec1A33E928", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x45fFdeC3fc3b475220c0Fdd3e80c3692bc711E0e" + } + }, + { + "chainId": 137, + "name": "CRE8R DAO", + "symbol": "CRE8R", + "decimals": 18, + "address": "0x079202AD852ccc46d8E73815f10Ff055049D3916", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaa61d5dec73971cd4a026ef2820bb87b4a4ed8d6" + } + }, + { + "chainId": 137, + "name": "Wallstreetbets", + "symbol": "WSB", + "decimals": 18, + "address": "0x4CB9050EA02395a8941715ceeffe0cDf60c59f07", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8DF586aa346c3d9d1c99A21316A2735d71355eC8" + } + }, + { + "chainId": 137, + "name": "Virtual Cash", + "symbol": "vCASH", + "decimals": 18, + "address": "0x7621eE0CE0F686b88dD70551B05F90dd3C04d6e9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x532D7ebE4556216490c9d03460214b58e4933454" + } + }, + { + "chainId": 137, + "name": "HashRush", + "symbol": "RUSH", + "decimals": 8, + "address": "0x8e8f8DF6dcE311A011A5B09788ddA689A82d9F37", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcfcd43d7ee21416a71c2eb9888587d52716fc77a" + } + }, + { + "chainId": 137, + "name": "Enjinstarter", + "symbol": "EJS", + "decimals": 18, + "address": "0x71A6e3D6A6629F700D1A4D79D326e2A3F74eDd5f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x96610186F3ab8d73EBEe1CF950C750f3B1Fb79C2" + } + }, + { + "chainId": 137, + "name": "Bored Banana Token", + "symbol": "$BANANA", + "decimals": 0, + "address": "0x6393c0a63712601e3Dda577dc5Bfaf0189e89169", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe17093967e43D37Ad615a64cb86aE11826D6e58b" + } + }, + { + "chainId": 137, + "name": "Daily COP", + "symbol": "DLYCOP", + "decimals": 18, + "address": "0x1659fFb2d40DfB1671Ac226A0D9Dcc95A774521A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1659fFb2d40DfB1671Ac226A0D9Dcc95A774521A" + } + }, + { + "chainId": 137, + "name": "SushiBar", + "symbol": "xSUSHI", + "decimals": 18, + "address": "0x6811079E3c63ED96Eb005384d7E7ec8810E3D521", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8798249c2E607446EfB7Ad49eC89dD1865Ff4272" + } + }, + { + "chainId": 137, + "name": "Folder Coin", + "symbol": "FOL", + "decimals": 18, + "address": "0xA8F0634F1Ab83Bc31e4cE33905db29E36958C5cc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa8580f3363684d76055bdc6660caefe8709744e1" + } + }, + { + "chainId": 137, + "name": "Bollycoin", + "symbol": "BOLLY", + "decimals": 18, + "address": "0x7Dc47Cfb674bEb5827283F6140F635680A5cE992", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6bd361e10c1afed0d95259e7C0115f3A60e4ea99" + } + }, + { + "chainId": 137, + "name": "Ojamu Token", + "symbol": "OJA", + "decimals": 18, + "address": "0x26373EC913876C9e6d38494dde458Cb8649cb30c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0aa7efe4945db24d95ca6e117bba65ed326e291a" + } + }, + { + "chainId": 137, + "name": "NIFTSY", + "symbol": "NIFTSY", + "decimals": 18, + "address": "0x432cdbC749FD96AA35e1dC27765b23fDCc8F5cf1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7728cd70b3dD86210e2bd321437F448231B81733" + } + }, + { + "chainId": 137, + "name": "Dexmex", + "symbol": "DEXM", + "decimals": 18, + "address": "0xd9C774a5BB7fdE18c3e03a59c40d7c77d0B90910", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0020d80229877b495D2bf3269a4c13f6f1e1B9D3" + } + }, + { + "chainId": 137, + "name": "Entropy", + "symbol": "ERP", + "decimals": 18, + "address": "0x28accA4ed2F6186c3D93e20e29e6e6a9Af656341", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0a0e3bfD5a8cE610E735D4469Bc1b3b130402267" + } + }, + { + "chainId": 137, + "name": "Nexen", + "symbol": "NXN", + "decimals": 18, + "address": "0x4E6A6cE59Ca7AA0CBc52dbD81aB2dEA89D7ECcF2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbec8d5c639778652dc2440da996a6bcf43f07746" + } + }, + { + "chainId": 137, + "name": "MovieBizCoin", + "symbol": "MBZ", + "decimals": 8, + "address": "0xf932A6F93432517192C71db155bE3d9C7402fbbA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd8b110beee01e74dba9be687fc247c550a41cffe" + } + }, + { + "chainId": 137, + "name": "Human Token", + "symbol": "HMT", + "decimals": 18, + "address": "0xc748B2A084F8eFc47E086ccdDD9b7e67aEb571BF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd1ba9bac957322d6e8c07a160a3a8da11a0d2867" + } + }, + { + "chainId": 137, + "name": "ethbox Token", + "symbol": "EBOX", + "decimals": 18, + "address": "0x8c48aC62F1ECd20EC72f0B1a9a3Bc33eb4B93828", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x33840024177a7daca3468912363bed8b425015c5" + } + }, + { + "chainId": 137, + "name": "OBORTECH", + "symbol": "OBOT", + "decimals": 18, + "address": "0x3522898a74959A16C43F59055392b2Fce48727d0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xedadeb5faa413e6c8623461849dfd0b7c3790c32" + } + }, + { + "chainId": 137, + "name": "50MM", + "symbol": "50MM", + "decimals": 18, + "address": "0xE4e8056A49E35dbDe67384bEdCEE310B9693D4d6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3239ebFA182B04DfCA2A15ccf81AF97C024ce0e0" + } + }, + { + "chainId": 137, + "name": "Wrapped PECO", + "symbol": "PECO", + "decimals": 18, + "address": "0x13607B1ca022368c81f2f2709b181ee8e0f42dD6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9d3EE6B64e69Ebe12a4bF0b01D031CB80F556eE4" + } + }, + { + "chainId": 137, + "name": "MaidCoin", + "symbol": "$MAID", + "decimals": 18, + "address": "0xCf9F8BBfB65BA5F7491e61e542c72F00Ff4DACc4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4Af698B479D0098229DC715655c667Ceb6cd8433" + } + }, + { + "chainId": 137, + "name": "KingToken", + "symbol": "$KING", + "decimals": 18, + "address": "0xB31BAc3b0Ff9F588fD07B00859555F7970950015", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd2057d71fe3f5b0dc1e3e7722940e1908fc72078" + } + }, + { + "chainId": 137, + "name": "MOE Token", + "symbol": "MOE", + "decimals": 18, + "address": "0x3be6601208c404a022612d06bfc8db5c88c8217c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6d9cf12482b14888453b63a0821b7b0e854f59a2" + } + }, + { + "chainId": 137, + "name": "Safaia Gabanansu", + "symbol": "GABA", + "decimals": 5, + "address": "0xD1e3F2FE09D92E47868F6fEb653344932bCF5091", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc9e823929b74720990f0e3914ef718c37480494f" + } + }, + { + "chainId": 137, + "name": "Weird", + "symbol": "WEIRD", + "decimals": 18, + "address": "0xcB8BCDb991B45bF5D78000a0b5C0A6686cE43790", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xff5a1a18650fac5afa7c94a8dcb3ebf73b00ddb7" + } + }, + { + "chainId": 137, + "name": "Junø", + "symbol": "JUNO", + "decimals": 6, + "address": "0xc6bdB9dD7F33FF11EfDD3A84b2C1c99b8CC93052", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x413e8196E7D6d2C02A6BCcc46366F881017ea479" + } + }, + { + "chainId": 137, + "name": "BitCanna", + "symbol": "BCNA", + "decimals": 6, + "address": "0xbcAe3a93bFa5258fEDB78758d45E03e3C2bda3E8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeB5Bea778339e5F0C8D9419cf9891445af823A29" + } + }, + { + "chainId": 137, + "name": "e-Money EUR", + "symbol": "EEUR", + "decimals": 6, + "address": "0x2D27E0E31f86bd8889300E5D8148BA7b231Cf1c1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x714bfD06Da6EB24fAc379f0d9DEBFa85261bF439" + } + }, + { + "chainId": 137, + "name": "Microtick", + "symbol": "TICK", + "decimals": 6, + "address": "0x4305fF9f3714C8bEFE7854D401c4C2e395662Db4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcf9902B43D01D7C6cd5c12e0c1112cc2C4FC4Ec5" + } + }, + { + "chainId": 137, + "name": "e-Money", + "symbol": "NGM", + "decimals": 6, + "address": "0xc54FF1b09Ab25B01275cD1093c2Ba311A18c00Eb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56667705DF047677A15D3D417A138b10B6ed62C4" + } + }, + { + "chainId": 137, + "name": "ixo", + "symbol": "IXO", + "decimals": 6, + "address": "0x4a8D681bF9FC7A32d8284B6f2d869eb1CB14A7f0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8Ea2645CD39D5e0C901bCA25dF8d0998a6926cf2" + } + }, + { + "chainId": 137, + "name": "Certik", + "symbol": "CTK", + "decimals": 6, + "address": "0x799a88F32EBB23aA9Ef440a7A1cb37653af74422", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4c67B8392fC17892338d590e5AE1aB7BE485BE50" + } + }, + { + "chainId": 137, + "name": "Starname", + "symbol": "IOV", + "decimals": 6, + "address": "0x6ec60377b874782408EA493BeCCCce39347A911A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3dE8006B2c571eBC19a5d3a85a0940A7a9339470" + } + }, + { + "chainId": 137, + "name": "TrailerPark", + "symbol": "PARK", + "decimals": 18, + "address": "0xD6CC9119650b5591dc44a761754aFC83F259ab41", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6a2523c3eb9159fe4321ca70c06cbc04b3732a63" + } + }, + { + "chainId": 137, + "name": "Anyswap", + "symbol": "ANY", + "decimals": 18, + "address": "0x99Cd301508Ac0020AA2D5E4572f846590C5aB3AD", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf99d58e463a2e07e5692127302c20a191861b4d6" + } + }, + { + "chainId": 137, + "name": "PreKlima", + "symbol": "pKLIMA", + "decimals": 18, + "address": "0x0aF5deE6678869201924930D924a435F6E4839c9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc497b856b1b8e952521154d24f9e951b758ed84d" + } + }, + { + "chainId": 137, + "name": "WFAIR Token", + "symbol": "WFAIR", + "decimals": 18, + "address": "0xb6B5CDF74606181a1b05bfC0B9F17fC2A64B0cD5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xC6065B9fc8171Ad3D29bad510709249681758972" + } + }, + { + "chainId": 137, + "name": "Alkemi_Network_DAO_Token", + "symbol": "ALK", + "decimals": 18, + "address": "0x3F3713030d836A0E1B774f1428c1F1f2148DaB64", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6c16119b20fa52600230f074b349da3cb861a7e3" + } + }, + { + "chainId": 137, + "name": "Direwolftoken.com", + "symbol": "DIREWOLF", + "decimals": 2, + "address": "0x8135532bC7765818eFECF49A295FEA4262121e36", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xBdea5bB640DBFC4593809DEeC5CdB8F99b704Cd2" + } + }, + { + "chainId": 137, + "name": "CryptoQuantumTradingFund", + "symbol": "CQTF", + "decimals": 18, + "address": "0xcCBBA38E41d5428FD82cf42efE5385AEF6f80826", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4e2721c261C056D2F7bD6F6b2388C6853D22dA78" + } + }, + { + "chainId": 137, + "name": "pTokens ORE", + "symbol": "ORE", + "decimals": 18, + "address": "0xD52f6CA48882Be8fbaa98ce390db18e1dbe1062d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4f640F2529ee0cF119A2881485845FA8e61A782A" + } + }, + { + "chainId": 137, + "name": "Fly Dollar", + "symbol": "FUSD", + "decimals": 18, + "address": "0x5973aC9378d0D3e982A37Cc43D480d455C19ae8a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2ee7d743d97173bacd150f3d06e7c4518d393918" + } + }, + { + "chainId": 137, + "name": "Witch Token", + "symbol": "WITCH", + "decimals": 18, + "address": "0x842e4B170021cE14c9c1b7859f3452a63b4f6841", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdc524e3c6910257744c1f93cf15e9f472b5bd236" + } + }, + { + "chainId": 137, + "name": "QuiverX", + "symbol": "QRX", + "decimals": 18, + "address": "0x0cC013A6971fAF2Ec8beEe2cd6AdccA6F801a29c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6e0dade58d2d89ebbe7afc384e3e4f15b70b14d8" + } + }, + { + "chainId": 137, + "name": "Ino Coin", + "symbol": "INO", + "decimals": 0, + "address": "0xba19a5b5029AEa6Fe018742E6eFc5a204a58c14d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc9859fccC876e6b4B3C749C5D29EA04F48aCb74F" + } + }, + { + "chainId": 137, + "name": "Adaptech Design Co", + "symbol": "ADCO", + "decimals": 18, + "address": "0xd8A805447b1ce5BAE810f029dF5536A57F71b91C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x83cc32d627C66e70C69f86f13Ad836FeA07d7407" + } + }, + { + "chainId": 137, + "name": "Pozzle Planet", + "symbol": "POZ", + "decimals": 18, + "address": "0x701fD77F1B00547BE745957Ddf1cc92F9D088B6B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x099945992A6678A724a64CE96B3D348259d17e45" + } + }, + { + "chainId": 137, + "name": "Orbitum", + "symbol": "ORBTM", + "decimals": 18, + "address": "0xE93C4431494B45115ea656274ea75B987f541B17", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x93ca2df0bf96936bd0b59e3ceff0162180574ebc" + } + }, + { + "chainId": 137, + "name": "ARTM", + "symbol": "ARTM", + "decimals": 18, + "address": "0xcBEA63B905d62bAd6506e2C47b1Ea00C56D8f93d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x19ebaa7f212b09de2aee2a32d40338553c70e2e3" + } + }, + { + "chainId": 137, + "name": "FlyCoin", + "symbol": "FLY", + "decimals": 18, + "address": "0x486FFAf06A681bf22B5209e9fFCE722662A60E8C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4e568ab95F029E8dF1e39b30c9d6D076eaA15945" + } + }, + { + "chainId": 137, + "name": "Sekuritance", + "symbol": "SKRT", + "decimals": 18, + "address": "0xE51E88dD08499762B8e4EB3a9f3Da9b8e79608c3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x887168120cb89fb06f3e74dc4af20d67df0977f6" + } + }, + { + "chainId": 137, + "name": "Empty Set Share", + "symbol": "ESS", + "decimals": 18, + "address": "0x5362dAf94A6bd0E9078aC3070f575861F12A2E77", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e" + } + }, + { + "chainId": 137, + "name": "Digital Standard Unit", + "symbol": "DSU", + "decimals": 18, + "address": "0x777211c3C0b03D9fF2Aaa288a016b1a3b64DDB8C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x605d26fbd5be761089281d5cec2ce86eea667109" + } + }, + { + "chainId": 137, + "name": "Global Digital Content", + "symbol": "GDC", + "decimals": 18, + "address": "0x2e8FaF0f7918c4914E890716E22A74E675115D52", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x301c755ba0fca00b1923768fffb3df7f4e63af31" + } + }, + { + "chainId": 137, + "name": "Eliot", + "symbol": "ELIOT", + "decimals": 18, + "address": "0xB83a45Bbb5699ae47B39c32B20A145b28B446fCa", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf17E3bD04465f2b60aB31A42414fB7474E52D62D" + } + }, + { + "chainId": 137, + "name": "Goji", + "symbol": "GOJ", + "decimals": 10, + "address": "0x3Ee21b6d44a3879EeF12084423B4C7a9A286D00D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xec4a1c7a4e9fdc7cc621b548a931c92bc08a679a" + } + }, + { + "chainId": 137, + "name": "Mia Neko", + "symbol": "MIA", + "decimals": 10, + "address": "0x424EB54e29868E15e44FdA6BD17F55D1Ac5EcFb5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8d52061af43c52204c717d0610ea8f52f955ce0b" + } + }, + { + "chainId": 137, + "name": "Fair Trader", + "symbol": "FTP", + "decimals": 18, + "address": "0x8AC24ae89cd33BA285A65d3A7039de3B23C9f83e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6B71cDc52B6B5e007E9e018D65B233AbeD8589C7" + } + }, + { + "chainId": 137, + "name": "GTS Coin", + "symbol": "GTS", + "decimals": 18, + "address": "0xa6BE18a7870D464c97c76a457d965CB74bE0dB3f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xebD8af559699136EF01c3f06fdD1131Fd64EFA87" + } + }, + { + "chainId": 137, + "name": "PureFi Token", + "symbol": "UFI", + "decimals": 18, + "address": "0x3c205C8B3e02421Da82064646788c82f7bd753B9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcDa4e840411C00a614aD9205CAEC807c7458a0E3" + } + }, + { + "chainId": 137, + "name": "UnirisToken", + "symbol": "UCO", + "decimals": 18, + "address": "0x3C720206bFaCB2d16fA3ac0ed87D2048Dbc401Fc", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8a3d77e9d6968b780564936d15b09805827c21fa" + } + }, + { + "chainId": 137, + "name": "BlockTV", + "symbol": "BLTV", + "decimals": 18, + "address": "0x2C1084a041B976b96B769d1C250562864317c1Aa", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe08854b668958657064fa20f309F6BA7a19D5Af2" + } + }, + { + "chainId": 137, + "name": "AurusGOLD", + "symbol": "AWG", + "decimals": 18, + "address": "0xAEe0ffb690B37449B7f1C49B199E1E3ec6084490", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x696acc2de564b48682d71d0847b3632f87c9a402" + } + }, + { + "chainId": 137, + "name": "XMANNA TOKEN", + "symbol": "XMAN", + "decimals": 18, + "address": "0x6db9dd7342e9aE835Ed498d141A85970813F1E9c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9Fff5F700196269079cA4dAbC9Ff7319346e6DbF" + } + }, + { + "chainId": 137, + "name": "Web4", + "symbol": "WEB4", + "decimals": 18, + "address": "0x362d55939b3b914BDAe5992F7e80FA03d4Df2B15", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x75239ba45ccd3ec2e25f1b44e7e56f2edf0f80a8" + } + }, + { + "chainId": 137, + "name": "Rentible", + "symbol": "RNB", + "decimals": 18, + "address": "0x4D53d5CF63ed51DDA047B363F3a6F62677d37613", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2a039b1d9bbdccbb91be28691b730ca893e5e743" + } + }, + { + "chainId": 137, + "name": "VectorspaceAI", + "symbol": "VXV", + "decimals": 18, + "address": "0x5DecD638E9E6C7b3533Ef40788094b5e6231826a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7D29A64504629172a429e64183D6673b9dAcbFCe" + } + }, + { + "chainId": 137, + "name": "ACY", + "symbol": "ACY", + "decimals": 18, + "address": "0x8b1f836491903743fE51ACd13f2CC8Ab95b270f6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaf9db9e362e306688af48c4acb9618c06db38ac3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/acy.svg" + }, + { + "chainId": 137, + "name": "Strong", + "symbol": "STRONG", + "decimals": 18, + "address": "0xf4487f1FF4f7e38c640AeA91d7bb47AeA98c09a7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x990f341946a3fdb507ae7e52d17851b87168017c" + } + }, + { + "chainId": 137, + "name": "Olympus", + "symbol": "OHM", + "decimals": 9, + "address": "0xfA49101D56734aF877AA312a6a40f634d4E3729d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x383518188c0c6d7730d91b2c03a03c837814a899" + } + }, + { + "chainId": 137, + "name": "Hue", + "symbol": "HUE", + "decimals": 4, + "address": "0xd9Cc6BC0569c22a16d804B46e6774611A93dD90B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdcfe18bc46f5a0cd0d3af0c2155d2bcb5ade2fc5" + } + }, + { + "chainId": 137, + "name": "SRSC Chiz Token", + "symbol": "CHIZ", + "decimals": 18, + "address": "0x383180a2f52c8F2C67a5a10e2f0752276274E442", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5c761c1a21637362374204000e383204d347064c" + } + }, + { + "chainId": 137, + "name": "Gian Ferrer", + "symbol": "GIAN", + "decimals": 18, + "address": "0x8527aBEf4EDE978af2B753543f8864EC85FD55c6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC48752b8e1DC43F9d70504099b5C17c4380Ac605" + } + }, + { + "chainId": 137, + "name": "AlchemistKlima", + "symbol": "alKLIMA", + "decimals": 18, + "address": "0xd50EC6360f560a59926216Eafb98395AC430C9fD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0f92565e9ba96918b2db48537616dd9d0b09502b" + } + }, + { + "chainId": 137, + "name": "GGToken", + "symbol": "GGTK", + "decimals": 18, + "address": "0x49B1bE61A8Ca3f9A9F178d6550e41E00D9162159", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfa99a87b14b02e2240c79240c5a20f945ca5ef76" + } + }, + { + "chainId": 137, + "name": "Compound USD Coin", + "symbol": "cUSDC", + "decimals": 8, + "address": "0xd871B40646E1a6dbDED6290B6B696459a69C68A0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x39AA39c021dfbaE8faC545936693aC917d5E7563" + } + }, + { + "chainId": 137, + "name": "Harrison First", + "symbol": "FIRST", + "decimals": 4, + "address": "0x25B3A129907B675E19cE6Dd3F2A6db50023eCF80", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9903A4Cd589DA8e434f264deAFc406836418578E" + } + }, + { + "chainId": 137, + "name": "AurusDeFi", + "symbol": "AWX", + "decimals": 18, + "address": "0x56a0efefc9f1fbb54fbd25629ac2aa764f1b56f7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa51fc71422a30fa7ffa605b360c3b283501b5bf6" + } + }, + { + "chainId": 137, + "name": "Dogira", + "symbol": "DOGIRA", + "decimals": 9, + "address": "0x23274CD85642068B22EbF61Ff64402CF4252c7f5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD8C1232FcD219286E341271385bd70601503B3D7" + } + }, + { + "chainId": 137, + "name": "FastArgmag20L1N", + "symbol": "FastArgmag20L1S", + "decimals": 18, + "address": "0xc9b7Bc25AaA5D2a26e508eb0cB0b3AF08a4cA6F8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA494e64fe7a4E329C23aD961ad16dF983e322c62" + } + }, + { + "chainId": 137, + "name": "vEmpire Gamer Token", + "symbol": "VEMP", + "decimals": 18, + "address": "0x7Fb7DdB3a3ec90e1c7A3E58Ff6670DA82F73c1cF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcfeb09c3c5f0f78ad72166d55f9e6e9a60e96eec" + } + }, + { + "chainId": 137, + "name": "RevolutionPopuli ERC20 Token", + "symbol": "RVP", + "decimals": 18, + "address": "0x120cA63f5F79B6760324B1ddE6BeA4C7F01FBa0E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x17ef75aa22dd5f6c2763b8304ab24f40ee54d48a" + } + }, + { + "chainId": 137, + "name": "Argmag20L1Name", + "symbol": "Argmag20L1Sym", + "decimals": 18, + "address": "0x1fB39C88Df91c9fDB83D0e8761c8D2D2A4Ab5335", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7235a194451B9cb6D7c2F1E4ED3976C2aDAe7E22" + } + }, + { + "chainId": 137, + "name": "+Blockchain Cuties Universe Governance Token", + "symbol": "BCUG", + "decimals": 18, + "address": "0xbd3859443377e0882dc58812E1f7C9EE057B64Be", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x14da7b27b2e0fedefe0a664118b0c9bc68e2e9af" + } + }, + { + "chainId": 137, + "name": "LGCY Network", + "symbol": "LGCY", + "decimals": 18, + "address": "0x834dfb4Df4425BDeC02F2A1CAFdf0cc39c3c0A59", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xae697f994fc5ebc000f8e22ebffee04612f98a0d" + } + }, + { + "chainId": 137, + "name": "LeftHouse", + "symbol": "LEFT", + "decimals": 4, + "address": "0xeB4a74e9882273B7D9d985098d7b7C7512001c31", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4804FB55e75BD1c32aB06CD053C5510c1b80Fd26" + } + }, + { + "chainId": 137, + "name": "THEOS", + "symbol": "THEOS", + "decimals": 18, + "address": "0xDb982a636807B3ACD9FD28a99410B68c2159Fb32", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9e10f61749c4952c320412a6b26901605ff6da1d" + } + }, + { + "chainId": 137, + "name": "Continuum", + "symbol": "UM", + "decimals": 18, + "address": "0x3B1A0c9252ee7403093fF55b4a5886d49a3d837a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb19Dd661F076998e3B0456935092a233e12C2280" + } + }, + { + "chainId": 137, + "name": "AlphaKlima", + "symbol": "aKLIMA", + "decimals": 18, + "address": "0xEb935614447185eeea0aBC756Ff2ddC99FBB9047", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6b4d5e9ec2aceA23D4110F4803Da99E25443c5Df" + } + }, + { + "chainId": 137, + "name": "Quant", + "symbol": "QNT", + "decimals": 18, + "address": "0x36B77a184bE8ee56f5E81C56727B20647A42e28E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4a220e6096b25eadb88358cb44068a3248254675" + } + }, + { + "chainId": 137, + "name": "AqarChain", + "symbol": "AQR", + "decimals": 18, + "address": "0x7467afa7C48132e8f8C90A919fC2ebA041207195", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7467afa7C48132e8f8C90A919fC2ebA041207195" + } + }, + { + "chainId": 137, + "name": "Scam Inu", + "symbol": "SINU", + "decimals": 18, + "address": "0xe99eF864CC6035a68e6eb4A813FbC6c034277cAc", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xDB6F6C8b940110617cf66E50c271E2278c8a32Df" + } + }, + { + "chainId": 137, + "name": "NFTicket Token", + "symbol": "NTT", + "decimals": 18, + "address": "0x8B0180f2101c8260d49339abfEe87927412494B4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x023ecaebc57fae26579ae395dcd431d63c072339" + } + }, + { + "chainId": 137, + "name": "Ripio Coin", + "symbol": "RPC", + "decimals": 18, + "address": "0xe1e516Ed179E8f448f5ebD5eca4F2A892368b78b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEd025A9Fe4b30bcd68460BCA42583090c2266468" + } + }, + { + "chainId": 137, + "name": "DIGITAL FITNESS", + "symbol": "DEFIT", + "decimals": 18, + "address": "0xb070d0166A4CE2D47d8af1178847886aA240895D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x84cffa78B2fBbeeC8c37391d2B12A04d2030845e" + } + }, + { + "chainId": 137, + "name": "IMPULSEVEN", + "symbol": "i7", + "decimals": 18, + "address": "0xF8d7195eEB28c7449f7ef8557fF9A4Da86da0c64", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x560cC7De81B2A594F6518713cBE122bCF297A6E8" + } + }, + { + "chainId": 137, + "name": "NEUY", + "symbol": "NEUY", + "decimals": 18, + "address": "0x62a872d9977Db171d9e213A5dc2b782e72ca0033", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa80505c408C4DEFD9522981cD77e026f5a49FE63" + } + }, + { + "chainId": 137, + "name": "HoboNickels", + "symbol": "HOBO", + "decimals": 8, + "address": "0x36FF415d0BcEdF976d60E85c72E01D19230FBd29", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6Ee2AbfBF98D85c7090B5459103334a3638649c4" + } + }, + { + "chainId": 137, + "name": "Seed Of The Universe", + "symbol": "SOTU", + "decimals": 18, + "address": "0xb89FB010b3a409929E5e4a99F7cd0BEec18e0bC4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa91c82b6933105c23298e631a0c1be751d239162" + } + }, + { + "chainId": 137, + "name": "Tuschay Coin", + "symbol": "TSHY", + "decimals": 18, + "address": "0xD8f9a909649BA317175A4f2F5416958Af64a0BFC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xCa9FEEb9f20F0c61a2e2c5C24897BD0206dD899A" + } + }, + { + "chainId": 137, + "name": "Mobius Token", + "symbol": "MOT", + "decimals": 18, + "address": "0x2db0Db271a10661e7090b6758350E18F6798a49D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1E02cdbbA6729B6470de81Ad4D2cCA4c514521b9" + } + }, + { + "chainId": 137, + "name": "UNIC", + "symbol": "UNIC", + "decimals": 18, + "address": "0x21CE5251d47AA72d2d1dc849b1Bcce14d2467D1b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x94e0bab2f6ab1f19f4750e42d7349f2740513ad5" + } + }, + { + "chainId": 137, + "name": "Amun Wrapped Weth", + "symbol": "AWW", + "decimals": 18, + "address": "0x229F692adA2f4405789D5AEEac832877e4C0750E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x229F692adA2f4405789D5AEEac832877e4C0750E" + } + }, + { + "chainId": 137, + "name": "EMotiveToken", + "symbol": "EMOT", + "decimals": 18, + "address": "0x23DB3a5dF58eb5EB74b79fF1c64Cf200B07De5ee", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x176b7f05b31ee23cea1c934ed68bc0c3dff43f46" + } + }, + { + "chainId": 137, + "name": "CRYPTOPUNT Token", + "symbol": "PUN", + "decimals": 18, + "address": "0x908435624Fc23130fDA2d07b10C91cA2B6A57abA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x31903E333809897eE57Af57567f4377a1a78756c" + } + }, + { + "chainId": 137, + "name": "Cashpayz Token", + "symbol": "CPC", + "decimals": 8, + "address": "0xe0B4Af6c2E9cb2E43DFe5A357a00CED16da4547b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x28ea81fac7b1719138cbf61267198155b433e00e" + } + }, + { + "chainId": 137, + "name": "ChilliTest Token", + "symbol": "CHLITEST", + "decimals": 18, + "address": "0x8c7f28BD18ee3BBe766b2036c9E8A8357B07CACa", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8c7f28bd18ee3bbe766b2036c9e8a8357b07caca" + } + }, + { + "chainId": 137, + "name": "RADIAN", + "symbol": "RADI", + "decimals": 18, + "address": "0x57a0E527611Bcd7e466407a621ce02Bf923C0d15", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8cd0bdeef4a97f788fa8cb5d21185ae10c74dcfa" + } + }, + { + "chainId": 137, + "name": "BITE POINT", + "symbol": "BITEPT", + "decimals": 18, + "address": "0x5c1A50c4Cd26AD2a3A156c2F4B1A8826E7f3a4e0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1a31c79C54214537cd893A572314996bB6fe472C" + } + }, + { + "chainId": 137, + "name": "Floki Kishu Inu", + "symbol": "FLOKII", + "decimals": 9, + "address": "0x3EcE64186c05f47e41657ccBf3F9419F76505377", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xFf4DB8E71a8e2655e9295C2C817aC86e65767db1" + } + }, + { + "chainId": 137, + "name": "Etherlands Playtest Token", + "symbol": "HOAP", + "decimals": 18, + "address": "0x9e416F2FCE870b8eDd91fc23C9280A77f4c4A928", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7d60fc2f2219537c2605b827fb08f00d8ead44ae" + } + }, + { + "chainId": 137, + "name": "IRISnet", + "symbol": "IRIS", + "decimals": 6, + "address": "0x3dc6052a693E4a2fc28Eb2Ea12fe0CfD3BD221D1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x76C4A2B59523eaE19594c630aAb43288dBB1463f" + } + }, + { + "chainId": 137, + "name": "Persistence", + "symbol": "XPRT", + "decimals": 6, + "address": "0xb3b9c016AD1E9f7EFdAE451b04EF696e05658b32", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xae837EacBAE2a6bA166ce0DEd5C72340f212835c" + } + }, + { + "chainId": 137, + "name": "HARD Protocol", + "symbol": "HARD", + "decimals": 6, + "address": "0x8bdC1239840D4a0DB234F2E7D65dF83164D18e49", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1C700F95Df53fc31e83D89AC89e5DD778D4cD310" + } + }, + { + "chainId": 137, + "name": "Osmosis", + "symbol": "OSMO", + "decimals": 6, + "address": "0x8C7a56F2F2fD97DA0f5b4FAde180Fa8DC3fbEa8D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x93A62Ccfcf1EfCB5f60317981F71ed6Fb39F4BA2" + } + }, + { + "chainId": 137, + "name": "Regen Network", + "symbol": "REGEN", + "decimals": 6, + "address": "0xEc482De9569a5EA3Dd9779039b79e53F15791fDE", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xeEE10b3736d5978924f392ED67497cfAE795128B" + } + }, + { + "chainId": 137, + "name": "Ion", + "symbol": "ION", + "decimals": 6, + "address": "0x68b741416153bBf5CB4FaEe0aA447f918fE5C322", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xee59B43149CEAD680aedF8778163ce8CB8c8A6fB" + } + }, + { + "chainId": 137, + "name": "Kava.io", + "symbol": "KAVA", + "decimals": 6, + "address": "0x87D32F2C0A3D6D091772890C81E321026454a125", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0C356B7fD36a5357E5A017EF11887ba100C9AB76" + } + }, + { + "chainId": 137, + "name": "Polybius Token", + "symbol": "PLBT", + "decimals": 6, + "address": "0x65885a2Aa8888d2891246B9d811b0a8E15d75d48", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0affa06e7fbe5bc9a764c979aa66e8256a631f02" + } + }, + { + "chainId": 137, + "name": "10Set Token", + "symbol": "10SET", + "decimals": 18, + "address": "0x602C6690A6cb2D2Fce95AD50Fe81d731dF0AD6ed", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7FF4169a6B5122b664c51c95727d87750eC07c84" + } + }, + { + "chainId": 137, + "name": "CHARLI3", + "symbol": "C3", + "decimals": 18, + "address": "0xc73594aA7593182a516331e712fEA2d8C49FF8DD", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf1a91c7d44768070f711c68f33a7ca25c8d30268" + } + }, + { + "chainId": 137, + "name": "GeroWallet", + "symbol": "GERO", + "decimals": 18, + "address": "0x99aB67C6D0b9BF4201cd9AAd66F84F5F524e0018", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3431f91b3a388115f00c5ba9fdb899851d005fb5" + } + }, + { + "chainId": 137, + "name": "Zks", + "symbol": "ZKS", + "decimals": 18, + "address": "0x70B7B259001c1aF1583fc466C27f49105f38fbFd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe4815ae53b124e7263f08dcdbbb757d41ed658c6" + } + }, + { + "chainId": 137, + "name": "Zero.Exchange Token", + "symbol": "ZERO", + "decimals": 18, + "address": "0x96fEbBC05Bb00F83bb5A3F20DD97940454EC3b7d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf0939011a9bb95c3b791f0cb546377ed2693a574" + } + }, + { + "chainId": 137, + "name": "SmartKey", + "symbol": "Skey", + "decimals": 8, + "address": "0x2B642B8289780cA28ec283f2ab1932436d82AC02", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x06a01a4d579479dd5d884ebf61a31727a3d8d442" + } + }, + { + "chainId": 137, + "name": "Hanu Yokia", + "symbol": "HANU", + "decimals": 12, + "address": "0x709A4B6217584188DDb93c82f5d716D969accE1C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x72e5390edb7727e3d4e3436451dadaff675dbcc0" + } + }, + { + "chainId": 137, + "name": "Cosmos", + "symbol": "ATOM", + "decimals": 6, + "address": "0xac51C4c48Dc3116487eD4BC16542e27B5694Da1b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8D983cb9388EaC77af0474fA441C4815500Cb7BB" + } + }, + { + "chainId": 137, + "name": "wLitiCapital", + "symbol": "wLITI", + "decimals": 18, + "address": "0x3674fFe94d5a306DdA2CDcdC0D735561E4E79bC8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0b63128c40737b13647552e0c926bcfeccc35f93" + } + }, + { + "chainId": 137, + "name": "XEND", + "symbol": "XEND", + "decimals": 18, + "address": "0x4A2B3c1527cf704D959390c0063FcF2A9E2bD9c1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE4CFE9eAa8Cdb0942A80B7bC68fD8Ab0F6D44903" + } + }, + { + "chainId": 137, + "name": "Andy Coin", + "symbol": "ANDY", + "decimals": 18, + "address": "0xcB816bEdd44D1d04870d4A171A2CD93903356960", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1465140fac1cf3760093f1ea2c78289f6b0e432f" + } + }, + { + "chainId": 137, + "name": "The Doge NFT", + "symbol": "DOG", + "decimals": 18, + "address": "0x4d7d6e43ED36298Bfe287711a48c1018D87f272c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xBAac2B4491727D78D2b78815144570b9f2Fe8899" + } + }, + { + "chainId": 137, + "name": "The 4th Pillar Token", + "symbol": "FOUR", + "decimals": 18, + "address": "0x48cBc913dE09317dF2365e6827Df50dA083701D5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4730fb1463a6f1f44aeb45f6c5c422427f37f4d0" + } + }, + { + "chainId": 137, + "name": "USDP Stablecoin", + "symbol": "USDP", + "decimals": 18, + "address": "0xD778beF166D19548799E5f4A5D6354b22883563d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1456688345527be1f37e9e627da0837d6f08c925" + } + }, + { + "chainId": 137, + "name": "Proxy", + "symbol": "PRXY", + "decimals": 18, + "address": "0x1441729568ab2A9871677edfeb13fBFCc7157a26", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x22acaee85ddb83a3a33b7f0928a0e2c3bfdb6a4f" + } + }, + { + "chainId": 137, + "name": "Wolves Of Wall Street", + "symbol": "WOWS", + "decimals": 18, + "address": "0x9661c0614A80319c8Be0FF360079902350aD547D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x672EF7E4Fe230B5cA1466C5fDD40588d30FdF90a" + } + }, + { + "chainId": 137, + "name": "ZKCHAOS", + "symbol": "CHAOS", + "decimals": 18, + "address": "0x6B3C5075c01771d6E083D150212b3653030D4da4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb53de031602cd825febe9f2eedf962cd8cc3805d" + } + }, + { + "chainId": 137, + "name": "\"Silicon Valley Entrepreneurs Token", + "symbol": "SVET", + "decimals": 18, + "address": "0xF5499D8714e55DCf4E84C861cA1C8358e7E69cBA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x434CE605FC30C456c178B5B5842e54fE7C023633" + } + }, + { + "chainId": 137, + "name": "VENT", + "symbol": "VENT", + "decimals": 18, + "address": "0xd116d8EA4dE1225D3F903FdA43493E93eb4b1D54", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5f0bc16d50f72d10b719dbf6845de2e599eb5624" + } + }, + { + "chainId": 137, + "name": "+Wrapped Smart Advertising Transaction Token", + "symbol": "WSATT", + "decimals": 18, + "address": "0x4B6D775B7EA8E66499CB80777E65B895474f5C86", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x70A6395650b47D94A77dE4cFEDF9629f6922e645" + } + }, + { + "chainId": 137, + "name": "xIMX", + "symbol": "Staked IMX", + "decimals": 18, + "address": "0xfF52775dE813D060aA5854657055fB19b3a3DDa5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x363B2DEaC84F0100d63C7427335F8350f596bf59" + } + }, + { + "chainId": 137, + "name": "MileShare", + "symbol": "MILE", + "decimals": 18, + "address": "0xBbc8cCC5d47E9EFfC15F0c71A4e0eE8046546385", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x925d53524783fA6883dE2FABCCB1eC466ee4E20b" + } + }, + { + "chainId": 137, + "name": "Torum", + "symbol": "XTM", + "decimals": 18, + "address": "0xE1C42BE9699Ff4E11674819c1885D43Bd92E9D15", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xCd1fAFf6e578Fa5cAC469d2418C95671bA1a62Fe" + } + }, + { + "chainId": 137, + "name": "Hypersign Identity Token", + "symbol": "HID", + "decimals": 18, + "address": "0x87847703D4bb4FCD42DB887FfdcB94496e77e3ab", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb14ebf566511b9e6002bb286016ab2497b9b9c9d" + } + }, + { + "chainId": 137, + "name": "Dorayaki", + "symbol": "DORA", + "decimals": 18, + "address": "0x66147c74ABf6323A22C33e039DC761c07Df05878", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbc4171f45ef0ef66e76f979df021a34b46dcc81d" + } + }, + { + "chainId": 137, + "name": "UniArts Network Token", + "symbol": "UART", + "decimals": 12, + "address": "0xf244E91A46A9cdd48da295cA5d0B27894f8032B1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x507BDe03A87a6aA134d16634545E3D79c11c137D" + } + }, + { + "chainId": 137, + "name": "Dugg", + "symbol": "DUGG", + "decimals": 18, + "address": "0x4e0dD84d8D5CBd7753407D82824a344CE380fCDe", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x20ba4069294db3429d249fc4bc59b25b860a9ad1" + } + }, + { + "chainId": 137, + "name": "Polinate", + "symbol": "POLI", + "decimals": 18, + "address": "0x6fb54Ffe60386aC33b722be13d2549dd87BF63AF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa1a36D3537bBe375Cc9694795F663DDC8D516Db9" + } + }, + { + "chainId": 137, + "name": "Lionverse Juice", + "symbol": "LVJ", + "decimals": 18, + "address": "0x42f2fcb9A26ac8cDd3E96e51b89134c3d4Dc509f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x87cdbe3c31F2A9E1c506DC2F827A02472A0660cE" + } + }, + { + "chainId": 137, + "name": "Snook", + "symbol": "SNK", + "decimals": 18, + "address": "0x689f8e5913C158fFB5Ac5aeb83b3C875F5d20309", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF9a3b62C2c9faD5aEC118c706323cED3242c9551" + } + }, + { + "chainId": 137, + "name": "Pinkslip Finance", + "symbol": "PSLIP", + "decimals": 18, + "address": "0xdC92de2CDbE69FEA9B1E4939D934f7F5195Bb1c9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x36ce7a52cda404b8fa87a98d0d17ec7dd0b144ed" + } + }, + { + "chainId": 137, + "name": "Adventure Gold", + "symbol": "AGLD", + "decimals": 18, + "address": "0x6a6bD53d677F8632631662C48bD47b1D4D6524ee", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x32353a6c91143bfd6c7d363b546e62a9a2489a20" + } + }, + { + "chainId": 137, + "name": "IPv6Token.com", + "symbol": "IPV6", + "decimals": 18, + "address": "0x06a0462e6b25793f306828C20033a7DB6E926394", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf44217cadef3316e01c5d7b2a2401b5b7ab82e8b" + } + }, + { + "chainId": 137, + "name": "Wrapped Ether IOU", + "symbol": "iWETH", + "decimals": 18, + "address": "0x3DA47Ba3528FDcA867b94496027c65d504eef8e6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3DA47Ba3528FDcA867b94496027c65d504eef8e6" + } + }, + { + "chainId": 137, + "name": "Page", + "symbol": "PAGE", + "decimals": 8, + "address": "0x9ceE70895726B0ea14E6019C961dAf32222a7C2f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x60e683c6514edd5f758a55b6f393bebbafaa8d5e" + } + }, + { + "chainId": 137, + "name": "dotmoovs", + "symbol": "MOOV", + "decimals": 18, + "address": "0xe46F5128B933e5A6F907Fe73EcE80059c222DB0A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x24ec2ca132abf8f6f8a6e24a1b97943e31f256a7" + } + }, + { + "chainId": 137, + "name": "MCF token", + "symbol": "MCF", + "decimals": 10, + "address": "0x15E5C5C8CeFa0AafebeF55B1A43Db5d2c9A4B6AE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe33ae4e795114279721047484e5ad5cc7df24fcb" + } + }, + { + "chainId": 137, + "name": "DOGZ", + "symbol": "DOGZ", + "decimals": 18, + "address": "0x29198A281fe6ED6a49AbE32A5d6864aDcCD7E89e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x82A77710495A35549D2aDD797412b4a4497D33eF" + } + }, + { + "chainId": 137, + "name": "PIGX", + "symbol": "PIGX", + "decimals": 18, + "address": "0x0eF2603Cd156E1934E19D0B07Cd64F415e1E7940", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x47e820df943170b0e31f9e18ecd5bdd67b77ff1f" + } + }, + { + "chainId": 137, + "name": "Z.com USD", + "symbol": "ZUSD", + "decimals": 6, + "address": "0x83a3b215b256df3f2Bc97DD0Fe1Fe32aF0d66D19", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc56c2b7e71B54d38Aab6d52E94a04Cbfa8F604fA" + } + }, + { + "chainId": 137, + "name": "GMO JPY", + "symbol": "GYEN", + "decimals": 6, + "address": "0x482bc619eE7662759CDc0685B4E78f464Da39C73", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xC08512927D12348F6620a698105e1BAac6EcD911" + } + }, + { + "chainId": 137, + "name": "indaHash Coin", + "symbol": "IDH", + "decimals": 6, + "address": "0x95a54B74a4891A7f41f7f72f3713e1764eEFCd4B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5136c98a80811c3f46bdda8b5c4555cfd9f812f0" + } + }, + { + "chainId": 137, + "name": "Knit Finance", + "symbol": "KFT", + "decimals": 18, + "address": "0xdf6843eeAEC6213625bC85E6E2C3AEa0782a9748", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEF53462838000184F35f7D991452e5f25110b207" + } + }, + { + "chainId": 137, + "name": "Neonious Token", + "symbol": "MDSIM", + "decimals": 18, + "address": "0xE454034b75Bb9D017f21228e61b9Ddbc889623C0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xda48c42517affb3bf3fc13ce26561092e1a61a80" + } + }, + { + "chainId": 137, + "name": "DaTa eXchange Token", + "symbol": "DTX", + "decimals": 18, + "address": "0x3f717919deF69f81d17b80839bf8af35697ccbFa", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x765f0c16d1ddc279295c1a7c24b0883f62d33f75" + } + }, + { + "chainId": 137, + "name": "BITTOKEN", + "symbol": "BITT", + "decimals": 18, + "address": "0xfd0cbdDec28a93bB86B9db4A62258F5EF25fEfdE", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9F9913853f749b3fE6D6D4e16a1Cc3C1656B6D51" + } + }, + { + "chainId": 137, + "name": "Shine", + "symbol": "SHN", + "decimals": 18, + "address": "0x53D76f967De13E7F95e90196438DCe695eCFA957", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1C7ede23b1361acC098A1e357C9085D131b34a01" + } + }, + { + "chainId": 137, + "name": "PolkaBridge", + "symbol": "PBR", + "decimals": 18, + "address": "0x0D6ae2a429df13e44A07Cd2969E085e4833f64A0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x298d492e8c1d909d3f63bc4a36c66c64acb3d695" + } + }, + { + "chainId": 137, + "name": "TknERC721Name", + "symbol": "TknERC721Sym", + "decimals": 18, + "address": "0x3b82319eF9e45c16621CC6F6b588324f5719a882", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2e16ba24F298dC205aC58791e0dab4141E79f3D4" + } + }, + { + "chainId": 137, + "name": "ELDORADO TOKEN", + "symbol": "ERD", + "decimals": 2, + "address": "0x2df2DC62Cc1dFAc66867524942E83439D558D8b9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x12dc767728105aa415dd720dfbd0ea1d85841172" + } + }, + { + "chainId": 137, + "name": "CelerToken", + "symbol": "CELR", + "decimals": 18, + "address": "0x91a4635F620766145C099E15889Bd2766906A559", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4f9254c83eb525f9fcf346490bbb3ed28a81c667" + } + }, + { + "chainId": 137, + "name": "TORG", + "symbol": "TORG", + "decimals": 18, + "address": "0xe9993763E0B7f7d915A62A5f22A6E151F91d98A8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcfa0885131f602d11d4da248d2c65a62063567a9" + } + }, + { + "chainId": 137, + "name": "THE TRUTH", + "symbol": "UFO", + "decimals": 18, + "address": "0x57194feaca970A4E98A19C365FE144fB54F657DB", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x249e38ea4102d0cf8264d3701f1a0e39c4f2dc3b" + } + }, + { + "chainId": 137, + "name": "Float Protocol: FLOAT", + "symbol": "FLOAT", + "decimals": 18, + "address": "0xF0Ae1EFdE60BAb0a830673747138F12367858e8D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb05097849bca421a3f51b249ba6cca4af4b97cb9" + } + }, + { + "chainId": 137, + "name": "Wrapped Navcoin", + "symbol": "WNAV", + "decimals": 8, + "address": "0x1a6872038B633Bc9EbD2ea36df3f81eAcd9b8823", + "logoURI": "https://navcoin.org/images/nav-logo-border.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x75571a52de30e2d7160af134798acfb80cc9c0be" + } + }, + { + "chainId": 137, + "name": "Party Of The Living Dead", + "symbol": "DEAD", + "decimals": 18, + "address": "0xeEEdf2960cdDA52cf2a5B3477B171B9F8b13d700", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0c7060bf06a78aaaab3fac76941318a52a3f4613" + } + }, + { + "chainId": 137, + "name": "VERA", + "symbol": "VRA", + "decimals": 18, + "address": "0x0769C9a377a285DBCb5a66326fA90aE330E5F6D3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf411903cbc70a74d22900a5de66a2dda66507255" + } + }, + { + "chainId": 137, + "name": "Drops Ownership Power", + "symbol": "DOP", + "decimals": 18, + "address": "0x4f2b262AC2D30e88371ddf45690F0C10e9c7807E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6bB61215298F296C55b19Ad842D3Df69021DA2ef" + } + }, + { + "chainId": 137, + "name": "NFTMart Token", + "symbol": "NMT", + "decimals": 18, + "address": "0xCC12201E4b21B2ad0071b729F2dCC2f1E95977C5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd81b71cbb89b2800cdb000aa277dc1491dc923c3" + } + }, + { + "chainId": 137, + "name": "StaFi rMATIC", + "symbol": "rMATIC", + "decimals": 18, + "address": "0x9f28e2455f9FFcFac9EBD6084853417362bc5dBb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3dbb00c9be5a327e25caf4f650844c5dba81e34b" + } + }, + { + "chainId": 137, + "name": "MetaFactory", + "symbol": "ROBOT", + "decimals": 18, + "address": "0x540EBA0ab20E9d77998f9a26e75079317703D76d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfb5453340c03db5ade474b27e68b6a9c6b2823eb" + } + }, + { + "chainId": 137, + "name": "Miguel Piedrafita", + "symbol": "MIGUEL", + "decimals": 18, + "address": "0x4B9D66B1d0343EB2f16ebc427270718b7E010f78", + "logoURI": "https://miguelpiedrafita.com/images/_site/logo.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9eeab5dacad364017c400bfbf717543a0e3c35cb" + } + }, + { + "chainId": 137, + "name": "Plexus Coin", + "symbol": "PLEXUS", + "decimals": 18, + "address": "0x0B6643f87c37280f5006808Ad4766C34FBF0996C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcFed2d8316D794426a4699a719Bcf18cecF36787" + } + }, + { + "chainId": 137, + "name": "Unreal Governance Token", + "symbol": "UGT", + "decimals": 18, + "address": "0xBa4c54Ea2d66b904C82847A7d2357d22B857E812", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9cf98eb8a8b28c83e8612046cf55701ce3eb0063" + } + }, + { + "chainId": 137, + "name": "Yield Guild Games Token", + "symbol": "YGG", + "decimals": 18, + "address": "0x82617aA52dddf5Ed9Bb7B370ED777b3182A30fd1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x25f8087ead173b73d6e8b84329989a8eea16cf73" + } + }, + { + "chainId": 137, + "name": "SPANK", + "symbol": "SPANK", + "decimals": 18, + "address": "0xfc574229a88292A0dcfd957Ad31B360495403723", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x42d6622dece394b54999fbd73d108123806f6a18" + } + }, + { + "chainId": 137, + "name": "IDEAOLOGY", + "symbol": "IDEA", + "decimals": 18, + "address": "0xD290C81dC2f51Cf8eEdc8C5FEAFE35e9003A0475", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5d3a4F62124498092Ce665f865E0b38fF6F5FbEa" + } + }, + { + "chainId": 137, + "name": "Cryptomeda", + "symbol": "TECH", + "decimals": 18, + "address": "0x6286A9e6f7e745A6D884561D88F94542d6715698", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6286A9e6f7e745A6D884561D88F94542d6715698" + } + }, + { + "chainId": 137, + "name": "Metis Token", + "symbol": "Metis", + "decimals": 18, + "address": "0x1B9D40715E757Bdb9bdEC3215B898E46d8a3b71a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9e32b13ce7f2e80a01932b42553652e053d6ed8e" + } + }, + { + "chainId": 137, + "name": "Couchain", + "symbol": "COU", + "decimals": 18, + "address": "0xB6027769f15bde8cFB29F3B14dE2e5622405Aa4C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf091cf09c51811819db705710e9634b8bf18f164" + } + }, + { + "chainId": 137, + "name": "Automata", + "symbol": "ATA", + "decimals": 18, + "address": "0x0df0f72EE0e5c9B7ca761ECec42754992B2Da5BF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa2120b9e674d3fc3875f415a7df52e382f141225" + } + }, + { + "chainId": 137, + "name": "ALICE", + "symbol": "ALICE", + "decimals": 6, + "address": "0x50858d870FAF55da2fD90FB6DF7c34b5648305C6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xAC51066d7bEC65Dc4589368da368b212745d63E8" + } + }, + { + "chainId": 137, + "name": "Covalent Query Token", + "symbol": "CQT", + "decimals": 18, + "address": "0x93B0fF1C8828F6eB039D345Ff681eD735086d925", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD417144312DbF50465b1C641d016962017Ef6240" + } + }, + { + "chainId": 137, + "name": "JustBet", + "symbol": "WINR", + "decimals": 18, + "address": "0x6d470424afaf9cC6476ce8A5d709B7b35F7Cc790", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x27460aac4b005de72e2326bd8391c27fb41780f8" + } + }, + { + "chainId": 137, + "name": "Pendle", + "symbol": "PENDLE", + "decimals": 18, + "address": "0x1D47e931F82bb9F8D967F0Cc3288268449835806", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x808507121b80c02388fad14726482e061b8da827" + } + }, + { + "chainId": 137, + "name": "SinCity", + "symbol": "SINS", + "decimals": 18, + "address": "0x2FAb6278BdfaEB333E4fCF99053349F4111246e5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x59A9aD833d55783a266E098290E679cE987204da" + } + }, + { + "chainId": 137, + "name": "FREEDOMX", + "symbol": "FRDMX", + "decimals": 18, + "address": "0x3F9b2dF1e7F28E046F32aC97F6bdC2e1eEE5CB6a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1c8504180fcef6ce332c7736707582f661d1a019" + } + }, + { + "chainId": 137, + "name": "Tipcoin", + "symbol": "TIP", + "decimals": 18, + "address": "0x098eABED893edbA2b7a1855130F1B1fb181f132c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7d7df208e470a328c5768779a04ba456f1618bc4" + } + }, + { + "chainId": 137, + "name": "WheyTokenV2", + "symbol": "WHEYV2", + "decimals": 18, + "address": "0x0cfbBb89Fd58F6B49B7bF5665397ddc84003d47c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x072cFb8233680B7B196fC8bA6E1aF76CBB5c49E6" + } + }, + { + "chainId": 137, + "name": "DAOventuresDeFi", + "symbol": "DVD", + "decimals": 18, + "address": "0xaa5eD3C460C38eB71fba089B853d0a91C0e71DD5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x77dcE26c03a9B833fc2D7C31C22Da4f42e9d9582" + } + }, + { + "chainId": 137, + "name": "BurningDAO", + "symbol": "BURN", + "decimals": 18, + "address": "0x6562Ba24D787DBb6739786a3dF06553018Ec029F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfE9205D6943087B3317D5cF3D393C67d9E15Fec5" + } + }, + { + "chainId": 137, + "name": "ETH Price Action Candlestick Set", + "symbol": "ETHPA", + "decimals": 18, + "address": "0x3915905289344feDB847d4799D5422f74209Aba9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x09e4bdfb273245063ef5e800d891eff7d04f9b83" + } + }, + { + "chainId": 137, + "name": "Alligator + Fractal Set", + "symbol": "GATOR", + "decimals": 18, + "address": "0x30dC1ebcbA423368c7Dfc0b2A5192890C7d7ce5B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf5c0e24aca5217bcbae662871cae1a86873f02db" + } + }, + { + "chainId": 137, + "name": "BTC RSI Crossover Yield Set", + "symbol": "BTCRSIAPY", + "decimals": 18, + "address": "0xDe08FF1Df4CB0bEfcF85E3802490CAeeF10aF60B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x924E26fEe8E10c20726006CC2Bd307A538B0eBE5" + } + }, + { + "chainId": 137, + "name": "Chad Link Set", + "symbol": "CHADLINK", + "decimals": 18, + "address": "0x134D934Bc4C05C11e19B03342E5E01aBC4C5f27C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x19F4a2f8E21915376F1429C26a3A9B9b1db5FF5A" + } + }, + { + "chainId": 137, + "name": "BURNS", + "symbol": "BURNING DAO", + "decimals": 18, + "address": "0x61C147570165c53Cf5e60a0B5E6A9e8791619Eb9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9B1Cc775292a42fBE9a224d076819B539507D029" + } + }, + { + "chainId": 137, + "name": "CryptoCat", + "symbol": "MEOW", + "decimals": 18, + "address": "0x0d7fB73C39411210088Bb76C0E0dB36816e7A951", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x68cd750e0617da0777f34a3c5e848a2471460e73" + } + }, + { + "chainId": 137, + "name": "Trace Token", + "symbol": "TRAC", + "decimals": 18, + "address": "0xA7b98d63a137bF402b4570799ac4caD0BB1c4B1c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaa7a9ca87d3694b5755f213b5d04094b8d0f0a6f" + } + }, + { + "chainId": 137, + "name": "Wrapped OMI Token", + "symbol": "wOMI", + "decimals": 18, + "address": "0xAAF165e75B4C9370d22b971AF08c630e76Bfa70c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x04969cd041c0cafb6ac462bd65b536a5bdb3a670" + } + }, + { + "chainId": 137, + "name": "CFF", + "symbol": "CFF", + "decimals": 4, + "address": "0x770A1864921bAfb324810a2362f7DeF4AFeb1d53", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe3049c12daca3e7c1ce05f2a8d3dce30860c3794" + } + }, + { + "chainId": 137, + "name": "BASENJI", + "symbol": "BSJ", + "decimals": 18, + "address": "0xF6a38Ce301700e28e0d0a3b021BaE6D4Fa1b5d1b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x43901e05f08f48546fff8d6f8df108f60570498b" + } + }, + { + "chainId": 137, + "name": "Spell Token", + "symbol": "SPELL", + "decimals": 18, + "address": "0xcdB3C70CD25FD15307D84C4F9D37d5C043B33Fb2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x090185f2135308bad17527004364ebcc2d37e5f6" + } + }, + { + "chainId": 137, + "name": "MatrixSwapToken", + "symbol": "MATRIX", + "decimals": 18, + "address": "0x211F4e76fcB811ed2B310A232a24B3445d95E3bC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc8D3DCb63C38607Cb0c9d3F55E8eccE628A01C36" + } + }, + { + "chainId": 137, + "name": "BDPToken", + "symbol": "BDP", + "decimals": 18, + "address": "0xa88Bebd0DF613eaCa1D8109A803736645a502961", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf3dcbc6d72a4e1892f7917b7c43b74131df8480e" + } + }, + { + "chainId": 137, + "name": "I HOUSE TOKEN", + "symbol": "IHT", + "decimals": 18, + "address": "0x8a06bF3FAA72f7dcf796608d4Fd54ABb83461eC3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeda8b016efa8b1161208cf041cd86972eee0f31e" + } + }, + { + "chainId": 137, + "name": "Token for Television", + "symbol": "TTV", + "decimals": 18, + "address": "0xaFBb5E3873dE55dB4f2708A08A90677c7a685a6E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa838be6e4b760e6061d4732d6b9f11bf578f9a76" + } + }, + { + "chainId": 137, + "name": "xWIN Token from BSC", + "symbol": "XWIN", + "decimals": 18, + "address": "0xC2B6200a9ced47B12f95587f3e1E2640893a26D6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x95d6bd26351ebc9fdb23555d2abf990cd17c6a46" + } + }, + { + "chainId": 137, + "name": "NOAH DECENTRALIZED STATE COIN", + "symbol": "NOAHP", + "decimals": 18, + "address": "0xA01749C95b876148c47A6F1FfB7Ea88C8e72903c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41b3F18c6384Dc9A39c33AFEcA60d9b8e61eAa9F" + } + }, + { + "chainId": 137, + "name": "BRL Coin", + "symbol": "BRLC", + "decimals": 6, + "address": "0x3aDdA29B608418Cc63385138F990A754901291e8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x153799b3D83941B9301674f1F147506c91711c25" + } + }, + { + "chainId": 137, + "name": "Cook Token", + "symbol": "COOK", + "decimals": 18, + "address": "0x35BB0DB8210a2A6A333EF81aF92E9ebe4AAdC456", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xff75ced57419bcaebe5f05254983b013b0646ef5" + } + }, + { + "chainId": 137, + "name": "Amongus.finance", + "symbol": "AMONG", + "decimals": 18, + "address": "0xD74CE620dDF70E7c143aF75519712e8eaDA541f3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xF841D292c1141cbF1460A1E2010916565a010cc8" + } + }, + { + "chainId": 137, + "name": "Pudgy Penguin #4815", + "symbol": "PENG4815", + "decimals": 18, + "address": "0x69377cC6f2929bd19039E88A54103FBC10BC4fA9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x40f7b17cc65b90feda698d7c7e1572c0cbc06499" + } + }, + { + "chainId": 137, + "name": "The Crowd", + "symbol": "CROWD", + "decimals": 18, + "address": "0x7f556fcB59a27b3E0046E3EA400A425a6ad2040D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7ce217b011ab060196128ab86a27be7763802fbc" + } + }, + { + "chainId": 137, + "name": "Day By Day Token", + "symbol": "DBD", + "decimals": 18, + "address": "0x72b9f88e822cf08B031c2206612B025a82fb303C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa5f1dbb0e55bc31f32c6d032bee330288490e722" + } + }, + { + "chainId": 137, + "name": "Taraxa Coin", + "symbol": "TARA", + "decimals": 18, + "address": "0xBEd23818D193B3573CFe651792ED6AD484dCC629", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf001937650bb4f62b57521824b2c20f5b91bea05" + } + }, + { + "chainId": 137, + "name": "Opacity", + "symbol": "OPCT", + "decimals": 18, + "address": "0xce6bF09e5c7A3E65B84F88DcC6475c88d38BA5eF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xDb05EA0877A2622883941b939f0bb11d1ac7c400" + } + }, + { + "chainId": 137, + "name": "#Smart Advertising Transaction Token", + "symbol": "SATT", + "decimals": 18, + "address": "0xF9137CF627878a1C7e2b0EEb1e91e64BbdbcFd27", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdf49c9f599a0a9049d97cff34d0c30e468987389" + } + }, + { + "chainId": 137, + "name": "ChartEx", + "symbol": "CHART", + "decimals": 18, + "address": "0xa09E1BF2205CDb1FBf57023258f3e731c5311b4d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1d37986f252d0e349522ea6c3b98cb935495e63e" + } + }, + { + "chainId": 137, + "name": "Cirus", + "symbol": "CIRUS", + "decimals": 18, + "address": "0x2a82437475A60BebD53e33997636fadE77604fc2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa01199c61841fce3b3dafb83fefc1899715c8756" + } + }, + { + "chainId": 137, + "name": "Ethereum Money", + "symbol": "ETHMNY", + "decimals": 2, + "address": "0x96f99063ECF25B72cEf4ed1473438AA623D27b82", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbf4a2ddaa16148a9d0fa2093ffac450adb7cd4aa" + } + }, + { + "chainId": 137, + "name": "Presail", + "symbol": "PRESAIL", + "decimals": 18, + "address": "0x566BE1AE21A925896A7d267A80ffCA5501653F14", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x232A6D2B6ea24676209905f77d5706e395c271C1" + } + }, + { + "chainId": 137, + "name": "NFT Zoo", + "symbol": "ZOOBY", + "decimals": 18, + "address": "0x755Df36E63e6452FaB42DB97490cd09f3958A8d7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xccddbab85426b81b6b2d5d804510aae07cb0d7e1" + } + }, + { + "chainId": 137, + "name": "bns.finance", + "symbol": "BNSD", + "decimals": 18, + "address": "0xFe457497A2A71bCE1eb93eA9e6a685057dd93dEe", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x668DbF100635f593A3847c0bDaF21f0a09380188" + } + }, + { + "chainId": 137, + "name": "BNS Token", + "symbol": "BNS", + "decimals": 8, + "address": "0x350bf84b899E3A7abC9048F28d25eaEBde8E9916", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x695106Ad73f506f9D0A9650a78019A93149AE07C" + } + }, + { + "chainId": 137, + "name": "yfii Tether USD", + "symbol": "iUSDT", + "decimals": 6, + "address": "0x6A3E4008aF5DCFc416e1B17130783dAEE13AB694", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x72cf258c852dc485a853370171d46b9d29fd3184" + } + }, + { + "chainId": 137, + "name": "DigitexFutures", + "symbol": "DGTX", + "decimals": 18, + "address": "0xE749Ea14A2D18E361eD092EbefbA64D77a8B4EaC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc666081073e8dff8d3d1c2292a29ae1a2153ec09" + } + }, + { + "chainId": 137, + "name": "Clover", + "symbol": "CLV", + "decimals": 6, + "address": "0x468041079d9d99c87F5a17b44Be6D6a529B5F597", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x22222c03318440305ac3e8a7820563d6a9fd777f" + } + }, + { + "chainId": 137, + "name": "AlphaToken", + "symbol": "ALPHA", + "decimals": 18, + "address": "0x3AE490db48d74B1bC626400135d4616377D0109f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa1faa113cbe53436df28ff0aee54275c13b40975" + } + }, + { + "chainId": 137, + "name": "Osinachi", + "symbol": "OSINA", + "decimals": 4, + "address": "0x574b21E8f0322acC3C9c31f4d291fD363867fbEe", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x39ad22c916f42af5f67371d6f2fb0dab42321a89" + } + }, + { + "chainId": 137, + "name": "Afrofuture", + "symbol": "AFTR", + "decimals": 8, + "address": "0x228a22bf6da9353Abbe37a31cf85c02dfC432456", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56dfa98f363edb99240b63f8a5141d8b64cfaf6e" + } + }, + { + "chainId": 137, + "name": "Convex Token", + "symbol": "CVX", + "decimals": 18, + "address": "0x4257EA7637c355F81616050CbB6a9b709fd72683", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4e3fbd56cd56c3e72c1403e103b45db9da5b9d2b" + } + }, + { + "chainId": 137, + "name": "dYdX", + "symbol": "DYDX", + "decimals": 18, + "address": "0x4C3bF0a3DE9524aF68327d1D2558a3B70d17D42a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x92d6c1e31e14520e676a687f0a93788b716beff5" + } + }, + { + "chainId": 137, + "name": "Toshi Token", + "symbol": "TOSHI", + "decimals": 18, + "address": "0xfE31a87c001c7B0FcDF4c480621222d4FE793364", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf136d7b0b7ae5b86d21e7b78dfa95375a7360f19" + } + }, + { + "chainId": 137, + "name": "GLOBALTRUSTFUND TOKEN", + "symbol": "GTF", + "decimals": 8, + "address": "0x8cB96E95C714E0996e6D299F617F518D965E352E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x87befc1d367190f2b9cbe9b689e0e5ca658e3b71" + } + }, + { + "chainId": 137, + "name": "XCAD Token", + "symbol": "XCAD", + "decimals": 18, + "address": "0xA55870278d6389ec5B524553D03C04F5677c061E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7659ce147d0e714454073a5dd7003544234b6aa0" + } + }, + { + "chainId": 137, + "name": "AllyFocus", + "symbol": "XYR", + "decimals": 18, + "address": "0x85BD0Db4F1B8bAE55a6Dc741D332b18bFb26A13e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56910520988c1d3edfdeae2acbe965d819b2e26d" + } + }, + { + "chainId": 137, + "name": "ORO Token", + "symbol": "ORO", + "decimals": 18, + "address": "0x2651b9C63290E543902dA4eb63c34029382FF552", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc3eb2622190c57429aac3901808994443b64b466" + } + }, + { + "chainId": 137, + "name": "GridZone.io", + "symbol": "ZONE", + "decimals": 18, + "address": "0x5Ab64dAAAa458d8f2019C0a3F2275FDc27e498D1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC1D9B5A0776d7C8B98b8A838e5a0DD1Bc5Fdd53C" + } + }, + { + "chainId": 137, + "name": "OddzToken", + "symbol": "ODDZ", + "decimals": 18, + "address": "0xC1e2ca002E03207F933d358DbDEcBaD108C4191a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcd2828fc4d8e8a0ede91bb38cf64b1a81de65bf6" + } + }, + { + "chainId": 137, + "name": "Epicenter Token", + "symbol": "ECR", + "decimals": 18, + "address": "0x89606fA5d084edA5E9949F7b8F750c65c609eB46", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x62De7d65739d2ac81C12CC30BBB1223c88753C23" + } + }, + { + "chainId": 137, + "name": "EtherCats.io", + "symbol": "ECAT", + "decimals": 18, + "address": "0xa1D6Cd1a37f82813Ac9852cd7E96f909cbccEa06", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x120cBc99bb2a713872C6B8d06306Ddb79c55E96f" + } + }, + { + "chainId": 137, + "name": "WIPcoin", + "symbol": "WIPC", + "decimals": 18, + "address": "0x8Cd9524406e9571EF524DBE8dFaCC7743fA72507", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xab47fbe8A0b75Baa4Ef846E99f6bB3b52007A115" + } + }, + { + "chainId": 137, + "name": "Kwikswap", + "symbol": "KWIK", + "decimals": 18, + "address": "0x8DF74088b3aeCfd0cB97BcFd053B173782f01e3A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x286C0936c7Eaf6651099Ab5DAb9ee5A6cB5d229D" + } + }, + { + "chainId": 137, + "name": "Etherdieum", + "symbol": "ED", + "decimals": 8, + "address": "0x7Dadd73F6AE9e4cE0bA50d8818ebd8A7eC578b11", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x502d9bd338486432c3eddfd3d578e9dc9f0e6372" + } + }, + { + "chainId": 137, + "name": "HHKcoin", + "symbol": "HHK", + "decimals": 18, + "address": "0x82f735270cfcCbCbceA08141f93Ed1816B779874", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc7b54f6d4d240aa2589d64f1e4608e614c84d60d" + } + }, + { + "chainId": 137, + "name": "GODL", + "symbol": "GODL", + "decimals": 18, + "address": "0xb233c90A0ebe7E19C30dB979B602803715cDB398", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7f509465c38b66bdecec2cfdc842e11809cc8357" + } + }, + { + "chainId": 137, + "name": "Hot Cross Token", + "symbol": "HOTCROSS", + "decimals": 18, + "address": "0x3b737a181f7d2532cF49864f8050b3465a310593", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4297394c20800e8a38a619a243e9bbe7681ff24e" + } + }, + { + "chainId": 137, + "name": "DAO Invest", + "symbol": "VEST", + "decimals": 18, + "address": "0x381caf412B45dAc0f62FBEeC89DE306D3eABE384", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1f19f83fC9a25F3C861260143E36c17706257986" + } + }, + { + "chainId": 137, + "name": "IDEX Token", + "symbol": "IDEX", + "decimals": 18, + "address": "0x9Cb74C8032b007466865f060ad2c46145d45553D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb705268213d593b8fd88d3fdeff93aff5cbdcfae" + } + }, + { + "chainId": 137, + "name": "SMART TRADE NETWORKS 5", + "symbol": "STN5", + "decimals": 18, + "address": "0xE4f0EefC8b184d9AFDD5Cfb6e4281ec27B6f3095", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x55150E8378B81F930f310d4B62AB7e1252c30B9B" + } + }, + { + "chainId": 137, + "name": "Bankless BED Index", + "symbol": "BED", + "decimals": 18, + "address": "0xeEDa694439C6FB56CbAA011cC849650b7273285B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2af1df3ab0ab157e1e2ad8f88a7d04fbea0c7dc6" + } + }, + { + "chainId": 137, + "name": "SW Capital", + "symbol": "SWC", + "decimals": 18, + "address": "0x01aE14B9643a720Dc3181abfA05e65c528b5A30F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8dca21c5c8165886ea1fa800ff9321ec74fde2c0" + } + }, + { + "chainId": 137, + "name": "Wasabi", + "symbol": "WASABI", + "decimals": 18, + "address": "0x167F8C8A1AF9A4c851C8E541BA0f9939D395cCF1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x896e145568624a498c5a909187363AE947631503" + } + }, + { + "chainId": 137, + "name": "Atlas Rising", + "symbol": "rising", + "decimals": 18, + "address": "0xa83D20E7B0e5c3483bbF65091c3591cEB7f75D97", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf4383b0aeb7f6c3ad411dc5f3d83594592646b11" + } + }, + { + "chainId": 137, + "name": "ARPA Token", + "symbol": "ARPA", + "decimals": 18, + "address": "0xEE800B277A96B0f490a1A732e1D6395FAD960A26", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xba50933c268f567bdc86e1ac131be072c6b0b71a" + } + }, + { + "chainId": 137, + "name": "Nsure Network Token", + "symbol": "Nsure", + "decimals": 18, + "address": "0x2D61F243d1a4c16640c3961100f50222679EC89E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x20945cA1df56D237fD40036d47E866C7DcCD2114" + } + }, + { + "chainId": 137, + "name": "Blockchain Certified Data Token", + "symbol": "BCDT", + "decimals": 18, + "address": "0xe7789178ddC4Edb3b038115B1826c66640C57Ecc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xacfa209fb73bf3dd5bbfb1101b9bc999c49062a5" + } + }, + { + "chainId": 137, + "name": "Tyrannical", + "symbol": "TIN", + "decimals": 8, + "address": "0xEF6B7E511c18B5fC0099e680f17AE5C3b7601d26", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xA52360d0e1290023100D0787623faA0b1784E7ff" + } + }, + { + "chainId": 137, + "name": "Aragon Network Token", + "symbol": "ANT", + "decimals": 18, + "address": "0x2b8504ab5eFc246d0eC5Ec7E74565683227497de", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa117000000f279d81a1d3cc75430faa017fa5a2e" + } + }, + { + "chainId": 137, + "name": "Dragon", + "symbol": "DRGN", + "decimals": 18, + "address": "0xE69Fa47DFe3aA7F5e5F5642110901f917513459b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x419c4db4b9e25d6db2ad9691ccb832c8d9fda05e" + } + }, + { + "chainId": 137, + "name": "Cindicator Token", + "symbol": "CND", + "decimals": 18, + "address": "0x7f4e5fC5D43D1EB91447011AC83957F673e31E9A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd4c435f5b09f855c3317c8524cb1f586e42795fa" + } + }, + { + "chainId": 137, + "name": "UnoRe", + "symbol": "UNO", + "decimals": 18, + "address": "0xb7403EdAA4Ff25Fd05E5b8ee83DeE53F15C4DB39", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x474021845c4643113458ea4414bdb7fb74a01a77" + } + }, + { + "chainId": 137, + "name": "Bitcoin Black", + "symbol": "BLACK", + "decimals": 18, + "address": "0xEE619a5bC09d6FAC8eB05B1031e5B3379f92F29E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf7ae0daa230bf3fb3c0e5e01e7a6e0a142c6cf7e" + } + }, + { + "chainId": 137, + "name": "OpenOcean", + "symbol": "OOE", + "decimals": 18, + "address": "0x9d5565dA88e596730522CbC5a918d2A89dbC16d9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7778360f035c589fce2f4ea5786cbd8b36e5396b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ooe.svg" + }, + { + "chainId": 137, + "name": "Wirex Token", + "symbol": "WXT", + "decimals": 18, + "address": "0xC4d094E246B69BB1F2EeDde1e5026BEba532248e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa02120696c7B8fE16C09C749E4598819b2B0E915" + } + }, + { + "chainId": 137, + "name": "Gen Shards", + "symbol": "GS", + "decimals": 18, + "address": "0xBfa05E530f42999AAfC5F15F98AfdF0667e312Bc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe0B9a2C3E9f40CF74B2C7F591B2b0CCa055c3112" + } + }, + { + "chainId": 137, + "name": "$Poolz Finance", + "symbol": "POOLZ", + "decimals": 18, + "address": "0xa052EFCDd44F02073B1FDC42bF06017A0234ae03", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x69a95185ee2a045cdc4bcd1b1df10710395e4e23" + } + }, + { + "chainId": 137, + "name": "BasketDAO DeFi Index", + "symbol": "BDI", + "decimals": 18, + "address": "0x76b1575482BcAA7815964Ed6759FE4bc4b0eB8b2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0309c98B1bffA350bcb3F9fB9780970CA32a5060" + } + }, + { + "chainId": 137, + "name": "Sheesha Finance", + "symbol": "SHEESHA", + "decimals": 18, + "address": "0xAE8948Bc6b4ec35FfE7Decc6BEb205Ea6d077b57", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x232FB065D9d24c34708eeDbF03724f2e95ABE768" + } + }, + { + "chainId": 137, + "name": "GamyFi", + "symbol": "GFX", + "decimals": 18, + "address": "0x99aC53C1ab08BAA7c83f444Ebf442d0fcbb09DB6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE4fA3C576c31696322e8d7165C5965d5a1F6A1A5" + } + }, + { + "chainId": 137, + "name": "Cover Protocol Governance Token", + "symbol": "COVER", + "decimals": 18, + "address": "0x708CCa2f9EdED49918865Fd45442eF733155CAcb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4688a8b1F292FDaB17E9a90c8Bc379dC1DBd8713" + } + }, + { + "chainId": 137, + "name": "Lido DAO Token", + "symbol": "LDO", + "decimals": 18, + "address": "0xC3C7d422809852031b44ab29EEC9F1EfF2A58756", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5A98FcBEA516Cf06857215779Fd812CA3beF1B32" + } + }, + { + "chainId": 137, + "name": "Base Protocol", + "symbol": "BASE", + "decimals": 9, + "address": "0xd4E3F03095A252323506Dd589810Dc78cEa0A923", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x07150e919B4De5fD6a63DE1F9384828396f25fDC" + } + }, + { + "chainId": 137, + "name": "DODO bird", + "symbol": "DODO", + "decimals": 18, + "address": "0xe4Bf2864ebeC7B7fDf6Eeca9BaCAe7cDfDAffe78", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x43Dfc4159D86F3A37A5A4B3D4580b888ad7d4DDd" + } + }, + { + "chainId": 137, + "name": "Ferrum Network Token", + "symbol": "FRM", + "decimals": 6, + "address": "0x0cdf14B01692c57fD8d066A053B3A0FA0Aa2Fc11", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE5CAeF4Af8780E59Df925470b050Fb23C43CA68C" + } + }, + { + "chainId": 137, + "name": "DLP Duck Token", + "symbol": "DUCK", + "decimals": 18, + "address": "0x2B34c0efB7Eeb5bEd0A7253581dB085171dAcB71", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC0bA369c8Db6eB3924965e5c4FD0b4C1B91e305F" + } + }, + { + "chainId": 137, + "name": "StorjToken", + "symbol": "STORJ", + "decimals": 8, + "address": "0xd72357dAcA2cF11A5F155b9FF7880E595A3F5792", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xB64ef51C888972c908CFacf59B47C1AfBC0Ab8aC" + } + }, + { + "chainId": 137, + "name": "OKB", + "symbol": "OKB", + "decimals": 18, + "address": "0x8F94400CDeF837F388100cfE56D7ebB8a3A3fb44", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x75231F58b43240C9718Dd58B4967c5114342a86c" + } + }, + { + "chainId": 137, + "name": "renBCH", + "symbol": "renBCH", + "decimals": 8, + "address": "0x627C50aa6A384933d6354448f70476D3BD02Fcc8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x459086F2376525BdCebA5bDDA135e4E9d3FeF5bf" + } + }, + { + "chainId": 137, + "name": "renZEC", + "symbol": "renZEC", + "decimals": 8, + "address": "0x6f0CAd28165121Ab60d3D5504A702e77d644E367", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1C5db575E2Ff833E46a2E9864C22F4B22E0B37C2" + } + }, + { + "chainId": 137, + "name": "Morpheus Infrastructure Token", + "symbol": "MITx", + "decimals": 18, + "address": "0x31042A4E66eDa0d12143ffc8cC1552D611dA4cbA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4a527d8fc13C5203AB24BA0944F4Cb14658D1Db6" + } + }, + { + "chainId": 137, + "name": "ASSY Index", + "symbol": "ASSY", + "decimals": 18, + "address": "0xd6d8fFC109a3EE48b0c1163a062eaD5Fcc83416e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xFA2562da1Bba7B954f26C74725dF51fb62646313" + } + }, + { + "chainId": 137, + "name": "Shadows Network", + "symbol": "DOWS", + "decimals": 18, + "address": "0xf3681947a43F180ea68a8b949F5E7A18df946a09", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x661Ab0Ed68000491d98C796146bcF28c20d7c559" + } + }, + { + "chainId": 137, + "name": "Ampleforth", + "symbol": "AMPL", + "decimals": 9, + "address": "0x688AB7562301b3B58B67bEB614986B51ad3698eB", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD46bA6D942050d489DBd938a2C909A5d5039A161" + } + }, + { + "chainId": 137, + "name": "yffi.finance", + "symbol": "YFFI", + "decimals": 18, + "address": "0xf862E6a988d0B7B7Bf2f87b8E28454fAfc5A4237", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xCee1d3c3A02267e37E6B373060F79d5d7b9e1669" + } + }, + { + "chainId": 137, + "name": "DuckDaoDime", + "symbol": "DDIM", + "decimals": 18, + "address": "0x0a5e1dE30E943421Ed9faAeC815125B6BdF9383e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xFbEEa1C75E4c4465CB2FCCc9c6d6afe984558E20" + } + }, + { + "chainId": 137, + "name": "TrueFi", + "symbol": "TRU", + "decimals": 8, + "address": "0x5b77bCA482bd3E7958b1103d123888EfCCDaF803", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4C19596f5aAfF459fA38B0f7eD92F11AE6543784" + } + }, + { + "chainId": 137, + "name": "BitMax token", + "symbol": "BTMX", + "decimals": 18, + "address": "0xf6a0277582919ea0A78078F54CD11a4bcCfd6Ac7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcca0c9c383076649604eE31b20248BC04FdF61cA" + } + }, + { + "chainId": 137, + "name": "TenX Pay Token", + "symbol": "PAY", + "decimals": 18, + "address": "0x163e9c8DF744B38Fe1975fBED2Eb3d9005c6655F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xB97048628DB6B661D4C2aA833e95Dbe1A905B280" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pay.svg" + }, + { + "chainId": 137, + "name": "Perlin", + "symbol": "PERL", + "decimals": 18, + "address": "0xB121FCD122DAAa153bB8a102754127b2682645CB", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeca82185adCE47f39c684352B0439f030f860318" + } + }, + { + "chainId": 137, + "name": "Compound 0x", + "symbol": "cZRX", + "decimals": 8, + "address": "0x62059c1F748CD663798CEe1B31e86ce28bA73eC2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xB3319f5D18Bc0D84dD1b4825Dcde5d5f7266d407" + } + }, + { + "chainId": 137, + "name": "Monolith TKN", + "symbol": "TKN", + "decimals": 8, + "address": "0xD98DeFAC38214426Ef58Cf7996DE8b373933f902", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaAAf91D9b90dF800Df4F55c205fd6989c977E73a" + } + }, + { + "chainId": 137, + "name": "LoomToken", + "symbol": "LOOM", + "decimals": 18, + "address": "0x66EfB7cC647e0efab02eBA4316a2d2941193F6b3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA4e8C3Ec456107eA67d3075bF9e3DF3A75823DB0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/loom.svg" + }, + { + "chainId": 137, + "name": "StableUSD", + "symbol": "USDS", + "decimals": 6, + "address": "0xb09C87726059f2a3d6b795cc7252A225292A53E1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA4Bdb11dc0a2bEC88d24A3aa1E6Bb17201112eBe" + } + }, + { + "chainId": 137, + "name": "Pundi X Token", + "symbol": "NPXS", + "decimals": 18, + "address": "0x8d42eCce45f4B30ff2435bD19a983f7616adD16e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA15C7Ebe1f07CaF6bFF097D8a589fb8AC49Ae5B3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/npxs.svg" + }, + { + "chainId": 137, + "name": "Orion Protocol", + "symbol": "ORN", + "decimals": 8, + "address": "0x0EE392bA5ef1354c9bd75a98044667d307C0e773", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0258F474786DdFd37ABCE6df6BBb1Dd5dfC4434a" + } + }, + { + "chainId": 137, + "name": "APYSwap", + "symbol": "APYS", + "decimals": 18, + "address": "0x0FfC26BEDf1EB59B27479f0b79D95f61DCFB200C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf7413489c474ca4399eeE604716c72879Eea3615" + } + }, + { + "chainId": 137, + "name": "DIAToken", + "symbol": "DIA", + "decimals": 18, + "address": "0x993f2CafE9dbE525243f4A78BeBC69DAc8D36000", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x84cA8bc7997272c7CfB4D0Cd3D55cd942B3c9419" + } + }, + { + "chainId": 137, + "name": "Geeq", + "symbol": "GEEQ", + "decimals": 18, + "address": "0x3Ea044a788fF278d4150CE1741c888fFed6Ce44F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6B9f031D718dDed0d681c20cB754F97b3BB81b78" + } + }, + { + "chainId": 137, + "name": "SIRIN", + "symbol": "SRN", + "decimals": 18, + "address": "0xb37Dc3620b3ed0D09bBD43BCB9ceF277a6a0f49B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x68d57c9a1C35f63E2c83eE8e49A64e9d70528D25" + } + }, + { + "chainId": 137, + "name": "POA ERC20 on Foundation", + "symbol": "POA20", + "decimals": 18, + "address": "0xFc192E1943289d6731Ae72850da167f4c194ab91", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6758B7d441a9739b98552B373703d8d3d14f9e62" + } + }, + { + "chainId": 137, + "name": "Synth sETH", + "symbol": "sETH", + "decimals": 18, + "address": "0x53c1AB7a25F1A44921dE8BF479F5528845fc1254", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5e74C9036fb86BD7eCdcb084a0673EFc32eA31cb" + } + }, + { + "chainId": 137, + "name": "Compound Dai", + "symbol": "cDAI", + "decimals": 8, + "address": "0x6fe9C1631b37a2b438CFD3d67409E15503Ddd535", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5d3a536E4D6DbD6114cc1Ead35777bAB948E3643" + } + }, + { + "chainId": 137, + "name": "Digix Gold Token", + "symbol": "DGX", + "decimals": 9, + "address": "0xEd29195ecd25Da21E8942884C5fAebAfD4E07dab", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4f3AfEC4E5a3F2A6a1A411DEF7D7dFe50eE057bF" + } + }, + { + "chainId": 137, + "name": "VIDT Datalink", + "symbol": "VIDT", + "decimals": 18, + "address": "0x9aAcb53AF37FE363E462A72Bc30F35a4d20f285f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfeF4185594457050cC9c23980d301908FE057Bb1" + } + }, + { + "chainId": 137, + "name": "Civic", + "symbol": "CVC", + "decimals": 8, + "address": "0x66Dc5A08091d1968e08C16aA5b27BAC8398b02Be", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41e5560054824ea6b0732e656e3ad64e20e94e45" + } + }, + { + "chainId": 137, + "name": "XinFin XDCE", + "symbol": "XDCE", + "decimals": 18, + "address": "0xfdCA275366efac9204D2d8D3D7A9428CA947307B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41ab1b6fcbb2fa9dced81acbdec13ea6315f2bf2" + } + }, + { + "chainId": 137, + "name": "FunFair", + "symbol": "FUN", + "decimals": 8, + "address": "0x2c14C84D08b35a8135f57338816f5FcBEac08d35", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x419d0d8bdd9af5e606ae2232ed285aff190e711b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/fun.svg" + }, + { + "chainId": 137, + "name": "BiLira", + "symbol": "TRYB", + "decimals": 6, + "address": "0x4Fb71290Ac171E1d144F7221D882BECAc7196EB5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2c537e5624e4af88a7ae4060c022609376c8d0eb" + } + }, + { + "chainId": 137, + "name": "AirSwap Token", + "symbol": "AST", + "decimals": 4, + "address": "0x04bEa9FCE76943E90520489cCAb84E84C0198E29", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x27054b13b1b798b345b591a4d22e6562d47ea75a" + } + }, + { + "chainId": 137, + "name": "DEXTools", + "symbol": "DEXT", + "decimals": 18, + "address": "0xff835562C761205659939B64583dd381a6AA4D92", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfb7b4564402e5500db5bb6d63ae671302777c75a" + } + }, + { + "chainId": 137, + "name": "Reserve", + "symbol": "RSV", + "decimals": 18, + "address": "0xE1444fa4b5c530E46b79A47bA1a8DFE252B8A1c0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x196f4727526eA7FB1e17b2071B3d8eAA38486988" + } + }, + { + "chainId": 137, + "name": "Reputation", + "symbol": "REPv2", + "decimals": 18, + "address": "0x6563c1244820CfBd6Ca8820FBdf0f2847363F733", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x221657776846890989a759BA2973e427DfF5C9bB" + } + }, + { + "chainId": 137, + "name": "Numeraire", + "symbol": "NMR", + "decimals": 18, + "address": "0x0Bf519071b02F22C17E7Ed5F4002ee1911f46729", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1776e1f26f98b1a5df9cd347953a26dd3cb46671" + } + }, + { + "chainId": 137, + "name": "uDOO", + "symbol": "uDOO", + "decimals": 18, + "address": "0x0C2ea0623E1C19bfB984Dce137404671a95f3478", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x12f649A9E821F90BB143089a6e56846945892ffB" + } + }, + { + "chainId": 137, + "name": "XIO Network", + "symbol": "XIO", + "decimals": 18, + "address": "0x9C81077ffdd65b7E3833dd576AA94bf4B49b00F0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0f7f961648ae6db43c75663ac7e5414eb79b5704" + } + }, + { + "chainId": 137, + "name": "Rari Governance Token", + "symbol": "RGT", + "decimals": 18, + "address": "0x3b9dB434F08003A89554CDB43b3e0b1f8734BdE7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD291E7a03283640FDc51b121aC401383A46cC623" + } + }, + { + "chainId": 137, + "name": "Moss Coin", + "symbol": "MOC", + "decimals": 18, + "address": "0x4Ded021C6f02dB04C9e9A97b898d36348094B9b8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x865ec58b06bF6305B886793AA20A2da31D034E68" + } + }, + { + "chainId": 137, + "name": "DOS Network Token", + "symbol": "DOS", + "decimals": 18, + "address": "0x0597a52b14B0DCA2158665d6961572E371Ff5678", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0a913bead80f321e7ac35285ee10d9d922659cb7" + } + }, + { + "chainId": 137, + "name": "MATH Token", + "symbol": "MATH", + "decimals": 18, + "address": "0x347ACCAFdA7F8c5BdeC57fa34a5b663CBd1aeca7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x08d967bb0134F2d07f7cfb6E246680c53927DD30" + } + }, + { + "chainId": 137, + "name": "Uptrennd", + "symbol": "1UP", + "decimals": 18, + "address": "0x77266e2B73adb5605D9877fE3d86b217eFA5cB49", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x07597255910a51509CA469568B048F2597E72504" + } + }, + { + "chainId": 137, + "name": "Liquidity Dividends Protocol", + "symbol": "LID", + "decimals": 18, + "address": "0xA9ADe7b8C8252b1E17cAFa53BF46FF1319F8532D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0417912b3a7AF768051765040A55BB0925D4DDcF" + } + }, + { + "chainId": 137, + "name": "PieDAO BTC++", + "symbol": "BTC++", + "decimals": 18, + "address": "0x6B3d5099c4827a3fC7C858865c1Cea15c3fe58ee", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0327112423F3A68efdF1fcF402F6c5CB9f7C33fd" + } + }, + { + "chainId": 137, + "name": "Stox", + "symbol": "STX", + "decimals": 18, + "address": "0xB36e3391B22a970d31A9b620Ae1A414C6c256d2a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x006BeA43Baa3f7A6f765F14f10A1a1b08334EF45" + } + }, + { + "chainId": 137, + "name": "NXM", + "symbol": "NXM", + "decimals": 18, + "address": "0xB2B613b771e5A5DDa496733B4024d34f309CC03d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd7c49cee7e9188cca6ad8ff264c1da2e69d4cf3b" + } + }, + { + "chainId": 137, + "name": "Compound USDT", + "symbol": "cUSDT", + "decimals": 8, + "address": "0x61B3c650154f9525dad3c1010de959fc6e2218F3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf650c3d88d12db855b8bf7d11be6c55a4e07dcc9" + } + }, + { + "chainId": 137, + "name": "Wrapped Centrifuge", + "symbol": "wCFG", + "decimals": 18, + "address": "0x90bb6fEB70A9a43CfAaA615F856BA309FD759A90", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc221b7e65ffc80de234bbb6667abdd46593d34f0" + } + }, + { + "chainId": 137, + "name": "Wrapped ANC Token", + "symbol": "ANC", + "decimals": 18, + "address": "0x60E68D032deB4c238c2ba580EC0F22516ebcbc13", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0f3adc247e91c3c50bc08721355a41037e89bc20" + } + }, + { + "chainId": 137, + "name": "Wrapped MIR Token", + "symbol": "MIR", + "decimals": 18, + "address": "0x1C5cccA2CB59145A4B25F452660cbA6436DDce9b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x09a3ecafa817268f77be1283176b946c4ff2e608" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror AAPL Token", + "symbol": "mAAPL", + "decimals": 18, + "address": "0x7E4e3923005aC2942745480D96751Ca9DEc5C9B6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd36932143F6eBDEDD872D5Fb0651f4B72Fd15a84" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror GOOGL Token", + "symbol": "mGOOGL", + "decimals": 18, + "address": "0x41970f24B738aA21152fDF05d65a688A9A3C63c7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x59A921Db27Dd6d4d974745B7FfC5c33932653442" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror NFLX Token", + "symbol": "mNFLX", + "decimals": 18, + "address": "0xB261387f5188c81DdD543e2A75c89309aB1bfD2C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC8d674114bac90148d11D3C1d33C61835a0F9DCD" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror QQQ Token", + "symbol": "mQQQ", + "decimals": 18, + "address": "0x20269A36538fbD3f33f1688919776E2220455567", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x13B02c8dE71680e71F0820c996E4bE43c2F57d15" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror TWTR Token", + "symbol": "mTWTR", + "decimals": 18, + "address": "0x5c7d670637CBAc5Cd71ddF3DF7DECee2A46dbFE2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEdb0414627E6f1e3F082DE65cD4F9C693D78CCA9" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror MSFT Token", + "symbol": "mMSFT", + "decimals": 18, + "address": "0xc4483AfED7159AF6b7D2eF41a18BC82F5081C063", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41BbEDd7286dAab5910a1f15d12CBda839852BD7" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror AMZN Token", + "symbol": "mAMZN", + "decimals": 18, + "address": "0xC46e5F28f1A7AdeAC72b0d2bC0c710dF865776F1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0cae9e4d663793c2a2A0b211c1Cf4bBca2B9cAa7" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror BABA Token", + "symbol": "mBABA", + "decimals": 18, + "address": "0x0959CAD1298a204277C1b5C00F62D9F2cb0b6756", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56aA298a19C93c6801FDde870fA63EF75Cc0aF72" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror IAU Token", + "symbol": "mIAU", + "decimals": 18, + "address": "0xB38B63CbcCd3239D72AB133771382BBbcf4BEd02", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1d350417d9787E000cc1b95d70E9536DcD91F373" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror USO Token", + "symbol": "mUSO", + "decimals": 18, + "address": "0xe861920768dA0310B125C27A44ADDA11532ab838", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x31c63146a635EB7465e5853020b39713AC356991" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror FB Token", + "symbol": "mFB", + "decimals": 18, + "address": "0xcDb3ff438D8fbC7B09a70311178eC68Ef4EAff00", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0e99cC0535BB6251F6679Fa6E65d6d3b430e840B" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror COIN Token", + "symbol": "mCOIN", + "decimals": 18, + "address": "0x14c36A063414Ee9BfA9Ef2bD0e1FdFAE690512be", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1e25857931F75022a8814e0B0c3a371942A88437" + } + }, + { + "chainId": 137, + "name": "DeversiFi Token", + "symbol": "DVF", + "decimals": 18, + "address": "0x02c46650701dD6b83dceC3472fC3fD69eA1a5ab7", + "logoURI": "https://deversifi.com/wp-content/uploads/2022/03/dvf.d8ad4805.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdddddd4301a082e62e84e43f474f044423921918" + } + }, + { + "chainId": 137, + "name": "RAKUN", + "symbol": "RAKU", + "decimals": 18, + "address": "0x2e02D3C4b81498177783584b842821864245cE50", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x51bc0deaf7bbe82bc9006b0c3531668a4206d27f" + } + }, + { + "chainId": 137, + "name": "Origin Dollar", + "symbol": "OUSD", + "decimals": 18, + "address": "0x655BD74cd109ebDd0b030Eb4609B9214028f7729", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2A8e1E676Ec238d8A992307B495b45B3fEAa5e86" + } + }, + { + "chainId": 137, + "name": "Inverse BTC Volatility Index", + "symbol": "iBTCV", + "decimals": 18, + "address": "0x89b1F5DB1797f82af33dED6e6B50623a83aE84fA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2590F1fD14Ef8Bb0A46C7A889c4CBc146510f9C3" + } + }, + { + "chainId": 137, + "name": "BTC Volatility Index", + "symbol": "BTCV", + "decimals": 18, + "address": "0xE52F979590067637120004D188771b4aE48807Ee", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x51B0bcBEFf204B39Ce792D1E16767Fe6F7631970" + } + }, + { + "chainId": 137, + "name": "Inverse ETH Volatility Index", + "symbol": "iETHV", + "decimals": 18, + "address": "0x39cDBd331c94d781D4B50802346152549689B1e5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3A707d56D538e85B783E8CE12B346e7fB6511F90" + } + }, + { + "chainId": 137, + "name": "ETH Volatility Index", + "symbol": "ETHV", + "decimals": 18, + "address": "0x3Dbd2A88627566306AE9f5F5FB466B498535aF21", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xC53342fd7575f572b0fF4569e31941A5B821aC76" + } + }, + { + "chainId": 137, + "name": "Resardis Token", + "symbol": "RSD", + "decimals": 18, + "address": "0x542af0d2Ec7f5a92F9caddaDD4e33B75d15F800c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x73627974adea82397bcf7fac5848207cce88938d" + } + }, + { + "chainId": 137, + "name": "BitBase", + "symbol": "BTBS", + "decimals": 18, + "address": "0x921cfe00bDc605c452412079b315Ead661983B10", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x32e6c34cd57087abbd59b5a4aecc4cb495924356" + } + }, + { + "chainId": 137, + "name": "Roxel DAO", + "symbol": "ROX", + "decimals": 18, + "address": "0x7767Ba7fB74082E02b821C341f9565Ce6440Fb26", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf4284a849c918ef676f54ed938703f2eeed3e058" + } + }, + { + "chainId": 137, + "name": "Infinity Diamond", + "symbol": "INF", + "decimals": 18, + "address": "0xcbEF7a4B4385Db4747362b900b6f6f8051B152c0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x506c6fc9d6f764338a4e1eed5f526ab440d0cc05" + } + }, + { + "chainId": 137, + "name": "Happy Monkey 🐵🐵🐵🐵🐵🐵🐵🐵", + "symbol": "HAPPY", + "decimals": 18, + "address": "0x3b7377F91F9682335C6d959E91b107d313C397cC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfb36b29cb225f564030024d329c837f0bf959daf" + } + }, + { + "chainId": 137, + "name": "Crypto Excellence", + "symbol": "CE", + "decimals": 18, + "address": "0x5dC70fAE21c9e21d47E1be6Cb01bBEb0c4d12CA3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8f12dfc7981de79a8a34070a732471f2d335eece" + } + }, + { + "chainId": 137, + "name": "Ultra Token", + "symbol": "UOS", + "decimals": 4, + "address": "0x1dce4a8b459A50F450EE91Fb5e6c86d161aA22f8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd13c7342e1ef687c5ad21b27c2b65d772cab5c8c" + } + }, + { + "chainId": 137, + "name": "MoonEdge", + "symbol": "MOONED", + "decimals": 18, + "address": "0x7E4c577ca35913af564ee2a24d882a4946Ec492B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7E4c577ca35913af564ee2a24d882a4946Ec492B" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mooned.svg" + }, + { + "chainId": 137, + "name": "Melon Token", + "symbol": "MLN", + "decimals": 18, + "address": "0xa9f37d84c856fda3812ad0519dad44fa0a3fe207", + "logoURI": "https://user-images.githubusercontent.com/28834887/157407476-6a64c697-341b-479c-be97-ce6aadc1a8fa.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xec67005c4e498ec7f55e092bd1d35cbc47c91892" + } + }, + { + "chainId": 137, + "name": "loser coin", + "symbol": "lowb", + "decimals": 18, + "address": "0x1C0a798B5a5273a9e54028eb1524fD337B24145F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x69e5c11a7c30f0bf84a9faecbd5161aa7a94deca" + } + }, + { + "chainId": 137, + "name": "JUMP", + "symbol": "$JUMP", + "decimals": 18, + "address": "0xEd558Bb8881163AFdC9F3BdBa5F43Fd527c39Af8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE650b007529F445EaE83bc931Abaa9bb1eFECA6f" + } + }, + { + "chainId": 137, + "name": "DeepGo Token", + "symbol": "DGT", + "decimals": 18, + "address": "0x839d8Cc21F51ddDcB635064f8d11166e6D0053c5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC8eEC1277B84fC8a79364D0add8C256b795C6727" + } + }, + { + "chainId": 137, + "name": "SAUNALAND", + "symbol": "SAUNA", + "decimals": 18, + "address": "0xea9D32bf641ee72bA1f301512891fBc96d39e6B2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x82b666f1d7d6439b32f580335e492cb31a07bff5" + } + }, + { + "chainId": 137, + "name": "CodeCoin", + "symbol": "CODE", + "decimals": 18, + "address": "0x9FF32E82C4c80499266cA26776c535458B758369", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9adaba9ffda15e3a043c907d390f645147eb532a" + } + }, + { + "chainId": 137, + "name": "Matching Cards", + "symbol": "MATCH", + "decimals": 18, + "address": "0x82Ea80b9E021E8CB4a2b20e1BE60fe2CA04c9621", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9217c19e72e4ab9e1015ebe9098285a6ef1761c3" + } + }, + { + "chainId": 137, + "name": "Convertible Phoenix Token", + "symbol": "cPHX", + "decimals": 18, + "address": "0x54a02FD4AeFc77aA97Cd3d30322F3E7a7D875a27", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xBdD50c7B6c871D9aFB278445d5b74fDc4705a234" + } + }, + { + "chainId": 137, + "name": "DinoSwap", + "symbol": "DINO", + "decimals": 18, + "address": "0xAa9654BECca45B5BDFA5ac646c939C62b527D394", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2701E1D67219a49F5691C92468Fe8D8ADc03e609" + } + }, + { + "chainId": 137, + "name": "BOWIE", + "symbol": "BOWIE", + "decimals": 9, + "address": "0x8f6A1c0C10B72c1218270c81B0D5740aaE71f91d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x077e06ad69983b12fc4e83b51260b894c7841d1e" + } + }, + { + "chainId": 137, + "name": "Marvin Coin", + "symbol": "MARVIN", + "decimals": 18, + "address": "0x268c4a88208B5b22993D1E56D5Fc039A28d1a18C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4bb12e64be9310d61f9a7950f4c3de50eb4c9807" + } + }, + { + "chainId": 137, + "name": "CatNorris Revenge", + "symbol": "$CATNORRIS", + "decimals": 9, + "address": "0xe7C83848aD3d46B002E6F0DFA135aeFC16D8A30f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x920fbc929bb5940fc44dd722577d542caa0cd6d8" + } + }, + { + "chainId": 137, + "name": "Cryptid", + "symbol": "CID", + "decimals": 18, + "address": "0xb8DD82E944354B7bf9e9E0744ba5fF786581d372", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4599836c212cd988eaccc54c820ee9261cdaac71" + } + }, + { + "chainId": 137, + "name": "Tartarus", + "symbol": "TAR", + "decimals": 8, + "address": "0x2cf15C001A2A5dA76bf213D17763e5C856aE3632", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc567bca531992352166252ea5121e535432e81ed" + } + }, + { + "chainId": 137, + "name": "ChiHuaHua Finance", + "symbol": "CHUA", + "decimals": 18, + "address": "0xdD5E426362ef1B524d156335901be65F4573FF8E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb8dbce6859ba9a46e8072bc2b5bf0d8c6b751fcd" + } + }, + { + "chainId": 137, + "name": "Yuán 猿", + "symbol": "YUAN", + "decimals": 9, + "address": "0x1ddD49dF0097700479D89b361384ACFAF21f9621", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4f8cc34bfdd972bdbeaf4cc5118fba1382abb550" + } + }, + { + "chainId": 137, + "name": "Melalie", + "symbol": "MEL", + "decimals": 18, + "address": "0xb9784E05C7af6068FC82A80730a599fE17Ca2aDf", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xed0889f7e1c7c7267407222be277e1f1ef4d4892" + } + }, + { + "chainId": 137, + "name": "VNDC", + "symbol": "VNDC", + "decimals": 0, + "address": "0xC87DC7474DB6cdb9D37cc38A227DCd7b12289F22", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1f3f677ecc58f6a1f9e2cf410df4776a8546b5de" + } + }, + { + "chainId": 137, + "name": "Adshares", + "symbol": "ADS", + "decimals": 11, + "address": "0x598e49f01bEfeB1753737934a5b11fea9119C796", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcfcecfe2bd2fed07a9145222e8a7ad9cf1ccd22a" + } + }, + { + "chainId": 137, + "name": "EdgeTest", + "symbol": "EDGT", + "decimals": 18, + "address": "0x24F8A7bB3190039b4Cf0F96Cd72e2EA3a2D82256", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9D7e326b8C87E48b84dE6d300D7Bee3Ce42EfC37" + } + }, + { + "chainId": 137, + "name": "Ins3.Finance Coin", + "symbol": "ITF", + "decimals": 18, + "address": "0x0921FE2ad25266df4C078C051f7AD1c2298E89FC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa329e8944426b32c16b33d754149fe524a32b348" + } + }, + { + "chainId": 137, + "name": "OT Compound Dai 29DEC2022", + "symbol": "OT-cDAI-29DEC2022", + "decimals": 8, + "address": "0x1997FC07b67E7962cddD6E4db84E3C7315Bf4EB0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3d4e7f52efafb9e0c70179b688fc3965a75bcfea" + } + }, + { + "chainId": 137, + "name": "OT Aave interest bearing USDC 29DEC2022", + "symbol": "OT-aUSDC-29DEC2022", + "decimals": 6, + "address": "0x778Ba5C85c48C695228aF7e4CE3e8Ea96A50870c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8fcb1783bf4b71a51f702af0c266729c4592204a" + } + }, + { + "chainId": 137, + "name": "Valencoin", + "symbol": "VALOU", + "decimals": 0, + "address": "0xb91c05cf30A973a58295C8Db9248D0911CF091E5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb91c05cf30A973a58295C8Db9248D0911CF091E5" + } + }, + { + "chainId": 137, + "name": "VIQYY", + "symbol": "VIQYY", + "decimals": 18, + "address": "0xa0715b961daabafCb7a8A2Bc1146541a21aa56C1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8756c7f30a3b33f6412adeda21f627c93e599c14" + } + }, + { + "chainId": 137, + "name": "GIX Coin", + "symbol": "GIX", + "decimals": 18, + "address": "0xf4426F20E0956e91B75217A0F6B0e747213DaC75", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbd434a09191d401da3283a5545bb3515d033b8c4" + } + }, + { + "chainId": 137, + "name": "TradeStars TSX", + "symbol": "TSX", + "decimals": 18, + "address": "0xF11de26883EB2EBF9877a01703DDC1eB619094E6", + "tags": [ + "pos", + "erc20", + "noDeposit" + ], + "extensions": { + "rootAddress": "0x734c90044a0ba31b3f2e640c10dc5d3540499bfd" + } + }, + { + "chainId": 137, + "name": "Peri Finance Token", + "symbol": "PERI", + "decimals": 18, + "address": "0xDC0E17eAE3B9651875030244b971fa0223a1764f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5d30aD9C6374Bf925D0A75454fa327AACf778492" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/peri.svg" + }, + { + "chainId": 137, + "name": "Singularity Dao", + "symbol": "SDAO", + "decimals": 18, + "address": "0x59e991B37b35Ac2187113dFdB5D60D2e887eEec1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x993864e43caa7f7f12953ad6feb1d1ca635b875f" + } + }, + { + "chainId": 137, + "name": "Shibies Treats", + "symbol": "TREATS", + "decimals": 18, + "address": "0x21364671fD823BBda8Ba1f40a24171DeCBdB3D54", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0B5Afdc93A86062A49063EA96AE944D7F966B6AE" + } + }, + { + "chainId": 137, + "name": "Aegis", + "symbol": "aDAO", + "decimals": 18, + "address": "0x76D431cCC4A1696996C4F282284e8998f7315eD8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x926dbd499d701c61eabe2d576e770eccf9c7f4f3" + } + }, + { + "chainId": 137, + "name": "Fear NFTs", + "symbol": "FEAR", + "decimals": 18, + "address": "0xa2CA40DBe72028D3Ac78B5250a8CB8c404e7Fb8C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x88a9a52f944315d5b4e917b9689e65445c401e83" + } + }, + { + "chainId": 137, + "name": "Love", + "symbol": "LOVE", + "decimals": 18, + "address": "0x69bdE563680f580A2da5b5d4E202ecA4FDF35664", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x12E57F85b847baDE37F37cdE3442f00Dc33b9982" + } + }, + { + "chainId": 137, + "name": "Attrace", + "symbol": "ATTR", + "decimals": 18, + "address": "0x0335DeFC8A1977b99488e0b5f5c6bc3D44fAcdD4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x44e2dec86b9f0e0266e9aa66e10323a2bd69cf9a" + } + }, + { + "chainId": 137, + "name": "ZEUZ", + "symbol": "ZEUZ", + "decimals": 18, + "address": "0x2f3CcE940815daacE6d8f773A1a4f8c6Cb22AE00", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xFf729170f0C793cc1a28Ea3c30d88c219743D0a6" + } + }, + { + "chainId": 137, + "name": "Radicle", + "symbol": "RAD", + "decimals": 18, + "address": "0x2f81e176471CC57fDC76f7d332FB4511bF2bebDD", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x31c8eacbffdd875c74b94b077895bd78cf1e64a3" + } + }, + { + "chainId": 137, + "name": "Cfoforum Token", + "symbol": "CFO", + "decimals": 6, + "address": "0x0E2a70C08e884eA76116fccdC8b8be559162f08e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xB8981aCbBF7DA95A8fF6Df79Aab935cE63434fC8" + } + }, + { + "chainId": 137, + "name": "USDT-LP", + "symbol": "USDT-LP", + "decimals": 18, + "address": "0xA15a8e5743D15ba1B2fD857C4E1937Dbf1727bd6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe0437BeB5bb7Cf980e90983f6029033d710bd1da" + } + }, + { + "chainId": 137, + "name": "BabyFloki", + "symbol": "BabyFloki", + "decimals": 9, + "address": "0x892fC8D2b2d6252cDd91Ed29AE08d89C03c5E0b2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdf35988d795d90711e785b488bb2127692e6f956" + } + }, + { + "chainId": 137, + "name": "WaifuToken", + "symbol": "WAIFU", + "decimals": 18, + "address": "0x690e822b6f26AC835432b05908A8c0D7C9DB76e9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x50d812bd2728e1bd7c7f57d97819e0bdc486d6ff" + } + }, + { + "chainId": 137, + "name": "Kilroy", + "symbol": "KROY", + "decimals": 18, + "address": "0x8454498Ce328D7D3FC35B743301f52De67eB9Fdc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa85784108dbdcf8fe6564c7657a24c4765a2413f" + } + }, + { + "chainId": 137, + "name": "Bella", + "symbol": "BEL", + "decimals": 18, + "address": "0x28C388FB1F4fa9F9eB445f0579666849EE5eeb42", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa91ac63d040deb1b7a5e4d4134ad23eb0ba07e14" + } + }, + { + "chainId": 137, + "name": "Ripio Credit Network Token", + "symbol": "RCN", + "decimals": 18, + "address": "0x89C296Be2F904F3e99a6125815b4B78F5388d2dd", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF970b8E36e23F7fC3FD752EeA86f8Be8D83375A6" + } + }, + { + "chainId": 137, + "name": "MIMO Parallel Governance Token", + "symbol": "MIMO", + "decimals": 18, + "address": "0xADAC33f543267c4D59a8c299cF804c303BC3e4aC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x90b831fa3bebf58e9744a14d638e25b4ee06f9bc" + } + }, + { + "chainId": 137, + "name": "INDI CORPS", + "symbol": "INDI", + "decimals": 18, + "address": "0x883Ec81B5dBCb9bcEAFe0c101893487c88B167bF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd9276198cf1b9261a25f61f0ff28eee2fb36dd5a" + } + }, + { + "chainId": 137, + "name": "PantherSwap Token", + "symbol": "PANTHER", + "decimals": 18, + "address": "0xC7BDAbDe06cd7a873D8f3db47c42AB6146403b05", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9C972AF892F91B06455b4aB3c4359DE51DE36B9C" + } + }, + { + "chainId": 137, + "name": "GateChainToken", + "symbol": "GT", + "decimals": 18, + "address": "0x8da74b5450576998a5Bc499cb80AE3FE66eBb023", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xE66747a101bFF2dBA3697199DCcE5b743b454759" + } + }, + { + "chainId": 137, + "name": "Hokkaidu Inu", + "symbol": "HOKK", + "decimals": 9, + "address": "0x5B4d05223A14AEB6160f8400DcBbdD0A84aF60f7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc40af1e4fecfa05ce6bab79dcd8b373d2e436c4e" + } + }, + { + "chainId": 137, + "name": "Tesla Inu", + "symbol": "TESINU", + "decimals": 9, + "address": "0xD68468a1c2255FF4b13279752D68b5915Bd84860", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xff69e48af1174da7f15d0c771861c33d3f19ed8a" + } + }, + { + "chainId": 137, + "name": "Dogecaps", + "symbol": "dcaps", + "decimals": 9, + "address": "0x08912AA55D5eb104107c929cD4F48840D287613E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0bafa383ea3726982fcf0507f63c9c3d02f28eec" + } + }, + { + "chainId": 137, + "name": "uBitcoin", + "symbol": "uBTC", + "decimals": 18, + "address": "0x7DF29b5e0F2c7895F4B4FA4a20E759F8AbC1ba91", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x49766c22dcbc885f993ffeae547a79b5508aa9ec" + } + }, + { + "chainId": 137, + "name": "Bailey Building & Loans", + "symbol": "BBL", + "decimals": 18, + "address": "0xE6a823862eE153168C772Cf494e9DfF77140C696", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8abcEbDa80cE8C1fCF0105EF8d5d7fC5b26b0Cd0" + } + }, + { + "chainId": 137, + "name": "EmiSwap - EmiDao Token", + "symbol": "ESW", + "decimals": 18, + "address": "0xd2A2a353D28e4833FAFfC882f6649c9c884a7D8f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5a75A093747b72a0e14056352751eDF03518031d" + } + }, + { + "chainId": 137, + "name": "Mask Network", + "symbol": "MASK", + "decimals": 18, + "address": "0x2B9E7ccDF0F4e5B24757c1E1a80e311E34Cb10c7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x69af81e73a73b40adf4f3d4223cd9b1ece623074" + } + }, + { + "chainId": 137, + "name": "Phoenix Token", + "symbol": "PHX", + "decimals": 18, + "address": "0x9C6BfEdc14b5C23E3900889436Edca7805170f01", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xAeC65404DdC3af3C897AD89571d5772C1A695F22" + } + }, + { + "chainId": 137, + "name": "Charged Particles - IONX", + "symbol": "IONX", + "decimals": 18, + "address": "0x01b317bC5eD573FAa112eF64DD029F407CecB155", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x02d3a27ac3f55d5d91fb0f52759842696a864217" + } + }, + { + "chainId": 137, + "name": "RUNCOIN", + "symbol": "RUN", + "decimals": 18, + "address": "0x648A372552725EE4ABFC8E8F3006d80124D63B44", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x66eb3d45949f161d4f0bc6eb1e1678e6ff0a0ca1" + } + }, + { + "chainId": 137, + "name": "1PLANET Carbon Credit", + "symbol": "1PLCO2", + "decimals": 18, + "address": "0x14B5eD5dc05e9F7d35104D035719BD65a7EE93E0", + "logoURI": "https://1planet.app/images/1PL_Token_Logo.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2E8891AA76743ee96547AcB764a69b87872423f8" + } + }, + { + "chainId": 137, + "name": "Tokenart", + "symbol": "OKNA", + "decimals": 18, + "address": "0xf00eCE8EDF75Db1aD4c8640EA44537fCCDF6E7a4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6FD6171442ae34bA5C9CE2bb9b1E0CF543c4F6f1" + } + }, + { + "chainId": 137, + "name": "Synth sUSD", + "symbol": "sUSD", + "decimals": 18, + "address": "0xF81b4Bec6Ca8f9fe7bE01CA734F55B2b6e03A7a0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x57Ab1ec28D129707052df4dF418D58a2D46d5f51" + } + }, + { + "chainId": 137, + "name": "HK Monetary Token", + "symbol": "HKMT", + "decimals": 6, + "address": "0xE368e30C2b0F58EF216e12073141E07a875fbA6d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc8c97d9B0aF219c2329a0179f6AB8C7a55B39fc1" + } + }, + { + "chainId": 137, + "name": "IBIZA Token", + "symbol": "IBZ", + "decimals": 18, + "address": "0x428aC1de3FC08c0F3A47745C964f7d677716981F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5aa7c403c7de4b3bb0cc07079a03e389671a4771" + } + }, + { + "chainId": 137, + "name": "Aurox Token", + "symbol": "URUS", + "decimals": 18, + "address": "0xa3E6ac447c6A65e738AdBdA36034b54E2bC9603b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6c5fbc90e4d78f70cc5025db005b39b03914fc0c" + } + }, + { + "chainId": 137, + "name": "Siberian Husky", + "symbol": "SHUSKY", + "decimals": 9, + "address": "0x941f59F9577451530EE38287e5F146bd42cda258", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x236d53148f83706c3d670064809577385f923a75" + } + }, + { + "chainId": 137, + "name": "ShibaCoin", + "symbol": "SHIBA", + "decimals": 18, + "address": "0x141b8B6834fB2D24F9205AD262326DbC699Defa4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x321bd6fa7696e0e4ba082e454b6e87b6c8372b27" + } + }, + { + "chainId": 137, + "name": "Moon Pug", + "symbol": "MOONPUG", + "decimals": 9, + "address": "0x14f2aF758c62Aa1dE8c9e48e1DE363826b087453", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x856710ea0007af7bdc387fe54f64db51dddaf0a2" + } + }, + { + "chainId": 137, + "name": "Golden Pineapple 🍍🪙🍍🪙🍍🪙", + "symbol": "GOLDENPINE", + "decimals": 18, + "address": "0x95894e4286bf4618eDd3824dD5b38a082a431953", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe6f7466cb27d3072cf9dda358596b1a165cf5ce1" + } + }, + { + "chainId": 137, + "name": "Shiva 🌼🌼🌼🌼🌼🌼🌼🌼🌼🌼🌼", + "symbol": "SHIVA", + "decimals": 18, + "address": "0x137E8f56BB8B4DA5720E912DB15D45b01ac3C3ad", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x002f46770160ffb092bc15699fb035526b0b65d7" + } + }, + { + "chainId": 137, + "name": "brotDAO", + "symbol": "BROT", + "decimals": 18, + "address": "0xCEb082Ab7c63d68476797223a84f49e0284e9B29", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc6287874391410C77E3fD73748C735f9381b8859" + } + }, + { + "chainId": 137, + "name": "TRASH", + "symbol": "TRSH", + "decimals": 18, + "address": "0xa73eACB2955fF636F8FE16F6BE35FC11D8D61f9E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0f46eba0Bafe2739d9F3C43A48BB84BEE1f6644f" + } + }, + { + "chainId": 137, + "name": "The SporkDAO Token", + "symbol": "SPORK", + "decimals": 18, + "address": "0x9CA6a77C8B38159fd2dA9Bd25bc3E259C33F5E39", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb624FdE1a972B1C89eC1dAD691442d5E8E891469" + } + }, + { + "chainId": 137, + "name": "UMA Voting Token v1", + "symbol": "UMA", + "decimals": 18, + "address": "0x3066818837c5e6eD6601bd5a91B0762877A6B731", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x04Fa0d235C4abf4BcF4787aF4CF447DE572eF828" + } + }, + { + "chainId": 137, + "name": "CULTURE", + "symbol": "CULTURE", + "decimals": 18, + "address": "0x98F39821b479eb32F0659734a3CA0BB717A4dD4a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEeA1dd32b4c4DfD16D200AC2cb286b28F7402728" + } + }, + { + "chainId": 137, + "name": "American Akita", + "symbol": "USKITA", + "decimals": 9, + "address": "0xe7eA6564f85CC4F98D8B20a6888B877b3362D6ab", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc18e7a03f8986798323658dd8645f93aa79ac5c9" + } + }, + { + "chainId": 137, + "name": "Fat Doge", + "symbol": "FOGE", + "decimals": 9, + "address": "0x20583A26a27a81C0c5387521A6FF443E6806Be75", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x76851a93977bea9264c32255b6457882035c7501" + } + }, + { + "chainId": 137, + "name": "TREKS", + "symbol": "TREKS", + "decimals": 18, + "address": "0xa65d74f1f047596b2DaFedFdfA327Ccbd499Aa9e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x15492208Ef531EE413BD24f609846489a082F74C" + } + }, + { + "chainId": 137, + "name": "CC Token", + "symbol": "CC", + "decimals": 18, + "address": "0xb3fb97019e9F69d0fD2e76fBD113ec6960a5389a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd6860c96b5e1452811573b499d0c6aeddada4f23" + } + }, + { + "chainId": 137, + "name": "xFORCE", + "symbol": "xFORCE", + "decimals": 18, + "address": "0x27Ca65acd4397a6Ade56ac2a5d63587c14a46F0f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe7f445b93eb9cdabfe76541cc43ff8de930a58e6" + } + }, + { + "chainId": 137, + "name": "Jomon Shiba", + "symbol": "JSHIBA", + "decimals": 9, + "address": "0x0F44C5CD9cF957Ce0C7dEa558A765e81E8378b37", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1426cc6d52d1b14e2b3b1cb04d57ea42b39c4c7c" + } + }, + { + "chainId": 137, + "name": "Free Coin", + "symbol": "FREE", + "decimals": 18, + "address": "0x7cef6ed1e07079e174601d39066AD0856cB47988", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2f141ce366a2462f02cea3d12cf93e4dca49e4fd" + } + }, + { + "chainId": 137, + "name": "Based Loans Ownership", + "symbol": "BLO", + "decimals": 18, + "address": "0x9737399FaB00754FDc8BEe48FCB0697CE85C7DE5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x68481f2c02be3786987ac2bc3327171c5d05f9bd" + } + }, + { + "chainId": 137, + "name": "PIKA TOKEN", + "symbol": "PKAT", + "decimals": 18, + "address": "0xB45d03F97357F7c5018c0235830aB802E29dBD0d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5622fc0bd7ef3f07b2d1b05097dff6f50cc0b2f5" + } + }, + { + "chainId": 137, + "name": "Myōbu", + "symbol": "MYOBU", + "decimals": 9, + "address": "0x2efd9Dab50cF55C8A9FDB7a24dD2034dcaA1Ec29", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x75d12e4f91df721fafcae4c6cd1d5280381370ac" + } + }, + { + "chainId": 137, + "name": "Raze Network", + "symbol": "RAZE", + "decimals": 18, + "address": "0xA947239ADC5D53Aa03E5f661a2e16d7B009fC5A6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5Eaa69B29f99C84Fe5dE8200340b4e9b4Ab38EaC" + } + }, + { + "chainId": 137, + "name": "The Tokenized Bitcoin", + "symbol": "imBTC", + "decimals": 8, + "address": "0x897f86e22A5F5782c439118D68338f4FC420E59C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3212b29E33587A00FB1C83346f5dBFA69A458923" + } + }, + { + "chainId": 137, + "name": "MahaDAO", + "symbol": "MAHA", + "decimals": 18, + "address": "0xeDd6cA8A4202d4a36611e2fff109648c4863ae19", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb4d930279552397bba2ee473229f89ec245bc365" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/maha.svg" + }, + { + "chainId": 137, + "name": "Yieldly", + "symbol": "YLDY", + "decimals": 18, + "address": "0x07280d3143311b012ad268a74F2aa791713952eA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x88cb253d4c8cab8cdf7948a9251db85a13669e23" + } + }, + { + "chainId": 137, + "name": "Roseon token", + "symbol": "ROSN", + "decimals": 18, + "address": "0x1B2a3C1417C69DA16bb9193268d0AAbFe54b3b39", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x651cd665bd558175a956fb3d72206ea08eb3df5b" + } + }, + { + "chainId": 137, + "name": "CryptoChefs AROMA Token", + "symbol": "AROMA", + "decimals": 18, + "address": "0x444DBcb15Ea0d706C04DaB615374a11759E07A25", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x444DBcb15Ea0d706C04DaB615374a11759E07A25" + } + }, + { + "chainId": 137, + "name": "Conceal - Wrapped CCX ", + "symbol": "wCCX", + "decimals": 6, + "address": "0xeB9069218E171C62CEfAACa1581efEa3e9D57a31", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x21686f8ce003a95c99acd297e302faacf742f7d4" + } + }, + { + "chainId": 137, + "name": "UCASH", + "symbol": "UCASH", + "decimals": 8, + "address": "0xA94880d3A4b39746E90Cdb57f8De3732c984DE14", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x92e52a1a235d9a103d970901066ce910aacefd37" + } + }, + { + "chainId": 137, + "name": "SpiderDAO Token", + "symbol": "SPDR", + "decimals": 18, + "address": "0x916dC64C5BCa5DA97A354bBD3998771A26545E09", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbcd4b7de6fde81025f74426d43165a5b0d790fdd" + } + }, + { + "chainId": 137, + "name": "BIRB", + "symbol": "BRB", + "decimals": 8, + "address": "0xB5CEdF3a2aD0aad7cf43F6cF4Cb9FBE01130d684", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x216d7636b791Ed93BFD56BF696b35A14115416ab" + } + }, + { + "chainId": 137, + "name": "Bluzelle Token", + "symbol": "BLZ", + "decimals": 18, + "address": "0x438B28C5AA5F00a817b7Def7cE2Fb3d5d1970974", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5732046a883704404f284ce41ffadd5b007fd668" + } + }, + { + "chainId": 137, + "name": "Aluna", + "symbol": "ALN", + "decimals": 18, + "address": "0xa8fcEe762642f156b5D757b6FabC36E06b6d4A1A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8185bc4757572da2a610f887561c32298f1a5748" + } + }, + { + "chainId": 137, + "name": "The Force Token", + "symbol": "FOR", + "decimals": 18, + "address": "0x546b4c391520E6652897c65153074088BFC0A909", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1FCdcE58959f536621d76f5b7FfB955baa5A672F" + } + }, + { + "chainId": 137, + "name": "Deri", + "symbol": "DERI", + "decimals": 18, + "address": "0x3D1D2aFd191b165D140e3E8329E634665fFB0E5e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA487bF43cF3b10dffc97A9A744cbB7036965d3b9" + } + }, + { + "chainId": 137, + "name": "Gnarcoin", + "symbol": "GNAR", + "decimals": 18, + "address": "0x8dfe9e53F920D43C2D59133804Aff6540B4e05fF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x017429367d6e4f9fa7b673bdb2247887bd9233e8" + } + }, + { + "chainId": 137, + "name": "Geyser", + "symbol": "GYSR", + "decimals": 18, + "address": "0xc48F61a288A08F1B80c2edd74652e1276B6A168c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbea98c05eeae2f3bc8c3565db7551eb738c8ccab" + } + }, + { + "chainId": 137, + "name": "Newscrypto", + "symbol": "NWC", + "decimals": 18, + "address": "0x968F6f898a6Df937fC1859b323aC2F14643e3fED", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x968f6f898a6df937fc1859b323ac2f14643e3fed" + } + }, + { + "chainId": 137, + "name": "PairX Token", + "symbol": "PAIRX", + "decimals": 18, + "address": "0x7a51028299AE19B4C56BF8d66B42Fd53e42F43aB", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7a51028299AE19B4C56BF8d66B42Fd53e42F43aB" + } + }, + { + "chainId": 137, + "name": "X-Cash", + "symbol": "XCASH", + "decimals": 18, + "address": "0x03678f2c2c762DC63c2Bb738c3a837D366eDa560", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x235328f864f38a91f0d2282159ea7c7b7c9f7c62" + } + }, + { + "chainId": 137, + "name": "Oiler", + "symbol": "OIL", + "decimals": 18, + "address": "0x65DfA90171e1bd9060209405026C4E1f4A8E58df", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0275E1001e293C46CFe158B3702AADe0B99f88a5" + } + }, + { + "chainId": 137, + "name": "ReillyCoin", + "symbol": "REILLY", + "decimals": 18, + "address": "0x0a6cb35d3C309578aB3AE19c06Af9a77A045F18b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x12D0545F7f74a17C84432e9552D8E4eb62b59DCD" + } + }, + { + "chainId": 137, + "name": "Dollar", + "symbol": "DOLLAR", + "decimals": 18, + "address": "0x432167928d23C378B316B78Dfa378Baa4a84F25a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe0ea460dc00d4cc62f539550d8dc9861dfd460fd" + } + }, + { + "chainId": 137, + "name": "penny", + "symbol": "PENNY", + "decimals": 18, + "address": "0x61FE6d0Ee83A5614822bE14599Ee99c621190a60", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x53bfb267aae3ca9d41febe271b7b8ea5dcffacfa" + } + }, + { + "chainId": 137, + "name": "super veggie burrito", + "symbol": "SVB", + "decimals": 18, + "address": "0xA5f7EA46EBDC3F192c19e900012B3c4a2D6E11a0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa2dddf1755603e209392dd987a1eb8689277b2c6" + } + }, + { + "chainId": 137, + "name": "funkyninja *❄✲❄* spacerobots", + "symbol": "SPACEFUNK", + "decimals": 18, + "address": "0x9656cfbbdDc777f15341F4bd1733f5eEC6B5Feb4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc3dff9e16f76d15beaa0959af135a06df78ac0e1" + } + }, + { + "chainId": 137, + "name": "baby love", + "symbol": "BABY", + "decimals": 18, + "address": "0x7717f1EFA5E36205527A2374603004968aBb480a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x39Ffb0C8Ff3DEa288D3056b43f9fBedBBe996B86" + } + }, + { + "chainId": 137, + "name": "friends", + "symbol": "FRIENDS", + "decimals": 18, + "address": "0xb4cA879d4AC2eee3ae0f42488106f2b242cD0462", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x57E15f54E11D28a5c42f1a0376F2E6c05adBe930" + } + }, + { + "chainId": 137, + "name": "Magic Internet Money", + "symbol": "MIM", + "decimals": 18, + "address": "0x01288e04435bFcd4718FF203D6eD18146C17Cd4b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x99D8a9C45b2ecA8864373A26D1459e3Dff1e17F3" + } + }, + { + "chainId": 137, + "name": "The Employment Commons Work Token", + "symbol": "WORK", + "decimals": 18, + "address": "0x6002410dDA2Fb88b4D0dc3c1D562F7761191eA80", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1482295Df16e7761d128B9823B61785D43CA038B" + } + }, + { + "chainId": 137, + "name": "Lunar Token", + "symbol": "LUNAR", + "decimals": 18, + "address": "0xbDe7EEF06Fa6Cb25883268207eed61b29C9B9fC6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5Ef874AB47aBbd72A6502ec17a1e3d046f5D5739" + } + }, + { + "chainId": 137, + "name": "UNIFARM Token", + "symbol": "UFARM", + "decimals": 18, + "address": "0xA7305Ae84519fF8Be02484CdA45834C4E7D13Dd6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x40986a85b4cfcdb054a6cbfb1210194fee51af88" + } + }, + { + "chainId": 137, + "name": "Gaimin Token", + "symbol": "GMRX", + "decimals": 18, + "address": "0x73F56124a34E0214067B7e5F42A132b3eA072014", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfbb21d217e23a73aa8c1c7d39e43a6971d35e0e2" + } + }, + { + "chainId": 137, + "name": "ramen.bet", + "symbol": "RMN", + "decimals": 18, + "address": "0x77777FDFaac9FAbCdb0851EF574b84C2B7777777", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x77777FDFaac9FAbCdb0851EF574b84C2B7777777" + } + }, + { + "chainId": 137, + "name": "HyperDaonew", + "symbol": "HADO", + "decimals": 18, + "address": "0x0d202214527E82231867CC045308C1C1Ee7A1056", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x78f7126d488E7A1F0f1b47aEA1384A9BbFE93D59" + } + }, + { + "chainId": 137, + "name": "Delta Exchange Token", + "symbol": "DETO", + "decimals": 18, + "address": "0xb6dd51D3852A174D4Dbe045e77DF2ED84942ae6f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xab93df617f51e1e415b5b4f8111f122d6b48e55c" + } + }, + { + "chainId": 137, + "name": "SupremeX Token", + "symbol": "SXC", + "decimals": 18, + "address": "0x46d3EC8CE3eC767414F16FE12176De23E3E5B46A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x01B0086a5bBB25FE081629C232950c7aff660E2d" + } + }, + { + "chainId": 137, + "name": "Agave", + "symbol": "AGVE", + "decimals": 18, + "address": "0x75EB9Fd8608E2ff9418821062398E4F4B8d53644", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0b006e475620af076915257c6a9e40635abdbbad" + } + }, + { + "chainId": 137, + "name": "CAD Coin", + "symbol": "CADC", + "decimals": 18, + "address": "0x5d146d8B1dACb1EBBA5cb005ae1059DA8a1FbF57", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcadc0acd4b445166f12d2c07eac6e2544fbe2eef" + } + }, + { + "chainId": 137, + "name": "XSGD", + "symbol": "XSGD", + "decimals": 6, + "address": "0x769434dcA303597C8fc4997Bf3DAB233e961Eda2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x70e8de73ce538da2beed35d14187f6959a8eca96" + } + }, + { + "chainId": 137, + "name": "Cream", + "symbol": "CREAM", + "decimals": 18, + "address": "0x04f3C4cF2e806da6DF31e80E8A5D121F98eDD61d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2ba592F78dB6436527729929AAf6c908497cB200" + } + }, + { + "chainId": 137, + "name": "Wrapped Ribbits", + "symbol": "wRBT", + "decimals": 18, + "address": "0xA5d447757daC8C5FaAB1858B13DA4aF701aDf4bb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaAF49D386bd44E31fF22EDF723F40EE3e4dA53cd" + } + }, + { + "chainId": 137, + "name": "Minty Art", + "symbol": "MINTY", + "decimals": 18, + "address": "0x474Ba20088174612427cf8440ac5712e98652AD2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb6c6920327b33f8eec26786c7462c5f4098d47e3" + } + }, + { + "chainId": 137, + "name": "Wrapped Leviathan", + "symbol": "WLEV", + "decimals": 18, + "address": "0xEB7f7955730A7DBA1427A6567950eb4a98DfCbdF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa2482ccff8432ee68b9a26a30fcdd2782bd81bed" + } + }, + { + "chainId": 137, + "name": "HuobiToken", + "symbol": "HT", + "decimals": 18, + "address": "0xFAD65Eb62a97fF5Ed91B23aFD039956aaCa6e93b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6f259637dcd74c767781e37bc6133cd6a68aa161" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ht.svg" + }, + { + "chainId": 137, + "name": "extraDNA", + "symbol": "xDNA", + "decimals": 18, + "address": "0x0378566d2979AdCfB80316b2491757C99a44ED45", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8e57c27761EBBd381b0f9d09Bb92CeB51a358AbB" + } + }, + { + "chainId": 137, + "name": "BaoBoShiCoin", + "symbol": "BBSC", + "decimals": 18, + "address": "0xE2aFF5409F0a5d66879f6905dFc832cbdb59919F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf89ba2862dfae69bc2546568d56b087d7454c9c9" + } + }, + { + "chainId": 137, + "name": "HUSD", + "symbol": "HUSD", + "decimals": 8, + "address": "0x2088C47Fc0c78356c622F79dBa4CbE1cCfA84A91", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdf574c24545e5ffecb9a659c229253d4111d87e1" + } + }, + { + "chainId": 137, + "name": "infinite peace protocol", + "symbol": "----------", + "decimals": 18, + "address": "0xC95F5D57C482a9eE5bEd594e065ac0A2A81aAF6C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbe74D4CA0441fB8C6c8B3122d24BDFEcA1622D63" + } + }, + { + "chainId": 137, + "name": "pizza", + "symbol": "PIZZA", + "decimals": 18, + "address": "0x541f3deD0B7b6Dcd5ac1F44ad2f2fD99ba8E667d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x183fb2d55120d75af601fb714f2fadda61fed49e" + } + }, + { + "chainId": 137, + "name": "UBX", + "symbol": "UBX", + "decimals": 0, + "address": "0xae64D44AA6bd7536005E663c48197d9631D4b3eB", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf5b5efc906513b4344ebabcf47a04901f99f09f3" + } + }, + { + "chainId": 137, + "name": "Zum Token", + "symbol": "ZUM", + "decimals": 8, + "address": "0x0191297c4Bf40B31031152c06FE804ba5af5fEc1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe0b9bcd54bf8a730ea5d3f1ffce0885e911a502c" + } + }, + { + "chainId": 137, + "name": "EthereumPay", + "symbol": "EPAY", + "decimals": 18, + "address": "0xef8480105b325D4bB7df87fC9a665Cf9bFC3807b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2b5ca2f9510cf1e3595ff219f24d75d4244585ea" + } + }, + { + "chainId": 137, + "name": "FEGtoken", + "symbol": "FEG", + "decimals": 9, + "address": "0xF391F574C63d9b8764B7a1F56D6383762E07B75B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x389999216860ab8e0175387a0c90e5c52522c945" + } + }, + { + "chainId": 137, + "name": "New Guinea Singing Dog Inu", + "symbol": "NEWINU", + "decimals": 9, + "address": "0x7C254df221993A8a2E703c3351c528f05E329595", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1997830b5beb723f5089bb8fc38766d419a0444d" + } + }, + { + "chainId": 137, + "name": "Instadapp", + "symbol": "INST", + "decimals": 18, + "address": "0xf50D05A1402d0adAfA880D36050736f9f6ee7dee", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6f40d4A6237C257fff2dB00FA0510DeEECd303eb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/inst.svg" + }, + { + "chainId": 137, + "name": "Trace Network", + "symbol": "TRACE", + "decimals": 18, + "address": "0x4287F07CBE6954f9F0DecD91d0705C926d8d03A4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9F7fC686CfD64aA5Ae15b351d03071e91533094b" + } + }, + { + "chainId": 137, + "name": "DeSpace Protocol", + "symbol": "DES", + "decimals": 18, + "address": "0x4837C6AdB831cC3C0a5b3992bd8aE16549c9B672", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x634239cfA331Df0291653139d1a6083B9cf705e3" + } + }, + { + "chainId": 137, + "name": "Fight Token", + "symbol": "FIGHT", + "decimals": 18, + "address": "0x656010c92127623AD59991b392F9b9CF1D5B4C7a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2ba55a162a86c005b900c9cc63be0336e2bb8305" + } + }, + { + "chainId": 137, + "name": "ramen.bet Trial", + "symbol": "RMNT", + "decimals": 18, + "address": "0x77777777740Ccbda196b7d0b83dBFD6c00bad7e4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x77777777740ccbda196b7d0b83dbfd6c00bad7e4" + } + }, + { + "chainId": 137, + "name": "MarginSwap", + "symbol": "MFI", + "decimals": 18, + "address": "0x7Bc429a2fA7d71C4693424FDcaB5a2521b9FD343", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaa4e3edb11afa93c41db59842b29de64b72e355b" + } + }, + { + "chainId": 137, + "name": "DoggittyDoGG", + "symbol": "DOGG", + "decimals": 18, + "address": "0x652879Fc10c16B56A00568879A91dddABf45B211", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8230A4634fafd27764833e19FB618E3396749C18" + } + }, + { + "chainId": 137, + "name": "DeFiPIE Token", + "symbol": "PIE", + "decimals": 18, + "address": "0x5E12f36bF1739A3A740D5916A8b22B0F5275F717", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x607c794cda77efb21f8848b7910ecf27451ae842" + } + }, + { + "chainId": 137, + "name": "YGGDRASH", + "symbol": "YEED", + "decimals": 18, + "address": "0x45A5dF3109fa4723c745Cea20548A66796870f01", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xca2796f9f61dc7b238aab043971e49c6164df375" + } + }, + { + "chainId": 137, + "name": "Ethereum Meta", + "symbol": "ETHM", + "decimals": 18, + "address": "0xbE624349C80576f6b5714BFb6DF0b5Be526719f6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfd957f21bd95e723645c07c48a2d8acb8ffb3794" + } + }, + { + "chainId": 137, + "name": "Centralex Token", + "symbol": "CenX", + "decimals": 18, + "address": "0x7c922aa6820b206C938D92522Bb2D5Ba1bc4dc17", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x504cde95dbc5d90d09b802f43b371971adbecf79" + } + }, + { + "chainId": 137, + "name": "Milf Token", + "symbol": "MILF", + "decimals": 18, + "address": "0xDC3b7CB4FEC9542CC518161b8C0B9a7969302C5E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0Dd1989e4B0E82f154b729FF47F8c9a4f4b2cC1C" + } + }, + { + "chainId": 137, + "name": "Nocturne", + "symbol": "XNOCT", + "decimals": 18, + "address": "0x0a86DB0Ad46C1201aa73D07497A5dBaa5B9Ed2c4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc00a57c49247106dac598912d514fcaee37db213" + } + }, + { + "chainId": 137, + "name": "Coinspaid", + "symbol": "CPD", + "decimals": 18, + "address": "0x1cE4A2C355F0DcC24E32A9Af19F1836D6F4f98ae", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9b31bb425D8263fA1b8B9d090b83CF0C31665355" + } + }, + { + "chainId": 137, + "name": "Cat Token", + "symbol": "CAT", + "decimals": 18, + "address": "0x32EFCa87e441A654B00640D9578DF8Ad28c2Df72", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56015BBE3C01fE05bc30A8a9a9Fd9A88917e7dB3" + } + }, + { + "chainId": 137, + "name": "AGA Carbon Credit", + "symbol": "AGAc", + "decimals": 18, + "address": "0x669ddc70273084Ea30e6cd4f28CA6e2C70735065", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF2032813Aa3c8feEf7973e44A92E68ab11eE8021" + } + }, + { + "chainId": 137, + "name": "EXMOCoin", + "symbol": "EXM", + "decimals": 8, + "address": "0x54371579945270DEB92a9F6f1a4e33bb2A7090c5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x83869de76b9ad8125e22b857f519f001588c0f62" + } + }, + { + "chainId": 137, + "name": "Fusion Token", + "symbol": "FSN", + "decimals": 18, + "address": "0xFA1171334CB3a0f0A91E8cA6765F10e9638D1cBF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd0352a019e9ab9d757776f532377aaebd36fd541" + } + }, + { + "chainId": 137, + "name": "PANDA", + "symbol": "PANDA", + "decimals": 18, + "address": "0xcD7ECB53e78564C09e024bEEac51F611ad92C618", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x73efe5e41f70bdcde2b88bda860c98f996884246" + } + }, + { + "chainId": 137, + "name": "Endor Protocol Token", + "symbol": "EDR", + "decimals": 18, + "address": "0x1Ac417f1dD23504aAC2076D854581f03196403Fd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc528c28fec0a90c083328bc45f587ee215760a0f" + } + }, + { + "chainId": 137, + "name": "superkittens", + "symbol": "SKITS", + "decimals": 18, + "address": "0x5357De35CF517e6CEcD91B269eA551caEE4D171C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6ad053f0a9BFEC8B2e9f91EbCc07e679977bdA76" + } + }, + { + "chainId": 137, + "name": "Cryption Network Token", + "symbol": "CNT", + "decimals": 18, + "address": "0xD1e6354fb05bF72A8909266203dAb80947dcEccF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x429876c4a6f89fb470e92456b8313879df98b63c" + } + }, + { + "chainId": 137, + "name": "Polymath", + "symbol": "POLY", + "decimals": 18, + "address": "0xcB059C5573646047D6d88dDdb87B745C18161d3b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9992ec3cf6a55b00978cddf2b27bc6882d88d1ec" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/poly.svg" + }, + { + "chainId": 137, + "name": "SafeMoon Inu", + "symbol": "SMI", + "decimals": 8, + "address": "0x196DE3b89083ADcaD83FE49A308de24a96194731", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcd7492db29e2ab436e819b249452ee1bbdf52214" + } + }, + { + "chainId": 137, + "name": "VUSD", + "symbol": "VUSD", + "decimals": 18, + "address": "0x28F4F063C2405922d8792B04fF24983d6eE7a4b4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x677ddbd918637e5f2c79e164d402454de7da8619" + } + }, + { + "chainId": 137, + "name": "BNB", + "symbol": "BNB", + "decimals": 18, + "address": "0x3BA4c387f786bFEE076A58914F5Bd38d668B42c3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xB8c77482e45F1F44dE1745F52C74426C631bDD52" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bnb.svg" + }, + { + "chainId": 137, + "name": "DeFi SISMO", + "symbol": "SISMO", + "decimals": 18, + "address": "0x6681fe034aE21917fac759B087684de5335efD3A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x686dDECeCC39e1Ff33EAdfB4Bfd059A44cC700Ca" + } + }, + { + "chainId": 137, + "name": "Trism", + "symbol": "TRISM", + "decimals": 18, + "address": "0x10Bc8bf16308f63F1b4852b2522F22bfD59d4392", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56b4f8c39e07d4d5d91692acf9d0f6d4d3493763" + } + }, + { + "chainId": 137, + "name": "ALAN", + "symbol": "ALAN", + "decimals": 18, + "address": "0xa6E99049d3DC5fA94292c86E67742d7CD2ebE561", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8c9952fb855346a752190234261f74dad13c26fa" + } + }, + { + "chainId": 137, + "name": "BracebridgeGolfClub", + "symbol": "BGC", + "decimals": 0, + "address": "0xEBd0E6B73a0e0D231DA8C91bdD60c09C9C0875c3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa6dc5e47ed08aa8e642ff07b0a3685f41f9f437b" + } + }, + { + "chainId": 137, + "name": "MoonTools.io", + "symbol": "MOONS", + "decimals": 18, + "address": "0x6F7362AD5656Beb11D94f4e608f2045e2fAD9dC2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x260e63d91fccc499606bae3fe945c4ed1cf56a56" + } + }, + { + "chainId": 137, + "name": "FLAPP", + "symbol": "FLAP", + "decimals": 18, + "address": "0x594F9D6F09a17f9CAF2dC3c8705a487433412f69", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xCfb72ED3647cC8E7FA52E4F121eCdAbEfC305e7f" + } + }, + { + "chainId": 137, + "name": "CBK", + "symbol": "CBK", + "decimals": 18, + "address": "0x53f8036e43b2EF39cFCD0C5f26C1257a85D5A3B2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x87761e886399ef8e1624cb0db3230b075a322c88" + } + }, + { + "chainId": 137, + "name": "Octett", + "symbol": "OCTT", + "decimals": 18, + "address": "0x37B5f741371ABf2207D236B6309d7D2015Bd64e9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x06da6213683a01201b38ee1b39f56090a3cc5703" + } + }, + { + "chainId": 137, + "name": "XY Oracle", + "symbol": "XYO", + "decimals": 18, + "address": "0xd2507e7b5794179380673870d88B22F94da6abe0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x55296f69f40ea6d20e478533c15a6b08b654e758" + } + }, + { + "chainId": 137, + "name": "DegenVC", + "symbol": "DGVC", + "decimals": 18, + "address": "0x55CeBfa4504124272D4D5464479E8878d822a8A1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x26E43759551333e57F073bb0772F50329A957b30" + } + }, + { + "chainId": 137, + "name": "KatanaToken", + "symbol": "KATANA", + "decimals": 18, + "address": "0x90c98Ee97B8bf9A3F8dC402EACc7Bb41028A5D93", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe6410569602124506658ff992f258616ea2d4a3d" + } + }, + { + "chainId": 137, + "name": "Collective", + "symbol": "CO2", + "decimals": 18, + "address": "0xd9b452421913D014EaEd2588ac57E941A1078C18", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x75739d5944534115d7c54ee8c73f186d793bae02" + } + }, + { + "chainId": 137, + "name": "Gitcoin", + "symbol": "GTC", + "decimals": 18, + "address": "0xdb95f9188479575F3F718a245EcA1B3BF74567EC", + "logoURI": "https://user-images.githubusercontent.com/9419140/164305478-c13be380-142e-4fe8-9adf-ac2c09e8f8d8.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xde30da39c46104798bb5aa3fe8b9e0e1f348163f" + } + }, + { + "chainId": 137, + "name": "Orchid", + "symbol": "OXT", + "decimals": 18, + "address": "0x9880e3dDA13c8e7D4804691A45160102d31F6060", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4575f41308EC1483f3d399aa9a2826d74Da13Deb" + } + }, + { + "chainId": 137, + "name": "Options.Market", + "symbol": "OSM", + "decimals": 18, + "address": "0x7392B03A2b8441a108C253f49bDfaCd40853Cc02", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9b75848172677042269c63365b57b0a51c21d031" + } + }, + { + "chainId": 137, + "name": "renBTC", + "symbol": "renBTC", + "decimals": 8, + "address": "0xD6C23852b94FEde6AB571e4b4cFdb745b49Dc9EB", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEB4C2781e4ebA804CE9a9803C67d0893436bB27D" + } + }, + { + "chainId": 137, + "name": "Nftfy Token", + "symbol": "NFTFY", + "decimals": 18, + "address": "0xBf6Ff49FfD3d104302Ef0AB0F10f5a84324c091c", + "logoURI": "https://gateway.ipfs.io/ipfs/QmS3W7dsYiMUqJdPofjetJPoiUTYjicZVjT2kSAiWZwJLh", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xBf6Ff49FfD3d104302Ef0AB0F10f5a84324c091c" + } + }, + { + "chainId": 137, + "name": "EthereumMax", + "symbol": "eMax", + "decimals": 18, + "address": "0x2f3D902baC71430DEdf5307E9041382dF911B1Af", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x15874d65e649880c2614e7a480cb7c9A55787FF6" + } + }, + { + "chainId": 137, + "name": "Foundry Logistics Token", + "symbol": "FRY", + "decimals": 18, + "address": "0x48D3a72230e65380f63a05eE41A7BE31773c44b4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6c972b70c533E2E045F333Ee28b9fFb8D717bE69" + } + }, + { + "chainId": 137, + "name": "Crypto puzzles", + "symbol": "CPTE", + "decimals": 18, + "address": "0x0833E165255E21a9e81f2D4D6bD10C43973c6526", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xE0bDFe2CE51F44556309665D59818CCb541ff067" + } + }, + { + "chainId": 137, + "name": "Assets of Steve Bayer", + "symbol": "XASB", + "decimals": 18, + "address": "0xE898695409ef54080518ECC568C6CE618E7818e1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6c7d4eD524C14C36048F00dc5f9bBA5848314f39" + } + }, + { + "chainId": 137, + "name": "Unifty", + "symbol": "NIF", + "decimals": 18, + "address": "0xB6Be3449C6A4b8AB082733F715788d94e78D60Ff", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7e291890b01e5181f7ecc98d79ffbe12ad23df9e" + } + }, + { + "chainId": 137, + "name": "Panda Token", + "symbol": "PT", + "decimals": 18, + "address": "0xa053517276ae28D46b09dA0023dFCB6E1FC8e13f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd8164b8d21d2e97484de89bfff787d792c95ef2d" + } + }, + { + "chainId": 137, + "name": "Media Licensing Token", + "symbol": "MLT", + "decimals": 18, + "address": "0x078f0cD6ec0BeD408E9244EecE9fAc05bb4052a7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9506d37f70eB4C3d79C398d326C871aBBf10521d" + } + }, + { + "chainId": 137, + "name": "Student Coin", + "symbol": "STC", + "decimals": 18, + "address": "0x779b299eA455D35A44FE9baC48648be22C08DEa2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x15b543e986b8c34074dfc9901136d9355a537e7e" + } + }, + { + "chainId": 137, + "name": "Fetch", + "symbol": "FET", + "decimals": 18, + "address": "0x7583FEDDbceFA813dc18259940F76a02710A8905", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaea46a60368a7bd060eec7df8cba43b7ef41ad85" + } + }, + { + "chainId": 137, + "name": "Uniqly", + "symbol": "UNIQ", + "decimals": 18, + "address": "0xABEb34C52292c5f3EE96396E02D8a77c8A903a4F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3758e00b100876c854636ef8db61988931bb8025" + } + }, + { + "chainId": 137, + "name": "rainbowpuffpuff", + "symbol": "RPP", + "decimals": 18, + "address": "0xea9306Bbe5fEE6D501282b34e9Db2C25415662DD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x22E38592d99102FfdAE1AE79A5bbF42DDf92818F" + } + }, + { + "chainId": 137, + "name": "Pod USD Coin", + "symbol": "pUSDC", + "decimals": 6, + "address": "0x96d161cbf38FACCeD333851A9cEf20936DDA88F4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x386EB78f2eE79AddE8Bdb0a0e27292755ebFea58" + } + }, + { + "chainId": 137, + "name": "Pod Dai Stablecoin", + "symbol": "pDAI", + "decimals": 18, + "address": "0x18C4315847Cf73D5028c8A98EAd16e862450E618", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2f994e2E4F3395649eeE8A89092e63Ca526dA829" + } + }, + { + "chainId": 137, + "name": "HappyPay", + "symbol": "HPAY", + "decimals": 18, + "address": "0xF9774f6D13F96b0b7f8C35E86755E1337eCEbC3C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEeE690AAA67d1eE33365c02C3Bf477A93867052f" + } + }, + { + "chainId": 137, + "name": "Fortune Cat Coin", + "symbol": "FCAT", + "decimals": 18, + "address": "0x0f4044F4475B7eC4bdE170146ad02A9cD3ad4853", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xB1525E3DbB9F70DA3CF6880839dE62D75E3Ce529" + } + }, + { + "chainId": 137, + "name": "eWit", + "symbol": "EWIT", + "decimals": 9, + "address": "0xe19958a47432e839932541859B639A8fB4f11232", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x56EE175FE37CD461486cE3c3166e0CaFCcd9843f" + } + }, + { + "chainId": 137, + "name": "RIOT", + "symbol": "RIOT", + "decimals": 18, + "address": "0x4FF0b68ABc2b9E4e1401E9b691DBa7d66B264AC8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf56408077487cB879c992909C5b5C66D68c02Eb4" + } + }, + { + "chainId": 137, + "name": "EVO", + "symbol": "EVO", + "decimals": 18, + "address": "0x4237302A7db5dfD04d1FfF5Fd93a6F09bdE8F08C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3fEa51dAab1672d3385f6AF02980e1462cA0687b" + } + }, + { + "chainId": 137, + "name": "Marlin POND", + "symbol": "POND", + "decimals": 18, + "address": "0x73580A2416A57f1C4b6391DBA688A9e4f7DBECE0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x57b946008913b82e4df85f501cbaed910e58d26c" + } + }, + { + "chainId": 137, + "name": "kittenMATIC", + "symbol": "kiMATIC", + "decimals": 18, + "address": "0xaba7d7454175D549a21a6318831fde7f5046C303", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4313D2669b73987433C82aA8Df318a39DA9e3209" + } + }, + { + "chainId": 137, + "name": "BlackPool Token", + "symbol": "BPT", + "decimals": 18, + "address": "0x6863BD30C9e313B264657B107352bA246F8Af8e0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0eC9F76202a7061eB9b3a7D6B59D36215A7e37da" + } + }, + { + "chainId": 137, + "name": "BCLTjack", + "symbol": "jack", + "decimals": 0, + "address": "0x11CC08D7831F50a1359ff5f30E4cB7d309272E48", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x074bF09d5859AA9DBA6c8f093255d7c01c3e7baD" + } + }, + { + "chainId": 137, + "name": "Mute.io", + "symbol": "MUTE", + "decimals": 18, + "address": "0x147Ee2488d2ede60b2443B22b245F6B4825F020f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa49d7499271ae71cd8ab9ac515e6694c755d400c" + } + }, + { + "chainId": 137, + "name": "bZx Protocol Token", + "symbol": "BZRX", + "decimals": 18, + "address": "0x54cFe73f2c7d0c4b62Ab869B473F5512Dc0944D2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x56d811088235F11C8920698a204A5010a788f4b3" + } + }, + { + "chainId": 137, + "name": "Sake", + "symbol": "SAK3", + "decimals": 18, + "address": "0xeeE92219b7C4Dc9B8Aa31da1C071bc4932e6CE99", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe9F84dE264E91529aF07Fa2C746e934397810334" + } + }, + { + "chainId": 137, + "name": "Klee Kai", + "symbol": "KLEE", + "decimals": 9, + "address": "0xf137d1744F050De7A610Db728E1cdd77C2aAa755", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x382f0160c24f5c515a19f155bac14d479433a407" + } + }, + { + "chainId": 137, + "name": "Mainframe Token", + "symbol": "MFT", + "decimals": 18, + "address": "0x91cA694d2B293f70Fe722fbA7d8A5259188959c3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xDF2C7238198Ad8B389666574f2d8bc411A4b7428" + } + }, + { + "chainId": 137, + "name": "SIREN", + "symbol": "SI", + "decimals": 18, + "address": "0x54585aAc4353ac2B30022797915ef81D152D5223", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd23ac27148af6a2f339bd82d0e3cff380b5093de" + } + }, + { + "chainId": 137, + "name": "SamoSwap", + "symbol": "SAMOZ", + "decimals": 18, + "address": "0x7d3fA4bAD8220d927A23F29aa70866Ea97bBF313", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7BE4060ffF13360301E0123D676A2705149964D7" + } + }, + { + "chainId": 137, + "name": "Penky", + "symbol": "PENKY", + "decimals": 18, + "address": "0x3A35e98cC7390A15d458Bb85f9a12823e2eF25eD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf8939164a46fbe9fc923f837221eb541e3c7e7b0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/penky.svg" + }, + { + "chainId": 137, + "name": "Pteria", + "symbol": "PTERIA", + "decimals": 18, + "address": "0xc844e334cC96435e71869Fb2F7AD26961A010821", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x02Eca910CB3A7D43eBC7e8028652ed5C6b70259B" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pteria.svg" + }, + { + "chainId": 137, + "name": "Museum of Crypto Art", + "symbol": "MOCA", + "decimals": 18, + "address": "0xcE899f26928a2B21c6a2Fddd393EF37c61dbA918", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9Ac07635DDBDE5db18648c360DEFb00F5f22537e" + } + }, + { + "chainId": 137, + "name": "Future of Finance Fund", + "symbol": "FFF", + "decimals": 18, + "address": "0x9aCeB6f749396d1930aBc9e263eFc449E5e82c13", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xabafa52d3d5a2c18a4c1ae24480d22b831fc0413" + } + }, + { + "chainId": 137, + "name": "Zoo Token", + "symbol": "ZOOT", + "decimals": 9, + "address": "0x698619687Dcc9DBE01739D15DfA47e04b0d22443", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1341a2257fa7b770420ef70616f888056f90926c" + } + }, + { + "chainId": 137, + "name": "Hanzo Inu", + "symbol": "HNZO", + "decimals": 9, + "address": "0xfd66114337Ec9c1021f774aF01f81c56148D938B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x239dc02a28a0774738463e06245544a72745d5c5" + } + }, + { + "chainId": 137, + "name": "Highly Regarded Token", + "symbol": "RTRD", + "decimals": 18, + "address": "0x5B0c10270Ae2Ee3DC1003BB1E5Cb63E93306131C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5aaddb423d184b4f84b1c07022a1ba1168f83575" + } + }, + { + "chainId": 137, + "name": "FalconSwap Token", + "symbol": "FSW", + "decimals": 18, + "address": "0xad5dc12E88C6534Eea8cFe2265851D9d4A1472AD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfffffffFf15AbF397dA76f1dcc1A1604F45126DB" + } + }, + { + "chainId": 137, + "name": "Etherland", + "symbol": "ELAND", + "decimals": 18, + "address": "0xb0f61C597BBcc29f3f38396B01f9C0f0C2e8BFf0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x33e07f5055173cf8febede8b21b12d1e2b523205" + } + }, + { + "chainId": 137, + "name": "validator-Eth2", + "symbol": "vETH2", + "decimals": 18, + "address": "0x2fBB41B5Bb01cbFa1cf14473B136666a08Db4AdF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x898bad2774eb97cf6b94605677f43b41871410b1" + } + }, + { + "chainId": 137, + "name": "DeHive.finance", + "symbol": "DHV", + "decimals": 18, + "address": "0x6362Bd3Bd1a217bbf6Afa810eaA63f2d55620e2e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x62dc4817588d53a056cbbd18231d91ffccd34b2a" + } + }, + { + "chainId": 137, + "name": "Bytom minted", + "symbol": "mBTM", + "decimals": 8, + "address": "0xA16EbA3b7562FC92597579A80Fe53a92DCab7122", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9288a57d6c5644b25569e9d1d5e9e328228d26c6" + } + }, + { + "chainId": 137, + "name": "Koji", + "symbol": "KOJI", + "decimals": 18, + "address": "0x6E94662b2f78DF1f014Dafa7464Bded57F1481B2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1c8266a4369af6d80df2659ba47b3c98f35cb8be" + } + }, + { + "chainId": 137, + "name": "CargoX Token", + "symbol": "CXO", + "decimals": 18, + "address": "0xf2ae0038696774d65E67892c9D301C5f2CbbDa58", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb6ee9668771a79be7967ee29a63d4184f8097143" + } + }, + { + "chainId": 137, + "name": "ExoPlanets", + "symbol": "XPL", + "decimals": 18, + "address": "0x8A95d35dF832F03e99ED8Ee86E9d5F6Dd2641e81", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb12e260275bcd28e6f8820666ba02c67c9600843" + } + }, + { + "chainId": 137, + "name": "Metric.exchange", + "symbol": "METRIC", + "decimals": 18, + "address": "0x9f1Aeb72d5F38f2852b2a0f610bFb0391a6a9aB4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xefc1c73a3d8728dc4cf2a18ac5705fe93e5914ac" + } + }, + { + "chainId": 137, + "name": "BitSong", + "symbol": "BTSG", + "decimals": 18, + "address": "0xc5946F0c9b521f72658b658fC1260D04ea7fBE73", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x05079687d35b93538cbd59fe5596380cae9054a9" + } + }, + { + "chainId": 137, + "name": "AMIS", + "symbol": "AMIS", + "decimals": 9, + "address": "0x6f57Ec3C983a04C9Bf9958C9E908c39a3cD0870d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x949bed886c739f1a3273629b3320db0c5024c719" + } + }, + { + "chainId": 137, + "name": "Spice", + "symbol": "SFI", + "decimals": 18, + "address": "0x35b937583F04A24963eb685F728a542240f28Dd8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb753428af26e81097e7fd17f40c88aaa3e04902c" + } + }, + { + "chainId": 137, + "name": "NETVRK", + "symbol": "NTVRK", + "decimals": 18, + "address": "0xe4eF793a4bFe292D7eb229dF804FAb5BDc2c51E8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfc0d6cf33e38bce7ca7d89c0e292274031b7157a" + } + }, + { + "chainId": 137, + "name": "Oraichain Token", + "symbol": "ORAI", + "decimals": 18, + "address": "0xF4310Adb83694Bc4808e0C5ca8F7027C6127921D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4c11249814f11b9346808179cf06e71ac328c1b5" + } + }, + { + "chainId": 137, + "name": "Archer DAO Governance Token", + "symbol": "ARCH", + "decimals": 18, + "address": "0x15c310F7Af0F5379D84dfBA2fbF41b127023C784", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1f3f9d3068568f8040775be2e8c03c103c61f3af" + } + }, + { + "chainId": 137, + "name": "Bird.Money", + "symbol": "BIRD", + "decimals": 18, + "address": "0x464F540Ef8c72bBBEC620dFb12Fcb55d1989d861", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x70401dfd142a16dc7031c56e862fc88cb9537ce0" + } + }, + { + "chainId": 137, + "name": "Meta", + "symbol": "MTA", + "decimals": 18, + "address": "0xF501dd45a1198C2E1b5aEF5314A68B9006D842E0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa3bed4e1c75d00fa6f4e5e6922db7261b5e9acd2" + } + }, + { + "chainId": 137, + "name": "AllianceBlock Token", + "symbol": "ALBT", + "decimals": 18, + "address": "0x60098a09fe0436eA7099F0444F05A36bEB71cB09", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x00a8b738e453ffd858a7edf03bccfe20412f0eb0" + } + }, + { + "chainId": 137, + "name": "Hegic", + "symbol": "HEGIC", + "decimals": 18, + "address": "0xb54E928297F1Bf5740FF345811443de0F6FCd48b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x584bc13c7d411c00c01a62e8019472de68768430" + } + }, + { + "chainId": 137, + "name": "ROOK", + "symbol": "ROOK", + "decimals": 18, + "address": "0xF92501c8213da1D6C74A76372CCc720Dc8818407", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfa5047c9c78b8877af97bdcb85db743fd7313d4a" + } + }, + { + "chainId": 137, + "name": "CRO", + "symbol": "CRO", + "decimals": 8, + "address": "0xAdA58DF0F643D959C2A47c9D4d4c1a4deFe3F11C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa0b73e1ff0b80914ab6fe0444e65848c4c34450b" + } + }, + { + "chainId": 137, + "name": "Voyager", + "symbol": "VGX", + "decimals": 8, + "address": "0x054c42b6414747F5263b4A86f21B1aFAD00326Bf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5af2be193a6abca9c8817001f45744777db30756" + } + }, + { + "chainId": 137, + "name": "Serum", + "symbol": "SRM", + "decimals": 6, + "address": "0x6Bf2eb299E51Fc5DF30Dec81D9445dDe70e3F185", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x476c5e26a75bd202a9683ffd34359c0cc15be0ff" + } + }, + { + "chainId": 137, + "name": "Phala", + "symbol": "PHA", + "decimals": 18, + "address": "0x3Dee6CeB3F1E0061793510D21F2CCdE2941CB612", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6c5ba91642f10282b576d91922ae6448c9d52f4e" + } + }, + { + "chainId": 137, + "name": "Carbon", + "symbol": "CRBN", + "decimals": 18, + "address": "0x89eF0900b0A6b5548ab2FF58EF588F9433b5fCf5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcdeee767bed58c5325f68500115d4b722b3724ee" + } + }, + { + "chainId": 137, + "name": "Collateral", + "symbol": "COLL", + "decimals": 18, + "address": "0x7C68ad908D4Da363c2379D2D58E718093b9Bf970", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x957891c11616d3e0b0a76a76fb42724c382e0ef3" + } + }, + { + "chainId": 137, + "name": "LQTY", + "symbol": "LQTY", + "decimals": 18, + "address": "0x8Ab2Fec94d17ae69FB90E7c773f2C85Ed1802c01", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6dea81c8171d0ba574754ef6f8b412f2ed88c54d" + } + }, + { + "chainId": 137, + "name": "Plasma", + "symbol": "PPAY", + "decimals": 18, + "address": "0x08158A6b5d4018340387d1A302f882E98a8bC5b4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x054D64b73d3D8A21Af3D764eFd76bCaA774f3Bb2" + } + }, + { + "chainId": 137, + "name": "Healthcare Administration Token", + "symbol": "SOLVE", + "decimals": 8, + "address": "0x00A49A868d3FB149483A69045e1Ed01e8C812FF0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x446c9033e7516d820cc9a2ce2d0b7328b579406f" + } + }, + { + "chainId": 137, + "name": "Pogcoin", + "symbol": "POG", + "decimals": 2, + "address": "0xE9124Da8d008774283467b2D618624D287dE0339", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9DF38Ad87D02b006F93424C6815BA0B2B3e3AEF8" + } + }, + { + "chainId": 137, + "name": "DAO1", + "symbol": "DAO1", + "decimals": 18, + "address": "0x3c5D1617C30BA71972adD4b0C9A6B9848f2afeeD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xce3f6f6672616c39d8b6858f8dac9902eca42c84" + } + }, + { + "chainId": 137, + "name": "SafeSwap", + "symbol": "SSGT", + "decimals": 18, + "address": "0x914034f0FF781c430Aa9594851cC95806fd19dc6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2ECc48ba346A73d7d55aa5a46b5E314d9DAA6161" + } + }, + { + "chainId": 137, + "name": "Value Coin", + "symbol": "VALUE", + "decimals": 18, + "address": "0x6B0a55D19Af4F16F98965A5B85a308383D8bE55f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6997a08DE139F0b99444506f333A04Cf657832a1" + } + }, + { + "chainId": 137, + "name": "ShroomTopia SPOR Token", + "symbol": "SPOR", + "decimals": 18, + "address": "0xdc87ED1b972d42c5B218503A542d438B7fc65B7B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x80b70ec7ed638b5f7b4ecf0edbe6c2feebde9d02" + } + }, + { + "chainId": 137, + "name": "Tacos", + "symbol": "TACO", + "decimals": 18, + "address": "0x09450784A86A083041F5773836dCA457531ea00b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x00d1793d7c3aae506257ba985b34c76aaf642557" + } + }, + { + "chainId": 137, + "name": "THORChain ETH.RUNE", + "symbol": "RUNE", + "decimals": 18, + "address": "0x722Eb54CD20D13938dF8E792A5849a2391C8463F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3155ba85d5f96b2d030a4966af206230e46849cb" + } + }, + { + "chainId": 137, + "name": "PieDAO DOUGH v2", + "symbol": "DOUGH", + "decimals": 18, + "address": "0x990F860968714c2D16e91Ec0cd9709A94264Cf64", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xad32a8e6220741182940c5abf610bde99e737b2d" + } + }, + { + "chainId": 137, + "name": "TestScaleSwapToken", + "symbol": "TSCA", + "decimals": 18, + "address": "0x2242973E0D9CACAda96372A9E23C96F15776B96b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc5e9be63ab9473280c4ff9ff789ca584958e0494" + } + }, + { + "chainId": 137, + "name": "Yearn Ecosystem Pie", + "symbol": "YPIE", + "decimals": 18, + "address": "0xd3F0cd30a2D3aEFb180D23f3F38Aa1C4e0B1c98A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x17525e4f4af59fbc29551bc4ece6ab60ed49ce31" + } + }, + { + "chainId": 137, + "name": "PieDAO DEFI Large Cap", + "symbol": "DEFI+L", + "decimals": 18, + "address": "0xE90777bd6c84bf4762565eD83bc5784cc9FAf8C4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x78f225869c08d478c34e5f645d07a87d3fe8eb78" + } + }, + { + "chainId": 137, + "name": "PieDAO DEFI Small Cap", + "symbol": "DEFI+S", + "decimals": 18, + "address": "0x986d3EA4089488f77469697c50517eE12F36E1bC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xad6a626ae2b43dcb1b39430ce496d2fa0365ba9c" + } + }, + { + "chainId": 137, + "name": "PieDAO DEFI++", + "symbol": "DEFI++", + "decimals": 18, + "address": "0x5b6ab5078Bd2bbF1A215fFFBa16a94b7DF7F639d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8d1ce361eb68e9e05573443c407d4a3bed23b033" + } + }, + { + "chainId": 137, + "name": "CompliFi", + "symbol": "COMFI", + "decimals": 18, + "address": "0x72bba3Aa59a1cCB1591D7CDDB714d8e4D5597E96", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x752efadc0a7e05ad1bcccda22c141d01a75ef1e4" + } + }, + { + "chainId": 137, + "name": "COOS", + "symbol": "COOS", + "decimals": 18, + "address": "0xff4b04163E530d763010171358E7e1f70c1AbbD1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x24EbfC20Bb2e1dAADd98d28341ab37D0c154f4Cb" + } + }, + { + "chainId": 137, + "name": "Method", + "symbol": "MTHD", + "decimals": 18, + "address": "0x9bD0463B12B432AfBDd6B79Ae2032267676ce948", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x84ba4aecfde39d69686a841bab434c32d179a169" + } + }, + { + "chainId": 137, + "name": "pTokens BTC", + "symbol": "pBTC", + "decimals": 18, + "address": "0x121eF177A0489271B4339bc29Ee64609b47D43C4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5228a22e72ccc52d415ecfd199f99d0665e7733b" + } + }, + { + "chainId": 137, + "name": "NFT Protocol", + "symbol": "NFT", + "decimals": 18, + "address": "0x65c2C7095bFDC8460d7302b6a95c66cD5D8B2CFf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcB8d1260F9c92A3A545d409466280fFdD7AF7042" + } + }, + { + "chainId": 137, + "name": "Echo Token", + "symbol": "ECHO", + "decimals": 18, + "address": "0xbE34506683C842Dea90244333f9E8312672F1106", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x171706B7D113c68f2cc68a6CE63b1dbDcdF7B233" + } + }, + { + "chainId": 137, + "name": "0chain", + "symbol": "ZCN", + "decimals": 10, + "address": "0x8bB30E0e67b11b978a5040144c410e1ccDDcba30", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb9EF770B6A5e12E45983C5D80545258aA38F3B78" + } + }, + { + "chainId": 137, + "name": "Golem Network Token", + "symbol": "GLM", + "decimals": 18, + "address": "0x0B220b82F3eA3B7F6d9A1D8ab58930C064A2b5Bf", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7DD9c5Cba05E151C895FDe1CF355C9A1D5DA6429" + } + }, + { + "chainId": 137, + "name": "Mutt Coin", + "symbol": "MUTT", + "decimals": 18, + "address": "0x3B538469d94cDa1387c473F408C833c2208bcEd7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x766b0f271b6bf2a424259e19e155d6d24ea1c0b1" + } + }, + { + "chainId": 137, + "name": "Linear Token", + "symbol": "LINA", + "decimals": 18, + "address": "0x664a31F4985f1eF31d90D73E3da7ed880a052195", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3e9bc21c9b189c09df3ef1b824798658d5011937" + } + }, + { + "chainId": 137, + "name": "South African Tether", + "symbol": "XZAR", + "decimals": 18, + "address": "0x30DE46509Dbc3a491128F97be0aAf70dc7Ff33cB", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x48f07301e9e29c3c38a80ae8d9ae771f224f1054" + } + }, + { + "chainId": 137, + "name": "TNodeGreen", + "symbol": "TNG", + "decimals": 8, + "address": "0x0F38dB64E04Bcd5373dCdF941Fd909d8436f4fdb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa0e2a28fd7b1e4e7e5cced5c5bb00f7d24a5c282" + } + }, + { + "chainId": 137, + "name": "OCC", + "symbol": "OCC", + "decimals": 18, + "address": "0xF30355BA14B2d3b31597EC71a4542f57e902Cb80", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2f109021afe75b949429fe30523ee7c0d5b27207" + } + }, + { + "chainId": 137, + "name": "Layer 2 Index", + "symbol": "LTI", + "decimals": 18, + "address": "0xE329456b762a3888bbaFf6880036931D1399a417", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x693391144D1e079e20cC64f795e9450C94966171" + } + }, + { + "chainId": 137, + "name": "DEXTF Token", + "symbol": "DEXTF", + "decimals": 18, + "address": "0x400784930560ab531bD840Eb00f52e9CF66bdf98", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5f64ab1544d28732f0a24f4713c2c8ec0da089f0" + } + }, + { + "chainId": 137, + "name": "vVSP pool", + "symbol": "vVSP", + "decimals": 18, + "address": "0xF2C1b3B6eB00a3fe46478FC2E7a5E04997fEBa22", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbA4cFE5741b357FA371b506e5db0774aBFeCf8Fc" + } + }, + { + "chainId": 137, + "name": "Virtual Dollar", + "symbol": "DV", + "decimals": 18, + "address": "0x385E2000681D5979AE4e5171B94b5d5813d6253F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb791a875eA4836a9EC16CdCF4F747c0b9CA47C7d" + } + }, + { + "chainId": 137, + "name": "VesperToken", + "symbol": "VSP", + "decimals": 18, + "address": "0x09C5a4BCA808bD1ba2b8E6B3aAF7442046B4ca5B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1b40183efb4dd766f11bda7a7c3ad8982e998421" + } + }, + { + "chainId": 137, + "name": "CoinDev.io", + "symbol": "ANAL", + "decimals": 18, + "address": "0x0A438D3b374bB68a1EFd8e70ACDf22C995310Cf7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1a2df43ae7dee5e7a1915a4125a0c3875757bd5a" + } + }, + { + "chainId": 137, + "name": "Lyon.Finance", + "symbol": "LYON", + "decimals": 2, + "address": "0x6b8f374e899e20CD1c97300a4A87ed07E4b8B9f9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0e29041fb31a3e7f5f7f6a917a7df006f75a7373" + } + }, + { + "chainId": 137, + "name": "APWine Token", + "symbol": "APW", + "decimals": 18, + "address": "0x6C0AB120dBd11BA701AFF6748568311668F63FE0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4104b135DBC9609Fc1A9490E61369036497660c8" + } + }, + { + "chainId": 137, + "name": "ZEN Exchange Token", + "symbol": "ZCX", + "decimals": 18, + "address": "0xf86302c0716098Ef5b3d358099683904f449FFB8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc52c326331e9ce41f04484d3b5e5648158028804" + } + }, + { + "chainId": 137, + "name": "ZARP (Rand Reserve)", + "symbol": "ZARP", + "decimals": 2, + "address": "0xA28F6797f9Be95a6AE2b59Bbe94498725dC091A9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2f085edec7113e54a1747bD9572b213E662C6165" + } + }, + { + "chainId": 137, + "name": "bXIOT Token", + "symbol": "bXIOT", + "decimals": 6, + "address": "0x8FE2526045E6658Cd60c3eCbD92F6D33E73A1D1b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5c4ac68aAc56eBe098D621Cd8CE9F43270Aaa355" + } + }, + { + "chainId": 137, + "name": "RegiCoin", + "symbol": "REGI", + "decimals": 18, + "address": "0xfa72b07adE2Af7d41413850A1e8D5578b3490988", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xD8b98032f2220e1DDCC65371c0a7b9fA7391D347" + } + }, + { + "chainId": 137, + "name": "HORD Token", + "symbol": "HORD", + "decimals": 18, + "address": "0xa3590A0e0c9963d048a9f43cF1ee506Fb27D9129", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x43a96962254855f16b925556f9e97be436a43448" + } + }, + { + "chainId": 137, + "name": "Polkadex", + "symbol": "PDEX", + "decimals": 18, + "address": "0x93C2C75A674700e9Ed7A46Cf220EC140aea09Fad", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xF59ae934f6fe444afC309586cC60a84a0F89Aaea" + } + }, + { + "chainId": 137, + "name": "Doge of Woof Street", + "symbol": "WSDOGE", + "decimals": 9, + "address": "0xCaE54386449C0A7CE2d680982E3D08250dc3ec3b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xCBDf1deb934E945a70b7289bB98e97013777F820" + } + }, + { + "chainId": 137, + "name": "Cyclone Protocol", + "symbol": "CYC", + "decimals": 18, + "address": "0x76cD98a81b80f9373463b70cFfFf9c4b4Fd92062", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8861cff2366c1128fd699b68304ad99a0764ef9a" + } + }, + { + "chainId": 137, + "name": "IoTeX Network", + "symbol": "IOTX", + "decimals": 18, + "address": "0xf6372cDb9c1d3674E83842e3800F2A62aC9F3C66", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6fb3e0a217407efff7ca062d46c26e5d60a14d69" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/iotx.svg" + }, + { + "chainId": 137, + "name": "DogeDao", + "symbol": "DogeDao", + "decimals": 18, + "address": "0x40077808B346681C7032Cdf6a2920ab9980eAb91", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x044f613cdfffbac8bba42283dd8d97b81c8b3f3c" + } + }, + { + "chainId": 137, + "name": "Pinknode Token", + "symbol": "PNODE", + "decimals": 18, + "address": "0x4E92f6f10496F3fCB790Cc6969Cc15B87c8F9199", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xAF691508BA57d416f895e32a1616dA1024e882D2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pnode.svg" + }, + { + "chainId": 137, + "name": "Shiba Cosmos", + "symbol": "SHIBCO", + "decimals": 9, + "address": "0x19334A0E0A6089D4014f82E9077Ec1a27e27bfa1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc5c43ad81e6c76eaa1f2dd92cb6a11ff6b6d09ea" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/shibco.svg" + }, + { + "chainId": 137, + "name": "Coldstack", + "symbol": "CLS", + "decimals": 18, + "address": "0xd1C9704bB651d334e9A600dbc056504cc773479F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x675bbc7514013e2073db7a919f6e4cbef576de37" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cls.svg" + }, + { + "chainId": 137, + "name": "Interest-Bearing BTC", + "symbol": "ibBTC", + "decimals": 18, + "address": "0x4EaC4c4e9050464067D673102F8E24b2FccEB350", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc4e15973e6ff2a35cc804c2cf9d2a1b817a8b40f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ibbtc.svg" + }, + { + "chainId": 137, + "name": "UniPower", + "symbol": "POWER", + "decimals": 18, + "address": "0x00D5149cDF7CEC8725bf50073c51c4fa58eCCa12", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF2f9A7e93f845b3ce154EfbeB64fB9346FCCE509" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/power.svg" + }, + { + "chainId": 137, + "name": "SafeEarth", + "symbol": "SAFEEARTH", + "decimals": 9, + "address": "0x431351DbFE3E03Be7842e411C6627aCb0763C5fc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe6f1966d04cfcb9cd1b1dc4e8256d8b501b11cba" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/safeearth.svg" + }, + { + "chainId": 137, + "name": "Conjure", + "symbol": "CNJ", + "decimals": 18, + "address": "0x2b76F9E7BecC7B4381EEB1894385045B1aA7fBAb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x00A55375002f3cDa400383F479e7Cd57Bad029A9" + } + }, + { + "chainId": 137, + "name": "Donkey", + "symbol": "DON", + "decimals": 18, + "address": "0xc1fe55e82A992f870F68Ba208617486Bee7Ad0fc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x217ddead61a42369a266f1fb754eb5d3ebadc88a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/don.svg" + }, + { + "chainId": 137, + "name": "dfohub", + "symbol": "buidl", + "decimals": 18, + "address": "0x33E09c93c7515BC346bF49D4e4bD0C7bE63F814D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7b123f53421b1bf8533339bfbdc7c98aa94163db" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/buidl.svg" + }, + { + "chainId": 137, + "name": "ETHA", + "symbol": "ETHA", + "decimals": 18, + "address": "0x59E9261255644c411AfDd00bD89162d09D862e38", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x59E9261255644c411AfDd00bD89162d09D862e38" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/etha.svg" + }, + { + "chainId": 137, + "name": "megaBONK", + "symbol": "mBONK", + "decimals": 18, + "address": "0xd93c61D4418d77A537b6B57478C108E193362f0C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xacfe45c352c902ae3a3f9b6bfe6ec994c5d791bf" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mbonk.svg" + }, + { + "chainId": 137, + "name": "ChainGuardians Governance Token", + "symbol": "CGG", + "decimals": 18, + "address": "0x2Ab4f9aC80F33071211729e45Cfc346C1f8446d5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1fe24f25b1cf609b9c4e7e12d802e3640dfa5e43" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cgg.svg" + }, + { + "chainId": 137, + "name": "dHEDGE Top Index", + "symbol": "dTOP", + "decimals": 18, + "address": "0x0361BdEAB89DF6BBcc52c43589FABba5143d19dD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0f4c00139602AB502Bc7c1c0e71D6CB72A9FB0e7" + } + }, + { + "chainId": 137, + "name": "iEx.ec Network Token", + "symbol": "RLC", + "decimals": 9, + "address": "0xbe662058e00849C3Eef2AC9664f37fEfdF2cdbFE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x607f4c5bb672230e8672085532f7e901544a7375" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rlc.svg" + }, + { + "chainId": 137, + "name": "Woofy", + "symbol": "WOOFY", + "decimals": 12, + "address": "0xD0660cD418a64a1d44E9214ad8e459324D8157f1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xD0660cD418a64a1d44E9214ad8e459324D8157f1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/woofy.svg" + }, + { + "chainId": 137, + "name": "Jigstack", + "symbol": "STAK", + "decimals": 18, + "address": "0x46A5D492788f8AFdfC743Ab7D7bD13F996249ED5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1f8a626883d7724dbd59ef51cbd4bf1cf2016d13" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/stak.svg" + }, + { + "chainId": 137, + "name": "Mogul Stars", + "symbol": "STARS", + "decimals": 18, + "address": "0xFd81cfCD9C525b0A4C83Cdc37fd23f7e233CDE45", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc55c2175E90A46602fD42e931f62B3Acc1A013Ca" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/stars.svg" + }, + { + "chainId": 137, + "name": "Cryptex", + "symbol": "CTX", + "decimals": 18, + "address": "0x8c208BC2A808a088a78398fed8f2640cab0b6EDb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x321c2fe4446c7c963dc41dd58879af648838f98d" + } + }, + { + "chainId": 137, + "name": "TCAP Token", + "symbol": "TCAP", + "decimals": 18, + "address": "0x67BcDE6a52BE923D3223fCae927aB16B352768Bb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x16c52CeeCE2ed57dAd87319D91B5e3637d50aFa4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/tcap.svg" + }, + { + "chainId": 137, + "name": "ArGo Token", + "symbol": "ARGO", + "decimals": 18, + "address": "0xD0252fB67606Ed74d0cACD17B2eb38446e4466c9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x28Cca76f6e8eC81e4550ecd761f899110b060E97" + } + }, + { + "chainId": 137, + "name": "SuperBid", + "symbol": "SUPERBID", + "decimals": 18, + "address": "0xA3860f969075045D82de85B06bB665f93c4BAE32", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0563dce613d559a47877ffd1593549fb9d3510d6" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/superbid.svg" + }, + { + "chainId": 137, + "name": "Finally Usable Crypto Karma", + "symbol": "FUCK", + "decimals": 4, + "address": "0x3C1D58c24D9a33bBa6d90E31e3AA828aF33f4F58", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x65be44c747988fbf606207698c944df4442efe19" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/fuck.svg" + }, + { + "chainId": 137, + "name": "AurusSILVER", + "symbol": "AWS", + "decimals": 18, + "address": "0xA96D47c621a8316d4F9539E3B38180C7067e84CA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb89903dde3899f0280b99913168ee833a7896b93" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/aws.svg" + }, + { + "chainId": 137, + "name": "Dogelon", + "symbol": "ELON", + "decimals": 18, + "address": "0xE0339c80fFDE91F3e20494Df88d4206D86024cdF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x761d38e5ddf6ccf6cf7c55759d5210750b5d60f3" + } + }, + { + "chainId": 137, + "name": "Wrapped Tezos", + "symbol": "WXTZ", + "decimals": 18, + "address": "0x308ba429a913d952275090Fc35dEA9C36A511B5A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA3865E64121537b5b59B5e239Db4aCBe6F36aa74" + } + }, + { + "chainId": 137, + "name": "Wrapped Litecoin", + "symbol": "WLTC", + "decimals": 18, + "address": "0xb2DB9d30CaA8A46e7a99b3Cec2e014f9488071eC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x53c4871322Bb47e7A24136fce291a6dcC832a294" + } + }, + { + "chainId": 137, + "name": "Wrapped Filecoin", + "symbol": "WFIL", + "decimals": 18, + "address": "0xEde1B77C0Ccc45BFa949636757cd2cA7eF30137F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6e1A19F235bE7ED8E3369eF73b196C07257494DE" + } + }, + { + "chainId": 137, + "name": "Wrapped ZEC", + "symbol": "WZEC", + "decimals": 18, + "address": "0x4F38008D9E2b6F1374199B29d6610021f70F174b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4A64515E5E1d1073e83f30cB97BEd20400b66E10" + } + }, + { + "chainId": 137, + "name": "Labra", + "symbol": "LABRA", + "decimals": 9, + "address": "0xCE59e5c0F130Da0796509a0d32f44B0a6C81B9de", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x106d3c66d22d2dd0446df23d7f5960752994d600" + } + }, + { + "chainId": 137, + "name": "LIQUID", + "symbol": "LIQUID", + "decimals": 18, + "address": "0x258b34a8f350c833D5308cEb3F7f586c54aFe973", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC618D56b6D606E59c6B87Af724AB5a91eb40D1cb" + } + }, + { + "chainId": 137, + "name": "PETRON PAY SECURITY TOKEN", + "symbol": "PETRON", + "decimals": 18, + "address": "0xfF7ef642B070CF63602E46a2eD63aDf893e95437", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x43789e8aeef0d30cffb57fc0870a5c785b7b93a1" + } + }, + { + "chainId": 137, + "name": "Jejudoge", + "symbol": "JEJUDOGE", + "decimals": 18, + "address": "0x5Ca2ea050a3552aDdAA88466f0AA088bCc0dC2fb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x939a7a577d93ad29b64c1595b1284ce660a479b9" + } + }, + { + "chainId": 137, + "name": "Inverse DAO", + "symbol": "INV", + "decimals": 18, + "address": "0xF18Ac368001b0DdC80aA6a8374deb49e868EFDb8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41D5D79431A913C4aE7d69a668ecdfE5fF9DFB68" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/inv.svg" + }, + { + "chainId": 137, + "name": "Wrapped STA", + "symbol": "WSTA", + "decimals": 18, + "address": "0xf629712180bEF6F4c569B704e03d0AcbE276Eb6d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xedeec5691f23e4914cf0183a4196bbeb30d027a0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wsta.svg" + }, + { + "chainId": 137, + "name": "Sanshu Inu", + "symbol": "SANSHU", + "decimals": 9, + "address": "0xC518edFB9667214Be3559B86E73777d1C4789163", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc73c167e7a4ba109e4052f70d5466d0c312a344d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sanshu.svg" + }, + { + "chainId": 137, + "name": "YFII.finance", + "symbol": "YFII", + "decimals": 18, + "address": "0xb8cb8a7F4C2885C03e57E973C74827909Fdc2032", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa1d0E215a23d7030842FC67cE582a6aFa3CCaB83" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/yfii.svg" + }, + { + "chainId": 137, + "name": "USDK", + "symbol": "USDK", + "decimals": 18, + "address": "0xD07A7FAc2857901E4bEC0D89bBDAe764723AAB86", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1c48f86ae57291f7686349f12601910bd8d470bb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/usdk.svg" + }, + { + "chainId": 137, + "name": "Paxos Standard", + "symbol": "PAX", + "decimals": 18, + "address": "0x6F3B3286fd86d8b47EC737CEB3D0D354cc657B3e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8e870d67f660d95d5be530380d0ec0bd388289e1" + } + }, + { + "chainId": 137, + "name": "Gemini dollar", + "symbol": "GUSD", + "decimals": 2, + "address": "0xC8A94a3d3D2dabC3C1CaffFFDcA6A7543c3e3e65", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x056fd409e1d7a124bd7017459dfea2f387b6d5cd" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/gusd.svg" + }, + { + "chainId": 137, + "name": "TrueUSD", + "symbol": "TUSD", + "decimals": 18, + "address": "0x2e1AD108fF1D8C782fcBbB89AAd783aC49586756", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0000000000085d4780B73119b644AE5ecd22b376" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/tusd.svg" + }, + { + "chainId": 137, + "name": "0x Protocol Token", + "symbol": "ZRX", + "decimals": 18, + "address": "0x5559Edb74751A0edE9DeA4DC23aeE72cCA6bE3D5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe41d2489571d322189246dafa5ebde1f4699f498" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/zrx.svg" + }, + { + "chainId": 137, + "name": "3 Comma Club", + "symbol": "THREE", + "decimals": 18, + "address": "0x66D70309D37eaEA53B22A1a3fA280327B2C610c6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x14fD3063dfd3cE0A2C4C5eE43aB49988A989202C" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/three.svg" + }, + { + "chainId": 137, + "name": "PUSSY token", + "symbol": "PUSSY", + "decimals": 18, + "address": "0x79B9A1C21EcF6a22A6D722A5Bfb437Ef776E87CD", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9196e18bc349b1f64bc08784eae259525329a1ad" + } + }, + { + "chainId": 137, + "name": "BTC 2x Flexible Leverage Index", + "symbol": "BTC2x-FLI", + "decimals": 18, + "address": "0x4b54Bc363f5F9c6E0fcd82EaC6919aE213464Cc6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0b498ff89709d3838a063f1dfa463091f9801c2b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/btc2x-fli.svg" + }, + { + "chainId": 137, + "name": "Dickels", + "symbol": "8=D", + "decimals": 18, + "address": "0x68e311445FA668107f1dCd13758788643b3AF240", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa64c3956D55592fa20762D8e62eB5B8E6f8AaAd0" + } + }, + { + "chainId": 137, + "name": "BLOCKv Token", + "symbol": "VEE", + "decimals": 18, + "address": "0xf1c1A3C2481A3a8A3f173A9ab5Ade275292A6fA3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x340D2bdE5Eb28c1eed91B2f790723E3B160613B7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/vee.svg" + }, + { + "chainId": 137, + "name": "L�f", + "symbol": "LIF", + "decimals": 18, + "address": "0x5b3455590Ec7F5a25119885Ed62aFBA9bC2e5D65", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEB9951021698B42e4399f9cBb6267Aa35F82D59D" + } + }, + { + "chainId": 137, + "name": "ProjectSenpai", + "symbol": "SENPAI", + "decimals": 18, + "address": "0x69f240eD3456A098f2D0D898566597E7551a7C81", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5a705745373a780814c379Ef17810630D529EFE0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/senpai.svg" + }, + { + "chainId": 137, + "name": "FOX", + "symbol": "FOX", + "decimals": 18, + "address": "0x65A05DB8322701724c197AF82C9CaE41195B0aA8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc770eefad204b5180df6a14ee197d99d808ee52d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/fox.svg" + }, + { + "chainId": 137, + "name": "Nash Exchange Token", + "symbol": "NEX", + "decimals": 8, + "address": "0xA486c6BC102f409180cCB8a94ba045D39f8fc7cB", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe2dc070524a6e305ddb64d8513dc444b6a1ec845" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nex.svg" + }, + { + "chainId": 137, + "name": "Dogen", + "symbol": "DOGEN", + "decimals": 18, + "address": "0x9D8A8D15A45fb10060f1d642FB97aA28F5CdedE2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x17eb50fdd2995696ee82912a80a9766fcbb0ecca" + } + }, + { + "chainId": 137, + "name": "Corgi Inu", + "symbol": "CORGI", + "decimals": 10, + "address": "0x26361cFC497021ecc366ec11cAFa27290f3c055c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe50006781f435ae43096288334afd9ae5ba50065" + } + }, + { + "chainId": 137, + "name": "Bitfinex LEO Token", + "symbol": "LEO", + "decimals": 18, + "address": "0x06D02e9D62A13fC76BB229373FB3BBBD1101D2fC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2af5d2ad76741191d15dfe7bf6ac92d4bd912ca3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/leo.svg" + }, + { + "chainId": 137, + "name": "KIMCHI.finance", + "symbol": "KIMCHI", + "decimals": 18, + "address": "0xD62355546a93bFb0E891E905Ff40B3B26ff5F2b1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1e18821e69b9faa8e6e75dffe54e7e25754beda0" + } + }, + { + "chainId": 137, + "name": "Silver Fifty Token", + "symbol": "SLX", + "decimals": 0, + "address": "0xD762d38220751F84aE5dC3fb67C8d971c08A638a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb17d1826e09135457328c3a397fc40aa56a46256" + } + }, + { + "chainId": 137, + "name": "Governor", + "symbol": "GDAO", + "decimals": 18, + "address": "0x98113e216578359b8c0EB3a9fDDd64285E91120A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x515d7e9d75e2b76db60f8a051cd890eba23286bc" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/gdao.svg" + }, + { + "chainId": 137, + "name": "Musketeer", + "symbol": "MUSKETS", + "decimals": 18, + "address": "0x46ca31e0439dbF5D0D9c0338Be4912dd35D45A51", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbc93d1aba134cc81F431dE04f2D9F46Fc5D6D6bc" + } + }, + { + "chainId": 137, + "name": "Neos Credits", + "symbol": "NCR", + "decimals": 18, + "address": "0xDA6f726E2088F129D3Ecb2257206AdF7D8537Ba5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdb5c3c46e28b53a39c255aa39a411dd64e5fed9c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ncr.svg" + }, + { + "chainId": 137, + "name": "POP Token", + "symbol": "POP!", + "decimals": 18, + "address": "0xF872ff474C01C4178dadEB941089a130Aa1EEd93", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x98629512ed2239974e169341be5b920ea4dcdb21" + } + }, + { + "chainId": 137, + "name": "Truebit", + "symbol": "TRUtru", + "decimals": 18, + "address": "0xfD39C9Bb69Cc3bD57959284aCF855AE65d06f8CF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf65B5C5104c4faFD4b709d9D60a185eAE063276c" + } + }, + { + "chainId": 137, + "name": "UNIFUND", + "symbol": "iFUND", + "decimals": 18, + "address": "0x4ba47B10EA8f544F8969BA61dF3E5bE67692a122", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x04b5e13000c6e9a3255dc057091f3e3eeee7b0f0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ifund.svg" + }, + { + "chainId": 137, + "name": "IdleUSDC", + "symbol": "idleUSDC", + "decimals": 18, + "address": "0xE8b3D257202a9DfE00Ec396B8a8A45fceD1f5798", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5274891bEC421B39D23760c04A6755eCB444797C" + } + }, + { + "chainId": 137, + "name": "Kanga Exchange Token", + "symbol": "KNG", + "decimals": 18, + "address": "0x17D342b29F054030a455b4191f977C3b0aA62Fd9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x471d113059324321749e097705197a2b44a070fc" + } + }, + { + "chainId": 137, + "name": "CARD.STARTER", + "symbol": "CARDS", + "decimals": 18, + "address": "0xF1bd521984b4b46176ef4E77f3de01B9FBbe5191", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3d6f0dea3ac3c607b3998e6ce14b6350721752d9" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cards.svg" + }, + { + "chainId": 137, + "name": "PhoenixDAO", + "symbol": "PHNX", + "decimals": 18, + "address": "0x92C59F1cC9A322670CCa29594e4D994d48BDFd36", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x38A2fDc11f526Ddd5a607C1F251C065f40fBF2f7" + } + }, + { + "chainId": 137, + "name": "Idle", + "symbol": "IDLE", + "decimals": 18, + "address": "0xC25351811983818c9Fe6D8c580531819c8ADe90f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x875773784Af8135eA0ef43b5a374AaD105c5D39e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/idle.svg" + }, + { + "chainId": 137, + "name": "Bsit Token", + "symbol": "BSIT", + "decimals": 4, + "address": "0x5e765e58A4d15262123a8Db42a31c8BA99Ae48ab", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3b9abadd72b3e90eb980d213bf1f697566358100" + } + }, + { + "chainId": 137, + "name": "Kirobo", + "symbol": "KIRO", + "decimals": 18, + "address": "0xB382C1cfA622795a534e5bd56Fac93d59BAc8B0D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb1191f691a355b43542bea9b8847bc73e7abb137" + } + }, + { + "chainId": 137, + "name": "FullDex", + "symbol": "FLDX", + "decimals": 16, + "address": "0xE5d6364efCDCb90eD92cf6F776dD0B6165168a7e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6a30ef92f921836F3743a4A9d27e6CF2C8670b9B" + } + }, + { + "chainId": 137, + "name": "OnSynthetics", + "symbol": "ONS", + "decimals": 18, + "address": "0xF50C6E2b720Dab4eA87E0050856a511E3E3cEB8D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfC97C0c12438B6E4CF246cD831b02FeF4950DCAD" + } + }, + { + "chainId": 137, + "name": "Ankr", + "symbol": "ANKR", + "decimals": 18, + "address": "0x101A023270368c0D50BFfb62780F4aFd4ea79C35", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8290333cef9e6d528dd5618fb97a76f268f3edd4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ankr.svg" + }, + { + "chainId": 137, + "name": "GET Protocol", + "symbol": "GET", + "decimals": 18, + "address": "0xdb725f82818De83e99F1dAc22A9b5B51d3d04DD4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8a854288a5976036a725879164ca3e91d30c6a1b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/get.svg" + }, + { + "chainId": 137, + "name": "Quoxent", + "symbol": "QUO", + "decimals": 18, + "address": "0x9b0162d3B3b4E73fE7dBB10b141E03539199A8F2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xefd720C94659F2cCb767809347245F917A145ed8" + } + }, + { + "chainId": 137, + "name": "Unilayer", + "symbol": "LAYER", + "decimals": 18, + "address": "0x9A37814d1eC68cA5f8aaB205f628869f3926cE3E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0fF6ffcFDa92c53F615a4A75D982f399C989366b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/layer.svg" + }, + { + "chainId": 137, + "name": "ClinTex", + "symbol": "CTI", + "decimals": 18, + "address": "0x8Ba941b64901E306667a287A370F145d98811096", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8c18d6a985ef69744b9d57248a45c0861874f244" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cti.svg" + }, + { + "chainId": 137, + "name": "Wrapped UST Token", + "symbol": "UST", + "decimals": 18, + "address": "0x692597b009d13C4049a947CAB2239b7d6517875F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa47c8bf37f92abed4a126bda807a7b7498661acd" + } + }, + { + "chainId": 137, + "name": "Enjin Coin", + "symbol": "ENJ", + "decimals": 18, + "address": "0x7eC26842F195c852Fa843bB9f6D8B583a274a157", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf629cbd94d3791c9250152bd8dfbdf380e2a3b9c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/enj.svg" + }, + { + "chainId": 137, + "name": "Defi Firefly", + "symbol": "DFF", + "decimals": 8, + "address": "0xC8F190b18579eA425D89Fb8e84774335715795cb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaf183350bdf8082b486cee23fbfcca6ea3258dac" + } + }, + { + "chainId": 137, + "name": "Nimbus", + "symbol": "NBU", + "decimals": 18, + "address": "0x977777C5d1208742343BB1F4CAB182E56D624f1F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeb58343b36c7528f23caae63a150240241310049" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nbu.svg" + }, + { + "chainId": 137, + "name": "Nimbus Governance Token", + "symbol": "GNBU", + "decimals": 18, + "address": "0x68de9750059Aed98c9A200Ee661A5316b5C7F941", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x639ae8f3eed18690bf451229d14953a5a5627b72" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/gnbu.svg" + }, + { + "chainId": 137, + "name": "Ampleforth Governance", + "symbol": "FORTH", + "decimals": 18, + "address": "0x5eCbA59DAcc1ADc5bDEA35f38A732823fc3dE977", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x77fba179c79de5b7653f68b5039af940ada60ce0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/forth.svg" + }, + { + "chainId": 137, + "name": "SHIBA INU", + "symbol": "SHIB", + "decimals": 18, + "address": "0x6f8a06447Ff6FcF75d803135a7de15CE88C1d4ec", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x95ad61b0a150d79219dcf64e1e6cc01f0b64c4ce" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/shib.svg" + }, + { + "chainId": 137, + "name": "Solid", + "symbol": "Solid", + "decimals": 18, + "address": "0x498E0A753840075c4925442D4d8863eEe49D61E2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5011d48d4265b6fb8228600a111b2faa1fda3139" + } + }, + { + "chainId": 137, + "name": "Waifu", + "symbol": "WAIF", + "decimals": 18, + "address": "0xdEE1ebd2a9F6fE069a045601ebeE7C42572ABD5F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb2279b6769cfba691416f00609b16244c0cf4b20" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/waif.svg" + }, + { + "chainId": 137, + "name": "NOIA Token", + "symbol": "NOIA", + "decimals": 18, + "address": "0x957d1AD5214468332C5e6C00305a25116f9A46BB", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa8c8CfB141A3bB59FEA1E2ea6B79b5ECBCD7b6ca" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/noia.svg" + }, + { + "chainId": 137, + "name": "Reality Clash Coin", + "symbol": "RCC", + "decimals": 18, + "address": "0x11b4ce411bc617E636Cf1109dE9f3CA977d4a00d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9b6443b0fb9c241a7fdac375595cea13e6b7807a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rcc.svg" + }, + { + "chainId": 137, + "name": "SakeToken", + "symbol": "SAKE", + "decimals": 18, + "address": "0x6127Bb5A1b847fF57bF7B9469c4db6E310466214", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x066798d9ef0833ccc719076Dab77199eCbd178b0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sake.svg" + }, + { + "chainId": 137, + "name": "Wrapped NXM", + "symbol": "wNXM", + "decimals": 18, + "address": "0x0539F01d9ED66c3133a0B0FaB83f4fa69B3608E8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0d438f3b5175bebc262bf23753c1e53d03432bde" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wnxm.svg" + }, + { + "chainId": 137, + "name": "PowerLedger", + "symbol": "POWR", + "decimals": 6, + "address": "0x0AaB8DC887D34f00D50E19aee48371a941390d14", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x595832f8fc6bf59c85c527fec3740a1b7a361269" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/powr.svg" + }, + { + "chainId": 137, + "name": "BSNcommunitynet", + "symbol": "cBSN", + "decimals": 18, + "address": "0xA219a63C170D0bcDe994886d53878f86C5126106", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7d4B1d793239707445305D8d2456D2c735F6B25B" + } + }, + { + "chainId": 137, + "name": "Nuggets", + "symbol": "NUG", + "decimals": 18, + "address": "0xf0e7BeEdc882a66C151D03B594503317B8472336", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x245ef47d4d0505ecf3ac463f4d81f41ade8f1fd1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nug.svg" + }, + { + "chainId": 137, + "name": "DokiDoki.Chainbinders", + "symbol": "BND", + "decimals": 18, + "address": "0x032b3217241fe53fFaDB334a9d06aACd2A9153D9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x84cd68c3e470ecee4b8b6212efcb8c6bcb38da1d" + } + }, + { + "chainId": 137, + "name": "AlphaDex", + "symbol": "DEX", + "decimals": 18, + "address": "0x7120441Ad773A6704d13dAC8D8Ccfe94da9AFC9B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3516415161C478DF10ADBb8bb884Cc83FbD5F11a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dex.svg" + }, + { + "chainId": 137, + "name": "KittenFinance", + "symbol": "KIF", + "decimals": 18, + "address": "0x5f084F3EE7EA09E4C01CEE3cDF1B5620A3344fd0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x177BA0cac51bFC7eA24BAd39d81dcEFd59d74fAa" + } + }, + { + "chainId": 137, + "name": "Kishu Inu", + "symbol": "KISHU", + "decimals": 9, + "address": "0xA3D595823beeDE02cC755AB4e22AD009A70cB590", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xA2b4C0Af19cC16a6CfAcCe81F192B024d625817D" + } + }, + { + "chainId": 137, + "name": "EASY V2", + "symbol": "EZ", + "decimals": 18, + "address": "0x34C1b299A74588D6Abdc1b85A53345A48428a521", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x00AbA6fE5557De1a1d565658cBDdddf7C710a1eb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ez.svg" + }, + { + "chainId": 137, + "name": "Akropolis", + "symbol": "AKRO", + "decimals": 18, + "address": "0xd8a2B5ED27d57d003962032ea78f3738fF5617a8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8ab7404063ec4dbcfd4598215992dc3f8ec853d7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/akro.svg" + }, + { + "chainId": 137, + "name": "Metaverse Index", + "symbol": "MVI", + "decimals": 18, + "address": "0xfe712251173A2cd5F5bE2B46Bb528328EA3565E1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x72e364f2abdc788b7e918bc238b21f109cd634d7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mvi.svg" + }, + { + "chainId": 137, + "name": "Index", + "symbol": "INDEX", + "decimals": 18, + "address": "0xfBd8A3b908e764dBcD51e27992464B4432A1132b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0954906da0Bf32d5479e25f46056d22f08464cab" + } + }, + { + "chainId": 137, + "name": "LTO Network Token", + "symbol": "LTO", + "decimals": 8, + "address": "0x96963189dC1dFBE8De4b1BB03c603adeFcD3E59d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3db6ba6ab6f95efed1a6e794cad492faaabf294d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lto.svg" + }, + { + "chainId": 137, + "name": "ETH 2x Flexible Leverage Index", + "symbol": "ETH2x-FLI", + "decimals": 18, + "address": "0x66d7FDCc7403f18cAE9b0e2e8385649D2AcBC12A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaa6e8127831c9de45ae56bb1b0d4d4da6e5665bd" + } + }, + { + "chainId": 137, + "name": "Livepeer Token", + "symbol": "LPT", + "decimals": 18, + "address": "0x3962F4A0A0051DccE0be73A7e09cEf5756736712", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x58b6a8a3302369daec383334672404ee733ab239" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lpt.svg" + }, + { + "chainId": 137, + "name": "Indexed", + "symbol": "NDX", + "decimals": 18, + "address": "0x835273d47A2a4Cc84693639f8D890af1CaeA611D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x86772b1409b61c639eaac9ba0acfbb6e238e5f83" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ndx.svg" + }, + { + "chainId": 137, + "name": "Zoracles", + "symbol": "ZORA", + "decimals": 9, + "address": "0x2f9679F1Db7E1a3Ffd659e1880339E18B482F17A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD8E3FB3b08eBA982F2754988d70D57eDc0055ae6" + } + }, + { + "chainId": 137, + "name": "INVERSE", + "symbol": "XIV", + "decimals": 18, + "address": "0xde799636aF0d8D65a17AAa83b66cBBE9B185EB01", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x44f262622248027f8e2a8fb1090c4cf85072392c" + } + }, + { + "chainId": 137, + "name": "ACoconut BTC", + "symbol": "acBTC", + "decimals": 18, + "address": "0xFb0E4a608657c09e0fE048D8BB54431eb7fB58D0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xef6e45af9a422c5469928f927ca04ed332322e2e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/acbtc.svg" + }, + { + "chainId": 137, + "name": "ACoconut", + "symbol": "AC", + "decimals": 18, + "address": "0x6D1B94027453C457e90C28E83154B02718bD48b2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9a0aba393aac4dfbff4333b06c407458002c6183" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ac.svg" + }, + { + "chainId": 137, + "name": "Global Scan Token", + "symbol": "GST", + "decimals": 18, + "address": "0xe5703ad34D2b5BCB5c1fEeb64d4b7572B857D6c0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x382f5DfE9eE6e309D1B9D622735e789aFde6BADe" + } + }, + { + "chainId": 137, + "name": "Time", + "symbol": "Time", + "decimals": 18, + "address": "0x0BaC8F2819527c562b1BdD5B9C8E24bE7dbd6cae", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xC2Ce8D7cA631555fC7DacF744326f70586a12898" + } + }, + { + "chainId": 137, + "name": "PeetyCoin", + "symbol": "PTC", + "decimals": 18, + "address": "0x4BB0A0ceF106b0376A9320BE1cF9BCe2D9fC075E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x91b2372c2a364ef0acfd6a87e41825c186164772" + } + }, + { + "chainId": 137, + "name": "LoopringCoin V2", + "symbol": "LRC", + "decimals": 18, + "address": "0x84e1670F61347CDaeD56dcc736FB990fBB47ddC1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbbbbca6a901c926f240b89eacb641d8aec7aeafd" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lrc.svg" + }, + { + "chainId": 137, + "name": "GOVI", + "symbol": "GOVI", + "decimals": 18, + "address": "0x43Df9c0a1156c96cEa98737b511ac89D0e2A1F46", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xeeaa40b28a2d1b0b08f6f97bb1dd4b75316c6107" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/govi.svg" + }, + { + "chainId": 137, + "name": "Dracula Token", + "symbol": "DRaCula", + "decimals": 18, + "address": "0xdf2d3db12254B062b96424F27f44649321901499", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb78B3320493a4EFaa1028130C5Ba26f0B6085Ef8" + } + }, + { + "chainId": 137, + "name": "Wrapped Mirror TSLA Token", + "symbol": "mTSLA", + "decimals": 18, + "address": "0x52c57f0eA393Bb213445F47c48c5f34e419061C7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x21cA39943E91d704678F5D00b6616650F066fD63" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mtsla.svg" + }, + { + "chainId": 137, + "name": "BribeToken", + "symbol": "BRIBE", + "decimals": 18, + "address": "0xA9e0CDE4bE86F5DF7e2888753E5F663A41220469", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x679fa6dc913acab6def33ec469fc6e421bc794f5" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bribe.svg" + }, + { + "chainId": 137, + "name": "Nectar", + "symbol": "NCT", + "decimals": 18, + "address": "0x4985E0B13554fB521840e893574D3848C10Fcc6f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9e46a38f5daabe8683e10793b06749eef7d733d1" + } + }, + { + "chainId": 137, + "name": "InfiniCoin", + "symbol": "INFC", + "decimals": 2, + "address": "0x6046b4d4E5ccC4aD4AABf655b557d8FD19B631D9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x742a56a727dac07e0889920b8887d482325f659b" + } + }, + { + "chainId": 137, + "name": "StakeWise", + "symbol": "SWISE", + "decimals": 18, + "address": "0xBbbe128568222623D21299f019a978C8587B33dC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x48c3399719b582dd63eb5aadf12a40b4c3f52fa2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/swise.svg" + }, + { + "chainId": 137, + "name": "Blockpass", + "symbol": "PASS", + "decimals": 6, + "address": "0x030a6b1Da67963Fc22265d8C6686d1878d581b6B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xee4458e052b533b1aabd493b5f8c4d85d7b263dc" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pass.svg" + }, + { + "chainId": 137, + "name": "Celo", + "symbol": "CELO", + "decimals": 18, + "address": "0x9b90e9Dc868A3c769dbb1d43F925cC954327F666", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6d0081857009cb79014df13e34fc49192f66aee1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/celo.svg" + }, + { + "chainId": 137, + "name": "LUSD Stablecoin", + "symbol": "LUSD", + "decimals": 18, + "address": "0x23001f892c0C82b79303EDC9B9033cD190BB21c7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5f98805a4e8be255a32880fdec7f6728c6568ba0" + } + }, + { + "chainId": 137, + "name": "Unicly Doki Collection", + "symbol": "uDOKI", + "decimals": 18, + "address": "0xFfB6efF3e73DB35b3efCF2bCD160fc517C5Df9Ec", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7e6c38d007740931e4b419bf15a68c79a0fb0c66" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/udoki.svg" + }, + { + "chainId": 137, + "name": "Shardus", + "symbol": "ULT", + "decimals": 18, + "address": "0xf0059CC2b3E980065A906940fbce5f9Db7ae40A7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x09617f6fd6cf8a71278ec86e23bbab29c04353a7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ult.svg" + }, + { + "chainId": 137, + "name": "OVR", + "symbol": "OVR", + "decimals": 18, + "address": "0x1631244689EC1fEcbDD22fb5916E920dFC9b8D30", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x21bfbda47a0b4b5b1248c767ee49f7caa9b23697" + } + }, + { + "chainId": 137, + "name": "Digi", + "symbol": "DIGI", + "decimals": 18, + "address": "0x4d8181f051E617642e233Be09Cea71Cc3308ffD4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3cbf23c081faa5419810ce0f6bc1ecb73006d848" + } + }, + { + "chainId": 137, + "name": "Pikachu", + "symbol": "Pikachu", + "decimals": 18, + "address": "0x7E6afEC8cf917976d11Fe65A34d3c17289fe3aE0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe09fb60e8d6e7e1cebbe821bd5c3fc67a40f86bf" + } + }, + { + "chainId": 137, + "name": "Beyond Finance", + "symbol": "BYN", + "decimals": 18, + "address": "0x11602A402281974a70C2B4824d58ebeDe967E2bE", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4Bb3205bf648B7F59EF90Dee0F1B62F6116Bc7ca" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/byn.svg" + }, + { + "chainId": 137, + "name": "Launchpool token", + "symbol": "LPOOL", + "decimals": 18, + "address": "0x9e7Deba360c77949bb75d16DC81b2393C15005Eb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6149c26cd2f7b5ccdb32029af817123f6e37df5b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lpool.svg" + }, + { + "chainId": 137, + "name": "Gremlin DAO", + "symbol": "GRMLN", + "decimals": 18, + "address": "0x80a017A2B089b642743d863cEeb6Da1FE0191ADC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcb167289204d02d33a8faf24a68b57647eb621bf" + } + }, + { + "chainId": 137, + "name": "Internet Exchange Token", + "symbol": "INEX", + "decimals": 8, + "address": "0xD8324aE24AF9b499Cb75fb0bad8E0094c10CAC58", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa2d77f8353cb2afd709aba4a967257511ecff716" + } + }, + { + "chainId": 137, + "name": "MyFiChain", + "symbol": "myfi", + "decimals": 18, + "address": "0x217CA87921B066728feBC2d093FE9a6503450c47", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0dfdd839cde95dabf56f0b5c5698e0159138930d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/myfi.svg" + }, + { + "chainId": 137, + "name": "ETH.limiteD", + "symbol": "ELD", + "decimals": 18, + "address": "0x222Cc013116D43a8b6BEfA84aaF7c11cBc073496", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf0c6521b1f8ad9c33a99aaf056f6c6247a3862ba" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/eld.svg" + }, + { + "chainId": 137, + "name": "ZperToken", + "symbol": "ZPR", + "decimals": 18, + "address": "0x9f9003c25d475Ca76D925Bfad0c568D8B3720353", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb5b8f5616fe42d5ceca3e87f3fddbdd8f496d760" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/zpr.svg" + }, + { + "chainId": 137, + "name": "NANJCOIN", + "symbol": "NANJ", + "decimals": 8, + "address": "0x868547EB48e0Ed2Fd3dB52Db9818ab9496EA4ef1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xffe02ee4c69edf1b340fcad64fbd6b37a7b9e265" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nanj.svg" + }, + { + "chainId": 137, + "name": "Chai", + "symbol": "CHAI", + "decimals": 18, + "address": "0x4B64399CA6609eBB5CB649eAA50387C2d9fe20eb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x06af07097c9eeb7fd685c692751d5c66db49c215" + } + }, + { + "chainId": 137, + "name": "Litecoin SV", + "symbol": "LSV", + "decimals": 18, + "address": "0xb6d5d0E2baD865750Bc2cB21bBaE636c3BaD6581", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xee059f0ca1507e4e20c689b20cff71b5e924f7bd" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lsv.svg" + }, + { + "chainId": 137, + "name": "simian.finance", + "symbol": "SIFI", + "decimals": 9, + "address": "0x41d36d3bd6297fE288E31C75De8B7453de9Daf90", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4afb0aac9b862946837b2444566b8a914d6d0d97" + } + }, + { + "chainId": 137, + "name": "BTSE Token", + "symbol": "BTSE", + "decimals": 8, + "address": "0xc96a4a6B780AF3a6383962ea0Ac96DD3c40532d4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x666d875c600aa06ac1cf15641361dec3b00432ef" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/btse.svg" + }, + { + "chainId": 137, + "name": "Shungite", + "symbol": "SHUNG", + "decimals": 18, + "address": "0xA3d8885825A843F040eb64A6a846b687cd07F072", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x839b2086ef84f25a07beeb61cd325b79b5e08a5d" + } + }, + { + "chainId": 137, + "name": "PGF500 Token", + "symbol": "PGF7T", + "decimals": 18, + "address": "0xdd0fDc648a9dbC9be5A735FE4561893a13399Da2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9fadea1aff842d407893e21dbd0e2017b4c287b6" + } + }, + { + "chainId": 137, + "name": "MOAR Finance", + "symbol": "MOAR", + "decimals": 18, + "address": "0x34cba1561424b192F263883ba2b8CcBBc12bb13F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x187eff9690e1f1a61d578c7c492296eaab82701a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/moar.svg" + }, + { + "chainId": 137, + "name": "renDOGE", + "symbol": "renDOGE", + "decimals": 8, + "address": "0x7C4A54f5d20b4023D6746F1f765f4DFe7C39a7e6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3832d2f059e55934220881f831be501d180671a7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rendoge.svg" + }, + { + "chainId": 137, + "name": "LADZ", + "symbol": "LADZ", + "decimals": 4, + "address": "0x220ED61d1f1CC754cB71978585D69e07Be576315", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1287c0509df9a475Ef178471aB2132b9dfD312B3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ladz.svg" + }, + { + "chainId": 137, + "name": "Defiville Island Token", + "symbol": "ISLA", + "decimals": 18, + "address": "0xFE6A2342f7C5D234E8496dF12c468Be17e0c181F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x20a68F9e34076b2dc15ce726d7eEbB83b694702d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/isla.svg" + }, + { + "chainId": 137, + "name": "Pinakion", + "symbol": "PNK", + "decimals": 18, + "address": "0xad93E067e149f0A5ecd12D8EA83B05581dD6374C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x93ed3fbe21207ec2e8f2d3c3de6e058cb73bc04d" + } + }, + { + "chainId": 137, + "name": "mushrooming Wrapped BTC", + "symbol": "mWBTC", + "decimals": 8, + "address": "0x652E36ecFA0E4F7e435F6D38688D68a3bE65639c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb06661A221Ab2Ec615531f9632D6Dc5D2984179A" + } + }, + { + "chainId": 137, + "name": "mushrooming 0x Protocol Token", + "symbol": "mZRX", + "decimals": 18, + "address": "0x9cc0FF2Db430cBC95752b25487059046d507780C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x037B39EdAE767EA692884D51fc697c54e777710e" + } + }, + { + "chainId": 137, + "name": "mushrooming Alchemix USD", + "symbol": "malUSD", + "decimals": 18, + "address": "0x6aaF0cd9E0339DC385f566EB2d2Bd83C756E7d63", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5DEDEC994C11aB5F9908f33Aed2947F33B67a449" + } + }, + { + "chainId": 137, + "name": "mushrooming Alchemix", + "symbol": "mALCX", + "decimals": 18, + "address": "0x2bB8ff0B289F1670415713B75331CC927D0C5CEA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x076950237f8c0D27Ac25694c9078F96e535723BC" + } + }, + { + "chainId": 137, + "name": "mushrooming ChainLink Token", + "symbol": "mLINK", + "decimals": 18, + "address": "0x44a57De864dD580c3A1FE44Cfa8E39e25170c156", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3EdeE5F69e9A8F88da9063B1aa78311E38DBE96c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mlink.svg" + }, + { + "chainId": 137, + "name": "mushrooming Uniswap", + "symbol": "mUNI", + "decimals": 18, + "address": "0x65E4Fc43404569998e7cb8E74e785943581f758F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41e0c2A507415e25005b1713f5f68AD6648fCF43" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/muni.svg" + }, + { + "chainId": 137, + "name": "mushrooming USD Coin", + "symbol": "mUSDC", + "decimals": 6, + "address": "0x6998F006c8B5bD288dcb8E00c0060927d517Aa58", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x23B197dc671A55F256199cF7e8Bee77Ea2bDC16D" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/musdc.svg" + }, + { + "chainId": 137, + "name": "mushrooming Dai Stablecoin", + "symbol": "mDAI", + "decimals": 18, + "address": "0x6BAF56F2768434592c2Fcce2dC04235366E5A088", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6802377968857656fE8aE47fBECe76AaE588eeF7" + } + }, + { + "chainId": 137, + "name": "mushrooming Curve DAI/USDC/USDT", + "symbol": "m3Crv", + "decimals": 18, + "address": "0x6E5BCf069213676e4E3C75aEb60Eaab0C41ff1CE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0c0291f4c12F04Da8B4139996C720a89D28Ca069" + } + }, + { + "chainId": 137, + "name": "mushrooming Wrapped Ether", + "symbol": "mWETH", + "decimals": 18, + "address": "0xdc0f3C12dF89593357985491bdAcc5Fd789cA4B2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb0f1a38F5531b398E2081c2F9E61EdD2A924b488" + } + }, + { + "chainId": 137, + "name": "HASHGARD", + "symbol": "GARD", + "decimals": 18, + "address": "0xf89250E83fA2F33058385C98c7c44e723B040359", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5c64031c62061865e5fd0f53d3cdaef80f72e99d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/gard.svg" + }, + { + "chainId": 137, + "name": "blocsport1", + "symbol": "BS1", + "decimals": 18, + "address": "0x2E789b197a1874ca6384082090e0ebed30F16E1A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xAeaf14ce56b052DFC2A2Eb0654136EcF87821fbF" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bs1.svg" + }, + { + "chainId": 137, + "name": "GeoDB Coin", + "symbol": "GEO", + "decimals": 18, + "address": "0xAe07B360cF41C8971F6c544620A6ed428Ff3a661", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x147faF8De9d8D8DAAE129B187F0D02D819126750" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/geo.svg" + }, + { + "chainId": 137, + "name": "Universal Basic Income", + "symbol": "UBI", + "decimals": 18, + "address": "0xFe7FF8b5dfbA93A9EaB7Aee447C3c72990052d93", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xDd1Ad9A21Ce722C151A836373baBe42c868cE9a4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ubi.svg" + }, + { + "chainId": 137, + "name": "Grumpy Cat", + "symbol": "GRUMPY", + "decimals": 9, + "address": "0x733726968Ae55dC58c26dBDc193FEa256a704ba4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x93b2fff814fcaeffb01406e80b4ecd89ca6a021b" + } + }, + { + "chainId": 137, + "name": "YearnSecure", + "symbol": "YSEC", + "decimals": 18, + "address": "0x3D6C5c1a66e7B43342FcA37827B7Faf3bD074dD3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xeea9aE787f3A620072d13b2cdC8cabFFb9c0aB96" + } + }, + { + "chainId": 137, + "name": "Ludus", + "symbol": "LUDUS", + "decimals": 18, + "address": "0xd132d531367D5907d0844988A71B9fAd32D14368", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x03fdcadc09559262f40f5ea61c720278264eb1da" + } + }, + { + "chainId": 137, + "name": "Nexo", + "symbol": "NEXO", + "decimals": 18, + "address": "0x41b3966B4FF7b427969ddf5da3627d6AEAE9a48E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb62132e35a6c13ee1ee0f84dc5d40bad8d815206" + } + }, + { + "chainId": 137, + "name": "Ethix", + "symbol": "ETHIX", + "decimals": 18, + "address": "0x08Bba6ABE87e2a8c226a1C6c0d0E9cae758f82Ec", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfd09911130e6930bf87f2b0554c44f400bd80d3e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ethix.svg" + }, + { + "chainId": 137, + "name": "Beatify", + "symbol": "SONG", + "decimals": 18, + "address": "0x609255414fF5289f87c99bAF9737a4EC85A18643", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xA18A0bE599366C8e2fFfFD83A2418a3cCb825d7f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/song.svg" + }, + { + "chainId": 137, + "name": "Internxt", + "symbol": "INXT", + "decimals": 8, + "address": "0xE64106154816A252da7728E35A0060F15d66cb34", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa8006c4ca56f24d6836727d106349320db7fef82" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/inxt.svg" + }, + { + "chainId": 137, + "name": "Blind Boxes Token", + "symbol": "BLES", + "decimals": 18, + "address": "0x1B599bEB7b1F50807dD58Fd7e8fFcf073b435e71", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe796d6ca1ceb1b022ece5296226bf784110031cd" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bles.svg" + }, + { + "chainId": 137, + "name": "Alchemy", + "symbol": "ALCH", + "decimals": 18, + "address": "0x87B078cf94B188EFB9D2208cAE47A66ea7FEa09A", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0000A1c00009A619684135B824Ba02f7FbF3A572" + } + }, + { + "chainId": 137, + "name": "YOP", + "symbol": "YOP", + "decimals": 8, + "address": "0x103308793661879166464cD0d0370Ac3b8A2A1cB", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xae1eaae3f627aaca434127644371b67b18444051" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/yop.svg" + }, + { + "chainId": 137, + "name": "Darwinia", + "symbol": "Ring", + "decimals": 18, + "address": "0x9C1C23E60B72Bc88a043bf64aFdb16A02540Ae8f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9469d013805bffb7d3debe5e7839237e535ec483" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ring.svg" + }, + { + "chainId": 137, + "name": "Gala", + "symbol": "GALA", + "decimals": 8, + "address": "0x09E1943Dd2A4e82032773594f50CF54453000b97", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x15D4c048F83bd7e37d49eA4C83a07267Ec4203dA" + } + }, + { + "chainId": 137, + "name": "Rocket Pool", + "symbol": "RPL", + "decimals": 18, + "address": "0x7205705771547cF79201111B4bd8aaF29467b9eC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb4efd85c19999d84251304bda99e90b92300bd93" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rpl.svg" + }, + { + "chainId": 137, + "name": "VGTGToken", + "symbol": "VGTG", + "decimals": 18, + "address": "0x0c5EBeD5cB5BD838BDc43E1583D9d054f3d7Be6c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe61eecfdba2ad1669cee138f1919d08ced070b83" + } + }, + { + "chainId": 137, + "name": "IceToken", + "symbol": "ICE", + "decimals": 18, + "address": "0xdF00c50a3daE240860F57b77508203B8D9593283", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf16e81dce15b08f326220742020379b855b87df9" + }, + "logoURI": "https://etherscan.io/token/images/popsiclefinance_32.png" + }, + { + "chainId": 137, + "name": "Meliora", + "symbol": "MORA", + "decimals": 18, + "address": "0x164fBeF6729c86B0fd719789D2f985AFa15a4430", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb64cD4F56043F8d80691433e395d08B1bEBDADF0" + } + }, + { + "chainId": 137, + "name": "Polkalokr", + "symbol": "LKR", + "decimals": 18, + "address": "0x6f83Ffedfd8774d09329D92bF3647654Ee171dfA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x80ce3027a70e0a928d9268994e9b85d03bd4cdcf" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lkr.svg" + }, + { + "chainId": 137, + "name": "LABS Group", + "symbol": "LABS", + "decimals": 18, + "address": "0xb3658a5493332e952Fc86991c24C9c759d2D8cD0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8b0e42f366ba502d787bb134478adfae966c8798" + } + }, + { + "chainId": 137, + "name": "OnX.finance", + "symbol": "ONX", + "decimals": 18, + "address": "0xEb94A5e2C643403E29fa1d7197e7E0708B09aD84", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe0ad1806fd3e7edf6ff52fdb822432e847411033" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/onx.svg" + }, + { + "chainId": 137, + "name": "King Token", + "symbol": "KING", + "decimals": 18, + "address": "0xC7bd6b9a83C2e27a17026Aa2DEE03E0EAC97EE50", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc46321EfE8883D22D81eD65CB4F0766e1004129d" + } + }, + { + "chainId": 137, + "name": "TAIYAKI", + "symbol": "TAIYAKI", + "decimals": 18, + "address": "0x1A5C71dDF3d71CBB0C0Bc312ff712a52cBe29cD2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4f9f3504d6C3670672692fcbCaeb409B0cFb40b2" + } + }, + { + "chainId": 137, + "name": "Deeper Network", + "symbol": "DPR", + "decimals": 18, + "address": "0x3C27F2D0744DA4f96D9AB5f4212d8162c031dEA9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf3ae5d769e153ef72b4e3591ac004e89f48107a1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dpr.svg" + }, + { + "chainId": 137, + "name": "xToken", + "symbol": "XTK", + "decimals": 18, + "address": "0x22308317A4aA9e8196065E0b3647e582d44c4d7b", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7f3edcdd180dbe4819bd98fee8929b5cedb3adeb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/xtk.svg" + }, + { + "chainId": 137, + "name": "LinkPool", + "symbol": "LPL", + "decimals": 18, + "address": "0x7e85E6b00a8e9c757f2Fef60d047B6f787c66a1E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x99295f1141d58a99e939f7be6bbe734916a875b8" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lpl.svg" + }, + { + "chainId": 137, + "name": "dHedge DAO Token", + "symbol": "DHT", + "decimals": 18, + "address": "0x8C92e38eCA8210f4fcBf17F0951b198Dd7668292", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xca1207647ff814039530d7d35df0e1dd2e91fa84" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dht.svg" + }, + { + "chainId": 137, + "name": "MEE Token", + "symbol": "MEE", + "decimals": 18, + "address": "0xF4cbD4a7143E221eb983d292C0D13275f12C8172", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe1b583dc66e0a24fd9af2dc665f6f5e48978e106" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mee.svg" + }, + { + "chainId": 137, + "name": "FOAM Token", + "symbol": "FOAM", + "decimals": 18, + "address": "0x66e16D50c07A01BB473eC794349d45aa1a0E5Dc2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4946Fcea7C692606e8908002e55A582af44AC121" + } + }, + { + "chainId": 137, + "name": "CocktailBar", + "symbol": "COC", + "decimals": 8, + "address": "0xF2cEd5F137e27f68E6A01Cc6C4198729e200e457", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x22b6c31c2beb8f2d0d5373146eed41ab9ede3caf" + } + }, + { + "chainId": 137, + "name": "AMPnet APX Token", + "symbol": "AAPX", + "decimals": 18, + "address": "0x3fC8bd9b0d8054CBDC174c4ed4b41A95d3c6A427", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbfd815347d024f449886c171f78fa5b8e6790811" + } + }, + { + "chainId": 137, + "name": "UpBots", + "symbol": "UBXT", + "decimals": 18, + "address": "0xDD24E07c3C840ae6435e7C9F98E6eE6ce168D788", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8564653879a18c560e7c0ea0e084c516c62f5653" + } + }, + { + "chainId": 137, + "name": "SAND", + "symbol": "SAND", + "decimals": 18, + "address": "0xBbba073C31bF03b8ACf7c28EF0738DeCF3695683", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3845badAde8e6dFF049820680d1F14bD3903a5d0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sand.svg" + }, + { + "chainId": 137, + "name": "Darwinia Commitment Token", + "symbol": "KTON", + "decimals": 18, + "address": "0xE21b9bDA4ECeF9e4652BC5C6863F731C2151Ef28", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9f284e1337a815fe77d2ff4ae46544645b20c5ff" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/kton.svg" + }, + { + "chainId": 137, + "name": "Exeedme", + "symbol": "XED", + "decimals": 18, + "address": "0x2fe8733dcb25BFbbA79292294347415417510067", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xee573a945b01b788b9287ce062a0cfc15be9fd86" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/xed.svg" + }, + { + "chainId": 137, + "name": "unilock.network", + "symbol": "UNL", + "decimals": 18, + "address": "0x7Dd51d62CA7C94664111eee95B38dffDA14d582d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x04ab43d32d0172c76f5287b6619f0aa50af89303" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/unl.svg" + }, + { + "chainId": 137, + "name": " SPACE HOGE", + "symbol": "SOGE", + "decimals": 18, + "address": "0xe38eb5a707d9A09757246DC37dF11b35E47ba782", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x41933422dc4a1cb8c822e06f12f7b52fa5e7e094" + } + }, + { + "chainId": 137, + "name": "Rubaled", + "symbol": "RUB", + "decimals": 18, + "address": "0x0E622E0e97B88824C655A0443e69416c3233a522", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdc28699481502339560e984d47278e49f4153a26" + } + }, + { + "chainId": 137, + "name": "ZILLAPUMP", + "symbol": "ZPUMP", + "decimals": 9, + "address": "0x408A67a0A01281cFb96dD18EbbfdDDEc9CB028b7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4cA60BfF981785d9B6Cf3433914eEff60d5d8cD8" + } + }, + { + "chainId": 137, + "name": "froge.finance", + "symbol": "FROGE", + "decimals": 9, + "address": "0x37Ff2a6cF0E8061CBD9a00919690F1B0A46eE674", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x29502fE4d233EF0b45C3647101Fa1252cE0634BD" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/froge.svg" + }, + { + "chainId": 137, + "name": "Axion", + "symbol": "AXN", + "decimals": 18, + "address": "0x221afaC78D2725D090499b973bB42FC93CCA2ef5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x71F85B2E46976bD21302B64329868fd15eb0D127" + } + }, + { + "chainId": 137, + "name": "Kattana", + "symbol": "KTN", + "decimals": 18, + "address": "0x2C7A7358E60f2D145FaC48C71950A2C523636075", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x491e136ff7ff03e6ab097e54734697bb5802fc1c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ktn.svg" + }, + { + "chainId": 137, + "name": "NFT WARS", + "symbol": "WAR", + "decimals": 18, + "address": "0x7F2841A5C7e69e921897fBfbCE95caEa34634A35", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4d75d9e37667a2d4677ec3d74bdd9049326ad8d6" + } + }, + { + "chainId": 137, + "name": "GAMEE", + "symbol": "GMEE", + "decimals": 18, + "address": "0xcf32822ff397Ef82425153a9dcb726E5fF61DCA7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd9016a907dc0ecfa3ca425ab20b6b785b42f2373" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/gmee.svg" + }, + { + "chainId": 137, + "name": "BAB", + "symbol": "BAB", + "decimals": 18, + "address": "0x37C6656CD3882A422d87bD15aC547c5515C0Df1C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc36824905dff2eaaee7ecc09fcc63abc0af5abc5" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bab.svg" + }, + { + "chainId": 137, + "name": "BAC", + "symbol": "BAC", + "decimals": 18, + "address": "0xcdE5E3D90631cacB842fA86f62dD0fc08A3ce43d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3449fc1cd036255ba1eb19d65ff4ba2b8903a69a" + } + }, + { + "chainId": 137, + "name": "BASv2", + "symbol": "BASv2", + "decimals": 18, + "address": "0x83A6DA342099835bCAA9C219DD76a5033c837de5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x106538cc16f938776c7c180186975bca23875287" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/basv2.svg" + }, + { + "chainId": 137, + "name": "CehhCoin", + "symbol": "CEHH", + "decimals": 0, + "address": "0xA6D996AFdBC613A5C5FC92bbAeFbC7b827419e8f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4F38f4229924bfa28D58eeda496Cc85e8016bCCC" + } + }, + { + "chainId": 137, + "name": "CheGuevara", + "symbol": "Che", + "decimals": 18, + "address": "0x365AE1c67b3efA55C624c9705Ad1Df2072D3d254", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x25a1DE1C3eE658FE034B8914a1D8d34110423AF8" + } + }, + { + "chainId": 137, + "name": "HotLove", + "symbol": "HL", + "decimals": 18, + "address": "0xe947283361D0D47c870c0898d7a5578310E1dB37", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xDfF991Af459d05175B3bb766b950aFC697B68dF0" + } + }, + { + "chainId": 137, + "name": "Penis", + "symbol": "PNS", + "decimals": 2, + "address": "0xE63E303460e078c2DEAF9Cd3CB46ECA0C8cb1B59", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xce853db3359326dB6D03981C9fb42983BbCdd007" + } + }, + { + "chainId": 137, + "name": "YiYouBao", + "symbol": "YYB", + "decimals": 18, + "address": "0x1656484C36cEF1B24cD49457470AbcE90C480d29", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x85993bE4EF5BEc00B62BA7e46a8a70f353182b3e" + } + }, + { + "chainId": 137, + "name": "YunJiaMi", + "symbol": "YJM", + "decimals": 18, + "address": "0x223097da39Cb07fA133d70cD820f27867b4452c3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x27BC53596Dc0EA71dE3c65C799d8E6c96C1dDA98" + } + }, + { + "chainId": 137, + "name": "IgnisLite", + "symbol": "IgnisLite", + "decimals": 18, + "address": "0xEbBB74174D1a22729B9a9cddb28c18cA07BE0314", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9AA9F330aB322e8a6F044C46a109B5910fa373CE" + } + }, + { + "chainId": 137, + "name": "360APP", + "symbol": "DAPP", + "decimals": 18, + "address": "0x24274DE25578F97984f66Be0Cc0762138757C935", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5D0fa08AEb173AdE44B0Cf7F31d506D8E04f0ac8" + } + }, + { + "chainId": 137, + "name": "Wootrade Network", + "symbol": "WOO", + "decimals": 18, + "address": "0x1B815d120B3eF02039Ee11dC2d33DE7aA4a8C603", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4691937a7508860f876c9c0a2a617e7d9e945d4b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/woo.svg" + }, + { + "chainId": 137, + "name": "BoringDAO LTC", + "symbol": "oLTC", + "decimals": 18, + "address": "0xf9f8D3BcAD8958ffef131bAb376CFfAc0d16551B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x07C44B5Ac257C2255AA0933112c3b75A6BFf3Cb1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/oltc.svg" + }, + { + "chainId": 137, + "name": "BoringDAO BTC", + "symbol": "oBTC", + "decimals": 18, + "address": "0x90fB380DdEbAF872cc1F8d8e8C604Ff2f4697c19", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8064d9Ae6cDf087b1bcd5BDf3531bD5d8C537a68" + } + }, + { + "chainId": 137, + "name": "UmbriaToken", + "symbol": "UMBR", + "decimals": 18, + "address": "0x2e4b0Fb46a46C90CB410FE676f24E466753B469f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa4bbe66f151b22b167127c770016b15ff97dd35c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/umbr.svg" + }, + { + "chainId": 137, + "name": "Zilliqa", + "symbol": "ZIL", + "decimals": 12, + "address": "0x1e2231DB2DBEdD0FAC3eB70608d402E80F244C6D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x05f4a42e251f2d52b8ed15e9fedaacfcef1fad27" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/zil.svg" + }, + { + "chainId": 137, + "name": "SOCIALBI DEFI", + "symbol": "SBI", + "decimals": 18, + "address": "0x179a16D33E4c08Dd773B002f475ca36Ce22Fa169", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x03F2892669D00BFFB6C5F317106f7E89213894aF" + } + }, + { + "chainId": 137, + "name": "Corn", + "symbol": "CORN", + "decimals": 18, + "address": "0xA5C09Ba00f342F61F637e1A88F1Bd7EbaCf5BE48", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3CD1833Ce959E087D0eF0Cb45ed06BffE60F23Ba" + } + }, + { + "chainId": 137, + "name": "Land", + "symbol": "LAND", + "decimals": 18, + "address": "0xAd230ec33ccf849C2bBd8D26C1706DB07b24Db95", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3258cd8134b6b28e814772dd91d5ecceea512818" + } + }, + { + "chainId": 137, + "name": "RougeCoin", + "symbol": "XRGE", + "decimals": 18, + "address": "0x642F7511a68c57faE8AC0CAa618673a66166e4c7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa1c7d450130bb77c6a23ddfaecbc4a060215384b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/xrge.svg" + }, + { + "chainId": 137, + "name": "AIOZ Network", + "symbol": "AIOZ", + "decimals": 18, + "address": "0xe2341718c6C0CbFa8e6686102DD8FbF4047a9e9B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x626e8036deb333b408be468f951bdb42433cbf18" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/aioz.svg" + }, + { + "chainId": 137, + "name": "Work Quest Token", + "symbol": "WQT", + "decimals": 18, + "address": "0x4349D5464203F1Da44513C1fEAb502839e69DBF8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x06677dc4fe12d3ba3c7ccfd0df8cd45e4d4095bf" + } + }, + { + "chainId": 137, + "name": "SPLYT SHOPX", + "symbol": "SHOPX", + "decimals": 18, + "address": "0x7886A4EBDda9f1861d6a081cD794b3e79c375011", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7bef710a5759d197ec0bf621c3df802c2d60d848" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/shopx.svg" + }, + { + "chainId": 137, + "name": "UnFederalReserveToken", + "symbol": "eRSDL", + "decimals": 18, + "address": "0x5095cC6511B70e287bc525Aa57AfbC60EB73ac47", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5218e472cfcfe0b64a064f055b43b4cdc9efd3a6" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ersdl.svg" + }, + { + "chainId": 137, + "name": "KardiaChain Token", + "symbol": "KAI", + "decimals": 18, + "address": "0x32ef6DcB27Ae8697E217fe3594D665535B176721", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd9ec3ff1f8be459bb9369b4e79e9ebcf7141c093" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/kai.svg" + }, + { + "chainId": 137, + "name": "MobiFi", + "symbol": "MoFi", + "decimals": 18, + "address": "0xF689E85988d3a7921E852867CE49F53388985E6d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb2dbf14d0b47ed3ba02bdb7c954e05a72deb7544" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mofi.svg" + }, + { + "chainId": 137, + "name": "DAFI Token", + "symbol": "DAFI", + "decimals": 18, + "address": "0x638Df98Ad8069a15569dA5a6b01181804c47e34c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfc979087305a826c2b2a0056cfaba50aad3e6439" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dafi.svg" + }, + { + "chainId": 137, + "name": "Cardstack", + "symbol": "CARD", + "decimals": 18, + "address": "0x3A4BeD49Ab592A227bAe8F41eFd0d38E6e06d96c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x954b890704693af242613edef1b603825afcd708" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/card.svg" + }, + { + "chainId": 137, + "name": "Kylin Network", + "symbol": "KYL", + "decimals": 18, + "address": "0x9ccdf331f97449A84D100918e1e233B097A3E13F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x67b6d479c7bb412c54e03dca8e1bc6740ce6b99c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/kyl.svg" + }, + { + "chainId": 137, + "name": "Gains V2", + "symbol": "GFARM2", + "decimals": 18, + "address": "0x7075cAB6bCCA06613e2d071bd918D1a0241379E2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x831091dA075665168E01898c6DAC004A867f1e1B" + } + }, + { + "chainId": 137, + "name": "DeFi11", + "symbol": "D11", + "decimals": 18, + "address": "0xc58158c14D4757EF36Ce25e493758F2fcEEDec5D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9bf02cF6B0435A0523E6f6e0D2f35A920144F5FA" + } + }, + { + "chainId": 137, + "name": "CHONKER FINANCE", + "symbol": "CHONK", + "decimals": 18, + "address": "0xc059a4777279E30C5238Da786384700cD14d8f47", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x84679bc467DC6c2c40ab04538813AfF3796351f1" + } + }, + { + "chainId": 137, + "name": "Convergence", + "symbol": "CONV", + "decimals": 18, + "address": "0x95Bbe8fbD32088bC13E67b05c7E783AD6CA854D8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc834fa996fa3bec7aad3693af486ae53d8aa8b50" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/conv.svg" + }, + { + "chainId": 137, + "name": "BoughtThe.top", + "symbol": "BTT", + "decimals": 18, + "address": "0x04AE4aE7F9af802DE5A2Da9561948F6f24D4b043", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x910aCE1b34df96c8EAd1088F279FE114bE301286" + } + }, + { + "chainId": 137, + "name": "DxSale.Network", + "symbol": "SALE", + "decimals": 18, + "address": "0x8f6196901a4a153d8eE8F3fa779A042F6092D908", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF063fE1aB7a291c5d06a86e14730b00BF24cB589" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sale.svg" + }, + { + "chainId": 137, + "name": "wMBX Token", + "symbol": "wMBX", + "decimals": 18, + "address": "0x6181dEdD5D6aa117716cc385A0184C709b1263F3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x71ba91dc68c6a206db0a6a92b4b1de3f9271432d" + } + }, + { + "chainId": 137, + "name": "BaoToken", + "symbol": "BAO", + "decimals": 18, + "address": "0xc81278a52AD0e1485B7C3cDF79079220Ddd68b7D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x374cb8c27130e2c9e04f44303f3c8351b9de61c1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bao.svg" + }, + { + "chainId": 137, + "name": "Wrapped Gen 0", + "symbol": "WG0", + "decimals": 18, + "address": "0xbD18f2909A2B55637007fA273069febe9DAb8664", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa10740ff9ff6852eac84cdcff9184e1d6d27c057" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wg0.svg" + }, + { + "chainId": 137, + "name": "Paypolitan Token", + "symbol": "EPAN", + "decimals": 18, + "address": "0x6B4E056B0A2c7d967728B0d0329A61b746B04cd8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x72630B1e3B42874bf335020Ba0249e3E9e47Bafc" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/epan.svg" + }, + { + "chainId": 137, + "name": "POLVEN", + "symbol": "POLVEN", + "decimals": 18, + "address": "0x1109C91F24F1E485f7c04d286C12B7F709e89a16", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4a6ab9792e9f046c3ab22d8602450de5186be9a7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/polven.svg" + }, + { + "chainId": 137, + "name": "SOAR.FI", + "symbol": "SOAR", + "decimals": 9, + "address": "0xfdc99999c4139F953A3Af41dE986687275bD4F4B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbae5f2d8a1299e5c4963eaff3312399253f27ccb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/soar.svg" + }, + { + "chainId": 137, + "name": "SharedStake Governance Token", + "symbol": "SGT", + "decimals": 18, + "address": "0xDd418748FeCfc870b7322b1D11402814f5ee55Ab", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x84810bcf08744d5862b8181f12d17bfd57d3b078" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sgt.svg" + }, + { + "chainId": 137, + "name": "GraphLinq", + "symbol": "GLQ", + "decimals": 18, + "address": "0x0CfC9a713A5C17Bc8a5fF0379467f6558bAcD0e0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9f9c8ec3534c3ce16f928381372bfbfbfb9f4d24" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/glq.svg" + }, + { + "chainId": 137, + "name": "StakeWise Reward ETH2", + "symbol": "rETH2", + "decimals": 18, + "address": "0xDEcE9bD4A6f4CABa2f71A8af6CbF0952758f8B36", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x20bc832ca081b91433ff6c17f85701b6e92486c5" + } + }, + { + "chainId": 137, + "name": "StakeWise Staked ETH2", + "symbol": "sETH2", + "decimals": 18, + "address": "0xfd08e84075C8B46faaA5629eDd044effD0A597ac", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfe2e637202056d30016725477c5da089ab0a043a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/seth2.svg" + }, + { + "chainId": 137, + "name": "Kagra", + "symbol": "KGR", + "decimals": 18, + "address": "0xc4ec74F50dd4A9ae7268898B3292DEcEf8Eda226", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe445e067Cb17b62b15f4883B66b69E05eA7b327d" + } + }, + { + "chainId": 137, + "name": "RAGEMATIC", + "symbol": "RAGE", + "decimals": 18, + "address": "0x40CCD55B789fdEE8D434915dC2Aa6Bd938506A92", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x94804dc4948184fFd7355f62Ccbb221c9765886F" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rage.svg" + }, + { + "chainId": 137, + "name": "xHDX", + "symbol": "xHDX", + "decimals": 12, + "address": "0xe8388f307caa9c338955465f0AE2aA4c3E023Dd8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6fcb6408499a7c0f242e32d77eb51ffa1dd28a7e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/xhdx.svg" + }, + { + "chainId": 137, + "name": "Stater", + "symbol": "STR", + "decimals": 18, + "address": "0xA79E0Bfc579c709819f4A0E95d4597f03093B011", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x84bb947fcedba6b9c7dcead42df07e113bb03007" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/str.svg" + }, + { + "chainId": 137, + "name": "santa.investments", + "symbol": "SANTA", + "decimals": 0, + "address": "0x0aB8B5304c07Bb29514dAd43AdBA7A44C67b0506", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x499a7e6ddaf01de4c309f22933a1c38cbb44a1d4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/santa.svg" + }, + { + "chainId": 137, + "name": "Pluton", + "symbol": "PLU", + "decimals": 18, + "address": "0x7dc0cb65EC6019330a6841e9c274f2EE57A6CA6C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xD8912C10681D8B21Fd3742244f44658dBA12264E" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/plu.svg" + }, + { + "chainId": 137, + "name": "Armor", + "symbol": "ARMOR", + "decimals": 18, + "address": "0x5de4005155933c0e1612Ce808f12B4cd8DAabc82", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1337def16f9b486faed0293eb623dc8395dfe46a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/armor.svg" + }, + { + "chainId": 137, + "name": "NFT Platform Index", + "symbol": "NFTP", + "decimals": 18, + "address": "0xf7d9e281c5Cb4C6796284C5b663b3593D2037aF2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x68bb81b3f67f7aab5fd1390ecb0b8e1a806f2465" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nftp.svg" + }, + { + "chainId": 137, + "name": "Strudel BTC", + "symbol": "VBTC", + "decimals": 18, + "address": "0x1489F4F7E3a80A0aD9fA23C39D2E8af818204ce9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe1406825186d63980fd6e2ec61888f7b91c4bae4" + } + }, + { + "chainId": 137, + "name": "Frontier Token", + "symbol": "FRONT", + "decimals": 18, + "address": "0xa3eD22EEE92a3872709823a6970069e12A4540Eb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf8C3527CC04340b208C854E985240c02F7B7793f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/front.svg" + }, + { + "chainId": 137, + "name": "YAM", + "symbol": "YAM", + "decimals": 18, + "address": "0xb3B681dEE0435eCc0a508e40B02b3C9068D618cd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0aacfbec6a24756c20d41914f2caba817c0d8521" + } + }, + { + "chainId": 137, + "name": "NIL Token", + "symbol": "NIL", + "decimals": 9, + "address": "0x6374fce99CF93A8f07728c4ADF2991b0f5E50F45", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7DEb93314090837fb33bB9a30D62C459BDFdc661" + } + }, + { + "chainId": 137, + "name": "Havens Nook", + "symbol": "HXN", + "decimals": 18, + "address": "0x175Bdc4e52EECB675B86FC4C9A3Ea3f80adBb610", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0E1fe60bc4aC0e3102343752ae7E49d01d444c0b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hxn.svg" + }, + { + "chainId": 137, + "name": "Staked SDT", + "symbol": "xSDT", + "decimals": 18, + "address": "0xD921F8318cfd786baB1ea7492673F053c518Ac04", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaC14864ce5A98aF3248Ffbf549441b04421247D3" + } + }, + { + "chainId": 137, + "name": "Flowing Hair", + "symbol": "FGH", + "decimals": 18, + "address": "0xb8E5b39689f886f8C34D3E5ac09F513A282d486D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3ec03cD2763A729339AFf9927BE679c76325D1bf" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/fgh.svg" + }, + { + "chainId": 137, + "name": "Premia", + "symbol": "PREMIA", + "decimals": 18, + "address": "0x055dC5c3b7c386f2daefEc554bB42831fB4107Be", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6399c842dd2be3de30bf99bc7d1bbf6fa3650e70" + } + }, + { + "chainId": 137, + "name": "LCX", + "symbol": "LCX", + "decimals": 18, + "address": "0xE8A51D0dD1b4525189ddA2187F90ddF0932b5482", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x037a54aab062628c9bbae1fdb1583c195585fe41" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lcx.svg" + }, + { + "chainId": 137, + "name": "kongdefi.finance", + "symbol": "KONG", + "decimals": 9, + "address": "0x9ECf85badEbd3ecF6eF79db44bB59519Cbd21d82", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7c3cf2d43b50e78e27a81293a43fcac45796fb54" + } + }, + { + "chainId": 137, + "name": "E-RADIX", + "symbol": "eXRD", + "decimals": 18, + "address": "0x56B1c1e028c2E0a8852906E1eE7730ED67A3D9Bb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6468e79a80c0eab0f9a2b574c8d5bc374af59414" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/exrd.svg" + }, + { + "chainId": 137, + "name": "Wise Token", + "symbol": "WISE", + "decimals": 18, + "address": "0xB77e62709e39aD1cbeEBE77cF493745AeC0F453a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x66a0f676479Cee1d7373f3DC2e2952778BfF5bd6" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wise.svg" + }, + { + "chainId": 137, + "name": "Glitch", + "symbol": "GLCH", + "decimals": 18, + "address": "0xbE5cf150E1fF59ca7F2499Eaa13BFC40AAE70e78", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x038a68FF68c393373eC894015816e33Ad41BD564" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/glch.svg" + }, + { + "chainId": 137, + "name": "Marblecoin", + "symbol": "MBC", + "decimals": 18, + "address": "0xcBB2Da0127042546cEfF56da69fAF3f2ba6d1C51", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8888889213dd4da823ebdd1e235b09590633c150" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mbc.svg" + }, + { + "chainId": 137, + "name": "AnRKey X", + "symbol": "$ANRX", + "decimals": 18, + "address": "0x554f074d9cCda8F483d1812d4874cBebD682644E", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xCae72A7A0Fd9046cf6b165CA54c9e3a3872109E0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/$anrx.svg" + }, + { + "chainId": 137, + "name": "FingerPrint", + "symbol": "FGP", + "decimals": 18, + "address": "0x8b62011D9e73922Ac5eF6d30A82588cB33F98055", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd9a8cfe21c232d485065cb62a96866799d4645f7" + } + }, + { + "chainId": 137, + "name": "UniMex", + "symbol": "UMX", + "decimals": 18, + "address": "0x5dF1a47e05b4caBa0ED3Df13662642f05314764D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x10Be9a8dAe441d276a5027936c3aADEd2d82bC15" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/umx.svg" + }, + { + "chainId": 137, + "name": "SnowSwap", + "symbol": "SNOW", + "decimals": 18, + "address": "0x33c9f7C0Afe2722cb9e426360C261fB755B4483d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfe9a29ab92522d14fc65880d817214261d8479ae" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/snow.svg" + }, + { + "chainId": 137, + "name": "SifChain (erowan)", + "symbol": "EROWAN", + "decimals": 18, + "address": "0xa7051C5a22d963b81D71C2BA64D46a877fBc1821", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x07bac35846e5ed502aa91adf6a9e7aa210f2dcbe" + } + }, + { + "chainId": 137, + "name": "ALOHA", + "symbol": "ALOHA", + "decimals": 18, + "address": "0x60AC2E84078Ce30CBC68e3d7b18bCF613271ce6B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x455f7ef6d8bcfc35f9337e85aee1b0600a59fabe" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/aloha.svg" + }, + { + "chainId": 137, + "name": "PolkaFoundry", + "symbol": "PKF", + "decimals": 18, + "address": "0x3d32a7Dc8B0C62A73639BF0D4FE8D229a2431EC8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8b39b70e39aa811b69365398e0aace9bee238aeb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pkf.svg" + }, + { + "chainId": 137, + "name": "Green Token", + "symbol": "GREEN", + "decimals": 8, + "address": "0x8A4001fD666BE272605c56BB956d11A46200Db81", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5e68801A5dDA8671051006eb2920FfE9Cd553544" + } + }, + { + "chainId": 137, + "name": "KEY Token", + "symbol": "KEY", + "decimals": 0, + "address": "0x03bb597efd7Bb986222aFdA80858F05a3BC4A2E9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf179597937d04ed22bea98745b667d2ccfc74f9d" + } + }, + { + "chainId": 137, + "name": "Opium Governance Token", + "symbol": "OPIUM", + "decimals": 18, + "address": "0xE8F157E041Df3B28151B667364e9c90789Da7923", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x888888888889c00c67689029d7856aac1065ec11" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/opium.svg" + }, + { + "chainId": 137, + "name": "MAXXToken.com", + "symbol": "MAXX", + "decimals": 18, + "address": "0x41B3Fc2302C8aAc4C84c552f770419091EF52435", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x57641b7250f153020a33037845f63ff23a090d17" + } + }, + { + "chainId": 137, + "name": "ICOStart Token", + "symbol": "ICH", + "decimals": 18, + "address": "0xb257De22059cd200e34139d27CE0e415E173cE49", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x330839ef82d34801bd96e75a4ee778ac56fa1ed8" + } + }, + { + "chainId": 137, + "name": "DexKit", + "symbol": "KIT", + "decimals": 18, + "address": "0x4D0Def42Cf57D6f27CD4983042a55dce1C9F853c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7866e48c74cbfb8183cd1a929cd9b95a7a5cb4f4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/kit.svg" + }, + { + "chainId": 137, + "name": "VISOR", + "symbol": "VISR", + "decimals": 18, + "address": "0xB090B6310970DD028a007981a24C1a492568a816", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf938424f7210f31df2aee3011291b658f872e91e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/visr.svg" + }, + { + "chainId": 137, + "name": "Cellframe Token", + "symbol": "CELL", + "decimals": 18, + "address": "0x1D545D7ff917e08D7Bf26320343b16BdF51FdBb6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x26c8afbbfe1ebaca03c2bb082e69d0476bffe099" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cell.svg" + }, + { + "chainId": 137, + "name": "MUAN", + "symbol": "MUA", + "decimals": 18, + "address": "0xdfeEB5661ef760A1c565Caf07A50aCa182EaFceE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD7F8032777C50aFD2e7AFa41912a4d8038127271" + } + }, + { + "chainId": 137, + "name": "Alchemix", + "symbol": "ALCX", + "decimals": 18, + "address": "0x95c300e7740D2A88a44124B424bFC1cB2F9c3b89", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdbdb4d16eda451d0503b854cf79d55697f90c8df" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/alcx.svg" + }, + { + "chainId": 137, + "name": "YfDAI.finance", + "symbol": "Yf-DAI", + "decimals": 18, + "address": "0x7E7fF932FAb08A0af569f93Ce65e7b8b23698Ad8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf4cd3d3fda8d7fd6c5a500203e38640a70bf9577" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/yf-dai.svg" + }, + { + "chainId": 137, + "name": "Cryptocurrency Top Tokens Index", + "symbol": "CC10", + "decimals": 18, + "address": "0x9c49BA0212Bb5Db371e66b59D1565b7c06E4894e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x17ac188e09a7890a1844e5e65471fe8b0ccfadf3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cc10.svg" + }, + { + "chainId": 137, + "name": "Orient", + "symbol": "OFT", + "decimals": 18, + "address": "0x8CA5ed20346c5d8a21A849d59c64f0884a532882", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc0A25a24CcE412E2Fb407c08E3785437FEE9Ad1d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/oft.svg" + }, + { + "chainId": 137, + "name": "Ethernity Chain", + "symbol": "ERN", + "decimals": 18, + "address": "0x0E50BEA95Fe001A370A4F1C220C49AEdCB982DeC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbbc2ae13b23d715c30720f079fcd9b4a74093505" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ern.svg" + }, + { + "chainId": 137, + "name": "REN", + "symbol": "REN", + "decimals": 18, + "address": "0x19782D3Dc4701cEeeDcD90f0993f0A9126ed89d0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x408e41876cccdc0f92210600ef50372656052a38" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ren.svg" + }, + { + "chainId": 137, + "name": "HOLO", + "symbol": "HOT", + "decimals": 18, + "address": "0x0C51f415cF478f8D08c246a6C6Ee180C5dC3A012", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6c6ee5e31d828de241282b9606c8e98ea48526e2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hot.svg" + }, + { + "chainId": 137, + "name": "ADD.XYZ", + "symbol": "ADD", + "decimals": 18, + "address": "0xfA15611AA3775FBfE1375Fb56cd3027F5D3DD2Db", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x635d081fd8f6670135d8a3640e2cf78220787d56" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/add.svg" + }, + { + "chainId": 137, + "name": "CherryBlossom", + "symbol": "CBL", + "decimals": 18, + "address": "0xf35a85C493c49f19bCC176E718865b148958a130", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf0acc6f66ac9b9b563f20e2347e67e1fd523ec1a" + } + }, + { + "chainId": 137, + "name": "MultiVAC", + "symbol": "MTV", + "decimals": 18, + "address": "0x885b6e6DBb84148f98c806800Bc19c9A9DB4cFeb", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6226e00bcac68b0fe55583b90a1d727c14fab77f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mtv.svg" + }, + { + "chainId": 137, + "name": "Wrapped Wagerr", + "symbol": "WWGR", + "decimals": 8, + "address": "0x157B28E46F301c596668A4B85C59f710F9C4BBAA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc237868a9c5729bdf3173dddacaa336a0a5bb6e0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wwgr.svg" + }, + { + "chainId": 137, + "name": "CHZ", + "symbol": "CHZ", + "decimals": 18, + "address": "0xf1938Ce12400f9a761084E7A80d37e732a4dA056", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3506424f91fd33084466f402d5d97f05f8e3b4af" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/chz.svg" + }, + { + "chainId": 137, + "name": "NodeRunners", + "symbol": "NDR", + "decimals": 18, + "address": "0xfb65ef42F7c8A70ff73F627DB6E9ba2Aff1F20fa", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x739763a258640919981f9ba610ae65492455be53" + } + }, + { + "chainId": 137, + "name": "Monavale", + "symbol": "MONA", + "decimals": 18, + "address": "0x6968105460f67c3BF751bE7C15f92F5286Fd0CE5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x275f5Ad03be0Fa221B4C6649B8AeE09a42D9412A" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mona.svg" + }, + { + "chainId": 137, + "name": "DOVU", + "symbol": "DOV", + "decimals": 18, + "address": "0x0E0ffc562d72316b783E887bbAAe1FD794ADb530", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xac3211a5025414af2866ff09c23fc18bc97e79b1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dov.svg" + }, + { + "chainId": 137, + "name": "Value USD", + "symbol": "USDV", + "decimals": 18, + "address": "0x55bCbEAB7b9daDaDb0b2E97C354357c58a052d88", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xA62CfAf94A42E1D9b70241840BFDad76C15B2b24" + } + }, + { + "chainId": 137, + "name": "Hakka Finance", + "symbol": "HAKKA", + "decimals": 18, + "address": "0xD893dde7346cc0aB46dc7EA468AeB69D9BF087c5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0e29e5abbb5fd88e28b2d355774e73bd47de3bcd" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hakka.svg" + }, + { + "chainId": 137, + "name": "STASIS EURS Token", + "symbol": "EURS", + "decimals": 2, + "address": "0xE111178A87A3BFf0c8d18DECBa5798827539Ae99", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdb25f211ab05b1c97d595516f45794528a807ad8" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/eurs.svg" + }, + { + "chainId": 137, + "name": "stake dao Curve.fi renBTC/wBTC/sBTC", + "symbol": "sdcrvRenWSBTC", + "decimals": 18, + "address": "0xe212f92E5Af85268B33D2Aa587B51f49C3B945Be", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x24129b935aff071c4f0554882c0d9573f4975fed" + } + }, + { + "chainId": 137, + "name": "stake dao Curve.fi EURS/sEUR", + "symbol": "sdeursCRV", + "decimals": 18, + "address": "0xfBdb45075Fb73ca4CC8b83FD6fdB4F9B696B1BA1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcd6997334867728ba14d7922f72c893fcee70e84" + } + }, + { + "chainId": 137, + "name": "stake dao Curve.fi DAI/USDC/USDT", + "symbol": "sd3Crv", + "decimals": 18, + "address": "0x87f0BFEE4435CE2B8643b221D0C1CAd21F5328B4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb17640796e4c27a39af51887aff3f8dc0daf9567" + } + }, + { + "chainId": 137, + "name": "BetProtocolToken", + "symbol": "BEPRO", + "decimals": 18, + "address": "0x07CC1cC3628Cc1615120DF781eF9fc8EC2feAE09", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcf3c8be2e2c42331da80ef210e9b1b307c03d36a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bepro.svg" + }, + { + "chainId": 137, + "name": "Vox.Finance", + "symbol": "VOX", + "decimals": 18, + "address": "0x7Dd3D9E1868A7dA87509A601E7dbBf938c819a32", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x12D102F06da35cC0111EB58017fd2Cd28537d0e1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/vox.svg" + }, + { + "chainId": 137, + "name": "Nord Token", + "symbol": "NORD", + "decimals": 18, + "address": "0xF6F85b3f9fd581C2eE717c404F7684486F057F95", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6e9730ecffbed43fd876a264c982e254ef05a0de" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nord.svg" + }, + { + "chainId": 137, + "name": "veCRV-Stake-DAO", + "symbol": "veCRV", + "decimals": 18, + "address": "0x9613282539b6d0e3CB1eDC843a43Da7768AC3838", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x478bBC744811eE8310B461514BDc29D03739084D" + } + }, + { + "chainId": 137, + "name": "Julien", + "symbol": "JULIEN", + "decimals": 4, + "address": "0x268Ad27C28601D28b79c792C14e95BD2b7A030F8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe6710e0cda178f3d921f456902707b0d4c4a332b" + } + }, + { + "chainId": 137, + "name": "hoge.finance", + "symbol": "HOGE", + "decimals": 9, + "address": "0xdd539b42dadDc0Ca55fb3aC2260240E61414d92B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfad45e47083e4607302aa43c65fb3106f1cd7607" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hoge.svg" + }, + { + "chainId": 137, + "name": "DEGEN Index", + "symbol": "DEGEN", + "decimals": 18, + "address": "0x8a2870fb69A90000D6439b7aDfB01d4bA383A415", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x126c121f99e1e211df2e5f8de2d96fa36647c855" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/degen.svg" + }, + { + "chainId": 137, + "name": "MAKER", + "symbol": "MKR", + "decimals": 18, + "address": "0x6f7C932e7684666C9fd1d44527765433e01fF61d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9f8f72aa9304c8b593d555f12ef6589cc3a579a2" + } + }, + { + "chainId": 137, + "name": "NapoleonX Token", + "symbol": "NPX", + "decimals": 2, + "address": "0x106035DEDcA635d75d6Ff05F98F25916829eDB77", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x28b5e12cce51f15594b0b91d5b5adaa70f684a02" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/npx.svg" + }, + { + "chainId": 137, + "name": "Stake DAO Token", + "symbol": "SDT", + "decimals": 18, + "address": "0x361A5a4993493cE00f61C32d4EcCA5512b82CE90", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x73968b9a57c6e53d41345fd57a6e6ae27d6cdb2f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sdt.svg" + }, + { + "chainId": 137, + "name": "EASY", + "symbol": "EASY", + "decimals": 18, + "address": "0xDb3b3b147A030F032633f6C4BEBf9a2fB5a882B5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x913D8ADf7CE6986a8CbFee5A54725D9Eea4F0729" + } + }, + { + "chainId": 137, + "name": "Vidya", + "symbol": "VIDYA", + "decimals": 18, + "address": "0xFe9CA7Cf13E33b23aF63Fea696f4AAe1b7A65585", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3d3d35bb9bec23b06ca00fe472b50e7a4c692c30" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/vidya.svg" + }, + { + "chainId": 137, + "name": "Betbeetle", + "symbol": "BTL", + "decimals": 18, + "address": "0x2D0b6b0C7468C7cFb716e9Cf0ff24F45A239a3A0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb9a8695a234b6e8f9e65d299df8f94234540fc05" + } + }, + { + "chainId": 137, + "name": "Street Cred", + "symbol": "CRED", + "decimals": 18, + "address": "0x13654478010268c8c729E8078313C3d0acC21819", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xED7Fa212E100DFb3b13B834233E4B680332a3420" + } + }, + { + "chainId": 137, + "name": "coin_artist", + "symbol": "COIN", + "decimals": 18, + "address": "0x26F10028C105501678531A19Fe025b93Ae055a9f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x87b008E57F640D94Ee44Fd893F0323AF933F9195" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/coin.svg" + }, + { + "chainId": 137, + "name": "PickleToken", + "symbol": "PICKLE", + "decimals": 18, + "address": "0x2b88aD57897A8b496595925F43048301C37615Da", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x429881672B9AE42b8EbA0E26cD9C73711b891Ca5" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pickle.svg" + }, + { + "chainId": 137, + "name": "Render Token", + "symbol": "RNDR", + "decimals": 18, + "address": "0x61299774020dA444Af134c82fa83E3810b309991", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6de037ef9ad2725eb40118bb1702ebb27e4aeb24" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rndr.svg" + }, + { + "chainId": 137, + "name": "Cryptotipsfr Token V2", + "symbol": "CRTS", + "decimals": 9, + "address": "0xebf9B87583C284F0a1b7aF72371F84D2A7567285", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x94cA37d108E89775dC8ae65F51AE28c2d9599f9A" + } + }, + { + "chainId": 137, + "name": "CRV", + "symbol": "CRV", + "decimals": 18, + "address": "0x172370d5Cd63279eFa6d502DAB29171933a610AF", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd533a949740bb3306d119cc777fa900ba034cd52" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/crv.svg" + }, + { + "chainId": 137, + "name": "TORN", + "symbol": "TORN", + "decimals": 18, + "address": "0x23fE1Ee2f536427B7e8aC02FB037A7f867037Fe8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x77777feddddffc19ff86db637967013e6c6a116c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/torn.svg" + }, + { + "chainId": 137, + "name": "FOTO", + "symbol": "FOTO", + "decimals": 18, + "address": "0x7827F070D3F0DCAE72aC6a9E1953459d50A426A7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf6ea0e60cee427b90aa36f327ee61d1d4cabc49f" + } + }, + { + "chainId": 137, + "name": "STAKE", + "symbol": "STAKE", + "decimals": 18, + "address": "0xeb5c9e515629B725D3588A55E2a43964DcfdE8cA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0ae055097c6d159879521c384f1d2123d1f195e6" + } + }, + { + "chainId": 137, + "name": "PERP", + "symbol": "PERP", + "decimals": 18, + "address": "0x263534a4Fe3cb249dF46810718B7B612a30ebbff", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbc396689893d065f41bc2c6ecbee5e0085233447" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/perp.svg" + }, + { + "chainId": 137, + "name": "Maps.me Token", + "symbol": "MAPS", + "decimals": 6, + "address": "0x7B9FD890072508f66978e1cb9D4F802DCC2C4fDf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2b915b505c017abb1547aa5ab355fbe69865cc6d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/maps.svg" + }, + { + "chainId": 137, + "name": "Mysterium", + "symbol": "MYST", + "decimals": 18, + "address": "0x1379E8886A944d2D9d440b3d88DF536Aea08d9F3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4Cf89ca06ad997bC732Dc876ed2A7F26a9E7f361" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/myst.svg" + }, + { + "chainId": 137, + "name": "Fractal Protocol Token", + "symbol": "FCL", + "decimals": 18, + "address": "0x6f934b45fc6043527d73C7c99313dd838E723DB7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf4d861575ecc9493420a3f5a14f85b13f0b50eb3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/fcl.svg" + }, + { + "chainId": 137, + "name": "URANIUM", + "symbol": "URANIUM", + "decimals": 18, + "address": "0x2Ecf35111DC4894f43FEab1683a9845cd1b4E0C4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xeea6D30798300F4E1d8cd819c8db3B4E6d1e29f6" + } + }, + { + "chainId": 137, + "name": "RAZOR", + "symbol": "RAZOR", + "decimals": 18, + "address": "0xC91c06DB0f7bFFba61e2A5645CC15686F0a8c828", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x50de6856358cc35f3a9a57eaaa34bd4cb707d2cd" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/razor.svg" + }, + { + "chainId": 137, + "name": "FireAnts", + "symbol": "ANTS", + "decimals": 18, + "address": "0x24212089B9D90B4D06ef10bD80CA14ec9356D98f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa9fbb83a2689f4ff86339a4b96874d718673b627" + } + }, + { + "chainId": 137, + "name": "YVS.Finance", + "symbol": "YVS", + "decimals": 18, + "address": "0xb565CF70613ca464D68427106af80C67a8e4b801", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xEC681F28f4561c2a9534799AA38E0d36A83Cf478" + } + }, + { + "chainId": 137, + "name": "Hopr", + "symbol": "HOPR", + "decimals": 18, + "address": "0x6cCBF3627b2C83AFEF05bf2F035E7f7B210Fe30D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf5581dfefd8fb0e4aec526be659cfab1f8c781da" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hopr.svg" + }, + { + "chainId": 137, + "name": "Tapmydata", + "symbol": "TAP", + "decimals": 18, + "address": "0x10635bF5c17F5E4c0Ed9012aEf7C12f96a57a4Dd", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7f1f2d3dfa99678675ece1c243d3f7bc3746db5d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/tap.svg" + }, + { + "chainId": 137, + "name": "Injective Token", + "symbol": "INJ", + "decimals": 18, + "address": "0x4E8dc2149EaC3f3dEf36b1c281EA466338249371", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe28b3B32B6c345A34Ff64674606124Dd5Aceca30" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/inj.svg" + }, + { + "chainId": 137, + "name": "Badger Sett Digg", + "symbol": "bDIGG", + "decimals": 18, + "address": "0xFDde616084427f0A231D0664a985E1F820E34693", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7e7e112a68d8d2e221e11047a72ffc1065c38e1a" + } + }, + { + "chainId": 137, + "name": "Digg", + "symbol": "DIGG", + "decimals": 9, + "address": "0x12255b2DaDC7E18Fd34353DAa161974cC917C8dd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x798d1be841a82a273720ce31c822c61a67a601c3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/digg.svg" + }, + { + "chainId": 137, + "name": "Badger Sett Badger", + "symbol": "bBADGER", + "decimals": 18, + "address": "0x2628D301b161DB70E3dBbAc88d9D900cA426fF02", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x19d97d8fa813ee2f51ad4b4e04ea08baf4dffc28" + } + }, + { + "chainId": 137, + "name": "Badger", + "symbol": "BADGER", + "decimals": 18, + "address": "0x1FcbE5937B0cc2adf69772D228fA4205aCF4D9b2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3472A5A71965499acd81997a54BBA8D852C6E53d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/badger.svg" + }, + { + "chainId": 137, + "name": "Theta Token", + "symbol": "THETA", + "decimals": 18, + "address": "0xB46E0ae620EFd98516f49bb00263317096C114b2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3883f5e181fccaf8410fa61e12b59bad963fb645" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/theta.svg" + }, + { + "chainId": 137, + "name": "Tixl Token", + "symbol": "TXL", + "decimals": 18, + "address": "0x6EE244034336f0135dcef9A5755D03a9f51Dd114", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8eEF5a82E6Aa222a60F009ac18c24EE12dBf4b41" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/txl.svg" + }, + { + "chainId": 137, + "name": "RFOX", + "symbol": "RFOX", + "decimals": 18, + "address": "0xdD4959cd915AE74DCD3F51e11e40Fe112aC7AA69", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa1d6df714f91debf4e0802a542e13067f31b8262" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rfox.svg" + }, + { + "chainId": 137, + "name": "Energy Web Token Bridged", + "symbol": "EWTB", + "decimals": 18, + "address": "0x43E4B063F96c33F0433863A927F5bad34bb4B03d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x178c820f862b14f316509ec36b13123da19a6054" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ewtb.svg" + }, + { + "chainId": 137, + "name": "DEAPCOIN", + "symbol": "DEP", + "decimals": 18, + "address": "0xD0ee109352c6116dB0f17F4Aa8519CdBfc7e7887", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1a3496c18d558bd9c6c8f609e1b129f67ab08163" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dep.svg" + }, + { + "chainId": 137, + "name": "IceCream", + "symbol": "SCOOP", + "decimals": 6, + "address": "0x25F5ea9BD2ff7F4fE7CAd29a271Eb484AcBF19f8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9E7aCE871aFa0c18f979979a22104dd01d39b414" + } + }, + { + "chainId": 137, + "name": "AGA Rewards", + "symbol": "AGAr", + "decimals": 8, + "address": "0xF84BD51eab957c2e7B7D646A3427C5A50848281D", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb453f1f2EE776dAF2586501361c457dB70e1ca0F" + } + }, + { + "chainId": 137, + "name": "PoolTogether", + "symbol": "POOL", + "decimals": 18, + "address": "0x25788a1a171ec66Da6502f9975a15B609fF54CF6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0cec1a9154ff802e7934fc916ed7ca50bde6844e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pool.svg" + }, + { + "chainId": 137, + "name": "BandToken", + "symbol": "BAND", + "decimals": 18, + "address": "0xA8b1E0764f85f53dfe21760e8AfE5446D82606ac", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xba11d00c5f74255f56a5e366f4f77f5a186d7f55" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/band.svg" + }, + { + "chainId": 137, + "name": "Fantom Token", + "symbol": "FTM", + "decimals": 18, + "address": "0xC9c1c1c20B3658F8787CC2FD702267791f224Ce1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4e15361fd6b4bb609fa63c81a2be19d873717870" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ftm.svg" + }, + { + "chainId": 137, + "name": "OriginToken", + "symbol": "OGN", + "decimals": 18, + "address": "0xa63Beffd33AB3a2EfD92a39A7D2361CEE14cEbA8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8207c1ffc5b6804f6024322ccf34f29c3541ae26" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ogn.svg" + }, + { + "chainId": 137, + "name": "1Million Token", + "symbol": "1MT", + "decimals": 7, + "address": "0x2052344CeAce7f140da3E819c7729fEF72F97851", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf0bc1ae4ef7ffb126a8347d06ac6f8add770e1ce" + } + }, + { + "chainId": 137, + "name": "Spartan", + "symbol": "300", + "decimals": 7, + "address": "0x454E1Ec2F58ee542B75d2AB713Ed53Cd33Ba4308", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x167e2a574669b0eeb552aaf3da47c728cb348a41" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/300.svg" + }, + { + "chainId": 137, + "name": "1337", + "symbol": "1337", + "decimals": 4, + "address": "0x49Fc111e5Ddd5580f48D6fDc4314540cb3A5CC4B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x35872fea6a4843facbcdbce99e3b69596a3680b8" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/1337.svg" + }, + { + "chainId": 137, + "name": "WHALE", + "symbol": "WHALE", + "decimals": 4, + "address": "0xb9585ec9d4C97Ad9DEd7250Bb9a199fe8eED0ECA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9355372396e3f6daf13359b7b607a3374cc638e0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/whale.svg" + }, + { + "chainId": 137, + "name": "AutoChainTokenCandy", + "symbol": "ATCx", + "decimals": 4, + "address": "0x0F933Ae2ffb1ee8b7385647Eb6A5610F31d5B56F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcb6e019e74a2d6e0dd60afc716e4c708140bff7d" + } + }, + { + "chainId": 137, + "name": "Tellor Tributes", + "symbol": "TRB", + "decimals": 18, + "address": "0xE3322702BEdaaEd36CdDAb233360B939775ae5f1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x88dF592F8eb5D7Bd38bFeF7dEb0fBc02cf3778a0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/trb.svg" + }, + { + "chainId": 137, + "name": "SwapMatic Token", + "symbol": "SWAM", + "decimals": 18, + "address": "0x94C18174840F80D49d59DC3a1742aF0B884A8184", + "logoURI": "https://raw.githubusercontent.com/BlockTimeWorld/crawler/main/icons/swam.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x368306eb52c8313fd398418c8220ddd560940e68" + } + }, + { + "chainId": 137, + "name": "IOI Token ", + "symbol": "IOI", + "decimals": 6, + "address": "0xAF24765F631C8830B5528B57002241eE7eef1C14", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8b3870df408ff4d7c3a26df852d41034eda11d81" + } + }, + { + "chainId": 137, + "name": "B.20", + "symbol": "B20", + "decimals": 18, + "address": "0xff898089e368eCc47Fc37Fd0D905Fbcf0D70E820", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc4de189abf94c57f396bd4c52ab13b954febefd8" + } + }, + { + "chainId": 137, + "name": "Neutrino USD", + "symbol": "USDN", + "decimals": 18, + "address": "0x1b630A1f5838D142F4E91CC4163CD41F5139b166", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x674C6Ad92Fd080e4004b2312b45f796a192D27a0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/usdn.svg" + }, + { + "chainId": 137, + "name": "Ammunition", + "symbol": "AMMO", + "decimals": 18, + "address": "0x9C72573A47b0d81Ef6048c320bF5563e1606A04C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41D4E9880d6aE03f6E152A52afc3ECF82063A08b" + } + }, + { + "chainId": 137, + "name": "Ruletka", + "symbol": "RTK", + "decimals": 18, + "address": "0x38332D8671961aE13d0BDe040d536eB336495eEA", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1F6DEADcb526c4710Cf941872b86dcdfBbBD9211" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rtk.svg" + }, + { + "chainId": 137, + "name": "Crypto Accept", + "symbol": "ACPT", + "decimals": 18, + "address": "0xFCf1E2fC0A398925ddb09222842b376E3A7D573B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcAd2d4C4469fF09aB24d02A63BCeDfCD44bE0645" + } + }, + { + "chainId": 137, + "name": "Vortex DeFi", + "symbol": "VTX", + "decimals": 18, + "address": "0x392f5C034b5423569a09Bb172f408aCb62A1Be7A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xceb286c9604c542d3cc08b41aa6c9675b078a832" + } + }, + { + "chainId": 137, + "name": "Offshift", + "symbol": "XFT", + "decimals": 18, + "address": "0x9EC5AbD7A442B8325F529daB25019674D0ba983d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xabe580e7ee158da464b51ee1a83ac0289622e6be" + } + }, + { + "chainId": 137, + "name": "Digital Reserve Currency", + "symbol": "DRC", + "decimals": 0, + "address": "0xFeD16c746CB5BFeD009730f9E3e6A673006105c7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa150Db9b1Fa65b44799d4dD949D922c0a33Ee606" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/drc.svg" + }, + { + "chainId": 137, + "name": "Paxos Gold", + "symbol": "PAXG", + "decimals": 18, + "address": "0x553d3D295e0f695B9228246232eDF400ed3560B5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x45804880de22913dafe09f4980848ece6ecbaf78" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/paxg.svg" + }, + { + "chainId": 137, + "name": "Gnosis Token", + "symbol": "GNO", + "decimals": 18, + "address": "0x5FFD62D3C3eE2E81C00A7b9079FB248e7dF024A8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6810e776880C02933D47DB1b9fc05908e5386b96" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/gno.svg" + }, + { + "chainId": 137, + "name": "Synthetix Network Token", + "symbol": "SNX", + "decimals": 18, + "address": "0x50B728D8D964fd00C2d0AAD81718b71311feF68a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc011a73ee8576fb46f5e1c5751ca3b9fe0af2a6f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/snx.svg" + }, + { + "chainId": 137, + "name": "cVault.finance", + "symbol": "CORE", + "decimals": 18, + "address": "0xE47dbe919C8AB0c1A1C1e97A1Eefc2B946253924", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x62359ed7505efc61ff1d56fef82158ccaffa23d7" + } + }, + { + "chainId": 137, + "name": "Decentr ", + "symbol": "DEC", + "decimals": 18, + "address": "0x314338767151e6Ed23DB8A41c6F6943c1958Ee56", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x30f271c9e86d2b7d00a6376cd96a1cfbd5f0b9b3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dec.svg" + }, + { + "chainId": 137, + "name": "AAH", + "symbol": "AAH", + "decimals": 18, + "address": "0xaf9444bc9D6117121Aa108fC6c45835Be60E7d07", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7a911c71144f4d5a00e4216b1c5b12d9571e9336" + } + }, + { + "chainId": 137, + "name": "DoTx Uniswap V2", + "symbol": "DoTxUNI-V2", + "decimals": 18, + "address": "0x421E0acEa8cD9D4aa2bcEdB407726b6A4Bffb664", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5488ed7f9a99684d0e9eccd3847860c734017575" + } + }, + { + "chainId": 137, + "name": "Firebird DAO", + "symbol": "FBIRD", + "decimals": 18, + "address": "0x422E0Cba8e57Acc799fC14DAdf2b72DfbA281c5F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x299e6062fc7e68f517746ab40cd915c0e9410935" + } + }, + { + "chainId": 137, + "name": "PolkastarterToken", + "symbol": "POLS", + "decimals": 18, + "address": "0x8dc302e2141DA59c934d900886DbF1518Fd92cd4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x83e6f1E41cdd28eAcEB20Cb649155049Fac3D5Aa" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pols.svg" + }, + { + "chainId": 137, + "name": "DSLA", + "symbol": "DSLA", + "decimals": 18, + "address": "0xa0E390e9ceA0D0e8cd40048ced9fA9EA10D71639", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3affcca64c2a6f4e3b6bd9c64cd2c969efd1ecbe" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dsla.svg" + }, + { + "chainId": 137, + "name": "Bancor Network Token", + "symbol": "BNT", + "decimals": 18, + "address": "0xc26D47d5c33aC71AC5CF9F776D63Ba292a4F7842", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1f573d6fb3f13d689ff844b4ce37794d79a7ff1c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bnt.svg" + }, + { + "chainId": 137, + "name": "Reserve Rights", + "symbol": "RSR", + "decimals": 18, + "address": "0x7B38C0d5dfc91d0A3FeF2F8DAb3BE404c1f61fa4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8762db106b2c2a0bccb3a80d1ed41273552616e8" + } + }, + { + "chainId": 137, + "name": "Ethereum Blue", + "symbol": "BLUE", + "decimals": 8, + "address": "0xe7f960685aba7327ADA3b161Ea252703C87be0bF", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x539efe69bcdd21a83efd9122571a64cc25e0282b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/blue.svg" + }, + { + "chainId": 137, + "name": "API3", + "symbol": "API3", + "decimals": 18, + "address": "0x45C27821E80F8789b60Fd8B600C73815d34DDa6C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0b38210ea11411557c13457D4dA7dC6ea731B88a" + } + }, + { + "chainId": 137, + "name": "MODEFI ", + "symbol": "MOD", + "decimals": 18, + "address": "0x8346Ab8d5EA7A9Db0209aEd2d1806AFA0E2c4C21", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xea1ea0972fa092dd463f2968f9bb51cc4c981d71" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mod.svg" + }, + { + "chainId": 137, + "name": "DEFI Top 5 Tokens Index", + "symbol": "DEFI5", + "decimals": 18, + "address": "0x42435F467D33e5C4146a4E8893976ef12BBCE762", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfa6de2697d59e88ed7fc4dfe5a33dac43565ea41" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/defi5.svg" + }, + { + "chainId": 137, + "name": "Rarible", + "symbol": "RARI", + "decimals": 18, + "address": "0x780053837cE2CeEaD2A90D9151aA21FC89eD49c2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfca59cd816ab1ead66534d82bc21e7515ce441cf" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rari.svg" + }, + { + "chainId": 137, + "name": "OptionRoom", + "symbol": "ROOM", + "decimals": 18, + "address": "0x29a13AF916FE709b10029b578C94759675c9e91e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xad4f86a25bbc20ffb751f2fac312a0b4d8f88c64" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/room.svg" + }, + { + "chainId": 137, + "name": "Audius", + "symbol": "AUDIO", + "decimals": 18, + "address": "0x5eB8D998371971D01954205c7AFE90A7AF6a95AC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x18aaa7115705e8be94bffebde57af9bfc265b998" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/audio.svg" + }, + { + "chainId": 137, + "name": "SuperFarm", + "symbol": "SUPER", + "decimals": 18, + "address": "0xa1428174F516F527fafdD146b883bB4428682737", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe53ec727dbdeb9e2d5456c3be40cff031ab40a55" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/super.svg" + }, + { + "chainId": 137, + "name": "Centaur Token", + "symbol": "CNTR", + "decimals": 18, + "address": "0xdae89dA41a96956e9e70320Ac9c0dd077070D3a5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x03042482d64577a7bdb282260e2ea4c8a89c064b" + } + }, + { + "chainId": 137, + "name": "CyberFi Token", + "symbol": "CFi", + "decimals": 18, + "address": "0xeCf8f2FA183b1C4d2A269BF98A54fCe86C812d3e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x63b4f3e3fa4e438698ce330e365e831f7ccd1ef4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cfi.svg" + }, + { + "chainId": 137, + "name": "tBTC", + "symbol": "TBTC", + "decimals": 18, + "address": "0x50a4a434247089848991DD8f09b889D4e2870aB6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8dAEBADE922dF735c38C80C7eBD708Af50815fAa" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/tbtc.svg" + }, + { + "chainId": 137, + "name": "KEEP Token", + "symbol": "KEEP", + "decimals": 18, + "address": "0x42f37A1296b2981F7C3cAcEd84c5096b2Eb0C72C", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x85eee30c52b0b379b046fb0f85f4f3dc3009afec" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/keep.svg" + }, + { + "chainId": 137, + "name": "Sapiency", + "symbol": "SPCY", + "decimals": 18, + "address": "0x87c830b6d732C3209dB97f61B379F359570d6A49", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x15f503F23d4d2716e0817714709B5DCF868013EE" + } + }, + { + "chainId": 137, + "name": "Datamine", + "symbol": "DAM", + "decimals": 18, + "address": "0xb75bBd79985a8092B05224f62D7fED25924B075d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xF80D589b3Dbe130c270a69F1a69D050f268786Df" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dam.svg" + }, + { + "chainId": 137, + "name": "Zenfuse", + "symbol": "ZEFU", + "decimals": 18, + "address": "0xE117837c0c8A53765cb6b4A16eBc84B3a71DD0BD", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb1e9157c2fdcc5a856c8da8b2d89b6c32b3c1229" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/zefu.svg" + }, + { + "chainId": 137, + "name": "Rai Reflex Index", + "symbol": "RAI", + "decimals": 18, + "address": "0x00e5646f60AC6Fb446f621d146B6E1886f002905", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x03ab458634910AaD20eF5f1C8ee96F1D6ac54919" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rai.svg" + }, + { + "chainId": 137, + "name": "Wrapped LUNA Token", + "symbol": "LUNA", + "decimals": 18, + "address": "0x24834BBEc7E39ef42f4a75EAF8E5B6486d3F0e57", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd2877702675e6cEb975b4A1dFf9fb7BAF4C91ea9" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/luna.svg" + }, + { + "chainId": 137, + "name": "Power Trade Fuel", + "symbol": "PTF", + "decimals": 18, + "address": "0xFc42E9996973ac2E0Ff1055762E78CFaF0061188", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xbe38a889d67467b665e30e20ee5604a6f5696e38" + } + }, + { + "chainId": 137, + "name": "PLOT", + "symbol": "PLOT", + "decimals": 18, + "address": "0xe82808eaA78339b06a691fd92E1Be79671cAd8D3", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x72F020f8f3E8fd9382705723Cd26380f8D0c66Bb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/plot.svg" + }, + { + "chainId": 137, + "name": "Social Rocket", + "symbol": "ROCKS", + "decimals": 18, + "address": "0x434B5acf47e2883fC83D326D69F32965945C1f3D", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0829d2d5cC09d3d341E813c821B0cfAE272D9fb2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rocks.svg" + }, + { + "chainId": 137, + "name": "Graph Token", + "symbol": "GRT", + "decimals": 18, + "address": "0x5fe2B58c013d7601147DcdD68C143A77499f5531", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc944e90c64b2c07662a292be6244bdf05cda44a7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/grt.svg" + }, + { + "chainId": 137, + "name": "OMGToken", + "symbol": "OMG", + "decimals": 18, + "address": "0x62414D03084EeB269E18C970a21f45D2967F0170", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd26114cd6ee289accf82350c8d8487fedb8a0c07" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/omg.svg" + }, + { + "chainId": 137, + "name": "Bridge Mutual", + "symbol": "BMI", + "decimals": 18, + "address": "0x1A47E3316282d57DF146F87c58A1FB4b26992Bbf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x725c263e32c72ddc3a19bea12c5a0479a81ee688" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bmi.svg" + }, + { + "chainId": 137, + "name": "Sora Token", + "symbol": "XOR", + "decimals": 18, + "address": "0xECaE5e66d7F2BAe250dfF839216A01C2702aDFFD", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x40fd72257597aa14c7231a7b1aaa29fce868f677" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/xor.svg" + }, + { + "chainId": 137, + "name": "Coreto", + "symbol": "COR", + "decimals": 18, + "address": "0x4fdCE518fE527439Fe76883e6b51A1c522B61b7C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9c2dc0c3cc2badde84b0025cf4df1c5af288d835" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cor.svg" + }, + { + "chainId": 137, + "name": "CumCoin", + "symbol": "CUM", + "decimals": 18, + "address": "0x0f92D459B20D21F6bf9E02056EA9165d3f78bA62", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4ecebfe9b26cd2949202bc0c74e8b5748115fe20" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cum.svg" + }, + { + "chainId": 137, + "name": "Swipe", + "symbol": "SXP", + "decimals": 18, + "address": "0x6aBB753C1893194DE4a83c6e8B4EadFc105Fd5f5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8ce9137d39326ad0cd6491fb5cc0cba0e089b6a9" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sxp.svg" + }, + { + "chainId": 137, + "name": "DokiDokiAzuki", + "symbol": "AZUKI", + "decimals": 18, + "address": "0x7CdC0421469398e0F3aA8890693d86c840Ac8931", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x910524678C0B1B23FFB9285a81f99C29C11CBaEd" + } + }, + { + "chainId": 137, + "name": "Unibright", + "symbol": "UBT", + "decimals": 8, + "address": "0x7FBc10850caE055B27039aF31bD258430e714c62", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8400d94a5cb0fa0d041a3788e395285d61c9ee5e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ubt.svg" + }, + { + "chainId": 137, + "name": "ARIANEE", + "symbol": "ARIA20", + "decimals": 18, + "address": "0x46F48FbdedAa6F5500993BEDE9539ef85F4BeE8e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xedf6568618a00c6f0908bf7758a16f76b6e04af9" + } + }, + { + "chainId": 137, + "name": "DefiPulse Index", + "symbol": "DPI", + "decimals": 18, + "address": "0x85955046DF4668e1DD369D2DE9f3AEB98DD2A369", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1494ca1f11d487c2bbe4543e90080aeba4ba3c2b" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dpi.svg" + }, + { + "chainId": 137, + "name": "RAMP", + "symbol": "RAMP", + "decimals": 18, + "address": "0xaECeBfcF604AD245Eaf0D5BD68459C3a7A6399c2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x33d0568941c0c64ff7e0fb4fba0b11bd37deed9f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ramp.svg" + }, + { + "chainId": 137, + "name": "Butterfly Protocol", + "symbol": "BFLY", + "decimals": 18, + "address": "0x5B0a0CD03e9Df1829E00128ebE277Cc3247da346", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf680429328caaaCabee69b7A9FdB21a71419c063" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bfly.svg" + }, + { + "chainId": 137, + "name": "SwissBorg", + "symbol": "CHSB", + "decimals": 8, + "address": "0x67Ce67ec4fCd4aCa0Fcb738dD080b2a21ff69D75", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xba9d4199fab4f26efe3551d490e3821486f135ba" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/chsb.svg" + }, + { + "chainId": 137, + "name": "Trendering", + "symbol": "TRND", + "decimals": 18, + "address": "0xa38735c2be496A0C2D4FE32c7459c1d391501035", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc3dd23a0a854b4f9ae80670f528094e9eb607ccb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/trnd.svg" + }, + { + "chainId": 137, + "name": "TAMA EGG NiftyGotchi", + "symbol": "TME", + "decimals": 18, + "address": "0xbB6c356bDC5C258cb4e39C112d68fB6A9a9F6E26", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6e742e29395cf5736c358538f0f1372ab3dfe731" + } + }, + { + "chainId": 137, + "name": "Terra Virtua Kolect", + "symbol": "TVK", + "decimals": 18, + "address": "0x5667dcC0ab74D1b1355C3b2061893399331B57e2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd084b83c305dafd76ae3e1b4e1f1fe2ecccb3988" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/tvk.svg" + }, + { + "chainId": 137, + "name": "Feathers", + "symbol": "myFTHR", + "decimals": 4, + "address": "0xDfE5bED8D271a4cD89cd2066839B2b0Ec934A6E8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7C918dF91f8F4e8D707a7A4013b8e7247C0293B1" + } + }, + { + "chainId": 137, + "name": "1Inch", + "symbol": "1INCH", + "decimals": 18, + "address": "0x9c2C5fd7b07E95EE044DDeba0E97a665F142394f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x111111111117dc0aa78b770fa6a738034120c302" + } + }, + { + "chainId": 137, + "name": "Hands Of Steel", + "symbol": "STEEL", + "decimals": 0, + "address": "0xc8C511fE3EdBA60bc1049A88060468c2EA2D6358", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6f022e991ea21d26f85f6716c088e2864101dfec" + } + }, + { + "chainId": 137, + "name": "Circolo Arduino Token", + "symbol": "ARDU", + "decimals": 18, + "address": "0xBe319A08eBE5da37C5A8ce8a0D8463ff6750e53B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3d58f7b1b6f0262031c319265bd57e4752e3fa1e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ardu.svg" + }, + { + "chainId": 137, + "name": "UniLend Finance Token", + "symbol": "UFT", + "decimals": 18, + "address": "0x5B4CF2C120A9702225814E18543ee658c5f8631e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0202Be363B8a4820f3F4DE7FaF5224fF05943AB1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/uft.svg" + }, + { + "chainId": 137, + "name": "Omniunit Cash", + "symbol": "OMCH", + "decimals": 18, + "address": "0x349f96F489ed4e73e6C118Ed2D568343C9ee7cEc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaedb08ffbda65c9843875669fbcb544bcab63feb" + } + }, + { + "chainId": 137, + "name": "Chain Games", + "symbol": "CHAIN", + "decimals": 18, + "address": "0xd55fCe7CDaB84d84f2EF3F99816D765a2a94a509", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc4c2614e694cf534d407ee49f8e44d125e4681c4" + } + }, + { + "chainId": 137, + "name": "Rubic", + "symbol": "RBC", + "decimals": 18, + "address": "0xc3cFFDAf8F3fdF07da6D5e3A89B8723D5E385ff8", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa4eed63db85311e22df4473f87ccfc3dadcfa3e3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rbc.svg" + }, + { + "chainId": 137, + "name": "Shopping.io", + "symbol": "SPI", + "decimals": 18, + "address": "0x068180071617528606371c31892EcBF2B70ac1d2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9b02dd390a603add5c07f9fd9175b7dabe8d63b7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/spi.svg" + }, + { + "chainId": 137, + "name": "SURF.Finance", + "symbol": "SURF", + "decimals": 18, + "address": "0x1E42EDbe5376e717C1B22904C59e406426E8173F", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xEa319e87Cf06203DAe107Dd8E5672175e3Ee976c" + } + }, + { + "chainId": 137, + "name": "Omniunit", + "symbol": "OMNIUNIT", + "decimals": 18, + "address": "0xFd6cF3A1fcb42371fD7E69633d31303868b8171a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd22dcf31ca28cf4dce530a0f120e244f4b4539eb" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/omniunit.svg" + }, + { + "chainId": 137, + "name": "DokiDokiFinance", + "symbol": "DOKI", + "decimals": 18, + "address": "0x5C7F7Fe4766fE8f0fa9b41E2E4194d939488ff1C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9ceb84f92a0561fa3cc4132ab9c0b76a59787544" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/doki.svg" + }, + { + "chainId": 137, + "name": "AGA Token", + "symbol": "AGA", + "decimals": 4, + "address": "0x033d942A6b495C4071083f4CDe1f17e986FE856c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2D80f5F5328FdcB6ECeb7Cacf5DD8AEDaEC94e20" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/aga.svg" + }, + { + "chainId": 137, + "name": "DOGEFI", + "symbol": "DOGEFI", + "decimals": 18, + "address": "0x13405CC33ffae0a9f91FeBb66B6b85A9C54DA13A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9b9087756eca997c5d595c840263001c9a26646d" + } + }, + { + "chainId": 137, + "name": "Sync Network ", + "symbol": "SYNC", + "decimals": 18, + "address": "0x5e648D09170C346DD27df9Db332591e4FAa6A844", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb6ff96b8a8d214544ca0dbc9b33f7ad6503efd32" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sync.svg" + }, + { + "chainId": 137, + "name": "NFTX", + "symbol": "NFTX", + "decimals": 18, + "address": "0x418839451873b0E69e628F95DC39a877a9715196", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x87d73e916d7057945c9bcd8cdd94e42a6f47f776" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/nftx.svg" + }, + { + "chainId": 137, + "name": "Rio Fuel Token", + "symbol": "RFuel", + "decimals": 18, + "address": "0x147697003255510f6431a44443E67B227109832e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xaf9f549774ecedbd0966c52f250acc548d3f36e5" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/rfuel.svg" + }, + { + "chainId": 137, + "name": "WePower Token", + "symbol": "WPR", + "decimals": 18, + "address": "0xCBAb27B2D5b468Eea509Bd430100922341BC3f1A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4cf488387f035ff08c371515562cba712f9015d4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wpr.svg" + }, + { + "chainId": 137, + "name": "Cartesi Token", + "symbol": "CTSI", + "decimals": 18, + "address": "0x2727Ab1c2D22170ABc9b595177B2D5C6E1Ab7B7B", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x491604c0fdf08347dd1fa4ee062a822a5dd06b5d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ctsi.svg" + }, + { + "chainId": 137, + "name": "N3RD.FINANCE", + "symbol": "N3RDz", + "decimals": 18, + "address": "0x8f3dc8321cBa3Abe08Fb29055a0A10dC79223252", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x32c868f6318d6334b2250f323d914bc2239e4eee" + } + }, + { + "chainId": 137, + "name": "SERGS", + "symbol": "SERGS", + "decimals": 18, + "address": "0xc73A8F11ec303eD81000AC5Eae94Bf2D65b67dD6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x79ba92dda26fce15e1e9af47d5cfdfd2a093e000" + } + }, + { + "chainId": 137, + "name": "Jarvis Reward Token", + "symbol": "JRT", + "decimals": 18, + "address": "0x596eBE76e2DB4470966ea395B0d063aC6197A8C5", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8a9c67fee641579deba04928c4bc45f66e26343a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/jrt.svg" + }, + { + "chainId": 137, + "name": "LOAD", + "symbol": "LOAD", + "decimals": 8, + "address": "0x81C88f5CFF4fd506df906cb32F8b02218701b0C7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa883e72c12473ded50a5fbffa60e4000fa5fe3c8" + } + }, + { + "chainId": 137, + "name": "ZeroUtility", + "symbol": "ZUT", + "decimals": 18, + "address": "0xe86E8beb7340659DDDCE61727E500e3A5aD75a90", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x83f873388cd14b83a9f47fabde3c9850b5c74548" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/zut.svg" + }, + { + "chainId": 137, + "name": "Pepemon Pepeballs", + "symbol": "PPBLZ", + "decimals": 18, + "address": "0x13607aA9b2ffdd8340F4628049Bd35C02A68fA05", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4d2ee5dae46c86da2ff521f7657dad98834f97b8" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ppblz.svg" + }, + { + "chainId": 137, + "name": "Bounty0x Token", + "symbol": "BNTY", + "decimals": 18, + "address": "0x0f40D69Ff494a9e74b1F20A89EfF299B2A05918F", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd2d6158683aee4cc838067727209a0aaf4359de3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bnty.svg" + }, + { + "chainId": 137, + "name": "Blockchain Mind", + "symbol": "BCM", + "decimals": 18, + "address": "0x29B9c200B27683feA3512911DAFAf0AfD60dA4E3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9620366a3e732f484b2dc63103bb0eef0dde1f33" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bcm.svg" + }, + { + "chainId": 137, + "name": "YELD", + "symbol": "YELD", + "decimals": 18, + "address": "0x9Bd3b7C3dCC24708cbF122523546Ee5C6cAEfCe8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x468ab3b1f63A1C14b361bC367c3cC92277588Da1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/yeld.svg" + }, + { + "chainId": 137, + "name": "Frax Share", + "symbol": "FXS", + "decimals": 18, + "address": "0x3e121107F6F22DA4911079845a470757aF4e1A1b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3432b6a60d23ca0dfca7761b7ab56459d9c964d0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/fxs.svg" + }, + { + "chainId": 137, + "name": "SpiritCoin", + "symbol": "SPIRIT", + "decimals": 15, + "address": "0x24627609f3b7a01fc5A99D71067d4A28778d2B7A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x88647c0a3a3349b9dc9e69d7385a9393a15245dc" + } + }, + { + "chainId": 137, + "name": "Reef.finance", + "symbol": "REEF", + "decimals": 18, + "address": "0xa383abD0fE30fa2b781c0b454bfcC0475c6c8844", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xfe3e6a25e6b192a42a44ecddcd13796471735acf" + } + }, + { + "chainId": 137, + "name": "DeFi Of Thrones", + "symbol": "DoTx", + "decimals": 18, + "address": "0x3Ef402Af15EEB3c80b4441E60913f31a5C41E077", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xFAb5a05C933f1A2463E334E011992E897D56eF0a" + } + }, + { + "chainId": 137, + "name": "Frax", + "symbol": "FRAX", + "decimals": 18, + "address": "0x104592a158490a9228070E0A8e5343B499e125D0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x853d955acef822db058eb8505911ed77f175b99e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/frax.svg" + }, + { + "chainId": 137, + "name": "LoganCoin", + "symbol": "LOG", + "decimals": 18, + "address": "0x2F128A29F2b070a68d92777EBBc0B1E8B1D5Bcd0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x7FdF5d604A5597a20950F0744342647098154abE" + } + }, + { + "chainId": 137, + "name": "Parsiq", + "symbol": "PRQ", + "decimals": 18, + "address": "0x9377Eeb7419486FD4D485671d50baa4BF77c2222", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x362bc847a3a9637d3af6624eec853618a43ed7d2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/prq.svg" + }, + { + "chainId": 137, + "name": "HYDRO", + "symbol": "HYDRO", + "decimals": 18, + "address": "0x902742E3c5169657B1028977371CDF2c1608F67a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xEBBdf302c940c6bfd49C6b165f457fdb324649bc" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hydro.svg" + }, + { + "chainId": 137, + "name": "RottenToken", + "symbol": "ROT", + "decimals": 18, + "address": "0x21389a523B3A9F39Bb3A4065572994455faf59E8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD04785C4d8195e4A54d9dEc3a9043872875ae9E2" + } + }, + { + "chainId": 137, + "name": "Vibrant Finance", + "symbol": "ViFi", + "decimals": 18, + "address": "0xD6c914BB2fca4BCB6644D01C4cf690c34a166e13", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8a99E2dAE13e4df4A6aA2A9Db2d6A7901eD0107D" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/vifi.svg" + }, + { + "chainId": 137, + "name": "Atari", + "symbol": "ATRI", + "decimals": 0, + "address": "0xB140665ddE25c644c6B418e417C930dE8A8a6Ac9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdacd69347de42babfaecd09dc88958378780fb62" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/atri.svg" + }, + { + "chainId": 137, + "name": "CORD.Finance Bridge", + "symbol": "CORDBRIDGE", + "decimals": 18, + "address": "0x6C222361B1407c196F740c1BfFC17d1770BFD55c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x63Ebe5Dc670FA883e184771fCB42555CB6069bcA" + } + }, + { + "chainId": 137, + "name": "DAOfi", + "symbol": "DAOfi", + "decimals": 18, + "address": "0x083BdF826F6A7419d3Cef30B9E338316224c8e8B", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd82bb924a1707950903e2c0a619824024e254cd1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/daofi.svg" + }, + { + "chainId": 137, + "name": "Karma", + "symbol": "KARMA", + "decimals": 4, + "address": "0x4016489B230980fd43511e28E7Fb91ED795c90C5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdfe691f37b6264a90ff507eb359c45d55037951c" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/karma.svg" + }, + { + "chainId": 137, + "name": "Koinos", + "symbol": "KOIN", + "decimals": 8, + "address": "0xd617a689F1B8d3b27D51Cf7789f18bD43d8c1706", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x66d28cb58487a7609877550e1a34691810a6b9fc" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/koin.svg" + }, + { + "chainId": 137, + "name": "DAO Maker", + "symbol": "DAO", + "decimals": 18, + "address": "0x048c83a1176A1d3d12cb8C305179D360B1E4C958", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0f51bb10119727a7e5ea3538074fb341f56b09ad" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dao.svg" + }, + { + "chainId": 137, + "name": "Lead Token", + "symbol": "XPb", + "decimals": 18, + "address": "0xB272B6D99858B0EfB079946942006727fe105201", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbC81BF5B3173BCCDBE62dba5f5b695522aD63559" + } + }, + { + "chainId": 137, + "name": "Keep3rV1", + "symbol": "KP3R", + "decimals": 18, + "address": "0x53AEc293212E3B792563Bc16f1be26956adb12e9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1ceb5cb57c4d4e2b2433641b95dd330a33185a44" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/kp3r.svg" + }, + { + "chainId": 137, + "name": "Fuego Token", + "symbol": "FUEGO", + "decimals": 18, + "address": "0x088C9b7FC7d1E8F36028996236C9993BDf25Ac3E", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf93a26a41df2d39650d32f2bffae90e3c5286da9" + } + }, + { + "chainId": 137, + "name": "Must", + "symbol": "MUST", + "decimals": 18, + "address": "0x9C78EE466D6Cb57A4d01Fd887D2b5dFb2D46288f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9c78ee466d6cb57a4d01fd887d2b5dfb2d46288f" + } + }, + { + "chainId": 137, + "name": "MEME", + "symbol": "MEME", + "decimals": 8, + "address": "0xf2b5a8c37278bcdD50727D5CA879f8e5A4642e2e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd5525d397898e5502075ea5e830d8914f6f0affe" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/meme.svg" + }, + { + "chainId": 137, + "name": "Honey", + "symbol": "HNY", + "decimals": 18, + "address": "0xb371248Dd0f9E4061ccf8850E9223Ca48Aa7CA4b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc3589f56b6869824804a5ea29f2c9886af1b0fce" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hny.svg" + }, + { + "chainId": 137, + "name": "ethersmart", + "symbol": "ETM", + "decimals": 18, + "address": "0xAf95C20C60b49aD88024d8e77858900D9f2c98Bc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xF3eb8B90C763b8B2B53E7819ac27eca8f94C8Ec2" + } + }, + { + "chainId": 137, + "name": "DONUT", + "symbol": "DONUT", + "decimals": 18, + "address": "0xDe4e5B3672c4077B69216b77d99D8Ec35ec6C31A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc0f9bd5fa5698b6505f643900ffa515ea5df54a9" + } + }, + { + "chainId": 137, + "name": "MCHCoin", + "symbol": "MCHC", + "decimals": 18, + "address": "0xee7666aACAEFaa6efeeF62ea40176d3eB21953B9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd69f306549e9d96f183b1aeca30b8f4353c2ecc3" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mchc.svg" + }, + { + "chainId": 137, + "name": "JPY Coin", + "symbol": "JPYC", + "decimals": 18, + "address": "0x6AE7Dfc73E0dDE2aa99ac063DcF7e8A63265108c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2370f9d504c7a6E775bf6E14B3F12846b594cD53" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/jpyc.svg" + }, + { + "chainId": 137, + "name": "Pixel", + "symbol": "PIXEL", + "decimals": 4, + "address": "0x24f82AE063f165d621b2aEC10714eB989c51938A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1e906717de2e4a4600f13b6909736b0346bdde3e" + } + }, + { + "chainId": 137, + "name": "Vision Token", + "symbol": "VISION", + "decimals": 18, + "address": "0x034b2090b579228482520c589dbD397c53Fc51cC", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf406f7a9046793267bc276908778b29563323996" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/vision.svg" + }, + { + "chainId": 137, + "name": "Mireneum token", + "symbol": "MNE", + "decimals": 8, + "address": "0x8e600198218AEAEb6a4B4F84771dF8b38930ddcE", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x426CA1eA2406c07d75Db9585F22781c096e3d0E0" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mne.svg" + }, + { + "chainId": 137, + "name": "Benzene", + "symbol": "BZN", + "decimals": 18, + "address": "0xcD0D64C971AF8B477042130c5e6cD2A6f7842869", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6524b87960c2d573ae514fd4181777e7842435d4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bzn.svg" + }, + { + "chainId": 137, + "name": "Amp Token", + "symbol": "AMP", + "decimals": 18, + "address": "0x0621d647cecbFb64b79E44302c1933cB4f27054d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xff20817765cb7f73d4bde2e66e067e58d11095c2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/amp.svg" + }, + { + "chainId": 137, + "name": "Celsius", + "symbol": "CEL", + "decimals": 4, + "address": "0xD85d1e945766Fea5Eda9103F918Bd915FbCa63E6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xaaaebe6fe48e54f431b0c390cfaf0b017d09d42d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cel.svg" + }, + { + "chainId": 137, + "name": "SportX", + "symbol": "SX", + "decimals": 18, + "address": "0x840195888Db4D6A99ED9F73FcD3B225Bb3cB1A79", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x99fE3B1391503A1bC1788051347A1324bff41452" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/sx.svg" + }, + { + "chainId": 137, + "name": "Route", + "symbol": "ROUTE", + "decimals": 18, + "address": "0x16ECCfDbb4eE1A85A33f3A9B21175Cd7Ae753dB4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x16ECCfDbb4eE1A85A33f3A9B21175Cd7Ae753dB4" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/route.svg" + }, + { + "chainId": 137, + "name": "Rebalance Token", + "symbol": "RBAL", + "decimals": 18, + "address": "0x03247a4368A280bEc8133300cD930A3a61d604f6", + "logoURI": "https://cdn.coinranking.com/fLjFmBf-k/rbal.png", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe5a6739b21Fe84847daDE7152Ae6C68895dFdb38" + } + }, + { + "chainId": 137, + "name": "CHERRY", + "symbol": "CHERRY", + "decimals": 4, + "address": "0xbE32718f77Aa63d95658Ddd8EF472039c71Eb704", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4ecb692b0fedecd7b486b4c99044392784877e8c" + } + }, + { + "chainId": 137, + "name": "Axioms", + "symbol": "AXI", + "decimals": 18, + "address": "0x01fA5b3A5d77BcF705DD505bBcBb34bce310E7FE", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x73ee6d7e6b203125add89320e9f343d65ec7c39a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/axi.svg" + }, + { + "chainId": 137, + "name": "Deflect", + "symbol": "DEFLCT", + "decimals": 9, + "address": "0x80E3E8f5D06CbeF73c12e6bdc2f63563fE57f866", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3aa5f749d4a6bcf67dac1091ceb69d1f5d86fa53" + } + }, + { + "chainId": 137, + "name": "Devcash", + "symbol": "DEV", + "decimals": 8, + "address": "0xE951e4C7B0B91447C1a0A46BFb46630682A3f229", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0fca8fdb0fb115a33baadec6e7a141ffc1bc7d5a" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dev.svg" + }, + { + "chainId": 137, + "name": "Swirge", + "symbol": "SWG", + "decimals": 18, + "address": "0x043A3Aa319B563aC25D4E342d32bFfb51298DB7b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x92eF4FFBfe0Df030837b65d7FcCFE1ABd6549579" + } + }, + { + "chainId": 137, + "name": "SPRING Token", + "symbol": "SPRING", + "decimals": 18, + "address": "0xE0011abAb503659C48a07d44561A7eF077b1AD56", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfb0bdc444c8ae7e9b5beea5e4d1e8de93879e487" + } + }, + { + "chainId": 137, + "name": "Elementeum", + "symbol": "ELET", + "decimals": 18, + "address": "0x07738Eb4ce8932CA961c815Cb12C9d4ab5Bd0Da4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6c37Bf4f042712C978A73e3fd56D1F5738dD7C43" + } + }, + { + "chainId": 137, + "name": "THERA", + "symbol": "THERA", + "decimals": 18, + "address": "0xe2D460a2F928CbC4Cf3268f8d95dbd89c21202c4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xffb3518f60A967839e5bA5B2908C5D6840632c0f" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/thera.svg" + }, + { + "chainId": 137, + "name": "Pepedex", + "symbol": "PPDEX", + "decimals": 18, + "address": "0x127984b5E6d5c59f81DACc9F1C8b3Bdc8494572e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf1f508c7c9f0d1b15a76fba564eef2d956220cf7" + } + }, + { + "chainId": 137, + "name": "JUICE", + "symbol": "JUICE", + "decimals": 6, + "address": "0x28E96FFe75CdCc97044585b866BD02bD79C12dc0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x38e2FB9935952b00673cCB63daB105c9d698784E" + } + }, + { + "chainId": 137, + "name": "Koin", + "symbol": "XKO", + "decimals": 18, + "address": "0x7B276A55987E3020026Bb098F15E968313Bd1aF2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe93714F621c0481DF8685b956800568b364F138f" + } + }, + { + "chainId": 137, + "name": "Digital Coin", + "symbol": "DCB", + "decimals": 18, + "address": "0x1f71bC1F88f09EcE59E844dEA4FCc4fA73934117", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2d8e1dd483008c6843b9cf644bad7fb25bf52b84" + } + }, + { + "chainId": 137, + "name": "StableDark", + "symbol": "SDARK", + "decimals": 18, + "address": "0x12919A30447fF59947740507362A05B8BEA9A6e7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x26c7D50B9f372e1FA9cA078CC054298f36D68B17" + } + }, + { + "chainId": 137, + "name": "decentral.games", + "symbol": "$DG", + "decimals": 18, + "address": "0x2a93172c8DCCbfBC60a39d56183B7279a2F647b4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xee06a81a695750e71a662b51066f2c74cf4478a0" + } + }, + { + "chainId": 137, + "name": "Drakoin", + "symbol": "DRK", + "decimals": 18, + "address": "0xB6509Cbd9e2D1CeC787a7357eB1578B86a0c702d", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2369686fc9fb6e1fdc46541891568c2f341906ef" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/drk.svg" + }, + { + "chainId": 137, + "name": "Autonio", + "symbol": "NIOX", + "decimals": 4, + "address": "0xad684e79CE4b6D464f2Ff7c3FD51646892e24b96", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc813EA5e3b48BEbeedb796ab42A30C5599b01740" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/niox.svg" + }, + { + "chainId": 137, + "name": "HEX", + "symbol": "HEX", + "decimals": 8, + "address": "0x23D29D30e35C5e8D321e1dc9A8a61BFD846D4C5C", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2b591e99afe9f32eaa6214f7b7629768c40eeb39" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/hex.svg" + }, + { + "chainId": 137, + "name": "DarkPool", + "symbol": "pDARK", + "decimals": 18, + "address": "0x066028738CE85aa1946b9D05B1d0F06F3d0Fdb7A", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf62dC91f8f43b241840228B3a857FF9d6522660C" + } + }, + { + "chainId": 137, + "name": "Opu Coin", + "symbol": "OPU", + "decimals": 18, + "address": "0x7ff2FC33E161E3b1C6511B934F0209D304267857", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x65e3c4a750a2e7cc7cce86d01587bbcbbe99042e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/opu.svg" + }, + { + "chainId": 137, + "name": "Brand Tokens", + "symbol": "BRND", + "decimals": 18, + "address": "0x1683767B3e3a40a61D9faa94CF86E5788F0a834a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x41A6bFd5FC91B9822774d549674Cc90512b3a54A" + } + }, + { + "chainId": 137, + "name": "ERNE finance", + "symbol": "ERNE", + "decimals": 18, + "address": "0x52aF6aA779F36a53De44ae1969756a506b2577b5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xCf978BE45f74ab6f4dA0E68B24624657F40A3d9B" + } + }, + { + "chainId": 137, + "name": "Friendz Coin ", + "symbol": "FDZ", + "decimals": 18, + "address": "0x7D836dA4Dd2aFda1d09992980569E22597F09981", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x23352036e911a22cfc692b5e2e196692658aded9" + } + }, + { + "chainId": 137, + "name": "MCDEX Token", + "symbol": "MCB", + "decimals": 18, + "address": "0xCf46c5Bf01deAE14a272f89A7b6c9E96A48f5546", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4e352cf164e64adcbad318c3a1e222e9eba4ce42" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mcb.svg" + }, + { + "chainId": 137, + "name": "Galactican Founders Token", + "symbol": "GFT", + "decimals": 0, + "address": "0xc10aAcff41Af60BfCfaba3A03099c4AEdB113E15", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xF8dd0D8e2b646589E2273803c4fEF8a7Da8D6AdB" + } + }, + { + "chainId": 137, + "name": "BlazarBits", + "symbol": "BzB", + "decimals": 18, + "address": "0x462D8d82C2B2D2DDabf7f8a93928De09d47A5807", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5cd763f24e849e334cc8ed78d0e09970988cf4ad" + } + }, + { + "chainId": 137, + "name": "IG Orb", + "symbol": "ORB", + "decimals": 2, + "address": "0x5a2fdF906ada9353eBe496Fa5D351B39f8908d19", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xa7b12e22f318762f76a9a179c86babcb02e62734" + } + }, + { + "chainId": 137, + "name": "IG Gold", + "symbol": "IGG", + "decimals": 6, + "address": "0xe6FC6C7CB6d2c31b359A49A33eF08aB87F4dE7CE", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8ffe40a3d0f80c0ce6b203d5cdc1a6a86d9acaea" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/igg.svg" + }, + { + "chainId": 137, + "name": "DarkToken", + "symbol": "DARK", + "decimals": 18, + "address": "0x3F99009295dEDd768f7284AFE07cDfED70c3E3AC", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3108ccFd96816F9E663baA0E8c5951D229E8C6da" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dark.svg" + }, + { + "chainId": 137, + "name": "TrumpBux", + "symbol": "TBUX", + "decimals": 18, + "address": "0xc576E8BB0017AFfC2Cb245609E304E57401ee78a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9d29bD441E9DA3EfF48568Aea1348383544547e7" + } + }, + { + "chainId": 137, + "name": "Sapien Network", + "symbol": "SPN", + "decimals": 6, + "address": "0x3Cd92Be3Be24daf6D03c46863f868F82D74905bA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x20F7A3DdF244dc9299975b4Da1C39F8D5D75f05A" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/spn.svg" + }, + { + "chainId": 137, + "name": "KIWI Token", + "symbol": "KIWI", + "decimals": 8, + "address": "0x578360AdF0BbB2F10ec9cEC7EF89Ef495511ED5f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2BF91c18Cd4AE9C2f2858ef9FE518180F7B5096D" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/kiwi.svg" + }, + { + "chainId": 137, + "name": "0xBitcoin Token", + "symbol": "0xBTC", + "decimals": 8, + "address": "0x71B821aa52a49F32EEd535fCA6Eb5aa130085978", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xB6eD7644C69416d67B522e20bC294A9a9B405B31" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/0xbtc.svg" + }, + { + "chainId": 137, + "name": "Decentraland MANA", + "symbol": "MANA", + "decimals": 18, + "address": "0xA1c57f48F0Deb89f569dFbE6E2B7f46D33606fD4", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0F5D2fB29fb7d3CFeE444a200298f468908cC942" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/mana.svg" + }, + { + "chainId": 137, + "name": "yearn.finance", + "symbol": "YFI", + "decimals": 18, + "address": "0xDA537104D6A5edd53c6fBba9A898708E465260b6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0bc529c00C6401aEF6D220BE8C6Ea1667F6Ad93e" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/yfi.svg" + }, + { + "chainId": 137, + "name": "EthLend Token", + "symbol": "LEND", + "decimals": 18, + "address": "0x313d009888329C9d1cf4f75CA3f32566335bd604", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x80fB784B7eD66730e8b1DBd9820aFD29931aab03" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/lend.svg" + }, + { + "chainId": 137, + "name": "Compound", + "symbol": "COMP", + "decimals": 18, + "address": "0x8505b9d2254A7Ae468c0E9dd10Ccea3A837aef5c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc00e94Cb662C3520282E6f5717214004A7f26888" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/comp.svg" + }, + { + "chainId": 137, + "name": "Dummy ERC20", + "symbol": "DERC20", + "decimals": 18, + "address": "0xeFfdCB49C2D0EF813764B709Ca3c6fe71f230E3e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf2F3bD7Ca5746C5fac518f67D1BE87805a2Be82A" + } + }, + { + "chainId": 137, + "name": "Ether Stone", + "symbol": "ETHS", + "decimals": 18, + "address": "0x5Adf17a97Ef5DB18ad4cFC4B3F05128b922E0a58", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x11a207b158ddd17027e2dd5b1261a0a8012f6550" + } + }, + { + "chainId": 137, + "name": "BeatzCoin", + "symbol": "BTZC", + "decimals": 6, + "address": "0x81a9d2ecEd101479FaD8c9663f4A997fbE5c83cA", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x80640db285Cc63496bdd8c1980A7f4526A4D477F" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/btzc.svg" + }, + { + "chainId": 137, + "name": "SHIP20T5", + "symbol": "SHIP20T5", + "decimals": 18, + "address": "0x02dAEFc2E8AAD089d094579499508398E3057966", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa63a5122E849d2Fbff88Fc44d3C7EAE9196F1293" + } + }, + { + "chainId": 137, + "name": "One For All", + "symbol": "O4A", + "decimals": 36, + "address": "0x30810b6e871f333ea6935b21871cde070921bc38", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xce8e76aa57fa4d9f0db1c05c232fa4cf071aebba" + } + }, + { + "chainId": 137, + "name": "Castello Coin", + "symbol": "CAST", + "decimals": 8, + "address": "0xa554e5a79caebfeae867c66a56a951338f748c8a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3fab0bbaa03bceaf7c49e2b12877db0142be65fc" + } + }, + { + "chainId": 137, + "name": "EVER META", + "symbol": "EVEM", + "decimals": 18, + "address": "0x62a3c5d6346a842d24053d871ebe908a78cb46ab", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xeefa9e2e5be13b6531eb45ba47917017b5affffb" + } + }, + { + "chainId": 137, + "name": "Wrapped STOR", + "symbol": "WSTOR", + "decimals": 12, + "address": "0x5d1245ad0e4f118186042040bb092aba59be4167", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe51da1683f21a844269d0d23135f04c506ac8ae1" + } + }, + { + "chainId": 137, + "name": "WGMI", + "symbol": "WGMI", + "decimals": 18, + "address": "0x1b9f699c6cb0aa6079f326a11d3c960680eab5d9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x20f6a313cb250062331fe70b9567e3ee5f01888b" + } + }, + { + "chainId": 137, + "name": "TOMI", + "symbol": "TOMI", + "decimals": 18, + "address": "0xcd966b72cff52dc349089b6b6f5865b5743b4e08", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x533e90705c0d1a364eb63d620ea16c8478179894" + } + }, + { + "chainId": 137, + "name": "Menlo One", + "symbol": "ONE", + "decimals": 18, + "address": "0x6dc1ed4402a9db4956e077876e72d3ac7ba7f47f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4d807509aece24c0fa5a102b6a3b059ec6e14392" + } + }, + { + "chainId": 137, + "name": "Streamr (old)", + "symbol": "XDATA", + "decimals": 18, + "address": "0xd668c5e8a4a837ca95be5e3a8d5bd62f5985390d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x0cf0ee63788a0849fe5297f3407f701e122cc023" + } + }, + { + "chainId": 137, + "name": "Fei USD", + "symbol": "FEI", + "decimals": 18, + "address": "0xc7031408c7978da9aca03308cd104cb54e7a2eb3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x956f47f50a910163d8bf957cf5846d573e7f87ca" + } + }, + { + "chainId": 137, + "name": "Liquid staked Ether 2.0", + "symbol": "stETH", + "decimals": 18, + "address": "0x4c6b65fe93fc9daf413498b88195fafff36dd960", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xae7ab96520de3a18e5e111b5eaab095312d7fe84" + } + }, + { + "chainId": 137, + "name": "Tidal Token", + "symbol": "TIDAL", + "decimals": 18, + "address": "0xb41ec2c036f8a42da384dde6ada79884f8b84b26", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x29cbd0510eec0327992cd6006e63f9fa8e7f33b7" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/tidal.svg" + }, + { + "chainId": 137, + "name": "DC Token", + "symbol": "DC", + "decimals": 18, + "address": "0x3ebeb3f48f3a16b6a1e1e19b82c09bc8aae5d983", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb3fb97019e9f69d0fd2e76fbd113ec6960a5389a" + } + }, + { + "chainId": 137, + "name": "Wrapped Celo USD", + "symbol": "wCUSD", + "decimals": 18, + "address": "0x9fa22bda93a0ecef300928c0358003b63647c5d8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xad3e3fc59dff318beceaab7d00eb4f68b1ecf195" + } + }, + { + "chainId": 137, + "name": "JulSwap on ETH", + "symbol": "JulD", + "decimals": 18, + "address": "0x049f12f5a27132d06de128d48a914f6d82d33d23", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x93effd08e3e5a4b1b40c26137e63876b2501ffa4" + } + }, + { + "chainId": 137, + "name": "JUL", + "symbol": "JUL", + "decimals": 18, + "address": "0x03bc3f7affbe592e3f3502cf818aafb93b12334c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5580ab97f226c324c671746a1787524aef42e415" + } + }, + { + "chainId": 137, + "name": "OnX Ethereum Stablecoin", + "symbol": "onETH", + "decimals": 18, + "address": "0x057097bd91aa32aa10f5a42ba49637480963dc31", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc1330acbbce97cb9695b7ee161c0f95b875a8b0f" + } + }, + { + "chainId": 137, + "name": "QuadrantProtocol", + "symbol": "eQUAD", + "decimals": 18, + "address": "0xdab625853c2b35d0a9c6bd8e5a097a664ef4ccfb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc28e931814725bbeb9e670676fabbcb694fe7df2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/equad.svg" + }, + { + "chainId": 137, + "name": "Upfiring", + "symbol": "UFR", + "decimals": 18, + "address": "0x741b18e6db7a7dc3e686171b99387edc8dac1e32", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xea097a2b1db00627b2fa17460ad260c016016977" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ufr.svg" + }, + { + "chainId": 137, + "name": "Polkamon", + "symbol": "PMON", + "decimals": 18, + "address": "0xc8ed802a2cb6240b05b8c310137086bf4bc11b55", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1796ae0b0fa4862485106a0de9b654efe301d0b2" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pmon.svg" + }, + { + "chainId": 137, + "name": "Bidao", + "symbol": "BID", + "decimals": 18, + "address": "0xd7671bdce849eabef4da313ccc80e689151ee811", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x25e1474170c4c0aa64fa98123bdc8db49d7802fa" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/bid.svg" + }, + { + "chainId": 137, + "name": "UNION Protocol Governance Token", + "symbol": "UNN", + "decimals": 18, + "address": "0x67480287cb3715d1d9429b38772c71d6e94c16da", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x226f7b842e0f0120b7e194d05432b3fd14773a9d" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/unn.svg" + }, + { + "chainId": 137, + "name": "aleph.im v2", + "symbol": "ALEPH", + "decimals": 18, + "address": "0x82dcf1df86ada26b2dcd9ba6334cedb8c2448e9e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x27702a26126e0b3702af63ee09ac4d1a084ef628" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/aleph.svg" + }, + { + "chainId": 137, + "name": "Panvala pan", + "symbol": "PAN", + "decimals": 18, + "address": "0xe9949106f0777e7a2e36df891d59583ac94dc896", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xd56dac73a4d6766464b38ec6d91eb45ce7457c44" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/pan.svg" + }, + { + "chainId": 137, + "name": "CheerMedal", + "symbol": "CHML", + "decimals": 18, + "address": "0x3c711f725272b05336b44c5c9dccb9fe2ff42ef4", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfca0e33c4d9a7360a1caf517960be202c7693319" + } + }, + { + "chainId": 137, + "name": "Concentrated Voting Power", + "symbol": "CVP", + "decimals": 18, + "address": "0x530d954549f3efa00799784bc7fe0c3fed76da19", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x38e4adb44ef08f22f5b5b76a8f0c2d0dcbe7dca1" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/cvp.svg" + }, + { + "chainId": 137, + "name": "EASYX", + "symbol": "EASYX", + "decimals": 18, + "address": "0xd4c1e34187edc72fb6ebf3c4011dee50cabf89c2", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x346e2c8925d3bdc406181340eb7485d646055744" + } + }, + { + "chainId": 137, + "name": "DUST Token", + "symbol": "DUST", + "decimals": 18, + "address": "0x167ef3603c0b1d52be9a96e3af01aa33097a6ce9", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe2e109f1b4eaa8915655fe8fdefc112a34acc5f0" + } + }, + { + "chainId": 137, + "name": "Scalara NFT Index", + "symbol": "NFTI", + "decimals": 18, + "address": "0xc75ea0c71023c14952f3c7b9101ecbbaa14aa27a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x525ef76138bf76118d786dbedeae5f87aabf4a81" + } + }, + { + "chainId": 137, + "name": "Definitex", + "symbol": "DFX", + "decimals": 18, + "address": "0x142107a65d5c29c35129100bf386ba54f67a8668", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf1f5de69c9c8d9be8a7b01773cc1166d4ec6ede2" + } + }, + { + "chainId": 137, + "name": "Amplify Token", + "symbol": "AMPT", + "decimals": 18, + "address": "0x4ed92a1de77ee2638a2a42be48dd4720b3a2734a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3f17cfad23c2014c5a32722557df87dff46819da" + } + }, + { + "chainId": 137, + "name": "fees.wtf", + "symbol": "WTF", + "decimals": 18, + "address": "0x1b8acaac11250634028cf1735ca958fd46aaf320", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa68dd8cb83097765263adad881af6eed479c4a33" + } + }, + { + "chainId": 137, + "name": "WILD Token", + "symbol": "WILD", + "decimals": 18, + "address": "0x4c1705a7ddaa68fe187363487898705e040dd77e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd3c00772b24d997a812249ca637a921e81357701" + } + }, + { + "chainId": 137, + "name": "Herocoin", + "symbol": "PLAY", + "decimals": 18, + "address": "0x672255e73e9fcb8d8971b6e2622057baa84b5afe", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe477292f1b3268687a29376116b0ed27a9c76170" + } + }, + { + "chainId": 137, + "name": "PYR Token", + "symbol": "PYR", + "decimals": 18, + "address": "0x430ef9263e76dae63c84292c3409d61c598e9682", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x430ef9263e76dae63c84292c3409d61c598e9682" + } + }, + { + "chainId": 137, + "name": "Boba Token", + "symbol": "BOBA", + "decimals": 18, + "address": "0xa4b2b20b2c73c7046ed19ac6bff5e5285c58f20a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x42bbfa2e77757c645eeaad1655e0911a7553efbc" + } + }, + { + "chainId": 137, + "name": "Rocket Pool ETH", + "symbol": "rETH", + "decimals": 18, + "address": "0x0266f4f08d82372cf0fcbccc0ff74309089c74d1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xae78736cd615f374d3085123a210448e74fc6393" + } + }, + { + "chainId": 137, + "name": "humanDAO", + "symbol": "HDAO", + "decimals": 18, + "address": "0x72928d5436ff65e57f72d5566dcd3baedc649a88", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdac657ffd44a3b9d8aba8749830bf14beb66ff2d" + } + }, + { + "chainId": 137, + "name": "Immutable X", + "symbol": "IMX", + "decimals": 18, + "address": "0x183070c90b34a63292cc908ce1b263cb56d49a7f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf57e7e7c23978c3caec3c3548e3d615c346e79ff" + } + }, + { + "chainId": 137, + "name": "Fintropy", + "symbol": "FINT", + "decimals": 18, + "address": "0xd61143652af94f570c7d9429356662dd859ca6ec", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd61143652af94f570c7d9429356662dd859ca6ec" + } + }, + { + "chainId": 137, + "name": "Streamr", + "symbol": "DATA", + "decimals": 18, + "address": "0x3a9a81d576d83ff21f26f325066054540720fc34", + "logoURI": "https://raw.githubusercontent.com/streamr-dev/design-assets/main/Svg/Marks%20and%20Symbols/Token%20symbols/%24DATA%20new%20token%20symbol.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x8f693ca8d21b157107184d29d398a8d082b38b76" + } + }, + { + "chainId": 137, + "name": "DATA Economy Index", + "symbol": "DATA", + "decimals": 18, + "address": "0x1d607faa0a51518a7728580c238d912747e71f7a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x33d63ba1e57e54779f7ddaeaa7109349344cf5f1" + } + }, + { + "chainId": 137, + "name": "Float Bank", + "symbol": "BANK", + "decimals": 18, + "address": "0xfc2e967bf55f545d656de5c40618c1ae80eb6edf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x24a6a37576377f63f194caa5f518a60f45b42921" + } + }, + { + "chainId": 137, + "name": "Propy", + "symbol": "PRO", + "decimals": 8, + "address": "0x82ffdfd1d8699e8886a4e77cefa9dd9710a7fefd", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x226bb599a12c826476e3a771454697ea52e9e220" + } + }, + { + "chainId": 137, + "name": "BONE SHIBASWAP", + "symbol": "BONE", + "decimals": 18, + "address": "0xe15c40cae674a35dcd0108e66383e6f483533b82", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9813037ee2218799597d83d4a5b6f3b6778218d9" + } + }, + { + "chainId": 137, + "name": "Morpheus.Network", + "symbol": "MNW", + "decimals": 18, + "address": "0x3c59798620e5fec0ae6df1a19c6454094572ab92", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd3e4ba569045546d09cf021ecc5dfe42b1d7f6e4" + } + }, + { + "chainId": 137, + "name": "Internet of Energy Network", + "symbol": "IOEN", + "decimals": 18, + "address": "0xd0e9c8f5fae381459cf07ec506c1d2896e8b5df6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1e4e46b7bf03ece908c88ff7cc4975560010893a" + } + }, + { + "chainId": 137, + "name": "TAGBOND", + "symbol": "TAG", + "decimals": 18, + "address": "0x6a284bf3e568aea2c28010f061a85e107efdb6b6", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcc4ae94372da236e9b113132e0c46c68704246b9" + } + }, + { + "chainId": 137, + "name": "Smooth Love Potion", + "symbol": "SLP", + "decimals": 0, + "address": "0x0c7304fbaf2a320a1c50c46fe03752722f729946", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xcc8fa225d80b9c7d42f96e9570156c65d6caaa25" + } + }, + { + "chainId": 137, + "name": "BitcashPay", + "symbol": "BCP", + "decimals": 8, + "address": "0x5bc90f0d5fa1b716fb5edfda885a44bfc41b5594", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe047705117eb07e712c3d684f5b18e74577e83ac" + } + }, + { + "chainId": 137, + "name": "DragonBite", + "symbol": "BITE", + "decimals": 18, + "address": "0x280724409b288de06c6d66c05965d3d456e2283a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x4eed0fa8de12d5a86517f214c2f11586ba2ed88d" + } + }, + { + "chainId": 137, + "name": "PIKA", + "symbol": "PIKA", + "decimals": 18, + "address": "0xffb89d7637cf4860884ed48b57ae5562bf64e10f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x60f5672a271c7e39e787427a18353ba59a4a3578" + } + }, + { + "chainId": 137, + "name": "StaFi", + "symbol": "rATOM", + "decimals": 18, + "address": "0xe088651125864a2fdfe806257a9a7e75b53812ba", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd01cb3d113a864763dd3977fe1e725860013b0ed" + } + }, + { + "chainId": 137, + "name": "StaFi", + "symbol": "rETH", + "decimals": 18, + "address": "0x5736df66b4f8401d639ffa915a46b4c548c09ac1", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9559aaa82d9649c7a7b220e7c461d2e74c9a3593" + } + }, + { + "chainId": 137, + "name": "MoonieNFT Token", + "symbol": "MNY", + "decimals": 18, + "address": "0xa6f7645ed967faf708a614a2fca8d4790138586f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa6f7645ed967faf708a614a2fca8d4790138586f" + } + }, + { + "chainId": 137, + "name": "StaFi", + "symbol": "rFIS", + "decimals": 18, + "address": "0xa3983552d08ab820002a38baf51c5f3777c0d287", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xc82eb6dea0c93edb8b697b89ad1b13d19469d635" + } + }, + { + "chainId": 137, + "name": "Bondly", + "symbol": "BONDLY", + "decimals": 18, + "address": "0x64ca1571d1476b7a21c5aaf9f1a750a193a103c0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x91dfbee3965baaee32784c2d546b7a0c62f268c9" + } + }, + { + "chainId": 137, + "name": "Standard", + "symbol": "STND", + "decimals": 18, + "address": "0x08be454de533509e8832b257116c5506e55b0b64", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9040e237c3bf18347bb00957dc22167d0f2b999d" + } + }, + { + "chainId": 137, + "name": "Wilder", + "symbol": "WILD", + "decimals": 18, + "address": "0xf1a4015ae4d16ff64e41535fe973a1796c0203d6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2a3bff78b79a009976eea096a51a948a3dc00e34" + } + }, + { + "chainId": 137, + "name": "LMAO Token", + "symbol": "LMAO", + "decimals": 18, + "address": "0xda6f81c2426131337b0cf73768b94c2004390b0e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x69ef45cf64d8360279daa974aabadb42f0683a6c" + } + }, + { + "chainId": 137, + "name": "TitanSwap", + "symbol": "Titan", + "decimals": 18, + "address": "0x79ddc6ca9b76aa14dcfbd02bf75db588f5486df8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3a8cccb969a61532d1e6005e2ce12c200caece87" + } + }, + { + "chainId": 137, + "name": "StaFi", + "symbol": "FIS", + "decimals": 18, + "address": "0x7a7b94f18ef6ad056cda648588181cda84800f94", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xef3a930e1ffffacd2fc13434ac81bd278b0ecc8d" + } + }, + { + "chainId": 137, + "name": "PAID Network", + "symbol": "PAID", + "decimals": 18, + "address": "0xeaef6caf6d5894edb2d4ea7ec11ec4ab655f1cbf", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x1614f18fc94f47967a3fbe5ffcd46d4e7da3d787" + } + }, + { + "chainId": 137, + "name": "Kyber Network Crystal", + "symbol": "KNC", + "decimals": 18, + "address": "0x324b28d6565f784d596422b0f2e5ab6e9cfa1dc7", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdd974d5c2e2928dea5f71b9825b8b646686bd200" + } + }, + { + "chainId": 137, + "name": "UniCrypt", + "symbol": "UNC", + "decimals": 18, + "address": "0xfa2328d170d9476feafe1a6180abdb61a13a9494", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf29e46887ffae92f1ff87dfe39713875da541373" + } + }, + { + "chainId": 137, + "name": "Bankless Token", + "symbol": "BANK", + "decimals": 18, + "address": "0xdb7cb471dd0b49b29cab4a1c14d070f27216a0ab", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x2d94aa3e47d9d5024503ca8491fce9a2fb4da198" + } + }, + { + "chainId": 137, + "name": "NFT INDEX", + "symbol": "NFTI", + "decimals": 18, + "address": "0xd7a2dc75ea2057b3949f9e1dbdf3480203dbe26a", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe5feeac09d36b18b3fa757e5cf3f8da6b8e27f4c" + } + }, + { + "chainId": 137, + "name": "Bone", + "symbol": "Bone", + "decimals": 18, + "address": "0xc20dde5a129b01b5a16d315fb18bdbd21a59a4a6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x5c84bc60a796534bfec3439af0e6db616a966335" + } + }, + { + "chainId": 137, + "name": "Axie Infinity Shard", + "symbol": "AXS", + "decimals": 18, + "address": "0x61bdd9c7d4df4bf47a4508c0c8245505f2af5b7b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbb0e17ef65f82ab018d8edd776e8dd940327b28b" + } + }, + { + "chainId": 137, + "name": "SingularityNET Token", + "symbol": "AGIX", + "decimals": 8, + "address": "0x190eb8a183d22a4bdf278c6791b152228857c033", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x5b7533812759b45c2b44c19e320ba2cd2681b542" + } + }, + { + "chainId": 137, + "name": "PAR Stablecoin", + "symbol": "PAR", + "decimals": 18, + "address": "0x7b367a058f370c0057762280547d0b974cf3ac10", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x68037790a0229e9ce6eaa8a99ea92964106c4703" + } + }, + { + "chainId": 137, + "name": "Stone Token", + "symbol": "STN", + "decimals": 18, + "address": "0xfb8a07e99450d1dc566da18a8f0e630addefdd3e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe63d6b308bce0f6193aec6b7e6eba005f41e36ab" + } + }, + { + "chainId": 137, + "name": "FORCE", + "symbol": "FORCE", + "decimals": 18, + "address": "0x60c4f9718b445df881e6c00921afb2a8de4b1873", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6807d7f7df53b7739f6438eabd40ab8c262c0aa8" + } + }, + { + "chainId": 137, + "name": "Impermax", + "symbol": "IMX", + "decimals": 18, + "address": "0x60bb3d364b765c497c8ce50ae0ae3f0882c5bd05", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x7b35ce522cb72e4077baeb96cb923a5529764a00" + } + }, + { + "chainId": 137, + "name": "DFX Token", + "symbol": "DFX", + "decimals": 18, + "address": "0xe7804d91dfcde7f776c90043e03eaa6df87e6395", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x888888435fde8e7d4c54cab67f206e4199454c60" + } + }, + { + "chainId": 137, + "name": "BoringDAO DOGE", + "symbol": "oDOGE", + "decimals": 18, + "address": "0x5a8adda3140d961cd069cbb7b400d7834dd558ac", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x9c306a78b1a904e83115c05ac67c1ef07c653651" + } + }, + { + "chainId": 137, + "name": "Memecoin", + "symbol": "MEM", + "decimals": 18, + "address": "0x42dbbd5ae373fea2fc320f62d44c058522bb3758", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x42dbbd5ae373fea2fc320f62d44c058522bb3758" + } + }, + { + "chainId": 137, + "name": "BoringDAO", + "symbol": "BORING", + "decimals": 18, + "address": "0xff88434e29d1e2333ad6baa08d358b436196da6b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbc19712feb3a26080ebf6f2f7849b417fdd792ca" + } + }, + { + "chainId": 137, + "name": "Kyber Network Crystal v2", + "symbol": "KNC", + "decimals": 18, + "address": "0x1c954e8fe737f99f68fa1ccda3e51ebdb291948c", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xdefa4e8a7bcba345f687a2f1456f5edd9ce97202" + } + }, + { + "chainId": 137, + "name": "PlayDapp Token", + "symbol": "PLA", + "decimals": 18, + "address": "0x8765f05adce126d70bcdf1b0a48db573316662eb", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3a4f40631a4f906c2bad353ed06de7a5d3fcb430" + } + }, + { + "chainId": 137, + "name": "88mph.app", + "symbol": "MPH", + "decimals": 18, + "address": "0x654f82124a885af03d2da6b53c004343920ae189", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8888801af4d980682e47f1a9036e589479e835c5" + } + }, + { + "chainId": 137, + "name": "Litentry", + "symbol": "LIT", + "decimals": 18, + "address": "0xe6e320b7bb22018d6ca1f4d8cea1365ef5d25ced", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xb59490ab09a0f526cc7305822ac65f2ab12f9723" + } + }, + { + "chainId": 137, + "name": "B21 Token", + "symbol": "B21", + "decimals": 18, + "address": "0xad356bf748b9c320a5ddd4baaffa3f323eeb5546", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6faa826af0568d1866fca570da79b318ef114dab" + } + }, + { + "chainId": 137, + "name": "PieDAO Balanced Crypto Pie", + "symbol": "BCP", + "decimals": 18, + "address": "0x76e3f52ad78c367f23cfa08febf122053ee4f781", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe4f726adc8e89c6a6017f01eada77865db22da14" + } + }, + { + "chainId": 137, + "name": "Aave Interest bearing DAI", + "symbol": "aDAI", + "decimals": 18, + "address": "0x6a9d92f366f01b1980c4e75f0d9fa54db658105d", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xfc1e690f61efd961294b3e1ce3313fbd8aa4f85d" + } + }, + { + "chainId": 137, + "name": "Aave interest bearing DAI", + "symbol": "aDAI", + "decimals": 18, + "address": "0x329434fe066ac71d5fb93489f955a6959658097b", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x028171bca77440897b824ca71d1c56cac55b68a3" + } + }, + { + "chainId": 137, + "name": "LITonium", + "symbol": "LIT", + "decimals": 2, + "address": "0x7a46e5c2a19e371f23416fdf5930255589b95d3f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2e3c062e16c1a3a04ddc5003c62e294305d83684" + } + }, + { + "chainId": 137, + "name": "Force DAO", + "symbol": "FORCE", + "decimals": 18, + "address": "0xdf4d2226c810976c582a8111d831fa5fc543f7e5", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2c31b10ca416b82cec4c5e93c615ca851213d48d" + } + }, + { + "chainId": 137, + "name": "Morpher", + "symbol": "MPH", + "decimals": 18, + "address": "0xeba044af66a6d959c12e91fccd74ea1c3ca07578", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x6369c3dadfc00054a42ba8b2c09c48131dd4aa38" + } + }, + { + "chainId": 137, + "name": "The Crypto Prophecies", + "symbol": "TCP", + "decimals": 18, + "address": "0x032f85b8fbf8540a92b986d953e4c3a61c76d39e", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x06576eb3b212d605b797dc15523d9dc9f4f66db4" + } + }, + { + "chainId": 137, + "name": "MUNCH Token", + "symbol": "MUNCH", + "decimals": 9, + "address": "0x1002068d890ac351143bc5ae70711175e75f1ea8", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x944eee930933be5e23b690c8589021ec8619a301" + } + }, + { + "chainId": 137, + "name": "IdleUSDC v4 [Risk adjusted]", + "symbol": "idleUSDCSafe", + "decimals": 18, + "address": "0x73e86097021714509d3f193dfd0bbbc57b3cdcc6", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3391bc034f2935ef0e1e41619445f998b2680d35" + } + }, + { + "chainId": 137, + "name": "DFYN Token", + "symbol": "DFYN", + "decimals": 18, + "address": "0xc168e40227e4ebd8c1cae80f7a55a4f0e6d66c97", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x9695e0114e12c0d3a3636fab5a18e6b737529023" + } + }, + { + "chainId": 137, + "name": "onG", + "symbol": "ONG", + "decimals": 18, + "address": "0xb6f10be9201fb110b3aa275267a234e84ade8e95", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xd341d1680eeee3255b8c4c75bcce7eb57f144dae" + } + }, + { + "chainId": 137, + "name": "$Ankr ETH2 Reward Bearing Certificate", + "symbol": "aETHc", + "decimals": 18, + "address": "0xc4e82ba0fe6763cbe5e9cbca0ba7cbd6f91c6018", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xe95a203b1a91a908f9b9ce46459d101078c2c3cb" + } + }, + { + "chainId": 137, + "name": "BarnBridge Governance Token", + "symbol": "BOND", + "decimals": 18, + "address": "0xa041544fe2be56cce31ebb69102b965e06aace80", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0391d2021f89dc339f60fff84546ea23e337750f" + } + }, + { + "chainId": 137, + "name": "Showcase Token", + "symbol": "SHO", + "decimals": 18, + "address": "0x9e01e0a928588ae6e669b8d1f0f1fa4ab976f617", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcc0014ccb39f6e86b1be0f17859a783b6722722f" + } + }, + { + "chainId": 137, + "name": "Strudel Finance", + "symbol": "$TRDL", + "decimals": 18, + "address": "0xf89887862538ce8efbdbadd5d483ae4a09dd9688", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x297d33e17e61c2ddd812389c2105193f8348188a" + } + }, + { + "chainId": 137, + "name": "Metaverse NFT Index", + "symbol": "PLAY", + "decimals": 18, + "address": "0xdd24aa9166dcdf0b37d0fca17d6ea87748771dcc", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x33e18a092a93ff21ad04746c7da12e35d34dc7c4" + } + }, + { + "chainId": 137, + "name": "BoringDAO", + "symbol": "BOR", + "decimals": 18, + "address": "0x7d8c139d5bfbafdfd1d2d0284e7fc862babe4137", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x3c9d6c1c73b31c837832c72e04d3152f051fc1a9" + } + }, + { + "chainId": 137, + "name": "Yield", + "symbol": "YLD", + "decimals": 18, + "address": "0xb718412ef9c238c3a90079f21b57808ff8c18f1c", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xdcb01cc464238396e213a6fdd933e36796eaff9f" + } + }, + { + "chainId": 137, + "name": "Dentacoin", + "symbol": "٨", + "decimals": 0, + "address": "0xd9e658caed24fb0486e92f0f1702f77a712790da", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x08d32b0da63e2c3bcf8019c9c5d849d7a9d791e6" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/dcn.svg" + }, + { + "chainId": 137, + "name": "Generation of Yield", + "symbol": "YGY", + "decimals": 6, + "address": "0x266af96fece1c3dd4b8a0a6de9ae7a3bd5408ee9", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x11b0a8c0fa626627601ed518c3538a39d92d609e" + } + }, + { + "chainId": 137, + "name": "UniCrypt", + "symbol": "UNCX", + "decimals": 18, + "address": "0x9eecd634c7a934f752af0eb90dda9ecc262f199f", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xadb2437e6f65682b85f814fbc12fec0508a7b1d0" + } + }, + { + "chainId": 137, + "name": "Global Coin Research", + "symbol": "GCR", + "decimals": 4, + "address": "0xa69d14d6369e414a32a5c7e729b7afbafd285965", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x6307b25a665efc992ec1c1bc403c38f3ddd7c661" + } + }, + { + "chainId": 137, + "name": "FTT", + "symbol": "FTX Token", + "decimals": 18, + "address": "0x918c749a09fa539e1dc8019f875fab9eb1ebc6a3", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x50d1c9771902476076ecfc8b2a83ad6b9355a4c9" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/ftt.svg" + }, + { + "chainId": 137, + "name": "Yield", + "symbol": "YLD", + "decimals": 18, + "address": "0x4cebdbcb286101a17d3ea1f7fe7bbded2b2053dd", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xf94b5c5651c888d928439ab6514b93944eee6f48" + } + }, + { + "chainId": 137, + "name": "FLUX", + "symbol": "FLUX", + "decimals": 18, + "address": "0x2808edb7398b25e0f6c41cd98fd114d924008c87", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x469eda64aed3a3ad6f868c44564291aa415cb1d9" + } + }, + { + "chainId": 137, + "name": "Basic Attention Token", + "symbol": "BAT", + "decimals": 18, + "address": "0x3cef98bb43d732e2f285ee605a8158cde967d219", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x0d8775f648430679a709e98d2b0cb6250d2887ef" + } + }, + { + "chainId": 137, + "name": "iFARM", + "symbol": "iFARM", + "decimals": 18, + "address": "0xab0b2ddb9c7e440fac8e140a89c0dbcbf2d7bbff", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1571ed0bed4d987fe2b498ddbae7dfa19519f651" + } + }, + { + "chainId": 137, + "name": "LITION", + "symbol": "LIT", + "decimals": 18, + "address": "0xa8e198fc5c68264b185619a96748f855720494c0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x763fa6806e1acf68130d2d0f0df754c93cc546b2" + } + }, + { + "chainId": 137, + "name": "Wrapped Celo", + "symbol": "wCELO", + "decimals": 18, + "address": "0xc30dd0cce2e683aa68c87c280e73beb3dec9b3ba", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xe452e6ea2ddeb012e20db73bf5d3863a3ac8d77a" + } + }, + { + "chainId": 137, + "name": "Zeus", + "symbol": "ZUZ", + "decimals": 18, + "address": "0x232eab56c4fb3f84c6fb0a50c087c74b7b43c6ad", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x202f1877e1db1120ca3e9a98c5d505e7f035c249" + } + }, + { + "chainId": 137, + "name": "FARM Reward Token", + "symbol": "FARM", + "decimals": 18, + "address": "0x176f5ab638cf4ff3b6239ba609c3fadaa46ef5b0", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa0246c9032bc3a600820415ae600c6388619a14d" + } + }, + { + "chainId": 137, + "name": "MANTRA DAO", + "symbol": "OM", + "decimals": 18, + "address": "0xc3ec80343d2bae2f8e680fdadde7c17e71e114ea", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x3593d125a4f7849a1b059e64f4517a86dd60c95d" + } + }, + { + "chainId": 137, + "name": "Standard", + "symbol": "xMARK", + "decimals": 9, + "address": "0xf153eff70dc0bf3b085134928daeea248d9b30d0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x36b679bd64ed73dbfd88909cdcb892cb66bd4cbb" + } + }, + { + "chainId": 137, + "name": "SENTinel", + "symbol": "SENT", + "decimals": 8, + "address": "0x48e3883233461c2ef4cb3fcf419d6db07fb86cea", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xa44e5137293e855b1b7bc7e2c6f8cd796ffcb037" + } + }, + { + "chainId": 137, + "name": "Decentralized Insurance Protocol", + "symbol": "DIP", + "decimals": 18, + "address": "0xfeff6c1643d38b13a198cfe1d76505701c380af0", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xc719d010b63e5bbf2c0551872cd5316ed26acd83" + } + }, + { + "chainId": 137, + "name": "Ocean Token", + "symbol": "OCEAN", + "decimals": 18, + "address": "0x282d8efce846a88b159800bd4130ad77443fa1a1", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x967da4048cd07ab37855c090aaf366e4ce1b9f48" + } + }, + { + "chainId": 137, + "name": "TrustSwap Token", + "symbol": "SWAP", + "decimals": 18, + "address": "0x3809dcdd5dde24b37abe64a5a339784c3323c44f", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xcc4304a31d09258b0029ea7fe63d032f52e44efe" + } + }, + { + "chainId": 137, + "name": "Parachute", + "symbol": "PAR", + "decimals": 18, + "address": "0xf521d590fb1e0b432fd0e020cdbd6c6397d652c2", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x1beef31946fbbb40b877a72e4ae04a8d1a5cee06" + } + }, + { + "chainId": 137, + "name": "Dark Matter Token", + "symbol": "DMT", + "decimals": 18, + "address": "0xd28449bb9bb659725accad52947677cce3719fd7", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0x79126d32a86e6663f3aaac4527732d0701c1ae6c" + } + }, + { + "chainId": 137, + "name": "Binance Wrapped WRX", + "symbol": "BWRX", + "decimals": 8, + "address": "0x72d6066f486bd0052eefb9114b66ae40e0a6031a", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xff0a024b66739357c4ed231fb3dbc0c8c22749f5" + }, + "logoURI": "https://wallet-asset.matic.network/img/tokens/wrx.svg" + }, + { + "chainId": 137, + "name": "Distant Universe Stardust Token", + "symbol": "DUST", + "decimals": 8, + "address": "0x556f501cf8a43216df5bc9cc57eb04d4ffaa9e6d", + "logoURI": "https://raw.githubusercontent.com/BlockTimeWorld/crawler/main/icons/dust.svg", + "tags": [ + "pos", + "erc20", + "swapable" + ], + "extensions": { + "rootAddress": "0xbca3c97837a39099ec3082df97e28ce91be14472" + } + }, + { + "chainId": 137, + "name": "Ludena Protocol", + "symbol": "LDN", + "decimals": 18, + "address": "0x7df5638222bbe24cce39f726c3b61cc03610622a", + "logoURI": "https://www.ludenaprotocol.io/data/ludena_protocol_symbol_basic.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xb29663aa4e2e81e425294193616c1b102b70a158" + } + }, + { + "chainId": 137, + "name": "dForce", + "symbol": "DF", + "decimals": 18, + "address": "0x08C15FA26E519A78a666D19CE5C646D55047e0a3", + "logoURI": "https://raw.githubusercontent.com/dforce-network/documents/master/logos/dForce/DF.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x431ad2ff6a9C365805eBaD47Ee021148d6f7DBe0" + } + }, + { + "chainId": 137, + "name": "Orbit Chain", + "symbol": "ORC", + "decimals": 18, + "address": "0x1bd5048e0b85c410dd039aa9c05069a9d82488b8", + "logoURI": "https://s.ozys.io/icon/orbitchain.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x662b67d00a13faf93254714dd601f5ed49ef2f51" + } + }, + { + "chainId": 137, + "name": "ClayStack Staked MATIC", + "symbol": "csMATIC", + "decimals": 18, + "address": "0x7ed6390f38d554B8518eF30B925b46972E768AF8", + "logoURI": "https://raw.githubusercontent.com/ClayStack/media-kit/14dd5b413d744230b299d2008e98c63ef112bbb6/token-images/csMATIC.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x38b7Bf4eeCF3EB530b1529c9401FC37d2a71a912" + } + }, + { + "chainId": 137, + "name": "Thales DAO Token", + "symbol": "THALES", + "decimals": 18, + "address": "0x692c44990e4f408ba0917f5c78a83160c1557237", + "logoURI": "https://raw.githubusercontent.com/0xProject/0x-staking-pool-registry/master/logos/thales_logo.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8947da500eb47f82df21143d0c01a29862a8c3c5" + } + }, + { + "chainId": 137, + "name": "Only Graded Coin", + "symbol": "OGUC", + "decimals": 18, + "address": "0x2ae0e530ca7857b0e40078c43ba7158ce424838a", + "logoURI": "https://onlygradedcoin.com/assets/images/ogc-logo.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xB4F74994FCBd60E1bC3603b9a33069eA1b32d4A4" + } + }, + { + "chainId": 137, + "name": "TCGCoin", + "symbol": "TCGC", + "decimals": 18, + "address": "0x44ACD96620B708162af4A90524F29A6839675533", + "logoURI": "https://tcgverse-assets.s3.ap-northeast-1.amazonaws.com/tcgcoin_logo.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x2FFdE077455f81E28bAa675a46B9c085740216d4" + } + }, + { + "chainId": 137, + "name": "Cityroots", + "symbol": "UNITY", + "decimals": 18, + "address": "0x9d7313E23C29e6d314A160A3fF345a2f7Ab0f3f5", + "logoURI": "https://etherscan.io/token/images/cityrootsunity_32.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8fc1A87af3aD30a90cAa197B6c7aDb80d9F2aC44" + } + }, + { + "chainId": 137, + "name": "Respawn Finance Wrapped Staked Ethereum", + "symbol": "RFWSTETH", + "decimals": 18, + "address": "0x716ceb4Dc674FB91C4198c50b837F11f6ef75df0", + "logoURI": "https://assets.respawn.finance/rfwsteth.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x07FA101efde726E0956Edd2c4D5C8d3d1A5E9c53" + } + }, + { + "chainId": 137, + "name": "REVV Motorsport Shard", + "symbol": "SHRD", + "decimals": 18, + "address": "0xc99fd38d967944d7c3578afc4451920404c238d1", + "tags": [ + "pos", + "erc20", + "customWithdrawEventSig" + ], + "extensions": { + "rootAddress": "0x6d4a51c0ddfe6baeb7e233d6df5ae38a81f55c4b", + "withdrawEventSig": "0x7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5" + } + }, + { + "chainId": 137, + "name": "Liquid Staked Matic by Stader", + "symbol": "MaticX", + "decimals": 18, + "address": "0xfa68fb4628dff1028cfec22b4162fccd0d45efb6", + "logoURI": "https://user-images.githubusercontent.com/19915413/198746681-bcfd16fd-72e5-41b3-bcb8-5494d77195e0.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xf03a7eb46d01d9ecaa104558c732cf82f6b6b645" + } + }, + { + "chainId": 137, + "name": "AnimeToken", + "symbol": "ANX", + "decimals": 18, + "address": "0xe57EAC8b4666032Cfa16b626FfE99403a40b64D3", + "logoURI": "https://animebank.s3.ap-northeast-1.amazonaws.com/assets/anx.png", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x8DaDC5124714bEd53fbc603478De7D4BFEE1fF2a" + } + }, + { + "chainId": 137, + "name": "Cobak Token", + "symbol": "CBK", + "decimals": 18, + "address": "0x4EC203dD0699Fac6adAF483CDd2519BC05D2c573", + "logoURI": "https://storage.cobak.co/logo/cbk_symbol.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0xD85a6Ae55a7f33B0ee113C234d2EE308EdeAF7fD" + } + }, + { + "chainId": 137, + "name": "Apecoin", + "symbol": "APE", + "decimals": 18, + "address": "0xb7b31a6bc18e48888545ce79e83e06003be70930", + "logoURI": "https://wallet-asset.matic.network/img/tokens/ape.svg", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x4d224452801aced8b2f0aebe155379bb5d594381" + } + }, + { + "chainId": 137, + "name": "Across Protocol Token", + "symbol": "ACX", + "decimals": 18, + "address": "0xf328b73b6c685831f238c30a23fc19140cb4d8fc", + "logoURI": "https://2085701667-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2Fo33kX1T6RRp4inOcEH1d%2Fuploads%2FQCmyGUDBYGZjov370F6T%2Facross%20symbol.svg?alt=media&token=0dd53bc2-d38d-4e3e-b90f-f6c3c981a89e", + "tags": [ + "pos", + "erc20" + ], + "extensions": { + "rootAddress": "0x44108f0223A3C3028F5Fe7AEC7f9bb2E66beF82F" + } + } + ] +} \ No newline at end of file diff --git a/src/chains/polygon/polygon_tokens_mumbai.json b/src/chains/polygon/polygon_tokens_mumbai.json new file mode 100644 index 0000000000..5e92818bdf --- /dev/null +++ b/src/chains/polygon/polygon_tokens_mumbai.json @@ -0,0 +1,23 @@ +{ + "name": "mumbai", + "tokens": [ + { + "symbol": "WMATIC", + "chainId": 80001, + "address": "0x9c3c9283d3e44854697cd22d3faa240cfb032889", + "decimals": 18 + }, + { + "symbol": "WETH", + "chainId": 80001, + "address": "0xa6fa4fb5f76172d178d61b04b0ecd319c5d1c0aa", + "decimals": 18 + }, + { + "symbol": "DAI", + "chainId": 80001, + "address": "0xcb1e72786a6eb3b44c2a2429e317c8a2462cfeb1", + "decimals": 18 + } + ] +} diff --git a/src/connectors/connectors.routes.ts b/src/connectors/connectors.routes.ts new file mode 100644 index 0000000000..48d7f54636 --- /dev/null +++ b/src/connectors/connectors.routes.ts @@ -0,0 +1,102 @@ +import { Router } from 'express'; +import { asyncHandler } from '../services/error-handler'; +import { DefiraConfig } from './defira/defira.config'; +import { DefikingdomsConfig } from './defikingdoms/defikingdoms.config'; +import { MadMeerkatConfig } from './mad_meerkat/mad_meerkat.config'; +import { OpenoceanConfig } from './openocean/openocean.config'; +import { PangolinConfig } from './pangolin/pangolin.config'; +import { PerpConfig } from './perp/perp.config'; +import { QuickswapConfig } from './quickswap/quickswap.config'; +import { SushiswapConfig } from './sushiswap/sushiswap.config'; +import { TraderjoeConfig } from './traderjoe/traderjoe.config'; +import { UniswapConfig } from './uniswap/uniswap.config'; +import { VVSConfig } from './vvs/vvs.config'; +import { RefConfig } from './ref/ref.config'; +import { PancakeSwapConfig } from './pancakeswap/pancakeswap.config'; + +export namespace ConnectorsRoutes { + export const router = Router(); + + router.get( + '/', + asyncHandler(async (_req, res) => { + res.status(200).json({ + connectors: [ + { + name: 'uniswap', + trading_type: UniswapConfig.config.tradingTypes('swap'), + available_networks: UniswapConfig.config.availableNetworks, + }, + { + name: 'uniswapLP', + trading_type: UniswapConfig.config.tradingTypes('LP'), + available_networks: JSON.parse( + JSON.stringify(UniswapConfig.config.availableNetworks) + ), + additional_spenders: ['uniswap'], + }, + { + name: 'pangolin', + trading_type: PangolinConfig.config.tradingTypes, + available_networks: PangolinConfig.config.availableNetworks, + }, + { + name: 'openocean', + trading_type: OpenoceanConfig.config.tradingTypes, + available_networks: OpenoceanConfig.config.availableNetworks, + }, + { + name: 'quickswap', + trading_type: QuickswapConfig.config.tradingTypes, + available_networks: QuickswapConfig.config.availableNetworks, + }, + { + name: 'perp', + trading_type: PerpConfig.config.tradingTypes('perp'), + available_networks: PerpConfig.config.availableNetworks, + }, + { + name: 'sushiswap', + trading_type: SushiswapConfig.config.tradingTypes, + available_networks: SushiswapConfig.config.availableNetworks, + }, + { + name: 'traderjoe', + trading_type: TraderjoeConfig.config.tradingTypes, + available_networks: TraderjoeConfig.config.availableNetworks, + }, + { + name: 'defikingdoms', + trading_type: DefikingdomsConfig.config.tradingTypes, + available_networks: DefikingdomsConfig.config.availableNetworks, + }, + { + name: 'defira', + trading_type: DefiraConfig.config.tradingTypes, + available_networks: DefiraConfig.config.availableNetworks, + }, + { + name: 'mad_meerkat', + trading_type: MadMeerkatConfig.config.tradingTypes, + available_networks: MadMeerkatConfig.config.availableNetworks, + }, + { + name: 'vvs', + trading_type: VVSConfig.config.tradingTypes, + available_networks: VVSConfig.config.availableNetworks, + }, + { + name: 'ref', + trading_type: RefConfig.config.tradingTypes, + available_networks: RefConfig.config.availableNetworks, + }, + { + name: 'pancakeswap', + trading_type: PancakeSwapConfig.config.tradingTypes, + available_networks: PancakeSwapConfig.config.availableNetworks, + }, + ], + }); + }) + ); +} diff --git a/src/connectors/cronos-base/cronos-base-uniswapish-connector.config.ts b/src/connectors/cronos-base/cronos-base-uniswapish-connector.config.ts new file mode 100644 index 0000000000..cd61de43d3 --- /dev/null +++ b/src/connectors/cronos-base/cronos-base-uniswapish-connector.config.ts @@ -0,0 +1,38 @@ +import { AvailableNetworks } from '../../services/config-manager-types'; +import { ConfigManagerV2 } from '../../services/config-manager-v2'; + +export namespace CronosBaseUniswapishConnectorConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export function buildConfig( + connector: string, + tradingTypes: Array + ): NetworkConfig { + const contractAddresses: any = ConfigManagerV2.getInstance().get( + `${connector}.contractAddresses` // todo: test + ); + const networks: Array = Object.keys(contractAddresses); + return { + allowedSlippage: ConfigManagerV2.getInstance().get( + `${connector}.allowedSlippage` + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + `${connector}.gasLimitEstimate` + ), + ttl: ConfigManagerV2.getInstance().get(`${connector}.ttl`), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + `${connector}.contractAddresses.` + network + '.routerAddress' + ), + tradingTypes: tradingTypes, + availableNetworks: [{ chain: 'cronos', networks: networks }], + }; + } +} diff --git a/src/connectors/cronos-base/cronos-base-uniswapish-connector.ts b/src/connectors/cronos-base/cronos-base-uniswapish-connector.ts new file mode 100644 index 0000000000..1af2ef34af --- /dev/null +++ b/src/connectors/cronos-base/cronos-base-uniswapish-connector.ts @@ -0,0 +1,386 @@ +import { + ExpectedTrade, + Pairish, + Percentish, + TokenAmountish, + Tokenish, + Uniswapish, + UniswapishAmount, + UniswapishCurrency, + UniswapishSwapParameters, + UniswapishTrade, +} from '../../services/common-interfaces'; +import { + BigNumber, + Contract, + ContractInterface, + ContractTransaction, + Transaction, + Wallet, +} from 'ethers'; +import { CronosBaseUniswapishConnectorConfig } from './cronos-base-uniswapish-connector.config'; +import { Cronos } from '../../chains/cronos/cronos'; +import { logger } from '../../services/logger'; +import { UniswapishPriceError } from '../../services/error-handler'; +import { isFractionString } from '../../services/validators'; +import { percentRegexp } from '../../services/config-manager-v2'; + +export abstract class CronosBaseUniswapishConnector implements Uniswapish { + private static _instances: { [name: string]: CronosBaseUniswapishConnector }; + private _config: CronosBaseUniswapishConnectorConfig.NetworkConfig; + private _cronos: Cronos; + private _chainId: number; + private _chain: string; + private _router: string; + private _ttl: number; + private _gasLimitEstimate: number; + private _tokenList: Record = {}; + private _ready: boolean = false; + + protected constructor( + private _sdkProvider: CronosBaseUniswapishSDKProvider, + private readonly _routerAbi: ContractInterface, + chain: string, + network: string + ) { + this._config = this.buildConfig(); + this._cronos = Cronos.getInstance(network); + this._chainId = this._cronos.chainId; + this._chain = chain; + this._router = this._config.routerAddress(network); + this._ttl = this._config.ttl; + this._gasLimitEstimate = this._config.gasLimitEstimate; + } + + public async init() { + if (this._chain == 'cronos' && !this._cronos.ready()) + throw new Error('Cronos is not available'); + for (const token of this._cronos.storedTokenList) { + this._tokenList[token.address] = this._sdkProvider.buildToken( + this._chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + protected abstract buildConfig(): CronosBaseUniswapishConnectorConfig.NetworkConfig; + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Tokenish { + return this._tokenList[address]; + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + * @param allowedSlippage The slippage amount allowed + */ + public async estimateSellTrade( + baseToken: Tokenish, + quoteToken: Tokenish, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmountish = + this._sdkProvider.buildTokenAmount(baseToken, amount); + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + const pair: Pairish = await this._sdkProvider.fetchPairData( + baseToken, + quoteToken, + this._cronos.provider + ); + const trades: UniswapishTrade[] = this._sdkProvider.bestTradeExactIn( + [pair], + nativeTokenAmount, + quoteToken, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ${trades[0]}` + ); + const expectedAmount = this._sdkProvider.minimumAmountOut( + trades[0], + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + * @param allowedSlippage The slippage amount allowed + */ + public async estimateBuyTrade( + quoteToken: Tokenish, + baseToken: Tokenish, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmountish = + this._sdkProvider.buildTokenAmount(baseToken, amount); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const pair: Pairish = await this._sdkProvider.fetchPairData( + quoteToken, + baseToken, + this._cronos.provider + ); + const trades: UniswapishTrade[] = this._sdkProvider.bestTradeExactOut( + [pair], + quoteToken, + nativeTokenAmount, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ${trades[0]}` + ); + + const expectedAmount = this._sdkProvider.maximumAmountIn( + trades[0], + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Uniswap-ish trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param CronosBaseUniswapishConnectorRoute Router smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + * @param allowedSlippage The slippage amount allowe + */ + public async executeTrade( + wallet: Wallet, + trade: UniswapishTrade, + gasPrice: number, + CronosBaseUniswapishConnectorRoute: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise { + const result = this._sdkProvider.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract = new Contract( + CronosBaseUniswapishConnectorRoute, + abi, + wallet + ); + return this._cronos.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + let tx: ContractTransaction; + if (maxFeePerGas || maxPriorityFeePerGas) { + tx = await contract[result.methodName](...result.args, { + gasLimit: gasLimit, + value: result.value, + nonce: nextNonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await contract[result.methodName](...result.args, { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + }); + } + + logger.info(`Transaction Details: ${JSON.stringify(tx)}`); + return tx; + } + ); + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percentish { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return this._sdkProvider.buildPercent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = this._config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return this._sdkProvider.buildPercent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + public static getInstance( + this: { new (chain: string, network: string): T }, // see https://stackoverflow.com/questions/45123761/instantiating-child-class-from-a-static-method-in-base-class-using-typescript + chain: string, + network: string + ): CronosBaseUniswapishConnector { + if (CronosBaseUniswapishConnector._instances == undefined) { + CronosBaseUniswapishConnector._instances = {}; + } + + const instanceName = chain + network + this.name; + + if (!(instanceName in CronosBaseUniswapishConnector._instances)) { + CronosBaseUniswapishConnector._instances[instanceName] = new this( + chain, + network + ); + } + + return CronosBaseUniswapishConnector._instances[instanceName]; + } +} + +export interface CronosBaseUniswapishSDKProvider { + buildToken( + chainId: number, + address: string, + decimals: number, + symbol?: string, + name?: string, + projectLink?: string + ): Tokenish; + + buildTokenAmount(token: Tokenish, amount: BigNumber): TokenAmountish; + + fetchPairData( + tokenA: Tokenish, + tokenB: Tokenish, + provider?: import('@ethersproject/providers').BaseProvider + ): Promise; + + bestTradeExactIn( + pairs: Pairish[], + currencyAmountIn: UniswapishAmount, + currencyOut: UniswapishCurrency, + bestTradeOptions?: { + maxNumResults?: number; + maxHops?: number; + }, + currentPairs?: Pairish[], + originalAmountIn?: UniswapishAmount, + bestTrades?: UniswapishTrade[] + ): UniswapishTrade[]; + + bestTradeExactOut( + pairs: Pairish[], + currencyIn: UniswapishCurrency, + currencyAmountOut: UniswapishAmount, + bestTradeOptions?: { + maxNumResults?: number; + maxHops?: number; + }, + currentPairs?: Pairish[], + originalAmountOut?: UniswapishAmount, + bestTrades?: UniswapishTrade[] + ): UniswapishTrade[]; + + buildPercent(numerator: string, denominator?: string): Percentish; + + minimumAmountOut( + trade: UniswapishTrade, + slippageTolerance: Percentish + ): UniswapishAmount; + + maximumAmountIn( + trade: UniswapishTrade, + slippageTolerance: Percentish + ): UniswapishAmount; + + swapCallParameters( + trade: UniswapishTrade, + tradeOptions: { + allowedSlippage: Percentish; + ttl: number; + recipient: string; + feeOnTransfer?: boolean; + deadline?: number; + } + ): UniswapishSwapParameters; +} diff --git a/src/connectors/defikingdoms/defikingdoms.config.ts b/src/connectors/defikingdoms/defikingdoms.config.ts new file mode 100644 index 0000000000..8e5d81b891 --- /dev/null +++ b/src/connectors/defikingdoms/defikingdoms.config.ts @@ -0,0 +1,31 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; +export namespace DefikingdomsConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimit: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + `defikingdoms.allowedSlippage` + ), + gasLimit: ConfigManagerV2.getInstance().get(`defikingdoms.gasLimit`), + ttl: ConfigManagerV2.getInstance().get(`defikingdoms.ttl`), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + `defikingdoms.contractAddresses.${network}.routerAddress` + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [ + { + chain: 'harmony', + networks: ['mainnet'], + }, + ], + }; +} diff --git a/src/connectors/defikingdoms/defikingdoms.ts b/src/connectors/defikingdoms/defikingdoms.ts new file mode 100644 index 0000000000..a1d2460b07 --- /dev/null +++ b/src/connectors/defikingdoms/defikingdoms.ts @@ -0,0 +1,291 @@ +import { UniswapishPriceError } from '../../services/error-handler'; +import { isFractionString } from '../../services/validators'; +import { DefikingdomsConfig } from './defikingdoms.config'; +import routerAbi from './defikingdoms_router_abi.json'; +import { + Contract, + ContractInterface, + ContractTransaction, +} from '@ethersproject/contracts'; +import { + Fetcher, + Percent, + Router, + Token, + TokenAmount, + Trade, + Pair, + SwapParameters, + // } from '@defikingdoms/sdk'; +} from '@switchboard-xyz/defikingdoms-sdk'; +import { BigNumber, Transaction, Wallet } from 'ethers'; +import { logger } from '../../services/logger'; +import { percentRegexp } from '../../services/config-manager-v2'; +// import { Ethereum } from '../../chains/ethereum/ethereum'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; +import { Harmony } from '../../chains/harmony/harmony'; + +export class Defikingdoms implements Uniswapish { + private static _instances: { [name: string]: Defikingdoms }; + private harmony: Harmony; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(network: string) { + const config = DefikingdomsConfig.config; + this.harmony = Harmony.getInstance(network); + this.chainId = this.harmony.chainId; + this._ttl = DefikingdomsConfig.config.ttl; + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = DefikingdomsConfig.config.gasLimit; + this._router = config.routerAddress(network); + } + + public static getInstance(chain: string, network: string): Defikingdoms { + if (Defikingdoms._instances === undefined) { + Defikingdoms._instances = {}; + } + if (!(chain + network in Defikingdoms._instances)) { + // eslint-disable-next-line prettier/prettier + Defikingdoms._instances[chain + network] = new Defikingdoms(network); + } + + return Defikingdoms._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.harmony.ready()) { + await this.harmony.init(); + } + for (const token of this.harmony.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = DefikingdomsConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + + const pair: Pair = await this.fetchPairData(baseToken, quoteToken); + const trades: Trade[] = Trade.bestTradeExactIn( + [pair], + nativeTokenAmount, + quoteToken, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ` + + `${trades[0].executionPrice.toFixed(6)}` + + `${baseToken.name}.` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + logger.info( + JSON.stringify({ quoteToken, baseToken, provider: this.harmony.provider }) + ); + const pair: Pair = await this.fetchPairData(quoteToken, baseToken); + const trades: Trade[] = Trade.bestTradeExactOut( + [pair], + quoteToken, + nativeTokenAmount, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ` + + `${trades[0].executionPrice.invert().toFixed(6)} ` + + `${baseToken.name}.` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Defikingdoms trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param defikingdomsRouter Router smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + defikingdomsRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + _1?: BigNumber, + _2?: BigNumber, + allowedSlippage?: string + ): Promise { + const result: SwapParameters = Router.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract: Contract = new Contract(defikingdomsRouter, abi, wallet); + return this.harmony.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + const tx: ContractTransaction = await contract[result.methodName]( + ...result.args, + { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + } + ); + + logger.info(JSON.stringify(tx)); + return tx; + } + ); + } + + async fetchPairData(tokenA: Token, tokenB: Token): Promise { + return await Fetcher.fetchPairData(tokenA, tokenB, this.harmony.provider); + } +} diff --git a/src/connectors/defikingdoms/defikingdoms_router_abi.json b/src/connectors/defikingdoms/defikingdoms_router_abi.json new file mode 100644 index 0000000000..5a0d96a6f1 --- /dev/null +++ b/src/connectors/defikingdoms/defikingdoms_router_abi.json @@ -0,0 +1,1625 @@ +{ + "abi": [ + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "evm": { + "bytecode": { + "linkReferences": {}, + "object": "", + "opcodes": "", + "sourceMap": "" + }, + "deployedBytecode": { + "immutableReferences": {}, + "linkReferences": {}, + "object": "", + "opcodes": "", + "sourceMap": "" + } + }, + "metadata": "{\"compiler\":{\"version\":\"0.6.12+commit.27d51765\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"owner\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"spender\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"}],\"name\":\"Approval\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount0\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount1\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"}],\"name\":\"Burn\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount0\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount1\",\"type\":\"uint256\"}],\"name\":\"Mint\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount0In\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount1In\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount0Out\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount1Out\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"}],\"name\":\"Swap\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint112\",\"name\":\"reserve0\",\"type\":\"uint112\"},{\"indexed\":false,\"internalType\":\"uint112\",\"name\":\"reserve1\",\"type\":\"uint112\"}],\"name\":\"Sync\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"from\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"}],\"name\":\"Transfer\",\"type\":\"event\"},{\"inputs\":[],\"name\":\"DOMAIN_SEPARATOR\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"MINIMUM_LIQUIDITY\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"PERMIT_TYPEHASH\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"owner\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"spender\",\"type\":\"address\"}],\"name\":\"allowance\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"spender\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"}],\"name\":\"approve\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"balanceOf\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"}],\"name\":\"burn\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"amount0\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"amount1\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"decimals\",\"outputs\":[{\"internalType\":\"uint8\",\"name\":\"\",\"type\":\"uint8\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"factory\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getReserves\",\"outputs\":[{\"internalType\":\"uint112\",\"name\":\"reserve0\",\"type\":\"uint112\"},{\"internalType\":\"uint112\",\"name\":\"reserve1\",\"type\":\"uint112\"},{\"internalType\":\"uint32\",\"name\":\"blockTimestampLast\",\"type\":\"uint32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"kLast\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"}],\"name\":\"mint\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"liquidity\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"name\",\"outputs\":[{\"internalType\":\"string\",\"name\":\"\",\"type\":\"string\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"nonces\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"owner\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"spender\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"deadline\",\"type\":\"uint256\"},{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"name\":\"permit\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"price0CumulativeLast\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"price1CumulativeLast\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"}],\"name\":\"skim\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"amount0Out\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"amount1Out\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"swap\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"symbol\",\"outputs\":[{\"internalType\":\"string\",\"name\":\"\",\"type\":\"string\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"sync\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"token0\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"token1\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalSupply\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"}],\"name\":\"transfer\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"from\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"}],\"name\":\"transferFrom\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/interfaces/IUniswapV2Pair.sol\":\"IUniswapV2Pair\"},\"evmVersion\":\"istanbul\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"enabled\":true,\"runs\":999999},\"remappings\":[]},\"sources\":{\"contracts/interfaces/IUniswapV2Pair.sol\":{\"keccak256\":\"0x3368b1700fc4a77b780967cdd03c731da787a99f054f69f4b404d3cd3691712d\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://47521585cb5e7f2a8a1586b7d4f09e5ffc80929af8f9ed18012a1b4a82920b9f\",\"dweb:/ipfs/QmdHmVCdnyDq9GFDuRKXe69ATcY4ABXehHzoKRnzxtWNFv\"]}},\"version\":1}", + "interface": [ + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "owner", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "spender", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "value", + "type": "uint256" + } + ], + "name": "Approval", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount0", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount1", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "address", + "name": "to", + "type": "address" + } + ], + "name": "Burn", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount0", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount1", + "type": "uint256" + } + ], + "name": "Mint", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount0In", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount1In", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount0Out", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount1Out", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "address", + "name": "to", + "type": "address" + } + ], + "name": "Swap", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint112", + "name": "reserve0", + "type": "uint112" + }, + { + "indexed": false, + "internalType": "uint112", + "name": "reserve1", + "type": "uint112" + } + ], + "name": "Sync", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "from", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "value", + "type": "uint256" + } + ], + "name": "Transfer", + "type": "event" + }, + { + "inputs": [], + "name": "DOMAIN_SEPARATOR", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "MINIMUM_LIQUIDITY", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [], + "name": "PERMIT_TYPEHASH", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "owner", + "type": "address" + }, + { + "internalType": "address", + "name": "spender", + "type": "address" + } + ], + "name": "allowance", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "spender", + "type": "address" + }, + { + "internalType": "uint256", + "name": "value", + "type": "uint256" + } + ], + "name": "approve", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "owner", + "type": "address" + } + ], + "name": "balanceOf", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "to", + "type": "address" + } + ], + "name": "burn", + "outputs": [ + { + "internalType": "uint256", + "name": "amount0", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amount1", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "decimals", + "outputs": [ + { + "internalType": "uint8", + "name": "", + "type": "uint8" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getReserves", + "outputs": [ + { + "internalType": "uint112", + "name": "reserve0", + "type": "uint112" + }, + { + "internalType": "uint112", + "name": "reserve1", + "type": "uint112" + }, + { + "internalType": "uint32", + "name": "blockTimestampLast", + "type": "uint32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + }, + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "kLast", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "to", + "type": "address" + } + ], + "name": "mint", + "outputs": [ + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "name", + "outputs": [ + { + "internalType": "string", + "name": "", + "type": "string" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "owner", + "type": "address" + } + ], + "name": "nonces", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "owner", + "type": "address" + }, + { + "internalType": "address", + "name": "spender", + "type": "address" + }, + { + "internalType": "uint256", + "name": "value", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "permit", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "price0CumulativeLast", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "price1CumulativeLast", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "to", + "type": "address" + } + ], + "name": "skim", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amount0Out", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amount1Out", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "swap", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "symbol", + "outputs": [ + { + "internalType": "string", + "name": "", + "type": "string" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [], + "name": "sync", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "token0", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "token1", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "totalSupply", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "value", + "type": "uint256" + } + ], + "name": "transfer", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "from", + "type": "address" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "value", + "type": "uint256" + } + ], + "name": "transferFrom", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "bytecode": "" +} diff --git a/src/connectors/defira/defira.config.ts b/src/connectors/defira/defira.config.ts new file mode 100644 index 0000000000..739235add3 --- /dev/null +++ b/src/connectors/defira/defira.config.ts @@ -0,0 +1,36 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; +export namespace DefiraConfig { + export interface NetworkConfig { + allowedSlippage: () => string; + gasLimitEstimate: () => number; + ttl: () => number; + routerAddress: (network: string) => string; + initCodeHash: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: () => + ConfigManagerV2.getInstance().get(`defira.allowedSlippage`), + gasLimitEstimate: () => + ConfigManagerV2.getInstance().get(`defira.gasLimitEstimate`), + ttl: () => ConfigManagerV2.getInstance().get(`defira.ttl`), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + `defira.contractAddresses.${network}.routerAddress` + ), + initCodeHash: (network: string) => + ConfigManagerV2.getInstance().get( + `defira.contractAddresses.${network}.initCodeHash` + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [ + { + chain: 'harmony', + networks: ['mainnet', 'testnet'], + }, + ], + }; +} diff --git a/src/connectors/defira/defira.ts b/src/connectors/defira/defira.ts new file mode 100644 index 0000000000..a179310fcb --- /dev/null +++ b/src/connectors/defira/defira.ts @@ -0,0 +1,322 @@ +import { UniswapishPriceError } from '../../services/error-handler'; +import { isFractionString } from '../../services/validators'; +import { DefiraConfig } from './defira.config'; +import routerAbi from './defira_v2_router_abi.json'; +import { + Contract, + ContractInterface, + ContractTransaction, +} from '@ethersproject/contracts'; +import { + Router as DefiraRouter, + Pair as DefiraPair, + SwapParameters, + Trade as DefiraTrade, + Fetcher as DefiraFetcher, +} from '@zuzu-cat/defira-sdk'; + +import { Percent, Token, CurrencyAmount, TradeType } from '@uniswap/sdk-core'; +import { BigNumber, Transaction, Wallet } from 'ethers'; +import { logger } from '../../services/logger'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { Harmony } from '../../chains/harmony/harmony'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; + +export class Defira implements Uniswapish { + private static _instances: { [name: string]: Defira }; + private harmony: Harmony; + private _router: string; + private _factory: string | null; + private _routerAbi: ContractInterface; + private _initCodeHash: string; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(network: string) { + const config = DefiraConfig.config; + this.harmony = Harmony.getInstance(network); + this.chainId = this.harmony.chainId; + this._ttl = config.ttl(); + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = config.gasLimitEstimate(); + this._router = config.routerAddress(network); + this._initCodeHash = config.initCodeHash(network); + this._factory = null; + } + + public static getInstance(chain: string, network: string): Defira { + if (Defira._instances === undefined) { + Defira._instances = {}; + } + if (!(chain + network in Defira._instances)) { + Defira._instances[chain + network] = new Defira(network); + } + + return Defira._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.harmony.ready()) { + await this.harmony.init(); + } + for (const token of this.harmony.storedTokenList) { + this.tokenList[token.address] = new Token( + token.chainId || this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Lazily computed factory address. + */ + public get factory(): Promise { + // boilerplate to support async getter + return (async () => { + if (!this._factory) { + const routerContract = new Contract( + this.router, + this.routerAbi, + this.provider() + ); + this._factory = await routerContract.factory(); + } + return this._factory as string; + })(); + } + + /** + * Init code hash of Defira DEX Pair contract, used to compute individual pair addresses without network lookups + */ + public get initCodeHash(): string { + return this._initCodeHash; + } + + // in place for mocking + async fetchPairData(tokenA: Token, tokenB: Token): Promise { + return await DefiraFetcher.fetchPairData( + tokenA, + tokenB, + await this.factory, + this.initCodeHash, + this.provider() + ); + } + + // in place for mocking + provider(): any { + return this.harmony.provider; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = DefiraConfig.config.allowedSlippage(); + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const baseTokenAmount = CurrencyAmount.fromRawAmount( + baseToken, + amount.toString() + ); + + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + + const pair: DefiraPair = await this.fetchPairData(quoteToken, baseToken); + const trades: DefiraTrade[] = + DefiraTrade.bestTradeExactIn([pair], baseTokenAmount, quoteToken, { + maxHops: 1, + }); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken.address} to ${quoteToken.address}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ` + + `${trades[0].executionPrice.toFixed(6)}` + + `${baseToken.name}.` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const baseTokenAmount = CurrencyAmount.fromRawAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const pair: DefiraPair = await this.fetchPairData(quoteToken, baseToken); + const trades: DefiraTrade[] = + DefiraTrade.bestTradeExactOut([pair], quoteToken, baseTokenAmount, { + maxHops: 1, + }); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ` + + `${trades[0].executionPrice.invert().toFixed(6)} ` + + `${baseToken.name}.` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a defira trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param defiraRouter Router smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + */ + async executeTrade( + wallet: Wallet, + trade: DefiraTrade, + gasPrice: number, + defiraRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + _1?: BigNumber, + _2?: BigNumber, + allowedSlippage?: string + ): Promise { + const result: SwapParameters = DefiraRouter.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract: Contract = new Contract(defiraRouter, abi, wallet); + return this.harmony.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + const tx: ContractTransaction = await contract[result.methodName]( + ...result.args, + { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + } + ); + + logger.info(JSON.stringify(tx)); + return tx; + } + ); + } +} diff --git a/src/connectors/defira/defira_v2_router_abi.json b/src/connectors/defira/defira_v2_router_abi.json new file mode 100644 index 0000000000..14a192176b --- /dev/null +++ b/src/connectors/defira/defira_v2_router_abi.json @@ -0,0 +1,985 @@ +{ + "abi": [ + { + "inputs": [ + { + "type": "address", + "name": "_factory", + "internalType": "address" + }, + { + "internalType": "address", + "name": "_WETH", + "type": "address" + } + ], + "type": "constructor", + "stateMutability": "nonpayable" + }, + { + "name": "WETH", + "type": "function", + "inputs": [], + "outputs": [ + { + "internalType": "address", + "type": "address", + "name": "" + } + ], + "stateMutability": "view" + }, + { + "stateMutability": "view", + "name": "factory", + "type": "function", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address", + "internalType": "address" + } + ] + }, + { + "stateMutability": "payable", + "type": "receive" + }, + { + "name": "addLiquidity", + "type": "function", + "stateMutability": "nonpayable", + "outputs": [ + { + "name": "amountA", + "internalType": "uint256", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "name": "liquidity", + "type": "uint256", + "internalType": "uint256" + } + ], + "inputs": [ + { + "name": "tokenA", + "internalType": "address", + "type": "address" + }, + { + "name": "tokenB", + "type": "address", + "internalType": "address" + }, + { + "internalType": "uint256", + "type": "uint256", + "name": "amountADesired" + }, + { + "type": "uint256", + "name": "amountBDesired", + "internalType": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "name": "to", + "internalType": "address", + "type": "address" + }, + { + "name": "deadline", + "type": "uint256", + "internalType": "uint256" + } + ] + }, + { + "outputs": [ + { + "type": "uint256", + "name": "amountToken", + "internalType": "uint256" + }, + { + "name": "amountETH", + "internalType": "uint256", + "type": "uint256" + }, + { + "name": "liquidity", + "type": "uint256", + "internalType": "uint256" + } + ], + "type": "function", + "name": "addLiquidityETH", + "inputs": [ + { + "type": "address", + "name": "token", + "internalType": "address" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "amountTokenDesired" + }, + { + "name": "amountTokenMin", + "internalType": "uint256", + "type": "uint256" + }, + { + "internalType": "uint256", + "type": "uint256", + "name": "amountETHMin" + }, + { + "type": "address", + "internalType": "address", + "name": "to" + }, + { + "type": "uint256", + "name": "deadline", + "internalType": "uint256" + } + ], + "stateMutability": "payable" + }, + { + "type": "function", + "stateMutability": "nonpayable", + "inputs": [ + { + "name": "tokenA", + "type": "address", + "internalType": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "name": "liquidity", + "type": "uint256", + "internalType": "uint256" + }, + { + "type": "uint256", + "name": "amountAMin", + "internalType": "uint256" + }, + { + "name": "amountBMin", + "internalType": "uint256", + "type": "uint256" + }, + { + "name": "to", + "type": "address", + "internalType": "address" + }, + { + "type": "uint256", + "name": "deadline", + "internalType": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "amountB" + } + ] + }, + { + "stateMutability": "nonpayable", + "outputs": [ + { + "name": "amountToken", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "inputs": [ + { + "name": "token", + "type": "address", + "internalType": "address" + }, + { + "name": "liquidity", + "type": "uint256", + "internalType": "uint256" + }, + { + "name": "amountTokenMin", + "internalType": "uint256", + "type": "uint256" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "amountETHMin" + }, + { + "type": "address", + "internalType": "address", + "name": "to" + }, + { + "name": "deadline", + "type": "uint256", + "internalType": "uint256" + } + ], + "type": "function" + }, + { + "stateMutability": "nonpayable", + "type": "function", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "name": "amountB", + "type": "uint256", + "internalType": "uint256" + } + ], + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "name": "liquidity", + "internalType": "uint256", + "type": "uint256" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "amountAMin" + }, + { + "type": "uint256", + "name": "amountBMin", + "internalType": "uint256" + }, + { + "type": "address", + "name": "to", + "internalType": "address" + }, + { + "name": "deadline", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "name": "v", + "internalType": "uint8", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "name": "s", + "internalType": "bytes32", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit" + }, + { + "name": "removeLiquidityETHWithPermit", + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "name": "liquidity", + "internalType": "uint256", + "type": "uint256" + }, + { + "name": "amountTokenMin", + "internalType": "uint256", + "type": "uint256" + }, + { + "name": "amountETHMin", + "type": "uint256", + "internalType": "uint256" + }, + { + "type": "address", + "name": "to", + "internalType": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "name": "r", + "type": "bytes32", + "internalType": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "type": "function", + "stateMutability": "nonpayable", + "outputs": [ + { + "internalType": "uint256", + "type": "uint256", + "name": "amountToken" + }, + { + "internalType": "uint256", + "type": "uint256", + "name": "amountETH" + } + ] + }, + { + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "stateMutability": "nonpayable", + "inputs": [ + { + "name": "token", + "internalType": "address", + "type": "address" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "liquidity" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "amountTokenMin" + }, + { + "name": "amountETHMin", + "internalType": "uint256", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "deadline" + } + ], + "type": "function", + "outputs": [ + { + "type": "uint256", + "name": "amountETH", + "internalType": "uint256" + } + ] + }, + { + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "type": "function", + "stateMutability": "nonpayable", + "inputs": [ + { + "name": "token", + "type": "address", + "internalType": "address" + }, + { + "name": "liquidity", + "type": "uint256", + "internalType": "uint256" + }, + { + "name": "amountTokenMin", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "uint256", + "type": "uint256", + "name": "amountETHMin" + }, + { + "type": "address", + "internalType": "address", + "name": "to" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "type": "bool", + "name": "approveMax", + "internalType": "bool" + }, + { + "name": "v", + "type": "uint8", + "internalType": "uint8" + }, + { + "type": "bytes32", + "name": "r", + "internalType": "bytes32" + }, + { + "name": "s", + "type": "bytes32", + "internalType": "bytes32" + } + ], + "outputs": [ + { + "type": "uint256", + "name": "amountETH", + "internalType": "uint256" + } + ] + }, + { + "type": "function", + "inputs": [ + { + "name": "amountIn", + "type": "uint256", + "internalType": "uint256" + }, + { + "name": "amountOutMin", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "type": "address", + "name": "to", + "internalType": "address" + }, + { + "name": "deadline", + "type": "uint256", + "internalType": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "stateMutability": "nonpayable", + "outputs": [ + { + "name": "amounts", + "type": "uint256[]", + "internalType": "uint256[]" + } + ] + }, + { + "type": "function", + "outputs": [ + { + "name": "amounts", + "internalType": "uint256[]", + "type": "uint256[]" + } + ], + "inputs": [ + { + "type": "uint256", + "internalType": "uint256", + "name": "amountOut" + }, + { + "name": "amountInMax", + "internalType": "uint256", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "name": "to", + "internalType": "address", + "type": "address" + }, + { + "name": "deadline", + "type": "uint256", + "internalType": "uint256" + } + ], + "stateMutability": "nonpayable", + "name": "swapTokensForExactTokens" + }, + { + "inputs": [ + { + "name": "amountOutMin", + "type": "uint256", + "internalType": "uint256" + }, + { + "name": "path", + "type": "address[]", + "internalType": "address[]" + }, + { + "name": "to", + "internalType": "address", + "type": "address" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "deadline" + } + ], + "outputs": [ + { + "name": "amounts", + "internalType": "uint256[]", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "name": "swapExactETHForTokens", + "type": "function" + }, + { + "stateMutability": "nonpayable", + "type": "function", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "name": "swapTokensForExactETH", + "inputs": [ + { + "internalType": "uint256", + "type": "uint256", + "name": "amountOut" + }, + { + "name": "amountInMax", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "address[]", + "type": "address[]", + "name": "path" + }, + { + "type": "address", + "name": "to", + "internalType": "address" + }, + { + "type": "uint256", + "name": "deadline", + "internalType": "uint256" + } + ] + }, + { + "outputs": [ + { + "name": "amounts", + "type": "uint256[]", + "internalType": "uint256[]" + } + ], + "inputs": [ + { + "name": "amountIn", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "uint256", + "type": "uint256", + "name": "amountOutMin" + }, + { + "type": "address[]", + "name": "path", + "internalType": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "name": "deadline", + "type": "uint256", + "internalType": "uint256" + } + ], + "stateMutability": "nonpayable", + "name": "swapExactTokensForETH", + "type": "function" + }, + { + "inputs": [ + { + "name": "amountOut", + "type": "uint256", + "internalType": "uint256" + }, + { + "type": "address[]", + "internalType": "address[]", + "name": "path" + }, + { + "name": "to", + "type": "address", + "internalType": "address" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "deadline" + } + ], + "stateMutability": "payable", + "name": "swapETHForExactTokens", + "type": "function", + "outputs": [ + { + "internalType": "uint256[]", + "type": "uint256[]", + "name": "amounts" + } + ] + }, + { + "inputs": [ + { + "internalType": "uint256", + "type": "uint256", + "name": "amountIn" + }, + { + "name": "amountOutMin", + "type": "uint256", + "internalType": "uint256" + }, + { + "type": "address[]", + "name": "path", + "internalType": "address[]" + }, + { + "name": "to", + "internalType": "address", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "outputs": [], + "type": "function", + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "stateMutability": "nonpayable" + }, + { + "stateMutability": "payable", + "type": "function", + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "inputs": [ + { + "name": "amountOutMin", + "type": "uint256", + "internalType": "uint256" + }, + { + "type": "address[]", + "name": "path", + "internalType": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "name": "deadline", + "internalType": "uint256", + "type": "uint256" + } + ] + }, + { + "inputs": [ + { + "internalType": "uint256", + "type": "uint256", + "name": "amountIn" + }, + { + "name": "amountOutMin", + "internalType": "uint256", + "type": "uint256" + }, + { + "name": "path", + "internalType": "address[]", + "type": "address[]" + }, + { + "name": "to", + "internalType": "address", + "type": "address" + }, + { + "type": "uint256", + "name": "deadline", + "internalType": "uint256" + } + ], + "type": "function", + "outputs": [], + "stateMutability": "nonpayable", + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens" + }, + { + "name": "quote", + "inputs": [ + { + "type": "uint256", + "internalType": "uint256", + "name": "amountA" + }, + { + "name": "reserveA", + "type": "uint256", + "internalType": "uint256" + }, + { + "internalType": "uint256", + "type": "uint256", + "name": "reserveB" + } + ], + "outputs": [ + { + "type": "uint256", + "name": "amountB", + "internalType": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "name": "getAmountOut", + "outputs": [ + { + "name": "amountOut", + "type": "uint256", + "internalType": "uint256" + } + ], + "type": "function", + "inputs": [ + { + "name": "amountIn", + "type": "uint256", + "internalType": "uint256" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "reserveIn" + }, + { + "type": "uint256", + "internalType": "uint256", + "name": "reserveOut" + }, + { + "name": "swapFee", + "internalType": "uint256", + "type": "uint256" + } + ], + "stateMutability": "pure" + }, + { + "inputs": [ + { + "name": "amountOut", + "internalType": "uint256", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "type": "uint256", + "name": "reserveOut", + "internalType": "uint256" + }, + { + "internalType": "uint256", + "name": "swapFee", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "name": "amountIn", + "type": "uint256", + "internalType": "uint256" + } + ], + "type": "function", + "stateMutability": "pure" + }, + { + "type": "function", + "outputs": [ + { + "type": "uint256[]", + "name": "amounts", + "internalType": "uint256[]" + } + ], + "inputs": [ + { + "name": "amountIn", + "internalType": "uint256", + "type": "uint256" + }, + { + "type": "address[]", + "internalType": "address[]", + "name": "path" + } + ], + "name": "getAmountsOut", + "stateMutability": "view" + }, + { + "inputs": [ + { + "name": "amountOut", + "type": "uint256", + "internalType": "uint256" + }, + { + "name": "path", + "type": "address[]", + "internalType": "address[]" + } + ], + "stateMutability": "view", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "name": "getAmountsIn", + "type": "function" + } + ] +} diff --git a/src/connectors/mad_meerkat/abi.json b/src/connectors/mad_meerkat/abi.json new file mode 100644 index 0000000000..17d4976788 --- /dev/null +++ b/src/connectors/mad_meerkat/abi.json @@ -0,0 +1,1080 @@ +[ + { + "inputs": [ + { + "internalType": "address", + "name": "_factory", + "type": "address" + }, + { + "internalType": "address", + "name": "_WETH", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "previousOwner", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "newOwner", + "type": "address" + } + ], + "name": "OwnershipTransferred", + "type": "event" + }, + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "swapFee", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "swapFee", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "isOwner", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "owner", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "renounceOwnership", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_swapFeeReward", + "type": "address" + } + ], + "name": "setSwapFeeReward", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "swapFeeReward", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newOwner", + "type": "address" + } + ], + "name": "transferOwnership", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } +] diff --git a/src/connectors/mad_meerkat/mad_meerkat.config.ts b/src/connectors/mad_meerkat/mad_meerkat.config.ts new file mode 100644 index 0000000000..1fee15ee93 --- /dev/null +++ b/src/connectors/mad_meerkat/mad_meerkat.config.ts @@ -0,0 +1,10 @@ +import { CronosBaseUniswapishConnectorConfig } from '../cronos-base/cronos-base-uniswapish-connector.config'; + +export namespace MadMeerkatConfig { + const tradingTypes = ['EVM_AMM']; + export const config: CronosBaseUniswapishConnectorConfig.NetworkConfig = + CronosBaseUniswapishConnectorConfig.buildConfig( + 'mad_meerkat', + tradingTypes + ); +} diff --git a/src/connectors/mad_meerkat/mad_meerkat.ts b/src/connectors/mad_meerkat/mad_meerkat.ts new file mode 100644 index 0000000000..c4374998b4 --- /dev/null +++ b/src/connectors/mad_meerkat/mad_meerkat.ts @@ -0,0 +1,136 @@ +import { + Currency, + CurrencyAmount, + Fetcher, + Pair, + Percent, + Router, + Token, + TokenAmount, + Trade, +} from '@crocswap/sdk'; +import { BigNumber } from 'ethers'; +import { + Pairish, + Percentish, + UniswapishSwapParameters, +} from '../../services/common-interfaces'; +import { + CronosBaseUniswapishSDKProvider, + CronosBaseUniswapishConnector, +} from '../cronos-base/cronos-base-uniswapish-connector'; +import { CronosBaseUniswapishConnectorConfig } from '../cronos-base/cronos-base-uniswapish-connector.config'; +import routerAbi from './abi.json'; +import { MadMeerkatConfig } from './mad_meerkat.config'; + +export class MadMeerkat extends CronosBaseUniswapishConnector { + constructor(chain: string, network: string) { + const sdkProvider = new MadMeerkatSDKProvider(); + super(sdkProvider, routerAbi, chain, network); + } + protected buildConfig(): CronosBaseUniswapishConnectorConfig.NetworkConfig { + return MadMeerkatConfig.config; + } +} + +class MadMeerkatSDKProvider implements CronosBaseUniswapishSDKProvider { + public buildToken( + chainId: number, + address: string, + decimals: number, + symbol?: string, + name?: string, + projectLink?: string + ): Token { + return new Token(chainId, address, decimals, symbol, name, projectLink); + } + + public buildTokenAmount(token: Token, amount: BigNumber): TokenAmount { + return new TokenAmount(token, amount.toString()); + } + + public fetchPairData( + tokenA: Token, + tokenB: Token, + provider?: import('@ethersproject/providers').BaseProvider + ): Promise { + return Fetcher.fetchPairData(tokenA, tokenB, provider); + } + + public bestTradeExactIn( + pairs: Pair[], + currencyAmountIn: CurrencyAmount, + currencyOut: Currency, + bestTradeOptions?: { + maxNumResults?: number; + maxHops?: number; + }, + currentPairs?: Pair[], + originalAmountIn?: CurrencyAmount, + bestTrades?: Trade[] + ): Trade[] { + return Trade.bestTradeExactIn( + pairs, + currencyAmountIn, + currencyOut, + bestTradeOptions, + currentPairs, + originalAmountIn, + bestTrades + ); + } + + public bestTradeExactOut( + pairs: Pair[], + currencyIn: Currency, + currencyAmountOut: CurrencyAmount, + bestTradeOptions?: { + maxNumResults?: number; + maxHops?: number; + }, + currentPairs?: Pair[], + originalAmountOut?: CurrencyAmount, + bestTrades?: Trade[] + ): Trade[] { + return Trade.bestTradeExactOut( + pairs, + currencyIn, + currencyAmountOut, + bestTradeOptions, + currentPairs, + originalAmountOut, + bestTrades + ); + } + + public buildPercent(numerator: string, denominator?: string): Percentish { + return new Percent(numerator, denominator); + } + + public minimumAmountOut( + trade: Trade, + slippageTolerance: Percent + ): CurrencyAmount { + return trade.minimumAmountOut(slippageTolerance); + } + + public maximumAmountIn( + trade: Trade, + slippageTolerance: Percent + ): CurrencyAmount { + return trade.maximumAmountIn(slippageTolerance); + } + + public swapCallParameters( + trade: Trade, + tradeOptions: { + allowedSlippage: Percent; + ttl: number; + recipient: string; + feeOnTransfer?: boolean; + deadline?: number; + } + ): UniswapishSwapParameters { + return Router.swapCallParameters(trade, tradeOptions); + } +} diff --git a/src/connectors/openocean/openocean.config.ts b/src/connectors/openocean/openocean.config.ts new file mode 100644 index 0000000000..ccbb71152a --- /dev/null +++ b/src/connectors/openocean/openocean.config.ts @@ -0,0 +1,29 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; + +export namespace OpenoceanConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + 'openocean.allowedSlippage' + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + `pangolin.gasLimitEstimate` + ), + ttl: ConfigManagerV2.getInstance().get('openocean.ttl'), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + 'openocean.contractAddresses.' + network + '.routerAddress' + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [{ chain: 'avalanche', networks: ['avalanche'] }], + }; +} diff --git a/src/connectors/openocean/openocean.ts b/src/connectors/openocean/openocean.ts new file mode 100644 index 0000000000..160b50688f --- /dev/null +++ b/src/connectors/openocean/openocean.ts @@ -0,0 +1,412 @@ +import { percentRegexp } from '../../services/config-manager-v2'; +import { BigNumber, ContractInterface, Transaction, Wallet } from 'ethers'; +import { OpenoceanConfig } from './openocean.config'; +import { + Token, + TokenAmount, + Trade, + Pair, + TradeType, + Route, + Price, +} from '@uniswap/sdk'; +import Decimal from 'decimal.js-light'; +import axios from 'axios'; +import { logger } from '../../services/logger'; +import { Avalanche } from '../../chains/avalanche/avalanche'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; +import { + HttpException, + TRADE_FAILED_ERROR_CODE, + TRADE_FAILED_ERROR_MESSAGE, + UniswapishPriceError, + UNKNOWN_ERROR_ERROR_CODE, + UNKNOWN_ERROR_MESSAGE, +} from '../../services/error-handler'; + +export function newFakeTrade( + tokenIn: Token, + tokenOut: Token, + tokenInAmount: BigNumber, + tokenOutAmount: BigNumber +): Trade { + const baseAmount = new TokenAmount(tokenIn, tokenInAmount.toString()); + const quoteAmount = new TokenAmount(tokenOut, tokenOutAmount.toString()); + // Pair needs the reserves but this is not possible to pull in sushiswap contract + const pair = new Pair(baseAmount, quoteAmount); + const route = new Route([pair], tokenIn, tokenOut); + const trade = new Trade(route, baseAmount, TradeType.EXACT_INPUT); + // hack to set readonly component given we can't easily get pool token amounts + (trade.executionPrice as Price) = new Price( + tokenIn, + tokenOut, + tokenInAmount.toBigInt(), + tokenOutAmount.toBigInt() + ); + return trade; +} + +export class Openocean implements Uniswapish { + private static _instances: { [name: string]: Openocean }; + private avalanche: Avalanche; + private _chain: string; + private _router: string; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(chain: string, network: string) { + this._chain = chain; + const config = OpenoceanConfig.config; + this.avalanche = Avalanche.getInstance(network); + this.chainId = this.avalanche.chainId; + this._router = config.routerAddress(network); + this._ttl = config.ttl; + this._gasLimitEstimate = config.gasLimitEstimate; + } + + public static getInstance(chain: string, network: string): Openocean { + if (Openocean._instances === undefined) { + Openocean._instances = {}; + } + if (!(chain + network in Openocean._instances)) { + Openocean._instances[chain + network] = new Openocean(chain, network); + } + + return Openocean._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.avalanche.ready()) { + await this.avalanche.init(); + } + for (const token of this.avalanche.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return ''; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + public get chainName(): string { + return this._chain === 'avalanche' ? 'avax' : this._chain; + } + + getSlippageNumberage(): number { + const allowedSlippage = OpenoceanConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return Number(nd[1]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber + ): Promise { + logger.info( + `estimateSellTrade getting amounts out ${baseToken.address}-${quoteToken.address}.` + ); + + const reqAmount = new Decimal(amount.toString()) + .div(new Decimal((10 ** baseToken.decimals).toString())) + .toNumber(); + logger.info(`reqAmount:${reqAmount}`); + const gasPrice = this.avalanche.gasPrice; + let quoteRes; + try { + quoteRes = await axios.get( + `https://open-api.openocean.finance/v3/${this.chainName}/quote`, + { + params: { + inTokenAddress: baseToken.address, + outTokenAddress: quoteToken.address, + amount: reqAmount, + gasPrice: gasPrice, + }, + } + ); + } catch (e) { + if (e instanceof Error) { + logger.error(`Could not get trade info. ${e.message}`); + throw new HttpException( + 500, + TRADE_FAILED_ERROR_MESSAGE + e.message, + TRADE_FAILED_ERROR_CODE + ); + } else { + logger.error('Unknown error trying to get trade info.'); + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + + if (quoteRes.status == 200) { + if ( + quoteRes.data.code == 200 && + Number(quoteRes.data.data.outAmount) > 0 + ) { + const quoteData = quoteRes.data.data; + const amounts = [quoteData.inAmount, quoteData.outAmount]; + const maximumOutput = new TokenAmount( + quoteToken, + amounts[1].toString() + ); + const trade = newFakeTrade( + baseToken, + quoteToken, + BigNumber.from(amounts[0]), + BigNumber.from(amounts[1]) + ); + return { trade: trade, expectedAmount: maximumOutput }; + } else { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken.address} to ${quoteToken.address}.` + ); + } + } + throw new HttpException( + quoteRes.status, + `Could not get trade info. ${quoteRes.statusText}`, + TRADE_FAILED_ERROR_CODE + ); + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber + ): Promise { + logger.info( + `estimateBuyTrade getting amounts in ${quoteToken.address}-${baseToken.address}.` + ); + + const reqAmount = new Decimal(amount.toString()) + .div(new Decimal((10 ** baseToken.decimals).toString())) + .toNumber(); + logger.info(`reqAmount:${reqAmount}`); + const gasPrice = this.avalanche.gasPrice; + let quoteRes; + try { + quoteRes = await axios.get( + `https://open-api.openocean.finance/v3/${this.chainName}/reverseQuote`, + { + params: { + inTokenAddress: baseToken.address, + outTokenAddress: quoteToken.address, + amount: reqAmount, + gasPrice: gasPrice, + }, + } + ); + } catch (e) { + if (e instanceof Error) { + logger.error(`Could not get trade info. ${e.message}`); + throw new HttpException( + 500, + TRADE_FAILED_ERROR_MESSAGE + e.message, + TRADE_FAILED_ERROR_CODE + ); + } else { + logger.error('Unknown error trying to get trade info.'); + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + if (quoteRes.status == 200) { + if ( + quoteRes.data.code == 200 && + Number(quoteRes.data.data.reverseAmount) > 0 + ) { + const quoteData = quoteRes.data.data; + const amounts = [quoteData.reverseAmount, quoteData.inAmount]; + const minimumInput = new TokenAmount(quoteToken, amounts[0].toString()); + const trade = newFakeTrade( + quoteToken, + baseToken, + BigNumber.from(amounts[0]), + BigNumber.from(amounts[1]) + ); + return { trade: trade, expectedAmount: minimumInput }; + } else { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + } + throw new HttpException( + quoteRes.status, + `Could not get trade info. ${quoteRes.statusText}`, + TRADE_FAILED_ERROR_CODE + ); + } + + /** + * Given a wallet and a Uniswap-ish trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param openoceanRouter smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + openoceanRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise { + logger.info( + `executeTrade ${openoceanRouter}-${ttl}-${abi}-${gasPrice}-${gasLimit}-${nonce}-${maxFeePerGas}-${maxPriorityFeePerGas}.` + ); + const inToken: any = trade.route.input; + const outToken: any = trade.route.output; + let swapRes; + try { + swapRes = await axios.get( + `https://open-api.openocean.finance/v3/${this.chainName}/swap_quote`, + { + params: { + inTokenAddress: inToken.address, + outTokenAddress: outToken.address, + amount: trade.inputAmount.toExact(), + slippage: this.getSlippageNumberage(), + account: wallet.address, + gasPrice: gasPrice.toString(), + }, + } + ); + } catch (e) { + if (e instanceof Error) { + logger.error(`Could not get trade info. ${e.message}`); + throw new HttpException( + 500, + TRADE_FAILED_ERROR_MESSAGE + e.message, + TRADE_FAILED_ERROR_CODE + ); + } else { + logger.error('Unknown error trying to get trade info.'); + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + if (swapRes.status == 200 && swapRes.data.code == 200) { + const swapData = swapRes.data.data; + return this.avalanche.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + const gas = Math.ceil(Number(swapData.estimatedGas) * 1.15); + const trans = { + nonce: nextNonce, + from: swapData.from, + to: swapData.to, + gasLimit: BigNumber.from(gas.toString()), + data: swapData.data, + value: BigNumber.from(swapData.value), + chainId: this.chainId, + }; + const tx = await wallet.sendTransaction(trans); + logger.info(JSON.stringify(tx)); + + return tx; + } + ); + } + throw new HttpException( + swapRes.status, + `Could not get trade info. ${swapRes.statusText}`, + TRADE_FAILED_ERROR_CODE + ); + } +} diff --git a/src/connectors/pancakeswap/pancakeswap.config.ts b/src/connectors/pancakeswap/pancakeswap.config.ts new file mode 100644 index 0000000000..599fbb2bd9 --- /dev/null +++ b/src/connectors/pancakeswap/pancakeswap.config.ts @@ -0,0 +1,31 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; + +export namespace PancakeSwapConfig { + export interface ExchangeConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: ExchangeConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + 'pancakeswap.allowedSlippage' + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + `pancakeswap.gasLimitEstimate` + ), + ttl: ConfigManagerV2.getInstance().get('pancakeswap.ttl'), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + 'pancakeswap.contractAddresses.' + network + '.routerAddress' + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [ + { chain: 'binance-smart-chain', networks: ['mainnet', 'testnet'] }, + ], + }; +} diff --git a/src/connectors/pancakeswap/pancakeswap.ts b/src/connectors/pancakeswap/pancakeswap.ts new file mode 100644 index 0000000000..9296dad496 --- /dev/null +++ b/src/connectors/pancakeswap/pancakeswap.ts @@ -0,0 +1,316 @@ +import { + Fetcher, + Pair, + Percent, + Router, + SwapParameters, + Token, + TokenAmount, + Trade, +} from '@pancakeswap/sdk'; +import { + BigNumber, + Contract, + ContractInterface, + ContractTransaction, + Transaction, + Wallet, +} from 'ethers'; +import { BinanceSmartChain } from '../../chains/binance-smart-chain/binance-smart-chain'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { + InitializationError, + SERVICE_UNITIALIZED_ERROR_CODE, + SERVICE_UNITIALIZED_ERROR_MESSAGE, + UniswapishPriceError, +} from '../../services/error-handler'; +import { logger } from '../../services/logger'; +import { isFractionString } from '../../services/validators'; +import { PancakeSwapConfig } from './pancakeswap.config'; +import routerAbi from './pancakeswap_router_abi.json'; + +export class PancakeSwap implements Uniswapish { + private static _instances: { [name: string]: PancakeSwap }; + private bsc: BinanceSmartChain; + private chainId; + + private _chain: string; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(chain: string, network: string) { + const config = PancakeSwapConfig.config; + this.bsc = BinanceSmartChain.getInstance(network); + this.chainId = this.bsc.chainId; + + this._chain = chain; + this._router = config.routerAddress(network); + this._ttl = config.ttl; + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = config.gasLimitEstimate; + } + + public static getInstance(chain: string, network: string): PancakeSwap { + if (PancakeSwap._instances === undefined) { + PancakeSwap._instances = {}; + } + if (!(chain + network in PancakeSwap._instances)) { + PancakeSwap._instances[chain + network] = new PancakeSwap(chain, network); + } + + return PancakeSwap._instances[chain + network]; + } + + public async init() { + if (this._chain == 'binance-smart-chain' && !this.bsc.ready()) + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('BinanceSmartChain'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + for (const token of this.bsc.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + /* + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + /** + * Determines if the connector is ready. + */ + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = PancakeSwapConfig.config.allowedSlippage; + const matches = allowedSlippage.match(percentRegexp); + if (matches) return new Percent(matches[1], matches[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + * @param allowedSlippage (Optional) Fraction in string representing the allowed slippage for this transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + quoteToken, + baseToken, + this.bsc.provider + ); + const trades: Trade[] = Trade.bestTradeExactOut( + [pair], + quoteToken, + nativeTokenAmount, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ` + + `${trades[0].executionPrice.invert().toFixed(6)} ` + + `${baseToken.name}.` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + * @param allowedSlippage (Optional) Fraction in string representing the allowed slippage for this transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + + const pair: Pair = await Fetcher.fetchPairData( + baseToken, + quoteToken, + this.bsc.provider + ); + const trades: Trade[] = Trade.bestTradeExactIn( + [pair], + nativeTokenAmount, + quoteToken, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ` + + `${trades[0].executionPrice.toFixed(6)}` + + `${baseToken.name}.` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Uniswap trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param pancakeswapRouter Router smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + * @param allowedSlippage (Optional) Fraction in string representing the allowed slippage for this transaction + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + pancakeswapRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise { + const result: SwapParameters = Router.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract: Contract = new Contract(pancakeswapRouter, abi, wallet); + if (nonce === undefined) { + nonce = await this.bsc.nonceManager.getNextNonce(wallet.address); + } + let tx: ContractTransaction; + if (maxFeePerGas || maxPriorityFeePerGas) { + tx = await contract[result.methodName](...result.args, { + gasLimit: gasLimit, + value: result.value, + nonce: nonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await contract[result.methodName](...result.args, { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nonce, + }); + } + + logger.info(`Transaction Details: ${JSON.stringify(tx)}`); + await this.bsc.nonceManager.commitNonce(wallet.address, nonce); + return tx; + } +} diff --git a/src/connectors/pancakeswap/pancakeswap_router_abi.json b/src/connectors/pancakeswap/pancakeswap_router_abi.json new file mode 100644 index 0000000000..96c20e112e --- /dev/null +++ b/src/connectors/pancakeswap/pancakeswap_router_abi.json @@ -0,0 +1,975 @@ +{ + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_factory", + "type": "address" + }, + { + "internalType": "address", + "name": "_WETH", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ] +} diff --git a/src/connectors/pangolin/IPangolinRouter.json b/src/connectors/pangolin/IPangolinRouter.json new file mode 100644 index 0000000000..e9a153fcc7 --- /dev/null +++ b/src/connectors/pangolin/IPangolinRouter.json @@ -0,0 +1,962 @@ +{ + "_format": "hh-sol-artifact-1", + "contractName": "IPangolinRouter", + "sourceName": "contracts/pangolin-periphery/interfaces/IPangolinRouter.sol", + "abi": [ + { + "inputs": [], + "name": "WAVAX", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityAVAX", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAX", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityAVAX", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAX", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityAVAXSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountAVAX", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityAVAXWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAX", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityAVAXWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountAVAX", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapAVAXForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactAVAXForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactAVAXForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForAVAX", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForAVAXSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactAVAX", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "bytecode": "0x", + "deployedBytecode": "0x", + "linkReferences": {}, + "deployedLinkReferences": {} +} diff --git a/src/connectors/pangolin/pangolin.config.ts b/src/connectors/pangolin/pangolin.config.ts new file mode 100644 index 0000000000..13aa570ef7 --- /dev/null +++ b/src/connectors/pangolin/pangolin.config.ts @@ -0,0 +1,31 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; + +export namespace PangolinConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + 'pangolin.allowedSlippage' + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + `pangolin.gasLimitEstimate` + ), + ttl: ConfigManagerV2.getInstance().get('pangolin.ttl'), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + 'pangolin.contractAddresses.' + network + '.routerAddress' + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [ + { chain: 'avalanche', networks: ['avalanche', 'fuji'] }, + ], + }; +} diff --git a/src/connectors/pangolin/pangolin.ts b/src/connectors/pangolin/pangolin.ts new file mode 100644 index 0000000000..bc0a149e42 --- /dev/null +++ b/src/connectors/pangolin/pangolin.ts @@ -0,0 +1,295 @@ +import { percentRegexp } from '../../services/config-manager-v2'; +import { UniswapishPriceError } from '../../services/error-handler'; +import { + BigNumber, + Contract, + ContractInterface, + ContractTransaction, + Transaction, + Wallet, +} from 'ethers'; +import { isFractionString } from '../../services/validators'; +import { PangolinConfig } from './pangolin.config'; +import routerAbi from './IPangolinRouter.json'; +import { + Fetcher, + Percent, + Router, + Token, + TokenAmount, + Trade, + Pair, +} from '@pangolindex/sdk'; +import { logger } from '../../services/logger'; +import { Avalanche } from '../../chains/avalanche/avalanche'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; + +export class Pangolin implements Uniswapish { + private static _instances: { [name: string]: Pangolin }; + private avalanche: Avalanche; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(network: string) { + const config = PangolinConfig.config; + this.avalanche = Avalanche.getInstance(network); + this.chainId = this.avalanche.chainId; + this._router = config.routerAddress(network); + this._ttl = config.ttl; + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = config.gasLimitEstimate; + } + + public static getInstance(chain: string, network: string): Pangolin { + if (Pangolin._instances === undefined) { + Pangolin._instances = {}; + } + if (!(chain + network in Pangolin._instances)) { + Pangolin._instances[chain + network] = new Pangolin(network); + } + + return Pangolin._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.avalanche.ready()) { + await this.avalanche.init(); + } + for (const token of this.avalanche.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = PangolinConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + baseToken, + quoteToken, + this.avalanche.provider + ); + const trades: Trade[] = Trade.bestTradeExactIn( + [pair], + nativeTokenAmount, + quoteToken, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ${trades[0]}` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + quoteToken, + baseToken, + this.avalanche.provider + ); + const trades: Trade[] = Trade.bestTradeExactOut( + [pair], + quoteToken, + nativeTokenAmount, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ${trades[0]}` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Uniswap-ish trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param pangolinRouter smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + pangolinRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise { + const result = Router.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract = new Contract(pangolinRouter, abi, wallet); + return this.avalanche.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + let tx: ContractTransaction; + if (maxFeePerGas || maxPriorityFeePerGas) { + tx = await contract[result.methodName](...result.args, { + gasLimit: gasLimit, + value: result.value, + nonce: nextNonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await contract[result.methodName](...result.args, { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + }); + } + + logger.info(JSON.stringify(tx)); + return tx; + } + ); + } +} diff --git a/src/connectors/perp/perp.config.ts b/src/connectors/perp/perp.config.ts new file mode 100644 index 0000000000..7dfdaba74c --- /dev/null +++ b/src/connectors/perp/perp.config.ts @@ -0,0 +1,18 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; +export namespace PerpConfig { + export interface NetworkConfig { + allowedSlippage: string; + ttl: number; + tradingTypes: (type: string) => Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get(`perp.allowedSlippage`), + ttl: ConfigManagerV2.getInstance().get(`perp.versions.ttl`), + tradingTypes: (type: string) => + type === 'perp' ? ['EVM_Perpetual'] : ['EVM_AMM_LP'], + availableNetworks: [{ chain: 'ethereum', networks: ['optimism'] }], + }; +} diff --git a/src/connectors/perp/perp.controllers.ts b/src/connectors/perp/perp.controllers.ts new file mode 100644 index 0000000000..06f792c1f8 --- /dev/null +++ b/src/connectors/perp/perp.controllers.ts @@ -0,0 +1,229 @@ +import { Transaction } from 'ethers'; +import { + HttpException, + TOKEN_NOT_SUPPORTED_ERROR_CODE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + INCOMPLETE_REQUEST_PARAM, + INCOMPLETE_REQUEST_PARAM_CODE, + UNKNOWN_ERROR_ERROR_CODE, + UNKNOWN_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { TokenInfo } from '../../services/ethereum-base'; +import { latency, gasCostInEthString } from '../../services/base'; +import { + Ethereumish, + Tokenish, + Perpish, +} from '../../services/common-interfaces'; +import { logger } from '../../services/logger'; +import { + EstimateGasResponse, + PriceRequest, + PerpPricesResponse, + PerpCreateTakerRequest, + PerpCreateTakerResponse, + PerpAvailablePairsResponse, + PerpPositionRequest, + PerpPositionResponse, + PerpMarketRequest, + PerpMarketResponse, + PerpBalanceResponse, +} from '../../amm/amm.requests'; +import { PerpPosition } from './perp'; + +export async function getPriceData( + ethereumish: Ethereumish, + perpish: Perpish, + req: PriceRequest +): Promise { + const startTimestamp: number = Date.now(); + let prices; + try { + prices = await perpish.prices(`${req.base}${req.quote}`); + } catch (e) { + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: req.base, + quote: req.quote, + markPrice: prices.markPrice.toString(), + indexPrice: prices.indexPrice.toString(), + indexTwapPrice: prices.indexTwapPrice.toString(), + }; +} + +export async function getAvailablePairs( + ethereumish: Ethereumish, + perpish: Perpish +): Promise { + const startTimestamp: number = Date.now(); + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + pairs: perpish.availablePairs(), + }; +} + +export async function checkMarketStatus( + ethereumish: Ethereumish, + perpish: Perpish, + req: PerpMarketRequest +): Promise { + const startTimestamp: number = Date.now(); + const status = await perpish.isMarketActive(`${req.base}${req.quote}`); + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: req.base, + quote: req.quote, + isActive: status, + }; +} + +export async function getPosition( + ethereumish: Ethereumish, + perpish: Perpish, + req: PerpPositionRequest +): Promise { + const startTimestamp: number = Date.now(); + const position = await perpish.getPositions(`${req.base}${req.quote}`); + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: req.base, + quote: req.quote, + ...(position as PerpPosition), + }; +} + +export async function createTakerOrder( + ethereumish: Ethereumish, + perpish: Perpish, + req: PerpCreateTakerRequest, + isOpen: boolean +): Promise { + const startTimestamp: number = Date.now(); + + const gasPrice: number = ethereumish.gasPrice; + let tx: Transaction; + + if (isOpen) { + if (!req.amount && !req.side) { + throw new HttpException( + 500, + INCOMPLETE_REQUEST_PARAM, + INCOMPLETE_REQUEST_PARAM_CODE + ); + } + + tx = await perpish.openPosition( + req.side === 'LONG' ? true : false, + `${req.base}${req.quote}`, + req.amount as string, + req.allowedSlippage + ); + } else { + tx = await perpish.closePosition( + `${req.base}${req.quote}`, + req.allowedSlippage + ); + } + + await ethereumish.txStorage.saveTx( + ethereumish.chain, + ethereumish.chainId, + tx.hash as string, + new Date(), + ethereumish.gasPrice + ); + + logger.info( + `Order has been sent, txHash is ${tx.hash}, nonce is ${tx.nonce}, gasPrice is ${gasPrice}.` + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: req.base, + quote: req.quote, + amount: req.amount ? req.amount : '0', + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: perpish.gasLimit, + gasCost: gasCostInEthString(gasPrice, perpish.gasLimit), + nonce: tx.nonce, + txHash: tx.hash, + }; +} + +export function getFullTokenFromSymbol( + ethereumish: Ethereumish, + perpish: Perpish, + tokenSymbol: string +): Tokenish { + const tokenInfo: TokenInfo | undefined = + ethereumish.getTokenBySymbol(tokenSymbol); + let fullToken: Tokenish | undefined; + if (tokenInfo) { + fullToken = perpish.getTokenByAddress(tokenInfo.address); + } + if (!fullToken) + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + tokenSymbol, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + return fullToken; +} + +export async function estimateGas( + ethereumish: Ethereumish, + perpish: Perpish +): Promise { + const gasPrice: number = ethereumish.gasPrice; + const gasLimit: number = perpish.gasLimit; + return { + network: ethereumish.chain, + timestamp: Date.now(), + gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit, + gasCost: gasCostInEthString(gasPrice, gasLimit), + }; +} + +export async function getAccountValue( + ethereumish: Ethereumish, + perpish: Perpish +): Promise { + const startTimestamp: number = Date.now(); + let value; + try { + value = await perpish.getAccountValue(); + } catch (e) { + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + balance: value.toString(), + }; +} diff --git a/src/connectors/perp/perp.ts b/src/connectors/perp/perp.ts new file mode 100644 index 0000000000..0590673c52 --- /dev/null +++ b/src/connectors/perp/perp.ts @@ -0,0 +1,293 @@ +import { + HttpException, + InitializationError, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, + SERVICE_UNITIALIZED_ERROR_CODE, + SERVICE_UNITIALIZED_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { isFractionString } from '../../services/validators'; +import { PerpConfig } from './perp.config'; +import { + PerpetualProtocol, + MarketStatus, + Position, + Positions, + PositionSide, + ClearingHouse, +} from '@perp/sdk-curie'; +import { Token } from '@uniswap/sdk'; +import { Big } from 'big.js'; +import { Transaction, Wallet } from 'ethers'; +import { logger } from '../../services/logger'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { Ethereum } from '../../chains/ethereum/ethereum'; +import { Perpish } from '../../services/common-interfaces'; + +export interface PerpPosition { + positionAmt: string; + positionSide: string; + unrealizedProfit: string; + leverage: string; + entryPrice: string; + tickerSymbol: string; + pendingFundingPayment: string; +} + +export class Perp implements Perpish { + private static _instances: { [name: string]: Perp }; + private ethereum: Ethereum; + private _perp: PerpetualProtocol; + private _address: string; + private _wallet?: Wallet; + private _chain: string; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + public gasLimit = 16000000; // Default from perpfi https://github.com/perpetual-protocol/sdk-curie/blob/6211010ce6ddeb24312085775fc7e64336e426da/src/transactionSender/index.ts#L44 + + private constructor(chain: string, network: string, address?: string) { + this._chain = chain; + this.ethereum = Ethereum.getInstance(network); + this.chainId = this.ethereum.chainId; + this._perp = new PerpetualProtocol({ + chainId: this.chainId, + providerConfigs: [{ rpcUrl: this.ethereum.rpcUrl }], + }); + this._address = address ? address : ''; + } + + public get perp(): PerpetualProtocol { + return this._perp; + } + + public static getInstance( + chain: string, + network: string, + address?: string + ): Perp { + if (Perp._instances === undefined) { + Perp._instances = {}; + } + + if (!(chain + network + address in Perp._instances)) { + Perp._instances[chain + network + address] = new Perp( + chain, + network, + address + ); + } + + return Perp._instances[chain + network + address]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (this._chain == 'ethereum' && !this.ethereum.ready()) + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('ETH'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + for (const token of this.ethereum.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + await this._perp.init(); + if (this._address !== '') { + try { + this._wallet = await this.ethereum.getWallet(this._address); + } catch (err) { + logger.error(`Wallet ${this._address} not available.`); + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + + await this._perp.connect({ signer: this._wallet }); + logger.info( + `${this._wallet.address} wallet connected on perp ${this._chain}.` + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): number { + let allowedSlippage; + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + allowedSlippage = allowedSlippageStr; + } else allowedSlippage = PerpConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return Number(nd[1]) / Number(nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * @returns a list of available marker pairs. + */ + availablePairs(): string[] { + return Object.keys(this._perp.markets.marketMap); + } + + /** + * Queries for the market, index and indexTwap prices for a given market pair. + * @param tickerSymbol Market pair + */ + async prices(tickerSymbol: string): Promise<{ + markPrice: Big; + indexPrice: Big; + indexTwapPrice: Big; + }> { + const market = this._perp.markets.getMarket({ tickerSymbol }); + return await market.getPrices({ cache: false }); + } + + /** + * Used to know if a market is active/tradable. + * @param tickerSymbol Market pair + * @returns true | false + */ + async isMarketActive(tickerSymbol: string): Promise { + const market = this._perp.markets.getMarket({ tickerSymbol }); + return (await market.getStatus()) === MarketStatus.ACTIVE ? true : false; + } + + /** + * Gets available Position. + * @param tickerSymbol An optional parameter to get specific position. + * @returns Return all Positions or specific position. + */ + async getPositions(tickerSymbol: string): Promise { + const positions = this._perp.positions; + let positionAmt: string = '0', + positionSide: string = '', + unrealizedProfit: string = '0', + leverage: string = '1', + entryPrice: string = '0', + pendingFundingPayment: string = '0'; + if (positions && tickerSymbol) { + const fp = await positions.getTotalPendingFundingPayments({ + cache: false, + }); + for (const [key, value] of Object.entries(fp)) { + if (key === tickerSymbol) pendingFundingPayment = value.toString(); + } + + const position = await positions.getTakerPositionByTickerSymbol( + tickerSymbol, + { cache: false } + ); + if (position) { + positionSide = PositionSide[position.side]; + unrealizedProfit = ( + await position.getUnrealizedPnl({ cache: false }) + ).toString(); + leverage = '1'; + entryPrice = position.entryPrice.toString(); + positionAmt = position.sizeAbs.toString(); + } + } + return { + positionAmt, + positionSide, + unrealizedProfit, + leverage, + entryPrice, + tickerSymbol, + pendingFundingPayment, + }; + } + + /** + * Given the necessary parameters, open a position. + * @param isLong Will create a long position if true, else a short pos will be created. + * @param tickerSymbol the market to create position on. + * @param minBaseAmount the min amount for the position to be opened. + * @returns An ethers transaction object. + */ + async openPosition( + isLong: boolean, + tickerSymbol: string, + minBaseAmount: string, + allowedSlippage?: string + ): Promise { + let slippage: Big; + if (allowedSlippage) + slippage = new Big(this.getAllowedSlippage(allowedSlippage).toString()); + else slippage = new Big(this.getAllowedSlippage().toString()); + const amountInput = new Big(minBaseAmount); + const side = isLong ? PositionSide.LONG : PositionSide.SHORT; + const isAmountInputBase = false; // we are not using base token to open position. + const clearingHouse = this._perp.clearingHouse as ClearingHouse; + + const newPositionDraft = clearingHouse.createPositionDraft({ + tickerSymbol, + side, + amountInput, + isAmountInputBase, + }); + return (await clearingHouse.openPosition(newPositionDraft, slippage)) + .transaction; + } + + /** + * Closes an open position on the specified market. + * @param tickerSymbol The market on which we want to close position. + * @returns An ethers transaction object. + */ + async closePosition( + tickerSymbol: string, + allowedSlippage?: string + ): Promise { + let slippage: Big; + if (allowedSlippage) + slippage = new Big(this.getAllowedSlippage(allowedSlippage).toString()); + else slippage = new Big(this.getAllowedSlippage().toString()); + const clearingHouse = this._perp.clearingHouse as ClearingHouse; + const positions = this._perp.positions as Positions; + const position = await positions.getTakerPositionByTickerSymbol( + tickerSymbol + ); + if (!position) { + throw new Error(`No active position on ${tickerSymbol}.`); + } + return (await clearingHouse.closePosition(position as Position, slippage)) + .transaction; + } + + /** + * Function for getting account value + * @returns account value + */ + async getAccountValue(): Promise { + const clearingHouse = this._perp.clearingHouse as ClearingHouse; + return await clearingHouse.getAccountValue(); + } +} diff --git a/src/connectors/quickswap/quickswap.config.ts b/src/connectors/quickswap/quickswap.config.ts new file mode 100644 index 0000000000..9af5ca8938 --- /dev/null +++ b/src/connectors/quickswap/quickswap.config.ts @@ -0,0 +1,29 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; + +export namespace QuickswapConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + 'quickswap.allowedSlippage' + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + 'quickswap.gasLimitEstimate' + ), + ttl: ConfigManagerV2.getInstance().get('quickswap.ttl'), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + 'quickswap.contractAddresses.' + network + '.routerAddress' + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [{ chain: 'polygon', networks: ['mainnet', 'mumbai'] }], + }; +} diff --git a/src/connectors/quickswap/quickswap.ts b/src/connectors/quickswap/quickswap.ts new file mode 100644 index 0000000000..c58b4d3708 --- /dev/null +++ b/src/connectors/quickswap/quickswap.ts @@ -0,0 +1,294 @@ +import { percentRegexp } from '../../services/config-manager-v2'; +import { UniswapishPriceError } from '../../services/error-handler'; +import { + BigNumber, + Contract, + ContractInterface, + Transaction, + Wallet, +} from 'ethers'; +import { isFractionString } from '../../services/validators'; +import { QuickswapConfig } from './quickswap.config'; +import routerAbi from '../traderjoe/IJoeRouter02.json'; +import { + Fetcher, + Percent, + Router, + Token, + TokenAmount, + Trade, + Pair, +} from 'quickswap-sdk'; +import { logger } from '../../services/logger'; +import { Polygon } from '../../chains/polygon/polygon'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; + +export class Quickswap implements Uniswapish { + private static _instances: { [name: string]: Quickswap }; + private polygon: Polygon; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(network: string) { + const config = QuickswapConfig.config; + this.polygon = Polygon.getInstance(network); + this.chainId = this.polygon.chainId; + this._router = config.routerAddress(network); + this._ttl = config.ttl; + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = config.gasLimitEstimate; + } + + public static getInstance(chain: string, network: string): Quickswap { + if (Quickswap._instances === undefined) { + Quickswap._instances = {}; + } + if (!(chain + network in Quickswap._instances)) { + Quickswap._instances[chain + network] = new Quickswap(network); + } + + return Quickswap._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.polygon.ready()) { + await this.polygon.init(); + } + for (const token of this.polygon.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit used to estimate cost for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = QuickswapConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + baseToken, + quoteToken, + this.polygon.provider + ); + const trades: Trade[] = Trade.bestTradeExactIn( + [pair], + nativeTokenAmount, + quoteToken, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ${trades[0]}` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + quoteToken, + baseToken, + this.polygon.provider + ); + const trades: Trade[] = Trade.bestTradeExactOut( + [pair], + quoteToken, + nativeTokenAmount, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ${trades[0]}` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Uniswap-ish trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param quickswapRouter smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + quickswapRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise { + const result = Router.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract = new Contract(quickswapRouter, abi, wallet); + return this.polygon.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + let tx; + if (maxFeePerGas || maxPriorityFeePerGas) { + tx = await contract[result.methodName](...result.args, { + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await contract[result.methodName](...result.args, { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + }); + } + + logger.info(JSON.stringify(tx)); + return tx; + } + ); + } +} diff --git a/src/connectors/ref/ref.config.ts b/src/connectors/ref/ref.config.ts new file mode 100644 index 0000000000..aa7c3d93db --- /dev/null +++ b/src/connectors/ref/ref.config.ts @@ -0,0 +1,35 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; +export namespace RefConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get(`ref.allowedSlippage`), + gasLimitEstimate: ConfigManagerV2.getInstance().get(`ref.gasLimitEstimate`), + ttl: ConfigManagerV2.getInstance().get(`ref.ttl`), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + `ref.contractAddresses.${network}.routerAddress` + ), + tradingTypes: ['NEAR_AMM'], + availableNetworks: [ + { + chain: 'near', + networks: Object.keys( + ConfigManagerV2.getInstance().get('ref.contractAddresses') + ).filter((network) => + Object.keys( + ConfigManagerV2.getInstance().get('near.networks') + ).includes(network) + ), + }, + ], + }; +} diff --git a/src/connectors/ref/ref.controllers.ts b/src/connectors/ref/ref.controllers.ts new file mode 100644 index 0000000000..c2f6701c65 --- /dev/null +++ b/src/connectors/ref/ref.controllers.ts @@ -0,0 +1,315 @@ +import Decimal from 'decimal.js-light'; +import { + HttpException, + TOKEN_NOT_SUPPORTED_ERROR_CODE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + PRICE_FAILED_ERROR_CODE, + PRICE_FAILED_ERROR_MESSAGE, + TRADE_FAILED_ERROR_CODE, + TRADE_FAILED_ERROR_MESSAGE, + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_CODE, + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_MESSAGE, + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_CODE, + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE, + UNKNOWN_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { TokenInfo } from '../../services/ethereum-base'; +import { latency } from '../../services/base'; +import { Nearish, RefAMMish } from '../../services/common-interfaces'; +import { logger } from '../../services/logger'; +import { + EstimateGasResponse, + PriceRequest, + PriceResponse, + TradeRequest, + TradeResponse, +} from '../../amm/amm.requests'; +import { EstimateSwapView, TokenMetadata } from 'coinalpha-ref-sdk'; +import { Account } from 'near-api-js'; +import { ExpectedTrade } from './ref'; + +export interface TradeInfo { + baseToken: TokenMetadata; + quoteToken: TokenMetadata; + requestAmount: string; + expectedTrade: EstimateSwapView[]; +} + +export async function getTradeInfo( + nearish: Nearish, + refAMMish: RefAMMish, + baseAsset: string, + quoteAsset: string, + amount: string, + tradeSide: string, + allowedSlippage?: string +): Promise { + const baseToken: TokenMetadata = getFullTokenFromSymbol( + nearish, + refAMMish, + baseAsset + ); + const quoteToken: TokenMetadata = getFullTokenFromSymbol( + nearish, + refAMMish, + quoteAsset + ); + + let expectedTrade: ExpectedTrade; + if (tradeSide === 'BUY') { + expectedTrade = await refAMMish.estimateBuyTrade( + quoteToken, + baseToken, + amount, + allowedSlippage + ); + } else { + expectedTrade = await refAMMish.estimateSellTrade( + baseToken, + quoteToken, + amount, + allowedSlippage + ); + } + + return { + baseToken, + quoteToken, + requestAmount: amount, + expectedTrade: expectedTrade.trade, + }; +} + +export async function price( + nearish: Nearish, + refAMMish: RefAMMish, + req: PriceRequest +): Promise { + const startTimestamp: number = Date.now(); + let tradeInfo: TradeInfo; + try { + tradeInfo = await getTradeInfo( + nearish, + refAMMish, + req.base, + req.quote, + req.amount, + req.side, + req.allowedSlippage + ); + } catch (e) { + if (e instanceof Error) { + throw new HttpException( + 500, + PRICE_FAILED_ERROR_MESSAGE + e.message, + PRICE_FAILED_ERROR_CODE + ); + } else { + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + + const { estimatedPrice, expectedAmount } = refAMMish.parseTrade( + tradeInfo.expectedTrade, + req.side + ); + + const gasLimitTransaction = nearish.gasLimitTransaction; + const gasPrice = nearish.gasPrice; + const gasLimitEstimate = refAMMish.gasLimitEstimate; + return { + network: nearish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: tradeInfo.baseToken.id, + quote: tradeInfo.quoteToken.id, + amount: new Decimal(req.amount).toFixed(tradeInfo.baseToken.decimals), + rawAmount: tradeInfo.requestAmount.toString(), + expectedAmount: expectedAmount, + price: estimatedPrice, + gasPrice: gasPrice, + gasPriceToken: nearish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: String((gasPrice * gasLimitEstimate) / 1e24), + }; +} + +export async function trade( + nearish: Nearish, + refAMMish: RefAMMish, + req: TradeRequest +): Promise { + const startTimestamp: number = Date.now(); + + const limitPrice = req.limitPrice; + const account: Account = await nearish.getWallet(req.address); + + let tradeInfo: TradeInfo; + try { + tradeInfo = await getTradeInfo( + nearish, + refAMMish, + req.base, + req.quote, + req.amount, + req.side + ); + } catch (e) { + if (e instanceof Error) { + logger.error(`Could not get trade info. ${e.message}`); + throw new HttpException( + 500, + TRADE_FAILED_ERROR_MESSAGE + e.message, + TRADE_FAILED_ERROR_CODE + ); + } else { + logger.error('Unknown error trying to get trade info.'); + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + + const gasPrice: number = nearish.gasPrice; + const gasLimitTransaction: number = nearish.gasLimitTransaction; + const gasLimitEstimate: number = refAMMish.gasLimitEstimate; + const { estimatedPrice, expectedAmount } = refAMMish.parseTrade( + tradeInfo.expectedTrade, + req.side + ); + + logger.info( + `Expected execution price is ${estimatedPrice}, ` + + `limit price is ${limitPrice}.` + ); + + if (req.side === 'BUY') { + if (limitPrice && new Decimal(estimatedPrice).gt(new Decimal(limitPrice))) { + logger.error('Swap price exceeded limit price.'); + throw new HttpException( + 500, + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_MESSAGE( + estimatedPrice, + limitPrice + ), + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_CODE + ); + } + + const amountIn = new Decimal(req.amount) + .mul(new Decimal(estimatedPrice)) + .toString(); + + const tx = await refAMMish.executeTrade( + account, + tradeInfo.expectedTrade, + amountIn, + tradeInfo.quoteToken, + tradeInfo.baseToken, + req.allowedSlippage + ); + + logger.info(`Buy Ref swap has been executed.`); + + return { + network: nearish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: tradeInfo.baseToken.id, + quote: tradeInfo.quoteToken.id, + amount: new Decimal(req.amount).toFixed(tradeInfo.baseToken.decimals), + rawAmount: tradeInfo.requestAmount.toString(), + expectedIn: expectedAmount, + price: estimatedPrice, + gasPrice: gasPrice, + gasPriceToken: nearish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: String((gasPrice * gasLimitEstimate) / 1e24), + txHash: tx, + }; + } else { + if (limitPrice && new Decimal(estimatedPrice).lt(new Decimal(limitPrice))) { + logger.error('Swap price lower than limit price.'); + throw new HttpException( + 500, + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_MESSAGE( + estimatedPrice, + limitPrice + ), + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_CODE + ); + } + + const tx = await refAMMish.executeTrade( + account, + tradeInfo.expectedTrade, + req.amount, + tradeInfo.baseToken, + tradeInfo.quoteToken, + req.allowedSlippage + ); + + logger.info(`Sell Ref swap has been executed.`); + + return { + network: nearish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: tradeInfo.baseToken.id, + quote: tradeInfo.quoteToken.id, + amount: new Decimal(req.amount).toFixed(tradeInfo.baseToken.decimals), + rawAmount: tradeInfo.requestAmount.toString(), + expectedOut: expectedAmount, + price: estimatedPrice, + gasPrice: gasPrice, + gasPriceToken: nearish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: String((gasPrice * gasLimitEstimate) / 1e24), + txHash: tx, + }; + } +} + +export function getFullTokenFromSymbol( + nearish: Nearish, + refAMMish: RefAMMish, + tokenSymbol: string +): TokenMetadata { + const tokenInfo: TokenInfo | undefined = + nearish.getTokenBySymbol(tokenSymbol); + let fullToken: TokenMetadata | undefined; + if (tokenInfo) { + fullToken = refAMMish.getTokenByAddress(tokenInfo.address); + } + if (!fullToken) + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + tokenSymbol, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + return fullToken; +} + +export async function estimateGas( + nearish: Nearish, + refAMMish: RefAMMish +): Promise { + const gasPrice: number = nearish.gasPrice; + const gasLimitTransaction: number = nearish.gasLimitTransaction; + const gasLimitEstimate: number = refAMMish.gasLimitEstimate; + return { + network: nearish.chain, + timestamp: Date.now(), + gasPrice, + gasPriceToken: nearish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: String((gasPrice * gasLimitEstimate) / 1e24), + }; +} diff --git a/src/connectors/ref/ref.helper.ts b/src/connectors/ref/ref.helper.ts new file mode 100644 index 0000000000..b78ff1c578 --- /dev/null +++ b/src/connectors/ref/ref.helper.ts @@ -0,0 +1,131 @@ +import { + providers, + transactions as nearTransactions, + utils, + Account, +} from 'near-api-js'; +import BN from 'bn.js'; +import { AccessKeyView } from 'near-api-js/lib/providers/provider'; +import { + Transaction, + transformTransactions, + TransformedTransaction, +} from 'coinalpha-ref-sdk'; + +const validateAccessKey = ( + transaction: TransformedTransaction, + accessKey: AccessKeyView +) => { + if (accessKey.permission === 'FullAccess') { + return accessKey; + } + + // eslint-disable-next-line @typescript-eslint/naming-convention + const { receiver_id, method_names } = accessKey.permission.FunctionCall; + + if (transaction.receiverId !== receiver_id) { + return null; + } + + return transaction.actions.every( + (action: { type: string; params: { methodName: any; deposit: any } }) => { + if (action.type !== 'FunctionCall') { + return false; + } + + const { methodName, deposit } = action.params; + + if (method_names.length && method_names.includes(methodName)) { + return false; + } + + return parseFloat(deposit) <= 0; + } + ); +}; + +export const getSignedTransactions = async ({ + transactionsRef, + account, +}: { + transactionsRef: Transaction[]; + account: Account; +}) => { + const AccountId: string = account.accountId; + const networkId: string = account.connection.networkId; + const transactions = transformTransactions(transactionsRef, AccountId); + + const block = await account.connection.provider.block({ finality: 'final' }); + + const signedTransactions: Array = []; + + const publicKey = await account.connection.signer.getPublicKey( + account.accountId, + account.connection.networkId + ); + if (!publicKey) { + throw 'Wallet not properly initialized.'; + } + + const accessKey = await account.connection.provider.query({ + request_type: 'view_access_key', + finality: 'final', + account_id: AccountId, + public_key: publicKey.toString(), + }); + + for (let i = 0; i < transactions.length; i += 1) { + const transaction = transactions[i]; + + if (!validateAccessKey(transaction, accessKey)) { + throw 'Account does not have access.'; + } + + const tx = nearTransactions.createTransaction( + AccountId, + utils.PublicKey.from(publicKey.toString()), + transactions[i].receiverId, + accessKey.nonce + i + 1, + transaction.actions.map( + (action: { + params: { methodName: any; args: any; gas: any; deposit: any }; + }) => { + const { methodName, args, gas, deposit } = action.params; + return nearTransactions.functionCall( + methodName, + args, + new BN(gas), + new BN(deposit) + ); + } + ), + utils.serialize.base_decode(block.header.hash) + ); + + const [, signedTx] = await nearTransactions.signTransaction( + tx, + account.connection.signer, + transactions[i].signerId, + networkId + ); + signedTransactions.push(signedTx); + } + + return signedTransactions; +}; + +export const sendTransactions = async ({ + signedTransactions, + provider, +}: { + signedTransactions: nearTransactions.SignedTransaction[]; + provider: providers.Provider; +}) => { + const results: Array = []; + + for (const signedTransaction of signedTransactions) { + results.push(await provider.sendTransactionAsync(signedTransaction)); + } + + return results; +}; diff --git a/src/connectors/ref/ref.ts b/src/connectors/ref/ref.ts new file mode 100644 index 0000000000..8f9683d749 --- /dev/null +++ b/src/connectors/ref/ref.ts @@ -0,0 +1,316 @@ +import { UniswapishPriceError as AMMishPriceError } from '../../services/error-handler'; +import { isFractionString } from '../../services/validators'; +import { RefConfig } from './ref.config'; +import { + estimateSwap, + EstimateSwapView, + fetchAllPools, + instantSwap, + SwapOptions, + TokenMetadata, + Transaction, + toReadableNumber, + Pool, +} from 'coinalpha-ref-sdk'; +import { logger } from '../../services/logger'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { RefAMMish } from '../../services/common-interfaces'; +import { Near } from '../../chains/near/near'; +import { Account } from 'near-api-js'; +import { SignedTransaction } from 'near-api-js/lib/transaction'; +import { getSignedTransactions, sendTransactions } from './ref.helper'; +import { FinalExecutionOutcome } from 'near-api-js/lib/providers'; + +export type ExpectedTrade = { + trade: EstimateSwapView[]; + expectedAmount: string; +}; + +type PoolEntries = { + [key: string]: { inputAmount: string; outputAmount: string }; +}; + +export class Ref implements RefAMMish { + private static _instances: { [name: string]: Ref }; + private near: Near; + private _router: string; + private _gasLimitEstimate: number; + private _ttl: number; + private tokenList: Record = {}; + private _ready: boolean = false; + private _cachedPools: Pool[] = []; + + private constructor(network: string) { + const config = RefConfig.config; + this.near = Near.getInstance(network); + this._ttl = RefConfig.config.ttl; + this._gasLimitEstimate = RefConfig.config.gasLimitEstimate; + this._router = config.routerAddress(network); + } + + public static getInstance(chain: string, network: string): Ref { + if (Ref._instances === undefined) { + Ref._instances = {}; + } + if (!(chain + network in Ref._instances)) { + Ref._instances[chain + network] = new Ref(network); + } + + return Ref._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): TokenMetadata { + return this.tokenList[address]; + } + + public async init() { + if (!this.near.ready()) { + await this.near.init(); + } + for (const token of this.near.storedTokenList) { + this.tokenList[token.address] = { + id: token.address, + decimals: token.decimals, + symbol: token.symbol, + name: token.name, + icon: '', + }; + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): number { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return Number(fractionSplit[0]) / Number(fractionSplit[1]); + } + + const allowedSlippage = RefConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return Number(nd[1]) / Number(nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Calculated expected execution price and expected amount in after a swap/trade + * @param trades The trade path object + */ + parseTrade( + trades: EstimateSwapView[], + side: string + ): { + estimatedPrice: string; + expectedAmount: string; + } { + const paths: PoolEntries = {}; + for (const trade of trades) { + if (trade.nodeRoute) { + if (!paths[trade.nodeRoute.join()]) + paths[trade.nodeRoute.join()] = { + inputAmount: '0', + outputAmount: '0', + }; + + if (trade.inputToken === trade.nodeRoute[0]) { + const token: TokenMetadata[] = ( + trade.tokens?.filter((t) => t.id === trade.inputToken) + ); + + paths[trade.nodeRoute.join()].inputAmount = toReadableNumber( + token[0].decimals, + trade.pool.partialAmountIn + ); + } else if ( + trade.outputToken === trade.nodeRoute[trade.nodeRoute.length - 1] + ) { + paths[trade.nodeRoute.join()].outputAmount = trade.estimate; + } + } + } + let expectedAmount = 0, + amountIn = 0; + Object.values(paths).forEach((entries) => { + expectedAmount += Number(entries.outputAmount); + amountIn += Number(entries.inputAmount); + }); + return { + estimatedPrice: + side.toUpperCase() === 'BUY' + ? String(amountIn / expectedAmount) + : String(expectedAmount / amountIn), + expectedAmount: String(expectedAmount), + }; + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: TokenMetadata, + quoteToken: TokenMetadata, + amount: string, + _allowedSlippage?: string + ): Promise { + logger.info(`Fetching pair data for ${baseToken.id}-${quoteToken.id}.`); + + const { simplePools } = await fetchAllPools(); + this._cachedPools = simplePools; + + const options: SwapOptions = { + enableSmartRouting: true, + }; + const trades: EstimateSwapView[] = await estimateSwap({ + tokenIn: baseToken, + tokenOut: quoteToken, + amountIn: amount, + simplePools, + options, + }); + if (!trades || trades.length === 0) { + throw new AMMishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + const { estimatedPrice, expectedAmount } = this.parseTrade(trades, 'SELL'); + logger.info( + `Best trade for ${baseToken.id}-${quoteToken.id}: ` + + `${estimatedPrice}` + + `${baseToken.name}.` + ); + return { trade: trades, expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: TokenMetadata, + baseToken: TokenMetadata, + amount: string, + _allowedSlippage?: string + ): Promise { + const buyEstimate: ExpectedTrade = await this.estimateSellTrade( + baseToken, + quoteToken, + amount + ); + + const options: SwapOptions = { + enableSmartRouting: true, + }; + + const trades: EstimateSwapView[] = await estimateSwap({ + tokenIn: quoteToken, + tokenOut: baseToken, + amountIn: buyEstimate.expectedAmount, + simplePools: this._cachedPools, + options, + }); + if (!trades || trades.length === 0) { + throw new AMMishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.id} to ${baseToken.id}.` + ); + } + + const { estimatedPrice, expectedAmount } = this.parseTrade(trades, 'BUY'); + logger.info( + `Best trade for ${quoteToken.id}-${baseToken.id}: ` + + `${estimatedPrice} ` + + `${baseToken.name}.` + ); + + return { trade: trades, expectedAmount }; + } + + /** + * Given an Account and a Ref trade, try to execute it on blockchain. + * + * @param account Account + * @param trade Expected trade + * @param amountIn Amount to swap in + * @param tokenIn Token to be sent + * @param tokenOut Token to be received + * @param allowedSlippage Maximum allowable slippage + */ + async executeTrade( + account: Account, + trade: EstimateSwapView[], + amountIn: string, + tokenIn: TokenMetadata, + tokenOut: TokenMetadata, + allowedSlippage?: string + ): Promise { + const transactionsRef: Transaction[] = await instantSwap({ + tokenIn, + tokenOut, + amountIn, + slippageTolerance: this.getAllowedSlippage(allowedSlippage), + swapTodos: trade, + AccountId: account.accountId, + }); + + const signedTransactions: SignedTransaction[] = await getSignedTransactions( + { transactionsRef, account } + ); + const transaction: FinalExecutionOutcome[] = await sendTransactions({ + signedTransactions, + provider: account.connection.provider, + }); + + logger.info(JSON.stringify(transaction)); + return transaction[0]; + } +} diff --git a/src/connectors/sushiswap/sushiswap.config.ts b/src/connectors/sushiswap/sushiswap.config.ts new file mode 100644 index 0000000000..2080583c76 --- /dev/null +++ b/src/connectors/sushiswap/sushiswap.config.ts @@ -0,0 +1,39 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; + +export namespace SushiswapConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + sushiswapRouterAddress: (chain: string, network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + 'sushiswap.allowedSlippage' + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + 'sushiswap.gasLimitEstimate' + ), + ttl: ConfigManagerV2.getInstance().get('sushiswap.ttl'), + sushiswapRouterAddress: (chain: string, network: string) => + ConfigManagerV2.getInstance().get( + 'sushiswap.contractAddresses.' + + chain + + '.' + + network + + '.sushiswapRouterAddress' + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [ + { + chain: 'ethereum', + networks: ['mainnet', 'kovan', 'goerli', 'ropsten'], + }, + { chain: 'binance-smart-chain', networks: ['mainnet', 'testnet'] }, + ], + }; +} diff --git a/src/connectors/sushiswap/sushiswap.ts b/src/connectors/sushiswap/sushiswap.ts new file mode 100644 index 0000000000..dff95392c7 --- /dev/null +++ b/src/connectors/sushiswap/sushiswap.ts @@ -0,0 +1,300 @@ +import { UniswapishPriceError } from '../../services/error-handler'; +import { SushiswapConfig } from './sushiswap.config'; +import routerAbi from './sushiswap_router.json'; + +import { ContractInterface } from '@ethersproject/contracts'; + +import { + Percent, + Router, + Token, + CurrencyAmount, + Trade, + Pair, + SwapParameters, + TradeType, +} from '@sushiswap/sdk'; +import IUniswapV2Pair from '@uniswap/v2-core/build/IUniswapV2Pair.json'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; +import { Ethereum } from '../../chains/ethereum/ethereum'; +import { BinanceSmartChain } from '../../chains/binance-smart-chain/binance-smart-chain'; +import { + BigNumber, + Wallet, + Transaction, + Contract, + ContractTransaction, +} from 'ethers'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { logger } from '../../services/logger'; + +export class Sushiswap implements Uniswapish { + private static _instances: { [name: string]: Sushiswap }; + private chain: Ethereum | BinanceSmartChain; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(chain: string, network: string) { + const config = SushiswapConfig.config; + if (chain === 'ethereum') { + this.chain = Ethereum.getInstance(network); + } else if (chain === 'binance-smart-chain') { + this.chain = BinanceSmartChain.getInstance(network); + } else { + throw new Error('unsupported chain'); + } + this.chainId = this.chain.chainId; + this._ttl = config.ttl; + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = config.gasLimitEstimate; + this._router = config.sushiswapRouterAddress(chain, network); + } + + public static getInstance(chain: string, network: string): Sushiswap { + if (Sushiswap._instances === undefined) { + Sushiswap._instances = {}; + } + if (!(chain + network in Sushiswap._instances)) { + Sushiswap._instances[chain + network] = new Sushiswap(chain, network); + } + + return Sushiswap._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.chain.ready()) { + await this.chain.init(); + } + for (const token of this.chain.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from configuration. + */ + getSlippagePercentage(): Percent { + const allowedSlippage = SushiswapConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Fetches information about a pair and constructs a pair from the given two tokens. + * This is to replace the Fetcher Class + * @param tokenA first token + * @param tokenB second token + */ + + async fetchData(baseToken: Token, quoteToken: Token): Promise { + const pairAddress = Pair.getAddress(baseToken, quoteToken); + const contract = new Contract( + pairAddress, + IUniswapV2Pair.abi, + this.chain.provider + ); + const [reserves0, reserves1] = await contract.getReserves(); + const balances = baseToken.sortsBefore(quoteToken) + ? [reserves0, reserves1] + : [reserves1, reserves0]; + const pair = new Pair( + CurrencyAmount.fromRawAmount(baseToken, balances[0]), + CurrencyAmount.fromRawAmount(quoteToken, balances[1]) + ); + return pair; + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber + ): Promise { + const nativeTokenAmount: CurrencyAmount = + CurrencyAmount.fromRawAmount(baseToken, amount.toString()); + + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + + const pair: Pair = await this.fetchData(baseToken, quoteToken); + + const trades: Trade[] = + Trade.bestTradeExactIn([pair], nativeTokenAmount, quoteToken, { + maxHops: 1, + }); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ` + + `${trades[0].executionPrice.toFixed(6)}` + + `${baseToken.name}.` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getSlippagePercentage() + ); + + return { trade: trades[0], expectedAmount }; + } + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber + ): Promise { + const nativeTokenAmount: CurrencyAmount = + CurrencyAmount.fromRawAmount(baseToken, amount.toString()); + + const pair: Pair = await this.fetchData(quoteToken, baseToken); + + const trades: Trade[] = + Trade.bestTradeExactOut([pair], quoteToken, nativeTokenAmount, { + maxHops: 1, + }); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ` + + `${trades[0].executionPrice.invert().toFixed(6)} ` + + `${baseToken.name}.` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getSlippagePercentage() + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Uniswap trade, try to execute it on blockchain. + * + * @param _wallet Wallet + * @param _trade Expected trade + * @param _gasPrice Base gas price, for pre-EIP1559 transactions + * @param uniswapRouter Router smart contract address + * @param _ttl How long the swap is valid before expiry, in seconds + * @param _abi Router contract ABI + * @param _gasLimit Gas limit + * @param _nonce (Optional) EVM transaction nonce + * @param _maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param _maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + sushswapRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise { + const result: SwapParameters = Router.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getSlippagePercentage(), + }); + const contract: Contract = new Contract(sushswapRouter, abi, wallet); + return this.chain.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + let tx: ContractTransaction; + if (maxFeePerGas !== undefined || maxPriorityFeePerGas !== undefined) { + tx = await contract[result.methodName](...result.args, { + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await contract[result.methodName](...result.args, { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + }); + } + + logger.info(JSON.stringify(tx)); + return tx; + } + ); + } +} diff --git a/src/connectors/sushiswap/sushiswap_router.json b/src/connectors/sushiswap/sushiswap_router.json new file mode 100644 index 0000000000..e2eac42088 --- /dev/null +++ b/src/connectors/sushiswap/sushiswap_router.json @@ -0,0 +1,1924 @@ +{ + "abi": [ + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "evm": { + "bytecode": { + "linkReferences": {}, + "object": "", + "opcodes": "", + "sourceMap": "" + }, + "deployedBytecode": { + "immutableReferences": {}, + "linkReferences": {}, + "object": "", + "opcodes": "", + "sourceMap": "" + } + }, + "interface": [ + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "bytecode": "" +} diff --git a/src/connectors/traderjoe/IJoeRouter02.json b/src/connectors/traderjoe/IJoeRouter02.json new file mode 100644 index 0000000000..24b3b78817 --- /dev/null +++ b/src/connectors/traderjoe/IJoeRouter02.json @@ -0,0 +1,437 @@ +{ + "contractName": "IJoeRouter02", + "sourceName": "contracts/traderjoe/IJoeRouter02.sol", + "abi": [ + { + "inputs": [], + "name": "WAVAX", + "outputs": [{ "internalType": "address", "name": "", "type": "address" }], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "tokenA", "type": "address" }, + { "internalType": "address", "name": "tokenB", "type": "address" }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { "internalType": "uint256", "name": "amountAMin", "type": "uint256" }, + { "internalType": "uint256", "name": "amountBMin", "type": "uint256" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "addLiquidity", + "outputs": [ + { "internalType": "uint256", "name": "amountA", "type": "uint256" }, + { "internalType": "uint256", "name": "amountB", "type": "uint256" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "token", "type": "address" }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "addLiquidityAVAX", + "outputs": [ + { "internalType": "uint256", "name": "amountToken", "type": "uint256" }, + { "internalType": "uint256", "name": "amountAVAX", "type": "uint256" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [{ "internalType": "address", "name": "", "type": "address" }], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountOut", "type": "uint256" }, + { "internalType": "uint256", "name": "reserveIn", "type": "uint256" }, + { "internalType": "uint256", "name": "reserveOut", "type": "uint256" } + ], + "name": "getAmountIn", + "outputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" }, + { "internalType": "uint256", "name": "reserveIn", "type": "uint256" }, + { "internalType": "uint256", "name": "reserveOut", "type": "uint256" } + ], + "name": "getAmountOut", + "outputs": [ + { "internalType": "uint256", "name": "amountOut", "type": "uint256" } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountOut", "type": "uint256" }, + { "internalType": "address[]", "name": "path", "type": "address[]" } + ], + "name": "getAmountsIn", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" }, + { "internalType": "address[]", "name": "path", "type": "address[]" } + ], + "name": "getAmountsOut", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountA", "type": "uint256" }, + { "internalType": "uint256", "name": "reserveA", "type": "uint256" }, + { "internalType": "uint256", "name": "reserveB", "type": "uint256" } + ], + "name": "quote", + "outputs": [ + { "internalType": "uint256", "name": "amountB", "type": "uint256" } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "tokenA", "type": "address" }, + { "internalType": "address", "name": "tokenB", "type": "address" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" }, + { "internalType": "uint256", "name": "amountAMin", "type": "uint256" }, + { "internalType": "uint256", "name": "amountBMin", "type": "uint256" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "removeLiquidity", + "outputs": [ + { "internalType": "uint256", "name": "amountA", "type": "uint256" }, + { "internalType": "uint256", "name": "amountB", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "token", "type": "address" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "removeLiquidityAVAX", + "outputs": [ + { "internalType": "uint256", "name": "amountToken", "type": "uint256" }, + { "internalType": "uint256", "name": "amountAVAX", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "token", "type": "address" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "removeLiquidityAVAXSupportingFeeOnTransferTokens", + "outputs": [ + { "internalType": "uint256", "name": "amountAVAX", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "token", "type": "address" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" }, + { "internalType": "bool", "name": "approveMax", "type": "bool" }, + { "internalType": "uint8", "name": "v", "type": "uint8" }, + { "internalType": "bytes32", "name": "r", "type": "bytes32" }, + { "internalType": "bytes32", "name": "s", "type": "bytes32" } + ], + "name": "removeLiquidityAVAXWithPermit", + "outputs": [ + { "internalType": "uint256", "name": "amountToken", "type": "uint256" }, + { "internalType": "uint256", "name": "amountAVAX", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "token", "type": "address" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAVAXMin", + "type": "uint256" + }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" }, + { "internalType": "bool", "name": "approveMax", "type": "bool" }, + { "internalType": "uint8", "name": "v", "type": "uint8" }, + { "internalType": "bytes32", "name": "r", "type": "bytes32" }, + { "internalType": "bytes32", "name": "s", "type": "bytes32" } + ], + "name": "removeLiquidityAVAXWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { "internalType": "uint256", "name": "amountAVAX", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "tokenA", "type": "address" }, + { "internalType": "address", "name": "tokenB", "type": "address" }, + { "internalType": "uint256", "name": "liquidity", "type": "uint256" }, + { "internalType": "uint256", "name": "amountAMin", "type": "uint256" }, + { "internalType": "uint256", "name": "amountBMin", "type": "uint256" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" }, + { "internalType": "bool", "name": "approveMax", "type": "bool" }, + { "internalType": "uint8", "name": "v", "type": "uint8" }, + { "internalType": "bytes32", "name": "r", "type": "bytes32" }, + { "internalType": "bytes32", "name": "s", "type": "bytes32" } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { "internalType": "uint256", "name": "amountA", "type": "uint256" }, + { "internalType": "uint256", "name": "amountB", "type": "uint256" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountOut", "type": "uint256" }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapAVAXForExactTokens", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapExactAVAXForTokens", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapExactAVAXForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapExactTokensForAVAX", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapExactTokensForAVAXSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountIn", "type": "uint256" }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountOut", "type": "uint256" }, + { "internalType": "uint256", "name": "amountInMax", "type": "uint256" }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapTokensForExactAVAX", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "amountOut", "type": "uint256" }, + { "internalType": "uint256", "name": "amountInMax", "type": "uint256" }, + { "internalType": "address[]", "name": "path", "type": "address[]" }, + { "internalType": "address", "name": "to", "type": "address" }, + { "internalType": "uint256", "name": "deadline", "type": "uint256" } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { "internalType": "uint256[]", "name": "amounts", "type": "uint256[]" } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ] +} diff --git a/src/connectors/traderjoe/traderjoe.config.ts b/src/connectors/traderjoe/traderjoe.config.ts new file mode 100644 index 0000000000..18d5803a09 --- /dev/null +++ b/src/connectors/traderjoe/traderjoe.config.ts @@ -0,0 +1,31 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; + +export namespace TraderjoeConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + routerAddress: (network: string) => string; + tradingTypes: Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + 'traderjoe.allowedSlippage' + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + 'traderjoe.gasLimitEstimate' + ), + ttl: ConfigManagerV2.getInstance().get('traderjoe.ttl'), + routerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + 'traderjoe.contractAddresses.' + network + '.routerAddress' + ), + tradingTypes: ['EVM_AMM'], + availableNetworks: [ + { chain: 'avalanche', networks: ['avalanche', 'fuji'] }, + ], + }; +} diff --git a/src/connectors/traderjoe/traderjoe.ts b/src/connectors/traderjoe/traderjoe.ts new file mode 100644 index 0000000000..380ea4523f --- /dev/null +++ b/src/connectors/traderjoe/traderjoe.ts @@ -0,0 +1,295 @@ +import { percentRegexp } from '../../services/config-manager-v2'; +import { UniswapishPriceError } from '../../services/error-handler'; +import { + BigNumber, + Contract, + ContractInterface, + Transaction, + Wallet, +} from 'ethers'; +import { isFractionString } from '../../services/validators'; +import { TraderjoeConfig } from './traderjoe.config'; +import routerAbi from './IJoeRouter02.json'; +import { + Fetcher, + Percent, + Router, + Token, + TokenAmount, + Trade, + Pair, +} from '@traderjoe-xyz/sdk'; +import { logger } from '../../services/logger'; +import { Avalanche } from '../../chains/avalanche/avalanche'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; + +export class Traderjoe implements Uniswapish { + private static _instances: { [name: string]: Traderjoe }; + private avalanche: Avalanche; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(network: string) { + const config = TraderjoeConfig.config; + this.avalanche = Avalanche.getInstance(network); + this.chainId = this.avalanche.chainId; + this._router = config.routerAddress(network); + this._ttl = config.ttl; + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = config.gasLimitEstimate; + } + + public static getInstance(chain: string, network: string): Traderjoe { + if (Traderjoe._instances === undefined) { + Traderjoe._instances = {}; + } + if (!(chain + network in Traderjoe._instances)) { + Traderjoe._instances[chain + network] = new Traderjoe(network); + } + + return Traderjoe._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.avalanche.ready()) { + await this.avalanche.init(); + } + + for (const token of this.avalanche.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit estimate for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = TraderjoeConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${baseToken.address}-${quoteToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + baseToken, + quoteToken, + this.avalanche.provider + ); + const trades: Trade[] = Trade.bestTradeExactIn( + [pair], + nativeTokenAmount, + quoteToken, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ${trades[0]}` + ); + const expectedAmount = trades[0].minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: TokenAmount = new TokenAmount( + baseToken, + amount.toString() + ); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const pair: Pair = await Fetcher.fetchPairData( + quoteToken, + baseToken, + this.avalanche.provider + ); + const trades: Trade[] = Trade.bestTradeExactOut( + [pair], + quoteToken, + nativeTokenAmount, + { maxHops: 1 } + ); + if (!trades || trades.length === 0) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ${trades[0]}` + ); + + const expectedAmount = trades[0].maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: trades[0], expectedAmount }; + } + + /** + * Given a wallet and a Uniswap-ish trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param traderjoeRouter smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + traderjoeRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise { + const result = Router.swapCallParameters(trade, { + ttl, + recipient: wallet.address, + allowedSlippage: this.getAllowedSlippage(allowedSlippage), + }); + + const contract = new Contract(traderjoeRouter, abi, wallet); + return this.avalanche.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + let tx; + if (maxFeePerGas || maxPriorityFeePerGas) { + tx = await contract[result.methodName](...result.args, { + gasLimit: gasLimit, + value: result.value, + nonce: nextNonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await contract[result.methodName](...result.args, { + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: result.value, + nonce: nextNonce, + }); + } + logger.info(JSON.stringify(tx)); + + return tx; + } + ); + } +} diff --git a/src/connectors/uniswap/uniswap.config.ts b/src/connectors/uniswap/uniswap.config.ts new file mode 100644 index 0000000000..320d496eed --- /dev/null +++ b/src/connectors/uniswap/uniswap.config.ts @@ -0,0 +1,58 @@ +import { ConfigManagerV2 } from '../../services/config-manager-v2'; +import { AvailableNetworks } from '../../services/config-manager-types'; +export namespace UniswapConfig { + export interface NetworkConfig { + allowedSlippage: string; + gasLimitEstimate: number; + ttl: number; + maximumHops: number; + uniswapV3SmartOrderRouterAddress: (network: string) => string; + uniswapV3NftManagerAddress: (network: string) => string; + tradingTypes: (type: string) => Array; + availableNetworks: Array; + } + + export const config: NetworkConfig = { + allowedSlippage: ConfigManagerV2.getInstance().get( + `uniswap.allowedSlippage` + ), + gasLimitEstimate: ConfigManagerV2.getInstance().get( + `uniswap.gasLimitEstimate` + ), + ttl: ConfigManagerV2.getInstance().get(`uniswap.ttl`), + maximumHops: ConfigManagerV2.getInstance().get(`uniswap.maximumHops`), + uniswapV3SmartOrderRouterAddress: (network: string) => + ConfigManagerV2.getInstance().get( + `uniswap.contractAddresses.${network}.uniswapV3SmartOrderRouterAddress` + ), + uniswapV3NftManagerAddress: (network: string) => + ConfigManagerV2.getInstance().get( + `uniswap.contractAddresses.${network}.uniswapV3NftManagerAddress` + ), + tradingTypes: (type: string) => { + return type === 'swap' ? ['EVM_AMM'] : ['EVM_AMM_LP']; + }, + availableNetworks: [ + { + chain: 'ethereum', + networks: Object.keys( + ConfigManagerV2.getInstance().get('uniswap.contractAddresses') + ).filter((network) => + Object.keys( + ConfigManagerV2.getInstance().get('ethereum.networks') + ).includes(network) + ), + }, + { + chain: 'polygon', + networks: Object.keys( + ConfigManagerV2.getInstance().get('uniswap.contractAddresses') + ).filter((network) => + Object.keys( + ConfigManagerV2.getInstance().get('polygon.networks') + ).includes(network) + ), + }, + ], + }; +} diff --git a/src/connectors/uniswap/uniswap.controllers.ts b/src/connectors/uniswap/uniswap.controllers.ts new file mode 100644 index 0000000000..57831232c6 --- /dev/null +++ b/src/connectors/uniswap/uniswap.controllers.ts @@ -0,0 +1,630 @@ +import Decimal from 'decimal.js-light'; +import { BigNumber, Transaction, Wallet } from 'ethers'; +import { Token } from '@uniswap/sdk-core'; +import { FeeAmount } from '@uniswap/v3-sdk'; +import { + HttpException, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + PRICE_FAILED_ERROR_CODE, + PRICE_FAILED_ERROR_MESSAGE, + TRADE_FAILED_ERROR_CODE, + TRADE_FAILED_ERROR_MESSAGE, + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_CODE, + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_MESSAGE, + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_CODE, + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE, + UNKNOWN_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { TokenInfo } from '../../services/ethereum-base'; +import { latency, gasCostInEthString } from '../../services/base'; +import { + Ethereumish, + ExpectedTrade, + Uniswapish, + UniswapLPish, + Tokenish, + Fractionish, +} from '../../services/common-interfaces'; +import { logger } from '../../services/logger'; +import { + EstimateGasResponse, + PriceRequest, + PriceResponse, + TradeRequest, + TradeResponse, + AddLiquidityRequest, + AddLiquidityResponse, + RemoveLiquidityRequest, + RemoveLiquidityResponse, + CollectEarnedFeesRequest, + PositionRequest, + PositionResponse, + PoolPriceRequest, + PoolPriceResponse, +} from '../../amm/amm.requests'; + +export interface TradeInfo { + baseToken: Tokenish; + quoteToken: Tokenish; + requestAmount: BigNumber; + expectedTrade: ExpectedTrade; +} + +export async function txWriteData( + ethereumish: Ethereumish, + address: string, + maxFeePerGas?: string, + maxPriorityFeePerGas?: string +): Promise<{ + wallet: Wallet; + maxFeePerGasBigNumber: BigNumber | undefined; + maxPriorityFeePerGasBigNumber: BigNumber | undefined; +}> { + let maxFeePerGasBigNumber: BigNumber | undefined; + if (maxFeePerGas) { + maxFeePerGasBigNumber = BigNumber.from(maxFeePerGas); + } + let maxPriorityFeePerGasBigNumber: BigNumber | undefined; + if (maxPriorityFeePerGas) { + maxPriorityFeePerGasBigNumber = BigNumber.from(maxPriorityFeePerGas); + } + + let wallet: Wallet; + try { + wallet = await ethereumish.getWallet(address); + } catch (err) { + logger.error(`Wallet ${address} not available.`); + throw new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + err, + LOAD_WALLET_ERROR_CODE + ); + } + return { wallet, maxFeePerGasBigNumber, maxPriorityFeePerGasBigNumber }; +} + +export async function getTradeInfo( + ethereumish: Ethereumish, + uniswapish: Uniswapish, + baseAsset: string, + quoteAsset: string, + baseAmount: Decimal, + tradeSide: string, + allowedSlippage?: string +): Promise { + const baseToken: Tokenish = getFullTokenFromSymbol( + ethereumish, + uniswapish, + baseAsset + ); + const quoteToken: Tokenish = getFullTokenFromSymbol( + ethereumish, + uniswapish, + quoteAsset + ); + const requestAmount: BigNumber = BigNumber.from( + baseAmount.toFixed(baseToken.decimals).replace('.', '') + ); + + let expectedTrade: ExpectedTrade; + if (tradeSide === 'BUY') { + expectedTrade = await uniswapish.estimateBuyTrade( + quoteToken, + baseToken, + requestAmount, + allowedSlippage + ); + } else { + expectedTrade = await uniswapish.estimateSellTrade( + baseToken, + quoteToken, + requestAmount, + allowedSlippage + ); + } + + return { + baseToken, + quoteToken, + requestAmount, + expectedTrade, + }; +} + +export async function price( + ethereumish: Ethereumish, + uniswapish: Uniswapish, + req: PriceRequest +): Promise { + const startTimestamp: number = Date.now(); + let tradeInfo: TradeInfo; + try { + tradeInfo = await getTradeInfo( + ethereumish, + uniswapish, + req.base, + req.quote, + new Decimal(req.amount), + req.side, + req.allowedSlippage + ); + } catch (e) { + if (e instanceof Error) { + throw new HttpException( + 500, + PRICE_FAILED_ERROR_MESSAGE + e.message, + PRICE_FAILED_ERROR_CODE + ); + } else { + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + + const trade = tradeInfo.expectedTrade.trade; + const expectedAmount = tradeInfo.expectedTrade.expectedAmount; + + const tradePrice = + req.side === 'BUY' ? trade.executionPrice.invert() : trade.executionPrice; + + const gasLimitTransaction = ethereumish.gasLimitTransaction; + const gasPrice = ethereumish.gasPrice; + const gasLimitEstimate = uniswapish.gasLimitEstimate; + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: tradeInfo.baseToken.address, + quote: tradeInfo.quoteToken.address, + amount: new Decimal(req.amount).toFixed(tradeInfo.baseToken.decimals), + rawAmount: tradeInfo.requestAmount.toString(), + expectedAmount: expectedAmount.toSignificant(8), + price: tradePrice.toSignificant(8), + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + }; +} + +export async function trade( + ethereumish: Ethereumish, + uniswapish: Uniswapish, + req: TradeRequest +): Promise { + const startTimestamp: number = Date.now(); + + const limitPrice = req.limitPrice; + const { wallet, maxFeePerGasBigNumber, maxPriorityFeePerGasBigNumber } = + await txWriteData( + ethereumish, + req.address, + req.maxFeePerGas, + req.maxPriorityFeePerGas + ); + + let tradeInfo: TradeInfo; + try { + tradeInfo = await getTradeInfo( + ethereumish, + uniswapish, + req.base, + req.quote, + new Decimal(req.amount), + req.side + ); + } catch (e) { + if (e instanceof Error) { + logger.error(`Could not get trade info. ${e.message}`); + throw new HttpException( + 500, + TRADE_FAILED_ERROR_MESSAGE + e.message, + TRADE_FAILED_ERROR_CODE + ); + } else { + logger.error('Unknown error trying to get trade info.'); + throw new HttpException( + 500, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE + ); + } + } + + const gasPrice: number = ethereumish.gasPrice; + const gasLimitTransaction: number = ethereumish.gasLimitTransaction; + const gasLimitEstimate: number = uniswapish.gasLimitEstimate; + + if (req.side === 'BUY') { + const price: Fractionish = + tradeInfo.expectedTrade.trade.executionPrice.invert(); + if ( + limitPrice && + new Decimal(price.toFixed(8)).gt(new Decimal(limitPrice)) + ) { + logger.error('Swap price exceeded limit price.'); + throw new HttpException( + 500, + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_MESSAGE( + price.toFixed(8), + limitPrice + ), + SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_CODE + ); + } + + const tx = await uniswapish.executeTrade( + wallet, + tradeInfo.expectedTrade.trade, + gasPrice, + uniswapish.router, + uniswapish.ttl, + uniswapish.routerAbi, + gasLimitTransaction, + req.nonce, + maxFeePerGasBigNumber, + maxPriorityFeePerGasBigNumber, + req.allowedSlippage + ); + + if (tx.hash) { + await ethereumish.txStorage.saveTx( + ethereumish.chain, + ethereumish.chainId, + tx.hash, + new Date(), + ethereumish.gasPrice + ); + } + + logger.info( + `Trade has been executed, txHash is ${tx.hash}, nonce is ${tx.nonce}, gasPrice is ${gasPrice}.` + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: tradeInfo.baseToken.address, + quote: tradeInfo.quoteToken.address, + amount: new Decimal(req.amount).toFixed(tradeInfo.baseToken.decimals), + rawAmount: tradeInfo.requestAmount.toString(), + expectedIn: tradeInfo.expectedTrade.expectedAmount.toSignificant(8), + price: price.toSignificant(8), + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + nonce: tx.nonce, + txHash: tx.hash, + }; + } else { + const price: Fractionish = tradeInfo.expectedTrade.trade.executionPrice; + logger.info( + `Expected execution price is ${price.toFixed(6)}, ` + + `limit price is ${limitPrice}.` + ); + if ( + limitPrice && + new Decimal(price.toFixed(8)).lt(new Decimal(limitPrice)) + ) { + logger.error('Swap price lower than limit price.'); + throw new HttpException( + 500, + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_MESSAGE( + price.toFixed(8), + limitPrice + ), + SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_CODE + ); + } + + const tx = await uniswapish.executeTrade( + wallet, + tradeInfo.expectedTrade.trade, + gasPrice, + uniswapish.router, + uniswapish.ttl, + uniswapish.routerAbi, + gasLimitTransaction, + req.nonce, + maxFeePerGasBigNumber, + maxPriorityFeePerGasBigNumber + ); + + logger.info( + `Trade has been executed, txHash is ${tx.hash}, nonce is ${tx.nonce}, gasPrice is ${gasPrice}.` + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + base: tradeInfo.baseToken.address, + quote: tradeInfo.quoteToken.address, + amount: new Decimal(req.amount).toFixed(tradeInfo.baseToken.decimals), + rawAmount: tradeInfo.requestAmount.toString(), + expectedOut: tradeInfo.expectedTrade.expectedAmount.toSignificant(8), + price: price.toSignificant(8), + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + nonce: tx.nonce, + txHash: tx.hash, + }; + } +} + +export async function addLiquidity( + ethereumish: Ethereumish, + uniswapish: UniswapLPish, + req: AddLiquidityRequest +): Promise { + const startTimestamp: number = Date.now(); + + const { wallet, maxFeePerGasBigNumber, maxPriorityFeePerGasBigNumber } = + await txWriteData( + ethereumish, + req.address, + req.maxFeePerGas, + req.maxPriorityFeePerGas + ); + + const fee = FeeAmount[req.fee.toUpperCase() as keyof typeof FeeAmount]; + + const token0: Token = getFullTokenFromSymbol( + ethereumish, + uniswapish, + req.token0 + ) as Token; + + const token1: Token = getFullTokenFromSymbol( + ethereumish, + uniswapish, + req.token1 + ) as Token; + + const gasPrice: number = ethereumish.gasPrice; + const gasLimitTransaction: number = ethereumish.gasLimitTransaction; + const gasLimitEstimate: number = uniswapish.gasLimitEstimate; + + const tx = await uniswapish.addPosition( + wallet, + token0, + token1, + req.amount0, + req.amount1, + fee, + Number(req.lowerPrice), + Number(req.upperPrice), + req.tokenId ? req.tokenId : 0, + gasLimitTransaction, + gasPrice, + req.nonce, + maxFeePerGasBigNumber, + maxPriorityFeePerGasBigNumber + ); + + logger.info( + `Liquidity added, txHash is ${tx.hash}, nonce is ${tx.nonce}, gasPrice is ${gasPrice}.` + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + token0: token0.address, + token1: token1.address, + fee: req.fee, + tokenId: req.tokenId ? req.tokenId : 0, + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + nonce: tx.nonce, + txHash: tx.hash, + }; +} + +export async function removeLiquidity( + ethereumish: Ethereumish, + uniswapish: UniswapLPish, + req: RemoveLiquidityRequest +): Promise { + const startTimestamp: number = Date.now(); + + const { wallet, maxFeePerGasBigNumber, maxPriorityFeePerGasBigNumber } = + await txWriteData( + ethereumish, + req.address, + req.maxFeePerGas, + req.maxPriorityFeePerGas + ); + + const gasPrice: number = ethereumish.gasPrice; + const gasLimitTransaction: number = ethereumish.gasLimitTransaction; + const gasLimitEstimate: number = uniswapish.gasLimitEstimate; + + const tx = await uniswapish.reducePosition( + wallet, + req.tokenId, + req.decreasePercent ? req.decreasePercent : 100, + gasLimitTransaction, + gasPrice, + req.nonce, + maxFeePerGasBigNumber, + maxPriorityFeePerGasBigNumber + ); + + logger.info( + `Liquidity removed, txHash is ${tx.hash}, nonce is ${tx.nonce}, gasPrice is ${gasPrice}.` + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + tokenId: req.tokenId, + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + nonce: tx.nonce, + txHash: tx.hash, + }; +} + +export async function collectEarnedFees( + ethereumish: Ethereumish, + uniswapish: UniswapLPish, + req: CollectEarnedFeesRequest +): Promise { + const startTimestamp: number = Date.now(); + + const { wallet, maxFeePerGasBigNumber, maxPriorityFeePerGasBigNumber } = + await txWriteData( + ethereumish, + req.address, + req.maxFeePerGas, + req.maxPriorityFeePerGas + ); + + const gasPrice: number = ethereumish.gasPrice; + const gasLimitTransaction: number = ethereumish.gasLimitTransaction; + const gasLimitEstimate: number = uniswapish.gasLimitEstimate; + + const tx: Transaction = ( + await uniswapish.collectFees( + wallet, + req.tokenId, + gasLimitTransaction, + gasPrice, + req.nonce, + maxFeePerGasBigNumber, + maxPriorityFeePerGasBigNumber + ) + ); + + logger.info( + `Fees collected, txHash is ${tx.hash}, nonce is ${tx.nonce}, gasPrice is ${gasPrice}.` + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + tokenId: req.tokenId, + gasPrice: gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + nonce: tx.nonce, + txHash: tx.hash, + }; +} + +export async function positionInfo( + ethereumish: Ethereumish, + uniswapish: UniswapLPish, + req: PositionRequest +): Promise { + const startTimestamp: number = Date.now(); + + const posInfo = await uniswapish.getPosition(req.tokenId); + + logger.info(`Position info for position ${req.tokenId} retrieved.`); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + ...posInfo, + }; +} + +export async function poolPrice( + ethereumish: Ethereumish, + uniswapish: UniswapLPish, + req: PoolPriceRequest +): Promise { + const startTimestamp: number = Date.now(); + + const token0: Token = getFullTokenFromSymbol( + ethereumish, + uniswapish, + req.token0 + ) as Token; + + const token1: Token = getFullTokenFromSymbol( + ethereumish, + uniswapish, + req.token1 + ) as Token; + + const fee = FeeAmount[req.fee.toUpperCase() as keyof typeof FeeAmount]; + + const prices = await uniswapish.poolPrice( + token0, + token1, + fee, + req.period, + req.interval + ); + + return { + network: ethereumish.chain, + timestamp: startTimestamp, + latency: latency(startTimestamp, Date.now()), + token0: token0.address, + token1: token1.address, + fee: req.fee, + period: req.period, + interval: req.interval, + prices: prices, + }; +} + +export function getFullTokenFromSymbol( + ethereumish: Ethereumish, + uniswapish: Uniswapish | UniswapLPish, + tokenSymbol: string +): Tokenish | Token { + const tokenInfo: TokenInfo | undefined = + ethereumish.getTokenBySymbol(tokenSymbol); + let fullToken: Tokenish | Token | undefined; + if (tokenInfo) { + fullToken = uniswapish.getTokenByAddress(tokenInfo.address); + } + if (!fullToken) + throw new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + tokenSymbol, + TOKEN_NOT_SUPPORTED_ERROR_CODE + ); + return fullToken; +} + +export async function estimateGas( + ethereumish: Ethereumish, + uniswapish: Uniswapish +): Promise { + const gasPrice: number = ethereumish.gasPrice; + const gasLimitTransaction: number = ethereumish.gasLimitTransaction; + const gasLimitEstimate: number = uniswapish.gasLimitEstimate; + return { + network: ethereumish.chain, + timestamp: Date.now(), + gasPrice, + gasPriceToken: ethereumish.nativeTokenSymbol, + gasLimit: gasLimitTransaction, + gasCost: gasCostInEthString(gasPrice, gasLimitEstimate), + }; +} diff --git a/src/connectors/uniswap/uniswap.lp.helper.ts b/src/connectors/uniswap/uniswap.lp.helper.ts new file mode 100644 index 0000000000..6167e72467 --- /dev/null +++ b/src/connectors/uniswap/uniswap.lp.helper.ts @@ -0,0 +1,466 @@ +import { + InitializationError, + SERVICE_UNITIALIZED_ERROR_CODE, + SERVICE_UNITIALIZED_ERROR_MESSAGE, +} from '../../services/error-handler'; +import { UniswapConfig } from './uniswap.config'; +import { Contract, ContractInterface } from '@ethersproject/contracts'; +import { + Token, + Fraction, + CurrencyAmount, + Percent, + Price, +} from '@uniswap/sdk-core'; +import * as uniV3 from '@uniswap/v3-sdk'; +import { + AlphaRouter, + SwapToRatioResponse, + SwapToRatioStatus, +} from '@uniswap/smart-order-router'; +import { providers, Wallet, Signer, utils } from 'ethers'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { Ethereum } from '../../chains/ethereum/ethereum'; +import { + PoolState, + RawPosition, + AddPosReturn, + ReduceLiquidityData, +} from './uniswap.lp.interfaces'; +import * as math from 'mathjs'; + +export class UniswapLPHelper { + protected ethereum: Ethereum; + protected chainId; + private _router: string; + private _nftManager: string; + private _ttl: number; + private _routerAbi: ContractInterface; + private _nftAbi: ContractInterface; + private _poolAbi: ContractInterface; + private _alphaRouter: AlphaRouter; + private tokenList: Record = {}; + private _chain: string; + private _ready: boolean = false; + public abiDecoder: any; + + constructor(chain: string, network: string) { + this.ethereum = Ethereum.getInstance(network); + this._chain = chain; + this.chainId = this.ethereum.chainId; + this._alphaRouter = new AlphaRouter({ + chainId: this.chainId, + provider: this.ethereum.provider, + }); + this._router = + UniswapConfig.config.uniswapV3SmartOrderRouterAddress(network); + this._nftManager = UniswapConfig.config.uniswapV3NftManagerAddress(network); + this._ttl = UniswapConfig.config.ttl; + this._routerAbi = + require('@uniswap/v3-periphery/artifacts/contracts/SwapRouter.sol/SwapRouter.json').abi; + this._nftAbi = + require('@uniswap/v3-periphery/artifacts/contracts/NonfungiblePositionManager.sol/NonfungiblePositionManager.json').abi; + this._poolAbi = + require('@uniswap/v3-core/artifacts/contracts/UniswapV3Pool.sol/UniswapV3Pool.json').abi; + this.abiDecoder = require('abi-decoder'); + this.abiDecoder.addABI(this._nftAbi); + this.abiDecoder.addABI(this._routerAbi); + } + + public ready(): boolean { + return this._ready; + } + + public get alphaRouter(): AlphaRouter { + return this._alphaRouter; + } + + public get router(): string { + return this._router; + } + + public get nftManager(): string { + return this._nftManager; + } + + public get ttl(): number { + return parseInt(String(Date.now() / 1000)) + this._ttl; + } + + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + public get nftAbi(): ContractInterface { + return this._nftAbi; + } + + public get poolAbi(): ContractInterface { + return this._poolAbi; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (this._chain == 'ethereum' && !this.ethereum.ready()) + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('ETH'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + for (const token of this.ethereum.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + getPercentage(rawPercent: number | string): Percent { + const slippage = math.fraction(rawPercent) as math.Fraction; + return new Percent(slippage.n, slippage.d * 100); + } + + getSlippagePercentage(): Percent { + const allowedSlippage = UniswapConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + getContract( + contract: string, + signer: providers.StaticJsonRpcProvider | Signer + ): Contract { + if (contract === 'router') { + return new Contract(this.router, this.routerAbi, signer); + } else { + return new Contract(this.nftManager, this.nftAbi, signer); + } + } + + getPoolContract( + pool: string, + wallet: providers.StaticJsonRpcProvider | Signer + ): Contract { + return new Contract(pool, this.poolAbi, wallet); + } + + async getPoolState( + poolAddress: string, + fee: uniV3.FeeAmount + ): Promise { + const poolContract = this.getPoolContract( + poolAddress, + this.ethereum.provider + ); + const minTick = uniV3.nearestUsableTick( + uniV3.TickMath.MIN_TICK, + uniV3.TICK_SPACINGS[fee] + ); + const maxTick = uniV3.nearestUsableTick( + uniV3.TickMath.MAX_TICK, + uniV3.TICK_SPACINGS[fee] + ); + const poolDataReq = await Promise.allSettled([ + poolContract.liquidity(), + poolContract.slot0(), + poolContract.ticks(minTick), + poolContract.ticks(maxTick), + ]); + + const rejected = poolDataReq.filter( + (r) => r.status === 'rejected' + ) as PromiseRejectedResult[]; + + if (rejected.length > 0) throw new Error('Unable to fetch pool state'); + + const poolData = ( + poolDataReq.filter( + (r) => r.status === 'fulfilled' + ) as PromiseFulfilledResult[] + ).map((r) => r.value); + + return { + liquidity: poolData[0], + sqrtPriceX96: poolData[1][0], + tick: poolData[1][1], + observationIndex: poolData[1][2], + observationCardinality: poolData[1][3], + observationCardinalityNext: poolData[1][4], + feeProtocol: poolData[1][5], + unlocked: poolData[1][6], + fee: fee, + tickProvider: [ + { + index: minTick, + liquidityNet: poolData[2][1], + liquidityGross: poolData[2][0], + }, + { + index: maxTick, + liquidityNet: poolData[3][1], + liquidityGross: poolData[3][0], + }, + ], + }; + } + + async poolPrice( + token0: Token, + token1: Token, + tier: uniV3.FeeAmount, + period: number = 1, + interval: number = 1 + ): Promise { + const fetchPriceTime = []; + const prices = []; + const poolContract = new Contract( + uniV3.Pool.getAddress(token0, token1, tier), + this.poolAbi, + this.ethereum.provider + ); + for ( + let x = Math.ceil(period / interval) * interval; + x >= 0; + x -= interval + ) { + fetchPriceTime.push(x); + } + try { + const response = await poolContract.observe(fetchPriceTime); + for (let twap = 0; twap < response.tickCumulatives.length - 1; twap++) { + prices.push( + uniV3 + .tickToPrice( + token0, + token1, + Math.ceil( + response.tickCumulatives[twap + 1].sub( + response.tickCumulatives[twap].toNumber() + ) / interval + ) + ) + .toFixed(8) + ); + } + } catch (e) { + return ['0']; + } + return prices; + } + + async getRawPosition(wallet: Wallet, tokenId: number): Promise { + const contract = this.getContract('nft', wallet); + const requests = [contract.positions(tokenId)]; + const positionInfoReq = await Promise.allSettled(requests); + const rejected = positionInfoReq.filter( + (r) => r.status === 'rejected' + ) as PromiseRejectedResult[]; + if (rejected.length > 0) throw new Error('Unable to fetch position'); + const positionInfo = ( + positionInfoReq.filter( + (r) => r.status === 'fulfilled' + ) as PromiseFulfilledResult[] + ).map((r) => r.value); + return positionInfo[0]; + } + + getReduceLiquidityData( + percent: number, + tokenId: number, + token0: Token, + token1: Token, + wallet: Wallet + ): ReduceLiquidityData { + return { + tokenId: tokenId, + liquidityPercentage: this.getPercentage(percent), + slippageTolerance: this.getSlippagePercentage(), + deadline: this.ttl, + burnToken: false, + collectOptions: { + expectedCurrencyOwed0: CurrencyAmount.fromRawAmount(token0, '0'), + expectedCurrencyOwed1: CurrencyAmount.fromRawAmount(token1, '0'), + recipient: wallet.address, + }, + }; + } + + async addPositionHelper( + wallet: Wallet, + token0: Token, + token1: Token, + amount0: string, + amount1: string, + fee: uniV3.FeeAmount, + lowerPrice: number, + upperPrice: number, + tokenId: number = 0 + ): Promise { + if (token1.sortsBefore(token0)) { + [token0, token1] = [token1, token0]; + [amount0, amount1] = [amount1, amount0]; + [lowerPrice, upperPrice] = [1 / upperPrice, 1 / lowerPrice]; + } + const lowerPriceInFraction = math.fraction(lowerPrice) as math.Fraction; + const upperPriceInFraction = math.fraction(upperPrice) as math.Fraction; + const poolData = await this.getPoolState( + uniV3.Pool.getAddress(token0, token1, fee), + fee + ); + const pool = new uniV3.Pool( + token0, + token1, + poolData.fee, + poolData.sqrtPriceX96.toString(), + poolData.liquidity.toString(), + poolData.tick + ); + + const addLiquidityOptions = + tokenId === 0 ? { recipient: wallet.address } : { tokenId: tokenId }; + + const swapOptions = { + recipient: wallet.address, + slippageTolerance: this.getSlippagePercentage(), + deadline: this.ttl, + }; + + const tickLower = uniV3.nearestUsableTick( + uniV3.priceToClosestTick( + new Price( + token0, + token1, + utils + .parseUnits(lowerPriceInFraction.d.toString(), token0.decimals) + .toString(), + utils + .parseUnits(lowerPriceInFraction.n.toString(), token1.decimals) + .toString() + ) + ), + uniV3.TICK_SPACINGS[fee] + ); + + const tickUpper = uniV3.nearestUsableTick( + uniV3.priceToClosestTick( + new Price( + token0, + token1, + utils + .parseUnits(upperPriceInFraction.d.toString(), token0.decimals) + .toString(), + utils + .parseUnits(upperPriceInFraction.n.toString(), token1.decimals) + .toString() + ) + ), + uniV3.TICK_SPACINGS[fee] + ); + + const position = uniV3.Position.fromAmounts({ + pool: pool, + tickLower: + tickLower === tickUpper + ? tickLower - uniV3.TICK_SPACINGS[fee] + : tickLower, + tickUpper: tickUpper, + amount0: utils.parseUnits(amount0, token0.decimals).toString(), + amount1: utils.parseUnits(amount1, token1.decimals).toString(), + useFullPrecision: true, + }); + + const autorouterRoute: SwapToRatioResponse = + await this.alphaRouter.routeToRatio( + CurrencyAmount.fromRawAmount( + token0, + utils.parseUnits(amount0, token0.decimals).toString() + ), + CurrencyAmount.fromRawAmount( + token1, + utils.parseUnits(amount1, token1.decimals).toString() + ), + position, + { + ratioErrorTolerance: new Fraction(1, 100), + maxIterations: 6, + }, + { + swapOptions: swapOptions, + addLiquidityOptions: addLiquidityOptions, + } + ); + + let methodParameters: uniV3.MethodParameters; + let swapReq = false; + if (autorouterRoute.status === SwapToRatioStatus.SUCCESS) { + swapReq = true; + methodParameters = autorouterRoute.result + .methodParameters as uniV3.MethodParameters; + } else if (autorouterRoute.status === SwapToRatioStatus.NO_SWAP_NEEDED) { + methodParameters = uniV3.NonfungiblePositionManager.addCallParameters( + position, + { ...swapOptions, ...addLiquidityOptions } + ); + } else { + throw new Error( + `Unable to add liquidity - ${SwapToRatioStatus[autorouterRoute.status]}` + ); + } + return { ...methodParameters, swapRequired: swapReq }; + } + + async reducePositionHelper( + wallet: Wallet, + tokenId: number, + decreasePercent: number + ): Promise { + // Reduce position and burn + const positionData = await this.getRawPosition(wallet, tokenId); + const token0 = this.getTokenByAddress(positionData.token0); + const token1 = this.getTokenByAddress(positionData.token1); + const fee = positionData.fee; + if (!token0 || !token1) { + throw new Error(`One of the tokens in this position isn't recognized.`); + } + const poolAddress = uniV3.Pool.getAddress(token0, token1, fee); + const poolData = await this.getPoolState(poolAddress, fee); + const position = new uniV3.Position({ + pool: new uniV3.Pool( + token0, + token1, + poolData.fee, + poolData.sqrtPriceX96.toString(), + poolData.liquidity.toString(), + poolData.tick + ), + tickLower: positionData.tickLower, + tickUpper: positionData.tickUpper, + liquidity: positionData.liquidity, + }); + return uniV3.NonfungiblePositionManager.removeCallParameters( + position, + this.getReduceLiquidityData( + decreasePercent, + tokenId, + token0, + token1, + wallet + ) + ); + } +} diff --git a/src/connectors/uniswap/uniswap.lp.interfaces.ts b/src/connectors/uniswap/uniswap.lp.interfaces.ts new file mode 100644 index 0000000000..5169affaaa --- /dev/null +++ b/src/connectors/uniswap/uniswap.lp.interfaces.ts @@ -0,0 +1,52 @@ +import { CurrencyAmount, Percent, Token } from '@uniswap/sdk-core'; +import * as uniV3 from '@uniswap/v3-sdk'; +import { BigNumber } from 'ethers'; + +export interface PoolState { + liquidity: BigNumber; + sqrtPriceX96: BigNumber; + tick: number; + observationIndex: BigNumber; + observationCardinality: BigNumber; + observationCardinalityNext: BigNumber; + feeProtocol: BigNumber; + unlocked: boolean; + fee: uniV3.FeeAmount; + tickProvider: { + index: number; + liquidityNet: BigNumber; + liquidityGross: BigNumber; + }[]; +} + +export interface RawPosition { + nonce: number; + operator: string; + token0: string; + token1: string; + fee: number; + tickLower: number; + tickUpper: number; + liquidity: number; + feeGrowthInside0LastX128: BigNumber; + feeGrowthInside1LastX128: BigNumber; + tokensOwed0: BigNumber; + tokensOwed1: BigNumber; +} + +export interface AddPosReturn extends uniV3.MethodParameters { + swapRequired: boolean; +} + +export interface ReduceLiquidityData { + tokenId: number; + liquidityPercentage: Percent; + slippageTolerance: Percent; + deadline: number; + burnToken: boolean; + collectOptions: { + expectedCurrencyOwed0: CurrencyAmount; + expectedCurrencyOwed1: CurrencyAmount; + recipient: string; + }; +} diff --git a/src/connectors/uniswap/uniswap.lp.ts b/src/connectors/uniswap/uniswap.lp.ts new file mode 100644 index 0000000000..e6205c0174 --- /dev/null +++ b/src/connectors/uniswap/uniswap.lp.ts @@ -0,0 +1,257 @@ +import { logger } from '../../services/logger'; +import { PositionInfo, UniswapLPish } from '../../services/common-interfaces'; +import { UniswapConfig } from './uniswap.config'; +import { Token } from '@uniswap/sdk-core'; +import * as uniV3 from '@uniswap/v3-sdk'; +import { + BigNumber, + Transaction, + Wallet, + utils, + constants, + providers, +} from 'ethers'; +import { UniswapLPHelper } from './uniswap.lp.helper'; +import { AddPosReturn } from './uniswap.lp.interfaces'; + +const MaxUint128 = BigNumber.from(2).pow(128).sub(1); + +export type Overrides = { + gasLimit: BigNumber; + gasPrice?: BigNumber; + value?: BigNumber; + nonce?: BigNumber; + maxFeePerGas?: BigNumber; + maxPriorityFeePerGas?: BigNumber; +}; + +export class UniswapLP extends UniswapLPHelper implements UniswapLPish { + private static _instances: { [name: string]: UniswapLP }; + private _gasLimitEstimate: number; + + private constructor(chain: string, network: string) { + super(chain, network); + this._gasLimitEstimate = UniswapConfig.config.gasLimitEstimate; + } + + public static getInstance(chain: string, network: string): UniswapLP { + if (UniswapLP._instances === undefined) { + UniswapLP._instances = {}; + } + if (!(chain + network in UniswapLP._instances)) { + UniswapLP._instances[chain + network] = new UniswapLP(chain, network); + } + + return UniswapLP._instances[chain + network]; + } + + /** + * Default gas limit for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + async getPosition(tokenId: number): Promise { + const contract = this.getContract('nft', this.ethereum.provider); + const requests = [ + contract.positions(tokenId), + this.collectFees(this.ethereum.provider, tokenId), // static call to calculate earned fees + ]; + const positionInfoReq = await Promise.allSettled(requests); + const rejected = positionInfoReq.filter( + (r) => r.status === 'rejected' + ) as PromiseRejectedResult[]; + if (rejected.length > 0) + throw new Error(`Unable to fetch position with id ${tokenId}`); + const positionInfo = ( + positionInfoReq.filter( + (r) => r.status === 'fulfilled' + ) as PromiseFulfilledResult[] + ).map((r) => r.value); + const position = positionInfo[0]; + const feeInfo = positionInfo[1]; + const token0 = this.getTokenByAddress(position.token0); + const token1 = this.getTokenByAddress(position.token1); + if (!token0 || !token1) { + throw new Error(`One of the tokens in this position isn't recognized.`); + } + const fee = position.fee; + const poolAddress = uniV3.Pool.getAddress(token0, token1, fee); + const poolData = await this.getPoolState(poolAddress, fee); + const positionInst = new uniV3.Position({ + pool: new uniV3.Pool( + token0, + token1, + poolData.fee, + poolData.sqrtPriceX96.toString(), + poolData.liquidity.toString(), + poolData.tick + ), + tickLower: position.tickLower, + tickUpper: position.tickUpper, + liquidity: position.liquidity, + }); + return { + token0: token0.symbol, + token1: token1.symbol, + fee: uniV3.FeeAmount[position.fee], + lowerPrice: positionInst.token0PriceLower.toFixed(8), + upperPrice: positionInst.token0PriceUpper.toFixed(8), + amount0: positionInst.amount0.toFixed(), + amount1: positionInst.amount1.toFixed(), + unclaimedToken0: utils.formatUnits( + feeInfo.amount0.toString(), + token0.decimals + ), + unclaimedToken1: utils.formatUnits( + feeInfo.amount1.toString(), + token1.decimals + ), + }; + } + + async addPosition( + wallet: Wallet, + token0: Token, + token1: Token, + amount0: string, + amount1: string, + fee: uniV3.FeeAmount, + lowerPrice: number, + upperPrice: number, + tokenId: number = 0, + gasLimit: number, + gasPrice: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise { + const addLiquidityResponse: AddPosReturn = await this.addPositionHelper( + wallet, + token0, + token1, + amount0, + amount1, + fee, + lowerPrice, + upperPrice, + tokenId + ); + + if (nonce === undefined) { + nonce = await this.ethereum.nonceManager.getNextNonce(wallet.address); + } + + const tx = await wallet.sendTransaction({ + data: addLiquidityResponse.calldata, + to: addLiquidityResponse.swapRequired ? this.router : this.nftManager, + ...this.generateOverrides( + gasLimit, + gasPrice, + nonce, + maxFeePerGas, + maxPriorityFeePerGas, + addLiquidityResponse.value + ), + }); + logger.info(`Uniswap V3 Add position Tx Hash: ${tx.hash}`); + return tx; + } + + async reducePosition( + wallet: Wallet, + tokenId: number, + decreasePercent: number = 100, + gasLimit: number, + gasPrice: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise { + // Reduce position and burn + const contract = this.getContract('nft', wallet); + const { calldata, value } = await this.reducePositionHelper( + wallet, + tokenId, + decreasePercent + ); + + if (nonce === undefined) { + nonce = await this.ethereum.nonceManager.getNextNonce(wallet.address); + } + + const tx = await contract.multicall( + [calldata], + this.generateOverrides( + gasLimit, + gasPrice, + nonce, + maxFeePerGas, + maxPriorityFeePerGas, + value + ) + ); + logger.info(`Uniswap V3 Remove position Tx Hash: ${tx.hash}`); + return tx; + } + + async collectFees( + wallet: Wallet | providers.StaticJsonRpcProvider, + tokenId: number, + gasLimit: number = this.gasLimitEstimate, + gasPrice: number = 0, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise { + const contract = this.getContract('nft', wallet); + const collectData = { + tokenId: tokenId, + recipient: constants.AddressZero, + amount0Max: MaxUint128, + amount1Max: MaxUint128, + }; + + if (wallet instanceof providers.StaticJsonRpcProvider) { + return await contract.callStatic.collect(collectData); + } else { + collectData.recipient = wallet.address; + if (nonce === undefined) { + nonce = await this.ethereum.nonceManager.getNextNonce(wallet.address); + } + return await contract.collect( + collectData, + this.generateOverrides( + gasLimit, + gasPrice, + nonce, + maxFeePerGas, + maxPriorityFeePerGas + ) + ); + } + } + + generateOverrides( + gasLimit: number, + gasPrice: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + value?: string + ): Overrides { + const overrides: Overrides = { + gasLimit: BigNumber.from(String(gasLimit.toFixed(0))), + }; + if (maxFeePerGas && maxPriorityFeePerGas) { + overrides.maxFeePerGas = maxFeePerGas; + overrides.maxPriorityFeePerGas = maxPriorityFeePerGas; + } else { + overrides.gasPrice = BigNumber.from(String((gasPrice * 1e9).toFixed(0))); + } + if (nonce) overrides.nonce = BigNumber.from(String(nonce)); + if (value) overrides.value = BigNumber.from(value); + return overrides; + } +} diff --git a/src/connectors/uniswap/uniswap.ts b/src/connectors/uniswap/uniswap.ts new file mode 100644 index 0000000000..a016f2ef90 --- /dev/null +++ b/src/connectors/uniswap/uniswap.ts @@ -0,0 +1,323 @@ +import { UniswapishPriceError } from '../../services/error-handler'; +import { isFractionString } from '../../services/validators'; +import { UniswapConfig } from './uniswap.config'; +import routerAbi from './uniswap_v2_router_abi.json'; +import { + ContractInterface, + ContractTransaction, +} from '@ethersproject/contracts'; +import { AlphaRouter } from '@uniswap/smart-order-router'; +import { Trade, SwapRouter } from '@uniswap/router-sdk'; +import { MethodParameters } from '@uniswap/v3-sdk'; +import { + Token, + CurrencyAmount, + Percent, + TradeType, + Currency, +} from '@uniswap/sdk-core'; +import { BigNumber, Transaction, Wallet } from 'ethers'; +import { logger } from '../../services/logger'; +import { percentRegexp } from '../../services/config-manager-v2'; +import { Ethereum } from '../../chains/ethereum/ethereum'; +import { Polygon } from '../../chains/polygon/polygon'; +import { ExpectedTrade, Uniswapish } from '../../services/common-interfaces'; + +export class Uniswap implements Uniswapish { + private static _instances: { [name: string]: Uniswap }; + private chain: Ethereum | Polygon; + private _alphaRouter: AlphaRouter; + private _router: string; + private _routerAbi: ContractInterface; + private _gasLimitEstimate: number; + private _ttl: number; + private _maximumHops: number; + private chainId; + private tokenList: Record = {}; + private _ready: boolean = false; + + private constructor(chain: string, network: string) { + const config = UniswapConfig.config; + if (chain === 'ethereum') { + this.chain = Ethereum.getInstance(network); + } else { + this.chain = Polygon.getInstance(network); + } + this.chainId = this.chain.chainId; + this._ttl = UniswapConfig.config.ttl; + this._maximumHops = UniswapConfig.config.maximumHops; + this._alphaRouter = new AlphaRouter({ + chainId: this.chainId, + provider: this.chain.provider, + }); + this._routerAbi = routerAbi.abi; + this._gasLimitEstimate = UniswapConfig.config.gasLimitEstimate; + this._router = config.uniswapV3SmartOrderRouterAddress(network); + } + + public static getInstance(chain: string, network: string): Uniswap { + if (Uniswap._instances === undefined) { + Uniswap._instances = {}; + } + if (!(chain + network in Uniswap._instances)) { + Uniswap._instances[chain + network] = new Uniswap(chain, network); + } + + return Uniswap._instances[chain + network]; + } + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + public getTokenByAddress(address: string): Token { + return this.tokenList[address]; + } + + public async init() { + if (!this.chain.ready()) { + await this.chain.init(); + } + for (const token of this.chain.storedTokenList) { + this.tokenList[token.address] = new Token( + this.chainId, + token.address, + token.decimals, + token.symbol, + token.name + ); + } + this._ready = true; + } + + public ready(): boolean { + return this._ready; + } + + /** + * Router address. + */ + public get router(): string { + return this._router; + } + + /** + * AlphaRouter instance. + */ + public get alphaRouter(): AlphaRouter { + return this._alphaRouter; + } + + /** + * Router smart contract ABI. + */ + public get routerAbi(): ContractInterface { + return this._routerAbi; + } + + /** + * Default gas limit used to estimate gasCost for swap transactions. + */ + public get gasLimitEstimate(): number { + return this._gasLimitEstimate; + } + + /** + * Default time-to-live for swap transactions, in seconds. + */ + public get ttl(): number { + return this._ttl; + } + + /** + * Default maximum number of hops for to go through for a swap transactions. + */ + public get maximumHops(): number { + return this._maximumHops; + } + + /** + * Gets the allowed slippage percent from the optional parameter or the value + * in the configuration. + * + * @param allowedSlippageStr (Optional) should be of the form '1/10'. + */ + public getAllowedSlippage(allowedSlippageStr?: string): Percent { + if (allowedSlippageStr != null && isFractionString(allowedSlippageStr)) { + const fractionSplit = allowedSlippageStr.split('/'); + return new Percent(fractionSplit[0], fractionSplit[1]); + } + + const allowedSlippage = UniswapConfig.config.allowedSlippage; + const nd = allowedSlippage.match(percentRegexp); + if (nd) return new Percent(nd[1], nd[2]); + throw new Error( + 'Encountered a malformed percent string in the config for ALLOWED_SLIPPAGE.' + ); + } + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + async estimateSellTrade( + baseToken: Token, + quoteToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: CurrencyAmount = + CurrencyAmount.fromRawAmount(baseToken, amount.toString()); + + logger.info( + `Fetching trade data for ${baseToken.address}-${quoteToken.address}.` + ); + + const route = await this._alphaRouter.route( + nativeTokenAmount, + quoteToken, + TradeType.EXACT_INPUT, + undefined, + { + maxSwapsPerPath: this.maximumHops, + } + ); + + if (!route) { + throw new UniswapishPriceError( + `priceSwapIn: no trade pair found for ${baseToken} to ${quoteToken}.` + ); + } + logger.info( + `Best trade for ${baseToken.address}-${quoteToken.address}: ` + + `${route.trade.executionPrice.toFixed(6)}` + + `${baseToken.symbol}.` + ); + const expectedAmount = route.trade.minimumAmountOut( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: route.trade, expectedAmount }; + } + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + async estimateBuyTrade( + quoteToken: Token, + baseToken: Token, + amount: BigNumber, + allowedSlippage?: string + ): Promise { + const nativeTokenAmount: CurrencyAmount = + CurrencyAmount.fromRawAmount(baseToken, amount.toString()); + logger.info( + `Fetching pair data for ${quoteToken.address}-${baseToken.address}.` + ); + const route = await this._alphaRouter.route( + nativeTokenAmount, + quoteToken, + TradeType.EXACT_OUTPUT, + undefined, + { + maxSwapsPerPath: this.maximumHops, + } + ); + if (!route) { + throw new UniswapishPriceError( + `priceSwapOut: no trade pair found for ${quoteToken.address} to ${baseToken.address}.` + ); + } + logger.info( + `Best trade for ${quoteToken.address}-${baseToken.address}: ` + + `${route.trade.executionPrice.invert().toFixed(6)} ` + + `${baseToken.symbol}.` + ); + + const expectedAmount = route.trade.maximumAmountIn( + this.getAllowedSlippage(allowedSlippage) + ); + return { trade: route.trade, expectedAmount }; + } + + /** + * Given a wallet and a Uniswap trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param uniswapRouter Router smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param _abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + async executeTrade( + wallet: Wallet, + trade: Trade, + gasPrice: number, + uniswapRouter: string, + ttl: number, + _abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise { + const methodParameters: MethodParameters = SwapRouter.swapCallParameters( + trade, + { + deadlineOrPreviousBlockhash: Math.floor(Date.now() / 1000 + ttl), + recipient: wallet.address, + slippageTolerance: this.getAllowedSlippage(allowedSlippage), + } + ); + + return this.chain.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + let tx: ContractTransaction; + if (maxFeePerGas !== undefined || maxPriorityFeePerGas !== undefined) { + tx = await wallet.sendTransaction({ + data: methodParameters.calldata, + to: uniswapRouter, + gasLimit: gasLimit.toFixed(0), + value: methodParameters.value, + nonce: nextNonce, + maxFeePerGas, + maxPriorityFeePerGas, + }); + } else { + tx = await wallet.sendTransaction({ + data: methodParameters.calldata, + to: this.router, + gasPrice: (gasPrice * 1e9).toFixed(0), + gasLimit: gasLimit.toFixed(0), + value: methodParameters.value, + nonce: nextNonce, + }); + } + logger.info(JSON.stringify(tx)); + return tx; + } + ); + } +} diff --git a/src/connectors/uniswap/uniswap_v2_router_abi.json b/src/connectors/uniswap/uniswap_v2_router_abi.json new file mode 100644 index 0000000000..e2eac42088 --- /dev/null +++ b/src/connectors/uniswap/uniswap_v2_router_abi.json @@ -0,0 +1,1924 @@ +{ + "abi": [ + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "evm": { + "bytecode": { + "linkReferences": {}, + "object": "", + "opcodes": "", + "sourceMap": "" + }, + "deployedBytecode": { + "immutableReferences": {}, + "linkReferences": {}, + "object": "", + "opcodes": "", + "sourceMap": "" + } + }, + "interface": [ + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "bytecode": "" +} diff --git a/src/connectors/vvs/abi.json b/src/connectors/vvs/abi.json new file mode 100644 index 0000000000..c1d05c2c79 --- /dev/null +++ b/src/connectors/vvs/abi.json @@ -0,0 +1,973 @@ +[ + { + "inputs": [ + { + "internalType": "address", + "name": "_factory", + "type": "address" + }, + { + "internalType": "address", + "name": "_WETH", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "inputs": [], + "name": "WETH", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountADesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "amountTokenDesired", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "addLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "factory", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountIn", + "outputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveOut", + "type": "uint256" + } + ], + "name": "getAmountOut", + "outputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsIn", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + } + ], + "name": "getAmountsOut", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "reserveB", + "type": "uint256" + } + ], + "name": "quote", + "outputs": [ + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidity", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETH", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "removeLiquidityETHSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountToken", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountTokenMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountETHMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityETHWithPermitSupportingFeeOnTransferTokens", + "outputs": [ + { + "internalType": "uint256", + "name": "amountETH", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "tokenA", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenB", + "type": "address" + }, + { + "internalType": "uint256", + "name": "liquidity", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountAMin", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountBMin", + "type": "uint256" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + }, + { + "internalType": "bool", + "name": "approveMax", + "type": "bool" + }, + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "name": "removeLiquidityWithPermit", + "outputs": [ + { + "internalType": "uint256", + "name": "amountA", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountB", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapETHForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactETHForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForETHSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountIn", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountOutMin", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapExactTokensForTokensSupportingFeeOnTransferTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactETH", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "amountOut", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "amountInMax", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "path", + "type": "address[]" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "uint256", + "name": "deadline", + "type": "uint256" + } + ], + "name": "swapTokensForExactTokens", + "outputs": [ + { + "internalType": "uint256[]", + "name": "amounts", + "type": "uint256[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } +] diff --git a/src/connectors/vvs/vvs.config.ts b/src/connectors/vvs/vvs.config.ts new file mode 100644 index 0000000000..02f38ff197 --- /dev/null +++ b/src/connectors/vvs/vvs.config.ts @@ -0,0 +1,7 @@ +import { CronosBaseUniswapishConnectorConfig } from '../cronos-base/cronos-base-uniswapish-connector.config'; + +export namespace VVSConfig { + const tradingTypes = ['EVM_AMM']; + export const config: CronosBaseUniswapishConnectorConfig.NetworkConfig = + CronosBaseUniswapishConnectorConfig.buildConfig('vvs', tradingTypes); +} diff --git a/src/connectors/vvs/vvs.ts b/src/connectors/vvs/vvs.ts new file mode 100644 index 0000000000..63f5fd153e --- /dev/null +++ b/src/connectors/vvs/vvs.ts @@ -0,0 +1,136 @@ +import { BigNumber } from 'ethers'; +import { + Currency, + CurrencyAmount, + Fetcher, + Pair, + Percent, + Router, + Token, + TokenAmount, + Trade, +} from 'vvs-sdk'; +import { + Pairish, + Percentish, + UniswapishSwapParameters, +} from '../../services/common-interfaces'; +import { + CronosBaseUniswapishSDKProvider, + CronosBaseUniswapishConnector, +} from '../cronos-base/cronos-base-uniswapish-connector'; +import { CronosBaseUniswapishConnectorConfig } from '../cronos-base/cronos-base-uniswapish-connector.config'; +import routerAbi from './abi.json'; +import { VVSConfig } from './vvs.config'; + +export class VVSConnector extends CronosBaseUniswapishConnector { + constructor(chain: string, network: string) { + const sdkProvider = new VVSSDKProvider(); + super(sdkProvider, routerAbi, chain, network); + } + protected buildConfig(): CronosBaseUniswapishConnectorConfig.NetworkConfig { + return VVSConfig.config; + } +} + +class VVSSDKProvider implements CronosBaseUniswapishSDKProvider { + public buildToken( + chainId: number, + address: string, + decimals: number, + symbol?: string, + name?: string, + projectLink?: string + ): Token { + return new Token(chainId, address, decimals, symbol, name, projectLink); + } + + public buildTokenAmount(token: Token, amount: BigNumber): TokenAmount { + return new TokenAmount(token, amount.toString()); + } + + public fetchPairData( + tokenA: Token, + tokenB: Token, + provider?: import('@ethersproject/providers').BaseProvider + ): Promise { + return Fetcher.fetchPairData(tokenA, tokenB, provider); + } + + public bestTradeExactIn( + pairs: Pair[], + currencyAmountIn: CurrencyAmount, + currencyOut: Currency, + bestTradeOptions?: { + maxNumResults?: number; + maxHops?: number; + }, + currentPairs?: Pair[], + originalAmountIn?: CurrencyAmount, + bestTrades?: Trade[] + ): Trade[] { + return Trade.bestTradeExactIn( + pairs, + currencyAmountIn, + currencyOut, + bestTradeOptions, + currentPairs, + originalAmountIn, + bestTrades + ); + } + + public bestTradeExactOut( + pairs: Pair[], + currencyIn: Currency, + currencyAmountOut: CurrencyAmount, + bestTradeOptions?: { + maxNumResults?: number; + maxHops?: number; + }, + currentPairs?: Pair[], + originalAmountOut?: CurrencyAmount, + bestTrades?: Trade[] + ): Trade[] { + return Trade.bestTradeExactOut( + pairs, + currencyIn, + currencyAmountOut, + bestTradeOptions, + currentPairs, + originalAmountOut, + bestTrades + ); + } + + public buildPercent(numerator: string, denominator?: string): Percentish { + return new Percent(numerator, denominator); + } + + public minimumAmountOut( + trade: Trade, + slippageTolerance: Percent + ): CurrencyAmount { + return trade.minimumAmountOut(slippageTolerance); + } + + public maximumAmountIn( + trade: Trade, + slippageTolerance: Percent + ): CurrencyAmount { + return trade.maximumAmountIn(slippageTolerance); + } + + public swapCallParameters( + trade: Trade, + tradeOptions: { + allowedSlippage: Percent; + ttl: number; + recipient: string; + feeOnTransfer?: boolean; + deadline?: number; + } + ): UniswapishSwapParameters { + return Router.swapCallParameters(trade, tradeOptions); + } +} diff --git a/src/evm/evm.requests.ts b/src/evm/evm.requests.ts new file mode 100644 index 0000000000..a814e86cb5 --- /dev/null +++ b/src/evm/evm.requests.ts @@ -0,0 +1,58 @@ +import { + CustomTransaction, + NetworkSelectionRequest, +} from '../services/common-interfaces'; + +export interface NonceRequest extends NetworkSelectionRequest { + address: string; // the users public Ethereum key +} +export interface NonceResponse { + nonce: number; // the user's nonce +} + +export interface AllowancesRequest extends NetworkSelectionRequest { + address: string; // the users public Ethereum key + spender: string; // the spender address for whom approvals are checked + tokenSymbols: string[]; // a list of token symbol +} + +export interface AllowancesResponse { + network: string; + timestamp: number; + latency: number; + spender: string; + approvals: Record; +} + +export interface ApproveRequest extends NetworkSelectionRequest { + amount?: string; // the amount the spender will be approved to use + nonce?: number; // the address's next nonce + maxFeePerGas?: string; + maxPriorityFeePerGas?: string; + address: string; // the user's public Ethereum key + spender: string; // the address of the spend (or a pre-defined string like 'uniswap', 'balancer', etc.) + token: string; // the token symbol the spender will be approved for +} + +export interface ApproveResponse { + network: string; + timestamp: number; + latency: number; + tokenAddress: string; + spender: string; + amount: string; + nonce: number; + approval: CustomTransaction; +} + +export interface CancelRequest extends NetworkSelectionRequest { + nonce: number; // the nonce of the transaction to be canceled + address: string; // the user's public Ethereum key +} + +export interface CancelResponse { + network: string; + timestamp: number; + latency: number; + txHash: string | undefined; +} diff --git a/src/evm/evm.routes.ts b/src/evm/evm.routes.ts new file mode 100644 index 0000000000..0e9e94640f --- /dev/null +++ b/src/evm/evm.routes.ts @@ -0,0 +1,119 @@ +/* eslint-disable no-inner-declarations */ +/* eslint-disable @typescript-eslint/ban-types */ +import { Router, Request, Response } from 'express'; +import { Ethereumish } from '../services/common-interfaces'; +import { asyncHandler } from '../services/error-handler'; +import { + approve, + allowances, + nonce, + nextNonce, + cancel, +} from '../chains/ethereum/ethereum.controllers'; + +import { + validateAllowancesRequest, + validateApproveRequest, + validateCancelRequest, + validateNonceRequest, +} from '../chains/ethereum/ethereum.validators'; +import { getChain } from '../services/connection-manager'; +import { + AllowancesRequest, + AllowancesResponse, + ApproveRequest, + ApproveResponse, + CancelRequest, + CancelResponse, + NonceRequest, + NonceResponse, +} from './evm.requests'; + +export namespace EVMRoutes { + export const router = Router(); + + router.post( + '/nextNonce', + asyncHandler( + async ( + req: Request<{}, {}, NonceRequest>, + res: Response + ) => { + validateNonceRequest(req.body); + const chain = await getChain( + req.body.chain, + req.body.network + ); + res.status(200).json(await nextNonce(chain, req.body)); + } + ) + ); + + router.post( + '/nonce', + asyncHandler( + async ( + req: Request<{}, {}, NonceRequest>, + res: Response + ) => { + validateNonceRequest(req.body); + const chain = await getChain( + req.body.chain, + req.body.network + ); + res.status(200).json(await nonce(chain, req.body)); + } + ) + ); + + router.post( + '/allowances', + asyncHandler( + async ( + req: Request<{}, {}, AllowancesRequest>, + res: Response + ) => { + validateAllowancesRequest(req.body); + const chain = await getChain( + req.body.chain, + req.body.network + ); + res.status(200).json(await allowances(chain, req.body)); + } + ) + ); + + router.post( + '/approve', + asyncHandler( + async ( + req: Request<{}, {}, ApproveRequest>, + res: Response + ) => { + validateApproveRequest(req.body); + const chain = await getChain( + req.body.chain, + req.body.network + ); + res.status(200).json(await approve(chain, req.body)); + } + ) + ); + + router.post( + '/cancel', + asyncHandler( + async ( + req: Request<{}, {}, CancelRequest>, + res: Response + ) => { + validateCancelRequest(req.body); + const chain = await getChain( + req.body.chain, + req.body.network + ); + res.status(200).json(await cancel(chain, req.body)); + } + ) + ); +} diff --git a/src/https.ts b/src/https.ts new file mode 100644 index 0000000000..0175d47e7e --- /dev/null +++ b/src/https.ts @@ -0,0 +1,41 @@ +import { Application } from 'express'; +import fs from 'fs'; +import https from 'https'; +import { ConfigManagerCertPassphrase } from './services/config-manager-cert-passphrase'; +import { ConfigManagerV2 } from './services/config-manager-v2'; + +export const addHttps = (app: Application) => { + const serverKey = fs.readFileSync( + ConfigManagerV2.getInstance().get('ssl.keyPath'), + { + encoding: 'utf-8', + } + ); + const serverCert = fs.readFileSync( + ConfigManagerV2.getInstance().get('ssl.certificatePath'), + { + encoding: 'utf-8', + } + ); + const caCert = fs.readFileSync( + ConfigManagerV2.getInstance().get('ssl.caCertificatePath'), + { + encoding: 'utf-8', + } + ); + + return https.createServer( + { + key: serverKey, + cert: serverCert, + // request client certificate from user + requestCert: true, + // reject requests with no valid certificate + rejectUnauthorized: true, + // use ca cert created with own key for self-signed + ca: [caCert], + passphrase: ConfigManagerCertPassphrase.readPassphrase(), + }, + app + ); +}; diff --git a/src/index.ts b/src/index.ts new file mode 100644 index 0000000000..fee457573c --- /dev/null +++ b/src/index.ts @@ -0,0 +1,3 @@ +import { startGateway } from './app'; + +startGateway(); diff --git a/src/network/network.controllers.ts b/src/network/network.controllers.ts new file mode 100644 index 0000000000..1701ec0430 --- /dev/null +++ b/src/network/network.controllers.ts @@ -0,0 +1,166 @@ +import { + StatusRequest, + StatusResponse, + TokensRequest, + TokensResponse, +} from './network.requests'; +import { Avalanche } from '../chains/avalanche/avalanche'; +import { BinanceSmartChain } from '../chains/binance-smart-chain/binance-smart-chain'; +import { Ethereum } from '../chains/ethereum/ethereum'; +import { Harmony } from '../chains/harmony/harmony'; +import { Polygon } from '../chains/polygon/polygon'; +import { TokenInfo } from '../services/ethereum-base'; +import { + HttpException, + UNKNOWN_CHAIN_ERROR_CODE, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE, +} from '../services/error-handler'; +import { EthereumBase } from '../services/ethereum-base'; +import { Cronos } from '../chains/cronos/cronos'; +import { Near } from '../chains/near/near'; +import { Nearish } from '../services/common-interfaces'; + +export async function getStatus( + req: StatusRequest +): Promise { + const statuses: StatusResponse[] = []; + let connections: any[] = []; + let chain: string; + let chainId: number; + let rpcUrl: string; + let currentBlockNumber: number | undefined; + let nativeCurrency: string; + + if (req.chain) { + if (req.chain === 'avalanche') { + connections.push(Avalanche.getInstance(req.network as string)); + } else if (req.chain === 'binance-smart-chain') { + connections.push(BinanceSmartChain.getInstance(req.network as string)); + } else if (req.chain === 'harmony') { + connections.push(Harmony.getInstance(req.network as string)); + } else if (req.chain === 'ethereum') { + connections.push(Ethereum.getInstance(req.network as string)); + } else if (req.chain === 'polygon') { + connections.push(Polygon.getInstance(req.network as string)); + } else if (req.chain === 'near') { + connections.push(Near.getInstance(req.network as string)); + } else if (req.chain === 'cronos') { + connections.push(await Cronos.getInstance(req.network as string)); + } else { + throw new HttpException( + 500, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE(req.chain), + UNKNOWN_CHAIN_ERROR_CODE + ); + } + } else { + const avalancheConnections = Avalanche.getConnectedInstances(); + connections = connections.concat( + avalancheConnections ? Object.values(avalancheConnections) : [] + ); + + const harmonyConnections = Harmony.getConnectedInstances(); + connections = connections.concat( + harmonyConnections ? Object.values(harmonyConnections) : [] + ); + + const ethereumConnections = Ethereum.getConnectedInstances(); + connections = connections.concat( + ethereumConnections ? Object.values(ethereumConnections) : [] + ); + + const polygonConnections = Polygon.getConnectedInstances(); + connections = connections.concat( + polygonConnections ? Object.values(polygonConnections) : [] + ); + + const cronosConnections = Cronos.getConnectedInstances(); + connections = connections.concat( + cronosConnections ? Object.values(cronosConnections) : [] + ); + + const nearConnections = Near.getConnectedInstances(); + connections = connections.concat( + nearConnections ? Object.values(nearConnections) : [] + ); + + const bscConnections = BinanceSmartChain.getConnectedInstances(); + connections = connections.concat( + bscConnections ? Object.values(bscConnections) : [] + ); + } + + for (const connection of connections) { + if (!connection.ready()) { + await connection.init(); + } + chain = connection.chain; + chainId = connection.chainId; + rpcUrl = connection.rpcUrl; + nativeCurrency = connection.nativeTokenSymbol; + + try { + currentBlockNumber = await connection.getCurrentBlockNumber(); + } catch (_e) { + if (await connection.provider.getNetwork()) currentBlockNumber = 1; // necessary for connectors like hedera that do not have concept of blocknumber + } + statuses.push({ + chain, + chainId, + rpcUrl, + currentBlockNumber, + nativeCurrency, + }); + } + + return req.chain ? statuses[0] : statuses; +} + +export async function getTokens(req: TokensRequest): Promise { + let connection: EthereumBase | Nearish; + let tokens: TokenInfo[] = []; + + if (req.chain && req.network) { + if (req.chain === 'avalanche') { + connection = Avalanche.getInstance(req.network); + } else if (req.chain === 'binance-smart-chain') { + connection = BinanceSmartChain.getInstance(req.network); + } else if (req.chain === 'harmony') { + connection = Harmony.getInstance(req.network); + } else if (req.chain === 'ethereum') { + connection = Ethereum.getInstance(req.network); + } else if (req.chain === 'polygon') { + connection = Polygon.getInstance(req.network); + } else if (req.chain === 'near') { + connection = Near.getInstance(req.network); + } else if (req.chain === 'cronos') { + connection = await Cronos.getInstance(req.network); + } else { + throw new HttpException( + 500, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE(req.chain), + UNKNOWN_CHAIN_ERROR_CODE + ); + } + } else { + throw new HttpException( + 500, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE(req.chain), + UNKNOWN_CHAIN_ERROR_CODE + ); + } + + if (!connection.ready()) { + await connection.init(); + } + + if (!req.tokenSymbols) { + tokens = connection.storedTokenList; + } else { + for (const t of req.tokenSymbols as []) { + tokens.push(connection.getTokenForSymbol(t) as TokenInfo); + } + } + + return { tokens }; +} diff --git a/src/network/network.requests.ts b/src/network/network.requests.ts new file mode 100644 index 0000000000..881ab816ac --- /dev/null +++ b/src/network/network.requests.ts @@ -0,0 +1,57 @@ +import { + CustomTransactionReceipt, + CustomTransactionResponse, + NetworkSelectionRequest, +} from '../services/common-interfaces'; + +import { TokenInfo } from '../services/ethereum-base'; + +export interface BalanceRequest extends NetworkSelectionRequest { + address: string; // the users public Ethereum key + tokenSymbols: string[]; // a list of token symbol +} + +export interface BalanceResponse { + network: string; + timestamp: number; + latency: number; + balances: Record; // the balance should be a string encoded number +} + +export interface PollRequest extends NetworkSelectionRequest { + txHash: string; +} + +export interface PollResponse { + network: string; + timestamp: number; + currentBlock: number; + txHash: string; + txStatus: number; + txBlock: number; + txData: CustomTransactionResponse | null; + txReceipt: CustomTransactionReceipt | null; +} + +export interface StatusRequest { + chain?: string; //the target chain (e.g. ethereum, avalanche, or harmony) + network?: string; // the target network of the chain (e.g. mainnet) +} + +export interface StatusResponse { + chain: string; + chainId: number; + rpcUrl: string; + nativeCurrency: string; + currentBlockNumber?: number; // only reachable if connected +} + +export interface TokensRequest { + chain?: string; //the target chain (e.g. ethereum, avalanche, or harmony) + network?: string; // the target network of the chain (e.g. mainnet) + tokenSymbols?: string[]; +} + +export interface TokensResponse { + tokens: TokenInfo[]; +} diff --git a/src/network/network.routes.ts b/src/network/network.routes.ts new file mode 100644 index 0000000000..67dd9a79ac --- /dev/null +++ b/src/network/network.routes.ts @@ -0,0 +1,110 @@ +/* eslint-disable @typescript-eslint/ban-types */ +import { NextFunction, Request, Response, Router } from 'express'; +import * as ethereumControllers from '../chains/ethereum/ethereum.controllers'; +import { Ethereumish } from '../services/common-interfaces'; +import { ConfigManagerV2 } from '../services/config-manager-v2'; +import { getChain } from '../services/connection-manager'; +import { asyncHandler } from '../services/error-handler'; +import { + mkRequestValidator, + RequestValidator, + validateTxHash, +} from '../services/validators'; +import { getStatus, getTokens } from './network.controllers'; +import { + BalanceRequest, + BalanceResponse, + PollRequest, + PollResponse, + StatusRequest, + StatusResponse, + TokensRequest, + TokensResponse, +} from './network.requests'; +import { + validateBalanceRequest as validateEthereumBalanceRequest, + validateChain as validateEthereumChain, + validateNetwork as validateEthereumNetwork, +} from '../chains/ethereum/ethereum.validators'; + +export const validatePollRequest: RequestValidator = mkRequestValidator([ + validateTxHash, +]); + +export const validateTokensRequest: RequestValidator = mkRequestValidator([ + validateEthereumChain, + validateEthereumNetwork, +]); + +export namespace NetworkRoutes { + export const router = Router(); + + router.get( + '/status', + asyncHandler( + async ( + req: Request<{}, {}, {}, StatusRequest>, + res: Response + ) => { + res.status(200).json(await getStatus(req.query)); + } + ) + ); + + router.get('/config', (_req: Request, res: Response) => { + res.status(200).json(ConfigManagerV2.getInstance().allConfigurations); + }); + + router.post( + '/balances', + asyncHandler( + async ( + req: Request<{}, {}, BalanceRequest>, + res: Response, + _next: NextFunction + ) => { + validateEthereumBalanceRequest(req.body); + const chain = await getChain( + req.body.chain, + req.body.network + ); + + res + .status(200) + .json(await ethereumControllers.balances(chain, req.body)); + } + ) + ); + + router.post( + '/poll', + asyncHandler( + async ( + req: Request<{}, {}, PollRequest>, + res: Response + ) => { + validatePollRequest(req.body); + + const chain = await getChain( + req.body.chain, + req.body.network + ); + + res.status(200).json(await ethereumControllers.poll(chain, req.body)); + } + ) + ); + + router.get( + '/tokens', + asyncHandler( + async ( + req: Request<{}, {}, {}, TokensRequest>, + res: Response + ) => { + validateTokensRequest(req.query); + res.status(200).json(await getTokens(req.query)); + } + ) + ); +} diff --git a/src/paths.ts b/src/paths.ts new file mode 100644 index 0000000000..f5927c9c4c --- /dev/null +++ b/src/paths.ts @@ -0,0 +1,17 @@ +import path from 'path'; +import fs from 'fs'; + +/** + * Returns the project root path. + * + * This can be different depending on whether compiled scripts (i.e. in dist/) + * are used, or, in jest's case, whether the .ts files are being run directly + * via ts-jest. + */ +export function rootPath(): string { + const insideDistDir: boolean = __filename.match(/dist\//) !== null; + if (insideDistDir) { + return fs.realpathSync(path.join(__dirname, '../../'), 'utf8'); + } + return fs.realpathSync(path.join(__dirname, '../'), 'utf8'); +} diff --git a/src/services/base.ts b/src/services/base.ts new file mode 100644 index 0000000000..a0e9a84704 --- /dev/null +++ b/src/services/base.ts @@ -0,0 +1,114 @@ +import { BigNumber } from 'ethers'; +import { format, fraction, number } from 'mathjs'; +import { isFractionString, isFloatString } from './validators'; + +// the type of information source for tokens +export type TokenListType = 'FILE' | 'URL'; + +// insert a string into another string at an index +const stringInsert = (str: string, val: string, index: number) => { + if (index > 0) { + return str.substring(0, index) + val + str.substr(index); + } + + return val + str; +}; + +// counts decimal places of a value +export const countDecimals = (value: number): number => { + if (value >= 1 || value <= 0) { + throw new RangeError( + 'countDecimals() is only valid for values between (0, 1).' + ); + } else { + return Number(value.toExponential().split('-')[1]); + } +}; + +// convert a BigNumber and the number of decimals into a numeric string. +// this makes it JavaScript compatible while preserving all the data. +export const bigNumberWithDecimalToStr = (n: BigNumber, d: number): string => { + const n_ = n.toString(); + + let zeros = ''; + + if (n_.length <= d) { + zeros = '0'.repeat(d - n_.length + 1); + } + + return stringInsert(n_.split('').reverse().join('') + zeros, '.', d) + .split('') + .reverse() + .join(''); +}; + +export const gasCostInEthString = ( + gasPrice: number, + gasLimitTransaction: number +): string => { + return bigNumberWithDecimalToStr( + BigNumber.from(Math.ceil(gasPrice * gasLimitTransaction)).mul( + BigNumber.from(1e9) + ), + 18 + ); +}; + +// a nice way to represent the token value without carrying around as a string +export interface TokenValue { + value: BigNumber; + decimals: number; +} + +// we should turn Token into a string when we return as a value in an API call +export const tokenValueToString = (t: TokenValue): string => { + return bigNumberWithDecimalToStr(t.value, t.decimals); +}; + +// safely parse a JSON from a string to a type. +export const safeJsonParse = + (guard: (o: any) => o is T) => + (text: string): ParseResult => { + const parsed = JSON.parse(text); + return guard(parsed) ? { parsed, hasError: false } : { hasError: true }; + }; + +// If the JSON was parsed successfully, return the result, otherwises return the error +export type ParseResult = + | { parsed: T; hasError: false; error?: undefined } + | { parsed?: undefined; hasError: true; error?: unknown }; + +export const latency = (startTime: number, endTime: number): number => { + return (endTime - startTime) / 1000; +}; + +export const walletPath = './conf/wallets'; + +// convert a fraction string to a number +export const fromFractionString = (value: string): number | null => { + if (isFractionString(value)) { + const num = number(fraction(value)); // this can return different mathematical values, control for number + if (typeof num === 'number') { + return num; + } else { + return null; + } + } else { + return null; + } +}; + +// convert a number to a fraction string or verify that a string is a string +// of a fraction +export const toFractionString = (value: number | string): string | null => { + if (typeof value === 'number') { + return format(fraction(value), { fraction: 'ratio' }); + } else { + if (isFractionString(value) || isFloatString(value)) { + return format(fraction(value), { fraction: 'ratio' }); + } else { + return null; + } + } + return null; +}; diff --git a/src/services/common-interfaces.ts b/src/services/common-interfaces.ts new file mode 100644 index 0000000000..00405eb0de --- /dev/null +++ b/src/services/common-interfaces.ts @@ -0,0 +1,680 @@ +import { Big } from 'big.js'; +import { + Contract, + Transaction, + Wallet, + ContractInterface, + BigNumber, + ethers, +} from 'ethers'; +import { EthereumBase } from './ethereum-base'; +import { CosmosBase } from './cosmos-base'; +import { Provider } from '@ethersproject/abstract-provider'; +import { CurrencyAmount, Token, Trade as TradeUniswap } from '@uniswap/sdk'; +import { Trade } from '@uniswap/router-sdk'; +import { Trade as UniswapV3Trade } from '@uniswap/v3-sdk'; +import { + TradeType, + Currency, + CurrencyAmount as UniswapCoreCurrencyAmount, + Token as UniswapCoreToken, + Fraction as UniswapFraction, +} from '@uniswap/sdk-core'; +import { + Token as TokenDefikingdoms, + CurrencyAmount as CurrencyAmountDefikingdoms, + Trade as TradeDefikingdoms, + Fraction as DefikingdomsFraction, + // } from '@defikingdoms/sdk'; +} from '@switchboard-xyz/defikingdoms-sdk'; +import { + Token as TokenPangolin, + CurrencyAmount as CurrencyAmountPangolin, + Trade as TradePangolin, + Fraction as PangolinFraction, +} from '@pangolindex/sdk'; +import { + Token as TokenQuickswap, + CurrencyAmount as CurrencyAmountQuickswap, + Trade as TradeQuickswap, + Fraction as QuickswapFraction, +} from 'quickswap-sdk'; +import { + Trade as SushiswapTrade, + Token as SushiToken, + CurrencyAmount as SushiCurrencyAmount, + TradeType as SushiTradeType, + Currency as SushiCurrency, + Fraction as SushiFraction, +} from '@sushiswap/sdk'; +import { + Token as TokenTraderjoe, + CurrencyAmount as CurrencyAmountTraderjoe, + Trade as TradeTraderjoe, + Fraction as TraderjoeFraction, +} from '@traderjoe-xyz/sdk'; +import { + Token as MMFToken, + TokenAmount as MMFTokenAmount, + Pair as MMFPair, + CurrencyAmount as CurrencyAmountMMF, + Trade as MMFTrade, + Fraction as FractionMMF, + Percent as MMFPercent, + Currency as MMFCurrency, + TradeOptions as MMFTradeOptions, + TradeOptionsDeadline as MMFTradeOptionsDeadline, + SwapParameters as MMFSwapParameters, +} from '@crocswap/sdk'; +import { + Token as VVSToken, + TokenAmount as VVSTokenAmount, + Pair as VVSPair, + CurrencyAmount as CurrencyAmountVVS, + Trade as VVSTrade, + Fraction as FractionVVS, + Percent as VVSPercent, + Currency as VVSCurrency, + TradeOptions as VVSTradeOptions, + TradeOptionsDeadline as VVSTradeOptionsDeadline, + SwapParameters as VVSSwapParameters, +} from 'vvs-sdk'; +import { Trade as DefiraTrade } from '@zuzu-cat/defira-sdk'; +import { + Token as PancakeSwapToken, + CurrencyAmount as PancakeSwapCurrencyAmount, + Trade as PancakeSwapTrade, + Fraction as PancakeSwapFraction, +} from '@pancakeswap/sdk'; +import { PerpPosition } from '../connectors/perp/perp'; +import { NearBase } from '../chains/near/near.base'; +import { Account, Contract as NearContract } from 'near-api-js'; +import { EstimateSwapView, TokenMetadata } from 'coinalpha-ref-sdk'; +import { FinalExecutionOutcome } from 'near-api-js/lib/providers'; + +// TODO Check the possibility to have clob/solana/serum equivalents here +// Check this link https://hummingbot.org/developers/gateway/building-gateway-connectors/#5-add-sdk-classes-to-uniswapish-interface +export type Tokenish = + | Token + | TokenPangolin + | UniswapCoreToken + | TokenQuickswap + | TokenTraderjoe + | UniswapCoreToken + | SushiToken + | TokenDefikingdoms + | PancakeSwapToken + | MMFToken + | VVSToken; + +export type TokenAmountish = MMFTokenAmount | VVSTokenAmount; + +export type Pairish = MMFPair | VVSPair; + +export type Percentish = MMFPercent | VVSPercent; + +export type UniswapishCurrency = MMFCurrency | VVSCurrency; + +export type UniswapishTrade = + | Trade + | TradePangolin + | UniswapV3Trade + | TradeQuickswap + | TradeTraderjoe + | SushiswapTrade + | UniswapV3Trade + | TradeUniswap + | TradeDefikingdoms + | DefiraTrade + | PancakeSwapTrade + | MMFTrade + | VVSTrade; + +export type UniswapishTradeOptions = + | MMFTradeOptions + | MMFTradeOptionsDeadline + | VVSTradeOptions + | VVSTradeOptionsDeadline; + +export type UniswapishSwapParameters = MMFSwapParameters | VVSSwapParameters; + +export type UniswapishAmount = + | CurrencyAmount + | CurrencyAmountPangolin + | CurrencyAmountQuickswap + | UniswapCoreCurrencyAmount + | CurrencyAmountTraderjoe + | SushiCurrencyAmount + | CurrencyAmountDefikingdoms + | PancakeSwapCurrencyAmount + | CurrencyAmountMMF + | CurrencyAmountVVS; + +export type Fractionish = + | UniswapFraction + | PangolinFraction + | QuickswapFraction + | TraderjoeFraction + | SushiFraction + | DefikingdomsFraction + | PancakeSwapFraction + | FractionMMF + | FractionVVS; + +export interface ExpectedTrade { + trade: UniswapishTrade; + expectedAmount: UniswapishAmount; +} + +export interface PositionInfo { + token0: string | undefined; + token1: string | undefined; + fee: string | undefined; + lowerPrice: string; + upperPrice: string; + amount0: string; + amount1: string; + unclaimedToken0: string; + unclaimedToken1: string; +} + +export interface Uniswapish { + /** + * Router address. + */ + router: string; + + /** + * Router smart contract ABI. + */ + routerAbi: ContractInterface; + + /** + * Interface for decoding transaction logs + */ + abiDecoder?: any; + + /** + * Default gas estiamte for swap transactions. + */ + gasLimitEstimate: number; + + /** + * Default time-to-live for swap transactions, in seconds. + */ + ttl: number; + + init(): Promise; + + ready(): boolean; + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + getTokenByAddress(address: string): Tokenish; + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + estimateSellTrade( + baseToken: Tokenish, + quoteToken: Tokenish, + amount: BigNumber, + allowedSlippage?: string + ): Promise; + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + estimateBuyTrade( + quoteToken: Tokenish, + baseToken: Tokenish, + amount: BigNumber, + allowedSlippage?: string + ): Promise; + + /** + * Given a wallet and a Uniswap-ish trade, try to execute it on blockchain. + * + * @param wallet Wallet + * @param trade Expected trade + * @param gasPrice Base gas price, for pre-EIP1559 transactions + * @param uniswapRouter Router smart contract address + * @param ttl How long the swap is valid before expiry, in seconds + * @param abi Router contract ABI + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + executeTrade( + wallet: Wallet, + trade: UniswapishTrade, + gasPrice: number, + uniswapRouter: string, + ttl: number, + abi: ContractInterface, + gasLimit: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + allowedSlippage?: string + ): Promise; +} + +export interface RefAMMish { + /** + * Router address. + */ + router: string; + + /** + * Default gas estiamte for swap transactions. + */ + gasLimitEstimate: number; + + /** + * Default time-to-live for swap transactions, in seconds. + */ + ttl: number; + + init(): Promise; + + ready(): boolean; + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + getTokenByAddress(address: string): TokenMetadata; + + /** + * Calculated expected execution price and expected amount in after a swap/trade + * @param trades The trade path object + */ + parseTrade( + trades: EstimateSwapView[], + side: string + ): { + estimatedPrice: string; + expectedAmount: string; + }; + + /** + * Given the amount of `baseToken` to put into a transaction, calculate the + * amount of `quoteToken` that can be expected from the transaction. + * + * This is typically used for calculating token sell prices. + * + * @param baseToken Token input for the transaction + * @param quoteToken Output from the transaction + * @param amount Amount of `baseToken` to put into the transaction + */ + estimateSellTrade( + baseToken: TokenMetadata, + quoteToken: TokenMetadata, + amount: string, + allowedSlippage?: string + ): Promise<{ trade: EstimateSwapView[]; expectedAmount: string }>; + + /** + * Given the amount of `baseToken` desired to acquire from a transaction, + * calculate the amount of `quoteToken` needed for the transaction. + * + * This is typically used for calculating token buy prices. + * + * @param quoteToken Token input for the transaction + * @param baseToken Token output from the transaction + * @param amount Amount of `baseToken` desired from the transaction + */ + estimateBuyTrade( + quoteToken: TokenMetadata, + baseToken: TokenMetadata, + amount: string, + allowedSlippage?: string + ): Promise<{ trade: EstimateSwapView[]; expectedAmount: string }>; + + /** + * Given an Account and a Ref trade, try to execute it on blockchain. + * + * @param account Account + * @param trade Expected trade + * @param amountIn Amount to swap in + * @param tokenIn Token to be sent + * @param tokenOut Token to be received + * @param allowedSlippage Maximum allowable slippage + */ + executeTrade( + account: Account, + trade: EstimateSwapView[], + amountIn: string, + tokenIn: TokenMetadata, + tokenOut: TokenMetadata, + allowedSlippage?: string + ): Promise; +} + +export interface UniswapLPish { + /** + * Router address. + */ + router: string; + + /** + * Router smart contract ABI. + */ + routerAbi: ContractInterface; + + /** + * NTF manager address. + */ + nftManager: string; + + /** + * NTF manager smart contract ABI. + */ + nftAbi: ContractInterface; + + /** + * Pool smart contract ABI. + */ + poolAbi: ContractInterface; + + /** + * Interface for decoding transaction logs + */ + abiDecoder: any; + + /** + * Default gas limit used to estimate gasCost for swap transactions. + */ + gasLimitEstimate: number; + + /** + * Default time-to-live for swap transactions, in seconds. + */ + ttl: number; + + init(): Promise; + + ready(): boolean; + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + getTokenByAddress(address: string): Tokenish; + + /** + * Given a wallet and tokenId, fetch info about position. + * + * @param tokenId: id of exiting position to fetch liquidity data + */ + getPosition(tokenId: number): Promise; + + /** + * Given a wallet, add/increase liquidity for a position. + * + * @param wallet Wallet for the transaction + * @param token0 Token 1 for position + * @param token1 Token 0 for position + * @param amount0 Amount of `token0` to put into the position + * @param amount1 Amount of `token1` to put into the position + * @param fee Fee tier of position, + * @param lowerPrice lower price bound of the position + * @param upperPrice upper price bound for the position + * @param tokenId id of exiting position to increase liquidity + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + addPosition( + wallet: Wallet, + token0: UniswapCoreToken, + token1: UniswapCoreToken, + amount0: string, + amount1: string, + fee: number, + lowerPrice: number, + upperPrice: number, + tokenId: number, + gasLimit: number, + gasPrice: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise; + + /** + * Given a wallet, reduce/remove liquidity for a position. + * + * @param wallet Wallet for the transaction + * @param tokenId id of exiting position to decrease liquidity + * @param decreasePercent: percentage of liquidity to remove + * @param getFee used to estimate the gas cost of closing position + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + reducePosition( + wallet: Wallet, + tokenId: number, + decreasePercent: number, + gasLimit: number, + gasPrice: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise; + + /** + * Given a wallet and tokenId, collect earned fees on position. + * + * @param wallet Wallet for the transaction + * @param tokenId id of exiting position to collet earned fees + * @param gasLimit Gas limit + * @param nonce (Optional) EVM transaction nonce + * @param maxFeePerGas (Optional) Maximum total fee per gas you want to pay + * @param maxPriorityFeePerGas (Optional) Maximum tip per gas you want to pay + */ + collectFees( + wallet: Wallet, + tokenId: number, + gasLimit: number, + gasPrice: number, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber + ): Promise; + + /** + * Given a fee tier, tokens and time parameters, fetch historical pool prices. + * + * @param token0 Token in pool + * @param token1 Token in pool + * @param fee fee tier + * @param period total period of time to fetch pool prices in seconds + * @param interval interval within period to fetch pool prices + */ + poolPrice( + token0: UniswapCoreToken, + token1: UniswapCoreToken, + fee: number, + period: number, + interval: number + ): Promise; +} + +export interface Perpish { + gasLimit: number; + + init(): Promise; + + ready(): boolean; + + /** + * Given a token's address, return the connector's native representation of + * the token. + * + * @param address Token address + */ + getTokenByAddress(address: string): Tokenish; + + /** + * Function for retrieving token list. + * @returns a list of available marker pairs. + */ + availablePairs(): string[]; + + /** + * Give a market, queries for market, index and indexTwap prices. + * @param tickerSymbol Market pair + */ + prices(tickerSymbol: string): Promise<{ + markPrice: Big; + indexPrice: Big; + indexTwapPrice: Big; + }>; + + /** + * Used to know if a market is active/tradable. + * @param tickerSymbol Market pair + * @returns true | false + */ + isMarketActive(tickerSymbol: string): Promise; + + /** + * Gets available Positions/Position. + * @param tickerSymbol An optional parameter to get specific position. + * @returns Return all Positions or specific position. + */ + getPositions(tickerSymbol: string): Promise; + + /** + * Attempts to return balance of a connected acct + */ + getAccountValue(): Promise; + + /** + * Given the necessary parameters, open a position. + * @param isLong Will create a long position if true, else a short pos will be created. + * @param tickerSymbol the market to create position on. + * @param minBaseAmount the min amount for the position to be opened. + * @returns An ethers transaction object. + */ + openPosition( + isLong: boolean, + tickerSymbol: string, + minBaseAmount: string, + allowedSlippage?: string + ): Promise; + + /** + * Closes an open position on the specified market. + * @param tickerSymbol The market on which we want to close position. + * @returns An ethers transaction object. + */ + closePosition( + tickerSymbol: string, + allowedSlippage?: string + ): Promise; +} + +export interface BasicChainMethods { + getSpender(reqSpender: string): string; + gasPrice: number; + nativeTokenSymbol: string; + chain: string; +} + +export interface Ethereumish extends BasicChainMethods, EthereumBase { + cancelTx(wallet: Wallet, nonce: number): Promise; + getContract( + tokenAddress: string, + signerOrProvider?: Wallet | Provider + ): Contract; +} + +export interface Nearish extends BasicChainMethods, NearBase { + cancelTx(account: Account, nonce: number): Promise; + getContract(tokenAddress: string, account: Account): NearContract; +} +export interface Cosmosish extends CosmosBase { + gasPrice: number; + nativeTokenSymbol: string; + chain: string; +} + +export interface NetworkSelectionRequest { + chain: string; //the target chain (e.g. ethereum, avalanche, or harmony) + network: string; // the target network of the chain (e.g. mainnet) + connector?: string; //the target connector (e.g. uniswap or pangolin) +} + +export class ResponseWrapper { + get status(): number { + return this._status || -1; + } + set status(value: number) { + this._status = value; + } + private _status: number | undefined; + + title?: string; + message?: string; + body?: T; +} + +export interface CustomTransactionReceipt + extends Omit< + ethers.providers.TransactionReceipt, + 'gasUsed' | 'cumulativeGasUsed' | 'effectiveGasPrice' + > { + gasUsed: string; + cumulativeGasUsed: string; + effectiveGasPrice: string | null; +} + +export interface CustomTransaction + extends Omit< + Transaction, + 'maxPriorityFeePerGas' | 'maxFeePerGas' | 'gasLimit' | 'value' + > { + maxPriorityFeePerGas: string | null; + maxFeePerGas: string | null; + gasLimit: string | null; + value: string; +} + +export interface CustomTransactionResponse + extends Omit< + ethers.providers.TransactionResponse, + 'gasPrice' | 'gasLimit' | 'value' + > { + gasPrice: string | null; + gasLimit: string; + value: string; +} diff --git a/src/services/config-manager-cert-passphrase.ts b/src/services/config-manager-cert-passphrase.ts new file mode 100644 index 0000000000..982fe10a50 --- /dev/null +++ b/src/services/config-manager-cert-passphrase.ts @@ -0,0 +1,27 @@ +import { logger } from './logger'; +const argvParser = require('minimist'); +const PASSPHRASE_ARGUMENT = 'passphrase'; +const PASSPHRASE_ENV = 'GATEWAY_PASSPHRASE'; + +export namespace ConfigManagerCertPassphrase { + // this adds a level of indirection so we can test the code + export const bindings = { + _exit: process.exit, + }; + + export const readPassphrase = (): string | undefined => { + if (argvParser(process.argv)[PASSPHRASE_ARGUMENT]) { + return argvParser(process.argv)[PASSPHRASE_ARGUMENT]; + } else if (process.env[PASSPHRASE_ENV]) { + return process.env[PASSPHRASE_ENV]; + } + + // the compiler does not know that bindings._exit() will end the function + // so we need a return to satisfy the compiler checks + logger.error( + `The passphrase has to be provided by argument (--${PASSPHRASE_ARGUMENT}=XXX) or in an env variable (${PASSPHRASE_ENV}=XXX)` + ); + bindings._exit(); + return; + }; +} diff --git a/src/services/config-manager-types.ts b/src/services/config-manager-types.ts new file mode 100644 index 0000000000..7b165e6c25 --- /dev/null +++ b/src/services/config-manager-types.ts @@ -0,0 +1,4 @@ +export interface AvailableNetworks { + chain: string; + networks: Array; +} diff --git a/src/services/config-manager-v2.ts b/src/services/config-manager-v2.ts new file mode 100644 index 0000000000..ba82eae0f8 --- /dev/null +++ b/src/services/config-manager-v2.ts @@ -0,0 +1,452 @@ +import Ajv from 'ajv'; +import { ValidateFunction, DefinedError } from 'ajv'; +import fs from 'fs'; +import path from 'path'; +import yaml from 'js-yaml'; +import * as migrations from './config-migration/migrations'; +import { rootPath } from '../paths'; + +type Configuration = { [key: string]: any }; +type ConfigurationDefaults = { [namespaceId: string]: Configuration }; +export type Migration = ( + configRootFullPath: string, + configRootTemplateFullPath: string +) => void; +type MigrationFunctions = { + [key: string]: Migration; +}; +interface _ConfigurationNamespaceDefinition { + configurationPath: string; + schemaPath: string; +} +type ConfigurationNamespaceDefinition = _ConfigurationNamespaceDefinition & { + [key: string]: string; +}; +type ConfigurationNamespaceDefinitions = { + [namespaceId: string]: ConfigurationNamespaceDefinition; +}; +interface ConfigurationRoot { + version: number; + configurations: ConfigurationNamespaceDefinitions; +} +const NamespaceTag: string = '$namespace '; +export const ConfigRootSchemaPath: string = path.join( + __dirname, + 'schema/configuration-root-schema.json' +); +const ConfigTemplatesDir: string = path.join(__dirname, '../templates/'); +const ConfigDir: string = path.join(rootPath(), 'conf/'); + +interface UnpackedConfigNamespace { + namespace: ConfigurationNamespace; + configPath: string; +} + +export function deepCopy(srcObject: any, dstObject: any): any { + for (const [key, value] of Object.entries(srcObject)) { + if (srcObject[key] instanceof Array) { + if (!dstObject[key]) dstObject[key] = []; + deepCopy(srcObject[key], dstObject[key]); + } else if (srcObject[key] instanceof Object) { + if (!dstObject[key]) dstObject[key] = {}; + deepCopy(srcObject[key], dstObject[key]); + } else if ( + typeof srcObject[key] === typeof dstObject[key] || + !dstObject[key] + ) { + dstObject[key] = value; + } + } +} + +export function initiateWithTemplate(templateFile: string, configFile: string) { + fs.copyFileSync(templateFile, configFile); +} + +const ajv: Ajv = new Ajv(); + +export const percentRegexp = new RegExp(/^(\d+)\/(\d+)$/); + +export class ConfigurationNamespace { + /** + * This class encapsulates a namespace under the configuration tree. + * A namespace represents the top-level component of a configuration path. + * e.g. if the config path is "ssl.certificatePath", then "ssl" is the + * namespace. + * + * Each namespace contains a JSON schema and a YAML configuration file. + * + * The JSON schema specifies the properties and data types allowed within the + * namespace. e.g. you may specify that the "ssl" namespace has a few + * mandatory properties dealing with certificates and private keys. This means + * any missing properties or any properties outsides of the JSON schema would + * cause a failure to initialize the namespace, and also cannot be set into + * the namespace. + * + * The YAML configuration file is where the actual configuration tree goes + * to. It is automatically validated against the JSON schema at namespace + * initiation. It is automatically saved to and validated against JSON schema + * again at every set() call. + * + * Note that configuration paths may have multiple levels. What it implies + * is those configurations are stored in nested dictionaries - aka. a tree. + * e.g. if the config path is "ethereum.networks.kovan.networkID", then, + * what it means you're accessing ["networks"]["kovan"]["networkID"] under + * the "ethereum" namespace. + */ + readonly #namespaceId: string; + readonly #schemaPath: string; + readonly #configurationPath: string; + readonly #templatePath: string; + readonly #validator: ValidateFunction; + #configuration: Configuration; + + constructor( + id: string, + schemaPath: string, + configurationPath: string, + templatePath: string + ) { + this.#namespaceId = id; + this.#schemaPath = schemaPath; + this.#configurationPath = configurationPath; + this.#templatePath = templatePath; + this.#configuration = {}; + if (!fs.existsSync(schemaPath)) { + throw new Error( + `The JSON schema for namespace ${id} (${schemaPath}) does not exist.` + ); + } + + this.#validator = ajv.compile( + JSON.parse(fs.readFileSync(schemaPath).toString()) + ); + + if (!fs.existsSync(configurationPath)) { + // copy from template + initiateWithTemplate(this.templatePath, this.configurationPath); + } + this.loadConfig(); + } + + get id(): string { + return this.#namespaceId; + } + + get schemaPath(): string { + return this.#schemaPath; + } + + get configurationPath(): string { + return this.#configurationPath; + } + + get configuration(): Configuration { + return this.#configuration; + } + + get templatePath(): string { + return this.#templatePath; + } + + loadConfig() { + const configCandidate: Configuration = yaml.load( + fs.readFileSync(this.#configurationPath, 'utf8') + ) as Configuration; + if (!this.#validator(configCandidate)) { + // merge with template file and try validating again + const configTemplateCandidate: Configuration = yaml.load( + fs.readFileSync(this.#templatePath, 'utf8') + ) as Configuration; + deepCopy(configCandidate, configTemplateCandidate); + if (!this.#validator(configTemplateCandidate)) { + for (const err of this.#validator.errors as DefinedError[]) { + if (err.keyword === 'additionalProperties') { + throw new Error( + `${this.id} config file seems to be outdated/broken due to additional property "${err.params.additionalProperty}". Kindly fix manually.` + ); + } else { + throw new Error( + `${this.id} config file seems to be outdated/broken due to "${err.keyword}" in "${err.instancePath}" - ${err.message}. Kindly fix manually.` + ); + } + } + } + this.#configuration = configTemplateCandidate; + this.saveConfig(); + return; + } + this.#configuration = configCandidate; + } + + saveConfig() { + fs.writeFileSync(this.#configurationPath, yaml.dump(this.#configuration)); + } + + get(configPath: string): any { + const pathComponents: Array = configPath.split('.'); + let cursor: Configuration | any = this.#configuration; + + for (const component of pathComponents) { + cursor = cursor[component]; + if (cursor === undefined) { + return cursor; + } + } + + return cursor; + } + + set(configPath: string, value: any): void { + const pathComponents: Array = configPath.split('.'); + const configClone: Configuration = JSON.parse( + JSON.stringify(this.#configuration) + ); + let cursor: Configuration | any = configClone; + let parent: Configuration = configClone; + + for (const component of pathComponents.slice(0, -1)) { + parent = cursor; + cursor = cursor[component]; + if (cursor === undefined) { + parent[component] = {}; + cursor = parent[component]; + } + } + + const lastComponent: string = pathComponents[pathComponents.length - 1]; + cursor[lastComponent] = value; + + if (!this.#validator(configClone)) { + throw new Error( + `Cannot set ${this.id}.${configPath} to ${value}: ` + + 'JSON schema violation.' + ); + } + + this.#configuration = configClone; + this.saveConfig(); + } +} + +export class ConfigManagerV2 { + /** + * This class encapsulates the configuration tree and all the contained + * namespaces and files for Hummingbot Gateway. It also contains a defaults + * mechanism for modules to set default configurations under their namespaces. + * + * The configuration manager starts by loading the root configuration file, + * which defines all the configuration namespaces. The root configuration file + * has a fixed JSON schema, that only allows namespaces to be defined there. + * + * After the namespaces are loaded into the configuration manager during + * initiation, the get() and set() functions will map configuration keys and + * values to the appropriate namespaces. + * + * e.g. get('ethereum.networks.kovan.networkID') will be mapped to + * ethereumNamespace.get('networks.kovan.networkID') + * e.g. set('ethereum.networks.kovan.networkID', 42) will be mapped to + * ethereumNamespace.set('networks.kovan.networkID', 42) + * + * File paths in the root configuration file may be defined as absolute paths + * or relative paths. Any relative paths would be rebased to the root + * configuration file's parent directory. + * + * The static function `setDefaults()` is expected to be called by gateway + * modules, to set default configurations under their own namespaces. Default + * configurations are used in the `get()` function if the corresponding config + * key is not found in its configuration namespace. + */ + readonly #namespaces: { [key: string]: ConfigurationNamespace }; + + private static _instance: ConfigManagerV2; + + public static getInstance(): ConfigManagerV2 { + if (!ConfigManagerV2._instance) { + const rootPath = path.join(ConfigDir, 'root.yml'); + if (!fs.existsSync(rootPath)) { + // copy from template + fs.copyFileSync(path.join(ConfigTemplatesDir, 'root.yml'), rootPath); + } + ConfigManagerV2._instance = new ConfigManagerV2(rootPath); + } + return ConfigManagerV2._instance; + } + + static defaults: ConfigurationDefaults = {}; + + constructor(configRootPath: string) { + this.#namespaces = {}; + this.loadConfigRoot(configRootPath); + } + + static setDefaults(namespaceId: string, defaultTree: Configuration) { + ConfigManagerV2.defaults[namespaceId] = defaultTree; + } + + static getFromDefaults(namespaceId: string, configPath: string): any { + if (!(namespaceId in ConfigManagerV2.defaults)) { + return undefined; + } + + const pathComponents: Array = configPath.split('.'); + const defaultConfig: Configuration = ConfigManagerV2.defaults[namespaceId]; + let cursor: Configuration | any = defaultConfig; + for (const pathComponent of pathComponents) { + cursor = cursor[pathComponent]; + if (cursor === undefined) { + return cursor; + } + } + + return cursor; + } + + get namespaces(): { [key: string]: ConfigurationNamespace } { + return this.#namespaces; + } + + get allConfigurations(): { [key: string]: Configuration } { + const result: { [key: string]: Configuration } = {}; + for (const [key, value] of Object.entries(this.#namespaces)) { + result[key] = value.configuration; + } + return result; + } + + getNamespace(id: string): ConfigurationNamespace | undefined { + return this.#namespaces[id]; + } + + addNamespace( + id: string, + schemaPath: string, + configurationPath: string, + templatePath: string + ): void { + this.#namespaces[id] = new ConfigurationNamespace( + id, + schemaPath, + configurationPath, + templatePath + ); + } + + unpackFullConfigPath(fullConfigPath: string): UnpackedConfigNamespace { + const pathComponents: Array = fullConfigPath.split('.'); + if (pathComponents.length < 2) { + throw new Error('Configuration paths must have at least two components.'); + } + + const namespaceComponent: string = pathComponents[0]; + const namespace: ConfigurationNamespace | undefined = + this.#namespaces[namespaceComponent]; + if (namespace === undefined) { + throw new Error( + `The configuration namespace ${namespaceComponent} does not exist.` + ); + } + + const configPath: string = pathComponents.slice(1).join('.'); + return { + namespace, + configPath, + }; + } + + get(fullConfigPath: string): any { + const { namespace, configPath } = this.unpackFullConfigPath(fullConfigPath); + const configValue: any = namespace.get(configPath); + if (configValue === undefined) { + return ConfigManagerV2.getFromDefaults(namespace.id, configPath); + } + return configValue; + } + + set(fullConfigPath: string, value: any) { + const { namespace, configPath } = this.unpackFullConfigPath(fullConfigPath); + namespace.set(configPath, value); + } + + loadConfigRoot(configRootPath: string) { + // Load the config root file. + const configRootFullPath: string = fs.realpathSync(configRootPath); + const configRootTemplateFullPath: string = path.join( + ConfigTemplatesDir, + 'root.yml' + ); + const configRootDir: string = path.dirname(configRootFullPath); + const configRoot: ConfigurationRoot = yaml.load( + fs.readFileSync(configRootFullPath, 'utf8') + ) as ConfigurationRoot; + const configRootTemplate: ConfigurationRoot = yaml.load( + fs.readFileSync(configRootTemplateFullPath, 'utf8') + ) as ConfigurationRoot; + + // version control to only handle upgrades + if (configRootTemplate.version > configRoot.version) { + // run migration in order if available + for ( + let num = configRoot.version + 1; + num <= configRootTemplate.version; + num++ + ) { + if ((migrations as MigrationFunctions)[`updateToVersion${num}`]) { + (migrations as MigrationFunctions)[`updateToVersion${num}`]( + configRootFullPath, + configRootTemplateFullPath + ); + } + } + } + + // Validate the config root file. + const validator: ValidateFunction = ajv.compile( + JSON.parse(fs.readFileSync(ConfigRootSchemaPath).toString()) + ); + if (!validator(configRoot)) { + throw new Error('Configuration root file is invalid.'); + } + + // Extract the namespace ids. + const namespaceMap: ConfigurationNamespaceDefinitions = {}; + for (const namespaceKey of Object.keys(configRoot.configurations)) { + namespaceMap[namespaceKey.slice(NamespaceTag.length)] = + configRoot.configurations[namespaceKey]; + } + + // Rebase the file paths in config & template roots if they're relative paths. + for (const namespaceDefinition of Object.values(namespaceMap)) { + for (const [key, filePath] of Object.entries(namespaceDefinition)) { + if (!path.isAbsolute(filePath)) { + if (key === 'configurationPath') { + namespaceDefinition['templatePath'] = path.join( + ConfigTemplatesDir, + filePath + ); + namespaceDefinition[key] = path.join(configRootDir, filePath); + } else if (key === 'schemaPath') { + namespaceDefinition[key] = path.join( + path.dirname(ConfigRootSchemaPath), + filePath + ); + } + } else { + throw new Error(`Absolute path not allowed for ${key}.`); + } + } + } + + // Add the namespaces according to config root. + for (const [namespaceId, namespaceDefinition] of Object.entries( + namespaceMap + )) { + this.addNamespace( + namespaceId, + namespaceDefinition.schemaPath, + namespaceDefinition.configurationPath, + namespaceDefinition.templatePath + ); + } + } +} diff --git a/src/services/config-migration/migrations.ts b/src/services/config-migration/migrations.ts new file mode 100644 index 0000000000..da008027c5 --- /dev/null +++ b/src/services/config-migration/migrations.ts @@ -0,0 +1,17 @@ +import * as utils from '../config-manager-v2'; + +/* + * This file defines migration functions for each version. + * Note: type utils.Migration = (configRootFullPath: string, + * configRootTemplateFullPath: string) => void; + */ + +export const updateToVersion1: utils.Migration = ( + configRootFullPath, + configRootTemplateFullPath +) => { + // just dummy calls + configRootFullPath; + configRootTemplateFullPath; + return; +}; diff --git a/src/services/config/config.requests.ts b/src/services/config/config.requests.ts new file mode 100644 index 0000000000..35b4708e81 --- /dev/null +++ b/src/services/config/config.requests.ts @@ -0,0 +1,4 @@ +export interface ConfigUpdateRequest { + configPath: string; + configValue: any; +} diff --git a/src/services/config/config.routes.ts b/src/services/config/config.routes.ts new file mode 100644 index 0000000000..38eba2a0da --- /dev/null +++ b/src/services/config/config.routes.ts @@ -0,0 +1,48 @@ +/* eslint-disable no-inner-declarations */ +/* eslint-disable @typescript-eslint/ban-types */ +import { Router, Request, Response } from 'express'; +import { asyncHandler } from '../error-handler'; +import { ConfigUpdateRequest } from './config.requests'; +import { + validateConfigUpdateRequest, + updateAllowedSlippageToFraction, +} from './config.validators'; +import { ConfigManagerV2 } from '../config-manager-v2'; + +export namespace ConfigRoutes { + export const router = Router(); + + router.post( + '/update', + asyncHandler( + async ( + req: Request, + res: Response + ) => { + validateConfigUpdateRequest(req.body); + const config = ConfigManagerV2.getInstance().get(req.body.configPath); + if (typeof req.body.configValue == 'string') + switch (typeof config) { + case 'number': + req.body.configValue = Number(req.body.configValue); + break; + case 'boolean': + req.body.configValue = + req.body.configValue.toLowerCase() === 'true'; + break; + } + + if (req.body.configPath.endsWith('allowedSlippage')) { + updateAllowedSlippageToFraction(req.body); + } + + ConfigManagerV2.getInstance().set( + req.body.configPath, + req.body.configValue + ); + + res.status(200).json({ message: 'The config has been updated' }); + } + ) + ); +} diff --git a/src/services/config/config.validators.ts b/src/services/config/config.validators.ts new file mode 100644 index 0000000000..32e8b467c5 --- /dev/null +++ b/src/services/config/config.validators.ts @@ -0,0 +1,83 @@ +import { + RequestValidator, + Validator, + isFloatString, + isFractionString, + mkRequestValidator, +} from '../validators'; +import { fromFractionString, toFractionString } from '../base'; +import { ConfigUpdateRequest } from './config.requests'; + +export const invalidAllowedSlippage: string = + 'allowedSlippage should be a number between 0.0 and 1.0 or a string of a fraction.'; + +// only permit percentages 0.0 (inclusive) to less one +export const isAllowedPercentage = (val: string | number): boolean => { + if (typeof val === 'string') { + if (isFloatString(val)) { + const num: number = parseFloat(val); + return num >= 0.0 && num < 1.0; + } else { + const num: number | null = fromFractionString(val); // this checks if it is a fraction string + if (num !== null) { + return num >= 0.0 && num < 1.0; + } else { + return false; + } + } + } else { + return val >= 0.0 && val < 1.0; + } +}; + +// This is a specialized version of mkValidator for /config/update. +// All requests should be of the form {configPath, configValue}. This allows you +// to create validators that match on configPath, then test the value of configValue. +// (for example: {configPath: 'uniswap.versions.v2.allowedSlippage', configValue: 0.1}. +export const mkConfigValidator = ( + configPathEnding: string, + errorMsg: string, + condition: (x: any) => boolean +): Validator => { + return (req: any) => { + const errors: Array = []; + const configPath: string = req.configPath; + if (configPath.endsWith(configPathEnding)) { + const configValue = req.configValue; + if (!condition(configValue)) { + errors.push(errorMsg); + } + } + + return errors; + }; +}; + +export const validateAllowedSlippage: Validator = mkConfigValidator( + 'allowedSlippage', + invalidAllowedSlippage, + (val) => + (typeof val === 'number' || + (typeof val === 'string' && + (isFractionString(val) || isFloatString(val)))) && + isAllowedPercentage(val) +); + +export const validateConfigUpdateRequest: RequestValidator = mkRequestValidator( + [validateAllowedSlippage] +); + +// this mutates the input value in place +export const updateAllowedSlippageToFraction = ( + body: ConfigUpdateRequest +): void => { + if (body.configPath.endsWith('allowedSlippage')) { + if ( + typeof body.configValue === 'number' || + (typeof body.configValue == 'string' && + !isFractionString(body.configValue)) + ) { + body.configValue = toFractionString(body.configValue); + } + } +}; diff --git a/src/services/connection-manager.ts b/src/services/connection-manager.ts new file mode 100644 index 0000000000..e0fe97c61d --- /dev/null +++ b/src/services/connection-manager.ts @@ -0,0 +1,126 @@ +import { Avalanche } from '../chains/avalanche/avalanche'; +import { Cronos } from '../chains/cronos/cronos'; +import { Ethereum } from '../chains/ethereum/ethereum'; +import { BinanceSmartChain } from '../chains/binance-smart-chain/binance-smart-chain'; +import { Harmony } from '../chains/harmony/harmony'; +import { Polygon } from '../chains/polygon/polygon'; +import { MadMeerkat } from '../connectors/mad_meerkat/mad_meerkat'; +import { Openocean } from '../connectors/openocean/openocean'; +import { Pangolin } from '../connectors/pangolin/pangolin'; +import { Perp } from '../connectors/perp/perp'; +import { Quickswap } from '../connectors/quickswap/quickswap'; +import { PancakeSwap } from '../connectors/pancakeswap/pancakeswap'; +import { Uniswap } from '../connectors/uniswap/uniswap'; +import { UniswapLP } from '../connectors/uniswap/uniswap.lp'; +import { VVSConnector } from '../connectors/vvs/vvs'; +import { + Ethereumish, + Nearish, + Perpish, + RefAMMish, + Uniswapish, + UniswapLPish, +} from './common-interfaces'; +import { Traderjoe } from '../connectors/traderjoe/traderjoe'; +import { Sushiswap } from '../connectors/sushiswap/sushiswap'; +import { Defikingdoms } from '../connectors/defikingdoms/defikingdoms'; +import { Defira } from '../connectors/defira/defira'; +import { Near } from '../chains/near/near'; +import { Ref } from '../connectors/ref/ref'; + +export type ChainUnion = Ethereumish | Nearish; + +export type Chain = T extends Ethereumish + ? Ethereumish + : T extends Nearish + ? Nearish + : never; + +export async function getChain( + chain: string, + network: string +): Promise> { + let chainInstance: ChainUnion; + + if (chain === 'ethereum') chainInstance = Ethereum.getInstance(network); + else if (chain === 'avalanche') + chainInstance = Avalanche.getInstance(network); + else if (chain === 'polygon') chainInstance = Polygon.getInstance(network); + else if (chain === 'harmony') chainInstance = Harmony.getInstance(network); + else if (chain === 'near') chainInstance = Near.getInstance(network); + else if (chain === 'binance-smart-chain') + chainInstance = BinanceSmartChain.getInstance(network); + else if (chain === 'cronos') chainInstance = Cronos.getInstance(network); + else throw new Error('unsupported chain'); + + if (!chainInstance.ready()) { + await chainInstance.init(); + } + + return chainInstance as Chain; +} + +type ConnectorUnion = Uniswapish | UniswapLPish | Perpish | RefAMMish; + +export type Connector = T extends Uniswapish + ? Uniswapish + : T extends UniswapLPish + ? UniswapLPish + : T extends Perpish + ? Perpish + : T extends RefAMMish + ? RefAMMish + : never; + +export async function getConnector( + chain: string, + network: string, + connector: string | undefined, + address?: string +): Promise> { + let connectorInstance: ConnectorUnion; + + if ( + (chain === 'ethereum' || chain === 'polygon') && + connector === 'uniswap' + ) { + connectorInstance = Uniswap.getInstance(chain, network); + } else if (chain === 'polygon' && connector === 'quickswap') { + connectorInstance = Quickswap.getInstance(chain, network); + } else if ( + (chain === 'ethereum' || chain === 'polygon') && + connector === 'uniswapLP' + ) { + connectorInstance = UniswapLP.getInstance(chain, network); + } else if (chain === 'ethereum' && connector === 'perp') { + connectorInstance = Perp.getInstance(chain, network, address); + } else if (chain === 'avalanche' && connector === 'pangolin') { + connectorInstance = Pangolin.getInstance(chain, network); + } else if (chain === 'avalanche' && connector === 'openocean') { + connectorInstance = Openocean.getInstance(chain, network); + } else if (chain === 'avalanche' && connector === 'traderjoe') { + connectorInstance = Traderjoe.getInstance(chain, network); + } else if (chain === 'harmony' && connector === 'defikingdoms') { + connectorInstance = Defikingdoms.getInstance(chain, network); + } else if (chain === 'harmony' && connector === 'defira') { + connectorInstance = Defira.getInstance(chain, network); + } else if (chain === 'cronos' && connector === 'mad_meerkat') { + connectorInstance = MadMeerkat.getInstance(chain, network); + } else if (chain === 'cronos' && connector === 'vvs') { + connectorInstance = VVSConnector.getInstance(chain, network); + } else if (chain === 'near' && connector === 'ref') { + connectorInstance = Ref.getInstance(chain, network); + } else if (chain === 'binance-smart-chain' && connector === 'pancakeswap') { + connectorInstance = PancakeSwap.getInstance(chain, network); + } else if (connector === 'sushiswap') { + connectorInstance = Sushiswap.getInstance(chain, network); + } else { + throw new Error('unsupported chain or connector'); + } + + if (!connectorInstance.ready()) { + await connectorInstance.init(); + } + + return connectorInstance as Connector; +} diff --git a/src/services/cosmos-base.ts b/src/services/cosmos-base.ts new file mode 100644 index 0000000000..fcdae3174d --- /dev/null +++ b/src/services/cosmos-base.ts @@ -0,0 +1,367 @@ +import axios from 'axios'; +import { promises as fs } from 'fs'; +import { TokenListType, TokenValue, walletPath } from './base'; +import NodeCache from 'node-cache'; +import fse from 'fs-extra'; +import { ConfigManagerCertPassphrase } from './config-manager-cert-passphrase'; +import { BigNumber } from 'ethers'; +import { AccountData, DirectSignResponse } from '@cosmjs/proto-signing'; + +import { IndexedTx, setupIbcExtension } from '@cosmjs/stargate'; + +//Cosmos +const { DirectSecp256k1Wallet } = require('@cosmjs/proto-signing'); +const { StargateClient } = require('@cosmjs/stargate'); +const { toBase64, fromBase64, fromHex } = require('@cosmjs/encoding'); +const crypto = require('crypto').webcrypto; +export interface Token { + base: string; + address: string; + name: string; + symbol: string; + decimals: number; +} + +export interface CosmosWallet { + privKey: Uint8Array; + pubkey: Uint8Array; + prefix: 'string'; + getAccounts(): [AccountData]; + signDirect(): DirectSignResponse; + fromKey(): CosmosWallet; +} + +export interface KeyAlgorithm { + name: string; + salt: Uint8Array; + iterations: number; + hash: string; +} + +export interface CipherAlgorithm { + name: string; + iv: Uint8Array; +} +export interface EncryptedPrivateKey { + keyAlgorithm: KeyAlgorithm; + cipherAlgorithm: CipherAlgorithm; + ciphertext: Uint8Array; +} + +export type NewBlockHandler = (bn: number) => void; + +export type NewDebugMsgHandler = (msg: any) => void; + +export class CosmosBase { + private _provider; + protected tokenList: Token[] = []; + private _tokenMap: Record = {}; + + private _ready: boolean = false; + private _initializing: boolean = false; + private _initPromise: Promise = Promise.resolve(); + + public chainName; + public rpcUrl; + public gasPriceConstant; + public tokenListSource: string; + public tokenListType: TokenListType; + public cache: NodeCache; + + constructor( + chainName: string, + rpcUrl: string, + tokenListSource: string, + tokenListType: TokenListType, + gasPriceConstant: number + ) { + this._provider = StargateClient.connect(rpcUrl); + this.chainName = chainName; + this.rpcUrl = rpcUrl; + this.gasPriceConstant = gasPriceConstant; + this.tokenListSource = tokenListSource; + this.tokenListType = tokenListType; + this.cache = new NodeCache({ stdTTL: 3600 }); // set default cache ttl to 1hr + } + + ready(): boolean { + return this._ready; + } + + public get provider() { + return this._provider; + } + + async init(): Promise { + if (!this.ready() && !this._initializing) { + this._initializing = true; + this._initPromise = this.loadTokens( + this.tokenListSource, + this.tokenListType + ).then(() => { + this._ready = true; + this._initializing = false; + }); + } + return this._initPromise; + } + + async loadTokens( + tokenListSource: string, + tokenListType: TokenListType + ): Promise { + this.tokenList = await this.getTokenList(tokenListSource, tokenListType); + + if (this.tokenList) { + this.tokenList.forEach( + (token: Token) => (this._tokenMap[token.symbol] = token) + ); + } + } + + // returns a Tokens for a given list source and list type + async getTokenList( + tokenListSource: string, + tokenListType: TokenListType + ): Promise { + let tokens; + if (tokenListType === 'URL') { + ({ data: tokens } = await axios.get(tokenListSource)); + } else { + ({ tokens } = JSON.parse(await fs.readFile(tokenListSource, 'utf8'))); + } + return tokens; + } + + // ethereum token lists are large. instead of reloading each time with + // getTokenList, we can read the stored tokenList value from when the + // object was initiated. + public get storedTokenList(): Token[] { + return this.tokenList; + } + + // return the Token object for a symbol + getTokenForSymbol(symbol: string): Token | null { + return this._tokenMap[symbol] ? this._tokenMap[symbol] : null; + } + + async getWalletFromPrivateKey( + privateKey: string, + prefix: string + ): Promise { + const wallet = await DirectSecp256k1Wallet.fromKey( + fromHex(privateKey), + prefix + ); + + return wallet; + } + + async getAccountsfromPrivateKey( + privateKey: string, + prefix: string + ): Promise { + const wallet = await this.getWalletFromPrivateKey(privateKey, prefix); + + const accounts = await wallet.getAccounts(); + + return accounts[0]; + } + + // returns Wallet for an address + // TODO: Abstract-away into base.ts + async getWallet(address: string, prefix: string): Promise { + const path = `${walletPath}/${this.chainName}`; + + const encryptedPrivateKey: EncryptedPrivateKey = JSON.parse( + await fse.readFile(`${path}/${address}.json`, 'utf8'), + (key, value) => { + switch (key) { + case 'ciphertext': + case 'salt': + case 'iv': + return fromBase64(value); + default: + return value; + } + } + ); + + const passphrase = ConfigManagerCertPassphrase.readPassphrase(); + if (!passphrase) { + throw new Error('missing passphrase'); + } + + return await this.decrypt(encryptedPrivateKey, passphrase, prefix); + } + + private static async getKeyMaterial(password: string) { + const enc = new TextEncoder(); + return await crypto.subtle.importKey( + 'raw', + enc.encode(password), + 'PBKDF2', + false, + ['deriveBits', 'deriveKey'] + ); + } + + private static async getKey( + keyAlgorithm: { + salt: Uint8Array; + name: string; + iterations: number; + hash: string; + }, + keyMaterial: CryptoKey + ) { + return await crypto.subtle.deriveKey( + keyAlgorithm, + keyMaterial, + { name: 'AES-GCM', length: 256 }, + true, + ['encrypt', 'decrypt'] + ); + } + + // from Solana.ts + async encrypt(privateKey: string, password: string): Promise { + const iv = crypto.getRandomValues(new Uint8Array(16)); + const salt = crypto.getRandomValues(new Uint8Array(16)); + const keyMaterial = await CosmosBase.getKeyMaterial(password); + const keyAlgorithm = { + name: 'PBKDF2', + salt: salt, + iterations: 500000, + hash: 'SHA-256', + }; + const key = await CosmosBase.getKey(keyAlgorithm, keyMaterial); + const cipherAlgorithm = { + name: 'AES-GCM', + iv: iv, + }; + const enc = new TextEncoder(); + const ciphertext: Uint8Array = (await crypto.subtle.encrypt( + cipherAlgorithm, + key, + enc.encode(privateKey) + )) as Uint8Array; + return JSON.stringify( + { + keyAlgorithm, + cipherAlgorithm, + ciphertext: new Uint8Array(ciphertext), + }, + (key, value) => { + switch (key) { + case 'ciphertext': + case 'salt': + case 'iv': + return toBase64(Uint8Array.from(Object.values(value))); + default: + return value; + } + } + ); + } + + async decrypt( + encryptedPrivateKey: EncryptedPrivateKey, + password: string, + prefix: string + ): Promise { + const keyMaterial = await CosmosBase.getKeyMaterial(password); + const key = await CosmosBase.getKey( + encryptedPrivateKey.keyAlgorithm, + keyMaterial + ); + const decrypted = await crypto.subtle.decrypt( + encryptedPrivateKey.cipherAlgorithm, + key, + encryptedPrivateKey.ciphertext + ); + const dec = new TextDecoder(); + dec.decode(decrypted); + + return await this.getWalletFromPrivateKey(dec.decode(decrypted), prefix); + } + + async getDenomMetadata(provider: any, denom: string): Promise { + return await provider.queryClient.bank.denomMetadata(denom); + } + + getTokenDecimals(token: any): number { + return token ? token.denom_units[token.denom_units.length - 1].exponent : 6; // Last denom unit has the decimal amount we need from our list + } + + async getBalances(wallet: CosmosWallet): Promise> { + const balances: Record = {}; + + const provider = await this._provider; + + const accounts = await wallet.getAccounts(); + + const { address } = accounts[0]; + + const allTokens = await provider.getAllBalances(address); + + await Promise.all( + allTokens.map(async (t: { denom: string; amount: string }) => { + let token = this.getTokenByBase(t.denom); + + if (!token && t.denom.startsWith('ibc/')) { + const ibcHash: string = t.denom.replace('ibc/', ''); + + // Get base denom by IBC hash + if (ibcHash) { + const { denomTrace } = await setupIbcExtension( + await provider.queryClient + ).ibc.transfer.denomTrace(ibcHash); + + if (denomTrace) { + const { baseDenom } = denomTrace; + + token = this.getTokenByBase(baseDenom); + } + } + } + + // Not all tokens are added in the registry so we use the denom if the token doesn't exist + balances[token ? token.symbol : t.denom] = { + value: BigNumber.from(parseInt(t.amount, 10)), + decimals: this.getTokenDecimals(token), + }; + }) + ); + + return balances; + } + + // returns a cosmos tx for a txHash + async getTransaction(id: string): Promise { + const provider = await this._provider; + const transaction = await provider.getTx(id); + + if (!transaction) { + throw new Error('Transaction not found'); + } + + return transaction; + } + + public getTokenBySymbol(tokenSymbol: string): Token | undefined { + return this.tokenList.find( + (token: Token) => token.symbol.toUpperCase() === tokenSymbol.toUpperCase() + ); + } + + public getTokenByBase(base: string): Token | undefined { + return this.tokenList.find((token: Token) => token.base === base); + } + + async getCurrentBlockNumber(): Promise { + const provider = await this._provider; + + return await provider.getHeight(); + } +} diff --git a/src/services/error-handler.ts b/src/services/error-handler.ts new file mode 100644 index 0000000000..3deb9c6e44 --- /dev/null +++ b/src/services/error-handler.ts @@ -0,0 +1,207 @@ +import { Request, RequestHandler, Response, NextFunction } from 'express'; + +// error origination from ethers library when interracting with node +export interface NodeError extends Error { + code: string | number; + reason?: string; + data?: any; +} + +// custom error for http exceptions +export class HttpException extends Error { + status: number; + message: string; + errorCode: number; + constructor(status: number, message: string, errorCode: number = -1) { + super(message); + this.status = status; + this.message = message; + this.errorCode = errorCode; + } +} + +export class InitializationError extends Error { + message: string; + errorCode: number; + constructor(message: string, errorCode: number) { + super(message); + this.message = message; + this.errorCode = errorCode; + } +} + +export class UniswapishPriceError extends Error { + message: string; + constructor(message: string) { + super(message); + this.message = message; + } +} + +export class InvalidNonceError extends Error { + message: string; + errorCode: number; + constructor(message: string, errorCode: number) { + super(message); + this.message = message; + this.errorCode = errorCode; + } +} + +// Capture errors from an async route, this must wrap any route that uses async. +// For example, `app.get('/', asyncHandler(async (req, res) -> {...}))` +export const asyncHandler = + (fn: RequestHandler) => (req: Request, res: Response, next: NextFunction) => { + return Promise.resolve(fn(req, res, next)).catch(next); + }; + +export interface TransactionError { + errorCode: number; + message: string; +} + +export const parseTransactionGasError = ( + error: any +): TransactionError | null => { + if ('code' in error && error.code === 'SERVER_ERROR') { + if ('body' in error) { + const innerError = JSON.parse(error['body']); + + if ( + 'error' in innerError && + 'code' in innerError['error'] && + innerError['error']['code'] === -32010 && + 'message' in innerError['error'] + ) { + const transactionError: TransactionError = { + errorCode: TRANSACTION_GAS_PRICE_TOO_LOW, + message: innerError['error']['message'], + }; + + return transactionError; + } + } + } + return null; +}; + +export const NETWORK_ERROR_CODE = 1001; +export const RATE_LIMIT_ERROR_CODE = 1002; +export const OUT_OF_GAS_ERROR_CODE = 1003; +export const TRANSACTION_GAS_PRICE_TOO_LOW = 1004; +export const LOAD_WALLET_ERROR_CODE = 1005; +export const TOKEN_NOT_SUPPORTED_ERROR_CODE = 1006; +export const TRADE_FAILED_ERROR_CODE = 1007; +export const SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_CODE = 1008; +export const SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_CODE = 1009; +export const SERVICE_UNITIALIZED_ERROR_CODE = 1010; +export const UNKNOWN_CHAIN_ERROR_CODE = 1011; +export const INVALID_NONCE_ERROR_CODE = 1012; +export const PRICE_FAILED_ERROR_CODE = 1013; +export const INCOMPLETE_REQUEST_PARAM_CODE = 1014; +export const ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_CODE = 1015; +export const ACCOUNT_NOT_SPECIFIED_CODE = 1016; +export const UNKNOWN_ERROR_ERROR_CODE = 1099; + +export const NETWORK_ERROR_MESSAGE = + 'Network error. Please check your node URL, API key, and Internet connection.'; +export const RATE_LIMIT_ERROR_MESSAGE = + 'Blockchain node API rate limit exceeded.'; +export const OUT_OF_GAS_ERROR_MESSAGE = 'Transaction out of gas.'; +export const LOAD_WALLET_ERROR_MESSAGE = 'Failed to load wallet: '; +export const TOKEN_NOT_SUPPORTED_ERROR_MESSAGE = 'Token not supported: '; +export const TRADE_FAILED_ERROR_MESSAGE = 'Trade query failed: '; +export const INCOMPLETE_REQUEST_PARAM = 'Incomplete request parameters.'; +export const INVALID_NONCE_ERROR_MESSAGE = 'Invalid Nonce provided: '; +export const SWAP_PRICE_EXCEEDS_LIMIT_PRICE_ERROR_MESSAGE = ( + price: any, + limitPrice: any +) => `Swap price ${price} exceeds limitPrice ${limitPrice}`; + +export const SWAP_PRICE_LOWER_THAN_LIMIT_PRICE_ERROR_MESSAGE = ( + price: any, + limitPrice: any +) => `Swap price ${price} lower than limitPrice ${limitPrice}`; + +export const SERVICE_UNITIALIZED_ERROR_MESSAGE = (service: any) => + `${service} was called before being initialized.`; + +export const UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE = (chainName: any) => + `Unrecognized chain name ${chainName}.`; + +export const ACCOUNT_NOT_SPECIFIED_ERROR_MESSAGE = () => + `AccountID or address not specified.`; + +export const ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_MESSAGE = ( + privKey: string +) => + `Unable to retrieve wallet address for provided private key: ${privKey.substring( + 0, + 5 + )}`; + +export const UNKNOWN_ERROR_MESSAGE = 'Unknown error.'; + +export const PRICE_FAILED_ERROR_MESSAGE = 'Price query failed: '; + +export interface ErrorResponse { + stack?: any; + message: string; + httpErrorCode: number; + errorCode: number; +} + +export const gatewayErrorMiddleware = ( + err: Error | NodeError | HttpException | InitializationError +): ErrorResponse => { + const response: ErrorResponse = { + message: err.message || UNKNOWN_ERROR_MESSAGE, + httpErrorCode: 503, + errorCode: UNKNOWN_ERROR_ERROR_CODE, + stack: err.stack, + }; + // the default http error code is 503 for an unknown error + if (err instanceof HttpException) { + response.httpErrorCode = err.status; + response.errorCode = err.errorCode; + } else if (err instanceof InitializationError) { + response.errorCode = err.errorCode; + } else { + response.errorCode = UNKNOWN_ERROR_ERROR_CODE; + response.message = UNKNOWN_ERROR_MESSAGE; + + if ('code' in err) { + switch (typeof err.code) { + case 'string': + // error is from ethers library + if (['NETWORK_ERROR', 'TIMEOUT'].includes(err.code)) { + response.errorCode = NETWORK_ERROR_CODE; + response.message = NETWORK_ERROR_MESSAGE; + } else if (err.code === 'SERVER_ERROR') { + const transactionError = parseTransactionGasError(err); + if (transactionError) { + response.errorCode = transactionError.errorCode; + response.message = transactionError.message; + } else { + response.errorCode = NETWORK_ERROR_CODE; + response.message = NETWORK_ERROR_MESSAGE; + } + } + break; + + case 'number': + // errors from provider, this code comes from infura + if (err.code === -32005) { + // we only handle rate-limit errors + response.errorCode = RATE_LIMIT_ERROR_CODE; + response.message = RATE_LIMIT_ERROR_MESSAGE; + } else if (err.code === -32010) { + response.errorCode = TRANSACTION_GAS_PRICE_TOO_LOW; + response.message = err.message; + } + break; + } + } + } + return response; +}; diff --git a/src/services/ethereum-base.ts b/src/services/ethereum-base.ts new file mode 100644 index 0000000000..4ccc3df7a8 --- /dev/null +++ b/src/services/ethereum-base.ts @@ -0,0 +1,393 @@ +import { + BigNumber, + Contract, + providers, + Transaction, + utils, + Wallet, +} from 'ethers'; +import axios from 'axios'; +import { promises as fs } from 'fs'; +import path from 'path'; +import { rootPath } from '../paths'; +import { TokenListType, TokenValue, walletPath } from './base'; +import { EVMNonceManager } from './evm.nonce'; +import NodeCache from 'node-cache'; +import { EvmTxStorage } from './evm.tx-storage'; +import fse from 'fs-extra'; +import { ConfigManagerCertPassphrase } from './config-manager-cert-passphrase'; +import { logger } from './logger'; +import { ReferenceCountingCloseable } from './refcounting-closeable'; + +// information about an Ethereum token +export interface TokenInfo { + chainId: number; + address: string; + name: string; + symbol: string; + decimals: number; +} + +export type NewBlockHandler = (bn: number) => void; + +export type NewDebugMsgHandler = (msg: any) => void; + +export class EthereumBase { + private _provider; + protected tokenList: TokenInfo[] = []; + private _tokenMap: Record = {}; + // there are async values set in the constructor + private _ready: boolean = false; + private _initializing: boolean = false; + public chainName; + public chainId; + public rpcUrl; + public gasPriceConstant; + private _gasLimitTransaction; + public tokenListSource: string; + public tokenListType: TokenListType; + public cache: NodeCache; + private readonly _refCountingHandle: string; + private readonly _nonceManager: EVMNonceManager; + private readonly _txStorage: EvmTxStorage; + + constructor( + chainName: string, + chainId: number, + rpcUrl: string, + tokenListSource: string, + tokenListType: TokenListType, + gasPriceConstant: number, + gasLimitTransaction: number, + nonceDbPath: string, + transactionDbPath: string + ) { + this._provider = new providers.StaticJsonRpcProvider(rpcUrl); + this.chainName = chainName; + this.chainId = chainId; + this.rpcUrl = rpcUrl; + this.gasPriceConstant = gasPriceConstant; + this.tokenListSource = tokenListSource; + this.tokenListType = tokenListType; + + this._refCountingHandle = ReferenceCountingCloseable.createHandle(); + this._nonceManager = new EVMNonceManager( + chainName, + chainId, + this.resolveDBPath(nonceDbPath) + ); + this._nonceManager.declareOwnership(this._refCountingHandle); + this.cache = new NodeCache({ stdTTL: 3600 }); // set default cache ttl to 1hr + this._gasLimitTransaction = gasLimitTransaction; + this._txStorage = EvmTxStorage.getInstance( + this.resolveDBPath(transactionDbPath), + this._refCountingHandle + ); + this._txStorage.declareOwnership(this._refCountingHandle); + } + + ready(): boolean { + return this._ready; + } + + public get provider() { + return this._provider; + } + + public get gasLimitTransaction() { + return this._gasLimitTransaction; + } + + public resolveDBPath(oldPath: string): string { + if (oldPath.charAt(0) === '/') return oldPath; + const dbDir: string = path.join(rootPath(), 'db/'); + fse.mkdirSync(dbDir, { recursive: true }); + return path.join(dbDir, oldPath); + } + + public events() { + this._provider._events.map(function (event) { + return [event.tag]; + }); + } + + public onNewBlock(func: NewBlockHandler) { + this._provider.on('block', func); + } + + public onDebugMessage(func: NewDebugMsgHandler) { + this._provider.on('debug', func); + } + + async init(): Promise { + if (!this.ready() && !this._initializing) { + this._initializing = true; + await this._nonceManager.init(this.provider); + await this.loadTokens(this.tokenListSource, this.tokenListType); + this._ready = true; + this._initializing = false; + } + return; + } + + async loadTokens( + tokenListSource: string, + tokenListType: TokenListType + ): Promise { + this.tokenList = await this.getTokenList(tokenListSource, tokenListType); + // Only keep tokens in the same chain + this.tokenList = this.tokenList.filter( + (token: TokenInfo) => token.chainId === this.chainId + ); + if (this.tokenList) { + this.tokenList.forEach( + (token: TokenInfo) => (this._tokenMap[token.symbol] = token) + ); + } + } + + // returns a Tokens for a given list source and list type + async getTokenList( + tokenListSource: string, + tokenListType: TokenListType + ): Promise { + let tokens; + if (tokenListType === 'URL') { + ({ + data: { tokens }, + } = await axios.get(tokenListSource)); + } else { + ({ tokens } = JSON.parse(await fs.readFile(tokenListSource, 'utf8'))); + } + return tokens; + } + + public get nonceManager() { + return this._nonceManager; + } + + public get txStorage(): EvmTxStorage { + return this._txStorage; + } + + // ethereum token lists are large. instead of reloading each time with + // getTokenList, we can read the stored tokenList value from when the + // object was initiated. + public get storedTokenList(): TokenInfo[] { + return Object.values(this._tokenMap); + } + + // return the Token object for a symbol + getTokenForSymbol(symbol: string): TokenInfo | null { + return this._tokenMap[symbol] ? this._tokenMap[symbol] : null; + } + + getWalletFromPrivateKey(privateKey: string): Wallet { + return new Wallet(privateKey, this._provider); + } + // returns Wallet for an address + // TODO: Abstract-away into base.ts + async getWallet(address: string): Promise { + const path = `${walletPath}/${this.chainName}`; + + const encryptedPrivateKey: string = await fse.readFile( + `${path}/${address}.json`, + 'utf8' + ); + + const passphrase = ConfigManagerCertPassphrase.readPassphrase(); + if (!passphrase) { + throw new Error('missing passphrase'); + } + return await this.decrypt(encryptedPrivateKey, passphrase); + } + + encrypt(privateKey: string, password: string): Promise { + const wallet = this.getWalletFromPrivateKey(privateKey); + return wallet.encrypt(password); + } + + async decrypt( + encryptedPrivateKey: string, + password: string + ): Promise { + const wallet = await Wallet.fromEncryptedJson( + encryptedPrivateKey, + password + ); + return wallet.connect(this._provider); + } + + // returns the Native balance, convert BigNumber to string + async getNativeBalance(wallet: Wallet): Promise { + const balance = await wallet.getBalance(); + return { value: balance, decimals: 18 }; + } + + // returns the balance for an ERC-20 token + async getERC20Balance( + contract: Contract, + wallet: Wallet, + decimals: number + ): Promise { + logger.info('Requesting balance for owner ' + wallet.address + '.'); + const balance: BigNumber = await contract.balanceOf(wallet.address); + logger.info( + `Raw balance of ${contract.address} for ` + + `${wallet.address}: ${balance.toString()}` + ); + return { value: balance, decimals: decimals }; + } + + // returns the allowance for an ERC-20 token + async getERC20Allowance( + contract: Contract, + wallet: Wallet, + spender: string, + decimals: number + ): Promise { + logger.info( + 'Requesting spender ' + + spender + + ' allowance for owner ' + + wallet.address + + '.' + ); + const allowance = await contract.allowance(wallet.address, spender); + logger.info(allowance); + return { value: allowance, decimals: decimals }; + } + + // returns an ethereum TransactionResponse for a txHash. + async getTransaction(txHash: string): Promise { + return this._provider.getTransaction(txHash); + } + + // caches transaction receipt once they arrive + cacheTransactionReceipt(tx: providers.TransactionReceipt) { + this.cache.set(tx.transactionHash, tx); // transaction hash is used as cache key since it is unique enough + } + + // returns an ethereum TransactionReceipt for a txHash if the transaction has been mined. + async getTransactionReceipt( + txHash: string + ): Promise { + if (this.cache.keys().includes(txHash)) { + // If it's in the cache, return the value in cache, whether it's null or not + return this.cache.get(txHash) as providers.TransactionReceipt; + } else { + // If it's not in the cache, + const fetchedTxReceipt = await this._provider.getTransactionReceipt( + txHash + ); + + this.cache.set(txHash, fetchedTxReceipt); // Cache the fetched receipt, whether it's null or not + + if (!fetchedTxReceipt) { + this._provider.once(txHash, this.cacheTransactionReceipt.bind(this)); + } + + return fetchedTxReceipt; + } + } + + // adds allowance by spender to transfer the given amount of Token + async approveERC20( + contract: Contract, + wallet: Wallet, + spender: string, + amount: BigNumber, + nonce?: number, + maxFeePerGas?: BigNumber, + maxPriorityFeePerGas?: BigNumber, + gasPrice?: number + ): Promise { + logger.info( + 'Calling approve method called for spender ' + + spender + + ' requesting allowance ' + + amount.toString() + + ' from owner ' + + wallet.address + + '.' + ); + return this.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + const params: any = { + gasLimit: this._gasLimitTransaction, + nonce: nextNonce, + }; + if (maxFeePerGas || maxPriorityFeePerGas) { + params.maxFeePerGas = maxFeePerGas; + params.maxPriorityFeePerGas = maxPriorityFeePerGas; + } else if (gasPrice) { + params.gasPrice = (gasPrice * 1e9).toFixed(0); + } + return contract.approve(spender, amount, params); + } + ); + } + + public getTokenBySymbol(tokenSymbol: string): TokenInfo | undefined { + return this.tokenList.find( + (token: TokenInfo) => + token.symbol.toUpperCase() === tokenSymbol.toUpperCase() && + token.chainId === this.chainId + ); + } + + // returns the current block number + async getCurrentBlockNumber(): Promise { + return this._provider.getBlockNumber(); + } + + // cancel transaction + async cancelTxWithGasPrice( + wallet: Wallet, + nonce: number, + gasPrice: number + ): Promise { + return this.nonceManager.provideNonce( + nonce, + wallet.address, + async (nextNonce) => { + const tx = { + from: wallet.address, + to: wallet.address, + value: utils.parseEther('0'), + nonce: nextNonce, + gasPrice: (gasPrice * 1e9).toFixed(0), + }; + const response = await wallet.sendTransaction(tx); + logger.info(response); + + return response; + } + ); + } + + /** + * Get the base gas fee and the current max priority fee from the EVM + * node, and add them together. + */ + async getGasPrice(): Promise { + if (!this.ready) { + await this.init(); + } + const feeData: providers.FeeData = await this._provider.getFeeData(); + if (feeData.gasPrice !== null && feeData.maxPriorityFeePerGas !== null) { + return ( + feeData.gasPrice.add(feeData.maxPriorityFeePerGas).toNumber() * 1e-9 + ); + } else { + return null; + } + } + + async close() { + await this._nonceManager.close(this._refCountingHandle); + await this._txStorage.close(this._refCountingHandle); + } +} diff --git a/src/services/ethereum.abi.json b/src/services/ethereum.abi.json new file mode 100644 index 0000000000..df4b12646d --- /dev/null +++ b/src/services/ethereum.abi.json @@ -0,0 +1,600 @@ +{ + "ERC20Abi": [ + { + "constant": true, + "inputs": [], + "name": "name", + "outputs": [ + { + "name": "", + "type": "string" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_spender", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "approve", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "totalSupply", + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "transferFrom", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "decimals", + "outputs": [ + { + "name": "", + "type": "uint8" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { + "name": "_owner", + "type": "address" + } + ], + "name": "balanceOf", + "outputs": [ + { + "name": "balance", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "symbol", + "outputs": [ + { + "name": "", + "type": "string" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_to", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "transfer", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { + "name": "_owner", + "type": "address" + }, + { + "name": "_spender", + "type": "address" + } + ], + "name": "allowance", + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "payable": true, + "stateMutability": "payable", + "type": "fallback" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "name": "owner", + "type": "address" + }, + { + "indexed": true, + "name": "spender", + "type": "address" + }, + { + "indexed": false, + "name": "value", + "type": "uint256" + } + ], + "name": "Approval", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "name": "from", + "type": "address" + }, + { + "indexed": true, + "name": "to", + "type": "address" + }, + { + "indexed": false, + "name": "value", + "type": "uint256" + } + ], + "name": "Transfer", + "type": "event" + } + ], + "MKRAbi": [ + { + "constant": true, + "inputs": [], + "name": "name", + "outputs": [ + { + "name": "", + "type": "bytes32" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_spender", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "approve", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "totalSupply", + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "transferFrom", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "decimals", + "outputs": [ + { + "name": "", + "type": "uint8" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { + "name": "_owner", + "type": "address" + } + ], + "name": "balanceOf", + "outputs": [ + { + "name": "balance", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "symbol", + "outputs": [ + { + "name": "", + "type": "bytes32" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_to", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "transfer", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { + "name": "_owner", + "type": "address" + }, + { + "name": "_spender", + "type": "address" + } + ], + "name": "allowance", + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "payable": true, + "stateMutability": "payable", + "type": "fallback" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "name": "owner", + "type": "address" + }, + { + "indexed": true, + "name": "spender", + "type": "address" + }, + { + "indexed": false, + "name": "value", + "type": "uint256" + } + ], + "name": "Approval", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "name": "from", + "type": "address" + }, + { + "indexed": true, + "name": "to", + "type": "address" + }, + { + "indexed": false, + "name": "value", + "type": "uint256" + } + ], + "name": "Transfer", + "type": "event" + } + ], + "KovanWETHAbi": [ + { + "constant": true, + "inputs": [], + "name": "name", + "outputs": [{ "name": "", "type": "string" }], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { "name": "guy", "type": "address" }, + { "name": "wad", "type": "uint256" } + ], + "name": "approve", + "outputs": [{ "name": "", "type": "bool" }], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "totalSupply", + "outputs": [{ "name": "", "type": "uint256" }], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { "name": "src", "type": "address" }, + { "name": "dst", "type": "address" }, + { "name": "wad", "type": "uint256" } + ], + "name": "transferFrom", + "outputs": [{ "name": "", "type": "bool" }], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": false, + "inputs": [{ "name": "wad", "type": "uint256" }], + "name": "withdraw", + "outputs": [], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "decimals", + "outputs": [{ "name": "", "type": "uint8" }], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [{ "name": "", "type": "address" }], + "name": "balanceOf", + "outputs": [{ "name": "", "type": "uint256" }], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "symbol", + "outputs": [{ "name": "", "type": "string" }], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { "name": "dst", "type": "address" }, + { "name": "wad", "type": "uint256" } + ], + "name": "transfer", + "outputs": [{ "name": "", "type": "bool" }], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": false, + "inputs": [], + "name": "deposit", + "outputs": [], + "payable": true, + "stateMutability": "payable", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { "name": "", "type": "address" }, + { "name": "", "type": "address" } + ], + "name": "allowance", + "outputs": [{ "name": "", "type": "uint256" }], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { "payable": true, "stateMutability": "payable", "type": "fallback" }, + { + "anonymous": false, + "inputs": [ + { "indexed": true, "name": "src", "type": "address" }, + { "indexed": true, "name": "guy", "type": "address" }, + { "indexed": false, "name": "wad", "type": "uint256" } + ], + "name": "Approval", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { "indexed": true, "name": "src", "type": "address" }, + { "indexed": true, "name": "dst", "type": "address" }, + { "indexed": false, "name": "wad", "type": "uint256" } + ], + "name": "Transfer", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { "indexed": true, "name": "dst", "type": "address" }, + { "indexed": false, "name": "wad", "type": "uint256" } + ], + "name": "Deposit", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { "indexed": true, "name": "src", "type": "address" }, + { "indexed": false, "name": "wad", "type": "uint256" } + ], + "name": "Withdrawal", + "type": "event" + } + ], + "KovanFaucetAddress": "0xb48Cc42C45d262534e46d5965a9Ac496F1B7a830" +} diff --git a/src/services/evm.nonce.ts b/src/services/evm.nonce.ts new file mode 100644 index 0000000000..400c010354 --- /dev/null +++ b/src/services/evm.nonce.ts @@ -0,0 +1,546 @@ +import ethers from 'ethers'; +import { + InitializationError, + InvalidNonceError, + INVALID_NONCE_ERROR_CODE, + INVALID_NONCE_ERROR_MESSAGE, + SERVICE_UNITIALIZED_ERROR_CODE, + SERVICE_UNITIALIZED_ERROR_MESSAGE, +} from './error-handler'; +import { LocalStorage } from './local-storage'; +import { logger } from './logger'; +import { ReferenceCountingCloseable } from './refcounting-closeable'; + +export class NonceInfo { + constructor(readonly nonce: number, public expiry: number) {} +} + +NonceInfo.prototype.valueOf = function () { + return this.nonce; +}; + +export class NonceLocalStorage extends ReferenceCountingCloseable { + private readonly _localStorage: LocalStorage; + + protected constructor(dbPath: string) { + super(dbPath); + this._localStorage = LocalStorage.getInstance(dbPath, this.handle); + } + + public async init(): Promise { + await this._localStorage.init(); + } + + public async saveLeadingNonce( + chain: string, + chainId: number, + address: string, + nonce: NonceInfo + ): Promise { + const nonceValue: string = String(nonce.nonce); + const nonceExpiry: string = String(nonce.expiry); + + return this._localStorage.save( + chain + '/' + String(chainId) + '/' + address, + `${nonceValue}:${nonceExpiry}` + ); + } + + public async getLeadingNonces( + chain: string, + chainId: number + ): Promise> { + return this._localStorage.get((key: string, value: any) => { + const splitKey: string[] = key.split('/'); + if ( + splitKey.length === 3 && + splitKey[0] === chain && + splitKey[1] === String(chainId) + ) { + const nonceValues: string[] = value.split(':'); + const address: string = String(splitKey[2]); + const nonce: NonceInfo = new NonceInfo( + parseInt(nonceValues[0]), + parseInt(nonceValues[1]) + ); + return [address, nonce]; + } + return; + }); + } + + public async savePendingNonces( + chain: string, + chainId: number, + address: string, + nonces: NonceInfo[] + ): Promise { + let value = ''; + + for (const nonce of nonces) { + const nonceValue: string = String(nonce.nonce); + const nonceExpiry: string = String(nonce.expiry); + value = value + ',' + `${nonceValue}:${nonceExpiry}`; + } + + return this._localStorage.save( + `${chain}/${String(chainId)}/${address}/pending`, + value + ); + } + + public async getPendingNonces( + chain: string, + chainId: number + ): Promise> { + return this._localStorage.get((key: string, value: any) => { + const splitKey: string[] = key.split('/'); + if ( + splitKey.length === 4 && + splitKey[0] === chain && + splitKey[1] === String(chainId) && + splitKey[3] === String('pending') + ) { + const address: string = String(splitKey[2]); + const rawNonceValues: string[] = value.split(','); + + const nonceInfoList = []; + for (const values of rawNonceValues) { + const nonceValues: string[] = values.split(':'); + nonceInfoList.push( + new NonceInfo(parseInt(nonceValues[0]), parseInt(nonceValues[1])) + ); + } + nonceInfoList.splice(0, 1); + return [`${address}`, nonceInfoList]; + } + return; + }); + } + + public async close(handle: string): Promise { + await super.close(handle); + if (this.refCount < 1) { + await this._localStorage.close(this.handle); + } + } +} + +/** + * Manages EVM nonce for addresses to ensure logical consistency of nonces when + * there is a burst of transactions being sent out. + * + * This class aims to solve the following problems: + * + * 1. Sending multiple EVM transactions concurrently. + * Naively, developers would use the transaction count from the EVM node as + * the nonce for new transactions. When multiple transactions are being sent + * out this way - these transactions would often end up using the same nonce + * and thus only one of them would succeed. + * The EVM nonce manager ensures the correct serialization of nonces used in + * this case, s.t. the nonces for new concurrent transactions will go out as + * [n, n+1, n+2, ...] rathan than [n, n, n, ...] + * + * 2. Stuck or dropped transactions. + * If you've sent out a transaction with nonce n before, but it got stuck or + * was dropped from the mem-pool - it's better to just forget about its nonce + * and send the next transaction with its nonce rather than to wait for it to + * be confirmed. + * This is where the `localNonceTTL` parameter comes in. The locally cached + * nonces are only remembered for a period of time (default is 5 minutes). + * After that, nonce values from the EVM node will be used again to prevent + * potentially dropped nonces from blocking new transactions. + * + * 3. Canceling, or re-sending past transactions. + * Canceling or re-sending past transactions would typically re-use past + * nonces. This means the user is intending to reset his transaction chain + * back to a certain nonce. The manager should allow the cached nonce to go + * back to the specified past nonce when it happens. + * This means whenever a transaction is sent with a past nonce or an EVM + * cancel happens, the API logic **must** call commitNonce() to reset the + * cached nonce back to the specified position. + */ +export class EVMNonceManager extends ReferenceCountingCloseable { + // leading nonce means the latest nonce we have passed to the blockchain. + // It may or may not already be included in the blockchain. + #addressToLeadingNonce: Record = {}; + #addressToPendingNonces: Record = {}; + + #initialized: boolean = false; + #chainId: number; + #chainName: string; + #db: NonceLocalStorage; + + // These variables should be private but then we will not be able to mock it otherwise. + public _provider: ethers.providers.Provider | null = null; + public _localNonceTTL: number; + public _pendingNonceTTL: number; + + constructor( + chainName: string, + chainId: number, + dbPath: string, + localNonceTTL: number = 300 * 1000, + pendingNonceTTL: number = 300 * 1000 + ) { + const refCountKey: string = `${chainName}/${chainId}/${dbPath}`; + super(refCountKey); + + this.#chainName = chainName; + this.#chainId = chainId; + this.#db = NonceLocalStorage.getInstance(dbPath, this.handle); + this._localNonceTTL = localNonceTTL; + this._pendingNonceTTL = pendingNonceTTL; + } + + // init can be called many times and generally should always be called + // getInstance, but it only applies the values the first time it is called + public async init(provider: ethers.providers.Provider): Promise { + if (this._localNonceTTL < 0) { + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE( + 'EVMNonceManager.init localNonceTTL must be greater than or equal to zero.' + ), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + + if (this._pendingNonceTTL < 0) { + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE( + 'EVMNonceManager.init pendingNonceTTL must be greater than or equal to zero.' + ), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + + if (!this._provider) { + this._provider = provider; + } + + if (!this.#initialized) { + await this.#db.init(); + const addressToLeadingNonce: Record = + await this.#db.getLeadingNonces(this.#chainName, this.#chainId); + + const addressToPendingNonces: Record = + await this.#db.getPendingNonces(this.#chainName, this.#chainId); + + for (const [address, nonce] of Object.entries(addressToLeadingNonce)) { + logger.info(`Loading leading nonce ${nonce} for address ${address}.`); + this.#addressToLeadingNonce[address] = nonce; + } + + for (const [address, pendingNonceInfoList] of Object.entries( + addressToPendingNonces + )) { + this.#addressToPendingNonces[address] = pendingNonceInfoList; + } + + await Promise.all( + Object.keys(this.#addressToLeadingNonce).map(async (address) => { + await this.mergeNonceFromEVMNode(address, true); + }) + ); + this.#initialized = true; + } + } + + async mergeNonceFromEVMNode( + ethAddress: string, + intializationPhase: boolean = false + ): Promise { + /* + Retrieves and saves the nonce from the last successful transaction from the EVM node. + If time period of the last stored nonce exceeds the localNonceTTL, we update the nonce using the getTransactionCount + call. + */ + if (this._provider != null && (intializationPhase || this.#initialized)) { + // only run the logic below if the leading nonce does not exist or it has expired + const leadingNonceExpiryTimestamp: number = this.#addressToLeadingNonce[ + ethAddress + ] + ? this.#addressToLeadingNonce[ethAddress].expiry + : -1; + const now: number = new Date().getTime(); + if (leadingNonceExpiryTimestamp > now) { + return; + } + + const externalNonce: number = + (await this._provider.getTransactionCount(ethAddress, 'latest')) - 1; + + // update the address's leading nonce to the latest nonce from the block chain + this.#addressToLeadingNonce[ethAddress] = new NonceInfo( + externalNonce, + now + this._localNonceTTL + ); + + await this.#db.saveLeadingNonce( + this.#chainName, + this.#chainId, + ethAddress, + this.#addressToLeadingNonce[ethAddress] + ); + + // only keep pending nonces that are greater than externalNonce and have not expired + await this.dropExpiredPendingNonces(ethAddress); + } else { + logger.error( + 'EVMNonceManager.mergeNonceFromEVMNode called before initiated' + ); + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE( + 'EVMNonceManager.mergeNonceFromEVMNode' + ), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + } + + async getNonceFromMemory(ethAddress: string): Promise { + if (this.#initialized) { + if (this.#addressToLeadingNonce[ethAddress]) { + await this.mergeNonceFromEVMNode(ethAddress); + return this.#addressToLeadingNonce[ethAddress].nonce; + } else { + return null; + } + } else { + logger.error( + 'EVMNonceManager.getNonceFromMemory called before initiated' + ); + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('EVMNonceManager.getNonceFromMemory'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + } + + async getNonceFromNode(ethAddress: string): Promise { + if (this.#initialized && this._provider != null) { + const externalNonce: number = + (await this._provider.getTransactionCount(ethAddress)) - 1; + + const now: number = new Date().getTime(); + this.#addressToLeadingNonce[ethAddress] = new NonceInfo( + externalNonce, + now + this._pendingNonceTTL + ); + await this.#db.saveLeadingNonce( + this.#chainName, + this.#chainId, + ethAddress, + this.#addressToLeadingNonce[ethAddress] + ); + return this.#addressToLeadingNonce[ethAddress].nonce; + } else { + logger.error('EVMNonceManager.getNonceFromNode called before initiated'); + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('EVMNonceManager.getNonceFromNode'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + } + + async getNonce(ethAddress: string): Promise { + let nonce: number | null = await this.getNonceFromMemory(ethAddress); + if (nonce === null) { + nonce = await this.getNonceFromNode(ethAddress); + } + return nonce; + } + + async getNextNonce(ethAddress: string): Promise { + /* + Retrieves the next available nonce for a given wallet address. + This function will automatically increment the leading Nonce of the given wallet address. + */ + + if (this.#initialized) { + await this.mergeNonceFromEVMNode(ethAddress); + await this.dropExpiredPendingNonces(ethAddress); + + let newNonce = null; + let numberOfPendingNonce = 0; + const now: number = new Date().getTime(); + + if (this.#addressToPendingNonces[ethAddress] instanceof Array) + numberOfPendingNonce = this.#addressToPendingNonces[ethAddress].length; + if (numberOfPendingNonce > 0) { + const pendingNonces: NonceInfo[] = + this.#addressToPendingNonces[ethAddress]; + + for (const nonceInfo of pendingNonces) { + if (now > nonceInfo.expiry) { + newNonce = nonceInfo; + newNonce.expiry = now + this._pendingNonceTTL; + break; + } + } + if (newNonce === null) { + // All pending nonce have yet to expire. + // Use last entry in pendingNonce to determine next nonce. + newNonce = new NonceInfo( + pendingNonces[pendingNonces.length - 1].nonce + 1, + now + this._pendingNonceTTL + ); + this.#addressToPendingNonces[ethAddress].push(newNonce); + } + } else { + newNonce = new NonceInfo( + (await this.getNonce(ethAddress)) + 1, + now + this._pendingNonceTTL + ); + this.#addressToPendingNonces[ethAddress] = [newNonce]; + } + await this.#db.savePendingNonces( + this.#chainName, + this.#chainId, + `${ethAddress}`, + this.#addressToPendingNonces[ethAddress] + ); + + return newNonce.nonce; + } else { + logger.error('EVMNonceManager.getNextNonce called before initiated'); + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('EVMNonceManager.getNextNonce'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + } + + private async dropExpiredPendingNonces(ethAddress: string): Promise { + if (this.#addressToPendingNonces[ethAddress] instanceof Array) { + const now: number = new Date().getTime(); + const leadingNonce: NonceInfo | undefined = + this.#addressToLeadingNonce[ethAddress]; + const unexpiredPendingNonces: Array = []; + for (const pendingNonceInfo of this.#addressToPendingNonces[ethAddress]) { + // keep only the nonces that have not expired. If there is a leading nonce, they must also be greater than the leading nonce + if ( + pendingNonceInfo.expiry > now && + (leadingNonce === undefined || + pendingNonceInfo.nonce > leadingNonce.nonce) + ) { + unexpiredPendingNonces.push(pendingNonceInfo); + } + } + this.#addressToPendingNonces[ethAddress] = unexpiredPendingNonces; + + await this.#db.savePendingNonces( + this.#chainName, + this.#chainId, + ethAddress, + this.#addressToPendingNonces[ethAddress] + ); + } + } + + public async provideNonce( + nonce: number | undefined, // when cancelling a transaction, the client specifies the nonce, in most other cases, they late gateway decide the nonce + ethAddress: string, + f: (_nextNonce: number) => Promise // should perform a blockchain transaction that uses the nonce + ): Promise { + let nextNonce: number; + if (nonce === undefined) { + nextNonce = await this.getNextNonce(ethAddress); + } else { + nextNonce = nonce; + } + + // try to perform the transaction function f + try { + logger.info( + `Providing the next nonce ${nextNonce} for address ${ethAddress}.` + ); + const result = await f(nextNonce); // OBS: may say the nonce is too high, or the nonce is too low, can we capture that?, should we try to adjust the nonce automatically? + // OBS: what happens if there is another wallet also emitting transactions? + await this.commitNonce(ethAddress, nextNonce); + return result; + } catch (err) { + logger.error( + `Transaction with nonce ${nextNonce} for address ${ethAddress} failed : ${err}` + ); + // the transaction failed, remove nonces geq nextNonce + this.#addressToPendingNonces[ethAddress] = this.#addressToPendingNonces[ + ethAddress + ].filter((pendingNonceInfo) => pendingNonceInfo.nonce < nextNonce); + + await this.#db.savePendingNonces( + this.#chainName, + this.#chainId, + ethAddress, + this.#addressToPendingNonces[ethAddress] + ); + + throw err; + } + } + + async commitNonce(ethAddress: string, txNonce: number): Promise { + /* + Stores the nonce of the last successful transaction. + */ + if (this.#initialized) { + const now: number = new Date().getTime(); + + if (this.#addressToLeadingNonce[ethAddress]) { + if (txNonce > this.#addressToLeadingNonce[ethAddress].nonce) { + const nonce: NonceInfo = new NonceInfo( + txNonce, + now + this._localNonceTTL + ); + this.#addressToLeadingNonce[ethAddress] = nonce; + await this.#db.saveLeadingNonce( + this.#chainName, + this.#chainId, + ethAddress, + nonce + ); + return; + } else { + logger.error('Provided txNonce is < currentNonce'); + throw new InvalidNonceError( + INVALID_NONCE_ERROR_MESSAGE + + `txNonce(${txNonce}) < currentNonce(${ + this.#addressToLeadingNonce[ethAddress].nonce + })`, + INVALID_NONCE_ERROR_CODE + ); + } + } + const nonce: NonceInfo = new NonceInfo( + txNonce, + now + this._localNonceTTL + ); + this.#addressToLeadingNonce[ethAddress] = nonce; + await this.#db.saveLeadingNonce( + this.#chainName, + this.#chainId, + ethAddress, + nonce + ); + } else { + logger.error('EVMNonceManager.commitNonce called before initiated'); + throw new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('EVMNonceManager.commitNonce'), + SERVICE_UNITIALIZED_ERROR_CODE + ); + } + } + + async isValidNonce(ethAddress: string, nonce: number): Promise { + const expectedNonce: number = await this.getNextNonce(ethAddress); + if (nonce == expectedNonce) return true; + return false; + } + + async close(ownerHandle: string): Promise { + await super.close(ownerHandle); + if (this.refCount < 1) { + await this.#db.close(this.handle); + } + } +} diff --git a/src/services/evm.tx-storage.ts b/src/services/evm.tx-storage.ts new file mode 100644 index 0000000000..2af249e9d6 --- /dev/null +++ b/src/services/evm.tx-storage.ts @@ -0,0 +1,70 @@ +import { LocalStorage } from './local-storage'; +import { ReferenceCountingCloseable } from './refcounting-closeable'; + +// store the timestamp for when a transaction was initiated +// this will be used to calculate a heuristic of the likelihood +// a mempool transaction will be included in a future block +export class EvmTxStorage extends ReferenceCountingCloseable { + readonly localStorage: LocalStorage; + + protected constructor(dbPath: string) { + super(dbPath); + this.localStorage = LocalStorage.getInstance(dbPath, this.handle); + } + + public async init(): Promise { + await this.localStorage.init(); + } + + // pass in a date, then store it as a POSIX timestamp + public async saveTx( + chain: string, + chainId: number, + tx: string, + date: Date, + currentGasPrice: number + ): Promise { + return this.localStorage.save( + chain + '/' + String(chainId) + '/' + tx, + date.getTime().toString() + ',' + currentGasPrice.toString() + ); + } + + public async deleteTx( + chain: string, + chainId: number, + tx: string + ): Promise { + return this.localStorage.del(chain + '/' + String(chainId) + '/' + tx); + } + + // retrieve POSIX timestamps and convert them back into JavaScript Date types + public async getTxs( + chain: string, + chainId: number + ): Promise> { + return this.localStorage.get((key: string, value: string) => { + const splitKey = key.split('/'); + const splitValue = value.split(','); + if ( + splitKey.length === 3 && + splitKey[0] === chain && + splitKey[1] === String(chainId) && + splitValue.length === 2 + ) { + return [ + splitKey[2], + [new Date(parseInt(splitValue[0])), parseInt(splitValue[1])], + ]; + } + return; + }); + } + + public async close(handle: string): Promise { + await super.close(handle); + if (this.refCount < 1) { + await this.localStorage.close(this.handle); + } + } +} diff --git a/src/services/local-storage.ts b/src/services/local-storage.ts new file mode 100644 index 0000000000..fb3f01d124 --- /dev/null +++ b/src/services/local-storage.ts @@ -0,0 +1,87 @@ +import { Level } from 'level'; +import { ReferenceCountingCloseable } from './refcounting-closeable'; + +export class LocalStorage extends ReferenceCountingCloseable { + readonly #dbPath: string; + #db: Level; + + protected constructor(dbPath: string) { + super(dbPath); + this.#dbPath = dbPath; + this.#db = new Level(dbPath, { + createIfMissing: true, + valueEncoding: 'json', + }); + } + + public async init(): Promise { + await this.#db.open({ passive: true }); + } + + get dbPath(): string { + return this.#dbPath; + } + + get dbStatus(): string { + return this.#db.status; + } + + private async assertDbOpen(): Promise { + if (this.#db.status === 'open') { + // this is the target state, finish! + return; + } else if (this.#db.status === 'closing') { + // do nothing if closing, then try again + await new Promise((resolve) => setTimeout(resolve, 1000)); + await this.assertDbOpen(); + } else if (this.#db.status === 'closed') { + // reopen the db + await this.#db.open({ createIfMissing: true }); + await this.assertDbOpen(); + } else if (this.#db.status === 'opening') { + // wait for but do not initate the opening of the db + await this.#db.open({ passive: true }); + } + } + + public async save(key: string, value: any): Promise { + await this.assertDbOpen(); + await this.#db.put(key, value); + } + + public async del(key: string): Promise { + await this.assertDbOpen(); + await this.#db.del(key); + } + + public async get( + readFunc: (key: string, string: any) => [string, any] | undefined + ): Promise> { + await this.assertDbOpen(); + + const results: Record = {}; + const kvs = await this.#db + .iterator({ + keys: true, + values: true, + }) + .all(); + for (const [key, value] of kvs) { + const data = readFunc(key, value); + if (data) { + results[data[0]] = data[1]; + } + } + + return results; + } + + public async close(handle: string): Promise { + await super.close(handle); + if (this.refCount < 1) { + // XXX(martin_kou): `await #db.close()` would freeze. So this is used + // instead. + this.#db.close((_) => true); + } + } +} diff --git a/src/services/logger.ts b/src/services/logger.ts new file mode 100644 index 0000000000..90c3a304a8 --- /dev/null +++ b/src/services/logger.ts @@ -0,0 +1,92 @@ +import winston from 'winston'; +import DailyRotateFile from 'winston-daily-rotate-file'; +import { TelemetryTransport } from './telemetry-transport'; +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc'; +import appRoot from 'app-root-path'; +import { ConfigManagerV2 } from './config-manager-v2'; +dayjs.extend(utc); + +const { LEVEL, MESSAGE } = require('triple-beam'); + +const errorsWithStack = winston.format((einfo) => { + if (einfo instanceof Error) { + const info = Object.assign({}, einfo, { + level: einfo.level, + [LEVEL]: einfo[LEVEL] || einfo.level, + message: einfo.message, + [MESSAGE]: einfo[MESSAGE] || einfo.message, + stack: `\n${einfo.stack}` || '', + }); + return info; + } + return einfo; +}); + +export const getLocalDate = () => { + const gmtOffset = ConfigManagerV2.getInstance().get('server.GMTOffset'); + return dayjs().utcOffset(gmtOffset, false).format('YYYY-MM-DD hh:mm:ss'); +}; + +const logFileFormat = winston.format.combine( + winston.format.errors({ stack: true }), + winston.format.align(), + errorsWithStack(), + winston.format.printf((info) => { + const localDate = getLocalDate(); + return `${localDate} | ${info.level} | ${info.message} | ${info.stack}`; + }) +); + +const sdtoutFormat = winston.format.combine( + winston.format.printf((info) => { + const localDate = getLocalDate(); + return `${localDate} | ${info.level} | ${info.message}`; + }) +); + +const getLogPath = () => { + let logPath = ConfigManagerV2.getInstance().get('logging.logPath'); + logPath = [appRoot.path, 'logs'].join('/'); + return logPath; +}; + +const allLogsFileTransport = new DailyRotateFile({ + level: 'info', + filename: `${getLogPath()}/logs_gateway_app.log.%DATE%`, + datePattern: 'YYYY-MM-DD', + handleExceptions: true, + handleRejections: true, +}); + +export const logger = winston.createLogger({ + level: 'info', + format: logFileFormat, + exitOnError: false, + transports: [allLogsFileTransport], +}); + +const toStdout = new winston.transports.Console({ + format: sdtoutFormat, +}); + +const reportingProxy = new TelemetryTransport({ + host: 'api.coinalpha.com', + instanceId: ConfigManagerV2.getInstance().get('server.id'), + level: 'http', +}); + +export const updateLoggerToStdout = () => { + ConfigManagerV2.getInstance().get('logging.logToStdOut') === true + ? logger.add(toStdout) + : logger.remove(toStdout); +}; + +export const telemetry = () => { + ConfigManagerV2.getInstance().get('telemetry.enabled') === true + ? logger.add(reportingProxy) + : logger.remove(reportingProxy); +}; + +updateLoggerToStdout(); +telemetry(); diff --git a/src/services/refcounting-closeable.ts b/src/services/refcounting-closeable.ts new file mode 100644 index 0000000000..0266a653b1 --- /dev/null +++ b/src/services/refcounting-closeable.ts @@ -0,0 +1,179 @@ +import { v4 as uuidv4 } from 'uuid'; + +/** + * A referencing counting implementation for getInstance(), which guarantees + * shared instances would not be closed prematurely. Think about the following + * case: + * + * 1. You have an Ethereum instance, an Avalanche instance, and a Harmony + * instance - all of them depend on a shared database object. + * 2. Let's say you call `avalanche.close()`. The shared database object should + * NOT be closed at this point - since the Ethereum and Harmony instances + * may still want to use it. + * 3. But let's say `harmony.close()` and `ethereum.close()` are also called, + * the shared database should be closed at the last close call - because + * once that's called, there's no longer anyone owning the shared database + * object. + * + * This class provides smarter `getInstance()` and `close()` functions that are + * aware of ownership relation between objects, and use reference counting to + * determine whether an underlying object should actually be finalized or not + * when close() is called. + * + * In the above example, when `avalanche.close()` is called, the class would + * understand that the shared database object is still owned by the `ethereum` + * and `harmony` objects. So the shared database object wouldn't be finalized. + * + * When `ethereum.close()` is called, the class would see that there's no more + * object referencing the shared database, and thus it would finalize the + * database object. + * + * Every `ReferenceCountingCloseable` object has a retrieval key and a handle. + * + * The retrieval key is the shared object ID for use with `getInstance()`. + * Typically, this has to do with the shared object's semantics, like Ethereum + * network name, or database file path. + * + * The handle is the closeable object's random unique ID, used for declaring + * ownership of another shared object. When `getInstance(key, handle)` is called + * with object A's handle to retrieve object B, it means object A owns object B. + * Shared object B's `close()` function would only finalize it when all owning + * objects have also finalized. + */ +export class ReferenceCountingCloseable { + private static _retrievalMap: { + [key: string]: ReferenceCountingCloseable; + } = {}; + private static _refCounts: { [key: string]: Set } = {}; + private readonly _retrievalKey: string; + private readonly _handle: string; + + /** + * Constructs a new closeable object with reference counting. + * + * @param retrievalKey Key for use with getInstance() + * @protected + */ + protected constructor(retrievalKey: string) { + this._retrievalKey = retrievalKey; + this._handle = ReferenceCountingCloseable.createHandle(); + } + + /** + * Shared object retrieval key for use with `getInstance()`. + */ + get retrievalKey(): string { + return this._retrievalKey; + } + + /** + * Object ID for declaring ownership relation on `getInstance()`. + */ + get handle(): string { + return this._handle; + } + + /** + * How many ownership relations are pointing towards this object? + */ + get refCount(): number { + const fullKey: string = `${this.constructor.name}/${this.retrievalKey}`; + if (fullKey in ReferenceCountingCloseable._refCounts) { + return ReferenceCountingCloseable._refCounts[fullKey].size; + } + return 0; + } + + /** + * Creates a randomized object handle string. + */ + public static createHandle(): string { + return uuidv4(); + } + + /** + * Retrieves a shared object of the current class, given a retrieval key and + * the owner's handle. + * + * @param retrievalKey Retrieval key for shared object + * @param ownerHandle Handle string of owner object + */ + public static getInstance( + retrievalKey: string, + ownerHandle: string + ): T { + const fullKey: string = `${this.name}/${retrievalKey}`; + if (fullKey in ReferenceCountingCloseable._retrievalMap) { + ReferenceCountingCloseable._refCounts[fullKey].add(ownerHandle); + return ReferenceCountingCloseable._retrievalMap[fullKey] as T; + } + + const instance: ReferenceCountingCloseable = + this.createInstanceFromKey(retrievalKey); + ReferenceCountingCloseable._retrievalMap[fullKey] = instance; + ReferenceCountingCloseable._refCounts[fullKey] = new Set([ownerHandle]); + + return instance as T; + } + + /** + * Creates an instance of the current class, given a retrieval key. A default + * implementation is provided, but this can be overridden if a child class + * requires a different implementation. This function is called by + * `getInstance()` if there's no existing shared object for a retrieval key. + * + * @param retrievalKey Retrieval key for shared object + */ + public static createInstanceFromKey( + retrievalKey: string + ): ReferenceCountingCloseable { + return new this(retrievalKey); + } + + /** + * Declares ownership of this object to a handle string. This is useful when + * you wish to declare a closeable object to be owned by an outside object. + * + * @param ownerHandle Handle string representing the owner object. + */ + public declareOwnership(ownerHandle: string) { + const fullKey: string = `${this.constructor.name}/${this.retrievalKey}`; + if (!(fullKey in ReferenceCountingCloseable._retrievalMap)) { + ReferenceCountingCloseable._retrievalMap[fullKey] = this; + } + if (!(fullKey in ReferenceCountingCloseable._refCounts)) { + ReferenceCountingCloseable._refCounts[fullKey] = new Set([ownerHandle]); + } else { + ReferenceCountingCloseable._refCounts[fullKey].add(ownerHandle); + } + } + + /** + * Close with reference counting. This declares the owner object represented + * by `ownerHandle` is disposing of this object. If this object has no more + * owners, it should finalize itself (e.g. closing the underlying database, + * network connection, etc.) + * + * This is expected to be overridden by child classes. Typically, every child + * class should override this function to do two things: + * + * 1. Call `await super.close(ownerHandle);`. + * 2. If its own reference count is now 0, finalize itself: + * i. Call `await close()` for all other `ReferenceCountingCloseable` + * objects it owns. + * ii. Finalize / release any system resource it owns, e.g. database + * handles or network connections. + * + * @param ownerHandle + */ + public async close(ownerHandle: string): Promise { + const fullKey: string = `${this.constructor.name}/${this.retrievalKey}`; + if (fullKey in ReferenceCountingCloseable._retrievalMap) { + ReferenceCountingCloseable._refCounts[fullKey].delete(ownerHandle); + if (ReferenceCountingCloseable._refCounts[fullKey].size < 1) { + delete ReferenceCountingCloseable._refCounts[fullKey]; + delete ReferenceCountingCloseable._retrievalMap[fullKey]; + } + } + } +} diff --git a/src/services/schema/configuration-root-schema.json b/src/services/schema/configuration-root-schema.json new file mode 100644 index 0000000000..ad69052095 --- /dev/null +++ b/src/services/schema/configuration-root-schema.json @@ -0,0 +1,28 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "version": { + "type": "integer" + }, + "configurations": { + "type": "object", + "patternProperties": { + "^\\$namespace ": { + "type": "object", + "properties": { + "configurationPath": { + "type": "string" + }, + "schemaPath": { + "type": "string" + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + "additionalProperties": false + } +} diff --git a/src/services/schema/cosmos-schema.json b/src/services/schema/cosmos-schema.json new file mode 100644 index 0000000000..20fe33bf37 --- /dev/null +++ b/src/services/schema/cosmos-schema.json @@ -0,0 +1,30 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "networks": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "rpcURL": { "type": "string" }, + "tokenListType": { "type": "string" }, + "tokenListSource": { "type": "string" } + }, + "required": [ + "rpcURL", + "tokenListType", + "tokenListSource" + ], + "additionalProperties": false + } + }, + "additionalProperties": false + }, + "network": { "type": "string" }, + "nativeCurrencySymbol": { "type": "string" }, + "manualGasPrice": { "type": "integer" } + }, + "additionalProperties": false +} diff --git a/src/services/schema/cronos-connector-schema.json b/src/services/schema/cronos-connector-schema.json new file mode 100644 index 0000000000..2760a9dcef --- /dev/null +++ b/src/services/schema/cronos-connector-schema.json @@ -0,0 +1,25 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": ["allowedSlippage", "ttl", "contractAddresses"] +} diff --git a/src/services/schema/database-schema.json b/src/services/schema/database-schema.json new file mode 100644 index 0000000000..68eb48487d --- /dev/null +++ b/src/services/schema/database-schema.json @@ -0,0 +1,10 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "nonceDbPath": { "type": "string" }, + "transactionDbPath": { "type": "string" } + }, + "additionalProperties": false, + "required": ["nonceDbPath", "transactionDbPath"] +} diff --git a/src/services/schema/defikingdoms-schema.json b/src/services/schema/defikingdoms-schema.json new file mode 100644 index 0000000000..1f5a967e68 --- /dev/null +++ b/src/services/schema/defikingdoms-schema.json @@ -0,0 +1,25 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimit": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": ["allowedSlippage", "gasLimit", "ttl", "contractAddresses"] +} diff --git a/src/services/schema/defira-schema.json b/src/services/schema/defira-schema.json new file mode 100644 index 0000000000..5c4c8f599a --- /dev/null +++ b/src/services/schema/defira-schema.json @@ -0,0 +1,31 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" }, + "initCodeHash": { "type": "string" } + }, + "required": ["routerAddress", "initCodeHash"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "allowedSlippage", + "contractAddresses", + "gasLimitEstimate", + "ttl" + ] +} diff --git a/src/services/schema/ethereum-gas-station-schema.json b/src/services/schema/ethereum-gas-station-schema.json new file mode 100644 index 0000000000..8c35c86066 --- /dev/null +++ b/src/services/schema/ethereum-gas-station-schema.json @@ -0,0 +1,12 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "enabled": { "type": "boolean" }, + "gasStationURL": { "type": "string" }, + "APIKey": { "type": ["string", "null"] }, + "gasLevel": { "enum": ["fast", "fastest", "safeLow", "average"] } + }, + "additionalProperties": false, + "required": ["enabled"] +} diff --git a/src/services/schema/ethereum-schema.json b/src/services/schema/ethereum-schema.json new file mode 100644 index 0000000000..e9c3b00b74 --- /dev/null +++ b/src/services/schema/ethereum-schema.json @@ -0,0 +1,34 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "networks": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "chainID": { "type": "integer" }, + "nodeURL": { "type": "string" }, + "tokenListType": { "type": "string" }, + "tokenListSource": { "type": "string" }, + "nativeCurrencySymbol": { "type": "string" }, + "gasPriceRefreshInterval": { "type": "number" } + }, + "required": [ + "chainID", + "nodeURL", + "tokenListType", + "tokenListSource", + "nativeCurrencySymbol" + ], + "additionalProperties": false + } + }, + "additionalProperties": false + }, + "manualGasPrice": { "type": "integer" }, + "gasLimitTransaction": { "type": "integer" } + }, + "additionalProperties": false +} diff --git a/src/services/schema/harmony-schema.json b/src/services/schema/harmony-schema.json new file mode 100644 index 0000000000..2705fcd810 --- /dev/null +++ b/src/services/schema/harmony-schema.json @@ -0,0 +1,36 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "networks": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "chainID": { "type": "integer" }, + "nodeURL": { "type": "string" }, + "tokenListType": { "type": "string" }, + "tokenListSource": { "type": "string" }, + "nativeCurrencySymbol": { "type": "string" } + }, + "required": [ + "chainID", + "nodeURL", + "tokenListType", + "tokenListSource", + "nativeCurrencySymbol" + ], + "additionalProperties": false + } + }, + "additionalProperties": false + }, + "network": { "type": "string" }, + "autoGasPrice": { "type": "boolean" }, + "manualGasPrice": { "type": "integer" }, + "gasPricerefreshTime": { "type": "integer" }, + "gasLimitTransaction": { "type": "integer" } + }, + "additionalProperties": false +} diff --git a/src/services/schema/logging-schema.json b/src/services/schema/logging-schema.json new file mode 100644 index 0000000000..b1c5f2dd9f --- /dev/null +++ b/src/services/schema/logging-schema.json @@ -0,0 +1,10 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "logPath": { "type": "string" }, + "logToStdOut": { "type": "boolean" } + }, + "additionalProperties": false, + "required": ["logPath"] +} diff --git a/src/services/schema/openocean-schema.json b/src/services/schema/openocean-schema.json new file mode 100644 index 0000000000..9505b66fe2 --- /dev/null +++ b/src/services/schema/openocean-schema.json @@ -0,0 +1,30 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "allowedSlippage", + "gasLimitEstimate", + "ttl", + "contractAddresses" + ] +} diff --git a/src/services/schema/pangolin-schema.json b/src/services/schema/pangolin-schema.json new file mode 100644 index 0000000000..2760a9dcef --- /dev/null +++ b/src/services/schema/pangolin-schema.json @@ -0,0 +1,25 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": ["allowedSlippage", "ttl", "contractAddresses"] +} diff --git a/src/services/schema/perp-schema.json b/src/services/schema/perp-schema.json new file mode 100644 index 0000000000..1ca7edad77 --- /dev/null +++ b/src/services/schema/perp-schema.json @@ -0,0 +1,10 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "ttl": { "type": "integer" } + }, + "additionalProperties": false, + "required": ["allowedSlippage", "ttl"] +} diff --git a/src/services/schema/quickswap-schema.json b/src/services/schema/quickswap-schema.json new file mode 100644 index 0000000000..9505b66fe2 --- /dev/null +++ b/src/services/schema/quickswap-schema.json @@ -0,0 +1,30 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "allowedSlippage", + "gasLimitEstimate", + "ttl", + "contractAddresses" + ] +} diff --git a/src/services/schema/ref-schema.json b/src/services/schema/ref-schema.json new file mode 100644 index 0000000000..ae60f366b1 --- /dev/null +++ b/src/services/schema/ref-schema.json @@ -0,0 +1,25 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": ["allowedSlippage", "gasLimitEstimate", "ttl"] +} diff --git a/src/services/schema/server-schema.json b/src/services/schema/server-schema.json new file mode 100644 index 0000000000..95d17686e5 --- /dev/null +++ b/src/services/schema/server-schema.json @@ -0,0 +1,13 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "port": { "type": "integer" }, + "ipWhitelist": { "type": "array" }, + "unsafeDevModeWithHTTP": { "type": "boolean" }, + "GMTOffset": { "type": "number" }, + "id": { "type": "string" } + }, + "additionalProperties": false, + "required": ["port", "unsafeDevModeWithHTTP"] +} diff --git a/src/services/schema/ssl-schema.json b/src/services/schema/ssl-schema.json new file mode 100644 index 0000000000..6465fb7914 --- /dev/null +++ b/src/services/schema/ssl-schema.json @@ -0,0 +1,11 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "caCertificatePath": { "type": "string" }, + "certificatePath": { "type": "string" }, + "keyPath": { "type": "string" } + }, + "additionalProperties": false, + "required": ["caCertificatePath", "certificatePath", "keyPath"] +} diff --git a/src/services/schema/sushiswap-schema.json b/src/services/schema/sushiswap-schema.json new file mode 100644 index 0000000000..9fb61fa39f --- /dev/null +++ b/src/services/schema/sushiswap-schema.json @@ -0,0 +1,36 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^[\\w-]+$": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "sushiswapRouterAddress": { "type": "string" } + }, + "required": ["sushiswapRouterAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "allowedSlippage", + "gasLimitEstimate", + "ttl", + "contractAddresses" + ] +} diff --git a/src/services/schema/telemetry-schema.json b/src/services/schema/telemetry-schema.json new file mode 100644 index 0000000000..cdb8612791 --- /dev/null +++ b/src/services/schema/telemetry-schema.json @@ -0,0 +1,8 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "enabled": { "type": "boolean" } + }, + "required": ["enabled"] +} diff --git a/src/services/schema/traderjoe-schema.json b/src/services/schema/traderjoe-schema.json new file mode 100644 index 0000000000..9505b66fe2 --- /dev/null +++ b/src/services/schema/traderjoe-schema.json @@ -0,0 +1,30 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "routerAddress": { "type": "string" } + }, + "required": ["routerAddress"], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "allowedSlippage", + "gasLimitEstimate", + "ttl", + "contractAddresses" + ] +} diff --git a/src/services/schema/uniswap-schema.json b/src/services/schema/uniswap-schema.json new file mode 100644 index 0000000000..91710caf14 --- /dev/null +++ b/src/services/schema/uniswap-schema.json @@ -0,0 +1,36 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "properties": { + "allowedSlippage": { "type": "string" }, + "gasLimitEstimate": { "type": "integer" }, + "ttl": { "type": "integer" }, + "maximumHops": { "type": "integer" }, + "contractAddresses": { + "type": "object", + "patternProperties": { + "^\\w+$": { + "type": "object", + "properties": { + "uniswapV3SmartOrderRouterAddress": { "type": "string" }, + "uniswapV3NftManagerAddress": { "type": "string" } + }, + "required": [ + "uniswapV3SmartOrderRouterAddress", + "uniswapV3NftManagerAddress" + ], + "additionalProperties": false + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "allowedSlippage", + "gasLimitEstimate", + "ttl", + "maximumHops", + "contractAddresses" + ] +} diff --git a/src/services/swagger-manager.ts b/src/services/swagger-manager.ts new file mode 100644 index 0000000000..04221ca5e0 --- /dev/null +++ b/src/services/swagger-manager.ts @@ -0,0 +1,59 @@ +import fs from 'fs'; +import yaml from 'js-yaml'; + +export namespace SwaggerManager { + export function validateMainFile(o: any): boolean { + return ( + 'swagger' in o && + 'info' in o && + 'host' in o && + 'tags' in o && + 'schemes' in o && + 'externalDocs' in o + ); + } + + export function validateRoutesFile(o: any): boolean { + return 'paths' in o; + } + + export function validateDefinitionsFile(o: any): boolean { + return 'definitions' in o; + } + + export function validate( + fp: string, + f: (o: any) => boolean + ): Record { + const o = yaml.load(fs.readFileSync(fp, 'utf8')); + if (o != null && typeof o === 'object' && f(o)) { + return >o; + } else { + throw new Error(fp + ' does not conform to the expected structure.'); + } + } + + export function generateSwaggerJson( + mainFilePath: string, + definitionsFilePath: string, + routesFilePaths: string[] + ): Record { + const main = validate(mainFilePath, validateMainFile); + + const paths: Record = {}; + + for (const fp of routesFilePaths) { + const routes = validate(fp, validateRoutesFile); + for (const key in routes['paths']) { + paths[key] = routes['paths'][key]; + } + } + + main['paths'] = paths; + + const definitions = validate(definitionsFilePath, validateDefinitionsFile); + main['definitions'] = definitions['definitions']; + + return main; + } +} diff --git a/src/services/telemetry-transport.ts b/src/services/telemetry-transport.ts new file mode 100644 index 0000000000..c76df1c376 --- /dev/null +++ b/src/services/telemetry-transport.ts @@ -0,0 +1,104 @@ +import winston from 'winston'; +import https from 'https'; +import querystring from 'querystring'; + +export type LogCallback = (err: any, res: any) => void; + +// Inherit from `winston-transport Http` so you can take advantage +// of the base functionality and `.exceptions.handle()`. +// +// Note: query and stream wouldn't work on this transport. +export class TelemetryTransport extends winston.transports.Http { + private logInterval: number; + private errorLogBuffer: string[]; + private requestCountAggregator: number; + private instanceId: string; + + constructor(opts: any) { + super(opts); + + this.logInterval = 3600000; + this.instanceId = opts.instanceId || ''; + this.errorLogBuffer = []; + this.requestCountAggregator = 0; + setInterval(this.sendLogs.bind(this), this.logInterval); + } + + private processData(log: any): void { + if ('stack' in log) + this.errorLogBuffer.push(`${Date.now()} - ${log.message}\n${log.stack}`); + else if (log.level === 'http') + this.requestCountAggregator += Number(log.message.split('\t')[1]); + } + + public responseHandler(err: any, res: any): void { + if (res && res.statusCode !== 200) { + err = new Error(`Invalid HTTP Status Code: ${res.statusCode}`); + } + + if (err) { + this.emit('warn', err); + } else { + this.emit('logged', 'Successfully logged metrics.'); + } + } + + public sendLogs(): void { + if (this.errorLogBuffer.length > 0) { + const logData = { + data: JSON.stringify(this.errorLogBuffer), + params: { + ddtags: `instance_id:${this.instanceId},type:logs`, + ddsource: 'gateway', + }, + }; + this._request(logData, true, this.responseHandler.bind(this)); + } + + if (this.requestCountAggregator > 0) { + const metric = { + data: JSON.stringify({ + name: 'request_count', + source: 'gateway', + instance_id: this.instanceId, + value: this.requestCountAggregator, + }), + }; + this._request(metric, false, this.responseHandler.bind(this)); + } + + this.errorLogBuffer = []; // reset error log buffer + this.requestCountAggregator = 0; // reset request counter + } + + public log(data: any, callback: LogCallback) { + this.processData(data); + + if (callback) { + setImmediate(callback); + } + } + + public _request(options: any, isLog: boolean, callback: LogCallback) { + // Prepare options for outgoing HTTP request + const headers = { + 'Content-Type': 'application/json', + 'Content-Length': options.data.length, + }; + const req = https.request({ + method: 'POST', + host: this.host, + port: 443, + path: isLog + ? `/reporting-proxy-v2/log?${querystring.stringify(options.params)}` + : '/reporting-proxy-v2/client_metrics', + headers: headers, + }); + + req.on('error', callback); + req.on('response', (res) => + res.on('end', () => callback(null, res)).resume() + ); + req.end(Buffer.from(options.data, 'utf8')); + } +} diff --git a/src/services/validators.ts b/src/services/validators.ts new file mode 100644 index 0000000000..576c64e1ac --- /dev/null +++ b/src/services/validators.ts @@ -0,0 +1,182 @@ +import { HttpException } from './error-handler'; + +export const invalidAmountError: string = + 'If amount is included it must be a string of a non-negative integer.'; + +export const invalidTokenError: string = 'The token param should be a string.'; + +export const invalidTxHashError: string = 'The txHash param must be a string.'; + +export const invalidTokenSymbolsError: string = + 'The tokenSymbols param should be an array of strings.'; + +export const isNaturalNumberString = (str: string): boolean => { + return /^[0-9]+$/.test(str); +}; + +export const isIntegerString = (str: string): boolean => { + return /^[+-]?[0-9]+$/.test(str); +}; + +export const isFloatString = (str: string): boolean => { + if (isIntegerString(str)) { + return true; + } + const decimalSplit = str.split('.'); + if (decimalSplit.length === 2) { + return ( + isIntegerString(decimalSplit[0]) && isNaturalNumberString(decimalSplit[1]) + ); + } + return false; +}; + +export const isFractionString = (str: string): boolean => { + const fractionSplit = str.split('/'); + if (fractionSplit.length == 2) { + return ( + isIntegerString(fractionSplit[0]) && isIntegerString(fractionSplit[1]) + ); + } + return false; +}; + +// throw an error because the request parameter is malformed, collect all the +// errors related to the request to give the most information possible +export const throwIfErrorsExist = (errors: Array): void => { + if (errors.length > 0) { + throw new HttpException(404, errors.join(', ')); + } +}; + +export const missingParameter = (key: string): string => { + return `The request is missing the key: ${key}`; +}; + +export type Validator = (req: any) => Array; + +export type RequestValidator = (req: any) => void; + +export const mkBranchingValidator = ( + branchingKey: string, + branchingCondition: (req: any, key: string) => boolean, + validator1: Validator, + validator2: Validator +): Validator => { + return (req: any) => { + let errors: Array = []; + if (req[branchingKey]) { + if (branchingCondition(req, branchingKey)) { + errors = errors.concat(validator1(req)); + } else { + errors = errors.concat(validator2(req)); + } + } else { + errors.push(missingParameter(branchingKey)); + } + return errors; + }; +}; + +export const mkSelectingValidator = ( + branchingKey: string, + branchingCondition: (req: any, key: string) => string, + validators: { [id: string]: Validator } +): Validator => { + return (req: any) => { + let errors: Array = []; + if (req[branchingKey]) { + if ( + Object.keys(validators).includes(branchingCondition(req, branchingKey)) + ) { + errors = errors.concat( + validators[branchingCondition(req, branchingKey)](req) + ); + } else { + errors.push( + `No validator exists for ${branchingCondition(req, branchingKey)}.` + ); + } + } else { + errors.push(missingParameter(branchingKey)); + } + return errors; + }; +}; + +export const mkValidator = ( + key: string, + errorMsg: string, + condition: (x: any) => boolean, + optional: boolean = false +): Validator => { + return (req: any) => { + const errors: Array = []; + if (req[key]) { + if (!condition(req[key])) { + errors.push(errorMsg); + } + } else { + if (!optional) { + errors.push(missingParameter(key)); + } + } + + return errors; + }; +}; + +export const mkRequestValidator = ( + validators: Array +): RequestValidator => { + return (req: any) => { + let errors: Array = []; + validators.forEach( + (validator: Validator) => (errors = errors.concat(validator(req))) + ); + throwIfErrorsExist(errors); + }; +}; + +// confirm that tokenSymbols is an array of strings +export const validateTokenSymbols: Validator = (req: any) => { + const errors: Array = []; + if (req.tokenSymbols) { + if (Array.isArray(req.tokenSymbols)) { + req.tokenSymbols.forEach((symbol: any) => { + if (typeof symbol !== 'string') { + errors.push(invalidTokenSymbolsError); + } + }); + } else { + errors.push(invalidTokenSymbolsError); + } + } else { + errors.push(missingParameter('tokenSymbols')); + } + return errors; +}; + +export const isBase58 = (value: string): boolean => + /^[A-HJ-NP-Za-km-z1-9]*$/.test(value); + +// confirm that token is a string +export const validateToken: Validator = mkValidator( + 'token', + invalidTokenError, + (val) => typeof val === 'string' +); + +// if amount exists, confirm that it is a string of a natural number +export const validateAmount: Validator = mkValidator( + 'amount', + invalidAmountError, + (val) => typeof val === 'string' && isNaturalNumberString(val), + true +); + +export const validateTxHash: Validator = mkValidator( + 'txHash', + invalidTxHashError, + (val) => typeof val === 'string' +); diff --git a/src/services/wallet/wallet.controllers.ts b/src/services/wallet/wallet.controllers.ts new file mode 100644 index 0000000000..a1ea9d3641 --- /dev/null +++ b/src/services/wallet/wallet.controllers.ts @@ -0,0 +1,176 @@ +import fse from 'fs-extra'; +import { Avalanche } from '../../chains/avalanche/avalanche'; +import { BinanceSmartChain } from '../../chains/binance-smart-chain/binance-smart-chain'; +import { Cronos } from '../../chains/cronos/cronos'; +import { Ethereum } from '../../chains/ethereum/ethereum'; +import { Polygon } from '../../chains/polygon/polygon'; +import { Cosmos } from '../../chains/cosmos/cosmos'; +import { Harmony } from '../../chains/harmony/harmony'; + +import { + AddWalletRequest, + AddWalletResponse, + RemoveWalletRequest, + GetWalletResponse, +} from './wallet.requests'; + +import { ConfigManagerCertPassphrase } from '../config-manager-cert-passphrase'; + +import { + ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_CODE, + ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_MESSAGE, + ACCOUNT_NOT_SPECIFIED_CODE, + ACCOUNT_NOT_SPECIFIED_ERROR_MESSAGE, + HttpException, + UNKNOWN_CHAIN_ERROR_CODE, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE, +} from '../error-handler'; +import { EthereumBase } from '../ethereum-base'; +import { Near } from '../../chains/near/near'; + +const walletPath = './conf/wallets'; +export async function mkdirIfDoesNotExist(path: string): Promise { + const exists = await fse.pathExists(path); + if (!exists) { + await fse.mkdir(path, { recursive: true }); + } +} + +export async function addWallet( + req: AddWalletRequest +): Promise { + const passphrase = ConfigManagerCertPassphrase.readPassphrase(); + if (!passphrase) { + throw new Error('There is no passphrase'); + } + let connection: EthereumBase | Near | Cosmos; + let address: string | undefined; + let encryptedPrivateKey: string | undefined; + + if (req.chain === 'ethereum') { + connection = Ethereum.getInstance(req.network); + } else if (req.chain === 'avalanche') { + connection = Avalanche.getInstance(req.network); + } else if (req.chain === 'harmony') { + connection = Harmony.getInstance(req.network); + } else if (req.chain === 'cronos') { + connection = Cronos.getInstance(req.network); + } else if (req.chain === 'polygon') { + connection = Polygon.getInstance(req.network); + } else if (req.chain === 'cosmos') { + connection = Cosmos.getInstance(req.network); + } else if (req.chain === 'near') { + if (!('address' in req)) + throw new HttpException( + 500, + ACCOUNT_NOT_SPECIFIED_ERROR_MESSAGE(), + ACCOUNT_NOT_SPECIFIED_CODE + ); + connection = Near.getInstance(req.network); + } else if (req.chain === 'binance-smart-chain') { + connection = BinanceSmartChain.getInstance(req.network); + } else { + throw new HttpException( + 500, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE(req.chain), + UNKNOWN_CHAIN_ERROR_CODE + ); + } + + if (!connection.ready()) { + await connection.init(); + } + + try { + if (connection instanceof EthereumBase) { + address = connection.getWalletFromPrivateKey(req.privateKey).address; + encryptedPrivateKey = await connection.encrypt( + req.privateKey, + passphrase + ); + } else if (connection instanceof Cosmos) { + const wallet = await connection.getAccountsfromPrivateKey( + req.privateKey, + 'cosmos' + ); + address = wallet.address; + encryptedPrivateKey = await connection.encrypt( + req.privateKey, + passphrase + ); + } else if (connection instanceof Near) { + address = ( + await connection.getWalletFromPrivateKey( + req.privateKey, + req.address + ) + ).accountId; + encryptedPrivateKey = connection.encrypt(req.privateKey, passphrase); + } + + if (address === undefined || encryptedPrivateKey === undefined) { + throw new Error('ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_CODE'); + } + } catch (_e: unknown) { + throw new HttpException( + 500, + ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_MESSAGE(req.privateKey), + ERROR_RETRIEVING_WALLET_ADDRESS_ERROR_CODE + ); + } + const path = `${walletPath}/${req.chain}`; + await mkdirIfDoesNotExist(path); + await fse.writeFile(`${path}/${address}.json`, encryptedPrivateKey); + return { address }; +} + +// if the file does not exist, this should not fail +export async function removeWallet(req: RemoveWalletRequest): Promise { + await fse.rm(`./conf/wallets/${req.chain}/${req.address}.json`, { + force: true, + }); +} + +export async function getDirectories(source: string): Promise { + await mkdirIfDoesNotExist(walletPath); + const files = await fse.readdir(source, { withFileTypes: true }); + return files + .filter((dirent) => dirent.isDirectory()) + .map((dirent) => dirent.name); +} + +export function getLastPath(path: string): string { + return path.split('/').slice(-1)[0]; +} + +export function dropExtension(path: string): string { + return path.substr(0, path.lastIndexOf('.')) || path; +} + +export async function getJsonFiles(source: string): Promise { + const files = await fse.readdir(source, { withFileTypes: true }); + return files + .filter((f) => f.isFile() && f.name.endsWith('.json')) + .map((f) => f.name); +} + +export async function getWallets(): Promise { + const chains = await getDirectories(walletPath); + + const responses: GetWalletResponse[] = []; + + for (const chain of chains) { + const walletFiles = await getJsonFiles(`${walletPath}/${chain}`); + + const response: GetWalletResponse = { chain, walletAddresses: [] }; + + for (const walletFile of walletFiles) { + const address = dropExtension(getLastPath(walletFile)); + response.walletAddresses.push(address); + } + + responses.push(response); + } + + return responses; +} diff --git a/src/services/wallet/wallet.requests.ts b/src/services/wallet/wallet.requests.ts new file mode 100644 index 0000000000..bc30504c0b --- /dev/null +++ b/src/services/wallet/wallet.requests.ts @@ -0,0 +1,20 @@ +export interface AddWalletRequest { + chain: string; + network: string; + privateKey: string; + address?: string; +} + +export interface AddWalletResponse { + address: string; +} + +export interface RemoveWalletRequest { + chain: string; + address: string; +} + +export interface GetWalletResponse { + chain: string; + walletAddresses: string[]; +} diff --git a/src/services/wallet/wallet.routes.ts b/src/services/wallet/wallet.routes.ts new file mode 100644 index 0000000000..9b6bd17f1d --- /dev/null +++ b/src/services/wallet/wallet.routes.ts @@ -0,0 +1,57 @@ +/* eslint-disable @typescript-eslint/ban-types */ +import { Router, Request, Response } from 'express'; + +import { asyncHandler } from '../error-handler'; + +import { addWallet, removeWallet, getWallets } from './wallet.controllers'; + +import { + AddWalletRequest, + AddWalletResponse, + RemoveWalletRequest, + GetWalletResponse, +} from './wallet.requests'; + +import { + validateAddWalletRequest, + validateRemoveWalletRequest, +} from './wallet.validators'; + +export namespace WalletRoutes { + export const router = Router(); + + router.get( + '/', + asyncHandler(async (_req, res: Response) => { + const response = await getWallets(); + res.status(200).json(response); + }) + ); + + router.post( + '/add', + asyncHandler( + async ( + req: Request<{}, {}, AddWalletRequest>, + res: Response + ) => { + validateAddWalletRequest(req.body); + res.status(200).json(await addWallet(req.body)); + } + ) + ); + + router.delete( + '/remove', + asyncHandler( + async ( + req: Request<{}, {}, RemoveWalletRequest>, + res: Response + ) => { + validateRemoveWalletRequest(req.body); + await removeWallet(req.body); + res.status(200).json(); + } + ) + ); +} diff --git a/src/services/wallet/wallet.validators.ts b/src/services/wallet/wallet.validators.ts new file mode 100644 index 0000000000..10f9492824 --- /dev/null +++ b/src/services/wallet/wallet.validators.ts @@ -0,0 +1,131 @@ +import { + mkValidator, + mkRequestValidator, + RequestValidator, + Validator, + mkSelectingValidator, +} from '../validators'; +const { fromBase64 } = require('@cosmjs/encoding'); + +export const invalidEthPrivateKeyError: string = + 'The privateKey param is not a valid Ethereum private key (64 hexadecimal characters).'; + +export const invalidNearPrivateKeyError: string = + 'The privateKey param is not a valid Near private key.'; + +export const invalidCosmosPrivateKeyError: string = + 'The privateKey param is not a valid Cosmos private key.'; + +// test if a string matches the shape of an Ethereum private key +export const isEthPrivateKey = (str: string): boolean => { + return /^(0x)?[a-fA-F0-9]{64}$/.test(str); +}; + +// test if a string matches the Near private key encoding format (i.e. :') +export const isNearPrivateKey = (str: string): boolean => { + const parts = str.split(':'); + return parts.length === 2; +}; + +export const isCosmosPrivateKey = (str: string): boolean => { + try { + fromBase64(str); + + return true; + } catch { + return false; + } +}; + +// given a request, look for a key called privateKey that is an Ethereum private key +export const validatePrivateKey: Validator = mkSelectingValidator( + 'chain', + (req, key) => req[key], + { + ethereum: mkValidator( + 'privateKey', + invalidEthPrivateKeyError, + (val) => typeof val === 'string' && isEthPrivateKey(val) + ), + cronos: mkValidator( + 'privateKey', + invalidEthPrivateKeyError, + (val) => typeof val === 'string' && isEthPrivateKey(val) + ), + avalanche: mkValidator( + 'privateKey', + invalidEthPrivateKeyError, + (val) => typeof val === 'string' && isEthPrivateKey(val) + ), + harmony: mkValidator( + 'privateKey', + invalidEthPrivateKeyError, + (val) => typeof val === 'string' && isEthPrivateKey(val) + ), + near: mkValidator( + 'privateKey', + invalidNearPrivateKeyError, + (val) => typeof val === 'string' && isNearPrivateKey(val) + ), + cosmos: mkValidator( + 'privateKey', + invalidCosmosPrivateKeyError, + (val) => typeof val === 'string' && isCosmosPrivateKey(val) + ), + polygon: mkValidator( + 'privateKey', + invalidEthPrivateKeyError, + (val) => typeof val === 'string' && isEthPrivateKey(val) + ), + 'binance-smart-chain': mkValidator( + 'privateKey', + invalidEthPrivateKeyError, + (val) => typeof val === 'string' && isEthPrivateKey(val) + ), + } +); + +export const invalidChainError: string = + 'chain must be "ethereum", "avalanche", "near", "harmony", "cosmos" or "binance-smart-chain"'; + +export const invalidNetworkError: string = + 'expected a string for the network key'; + +export const invalidAddressError: string = 'address must be a string'; + +export const validateChain: Validator = mkValidator( + 'chain', + invalidChainError, + (val) => + typeof val === 'string' && + (val === 'ethereum' || + val === 'avalanche' || + val === 'polygon' || + val == 'near' || + val === 'harmony' || + val === 'cronos' || + val === 'cosmos' || + val === 'binance-smart-chain') +); + +export const validateNetwork: Validator = mkValidator( + 'network', + invalidNetworkError, + (val) => typeof val === 'string' +); + +export const validateAddress: Validator = mkValidator( + 'address', + invalidAddressError, + (val) => typeof val === 'string' +); + +export const validateAddWalletRequest: RequestValidator = mkRequestValidator([ + validatePrivateKey, + validateChain, + validateNetwork, +]); + +export const validateRemoveWalletRequest: RequestValidator = mkRequestValidator( + [validateAddress, validateChain] +); diff --git a/src/templates/avalanche.yml b/src/templates/avalanche.yml new file mode 100644 index 0000000000..3fc09d0261 --- /dev/null +++ b/src/templates/avalanche.yml @@ -0,0 +1,19 @@ +# list the Avalanche networks available to gateway +networks: + fuji: + chainID: 43113 + nodeURL: https://rpc.ankr.com/avalanche_fuji + tokenListType: 'FILE' + tokenListSource: 'src/chains/avalanche/avalanche_tokens_fuji.json' + nativeCurrencySymbol: 'AVAX' + gasPriceRefreshInterval: 60 + avalanche: + chainID: 43114 + nodeURL: https://rpc.ankr.com/avalanche + tokenListType: 'FILE' + tokenListSource: 'src/chains/avalanche/avanlanche_tokens.json' + nativeCurrencySymbol: 'AVAX' + gasPriceRefreshInterval: 60 + +manualGasPrice: 100 +gasLimitTransaction: 3000000 diff --git a/src/templates/binance-smart-chain.yml b/src/templates/binance-smart-chain.yml new file mode 100644 index 0000000000..f4cd74d2dc --- /dev/null +++ b/src/templates/binance-smart-chain.yml @@ -0,0 +1,19 @@ +# list the BSC networks available to gateway +networks: + mainnet: + chainID: 56 + nodeURL: 'https://bsc-dataseed1.binance.org/' + tokenListType: FILE + tokenListSource: src/chains/binance-smart-chain/bep20_tokens_mainnet.json + nativeCurrencySymbol: 'BNB' + gasPriceRefreshInterval: 60 + testnet: + chainID: 97 + nodeURL: 'https://data-seed-prebsc-1-s1.binance.org:8545/' + tokenListType: 'FILE' + tokenListSource: 'src/chains/binance-smart-chain/bep20_tokens_testnet.json' + nativeCurrencySymbol: 'BNB' + gasPriceRefreshInterval: 60 + +manualGasPrice: 100 +gasLimitTransaction: 3000000 diff --git a/src/templates/cosmos.yml b/src/templates/cosmos.yml new file mode 100644 index 0000000000..830ab6cf8d --- /dev/null +++ b/src/templates/cosmos.yml @@ -0,0 +1,13 @@ +networks: + mainnet: + rpcURL: https://cosmos-mainnet-rpc.allthatnode.com:26657 + tokenListType: URL + tokenListSource: >- + https://cosmos-chain-registry-list.vercel.app/list.json + testnet: + rpcURL: https://cosmos-testnet-rpc.allthatnode.com:26657 + tokenListType: URL + tokenListSource: https://cosmos-chain-registry-list.vercel.app/list.json +network: mainnet +nativeCurrencySymbol: ATOM +manualGasPrice: 110 diff --git a/src/templates/cronos.yml b/src/templates/cronos.yml new file mode 100644 index 0000000000..f20afe40fb --- /dev/null +++ b/src/templates/cronos.yml @@ -0,0 +1,19 @@ +# list the cronos networks available to gateway +networks: + mainnet: + chainID: 25 + nodeURL: 'https://evm.cronos.org/' + tokenListType: 'FILE' + tokenListSource: 'src/chains/cronos/mainnet_beta.json' + nativeCurrencySymbol: 'CRO' + gasPriceRefreshInterval: 60 + testnet: + chainID: 338 + nodeURL: 'https://evm-t3.cronos.org/' + tokenListType: 'FILE' + tokenListSource: 'src/chains/cronos/testnet.json' + nativeCurrencySymbol: 'CRO' + gasPriceRefreshInterval: 60 + +manualGasPrice: 100 +gasLimitTransaction: 3000000 diff --git a/src/templates/database.yml b/src/templates/database.yml new file mode 100644 index 0000000000..ccbd1db6af --- /dev/null +++ b/src/templates/database.yml @@ -0,0 +1,2 @@ +nonceDbPath: 'nonce.level' +transactionDbPath: 'transaction.level' diff --git a/src/templates/defikingdoms.yml b/src/templates/defikingdoms.yml new file mode 100644 index 0000000000..86956e6323 --- /dev/null +++ b/src/templates/defikingdoms.yml @@ -0,0 +1,14 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas allowed for a defikingdoms trade. +gasLimit: 2000000 + +# how long a trade is valid in seconds. After time passes defikingdoms will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + mainnet: + routerAddress: '0x24ad62502d1C652Cc7684081169D04896aC20f30' diff --git a/src/templates/defira.yml b/src/templates/defira.yml new file mode 100644 index 0000000000..b6cff6865f --- /dev/null +++ b/src/templates/defira.yml @@ -0,0 +1,18 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas allowed for a defira trade. +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes defira will not +# perform the trade, but the gas will still be spent. +ttl: 600 + +contractAddresses: + mainnet: + routerAddress: '0x3C8BF7e25EbfAaFb863256A4380A8a93490d8065' + initCodeHash: '0x8e129668eb66a23d5dbb072b9b801a6ca1147df379e11546ad4ac19e28557e6c' + testnet: + routerAddress: '0xA5C5D1fd1Fd07F95359E2bde419CB5B2cdC622A9' + initCodeHash: '0x7224a10f5f94e12d3973f5ef0f63a558539a93e1eef47935934ffc4d741b4b9f' diff --git a/src/templates/ethereum.yml b/src/templates/ethereum.yml new file mode 100644 index 0000000000..2e3dc35830 --- /dev/null +++ b/src/templates/ethereum.yml @@ -0,0 +1,37 @@ +networks: + arbitrum_one: + chainID: 42161 + nodeURL: https://rpc.ankr.com/arbitrum + tokenListType: FILE + tokenListSource: src/chains/ethereum/arbitrum_one_tokens.json + nativeCurrencySymbol: ETH + gasPriceRefreshInterval: 60 + arbitrum_rinkeby: + chainID: 421611 + nodeURL: https://arbitrum-rinkeby.infura.io/v3/ + tokenListType: FILE + tokenListSource: src/chains/ethereum/arbitrum_rinkeby_tokens.json + nativeCurrencySymbol: ETH + mainnet: + chainID: 1 + nodeURL: https://rpc.ankr.com/eth + tokenListType: FILE + nativeCurrencySymbol: ETH + tokenListSource: src/chains/ethereum/erc20_tokens_mainnet.json + gasPriceRefreshInterval: 60 + optimism: + chainID: 10 + nodeURL: https://rpc.ankr.com/optimism + tokenListType: FILE + tokenListSource: src/chains/ethereum/optimism_tokens.json + nativeCurrencySymbol: OETH + gasPriceRefreshInterval: 60 + goerli: + chainID: 5 + nodeURL: https://rpc.ankr.com/eth_goerli + tokenListType: FILE + tokenListSource: src/chains/ethereum/erc20_tokens_goerli.json + nativeCurrencySymbol: ETH + +gasLimitTransaction: 3000000 +manualGasPrice: 200 diff --git a/src/templates/harmony.yml b/src/templates/harmony.yml new file mode 100644 index 0000000000..bdb40f1c10 --- /dev/null +++ b/src/templates/harmony.yml @@ -0,0 +1,20 @@ +# list the Avalanche networks available to gateway +networks: + mainnet: + chainID: 1666600000 + nodeURL: https://rpc.ankr.com/harmony + tokenListType: 'FILE' + tokenListSource: 'src/chains/harmony/harmony_tokens_sushiswap.json' + nativeCurrencySymbol: 'ONE' + testnet: + chainID: 1666700000 + nodeURL: 'https://api.s0.b.hmny.io' + tokenListType: 'FILE' + tokenListSource: 'src/chains/harmony/harmony_tokens_sushiswap_testnet.json' + nativeCurrencySymbol: 'ONE' + +network: 'harmony' +autoGasPrice: true +manualGasPrice: 30 +gasPricerefreshTime: 60 +gasLimitTransaction: 3000000 diff --git a/src/templates/logging.yml b/src/templates/logging.yml new file mode 100644 index 0000000000..c5ffe44046 --- /dev/null +++ b/src/templates/logging.yml @@ -0,0 +1,6 @@ +# The directory path where logs will be stored. +logPath: './logs' + +# If true, logs will be stored in logPath and printed to stdout. If false, they +# will only be stored in logPath and not printed to stdout. +logToStdOut: true diff --git a/src/templates/mad_meerkat.yml b/src/templates/mad_meerkat.yml new file mode 100644 index 0000000000..5ee1d01fc1 --- /dev/null +++ b/src/templates/mad_meerkat.yml @@ -0,0 +1,14 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas used to estimate gasCost for a Mad Meerkat Finance trade. +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes Mad Meerkat will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + mainnet: + routerAddress: '0x145677FC4d9b8F19B5D56d1820c48e0443049a30' diff --git a/src/templates/near.yml b/src/templates/near.yml new file mode 100644 index 0000000000..69e118f081 --- /dev/null +++ b/src/templates/near.yml @@ -0,0 +1,19 @@ +networks: + mainnet: + chainID: 0 + nodeURL: https://rpc.mainnet.near.org + tokenListType: FILE + nativeCurrencySymbol: NEAR + tokenListSource: src/chains/near/near_tokens.json + gasPriceRefreshInterval: 60 + testnet: + chainID: 0 + nodeURL: https://rpc.testnet.near.org + tokenListType: FILE + tokenListSource: src/chains/near/near_testnet_tokens.json + nativeCurrencySymbol: NEAR + gasPriceRefreshInterval: 60 + +gasLimitTransaction: 3000000000000 +manualGasPrice: 0 + \ No newline at end of file diff --git a/src/templates/openocean.yml b/src/templates/openocean.yml new file mode 100644 index 0000000000..2ef5da3f5d --- /dev/null +++ b/src/templates/openocean.yml @@ -0,0 +1,14 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas allowed for a openocean trade. +gasLimitEstimate: 185837 + +# how long a trade is valid in seconds. After time passes openocean will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + avalanche: + routerAddress: '0x6352a56caadC4F1E25CD6c75970Fa768A3304e64' diff --git a/src/templates/pancakeswap.yml b/src/templates/pancakeswap.yml new file mode 100644 index 0000000000..0f57ea04f1 --- /dev/null +++ b/src/templates/pancakeswap.yml @@ -0,0 +1,16 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas used to estimate gasCost for a uniswap trade. +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes pancakeswap will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + mainnet: + routerAddress: '0x10ED43C718714eb63d5aA57B78B54704E256024E' + testnet: + routerAddress: '0xdc4904b5f716Ff30d8495e35dC99c109bb5eCf81' diff --git a/src/templates/pangolin.yml b/src/templates/pangolin.yml new file mode 100644 index 0000000000..5ce88b0e2f --- /dev/null +++ b/src/templates/pangolin.yml @@ -0,0 +1,16 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas used to estimate gasCost for a pangolin trade. +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes pangolin will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + fuji: + routerAddress: '0xE54Ca86531e17Ef3616d22Ca28b0D458b6C89106' + avalanche: + routerAddress: '0xE54Ca86531e17Ef3616d22Ca28b0D458b6C89106' diff --git a/src/templates/perp.yml b/src/templates/perp.yml new file mode 100644 index 0000000000..1b4811ee04 --- /dev/null +++ b/src/templates/perp.yml @@ -0,0 +1,6 @@ +# how much price slippage tp allow +allowedSlippage: '2/100' + +# how long a transaction is valid in seconds. After time passes transactio will +# fail and gas will still be sent. +ttl: 600 \ No newline at end of file diff --git a/src/templates/polygon.yml b/src/templates/polygon.yml new file mode 100644 index 0000000000..ed2639dd8f --- /dev/null +++ b/src/templates/polygon.yml @@ -0,0 +1,17 @@ +# list the Polygon networks available to gateway +networks: + mainnet: + chainID: 137 + nodeURL: https://rpc.ankr.com/polygon + tokenListType: 'FILE' + tokenListSource: 'src/chains/polygon/polygon_tokens_mainnet.json' + nativeCurrencySymbol: 'MATIC' + mumbai: + chainID: 80001 + nodeURL: https://rpc.ankr.com/polygon_mumbai + tokenListType: 'FILE' + tokenListSource: 'src/chains/polygon/polygon_tokens_mumbai.json' + nativeCurrencySymbol: 'MATIC' + +manualGasPrice: 100 +gasLimitTransaction: 3000000 diff --git a/src/templates/quickswap.yml b/src/templates/quickswap.yml new file mode 100644 index 0000000000..80051a487e --- /dev/null +++ b/src/templates/quickswap.yml @@ -0,0 +1,16 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas used to estimate cost of a traderjoe trade. +gasLimitEstimate: 300000 + +# how long a trade is valid in seconds. After time passes traderjoe will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + mainnet: + routerAddress: '0xa5E0829CaCEd8fFDD4De3c43696c57F7D7A678ff' + mumbai: + routerAddress: '0x8954AfA98594b838bda56FE4C12a09D7739D179b' diff --git a/src/templates/ref.yml b/src/templates/ref.yml new file mode 100644 index 0000000000..18b2de0bb1 --- /dev/null +++ b/src/templates/ref.yml @@ -0,0 +1,16 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas allowed for a ref trade. +gasLimitEstimate: 2000000 + +# how long a trade is valid in seconds. After time passes ref will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + mainnet: + routerAddress: 'v2.ref-finance.near' + testnet: + routerAddress: 'ref-finance-101.testnet' diff --git a/src/templates/root.yml b/src/templates/root.yml new file mode 100644 index 0000000000..74976f195f --- /dev/null +++ b/src/templates/root.yml @@ -0,0 +1,109 @@ +version: 1 +configurations: + $namespace harmony: + configurationPath: harmony.yml + schemaPath: harmony-schema.json + + $namespace avalanche: + configurationPath: avalanche.yml + schemaPath: ethereum-schema.json + + $namespace database: + configurationPath: database.yml + schemaPath: database-schema.json + + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: ethereum-schema.json + + $namespace polygon: + configurationPath: polygon.yml + schemaPath: ethereum-schema.json + + $namespace ethereumGasStation: + configurationPath: ethereum-gas-station.yml + schemaPath: ethereum-gas-station-schema.json + + $namespace logging: + configurationPath: logging.yml + schemaPath: logging-schema.json + + $namespace ssl: + configurationPath: ssl.yml + schemaPath: ssl-schema.json + + $namespace defira: + configurationPath: defira.yml + schemaPath: defira-schema.json + + $namespace near: + configurationPath: near.yml + schemaPath: ethereum-schema.json + + $namespace pangolin: + configurationPath: pangolin.yml + schemaPath: pangolin-schema.json + + $namespace quickswap: + configurationPath: quickswap.yml + schemaPath: quickswap-schema.json + + $namespace perp: + configurationPath: perp.yml + schemaPath: perp-schema.json + + $namespace sushiswap: + configurationPath: sushiswap.yml + schemaPath: sushiswap-schema.json + + $namespace traderjoe: + configurationPath: traderjoe.yml + schemaPath: traderjoe-schema.json + + $namespace server: + configurationPath: server.yml + schemaPath: server-schema.json + + $namespace telemetry: + configurationPath: telemetry.yml + schemaPath: telemetry-schema.json + + $namespace uniswap: + configurationPath: uniswap.yml + schemaPath: uniswap-schema.json + + $namespace ref: + configurationPath: ref.yml + schemaPath: ref-schema.json + + $namespace openocean: + configurationPath: openocean.yml + schemaPath: openocean-schema.json + + $namespace defikingdoms: + configurationPath: defikingdoms.yml + schemaPath: defikingdoms-schema.json + + $namespace cosmos: + configurationPath: cosmos.yml + schemaPath: cosmos-schema.json + + $namespace cronos: + configurationPath: cronos.yml + schemaPath: ethereum-schema.json + + $namespace mad_meerkat: + configurationPath: mad_meerkat.yml + schemaPath: cronos-connector-schema.json + + $namespace vvs: + configurationPath: vvs.yml + schemaPath: cronos-connector-schema.json + + $namespace binance-smart-chain: + configurationPath: binance-smart-chain.yml + schemaPath: ethereum-schema.json + + $namespace pancakeswap: + configurationPath: pancakeswap.yml + schemaPath: pangolin-schema.json diff --git a/src/templates/server.yml b/src/templates/server.yml new file mode 100644 index 0000000000..93d4137ebb --- /dev/null +++ b/src/templates/server.yml @@ -0,0 +1,10 @@ +# The port to expose the gateway server on. +port: 15888 + +# The IPs allowed to access gateway. localhost is allowed by default. +ipWhitelist: [] + +unsafeDevModeWithHTTP: false + + +GMTOffset: +0800 diff --git a/src/templates/ssl.yml b/src/templates/ssl.yml new file mode 100644 index 0000000000..e5bfacf950 --- /dev/null +++ b/src/templates/ssl.yml @@ -0,0 +1,8 @@ +# need more details... +caCertificatePath: /usr/src/app/certs/ca_cert.pem + +# need more details... +certificatePath: /usr/src/app/certs/server_cert.pem + +# need more details... +keyPath: /usr/src/app/certs/server_key.pem diff --git a/src/templates/sushiswap.yml b/src/templates/sushiswap.yml new file mode 100644 index 0000000000..3196c83b33 --- /dev/null +++ b/src/templates/sushiswap.yml @@ -0,0 +1,26 @@ + +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas allowed for a unsiwap trade. +# TODO: find best values for sushi swap +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes sushiswap will not +# perform the trade, but the gas will still be sent. +ttl: 600 + +contractAddresses: + ethereum: + mainnet: + sushiswapRouterAddress: '0xd9e1cE17f2641f24aE83637ab66a2cca9C378B9F' + kovan: + sushiswapRouterAddress: '0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506' + ropsten: + sushiswapRouterAddress: '0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506' + binance-smart-chain: + mainnet: + sushiswapRouterAddress: '0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506' + testnet: + sushiswapRouterAddress: '0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506' \ No newline at end of file diff --git a/src/templates/telemetry.yml b/src/templates/telemetry.yml new file mode 100644 index 0000000000..d8e96575f4 --- /dev/null +++ b/src/templates/telemetry.yml @@ -0,0 +1,2 @@ +# If true it will collect data about API usage. +enabled: false diff --git a/src/templates/traderjoe.yml b/src/templates/traderjoe.yml new file mode 100644 index 0000000000..c1e6cc0532 --- /dev/null +++ b/src/templates/traderjoe.yml @@ -0,0 +1,16 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas allowed for a traderjoe trade. +gasLimitEstimate: 300000 + +# how long a trade is valid in seconds. After time passes traderjoe will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + fuji: + routerAddress: '0x60aE616a2155Ee3d9A68541Ba4544862310933d4' + avalanche: + routerAddress: '0x60aE616a2155Ee3d9A68541Ba4544862310933d4' diff --git a/src/templates/uniswap.yml b/src/templates/uniswap.yml new file mode 100644 index 0000000000..601c7aa3ba --- /dev/null +++ b/src/templates/uniswap.yml @@ -0,0 +1,37 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas used to estimate gasCost for a uniswap trade. +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes uniswap will not +# perform the trade, but the gas will still be sent. +ttl: 600 + +# For each swap, the maximum number of hops to consider. +# Note: More hops will increase latency of the algorithm. +maximumHops: 4 + +contractAddresses: + mainnet: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + kovan: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + goerli: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + ropsten: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + arbitrum_one: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + optimism: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + mumbai: + uniswapV3SmartOrderRouterAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + uniswapV3NftManagerAddress: '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' diff --git a/src/templates/vvs.yml b/src/templates/vvs.yml new file mode 100644 index 0000000000..2d30f1c92c --- /dev/null +++ b/src/templates/vvs.yml @@ -0,0 +1,14 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '1/100' + +# the maximum gas used to estimate gasCost for a VSS trade. +gasLimitEstimate: 150688 + +# how long a trade is valid in seconds. After time passes Mad Meerkat will not +# perform the trade, but the gas will still be spent. +ttl: 300 + +contractAddresses: + mainnet: + routerAddress: '0x145863Eb42Cf62847A6Ca784e6416C1682b1b2Ae' diff --git a/startup.sh b/startup.sh new file mode 100644 index 0000000000..1d264eddbf --- /dev/null +++ b/startup.sh @@ -0,0 +1,7 @@ +#!/bin/bash +node dist/src/index.js $1 + +while [ $? != 0 ]; do + echo "Gateway API server stopped unexpectedly. Restarting..." + node dist/src/index.js $1; +done \ No newline at end of file diff --git a/test-scripts/README.md b/test-scripts/README.md new file mode 100644 index 0000000000..af73803287 --- /dev/null +++ b/test-scripts/README.md @@ -0,0 +1,6 @@ +# gateway test scripts + +Make sure to properly setup your config files and add a wallet to use for testing. +Then set the environment variable `ETH_PUBLIC_KEY` to an added wallet. +Start a local instance of the gateway API with `yarn start`, and run the +test script with `yarn test:scripts`. diff --git a/test-scripts/cosmos.test.ts b/test-scripts/cosmos.test.ts new file mode 100644 index 0000000000..3488ecdd5f --- /dev/null +++ b/test-scripts/cosmos.test.ts @@ -0,0 +1,73 @@ +import 'jest-extended'; +import { + privateKey, + publicKey, +} from '../test/chains/cosmos/cosmos.validators.test'; +import { request } from './test.base'; + +// constants +const TOKENS = ['ATOM']; + +jest.setTimeout(300000); // run for 5 mins + +export const unitTests = async () => { + test('cosmos routes', async () => { + await cosmosTests(TOKENS); + }); +}; + +export const cosmosTests = async (tokens: string[] = []) => { + console.log('\nStarting Cosmos tests'); + console.log('***************************************************'); + console.log('Token symbols used in tests: ', tokens); + expect(tokens.length).toEqual(1); + + // call / + console.log('Checking status of gateway server...'); + const result = await request('GET', '/', {}); + // confirm expected response + console.log(result); + expect(result.status).toEqual('ok'); + + // Check wallet for public key is added + console.log(`Checking if wallet ${publicKey} has been added...`); + const wallets = await request('GET', '/wallet/', {}); + let alreadyAdded = false; + for (const chain of wallets) { + if (chain.chain === 'cosmos' && publicKey in chain.walletAddresses) { + console.log(`Wallet ${publicKey} has been already added...`); + alreadyAdded = true; + } + } + if (alreadyAdded === false) { + console.log(`Adding wallet ${publicKey}...`); + await request('POST', '/wallet/add', { + privateKey: privateKey, + chain: 'cosmos', + network: 'testnet', + }); + } + + // call /balances with invalid token symbol + // confirm expected error message + console.log('calling balances with invalid token symbols 15B and LLL...'); + const balancesResponse1 = await request('POST', '/cosmos/balances', { + address: publicKey, + tokenSymbols: ['15B', 'LLL'], + }); + expect(balancesResponse1).toBeUndefined(); + + // call /balances + console.log('Checking balances...'); + const balancesResponse = await request('POST', '/cosmos/balances', { + address: publicKey, + tokenSymbols: tokens, + }); + // confirm and save balances + const balances = balancesResponse.balances; + expect(parseFloat(balances.ATOM)).toBeGreaterThanOrEqual(0.0); +}; + +(async () => { + await unitTests(); +})(); diff --git a/test-scripts/ethereum.test.base.ts b/test-scripts/ethereum.test.base.ts new file mode 100644 index 0000000000..502d7aedd7 --- /dev/null +++ b/test-scripts/ethereum.test.base.ts @@ -0,0 +1,133 @@ +import 'jest-extended'; +import { request } from './test.base'; + +const ALLOWANCE = 5000000; + +let publicKey: string; +if (process.env.ETH_PUBLIC_KEY && process.env.ETH_PUBLIC_KEY !== '') { + publicKey = process.env.ETH_PUBLIC_KEY; +} else { + console.log( + 'Please define the env variable ETH_PUBLIC_KEY in order to run the tests.' + ); + process.exit(1); +} + +const sleep = (ms: number) => { + return new Promise((resolve) => setTimeout(resolve, ms)); +}; + +jest.setTimeout(300000); // run for 5 mins + +export const ethTests = async ( + connector: string = '', + tokens: string[] = [] +) => { + console.log('\nStarting ETH tests'); + console.log('***************************************************'); + console.log('Token symbols used in tests: ', tokens); + expect(tokens.length).toEqual(3); + + // Check wallet for public key is added + console.log('Checking wallet has been added...'); + const wallets = await request('GET', '/wallet/', {}); + console.log(wallets); + for (const chain of wallets) { + if (chain.chain === 'ethereum') + expect(chain.walletAddresses).toContain(publicKey); + } + + // call / + console.log('Checking status of gateway server...'); + const result = await request('GET', '/', {}); + // confirm expected response + console.log(result); + expect(result.status).toEqual('ok'); + + // call /balances + console.log('Checking balances...'); + const balancesResponse = await request('POST', '/eth/balances', { + tokenSymbols: tokens, + }); + // confirm and save balances + const balances = balancesResponse.balances; + console.log(balances); + expect(parseFloat(balances.ETH)).toBeGreaterThan(0); + + // call /balances with invalid token symbol + // confirm expected error message + console.log('calling balances with invalid token symbols ABC and XYZ...'); + const balancesResponse1 = await request('POST', '/eth/balances', { + tokenSymbols: ['ABC', 'XYZ'], + }); + expect(balancesResponse1).toBeUndefined(); + + // call /allowances + // confirm and save allowances + console.log('checking initial allowances...'); + const allowancesResponse1 = await request('POST', '/eth/allowances', { + tokenSymbols: tokens, + spender: connector, + }); + let allowances = allowancesResponse1.approvals; + console.log(allowances); + + for (const token of [tokens[0], tokens[1]]) { + // call /approve on each token + console.log(`Resetting allowance for ${token} to ${ALLOWANCE}...`); + const nonce = await request('POST', '/eth/nonce', {}); + console.log(`Nonce: ${nonce.nonce}`); + const approve1 = await request('POST', '/eth/approve', { + token: token, + spender: connector, + amount: ALLOWANCE.toString(), + nonce: nonce.nonce, + }); + console.log(approve1); + while (allowances[token] !== approve1.amount) { + console.log( + 'Waiting for atleast 1 block time (i.e 13 secs) to give time for approval to be mined.' + ); + await sleep(13000); + // confirm that allowance changed correctly + console.log('Rechecking allowances to confirm approval...'); + const allowancesResponse2 = await request('POST', '/eth/allowances', { + tokenSymbols: tokens, + spender: connector, + }); + allowances = allowancesResponse2.approvals; + console.log(allowances); + } + } + + // call /approve with invalid spender address + console.log('Trying to approve for invalid contract...'); + const approve3 = await request('POST', '/eth/approve', { + token: tokens[0], + spender: 'nill', + }); + console.log(approve3); + // confirm expected error message + expect(approve3).toBeUndefined(); + + // call /approve with invalid token symbol + console.log('Trying to approve invalid token ABC...'); + const approve4 = await request('POST', '/eth/approve', { + token: 'ABC', + spender: connector, + }); + console.log(approve4); + // confirm expected error message + expect(approve4).toBeUndefined(); + + // call /approve with invalid amount + console.log('Trying to approve invalid amount...'); + const approve5 = await request('POST', '/eth/approve', { + token: tokens[0], + connector: connector, + amount: 'number', + }); + console.log(approve5); + // confirm expected error message + expect(approve5).toBeUndefined(); +}; diff --git a/test-scripts/harmony.test.ts b/test-scripts/harmony.test.ts new file mode 100644 index 0000000000..5320ca2099 --- /dev/null +++ b/test-scripts/harmony.test.ts @@ -0,0 +1,176 @@ +import 'jest-extended'; +import { requestHarmony as request } from './test.base'; + +const ALLOWANCE = '5000000'; + +let publicKey: string; +if (process.env.ETH_PUBLIC_KEY && process.env.ETH_PUBLIC_KEY !== '') { + publicKey = process.env.ETH_PUBLIC_KEY; +} else { + console.log( + 'Please define the env variable ETH_PUBLIC_KEY in order to run the tests.' + ); + process.exit(1); +} + +const sleep = (ms: number) => { + return new Promise((resolve) => setTimeout(resolve, ms)); +}; + +jest.setTimeout(300000); // run for 5 mins + +export const unitTests = async () => { + test('harmony routes', async () => { + await harmonyTests(); + }); +}; + +const network = 'mainnet'; // Replace with `testnet` for testing on test net + +export const harmonyTests = async ( + connector: string = '0x1b02da8cb0d097eb8d57a175b88c7d8b47997506', // Sushiswap router address + tokens: string[] = ['WONE', 'USDC'] +) => { + console.log('\nStarting Harmony tests'); + console.log('***************************************************'); + console.log('Token symbols used in tests: ', tokens); + expect(tokens.length).toEqual(2); + + // Check wallet for public key is added + console.log('Checking wallet has been added...'); + const wallets = await request('GET', '/wallet', {}); + console.log(wallets); + for (const chain of wallets) { + if (chain.chain === 'harmony') + expect(chain.walletAddresses).toContain(publicKey); + } + + // call / + console.log('Checking status of gateway server...'); + const result = await request('GET', '/', {}); + // confirm expected response + console.log(result); + expect(result.status).toEqual('ok'); + + // call /balances + console.log('Checking balances...'); + const balancesResponse = await request('POST', '/network/balances', { + address: publicKey, + chain: 'harmony', + network, + tokenSymbols: tokens, + }); + // confirm and save balances + const balances = balancesResponse.balances; + console.log(balances); + expect(parseFloat(balances['WONE'])).toBeDefined(); + expect(parseFloat(balances['USDC'])).toBeDefined(); + + // call /balances with invalid token symbol + // confirm expected error message + console.log('calling balances with invalid token symbols ABC and XYZ...'); + const balancesResponse1 = await request('POST', '/network/balances', { + address: publicKey, + chain: 'harmony', + network, + tokenSymbols: ['ABC', 'XYZ'], + }); + expect(balancesResponse1).toBeUndefined(); + + // call /allowances + // confirm and save allowances + console.log('checking initial allowances...'); + const allowancesResponse1 = await request('POST', '/evm/allowances', { + address: publicKey, + chain: 'harmony', + network, + tokenSymbols: tokens, + spender: connector, + }); + let allowances = allowancesResponse1.approvals; + console.log(allowances); + + // TODO: For some reason, the approve amount is not working + + for (const token of [tokens[0], tokens[1]]) { + // call /approve on each token + console.log(`Resetting allowance for ${token} to ${ALLOWANCE}...`); + const nonce = await request('POST', '/evm/nonce', { + address: publicKey, + chain: 'harmony', + network, + }); + console.log(`Nonce: ${nonce.nonce}`); + const approve1 = await request('POST', '/evm/approve', { + address: publicKey, + chain: 'harmony', + network, + token: token, + spender: connector, + amount: ALLOWANCE, + nonce: nonce.nonce, + }); + console.log(approve1); + while (allowances[token] !== approve1.amount) { + console.log( + 'Waiting for atleast 1 block time (i.e 13 secs) to give time for approval to be mined.' + ); + await sleep(13000); + // confirm that allowance changed correctly + console.log('Rechecking allowances to confirm approval...'); + const allowancesResponse2 = await request('POST', '/evm/allowances', { + address: publicKey, + chain: 'harmony', + network, + tokenSymbols: tokens, + spender: connector, + }); + allowances = allowancesResponse2.approvals; + console.log(allowances); + } + } + + // call /approve with invalid spender address + console.log('Trying to approve for invalid contract...'); + const approve3 = await request('POST', '/evm/approve', { + address: publicKey, + chain: 'harmony', + network, + token: tokens[0], + spender: 'nill', + }); + console.log(approve3); + // confirm expected error message + expect(approve3).toBeUndefined(); + + // call /approve with invalid token symbol + console.log('Trying to approve invalid token ABC...'); + const approve4 = await request('POST', '/evm/approve', { + address: publicKey, + chain: 'harmony', + network, + token: 'ABC', + spender: connector, + }); + console.log(approve4); + // confirm expected error message + expect(approve4).toBeUndefined(); + + // call /approve with invalid amount + console.log('Trying to approve invalid amount...'); + const approve5 = await request('POST', '/evm/approve', { + address: publicKey, + chain: 'harmony', + network, + token: tokens[0], + connector: connector, + amount: 'number', + }); + console.log(approve5); + // confirm expected error message + expect(approve5).toBeUndefined(); +}; + +(async () => { + await unitTests(); +})(); diff --git a/test-scripts/test.base.ts b/test-scripts/test.base.ts new file mode 100644 index 0000000000..fc2e1815c1 --- /dev/null +++ b/test-scripts/test.base.ts @@ -0,0 +1,72 @@ +import fs = require('fs'); +import path = require('path'); +import https = require('https'); +import axios from 'axios'; +import { ConfigManagerV2 } from '../src/services/config-manager-v2'; + +type method = 'GET' | 'POST'; + +const confV2 = new ConfigManagerV2(path.join(__dirname, '../conf/root.yml')); +const certPath = path.dirname(confV2.get('ssl.certificatePath')); +const host = 'localhost'; +const port = confV2.get('server.port'); + +const httpsAgent = axios.create({ + httpsAgent: new https.Agent({ + ca: fs.readFileSync(certPath.concat('/ca_cert.pem'), { + encoding: 'utf-8', + }), + cert: fs.readFileSync(certPath.concat('/client_cert.pem'), { + encoding: 'utf-8', + }), + key: fs.readFileSync(certPath.concat('/client_key.pem'), { + encoding: 'utf-8', + }), + host: host, + port: port, + requestCert: true, + rejectUnauthorized: false, + }), +}); + +export const request = async ( + method: method, + path: string, + params: Record +) => { + try { + let response; + const gatewayAddress = `${ + ConfigManagerV2.getInstance().get('server.unsafeDevModeWithHTTP') + ? 'http://' + : 'https://' + }${host}:${port}`; + if (method === 'GET') { + response = await httpsAgent.get(gatewayAddress + path); + } else { + response = await httpsAgent.post(gatewayAddress + path, params); + } + return response.data; + } catch (err) { + console.log(`${method} ${path} - ${err}`); + } +}; + +export const requestHarmony = async ( + method: method, + path: string, + params: Record +) => { + try { + let response; + const gatewayAddress = `https://${host}:${port}`; + if (method === 'GET') { + response = await httpsAgent.get(gatewayAddress + path); + } else { + response = await httpsAgent.post(gatewayAddress + path, params); + } + return response.data; + } catch (err) { + console.log(`${method} ${path} - ${err}`); + } +}; diff --git a/test-scripts/uniswap.v2.test.ts b/test-scripts/uniswap.v2.test.ts new file mode 100644 index 0000000000..89556c1602 --- /dev/null +++ b/test-scripts/uniswap.v2.test.ts @@ -0,0 +1,124 @@ +import { ethTests } from './ethereum.test.base'; +import 'jest-extended'; +import { request } from './test.base'; + +// constants +const TOKENS = ['WETH', 'DAI', 'ETH']; +const AMOUNT_PRICE = 1; +const AMOUNT_TRADE = 0.01; +const SCALE_FACTOR = 1000; + +jest.setTimeout(300000); // run for 5 mins + +export const unitTests = async () => { + test('ethereum routes', async () => { + await ethTests('uniswap', TOKENS); + console.log('\nStarting Uniswap tests'); + console.log('***************************************************'); + // call / + const pair = `${TOKENS[0]}-${TOKENS[1]}`; + console.log(`Starting Uniswap v2 on pair ${pair}...`); + const root = await request('GET', '/eth/uniswap/', {}); + console.log(root); + + // price buy + console.log(`Checking buy price for ${pair}...`); + const buyPrice = await request('POST', '/eth/uniswap/price', { + base: TOKENS[0], + quote: TOKENS[1], + amount: AMOUNT_PRICE.toString(), + side: 'BUY', + }); + console.log(`Buy price: ${buyPrice.price}`); + + // price sell + console.log(`Checking sell price for ${pair}...`); + const sellPrice = await request('POST', '/eth/uniswap/price', { + base: TOKENS[0], + quote: TOKENS[1], + amount: AMOUNT_PRICE.toString(), + side: 'SELL', + }); + console.log(`Sell price: ${sellPrice.price}`); + + // trade buy + console.log( + `Executing buy trade on ${pair} with ${AMOUNT_TRADE} amount...` + ); + const buy = await request('POST', '/eth/uniswap/trade', { + base: TOKENS[0], + quote: TOKENS[1], + amount: AMOUNT_TRADE.toString(), + side: 'BUY', + }); + expect(buy.txHash).toBeDefined(); + console.log(`Buy hash - ${buy.txHash}`); + let txStatus = 0; + let tx1, tx2; + console.log(`Polling...`); + while (txStatus !== 1) { + tx1 = await request('POST', '/eth/poll', { txHash: buy.txHash }); + console.log(tx1); + txStatus = tx1.txStatus; + } + expect(tx1.txReceipt.status).toEqual(1); + + txStatus = 0; + + // trade sell + console.log( + `Executing sell trade on ${pair} with ${AMOUNT_TRADE} amount...` + ); + const sell = await request('POST', '/eth/uniswap/trade', { + base: TOKENS[0], + quote: TOKENS[1], + amount: AMOUNT_TRADE.toString(), + side: 'SELL', + }); + expect(sell.txHash).toBeDefined(); + console.log(`Sell hash - ${sell.txHash}`); + console.log(`Polling...`); + while (txStatus !== 1) { + tx2 = await request('POST', '/eth/poll', { txHash: sell.txHash }); + console.log(tx2); + txStatus = tx2.txStatus; + } + expect(tx2.txReceipt.status).toEqual(1); + + // add tests for extreme values of limitPrice - buy and sell + console.log( + `Testing for failure with ${ + buyPrice.price / SCALE_FACTOR + } buy limitPrice...` + ); + expect( + await request('POST', '/eth/uniswap/trade', { + base: TOKENS[0], + quote: TOKENS[1], + amount: '1', + side: 'BUY', + limitPrice: buyPrice.price / SCALE_FACTOR, + }) + ).toBeUndefined(); + + // add tests for extreme values of minimumSlippage + console.log( + `Testing for failure with ${ + sellPrice.price * SCALE_FACTOR + } sell limitPrice...` + ); + expect( + await request('POST', '/eth/uniswap/trade', { + base: TOKENS[0], + quote: TOKENS[1], + amount: '1', + side: 'SELL', + limitPrice: sellPrice.price * SCALE_FACTOR, + }) + ).toBeUndefined(); + }); +}; + +(async () => { + await unitTests(); +})(); diff --git a/test/amm/amm.validators.test.ts b/test/amm/amm.validators.test.ts new file mode 100644 index 0000000000..82ccfeb61b --- /dev/null +++ b/test/amm/amm.validators.test.ts @@ -0,0 +1,192 @@ +import { + invalidQuoteError, + validateQuote, + invalidBaseError, + validateBase, + invalidSideError, + validateSide, + invalidLimitPriceError, + validateLimitPrice, + invalidAllowedSlippageError, + validateAllowedSlippage, +} from '../../src/amm/amm.validators'; + +import { missingParameter } from '../../src/services/validators'; + +import 'jest-extended'; + +describe('validateQuote', () => { + it('valid when req.quote is a string', () => { + expect( + validateQuote({ + quote: 'DAI', + }) + ).toEqual([]); + + expect( + validateQuote({ + quote: 'WETH', + }) + ).toEqual([]); + }); + + it('return error when req.quote does not exist', () => { + expect( + validateQuote({ + hello: 'world', + }) + ).toEqual([missingParameter('quote')]); + }); + + it('return error when req.quote is invalid', () => { + expect( + validateQuote({ + quote: 123, + }) + ).toEqual([invalidQuoteError]); + }); +}); + +describe('validateBase', () => { + it('valid when req.base is a string', () => { + expect( + validateBase({ + base: 'DAI', + }) + ).toEqual([]); + + expect( + validateBase({ + base: 'WETH', + }) + ).toEqual([]); + }); + + it('return error when req.base does not exist', () => { + expect( + validateBase({ + hello: 'world', + }) + ).toEqual([missingParameter('base')]); + }); + + it('return error when req.base is invalid', () => { + expect( + validateBase({ + base: 123, + }) + ).toEqual([invalidBaseError]); + }); +}); + +describe('validateSide', () => { + it('valid when req.side is a string', () => { + expect( + validateSide({ + side: 'BUY', + }) + ).toEqual([]); + + expect( + validateSide({ + side: 'SELL', + }) + ).toEqual([]); + }); + + it('return error when req.side does not exist', () => { + expect( + validateSide({ + hello: 'world', + }) + ).toEqual([missingParameter('side')]); + }); + + it('return error when req.side is invalid', () => { + expect( + validateSide({ + side: 'comprar', + }) + ).toEqual([invalidSideError]); + }); +}); + +describe('validateLimitPrice', () => { + it('valid when req.limitPrice is a string', () => { + expect( + validateLimitPrice({ + limitPrice: '12000.123', + }) + ).toEqual([]); + + expect( + validateLimitPrice({ + limitPrice: '89425894', + }) + ).toEqual([]); + }); + + it('pass when req.limitPrice does not exist', () => { + expect( + validateLimitPrice({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.limitPrice is invalid', () => { + expect( + validateLimitPrice({ + limitPrice: 'comprar', + }) + ).toEqual([invalidLimitPriceError]); + }); +}); + +describe('validateAllowedSlippage', () => { + it('valid when req.allowedSlippage is a fraction string', () => { + expect( + validateAllowedSlippage({ + allowedSlippage: '1/100', + }) + ).toEqual([]); + + expect( + validateAllowedSlippage({ + allowedSlippage: '0/1', + }) + ).toEqual([]); + }); + + it('pass when req.allowedSlippage does not exist', () => { + expect( + validateAllowedSlippage({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.allowedSlippage is a number', () => { + expect( + validateAllowedSlippage({ + allowedSlippage: 100, + }) + ).toEqual([invalidAllowedSlippageError]); + }); + + it('return error when req.allowedSlippage is a non-fraction string', () => { + expect( + validateAllowedSlippage({ + allowedSlippage: 'hello', + }) + ).toEqual([invalidAllowedSlippageError]); + }); + + it('return error when req.allowedSlippage is a non-fraction number string', () => { + expect( + validateAllowedSlippage({ + allowedSlippage: '100', + }) + ).toEqual([invalidAllowedSlippageError]); + }); +}); diff --git a/test/app.test.ts b/test/app.test.ts new file mode 100644 index 0000000000..83ba274246 --- /dev/null +++ b/test/app.test.ts @@ -0,0 +1,37 @@ +jest.useFakeTimers(); +import { gatewayApp, swaggerDocument } from '../src/app'; +import { difference } from 'lodash'; + +describe('verify swagger docs', () => { + it('All routes should have swagger documentation', () => { + const documentedRoutes = Object.keys(swaggerDocument.paths).sort(); + + const allRoutes: any[] = []; + gatewayApp._router.stack.forEach(function (middleware: any) { + if (middleware.route) { + // routes registered directly on the gatewayApp + allRoutes.push(middleware.route.path); + } else if (middleware.name === 'router') { + const parentPath = middleware.regexp + .toString() + .split('?')[0] + .slice(2) + .replaceAll('\\', '') + .slice(0, -1); + // router middleware + middleware.handle.stack.forEach(function (handler: any) { + const route = handler.route; + if (route) { + route.path = `${parentPath}${route.path}`; + if (route.path.slice(-1) === '/') + route.path = route.path.slice(0, -1); + allRoutes.push(route.path); + } + }); + } + }); + allRoutes.sort(); + const routesNotDocumented = difference(allRoutes, documentedRoutes); + expect(routesNotDocumented).toEqual([]); + }); +}); diff --git a/test/chains/avalanche/avalanche.routes.test.ts b/test/chains/avalanche/avalanche.routes.test.ts new file mode 100644 index 0000000000..32cb12ed06 --- /dev/null +++ b/test/chains/avalanche/avalanche.routes.test.ts @@ -0,0 +1,379 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { + NETWORK_ERROR_CODE, + OUT_OF_GAS_ERROR_CODE, + UNKNOWN_ERROR_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_MESSAGE, + UNKNOWN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import * as transactionSuccesful from '../ethereum/fixtures/transaction-succesful.json'; +import * as transactionSuccesfulReceipt from '../ethereum/fixtures/transaction-succesful-receipt.json'; +import * as transactionOutOfGas from '../ethereum/fixtures/transaction-out-of-gas.json'; +import * as transactionOutOfGasReceipt from '../ethereum/fixtures/transaction-out-of-gas-receipt.json'; +import { Avalanche } from '../../../src/chains/avalanche/avalanche'; +let avalanche: Avalanche; + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +beforeAll(async () => { + avalanche = Avalanche.getInstance('fuji'); +}); + +afterAll(async () => { + await avalanche.close(); +}); + +afterEach(unpatch); + +const patchGetWallet = () => { + patch(avalanche, 'getWallet', () => { + return { + address, + }; + }); +}; + +const patchGetNonce = () => { + patch(avalanche.nonceManager, 'getNonce', () => 2); +}; + +const patchGetTokenBySymbol = () => { + patch(avalanche, 'getTokenBySymbol', () => { + return { + chainId: 43114, + address: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + decimals: 18, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + logoURI: + 'https://raw.githubusercontent.com/ava-labs/bridge-tokens/main/avalanche-tokens/0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7/logo.png', + }; + }); +}; + +const patchApproveERC20 = () => { + patch(avalanche, 'approveERC20', () => { + return { + type: 2, + chainId: 43114, + nonce: 115, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '100000' }, + to: '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9', // noqa: mock + v: 0, + r: '0xbeb9aa40028d79b9fdab108fcef5de635457a05f3a254410414c095b02c64643', // noqa: mock + s: '0x5a1506fa4b7f8b4f3826d8648f27ebaa9c0ee4bd67f569414b8cd8884c073100', // noqa: mock + from: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + confirmations: 0, + }; + }); +}; + +const patchGetERC20Allowance = () => { + patch(avalanche, 'getERC20Allowance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetNativeBalance = () => { + patch(avalanche, 'getNativeBalance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetERC20Balance = () => { + patch(avalanche, 'getERC20Balance', () => ({ value: 1, decimals: 3 })); +}; + +describe('POST /evm/nonce', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetNonce(); + + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'avalanche', + network: 'fuji', + address, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.nonce).toBe(2)); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'avalanche', + network: 'fuji', + address: 'da857cbda0ba96757fed842617a4', + }) + .expect(404); + }); +}); + +describe('POST /evm/approve', () => { + it('should return 200', async () => { + patchGetWallet(); + avalanche.getContract = jest.fn().mockReturnValue({ + address, + }); + patch(avalanche.nonceManager, 'getNonce', () => 115); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'avalanche', + network: 'fuji', + address, + spender: 'pangolin', + token: 'PNG', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(115); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'avalanche', + network: 'fuji', + address, + spender: 'pangolin', + token: 123, + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /evm/allowances', () => { + it('should return 200 asking for allowances', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + const spender = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + avalanche.getSpender = jest.fn().mockReturnValue(spender); + avalanche.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + patchGetERC20Allowance(); + + await request(gatewayApp) + .post(`/evm/allowances`) + .send({ + chain: 'avalanche', + network: 'fuji', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: spender, + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.spender).toEqual(spender)) + .expect((res) => expect(res.body.approvals.WETH).toEqual('0.001')) + .expect((res) => expect(res.body.approvals.DAI).toEqual('0.001')); + }); +}); + +describe('POST /network/balances', () => { + it('should return 200 asking for supported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + avalanche.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'avalanche', + network: 'fuji', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.balances.WETH).toBeDefined()) + .expect((res) => expect(res.body.balances.DAI).toBeDefined()); + }); +}); + +describe('POST /evm/cancel', () => { + it('should return 200', async () => { + // override getWallet (network call) + avalanche.getWallet = jest.fn().mockReturnValue({ + address, + }); + + avalanche.cancelTx = jest.fn().mockReturnValue({ + hash: '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77', // noqa: mock + }); + + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'avalanche', + network: 'fuji', + address, + nonce: 23, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.txHash).toEqual( + '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77' // noqa: mock + ); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'avalanche', + network: 'fuji', + address: '', + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /network/poll', () => { + it('should get a NETWORK_ERROR_CODE when the network is unavailable', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = 'NETWORK_ERROR'; + throw error; + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(NETWORK_ERROR_CODE); + expect(res.body.message).toEqual(NETWORK_ERROR_MESSAGE); + }); + + it('should get a UNKNOWN_ERROR_ERROR_CODE when an unknown error is thrown', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => { + throw new Error(); + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + }); + + it('should get an OUT of GAS error for failed out of gas transactions', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => 1); + patch(avalanche, 'getTransaction', () => transactionOutOfGas); + patch(avalanche, 'getTransactionReceipt', () => transactionOutOfGasReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(OUT_OF_GAS_ERROR_CODE); + expect(res.body.message).toEqual(OUT_OF_GAS_ERROR_MESSAGE); + }); + + it('should get a null in txReceipt for Tx in the mempool', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => 1); + patch(avalanche, 'getTransaction', () => transactionOutOfGas); + patch(avalanche, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toBeDefined(); + }); + + it('should get a null in txReceipt and txData for Tx that didnt reach the mempool and TxReceipt is null', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => 1); + patch(avalanche, 'getTransaction', () => null); + patch(avalanche, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toEqual(null); + }); + + it('should get txStatus = 1 for a succesful query', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => 1); + patch(avalanche, 'getTransaction', () => transactionSuccesful); + patch( + avalanche, + 'getTransactionReceipt', + () => transactionSuccesfulReceipt + ); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toBeDefined(); + expect(res.body.txData).toBeDefined(); + }); + + it('should get unknown error', async () => { + patch(avalanche, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = -32006; + throw error; + }); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'avalanche', + network: 'fuji', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + expect(res.body.message).toEqual(UNKNOWN_ERROR_MESSAGE); + }); +}); diff --git a/test/chains/avalanche/avalanche.test.ts b/test/chains/avalanche/avalanche.test.ts new file mode 100644 index 0000000000..c6c1259a13 --- /dev/null +++ b/test/chains/avalanche/avalanche.test.ts @@ -0,0 +1,56 @@ +jest.useFakeTimers(); +import { patch, unpatch } from '../../services/patch'; +import { Avalanche } from '../../../src/chains/avalanche/avalanche'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; +let avalanche: Avalanche; + +// Fake data for for testing +const TOKENS = [ + { + chainId: 11111, + address: '0x21cf0eB2E3Ab483a67C900b27dA8F34185991982', + decimals: 18, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + logoURI: + 'https://raw.githubusercontent.com/pangolindex/tokens/main/assets/11111/0x21cf0eB2E3Ab483a67C900b27dA8F34185991982/logo.png', + }, + { + chainId: 43114, + address: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + decimals: 18, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + logoURI: + 'https://raw.githubusercontent.com/pangolindex/tokens/main/assets/0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7/logo.png', + }, +]; + +beforeAll(async () => { + avalanche = Avalanche.getInstance('avalanche'); + // Return the mocked token list instead of getting the list from github + patch(avalanche, 'getTokenList', () => TOKENS); + patchEVMNonceManager(avalanche.nonceManager); + + await avalanche.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(avalanche.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await avalanche.close(); +}); + +describe('verify Pangolin storedTokenList', () => { + it('Should only return tokens in the chain', async () => { + const tokenList = avalanche.storedTokenList; + // Only one of them has chainId 43114 + expect(tokenList).toEqual([TOKENS[1]]); + }); +}); diff --git a/test/chains/avalanche/avalanche.validators.test.ts b/test/chains/avalanche/avalanche.validators.test.ts new file mode 100644 index 0000000000..2d68c949d9 --- /dev/null +++ b/test/chains/avalanche/avalanche.validators.test.ts @@ -0,0 +1,42 @@ +import { + validateSpender, + invalidSpenderError, +} from '../../../src/chains/avalanche/avalanche.validators'; + +import { missingParameter } from '../../../src/services/validators'; + +import 'jest-extended'; + +describe('validateSpender', () => { + it('valid when req.spender is a publicKey', () => { + expect( + validateSpender({ + spender: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it("valid when req.spender is a 'uniswap'", () => { + expect( + validateSpender({ + spender: 'pangolin', + }) + ).toEqual([]); + }); + + it('return error when req.spender does not exist', () => { + expect( + validateSpender({ + hello: 'world', + }) + ).toEqual([missingParameter('spender')]); + }); + + it('return error when req.spender is invalid', () => { + expect( + validateSpender({ + spender: 'world', + }) + ).toEqual([invalidSpenderError]); + }); +}); diff --git a/test/chains/avalanche/openocean/openocean.routes.test.ts b/test/chains/avalanche/openocean/openocean.routes.test.ts new file mode 100644 index 0000000000..6c9a8f90ff --- /dev/null +++ b/test/chains/avalanche/openocean/openocean.routes.test.ts @@ -0,0 +1,705 @@ +import request from 'supertest'; +import { Avalanche } from '../../../../src/chains/avalanche/avalanche'; +import { Openocean } from '../../../../src/connectors/openocean/openocean'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +import { patch, unpatch } from '../../../services/patch'; +import { gasCostInEthString } from '../../../../src/services/base'; +import { AmmRoutes } from '../../../../src/amm/amm.routes'; +import express from 'express'; +import { Express } from 'express-serve-static-core'; +let app: Express; +let avalanche: Avalanche; +let openocean: Openocean; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + + avalanche = Avalanche.getInstance('avalanche'); + patchEVMNonceManager(avalanche.nonceManager); + await avalanche.init(); + + openocean = Openocean.getInstance('avalanche', 'avalanche'); + await openocean.init(); + + app.use('/amm', AmmRoutes.router); +}); + +beforeEach(() => { + patchEVMNonceManager(avalanche.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await avalanche.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(avalanche, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchInit = () => { + patch(openocean, 'init', async () => { + return; + }); +}; + +const patchStoredTokenList = () => { + patch(avalanche, 'tokenList', () => { + return [ + { + chainId: 43114, + name: 'USDC', + symbol: 'USDC', + address: '0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E', + decimals: 6, + }, + { + chainId: 43114, + name: 'sAVAX', + symbol: 'sAVAX', + address: '0x2b2C81e08f1Af8835a78Bb2A90AE924ACE0eA4bE', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'USDC') { + return { + chainId: 43114, + name: 'USDC', + symbol: 'USDC', + address: '0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E', + decimals: 6, + }; + } else { + return { + chainId: 43114, + name: 'sAVAX', + symbol: 'sAVAX', + address: '0x2b2C81e08f1Af8835a78Bb2A90AE924ACE0eA4bE', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(openocean, 'getTokenByAddress', () => { + return { + chainId: 43114, + name: 'USDC', + symbol: 'USDC', + address: '0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E', + decimals: 6, + }; + }); +}; + +const patchGasPrice = () => { + patch(avalanche, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(openocean, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(openocean, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(avalanche.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(openocean, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'sAVAX', + base: 'USDC', + amount: '0.01', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('0.010000'); + expect(res.body.rawAmount).toEqual('10000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'sAVAX', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000'); + expect(res.body.rawAmount).toEqual('10000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'bDAI', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'bDAI', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'bDAI', + amount: '10.000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'bDAI', + amount: '10.000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(openocean, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'bDAI', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(openocean, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'bDAI', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'sAVAX', + base: 'USDC', + amount: '0.01', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'sAVAX', + base: 'USDC', + amount: '0.01', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'sAVAX', + base: 'USDC', + amount: '0.01', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'sAVAX', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'sAVAX', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'sAVAX', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'USDC') { + return { + chainId: 43114, + name: 'USDC', + symbol: 'USDC', + address: '0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E', + decimals: 6, + }; + } else { + return null; + } + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'USDC') { + return { + chainId: 43114, + name: 'USDC', + symbol: 'USDC', + address: '0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E', + decimals: 6, + }; + } else { + return null; + } + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'BITCOIN', + base: 'USDC', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'sAVAX', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'sAVAX', + base: 'USDC', + amount: '0.01', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'USDC', + base: 'sAVAX', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for BUY with price less than limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + quote: 'sAVAX', + base: 'USDC', + amount: '0.01', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/estimateGas', () => { + it('should return 200 for valid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'openocean', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('avalanche'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + gasCostInEthString(100, openocean.gasLimitEstimate) + ); + }); + }); + + it('should return 500 for invalid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'avalanche', + network: 'avalanche', + connector: 'sushiswap', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/avalanche/openocean/openocean.test.ts b/test/chains/avalanche/openocean/openocean.test.ts new file mode 100644 index 0000000000..24fd9a9068 --- /dev/null +++ b/test/chains/avalanche/openocean/openocean.test.ts @@ -0,0 +1,83 @@ +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +jest.useFakeTimers(); +jest.setTimeout(30000); +import { Openocean } from '../../../../src/connectors/openocean/openocean'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { Token } from '@uniswap/sdk'; +import { BigNumber } from 'ethers'; +import { Avalanche } from '../../../../src/chains/avalanche/avalanche'; + +let avalanche: Avalanche; +let openocean: Openocean; + +const USDC = new Token( + 43114, + '0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E', + 6, + 'USDC' +); +const WAVAX = new Token( + 43114, + '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + 18, + 'WAVAX' +); +const bDAI = new Token( + 43114, + '0x6807eD4369d9399847F306D7d835538915fA749d', + 18, + 'bDAI' +); + +beforeAll(async () => { + avalanche = Avalanche.getInstance('avalanche'); + patchEVMNonceManager(avalanche.nonceManager); + await avalanche.init(); + openocean = Openocean.getInstance('avalanche', 'avalanche'); + await openocean.init(); +}); + +describe('verify Openocean estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + const expectedTrade = await openocean.estimateSellTrade( + USDC, + WAVAX, + BigNumber.from((10 ** USDC.decimals).toString()) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + await expect(async () => { + await openocean.estimateSellTrade( + USDC, + bDAI, + BigNumber.from((10 ** USDC.decimals).toString()) + ); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify Openocean estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + const expectedTrade = await openocean.estimateBuyTrade( + USDC, + WAVAX, + BigNumber.from((10 ** WAVAX.decimals).toString()) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + await expect(async () => { + await openocean.estimateBuyTrade( + USDC, + bDAI, + BigNumber.from((10 ** bDAI.decimals).toString()) + ); + }).rejects.toThrow(UniswapishPriceError); + }); +}); diff --git a/test/chains/avalanche/pangolin/pangolin.routes.test.ts b/test/chains/avalanche/pangolin/pangolin.routes.test.ts new file mode 100644 index 0000000000..ca6b6da9d5 --- /dev/null +++ b/test/chains/avalanche/pangolin/pangolin.routes.test.ts @@ -0,0 +1,561 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../../services/patch'; +import { gatewayApp } from '../../../../src/app'; +import { Avalanche } from '../../../../src/chains/avalanche/avalanche'; +import { Pangolin } from '../../../../src/connectors/pangolin/pangolin'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let avalanche: Avalanche; +let pangolin: Pangolin; + +beforeAll(async () => { + avalanche = Avalanche.getInstance('fuji'); + patchEVMNonceManager(avalanche.nonceManager); + await avalanche.init(); + + pangolin = Pangolin.getInstance('avalanche', 'fuji'); + await pangolin.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(avalanche.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await avalanche.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(avalanche, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchStoredTokenList = () => { + patch(avalanche, 'tokenList', () => { + return [ + { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 43114, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + address: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'WAVAX', + symbol: 'WAVAX', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(pangolin, 'getTokenByAddress', () => { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(avalanche, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(pangolin, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(pangolin, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(avalanche.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(pangolin, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WETH', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(avalanche, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'BITCOIN', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for BUY with price less than limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'avalanche', + network: 'fuji', + connector: 'pangolin', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/avalanche/pangolin/pangolin.test.ts b/test/chains/avalanche/pangolin/pangolin.test.ts new file mode 100644 index 0000000000..29bd95ef5f --- /dev/null +++ b/test/chains/avalanche/pangolin/pangolin.test.ts @@ -0,0 +1,148 @@ +jest.useFakeTimers(); +import { Pangolin } from '../../../../src/connectors/pangolin/pangolin'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { + Fetcher, + Pair, + Percent, + Route, + Token, + TokenAmount, + Trade, + TradeType, +} from '@pangolindex/sdk'; +import { BigNumber } from 'ethers'; +import { Avalanche } from '../../../../src/chains/avalanche/avalanche'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let avalanche: Avalanche; +let pangolin: Pangolin; + +const WETH = new Token( + 43114, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); +const WAVAX = new Token( + 43114, + '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + 18, + 'WAVAX' +); + +beforeAll(async () => { + avalanche = Avalanche.getInstance('fuji'); + patchEVMNonceManager(avalanche.nonceManager); + await avalanche.init(); + + pangolin = Pangolin.getInstance('avalanche', 'fuji'); + await pangolin.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(avalanche.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await avalanche.close(); +}); + +const patchFetchPairData = () => { + patch(Fetcher, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000'), + 43114 + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WETH_WAVAX = new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000'), + 43114 + ); + const WAVAX_TO_WETH = new Route([WETH_WAVAX], WAVAX); + return [ + new Trade( + WAVAX_TO_WETH, + new TokenAmount(WAVAX, '1000000000000000'), + TradeType.EXACT_INPUT, + 43114 + ), + ]; + }); +}; + +describe('verify Pangolin estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await pangolin.estimateSellTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await pangolin.estimateSellTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify Pangolin estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await pangolin.estimateBuyTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await pangolin.estimateBuyTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = pangolin.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(new Percent('3', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = pangolin.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = pangolin.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); +}); diff --git a/test/chains/avalanche/traderjoe/traderjoe.test.ts b/test/chains/avalanche/traderjoe/traderjoe.test.ts new file mode 100644 index 0000000000..0c0308c5d3 --- /dev/null +++ b/test/chains/avalanche/traderjoe/traderjoe.test.ts @@ -0,0 +1,148 @@ +jest.useFakeTimers(); +import { Traderjoe } from '../../../../src/connectors/traderjoe/traderjoe'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { + Fetcher, + Pair, + Percent, + Route, + Token, + TokenAmount, + Trade, + TradeType, +} from '@traderjoe-xyz/sdk'; +import { BigNumber } from 'ethers'; +import { Avalanche } from '../../../../src/chains/avalanche/avalanche'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let avalanche: Avalanche; +let traderjoe: Traderjoe; + +const WETH = new Token( + 43114, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); +const WAVAX = new Token( + 43114, + '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + 18, + 'WAVAX' +); + +beforeAll(async () => { + avalanche = Avalanche.getInstance('fuji'); + patchEVMNonceManager(avalanche.nonceManager); + await avalanche.init(); + + traderjoe = Traderjoe.getInstance('avalanche', 'fuji'); + await traderjoe.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(avalanche.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await avalanche.close(); +}); + +const patchFetchPairData = () => { + patch(Fetcher, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000'), + 43114 + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WETH_WAVAX = new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000'), + 43114 + ); + const WAVAX_TO_WETH = new Route([WETH_WAVAX], WAVAX); + return [ + new Trade( + WAVAX_TO_WETH, + new TokenAmount(WAVAX, '1000000000000000'), + TradeType.EXACT_INPUT, + 43114 + ), + ]; + }); +}; + +describe('verify Traderjoe estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await traderjoe.estimateSellTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await traderjoe.estimateSellTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify Traderjoe estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await traderjoe.estimateBuyTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await traderjoe.estimateBuyTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = traderjoe.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(new Percent('3', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = traderjoe.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = traderjoe.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); +}); diff --git a/test/chains/binance-smart-chain/binance-smart-chain.routes.test.ts b/test/chains/binance-smart-chain/binance-smart-chain.routes.test.ts new file mode 100644 index 0000000000..990111a6ed --- /dev/null +++ b/test/chains/binance-smart-chain/binance-smart-chain.routes.test.ts @@ -0,0 +1,376 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { + NETWORK_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_CODE, + OUT_OF_GAS_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE, + UNKNOWN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import * as transactionSuccesful from '../ethereum/fixtures/transaction-succesful.json'; +import * as transactionSuccesfulReceipt from '../ethereum//fixtures/transaction-succesful-receipt.json'; +import * as transactionOutOfGas from '../ethereum//fixtures/transaction-out-of-gas.json'; +import * as transactionOutOfGasReceipt from '../ethereum/fixtures/transaction-out-of-gas-receipt.json'; +import { BinanceSmartChain } from '../../../src/chains/binance-smart-chain/binance-smart-chain'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; + +let bsc: BinanceSmartChain; + +beforeAll(async () => { + bsc = BinanceSmartChain.getInstance('testnet'); + + patchEVMNonceManager(bsc.nonceManager); + + await bsc.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(bsc.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await bsc.close(); +}); + +const address: string = '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD'; + +const patchGetWallet = () => { + patch(bsc, 'getWallet', () => { + return { + address, + }; + }); +}; + +const patchGetNonce = () => { + patch(bsc.nonceManager, 'getNonce', () => 0); +}; + +const patchGetTokenBySymbol = () => { + patch(bsc, 'getTokenBySymbol', () => { + return { + chainId: 97, + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + name: 'WBNB Token', + symbol: 'WBNB', + logoURI: + 'https://exchange.pancakeswap.finance/images/coins/0xbb4cdb9cbd36b01bd1cbaebf2de08d9173bc095c.png', + }; + }); +}; + +const patchApproveERC20 = () => { + patch(bsc, 'approveERC20', () => { + return { + type: 2, + chainId: 97, + nonce: 0, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '66763' }, + to: '0x8babbb98678facc7342735486c851abd7a0d17ca', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + v: 229, + r: '0x8800b16cbc6d468acad057dd5f724944d6aa48543cd90472e28dd5c6e90268b1', // noqa: mock + s: '0x662ed86bb86fb40911738ab67785f6e6c76f1c989d977ca23c504ef7a4796d08', // noqa: mock + from: '0x242532ebdfcc760f2ddfe8378eb51f5f847ce5bd', + confirmations: 98, + }; + }); +}; + +const patchGetERC20Allowance = () => { + patch(bsc, 'getERC20Allowance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetNativeBalance = () => { + patch(bsc, 'getNativeBalance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetERC20Balance = () => { + patch(bsc, 'getERC20Balance', () => ({ value: 1, decimals: 3 })); +}; + +describe('POST /evm/approve', () => { + it('should return 200', async () => { + patchGetWallet(); + bsc.getContract = jest.fn().mockReturnValue({ + address, + }); + patchGetNonce(); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address, + spender: address, + token: 'BNB', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(0); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address, + spender: address, + token: 123, + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /evm/nonce', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetNonce(); + + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.nonce).toBe(0)); + }); +}); + +describe('POST /evm/allowances', () => { + it('should return 200 asking for allowances', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + const spender = '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD'; + bsc.getSpender = jest.fn().mockReturnValue(spender); + bsc.getContract = jest.fn().mockReturnValue({ + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', + }); + patchGetERC20Allowance(); + + await request(gatewayApp) + .post(`/evm/allowances`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', + spender: spender, + tokenSymbols: ['BNB', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.spender).toEqual(spender)) + .expect((res) => expect(res.body.approvals.BNB).toEqual('0.001')) + .expect((res) => expect(res.body.approvals.DAI).toEqual('0.001')); + }); +}); + +describe('POST /network/balances', () => { + it('should return 200 asking for supported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + bsc.getContract = jest.fn().mockReturnValue({ + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.balances.WETH).toBeDefined()) + .expect((res) => expect(res.body.balances.DAI).toBeDefined()); + }); +}); + +describe('POST /evm/cancel', () => { + it('should return 200', async () => { + // override getWallet (network call) + bsc.getWallet = jest.fn().mockReturnValue({ + address, + }); + + bsc.cancelTx = jest.fn().mockReturnValue({ + hash: '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77', // noqa: mock + }); + + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address, + nonce: 23, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.txHash).toEqual( + '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77' // noqa: mock + ); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + address: '', + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /network/poll', () => { + it('should get a NETWORK_ERROR_CODE when the network is unavailable', async () => { + patch(bsc, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = 'NETWORK_ERROR'; + throw error; + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(NETWORK_ERROR_CODE); + expect(res.body.message).toEqual(NETWORK_ERROR_MESSAGE); + }); + + it('should get a UNKNOWN_ERROR_ERROR_CODE when an unknown error is thrown', async () => { + patch(bsc, 'getCurrentBlockNumber', () => { + throw new Error(); + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + }); + + it('should get an OUT of GAS error for failed out of gas transactions', async () => { + patch(bsc, 'getCurrentBlockNumber', () => 1); + patch(bsc, 'getTransaction', () => transactionOutOfGas); + patch(bsc, 'getTransactionReceipt', () => transactionOutOfGasReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(OUT_OF_GAS_ERROR_CODE); + expect(res.body.message).toEqual(OUT_OF_GAS_ERROR_MESSAGE); + }); + + it('should get a null in txReceipt for Tx in the mempool', async () => { + patch(bsc, 'getCurrentBlockNumber', () => 1); + patch(bsc, 'getTransaction', () => transactionOutOfGas); + patch(bsc, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toBeDefined(); + }); + + it('should get a null in txReceipt and txData for Tx that didnt reach the mempool and TxReceipt is null', async () => { + patch(bsc, 'getCurrentBlockNumber', () => 1); + patch(bsc, 'getTransaction', () => null); + patch(bsc, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toEqual(null); + }); + + it('should get txStatus = 1 for a succesful query', async () => { + patch(bsc, 'getCurrentBlockNumber', () => 1); + patch(bsc, 'getTransaction', () => transactionSuccesful); + patch(bsc, 'getTransactionReceipt', () => transactionSuccesfulReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toBeDefined(); + expect(res.body.txData).toBeDefined(); + }); + + it('should get unknown error', async () => { + patch(bsc, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = -32006; + throw error; + }); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'binance-smart-chain', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + expect(res.body.message).toEqual(UNKNOWN_ERROR_MESSAGE); + }); +}); diff --git a/test/chains/binance-smart-chain/pancakeswap/pancakeswap.routes.test.ts b/test/chains/binance-smart-chain/pancakeswap/pancakeswap.routes.test.ts new file mode 100644 index 0000000000..f67cdd096a --- /dev/null +++ b/test/chains/binance-smart-chain/pancakeswap/pancakeswap.routes.test.ts @@ -0,0 +1,561 @@ +import request from 'supertest'; +import { gatewayApp } from '../../../../src/app'; +import { BinanceSmartChain } from '../../../../src/chains/binance-smart-chain/binance-smart-chain'; +import { PancakeSwap } from '../../../../src/connectors/pancakeswap/pancakeswap'; +import { patch, unpatch } from '../../../services/patch'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let bsc: BinanceSmartChain; +let pancakeswap: PancakeSwap; + +beforeAll(async () => { + bsc = BinanceSmartChain.getInstance('testnet'); + patchEVMNonceManager(bsc.nonceManager); + await bsc.init(); + pancakeswap = PancakeSwap.getInstance('binance-smart-chain', 'testnet'); + await pancakeswap.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(bsc.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await bsc.close(); +}); + +const address: string = '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD'; + +const patchGetWallet = () => { + patch(bsc, 'getWallet', () => { + return { + address: address, + }; + }); +}; + +const patchStoredTokenList = () => { + patch(bsc, 'tokenList', () => { + return [ + { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }, + { + chainId: 97, + name: 'DAI', + symbol: 'DAI', + address: '0x8a9424745056Eb399FD19a0EC26A14316684e274', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(bsc, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WBNB') { + return { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }; + } else { + return { + chainId: 97, + name: 'DAI', + symbol: 'DAI', + address: '0x8a9424745056Eb399FD19a0EC26A14316684e274', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(pancakeswap, 'getTokenByAddress', () => { + return { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(bsc, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(pancakeswap, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(pancakeswap, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(bsc.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(pancakeswap, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(bsc, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WBNB') { + return { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DOGE', + base: 'WBNB', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(bsc, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WBNB') { + return { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(bsc, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WBNB') { + return { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'WBNB', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(bsc, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WBNB') { + return { + chainId: 97, + name: 'WBNB', + symbol: 'WBNB', + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'BITCOIN', + base: 'WBNB', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for BUY with price less than limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'binance-smart-chain', + network: 'testnet', + connector: 'pancakeswap', + quote: 'DAI', + base: 'WBNB', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/binance-smart-chain/pancakeswap/pancakeswap.test.ts b/test/chains/binance-smart-chain/pancakeswap/pancakeswap.test.ts new file mode 100644 index 0000000000..9099212b9e --- /dev/null +++ b/test/chains/binance-smart-chain/pancakeswap/pancakeswap.test.ts @@ -0,0 +1,141 @@ +jest.useFakeTimers(); +import { + Fetcher, + Pair, + Percent, + Route, + Token, + TokenAmount, + Trade, + TradeType, +} from '@pancakeswap/sdk'; +import { BigNumber } from 'ethers'; +import { BinanceSmartChain } from '../../../../src/chains/binance-smart-chain/binance-smart-chain'; +import { PancakeSwap } from '../../../../src/connectors/pancakeswap/pancakeswap'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +import { patch, unpatch } from '../../../services/patch'; + +let bsc: BinanceSmartChain; +let pancakeswap: PancakeSwap; + +const WBNB = new Token( + 97, + '0xae13d989dac2f0debff460ac112a837c89baa7cd', + 18, + 'WBNB' +); +const DAI = new Token( + 97, + '0x8a9424745056Eb399FD19a0EC26A14316684e274', + 18, + 'DAI' +); + +beforeAll(async () => { + bsc = BinanceSmartChain.getInstance('testnet'); + patchEVMNonceManager(bsc.nonceManager); + await bsc.init(); + pancakeswap = PancakeSwap.getInstance('binance-smart-chain', 'testnet'); + await pancakeswap.init(); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await bsc.close(); +}); + +const patchFetchPairData = () => { + patch(Fetcher, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WBNB, '2000000000000000000'), + new TokenAmount(DAI, '1000000000000000000') + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WBNB_DAI = new Pair( + new TokenAmount(WBNB, '2000000000000000000'), + new TokenAmount(DAI, '1000000000000000000') + ); + const DAI_TO_WBNB = new Route([WBNB_DAI], DAI); + return [ + new Trade( + DAI_TO_WBNB, + new TokenAmount(DAI, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify PancakeSwap estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await pancakeswap.estimateSellTrade( + WBNB, + DAI, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await pancakeswap.estimateSellTrade(WBNB, DAI, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify PancakeSwap estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await pancakeswap.estimateBuyTrade( + WBNB, + DAI, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await pancakeswap.estimateBuyTrade(WBNB, DAI, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = pancakeswap.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(new Percent('3', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = pancakeswap.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = pancakeswap.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); +}); diff --git a/test/chains/cosmos/cosmos.routes.test.ts b/test/chains/cosmos/cosmos.routes.test.ts new file mode 100644 index 0000000000..bd9cccf285 --- /dev/null +++ b/test/chains/cosmos/cosmos.routes.test.ts @@ -0,0 +1,127 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { publicKey } from './cosmos.validators.test'; +import * as getTransactionData from './fixtures/getTransaction.json'; +import { BigNumber } from 'ethers'; +import { Cosmos } from '../../../src/chains/cosmos/cosmos'; +const { decodeTxRaw } = require('@cosmjs/proto-signing'); + +let cosmos: Cosmos; + +const tokens = ['ATOM', 'AXS']; + +beforeAll(async () => { + cosmos = Cosmos.getInstance('testnet'); + await cosmos.init(); +}); + +afterEach(() => unpatch()); + +describe('GET /cosmos', () => { + it('should return 200', async () => { + await request(gatewayApp) + .get(`/cosmos`) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.connection).toBe(true)) + .expect((res) => expect(res.body.rpcUrl).toBe(cosmos.rpcUrl)); + }); +}); + +const patchGetBalances = () => { + patch(cosmos, 'getBalances', () => { + return { + [tokens[0]]: { value: BigNumber.from(228293), decimals: 9 }, + [tokens[1]]: { value: BigNumber.from(300003), decimals: 9 }, + }; + }); +}; + +const patchGetWallet = () => { + patch(cosmos, 'getWallet', () => { + return { + address: publicKey, + prefix: 'cosmos', + }; + }); +}; + +describe('POST /cosmos/balances', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetBalances(); + + await request(gatewayApp) + .post(`/cosmos/balances`) + .send({ address: publicKey, tokenSymbols: tokens, network: cosmos.chain }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.network).toBe(cosmos.chain)) + .expect((res) => expect(res.body.timestamp).toBeNumber()) + .expect((res) => expect(res.body.latency).toBeNumber()) + .expect((res) => + expect(res.body.balances).toEqual({ + [tokens[0]]: '0.000228293', + [tokens[1]]: '0.000300003', + }) + ); + }); + + it('should return 500 when asking for an unsupported token', async () => { + patchGetWallet(); + patchGetBalances(); + + await request(gatewayApp) + .post(`/cosmos/balances`) + .send({ + address: publicKey, + tokenSymbols: ['AXSS'], + network: cosmos.chain, + }) + .expect(500); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp).post(`/cosmos/balances`).send({}).expect(404); + }); +}); + +const CurrentBlockNumber = 11829933; +const patchGetCurrentBlockNumber = () => { + patch(cosmos, 'getCurrentBlockNumber', () => CurrentBlockNumber); +}; + +const patchGetTransaction = () => { + patch(cosmos, 'getTransaction', () => getTransactionData); +}; + +const txHash = + 'F499E2C489FAF5C8E575650666EE8934963DF15E7850E710179BB4C00713C190'; // noqa: mock + +describe('POST /cosmos/poll', () => { + it('should return 200', async () => { + patchGetCurrentBlockNumber(); + patchGetTransaction(); + + await request(gatewayApp) + .post(`/cosmos/poll`) + .send({ + txHash, + network: cosmos.chain, + }) + .expect('Content-Type', /json/) + .expect((res) => expect(res.body.network).toBe(cosmos.chain)) + .expect(200) + .expect((res) => expect(res.body.timestamp).toBeNumber()) + .expect((res) => expect(res.body.currentBlock).toBe(CurrentBlockNumber)) + .expect((res) => expect(res.body.txHash).toBe(txHash)) + .expect((res) => + expect(res.body.txData).toEqual(decodeTxRaw(getTransactionData.tx)) + ); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp).post(`/cosmos/poll`).send({}).expect(404); + }); +}); diff --git a/test/chains/cosmos/cosmos.validators.test.ts b/test/chains/cosmos/cosmos.validators.test.ts new file mode 100644 index 0000000000..d4723bf852 --- /dev/null +++ b/test/chains/cosmos/cosmos.validators.test.ts @@ -0,0 +1,51 @@ +import { + invalidCosmosAddressError, + isValidCosmosAddress, + validatePublicKey, +} from '../../../src/chains/cosmos/cosmos.validators'; +import { missingParameter } from '../../../src/services/validators'; +import 'jest-extended'; + +export const publicKey = 'cosmos1pc8m5m7n0z8xe7sx2tawkvc0v6qkjql83js0dr'; +export const privateKey = + 'b6dd181dfa0023013b2479c109e483cb8dc3c20d6fdae6b2443be147c11e5220'; // noqa: mock + +describe('isValidCosmosAddress', () => { + it('pass against a well formed public key', () => { + expect(isValidCosmosAddress(publicKey)).toEqual(true); + }); + + it('fail against a string that is too short', () => { + expect(isValidCosmosAddress(publicKey.substring(2))).toEqual(false); + }); + + it('fail against a string that is too long', () => { + expect(isValidCosmosAddress(publicKey + 1)).toEqual(false); + }); +}); + +describe('validatePublicKey', () => { + it('valid when req.publicKey is a publicKey', () => { + expect( + validatePublicKey({ + address: publicKey, + }) + ).toEqual([]); + }); + + it('return error when req.publicKey does not exist', () => { + expect( + validatePublicKey({ + hello: 'world', + }) + ).toEqual([missingParameter('address')]); + }); + + it('return error when req.publicKey is invalid', () => { + expect( + validatePublicKey({ + address: 'world', + }) + ).toEqual([invalidCosmosAddressError]); + }); +}); diff --git a/test/chains/cosmos/fixtures/getTransaction.json b/test/chains/cosmos/fixtures/getTransaction.json new file mode 100644 index 0000000000..d901a137f6 --- /dev/null +++ b/test/chains/cosmos/fixtures/getTransaction.json @@ -0,0 +1 @@ +{"height":11829902,"hash":"43785B183B154C3701CD62C07187CBFBE0A938B27D032094FBE9F9FA288BC6ED","code":0,"rawLog":"[{\"events\":[{\"type\":\"coin_received\",\"attributes\":[{\"key\":\"receiver\",\"value\":\"cosmos1e4l5lg68vl6r85zcemhryy6hyjwsw59c740p8u\"},{\"key\":\"amount\",\"value\":\"415432uatom\"}]},{\"type\":\"coin_spent\",\"attributes\":[{\"key\":\"spender\",\"value\":\"cosmos1jv65s3grqf6v6jl3dp4t6c9t9rk99cd88lyufl\"},{\"key\":\"amount\",\"value\":\"415432uatom\"}]},{\"type\":\"message\",\"attributes\":[{\"key\":\"action\",\"value\":\"/cosmos.distribution.v1beta1.MsgWithdrawDelegatorReward\"},{\"key\":\"sender\",\"value\":\"cosmos1jv65s3grqf6v6jl3dp4t6c9t9rk99cd88lyufl\"},{\"key\":\"module\",\"value\":\"distribution\"},{\"key\":\"sender\",\"value\":\"cosmos1e4l5lg68vl6r85zcemhryy6hyjwsw59c740p8u\"}]},{\"type\":\"transfer\",\"attributes\":[{\"key\":\"recipient\",\"value\":\"cosmos1e4l5lg68vl6r85zcemhryy6hyjwsw59c740p8u\"},{\"key\":\"sender\",\"value\":\"cosmos1jv65s3grqf6v6jl3dp4t6c9t9rk99cd88lyufl\"},{\"key\":\"amount\",\"value\":\"415432uatom\"}]},{\"type\":\"withdraw_rewards\",\"attributes\":[{\"key\":\"amount\",\"value\":\"415432uatom\"},{\"key\":\"validator\",\"value\":\"cosmosvaloper1fsg635n5vgc7jazz9sx5725wnc3xqgr7awxaag\"}]}]}]","tx":{"0":10,"1":163,"2":1,"3":10,"4":160,"5":1,"6":10,"7":55,"8":47,"9":99,"10":111,"11":115,"12":109,"13":111,"14":115,"15":46,"16":100,"17":105,"18":115,"19":116,"20":114,"21":105,"22":98,"23":117,"24":116,"25":105,"26":111,"27":110,"28":46,"29":118,"30":49,"31":98,"32":101,"33":116,"34":97,"35":49,"36":46,"37":77,"38":115,"39":103,"40":87,"41":105,"42":116,"43":104,"44":100,"45":114,"46":97,"47":119,"48":68,"49":101,"50":108,"51":101,"52":103,"53":97,"54":116,"55":111,"56":114,"57":82,"58":101,"59":119,"60":97,"61":114,"62":100,"63":18,"64":101,"65":10,"66":45,"67":99,"68":111,"69":115,"70":109,"71":111,"72":115,"73":49,"74":101,"75":52,"76":108,"77":53,"78":108,"79":103,"80":54,"81":56,"82":118,"83":108,"84":54,"85":114,"86":56,"87":53,"88":122,"89":99,"90":101,"91":109,"92":104,"93":114,"94":121,"95":121,"96":54,"97":104,"98":121,"99":106,"100":119,"101":115,"102":119,"103":53,"104":57,"105":99,"106":55,"107":52,"108":48,"109":112,"110":56,"111":117,"112":18,"113":52,"114":99,"115":111,"116":115,"117":109,"118":111,"119":115,"120":118,"121":97,"122":108,"123":111,"124":112,"125":101,"126":114,"127":49,"128":102,"129":115,"130":103,"131":54,"132":51,"133":53,"134":110,"135":53,"136":118,"137":103,"138":99,"139":55,"140":106,"141":97,"142":122,"143":122,"144":57,"145":115,"146":120,"147":53,"148":55,"149":50,"150":53,"151":119,"152":110,"153":99,"154":51,"155":120,"156":113,"157":103,"158":114,"159":55,"160":97,"161":119,"162":120,"163":97,"164":97,"165":103,"166":18,"167":103,"168":10,"169":80,"170":10,"171":70,"172":10,"173":31,"174":47,"175":99,"176":111,"177":115,"178":109,"179":111,"180":115,"181":46,"182":99,"183":114,"184":121,"185":112,"186":116,"187":111,"188":46,"189":115,"190":101,"191":99,"192":112,"193":50,"194":53,"195":54,"196":107,"197":49,"198":46,"199":80,"200":117,"201":98,"202":75,"203":101,"204":121,"205":18,"206":35,"207":10,"208":33,"209":3,"210":120,"211":171,"212":247,"213":204,"214":94,"215":113,"216":116,"217":105,"218":24,"219":78,"220":111,"221":14,"222":99,"223":19,"224":173,"225":248,"226":235,"227":83,"228":144,"229":210,"230":208,"231":99,"232":221,"233":29,"234":216,"235":53,"236":134,"237":224,"238":207,"239":144,"240":78,"241":236,"242":18,"243":4,"244":10,"245":2,"246":8,"247":1,"248":24,"249":33,"250":18,"251":19,"252":10,"253":13,"254":10,"255":5,"256":117,"257":97,"258":116,"259":111,"260":109,"261":18,"262":4,"263":49,"264":48,"265":48,"266":48,"267":16,"268":160,"269":194,"270":30,"271":26,"272":64,"273":104,"274":84,"275":138,"276":51,"277":234,"278":178,"279":225,"280":249,"281":173,"282":23,"283":107,"284":22,"285":60,"286":218,"287":27,"288":215,"289":147,"290":212,"291":187,"292":134,"293":95,"294":144,"295":146,"296":58,"297":29,"298":244,"299":154,"300":29,"301":176,"302":248,"303":157,"304":209,"305":24,"306":45,"307":86,"308":11,"309":110,"310":233,"311":139,"312":142,"313":145,"314":56,"315":182,"316":58,"317":59,"318":33,"319":195,"320":10,"321":156,"322":185,"323":85,"324":73,"325":56,"326":34,"327":147,"328":52,"329":168,"330":230,"331":166,"332":62,"333":12,"334":56,"335":94,"336":31},"gasUsed":116639,"gasWanted":500000} \ No newline at end of file diff --git a/test/chains/cronos/cronos.routes.test.ts b/test/chains/cronos/cronos.routes.test.ts new file mode 100644 index 0000000000..26338cb01d --- /dev/null +++ b/test/chains/cronos/cronos.routes.test.ts @@ -0,0 +1,371 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { + NETWORK_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_CODE, + OUT_OF_GAS_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE, + UNKNOWN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import * as transactionSuccesful from '../ethereum/fixtures/transaction-succesful.json'; +import * as transactionSuccesfulReceipt from '../ethereum/fixtures/transaction-succesful-receipt.json'; +import * as transactionOutOfGas from '../ethereum/fixtures/transaction-out-of-gas.json'; +import * as transactionOutOfGasReceipt from '../ethereum/fixtures/transaction-out-of-gas-receipt.json'; +import { Cronos } from '../../../src/chains/cronos/cronos'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; + +let cronos: Cronos; +const address: string = '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD'; // noqa: mock + +beforeAll(async () => { + cronos = Cronos.getInstance('testnet'); + patchEVMNonceManager(cronos.nonceManager); + await cronos.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(cronos.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await cronos.close(); +}); + +const patchGetWallet = () => { + patch(cronos, 'getWallet', () => { + return { + address, + }; + }); +}; + +const patchGetNonce = () => { + patch(cronos.nonceManager, 'getNonce', () => 0); +}; + +const patchGetTokenBySymbol = () => { + patch(cronos, 'getTokenBySymbol', () => { + return { + chainId: 25, + address: '0xae13d989dac2f0debff460ac112a837c89baa7cd', + decimals: 18, + name: 'WCRON Token', + symbol: 'WCRON', + }; + }); +}; + +const patchApproveERC20 = () => { + patch(cronos, 'approveERC20', () => { + return { + type: 2, + chainId: 25, + nonce: 0, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '66763' }, + to: '0x8babbb98678facc7342735486c851abd7a0d17ca', // noqa: mock + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + v: 229, + r: '0x8800b16cbc6d468acad057dd5f724944d6aa48543cd90472e28dd5c6e90268b1', // noqa: mock + s: '0x662ed86bb86fb40911738ab67785f6e6c76f1c989d977ca23c504ef7a4796d08', // noqa: mock + from: '0x242532ebdfcc760f2ddfe8378eb51f5f847ce5bd', // noqa: mock + confirmations: 98, + }; + }); +}; + +const patchGetERC20Allowance = () => { + patch(cronos, 'getERC20Allowance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetNativeBalance = () => { + patch(cronos, 'getNativeBalance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetERC20Balance = () => { + patch(cronos, 'getERC20Balance', () => ({ value: 1, decimals: 3 })); +}; + +describe('POST /evm/approve', () => { + it('should return 200', async () => { + patchGetWallet(); + cronos.getContract = jest.fn().mockReturnValue({ + address, + }); + patchGetNonce(); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'cronos', + network: 'testnet', + address, + spender: address, + token: 'BNB', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(0); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'cronos', + network: 'testnet', + address, + spender: address, + token: 123, + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /evm/nonce', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetNonce(); + + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'cronos', + network: 'testnet', + address, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.nonce).toBe(0)); + }); +}); + +describe('POST /evm/allowances', () => { + it('should return 200 asking for allowances', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + const spender = '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD'; // noqa: mock + cronos.getSpender = jest.fn().mockReturnValue(spender); + cronos.getContract = jest.fn().mockReturnValue({ + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', // noqa: mock + }); + patchGetERC20Allowance(); + + await request(gatewayApp) + .post(`/evm/allowances`) + .send({ + chain: 'cronos', + network: 'testnet', + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', // noqa: mock + spender: spender, + tokenSymbols: ['BNB', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.spender).toEqual(spender)) + .expect((res) => expect(res.body.approvals.BNB).toEqual('0.001')) + .expect((res) => expect(res.body.approvals.DAI).toEqual('0.001')); + }); +}); + +describe('POST /network/balances', () => { + it('should return 200 asking for supported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + cronos.getContract = jest.fn().mockReturnValue({ + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', // noqa: mock + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'cronos', + network: 'testnet', + address: '0x242532ebDfcc760f2Ddfe8378eB51f5F847CE5bD', // noqa: mock + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.balances.WETH).toBeDefined()) + .expect((res) => expect(res.body.balances.DAI).toBeDefined()); + }); +}); + +describe('POST /evm/cancel', () => { + it('should return 200', async () => { + // override getWallet (network call) + cronos.getWallet = jest.fn().mockReturnValue({ + address, + }); + + cronos.cancelTx = jest.fn().mockReturnValue({ + hash: '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77', // noqa: mock + }); + + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'cronos', + network: 'testnet', + address, + nonce: 23, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.txHash).toEqual( + '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77' // noqa: mock + ); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'cronos', + network: 'testnet', + address: '', + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /network/poll', () => { + it('should get a NETWORK_ERROR_CODE when the network is unavailable', async () => { + patch(cronos, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = 'NETWORK_ERROR'; + throw error; + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(NETWORK_ERROR_CODE); + expect(res.body.message).toEqual(NETWORK_ERROR_MESSAGE); + }); + + it('should get a UNKNOWN_ERROR_ERROR_CODE when an unknown error is thrown', async () => { + patch(cronos, 'getCurrentBlockNumber', () => { + throw new Error(); + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + }); + + it('should get an OUT of GAS error for failed out of gas transactions', async () => { + patch(cronos, 'getCurrentBlockNumber', () => 1); + patch(cronos, 'getTransaction', () => transactionOutOfGas); + patch(cronos, 'getTransactionReceipt', () => transactionOutOfGasReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(OUT_OF_GAS_ERROR_CODE); + expect(res.body.message).toEqual(OUT_OF_GAS_ERROR_MESSAGE); + }); + + it('should get a null in txReceipt for Tx in the mempool', async () => { + patch(cronos, 'getCurrentBlockNumber', () => 1); + patch(cronos, 'getTransaction', () => transactionOutOfGas); + patch(cronos, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toBeDefined(); + }); + + it('should get a null in txReceipt and txData for Tx that didnt reach the mempool and TxReceipt is null', async () => { + patch(cronos, 'getCurrentBlockNumber', () => 1); + patch(cronos, 'getTransaction', () => null); + patch(cronos, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toEqual(null); + }); + + it('should get txStatus = 1 for a succesful query', async () => { + patch(cronos, 'getCurrentBlockNumber', () => 1); + patch(cronos, 'getTransaction', () => transactionSuccesful); + patch(cronos, 'getTransactionReceipt', () => transactionSuccesfulReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toBeDefined(); + expect(res.body.txData).toBeDefined(); + }); + + it('should get unknown error', async () => { + patch(cronos, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = -32006; + throw error; + }); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'cronos', + network: 'testnet', + txHash: + '0xffdb7b393b46d3795b82c94b8d836ad6b3087a914244634fa89c3abbbf00ed72', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + expect(res.body.message).toEqual(UNKNOWN_ERROR_MESSAGE); + }); +}); diff --git a/test/chains/cronos/mad_meerkat/mad-meerkat.routes.test.ts b/test/chains/cronos/mad_meerkat/mad-meerkat.routes.test.ts new file mode 100644 index 0000000000..2e4bba7f89 --- /dev/null +++ b/test/chains/cronos/mad_meerkat/mad-meerkat.routes.test.ts @@ -0,0 +1,560 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../../services/patch'; +import { gatewayApp } from '../../../../src/app'; +import { Cronos } from '../../../../src/chains/cronos/cronos'; +import { MadMeerkat } from '../../../../src/connectors/mad_meerkat/mad_meerkat'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let cronos: Cronos; +let madMeerkat: MadMeerkat; + +beforeAll(async () => { + cronos = Cronos.getInstance('mainnet'); + patchEVMNonceManager(cronos.nonceManager); + await cronos.init(); + madMeerkat = MadMeerkat.getInstance('cronos', 'mainnet') as MadMeerkat; + await madMeerkat.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(cronos.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await cronos.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(cronos, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchStoredTokenList = () => { + patch(cronos, 'tokenList', () => { + return [ + { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 43114, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + address: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'WAVAX', + symbol: 'WAVAX', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(madMeerkat, 'getTokenByAddress', () => { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(cronos, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(madMeerkat, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(madMeerkat, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(cronos.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(madMeerkat, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WETH', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'BITCOIN', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for BUY with price less than limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'mad_meerkat', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/cronos/mad_meerkat/mad-meerkat.test.ts b/test/chains/cronos/mad_meerkat/mad-meerkat.test.ts new file mode 100644 index 0000000000..849b47c4a5 --- /dev/null +++ b/test/chains/cronos/mad_meerkat/mad-meerkat.test.ts @@ -0,0 +1,146 @@ +jest.useFakeTimers(); +import { MadMeerkat } from '../../../../src/connectors/mad_meerkat/mad_meerkat'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { + ChainId, + Fetcher, + Pair, + Percent, + Route, + Token, + TokenAmount, + Trade, + TradeType, +} from '@crocswap/sdk'; +import { BigNumber } from 'ethers'; +import { Cronos } from '../../../../src/chains/cronos/cronos'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let cronos: Cronos; +let madMeerkat: MadMeerkat; + +const WETH = new Token( + ChainId.MAINNET, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); +const WAVAX = new Token( + ChainId.MAINNET, + '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + 18, + 'WAVAX' +); + +beforeAll(async () => { + cronos = Cronos.getInstance('mainnet'); + patchEVMNonceManager(cronos.nonceManager); + await cronos.init(); + madMeerkat = MadMeerkat.getInstance('cronos', 'mainnet') as MadMeerkat; + await madMeerkat.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(cronos.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await cronos.close(); +}); + +const patchFetchPairData = () => { + patch(Fetcher, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000') + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WETH_WAVAX = new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000') + ); + const WAVAX_TO_WETH = new Route([WETH_WAVAX], WAVAX); + return [ + new Trade( + WAVAX_TO_WETH, + new TokenAmount(WAVAX, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify MadMeerkat estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await madMeerkat.estimateSellTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await madMeerkat.estimateSellTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify MadMeerkat estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await madMeerkat.estimateBuyTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await madMeerkat.estimateBuyTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = madMeerkat.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(new Percent('3', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = madMeerkat.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = madMeerkat.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); +}); diff --git a/test/chains/cronos/vvs/vvs.routes.test.ts b/test/chains/cronos/vvs/vvs.routes.test.ts new file mode 100644 index 0000000000..3314d7d6c5 --- /dev/null +++ b/test/chains/cronos/vvs/vvs.routes.test.ts @@ -0,0 +1,560 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../../services/patch'; +import { gatewayApp } from '../../../../src/app'; +import { Cronos } from '../../../../src/chains/cronos/cronos'; +import { VVSConnector } from '../../../../src/connectors/vvs/vvs'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let cronos: Cronos; +let vvs: VVSConnector; + +beforeAll(async () => { + cronos = Cronos.getInstance('mainnet'); + patchEVMNonceManager(cronos.nonceManager); + await cronos.init(); + vvs = VVSConnector.getInstance('cronos', 'mainnet') as VVSConnector; + await vvs.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(cronos.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await cronos.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(cronos, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchStoredTokenList = () => { + patch(cronos, 'tokenList', () => { + return [ + { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 43114, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + address: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'WAVAX', + symbol: 'WAVAX', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(vvs, 'getTokenByAddress', () => { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(cronos, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(vvs, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(vvs, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(cronos.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(vvs, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WETH', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(cronos, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'BITCOIN', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for BUY with price less than limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'cronos', + network: 'mainnet', + connector: 'vvs', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/cronos/vvs/vvs.test.ts b/test/chains/cronos/vvs/vvs.test.ts new file mode 100644 index 0000000000..ffd0983a70 --- /dev/null +++ b/test/chains/cronos/vvs/vvs.test.ts @@ -0,0 +1,146 @@ +jest.useFakeTimers(); +import { VVSConnector } from '../../../../src/connectors/vvs/vvs'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { + ChainId, + Fetcher, + Pair, + Percent, + Route, + Token, + TokenAmount, + Trade, + TradeType, +} from 'vvs-sdk'; +import { BigNumber } from 'ethers'; +import { Cronos } from '../../../../src/chains/cronos/cronos'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let cronos: Cronos; +let vvs: VVSConnector; + +const WETH = new Token( + ChainId.MAINNET, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); +const WAVAX = new Token( + ChainId.MAINNET, + '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + 18, + 'WAVAX' +); + +beforeAll(async () => { + cronos = Cronos.getInstance('mainnet'); + patchEVMNonceManager(cronos.nonceManager); + await cronos.init(); + vvs = VVSConnector.getInstance('cronos', 'mainnet') as VVSConnector; + await vvs.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(cronos.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await cronos.close(); +}); + +const patchFetchPairData = () => { + patch(Fetcher, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000') + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WETH_WAVAX = new Pair( + new TokenAmount(WETH, '2000000000000000000'), + new TokenAmount(WAVAX, '1000000000000000000') + ); + const WAVAX_TO_WETH = new Route([WETH_WAVAX], WAVAX); + return [ + new Trade( + WAVAX_TO_WETH, + new TokenAmount(WAVAX, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify VVS estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await vvs.estimateSellTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await vvs.estimateSellTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify VVS estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await vvs.estimateBuyTrade( + WETH, + WAVAX, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await vvs.estimateBuyTrade(WETH, WAVAX, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = vvs.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(new Percent('3', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = vvs.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = vvs.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); +}); diff --git a/test/chains/ethereum/ethereum.controllers.test.ts b/test/chains/ethereum/ethereum.controllers.test.ts new file mode 100644 index 0000000000..1d61cbe445 --- /dev/null +++ b/test/chains/ethereum/ethereum.controllers.test.ts @@ -0,0 +1,292 @@ +import { BigNumber } from 'ethers'; +import { Ethereum } from '../../../src/chains/ethereum/ethereum'; +import { patch, unpatch } from '../../services/patch'; +import { TokenInfo } from '../../../src/services/ethereum-base'; +import { + nonce, + nextNonce, + getTokenSymbolsToTokens, + allowances, + approve, + balances, + cancel, + willTxSucceed, +} from '../../../src/chains/ethereum/ethereum.controllers'; +import { + HttpException, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE, +} from '../../../src/services/error-handler'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; +let eth: Ethereum; + +beforeAll(async () => { + eth = Ethereum.getInstance('kovan'); + + patchEVMNonceManager(eth.nonceManager); + + await eth.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(eth.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await eth.close(); +}); + +const zeroAddress = + '0000000000000000000000000000000000000000000000000000000000000000'; // noqa: mock + +describe('nonce', () => { + it('return a nonce for a wallet', async () => { + patch(eth, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + patch(eth.nonceManager, 'getNonce', () => 2); + const n = await nonce(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + }); + expect(n).toEqual({ nonce: 2 }); + }); + + it('return next nonce for a wallet', async () => { + patch(eth, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + patch(eth.nonceManager, 'getNextNonce', () => 3); + const n = await nextNonce(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + }); + expect(n).toEqual({ nonce: 3 }); + }); +}); + +const weth: TokenInfo = { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, +}; +describe('getTokenSymbolsToTokens', () => { + it('return tokens for strings', () => { + patch(eth, 'getTokenBySymbol', () => { + return weth; + }); + expect(getTokenSymbolsToTokens(eth, ['WETH'])).toEqual({ WETH: weth }); + }); +}); + +const uniswap = '0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D'; + +describe('allowances', () => { + it('return allowances for an owner, spender and tokens', async () => { + patch(eth, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + + patch(eth, 'getTokenBySymbol', () => { + return weth; + }); + + patch(eth, 'getSpender', () => { + return uniswap; + }); + + patch(eth, 'getERC20Allowance', () => { + return { + value: BigNumber.from('999999999999999999999999'), + decimals: 2, + }; + }); + + const result = await allowances(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + spender: uniswap, + tokenSymbols: ['WETH'], + }); + expect((result as any).approvals).toEqual({ + WETH: '9999999999999999999999.99', + }); + }); +}); + +describe('approve', () => { + it('approve a spender for an owner, token and amount', async () => { + patch(eth, 'getSpender', () => { + return uniswap; + }); + eth.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + patch(eth, 'ready', () => true); + + patch(eth, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + + patch(eth, 'getTokenBySymbol', () => { + return weth; + }); + + patch(eth, 'approveERC20', () => { + return { + spender: uniswap, + value: { toString: () => '9999999' }, + }; + }); + + const result = await approve(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + spender: uniswap, + token: 'WETH', + }); + expect((result as any).spender).toEqual(uniswap); + }); + + it('fail if wallet not found', async () => { + patch(eth, 'getSpender', () => { + return uniswap; + }); + + const err = 'wallet does not exist'; + patch(eth, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + approve(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + spender: uniswap, + token: 'WETH', + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); + + it('fail if token not found', async () => { + patch(eth, 'getSpender', () => { + return uniswap; + }); + + patch(eth, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + + patch(eth, 'getTokenBySymbol', () => { + return null; + }); + + await expect( + approve(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + spender: uniswap, + token: 'WETH', + }) + ).rejects.toThrow( + new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + 'WETH', + TOKEN_NOT_SUPPORTED_ERROR_CODE + ) + ); + }); +}); + +describe('balances', () => { + it('fail if wallet not found', async () => { + const err = 'wallet does not exist'; + patch(eth, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + balances(eth, { + chain: 'ethereum', + network: 'kovan', + address: zeroAddress, + tokenSymbols: ['WETH', 'DAI'], + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); +}); + +describe('cancel', () => { + it('fail if wallet not found', async () => { + const err = 'wallet does not exist'; + patch(eth, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + cancel(eth, { + chain: 'ethereum', + network: 'kovan', + nonce: 123, + address: zeroAddress, + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); +}); + +describe('willTxSucceed', () => { + it('time limit met and gas price higher than that of the tx', () => { + expect(willTxSucceed(100, 10, 10, 100)).toEqual(false); + }); + + it('time limit met but gas price has not exceeded that of the tx', () => { + expect(willTxSucceed(100, 10, 100, 90)).toEqual(true); + }); + + it('time limit not met', () => { + expect(willTxSucceed(10, 100, 100, 90)).toEqual(true); + }); +}); diff --git a/test/chains/ethereum/ethereum.routes.test.ts b/test/chains/ethereum/ethereum.routes.test.ts new file mode 100644 index 0000000000..a30342a4df --- /dev/null +++ b/test/chains/ethereum/ethereum.routes.test.ts @@ -0,0 +1,634 @@ +import request from 'supertest'; +import { Ethereum } from '../../../src/chains/ethereum/ethereum'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { + NETWORK_ERROR_CODE, + RATE_LIMIT_ERROR_CODE, + OUT_OF_GAS_ERROR_CODE, + UNKNOWN_ERROR_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + RATE_LIMIT_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_MESSAGE, + UNKNOWN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; +import * as transactionSuccesful from './fixtures/transaction-succesful.json'; +import * as transactionSuccesfulReceipt from './fixtures/transaction-succesful-receipt.json'; +import * as transactionOutOfGas from './fixtures/transaction-out-of-gas.json'; +import * as transactionOutOfGasReceipt from './fixtures/transaction-out-of-gas-receipt.json'; +let eth: Ethereum; + +beforeAll(async () => { + eth = Ethereum.getInstance('kovan'); + patchEVMNonceManager(eth.nonceManager); + await eth.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(eth.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await eth.close(); +}); + +const patchGetWallet = () => { + patch(eth, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchGetNonce = () => { + patch(eth.nonceManager, 'getNonce', () => 2); +}; + +const patchGetNextNonce = () => { + patch(eth.nonceManager, 'getNextNonce', () => 3); +}; + +const patchGetERC20Balance = () => { + patch(eth, 'getERC20Balance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetNativeBalance = () => { + patch(eth, 'getNativeBalance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetERC20Allowance = () => { + patch(eth, 'getERC20Allowance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetTokenBySymbol = () => { + patch(eth, 'getTokenBySymbol', (symbol: string) => { + let result; + switch (symbol) { + case 'WETH': + result = { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + break; + case 'DAI': + result = { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0xd0A1E359811322d97991E03f863a0C30C2cFFFFF', + decimals: 18, + }; + break; + } + return result; + }); +}; + +const patchApproveERC20 = (tx_type?: string) => { + const default_tx = { + type: 2, + chainId: 42, + nonce: 115, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '100000' }, + to: '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9', // noqa: mock + v: 0, + r: '0xbeb9aa40028d79b9fdab108fcef5de635457a05f3a254410414c095b02c64643', // noqa: mock + s: '0x5a1506fa4b7f8b4f3826d8648f27ebaa9c0ee4bd67f569414b8cd8884c073100', // noqa: mock + from: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + confirmations: 0, + }; + if (tx_type === 'overwritten_tx') { + default_tx.hash = + '0x5a1ed682d0d7a58fbd7828bbf5994cd024feb8895d4da82c741ec4a191b9e849'; // noqa: mock + } + patch(eth, 'approveERC20', () => { + return default_tx; + }); +}; + +describe('POST /evm/allowances', () => { + it('should return 200 asking for allowances', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + const theSpender = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + eth.getSpender = jest.fn().mockReturnValue(theSpender); + eth.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + patchGetERC20Allowance(); + + await request(gatewayApp) + .post(`/evm/allowances`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: theSpender, + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.spender).toEqual(theSpender)) + .expect((res) => expect(res.body.approvals.WETH).toEqual('0.001')) + .expect((res) => expect(res.body.approvals.DAI).toEqual('0.001')); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/allowances`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: '0xSpender', + tokenSymbols: ['WETH', 'DAI'], + }) + .expect(404); + }); +}); + +describe('POST /network/balances', () => { + it('should return 200 asking for supported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + eth.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.balances.WETH).toBeDefined()) + .expect((res) => expect(res.body.balances.DAI).toBeDefined()); + }); + + it('should return 200 asking for native token', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + eth.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + tokenSymbols: ['ETH'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.balances.ETH).toBeDefined()) + .expect((res) => console.log(res.body)); + }); + + it('should return 500 for unsupported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + eth.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + tokenSymbols: ['XXX', 'YYY'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(500); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: 'da857cbda0ba96757fed842617a4', + }) + .expect(404); + }); +}); + +describe('POST /evm/nonce', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetNonce(); + + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.nonce).toBe(2)); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: 'da857cbda0ba96757fed842617a4', + }) + .expect(404); + }); +}); + +describe('POST /evm/nextNonce', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetNextNonce(); + + await request(gatewayApp) + .post(`/evm/nextNonce`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.nonce).toBe(3)); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/nextNonce`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: 'da857cbda0ba96757fed842617a4', + }) + .expect(404); + }); +}); + +describe('POST /evm/approve', () => { + it('approve without nonce parameter should return 200', async () => { + patchGetWallet(); + eth.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + patch(eth.nonceManager, 'getNonce', () => 115); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: 'uniswap', + token: 'WETH', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200); + }); + + it('approve with nonce parameter should return 200', async () => { + patchGetWallet(); + patch(eth.nonceManager, 'getNonce', () => 115); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: 'uniswap', + token: 'WETH', + nonce: 115, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(115); + }); + }); + + it('approve with maxFeePerGas and maxPriorityFeePerGas should return 200', async () => { + patchGetWallet(); + patch(eth.nonceManager, 'getNonce', () => 115); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: 'uniswap', + token: 'WETH', + nonce: 115, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: 'uniswap', + token: 123, + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /evm/cancel', () => { + it('should return 200', async () => { + // override getWallet (network call) + eth.getWallet = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + eth.cancelTx = jest.fn().mockReturnValue({ + hash: '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77', // noqa: mock + }); + + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + nonce: 23, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.txHash).toEqual( + '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77' // noqa: mock + ); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'ethereum', + network: 'kovan', + address: '', + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /network/poll', () => { + it('should get a NETWORK_ERROR_CODE when the network is unavailable', async () => { + patch(eth, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = 'NETWORK_ERROR'; + throw error; + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(NETWORK_ERROR_CODE); + expect(res.body.message).toEqual(NETWORK_ERROR_MESSAGE); + }); + + it('should get a UNKNOWN_ERROR_ERROR_CODE when an unknown error is thrown', async () => { + patch(eth, 'getCurrentBlockNumber', () => { + throw new Error(); + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + }); + + it('should get an OUT of GAS error for failed out of gas transactions', async () => { + patch(eth, 'getCurrentBlockNumber', () => 1); + patch(eth, 'getTransaction', () => transactionOutOfGas); + patch(eth, 'getTransactionReceipt', () => transactionOutOfGasReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(OUT_OF_GAS_ERROR_CODE); + expect(res.body.message).toEqual(OUT_OF_GAS_ERROR_MESSAGE); + }); + + it('should get a null in txReceipt for Tx in the mempool', async () => { + patch(eth, 'getCurrentBlockNumber', () => 1); + patch(eth, 'getTransaction', () => transactionOutOfGas); + patch(eth, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toBeDefined(); + }); + + it('should get a null in txReceipt and txData for Tx that didnt reach the mempool and TxReceipt is null', async () => { + patch(eth, 'getCurrentBlockNumber', () => 1); + patch(eth, 'getTransaction', () => null); + patch(eth, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toEqual(null); + }); + + it('should get txStatus = 1 for a succesful query', async () => { + patch(eth, 'getCurrentBlockNumber', () => 1); + patch(eth, 'getTransaction', () => transactionSuccesful); + patch(eth, 'getTransactionReceipt', () => transactionSuccesfulReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toBeDefined(); + expect(res.body.txData).toBeDefined(); + }); + + it('should get an RATE_LIMIT_ERROR_CODE when the blockchain API is rate limited', async () => { + patch(eth, 'getCurrentBlockNumber', () => { + const error: any = new Error( + 'daily request count exceeded, request rate limited' + ); + error.code = -32005; + error.data = { + see: 'https://infura.io/docs/ethereum/jsonrpc/ratelimits', + current_rps: 13.333, + allowed_rps: 10.0, + backoff_seconds: 30.0, + }; + throw error; + }); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(RATE_LIMIT_ERROR_CODE); + expect(res.body.message).toEqual(RATE_LIMIT_ERROR_MESSAGE); + }); + + it('should get unknown error', async () => { + patch(eth, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = -32006; + throw error; + }); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + expect(res.body.message).toEqual(UNKNOWN_ERROR_MESSAGE); + }); +}); + +describe('overwrite existing transaction', () => { + it('overwritten transaction is dropped', async () => { + patchGetWallet(); + patch(eth.nonceManager, 'getNonce', () => 115); + patchGetTokenBySymbol(); + + const requestParam = { + chain: 'ethereum', + network: 'kovan', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: 'uniswap', + token: 'WETH', + nonce: 115, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }; + + patchApproveERC20('overwritten_tx'); + const tx_1 = await request(gatewayApp) + .post(`/evm/approve`) + .send(requestParam) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200); + + patchApproveERC20(); // patch to return different tx_hash + requestParam.maxPriorityFeePerGas = '8000000000'; // we only increase maxPriorityFeePerGas + const tx_2 = await request(gatewayApp) + .post(`/evm/approve`) + .send(requestParam) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200); + + // once tx_2 is confirmed, tx_1 will be dropped + patch(eth, 'getCurrentBlockNumber', () => 1); + patch(eth, 'getTransaction', () => null); + patch(eth, 'getTransactionReceipt', () => null); + const res_1 = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: tx_1.body.approval.hash, + }); + expect(res_1.statusCode).toEqual(200); + expect(res_1.body.txReceipt).toEqual(null); + expect(res_1.body.txData).toEqual(null); + + patch(eth, 'getCurrentBlockNumber', () => 1); + patch(eth, 'getTransaction', () => transactionSuccesful); + patch(eth, 'getTransactionReceipt', () => transactionSuccesfulReceipt); + const res_2 = await request(gatewayApp).post('/network/poll').send({ + chain: 'ethereum', + network: 'kovan', + txHash: tx_2.body.approval.hash, + }); + expect(res_2.statusCode).toEqual(200); + expect(res_2.body.txReceipt).toBeDefined(); + expect(res_2.body.txData).toBeDefined(); + }); +}); diff --git a/test/chains/ethereum/ethereum.validators.test.ts b/test/chains/ethereum/ethereum.validators.test.ts new file mode 100644 index 0000000000..cc6744a048 --- /dev/null +++ b/test/chains/ethereum/ethereum.validators.test.ts @@ -0,0 +1,196 @@ +import { + isAddress, + validateAddress, + invalidAddressError, + validateSpender, + invalidSpenderError, + validateNonce, + invalidNonceError, + invalidMaxFeePerGasError, + validateMaxFeePerGas, + invalidMaxPriorityFeePerGasError, + validateMaxPriorityFeePerGas, +} from '../../../src/chains/ethereum/ethereum.validators'; + +import { missingParameter } from '../../../src/services/validators'; + +import 'jest-extended'; + +describe('isAddress', () => { + it('pass against a well formed public key', () => { + expect(isAddress('0xFaA12FD102FE8623C9299c72B03E45107F2772B5')).toEqual( + true + ); + }); + + it('fail against a string that is too short', () => { + expect(isAddress('0xFaA12FD102FE8623C9299c72')).toEqual(false); + }); + + it('fail against a string that has non-hexadecimal characters', () => { + expect(isAddress('0xFaA12FD102FE8623C9299c7iwqpneciqwopienff')).toEqual( + false + ); + }); + + it('fail against a valid public key that is missing the initial 0x', () => { + expect(isAddress('FaA12FD102FE8623C9299c72B03E45107F2772B5')).toEqual( + false + ); + }); +}); + +describe('validateAddress', () => { + it('valid when req.address is a address', () => { + expect( + validateAddress({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it('return error when req.address does not exist', () => { + expect( + validateAddress({ + hello: 'world', + }) + ).toEqual([missingParameter('address')]); + }); + + it('return error when req.address is invalid', () => { + expect( + validateAddress({ + address: 'world', + }) + ).toEqual([invalidAddressError]); + }); +}); + +describe('validateSpender', () => { + it('valid when req.spender is a publicKey', () => { + expect( + validateSpender({ + spender: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it("valid when req.spender is a 'uniswap'", () => { + expect( + validateSpender({ + spender: 'uniswap', + }) + ).toEqual([]); + }); + + it('return error when req.spender does not exist', () => { + expect( + validateSpender({ + hello: 'world', + }) + ).toEqual([missingParameter('spender')]); + }); + + it('return error when req.spender is invalid', () => { + expect( + validateSpender({ + spender: 'world', + }) + ).toEqual([invalidSpenderError]); + }); +}); + +describe('validateNonce', () => { + it('valid when req.nonce is a number', () => { + expect( + validateNonce({ + nonce: 0, + }) + ).toEqual([]); + expect( + validateNonce({ + nonce: 999, + }) + ).toEqual([]); + }); + + it('valid when req.nonce does not exist', () => { + expect( + validateNonce({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.nonce is invalid', () => { + expect( + validateNonce({ + nonce: '123', + }) + ).toEqual([invalidNonceError]); + }); +}); + +describe('validateMaxFeePerGas', () => { + it('valid when req.quote is a string', () => { + expect( + validateMaxFeePerGas({ + maxFeePerGas: '5000000000', + }) + ).toEqual([]); + + expect( + validateMaxFeePerGas({ + maxFeePerGas: '1', + }) + ).toEqual([]); + }); + + it('return no error when req.maxFeePerGas does not exist', () => { + expect( + validateMaxFeePerGas({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.maxFeePerGas is invalid', () => { + expect( + validateMaxFeePerGas({ + maxFeePerGas: 123, + }) + ).toEqual([invalidMaxFeePerGasError]); + }); +}); + +describe('validateMaxPriorityFeePerGas', () => { + it('valid when req.quote is a string', () => { + expect( + validateMaxPriorityFeePerGas({ + maxPriorityFeePerGasError: '5000000000', + }) + ).toEqual([]); + + expect( + validateMaxPriorityFeePerGas({ + maxPriorityFeePerGasError: '1', + }) + ).toEqual([]); + }); + + it('return no error when req.maxPriorityFeePerGas does not exist', () => { + expect( + validateMaxPriorityFeePerGas({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.maxPriorityFeePerGas is invalid', () => { + expect( + validateMaxPriorityFeePerGas({ + maxPriorityFeePerGas: 123, + }) + ).toEqual([invalidMaxPriorityFeePerGasError]); + }); +}); diff --git a/test/chains/ethereum/evm.nonce.test.ts b/test/chains/ethereum/evm.nonce.test.ts new file mode 100644 index 0000000000..b8ed629f76 --- /dev/null +++ b/test/chains/ethereum/evm.nonce.test.ts @@ -0,0 +1,331 @@ +import fs from 'fs'; +import fsp from 'fs/promises'; +import os from 'os'; +import path from 'path'; + +import { providers } from 'ethers'; +import { + InitializationError, + InvalidNonceError, + INVALID_NONCE_ERROR_CODE, + INVALID_NONCE_ERROR_MESSAGE, + SERVICE_UNITIALIZED_ERROR_CODE, + SERVICE_UNITIALIZED_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import { EVMNonceManager } from '../../../src/services/evm.nonce'; +import { patch, unpatch } from '../../services/patch'; + +import 'jest-extended'; +import { ReferenceCountingCloseable } from '../../../src/services/refcounting-closeable'; + +const exampleAddress = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +afterEach(() => { + unpatch(); +}); + +describe('uninitiated EVMNodeService', () => { + let dbPath = ''; + const handle: string = ReferenceCountingCloseable.createHandle(); + let nonceManager: EVMNonceManager; + + beforeAll(async () => { + jest.useFakeTimers(); + dbPath = await fsp.mkdtemp( + path.join(os.tmpdir(), '/evm-nonce1.test.level') + ); + nonceManager = new EVMNonceManager('ethereum', 43, dbPath, 0, 0); + nonceManager.declareOwnership(handle); + }); + + afterAll(async () => { + await nonceManager.close(handle); + fs.rmSync(dbPath, { force: true, recursive: true }); + }); + + it('mergeNonceFromEVMNode throws error', async () => { + await expect( + nonceManager.mergeNonceFromEVMNode(exampleAddress) + ).rejects.toThrow( + new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE( + 'EVMNonceManager.mergeNonceFromEVMNode' + ), + SERVICE_UNITIALIZED_ERROR_CODE + ) + ); + }); + + it('getNonce throws error', async () => { + await expect(nonceManager.getNonce(exampleAddress)).rejects.toThrow( + new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('EVMNonceManager.getNonceFromMemory'), + SERVICE_UNITIALIZED_ERROR_CODE + ) + ); + }); + + it('commitNonce (txNonce not null) throws error', async () => { + await expect(nonceManager.commitNonce(exampleAddress, 87)).rejects.toThrow( + new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE('EVMNonceManager.commitNonce'), + SERVICE_UNITIALIZED_ERROR_CODE + ) + ); + }); + + it('localNonceTTL value too low', async () => { + const provider = new providers.StaticJsonRpcProvider( + 'https://ethereum.node.com' + ); + + const nonceManager2 = new EVMNonceManager('ethereum', 43, dbPath, -5, 0); + nonceManager2.declareOwnership(handle); + + try { + await expect(nonceManager2.init(provider)).rejects.toThrow( + new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE( + 'EVMNonceManager.init localNonceTTL must be greater than or equal to zero.' + ), + SERVICE_UNITIALIZED_ERROR_CODE + ) + ); + } finally { + await nonceManager2.close(handle); + } + }); + + it('pendingNonceTTL value too low', async () => { + const provider = new providers.StaticJsonRpcProvider( + 'https://ethereum.node.com' + ); + + const nonceManager2 = new EVMNonceManager('ethereum', 43, dbPath, 0, -5); + nonceManager2.declareOwnership(handle); + + try { + await expect(nonceManager2.init(provider)).rejects.toThrow( + new InitializationError( + SERVICE_UNITIALIZED_ERROR_MESSAGE( + 'EVMNonceManager.init pendingNonceTTL must be greater than or equal to zero.' + ), + SERVICE_UNITIALIZED_ERROR_CODE + ) + ); + } finally { + await nonceManager2.close(handle); + } + }); +}); + +describe('EVMNodeService', () => { + let nonceManager: EVMNonceManager; + let dbPath = ''; + const handle: string = ReferenceCountingCloseable.createHandle(); + const provider = new providers.StaticJsonRpcProvider( + 'https://ethereum.node.com' + ); + + beforeEach(async () => { + dbPath = await fsp.mkdtemp( + path.join(os.tmpdir(), '/evm-nonce2.test.level') + ); + nonceManager = new EVMNonceManager('ethereum', 43, dbPath, 0, 0); + nonceManager.declareOwnership(handle); + await nonceManager.init(provider); + await nonceManager.commitNonce(exampleAddress, 0); + }); + + afterAll(async () => { + await nonceManager.close(handle); + fs.rmSync(dbPath, { force: true, recursive: true }); + }); + + const patchGetTransactionCount = () => { + if (nonceManager._provider) { + patch(nonceManager._provider, 'getTransactionCount', () => 11); + } + }; + + const patchDropExpiredPendingNonces = () => { + patch(nonceManager, 'dropExpiredPendingNonces', (_: any) => { + return null; + }); + }; + + it('commitNonce with a provided txNonce will only update current nonce if txNonce > currentNonce', async () => { + patchGetTransactionCount(); + await nonceManager.commitNonce(exampleAddress, 10); + let nonce = await nonceManager.getNonce(exampleAddress); + await expect(nonce).toEqual(10); + + await expect(nonceManager.commitNonce(exampleAddress, 5)).rejects.toThrow( + new InvalidNonceError( + INVALID_NONCE_ERROR_MESSAGE + `txNonce(5) < currentNonce(10)`, + INVALID_NONCE_ERROR_CODE + ) + ); + + nonce = await nonceManager.getNonce(exampleAddress); + await expect(nonce).toEqual(10); + }); + + it('mergeNonceFromEVMNode should update with nonce from EVM node (local { + if (nonceManager._provider) { + patch(nonceManager._provider, 'getTransactionCount', () => 20); + } + + await nonceManager.commitNonce(exampleAddress, 8); + jest.advanceTimersByTime(300000); + await nonceManager.mergeNonceFromEVMNode(exampleAddress); + const nonce = await nonceManager.getNonce(exampleAddress); + await expect(nonce).toEqual(19); + }); + + it('getNextNonce should return nonces that are sequentially increasing', async () => { + // Prevents nonce from expiring. + patchGetTransactionCount(); + patchDropExpiredPendingNonces(); + patch(nonceManager, '_pendingNonceTTL', 300 * 1000); + nonceManager.commitNonce(exampleAddress, 1); + jest.advanceTimersByTime(300000); + + const pendingNonce1 = await nonceManager.getNextNonce(exampleAddress); + expect(pendingNonce1).toEqual(11); + + const pendingNonce2 = await nonceManager.getNextNonce(exampleAddress); + expect(pendingNonce2).toEqual(pendingNonce1 + 1); + }); + + it('getNextNonce should reuse expired nonces', async () => { + // Prevents nonce from expiring. + patchGetTransactionCount(); + + const pendingNonce1 = await nonceManager.getNextNonce(exampleAddress); + expect(pendingNonce1).toEqual(11); + + // if this runs too quickly it will fail (the nonce has not expired yet) + jest.advanceTimersByTime(1000); + + const pendingNonce2 = await nonceManager.getNextNonce(exampleAddress); + expect(pendingNonce2).toEqual(pendingNonce1); + + await nonceManager.commitNonce(exampleAddress, 20); + jest.advanceTimersByTime(300000); + await nonceManager.mergeNonceFromEVMNode(exampleAddress); + const nonce = await nonceManager.getNonce(exampleAddress); + await expect(nonce).toEqual(10); + }); + + it('provideNonce, nonce not provided. should return function results and commit nonce on successful execution of transaction', async () => { + // Prevents leading nonce from expiring. + patchGetTransactionCount(); + patch(nonceManager, '_localNonceTTL', 300 * 1000); + + const testFunction = async (_nonce: number) => { + return { + nonce: _nonce, + }; + }; + const transactionResult = await nonceManager.provideNonce( + undefined, + exampleAddress, + testFunction + ); + const currentNonceFromMemory = await nonceManager.getNonceFromMemory( + exampleAddress + ); + + expect(transactionResult.nonce).toEqual(11); + expect(currentNonceFromMemory).toEqual(11); + }); + + it('provideNonce, nonce not provided. should remove all pendingNonces greater or equal should function fail', async () => { + // Prevents leading nonce from expiring. + patchGetTransactionCount(); + + const expectedNonce = await nonceManager.getNonceFromMemory(exampleAddress); + expect(expectedNonce).toEqual(10); + + const pendingNonce1 = await nonceManager.getNextNonce(exampleAddress); // This nonce should expire. + expect(pendingNonce1).toEqual(11); + + const testFunction = async (_nonce: number) => { + throw new Error('testFunction has failed.'); + }; + + jest.advanceTimersByTime(300000); + + try { + await nonceManager.provideNonce(undefined, exampleAddress, testFunction); + } catch (error) { + expect(error).toEqual(new Error('testFunction has failed.')); + } + + const currentNonceFromMemory = await nonceManager.getNonceFromMemory( + exampleAddress + ); + + expect(currentNonceFromMemory).toEqual(expectedNonce); + + const pendingNonce2 = await nonceManager.getNextNonce(exampleAddress); + expect(pendingNonce2).toEqual(pendingNonce1); // Nonce is re-used. + }); +}); + +describe("EVMNodeService was previously a singleton. Let's prove that it no longer is.", () => { + let nonceManager1: EVMNonceManager; + let nonceManager2: EVMNonceManager; + let dbPath = ''; + const handle: string = ReferenceCountingCloseable.createHandle(); + + beforeAll(async () => { + dbPath = await fsp.mkdtemp( + path.join(os.tmpdir(), '/evm-nonce3.test.level') + ); + nonceManager1 = new EVMNonceManager('ethereum', 43, dbPath, 60, 60); + const provider1 = new providers.StaticJsonRpcProvider( + 'https://ethereum.node.com' + ); + nonceManager1.declareOwnership(handle); + await nonceManager1.init(provider1); + + nonceManager2 = new EVMNonceManager('avalanche', 56, dbPath, 60, 60); + nonceManager2.declareOwnership(handle); + const provider2 = new providers.StaticJsonRpcProvider( + 'https://avalanche.node.com' + ); + await nonceManager2.init(provider2); + }); + + afterAll(async () => { + await nonceManager1.close(handle); + await nonceManager2.close(handle); + fs.rmSync(dbPath, { force: true, recursive: true }); + }); + + it('commitNonce with a provided txNonce will only update current nonce if txNonce > currentNonce', async () => { + if (nonceManager1._provider) { + patch(nonceManager1._provider, 'getTransactionCount', () => 11); + } + if (nonceManager2._provider) { + patch(nonceManager2._provider, 'getTransactionCount', () => 24); + } + + await nonceManager1.commitNonce(exampleAddress, 10); + jest.advanceTimersByTime(300000); + const nonce1 = await nonceManager1.getNonce(exampleAddress); + await expect(nonce1).toEqual(10); + + await nonceManager2.commitNonce(exampleAddress, 23); + jest.advanceTimersByTime(300000); + const nonce2 = await nonceManager2.getNonce(exampleAddress); + await expect(nonce2).toEqual(23); + + await nonceManager1.commitNonce(exampleAddress, 11); + jest.advanceTimersByTime(300000); + const nonce3 = await nonceManager1.getNonce(exampleAddress); + await expect(nonce3).toEqual(10); + }); +}); diff --git a/test/chains/ethereum/fixtures/transaction-out-of-gas-receipt.json b/test/chains/ethereum/fixtures/transaction-out-of-gas-receipt.json new file mode 100644 index 0000000000..8a835b215e --- /dev/null +++ b/test/chains/ethereum/fixtures/transaction-out-of-gas-receipt.json @@ -0,0 +1,18 @@ +{ + "to": "0xf650C3d88D12dB855b8bf7D11Be6C55A4e07dCC9", + "from": "0x58B7AA5bEd029A5D149E108Ad4bdF836D10F70Ea", + "contractAddress": null, + "transactionIndex": 44, + "gasUsed": { "type": "BigNumber", "hex": "0x033111" }, + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0xf1780cff8a16b790fcf06bccb9ad09a4ab1a037beeb031c92c45142176cf765b", + "transactionHash": "0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362", + "logs": [], + "blockNumber": 11156112, + "confirmations": 1991737, + "cumulativeGasUsed": { "type": "BigNumber", "hex": "0x44787d" }, + "effectiveGasPrice": { "type": "BigNumber", "hex": "0x0773594000" }, + "status": 0, + "type": 0, + "byzantium": true +} diff --git a/test/chains/ethereum/fixtures/transaction-out-of-gas.json b/test/chains/ethereum/fixtures/transaction-out-of-gas.json new file mode 100644 index 0000000000..f2f07dba5b --- /dev/null +++ b/test/chains/ethereum/fixtures/transaction-out-of-gas.json @@ -0,0 +1,21 @@ +{ + "hash": "0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362", + "type": 0, + "accessList": null, + "blockHash": "0xf1780cff8a16b790fcf06bccb9ad09a4ab1a037beeb031c92c45142176cf765b", + "blockNumber": 11156112, + "transactionIndex": 44, + "confirmations": 2036758, + "from": "0x58B7AA5bEd029A5D149E108Ad4bdF836D10F70Ea", + "gasPrice": { "type": "BigNumber", "hex": "0x0773594000" }, + "gasLimit": { "type": "BigNumber", "hex": "0x033c34" }, + "to": "0xf650C3d88D12dB855b8bf7D11Be6C55A4e07dCC9", + "value": { "type": "BigNumber", "hex": "0x00" }, + "nonce": 75, + "data": "0xa0712d680000000000000000000000000000000000000000000000000000000005efe122", + "r": "0xf062197d2148efd8a86969f747e812d738fd8355583c1443aa5bc28f57cf9d77", + "s": "0x57b010a8c20f0fa5911b0ec20d555f08ff93368f456d33c03e2ea62ff33dcf1b", + "v": 37, + "creates": null, + "chainId": 1 +} diff --git a/test/chains/ethereum/fixtures/transaction-succesful-receipt.json b/test/chains/ethereum/fixtures/transaction-succesful-receipt.json new file mode 100644 index 0000000000..036a0ae3ab --- /dev/null +++ b/test/chains/ethereum/fixtures/transaction-succesful-receipt.json @@ -0,0 +1,55 @@ +{ + "to": "0x37F4df6e6E75F288f85B970F3a58D1Aeb5E882A1", + "from": "0xf4f087451055f7daf82ece742489F6F428A24e20", + "contractAddress": null, + "transactionIndex": 15, + "gasUsed": { + "type": "BigNumber", + "hex": "0x011cdd" + }, + "logsBloom": "0x00000000000000000000000000000000000000008000400000000000000000000000000000000000000000000000000000000000000020000000800000000000000000000040000000000008000000000000000000000000000000000000000000000000000000000000000000002000000000000000000000000010400000000000000100000000000008000800000000000000000000000000000000000000000000080000000400000000000000000000000000000000000000000000000000000002000000000100000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000", + "blockHash": "0xefbb71d5ad4e145f15484b3fd4807b308b91118880305ccf6fa5c3fb5c9b1aab", + "transactionHash": "0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d", + "logs": [ + { + "transactionIndex": 15, + "blockNumber": 26549862, + "transactionHash": "0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d", + "address": "0x6E8363b3499B54944674fB546BfFe52c5F411A79", + "topics": [ + "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef", + "0x00000000000000000000000037f4df6e6e75f288f85b970f3a58d1aeb5e882a1", + "0x000000000000000000000000f4f087451055f7daf82ece742489f6f428a24e20" + ], + "data": "0x00000000000000000000000000000000000000000000000002700417b49d51b5", + "logIndex": 30, + "blockHash": "0xefbb71d5ad4e145f15484b3fd4807b308b91118880305ccf6fa5c3fb5c9b1aab" + }, + { + "transactionIndex": 15, + "blockNumber": 26549862, + "transactionHash": "0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d", + "address": "0x37F4df6e6E75F288f85B970F3a58D1Aeb5E882A1", + "topics": [ + "0xe2403640ba68fed3a2f88b7557551d1993f84b99bb10ff833f0cf8db0c5e0486", + "0x000000000000000000000000f4f087451055f7daf82ece742489f6f428a24e20" + ], + "data": "0x00000000000000000000000000000000000000000000000002700417b49d51b5", + "logIndex": 31, + "blockHash": "0xefbb71d5ad4e145f15484b3fd4807b308b91118880305ccf6fa5c3fb5c9b1aab" + } + ], + "blockNumber": 26549862, + "confirmations": 1029723, + "cumulativeGasUsed": { + "type": "BigNumber", + "hex": "0x3ed4ac" + }, + "effectiveGasPrice": { + "type": "BigNumber", + "hex": "0x3b9aca00" + }, + "status": 1, + "type": 0, + "byzantium": true +} diff --git a/test/chains/ethereum/fixtures/transaction-succesful.json b/test/chains/ethereum/fixtures/transaction-succesful.json new file mode 100644 index 0000000000..d540e6f4be --- /dev/null +++ b/test/chains/ethereum/fixtures/transaction-succesful.json @@ -0,0 +1,31 @@ +{ + "hash": "0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d", + "type": 0, + "accessList": null, + "blockHash": "0xefbb71d5ad4e145f15484b3fd4807b308b91118880305ccf6fa5c3fb5c9b1aab", + "blockNumber": 26549862, + "transactionIndex": 15, + "confirmations": 1029723, + "from": "0xf4f087451055f7daf82ece742489F6F428A24e20", + "gasPrice": { + "type": "BigNumber", + "hex": "0x3b9aca00" + }, + "gasLimit": { + "type": "BigNumber", + "hex": "0x03b85d" + }, + "to": "0x37F4df6e6E75F288f85B970F3a58D1Aeb5E882A1", + "value": { + "type": "BigNumber", + "hex": "0x00" + }, + "nonce": 14, + "data": "0x3d18b912", + "r": "0xb1d265af60265817dcd3baed68fcd92cb501bd36332c1d70d6838ceaae3a7abe", + "s": "0x1f32c4f3a20e90e26bde70dbb458dddbeedc96dd05318d25b9bad3f731eadf38", + "v": 120, + "creates": null, + "raw": "0xf8680e843b9aca008303b85d9437f4df6e6e75f288f85b970f3a58d1aeb5e882a180843d18b91278a0b1d265af60265817dcd3baed68fcd92cb501bd36332c1d70d6838ceaae3a7abea01f32c4f3a20e90e26bde70dbb458dddbeedc96dd05318d25b9bad3f731eadf38", + "chainId": 42 +} diff --git a/test/chains/ethereum/perp/perp.routes.test.ts b/test/chains/ethereum/perp/perp.routes.test.ts new file mode 100644 index 0000000000..011b79c5f8 --- /dev/null +++ b/test/chains/ethereum/perp/perp.routes.test.ts @@ -0,0 +1,356 @@ +import express from 'express'; +import { Express } from 'express-serve-static-core'; +import request from 'supertest'; +import { Big } from 'big.js'; +import { MarketStatus } from '@perp/sdk-curie'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { Perp } from '../../../../src/connectors/perp/perp'; + +import { PerpAmmRoutes } from '../../../../src/amm/amm.routes'; +import { patch, unpatch } from '../../../services/patch'; +import { gasCostInEthString } from '../../../../src/services/base'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let app: Express; +let ethereum: Ethereum; +let perp: Perp, perp2: Perp; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + + ethereum = Ethereum.getInstance('optimism'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + perp = Perp.getInstance('ethereum', 'optimism'); + perp2 = Perp.getInstance('ethereum', 'optimism', address); + + app.use('/amm/perp', PerpAmmRoutes.router); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); + patch(perp, 'ready', () => { + return true; + }); + patch(perp2, 'ready', () => { + return true; + }); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGasPrice = () => { + patch(ethereum, 'gasPrice', () => 100); +}; + +const patchMarket = () => { + patch(perp.perp, 'markets', () => { + return { + getMarket() { + return { + getPrices() { + return { + markPrice: new Big('1'), + indexPrice: new Big('2'), + indexTwapPrice: new Big('3'), + }; + }, + async getStatus() { + return MarketStatus.ACTIVE; + }, + }; + }, + get marketMap() { + return { + AAVEUSD: 1, + WETHUSD: 2, + WBTCUSD: 3, + }; + }, + }; + }); +}; + +const patchPosition = () => { + patch(perp.perp, 'positions', () => { + return { + getTakerPositionByTickerSymbol() { + return; + }, + getTotalPendingFundingPayments() { + return {}; + }, + }; + }); +}; + +const patchCH = () => { + patch(perp.perp, 'clearingHouse', () => { + return { + createPositionDraft() { + return; + }, + async openPosition() { + return { + transaction: { + type: 2, + chainId: 42, + nonce: 115, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '100000' }, + to: '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9', // noqa: mock + v: 0, + r: '0xbeb9aa40028d79b9fdab108fcef5de635457a05f3a254410414c095b02c64643', // noqa: mock + s: '0x5a1506fa4b7f8b4f3826d8648f27ebaa9c0ee4bd67f569414b8cd8884c073100', // noqa: mock + from: address, + confirmations: 0, + }, + }; + }, + async getAccountValue() { + return new Big('10'); + }, + }; + }); +}; + +describe('POST /amm/perp/market-prices', () => { + it('should return 200 with right parameter', async () => { + patchMarket(); + + await request(app) + .post(`/amm/perp/market-prices`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + quote: 'USD', + base: 'WETH', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.markPrice).toEqual('1'); + expect(res.body.indexPrice).toEqual('2'); + expect(res.body.indexTwapPrice).toEqual('3'); + }); + }); + + it('should return 500 with wrong paramters', async () => { + patchMarket(); + + await request(app) + .post(`/amm/perp/market-prices`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perpp', + quote: '1234', + base: 'WETH', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/perp/market-status', () => { + it('should return 200 with right parameter', async () => { + patchMarket(); + + await request(app) + .post(`/amm/perp/market-status`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + quote: 'USD', + base: 'WETH', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.isActive).toEqual(true); + }); + }); + + it('should return 500 with wrong paramters', async () => { + patchMarket(); + + await request(app) + .post(`/amm/perp/market-status`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perpp', + quote: '1234', + base: 'WETH', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/perp/pairs', () => { + it('should return list of available pairs', async () => { + patchMarket(); + + await request(app) + .post(`/amm/perp/pairs`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.pairs).toEqual(['AAVEUSD', 'WETHUSD', 'WBTCUSD']); + }); + }); +}); + +describe('POST /amm/perp/position', () => { + it('should return a default object of a perp position', async () => { + patchPosition(); + + await request(app) + .post(`/amm/perp/position`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + quote: 'USD', + base: 'WETH', + address: address, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body).toHaveProperty('positionAmt'); + expect(res.body).toHaveProperty('positionSide'); + expect(res.body).toHaveProperty('unrealizedProfit'); + expect(res.body).toHaveProperty('leverage'); + expect(res.body).toHaveProperty('entryPrice'); + expect(res.body).toHaveProperty('tickerSymbol'); + expect(res.body).toHaveProperty('pendingFundingPayment'); + }); + }); +}); + +describe('POST /amm/perp/balance', () => { + it('should return a account value', async () => { + patchCH(); + + await request(app) + .post(`/amm/perp/balance`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + address: address, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body).toHaveProperty('balance'); + }); + }); +}); + +describe('POST /amm/perp/open and /amm/perp/close', () => { + it('open should return with hash', async () => { + patchGasPrice(); + patchPosition(); + patchCH(); + + await request(app) + .post(`/amm/perp/open`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + quote: 'USD', + base: 'WETH', + amount: '0.01', + side: 'LONG', + address: address, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body).toHaveProperty('txHash'); + expect(res.body.nonce).toEqual(115); + }); + }); + + it('close should return error', async () => { + patchPosition(); + patchCH(); + + await request(app) + .post(`/amm/perp/close`) + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + quote: 'USD', + base: 'WETH', + address: address, + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/perp/estimateGas', () => { + it('should return 200 with right parameter', async () => { + patchGasPrice(); + + await request(app) + .post('/amm/perp/estimateGas') + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'perp', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('optimism'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + gasCostInEthString(100, perp.gasLimit) + ); + }); + }); + + it('should return 500 for invalid connector', async () => { + patchGasPrice(); + + await request(app) + .post('/amm/perp/estimateGas') + .send({ + chain: 'ethereum', + network: 'optimism', + connector: 'pangolin', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/ethereum/perp/perp.test.ts b/test/chains/ethereum/perp/perp.test.ts new file mode 100644 index 0000000000..4bf8c6a4f8 --- /dev/null +++ b/test/chains/ethereum/perp/perp.test.ts @@ -0,0 +1,187 @@ +jest.useFakeTimers(); +import { Perp } from '../../../../src/connectors/perp/perp'; +import { MarketStatus } from '@perp/sdk-curie'; +import { patch, unpatch } from '../../../services/patch'; +import { Big } from 'big.js'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let ethereum: Ethereum; +let perp: Perp; + +beforeAll(async () => { + ethereum = Ethereum.getInstance('optimism'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + perp = Perp.getInstance('ethereum', 'optimism'); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +const patchMarket = () => { + patch(perp.perp, 'markets', () => { + return { + getMarket() { + return { + getPrices() { + return { + markPrice: new Big('1'), + indexPrice: new Big('2'), + indexTwapPrice: new Big('3'), + }; + }, + async getStatus() { + return MarketStatus.ACTIVE; + }, + }; + }, + get marketMap() { + return { + AAVEUSD: 1, + WETHUSD: 2, + WBTCUSD: 3, + }; + }, + }; + }); +}; + +const patchPosition = () => { + patch(perp.perp, 'positions', () => { + return { + getTakerPositionByTickerSymbol() { + return; + }, + getTotalPendingFundingPayments() { + return {}; + }, + }; + }); +}; + +const patchCH = () => { + patch(perp.perp, 'clearingHouse', () => { + return { + createPositionDraft() { + return; + }, + async openPosition() { + return { + transaction: { + type: 2, + chainId: 42, + nonce: 115, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '100000' }, + to: '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9', // noqa: mock + v: 0, + r: '0xbeb9aa40028d79b9fdab108fcef5de635457a05f3a254410414c095b02c64643', // noqa: mock + s: '0x5a1506fa4b7f8b4f3826d8648f27ebaa9c0ee4bd67f569414b8cd8884c073100', // noqa: mock + from: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + confirmations: 0, + }, + }; + }, + async getAccountValue() { + return new Big('10'); + }, + }; + }); +}; + +describe('verify market functions', () => { + it('available pairs should return a list of pairs', async () => { + patchMarket(); + + const pairs = perp.availablePairs(); + expect(pairs).toEqual(['AAVEUSD', 'WETHUSD', 'WBTCUSD']); + }); + + it('tickerSymbol should return prices', async () => { + patchMarket(); + + const prices = await perp.prices('AAVEUSD'); + expect(prices.markPrice.toString()).toEqual('1'); + expect(prices.indexPrice.toString()).toEqual('2'); + expect(prices.indexTwapPrice.toString()).toEqual('3'); + }); + + it('market state should return boolean', async () => { + patchMarket(); + + const state = await perp.isMarketActive('AAVEUSD'); + expect(state).toEqual(true); + }); +}); + +describe('verify perp position', () => { + it('getPositions should return data', async () => { + patchPosition(); + + const pos = await perp.getPositions('AAVEUSD'); + expect(pos).toHaveProperty('positionAmt'); + expect(pos).toHaveProperty('positionSide'); + expect(pos).toHaveProperty('unrealizedProfit'); + expect(pos).toHaveProperty('leverage'); + expect(pos).toHaveProperty('entryPrice'); + expect(pos).toHaveProperty('tickerSymbol'); + expect(pos).toHaveProperty('pendingFundingPayment'); + }); +}); + +describe('verify perp open/close position', () => { + it('openPosition should return', async () => { + patchCH(); + + const pos = await perp.openPosition(true, 'AAVEUSD', '0.01', '1/10'); + expect(pos.hash).toEqual( + '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9' // noqa: mock + ); + }); + + it('getAccountValue should return', async () => { + patchCH(); + + const bal = await perp.getAccountValue(); + expect(bal.toString()).toEqual('10'); + }); + + it('closePosition should throw', async () => { + patchPosition(); + patchCH(); + + await expect(async () => { + await perp.closePosition('AAVEUSD', '1/10'); + }).rejects.toThrow(new Error(`No active position on AAVEUSD.`)); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = perp.getAllowedSlippage('1/100'); + expect(allowedSlippage).toEqual(0.01); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = perp.getAllowedSlippage(); + expect(allowedSlippage).toEqual(0.02); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = perp.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(0.02); + }); +}); diff --git a/test/chains/ethereum/sushiswap/sushiswap.routes.test.ts b/test/chains/ethereum/sushiswap/sushiswap.routes.test.ts new file mode 100644 index 0000000000..c3c950a138 --- /dev/null +++ b/test/chains/ethereum/sushiswap/sushiswap.routes.test.ts @@ -0,0 +1,669 @@ +import express from 'express'; +import { Express } from 'express-serve-static-core'; +import request from 'supertest'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { Sushiswap } from '../../../../src/connectors/sushiswap/sushiswap'; +import { AmmRoutes } from '../../../../src/amm/amm.routes'; +import { patch, unpatch } from '../../../services/patch'; +import { gasCostInEthString } from '../../../../src/services/base'; +let app: Express; +let ethereum: Ethereum; +let sushiswap: Sushiswap; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + ethereum = Ethereum.getInstance('kovan'); + await ethereum.init(); + sushiswap = Sushiswap.getInstance('ethereum', 'kovan'); + await sushiswap.init(); + app.use('/amm', AmmRoutes.router); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(ethereum, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchInit = () => { + patch(sushiswap, 'init', async () => { + return; + }); +}; + +const patchStoredTokenList = () => { + patch(ethereum, 'tokenList', () => { + return [ + { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(ethereum, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(sushiswap, 'getTokenByAddress', () => { + return { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(ethereum, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(sushiswap, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(sushiswap, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(ethereum.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(sushiswap, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10.000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10.000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(sushiswap, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(sushiswap, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 500 for BUY with price smaller than limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 404 when parameters are incorrect', async () => { + patchInit(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(sushiswap, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(sushiswap, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/estimateGas', () => { + it('should return 200 for valid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'sushiswap', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('kovan'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + gasCostInEthString(100, sushiswap.gasLimitEstimate) + ); + }); + }); + + it('should return 500 for invalid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'pangolin', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/ethereum/sushiswap/sushiswap.test.ts b/test/chains/ethereum/sushiswap/sushiswap.test.ts new file mode 100644 index 0000000000..e93b3a6da1 --- /dev/null +++ b/test/chains/ethereum/sushiswap/sushiswap.test.ts @@ -0,0 +1,135 @@ +jest.useFakeTimers(); +import { Sushiswap } from '../../../../src/connectors/sushiswap/sushiswap'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError as SushiswapishPriceError } from '../../../../src/services/error-handler'; +import { + Token, + CurrencyAmount, + Trade, + Pair, + TradeType, + Route, +} from '@sushiswap/sdk'; +import { BigNumber } from 'ethers'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let ethereum: Ethereum; +let sushiswap: Sushiswap; + +const WETH = new Token( + 3, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); +const DAI = new Token( + 3, + '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + 18, + 'DAI' +); + +beforeAll(async () => { + ethereum = Ethereum.getInstance('kovan'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + sushiswap = Sushiswap.getInstance('ethereum', 'kovan'); + await sushiswap.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const patchFetchData = () => { + patch(sushiswap, 'fetchData', () => { + return new Pair( + CurrencyAmount.fromRawAmount(WETH, '2000000000000000000'), + CurrencyAmount.fromRawAmount(DAI, '1000000000000000000') + ); + }); +}; +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WETH_DAI = new Pair( + CurrencyAmount.fromRawAmount(WETH, '2000000000000000000'), + CurrencyAmount.fromRawAmount(DAI, '1000000000000000000') + ); + const DAI_TO_WETH = new Route([WETH_DAI], DAI, WETH); + return [ + new Trade( + DAI_TO_WETH, + CurrencyAmount.fromRawAmount(DAI, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify Sushiswap estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await sushiswap.estimateSellTrade( + WETH, + DAI, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await sushiswap.estimateSellTrade(WETH, DAI, BigNumber.from(1)); + }).rejects.toThrow(SushiswapishPriceError); + }); +}); + +describe('verify sushiswap estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await sushiswap.estimateBuyTrade( + WETH, + DAI, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await sushiswap.estimateBuyTrade(WETH, DAI, BigNumber.from(1)); + }).rejects.toThrow(SushiswapishPriceError); + }); +}); + +describe('verify sushiswap Token List', () => { + it('Should return a token by address', async () => { + const token = sushiswap.getTokenByAddress( + '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa' + ); + expect(token).toBeInstanceOf(Token); + }); +}); diff --git a/test/chains/ethereum/uniswap/uniswap.lp.routes.test.ts b/test/chains/ethereum/uniswap/uniswap.lp.routes.test.ts new file mode 100644 index 0000000000..7b6d930c95 --- /dev/null +++ b/test/chains/ethereum/uniswap/uniswap.lp.routes.test.ts @@ -0,0 +1,442 @@ +import express from 'express'; +import { Express } from 'express-serve-static-core'; +import request from 'supertest'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { UniswapLP } from '../../../../src/connectors/uniswap/uniswap.lp'; +import { AmmLiquidityRoutes } from '../../../../src/amm/amm.routes'; +import { patch, unpatch } from '../../../services/patch'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let app: Express; +let ethereum: Ethereum; +let uniswap: UniswapLP; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + ethereum = Ethereum.getInstance('kovan'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + uniswap = UniswapLP.getInstance('ethereum', 'kovan'); + await uniswap.init(); + app.use('/amm/liquidity', AmmLiquidityRoutes.router); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(ethereum, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchInit = () => { + patch(uniswap, 'init', async () => { + return; + }); +}; + +const patchStoredTokenList = () => { + patch(ethereum, 'tokenList', () => { + return [ + { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(ethereum, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(uniswap, 'getTokenByAddress', () => { + return { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(ethereum, 'gasPrice', () => 100); +}; + +const patchGetNonce = () => { + patch(ethereum.nonceManager, 'getNonce', () => 21); +}; + +const patchAddPosition = () => { + patch(uniswap, 'addPosition', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +const patchRemovePosition = () => { + patch(uniswap, 'reducePosition', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +const patchCollectFees = () => { + patch(uniswap, 'collectFees', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +const patchPosition = () => { + patch(uniswap, 'getPosition', () => { + return { + token0: 'DAI', + token1: 'WETH', + fee: 300, + lowerPrice: '1', + upperPrice: '5', + amount0: '1', + amount1: '1', + unclaimedToken0: '1', + unclaimedToken1: '1', + }; + }); +}; + +describe('POST /liquidity/add', () => { + it('should return 200 when all parameter are OK', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchAddPosition(); + patchGetNonce(); + + await request(app) + .post(`/amm/liquidity/add`) + .send({ + address: address, + token0: 'DAI', + token1: 'WETH', + amount0: '1', + amount1: '1', + fee: 'LOW', + lowerPrice: '1', + upperPrice: '5', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 500 for unrecognized token0 symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + + await request(app) + .post(`/amm/liquidity/add`) + .send({ + address: address, + token0: 'DOGE', + token1: 'WETH', + amount0: '1', + amount1: '1', + fee: 'LOW', + lowerPrice: '1', + upperPrice: '5', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 404 for invalid fee tier', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/liquidity/add`) + .send({ + address: address, + token0: 'DAI', + token1: 'WETH', + amount0: '1', + amount1: '1', + fee: 300, + lowerPrice: '1', + upperPrice: '5', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when the helper operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(uniswap, 'addPositionHelper', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/liquidity/add`) + .send({ + address: address, + token0: 'DAI', + token1: 'WETH', + amount0: '1', + amount1: '1', + fee: 'LOW', + lowerPrice: '1', + upperPrice: '5', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /liquidity/remove', () => { + const patchForBuy = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchRemovePosition(); + patchGetNonce(); + }; + it('should return 200 when all parameter are OK', async () => { + patchForBuy(); + await request(app) + .post(`/amm/liquidity/remove`) + .send({ + address: address, + tokenId: 2732, + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when the tokenId is invalid', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/liquidity/remove`) + .send({ + address: address, + tokenId: 'Invalid', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(404); + }); +}); + +describe('POST /liquidity/collect_fees', () => { + const patchForBuy = () => { + patchGetWallet(); + patchInit(); + patchGasPrice(); + patchCollectFees(); + patchGetNonce(); + }; + it('should return 200 when all parameter are OK', async () => { + patchForBuy(); + await request(app) + .post(`/amm/liquidity/collect_fees`) + .send({ + address: address, + tokenId: 2732, + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when the tokenId is invalid', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/liquidity/collect_fees`) + .send({ + address: address, + tokenId: 'Invalid', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(404); + }); +}); + +describe('POST /liquidity/position', () => { + it('should return 200 when all parameter are OK', async () => { + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchPosition(); + + await request(app) + .post(`/amm/liquidity/position`) + .send({ + tokenId: 2732, + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when the tokenId is invalid', async () => { + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/liquidity/position`) + .send({ + tokenId: 'Invalid', + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(404); + }); +}); + +describe('POST /liquidity/price', () => { + const patchForBuy = () => { + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(uniswap, 'poolPrice', () => { + return ['100', '105']; + }); + }; + it('should return 200 when all parameter are OK', async () => { + patchForBuy(); + await request(app) + .post(`/amm/liquidity/price`) + .send({ + token0: 'DAI', + token1: 'WETH', + fee: 'LOW', + period: 120, + interval: 60, + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when the fee is invalid', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/liquidity/price`) + .send({ + token0: 'DAI', + token1: 'WETH', + fee: 11, + period: 120, + interval: 60, + chain: 'ethereum', + network: 'kovan', + connector: 'uniswapLP', + }) + .set('Accept', 'application/json') + .expect(404); + }); +}); diff --git a/test/chains/ethereum/uniswap/uniswap.lp.test.ts b/test/chains/ethereum/uniswap/uniswap.lp.test.ts new file mode 100644 index 0000000000..08448a3a6c --- /dev/null +++ b/test/chains/ethereum/uniswap/uniswap.lp.test.ts @@ -0,0 +1,285 @@ +jest.useFakeTimers(); +import { Token } from '@uniswap/sdk-core'; +import * as uniV3 from '@uniswap/v3-sdk'; +import { BigNumber, Transaction, Wallet } from 'ethers'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { UniswapLP } from '../../../../src/connectors/uniswap/uniswap.lp'; +import { patch, unpatch } from '../../../services/patch'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let ethereum: Ethereum; +let uniswapLP: UniswapLP; +let wallet: Wallet; + +const WETH = new Token( + 42, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); + +const DAI = new Token( + 42, + '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + 18, + 'DAI' +); + +const USDC = new Token( + 42, + '0x2F375e94FC336Cdec2Dc0cCB5277FE59CBf1cAe5', + 18, + 'DAI' +); + +const TX = { + type: 2, + chainId: 42, + nonce: 115, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '100000' }, + to: '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9', // noqa: mock + v: 0, + r: '0xbeb9aa40028d79b9fdab108fcef5de635457a05f3a254410414c095b02c64643', // noqa: mock + s: '0x5a1506fa4b7f8b4f3826d8648f27ebaa9c0ee4bd67f569414b8cd8884c073100', // noqa: mock + from: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + confirmations: 0, +}; + +const POOL_SQRT_RATIO_START = uniV3.encodeSqrtRatioX96(100e6, 100e18); + +const POOL_TICK_CURRENT = uniV3.TickMath.getTickAtSqrtRatio( + POOL_SQRT_RATIO_START +); + +const DAI_USDC_POOL = new uniV3.Pool( + DAI, + USDC, + 500, + POOL_SQRT_RATIO_START, + 0, + POOL_TICK_CURRENT, + [] +); + +beforeAll(async () => { + ethereum = Ethereum.getInstance('kovan'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + wallet = new Wallet( + '0000000000000000000000000000000000000000000000000000000000000002', // noqa: mock + ethereum.provider + ); + uniswapLP = UniswapLP.getInstance('ethereum', 'kovan'); + await uniswapLP.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const patchPoolState = () => { + patch(uniswapLP, 'getPoolContract', () => { + return { + liquidity() { + return DAI_USDC_POOL.liquidity; + }, + slot0() { + return [ + DAI_USDC_POOL.sqrtRatioX96, + DAI_USDC_POOL.tickCurrent, + 0, + 1, + 1, + 0, + true, + ]; + }, + ticks() { + return ['-118445039955967015140', '118445039955967015140']; + }, + }; + }); +}; + +const patchAlphaRouter = () => { + patch(uniswapLP.alphaRouter, 'routeToRatio', () => { + return { status: 3 }; + }); +}; + +const patchContract = () => { + patch(uniswapLP, 'getContract', () => { + return { + estimateGas: { + multicall() { + return BigNumber.from(5); + }, + }, + positions() { + return { + token0: WETH.address, + token1: USDC.address, + fee: 500, + tickLower: 0, + tickUpper: 23030, + liquidity: '6025055903594410671025', + }; + }, + multicall() { + return TX; + }, + collect() { + return TX; + }, + }; + }); +}; + +const patchWallet = () => { + patch(wallet, 'sendTransaction', () => { + return TX; + }); +}; + +describe('verify UniswapLP Nft functions', () => { + it('Should return correct contract addresses', async () => { + expect(uniswapLP.router).toEqual( + '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45' + ); + expect(uniswapLP.nftManager).toEqual( + '0xC36442b4a4522E871399CD717aBDD847Ab11FE88' + ); + }); + + it('Should return correct contract abi', async () => { + expect(Array.isArray(uniswapLP.routerAbi)).toEqual(true); + expect(Array.isArray(uniswapLP.nftAbi)).toEqual(true); + expect(Array.isArray(uniswapLP.poolAbi)).toEqual(true); + }); + + it('addPositionHelper returns calldata and value', async () => { + patchPoolState(); + patchAlphaRouter(); + + const callData = await uniswapLP.addPositionHelper( + wallet, + DAI, + WETH, + '10', + '10', + 500, + 1, + 10 + ); + expect(callData).toHaveProperty('calldata'); + expect(callData).toHaveProperty('value'); + }); + + it('reducePositionHelper returns calldata and value', async () => { + patchPoolState(); + patchContract(); + + const callData = await uniswapLP.reducePositionHelper(wallet, 1, 100); + expect(callData).toHaveProperty('calldata'); + expect(callData).toHaveProperty('value'); + }); + + it('basic functions should work', async () => { + patchContract(); + patchPoolState(); + + expect(uniswapLP.ready()).toEqual(true); + expect(uniswapLP.gasLimitEstimate).toBeGreaterThan(0); + expect(typeof uniswapLP.getContract('nft', ethereum.provider)).toEqual( + 'object' + ); + expect( + typeof uniswapLP.getPoolContract( + '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + wallet + ) + ).toEqual('object'); + }); + + it('generateOverrides returns overrides correctly', async () => { + const overrides = uniswapLP.generateOverrides( + 1, + 2, + 3, + BigNumber.from(4), + BigNumber.from(5), + '6' + ); + expect(overrides.gasLimit).toEqual(BigNumber.from('1')); + expect(overrides.gasPrice).toBeUndefined(); + expect(overrides.nonce).toEqual(BigNumber.from(3)); + expect(overrides.maxFeePerGas as BigNumber).toEqual(BigNumber.from(4)); + expect(overrides.maxPriorityFeePerGas as BigNumber).toEqual( + BigNumber.from(5) + ); + expect(overrides.value).toEqual(BigNumber.from('6')); + }); + + it('reducePosition should work', async () => { + patchPoolState(); + patchContract(); + + const reduceTx = (await uniswapLP.reducePosition( + wallet, + 1, + 100, + 50000, + 10 + )) as Transaction; + expect(reduceTx.hash).toEqual( + '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9' // noqa: mock + ); + }); + + it('addPosition should work', async () => { + patchPoolState(); + patchWallet(); + patchAlphaRouter(); + + const addTx = await uniswapLP.addPosition( + wallet, + DAI, + WETH, + '10', + '10', + 500, + 1, + 10, + 0, + 1, + 1 + ); + expect(addTx.hash).toEqual( + '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9' // noqa: mock + ); + }); + + it('collectFees should work', async () => { + patchContract(); + + const collectTx = (await uniswapLP.collectFees(wallet, 1)) as Transaction; + expect(collectTx.hash).toEqual( + '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9' // noqa: mock + ); + }); +}); diff --git a/test/chains/ethereum/uniswap/uniswap.routes.test.ts b/test/chains/ethereum/uniswap/uniswap.routes.test.ts new file mode 100644 index 0000000000..e16539c040 --- /dev/null +++ b/test/chains/ethereum/uniswap/uniswap.routes.test.ts @@ -0,0 +1,678 @@ +import express from 'express'; +import { Express } from 'express-serve-static-core'; +import request from 'supertest'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { Uniswap } from '../../../../src/connectors/uniswap/uniswap'; +import { AmmRoutes } from '../../../../src/amm/amm.routes'; +import { patch, unpatch } from '../../../services/patch'; +import { gasCostInEthString } from '../../../../src/services/base'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let app: Express; +let ethereum: Ethereum; +let uniswap: Uniswap; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + + ethereum = Ethereum.getInstance('kovan'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + uniswap = Uniswap.getInstance('ethereum', 'kovan'); + await uniswap.init(); + + app.use('/amm', AmmRoutes.router); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(ethereum, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchInit = () => { + patch(uniswap, 'init', async () => { + return; + }); +}; + +const patchStoredTokenList = () => { + patch(ethereum, 'tokenList', () => { + return [ + { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(ethereum, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(uniswap, 'getTokenByAddress', () => { + return { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(ethereum, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(uniswap, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(uniswap, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(ethereum.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(uniswap, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10.000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'SHIBA', + amount: '10.000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(uniswap, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(uniswap, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 500 for BUY with price smaller than limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 404 when parameters are incorrect', async () => { + patchInit(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(uniswap, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(uniswap, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + quote: 'DAI', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/estimateGas', () => { + it('should return 200 for valid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'uniswap', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('kovan'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + gasCostInEthString(100, uniswap.gasLimitEstimate) + ); + }); + }); + + it('should return 500 for invalid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'ethereum', + network: 'kovan', + connector: 'pangolin', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/ethereum/uniswap/uniswap.test.ts b/test/chains/ethereum/uniswap/uniswap.test.ts new file mode 100644 index 0000000000..d34f3fae22 --- /dev/null +++ b/test/chains/ethereum/uniswap/uniswap.test.ts @@ -0,0 +1,156 @@ +jest.useFakeTimers(); +import { Uniswap } from '../../../../src/connectors/uniswap/uniswap'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { CurrencyAmount, Percent, TradeType, Token } from '@uniswap/sdk-core'; +import { Pair, Route } from '@uniswap/v2-sdk'; +import { Trade } from '@uniswap/router-sdk'; +import { BigNumber, utils } from 'ethers'; +import { Ethereum } from '../../../../src/chains/ethereum/ethereum'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let ethereum: Ethereum; +let uniswap: Uniswap; + +const WETH = new Token( + 3, + '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + 18, + 'WETH' +); + +const DAI = new Token( + 3, + '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + 18, + 'DAI' +); + +beforeAll(async () => { + ethereum = Ethereum.getInstance('kovan'); + patchEVMNonceManager(ethereum.nonceManager); + await ethereum.init(); + + uniswap = Uniswap.getInstance('ethereum', 'kovan'); + await uniswap.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(ethereum.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await ethereum.close(); +}); + +const patchTrade = (_key: string, error?: Error) => { + patch(uniswap.alphaRouter, 'route', () => { + if (error) return false; + const WETH_DAI = new Pair( + CurrencyAmount.fromRawAmount(WETH, '2000000000000000000'), + CurrencyAmount.fromRawAmount(DAI, '1000000000000000000') + ); + const DAI_TO_WETH = new Route([WETH_DAI], DAI, WETH); + return { + quote: CurrencyAmount.fromRawAmount(DAI, '1000000000000000000'), + quoteGasAdjusted: CurrencyAmount.fromRawAmount( + DAI, + '1000000000000000000' + ), + estimatedGasUsed: utils.parseEther('100'), + estimatedGasUsedQuoteToken: CurrencyAmount.fromRawAmount( + DAI, + '1000000000000000000' + ), + estimatedGasUsedUSD: CurrencyAmount.fromRawAmount( + DAI, + '1000000000000000000' + ), + gasPriceWei: utils.parseEther('100'), + trade: new Trade({ + v2Routes: [ + { + routev2: DAI_TO_WETH, + inputAmount: CurrencyAmount.fromRawAmount( + DAI, + '1000000000000000000' + ), + outputAmount: CurrencyAmount.fromRawAmount( + WETH, + '2000000000000000000' + ), + }, + ], + v3Routes: [], + tradeType: TradeType.EXACT_INPUT, + }), + route: [], + blockNumber: BigNumber.from(5000), + }; + }); +}; + +describe('verify Uniswap estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchTrade('bestTradeExactIn'); + + const expectedTrade = await uniswap.estimateSellTrade( + WETH, + DAI, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await uniswap.estimateSellTrade(WETH, DAI, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify Uniswap estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchTrade('bestTradeExactOut'); + + const expectedTrade = await uniswap.estimateBuyTrade( + WETH, + DAI, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await uniswap.estimateBuyTrade(WETH, DAI, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = uniswap.getAllowedSlippage('1/100'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = uniswap.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('2', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = uniswap.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('2', '100')); + }); +}); diff --git a/test/chains/harmony/defikingdoms/defikingdoms.routes.test.ts b/test/chains/harmony/defikingdoms/defikingdoms.routes.test.ts new file mode 100644 index 0000000000..a1328d7826 --- /dev/null +++ b/test/chains/harmony/defikingdoms/defikingdoms.routes.test.ts @@ -0,0 +1,669 @@ +import express from 'express'; +import { Express } from 'express-serve-static-core'; +import request from 'supertest'; +import { Harmony } from '../../../../src/chains/harmony/harmony'; +import { Defikingdoms } from '../../../../src/connectors/defikingdoms/defikingdoms'; +import { AmmRoutes } from '../../../../src/amm/amm.routes'; +import { patch, unpatch } from '../../../services/patch'; +import { gasCostInEthString } from '../../../../src/services/base'; +let app: Express; +let harmony: Harmony; +let defikingdoms: Defikingdoms; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + harmony = Harmony.getInstance('mainnet'); + await harmony.init(); + defikingdoms = Defikingdoms.getInstance('harmony', 'mainnet'); + await defikingdoms.init(); + app.use('/amm', AmmRoutes.router); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(harmony, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchInit = () => { + patch(defikingdoms, 'init', async () => { + return; + }); +}; + +const patchStoredTokenList = () => { + patch(harmony, 'tokenList', () => { + return [ + { + chainId: 1666700000, + name: 'WONE74', + symbol: 'WONE74', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }, + { + chainId: 1666700000, + name: 'OneETH', + symbol: '1ETH', + address: '0x1E120B3b4aF96e7F394ECAF84375b1C661830013', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(harmony, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WONE74') { + return { + chainId: 1666700000, + name: 'WONE74', + symbol: 'WONE74', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } else { + return { + chainId: 1666700000, + name: 'OneETH', + symbol: '1ETH', + address: '0x1E120B3b4aF96e7F394ECAF84375b1C661830013', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(defikingdoms, 'getTokenByAddress', () => { + return { + chainId: 1666700000, + name: 'WONE74', + symbol: 'WONE74', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(harmony, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(defikingdoms, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(defikingdoms, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(harmony.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(defikingdoms, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: 'DOGE', + base: 'WONE74', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'SHIBA', + amount: '10.000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'SHIBA', + amount: '10.000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defikingdoms, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: 'DOGE', + base: 'WONE74', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defikingdoms, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: 'DOGE', + base: 'WONE74', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 500 for BUY with price smaller than limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 404 when parameters are incorrect', async () => { + patchInit(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defikingdoms, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defikingdoms, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/estimateGas', () => { + it('should return 200 for valid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'defikingdoms', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('mainnet'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + gasCostInEthString(100, defikingdoms.gasLimitEstimate) + ); + }); + }); + + it('should return 500 for invalid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'harmony', + network: 'mainnet', + connector: 'pangolin', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/harmony/defikingdoms/defikingdoms.test.ts b/test/chains/harmony/defikingdoms/defikingdoms.test.ts new file mode 100644 index 0000000000..679e001f05 --- /dev/null +++ b/test/chains/harmony/defikingdoms/defikingdoms.test.ts @@ -0,0 +1,151 @@ +jest.useFakeTimers(); +import { Defikingdoms } from '../../../../src/connectors/defikingdoms/defikingdoms'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { + Token, + TokenAmount, + TradeType, + Trade, + Pair, + Route, + Percent, +} from '@switchboard-xyz/defikingdoms-sdk'; +import { BigNumber } from 'ethers'; +import { Harmony } from '../../../../src/chains/harmony/harmony'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +import { DefikingdomsConfig } from '../../../../src/connectors/defikingdoms/defikingdoms.config'; + +let harmony: Harmony; +let defikingdoms: Defikingdoms; + +const WONE = new Token( + 1666600000, + '0xcF664087a5bB0237a0BAd6742852ec6c8d69A27a', + 18, + 'WONE' +); +const ETH = new Token( + 1666600000, + '0x6983D1E6DEf3690C4d616b13597A09e6193EA013', + 18, + 'ETH' +); + +beforeAll(async () => { + harmony = Harmony.getInstance('mainnet'); + patchEVMNonceManager(harmony.nonceManager); + + defikingdoms = Defikingdoms.getInstance('harmony', 'mainnet'); + await defikingdoms.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(harmony.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +const patchFetchData = () => { + patch(defikingdoms, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WONE, '2000000000000000000'), + new TokenAmount(ETH, '1000000000000000000') + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WONE_ETH = new Pair( + new TokenAmount(WONE, '2000000000000000000'), + new TokenAmount(ETH, '1000000000000000000') + ); + const ETH_TO_WONE = new Route([WONE_ETH], ETH, WONE); + return [ + new Trade( + ETH_TO_WONE, + new TokenAmount(ETH, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify defikingdoms gasLimit', () => { + it('Should initially match the config for mainnet', () => { + expect(defikingdoms.gasLimitEstimate).toEqual( + DefikingdomsConfig.config.gasLimit + ); + }); +}); + +describe('verify defikingdoms getAllowedSlippage', () => { + it('Should parse simple fractions', () => { + expect(defikingdoms.getAllowedSlippage('3/100')).toEqual( + new Percent('3', '100') + ); + }); +}); + +describe('verify defikingdoms estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await defikingdoms.estimateSellTrade( + WONE, + ETH, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await defikingdoms.estimateSellTrade(WONE, ETH, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify defikingdoms estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await defikingdoms.estimateBuyTrade( + WONE, + ETH, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await defikingdoms.estimateBuyTrade(WONE, ETH, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify defikingdoms Token List', () => { + it('Should return a token by address', async () => { + const token = defikingdoms.getTokenByAddress(ETH.address); + expect(token).toBeInstanceOf(Token); + }); +}); diff --git a/test/chains/harmony/defira/defira.routes.test.ts b/test/chains/harmony/defira/defira.routes.test.ts new file mode 100644 index 0000000000..e77df3350b --- /dev/null +++ b/test/chains/harmony/defira/defira.routes.test.ts @@ -0,0 +1,669 @@ +import express from 'express'; +import { Express } from 'express-serve-static-core'; +import request from 'supertest'; +import { Harmony } from '../../../../src/chains/harmony/harmony'; +import { Defira } from '../../../../src/connectors/defira/defira'; +import { AmmRoutes } from '../../../../src/amm/amm.routes'; +import { patch, unpatch } from '../../../services/patch'; +import { gasCostInEthString } from '../../../../src/services/base'; +let app: Express; +let harmony: Harmony; +let defira: Defira; + +beforeAll(async () => { + app = express(); + app.use(express.json()); + harmony = Harmony.getInstance('testnet'); + await harmony.init(); + defira = Defira.getInstance('harmony', 'testnet'); + await defira.init(); + app.use('/amm', AmmRoutes.router); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(harmony, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchInit = () => { + patch(defira, 'init', async () => { + return; + }); +}; + +const patchStoredTokenList = () => { + patch(harmony, 'tokenList', () => { + return [ + { + chainId: 1666700000, + name: 'WONE74', + symbol: 'WONE74', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }, + { + chainId: 1666700000, + name: 'OneETH', + symbol: '1ETH', + address: '0x1E120B3b4aF96e7F394ECAF84375b1C661830013', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(harmony, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WONE74') { + return { + chainId: 1666700000, + name: 'WONE74', + symbol: 'WONE74', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } else { + return { + chainId: 1666700000, + name: 'OneETH', + symbol: '1ETH', + address: '0x1E120B3b4aF96e7F394ECAF84375b1C661830013', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(defira, 'getTokenByAddress', () => { + return { + chainId: 1666700000, + name: 'WONE74', + symbol: 'WONE74', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(harmony, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(defira, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(defira, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(harmony.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(defira, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: 'DOGE', + base: 'WONE74', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and SELL', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'SHIBA', + amount: '10.000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol with decimals in the amount and BUY', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'SHIBA', + amount: '10.000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defira, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: 'DOGE', + base: 'WONE74', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defira, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/price`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: 'DOGE', + base: 'WONE74', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 500 for BUY with price smaller than limitPrice', async () => { + patchForBuy(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 404 when parameters are incorrect', async () => { + patchInit(); + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + it('should return 500 when the priceSwapIn operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defira, 'priceSwapIn', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when the priceSwapOut operation fails', async () => { + patchGetWallet(); + patchInit(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patch(defira, 'priceSwapOut', () => { + return 'error'; + }); + + await request(app) + .post(`/amm/trade`) + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + quote: '1ETH', + base: 'WONE74', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/estimateGas', () => { + it('should return 200 for valid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'defira', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('testnet'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + gasCostInEthString(100, defira.gasLimitEstimate) + ); + }); + }); + + it('should return 500 for invalid connector', async () => { + patchInit(); + patchGasPrice(); + + await request(app) + .post('/amm/estimateGas') + .send({ + chain: 'harmony', + network: 'testnet', + connector: 'pangolin', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/harmony/defira/defira.test.ts b/test/chains/harmony/defira/defira.test.ts new file mode 100644 index 0000000000..72335e3088 --- /dev/null +++ b/test/chains/harmony/defira/defira.test.ts @@ -0,0 +1,182 @@ +jest.useFakeTimers(); +const { MockProvider } = require('mock-ethers-provider'); +import { FACTORY_ADDRESS } from '@zuzu-cat/defira-sdk'; +import { Defira } from '../../../../src/connectors/defira/defira'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { Token, CurrencyAmount, TradeType, Percent } from '@uniswap/sdk-core'; +import { Trade, Pair, Route } from '@zuzu-cat/defira-sdk'; +import { BigNumber } from 'ethers'; +import { Harmony } from '../../../../src/chains/harmony/harmony'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +import { DefiraConfig } from '../../../../src/connectors/defira/defira.config'; +import { abi as routerAbi } from '../../../../src/connectors/defira/defira_v2_router_abi.json'; + +let harmony: Harmony; +let defira: Defira; + +const WONE = new Token( + 3, + '0x1E120B3b4aF96e7F394ECAF84375b1C661830013', + 18, + 'WONE' +); +const ETH = new Token( + 3, + '0x7466d7d0C21Fa05F32F5a0Fa27e12bdC06348Ce2', + 18, + 'ETH' +); + +let mockProvider: typeof MockProvider; + +beforeAll(async () => { + harmony = Harmony.getInstance('testnet'); + patchEVMNonceManager(harmony.nonceManager); + + defira = Defira.getInstance('harmony', 'testnet'); + await defira.init(); +}); + +beforeEach(() => { + mockProvider = new MockProvider(); + patchEVMNonceManager(harmony.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +const patchMockProvider = () => { + mockProvider.setMockContract( + DefiraConfig.config.routerAddress('testnet'), + routerAbi + ); + patch(defira, 'provider', () => { + return mockProvider; + }); +}; + +const patchFetchData = () => { + patch(defira, 'fetchPairData', () => { + return new Pair( + CurrencyAmount.fromRawAmount(WONE, '2000000000000000000'), + CurrencyAmount.fromRawAmount(ETH, '1000000000000000000') + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WONE_ETH = new Pair( + CurrencyAmount.fromRawAmount(WONE, '2000000000000000000'), + CurrencyAmount.fromRawAmount(ETH, '1000000000000000000') + ); + const ETH_TO_WONE = new Route([WONE_ETH], ETH, WONE); + return [ + new Trade( + ETH_TO_WONE, + CurrencyAmount.fromRawAmount(ETH, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify defira gasLimitEstimate', () => { + it('Should initially match the config for mainnet', () => { + expect(defira.gasLimitEstimate).toEqual( + DefiraConfig.config.gasLimitEstimate() + ); + }); +}); + +describe('verify defira getAllowedSlippage', () => { + it('Should parse simple fractions', () => { + expect(defira.getAllowedSlippage('3/100')).toEqual(new Percent('3', '100')); + }); +}); + +describe('verify defira factory', () => { + const expectedFactoryAddress = FACTORY_ADDRESS; + beforeEach(() => { + patchMockProvider(); + mockProvider.stub( + DefiraConfig.config.routerAddress('testnet'), + 'factory', + expectedFactoryAddress + ); + }); + it('Returns the factory address via the provider', async () => { + const factoryAddress = await defira.factory; + expect(factoryAddress).toEqual(expectedFactoryAddress); + }); +}); + +describe('verify defira initCodeHash', () => { + it('Should return the testnet factory initCodeHash', () => { + expect(defira.initCodeHash).toEqual( + DefiraConfig.config.initCodeHash('testnet') + ); + }); +}); + +describe('verify defira estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await defira.estimateSellTrade( + WONE, + ETH, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await defira.estimateSellTrade(WONE, ETH, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify defira estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await defira.estimateBuyTrade( + WONE, + ETH, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await defira.estimateBuyTrade(WONE, ETH, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify defira Token List', () => { + it('Should return a token by address', async () => { + const token = defira.getTokenByAddress(ETH.address); + expect(token).toBeInstanceOf(Token); + }); +}); diff --git a/test/chains/harmony/harmony.controllers.test.ts b/test/chains/harmony/harmony.controllers.test.ts new file mode 100644 index 0000000000..94c767f0aa --- /dev/null +++ b/test/chains/harmony/harmony.controllers.test.ts @@ -0,0 +1,276 @@ +import { BigNumber } from 'ethers'; +import { Harmony } from '../../../src/chains/harmony/harmony'; +import { patch, unpatch } from '../../services/patch'; +import { TokenInfo } from '../../../src/services/ethereum-base'; +import { + nonce, + getTokenSymbolsToTokens, + allowances, + approve, + balances, + cancel, + willTxSucceed, +} from '../../../src/chains/ethereum/ethereum.controllers'; +import { + HttpException, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE, + TOKEN_NOT_SUPPORTED_ERROR_CODE, +} from '../../../src/services/error-handler'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; + +jest.useFakeTimers(); +let harmony: Harmony; + +beforeAll(async () => { + harmony = Harmony.getInstance('testnet'); + patchEVMNonceManager(harmony.nonceManager); + await harmony.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(harmony.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +const zeroAddress = + '0000000000000000000000000000000000000000000000000000000000000000'; // noqa: mock + +describe('nonce', () => { + it('return a nonce for a wallet', async () => { + patch(harmony, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + patch(harmony.nonceManager, 'getNonce', () => 2); + const n = await nonce(harmony, { + chain: 'harmony', + network: 'testnet', + address: zeroAddress, + }); + expect(n).toEqual({ nonce: 2 }); + }); +}); + +const wone: TokenInfo = { + chainId: 1666700000, + name: '"Wrapped ONE', + symbol: 'WONE', + address: '0x7a2afac38517d512E55C0bCe3b6805c10a04D60F', + decimals: 18, +}; +describe('getTokenSymbolsToTokens', () => { + it('return tokens for strings', () => { + patch(harmony, 'getTokenBySymbol', () => { + return wone; + }); + expect(getTokenSymbolsToTokens(harmony, ['WONE'])).toEqual({ WONE: wone }); + }); +}); + +const sushiswap = '0x1b02da8cb0d097eb8d57a175b88c7d8b47997506'; + +describe('allowances', () => { + it('return allowances for an owner, spender and tokens', async () => { + patch(harmony, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + + patch(harmony, 'getTokenBySymbol', () => { + return wone; + }); + + patch(harmony, 'getSpender', () => { + return sushiswap; + }); + + patch(harmony, 'getERC20Allowance', () => { + return { + value: BigNumber.from('999999999999999999999999'), + decimals: 2, + }; + }); + + const result = await allowances(harmony, { + chain: 'harmony', + network: 'testnet', + address: zeroAddress, + spender: sushiswap, + tokenSymbols: ['WONE'], + }); + expect((result as any).approvals).toEqual({ + WONE: '9999999999999999999999.99', + }); + }); +}); + +describe('approve', () => { + it('approve a spender for an owner, token and amount', async () => { + patch(harmony, 'getSpender', () => { + return sushiswap; + }); + harmony.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + patch(harmony, 'ready', () => true); + + patch(harmony, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + + patch(harmony, 'getTokenBySymbol', () => { + return wone; + }); + + patch(harmony, 'approveERC20', () => { + return { + spender: sushiswap, + value: { toString: () => '9999999' }, + }; + }); + + const result = await approve(harmony, { + chain: 'harmony', + network: 'testnet', + address: zeroAddress, + spender: sushiswap, + token: 'WONE', + }); + expect((result as any).spender).toEqual(sushiswap); + }); + + it('fail if wallet not found', async () => { + patch(harmony, 'getSpender', () => { + return sushiswap; + }); + + const err = 'wallet does not exist'; + patch(harmony, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + approve(harmony, { + chain: 'harmony', + network: 'testnet', + address: zeroAddress, + spender: sushiswap, + token: 'WONE', + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); + + it('fail if token not found', async () => { + patch(harmony, 'getSpender', () => { + return sushiswap; + }); + + patch(harmony, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); + + patch(harmony, 'getTokenBySymbol', () => { + return null; + }); + + await expect( + approve(harmony, { + chain: 'harmony', + network: 'testnet', + address: zeroAddress, + spender: sushiswap, + token: 'WONE', + }) + ).rejects.toThrow( + new HttpException( + 500, + TOKEN_NOT_SUPPORTED_ERROR_MESSAGE + 'WONE', + TOKEN_NOT_SUPPORTED_ERROR_CODE + ) + ); + }); +}); + +describe('balances', () => { + it('fail if wallet not found', async () => { + const err = 'wallet does not exist'; + patch(harmony, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + balances(harmony, { + chain: 'harmony', + network: 'testnet', + address: zeroAddress, + tokenSymbols: ['WONE', 'WBTC'], + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); +}); + +describe('cancel', () => { + it('fail if wallet not found', async () => { + const err = 'wallet does not exist'; + patch(harmony, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + cancel(harmony, { + chain: 'harmony', + network: 'testnet', + nonce: 123, + address: zeroAddress, + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); +}); + +describe('willTxSucceed', () => { + it('time limit met and gas price higher than that of the tx', () => { + expect(willTxSucceed(100, 10, 10, 100)).toEqual(false); + }); + + it('time limit met but gas price has not exceeded that of the tx', () => { + expect(willTxSucceed(100, 10, 100, 90)).toEqual(true); + }); + + it('time limit not met', () => { + expect(willTxSucceed(10, 100, 100, 90)).toEqual(true); + }); +}); diff --git a/test/chains/harmony/harmony.routes.test.ts b/test/chains/harmony/harmony.routes.test.ts new file mode 100644 index 0000000000..5b553965f1 --- /dev/null +++ b/test/chains/harmony/harmony.routes.test.ts @@ -0,0 +1,389 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { + NETWORK_ERROR_CODE, + OUT_OF_GAS_ERROR_CODE, + UNKNOWN_ERROR_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + OUT_OF_GAS_ERROR_MESSAGE, + UNKNOWN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import * as transactionSuccesful from '../ethereum/fixtures/transaction-succesful.json'; +import * as transactionSuccesfulReceipt from '../ethereum/fixtures/transaction-succesful-receipt.json'; +import * as transactionOutOfGas from '../ethereum/fixtures/transaction-out-of-gas.json'; +import * as transactionOutOfGasReceipt from '../ethereum/fixtures/transaction-out-of-gas-receipt.json'; +import { Harmony } from '../../../src/chains/harmony/harmony'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; +let harmony: Harmony; + +beforeAll(async () => { + harmony = Harmony.getInstance('testnet'); + patchEVMNonceManager(harmony.nonceManager); + await harmony.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(harmony.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(harmony, 'getWallet', () => { + return { + address, + }; + }); +}; + +const patchGetNonce = () => { + patch(harmony.nonceManager, 'getNonce', () => 2); +}; + +const patchGetTokenBySymbol = () => { + patch(harmony, 'getTokenBySymbol', () => { + return { + chainId: 1666600000, + address: '0xcF664087a5bB0237a0BAd6742852ec6c8d69A27a', + decimals: 18, + name: 'Wrapped ONE', + symbol: 'WONE', + logoURI: + 'https://raw.githubusercontent.com/sushiswap/icons/master/token/one.jpg', + }; + }); +}; + +const patchApproveERC20 = (tx_type?: string) => { + const default_tx = { + type: 2, + chainId: 1666600000, + nonce: 115, + maxPriorityFeePerGas: { toString: () => '106000000000' }, + maxFeePerGas: { toString: () => '106000000000' }, + gasPrice: { toString: () => null }, + gasLimit: { toString: () => '100000' }, + to: '0x4F96Fe3b7A6Cf9725f59d353F723c1bDb64CA6Aa', + value: { toString: () => '0' }, + data: '0x095ea7b30000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', // noqa: mock + accessList: [], + hash: '0x75f98675a8f64dcf14927ccde9a1d59b67fa09b72cc2642ad055dae4074853d9', // noqa: mock + v: 0, + r: '0xbeb9aa40028d79b9fdab108fcef5de635457a05f3a254410414c095b02c64643', // noqa: mock + s: '0x5a1506fa4b7f8b4f3826d8648f27ebaa9c0ee4bd67f569414b8cd8884c073100', // noqa: mock + from: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + confirmations: 0, + }; + if (tx_type === 'overwritten_tx') { + default_tx.hash = + '0x5a1ed682d0d7a58fbd7828bbf5994cd024feb8895d4da82c741ec4a191b9e849'; // noqa: mock + } + patch(harmony, 'approveERC20', () => { + return default_tx; + }); +}; + +const patchGetERC20Allowance = () => { + patch(harmony, 'getERC20Allowance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetNativeBalance = () => { + patch(harmony, 'getNativeBalance', () => ({ value: 1, decimals: 3 })); +}; + +const patchGetERC20Balance = () => { + patch(harmony, 'getERC20Balance', () => ({ value: 1, decimals: 3 })); +}; + +describe('POST /evm/nonce', () => { + it('should return 200', async () => { + patchGetWallet(); + patchGetNonce(); + + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'harmony', + network: 'testnet', + address, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.nonce).toBe(2)); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/nonce`) + .send({ + chain: 'harmony', + network: 'testnet', + address: 'da857cbda0ba96757fed842617a4', + }) + .expect(404); + }); +}); + +describe('POST /evm/approve', () => { + it('should return 200', async () => { + patchGetWallet(); + harmony.getContract = jest.fn().mockReturnValue({ + address, + }); + patch(harmony.nonceManager, 'getNonce', () => 115); + patchGetTokenBySymbol(); + patchApproveERC20(); + + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'harmony', + network: 'testnet', + address, + spender: 'sushiswap', + token: 'SUSHI', + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(115); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/approve`) + .send({ + chain: 'harmony', + network: 'testnet', + address, + spender: 'sushiswap', + token: 123, + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /evm/allowances', () => { + it('should return 200 asking for allowances', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + const spender = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + harmony.getSpender = jest.fn().mockReturnValue(spender); + harmony.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + patchGetERC20Allowance(); + + await request(gatewayApp) + .post(`/evm/allowances`) + .send({ + chain: 'harmony', + network: 'testnet', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: spender, + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.spender).toEqual(spender)) + .expect((res) => expect(res.body.approvals.WETH).toEqual('0.001')) + .expect((res) => expect(res.body.approvals.DAI).toEqual('0.001')); + }); +}); + +describe('POST /network/balances', () => { + it('should return 200 asking for supported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetERC20Balance(); + harmony.getContract = jest.fn().mockReturnValue({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }); + + await request(gatewayApp) + .post(`/network/balances`) + .send({ + chain: 'harmony', + network: 'testnet', + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + tokenSymbols: ['WETH', 'DAI'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.balances.WETH).toBeDefined()) + .expect((res) => expect(res.body.balances.DAI).toBeDefined()); + }); +}); + +describe('POST /evm/cancel', () => { + it('should return 200', async () => { + // override getWallet (network call) + harmony.getWallet = jest.fn().mockReturnValue({ + address, + }); + + harmony.cancelTx = jest.fn().mockReturnValue({ + hash: '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77', // noqa: mock + }); + + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'harmony', + network: 'testnet', + address, + nonce: 23, + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .then((res: any) => { + expect(res.body.txHash).toEqual( + '0xf6b9e7cec507cb3763a1179ff7e2a88c6008372e3a6f297d9027a0b39b0fff77' // noqa: mock + ); + }); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/evm/cancel`) + .send({ + chain: 'harmony', + network: 'testnet', + address: '', + nonce: '23', + }) + .expect(404); + }); +}); + +describe('POST /network/poll', () => { + it('should get a NETWORK_ERROR_CODE when the network is unavailable', async () => { + patch(harmony, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = 'NETWORK_ERROR'; + throw error; + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(NETWORK_ERROR_CODE); + expect(res.body.message).toEqual(NETWORK_ERROR_MESSAGE); + }); + + it('should get a UNKNOWN_ERROR_ERROR_CODE when an unknown error is thrown', async () => { + patch(harmony, 'getCurrentBlockNumber', () => { + throw new Error(); + }); + + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + }); + + it('should get an OUT of GAS error for failed out of gas transactions', async () => { + patch(harmony, 'getCurrentBlockNumber', () => 1); + patch(harmony, 'getTransaction', () => transactionOutOfGas); + patch(harmony, 'getTransactionReceipt', () => transactionOutOfGasReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(OUT_OF_GAS_ERROR_CODE); + expect(res.body.message).toEqual(OUT_OF_GAS_ERROR_MESSAGE); + }); + + it('should get a null in txReceipt for Tx in the mempool', async () => { + patch(harmony, 'getCurrentBlockNumber', () => 1); + patch(harmony, 'getTransaction', () => transactionOutOfGas); + patch(harmony, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toBeDefined(); + }); + + it('should get a null in txReceipt and txData for Tx that didnt reach the mempool and TxReceipt is null', async () => { + patch(harmony, 'getCurrentBlockNumber', () => 1); + patch(harmony, 'getTransaction', () => null); + patch(harmony, 'getTransactionReceipt', () => null); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toEqual(null); + expect(res.body.txData).toEqual(null); + }); + + it('should get txStatus = 1 for a succesful query', async () => { + patch(harmony, 'getCurrentBlockNumber', () => 1); + patch(harmony, 'getTransaction', () => transactionSuccesful); + patch(harmony, 'getTransactionReceipt', () => transactionSuccesfulReceipt); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toBeDefined(); + expect(res.body.txData).toBeDefined(); + }); + + it('should get unknown error', async () => { + patch(harmony, 'getCurrentBlockNumber', () => { + const error: any = new Error('something went wrong'); + error.code = -32006; + throw error; + }); + const res = await request(gatewayApp).post('/network/poll').send({ + chain: 'harmony', + network: 'testnet', + txHash: + '0x2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + expect(res.body.message).toEqual(UNKNOWN_ERROR_MESSAGE); + }); +}); diff --git a/test/chains/harmony/harmony.test.ts b/test/chains/harmony/harmony.test.ts new file mode 100644 index 0000000000..6eddfe0318 --- /dev/null +++ b/test/chains/harmony/harmony.test.ts @@ -0,0 +1,62 @@ +import { Harmony } from '../../../src/chains/harmony/harmony'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; +import { SushiswapConfig } from '../../../src/connectors/sushiswap/sushiswap.config'; +import { DefikingdomsConfig } from '../../../src/connectors/defikingdoms/defikingdoms.config'; +import { DefiraConfig } from '../../../src/connectors/defira/defira.config'; + +let harmony: Harmony; + +beforeAll(async () => { + harmony = Harmony.getInstance('mainnet'); + patchEVMNonceManager(harmony.nonceManager); + await harmony.init(); +}); + +afterAll(async () => { + await harmony.close(); +}); + +describe('getSpender', () => { + describe('get defira', () => { + it('returns defira mainnet router address', () => { + const dfkAddress = harmony.getSpender('defira'); + expect(dfkAddress.toLowerCase()).toEqual( + DefiraConfig.config.routerAddress('mainnet').toLowerCase() + ); + }); + }); + describe('get viperswap', () => { + it('returns viperswap mainnet address', () => { + const viperswapAddress = harmony.getSpender('viperswap'); + expect(viperswapAddress.toLowerCase()).toEqual( + '0xf012702a5f0e54015362cbca26a26fc90aa832a3' + ); + }); + }); + describe('get sushiswap', () => { + it('returns sushiswap kovan address', () => { + const sushiswapAddress = harmony.getSpender('sushiswap'); + expect(sushiswapAddress.toLowerCase()).toEqual( + SushiswapConfig.config + .sushiswapRouterAddress('ethereum', 'kovan') + .toLowerCase() + ); + }); + }); + describe('get defikingdoms', () => { + it('returns defikingdoms mainnet router address', () => { + const dfkAddress = harmony.getSpender('defikingdoms'); + expect(dfkAddress.toLowerCase()).toEqual( + DefikingdomsConfig.config.routerAddress('mainnet').toLowerCase() + ); + }); + }); + describe('get defira', () => { + it('returns defira mainnet router address', () => { + const dfkAddress = harmony.getSpender('defira'); + expect(dfkAddress.toLowerCase()).toEqual( + DefiraConfig.config.routerAddress('mainnet').toLowerCase() + ); + }); + }); +}); diff --git a/test/chains/harmony/harmony.validators.test.ts b/test/chains/harmony/harmony.validators.test.ts new file mode 100644 index 0000000000..6c1889e675 --- /dev/null +++ b/test/chains/harmony/harmony.validators.test.ts @@ -0,0 +1,203 @@ +import { + validateAddress, + invalidAddressError, + validateSpender, + invalidSpenderError, + validateNonce, + invalidNonceError, + invalidMaxFeePerGasError, + validateMaxFeePerGas, + invalidMaxPriorityFeePerGasError, + validateMaxPriorityFeePerGas, +} from '../../../src/chains/harmony/harmony.validators'; + +import { missingParameter } from '../../../src/services/validators'; + +import 'jest-extended'; + +describe('validateAddress', () => { + it('valid when req.address is a address', () => { + expect( + validateAddress({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it('valid when req.address is a bech32 address', () => { + expect( + validateAddress({ + address: 'one1l2sjl5gzl6rz8jffn3etq0j9zpljwu44u9889l', + }) + ).toEqual([]); + }); + + it('return error when req.address does not exist', () => { + expect( + validateAddress({ + hello: 'world', + }) + ).toEqual([missingParameter('address')]); + }); + + it('return error when req.address is invalid', () => { + expect( + validateAddress({ + address: 'world', + }) + ).toEqual([invalidAddressError]); + }); +}); + +describe('validateSpender', () => { + it('valid when req.spender is a publicKey', () => { + expect( + validateSpender({ + spender: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it("valid when req.spender is a 'sushiswap'", () => { + expect( + validateSpender({ + spender: 'sushiswap', + }) + ).toEqual([]); + }); + + it("valid when req.spender is 'viperswap'", () => { + expect( + validateSpender({ + spender: 'viperswap', + }) + ).toEqual([]); + }); + + it("valid when req.spender is 'defikingdoms'", () => { + expect( + validateSpender({ + spender: 'defikingdoms', + }) + ).toEqual([]); + }); + + it("valid when req.spender is 'defira'", () => { + expect( + validateSpender({ + spender: 'defira', + }) + ).toEqual([]); + }); + + it('return error when req.spender does not exist', () => { + expect( + validateSpender({ + hello: 'world', + }) + ).toEqual([missingParameter('spender')]); + }); + + it('return error when req.spender is invalid', () => { + expect( + validateSpender({ + spender: 'world', + }) + ).toEqual([invalidSpenderError]); + }); +}); + +describe('validateNonce', () => { + it('valid when req.nonce is a number', () => { + expect( + validateNonce({ + nonce: 0, + }) + ).toEqual([]); + expect( + validateNonce({ + nonce: 999, + }) + ).toEqual([]); + }); + + it('valid when req.nonce does not exist', () => { + expect( + validateNonce({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.nonce is invalid', () => { + expect( + validateNonce({ + nonce: '123', + }) + ).toEqual([invalidNonceError]); + }); +}); + +describe('validateMaxFeePerGas', () => { + it('valid when req.quote is a string', () => { + expect( + validateMaxFeePerGas({ + maxFeePerGas: '5000000000', + }) + ).toEqual([]); + + expect( + validateMaxFeePerGas({ + maxFeePerGas: '1', + }) + ).toEqual([]); + }); + + it('return no error when req.maxFeePerGas does not exist', () => { + expect( + validateMaxFeePerGas({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.maxFeePerGas is invalid', () => { + expect( + validateMaxFeePerGas({ + maxFeePerGas: 123, + }) + ).toEqual([invalidMaxFeePerGasError]); + }); +}); + +describe('validateMaxPriorityFeePerGas', () => { + it('valid when req.quote is a string', () => { + expect( + validateMaxPriorityFeePerGas({ + maxPriorityFeePerGasError: '5000000000', + }) + ).toEqual([]); + + expect( + validateMaxPriorityFeePerGas({ + maxPriorityFeePerGasError: '1', + }) + ).toEqual([]); + }); + + it('return no error when req.maxPriorityFeePerGas does not exist', () => { + expect( + validateMaxPriorityFeePerGas({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.maxPriorityFeePerGas is invalid', () => { + expect( + validateMaxPriorityFeePerGas({ + maxPriorityFeePerGas: 123, + }) + ).toEqual([invalidMaxPriorityFeePerGasError]); + }); +}); diff --git a/test/chains/near/fixtures/getTokenList.json b/test/chains/near/fixtures/getTokenList.json new file mode 100644 index 0000000000..22345e5bae --- /dev/null +++ b/test/chains/near/fixtures/getTokenList.json @@ -0,0 +1,47 @@ +{ + "dai.near": { + "symbol": "DAI", + "name": "Dark Assassins Inc. Coin", + "decimals": 2 + }, + "ageur.near": { + "symbol": "agEUR", + "name": "agEUR (Wormhole)", + "decimals": 8 + }, + "angle.near": { + "symbol": "ANGLE", + "name": "ANGLE (Wormhole)", + "decimals": 8 + }, + "mbs.near": { + "symbol": "MBS", + "name": "MonkeyBucks", + "decimals": 6 + }, + "edb.near": { + "symbol": "EDB", + "name": "Emerald Block", + "decimals": 9 + }, + "cwar.near": { + "symbol": "CWAR", + "name": "Cryowar Token", + "decimals": 9 + }, + "echo.near": { + "symbol": "ECHO", + "name": "EchoDao", + "decimals": 9 + }, + "monke.near": { + "symbol": "MONKE", + "name": "MONKE TOKEN", + "decimals": 9 + }, + "dibu.near": { + "symbol": "DIBU", + "name": "DickButt", + "decimals": 3 + } +} diff --git a/test/chains/near/fixtures/getTransaction.json b/test/chains/near/fixtures/getTransaction.json new file mode 100644 index 0000000000..9df153f8be --- /dev/null +++ b/test/chains/near/fixtures/getTransaction.json @@ -0,0 +1,86 @@ +{ + "status": { + "SuccessValue": "" + }, + "transaction": { + "signer_id": "sender.testnet", + "public_key": "ed25519:Gowpa4kXNyTMRKgt5W7147pmcc2PxiFic8UHW9rsNvJ6", + "nonce": 15, + "receiver_id": "receiver.testnet", + "actions": [ + { + "Transfer": { + "deposit": "1000000000000000000000000" + } + } + ], + "signature": "ed25519:3168QMdTpcwHvM1dmMYBc8hg9J3Wn8n7MWBSE9WrEpns6P5CaY87RM6k4uzyBkQuML38CZhU18HzmQEevPG1zCvk", + "hash": "6zgh2u9DqHHiXzdy9ouTP7oGky2T4nugqzqt9wJZwNFm" + }, + "transaction_outcome": { + "proof": [ + { + "hash": "F7mL76CMdfbdZ3xCehVGNh1fCyaR37gr3MeGX3EZkiVf", + "direction": "Right" + } + ], + "block_hash": "ADTMLVtkhsvzUxuf6m87Pt1dnF5vi1yY7ftxmNpFx7y", + "id": "6zgh2u9DqHHiXzdy9ouTP7oGky2T4nugqzqt9wJZwNFm", + "outcome": { + "logs": [], + "receipt_ids": ["3dMfwczW5GQqXbD9GMTnmf8jy5uACxG6FC5dWxm3KcXT"], + "gas_burnt": 223182562500, + "tokens_burnt": "22318256250000000000", + "executor_id": "sender.testnet", + "status": { + "SuccessReceiptId": "3dMfwczW5GQqXbD9GMTnmf8jy5uACxG6FC5dWxm3KcXT" + } + } + }, + "receipts_outcome": [ + { + "proof": [ + { + "hash": "6h95oEd7ih62KXfyPT4zsZYont4qy9sWEXc5VQVDhqtG", + "direction": "Right" + }, + { + "hash": "6DnibgZk1T669ZprcehUy1GpCSPw1kjzXRGu69nSaUNn", + "direction": "Right" + } + ], + "block_hash": "GgFTVr33r4MrpAiHc9mr8TZqLnpZAX1BaZTNvhBnciy2", + "id": "3dMfwczW5GQqXbD9GMTnmf8jy5uACxG6FC5dWxm3KcXT", + "outcome": { + "logs": [], + "receipt_ids": ["46KYgN8ddxs4Qy8C7BDQH49XUfcYZsaQmAvdU1nfcL9V"], + "gas_burnt": 223182562500, + "tokens_burnt": "22318256250000000000", + "executor_id": "receiver.testnet", + "status": { + "SuccessValue": "" + } + } + }, + { + "proof": [ + { + "hash": "CD9Y7Bw3MSFgaPZzpc1yP51ajhGDCAsR61qXcMNcRoHf", + "direction": "Left" + } + ], + "block_hash": "EGAgKuW6Bd6QKYSaxAkx2pPGmnjrjAcq4UpoUiqMXvPH", + "id": "46KYgN8ddxs4Qy8C7BDQH49XUfcYZsaQmAvdU1nfcL9V", + "outcome": { + "logs": [], + "receipt_ids": [], + "gas_burnt": 0, + "tokens_burnt": "0", + "executor_id": "sender.testnet", + "status": { + "SuccessValue": "" + } + } + } + ] +} diff --git a/test/chains/near/near.controllers.test.ts b/test/chains/near/near.controllers.test.ts new file mode 100644 index 0000000000..6caec96273 --- /dev/null +++ b/test/chains/near/near.controllers.test.ts @@ -0,0 +1,124 @@ +import { Near } from '../../../src/chains/near/near'; +import { TokenInfo } from '../../../src/chains/near/near.base'; +import { + balances, + cancel, + getTokenSymbolsToTokens, + poll, +} from '../../../src/chains/near/near.controllers'; +import { PollResponse } from '../../../src/chains/near/near.requests'; +import { Nearish } from '../../../src/services/common-interfaces'; +import { + HttpException, + LOAD_WALLET_ERROR_CODE, + LOAD_WALLET_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import { patch, unpatch } from '../../services/patch'; +import * as getTokenListData from './fixtures/getTokenList.json'; +import * as getTransactionData from './fixtures/getTransaction.json'; +import { publicKey } from './near.validators.test'; + +let near: Nearish; +const txHash = 'JCVEmLB2EQUR5hijgJkLLKjW5aGxdcdAndTQZBZ85Fm8'; +const zeroAddress = + '0000000000000000000000000000000000000000000000000000000000000000'; // noqa: mock + +beforeAll(async () => { + near = Near.getInstance('testnet'); + near.getTokenList = jest.fn().mockReturnValue(getTokenListData); + await near.init(); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await near.close(); +}); + +const CurrentBlockNumber = 112646487; +const patchGetCurrentBlockNumber = () => { + patch(near, 'getCurrentBlockNumber', () => CurrentBlockNumber); +}; + +const patchGetTransaction = () => { + patch(near, 'getTransaction', () => getTransactionData); +}; + +describe('poll', () => { + it('return transaction data for given signature', async () => { + patchGetCurrentBlockNumber(); + patchGetTransaction(); + const n: PollResponse = await poll(near, publicKey, txHash); + expect(n.network).toBe(near.network); + expect(n.timestamp).toBeNumber(); + expect(n.currentBlock).toBe(CurrentBlockNumber); + expect(n.txHash).toBe(txHash); + expect(n.txStatus).toBe(1); + }); +}); + +describe('balances', () => { + it('fail if wallet not found', async () => { + const err = 'wallet does not exist'; + patch(near, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + balances(near, { + chain: 'near', + network: 'testnet', + address: publicKey, + tokenSymbols: ['ETHH', 'NEAR'], + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); +}); + +describe('cancel', () => { + it('fail if wallet not found', async () => { + const err = 'wallet does not exist'; + patch(near, 'getWallet', () => { + throw new Error(err); + }); + + await expect( + cancel(near, { + chain: 'near', + network: 'testnet', + nonce: 123, + address: zeroAddress, + }) + ).rejects.toThrow( + new HttpException( + 500, + LOAD_WALLET_ERROR_MESSAGE + 'Error: ' + err, + LOAD_WALLET_ERROR_CODE + ) + ); + }); +}); + +const eth: TokenInfo = { + chainId: 0, + name: 'ETH', + symbol: 'ETH', + address: 'eth.near', + decimals: 18, +}; +describe('getTokenSymbolsToTokens', () => { + it('return tokens for strings', () => { + patch(near, 'getTokenBySymbol', () => { + return eth; + }); + expect(getTokenSymbolsToTokens(near, ['ETH'])).toEqual({ ETH: eth }); + }); +}); diff --git a/test/chains/near/near.routes.test.ts b/test/chains/near/near.routes.test.ts new file mode 100644 index 0000000000..55128de12f --- /dev/null +++ b/test/chains/near/near.routes.test.ts @@ -0,0 +1,196 @@ +import request from 'supertest'; +import { Near } from '../../../src/chains/near/near'; +import { patch, unpatch } from '../../services/patch'; +import { gatewayApp } from '../../../src/app'; +import { + NETWORK_ERROR_CODE, + RATE_LIMIT_ERROR_CODE, + UNKNOWN_ERROR_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + RATE_LIMIT_ERROR_MESSAGE, + UNKNOWN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; +import * as transactionSuccesful from './fixtures/getTransaction.json'; +let near: Near; + +beforeAll(async () => { + near = Near.getInstance('testnet'); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await near.close(); +}); + +const patchGetWallet = () => { + patch(near, 'getWallet', () => { + return { + address: 'test.near', + }; + }); +}; + +const patchGetFTBalance = () => { + patch(near, 'getFungibleTokenBalance', () => '0.01'); +}; + +const patchGetNativeBalance = () => { + patch(near, 'getNativeBalance', () => '0.01'); +}; + +const patchGetTokenBySymbol = () => { + patch(near, 'getTokenBySymbol', (symbol: string) => { + let result; + switch (symbol) { + case 'WETH': + result = { + chainId: 42, + name: 'WETH', + symbol: 'WETH', + address: 'weth.near', + decimals: 18, + }; + break; + case 'DAI': + result = { + chainId: 42, + name: 'DAI', + symbol: 'DAI', + address: 'dai.near', + decimals: 18, + }; + break; + } + return result; + }); +}; + +describe('POST /near/balances', () => { + it('should return 500 for unsupported tokens', async () => { + patchGetWallet(); + patchGetTokenBySymbol(); + patchGetNativeBalance(); + patchGetFTBalance(); + near.getContract = jest.fn().mockReturnValue({ + address: 'test.near', + }); + + await request(gatewayApp) + .post(`/near/balances`) + .send({ + chain: 'near', + network: 'testnet', + address: 'test.near', + tokenSymbols: ['XXX', 'YYY'], + }) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(500); + }); + + it('should return 404 when parameters are invalid', async () => { + await request(gatewayApp) + .post(`/near/balances`) + .send({ + chain: 'near', + network: 'testnet', + address: 'da857cbda0ba96757fed842617a4', + }) + .expect(404); + }); +}); + +describe('POST /near/poll', () => { + it('should get a NETWORK_ERROR_CODE when the network is unavailable', async () => { + patch(near, 'getCurrentBlockNumber', () => { + const error: any = new Error('somnearing went wrong'); + error.code = 'NETWORK_ERROR'; + throw error; + }); + + const res = await request(gatewayApp).post('/near/poll').send({ + address: 'test.near', + network: 'testnet', + txHash: + '2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(NETWORK_ERROR_CODE); + expect(res.body.message).toEqual(NETWORK_ERROR_MESSAGE); + }); + + it('should get a UNKNOWN_ERROR_ERROR_CODE when an unknown error is thrown', async () => { + patch(near, 'getCurrentBlockNumber', () => { + throw new Error(); + }); + + const res = await request(gatewayApp).post('/near/poll').send({ + address: 'test.near', + network: 'testnet', + txHash: + '2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + }); + + it('should get txStatus = 1 for a succesful query', async () => { + patch(near, 'getCurrentBlockNumber', () => 1); + patch(near, 'getTransaction', () => transactionSuccesful); + const res = await request(gatewayApp).post('/near/poll').send({ + address: 'test.near', + network: 'testnet', + txHash: + '0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d', // noqa: mock + }); + expect(res.statusCode).toEqual(200); + expect(res.body.txReceipt).toBeDefined(); + }); + + it('should get an RATE_LIMIT_ERROR_CODE when the blockchain API is rate limited', async () => { + patch(near, 'getCurrentBlockNumber', () => { + const error: any = new Error( + 'daily request count exceeded, request rate limited' + ); + error.code = -32005; + error.data = { + see: 'https://infura.io/docs/near/jsonrpc/ratelimits', + current_rps: 13.333, + allowed_rps: 10.0, + backoff_seconds: 30.0, + }; + throw error; + }); + const res = await request(gatewayApp).post('/near/poll').send({ + address: 'test.near', + network: 'testnet', + txHash: + '2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(RATE_LIMIT_ERROR_CODE); + expect(res.body.message).toEqual(RATE_LIMIT_ERROR_MESSAGE); + }); + + it('should get unknown error', async () => { + patch(near, 'getCurrentBlockNumber', () => { + const error: any = new Error('somnearing went wrong'); + error.code = -32006; + throw error; + }); + const res = await request(gatewayApp).post('/near/poll').send({ + address: 'test.near', + network: 'testnet', + txHash: + '2faeb1aa55f96c1db55f643a8cf19b0f76bf091d0b7d1b068d2e829414576362', // noqa: mock + }); + expect(res.statusCode).toEqual(503); + expect(res.body.errorCode).toEqual(UNKNOWN_ERROR_ERROR_CODE); + expect(res.body.message).toEqual(UNKNOWN_ERROR_MESSAGE); + }); +}); diff --git a/test/chains/near/near.validators.test.ts b/test/chains/near/near.validators.test.ts new file mode 100644 index 0000000000..9fe96153d9 --- /dev/null +++ b/test/chains/near/near.validators.test.ts @@ -0,0 +1,159 @@ +import 'jest-extended'; +import { + invalidAddressError, + invalidChainError, + invalidNetworkError, + invalidNonceError, + invalidSpenderError, + validateAddress, + validateBalanceRequest, + validateChain, + validateNetwork, + validateNonce, + validateSpender, +} from '../../../src/chains/near/near.validators'; +import { missingParameter } from '../../../src/services/validators'; + +export const publicKey = 'test.near'; +export const privateKey = + '5K23ZvkHuNoakyMKGNoaCvky6a2Yu5yfeoRz2wQLKYAczMKzACN5ZZb9ixu6QcsQvrvh91CNfqu8U1LqC1nvnyfp'; + +describe('validatePublicKey', () => { + it('valid when req.publicKey is a publicKey', () => { + expect( + validateAddress({ + address: publicKey, + }) + ).toEqual([]); + }); + + it('return error when req.publicKey does not exist', () => { + expect( + validateAddress({ + hello: 'world', + }) + ).toEqual([missingParameter('address')]); + }); + + it('return error when req.publicKey is invalid', () => { + expect( + validateAddress({ + address: 1, + }) + ).toEqual([invalidAddressError]); + }); +}); + +describe('validateSpender', () => { + it('valid when req.spender is a publicKey', () => { + expect( + validateSpender({ + spender: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it("valid when req.spender is a 'uniswap'", () => { + expect( + validateSpender({ + spender: 'uniswap', + }) + ).toEqual([]); + }); + + it('return error when req.spender is invalid', () => { + expect( + validateSpender({ + spender: 123, + }) + ).toEqual([invalidSpenderError]); + }); +}); + +describe('validateNonce', () => { + it('valid when req.nonce is a number', () => { + expect( + validateNonce({ + nonce: 0, + }) + ).toEqual([]); + expect( + validateNonce({ + nonce: 999, + }) + ).toEqual([]); + }); + + it('valid when req.nonce does not exist', () => { + expect( + validateNonce({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.nonce is invalid', () => { + expect( + validateNonce({ + nonce: '123', + }) + ).toEqual([invalidNonceError]); + }); +}); + +describe('validateChain', () => { + it('invalid when req.chain is a number', () => { + expect( + validateChain({ + chain: 2, + }) + ).toEqual([invalidChainError]); + expect( + validateChain({ + chain: 999, + }) + ).toEqual([invalidChainError]); + }); + + it('valid when req.chain is a string', () => { + expect( + validateChain({ + chain: 'world', + }) + ).toEqual([]); + }); +}); + +describe('validateNetwork', () => { + it('invalid when req.network is a number', () => { + expect( + validateNetwork({ + network: 2, + }) + ).toEqual([invalidNetworkError]); + expect( + validateNetwork({ + network: 999, + }) + ).toEqual([invalidNetworkError]); + }); + + it('valid when req.network is a string', () => { + expect( + validateNetwork({ + network: 'world', + }) + ).toEqual([]); + }); +}); + +describe('validateBalanceRequest', () => { + it('valid when requests are correct', () => { + expect( + validateBalanceRequest({ + address: 'world', + tokenSymbols: ['token'], + }) + ).toEqual(undefined); + }); +}); diff --git a/test/chains/near/ref/ref.route.test.ts b/test/chains/near/ref/ref.route.test.ts new file mode 100644 index 0000000000..4e45410cf6 --- /dev/null +++ b/test/chains/near/ref/ref.route.test.ts @@ -0,0 +1,708 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../../services/patch'; +import { gatewayApp } from '../../../../src/app'; +import { Near } from '../../../../src/chains/near/near'; +import { Ref } from '../../../../src/connectors/ref/ref'; +let near: Near; +let ref: Ref; + +beforeAll(async () => { + near = Near.getInstance('testnet'); + await near.init(); + + ref = Ref.getInstance('near', 'testnet'); + await ref.init(); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await near.close(); +}); + +const address: string = 'test.near'; + +const patchGetWallet = () => { + patch(near, 'getWallet', () => { + return { + accountId: address, + connection: { + networkId: 'testnet', + signer: { + getPublicKey: { + toString: '0xa1242434', + }, + }, + provider: {}, + }, + }; + }); +}; + +const DAI = { + spec: 'ft-1.0.0', + name: 'Dai Stablecoin', + symbol: 'DAI', + icon: '', + reference: '', + reference_hash: '', + decimals: 18, + id: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', +}; + +const ETH = { + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', +}; + +const tradePath = [ + { + estimate: '438.7318928061755133021873247954861357077652', + pool: { + fee: 30, + gamma_bps: [], + id: 1207, + partialAmountIn: '988562670855139614', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '1124497821208300092576', + y: '501001402176405567560845153269', + }, + status: 'stableSmart', + token: { + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', + }, + outputToken: 'wrap.near', + inputToken: 'aurora', + nodeRoute: [ + 'aurora', + 'wrap.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + { + estimate: '1227.5907741995622146029347396525450563115171', + pool: { + fee: 30, + gamma_bps: [], + id: 2, + partialAmountIn: '0', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '15490663264513922879112087736', + y: '44701557151302991680091', + }, + status: 'stableSmart', + token: { + spec: 'ft-1.0.0', + name: 'Wrapped NEAR fungible token', + symbol: 'wNEAR', + icon: null, + reference: null, + reference_hash: null, + decimals: 24, + id: 'wrap.near', + }, + outputToken: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + inputToken: 'wrap.near', + nodeRoute: [ + 'aurora', + 'wrap.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + { + estimate: '3.8379037803866734449637949018757616354149', + pool: { + fee: 19, + gamma_bps: [], + id: 3023, + partialAmountIn: '11437329144860386', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '2282104348405543143', + y: '771077319322598388824', + }, + status: 'stableSmart', + token: { + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', + }, + outputToken: 'marmaj.tkn.near', + inputToken: 'aurora', + nodeRoute: [ + 'aurora', + 'marmaj.tkn.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + { + estimate: '14.299093444897422181731877348671464832746', + pool: { + fee: 19, + gamma_bps: [], + id: 10, + partialAmountIn: '0', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '123732450606489839390', + y: '476173588371142658007', + }, + status: 'stableSmart', + token: { + spec: 'ft-1.0.0', + name: 'marma j token', + symbol: 'marmaj', + icon: '', + reference: null, + reference_hash: null, + decimals: 18, + id: 'marmaj.tkn.near', + }, + outputToken: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + inputToken: 'marmaj.tkn.near', + nodeRoute: [ + 'aurora', + 'marmaj.tkn.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, +]; + +const patchStoredTokenList = () => { + patch(near, 'tokenList', () => { + return [ + { + chainId: 0, + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', + address: 'aurora', + }, + { + chainId: 0, + spec: 'ft-1.0.0', + name: 'Dai Stablecoin', + symbol: 'DAI', + icon: '', + reference: '', + reference_hash: '', + decimals: 18, + id: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + address: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(near, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'ETH') { + return { + chainId: 0, + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', + address: 'aurora', + }; + } else { + return { + chainId: 0, + spec: 'ft-1.0.0', + name: 'Dai Stablecoin', + symbol: 'DAI', + icon: '', + reference: '', + reference_hash: '', + decimals: 18, + id: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + address: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(ref, 'getTokenByAddress', () => { + return { + chainId: 0, + spec: 'ft-1.0.0', + name: 'Dai Stablecoin', + symbol: 'DAI', + icon: '', + reference: '', + reference_hash: '', + decimals: 18, + id: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + address: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + }; + }); +}; + +const patchGasPrice = () => { + patch(near, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(ref, 'estimateBuyTrade', () => { + return { + expectedAmount: '100', + trade: tradePath, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(ref, 'estimateSellTrade', () => { + return { + expectedAmount: '100', + trade: tradePath, + }; + }); +}; + +const patchExecuteTrade = () => { + patch(ref, 'executeTrade', () => { + return { hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(near, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'ETH') { + return { + chainId: 43114, + name: 'ETH', + symbol: 'ETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DOGE', + base: 'ETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(near, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'ETH') { + return { + chainId: 43114, + name: 'ETH', + symbol: 'ETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchExecuteTrade(); + }; + + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + address, + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(near, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'ETH') { + return { + chainId: 43114, + name: 'ETH', + symbol: 'ETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'ETH', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(near, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'ETH') { + return { + chainId: 43114, + name: 'ETH', + symbol: 'ETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'BITCOIN', + base: 'ETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + address, + side: 'SELL', + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + address, + side: 'BUY', + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 500 for SELL with price lower than limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + address, + side: 'SELL', + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for BUY with price higher than limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + quote: 'DAI', + base: 'ETH', + amount: '10000', + address, + side: 'BUY', + limitPrice: '0', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/estimateGas', () => { + it('should return 200 for valid connector', async () => { + patchGasPrice(); + + await request(gatewayApp) + .post('/amm/estimateGas') + .send({ + chain: 'near', + network: 'testnet', + connector: 'ref', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.network).toEqual('testnet'); + expect(res.body.gasPrice).toEqual(100); + expect(res.body.gasCost).toEqual( + String((100 * ref.gasLimitEstimate) / 1e24) + ); + }); + }); +}); diff --git a/test/chains/near/ref/ref.test.ts b/test/chains/near/ref/ref.test.ts new file mode 100644 index 0000000000..2faf079461 --- /dev/null +++ b/test/chains/near/ref/ref.test.ts @@ -0,0 +1,339 @@ +jest.useFakeTimers(); +import { Ref } from '../../../../src/connectors/ref/ref'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { Near } from '../../../../src/chains/near/near'; +import * as RefSDK from 'coinalpha-ref-sdk'; + +let near: Near; +let ref: Ref; + +const DAI = { + spec: 'ft-1.0.0', + name: 'Dai Stablecoin', + symbol: 'DAI', + icon: '', + reference: '', + reference_hash: '', + decimals: 18, + id: '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', +}; +const ETH = { + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', +}; + +beforeAll(async () => { + near = Near.getInstance('testnet'); + await near.init(); + + ref = Ref.getInstance('near', 'testnet'); + await ref.init(); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await near.close(); +}); + +const patchInstantSwap = () => { + patch(RefSDK, 'instantSwap', () => { + return []; + }); +}; + +const patchSignHelper = () => { + patch(Ref, 'getSignedTransactions', () => { + return []; + }); +}; + +const patchSendHelper = (result: string[]) => { + patch(Ref, 'sendTransactions', () => { + return result; + }); +}; + +const patchFetcher = () => { + patch(RefSDK, 'fetchAllPools', () => { + return { + simplePools: [], + unRatedPools: [], + ratedPools: [], + }; + }); +}; + +const patchEstimateSwap = () => { + patch(RefSDK, 'estimateSwap', () => { + return [ + { + estimate: '438.7318928061755133021873247954861357077652', + pool: { + fee: 30, + gamma_bps: [], + id: 1207, + partialAmountIn: '0.988562670855139614', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '1124497821208300092576', + y: '501001402176405567560845153269', + }, + status: 'stableSmart', + token: { + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', + }, + outputToken: 'wrap.near', + inputToken: 'aurora', + nodeRoute: [ + 'aurora', + 'wrap.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + { + estimate: '1227.5907741995622146029347396525450563115171', + pool: { + fee: 30, + gamma_bps: [], + id: 2, + partialAmountIn: '0', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '15490663264513922879112087736', + y: '44701557151302991680091', + }, + status: 'stableSmart', + token: { + spec: 'ft-1.0.0', + name: 'Wrapped NEAR fungible token', + symbol: 'wNEAR', + icon: null, + reference: null, + reference_hash: null, + decimals: 24, + id: 'wrap.near', + }, + outputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + inputToken: 'wrap.near', + nodeRoute: [ + 'aurora', + 'wrap.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + { + estimate: '3.8379037803866734449637949018757616354149', + pool: { + fee: 19, + gamma_bps: [], + id: 3023, + partialAmountIn: '11437329144860386', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '2282104348405543143', + y: '771077319322598388824', + }, + status: 'stableSmart', + token: { + decimals: 18, + icon: '', + name: 'Ether', + reference: null, + reference_hash: null, + spec: 'ft-1.0.0', + symbol: 'ETH', + id: 'aurora', + }, + outputToken: 'marmaj.tkn.near', + inputToken: 'aurora', + nodeRoute: [ + 'aurora', + 'marmaj.tkn.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + { + estimate: '14.299093444897422181731877348671464832746', + pool: { + fee: 19, + gamma_bps: [], + id: 10, + partialAmountIn: '0', + supplies: [Object], + token0_ref_price: '0', + tokenIds: [Array], + Dex: undefined, + x: '123732450606489839390', + y: '476173588371142658007', + }, + status: 'stableSmart', + token: { + spec: 'ft-1.0.0', + name: 'marma j token', + symbol: 'marmaj', + icon: '', + reference: null, + reference_hash: null, + decimals: 18, + id: 'marmaj.tkn.near', + }, + outputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + inputToken: 'marmaj.tkn.near', + nodeRoute: [ + 'aurora', + 'marmaj.tkn.near', + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + ], + route: [[Object], [Object]], + allRoutes: [[Array], [Array]], + allNodeRoutes: [[Array], [Array]], + totalInputAmount: '1000000000000000000', + allAllocations: [[], []], + tokens: [ETH, DAI], + routeInputToken: 'aurora', + routeOutputToken: + '6b175474e89094c44da98b954eedeac495271d0f.factory.bridge.near', + overallPriceImpact: '3.53957150694661537802481235958281919791', + }, + ]; + }); +}; + +const patchEstimateSwapWithError = () => { + patch(RefSDK, 'estimateSwap', () => { + return []; + }); +}; + +describe('verify Ref estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetcher(); + patchEstimateSwap(); + + const expectedTrade = await ref.estimateSellTrade(ETH, DAI, '1'); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetcher(); + patchEstimateSwapWithError(); + + await expect(async () => { + await ref.estimateSellTrade(ETH, DAI, '1'); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify Ref estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetcher(); + patchEstimateSwap(); + + const expectedTrade = await ref.estimateBuyTrade(ETH, DAI, '1'); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetcher(); + patchEstimateSwapWithError(); + + await expect(async () => { + await ref.estimateBuyTrade(ETH, DAI, '1'); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = ref.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(0.03); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = ref.getAllowedSlippage(); + expect(allowedSlippage).toEqual(0.02); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = ref.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(0.02); + }); +}); + +describe('verify Ref executeTrade', () => { + it('Should return an error if no pair is available', async () => { + patchInstantSwap(); + patchSignHelper(); + patchSendHelper([]); + + await expect(async () => { + await ref.executeTrade( + await near.getWalletFromPrivateKey( + 'ed25519:2wyRcSwSuHtRVmkMCGjPwnzZmQLeXLzLLyED1NDMt4BjnKgQL6tF85yBx6Jr26D2dUNeC716RBoTxntVHsegogYw', + 'test' + ), + [], + '0.1', + ETH, + DAI + ); + }).rejects.toThrow(); + }); +}); diff --git a/test/chains/polygon/polygon.test.ts b/test/chains/polygon/polygon.test.ts new file mode 100644 index 0000000000..309e7e6d3b --- /dev/null +++ b/test/chains/polygon/polygon.test.ts @@ -0,0 +1,44 @@ +import { Polygon } from '../../../src/chains/polygon/polygon'; +import { unpatch } from '../../services/patch'; +import { patchEVMNonceManager } from '../../evm.nonce.mock'; +let polygon: Polygon; + +beforeAll(async () => { + polygon = Polygon.getInstance('mumbai'); + + patchEVMNonceManager(polygon.nonceManager); + + await polygon.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(polygon.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await polygon.close(); +}); + +describe('public get', () => { + it('gasPrice', async () => { + expect(polygon.gasPrice).toEqual(100); + }); + + it('native token', async () => { + expect(polygon.nativeTokenSymbol).toEqual('MATIC'); + }); + + it('chain', async () => { + expect(polygon.chain).toEqual('mumbai'); + }); + + it('getSpender', async () => { + expect( + polygon.getSpender('0xd0A1E359811322d97991E03f863a0C30C2cF029C') + ).toEqual('0xd0A1E359811322d97991E03f863a0C30C2cF029C'); + }); +}); diff --git a/test/chains/polygon/polygon.validators.test.ts b/test/chains/polygon/polygon.validators.test.ts new file mode 100644 index 0000000000..92c8f324b4 --- /dev/null +++ b/test/chains/polygon/polygon.validators.test.ts @@ -0,0 +1,57 @@ +import { + validateSpender, + invalidSpenderError, + validatePolygonApproveRequest, +} from '../../../src/chains/polygon/polygon.validators'; + +import { missingParameter } from '../../../src/services/validators'; + +import 'jest-extended'; + +describe('validateSpender', () => { + it('valid when req.spender is a publicKey', () => { + expect( + validateSpender({ + spender: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }) + ).toEqual([]); + }); + + it("valid when req.spender is a 'uniswap'", () => { + expect( + validateSpender({ + spender: 'uniswap', + }) + ).toEqual([]); + }); + + it('return error when req.spender does not exist', () => { + expect( + validateSpender({ + hello: 'world', + }) + ).toEqual([missingParameter('spender')]); + }); + + it('return error when req.spender is invalid', () => { + expect( + validateSpender({ + spender: 'world', + }) + ).toEqual([invalidSpenderError]); + }); +}); + +describe('validatePolygonApproveRequest', () => { + it('valid when req.spender is a publicKey', () => { + expect( + validatePolygonApproveRequest({ + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + spender: 'uniswap', + token: 'DAI', + amount: '1000000', + nonce: 0, + }) + ).toEqual(undefined); + }); +}); diff --git a/test/chains/polygon/quickswap/quickswap.route.test.ts b/test/chains/polygon/quickswap/quickswap.route.test.ts new file mode 100644 index 0000000000..a6b4d69654 --- /dev/null +++ b/test/chains/polygon/quickswap/quickswap.route.test.ts @@ -0,0 +1,561 @@ +import request from 'supertest'; +import { patch, unpatch } from '../../../services/patch'; +import { gatewayApp } from '../../../../src/app'; +import { Polygon } from '../../../../src/chains/polygon/polygon'; +import { Quickswap } from '../../../../src/connectors/quickswap/quickswap'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; +let polygon: Polygon; +let quickswap: Quickswap; + +beforeAll(async () => { + polygon = Polygon.getInstance('mumbai'); + patchEVMNonceManager(polygon.nonceManager); + await polygon.init(); + + quickswap = Quickswap.getInstance('polygon', 'mumbai'); + await quickswap.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(polygon.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await polygon.close(); +}); + +const address: string = '0xFaA12FD102FE8623C9299c72B03E45107F2772B5'; + +const patchGetWallet = () => { + patch(polygon, 'getWallet', () => { + return { + address: '0xFaA12FD102FE8623C9299c72B03E45107F2772B5', + }; + }); +}; + +const patchStoredTokenList = () => { + patch(polygon, 'tokenList', () => { + return [ + { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }, + { + chainId: 43114, + name: 'Wrapped AVAX', + symbol: 'WAVAX', + address: '0xB31f66AA3C1e785363F0875A1B74E27b85FD66c7', + decimals: 18, + }, + ]; + }); +}; + +const patchGetTokenBySymbol = () => { + patch(polygon, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return { + chainId: 42, + name: 'WAVAX', + symbol: 'WAVAX', + address: '0x4f96fe3b7a6cf9725f59d353f723c1bdb64ca6aa', + decimals: 18, + }; + } + }); +}; + +const patchGetTokenByAddress = () => { + patch(quickswap, 'getTokenByAddress', () => { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + }); +}; + +const patchGasPrice = () => { + patch(polygon, 'gasPrice', () => 100); +}; + +const patchEstimateBuyTrade = () => { + patch(quickswap, 'estimateBuyTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + invert: jest.fn().mockReturnValue({ + toSignificant: () => 100, + toFixed: () => '100', + }), + }, + }, + }; + }); +}; + +const patchEstimateSellTrade = () => { + patch(quickswap, 'estimateSellTrade', () => { + return { + expectedAmount: { + toSignificant: () => 100, + }, + trade: { + executionPrice: { + toSignificant: () => 100, + toFixed: () => '100', + }, + }, + }; + }); +}; + +const patchGetNonce = () => { + patch(polygon.nonceManager, 'getNonce', () => 21); +}; + +const patchExecuteTrade = () => { + patch(quickswap, 'executeTrade', () => { + return { nonce: 21, hash: '000000000000000' }; + }); +}; + +describe('POST /amm/price', () => { + it('should return 200 for BUY', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 200 for SELL', async () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.amount).toEqual('10000.000000000000000000'); + expect(res.body.rawAmount).toEqual('10000000000000000000000'); + }); + }); + + it('should return 500 for unrecognized quote symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(polygon, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'DOGE', + base: 'WETH', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 for unrecognized base symbol', async () => { + patchGetWallet(); + patchStoredTokenList(); + patch(polygon, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + patchGetTokenByAddress(); + + await request(gatewayApp) + .post(`/amm/price`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'SHIBA', + amount: '10000', + side: 'SELL', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); + +describe('POST /amm/trade', () => { + const patchForBuy = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateBuyTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for BUY', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for BUY without nonce parameter', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + const patchForSell = () => { + patchGetWallet(); + patchStoredTokenList(); + patchGetTokenBySymbol(); + patchGetTokenByAddress(); + patchGasPrice(); + patchEstimateSellTrade(); + patchGetNonce(); + patchExecuteTrade(); + }; + it('should return 200 for SELL', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + }) + .set('Accept', 'application/json') + .expect(200) + .then((res: any) => { + expect(res.body.nonce).toEqual(21); + }); + }); + + it('should return 200 for SELL with maxFeePerGas and maxPriorityFeePerGas', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 404 when parameters are incorrect', async () => { + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: 10000, + address: 'da8', + side: 'comprar', + }) + .set('Accept', 'application/json') + .expect(404); + }); + + it('should return 500 when base token is unknown', async () => { + patchForSell(); + patch(polygon, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WETH', + base: 'BITCOIN', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 500 when quote token is unknown', async () => { + patchForSell(); + patch(polygon, 'getTokenBySymbol', (symbol: string) => { + if (symbol === 'WETH') { + return { + chainId: 43114, + name: 'WETH', + symbol: 'WETH', + address: '0xd0A1E359811322d97991E03f863a0C30C2cF029C', + decimals: 18, + }; + } else { + return null; + } + }); + + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'BITCOIN', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + maxFeePerGas: '5000000000', + maxPriorityFeePerGas: '5000000000', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for SELL with limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for BUY with limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '999999999999999999999', + }) + .set('Accept', 'application/json') + .expect(200); + }); + + it('should return 200 for SELL with price higher than limitPrice', async () => { + patchForSell(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'SELL', + nonce: 21, + limitPrice: '99999999999', + }) + .set('Accept', 'application/json') + .expect(500); + }); + + it('should return 200 for BUY with price less than limitPrice', async () => { + patchForBuy(); + await request(gatewayApp) + .post(`/amm/trade`) + .send({ + chain: 'polygon', + network: 'mumbai', + connector: 'quickswap', + quote: 'WAVAX', + base: 'WETH', + amount: '10000', + address, + side: 'BUY', + nonce: 21, + limitPrice: '9', + }) + .set('Accept', 'application/json') + .expect(500); + }); +}); diff --git a/test/chains/polygon/quickswap/quickswap.test.ts b/test/chains/polygon/quickswap/quickswap.test.ts new file mode 100644 index 0000000000..81bbd55c75 --- /dev/null +++ b/test/chains/polygon/quickswap/quickswap.test.ts @@ -0,0 +1,146 @@ +jest.useFakeTimers(); +import { Quickswap } from '../../../../src/connectors/quickswap/quickswap'; +import { patch, unpatch } from '../../../services/patch'; +import { UniswapishPriceError } from '../../../../src/services/error-handler'; +import { + Fetcher, + Percent, + Token, + TokenAmount, + Trade, + Pair, + TradeType, + Route, +} from 'quickswap-sdk'; +import { BigNumber } from 'ethers'; +import { Polygon } from '../../../../src/chains/polygon/polygon'; +import { patchEVMNonceManager } from '../../../evm.nonce.mock'; + +let polygon: Polygon; +let quickswap: Quickswap; + +const WMATIC = new Token( + 80001, + '0x9c3c9283d3e44854697cd22d3faa240cfb032889', + 18, + 'WMATIC' +); +const WETH = new Token( + 80001, + '0xa6fa4fb5f76172d178d61b04b0ecd319c5d1c0aa', + 18, + 'WETH' +); + +beforeAll(async () => { + polygon = Polygon.getInstance('mumbai'); + patchEVMNonceManager(polygon.nonceManager); + await polygon.init(); + + quickswap = Quickswap.getInstance('polygon', 'mumbai'); + await quickswap.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(polygon.nonceManager); +}); + +afterEach(() => { + unpatch(); +}); + +afterAll(async () => { + await polygon.close(); +}); + +const patchFetchPairData = () => { + patch(Fetcher, 'fetchPairData', () => { + return new Pair( + new TokenAmount(WMATIC, '2000000000000000000'), + new TokenAmount(WETH, '1000000000000000000') + ); + }); +}; + +const patchTrade = (key: string, error?: Error) => { + patch(Trade, key, () => { + if (error) return []; + const WMATIC_WETH = new Pair( + new TokenAmount(WMATIC, '2000000000000000000'), + new TokenAmount(WETH, '1000000000000000000') + ); + const WETH_TO_WMATIC = new Route([WMATIC_WETH], WETH, WMATIC); + return [ + new Trade( + WETH_TO_WMATIC, + new TokenAmount(WETH, '1000000000000000'), + TradeType.EXACT_INPUT + ), + ]; + }); +}; + +describe('verify Quickswap estimateSellTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn'); + + const expectedTrade = await quickswap.estimateSellTrade( + WMATIC, + WETH, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should throw an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactIn', new Error('error getting trade')); + + await expect(async () => { + await quickswap.estimateSellTrade(WMATIC, WETH, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('verify Quickswap estimateBuyTrade', () => { + it('Should return an ExpectedTrade when available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut'); + + const expectedTrade = await quickswap.estimateBuyTrade( + WMATIC, + WETH, + BigNumber.from(1) + ); + expect(expectedTrade).toHaveProperty('trade'); + expect(expectedTrade).toHaveProperty('expectedAmount'); + }); + + it('Should return an error if no pair is available', async () => { + patchFetchPairData(); + patchTrade('bestTradeExactOut', new Error('error getting trade')); + + await expect(async () => { + await quickswap.estimateBuyTrade(WMATIC, WETH, BigNumber.from(1)); + }).rejects.toThrow(UniswapishPriceError); + }); +}); + +describe('getAllowedSlippage', () => { + it('return value of string when not null', () => { + const allowedSlippage = quickswap.getAllowedSlippage('3/100'); + expect(allowedSlippage).toEqual(new Percent('3', '100')); + }); + + it('return value from config when string is null', () => { + const allowedSlippage = quickswap.getAllowedSlippage(); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); + + it('return value from config when string is malformed', () => { + const allowedSlippage = quickswap.getAllowedSlippage('yo'); + expect(allowedSlippage).toEqual(new Percent('1', '100')); + }); +}); diff --git a/test/config.util.ts b/test/config.util.ts new file mode 100644 index 0000000000..333c1e1d27 --- /dev/null +++ b/test/config.util.ts @@ -0,0 +1,47 @@ +import { ConfigManagerV2 } from '../src/services/config-manager-v2'; + +export class OverrideConfigs { + public nonceDbPath: string; + public transactionDbPath: string; + #testNonceDbPath: string = ''; + #testTransactionDbPath: string = ''; + #initialized: boolean = false; + + public constructor() { + this.nonceDbPath = ConfigManagerV2.getInstance().get( + 'database.nonceDbPath' + ); + this.transactionDbPath = ConfigManagerV2.getInstance().get( + 'database.transactionDbPath' + ); + } + + init(): void { + if (!this.#initialized) { + this.#testNonceDbPath = this.nonceDbPath + '.test'; + this.#testTransactionDbPath = this.transactionDbPath + '.test'; + this.#initialized = true; + } + } + + updateConfigs(): void { + ConfigManagerV2.getInstance().set( + 'database.nonceDbPath', + this.#testNonceDbPath + ); + ConfigManagerV2.getInstance().set( + 'database.transactionDbPath', + this.#testTransactionDbPath + ); + } + + resetConfigs(): void { + ConfigManagerV2.getInstance().set('database.nonceDbPath', this.nonceDbPath); + ConfigManagerV2.getInstance().set( + 'database.transactionDbPath', + this.transactionDbPath + ); + } +} + +export const DBPathOverride = new OverrideConfigs(); diff --git a/test/connectors/connectors.routes.test.ts b/test/connectors/connectors.routes.test.ts new file mode 100644 index 0000000000..7fca9edf1d --- /dev/null +++ b/test/connectors/connectors.routes.test.ts @@ -0,0 +1,13 @@ +import request from 'supertest'; +import { gatewayApp } from '../../src/app'; + +describe('GET /connectors', () => { + it('should return 200 with a list of connectors', async () => { + await request(gatewayApp) + .get(`/connectors`) + .set('Accept', 'application/json') + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.connectors).toBeDefined()); + }); +}); diff --git a/test/evm.nonce.mock.ts b/test/evm.nonce.mock.ts new file mode 100644 index 0000000000..676c4ecd5d --- /dev/null +++ b/test/evm.nonce.mock.ts @@ -0,0 +1,22 @@ +import { patch } from './services/patch'; +import { EVMNonceManager } from '../src/services/evm.nonce'; + +// override values so that nonceManager doesn't crash due to lack of provider +// connection +export const patchEVMNonceManager = (nonceManager: EVMNonceManager): void => { + patch(nonceManager, 'init', () => { + return; + }); + + patch(nonceManager, 'mergeNonceFromEVMNode', () => { + return; + }); + + patch(nonceManager, 'getNonceFromNode', (_ethAddress: string) => { + return Promise.resolve(12); + }); + + patch(nonceManager, 'getNextNonce', (_ethAddress: string) => { + return Promise.resolve(13); + }); +}; diff --git a/test/network/network.routes.test.ts b/test/network/network.routes.test.ts new file mode 100644 index 0000000000..c406942e8a --- /dev/null +++ b/test/network/network.routes.test.ts @@ -0,0 +1,347 @@ +import request from 'supertest'; +import { gatewayApp } from '../../src/app'; +import { Avalanche } from '../../src/chains/avalanche/avalanche'; +import { Cronos } from '../../src/chains/cronos/cronos'; +import { Ethereum } from '../../src/chains/ethereum/ethereum'; +import { Harmony } from '../../src/chains/harmony/harmony'; +import { Polygon } from '../../src/chains/polygon/polygon'; +import { patchEVMNonceManager } from '../evm.nonce.mock'; +import { patch, unpatch } from '../services/patch'; +let eth: Ethereum; +let goerli: Ethereum; +let avalanche: Avalanche; +let harmony: Harmony; +let polygon: Polygon; +let cronos: Cronos; + +beforeAll(async () => { + eth = Ethereum.getInstance('kovan'); + patchEVMNonceManager(eth.nonceManager); + await eth.init(); + + goerli = Ethereum.getInstance('goerli'); + patchEVMNonceManager(goerli.nonceManager); + await goerli.init(); + + avalanche = Avalanche.getInstance('fuji'); + patchEVMNonceManager(avalanche.nonceManager); + await avalanche.init(); + + harmony = Harmony.getInstance('testnet'); + await harmony.init(); + + polygon = Polygon.getInstance('mumbai'); + await polygon.init(); + + cronos = Cronos.getInstance('testnet'); + await cronos.init(); +}); + +beforeEach(() => { + patchEVMNonceManager(eth.nonceManager); + patchEVMNonceManager(goerli.nonceManager); + patchEVMNonceManager(avalanche.nonceManager); + patchEVMNonceManager(harmony.nonceManager); + patchEVMNonceManager(polygon.nonceManager); + patchEVMNonceManager(cronos.nonceManager); +}); + +afterEach(async () => { + unpatch(); +}); + +afterAll(async () => { + await eth.close(); + await goerli.close(); + await avalanche.close(); + await harmony.close(); + await polygon.close(); + await cronos.close(); +}); + +describe('GET /network/status', () => { + it('should return 200 when asking for harmony network status', async () => { + patch(harmony, 'chain', () => { + return 'testnet'; + }); + patch(harmony, 'rpcUrl', 'http://...'); + patch(harmony, 'chainId', 88); + patch(harmony, 'getCurrentBlockNumber', () => { + return 3; + }); + + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'harmony', + network: 'testnet', + }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.chain).toBe('testnet')) + .expect((res) => expect(res.body.chainId).toBeDefined()) + .expect((res) => expect(res.body.rpcUrl).toBeDefined()) + .expect((res) => expect(res.body.currentBlockNumber).toBeDefined()); + }); + + it('should return 200 when asking for ethereum network status', async () => { + patch(eth, 'chain', () => { + return 'kovan'; + }); + patch(eth, 'rpcUrl', 'http://...'); + patch(eth, 'chainId', 34); + patch(eth, 'getCurrentBlockNumber', () => { + return 1; + }); + + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'ethereum', + network: 'kovan', + }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.chain).toBe('kovan')) + .expect((res) => expect(res.body.chainId).toBeDefined()) + .expect((res) => expect(res.body.rpcUrl).toBeDefined()) + .expect((res) => expect(res.body.currentBlockNumber).toBeDefined()); + }); + + it('should return 200 when asking for goerli network status', async () => { + patch(goerli, 'chain', () => { + return 'goerli'; + }); + patch(goerli, 'rpcUrl', 'http://...'); + patch(goerli, 'chainId', 5); + patch(goerli, 'getCurrentBlockNumber', () => { + return 1; + }); + + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'ethereum', + network: 'goerli', + }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.chain).toBe('goerli')) + .expect((res) => expect(res.body.chainId).toBeDefined()) + .expect((res) => expect(res.body.rpcUrl).toBeDefined()) + .expect((res) => expect(res.body.currentBlockNumber).toBeDefined()); + }); + + it('should return 200 when asking for avalance network status', async () => { + patch(avalanche, 'chain', () => { + return 'fuji'; + }); + patch(avalanche, 'rpcUrl', 'http://...'); + patch(avalanche, 'chainId', 20); + patch(avalanche, 'getCurrentBlockNumber', () => { + return 2; + }); + + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'avalanche', + network: 'fuji', + }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.chain).toBe('fuji')) + .expect((res) => expect(res.body.chainId).toBeDefined()) + .expect((res) => expect(res.body.rpcUrl).toBeDefined()) + .expect((res) => expect(res.body.currentBlockNumber).toBeDefined()); + }); + + it('should return 200 when asking for polygon network status', async () => { + patch(polygon, 'chain', () => { + return 'mumbai'; + }); + patch(polygon, 'rpcUrl', 'http://...'); + patch(polygon, 'chainId', 80001); + patch(polygon, 'getCurrentBlockNumber', () => { + return 2; + }); + + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'polygon', + network: 'mumbai', + }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.chain).toBe('mumbai')) + .expect((res) => expect(res.body.chainId).toBeDefined()) + .expect((res) => expect(res.body.rpcUrl).toBeDefined()) + .expect((res) => expect(res.body.currentBlockNumber).toBeDefined()); + }); + + it('should return 200 when asking for cronos network status', async () => { + patch(cronos, 'chain', () => { + return 'testnet'; + }); + patch(cronos, 'rpcUrl', 'http://...'); + patch(cronos, 'chainId', 338); + patch(cronos, 'getCurrentBlockNumber', () => { + return 2; + }); + + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'cronos', + network: 'testnet', + }) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(res.body.chain).toBe('testnet')) + .expect((res) => expect(res.body.chainId).toBeDefined()) + .expect((res) => expect(res.body.rpcUrl).toBeDefined()) + .expect((res) => expect(res.body.currentBlockNumber).toBeDefined()); + }); + + it('should return 200 when requesting network status without specifying', async () => { + patch(eth, 'getCurrentBlockNumber', () => { + return 212; + }); + + patch(avalanche, 'getCurrentBlockNumber', () => { + return 204; + }); + patch(harmony, 'getCurrentBlockNumber', () => { + return 100; + }); + + await request(gatewayApp) + .get(`/network/status`) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => expect(Array.isArray(res.body)).toEqual(true)); + }); + + it('should return 500 when asking for invalid network', async () => { + await request(gatewayApp) + .get(`/network/status`) + .query({ + chain: 'hello', + }) + .expect(500); + }); +}); + +describe('GET /network/config', () => { + it('should return 200 when asking for config', async () => { + request(gatewayApp) + .get(`/network/config`) + .expect('Content-Type', /json/) + .expect(200); + }); +}); + +describe('GET /network/tokens', () => { + it('should return 200 when retrieving ethereum-kovan tokens, tokenSymbols parameter not provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'ethereum', + network: 'kovan', + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving ethereum-kovan tokens, s parameter provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'ethereum', + network: 'kovan', + tokenSymbols: ['COIN3', 'COIN1'], + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving ethereum-goerli tokens, tokenSymbols parameter not provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'ethereum', + network: 'goerli', + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving ethereum-goerli tokens, tokenSymbols parameter provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'ethereum', + network: 'goerli', + tokenSymbols: ['WETH', 'DAI'], + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving polygon-mumbai tokens, tokenSymbols parameter not provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'polygon', + network: 'mumbai', + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving polygon-mumbai tokens, tokenSymbols parameter provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'polygon', + network: 'mumbai', + tokenSymbols: ['WMATIC', 'WETH'], + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving cronos-testnet tokens, tokenSymbols parameter not provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'cronos', + network: 'testnet', + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 200 when retrieving cronos-testnet tokens, tokenSymbols parameter provided', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'cronos', + network: 'testnet', + tokenSymbols: ['WCRO', 'WETH'], + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('should return 500 when retrieving tokens for invalid chain', async () => { + await request(gatewayApp) + .get(`/network/tokens`) + .query({ + chain: 'unknown', + network: 'kovan', + }) + .expect(500); + }); +}); diff --git a/test/postman/collections/EthereumV2.postman_collection.json b/test/postman/collections/EthereumV2.postman_collection.json new file mode 100644 index 0000000000..1708994c21 --- /dev/null +++ b/test/postman/collections/EthereumV2.postman_collection.json @@ -0,0 +1,105 @@ +{ + "info": { + "_postman_id": "f2655c53-5a2d-4030-9cf3-a56001413ca6", + "name": "EthereumV2", + "schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json" + }, + "item": [ + { + "name": "eth/balances", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"privateKey\":\"{{privateKey}}\",\r\n \"tokenSymbols\":[\"ETH\",\"WETH\",\"USDC\", \"DAI\"]\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/eth/balances", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "balances"] + } + }, + "response": [] + }, + { + "name": "eth/poll", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"txHash\":\"0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/eth/poll", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "poll"] + } + }, + "response": [] + }, + { + "name": "eth/approve", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"privateKey\":\"{{privateKey}}\",\r\n \"spender\":\"uniswap\",\r\n \"token\":\"DAI\",\r\n \"amount\":\"\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/eth/approve", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "approve"] + } + }, + "response": [] + }, + { + "name": "eth/allowances", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"privateKey\":\"{{privateKey}}\",\r\n \"spender\":\"uniswap\",\r\n \"tokenSymbols\":[\"DAI\",\"WETH\"]\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/eth/allowances", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "allowances"] + } + }, + "response": [] + } + ] +} diff --git a/test/postman/collections/Openocean-GatewayV2.postman_collection.json b/test/postman/collections/Openocean-GatewayV2.postman_collection.json new file mode 100644 index 0000000000..7fdc53be33 --- /dev/null +++ b/test/postman/collections/Openocean-GatewayV2.postman_collection.json @@ -0,0 +1,57 @@ +{ + "info": { + "_postman_id": "b3877e64-9eb4-4f67-94bc-536b8979477a", + "name": "Openocean-GatewayV2", + "schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json" + }, + "item": [ + { + "name": "amm/trade", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"base\": \"WETH\",\r\n \"quote\": \"DAI\",\r\n \"amount\": \"0.01\",\r\n \"side\": \"buy\",\r\n \"privateKey\": \"{{privateKey}}\",\r\n \"nonce\": 51\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/amm/trade", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["amm", "trade"] + } + }, + "response": [] + }, + { + "name": "amm/price", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"base\": \"WETH\",\r\n \"quote\": \"DAI\",\r\n \"amount\": \"0.01\",\r\n \"side\": \"buy\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/amm/price", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["amm", "price"] + } + }, + "response": [] + } + ] +} diff --git a/test/postman/collections/Uniswap-GatewayV2.postman_collection.json b/test/postman/collections/Uniswap-GatewayV2.postman_collection.json new file mode 100644 index 0000000000..9fb7cf2671 --- /dev/null +++ b/test/postman/collections/Uniswap-GatewayV2.postman_collection.json @@ -0,0 +1,72 @@ +{ + "info": { + "_postman_id": "b3877e64-9eb4-4f67-94bc-536b8979477a", + "name": "Uniswap-GatewayV2", + "schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json" + }, + "item": [ + { + "name": "eth/uniswap", + "request": { + "method": "GET", + "header": [], + "url": { + "raw": "https://localhost:{{port}}/eth/uniswap", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "uniswap"] + } + }, + "response": [] + }, + { + "name": "eth/uniswap/trade", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"base\": \"WETH\",\r\n \"quote\": \"DAI\",\r\n \"amount\": \"0.01\",\r\n \"side\": \"buy\",\r\n \"privateKey\": \"{{privateKey}}\",\r\n \"nonce\": 51\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/eth/uniswap/trade", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "uniswap", "trade"] + } + }, + "response": [] + }, + { + "name": "eth/uniswap/price", + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"base\": \"WETH\",\r\n \"quote\": \"DAI\",\r\n \"amount\": \"0.01\",\r\n \"side\": \"buy\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "https://localhost:{{port}}/eth/uniswap/price", + "protocol": "https", + "host": ["localhost"], + "port": "{{port}}", + "path": ["eth", "uniswap", "price"] + } + }, + "response": [] + } + ] +} diff --git a/test/postman/enviroments/GatewayV2.postman_environment.json b/test/postman/enviroments/GatewayV2.postman_environment.json new file mode 100644 index 0000000000..f34c4e39d9 --- /dev/null +++ b/test/postman/enviroments/GatewayV2.postman_environment.json @@ -0,0 +1,24 @@ +{ + "id": "89deac56-cdda-47a7-9046-62dd044b59d4", + "name": "GatewayV2", + "values": [ + { + "key": "port", + "value": "15888", + "enabled": true + }, + { + "key": "privateKey", + "value": "myprivateKey", + "enabled": true + }, + { + "key": "txHash", + "value": "transactionhash", + "enabled": true + } + ], + "_postman_variable_scope": "environment", + "_postman_exported_at": "2021-09-20T19:28:24.957Z", + "_postman_exported_using": "Postman/9.0.0" +} diff --git a/test/services/base.test.ts b/test/services/base.test.ts new file mode 100644 index 0000000000..1ba1ded5a3 --- /dev/null +++ b/test/services/base.test.ts @@ -0,0 +1,70 @@ +import { BigNumber } from 'ethers'; +import { + bigNumberWithDecimalToStr, + gasCostInEthString, + countDecimals, + fromFractionString, + toFractionString, +} from '../../src/services/base'; +import 'jest-extended'; + +test('countDecimals', () => { + const rangeError = 'countDecimals() is only valid for values between (0, 1).'; + expect(() => countDecimals(0)).toThrow(rangeError); + expect(() => countDecimals(1)).toThrow(rangeError); + expect(() => countDecimals(-1)).toThrow(rangeError); + expect(() => countDecimals(100)).toThrow(rangeError); + expect(() => countDecimals(1.0000123)).toThrow(rangeError); + expect(() => countDecimals(100.0000123)).toThrow(rangeError); + expect(() => countDecimals(1e9)).toThrow(rangeError); + expect(countDecimals(0.0000123)).toEqual(5); + expect(countDecimals(1e-9)).toEqual(9); +}); + +test('bigNumberWithDecimalToStr', () => { + expect(bigNumberWithDecimalToStr(BigNumber.from(10), 1)).toEqual('1.0'); + + expect(bigNumberWithDecimalToStr(BigNumber.from(1), 1)).toEqual('0.1'); + + expect(bigNumberWithDecimalToStr(BigNumber.from(12345), 8)).toEqual( + '0.00012345' + ); + + expect( + bigNumberWithDecimalToStr(BigNumber.from('8447700000000000000'), 18) + ).toEqual('8.447700000000000000'); + + expect( + bigNumberWithDecimalToStr(BigNumber.from('1200304050607080001'), 18) + ).toEqual('1.200304050607080001'); + + expect( + bigNumberWithDecimalToStr(BigNumber.from('1345000000000000000000'), 18) + ).toEqual('1345.000000000000000000'); +}); + +test('gasCostInEthString', () => { + expect(gasCostInEthString(200, 21000)).toEqual('0.004200000000000000'); +}); + +test('fromFractionString', () => { + expect(fromFractionString('1/1')).toEqual(1); + expect(fromFractionString('1/2')).toEqual(0.5); + expect(fromFractionString('3/4')).toEqual(0.75); + expect(fromFractionString('1/100')).toEqual(0.01); + expect(fromFractionString('hello')).toEqual(null); +}); + +test('toFractionString', () => { + expect(toFractionString(1)).toEqual('1/1'); + expect(toFractionString(0.2)).toEqual('1/5'); + expect(toFractionString(0.1)).toEqual('1/10'); + expect(toFractionString(0.3)).toEqual('3/10'); + expect(toFractionString(0.01)).toEqual('1/100'); + expect(toFractionString('1/100')).toEqual('1/100'); + expect(toFractionString('2/100')).toEqual('1/50'); + expect(toFractionString('3/100')).toEqual('3/100'); + expect(toFractionString('0.2')).toEqual('1/5'); + expect(toFractionString('hello')).toEqual(null); + expect(toFractionString('0abc')).toEqual(null); +}); diff --git a/test/services/config-manager-cert-passphrase.test.ts b/test/services/config-manager-cert-passphrase.test.ts new file mode 100644 index 0000000000..7818e3a609 --- /dev/null +++ b/test/services/config-manager-cert-passphrase.test.ts @@ -0,0 +1,39 @@ +import { patch, unpatch } from './patch'; +import { ConfigManagerCertPassphrase } from '../../src/services/config-manager-cert-passphrase'; +import 'jest-extended'; + +describe('ConfigManagerCertPassphrase.readPassphrase', () => { + let witnessFailure = false; + + afterEach(() => { + unpatch(); + witnessFailure = false; + }); + + beforeEach(() => { + patch(ConfigManagerCertPassphrase.bindings, '_exit', () => { + witnessFailure = true; + }); + }); + + it('should get an error if there is no cert phrase', async () => { + ConfigManagerCertPassphrase.readPassphrase(); + expect(witnessFailure).toEqual(true); + }); + + it('should get the cert phrase from the process args', async () => { + const passphrase = 'args_passphrase'; + process.argv.push(`--passphrase=${passphrase}`); + const certPhrase = ConfigManagerCertPassphrase.readPassphrase(); + expect(certPhrase).toEqual(passphrase); + process.argv.pop(); + }); + + it('should get the cert phrase from an env variable', async () => { + const passphrase = 'env_var_passphrase'; + process.env['GATEWAY_PASSPHRASE'] = passphrase; + const certPhrase = ConfigManagerCertPassphrase.readPassphrase(); + expect(certPhrase).toEqual(passphrase); + delete process.env['GATEWAY_PASSPHRASE']; + }); +}); diff --git a/test/services/config-manager-v2.test.ts b/test/services/config-manager-v2.test.ts new file mode 100644 index 0000000000..4155fc4abf --- /dev/null +++ b/test/services/config-manager-v2.test.ts @@ -0,0 +1,238 @@ +import fs from 'fs'; +import fsp from 'fs/promises'; +import fse from 'fs-extra'; +import os from 'os'; +import path from 'path'; +import { + deepCopy, + ConfigManagerV2, + ConfigurationNamespace, + ConfigRootSchemaPath, +} from '../../src/services/config-manager-v2'; + +describe('Configuration manager v2 tests', () => { + const testDataSourcePath: string = fse.realpathSync( + path.join(__dirname, 'data/config-manager-v2') + ); + let tempDirPath: string = ''; + let configManager: ConfigManagerV2; + + beforeEach(async () => { + // Create a temp dir in project + tempDirPath = await fsp.mkdtemp( + path.join(os.tmpdir(), 'config-manager-v2-unit-test') + ); + tempDirPath = fse.realpathSync(tempDirPath); + + // Copy the test data into a temp dir. + await fse.copy(testDataSourcePath, tempDirPath); + + // Create a valid configuration manager from the temp dir. + configManager = new ConfigManagerV2( + path.join(tempDirPath, 'test1/root.yml') + ); + }); + + afterEach(async () => { + // Delete the temp dir. + fs.rmSync(tempDirPath, { force: true, recursive: true }); + tempDirPath = ''; + + // Delete any default configs. + ConfigManagerV2.setDefaults('ethereum', {}); + }); + + it('loading a valid configuration root', (done) => { + expect(configManager.get('ssl.caCertificatePath')).toBeDefined(); + expect(configManager.get('ethereum.networks')).toBeDefined(); + expect(configManager.get('defira.contractAddresses')).toBeDefined(); + done(); + }); + + it('loading an invalid configuration root', (done) => { + expect(() => { + new ConfigManagerV2(path.join(tempDirPath, 'test1/invalid-root.yml')); + }).toThrow(); + expect(() => { + new ConfigManagerV2(path.join(tempDirPath, 'test1/invalid-root-3.yml')); + }).toThrow(); + expect(() => { + new ConfigManagerV2(path.join(tempDirPath, 'test1/invalid-root-4.yml')); + }).toThrow(); + done(); + }); + + it('loading an invalid config file', (done) => { + expect(() => { + new ConfigManagerV2(path.join(tempDirPath, 'test1/invalid-root-2.yml')); + }).toThrow(); + expect(() => { + new ConfigManagerV2( + path.join(tempDirPath, 'test1/invalid-root-defira.yml') + ); + }).toThrow(); + done(); + }); + + it('reading from config file', (done) => { + expect(configManager.get('ssl.keyPath')).toEqual('gateway.key'); + expect(configManager.get('ethereum.networks.kovan.chainID')).toEqual(42); + expect( + configManager.get('ethereum.networks.kovan.nativeCurrencySymbol') + ).toEqual('ETH'); + expect( + configManager.get('defira.contractAddresses.testnet.initCodeHash') + ).toEqual( + '0x7224a10f5f94e12d3973f5ef0f63a558539a93e1eef47935934ffc4d741b4b9f' // noqa: mock + ); + done(); + }); + + it('reading a non-existent config entry', (done) => { + expect(configManager.get('ethereum.kovan.chainID')).toBeUndefined(); + expect(configManager.get('ssl.keyPath.keyPath')).toBeUndefined(); + done(); + }); + + it('reading invalid config keys', (done) => { + expect(() => { + configManager.get('ssl'); + }).toThrow(); + done(); + expect(() => { + configManager.get('noSuchNamespace.networks'); + }).toThrow(); + }); + + it('writing a valid configuration', (done) => { + const newKeyPath: string = 'new-gateway.key'; + configManager.set('ssl.keyPath', newKeyPath); + configManager.set('ethereum.networks.kovan.chainID', 970); + configManager.set('ethereum.networks.mainnet', { + chainID: 61, + nodeURL: 'http://localhost:8561', + tokenListType: 'URL', + tokenListSource: + 'https://wispy-bird-88a7.uniswap.workers.dev/?url=http://tokens.1inch.eth.link', + nativeCurrencySymbol: 'ETH', + }); + expect(configManager.get('ssl.keyPath')).toEqual(newKeyPath); + + const verifyConfigManager: ConfigManagerV2 = new ConfigManagerV2( + path.join(tempDirPath, 'test1/root.yml') + ); + expect(verifyConfigManager.get('ssl.keyPath')).toEqual(newKeyPath); + expect(verifyConfigManager.get('ethereum.networks.kovan.chainID')).toEqual( + 970 + ); + expect( + verifyConfigManager.get('ethereum.networks.mainnet.chainID') + ).toEqual(61); + done(); + }); + + it('writing an invalid configuration', (done) => { + expect(() => { + configManager.set('ssl.nonKeyPath', 'noSuchFile.txt'); + }).toThrow(); + expect(() => { + configManager.set('ethereum', {}); + }).toThrow(); + done(); + }); + + it('using default configurations', (done) => { + ConfigManagerV2.setDefaults('ethereum', { + networks: { + rinkeby: { + chainID: 4, + nodeURL: 'http://localhost:8504', + }, + }, + }); + expect(configManager.get('ethereum.networks.rinkeby.chainID')).toEqual(4); + done(); + }); + + it('getting namespace objects', (done) => { + const sslNamespace: ConfigurationNamespace = configManager.getNamespace( + 'ssl' + ) as ConfigurationNamespace; + expect(path.basename(sslNamespace.schemaPath)).toEqual('ssl-schema.json'); + expect(path.dirname(sslNamespace.schemaPath)).toEqual( + path.dirname(ConfigRootSchemaPath) + ); + expect(sslNamespace.configurationPath).toEqual( + path.join(tempDirPath, 'test1/ssl.yml') + ); + done(); + }); + + it('Test upgradability', () => { + expect(configManager.get('logging.logPath')).toEqual('./logs'); + expect(configManager.get('telemetry.allowed')).toEqual(false); + expect(configManager.get('telemetry.enabled')).toEqual(false); + }); + + it('Dummy test to attempt migration', () => { + const configManager2 = new ConfigManagerV2( + path.join(tempDirPath, 'test1/root2.yml') + ); + expect(configManager2.get('ssl.caCertificatePath')).toBeDefined(); + }); + + it('Test deep copy', (done) => { + const templateObj: any = { + a: 1, + b: { c: { f: 5, g: 6 }, d: 3 }, + e: 4, + j: [{ i: '0' }, { k: '1' }], + l: { m: [1, 2, 3], n: [9, 7, 8] }, + }; + const configObj: any = { + a: 9, + b: { c: 8, d: 7 }, + e: 6, + f: '5', + g: { h: 4 }, + h: ['1', '2'], + j: [{ i: '3' }, { k: '4' }], + l: { m: [9, 7, 8], n: [1, 2, 3] }, + }; + deepCopy(configObj, templateObj); + expect(templateObj.a).toEqual(9); + expect(templateObj.b.d).toEqual(7); + expect(templateObj.b.c).toEqual({ f: 5, g: 6 }); + expect(templateObj.e).toEqual(6); + expect(templateObj.f).toEqual('5'); + expect(templateObj.g).toEqual({ h: 4 }); + expect(templateObj.h).toEqual(['1', '2']); + expect(templateObj.j).toEqual([{ i: '3' }, { k: '4' }]); + expect(templateObj.l.m).toEqual([9, 7, 8]); + expect(templateObj.l.n).toEqual([1, 2, 3]); + done(); + }); + + it('Get all configuration', (done) => { + const allConfigs = configManager.allConfigurations; + expect(allConfigs.ssl.keyPath).toEqual('gateway.key'); + expect(allConfigs.ethereum.networks.kovan.chainID).toEqual(42); + done(); + }); + + it('Get instance', (done) => { + let configManager = ConfigManagerV2.getInstance(); + expect(configManager.allConfigurations.telemetry.enabled).toEqual(false); + configManager = ConfigManagerV2.getInstance(); + expect(configManager.allConfigurations.telemetry.enabled).toEqual(false); + done(); + }); +}); + +describe('Sample configurations', () => { + it('Read sample schemas', (done) => { + const sampleConfigManager = new ConfigManagerV2('./src/templates/root.yml'); + expect(sampleConfigManager.get('ssl.caCertificatePath')).toBeDefined(); + done(); + }); +}); diff --git a/test/services/config-validators.test.ts b/test/services/config-validators.test.ts new file mode 100644 index 0000000000..98061e0968 --- /dev/null +++ b/test/services/config-validators.test.ts @@ -0,0 +1,142 @@ +import { + invalidAllowedSlippage, + validateAllowedSlippage, + updateAllowedSlippageToFraction, +} from '../../src/services/config/config.validators'; +import 'jest-extended'; + +describe('validateAllowedSlippage', () => { + it('valid when req.uniswap.versions.v2.allowedSlippage is a fraction string', () => { + expect( + validateAllowedSlippage({ + configPath: 'req.uniswap.versions.v2.allowedSlippage', + configValue: '1/100', + }) + ).toEqual([]); + }); + + it('valid when req.uniswap.versions.v2.allowedSlippage is a number', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: 0.1, + }) + ).toEqual([]); + }); + + it('valid when req.avalanche.allowedSlippage is a fraction string', () => { + expect( + validateAllowedSlippage({ + configPath: 'req.avalanche.allowedSlippage', + configValue: '3/10', + }) + ).toEqual([]); + }); + + it('valid when req.avalanche.allowedSlippage is a float string', () => { + expect( + validateAllowedSlippage({ + configPath: 'req.avalanche.allowedSlippage', + configValue: '0.005', + }) + ).toEqual([]); + }); + + it('valid when req.avalanche.allowedSlippage is a float string', () => { + expect( + validateAllowedSlippage({ + configPath: 'req.avalanche.allowedSlippage', + configValue: '0.005', + }) + ).toEqual([]); + }); + + it('valid when req.avalanche.allowedSlippage is a number', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: 0.005, + }) + ).toEqual([]); + }); + + it('invalid when req.avalanche.allowedSlippage is too large (number)', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: 1.005, + }) + ).toEqual([invalidAllowedSlippage]); + }); + + it('invalid when req.avalanche.allowedSlippage is too large (fraction)', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: '3/2', + }) + ).toEqual([invalidAllowedSlippage]); + }); + + it('invalid when req.avalanche.allowedSlippage is too small (number)', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: -1.005, + }) + ).toEqual([invalidAllowedSlippage]); + }); + + it('invalid when req.avalanche.allowedSlippage is too small (fraction)', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: '-1/5', + }) + ).toEqual([invalidAllowedSlippage]); + }); + + it('valid when configPath is not allowedSlippage does not exist', () => { + expect( + validateAllowedSlippage({ configPath: 'hello', configValue: 'world' }) + ).toEqual([]); + }); + + it('invalid when req.avalanche.allowedSlippage is a non-numerical string', () => { + expect( + validateAllowedSlippage({ + configPath: 'avalanche.allowedSlippage', + configValue: 'hello', + }) + ).toEqual([invalidAllowedSlippage]); + }); +}); + +describe('updateAllowedSlippageToFraction', () => { + it('update when req.uniswap.versions.v2.allowedSlippage is a number', () => { + const body = { configPath: 'avalanche.allowedSlippage', configValue: 0.1 }; + updateAllowedSlippageToFraction(body); + expect(body.configValue).toEqual('1/10'); + }); + + it('update when req.uniswap.versions.v2.allowedSlippage is a number string', () => { + const body = { configPath: 'avalanche.allowedSlippage', configValue: 0.25 }; + updateAllowedSlippageToFraction(body); + expect(body.configValue).toEqual('1/4'); + }); + + it('do nothing when req.uniswap.versions.v2.allowedSlippage is a fraction', () => { + const body = { + configPath: 'avalanche.allowedSlippage', + configValue: '1/5', + }; + updateAllowedSlippageToFraction(body); + expect(body.configValue).toEqual('1/5'); + }); + + it('do nothing when the configPath is not allowedSlippage', () => { + const body = { configPath: 'hellow', configValue: 'goodbye' }; + updateAllowedSlippageToFraction(body); + expect(body.configValue).toEqual('goodbye'); + }); +}); diff --git a/test/services/data/config-manager-v2/test1/defira.yaml b/test/services/data/config-manager-v2/test1/defira.yaml new file mode 100644 index 0000000000..0d0ab84deb --- /dev/null +++ b/test/services/data/config-manager-v2/test1/defira.yaml @@ -0,0 +1,15 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas allowed for a defira trade. +gasLimit: 150688 + +# how long a trade is valid in seconds. After time passes defira will not +# perform the trade, but the gas will still be sent. +ttl: 600 + +contractAddresses: + testnet: + routerAddress: '0xA5C5D1fd1Fd07F95359E2bde419CB5B2cdC622A9' + initCodeHash: '0x7224a10f5f94e12d3973f5ef0f63a558539a93e1eef47935934ffc4d741b4b9f' diff --git a/test/services/data/config-manager-v2/test1/ethereum.yml b/test/services/data/config-manager-v2/test1/ethereum.yml new file mode 100644 index 0000000000..64af0deeb5 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/ethereum.yml @@ -0,0 +1,15 @@ +networks: + mainnet: + chainID: 1 + nodeURL: https://mainnet.infura.io/v3/ + tokenListType: URL + tokenListSource: https://wispy-bird-88a7.uniswap.workers.dev/?url=http://tokens.1inch.eth.link + nativeCurrencySymbol: ETH + kovan: + chainID: 42 + nodeURL: https://kovan.infura.io/v3/ + tokenListType: FILE + tokenListSource: src/chains/ethereum/erc20_tokens_kovan.json + nativeCurrencySymbol: ETH + +manualGasPrice: 110 diff --git a/test/services/data/config-manager-v2/test1/invalid-defira.yml b/test/services/data/config-manager-v2/test1/invalid-defira.yml new file mode 100644 index 0000000000..438a883f69 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-defira.yml @@ -0,0 +1,18 @@ +# how much the execution price is allowed to move unfavorably from the trade +# execution price. It uses a rational number for precision. +allowedSlippage: '2/100' + +# the maximum gas allowed for a defira trade. +gasLimit: 150688 + +# how long a trade is valid in seconds. After time passes defira will not +# perform the trade, but the gas will still be sent. +ttl: 600 + +contractAddresses: + mainnet: + routerAddress: '0x3C8BF7e25EbfAaFb863256A4380A8a93490d8065' + # missing initCodeHash + testnet: + routerAddress: '0xA5C5D1fd1Fd07F95359E2bde419CB5B2cdC622A9' + initCodeHash: '0x7224a10f5f94e12d3973f5ef0f63a558539a93e1eef47935934ffc4d741b4b9f' \ No newline at end of file diff --git a/test/services/data/config-manager-v2/test1/invalid-root-2.yml b/test/services/data/config-manager-v2/test1/invalid-root-2.yml new file mode 100644 index 0000000000..a1f2098fc5 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-root-2.yml @@ -0,0 +1,8 @@ +version: 1 +configurations: + $namespace ssl: + configurationPath: invalid-ssl.yml + schemaPath: ssl-schema.json + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: ethereum-schema.json diff --git a/test/services/data/config-manager-v2/test1/invalid-root-3.yml b/test/services/data/config-manager-v2/test1/invalid-root-3.yml new file mode 100644 index 0000000000..0df3ba42fe --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-root-3.yml @@ -0,0 +1,8 @@ +version: 1 +configurations: + $namespace ssl: + configurationPath: ssl.yml + schemaPath: ssl-schema.json + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: schema-nonexist.json diff --git a/test/services/data/config-manager-v2/test1/invalid-root-4.yml b/test/services/data/config-manager-v2/test1/invalid-root-4.yml new file mode 100644 index 0000000000..0df3ba42fe --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-root-4.yml @@ -0,0 +1,8 @@ +version: 1 +configurations: + $namespace ssl: + configurationPath: ssl.yml + schemaPath: ssl-schema.json + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: schema-nonexist.json diff --git a/test/services/data/config-manager-v2/test1/invalid-root-defira.yml b/test/services/data/config-manager-v2/test1/invalid-root-defira.yml new file mode 100644 index 0000000000..7cdac26a71 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-root-defira.yml @@ -0,0 +1,5 @@ +version: 1 +configurations: + $namespace defira: + configurationPath: invalid-defira.yml + schemaPath: defira-schema.json \ No newline at end of file diff --git a/test/services/data/config-manager-v2/test1/invalid-root.yml b/test/services/data/config-manager-v2/test1/invalid-root.yml new file mode 100644 index 0000000000..a7039d5da7 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-root.yml @@ -0,0 +1,11 @@ +version: 1 +configurations: + $namespace ssl: + configurationPath: ssl.yml + schemaPath: ssl-schema.json + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: ethereum-schema.json + not a namespace: + configurationPath: no.yml + schemaPath: no.json diff --git a/test/services/data/config-manager-v2/test1/invalid-ssl.yml b/test/services/data/config-manager-v2/test1/invalid-ssl.yml new file mode 100644 index 0000000000..6a983227e5 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/invalid-ssl.yml @@ -0,0 +1,4 @@ +caCertificatePath: ca.crt +certificatePath: gateway.crt +keyPath: gateway.key +funnyKeyPath: funny.key \ No newline at end of file diff --git a/test/services/data/config-manager-v2/test1/root.yml b/test/services/data/config-manager-v2/test1/root.yml new file mode 100644 index 0000000000..fbdd34f595 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/root.yml @@ -0,0 +1,61 @@ +version: 1 +configurations: + $namespace harmony: + configurationPath: harmony.yml + schemaPath: harmony-schema.json + + $namespace avalanche: + configurationPath: avalanche.yml + schemaPath: ethereum-schema.json + + $namespace database: + configurationPath: database.yml + schemaPath: database-schema.json + + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: ethereum-schema.json + + $namespace polygon: + configurationPath: polygon.yml + schemaPath: ethereum-schema.json + + $namespace ethereumGasStation: + configurationPath: ethereum-gas-station.yml + schemaPath: ethereum-gas-station-schema.json + + $namespace defira: + configurationPath: defira.yml + schemaPath: defira-schema.json + + $namespace logging: + configurationPath: logging.yml + schemaPath: logging-schema.json + + $namespace ssl: + configurationPath: ssl.yml + schemaPath: ssl-schema.json + + $namespace pangolin: + configurationPath: pangolin.yml + schemaPath: pangolin-schema.json + + $namespace sushiswap: + configurationPath: sushiswap.yml + schemaPath: sushiswap-schema.json + + $namespace traderjoe: + configurationPath: traderjoe.yml + schemaPath: traderjoe-schema.json + + $namespace server: + configurationPath: server.yml + schemaPath: server-schema.json + + $namespace telemetry: + configurationPath: telemetry.yml + schemaPath: telemetry-schema.json + + $namespace uniswap: + configurationPath: uniswap.yml + schemaPath: uniswap-schema.json diff --git a/test/services/data/config-manager-v2/test1/root2.yml b/test/services/data/config-manager-v2/test1/root2.yml new file mode 100644 index 0000000000..bf92142ed6 --- /dev/null +++ b/test/services/data/config-manager-v2/test1/root2.yml @@ -0,0 +1,14 @@ +version: 0 +configurations: + $namespace ssl: + configurationPath: ssl.yml + schemaPath: ssl-schema.json + $namespace ethereum: + configurationPath: ethereum.yml + schemaPath: ethereum-schema.json + $namespace logging: + configurationPath: logging.yml + schemaPath: logging-schema.json + $namespace telemetry: + configurationPath: telemetry.yml + schemaPath: telemetry-schema.json diff --git a/test/services/data/config-manager-v2/test1/ssl.yml b/test/services/data/config-manager-v2/test1/ssl.yml new file mode 100644 index 0000000000..7ab539b6eb --- /dev/null +++ b/test/services/data/config-manager-v2/test1/ssl.yml @@ -0,0 +1,3 @@ +caCertificatePath: ca.crt +certificatePath: gateway.crt +keyPath: gateway.key diff --git a/test/services/data/config-manager-v2/test1/telemetry.yml b/test/services/data/config-manager-v2/test1/telemetry.yml new file mode 100644 index 0000000000..353450877c --- /dev/null +++ b/test/services/data/config-manager-v2/test1/telemetry.yml @@ -0,0 +1,2 @@ +# If true it will collect data about API usage. +allowed: false diff --git a/test/services/error-handler.test.ts b/test/services/error-handler.test.ts new file mode 100644 index 0000000000..f467755daa --- /dev/null +++ b/test/services/error-handler.test.ts @@ -0,0 +1,154 @@ +import { + parseTransactionGasError, + TRANSACTION_GAS_PRICE_TOO_LOW, + UNKNOWN_ERROR_MESSAGE, + UNKNOWN_ERROR_ERROR_CODE, + NETWORK_ERROR_CODE, + NETWORK_ERROR_MESSAGE, + RATE_LIMIT_ERROR_MESSAGE, + RATE_LIMIT_ERROR_CODE, + HttpException, + gatewayErrorMiddleware, + InitializationError, +} from '../../src/services/error-handler'; +import 'jest-extended'; + +describe('parseTransactionGasError', () => { + test('return null for a normal Error', () => { + expect(parseTransactionGasError(new Error())).toEqual(null); + }); + + test('return errorCode and message for gas price error', () => { + expect( + parseTransactionGasError({ + code: 'SERVER_ERROR', + body: '{"error":{"message":"ERROR","code":-32010}}', + }) + ).toEqual({ errorCode: TRANSACTION_GAS_PRICE_TOO_LOW, message: 'ERROR' }); + }); +}); + +class NetworkError extends Error { + code: string; + constructor(message: string) { + super(message); + this.code = 'NETWORK_ERROR'; + } +} + +class ServerError extends Error { + code: string; + constructor(message: string) { + super(message); + this.code = 'SERVER_ERROR'; + } +} + +class TransactionGasError extends Error { + code: string; + body: string; + constructor(message: string) { + super(message); + this.code = 'SERVER_ERROR'; + this.body = '{"error":{"code":-32010,"message":"need more gas"}}'; + } +} + +class GasPriceTooLowError extends Error { + code: number; + constructor(message: string) { + super(message); + this.code = -32010; + } +} + +class RateLimit extends Error { + code: number; + constructor(message: string) { + super(message); + this.code = -32005; + } +} + +describe('gatewayErrorMiddleware', () => { + test('return 503 and UNKNOWN message and code for a normal error', () => { + expect(gatewayErrorMiddleware(new Error('there was an error'))).toEqual( + expect.objectContaining({ + message: UNKNOWN_ERROR_MESSAGE, + httpErrorCode: 503, + errorCode: UNKNOWN_ERROR_ERROR_CODE, + }) + ); + }); + + test('pass values from HttpException to response error', () => { + expect( + gatewayErrorMiddleware(new HttpException(403, 'error', 100)) + ).toEqual( + expect.objectContaining({ + message: 'error', + httpErrorCode: 403, + errorCode: 100, + }) + ); + }); + + test('return NETWORK_ERROR_CODE and NETWORK_ERROR_MESSAGE for network error', () => { + expect(gatewayErrorMiddleware(new NetworkError('error2'))).toEqual( + expect.objectContaining({ + message: NETWORK_ERROR_MESSAGE, + httpErrorCode: 503, + errorCode: NETWORK_ERROR_CODE, + }) + ); + }); + + test('return Infura RateLimit error', () => { + expect(gatewayErrorMiddleware(new RateLimit('error3'))).toEqual( + expect.objectContaining({ + message: RATE_LIMIT_ERROR_MESSAGE, + httpErrorCode: 503, + errorCode: RATE_LIMIT_ERROR_CODE, + }) + ); + }); + + test('return NETWORK_ERROR_CODE and NETWORK_ERROR_MESSAGE for network error', () => { + expect( + gatewayErrorMiddleware(new InitializationError('error4', 123)) + ).toEqual( + expect.objectContaining({ + message: 'error4', + errorCode: 123, + }) + ); + }); + + test('return NETWORK_ERROR_CODE and NETWORK_ERROR_MESSAGE for server error if not a transaction gas error', () => { + expect(gatewayErrorMiddleware(new ServerError('error5'))).toEqual( + expect.objectContaining({ + message: NETWORK_ERROR_MESSAGE, + httpErrorCode: 503, + errorCode: NETWORK_ERROR_CODE, + }) + ); + }); + + test('return transaction errorCode and message if it is a transaction gas error', () => { + expect(gatewayErrorMiddleware(new TransactionGasError('error6'))).toEqual( + expect.objectContaining({ + message: 'need more gas', + httpErrorCode: 503, + errorCode: TRANSACTION_GAS_PRICE_TOO_LOW, + }) + ); + }); + + test('return transaction errorCode and message if it is a transaction gas error', () => { + expect(gatewayErrorMiddleware(new GasPriceTooLowError('error7'))).toEqual( + expect.objectContaining({ + errorCode: TRANSACTION_GAS_PRICE_TOO_LOW, + }) + ); + }); +}); diff --git a/test/services/evm.nonce.test.ts b/test/services/evm.nonce.test.ts new file mode 100644 index 0000000000..b80a735712 --- /dev/null +++ b/test/services/evm.nonce.test.ts @@ -0,0 +1,182 @@ +import { providers } from 'ethers'; +import fs from 'fs'; +import fse from 'fs-extra'; +import fsp from 'fs/promises'; +import 'jest-extended'; +import os from 'os'; +import path from 'path'; +import { + EVMNonceManager, + NonceInfo, + NonceLocalStorage, +} from '../../src/services/evm.nonce'; +import { ReferenceCountingCloseable } from '../../src/services/refcounting-closeable'; +import { patch } from './patch'; + +describe('Test NonceLocalStorage', () => { + let dbPath: string = ''; + let db: NonceLocalStorage; + const handle: string = ReferenceCountingCloseable.createHandle(); + + beforeAll(async () => { + dbPath = await fsp.mkdtemp( + path.join(os.tmpdir(), '/NonceLocalStorage.test.level') + ); + }); + + beforeEach(() => { + db = NonceLocalStorage.getInstance(dbPath, handle); + }); + + afterAll(async () => { + await fse.emptyDir(dbPath); + fs.rmSync(dbPath, { force: true, recursive: true }); + }); + + afterEach(async () => { + await db.close(handle); + }); + + it('save, get and delete nonces', async () => { + const testChain1 = 'ethereum'; + const testChain1Id = 1; + const address1 = 'A'; + const address2 = 'B'; + + const now: number = new Date().getTime(); + + // saves a key with a NonceInfo value + db.saveLeadingNonce( + testChain1, + testChain1Id, + address1, + new NonceInfo(15, now + 1000) + ); + db.saveLeadingNonce( + testChain1, + testChain1Id, + address2, + new NonceInfo(23, now + 1000) + ); + + const results = await db.getLeadingNonces(testChain1, testChain1Id); + + // returns with an address as key with the corresponding NonceInfo value + expect(results).toStrictEqual({ + [address1]: new NonceInfo(15, now + 1000), + [address2]: new NonceInfo(23, now + 1000), + }); + }); +}); + +describe('Test EVMNonceManager', () => { + let dbPath: string = ''; + + beforeAll(async () => { + dbPath = await fsp.mkdtemp( + path.join(__dirname, '/EVMNonceManager.test.level') + ); + }); + + afterAll(async () => { + await fse.emptyDir(dbPath); + await fs.rmSync(dbPath, { force: true, recursive: true }); + }); + + const testChain1 = 'ethereum'; + const testChain1Id = 1; + + const testChain2 = 'avalanche'; + const testChain2Id = 1; + const address1 = 'ABC'; + + it('getNonce reads nonce from node, commits, then reads nonce from memory', async () => { + const evmNonceManager = new EVMNonceManager( + testChain1, + testChain1Id, + dbPath, + 300 + ); + + patch(evmNonceManager, 'mergeNonceFromEVMNode', (_ethAddress: string) => { + return; + }); + + patch(evmNonceManager, 'getNonceFromNode', (_ethAddress: string) => { + return Promise.resolve(12); + }); + + await evmNonceManager.init( + new providers.StaticJsonRpcProvider('https://kovan.infura.io/v3/') + ); + + const nonce = await evmNonceManager.getNonce(address1); + + expect(nonce).toEqual(12); + + await evmNonceManager.commitNonce(address1, nonce); + + const nonce2 = await evmNonceManager.getNextNonce(address1); + + expect(nonce2).toEqual(13); + }); + + it('commits to the same address on different chains should have separate nonce values', async () => { + const ethereumNonceManager = new EVMNonceManager( + testChain1, + testChain1Id, + dbPath, + 300 + ); + + const avalancheNonceManager = new EVMNonceManager( + testChain2, + testChain2Id, + dbPath, + 300 + ); + + patch( + ethereumNonceManager, + 'mergeNonceFromEVMNode', + (_ethAddress: string) => { + return; + } + ); + + patch(ethereumNonceManager, 'getNonceFromNode', (_ethAddress: string) => { + return Promise.resolve(30); + }); + + patch( + avalancheNonceManager, + 'mergeNonceFromEVMNode', + (_ethAddress: string) => { + return; + } + ); + + patch(avalancheNonceManager, 'getNonceFromNode', (_ethAddress: string) => { + return Promise.resolve(51); + }); + + await ethereumNonceManager.init(new providers.StaticJsonRpcProvider('')); + + await avalancheNonceManager.init(new providers.StaticJsonRpcProvider('')); + + const ethereumNonce1 = await ethereumNonceManager.getNextNonce(address1); + const avalancheNonce1 = await avalancheNonceManager.getNextNonce(address1); + + expect(ethereumNonce1).toEqual(14); // exists from previous test + expect(avalancheNonce1).toEqual(52); + + await ethereumNonceManager.commitNonce(address1, ethereumNonce1); + await avalancheNonceManager.commitNonce(address1, avalancheNonce1); + + const ethereumNonce2 = await ethereumNonceManager.getNextNonce(address1); + const avalancheNonce2 = await avalancheNonceManager.getNextNonce(address1); + + expect(ethereumNonce2).toEqual(15); + expect(avalancheNonce2).toEqual(53); + }); +}); diff --git a/test/services/evm.tx-storage.test.ts b/test/services/evm.tx-storage.test.ts new file mode 100644 index 0000000000..4984df1de9 --- /dev/null +++ b/test/services/evm.tx-storage.test.ts @@ -0,0 +1,121 @@ +import fs from 'fs'; +import fsp from 'fs/promises'; +import fse from 'fs-extra'; +import os from 'os'; +import path from 'path'; +import { EvmTxStorage } from '../../src/services/evm.tx-storage'; +import 'jest-extended'; +import { ReferenceCountingCloseable } from '../../src/services/refcounting-closeable'; + +describe('Test local-storage', () => { + let dbPath: string = ''; + let db: EvmTxStorage; + let handle: string; + + beforeAll(async () => { + dbPath = await fsp.mkdtemp( + path.join(os.tmpdir(), '/evm.tx-storage.test.level') + ); + }); + + afterAll(async () => { + await fse.emptyDir(dbPath); + fs.rmSync(dbPath, { force: true, recursive: true }); + }); + + beforeEach(() => { + handle = ReferenceCountingCloseable.createHandle(); + db = EvmTxStorage.getInstance(dbPath, handle); + }); + + afterEach(async () => { + await db.close(handle); + }); + + it('save, get and delete a key value pair in the local db', async () => { + const testChain1 = 'ethereum'; + const testChain1Id = 423; + const testChain1Tx1 = + '0xadaef9c4540192e45c991ffe6f12cc86be9c07b80b43487e5778d95c964405c7'; // noqa: mock + const testChain1GasPrice1 = 200000; + const testChain1Tx2 = + '0xadaef9c4540192e45c991ffe6f12cc86be9c07b80b43487edddddddddddddddd'; // noqa: mock + const testChain1GasPrice2 = 200300; + + // clean up any previous db runs + await db.deleteTx(testChain1, testChain1Id, testChain1Tx1); + await db.deleteTx(testChain1, testChain1Id, testChain1Tx2); + + // saves a key with a value + const testTime1 = new Date(); + await db.saveTx( + testChain1, + testChain1Id, + testChain1Tx1, + testTime1, + testChain1GasPrice1 + ); + + const results = await db.getTxs(testChain1, testChain1Id); + + // returns with an address as key, the chain/id is known by the parameters you provide + expect(results).toStrictEqual({ + [testChain1Tx1]: [testTime1, testChain1GasPrice1], + }); + + // store and retrieve a second value for the same chain/chainId + const testTime2 = new Date(); + await db.saveTx( + testChain1, + testChain1Id, + testChain1Tx2, + testTime2, + testChain1GasPrice2 + ); + const results2 = await db.getTxs(testChain1, testChain1Id); + + // returns with an address as key, the chain/id is known by the parameters you provide + expect(results2).toStrictEqual({ + [testChain1Tx1]: [testTime1, testChain1GasPrice1], + [testChain1Tx2]: [testTime2, testChain1GasPrice2], + }); + + // store and retrieve a third value for the a different chain/chainId + const testChain2 = 'avalanche'; + const testChain2Id = 10; + const testChain2Tx1 = + '0xadaef9c4540192e45c991ffe6f12cc86be9c07b80b43487fffffffffffffffff'; // noqa: mock + const testChain2GasPrice1 = 4000000; + const testTime3 = new Date(); + + // cleanup from previous test runs + await db.deleteTx(testChain2, testChain2Id, testChain2Tx1); + + // store data + await db.saveTx( + testChain2, + testChain2Id, + testChain2Tx1, + testTime3, + testChain2GasPrice1 + ); + + // retrieve and test + const results3 = await db.getTxs(testChain2, testChain2Id); + expect(results3).toStrictEqual({ + [testChain2Tx1]: [testTime3, testChain2GasPrice1], + }); + + // test db path is as exected place + expect(db.localStorage.dbPath).toStrictEqual(dbPath); + + // delete the recently added key/value pair + await db.deleteTx(testChain1, testChain1Id, testChain1Tx1); + await db.deleteTx(testChain1, testChain1Id, testChain1Tx2); + + const results4 = await db.getTxs(testChain1, testChain1Id); + + // the key has been deleted, expect an empty object + expect(results4).toStrictEqual({}); + }); +}); diff --git a/test/services/local-storage.test.ts b/test/services/local-storage.test.ts new file mode 100644 index 0000000000..2969627e2b --- /dev/null +++ b/test/services/local-storage.test.ts @@ -0,0 +1,92 @@ +import fs from 'fs'; +import fsp from 'fs/promises'; +import fse from 'fs-extra'; +import os from 'os'; +import path from 'path'; +import { LocalStorage } from '../../src/services/local-storage'; +import 'jest-extended'; +import { ReferenceCountingCloseable } from '../../src/services/refcounting-closeable'; + +let dbPath: string = ''; +const handle: string = ReferenceCountingCloseable.createHandle(); + +beforeAll(async () => { + dbPath = await fsp.mkdtemp( + path.join(os.tmpdir(), '/local-storage.test.level') + ); +}); + +afterAll(async () => { + await fse.emptyDir(dbPath); + fs.rmSync(dbPath, { force: true, recursive: true }); + + const db: LocalStorage = LocalStorage.getInstance(dbPath, handle); + await db.close(handle); +}); + +describe('Test local-storage', () => { + it('save, get and delete a key value pair in the local db', async () => { + const testKey = 'abc'; + const testValue = 123; + + const db: LocalStorage = LocalStorage.getInstance(dbPath, handle); + + // clean up any previous db runs + await db.del(testKey); + + // saves a key with a value + await db.save(testKey, testValue); + + const results: Record = await db.get((k: string, v: any) => { + return [k, parseInt(v)]; + }); + + // returns with an address as key, the chain/id is known by the parameters you provide + expect(results).toStrictEqual({ + [testKey]: testValue, + }); + + expect(db.dbPath).toStrictEqual(dbPath); + + // delete the recently added key/value pair + await db.del(testKey); + + const results2: Record = await db.get((k: string, v: any) => { + return [k, parseInt(v)]; + }); + + // the key has been deleted, expect an empty object + expect(results2).toStrictEqual({}); + }); + + it('Put and retrieve a objects', async () => { + const db: LocalStorage = LocalStorage.getInstance(dbPath, handle); + + const firstKey: string = 'camel'; + const firstValue = { kingdom: 'animalia', family: 'camelidae' }; + + const secondKey: string = 'elephant'; + const secondValue = { kingdom: 'animalia', family: 'elephantidae' }; + + const thirdKey: string = 'trex'; + const thirdValue = { kingdom: 'animalia', family: 'tyrannosauridae' }; + + const fourthKey: string = 'shiitake'; + const fourthValue = { kingdom: 'animalia', family: 'omphalotaceae' }; + + // saves a key with a value + await db.save(firstKey, firstValue); + await db.save(secondKey, secondValue); + await db.save(thirdKey, thirdValue); + await db.save(fourthKey, fourthValue); + + const results: Record = await db.get((k: string, v: any) => { + return [k, v]; + }); + + expect(results[firstKey]).toStrictEqual(firstValue); + expect(results[secondKey]).toStrictEqual(secondValue); + expect(results[thirdKey]).toStrictEqual(thirdValue); + expect(results[fourthKey]).toStrictEqual(fourthValue); + }); +}); diff --git a/test/services/logger.test.ts b/test/services/logger.test.ts new file mode 100644 index 0000000000..30228ebe01 --- /dev/null +++ b/test/services/logger.test.ts @@ -0,0 +1,32 @@ +import winston from 'winston'; +import { ConfigManagerV2 } from '../../src/services/config-manager-v2'; +import { + logger, + updateLoggerToStdout, + telemetry, +} from '../../src/services/logger'; + +describe('Test logger', () => { + it('updateLoggerToStdout works', (done) => { + ConfigManagerV2.getInstance().set('logging.logToStdOut', true); + updateLoggerToStdout(); + const ofTypeConsole = (element: any) => + element instanceof winston.transports.Console; + expect(logger.transports.some(ofTypeConsole)).toEqual(true); + ConfigManagerV2.getInstance().set('logging.logToStdOut', false); + updateLoggerToStdout(); + // Not sure why the below test doesn't on Github but passes on local + // expect(logger.transports.some(ofTypeConsole)).toEqual(false); + done(); + }); + + it('test telemetry transport can be added', () => { + const initTransports = logger.transports.length; + if (!ConfigManagerV2.getInstance().get('telemetry.enabled')) { + ConfigManagerV2.getInstance().set('telemetry.enabled', true); + telemetry(); + ConfigManagerV2.getInstance().set('telemetry.enabled', false); + expect(logger.transports.length).toEqual(initTransports + 1); + } + }); +}); diff --git a/test/services/patch.test.ts b/test/services/patch.test.ts new file mode 100644 index 0000000000..e40262da64 --- /dev/null +++ b/test/services/patch.test.ts @@ -0,0 +1,141 @@ +import { patch, unpatch } from './patch'; +import 'jest-extended'; + +class A { + private _x: number = 0; + + public get x() { + return this._x; + } + + private _y: boolean = false; + + public get y() { + return this._y; + } + + private _z: string = 'Guten Tag'; + + public get z() { + return this._z; + } +} + +class B { + private _alter: (x: string) => string = (x) => x.toLowerCase(); + + public get alter() { + return this._alter; + } +} + +class Singleton { + private static _instance: Singleton; + + private _x: number = -1; + + // eslint-disable-next-line @typescript-eslint/no-empty-function + private constructor() {} + + public static getInstance(): Singleton { + if (!Singleton._instance) { + Singleton._instance = new Singleton(); + } + return Singleton._instance; + } + + public get x() { + return this._x; + } +} + +describe('internal patch system', () => { + it('It can patch and unpatch private variables', () => { + const a = new A(); + // _x is private + patch(a, '_x', 1); + expect(a.x).toEqual(1); + + patch(a, 'x', () => 3); + expect(a.x).toEqual(3); + + unpatch(); + expect(a.x).toEqual(0); + }); + + it('It can patch a value multiple times and then retrieve the original value', () => { + const a = new A(); + patch(a, '_x', 1); + expect(a.x).toEqual(1); + + patch(a, '_x', 3); + expect(a.x).toEqual(3); + + patch(a, '_x', 10); + expect(a.x).toEqual(10); + + unpatch(); + expect(a.x).toEqual(0); + }); + + it('It can patch multiple values on an object and then retrieve all the original values', () => { + const a = new A(); + patch(a, '_x', 178); + patch(a, '_y', true); + patch(a, '_z', 'Guten Nacht'); + expect(a.x).toEqual(178); + expect(a.y).toEqual(true); + expect(a.z).toEqual('Guten Nacht'); + + patch(a, '_x', 999); + patch(a, '_z', 'Hummingbot'); + expect(a.x).toEqual(999); + expect(a.z).toEqual('Hummingbot'); + + unpatch(); + expect(a.x).toEqual(0); + expect(a.y).toEqual(false); + expect(a.z).toEqual('Guten Tag'); + }); + + it('It can patch and unpatch methods', () => { + const b = new B(); + // '_alter' is private + patch(b, '_alter', (x: string) => x.toUpperCase()); + expect(b.alter('HeLlO')).toEqual('HELLO'); + + // ignore param + patch(b, '_alter', () => 'Hummingbot'); + expect(b.alter('HeLlO')).toEqual('Hummingbot'); + + unpatch(); + expect(b.alter('HeLlO')).toEqual('hello'); + }); + + it('It can patch getter methods', () => { + const b = new B(); + + patch(b, 'alter', (_x: any) => (_y: any) => 'Hummingbot'); + expect(b.alter('HeLlO')).toEqual('Hummingbot'); + + unpatch(); + expect(b.alter('HeLlO')).toEqual('hello'); + }); + + it('It can patch and unpatch a singleton correctly', () => { + const a = Singleton.getInstance(); + const b = Singleton.getInstance(); + + patch(a, '_x', 1); + expect(a.x).toEqual(1); + expect(b.x).toEqual(1); + + patch(b, '_x', 1122); + expect(a.x).toEqual(1122); + expect(b.x).toEqual(1122); + + unpatch(); + expect(a.x).toEqual(-1); + expect(b.x).toEqual(-1); + }); +}); diff --git a/test/services/patch.ts b/test/services/patch.ts new file mode 100644 index 0000000000..c338779f2f --- /dev/null +++ b/test/services/patch.ts @@ -0,0 +1,80 @@ +let patchedObjects: Set = new Set(); + +export const classHasGetter = (obj: any, prop: string): boolean => { + const description = Object.getOwnPropertyDescriptor( + Object.getPrototypeOf(obj), + prop + ); + if (description) { + return !!description.get; + } + return false; +}; + +// override an existing property value, but make the old one recoverable. +export const patch = (target: any, propertyName: string, mock: any): void => { + // clean up a target if it has already been patched, this avoids issues in unpatch + if (patchedObjects.has(target)) patchedObjects.delete(target); + + // only store the previous property if it has not been mocked yet, this way we preserve + // the original non mocked value + if (!('__original__' + propertyName in target)) { + if (Object.getOwnPropertyDescriptor(target, propertyName)) { + // general case + target['__original__' + propertyName] = target[propertyName]; + } else { + // special case for getters and setters + target['__original__' + propertyName] = Object.getOwnPropertyDescriptor( + Object.getPrototypeOf(target), + propertyName + ); + } + } + + if (classHasGetter(target, propertyName)) { + // special case for getter without setter + const targetPrototype = Object.getPrototypeOf(target); + + Object.defineProperty(targetPrototype, propertyName, { + get: mock, + // this is a dummy setter, there needs to be a setter in order to change the getter + // the idea is that the mock overrides the getter and ignores the setter + set: (_value: any) => { + return; + }, + }); + + Object.setPrototypeOf(target, targetPrototype); + } else { + // general case + target[propertyName] = mock; + } + + patchedObjects.add(target); +}; + +// recover all old property values from before the patch. +export const unpatch = (): void => { + patchedObjects.forEach((target: any) => { + const keys = Object.keys(target); + keys.forEach((key: string) => { + if (key.startsWith('__original__')) { + const propertyName = key.slice(12); + + if (Object.getOwnPropertyDescriptor(target, propertyName)) { + // the property exists directly on the object + target[propertyName] = target[key]; + } else { + // the property is at a lower level in the object, it is likely a getter or setter + const targetPrototype = Object.getPrototypeOf(target); + + Object.defineProperty(targetPrototype, propertyName, target[key]); + Object.setPrototypeOf(target, targetPrototype); + } + + delete target[key]; + } + }); + }); + patchedObjects = new Set(); +}; diff --git a/test/services/refcounting-closeable.test.ts b/test/services/refcounting-closeable.test.ts new file mode 100644 index 0000000000..307e4ec83a --- /dev/null +++ b/test/services/refcounting-closeable.test.ts @@ -0,0 +1,180 @@ +import 'jest-extended'; +import { ReferenceCountingCloseable } from '../../src/services/refcounting-closeable'; + +class RefCountFixture extends ReferenceCountingCloseable { + private _finalized: boolean; + private readonly _members: { [key: string]: RefCountFixture }; + + constructor(retrievalKey: string) { + super(retrievalKey); + this._finalized = false; + this._members = {}; + } + + get finalized(): boolean { + return this._finalized; + } + + get members(): { [key: string]: RefCountFixture } { + return this._members; + } + + public async add(memberKey: string) { + const member: RefCountFixture = RefCountFixture.getInstance( + memberKey, + this.handle + ); + this._members[memberKey] = member; + } + + public async remove(memberKey: string) { + if (!(memberKey in this._members)) { + return; + } + + const member: RefCountFixture = this._members[memberKey]; + delete this._members[memberKey]; + await member.close(this.handle); + } + + public async close(ownersHandler: string): Promise { + await super.close(ownersHandler); + if (this.refCount < 1) { + for (const memberKey of Object.keys(this._members)) { + await this.remove(memberKey); + } + this._finalized = true; + } + } +} + +describe('Reference counting closeable tests', () => { + const rootHandle: string = ReferenceCountingCloseable.createHandle(); + + it('Finalize after being released by owner', async () => { + const fixture: RefCountFixture = RefCountFixture.getInstance( + 'instance1', + rootHandle + ); + + try { + expect(fixture.refCount).toEqual(1); + expect(fixture.finalized).toBeFalse(); + await fixture.close(rootHandle); + expect(fixture.refCount).toEqual(0); + expect(fixture.finalized).toBeTrue(); + } finally { + await fixture.close(rootHandle); + } + }); + + it('Do not finalize if more than zero owner left', async () => { + const owner1: RefCountFixture = RefCountFixture.getInstance( + 'instance1', + rootHandle + ); + const owner2: RefCountFixture = RefCountFixture.getInstance( + 'instance2', + rootHandle + ); + const sharedObject: RefCountFixture = RefCountFixture.getInstance( + 'shared', + rootHandle + ); + + try { + await owner1.add('shared'); + await owner2.add('shared'); + expect(sharedObject.refCount).toEqual(3); + await sharedObject.close(rootHandle); + expect(sharedObject.refCount).toEqual(2); + expect(sharedObject.finalized).toBeFalse(); + + await owner1.remove('shared'); + expect(sharedObject.refCount).toEqual(1); + expect(sharedObject.finalized).toBeFalse(); + + await owner2.remove('shared'); + expect(sharedObject.refCount).toEqual(0); + expect(sharedObject.finalized).toBeTrue(); + } finally { + await owner1.close(rootHandle); + await owner2.close(rootHandle); + await sharedObject.close(rootHandle); + } + }); + + it('Cascading finalization given an ownership graph', async () => { + const node1_1: RefCountFixture = RefCountFixture.getInstance( + 'node1_1', + rootHandle + ); + const node1_2: RefCountFixture = RefCountFixture.getInstance( + 'node1_2', + rootHandle + ); + const node1_3: RefCountFixture = RefCountFixture.getInstance( + 'node1_3', + rootHandle + ); + const node2_1: RefCountFixture = RefCountFixture.getInstance( + 'node2_1', + rootHandle + ); + const node3_1: RefCountFixture = RefCountFixture.getInstance( + 'node3_1', + rootHandle + ); + const node4_1: RefCountFixture = RefCountFixture.getInstance( + 'node4_1', + rootHandle + ); + const allNodes: RefCountFixture[] = [ + node1_1, + node1_2, + node1_3, + node2_1, + node3_1, + node4_1, + ]; + + try { + // Connect the nodes together as a dependency tree. + await node1_1.add('node2_1'); + await node1_2.add('node2_1'); + await node1_3.add('node2_1'); + await node2_1.add('node3_1'); + await node3_1.add('node4_1'); + + // Remove the non-top nodes from root ownership. + await node2_1.close(rootHandle); + await node3_1.close(rootHandle); + await node4_1.close(rootHandle); + + // Ensure all nodes are still not finalized. + expect(node1_1.refCount).toEqual(1); + expect(node1_2.refCount).toEqual(1); + expect(node1_3.refCount).toEqual(1); + expect(node2_1.refCount).toEqual(3); + expect(node3_1.refCount).toEqual(1); + expect(node4_1.refCount).toEqual(1); + for (const n of allNodes) { + expect(n.finalized).toBeFalse(); + } + + // Close the top nodes. + await node1_1.close(rootHandle); + await node1_2.close(rootHandle); + await node1_3.close(rootHandle); + + // All nodes should be finalized by now. + for (const n of allNodes) { + expect(n.finalized).toBeTrue(); + } + } finally { + for (const n of allNodes) { + await n.close(rootHandle); + } + } + }); +}); diff --git a/test/services/swagger-manager.test.ts b/test/services/swagger-manager.test.ts new file mode 100644 index 0000000000..ff66c86058 --- /dev/null +++ b/test/services/swagger-manager.test.ts @@ -0,0 +1,134 @@ +import { SwaggerManager } from '../../src/services/swagger-manager'; +import { patch, unpatch } from './patch'; +import fs from 'fs'; + +import 'jest-extended'; + +describe('validateMainFile', () => { + it('true with all expected keys', () => { + expect( + SwaggerManager.validateMainFile({ + swagger: '', + info: '', + host: '', + tags: '', + schemes: '', + externalDocs: '', + }) + ).toEqual(true); + }); + it('false with a key missing', () => { + expect( + SwaggerManager.validateMainFile({ + info: '', + host: '', + tags: '', + schemes: '', + externalDocs: '', + }) + ).toEqual(false); + }); +}); + +describe('validateRoutesFile', () => { + it('true with all expected keys', () => { + expect( + SwaggerManager.validateRoutesFile({ + paths: '', + }) + ).toEqual(true); + }); + it('false with a key missing', () => { + expect( + SwaggerManager.validateRoutesFile({ + info: '', + }) + ).toEqual(false); + }); +}); + +describe('validateDefinitionsFile', () => { + it('true with all expected keys', () => { + expect( + SwaggerManager.validateDefinitionsFile({ + definitions: '', + }) + ).toEqual(true); + }); + it('false with a key missing', () => { + expect( + SwaggerManager.validateDefinitionsFile({ + info: '', + }) + ).toEqual(false); + }); +}); + +describe('validate', () => { + afterEach(() => { + unpatch(); + }); + + it('return object if validation function returns true', () => { + patch(fs, 'readFileSync', () => 'definitions: abc'); + expect( + SwaggerManager.validate( + 'dummy-file-name', + SwaggerManager.validateDefinitionsFile + ) + ).toEqual({ definitions: 'abc' }); + }); + + it('throws an error if validation function returns false', () => { + patch(fs, 'readFileSync', () => 'definitions: abc'); + expect(() => + SwaggerManager.validate( + 'dummy-file-name', + SwaggerManager.validateMainFile + ) + ).toThrow(); + }); +}); + +describe('generateSwaggerJson', () => { + afterEach(() => { + unpatch(); + }); + + it('return object if validation function returns true', () => { + patch(fs, 'readFileSync', (fp: string) => { + if (fp === 'main') { + return "swagger: two\ninfo: 'nothing'\nhost: 'localhost'\ntags: []\nschemes: []\nexternalDocs: ''"; + } else if (fp === 'definitions') { + return 'definitions: []'; + } + return 'paths:\n /eth:\n get'; + }); + expect( + SwaggerManager.generateSwaggerJson('main', 'definitions', ['path']) + ).toEqual({ + swagger: 'two', + info: 'nothing', + host: 'localhost', + tags: [], + schemes: [], + externalDocs: '', + definitions: [], + paths: { '/eth': 'get' }, + }); + }); + + it('throw an error if something does not conform to the structure', () => { + patch(fs, 'readFileSync', (fp: string) => { + if (fp === 'main') { + return 'swagger: two\n'; + } else if (fp === 'definitions') { + return 'definitions: []'; + } + return 'paths:\n /eth:\n get'; + }); + expect(() => + SwaggerManager.generateSwaggerJson('main', 'definitions', ['path']) + ).toThrow(); + }); +}); diff --git a/test/services/validators.test.ts b/test/services/validators.test.ts new file mode 100644 index 0000000000..bfb027a595 --- /dev/null +++ b/test/services/validators.test.ts @@ -0,0 +1,199 @@ +import { + isNaturalNumberString, + isIntegerString, + isFloatString, + missingParameter, + validateTokenSymbols, + isBase58, + validateToken, + validateAmount, + validateTxHash, + invalidTokenSymbolsError, + invalidTokenError, + invalidAmountError, + invalidTxHashError, +} from '../../src/services/validators'; +import 'jest-extended'; + +export const tokenSymbols = ['DAI', 'WETH']; +export const txHash = + '0x6d068067a5e5a0f08c6395b31938893d1cdad81f54a54456221ecd8c1941294d'; // noqa: mock + +describe('isNaturalNumberString', () => { + it('pass against a well formed natural number in a string', () => { + expect(isNaturalNumberString('12345')).toEqual(true); + }); + + it('fail against a negative number in a string', () => { + expect(isNaturalNumberString('-12')).toEqual(false); + }); + + it('fail against a non number string', () => { + expect(isNaturalNumberString('Hello world')).toEqual(false); + }); +}); + +describe('isIntegerString', () => { + it('pass against a positive number in a string', () => { + expect(isIntegerString('12345')).toEqual(true); + }); + + it('pass against a negative number in a string', () => { + expect(isIntegerString('-12')).toEqual(true); + }); + + it('fail against a non number string', () => { + expect(isIntegerString('Hello world')).toEqual(false); + }); +}); + +describe('isFloatString', () => { + it('pass against a positive number in a string', () => { + expect(isFloatString('12345')).toEqual(true); + + expect(isFloatString('12.345')).toEqual(true); + + expect(isFloatString('0.45')).toEqual(true); + + expect(isFloatString('0')).toEqual(true); + + expect(isFloatString('0.00001')).toEqual(true); + }); + + it('pass against a negative number in a string', () => { + expect(isFloatString('-12')).toEqual(true); + + expect(isFloatString('-12.3123')).toEqual(true); + + expect(isFloatString('-0.123')).toEqual(true); + }); + + it('fail against a non number string', () => { + expect(isFloatString('Hello world')).toEqual(false); + }); +}); + +describe('validateTokenSymbols', () => { + it('valid when req.tokenSymbols is an array of strings', () => { + expect( + validateTokenSymbols({ + tokenSymbols, + }) + ).toEqual([]); + }); + + it('return error when req.tokenSymbols does not exist', () => { + expect( + validateTokenSymbols({ + hello: 'world', + }) + ).toEqual([missingParameter('tokenSymbols')]); + }); + + it('return error when req.tokenSymbols is invalid', () => { + expect( + validateTokenSymbols({ + tokenSymbols: tokenSymbols[0], + }) + ).toEqual([invalidTokenSymbolsError]); + }); +}); + +describe('isBase58', () => { + it('pass against a well formed Base58', () => { + expect(isBase58('HAE1oNnc3XBmPudphRcHhyCvGShtgDYtZVzx2MocKEr1')).toEqual( + true + ); + }); + + it('fail against a string that has non-Base58 characters', () => { + expect(isBase58('HAE1oNnc3XBmPudphRcHhyCvGShtgDYtZVzx2MocKErI')).toEqual( + false + ); + }); +}); + +describe('validateToken', () => { + it('valid when req.token is a string', () => { + expect( + validateToken({ + token: 'DAI', + }) + ).toEqual([]); + + expect( + validateToken({ + token: 'WETH', + }) + ).toEqual([]); + }); + + it('return error when req.token does not exist', () => { + expect( + validateToken({ + hello: 'world', + }) + ).toEqual([missingParameter('token')]); + }); + + it('return error when req.token is invalid', () => { + expect( + validateToken({ + token: 123, + }) + ).toEqual([invalidTokenError]); + }); +}); + +describe('validateAmount', () => { + it('valid when req.amount is a string of an integer', () => { + expect( + validateAmount({ + amount: '0', + }) + ).toEqual([]); + expect( + validateAmount({ + amount: '9999999999999999999999', + }) + ).toEqual([]); + }); + + it('valid when req.amount does not exist', () => { + expect( + validateAmount({ + hello: 'world', + }) + ).toEqual([]); + }); + + it('return error when req.amount is invalid', () => { + expect( + validateAmount({ + amount: 'WETH', + }) + ).toEqual([invalidAmountError]); + }); +}); + +describe('validateTxHash', () => { + it('valid when req.txHash is a string', () => { + expect(validateTxHash({ txHash })).toEqual([]); + }); + + it('invalid when req.txHash does not exist', () => { + expect( + validateTxHash({ + hello: 'world', + }) + ).toEqual([missingParameter('txHash')]); + }); + + it('return error when req.txHash is invalid', () => { + expect( + validateTxHash({ + txHash: 123, + }) + ).toEqual([invalidTxHashError]); + }); +}); diff --git a/test/services/wallet/wallet.controllers.test.ts b/test/services/wallet/wallet.controllers.test.ts new file mode 100644 index 0000000000..63faf11fb4 --- /dev/null +++ b/test/services/wallet/wallet.controllers.test.ts @@ -0,0 +1,385 @@ +import { patch, unpatch } from '../patch'; +import { Ethereum } from '../../../src/chains/ethereum/ethereum'; +import { Avalanche } from '../../../src/chains/avalanche/avalanche'; +import { Harmony } from '../../../src/chains/harmony/harmony'; + +import { + addWallet, + getWallets, + removeWallet, +} from '../../../src/services/wallet/wallet.controllers'; +import { + ACCOUNT_NOT_SPECIFIED_CODE, + ACCOUNT_NOT_SPECIFIED_ERROR_MESSAGE, + HttpException, + UNKNOWN_CHAIN_ERROR_CODE, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE, +} from '../../../src/services/error-handler'; + +import { ConfigManagerCertPassphrase } from '../../../src/services/config-manager-cert-passphrase'; +import { BinanceSmartChain } from '../../../src/chains/binance-smart-chain/binance-smart-chain'; +import { Cronos } from '../../../src/chains/cronos/cronos'; +import { Near } from '../../../src/chains/near/near'; +import { Cosmos } from '../../../src/chains/cosmos/cosmos'; + +let avalanche: Avalanche; +let cronos: Cronos; +let eth: Ethereum; +let harmony: Harmony; +let bsc: BinanceSmartChain; +let near: Near; +let cosmos: Cosmos; + +beforeAll(async () => { + patch(ConfigManagerCertPassphrase, 'readPassphrase', () => 'a'); + + avalanche = Avalanche.getInstance('fuji'); + eth = Ethereum.getInstance('kovan'); + harmony = Harmony.getInstance('testnet'); + bsc = BinanceSmartChain.getInstance('testnet'); + cronos = Cronos.getInstance('testnet'); + near = Near.getInstance('testnet'); + cosmos = Cosmos.getInstance('testnet'); +}); + +beforeEach(() => + patch(ConfigManagerCertPassphrase, 'readPassphrase', () => 'a') +); + +afterAll(async () => { + await avalanche.close(); + await eth.close(); + await harmony.close(); + await bsc.close(); + await cronos.close(); + await near.close(); + await cosmos.close(); +}); + +afterEach(() => unpatch()); + +const oneAddress = '0x7E5F4552091A69125d5DfCb7b8C2659029395Bdf'; + +const onePrivateKey = + '0000000000000000000000000000000000000000000000000000000000000001'; // noqa: mock + +// encoding of onePrivateKey with the password 'a' +const encodedPrivateKey = { + address: '7e5f4552091a69125d5dfcb7b8c2659029395bdf', + id: '7bb58a6c-06d3-4ede-af06-5f4a5cb87f0b', + version: 3, + Crypto: { + cipher: 'aes-128-ctr', + cipherparams: { iv: '60276d7bf5fa57ce0ae8e65fc578c3ac' }, + ciphertext: + 'be98ee3d44744e1417531b15a7b1e47b945cfc100d3ff2680f757a824840fb67', // noqa: mock + kdf: 'scrypt', + kdfparams: { + salt: '90b7e0017b4f9df67aa5f2de73495c14de086b8abb5b68ce3329596eb14f991c', // noqa: mock + n: 131072, + dklen: 32, + p: 1, + r: 8, + }, + mac: '0cea1492f67ed43234b69100d873e17b4a289dd508cf5e866a3b18599ff0a5fc', // noqa: mock + }, +}; + +const cosmosAddress = 'cosmos18nadm9qd4pz8pgffhvehc0dthuhpgevp4l3nar'; +const cosmosPrivateKey = + '218507defde7d91a9eba858437115b8aea68e3cbc7a4b68b3edac53d5ec89516'; // noqa: mock +const encodedCosmosPrivateKey = { + keyAlgorithm: { + name: 'PBKDF2', + salt: 'PkkhCEpSae+dYup0Q2ZKpA==', + iterations: 500000, + hash: 'SHA-256', + }, + cipherAlgorithm: { name: 'AES-GCM', iv: '1mBtuYgYHJ/xkkA7xdU1QQ==' }, + ciphertext: + 'F7M1ic/dSNHbD1MrU3gQlv9RCiHaSeyk1Rb63NkKSuOuIE1WeCvVLGha5LujsAJAkQ++Mts+h2Ub2OGCdoFkHRO1BMYF0djNDFmwJlKzd68=', +}; + +describe('addWallet and getWallets', () => { + it('add an Ethereum wallet', async () => { + patch(eth, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(eth, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'ethereum', + network: 'kovan', + }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'ethereum') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(oneAddress); + }); + + it('add an Avalanche wallet', async () => { + patch(avalanche, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(avalanche, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'avalanche', + network: 'fuji', + }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'avalanche') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(oneAddress); + }); + + it('add an Harmony wallet', async () => { + patch(harmony, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(harmony, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'harmony', + network: 'testnet', + }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'harmony') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(oneAddress); + }); + + it('add a Binance Smart Chain wallet', async () => { + patch(bsc, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(bsc, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'binance-smart-chain', + network: 'testnet', + }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'binance-smart-chain') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(oneAddress); + }); + + it('add a Cronos wallet', async () => { + patch(cronos, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(cronos, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'cronos', + network: 'testnet', + }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'cronos') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(oneAddress); + }); + + it('add a Cosmos wallet', async () => { + patch(cosmos, 'getWallet', () => { + return { + address: cosmosAddress, + prefix: 'cosmos', + }; + }); + + patch(cosmos, 'encrypt', () => { + return JSON.stringify(encodedCosmosPrivateKey); + }); + + await addWallet({ + privateKey: cosmosPrivateKey, + chain: 'cosmos', + network: 'testnet', + }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'cosmos') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(cosmosAddress); + }); + + it('fail to add a wallet to unknown chain', async () => { + await expect( + addWallet({ + privateKey: onePrivateKey, + chain: 'shibainu', + network: 'doge', + }) + ).rejects.toThrow( + new HttpException( + 500, + UNKNOWN_KNOWN_CHAIN_ERROR_MESSAGE('shibainu'), + UNKNOWN_CHAIN_ERROR_CODE + ) + ); + }); + + it('fail to add a wallet if account is not specified when adding near wallet', async () => { + await expect( + addWallet({ + privateKey: onePrivateKey, + chain: 'near', + network: 'testnet', + }) + ).rejects.toThrow( + new HttpException( + 500, + ACCOUNT_NOT_SPECIFIED_ERROR_MESSAGE(), + ACCOUNT_NOT_SPECIFIED_CODE + ) + ); + }); +}); + +describe('addWallet and removeWallets', () => { + it('remove an Ethereum wallet', async () => { + patch(eth, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(eth, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + patch(eth, 'getWalletFromPrivateKey', () => { + return { + address: oneAddress, + }; + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'ethereum', + network: 'kovan', + }); + + await removeWallet({ chain: 'ethereum', address: oneAddress }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'ethereum') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).not.toContain(oneAddress); + }); + + it('remove an Harmony wallet', async () => { + patch(harmony, 'getWallet', () => { + return { + address: oneAddress, + }; + }); + + patch(harmony, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await addWallet({ + privateKey: onePrivateKey, + chain: 'harmony', + network: 'testnet', + }); + + await removeWallet({ chain: 'harmony', address: oneAddress }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'harmony') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).not.toContain(oneAddress); + }); + + it('remove a Cosmos wallet', async () => { + patch(cosmos, 'getWallet', () => { + return { + address: cosmosAddress, + prefix: 'cosmos', + }; + }); + + patch(cosmos, 'encrypt', () => { + return JSON.stringify(encodedCosmosPrivateKey); + }); + + await addWallet({ + privateKey: cosmosPrivateKey, + chain: 'cosmos', + network: 'testnet', + }); + + await removeWallet({ chain: 'cosmos', address: cosmosAddress }); + + const wallets = await getWallets(); + + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'cosmos') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).not.toContain(cosmosAddress); + }); +}); diff --git a/test/services/wallet/wallet.routes.test.ts b/test/services/wallet/wallet.routes.test.ts new file mode 100644 index 0000000000..e7256881d3 --- /dev/null +++ b/test/services/wallet/wallet.routes.test.ts @@ -0,0 +1,308 @@ +import request from 'supertest'; +import { gatewayApp } from '../../../src/app'; +import { patch, unpatch } from '../patch'; +import { Ethereum } from '../../../src/chains/ethereum/ethereum'; +import { Avalanche } from '../../../src/chains/avalanche/avalanche'; +import { Harmony } from '../../../src/chains/harmony/harmony'; +import { ConfigManagerCertPassphrase } from '../../../src/services/config-manager-cert-passphrase'; +import { GetWalletResponse } from '../../../src/services/wallet/wallet.requests'; +let avalanche: Avalanche; +let eth: Ethereum; +let harmony: Harmony; + +beforeAll(async () => { + patch(ConfigManagerCertPassphrase, 'readPassphrase', () => 'a'); + + avalanche = Avalanche.getInstance('fuji'); + eth = Ethereum.getInstance('kovan'); + harmony = Harmony.getInstance('testnet'); +}); + +beforeEach(() => + patch(ConfigManagerCertPassphrase, 'readPassphrase', () => 'a') +); + +afterAll(async () => { + await avalanche.close(); + await eth.close(); + await harmony.close(); +}); + +afterEach(() => unpatch()); + +const twoAddress = '0x2b5ad5c4795c026514f8317c7a215e218dccd6cf'; + +const twoPrivateKey = + '0000000000000000000000000000000000000000000000000000000000000002'; // noqa: mock + +// encoding of twoPrivateKey with the password 'a' +const encodedPrivateKey = { + address: '2b5ad5c4795c026514f8317c7a215e218dccd6cf', + id: '116e3405-ea6c-40ba-93c0-6a835ad2ea99', + version: 3, + Crypto: { + cipher: 'aes-128-ctr', + cipherparams: { iv: 'dccf7a5f7d66bc6a61cf4fda422dcd55' }, + ciphertext: + 'ce561ad92c6a507a9399f51d64951b763f01b4956f15fd298ceb7a1174d0394a', // noqa: mock + kdf: 'scrypt', + kdfparams: { + salt: 'a88d99c6d01150af02861ebb1ace3b633a33b2a20561fe188a0c260a84d1ba99', // noqa: mock + n: 131072, + dklen: 32, + p: 1, + r: 8, + }, + mac: '684b0111ed08611ad993c76b4524d5dcda18b26cb930251983c36f40160eba8f', // noqa: mock + }, +}; + +describe('POST /wallet/add', () => { + it('return 200 for well formed ethereum request', async () => { + patch(eth, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(eth, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'ethereum', + network: 'kovan', + }) + .expect('Content-Type', /json/) + .expect(200); + }); + + it('return 200 for well formed avalanche request', async () => { + patch(avalanche, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(avalanche, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'avalanche', + network: 'fuji', + }) + + .expect('Content-Type', /json/) + .expect(200); + }); + + it('return 200 for well formed harmony request', async () => { + patch(harmony, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(harmony, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'harmony', + network: 'testnet', + }) + + .expect('Content-Type', /json/) + .expect(200); + }); + + it('return 404 for ill-formed avalanche request', async () => { + patch(avalanche, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(avalanche, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({}) + .expect('Content-Type', /json/) + .expect(404); + }); + + it('return 404 for ill-formed harmony request', async () => { + patch(harmony, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(harmony, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({}) + .expect('Content-Type', /json/) + .expect(404); + }); +}); + +describe('DELETE /wallet/remove', () => { + it('return 200 for well formed ethereum request', async () => { + patch(eth, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(eth, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'ethereum', + network: 'kovan', + }) + + .expect('Content-Type', /json/) + .expect(200); + + await request(gatewayApp) + .delete(`/wallet/remove`) + .send({ + address: twoAddress, + chain: 'ethereum', + }) + + .expect('Content-Type', /json/) + .expect(200); + }); + + it('return 200 for well formed harmony request', async () => { + patch(harmony, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(harmony, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'harmony', + network: 'testnet', + }) + + .expect('Content-Type', /json/) + .expect(200); + + await request(gatewayApp) + .delete(`/wallet/remove`) + .send({ + address: twoAddress, + chain: 'harmony', + }) + + .expect('Content-Type', /json/) + .expect(200); + }); + + it('return 404 for ill-formed request', async () => { + await request(gatewayApp).delete(`/wallet/delete`).send({}).expect(404); + }); +}); + +describe('GET /wallet', () => { + it('return 200 for well formed ethereum request', async () => { + patch(eth, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(eth, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'ethereum', + network: 'kovan', + }) + .expect('Content-Type', /json/) + .expect(200); + + await request(gatewayApp) + .get(`/wallet`) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => { + const wallets: GetWalletResponse[] = res.body; + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'ethereum') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(twoAddress); + }); + }); + + it('return 200 for well formed harmony request', async () => { + patch(harmony, 'getWalletFromPrivateKey', () => { + return { + address: twoAddress, + }; + }); + + patch(harmony, 'encrypt', () => { + return JSON.stringify(encodedPrivateKey); + }); + + await request(gatewayApp) + .post(`/wallet/add`) + .send({ + privateKey: twoPrivateKey, + chain: 'harmony', + network: 'testnet', + }) + .expect('Content-Type', /json/) + .expect(200); + + await request(gatewayApp) + .get(`/wallet`) + .expect('Content-Type', /json/) + .expect(200) + .expect((res) => { + const wallets: GetWalletResponse[] = res.body; + const addresses: string[][] = wallets + .filter((wallet) => wallet.chain === 'harmony') + .map((wallet) => wallet.walletAddresses); + + expect(addresses[0]).toContain(twoAddress); + }); + }); +}); diff --git a/test/services/wallet/wallet.validators.test.ts b/test/services/wallet/wallet.validators.test.ts new file mode 100644 index 0000000000..f9ef4169d6 --- /dev/null +++ b/test/services/wallet/wallet.validators.test.ts @@ -0,0 +1,299 @@ +import { + invalidEthPrivateKeyError, + isEthPrivateKey, + validatePrivateKey, + invalidChainError, + invalidAddressError, + validateChain, + validateAddress, + isNearPrivateKey, + isCosmosPrivateKey, + invalidCosmosPrivateKeyError, +} from '../../../src/services/wallet/wallet.validators'; + +import { missingParameter } from '../../../src/services/validators'; + +import 'jest-extended'; + +describe('isEthPrivateKey', () => { + it('pass against a well formed private key', () => { + expect( + isEthPrivateKey( + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4' // noqa: mock + ) + ).toEqual(true); + }); + + it('fail against a string that is too short', () => { + expect(isEthPrivateKey('da857cbda0ba96757fed842617a40693d0')).toEqual( + false + ); + }); + + it('fail against a string that has non-hexadecimal characters', () => { + expect( + isEthPrivateKey( + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747qwer' + ) + ).toEqual(false); + }); +}); + +describe('isCosmosPrivateKey', () => { + it('pass against a well formed private key', () => { + expect( + isCosmosPrivateKey( + '218507defde7d91a9eba858437115b8aea68e3cbc7a4b68b3edac53d5ec89515' // noqa: mock + ) + ).toEqual(true); + }); + + it('fail against a string that is invalid', () => { + expect( + isCosmosPrivateKey( + '218507defde7d91a9eba858437115b8aea68e3cbc7a4b68b3edac53d5ec8951' // noqa: mock + ) + ).toEqual(false); + }); +}); + +describe('isNearPrivateKey', () => { + it('pass against a well formed private key', () => { + expect( + isNearPrivateKey( + 'ed25519:5r1MuqBa3L9gpXHqULS3u2B142c5jA8szrEiL8cprvhjJDe6S2xz9Q4uppgaLegmuPpq4ftBpcMw7NNoJHJefiTt' + ) + ).toEqual(true); + }); + + it('fail against a string that is invalid', () => { + expect(isEthPrivateKey('ed25519')).toEqual(false); + }); +}); + +describe('validatePrivateKey', () => { + it('valid when req.privateKey is an ethereum key', () => { + expect( + validatePrivateKey({ + chain: 'ethereum', + privateKey: + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4', // noqa: mock + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is a near key', () => { + expect( + validatePrivateKey({ + chain: 'near', + privateKey: + 'ed25519:5r1MuqBa3L9gpXHqULS3u2B142c5jA8szrEiL8cprvhjJDe6S2xz9Q4uppgaLegmuPpq4ftBpcMw7NNoJHJefiTt', + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is a harmony key', () => { + expect( + validatePrivateKey({ + chain: 'harmony', + privateKey: + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4', // noqa: mock + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is a cronos key', () => { + expect( + validatePrivateKey({ + chain: 'cronos', + privateKey: + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4', // noqa: mock + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is a polygon key', () => { + expect( + validatePrivateKey({ + chain: 'polygon', + privateKey: + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4', // noqa: mock + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is a avalanche key', () => { + expect( + validatePrivateKey({ + chain: 'avalanche', + privateKey: + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4', // noqa: mock + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is an binance-smart-chain key', () => { + expect( + validatePrivateKey({ + chain: 'binance-smart-chain', + privateKey: + 'da857cbda0ba96757fed842617a40693d06d00001e55aa972955039ae747bac4', // noqa: mock + }) + ).toEqual([]); + }); + + it('valid when req.privateKey is a cosmos key', () => { + expect( + validatePrivateKey({ + chain: 'cosmos', + privateKey: + '218507defde7d91a9eba858437115b8aea68e3cbc7a4b68b3edac53d5ec89516', // noqa: mock + }) + ).toEqual([]); + }); + + it('return error when req.privateKey does not exist', () => { + expect( + validatePrivateKey({ + chain: 'ethereum', + hello: 'world', + }) + ).toEqual([missingParameter('privateKey')]); + }); + + it('return error when req.chain does not exist', () => { + expect( + validatePrivateKey({ + privateKey: + '5r1MuqBa3L9gpXHqULS3u2B142c5jA8szrEiL8cprvhjJDe6S2xz9Q4uppgaLegmuPpq4ftBpcMw7NNoJHJefiTt', + }) + ).toEqual([missingParameter('chain')]); + }); + + it('return error when req.privateKey is invalid ethereum key', () => { + expect( + validatePrivateKey({ + chain: 'ethereum', + privateKey: 'world', + }) + ).toEqual([invalidEthPrivateKeyError]); + }); + + it('return error when req.privateKey is invalid binance-smart-chain key', () => { + expect( + validatePrivateKey({ + chain: 'binance-smart-chain', + privateKey: 'someErroneousPrivateKey', + }) + ).toEqual([invalidEthPrivateKeyError]); + }); + + it('return error when req.privateKey is invalid cosmos key', () => { + expect( + validatePrivateKey({ + chain: 'cosmos', + privateKey: 'someErroneousPrivateKey', + }) + ).toEqual([invalidCosmosPrivateKeyError]); + }); +}); + +describe('validateChain', () => { + it('valid when chain is ethereum', () => { + expect( + validateChain({ + chain: 'ethereum', + }) + ).toEqual([]); + }); + + it('valid when chain is avalanche', () => { + expect( + validateChain({ + chain: 'avalanche', + }) + ).toEqual([]); + }); + + it('valid when chain is harmony', () => { + expect( + validateChain({ + chain: 'harmony', + }) + ).toEqual([]); + }); + + it('valid when chain is binance-smart-chain', () => { + expect( + validateChain({ + chain: 'binance-smart-chain', + }) + ).toEqual([]); + }); + + it('valid when chain is cronos', () => { + expect( + validateChain({ + chain: 'cronos', + }) + ).toEqual([]); + }); + + it('valid when chain is binance-smart-chain', () => { + expect( + validateChain({ + chain: 'binance-smart-chain', + }) + ).toEqual([]); + }); + + it('valid when chain is cosmos', () => { + expect( + validateChain({ + chain: 'cosmos', + }) + ).toEqual([]); + }); + + it('return error when req.chain does not exist', () => { + expect( + validateChain({ + hello: 'world', + }) + ).toEqual([missingParameter('chain')]); + }); + + it('return error when req.chain is invalid', () => { + expect( + validateChain({ + chain: 'shibainu', + }) + ).toEqual([invalidChainError]); + }); +}); + +describe('validateAddress', () => { + it('valid when address is a string', () => { + expect( + validateAddress({ + address: '0x000000000000000000000000000000000000000', + }) + ).toEqual([]); + }); + + it('return error when req.address does not exist', () => { + expect( + validateAddress({ + hello: 'world', + }) + ).toEqual([missingParameter('address')]); + }); + + it('return error when req.address is not a string', () => { + expect( + validateAddress({ + address: 1, + }) + ).toEqual([invalidAddressError]); + }); +}); diff --git a/test/setup.ts b/test/setup.ts new file mode 100644 index 0000000000..1404f2cffd --- /dev/null +++ b/test/setup.ts @@ -0,0 +1,7 @@ +import { DBPathOverride } from './config.util'; + +module.exports = (_globalConfig: any, _projectConfig: any) => { + // override db paths + DBPathOverride.init(); + DBPathOverride.updateConfigs(); +}; diff --git a/test/setupTests.js b/test/setupTests.js new file mode 100644 index 0000000000..c3752dce0d --- /dev/null +++ b/test/setupTests.js @@ -0,0 +1,2 @@ +/* eslint-disable no-undef */ +jest.setTimeout(10000); diff --git a/test/teardown.ts b/test/teardown.ts new file mode 100644 index 0000000000..e789d4b55d --- /dev/null +++ b/test/teardown.ts @@ -0,0 +1,6 @@ +import { DBPathOverride } from './config.util'; + +export default (_globalConfig: any, _projectConfig: any) => { + // revert change to db paths + DBPathOverride.resetConfigs(); +}; diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000000..90aed87e2a --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,36 @@ +{ + "compilerOptions": { + "strict": true, + "types": ["@types/jest", "jest", "node"], + "target": "es6", + "module": "commonjs", + "allowJs": true, + "lib": ["es6", "es2020", "esnext.asynciterable", "dom"], + "sourceMap": true, + "outDir": "./dist", + "moduleResolution": "node", + "removeComments": true, + "noImplicitAny": true, + "strictNullChecks": true, + "strictFunctionTypes": true, + "noImplicitThis": true, + "noUnusedLocals": true, + "noUnusedParameters": true, + "noImplicitReturns": true, + "noFallthroughCasesInSwitch": true, + "allowSyntheticDefaultImports": true, + "esModuleInterop": true, + "emitDecoratorMetadata": true, + "experimentalDecorators": true, + "resolveJsonModule": true, + "typeRoots": ["node_modules/@types", "src/@types"], + "downlevelIteration": true + }, + "exclude": ["node_modules"], + "include": [ + "src/**/*.ts", + "src/**/*.js", + "test/**/*.ts", + "integration-test/**/*.ts" + ] +} diff --git a/yarn.lock b/yarn.lock new file mode 100644 index 0000000000..ff990075e1 --- /dev/null +++ b/yarn.lock @@ -0,0 +1,15149 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@ampproject/remapping@^2.1.0": + version "2.2.0" + resolved "https://registry.yarnpkg.com/@ampproject/remapping/-/remapping-2.2.0.tgz#56c133824780de3174aed5ab6834f3026790154d" + integrity sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w== + dependencies: + "@jridgewell/gen-mapping" "^0.1.0" + "@jridgewell/trace-mapping" "^0.3.9" + +"@apollo/protobufjs@1.2.6": + version "1.2.6" + resolved "https://registry.yarnpkg.com/@apollo/protobufjs/-/protobufjs-1.2.6.tgz#d601e65211e06ae1432bf5993a1a0105f2862f27" + integrity sha512-Wqo1oSHNUj/jxmsVp4iR3I480p6qdqHikn38lKrFhfzcDJ7lwd7Ck7cHRl4JE81tWNArl77xhnG/OkZhxKBYOw== + dependencies: + "@protobufjs/aspromise" "^1.1.2" + "@protobufjs/base64" "^1.1.2" + "@protobufjs/codegen" "^2.0.4" + "@protobufjs/eventemitter" "^1.1.0" + "@protobufjs/fetch" "^1.1.0" + "@protobufjs/float" "^1.0.2" + "@protobufjs/inquire" "^1.1.0" + "@protobufjs/path" "^1.1.2" + "@protobufjs/pool" "^1.1.0" + "@protobufjs/utf8" "^1.1.0" + "@types/long" "^4.0.0" + "@types/node" "^10.1.0" + long "^4.0.0" + +"@apollo/utils.dropunuseddefinitions@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@apollo/utils.dropunuseddefinitions/-/utils.dropunuseddefinitions-1.1.0.tgz#02b04006442eaf037f4c4624146b12775d70d929" + integrity sha512-jU1XjMr6ec9pPoL+BFWzEPW7VHHulVdGKMkPAMiCigpVIT11VmCbnij0bWob8uS3ODJ65tZLYKAh/55vLw2rbg== + +"@apollo/utils.keyvaluecache@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@apollo/utils.keyvaluecache/-/utils.keyvaluecache-1.0.1.tgz#46f310f859067efe9fa126156c6954f8381080d2" + integrity sha512-nLgYLomqjVimEzQ4cdvVQkcryi970NDvcRVPfd0OPeXhBfda38WjBq+WhQFk+czSHrmrSp34YHBxpat0EtiowA== + dependencies: + "@apollo/utils.logger" "^1.0.0" + lru-cache "^7.10.1" + +"@apollo/utils.logger@^1.0.0": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@apollo/utils.logger/-/utils.logger-1.0.1.tgz#aea0d1bb7ceb237f506c6bbf38f10a555b99a695" + integrity sha512-XdlzoY7fYNK4OIcvMD2G94RoFZbzTQaNP0jozmqqMudmaGo2I/2Jx71xlDJ801mWA/mbYRihyaw6KJii7k5RVA== + +"@apollo/utils.printwithreducedwhitespace@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@apollo/utils.printwithreducedwhitespace/-/utils.printwithreducedwhitespace-1.1.0.tgz#c466299a4766eef8577a2a64c8f27712e8bd7e30" + integrity sha512-GfFSkAv3n1toDZ4V6u2d7L4xMwLA+lv+6hqXicMN9KELSJ9yy9RzuEXaX73c/Ry+GzRsBy/fdSUGayGqdHfT2Q== + +"@apollo/utils.removealiases@1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@apollo/utils.removealiases/-/utils.removealiases-1.0.0.tgz#75f6d83098af1fcae2d3beb4f515ad4a8452a8c1" + integrity sha512-6cM8sEOJW2LaGjL/0vHV0GtRaSekrPQR4DiywaApQlL9EdROASZU5PsQibe2MWeZCOhNrPRuHh4wDMwPsWTn8A== + +"@apollo/utils.sortast@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@apollo/utils.sortast/-/utils.sortast-1.1.0.tgz#93218c7008daf3e2a0725196085a33f5aab5ad07" + integrity sha512-VPlTsmUnOwzPK5yGZENN069y6uUHgeiSlpEhRnLFYwYNoJHsuJq2vXVwIaSmts015WTPa2fpz1inkLYByeuRQA== + dependencies: + lodash.sortby "^4.7.0" + +"@apollo/utils.stripsensitiveliterals@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@apollo/utils.stripsensitiveliterals/-/utils.stripsensitiveliterals-1.2.0.tgz#4920651f36beee8e260e12031a0c5863ad0c7b28" + integrity sha512-E41rDUzkz/cdikM5147d8nfCFVKovXxKBcjvLEQ7bjZm/cg9zEcXvS6vFY8ugTubI3fn6zoqo0CyU8zT+BGP9w== + +"@apollo/utils.usagereporting@^1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@apollo/utils.usagereporting/-/utils.usagereporting-1.0.0.tgz#b81df180f4ca78b91a22cb49105174a7f070db1e" + integrity sha512-5PL7hJMkTPmdo3oxPtigRrIyPxDk/ddrUryHPDaezL1lSFExpNzsDd2f1j0XJoHOg350GRd3LyD64caLA2PU1w== + dependencies: + "@apollo/utils.dropunuseddefinitions" "^1.1.0" + "@apollo/utils.printwithreducedwhitespace" "^1.1.0" + "@apollo/utils.removealiases" "1.0.0" + "@apollo/utils.sortast" "^1.1.0" + "@apollo/utils.stripsensitiveliterals" "^1.2.0" + apollo-reporting-protobuf "^3.3.1" + +"@apollographql/apollo-tools@^0.5.3": + version "0.5.4" + resolved "https://registry.yarnpkg.com/@apollographql/apollo-tools/-/apollo-tools-0.5.4.tgz#cb3998c6cf12e494b90c733f44dd9935e2d8196c" + integrity sha512-shM3q7rUbNyXVVRkQJQseXv6bnYM3BUma/eZhwXR4xsuM+bqWnJKvW7SAfRjP7LuSCocrexa5AXhjjawNHrIlw== + +"@apollographql/graphql-playground-html@1.6.29": + version "1.6.29" + resolved "https://registry.yarnpkg.com/@apollographql/graphql-playground-html/-/graphql-playground-html-1.6.29.tgz#a7a646614a255f62e10dcf64a7f68ead41dec453" + integrity sha512-xCcXpoz52rI4ksJSdOCxeOCn2DLocxwHf9dVT/Q90Pte1LX+LY+91SFtJF3KXVHH8kEin+g1KKCQPKBjZJfWNA== + dependencies: + xss "^1.0.8" + +"@babel/code-frame@7.12.11": + version "7.12.11" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.11.tgz#f4ad435aa263db935b8f10f2c552d23fb716a63f" + integrity sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw== + dependencies: + "@babel/highlight" "^7.10.4" + +"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.18.6.tgz#3b25d38c89600baa2dcc219edfa88a74eb2c427a" + integrity sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q== + dependencies: + "@babel/highlight" "^7.18.6" + +"@babel/compat-data@^7.18.8": + version "7.18.8" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.18.8.tgz#2483f565faca607b8535590e84e7de323f27764d" + integrity sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ== + +"@babel/core@^7.1.0", "@babel/core@^7.12.3", "@babel/core@^7.7.2", "@babel/core@^7.8.0": + version "7.18.10" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.18.10.tgz#39ad504991d77f1f3da91be0b8b949a5bc466fb8" + integrity sha512-JQM6k6ENcBFKVtWvLavlvi/mPcpYZ3+R+2EySDEMSMbp7Mn4FexlbbJVrx2R7Ijhr01T8gyqrOaABWIOgxeUyw== + dependencies: + "@ampproject/remapping" "^2.1.0" + "@babel/code-frame" "^7.18.6" + "@babel/generator" "^7.18.10" + "@babel/helper-compilation-targets" "^7.18.9" + "@babel/helper-module-transforms" "^7.18.9" + "@babel/helpers" "^7.18.9" + "@babel/parser" "^7.18.10" + "@babel/template" "^7.18.10" + "@babel/traverse" "^7.18.10" + "@babel/types" "^7.18.10" + convert-source-map "^1.7.0" + debug "^4.1.0" + gensync "^1.0.0-beta.2" + json5 "^2.2.1" + semver "^6.3.0" + +"@babel/generator@^7.18.10", "@babel/generator@^7.7.2": + version "7.18.12" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.18.12.tgz#fa58daa303757bd6f5e4bbca91b342040463d9f4" + integrity sha512-dfQ8ebCN98SvyL7IxNMCUtZQSq5R7kxgN+r8qYTGDmmSion1hX2C0zq2yo1bsCDhXixokv1SAWTZUMYbO/V5zg== + dependencies: + "@babel/types" "^7.18.10" + "@jridgewell/gen-mapping" "^0.3.2" + jsesc "^2.5.1" + +"@babel/helper-compilation-targets@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.9.tgz#69e64f57b524cde3e5ff6cc5a9f4a387ee5563bf" + integrity sha512-tzLCyVmqUiFlcFoAPLA/gL9TeYrF61VLNtb+hvkuVaB5SUjW7jcfrglBIX1vUIoT7CLP3bBlIMeyEsIl2eFQNg== + dependencies: + "@babel/compat-data" "^7.18.8" + "@babel/helper-validator-option" "^7.18.6" + browserslist "^4.20.2" + semver "^6.3.0" + +"@babel/helper-environment-visitor@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz#0c0cee9b35d2ca190478756865bb3528422f51be" + integrity sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg== + +"@babel/helper-function-name@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.18.9.tgz#940e6084a55dee867d33b4e487da2676365e86b0" + integrity sha512-fJgWlZt7nxGksJS9a0XdSaI4XvpExnNIgRP+rVefWh5U7BL8pPuir6SJUmFKRfjWQ51OtWSzwOxhaH/EBWWc0A== + dependencies: + "@babel/template" "^7.18.6" + "@babel/types" "^7.18.9" + +"@babel/helper-hoist-variables@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz#d4d2c8fb4baeaa5c68b99cc8245c56554f926678" + integrity sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-module-imports@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz#1e3ebdbbd08aad1437b428c50204db13c5a3ca6e" + integrity sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-module-transforms@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.18.9.tgz#5a1079c005135ed627442df31a42887e80fcb712" + integrity sha512-KYNqY0ICwfv19b31XzvmI/mfcylOzbLtowkw+mfvGPAQ3kfCnMLYbED3YecL5tPd8nAYFQFAd6JHp2LxZk/J1g== + dependencies: + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-module-imports" "^7.18.6" + "@babel/helper-simple-access" "^7.18.6" + "@babel/helper-split-export-declaration" "^7.18.6" + "@babel/helper-validator-identifier" "^7.18.6" + "@babel/template" "^7.18.6" + "@babel/traverse" "^7.18.9" + "@babel/types" "^7.18.9" + +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.8.0": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.9.tgz#4b8aea3b069d8cb8a72cdfe28ddf5ceca695ef2f" + integrity sha512-aBXPT3bmtLryXaoJLyYPXPlSD4p1ld9aYeR+sJNOZjJJGiOpb+fKfh3NkcCu7J54nUJwCERPBExCCpyCOHnu/w== + +"@babel/helper-simple-access@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz#d6d8f51f4ac2978068df934b569f08f29788c7ea" + integrity sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-split-export-declaration@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz#7367949bc75b20c6d5a5d4a97bba2824ae8ef075" + integrity sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-string-parser@^7.18.10": + version "7.18.10" + resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.18.10.tgz#181f22d28ebe1b3857fa575f5c290b1aaf659b56" + integrity sha512-XtIfWmeNY3i4t7t4D2t02q50HvqHybPqW2ki1kosnvWCwuCMeo81Jf0gwr85jy/neUdg5XDdeFE/80DXiO+njw== + +"@babel/helper-validator-identifier@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz#9c97e30d31b2b8c72a1d08984f2ca9b574d7a076" + integrity sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g== + +"@babel/helper-validator-option@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz#bf0d2b5a509b1f336099e4ff36e1a63aa5db4db8" + integrity sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw== + +"@babel/helpers@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.18.9.tgz#4bef3b893f253a1eced04516824ede94dcfe7ff9" + integrity sha512-Jf5a+rbrLoR4eNdUmnFu8cN5eNJT6qdTdOg5IHIzq87WwyRw9PwguLFOWYgktN/60IP4fgDUawJvs7PjQIzELQ== + dependencies: + "@babel/template" "^7.18.6" + "@babel/traverse" "^7.18.9" + "@babel/types" "^7.18.9" + +"@babel/highlight@^7.10.4", "@babel/highlight@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.18.6.tgz#81158601e93e2563795adcbfbdf5d64be3f2ecdf" + integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g== + dependencies: + "@babel/helper-validator-identifier" "^7.18.6" + chalk "^2.0.0" + js-tokens "^4.0.0" + +"@babel/parser@^7.1.0", "@babel/parser@^7.14.7", "@babel/parser@^7.18.10", "@babel/parser@^7.18.11": + version "7.18.11" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.18.11.tgz#68bb07ab3d380affa9a3f96728df07969645d2d9" + integrity sha512-9JKn5vN+hDt0Hdqn1PiJ2guflwP+B6Ga8qbDuoF0PzzVhrzsKIJo8yGqVk6CmMHiMei9w1C1Bp9IMJSIK+HPIQ== + +"@babel/plugin-syntax-async-generators@^7.8.4": + version "7.8.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz#a983fb1aeb2ec3f6ed042a210f640e90e786fe0d" + integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-bigint@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz#4c9a6f669f5d0cdf1b90a1671e9a146be5300cea" + integrity sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-class-properties@^7.8.3": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz#b5c987274c4a3a82b89714796931a6b53544ae10" + integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-import-meta@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz#ee601348c370fa334d2207be158777496521fd51" + integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-json-strings@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz#01ca21b668cd8218c9e640cb6dd88c5412b2c96a" + integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-logical-assignment-operators@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz#ca91ef46303530448b906652bac2e9fe9941f699" + integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz#167ed70368886081f74b5c36c65a88c03b66d1a9" + integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-numeric-separator@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz#b9b070b3e33570cd9fd07ba7fa91c0dd37b9af97" + integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-object-rest-spread@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz#60e225edcbd98a640332a2e72dd3e66f1af55871" + integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-catch-binding@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz#6111a265bcfb020eb9efd0fdfd7d26402b9ed6c1" + integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-chaining@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz#4f69c2ab95167e0180cd5336613f8c5788f7d48a" + integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-top-level-await@^7.8.3": + version "7.14.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz#c1cfdadc35a646240001f06138247b741c34d94c" + integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw== + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-typescript@^7.7.2": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.18.6.tgz#1c09cd25795c7c2b8a4ba9ae49394576d4133285" + integrity sha512-mAWAuq4rvOepWCBid55JuRNvpTNf2UGVgoz4JV0fXEKolsVZDzsa4NqCef758WZJj/GDu0gVGItjKFiClTAmZA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/runtime@^7.10.5", "@babel/runtime@^7.12.5", "@babel/runtime@^7.17.2", "@babel/runtime@^7.18.6", "@babel/runtime@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.18.9.tgz#b4fcfce55db3d2e5e080d2490f608a3b9f407f4a" + integrity sha512-lkqXDcvlFT5rvEjiu6+QYO+1GXrEHRo2LOtS7E4GtX5ESIZOgepqsZBVIj6Pv+a6zqsya9VCgiK1KAK4BvJDAw== + dependencies: + regenerator-runtime "^0.13.4" + +"@babel/runtime@^7.15.4": + version "7.20.1" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.20.1.tgz#1148bb33ab252b165a06698fde7576092a78b4a9" + integrity sha512-mrzLkl6U9YLF8qpqI7TB82PESyEGjm/0Ly91jG575eVxMMlb8fYfOXFZIJ8XfLrJZQbm7dlKry2bJmXBUEkdFg== + dependencies: + regenerator-runtime "^0.13.10" + +"@babel/runtime@^7.18.3": + version "7.20.6" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.20.6.tgz#facf4879bfed9b5326326273a64220f099b0fce3" + integrity sha512-Q+8MqP7TiHMWzSfwiJwXCjyf4GYA4Dgw3emg/7xmwsdLJOZUp+nMqcOwOzzYheuM1rhDu8FSj2l0aoMygEuXuA== + dependencies: + regenerator-runtime "^0.13.11" + +"@babel/runtime@^7.6.3", "@babel/runtime@^7.9.2": + version "7.19.4" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.19.4.tgz#a42f814502ee467d55b38dd1c256f53a7b885c78" + integrity sha512-EXpLCrk55f+cYqmHsSR+yD/0gAIMxxA9QK9lnQWzhMCvt+YmoBN7Zx94s++Kv0+unHk39vxNO8t+CMA2WSS3wA== + dependencies: + regenerator-runtime "^0.13.4" + +"@babel/template@^7.18.10", "@babel/template@^7.18.6", "@babel/template@^7.3.3": + version "7.18.10" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.18.10.tgz#6f9134835970d1dbf0835c0d100c9f38de0c5e71" + integrity sha512-TI+rCtooWHr3QJ27kJxfjutghu44DLnasDMwpDqCXVTal9RLp3RSYNh4NdBrRP2cQAoG9A8juOQl6P6oZG4JxA== + dependencies: + "@babel/code-frame" "^7.18.6" + "@babel/parser" "^7.18.10" + "@babel/types" "^7.18.10" + +"@babel/traverse@^7.18.10", "@babel/traverse@^7.18.9", "@babel/traverse@^7.7.2": + version "7.18.11" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.18.11.tgz#3d51f2afbd83ecf9912bcbb5c4d94e3d2ddaa16f" + integrity sha512-TG9PiM2R/cWCAy6BPJKeHzNbu4lPzOSZpeMfeNErskGpTJx6trEvFaVCbDvpcxwy49BKWmEPwiW8mrysNiDvIQ== + dependencies: + "@babel/code-frame" "^7.18.6" + "@babel/generator" "^7.18.10" + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-function-name" "^7.18.9" + "@babel/helper-hoist-variables" "^7.18.6" + "@babel/helper-split-export-declaration" "^7.18.6" + "@babel/parser" "^7.18.11" + "@babel/types" "^7.18.10" + debug "^4.1.0" + globals "^11.1.0" + +"@babel/types@^7.0.0", "@babel/types@^7.18.10", "@babel/types@^7.18.6", "@babel/types@^7.18.9", "@babel/types@^7.3.0", "@babel/types@^7.3.3": + version "7.18.10" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.18.10.tgz#4908e81b6b339ca7c6b7a555a5fc29446f26dde6" + integrity sha512-MJvnbEiiNkpjo+LknnmRrqbY1GPUUggjv+wQVjetM/AONoupqRALB7I6jGqNUAZsKcRIEu2J6FRFvsczljjsaQ== + dependencies: + "@babel/helper-string-parser" "^7.18.10" + "@babel/helper-validator-identifier" "^7.18.6" + to-fast-properties "^2.0.0" + +"@bcoe/v8-coverage@^0.2.3": + version "0.2.3" + resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39" + integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== + +"@blockworks-foundation/mango-client@^3.2.14": + version "3.6.10" + resolved "https://registry.yarnpkg.com/@blockworks-foundation/mango-client/-/mango-client-3.6.10.tgz#32b099e7bb0e04161f851e93799025135c508ae7" + integrity sha512-ch2LhT0i5ILfAIPHvwlPKuc6DfYaV1/PYHX+L/xxH0867LOTNDYXWS+neznRQcQUVVbCAcbrZCENDekBW+/NzQ== + dependencies: + "@project-serum/anchor" "^0.21.0" + "@project-serum/serum" "^0.13.65" + "@project-serum/sol-wallet-adapter" "^0.2.0" + "@solana/spl-token" "^0.1.6" + "@solana/web3.js" "^1.43.5" + big.js "^6.1.1" + bn.js "^5.1.0" + buffer-layout "^1.2.1" + cross-fetch "^3.1.5" + dotenv "^10.0.0" + toformat "^2.0.0" + yargs "^17.0.1" + +"@colors/colors@1.5.0": + version "1.5.0" + resolved "https://registry.yarnpkg.com/@colors/colors/-/colors-1.5.0.tgz#bb504579c1cae923e6576a4f5da43d25f97bdbd9" + integrity sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ== + +"@confio/ics23@^0.6.8": + version "0.6.8" + resolved "https://registry.yarnpkg.com/@confio/ics23/-/ics23-0.6.8.tgz#2a6b4f1f2b7b20a35d9a0745bb5a446e72930b3d" + integrity sha512-wB6uo+3A50m0sW/EWcU64xpV/8wShZ6bMTa7pF8eYsTrSkQA7oLUIJcs/wb8g4y2Oyq701BaGiO6n/ak5WXO1w== + dependencies: + "@noble/hashes" "^1.0.0" + protobufjs "^6.8.8" + +"@connectis/coverage-merger@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@connectis/coverage-merger/-/coverage-merger-1.1.0.tgz#3aea911a381c04f3d544e95b093b564e420bd3d9" + integrity sha512-H/t4AIXW4/0cFybMqgZouZMZw8lawaaH0n5q8QgLfP26amAJCqyZk/JLlFrdAJtt/VWdklfXWPSOoXja6/UTsw== + dependencies: + lodash "^4.17.11" + +"@connectis/coverage-parser@^1.0.7": + version "1.0.8" + resolved "https://registry.yarnpkg.com/@connectis/coverage-parser/-/coverage-parser-1.0.8.tgz#87a8ed74dac8539b5f33c5dae32fd0f6ec3395a4" + integrity sha512-uQmq4flTwRMRP6GZQDpsy48L0NeBNWGcjLgOqmI0wLwSSt87x8sjfJb+uVIcoCbRCG4K6JnAJZEzILnExjOsAQ== + dependencies: + "@cvrg-report/clover-json" "^0.1.0" + bluebird "^3.5.2" + cobertura-parse "^1.0.5" + fast-glob "^2.2.3" + golang-cover-parse "^2.0.0" + jacoco-parse "^2.0.1" + lcov-parse "^1.0.0" + lodash "^4.17.11" + +"@connectis/diff-test-coverage@^1.5.1": + version "1.5.3" + resolved "https://registry.yarnpkg.com/@connectis/diff-test-coverage/-/diff-test-coverage-1.5.3.tgz#cf2109027931794aeafe554f3d79cbea1422c140" + integrity sha512-YXDVxcWQeN3BA2fWLu/3O8gLyYjJO2KL+MwqmD52CJHNehjvjq/U4RzYe5IUg6UsIs/evcKP3h7pt659HSSwHQ== + dependencies: + "@connectis/coverage-merger" "^1.1.0" + "@connectis/coverage-parser" "^1.0.7" + bluebird "^3.5.2" + chalk "^2.4.1" + diffparser "^2.0.1" + get-stdin "^6.0.0" + lodash "^4.17.11" + micromatch "^3.1.10" + strip-ansi "^5.0.0" + yargs "^12.0.2" + +"@cosmjs/amino@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/amino/-/amino-0.28.13.tgz#b51417a23c1ff8ef8b85a6862eba8492c6c44f38" + integrity sha512-IHnH2zGwaY69qT4mVAavr/pfzx6YE+ud1NHJbvVePlbGiz68CXTi5LHR+K0lrKB5mQ7E+ZErWz2mw5U/x+V1wQ== + dependencies: + "@cosmjs/crypto" "0.28.13" + "@cosmjs/encoding" "0.28.13" + "@cosmjs/math" "0.28.13" + "@cosmjs/utils" "0.28.13" + +"@cosmjs/crypto@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/crypto/-/crypto-0.28.13.tgz#541b6a36f616b2da5a568ead46d4e83841ceb412" + integrity sha512-ynKfM0q/tMBQMHJby6ad8lR3gkgBKaelQhIsCZTjClsnuC7oYT9y3ThSZCUWr7Pa9h0J8ahU2YV2oFWFVWJQzQ== + dependencies: + "@cosmjs/encoding" "0.28.13" + "@cosmjs/math" "0.28.13" + "@cosmjs/utils" "0.28.13" + "@noble/hashes" "^1" + bn.js "^5.2.0" + elliptic "^6.5.3" + libsodium-wrappers "^0.7.6" + +"@cosmjs/encoding@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/encoding/-/encoding-0.28.13.tgz#7994e8e2c435beaf0690296ffb0f7f3eaec8150b" + integrity sha512-jtXbAYtV77rLHxoIrjGFsvgGjeTKttuHRv6cvuy3toCZzY7JzTclKH5O2g36IIE4lXwD9xwuhGJ2aa6A3dhNkA== + dependencies: + base64-js "^1.3.0" + bech32 "^1.1.4" + readonly-date "^1.0.0" + +"@cosmjs/json-rpc@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/json-rpc/-/json-rpc-0.28.13.tgz#ff3f0c4a2f363b1a2c6779f8624a897e217fe297" + integrity sha512-fInSvg7x9P6p+GWqet+TMhrMTM3OWWdLJOGS5w2ryubMjgpR1rLiAx77MdTNkArW+/6sUwku0sN4veM4ENQu6A== + dependencies: + "@cosmjs/stream" "0.28.13" + xstream "^11.14.0" + +"@cosmjs/math@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/math/-/math-0.28.13.tgz#50c05bc67007a04216f7f5e0c93f57270f8cc077" + integrity sha512-PDpL8W/kbyeWi0mQ2OruyqE8ZUAdxPs1xCbDX3WXJwy2oU+X2UTbkuweJHVpS9CIqmZulBoWQAmlf6t6zr1N/g== + dependencies: + bn.js "^5.2.0" + +"@cosmjs/proto-signing@0.28.13", "@cosmjs/proto-signing@^0.28.10": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/proto-signing/-/proto-signing-0.28.13.tgz#95ac12f0da0f0814f348f5ae996c3e96d015df61" + integrity sha512-nSl/2ZLsUJYz3Ad0RY3ihZUgRHIow2OnYqKsESMu+3RA/jTi9bDYhiBu8mNMHI0xrEJry918B2CyI56pOUHdPQ== + dependencies: + "@cosmjs/amino" "0.28.13" + "@cosmjs/crypto" "0.28.13" + "@cosmjs/encoding" "0.28.13" + "@cosmjs/math" "0.28.13" + "@cosmjs/utils" "0.28.13" + cosmjs-types "^0.4.0" + long "^4.0.0" + +"@cosmjs/socket@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/socket/-/socket-0.28.13.tgz#d8443ad6e91d080fc6b80a7e9cf297a56b1f6833" + integrity sha512-lavwGxQ5VdeltyhpFtwCRVfxeWjH5D5mmN7jgx9nuCf3XSFbTcOYxrk2pQ4usenu1Q1KZdL4Yl5RCNrJuHD9Ug== + dependencies: + "@cosmjs/stream" "0.28.13" + isomorphic-ws "^4.0.1" + ws "^7" + xstream "^11.14.0" + +"@cosmjs/stargate@^0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/stargate/-/stargate-0.28.13.tgz#a73d837a46ee8944e6eafe162f2ff6943c14350e" + integrity sha512-dVBMazDz8/eActHsRcZjDHHptOBMqvibj5CFgEtZBp22gP6ASzoAUXTlkSVk5FBf4sfuUHoff6st134/+PGMAg== + dependencies: + "@confio/ics23" "^0.6.8" + "@cosmjs/amino" "0.28.13" + "@cosmjs/encoding" "0.28.13" + "@cosmjs/math" "0.28.13" + "@cosmjs/proto-signing" "0.28.13" + "@cosmjs/stream" "0.28.13" + "@cosmjs/tendermint-rpc" "0.28.13" + "@cosmjs/utils" "0.28.13" + cosmjs-types "^0.4.0" + long "^4.0.0" + protobufjs "~6.11.3" + xstream "^11.14.0" + +"@cosmjs/stream@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/stream/-/stream-0.28.13.tgz#1e79d1116fda1e63e5ecddbd9d803d403942b1fa" + integrity sha512-AnjtfwT8NwPPkd3lhZhjOlOzT0Kn9bgEu2IPOZjQ1nmG2bplsr6TJmnwn0dJxHT7UGtex17h6whKB5N4wU37Wg== + dependencies: + xstream "^11.14.0" + +"@cosmjs/tendermint-rpc@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/tendermint-rpc/-/tendermint-rpc-0.28.13.tgz#0bf587ae66fa3f88319edbd258492d28e73f9f29" + integrity sha512-GB+ZmfuJIGQm0hsRtLYjeR3lOxF7Z6XyCBR0cX5AAYOZzSEBJjevPgUHD6tLn8zIhvzxaW3/VKnMB+WmlxdH4w== + dependencies: + "@cosmjs/crypto" "0.28.13" + "@cosmjs/encoding" "0.28.13" + "@cosmjs/json-rpc" "0.28.13" + "@cosmjs/math" "0.28.13" + "@cosmjs/socket" "0.28.13" + "@cosmjs/stream" "0.28.13" + "@cosmjs/utils" "0.28.13" + axios "^0.21.2" + readonly-date "^1.0.0" + xstream "^11.14.0" + +"@cosmjs/utils@0.28.13": + version "0.28.13" + resolved "https://registry.yarnpkg.com/@cosmjs/utils/-/utils-0.28.13.tgz#2fd2844ec832d7833811e2ae1691305d09791a08" + integrity sha512-dVeMBiyg+46x7XBZEfJK8yTihphbCFpjVYmLJVqmTsHfJwymQ65cpyW/C+V/LgWARGK8hWQ/aX9HM5Ao8QmMSg== + +"@crocswap/sdk@^2.4.5": + version "2.4.5" + resolved "https://registry.yarnpkg.com/@crocswap/sdk/-/sdk-2.4.5.tgz#4a4765af4a16c1af42fcbcc5e540e9dd8793a6c1" + integrity sha512-nIErmtZg3xNT97L7t0Xj6xJWA6WETETOBmvZwUNmYqQN33xo7iegVPxIx7XRo5taRVH2deN/qbr6IRxSeEvmJQ== + dependencies: + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.4" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@cspotcode/source-map-support@^0.8.0": + version "0.8.1" + resolved "https://registry.yarnpkg.com/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz#00629c35a688e05a88b1cda684fb9d5e73f000a1" + integrity sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw== + dependencies: + "@jridgewell/trace-mapping" "0.3.9" + +"@cvrg-report/clover-json@^0.1.0": + version "0.1.1" + resolved "https://registry.yarnpkg.com/@cvrg-report/clover-json/-/clover-json-0.1.1.tgz#7e4ab3498b195c390bed9c5507c4226739ccc188" + integrity sha512-oq6hdyVVbJ0gqXydCxlAMrc4HbilQYyq4HPlTuXg+JXDU/N2XawyblhLXvE25SCcBUvgfFRvXdWI4UuEbEeJTg== + dependencies: + xml2js "^0.4.19" + +"@dabh/diagnostics@^2.0.2": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@dabh/diagnostics/-/diagnostics-2.0.3.tgz#7f7e97ee9a725dffc7808d93668cc984e1dc477a" + integrity sha512-hrlQOIi7hAfzsMqlGSFyVucrx38O+j6wiGOf//H2ecvIEqYN4ADBSS2iLMh5UFyDunCNniUIPk/q3riFv45xRA== + dependencies: + colorspace "1.1.x" + enabled "2.0.x" + kuler "^2.0.0" + +"@eslint/eslintrc@^0.4.3": + version "0.4.3" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c" + integrity sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw== + dependencies: + ajv "^6.12.4" + debug "^4.1.1" + espree "^7.3.0" + globals "^13.9.0" + ignore "^4.0.6" + import-fresh "^3.2.1" + js-yaml "^3.13.1" + minimatch "^3.0.4" + strip-json-comments "^3.1.1" + +"@ethereumjs/block@^3.5.0", "@ethereumjs/block@^3.6.2", "@ethereumjs/block@^3.6.3": + version "3.6.3" + resolved "https://registry.yarnpkg.com/@ethereumjs/block/-/block-3.6.3.tgz#d96cbd7af38b92ebb3424223dbf773f5ccd27f84" + integrity sha512-CegDeryc2DVKnDkg5COQrE0bJfw/p0v3GBk2W5/Dj5dOVfEmb50Ux0GLnSPypooLnfqjwFaorGuT9FokWB3GRg== + dependencies: + "@ethereumjs/common" "^2.6.5" + "@ethereumjs/tx" "^3.5.2" + ethereumjs-util "^7.1.5" + merkle-patricia-tree "^4.2.4" + +"@ethereumjs/blockchain@^5.5.2", "@ethereumjs/blockchain@^5.5.3": + version "5.5.3" + resolved "https://registry.yarnpkg.com/@ethereumjs/blockchain/-/blockchain-5.5.3.tgz#aa49a6a04789da6b66b5bcbb0d0b98efc369f640" + integrity sha512-bi0wuNJ1gw4ByNCV56H0Z4Q7D+SxUbwyG12Wxzbvqc89PXLRNR20LBcSUZRKpN0+YCPo6m0XZL/JLio3B52LTw== + dependencies: + "@ethereumjs/block" "^3.6.2" + "@ethereumjs/common" "^2.6.4" + "@ethereumjs/ethash" "^1.1.0" + debug "^4.3.3" + ethereumjs-util "^7.1.5" + level-mem "^5.0.1" + lru-cache "^5.1.1" + semaphore-async-await "^1.5.1" + +"@ethereumjs/common@^2.5.0", "@ethereumjs/common@^2.6.4", "@ethereumjs/common@^2.6.5": + version "2.6.5" + resolved "https://registry.yarnpkg.com/@ethereumjs/common/-/common-2.6.5.tgz#0a75a22a046272579d91919cb12d84f2756e8d30" + integrity sha512-lRyVQOeCDaIVtgfbowla32pzeDv2Obr8oR8Put5RdUBNRGr1VGPGQNGP6elWIpgK3YdpzqTOh4GyUGOureVeeA== + dependencies: + crc-32 "^1.2.0" + ethereumjs-util "^7.1.5" + +"@ethereumjs/ethash@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@ethereumjs/ethash/-/ethash-1.1.0.tgz#7c5918ffcaa9cb9c1dc7d12f77ef038c11fb83fb" + integrity sha512-/U7UOKW6BzpA+Vt+kISAoeDie1vAvY4Zy2KF5JJb+So7+1yKmJeJEHOGSnQIj330e9Zyl3L5Nae6VZyh2TJnAA== + dependencies: + "@ethereumjs/block" "^3.5.0" + "@types/levelup" "^4.3.0" + buffer-xor "^2.0.1" + ethereumjs-util "^7.1.1" + miller-rabin "^4.0.0" + +"@ethereumjs/tx@^3.3.2", "@ethereumjs/tx@^3.5.1", "@ethereumjs/tx@^3.5.2": + version "3.5.2" + resolved "https://registry.yarnpkg.com/@ethereumjs/tx/-/tx-3.5.2.tgz#197b9b6299582ad84f9527ca961466fce2296c1c" + integrity sha512-gQDNJWKrSDGu2w7w0PzVXVBNMzb7wwdDOmOqczmhNjqFxFuIbhVJDwiGEnxFNC2/b8ifcZzY7MLcluizohRzNw== + dependencies: + "@ethereumjs/common" "^2.6.4" + ethereumjs-util "^7.1.5" + +"@ethereumjs/vm@^5.9.0": + version "5.9.3" + resolved "https://registry.yarnpkg.com/@ethereumjs/vm/-/vm-5.9.3.tgz#6d69202e4c132a4a1e1628ac246e92062e230823" + integrity sha512-Ha04TeF8goEglr8eL7hkkYyjhzdZS0PsoRURzYlTF6I0VVId5KjKb0N7MrA8GMgheN+UeTncfTgYx52D/WhEmg== + dependencies: + "@ethereumjs/block" "^3.6.3" + "@ethereumjs/blockchain" "^5.5.3" + "@ethereumjs/common" "^2.6.5" + "@ethereumjs/tx" "^3.5.2" + async-eventemitter "^0.2.4" + core-js-pure "^3.0.1" + debug "^4.3.3" + ethereumjs-util "^7.1.5" + functional-red-black-tree "^1.0.1" + mcl-wasm "^0.7.1" + merkle-patricia-tree "^4.2.4" + rustbn.js "~0.2.0" + +"@ethersproject/abi@5.6.4", "@ethersproject/abi@^5.0.12", "@ethersproject/abi@^5.1.2", "@ethersproject/abi@^5.4.0", "@ethersproject/abi@^5.5.0", "@ethersproject/abi@^5.6.3": + version "5.6.4" + resolved "https://registry.yarnpkg.com/@ethersproject/abi/-/abi-5.6.4.tgz#f6e01b6ed391a505932698ecc0d9e7a99ee60362" + integrity sha512-TTeZUlCeIHG6527/2goZA6gW5F8Emoc7MrZDC7hhP84aRGvW3TEdTnZR08Ls88YXM1m2SuK42Osw/jSi3uO8gg== + dependencies: + "@ethersproject/address" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/constants" "^5.6.1" + "@ethersproject/hash" "^5.6.1" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/strings" "^5.6.1" + +"@ethersproject/abstract-provider@5.6.1", "@ethersproject/abstract-provider@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/abstract-provider/-/abstract-provider-5.6.1.tgz#02ddce150785caf0c77fe036a0ebfcee61878c59" + integrity sha512-BxlIgogYJtp1FS8Muvj8YfdClk3unZH0vRMVX791Z9INBNT/kuACZ9GzaY1Y4yFq+YSy6/w4gzj3HCRKrK9hsQ== + dependencies: + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/networks" "^5.6.3" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/transactions" "^5.6.2" + "@ethersproject/web" "^5.6.1" + +"@ethersproject/abstract-signer@5.6.2", "@ethersproject/abstract-signer@^5.4.0", "@ethersproject/abstract-signer@^5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/abstract-signer/-/abstract-signer-5.6.2.tgz#491f07fc2cbd5da258f46ec539664713950b0b33" + integrity sha512-n1r6lttFBG0t2vNiI3HoWaS/KdOt8xyDjzlP2cuevlWLG6EX0OwcKLyG/Kp/cuwNxdy/ous+R/DEMdTUwWQIjQ== + dependencies: + "@ethersproject/abstract-provider" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + +"@ethersproject/address@5.6.1", "@ethersproject/address@^5.0.0", "@ethersproject/address@^5.0.0-beta", "@ethersproject/address@^5.0.1", "@ethersproject/address@^5.0.2", "@ethersproject/address@^5.4.0", "@ethersproject/address@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/address/-/address-5.6.1.tgz#ab57818d9aefee919c5721d28cd31fd95eff413d" + integrity sha512-uOgF0kS5MJv9ZvCz7x6T2EXJSzotiybApn4XlOgoTX0xdtyVIJ7pF+6cGPxiEq/dpBiTfMiw7Yc81JcwhSYA0Q== + dependencies: + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/rlp" "^5.6.1" + +"@ethersproject/base64@5.6.1", "@ethersproject/base64@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/base64/-/base64-5.6.1.tgz#2c40d8a0310c9d1606c2c37ae3092634b41d87cb" + integrity sha512-qB76rjop6a0RIYYMiB4Eh/8n+Hxu2NIZm8S/Q7kNo5pmZfXhHGHmS4MinUainiBC54SCyRnwzL+KZjj8zbsSsw== + dependencies: + "@ethersproject/bytes" "^5.6.1" + +"@ethersproject/basex@5.6.1", "@ethersproject/basex@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/basex/-/basex-5.6.1.tgz#badbb2f1d4a6f52ce41c9064f01eab19cc4c5305" + integrity sha512-a52MkVz4vuBXR06nvflPMotld1FJWSj2QT0985v7P/emPZO00PucFAkbcmq2vpVU7Ts7umKiSI6SppiLykVWsA== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/properties" "^5.6.0" + +"@ethersproject/bignumber@5.6.2", "@ethersproject/bignumber@^5.4.0", "@ethersproject/bignumber@^5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/bignumber/-/bignumber-5.6.2.tgz#72a0717d6163fab44c47bcc82e0c550ac0315d66" + integrity sha512-v7+EEUbhGqT3XJ9LMPsKvXYHFc8eHxTowFCG/HgJErmq4XHJ2WR7aeyICg3uTOAQ7Icn0GFHAohXEhxQHq4Ubw== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + bn.js "^5.2.1" + +"@ethersproject/bignumber@^5.6.0": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/bignumber/-/bignumber-5.6.0.tgz#116c81b075c57fa765a8f3822648cf718a8a0e26" + integrity sha512-VziMaXIUHQlHJmkv1dlcd6GY2PmT0khtAqaMctCIDogxkrarMzA9L94KN1NeXqqOfFD6r0sJT3vCTOFSmZ07DA== + dependencies: + "@ethersproject/bytes" "^5.6.0" + "@ethersproject/logger" "^5.6.0" + bn.js "^4.11.9" + +"@ethersproject/bytes@5.6.1", "@ethersproject/bytes@^5.4.0", "@ethersproject/bytes@^5.6.0", "@ethersproject/bytes@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/bytes/-/bytes-5.6.1.tgz#24f916e411f82a8a60412344bf4a813b917eefe7" + integrity sha512-NwQt7cKn5+ZE4uDn+X5RAXLp46E1chXoaMmrxAyA0rblpxz8t58lVkrHXoRIn0lz1joQElQ8410GqhTqMOwc6g== + dependencies: + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/constants@5.6.1", "@ethersproject/constants@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/constants/-/constants-5.6.1.tgz#e2e974cac160dd101cf79fdf879d7d18e8cb1370" + integrity sha512-QSq9WVnZbxXYFftrjSjZDUshp6/eKp6qrtdBtUCm0QxCV5z1fG/w3kdlcsjMCQuQHUnAclKoK7XpXMezhRDOLg== + dependencies: + "@ethersproject/bignumber" "^5.6.2" + +"@ethersproject/constants@^5.6.0": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/constants/-/constants-5.6.0.tgz#55e3eb0918584d3acc0688e9958b0cedef297088" + integrity sha512-SrdaJx2bK0WQl23nSpV/b1aq293Lh0sUaZT/yYKPDKn4tlAbkH96SPJwIhwSwTsoQQZxuh1jnqsKwyymoiBdWA== + dependencies: + "@ethersproject/bignumber" "^5.6.0" + +"@ethersproject/contracts@5.6.2", "@ethersproject/contracts@^5.0.0-beta", "@ethersproject/contracts@^5.0.1", "@ethersproject/contracts@^5.4.0", "@ethersproject/contracts@^5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/contracts/-/contracts-5.6.2.tgz#20b52e69ebc1b74274ff8e3d4e508de971c287bc" + integrity sha512-hguUA57BIKi6WY0kHvZp6PwPlWF87MCeB4B7Z7AbUpTxfFXFdn/3b0GmjZPagIHS+3yhcBJDnuEfU4Xz+Ks/8g== + dependencies: + "@ethersproject/abi" "^5.6.3" + "@ethersproject/abstract-provider" "^5.6.1" + "@ethersproject/abstract-signer" "^5.6.2" + "@ethersproject/address" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/constants" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/transactions" "^5.6.2" + +"@ethersproject/experimental@^5.3.0", "@ethersproject/experimental@^5.4.0": + version "5.6.3" + resolved "https://registry.yarnpkg.com/@ethersproject/experimental/-/experimental-5.6.3.tgz#d1cd8f3b886cbab86430fb2954eb65ddb7c75ffd" + integrity sha512-yMymv32XMr9sXvHc3S1On2wD0JMT6n4X9uKpfZ8jFFw5rEcI99yfovcCZ0tpUedh1b3IvReSain+RobeNQmmEg== + dependencies: + "@ethersproject/web" "^5.6.1" + ethers "^5.6.8" + scrypt-js "3.0.1" + +"@ethersproject/hash@5.6.1", "@ethersproject/hash@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/hash/-/hash-5.6.1.tgz#224572ea4de257f05b4abf8ae58b03a67e99b0f4" + integrity sha512-L1xAHurbaxG8VVul4ankNX5HgQ8PNCTrnVXEiFnE9xoRnaUcgfD12tZINtDinSllxPLCtGwguQxJ5E6keE84pA== + dependencies: + "@ethersproject/abstract-signer" "^5.6.2" + "@ethersproject/address" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/strings" "^5.6.1" + +"@ethersproject/hdnode@5.6.2", "@ethersproject/hdnode@^5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/hdnode/-/hdnode-5.6.2.tgz#26f3c83a3e8f1b7985c15d1db50dc2903418b2d2" + integrity sha512-tERxW8Ccf9CxW2db3WsN01Qao3wFeRsfYY9TCuhmG0xNpl2IO8wgXU3HtWIZ49gUWPggRy4Yg5axU0ACaEKf1Q== + dependencies: + "@ethersproject/abstract-signer" "^5.6.2" + "@ethersproject/basex" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/pbkdf2" "^5.6.1" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/sha2" "^5.6.1" + "@ethersproject/signing-key" "^5.6.2" + "@ethersproject/strings" "^5.6.1" + "@ethersproject/transactions" "^5.6.2" + "@ethersproject/wordlists" "^5.6.1" + +"@ethersproject/json-wallets@5.6.1", "@ethersproject/json-wallets@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/json-wallets/-/json-wallets-5.6.1.tgz#3f06ba555c9c0d7da46756a12ac53483fe18dd91" + integrity sha512-KfyJ6Zwz3kGeX25nLihPwZYlDqamO6pfGKNnVMWWfEVVp42lTfCZVXXy5Ie8IZTN0HKwAngpIPi7gk4IJzgmqQ== + dependencies: + "@ethersproject/abstract-signer" "^5.6.2" + "@ethersproject/address" "^5.6.1" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/hdnode" "^5.6.2" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/pbkdf2" "^5.6.1" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/random" "^5.6.1" + "@ethersproject/strings" "^5.6.1" + "@ethersproject/transactions" "^5.6.2" + aes-js "3.0.0" + scrypt-js "3.0.1" + +"@ethersproject/keccak256@5.6.1", "@ethersproject/keccak256@^5.6.0", "@ethersproject/keccak256@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/keccak256/-/keccak256-5.6.1.tgz#b867167c9b50ba1b1a92bccdd4f2d6bd168a91cc" + integrity sha512-bB7DQHCTRDooZZdL3lk9wpL0+XuG3XLGHLh3cePnybsO3V0rdCAOQGpn/0R3aODmnTOOkCATJiD2hnL+5bwthA== + dependencies: + "@ethersproject/bytes" "^5.6.1" + js-sha3 "0.8.0" + +"@ethersproject/logger@5.6.0", "@ethersproject/logger@^5.6.0": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/logger/-/logger-5.6.0.tgz#d7db1bfcc22fd2e4ab574cba0bb6ad779a9a3e7a" + integrity sha512-BiBWllUROH9w+P21RzoxJKzqoqpkyM1pRnEKG69bulE9TSQD8SAIvTQqIMZmmCO8pUNkgLP1wndX1gKghSpBmg== + +"@ethersproject/networks@5.6.4", "@ethersproject/networks@^5.0.0-beta", "@ethersproject/networks@^5.0.1", "@ethersproject/networks@^5.4.0", "@ethersproject/networks@^5.6.3": + version "5.6.4" + resolved "https://registry.yarnpkg.com/@ethersproject/networks/-/networks-5.6.4.tgz#51296d8fec59e9627554f5a8a9c7791248c8dc07" + integrity sha512-KShHeHPahHI2UlWdtDMn2lJETcbtaJge4k7XSjDR9h79QTd6yQJmv6Cp2ZA4JdqWnhszAOLSuJEd9C0PRw7hSQ== + dependencies: + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/pbkdf2@5.6.1", "@ethersproject/pbkdf2@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/pbkdf2/-/pbkdf2-5.6.1.tgz#f462fe320b22c0d6b1d72a9920a3963b09eb82d1" + integrity sha512-k4gRQ+D93zDRPNUfmduNKq065uadC2YjMP/CqwwX5qG6R05f47boq6pLZtV/RnC4NZAYOPH1Cyo54q0c9sshRQ== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/sha2" "^5.6.1" + +"@ethersproject/properties@5.6.0", "@ethersproject/properties@^5.6.0": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/properties/-/properties-5.6.0.tgz#38904651713bc6bdd5bdd1b0a4287ecda920fa04" + integrity sha512-szoOkHskajKePTJSZ46uHUWWkbv7TzP2ypdEK6jGMqJaEt2sb0jCgfBo0gH0m2HBpRixMuJ6TBRaQCF7a9DoCg== + dependencies: + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/providers@5.6.8", "@ethersproject/providers@^5.0.0-beta", "@ethersproject/providers@^5.0.4", "@ethersproject/providers@^5.4.0", "@ethersproject/providers@^5.6.8": + version "5.6.8" + resolved "https://registry.yarnpkg.com/@ethersproject/providers/-/providers-5.6.8.tgz#22e6c57be215ba5545d3a46cf759d265bb4e879d" + integrity sha512-Wf+CseT/iOJjrGtAOf3ck9zS7AgPmr2fZ3N97r4+YXN3mBePTG2/bJ8DApl9mVwYL+RpYbNxMEkEp4mPGdwG/w== + dependencies: + "@ethersproject/abstract-provider" "^5.6.1" + "@ethersproject/abstract-signer" "^5.6.2" + "@ethersproject/address" "^5.6.1" + "@ethersproject/base64" "^5.6.1" + "@ethersproject/basex" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/constants" "^5.6.1" + "@ethersproject/hash" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/networks" "^5.6.3" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/random" "^5.6.1" + "@ethersproject/rlp" "^5.6.1" + "@ethersproject/sha2" "^5.6.1" + "@ethersproject/strings" "^5.6.1" + "@ethersproject/transactions" "^5.6.2" + "@ethersproject/web" "^5.6.1" + bech32 "1.1.4" + ws "7.4.6" + +"@ethersproject/random@5.6.1", "@ethersproject/random@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/random/-/random-5.6.1.tgz#66915943981bcd3e11bbd43733f5c3ba5a790255" + integrity sha512-/wtPNHwbmng+5yi3fkipA8YBT59DdkGRoC2vWk09Dci/q5DlgnMkhIycjHlavrvrjJBkFjO/ueLyT+aUDfc4lA== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/rlp@5.6.1", "@ethersproject/rlp@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/rlp/-/rlp-5.6.1.tgz#df8311e6f9f24dcb03d59a2bac457a28a4fe2bd8" + integrity sha512-uYjmcZx+DKlFUk7a5/W9aQVaoEC7+1MOBgNtvNg13+RnuUwT4F0zTovC0tmay5SmRslb29V1B7Y5KCri46WhuQ== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/sha2@5.6.1", "@ethersproject/sha2@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/sha2/-/sha2-5.6.1.tgz#211f14d3f5da5301c8972a8827770b6fd3e51656" + integrity sha512-5K2GyqcW7G4Yo3uenHegbXRPDgARpWUiXc6RiF7b6i/HXUoWlb7uCARh7BAHg7/qT/Q5ydofNwiZcim9qpjB6g== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + hash.js "1.1.7" + +"@ethersproject/sha2@^5.5.0", "@ethersproject/sha2@^5.6.0": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/sha2/-/sha2-5.6.0.tgz#364c4c11cc753bda36f31f001628706ebadb64d9" + integrity sha512-1tNWCPFLu1n3JM9t4/kytz35DkuF9MxqkGGEHNauEbaARdm2fafnOyw1s0tIQDPKF/7bkP1u3dbrmjpn5CelyA== + dependencies: + "@ethersproject/bytes" "^5.6.0" + "@ethersproject/logger" "^5.6.0" + hash.js "1.1.7" + +"@ethersproject/signing-key@5.6.2", "@ethersproject/signing-key@^5.4.0", "@ethersproject/signing-key@^5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/signing-key/-/signing-key-5.6.2.tgz#8a51b111e4d62e5a62aee1da1e088d12de0614a3" + integrity sha512-jVbu0RuP7EFpw82vHcL+GP35+KaNruVAZM90GxgQnGqB6crhBqW/ozBfFvdeImtmb4qPko0uxXjn8l9jpn0cwQ== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + bn.js "^5.2.1" + elliptic "6.5.4" + hash.js "1.1.7" + +"@ethersproject/solidity@5.6.1", "@ethersproject/solidity@^5.0.0", "@ethersproject/solidity@^5.0.0-beta", "@ethersproject/solidity@^5.0.1", "@ethersproject/solidity@^5.4.0": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/solidity/-/solidity-5.6.1.tgz#5845e71182c66d32e6ec5eefd041fca091a473e2" + integrity sha512-KWqVLkUUoLBfL1iwdzUVlkNqAUIFMpbbeH0rgCfKmJp0vFtY4AsaN91gHKo9ZZLkC4UOm3cI3BmMV4N53BOq4g== + dependencies: + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/sha2" "^5.6.1" + "@ethersproject/strings" "^5.6.1" + +"@ethersproject/solidity@^5.0.9": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/solidity/-/solidity-5.6.0.tgz#64657362a596bf7f5630bdc921c07dd78df06dc3" + integrity sha512-YwF52vTNd50kjDzqKaoNNbC/r9kMDPq3YzDWmsjFTRBcIF1y4JCQJ8gB30wsTfHbaxgxelI5BfxQSxD/PbJOww== + dependencies: + "@ethersproject/bignumber" "^5.6.0" + "@ethersproject/bytes" "^5.6.0" + "@ethersproject/keccak256" "^5.6.0" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/sha2" "^5.6.0" + "@ethersproject/strings" "^5.6.0" + +"@ethersproject/strings@5.6.1", "@ethersproject/strings@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/strings/-/strings-5.6.1.tgz#dbc1b7f901db822b5cafd4ebf01ca93c373f8952" + integrity sha512-2X1Lgk6Jyfg26MUnsHiT456U9ijxKUybz8IM1Vih+NJxYtXhmvKBcHOmvGqpFSVJ0nQ4ZCoIViR8XlRw1v/+Cw== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/constants" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/strings@^5.6.0": + version "5.6.0" + resolved "https://registry.yarnpkg.com/@ethersproject/strings/-/strings-5.6.0.tgz#9891b26709153d996bf1303d39a7f4bc047878fd" + integrity sha512-uv10vTtLTZqrJuqBZR862ZQjTIa724wGPWQqZrofaPI/kUsf53TBG0I0D+hQ1qyNtllbNzaW+PDPHHUI6/65Mg== + dependencies: + "@ethersproject/bytes" "^5.6.0" + "@ethersproject/constants" "^5.6.0" + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/transactions@5.6.2", "@ethersproject/transactions@^5.4.0", "@ethersproject/transactions@^5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/transactions/-/transactions-5.6.2.tgz#793a774c01ced9fe7073985bb95a4b4e57a6370b" + integrity sha512-BuV63IRPHmJvthNkkt9G70Ullx6AcM+SDc+a8Aw/8Yew6YwT51TcBKEp1P4oOQ/bP25I18JJr7rcFRgFtU9B2Q== + dependencies: + "@ethersproject/address" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/constants" "^5.6.1" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/rlp" "^5.6.1" + "@ethersproject/signing-key" "^5.6.2" + +"@ethersproject/units@5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/units/-/units-5.6.1.tgz#ecc590d16d37c8f9ef4e89e2005bda7ddc6a4e6f" + integrity sha512-rEfSEvMQ7obcx3KWD5EWWx77gqv54K6BKiZzKxkQJqtpriVsICrktIQmKl8ReNToPeIYPnFHpXvKpi068YFZXw== + dependencies: + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/constants" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + +"@ethersproject/wallet@5.6.2": + version "5.6.2" + resolved "https://registry.yarnpkg.com/@ethersproject/wallet/-/wallet-5.6.2.tgz#cd61429d1e934681e413f4bc847a5f2f87e3a03c" + integrity sha512-lrgh0FDQPuOnHcF80Q3gHYsSUODp6aJLAdDmDV0xKCN/T7D99ta1jGVhulg3PY8wiXEngD0DfM0I2XKXlrqJfg== + dependencies: + "@ethersproject/abstract-provider" "^5.6.1" + "@ethersproject/abstract-signer" "^5.6.2" + "@ethersproject/address" "^5.6.1" + "@ethersproject/bignumber" "^5.6.2" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/hash" "^5.6.1" + "@ethersproject/hdnode" "^5.6.2" + "@ethersproject/json-wallets" "^5.6.1" + "@ethersproject/keccak256" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/random" "^5.6.1" + "@ethersproject/signing-key" "^5.6.2" + "@ethersproject/transactions" "^5.6.2" + "@ethersproject/wordlists" "^5.6.1" + +"@ethersproject/web@5.6.1", "@ethersproject/web@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/web/-/web-5.6.1.tgz#6e2bd3ebadd033e6fe57d072db2b69ad2c9bdf5d" + integrity sha512-/vSyzaQlNXkO1WV+RneYKqCJwualcUdx/Z3gseVovZP0wIlOFcCE1hkRhKBH8ImKbGQbMl9EAAyJFrJu7V0aqA== + dependencies: + "@ethersproject/base64" "^5.6.1" + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/strings" "^5.6.1" + +"@ethersproject/wordlists@5.6.1", "@ethersproject/wordlists@^5.6.1": + version "5.6.1" + resolved "https://registry.yarnpkg.com/@ethersproject/wordlists/-/wordlists-5.6.1.tgz#1e78e2740a8a21e9e99947e47979d72e130aeda1" + integrity sha512-wiPRgBpNbNwCQFoCr8bcWO8o5I810cqO6mkdtKfLKFlLxeCWcnzDi4Alu8iyNzlhYuS9npCwivMbRWF19dyblw== + dependencies: + "@ethersproject/bytes" "^5.6.1" + "@ethersproject/hash" "^5.6.1" + "@ethersproject/logger" "^5.6.0" + "@ethersproject/properties" "^5.6.0" + "@ethersproject/strings" "^5.6.1" + +"@findeth/abi@^0.3.0": + version "0.3.1" + resolved "https://registry.yarnpkg.com/@findeth/abi/-/abi-0.3.1.tgz#fe9a25211bc0c840c8bc53f937fd9af7278b9dab" + integrity sha512-T9HUVEjEgM0MzVLY4gs52ffz5AlHeC3CSGFcEzL4ojKMVzMxa3na1GW/XCmunrhnWP2cDh4fE2MhqLxA0CHqTw== + dependencies: + keccak "^3.0.0" + +"@firebase/analytics-types@0.4.0": + version "0.4.0" + resolved "https://registry.yarnpkg.com/@firebase/analytics-types/-/analytics-types-0.4.0.tgz#d6716f9fa36a6e340bc0ecfe68af325aa6f60508" + integrity sha512-Jj2xW+8+8XPfWGkv9HPv/uR+Qrmq37NPYT352wf7MvE9LrstpLVmFg3LqG6MCRr5miLAom5sen2gZ+iOhVDeRA== + +"@firebase/analytics@0.6.0": + version "0.6.0" + resolved "https://registry.yarnpkg.com/@firebase/analytics/-/analytics-0.6.0.tgz#49f508d3f9f419f08c503f1171ef5fa1c3ba52eb" + integrity sha512-6qYEOPUVYrMhqvJ46Z5Uf1S4uULd6d7vGpMP5Qz+u8kIWuOQGcPdJKQap+Hla6Rq164or9gC2HRXuYXKlgWfpw== + dependencies: + "@firebase/analytics-types" "0.4.0" + "@firebase/component" "0.1.19" + "@firebase/installations" "0.4.17" + "@firebase/logger" "0.2.6" + "@firebase/util" "0.3.2" + tslib "^1.11.1" + +"@firebase/app-types@0.6.1": + version "0.6.1" + resolved "https://registry.yarnpkg.com/@firebase/app-types/-/app-types-0.6.1.tgz#dcbd23030a71c0c74fc95d4a3f75ba81653850e9" + integrity sha512-L/ZnJRAq7F++utfuoTKX4CLBG5YR7tFO3PLzG1/oXXKEezJ0kRL3CMRoueBEmTCzVb/6SIs2Qlaw++uDgi5Xyg== + +"@firebase/app@0.6.11": + version "0.6.11" + resolved "https://registry.yarnpkg.com/@firebase/app/-/app-0.6.11.tgz#f73f9e4571ba62f4029d8f9c9880a97e5a94eb1d" + integrity sha512-FH++PaoyTzfTAVuJ0gITNYEIcjT5G+D0671La27MU8Vvr6MTko+5YUZ4xS9QItyotSeRF4rMJ1KR7G8LSyySiA== + dependencies: + "@firebase/app-types" "0.6.1" + "@firebase/component" "0.1.19" + "@firebase/logger" "0.2.6" + "@firebase/util" "0.3.2" + dom-storage "2.1.0" + tslib "^1.11.1" + xmlhttprequest "1.8.0" + +"@firebase/auth-interop-types@0.1.5": + version "0.1.5" + resolved "https://registry.yarnpkg.com/@firebase/auth-interop-types/-/auth-interop-types-0.1.5.tgz#9fc9bd7c879f16b8d1bb08373a0f48c3a8b74557" + integrity sha512-88h74TMQ6wXChPA6h9Q3E1Jg6TkTHep2+k63OWg3s0ozyGVMeY+TTOti7PFPzq5RhszQPQOoCi59es4MaRvgCw== + +"@firebase/auth-types@0.10.1": + version "0.10.1" + resolved "https://registry.yarnpkg.com/@firebase/auth-types/-/auth-types-0.10.1.tgz#7815e71c9c6f072034415524b29ca8f1d1770660" + integrity sha512-/+gBHb1O9x/YlG7inXfxff/6X3BPZt4zgBv4kql6HEmdzNQCodIRlEYnI+/da+lN+dha7PjaFH7C7ewMmfV7rw== + +"@firebase/auth@0.15.0": + version "0.15.0" + resolved "https://registry.yarnpkg.com/@firebase/auth/-/auth-0.15.0.tgz#45d6def6d6d9444432c005710df442991828275f" + integrity sha512-IFuzhxS+HtOQl7+SZ/Mhaghy/zTU7CENsJFWbC16tv2wfLZbayKF5jYGdAU3VFLehgC8KjlcIWd10akc3XivfQ== + dependencies: + "@firebase/auth-types" "0.10.1" + +"@firebase/component@0.1.19": + version "0.1.19" + resolved "https://registry.yarnpkg.com/@firebase/component/-/component-0.1.19.tgz#bd2ac601652c22576b574c08c40da245933dbac7" + integrity sha512-L0S3g8eqaerg8y0zox3oOHSTwn/FE8RbcRHiurnbESvDViZtP5S5WnhuAPd7FnFxa8ElWK0z1Tr3ikzWDv1xdQ== + dependencies: + "@firebase/util" "0.3.2" + tslib "^1.11.1" + +"@firebase/database-types@0.5.2": + version "0.5.2" + resolved "https://registry.yarnpkg.com/@firebase/database-types/-/database-types-0.5.2.tgz#23bec8477f84f519727f165c687761e29958b63c" + integrity sha512-ap2WQOS3LKmGuVFKUghFft7RxXTyZTDr0Xd8y2aqmWsbJVjgozi0huL/EUMgTjGFrATAjcf2A7aNs8AKKZ2a8g== + dependencies: + "@firebase/app-types" "0.6.1" + +"@firebase/database@0.6.13": + version "0.6.13" + resolved "https://registry.yarnpkg.com/@firebase/database/-/database-0.6.13.tgz#b96fe0c53757dd6404ee085fdcb45c0f9f525c17" + integrity sha512-NommVkAPzU7CKd1gyehmi3lz0K78q0KOfiex7Nfy7MBMwknLm7oNqKovXSgQV1PCLvKXvvAplDSFhDhzIf9obA== + dependencies: + "@firebase/auth-interop-types" "0.1.5" + "@firebase/component" "0.1.19" + "@firebase/database-types" "0.5.2" + "@firebase/logger" "0.2.6" + "@firebase/util" "0.3.2" + faye-websocket "0.11.3" + tslib "^1.11.1" + +"@firebase/firestore-types@1.14.0": + version "1.14.0" + resolved "https://registry.yarnpkg.com/@firebase/firestore-types/-/firestore-types-1.14.0.tgz#4516249d3c181849fd3c856831944dbd5c8c55fc" + integrity sha512-WF8IBwHzZDhwyOgQnmB0pheVrLNP78A8PGxk1nxb/Nrgh1amo4/zYvFMGgSsTeaQK37xMYS/g7eS948te/dJxw== + +"@firebase/firestore@1.18.0": + version "1.18.0" + resolved "https://registry.yarnpkg.com/@firebase/firestore/-/firestore-1.18.0.tgz#3430e8c60d3e6be1d174b3a258838b1944c93a4d" + integrity sha512-maMq4ltkrwjDRusR2nt0qS4wldHQMp+0IDSfXIjC+SNmjnWY/t/+Skn9U3Po+dB38xpz3i7nsKbs+8utpDnPSw== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/firestore-types" "1.14.0" + "@firebase/logger" "0.2.6" + "@firebase/util" "0.3.2" + "@firebase/webchannel-wrapper" "0.4.0" + "@grpc/grpc-js" "^1.0.0" + "@grpc/proto-loader" "^0.5.0" + node-fetch "2.6.1" + tslib "^1.11.1" + +"@firebase/functions-types@0.3.17": + version "0.3.17" + resolved "https://registry.yarnpkg.com/@firebase/functions-types/-/functions-types-0.3.17.tgz#348bf5528b238eeeeeae1d52e8ca547b21d33a94" + integrity sha512-DGR4i3VI55KnYk4IxrIw7+VG7Q3gA65azHnZxo98Il8IvYLr2UTBlSh72dTLlDf25NW51HqvJgYJDKvSaAeyHQ== + +"@firebase/functions@0.5.1": + version "0.5.1" + resolved "https://registry.yarnpkg.com/@firebase/functions/-/functions-0.5.1.tgz#fa0568bdcdf7dfa7e5f4f66c1e06e376dc7e25b6" + integrity sha512-yyjPZXXvzFPjkGRSqFVS5Hc2Y7Y48GyyMH+M3i7hLGe69r/59w6wzgXKqTiSYmyE1pxfjxU4a1YqBDHNkQkrYQ== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/functions-types" "0.3.17" + "@firebase/messaging-types" "0.5.0" + node-fetch "2.6.1" + tslib "^1.11.1" + +"@firebase/installations-types@0.3.4": + version "0.3.4" + resolved "https://registry.yarnpkg.com/@firebase/installations-types/-/installations-types-0.3.4.tgz#589a941d713f4f64bf9f4feb7f463505bab1afa2" + integrity sha512-RfePJFovmdIXb6rYwtngyxuEcWnOrzdZd9m7xAW0gRxDIjBT20n3BOhjpmgRWXo/DAxRmS7bRjWAyTHY9cqN7Q== + +"@firebase/installations@0.4.17": + version "0.4.17" + resolved "https://registry.yarnpkg.com/@firebase/installations/-/installations-0.4.17.tgz#1367b721e2c6c4880646bbc4f257e8616986a004" + integrity sha512-AE/TyzIpwkC4UayRJD419xTqZkKzxwk0FLht3Dci8WI2OEKHSwoZG9xv4hOBZebe+fDzoV2EzfatQY8c/6Avig== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/installations-types" "0.3.4" + "@firebase/util" "0.3.2" + idb "3.0.2" + tslib "^1.11.1" + +"@firebase/logger@0.2.6": + version "0.2.6" + resolved "https://registry.yarnpkg.com/@firebase/logger/-/logger-0.2.6.tgz#3aa2ca4fe10327cabf7808bd3994e88db26d7989" + integrity sha512-KIxcUvW/cRGWlzK9Vd2KB864HlUnCfdTH0taHE0sXW5Xl7+W68suaeau1oKNEqmc3l45azkd4NzXTCWZRZdXrw== + +"@firebase/messaging-types@0.5.0": + version "0.5.0" + resolved "https://registry.yarnpkg.com/@firebase/messaging-types/-/messaging-types-0.5.0.tgz#c5d0ef309ced1758fda93ef3ac70a786de2e73c4" + integrity sha512-QaaBswrU6umJYb/ZYvjR5JDSslCGOH6D9P136PhabFAHLTR4TWjsaACvbBXuvwrfCXu10DtcjMxqfhdNIB1Xfg== + +"@firebase/messaging@0.7.1": + version "0.7.1" + resolved "https://registry.yarnpkg.com/@firebase/messaging/-/messaging-0.7.1.tgz#debbe7eb17c5b789231da6c166c506e19ecf1ed4" + integrity sha512-iev/ST9v0xd/8YpGYrZtDcqdD9J6ZWzSuceRn8EKy5vIgQvW/rk2eTQc8axzvDpQ36ZfphMYuhW6XuNrR3Pd2Q== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/installations" "0.4.17" + "@firebase/messaging-types" "0.5.0" + "@firebase/util" "0.3.2" + idb "3.0.2" + tslib "^1.11.1" + +"@firebase/performance-types@0.0.13": + version "0.0.13" + resolved "https://registry.yarnpkg.com/@firebase/performance-types/-/performance-types-0.0.13.tgz#58ce5453f57e34b18186f74ef11550dfc558ede6" + integrity sha512-6fZfIGjQpwo9S5OzMpPyqgYAUZcFzZxHFqOyNtorDIgNXq33nlldTL/vtaUZA8iT9TT5cJlCrF/jthKU7X21EA== + +"@firebase/performance@0.4.2": + version "0.4.2" + resolved "https://registry.yarnpkg.com/@firebase/performance/-/performance-0.4.2.tgz#d5f134674b429d095ce0edfb50fcb4ab279c3cbe" + integrity sha512-irHTCVWJ/sxJo0QHg+yQifBeVu8ZJPihiTqYzBUz/0AGc51YSt49FZwqSfknvCN2+OfHaazz/ARVBn87g7Ex8g== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/installations" "0.4.17" + "@firebase/logger" "0.2.6" + "@firebase/performance-types" "0.0.13" + "@firebase/util" "0.3.2" + tslib "^1.11.1" + +"@firebase/polyfill@0.3.36": + version "0.3.36" + resolved "https://registry.yarnpkg.com/@firebase/polyfill/-/polyfill-0.3.36.tgz#c057cce6748170f36966b555749472b25efdb145" + integrity sha512-zMM9oSJgY6cT2jx3Ce9LYqb0eIpDE52meIzd/oe/y70F+v9u1LDqk5kUF5mf16zovGBWMNFmgzlsh6Wj0OsFtg== + dependencies: + core-js "3.6.5" + promise-polyfill "8.1.3" + whatwg-fetch "2.0.4" + +"@firebase/remote-config-types@0.1.9": + version "0.1.9" + resolved "https://registry.yarnpkg.com/@firebase/remote-config-types/-/remote-config-types-0.1.9.tgz#fe6bbe4d08f3b6e92fce30e4b7a9f4d6a96d6965" + integrity sha512-G96qnF3RYGbZsTRut7NBX0sxyczxt1uyCgXQuH/eAfUCngxjEGcZQnBdy6mvSdqdJh5mC31rWPO4v9/s7HwtzA== + +"@firebase/remote-config@0.1.28": + version "0.1.28" + resolved "https://registry.yarnpkg.com/@firebase/remote-config/-/remote-config-0.1.28.tgz#1c39916446f1ed82b4c07e556455bd232fcfd8e1" + integrity sha512-4zSdyxpt94jAnFhO8toNjG8oMKBD+xTuBIcK+Nw8BdQWeJhEamgXlupdBARUk1uf3AvYICngHH32+Si/dMVTbw== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/installations" "0.4.17" + "@firebase/logger" "0.2.6" + "@firebase/remote-config-types" "0.1.9" + "@firebase/util" "0.3.2" + tslib "^1.11.1" + +"@firebase/storage-types@0.3.13": + version "0.3.13" + resolved "https://registry.yarnpkg.com/@firebase/storage-types/-/storage-types-0.3.13.tgz#cd43e939a2ab5742e109eb639a313673a48b5458" + integrity sha512-pL7b8d5kMNCCL0w9hF7pr16POyKkb3imOW7w0qYrhBnbyJTdVxMWZhb0HxCFyQWC0w3EiIFFmxoz8NTFZDEFog== + +"@firebase/storage@0.3.43": + version "0.3.43" + resolved "https://registry.yarnpkg.com/@firebase/storage/-/storage-0.3.43.tgz#107fb5db2eff2561b5c4e35ee4cbff48f28c7e77" + integrity sha512-Jp54jcuyimLxPhZHFVAhNbQmgTu3Sda7vXjXrNpPEhlvvMSq4yuZBR6RrZxe/OrNVprLHh/6lTCjwjOVSo3bWA== + dependencies: + "@firebase/component" "0.1.19" + "@firebase/storage-types" "0.3.13" + "@firebase/util" "0.3.2" + tslib "^1.11.1" + +"@firebase/util@0.3.2": + version "0.3.2" + resolved "https://registry.yarnpkg.com/@firebase/util/-/util-0.3.2.tgz#87de27f9cffc2324651cabf6ec133d0a9eb21b52" + integrity sha512-Dqs00++c8rwKky6KCKLLY2T1qYO4Q+X5t+lF7DInXDNF4ae1Oau35bkD+OpJ9u7l1pEv7KHowP6CUKuySCOc8g== + dependencies: + tslib "^1.11.1" + +"@firebase/webchannel-wrapper@0.4.0": + version "0.4.0" + resolved "https://registry.yarnpkg.com/@firebase/webchannel-wrapper/-/webchannel-wrapper-0.4.0.tgz#becce788818d3f47f0ac1a74c3c061ac1dcf4f6d" + integrity sha512-8cUA/mg0S+BxIZ72TdZRsXKBP5n5uRcE3k29TZhZw6oIiHBt9JA7CTb/4pE1uKtE/q5NeTY2tBDcagoZ+1zjXQ== + +"@graphql-tools/batch-execute@8.5.1": + version "8.5.1" + resolved "https://registry.yarnpkg.com/@graphql-tools/batch-execute/-/batch-execute-8.5.1.tgz#fa3321d58c64041650be44250b1ebc3aab0ba7a9" + integrity sha512-hRVDduX0UDEneVyEWtc2nu5H2PxpfSfM/riUlgZvo/a/nG475uyehxR5cFGvTEPEQUKY3vGIlqvtRigzqTfCew== + dependencies: + "@graphql-tools/utils" "8.9.0" + dataloader "2.1.0" + tslib "^2.4.0" + value-or-promise "1.0.11" + +"@graphql-tools/delegate@^8.4.3": + version "8.8.1" + resolved "https://registry.yarnpkg.com/@graphql-tools/delegate/-/delegate-8.8.1.tgz#0653a72f38947f38ab7917dfac50ebf6a6b883e9" + integrity sha512-NDcg3GEQmdEHlnF7QS8b4lM1PSF+DKeFcIlLEfZFBvVq84791UtJcDj8734sIHLukmyuAxXMfA1qLd2l4lZqzA== + dependencies: + "@graphql-tools/batch-execute" "8.5.1" + "@graphql-tools/schema" "8.5.1" + "@graphql-tools/utils" "8.9.0" + dataloader "2.1.0" + tslib "~2.4.0" + value-or-promise "1.0.11" + +"@graphql-tools/merge@8.3.1": + version "8.3.1" + resolved "https://registry.yarnpkg.com/@graphql-tools/merge/-/merge-8.3.1.tgz#06121942ad28982a14635dbc87b5d488a041d722" + integrity sha512-BMm99mqdNZbEYeTPK3it9r9S6rsZsQKtlqJsSBknAclXq2pGEfOxjcIZi+kBSkHZKPKCRrYDd5vY0+rUmIHVLg== + dependencies: + "@graphql-tools/utils" "8.9.0" + tslib "^2.4.0" + +"@graphql-tools/merge@8.3.6": + version "8.3.6" + resolved "https://registry.yarnpkg.com/@graphql-tools/merge/-/merge-8.3.6.tgz#97a936d4c8e8f935e58a514bb516c476437b5b2c" + integrity sha512-uUBokxXi89bj08P+iCvQk3Vew4vcfL5ZM6NTylWi8PIpoq4r5nJ625bRuN8h2uubEdRiH8ntN9M4xkd/j7AybQ== + dependencies: + "@graphql-tools/utils" "8.12.0" + tslib "^2.4.0" + +"@graphql-tools/mock@^8.1.2": + version "8.7.6" + resolved "https://registry.yarnpkg.com/@graphql-tools/mock/-/mock-8.7.6.tgz#701d898f7fe6c22e40d6d80e25874e464359ce11" + integrity sha512-cQGPyY6dF4x28552zjAg9En2WWVury62u1/xzipCNUSCdKRVOsAupTNBcAGdMjsKPLcGzzk1cPA8dP0DUfNqzg== + dependencies: + "@graphql-tools/schema" "9.0.4" + "@graphql-tools/utils" "8.12.0" + fast-json-stable-stringify "^2.1.0" + tslib "^2.4.0" + +"@graphql-tools/schema@8.5.1", "@graphql-tools/schema@^8.0.0", "@graphql-tools/schema@^8.3.1": + version "8.5.1" + resolved "https://registry.yarnpkg.com/@graphql-tools/schema/-/schema-8.5.1.tgz#c2f2ff1448380919a330312399c9471db2580b58" + integrity sha512-0Esilsh0P/qYcB5DKQpiKeQs/jevzIadNTaT0jeWklPMwNbT7yMX4EqZany7mbeRRlSRwMzNzL5olyFdffHBZg== + dependencies: + "@graphql-tools/merge" "8.3.1" + "@graphql-tools/utils" "8.9.0" + tslib "^2.4.0" + value-or-promise "1.0.11" + +"@graphql-tools/schema@9.0.4": + version "9.0.4" + resolved "https://registry.yarnpkg.com/@graphql-tools/schema/-/schema-9.0.4.tgz#1a74608b57abf90fae6fd929d25e5482c57bc05d" + integrity sha512-B/b8ukjs18fq+/s7p97P8L1VMrwapYc3N2KvdG/uNThSazRRn8GsBK0Nr+FH+mVKiUfb4Dno79e3SumZVoHuOQ== + dependencies: + "@graphql-tools/merge" "8.3.6" + "@graphql-tools/utils" "8.12.0" + tslib "^2.4.0" + value-or-promise "1.0.11" + +"@graphql-tools/utils@8.12.0": + version "8.12.0" + resolved "https://registry.yarnpkg.com/@graphql-tools/utils/-/utils-8.12.0.tgz#243bc4f5fc2edbc9e8fd1038189e57d837cbe31f" + integrity sha512-TeO+MJWGXjUTS52qfK4R8HiPoF/R7X+qmgtOYd8DTH0l6b+5Y/tlg5aGeUJefqImRq7nvi93Ms40k/Uz4D5CWw== + dependencies: + tslib "^2.4.0" + +"@graphql-tools/utils@8.9.0": + version "8.9.0" + resolved "https://registry.yarnpkg.com/@graphql-tools/utils/-/utils-8.9.0.tgz#c6aa5f651c9c99e1aca55510af21b56ec296cdb7" + integrity sha512-pjJIWH0XOVnYGXCqej8g/u/tsfV4LvLlj0eATKQu5zwnxd/TiTHq7Cg313qUPTFFHZ3PP5wJ15chYVtLDwaymg== + dependencies: + tslib "^2.4.0" + +"@grpc/grpc-js@^1.0.0": + version "1.6.8" + resolved "https://registry.yarnpkg.com/@grpc/grpc-js/-/grpc-js-1.6.8.tgz#77cc8b2d841c34dea8b105d45ff1732caefae4f2" + integrity sha512-Nt5tufF/O5Q310kP0cDzxznWMZW58GCTZhUUiAQ9B0K0ANKNQ4Lj/K9XK0vZg+UBKq5/7z7+8mXHHfrcwoeFJQ== + dependencies: + "@grpc/proto-loader" "^0.7.0" + "@types/node" ">=12.12.47" + +"@grpc/proto-loader@^0.5.0": + version "0.5.6" + resolved "https://registry.yarnpkg.com/@grpc/proto-loader/-/proto-loader-0.5.6.tgz#1dea4b8a6412b05e2d58514d507137b63a52a98d" + integrity sha512-DT14xgw3PSzPxwS13auTEwxhMMOoz33DPUKNtmYK/QYbBSpLXJy78FGGs5yVoxVobEqPm4iW9MOIoz0A3bLTRQ== + dependencies: + lodash.camelcase "^4.3.0" + protobufjs "^6.8.6" + +"@grpc/proto-loader@^0.7.0": + version "0.7.0" + resolved "https://registry.yarnpkg.com/@grpc/proto-loader/-/proto-loader-0.7.0.tgz#743cc8a941cc251620c66ebe0d330e1411a33535" + integrity sha512-SGPZtVmqOvNfPFOA/nNPn+0Weqa5wubBgQ56+JgTbeLY2VezwtMjwPPFzh0kvQccwWT3a2TXT0ZGK/pJoOTk1A== + dependencies: + "@types/long" "^4.0.1" + lodash.camelcase "^4.3.0" + long "^4.0.0" + protobufjs "^7.0.0" + yargs "^16.2.0" + +"@harmony-js/account@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/account/-/account-0.1.56.tgz#74d008d199b81af6bd554a6cc455c882e85d61e7" + integrity sha512-VX3+NAirUxxowAc2QBuKEpHSN0XGYHqogYIf63XGFfg2BACS3RdN/tkJTzPPyIPejEKC3yDylm5c+8NzmsOjhQ== + dependencies: + "@harmony-js/core" "0.1.56" + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/staking" "0.1.56" + "@harmony-js/transaction" "0.1.56" + "@harmony-js/utils" "0.1.56" + +"@harmony-js/account@0.1.57": + version "0.1.57" + resolved "https://registry.yarnpkg.com/@harmony-js/account/-/account-0.1.57.tgz#d6e1e4955658ab25e89f512e12d9d9ecd28c738d" + integrity sha512-2Q0aX49m9IDDf9AvQHEgnxVBfvQ4wnXJqMo1y3g+9VuoyibNLFy/7GRwywwjrKTtfERXegTGHdZYo/CCO0PrpQ== + dependencies: + "@harmony-js/core" "0.1.57" + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/staking" "0.1.56" + "@harmony-js/transaction" "0.1.56" + "@harmony-js/utils" "0.1.56" + +"@harmony-js/contract@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/contract/-/contract-0.1.56.tgz#cfe8ffca6332008137f248d5bce59c4f3c5f22f3" + integrity sha512-4yKBjUtMkiaMvhwbEFps7qZV/NIWRgkJuO2yZYsqbkzdFf3eMXXrq60HpDZcWhNf+rsL0VpDso9i09mW+DDZJQ== + dependencies: + "@harmony-js/account" "0.1.56" + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/transaction" "0.1.56" + "@harmony-js/utils" "0.1.56" + +"@harmony-js/core@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/core/-/core-0.1.56.tgz#52c986c0ecfa881b57aaeb0448ae92d2d30c3f18" + integrity sha512-mYVIewX2oL0PHZJU64HD65M/QMA756d19MosATRqbfj8MLLgdMdTuXHF525NWDRxBiYlSh6BGSNJakNbtq8g3Q== + dependencies: + "@harmony-js/account" "0.1.56" + "@harmony-js/contract" "0.1.56" + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/staking" "0.1.56" + "@harmony-js/transaction" "0.1.56" + "@harmony-js/utils" "0.1.56" + +"@harmony-js/core@0.1.57", "@harmony-js/core@^0.1.57": + version "0.1.57" + resolved "https://registry.yarnpkg.com/@harmony-js/core/-/core-0.1.57.tgz#bf10eb017f0086868fa8aefab097894e7b36acb3" + integrity sha512-4d48MoR/3xabsoiV0fXjVwtL4u9AeNO72+UZWSZl2ZzrPvij2ucn14wvIZwCL69xJwD4bsqgy68Ju+DRLFVW3A== + dependencies: + "@harmony-js/account" "0.1.57" + "@harmony-js/contract" "0.1.56" + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/staking" "0.1.56" + "@harmony-js/transaction" "0.1.56" + "@harmony-js/utils" "0.1.56" + +"@harmony-js/crypto@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/crypto/-/crypto-0.1.56.tgz#62bdd850de8b98df6049bd2c43e096113852287d" + integrity sha512-JMOWte8d3HXO2b038MqQpZ6al6OHsB9aZTretuzijxwrOIOdPKu9sDNHhmyJhQTIOKqG2+gErlj9AclZbXGk5g== + dependencies: + "@harmony-js/utils" "0.1.56" + aes-js "^3.1.2" + bip39 "^2.5.0" + bn.js "^4.11.8" + elliptic "^6.4.1" + hdkey "^1.1.1" + hmac-drbg "^1.0.1" + js-sha3 "^0.8.0" + pbkdf2 "^3.0.17" + scrypt-shim "github:web3-js/scrypt-shim" + uuid "^3.3.2" + +"@harmony-js/network@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/network/-/network-0.1.56.tgz#86d08923d5963fb8ad15cb3beb85de045afd9969" + integrity sha512-ItwgvQPjcFyVKKa1mFAqRMno6yyp1cjM2UNIdHOHtWG+H8BgObcw2ZM4LJpAPVF/XSoaTcZZwfB2hD7zOFnnYQ== + dependencies: + "@harmony-js/utils" "0.1.56" + cross-fetch "^3.0.2" + mitt "^1.2.0" + websocket "^1.0.28" + +"@harmony-js/staking@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/staking/-/staking-0.1.56.tgz#34a0c873760b54f68c1301aa2567572d338b8810" + integrity sha512-i0tliihg/7llJNp3uMjW5NZjJzLGz9iIESA4ST/cD2yT3KeRviwmlQPVf4uZpxIlmGgtk/oR4tLPLzmZEgSTOw== + dependencies: + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/transaction" "0.1.56" + "@harmony-js/utils" "0.1.56" + text-encoding "^0.7.0" + +"@harmony-js/transaction@0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/transaction/-/transaction-0.1.56.tgz#6b68607ccd83b0d9c1871dbaf5bfdb5152203e7f" + integrity sha512-+eX1+xBGsi6aGMyeZf7cvd2gncItPPifP7Hyjh9wNxbpyxpgBLvVnhD8hGaUQ6MJ9xJkFeWfkQPduEQBsCZj7A== + dependencies: + "@harmony-js/crypto" "0.1.56" + "@harmony-js/network" "0.1.56" + "@harmony-js/utils" "0.1.56" + +"@harmony-js/utils@0.1.56", "@harmony-js/utils@^0.1.56": + version "0.1.56" + resolved "https://registry.yarnpkg.com/@harmony-js/utils/-/utils-0.1.56.tgz#89d77d07989ecfb5679776917f2b78b7b698c854" + integrity sha512-XoYYIMoK/mSxPkxFd25dY/wScIWWevoTrHoFdlFd8N7GWlilfdgQEF5vO+4BA6hyDJ4ryfdLnGc6W6Hz+5qs2A== + dependencies: + "@types/bn.js" "^4.11.3" + bn.js "^4.11.8" + +"@humanwhocodes/config-array@^0.5.0": + version "0.5.0" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.5.0.tgz#1407967d4c6eecd7388f83acf1eaf4d0c6e58ef9" + integrity sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg== + dependencies: + "@humanwhocodes/object-schema" "^1.2.0" + debug "^4.1.1" + minimatch "^3.0.4" + +"@humanwhocodes/object-schema@^1.2.0": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz#b520529ec21d8e5945a1851dfd1c32e94e39ff45" + integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== + +"@istanbuljs/load-nyc-config@^1.0.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz#fd3db1d59ecf7cf121e80650bb86712f9b55eced" + integrity sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ== + dependencies: + camelcase "^5.3.1" + find-up "^4.1.0" + get-package-type "^0.1.0" + js-yaml "^3.13.1" + resolve-from "^5.0.0" + +"@istanbuljs/schema@^0.1.2": + version "0.1.3" + resolved "https://registry.yarnpkg.com/@istanbuljs/schema/-/schema-0.1.3.tgz#e45e384e4b8ec16bce2fd903af78450f6bf7ec98" + integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA== + +"@jest/console@^24.9.0": + version "24.9.0" + resolved "https://registry.yarnpkg.com/@jest/console/-/console-24.9.0.tgz#79b1bc06fb74a8cfb01cbdedf945584b1b9707f0" + integrity sha512-Zuj6b8TnKXi3q4ymac8EQfc3ea/uhLeCGThFqXeC8H9/raaH8ARPUTdId+XyGd03Z4In0/VjD2OYFcBF09fNLQ== + dependencies: + "@jest/source-map" "^24.9.0" + chalk "^2.0.1" + slash "^2.0.0" + +"@jest/console@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/console/-/console-27.5.1.tgz#260fe7239602fe5130a94f1aa386eff54b014bba" + integrity sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg== + dependencies: + "@jest/types" "^27.5.1" + "@types/node" "*" + chalk "^4.0.0" + jest-message-util "^27.5.1" + jest-util "^27.5.1" + slash "^3.0.0" + +"@jest/core@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/core/-/core-27.5.1.tgz#267ac5f704e09dc52de2922cbf3af9edcd64b626" + integrity sha512-AK6/UTrvQD0Cd24NSqmIA6rKsu0tKIxfiCducZvqxYdmMisOYAsdItspT+fQDQYARPf8XgjAFZi0ogW2agH5nQ== + dependencies: + "@jest/console" "^27.5.1" + "@jest/reporters" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/transform" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + emittery "^0.8.1" + exit "^0.1.2" + graceful-fs "^4.2.9" + jest-changed-files "^27.5.1" + jest-config "^27.5.1" + jest-haste-map "^27.5.1" + jest-message-util "^27.5.1" + jest-regex-util "^27.5.1" + jest-resolve "^27.5.1" + jest-resolve-dependencies "^27.5.1" + jest-runner "^27.5.1" + jest-runtime "^27.5.1" + jest-snapshot "^27.5.1" + jest-util "^27.5.1" + jest-validate "^27.5.1" + jest-watcher "^27.5.1" + micromatch "^4.0.4" + rimraf "^3.0.0" + slash "^3.0.0" + strip-ansi "^6.0.0" + +"@jest/environment@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/environment/-/environment-27.5.1.tgz#d7425820511fe7158abbecc010140c3fd3be9c74" + integrity sha512-/WQjhPJe3/ghaol/4Bq480JKXV/Rfw8nQdN7f41fM8VDHLcxKXou6QyXAh3EFr9/bVG3x74z1NWDkP87EiY8gA== + dependencies: + "@jest/fake-timers" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + jest-mock "^27.5.1" + +"@jest/fake-timers@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-27.5.1.tgz#76979745ce0579c8a94a4678af7a748eda8ada74" + integrity sha512-/aPowoolwa07k7/oM3aASneNeBGCmGQsc3ugN4u6s4C/+s5M64MFo/+djTdiwcbQlRfFElGuDXWzaWj6QgKObQ== + dependencies: + "@jest/types" "^27.5.1" + "@sinonjs/fake-timers" "^8.0.1" + "@types/node" "*" + jest-message-util "^27.5.1" + jest-mock "^27.5.1" + jest-util "^27.5.1" + +"@jest/globals@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/globals/-/globals-27.5.1.tgz#7ac06ce57ab966566c7963431cef458434601b2b" + integrity sha512-ZEJNB41OBQQgGzgyInAv0UUfDDj3upmHydjieSxFvTRuZElrx7tXg/uVQ5hYVEwiXs3+aMsAeEc9X7xiSKCm4Q== + dependencies: + "@jest/environment" "^27.5.1" + "@jest/types" "^27.5.1" + expect "^27.5.1" + +"@jest/reporters@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/reporters/-/reporters-27.5.1.tgz#ceda7be96170b03c923c37987b64015812ffec04" + integrity sha512-cPXh9hWIlVJMQkVk84aIvXuBB4uQQmFqZiacloFuGiP3ah1sbCxCosidXFDfqG8+6fO1oR2dTJTlsOy4VFmUfw== + dependencies: + "@bcoe/v8-coverage" "^0.2.3" + "@jest/console" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/transform" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + chalk "^4.0.0" + collect-v8-coverage "^1.0.0" + exit "^0.1.2" + glob "^7.1.2" + graceful-fs "^4.2.9" + istanbul-lib-coverage "^3.0.0" + istanbul-lib-instrument "^5.1.0" + istanbul-lib-report "^3.0.0" + istanbul-lib-source-maps "^4.0.0" + istanbul-reports "^3.1.3" + jest-haste-map "^27.5.1" + jest-resolve "^27.5.1" + jest-util "^27.5.1" + jest-worker "^27.5.1" + slash "^3.0.0" + source-map "^0.6.0" + string-length "^4.0.1" + terminal-link "^2.0.0" + v8-to-istanbul "^8.1.0" + +"@jest/source-map@^24.9.0": + version "24.9.0" + resolved "https://registry.yarnpkg.com/@jest/source-map/-/source-map-24.9.0.tgz#0e263a94430be4b41da683ccc1e6bffe2a191714" + integrity sha512-/Xw7xGlsZb4MJzNDgB7PW5crou5JqWiBQaz6xyPd3ArOg2nfn/PunV8+olXbbEZzNl591o5rWKE9BRDaFAuIBg== + dependencies: + callsites "^3.0.0" + graceful-fs "^4.1.15" + source-map "^0.6.0" + +"@jest/source-map@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/source-map/-/source-map-27.5.1.tgz#6608391e465add4205eae073b55e7f279e04e8cf" + integrity sha512-y9NIHUYF3PJRlHk98NdC/N1gl88BL08aQQgu4k4ZopQkCw9t9cV8mtl3TV8b/YCB8XaVTFrmUTAJvjsntDireg== + dependencies: + callsites "^3.0.0" + graceful-fs "^4.2.9" + source-map "^0.6.0" + +"@jest/test-result@^24.9.0": + version "24.9.0" + resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-24.9.0.tgz#11796e8aa9dbf88ea025757b3152595ad06ba0ca" + integrity sha512-XEFrHbBonBJ8dGp2JmF8kP/nQI/ImPpygKHwQ/SY+es59Z3L5PI4Qb9TQQMAEeYsThG1xF0k6tmG0tIKATNiiA== + dependencies: + "@jest/console" "^24.9.0" + "@jest/types" "^24.9.0" + "@types/istanbul-lib-coverage" "^2.0.0" + +"@jest/test-result@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-27.5.1.tgz#56a6585fa80f7cdab72b8c5fc2e871d03832f5bb" + integrity sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag== + dependencies: + "@jest/console" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/istanbul-lib-coverage" "^2.0.0" + collect-v8-coverage "^1.0.0" + +"@jest/test-sequencer@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/test-sequencer/-/test-sequencer-27.5.1.tgz#4057e0e9cea4439e544c6353c6affe58d095745b" + integrity sha512-LCheJF7WB2+9JuCS7VB/EmGIdQuhtqjRNI9A43idHv3E4KltCTsPsLxvdaubFHSYwY/fNjMWjl6vNRhDiN7vpQ== + dependencies: + "@jest/test-result" "^27.5.1" + graceful-fs "^4.2.9" + jest-haste-map "^27.5.1" + jest-runtime "^27.5.1" + +"@jest/transform@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-27.5.1.tgz#6c3501dcc00c4c08915f292a600ece5ecfe1f409" + integrity sha512-ipON6WtYgl/1329g5AIJVbUuEh0wZVbdpGwC99Jw4LwuoBNS95MVphU6zOeD9pDkon+LLbFL7lOQRapbB8SCHw== + dependencies: + "@babel/core" "^7.1.0" + "@jest/types" "^27.5.1" + babel-plugin-istanbul "^6.1.1" + chalk "^4.0.0" + convert-source-map "^1.4.0" + fast-json-stable-stringify "^2.0.0" + graceful-fs "^4.2.9" + jest-haste-map "^27.5.1" + jest-regex-util "^27.5.1" + jest-util "^27.5.1" + micromatch "^4.0.4" + pirates "^4.0.4" + slash "^3.0.0" + source-map "^0.6.1" + write-file-atomic "^3.0.0" + +"@jest/types@^24.9.0": + version "24.9.0" + resolved "https://registry.yarnpkg.com/@jest/types/-/types-24.9.0.tgz#63cb26cb7500d069e5a389441a7c6ab5e909fc59" + integrity sha512-XKK7ze1apu5JWQ5eZjHITP66AX+QsLlbaJRBGYr8pNzwcAE2JVkwnf0yqjHTsDRcjR0mujy/NmZMXw5kl+kGBw== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.0" + "@types/istanbul-reports" "^1.1.1" + "@types/yargs" "^13.0.0" + +"@jest/types@^27.5.1": + version "27.5.1" + resolved "https://registry.yarnpkg.com/@jest/types/-/types-27.5.1.tgz#3c79ec4a8ba61c170bf937bcf9e98a9df175ec80" + integrity sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.0" + "@types/istanbul-reports" "^3.0.0" + "@types/node" "*" + "@types/yargs" "^16.0.0" + chalk "^4.0.0" + +"@josephg/resolvable@^1.0.0": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@josephg/resolvable/-/resolvable-1.0.1.tgz#69bc4db754d79e1a2f17a650d3466e038d94a5eb" + integrity sha512-CtzORUwWTTOTqfVtHaKRJ0I1kNQd1bpn3sUh8I3nJDVY+5/M/Oe1DnEWzPQvqq/xPIIkzzzIP7mfCoAjFRvDhg== + +"@jridgewell/gen-mapping@^0.1.0": + version "0.1.1" + resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz#e5d2e450306a9491e3bd77e323e38d7aff315996" + integrity sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w== + dependencies: + "@jridgewell/set-array" "^1.0.0" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@jridgewell/gen-mapping@^0.3.2": + version "0.3.2" + resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz#c1aedc61e853f2bb9f5dfe6d4442d3b565b253b9" + integrity sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A== + dependencies: + "@jridgewell/set-array" "^1.0.1" + "@jridgewell/sourcemap-codec" "^1.4.10" + "@jridgewell/trace-mapping" "^0.3.9" + +"@jridgewell/resolve-uri@^3.0.3": + version "3.1.0" + resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz#2203b118c157721addfe69d47b70465463066d78" + integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w== + +"@jridgewell/set-array@^1.0.0", "@jridgewell/set-array@^1.0.1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@jridgewell/set-array/-/set-array-1.1.2.tgz#7c6cf998d6d20b914c0a55a91ae928ff25965e72" + integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw== + +"@jridgewell/sourcemap-codec@^1.4.10": + version "1.4.14" + resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz#add4c98d341472a289190b424efbdb096991bb24" + integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw== + +"@jridgewell/trace-mapping@0.3.9": + version "0.3.9" + resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz#6534fd5933a53ba7cbf3a17615e273a0d1273ff9" + integrity sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ== + dependencies: + "@jridgewell/resolve-uri" "^3.0.3" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@jridgewell/trace-mapping@^0.3.9": + version "0.3.14" + resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz#b231a081d8f66796e475ad588a1ef473112701ed" + integrity sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ== + dependencies: + "@jridgewell/resolve-uri" "^3.0.3" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@metamask/eth-sig-util@^4.0.0": + version "4.0.1" + resolved "https://registry.yarnpkg.com/@metamask/eth-sig-util/-/eth-sig-util-4.0.1.tgz#3ad61f6ea9ad73ba5b19db780d40d9aae5157088" + integrity sha512-tghyZKLHZjcdlDqCA3gNZmLeR0XvOE9U1qoQO9ohyAZT6Pya+H9vkBPcsyXytmYLNgVoin7CKCmweo/R43V+tQ== + dependencies: + ethereumjs-abi "^0.6.8" + ethereumjs-util "^6.2.1" + ethjs-util "^0.1.6" + tweetnacl "^1.0.3" + tweetnacl-util "^0.15.1" + +"@mrmlnc/readdir-enhanced@^2.2.1": + version "2.2.1" + resolved "https://registry.yarnpkg.com/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz#524af240d1a360527b730475ecfa1344aa540dde" + integrity sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g== + dependencies: + call-me-maybe "^1.0.1" + glob-to-regexp "^0.3.0" + +"@noble/hashes@1.1.2", "@noble/hashes@~1.1.1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.1.2.tgz#e9e035b9b166ca0af657a7848eb2718f0f22f183" + integrity sha512-KYRCASVTv6aeUi1tsF8/vpyR7zpfs3FUzy2Jqm+MU+LmUKhQ0y2FpfwqkCcxSg2ua4GALJd8k2R76WxwZGbQpA== + +"@noble/hashes@^1", "@noble/hashes@^1.0.0": + version "1.1.4" + resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.1.4.tgz#2611ebf5764c1bf754da7c7794de4fb30512336d" + integrity sha512-+PYsVPrTSqtVjatKt2A/Proukn2Yrz61OBThOCKErc5w2/r1Fh37vbDv0Eah7pyNltrmacjwTvdw3JoR+WE4TA== + +"@noble/secp256k1@1.6.3", "@noble/secp256k1@~1.6.0": + version "1.6.3" + resolved "https://registry.yarnpkg.com/@noble/secp256k1/-/secp256k1-1.6.3.tgz#7eed12d9f4404b416999d0c87686836c4c5c9b94" + integrity sha512-T04e4iTurVy7I8Sw4+c5OSN9/RkPlo1uKxAomtxQNLq8j1uPAqnsqG1bqvY3Jv7c13gyr6dui0zmh/I3+f/JaQ== + +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== + +"@nodelib/fs.stat@^1.1.2": + version "1.1.3" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz#2b5a3ab3f918cca48a8c754c08168e3f03eba61b" + integrity sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw== + +"@nodelib/fs.walk@^1.2.3": + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== + dependencies: + "@nodelib/fs.scandir" "2.1.5" + fastq "^1.6.0" + +"@nomiclabs/hardhat-ethers@^2.0.6": + version "2.1.0" + resolved "https://registry.yarnpkg.com/@nomiclabs/hardhat-ethers/-/hardhat-ethers-2.1.0.tgz#9b7dc94d669ad9dc286b94f6f2f1513118c7027b" + integrity sha512-vlW90etB3675QWG7tMrHaDoTa7ymMB7irM4DAQ98g8zJoe9YqEggeDnbO6v5b+BLth/ty4vN6Ko/kaqRN1krHw== + +"@openzeppelin/cli@^2.8.2": + version "2.8.2" + resolved "https://registry.yarnpkg.com/@openzeppelin/cli/-/cli-2.8.2.tgz#b569c55f8c291ac4c7a16ca1b584ee2b4063a7f2" + integrity sha512-K0m1UAywnweAwzbwwmqI+JSezDRnqDRWkKQMI2VV6T03LOXcG/L9oqO9KRORI8md+KbxBW9v5rmNV63wGQIRlA== + dependencies: + "@openzeppelin/fuzzy-solidity-import-parser" "^0.1.2" + "@openzeppelin/upgrades" "2.8.0" + "@types/fs-extra" "^7.0.0" + "@types/npm" "^2.0.29" + "@types/semver" "^5.5.0" + ajv "^6.10.0" + axios "^0.18.0" + bignumber.js "^8.0.2" + chalk "^2.4.1" + cheerio "^1.0.0-rc.2" + commander "^2.15.1" + env-paths "^2.2.0" + ethereumjs-util "^6.1.0" + find-up "^3.0.0" + firebase "^7.8.0" + fs-extra "^7.0.1" + glob "^7.1.6" + inquirer "^6.4.1" + is-url "^1.2.4" + lockfile "^1.0.4" + npm-programmatic "0.0.12" + rlp "^2.2.3" + semver "^5.5.0" + simple-git "^1.110.0" + solc-wrapper "^0.6.3" + spinnies "^0.3.0" + toposort "^2.0.2" + truffle-config "1.1.16" + ts-generator "^0.0.8" + typechain "^1.0.3" + typechain-target-truffle "^1.0.1" + typechain-target-web3-v1 "^1.0.1" + underscore "^1.9.1" + uuid "^3.3.3" + web3 "1.2.2" + web3-eth "1.2.2" + web3-eth-contract "1.2.2" + web3-utils "1.2.2" + +"@openzeppelin/contracts@3.4.1-solc-0.7-2": + version "3.4.1-solc-0.7-2" + resolved "https://registry.yarnpkg.com/@openzeppelin/contracts/-/contracts-3.4.1-solc-0.7-2.tgz#371c67ebffe50f551c3146a9eec5fe6ffe862e92" + integrity sha512-tAG9LWg8+M2CMu7hIsqHPaTyG4uDzjr6mhvH96LvOpLZZj6tgzTluBt+LsCf1/QaYrlis6pITvpIaIhE+iZB+Q== + +"@openzeppelin/contracts@3.4.2-solc-0.7": + version "3.4.2-solc-0.7" + resolved "https://registry.yarnpkg.com/@openzeppelin/contracts/-/contracts-3.4.2-solc-0.7.tgz#38f4dbab672631034076ccdf2f3201fab1726635" + integrity sha512-W6QmqgkADuFcTLzHL8vVoNBtkwjvQRpYIAom7KiUNoLKghyx3FgH0GBjt8NRvigV1ZmMOBllvE1By1C+bi8WpA== + +"@openzeppelin/fuzzy-solidity-import-parser@^0.1.2": + version "0.1.2" + resolved "https://registry.yarnpkg.com/@openzeppelin/fuzzy-solidity-import-parser/-/fuzzy-solidity-import-parser-0.1.2.tgz#3b9f524d6028ca73df60474a313e0295e5610c51" + integrity sha512-leqEwfs8GlrPDrVcVc8Hv6LJ62ZzR0RgjwQNCkpT6H5jW9RB8YdR0a3inHoricSvw+sKI1b1hOqsCtPPZNnhng== + +"@openzeppelin/upgrades@2.8.0": + version "2.8.0" + resolved "https://registry.yarnpkg.com/@openzeppelin/upgrades/-/upgrades-2.8.0.tgz#8086ab9c99d9f8dac7205030b0f9e7e4a280c4a3" + integrity sha512-LzjTQPeljPsgHDPdZyH9cMCbIHZILgd2cpNcYEkdsC2IylBYRHShlbEDXJV9snnqg9JWfzPiKIqyj3XVliwtqQ== + dependencies: + "@types/cbor" "^2.0.0" + axios "^0.18.0" + bignumber.js "^7.2.0" + cbor "^4.1.5" + chalk "^2.4.1" + ethers "^4.0.20" + glob "^7.1.3" + lodash "^4.17.15" + semver "^5.5.1" + spinnies "^0.4.2" + truffle-flattener "^1.4.0" + web3 "1.2.2" + web3-eth "1.2.2" + web3-eth-contract "1.2.2" + web3-utils "1.2.2" + +"@pancakeswap-libs/pancake-swap-core@^0.1.0": + version "0.1.0" + resolved "https://registry.yarnpkg.com/@pancakeswap-libs/pancake-swap-core/-/pancake-swap-core-0.1.0.tgz#6957f1fa02170531a2ffbf95f2c0e145e9d21bc2" + integrity sha512-2jYiD1Ec3xAbP4JTa/Ozylx0xI4VwC7diCm5ak4AtGrIRhfRLSanaZSQdVpLigUnIFszma/4nVWtt3cup4Poxw== + dependencies: + truffle "^5.1.41" + truffle-flattener "^1.4.4" + truffle-hdwallet-provider "^1.0.17" + +"@pancakeswap/sdk@^2.4.5": + version "2.4.5" + resolved "https://registry.yarnpkg.com/@pancakeswap/sdk/-/sdk-2.4.5.tgz#783c02efc7ca89d2297b0b07040639d90c3e610d" + integrity sha512-qfHOPGXitDQ5y1dmYloe6UQe/0Ki0enow4MLtr5W49Jl7ZXr8oB6XV7usYtT63R7vqLSKY83rd8Wyw18vxP7dA== + dependencies: + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.4" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@pangolindex/exchange-contracts@^1.0.1": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@pangolindex/exchange-contracts/-/exchange-contracts-1.0.2.tgz#2d5be49d9e63a311cb3c2de53b21815923b3a996" + integrity sha512-G0imyN39C/vGX1VT/dn5do9SB8rJjRViT4p76KbseKNZ2wPChtFsz6yRFkqEJjeDRvqhBk7TZZlPGcbNvz/mBA== + dependencies: + hardhat-tracer "^1.0.0-alpha.5" + +"@pangolindex/sdk@^1.1.0": + version "1.5.0" + resolved "https://registry.yarnpkg.com/@pangolindex/sdk/-/sdk-1.5.0.tgz#5b51d76775b2e6fc23aa82264dea291fc12fbd8a" + integrity sha512-b/OLh0wGygl/6unrlJ1VtzepV9DpeNz/ifNVsQOkDUZFlGQT3Gv6DvSXWJelYKPUSK24ZPoNXbu0bvqHfnjhIg== + dependencies: + "@pangolindex/exchange-contracts" "^1.0.1" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.1" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@perp/curie-deployments@2022.10.5-1664940982527": + version "2022.10.5-1664940982527" + resolved "https://registry.yarnpkg.com/@perp/curie-deployments/-/curie-deployments-2022.10.5-1664940982527.tgz#ce191ad969b9e88a939fcae8409968d41665b0c2" + integrity sha512-07fv7vu8okF/9GevvOKoeUhOJqQNPAvOSdLj1DBffPtuq/dnUfP5Ck/CJopIm+FjRJVer8VX3Nx7IdQEo/nhBw== + +"@perp/sdk-curie@^1.16.0": + version "1.16.0" + resolved "https://registry.yarnpkg.com/@perp/sdk-curie/-/sdk-curie-1.16.0.tgz#a1de23339865648d901fb515822ee90567d67c85" + integrity sha512-MNaA2AkLdjm9tLTHuElxytbc43vcVBGLqM8TDtLMpvcMv3ALPp4l30hxF0LuEhGm2zvWB/9s1FDLpuM23Mbrbw== + dependencies: + "@perp/curie-deployments" "2022.10.5-1664940982527" + cross-fetch "3.1.5" + exponential-backoff "3.1.0" + +"@project-serum/anchor@^0.11.1": + version "0.11.1" + resolved "https://registry.yarnpkg.com/@project-serum/anchor/-/anchor-0.11.1.tgz#155bff2c70652eafdcfd5559c81a83bb19cec9ff" + integrity sha512-oIdm4vTJkUy6GmE6JgqDAuQPKI7XM4TPJkjtoIzp69RZe0iAD9JP2XHx7lV1jLdYXeYHqDXfBt3zcq7W91K6PA== + dependencies: + "@project-serum/borsh" "^0.2.2" + "@solana/web3.js" "^1.17.0" + base64-js "^1.5.1" + bn.js "^5.1.2" + bs58 "^4.0.1" + buffer-layout "^1.2.0" + camelcase "^5.3.1" + crypto-hash "^1.3.0" + eventemitter3 "^4.0.7" + find "^0.3.0" + js-sha256 "^0.9.0" + pako "^2.0.3" + snake-case "^3.0.4" + toml "^3.0.0" + +"@project-serum/anchor@^0.21.0": + version "0.21.0" + resolved "https://registry.yarnpkg.com/@project-serum/anchor/-/anchor-0.21.0.tgz#ad5fb33744991ec1900cdb2fd22707c908b12b5f" + integrity sha512-flRuW/F+iC8mitNokx82LOXyND7Dyk6n5UUPJpQv/+NfySFrNFlzuQZaBZJ4CG5g9s8HS/uaaIz1nVkDR8V/QA== + dependencies: + "@project-serum/borsh" "^0.2.4" + "@solana/web3.js" "^1.17.0" + base64-js "^1.5.1" + bn.js "^5.1.2" + bs58 "^4.0.1" + buffer-layout "^1.2.2" + camelcase "^5.3.1" + cross-fetch "^3.1.5" + crypto-hash "^1.3.0" + eventemitter3 "^4.0.7" + find "^0.3.0" + js-sha256 "^0.9.0" + pako "^2.0.3" + snake-case "^3.0.4" + toml "^3.0.0" + +"@project-serum/borsh@^0.2.2", "@project-serum/borsh@^0.2.4": + version "0.2.5" + resolved "https://registry.yarnpkg.com/@project-serum/borsh/-/borsh-0.2.5.tgz#6059287aa624ecebbfc0edd35e4c28ff987d8663" + integrity sha512-UmeUkUoKdQ7rhx6Leve1SssMR/Ghv8qrEiyywyxSWg7ooV7StdpPBhciiy5eB3T0qU1BXvdRNC8TdrkxK7WC5Q== + dependencies: + bn.js "^5.1.2" + buffer-layout "^1.2.0" + +"@project-serum/serum@^0.13.65": + version "0.13.65" + resolved "https://registry.yarnpkg.com/@project-serum/serum/-/serum-0.13.65.tgz#6d3cf07912f13985765237f053cca716fe84b0b0" + integrity sha512-BHRqsTqPSfFB5p+MgI2pjvMBAQtO8ibTK2fYY96boIFkCI3TTwXDt2gUmspeChKO2pqHr5aKevmexzAcXxrSRA== + dependencies: + "@project-serum/anchor" "^0.11.1" + "@solana/spl-token" "^0.1.6" + "@solana/web3.js" "^1.21.0" + bn.js "^5.1.2" + buffer-layout "^1.2.0" + +"@project-serum/sol-wallet-adapter@^0.2.0": + version "0.2.6" + resolved "https://registry.yarnpkg.com/@project-serum/sol-wallet-adapter/-/sol-wallet-adapter-0.2.6.tgz#b4cd25a566294354427c97c26d716112b91a0107" + integrity sha512-cpIb13aWPW8y4KzkZAPDgw+Kb+DXjCC6rZoH74MGm3I/6e/zKyGnfAuW5olb2zxonFqsYgnv7ev8MQnvSgJ3/g== + dependencies: + bs58 "^4.0.1" + eventemitter3 "^4.0.7" + +"@protobufjs/aspromise@^1.1.1", "@protobufjs/aspromise@^1.1.2": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@protobufjs/aspromise/-/aspromise-1.1.2.tgz#9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf" + integrity sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ== + +"@protobufjs/base64@^1.1.2": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@protobufjs/base64/-/base64-1.1.2.tgz#4c85730e59b9a1f1f349047dbf24296034bb2735" + integrity sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg== + +"@protobufjs/codegen@^2.0.4": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@protobufjs/codegen/-/codegen-2.0.4.tgz#7ef37f0d010fb028ad1ad59722e506d9262815cb" + integrity sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg== + +"@protobufjs/eventemitter@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz#355cbc98bafad5978f9ed095f397621f1d066b70" + integrity sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q== + +"@protobufjs/fetch@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@protobufjs/fetch/-/fetch-1.1.0.tgz#ba99fb598614af65700c1619ff06d454b0d84c45" + integrity sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ== + dependencies: + "@protobufjs/aspromise" "^1.1.1" + "@protobufjs/inquire" "^1.1.0" + +"@protobufjs/float@^1.0.2": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@protobufjs/float/-/float-1.0.2.tgz#5e9e1abdcb73fc0a7cb8b291df78c8cbd97b87d1" + integrity sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ== + +"@protobufjs/inquire@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@protobufjs/inquire/-/inquire-1.1.0.tgz#ff200e3e7cf2429e2dcafc1140828e8cc638f089" + integrity sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q== + +"@protobufjs/path@^1.1.2": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@protobufjs/path/-/path-1.1.2.tgz#6cc2b20c5c9ad6ad0dccfd21ca7673d8d7fbf68d" + integrity sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA== + +"@protobufjs/pool@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@protobufjs/pool/-/pool-1.1.0.tgz#09fd15f2d6d3abfa9b65bc366506d6ad7846ff54" + integrity sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw== + +"@protobufjs/utf8@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@protobufjs/utf8/-/utf8-1.1.0.tgz#a777360b5b39a1a2e5106f8e858f2fd2d060c570" + integrity sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw== + +"@redux-saga/core@^1.0.0": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@redux-saga/core/-/core-1.2.1.tgz#3680989621517d075a2cc85e0d2744b682990ed8" + integrity sha512-ABCxsZy9DwmNoYNo54ZlfuTvh77RXx8ODKpxOHeWam2dOaLGQ7vAktpfOtqSeTdYrKEORtTeWnxkGJMmPOoukg== + dependencies: + "@babel/runtime" "^7.6.3" + "@redux-saga/deferred" "^1.2.1" + "@redux-saga/delay-p" "^1.2.1" + "@redux-saga/is" "^1.1.3" + "@redux-saga/symbols" "^1.1.3" + "@redux-saga/types" "^1.2.1" + redux "^4.0.4" + typescript-tuple "^2.2.1" + +"@redux-saga/deferred@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@redux-saga/deferred/-/deferred-1.2.1.tgz#aca373a08ccafd6f3481037f2f7ee97f2c87c3ec" + integrity sha512-cmin3IuuzMdfQjA0lG4B+jX+9HdTgHZZ+6u3jRAOwGUxy77GSlTi4Qp2d6PM1PUoTmQUR5aijlA39scWWPF31g== + +"@redux-saga/delay-p@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@redux-saga/delay-p/-/delay-p-1.2.1.tgz#e72ac4731c5080a21f75b61bedc31cb639d9e446" + integrity sha512-MdiDxZdvb1m+Y0s4/hgdcAXntpUytr9g0hpcOO1XFVyyzkrDu3SKPgBFOtHn7lhu7n24ZKIAT1qtKyQjHqRd+w== + dependencies: + "@redux-saga/symbols" "^1.1.3" + +"@redux-saga/is@^1.1.3": + version "1.1.3" + resolved "https://registry.yarnpkg.com/@redux-saga/is/-/is-1.1.3.tgz#b333f31967e87e32b4e6b02c75b78d609dd4ad73" + integrity sha512-naXrkETG1jLRfVfhOx/ZdLj0EyAzHYbgJWkXbB3qFliPcHKiWbv/ULQryOAEKyjrhiclmr6AMdgsXFyx7/yE6Q== + dependencies: + "@redux-saga/symbols" "^1.1.3" + "@redux-saga/types" "^1.2.1" + +"@redux-saga/symbols@^1.1.3": + version "1.1.3" + resolved "https://registry.yarnpkg.com/@redux-saga/symbols/-/symbols-1.1.3.tgz#b731d56201719e96dc887dc3ae9016e761654367" + integrity sha512-hCx6ZvU4QAEUojETnX8EVg4ubNLBFl1Lps4j2tX7o45x/2qg37m3c6v+kSp8xjDJY+2tJw4QB3j8o8dsl1FDXg== + +"@redux-saga/types@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@redux-saga/types/-/types-1.2.1.tgz#9403f51c17cae37edf870c6bc0c81c1ece5ccef8" + integrity sha512-1dgmkh+3so0+LlBWRhGA33ua4MYr7tUOj+a9Si28vUi0IUFNbff1T3sgpeDJI/LaC75bBYnQ0A3wXjn0OrRNBA== + +"@resolver-engine/core@^0.2.1": + version "0.2.1" + resolved "https://registry.yarnpkg.com/@resolver-engine/core/-/core-0.2.1.tgz#0d71803f6d3b8cb2e9ed481a1bf0ca5f5256d0c0" + integrity sha512-nsLQHmPJ77QuifqsIvqjaF5B9aHnDzJjp73Q1z6apY3e9nqYrx4Dtowhpsf7Jwftg/XzVDEMQC+OzUBNTS+S1A== + dependencies: + debug "^3.1.0" + request "^2.85.0" + +"@resolver-engine/fs@^0.2.1": + version "0.2.1" + resolved "https://registry.yarnpkg.com/@resolver-engine/fs/-/fs-0.2.1.tgz#f98a308d77568cc02651d03636f46536b941b241" + integrity sha512-7kJInM1Qo2LJcKyDhuYzh9ZWd+mal/fynfL9BNjWOiTcOpX+jNfqb/UmGUqros5pceBITlWGqS4lU709yHFUbg== + dependencies: + "@resolver-engine/core" "^0.2.1" + debug "^3.1.0" + +"@resolver-engine/imports-fs@^0.2.2": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@resolver-engine/imports-fs/-/imports-fs-0.2.2.tgz#5a81ef3285dbf0411ab3b15205080a1ad7622d9e" + integrity sha512-gFCgMvCwyppjwq0UzIjde/WI+yDs3oatJhozG9xdjJdewwtd7LiF0T5i9lrHAUtqrQbqoFE4E+ZMRVHWpWHpKQ== + dependencies: + "@resolver-engine/fs" "^0.2.1" + "@resolver-engine/imports" "^0.2.2" + debug "^3.1.0" + +"@resolver-engine/imports@^0.2.2": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@resolver-engine/imports/-/imports-0.2.2.tgz#d3de55a1bb5f3beb7703fdde743298f321175843" + integrity sha512-u5/HUkvo8q34AA+hnxxqqXGfby5swnH0Myw91o3Sm2TETJlNKXibFGSKBavAH+wvWdBi4Z5gS2Odu0PowgVOUg== + dependencies: + "@resolver-engine/core" "^0.2.1" + debug "^3.1.0" + hosted-git-info "^2.6.0" + +"@scure/base@~1.1.0": + version "1.1.1" + resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.1.tgz#ebb651ee52ff84f420097055f4bf46cfba403938" + integrity sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA== + +"@scure/bip32@1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.1.0.tgz#dea45875e7fbc720c2b4560325f1cf5d2246d95b" + integrity sha512-ftTW3kKX54YXLCxH6BB7oEEoJfoE2pIgw7MINKAs5PsS6nqKPuKk1haTF/EuHmYqG330t5GSrdmtRuHaY1a62Q== + dependencies: + "@noble/hashes" "~1.1.1" + "@noble/secp256k1" "~1.6.0" + "@scure/base" "~1.1.0" + +"@scure/bip39@1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.1.0.tgz#92f11d095bae025f166bef3defcc5bf4945d419a" + integrity sha512-pwrPOS16VeTKg98dYXQyIjJEcWfz7/1YJIwxUEPFfQPtc86Ym/1sVgQ2RLoD43AazMk2l/unK4ITySSpW2+82w== + dependencies: + "@noble/hashes" "~1.1.1" + "@scure/base" "~1.1.0" + +"@sentry/core@5.30.0": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/core/-/core-5.30.0.tgz#6b203664f69e75106ee8b5a2fe1d717379b331f3" + integrity sha512-TmfrII8w1PQZSZgPpUESqjB+jC6MvZJZdLtE/0hZ+SrnKhW3x5WlYLvTXZpcWePYBku7rl2wn1RZu6uT0qCTeg== + dependencies: + "@sentry/hub" "5.30.0" + "@sentry/minimal" "5.30.0" + "@sentry/types" "5.30.0" + "@sentry/utils" "5.30.0" + tslib "^1.9.3" + +"@sentry/hub@5.30.0": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/hub/-/hub-5.30.0.tgz#2453be9b9cb903404366e198bd30c7ca74cdc100" + integrity sha512-2tYrGnzb1gKz2EkMDQcfLrDTvmGcQPuWxLnJKXJvYTQDGLlEvi2tWz1VIHjunmOvJrB5aIQLhm+dcMRwFZDCqQ== + dependencies: + "@sentry/types" "5.30.0" + "@sentry/utils" "5.30.0" + tslib "^1.9.3" + +"@sentry/minimal@5.30.0": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/minimal/-/minimal-5.30.0.tgz#ce3d3a6a273428e0084adcb800bc12e72d34637b" + integrity sha512-BwWb/owZKtkDX+Sc4zCSTNcvZUq7YcH3uAVlmh/gtR9rmUvbzAA3ewLuB3myi4wWRAMEtny6+J/FN/x+2wn9Xw== + dependencies: + "@sentry/hub" "5.30.0" + "@sentry/types" "5.30.0" + tslib "^1.9.3" + +"@sentry/node@^5.18.1": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/node/-/node-5.30.0.tgz#4ca479e799b1021285d7fe12ac0858951c11cd48" + integrity sha512-Br5oyVBF0fZo6ZS9bxbJZG4ApAjRqAnqFFurMVJJdunNb80brh7a5Qva2kjhm+U6r9NJAB5OmDyPkA1Qnt+QVg== + dependencies: + "@sentry/core" "5.30.0" + "@sentry/hub" "5.30.0" + "@sentry/tracing" "5.30.0" + "@sentry/types" "5.30.0" + "@sentry/utils" "5.30.0" + cookie "^0.4.1" + https-proxy-agent "^5.0.0" + lru_map "^0.3.3" + tslib "^1.9.3" + +"@sentry/tracing@5.30.0": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/tracing/-/tracing-5.30.0.tgz#501d21f00c3f3be7f7635d8710da70d9419d4e1f" + integrity sha512-dUFowCr0AIMwiLD7Fs314Mdzcug+gBVo/+NCMyDw8tFxJkwWAKl7Qa2OZxLQ0ZHjakcj1hNKfCQJ9rhyfOl4Aw== + dependencies: + "@sentry/hub" "5.30.0" + "@sentry/minimal" "5.30.0" + "@sentry/types" "5.30.0" + "@sentry/utils" "5.30.0" + tslib "^1.9.3" + +"@sentry/types@5.30.0": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/types/-/types-5.30.0.tgz#19709bbe12a1a0115bc790b8942917da5636f402" + integrity sha512-R8xOqlSTZ+htqrfteCWU5Nk0CDN5ApUTvrlvBuiH1DyP6czDZ4ktbZB0hAgBlVcK0U+qpD3ag3Tqqpa5Q67rPw== + +"@sentry/utils@5.30.0": + version "5.30.0" + resolved "https://registry.yarnpkg.com/@sentry/utils/-/utils-5.30.0.tgz#9a5bd7ccff85ccfe7856d493bffa64cabc41e980" + integrity sha512-zaYmoH0NWWtvnJjC9/CBseXMtKHm/tm40sz3YfJRxeQjyzRqNQPgivpd9R/oDJCYj999mzdW382p/qi2ypjLww== + dependencies: + "@sentry/types" "5.30.0" + tslib "^1.9.3" + +"@sindresorhus/is@^0.14.0": + version "0.14.0" + resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.14.0.tgz#9fb3a3cf3132328151f353de4632e01e52102bea" + integrity sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ== + +"@sindresorhus/is@^4.6.0": + version "4.6.0" + resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-4.6.0.tgz#3c7c9c46e678feefe7a2e5bb609d3dbd665ffb3f" + integrity sha512-t09vSN3MdfsyCHoFcTRCH/iUtG7OJ0CsjzB8cjAmKc/va/kIgeDI/TxsigdncE/4be734m0cvIYwNaV4i2XqAw== + +"@sinonjs/commons@^1.7.0": + version "1.8.3" + resolved "https://registry.yarnpkg.com/@sinonjs/commons/-/commons-1.8.3.tgz#3802ddd21a50a949b6721ddd72da36e67e7f1b2d" + integrity sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ== + dependencies: + type-detect "4.0.8" + +"@sinonjs/fake-timers@^8.0.1": + version "8.1.0" + resolved "https://registry.yarnpkg.com/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz#3fdc2b6cb58935b21bfb8d1625eb1300484316e7" + integrity sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg== + dependencies: + "@sinonjs/commons" "^1.7.0" + +"@solana/buffer-layout@^4.0.0": + version "4.0.0" + resolved "https://registry.yarnpkg.com/@solana/buffer-layout/-/buffer-layout-4.0.0.tgz#75b1b11adc487234821c81dfae3119b73a5fd734" + integrity sha512-lR0EMP2HC3+Mxwd4YcnZb0smnaDw7Bl2IQWZiTevRH5ZZBZn6VRWn3/92E3qdU4SSImJkA6IDHawOHAnx/qUvQ== + dependencies: + buffer "~6.0.3" + +"@solana/spl-token@^0.1.6": + version "0.1.8" + resolved "https://registry.yarnpkg.com/@solana/spl-token/-/spl-token-0.1.8.tgz#f06e746341ef8d04165e21fc7f555492a2a0faa6" + integrity sha512-LZmYCKcPQDtJgecvWOgT/cnoIQPWjdH+QVyzPcFvyDUiT0DiRjZaam4aqNUyvchLFhzgunv3d9xOoyE34ofdoQ== + dependencies: + "@babel/runtime" "^7.10.5" + "@solana/web3.js" "^1.21.0" + bn.js "^5.1.0" + buffer "6.0.3" + buffer-layout "^1.2.0" + dotenv "10.0.0" + +"@solana/web3.js@^1.17.0", "@solana/web3.js@^1.21.0", "@solana/web3.js@^1.43.5": + version "1.50.1" + resolved "https://registry.yarnpkg.com/@solana/web3.js/-/web3.js-1.50.1.tgz#dae726a06267d1bcd88b1e3cd8ae44c709302dcf" + integrity sha512-1l9N/nS8pJEA2YibNT8wa072718O0/A1eKWE0+pdWC5wDGQgBNxZSLuv7Cq5Dcn46WsZ5J5ZstK89q8J/ZZaQA== + dependencies: + "@babel/runtime" "^7.12.5" + "@ethersproject/sha2" "^5.5.0" + "@solana/buffer-layout" "^4.0.0" + bigint-buffer "^1.1.5" + bn.js "^5.0.0" + borsh "^0.7.0" + bs58 "^4.0.1" + buffer "6.0.1" + fast-stable-stringify "^1.0.0" + jayson "^3.4.4" + js-sha3 "^0.8.0" + node-fetch "2" + react-native-url-polyfill "^1.3.0" + rpc-websockets "^7.5.0" + secp256k1 "^4.0.2" + superstruct "^0.14.2" + tweetnacl "^1.0.0" + +"@solidity-parser/parser@^0.14.1", "@solidity-parser/parser@^0.14.2": + version "0.14.3" + resolved "https://registry.yarnpkg.com/@solidity-parser/parser/-/parser-0.14.3.tgz#0d627427b35a40d8521aaa933cc3df7d07bfa36f" + integrity sha512-29g2SZ29HtsqA58pLCtopI1P/cPy5/UAzlcAXO6T/CNJimG6yA8kx4NaseMyJULiC+TEs02Y9/yeHzClqoA0hw== + dependencies: + antlr4ts "^0.5.0-alpha.4" + +"@sushiswap/core@^2.0.0-canary.1": + version "2.0.0-canary.1" + resolved "https://registry.yarnpkg.com/@sushiswap/core/-/core-2.0.0-canary.1.tgz#91c938668282d463e4fce6e0cf4d320ce5f3768f" + integrity sha512-6YFT4EKgm0XgfwCBsKx5HrDtRI6EvhZHipjBKegdTV0b2zKuXnmdyZ+RwPCr0mCKq2pKB0qIiqCxfbgXYDlLCQ== + +"@sushiswap/sdk@^5.0.0-canary.116": + version "5.0.0-canary.116" + resolved "https://registry.yarnpkg.com/@sushiswap/sdk/-/sdk-5.0.0-canary.116.tgz#cdf303590dc0a174a0332c76b15ee8a0d92a8e4f" + integrity sha512-EC25LvMGIyhmMJr2vbJ1HWFSUgKHq7IJp+Esemokx1RIdyrkW2Hwo4RWSzkAzWG4+lDJC/aI79iH4riiEk5tng== + dependencies: + "@ethersproject/abi" "^5.4.0" + "@ethersproject/abstract-signer" "^5.4.0" + "@ethersproject/address" "^5.4.0" + "@ethersproject/bignumber" "^5.4.0" + "@ethersproject/bytes" "^5.4.0" + "@ethersproject/contracts" "^5.4.0" + "@ethersproject/experimental" "^5.4.0" + "@ethersproject/networks" "^5.4.0" + "@ethersproject/providers" "^5.4.0" + "@ethersproject/signing-key" "^5.4.0" + "@ethersproject/solidity" "^5.4.0" + "@ethersproject/transactions" "^5.4.0" + "@sushiswap/core" "^2.0.0-canary.1" + big.js "^6.1.0" + decimal.js-light "^2.5.0" + eip-712 "^0.4.3" + isomorphic-unfetch "^3.1.0" + jsbi "^4.1.0" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@switchboard-xyz/defikingdoms-sdk@^1.0.7": + version "1.0.7" + resolved "https://registry.yarnpkg.com/@switchboard-xyz/defikingdoms-sdk/-/defikingdoms-sdk-1.0.7.tgz#9c7c9e30f82c6504af478699db71779b2e0ca914" + integrity sha512-1QppBzxlGymUyY7Jf/Rskp+7+TY6J0HlutnEuCqMPDLiBbI6HJtVE1yJIGR+mP4w3korrbB22XD7PGsT6GIBLw== + dependencies: + "@ethersproject/address" "^5.0.0-beta" + "@ethersproject/contracts" "^5.0.0-beta" + "@ethersproject/networks" "^5.0.0-beta" + "@ethersproject/providers" "^5.0.0-beta" + "@ethersproject/solidity" "^5.0.0-beta" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.1" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@szmarczak/http-timer@^1.1.2": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-1.1.2.tgz#b1665e2c461a2cd92f4c1bbf50d5454de0d4b421" + integrity sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA== + dependencies: + defer-to-connect "^1.0.1" + +"@szmarczak/http-timer@^5.0.1": + version "5.0.1" + resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-5.0.1.tgz#c7c1bf1141cdd4751b0399c8fc7b8b664cd5be3a" + integrity sha512-+PmQX0PiAYPMeVYe237LJAYvOMYW1j2rH5YROyS3b4CTVJum34HfRvKvAzozHAQG0TnHNdUfY9nCeUyRAs//cw== + dependencies: + defer-to-connect "^2.0.1" + +"@tootallnate/once@1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82" + integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== + +"@traderjoe-xyz/sdk@^1.6.1": + version "1.6.4" + resolved "https://registry.yarnpkg.com/@traderjoe-xyz/sdk/-/sdk-1.6.4.tgz#a0382bd891f9f684d0df87f2b0012063809e78c7" + integrity sha512-hLfAa9SdSABql6cSN3VW+E+AIfY8RWBSBHeJvokX82RXciD2buRirWiqbECcbDVR/moMKdOFWfqQ4Qz3NYIgFA== + dependencies: + "@openzeppelin/cli" "^2.8.2" + "@uniswap/v2-core" "^1.0.1" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.1" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@truffle/abi-utils@^0.3.3": + version "0.3.3" + resolved "https://registry.yarnpkg.com/@truffle/abi-utils/-/abi-utils-0.3.3.tgz#4484489b160ad35aa0716427c73de10ebed40146" + integrity sha512-/KpaaPi0daffnwLhFulMtwdQ7YfZZtj24J34kZJi7OQw9x0dSNSskGFTU5SEv9d3fOfHNYqCevsqtv1zek0+zg== + dependencies: + change-case "3.0.2" + fast-check "3.1.1" + web3-utils "1.7.4" + +"@truffle/code-utils@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@truffle/code-utils/-/code-utils-3.0.0.tgz#47812cdaa6ede006d4f224c3f4d21d165a271e0a" + integrity sha512-MHUrOAZYlbmVp+9W2Mmw6vaLteWolkn6AF5iiKUr/j42Bon6CU5gNnc1gvdVoNdO/xsrqKqyoloYNgtZLgMldg== + dependencies: + cbor "^5.2.0" + +"@truffle/codec@^0.14.7": + version "0.14.7" + resolved "https://registry.yarnpkg.com/@truffle/codec/-/codec-0.14.7.tgz#2f7d2916f428be5da7a82559356c8570898e5cd9" + integrity sha512-qEbnghn/q3+hKoaRIlXfcdty0jhA1CcvWxjCgwOxEBVOGEBazjentyCzTGkrxyL9I4q1VDqk5Bmxl8umotzRTg== + dependencies: + "@truffle/abi-utils" "^0.3.3" + "@truffle/compile-common" "^0.9.0" + big.js "^6.0.3" + bn.js "^5.1.3" + cbor "^5.2.0" + debug "^4.3.1" + lodash "^4.17.21" + semver "7.3.7" + utf8 "^3.0.0" + web3-utils "1.7.4" + +"@truffle/compile-common@^0.9.0": + version "0.9.0" + resolved "https://registry.yarnpkg.com/@truffle/compile-common/-/compile-common-0.9.0.tgz#92ed5f91820b56e15604818464fa3803c6da13e7" + integrity sha512-kpTTU/7ZlQedH6cemCgrqXL4sUjsWAPj7X4LaqQ+KSna3egNJZ6wrKt2kpSYPpCpLihq2IpcBwWar3dTPZ7a5Q== + dependencies: + "@truffle/error" "^0.1.1" + colors "1.4.0" + +"@truffle/config@^1.3.40": + version "1.3.40" + resolved "https://registry.yarnpkg.com/@truffle/config/-/config-1.3.40.tgz#278a1b7cc4ab2af1c360df77b0c187425e4cb74d" + integrity sha512-4QWHZDPg4/YbJNdViYYJnNWR/XKmdQzff+4jUqpyFbeeW35NIvhTOVAbIiwnijjSZJ7PgNggploHI49Y3R+ohA== + dependencies: + "@truffle/error" "^0.1.1" + "@truffle/events" "^0.1.15" + "@truffle/provider" "^0.2.62" + conf "^10.1.2" + find-up "^2.1.0" + lodash "^4.17.21" + original-require "^1.0.1" + +"@truffle/dashboard-message-bus-client@^0.1.7": + version "0.1.7" + resolved "https://registry.yarnpkg.com/@truffle/dashboard-message-bus-client/-/dashboard-message-bus-client-0.1.7.tgz#62e71123eb2cc1e4dce0b1664a9455b3207c77da" + integrity sha512-7F62gQl5K1MIwVk5+dO9FeHD4zblty0jfTjKBMsdDZEd4yazzS2n2QOzxnPsjxvthX1oPPLRxK+VrN9c/3+VTw== + dependencies: + "@truffle/dashboard-message-bus-common" "^0.1.4" + "@truffle/promise-tracker" "^0.1.4" + axios "0.27.2" + debug "^4.3.1" + delay "^5.0.0" + isomorphic-ws "^4.0.1" + node-abort-controller "^3.0.1" + tiny-typed-emitter "^2.1.0" + ws "^7.2.0" + +"@truffle/dashboard-message-bus-common@^0.1.4": + version "0.1.4" + resolved "https://registry.yarnpkg.com/@truffle/dashboard-message-bus-common/-/dashboard-message-bus-common-0.1.4.tgz#f5b5326eb4774d5d209c310c135309f4b3f42bea" + integrity sha512-R+16jYcr/mxhz5pI+0GAJI14XUvYySLTB650kWubMBrVf4vi4QaIOdAOrx4KxAIA6e/5Nq9j0le59Y2c+xAHYg== + +"@truffle/db-loader@^0.2.2": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@truffle/db-loader/-/db-loader-0.2.2.tgz#6e6ac597060b1d3c46aecbae1d6bcfc3163fd15a" + integrity sha512-kkUTBsCku0kmOcFd25tIcOaVshzPnfaxmJb20/NwOZEGnEyrpzdXRaNLPLBOUVASvWk57tlLmfR9R+7mDLSvLg== + optionalDependencies: + "@truffle/db" "^2.0.2" + +"@truffle/db@^2.0.2": + version "2.0.2" + resolved "https://registry.yarnpkg.com/@truffle/db/-/db-2.0.2.tgz#c8324909d8a6d01fc5b81ee93c0e21cb5575b4eb" + integrity sha512-9bScL0XJnh046ifTvUVhLTaqSN3BdXZHQ+pVxwde2JZ+FRcpjTsSk735u8WFU4VVlJbcy3lmL18CL+kBzfLL8A== + dependencies: + "@graphql-tools/delegate" "^8.4.3" + "@graphql-tools/schema" "^8.3.1" + "@truffle/abi-utils" "^0.3.3" + "@truffle/code-utils" "^3.0.0" + "@truffle/config" "^1.3.40" + abstract-leveldown "^7.2.0" + apollo-server "^3.6.3" + debug "^4.3.1" + fs-extra "^9.1.0" + graphql "^15.3.0" + graphql-tag "^2.12.6" + json-stable-stringify "^1.0.1" + pascal-case "^2.0.1" + pluralize "^8.0.0" + pouchdb "7.3.0" + pouchdb-adapter-memory "^7.1.1" + pouchdb-debug "^7.1.1" + pouchdb-find "^7.0.0" + web3-utils "1.7.4" + +"@truffle/debugger@^11.0.13": + version "11.0.13" + resolved "https://registry.yarnpkg.com/@truffle/debugger/-/debugger-11.0.13.tgz#21a49c9ff733be5509c920b85c8feafdecef31bf" + integrity sha512-s8ZUkmZ/xQDbAapYf7iunb1W0tM+ZrAqf+y/S0E9H+xAf+INY9FLPfUxS0soOjbzKMIgp/1XZ8mF/tP/MeMmpA== + dependencies: + "@truffle/abi-utils" "^0.3.3" + "@truffle/codec" "^0.14.7" + "@truffle/source-map-utils" "^1.3.98" + bn.js "^5.1.3" + debug "^4.3.1" + json-pointer "^0.6.1" + json-stable-stringify "^1.0.1" + lodash "^4.17.21" + redux "^3.7.2" + redux-saga "1.0.0" + reselect-tree "^1.3.7" + semver "7.3.7" + web3 "1.7.4" + web3-eth-abi "1.7.4" + +"@truffle/error@^0.0.6": + version "0.0.6" + resolved "https://registry.yarnpkg.com/@truffle/error/-/error-0.0.6.tgz#75d499845b4b3a40537889e7d04c663afcaee85d" + integrity sha512-QUM9ZWiwlXGixFGpV18g5I6vua6/r+ZV9W/5DQA5go9A3eZUNPHPaTKMIQPJLYn6+ZV5jg5H28zCHq56LHF3yA== + +"@truffle/error@^0.1.1": + version "0.1.1" + resolved "https://registry.yarnpkg.com/@truffle/error/-/error-0.1.1.tgz#e52026ac8ca7180d83443dca73c03e07ace2a301" + integrity sha512-sE7c9IHIGdbK4YayH4BC8i8qMjoAOeg6nUXUDZZp8wlU21/EMpaG+CLx+KqcIPyR+GSWIW3Dm0PXkr2nlggFDA== + +"@truffle/events@^0.1.15": + version "0.1.15" + resolved "https://registry.yarnpkg.com/@truffle/events/-/events-0.1.15.tgz#d2dbcb2494804d9cbc80d7ab3a1624bfd86239a2" + integrity sha512-GP0WFayhgzFT1vu9LAYJOzbOnEV7PWdkzrMrjYPv5biQQLcchCNNuIyuarflFZZ/08wpEjvy2F4FHj/RJXRdkQ== + dependencies: + "@truffle/dashboard-message-bus-client" "^0.1.7" + "@truffle/spinners" "^0.2.2" + debug "^4.3.1" + emittery "^0.4.1" + web3-utils "1.7.4" + +"@truffle/interface-adapter@^0.5.23": + version "0.5.23" + resolved "https://registry.yarnpkg.com/@truffle/interface-adapter/-/interface-adapter-0.5.23.tgz#a4103270e3c73746089b9e5807aaa1359f4725bb" + integrity sha512-nU8kChKgcUP+tELId1PMgHnmd2KcBdBer59TxfVqAZXRmt6blm2tpBbGYtKzTIdZlf6kMqVbZXdB6u1CJDqfxg== + dependencies: + bn.js "^5.1.3" + ethers "^4.0.32" + web3 "1.7.4" + +"@truffle/promise-tracker@^0.1.4": + version "0.1.4" + resolved "https://registry.yarnpkg.com/@truffle/promise-tracker/-/promise-tracker-0.1.4.tgz#6f9d019b048a78b6d024bf2967e24dfa8c3a164d" + integrity sha512-JqsZZXWXUnrF+zsU2jf12BXyVYAHQj0iJck7EyTsdy9Wdx1aSsqX9Cnc6U274Xk0xNXziV+NestyuoF3kHTWiw== + +"@truffle/provider@^0.2.62": + version "0.2.62" + resolved "https://registry.yarnpkg.com/@truffle/provider/-/provider-0.2.62.tgz#bbea5c8df961a2703aff45330cd6dbfe87ae3655" + integrity sha512-MxfUkt+fUO66F1u4wjYu7j8ZZxkodnOALII4CUTd55rTHd0mw0rRtVtYiNAaK+WDljqHb55bc6ecE45ioeTnqA== + dependencies: + "@truffle/error" "^0.1.1" + "@truffle/interface-adapter" "^0.5.23" + debug "^4.3.1" + web3 "1.7.4" + +"@truffle/source-map-utils@^1.3.98": + version "1.3.98" + resolved "https://registry.yarnpkg.com/@truffle/source-map-utils/-/source-map-utils-1.3.98.tgz#a6169b86acf306731365fa41551cbc7d080c048e" + integrity sha512-u3OCqU69CUMhwCb/auE7dklYQPZMuEZ/SeduI/syAq1CVPIy2jHABsEKebL6RUux/HfP9OTC4bc3h/zabDQ3Ww== + dependencies: + "@truffle/code-utils" "^3.0.0" + "@truffle/codec" "^0.14.7" + debug "^4.3.1" + json-pointer "^0.6.1" + node-interval-tree "^1.3.3" + web3-utils "1.7.4" + +"@truffle/spinners@^0.2.2": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@truffle/spinners/-/spinners-0.2.2.tgz#0f69f18f3d8242eb6a9a20497e73e1c97e8ca0ac" + integrity sha512-6srCpV5MykkROtkj+ak5YX0GexAVuw+AB+lZIQxWLGP3i75pfJer7vL2nnqgr0madaAUuIixb7A2NJDFx3lOdg== + dependencies: + "@trufflesuite/spinnies" "^0.1.1" + +"@trufflesuite/bigint-buffer@1.1.10": + version "1.1.10" + resolved "https://registry.yarnpkg.com/@trufflesuite/bigint-buffer/-/bigint-buffer-1.1.10.tgz#a1d9ca22d3cad1a138b78baaf15543637a3e1692" + integrity sha512-pYIQC5EcMmID74t26GCC67946mgTJFiLXOT/BYozgrd4UEY2JHEGLhWi9cMiQCt5BSqFEvKkCHNnoj82SRjiEw== + dependencies: + node-gyp-build "4.4.0" + +"@trufflesuite/spinnies@^0.1.1": + version "0.1.1" + resolved "https://registry.yarnpkg.com/@trufflesuite/spinnies/-/spinnies-0.1.1.tgz#719230993f55ab39f936ed8778979e7661af188d" + integrity sha512-jltEtmFJj6xmQqr85gP8OqBHCEiId+zw+uAsb3DyLLRD17O6sySW6Afa2Z/jpzSafj+32ssDfLJ+c0of1NLqcA== + dependencies: + chalk "^4.1.2" + cli-cursor "^3.1.0" + strip-ansi "^6.0.0" + +"@tsconfig/node10@^1.0.7": + version "1.0.9" + resolved "https://registry.yarnpkg.com/@tsconfig/node10/-/node10-1.0.9.tgz#df4907fc07a886922637b15e02d4cebc4c0021b2" + integrity sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA== + +"@tsconfig/node12@^1.0.7": + version "1.0.11" + resolved "https://registry.yarnpkg.com/@tsconfig/node12/-/node12-1.0.11.tgz#ee3def1f27d9ed66dac6e46a295cffb0152e058d" + integrity sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag== + +"@tsconfig/node14@^1.0.0": + version "1.0.3" + resolved "https://registry.yarnpkg.com/@tsconfig/node14/-/node14-1.0.3.tgz#e4386316284f00b98435bf40f72f75a09dabf6c1" + integrity sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow== + +"@tsconfig/node16@^1.0.2": + version "1.0.3" + resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.3.tgz#472eaab5f15c1ffdd7f8628bd4c4f753995ec79e" + integrity sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ== + +"@types/abstract-leveldown@*": + version "7.2.0" + resolved "https://registry.yarnpkg.com/@types/abstract-leveldown/-/abstract-leveldown-7.2.0.tgz#f055979a99f7654e84d6b8e6267419e9c4cfff87" + integrity sha512-q5veSX6zjUy/DlDhR4Y4cU0k2Ar+DT2LUraP00T19WLmTO6Se1djepCCaqU6nQrwcJ5Hyo/CWqxTzrrFg8eqbQ== + +"@types/accepts@^1.3.5": + version "1.3.5" + resolved "https://registry.yarnpkg.com/@types/accepts/-/accepts-1.3.5.tgz#c34bec115cfc746e04fe5a059df4ce7e7b391575" + integrity sha512-jOdnI/3qTpHABjM5cx1Hc0sKsPoYCp+DP/GJRGtDlPd7fiV9oXGGIcjW/ZOxLIvjGz8MA+uMZI9metHlgqbgwQ== + dependencies: + "@types/node" "*" + +"@types/app-root-path@^1.2.4": + version "1.2.4" + resolved "https://registry.yarnpkg.com/@types/app-root-path/-/app-root-path-1.2.4.tgz#a78b703282b32ac54de768f5512ecc3569919dc7" + integrity sha512-yhURoXmWN/zfw2MXXcOdUTwe5CWhzRWtb4Rs2+JwGpuhm2hxLCzjASi/aIuyVeJB3Iyks1teaHyOEfNNmltdvQ== + +"@types/async-retry@^1.4.2": + version "1.4.4" + resolved "https://registry.yarnpkg.com/@types/async-retry/-/async-retry-1.4.4.tgz#3304ce1e64f8757723f166518fc4c4b68df4fe66" + integrity sha512-IGT+yESLPYje0MV8MfOpT5V5oH9lAKLwlosQRyq75tYJmntkkWcfEThHLxsgYjGmYXJEY7ZZkYPb4xuW+NA6GA== + dependencies: + "@types/retry" "*" + +"@types/await-timeout@^0.3.1": + version "0.3.1" + resolved "https://registry.yarnpkg.com/@types/await-timeout/-/await-timeout-0.3.1.tgz#3a0baafc3a96c7a14447a4dcfdcc76b21ce97c3b" + integrity sha512-H5PzROT4KuP7XQDua13Iw8did//OCKAZ/3TL15DjvMzDonrk4HvhH1+tLko96f2guU6XaD3AoqRa49ZOwbwNig== + +"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.14": + version "7.1.19" + resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.19.tgz#7b497495b7d1b4812bdb9d02804d0576f43ee460" + integrity sha512-WEOTgRsbYkvA/KCsDwVEGkd7WAr1e3g31VHQ8zy5gul/V1qKullU/BU5I68X5v7V3GnB9eotmom4v5a5gjxorw== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + "@types/babel__generator" "*" + "@types/babel__template" "*" + "@types/babel__traverse" "*" + +"@types/babel__generator@*": + version "7.6.4" + resolved "https://registry.yarnpkg.com/@types/babel__generator/-/babel__generator-7.6.4.tgz#1f20ce4c5b1990b37900b63f050182d28c2439b7" + integrity sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg== + dependencies: + "@babel/types" "^7.0.0" + +"@types/babel__template@*": + version "7.4.1" + resolved "https://registry.yarnpkg.com/@types/babel__template/-/babel__template-7.4.1.tgz#3d1a48fd9d6c0edfd56f2ff578daed48f36c8969" + integrity sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + +"@types/babel__traverse@*", "@types/babel__traverse@^7.0.4", "@types/babel__traverse@^7.0.6": + version "7.18.0" + resolved "https://registry.yarnpkg.com/@types/babel__traverse/-/babel__traverse-7.18.0.tgz#8134fd78cb39567465be65b9fdc16d378095f41f" + integrity sha512-v4Vwdko+pgymgS+A2UIaJru93zQd85vIGWObM5ekZNdXCKtDYqATlEYnWgfo86Q6I1Lh0oXnksDnMU1cwmlPDw== + dependencies: + "@babel/types" "^7.3.0" + +"@types/big.js@^6.1.3": + version "6.1.5" + resolved "https://registry.yarnpkg.com/@types/big.js/-/big.js-6.1.5.tgz#ff06b43a4c0c4002522e0fd7fc28bb963722ab01" + integrity sha512-UiWyJ6TLWoHeHZ8VUyngzCOwJDVxTsPnqfAMR/85X93rkRk5A4T2U42BCx0wCmZdtMHGHN/utJ8ft5xWu0V1bA== + +"@types/big.js@^6.1.5": + version "6.1.6" + resolved "https://registry.yarnpkg.com/@types/big.js/-/big.js-6.1.6.tgz#3d417e758483d55345a03a087f7e0c87137ca444" + integrity sha512-0r9J+Zz9rYm2hOTwiMAVkm3XFQ4u5uTK37xrQMhc9bysn/sf/okzovWMYYIBMFTn/yrEZ11pusgLEaoarTlQbA== + +"@types/bn.js@^4.11.3", "@types/bn.js@^4.11.4": + version "4.11.6" + resolved "https://registry.yarnpkg.com/@types/bn.js/-/bn.js-4.11.6.tgz#c306c70d9358aaea33cd4eda092a742b9505967c" + integrity sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg== + dependencies: + "@types/node" "*" + +"@types/bn.js@^5.1.0": + version "5.1.0" + resolved "https://registry.yarnpkg.com/@types/bn.js/-/bn.js-5.1.0.tgz#32c5d271503a12653c62cf4d2b45e6eab8cebc68" + integrity sha512-QSSVYj7pYFN49kW77o2s9xTCwZ8F2xLbjLLSEVh8D2F4JUhZtPAGOFLTD+ffqksBx/u4cE/KImFjyhqCjn/LIA== + dependencies: + "@types/node" "*" + +"@types/bn.js@^5.1.1": + version "5.1.1" + resolved "https://registry.yarnpkg.com/@types/bn.js/-/bn.js-5.1.1.tgz#b51e1b55920a4ca26e9285ff79936bbdec910682" + integrity sha512-qNrYbZqMx0uJAfKnKclPh+dTwK33KfLHYqtyODwd5HnXOjnkhc4qgn3BrK6RWyGZm5+sIFE7Q7Vz6QQtJB7w7g== + dependencies: + "@types/node" "*" + +"@types/body-parser@*", "@types/body-parser@1.19.2": + version "1.19.2" + resolved "https://registry.yarnpkg.com/@types/body-parser/-/body-parser-1.19.2.tgz#aea2059e28b7658639081347ac4fab3de166e6f0" + integrity sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g== + dependencies: + "@types/connect" "*" + "@types/node" "*" + +"@types/bs58@^4.0.1": + version "4.0.1" + resolved "https://registry.yarnpkg.com/@types/bs58/-/bs58-4.0.1.tgz#3d51222aab067786d3bc3740a84a7f5a0effaa37" + integrity sha512-yfAgiWgVLjFCmRv8zAcOIHywYATEwiTVccTLnRp6UxTNavT55M9d/uhK3T03St/+8/z/wW+CRjGKUNmEqoHHCA== + dependencies: + base-x "^3.0.6" + +"@types/bunyan-blackhole@^0.2.2": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@types/bunyan-blackhole/-/bunyan-blackhole-0.2.2.tgz#469e58c5d129027a9e08bcf9a36232a69b6ad011" + integrity sha512-nbuxFn2FVw1AAT1h6shgluwz1cgpLKaMBYbEZcMU69Jb1UvSsXcwRiIg+FP4+/JjEUp/uPYLC+twWpfCAaVN1g== + dependencies: + "@types/bunyan" "*" + +"@types/bunyan@*", "@types/bunyan@^1.8.6": + version "1.8.8" + resolved "https://registry.yarnpkg.com/@types/bunyan/-/bunyan-1.8.8.tgz#8d6d33f090f37c07e2a80af30ae728450a101008" + integrity sha512-Cblq+Yydg3u+sGiz2mjHjC5MPmdjY+No4qvHrF+BUhblsmSfMvsHLbOG62tPbonsqBj6sbWv1LHcsoe5Jw+/Ow== + dependencies: + "@types/node" "*" + +"@types/cacheable-request@^6.0.2": + version "6.0.2" + resolved "https://registry.yarnpkg.com/@types/cacheable-request/-/cacheable-request-6.0.2.tgz#c324da0197de0a98a2312156536ae262429ff6b9" + integrity sha512-B3xVo+dlKM6nnKTcmm5ZtY/OL8bOAOd2Olee9M1zft65ox50OzjEHW91sDiU9j6cvW8Ejg1/Qkf4xd2kugApUA== + dependencies: + "@types/http-cache-semantics" "*" + "@types/keyv" "*" + "@types/node" "*" + "@types/responselike" "*" + +"@types/cbor@^2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@types/cbor/-/cbor-2.0.0.tgz#c627afc2ee22f23f2337fecb34628a4f97c6afbb" + integrity sha512-yQH0JLcrHrH/GBIFFFq6DAsj9M4rmYsmSpGGGs67JrLGWPepYr2c1YugGjMd2Ib5pebluRAfNPJ4O1p80qX9HQ== + dependencies: + "@types/node" "*" + +"@types/connect@*", "@types/connect@^3.4.33": + version "3.4.35" + resolved "https://registry.yarnpkg.com/@types/connect/-/connect-3.4.35.tgz#5fcf6ae445e4021d1fc2219a4873cc73a3bb2ad1" + integrity sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ== + dependencies: + "@types/node" "*" + +"@types/cookiejar@*": + version "2.1.2" + resolved "https://registry.yarnpkg.com/@types/cookiejar/-/cookiejar-2.1.2.tgz#66ad9331f63fe8a3d3d9d8c6e3906dd10f6446e8" + integrity sha512-t73xJJrvdTjXrn4jLS9VSGRbz0nUY3cl2DMGDU48lKl+HR9dbbjW2A9r3g40VA++mQpy6uuHg33gy7du2BKpog== + +"@types/cors@2.8.12": + version "2.8.12" + resolved "https://registry.yarnpkg.com/@types/cors/-/cors-2.8.12.tgz#6b2c510a7ad7039e98e7b8d3d6598f4359e5c080" + integrity sha512-vt+kDhq/M2ayberEtJcIN/hxXy1Pk+59g2FV/ZQceeaTyCtCucjL2Q7FXlFjtWn4n15KCr1NE2lNNFhp0lEThw== + +"@types/encoding-down@*": + version "5.0.0" + resolved "https://registry.yarnpkg.com/@types/encoding-down/-/encoding-down-5.0.0.tgz#0b5b90b93ac3aa75148f19508044e7bd36463557" + integrity sha512-G0MlS/+/U2RIQLcSEhhAcoMrXw3hXUCFSKbhbeEljoKMra2kq+NPX6tfOveSWQLX2hJXBo+YrvKgAGe+tFL1Aw== + dependencies: + "@types/abstract-leveldown" "*" + "@types/level-codec" "*" + +"@types/express-serve-static-core@4.17.31": + version "4.17.31" + resolved "https://registry.yarnpkg.com/@types/express-serve-static-core/-/express-serve-static-core-4.17.31.tgz#a1139efeab4e7323834bb0226e62ac019f474b2f" + integrity sha512-DxMhY+NAsTwMMFHBTtJFNp5qiHKJ7TeqOo23zVEM9alT1Ml27Q3xcTH0xwxn7Q0BbMcVEJOs/7aQtUWupUQN3Q== + dependencies: + "@types/node" "*" + "@types/qs" "*" + "@types/range-parser" "*" + +"@types/express-serve-static-core@^4.17.18", "@types/express-serve-static-core@^4.17.9": + version "4.17.30" + resolved "https://registry.yarnpkg.com/@types/express-serve-static-core/-/express-serve-static-core-4.17.30.tgz#0f2f99617fa8f9696170c46152ccf7500b34ac04" + integrity sha512-gstzbTWro2/nFed1WXtf+TtrpwxH7Ggs4RLYTLbeVgIkUQOI3WG/JKjgeOU1zXDvezllupjrf8OPIdvTbIaVOQ== + dependencies: + "@types/node" "*" + "@types/qs" "*" + "@types/range-parser" "*" + +"@types/express@*", "@types/express@^4.17.12": + version "4.17.13" + resolved "https://registry.yarnpkg.com/@types/express/-/express-4.17.13.tgz#a76e2995728999bab51a33fabce1d705a3709034" + integrity sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA== + dependencies: + "@types/body-parser" "*" + "@types/express-serve-static-core" "^4.17.18" + "@types/qs" "*" + "@types/serve-static" "*" + +"@types/express@4.17.14": + version "4.17.14" + resolved "https://registry.yarnpkg.com/@types/express/-/express-4.17.14.tgz#143ea0557249bc1b3b54f15db4c81c3d4eb3569c" + integrity sha512-TEbt+vaPFQ+xpxFLFssxUDXj5cWCxZJjIcB7Yg0k0GMHGtgtQgpvx/MUQUeAkNbA9AAGrwkAsoeItdTgS7FMyg== + dependencies: + "@types/body-parser" "*" + "@types/express-serve-static-core" "^4.17.18" + "@types/qs" "*" + "@types/serve-static" "*" + +"@types/fs-extra@^7.0.0": + version "7.0.0" + resolved "https://registry.yarnpkg.com/@types/fs-extra/-/fs-extra-7.0.0.tgz#9c4ad9e1339e7448a76698829def1f159c1b636c" + integrity sha512-ndoMMbGyuToTy4qB6Lex/inR98nPiNHacsgMPvy+zqMLgSxbt8VtWpDArpGp69h1fEDQHn1KB+9DWD++wgbwYA== + dependencies: + "@types/node" "*" + +"@types/fs-extra@^9.0.13": + version "9.0.13" + resolved "https://registry.yarnpkg.com/@types/fs-extra/-/fs-extra-9.0.13.tgz#7594fbae04fe7f1918ce8b3d213f74ff44ac1f45" + integrity sha512-nEnwB++1u5lVDM2UI4c1+5R+FYaKfaAzS4OococimjVm3nQw3TuzH5UNsocrcTBbhnerblyHj4A49qXbIiZdpA== + dependencies: + "@types/node" "*" + +"@types/graceful-fs@^4.1.2": + version "4.1.5" + resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.5.tgz#21ffba0d98da4350db64891f92a9e5db3cdb4e15" + integrity sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw== + dependencies: + "@types/node" "*" + +"@types/http-cache-semantics@*": + version "4.0.1" + resolved "https://registry.yarnpkg.com/@types/http-cache-semantics/-/http-cache-semantics-4.0.1.tgz#0ea7b61496902b95890dc4c3a116b60cb8dae812" + integrity sha512-SZs7ekbP8CN0txVG2xVRH6EgKmEm31BOxA07vkFaETzZz1xh+cbt8BcI0slpymvwhx5dlFnQG2rTlPVQn+iRPQ== + +"@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0", "@types/istanbul-lib-coverage@^2.0.1": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz#8467d4b3c087805d63580480890791277ce35c44" + integrity sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g== + +"@types/istanbul-lib-report@*": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#c14c24f18ea8190c118ee7562b7ff99a36552686" + integrity sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg== + dependencies: + "@types/istanbul-lib-coverage" "*" + +"@types/istanbul-reports@^1.1.1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-1.1.2.tgz#e875cc689e47bce549ec81f3df5e6f6f11cfaeb2" + integrity sha512-P/W9yOX/3oPZSpaYOCQzGqgCQRXn0FFO/V8bWrCQs+wLmvVVxk6CRBXALEvNs9OHIatlnlFokfhuDo2ug01ciw== + dependencies: + "@types/istanbul-lib-coverage" "*" + "@types/istanbul-lib-report" "*" + +"@types/istanbul-reports@^3.0.0": + version "3.0.1" + resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz#9153fe98bba2bd565a63add9436d6f0d7f8468ff" + integrity sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw== + dependencies: + "@types/istanbul-lib-report" "*" + +"@types/jest@^27.4.1": + version "27.5.2" + resolved "https://registry.yarnpkg.com/@types/jest/-/jest-27.5.2.tgz#ec49d29d926500ffb9fd22b84262e862049c026c" + integrity sha512-mpT8LJJ4CMeeahobofYWIjFo0xonRS/HfxnVEPMPFSQdGUt1uHCnoPT7Zhb+sjDU2wz0oKV0OLUR0WzrHNgfeA== + dependencies: + jest-matcher-utils "^27.0.0" + pretty-format "^27.0.0" + +"@types/js-yaml@^4.0.2": + version "4.0.5" + resolved "https://registry.yarnpkg.com/@types/js-yaml/-/js-yaml-4.0.5.tgz#738dd390a6ecc5442f35e7f03fa1431353f7e138" + integrity sha512-FhpRzf927MNQdRZP0J5DLIdTXhjLYzeUTmLAu69mnVksLH9CJY3IuSeEgbKUki7GQZm0WqDkGzyxju2EZGD2wA== + +"@types/json-buffer@~3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/json-buffer/-/json-buffer-3.0.0.tgz#85c1ff0f0948fc159810d4b5be35bf8c20875f64" + integrity sha512-3YP80IxxFJB4b5tYC2SUPwkg0XQLiu0nWvhRgEatgjf+29IcWO9X1k8xRv5DGssJ/lCrjYTjQPcobJr2yWIVuQ== + +"@types/json-schema@^7.0.7": + version "7.0.11" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.11.tgz#d421b6c527a3037f7c84433fd2c4229e016863d3" + integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== + +"@types/json5@^0.0.29": + version "0.0.29" + resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" + integrity sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ== + +"@types/keyv@*": + version "3.1.4" + resolved "https://registry.yarnpkg.com/@types/keyv/-/keyv-3.1.4.tgz#3ccdb1c6751b0c7e52300bcdacd5bcbf8faa75b6" + integrity sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg== + dependencies: + "@types/node" "*" + +"@types/level-codec@*": + version "9.0.1" + resolved "https://registry.yarnpkg.com/@types/level-codec/-/level-codec-9.0.1.tgz#b135e0b3da81185b6f27655334c5f1da89b2b0af" + integrity sha512-6z7DSlBsmbax3I/bV1Q6jT1nKquDjFl95LURVThdKtwILkRawLYtXdINW19xM95N5kqN2detWb2iGrbUlPwNyw== + +"@types/level-errors@*": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/level-errors/-/level-errors-3.0.0.tgz#15c1f4915a5ef763b51651b15e90f6dc081b96a8" + integrity sha512-/lMtoq/Cf/2DVOm6zE6ORyOM+3ZVm/BvzEZVxUhf6bgh8ZHglXlBqxbxSlJeVp8FCbD3IVvk/VbsaNmDjrQvqQ== + +"@types/level@^6.0.0": + version "6.0.1" + resolved "https://registry.yarnpkg.com/@types/level/-/level-6.0.1.tgz#6642c048dbae4638721105cd5f8255a2829bd5d6" + integrity sha512-4RK6vl9/CNCe5SyDCGaTgTOYEPNh8/wUaUY8UDN8AXon2D7hGPGIlx0t9jCds9wiKBqicsUyeAA0W4rUZeqYBQ== + dependencies: + "@types/abstract-leveldown" "*" + "@types/encoding-down" "*" + "@types/levelup" "*" + +"@types/levelup@*": + version "5.1.2" + resolved "https://registry.yarnpkg.com/@types/levelup/-/levelup-5.1.2.tgz#3b987fe66c95871dc97e74f0bce5b2eb91140782" + integrity sha512-JhCKONvFg2rEbsyyCCRkiPF03tMV1NyBXER4iXKBemgjwS4+SF6HGNuL4cfq6ueM6Yc+4ZbwJnU/5v6q3ZziUQ== + dependencies: + "@types/abstract-leveldown" "*" + "@types/level-errors" "*" + "@types/node" "*" + +"@types/levelup@^4.3.0": + version "4.3.3" + resolved "https://registry.yarnpkg.com/@types/levelup/-/levelup-4.3.3.tgz#4dc2b77db079b1cf855562ad52321aa4241b8ef4" + integrity sha512-K+OTIjJcZHVlZQN1HmU64VtrC0jC3dXWQozuEIR9zVvltIk90zaGPM2AgT+fIkChpzHhFE3YnvFLCbLtzAmexA== + dependencies: + "@types/abstract-leveldown" "*" + "@types/level-errors" "*" + "@types/node" "*" + +"@types/lodash@^4.14.159", "@types/lodash@^4.14.168", "@types/lodash@^4.14.178": + version "4.14.182" + resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.182.tgz#05301a4d5e62963227eaafe0ce04dd77c54ea5c2" + integrity sha512-/THyiqyQAP9AfARo4pF+aCGcyiQ94tX/Is2I7HofNRqoYLgN1PBoOWu2/zTA5zMxzP5EFutMtWtGAFRKUe961Q== + +"@types/lodash@^4.14.182": + version "4.14.186" + resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.186.tgz#862e5514dd7bd66ada6c70ee5fce844b06c8ee97" + integrity sha512-eHcVlLXP0c2FlMPm56ITode2AgLMSa6aJ05JTTbYbI+7EMkCEE5qk2E41d5g2lCVTqRe0GnnRFurmlCsDODrPw== + +"@types/long@^4.0.0", "@types/long@^4.0.1": + version "4.0.2" + resolved "https://registry.yarnpkg.com/@types/long/-/long-4.0.2.tgz#b74129719fc8d11c01868010082d483b7545591a" + integrity sha512-MqTGEo5bj5t157U6fA/BiDynNkn0YknVdh48CMPkTSpFTVmvao5UQmm7uEF6xBEo7qIMAlY/JSleYaE6VOdpaA== + +"@types/lru-cache@5.1.1", "@types/lru-cache@^5.1.0": + version "5.1.1" + resolved "https://registry.yarnpkg.com/@types/lru-cache/-/lru-cache-5.1.1.tgz#c48c2e27b65d2a153b19bfc1a317e30872e01eef" + integrity sha512-ssE3Vlrys7sdIzs5LOxCzTVMsU7i9oa/IaW92wF32JFb3CVczqOkru2xspuKczHEbG3nvmPY7IFqVmGGHdNbYw== + +"@types/mathjs@^9.4.2": + version "9.4.2" + resolved "https://registry.yarnpkg.com/@types/mathjs/-/mathjs-9.4.2.tgz#beec20340d768171fed8331b08fb321d218ec6e1" + integrity sha512-GF5g1vJmvKdWIWsE53XX7EDAyCaZ9p6gaYm1xhlXn5JjrY/NJrOfJN3fBxS3wyZpVh3QqKoMkS2WjFwxWMHOTw== + dependencies: + mathjs "*" + +"@types/mime@*": + version "3.0.1" + resolved "https://registry.yarnpkg.com/@types/mime/-/mime-3.0.1.tgz#5f8f2bca0a5863cb69bc0b0acd88c96cb1d4ae10" + integrity sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA== + +"@types/minimist@^1.2.2": + version "1.2.2" + resolved "https://registry.yarnpkg.com/@types/minimist/-/minimist-1.2.2.tgz#ee771e2ba4b3dc5b372935d549fd9617bf345b8c" + integrity sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ== + +"@types/mkdirp@^0.5.2": + version "0.5.2" + resolved "https://registry.yarnpkg.com/@types/mkdirp/-/mkdirp-0.5.2.tgz#503aacfe5cc2703d5484326b1b27efa67a339c1f" + integrity sha512-U5icWpv7YnZYGsN4/cmh3WD2onMY0aJIiTE6+51TwJCttdHvtCYmkBNOobHlXwrJRL0nkH9jH4kD+1FAdMN4Tg== + dependencies: + "@types/node" "*" + +"@types/morgan@^1.9.3": + version "1.9.3" + resolved "https://registry.yarnpkg.com/@types/morgan/-/morgan-1.9.3.tgz#ae04180dff02c437312bc0cfb1e2960086b2f540" + integrity sha512-BiLcfVqGBZCyNCnCH3F4o2GmDLrpy0HeBVnNlyZG4fo88ZiE9SoiBe3C+2ezuwbjlEyT+PDZ17//TAlRxAn75Q== + dependencies: + "@types/node" "*" + +"@types/node-fetch@^2.6.1": + version "2.6.2" + resolved "https://registry.yarnpkg.com/@types/node-fetch/-/node-fetch-2.6.2.tgz#d1a9c5fd049d9415dce61571557104dec3ec81da" + integrity sha512-DHqhlq5jeESLy19TYhLakJ07kNumXWjcDdxXsLUMJZ6ue8VZJj4kLPQVE/2mdHh3xZziNF1xppu5lwmS53HR+A== + dependencies: + "@types/node" "*" + form-data "^3.0.0" + +"@types/node@*": + version "17.0.31" + resolved "https://registry.yarnpkg.com/@types/node/-/node-17.0.31.tgz#a5bb84ecfa27eec5e1c802c6bbf8139bdb163a5d" + integrity sha512-AR0x5HbXGqkEx9CadRH3EBYx/VkiUgZIhP4wvPn/+5KIsgpNoyFaRlVe0Zlx9gRtg8fA06a9tskE2MSN7TcG4Q== + +"@types/node@>=12.12.47", "@types/node@>=13.7.0": + version "18.7.6" + resolved "https://registry.yarnpkg.com/@types/node/-/node-18.7.6.tgz#31743bc5772b6ac223845e18c3fc26f042713c83" + integrity sha512-EdxgKRXgYsNITy5mjjXjVE/CS8YENSdhiagGrLqjG0pvA2owgJ6i4l7wy/PFZGC0B1/H20lWKN7ONVDNYDZm7A== + +"@types/node@^10.1.0", "@types/node@^10.12.18", "@types/node@^10.3.2": + version "10.17.60" + resolved "https://registry.yarnpkg.com/@types/node/-/node-10.17.60.tgz#35f3d6213daed95da7f0f73e75bcc6980e90597b" + integrity sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw== + +"@types/node@^12.12.54": + version "12.20.50" + resolved "https://registry.yarnpkg.com/@types/node/-/node-12.20.50.tgz#14ba5198f1754ffd0472a2f84ab433b45ee0b65e" + integrity sha512-+9axpWx2b2JCVovr7Ilgt96uc6C1zBKOQMpGtRbWT9IoR/8ue32GGMfGA4woP8QyP2gBs6GQWEVM3tCybGCxDA== + +"@types/node@^12.12.6", "@types/node@^12.6.1": + version "12.20.55" + resolved "https://registry.yarnpkg.com/@types/node/-/node-12.20.55.tgz#c329cbd434c42164f846b909bd6f85b5537f6240" + integrity sha512-J8xLz7q2OFulZ2cyGTLE1TbbZcjpno7FaN6zdJNrgAdrJ+DZzh/uFR6YrTb4C+nXakvud8Q4+rbhoIWlYQbUFQ== + +"@types/node@^15.12.4": + version "15.14.9" + resolved "https://registry.yarnpkg.com/@types/node/-/node-15.14.9.tgz#bc43c990c3c9be7281868bbc7b8fdd6e2b57adfa" + integrity sha512-qjd88DrCxupx/kJD5yQgZdcYKZKSIGBVDIBE1/LTGcNm3d2Np/jxojkdePDdfnBHJc5W7vSMpbJ1aB7p/Py69A== + +"@types/npm@^2.0.29": + version "2.0.32" + resolved "https://registry.yarnpkg.com/@types/npm/-/npm-2.0.32.tgz#036682075b9c2116b510fe24b52a5b932e3a99d5" + integrity sha512-9Lg4woNVzJCtac0lET91H65lbO+8YXfk0nmlmoPGhHXMdaVEDloH6zOPIYMy2n39z/aCXXQR0nax66EDekAyIQ== + dependencies: + "@types/node" "*" + +"@types/pbkdf2@^3.0.0": + version "3.1.0" + resolved "https://registry.yarnpkg.com/@types/pbkdf2/-/pbkdf2-3.1.0.tgz#039a0e9b67da0cdc4ee5dab865caa6b267bb66b1" + integrity sha512-Cf63Rv7jCQ0LaL8tNXmEyqTHuIJxRdlS5vMh1mj5voN4+QFhVZnlZruezqpWYDiJ8UTzhP0VmeLXCmBk66YrMQ== + dependencies: + "@types/node" "*" + +"@types/prettier@^1.13.2": + version "1.19.1" + resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-1.19.1.tgz#33509849f8e679e4add158959fdb086440e9553f" + integrity sha512-5qOlnZscTn4xxM5MeGXAMOsIOIKIbh9e85zJWfBRVPlRMEVawzoPhINYbRGkBZCI8LxvBe7tJCdWiarA99OZfQ== + +"@types/prettier@^2.1.5": + version "2.7.0" + resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.7.0.tgz#ea03e9f0376a4446f44797ca19d9c46c36e352dc" + integrity sha512-RI1L7N4JnW5gQw2spvL7Sllfuf1SaHdrZpCHiBlCXjIlufi1SMNnbu2teze3/QE67Fg2tBlH7W+mi4hVNk4p0A== + +"@types/qs@*": + version "6.9.7" + resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.7.tgz#63bb7d067db107cc1e457c303bc25d511febf6cb" + integrity sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw== + +"@types/range-parser@*": + version "1.2.4" + resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.4.tgz#cd667bcfdd025213aafb7ca5915a932590acdcdc" + integrity sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw== + +"@types/resolve@^0.0.8": + version "0.0.8" + resolved "https://registry.yarnpkg.com/@types/resolve/-/resolve-0.0.8.tgz#f26074d238e02659e323ce1a13d041eee280e194" + integrity sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ== + dependencies: + "@types/node" "*" + +"@types/responselike@*", "@types/responselike@^1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@types/responselike/-/responselike-1.0.0.tgz#251f4fe7d154d2bad125abe1b429b23afd262e29" + integrity sha512-85Y2BjiufFzaMIlvJDvTTB8Fxl2xfLo4HgmHzVBz08w4wDePCTjYw66PdrolO0kzli3yam/YCgRufyo1DdQVTA== + dependencies: + "@types/node" "*" + +"@types/retry@*": + version "0.12.2" + resolved "https://registry.yarnpkg.com/@types/retry/-/retry-0.12.2.tgz#ed279a64fa438bb69f2480eda44937912bb7480a" + integrity sha512-XISRgDJ2Tc5q4TRqvgJtzsRkFYNJzZrhTdtMoGVBttwzzQJkPnS3WWTFc7kuDRoPtPakl+T+OfdEUjYJj7Jbow== + +"@types/secp256k1@^4.0.1": + version "4.0.3" + resolved "https://registry.yarnpkg.com/@types/secp256k1/-/secp256k1-4.0.3.tgz#1b8e55d8e00f08ee7220b4d59a6abe89c37a901c" + integrity sha512-Da66lEIFeIz9ltsdMZcpQvmrmmoqrfju8pm1BH8WbYjZSwUgCwXLb9C+9XYogwBITnbsSaMdVPb2ekf7TV+03w== + dependencies: + "@types/node" "*" + +"@types/seedrandom@3.0.1": + version "3.0.1" + resolved "https://registry.yarnpkg.com/@types/seedrandom/-/seedrandom-3.0.1.tgz#1254750a4fec4aff2ebec088ccd0bb02e91fedb4" + integrity sha512-giB9gzDeiCeloIXDgzFBCgjj1k4WxcDrZtGl6h1IqmUPlxF+Nx8Ve+96QCyDZ/HseB/uvDsKbpib9hU5cU53pw== + +"@types/semver@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-5.5.0.tgz#146c2a29ee7d3bae4bf2fcb274636e264c813c45" + integrity sha512-41qEJgBH/TWgo5NFSvBCJ1qkoi3Q6ONSF2avrHq1LVEZfYpdHmj0y9SuTK+u9ZhG1sYQKBL1AWXKyLWP4RaUoQ== + +"@types/serve-static@*": + version "1.15.0" + resolved "https://registry.yarnpkg.com/@types/serve-static/-/serve-static-1.15.0.tgz#c7930ff61afb334e121a9da780aac0d9b8f34155" + integrity sha512-z5xyF6uh8CbjAu9760KDKsH2FcDxZ2tFCsA4HIMWE6IkiYMXfVoa+4f9KX+FN0ZLsaMw1WNG2ETLA6N+/YA+cg== + dependencies: + "@types/mime" "*" + "@types/node" "*" + +"@types/stack-utils@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-1.0.1.tgz#0a851d3bd96498fa25c33ab7278ed3bd65f06c3e" + integrity sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw== + +"@types/stack-utils@^2.0.0": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.1.tgz#20f18294f797f2209b5f65c8e3b5c8e8261d127c" + integrity sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw== + +"@types/stats-lite@^2.2.0": + version "2.2.0" + resolved "https://registry.yarnpkg.com/@types/stats-lite/-/stats-lite-2.2.0.tgz#bc8190bf9dfa1e16b89eaa2b433c99dff0804de9" + integrity sha512-YV6SS4QC+pbzqjMIV8qVSTDOOazgKBLTVaN+7PfuxELjz/eyzc20KwDVGPrbHt2OcYMA7K2ezLB45Cp6DpNOSQ== + +"@types/superagent@*": + version "4.1.15" + resolved "https://registry.yarnpkg.com/@types/superagent/-/superagent-4.1.15.tgz#63297de457eba5e2bc502a7609426c4cceab434a" + integrity sha512-mu/N4uvfDN2zVQQ5AYJI/g4qxn2bHB6521t1UuH09ShNWjebTqN0ZFuYK9uYjcgmI0dTQEs+Owi1EO6U0OkOZQ== + dependencies: + "@types/cookiejar" "*" + "@types/node" "*" + +"@types/supertest@^2.0.11": + version "2.0.12" + resolved "https://registry.yarnpkg.com/@types/supertest/-/supertest-2.0.12.tgz#ddb4a0568597c9aadff8dbec5b2e8fddbe8692fc" + integrity sha512-X3HPWTwXRerBZS7Mo1k6vMVR1Z6zmJcDVn5O/31whe0tnjE4te6ZJSJGq1RiqHPjzPdMTfjCFogDJmwng9xHaQ== + dependencies: + "@types/superagent" "*" + +"@types/swagger-ui-express@^4.1.3": + version "4.1.3" + resolved "https://registry.yarnpkg.com/@types/swagger-ui-express/-/swagger-ui-express-4.1.3.tgz#7adbbbf5343b45869debef1e9ff39c9ba73e380f" + integrity sha512-jqCjGU/tGEaqIplPy3WyQg+Nrp6y80DCFnDEAvVKWkJyv0VivSSDCChkppHRHAablvInZe6pijDFMnavtN0vqA== + dependencies: + "@types/express" "*" + "@types/serve-static" "*" + +"@types/uuid@^8.3.4": + version "8.3.4" + resolved "https://registry.yarnpkg.com/@types/uuid/-/uuid-8.3.4.tgz#bd86a43617df0594787d38b735f55c805becf1bc" + integrity sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw== + +"@types/ws@^7.4.4": + version "7.4.7" + resolved "https://registry.yarnpkg.com/@types/ws/-/ws-7.4.7.tgz#f7c390a36f7a0679aa69de2d501319f4f8d9b702" + integrity sha512-JQbbmxZTZehdc2iszGKs5oC3NFnjeay7mtAWrdt7qNtAVK0g19muApzAy4bm9byz79xa2ZnO/BOBC2R8RC5Lww== + dependencies: + "@types/node" "*" + +"@types/yargs-parser@*": + version "21.0.0" + resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-21.0.0.tgz#0c60e537fa790f5f9472ed2776c2b71ec117351b" + integrity sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA== + +"@types/yargs@^13.0.0": + version "13.0.12" + resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-13.0.12.tgz#d895a88c703b78af0465a9de88aa92c61430b092" + integrity sha512-qCxJE1qgz2y0hA4pIxjBR+PelCH0U5CK1XJXFwCNqfmliatKp47UCXXE9Dyk1OXBDLvsCF57TqQEJaeLfDYEOQ== + dependencies: + "@types/yargs-parser" "*" + +"@types/yargs@^16.0.0": + version "16.0.4" + resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-16.0.4.tgz#26aad98dd2c2a38e421086ea9ad42b9e51642977" + integrity sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw== + dependencies: + "@types/yargs-parser" "*" + +"@typescript-eslint/eslint-plugin@^4.26.1": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.33.0.tgz#c24dc7c8069c7706bc40d99f6fa87edcb2005276" + integrity sha512-aINiAxGVdOl1eJyVjaWn/YcVAq4Gi/Yo35qHGCnqbWVz61g39D0h23veY/MA0rFFGfxK7TySg2uwDeNv+JgVpg== + dependencies: + "@typescript-eslint/experimental-utils" "4.33.0" + "@typescript-eslint/scope-manager" "4.33.0" + debug "^4.3.1" + functional-red-black-tree "^1.0.1" + ignore "^5.1.8" + regexpp "^3.1.0" + semver "^7.3.5" + tsutils "^3.21.0" + +"@typescript-eslint/experimental-utils@4.33.0": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-4.33.0.tgz#6f2a786a4209fa2222989e9380b5331b2810f7fd" + integrity sha512-zeQjOoES5JFjTnAhI5QY7ZviczMzDptls15GFsI6jyUOq0kOf9+WonkhtlIhh0RgHRnqj5gdNxW5j1EvAyYg6Q== + dependencies: + "@types/json-schema" "^7.0.7" + "@typescript-eslint/scope-manager" "4.33.0" + "@typescript-eslint/types" "4.33.0" + "@typescript-eslint/typescript-estree" "4.33.0" + eslint-scope "^5.1.1" + eslint-utils "^3.0.0" + +"@typescript-eslint/parser@^4.26.1": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-4.33.0.tgz#dfe797570d9694e560528d18eecad86c8c744899" + integrity sha512-ZohdsbXadjGBSK0/r+d87X0SBmKzOq4/S5nzK6SBgJspFo9/CUDJ7hjayuze+JK7CZQLDMroqytp7pOcFKTxZA== + dependencies: + "@typescript-eslint/scope-manager" "4.33.0" + "@typescript-eslint/types" "4.33.0" + "@typescript-eslint/typescript-estree" "4.33.0" + debug "^4.3.1" + +"@typescript-eslint/scope-manager@4.33.0": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-4.33.0.tgz#d38e49280d983e8772e29121cf8c6e9221f280a3" + integrity sha512-5IfJHpgTsTZuONKbODctL4kKuQje/bzBRkwHE8UOZ4f89Zeddg+EGZs8PD8NcN4LdM3ygHWYB3ukPAYjvl/qbQ== + dependencies: + "@typescript-eslint/types" "4.33.0" + "@typescript-eslint/visitor-keys" "4.33.0" + +"@typescript-eslint/types@4.33.0": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-4.33.0.tgz#a1e59036a3b53ae8430ceebf2a919dc7f9af6d72" + integrity sha512-zKp7CjQzLQImXEpLt2BUw1tvOMPfNoTAfb8l51evhYbOEEzdWyQNmHWWGPR6hwKJDAi+1VXSBmnhL9kyVTTOuQ== + +"@typescript-eslint/typescript-estree@4.33.0": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-4.33.0.tgz#0dfb51c2908f68c5c08d82aefeaf166a17c24609" + integrity sha512-rkWRY1MPFzjwnEVHsxGemDzqqddw2QbTJlICPD9p9I9LfsO8fdmfQPOX3uKfUaGRDFJbfrtm/sXhVXN4E+bzCA== + dependencies: + "@typescript-eslint/types" "4.33.0" + "@typescript-eslint/visitor-keys" "4.33.0" + debug "^4.3.1" + globby "^11.0.3" + is-glob "^4.0.1" + semver "^7.3.5" + tsutils "^3.21.0" + +"@typescript-eslint/visitor-keys@4.33.0": + version "4.33.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-4.33.0.tgz#2a22f77a41604289b7a186586e9ec48ca92ef1dd" + integrity sha512-uqi/2aSz9g2ftcHWf8uLPJA70rUv6yuMW5Bohw+bwcuzaxQIHaKFZCKGoGXIrc9vkTJ3+0txM73K0Hq3d5wgIg== + dependencies: + "@typescript-eslint/types" "4.33.0" + eslint-visitor-keys "^2.0.0" + +"@ungap/promise-all-settled@1.1.2": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz#aa58042711d6e3275dd37dc597e5d31e8c290a44" + integrity sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q== + +"@uniswap/default-token-list@^2.0.0": + version "2.3.0" + resolved "https://registry.yarnpkg.com/@uniswap/default-token-list/-/default-token-list-2.3.0.tgz#e5e522e775791999643aac9b0faf1ccfb4c49bd8" + integrity sha512-yfd4snv9K20tEbNwy9Vjym41RU3Yb2lN0seKxsgkr+m3f6oub2lWyXfTiNwgGFbOQPDvX4dxjMhA+M+S7mxqKg== + +"@uniswap/lib@^4.0.1-alpha": + version "4.0.1-alpha" + resolved "https://registry.yarnpkg.com/@uniswap/lib/-/lib-4.0.1-alpha.tgz#2881008e55f075344675b3bca93f020b028fbd02" + integrity sha512-f6UIliwBbRsgVLxIaBANF6w09tYqc6Y/qXdsrbEmXHyFA7ILiKrIwRFXe1yOg8M3cksgVsO9N7yuL2DdCGQKBA== + +"@uniswap/router-sdk@^1.2.0": + version "1.3.0" + resolved "https://registry.yarnpkg.com/@uniswap/router-sdk/-/router-sdk-1.3.0.tgz#8c17e957f65099a18dda536cd05fc34e779628aa" + integrity sha512-T6kXQFXrAkIHfCCmhyW+0xgUyuFVepL9rlwG9+MjnfVtmGIBssbMzyFKGk5HGQYlk6WQrm630W1j87kdfXpZ/Q== + dependencies: + "@ethersproject/abi" "^5.5.0" + "@uniswap/sdk-core" "^3.0.1" + "@uniswap/swap-router-contracts" "1.1.0" + "@uniswap/v2-sdk" "^3.0.1" + "@uniswap/v3-sdk" "^3.8.3" + +"@uniswap/sdk-core@^3.0.0", "@uniswap/sdk-core@^3.0.0-alpha.3", "@uniswap/sdk-core@^3.0.1": + version "3.0.1" + resolved "https://registry.yarnpkg.com/@uniswap/sdk-core/-/sdk-core-3.0.1.tgz#d08dd68257983af64b9a5f4d6b9cf26124b4138f" + integrity sha512-WbeDkhZ9myVR0VnHOdTrb8nHKKkqTFa5uE9RvUbG3eyDt2NWWDwhhqGHwAWJEHG405l30Fa1u3PogHDFsIOQlA== + dependencies: + "@ethersproject/address" "^5.0.2" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.4" + tiny-invariant "^1.1.0" + toformat "^2.0.0" + +"@uniswap/sdk@3.0.2": + version "3.0.2" + resolved "https://registry.yarnpkg.com/@uniswap/sdk/-/sdk-3.0.2.tgz#c75da48a8d7c3e62556c2b29d6c0f75f133d6afa" + integrity sha512-x6dYbxs3xUi1BOeGj3UqunFaWaJffzqAdSABZSPqyG3hhLpLa2AR4ehH9ZgtTVGF4Rq4MF7UDOHeXMA8AqwyaA== + dependencies: + "@ethersproject/address" "^5.0.1" + "@ethersproject/contracts" "^5.0.1" + "@ethersproject/networks" "^5.0.1" + "@ethersproject/providers" "^5.0.4" + "@ethersproject/solidity" "^5.0.1" + "@uniswap/v2-core" "^1.0.0" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.1" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +"@uniswap/smart-order-router@^2.5.26": + version "2.8.2" + resolved "https://registry.yarnpkg.com/@uniswap/smart-order-router/-/smart-order-router-2.8.2.tgz#cb521e1e02351ab18b35ca50f7a6c6f3eec2dc55" + integrity sha512-wV34O6QkRJPz52VClzCKmJ1wUY/WrIAC/L6oifySeJjqNh92xQ+HfNjZav+NPAjkz6GUD4UN4qCghi5wrR62ZA== + dependencies: + "@nomiclabs/hardhat-ethers" "^2.0.6" + "@types/async-retry" "^1.4.2" + "@types/await-timeout" "^0.3.1" + "@types/bunyan" "^1.8.6" + "@types/bunyan-blackhole" "^0.2.2" + "@types/lodash" "^4.14.168" + "@types/stats-lite" "^2.2.0" + "@uniswap/default-token-list" "^2.0.0" + "@uniswap/router-sdk" "^1.2.0" + "@uniswap/swap-router-contracts" "1.2.0" + "@uniswap/token-lists" "^1.0.0-beta.25" + "@uniswap/v2-sdk" "^3.0.1" + "@uniswap/v3-sdk" "^3.7.0" + async-retry "^1.3.1" + await-timeout "^1.1.1" + axios "^0.21.1" + bunyan "^1.8.15" + bunyan-blackhole "^1.1.1" + bunyan-debug-stream "^2.0.0" + ethers "^5.6.1" + graphql "^15.5.0" + graphql-request "^3.4.0" + hardhat "^2.9.6" + lodash "^4.17.21" + mnemonist "^0.38.3" + node-cache "^5.1.2" + stats-lite "^2.2.0" + +"@uniswap/swap-router-contracts@1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@uniswap/swap-router-contracts/-/swap-router-contracts-1.1.0.tgz#e027b14d4c172f231c53c48e1fd708a78d7d94d8" + integrity sha512-GPmpx1lvjXWloB95+YUabr3UHJYr3scnSS8EzaNXnNrIz9nYZ+XQcMaJxOKe85Yi7IfcUQpj0HzD2TW99dtolA== + dependencies: + "@openzeppelin/contracts" "3.4.1-solc-0.7-2" + "@uniswap/v2-core" "1.0.1" + "@uniswap/v3-core" "1.0.0" + "@uniswap/v3-periphery" "1.3.0" + hardhat-watcher "^2.1.1" + +"@uniswap/swap-router-contracts@1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@uniswap/swap-router-contracts/-/swap-router-contracts-1.2.0.tgz#9fd3be07c40c697cf71804ab450ca7d6c028401d" + integrity sha512-wau6xVIrXY/7EQc3uB+A1HlRfxnewS4MAYOgcJBHGHG4OVy+X0WAl8mILC52Xx+y6vx6uQHOwH+sT3SaWi5EGw== + dependencies: + "@openzeppelin/contracts" "3.4.1-solc-0.7-2" + "@uniswap/v2-core" "1.0.1" + "@uniswap/v3-core" "1.0.0" + "@uniswap/v3-periphery" "1.3.0" + dotenv "^14.2.0" + hardhat-watcher "^2.1.1" + +"@uniswap/swap-router-contracts@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@uniswap/swap-router-contracts/-/swap-router-contracts-1.2.1.tgz#223c8b6672b7754080d95ca917763d98feb5e696" + integrity sha512-aRNiZYIOpJ0uYxujPxvQsUEuNJWLC4bvnmU40TlNej1rGWHPyDL1PmnVzebu8UpW9EGeKlvDjsNGTyo53dih9Q== + dependencies: + "@openzeppelin/contracts" "3.4.2-solc-0.7" + "@uniswap/v2-core" "1.0.1" + "@uniswap/v3-core" "1.0.0" + "@uniswap/v3-periphery" "1.4.1" + dotenv "^14.2.0" + hardhat-watcher "^2.1.1" + +"@uniswap/token-lists@^1.0.0-beta.25": + version "1.0.0-beta.30" + resolved "https://registry.yarnpkg.com/@uniswap/token-lists/-/token-lists-1.0.0-beta.30.tgz#2103ca23b8007c59ec71718d34cdc97861c409e5" + integrity sha512-HwY2VvkQ8lNR6ks5NqQfAtg+4IZqz3KV1T8d2DlI8emIn9uMmaoFbIOg0nzjqAVKKnZSbMTRRtUoAh6mmjRvog== + +"@uniswap/v2-core@1.0.1", "@uniswap/v2-core@^1.0.0", "@uniswap/v2-core@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@uniswap/v2-core/-/v2-core-1.0.1.tgz#af8f508bf183204779938969e2e54043e147d425" + integrity sha512-MtybtkUPSyysqLY2U210NBDeCHX+ltHt3oADGdjqoThZaFRDKwM6k1Nb3F0A3hk5hwuQvytFWhrWHOEq6nVJ8Q== + +"@uniswap/v2-sdk@^3.0.1": + version "3.0.1" + resolved "https://registry.yarnpkg.com/@uniswap/v2-sdk/-/v2-sdk-3.0.1.tgz#690c484104c1debd1db56a236e5497def53d698b" + integrity sha512-eSpm2gjo2CZh9FACH5fq42str/oSNyWcDxB27o5k44bEew4sxb+pld4gGIf/byJndLBvArR9PtH8c0n/goNOTw== + dependencies: + "@ethersproject/address" "^5.0.0" + "@ethersproject/solidity" "^5.0.0" + "@uniswap/sdk-core" "^3.0.0-alpha.3" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + +"@uniswap/v3-core@1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@uniswap/v3-core/-/v3-core-1.0.0.tgz#6c24adacc4c25dceee0ba3ca142b35adbd7e359d" + integrity sha512-kSC4djMGKMHj7sLMYVnn61k9nu+lHjMIxgg9CDQT+s2QYLoA56GbSK9Oxr+qJXzzygbkrmuY6cwgP6cW2JXPFA== + +"@uniswap/v3-core@^1.0.0": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@uniswap/v3-core/-/v3-core-1.0.1.tgz#b6d2bdc6ba3c3fbd610bdc502395d86cd35264a0" + integrity sha512-7pVk4hEm00j9tc71Y9+ssYpO6ytkeI0y7WE9P6UcmNzhxPePwyAxImuhVsTqWK9YFvzgtvzJHi64pBl4jUzKMQ== + +"@uniswap/v3-periphery@1.3.0": + version "1.3.0" + resolved "https://registry.yarnpkg.com/@uniswap/v3-periphery/-/v3-periphery-1.3.0.tgz#37f0a1ef6025221722e50e9f3f2009c2d5d6e4ec" + integrity sha512-HjHdI5RkjBl8zz3bqHShrbULFoZSrjbbrRHoO2vbzn+WRzTa6xY4PWphZv2Tlcb38YEKfKHp6NPl5hVedac8uw== + dependencies: + "@openzeppelin/contracts" "3.4.1-solc-0.7-2" + "@uniswap/lib" "^4.0.1-alpha" + "@uniswap/v2-core" "1.0.1" + "@uniswap/v3-core" "1.0.0" + base64-sol "1.0.1" + hardhat-watcher "^2.1.1" + +"@uniswap/v3-periphery@1.4.1", "@uniswap/v3-periphery@^1.0.1", "@uniswap/v3-periphery@^1.1.1": + version "1.4.1" + resolved "https://registry.yarnpkg.com/@uniswap/v3-periphery/-/v3-periphery-1.4.1.tgz#b90f08b7386163c0abfd7258831caef6339c7862" + integrity sha512-Ab0ZCKOQrQMKIcpBTezTsEhWfQjItd0TtkCG8mPhoQu+wC67nPaf4hYUhM6wGHeFUmDiYY5MpEQuokB0ENvoTg== + dependencies: + "@openzeppelin/contracts" "3.4.2-solc-0.7" + "@uniswap/lib" "^4.0.1-alpha" + "@uniswap/v2-core" "1.0.1" + "@uniswap/v3-core" "1.0.0" + base64-sol "1.0.1" + hardhat-watcher "^2.1.1" + +"@uniswap/v3-sdk@^3.7.0", "@uniswap/v3-sdk@^3.8.3": + version "3.9.0" + resolved "https://registry.yarnpkg.com/@uniswap/v3-sdk/-/v3-sdk-3.9.0.tgz#de93fa19f89c29d460996aa4d0b4bb6531641105" + integrity sha512-LuoF3UcY1DxSAQKJ3E4/1Eq4HaNp+x+7q9mvbpiu+/PBj+O1DjLforAMrKxu+RsA0aarmZtz7yBnAPy+akgfgQ== + dependencies: + "@ethersproject/abi" "^5.0.12" + "@ethersproject/solidity" "^5.0.9" + "@uniswap/sdk-core" "^3.0.1" + "@uniswap/swap-router-contracts" "^1.2.1" + "@uniswap/v3-periphery" "^1.1.1" + "@uniswap/v3-staker" "1.0.0" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + +"@uniswap/v3-staker@1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@uniswap/v3-staker/-/v3-staker-1.0.0.tgz#9a6915ec980852479dfc903f50baf822ff8fa66e" + integrity sha512-JV0Qc46Px5alvg6YWd+UIaGH9lDuYG/Js7ngxPit1SPaIP30AlVer1UYB7BRYeUVVxE+byUyIeN5jeQ7LLDjIw== + dependencies: + "@openzeppelin/contracts" "3.4.1-solc-0.7-2" + "@uniswap/v3-core" "1.0.0" + "@uniswap/v3-periphery" "^1.0.1" + +"@zuzu-cat/defira-sdk@^1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@zuzu-cat/defira-sdk/-/defira-sdk-1.0.0.tgz#fc9a6625cb7c91d6a81440a6317faa4e3f326ad1" + integrity sha512-NuxpUe3wGjNFDS8YAI2RHi+KH3/h3q1uH3jx6uXJ1deh0QsaxCS7j+KgFKwpJQAvLUc2/wFJuauT4SOAJfLwIw== + dependencies: + "@ethersproject/address" "^5.0.0" + "@ethersproject/contracts" "^5.6.2" + "@ethersproject/providers" "^5.6.8" + "@ethersproject/solidity" "^5.0.0" + "@uniswap/sdk-core" "^3.0.0-alpha.3" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + +JSONStream@^1.3.5: + version "1.3.5" + resolved "https://registry.yarnpkg.com/JSONStream/-/JSONStream-1.3.5.tgz#3208c1f08d3a4d99261ab64f92302bc15e111ca0" + integrity sha512-E+iruNOY8VV9s4JEbe1aNEm6MiszPRr/UfcHMz0TQh1BXSxHK+ASV1R6W4HpjBhSeS+54PIsAMCBmwD06LLsqQ== + dependencies: + jsonparse "^1.2.0" + through ">=2.2.7 <3" + +abab@^2.0.3, abab@^2.0.5: + version "2.0.6" + resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.6.tgz#41b80f2c871d19686216b82309231cfd3cb3d291" + integrity sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA== + +abbrev@1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" + integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== + +abi-decoder@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/abi-decoder/-/abi-decoder-2.4.0.tgz#99f72337c614d6ac45a28dbc83c08b44eba48ad5" + integrity sha512-TOLU2q1HgYOjs1GKGtVzaqrYkar6I2fT9a80rzx6/9EJ/5crb4nCGuro0grZayixem93T7omrajYmLiMkYDLDA== + dependencies: + web3-eth-abi "^1.2.1" + web3-utils "^1.2.1" + +abort-controller@3.0.0, abort-controller@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" + integrity sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg== + dependencies: + event-target-shim "^5.0.0" + +abortcontroller-polyfill@^1.7.3: + version "1.7.3" + resolved "https://registry.yarnpkg.com/abortcontroller-polyfill/-/abortcontroller-polyfill-1.7.3.tgz#1b5b487bd6436b5b764fd52a612509702c3144b5" + integrity sha512-zetDJxd89y3X99Kvo4qFx8GKlt6GsvN3UcRZHwU6iFA/0KiOmhkTVhe8oRoTBiTVPZu09x3vCra47+w8Yz1+2Q== + +abstract-level@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/abstract-level/-/abstract-level-1.0.3.tgz#78a67d3d84da55ee15201486ab44c09560070741" + integrity sha512-t6jv+xHy+VYwc4xqZMn2Pa9DjcdzvzZmQGRjTFc8spIbRGHgBrEKbPq+rYXc7CCo0lxgYvSgKVg9qZAhpVQSjA== + dependencies: + buffer "^6.0.3" + catering "^2.1.0" + is-buffer "^2.0.5" + level-supports "^4.0.0" + level-transcoder "^1.0.1" + module-error "^1.0.1" + queue-microtask "^1.2.3" + +abstract-leveldown@^6.2.1: + version "6.3.0" + resolved "https://registry.yarnpkg.com/abstract-leveldown/-/abstract-leveldown-6.3.0.tgz#d25221d1e6612f820c35963ba4bd739928f6026a" + integrity sha512-TU5nlYgta8YrBMNpc9FwQzRbiXsj49gsALsXadbGHt9CROPzX5fB0rWDR5mtdpOOKa5XqRFpbj1QroPAoPzVjQ== + dependencies: + buffer "^5.5.0" + immediate "^3.2.3" + level-concat-iterator "~2.0.0" + level-supports "~1.0.0" + xtend "~4.0.0" + +abstract-leveldown@^7.2.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/abstract-leveldown/-/abstract-leveldown-7.2.0.tgz#08d19d4e26fb5be426f7a57004851b39e1795a2e" + integrity sha512-DnhQwcFEaYsvYDnACLZhMmCWd3rkOeEvglpa4q5i/5Jlm3UIsWaxVzuXvDLFCSCWRO3yy2/+V/G7FusFgejnfQ== + dependencies: + buffer "^6.0.3" + catering "^2.0.0" + is-buffer "^2.0.5" + level-concat-iterator "^3.0.0" + level-supports "^2.0.1" + queue-microtask "^1.2.3" + +abstract-leveldown@~2.7.1: + version "2.7.2" + resolved "https://registry.yarnpkg.com/abstract-leveldown/-/abstract-leveldown-2.7.2.tgz#87a44d7ebebc341d59665204834c8b7e0932cc93" + integrity sha512-+OVvxH2rHVEhWLdbudP6p0+dNMXu8JA1CbhP19T8paTYAcX7oJ4OVjT+ZUVpv7mITxXHqDMej+GdqXBmXkw09w== + dependencies: + xtend "~4.0.0" + +abstract-leveldown@~6.2.1, abstract-leveldown@~6.2.3: + version "6.2.3" + resolved "https://registry.yarnpkg.com/abstract-leveldown/-/abstract-leveldown-6.2.3.tgz#036543d87e3710f2528e47040bc3261b77a9a8eb" + integrity sha512-BsLm5vFMRUrrLeCcRc+G0t2qOaTzpoJQLOubq2XM72eNpjF5UdU5o/5NvlNhx95XHcAvcl8OMXr4mlg/fRgUXQ== + dependencies: + buffer "^5.5.0" + immediate "^3.2.3" + level-concat-iterator "~2.0.0" + level-supports "~1.0.0" + xtend "~4.0.0" + +accepts@^1.3.5, accepts@~1.3.8: + version "1.3.8" + resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" + integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== + dependencies: + mime-types "~2.1.34" + negotiator "0.6.3" + +acorn-globals@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-6.0.0.tgz#46cdd39f0f8ff08a876619b55f5ac8a6dc770b45" + integrity sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg== + dependencies: + acorn "^7.1.1" + acorn-walk "^7.1.1" + +acorn-jsx@^5.3.1: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + +acorn-walk@^7.1.1: + version "7.2.0" + resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-7.2.0.tgz#0de889a601203909b0fbe07b8938dc21d2e967bc" + integrity sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA== + +acorn-walk@^8.1.1: + version "8.2.0" + resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1" + integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== + +acorn@^7.1.1, acorn@^7.4.0: + version "7.4.1" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" + integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== + +acorn@^8.2.4, acorn@^8.4.1: + version "8.8.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.0.tgz#88c0187620435c7f6015803f5539dae05a9dbea8" + integrity sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w== + +add@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/add/-/add-2.0.6.tgz#248f0a9f6e5a528ef2295dbeec30532130ae2235" + integrity sha512-j5QzrmsokwWWp6kUcJQySpbG+xfOBqqKnup3OIk1pz+kB/80SLorZ9V8zHFLO92Lcd+hbvq8bT+zOGoPkmBV0Q== + +adm-zip@^0.4.16: + version "0.4.16" + resolved "https://registry.yarnpkg.com/adm-zip/-/adm-zip-0.4.16.tgz#cf4c508fdffab02c269cbc7f471a875f05570365" + integrity sha512-TFi4HBKSGfIKsK5YCkKaaFG2m4PEDyViZmEwof3MTIgzimHLto6muaHVpbrljdIvIrFZzEq/p4nafOeLcYegrg== + +aes-js@3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/aes-js/-/aes-js-3.0.0.tgz#e21df10ad6c2053295bcbb8dab40b09dbea87e4d" + integrity sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw== + +aes-js@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/aes-js/-/aes-js-3.1.2.tgz#db9aabde85d5caabbfc0d4f2a4446960f627146a" + integrity sha512-e5pEa2kBnBOgR4Y/p20pskXI74UEz7de8ZGVo58asOtvSVG5YAbJeELPZxOmt+Bnz3rX753YKhfIn4X4l1PPRQ== + +agent-base@6: + version "6.0.2" + resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" + integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== + dependencies: + debug "4" + +aggregate-error@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" + integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== + dependencies: + clean-stack "^2.0.0" + indent-string "^4.0.0" + +ajv-formats@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/ajv-formats/-/ajv-formats-2.1.1.tgz#6e669400659eb74973bbf2e33327180a0996b520" + integrity sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA== + dependencies: + ajv "^8.0.0" + +ajv@^6.10.0, ajv@^6.12.3, ajv@^6.12.4: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + +ajv@^8.0.0, ajv@^8.0.1, ajv@^8.6.3: + version "8.11.0" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.11.0.tgz#977e91dd96ca669f54a11e23e378e33b884a565f" + integrity sha512-wGgprdCvMalC0BztXvitD2hC04YffAvtsUn93JbGXYLAtCUO4xd17mCCZQxUOItiBwZvJScWo8NIvQMQ71rdpg== + dependencies: + fast-deep-equal "^3.1.1" + json-schema-traverse "^1.0.0" + require-from-string "^2.0.2" + uri-js "^4.2.2" + +ansi-colors@4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.1.tgz#cbb9ae256bf750af1eab344f229aa27fe94ba348" + integrity sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA== + +ansi-colors@^4.1.1: + version "4.1.3" + resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.3.tgz#37611340eb2243e70cc604cad35d63270d48781b" + integrity sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw== + +ansi-escapes@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-3.2.0.tgz#8780b98ff9dbf5638152d1f1fe5c1d7b4442976b" + integrity sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ== + +ansi-escapes@^4.2.1, ansi-escapes@^4.3.0: + version "4.3.2" + resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" + integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== + dependencies: + type-fest "^0.21.3" + +ansi-regex@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" + integrity sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA== + +ansi-regex@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.1.tgz#123d6479e92ad45ad897d4054e3c7ca7db4944e1" + integrity sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw== + +ansi-regex@^4.0.0, ansi-regex@^4.1.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.1.tgz#164daac87ab2d6f6db3a29875e2d1766582dabed" + integrity sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g== + +ansi-regex@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== + +ansi-styles@^3.2.0, ansi-styles@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" + integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== + dependencies: + color-convert "^1.9.0" + +ansi-styles@^4.0.0, ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + +ansi-styles@^5.0.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" + integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== + +antlr4ts@^0.5.0-alpha.4: + version "0.5.0-alpha.4" + resolved "https://registry.yarnpkg.com/antlr4ts/-/antlr4ts-0.5.0-alpha.4.tgz#71702865a87478ed0b40c0709f422cf14d51652a" + integrity sha512-WPQDt1B74OfPv/IMS2ekXAKkTZIHl88uMetg6q3OTqgFxZ/dxDXI0EWLyZid/1Pe6hTftyg5N7gel5wNAGxXyQ== + +any-promise@1.3.0, any-promise@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f" + integrity sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A== + +anymatch@^3.0.3, anymatch@~3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" + integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== + dependencies: + normalize-path "^3.0.0" + picomatch "^2.0.4" + +apollo-datasource@^3.3.2: + version "3.3.2" + resolved "https://registry.yarnpkg.com/apollo-datasource/-/apollo-datasource-3.3.2.tgz#5711f8b38d4b7b53fb788cb4dbd4a6a526ea74c8" + integrity sha512-L5TiS8E2Hn/Yz7SSnWIVbZw0ZfEIXZCa5VUiVxD9P53JvSrf4aStvsFDlGWPvpIdCR+aly2CfoB79B9/JjKFqg== + dependencies: + "@apollo/utils.keyvaluecache" "^1.0.1" + apollo-server-env "^4.2.1" + +apollo-reporting-protobuf@^3.3.1, apollo-reporting-protobuf@^3.3.3: + version "3.3.3" + resolved "https://registry.yarnpkg.com/apollo-reporting-protobuf/-/apollo-reporting-protobuf-3.3.3.tgz#df2b7ff73422cd682af3f1805d32301aefdd9e89" + integrity sha512-L3+DdClhLMaRZWVmMbBcwl4Ic77CnEBPXLW53F7hkYhkaZD88ivbCVB1w/x5gunO6ZHrdzhjq0FHmTsBvPo7aQ== + dependencies: + "@apollo/protobufjs" "1.2.6" + +apollo-server-core@^3.10.3: + version "3.10.3" + resolved "https://registry.yarnpkg.com/apollo-server-core/-/apollo-server-core-3.10.3.tgz#64db45703785e9e79e7c5dadb6df2f7ee6fcbecc" + integrity sha512-PiTirlcaszgnJGzSsGui9XWh0KAh0BUW+GvRKN6O0H0qOSXSLmoqqyL83J+u+HaUZGyyiE0+VOkyCcuF+kKbEw== + dependencies: + "@apollo/utils.keyvaluecache" "^1.0.1" + "@apollo/utils.logger" "^1.0.0" + "@apollo/utils.usagereporting" "^1.0.0" + "@apollographql/apollo-tools" "^0.5.3" + "@apollographql/graphql-playground-html" "1.6.29" + "@graphql-tools/mock" "^8.1.2" + "@graphql-tools/schema" "^8.0.0" + "@josephg/resolvable" "^1.0.0" + apollo-datasource "^3.3.2" + apollo-reporting-protobuf "^3.3.3" + apollo-server-env "^4.2.1" + apollo-server-errors "^3.3.1" + apollo-server-plugin-base "^3.6.3" + apollo-server-types "^3.6.3" + async-retry "^1.2.1" + fast-json-stable-stringify "^2.1.0" + graphql-tag "^2.11.0" + loglevel "^1.6.8" + lru-cache "^6.0.0" + sha.js "^2.4.11" + uuid "^9.0.0" + whatwg-mimetype "^3.0.0" + +apollo-server-env@^4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/apollo-server-env/-/apollo-server-env-4.2.1.tgz#ea5b1944accdbdba311f179e4dfaeca482c20185" + integrity sha512-vm/7c7ld+zFMxibzqZ7SSa5tBENc4B0uye9LTfjJwGoQFY5xsUPH5FpO5j0bMUDZ8YYNbrF9SNtzc5Cngcr90g== + dependencies: + node-fetch "^2.6.7" + +apollo-server-errors@^3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/apollo-server-errors/-/apollo-server-errors-3.3.1.tgz#ba5c00cdaa33d4cbd09779f8cb6f47475d1cd655" + integrity sha512-xnZJ5QWs6FixHICXHxUfm+ZWqqxrNuPlQ+kj5m6RtEgIpekOPssH/SD9gf2B4HuWV0QozorrygwZnux8POvyPA== + +apollo-server-express@^3.10.3: + version "3.10.3" + resolved "https://registry.yarnpkg.com/apollo-server-express/-/apollo-server-express-3.10.3.tgz#946b857c7d8516235a757e853966dd1189f247e1" + integrity sha512-Z8m0r10mX8KlGS3noYeRPcWxWR2hX6NHJicjuwZ62PeTZlrDJF5cwGmXqbUg/sCTPx7Ny//ZEASBTwFFp8DOeQ== + dependencies: + "@types/accepts" "^1.3.5" + "@types/body-parser" "1.19.2" + "@types/cors" "2.8.12" + "@types/express" "4.17.14" + "@types/express-serve-static-core" "4.17.31" + accepts "^1.3.5" + apollo-server-core "^3.10.3" + apollo-server-types "^3.6.3" + body-parser "^1.19.0" + cors "^2.8.5" + parseurl "^1.3.3" + +apollo-server-plugin-base@^3.6.3: + version "3.6.3" + resolved "https://registry.yarnpkg.com/apollo-server-plugin-base/-/apollo-server-plugin-base-3.6.3.tgz#7eaf24af19641ddccf37307f294aba6877bf4c86" + integrity sha512-/Q0Zx8N8La97faKV0siGHDzfZ56ygN6ovtUpPbr+1GIbNmUzkte3lWW2YV08HmxiRmC2i2OGN80exNJEvbKvNA== + dependencies: + apollo-server-types "^3.6.3" + +apollo-server-types@^3.6.3: + version "3.6.3" + resolved "https://registry.yarnpkg.com/apollo-server-types/-/apollo-server-types-3.6.3.tgz#7818cab914c865dafa53ea263ca6cb1854b4f05a" + integrity sha512-+7caNTLdevpWI2dGKSa7CWdyudO3NBuJ3HzcrYxjBei6Bth9YdRUNzPSFmBjlm2baHF0GsrMwLpjO+HStJzm3A== + dependencies: + "@apollo/utils.keyvaluecache" "^1.0.1" + "@apollo/utils.logger" "^1.0.0" + apollo-reporting-protobuf "^3.3.3" + apollo-server-env "^4.2.1" + +apollo-server@^3.6.3: + version "3.10.3" + resolved "https://registry.yarnpkg.com/apollo-server/-/apollo-server-3.10.3.tgz#1da948f6494d30fb6dcb37b636c140489ea0bf39" + integrity sha512-qWaCVKmMpUmDPiug93kWbqVPt9/T9RwFsPP6cZ4MUF/0X931WrWPpYzyETPUhnVgdPzWbdVcvbXjgyKYc4NB2g== + dependencies: + "@types/express" "4.17.14" + apollo-server-core "^3.10.3" + apollo-server-express "^3.10.3" + express "^4.17.1" + +app-module-path@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/app-module-path/-/app-module-path-2.2.0.tgz#641aa55dfb7d6a6f0a8141c4b9c0aa50b6c24dd5" + integrity sha512-gkco+qxENJV+8vFcDiiFhuoSvRXb2a/QPqpSoWhVz829VNJfOTnELbBmPmNKFxf3xdNnw4DWCkzkDaavcX/1YQ== + +app-root-path@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/app-root-path/-/app-root-path-3.0.0.tgz#210b6f43873227e18a4b810a032283311555d5ad" + integrity sha512-qMcx+Gy2UZynHjOHOIXPNvpf+9cjvk3cWrBBK7zg4gH9+clobJRb9NGzcT7mQTcV/6Gm/1WelUtqxVXnNlrwcw== + +arg@^4.1.0: + version "4.1.3" + resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" + integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== + +argparse@^1.0.7: + version "1.0.10" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" + integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== + dependencies: + sprintf-js "~1.0.2" + +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + +argsarray@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/argsarray/-/argsarray-0.0.1.tgz#6e7207b4ecdb39b0af88303fa5ae22bda8df61cb" + integrity sha512-u96dg2GcAKtpTrBdDoFIM7PjcBA+6rSP0OR94MOReNRyUECL6MtQt5XXmRr4qrftYaef9+l5hcpO5te7sML1Cg== + +arr-diff@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz#d6461074febfec71e7e15235761a329a5dc7c520" + integrity sha512-YVIQ82gZPGBebQV/a8dar4AitzCQs0jjXwMPZllpXMaGjXPYVUawSxQrRsjhjupyVxEvbHgUmIhKVlND+j02kA== + +arr-flatten@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" + integrity sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg== + +arr-union@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz#e39b09aea9def866a8f206e288af63919bae39c4" + integrity sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q== + +array-back@^1.0.3, array-back@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/array-back/-/array-back-1.0.4.tgz#644ba7f095f7ffcf7c43b5f0dc39d3c1f03c063b" + integrity sha512-1WxbZvrmyhkNoeYcizokbmh5oiOCIfyvGtcqbK3Ls1v1fKcquzxnQSceOx6tzq7jmai2kFLWIpGND2cLhH6TPw== + dependencies: + typical "^2.6.0" + +array-back@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/array-back/-/array-back-2.0.0.tgz#6877471d51ecc9c9bfa6136fb6c7d5fe69748022" + integrity sha512-eJv4pLLufP3g5kcZry0j6WXpIbzYw9GUB4mVJZno9wfwiBxbizTnHCw3VJb07cBihbFX48Y7oSrW9y+gt4glyw== + dependencies: + typical "^2.6.1" + +array-flatten@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" + integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== + +array-includes@^3.1.4: + version "3.1.5" + resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.5.tgz#2c320010db8d31031fd2a5f6b3bbd4b1aad31bdb" + integrity sha512-iSDYZMMyTPkiFasVqfuAQnWAYcvO/SeBSCGKePoEthjp4LEMTe4uLc7b025o4jAZpHhihh8xPo99TNWUWWkGDQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.19.5" + get-intrinsic "^1.1.1" + is-string "^1.0.7" + +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + +array-unique@^0.3.2: + version "0.3.2" + resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428" + integrity sha512-SleRWjh9JUud2wH1hPs9rZBZ33H6T9HOiL0uwGnGx9FpE6wKGyfWugmbkEOIs6qWrZhg0LWeLziLrEwQJhs5mQ== + +array.prototype.flat@^1.2.5: + version "1.3.0" + resolved "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.3.0.tgz#0b0c1567bf57b38b56b4c97b8aa72ab45e4adc7b" + integrity sha512-12IUEkHsAhA4DY5s0FPgNXIdc8VRSqD9Zp78a5au9abH/SOBrsp082JOWFNTjkMozh8mqcdiKuaLGhPeYztxSw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.2" + es-shim-unscopables "^1.0.0" + +asap@^2.0.0: + version "2.0.6" + resolved "https://registry.yarnpkg.com/asap/-/asap-2.0.6.tgz#e50347611d7e690943208bbdafebcbc2fb866d46" + integrity sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA== + +asn1.js@^5.2.0: + version "5.4.1" + resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-5.4.1.tgz#11a980b84ebb91781ce35b0fdc2ee294e3783f07" + integrity sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA== + dependencies: + bn.js "^4.0.0" + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + safer-buffer "^2.1.0" + +asn1@~0.2.3: + version "0.2.6" + resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.6.tgz#0d3a7bb6e64e02a90c0303b31f292868ea09a08d" + integrity sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ== + dependencies: + safer-buffer "~2.1.0" + +assert-plus@1.0.0, assert-plus@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" + integrity sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw== + +assign-symbols@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367" + integrity sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw== + +astral-regex@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" + integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ== + +async-eventemitter@^0.2.4: + version "0.2.4" + resolved "https://registry.yarnpkg.com/async-eventemitter/-/async-eventemitter-0.2.4.tgz#f5e7c8ca7d3e46aab9ec40a292baf686a0bafaca" + integrity sha512-pd20BwL7Yt1zwDFy+8MX8F1+WCT8aQeKj0kQnTrH9WaeRETlRamVhD0JtRPmrV4GfOJ2F9CvdQkZeZhnh2TuHw== + dependencies: + async "^2.4.0" + +async-limiter@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/async-limiter/-/async-limiter-1.0.1.tgz#dd379e94f0db8310b08291f9d64c3209766617fd" + integrity sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ== + +async-retry@^1.2.1, async-retry@^1.3.1: + version "1.3.3" + resolved "https://registry.yarnpkg.com/async-retry/-/async-retry-1.3.3.tgz#0e7f36c04d8478e7a58bdbed80cedf977785f280" + integrity sha512-wfr/jstw9xNi/0teMHrRW7dsz3Lt5ARhYNZ2ewpadnhaIp5mbALhOAP+EAdsC7t4Z6wqsDVv9+W6gm1Dk9mEyw== + dependencies: + retry "0.13.1" + +async@^2.4.0: + version "2.6.4" + resolved "https://registry.yarnpkg.com/async/-/async-2.6.4.tgz#706b7ff6084664cd7eae713f6f965433b5504221" + integrity sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA== + dependencies: + lodash "^4.17.14" + +async@^3.2.3: + version "3.2.4" + resolved "https://registry.yarnpkg.com/async/-/async-3.2.4.tgz#2d22e00f8cddeb5fde5dd33522b56d1cf569a81c" + integrity sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ== + +asynckit@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" + integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== + +at-least-node@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" + integrity sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg== + +atob@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" + integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== + +atomically@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/atomically/-/atomically-1.7.0.tgz#c07a0458432ea6dbc9a3506fffa424b48bccaafe" + integrity sha512-Xcz9l0z7y9yQ9rdDaxlmaI4uJHf/T8g9hOEzJcsEqX2SjCj4J20uK7+ldkDHMbpJDK76wF7xEIgxc/vSlsfw5w== + +available-typed-arrays@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz#92f95616501069d07d10edb2fc37d3e1c65123b7" + integrity sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw== + +await-timeout@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/await-timeout/-/await-timeout-1.1.1.tgz#d42062ee6bc4eb271fe4d4f851eb658dae7e3906" + integrity sha512-gsDXAS6XVc4Jt+7S92MPX6Noq69bdeXUPEaXd8dk3+yVr629LTDLxNt4j1ycBbrU+AStK2PhKIyNIM+xzWMVOQ== + +aws-sign2@~0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" + integrity sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA== + +aws4@^1.8.0: + version "1.11.0" + resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.11.0.tgz#d61f46d83b2519250e2784daf5b09479a8b41c59" + integrity sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA== + +axios@0.27.2: + version "0.27.2" + resolved "https://registry.yarnpkg.com/axios/-/axios-0.27.2.tgz#207658cc8621606e586c85db4b41a750e756d972" + integrity sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ== + dependencies: + follow-redirects "^1.14.9" + form-data "^4.0.0" + +axios@^0.18.0: + version "0.18.1" + resolved "https://registry.yarnpkg.com/axios/-/axios-0.18.1.tgz#ff3f0de2e7b5d180e757ad98000f1081b87bcea3" + integrity sha512-0BfJq4NSfQXd+SkFdrvFbG7addhYSBA2mQwISr46pD6E5iqkWg02RAs8vyTT/j0RTnoYmeXauBuSv1qKwR179g== + dependencies: + follow-redirects "1.5.10" + is-buffer "^2.0.2" + +axios@^0.21.1, axios@^0.21.2: + version "0.21.4" + resolved "https://registry.yarnpkg.com/axios/-/axios-0.21.4.tgz#c67b90dc0568e5c1cf2b0b858c43ba28e2eda575" + integrity sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg== + dependencies: + follow-redirects "^1.14.0" + +babel-jest@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-27.5.1.tgz#a1bf8d61928edfefd21da27eb86a695bfd691444" + integrity sha512-cdQ5dXjGRd0IBRATiQ4mZGlGlRE8kJpjPOixdNRdT+m3UcNqmYWN6rK6nvtXYfY3D76cb8s/O1Ss8ea24PIwcg== + dependencies: + "@jest/transform" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/babel__core" "^7.1.14" + babel-plugin-istanbul "^6.1.1" + babel-preset-jest "^27.5.1" + chalk "^4.0.0" + graceful-fs "^4.2.9" + slash "^3.0.0" + +babel-plugin-istanbul@^6.1.1: + version "6.1.1" + resolved "https://registry.yarnpkg.com/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz#fa88ec59232fd9b4e36dbbc540a8ec9a9b47da73" + integrity sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA== + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@istanbuljs/load-nyc-config" "^1.0.0" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-instrument "^5.0.4" + test-exclude "^6.0.0" + +babel-plugin-jest-hoist@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.1.tgz#9be98ecf28c331eb9f5df9c72d6f89deb8181c2e" + integrity sha512-50wCwD5EMNW4aRpOwtqzyZHIewTYNxLA4nhB+09d8BIssfNfzBRhkBIHiaPv1Si226TQSvp8gxAJm2iY2qs2hQ== + dependencies: + "@babel/template" "^7.3.3" + "@babel/types" "^7.3.3" + "@types/babel__core" "^7.0.0" + "@types/babel__traverse" "^7.0.6" + +babel-preset-current-node-syntax@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz#b4399239b89b2a011f9ddbe3e4f401fc40cff73b" + integrity sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ== + dependencies: + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-bigint" "^7.8.3" + "@babel/plugin-syntax-class-properties" "^7.8.3" + "@babel/plugin-syntax-import-meta" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.8.3" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.8.3" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-top-level-await" "^7.8.3" + +babel-preset-jest@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-27.5.1.tgz#91f10f58034cb7989cb4f962b69fa6eef6a6bc81" + integrity sha512-Nptf2FzlPCWYuJg41HBqXVT8ym6bXOevuCTbhxlUpjwtysGaIWFvDEjp4y+G7fl13FgOdjs7P/DmErqH7da0Ag== + dependencies: + babel-plugin-jest-hoist "^27.5.1" + babel-preset-current-node-syntax "^1.0.0" + +balanced-match@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== + +base-x@^3.0.2, base-x@^3.0.6, base-x@^3.0.8: + version "3.0.9" + resolved "https://registry.yarnpkg.com/base-x/-/base-x-3.0.9.tgz#6349aaabb58526332de9f60995e548a53fe21320" + integrity sha512-H7JU6iBHTal1gp56aKoaa//YUxEaAOUiydvrV/pILqIHXTtqxSkATOnDA2u+jZ/61sD+L/412+7kzXRtWukhpQ== + dependencies: + safe-buffer "^5.0.1" + +base-x@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/base-x/-/base-x-4.0.0.tgz#d0e3b7753450c73f8ad2389b5c018a4af7b2224a" + integrity sha512-FuwxlW4H5kh37X/oW59pwTzzTKRzfrrQwhmyspRM7swOEZcHtDZSCt45U6oKgtuFE+WYPblePMVIPR4RZrh/hw== + +base64-js@^1.3.0, base64-js@^1.3.1, base64-js@^1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" + integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== + +base64-sol@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/base64-sol/-/base64-sol-1.0.1.tgz#91317aa341f0bc763811783c5729f1c2574600f6" + integrity sha512-ld3cCNMeXt4uJXmLZBHFGMvVpK9KsLVEhPpFRXnvSVAqABKbuNZg/+dsq3NuM+wxFLb/UrVkz7m1ciWmkMfTbg== + +base@^0.11.1: + version "0.11.2" + resolved "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz#7bde5ced145b6d551a90db87f83c558b4eb48a8f" + integrity sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg== + dependencies: + cache-base "^1.0.1" + class-utils "^0.3.5" + component-emitter "^1.2.1" + define-property "^1.0.0" + isobject "^3.0.1" + mixin-deep "^1.2.0" + pascalcase "^0.1.1" + +basic-auth@~2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/basic-auth/-/basic-auth-2.0.1.tgz#b998279bf47ce38344b4f3cf916d4679bbf51e3a" + integrity sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg== + dependencies: + safe-buffer "5.1.2" + +bcrypt-pbkdf@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e" + integrity sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w== + dependencies: + tweetnacl "^0.14.3" + +bech32@1.1.4, bech32@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/bech32/-/bech32-1.1.4.tgz#e38c9f37bf179b8eb16ae3a772b40c356d4832e9" + integrity sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ== + +big.js@^5.2.2: + version "5.2.2" + resolved "https://registry.yarnpkg.com/big.js/-/big.js-5.2.2.tgz#65f0af382f578bcdc742bd9c281e9cb2d7768328" + integrity sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ== + +big.js@^6.0.3, big.js@^6.1.0, big.js@^6.1.1, big.js@^6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/big.js/-/big.js-6.2.1.tgz#7205ce763efb17c2e41f26f121c420c6a7c2744f" + integrity sha512-bCtHMwL9LeDIozFn+oNhhFoq+yQ3BNdnsLSASUxLciOb1vgvpHsIO1dsENiGMgbb4SkP5TrzWzRiLddn8ahVOQ== + +bigint-buffer@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/bigint-buffer/-/bigint-buffer-1.1.5.tgz#d038f31c8e4534c1f8d0015209bf34b4fa6dd442" + integrity sha512-trfYco6AoZ+rKhKnxA0hgX0HAbVP/s808/EuDSe2JDzUnCp/xAsli35Orvk67UrTEcwuxZqYZDmfA2RXJgxVvA== + dependencies: + bindings "^1.3.0" + +bignumber.js@^7.2.0: + version "7.2.1" + resolved "https://registry.yarnpkg.com/bignumber.js/-/bignumber.js-7.2.1.tgz#80c048759d826800807c4bfd521e50edbba57a5f" + integrity sha512-S4XzBk5sMB+Rcb/LNcpzXr57VRTxgAvaAEDAl1AwRx27j00hT84O6OkteE7u8UB3NuaaygCRrEpqox4uDOrbdQ== + +bignumber.js@^8.0.2: + version "8.1.1" + resolved "https://registry.yarnpkg.com/bignumber.js/-/bignumber.js-8.1.1.tgz#4b072ae5aea9c20f6730e4e5d529df1271c4d885" + integrity sha512-QD46ppGintwPGuL1KqmwhR0O+N2cZUg8JG/VzwI2e28sM9TqHjQB10lI4QAaMHVbLzwVLLAwEglpKPViWX+5NQ== + +bignumber.js@^9.0.0, bignumber.js@^9.0.1: + version "9.0.2" + resolved "https://registry.yarnpkg.com/bignumber.js/-/bignumber.js-9.0.2.tgz#71c6c6bed38de64e24a65ebe16cfcf23ae693673" + integrity sha512-GAcQvbpsM0pUb0zw1EI0KhQEZ+lRwR5fYaAp3vPOYuP7aDvGy6cVN6XHLauvF8SOga2y0dcLcjt3iQDTSEliyw== + +binary-extensions@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" + integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== + +bindings@^1.3.0, bindings@^1.3.1, bindings@^1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/bindings/-/bindings-1.5.0.tgz#10353c9e945334bc0511a6d90b38fbc7c9c504df" + integrity sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ== + dependencies: + file-uri-to-path "1.0.0" + +bip39@^2.5.0: + version "2.6.0" + resolved "https://registry.yarnpkg.com/bip39/-/bip39-2.6.0.tgz#9e3a720b42ec8b3fbe4038f1e445317b6a99321c" + integrity sha512-RrnQRG2EgEoqO24ea+Q/fftuPUZLmrEM3qNhhGsA3PbaXaCW791LTzPuVyx/VprXQcTbPJ3K3UeTna8ZnVl2sg== + dependencies: + create-hash "^1.1.0" + pbkdf2 "^3.0.9" + randombytes "^2.0.1" + safe-buffer "^5.0.1" + unorm "^1.3.3" + +bip66@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/bip66/-/bip66-1.1.5.tgz#01fa8748785ca70955d5011217d1b3139969ca22" + integrity sha512-nemMHz95EmS38a26XbbdxIYj5csHd3RMP3H5bwQknX0WYHF01qhpufP42mLOwVICuH2JmhIhXiWs89MfUGL7Xw== + dependencies: + safe-buffer "^5.0.1" + +bl@^1.0.0: + version "1.2.3" + resolved "https://registry.yarnpkg.com/bl/-/bl-1.2.3.tgz#1e8dd80142eac80d7158c9dccc047fb620e035e7" + integrity sha512-pvcNpa0UU69UT341rO6AYy4FVAIkUHuZXRIWbq+zHnsVcRzDDjIAhGuuYoi0d//cwIwtt4pkpKycWEfjdV+vww== + dependencies: + readable-stream "^2.3.5" + safe-buffer "^5.1.1" + +blakejs@^1.1.0: + version "1.2.1" + resolved "https://registry.yarnpkg.com/blakejs/-/blakejs-1.2.1.tgz#5057e4206eadb4a97f7c0b6e197a505042fc3814" + integrity sha512-QXUSXI3QVc/gJME0dBpXrag1kbzOqCjCX8/b54ntNyW6sjtoqxqRk3LTmXzaJoh71zMsDCjM+47jS7XiwN/+fQ== + +bluebird@3.7.2, bluebird@^3.4.1, bluebird@^3.5.0, bluebird@^3.5.2: + version "3.7.2" + resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" + integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== + +bn.js@4.11.6: + version "4.11.6" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.11.6.tgz#53344adb14617a13f6e8dd2ce28905d1c0ba3215" + integrity sha512-XWwnNNFCuuSQ0m3r3C4LE3EiORltHd9M05pq6FOlVeiophzRbMo50Sbz1ehl8K3Z+jw9+vmgnXefY1hz8X+2wA== + +bn.js@4.11.8: + version "4.11.8" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.11.8.tgz#2cde09eb5ee341f484746bb0309b3253b1b1442f" + integrity sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA== + +bn.js@5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.0.tgz#358860674396c6997771a9d051fcc1b57d4ae002" + integrity sha512-D7iWRBvnZE8ecXiLj/9wbxH7Tk79fAh8IHaTNq1RWRixsS02W+5qS+iE9yq6RYl0asXx5tw0bLhmT5pIfbSquw== + +bn.js@5.2.1, bn.js@^5.0.0, bn.js@^5.1.0, bn.js@^5.1.1, bn.js@^5.1.2, bn.js@^5.1.3, bn.js@^5.2.0, bn.js@^5.2.1: + version "5.2.1" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.1.tgz#0bc527a6a0d18d0aa8d5b0538ce4a77dccfa7b70" + integrity sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ== + +bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.11.0, bn.js@^4.11.6, bn.js@^4.11.8, bn.js@^4.11.9, bn.js@^4.4.0: + version "4.12.0" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" + integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== + +body-parser@1.20.0, body-parser@^1.16.0, body-parser@^1.19.0: + version "1.20.0" + resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.0.tgz#3de69bd89011c11573d7bfee6a64f11b6bd27cc5" + integrity sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg== + dependencies: + bytes "3.1.2" + content-type "~1.0.4" + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + http-errors "2.0.0" + iconv-lite "0.4.24" + on-finished "2.4.1" + qs "6.10.3" + raw-body "2.5.1" + type-is "~1.6.18" + unpipe "1.0.0" + +boolbase@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" + integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww== + +borsh@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/borsh/-/borsh-0.6.0.tgz#a7c9eeca6a31ca9e0607cb49f329cb659eb791e1" + integrity sha512-sl5k89ViqsThXQpYa9XDtz1sBl3l1lI313cFUY1HKr+wvMILnb+58xpkqTNrYbelh99dY7K8usxoCusQmqix9Q== + dependencies: + bn.js "^5.2.0" + bs58 "^4.0.0" + text-encoding-utf-8 "^1.0.2" + +borsh@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/borsh/-/borsh-0.7.0.tgz#6e9560d719d86d90dc589bca60ffc8a6c51fec2a" + integrity sha512-CLCsZGIBCFnPtkNnieW/a8wmreDmfUtjU2m9yHrzPXIlNbqVs0AQrSatSG6vdNYUqdc83tkQi2eHfF98ubzQLA== + dependencies: + bn.js "^5.2.0" + bs58 "^4.0.0" + text-encoding-utf-8 "^1.0.2" + +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +brace-expansion@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== + dependencies: + balanced-match "^1.0.0" + +braces@^2.3.1: + version "2.3.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-2.3.2.tgz#5979fd3f14cd531565e5fa2df1abfff1dfaee729" + integrity sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w== + dependencies: + arr-flatten "^1.1.0" + array-unique "^0.3.2" + extend-shallow "^2.0.1" + fill-range "^4.0.0" + isobject "^3.0.1" + repeat-element "^1.1.2" + snapdragon "^0.8.1" + snapdragon-node "^2.0.1" + split-string "^3.0.2" + to-regex "^3.0.1" + +braces@^3.0.2, braces@~3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + +brorand@^1.0.1, brorand@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" + integrity sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w== + +browser-level@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/browser-level/-/browser-level-1.0.1.tgz#36e8c3183d0fe1c405239792faaab5f315871011" + integrity sha512-XECYKJ+Dbzw0lbydyQuJzwNXtOpbMSq737qxJN11sIRTErOMShvDpbzTlgju7orJKvx4epULolZAuJGLzCmWRQ== + dependencies: + abstract-level "^1.0.2" + catering "^2.1.1" + module-error "^1.0.2" + run-parallel-limit "^1.1.0" + +browser-process-hrtime@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz#3c9b4b7d782c8121e56f10106d84c0d0ffc94626" + integrity sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow== + +browser-stdout@1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/browser-stdout/-/browser-stdout-1.3.1.tgz#baa559ee14ced73452229bad7326467c61fabd60" + integrity sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw== + +browserify-aes@^1.0.0, browserify-aes@^1.0.4, browserify-aes@^1.0.6, browserify-aes@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.2.0.tgz#326734642f403dabc3003209853bb70ad428ef48" + integrity sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA== + dependencies: + buffer-xor "^1.0.3" + cipher-base "^1.0.0" + create-hash "^1.1.0" + evp_bytestokey "^1.0.3" + inherits "^2.0.1" + safe-buffer "^5.0.1" + +browserify-cipher@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.1.tgz#8d6474c1b870bfdabcd3bcfcc1934a10e94f15f0" + integrity sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w== + dependencies: + browserify-aes "^1.0.4" + browserify-des "^1.0.0" + evp_bytestokey "^1.0.0" + +browserify-des@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.2.tgz#3af4f1f59839403572f1c66204375f7a7f703e9c" + integrity sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A== + dependencies: + cipher-base "^1.0.1" + des.js "^1.0.0" + inherits "^2.0.1" + safe-buffer "^5.1.2" + +browserify-rsa@^4.0.0, browserify-rsa@^4.0.1: + version "4.1.0" + resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.1.0.tgz#b2fd06b5b75ae297f7ce2dc651f918f5be158c8d" + integrity sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog== + dependencies: + bn.js "^5.0.0" + randombytes "^2.0.1" + +browserify-sign@^4.0.0: + version "4.2.1" + resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.2.1.tgz#eaf4add46dd54be3bb3b36c0cf15abbeba7956c3" + integrity sha512-/vrA5fguVAKKAVTNJjgSm1tRQDHUU6DbwO9IROu/0WAzC8PKhucDSh18J0RMvVeHAn5puMd+QHC2erPRNf8lmg== + dependencies: + bn.js "^5.1.1" + browserify-rsa "^4.0.1" + create-hash "^1.2.0" + create-hmac "^1.1.7" + elliptic "^6.5.3" + inherits "^2.0.4" + parse-asn1 "^5.1.5" + readable-stream "^3.6.0" + safe-buffer "^5.2.0" + +browserslist@^4.20.2: + version "4.21.3" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.21.3.tgz#5df277694eb3c48bc5c4b05af3e8b7e09c5a6d1a" + integrity sha512-898rgRXLAyRkM1GryrrBHGkqA5hlpkV5MhtZwg9QXeiyLUYs2k00Un05aX5l2/yJIOObYKOpS2JNo8nJDE7fWQ== + dependencies: + caniuse-lite "^1.0.30001370" + electron-to-chromium "^1.4.202" + node-releases "^2.0.6" + update-browserslist-db "^1.0.5" + +bs-logger@0.x: + version "0.2.6" + resolved "https://registry.yarnpkg.com/bs-logger/-/bs-logger-0.2.6.tgz#eb7d365307a72cf974cc6cda76b68354ad336bd8" + integrity sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog== + dependencies: + fast-json-stable-stringify "2.x" + +bs58@^4.0.0, bs58@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/bs58/-/bs58-4.0.1.tgz#be161e76c354f6f788ae4071f63f34e8c4f0a42a" + integrity sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw== + dependencies: + base-x "^3.0.2" + +bs58@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/bs58/-/bs58-5.0.0.tgz#865575b4d13c09ea2a84622df6c8cbeb54ffc279" + integrity sha512-r+ihvQJvahgYT50JD05dyJNKlmmSlMoOGwn1lCcEzanPglg7TxYjioQUYehQ9mAR/+hOSd2jRc/Z2y5UxBymvQ== + dependencies: + base-x "^4.0.0" + +bs58check@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/bs58check/-/bs58check-2.1.2.tgz#53b018291228d82a5aa08e7d796fdafda54aebfc" + integrity sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA== + dependencies: + bs58 "^4.0.0" + create-hash "^1.1.0" + safe-buffer "^5.1.2" + +bser@2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/bser/-/bser-2.1.1.tgz#e6787da20ece9d07998533cfd9de6f5c38f4bc05" + integrity sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ== + dependencies: + node-int64 "^0.4.0" + +buffer-alloc-unsafe@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/buffer-alloc-unsafe/-/buffer-alloc-unsafe-1.1.0.tgz#bd7dc26ae2972d0eda253be061dba992349c19f0" + integrity sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg== + +buffer-alloc@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/buffer-alloc/-/buffer-alloc-1.2.0.tgz#890dd90d923a873e08e10e5fd51a57e5b7cce0ec" + integrity sha512-CFsHQgjtW1UChdXgbyJGtnm+O/uLQeZdtbDo8mfUgYXCHSM1wgrVxXm6bSyrUuErEb+4sYVGCzASBRot7zyrow== + dependencies: + buffer-alloc-unsafe "^1.1.0" + buffer-fill "^1.0.0" + +buffer-crc32@~0.2.3: + version "0.2.13" + resolved "https://registry.yarnpkg.com/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242" + integrity sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ== + +buffer-fill@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/buffer-fill/-/buffer-fill-1.0.0.tgz#f8f78b76789888ef39f205cd637f68e702122b2c" + integrity sha512-T7zexNBwiiaCOGDg9xNX9PBmjrubblRkENuptryuI64URkXDFum9il/JGL8Lm8wYfAXpredVXXZz7eMHilimiQ== + +buffer-from@1.1.2, buffer-from@^1.0.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" + integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== + +buffer-layout@^1.2.0, buffer-layout@^1.2.1, buffer-layout@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/buffer-layout/-/buffer-layout-1.2.2.tgz#b9814e7c7235783085f9ca4966a0cfff112259d5" + integrity sha512-kWSuLN694+KTk8SrYvCqwP2WcgQjoRCiF5b4QDvkkz8EmgD+aWAIceGFKMIAdmF/pH+vpgNV3d3kAKorcdAmWA== + +buffer-to-arraybuffer@^0.0.5: + version "0.0.5" + resolved "https://registry.yarnpkg.com/buffer-to-arraybuffer/-/buffer-to-arraybuffer-0.0.5.tgz#6064a40fa76eb43c723aba9ef8f6e1216d10511a" + integrity sha512-3dthu5CYiVB1DEJp61FtApNnNndTckcqe4pFcLdvHtrpG+kcyekCJKg4MRiDcFW7A6AODnXB9U4dwQiCW5kzJQ== + +buffer-xor@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" + integrity sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ== + +buffer-xor@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-2.0.2.tgz#34f7c64f04c777a1f8aac5e661273bb9dd320289" + integrity sha512-eHslX0bin3GB+Lx2p7lEYRShRewuNZL3fUl4qlVJGGiwoPGftmt8JQgk2Y9Ji5/01TnVDo33E5b5O3vUB1HdqQ== + dependencies: + safe-buffer "^5.1.1" + +buffer@6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.1.tgz#3cbea8c1463e5a0779e30b66d4c88c6ffa182ac2" + integrity sha512-rVAXBwEcEoYtxnHSO5iWyhzV/O1WMtkUYWlfdLS7FjU4PnSJJHEfHXi/uHPI5EwltmOA794gN3bm3/pzuctWjQ== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.2.1" + +buffer@6.0.3, buffer@^6.0.3, buffer@~6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" + integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.2.1" + +buffer@^5.0.5, buffer@^5.2.1, buffer@^5.4.3, buffer@^5.5.0, buffer@^5.6.0: + version "5.7.1" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.7.1.tgz#ba62e7c13133053582197160851a8f648e99eed0" + integrity sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.1.13" + +bufferutil@4.0.5: + version "4.0.5" + resolved "https://registry.yarnpkg.com/bufferutil/-/bufferutil-4.0.5.tgz#da9ea8166911cc276bf677b8aed2d02d31f59028" + integrity sha512-HTm14iMQKK2FjFLRTM5lAVcyaUzOnqbPtesFIvREgXpJHdQm8bWS+GkQgIkfaBYRHuCnea7w8UVNfwiAQhlr9A== + dependencies: + node-gyp-build "^4.3.0" + +bufferutil@^4.0.1: + version "4.0.6" + resolved "https://registry.yarnpkg.com/bufferutil/-/bufferutil-4.0.6.tgz#ebd6c67c7922a0e902f053e5d8be5ec850e48433" + integrity sha512-jduaYOYtnio4aIAyc6UbvPCVcgq7nYpVnucyxr6eCYg/Woad9Hf/oxxBRDnGGjPfjUm6j5O/uBWhIu4iLebFaw== + dependencies: + node-gyp-build "^4.3.0" + +bunyan-blackhole@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/bunyan-blackhole/-/bunyan-blackhole-1.1.1.tgz#b9208586dc0b4e47f4f713215b1bddd65e4f6257" + integrity sha512-UwzNPhbbSqbzeJhCbygqjlAY7p0ZUdv1ADXPQvDh3CA7VW3C/rCc1gaQO/8j9QL4vsKQCQZQSQIEwX+lxioPAQ== + dependencies: + stream-blackhole "^1.0.3" + +bunyan-debug-stream@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/bunyan-debug-stream/-/bunyan-debug-stream-2.0.1.tgz#9bd7c7e30c7b2cf711317e9d37529b0464c3b164" + integrity sha512-MCEoqggU7NMt7f2O+PU8VkqfSkoQoa4lmN/OWhaRfqFRBF1Se2TOXQyLF6NxC+EtfrdthnquQe8jOe83fpEoGA== + dependencies: + colors "1.4.0" + exception-formatter "^1.0.4" + +bunyan@^1.8.15: + version "1.8.15" + resolved "https://registry.yarnpkg.com/bunyan/-/bunyan-1.8.15.tgz#8ce34ca908a17d0776576ca1b2f6cbd916e93b46" + integrity sha512-0tECWShh6wUysgucJcBAoYegf3JJoZWibxdqhTm7OHPeT42qdjkZ29QCMcKwbgU1kiH+auSIasNRXMLWXafXig== + optionalDependencies: + dtrace-provider "~0.8" + moment "^2.19.3" + mv "~2" + safe-json-stringify "~1" + +bytes@3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" + integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== + +cache-base@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2" + integrity sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ== + dependencies: + collection-visit "^1.0.0" + component-emitter "^1.2.1" + get-value "^2.0.6" + has-value "^1.0.0" + isobject "^3.0.1" + set-value "^2.0.0" + to-object-path "^0.3.0" + union-value "^1.0.0" + unset-value "^1.0.0" + +cacheable-lookup@^6.0.4: + version "6.0.4" + resolved "https://registry.yarnpkg.com/cacheable-lookup/-/cacheable-lookup-6.0.4.tgz#65c0e51721bb7f9f2cb513aed6da4a1b93ad7dc8" + integrity sha512-mbcDEZCkv2CZF4G01kr8eBd/5agkt9oCqz75tJMSIsquvRZ2sL6Hi5zGVKi/0OSC9oO1GHfJ2AV0ZIOY9vye0A== + +cacheable-request@^6.0.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" + integrity sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg== + dependencies: + clone-response "^1.0.2" + get-stream "^5.1.0" + http-cache-semantics "^4.0.0" + keyv "^3.0.0" + lowercase-keys "^2.0.0" + normalize-url "^4.1.0" + responselike "^1.0.2" + +cacheable-request@^7.0.2: + version "7.0.2" + resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-7.0.2.tgz#ea0d0b889364a25854757301ca12b2da77f91d27" + integrity sha512-pouW8/FmiPQbuGpkXQ9BAPv/Mo5xDGANgSNXzTzJ8DrKGuXOssM4wIQRjfanNRh3Yu5cfYPvcorqbhg2KIJtew== + dependencies: + clone-response "^1.0.2" + get-stream "^5.1.0" + http-cache-semantics "^4.0.0" + keyv "^4.0.0" + lowercase-keys "^2.0.0" + normalize-url "^6.0.1" + responselike "^2.0.0" + +call-bind@^1.0.0, call-bind@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" + integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== + dependencies: + function-bind "^1.1.1" + get-intrinsic "^1.0.2" + +call-me-maybe@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/call-me-maybe/-/call-me-maybe-1.0.1.tgz#26d208ea89e37b5cbde60250a15f031c16a4d66b" + integrity sha512-wCyFsDQkKPwwF8BDwOiWNx/9K45L/hvggQiDbve+viMNMQnWhrlYIuBk09offfwCRtCO9P6XwUttufzU11WCVw== + +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +camel-case@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/camel-case/-/camel-case-3.0.0.tgz#ca3c3688a4e9cf3a4cda777dc4dcbc713249cf73" + integrity sha512-+MbKztAYHXPr1jNTSKQF52VpcFjwY5RkR7fxksV8Doo4KAYc5Fl4UJRgthBbTmEx8C54DqahhbLJkDwjI3PI/w== + dependencies: + no-case "^2.2.0" + upper-case "^1.1.1" + +camelcase@^5.0.0, camelcase@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" + integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== + +camelcase@^6.0.0, camelcase@^6.2.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.3.0.tgz#5685b95eb209ac9c0c177467778c9c84df58ba9a" + integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== + +caniuse-lite@^1.0.30001370: + version "1.0.30001374" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001374.tgz#3dab138e3f5485ba2e74bd13eca7fe1037ce6f57" + integrity sha512-mWvzatRx3w+j5wx/mpFN5v5twlPrabG8NqX2c6e45LCpymdoGqNvRkRutFUqpRTXKFQFNQJasvK0YT7suW6/Hw== + +capability@^0.2.5: + version "0.2.5" + resolved "https://registry.yarnpkg.com/capability/-/capability-0.2.5.tgz#51ad87353f1936ffd77f2f21c74633a4dea88801" + integrity sha512-rsJZYVCgXd08sPqwmaIqjAd5SUTfonV0z/gDJ8D6cN8wQphky1kkAYEqQ+hmDxTw7UihvBfjUVUSY+DBEe44jg== + +caseless@~0.12.0: + version "0.12.0" + resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" + integrity sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw== + +catering@^2.0.0, catering@^2.1.0, catering@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/catering/-/catering-2.1.1.tgz#66acba06ed5ee28d5286133982a927de9a04b510" + integrity sha512-K7Qy8O9p76sL3/3m7/zLKbRkyOlSZAgzEaLhyj2mXS8PsCud2Eo4hAb8aLtZqHh0QGqLcb9dlJSu6lHRVENm1w== + +cbor@^4.1.5: + version "4.3.0" + resolved "https://registry.yarnpkg.com/cbor/-/cbor-4.3.0.tgz#0217c1cadd067d9112f44336dca07e72020bb804" + integrity sha512-CvzaxQlaJVa88sdtTWvLJ++MbdtPHtZOBBNjm7h3YKUHILMs9nQyD4AC6hvFZy7GBVB3I6bRibJcxeHydyT2IQ== + dependencies: + bignumber.js "^9.0.0" + commander "^3.0.0" + json-text-sequence "^0.1" + nofilter "^1.0.3" + +cbor@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/cbor/-/cbor-5.2.0.tgz#4cca67783ccd6de7b50ab4ed62636712f287a67c" + integrity sha512-5IMhi9e1QU76ppa5/ajP1BmMWZ2FHkhAhjeVKQ/EFCgYSEaeVaoGtL7cxJskf9oCCk+XjzaIdc3IuU/dbA/o2A== + dependencies: + bignumber.js "^9.0.1" + nofilter "^1.0.4" + +chain-registry@^0.0.26: + version "0.0.26" + resolved "https://registry.yarnpkg.com/chain-registry/-/chain-registry-0.0.26.tgz#63598d451f9b121d3a7f6bc038a3415121696c66" + integrity sha512-lLtXYvJ19KbN/eUm2kLzl+G7SRdPM06Ti7AzqB0f9lcHORwOP7AyqtLq3swLjgU8mOJ03zpqoj7tiSELf4PCow== + dependencies: + "@babel/runtime" "^7.18.3" + +chalk@^2.0.0, chalk@^2.0.1, chalk@^2.4.1, chalk@^2.4.2: + version "2.4.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" + integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== + dependencies: + ansi-styles "^3.2.1" + escape-string-regexp "^1.0.5" + supports-color "^5.3.0" + +chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +change-case@3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/change-case/-/change-case-3.0.2.tgz#fd48746cce02f03f0a672577d1d3a8dc2eceb037" + integrity sha512-Mww+SLF6MZ0U6kdg11algyKd5BARbyM4TbFBepwowYSR5ClfQGCGtxNXgykpN0uF/bstWeaGDT4JWaDh8zWAHA== + dependencies: + camel-case "^3.0.0" + constant-case "^2.0.0" + dot-case "^2.1.0" + header-case "^1.0.0" + is-lower-case "^1.1.0" + is-upper-case "^1.1.0" + lower-case "^1.1.1" + lower-case-first "^1.0.0" + no-case "^2.3.2" + param-case "^2.1.0" + pascal-case "^2.0.0" + path-case "^2.1.0" + sentence-case "^2.1.0" + snake-case "^2.1.0" + swap-case "^1.1.0" + title-case "^2.1.0" + upper-case "^1.1.1" + upper-case-first "^1.1.0" + +char-regex@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" + integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== + +chardet@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/chardet/-/chardet-0.7.0.tgz#90094849f0937f2eedc2425d0d28a9e5f0cbad9e" + integrity sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA== + +cheerio-select@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/cheerio-select/-/cheerio-select-2.1.0.tgz#4d8673286b8126ca2a8e42740d5e3c4884ae21b4" + integrity sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g== + dependencies: + boolbase "^1.0.0" + css-select "^5.1.0" + css-what "^6.1.0" + domelementtype "^2.3.0" + domhandler "^5.0.3" + domutils "^3.0.1" + +cheerio@^1.0.0-rc.2: + version "1.0.0-rc.12" + resolved "https://registry.yarnpkg.com/cheerio/-/cheerio-1.0.0-rc.12.tgz#788bf7466506b1c6bf5fae51d24a2c4d62e47683" + integrity sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q== + dependencies: + cheerio-select "^2.1.0" + dom-serializer "^2.0.0" + domhandler "^5.0.3" + domutils "^3.0.1" + htmlparser2 "^8.0.1" + parse5 "^7.0.0" + parse5-htmlparser2-tree-adapter "^7.0.0" + +chokidar@3.5.3, chokidar@^3.4.0, chokidar@^3.5.2, chokidar@^3.5.3: + version "3.5.3" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" + integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw== + dependencies: + anymatch "~3.1.2" + braces "~3.0.2" + glob-parent "~5.1.2" + is-binary-path "~2.1.0" + is-glob "~4.0.1" + normalize-path "~3.0.0" + readdirp "~3.6.0" + optionalDependencies: + fsevents "~2.3.2" + +chownr@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" + integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== + +ci-info@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" + integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== + +ci-info@^3.2.0: + version "3.3.2" + resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.3.2.tgz#6d2967ffa407466481c6c90b6e16b3098f080128" + integrity sha512-xmDt/QIAdeZ9+nfdPsaBCpMvHNLFiLdjj59qjqn+6iPe6YmHGQ35sBnQ8uslRBXFmXkiZQOJRjvQeoGppoTjjg== + +cids@^0.7.1: + version "0.7.5" + resolved "https://registry.yarnpkg.com/cids/-/cids-0.7.5.tgz#60a08138a99bfb69b6be4ceb63bfef7a396b28b2" + integrity sha512-zT7mPeghoWAu+ppn8+BS1tQ5qGmbMfB4AregnQjA/qHY3GC1m1ptI9GkWNlgeu38r7CuRdXB47uY2XgAYt6QVA== + dependencies: + buffer "^5.5.0" + class-is "^1.1.0" + multibase "~0.6.0" + multicodec "^1.0.0" + multihashes "~0.4.15" + +cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" + integrity sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +cjs-module-lexer@^1.0.0: + version "1.2.2" + resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz#9f84ba3244a512f3a54e5277e8eef4c489864e40" + integrity sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA== + +class-is@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/class-is/-/class-is-1.1.0.tgz#9d3c0fba0440d211d843cec3dedfa48055005825" + integrity sha512-rhjH9AG1fvabIDoGRVH587413LPjTZgmDF9fOFCbFJQV4yuocX1mHxxvXI4g3cGwbVY9wAYIoKlg1N79frJKQw== + +class-utils@^0.3.5: + version "0.3.6" + resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463" + integrity sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg== + dependencies: + arr-union "^3.1.0" + define-property "^0.2.5" + isobject "^3.0.0" + static-extend "^0.1.1" + +classic-level@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/classic-level/-/classic-level-1.2.0.tgz#2d52bdec8e7a27f534e67fdeb890abef3e643c27" + integrity sha512-qw5B31ANxSluWz9xBzklRWTUAJ1SXIdaVKTVS7HcTGKOAmExx65Wo5BUICW+YGORe2FOUaDghoI9ZDxj82QcFg== + dependencies: + abstract-level "^1.0.2" + catering "^2.1.0" + module-error "^1.0.1" + napi-macros "~2.0.0" + node-gyp-build "^4.3.0" + +clean-stack@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" + integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== + +cli-cursor@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-2.1.0.tgz#b35dac376479facc3e94747d41d0d0f5238ffcb5" + integrity sha512-8lgKz8LmCRYZZQDpRyT2m5rKJ08TnU4tR9FFFW2rxpxR1FzWi4PQ/NfyODchAatHaUgnSPVcx/R5w6NuTBzFiw== + dependencies: + restore-cursor "^2.0.0" + +cli-cursor@^3.0.0, cli-cursor@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-3.1.0.tgz#264305a7ae490d1d03bf0c9ba7c925d1753af307" + integrity sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw== + dependencies: + restore-cursor "^3.1.0" + +cli-width@^2.0.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.1.tgz#b0433d0b4e9c847ef18868a4ef16fd5fc8271c48" + integrity sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw== + +cliui@^4.0.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-4.1.0.tgz#348422dbe82d800b3022eef4f6ac10bf2e4d1b49" + integrity sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ== + dependencies: + string-width "^2.1.1" + strip-ansi "^4.0.0" + wrap-ansi "^2.0.0" + +cliui@^7.0.2: + version "7.0.4" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f" + integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== + dependencies: + string-width "^4.2.0" + strip-ansi "^6.0.0" + wrap-ansi "^7.0.0" + +clone-buffer@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/clone-buffer/-/clone-buffer-1.0.0.tgz#e3e25b207ac4e701af721e2cb5a16792cac3dc58" + integrity sha512-KLLTJWrvwIP+OPfMn0x2PheDEP20RPUcGXj/ERegTgdmPEZylALQldygiqrPPu8P45uNuPs7ckmReLY6v/iA5g== + +clone-response@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/clone-response/-/clone-response-1.0.3.tgz#af2032aa47816399cf5f0a1d0db902f517abb8c3" + integrity sha512-ROoL94jJH2dUVML2Y/5PEDNaSHgeOdSDicUyS7izcF63G6sTc/FTjLub4b8Il9S8S0beOfYt0TaA5qvFK+w0wA== + dependencies: + mimic-response "^1.0.0" + +clone@2.x: + version "2.1.2" + resolved "https://registry.yarnpkg.com/clone/-/clone-2.1.2.tgz#1b7f4b9f591f1e8f83670401600345a02887435f" + integrity sha512-3Pe/CF1Nn94hyhIYpjtiLhdCoEoz0DqQ+988E9gmeEdQZlojxnOb74wctFyuwWQHzqyf9X7C7MG8juUpqBJT8w== + +co@^4.6.0: + version "4.6.0" + resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184" + integrity sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ== + +cobertura-parse@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/cobertura-parse/-/cobertura-parse-1.0.5.tgz#3a8c5d30a97468496a2aabd04b8fa4fb7c3cd20e" + integrity sha512-uYJfkGhzw1wibe/8jqqHmSaPNWFguzq/IlSj83u3cSnZho/lUnfj0mLTmZGmB3AiKCOTYr22TYwpR1sXy2JEkg== + dependencies: + mocha "5.0.5" + xml2js "0.4.19" + +code-point-at@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" + integrity sha512-RpAVKQA5T63xEj6/giIbUEtZwJ4UFIc3ZtvEkiaUERylqe8xb5IvqcgOurZLahv93CLKfxcw5YI+DZcUBRyLXA== + +coinalpha-ref-sdk@1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/coinalpha-ref-sdk/-/coinalpha-ref-sdk-1.1.0.tgz#f8d2d08e2de5ddafa7ee948553b6780d206770ec" + integrity sha512-C3rtns2RWyi1DmfJCVmW2MOLqXOvVVIVqjXZPQkThexsimzdqNQ6DgU2CWLRlIujlqHgRNT6LYaqfc25wCC0Kg== + dependencies: + "@types/big.js" "^6.1.5" + "@types/bn.js" "^5.1.1" + "@types/lodash" "^4.14.182" + big.js "^6.2.1" + lodash-es "^4.17.21" + mathjs "^9.3.0" + near-api-js "0.44.2" + ref-sdk "^0.1.5" + +collect-v8-coverage@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz#cc2c8e94fc18bbdffe64d6534570c8a673b27f59" + integrity sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg== + +collection-visit@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz#4bc0373c164bc3291b4d368c829cf1a80a59dca0" + integrity sha512-lNkKvzEeMBBjUGHZ+q6z9pSJla0KWAQPvtzhEV9+iGyQYG+pBpl7xKDhxoNSOZH2hhv0v5k0y2yAM4o4SjoSkw== + dependencies: + map-visit "^1.0.0" + object-visit "^1.0.0" + +color-convert@^1.9.0, color-convert@^1.9.3: + version "1.9.3" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" + integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== + dependencies: + color-name "1.1.3" + +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + +color-name@1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" + integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== + +color-name@^1.0.0, color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + +color-string@^1.6.0: + version "1.9.1" + resolved "https://registry.yarnpkg.com/color-string/-/color-string-1.9.1.tgz#4467f9146f036f855b764dfb5bf8582bf342c7a4" + integrity sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg== + dependencies: + color-name "^1.0.0" + simple-swizzle "^0.2.2" + +color@^3.1.3: + version "3.2.1" + resolved "https://registry.yarnpkg.com/color/-/color-3.2.1.tgz#3544dc198caf4490c3ecc9a790b54fe9ff45e164" + integrity sha512-aBl7dZI9ENN6fUGC7mWpMTPNHmWUSNan9tuWN6ahh5ZLNk9baLJOnSMlrQkHcrfFgz2/RigjUVAjdx36VcemKA== + dependencies: + color-convert "^1.9.3" + color-string "^1.6.0" + +colors@1.4.0, colors@^1.0.3: + version "1.4.0" + resolved "https://registry.yarnpkg.com/colors/-/colors-1.4.0.tgz#c50491479d4c1bdaed2c9ced32cf7c7dc2360f78" + integrity sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA== + +colorspace@1.1.x: + version "1.1.4" + resolved "https://registry.yarnpkg.com/colorspace/-/colorspace-1.1.4.tgz#8d442d1186152f60453bf8070cd66eb364e59243" + integrity sha512-BgvKJiuVu1igBUF2kEjRCZXol6wiiGbY5ipL/oVPwm0BL9sIpMIzM8IK7vwuxIIzOXMV3Ey5w+vxhm0rR/TN8w== + dependencies: + color "^3.1.3" + text-hex "1.0.x" + +combined-stream@^1.0.6, combined-stream@^1.0.8, combined-stream@~1.0.6: + version "1.0.8" + resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" + integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== + dependencies: + delayed-stream "~1.0.0" + +command-exists@^1.2.8: + version "1.2.9" + resolved "https://registry.yarnpkg.com/command-exists/-/command-exists-1.2.9.tgz#c50725af3808c8ab0260fd60b01fbfa25b954f69" + integrity sha512-LTQ/SGc+s0Xc0Fu5WaKnR0YiygZkm9eKFvyS+fRsU7/ZWFF8ykFM6Pc9aCVf1+xasOOZpO3BAVgVrKvsqKHV7w== + +command-line-args@^4.0.7: + version "4.0.7" + resolved "https://registry.yarnpkg.com/command-line-args/-/command-line-args-4.0.7.tgz#f8d1916ecb90e9e121eda6428e41300bfb64cc46" + integrity sha512-aUdPvQRAyBvQd2n7jXcsMDz68ckBJELXNzBybCHOibUWEg0mWTnaYCSRU8h9R+aNRSvDihJtssSRCiDRpLaezA== + dependencies: + array-back "^2.0.0" + find-replace "^1.0.3" + typical "^2.6.1" + +commander@2.11.0: + version "2.11.0" + resolved "https://registry.yarnpkg.com/commander/-/commander-2.11.0.tgz#157152fd1e7a6c8d98a5b715cf376df928004563" + integrity sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ== + +commander@2.15.1: + version "2.15.1" + resolved "https://registry.yarnpkg.com/commander/-/commander-2.15.1.tgz#df46e867d0fc2aec66a34662b406a9ccafff5b0f" + integrity sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag== + +commander@3.0.2, commander@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/commander/-/commander-3.0.2.tgz#6837c3fb677ad9933d1cfba42dd14d5117d6b39e" + integrity sha512-Gar0ASD4BDyKC4hl4DwHqDrmvjoxWKZigVnAbn5H1owvm4CxCPdb0HQDehwNYMJpla5+M2tPmPARzhtYuwpHow== + +commander@^2.15.1, commander@^2.20.3, commander@^2.8.1: + version "2.20.3" + resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33" + integrity sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ== + +complex.js@^2.0.15, complex.js@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/complex.js/-/complex.js-2.1.1.tgz#0675dac8e464ec431fb2ab7d30f41d889fb25c31" + integrity sha512-8njCHOTtFFLtegk6zQo0kkVX1rngygb/KQI6z1qZxlFI3scluC+LVTCFbrkWjBv4vvLlbQ9t88IPMC6k95VTTg== + +component-emitter@^1.2.1, component-emitter@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz#16e4070fba8ae29b679f2215853ee181ab2eabc0" + integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== + +compress-brotli@^1.3.8: + version "1.3.8" + resolved "https://registry.yarnpkg.com/compress-brotli/-/compress-brotli-1.3.8.tgz#0c0a60c97a989145314ec381e84e26682e7b38db" + integrity sha512-lVcQsjhxhIXsuupfy9fmZUFtAIdBmXA7EGY6GBdgZ++qkM9zG4YFT8iU7FoBxzryNDMOpD1HIFHUSX4D87oqhQ== + dependencies: + "@types/json-buffer" "~3.0.0" + json-buffer "~3.0.1" + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + +conf@^10.1.2: + version "10.2.0" + resolved "https://registry.yarnpkg.com/conf/-/conf-10.2.0.tgz#838e757be963f1a2386dfe048a98f8f69f7b55d6" + integrity sha512-8fLl9F04EJqjSqH+QjITQfJF8BrOVaYr1jewVgSRAEWePfxT0sku4w2hrGQ60BC/TNLGQ2pgxNlTbWQmMPFvXg== + dependencies: + ajv "^8.6.3" + ajv-formats "^2.1.1" + atomically "^1.7.0" + debounce-fn "^4.0.0" + dot-prop "^6.0.1" + env-paths "^2.2.1" + json-schema-typed "^7.0.3" + onetime "^5.1.2" + pkg-up "^3.1.0" + semver "^7.3.5" + +configstore@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/configstore/-/configstore-4.0.0.tgz#5933311e95d3687efb592c528b922d9262d227e7" + integrity sha512-CmquAXFBocrzaSM8mtGPMM/HiWmyIpr4CcJl/rgY2uCObZ/S7cKU0silxslqJejl+t/T9HS8E0PUNQD81JGUEQ== + dependencies: + dot-prop "^4.1.0" + graceful-fs "^4.1.2" + make-dir "^1.0.0" + unique-string "^1.0.0" + write-file-atomic "^2.0.0" + xdg-basedir "^3.0.0" + +constant-case@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/constant-case/-/constant-case-2.0.0.tgz#4175764d389d3fa9c8ecd29186ed6005243b6a46" + integrity sha512-eS0N9WwmjTqrOmR3o83F5vW8Z+9R1HnVz3xmzT2PMFug9ly+Au/fxRWlEBSb6LcZwspSsEn9Xs1uw9YgzAg1EQ== + dependencies: + snake-case "^2.1.0" + upper-case "^1.1.1" + +content-disposition@0.5.4: + version "0.5.4" + resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" + integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== + dependencies: + safe-buffer "5.2.1" + +content-hash@^2.5.2: + version "2.5.2" + resolved "https://registry.yarnpkg.com/content-hash/-/content-hash-2.5.2.tgz#bbc2655e7c21f14fd3bfc7b7d4bfe6e454c9e211" + integrity sha512-FvIQKy0S1JaWV10sMsA7TRx8bpU+pqPkhbsfvOJAdjRXvYxEckAwQWGwtRjiaJfh+E0DvcWUGqcdjwMGFjsSdw== + dependencies: + cids "^0.7.1" + multicodec "^0.5.5" + multihashes "^0.4.15" + +content-type@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" + integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== + +convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369" + integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA== + dependencies: + safe-buffer "~5.1.1" + +cookie-signature@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" + integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== + +cookie@0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.5.0.tgz#d1f5d71adec6558c58f389987c366aa47e994f8b" + integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== + +cookie@^0.4.1: + version "0.4.2" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.2.tgz#0e41f24de5ecf317947c82fc789e06a884824432" + integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== + +cookiejar@^2.1.1, cookiejar@^2.1.3: + version "2.1.3" + resolved "https://registry.yarnpkg.com/cookiejar/-/cookiejar-2.1.3.tgz#fc7a6216e408e74414b90230050842dacda75acc" + integrity sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ== + +copy-descriptor@^0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d" + integrity sha512-XgZ0pFcakEUlbwQEVNg3+QAis1FyTL3Qel9FYy8pSkQqoG3PNoT0bOCQtOXcOkur21r2Eq2kI+IE+gsmAEVlYw== + +copyfiles@^2.4.1: + version "2.4.1" + resolved "https://registry.yarnpkg.com/copyfiles/-/copyfiles-2.4.1.tgz#d2dcff60aaad1015f09d0b66e7f0f1c5cd3c5da5" + integrity sha512-fereAvAvxDrQDOXybk3Qu3dPbOoKoysFMWtkY3mv5BsL8//OSZVL5DCLYqgRfY5cWirgRzlC+WSrxp6Bo3eNZg== + dependencies: + glob "^7.0.5" + minimatch "^3.0.3" + mkdirp "^1.0.4" + noms "0.0.0" + through2 "^2.0.1" + untildify "^4.0.0" + yargs "^16.1.0" + +core-js-pure@^3.0.1: + version "3.24.1" + resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.24.1.tgz#8839dde5da545521bf282feb7dc6d0b425f39fd3" + integrity sha512-r1nJk41QLLPyozHUUPmILCEMtMw24NG4oWK6RbsDdjzQgg9ZvrUsPBj1MnG0wXXp1DCDU6j+wUvEmBSrtRbLXg== + +core-js@3.6.5: + version "3.6.5" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.6.5.tgz#7395dc273af37fb2e50e9bd3d9fe841285231d1a" + integrity sha512-vZVEEwZoIsI+vPEuoF9Iqf5H7/M3eeQqWlQnYa8FSKKePuYTf5MWnxb5SDAzCa60b3JBRS5g9b+Dq7b1y/RCrA== + +core-util-is@1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" + integrity sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ== + +core-util-is@~1.0.0: + version "1.0.3" + resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85" + integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== + +cors@^2.8.1, cors@^2.8.5: + version "2.8.5" + resolved "https://registry.yarnpkg.com/cors/-/cors-2.8.5.tgz#eac11da51592dd86b9f06f6e7ac293b3df875d29" + integrity sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g== + dependencies: + object-assign "^4" + vary "^1" + +cosmjs-types@^0.4.0: + version "0.4.1" + resolved "https://registry.yarnpkg.com/cosmjs-types/-/cosmjs-types-0.4.1.tgz#3b2a53ba60d33159dd075596ce8267cfa7027063" + integrity sha512-I7E/cHkIgoJzMNQdFF0YVqPlaTqrqKHrskuSTIqlEyxfB5Lf3WKCajSXVK2yHOfOFfSux/RxEdpMzw/eO4DIog== + dependencies: + long "^4.0.0" + protobufjs "~6.11.2" + +crc-32@^1.2.0: + version "1.2.2" + resolved "https://registry.yarnpkg.com/crc-32/-/crc-32-1.2.2.tgz#3cad35a934b8bf71f25ca524b6da51fb7eace2ff" + integrity sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ== + +create-ecdh@^4.0.0: + version "4.0.4" + resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.4.tgz#d6e7f4bffa66736085a0762fd3a632684dabcc4e" + integrity sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A== + dependencies: + bn.js "^4.1.0" + elliptic "^6.5.3" + +create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.2.0.tgz#889078af11a63756bcfb59bd221996be3a9ef196" + integrity sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg== + dependencies: + cipher-base "^1.0.1" + inherits "^2.0.1" + md5.js "^1.3.4" + ripemd160 "^2.0.1" + sha.js "^2.4.0" + +create-hmac@^1.1.0, create-hmac@^1.1.4, create-hmac@^1.1.7: + version "1.1.7" + resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.7.tgz#69170c78b3ab957147b2b8b04572e47ead2243ff" + integrity sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg== + dependencies: + cipher-base "^1.0.3" + create-hash "^1.1.0" + inherits "^2.0.1" + ripemd160 "^2.0.0" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +create-require@^1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/create-require/-/create-require-1.1.1.tgz#c1d7e8f1e5f6cfc9ff65f9cd352d37348756c333" + integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== + +cross-fetch@3.1.5, cross-fetch@^3.0.2, cross-fetch@^3.0.6, cross-fetch@^3.1.4, cross-fetch@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/cross-fetch/-/cross-fetch-3.1.5.tgz#e1389f44d9e7ba767907f7af8454787952ab534f" + integrity sha512-lvb1SBsI0Z7GDwmuid+mU3kWVBwTVUbe7S0H52yaaAdQOXq2YktTCZdlAcNKFzE6QtRz0snpw9bNiPeOIkkQvw== + dependencies: + node-fetch "2.6.7" + +cross-spawn@^6.0.0: + version "6.0.5" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-6.0.5.tgz#4a5ec7c64dfae22c3a14124dbacdee846d80cbc4" + integrity sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ== + dependencies: + nice-try "^1.0.4" + path-key "^2.0.1" + semver "^5.5.0" + shebang-command "^1.2.0" + which "^1.2.9" + +cross-spawn@^7.0.2, cross-spawn@^7.0.3: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +crypto-browserify@3.12.0: + version "3.12.0" + resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec" + integrity sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg== + dependencies: + browserify-cipher "^1.0.0" + browserify-sign "^4.0.0" + create-ecdh "^4.0.0" + create-hash "^1.1.0" + create-hmac "^1.1.0" + diffie-hellman "^5.0.0" + inherits "^2.0.1" + pbkdf2 "^3.0.3" + public-encrypt "^4.0.0" + randombytes "^2.0.0" + randomfill "^1.0.3" + +crypto-hash@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/crypto-hash/-/crypto-hash-1.3.0.tgz#b402cb08f4529e9f4f09346c3e275942f845e247" + integrity sha512-lyAZ0EMyjDkVvz8WOeVnuCPvKVBXcMv1l5SVqO1yC7PzTwrD/pPje/BIRbWhMoPe436U+Y2nD7f5bFx0kt+Sbg== + +crypto-random-string@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-1.0.0.tgz#a230f64f568310e1498009940790ec99545bca7e" + integrity sha512-GsVpkFPlycH7/fRR7Dhcmnoii54gV1nz7y4CWyeFS14N+JVBBhY+r8amRHE4BwSYal7BPTDp8isvAlCxyFt3Hg== + +css-select@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/css-select/-/css-select-5.1.0.tgz#b8ebd6554c3637ccc76688804ad3f6a6fdaea8a6" + integrity sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg== + dependencies: + boolbase "^1.0.0" + css-what "^6.1.0" + domhandler "^5.0.2" + domutils "^3.0.1" + nth-check "^2.0.1" + +css-what@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/css-what/-/css-what-6.1.0.tgz#fb5effcf76f1ddea2c81bdfaa4de44e79bac70f4" + integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw== + +cssfilter@0.0.10: + version "0.0.10" + resolved "https://registry.yarnpkg.com/cssfilter/-/cssfilter-0.0.10.tgz#c6d2672632a2e5c83e013e6864a42ce8defd20ae" + integrity sha512-FAaLDaplstoRsDR8XGYH51znUN0UY7nMc6Z9/fvE8EXGwvJE9hu7W2vHwx1+bd6gCYnln9nLbzxFTrcO9YQDZw== + +cssom@^0.4.4: + version "0.4.4" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" + integrity sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw== + +cssom@~0.3.6: + version "0.3.8" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" + integrity sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg== + +cssstyle@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-2.3.0.tgz#ff665a0ddbdc31864b09647f34163443d90b0852" + integrity sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A== + dependencies: + cssom "~0.3.6" + +cycle@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/cycle/-/cycle-1.0.3.tgz#21e80b2be8580f98b468f379430662b046c34ad2" + integrity sha512-TVF6svNzeQCOpjCqsy0/CSy8VgObG3wXusJ73xW2GbG5rGx7lC8zxDSURicsXI2UsGdi2L0QNRCi745/wUDvsA== + +d@1, d@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/d/-/d-1.0.1.tgz#8698095372d58dbee346ffd0c7093f99f8f9eb5a" + integrity sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA== + dependencies: + es5-ext "^0.10.50" + type "^1.0.1" + +dashdash@^1.12.0: + version "1.14.1" + resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" + integrity sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g== + dependencies: + assert-plus "^1.0.0" + +data-urls@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-2.0.0.tgz#156485a72963a970f5d5821aaf642bef2bf2db9b" + integrity sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ== + dependencies: + abab "^2.0.3" + whatwg-mimetype "^2.3.0" + whatwg-url "^8.0.0" + +dataloader@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/dataloader/-/dataloader-2.1.0.tgz#c69c538235e85e7ac6c6c444bae8ecabf5de9df7" + integrity sha512-qTcEYLen3r7ojZNgVUaRggOI+KM7jrKxXeSHhogh/TWxYMeONEMqY+hmkobiYQozsGIyg9OYVzO4ZIfoB4I0pQ== + +dayjs@^1.10.6: + version "1.11.4" + resolved "https://registry.yarnpkg.com/dayjs/-/dayjs-1.11.4.tgz#3b3c10ca378140d8917e06ebc13a4922af4f433e" + integrity sha512-Zj/lPM5hOvQ1Bf7uAvewDaUcsJoI6JmNqmHhHl3nyumwe0XHwt8sWdOVAPACJzCebL8gQCi+K49w7iKWnGwX9g== + +debounce-fn@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/debounce-fn/-/debounce-fn-4.0.0.tgz#ed76d206d8a50e60de0dd66d494d82835ffe61c7" + integrity sha512-8pYCQiL9Xdcg0UPSD3d+0KMlOjp+KGU5EPwYddgzQ7DATsg4fuUDjQtsYLmWjnk2obnNHgV3vE2Y4jejSOJVBQ== + dependencies: + mimic-fn "^3.0.0" + +debug@2.6.9, debug@^2.2.0, debug@^2.3.3, debug@^2.6.9: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +debug@3.1.0, debug@=3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/debug/-/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261" + integrity sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g== + dependencies: + ms "2.0.0" + +debug@4, debug@4.3.4, debug@^4.0.1, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.3, debug@^4.3.4: + version "4.3.4" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + +debug@4.3.3: + version "4.3.3" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" + integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q== + dependencies: + ms "2.1.2" + +debug@^3.0.1, debug@^3.1.0, debug@^3.2.7: + version "3.2.7" + resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" + integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== + dependencies: + ms "^2.1.1" + +decamelize@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" + integrity sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA== + +decamelize@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" + integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== + +decimal.js-light@^2.5.0, decimal.js-light@^2.5.1: + version "2.5.1" + resolved "https://registry.yarnpkg.com/decimal.js-light/-/decimal.js-light-2.5.1.tgz#134fd32508f19e208f4fb2f8dac0d2626a867934" + integrity sha512-qIMFpTMZmny+MMIitAB6D7iVPEorVw6YQRWkvarTkT4tBeSLLiHzcwj6q0MmYSFCiVpiqPJTJEYIrpcPzVEIvg== + +decimal.js@^10.2.1, decimal.js@^10.3.1: + version "10.3.1" + resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.3.1.tgz#d8c3a444a9c6774ba60ca6ad7261c3a94fd5e783" + integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== + +decode-uri-component@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" + integrity sha512-hjf+xovcEn31w/EUYdTXQh/8smFL/dzYjohQGEIgjyNavaJfBY2p5F527Bo1VPATxv0VYTUC2bOcXvqFwk78Og== + +decompress-response@^3.2.0, decompress-response@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-3.3.0.tgz#80a4dd323748384bfa248083622aedec982adff3" + integrity sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA== + dependencies: + mimic-response "^1.0.0" + +decompress-response@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-6.0.0.tgz#ca387612ddb7e104bd16d85aab00d5ecf09c66fc" + integrity sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ== + dependencies: + mimic-response "^3.1.0" + +decompress-tar@^4.0.0, decompress-tar@^4.1.0, decompress-tar@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/decompress-tar/-/decompress-tar-4.1.1.tgz#718cbd3fcb16209716e70a26b84e7ba4592e5af1" + integrity sha512-JdJMaCrGpB5fESVyxwpCx4Jdj2AagLmv3y58Qy4GE6HMVjWz1FeVQk1Ct4Kye7PftcdOo/7U7UKzYBJgqnGeUQ== + dependencies: + file-type "^5.2.0" + is-stream "^1.1.0" + tar-stream "^1.5.2" + +decompress-tarbz2@^4.0.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/decompress-tarbz2/-/decompress-tarbz2-4.1.1.tgz#3082a5b880ea4043816349f378b56c516be1a39b" + integrity sha512-s88xLzf1r81ICXLAVQVzaN6ZmX4A6U4z2nMbOwobxkLoIIfjVMBg7TeguTUXkKeXni795B6y5rnvDw7rxhAq9A== + dependencies: + decompress-tar "^4.1.0" + file-type "^6.1.0" + is-stream "^1.1.0" + seek-bzip "^1.0.5" + unbzip2-stream "^1.0.9" + +decompress-targz@^4.0.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/decompress-targz/-/decompress-targz-4.1.1.tgz#c09bc35c4d11f3de09f2d2da53e9de23e7ce1eee" + integrity sha512-4z81Znfr6chWnRDNfFNqLwPvm4db3WuZkqV+UgXQzSngG3CEKdBkw5jrv3axjjL96glyiiKjsxJG3X6WBZwX3w== + dependencies: + decompress-tar "^4.1.1" + file-type "^5.2.0" + is-stream "^1.1.0" + +decompress-unzip@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/decompress-unzip/-/decompress-unzip-4.0.1.tgz#deaaccdfd14aeaf85578f733ae8210f9b4848f69" + integrity sha512-1fqeluvxgnn86MOh66u8FjbtJpAFv5wgCT9Iw8rcBqQcCo5tO8eiJw7NNTrvt9n4CRBVq7CstiS922oPgyGLrw== + dependencies: + file-type "^3.8.0" + get-stream "^2.2.0" + pify "^2.3.0" + yauzl "^2.4.2" + +decompress@^4.0.0: + version "4.2.1" + resolved "https://registry.yarnpkg.com/decompress/-/decompress-4.2.1.tgz#007f55cc6a62c055afa37c07eb6a4ee1b773f118" + integrity sha512-e48kc2IjU+2Zw8cTb6VZcJQ3lgVbS4uuB1TfCHbiZIP/haNXm+SVyhu+87jts5/3ROpd82GSVCoNs/z8l4ZOaQ== + dependencies: + decompress-tar "^4.0.0" + decompress-tarbz2 "^4.0.0" + decompress-targz "^4.0.0" + decompress-unzip "^4.0.1" + graceful-fs "^4.1.10" + make-dir "^1.0.0" + pify "^2.3.0" + strip-dirs "^2.0.0" + +dedent@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" + integrity sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA== + +deep-is@^0.1.3, deep-is@~0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + +deepmerge@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.2.2.tgz#44d2ea3679b8f4d4ffba33f03d865fc1e7bf4955" + integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== + +defer-to-connect@^1.0.1: + version "1.1.3" + resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-1.1.3.tgz#331ae050c08dcf789f8c83a7b81f0ed94f4ac591" + integrity sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ== + +defer-to-connect@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-2.0.1.tgz#8016bdb4143e4632b77a3449c6236277de520587" + integrity sha512-4tvttepXG1VaYGrRibk5EwJd1t4udunSOVMdLSAL6mId1ix438oPwPZMALY41FCijukO1L0twNcGsdzS7dHgDg== + +deferred-leveldown@~5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/deferred-leveldown/-/deferred-leveldown-5.3.0.tgz#27a997ad95408b61161aa69bd489b86c71b78058" + integrity sha512-a59VOT+oDy7vtAbLRCZwWgxu2BaCfd5Hk7wxJd48ei7I+nsg8Orlb9CLG0PMZienk9BSUKgeAqkO2+Lw+1+Ukw== + dependencies: + abstract-leveldown "~6.2.1" + inherits "^2.0.3" + +define-properties@^1.1.3, define-properties@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.4.tgz#0b14d7bd7fbeb2f3572c3a7eda80ea5d57fb05b1" + integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== + dependencies: + has-property-descriptors "^1.0.0" + object-keys "^1.1.1" + +define-property@^0.2.5: + version "0.2.5" + resolved "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz#c35b1ef918ec3c990f9a5bc57be04aacec5c8116" + integrity sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA== + dependencies: + is-descriptor "^0.1.0" + +define-property@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz#769ebaaf3f4a63aad3af9e8d304c9bbe79bfb0e6" + integrity sha512-cZTYKFWspt9jZsMscWo8sc/5lbPC9Q0N5nBLgb+Yd915iL3udB1uFgS3B8YCx66UVHq018DAVFoee7x+gxggeA== + dependencies: + is-descriptor "^1.0.0" + +define-property@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz#d459689e8d654ba77e02a817f8710d702cb16e9d" + integrity sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ== + dependencies: + is-descriptor "^1.0.2" + isobject "^3.0.1" + +delay@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/delay/-/delay-5.0.0.tgz#137045ef1b96e5071060dd5be60bf9334436bd1d" + integrity sha512-ReEBKkIfe4ya47wlPYf/gu5ib6yUG0/Aez0JQZQz94kiWtRQvZIQbTiehsnwHvLSWJnQdhVeqYue7Id1dKr0qw== + +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" + integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== + +delimit-stream@0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/delimit-stream/-/delimit-stream-0.1.0.tgz#9b8319477c0e5f8aeb3ce357ae305fc25ea1cd2b" + integrity sha512-a02fiQ7poS5CnjiJBAsjGLPp5EwVoGHNeu9sziBd9huppRfsAFIpv5zNLv0V1gbop53ilngAf5Kf331AwcoRBQ== + +denque@^1.5.0: + version "1.5.1" + resolved "https://registry.yarnpkg.com/denque/-/denque-1.5.1.tgz#07f670e29c9a78f8faecb2566a1e2c11929c5cbf" + integrity sha512-XwE+iZ4D6ZUB7mfYRMb5wByE8L74HCn30FBN7sWnXksWc1LO1bPDl67pBR9o/kC4z/xSNAwkMYcGgqDV3BE3Hw== + +depd@2.0.0, depd@^2.0.0, depd@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" + integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== + +depd@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" + integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== + +des.js@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.0.1.tgz#5382142e1bdc53f85d86d53e5f4aa7deb91e0843" + integrity sha512-Q0I4pfFrv2VPd34/vfLrFOoRmlYj3OV50i7fskps1jZWK1kApMWWT9G6RRUeYedLcBDIhnSDaUvJMb3AhUlaEA== + dependencies: + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + +destroy@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" + integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== + +detect-newline@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" + integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA== + +dezalgo@1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/dezalgo/-/dezalgo-1.0.3.tgz#7f742de066fc748bc8db820569dddce49bf0d456" + integrity sha512-K7i4zNfT2kgQz3GylDw40ot9GAE47sFZ9EXHFSPP6zONLgH6kWXE0KWJchkbQJLBkRazq4APwZ4OwiFFlT95OQ== + dependencies: + asap "^2.0.0" + wrappy "1" + +diff-sequences@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-24.9.0.tgz#5715d6244e2aa65f48bba0bc972db0b0b11e95b5" + integrity sha512-Dj6Wk3tWyTE+Fo1rW8v0Xhwk80um6yFYKbuAxc9c3EZxIHFDYwbi34Uk42u1CdnIiVorvt4RmlSDjIPyzGC2ew== + +diff-sequences@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-27.5.1.tgz#eaecc0d327fd68c8d9672a1e64ab8dccb2ef5327" + integrity sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ== + +diff@3.5.0: + version "3.5.0" + resolved "https://registry.yarnpkg.com/diff/-/diff-3.5.0.tgz#800c0dd1e0a8bfbc95835c202ad220fe317e5a12" + integrity sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA== + +diff@5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/diff/-/diff-5.0.0.tgz#7ed6ad76d859d030787ec35855f5b1daf31d852b" + integrity sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w== + +diff@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d" + integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== + +diffie-hellman@^5.0.0: + version "5.0.3" + resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.3.tgz#40e8ee98f55a2149607146921c63e1ae5f3d2875" + integrity sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg== + dependencies: + bn.js "^4.1.0" + miller-rabin "^4.0.0" + randombytes "^2.0.0" + +diffparser@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/diffparser/-/diffparser-2.0.1.tgz#4228d5688ab2f05832c320231deda048fcfce8e7" + integrity sha512-XBuCzzdLUBJzXTvbonNPv7+AhNkiUyhyiZBSrhKxKYcIXfAcPOVaINviC2vB+bfBa5EopW60CzkBjuwb3jdmiw== + +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + +doctrine@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz#5cd01fc101621b42c4cd7f5d1a66243716d3f39d" + integrity sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw== + dependencies: + esutils "^2.0.2" + +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== + dependencies: + esutils "^2.0.2" + +dom-serializer@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-2.0.0.tgz#e41b802e1eedf9f6cae183ce5e622d789d7d8e53" + integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg== + dependencies: + domelementtype "^2.3.0" + domhandler "^5.0.2" + entities "^4.2.0" + +dom-storage@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/dom-storage/-/dom-storage-2.1.0.tgz#00fb868bc9201357ea243c7bcfd3304c1e34ea39" + integrity sha512-g6RpyWXzl0RR6OTElHKBl7nwnK87GUyZMYC7JWsB/IA73vpqK2K6LT39x4VepLxlSsWBFrPVLnsSR5Jyty0+2Q== + +dom-walk@^0.1.0: + version "0.1.2" + resolved "https://registry.yarnpkg.com/dom-walk/-/dom-walk-0.1.2.tgz#0c548bef048f4d1f2a97249002236060daa3fd84" + integrity sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w== + +domelementtype@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d" + integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== + +domexception@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/domexception/-/domexception-2.0.1.tgz#fb44aefba793e1574b0af6aed2801d057529f304" + integrity sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg== + dependencies: + webidl-conversions "^5.0.0" + +domhandler@^5.0.1, domhandler@^5.0.2, domhandler@^5.0.3: + version "5.0.3" + resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-5.0.3.tgz#cc385f7f751f1d1fc650c21374804254538c7d31" + integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w== + dependencies: + domelementtype "^2.3.0" + +domutils@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/domutils/-/domutils-3.0.1.tgz#696b3875238338cb186b6c0612bd4901c89a4f1c" + integrity sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q== + dependencies: + dom-serializer "^2.0.0" + domelementtype "^2.3.0" + domhandler "^5.0.1" + +dot-case@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-2.1.1.tgz#34dcf37f50a8e93c2b3bca8bb7fb9155c7da3bee" + integrity sha512-HnM6ZlFqcajLsyudHq7LeeLDr2rFAVYtDv/hV5qchQEidSck8j9OPUsXY9KwJv/lHMtYlX4DjRQqwFYa+0r8Ug== + dependencies: + no-case "^2.2.0" + +dot-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-3.0.4.tgz#9b2b670d00a431667a8a75ba29cd1b98809ce751" + integrity sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + +dot-prop@^4.1.0: + version "4.2.1" + resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-4.2.1.tgz#45884194a71fc2cda71cbb4bceb3a4dd2f433ba4" + integrity sha512-l0p4+mIuJIua0mhxGoh4a+iNL9bmeK5DvnSVQa6T0OhrVmaEa1XScX5Etc673FePCJOArq/4Pa2cLGODUWTPOQ== + dependencies: + is-obj "^1.0.0" + +dot-prop@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-6.0.1.tgz#fc26b3cf142b9e59b74dbd39ed66ce620c681083" + integrity sha512-tE7ztYzXHIeyvc7N+hR3oi7FIbf/NIjVP9hmAt3yMXzrQ072/fpjGLx2GxNxGxUl5V73MEqYzioOMoVhGMJ5cA== + dependencies: + is-obj "^2.0.0" + +dotenv@10.0.0, dotenv@^10.0.0: + version "10.0.0" + resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-10.0.0.tgz#3d4227b8fb95f81096cdd2b66653fb2c7085ba81" + integrity sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q== + +dotenv@^14.2.0: + version "14.3.2" + resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-14.3.2.tgz#7c30b3a5f777c79a3429cb2db358eef6751e8369" + integrity sha512-vwEppIphpFdvaMCaHfCEv9IgwcxMljMw2TnAQBB4VWPvzXQLTb82jwmdOKzlEVUL3gNFT4l4TPKO+Bn+sqcrVQ== + +double-ended-queue@2.1.0-0: + version "2.1.0-0" + resolved "https://registry.yarnpkg.com/double-ended-queue/-/double-ended-queue-2.1.0-0.tgz#103d3527fd31528f40188130c841efdd78264e5c" + integrity sha512-+BNfZ+deCo8hMNpDqDnvT+c0XpJ5cUa6mqYq89bho2Ifze4URTqRkcwR399hWoTrTkbZ/XJYDgP6rc7pRgffEQ== + +drbg.js@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/drbg.js/-/drbg.js-1.0.1.tgz#3e36b6c42b37043823cdbc332d58f31e2445480b" + integrity sha512-F4wZ06PvqxYLFEZKkFxTDcns9oFNk34hvmJSEwdzsxVQ8YI5YaxtACgQatkYgv2VI2CFkUd2Y+xosPQnHv809g== + dependencies: + browserify-aes "^1.0.6" + create-hash "^1.1.2" + create-hmac "^1.1.4" + +dtrace-provider@~0.8: + version "0.8.8" + resolved "https://registry.yarnpkg.com/dtrace-provider/-/dtrace-provider-0.8.8.tgz#2996d5490c37e1347be263b423ed7b297fb0d97e" + integrity sha512-b7Z7cNtHPhH9EJhNNbbeqTcXB8LGFFZhq1PGgEvpeHlzd36bhbdTWoE/Ba/YguqpBSlAPKnARWhVlhunCMwfxg== + dependencies: + nan "^2.14.0" + +duplexer3@^0.1.4: + version "0.1.5" + resolved "https://registry.yarnpkg.com/duplexer3/-/duplexer3-0.1.5.tgz#0b5e4d7bad5de8901ea4440624c8e1d20099217e" + integrity sha512-1A8za6ws41LQgv9HrE/66jyC5yuSjQ3L/KOpFtoBilsAK2iA2wuS5rTt1OCzIvtS2V7nVmedsUU+DGRcjBmOYA== + +ecc-jsbn@~0.1.1: + version "0.1.2" + resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9" + integrity sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw== + dependencies: + jsbn "~0.1.0" + safer-buffer "^2.1.0" + +ee-first@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" + integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= + +eip-712@^0.4.3: + version "0.4.3" + resolved "https://registry.yarnpkg.com/eip-712/-/eip-712-0.4.3.tgz#71da445c3118960933910d168e75f0b1f8f39879" + integrity sha512-RzHERjClqKWennbIFFfoxSTI/BB241R+Dm1FO6KP+NEcFODzApxZHaIXut4fgB4x+5SmQjdW577PfozFoHQ1FA== + dependencies: + "@findeth/abi" "^0.3.0" + keccak "^3.0.1" + superstruct "^0.10.12" + +electron-to-chromium@^1.4.202: + version "1.4.211" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.211.tgz#afaa8b58313807501312d598d99b953568d60f91" + integrity sha512-BZSbMpyFQU0KBJ1JG26XGeFI3i4op+qOYGxftmZXFZoHkhLgsSv4DHDJfl8ogII3hIuzGt51PaZ195OVu0yJ9A== + +elliptic@6.3.3: + version "6.3.3" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.3.3.tgz#5482d9646d54bcb89fd7d994fc9e2e9568876e3f" + integrity sha512-cIky9SO2H8W2eU1NOLySnhOYJnuEWCq9ZJeHvHd/lXzEL9vyraIMfilZSn57X3aVX+wkfYmqkch2LvmTzkjFpA== + dependencies: + bn.js "^4.4.0" + brorand "^1.0.1" + hash.js "^1.0.0" + inherits "^2.0.1" + +elliptic@6.5.4, elliptic@^6.4.0, elliptic@^6.4.1, elliptic@^6.5.2, elliptic@^6.5.3, elliptic@^6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.4.tgz#da37cebd31e79a1367e941b592ed1fbebd58abbb" + integrity sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ== + dependencies: + bn.js "^4.11.9" + brorand "^1.1.0" + hash.js "^1.0.0" + hmac-drbg "^1.0.1" + inherits "^2.0.4" + minimalistic-assert "^1.0.1" + minimalistic-crypto-utils "^1.0.1" + +emittery@0.10.0: + version "0.10.0" + resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.10.0.tgz#bb373c660a9d421bb44706ec4967ed50c02a8026" + integrity sha512-AGvFfs+d0JKCJQ4o01ASQLGPmSCxgfU9RFXvzPvZdjKK8oscynksuJhWrSTSw7j7Ep/sZct5b5ZhYCi8S/t0HQ== + +emittery@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.4.1.tgz#abe9d3297389ba424ac87e53d1c701962ce7433d" + integrity sha512-r4eRSeStEGf6M5SKdrQhhLK5bOwOBxQhIE3YSTnZE3GpKiLfnnhE+tPtrJE79+eDJgm39BM6LSoI8SCx4HbwlQ== + +emittery@^0.8.1: + version "0.8.1" + resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.8.1.tgz#bb23cc86d03b30aa75a7f734819dee2e1ba70860" + integrity sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg== + +emoji-regex@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" + integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== + +enabled@2.0.x: + version "2.0.0" + resolved "https://registry.yarnpkg.com/enabled/-/enabled-2.0.0.tgz#f9dd92ec2d6f4bbc0d5d1e64e21d61cd4665e7c2" + integrity sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ== + +encodeurl@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" + integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= + +encoding-down@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/encoding-down/-/encoding-down-6.3.0.tgz#b1c4eb0e1728c146ecaef8e32963c549e76d082b" + integrity sha512-QKrV0iKR6MZVJV08QY0wp1e7vF6QbhnbQhb07bwpEyuz4uZiZgPlEGdkCROuFkUwdxlFaiPIhjyarH1ee/3vhw== + dependencies: + abstract-leveldown "^6.2.1" + inherits "^2.0.3" + level-codec "^9.0.0" + level-errors "^2.0.0" + +end-of-stream@^1.0.0, end-of-stream@^1.1.0: + version "1.4.4" + resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" + integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== + dependencies: + once "^1.4.0" + +end-stream@~0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/end-stream/-/end-stream-0.1.0.tgz#32003f3f438a2b0143168137f8fa6e9866c81ed5" + integrity sha512-Brl10T8kYnc75IepKizW6Y9liyW8ikz1B7n/xoHrJxoVSSjoqPn30sb7XVFfQERK4QfUMYRGs9dhWwtt2eu6uA== + dependencies: + write-stream "~0.4.3" + +enquirer@^2.3.0, enquirer@^2.3.5: + version "2.3.6" + resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.3.6.tgz#2a7fe5dd634a1e4125a975ec994ff5456dc3734d" + integrity sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg== + dependencies: + ansi-colors "^4.1.1" + +entities@^4.2.0, entities@^4.3.0: + version "4.3.1" + resolved "https://registry.yarnpkg.com/entities/-/entities-4.3.1.tgz#c34062a94c865c322f9d67b4384e4169bcede6a4" + integrity sha512-o4q/dYJlmyjP2zfnaWDUC6A3BQFmVTX+tZPezK7k0GLSU9QYCauscf5Y+qcEPzKL+EixVouYDgLQK5H9GrLpkg== + +env-paths@^2.2.0, env-paths@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" + integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== + +errno@~0.1.1: + version "0.1.8" + resolved "https://registry.yarnpkg.com/errno/-/errno-0.1.8.tgz#8bb3e9c7d463be4976ff888f76b4809ebc2e811f" + integrity sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A== + dependencies: + prr "~1.0.1" + +error-ex@^1.3.1: + version "1.3.2" + resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" + integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== + dependencies: + is-arrayish "^0.2.1" + +error-polyfill@^0.1.3: + version "0.1.3" + resolved "https://registry.yarnpkg.com/error-polyfill/-/error-polyfill-0.1.3.tgz#df848b61ad8834f7a5db69a70b9913df86721d15" + integrity sha512-XHJk60ufE+TG/ydwp4lilOog549iiQF2OAPhkk9DdiYWMrltz5yhDz/xnKuenNwP7gy3dsibssO5QpVhkrSzzg== + dependencies: + capability "^0.2.5" + o3 "^1.0.3" + u3 "^0.1.1" + +es-abstract@^1.19.0, es-abstract@^1.19.1, es-abstract@^1.19.2, es-abstract@^1.19.5, es-abstract@^1.20.0: + version "1.20.1" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.20.1.tgz#027292cd6ef44bd12b1913b828116f54787d1814" + integrity sha512-WEm2oBhfoI2sImeM4OF2zE2V3BYdSF+KnSi9Sidz51fQHd7+JuF8Xgcj9/0o+OWeIeIS/MiuNnlruQrJf16GQA== + dependencies: + call-bind "^1.0.2" + es-to-primitive "^1.2.1" + function-bind "^1.1.1" + function.prototype.name "^1.1.5" + get-intrinsic "^1.1.1" + get-symbol-description "^1.0.0" + has "^1.0.3" + has-property-descriptors "^1.0.0" + has-symbols "^1.0.3" + internal-slot "^1.0.3" + is-callable "^1.2.4" + is-negative-zero "^2.0.2" + is-regex "^1.1.4" + is-shared-array-buffer "^1.0.2" + is-string "^1.0.7" + is-weakref "^1.0.2" + object-inspect "^1.12.0" + object-keys "^1.1.1" + object.assign "^4.1.2" + regexp.prototype.flags "^1.4.3" + string.prototype.trimend "^1.0.5" + string.prototype.trimstart "^1.0.5" + unbox-primitive "^1.0.2" + +es-shim-unscopables@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz#702e632193201e3edf8713635d083d378e510241" + integrity sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w== + dependencies: + has "^1.0.3" + +es-to-primitive@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz#e55cd4c9cdc188bcefb03b366c736323fc5c898a" + integrity sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA== + dependencies: + is-callable "^1.1.4" + is-date-object "^1.0.1" + is-symbol "^1.0.2" + +es5-ext@^0.10.35, es5-ext@^0.10.50: + version "0.10.62" + resolved "https://registry.yarnpkg.com/es5-ext/-/es5-ext-0.10.62.tgz#5e6adc19a6da524bf3d1e02bbc8960e5eb49a9a5" + integrity sha512-BHLqn0klhEpnOKSrzn/Xsz2UIW8j+cGmo9JLzr8BiUapV8hPL9+FliFqjwr9ngW7jWdnxv6eO+/LqyhJVqgrjA== + dependencies: + es6-iterator "^2.0.3" + es6-symbol "^3.1.3" + next-tick "^1.1.0" + +es6-iterator@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/es6-iterator/-/es6-iterator-2.0.3.tgz#a7de889141a05a94b0854403b2d0a0fbfa98f3b7" + integrity sha512-zw4SRzoUkd+cl+ZoE15A9o1oQd920Bb0iOJMQkQhl3jNc03YqVjAhG7scf9C5KWRU/R13Orf588uCC6525o02g== + dependencies: + d "1" + es5-ext "^0.10.35" + es6-symbol "^3.1.1" + +es6-promise@^4.0.3, es6-promise@^4.2.8: + version "4.2.8" + resolved "https://registry.yarnpkg.com/es6-promise/-/es6-promise-4.2.8.tgz#4eb21594c972bc40553d276e510539143db53e0a" + integrity sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w== + +es6-promisify@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/es6-promisify/-/es6-promisify-5.0.0.tgz#5109d62f3e56ea967c4b63505aef08291c8a5203" + integrity sha512-C+d6UdsYDk0lMebHNR4S2NybQMMngAOnOwYBQjTOiv0MkoJMP0Myw2mgpDLBcpfCmRLxyFqYhS/CfOENq4SJhQ== + dependencies: + es6-promise "^4.0.3" + +es6-symbol@^3.1.1, es6-symbol@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/es6-symbol/-/es6-symbol-3.1.3.tgz#bad5d3c1bcdac28269f4cb331e431c78ac705d18" + integrity sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA== + dependencies: + d "^1.0.1" + ext "^1.1.2" + +escalade@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" + integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== + +escape-html@~1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" + integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== + +escape-latex@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/escape-latex/-/escape-latex-1.2.0.tgz#07c03818cf7dac250cce517f4fda1b001ef2bca1" + integrity sha512-nV5aVWW1K0wEiUIEdZ4erkGGH8mDxGyxSeqPzRNtWP7ataw+/olFObw7hujFWlVjNsaDFw5VZ5NzVSIqRgfTiw== + +escape-string-regexp@1.0.5, escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== + +escape-string-regexp@4.0.0, escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +escape-string-regexp@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344" + integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== + +escodegen@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-2.0.0.tgz#5e32b12833e8aa8fa35e1bf0befa89380484c7dd" + integrity sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw== + dependencies: + esprima "^4.0.1" + estraverse "^5.2.0" + esutils "^2.0.2" + optionator "^0.8.1" + optionalDependencies: + source-map "~0.6.1" + +eslint-config-prettier@^8.3.0: + version "8.5.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.5.0.tgz#5a81680ec934beca02c7b1a61cf8ca34b66feab1" + integrity sha512-obmWKLUNCnhtQRKc+tmnYuQl0pFU1ibYJQ5BGhTVB08bHe9wC8qUeG7c08dj9XX+AuPj1YSGSQIHl1pnDHZR0Q== + +eslint-config-standard@^16.0.3: + version "16.0.3" + resolved "https://registry.yarnpkg.com/eslint-config-standard/-/eslint-config-standard-16.0.3.tgz#6c8761e544e96c531ff92642eeb87842b8488516" + integrity sha512-x4fmJL5hGqNJKGHSjnLdgA6U6h1YW/G2dW9fA+cyVur4SK6lyue8+UgNKWlZtUDTXvgKDD/Oa3GQjmB5kjtVvg== + +eslint-import-resolver-node@^0.3.6: + version "0.3.6" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz#4048b958395da89668252001dbd9eca6b83bacbd" + integrity sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw== + dependencies: + debug "^3.2.7" + resolve "^1.20.0" + +eslint-module-utils@^2.7.3: + version "2.7.3" + resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.7.3.tgz#ad7e3a10552fdd0642e1e55292781bd6e34876ee" + integrity sha512-088JEC7O3lDZM9xGe0RerkOMd0EjFl+Yvd1jPWIkMT5u3H9+HC34mWWPnqPrN13gieT9pBOO+Qt07Nb/6TresQ== + dependencies: + debug "^3.2.7" + find-up "^2.1.0" + +eslint-plugin-es@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-es/-/eslint-plugin-es-3.0.1.tgz#75a7cdfdccddc0589934aeeb384175f221c57893" + integrity sha512-GUmAsJaN4Fc7Gbtl8uOBlayo2DqhwWvEzykMHSCZHU3XdJ+NSzzZcVhXh3VxX5icqQ+oQdIEawXX8xkR3mIFmQ== + dependencies: + eslint-utils "^2.0.0" + regexpp "^3.0.0" + +eslint-plugin-import@^2.23.4: + version "2.26.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.26.0.tgz#f812dc47be4f2b72b478a021605a59fc6fe8b88b" + integrity sha512-hYfi3FXaM8WPLf4S1cikh/r4IxnO6zrhZbEGz2b660EJRbuxgpDS5gkCuYgGWg2xxh2rBuIr4Pvhve/7c31koA== + dependencies: + array-includes "^3.1.4" + array.prototype.flat "^1.2.5" + debug "^2.6.9" + doctrine "^2.1.0" + eslint-import-resolver-node "^0.3.6" + eslint-module-utils "^2.7.3" + has "^1.0.3" + is-core-module "^2.8.1" + is-glob "^4.0.3" + minimatch "^3.1.2" + object.values "^1.1.5" + resolve "^1.22.0" + tsconfig-paths "^3.14.1" + +eslint-plugin-node@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-node/-/eslint-plugin-node-11.1.0.tgz#c95544416ee4ada26740a30474eefc5402dc671d" + integrity sha512-oUwtPJ1W0SKD0Tr+wqu92c5xuCeQqB3hSCHasn/ZgjFdA9iDGNkNf2Zi9ztY7X+hNuMib23LNGRm6+uN+KLE3g== + dependencies: + eslint-plugin-es "^3.0.0" + eslint-utils "^2.0.0" + ignore "^5.1.1" + minimatch "^3.0.4" + resolve "^1.10.1" + semver "^6.1.0" + +eslint-plugin-prettier@^3.4.0: + version "3.4.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-prettier/-/eslint-plugin-prettier-3.4.1.tgz#e9ddb200efb6f3d05ffe83b1665a716af4a387e5" + integrity sha512-htg25EUYUeIhKHXjOinK4BgCcDwtLHjqaxCDsMy5nbnUMkKFvIhMVCp+5GFUXQ4Nr8lBsPqtGAqBenbpFqAA2g== + dependencies: + prettier-linter-helpers "^1.0.0" + +eslint-plugin-promise@^5.1.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-promise/-/eslint-plugin-promise-5.2.0.tgz#a596acc32981627eb36d9d75f9666ac1a4564971" + integrity sha512-SftLb1pUG01QYq2A/hGAWfDRXqYD82zE7j7TopDOyNdU+7SvvoXREls/+PRTY17vUXzXnZA/zfnyKgRH6x4JJw== + +eslint-plugin-standard@^4.0.1: + version "4.1.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-standard/-/eslint-plugin-standard-4.1.0.tgz#0c3bf3a67e853f8bbbc580fb4945fbf16f41b7c5" + integrity sha512-ZL7+QRixjTR6/528YNGyDotyffm5OQst/sGxKDwGb9Uqs4In5Egi4+jbobhqJoyoCM6/7v/1A5fhQ7ScMtDjaQ== + +eslint-scope@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" + integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== + dependencies: + esrecurse "^4.3.0" + estraverse "^4.1.1" + +eslint-utils@^2.0.0, eslint-utils@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-2.1.0.tgz#d2de5e03424e707dc10c74068ddedae708741b27" + integrity sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg== + dependencies: + eslint-visitor-keys "^1.1.0" + +eslint-utils@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-3.0.0.tgz#8aebaface7345bb33559db0a1f13a1d2d48c3672" + integrity sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA== + dependencies: + eslint-visitor-keys "^2.0.0" + +eslint-visitor-keys@^1.1.0, eslint-visitor-keys@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz#30ebd1ef7c2fdff01c3a4f151044af25fab0523e" + integrity sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ== + +eslint-visitor-keys@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz#f65328259305927392c938ed44eb0a5c9b2bd303" + integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw== + +eslint@^7.25.0: + version "7.32.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.32.0.tgz#c6d328a14be3fb08c8d1d21e12c02fdb7a2a812d" + integrity sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA== + dependencies: + "@babel/code-frame" "7.12.11" + "@eslint/eslintrc" "^0.4.3" + "@humanwhocodes/config-array" "^0.5.0" + ajv "^6.10.0" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.0.1" + doctrine "^3.0.0" + enquirer "^2.3.5" + escape-string-regexp "^4.0.0" + eslint-scope "^5.1.1" + eslint-utils "^2.1.0" + eslint-visitor-keys "^2.0.0" + espree "^7.3.1" + esquery "^1.4.0" + esutils "^2.0.2" + fast-deep-equal "^3.1.3" + file-entry-cache "^6.0.1" + functional-red-black-tree "^1.0.1" + glob-parent "^5.1.2" + globals "^13.6.0" + ignore "^4.0.6" + import-fresh "^3.0.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + js-yaml "^3.13.1" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash.merge "^4.6.2" + minimatch "^3.0.4" + natural-compare "^1.4.0" + optionator "^0.9.1" + progress "^2.0.0" + regexpp "^3.1.0" + semver "^7.2.1" + strip-ansi "^6.0.0" + strip-json-comments "^3.1.0" + table "^6.0.9" + text-table "^0.2.0" + v8-compile-cache "^2.0.3" + +espree@^7.3.0, espree@^7.3.1: + version "7.3.1" + resolved "https://registry.yarnpkg.com/espree/-/espree-7.3.1.tgz#f2df330b752c6f55019f8bd89b7660039c1bbbb6" + integrity sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g== + dependencies: + acorn "^7.4.0" + acorn-jsx "^5.3.1" + eslint-visitor-keys "^1.3.0" + +esprima@^4.0.0, esprima@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" + integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== + +esquery@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.4.0.tgz#2148ffc38b82e8c7057dfed48425b3e61f0f24a5" + integrity sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^4.1.1: + version "4.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" + integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== + +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +etag@~1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" + integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== + +eth-ens-namehash@2.0.8: + version "2.0.8" + resolved "https://registry.yarnpkg.com/eth-ens-namehash/-/eth-ens-namehash-2.0.8.tgz#229ac46eca86d52e0c991e7cb2aef83ff0f68bcf" + integrity sha512-VWEI1+KJfz4Km//dadyvBBoBeSQ0MHTXPvr8UIXiLW6IanxvAV+DmlZAijZwAyggqGUfwQBeHf7tc9wzc1piSw== + dependencies: + idna-uts46-hx "^2.3.1" + js-sha3 "^0.5.7" + +eth-lib@0.2.7: + version "0.2.7" + resolved "https://registry.yarnpkg.com/eth-lib/-/eth-lib-0.2.7.tgz#2f93f17b1e23aec3759cd4a3fe20c1286a3fc1ca" + integrity sha512-VqEBQKH92jNsaE8lG9CTq8M/bc12gdAfb5MY8Ro1hVyXkh7rOtY3m5tRHK3Hus5HqIAAwU2ivcUjTLVwsvf/kw== + dependencies: + bn.js "^4.11.6" + elliptic "^6.4.0" + xhr-request-promise "^0.1.2" + +eth-lib@0.2.8: + version "0.2.8" + resolved "https://registry.yarnpkg.com/eth-lib/-/eth-lib-0.2.8.tgz#b194058bef4b220ad12ea497431d6cb6aa0623c8" + integrity sha512-ArJ7x1WcWOlSpzdoTBX8vkwlkSQ85CjjifSZtV4co64vWxSV8geWfPI9x4SVYu3DSxnX4yWFVTtGL+j9DUFLNw== + dependencies: + bn.js "^4.11.6" + elliptic "^6.4.0" + xhr-request-promise "^0.1.2" + +eth-lib@^0.1.26: + version "0.1.29" + resolved "https://registry.yarnpkg.com/eth-lib/-/eth-lib-0.1.29.tgz#0c11f5060d42da9f931eab6199084734f4dbd1d9" + integrity sha512-bfttrr3/7gG4E02HoWTDUcDDslN003OlOoBxk9virpAZQ1ja/jDgwkWB8QfJF7ojuEowrqy+lzp9VcJG7/k5bQ== + dependencies: + bn.js "^4.11.6" + elliptic "^6.4.0" + nano-json-stream-parser "^0.1.2" + servify "^0.1.12" + ws "^3.0.0" + xhr-request-promise "^0.1.2" + +ethereum-bloom-filters@^1.0.6: + version "1.0.10" + resolved "https://registry.yarnpkg.com/ethereum-bloom-filters/-/ethereum-bloom-filters-1.0.10.tgz#3ca07f4aed698e75bd134584850260246a5fed8a" + integrity sha512-rxJ5OFN3RwjQxDcFP2Z5+Q9ho4eIdEmSc2ht0fCu8Se9nbXjZ7/031uXoUYJ87KHCOdVeiUuwSnoS7hmYAGVHA== + dependencies: + js-sha3 "^0.8.0" + +ethereum-cryptography@^0.1.3: + version "0.1.3" + resolved "https://registry.yarnpkg.com/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz#8d6143cfc3d74bf79bbd8edecdf29e4ae20dd191" + integrity sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ== + dependencies: + "@types/pbkdf2" "^3.0.0" + "@types/secp256k1" "^4.0.1" + blakejs "^1.1.0" + browserify-aes "^1.2.0" + bs58check "^2.1.2" + create-hash "^1.2.0" + create-hmac "^1.1.7" + hash.js "^1.1.7" + keccak "^3.0.0" + pbkdf2 "^3.0.17" + randombytes "^2.1.0" + safe-buffer "^5.1.2" + scrypt-js "^3.0.0" + secp256k1 "^4.0.1" + setimmediate "^1.0.5" + +ethereum-cryptography@^1.0.3: + version "1.1.2" + resolved "https://registry.yarnpkg.com/ethereum-cryptography/-/ethereum-cryptography-1.1.2.tgz#74f2ac0f0f5fe79f012c889b3b8446a9a6264e6d" + integrity sha512-XDSJlg4BD+hq9N2FjvotwUET9Tfxpxc3kWGE2AqUG5vcbeunnbImVk3cj6e/xT3phdW21mE8R5IugU4fspQDcQ== + dependencies: + "@noble/hashes" "1.1.2" + "@noble/secp256k1" "1.6.3" + "@scure/bip32" "1.1.0" + "@scure/bip39" "1.1.0" + +ethereumjs-abi@^0.6.8: + version "0.6.8" + resolved "https://registry.yarnpkg.com/ethereumjs-abi/-/ethereumjs-abi-0.6.8.tgz#71bc152db099f70e62f108b7cdfca1b362c6fcae" + integrity sha512-Tx0r/iXI6r+lRsdvkFDlut0N08jWMnKRZ6Gkq+Nmw75lZe4e6o3EkSnkaBP5NF6+m5PTGAr9JP43N3LyeoglsA== + dependencies: + bn.js "^4.11.8" + ethereumjs-util "^6.0.0" + +ethereumjs-common@^1.3.2, ethereumjs-common@^1.5.0: + version "1.5.2" + resolved "https://registry.yarnpkg.com/ethereumjs-common/-/ethereumjs-common-1.5.2.tgz#2065dbe9214e850f2e955a80e650cb6999066979" + integrity sha512-hTfZjwGX52GS2jcVO6E2sx4YuFnf0Fhp5ylo4pEPhEffNln7vS59Hr5sLnp3/QCazFLluuBZ+FZ6J5HTp0EqCA== + +ethereumjs-tx@^2.1.1: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ethereumjs-tx/-/ethereumjs-tx-2.1.2.tgz#5dfe7688bf177b45c9a23f86cf9104d47ea35fed" + integrity sha512-zZEK1onCeiORb0wyCXUvg94Ve5It/K6GD1K+26KfFKodiBiS6d9lfCXlUKGBBdQ+bv7Day+JK0tj1K+BeNFRAw== + dependencies: + ethereumjs-common "^1.5.0" + ethereumjs-util "^6.0.0" + +ethereumjs-util@^6.0.0, ethereumjs-util@^6.1.0, ethereumjs-util@^6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz#fcb4e4dd5ceacb9d2305426ab1a5cd93e3163b69" + integrity sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw== + dependencies: + "@types/bn.js" "^4.11.3" + bn.js "^4.11.0" + create-hash "^1.1.2" + elliptic "^6.5.2" + ethereum-cryptography "^0.1.3" + ethjs-util "0.1.6" + rlp "^2.2.3" + +ethereumjs-util@^7.0.10, ethereumjs-util@^7.1.0, ethereumjs-util@^7.1.1, ethereumjs-util@^7.1.4, ethereumjs-util@^7.1.5: + version "7.1.5" + resolved "https://registry.yarnpkg.com/ethereumjs-util/-/ethereumjs-util-7.1.5.tgz#9ecf04861e4fbbeed7465ece5f23317ad1129181" + integrity sha512-SDl5kKrQAudFBUe5OJM9Ac6WmMyYmXX/6sTmLZ3ffG2eY6ZIGBes3pEDxNN6V72WyOw4CPD5RomKdsa8DAAwLg== + dependencies: + "@types/bn.js" "^5.1.0" + bn.js "^5.1.2" + create-hash "^1.1.2" + ethereum-cryptography "^0.1.3" + rlp "^2.2.4" + +ethers@4.0.0-beta.3: + version "4.0.0-beta.3" + resolved "https://registry.yarnpkg.com/ethers/-/ethers-4.0.0-beta.3.tgz#15bef14e57e94ecbeb7f9b39dd0a4bd435bc9066" + integrity sha512-YYPogooSknTwvHg3+Mv71gM/3Wcrx+ZpCzarBj3mqs9njjRkrOo2/eufzhHloOCo3JSoNI4TQJJ6yU5ABm3Uog== + dependencies: + "@types/node" "^10.3.2" + aes-js "3.0.0" + bn.js "^4.4.0" + elliptic "6.3.3" + hash.js "1.1.3" + js-sha3 "0.5.7" + scrypt-js "2.0.3" + setimmediate "1.0.4" + uuid "2.0.1" + xmlhttprequest "1.8.0" + +ethers@^4.0.20, ethers@^4.0.32: + version "4.0.49" + resolved "https://registry.yarnpkg.com/ethers/-/ethers-4.0.49.tgz#0eb0e9161a0c8b4761be547396bbe2fb121a8894" + integrity sha512-kPltTvWiyu+OktYy1IStSO16i2e7cS9D9OxZ81q2UUaiNPVrm/RTcbxamCXF9VUSKzJIdJV68EAIhTEVBalRWg== + dependencies: + aes-js "3.0.0" + bn.js "^4.11.9" + elliptic "6.5.4" + hash.js "1.1.3" + js-sha3 "0.5.7" + scrypt-js "2.0.4" + setimmediate "1.0.4" + uuid "2.0.1" + xmlhttprequest "1.8.0" + +ethers@^5.0.19, ethers@^5.0.24, ethers@^5.6.1, ethers@^5.6.2, ethers@^5.6.8: + version "5.6.9" + resolved "https://registry.yarnpkg.com/ethers/-/ethers-5.6.9.tgz#4e12f8dfcb67b88ae7a78a9519b384c23c576a4d" + integrity sha512-lMGC2zv9HC5EC+8r429WaWu3uWJUCgUCt8xxKCFqkrFuBDZXDYIdzDUECxzjf2BMF8IVBByY1EBoGSL3RTm8RA== + dependencies: + "@ethersproject/abi" "5.6.4" + "@ethersproject/abstract-provider" "5.6.1" + "@ethersproject/abstract-signer" "5.6.2" + "@ethersproject/address" "5.6.1" + "@ethersproject/base64" "5.6.1" + "@ethersproject/basex" "5.6.1" + "@ethersproject/bignumber" "5.6.2" + "@ethersproject/bytes" "5.6.1" + "@ethersproject/constants" "5.6.1" + "@ethersproject/contracts" "5.6.2" + "@ethersproject/hash" "5.6.1" + "@ethersproject/hdnode" "5.6.2" + "@ethersproject/json-wallets" "5.6.1" + "@ethersproject/keccak256" "5.6.1" + "@ethersproject/logger" "5.6.0" + "@ethersproject/networks" "5.6.4" + "@ethersproject/pbkdf2" "5.6.1" + "@ethersproject/properties" "5.6.0" + "@ethersproject/providers" "5.6.8" + "@ethersproject/random" "5.6.1" + "@ethersproject/rlp" "5.6.1" + "@ethersproject/sha2" "5.6.1" + "@ethersproject/signing-key" "5.6.2" + "@ethersproject/solidity" "5.6.1" + "@ethersproject/strings" "5.6.1" + "@ethersproject/transactions" "5.6.2" + "@ethersproject/units" "5.6.1" + "@ethersproject/wallet" "5.6.2" + "@ethersproject/web" "5.6.1" + "@ethersproject/wordlists" "5.6.1" + +ethjs-unit@0.1.6: + version "0.1.6" + resolved "https://registry.yarnpkg.com/ethjs-unit/-/ethjs-unit-0.1.6.tgz#c665921e476e87bce2a9d588a6fe0405b2c41699" + integrity sha512-/Sn9Y0oKl0uqQuvgFk/zQgR7aw1g36qX/jzSQ5lSwlO0GigPymk4eGQfeNTD03w1dPOqfz8V77Cy43jH56pagw== + dependencies: + bn.js "4.11.6" + number-to-bn "1.7.0" + +ethjs-util@0.1.6, ethjs-util@^0.1.6: + version "0.1.6" + resolved "https://registry.yarnpkg.com/ethjs-util/-/ethjs-util-0.1.6.tgz#f308b62f185f9fe6237132fb2a9818866a5cd536" + integrity sha512-CUnVOQq7gSpDHZVVrQW8ExxUETWrnrvXYvYz55wOU8Uj4VCgw56XC2B/fVqQN+f7gmrnRHSLVnFAwsCuNwji8w== + dependencies: + is-hex-prefixed "1.0.0" + strip-hex-prefix "1.0.0" + +event-target-shim@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/event-target-shim/-/event-target-shim-5.0.1.tgz#5d4d3ebdf9583d63a5333ce2deb7480ab2b05789" + integrity sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ== + +eventemitter3@3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-3.1.2.tgz#2d3d48f9c346698fce83a85d7d664e98535df6e7" + integrity sha512-tvtQIeLVHjDkJYnzf2dgVMxfuSGJeM/7UCG17TT4EumTfNtF+0nebF/4zWOIkCreAbtNqhGEboB6BWrwqNaw4Q== + +eventemitter3@4.0.4: + version "4.0.4" + resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-4.0.4.tgz#b5463ace635a083d018bdc7c917b4c5f10a85384" + integrity sha512-rlaVLnVxtxvoyLsQQFBx53YmXHDxRIzzTLbdfxqi4yocpSjAxXwkU0cScM5JgSKMqEhrZpnvQ2D9gjylR0AimQ== + +eventemitter3@^4.0.7: + version "4.0.7" + resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-4.0.7.tgz#2de9b68f6528d5644ef5c59526a1b4a07306169f" + integrity sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw== + +evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" + integrity sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA== + dependencies: + md5.js "^1.3.4" + safe-buffer "^5.1.1" + +exception-formatter@^1.0.4: + version "1.0.7" + resolved "https://registry.yarnpkg.com/exception-formatter/-/exception-formatter-1.0.7.tgz#3291616b86fceabefa97aee6a4708032c6e3b96d" + integrity sha512-zV45vEsjytJrwfGq6X9qd1Ll56cW4NC2mhCO6lqwMk4ZpA1fZ6C3UiaQM/X7if+7wZFmCgss3ahp9B/uVFuLRw== + dependencies: + colors "^1.0.3" + +execa@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/execa/-/execa-1.0.0.tgz#c6236a5bb4df6d6f15e88e7f017798216749ddd8" + integrity sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA== + dependencies: + cross-spawn "^6.0.0" + get-stream "^4.0.0" + is-stream "^1.1.0" + npm-run-path "^2.0.0" + p-finally "^1.0.0" + signal-exit "^3.0.0" + strip-eof "^1.0.0" + +execa@^5.0.0: + version "5.1.1" + resolved "https://registry.yarnpkg.com/execa/-/execa-5.1.1.tgz#f80ad9cbf4298f7bd1d4c9555c21e93741c411dd" + integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== + dependencies: + cross-spawn "^7.0.3" + get-stream "^6.0.0" + human-signals "^2.1.0" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.1" + onetime "^5.1.2" + signal-exit "^3.0.3" + strip-final-newline "^2.0.0" + +exit@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/exit/-/exit-0.1.2.tgz#0632638f8d877cc82107d30a0fff1a17cba1cd0c" + integrity sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ== + +expand-brackets@^2.1.4: + version "2.1.4" + resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz#b77735e315ce30f6b6eff0f83b04151a22449622" + integrity sha512-w/ozOKR9Obk3qoWeY/WDi6MFta9AoMR+zud60mdnbniMcBxRuFJyDt2LdX/14A1UABeqk+Uk+LDfUpvoGKppZA== + dependencies: + debug "^2.3.3" + define-property "^0.2.5" + extend-shallow "^2.0.1" + posix-character-classes "^0.1.0" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.1" + +expect@^24.1.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/expect/-/expect-24.9.0.tgz#b75165b4817074fa4a157794f46fe9f1ba15b6ca" + integrity sha512-wvVAx8XIol3Z5m9zvZXiyZOQ+sRJqNTIm6sGjdWlaZIeupQGO3WbYI+15D/AmEwZywL6wtJkbAbJtzkOfBuR0Q== + dependencies: + "@jest/types" "^24.9.0" + ansi-styles "^3.2.0" + jest-get-type "^24.9.0" + jest-matcher-utils "^24.9.0" + jest-message-util "^24.9.0" + jest-regex-util "^24.9.0" + +expect@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/expect/-/expect-27.5.1.tgz#83ce59f1e5bdf5f9d2b94b61d2050db48f3fef74" + integrity sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw== + dependencies: + "@jest/types" "^27.5.1" + jest-get-type "^27.5.1" + jest-matcher-utils "^27.5.1" + jest-message-util "^27.5.1" + +exponential-backoff@3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/exponential-backoff/-/exponential-backoff-3.1.0.tgz#9409c7e579131f8bd4b32d7d8094a911040f2e68" + integrity sha512-oBuz5SYz5zzyuHINoe9ooePwSu0xApKWgeNzok4hZ5YKXFh9zrQBEM15CXqoZkJJPuI2ArvqjPQd8UKJA753XA== + +express-ipfilter@^1.2.0: + version "1.3.1" + resolved "https://registry.yarnpkg.com/express-ipfilter/-/express-ipfilter-1.3.1.tgz#200ccee7954bf914d2e2b150e389e3234ee142d3" + integrity sha512-9WZC8wGkI6I6ygZNzuZ2MbFJiGoDXs1dM+E8LKtSP13pdgqrnkonWlgvvbxG3YZpa7Haz7Ndum9/J6qkj52OqA== + dependencies: + ip "^1.1.8" + lodash "^4.17.11" + proxy-addr "^2.0.7" + range_check "^2.0.4" + +express-winston@^4.1.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/express-winston/-/express-winston-4.2.0.tgz#e9d535d52aa4c125a54a29cce132ae2e3633f4fa" + integrity sha512-EMD74g63nVHi7pFleQw7KHCxiA1pjF5uCwbCfzGqmFxs9KvlDPIVS3cMGpULm6MshExMT9TjC3SqmRGB9kb7yw== + dependencies: + chalk "^2.4.2" + lodash "^4.17.21" + +express@^4.14.0, express@^4.17.1: + version "4.18.1" + resolved "https://registry.yarnpkg.com/express/-/express-4.18.1.tgz#7797de8b9c72c857b9cd0e14a5eea80666267caf" + integrity sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q== + dependencies: + accepts "~1.3.8" + array-flatten "1.1.1" + body-parser "1.20.0" + content-disposition "0.5.4" + content-type "~1.0.4" + cookie "0.5.0" + cookie-signature "1.0.6" + debug "2.6.9" + depd "2.0.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + finalhandler "1.2.0" + fresh "0.5.2" + http-errors "2.0.0" + merge-descriptors "1.0.1" + methods "~1.1.2" + on-finished "2.4.1" + parseurl "~1.3.3" + path-to-regexp "0.1.7" + proxy-addr "~2.0.7" + qs "6.10.3" + range-parser "~1.2.1" + safe-buffer "5.2.1" + send "0.18.0" + serve-static "1.15.0" + setprototypeof "1.2.0" + statuses "2.0.1" + type-is "~1.6.18" + utils-merge "1.0.1" + vary "~1.1.2" + +ext@^1.1.2: + version "1.6.0" + resolved "https://registry.yarnpkg.com/ext/-/ext-1.6.0.tgz#3871d50641e874cc172e2b53f919842d19db4c52" + integrity sha512-sdBImtzkq2HpkdRLtlLWDa6w4DX22ijZLKx8BMPUuKe1c5lbN6xwQDQCxSfxBQnHZ13ls/FH0MQZx/q/gr6FQg== + dependencies: + type "^2.5.0" + +extend-shallow@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" + integrity sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug== + dependencies: + is-extendable "^0.1.0" + +extend-shallow@^3.0.0, extend-shallow@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz#26a71aaf073b39fb2127172746131c2704028db8" + integrity sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q== + dependencies: + assign-symbols "^1.0.0" + is-extendable "^1.0.1" + +extend@~3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" + integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== + +external-editor@^3.0.3: + version "3.1.0" + resolved "https://registry.yarnpkg.com/external-editor/-/external-editor-3.1.0.tgz#cb03f740befae03ea4d283caed2741a83f335495" + integrity sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew== + dependencies: + chardet "^0.7.0" + iconv-lite "^0.4.24" + tmp "^0.0.33" + +extglob@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543" + integrity sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw== + dependencies: + array-unique "^0.3.2" + define-property "^1.0.0" + expand-brackets "^2.1.4" + extend-shallow "^2.0.1" + fragment-cache "^0.2.1" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.1" + +extract-files@^9.0.0: + version "9.0.0" + resolved "https://registry.yarnpkg.com/extract-files/-/extract-files-9.0.0.tgz#8a7744f2437f81f5ed3250ed9f1550de902fe54a" + integrity sha512-CvdFfHkC95B4bBBk36hcEmvdR2awOdhhVUYH6S/zrVj3477zven/fJMYg7121h4T1xHZC+tetUpubpAhxwI7hQ== + +extsprintf@1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" + integrity sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g== + +extsprintf@^1.2.0: + version "1.4.1" + resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.1.tgz#8d172c064867f235c0c84a596806d279bf4bcc07" + integrity sha512-Wrk35e8ydCKDj/ArClo1VrPVmN8zph5V4AtHwIuHhvMXsKf73UT3BOD+azBIW+3wOJ4FhEH7zyaJCFvChjYvMA== + +eyes@^0.1.8: + version "0.1.8" + resolved "https://registry.yarnpkg.com/eyes/-/eyes-0.1.8.tgz#62cf120234c683785d902348a800ef3e0cc20bc0" + integrity sha512-GipyPsXO1anza0AOZdy69Im7hGFCNB7Y/NGjDlZGJ3GJJLtwNSb2vrzYrTYJRrRloVx7pl+bhUaTB8yiccPvFQ== + +fast-check@3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/fast-check/-/fast-check-3.1.1.tgz#72c5ae7022a4e86504762e773adfb8a5b0b01252" + integrity sha512-3vtXinVyuUKCKFKYcwXhGE6NtGWkqF8Yh3rvMZNzmwz8EPrgoc/v4pDdLHyLnCyCI5MZpZZkDEwFyXyEONOxpA== + dependencies: + pure-rand "^5.0.1" + +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-diff@^1.1.2: + version "1.2.0" + resolved "https://registry.yarnpkg.com/fast-diff/-/fast-diff-1.2.0.tgz#73ee11982d86caaf7959828d519cfe927fac5f03" + integrity sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w== + +fast-glob@^2.2.3: + version "2.2.7" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-2.2.7.tgz#6953857c3afa475fff92ee6015d52da70a4cd39d" + integrity sha512-g1KuQwHOZAmOZMuBtHdxDtju+T2RT8jgCC9aANsbpdiDDTSnjgfuVsIBNKbUeJI3oKMRExcfNDtJl4OhbffMsw== + dependencies: + "@mrmlnc/readdir-enhanced" "^2.2.1" + "@nodelib/fs.stat" "^1.1.2" + glob-parent "^3.1.0" + is-glob "^4.0.0" + merge2 "^1.2.3" + micromatch "^3.1.10" + +fast-glob@^3.2.9: + version "3.2.11" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.11.tgz#a1172ad95ceb8a16e20caa5c5e56480e5129c1d9" + integrity sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + +fast-json-stable-stringify@2.x, fast-json-stable-stringify@^2.0.0, fast-json-stable-stringify@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-levenshtein@^2.0.6, fast-levenshtein@~2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + +fast-safe-stringify@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz#c406a83b6e70d9e35ce3b30a81141df30aeba884" + integrity sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA== + +fast-stable-stringify@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fast-stable-stringify/-/fast-stable-stringify-1.0.0.tgz#5c5543462b22aeeefd36d05b34e51c78cb86d313" + integrity sha512-wpYMUmFu5f00Sm0cj2pfivpmawLZ0NKdviQ4w9zJeR8JVtOpOxHmLaJuj0vxvGqMJQWyP/COUkF75/57OKyRag== + +fastq@^1.6.0: + version "1.13.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.13.0.tgz#616760f88a7526bdfc596b7cab8c18938c36b98c" + integrity sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw== + dependencies: + reusify "^1.0.4" + +faye-websocket@0.11.3: + version "0.11.3" + resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.3.tgz#5c0e9a8968e8912c286639fde977a8b209f2508e" + integrity sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA== + dependencies: + websocket-driver ">=0.5.1" + +fb-watchman@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.1.tgz#fc84fb39d2709cf3ff6d743706157bb5708a8a85" + integrity sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg== + dependencies: + bser "2.1.1" + +fd-slicer@~1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/fd-slicer/-/fd-slicer-1.1.0.tgz#25c7c89cb1f9077f8891bbe61d8f390eae256f1e" + integrity sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g== + dependencies: + pend "~1.2.0" + +fecha@^4.2.0: + version "4.2.3" + resolved "https://registry.yarnpkg.com/fecha/-/fecha-4.2.3.tgz#4d9ccdbc61e8629b259fdca67e65891448d569fd" + integrity sha512-OP2IUU6HeYKJi3i0z4A19kHMQoLVs4Hc+DPqqxI2h/DPZHTm/vjsfC6P0b4jCMy14XizLBqvndQ+UilD7707Jw== + +fetch-cookie@0.11.0: + version "0.11.0" + resolved "https://registry.yarnpkg.com/fetch-cookie/-/fetch-cookie-0.11.0.tgz#e046d2abadd0ded5804ce7e2cae06d4331c15407" + integrity sha512-BQm7iZLFhMWFy5CZ/162sAGjBfdNWb7a8LEqqnzsHFhxT/X/SVj/z2t2nu3aJvjlbQkrAlTUApplPRjWyH4mhA== + dependencies: + tough-cookie "^2.3.3 || ^3.0.1 || ^4.0.0" + +figures@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/figures/-/figures-2.0.0.tgz#3ab1a2d2a62c8bfb431a0c94cb797a2fce27c962" + integrity sha512-Oa2M9atig69ZkfwiApY8F2Yy+tzMbazyvqv21R0NsSC8floSOC09BbT1ITWAdoMGQvJ/aZnR1KMwdx9tvHnTNA== + dependencies: + escape-string-regexp "^1.0.5" + +file-entry-cache@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" + integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg== + dependencies: + flat-cache "^3.0.4" + +file-stream-rotator@^0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/file-stream-rotator/-/file-stream-rotator-0.6.1.tgz#007019e735b262bb6c6f0197e58e5c87cb96cec3" + integrity sha512-u+dBid4PvZw17PmDeRcNOtCP9CCK/9lRN2w+r1xIS7yOL9JFrIBKTvrYsxT4P0pGtThYTn++QS5ChHaUov3+zQ== + dependencies: + moment "^2.29.1" + +file-type@^3.8.0: + version "3.9.0" + resolved "https://registry.yarnpkg.com/file-type/-/file-type-3.9.0.tgz#257a078384d1db8087bc449d107d52a52672b9e9" + integrity sha512-RLoqTXE8/vPmMuTI88DAzhMYC99I8BWv7zYP4A1puo5HIjEJ5EX48ighy4ZyKMG9EDXxBgW6e++cn7d1xuFghA== + +file-type@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/file-type/-/file-type-5.2.0.tgz#2ddbea7c73ffe36368dfae49dc338c058c2b8ad6" + integrity sha512-Iq1nJ6D2+yIO4c8HHg4fyVb8mAJieo1Oloy1mLLaB2PvezNedhBVm+QU7g0qM42aiMbRXTxKKwGD17rjKNJYVQ== + +file-type@^6.1.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/file-type/-/file-type-6.2.0.tgz#e50cd75d356ffed4e306dc4f5bcf52a79903a919" + integrity sha512-YPcTBDV+2Tm0VqjybVd32MHdlEGAtuxS3VAYsumFokDSMG+ROT5wawGlnHDoz7bfMcMDt9hxuXvXwoKUx2fkOg== + +file-uri-to-path@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" + integrity sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw== + +fill-range@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7" + integrity sha512-VcpLTWqWDiTerugjj8e3+esbg+skS3M9e54UuR3iCeIDMXCLTsAH8hTSzDQU/X6/6t3eYkOKoZSef2PlU6U1XQ== + dependencies: + extend-shallow "^2.0.1" + is-number "^3.0.0" + repeat-string "^1.6.1" + to-regex-range "^2.1.0" + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +finalhandler@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.2.0.tgz#7d23fe5731b207b4640e4fcd00aec1f9207a7b32" + integrity sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg== + dependencies: + debug "2.6.9" + encodeurl "~1.0.2" + escape-html "~1.0.3" + on-finished "2.4.1" + parseurl "~1.3.3" + statuses "2.0.1" + unpipe "~1.0.0" + +find-replace@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/find-replace/-/find-replace-1.0.3.tgz#b88e7364d2d9c959559f388c66670d6130441fa0" + integrity sha512-KrUnjzDCD9426YnCP56zGYy/eieTnhtK6Vn++j+JJzmlsWWwEkDnsyVF575spT6HJ6Ow9tlbT3TQTDsa+O4UWA== + dependencies: + array-back "^1.0.4" + test-value "^2.1.0" + +find-up@5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +find-up@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz#45d1b7e506c717ddd482775a2b77920a3c0c57a7" + integrity sha512-NWzkk0jSJtTt08+FBFMvXoeZnOJD+jTtsRmBYbAIzJdX6l7dLgR7CTubCM5/eDdPUBvLCeVasP1brfVR/9/EZQ== + dependencies: + locate-path "^2.0.0" + +find-up@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" + integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== + dependencies: + locate-path "^3.0.0" + +find-up@^4.0.0, find-up@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" + integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== + dependencies: + locate-path "^5.0.0" + path-exists "^4.0.0" + +find@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/find/-/find-0.3.0.tgz#4082e8fc8d8320f1a382b5e4f521b9bc50775cb8" + integrity sha512-iSd+O4OEYV/I36Zl8MdYJO0xD82wH528SaCieTVHhclgiYNe9y+yPKSwK+A7/WsmHL1EZ+pYUJBXWTL5qofksw== + dependencies: + traverse-chain "~0.1.0" + +firebase@^7.8.0: + version "7.24.0" + resolved "https://registry.yarnpkg.com/firebase/-/firebase-7.24.0.tgz#dab53b9c0f1c9538d2d6f4f51769897b0b6d60d8" + integrity sha512-j6jIyGFFBlwWAmrlUg9HyQ/x+YpsPkc/TTkbTyeLwwAJrpAmmEHNPT6O9xtAnMV4g7d3RqLL/u9//aZlbY4rQA== + dependencies: + "@firebase/analytics" "0.6.0" + "@firebase/app" "0.6.11" + "@firebase/app-types" "0.6.1" + "@firebase/auth" "0.15.0" + "@firebase/database" "0.6.13" + "@firebase/firestore" "1.18.0" + "@firebase/functions" "0.5.1" + "@firebase/installations" "0.4.17" + "@firebase/messaging" "0.7.1" + "@firebase/performance" "0.4.2" + "@firebase/polyfill" "0.3.36" + "@firebase/remote-config" "0.1.28" + "@firebase/storage" "0.3.43" + "@firebase/util" "0.3.2" + +flat-cache@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" + integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + dependencies: + flatted "^3.1.0" + rimraf "^3.0.2" + +flat@^5.0.2: + version "5.0.2" + resolved "https://registry.yarnpkg.com/flat/-/flat-5.0.2.tgz#8ca6fe332069ffa9d324c327198c598259ceb241" + integrity sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ== + +flatted@^3.1.0: + version "3.2.6" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.6.tgz#022e9218c637f9f3fc9c35ab9c9193f05add60b2" + integrity sha512-0sQoMh9s0BYsm+12Huy/rkKxVu4R1+r96YX5cG44rHV0pQ6iC3Q+mkoMFaGWObMFYQxCVT+ssG1ksneA2MI9KQ== + +fn.name@1.x.x: + version "1.1.0" + resolved "https://registry.yarnpkg.com/fn.name/-/fn.name-1.1.0.tgz#26cad8017967aea8731bc42961d04a3d5988accc" + integrity sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw== + +follow-redirects@1.5.10: + version "1.5.10" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.5.10.tgz#7b7a9f9aea2fdff36786a94ff643ed07f4ff5e2a" + integrity sha512-0V5l4Cizzvqt5D44aTXbFZz+FtyXV1vrDN6qrelxtfYQKW0KO0W2T/hkE8xvGa/540LkZlkaUjO4ailYTFtHVQ== + dependencies: + debug "=3.1.0" + +follow-redirects@^1.12.1, follow-redirects@^1.14.0: + version "1.15.1" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.1.tgz#0ca6a452306c9b276e4d3127483e29575e207ad5" + integrity sha512-yLAMQs+k0b2m7cVxpS1VKJVvoz7SS9Td1zss3XRwXj+ZDH00RJgnuLx7E44wx02kQLrdM3aOOy+FpzS7+8OizA== + +follow-redirects@^1.14.9: + version "1.15.2" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.2.tgz#b460864144ba63f2681096f274c4e57026da2c13" + integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA== + +for-each@^0.3.3: + version "0.3.3" + resolved "https://registry.yarnpkg.com/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" + integrity sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw== + dependencies: + is-callable "^1.1.3" + +for-in@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" + integrity sha512-7EwmXrOjyL+ChxMhmG5lnW9MPt1aIeZEwKhQzoBUdTV0N3zuwWDZYVJatDvZ2OyzPUvdIAZDsCetk3coyMfcnQ== + +foreach@^2.0.4: + version "2.0.6" + resolved "https://registry.yarnpkg.com/foreach/-/foreach-2.0.6.tgz#87bcc8a1a0e74000ff2bf9802110708cfb02eb6e" + integrity sha512-k6GAGDyqLe9JaebCsFCoudPPWfihKu8pylYXRlqP1J7ms39iPoTtk2fviNglIeQEwdh0bQeKJ01ZPyuyQvKzwg== + +forever-agent@~0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" + integrity sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw== + +form-data-encoder@1.7.1: + version "1.7.1" + resolved "https://registry.yarnpkg.com/form-data-encoder/-/form-data-encoder-1.7.1.tgz#ac80660e4f87ee0d3d3c3638b7da8278ddb8ec96" + integrity sha512-EFRDrsMm/kyqbTQocNvRXMLjc7Es2Vk+IQFx/YW7hkUH1eBl4J1fqiP34l74Yt0pFLCNpc06fkbVk00008mzjg== + +form-data@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-3.0.1.tgz#ebd53791b78356a99af9a300d4282c4d5eb9755f" + integrity sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +form-data@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" + integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +form-data@~2.3.2: + version "2.3.3" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6" + integrity sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.6" + mime-types "^2.1.12" + +formidable@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/formidable/-/formidable-2.0.1.tgz#4310bc7965d185536f9565184dee74fbb75557ff" + integrity sha512-rjTMNbp2BpfQShhFbR3Ruk3qk2y9jKpvMW78nJgx8QKtxjDVrwbZG+wvDOmVbifHyOUOQJXxqEy6r0faRrPzTQ== + dependencies: + dezalgo "1.0.3" + hexoid "1.0.0" + once "1.4.0" + qs "6.9.3" + +forwarded@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" + integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== + +fp-ts@1.19.3: + version "1.19.3" + resolved "https://registry.yarnpkg.com/fp-ts/-/fp-ts-1.19.3.tgz#261a60d1088fbff01f91256f91d21d0caaaaa96f" + integrity sha512-H5KQDspykdHuztLTg+ajGN0Z2qUjcEf3Ybxc6hLt0k7/zPkn29XnKnxlBPyW2XIddWrGaJBzBl4VLYOtk39yZg== + +fp-ts@^1.0.0: + version "1.19.5" + resolved "https://registry.yarnpkg.com/fp-ts/-/fp-ts-1.19.5.tgz#3da865e585dfa1fdfd51785417357ac50afc520a" + integrity sha512-wDNqTimnzs8QqpldiId9OavWK2NptormjXnRJTQecNjzwfyp6P/8s/zG8e4h3ja3oqkKaY72UlTjQYt/1yXf9A== + +fraction.js@^4.1.1, fraction.js@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/fraction.js/-/fraction.js-4.2.0.tgz#448e5109a313a3527f5a3ab2119ec4cf0e0e2950" + integrity sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA== + +fragment-cache@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19" + integrity sha512-GMBAbW9antB8iZRHLoGw0b3HANt57diZYFO/HL1JGIC1MjKrdmhxvrJbupnVvpys0zsz7yBApXdQyfepKly2kA== + dependencies: + map-cache "^0.2.2" + +fresh@0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" + integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== + +fs-constants@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs-constants/-/fs-constants-1.0.0.tgz#6be0de9be998ce16af8afc24497b9ee9b7ccd9ad" + integrity sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow== + +fs-extra@^0.30.0: + version "0.30.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-0.30.0.tgz#f233ffcc08d4da7d432daa449776989db1df93f0" + integrity sha512-UvSPKyhMn6LEd/WpUaV9C9t3zATuqoqfWc3QdPhPLb58prN9tqYPlPWi8Krxi44loBoUzlobqZ3+8tGpxxSzwA== + dependencies: + graceful-fs "^4.1.2" + jsonfile "^2.1.0" + klaw "^1.0.0" + path-is-absolute "^1.0.0" + rimraf "^2.2.8" + +fs-extra@^10.0.0: + version "10.1.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-10.1.0.tgz#02873cfbc4084dde127eaa5f9905eef2325d1abf" + integrity sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ== + dependencies: + graceful-fs "^4.2.0" + jsonfile "^6.0.1" + universalify "^2.0.0" + +fs-extra@^4.0.2: + version "4.0.3" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-4.0.3.tgz#0d852122e5bc5beb453fb028e9c0c9bf36340c94" + integrity sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg== + dependencies: + graceful-fs "^4.1.2" + jsonfile "^4.0.0" + universalify "^0.1.0" + +fs-extra@^7.0.0, fs-extra@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-7.0.1.tgz#4f189c44aa123b895f722804f55ea23eadc348e9" + integrity sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw== + dependencies: + graceful-fs "^4.1.2" + jsonfile "^4.0.0" + universalify "^0.1.0" + +fs-extra@^9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" + integrity sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ== + dependencies: + at-least-node "^1.0.0" + graceful-fs "^4.2.0" + jsonfile "^6.0.1" + universalify "^2.0.0" + +fs-minipass@^1.2.7: + version "1.2.7" + resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-1.2.7.tgz#ccff8570841e7fe4265693da88936c55aed7f7c7" + integrity sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA== + dependencies: + minipass "^2.6.0" + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== + +fsevents@^2.3.2, fsevents@~2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + +function-bind@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" + integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== + +function.prototype.name@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.5.tgz#cce0505fe1ffb80503e6f9e46cc64e46a12a9621" + integrity sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.0" + functions-have-names "^1.2.2" + +functional-red-black-tree@^1.0.1, functional-red-black-tree@~1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" + integrity sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g== + +functions-have-names@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" + integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== + +ganache@7.4.4: + version "7.4.4" + resolved "https://registry.yarnpkg.com/ganache/-/ganache-7.4.4.tgz#af1bb7e85cde010c8d05186ab952a69df970dfa2" + integrity sha512-wC5XZB7ttHXc4rYfAq8+ieOZZajlsTdWsWievtQNjiuxcrIkqPqSwAZK6IP5mbooe/HSp3bDGJhXW5EHVd2G9w== + dependencies: + "@trufflesuite/bigint-buffer" "1.1.10" + "@types/bn.js" "^5.1.0" + "@types/lru-cache" "5.1.1" + "@types/seedrandom" "3.0.1" + emittery "0.10.0" + keccak "3.0.2" + leveldown "6.1.0" + secp256k1 "4.0.3" + optionalDependencies: + bufferutil "4.0.5" + utf-8-validate "5.0.7" + +gensync@^1.0.0-beta.2: + version "1.0.0-beta.2" + resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" + integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== + +get-caller-file@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.3.tgz#f978fa4c90d1dfe7ff2d6beda2a515e713bdcf4a" + integrity sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w== + +get-caller-file@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" + integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== + +get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.2.tgz#336975123e05ad0b7ba41f152ee4aadbea6cf598" + integrity sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA== + dependencies: + function-bind "^1.1.1" + has "^1.0.3" + has-symbols "^1.0.3" + +get-package-type@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" + integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== + +get-stdin@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/get-stdin/-/get-stdin-6.0.0.tgz#9e09bf712b360ab9225e812048f71fde9c89657b" + integrity sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g== + +get-stream@^2.2.0: + version "2.3.1" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-2.3.1.tgz#5f38f93f346009666ee0150a054167f91bdd95de" + integrity sha512-AUGhbbemXxrZJRD5cDvKtQxLuYaIbNtDTK8YqupCI393Q2KSTreEsLUN3ZxAWFGiKTzL6nKuzfcIvieflUX9qA== + dependencies: + object-assign "^4.0.1" + pinkie-promise "^2.0.0" + +get-stream@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz#8e943d1358dc37555054ecbe2edb05aa174ede14" + integrity sha512-GlhdIUuVakc8SJ6kK0zAFbiGzRFzNnY4jUuEbV9UROo4Y+0Ny4fjvcZFVTeDA4odpFyOQzaw6hXukJSq/f28sQ== + +get-stream@^4.0.0, get-stream@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz#c1b255575f3dc21d59bfc79cd3d2b46b1c3a54b5" + integrity sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w== + dependencies: + pump "^3.0.0" + +get-stream@^5.1.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" + integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== + dependencies: + pump "^3.0.0" + +get-stream@^6.0.0, get-stream@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" + integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== + +get-symbol-description@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" + integrity sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.1.1" + +get-value@^2.0.3, get-value@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" + integrity sha512-Ln0UQDlxH1BapMu3GPtf7CuYNwRZf2gwCuPqbyG6pB8WfmFpzqcy4xtAaAMUhnNqjMKTiCPZG2oMT3YSx8U2NA== + +getpass@^0.1.1: + version "0.1.7" + resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" + integrity sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng== + dependencies: + assert-plus "^1.0.0" + +glob-parent@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-3.1.0.tgz#9e6af6299d8d3bd2bd40430832bd113df906c5ae" + integrity sha512-E8Ak/2+dZY6fnzlR7+ueWvhsH1SjHr4jjss4YS/h4py44jY9MhK/VFdaZJAWDz6BbL21KeteKxFSFpq8OS5gVA== + dependencies: + is-glob "^3.1.0" + path-dirname "^1.0.0" + +glob-parent@^5.1.2, glob-parent@~5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob-to-regexp@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz#8c5a1494d2066c570cc3bfe4496175acc4d502ab" + integrity sha512-Iozmtbqv0noj0uDDqoL0zNq0VBEfK2YFoMAZoxJe4cwphvLR+JskfF30QhXHOR4m3KrE6NLRYw+U9MRXvifyig== + +glob@7.1.2: + version "7.1.2" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.2.tgz#c19c9df9a028702d678612384a6552404c636d15" + integrity sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.0.4" + once "^1.3.0" + path-is-absolute "^1.0.0" + +glob@7.2.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023" + integrity sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.0.4" + once "^1.3.0" + path-is-absolute "^1.0.0" + +glob@^6.0.1: + version "6.0.4" + resolved "https://registry.yarnpkg.com/glob/-/glob-6.0.4.tgz#0f08860f6a155127b2fadd4f9ce24b1aab6e4d22" + integrity sha512-MKZeRNyYZAVVVG1oZeLaWie1uweH40m9AZwIwxyPbTSX4hHrVYSzLg0Ro5Z5R7XKkIX+Cc6oD1rqeDJnwsB8/A== + dependencies: + inflight "^1.0.4" + inherits "2" + minimatch "2 || 3" + once "^1.3.0" + path-is-absolute "^1.0.0" + +glob@^7.0.5, glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6: + version "7.2.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" + integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.1.1" + once "^1.3.0" + path-is-absolute "^1.0.0" + +global@~4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/global/-/global-4.4.0.tgz#3e7b105179006a323ed71aafca3e9c57a5cc6406" + integrity sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w== + dependencies: + min-document "^2.19.0" + process "^0.11.10" + +globals@^11.1.0: + version "11.12.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" + integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== + +globals@^13.6.0, globals@^13.9.0: + version "13.17.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.17.0.tgz#902eb1e680a41da93945adbdcb5a9f361ba69bd4" + integrity sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw== + dependencies: + type-fest "^0.20.2" + +globalthis@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/globalthis/-/globalthis-1.0.3.tgz#5852882a52b80dc301b0660273e1ed082f0b6ccf" + integrity sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA== + dependencies: + define-properties "^1.1.3" + +globby@^11.0.3: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + +golang-cover-parse@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/golang-cover-parse/-/golang-cover-parse-2.0.0.tgz#6bac2e5a88c1fb26468fa8d605aa52b4b8d12119" + integrity sha512-3AI0uT2motB7CQUInokoYqVVLeRpqTDaoXL5XS++v+UwCUNM0uIiEDy0L1UZe0VXbhhe8LUvcG3CtFXdzEebxA== + dependencies: + mocha "^5.2.0" + +got@12.1.0: + version "12.1.0" + resolved "https://registry.yarnpkg.com/got/-/got-12.1.0.tgz#099f3815305c682be4fd6b0ee0726d8e4c6b0af4" + integrity sha512-hBv2ty9QN2RdbJJMK3hesmSkFTjVIHyIDDbssCKnSmq62edGgImJWD10Eb1k77TiV1bxloxqcFAVK8+9pkhOig== + dependencies: + "@sindresorhus/is" "^4.6.0" + "@szmarczak/http-timer" "^5.0.1" + "@types/cacheable-request" "^6.0.2" + "@types/responselike" "^1.0.0" + cacheable-lookup "^6.0.4" + cacheable-request "^7.0.2" + decompress-response "^6.0.0" + form-data-encoder "1.7.1" + get-stream "^6.0.1" + http2-wrapper "^2.1.10" + lowercase-keys "^3.0.0" + p-cancelable "^3.0.0" + responselike "^2.0.0" + +got@9.6.0: + version "9.6.0" + resolved "https://registry.yarnpkg.com/got/-/got-9.6.0.tgz#edf45e7d67f99545705de1f7bbeeeb121765ed85" + integrity sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q== + dependencies: + "@sindresorhus/is" "^0.14.0" + "@szmarczak/http-timer" "^1.1.2" + cacheable-request "^6.0.0" + decompress-response "^3.3.0" + duplexer3 "^0.1.4" + get-stream "^4.1.0" + lowercase-keys "^1.0.1" + mimic-response "^1.0.1" + p-cancelable "^1.0.0" + to-readable-stream "^1.0.0" + url-parse-lax "^3.0.0" + +got@^7.1.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/got/-/got-7.1.0.tgz#05450fd84094e6bbea56f451a43a9c289166385a" + integrity sha512-Y5WMo7xKKq1muPsxD+KmrR8DH5auG7fBdDVueZwETwV6VytKyU9OX/ddpq2/1hp1vIPvVb4T81dKQz3BivkNLw== + dependencies: + decompress-response "^3.2.0" + duplexer3 "^0.1.4" + get-stream "^3.0.0" + is-plain-obj "^1.1.0" + is-retry-allowed "^1.0.0" + is-stream "^1.0.0" + isurl "^1.0.0-alpha5" + lowercase-keys "^1.0.0" + p-cancelable "^0.3.0" + p-timeout "^1.1.1" + safe-buffer "^5.0.1" + timed-out "^4.0.0" + url-parse-lax "^1.0.0" + url-to-options "^1.0.1" + +graceful-fs@^4.1.10, graceful-fs@^4.1.11, graceful-fs@^4.1.15, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.1.9, graceful-fs@^4.2.0, graceful-fs@^4.2.9: + version "4.2.10" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" + integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== + +graphql-request@^3.4.0: + version "3.7.0" + resolved "https://registry.yarnpkg.com/graphql-request/-/graphql-request-3.7.0.tgz#c7406e537084f8b9788541e3e6704340ca13055b" + integrity sha512-dw5PxHCgBneN2DDNqpWu8QkbbJ07oOziy8z+bK/TAXufsOLaETuVO4GkXrbs0WjhdKhBMN3BkpN/RIvUHkmNUQ== + dependencies: + cross-fetch "^3.0.6" + extract-files "^9.0.0" + form-data "^3.0.0" + +graphql-tag@^2.11.0, graphql-tag@^2.12.6: + version "2.12.6" + resolved "https://registry.yarnpkg.com/graphql-tag/-/graphql-tag-2.12.6.tgz#d441a569c1d2537ef10ca3d1633b48725329b5f1" + integrity sha512-FdSNcu2QQcWnM2VNvSCCDCVS5PpPqpzgFT8+GXzqJuoDd0CBncxCY278u4mhRO7tMgo2JjgJA5aZ+nWSQ/Z+xg== + dependencies: + tslib "^2.1.0" + +graphql@^15.3.0, graphql@^15.5.0: + version "15.8.0" + resolved "https://registry.yarnpkg.com/graphql/-/graphql-15.8.0.tgz#33410e96b012fa3bdb1091cc99a94769db212b38" + integrity sha512-5gghUc24tP9HRznNpV2+FIoq3xKkj5dTQqf4v0CpdPbFVwFkWoxOM+o+2OC9ZSvjEMTjfmG9QT+gcvggTwW1zw== + +growl@1.10.3: + version "1.10.3" + resolved "https://registry.yarnpkg.com/growl/-/growl-1.10.3.tgz#1926ba90cf3edfe2adb4927f5880bc22c66c790f" + integrity sha512-hKlsbA5Vu3xsh1Cg3J7jSmX/WaW6A5oBeqzM88oNbCRQFz+zUaXm6yxS4RVytp1scBoJzSYl4YAEOQIt6O8V1Q== + +growl@1.10.5: + version "1.10.5" + resolved "https://registry.yarnpkg.com/growl/-/growl-1.10.5.tgz#f2735dc2283674fa67478b10181059355c369e5e" + integrity sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA== + +har-schema@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" + integrity sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q== + +har-validator@~5.1.3: + version "5.1.5" + resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-5.1.5.tgz#1f0803b9f8cb20c0fa13822df1ecddb36bde1efd" + integrity sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w== + dependencies: + ajv "^6.12.3" + har-schema "^2.0.0" + +hardhat-tracer@^1.0.0-alpha.5: + version "1.0.0-alpha.6" + resolved "https://registry.yarnpkg.com/hardhat-tracer/-/hardhat-tracer-1.0.0-alpha.6.tgz#4545a772930567cad4620ee9448cb76e89b07b02" + integrity sha512-QXKEJPaCDU0P7ZNHvFuGQoKLZ9+uma3ASAoPjhHr4CYwgIHcronVPZ7zkztRc7LhDbKFffIuoh0jEQWGgR6Neg== + dependencies: + ethers "^5.0.24" + +hardhat-watcher@^2.1.1: + version "2.3.0" + resolved "https://registry.yarnpkg.com/hardhat-watcher/-/hardhat-watcher-2.3.0.tgz#57586a7fb79b73365014794f7e3dc0706aa65b7d" + integrity sha512-u76a/1pxPyW9DRZ7FZ8HoSQ4AuKOiSDQTR2NyiZlH5f0Ux+qQfahsh9CNusRLhx2s1OWzlkwCVvrdHq5FTGUzw== + dependencies: + chokidar "^3.5.3" + +hardhat@^2.0.0, hardhat@^2.9.6: + version "2.10.1" + resolved "https://registry.yarnpkg.com/hardhat/-/hardhat-2.10.1.tgz#37fdc0c96d6a5d16b322269db2ad8f9f115c4046" + integrity sha512-0FN9TyCtn7Lt25SB2ei2G7nA2rZjP+RN6MvFOm+zYwherxLZNo6RbD8nDz88eCbhRapevmXqOiL2nM8INKsjmA== + dependencies: + "@ethereumjs/block" "^3.6.2" + "@ethereumjs/blockchain" "^5.5.2" + "@ethereumjs/common" "^2.6.4" + "@ethereumjs/tx" "^3.5.1" + "@ethereumjs/vm" "^5.9.0" + "@ethersproject/abi" "^5.1.2" + "@metamask/eth-sig-util" "^4.0.0" + "@sentry/node" "^5.18.1" + "@solidity-parser/parser" "^0.14.2" + "@types/bn.js" "^5.1.0" + "@types/lru-cache" "^5.1.0" + abort-controller "^3.0.0" + adm-zip "^0.4.16" + aggregate-error "^3.0.0" + ansi-escapes "^4.3.0" + chalk "^2.4.2" + chokidar "^3.4.0" + ci-info "^2.0.0" + debug "^4.1.1" + enquirer "^2.3.0" + env-paths "^2.2.0" + ethereum-cryptography "^1.0.3" + ethereumjs-abi "^0.6.8" + ethereumjs-util "^7.1.4" + find-up "^2.1.0" + fp-ts "1.19.3" + fs-extra "^7.0.1" + glob "7.2.0" + immutable "^4.0.0-rc.12" + io-ts "1.10.4" + lodash "^4.17.11" + merkle-patricia-tree "^4.2.4" + mnemonist "^0.38.0" + mocha "^10.0.0" + p-map "^4.0.0" + qs "^6.7.0" + raw-body "^2.4.1" + resolve "1.17.0" + semver "^6.3.0" + slash "^3.0.0" + solc "0.7.3" + source-map-support "^0.5.13" + stacktrace-parser "^0.1.10" + "true-case-path" "^2.2.1" + tsort "0.0.1" + undici "^5.4.0" + uuid "^8.3.2" + ws "^7.4.6" + +has-bigints@^1.0.1, has-bigints@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.2.tgz#0871bd3e3d51626f6ca0966668ba35d5602d6eaa" + integrity sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ== + +has-flag@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-2.0.0.tgz#e8207af1cc7b30d446cc70b734b5e8be18f88d51" + integrity sha512-P+1n3MnwjR/Epg9BBo1KT8qbye2g2Ou4sFumihwt6I4tsUX7jnLcX4BTOSKg/B1ZrIYMN9FcEnG4x5a7NB8Eng== + +has-flag@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" + integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +has-property-descriptors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" + integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== + dependencies: + get-intrinsic "^1.1.1" + +has-symbol-support-x@^1.4.1: + version "1.4.2" + resolved "https://registry.yarnpkg.com/has-symbol-support-x/-/has-symbol-support-x-1.4.2.tgz#1409f98bc00247da45da67cee0a36f282ff26455" + integrity sha512-3ToOva++HaW+eCpgqZrCfN51IPB+7bJNVT6CUATzueB5Heb8o6Nam0V3HG5dlDvZU1Gn5QLcbahiKw/XVk5JJw== + +has-symbols@^1.0.1, has-symbols@^1.0.2, has-symbols@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== + +has-to-string-tag-x@^1.2.0: + version "1.4.1" + resolved "https://registry.yarnpkg.com/has-to-string-tag-x/-/has-to-string-tag-x-1.4.1.tgz#a045ab383d7b4b2012a00148ab0aa5f290044d4d" + integrity sha512-vdbKfmw+3LoOYVr+mtxHaX5a96+0f3DljYd8JOqvOLsf5mw2Otda2qCDT9qRqLAhrjyQ0h7ual5nOiASpsGNFw== + dependencies: + has-symbol-support-x "^1.4.1" + +has-tostringtag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz#7e133818a7d394734f941e73c3d3f9291e658b25" + integrity sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ== + dependencies: + has-symbols "^1.0.2" + +has-value@^0.3.1: + version "0.3.1" + resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f" + integrity sha512-gpG936j8/MzaeID5Yif+577c17TxaDmhuyVgSwtnL/q8UUTySg8Mecb+8Cf1otgLoD7DDH75axp86ER7LFsf3Q== + dependencies: + get-value "^2.0.3" + has-values "^0.1.4" + isobject "^2.0.0" + +has-value@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz#18b281da585b1c5c51def24c930ed29a0be6b177" + integrity sha512-IBXk4GTsLYdQ7Rvt+GRBrFSVEkmuOUy4re0Xjd9kJSUQpnTrWR4/y9RpfexN9vkAPMFuQoeWKwqzPozRTlasGw== + dependencies: + get-value "^2.0.6" + has-values "^1.0.0" + isobject "^3.0.0" + +has-values@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz#6d61de95d91dfca9b9a02089ad384bff8f62b771" + integrity sha512-J8S0cEdWuQbqD9//tlZxiMuMNmxB8PlEwvYwuxsTmR1G5RXUePEX/SJn7aD0GMLieuZYSwNH0cQuJGwnYunXRQ== + +has-values@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz#95b0b63fec2146619a6fe57fe75628d5a39efe4f" + integrity sha512-ODYZC64uqzmtfGMEAX/FvZiRyWLpAC3vYnNunURUnkGVTS+mI0smVsWaPydRBsE3g+ok7h960jChO8mFcWlHaQ== + dependencies: + is-number "^3.0.0" + kind-of "^4.0.0" + +has@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" + integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== + dependencies: + function-bind "^1.1.1" + +hash-base@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.1.0.tgz#55c381d9e06e1d2997a883b4a3fddfe7f0d3af33" + integrity sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA== + dependencies: + inherits "^2.0.4" + readable-stream "^3.6.0" + safe-buffer "^5.2.0" + +hash.js@1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.3.tgz#340dedbe6290187151c1ea1d777a3448935df846" + integrity sha512-/UETyP0W22QILqS+6HowevwhEFJ3MBJnwTf75Qob9Wz9t0DPuisL8kW8YZMK62dHAKE1c1p+gY1TtOLY+USEHA== + dependencies: + inherits "^2.0.3" + minimalistic-assert "^1.0.0" + +hash.js@1.1.7, hash.js@^1.0.0, hash.js@^1.0.3, hash.js@^1.1.7: + version "1.1.7" + resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.7.tgz#0babca538e8d4ee4a0f8988d68866537a003cf42" + integrity sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA== + dependencies: + inherits "^2.0.3" + minimalistic-assert "^1.0.1" + +hdkey@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/hdkey/-/hdkey-1.1.2.tgz#c60f9cf6f90fbf24a8a52ea06893f36a0108cd3e" + integrity sha512-PTQ4VKu0oRnCrYfLp04iQZ7T2Cxz0UsEXYauk2j8eh6PJXCpbXuCFhOmtIFtbET0i3PMWmHN9J11gU8LEgUljQ== + dependencies: + bs58check "^2.1.2" + safe-buffer "^5.1.1" + secp256k1 "^3.0.1" + +he@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/he/-/he-1.1.1.tgz#93410fd21b009735151f8868c2f271f3427e23fd" + integrity sha512-z/GDPjlRMNOa2XJiB4em8wJpuuBfrFOlYKTZxtpkdr1uPdibHI8rYA3MY0KDObpVyaes0e/aunid/t88ZI2EKA== + +he@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" + integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== + +header-case@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/header-case/-/header-case-1.0.1.tgz#9535973197c144b09613cd65d317ef19963bd02d" + integrity sha512-i0q9mkOeSuhXw6bGgiQCCBgY/jlZuV/7dZXyZ9c6LcBrqwvT8eT719E9uxE5LiZftdl+z81Ugbg/VvXV4OJOeQ== + dependencies: + no-case "^2.2.0" + upper-case "^1.1.3" + +hexoid@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/hexoid/-/hexoid-1.0.0.tgz#ad10c6573fb907de23d9ec63a711267d9dc9bc18" + integrity sha512-QFLV0taWQOZtvIRIAdBChesmogZrtuXvVWsFHZTk2SU+anspqZ2vMnoLg7IE1+Uk16N19APic1BuF8bC8c2m5g== + +hmac-drbg@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" + integrity sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg== + dependencies: + hash.js "^1.0.3" + minimalistic-assert "^1.0.0" + minimalistic-crypto-utils "^1.0.1" + +hosted-git-info@^2.6.0: + version "2.8.9" + resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz#dffc0bf9a21c02209090f2aa69429e1414daf3f9" + integrity sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw== + +html-encoding-sniffer@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz#42a6dc4fd33f00281176e8b23759ca4e4fa185f3" + integrity sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ== + dependencies: + whatwg-encoding "^1.0.5" + +html-escaper@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" + integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== + +htmlparser2@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-8.0.1.tgz#abaa985474fcefe269bc761a779b544d7196d010" + integrity sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA== + dependencies: + domelementtype "^2.3.0" + domhandler "^5.0.2" + domutils "^3.0.1" + entities "^4.3.0" + +http-cache-semantics@^4.0.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" + integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== + +http-errors@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" + integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== + dependencies: + depd "2.0.0" + inherits "2.0.4" + setprototypeof "1.2.0" + statuses "2.0.1" + toidentifier "1.0.1" + +http-errors@^1.7.2: + version "1.8.1" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.8.1.tgz#7c3f28577cbc8a207388455dbd62295ed07bd68c" + integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g== + dependencies: + depd "~1.1.2" + inherits "2.0.4" + setprototypeof "1.2.0" + statuses ">= 1.5.0 < 2" + toidentifier "1.0.1" + +http-https@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/http-https/-/http-https-1.0.0.tgz#2f908dd5f1db4068c058cd6e6d4ce392c913389b" + integrity sha512-o0PWwVCSp3O0wS6FvNr6xfBCHgt0m1tvPLFOCc2iFDKTRAXhB7m8klDf7ErowFH8POa6dVdGatKU5I1YYwzUyg== + +http-parser-js@>=0.5.1: + version "0.5.8" + resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.8.tgz#af23090d9ac4e24573de6f6aecc9d84a48bf20e3" + integrity sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q== + +http-proxy-agent@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz#8a8c8ef7f5932ccf953c296ca8291b95aa74aa3a" + integrity sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg== + dependencies: + "@tootallnate/once" "1" + agent-base "6" + debug "4" + +http-signature@~1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1" + integrity sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ== + dependencies: + assert-plus "^1.0.0" + jsprim "^1.2.2" + sshpk "^1.7.0" + +http-status-codes@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/http-status-codes/-/http-status-codes-2.2.0.tgz#bb2efe63d941dfc2be18e15f703da525169622be" + integrity sha512-feERVo9iWxvnejp3SEfm/+oNG517npqL2/PIA8ORjyOZjGC7TwCRQsZylciLS64i6pJ0wRYz3rkXLRwbtFa8Ng== + +http2-wrapper@^2.1.10: + version "2.1.11" + resolved "https://registry.yarnpkg.com/http2-wrapper/-/http2-wrapper-2.1.11.tgz#d7c980c7ffb85be3859b6a96c800b2951ae257ef" + integrity sha512-aNAk5JzLturWEUiuhAN73Jcbq96R7rTitAoXV54FYMatvihnpD2+6PUgU4ce3D/m5VDbw+F5CsyKSF176ptitQ== + dependencies: + quick-lru "^5.1.1" + resolve-alpn "^1.2.0" + +https-proxy-agent@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" + integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== + dependencies: + agent-base "6" + debug "4" + +human-signals@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" + integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== + +iconv-lite@0.4.24, iconv-lite@^0.4.24: + version "0.4.24" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" + integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== + dependencies: + safer-buffer ">= 2.1.2 < 3" + +idb@3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/idb/-/idb-3.0.2.tgz#c8e9122d5ddd40f13b60ae665e4862f8b13fa384" + integrity sha512-+FLa/0sTXqyux0o6C+i2lOR0VoS60LU/jzUo5xjfY6+7sEEgy4Gz1O7yFBXvjd7N0NyIGWIRg8DcQSLEG+VSPw== + +idna-uts46-hx@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/idna-uts46-hx/-/idna-uts46-hx-2.3.1.tgz#a1dc5c4df37eee522bf66d969cc980e00e8711f9" + integrity sha512-PWoF9Keq6laYdIRwwCdhTPl60xRqAloYNMQLiyUnG42VjT53oW07BXIRM+NK7eQjzXjAk2gUvX9caRxlnF9TAA== + dependencies: + punycode "2.1.0" + +ieee754@^1.1.13, ieee754@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" + integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== + +ignore-by-default@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/ignore-by-default/-/ignore-by-default-1.0.1.tgz#48ca6d72f6c6a3af00a9ad4ae6876be3889e2b09" + integrity sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA== + +ignore@^4.0.6: + version "4.0.6" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" + integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== + +ignore@^5.1.1, ignore@^5.1.8, ignore@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.0.tgz#6d3bac8fa7fe0d45d9f9be7bac2fc279577e345a" + integrity sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ== + +immediate@3.3.0, immediate@^3.2.3: + version "3.3.0" + resolved "https://registry.yarnpkg.com/immediate/-/immediate-3.3.0.tgz#1aef225517836bcdf7f2a2de2600c79ff0269266" + integrity sha512-HR7EVodfFUdQCTIeySw+WDRFJlPcLOJbXfwwZ7Oom6tjsvZ3bOkCDJHehQC3nxJrv7+f9XecwazynjU8e4Vw3Q== + +immediate@~3.2.3: + version "3.2.3" + resolved "https://registry.yarnpkg.com/immediate/-/immediate-3.2.3.tgz#d140fa8f614659bd6541233097ddaac25cdd991c" + integrity sha512-RrGCXRm/fRVqMIhqXrGEX9rRADavPiDFSoMb/k64i9XMk8uH4r/Omi5Ctierj6XzNecwDbO4WuFbDD1zmpl3Tg== + +immutable@^4.0.0, immutable@^4.0.0-rc.12: + version "4.1.0" + resolved "https://registry.yarnpkg.com/immutable/-/immutable-4.1.0.tgz#f795787f0db780183307b9eb2091fcac1f6fafef" + integrity sha512-oNkuqVTA8jqG1Q6c+UglTOD1xhC1BtjKI7XkCXRkZHrN5m18/XsnUp8Q89GkQO/z+0WjonSvl0FLhDYftp46nQ== + +import-fresh@^3.0.0, import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + +import-local@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/import-local/-/import-local-3.1.0.tgz#b4479df8a5fd44f6cdce24070675676063c95cb4" + integrity sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg== + dependencies: + pkg-dir "^4.2.0" + resolve-cwd "^3.0.0" + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== + +indent-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" + integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.1, inherits@~2.0.3: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +inquirer@^6.4.1: + version "6.5.2" + resolved "https://registry.yarnpkg.com/inquirer/-/inquirer-6.5.2.tgz#ad50942375d036d327ff528c08bd5fab089928ca" + integrity sha512-cntlB5ghuB0iuO65Ovoi8ogLHiWGs/5yNrtUcKjFhSSiVeAIVpD7koaSU9RM8mpXw5YDi9RdYXGQMaOURB7ycQ== + dependencies: + ansi-escapes "^3.2.0" + chalk "^2.4.2" + cli-cursor "^2.1.0" + cli-width "^2.0.0" + external-editor "^3.0.3" + figures "^2.0.0" + lodash "^4.17.12" + mute-stream "0.0.7" + run-async "^2.2.0" + rxjs "^6.4.0" + string-width "^2.1.0" + strip-ansi "^5.1.0" + through "^2.3.6" + +internal-slot@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.3.tgz#7347e307deeea2faac2ac6205d4bc7d34967f59c" + integrity sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA== + dependencies: + get-intrinsic "^1.1.0" + has "^1.0.3" + side-channel "^1.0.4" + +invert-kv@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/invert-kv/-/invert-kv-2.0.0.tgz#7393f5afa59ec9ff5f67a27620d11c226e3eec02" + integrity sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA== + +io-ts@1.10.4: + version "1.10.4" + resolved "https://registry.yarnpkg.com/io-ts/-/io-ts-1.10.4.tgz#cd5401b138de88e4f920adbcb7026e2d1967e6e2" + integrity sha512-b23PteSnYXSONJ6JQXRAlvJhuw8KOtkqa87W4wDtvMrud/DTJd5X+NpOOI+O/zZwVq6v0VLAaJ+1EDViKEuN9g== + dependencies: + fp-ts "^1.0.0" + +ip6@^0.2.0: + version "0.2.10" + resolved "https://registry.yarnpkg.com/ip6/-/ip6-0.2.10.tgz#19c07f70b68e1f3b40685d69c8cec0ea9e4ec0fd" + integrity sha512-1LdpyKjhvepd6EbAU6rW4g14vuYtx5TnJX9TfZZBhsM6DsyPQLNzW12rtbUqXBMwqFrLVV/Gcxv0GNFvJp2cYA== + +ip@^1.1.8: + version "1.1.8" + resolved "https://registry.yarnpkg.com/ip/-/ip-1.1.8.tgz#ae05948f6b075435ed3307acce04629da8cdbf48" + integrity sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg== + +ipaddr.js@1.9.1, ipaddr.js@^1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +is-accessor-descriptor@^0.1.6: + version "0.1.6" + resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz#a9e12cb3ae8d876727eeef3843f8a0897b5c98d6" + integrity sha512-e1BM1qnDbMRG3ll2U9dSK0UMHuWOs3pY3AtcFsmvwPtKL3MML/Q86i+GilLfvqEs4GW+ExB91tQ3Ig9noDIZ+A== + dependencies: + kind-of "^3.0.2" + +is-accessor-descriptor@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz#169c2f6d3df1f992618072365c9b0ea1f6878656" + integrity sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ== + dependencies: + kind-of "^6.0.0" + +is-arguments@^1.0.4: + version "1.1.1" + resolved "https://registry.yarnpkg.com/is-arguments/-/is-arguments-1.1.1.tgz#15b3f88fda01f2a97fec84ca761a560f123efa9b" + integrity sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + +is-arrayish@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" + integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== + +is-arrayish@^0.3.1: + version "0.3.2" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.3.2.tgz#4574a2ae56f7ab206896fb431eaeed066fdf8f03" + integrity sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ== + +is-bigint@^1.0.1: + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-bigint/-/is-bigint-1.0.4.tgz#08147a1875bc2b32005d41ccd8291dffc6691df3" + integrity sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg== + dependencies: + has-bigints "^1.0.1" + +is-binary-path@~2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" + integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== + dependencies: + binary-extensions "^2.0.0" + +is-boolean-object@^1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.2.tgz#5c6dc200246dd9321ae4b885a114bb1f75f63719" + integrity sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + +is-buffer@^1.1.5: + version "1.1.6" + resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" + integrity sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w== + +is-buffer@^2.0.2, is-buffer@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-2.0.5.tgz#ebc252e400d22ff8d77fa09888821a24a658c191" + integrity sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ== + +is-callable@^1.1.3, is-callable@^1.1.4, is-callable@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.4.tgz#47301d58dd0259407865547853df6d61fe471945" + integrity sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w== + +is-core-module@^2.8.1, is-core-module@^2.9.0: + version "2.10.0" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.10.0.tgz#9012ede0a91c69587e647514e1d5277019e728ed" + integrity sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg== + dependencies: + has "^1.0.3" + +is-data-descriptor@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56" + integrity sha512-+w9D5ulSoBNlmw9OHn3U2v51SyoCd0he+bB3xMl62oijhrspxowjU+AIcDY0N3iEJbUEkB15IlMASQsxYigvXg== + dependencies: + kind-of "^3.0.2" + +is-data-descriptor@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz#d84876321d0e7add03990406abbbbd36ba9268c7" + integrity sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ== + dependencies: + kind-of "^6.0.0" + +is-date-object@^1.0.1: + version "1.0.5" + resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.5.tgz#0841d5536e724c25597bf6ea62e1bd38298df31f" + integrity sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ== + dependencies: + has-tostringtag "^1.0.0" + +is-descriptor@^0.1.0: + version "0.1.6" + resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz#366d8240dde487ca51823b1ab9f07a10a78251ca" + integrity sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg== + dependencies: + is-accessor-descriptor "^0.1.6" + is-data-descriptor "^0.1.4" + kind-of "^5.0.0" + +is-descriptor@^1.0.0, is-descriptor@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz#3b159746a66604b04f8c81524ba365c5f14d86ec" + integrity sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg== + dependencies: + is-accessor-descriptor "^1.0.0" + is-data-descriptor "^1.0.0" + kind-of "^6.0.2" + +is-extendable@^0.1.0, is-extendable@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" + integrity sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw== + +is-extendable@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz#a7470f9e426733d81bd81e1155264e3a3507cab4" + integrity sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA== + dependencies: + is-plain-object "^2.0.4" + +is-extglob@^2.1.0, is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + +is-fullwidth-code-point@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" + integrity sha512-1pqUqRjkhPJ9miNq9SwMfdvi6lBJcd6eFxvfaivQhaH3SgisfiuudvFntdKOmxuee/77l+FPjKrQjWvmPjWrRw== + dependencies: + number-is-nan "^1.0.0" + +is-fullwidth-code-point@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" + integrity sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w== + +is-fullwidth-code-point@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" + integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== + +is-function@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-function/-/is-function-1.0.2.tgz#4f097f30abf6efadac9833b17ca5dc03f8144e08" + integrity sha512-lw7DUp0aWXYg+CBCN+JKkcE0Q2RayZnSvnZBlwgxHBQhqt5pZNVy4Ri7H9GmmXkdu7LUthszM+Tor1u/2iBcpQ== + +is-generator-fn@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-generator-fn/-/is-generator-fn-2.1.0.tgz#7d140adc389aaf3011a8f2a2a4cfa6faadffb118" + integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== + +is-generator-function@^1.0.7: + version "1.0.10" + resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.10.tgz#f1558baf1ac17e0deea7c0415c438351ff2b3c72" + integrity sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A== + dependencies: + has-tostringtag "^1.0.0" + +is-glob@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-3.1.0.tgz#7ba5ae24217804ac70707b96922567486cc3e84a" + integrity sha512-UFpDDrPgM6qpnFNI+rh/p3bUaq9hKLZN8bMUWzxmcnZVS3omf4IPK+BrewlnWjO1WmUsMYuSjKh4UJuV4+Lqmw== + dependencies: + is-extglob "^2.1.0" + +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + +is-hex-prefixed@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz#7d8d37e6ad77e5d127148913c573e082d777f554" + integrity sha512-WvtOiug1VFrE9v1Cydwm+FnXd3+w9GaeVUss5W4v/SLy3UW00vP+6iNF2SdnfiBoLy4bTqVdkftNGTUeOFVsbA== + +is-lower-case@^1.1.0: + version "1.1.3" + resolved "https://registry.yarnpkg.com/is-lower-case/-/is-lower-case-1.1.3.tgz#7e147be4768dc466db3bfb21cc60b31e6ad69393" + integrity sha512-+5A1e/WJpLLXZEDlgz4G//WYSHyQBD32qa4Jd3Lw06qQlv3fJHnp3YIHjTQSGzHMgzmVKz2ZP3rBxTHkPw/lxA== + dependencies: + lower-case "^1.1.0" + +is-natural-number@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/is-natural-number/-/is-natural-number-4.0.1.tgz#ab9d76e1db4ced51e35de0c72ebecf09f734cde8" + integrity sha512-Y4LTamMe0DDQIIAlaer9eKebAlDSV6huy+TWhJVPlzZh2o4tRP5SQWFlLn5N0To4mDD22/qdOq+veo1cSISLgQ== + +is-negative-zero@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" + integrity sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA== + +is-number-object@^1.0.4: + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.7.tgz#59d50ada4c45251784e9904f5246c742f07a42fc" + integrity sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ== + dependencies: + has-tostringtag "^1.0.0" + +is-number@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" + integrity sha512-4cboCqIpliH+mAvFNegjZQ4kgKc3ZUhQVr3HvWbSh5q3WH2v82ct+T2Y1hdU5Gdtorx/cLifQjqCbL7bpznLTg== + dependencies: + kind-of "^3.0.2" + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-obj@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f" + integrity sha512-l4RyHgRqGN4Y3+9JHVrNqO+tN0rV5My76uW5/nuO4K1b6vw5G8d/cmFjP9tRfEsdhZNt0IFdZuK/c2Vr4Nb+Qg== + +is-obj@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" + integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== + +is-object@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-object/-/is-object-1.0.2.tgz#a56552e1c665c9e950b4a025461da87e72f86fcf" + integrity sha512-2rRIahhZr2UWb45fIOuvZGpFtz0TyOZLf32KxBbSoUCeZR495zCKlWUKKUByk3geS2eAs7ZAABt0Y/Rx0GiQGA== + +is-plain-obj@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e" + integrity sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg== + +is-plain-obj@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-2.1.0.tgz#45e42e37fccf1f40da8e5f76ee21515840c09287" + integrity sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA== + +is-plain-object@^2.0.3, is-plain-object@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" + integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== + dependencies: + isobject "^3.0.1" + +is-potential-custom-element-name@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5" + integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ== + +is-regex@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" + integrity sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + +is-retry-allowed@^1.0.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz#d778488bd0a4666a3be8a1482b9f2baafedea8b4" + integrity sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg== + +is-shared-array-buffer@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz#8f259c573b60b6a32d4058a1a07430c0a7344c79" + integrity sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA== + dependencies: + call-bind "^1.0.2" + +is-stream@^1.0.0, is-stream@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" + integrity sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ== + +is-stream@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" + integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== + +is-string@^1.0.5, is-string@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" + integrity sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg== + dependencies: + has-tostringtag "^1.0.0" + +is-symbol@^1.0.2, is-symbol@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.4.tgz#a6dac93b635b063ca6872236de88910a57af139c" + integrity sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg== + dependencies: + has-symbols "^1.0.2" + +is-typed-array@^1.1.3, is-typed-array@^1.1.9: + version "1.1.9" + resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.9.tgz#246d77d2871e7d9f5aeb1d54b9f52c71329ece67" + integrity sha512-kfrlnTTn8pZkfpJMUgYD7YZ3qzeJgWUn8XfVYBARc4wnmNOmLbmuuaAs3q5fvB0UJOn6yHAKaGTPM7d6ezoD/A== + dependencies: + available-typed-arrays "^1.0.5" + call-bind "^1.0.2" + es-abstract "^1.20.0" + for-each "^0.3.3" + has-tostringtag "^1.0.0" + +is-typedarray@^1.0.0, is-typedarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" + integrity sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA== + +is-unicode-supported@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" + integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== + +is-upper-case@^1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/is-upper-case/-/is-upper-case-1.1.2.tgz#8d0b1fa7e7933a1e58483600ec7d9661cbaf756f" + integrity sha512-GQYSJMgfeAmVwh9ixyk888l7OIhNAGKtY6QA+IrWlu9MDTCaXmeozOZ2S9Knj7bQwBO/H6J2kb+pbyTUiMNbsw== + dependencies: + upper-case "^1.1.0" + +is-url@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/is-url/-/is-url-1.2.4.tgz#04a4df46d28c4cff3d73d01ff06abeb318a1aa52" + integrity sha512-ITvGim8FhRiYe4IQ5uHSkj7pVaPDrCTkNd3yq3cV7iZAcJdHTUMPMEHcqSOy9xZ9qFenQCvi+2wjH9a1nXqHww== + +is-weakref@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" + integrity sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ== + dependencies: + call-bind "^1.0.2" + +is-windows@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz#d1850eb9791ecd18e6182ce12a30f396634bb19d" + integrity sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA== + +isarray@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" + integrity sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ== + +isarray@1.0.0, isarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" + integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== + +isnumber@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isnumber/-/isnumber-1.0.0.tgz#0e3f9759b581d99dd85086f0ec2a74909cfadd01" + integrity sha512-JLiSz/zsZcGFXPrB4I/AGBvtStkt+8QmksyZBZnVXnnK9XdTEyz0tX8CRYljtwYDuIuZzih6DpHQdi+3Q6zHPw== + +isobject@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" + integrity sha512-+OUdGJlgjOBZDfxnDjYYG6zp487z0JGNQq3cYQYg5f5hKR+syHMsaztzGeml/4kGG55CSpKSpWTY+jYGgsHLgA== + dependencies: + isarray "1.0.0" + +isobject@^3.0.0, isobject@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" + integrity sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg== + +isomorphic-unfetch@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/isomorphic-unfetch/-/isomorphic-unfetch-3.1.0.tgz#87341d5f4f7b63843d468438128cb087b7c3e98f" + integrity sha512-geDJjpoZ8N0kWexiwkX8F9NkTsXhetLPVbZFQ+JTW239QNOwvB0gniuR1Wc6f0AMTn7/mFGyXvHTifrCp/GH8Q== + dependencies: + node-fetch "^2.6.1" + unfetch "^4.2.0" + +isomorphic-ws@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/isomorphic-ws/-/isomorphic-ws-4.0.1.tgz#55fd4cd6c5e6491e76dc125938dd863f5cd4f2dc" + integrity sha512-BhBvN2MBpWTaSHdWRb/bwdZJ1WaehQ2L1KngkCkfLUGF0mAWAT1sQUQacEmQ0jXkFw/czDXPNQSL5u2/Krsz1w== + +isstream@~0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" + integrity sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g== + +istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz#189e7909d0a39fa5a3dfad5b03f71947770191d3" + integrity sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw== + +istanbul-lib-instrument@^5.0.4, istanbul-lib-instrument@^5.1.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.0.tgz#31d18bdd127f825dd02ea7bfdfd906f8ab840e9f" + integrity sha512-6Lthe1hqXHBNsqvgDzGO6l03XNeu3CrG4RqQ1KM9+l5+jNGpEJfIELx1NS3SEHmJQA8np/u+E4EPRKRiu6m19A== + dependencies: + "@babel/core" "^7.12.3" + "@babel/parser" "^7.14.7" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-coverage "^3.2.0" + semver "^6.3.0" + +istanbul-lib-report@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#7518fe52ea44de372f460a76b5ecda9ffb73d8a6" + integrity sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw== + dependencies: + istanbul-lib-coverage "^3.0.0" + make-dir "^3.0.0" + supports-color "^7.1.0" + +istanbul-lib-source-maps@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz#895f3a709fcfba34c6de5a42939022f3e4358551" + integrity sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw== + dependencies: + debug "^4.1.1" + istanbul-lib-coverage "^3.0.0" + source-map "^0.6.1" + +istanbul-reports@^3.1.3: + version "3.1.5" + resolved "https://registry.yarnpkg.com/istanbul-reports/-/istanbul-reports-3.1.5.tgz#cc9a6ab25cb25659810e4785ed9d9fb742578bae" + integrity sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w== + dependencies: + html-escaper "^2.0.0" + istanbul-lib-report "^3.0.0" + +isurl@^1.0.0-alpha5: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isurl/-/isurl-1.0.0.tgz#b27f4f49f3cdaa3ea44a0a5b7f3462e6edc39d67" + integrity sha512-1P/yWsxPlDtn7QeRD+ULKQPaIaN6yF368GZ2vDfv0AL0NwpStafjWCDDdn0k8wgFMWpVAqG7oJhxHnlud42i9w== + dependencies: + has-to-string-tag-x "^1.2.0" + is-object "^1.0.1" + +jacoco-parse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/jacoco-parse/-/jacoco-parse-2.0.1.tgz#a1fab49df2c8a11fd9204b615677bc58ab784b65" + integrity sha512-YGhIb2iXuQ4/zNh2zgHd6Z6dqlYwLYH1wfsxtTNQ+jnHH9PhhuMwqOFihXymSI41trxok48LdKkSeDIWs28tYg== + dependencies: + mocha "^5.2.0" + xml2js "^0.4.9" + +javascript-natural-sort@^0.7.1: + version "0.7.1" + resolved "https://registry.yarnpkg.com/javascript-natural-sort/-/javascript-natural-sort-0.7.1.tgz#f9e2303d4507f6d74355a73664d1440fb5a0ef59" + integrity sha512-nO6jcEfZWQXDhOiBtG2KvKyEptz7RVbpGP4vTD2hLBdmNQSsCiicO2Ioinv6UI4y9ukqnBpy+XZ9H6uLNgJTlw== + +jayson@^3.4.4: + version "3.6.6" + resolved "https://registry.yarnpkg.com/jayson/-/jayson-3.6.6.tgz#189984f624e398f831bd2be8e8c80eb3abf764a1" + integrity sha512-f71uvrAWTtrwoww6MKcl9phQTC+56AopLyEenWvKVAIMz+q0oVGj6tenLZ7Z6UiPBkJtKLj4kt0tACllFQruGQ== + dependencies: + "@types/connect" "^3.4.33" + "@types/express-serve-static-core" "^4.17.9" + "@types/lodash" "^4.14.159" + "@types/node" "^12.12.54" + "@types/ws" "^7.4.4" + JSONStream "^1.3.5" + commander "^2.20.3" + delay "^5.0.0" + es6-promisify "^5.0.0" + eyes "^0.1.8" + isomorphic-ws "^4.0.1" + json-stringify-safe "^5.0.1" + lodash "^4.17.20" + uuid "^8.3.2" + ws "^7.4.5" + +jest-changed-files@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-27.5.1.tgz#a348aed00ec9bf671cc58a66fcbe7c3dfd6a68f5" + integrity sha512-buBLMiByfWGCoMsLLzGUUSpAmIAGnbR2KJoMN10ziLhOLvP4e0SlypHnAel8iqQXTrcbmfEY9sSqae5sgUsTvw== + dependencies: + "@jest/types" "^27.5.1" + execa "^5.0.0" + throat "^6.0.1" + +jest-circus@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-circus/-/jest-circus-27.5.1.tgz#37a5a4459b7bf4406e53d637b49d22c65d125ecc" + integrity sha512-D95R7x5UtlMA5iBYsOHFFbMD/GVA4R/Kdq15f7xYWUfWHBto9NYRsOvnSauTgdF+ogCpJ4tyKOXhUifxS65gdw== + dependencies: + "@jest/environment" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + dedent "^0.7.0" + expect "^27.5.1" + is-generator-fn "^2.0.0" + jest-each "^27.5.1" + jest-matcher-utils "^27.5.1" + jest-message-util "^27.5.1" + jest-runtime "^27.5.1" + jest-snapshot "^27.5.1" + jest-util "^27.5.1" + pretty-format "^27.5.1" + slash "^3.0.0" + stack-utils "^2.0.3" + throat "^6.0.1" + +jest-cli@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-27.5.1.tgz#278794a6e6458ea8029547e6c6cbf673bd30b145" + integrity sha512-Hc6HOOwYq4/74/c62dEE3r5elx8wjYqxY0r0G/nFrLDPMFRu6RA/u8qINOIkvhxG7mMQ5EJsOGfRpI8L6eFUVw== + dependencies: + "@jest/core" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/types" "^27.5.1" + chalk "^4.0.0" + exit "^0.1.2" + graceful-fs "^4.2.9" + import-local "^3.0.2" + jest-config "^27.5.1" + jest-util "^27.5.1" + jest-validate "^27.5.1" + prompts "^2.0.1" + yargs "^16.2.0" + +jest-config@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-config/-/jest-config-27.5.1.tgz#5c387de33dca3f99ad6357ddeccd91bf3a0e4a41" + integrity sha512-5sAsjm6tGdsVbW9ahcChPAFCk4IlkQUknH5AvKjuLTSlcO/wCZKyFdn7Rg0EkC+OGgWODEy2hDpWB1PgzH0JNA== + dependencies: + "@babel/core" "^7.8.0" + "@jest/test-sequencer" "^27.5.1" + "@jest/types" "^27.5.1" + babel-jest "^27.5.1" + chalk "^4.0.0" + ci-info "^3.2.0" + deepmerge "^4.2.2" + glob "^7.1.1" + graceful-fs "^4.2.9" + jest-circus "^27.5.1" + jest-environment-jsdom "^27.5.1" + jest-environment-node "^27.5.1" + jest-get-type "^27.5.1" + jest-jasmine2 "^27.5.1" + jest-regex-util "^27.5.1" + jest-resolve "^27.5.1" + jest-runner "^27.5.1" + jest-util "^27.5.1" + jest-validate "^27.5.1" + micromatch "^4.0.4" + parse-json "^5.2.0" + pretty-format "^27.5.1" + slash "^3.0.0" + strip-json-comments "^3.1.1" + +jest-diff@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-24.9.0.tgz#931b7d0d5778a1baf7452cb816e325e3724055da" + integrity sha512-qMfrTs8AdJE2iqrTp0hzh7kTd2PQWrsFyj9tORoKmu32xjPjeE4NyjVRDz8ybYwqS2ik8N4hsIpiVTyFeo2lBQ== + dependencies: + chalk "^2.0.1" + diff-sequences "^24.9.0" + jest-get-type "^24.9.0" + pretty-format "^24.9.0" + +jest-diff@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-27.5.1.tgz#a07f5011ac9e6643cf8a95a462b7b1ecf6680def" + integrity sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw== + dependencies: + chalk "^4.0.0" + diff-sequences "^27.5.1" + jest-get-type "^27.5.1" + pretty-format "^27.5.1" + +jest-docblock@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-docblock/-/jest-docblock-27.5.1.tgz#14092f364a42c6108d42c33c8cf30e058e25f6c0" + integrity sha512-rl7hlABeTsRYxKiUfpHrQrG4e2obOiTQWfMEH3PxPjOtdsfLQO4ReWSZaQ7DETm4xu07rl4q/h4zcKXyU0/OzQ== + dependencies: + detect-newline "^3.0.0" + +jest-each@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-each/-/jest-each-27.5.1.tgz#5bc87016f45ed9507fed6e4702a5b468a5b2c44e" + integrity sha512-1Ff6p+FbhT/bXQnEouYy00bkNSY7OUpfIcmdl8vZ31A1UUaurOLPA8a8BbJOF2RDUElwJhmeaV7LnagI+5UwNQ== + dependencies: + "@jest/types" "^27.5.1" + chalk "^4.0.0" + jest-get-type "^27.5.1" + jest-util "^27.5.1" + pretty-format "^27.5.1" + +jest-environment-jsdom@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-27.5.1.tgz#ea9ccd1fc610209655a77898f86b2b559516a546" + integrity sha512-TFBvkTC1Hnnnrka/fUb56atfDtJ9VMZ94JkjTbggl1PEpwrYtUBKMezB3inLmWqQsXYLcMwNoDQwoBTAvFfsfw== + dependencies: + "@jest/environment" "^27.5.1" + "@jest/fake-timers" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + jest-mock "^27.5.1" + jest-util "^27.5.1" + jsdom "^16.6.0" + +jest-environment-node@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-27.5.1.tgz#dedc2cfe52fab6b8f5714b4808aefa85357a365e" + integrity sha512-Jt4ZUnxdOsTGwSRAfKEnE6BcwsSPNOijjwifq5sDFSA2kesnXTvNqKHYgM0hDq3549Uf/KzdXNYn4wMZJPlFLw== + dependencies: + "@jest/environment" "^27.5.1" + "@jest/fake-timers" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + jest-mock "^27.5.1" + jest-util "^27.5.1" + +jest-extended@^0.11.5: + version "0.11.5" + resolved "https://registry.yarnpkg.com/jest-extended/-/jest-extended-0.11.5.tgz#f063b3f1eaadad8d7c13a01f0dfe0f538d498ccf" + integrity sha512-3RsdFpLWKScpsLD6hJuyr/tV5iFOrw7v6YjA3tPdda9sJwoHwcMROws5gwiIZfcwhHlJRwFJB2OUvGmF3evV/Q== + dependencies: + expect "^24.1.0" + jest-get-type "^22.4.3" + jest-matcher-utils "^22.0.0" + +jest-get-type@^22.4.3: + version "22.4.3" + resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-22.4.3.tgz#e3a8504d8479342dd4420236b322869f18900ce4" + integrity sha512-/jsz0Y+V29w1chdXVygEKSz2nBoHoYqNShPe+QgxSNjAuP1i8+k4LbQNrfoliKej0P45sivkSCh7yiD6ubHS3w== + +jest-get-type@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-24.9.0.tgz#1684a0c8a50f2e4901b6644ae861f579eed2ef0e" + integrity sha512-lUseMzAley4LhIcpSP9Jf+fTrQ4a1yHQwLNeeVa2cEmbCGeoZAtYPOIv8JaxLD/sUpKxetKGP+gsHl8f8TSj8Q== + +jest-get-type@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-27.5.1.tgz#3cd613c507b0f7ace013df407a1c1cd578bcb4f1" + integrity sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw== + +jest-haste-map@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-27.5.1.tgz#9fd8bd7e7b4fa502d9c6164c5640512b4e811e7f" + integrity sha512-7GgkZ4Fw4NFbMSDSpZwXeBiIbx+t/46nJ2QitkOjvwPYyZmqttu2TDSimMHP1EkPOi4xUZAN1doE5Vd25H4Jng== + dependencies: + "@jest/types" "^27.5.1" + "@types/graceful-fs" "^4.1.2" + "@types/node" "*" + anymatch "^3.0.3" + fb-watchman "^2.0.0" + graceful-fs "^4.2.9" + jest-regex-util "^27.5.1" + jest-serializer "^27.5.1" + jest-util "^27.5.1" + jest-worker "^27.5.1" + micromatch "^4.0.4" + walker "^1.0.7" + optionalDependencies: + fsevents "^2.3.2" + +jest-jasmine2@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-27.5.1.tgz#a037b0034ef49a9f3d71c4375a796f3b230d1ac4" + integrity sha512-jtq7VVyG8SqAorDpApwiJJImd0V2wv1xzdheGHRGyuT7gZm6gG47QEskOlzsN1PG/6WNaCo5pmwMHDf3AkG2pQ== + dependencies: + "@jest/environment" "^27.5.1" + "@jest/source-map" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + expect "^27.5.1" + is-generator-fn "^2.0.0" + jest-each "^27.5.1" + jest-matcher-utils "^27.5.1" + jest-message-util "^27.5.1" + jest-runtime "^27.5.1" + jest-snapshot "^27.5.1" + jest-util "^27.5.1" + pretty-format "^27.5.1" + throat "^6.0.1" + +jest-leak-detector@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-leak-detector/-/jest-leak-detector-27.5.1.tgz#6ec9d54c3579dd6e3e66d70e3498adf80fde3fb8" + integrity sha512-POXfWAMvfU6WMUXftV4HolnJfnPOGEu10fscNCA76KBpRRhcMN2c8d3iT2pxQS3HLbA+5X4sOUPzYO2NUyIlHQ== + dependencies: + jest-get-type "^27.5.1" + pretty-format "^27.5.1" + +jest-matcher-utils@^22.0.0: + version "22.4.3" + resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-22.4.3.tgz#4632fe428ebc73ebc194d3c7b65d37b161f710ff" + integrity sha512-lsEHVaTnKzdAPR5t4B6OcxXo9Vy4K+kRRbG5gtddY8lBEC+Mlpvm1CJcsMESRjzUhzkz568exMV1hTB76nAKbA== + dependencies: + chalk "^2.0.1" + jest-get-type "^22.4.3" + pretty-format "^22.4.3" + +jest-matcher-utils@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-24.9.0.tgz#f5b3661d5e628dffe6dd65251dfdae0e87c3a073" + integrity sha512-OZz2IXsu6eaiMAwe67c1T+5tUAtQyQx27/EMEkbFAGiw52tB9em+uGbzpcgYVpA8wl0hlxKPZxrly4CXU/GjHA== + dependencies: + chalk "^2.0.1" + jest-diff "^24.9.0" + jest-get-type "^24.9.0" + pretty-format "^24.9.0" + +jest-matcher-utils@^27.0.0, jest-matcher-utils@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz#9c0cdbda8245bc22d2331729d1091308b40cf8ab" + integrity sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw== + dependencies: + chalk "^4.0.0" + jest-diff "^27.5.1" + jest-get-type "^27.5.1" + pretty-format "^27.5.1" + +jest-message-util@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-24.9.0.tgz#527f54a1e380f5e202a8d1149b0ec872f43119e3" + integrity sha512-oCj8FiZ3U0hTP4aSui87P4L4jC37BtQwUMqk+zk/b11FR19BJDeZsZAvIHutWnmtw7r85UmR3CEWZ0HWU2mAlw== + dependencies: + "@babel/code-frame" "^7.0.0" + "@jest/test-result" "^24.9.0" + "@jest/types" "^24.9.0" + "@types/stack-utils" "^1.0.1" + chalk "^2.0.1" + micromatch "^3.1.10" + slash "^2.0.0" + stack-utils "^1.0.1" + +jest-message-util@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-27.5.1.tgz#bdda72806da10d9ed6425e12afff38cd1458b6cf" + integrity sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g== + dependencies: + "@babel/code-frame" "^7.12.13" + "@jest/types" "^27.5.1" + "@types/stack-utils" "^2.0.0" + chalk "^4.0.0" + graceful-fs "^4.2.9" + micromatch "^4.0.4" + pretty-format "^27.5.1" + slash "^3.0.0" + stack-utils "^2.0.3" + +jest-mock@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-27.5.1.tgz#19948336d49ef4d9c52021d34ac7b5f36ff967d6" + integrity sha512-K4jKbY1d4ENhbrG2zuPWaQBvDly+iZ2yAW+T1fATN78hc0sInwn7wZB8XtlNnvHug5RMwV897Xm4LqmPM4e2Og== + dependencies: + "@jest/types" "^27.5.1" + "@types/node" "*" + +jest-pnp-resolver@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz#b704ac0ae028a89108a4d040b3f919dfddc8e33c" + integrity sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w== + +jest-regex-util@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-24.9.0.tgz#c13fb3380bde22bf6575432c493ea8fe37965636" + integrity sha512-05Cmb6CuxaA+Ys6fjr3PhvV3bGQmO+2p2La4hFbU+W5uOc479f7FdLXUWXw4pYMAhhSZIuKHwSXSu6CsSBAXQA== + +jest-regex-util@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-27.5.1.tgz#4da143f7e9fd1e542d4aa69617b38e4a78365b95" + integrity sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg== + +jest-resolve-dependencies@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.1.tgz#d811ecc8305e731cc86dd79741ee98fed06f1da8" + integrity sha512-QQOOdY4PE39iawDn5rzbIePNigfe5B9Z91GDD1ae/xNDlu9kaat8QQ5EKnNmVWPV54hUdxCVwwj6YMgR2O7IOg== + dependencies: + "@jest/types" "^27.5.1" + jest-regex-util "^27.5.1" + jest-snapshot "^27.5.1" + +jest-resolve@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-27.5.1.tgz#a2f1c5a0796ec18fe9eb1536ac3814c23617b384" + integrity sha512-FFDy8/9E6CV83IMbDpcjOhumAQPDyETnU2KZ1O98DwTnz8AOBsW/Xv3GySr1mOZdItLR+zDZ7I/UdTFbgSOVCw== + dependencies: + "@jest/types" "^27.5.1" + chalk "^4.0.0" + graceful-fs "^4.2.9" + jest-haste-map "^27.5.1" + jest-pnp-resolver "^1.2.2" + jest-util "^27.5.1" + jest-validate "^27.5.1" + resolve "^1.20.0" + resolve.exports "^1.1.0" + slash "^3.0.0" + +jest-runner@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-runner/-/jest-runner-27.5.1.tgz#071b27c1fa30d90540805c5645a0ec167c7b62e5" + integrity sha512-g4NPsM4mFCOwFKXO4p/H/kWGdJp9V8kURY2lX8Me2drgXqG7rrZAx5kv+5H7wtt/cdFIjhqYx1HrlqWHaOvDaQ== + dependencies: + "@jest/console" "^27.5.1" + "@jest/environment" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/transform" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + chalk "^4.0.0" + emittery "^0.8.1" + graceful-fs "^4.2.9" + jest-docblock "^27.5.1" + jest-environment-jsdom "^27.5.1" + jest-environment-node "^27.5.1" + jest-haste-map "^27.5.1" + jest-leak-detector "^27.5.1" + jest-message-util "^27.5.1" + jest-resolve "^27.5.1" + jest-runtime "^27.5.1" + jest-util "^27.5.1" + jest-worker "^27.5.1" + source-map-support "^0.5.6" + throat "^6.0.1" + +jest-runtime@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-runtime/-/jest-runtime-27.5.1.tgz#4896003d7a334f7e8e4a53ba93fb9bcd3db0a1af" + integrity sha512-o7gxw3Gf+H2IGt8fv0RiyE1+r83FJBRruoA+FXrlHw6xEyBsU8ugA6IPfTdVyA0w8HClpbK+DGJxH59UrNMx8A== + dependencies: + "@jest/environment" "^27.5.1" + "@jest/fake-timers" "^27.5.1" + "@jest/globals" "^27.5.1" + "@jest/source-map" "^27.5.1" + "@jest/test-result" "^27.5.1" + "@jest/transform" "^27.5.1" + "@jest/types" "^27.5.1" + chalk "^4.0.0" + cjs-module-lexer "^1.0.0" + collect-v8-coverage "^1.0.0" + execa "^5.0.0" + glob "^7.1.3" + graceful-fs "^4.2.9" + jest-haste-map "^27.5.1" + jest-message-util "^27.5.1" + jest-mock "^27.5.1" + jest-regex-util "^27.5.1" + jest-resolve "^27.5.1" + jest-snapshot "^27.5.1" + jest-util "^27.5.1" + slash "^3.0.0" + strip-bom "^4.0.0" + +jest-serializer@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-serializer/-/jest-serializer-27.5.1.tgz#81438410a30ea66fd57ff730835123dea1fb1f64" + integrity sha512-jZCyo6iIxO1aqUxpuBlwTDMkzOAJS4a3eYz3YzgxxVQFwLeSA7Jfq5cbqCY+JLvTDrWirgusI/0KwxKMgrdf7w== + dependencies: + "@types/node" "*" + graceful-fs "^4.2.9" + +jest-snapshot@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-snapshot/-/jest-snapshot-27.5.1.tgz#b668d50d23d38054a51b42c4039cab59ae6eb6a1" + integrity sha512-yYykXI5a0I31xX67mgeLw1DZ0bJB+gpq5IpSuCAoyDi0+BhgU/RIrL+RTzDmkNTchvDFWKP8lp+w/42Z3us5sA== + dependencies: + "@babel/core" "^7.7.2" + "@babel/generator" "^7.7.2" + "@babel/plugin-syntax-typescript" "^7.7.2" + "@babel/traverse" "^7.7.2" + "@babel/types" "^7.0.0" + "@jest/transform" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/babel__traverse" "^7.0.4" + "@types/prettier" "^2.1.5" + babel-preset-current-node-syntax "^1.0.0" + chalk "^4.0.0" + expect "^27.5.1" + graceful-fs "^4.2.9" + jest-diff "^27.5.1" + jest-get-type "^27.5.1" + jest-haste-map "^27.5.1" + jest-matcher-utils "^27.5.1" + jest-message-util "^27.5.1" + jest-util "^27.5.1" + natural-compare "^1.4.0" + pretty-format "^27.5.1" + semver "^7.3.2" + +jest-util@^27.0.0, jest-util@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-27.5.1.tgz#3ba9771e8e31a0b85da48fe0b0891fb86c01c2f9" + integrity sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw== + dependencies: + "@jest/types" "^27.5.1" + "@types/node" "*" + chalk "^4.0.0" + ci-info "^3.2.0" + graceful-fs "^4.2.9" + picomatch "^2.2.3" + +jest-validate@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-validate/-/jest-validate-27.5.1.tgz#9197d54dc0bdb52260b8db40b46ae668e04df067" + integrity sha512-thkNli0LYTmOI1tDB3FI1S1RTp/Bqyd9pTarJwL87OIBFuqEb5Apv5EaApEudYg4g86e3CT6kM0RowkhtEnCBQ== + dependencies: + "@jest/types" "^27.5.1" + camelcase "^6.2.0" + chalk "^4.0.0" + jest-get-type "^27.5.1" + leven "^3.1.0" + pretty-format "^27.5.1" + +jest-watcher@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-27.5.1.tgz#71bd85fb9bde3a2c2ec4dc353437971c43c642a2" + integrity sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw== + dependencies: + "@jest/test-result" "^27.5.1" + "@jest/types" "^27.5.1" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + jest-util "^27.5.1" + string-length "^4.0.1" + +jest-worker@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.5.1.tgz#8d146f0900e8973b106b6f73cc1e9a8cb86f8db0" + integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg== + dependencies: + "@types/node" "*" + merge-stream "^2.0.0" + supports-color "^8.0.0" + +jest@^27.3.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest/-/jest-27.5.1.tgz#dadf33ba70a779be7a6fc33015843b51494f63fc" + integrity sha512-Yn0mADZB89zTtjkPJEXwrac3LHudkQMR+Paqa8uxJHCBr9agxztUifWCyiYrjhMPBoUVBjyny0I7XH6ozDr7QQ== + dependencies: + "@jest/core" "^27.5.1" + import-local "^3.0.2" + jest-cli "^27.5.1" + +js-sha256@^0.9.0: + version "0.9.0" + resolved "https://registry.yarnpkg.com/js-sha256/-/js-sha256-0.9.0.tgz#0b89ac166583e91ef9123644bd3c5334ce9d0966" + integrity sha512-sga3MHh9sgQN2+pJ9VYZ+1LPwXOxuBJBA5nrR5/ofPfuiJBE2hnjsaN8se8JznOmGLN2p49Pe5U/ttafcs/apA== + +js-sha3@0.5.7, js-sha3@^0.5.7: + version "0.5.7" + resolved "https://registry.yarnpkg.com/js-sha3/-/js-sha3-0.5.7.tgz#0d4ffd8002d5333aabaf4a23eed2f6374c9f28e7" + integrity sha512-GII20kjaPX0zJ8wzkTbNDYMY7msuZcTWk8S5UOh6806Jq/wz1J8/bnr8uGU0DAUmYDjj2Mr4X1cW8v/GLYnR+g== + +js-sha3@0.8.0, js-sha3@^0.8.0: + version "0.8.0" + resolved "https://registry.yarnpkg.com/js-sha3/-/js-sha3-0.8.0.tgz#b9b7a5da73afad7dedd0f8c463954cbde6818840" + integrity sha512-gF1cRrHhIzNfToc802P800N8PpXS+evLLXfsVpowqmAFR9uwbi89WvXg2QspOmXL8QL86J4T1EpFu+yUkwJY3Q== + +"js-tokens@^3.0.0 || ^4.0.0", js-tokens@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" + integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== + +js-yaml@4.1.0, js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + +js-yaml@^3.13.1: + version "3.14.1" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.1.tgz#dae812fdb3825fa306609a8717383c50c36a0537" + integrity sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g== + dependencies: + argparse "^1.0.7" + esprima "^4.0.0" + +jsbi@^3.1.1, jsbi@^3.1.4: + version "3.2.5" + resolved "https://registry.yarnpkg.com/jsbi/-/jsbi-3.2.5.tgz#b37bb90e0e5c2814c1c2a1bcd8c729888a2e37d6" + integrity sha512-aBE4n43IPvjaddScbvWRA2YlTzKEynHzu7MqOyTipdHucf/VxS63ViCjxYRg86M8Rxwbt/GfzHl1kKERkt45fQ== + +jsbi@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/jsbi/-/jsbi-4.3.0.tgz#b54ee074fb6fcbc00619559305c8f7e912b04741" + integrity sha512-SnZNcinB4RIcnEyZqFPdGPVgrg2AcnykiBy0sHVJQKHYeaLUvi3Exj+iaPpLnFVkDPZIV4U0yvgC9/R4uEAZ9g== + +jsbn@~0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" + integrity sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg== + +jsdom@^16.6.0: + version "16.7.0" + resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.7.0.tgz#918ae71965424b197c819f8183a754e18977b710" + integrity sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw== + dependencies: + abab "^2.0.5" + acorn "^8.2.4" + acorn-globals "^6.0.0" + cssom "^0.4.4" + cssstyle "^2.3.0" + data-urls "^2.0.0" + decimal.js "^10.2.1" + domexception "^2.0.1" + escodegen "^2.0.0" + form-data "^3.0.0" + html-encoding-sniffer "^2.0.1" + http-proxy-agent "^4.0.1" + https-proxy-agent "^5.0.0" + is-potential-custom-element-name "^1.0.1" + nwsapi "^2.2.0" + parse5 "6.0.1" + saxes "^5.0.1" + symbol-tree "^3.2.4" + tough-cookie "^4.0.0" + w3c-hr-time "^1.0.2" + w3c-xmlserializer "^2.0.0" + webidl-conversions "^6.1.0" + whatwg-encoding "^1.0.5" + whatwg-mimetype "^2.3.0" + whatwg-url "^8.5.0" + ws "^7.4.6" + xml-name-validator "^3.0.0" + +jsesc@^2.5.1: + version "2.5.2" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" + integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== + +json-buffer@3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.0.tgz#5b1f397afc75d677bde8bcfc0e47e1f9a3d9a898" + integrity sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ== + +json-buffer@3.0.1, json-buffer@~3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" + integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ== + +json-parse-even-better-errors@^2.3.0: + version "2.3.1" + resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" + integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== + +json-pointer@^0.6.1: + version "0.6.2" + resolved "https://registry.yarnpkg.com/json-pointer/-/json-pointer-0.6.2.tgz#f97bd7550be5e9ea901f8c9264c9d436a22a93cd" + integrity sha512-vLWcKbOaXlO+jvRy4qNd+TI1QUPZzfJj1tpJ3vAXDych5XJf93ftpUKe5pKCrzyIIwgBJcOcCVRUfqQP25afBw== + dependencies: + foreach "^2.0.4" + +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + +json-schema-traverse@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" + integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== + +json-schema-typed@^7.0.3: + version "7.0.3" + resolved "https://registry.yarnpkg.com/json-schema-typed/-/json-schema-typed-7.0.3.tgz#23ff481b8b4eebcd2ca123b4fa0409e66469a2d9" + integrity sha512-7DE8mpG+/fVw+dTpjbxnx47TaMnDfOI1jwft9g1VybltZCduyRQPJPvc+zzKY9WPHxhPWczyFuYa6I8Mw4iU5A== + +json-schema@0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.4.0.tgz#f7de4cf6efab838ebaeb3236474cbba5a1930ab5" + integrity sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA== + +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== + +json-stable-stringify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz#9a759d39c5f2ff503fd5300646ed445f88c4f9af" + integrity sha512-i/J297TW6xyj7sDFa7AmBPkQvLIxWr2kKPWI26tXydnZrzVAocNqn5DMNT1Mzk0vit1V5UkRM7C1KdVNp7Lmcg== + dependencies: + jsonify "~0.0.0" + +json-stringify-safe@^5.0.1, json-stringify-safe@~5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" + integrity sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA== + +json-text-sequence@^0.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/json-text-sequence/-/json-text-sequence-0.1.1.tgz#a72f217dc4afc4629fff5feb304dc1bd51a2f3d2" + integrity sha512-L3mEegEWHRekSHjc7+sc8eJhba9Clq1PZ8kMkzf8OxElhXc8O4TS5MwcVlj9aEbm5dr81N90WHC5nAz3UO971w== + dependencies: + delimit-stream "0.1.0" + +json5@2.x, json5@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.1.tgz#655d50ed1e6f95ad1a3caababd2b0efda10b395c" + integrity sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA== + +json5@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" + integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== + dependencies: + minimist "^1.2.0" + +jsonfile@^2.1.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-2.4.0.tgz#3736a2b428b87bbda0cc83b53fa3d633a35c2ae8" + integrity sha512-PKllAqbgLgxHaj8TElYymKCAgrASebJrWpTnEkOaTowt23VKXXN0sUeriJ+eh7y6ufb/CC5ap11pz71/cM0hUw== + optionalDependencies: + graceful-fs "^4.1.6" + +jsonfile@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb" + integrity sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg== + optionalDependencies: + graceful-fs "^4.1.6" + +jsonfile@^6.0.1: + version "6.1.0" + resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" + integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ== + dependencies: + universalify "^2.0.0" + optionalDependencies: + graceful-fs "^4.1.6" + +jsonify@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.1.tgz#2aa3111dae3d34a0f151c63f3a45d995d9420978" + integrity sha512-2/Ki0GcmuqSrgFyelQq9M05y7PS0mEwuIzrf3f1fPqkVDVRvZrPZtVSMHxdgo8Aq0sxAOb/cr2aqqA3LeWHVPg== + +jsonparse@^1.2.0: + version "1.3.1" + resolved "https://registry.yarnpkg.com/jsonparse/-/jsonparse-1.3.1.tgz#3f4dae4a91fac315f71062f8521cc239f1366280" + integrity sha1-P02uSpH6wxX3EGL4UhzCOfE2YoA= + +jsprim@^1.2.2: + version "1.4.2" + resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.2.tgz#712c65533a15c878ba59e9ed5f0e26d5b77c5feb" + integrity sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw== + dependencies: + assert-plus "1.0.0" + extsprintf "1.3.0" + json-schema "0.4.0" + verror "1.10.0" + +keccak@3.0.2, keccak@^3.0.0, keccak@^3.0.1: + version "3.0.2" + resolved "https://registry.yarnpkg.com/keccak/-/keccak-3.0.2.tgz#4c2c6e8c54e04f2670ee49fa734eb9da152206e0" + integrity sha512-PyKKjkH53wDMLGrvmRGSNWgmSxZOUqbnXwKL9tmgbFYA1iAYqW21kfR7mZXV0MlESiefxQQE9X9fTa3X+2MPDQ== + dependencies: + node-addon-api "^2.0.0" + node-gyp-build "^4.2.0" + readable-stream "^3.6.0" + +keyv@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/keyv/-/keyv-3.1.0.tgz#ecc228486f69991e49e9476485a5be1e8fc5c4d9" + integrity sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA== + dependencies: + json-buffer "3.0.0" + +keyv@^4.0.0: + version "4.3.3" + resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.3.3.tgz#6c1bcda6353a9e96fc1b4e1aeb803a6e35090ba9" + integrity sha512-AcysI17RvakTh8ir03+a3zJr5r0ovnAH/XTXei/4HIv3bL2K/jzvgivLK9UuI/JbU1aJjM3NSAnVvVVd3n+4DQ== + dependencies: + compress-brotli "^1.3.8" + json-buffer "3.0.1" + +kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0: + version "3.2.2" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" + integrity sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ== + dependencies: + is-buffer "^1.1.5" + +kind-of@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57" + integrity sha512-24XsCxmEbRwEDbz/qz3stgin8TTzZ1ESR56OMCN0ujYg+vRutNSiOj9bHH9u85DKgXguraugV5sFuvbD4FW/hw== + dependencies: + is-buffer "^1.1.5" + +kind-of@^5.0.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-5.1.0.tgz#729c91e2d857b7a419a1f9aa65685c4c33f5845d" + integrity sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw== + +kind-of@^6.0.0, kind-of@^6.0.2: + version "6.0.3" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" + integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== + +klaw@^1.0.0: + version "1.3.1" + resolved "https://registry.yarnpkg.com/klaw/-/klaw-1.3.1.tgz#4088433b46b3b1ba259d78785d8e96f73ba02439" + integrity sha512-TED5xi9gGQjGpNnvRWknrwAB1eL5GciPfVFOt3Vk1OJCVDQbzuSfrF3hkUQKlsgKrG1F+0t5W0m+Fje1jIt8rw== + optionalDependencies: + graceful-fs "^4.1.9" + +kleur@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/kleur/-/kleur-3.0.3.tgz#a79c9ecc86ee1ce3fa6206d1216c501f147fc07e" + integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== + +kuler@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/kuler/-/kuler-2.0.0.tgz#e2c570a3800388fb44407e851531c1d670b061b3" + integrity sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A== + +lcid@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/lcid/-/lcid-2.0.0.tgz#6ef5d2df60e52f82eb228a4c373e8d1f397253cf" + integrity sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA== + dependencies: + invert-kv "^2.0.0" + +lcov-parse@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/lcov-parse/-/lcov-parse-1.0.0.tgz#eb0d46b54111ebc561acb4c408ef9363bdc8f7e0" + integrity sha1-6w1GtUER68VhrLTECO+TY73I9+A= + +level-codec@9.0.2, level-codec@^9.0.0: + version "9.0.2" + resolved "https://registry.yarnpkg.com/level-codec/-/level-codec-9.0.2.tgz#fd60df8c64786a80d44e63423096ffead63d8cbc" + integrity sha512-UyIwNb1lJBChJnGfjmO0OR+ezh2iVu1Kas3nvBS/BzGnx79dv6g7unpKIDNPMhfdTEGoc7mC8uAu51XEtX+FHQ== + dependencies: + buffer "^5.6.0" + +level-concat-iterator@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/level-concat-iterator/-/level-concat-iterator-3.1.0.tgz#5235b1f744bc34847ed65a50548aa88d22e881cf" + integrity sha512-BWRCMHBxbIqPxJ8vHOvKUsaO0v1sLYZtjN3K2iZJsRBYtp+ONsY6Jfi6hy9K3+zolgQRryhIn2NRZjZnWJ9NmQ== + dependencies: + catering "^2.1.0" + +level-concat-iterator@~2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/level-concat-iterator/-/level-concat-iterator-2.0.1.tgz#1d1009cf108340252cb38c51f9727311193e6263" + integrity sha512-OTKKOqeav2QWcERMJR7IS9CUo1sHnke2C0gkSmcR7QuEtFNLLzHQAvnMw8ykvEcv0Qtkg0p7FOwP1v9e5Smdcw== + +level-errors@^2.0.0, level-errors@~2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/level-errors/-/level-errors-2.0.1.tgz#2132a677bf4e679ce029f517c2f17432800c05c8" + integrity sha512-UVprBJXite4gPS+3VznfgDSU8PTRuVX0NXwoWW50KLxd2yw4Y1t2JUR5In1itQnudZqRMT9DlAM3Q//9NCjCFw== + dependencies: + errno "~0.1.1" + +level-iterator-stream@~4.0.0: + version "4.0.2" + resolved "https://registry.yarnpkg.com/level-iterator-stream/-/level-iterator-stream-4.0.2.tgz#7ceba69b713b0d7e22fcc0d1f128ccdc8a24f79c" + integrity sha512-ZSthfEqzGSOMWoUGhTXdX9jv26d32XJuHz/5YnuHZzH6wldfWMOVwI9TBtKcya4BKTyTt3XVA0A3cF3q5CY30Q== + dependencies: + inherits "^2.0.4" + readable-stream "^3.4.0" + xtend "^4.0.2" + +level-js@^5.0.0: + version "5.0.2" + resolved "https://registry.yarnpkg.com/level-js/-/level-js-5.0.2.tgz#5e280b8f93abd9ef3a305b13faf0b5397c969b55" + integrity sha512-SnBIDo2pdO5VXh02ZmtAyPP6/+6YTJg2ibLtl9C34pWvmtMEmRTWpra+qO/hifkUtBTOtfx6S9vLDjBsBK4gRg== + dependencies: + abstract-leveldown "~6.2.3" + buffer "^5.5.0" + inherits "^2.0.3" + ltgt "^2.1.2" + +level-mem@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/level-mem/-/level-mem-5.0.1.tgz#c345126b74f5b8aa376dc77d36813a177ef8251d" + integrity sha512-qd+qUJHXsGSFoHTziptAKXoLX87QjR7v2KMbqncDXPxQuCdsQlzmyX+gwrEHhlzn08vkf8TyipYyMmiC6Gobzg== + dependencies: + level-packager "^5.0.3" + memdown "^5.0.0" + +level-packager@^5.0.3, level-packager@^5.1.0: + version "5.1.1" + resolved "https://registry.yarnpkg.com/level-packager/-/level-packager-5.1.1.tgz#323ec842d6babe7336f70299c14df2e329c18939" + integrity sha512-HMwMaQPlTC1IlcwT3+swhqf/NUO+ZhXVz6TY1zZIIZlIR0YSn8GtAAWmIvKjNY16ZkEg/JcpAuQskxsXqC0yOQ== + dependencies: + encoding-down "^6.3.0" + levelup "^4.3.2" + +level-supports@^2.0.1: + version "2.1.0" + resolved "https://registry.yarnpkg.com/level-supports/-/level-supports-2.1.0.tgz#9af908d853597ecd592293b2fad124375be79c5f" + integrity sha512-E486g1NCjW5cF78KGPrMDRBYzPuueMZ6VBXHT6gC7A8UYWGiM14fGgp+s/L1oFfDWSPV/+SFkYCmZ0SiESkRKA== + +level-supports@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/level-supports/-/level-supports-4.0.1.tgz#431546f9d81f10ff0fea0e74533a0e875c08c66a" + integrity sha512-PbXpve8rKeNcZ9C1mUicC9auIYFyGpkV9/i6g76tLgANwWhtG2v7I4xNBUlkn3lE2/dZF3Pi0ygYGtLc4RXXdA== + +level-supports@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/level-supports/-/level-supports-1.0.1.tgz#2f530a596834c7301622521988e2c36bb77d122d" + integrity sha512-rXM7GYnW8gsl1vedTJIbzOrRv85c/2uCMpiiCzO2fndd06U/kUXEEU9evYn4zFggBOg36IsBW8LzqIpETwwQzg== + dependencies: + xtend "^4.0.2" + +level-transcoder@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/level-transcoder/-/level-transcoder-1.0.1.tgz#f8cef5990c4f1283d4c86d949e73631b0bc8ba9c" + integrity sha512-t7bFwFtsQeD8cl8NIoQ2iwxA0CL/9IFw7/9gAjOonH0PWTTiRfY7Hq+Ejbsxh86tXobDQ6IOiddjNYIfOBs06w== + dependencies: + buffer "^6.0.3" + module-error "^1.0.1" + +level-write-stream@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/level-write-stream/-/level-write-stream-1.0.0.tgz#3f7fbb679a55137c0feb303dee766e12ee13c1dc" + integrity sha512-bBNKOEOMl8msO+uIM9YX/gUO6ckokZ/4pCwTm/lwvs46x6Xs8Zy0sn3Vh37eDqse4mhy4fOMIb/JsSM2nyQFtw== + dependencies: + end-stream "~0.1.0" + +level-ws@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/level-ws/-/level-ws-2.0.0.tgz#207a07bcd0164a0ec5d62c304b4615c54436d339" + integrity sha512-1iv7VXx0G9ec1isqQZ7y5LmoZo/ewAsyDHNA8EFDW5hqH2Kqovm33nSFkSdnLLAK+I5FlT+lo5Cw9itGe+CpQA== + dependencies: + inherits "^2.0.3" + readable-stream "^3.1.0" + xtend "^4.0.1" + +level@6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/level/-/level-6.0.1.tgz#dc34c5edb81846a6de5079eac15706334b0d7cd6" + integrity sha512-psRSqJZCsC/irNhfHzrVZbmPYXDcEYhA5TVNwr+V92jF44rbf86hqGp8fiT702FyiArScYIlPSBTDUASCVNSpw== + dependencies: + level-js "^5.0.0" + level-packager "^5.1.0" + leveldown "^5.4.0" + +level@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/level/-/level-8.0.0.tgz#41b4c515dabe28212a3e881b61c161ffead14394" + integrity sha512-ypf0jjAk2BWI33yzEaaotpq7fkOPALKAgDBxggO6Q9HGX2MRXn0wbP1Jn/tJv1gtL867+YOjOB49WaUF3UoJNQ== + dependencies: + browser-level "^1.0.1" + classic-level "^1.2.0" + +leveldown@5.6.0, leveldown@^5.4.0: + version "5.6.0" + resolved "https://registry.yarnpkg.com/leveldown/-/leveldown-5.6.0.tgz#16ba937bb2991c6094e13ac5a6898ee66d3eee98" + integrity sha512-iB8O/7Db9lPaITU1aA2txU/cBEXAt4vWwKQRrrWuS6XDgbP4QZGj9BL2aNbwb002atoQ/lIotJkfyzz+ygQnUQ== + dependencies: + abstract-leveldown "~6.2.1" + napi-macros "~2.0.0" + node-gyp-build "~4.1.0" + +leveldown@6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/leveldown/-/leveldown-6.1.0.tgz#7ab1297706f70c657d1a72b31b40323aa612b9ee" + integrity sha512-8C7oJDT44JXxh04aSSsfcMI8YiaGRhOFI9/pMEL7nWJLVsWajDPTRxsSHTM2WcTVY5nXM+SuRHzPPi0GbnDX+w== + dependencies: + abstract-leveldown "^7.2.0" + napi-macros "~2.0.0" + node-gyp-build "^4.3.0" + +levelup@4.4.0, levelup@^4.3.2: + version "4.4.0" + resolved "https://registry.yarnpkg.com/levelup/-/levelup-4.4.0.tgz#f89da3a228c38deb49c48f88a70fb71f01cafed6" + integrity sha512-94++VFO3qN95cM/d6eBXvd894oJE0w3cInq9USsyQzzoJxmiYzPAocNcuGCPGGjoXqDVJcr3C1jzt1TSjyaiLQ== + dependencies: + deferred-leveldown "~5.3.0" + level-errors "~2.0.0" + level-iterator-stream "~4.0.0" + level-supports "~1.0.0" + xtend "~4.0.0" + +leven@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2" + integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== + +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + +levn@~0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" + integrity sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA== + dependencies: + prelude-ls "~1.1.2" + type-check "~0.3.2" + +libsodium-wrappers@^0.7.6: + version "0.7.10" + resolved "https://registry.yarnpkg.com/libsodium-wrappers/-/libsodium-wrappers-0.7.10.tgz#13ced44cacb0fc44d6ac9ce67d725956089ce733" + integrity sha512-pO3F1Q9NPLB/MWIhehim42b/Fwb30JNScCNh8TcQ/kIc+qGLQch8ag8wb0keK3EP5kbGakk1H8Wwo7v+36rNQg== + dependencies: + libsodium "^0.7.0" + +libsodium@^0.7.0: + version "0.7.10" + resolved "https://registry.yarnpkg.com/libsodium/-/libsodium-0.7.10.tgz#c2429a7e4c0836f879d701fec2c8a208af024159" + integrity sha512-eY+z7hDrDKxkAK+QKZVNv92A5KYkxfvIshtBJkmg5TSiCnYqZP3i9OO9whE79Pwgm4jGaoHgkM4ao/b9Cyu4zQ== + +lines-and-columns@^1.1.6: + version "1.2.4" + resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" + integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== + +locate-path@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" + integrity sha512-NCI2kiDkyR7VeEKm27Kda/iQHyKJe1Bu0FlTbYp3CqJu+9IFe9bLyAjMxf5ZDDbEg+iMPzB5zYyUTSm8wVTKmA== + dependencies: + p-locate "^2.0.0" + path-exists "^3.0.0" + +locate-path@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" + integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== + dependencies: + p-locate "^3.0.0" + path-exists "^3.0.0" + +locate-path@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" + integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== + dependencies: + p-locate "^4.1.0" + +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + +lockfile@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/lockfile/-/lockfile-1.0.4.tgz#07f819d25ae48f87e538e6578b6964a4981a5609" + integrity sha512-cvbTwETRfsFh4nHsL1eGWapU1XFi5Ot9E85sWAwia7Y7EgB7vfqcZhTKZ+l7hCGxSPoushMv5GKhT5PdLv03WA== + dependencies: + signal-exit "^3.0.2" + +lodash-es@^4.17.21, lodash-es@^4.2.1: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash-es/-/lodash-es-4.17.21.tgz#43e626c46e6591b7750beb2b50117390c609e3ee" + integrity sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw== + +lodash.camelcase@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6" + integrity sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA== + +lodash.memoize@4.x: + version "4.1.2" + resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" + integrity sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag== + +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + +lodash.sortby@^4.7.0: + version "4.7.0" + resolved "https://registry.yarnpkg.com/lodash.sortby/-/lodash.sortby-4.7.0.tgz#edd14c824e2cc9c1e0b0a1b42bb5210516a42438" + integrity sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA== + +lodash.truncate@^4.4.2: + version "4.4.2" + resolved "https://registry.yarnpkg.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz#5a350da0b1113b837ecfffd5812cbe58d6eae193" + integrity sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw== + +lodash@^4.17.11, lodash@^4.17.12, lodash@^4.17.13, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.2.1, lodash@^4.7.0: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" + integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== + +log-symbols@4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-4.1.0.tgz#3fbdbb95b4683ac9fc785111e792e558d4abd503" + integrity sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg== + dependencies: + chalk "^4.1.0" + is-unicode-supported "^0.1.0" + +logform@^2.3.2, logform@^2.4.0: + version "2.4.2" + resolved "https://registry.yarnpkg.com/logform/-/logform-2.4.2.tgz#a617983ac0334d0c3b942c34945380062795b47c" + integrity sha512-W4c9himeAwXEdZ05dQNerhFz2XG80P9Oj0loPUMV23VC2it0orMHQhJm4hdnnor3rd1HsGf6a2lPwBM1zeXHGw== + dependencies: + "@colors/colors" "1.5.0" + fecha "^4.2.0" + ms "^2.1.1" + safe-stable-stringify "^2.3.1" + triple-beam "^1.3.0" + +loglevel@^1.6.8: + version "1.8.0" + resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.8.0.tgz#e7ec73a57e1e7b419cb6c6ac06bf050b67356114" + integrity sha512-G6A/nJLRgWOuuwdNuA6koovfEV1YpqqAG4pRUlFaz3jj2QNZ8M4vBqnVA+HBTmU/AMNUtlOsMmSpF6NyOjztbA== + +long@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28" + integrity sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA== + +long@^5.0.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/long/-/long-5.2.0.tgz#2696dadf4b4da2ce3f6f6b89186085d94d52fd61" + integrity sha512-9RTUNjK60eJbx3uz+TEGF7fUr29ZDxR5QzXcyDpeSfeH28S9ycINflOgOlppit5U+4kNTe83KQnMEerw7GmE8w== + +loose-envify@^1.1.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" + integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== + dependencies: + js-tokens "^3.0.0 || ^4.0.0" + +lower-case-first@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/lower-case-first/-/lower-case-first-1.0.2.tgz#e5da7c26f29a7073be02d52bac9980e5922adfa1" + integrity sha512-UuxaYakO7XeONbKrZf5FEgkantPf5DUqDayzP5VXZrtRPdH86s4kN47I8B3TW10S4QKiE3ziHNf3kRN//okHjA== + dependencies: + lower-case "^1.1.2" + +lower-case@^1.1.0, lower-case@^1.1.1, lower-case@^1.1.2: + version "1.1.4" + resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-1.1.4.tgz#9a2cabd1b9e8e0ae993a4bf7d5875c39c42e8eac" + integrity sha512-2Fgx1Ycm599x+WGpIYwJOvsjmXFzTSc34IwDWALRA/8AopUKAVPwfJ+h5+f85BCp0PWmmJcWzEpxOpoXycMpdA== + +lower-case@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-2.0.2.tgz#6fa237c63dbdc4a82ca0fd882e4722dc5e634e28" + integrity sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg== + dependencies: + tslib "^2.0.3" + +lowercase-keys@^1.0.0, lowercase-keys@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz#6f9e30b47084d971a7c820ff15a6c5167b74c26f" + integrity sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA== + +lowercase-keys@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" + integrity sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA== + +lowercase-keys@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-3.0.0.tgz#c5e7d442e37ead247ae9db117a9d0a467c89d4f2" + integrity sha512-ozCC6gdQ+glXOQsveKD0YsDy8DSQFjDTz4zyzEHNV5+JP5D62LmfDZ6o1cycFx9ouG940M5dE8C8CTewdj2YWQ== + +lru-cache@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" + integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== + dependencies: + yallist "^3.0.2" + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +lru-cache@^7.10.1: + version "7.14.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-7.14.0.tgz#21be64954a4680e303a09e9468f880b98a0b3c7f" + integrity sha512-EIRtP1GrSJny0dqb50QXRUNBxHJhcpxHC++M5tD7RYbvLLn5KVWKsbyswSSqDuU15UFi3bgTQIY8nhDMeF6aDQ== + +lru_map@^0.3.3: + version "0.3.3" + resolved "https://registry.yarnpkg.com/lru_map/-/lru_map-0.3.3.tgz#b5c8351b9464cbd750335a79650a0ec0e56118dd" + integrity sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ== + +ltgt@2.2.1, ltgt@^2.1.2, ltgt@~2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/ltgt/-/ltgt-2.2.1.tgz#f35ca91c493f7b73da0e07495304f17b31f87ee5" + integrity sha512-AI2r85+4MquTw9ZYqabu4nMwy9Oftlfa/e/52t9IjtfG+mGBbTNdAoZ3RQKLHR6r0wQnwZnPIEh/Ya6XTWAKNA== + +make-dir@^1.0.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-1.3.0.tgz#79c1033b80515bd6d24ec9933e860ca75ee27f0c" + integrity sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ== + dependencies: + pify "^3.0.0" + +make-dir@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" + integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== + dependencies: + semver "^6.0.0" + +make-error@1.x, make-error@^1.1.1: + version "1.3.6" + resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" + integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== + +makeerror@1.0.12: + version "1.0.12" + resolved "https://registry.yarnpkg.com/makeerror/-/makeerror-1.0.12.tgz#3e5dd2079a82e812e983cc6610c4a2cb0eaa801a" + integrity sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg== + dependencies: + tmpl "1.0.5" + +map-age-cleaner@^0.1.1: + version "0.1.3" + resolved "https://registry.yarnpkg.com/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz#7d583a7306434c055fe474b0f45078e6e1b4b92a" + integrity sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w== + dependencies: + p-defer "^1.0.0" + +map-cache@^0.2.2: + version "0.2.2" + resolved "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz#c32abd0bd6525d9b051645bb4f26ac5dc98a0dbf" + integrity sha512-8y/eV9QQZCiyn1SprXSrCmqJN0yNRATe+PO8ztwqrvrbdRLA3eYJF0yaR0YayLWkMbsQSKWS9N2gPcGEc4UsZg== + +map-visit@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz#ecdca8f13144e660f1b5bd41f12f3479d98dfb8f" + integrity sha512-4y7uGv8bd2WdM9vpQsiQNo41Ln1NvhvDRuVt0k2JZQ+ezN2uaQes7lZeZ+QQUHOLQAtDaBJ+7wCbi+ab/KFs+w== + dependencies: + object-visit "^1.0.0" + +mathjs@*: + version "11.0.1" + resolved "https://registry.yarnpkg.com/mathjs/-/mathjs-11.0.1.tgz#7fb5150ef8c427f8bcddba52a084a3d8bffda7ea" + integrity sha512-Kgm+GcTxwD68zupr7BPK0yrlWpTh2q8sMH6VcBcQe5+JCBqcwOrBxBF11WPah7hVv0NCLDnJnFTiXtik1Phasg== + dependencies: + "@babel/runtime" "^7.18.9" + complex.js "^2.1.1" + decimal.js "^10.3.1" + escape-latex "^1.2.0" + fraction.js "^4.2.0" + javascript-natural-sort "^0.7.1" + seedrandom "^3.0.5" + tiny-emitter "^2.1.0" + typed-function "^3.0.0" + +mathjs@^10.5.0: + version "10.6.4" + resolved "https://registry.yarnpkg.com/mathjs/-/mathjs-10.6.4.tgz#1b87a1268781d64f0c8b4e5e1b36cf7ecf58bb05" + integrity sha512-omQyvRE1jIy+3k2qsqkWASOcd45aZguXZDckr3HtnTYyXk5+2xpVfC3kATgbO2Srjxlqww3TVdhD0oUdZ/hiFA== + dependencies: + "@babel/runtime" "^7.18.6" + complex.js "^2.1.1" + decimal.js "^10.3.1" + escape-latex "^1.2.0" + fraction.js "^4.2.0" + javascript-natural-sort "^0.7.1" + seedrandom "^3.0.5" + tiny-emitter "^2.1.0" + typed-function "^2.1.0" + +mathjs@^9.3.0: + version "9.5.2" + resolved "https://registry.yarnpkg.com/mathjs/-/mathjs-9.5.2.tgz#e0f3279320dc6f49e45d99c4fcdd8b52231f0462" + integrity sha512-c0erTq0GP503/Ch2OtDOAn50GIOsuxTMjmE00NI/vKJFSWrDaQHRjx6ai+16xYv70yBSnnpUgHZGNf9FR9IwmA== + dependencies: + "@babel/runtime" "^7.15.4" + complex.js "^2.0.15" + decimal.js "^10.3.1" + escape-latex "^1.2.0" + fraction.js "^4.1.1" + javascript-natural-sort "^0.7.1" + seedrandom "^3.0.5" + tiny-emitter "^2.1.0" + typed-function "^2.0.0" + +mcl-wasm@^0.7.1: + version "0.7.9" + resolved "https://registry.yarnpkg.com/mcl-wasm/-/mcl-wasm-0.7.9.tgz#c1588ce90042a8700c3b60e40efb339fc07ab87f" + integrity sha512-iJIUcQWA88IJB/5L15GnJVnSQJmf/YaxxV6zRavv83HILHaJQb6y0iFyDMdDO0gN8X37tdxmAOrH/P8B6RB8sQ== + +md5.js@^1.3.4: + version "1.3.5" + resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.5.tgz#b5d07b8e3216e3e27cd728d72f70d1e6a342005f" + integrity sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg== + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + safe-buffer "^5.1.2" + +media-typer@0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" + integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== + +mem@^4.0.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/mem/-/mem-4.3.0.tgz#461af497bc4ae09608cdb2e60eefb69bff744178" + integrity sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w== + dependencies: + map-age-cleaner "^0.1.1" + mimic-fn "^2.0.0" + p-is-promise "^2.0.0" + +memdown@1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/memdown/-/memdown-1.4.1.tgz#b4e4e192174664ffbae41361aa500f3119efe215" + integrity sha512-iVrGHZB8i4OQfM155xx8akvG9FIj+ht14DX5CQkCTG4EHzZ3d3sgckIf/Lm9ivZalEsFuEVnWv2B2WZvbrro2w== + dependencies: + abstract-leveldown "~2.7.1" + functional-red-black-tree "^1.0.1" + immediate "^3.2.3" + inherits "~2.0.1" + ltgt "~2.2.0" + safe-buffer "~5.1.1" + +memdown@^5.0.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/memdown/-/memdown-5.1.0.tgz#608e91a9f10f37f5b5fe767667a8674129a833cb" + integrity sha512-B3J+UizMRAlEArDjWHTMmadet+UKwHd3UjMgGBkZcKAxAYVPS9o0Yeiha4qvz7iGiL2Sb3igUft6p7nbFWctpw== + dependencies: + abstract-leveldown "~6.2.1" + functional-red-black-tree "~1.0.1" + immediate "~3.2.3" + inherits "~2.0.1" + ltgt "~2.2.0" + safe-buffer "~5.2.0" + +memorystream@^0.3.1: + version "0.3.1" + resolved "https://registry.yarnpkg.com/memorystream/-/memorystream-0.3.1.tgz#86d7090b30ce455d63fbae12dda51a47ddcaf9b2" + integrity sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw== + +merge-descriptors@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" + integrity sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w== + +merge-stream@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" + integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== + +merge2@^1.2.3, merge2@^1.3.0, merge2@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + +merkle-patricia-tree@^4.2.4: + version "4.2.4" + resolved "https://registry.yarnpkg.com/merkle-patricia-tree/-/merkle-patricia-tree-4.2.4.tgz#ff988d045e2bf3dfa2239f7fabe2d59618d57413" + integrity sha512-eHbf/BG6eGNsqqfbLED9rIqbsF4+sykEaBn6OLNs71tjclbMcMOk1tEPmJKcNcNCLkvbpY/lwyOlizWsqPNo8w== + dependencies: + "@types/levelup" "^4.3.0" + ethereumjs-util "^7.1.4" + level-mem "^5.0.1" + level-ws "^2.0.0" + readable-stream "^3.6.0" + semaphore-async-await "^1.5.1" + +methods@^1.1.2, methods@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" + integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== + +micromatch@^3.1.10: + version "3.1.10" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz#70859bc95c9840952f359a068a3fc49f9ecfac23" + integrity sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg== + dependencies: + arr-diff "^4.0.0" + array-unique "^0.3.2" + braces "^2.3.1" + define-property "^2.0.2" + extend-shallow "^3.0.2" + extglob "^2.0.4" + fragment-cache "^0.2.1" + kind-of "^6.0.2" + nanomatch "^1.2.9" + object.pick "^1.3.0" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.2" + +micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + +miller-rabin@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" + integrity sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA== + dependencies: + bn.js "^4.0.0" + brorand "^1.0.1" + +mime-db@1.52.0: + version "1.52.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-types@^2.1.12, mime-types@^2.1.16, mime-types@~2.1.19, mime-types@~2.1.24, mime-types@~2.1.34: + version "2.1.35" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + +mime@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" + integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== + +mime@2.6.0: + version "2.6.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-2.6.0.tgz#a2a682a95cd4d0cb1d6257e28f83da7e35800367" + integrity sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg== + +mimic-fn@^1.0.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz#820c86a39334640e99516928bd03fca88057d022" + integrity sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ== + +mimic-fn@^2.0.0, mimic-fn@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" + integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== + +mimic-fn@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-3.1.0.tgz#65755145bbf3e36954b949c16450427451d5ca74" + integrity sha512-Ysbi9uYW9hFyfrThdDEQuykN4Ey6BuwPD2kpI5ES/nFTDn/98yxYNLZJcgUAKPT/mcrLLKaGzJR9YVxJrIdASQ== + +mimic-response@^1.0.0, mimic-response@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" + integrity sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ== + +mimic-response@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-3.1.0.tgz#2d1d59af9c1b129815accc2c46a022a5ce1fa3c9" + integrity sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ== + +min-document@^2.19.0: + version "2.19.0" + resolved "https://registry.yarnpkg.com/min-document/-/min-document-2.19.0.tgz#7bd282e3f5842ed295bb748cdd9f1ffa2c824685" + integrity sha512-9Wy1B3m3f66bPPmU5hdA4DR4PB2OfDU/+GS3yAB7IQozE3tqXaVv2zOjgla7MEGSRv95+ILmOuvhLkOK6wJtCQ== + dependencies: + dom-walk "^0.1.0" + +minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" + integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== + +minimalistic-crypto-utils@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" + integrity sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg== + +"minimatch@2 || 3", minimatch@^3.0.3, minimatch@^3.0.4, minimatch@^3.1.1, minimatch@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +minimatch@3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" + integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== + dependencies: + brace-expansion "^1.1.7" + +minimatch@4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-4.2.1.tgz#40d9d511a46bdc4e563c22c3080cde9c0d8299b4" + integrity sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g== + dependencies: + brace-expansion "^1.1.7" + +minimatch@5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.0.1.tgz#fb9022f7528125187c92bd9e9b6366be1cf3415b" + integrity sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g== + dependencies: + brace-expansion "^2.0.1" + +minimist@0.0.8: + version "0.0.8" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d" + integrity sha512-miQKw5Hv4NS1Psg2517mV4e4dYNaO3++hjAvLOAzKqZ61rH8NS1SK+vbfBWZ5PY/Me/bEWhUwqMghEW5Fb9T7Q== + +minimist@^1.2.0, minimist@^1.2.5, minimist@^1.2.6: + version "1.2.6" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" + integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== + +minipass@^2.6.0, minipass@^2.9.0: + version "2.9.0" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.9.0.tgz#e713762e7d3e32fed803115cf93e04bca9fcc9a6" + integrity sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg== + dependencies: + safe-buffer "^5.1.2" + yallist "^3.0.0" + +minizlib@^1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-1.3.3.tgz#2290de96818a34c29551c8a8d301216bd65a861d" + integrity sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q== + dependencies: + minipass "^2.9.0" + +mitt@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/mitt/-/mitt-1.2.0.tgz#cb24e6569c806e31bd4e3995787fe38a04fdf90d" + integrity sha512-r6lj77KlwqLhIUku9UWYes7KJtsczvolZkzp8hbaDPPaE24OmWl5s539Mytlj22siEQKosZ26qCBgda2PKwoJw== + +mixin-deep@^1.2.0: + version "1.3.2" + resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" + integrity sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA== + dependencies: + for-in "^1.0.2" + is-extendable "^1.0.1" + +mkdirp-promise@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/mkdirp-promise/-/mkdirp-promise-5.0.1.tgz#e9b8f68e552c68a9c1713b84883f7a1dd039b8a1" + integrity sha512-Hepn5kb1lJPtVW84RFT40YG1OddBNTOVUZR2bzQUHc+Z03en8/3uX0+060JDhcEzyO08HmipsN9DcnFMxhIL9w== + dependencies: + mkdirp "*" + +mkdirp@*, mkdirp@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" + integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== + +mkdirp@0.5.1: + version "0.5.1" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903" + integrity sha512-SknJC52obPfGQPnjIkXbmA6+5H15E+fR+E4iR2oQ3zzCLbd7/ONua69R/Gw7AgkTLsRG+r5fzksYwWe1AgTyWA== + dependencies: + minimist "0.0.8" + +mkdirp@^0.5.1, mkdirp@^0.5.5, mkdirp@~0.5.1: + version "0.5.6" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.6.tgz#7def03d2432dcae4ba1d611445c48396062255f6" + integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== + dependencies: + minimist "^1.2.6" + +mnemonist@^0.38.0, mnemonist@^0.38.3: + version "0.38.5" + resolved "https://registry.yarnpkg.com/mnemonist/-/mnemonist-0.38.5.tgz#4adc7f4200491237fe0fa689ac0b86539685cade" + integrity sha512-bZTFT5rrPKtPJxj8KSV0WkPyNxl72vQepqqVUAW2ARUpUSF2qXMB6jZj7hW5/k7C1rtpzqbD/IIbJwLXUjCHeg== + dependencies: + obliterator "^2.0.0" + +mocha@5.0.5: + version "5.0.5" + resolved "https://registry.yarnpkg.com/mocha/-/mocha-5.0.5.tgz#e228e3386b9387a4710007a641f127b00be44b52" + integrity sha512-3MM3UjZ5p8EJrYpG7s+29HAI9G7sTzKEe4+w37Dg0QP7qL4XGsV+Q2xet2cE37AqdgN1OtYQB6Vl98YiPV3PgA== + dependencies: + browser-stdout "1.3.1" + commander "2.11.0" + debug "3.1.0" + diff "3.5.0" + escape-string-regexp "1.0.5" + glob "7.1.2" + growl "1.10.3" + he "1.1.1" + mkdirp "0.5.1" + supports-color "4.4.0" + +mocha@9.2.2: + version "9.2.2" + resolved "https://registry.yarnpkg.com/mocha/-/mocha-9.2.2.tgz#d70db46bdb93ca57402c809333e5a84977a88fb9" + integrity sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g== + dependencies: + "@ungap/promise-all-settled" "1.1.2" + ansi-colors "4.1.1" + browser-stdout "1.3.1" + chokidar "3.5.3" + debug "4.3.3" + diff "5.0.0" + escape-string-regexp "4.0.0" + find-up "5.0.0" + glob "7.2.0" + growl "1.10.5" + he "1.2.0" + js-yaml "4.1.0" + log-symbols "4.1.0" + minimatch "4.2.1" + ms "2.1.3" + nanoid "3.3.1" + serialize-javascript "6.0.0" + strip-json-comments "3.1.1" + supports-color "8.1.1" + which "2.0.2" + workerpool "6.2.0" + yargs "16.2.0" + yargs-parser "20.2.4" + yargs-unparser "2.0.0" + +mocha@^10.0.0: + version "10.0.0" + resolved "https://registry.yarnpkg.com/mocha/-/mocha-10.0.0.tgz#205447d8993ec755335c4b13deba3d3a13c4def9" + integrity sha512-0Wl+elVUD43Y0BqPZBzZt8Tnkw9CMUdNYnUsTfOM1vuhJVZL+kiesFYsqwBkEEuEixaiPe5ZQdqDgX2jddhmoA== + dependencies: + "@ungap/promise-all-settled" "1.1.2" + ansi-colors "4.1.1" + browser-stdout "1.3.1" + chokidar "3.5.3" + debug "4.3.4" + diff "5.0.0" + escape-string-regexp "4.0.0" + find-up "5.0.0" + glob "7.2.0" + he "1.2.0" + js-yaml "4.1.0" + log-symbols "4.1.0" + minimatch "5.0.1" + ms "2.1.3" + nanoid "3.3.3" + serialize-javascript "6.0.0" + strip-json-comments "3.1.1" + supports-color "8.1.1" + workerpool "6.2.1" + yargs "16.2.0" + yargs-parser "20.2.4" + yargs-unparser "2.0.0" + +mocha@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/mocha/-/mocha-5.2.0.tgz#6d8ae508f59167f940f2b5b3c4a612ae50c90ae6" + integrity sha512-2IUgKDhc3J7Uug+FxMXuqIyYzH7gJjXECKe/w43IGgQHTSj3InJi+yAA7T24L9bQMRKiUEHxEX37G5JpVUGLcQ== + dependencies: + browser-stdout "1.3.1" + commander "2.15.1" + debug "3.1.0" + diff "3.5.0" + escape-string-regexp "1.0.5" + glob "7.1.2" + growl "1.10.5" + he "1.1.1" + minimatch "3.0.4" + mkdirp "0.5.1" + supports-color "5.4.0" + +mock-ethers-provider@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/mock-ethers-provider/-/mock-ethers-provider-1.0.2.tgz#e63966d9c3f088987c9f47b52b2c7e9a5157de68" + integrity sha512-bxNEAGoHpjOi8Used1GUfT/rT42UekmbsByxyEdcZRlr7zZwxoL0ONIS9pgWkpWcSzqzzQvlElNblyUK/FqcXg== + dependencies: + ethers "^5.0.19" + +mock-fs@^4.1.0: + version "4.14.0" + resolved "https://registry.yarnpkg.com/mock-fs/-/mock-fs-4.14.0.tgz#ce5124d2c601421255985e6e94da80a7357b1b18" + integrity sha512-qYvlv/exQ4+svI3UOvPUpLDF0OMX5euvUH0Ny4N5QyRyhNdgAgUrVH3iUINSzEPLvx0kbo/Bp28GJKIqvE7URw== + +module-error@^1.0.1, module-error@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/module-error/-/module-error-1.0.2.tgz#8d1a48897ca883f47a45816d4fb3e3c6ba404d86" + integrity sha512-0yuvsqSCv8LbaOKhnsQ/T5JhyFlCYLPXK3U2sgV10zoKQwzs/MyfuQUOZQ1V/6OCOJsK/TRgNVrPuPDqtdMFtA== + +moment@^2.19.3, moment@^2.29.1: + version "2.29.4" + resolved "https://registry.yarnpkg.com/moment/-/moment-2.29.4.tgz#3dbe052889fe7c1b2ed966fcb3a77328964ef108" + integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w== + +morgan@^1.10.0: + version "1.10.0" + resolved "https://registry.yarnpkg.com/morgan/-/morgan-1.10.0.tgz#091778abc1fc47cd3509824653dae1faab6b17d7" + integrity sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ== + dependencies: + basic-auth "~2.0.1" + debug "2.6.9" + depd "~2.0.0" + on-finished "~2.3.0" + on-headers "~1.0.2" + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" + integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== + +ms@2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@2.1.3, ms@^2.1.1: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +multibase@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/multibase/-/multibase-0.7.0.tgz#1adfc1c50abe05eefeb5091ac0c2728d6b84581b" + integrity sha512-TW8q03O0f6PNFTQDvh3xxH03c8CjGaaYrjkl9UQPG6rz53TQzzxJVCIWVjzcbN/Q5Y53Zd0IBQBMVktVgNx4Fg== + dependencies: + base-x "^3.0.8" + buffer "^5.5.0" + +multibase@~0.6.0: + version "0.6.1" + resolved "https://registry.yarnpkg.com/multibase/-/multibase-0.6.1.tgz#b76df6298536cc17b9f6a6db53ec88f85f8cc12b" + integrity sha512-pFfAwyTjbbQgNc3G7D48JkJxWtoJoBMaR4xQUOuB8RnCgRqaYmWNFeJTTvrJ2w51bjLq2zTby6Rqj9TQ9elSUw== + dependencies: + base-x "^3.0.8" + buffer "^5.5.0" + +multicodec@^0.5.5: + version "0.5.7" + resolved "https://registry.yarnpkg.com/multicodec/-/multicodec-0.5.7.tgz#1fb3f9dd866a10a55d226e194abba2dcc1ee9ffd" + integrity sha512-PscoRxm3f+88fAtELwUnZxGDkduE2HD9Q6GHUOywQLjOGT/HAdhjLDYNZ1e7VR0s0TP0EwZ16LNUTFpoBGivOA== + dependencies: + varint "^5.0.0" + +multicodec@^1.0.0: + version "1.0.4" + resolved "https://registry.yarnpkg.com/multicodec/-/multicodec-1.0.4.tgz#46ac064657c40380c28367c90304d8ed175a714f" + integrity sha512-NDd7FeS3QamVtbgfvu5h7fd1IlbaC4EQ0/pgU4zqE2vdHCmBGsUa0TiM8/TdSeG6BMPC92OOCf8F1ocE/Wkrrg== + dependencies: + buffer "^5.6.0" + varint "^5.0.0" + +multihashes@^0.4.15, multihashes@~0.4.15: + version "0.4.21" + resolved "https://registry.yarnpkg.com/multihashes/-/multihashes-0.4.21.tgz#dc02d525579f334a7909ade8a122dabb58ccfcb5" + integrity sha512-uVSvmeCWf36pU2nB4/1kzYZjsXD9vofZKpgudqkceYY5g2aZZXJ5r9lxuzoRLl1OAp28XljXsEJ/X/85ZsKmKw== + dependencies: + buffer "^5.5.0" + multibase "^0.7.0" + varint "^5.0.0" + +mustache@^4.0.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/mustache/-/mustache-4.2.0.tgz#e5892324d60a12ec9c2a73359edca52972bf6f64" + integrity sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ== + +mute-stream@0.0.7: + version "0.0.7" + resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.7.tgz#3075ce93bc21b8fab43e1bc4da7e8115ed1e7bab" + integrity sha512-r65nCZhrbXXb6dXOACihYApHw2Q6pV0M3V0PSxd74N0+D8nzAdEAITq2oAjA1jVnKI+tGvEBUpqiMh0+rW6zDQ== + +mv@~2: + version "2.1.1" + resolved "https://registry.yarnpkg.com/mv/-/mv-2.1.1.tgz#ae6ce0d6f6d5e0a4f7d893798d03c1ea9559b6a2" + integrity sha512-at/ZndSy3xEGJ8i0ygALh8ru9qy7gWW1cmkaqBN29JmMlIvM//MEO9y1sk/avxuwnPcfhkejkLsuPxH81BrkSg== + dependencies: + mkdirp "~0.5.1" + ncp "~2.0.0" + rimraf "~2.4.0" + +nan@^2.14.0: + version "2.16.0" + resolved "https://registry.yarnpkg.com/nan/-/nan-2.16.0.tgz#664f43e45460fb98faf00edca0bb0d7b8dce7916" + integrity sha512-UdAqHyFngu7TfQKsCBgAA6pWDkT8MAO7d0jyOecVhN5354xbLqdn8mV9Tat9gepAupm0bt2DbeaSC8vS52MuFA== + +nano-json-stream-parser@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/nano-json-stream-parser/-/nano-json-stream-parser-0.1.2.tgz#0cc8f6d0e2b622b479c40d499c46d64b755c6f5f" + integrity sha512-9MqxMH/BSJC7dnLsEMPyfN5Dvoo49IsPFYMcHw3Bcfc2kN0lpHRBSzlMSVx4HGyJ7s9B31CyBTVehWJoQ8Ctew== + +nanoid@3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.1.tgz#6347a18cac88af88f58af0b3594b723d5e99bb35" + integrity sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw== + +nanoid@3.3.3: + version "3.3.3" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.3.tgz#fd8e8b7aa761fe807dba2d1b98fb7241bb724a25" + integrity sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w== + +nanomatch@^1.2.9: + version "1.2.13" + resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" + integrity sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA== + dependencies: + arr-diff "^4.0.0" + array-unique "^0.3.2" + define-property "^2.0.2" + extend-shallow "^3.0.2" + fragment-cache "^0.2.1" + is-windows "^1.0.2" + kind-of "^6.0.2" + object.pick "^1.3.0" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.1" + +napi-macros@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/napi-macros/-/napi-macros-2.0.0.tgz#2b6bae421e7b96eb687aa6c77a7858640670001b" + integrity sha512-A0xLykHtARfueITVDernsAWdtIMbOJgKgcluwENp3AlsKN/PloyO10HtmoqnFAQAcxPkgZN7wdfPfEd0zNGxbg== + +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" + integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== + +ncp@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ncp/-/ncp-2.0.0.tgz#195a21d6c46e361d2fb1281ba38b91e9df7bdbb3" + integrity sha512-zIdGUrPRFTUELUvr3Gmc7KZ2Sw/h1PiVM0Af/oHB6zgnV1ikqSfRk+TOufi79aHYCW3NiOXmr1BP5nWbzojLaA== + +near-api-js@0.44.2: + version "0.44.2" + resolved "https://registry.yarnpkg.com/near-api-js/-/near-api-js-0.44.2.tgz#e451f68f2c56bd885c7b918db5818a3e6e9423d0" + integrity sha512-eMnc4V+geggapEUa3nU2p8HSHn/njtloI4P2mceHQWO8vDE1NGpnAw8FuTBrLmXSgIv9m6oocgFc9t3VNf5zwg== + dependencies: + bn.js "5.2.0" + borsh "^0.6.0" + bs58 "^4.0.0" + depd "^2.0.0" + error-polyfill "^0.1.3" + http-errors "^1.7.2" + js-sha256 "^0.9.0" + mustache "^4.0.0" + node-fetch "^2.6.1" + text-encoding-utf-8 "^1.0.2" + tweetnacl "^1.0.1" + +near-api-js@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/near-api-js/-/near-api-js-1.0.0.tgz#7aebc8e538071114ed242e6cce3b8fa956267691" + integrity sha512-OYItaQIYlKK27FG5PrqqtkTI8Vv9TEOCi7gXePYigS4o6WofXciAXNjr4sihDJ8Vzi6s7+eEkf3zTNP3042FBw== + dependencies: + bn.js "5.2.1" + borsh "^0.7.0" + bs58 "^4.0.0" + depd "^2.0.0" + error-polyfill "^0.1.3" + http-errors "^1.7.2" + js-sha256 "^0.9.0" + mustache "^4.0.0" + node-fetch "^2.6.1" + text-encoding-utf-8 "^1.0.2" + tweetnacl "^1.0.1" + +negotiator@0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" + integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + +next-tick@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/next-tick/-/next-tick-1.1.0.tgz#1836ee30ad56d67ef281b22bd199f709449b35eb" + integrity sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ== + +nice-try@^1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" + integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== + +no-case@^2.2.0, no-case@^2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/no-case/-/no-case-2.3.2.tgz#60b813396be39b3f1288a4c1ed5d1e7d28b464ac" + integrity sha512-rmTZ9kz+f3rCvK2TD1Ue/oZlns7OGoIWP4fc3llxxRXlOkHKoWPPWJOfFYpITabSow43QJbRIoHQXtt10VldyQ== + dependencies: + lower-case "^1.1.1" + +no-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" + integrity sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg== + dependencies: + lower-case "^2.0.2" + tslib "^2.0.3" + +node-abort-controller@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/node-abort-controller/-/node-abort-controller-3.0.1.tgz#f91fa50b1dee3f909afabb7e261b1e1d6b0cb74e" + integrity sha512-/ujIVxthRs+7q6hsdjHMaj8hRG9NuWmwrz+JdRwZ14jdFoKSkm+vDsCbF9PLpnSqjaWQJuTmVtcWHNLr+vrOFw== + +node-addon-api@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-2.0.2.tgz#432cfa82962ce494b132e9d72a15b29f71ff5d32" + integrity sha512-Ntyt4AIXyaLIuMHF6IOoTakB3K+RWxwtsHNRxllEoA6vPwP9o4866g6YWDLUdnucilZhmkxiHwHr11gAENw+QA== + +node-cache@5.1.2, node-cache@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/node-cache/-/node-cache-5.1.2.tgz#f264dc2ccad0a780e76253a694e9fd0ed19c398d" + integrity sha512-t1QzWwnk4sjLWaQAS8CHgOJ+RAfmHpxFWmc36IWTiWHQfs0w5JDMBS1b1ZxQteo0vVVuWJvIUKHDkkeK7vIGCg== + dependencies: + clone "2.x" + +node-fetch@2, node-fetch@2.6.7, node-fetch@^2.6.1, node-fetch@^2.6.7: + version "2.6.7" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.7.tgz#24de9fba827e3b4ae44dc8b20256a379160052ad" + integrity sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ== + dependencies: + whatwg-url "^5.0.0" + +node-fetch@2.6.1: + version "2.6.1" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.1.tgz#045bd323631f76ed2e2b55573394416b639a0052" + integrity sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw== + +node-gyp-build@4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.4.0.tgz#42e99687ce87ddeaf3a10b99dc06abc11021f3f4" + integrity sha512-amJnQCcgtRVw9SvoebO3BKGESClrfXGCUTX9hSn1OuGQTQBOZmVd0Z0OlecpuRksKvbsUqALE8jls/ErClAPuQ== + +node-gyp-build@^4.2.0, node-gyp-build@^4.3.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.5.0.tgz#7a64eefa0b21112f89f58379da128ac177f20e40" + integrity sha512-2iGbaQBV+ITgCz76ZEjmhUKAKVf7xfY1sRl4UiKQspfZMH2h06SyhNsnSVy50cwkFQDGLyif6m/6uFXHkOZ6rg== + +node-gyp-build@~4.1.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.1.1.tgz#d7270b5d86717068d114cc57fff352f96d745feb" + integrity sha512-dSq1xmcPDKPZ2EED2S6zw/b9NKsqzXRE6dVr8TVQnI3FJOTteUMuqF3Qqs6LZg+mLGYJWqQzMbIjMtJqTv87nQ== + +node-int64@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" + integrity sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw== + +node-interval-tree@^1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/node-interval-tree/-/node-interval-tree-1.3.3.tgz#15ffb904cde08270214acace8dc7653e89ae32b7" + integrity sha512-K9vk96HdTK5fEipJwxSvIIqwTqr4e3HRJeJrNxBSeVMNSC/JWARRaX7etOLOuTmrRMeOI/K5TCJu3aWIwZiNTw== + dependencies: + shallowequal "^1.0.2" + +node-releases@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.6.tgz#8a7088c63a55e493845683ebf3c828d8c51c5503" + integrity sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg== + +node-ts-cache-storage-memory@4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/node-ts-cache-storage-memory/-/node-ts-cache-storage-memory-4.4.0.tgz#d87da36bef0145c4d5a988191ffff6b9789c394e" + integrity sha512-eG8tFF4C1/RBmx52cS/dEu63l+Cn+Z6mz16nuTJwNyvtvDHWjsKKM3hg77PA7ddgf2ztaCyen8ZMQnLy191S4g== + dependencies: + debug "^4.3.2" + node-ts-cache "^4.4.0" + +node-ts-cache@4.4.0, node-ts-cache@^4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/node-ts-cache/-/node-ts-cache-4.4.0.tgz#ce10368537751d198565d15d1352bab5cc649252" + integrity sha512-ZULcxpzyFfgpOd33PHjwhPz4fkWSfyrwa9sq1j4jyOm+PaBpQDIzB3m5HRiSKdgEBtQhP3g6hX44dnMjnoHiPA== + dependencies: + bluebird "3.7.2" + debug "^4.3.2" + redis "^3.1.2" + +nodemon@^2.0.16: + version "2.0.19" + resolved "https://registry.yarnpkg.com/nodemon/-/nodemon-2.0.19.tgz#cac175f74b9cb8b57e770d47841995eebe4488bd" + integrity sha512-4pv1f2bMDj0Eeg/MhGqxrtveeQ5/G/UVe9iO6uTZzjnRluSA4PVWf8CW99LUPwGB3eNIA7zUFoP77YuI7hOc0A== + dependencies: + chokidar "^3.5.2" + debug "^3.2.7" + ignore-by-default "^1.0.1" + minimatch "^3.0.4" + pstree.remy "^1.1.8" + semver "^5.7.1" + simple-update-notifier "^1.0.7" + supports-color "^5.5.0" + touch "^3.1.0" + undefsafe "^2.0.5" + +nofilter@^1.0.3, nofilter@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/nofilter/-/nofilter-1.0.4.tgz#78d6f4b6a613e7ced8b015cec534625f7667006e" + integrity sha512-N8lidFp+fCz+TD51+haYdbDGrcBWwuHX40F5+z0qkUjMJ5Tp+rdSuAkMJ9N9eoolDlEVTf6u5icM+cNKkKW2mA== + +nohup@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/nohup/-/nohup-0.1.0.tgz#b280603d4d04211648b4047d011484d0bcf347e3" + integrity sha512-22CT1M3ehv0QWL3+oJUfl5I/3MqtBaUO1kI4ciW+9AAjBsZ4u1CsGU8tlLwgDvYk6GmG7ECB0LTadvRjMFEpMg== + +noms@0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/noms/-/noms-0.0.0.tgz#da8ebd9f3af9d6760919b27d9cdc8092a7332859" + integrity sha512-lNDU9VJaOPxUmXcLb+HQFeUgQQPtMI24Gt6hgfuMHRJgMRHMF/qZ4HJD3GDru4sSw9IQl2jPjAYnQrdIeLbwow== + dependencies: + inherits "^2.0.1" + readable-stream "~1.0.31" + +nopt@~1.0.10: + version "1.0.10" + resolved "https://registry.yarnpkg.com/nopt/-/nopt-1.0.10.tgz#6ddd21bd2a31417b92727dd585f8a6f37608ebee" + integrity sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg== + dependencies: + abbrev "1" + +normalize-path@^3.0.0, normalize-path@~3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" + integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== + +normalize-url@^4.1.0: + version "4.5.1" + resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.1.tgz#0dd90cf1288ee1d1313b87081c9a5932ee48518a" + integrity sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA== + +normalize-url@^6.0.1: + version "6.1.0" + resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-6.1.0.tgz#40d0885b535deffe3f3147bec877d05fe4c5668a" + integrity sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A== + +npm-programmatic@0.0.12: + version "0.0.12" + resolved "https://registry.yarnpkg.com/npm-programmatic/-/npm-programmatic-0.0.12.tgz#566ba2452c886c7fd3a41586bd559cdc872fa77e" + integrity sha512-fvZdiJS038ZH31z59cEiIywOcgX1u23aLc0wAKF4btyhbYQxE93wTQjzs/URERK+GhS/QghDILQmEvgxu77/zQ== + dependencies: + bluebird "^3.4.1" + +npm-run-path@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f" + integrity sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw== + dependencies: + path-key "^2.0.0" + +npm-run-path@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" + integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== + dependencies: + path-key "^3.0.0" + +nth-check@^2.0.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d" + integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w== + dependencies: + boolbase "^1.0.0" + +number-is-nan@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" + integrity sha512-4jbtZXNAsfZbAHiiqjLPBiCl16dES1zI4Hpzzxw61Tk+loF+sBDBKx1ICKKKwIqQ7M0mFn1TmkN7euSncWgHiQ== + +number-to-bn@1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/number-to-bn/-/number-to-bn-1.7.0.tgz#bb3623592f7e5f9e0030b1977bd41a0c53fe1ea0" + integrity sha512-wsJ9gfSz1/s4ZsJN01lyonwuxA1tml6X1yBDnfpMglypcBRFZZkus26EdPSlqS5GJfYddVZa22p3VNb3z5m5Ig== + dependencies: + bn.js "4.11.6" + strip-hex-prefix "1.0.0" + +nwsapi@^2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.1.tgz#10a9f268fbf4c461249ebcfe38e359aa36e2577c" + integrity sha512-JYOWTeFoS0Z93587vRJgASD5Ut11fYl5NyihP3KrYBvMe1FRRs6RN7m20SA/16GM4P6hTnZjT+UmDOt38UeXNg== + +o3@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/o3/-/o3-1.0.3.tgz#192ce877a882dfa6751f0412a865fafb2da1dac0" + integrity sha512-f+4n+vC6s4ysy7YO7O2gslWZBUu8Qj2i2OUJOvjRxQva7jVjYjB29jrr9NCjmxZQR0gzrOcv1RnqoYOeMs5VRQ== + dependencies: + capability "^0.2.5" + +oauth-sign@~0.9.0: + version "0.9.0" + resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.9.0.tgz#47a7b016baa68b5fa0ecf3dee08a85c679ac6455" + integrity sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ== + +object-assign@^4, object-assign@^4.0.1, object-assign@^4.1.0, object-assign@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== + +object-copy@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c" + integrity sha512-79LYn6VAb63zgtmAteVOWo9Vdj71ZVBy3Pbse+VqxDpEP83XuujMrGqHIwAXJ5I/aM0zU7dIyIAhifVTPrNItQ== + dependencies: + copy-descriptor "^0.1.0" + define-property "^0.2.5" + kind-of "^3.0.3" + +object-hash@^2.0.1: + version "2.2.0" + resolved "https://registry.yarnpkg.com/object-hash/-/object-hash-2.2.0.tgz#5ad518581eefc443bd763472b8ff2e9c2c0d54a5" + integrity sha512-gScRMn0bS5fH+IuwyIFgnh9zBdo4DV+6GhygmWM9HyNJSgS0hScp1f5vjtm7oIIOiT9trXrShAkLFSc2IqKNgw== + +object-inspect@^1.12.0, object-inspect@^1.9.0: + version "1.12.2" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.2.tgz#c0641f26394532f28ab8d796ab954e43c009a8ea" + integrity sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ== + +object-keys@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" + integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== + +object-visit@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz#f79c4493af0c5377b59fe39d395e41042dd045bb" + integrity sha512-GBaMwwAVK9qbQN3Scdo0OyvgPW7l3lnaVMj84uTOZlswkX0KpF6fyDBJhtTthf7pymztoN36/KEr1DyhF96zEA== + dependencies: + isobject "^3.0.0" + +object.assign@^4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.2.tgz#0ed54a342eceb37b38ff76eb831a0e788cb63940" + integrity sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + has-symbols "^1.0.1" + object-keys "^1.1.1" + +object.pick@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747" + integrity sha512-tqa/UMy/CCoYmj+H5qc07qvSL9dqcs/WZENZ1JbtWBlATP+iVOe778gE6MSijnyCnORzDuX6hU+LA4SZ09YjFQ== + dependencies: + isobject "^3.0.1" + +object.values@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.5.tgz#959f63e3ce9ef108720333082131e4a459b716ac" + integrity sha512-QUZRW0ilQ3PnPpbNtgdNV1PDbEqLIiSFB3l+EnGtBQ/8SUTLj1PZwtQHABZtLgwpJZTSZhuGLOGk57Drx2IvYg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + +obliterator@^2.0.0: + version "2.0.4" + resolved "https://registry.yarnpkg.com/obliterator/-/obliterator-2.0.4.tgz#fa650e019b2d075d745e44f1effeb13a2adbe816" + integrity sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ== + +oboe@2.1.4: + version "2.1.4" + resolved "https://registry.yarnpkg.com/oboe/-/oboe-2.1.4.tgz#20c88cdb0c15371bb04119257d4fdd34b0aa49f6" + integrity sha512-ymBJ4xSC6GBXLT9Y7lirj+xbqBLa+jADGJldGEYG7u8sZbS9GyG+u1Xk9c5cbriKwSpCg41qUhPjvU5xOpvIyQ== + dependencies: + http-https "^1.0.0" + +oboe@2.1.5: + version "2.1.5" + resolved "https://registry.yarnpkg.com/oboe/-/oboe-2.1.5.tgz#5554284c543a2266d7a38f17e073821fbde393cd" + integrity sha512-zRFWiF+FoicxEs3jNI/WYUrVEgA7DeET/InK0XQuudGHRg8iIob3cNPrJTKaz4004uaA9Pbe+Dwa8iluhjLZWA== + dependencies: + http-https "^1.0.0" + +on-finished@2.4.1: + version "2.4.1" + resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" + integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== + dependencies: + ee-first "1.1.1" + +on-finished@~2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" + integrity sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww== + dependencies: + ee-first "1.1.1" + +on-headers@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" + integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== + +once@1.4.0, once@^1.3.0, once@^1.3.1, once@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== + dependencies: + wrappy "1" + +one-time@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/one-time/-/one-time-1.0.0.tgz#e06bc174aed214ed58edede573b433bbf827cb45" + integrity sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g== + dependencies: + fn.name "1.x.x" + +onetime@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-2.0.1.tgz#067428230fd67443b2794b22bba528b6867962d4" + integrity sha512-oyyPpiMaKARvvcgip+JV+7zci5L8D1W9RZIz2l1o08AM3pfspitVWnPt3mzHcBPp12oYMTy0pqrFs/C+m3EwsQ== + dependencies: + mimic-fn "^1.0.0" + +onetime@^5.1.0, onetime@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" + integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== + dependencies: + mimic-fn "^2.1.0" + +optionator@^0.8.1: + version "0.8.3" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.8.3.tgz#84fa1d036fe9d3c7e21d99884b601167ec8fb495" + integrity sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA== + dependencies: + deep-is "~0.1.3" + fast-levenshtein "~2.0.6" + levn "~0.3.0" + prelude-ls "~1.1.2" + type-check "~0.3.2" + word-wrap "~1.2.3" + +optionator@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" + integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.3" + +original-require@1.0.1, original-require@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/original-require/-/original-require-1.0.1.tgz#0f130471584cd33511c5ec38c8d59213f9ac5e20" + integrity sha512-5vdKMbE58WaE61uVD+PKyh8xdM398UnjPBLotW2sjG5MzHARwta/+NtMBCBA0t2WQblGYBvq5vsiZpWokwno+A== + +os-locale@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/os-locale/-/os-locale-3.1.0.tgz#a802a6ee17f24c10483ab9935719cef4ed16bf1a" + integrity sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q== + dependencies: + execa "^1.0.0" + lcid "^2.0.0" + mem "^4.0.0" + +os-tmpdir@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" + integrity sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g== + +p-cancelable@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-0.3.0.tgz#b9e123800bcebb7ac13a479be195b507b98d30fa" + integrity sha512-RVbZPLso8+jFeq1MfNvgXtCRED2raz/dKpacfTNxsx6pLEpEomM7gah6VeHSYV3+vo0OAi4MkArtQcWWXuQoyw== + +p-cancelable@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-1.1.0.tgz#d078d15a3af409220c886f1d9a0ca2e441ab26cc" + integrity sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw== + +p-cancelable@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-3.0.0.tgz#63826694b54d61ca1c20ebcb6d3ecf5e14cd8050" + integrity sha512-mlVgR3PGuzlo0MmTdk4cXqXWlwQDLnONTAg6sm62XkMJEiRxN3GL3SffkYvqwonbkJBcrI7Uvv5Zh9yjvn2iUw== + +p-defer@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/p-defer/-/p-defer-1.0.0.tgz#9f6eb182f6c9aa8cd743004a7d4f96b196b0fb0c" + integrity sha512-wB3wfAxZpk2AzOfUMJNL+d36xothRSyj8EXOa4f6GMqYDN9BJaaSISbsk+wS9abmnebVw95C2Kb5t85UmpCxuw== + +p-finally@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz#3fbcfb15b899a44123b34b6dcc18b724336a2cae" + integrity sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow== + +p-is-promise@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/p-is-promise/-/p-is-promise-2.1.0.tgz#918cebaea248a62cf7ffab8e3bca8c5f882fc42e" + integrity sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg== + +p-limit@^1.1.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz#b86bd5f0c25690911c7590fcbfc2010d54b3ccb8" + integrity sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q== + dependencies: + p-try "^1.0.0" + +p-limit@^2.0.0, p-limit@^2.2.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" + integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== + dependencies: + p-try "^2.0.0" + +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-locate@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" + integrity sha512-nQja7m7gSKuewoVRen45CtVfODR3crN3goVQ0DDZ9N3yHxgpkuBhZqsaiotSQRrADUrne346peY7kT3TSACykg== + dependencies: + p-limit "^1.1.0" + +p-locate@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" + integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== + dependencies: + p-limit "^2.0.0" + +p-locate@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" + integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== + dependencies: + p-limit "^2.2.0" + +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + +p-map@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" + integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== + dependencies: + aggregate-error "^3.0.0" + +p-timeout@^1.1.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/p-timeout/-/p-timeout-1.2.1.tgz#5eb3b353b7fce99f101a1038880bb054ebbea386" + integrity sha512-gb0ryzr+K2qFqFv6qi3khoeqMZF/+ajxQipEF6NteZVnvz9tzdsfAVj3lYtn1gAXvH5lfLwfxEII799gt/mRIA== + dependencies: + p-finally "^1.0.0" + +p-try@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/p-try/-/p-try-1.0.0.tgz#cbc79cdbaf8fd4228e13f621f2b1a237c1b207b3" + integrity sha512-U1etNYuMJoIz3ZXSrrySFjsXQTWOx2/jdi86L+2pRvph/qMKL6sbcCYdH23fqsbm8TH2Gn0OybpT4eSFlCVHww== + +p-try@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" + integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== + +pako@^2.0.3: + version "2.0.4" + resolved "https://registry.yarnpkg.com/pako/-/pako-2.0.4.tgz#6cebc4bbb0b6c73b0d5b8d7e8476e2b2fbea576d" + integrity sha512-v8tweI900AUkZN6heMU/4Uy4cXRc2AYNRggVmTR+dEncawDJgCdLMximOVA2p4qO57WMynangsfGRb5WD6L1Bg== + +param-case@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/param-case/-/param-case-2.1.1.tgz#df94fd8cf6531ecf75e6bef9a0858fbc72be2247" + integrity sha512-eQE845L6ot89sk2N8liD8HAuH4ca6Vvr7VWAWwt7+kvvG5aBcPmmphQ68JsEG2qa9n1TykS2DLeMt363AAH8/w== + dependencies: + no-case "^2.2.0" + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + +parse-asn1@^5.0.0, parse-asn1@^5.1.5: + version "5.1.6" + resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.6.tgz#385080a3ec13cb62a62d39409cb3e88844cdaed4" + integrity sha512-RnZRo1EPU6JBnra2vGHj0yhp6ebyjBZpmUCLHWiFhxlzvBCCpAuZ7elsBp1PVAbQN0/04VD/19rfzlBSwLstMw== + dependencies: + asn1.js "^5.2.0" + browserify-aes "^1.0.0" + evp_bytestokey "^1.0.0" + pbkdf2 "^3.0.3" + safe-buffer "^5.1.1" + +parse-headers@^2.0.0: + version "2.0.5" + resolved "https://registry.yarnpkg.com/parse-headers/-/parse-headers-2.0.5.tgz#069793f9356a54008571eb7f9761153e6c770da9" + integrity sha512-ft3iAoLOB/MlwbNXgzy43SWGP6sQki2jQvAyBg/zDFAgr9bfNWZIUj42Kw2eJIl8kEi4PbgE6U1Zau/HwI75HA== + +parse-json@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" + integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== + dependencies: + "@babel/code-frame" "^7.0.0" + error-ex "^1.3.1" + json-parse-even-better-errors "^2.3.0" + lines-and-columns "^1.1.6" + +parse5-htmlparser2-tree-adapter@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz#23c2cc233bcf09bb7beba8b8a69d46b08c62c2f1" + integrity sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g== + dependencies: + domhandler "^5.0.2" + parse5 "^7.0.0" + +parse5@6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b" + integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== + +parse5@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/parse5/-/parse5-7.0.0.tgz#51f74a5257f5fcc536389e8c2d0b3802e1bfa91a" + integrity sha512-y/t8IXSPWTuRZqXc0ajH/UwDj4mnqLEbSttNbThcFhGrZuOyoyvNBO85PBp2jQa55wY9d07PBNjsK8ZP3K5U6g== + dependencies: + entities "^4.3.0" + +parseurl@^1.3.3, parseurl@~1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" + integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== + +pascal-case@^2.0.0, pascal-case@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-2.0.1.tgz#2d578d3455f660da65eca18ef95b4e0de912761e" + integrity sha512-qjS4s8rBOJa2Xm0jmxXiyh1+OFf6ekCWOvUaRgAQSktzlTbMotS0nmG9gyYAybCWBcuP4fsBeRCKNwGBnMe2OQ== + dependencies: + camel-case "^3.0.0" + upper-case-first "^1.1.0" + +pascalcase@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz#b363e55e8006ca6fe21784d2db22bd15d7917f14" + integrity sha512-XHXfu/yOQRy9vYOtUDVMN60OEJjW013GoObG1o+xwQTpB9eYJX/BjXMsdW13ZDPruFhYYn0AG22w0xgQMwl3Nw== + +path-case@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/path-case/-/path-case-2.1.1.tgz#94b8037c372d3fe2906e465bb45e25d226e8eea5" + integrity sha512-Ou0N05MioItesaLr9q8TtHVWmJ6fxWdqKB2RohFmNWVyJ+2zeKIeDNWAN6B/Pe7wpzWChhZX6nONYmOnMeJQ/Q== + dependencies: + no-case "^2.2.0" + +path-dirname@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/path-dirname/-/path-dirname-1.0.2.tgz#cc33d24d525e099a5388c0336c6e32b9160609e0" + integrity sha512-ALzNPpyNq9AqXMBjeymIjFDAkAFH06mHJH/cSBHAgU0s4vfpBn6b2nf8tiRLvagKD8RbTpq2FKTBg7cl9l3c7Q== + +path-exists@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" + integrity sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ== + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== + +path-key@^2.0.0, path-key@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40" + integrity sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw== + +path-key@^3.0.0, path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.6, path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== + +path-to-regexp@0.1.7: + version "0.1.7" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" + integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== + +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + +pbkdf2@^3.0.17, pbkdf2@^3.0.3, pbkdf2@^3.0.9: + version "3.1.2" + resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.2.tgz#dd822aa0887580e52f1a039dc3eda108efae3075" + integrity sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA== + dependencies: + create-hash "^1.1.2" + create-hmac "^1.1.4" + ripemd160 "^2.0.1" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +pend@~1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" + integrity sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg== + +performance-now@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" + integrity sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow== + +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.3, picomatch@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + +pify@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" + integrity sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog== + +pify@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/pify/-/pify-3.0.0.tgz#e5a4acd2c101fdf3d9a4d07f0dbc4db49dd28176" + integrity sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg== + +pinkie-promise@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa" + integrity sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw== + dependencies: + pinkie "^2.0.0" + +pinkie@^2.0.0: + version "2.0.4" + resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" + integrity sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg== + +pirates@^4.0.4: + version "4.0.5" + resolved "https://registry.yarnpkg.com/pirates/-/pirates-4.0.5.tgz#feec352ea5c3268fb23a37c702ab1699f35a5f3b" + integrity sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ== + +pkg-dir@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" + integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== + dependencies: + find-up "^4.0.0" + +pkg-up@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/pkg-up/-/pkg-up-3.1.0.tgz#100ec235cc150e4fd42519412596a28512a0def5" + integrity sha512-nDywThFk1i4BQK4twPQ6TA4RT8bDY96yeuCVBWL3ePARCiEKDRSrNGbFIgUJpLp+XeIR65v8ra7WuJOFUBtkMA== + dependencies: + find-up "^3.0.0" + +pluralize@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/pluralize/-/pluralize-8.0.0.tgz#1a6fa16a38d12a1901e0320fa017051c539ce3b1" + integrity sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA== + +posix-character-classes@^0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" + integrity sha512-xTgYBc3fuo7Yt7JbiuFxSYGToMoz8fLoE6TC9Wx1P/u+LfeThMOAqmuyECnlBaaJb+u1m9hHiXUEtwW4OzfUJg== + +pouchdb-abstract-mapreduce@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-abstract-mapreduce/-/pouchdb-abstract-mapreduce-7.3.0.tgz#cc178cb5d07f73b7c3f0f47a7f963defd4872b1c" + integrity sha512-+2fVt3SDh7D776lIGbYZOsKX5js1aUyUw7iJaTGitxSdQ2ObWSTrr3SUrj5Qo1CkgPXwRM3Tdoq/53JYAa2qCA== + dependencies: + pouchdb-binary-utils "7.3.0" + pouchdb-collate "7.3.0" + pouchdb-collections "7.3.0" + pouchdb-errors "7.3.0" + pouchdb-fetch "7.3.0" + pouchdb-mapreduce-utils "7.3.0" + pouchdb-md5 "7.3.0" + pouchdb-utils "7.3.0" + +pouchdb-adapter-leveldb-core@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-adapter-leveldb-core/-/pouchdb-adapter-leveldb-core-7.3.0.tgz#91fa1fbc35e744252ae73f9e88911883c1841c9a" + integrity sha512-OyUsEae1JlqR2jSGMohP03gj6VANh9fDR/3nPIa1vYyoQWlwQzOS7knKqDaJm7Nui3JC5q/lWos7/FGZBFuF5Q== + dependencies: + argsarray "0.0.1" + buffer-from "1.1.2" + double-ended-queue "2.1.0-0" + levelup "4.4.0" + pouchdb-adapter-utils "7.3.0" + pouchdb-binary-utils "7.3.0" + pouchdb-collections "7.3.0" + pouchdb-errors "7.3.0" + pouchdb-json "7.3.0" + pouchdb-md5 "7.3.0" + pouchdb-merge "7.3.0" + pouchdb-utils "7.3.0" + sublevel-pouchdb "7.3.0" + through2 "3.0.2" + +pouchdb-adapter-memory@^7.1.1: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-adapter-memory/-/pouchdb-adapter-memory-7.3.0.tgz#ddd5b9ab9d30209d066374648abc761c68444db3" + integrity sha512-nUdYi5KpbUa0uv0L3IJorpiUnIOBPxX9qplCX9i7JE8OtLPeLyKuX3WC+3M1//8Lmmxg3b1wXSNIod6FJy4wAQ== + dependencies: + memdown "1.4.1" + pouchdb-adapter-leveldb-core "7.3.0" + pouchdb-utils "7.3.0" + +pouchdb-adapter-utils@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-adapter-utils/-/pouchdb-adapter-utils-7.3.0.tgz#1747e4ea0b519a9d817c6eda0e2f0ebc3dc18c41" + integrity sha512-mU1+smcagWSpInVx/VQk7VVjjnJlyagKtusUS3OdCMFZY35L6RbXC8eIhoNVDbkBfEv3cIwqQ3t7fdvkaa1odQ== + dependencies: + pouchdb-binary-utils "7.3.0" + pouchdb-collections "7.3.0" + pouchdb-errors "7.3.0" + pouchdb-md5 "7.3.0" + pouchdb-merge "7.3.0" + pouchdb-utils "7.3.0" + +pouchdb-binary-utils@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-binary-utils/-/pouchdb-binary-utils-7.3.0.tgz#ecc235d28e7f226c168affcf53959675f78d5aaf" + integrity sha512-xvBH/XGHGcou2vkEzszJxkCc7YElfRUrkLUg51Jbdmh1mogLDUO0bU3Tj6TOIIJfRkQrU/HV+dDkMAhsil0amQ== + dependencies: + buffer-from "1.1.2" + +pouchdb-collate@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-collate/-/pouchdb-collate-7.3.0.tgz#9276de7459a21a6aded71e3090d9b5d5488be19f" + integrity sha512-ys7rXKtEr6cfghgUjknwFJiOkITebV6JmeTybJKCzMV0r2luXu0OoPQsKVpE/wbM/3F5LxfpbFKGFpPcfGMvTA== + +pouchdb-collections@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-collections/-/pouchdb-collections-7.3.0.tgz#3197dfbee8d69c3760229705fc5a73d0c8a896f1" + integrity sha512-Xr54m2+fErShXn+qAT4xwqJ+8NwddNPeTMJT4z4k1sZsrwfHmZsWbsKAyGPMF04eQaaU+7DDRMciu2VzaBUXyg== + +pouchdb-debug@^7.1.1: + version "7.2.1" + resolved "https://registry.yarnpkg.com/pouchdb-debug/-/pouchdb-debug-7.2.1.tgz#f5f869f6113c12ccb97cddf5b0a32b6e0e67e961" + integrity sha512-eP3ht/AKavLF2RjTzBM6S9gaI2/apcW6xvaKRQhEdOfiANqerFuksFqHCal3aikVQuDO+cB/cw+a4RyJn/glBw== + dependencies: + debug "3.1.0" + +pouchdb-errors@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-errors/-/pouchdb-errors-7.3.0.tgz#23bc328108778be0bfe22d69c0df67eab94aeca5" + integrity sha512-dTBbIC1BbCy6J9W/Csg5xROgb3wJN3HpbgAJHHSEtAkb8oA45KZmU3ZwEpNhf0AfPuQm4XgW1936PvlDlGgJiw== + dependencies: + inherits "2.0.4" + +pouchdb-fetch@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-fetch/-/pouchdb-fetch-7.3.0.tgz#92b5d3b067d79ecbb9a61cbd52dce36e94dbbf28" + integrity sha512-8/lcg8iMDG+GVs1dHNXA4ktJSEpH71dHU3xesMJ25tNQOqfAaaWrkfz9j71ZYDDkveLYE6UjUzl/sDacu2hSjw== + dependencies: + abort-controller "3.0.0" + fetch-cookie "0.11.0" + node-fetch "2.6.7" + +pouchdb-find@^7.0.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-find/-/pouchdb-find-7.3.0.tgz#27291c3d069f4f1a1a4913f63b1a148dac1b345b" + integrity sha512-EwhnfyxCAkKf8PG4tfndTTygEmtuz+o1LiZkxfPrflfXA3m1jo1ithib0hwBYtEwEYWuZxH6B8pRZutbLoQCGA== + dependencies: + pouchdb-abstract-mapreduce "7.3.0" + pouchdb-collate "7.3.0" + pouchdb-errors "7.3.0" + pouchdb-fetch "7.3.0" + pouchdb-md5 "7.3.0" + pouchdb-selector-core "7.3.0" + pouchdb-utils "7.3.0" + +pouchdb-json@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-json/-/pouchdb-json-7.3.0.tgz#94c2d876202c6879cb525db05e7633b926346e5d" + integrity sha512-D4wyi20ltyiFpuziQeMk3CbXs/Q58VoGTYTJQY8MWBw37OidtHGQAt1Kh5yJ435wJqDzJZyxMA5RxGZxEOBDVg== + dependencies: + vuvuzela "1.0.3" + +pouchdb-mapreduce-utils@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-mapreduce-utils/-/pouchdb-mapreduce-utils-7.3.0.tgz#21d42ea9a376b0fa2e61c8c1ac53f886ffdf3409" + integrity sha512-KDVSd+H2r+XWTrQfKWV71SknDDYRjYXoeWs0ZQl3xITHCcTl+fIgqyagg/XN+Zy/U9LeLPGMe2JdgPx9H8lJgw== + dependencies: + argsarray "0.0.1" + inherits "2.0.4" + pouchdb-collections "7.3.0" + pouchdb-utils "7.3.0" + +pouchdb-md5@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-md5/-/pouchdb-md5-7.3.0.tgz#3a094e45ccce87271530ad3f37d7e82c53562bb0" + integrity sha512-wL04QgoKyd/L/TV5gxgcvlEyCJiZoXCOEFJklTzkdza/kBQNJGPH7i0ZhKa7Sb+AvZYoWZHddf1Zgv7rBScHkA== + dependencies: + pouchdb-binary-utils "7.3.0" + spark-md5 "3.0.2" + +pouchdb-merge@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-merge/-/pouchdb-merge-7.3.0.tgz#dfde5b54aa6dd203ac62d768fe33e7bdbd56e38e" + integrity sha512-E7LmchMzwYFm6V8OBxejzARLisanpksOju2LEfuiYnotGfNDeW7MByP0qBH0/zF8BfUyyjA1cl7ByaEpsapkeQ== + +pouchdb-selector-core@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-selector-core/-/pouchdb-selector-core-7.3.0.tgz#1860afeec069ba4d5b79583b4b520dd2b643e3a3" + integrity sha512-sK/cCrIGeL9ImcMhKGcwa54+bzX7Wv4hhVV+oUW3T1Nasaoxh+Muem1GuA+x1+SbTCE8y37rUg8i6DIOhX51ew== + dependencies: + pouchdb-collate "7.3.0" + pouchdb-utils "7.3.0" + +pouchdb-utils@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb-utils/-/pouchdb-utils-7.3.0.tgz#782df5ab3309edd5dc8c0f8ae4663bf0e67962e2" + integrity sha512-HH+5IXXWn/ZgVCSnrlydBMYn6MabT7RS7SNoo9w8qVH9efpZSp3eLchw6yMQNLw8LQefWmbbskiHV9VgJmSVWQ== + dependencies: + argsarray "0.0.1" + clone-buffer "1.0.0" + immediate "3.3.0" + inherits "2.0.4" + pouchdb-collections "7.3.0" + pouchdb-errors "7.3.0" + pouchdb-md5 "7.3.0" + uuid "8.3.2" + +pouchdb@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/pouchdb/-/pouchdb-7.3.0.tgz#440fbef12dfd8f9002320802528665e883a3b7f8" + integrity sha512-OwsIQGXsfx3TrU1pLruj6PGSwFH+h5k4hGNxFkZ76Um7/ZI8F5TzUHFrpldVVIhfXYi2vP31q0q7ot1FSLFYOw== + dependencies: + abort-controller "3.0.0" + argsarray "0.0.1" + buffer-from "1.1.2" + clone-buffer "1.0.0" + double-ended-queue "2.1.0-0" + fetch-cookie "0.11.0" + immediate "3.3.0" + inherits "2.0.4" + level "6.0.1" + level-codec "9.0.2" + level-write-stream "1.0.0" + leveldown "5.6.0" + levelup "4.4.0" + ltgt "2.2.1" + node-fetch "2.6.7" + readable-stream "1.1.14" + spark-md5 "3.0.2" + through2 "3.0.2" + uuid "8.3.2" + vuvuzela "1.0.3" + +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prelude-ls@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" + integrity sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w== + +prepend-http@^1.0.1: + version "1.0.4" + resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-1.0.4.tgz#d4f4562b0ce3696e41ac52d0e002e57a635dc6dc" + integrity sha512-PhmXi5XmoyKw1Un4E+opM2KcsJInDvKyuOumcjjw3waw86ZNjHwVUOOWLc4bCzLdcKNaWBH9e99sbWzDQsVaYg== + +prepend-http@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897" + integrity sha512-ravE6m9Atw9Z/jjttRUZ+clIXogdghyZAuWJ3qEzjT+jI/dL1ifAqhZeC5VHzQp1MSt1+jxKkFNemj/iO7tVUA== + +prettier-linter-helpers@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz#d23d41fe1375646de2d0104d3454a3008802cf7b" + integrity sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w== + dependencies: + fast-diff "^1.1.2" + +prettier@^1.14.2: + version "1.19.1" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-1.19.1.tgz#f7d7f5ff8a9cd872a7be4ca142095956a60797cb" + integrity sha512-s7PoyDv/II1ObgQunCbB9PdLmUcBZcnWOcxDh7O0N/UwDEsHyqkW+Qh28jW+mVuCdx7gLB0BotYI1Y6uI9iyew== + +prettier@^2.3.0: + version "2.7.1" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.7.1.tgz#e235806850d057f97bb08368a4f7d899f7760c64" + integrity sha512-ujppO+MkdPqoVINuDFDRLClm7D78qbDt0/NR+wp5FqEZOoTNAjPHWj17QRhu7geIHJfcNhRk1XVQmF8Bp3ye+g== + +pretty-format@^22.4.3: + version "22.4.3" + resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-22.4.3.tgz#f873d780839a9c02e9664c8a082e9ee79eaac16f" + integrity sha512-S4oT9/sT6MN7/3COoOy+ZJeA92VmOnveLHgrwBE3Z1W5N9S2A1QGNYiE1z75DAENbJrXXUb+OWXhpJcg05QKQQ== + dependencies: + ansi-regex "^3.0.0" + ansi-styles "^3.2.0" + +pretty-format@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-24.9.0.tgz#12fac31b37019a4eea3c11aa9a959eb7628aa7c9" + integrity sha512-00ZMZUiHaJrNfk33guavqgvfJS30sLYf0f8+Srklv0AMPodGGHcoHgksZ3OThYnIvOd+8yMCn0YiEOogjlgsnA== + dependencies: + "@jest/types" "^24.9.0" + ansi-regex "^4.0.0" + ansi-styles "^3.2.0" + react-is "^16.8.4" + +pretty-format@^27.0.0, pretty-format@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-27.5.1.tgz#2181879fdea51a7a5851fb39d920faa63f01d88e" + integrity sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ== + dependencies: + ansi-regex "^5.0.1" + ansi-styles "^5.0.0" + react-is "^17.0.1" + +process-nextick-args@~2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" + integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== + +process@^0.11.10: + version "0.11.10" + resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" + integrity sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A== + +progress@^2.0.0: + version "2.0.3" + resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" + integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA== + +promise-polyfill@8.1.3: + version "8.1.3" + resolved "https://registry.yarnpkg.com/promise-polyfill/-/promise-polyfill-8.1.3.tgz#8c99b3cf53f3a91c68226ffde7bde81d7f904116" + integrity sha512-MG5r82wBzh7pSKDRa9y+vllNHz3e3d4CNj1PQE4BQYxLme0gKYYBm9YENq+UkEikyZ0XbiGWxYlVw3Rl9O/U8g== + +prompts@^2.0.1: + version "2.4.2" + resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.4.2.tgz#7b57e73b3a48029ad10ebd44f74b01722a4cb069" + integrity sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q== + dependencies: + kleur "^3.0.3" + sisteransi "^1.0.5" + +protobufjs@^6.8.6, protobufjs@^6.8.8, protobufjs@~6.11.2, protobufjs@~6.11.3: + version "6.11.3" + resolved "https://registry.yarnpkg.com/protobufjs/-/protobufjs-6.11.3.tgz#637a527205a35caa4f3e2a9a4a13ddffe0e7af74" + integrity sha512-xL96WDdCZYdU7Slin569tFX712BxsxslWwAfAhCYjQKGTq7dAU91Lomy6nLLhh/dyGhk/YH4TwTSRxTzhuHyZg== + dependencies: + "@protobufjs/aspromise" "^1.1.2" + "@protobufjs/base64" "^1.1.2" + "@protobufjs/codegen" "^2.0.4" + "@protobufjs/eventemitter" "^1.1.0" + "@protobufjs/fetch" "^1.1.0" + "@protobufjs/float" "^1.0.2" + "@protobufjs/inquire" "^1.1.0" + "@protobufjs/path" "^1.1.2" + "@protobufjs/pool" "^1.1.0" + "@protobufjs/utf8" "^1.1.0" + "@types/long" "^4.0.1" + "@types/node" ">=13.7.0" + long "^4.0.0" + +protobufjs@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/protobufjs/-/protobufjs-7.0.0.tgz#8c678e1351fd926178fce5a4213913e8d990974f" + integrity sha512-ffNIEm+quOcYtQvHdW406v1NQmZSuqVklxsXk076BtuFnlYZfigLU+JOMrTD8TUOyqHYbRI/fSVNvgd25YeN3w== + dependencies: + "@protobufjs/aspromise" "^1.1.2" + "@protobufjs/base64" "^1.1.2" + "@protobufjs/codegen" "^2.0.4" + "@protobufjs/eventemitter" "^1.1.0" + "@protobufjs/fetch" "^1.1.0" + "@protobufjs/float" "^1.0.2" + "@protobufjs/inquire" "^1.1.0" + "@protobufjs/path" "^1.1.2" + "@protobufjs/pool" "^1.1.0" + "@protobufjs/utf8" "^1.1.0" + "@types/long" "^4.0.1" + "@types/node" ">=13.7.0" + long "^5.0.0" + +proxy-addr@^2.0.7, proxy-addr@~2.0.7: + version "2.0.7" + resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" + integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== + dependencies: + forwarded "0.2.0" + ipaddr.js "1.9.1" + +prr@~1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/prr/-/prr-1.0.1.tgz#d3fc114ba06995a45ec6893f484ceb1d78f5f476" + integrity sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw== + +psl@^1.1.28, psl@^1.1.33: + version "1.9.0" + resolved "https://registry.yarnpkg.com/psl/-/psl-1.9.0.tgz#d0df2a137f00794565fcaf3b2c00cd09f8d5a5a7" + integrity sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag== + +pstree.remy@^1.1.8: + version "1.1.8" + resolved "https://registry.yarnpkg.com/pstree.remy/-/pstree.remy-1.1.8.tgz#c242224f4a67c21f686839bbdb4ac282b8373d3a" + integrity sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w== + +public-encrypt@^4.0.0: + version "4.0.3" + resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.3.tgz#4fcc9d77a07e48ba7527e7cbe0de33d0701331e0" + integrity sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q== + dependencies: + bn.js "^4.1.0" + browserify-rsa "^4.0.0" + create-hash "^1.1.0" + parse-asn1 "^5.0.0" + randombytes "^2.0.1" + safe-buffer "^5.1.2" + +pump@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" + integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== + dependencies: + end-of-stream "^1.1.0" + once "^1.3.1" + +punycode@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.0.tgz#5f863edc89b96db09074bad7947bf09056ca4e7d" + integrity sha512-Yxz2kRwT90aPiWEMHVYnEf4+rhwF1tBmmZ4KepCP+Wkium9JxtWnUm1nqGwpiAHr/tnTSeHqr3wb++jgSkXjhA== + +punycode@^2.1.0, punycode@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" + integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== + +pure-rand@^5.0.1: + version "5.0.3" + resolved "https://registry.yarnpkg.com/pure-rand/-/pure-rand-5.0.3.tgz#a2f15dfbc3be8433d1d8ed67ee411aa83fb90406" + integrity sha512-9N8x1h8dptBQpHyC7aZMS+iNOAm97WMGY0AFrguU1cpfW3I5jINkWe5BIY5md0ofy+1TCIELsVcm/GJXZSaPbw== + +qs@6.10.3: + version "6.10.3" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.10.3.tgz#d6cde1b2ffca87b5aa57889816c5f81535e22e8e" + integrity sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ== + dependencies: + side-channel "^1.0.4" + +qs@6.9.3: + version "6.9.3" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.9.3.tgz#bfadcd296c2d549f1dffa560619132c977f5008e" + integrity sha512-EbZYNarm6138UKKq46tdx08Yo/q9ZhFoAXAI1meAFd2GtbRDhbZY2WQSICskT0c5q99aFzLG1D4nvTk9tqfXIw== + +qs@^6.10.3, qs@^6.7.0: + version "6.11.0" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.11.0.tgz#fd0d963446f7a65e1367e01abd85429453f0c37a" + integrity sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q== + dependencies: + side-channel "^1.0.4" + +qs@~6.5.2: + version "6.5.3" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.3.tgz#3aeeffc91967ef6e35c0e488ef46fb296ab76aad" + integrity sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA== + +query-string@^5.0.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/query-string/-/query-string-5.1.1.tgz#a78c012b71c17e05f2e3fa2319dd330682efb3cb" + integrity sha512-gjWOsm2SoGlgLEdAGt7a6slVOk9mGiXmPFMqrEhLQ68rhQuBnpfs3+EmlvqKyxnCo9/PPlF+9MtY02S1aFg+Jw== + dependencies: + decode-uri-component "^0.2.0" + object-assign "^4.1.0" + strict-uri-encode "^1.0.0" + +querystringify@^2.1.1: + version "2.2.0" + resolved "https://registry.yarnpkg.com/querystringify/-/querystringify-2.2.0.tgz#3345941b4153cb9d082d8eee4cda2016a9aef7f6" + integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== + +queue-microtask@^1.2.2, queue-microtask@^1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + +quick-lru@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" + integrity sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA== + +quickswap-sdk@^3.0.8: + version "3.0.9" + resolved "https://registry.yarnpkg.com/quickswap-sdk/-/quickswap-sdk-3.0.9.tgz#905af4ed4117396beabcc836a0171124975afe93" + integrity sha512-4Txvhb4xhrkNNbsxWGguUJsUlv2LP8NUGD7rpvrlOv8FXhtvataVBv/EFAr5QAh0PrxLOuOWeo7V7BhVlT61ww== + dependencies: + "@uniswap/v2-core" "^1.0.0" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.1" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5, randombytes@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" + integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== + dependencies: + safe-buffer "^5.1.0" + +randomfill@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458" + integrity sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw== + dependencies: + randombytes "^2.0.5" + safe-buffer "^5.1.0" + +range-parser@~1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" + integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== + +range_check@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/range_check/-/range_check-2.0.4.tgz#6682e9ed16da5e84089a553028ceb5920f1111a5" + integrity sha512-aed0ocXXj+SIiNNN9b+mZWA3Ow2GXHtftOGk2xQwshK5GbEZAvUcPWNQBLTx/lPcdFRIUFlFCRtHTQNIFMqynQ== + dependencies: + ip6 "^0.2.0" + ipaddr.js "^1.9.1" + +raw-body@2.5.1, raw-body@^2.4.1: + version "2.5.1" + resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.1.tgz#fe1b1628b181b700215e5fd42389f98b71392857" + integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== + dependencies: + bytes "3.1.2" + http-errors "2.0.0" + iconv-lite "0.4.24" + unpipe "1.0.0" + +react-is@^16.8.4: + version "16.13.1" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" + integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== + +react-is@^17.0.1: + version "17.0.2" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-17.0.2.tgz#e691d4a8e9c789365655539ab372762b0efb54f0" + integrity sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w== + +react-native-url-polyfill@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/react-native-url-polyfill/-/react-native-url-polyfill-1.3.0.tgz#c1763de0f2a8c22cc3e959b654c8790622b6ef6a" + integrity sha512-w9JfSkvpqqlix9UjDvJjm1EjSt652zVQ6iwCIj1cVVkwXf4jQhQgTNXY6EVTwuAmUjg6BC6k9RHCBynoLFo3IQ== + dependencies: + whatwg-url-without-unicode "8.0.0-3" + +readable-stream@1.1.14: + version "1.1.14" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.14.tgz#7cf4c54ef648e3813084c636dd2079e166c081d9" + integrity sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.1" + isarray "0.0.1" + string_decoder "~0.10.x" + +"readable-stream@2 || 3", readable-stream@^3.1.0, readable-stream@^3.4.0, readable-stream@^3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" + integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== + dependencies: + inherits "^2.0.3" + string_decoder "^1.1.1" + util-deprecate "^1.0.1" + +readable-stream@^2.3.0, readable-stream@^2.3.5, readable-stream@~2.3.6: + version "2.3.7" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" + integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.3" + isarray "~1.0.0" + process-nextick-args "~2.0.0" + safe-buffer "~5.1.1" + string_decoder "~1.1.1" + util-deprecate "~1.0.1" + +readable-stream@~0.0.2: + version "0.0.4" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-0.0.4.tgz#f32d76e3fb863344a548d79923007173665b3b8d" + integrity sha512-azrivNydKRYt7zwLV5wWUK7YzKTWs3q87xSmY6DlHapPrCvaT6ZrukvM5erV+yCSSPmZT8zkSdttOHQpWWm9zw== + +readable-stream@~1.0.31: + version "1.0.34" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.0.34.tgz#125820e34bc842d2f2aaafafe4c2916ee32c157c" + integrity sha512-ok1qVCJuRkNmvebYikljxJA/UEsKwLl2nI1OmaqAu4/UE+h0wKCHok4XkL/gvi39OacXvw59RJUOFUkDib2rHg== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.1" + isarray "0.0.1" + string_decoder "~0.10.x" + +readdirp@~3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" + integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== + dependencies: + picomatch "^2.2.1" + +readonly-date@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/readonly-date/-/readonly-date-1.0.0.tgz#5af785464d8c7d7c40b9d738cbde8c646f97dcd9" + integrity sha512-tMKIV7hlk0h4mO3JTmmVuIlJVXjKk3Sep9Bf5OH0O+758ruuVkUy2J9SttDLm91IEX/WHlXPSpxMGjPj4beMIQ== + +redis-commands@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/redis-commands/-/redis-commands-1.7.0.tgz#15a6fea2d58281e27b1cd1acfb4b293e278c3a89" + integrity sha512-nJWqw3bTFy21hX/CPKHth6sfhZbdiHP6bTawSgQBlKOVRG7EZkfHbbHwQJnrE4vsQf0CMNE+3gJ4Fmm16vdVlQ== + +redis-errors@^1.0.0, redis-errors@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/redis-errors/-/redis-errors-1.2.0.tgz#eb62d2adb15e4eaf4610c04afe1529384250abad" + integrity sha512-1qny3OExCf0UvUV/5wpYKf2YwPcOqXzkwKKSmKHiE6ZMQs5heeE/c8eXK+PNllPvmjgAbfnsbpkGZWy8cBpn9w== + +redis-parser@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/redis-parser/-/redis-parser-3.0.0.tgz#b66d828cdcafe6b4b8a428a7def4c6bcac31c8b4" + integrity sha512-DJnGAeenTdpMEH6uAJRK/uiyEIH9WVsUmoLwzudwGJUwZPp80PDBWPHXSAGNPwNvIXAbe7MSUB1zQFugFml66A== + dependencies: + redis-errors "^1.0.0" + +redis@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/redis/-/redis-3.1.2.tgz#766851117e80653d23e0ed536254677ab647638c" + integrity sha512-grn5KoZLr/qrRQVwoSkmzdbw6pwF+/rwODtrOr6vuBRiR/f3rjSTGupbF90Zpqm2oenix8Do6RV7pYEkGwlKkw== + dependencies: + denque "^1.5.0" + redis-commands "^1.7.0" + redis-errors "^1.2.0" + redis-parser "^3.0.0" + +redux-saga@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/redux-saga/-/redux-saga-1.0.0.tgz#acb8b3ed9180fecbe75f342011d75af3ac11045b" + integrity sha512-GvJWs/SzMvEQgeaw6sRMXnS2FghlvEGsHiEtTLpJqc/FHF3I5EE/B+Hq5lyHZ8LSoT2r/X/46uWvkdCnK9WgHA== + dependencies: + "@redux-saga/core" "^1.0.0" + +redux@^3.7.2: + version "3.7.2" + resolved "https://registry.yarnpkg.com/redux/-/redux-3.7.2.tgz#06b73123215901d25d065be342eb026bc1c8537b" + integrity sha512-pNqnf9q1hI5HHZRBkj3bAngGZW/JMCmexDlOxw4XagXY2o1327nHH54LoTjiPJ0gizoqPDRqWyX/00g0hD6w+A== + dependencies: + lodash "^4.2.1" + lodash-es "^4.2.1" + loose-envify "^1.1.0" + symbol-observable "^1.0.3" + +redux@^4.0.4: + version "4.2.0" + resolved "https://registry.yarnpkg.com/redux/-/redux-4.2.0.tgz#46f10d6e29b6666df758780437651eeb2b969f13" + integrity sha512-oSBmcKKIuIR4ME29/AeNUnl5L+hvBq7OaJWzaptTQJAntaPvxIJqfnjbaEiCzzaIz+XmVILfqAM3Ob0aXLPfjA== + dependencies: + "@babel/runtime" "^7.9.2" + +ref-sdk@^0.1.4, ref-sdk@^0.1.5: + version "0.1.5" + resolved "https://registry.yarnpkg.com/ref-sdk/-/ref-sdk-0.1.5.tgz#d6e4cfca38a6f2a2433d97a930ed4eebb81de8c4" + integrity sha512-Gr40hYT+xY+rsj47s+HHejFENWkcBNELMbi67HZ8DmTyOq8VHUhXUY7gP5bMicw03jFAVU3+6jZ90iGM82IoXw== + dependencies: + "@types/big.js" "^6.1.5" + "@types/bn.js" "^5.1.1" + "@types/lodash" "^4.14.182" + big.js "^6.2.1" + mathjs "^9.3.0" + near-api-js "0.44.2" + ref-sdk "^0.1.4" + +regenerator-runtime@^0.13.10: + version "0.13.10" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.10.tgz#ed07b19616bcbec5da6274ebc75ae95634bfc2ee" + integrity sha512-KepLsg4dU12hryUO7bp/axHAKvwGOCV0sGloQtpagJ12ai+ojVDqkeGSiRX1zlq+kjIMZ1t7gpze+26QqtdGqw== + +regenerator-runtime@^0.13.11: + version "0.13.11" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz#f6dca3e7ceec20590d07ada785636a90cdca17f9" + integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg== + +regenerator-runtime@^0.13.4: + version "0.13.9" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz#8925742a98ffd90814988d7566ad30ca3b263b52" + integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== + +regex-not@^1.0.0, regex-not@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c" + integrity sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A== + dependencies: + extend-shallow "^3.0.2" + safe-regex "^1.1.0" + +regexp.prototype.flags@^1.4.3: + version "1.4.3" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz#87cab30f80f66660181a3bb7bf5981a872b367ac" + integrity sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + functions-have-names "^1.2.2" + +regexpp@^3.0.0, regexpp@^3.1.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.2.0.tgz#0425a2768d8f23bad70ca4b90461fa2f1213e1b2" + integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== + +repeat-element@^1.1.2: + version "1.1.4" + resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.4.tgz#be681520847ab58c7568ac75fbfad28ed42d39e9" + integrity sha512-LFiNfRcSu7KK3evMyYOuCzv3L10TW7yC1G2/+StMjK8Y6Vqd2MG7r/Qjw4ghtuCOjFvlnms/iMmLqpvW/ES/WQ== + +repeat-string@^1.6.1: + version "1.6.1" + resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" + integrity sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w== + +request@^2.79.0, request@^2.85.0: + version "2.88.2" + resolved "https://registry.yarnpkg.com/request/-/request-2.88.2.tgz#d73c918731cb5a87da047e207234146f664d12b3" + integrity sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw== + dependencies: + aws-sign2 "~0.7.0" + aws4 "^1.8.0" + caseless "~0.12.0" + combined-stream "~1.0.6" + extend "~3.0.2" + forever-agent "~0.6.1" + form-data "~2.3.2" + har-validator "~5.1.3" + http-signature "~1.2.0" + is-typedarray "~1.0.0" + isstream "~0.1.2" + json-stringify-safe "~5.0.1" + mime-types "~2.1.19" + oauth-sign "~0.9.0" + performance-now "^2.1.0" + qs "~6.5.2" + safe-buffer "^5.1.2" + tough-cookie "~2.5.0" + tunnel-agent "^0.6.0" + uuid "^3.3.2" + +require-directory@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" + integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q== + +require-from-string@^2.0.0, require-from-string@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" + integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== + +require-main-filename@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-1.0.1.tgz#97f717b69d48784f5f526a6c5aa8ffdda055a4d1" + integrity sha512-IqSUtOVP4ksd1C/ej5zeEh/BIP2ajqpn8c5x+q99gvcIG/Qf0cud5raVnE/Dwd0ua9TXYDoDc0RE5hBSdz22Ug== + +requires-port@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" + integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== + +reselect-tree@^1.3.7: + version "1.3.7" + resolved "https://registry.yarnpkg.com/reselect-tree/-/reselect-tree-1.3.7.tgz#c3eca58765d9df96bae0017f6ff3504c304cdea0" + integrity sha512-kZN+C1cVJ6fFN2smSb0l4UvYZlRzttgnu183svH4NrU22cBY++ikgr2QT75Uuk4MYpv5gXSVijw4c5U6cx6GKg== + dependencies: + debug "^3.1.0" + json-pointer "^0.6.1" + reselect "^4.0.0" + +reselect@^4.0.0: + version "4.1.6" + resolved "https://registry.yarnpkg.com/reselect/-/reselect-4.1.6.tgz#19ca2d3d0b35373a74dc1c98692cdaffb6602656" + integrity sha512-ZovIuXqto7elwnxyXbBtCPo9YFEr3uJqj2rRbcOOog1bmu2Ag85M4hixSwFWyaBMKXNgvPaJ9OSu9SkBPIeJHQ== + +resolve-alpn@^1.2.0: + version "1.2.1" + resolved "https://registry.yarnpkg.com/resolve-alpn/-/resolve-alpn-1.2.1.tgz#b7adbdac3546aaaec20b45e7d8265927072726f9" + integrity sha512-0a1F4l73/ZFZOakJnQ3FvkJ2+gSTQWz/r2KE5OdDY0TxPm5h4GkqkWWfM47T7HsbnOtcJVEF4epCVy6u7Q3K+g== + +resolve-cwd@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/resolve-cwd/-/resolve-cwd-3.0.0.tgz#0f0075f1bb2544766cf73ba6a6e2adfebcb13f2d" + integrity sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg== + dependencies: + resolve-from "^5.0.0" + +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + +resolve-from@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-5.0.0.tgz#c35225843df8f776df21c57557bc087e9dfdfc69" + integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw== + +resolve-url@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a" + integrity sha512-ZuF55hVUQaaczgOIwqWzkEcEidmlD/xl44x1UZnhOXcYuFN2S6+rcxpG+C1N3So0wvNI3DmJICUFfu2SxhBmvg== + +resolve.exports@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/resolve.exports/-/resolve.exports-1.1.0.tgz#5ce842b94b05146c0e03076985d1d0e7e48c90c9" + integrity sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ== + +resolve@1.17.0: + version "1.17.0" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.17.0.tgz#b25941b54968231cc2d1bb76a79cb7f2c0bf8444" + integrity sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w== + dependencies: + path-parse "^1.0.6" + +resolve@^1.10.1, resolve@^1.20.0, resolve@^1.22.0, resolve@^1.8.1: + version "1.22.1" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.1.tgz#27cb2ebb53f91abb49470a928bba7558066ac177" + integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw== + dependencies: + is-core-module "^2.9.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +responselike@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/responselike/-/responselike-1.0.2.tgz#918720ef3b631c5642be068f15ade5a46f4ba1e7" + integrity sha512-/Fpe5guzJk1gPqdJLJR5u7eG/gNY4nImjbRDaVWVMRhne55TCmj2i9Q+54PBRfatRC8v/rIiv9BN0pMd9OV5EQ== + dependencies: + lowercase-keys "^1.0.0" + +responselike@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/responselike/-/responselike-2.0.1.tgz#9a0bc8fdc252f3fb1cca68b016591059ba1422bc" + integrity sha512-4gl03wn3hj1HP3yzgdI7d3lCkF95F21Pz4BPGvKHinyQzALR5CapwC8yIi0Rh58DEMQ/SguC03wFj2k0M/mHhw== + dependencies: + lowercase-keys "^2.0.0" + +restore-cursor@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-2.0.0.tgz#9f7ee287f82fd326d4fd162923d62129eee0dfaf" + integrity sha512-6IzJLuGi4+R14vwagDHX+JrXmPVtPpn4mffDJ1UdR7/Edm87fl6yi8mMBIVvFtJaNTUvjughmW4hwLhRG7gC1Q== + dependencies: + onetime "^2.0.0" + signal-exit "^3.0.2" + +restore-cursor@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-3.1.0.tgz#39f67c54b3a7a58cea5236d95cf0034239631f7e" + integrity sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA== + dependencies: + onetime "^5.1.0" + signal-exit "^3.0.2" + +ret@~0.1.10: + version "0.1.15" + resolved "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz#b8a4825d5bdb1fc3f6f53c2bc33f81388681c7bc" + integrity sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg== + +retry@0.13.1: + version "0.13.1" + resolved "https://registry.yarnpkg.com/retry/-/retry-0.13.1.tgz#185b1587acf67919d63b357349e03537b2484658" + integrity sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg== + +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + +rimraf@^2.2.8: + version "2.7.1" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" + integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== + dependencies: + glob "^7.1.3" + +rimraf@^3.0.0, rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +rimraf@~2.4.0: + version "2.4.5" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.4.5.tgz#ee710ce5d93a8fdb856fb5ea8ff0e2d75934b2da" + integrity sha512-J5xnxTyqaiw06JjMftq7L9ouA448dw/E7dKghkP9WpKNuwmARNNg+Gk8/u5ryb9N/Yo2+z3MCwuqFK/+qPOPfQ== + dependencies: + glob "^6.0.1" + +ripemd160@^2.0.0, ripemd160@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c" + integrity sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA== + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + +rlp@^2.2.3, rlp@^2.2.4: + version "2.2.7" + resolved "https://registry.yarnpkg.com/rlp/-/rlp-2.2.7.tgz#33f31c4afac81124ac4b283e2bd4d9720b30beaf" + integrity sha512-d5gdPmgQ0Z+AklL2NVXr/IoSjNZFfTVvQWzL/AM2AOcSzYP2xjlb0AC8YyCLc41MSNf6P6QVtjgPdmVtzb+4lQ== + dependencies: + bn.js "^5.2.0" + +rpc-websockets@^7.5.0: + version "7.5.0" + resolved "https://registry.yarnpkg.com/rpc-websockets/-/rpc-websockets-7.5.0.tgz#bbeb87572e66703ff151e50af1658f98098e2748" + integrity sha512-9tIRi1uZGy7YmDjErf1Ax3wtqdSSLIlnmL5OtOzgd5eqPKbsPpwDP5whUDO2LQay3Xp0CcHlcNSGzacNRluBaQ== + dependencies: + "@babel/runtime" "^7.17.2" + eventemitter3 "^4.0.7" + uuid "^8.3.2" + ws "^8.5.0" + optionalDependencies: + bufferutil "^4.0.1" + utf-8-validate "^5.0.2" + +run-async@^2.2.0: + version "2.4.1" + resolved "https://registry.yarnpkg.com/run-async/-/run-async-2.4.1.tgz#8440eccf99ea3e70bd409d49aab88e10c189a455" + integrity sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ== + +run-parallel-limit@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/run-parallel-limit/-/run-parallel-limit-1.1.0.tgz#be80e936f5768623a38a963262d6bef8ff11e7ba" + integrity sha512-jJA7irRNM91jaKc3Hcl1npHsFLOXOoTkPCUL1JEa1R82O2miplXXRaGdjW/KM/98YQWDhJLiSs793CnXfblJUw== + dependencies: + queue-microtask "^1.2.2" + +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + +rustbn.js@~0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/rustbn.js/-/rustbn.js-0.2.0.tgz#8082cb886e707155fd1cb6f23bd591ab8d55d0ca" + integrity sha512-4VlvkRUuCJvr2J6Y0ImW7NvTCriMi7ErOAqWk1y69vAdoNIzCF3yPmgeNzx+RQTLEDFq5sHfscn1MwHxP9hNfA== + +rxjs@^6.4.0: + version "6.6.7" + resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-6.6.7.tgz#90ac018acabf491bf65044235d5863c4dab804c9" + integrity sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ== + dependencies: + tslib "^1.9.0" + +safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: + version "5.1.2" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" + integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== + +safe-buffer@5.2.1, safe-buffer@>=5.1.0, safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@^5.2.1, safe-buffer@~5.2.0: + version "5.2.1" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" + integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== + +safe-json-stringify@~1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/safe-json-stringify/-/safe-json-stringify-1.2.0.tgz#356e44bc98f1f93ce45df14bcd7c01cda86e0afd" + integrity sha512-gH8eh2nZudPQO6TytOvbxnuhYBOvDBBLW52tz5q6X58lJcd/tkmqFR+5Z9adS8aJtURSXWThWy/xJtJwixErvg== + +safe-regex@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e" + integrity sha512-aJXcif4xnaNUzvUuC5gcb46oTS7zvg4jpMTnuqtrEPlR3vFr4pxtdTwaF1Qs3Enjn9HK+ZlwQui+a7z0SywIzg== + dependencies: + ret "~0.1.10" + +safe-stable-stringify@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/safe-stable-stringify/-/safe-stable-stringify-2.3.1.tgz#ab67cbe1fe7d40603ca641c5e765cb942d04fc73" + integrity sha512-kYBSfT+troD9cDA85VDnHZ1rpHC50O0g1e6WlGHVCz/g+JS+9WKLj+XwFYyR8UbrZN8ll9HUpDAAddY58MGisg== + +"safer-buffer@>= 2.1.2 < 3", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +sax@>=0.6.0: + version "1.2.4" + resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" + integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== + +saxes@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/saxes/-/saxes-5.0.1.tgz#eebab953fa3b7608dbe94e5dadb15c888fa6696d" + integrity sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw== + dependencies: + xmlchars "^2.2.0" + +scrypt-js@2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/scrypt-js/-/scrypt-js-2.0.3.tgz#bb0040be03043da9a012a2cea9fc9f852cfc87d4" + integrity sha512-d8DzQxNivoNDogyYmb/9RD5mEQE/Q7vG2dLDUgvfPmKL9xCVzgqUntOdS0me9Cq9Sh9VxIZuoNEFcsfyXRnyUw== + +scrypt-js@2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/scrypt-js/-/scrypt-js-2.0.4.tgz#32f8c5149f0797672e551c07e230f834b6af5f16" + integrity sha512-4KsaGcPnuhtCZQCxFxN3GVYIhKFPTdLd8PLC552XwbMndtD0cjRFAhDuuydXQ0h08ZfPgzqe6EKHozpuH74iDw== + +scrypt-js@3.0.1, scrypt-js@^3.0.0, scrypt-js@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/scrypt-js/-/scrypt-js-3.0.1.tgz#d314a57c2aef69d1ad98a138a21fe9eafa9ee312" + integrity sha512-cdwTTnqPu0Hyvf5in5asVdZocVDTNRmR7XEcJuIzMjJeSHybHl7vpB66AzwTaIg6CLSbtjcxc8fqcySfnTkccA== + +"scrypt-shim@github:web3-js/scrypt-shim": + version "0.1.0" + resolved "https://codeload.github.com/web3-js/scrypt-shim/tar.gz/aafdadda13e660e25e1c525d1f5b2443f5eb1ebb" + dependencies: + scryptsy "^2.1.0" + semver "^6.3.0" + +scryptsy@2.1.0, scryptsy@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/scryptsy/-/scryptsy-2.1.0.tgz#8d1e8d0c025b58fdd25b6fa9a0dc905ee8faa790" + integrity sha512-1CdSqHQowJBnMAFyPEBRfqag/YP9OF394FV+4YREIJX4ljD7OxvQRDayyoyyCk+senRjSkP6VnUNQmVQqB6g7w== + +secp256k1@4.0.3, secp256k1@^4.0.1, secp256k1@^4.0.2: + version "4.0.3" + resolved "https://registry.yarnpkg.com/secp256k1/-/secp256k1-4.0.3.tgz#c4559ecd1b8d3c1827ed2d1b94190d69ce267303" + integrity sha512-NLZVf+ROMxwtEj3Xa562qgv2BK5e2WNmXPiOdVIPLgs6lyTzMvBq0aWTYMI5XCP9jZMVKOcqZLw/Wc4vDkuxhA== + dependencies: + elliptic "^6.5.4" + node-addon-api "^2.0.0" + node-gyp-build "^4.2.0" + +secp256k1@^3.0.1: + version "3.8.0" + resolved "https://registry.yarnpkg.com/secp256k1/-/secp256k1-3.8.0.tgz#28f59f4b01dbee9575f56a47034b7d2e3b3b352d" + integrity sha512-k5ke5avRZbtl9Tqx/SA7CbY3NF6Ro+Sj9cZxezFzuBlLDmyqPiL8hJJ+EmzD8Ig4LUDByHJ3/iPOVoRixs/hmw== + dependencies: + bindings "^1.5.0" + bip66 "^1.1.5" + bn.js "^4.11.8" + create-hash "^1.2.0" + drbg.js "^1.0.1" + elliptic "^6.5.2" + nan "^2.14.0" + safe-buffer "^5.1.2" + +seedrandom@^3.0.5: + version "3.0.5" + resolved "https://registry.yarnpkg.com/seedrandom/-/seedrandom-3.0.5.tgz#54edc85c95222525b0c7a6f6b3543d8e0b3aa0a7" + integrity sha512-8OwmbklUNzwezjGInmZ+2clQmExQPvomqjL7LFqOYqtmuxRgQYqOD3mHaU+MvZn5FLUeVxVfQjwLZW/n/JFuqg== + +seek-bzip@^1.0.5: + version "1.0.6" + resolved "https://registry.yarnpkg.com/seek-bzip/-/seek-bzip-1.0.6.tgz#35c4171f55a680916b52a07859ecf3b5857f21c4" + integrity sha512-e1QtP3YL5tWww8uKaOCQ18UxIT2laNBXHjV/S2WYCiK4udiv8lkG89KRIoCjUagnAmCBurjF4zEVX2ByBbnCjQ== + dependencies: + commander "^2.8.1" + +semaphore-async-await@^1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/semaphore-async-await/-/semaphore-async-await-1.5.1.tgz#857bef5e3644601ca4b9570b87e9df5ca12974fa" + integrity sha512-b/ptP11hETwYWpeilHXXQiV5UJNJl7ZWWooKRE5eBIYWoom6dZ0SluCIdCtKycsMtZgKWE01/qAw6jblw1YVhg== + +semver@6.2.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.2.0.tgz#4d813d9590aaf8a9192693d6c85b9344de5901db" + integrity sha512-jdFC1VdUGT/2Scgbimf7FSx9iJLXoqfglSF+gJeuNWVpiE37OIbc1jywR/GJyFdz3mnkz2/id0L0J/cr0izR5A== + +semver@7.3.7, semver@7.x, semver@^7.2.1, semver@^7.3.2, semver@^7.3.5, semver@^7.3.7: + version "7.3.7" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.7.tgz#12c5b649afdbf9049707796e22a4028814ce523f" + integrity sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g== + dependencies: + lru-cache "^6.0.0" + +semver@^5.5.0, semver@^5.5.1, semver@^5.7.1: + version "5.7.1" + resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" + integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== + +semver@^6.0.0, semver@^6.1.0, semver@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" + integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== + +semver@~7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.0.0.tgz#5f3ca35761e47e05b206c6daff2cf814f0316b8e" + integrity sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A== + +send@0.18.0: + version "0.18.0" + resolved "https://registry.yarnpkg.com/send/-/send-0.18.0.tgz#670167cc654b05f5aa4a767f9113bb371bc706be" + integrity sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg== + dependencies: + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + fresh "0.5.2" + http-errors "2.0.0" + mime "1.6.0" + ms "2.1.3" + on-finished "2.4.1" + range-parser "~1.2.1" + statuses "2.0.1" + +sentence-case@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/sentence-case/-/sentence-case-2.1.1.tgz#1f6e2dda39c168bf92d13f86d4a918933f667ed4" + integrity sha512-ENl7cYHaK/Ktwk5OTD+aDbQ3uC8IByu/6Bkg+HDv8Mm+XnBnppVNalcfJTNsp1ibstKh030/JKQQWglDvtKwEQ== + dependencies: + no-case "^2.2.0" + upper-case-first "^1.1.2" + +serialize-javascript@6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.0.tgz#efae5d88f45d7924141da8b5c3a7a7e663fefeb8" + integrity sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag== + dependencies: + randombytes "^2.1.0" + +serve-static@1.15.0: + version "1.15.0" + resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.15.0.tgz#faaef08cffe0a1a62f60cad0c4e513cff0ac9540" + integrity sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g== + dependencies: + encodeurl "~1.0.2" + escape-html "~1.0.3" + parseurl "~1.3.3" + send "0.18.0" + +servify@^0.1.12: + version "0.1.12" + resolved "https://registry.yarnpkg.com/servify/-/servify-0.1.12.tgz#142ab7bee1f1d033b66d0707086085b17c06db95" + integrity sha512-/xE6GvsKKqyo1BAY+KxOWXcLpPsUUyji7Qg3bVD7hh1eRze5bR1uYiuDA/k3Gof1s9BTzQZEJK8sNcNGFIzeWw== + dependencies: + body-parser "^1.16.0" + cors "^2.8.1" + express "^4.14.0" + request "^2.79.0" + xhr "^2.3.3" + +set-blocking@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" + integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== + +set-value@^2.0.0, set-value@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b" + integrity sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw== + dependencies: + extend-shallow "^2.0.1" + is-extendable "^0.1.1" + is-plain-object "^2.0.3" + split-string "^3.0.1" + +setimmediate@1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.4.tgz#20e81de622d4a02588ce0c8da8973cbcf1d3138f" + integrity sha512-/TjEmXQVEzdod/FFskf3o7oOAsGhHf2j1dZqRFbDzq4F3mvvxflIIi4Hd3bLQE9y/CpwqfSQam5JakI/mi3Pog== + +setimmediate@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" + integrity sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA== + +setprototypeof@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" + integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== + +sha.js@^2.4.0, sha.js@^2.4.11, sha.js@^2.4.8: + version "2.4.11" + resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.11.tgz#37a5cf0b81ecbc6943de109ba2960d1b26584ae7" + integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +shallowequal@^1.0.2: + version "1.1.0" + resolved "https://registry.yarnpkg.com/shallowequal/-/shallowequal-1.1.0.tgz#188d521de95b9087404fd4dcb68b13df0ae4e7f8" + integrity sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ== + +shebang-command@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea" + integrity sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg== + dependencies: + shebang-regex "^1.0.0" + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" + integrity sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ== + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +side-channel@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" + integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== + dependencies: + call-bind "^1.0.0" + get-intrinsic "^1.0.2" + object-inspect "^1.9.0" + +signal-exit@^3.0.0, signal-exit@^3.0.2, signal-exit@^3.0.3: + version "3.0.7" + resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" + integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== + +simple-concat@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/simple-concat/-/simple-concat-1.0.1.tgz#f46976082ba35c2263f1c8ab5edfe26c41c9552f" + integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== + +simple-get@^2.7.0: + version "2.8.2" + resolved "https://registry.yarnpkg.com/simple-get/-/simple-get-2.8.2.tgz#5708fb0919d440657326cd5fe7d2599d07705019" + integrity sha512-Ijd/rV5o+mSBBs4F/x9oDPtTx9Zb6X9brmnXvMW4J7IR15ngi9q5xxqWBKU744jTZiaXtxaPL7uHG6vtN8kUkw== + dependencies: + decompress-response "^3.3.0" + once "^1.3.1" + simple-concat "^1.0.0" + +simple-git@^1.110.0: + version "1.132.0" + resolved "https://registry.yarnpkg.com/simple-git/-/simple-git-1.132.0.tgz#53ac4c5ec9e74e37c2fd461e23309f22fcdf09b1" + integrity sha512-xauHm1YqCTom1sC9eOjfq3/9RKiUA9iPnxBbrY2DdL8l4ADMu0jjM5l5lphQP5YWNqAL2aXC/OeuQ76vHtW5fg== + dependencies: + debug "^4.0.1" + +simple-swizzle@^0.2.2: + version "0.2.2" + resolved "https://registry.yarnpkg.com/simple-swizzle/-/simple-swizzle-0.2.2.tgz#a4da6b635ffcccca33f70d17cb92592de95e557a" + integrity sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg== + dependencies: + is-arrayish "^0.3.1" + +simple-update-notifier@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/simple-update-notifier/-/simple-update-notifier-1.0.7.tgz#7edf75c5bdd04f88828d632f762b2bc32996a9cc" + integrity sha512-BBKgR84BJQJm6WjWFMHgLVuo61FBDSj1z/xSFUIozqO6wO7ii0JxCqlIud7Enr/+LhlbNI0whErq96P2qHNWew== + dependencies: + semver "~7.0.0" + +sisteransi@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" + integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg== + +slash@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-2.0.0.tgz#de552851a1759df3a8f206535442f5ec4ddeab44" + integrity sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A== + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +slice-ansi@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-4.0.0.tgz#500e8dd0fd55b05815086255b3195adf2a45fe6b" + integrity sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ== + dependencies: + ansi-styles "^4.0.0" + astral-regex "^2.0.0" + is-fullwidth-code-point "^3.0.0" + +snake-case@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/snake-case/-/snake-case-2.1.0.tgz#41bdb1b73f30ec66a04d4e2cad1b76387d4d6d9f" + integrity sha512-FMR5YoPFwOLuh4rRz92dywJjyKYZNLpMn1R5ujVpIYkbA9p01fq8RMg0FkO4M+Yobt4MjHeLTJVm5xFFBHSV2Q== + dependencies: + no-case "^2.2.0" + +snake-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/snake-case/-/snake-case-3.0.4.tgz#4f2bbd568e9935abdfd593f34c691dadb49c452c" + integrity sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg== + dependencies: + dot-case "^3.0.4" + tslib "^2.0.3" + +snapdragon-node@^2.0.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b" + integrity sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw== + dependencies: + define-property "^1.0.0" + isobject "^3.0.0" + snapdragon-util "^3.0.1" + +snapdragon-util@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz#f956479486f2acd79700693f6f7b805e45ab56e2" + integrity sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ== + dependencies: + kind-of "^3.2.0" + +snapdragon@^0.8.1: + version "0.8.2" + resolved "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz#64922e7c565b0e14204ba1aa7d6964278d25182d" + integrity sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg== + dependencies: + base "^0.11.1" + debug "^2.2.0" + define-property "^0.2.5" + extend-shallow "^2.0.1" + map-cache "^0.2.2" + source-map "^0.5.6" + source-map-resolve "^0.5.0" + use "^3.1.0" + +solc-wrapper@^0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/solc-wrapper/-/solc-wrapper-0.6.3.tgz#3230f9665bf8dce9fbe5a1517bd81b96c605e3a3" + integrity sha512-FWBnuQfU537SVSsBxuE4XkOKcK88a/bpLMVde2gc3BZcj0VmPc38wYO0Hkqqxsek7ZLK2lmXuEDLmgXhXl8Kyw== + dependencies: + command-exists "^1.2.8" + fs-extra "^0.30.0" + js-sha3 "0.8.0" + memorystream "^0.3.1" + require-from-string "^2.0.0" + semver "^5.5.0" + tmp "0.0.33" + +solc@0.7.3: + version "0.7.3" + resolved "https://registry.yarnpkg.com/solc/-/solc-0.7.3.tgz#04646961bd867a744f63d2b4e3c0701ffdc7d78a" + integrity sha512-GAsWNAjGzIDg7VxzP6mPjdurby3IkGCjQcM8GFYZT6RyaoUZKmMU6Y7YwG+tFGhv7dwZ8rmR4iwFDrrD99JwqA== + dependencies: + command-exists "^1.2.8" + commander "3.0.2" + follow-redirects "^1.12.1" + fs-extra "^0.30.0" + js-sha3 "0.8.0" + memorystream "^0.3.1" + require-from-string "^2.0.0" + semver "^5.5.0" + tmp "0.0.33" + +source-map-resolve@^0.5.0: + version "0.5.3" + resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a" + integrity sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw== + dependencies: + atob "^2.1.2" + decode-uri-component "^0.2.0" + resolve-url "^0.2.1" + source-map-url "^0.4.0" + urix "^0.1.0" + +source-map-support@^0.5.13, source-map-support@^0.5.6: + version "0.5.21" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" + integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map-url@^0.4.0: + version "0.4.1" + resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.1.tgz#0af66605a745a5a2f91cf1bbf8a7afbc283dec56" + integrity sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw== + +source-map@^0.5.6: + version "0.5.7" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" + integrity sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ== + +source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" + integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== + +source-map@^0.7.3: + version "0.7.4" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.4.tgz#a9bbe705c9d8846f4e08ff6765acf0f1b0898656" + integrity sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA== + +spark-md5@3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/spark-md5/-/spark-md5-3.0.2.tgz#7952c4a30784347abcee73268e473b9c0167e3fc" + integrity sha512-wcFzz9cDfbuqe0FZzfi2or1sgyIrsDwmPwfZC4hiNidPdPINjeUwNfv5kldczoEAcjl9Y1L3SM7Uz2PUEQzxQw== + +spinnies@^0.3.0: + version "0.3.2" + resolved "https://registry.yarnpkg.com/spinnies/-/spinnies-0.3.2.tgz#693d85cdaa095e253b13a8dc0dc8808cef23d678" + integrity sha512-WOvGI8X3h2XbAu/VBzIG99qJTeWCZ5RjyZtuLc4Q6qwAIv1/OPA2aL9j5wYEhwNsWLbBDHH5bLk/bOJTpexljw== + dependencies: + chalk "^2.4.2" + cli-cursor "^3.0.0" + +spinnies@^0.4.2: + version "0.4.3" + resolved "https://registry.yarnpkg.com/spinnies/-/spinnies-0.4.3.tgz#2ea0ad148e78353ddf621dec3951a6f4c3cbf66e" + integrity sha512-TTA2vWXrXJpfThWAl2t2hchBnCMI1JM5Wmb2uyI7Zkefdw/xO98LDy6/SBYwQPiYXL3swx3Eb44ZxgoS8X5wpA== + dependencies: + chalk "^2.4.2" + cli-cursor "^3.0.0" + strip-ansi "^5.2.0" + +split-string@^3.0.1, split-string@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz#7cb09dda3a86585705c64b39a6466038682e8fe2" + integrity sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw== + dependencies: + extend-shallow "^3.0.0" + +sprintf-js@~1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" + integrity sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g== + +sshpk@^1.7.0: + version "1.17.0" + resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.17.0.tgz#578082d92d4fe612b13007496e543fa0fbcbe4c5" + integrity sha512-/9HIEs1ZXGhSPE8X6Ccm7Nam1z8KcoCqPdI7ecm1N33EzAetWahvQWVqLZtaZQ+IDKX4IyA2o0gBzqIMkAagHQ== + dependencies: + asn1 "~0.2.3" + assert-plus "^1.0.0" + bcrypt-pbkdf "^1.0.0" + dashdash "^1.12.0" + ecc-jsbn "~0.1.1" + getpass "^0.1.1" + jsbn "~0.1.0" + safer-buffer "^2.0.2" + tweetnacl "~0.14.0" + +stack-trace@0.0.x: + version "0.0.10" + resolved "https://registry.yarnpkg.com/stack-trace/-/stack-trace-0.0.10.tgz#547c70b347e8d32b4e108ea1a2a159e5fdde19c0" + integrity sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg== + +stack-utils@^1.0.1: + version "1.0.5" + resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-1.0.5.tgz#a19b0b01947e0029c8e451d5d61a498f5bb1471b" + integrity sha512-KZiTzuV3CnSnSvgMRrARVCj+Ht7rMbauGDK0LdVFRGyenwdylpajAp4Q0i6SX8rEmbTpMMf6ryq2gb8pPq2WgQ== + dependencies: + escape-string-regexp "^2.0.0" + +stack-utils@^2.0.3: + version "2.0.5" + resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.5.tgz#d25265fca995154659dbbfba3b49254778d2fdd5" + integrity sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA== + dependencies: + escape-string-regexp "^2.0.0" + +stacktrace-parser@^0.1.10: + version "0.1.10" + resolved "https://registry.yarnpkg.com/stacktrace-parser/-/stacktrace-parser-0.1.10.tgz#29fb0cae4e0d0b85155879402857a1639eb6051a" + integrity sha512-KJP1OCML99+8fhOHxwwzyWrlUuVX5GQ0ZpJTd1DFXhdkrvg1szxfHhawXUZ3g9TkXORQd4/WG68jMlQZ2p8wlg== + dependencies: + type-fest "^0.7.1" + +static-extend@^0.1.1: + version "0.1.2" + resolved "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz#60809c39cbff55337226fd5e0b520f341f1fb5c6" + integrity sha512-72E9+uLc27Mt718pMHt9VMNiAL4LMsmDbBva8mxWUCkT07fSzEGMYUCk0XWY6lp0j6RBAG4cJ3mWuZv2OE3s0g== + dependencies: + define-property "^0.2.5" + object-copy "^0.1.0" + +stats-lite@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/stats-lite/-/stats-lite-2.2.0.tgz#278a5571fa1d2e8b1691295dccc0235282393bbf" + integrity sha512-/Kz55rgUIv2KP2MKphwYT/NCuSfAlbbMRv2ZWw7wyXayu230zdtzhxxuXXcvsc6EmmhS8bSJl3uS1wmMHFumbA== + dependencies: + isnumber "~1.0.0" + +statuses@2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" + integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== + +"statuses@>= 1.5.0 < 2": + version "1.5.0" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" + integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA== + +stream-blackhole@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/stream-blackhole/-/stream-blackhole-1.0.3.tgz#6fc2e2c2e9d9fde6be8c68d3db88de09802e4d63" + integrity sha512-7NWl3dkmCd12mPkEwTbBPGxwvxj7L4O9DTjJudn02Fmk9K+RuPaDF8zeGo3kmjbsffU5E1aGpZ1dTR9AaRg6AQ== + +strict-uri-encode@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz#279b225df1d582b1f54e65addd4352e18faa0713" + integrity sha512-R3f198pcvnB+5IpnBlRkphuE9n46WyVl8I39W/ZUTZLz4nqSP/oLYUrcnJrw462Ds8he4YKMov2efsTIw1BDGQ== + +string-length@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/string-length/-/string-length-4.0.2.tgz#a8a8dc7bd5c1a82b9b3c8b87e125f66871b6e57a" + integrity sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ== + dependencies: + char-regex "^1.0.2" + strip-ansi "^6.0.0" + +string-width@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" + integrity sha512-0XsVpQLnVCXHJfyEs8tC0zpTVIr5PKKsQtkT29IwupnPTjtPmQ3xT/4yCREF9hYkV/3M3kzcUTSAZT6a6h81tw== + dependencies: + code-point-at "^1.0.0" + is-fullwidth-code-point "^1.0.0" + strip-ansi "^3.0.0" + +string-width@^2.0.0, string-width@^2.1.0, string-width@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" + integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== + dependencies: + is-fullwidth-code-point "^2.0.0" + strip-ansi "^4.0.0" + +string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: + version "4.2.3" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" + integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== + dependencies: + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.1" + +string.prototype.trimend@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.5.tgz#914a65baaab25fbdd4ee291ca7dde57e869cb8d0" + integrity sha512-I7RGvmjV4pJ7O3kdf+LXFpVfdNOxtCW/2C8f6jNiW4+PQchwxkCDzlk1/7p+Wl4bqFIZeF47qAHXLuHHWKAxog== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.19.5" + +string.prototype.trimstart@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.5.tgz#5466d93ba58cfa2134839f81d7f42437e8c01fef" + integrity sha512-THx16TJCGlsN0o6dl2o6ncWUsdgnLRSA23rRE5pyGBw/mLr3Ej/R2LaqCtgP8VNMGZsvMWnf9ooZPyY2bHvUFg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.19.5" + +string_decoder@^1.1.1: + version "1.3.0" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" + integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== + dependencies: + safe-buffer "~5.2.0" + +string_decoder@~0.10.x: + version "0.10.31" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" + integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== + +string_decoder@~1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" + integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== + dependencies: + safe-buffer "~5.1.0" + +strip-ansi@^3.0.0, strip-ansi@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" + integrity sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg== + dependencies: + ansi-regex "^2.0.0" + +strip-ansi@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" + integrity sha512-4XaJ2zQdCzROZDivEVIDPkcQn8LMFSa8kj8Gxb/Lnwzv9A8VctNZ+lfivC/sV3ivW8ElJTERXZoPBRrZKkNKow== + dependencies: + ansi-regex "^3.0.0" + +strip-ansi@^5.0.0, strip-ansi@^5.1.0, strip-ansi@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" + integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== + dependencies: + ansi-regex "^4.1.0" + +strip-ansi@^6.0.0, strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + +strip-bom@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" + integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== + +strip-bom@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-4.0.0.tgz#9c3505c1db45bcedca3d9cf7a16f5c5aa3901878" + integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== + +strip-dirs@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/strip-dirs/-/strip-dirs-2.1.0.tgz#4987736264fc344cf20f6c34aca9d13d1d4ed6c5" + integrity sha512-JOCxOeKLm2CAS73y/U4ZeZPTkE+gNVCzKt7Eox84Iej1LT/2pTWYpZKJuxwQpvX1LiZb1xokNR7RLfuBAa7T3g== + dependencies: + is-natural-number "^4.0.1" + +strip-eof@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf" + integrity sha512-7FCwGGmx8mD5xQd3RPUvnSpUXHM3BWuzjtpD4TXsfcZ9EL4azvVVUscFYwD9nx8Kh+uCBC00XBtAykoMHwTh8Q== + +strip-final-newline@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" + integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== + +strip-hex-prefix@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz#0c5f155fef1151373377de9dbb588da05500e36f" + integrity sha512-q8d4ue7JGEiVcypji1bALTos+0pWtyGlivAWyPuTkHzuTCJqrK9sWxYQZUq6Nq3cuyv3bm734IhHvHtGGURU6A== + dependencies: + is-hex-prefixed "1.0.0" + +strip-json-comments@3.1.1, strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +sublevel-pouchdb@7.3.0: + version "7.3.0" + resolved "https://registry.yarnpkg.com/sublevel-pouchdb/-/sublevel-pouchdb-7.3.0.tgz#d27138c34d98c3d5c8c3ee85c1662add3ad04525" + integrity sha512-zp7u4jmv2N/s+dXZkWTtL4BjREs3SZ1nGBNNJ8RWX4yqN59oHgKmti4CfVOqfsAW9RMasmTqQAEPxL9hX8+CIA== + dependencies: + inherits "2.0.4" + level-codec "9.0.2" + ltgt "2.2.1" + readable-stream "1.1.14" + +superagent@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/superagent/-/superagent-8.0.0.tgz#2ea4587df4b81ef023ec01ebc6e1bcb9e2344cb6" + integrity sha512-iudipXEel+SzlP9y29UBWGDjB+Zzag+eeA1iLosaR2YHBRr1Q1kC29iBrF2zIVD9fqVbpZnXkN/VJmwFMVyNWg== + dependencies: + component-emitter "^1.3.0" + cookiejar "^2.1.3" + debug "^4.3.4" + fast-safe-stringify "^2.1.1" + form-data "^4.0.0" + formidable "^2.0.1" + methods "^1.1.2" + mime "2.6.0" + qs "^6.10.3" + readable-stream "^3.6.0" + semver "^7.3.7" + +superstruct@^0.10.12: + version "0.10.13" + resolved "https://registry.yarnpkg.com/superstruct/-/superstruct-0.10.13.tgz#705535a5598ff231bd976601a7b6b534a71a821b" + integrity sha512-W4SitSZ9MOyMPbHreoZVEneSZyPEeNGbdfJo/7FkJyRs/M3wQRFzq+t3S/NBwlrFSWdx1ONLjLb9pB+UKe4IqQ== + +superstruct@^0.14.2: + version "0.14.2" + resolved "https://registry.yarnpkg.com/superstruct/-/superstruct-0.14.2.tgz#0dbcdf3d83676588828f1cf5ed35cda02f59025b" + integrity sha512-nPewA6m9mR3d6k7WkZ8N8zpTWfenFH3q9pA2PkuiZxINr9DKB2+40wEQf0ixn8VaGuJ78AB6iWOtStI+/4FKZQ== + +supertest@^6.1.6: + version "6.2.4" + resolved "https://registry.yarnpkg.com/supertest/-/supertest-6.2.4.tgz#3dcebe42f7fd6f28dd7ac74c6cba881f7101b2f0" + integrity sha512-M8xVnCNv+q2T2WXVzxDECvL2695Uv2uUj2O0utxsld/HRyJvOU8W9f1gvsYxSNU4wmIe0/L/ItnpU4iKq0emDA== + dependencies: + methods "^1.1.2" + superagent "^8.0.0" + +supports-color@4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-4.4.0.tgz#883f7ddabc165142b2a61427f3352ded195d1a3e" + integrity sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ== + dependencies: + has-flag "^2.0.0" + +supports-color@5.4.0: + version "5.4.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.4.0.tgz#1c6b337402c2137605efe19f10fec390f6faab54" + integrity sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w== + dependencies: + has-flag "^3.0.0" + +supports-color@8.1.1, supports-color@^8.0.0: + version "8.1.1" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" + integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== + dependencies: + has-flag "^4.0.0" + +supports-color@^5.3.0, supports-color@^5.5.0: + version "5.5.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" + integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== + dependencies: + has-flag "^3.0.0" + +supports-color@^7.0.0, supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-hyperlinks@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz#4f77b42488765891774b70c79babd87f9bd594bb" + integrity sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ== + dependencies: + has-flag "^4.0.0" + supports-color "^7.0.0" + +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + +swagger-ui-dist@>=4.1.3: + version "4.14.0" + resolved "https://registry.yarnpkg.com/swagger-ui-dist/-/swagger-ui-dist-4.14.0.tgz#e34d807464eb84578c43902e393084a1a6fbda52" + integrity sha512-TBzhheU15s+o54Cgk9qxuYcZMiqSm/SkvKnapoGHOF66kz0Y5aGjpzj5BT/vpBbn6rTPJ9tUYXQxuDWfsjiGMw== + +swagger-ui-express@^4.1.6: + version "4.3.0" + resolved "https://registry.yarnpkg.com/swagger-ui-express/-/swagger-ui-express-4.3.0.tgz#226238ab231f7718f9109d63a66efc3a795618dd" + integrity sha512-jN46SEEe9EoXa3ZgZoKgnSF6z0w3tnM1yqhO4Y+Q4iZVc8JOQB960EZpIAz6rNROrDApVDwcMHR0mhlnc/5Omw== + dependencies: + swagger-ui-dist ">=4.1.3" + +swap-case@^1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/swap-case/-/swap-case-1.1.2.tgz#c39203a4587385fad3c850a0bd1bcafa081974e3" + integrity sha512-BAmWG6/bx8syfc6qXPprof3Mn5vQgf5dwdUNJhsNqU9WdPt5P+ES/wQ5bxfijy8zwZgZZHslC3iAsxsuQMCzJQ== + dependencies: + lower-case "^1.1.1" + upper-case "^1.1.1" + +swarm-js@0.1.39: + version "0.1.39" + resolved "https://registry.yarnpkg.com/swarm-js/-/swarm-js-0.1.39.tgz#79becb07f291d4b2a178c50fee7aa6e10342c0e8" + integrity sha512-QLMqL2rzF6n5s50BptyD6Oi0R1aWlJC5Y17SRIVXRj6OR1DRIPM7nepvrxxkjA1zNzFz6mUOMjfeqeDaWB7OOg== + dependencies: + bluebird "^3.5.0" + buffer "^5.0.5" + decompress "^4.0.0" + eth-lib "^0.1.26" + fs-extra "^4.0.2" + got "^7.1.0" + mime-types "^2.1.16" + mkdirp-promise "^5.0.1" + mock-fs "^4.1.0" + setimmediate "^1.0.5" + tar "^4.0.2" + xhr-request-promise "^0.1.2" + +swarm-js@^0.1.40: + version "0.1.40" + resolved "https://registry.yarnpkg.com/swarm-js/-/swarm-js-0.1.40.tgz#b1bc7b6dcc76061f6c772203e004c11997e06b99" + integrity sha512-yqiOCEoA4/IShXkY3WKwP5PvZhmoOOD8clsKA7EEcRILMkTEYHCQ21HDCAcVpmIxZq4LyZvWeRJ6quIyHk1caA== + dependencies: + bluebird "^3.5.0" + buffer "^5.0.5" + eth-lib "^0.1.26" + fs-extra "^4.0.2" + got "^7.1.0" + mime-types "^2.1.16" + mkdirp-promise "^5.0.1" + mock-fs "^4.1.0" + setimmediate "^1.0.5" + tar "^4.0.2" + xhr-request "^1.0.1" + +symbol-observable@^1.0.3: + version "1.2.0" + resolved "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.2.0.tgz#c22688aed4eab3cdc2dfeacbb561660560a00804" + integrity sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ== + +symbol-observable@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-2.0.3.tgz#5b521d3d07a43c351055fa43b8355b62d33fd16a" + integrity sha512-sQV7phh2WCYAn81oAkakC5qjq2Ml0g8ozqz03wOGnx9dDlG1de6yrF+0RAzSJD8fPUow3PTSMf2SAbOGxb93BA== + +symbol-tree@^3.2.4: + version "3.2.4" + resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" + integrity sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw== + +table@^6.0.9: + version "6.8.0" + resolved "https://registry.yarnpkg.com/table/-/table-6.8.0.tgz#87e28f14fa4321c3377ba286f07b79b281a3b3ca" + integrity sha512-s/fitrbVeEyHKFa7mFdkuQMWlH1Wgw/yEXMt5xACT4ZpzWFluehAxRtUUQKPuWhaLAWhFcVx6w3oC8VKaUfPGA== + dependencies: + ajv "^8.0.1" + lodash.truncate "^4.4.2" + slice-ansi "^4.0.0" + string-width "^4.2.3" + strip-ansi "^6.0.1" + +tar-stream@^1.5.2: + version "1.6.2" + resolved "https://registry.yarnpkg.com/tar-stream/-/tar-stream-1.6.2.tgz#8ea55dab37972253d9a9af90fdcd559ae435c555" + integrity sha512-rzS0heiNf8Xn7/mpdSVVSMAWAoy9bfb1WOTYC78Z0UQKeKa/CWS8FOq0lKGNa8DWKAn9gxjCvMLYc5PGXYlK2A== + dependencies: + bl "^1.0.0" + buffer-alloc "^1.2.0" + end-of-stream "^1.0.0" + fs-constants "^1.0.0" + readable-stream "^2.3.0" + to-buffer "^1.1.1" + xtend "^4.0.0" + +tar@^4.0.2: + version "4.4.19" + resolved "https://registry.yarnpkg.com/tar/-/tar-4.4.19.tgz#2e4d7263df26f2b914dee10c825ab132123742f3" + integrity sha512-a20gEsvHnWe0ygBY8JbxoM4w3SJdhc7ZAuxkLqh+nvNQN2IOt0B5lLgM490X5Hl8FF0dl0tOf2ewFYAlIFgzVA== + dependencies: + chownr "^1.1.4" + fs-minipass "^1.2.7" + minipass "^2.9.0" + minizlib "^1.3.3" + mkdirp "^0.5.5" + safe-buffer "^5.2.1" + yallist "^3.1.1" + +terminal-link@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/terminal-link/-/terminal-link-2.1.1.tgz#14a64a27ab3c0df933ea546fba55f2d078edc994" + integrity sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ== + dependencies: + ansi-escapes "^4.2.1" + supports-hyperlinks "^2.0.0" + +test-exclude@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-6.0.0.tgz#04a8698661d805ea6fa293b6cb9e63ac044ef15e" + integrity sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w== + dependencies: + "@istanbuljs/schema" "^0.1.2" + glob "^7.1.4" + minimatch "^3.0.4" + +test-value@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/test-value/-/test-value-2.1.0.tgz#11da6ff670f3471a73b625ca4f3fdcf7bb748291" + integrity sha512-+1epbAxtKeXttkGFMTX9H42oqzOTufR1ceCF+GYA5aOmvaPq9wd4PUS8329fn2RRLGNeUkgRLnVpycjx8DsO2w== + dependencies: + array-back "^1.0.3" + typical "^2.6.0" + +text-encoding-utf-8@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/text-encoding-utf-8/-/text-encoding-utf-8-1.0.2.tgz#585b62197b0ae437e3c7b5d0af27ac1021e10d13" + integrity sha512-8bw4MY9WjdsD2aMtO0OzOCY3pXGYNx2d2FfHRVUKkiCPDWjKuOlhLVASS+pD7VkLTVjW268LYJHwsnPFlBpbAg== + +text-encoding@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/text-encoding/-/text-encoding-0.7.0.tgz#f895e836e45990624086601798ea98e8f36ee643" + integrity sha512-oJQ3f1hrOnbRLOcwKz0Liq2IcrvDeZRHXhd9RgLrsT+DjWY/nty1Hi7v3dtkaEYbPYe0mUoOfzRrMwfXXwgPUA== + +text-hex@1.0.x: + version "1.0.0" + resolved "https://registry.yarnpkg.com/text-hex/-/text-hex-1.0.0.tgz#69dc9c1b17446ee79a92bf5b884bb4b9127506f5" + integrity sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg== + +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + +throat@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/throat/-/throat-6.0.1.tgz#d514fedad95740c12c2d7fc70ea863eb51ade375" + integrity sha512-8hmiGIJMDlwjg7dlJ4yKGLK8EsYqKgPWbG3b4wjJddKNwc7N7Dpn08Df4szr/sZdMVeOstrdYSsqzX6BYbcB+w== + +through2@3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/through2/-/through2-3.0.2.tgz#99f88931cfc761ec7678b41d5d7336b5b6a07bf4" + integrity sha512-enaDQ4MUyP2W6ZyT6EsMzqBPZaM/avg8iuo+l2d3QCs0J+6RaqkHV/2/lOwDTueBHeJ/2LG9lrLW3d5rWPucuQ== + dependencies: + inherits "^2.0.4" + readable-stream "2 || 3" + +through2@^2.0.1: + version "2.0.5" + resolved "https://registry.yarnpkg.com/through2/-/through2-2.0.5.tgz#01c1e39eb31d07cb7d03a96a70823260b23132cd" + integrity sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ== + dependencies: + readable-stream "~2.3.6" + xtend "~4.0.1" + +"through@>=2.2.7 <3", through@^2.3.6, through@^2.3.8: + version "2.3.8" + resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" + integrity sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg== + +timed-out@^4.0.0, timed-out@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/timed-out/-/timed-out-4.0.1.tgz#f32eacac5a175bea25d7fab565ab3ed8741ef56f" + integrity sha512-G7r3AhovYtr5YKOWQkta8RKAPb+J9IsO4uVmzjl8AZwfhs8UcUwTiD6gcJYSgOtzyjvQKrKYn41syHbUWMkafA== + +tiny-emitter@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tiny-emitter/-/tiny-emitter-2.1.0.tgz#1d1a56edfc51c43e863cbb5382a72330e3555423" + integrity sha512-NB6Dk1A9xgQPMoGqC5CVXn123gWyte215ONT5Pp5a0yt4nlEoO1ZWeCwpncaekPHXO60i47ihFnZPiRPjRMq4Q== + +tiny-invariant@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/tiny-invariant/-/tiny-invariant-1.2.0.tgz#a1141f86b672a9148c72e978a19a73b9b94a15a9" + integrity sha512-1Uhn/aqw5C6RI4KejVeTg6mIS7IqxnLJ8Mv2tV5rTc0qWobay7pDUz6Wi392Cnc8ak1H0F2cjoRzb2/AW4+Fvg== + +tiny-typed-emitter@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tiny-typed-emitter/-/tiny-typed-emitter-2.1.0.tgz#b3b027fdd389ff81a152c8e847ee2f5be9fad7b5" + integrity sha512-qVtvMxeXbVej0cQWKqVSSAHmKZEHAvxdF8HEUBFWts8h+xEo5m/lEiPakuyZ3BnCBjOD8i24kzNOiOLLgsSxhA== + +tiny-warning@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/tiny-warning/-/tiny-warning-1.0.3.tgz#94a30db453df4c643d0fd566060d60a875d84754" + integrity sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA== + +title-case@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/title-case/-/title-case-2.1.1.tgz#3e127216da58d2bc5becf137ab91dae3a7cd8faa" + integrity sha512-EkJoZ2O3zdCz3zJsYCsxyq2OC5hrxR9mfdd5I+w8h/tmFfeOxJ+vvkxsKxdmN0WtS9zLdHEgfgVOiMVgv+Po4Q== + dependencies: + no-case "^2.2.0" + upper-case "^1.0.3" + +tmp@0.0.33, tmp@^0.0.33: + version "0.0.33" + resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz#6d34335889768d21b2bcda0aa277ced3b1bfadf9" + integrity sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw== + dependencies: + os-tmpdir "~1.0.2" + +tmpl@1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.5.tgz#8683e0b902bb9c20c4f726e3c0b69f36518c07cc" + integrity sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw== + +to-buffer@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/to-buffer/-/to-buffer-1.1.1.tgz#493bd48f62d7c43fcded313a03dcadb2e1213a80" + integrity sha512-lx9B5iv7msuFYE3dytT+KE5tap+rNYw+K4jVkb9R/asAb+pbBSM17jtunHplhBe6RRJdZx3Pn2Jph24O32mOVg== + +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" + integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== + +to-object-path@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz#297588b7b0e7e0ac08e04e672f85c1f4999e17af" + integrity sha512-9mWHdnGRuh3onocaHzukyvCZhzvr6tiflAy/JRFXcJX0TjgfWA9pk9t8CMbzmBE4Jfw58pXbkngtBtqYxzNEyg== + dependencies: + kind-of "^3.0.2" + +to-readable-stream@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/to-readable-stream/-/to-readable-stream-1.0.0.tgz#ce0aa0c2f3df6adf852efb404a783e77c0475771" + integrity sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q== + +to-regex-range@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz#7c80c17b9dfebe599e27367e0d4dd5590141db38" + integrity sha512-ZZWNfCjUokXXDGXFpZehJIkZqq91BcULFq/Pi7M5i4JnxXdhMKAK682z8bCW3o8Hj1wuuzoKcW3DfVzaP6VuNg== + dependencies: + is-number "^3.0.0" + repeat-string "^1.6.1" + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +to-regex@^3.0.1, to-regex@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz#13cfdd9b336552f30b51f33a8ae1b42a7a7599ce" + integrity sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw== + dependencies: + define-property "^2.0.2" + extend-shallow "^3.0.2" + regex-not "^1.0.2" + safe-regex "^1.1.0" + +toformat@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/toformat/-/toformat-2.0.0.tgz#7a043fd2dfbe9021a4e36e508835ba32056739d8" + integrity sha512-03SWBVop6nU8bpyZCx7SodpYznbZF5R4ljwNLBcTQzKOD9xuihRo/psX58llS1BMFhhAI08H3luot5GoXJz2pQ== + +toidentifier@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" + integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== + +toml@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/toml/-/toml-3.0.0.tgz#342160f1af1904ec9d204d03a5d61222d762c5ee" + integrity sha512-y/mWCZinnvxjTKYhJ+pYxwD0mRLVvOtdS2Awbgxln6iEnt4rk0yBxeSBHkGJcPucRiG0e55mwWp+g/05rsrd6w== + +toposort@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/toposort/-/toposort-2.0.2.tgz#ae21768175d1559d48bef35420b2f4962f09c330" + integrity sha512-0a5EOkAUp8D4moMi2W8ZF8jcga7BgZd91O/yabJCFY8az+XSzeGyTKs0Aoo897iV1Nj6guFq8orWDS96z91oGg== + +touch@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/touch/-/touch-3.1.0.tgz#fe365f5f75ec9ed4e56825e0bb76d24ab74af83b" + integrity sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA== + dependencies: + nopt "~1.0.10" + +"tough-cookie@^2.3.3 || ^3.0.1 || ^4.0.0": + version "4.1.2" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.1.2.tgz#e53e84b85f24e0b65dd526f46628db6c85f6b874" + integrity sha512-G9fqXWoYFZgTc2z8Q5zaHy/vJMjm+WV0AkAeHxVCQiEB1b+dGvWzFW6QV07cY5jQ5gRkeid2qIkzkxUnmoQZUQ== + dependencies: + psl "^1.1.33" + punycode "^2.1.1" + universalify "^0.2.0" + url-parse "^1.5.3" + +tough-cookie@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4" + integrity sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg== + dependencies: + psl "^1.1.33" + punycode "^2.1.1" + universalify "^0.1.2" + +tough-cookie@~2.5.0: + version "2.5.0" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2" + integrity sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g== + dependencies: + psl "^1.1.28" + punycode "^2.1.1" + +tr46@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-2.1.0.tgz#fa87aa81ca5d5941da8cbf1f9b749dc969a4e240" + integrity sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw== + dependencies: + punycode "^2.1.1" + +tr46@~0.0.3: + version "0.0.3" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" + integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== + +traverse-chain@~0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/traverse-chain/-/traverse-chain-0.1.0.tgz#61dbc2d53b69ff6091a12a168fd7d433107e40f1" + integrity sha512-up6Yvai4PYKhpNp5PkYtx50m3KbwQrqDwbuZP/ItyL64YEWHAvH6Md83LFLV/GRSk/BoUVwwgUzX6SOQSbsfAg== + +triple-beam@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/triple-beam/-/triple-beam-1.3.0.tgz#a595214c7298db8339eeeee083e4d10bd8cb8dd9" + integrity sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw== + +"true-case-path@^2.2.1": + version "2.2.1" + resolved "https://registry.yarnpkg.com/true-case-path/-/true-case-path-2.2.1.tgz#c5bf04a5bbec3fd118be4084461b3a27c4d796bf" + integrity sha512-0z3j8R7MCjy10kc/g+qg7Ln3alJTodw9aDuVWZa3uiWqfuBMKeAeP2ocWcxoyM3D73yz3Jt/Pu4qPr4wHSdB/Q== + +truffle-config@1.1.16: + version "1.1.16" + resolved "https://registry.yarnpkg.com/truffle-config/-/truffle-config-1.1.16.tgz#366ec223165953c77852437e00f01ed8921a77a2" + integrity sha512-of9wKDjXAKIA4kpdQbxnSxRl4EOPi6ipkoOn01J3yC1UJ942jeyLm7hUrTRdxcL8Nz3G47xO+xTMX5T7UYbdTA== + dependencies: + configstore "^4.0.0" + find-up "^2.1.0" + lodash "^4.17.13" + original-require "1.0.1" + truffle-error "^0.0.5" + truffle-provider "^0.1.12" + +truffle-error@^0.0.5: + version "0.0.5" + resolved "https://registry.yarnpkg.com/truffle-error/-/truffle-error-0.0.5.tgz#6b5740c9f3aac74f47b85d654fff7fe2c1fc5e0e" + integrity sha512-JpzPLMPSCE0vaZ3vH5NO5u42GpMj/Y1SRBkQ6b69PSw3xMSH1umApN32cEcg1nnh8q5FNYc5FnKu0m4tiBffyQ== + +truffle-flattener@^1.4.0, truffle-flattener@^1.4.4: + version "1.6.0" + resolved "https://registry.yarnpkg.com/truffle-flattener/-/truffle-flattener-1.6.0.tgz#abb64488b711e6cca0a9d3e449f6a85e35964c5d" + integrity sha512-scS5Bsi4CZyvlrmD4iQcLHTiG2RQFUXVheTgWeH6PuafmI+Lk5U87Es98loM3w3ImqC9/fPHq+3QIXbcPuoJ1Q== + dependencies: + "@resolver-engine/imports-fs" "^0.2.2" + "@solidity-parser/parser" "^0.14.1" + find-up "^2.1.0" + mkdirp "^1.0.4" + tsort "0.0.1" + +truffle-hdwallet-provider@^1.0.17: + version "1.0.17" + resolved "https://registry.yarnpkg.com/truffle-hdwallet-provider/-/truffle-hdwallet-provider-1.0.17.tgz#fe8edd0d6974eeb31af9959e41525fb19abd74ca" + integrity sha512-s6DvSP83jiIAc6TUcpr7Uqnja1+sLGJ8og3X7n41vfyC4OCaKmBtXL5HOHf+SsU3iblOvnbFDgmN6Y1VBL/fsg== + dependencies: + any-promise "^1.3.0" + bindings "^1.3.1" + web3 "1.2.1" + websocket "^1.0.28" + +truffle-interface-adapter@^0.2.5: + version "0.2.5" + resolved "https://registry.yarnpkg.com/truffle-interface-adapter/-/truffle-interface-adapter-0.2.5.tgz#aa0bee635517b4a8e06adcdc99eacb993e68c243" + integrity sha512-EL39OpP8FcZ99ne1Rno3jImfb92Nectd4iVsZzoEUCBfbwHe7sr0k+i45guoruSoP8nMUE81Mov2s8I5pi6d9Q== + dependencies: + bn.js "^4.11.8" + ethers "^4.0.32" + lodash "^4.17.13" + web3 "1.2.1" + +truffle-provider@^0.1.12: + version "0.1.16" + resolved "https://registry.yarnpkg.com/truffle-provider/-/truffle-provider-0.1.16.tgz#05db46a4bda9b7e6503f8701f2b03ccb1e6c78ba" + integrity sha512-3d5WqSKIzZcpgW44mdfF97s+Tgh2a/3Ly6vHJirBV9OZDUtiAzP6WVnlRNvmlDJXFCDqt6Yb9qQWoXFHbYoR6w== + dependencies: + "@truffle/error" "^0.0.6" + truffle-interface-adapter "^0.2.5" + web3 "1.2.1" + +truffle@^5.1.41: + version "5.6.2" + resolved "https://registry.yarnpkg.com/truffle/-/truffle-5.6.2.tgz#69650bdc75ecef93cf96776116320ad782578571" + integrity sha512-xWcjQeG/xEXvtS+PcHAShleG5I6IO5YP4IYW5eA0scJO6F0wqaq5ZaU88NMqpFeopTB/neFwaHdvYKX/sfNQIQ== + dependencies: + "@truffle/db-loader" "^0.2.2" + "@truffle/debugger" "^11.0.13" + app-module-path "^2.2.0" + ganache "7.4.4" + mocha "9.2.2" + original-require "^1.0.1" + optionalDependencies: + "@truffle/db" "^2.0.2" + +ts-essentials@^1.0.0: + version "1.0.4" + resolved "https://registry.yarnpkg.com/ts-essentials/-/ts-essentials-1.0.4.tgz#ce3b5dade5f5d97cf69889c11bf7d2da8555b15a" + integrity sha512-q3N1xS4vZpRouhYHDPwO0bDW3EZ6SK9CrrDHxi/D6BPReSjpVgWIOpLS2o0gSBZm+7q/wyKp6RVM1AeeW7uyfQ== + +ts-generator@^0.0.8: + version "0.0.8" + resolved "https://registry.yarnpkg.com/ts-generator/-/ts-generator-0.0.8.tgz#7bd48ca064db026d9520bcb682b69efc20971d6a" + integrity sha512-Gi+aZCELpVL7Mqb+GuMgM+n8JZ/arZZib1iD/R9Ok8JDjOCOCrqS9b1lr72ku7J45WeDCFZxyJoRsiQvhokCnw== + dependencies: + "@types/mkdirp" "^0.5.2" + "@types/prettier" "^1.13.2" + "@types/resolve" "^0.0.8" + chalk "^2.4.1" + glob "^7.1.2" + mkdirp "^0.5.1" + prettier "^1.14.2" + resolve "^1.8.1" + ts-essentials "^1.0.0" + +ts-jest@^27.0.5: + version "27.1.5" + resolved "https://registry.yarnpkg.com/ts-jest/-/ts-jest-27.1.5.tgz#0ddf1b163fbaae3d5b7504a1e65c914a95cff297" + integrity sha512-Xv6jBQPoBEvBq/5i2TeSG9tt/nqkbpcurrEG1b+2yfBrcJelOZF9Ml6dmyMh7bcW9JyFbRYpR5rxROSlBLTZHA== + dependencies: + bs-logger "0.x" + fast-json-stable-stringify "2.x" + jest-util "^27.0.0" + json5 "2.x" + lodash.memoize "4.x" + make-error "1.x" + semver "7.x" + yargs-parser "20.x" + +ts-node@^10.0.0: + version "10.9.1" + resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.9.1.tgz#e73de9102958af9e1f0b168a6ff320e25adcff4b" + integrity sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw== + dependencies: + "@cspotcode/source-map-support" "^0.8.0" + "@tsconfig/node10" "^1.0.7" + "@tsconfig/node12" "^1.0.7" + "@tsconfig/node14" "^1.0.0" + "@tsconfig/node16" "^1.0.2" + acorn "^8.4.1" + acorn-walk "^8.1.1" + arg "^4.1.0" + create-require "^1.1.0" + diff "^4.0.1" + make-error "^1.1.1" + v8-compile-cache-lib "^3.0.1" + yn "3.1.1" + +tsconfig-paths@^3.14.1: + version "3.14.1" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.14.1.tgz#ba0734599e8ea36c862798e920bcf163277b137a" + integrity sha512-fxDhWnFSLt3VuTwtvJt5fpwxBHg5AdKWMsgcPOOIilyjymcYVZoCQF8fvFRezCNfblEXmi+PcM1eYHeOAgXCOQ== + dependencies: + "@types/json5" "^0.0.29" + json5 "^1.0.1" + minimist "^1.2.6" + strip-bom "^3.0.0" + +tslib@^1.11.1, tslib@^1.8.1, tslib@^1.9.0, tslib@^1.9.3: + version "1.14.1" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tslib@^2.0.3, tslib@^2.1.0, tslib@^2.3.1, tslib@^2.4.0, tslib@~2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.4.0.tgz#7cecaa7f073ce680a05847aa77be941098f36dc3" + integrity sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ== + +tsort@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/tsort/-/tsort-0.0.1.tgz#e2280f5e817f8bf4275657fd0f9aebd44f5a2786" + integrity sha512-Tyrf5mxF8Ofs1tNoxA13lFeZ2Zrbd6cKbuH3V+MQ5sb6DtBj5FjrXVsRWT8YvNAQTqNoz66dz1WsbigI22aEnw== + +tsutils@^3.21.0: + version "3.21.0" + resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" + integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== + dependencies: + tslib "^1.8.1" + +tunnel-agent@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" + integrity sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w== + dependencies: + safe-buffer "^5.0.1" + +tweetnacl-util@^0.15.1: + version "0.15.1" + resolved "https://registry.yarnpkg.com/tweetnacl-util/-/tweetnacl-util-0.15.1.tgz#b80fcdb5c97bcc508be18c44a4be50f022eea00b" + integrity sha512-RKJBIj8lySrShN4w6i/BonWp2Z/uxwC3h4y7xsRrpP59ZboCd0GpEVsOnMDYLMmKBpYhb5TgHzZXy7wTfYFBRw== + +tweetnacl@^0.14.3, tweetnacl@~0.14.0: + version "0.14.5" + resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" + integrity sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA== + +tweetnacl@^1.0.0, tweetnacl@^1.0.1, tweetnacl@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-1.0.3.tgz#ac0af71680458d8a6378d0d0d050ab1407d35596" + integrity sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw== + +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + +type-check@~0.3.2: + version "0.3.2" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72" + integrity sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg== + dependencies: + prelude-ls "~1.1.2" + +type-detect@4.0.8: + version "4.0.8" + resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" + integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== + +type-fest@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" + integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== + +type-fest@^0.21.3: + version "0.21.3" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37" + integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== + +type-fest@^0.7.1: + version "0.7.1" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.7.1.tgz#8dda65feaf03ed78f0a3f9678f1869147f7c5c48" + integrity sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg== + +type-is@~1.6.18: + version "1.6.18" + resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" + integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== + dependencies: + media-typer "0.3.0" + mime-types "~2.1.24" + +type@^1.0.1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/type/-/type-1.2.0.tgz#848dd7698dafa3e54a6c479e759c4bc3f18847a0" + integrity sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg== + +type@^2.5.0: + version "2.7.2" + resolved "https://registry.yarnpkg.com/type/-/type-2.7.2.tgz#2376a15a3a28b1efa0f5350dcf72d24df6ef98d0" + integrity sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw== + +typechain-target-truffle@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/typechain-target-truffle/-/typechain-target-truffle-1.0.2.tgz#52ecbd8b7a854960567ad223660d60fcb42eaa17" + integrity sha512-XF3Iq2IzR+Pqvx6fcKIKGXNEk3lEcY24vYv9VqoVPfPB6vUM09PRLJCeLm1/ag6Pr2PICKUA0f4Es+YTR3ESKA== + dependencies: + lodash "^4.17.15" + +typechain-target-web3-v1@^1.0.1: + version "1.0.4" + resolved "https://registry.yarnpkg.com/typechain-target-web3-v1/-/typechain-target-web3-v1-1.0.4.tgz#0157359e534737c07fc62529d5d8570a2047a2da" + integrity sha512-jQ6eCfY7QorBq6kQDjSy5LMuImZGkp6IXR6FXZp7/ulITIxAfb6Dxh+yvh0NN/zboLnMPvvSJi6tHWCqlwfSDA== + dependencies: + lodash "^4.17.15" + web3 "^1.2.4" + +typechain@^1.0.3: + version "1.0.5" + resolved "https://registry.yarnpkg.com/typechain/-/typechain-1.0.5.tgz#797899d9dbce54a83b3aef04ce1727ddf07d2138" + integrity sha512-gbQmJXPKuYQ0p3tK+dMhpdQql/UPtSnkPQXw2QM/aqwCengI86z2vEM2e5rVQpmk/blFx1PYNdApSDxE12rR1Q== + dependencies: + command-line-args "^4.0.7" + debug "^3.0.1" + fs-extra "^7.0.0" + js-sha3 "^0.8.0" + lodash "^4.17.15" + ts-generator "^0.0.8" + +typed-function@^2.0.0, typed-function@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/typed-function/-/typed-function-2.1.0.tgz#ded6f8a442ba8749ff3fe75bc41419c8d46ccc3f" + integrity sha512-bctQIOqx2iVbWGDGPWwIm18QScpu2XRmkC19D8rQGFsjKSgteq/o1hTZvIG/wuDq8fanpBDrLkLq+aEN/6y5XQ== + +typed-function@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/typed-function/-/typed-function-3.0.0.tgz#42f75ffdd7dd63bf5dcc950847138f2bb65f1ad3" + integrity sha512-mKJKkt2xYxJUuMD7jyfgUxfn5KCsCxkEKBVjep5yYellJJ5aEDO2QUAmIGdvcZmfQnIrplkzELIaG+5b1475qg== + +typedarray-to-buffer@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" + integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== + dependencies: + is-typedarray "^1.0.0" + +typescript-compare@^0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/typescript-compare/-/typescript-compare-0.0.2.tgz#7ee40a400a406c2ea0a7e551efd3309021d5f425" + integrity sha512-8ja4j7pMHkfLJQO2/8tut7ub+J3Lw2S3061eJLFQcvs3tsmJKp8KG5NtpLn7KcY2w08edF74BSVN7qJS0U6oHA== + dependencies: + typescript-logic "^0.0.0" + +typescript-logic@^0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/typescript-logic/-/typescript-logic-0.0.0.tgz#66ebd82a2548f2b444a43667bec120b496890196" + integrity sha512-zXFars5LUkI3zP492ls0VskH3TtdeHCqu0i7/duGt60i5IGPIpAHE/DWo5FqJ6EjQ15YKXrt+AETjv60Dat34Q== + +typescript-tuple@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/typescript-tuple/-/typescript-tuple-2.2.1.tgz#7d9813fb4b355f69ac55032e0363e8bb0f04dad2" + integrity sha512-Zcr0lbt8z5ZdEzERHAMAniTiIKerFCMgd7yjq1fPnDJ43et/k9twIFQMUYff9k5oXcsQ0WpvFcgzK2ZKASoW6Q== + dependencies: + typescript-compare "^0.0.2" + +typescript@^4.3.2: + version "4.7.4" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.7.4.tgz#1a88596d1cf47d59507a1bcdfb5b9dfe4d488235" + integrity sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ== + +typical@^2.6.0, typical@^2.6.1: + version "2.6.1" + resolved "https://registry.yarnpkg.com/typical/-/typical-2.6.1.tgz#5c080e5d661cbbe38259d2e70a3c7253e873881d" + integrity sha512-ofhi8kjIje6npGozTip9Fr8iecmYfEbS06i0JnIg+rh51KakryWF4+jX8lLKZVhy6N+ID45WYSFCxPOdTWCzNg== + +u3@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/u3/-/u3-0.1.1.tgz#5f52044f42ee76cd8de33148829e14528494b73b" + integrity sha512-+J5D5ir763y+Am/QY6hXNRlwljIeRMZMGs0cT6qqZVVzzT3X3nFPXVyPOFRMOR4kupB0T8JnCdpWdp6Q/iXn3w== + +ultron@~1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ultron/-/ultron-1.1.1.tgz#9fe1536a10a664a65266a1e3ccf85fd36302bc9c" + integrity sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og== + +unbox-primitive@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" + integrity sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw== + dependencies: + call-bind "^1.0.2" + has-bigints "^1.0.2" + has-symbols "^1.0.3" + which-boxed-primitive "^1.0.2" + +unbzip2-stream@^1.0.9: + version "1.4.3" + resolved "https://registry.yarnpkg.com/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz#b0da04c4371311df771cdc215e87f2130991ace7" + integrity sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg== + dependencies: + buffer "^5.2.1" + through "^2.3.8" + +undefsafe@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.5.tgz#38733b9327bdcd226db889fb723a6efd162e6e2c" + integrity sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA== + +underscore@1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/underscore/-/underscore-1.9.1.tgz#06dce34a0e68a7babc29b365b8e74b8925203961" + integrity sha512-5/4etnCkd9c8gwgowi5/om/mYO5ajCaOgdzj/oW+0eQV9WxKBDZw5+ycmKmeaTXjInS/W0BzpGLo2xR2aBwZdg== + +underscore@^1.9.1: + version "1.13.4" + resolved "https://registry.yarnpkg.com/underscore/-/underscore-1.13.4.tgz#7886b46bbdf07f768e0052f1828e1dcab40c0dee" + integrity sha512-BQFnUDuAQ4Yf/cYY5LNrK9NCJFKriaRbD9uR1fTeXnBeoa97W0i41qkZfGO9pSo8I5KzjAcSY2XYtdf0oKd7KQ== + +undici@^5.4.0: + version "5.8.1" + resolved "https://registry.yarnpkg.com/undici/-/undici-5.8.1.tgz#511d43ff6be02f84ec2513ae7f4b07c589319272" + integrity sha512-iDRmWX4Zar/4A/t+1LrKQRm102zw2l9Wgat3LtTlTn8ykvMZmAmpq9tjyHEigx18FsY7IfATvyN3xSw9BDz0eA== + +unfetch@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/unfetch/-/unfetch-4.2.0.tgz#7e21b0ef7d363d8d9af0fb929a5555f6ef97a3be" + integrity sha512-F9p7yYCn6cIW9El1zi0HI6vqpeIvBsr3dSuRO6Xuppb1u5rXpCPmMvLSyECLhybr9isec8Ohl0hPekMVrEinDA== + +union-value@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz#0b6fe7b835aecda61c6ea4d4f02c14221e109847" + integrity sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg== + dependencies: + arr-union "^3.1.0" + get-value "^2.0.6" + is-extendable "^0.1.1" + set-value "^2.0.1" + +unique-string@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-1.0.0.tgz#9e1057cca851abb93398f8b33ae187b99caec11a" + integrity sha512-ODgiYu03y5g76A1I9Gt0/chLCzQjvzDy7DsZGsLOE/1MrF6wriEskSncj1+/C58Xk/kPZDppSctDybCwOSaGAg== + dependencies: + crypto-random-string "^1.0.0" + +universalify@^0.1.0, universalify@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" + integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== + +universalify@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.2.0.tgz#6451760566fa857534745ab1dde952d1b1761be0" + integrity sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg== + +universalify@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" + integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== + +unorm@^1.3.3: + version "1.6.0" + resolved "https://registry.yarnpkg.com/unorm/-/unorm-1.6.0.tgz#029b289661fba714f1a9af439eb51d9b16c205af" + integrity sha512-b2/KCUlYZUeA7JFUuRJZPUtr4gZvBh7tavtv4fvk4+KV9pfGiR6CQAQAWl49ZpR3ts2dk4FYkP7EIgDJoiOLDA== + +unpipe@1.0.0, unpipe@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" + integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== + +unset-value@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559" + integrity sha512-PcA2tsuGSF9cnySLHTLSh2qrQiJ70mn+r+Glzxv2TWZblxsxCC52BDlZoPCsz7STd9pN7EZetkWZBAvk4cgZdQ== + dependencies: + has-value "^0.3.1" + isobject "^3.0.0" + +untildify@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/untildify/-/untildify-4.0.0.tgz#2bc947b953652487e4600949fb091e3ae8cd919b" + integrity sha512-KK8xQ1mkzZeg9inewmFVDNkg3l5LUhoq9kN6iWYB/CC9YMG8HA+c1Q8HwDe6dEX7kErrEVNVBO3fWsVq5iDgtw== + +update-browserslist-db@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.5.tgz#be06a5eedd62f107b7c19eb5bcefb194411abf38" + integrity sha512-dteFFpCyvuDdr9S/ff1ISkKt/9YZxKjI9WlRR99c180GaztJtRa/fn18FdxGVKVsnPY7/a/FDN68mcvUmP4U7Q== + dependencies: + escalade "^3.1.1" + picocolors "^1.0.0" + +upper-case-first@^1.1.0, upper-case-first@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/upper-case-first/-/upper-case-first-1.1.2.tgz#5d79bedcff14419518fd2edb0a0507c9b6859115" + integrity sha512-wINKYvI3Db8dtjikdAqoBbZoP6Q+PZUyfMR7pmwHzjC2quzSkUq5DmPrTtPEqHaz8AGtmsB4TqwapMTM1QAQOQ== + dependencies: + upper-case "^1.1.1" + +upper-case@^1.0.3, upper-case@^1.1.0, upper-case@^1.1.1, upper-case@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/upper-case/-/upper-case-1.1.3.tgz#f6b4501c2ec4cdd26ba78be7222961de77621598" + integrity sha512-WRbjgmYzgXkCV7zNVpy5YgrHgbBv126rMALQQMrmzOVC4GM2waQ9x7xtm8VU+1yF2kWyPzI9zbZ48n4vSxwfSA== + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +urix@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72" + integrity sha512-Am1ousAhSLBeB9cG/7k7r2R0zj50uDRlZHPGbazid5s9rlF1F/QKYObEKSIunSjIOkJZqwRRLpvewjEkM7pSqg== + +url-parse-lax@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/url-parse-lax/-/url-parse-lax-1.0.0.tgz#7af8f303645e9bd79a272e7a14ac68bc0609da73" + integrity sha512-BVA4lR5PIviy2PMseNd2jbFQ+jwSwQGdJejf5ctd1rEXt0Ypd7yanUK9+lYechVlN5VaTJGsu2U/3MDDu6KgBA== + dependencies: + prepend-http "^1.0.1" + +url-parse-lax@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/url-parse-lax/-/url-parse-lax-3.0.0.tgz#16b5cafc07dbe3676c1b1999177823d6503acb0c" + integrity sha512-NjFKA0DidqPa5ciFcSrXnAltTtzz84ogy+NebPvfEgAck0+TNg4UJ4IN+fB7zRZfbgUf0syOo9MDxFkDSMuFaQ== + dependencies: + prepend-http "^2.0.0" + +url-parse@^1.5.3: + version "1.5.10" + resolved "https://registry.yarnpkg.com/url-parse/-/url-parse-1.5.10.tgz#9d3c2f736c1d75dd3bd2be507dcc111f1e2ea9c1" + integrity sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ== + dependencies: + querystringify "^2.1.1" + requires-port "^1.0.0" + +url-set-query@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/url-set-query/-/url-set-query-1.0.0.tgz#016e8cfd7c20ee05cafe7795e892bd0702faa339" + integrity sha512-3AChu4NiXquPfeckE5R5cGdiHCMWJx1dwCWOmWIL4KHAziJNOFIYJlpGFeKDvwLPHovZRCxK3cYlwzqI9Vp+Gg== + +url-to-options@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/url-to-options/-/url-to-options-1.0.1.tgz#1505a03a289a48cbd7a434efbaeec5055f5633a9" + integrity sha512-0kQLIzG4fdk/G5NONku64rSH/x32NOA39LVQqlK8Le6lvTF6GGRJpqaQFGgU+CLwySIqBSMdwYM0sYcW9f6P4A== + +use@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f" + integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ== + +utf-8-validate@5.0.7: + version "5.0.7" + resolved "https://registry.yarnpkg.com/utf-8-validate/-/utf-8-validate-5.0.7.tgz#c15a19a6af1f7ad9ec7ddc425747ca28c3644922" + integrity sha512-vLt1O5Pp+flcArHGIyKEQq883nBt8nN8tVBcoL0qUXj2XT1n7p70yGIq2VK98I5FdZ1YHc0wk/koOnHjnXWk1Q== + dependencies: + node-gyp-build "^4.3.0" + +utf-8-validate@^5.0.2: + version "5.0.9" + resolved "https://registry.yarnpkg.com/utf-8-validate/-/utf-8-validate-5.0.9.tgz#ba16a822fbeedff1a58918f2a6a6b36387493ea3" + integrity sha512-Yek7dAy0v3Kl0orwMlvi7TPtiCNrdfHNd7Gcc/pLq4BLXqfAmd0J7OWMizUQnTTJsyjKn02mU7anqwfmUP4J8Q== + dependencies: + node-gyp-build "^4.3.0" + +utf8@3.0.0, utf8@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/utf8/-/utf8-3.0.0.tgz#f052eed1364d696e769ef058b183df88c87f69d1" + integrity sha512-E8VjFIQ/TyQgp+TZfS6l8yp/xWppSAHzidGiRrqe4bK4XP9pTRyKFgGJpO3SN7zdX4DeomTrwaseCHovfpFcqQ== + +util-deprecate@^1.0.1, util-deprecate@~1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" + integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== + +util@^0.12.0: + version "0.12.4" + resolved "https://registry.yarnpkg.com/util/-/util-0.12.4.tgz#66121a31420df8f01ca0c464be15dfa1d1850253" + integrity sha512-bxZ9qtSlGUWSOy9Qa9Xgk11kSslpuZwaxCg4sNIDj6FLucDab2JxnHwyNTCpHMtK1MjoQiWQ6DiUMZYbSrO+Sw== + dependencies: + inherits "^2.0.3" + is-arguments "^1.0.4" + is-generator-function "^1.0.7" + is-typed-array "^1.1.3" + safe-buffer "^5.1.2" + which-typed-array "^1.1.2" + +utils-merge@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" + integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= + +uuid@2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-2.0.1.tgz#c2a30dedb3e535d72ccf82e343941a50ba8533ac" + integrity sha512-nWg9+Oa3qD2CQzHIP4qKUqwNfzKn8P0LtFhotaCTFchsV7ZfDhAybeip/HZVeMIpZi9JgY1E3nUlwaCmZT1sEg== + +uuid@3.3.2: + version "3.3.2" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.3.2.tgz#1b4af4955eb3077c501c23872fc6513811587131" + integrity sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA== + +uuid@8.3.2, uuid@^8.3.2: + version "8.3.2" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" + integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== + +uuid@^3.3.2, uuid@^3.3.3: + version "3.4.0" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee" + integrity sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A== + +uuid@^9.0.0: + version "9.0.0" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-9.0.0.tgz#592f550650024a38ceb0c562f2f6aa435761efb5" + integrity sha512-MXcSTerfPa4uqyzStbRoTgt5XIe3x5+42+q1sDuy3R5MDk66URdLMOZe5aPX/SQd+kuYAh0FdP/pO28IkQyTeg== + +v8-compile-cache-lib@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz#6336e8d71965cb3d35a1bbb7868445a7c05264bf" + integrity sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg== + +v8-compile-cache@^2.0.3: + version "2.3.0" + resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" + integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== + +v8-to-istanbul@^8.1.0: + version "8.1.1" + resolved "https://registry.yarnpkg.com/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz#77b752fd3975e31bbcef938f85e9bd1c7a8d60ed" + integrity sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.1" + convert-source-map "^1.6.0" + source-map "^0.7.3" + +value-or-promise@1.0.11: + version "1.0.11" + resolved "https://registry.yarnpkg.com/value-or-promise/-/value-or-promise-1.0.11.tgz#3e90299af31dd014fe843fe309cefa7c1d94b140" + integrity sha512-41BrgH+dIbCFXClcSapVs5M6GkENd3gQOJpEfPDNa71LsUGMXDL0jMWpI/Rh7WhX+Aalfz2TTS3Zt5pUsbnhLg== + +varint@^5.0.0: + version "5.0.2" + resolved "https://registry.yarnpkg.com/varint/-/varint-5.0.2.tgz#5b47f8a947eb668b848e034dcfa87d0ff8a7f7a4" + integrity sha512-lKxKYG6H03yCZUpAGOPOsMcGxd1RHCu1iKvEHYDPmTyq2HueGhD73ssNBqqQWfvYs04G9iUFRvmAVLW20Jw6ow== + +vary@^1, vary@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" + integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== + +verror@1.10.0: + version "1.10.0" + resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" + integrity sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw== + dependencies: + assert-plus "^1.0.0" + core-util-is "1.0.2" + extsprintf "^1.2.0" + +vuvuzela@1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/vuvuzela/-/vuvuzela-1.0.3.tgz#3be145e58271c73ca55279dd851f12a682114b0b" + integrity sha512-Tm7jR1xTzBbPW+6y1tknKiEhz04Wf/1iZkcTJjSFcpNko43+dFW6+OOeQe9taJIug3NdfUAjFKgUSyQrIKaDvQ== + +vvs-sdk@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/vvs-sdk/-/vvs-sdk-2.4.0.tgz#bbc807b84b312b7cac47778f2722ef3d7d00fa08" + integrity sha512-xy/ICGVonDINDAjvMoWIlUzCB1JpZmJe/cXTzOHbzKqXFNFtRiKThlYZqZ1/ANT+pXIEvRGM4xfagBH1HIeLXw== + dependencies: + "@pancakeswap-libs/pancake-swap-core" "^0.1.0" + big.js "^5.2.2" + decimal.js-light "^2.5.0" + jsbi "^3.1.1" + tiny-invariant "^1.1.0" + tiny-warning "^1.0.3" + toformat "^2.0.0" + +w3c-hr-time@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz#0a89cdf5cc15822df9c360543676963e0cc308cd" + integrity sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ== + dependencies: + browser-process-hrtime "^1.0.0" + +w3c-xmlserializer@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz#3e7104a05b75146cc60f564380b7f683acf1020a" + integrity sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA== + dependencies: + xml-name-validator "^3.0.0" + +walker@^1.0.7: + version "1.0.8" + resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.8.tgz#bd498db477afe573dc04185f011d3ab8a8d7653f" + integrity sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ== + dependencies: + makeerror "1.0.12" + +web3-bzz@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-bzz/-/web3-bzz-1.2.1.tgz#c3bd1e8f0c02a13cd6d4e3c3e9e1713f144f6f0d" + integrity sha512-LdOO44TuYbGIPfL4ilkuS89GQovxUpmLz6C1UC7VYVVRILeZS740FVB3j9V4P4FHUk1RenaDfKhcntqgVCHtjw== + dependencies: + got "9.6.0" + swarm-js "0.1.39" + underscore "1.9.1" + +web3-bzz@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-bzz/-/web3-bzz-1.2.2.tgz#a3b9f613c49fd3e120e0997088a73557d5adb724" + integrity sha512-b1O2ObsqUN1lJxmFSjvnEC4TsaCbmh7Owj3IAIWTKqL9qhVgx7Qsu5O9cD13pBiSPNZJ68uJPaKq380QB4NWeA== + dependencies: + "@types/node" "^10.12.18" + got "9.6.0" + swarm-js "0.1.39" + underscore "1.9.1" + +web3-bzz@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-bzz/-/web3-bzz-1.7.4.tgz#9419e606e38a9777443d4ce40506ebd796e06075" + integrity sha512-w9zRhyEqTK/yi0LGRHjZMcPCfP24LBjYXI/9YxFw9VqsIZ9/G0CRCnUt12lUx0A56LRAMpF7iQ8eA73aBcO29Q== + dependencies: + "@types/node" "^12.12.6" + got "9.6.0" + swarm-js "^0.1.40" + +web3-bzz@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-bzz/-/web3-bzz-1.7.5.tgz#edeb262c3a6619109763077a94172513cf07cdde" + integrity sha512-Z53sY0YK/losqjJncmL4vP0zZI9r6tiXg6o7R6e1JD2Iy7FH3serQvU+qXmPjqEBzsnhf8wTG+YcBPB3RHpr0Q== + dependencies: + "@types/node" "^12.12.6" + got "12.1.0" + swarm-js "^0.1.40" + +web3-core-helpers@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-core-helpers/-/web3-core-helpers-1.2.1.tgz#f5f32d71c60a4a3bd14786118e633ce7ca6d5d0d" + integrity sha512-Gx3sTEajD5r96bJgfuW377PZVFmXIH4TdqDhgGwd2lZQCcMi+DA4TgxJNJGxn0R3aUVzyyE76j4LBrh412mXrw== + dependencies: + underscore "1.9.1" + web3-eth-iban "1.2.1" + web3-utils "1.2.1" + +web3-core-helpers@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-core-helpers/-/web3-core-helpers-1.2.2.tgz#484974f4bd4a487217b85b0d7cfe841af0907619" + integrity sha512-HJrRsIGgZa1jGUIhvGz4S5Yh6wtOIo/TMIsSLe+Xay+KVnbseJpPprDI5W3s7H2ODhMQTbogmmUFquZweW2ImQ== + dependencies: + underscore "1.9.1" + web3-eth-iban "1.2.2" + web3-utils "1.2.2" + +web3-core-helpers@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-core-helpers/-/web3-core-helpers-1.7.4.tgz#f8f808928560d3e64e0c8d7bdd163aa4766bcf40" + integrity sha512-F8PH11qIkE/LpK4/h1fF/lGYgt4B6doeMi8rukeV/s4ivseZHHslv1L6aaijLX/g/j4PsFmR42byynBI/MIzFg== + dependencies: + web3-eth-iban "1.7.4" + web3-utils "1.7.4" + +web3-core-helpers@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-core-helpers/-/web3-core-helpers-1.7.5.tgz#e97b3ecac787ade4b9390807a86aca78ed97872b" + integrity sha512-lDDjTks6Q6aNUO87RYrY2xub3UWTKr/RIWxpHJODEqkLxZS1dWdyliJ6aIx3031VQwsNT5HE7NvABe/t0p3iDQ== + dependencies: + web3-eth-iban "1.7.5" + web3-utils "1.7.5" + +web3-core-method@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-core-method/-/web3-core-method-1.2.1.tgz#9df1bafa2cd8be9d9937e01c6a47fc768d15d90a" + integrity sha512-Ghg2WS23qi6Xj8Od3VCzaImLHseEA7/usvnOItluiIc5cKs00WYWsNy2YRStzU9a2+z8lwQywPYp0nTzR/QXdQ== + dependencies: + underscore "1.9.1" + web3-core-helpers "1.2.1" + web3-core-promievent "1.2.1" + web3-core-subscriptions "1.2.1" + web3-utils "1.2.1" + +web3-core-method@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-core-method/-/web3-core-method-1.2.2.tgz#d4fe2bb1945b7152e5f08e4ea568b171132a1e56" + integrity sha512-szR4fDSBxNHaF1DFqE+j6sFR/afv9Aa36OW93saHZnrh+iXSrYeUUDfugeNcRlugEKeUCkd4CZylfgbK2SKYJA== + dependencies: + underscore "1.9.1" + web3-core-helpers "1.2.2" + web3-core-promievent "1.2.2" + web3-core-subscriptions "1.2.2" + web3-utils "1.2.2" + +web3-core-method@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-core-method/-/web3-core-method-1.7.4.tgz#3873c6405e1a0a8a1efc1d7b28de8b7550b00c15" + integrity sha512-56K7pq+8lZRkxJyzf5MHQPI9/VL3IJLoy4L/+q8HRdZJ3CkB1DkXYaXGU2PeylG1GosGiSzgIfu1ljqS7CP9xQ== + dependencies: + "@ethersproject/transactions" "^5.6.2" + web3-core-helpers "1.7.4" + web3-core-promievent "1.7.4" + web3-core-subscriptions "1.7.4" + web3-utils "1.7.4" + +web3-core-method@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-core-method/-/web3-core-method-1.7.5.tgz#ffe8883c169468f0e4d13509377f2d8876d9b7be" + integrity sha512-ApTvq1Llzlbxmy0n4L7QaE6NodIsR80VJqk8qN4kLg30SGznt/pNJFebryLI2kpyDmxSgj1TjEWzmHJBp6FhYg== + dependencies: + "@ethersproject/transactions" "^5.6.2" + web3-core-helpers "1.7.5" + web3-core-promievent "1.7.5" + web3-core-subscriptions "1.7.5" + web3-utils "1.7.5" + +web3-core-promievent@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-core-promievent/-/web3-core-promievent-1.2.1.tgz#003e8a3eb82fb27b6164a6d5b9cad04acf733838" + integrity sha512-IVUqgpIKoeOYblwpex4Hye6npM0aMR+kU49VP06secPeN0rHMyhGF0ZGveWBrGvf8WDPI7jhqPBFIC6Jf3Q3zw== + dependencies: + any-promise "1.3.0" + eventemitter3 "3.1.2" + +web3-core-promievent@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-core-promievent/-/web3-core-promievent-1.2.2.tgz#3b60e3f2a0c96db8a891c927899d29d39e66ab1c" + integrity sha512-tKvYeT8bkUfKABcQswK6/X79blKTKYGk949urZKcLvLDEaWrM3uuzDwdQT3BNKzQ3vIvTggFPX9BwYh0F1WwqQ== + dependencies: + any-promise "1.3.0" + eventemitter3 "3.1.2" + +web3-core-promievent@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-core-promievent/-/web3-core-promievent-1.7.4.tgz#80a75633fdfe21fbaae2f1e38950edb2f134868c" + integrity sha512-o4uxwXKDldN7ER7VUvDfWsqTx9nQSP1aDssi1XYXeYC2xJbVo0n+z6ryKtmcoWoRdRj7uSpVzal3nEmlr480mA== + dependencies: + eventemitter3 "4.0.4" + +web3-core-promievent@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-core-promievent/-/web3-core-promievent-1.7.5.tgz#56a9b06a20e20a0a89d2ab7f88d44c8ae01d5b62" + integrity sha512-uZ1VRErVuhiLtHlyt3oEH/JSvAf6bWPndChHR9PG7i1Zfqm6ZVCeM91ICTPmiL8ddsGQOxASpnJk4vhApcTIww== + dependencies: + eventemitter3 "4.0.4" + +web3-core-requestmanager@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-core-requestmanager/-/web3-core-requestmanager-1.2.1.tgz#fa2e2206c3d738db38db7c8fe9c107006f5c6e3d" + integrity sha512-xfknTC69RfYmLKC+83Jz73IC3/sS2ZLhGtX33D4Q5nQ8yc39ElyAolxr9sJQS8kihOcM6u4J+8gyGMqsLcpIBg== + dependencies: + underscore "1.9.1" + web3-core-helpers "1.2.1" + web3-providers-http "1.2.1" + web3-providers-ipc "1.2.1" + web3-providers-ws "1.2.1" + +web3-core-requestmanager@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-core-requestmanager/-/web3-core-requestmanager-1.2.2.tgz#667ba9ac724c9c76fa8965ae8a3c61f66e68d8d6" + integrity sha512-a+gSbiBRHtHvkp78U2bsntMGYGF2eCb6219aMufuZWeAZGXJ63Wc2321PCbA8hF9cQrZI4EoZ4kVLRI4OF15Hw== + dependencies: + underscore "1.9.1" + web3-core-helpers "1.2.2" + web3-providers-http "1.2.2" + web3-providers-ipc "1.2.2" + web3-providers-ws "1.2.2" + +web3-core-requestmanager@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-core-requestmanager/-/web3-core-requestmanager-1.7.4.tgz#2dc8a526dab8183dca3fef54658621801b1d0469" + integrity sha512-IuXdAm65BQtPL4aI6LZJJOrKAs0SM5IK2Cqo2/lMNvVMT9Kssq6qOk68Uf7EBDH0rPuINi+ReLP+uH+0g3AnPA== + dependencies: + util "^0.12.0" + web3-core-helpers "1.7.4" + web3-providers-http "1.7.4" + web3-providers-ipc "1.7.4" + web3-providers-ws "1.7.4" + +web3-core-requestmanager@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-core-requestmanager/-/web3-core-requestmanager-1.7.5.tgz#be18fc99642689aeb2e016fa43fb47bb9e8c94ce" + integrity sha512-3KpfxW/wVH4mgwWEsSJGHKrtRVoijWlDxtUrm17xgtqRNZ2mFolifKnHAUKa0fY48C9CrxmcCiMIi3W4G6WYRw== + dependencies: + util "^0.12.0" + web3-core-helpers "1.7.5" + web3-providers-http "1.7.5" + web3-providers-ipc "1.7.5" + web3-providers-ws "1.7.5" + +web3-core-subscriptions@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-core-subscriptions/-/web3-core-subscriptions-1.2.1.tgz#8c2368a839d4eec1c01a4b5650bbeb82d0e4a099" + integrity sha512-nmOwe3NsB8V8UFsY1r+sW6KjdOS68h8nuh7NzlWxBQT/19QSUGiERRTaZXWu5BYvo1EoZRMxCKyCQpSSXLc08g== + dependencies: + eventemitter3 "3.1.2" + underscore "1.9.1" + web3-core-helpers "1.2.1" + +web3-core-subscriptions@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-core-subscriptions/-/web3-core-subscriptions-1.2.2.tgz#bf4ba23a653a003bdc3551649958cc0b080b068e" + integrity sha512-QbTgigNuT4eicAWWr7ahVpJyM8GbICsR1Ys9mJqzBEwpqS+RXTRVSkwZ2IsxO+iqv6liMNwGregbJLq4urMFcQ== + dependencies: + eventemitter3 "3.1.2" + underscore "1.9.1" + web3-core-helpers "1.2.2" + +web3-core-subscriptions@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-core-subscriptions/-/web3-core-subscriptions-1.7.4.tgz#cfbd3fa71081a8c8c6f1a64577a1a80c5bd9826f" + integrity sha512-VJvKWaXRyxk2nFWumOR94ut9xvjzMrRtS38c4qj8WBIRSsugrZr5lqUwgndtj0qx4F+50JhnU++QEqUEAtKm3g== + dependencies: + eventemitter3 "4.0.4" + web3-core-helpers "1.7.4" + +web3-core-subscriptions@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-core-subscriptions/-/web3-core-subscriptions-1.7.5.tgz#c0e25610768ea9d9f9107b4ac74b6b6573125e00" + integrity sha512-YK6utQ7Wwjbe4XZOIA8quWGBPi1lFDS1A+jQYwxKKrCvm6BloBNc3FhvrcSYlDhLe/kOy8+2Je8i9amndgT4ww== + dependencies: + eventemitter3 "4.0.4" + web3-core-helpers "1.7.5" + +web3-core@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-core/-/web3-core-1.2.1.tgz#7278b58fb6495065e73a77efbbce781a7fddf1a9" + integrity sha512-5ODwIqgl8oIg/0+Ai4jsLxkKFWJYE0uLuE1yUKHNVCL4zL6n3rFjRMpKPokd6id6nJCNgeA64KdWQ4XfpnjdMg== + dependencies: + web3-core-helpers "1.2.1" + web3-core-method "1.2.1" + web3-core-requestmanager "1.2.1" + web3-utils "1.2.1" + +web3-core@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-core/-/web3-core-1.2.2.tgz#334b99c8222ef9cfd0339e27352f0b58ea789a2f" + integrity sha512-miHAX3qUgxV+KYfaOY93Hlc3kLW2j5fH8FJy6kSxAv+d4d5aH0wwrU2IIoJylQdT+FeenQ38sgsCnFu9iZ1hCQ== + dependencies: + "@types/bn.js" "^4.11.4" + "@types/node" "^12.6.1" + web3-core-helpers "1.2.2" + web3-core-method "1.2.2" + web3-core-requestmanager "1.2.2" + web3-utils "1.2.2" + +web3-core@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-core/-/web3-core-1.7.4.tgz#943fff99134baedafa7c65b4a0bbd424748429ff" + integrity sha512-L0DCPlIh9bgIED37tYbe7bsWrddoXYc897ANGvTJ6MFkSNGiMwDkTLWSgYd9Mf8qu8b4iuPqXZHMwIo4atoh7Q== + dependencies: + "@types/bn.js" "^5.1.0" + "@types/node" "^12.12.6" + bignumber.js "^9.0.0" + web3-core-helpers "1.7.4" + web3-core-method "1.7.4" + web3-core-requestmanager "1.7.4" + web3-utils "1.7.4" + +web3-core@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-core/-/web3-core-1.7.5.tgz#8ee2ca490230a30ca970cb9f308eb65b76405e1d" + integrity sha512-UgOWXZr1fR/3cUQJKWbfMwRxj1/N7o6RSd/dHqdXBlOD+62EjNZItFmLRg5veq5kp9YfXzrNw9bnDkXfsL+nKQ== + dependencies: + "@types/bn.js" "^5.1.0" + "@types/node" "^12.12.6" + bignumber.js "^9.0.0" + web3-core-helpers "1.7.5" + web3-core-method "1.7.5" + web3-core-requestmanager "1.7.5" + web3-utils "1.7.5" + +web3-eth-abi@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth-abi/-/web3-eth-abi-1.2.1.tgz#9b915b1c9ebf82f70cca631147035d5419064689" + integrity sha512-jI/KhU2a/DQPZXHjo2GW0myEljzfiKOn+h1qxK1+Y9OQfTcBMxrQJyH5AP89O6l6NZ1QvNdq99ThAxBFoy5L+g== + dependencies: + ethers "4.0.0-beta.3" + underscore "1.9.1" + web3-utils "1.2.1" + +web3-eth-abi@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth-abi/-/web3-eth-abi-1.2.2.tgz#d5616d88a90020f894763423a9769f2da11fe37a" + integrity sha512-Yn/ZMgoOLxhTVxIYtPJ0eS6pnAnkTAaJgUJh1JhZS4ekzgswMfEYXOwpMaD5eiqPJLpuxmZFnXnBZlnQ1JMXsw== + dependencies: + ethers "4.0.0-beta.3" + underscore "1.9.1" + web3-utils "1.2.2" + +web3-eth-abi@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth-abi/-/web3-eth-abi-1.7.4.tgz#3fee967bafd67f06b99ceaddc47ab0970f2a614a" + integrity sha512-eMZr8zgTbqyL9MCTCAvb67RbVyN5ZX7DvA0jbLOqRWCiw+KlJKTGnymKO6jPE8n5yjk4w01e165Qb11hTDwHgg== + dependencies: + "@ethersproject/abi" "^5.6.3" + web3-utils "1.7.4" + +web3-eth-abi@1.7.5, web3-eth-abi@^1.2.1: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth-abi/-/web3-eth-abi-1.7.5.tgz#db9d6dbcc043a6e922252f3228686e9bbd50d7c9" + integrity sha512-qWHvF7sayxql9BD1yqK9sZRLBQ66eJzGeaU53Y1PRq2iFPrhY6NUWxQ3c3ps0rg+dyObvRbloviWpKXcS4RE/A== + dependencies: + "@ethersproject/abi" "^5.6.3" + web3-utils "1.7.5" + +web3-eth-accounts@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth-accounts/-/web3-eth-accounts-1.2.1.tgz#2741a8ef337a7219d57959ac8bd118b9d68d63cf" + integrity sha512-26I4qq42STQ8IeKUyur3MdQ1NzrzCqPsmzqpux0j6X/XBD7EjZ+Cs0lhGNkSKH5dI3V8CJasnQ5T1mNKeWB7nQ== + dependencies: + any-promise "1.3.0" + crypto-browserify "3.12.0" + eth-lib "0.2.7" + scryptsy "2.1.0" + semver "6.2.0" + underscore "1.9.1" + uuid "3.3.2" + web3-core "1.2.1" + web3-core-helpers "1.2.1" + web3-core-method "1.2.1" + web3-utils "1.2.1" + +web3-eth-accounts@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth-accounts/-/web3-eth-accounts-1.2.2.tgz#c187e14bff6baa698ac352220290222dbfd332e5" + integrity sha512-KzHOEyXOEZ13ZOkWN3skZKqSo5f4Z1ogPFNn9uZbKCz+kSp+gCAEKxyfbOsB/JMAp5h7o7pb6eYsPCUBJmFFiA== + dependencies: + any-promise "1.3.0" + crypto-browserify "3.12.0" + eth-lib "0.2.7" + ethereumjs-common "^1.3.2" + ethereumjs-tx "^2.1.1" + scrypt-shim "github:web3-js/scrypt-shim" + underscore "1.9.1" + uuid "3.3.2" + web3-core "1.2.2" + web3-core-helpers "1.2.2" + web3-core-method "1.2.2" + web3-utils "1.2.2" + +web3-eth-accounts@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth-accounts/-/web3-eth-accounts-1.7.4.tgz#7a24a4dfe947f7e9d1bae678529e591aa146167a" + integrity sha512-Y9vYLRKP7VU7Cgq6wG1jFaG2k3/eIuiTKAG8RAuQnb6Cd9k5BRqTm5uPIiSo0AP/u11jDomZ8j7+WEgkU9+Btw== + dependencies: + "@ethereumjs/common" "^2.5.0" + "@ethereumjs/tx" "^3.3.2" + crypto-browserify "3.12.0" + eth-lib "0.2.8" + ethereumjs-util "^7.0.10" + scrypt-js "^3.0.1" + uuid "3.3.2" + web3-core "1.7.4" + web3-core-helpers "1.7.4" + web3-core-method "1.7.4" + web3-utils "1.7.4" + +web3-eth-accounts@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth-accounts/-/web3-eth-accounts-1.7.5.tgz#b37ee3aeebcc6bce3337636aeb272cbba0ece547" + integrity sha512-AzMLoTj3RGwKpyp3x3TtHrEeU4VpR99iMOD6NKrWSDumS6QEi0lCo+y7QZhdTlINw3iIA3SFIdvbAOO4NCHSDg== + dependencies: + "@ethereumjs/common" "^2.5.0" + "@ethereumjs/tx" "^3.3.2" + crypto-browserify "3.12.0" + eth-lib "0.2.8" + ethereumjs-util "^7.0.10" + scrypt-js "^3.0.1" + uuid "3.3.2" + web3-core "1.7.5" + web3-core-helpers "1.7.5" + web3-core-method "1.7.5" + web3-utils "1.7.5" + +web3-eth-contract@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth-contract/-/web3-eth-contract-1.2.1.tgz#3542424f3d341386fd9ff65e78060b85ac0ea8c4" + integrity sha512-kYFESbQ3boC9bl2rYVghj7O8UKMiuKaiMkxvRH5cEDHil8V7MGEGZNH0slSdoyeftZVlaWSMqkRP/chfnKND0g== + dependencies: + underscore "1.9.1" + web3-core "1.2.1" + web3-core-helpers "1.2.1" + web3-core-method "1.2.1" + web3-core-promievent "1.2.1" + web3-core-subscriptions "1.2.1" + web3-eth-abi "1.2.1" + web3-utils "1.2.1" + +web3-eth-contract@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth-contract/-/web3-eth-contract-1.2.2.tgz#84e92714918a29e1028ee7718f0712536e14e9a1" + integrity sha512-EKT2yVFws3FEdotDQoNsXTYL798+ogJqR2//CaGwx3p0/RvQIgfzEwp8nbgA6dMxCsn9KOQi7OtklzpnJMkjtA== + dependencies: + "@types/bn.js" "^4.11.4" + underscore "1.9.1" + web3-core "1.2.2" + web3-core-helpers "1.2.2" + web3-core-method "1.2.2" + web3-core-promievent "1.2.2" + web3-core-subscriptions "1.2.2" + web3-eth-abi "1.2.2" + web3-utils "1.2.2" + +web3-eth-contract@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth-contract/-/web3-eth-contract-1.7.4.tgz#e5761cfb43d453f57be4777b2e5e7e1082078ff7" + integrity sha512-ZgSZMDVI1pE9uMQpK0T0HDT2oewHcfTCv0osEqf5qyn5KrcQDg1GT96/+S0dfqZ4HKj4lzS5O0rFyQiLPQ8LzQ== + dependencies: + "@types/bn.js" "^5.1.0" + web3-core "1.7.4" + web3-core-helpers "1.7.4" + web3-core-method "1.7.4" + web3-core-promievent "1.7.4" + web3-core-subscriptions "1.7.4" + web3-eth-abi "1.7.4" + web3-utils "1.7.4" + +web3-eth-contract@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth-contract/-/web3-eth-contract-1.7.5.tgz#a032419579bcec062513a3d089ad0e89ac63d731" + integrity sha512-qab7NPJRKRlTs58ozsqK8YIEwWpxIm3vD/okSIKBGkFx5gIHWW+vGmMh5PDSfefLJM9rCd+T+Lc0LYvtME7uqg== + dependencies: + "@types/bn.js" "^5.1.0" + web3-core "1.7.5" + web3-core-helpers "1.7.5" + web3-core-method "1.7.5" + web3-core-promievent "1.7.5" + web3-core-subscriptions "1.7.5" + web3-eth-abi "1.7.5" + web3-utils "1.7.5" + +web3-eth-ens@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth-ens/-/web3-eth-ens-1.2.1.tgz#a0e52eee68c42a8b9865ceb04e5fb022c2d971d5" + integrity sha512-lhP1kFhqZr2nnbu3CGIFFrAnNxk2veXpOXBY48Tub37RtobDyHijHgrj+xTh+mFiPokyrapVjpFsbGa+Xzye4Q== + dependencies: + eth-ens-namehash "2.0.8" + underscore "1.9.1" + web3-core "1.2.1" + web3-core-helpers "1.2.1" + web3-core-promievent "1.2.1" + web3-eth-abi "1.2.1" + web3-eth-contract "1.2.1" + web3-utils "1.2.1" + +web3-eth-ens@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth-ens/-/web3-eth-ens-1.2.2.tgz#0a4abed1d4cbdacbf5e1ab06e502d806d1192bc6" + integrity sha512-CFjkr2HnuyMoMFBoNUWojyguD4Ef+NkyovcnUc/iAb9GP4LHohKrODG4pl76R5u61TkJGobC2ij6TyibtsyVYg== + dependencies: + eth-ens-namehash "2.0.8" + underscore "1.9.1" + web3-core "1.2.2" + web3-core-helpers "1.2.2" + web3-core-promievent "1.2.2" + web3-eth-abi "1.2.2" + web3-eth-contract "1.2.2" + web3-utils "1.2.2" + +web3-eth-ens@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth-ens/-/web3-eth-ens-1.7.4.tgz#346720305379c0a539e226141a9602f1da7bc0c8" + integrity sha512-Gw5CVU1+bFXP5RVXTCqJOmHn71X2ghNk9VcEH+9PchLr0PrKbHTA3hySpsPco1WJAyK4t8SNQVlNr3+bJ6/WZA== + dependencies: + content-hash "^2.5.2" + eth-ens-namehash "2.0.8" + web3-core "1.7.4" + web3-core-helpers "1.7.4" + web3-core-promievent "1.7.4" + web3-eth-abi "1.7.4" + web3-eth-contract "1.7.4" + web3-utils "1.7.4" + +web3-eth-ens@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth-ens/-/web3-eth-ens-1.7.5.tgz#fa0e287f5e6fae20531117b7467e21b482d58cab" + integrity sha512-k1Q0msdRv/wac2egpZBIwG3n/sa/KdrVmVJvFm471gLTL4xfUizV5qJjkDVf+ikf9JyDvWJTs5eWNUUbOFIw/A== + dependencies: + content-hash "^2.5.2" + eth-ens-namehash "2.0.8" + web3-core "1.7.5" + web3-core-helpers "1.7.5" + web3-core-promievent "1.7.5" + web3-eth-abi "1.7.5" + web3-eth-contract "1.7.5" + web3-utils "1.7.5" + +web3-eth-iban@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth-iban/-/web3-eth-iban-1.2.1.tgz#2c3801718946bea24e9296993a975c80b5acf880" + integrity sha512-9gkr4QPl1jCU+wkgmZ8EwODVO3ovVj6d6JKMos52ggdT2YCmlfvFVF6wlGLwi0VvNa/p+0BjJzaqxnnG/JewjQ== + dependencies: + bn.js "4.11.8" + web3-utils "1.2.1" + +web3-eth-iban@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth-iban/-/web3-eth-iban-1.2.2.tgz#76bec73bad214df7c4192388979a59fc98b96c5a" + integrity sha512-gxKXBoUhaTFHr0vJB/5sd4i8ejF/7gIsbM/VvemHT3tF5smnmY6hcwSMmn7sl5Gs+83XVb/BngnnGkf+I/rsrQ== + dependencies: + bn.js "4.11.8" + web3-utils "1.2.2" + +web3-eth-iban@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth-iban/-/web3-eth-iban-1.7.4.tgz#711fb2547fdf0f988060027331b2b6c430505753" + integrity sha512-XyrsgWlZQMv5gRcjXMsNvAoCRvV5wN7YCfFV5+tHUCqN8g9T/o4XUS20vDWD0k4HNiAcWGFqT1nrls02MGZ08w== + dependencies: + bn.js "^5.2.1" + web3-utils "1.7.4" + +web3-eth-iban@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth-iban/-/web3-eth-iban-1.7.5.tgz#1a50efa42cabf1b731396d38bef6a8bf92b5ee1f" + integrity sha512-mn2W5t/1IpL8OZvzAabLKT4kvwRnZSJ9K0tctndl9sDNWkfITYQibEEhUaNNA50Q5fJKgVudHI/m0gwIVTyG8Q== + dependencies: + bn.js "^5.2.1" + web3-utils "1.7.5" + +web3-eth-personal@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth-personal/-/web3-eth-personal-1.2.1.tgz#244e9911b7b482dc17c02f23a061a627c6e47faf" + integrity sha512-RNDVSiaSoY4aIp8+Hc7z+X72H7lMb3fmAChuSBADoEc7DsJrY/d0R5qQDK9g9t2BO8oxgLrLNyBP/9ub2Hc6Bg== + dependencies: + web3-core "1.2.1" + web3-core-helpers "1.2.1" + web3-core-method "1.2.1" + web3-net "1.2.1" + web3-utils "1.2.1" + +web3-eth-personal@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth-personal/-/web3-eth-personal-1.2.2.tgz#eee1c86a8132fa16b5e34c6d421ca92e684f0be6" + integrity sha512-4w+GLvTlFqW3+q4xDUXvCEMU7kRZ+xm/iJC8gm1Li1nXxwwFbs+Y+KBK6ZYtoN1qqAnHR+plYpIoVo27ixI5Rg== + dependencies: + "@types/node" "^12.6.1" + web3-core "1.2.2" + web3-core-helpers "1.2.2" + web3-core-method "1.2.2" + web3-net "1.2.2" + web3-utils "1.2.2" + +web3-eth-personal@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth-personal/-/web3-eth-personal-1.7.4.tgz#22c399794cb828a75703df8bb4b3c1331b471546" + integrity sha512-O10C1Hln5wvLQsDhlhmV58RhXo+GPZ5+W76frSsyIrkJWLtYQTCr5WxHtRC9sMD1idXLqODKKgI2DL+7xeZ0/g== + dependencies: + "@types/node" "^12.12.6" + web3-core "1.7.4" + web3-core-helpers "1.7.4" + web3-core-method "1.7.4" + web3-net "1.7.4" + web3-utils "1.7.4" + +web3-eth-personal@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth-personal/-/web3-eth-personal-1.7.5.tgz#615a3ddcf97aeea93e2a4569753c033fd7a495c5" + integrity sha512-txh2P/eN8I4AOUKFi9++KKddoD0tWfCuu9Y1Kc41jSRbk6smO88Fum0KWNmYFYhSCX2qiknS1DfqsONl3igoKQ== + dependencies: + "@types/node" "^12.12.6" + web3-core "1.7.5" + web3-core-helpers "1.7.5" + web3-core-method "1.7.5" + web3-net "1.7.5" + web3-utils "1.7.5" + +web3-eth@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-eth/-/web3-eth-1.2.1.tgz#b9989e2557c73a9e8ffdc107c6dafbe72c79c1b0" + integrity sha512-/2xly4Yry5FW1i+uygPjhfvgUP/MS/Dk+PDqmzp5M88tS86A+j8BzKc23GrlA8sgGs0645cpZK/999LpEF5UdA== + dependencies: + underscore "1.9.1" + web3-core "1.2.1" + web3-core-helpers "1.2.1" + web3-core-method "1.2.1" + web3-core-subscriptions "1.2.1" + web3-eth-abi "1.2.1" + web3-eth-accounts "1.2.1" + web3-eth-contract "1.2.1" + web3-eth-ens "1.2.1" + web3-eth-iban "1.2.1" + web3-eth-personal "1.2.1" + web3-net "1.2.1" + web3-utils "1.2.1" + +web3-eth@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-eth/-/web3-eth-1.2.2.tgz#65a1564634a23b990efd1655bf94ad513904286c" + integrity sha512-UXpC74mBQvZzd4b+baD4Ocp7g+BlwxhBHumy9seyE/LMIcMlePXwCKzxve9yReNpjaU16Mmyya6ZYlyiKKV8UA== + dependencies: + underscore "1.9.1" + web3-core "1.2.2" + web3-core-helpers "1.2.2" + web3-core-method "1.2.2" + web3-core-subscriptions "1.2.2" + web3-eth-abi "1.2.2" + web3-eth-accounts "1.2.2" + web3-eth-contract "1.2.2" + web3-eth-ens "1.2.2" + web3-eth-iban "1.2.2" + web3-eth-personal "1.2.2" + web3-net "1.2.2" + web3-utils "1.2.2" + +web3-eth@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-eth/-/web3-eth-1.7.4.tgz#a7c1d3ccdbba4de4a82df7e3c4db716e4a944bf2" + integrity sha512-JG0tTMv0Ijj039emXNHi07jLb0OiWSA9O24MRSk5vToTQyDNXihdF2oyq85LfHuF690lXZaAXrjhtLNlYqb7Ug== + dependencies: + web3-core "1.7.4" + web3-core-helpers "1.7.4" + web3-core-method "1.7.4" + web3-core-subscriptions "1.7.4" + web3-eth-abi "1.7.4" + web3-eth-accounts "1.7.4" + web3-eth-contract "1.7.4" + web3-eth-ens "1.7.4" + web3-eth-iban "1.7.4" + web3-eth-personal "1.7.4" + web3-net "1.7.4" + web3-utils "1.7.4" + +web3-eth@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-eth/-/web3-eth-1.7.5.tgz#36906f50a6c35570cbc08871a33caa83dc131c9c" + integrity sha512-BucjvqZyDWYkGlsFX+OnOBub0YutlC1KZiNGibdmvtNX0NQK+8iw1uzAoL9yTTwCSszL7lnkFe8N+HCOl9B4Dw== + dependencies: + web3-core "1.7.5" + web3-core-helpers "1.7.5" + web3-core-method "1.7.5" + web3-core-subscriptions "1.7.5" + web3-eth-abi "1.7.5" + web3-eth-accounts "1.7.5" + web3-eth-contract "1.7.5" + web3-eth-ens "1.7.5" + web3-eth-iban "1.7.5" + web3-eth-personal "1.7.5" + web3-net "1.7.5" + web3-utils "1.7.5" + +web3-net@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-net/-/web3-net-1.2.1.tgz#edd249503315dd5ab4fa00220f6509d95bb7ab10" + integrity sha512-Yt1Bs7WgnLESPe0rri/ZoPWzSy55ovioaP35w1KZydrNtQ5Yq4WcrAdhBzcOW7vAkIwrsLQsvA+hrOCy7mNauw== + dependencies: + web3-core "1.2.1" + web3-core-method "1.2.1" + web3-utils "1.2.1" + +web3-net@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-net/-/web3-net-1.2.2.tgz#5c3226ca72df7c591422440ce6f1203fd42ddad9" + integrity sha512-K07j2DXq0x4UOJgae65rWZKraOznhk8v5EGSTdFqASTx7vWE/m+NqBijBYGEsQY1lSMlVaAY9UEQlcXK5HzXTw== + dependencies: + web3-core "1.2.2" + web3-core-method "1.2.2" + web3-utils "1.2.2" + +web3-net@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-net/-/web3-net-1.7.4.tgz#3153dfd3423262dd6fbec7aae5467202c4cad431" + integrity sha512-d2Gj+DIARHvwIdmxFQ4PwAAXZVxYCR2lET0cxz4KXbE5Og3DNjJi+MoPkX+WqoUXqimu/EOd4Cd+7gefqVAFDg== + dependencies: + web3-core "1.7.4" + web3-core-method "1.7.4" + web3-utils "1.7.4" + +web3-net@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-net/-/web3-net-1.7.5.tgz#87fbc00a9ca40515bf60c847c0092498887cfdc8" + integrity sha512-xwuCb2YWw49PmW81AJQ/G+Xi2ikRsYyZXSgyPt4LmZuKjiqg/6kSdK8lZvUi3Pi3wM+QDBXbpr73M/WEkW0KvA== + dependencies: + web3-core "1.7.5" + web3-core-method "1.7.5" + web3-utils "1.7.5" + +web3-providers-http@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-providers-http/-/web3-providers-http-1.2.1.tgz#c93ea003a42e7b894556f7e19dd3540f947f5013" + integrity sha512-BDtVUVolT9b3CAzeGVA/np1hhn7RPUZ6YYGB/sYky+GjeO311Yoq8SRDUSezU92x8yImSC2B+SMReGhd1zL+bQ== + dependencies: + web3-core-helpers "1.2.1" + xhr2-cookies "1.1.0" + +web3-providers-http@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-providers-http/-/web3-providers-http-1.2.2.tgz#155e55c1d69f4c5cc0b411ede40dea3d06720956" + integrity sha512-BNZ7Hguy3eBszsarH5gqr9SIZNvqk9eKwqwmGH1LQS1FL3NdoOn7tgPPdddrXec4fL94CwgNk4rCU+OjjZRNDg== + dependencies: + web3-core-helpers "1.2.2" + xhr2-cookies "1.1.0" + +web3-providers-http@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-providers-http/-/web3-providers-http-1.7.4.tgz#8209cdcb115db5ccae1f550d1c4e3005e7538d02" + integrity sha512-AU+/S+49rcogUER99TlhW+UBMk0N2DxvN54CJ2pK7alc2TQ7+cprNPLHJu4KREe8ndV0fT6JtWUfOMyTvl+FRA== + dependencies: + web3-core-helpers "1.7.4" + xhr2-cookies "1.1.0" + +web3-providers-http@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-providers-http/-/web3-providers-http-1.7.5.tgz#144bb0c29007d1b766bafb0e20f80be050c7aa80" + integrity sha512-vPgr4Kzy0M3CHtoP/Bh7qwK/D9h2fhjpoqctdMWVJseOfeTgfOphCKN0uwV8w2VpZgDPXA8aeTdBx5OjmDdStA== + dependencies: + abortcontroller-polyfill "^1.7.3" + cross-fetch "^3.1.4" + es6-promise "^4.2.8" + web3-core-helpers "1.7.5" + +web3-providers-ipc@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-providers-ipc/-/web3-providers-ipc-1.2.1.tgz#017bfc687a8fc5398df2241eb98f135e3edd672c" + integrity sha512-oPEuOCwxVx8L4CPD0TUdnlOUZwGBSRKScCz/Ws2YHdr9Ium+whm+0NLmOZjkjQp5wovQbyBzNa6zJz1noFRvFA== + dependencies: + oboe "2.1.4" + underscore "1.9.1" + web3-core-helpers "1.2.1" + +web3-providers-ipc@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-providers-ipc/-/web3-providers-ipc-1.2.2.tgz#c6d165a12bc68674b4cdd543ea18aec79cafc2e8" + integrity sha512-t97w3zi5Kn/LEWGA6D9qxoO0LBOG+lK2FjlEdCwDQatffB/+vYrzZ/CLYVQSoyFZAlsDoBasVoYSWZK1n39aHA== + dependencies: + oboe "2.1.4" + underscore "1.9.1" + web3-core-helpers "1.2.2" + +web3-providers-ipc@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-providers-ipc/-/web3-providers-ipc-1.7.4.tgz#02e85e99e48f432c9d34cee7d786c3685ec9fcfa" + integrity sha512-jhArOZ235dZy8fS8090t60nTxbd1ap92ibQw5xIrAQ9m7LcZKNfmLAQUVsD+3dTFvadRMi6z1vCO7zRi84gWHw== + dependencies: + oboe "2.1.5" + web3-core-helpers "1.7.4" + +web3-providers-ipc@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-providers-ipc/-/web3-providers-ipc-1.7.5.tgz#5b0f9b4f7340416953b8816d2e42e3f548d47372" + integrity sha512-aNHx+RAROzO+apDEzy8Zncj78iqWBadIXtpmFDg7uiTn8i+oO+IcP1Yni7jyzkltsysVJHgHWG4kPx50ANCK3Q== + dependencies: + oboe "2.1.5" + web3-core-helpers "1.7.5" + +web3-providers-ws@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-providers-ws/-/web3-providers-ws-1.2.1.tgz#2d941eaf3d5a8caa3214eff8dc16d96252b842cb" + integrity sha512-oqsQXzu+ejJACVHy864WwIyw+oB21nw/pI65/sD95Zi98+/HQzFfNcIFneF1NC4bVF3VNX4YHTNq2I2o97LAiA== + dependencies: + underscore "1.9.1" + web3-core-helpers "1.2.1" + websocket "github:web3-js/WebSocket-Node#polyfill/globalThis" + +web3-providers-ws@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-providers-ws/-/web3-providers-ws-1.2.2.tgz#d2c05c68598cea5ad3fa6ef076c3bcb3ca300d29" + integrity sha512-Wb1mrWTGMTXOpJkL0yGvL/WYLt8fUIXx8k/l52QB2IiKzvyd42dTWn4+j8IKXGSYYzOm7NMqv6nhA5VDk12VfA== + dependencies: + underscore "1.9.1" + web3-core-helpers "1.2.2" + websocket "github:web3-js/WebSocket-Node#polyfill/globalThis" + +web3-providers-ws@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-providers-ws/-/web3-providers-ws-1.7.4.tgz#6e60bcefb456f569a3e766e386d7807a96f90595" + integrity sha512-g72X77nrcHMFU8hRzQJzfgi/072n8dHwRCoTw+WQrGp+XCQ71fsk2qIu3Tp+nlp5BPn8bRudQbPblVm2uT4myQ== + dependencies: + eventemitter3 "4.0.4" + web3-core-helpers "1.7.4" + websocket "^1.0.32" + +web3-providers-ws@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-providers-ws/-/web3-providers-ws-1.7.5.tgz#196b9e56a4a48f9bee54def56875ea53dec7c711" + integrity sha512-9uJNVVkIGC8PmM9kNbgPth56HDMSSsxZh3ZEENdwO3LNWemaADiQYUDCsD/dMVkn0xsGLHP5dgAy4Q5msqySLg== + dependencies: + eventemitter3 "4.0.4" + web3-core-helpers "1.7.5" + websocket "^1.0.32" + +web3-shh@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3-shh/-/web3-shh-1.2.1.tgz#4460e3c1e07faf73ddec24ccd00da46f89152b0c" + integrity sha512-/3Cl04nza5kuFn25bV3FJWa0s3Vafr5BlT933h26xovQ6HIIz61LmvNQlvX1AhFL+SNJOTcQmK1SM59vcyC8bA== + dependencies: + web3-core "1.2.1" + web3-core-method "1.2.1" + web3-core-subscriptions "1.2.1" + web3-net "1.2.1" + +web3-shh@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3-shh/-/web3-shh-1.2.2.tgz#44ed998f2a6ba0ec5cb9d455184a0f647826a49c" + integrity sha512-og258NPhlBn8yYrDWjoWBBb6zo1OlBgoWGT+LL5/LPqRbjPe09hlOYHgscAAr9zZGtohTOty7RrxYw6Z6oDWCg== + dependencies: + web3-core "1.2.2" + web3-core-method "1.2.2" + web3-core-subscriptions "1.2.2" + web3-net "1.2.2" + +web3-shh@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3-shh/-/web3-shh-1.7.4.tgz#bee91cce2737c529fd347274010b548b6ea060f1" + integrity sha512-mlSZxSYcMkuMCxqhTYnZkUdahZ11h+bBv/8TlkXp/IHpEe4/Gg+KAbmfudakq3EzG/04z70XQmPgWcUPrsEJ+A== + dependencies: + web3-core "1.7.4" + web3-core-method "1.7.4" + web3-core-subscriptions "1.7.4" + web3-net "1.7.4" + +web3-shh@1.7.5: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3-shh/-/web3-shh-1.7.5.tgz#742e27f5c44bea6d7adef3a49b085e0fcd6aa621" + integrity sha512-aCIWJyLMH5H76OybU4ZpUCJ93yNOPATGhJ+KboRPU8QZDzS2CcVhtEzyl27bbvw+rSnVroMLqBgTXBB4mmKI7A== + dependencies: + web3-core "1.7.5" + web3-core-method "1.7.5" + web3-core-subscriptions "1.7.5" + web3-net "1.7.5" + +web3-utils@1.2.1, web3-utils@1.2.2, web3-utils@1.7.3, web3-utils@1.7.4, web3-utils@1.7.5, web3-utils@^1.2.1: + version "1.7.3" + resolved "https://registry.yarnpkg.com/web3-utils/-/web3-utils-1.7.3.tgz#b214d05f124530d8694ad364509ac454d05f207c" + integrity sha512-g6nQgvb/bUpVUIxJE+ezVN+rYwYmlFyMvMIRSuqpi1dk6ApDD00YNArrk7sPcZnjvxOJ76813Xs2vIN2rgh4lg== + dependencies: + bn.js "^4.11.9" + ethereum-bloom-filters "^1.0.6" + ethereumjs-util "^7.1.0" + ethjs-unit "0.1.6" + number-to-bn "1.7.0" + randombytes "^2.1.0" + utf8 "3.0.0" + +web3@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/web3/-/web3-1.2.1.tgz#5d8158bcca47838ab8c2b784a2dee4c3ceb4179b" + integrity sha512-nNMzeCK0agb5i/oTWNdQ1aGtwYfXzHottFP2Dz0oGIzavPMGSKyVlr8ibVb1yK5sJBjrWVnTdGaOC2zKDFuFRw== + dependencies: + web3-bzz "1.2.1" + web3-core "1.2.1" + web3-eth "1.2.1" + web3-eth-personal "1.2.1" + web3-net "1.2.1" + web3-shh "1.2.1" + web3-utils "1.2.1" + +web3@1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/web3/-/web3-1.2.2.tgz#b1b8b69aafdf94cbaeadbb68a8aa1df2ef266aec" + integrity sha512-/ChbmB6qZpfGx6eNpczt5YSUBHEA5V2+iUCbn85EVb3Zv6FVxrOo5Tv7Lw0gE2tW7EEjASbCyp3mZeiZaCCngg== + dependencies: + "@types/node" "^12.6.1" + web3-bzz "1.2.2" + web3-core "1.2.2" + web3-eth "1.2.2" + web3-eth-personal "1.2.2" + web3-net "1.2.2" + web3-shh "1.2.2" + web3-utils "1.2.2" + +web3@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/web3/-/web3-1.7.4.tgz#00c9aef8e13ade92fd773d845fff250535828e93" + integrity sha512-iFGK5jO32vnXM/ASaJBaI0+gVR6uHozvYdxkdhaeOCD6HIQ4iIXadbO2atVpE9oc/H8l2MovJ4LtPhG7lIBN8A== + dependencies: + web3-bzz "1.7.4" + web3-core "1.7.4" + web3-eth "1.7.4" + web3-eth-personal "1.7.4" + web3-net "1.7.4" + web3-shh "1.7.4" + web3-utils "1.7.4" + +web3@^1.2.4, web3@^1.7.3: + version "1.7.5" + resolved "https://registry.yarnpkg.com/web3/-/web3-1.7.5.tgz#4e185d2058195b5775109b3f27cdea65a34a036e" + integrity sha512-3jHZTWyXt975AOXgnZKayiSWDLpoSKk9fZtLk1hURQtt7AdSbXPT8AK9ooBCm0Dt3GYaOeNcHGaiHC3gtyqhLg== + dependencies: + web3-bzz "1.7.5" + web3-core "1.7.5" + web3-eth "1.7.5" + web3-eth-personal "1.7.5" + web3-net "1.7.5" + web3-shh "1.7.5" + web3-utils "1.7.5" + +webidl-conversions@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" + integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== + +webidl-conversions@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-5.0.0.tgz#ae59c8a00b121543a2acc65c0434f57b0fc11aff" + integrity sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA== + +webidl-conversions@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-6.1.0.tgz#9111b4d7ea80acd40f5270d666621afa78b69514" + integrity sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w== + +websocket-driver@>=0.5.1: + version "0.7.4" + resolved "https://registry.yarnpkg.com/websocket-driver/-/websocket-driver-0.7.4.tgz#89ad5295bbf64b480abcba31e4953aca706f5760" + integrity sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg== + dependencies: + http-parser-js ">=0.5.1" + safe-buffer ">=5.1.0" + websocket-extensions ">=0.1.1" + +websocket-extensions@>=0.1.1: + version "0.1.4" + resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42" + integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg== + +websocket@^1.0.28, websocket@^1.0.32: + version "1.0.34" + resolved "https://registry.yarnpkg.com/websocket/-/websocket-1.0.34.tgz#2bdc2602c08bf2c82253b730655c0ef7dcab3111" + integrity sha512-PRDso2sGwF6kM75QykIesBijKSVceR6jL2G8NGYyq2XrItNC2P5/qL5XeR056GhA+Ly7JMFvJb9I312mJfmqnQ== + dependencies: + bufferutil "^4.0.1" + debug "^2.2.0" + es5-ext "^0.10.50" + typedarray-to-buffer "^3.1.5" + utf-8-validate "^5.0.2" + yaeti "^0.0.6" + +"websocket@github:web3-js/WebSocket-Node#polyfill/globalThis": + version "1.0.29" + resolved "https://codeload.github.com/web3-js/WebSocket-Node/tar.gz/ef5ea2f41daf4a2113b80c9223df884b4d56c400" + dependencies: + debug "^2.2.0" + es5-ext "^0.10.50" + nan "^2.14.0" + typedarray-to-buffer "^3.1.5" + yaeti "^0.0.6" + +whatwg-encoding@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz#5abacf777c32166a51d085d6b4f3e7d27113ddb0" + integrity sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw== + dependencies: + iconv-lite "0.4.24" + +whatwg-fetch@2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-2.0.4.tgz#dde6a5df315f9d39991aa17621853d720b85566f" + integrity sha512-dcQ1GWpOD/eEQ97k66aiEVpNnapVj90/+R+SXTPYGHpYBBypfKJEQjLrvMZ7YXbKm21gXd4NcuxUTjiv1YtLng== + +whatwg-mimetype@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf" + integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g== + +whatwg-mimetype@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz#5fa1a7623867ff1af6ca3dc72ad6b8a4208beba7" + integrity sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q== + +whatwg-url-without-unicode@8.0.0-3: + version "8.0.0-3" + resolved "https://registry.yarnpkg.com/whatwg-url-without-unicode/-/whatwg-url-without-unicode-8.0.0-3.tgz#ab6df4bf6caaa6c85a59f6e82c026151d4bb376b" + integrity sha512-HoKuzZrUlgpz35YO27XgD28uh/WJH4B0+3ttFqRo//lmq+9T/mIOJ6kqmINI9HpUpz1imRC/nR/lxKpJiv0uig== + dependencies: + buffer "^5.4.3" + punycode "^2.1.1" + webidl-conversions "^5.0.0" + +whatwg-url@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" + integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== + dependencies: + tr46 "~0.0.3" + webidl-conversions "^3.0.0" + +whatwg-url@^8.0.0, whatwg-url@^8.5.0: + version "8.7.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.7.0.tgz#656a78e510ff8f3937bc0bcbe9f5c0ac35941b77" + integrity sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg== + dependencies: + lodash "^4.7.0" + tr46 "^2.1.0" + webidl-conversions "^6.1.0" + +which-boxed-primitive@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6" + integrity sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg== + dependencies: + is-bigint "^1.0.1" + is-boolean-object "^1.1.0" + is-number-object "^1.0.4" + is-string "^1.0.5" + is-symbol "^1.0.3" + +which-module@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a" + integrity sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q== + +which-typed-array@^1.1.2: + version "1.1.8" + resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.8.tgz#0cfd53401a6f334d90ed1125754a42ed663eb01f" + integrity sha512-Jn4e5PItbcAHyLoRDwvPj1ypu27DJbtdYXUa5zsinrUx77Uvfb0cXwwnGMTn7cjUfhhqgVQnVJCwF+7cgU7tpw== + dependencies: + available-typed-arrays "^1.0.5" + call-bind "^1.0.2" + es-abstract "^1.20.0" + for-each "^0.3.3" + has-tostringtag "^1.0.0" + is-typed-array "^1.1.9" + +which@2.0.2, which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +which@^1.2.9: + version "1.3.1" + resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" + integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== + dependencies: + isexe "^2.0.0" + +winston-daily-rotate-file@^4.5.5: + version "4.7.1" + resolved "https://registry.yarnpkg.com/winston-daily-rotate-file/-/winston-daily-rotate-file-4.7.1.tgz#f60a643af87f8867f23170d8cd87dbe3603a625f" + integrity sha512-7LGPiYGBPNyGHLn9z33i96zx/bd71pjBn9tqQzO3I4Tayv94WPmBNwKC7CO1wPHdP9uvu+Md/1nr6VSH9h0iaA== + dependencies: + file-stream-rotator "^0.6.1" + object-hash "^2.0.1" + triple-beam "^1.3.0" + winston-transport "^4.4.0" + +winston-transport@^4.4.0, winston-transport@^4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/winston-transport/-/winston-transport-4.5.0.tgz#6e7b0dd04d393171ed5e4e4905db265f7ab384fa" + integrity sha512-YpZzcUzBedhlTAfJg6vJDlyEai/IFMIVcaEZZyl3UXIl4gmqRpU7AE89AHLkbzLUsv0NVmw7ts+iztqKxxPW1Q== + dependencies: + logform "^2.3.2" + readable-stream "^3.6.0" + triple-beam "^1.3.0" + +winston@^3.3.3: + version "3.8.1" + resolved "https://registry.yarnpkg.com/winston/-/winston-3.8.1.tgz#76f15b3478cde170b780234e0c4cf805c5a7fb57" + integrity sha512-r+6YAiCR4uI3N8eQNOg8k3P3PqwAm20cLKlzVD9E66Ch39+LZC+VH1UKf9JemQj2B3QoUHfKD7Poewn0Pr3Y1w== + dependencies: + "@dabh/diagnostics" "^2.0.2" + async "^3.2.3" + is-stream "^2.0.0" + logform "^2.4.0" + one-time "^1.0.0" + readable-stream "^3.4.0" + safe-stable-stringify "^2.3.1" + stack-trace "0.0.x" + triple-beam "^1.3.0" + winston-transport "^4.5.0" + +word-wrap@^1.2.3, word-wrap@~1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" + integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== + +workerpool@6.2.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/workerpool/-/workerpool-6.2.0.tgz#827d93c9ba23ee2019c3ffaff5c27fccea289e8b" + integrity sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A== + +workerpool@6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/workerpool/-/workerpool-6.2.1.tgz#46fc150c17d826b86a008e5a4508656777e9c343" + integrity sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw== + +wrap-ansi@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz#d8fc3d284dd05794fe84973caecdd1cf824fdd85" + integrity sha512-vAaEaDM946gbNpH5pLVNR+vX2ht6n0Bt3GXwVB1AuAqZosOvHNF3P7wDnh8KLkSqgUh0uh77le7Owgoz+Z9XBw== + dependencies: + string-width "^1.0.1" + strip-ansi "^3.0.1" + +wrap-ansi@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" + integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== + dependencies: + ansi-styles "^4.0.0" + string-width "^4.1.0" + strip-ansi "^6.0.0" + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== + +write-file-atomic@^2.0.0: + version "2.4.3" + resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-2.4.3.tgz#1fd2e9ae1df3e75b8d8c367443c692d4ca81f481" + integrity sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ== + dependencies: + graceful-fs "^4.1.11" + imurmurhash "^0.1.4" + signal-exit "^3.0.2" + +write-file-atomic@^3.0.0: + version "3.0.3" + resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" + integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== + dependencies: + imurmurhash "^0.1.4" + is-typedarray "^1.0.0" + signal-exit "^3.0.2" + typedarray-to-buffer "^3.1.5" + +write-stream@~0.4.3: + version "0.4.3" + resolved "https://registry.yarnpkg.com/write-stream/-/write-stream-0.4.3.tgz#83cc8c0347d0af6057a93862b4e3ae01de5c81c1" + integrity sha512-IJrvkhbAnj89W/GAVdVgbnPiVw5Ntg/B4tc/MUCIEwj/g6JIww1DWJyB/yBMT3yw2/TkT6IUZ0+IYef3flEw8A== + dependencies: + readable-stream "~0.0.2" + +ws@7.4.6: + version "7.4.6" + resolved "https://registry.yarnpkg.com/ws/-/ws-7.4.6.tgz#5654ca8ecdeee47c33a9a4bf6d28e2be2980377c" + integrity sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A== + +ws@^3.0.0: + version "3.3.3" + resolved "https://registry.yarnpkg.com/ws/-/ws-3.3.3.tgz#f1cf84fe2d5e901ebce94efaece785f187a228f2" + integrity sha512-nnWLa/NwZSt4KQJu51MYlCcSQ5g7INpOrOMt4XV8j4dqTXdmlUmSHQ8/oLC069ckre0fRsgfvsKwbTdtKLCDkA== + dependencies: + async-limiter "~1.0.0" + safe-buffer "~5.1.0" + ultron "~1.1.0" + +ws@^7, ws@^7.2.0, ws@^7.4.5, ws@^7.4.6: + version "7.5.9" + resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.9.tgz#54fa7db29f4c7cec68b1ddd3a89de099942bb591" + integrity sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q== + +ws@^8.5.0: + version "8.8.1" + resolved "https://registry.yarnpkg.com/ws/-/ws-8.8.1.tgz#5dbad0feb7ade8ecc99b830c1d77c913d4955ff0" + integrity sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA== + +xdg-basedir@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/xdg-basedir/-/xdg-basedir-3.0.0.tgz#496b2cc109eca8dbacfe2dc72b603c17c5870ad4" + integrity sha512-1Dly4xqlulvPD3fZUQJLY+FUIeqN3N2MM3uqe4rCJftAvOjFa3jFGfctOgluGx4ahPbUCsZkmJILiP0Vi4T6lQ== + +xhr-request-promise@^0.1.2: + version "0.1.3" + resolved "https://registry.yarnpkg.com/xhr-request-promise/-/xhr-request-promise-0.1.3.tgz#2d5f4b16d8c6c893be97f1a62b0ed4cf3ca5f96c" + integrity sha512-YUBytBsuwgitWtdRzXDDkWAXzhdGB8bYm0sSzMPZT7Z2MBjMSTHFsyCT1yCRATY+XC69DUrQraRAEgcoCRaIPg== + dependencies: + xhr-request "^1.1.0" + +xhr-request@^1.0.1, xhr-request@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/xhr-request/-/xhr-request-1.1.0.tgz#f4a7c1868b9f198723444d82dcae317643f2e2ed" + integrity sha512-Y7qzEaR3FDtL3fP30k9wO/e+FBnBByZeybKOhASsGP30NIkRAAkKD/sCnLvgEfAIEC1rcmK7YG8f4oEnIrrWzA== + dependencies: + buffer-to-arraybuffer "^0.0.5" + object-assign "^4.1.1" + query-string "^5.0.1" + simple-get "^2.7.0" + timed-out "^4.0.1" + url-set-query "^1.0.0" + xhr "^2.0.4" + +xhr2-cookies@1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/xhr2-cookies/-/xhr2-cookies-1.1.0.tgz#7d77449d0999197f155cb73b23df72505ed89d48" + integrity sha512-hjXUA6q+jl/bd8ADHcVfFsSPIf+tyLIjuO9TwJC9WI6JP2zKcS7C+p56I9kCLLsaCiNT035iYvEUUzdEFj/8+g== + dependencies: + cookiejar "^2.1.1" + +xhr@^2.0.4, xhr@^2.3.3: + version "2.6.0" + resolved "https://registry.yarnpkg.com/xhr/-/xhr-2.6.0.tgz#b69d4395e792b4173d6b7df077f0fc5e4e2b249d" + integrity sha512-/eCGLb5rxjx5e3mF1A7s+pLlR6CGyqWN91fv1JgER5mVWg1MZmlhBvy9kjcsOdRk8RrIujotWyJamfyrp+WIcA== + dependencies: + global "~4.4.0" + is-function "^1.0.1" + parse-headers "^2.0.0" + xtend "^4.0.0" + +xml-name-validator@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-3.0.0.tgz#6ae73e06de4d8c6e47f9fb181f78d648ad457c6a" + integrity sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw== + +xml2js@0.4.19: + version "0.4.19" + resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.19.tgz#686c20f213209e94abf0d1bcf1efaa291c7827a7" + integrity sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q== + dependencies: + sax ">=0.6.0" + xmlbuilder "~9.0.1" + +xml2js@^0.4.19, xml2js@^0.4.9: + version "0.4.23" + resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.23.tgz#a0c69516752421eb2ac758ee4d4ccf58843eac66" + integrity sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug== + dependencies: + sax ">=0.6.0" + xmlbuilder "~11.0.0" + +xmlbuilder@~11.0.0: + version "11.0.1" + resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-11.0.1.tgz#be9bae1c8a046e76b31127726347d0ad7002beb3" + integrity sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA== + +xmlbuilder@~9.0.1: + version "9.0.7" + resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-9.0.7.tgz#132ee63d2ec5565c557e20f4c22df9aca686b10d" + integrity sha512-7YXTQc3P2l9+0rjaUbLwMKRhtmwg1M1eDf6nag7urC7pIPYLD9W/jmzQ4ptRSUbodw5S0jfoGTflLemQibSpeQ== + +xmlchars@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" + integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw== + +xmlhttprequest@1.8.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz#67fe075c5c24fef39f9d65f5f7b7fe75171968fc" + integrity sha512-58Im/U0mlVBLM38NdZjHyhuMtCqa61469k2YP/AaPbvCoV9aQGUpbJBj1QRm2ytRiVQBD/fsw7L2bJGDVQswBA== + +xss@^1.0.8: + version "1.0.14" + resolved "https://registry.yarnpkg.com/xss/-/xss-1.0.14.tgz#4f3efbde75ad0d82e9921cc3c95e6590dd336694" + integrity sha512-og7TEJhXvn1a7kzZGQ7ETjdQVS2UfZyTlsEdDOqvQF7GoxNfY+0YLCzBy1kPdsDDx4QuNAonQPddpsn6Xl/7sw== + dependencies: + commander "^2.20.3" + cssfilter "0.0.10" + +xstream@^11.14.0: + version "11.14.0" + resolved "https://registry.yarnpkg.com/xstream/-/xstream-11.14.0.tgz#2c071d26b18310523b6877e86b4e54df068a9ae5" + integrity sha512-1bLb+kKKtKPbgTK6i/BaoAn03g47PpFstlbe1BA+y3pNS/LfvcaghS5BFf9+EE1J+KwSQsEpfJvFN5GqFtiNmw== + dependencies: + globalthis "^1.0.1" + symbol-observable "^2.0.3" + +xtend@^4.0.0, xtend@^4.0.1, xtend@^4.0.2, xtend@~4.0.0, xtend@~4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" + integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== + +"y18n@^3.2.1 || ^4.0.0": + version "4.0.3" + resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.3.tgz#b5f259c82cd6e336921efd7bfd8bf560de9eeedf" + integrity sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ== + +y18n@^5.0.5: + version "5.0.8" + resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" + integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== + +yaeti@^0.0.6: + version "0.0.6" + resolved "https://registry.yarnpkg.com/yaeti/-/yaeti-0.0.6.tgz#f26f484d72684cf42bedfb76970aa1608fbf9577" + integrity sha512-MvQa//+KcZCUkBTIC9blM+CU9J2GzuTytsOUwf2lidtvkx/6gnEp1QvJv34t9vdjhFmha/mUiNDbN0D0mJWdug== + +yallist@^3.0.0, yallist@^3.0.2, yallist@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" + integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yargs-parser@20.2.4: + version "20.2.4" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.4.tgz#b42890f14566796f85ae8e3a25290d205f154a54" + integrity sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA== + +yargs-parser@20.x, yargs-parser@^20.2.2: + version "20.2.9" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee" + integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== + +yargs-parser@^11.1.1: + version "11.1.1" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-11.1.1.tgz#879a0865973bca9f6bab5cbdf3b1c67ec7d3bcf4" + integrity sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ== + dependencies: + camelcase "^5.0.0" + decamelize "^1.2.0" + +yargs-parser@^21.0.0: + version "21.1.1" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-21.1.1.tgz#9096bceebf990d21bb31fa9516e0ede294a77d35" + integrity sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw== + +yargs-unparser@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/yargs-unparser/-/yargs-unparser-2.0.0.tgz#f131f9226911ae5d9ad38c432fe809366c2325eb" + integrity sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA== + dependencies: + camelcase "^6.0.0" + decamelize "^4.0.0" + flat "^5.0.2" + is-plain-obj "^2.1.0" + +yargs@16.2.0, yargs@^16.1.0, yargs@^16.2.0: + version "16.2.0" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-16.2.0.tgz#1c82bf0f6b6a66eafce7ef30e376f49a12477f66" + integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== + dependencies: + cliui "^7.0.2" + escalade "^3.1.1" + get-caller-file "^2.0.5" + require-directory "^2.1.1" + string-width "^4.2.0" + y18n "^5.0.5" + yargs-parser "^20.2.2" + +yargs@^12.0.2: + version "12.0.5" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-12.0.5.tgz#05f5997b609647b64f66b81e3b4b10a368e7ad13" + integrity sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw== + dependencies: + cliui "^4.0.0" + decamelize "^1.2.0" + find-up "^3.0.0" + get-caller-file "^1.0.1" + os-locale "^3.0.0" + require-directory "^2.1.1" + require-main-filename "^1.0.1" + set-blocking "^2.0.0" + string-width "^2.0.0" + which-module "^2.0.0" + y18n "^3.2.1 || ^4.0.0" + yargs-parser "^11.1.1" + +yargs@^17.0.1: + version "17.5.1" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.5.1.tgz#e109900cab6fcb7fd44b1d8249166feb0b36e58e" + integrity sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA== + dependencies: + cliui "^7.0.2" + escalade "^3.1.1" + get-caller-file "^2.0.5" + require-directory "^2.1.1" + string-width "^4.2.3" + y18n "^5.0.5" + yargs-parser "^21.0.0" + +yarn@^1.22.17: + version "1.22.19" + resolved "https://registry.yarnpkg.com/yarn/-/yarn-1.22.19.tgz#4ba7fc5c6e704fce2066ecbfb0b0d8976fe62447" + integrity sha512-/0V5q0WbslqnwP91tirOvldvYISzaqhClxzyUKXYxs07yUILIs5jx/k6CFe8bvKSkds5w+eiOqta39Wk3WxdcQ== + +yauzl@^2.4.2: + version "2.10.0" + resolved "https://registry.yarnpkg.com/yauzl/-/yauzl-2.10.0.tgz#c7eb17c93e112cb1086fa6d8e51fb0667b79a5f9" + integrity sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g== + dependencies: + buffer-crc32 "~0.2.3" + fd-slicer "~1.1.0" + +yn@3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/yn/-/yn-3.1.1.tgz#1e87401a09d767c1d5eab26a6e4c185182d2eb50" + integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==