mirror of
https://github.com/Cog-Creators/Red-DiscordBot.git
synced 2025-12-08 18:32:32 -05:00
[Config] Retrieve/save values with async context manager (#1131)
* [Config] Retrieve/save values with async context manager * Add a little docstring * Documentation * Implement async with syntax in existing modules
This commit is contained in:
@@ -328,10 +328,9 @@ class Admin:
|
||||
"""
|
||||
Add a role to the list of available selfroles.
|
||||
"""
|
||||
curr_selfroles = await self.conf.guild(ctx.guild).selfroles()
|
||||
if role.id not in curr_selfroles:
|
||||
curr_selfroles.append(role.id)
|
||||
await self.conf.guild(ctx.guild).selfroles.set(curr_selfroles)
|
||||
async with self.conf.guild(ctx.guild).selfroles() as curr_selfroles:
|
||||
if role.id not in curr_selfroles:
|
||||
curr_selfroles.append(role.id)
|
||||
|
||||
await ctx.send("The selfroles list has been successfully modified.")
|
||||
|
||||
@@ -341,9 +340,8 @@ class Admin:
|
||||
"""
|
||||
Removes a role from the list of available selfroles.
|
||||
"""
|
||||
curr_selfroles = await self.conf.guild(ctx.guild).selfroles()
|
||||
curr_selfroles.remove(role.id)
|
||||
await self.conf.guild(ctx.guild).selfroles.set(curr_selfroles)
|
||||
async with self.conf.guild(ctx.guild).selfroles() as curr_selfroles:
|
||||
curr_selfroles.remove(role.id)
|
||||
|
||||
await ctx.send("The selfroles list has been successfully modified.")
|
||||
|
||||
|
||||
@@ -82,41 +82,31 @@ class Alias:
|
||||
alias = AliasEntry(alias_name, command, ctx.author, global_=global_)
|
||||
|
||||
if global_:
|
||||
curr_aliases = await self._aliases.entries()
|
||||
curr_aliases.append(alias.to_json())
|
||||
await self._aliases.entries.set(curr_aliases)
|
||||
settings = self._aliases
|
||||
else:
|
||||
curr_aliases = await self._aliases.guild(ctx.guild).entries()
|
||||
settings = self._aliases.guild(ctx.guild)
|
||||
await settings.enabled.set(True)
|
||||
|
||||
async with settings.entries() as curr_aliases:
|
||||
curr_aliases.append(alias.to_json())
|
||||
await self._aliases.guild(ctx.guild).entries.set(curr_aliases)
|
||||
|
||||
await self._aliases.guild(ctx.guild).enabled.set(True)
|
||||
return alias
|
||||
|
||||
async def delete_alias(self, ctx: commands.Context, alias_name: str,
|
||||
global_: bool=False) -> bool:
|
||||
if global_:
|
||||
aliases = await self.unloaded_global_aliases()
|
||||
setter_func = self._aliases.entries.set
|
||||
settings = self._aliases
|
||||
else:
|
||||
aliases = await self.unloaded_aliases(ctx.guild)
|
||||
setter_func = self._aliases.guild(ctx.guild).entries.set
|
||||
settings = self._aliases.guild(ctx.guild)
|
||||
|
||||
did_delete_alias = False
|
||||
async with settings.entries() as aliases:
|
||||
for alias in aliases:
|
||||
alias_obj = AliasEntry.from_json(alias)
|
||||
if alias_obj.name == alias_name:
|
||||
aliases.remove(alias)
|
||||
return True
|
||||
|
||||
to_keep = []
|
||||
for alias in aliases:
|
||||
if alias.name != alias_name:
|
||||
to_keep.append(alias)
|
||||
else:
|
||||
did_delete_alias = True
|
||||
|
||||
await setter_func(
|
||||
[a.to_json() for a in to_keep]
|
||||
)
|
||||
|
||||
return did_delete_alias
|
||||
return False
|
||||
|
||||
async def get_prefix(self, message: discord.Message) -> str:
|
||||
"""
|
||||
|
||||
@@ -183,30 +183,24 @@ class Filter:
|
||||
await ctx.send(_("Count and time have been set."))
|
||||
|
||||
async def add_to_filter(self, server: discord.Guild, words: list) -> bool:
|
||||
added = 0
|
||||
cur_list = await self.settings.guild(server).filter()
|
||||
for w in words:
|
||||
if w.lower() not in cur_list and w != "":
|
||||
cur_list.append(w.lower())
|
||||
added += 1
|
||||
if added:
|
||||
await self.settings.guild(server).filter.set(cur_list)
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
added = False
|
||||
async with self.settings.guild(server).filter() as cur_list:
|
||||
for w in words:
|
||||
if w.lower() not in cur_list and w:
|
||||
cur_list.append(w.lower())
|
||||
added = True
|
||||
|
||||
return added
|
||||
|
||||
async def remove_from_filter(self, server: discord.Guild, words: list) -> bool:
|
||||
removed = 0
|
||||
cur_list = await self.settings.guild(server).filter()
|
||||
for w in words:
|
||||
if w.lower() in cur_list:
|
||||
cur_list.remove(w.lower())
|
||||
removed += 1
|
||||
if removed:
|
||||
await self.settings.guild(server).filter.set(cur_list)
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
removed = False
|
||||
async with self.settings.guild(server).filter() as cur_list:
|
||||
for w in words:
|
||||
if w.lower() in cur_list:
|
||||
cur_list.remove(w.lower())
|
||||
removed = True
|
||||
|
||||
return removed
|
||||
|
||||
async def check_filter(self, message: discord.Message):
|
||||
server = message.guild
|
||||
|
||||
@@ -1347,18 +1347,21 @@ class Mod:
|
||||
|
||||
async def on_member_update(self, before, after):
|
||||
if before.name != after.name:
|
||||
name_list = await self.settings.user(before).past_names()
|
||||
if after.name not in name_list:
|
||||
names = deque(name_list, maxlen=20)
|
||||
names.append(after.name)
|
||||
await self.settings.user(before).past_names.set(list(names))
|
||||
async with self.settings.user(before).past_names() as name_list:
|
||||
if after.nick in name_list:
|
||||
# Ensure order is maintained without duplicates occuring
|
||||
name_list.remove(after.nick)
|
||||
name_list.append(after.nick)
|
||||
while len(name_list) > 20:
|
||||
name_list.pop(0)
|
||||
|
||||
if before.nick != after.nick and after.nick is not None:
|
||||
nick_list = await self.settings.member(before).past_nicks()
|
||||
nicks = deque(nick_list, maxlen=20)
|
||||
if after.nick not in nicks:
|
||||
nicks.append(after.nick)
|
||||
await self.settings.member(before).past_nicks.set(list(nicks))
|
||||
async with self.settings.member(before).past_nicks() as nick_list:
|
||||
if after.nick in nick_list:
|
||||
nick_list.remove(after.nick)
|
||||
nick_list.append(after.nick)
|
||||
while len(nick_list) > 20:
|
||||
nick_list.pop(0)
|
||||
|
||||
@staticmethod
|
||||
def are_overwrites_empty(overwrites):
|
||||
|
||||
Reference in New Issue
Block a user