Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Scheduled close event for thread save to config vars #135

Merged
merged 25 commits into from
Jan 17, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
a903f55
Use call_later for close
Taaku18 Jan 16, 2019
561ac20
Use call_later for close
Taaku18 Jan 16, 2019
ee665a2
Merge pull request #1 from Taaku18/testing
Taaku18 Jan 16, 2019
668c4ba
Fix flawed statement
Taaku18 Jan 16, 2019
d16204a
Fix flawed statement
Taaku18 Jan 16, 2019
e32fa34
Fix flawed statement
Taaku18 Jan 16, 2019
272a0aa
Fix flawed statement
Taaku18 Jan 16, 2019
75865eb
Style/Convention for thread.py
Taaku18 Jan 16, 2019
fe88794
Removed reference as it's not necessary
Taaku18 Jan 16, 2019
7d25c41
Merge branch 'master' of https://github.com/kyb3r/modmail into dev
Taaku18 Jan 16, 2019
7a2fde7
Added the use of config vars
Taaku18 Jan 16, 2019
ef58811
Attempt to fix a problem where it cancels scheduled close 3 times
Taaku18 Jan 16, 2019
a06cf97
Added debugging print statement
Taaku18 Jan 16, 2019
581246e
Attempt to fix missing config
Taaku18 Jan 16, 2019
1a43eeb
Attempt to fix missing config (found typo)
Taaku18 Jan 16, 2019
8300316
Perhaps refreshing will help?
Taaku18 Jan 16, 2019
28e59c5
Added debugging print statement
Taaku18 Jan 16, 2019
9c4de11
Attempted to fix problem & clears closure when it's closed
Taaku18 Jan 16, 2019
a63d1b8
Added handling for when the channel's deleted when the bot's down
Taaku18 Jan 16, 2019
fdc6428
Removed debugging print statement
Taaku18 Jan 17, 2019
768d9ad
Merge branch 'master' of https://github.com/kyb3r/modmail into dev
Taaku18 Jan 17, 2019
ee7e1bd
Attempt to address PR issues
Taaku18 Jan 17, 2019
81aba61
Should address a bug and some issues
Taaku18 Jan 17, 2019
6013ba8
Address a preformance concern
Taaku18 Jan 17, 2019
03560c9
Bump version to v1.5.0
Taaku18 Jan 17, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 19 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,25 @@ 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).


# v2.5.0

Non-Breaking Changes:

### Background
Bots hosted by Heroku restart at least once every 27 hours.
During this period, local caches are deleted, which results in the inability to
set the scheduled close time to longer than 24 hours. This update
resolves this issue.
[PR #135](https://github.com/kyb3r/modmail/pull/135)


### Changed
- Created a new internal config var: `closures`.
- Store closure details into `closures` when the scheduled time isn't "now".
- Loaded upon bot restart.
- Deleted when a thread is closed.
- Use `call_later()` instead of `sleep()` for scheduling.

# v2.4.5

### Fixed
Expand Down
31 changes: 30 additions & 1 deletion bot.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
SOFTWARE.
"""

__version__ = '2.4.5'
__version__ = '2.5.0'

import asyncio
import textwrap
Expand Down Expand Up @@ -202,8 +202,37 @@ async def on_ready(self):
print(Fore.RED + Style.BRIGHT + 'WARNING - The GUILD_ID provided does not exist!' + Style.RESET_ALL)
else:
await self.threads.populate_cache()
await self.config.update()

closures = self.config.closures.copy()

for recipient_id, items in closures.items():
after = (datetime.datetime.fromisoformat(items['time']) -
datetime.datetime.utcnow()).total_seconds()
if after < 0:
after = 0
recipient = self.get_user(int(recipient_id))

thread = await self.threads.find(
recipient=recipient)

if not thread:
# If the recipient is gone or channel is deleted
self.config.closures.pop(str(recipient_id))
await self.config.update()
continue

# TODO: Low priority,
# Retrieve messages/replies when bot is down, from history?
self.loop.create_task(
thread.close(
closer=self.get_user(items['closer_id']),
after=after,
silent=items['silent'],
delete_channel=items['delete_channel'],
message=items['message']
)
)

async def process_modmail(self, message):
"""Processes messages sent to the bot."""
Expand Down
10 changes: 5 additions & 5 deletions cogs/modmail.py
Original file line number Diff line number Diff line change
Expand Up @@ -174,11 +174,11 @@ async def _close(self, ctx, *, after: UserFriendlyTime=None):
silent = str(message).lower() in {'silent', 'silently'}
cancel = str(message).lower() == 'cancel'

if cancel and thread.close_task is not None and not thread.close_task.cancelled():
thread.close_task.cancel()
await ctx.send(embed=discord.Embed(color=discord.Color.red(), description='Scheduled close has been cancelled.'))
return
elif cancel:
if cancel:
if thread.close_task is not None:
Taaku18 marked this conversation as resolved.
Show resolved Hide resolved
await thread.cancel_closure()
await ctx.send(embed=discord.Embed(color=discord.Color.red(), description='Scheduled close has been cancelled.'))
return
return await ctx.send(embed=discord.Embed(color=discord.Color.red(), description='This thread has not already been scheduled to close.'))

if after and after.dt > now:
Expand Down
18 changes: 12 additions & 6 deletions core/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,20 +7,24 @@ class ConfigManager:
"""Class that manages a cached configuration"""

allowed_to_change_in_command = {
'activity_message', 'activity_type', 'log_channel_id', 'mention', 'disable_autoupdates', 'prefix',
'main_category_id', 'sent_emoji', 'blocked_emoji', 'thread_creation_response', 'twitch_url'
'activity_message', 'activity_type', 'log_channel_id',
'mention', 'disable_autoupdates', 'prefix',
'main_category_id', 'sent_emoji', 'blocked_emoji',
'thread_creation_response', 'twitch_url'
}

internal_keys = {
'snippets', 'aliases', 'blocked', 'notification_squad', 'subscriptions'
'snippets', 'aliases', 'blocked',
'notification_squad', 'subscriptions',
'closures'
}

protected_keys = {
'token', 'owners', 'modmail_api_token', 'guild_id', 'modmail_guild_id',
'mongo_uri', 'github_access_token', 'log_url'
}

valid_keys = allowed_to_change_in_command.union(internal_keys).union(protected_keys)
valid_keys = allowed_to_change_in_command | internal_keys | protected_keys

def __init__(self, bot):
self.bot = bot
Expand All @@ -38,7 +42,8 @@ def populate_cache(self):
'aliases': {},
'blocked': {},
'notification_squad': {},
'subscriptions': {}
'subscriptions': {},
Taaku18 marked this conversation as resolved.
Show resolved Hide resolved
'closures': {},
}

try:
Expand All @@ -47,7 +52,8 @@ def populate_cache(self):
pass
finally:
data.update(os.environ)
data = {k.lower(): v for k, v in data.items() if k.lower() in self.valid_keys}
data = {k.lower(): v for k, v in data.items()
if k.lower() in self.valid_keys}
self.cache = data

async def update(self, data=None):
Expand Down
Loading