Quiz system permissions fix

This commit is contained in:
2020-11-10 00:52:54 +01:00
parent 714093fd34
commit 6e6e3a1b34
4 changed files with 42 additions and 24 deletions

View File

@@ -1,4 +1,5 @@
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
@@ -28,20 +29,20 @@ public class RedeemCommandListeners implements Listener, CommandExecutor {
dbConn.remove_toclaim(discordid);
Bukkit.dispatchCommand(Bukkit.getConsoleSender(), "eco give " + p.getName() + rewards);
p.sendMessage("You received " + rewards + " dollars!");
p.sendMessage(ChatColor.GREEN + "You received " + rewards + " dollars!");
return true;
}else{
p.sendMessage("You have no money to claim!");
p.sendMessage(ChatColor.RED + "You have no money to claim!");
}
}else{
p.sendMessage("Your account is not linked with discord");
p.sendMessage(ChatColor.RED + "Your account is not linked with discord");
}
return true;
}
}else{
sender.sendMessage("Only players can use this command!");
sender.sendMessage(ChatColor.RED + "Only players can use this command!");
return true;
}

View File

@@ -133,7 +133,7 @@ class PlayerLink(commands.Cog):
except SQLInsertError:
await message.edit(embed=create_embed(ctx.author, arg, timer))
finally:
dbLinker.closeconnections()
dbLinker.close()
else:
# this stops the timer task
timer.stop()
@@ -159,7 +159,7 @@ class PlayerLink(commands.Cog):
except PlayerNotLinked:
await ctx.send("Player not linked!")
finally:
dbLinker.closeconnections()
dbLinker.close()
def setup(client):

View File

@@ -6,13 +6,14 @@ import threading
import random
from functions.timer import Timer
from data.DatabaseConnection import *
from functions import checks
class QuizQuestions(commands.Cog):
def __init__(self, client):
self.client = client
@commands.group(name="q&a",case_insensitive=True, invoke_without_command=True)
@commands.check(checks.isModPlus)
# /q&a add "What is ...." "Australia"
async def questions(self, ctx, f, *args):
if (f == "add"):
@@ -75,11 +76,12 @@ class Quiz(commands.Cog):
def __init__(self, client):
self.client = client
self.in_progress = False
self.interval = (5, 10)
#self.interval = (6*60, 30*60)
#self.interval = (5, 10)
self.interval = (8*60, 30*60)
self.auto = False
@commands.command(name="quiz")
@commands.check(checks.isModPlus)
async def quiz_bot(self, ctx, f, *args):
if (f == "auto" and not self.auto):
self.auto = True
@@ -105,8 +107,16 @@ class Quiz(commands.Cog):
channel = self.client.get_channel(constants.QuizChannelID)
self.in_progress = True
answer_timer = Timer(10, 0)
await channel.send(self.question[1])
answer_timer = Timer(1, 0)
embed = discord.Embed()
#embed.set_author(name="Quiz")
embed.colour = discord.Colour.orange()
embed.add_field(name="Question:", value=f"{self.question[1]}", inline=False)
embed.add_field(name="Reward:", value=f"${self.question[3]}", inline=False)
self.embed = embed
await channel.send(embed=embed)
answer_timer.start()
while not answer_timer.ended and self.in_progress:
await asyncio.sleep(1)
@@ -114,7 +124,9 @@ class Quiz(commands.Cog):
answer_timer.stop()
else:
self.in_progress = False
await channel.send("The answer was : " + self.question[2])
embed.colour = discord.Colour.red()
embed.add_field(name="Answer:", value=f"{self.question[2]}", inline=False)
await channel.send(embed=embed)
@commands.Cog.listener()
@@ -125,11 +137,23 @@ class Quiz(commands.Cog):
if message.content.lower() == self.question[2].lower():
self.in_progress = False
userlinked = self.give_reward(message.author.id, self.question[3])
if userlinked:
await message.channel.send(f"{message.author.mention} Won 🎉🎉")
self.give_reward(message.author.id, self.question[3])
playerdblinker = PlayerDBLinker()
self.embed.colour = discord.Colour.green()
if playerdblinker.discordidused(message.author.id):
self.embed.add_field(name="Answer:", value=f"{self.question[2]}", inline=False)
self.embed.add_field(name="Winner:", value=f"{message.author.mention} 🎉🎉", inline=False)
#self.embed.add_field(name="Claim:", value=f"Claim your reward in Minecraft by using /redeem")
self.embed.add_field(name="Claim:", value=f"Claim your reward in Minecraft when the server is online")
await message.channel.send(embed=self.embed)
else:
await message.channel.send(f"{message.author.mention} Won 🎉🎉! To claim? Link your minecraft account")
self.embed.add_field(name="Answer:", value=f"{self.question[2]}", inline=False)
self.embed.add_field(name="Winner:", value=f"{message.author.mention} 🎉🎉", inline=False)
#self.embed.add_field(name="Claim:", value=f"1. Link your account by using /link <MinecraftName> \n2. Claim your reward in Minecraft by using /redeem")
self.embed.add_field(name="Claim:", value=f"Claim your reward in Minecraft when the server is online")
await message.channel.send(embed=self.embed)
playerdblinker.close()
def increment_asked_count(self, q_id):
quizdb = QuizDB()
@@ -148,13 +172,6 @@ class Quiz(commands.Cog):
quiz_players_db.close()
def setup(client):
client.add_cog(QuizQuestions(client))
client.add_cog(Quiz(client))

View File

@@ -202,6 +202,6 @@ class PlayerDBLinker:
else:
raise PlayerNotLinked()
def closeconnections(self):
def close(self):
self.discorddbconn.close()
self.serverdbconn.close()