diff options
author | Joe Robinson <joe@lc8n.com> | 2021-11-28 18:43:28 +0000 |
---|---|---|
committer | Joe Robinson <joe@lc8n.com> | 2021-11-28 18:43:28 +0000 |
commit | e8be5f63b792845bff0bef0b277c888b268b83c0 (patch) | |
tree | f8b12be9e3bdd81a24f81d8bd4c744b3afa0042d | |
parent | dfade65d2859188de22be990f4cbc1f0c7602735 (diff) |
Add handlers for exp and mee6
-rw-r--r-- | exp.py | 54 | ||||
-rw-r--r-- | mee6.py | 0 |
2 files changed, 54 insertions, 0 deletions
@@ -0,0 +1,54 @@ +import datetime +import random +from base import config +from models.level import Level +from models.user import User +from discord import TextChannel + + +class Exp: + def __init__(self, user: User, bot_channel: TextChannel): + self.user = user + self.channel = bot_channel + + async def calculate_exp(self): + self.add_message(self.user) + gained_exp = self.gain_exp(self.user) + if gained_exp: + if self.check_level_up(self.user): + await self.level_up(self.user, self.channel) + + def add_message(self, user: User): + messages = user.message_count + user.message_count = messages + 1 + user.save() + + def gain_exp(self, user: User): + time_now = datetime.datetime.utcnow() + minute_ago = time_now - datetime.timedelta(seconds=60) + print(f"now: {time_now}, minute: {minute_ago}, user: {user.exp_gained_time}") + if user.exp_gained_time is None or user.exp_gained_time < minute_ago: + gained_exp = random.randrange(15, 25) + total_exp = user.exp + gained_exp + user.exp = total_exp + user.exp_gained_time = time_now + user.save() + return True + else: + return False + + def check_level_up(self, user: User): + next_level = Level.get(user.level + 1) + if user.exp > next_level.exp_required: + return True + else: + return False + + async def level_up(self, user: User, channel: TextChannel): + user.level += 1 + level = Level.get(level=user.level) + user.currency += level.reward_currency + await channel.send( + f"Congrats {user.display_name}, you levelled up to {user.level}! You win {level.reward_currency} {config['currency']}!" + ) + user.save() |