From be3f8e568636d1c28bd2e72fdbfde5c4ea90d0f6 Mon Sep 17 00:00:00 2001 From: Benjamin B <7598058+BBlackwo@users.noreply.github.com> Date: Tue, 29 Aug 2023 21:51:53 +1000 Subject: [PATCH 1/4] Update spotbit api url and path --- src/cryptoadvance/specter/util/price_providers.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/cryptoadvance/specter/util/price_providers.py b/src/cryptoadvance/specter/util/price_providers.py index eaae3e1946..23bfdb3050 100644 --- a/src/cryptoadvance/specter/util/price_providers.py +++ b/src/cryptoadvance/specter/util/price_providers.py @@ -168,14 +168,15 @@ def get_price_at(specter, timestamp="now"): if timestamp == "now": price = failsafe_request_get( requests_session, - "http://h6zwwkcivy2hjys6xpinlnz2f74dsmvltzsd4xb42vinhlcaoe7fdeqd.onion/now/{}/{}".format( + "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/now/{}/{}".format( currency, exchange ), )["close"] else: price = failsafe_request_get( requests_session, - "http://h6zwwkcivy2hjys6xpinlnz2f74dsmvltzsd4xb42vinhlcaoe7fdeqd.onion/hist/{}/{}/{}/{}".format( + # TODO: Fix to use `start` and `end` query date time parameters instead of path parameters + "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/history/{}/{}/{}/{}".format( currency, exchange, timestamp * 1000, From 685f041b6f702a4ecec982ead068555e7de772bc Mon Sep 17 00:00:00 2001 From: k9ert Date: Tue, 19 Sep 2023 13:55:10 +0200 Subject: [PATCH 2/4] Update src/cryptoadvance/specter/util/price_providers.py Co-authored-by: Benjamin B <7598058+BBlackwo@users.noreply.github.com> --- src/cryptoadvance/specter/util/price_providers.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/cryptoadvance/specter/util/price_providers.py b/src/cryptoadvance/specter/util/price_providers.py index 23bfdb3050..27bf317df0 100644 --- a/src/cryptoadvance/specter/util/price_providers.py +++ b/src/cryptoadvance/specter/util/price_providers.py @@ -169,7 +169,7 @@ def get_price_at(specter, timestamp="now"): price = failsafe_request_get( requests_session, "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/now/{}/{}".format( - currency, exchange + currency.upper(), exchange ), )["close"] else: From 2f540a84d9bdfe503cf8ff1fba726a592d06dadd Mon Sep 17 00:00:00 2001 From: Kim Neunert Date: Tue, 19 Sep 2023 15:02:06 +0200 Subject: [PATCH 3/4] removed non-existent price-provider and added gemini --- .../templates/components/price_bar.jinja | 36 ++-------- .../specter/util/price_providers.py | 71 +++++++++---------- 2 files changed, 36 insertions(+), 71 deletions(-) diff --git a/src/cryptoadvance/specter/templates/components/price_bar.jinja b/src/cryptoadvance/specter/templates/components/price_bar.jinja index 2168353a62..f47ce0f36f 100644 --- a/src/cryptoadvance/specter/templates/components/price_bar.jinja +++ b/src/cryptoadvance/specter/templates/components/price_bar.jinja @@ -79,57 +79,29 @@ diff --git a/src/cryptoadvance/specter/util/price_providers.py b/src/cryptoadvance/specter/util/price_providers.py index 27bf317df0..8691f4cff1 100644 --- a/src/cryptoadvance/specter/util/price_providers.py +++ b/src/cryptoadvance/specter/util/price_providers.py @@ -15,85 +15,64 @@ currency_mapping = { "usd": { "symbol": "$", - "support": [ - "bitstamp", - "coindesk", - "spotbit_coinbase", - "spotbit_kraken", - "spotbit_bitfinex", - "spotbit_okcoin", - "spotbit_bitstamp", - ], + "support": ["bitstamp", "coindesk", "spotbit_bitstamp", "spotbit_gemini"], }, "eur": { "symbol": "€", "support": [ "bitstamp", "coindesk", - "spotbit_coinbase", - "spotbit_kraken", - "spotbit_bitfinex", - "spotbit_okcoin_eur", "spotbit_bitstamp", + "spotbit_gemini", ], }, "gbp": { "symbol": "£", - "support": [ - "bitstamp", - "coindesk", - "spotbit_coinbase", - "spotbit_kraken", - "spotbit_bitfinex", - "spotbit_bitstamp", - ], + "support": ["bitstamp", "coindesk", "spotbit_bitstamp", "spotbit_gemini"], }, "chf": { "symbol": " Fr.", - "support": ["coindesk", "spotbit_coinbase", "spotbit_kraken"], + "support": ["coindesk"], }, "aud": { "symbol": "$", - "support": ["coindesk", "spotbit_coinbase", "spotbit_kraken"], + "support": ["coindesk"], }, "cad": { "symbol": "$", - "support": ["coindesk", "spotbit_coinbase", "spotbit_kraken"], + "support": ["coindesk"], }, - "nzd": {"symbol": "$", "support": ["coindesk", "spotbit_coinbase"]}, - "hkd": {"symbol": "$", "support": ["coindesk", "spotbit_coinbase"]}, + "nzd": {"symbol": "$", "support": ["coindesk"]}, + "hkd": {"symbol": "$", "support": ["coindesk"]}, "jpy": { "symbol": "¥", "support": [ "coindesk", - "spotbit_coinbase", - "spotbit_kraken", - "spotbit_bitfinex", ], }, - "rub": {"symbol": "₽", "support": ["coindesk", "spotbit_coinbase"]}, - "ils": {"symbol": "₪", "support": ["coindesk", "spotbit_coinbase"]}, - "jod": {"symbol": "د.ا", "support": ["coindesk", "spotbit_coinbase"]}, - "twd": {"symbol": "$", "support": ["coindesk", "spotbit_coinbase"]}, - "brl": {"symbol": " BRL", "support": ["coindesk", "spotbit_coinbase"]}, + "rub": {"symbol": "₽", "support": ["coindesk"]}, + "ils": {"symbol": "₪", "support": ["coindesk"]}, + "jod": {"symbol": "د.ا", "support": ["coindesk"]}, + "twd": {"symbol": "$", "support": ["coindesk"]}, + "brl": {"symbol": " BRL", "support": ["coindesk"]}, "xau": { "symbol": " oz. ", - "support": ["coindesk", "spotbit_coinbase"], + "support": ["coindesk"], "weight_unit_convertible": True, }, "xag": { "symbol": " oz. ", - "support": ["coindesk", "spotbit_coinbase"], + "support": ["coindesk"], "weight_unit_convertible": True, }, "xpt": { "symbol": " oz. ", - "support": ["spotbit_coinbase"], + "support": [], "weight_unit_convertible": True, }, "xpd": { "symbol": " oz. ", - "support": ["spotbit_coinbase"], + "support": [], "weight_unit_convertible": True, }, } @@ -106,6 +85,7 @@ def update_price(specter, current_user): specter.update_alt_symbol(symbol, current_user) return True except SpecterError as e: + handle_exception(e) logger.error(f"{e} while updating price") except Exception as e: handle_exception(e) @@ -125,6 +105,7 @@ def get_price_at(specter, timestamp="now"): """returns a price and a currency-symbol at the timestamp""" try: if specter.price_check: + requests_session = specter.requests_session( force_tor=("spotbit" in specter.price_provider) ) @@ -137,7 +118,7 @@ def get_price_at(specter, timestamp="now"): ) except AttributeError: raise SpecterError(f"Currency not supported: {currency}") - + print("MUH" + specter.price_provider) if exchange not in currency_mapping[currency]["support"]: raise SpecterError( f"The currency {currency} is not supported on exchange {exchange}" @@ -164,8 +145,16 @@ def get_price_at(specter, timestamp="now"): else: raise SpecterError("coindesk does not support historic prices") elif specter.price_provider.startswith("spotbit"): + print("MUH") + print("MUH" + specter.price_provider) exchange = specter.price_provider.split("spotbit_")[1].split("_")[0] + print( + "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/now/{}/{}".format( + currency.upper(), exchange + ) + ) if timestamp == "now": + price = failsafe_request_get( requests_session, "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/now/{}/{}".format( @@ -202,6 +191,10 @@ def _parse_exchange_currency(exchange_currency): # e.g. "spotbit_bitstamp_eur" or "bitstamp_eur" arr = exchange_currency.split("_") if len(arr) == 2: + if not arr[1] in currency_mapping.keys(): + raise SpecterError( + f"{arr[1]} is not a valid currency. Received: {exchange_currency}" + ) return arr[0], arr[1] elif len(arr) == 3: return f"{arr[0]}_{arr[1]}", arr[2] From 245de1dcdcfd58e5c1261c02a6df7a74cb9558a3 Mon Sep 17 00:00:00 2001 From: Kim Neunert Date: Tue, 19 Sep 2023 15:18:02 +0200 Subject: [PATCH 4/4] fixed history API --- src/cryptoadvance/specter/util/price_providers.py | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/src/cryptoadvance/specter/util/price_providers.py b/src/cryptoadvance/specter/util/price_providers.py index 8691f4cff1..b9335acdbb 100644 --- a/src/cryptoadvance/specter/util/price_providers.py +++ b/src/cryptoadvance/specter/util/price_providers.py @@ -145,14 +145,8 @@ def get_price_at(specter, timestamp="now"): else: raise SpecterError("coindesk does not support historic prices") elif specter.price_provider.startswith("spotbit"): - print("MUH") - print("MUH" + specter.price_provider) exchange = specter.price_provider.split("spotbit_")[1].split("_")[0] - print( - "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/now/{}/{}".format( - currency.upper(), exchange - ) - ) + if timestamp == "now": price = failsafe_request_get( @@ -165,7 +159,8 @@ def get_price_at(specter, timestamp="now"): price = failsafe_request_get( requests_session, # TODO: Fix to use `start` and `end` query date time parameters instead of path parameters - "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/history/{}/{}/{}/{}".format( + # Hope that works like this: + "http://r5sru63gzyrnaayaua2ydo32f4hf6vd33bq6qmtktx3wjoib2cwi2gqd.onion/api/history/{}/{}?start={}&end={}".format( currency, exchange, timestamp * 1000,