Rewrite the verification code to the one required by Ryujinx Guild

This commit is contained in:
Ave Ozkal 2020-04-08 18:27:05 +03:00 committed by Mary
parent 5ef0f42967
commit 86eb6a7ad2
3 changed files with 102 additions and 10 deletions

View file

@ -588,12 +588,6 @@ class Mod(Cog):
if warn_count == 2: if warn_count == 2:
msg += " __The next warn will automatically kick.__" msg += " __The next warn will automatically kick.__"
if warn_count == 3: if warn_count == 3:
msg += (
"\n\nYou were kicked because of this warning. "
"You can join again right away. "
"Two more warnings will result in an automatic ban."
)
if warn_count == 4:
msg += ( msg += (
"\n\nYou were kicked because of this warning. " "\n\nYou were kicked because of this warning. "
"This is your final warning. " "This is your final warning. "
@ -601,8 +595,8 @@ class Mod(Cog):
"**one more warn will result in a ban**." "**one more warn will result in a ban**."
) )
chan_msg += "**This resulted in an auto-kick.**\n" chan_msg += "**This resulted in an auto-kick.**\n"
if warn_count == 5: if warn_count == 4:
msg += "\n\nYou were automatically banned due to five warnings." msg += "\n\nYou were automatically banned due to four warnings."
chan_msg += "**This resulted in an auto-ban.**\n" chan_msg += "**This resulted in an auto-ban.**\n"
try: try:
await target.send(msg) await target.send(msg)
@ -610,9 +604,9 @@ class Mod(Cog):
# Prevents log issues in cases where user blocked bot # Prevents log issues in cases where user blocked bot
# or has DMs disabled # or has DMs disabled
pass pass
if warn_count == 3 or warn_count == 4: if warn_count == 3:
await target.kick() await target.kick()
if warn_count >= 5: # just in case if warn_count >= 4: # just in case
await target.ban(reason="exceeded warn limit", delete_message_days=0) await target.ban(reason="exceeded warn limit", delete_message_days=0)
await ctx.send( await ctx.send(
f"{target.mention} warned. " f"User has {warn_count} warning(s)." f"{target.mention} warned. " f"User has {warn_count} warning(s)."

View file

@ -0,0 +1,94 @@
import discord
from discord.ext import commands
from discord.ext.commands import Cog
import config
import random
from helpers.checks import check_if_staff
class RyujinxVerification(Cog):
def __init__(self, bot):
self.bot = bot
# Export reset channel functions
self.bot.do_reset = self.do_reset
self.bot.do_resetalgo = self.do_resetalgo
@Cog.listener()
async def on_member_join(self, member):
await self.bot.wait_until_ready()
if (member.guild.id not in config.guild_whitelist):
return
join_channel = self.bot.get_channel(config.welcome_channel)
if join_channel is not None:
await join_channel.send('Hello {0.mention}! Welcome to Ryujinx! Please read the <#411271165429022730>, and then type the verifying command here to gain access to the rest of the channels.\n\nIf you need help with basic common questions, visit the <#585288848704143371> channel after joining.\n\nIf you need help with Animal Crossing visit the <#692104087889641472> channel for common issues and solutions. If you need help that is not Animal Crossing related, please visit the <#410208610455519243> channel after verifying.'.format(member))
async def process_message(self, message):
"""Process the verification process"""
if message.channel.id == config.welcome_channel:
# Assign common stuff into variables to make stuff less of a mess
mcl = message.content.lower()
# Get the role we will give in case of success
success_role = message.guild.get_role(config.participant_role)
if config.verification_string == mcl:
await message.author.add_roles(success_role)
await message.delete()
@Cog.listener()
async def on_message(self, message):
if message.author.bot:
return
try:
await self.process_message(message)
except discord.errors.Forbidden:
chan = self.bot.get_channel(message.channel)
await chan.send("💢 I don't have permission to do this.")
@Cog.listener()
async def on_message_edit(self, before, after):
if after.author.bot:
return
try:
await self.process_message(after)
except discord.errors.Forbidden:
chan = self.bot.get_channel(after.channel)
await chan.send("💢 I don't have permission to do this.")
@Cog.listener()
async def on_member_join(self, member):
await self.bot.wait_until_ready()
if (member.guild.id not in config.guild_whitelist):
return
join_channel = self.bot.get_channel(config.welcome_channel)
if join_channel is not None:
await join_channel.send(config.join_message.format(member))
@commands.check(check_if_staff)
@commands.command()
async def reset(self, ctx, limit: int = 100, force: bool = False):
"""Wipes messages and pastes the welcome message again. Staff only."""
if ctx.message.channel.id != config.welcome_channel and not force:
await ctx.send(f"This command is limited to"
f" <#{config.welcome_channel}>, unless forced.")
return
await self.do_reset(ctx.channel, ctx.author.mention, limit)
async def do_reset(self, channel, author, limit: int = 100):
await channel.purge(limit=limit)
async def do_resetalgo(self, channel, author, limit: int = 100):
# We only auto clear the channel daily
await self.do_reset(channel, author)
def setup(bot):
bot.add_cog(RyujinxVerification(bot))

View file

@ -51,6 +51,10 @@ initial_cogs = [
# and sends pins above limit to a github gist # and sends pins above limit to a github gist
# The string that users need to say to get past verification
verification_string = "go read the rules, not the code"
# Minimum account age required to join the guild # Minimum account age required to join the guild
# If user's account creation is shorter than the time delta given here # If user's account creation is shorter than the time delta given here
# then user will be kicked and informed # then user will be kicked and informed