2016-07-09 13:27:19 +12:00
|
|
|
from discord.ext import commands
|
|
|
|
from .utils import config
|
2016-07-17 04:49:14 +12:00
|
|
|
from .utils import checks
|
2016-07-09 13:27:19 +12:00
|
|
|
from threading import Timer
|
2016-07-09 13:42:33 +12:00
|
|
|
import discord
|
2016-07-09 13:27:19 +12:00
|
|
|
import random
|
|
|
|
|
|
|
|
battling = False
|
|
|
|
battleP1 = None
|
|
|
|
battleP2 = None
|
|
|
|
|
|
|
|
|
|
|
|
def battlingOff():
|
|
|
|
global battleP1
|
|
|
|
global battleP2
|
|
|
|
global battling
|
|
|
|
battling = False
|
|
|
|
battleP1 = ""
|
|
|
|
battleP2 = ""
|
|
|
|
|
|
|
|
|
|
|
|
def updateBattleRecords(winner, loser):
|
2016-07-18 03:17:47 +12:00
|
|
|
battles = config.getContent('battle_records')
|
|
|
|
if battles is not None:
|
|
|
|
record = battles.get(winner.id)
|
|
|
|
if record is not None:
|
|
|
|
result = record.split('-')
|
|
|
|
result[0] = str(int(result[0]) + 1)
|
2016-07-18 05:23:18 +12:00
|
|
|
battles[winner.id] = "-".join(result)
|
2016-07-18 03:17:47 +12:00
|
|
|
record = battles.get(loser.id)
|
|
|
|
if record is not None:
|
|
|
|
result = record.split('-')
|
|
|
|
result[1] = str(int(result[1]) + 1)
|
2016-07-18 05:23:18 +12:00
|
|
|
battles[loser.id] = "-".join(result)
|
2016-07-09 13:27:19 +12:00
|
|
|
else:
|
2016-07-18 03:17:47 +12:00
|
|
|
battles = {winner.id:"1-0",loser.id:"0-1"}
|
|
|
|
config.saveContent('battle_records',battles)
|
2016-07-09 13:27:19 +12:00
|
|
|
|
|
|
|
|
|
|
|
class Interaction:
|
2016-07-09 13:59:10 +12:00
|
|
|
"""Commands that interact with another user"""
|
2016-07-09 13:27:19 +12:00
|
|
|
def __init__(self, bot):
|
|
|
|
self.bot = bot
|
|
|
|
|
|
|
|
@commands.command(pass_context=True, no_pm=True)
|
2016-07-17 04:48:10 +12:00
|
|
|
@checks.customPermsOrRole("none")
|
2016-07-09 13:42:33 +12:00
|
|
|
async def battle(self, ctx, player2: discord.Member):
|
2016-07-09 13:27:19 +12:00
|
|
|
"""Challenges the mentioned user to a battle"""
|
2016-07-10 00:57:25 +12:00
|
|
|
global battleP1
|
|
|
|
global battleP2
|
|
|
|
global battling
|
|
|
|
if battling:
|
|
|
|
return
|
|
|
|
if len(ctx.message.mentions) == 0:
|
|
|
|
await self.bot.say("You must mention someone in the room " + ctx.message.author.mention + "!")
|
|
|
|
return
|
|
|
|
if len(ctx.message.mentions) > 1:
|
|
|
|
await self.bot.say("You cannot battle more than one person at once!")
|
|
|
|
return
|
|
|
|
if ctx.message.author.id == player2.id:
|
|
|
|
await self.bot.say("Why would you want to battle yourself? Suicide is not the answer")
|
|
|
|
return
|
|
|
|
if self.bot.user.id == player2.id:
|
|
|
|
await self.bot.say("I always win, don't even try it.")
|
|
|
|
return
|
|
|
|
fmt = "{0.mention} has challenged you to a battle {1.mention}\n!accept or !decline"
|
|
|
|
battleP1 = ctx.message.author
|
|
|
|
battleP2 = player2
|
|
|
|
await self.bot.say(fmt.format(ctx.message.author, player2))
|
|
|
|
t = Timer(180, battlingOff)
|
|
|
|
t.start()
|
|
|
|
battling = True
|
2016-07-09 13:27:19 +12:00
|
|
|
|
2016-07-11 09:57:52 +12:00
|
|
|
@commands.command(pass_context=True, no_pm=True)
|
2016-07-17 04:48:10 +12:00
|
|
|
@checks.customPermsOrRole("none")
|
2016-07-11 09:57:52 +12:00
|
|
|
async def accept(self, ctx):
|
2016-07-09 13:27:19 +12:00
|
|
|
"""Accepts the battle challenge"""
|
2016-07-11 09:57:52 +12:00
|
|
|
if not battling or battleP2 != ctx.message.author:
|
2016-07-10 00:57:25 +12:00
|
|
|
return
|
|
|
|
num = random.randint(1, 100)
|
|
|
|
fmt = config.battleWins[random.randint(0, len(config.battleWins) - 1)]
|
|
|
|
if num <= 50:
|
|
|
|
await self.bot.say(fmt.format(battleP1.mention, battleP2.mention))
|
|
|
|
updateBattleRecords(battleP1, battleP2)
|
2016-07-11 10:01:27 +12:00
|
|
|
battlingOff()
|
2016-07-10 00:57:25 +12:00
|
|
|
elif num > 50:
|
|
|
|
await self.bot.say(fmt.format(battleP2.mention, battleP1.mention))
|
|
|
|
updateBattleRecords(battleP2, battleP1)
|
|
|
|
battlingOff()
|
|
|
|
|
2016-07-11 09:57:52 +12:00
|
|
|
@commands.command(pass_context=True, no_pm=True)
|
2016-07-17 04:48:10 +12:00
|
|
|
@checks.customPermsOrRole("none")
|
2016-07-11 09:57:52 +12:00
|
|
|
async def decline(self, ctx):
|
2016-07-09 13:27:19 +12:00
|
|
|
"""Declines the battle challenge"""
|
2016-07-11 09:57:52 +12:00
|
|
|
if not battling or battleP2 != ctx.message.author:
|
2016-07-10 00:57:25 +12:00
|
|
|
return
|
|
|
|
await self.bot.say("{0} has chickened out! {1} wins by default!".format(battleP2.mention, battleP1.mention))
|
|
|
|
updateBattleRecords(battleP1, battleP2)
|
|
|
|
battlingOff()
|
2016-07-10 06:27:14 +12:00
|
|
|
|
2016-07-09 13:27:19 +12:00
|
|
|
@commands.command(pass_context=True, no_pm=True)
|
2016-07-17 04:48:10 +12:00
|
|
|
@checks.customPermsOrRole("none")
|
2016-07-09 13:42:33 +12:00
|
|
|
async def boop(self, ctx, boopee: discord.Member):
|
2016-07-09 13:27:19 +12:00
|
|
|
"""Boops the mentioned person"""
|
2016-07-10 00:57:25 +12:00
|
|
|
booper = ctx.message.author
|
|
|
|
if len(ctx.message.mentions) == 0:
|
|
|
|
await self.bot.say("You must mention someone in the room " + ctx.message.author.mention + "!")
|
|
|
|
return
|
|
|
|
if len(ctx.message.mentions) > 1:
|
|
|
|
await self.bot.say("You cannot boop more than one person at once!")
|
|
|
|
return
|
|
|
|
if boopee.id == booper.id:
|
|
|
|
await self.bot.say("You can't boop yourself! Silly...")
|
|
|
|
return
|
|
|
|
if boopee.id == self.bot.user.id:
|
|
|
|
await self.bot.say("Why the heck are you booping me? Get away from me >:c")
|
|
|
|
return
|
|
|
|
|
2016-07-18 03:17:47 +12:00
|
|
|
boops = config.getContent('boops')
|
|
|
|
if boops is None:
|
|
|
|
boops = {}
|
2016-07-10 00:57:25 +12:00
|
|
|
amount = 1
|
2016-07-18 03:17:47 +12:00
|
|
|
booper_boops = boops.get(ctx.message.author.id)
|
|
|
|
if booper_boops is None:
|
|
|
|
boops[ctx.message.author.id] = {boopee.id:1}
|
|
|
|
elif booper_boops.get(boopee.id) is None:
|
|
|
|
booper_boops[boopee.id] = 1
|
|
|
|
boops[ctx.message.author.id] = booper_boops
|
2016-07-10 00:57:25 +12:00
|
|
|
else:
|
2016-07-18 03:17:47 +12:00
|
|
|
amount = booper_boops.get(boopee.id) + 1
|
|
|
|
booper_boops[boopee.id] = amount
|
|
|
|
boops[ctx.message.author.id] = booper_boops
|
|
|
|
|
|
|
|
config.saveContent('boops',boops)
|
2016-07-10 00:57:25 +12:00
|
|
|
fmt = "{0.mention} has just booped you {1.mention}! That's {2} times now!"
|
|
|
|
await self.bot.say(fmt.format(booper, boopee, amount))
|
2016-07-09 13:27:19 +12:00
|
|
|
|
|
|
|
|
|
|
|
def setup(bot):
|
|
|
|
bot.add_cog(Interaction(bot))
|