From ef183232c13ce0c1b2f9467a91756e2db0dff091 Mon Sep 17 00:00:00 2001 From: bobloy Date: Thu, 16 Aug 2018 14:32:45 -0400 Subject: [PATCH 1/3] add message --- forcemention/forcemention.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/forcemention/forcemention.py b/forcemention/forcemention.py index 1a3e76e..fe0b773 100644 --- a/forcemention/forcemention.py +++ b/forcemention/forcemention.py @@ -21,18 +21,18 @@ class ForceMention: @checks.admin_or_permissions(manage_roles=True) @commands.command() - async def forcemention(self, ctx: commands.Context, role: str): + async def forcemention(self, ctx: commands.Context, role: str, *, message): """ Mentions that role, regardless if it's unmentionable """ - role = get(ctx.guild.roles, name=role) - if role is None: - await ctx.maybe_send_embed("Couldn't find role with that name") + role_obj = get(ctx.guild.roles, name=role) + if role_obj is None: + await ctx.maybe_send_embed("Couldn't find role named {}".format(role)) return - if not role.mentionable: - await role.edit(mentionable=True) - await ctx.send(role.mention) - await role.edit(mentionable=False) + if not role_obj.mentionable: + await role_obj.edit(mentionable=True) + await ctx.send("{}\n{}".format(role_obj.mention, message)) + await role_obj.edit(mentionable=False) else: - await ctx.send(role.mention) + await ctx.send(role_obj.mention) From 0fb643c58d1f8c7eb0eaa0becd4023bc513d5a1c Mon Sep 17 00:00:00 2001 From: bobloy Date: Thu, 16 Aug 2018 15:35:12 -0400 Subject: [PATCH 2/3] optional message --- forcemention/forcemention.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/forcemention/forcemention.py b/forcemention/forcemention.py index fe0b773..14d171f 100644 --- a/forcemention/forcemention.py +++ b/forcemention/forcemention.py @@ -7,7 +7,7 @@ from redbot.core.bot import Red class ForceMention: """ - V3 Cog Template + Mention the unmentionables """ def __init__(self, bot: Red): @@ -21,7 +21,7 @@ class ForceMention: @checks.admin_or_permissions(manage_roles=True) @commands.command() - async def forcemention(self, ctx: commands.Context, role: str, *, message): + async def forcemention(self, ctx: commands.Context, role: str, *, message=None): """ Mentions that role, regardless if it's unmentionable """ From 02389e03da89db1b9c5bb66f2b5728e7f4a29527 Mon Sep 17 00:00:00 2001 From: bobloy Date: Thu, 16 Aug 2018 15:37:13 -0400 Subject: [PATCH 3/3] better message and '' default --- forcemention/forcemention.py | 4 +-- nudity/info..json | 2 +- nudity/nudity.py | 70 ++++++++---------------------------- 3 files changed, 18 insertions(+), 58 deletions(-) diff --git a/forcemention/forcemention.py b/forcemention/forcemention.py index 14d171f..8086d7d 100644 --- a/forcemention/forcemention.py +++ b/forcemention/forcemention.py @@ -21,7 +21,7 @@ class ForceMention: @checks.admin_or_permissions(manage_roles=True) @commands.command() - async def forcemention(self, ctx: commands.Context, role: str, *, message=None): + async def forcemention(self, ctx: commands.Context, role: str, *, message=''): """ Mentions that role, regardless if it's unmentionable """ @@ -35,4 +35,4 @@ class ForceMention: await ctx.send("{}\n{}".format(role_obj.mention, message)) await role_obj.edit(mentionable=False) else: - await ctx.send(role_obj.mention) + await ctx.send("{}\n{}".format(role_obj.mention, message)) diff --git a/nudity/info..json b/nudity/info..json index 9f69325..4384930 100644 --- a/nudity/info..json +++ b/nudity/info..json @@ -10,7 +10,7 @@ "description": "Keep track of when users were last seen online", "hidden": true, "install_msg": "Thank you for installing LastSeen. Get started with `[p]help LastSeen`", - "requirements": [], + "requirements": ["nudepy"], "short": "Last seen tracker", "tags": [ "bobloy", diff --git a/nudity/nudity.py b/nudity/nudity.py index 1f6bf92..be30ee4 100644 --- a/nudity/nudity.py +++ b/nudity/nudity.py @@ -1,7 +1,8 @@ from datetime import datetime -import dateutil.parser import discord +import nude +from nude import Nude from redbot.core import Config from redbot.core import commands from redbot.core.bot import Red @@ -21,65 +22,24 @@ class Nudity: self.config = Config.get_conf(self, identifier=9811198108111121, force_registration=True) default_guild = { - "enabled": True + "enabled": False } self.config.register_guild(**default_guild) - @staticmethod - def get_date_time(s): - d = dateutil.parser.parse(s) - return d + @commands.command(aliases=['togglenudity'], name='nudity') + async def nudity(self, ctx: commands.Context): + """Toggle nude-checking on or off""" + is_on = await self.config.guild(ctx.guild).enabled() + await self.config.guild(ctx.guild).enabled.set(not is_on) + await ctx.send("Nude checking is now set to {}".format(not is_on)) - @commands.group(aliases=['setlseen'], name='lseenset') - async def lset(self, ctx: commands.Context): - """Change settings for lseen""" - if ctx.invoked_subcommand is None: - await ctx.send_help() + async def on_message(self, message: discord.Message): + is_on = await self.config.guild(message.guild).enabled() + if not is_on: + return - @lset.command(name="toggle") - async def lset_toggle(self, ctx: commands.Context): - """Toggles tracking seen for this server""" - enabled = not await self.config.guild(ctx.guild).enabled() - await self.config.guild(ctx.guild).enabled.set( - enabled) + if not message.attachments: + return - await ctx.send( - "Seen for this server is now {}".format( - "Enabled" if enabled else "Disabled")) - @commands.command(aliases=['lastseen']) - async def lseen(self, ctx: commands.Context, member: discord.Member): - """ - Just says the time the user was last seen - """ - - if member.status != self.offline_status: - last_seen = datetime.utcnow() - else: - last_seen = await self.config.member(member).seen() - if last_seen is None: - await ctx.send(embed=discord.Embed(description="I've never seen this user")) - return - last_seen = self.get_date_time(last_seen) - - # embed = discord.Embed( - # description="{} was last seen at this date and time".format(member.display_name), - # timestamp=self.get_date_time(last_seen)) - - embed = discord.Embed(timestamp=last_seen) - await ctx.send(embed=embed) - - # async def on_socket_raw_receive(self, data): - # try: - # if type(data) == str: - # raw = json.loads(data) - # print(data) - # except: - # print(data) - - async def on_member_update(self, before: discord.Member, after: discord.Member): - if before.status != self.offline_status and after.status == self.offline_status: - if not await self.config.guild(before.guild).enabled(): - return - await self.config.member(before).seen.set(datetime.utcnow().isoformat())