mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-17 10:51:00 +00:00
feat(common): better checks for delisted tokens
This commit is contained in:
parent
174985619d
commit
417b33ba78
@ -21,5 +21,15 @@
|
||||
"wallet": {
|
||||
"MyEtherWallet": null
|
||||
}
|
||||
},
|
||||
"eth:EOS": {
|
||||
"hidden": true,
|
||||
"ignore_cmc_rank": true,
|
||||
"reason": "this exists as misc:EOS and the eth: entry is probably a mistake"
|
||||
},
|
||||
"misc:LSK": {
|
||||
"hidden": true,
|
||||
"ignore_cmc_rank": true,
|
||||
"reason": "delisted incompatible hardfork"
|
||||
}
|
||||
}
|
||||
|
@ -3,6 +3,8 @@
|
||||
"erc20:eth:BTL (Bitlle)": true,
|
||||
"erc20:eth:LINK Platform": true,
|
||||
"erc20:eth:NXX": false,
|
||||
"erc20:eth:SNX:c011": false,
|
||||
"erc20:eth:TUSD": false,
|
||||
"erc20:eth:Hdp": true,
|
||||
"erc20:eth:Hdp.ф": true,
|
||||
"misc:BNB": false,
|
||||
|
@ -259,13 +259,15 @@ def check_missing_data(coins):
|
||||
LOG.info(f"{k}: Details are OK, but coin is still hidden")
|
||||
|
||||
if hide:
|
||||
data = marketcap.get_coin(coin)
|
||||
if data and data["cmc_rank"] < 150 and not coin.get("ignore_cmc_rank"):
|
||||
LOG.warning(f"{k}: Hiding coin ranked {data['cmc_rank']} on CMC")
|
||||
coin["hidden"] = 1
|
||||
|
||||
# summary of hidden coins
|
||||
hidden_coins = [k for k, coin in coins.items() if coin.get("hidden")]
|
||||
for key in hidden_coins:
|
||||
del coins[key]
|
||||
LOG.debug(f"{key}: Coin is hidden")
|
||||
|
||||
|
||||
def apply_overrides(coins):
|
||||
@ -310,7 +312,7 @@ def main(refresh, api_key, verbose):
|
||||
|
||||
marketcap.init(api_key, refresh=refresh)
|
||||
|
||||
defs = coin_info.coin_info()
|
||||
defs, _ = coin_info.coin_info_with_duplicates()
|
||||
support_info = coin_info.support_info(defs)
|
||||
|
||||
coins = {}
|
||||
|
@ -9,8 +9,7 @@ import requests
|
||||
COINMAKETCAP_CACHE = os.path.join(os.path.dirname(__file__), "coinmarketcap.json")
|
||||
COINMARKETCAP_API_BASE = "https://pro-api.coinmarketcap.com/v1/"
|
||||
|
||||
MARKET_CAPS = {}
|
||||
PRICES = {}
|
||||
COINS_SEARCHABLE = {}
|
||||
|
||||
|
||||
def call(endpoint, api_key, params=None):
|
||||
@ -21,7 +20,7 @@ def call(endpoint, api_key, params=None):
|
||||
|
||||
|
||||
def init(api_key, refresh=None):
|
||||
global MARKET_CAPS, PRICES
|
||||
global COINS_SEARCHABLE
|
||||
|
||||
force_refresh = refresh is True
|
||||
disable_refresh = refresh is False
|
||||
@ -60,41 +59,53 @@ def init(api_key, refresh=None):
|
||||
except Exception as e:
|
||||
raise RuntimeError("market cap data unavailable") from e
|
||||
|
||||
cap_data = {}
|
||||
price_data = {}
|
||||
data_searchable = {}
|
||||
for coin in coinmarketcap_data["data"]:
|
||||
slug = coin["slug"]
|
||||
symbol = coin["symbol"]
|
||||
platform = coin["meta"]["platform"]
|
||||
market_cap = coin["quote"]["USD"]["market_cap"]
|
||||
price = coin["quote"]["USD"]["price"]
|
||||
if market_cap is not None:
|
||||
cap_data[slug] = cap_data[symbol] = int(market_cap)
|
||||
price_data[symbol] = price
|
||||
if platform is not None and platform["name"] == "Ethereum":
|
||||
address = platform["token_address"].lower()
|
||||
cap_data[address] = int(market_cap)
|
||||
price_data[symbol] = price
|
||||
data_searchable[slug] = data_searchable[symbol] = coin
|
||||
if platform is not None and platform["name"] == "Ethereum":
|
||||
address = platform["token_address"].lower()
|
||||
data_searchable[address] = coin
|
||||
for explorer in coin["meta"]["urls"]["explorer"]:
|
||||
# some tokens exist in multiple places, such as BNB and ETH
|
||||
# then the "platform" field might list the wrong thing
|
||||
# to be sure, walk the list of explorers and look for etherscan.io
|
||||
if explorer.startswith("https://etherscan.io/token/"):
|
||||
address = explorer.rsplit("/", 1)[-1].lower()
|
||||
data_searchable[address] = coin
|
||||
|
||||
MARKET_CAPS = cap_data
|
||||
PRICES = price_data
|
||||
COINS_SEARCHABLE = data_searchable
|
||||
|
||||
|
||||
def get_coin(coin):
|
||||
if coin["type"] == "erc20":
|
||||
address = coin["address"].lower()
|
||||
return COINS_SEARCHABLE.get(address)
|
||||
|
||||
data = None
|
||||
if "coinmarketcap_alias" in coin:
|
||||
data = COINS_SEARCHABLE.get(coin["coinmarketcap_alias"])
|
||||
if data is None:
|
||||
slug = coin["name"].replace(" ", "-").lower()
|
||||
data = COINS_SEARCHABLE.get(slug)
|
||||
if data is None:
|
||||
data = COINS_SEARCHABLE.get(coin["shortcut"].lower())
|
||||
return data
|
||||
|
||||
|
||||
def marketcap(coin):
|
||||
cap = None
|
||||
if coin["type"] == "erc20":
|
||||
address = coin["address"].lower()
|
||||
return MARKET_CAPS.get(address)
|
||||
data = get_coin(coin)
|
||||
if data is None:
|
||||
return None
|
||||
|
||||
if "coinmarketcap_alias" in coin:
|
||||
cap = MARKET_CAPS.get(coin["coinmarketcap_alias"])
|
||||
if cap is None:
|
||||
slug = coin["name"].replace(" ", "-").lower()
|
||||
cap = MARKET_CAPS.get(slug)
|
||||
if cap is None:
|
||||
cap = MARKET_CAPS.get(coin["shortcut"].lower())
|
||||
return cap
|
||||
return int(data["quote"]["USD"]["market_cap"])
|
||||
|
||||
|
||||
def fiat_price(coin_symbol):
|
||||
return PRICES.get(coin_symbol)
|
||||
data = COINS_SEARCHABLE.get(coin_symbol)
|
||||
if data is None:
|
||||
return None
|
||||
|
||||
return data["quote"]["USD"]["price"]
|
||||
|
Loading…
Reference in New Issue
Block a user