mirror of
https://github.com/Ryujinx/ryuko-ng.git
synced 2025-01-24 19:11:07 +00:00
hash_choice needs to change every reset, not every boot
This commit is contained in:
parent
cccfe27310
commit
a1bc115621
|
@ -109,10 +109,11 @@ welcome_footer = (
|
||||||
|
|
||||||
hidden_term_line = ' • When you have finished reading all of the rules, send a message in this channel that includes the {0} hash of your discord "name#discriminator" (for example, {0}(User#1234)), and we\'ll grant you access to the other channels. You can find your "name#discriminator" (your username followed by a ‘#’ and four numbers) under the discord channel list.'
|
hidden_term_line = ' • When you have finished reading all of the rules, send a message in this channel that includes the {0} hash of your discord "name#discriminator" (for example, {0}(User#1234)), and we\'ll grant you access to the other channels. You can find your "name#discriminator" (your username followed by a ‘#’ and four numbers) under the discord channel list.'
|
||||||
|
|
||||||
|
hash_choice = hashlib.sha1
|
||||||
|
|
||||||
class Verification(Cog):
|
class Verification(Cog):
|
||||||
def __init__(self, bot):
|
def __init__(self, bot):
|
||||||
self.bot = bot
|
self.bot = bot
|
||||||
self.hash_choice = random.choice(tuple(hashlib.algorithms_guaranteed))
|
|
||||||
|
|
||||||
@commands.check(check_if_staff)
|
@commands.check(check_if_staff)
|
||||||
@commands.command()
|
@commands.command()
|
||||||
|
@ -123,13 +124,17 @@ class Verification(Cog):
|
||||||
f" <#{config.welcome_channel}>, unless forced.")
|
f" <#{config.welcome_channel}>, unless forced.")
|
||||||
return
|
return
|
||||||
|
|
||||||
|
if ctx.message.channel.id == config.welcome_channel:
|
||||||
|
# randomize hash_choice on reset
|
||||||
|
hash_choice = random.choice(tuple(hashlib.algorithms_guaranteed))
|
||||||
|
|
||||||
await ctx.channel.purge(limit=limit)
|
await ctx.channel.purge(limit=limit)
|
||||||
|
|
||||||
await ctx.send(welcome_header)
|
await ctx.send(welcome_header)
|
||||||
rules = ['**{}**. {}'.format(i, cleandoc(r)) for i, r in
|
rules = ['**{}**. {}'.format(i, cleandoc(r)) for i, r in
|
||||||
enumerate(welcome_rules, 1)]
|
enumerate(welcome_rules, 1)]
|
||||||
rule_choice = random.randint(2, len(rules))
|
rule_choice = random.randint(2, len(rules))
|
||||||
rules[rule_choice - 1] += '\n' + hidden_term_line.format(self.hash_choice.upper())
|
rules[rule_choice - 1] += '\n' + hidden_term_line.format(hash_choice.upper())
|
||||||
msg = f"🗑 **Reset**: {ctx.author.mention} cleared {limit} messages "\
|
msg = f"🗑 **Reset**: {ctx.author.mention} cleared {limit} messages "\
|
||||||
f" in {ctx.channel.mention}"
|
f" in {ctx.channel.mention}"
|
||||||
msg += f"\n💬 __Current challenge location__: under rule {rule_choice}"
|
msg += f"\n💬 __Current challenge location__: under rule {rule_choice}"
|
||||||
|
@ -200,11 +205,11 @@ class Verification(Cog):
|
||||||
close_names += [(cn + '\r') for cn in close_names]
|
close_names += [(cn + '\r') for cn in close_names]
|
||||||
|
|
||||||
# Finally, hash the stuff so that we can access them later :)
|
# Finally, hash the stuff so that we can access them later :)
|
||||||
hash_allow = [hashlib.new(self.hash_choice, name.encode('utf-8')).hexdigest()
|
hash_allow = [hashlib.new(hash_choice, name.encode('utf-8')).hexdigest()
|
||||||
for name in allowed_names]
|
for name in allowed_names]
|
||||||
|
|
||||||
# Detect if the user uses the wrong hash algorithm
|
# Detect if the user uses the wrong hash algorithm
|
||||||
for w in hashlib.algorithms_guaranteed - {self.hash_choice}:
|
for w in hashlib.algorithms_guaranteed - {hash_choice}:
|
||||||
for name in itertools.chain(allowed_names, close_names):
|
for name in itertools.chain(allowed_names, close_names):
|
||||||
if hashlib.new(w, name.encode('utf-8')).hexdigest() in message.content.lower():
|
if hashlib.new(w, name.encode('utf-8')).hexdigest() in message.content.lower():
|
||||||
self.wrong_hash_algo = true
|
self.wrong_hash_algo = true
|
||||||
|
|
Loading…
Reference in a new issue