diff options
| author | 2022-04-18 16:58:01 +0100 | |
|---|---|---|
| committer | 2022-04-18 16:58:01 +0100 | |
| commit | 4b93fbb03d22134cab1f9d9f1f07e5f81012dea5 (patch) | |
| tree | 4470bc87711d79de0be2680b52a618005c86f1c4 | |
| parent | Merge pull request #56 from python-discord/minor-fixes-to-BotBase (diff) | |
| parent | Reconnect to redis session on setup if it is closed (diff) | |
Merge pull request #61 from python-discord/redis-reconnect-on-setupv5.0.3
Reconnect to redis session on setup if it is closed
Diffstat (limited to '')
| -rw-r--r-- | CHANGELOG.md | 3 | ||||
| -rw-r--r-- | botcore/_bot.py | 7 | ||||
| -rw-r--r-- | pyproject.toml | 2 | 
3 files changed, 10 insertions, 2 deletions
| diff --git a/CHANGELOG.md b/CHANGELOG.md index 3779ad32..f78ef928 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,8 @@  # Changelog +## 5.0.3 18th April 2022 +- Fix: Reconnect to redis session on setup if it is closed. +  ## 5.0.2 5th April 2022  - Fix: Create a dummy `AsyncstatsdClient` before connecting to real url, in case a connection cannot be made on init.  - Fix: Move the creation of the `asyncio.Event`, `BotBase._guild_available` to within the setup hook, to avoid a deprecation notice. diff --git a/botcore/_bot.py b/botcore/_bot.py index e69b056d..69ccdc1c 100644 --- a/botcore/_bot.py +++ b/botcore/_bot.py @@ -222,6 +222,11 @@ class BotBase(commands.Bot):          )          self.http.connector = self._connector +        if getattr(self, "redis_session", False) and self.redis_session.closed: +            # If the RedisSession was somehow closed, we try to reconnect it +            # here. Normally, this shouldn't happen. +            await self.redis_session.connect() +          # Create dummy stats client first, in case `statsd_url` is unreachable within `_connect_statsd()`          self.stats = AsyncStatsClient(loop, "127.0.0.1")          self._connect_statsd(self.statsd_url, loop) @@ -265,7 +270,7 @@ class BotBase(commands.Bot):          if self.stats._transport:              self.stats._transport.close() -        if getattr(self.redis_session, None): +        if getattr(self, "redis_session", False):              await self.redis_session.close()          if self._statsd_timerhandle: diff --git a/pyproject.toml b/pyproject.toml index 76f0e667..1ad6edd9 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@  [tool.poetry]  name = "bot-core" -version = "5.0.2" +version = "5.0.3"  description = "Bot-Core provides the core functionality and utilities for the bots of the Python Discord community."  authors = ["Python Discord <[email protected]>"]  license = "MIT" | 
