Skip to content

Commit

Permalink
Merge pull request #1378 from Drakkar-Software/dev
Browse files Browse the repository at this point in the history
[Hollaex] handle kit URL fetch error
  • Loading branch information
GuillaumeDSM authored Nov 5, 2024
2 parents 004a330 + c01e5d5 commit 1089e13
Showing 1 changed file with 28 additions and 2 deletions.
30 changes: 28 additions & 2 deletions Trading/Exchange/hollaex_autofilled/hollaex_autofilled_exchange.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
import cachetools
import aiohttp
import typing
import asyncio

import octobot_commons.logging as commons_logging
import octobot_commons.constants
Expand All @@ -37,6 +38,8 @@ class HollaexAutofilled(hollaex):
AUTO_FILLED_KEY = "auto_filled"
WEBSOCKETS_KEY = "websockets"
KIT_PATH = "v2/kit"
MAX_RATE_LIMIT_ATTEMPTS = 60 # fetch over 3 minutes, every 3s (we can't start the bot if the kit request fails)
RATE_LIMIT_SLEEP_TIME = 3

@classmethod
def supported_autofill_exchanges(cls, tentacle_config):
Expand Down Expand Up @@ -96,10 +99,33 @@ async def _cached_fetch_autofilled_config(cls, tentacle_config, exchange_name) -
f"Fetching {exchange_name} HollaEx kit from {exchange_kit_url}"
)
async with aiohttp.ClientSession() as session:
async with session.get(exchange_kit_url) as response:
_EXCHANGE_REMOTE_CONFIG_BY_EXCHANGE_KIT_URL[exchange_kit_url] = await response.json()
_EXCHANGE_REMOTE_CONFIG_BY_EXCHANGE_KIT_URL[exchange_kit_url] = await cls._retry_fetch_when_rate_limit(
session, exchange_kit_url
)
return _EXCHANGE_REMOTE_CONFIG_BY_EXCHANGE_KIT_URL[exchange_kit_url]

@classmethod
async def _retry_fetch_when_rate_limit(cls, session, url):
for attempt in range(cls.MAX_RATE_LIMIT_ATTEMPTS):
async with session.get(url) as response:
if response.status < 300:
return await response.json()
elif response.status in (403, 429) or "has banned your IP address" in (await response.text()):
# rate limit: sleep and retry
commons_logging.get_logger(cls.get_name()).warning(
f"Error when fetching {url}: {response.status}. Retrying in {cls.RATE_LIMIT_SLEEP_TIME} seconds"
)
await asyncio.sleep(cls.RATE_LIMIT_SLEEP_TIME)
else:
# unexpected error
response.raise_for_status()

commons_logging.get_logger(cls.get_name()).error(
f"Error when fetching {url}: {response.status}. Max attempts ({cls.MAX_RATE_LIMIT_ATTEMPTS}) reached. "
f"Error text: {await response.text()}"
)
response.raise_for_status()

def _supports_autofill(self, exchange_name):
try:
self._get_kit_url(self.tentacle_config, exchange_name)
Expand Down

0 comments on commit 1089e13

Please sign in to comment.