2024-07-16 16:15:27 +02:00
|
|
|
#!/usr/bin/env python3.8
|
2021-06-06 22:08:18 +02:00
|
|
|
|
|
|
|
|
import discord
|
2024-07-17 15:52:39 +02:00
|
|
|
from discord.ext import commands, tasks
|
2021-07-15 22:17:05 +02:00
|
|
|
from jeevesbot import env
|
2024-07-17 15:52:39 +02:00
|
|
|
from jeevesbot.database import init_db, get_due_reminders
|
2021-07-15 22:17:05 +02:00
|
|
|
import os
|
2021-08-11 15:09:57 +02:00
|
|
|
import log
|
2021-08-11 20:02:47 +02:00
|
|
|
import logging.config
|
|
|
|
|
from logging import getLogger
|
2024-07-17 15:52:39 +02:00
|
|
|
import datetime
|
2022-11-09 14:10:46 +01:00
|
|
|
import asyncio
|
2021-06-06 22:08:18 +02:00
|
|
|
|
2021-08-11 20:02:47 +02:00
|
|
|
|
2024-07-17 15:52:39 +02:00
|
|
|
# Initialize the database
|
|
|
|
|
init_db()
|
|
|
|
|
|
|
|
|
|
|
2021-06-06 22:08:18 +02:00
|
|
|
# setup logging
|
2024-07-17 15:52:39 +02:00
|
|
|
logging.config.dictConfig(log.LOGGING)
|
2021-08-11 20:02:47 +02:00
|
|
|
log = getLogger(__name__)
|
2021-08-11 15:09:57 +02:00
|
|
|
|
2023-03-19 21:01:53 +01:00
|
|
|
|
2021-07-12 02:07:45 +02:00
|
|
|
# setup discord.py bot
|
|
|
|
|
intents = discord.Intents().all()
|
2024-07-17 15:52:39 +02:00
|
|
|
intents.message_content = True
|
2021-06-06 22:08:18 +02:00
|
|
|
e = discord.Embed()
|
2021-07-09 11:11:09 +02:00
|
|
|
|
2024-07-17 15:52:39 +02:00
|
|
|
class Jeeves(commands.Bot):
|
|
|
|
|
def __init__(self):
|
|
|
|
|
super().__init__(command_prefix='!', intents=intents, help_command=None)
|
|
|
|
|
self.guild_ids = [env.GUILD_ID]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@commands.command(name='load', hidden=True)
|
|
|
|
|
@commands.has_permissions(administrator=True)
|
|
|
|
|
async def load(self, ctx, extension):
|
|
|
|
|
self.load_extension(f'cogs.{extension}')
|
|
|
|
|
log.info(f'{ctx.message.author} loaded the {extension} module')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@commands.command(name='unload', hidden=True)
|
|
|
|
|
@commands.has_permissions(administrator=True)
|
|
|
|
|
async def unload(self, ctx, extension):
|
|
|
|
|
self.unload_extension(f'cogs.{extension}')
|
|
|
|
|
log.info(f'{ctx.message.author} unloaded the {extension} module')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@commands.command(name='reload', hidden=True)
|
|
|
|
|
@commands.has_permissions(administrator=True)
|
|
|
|
|
async def reload(self, ctx, extension):
|
|
|
|
|
self.unload_extension(f'cogs.{extension}')
|
|
|
|
|
self.load_extension(f'cogs.{extension}')
|
|
|
|
|
log.info(f'{ctx.message.author} reloaded the {extension} module')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def load_extensions(self):
|
|
|
|
|
for filename in os.listdir('./cogs'):
|
|
|
|
|
if filename.endswith('.py'):
|
|
|
|
|
await self.load_extension(f'cogs.{filename[:-3]}')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@tasks.loop(seconds=60)
|
|
|
|
|
async def check_reminders(self):
|
|
|
|
|
now = datetime.datetime.now().isoformat()
|
|
|
|
|
reminders = get_due_reminders(now)
|
|
|
|
|
for reminder in reminders:
|
|
|
|
|
user = self.get_user(reminder[1])
|
|
|
|
|
if user:
|
|
|
|
|
try:
|
|
|
|
|
await user.send(reminder[2])
|
|
|
|
|
except Exception as e:
|
|
|
|
|
log.error(f'Error sending reminder to user {reminder[1]}: {e}')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def on_ready(self):
|
|
|
|
|
log.info(f'Active with ID:{self.user.id} as {self.user.name}')
|
|
|
|
|
activity = discord.Activity(name='!help', type=discord.ActivityType.listening)
|
|
|
|
|
await self.change_presence(activity=activity)
|
|
|
|
|
# Sync commands for all guilds
|
|
|
|
|
for guild_id in self.guild_ids:
|
|
|
|
|
guild = discord.Object(id=guild_id)
|
|
|
|
|
try:
|
|
|
|
|
await self.tree.sync(guild=guild)
|
|
|
|
|
log.info(f'Successfully synced commands for guild {guild_id}')
|
|
|
|
|
except discord.errors.Forbidden as e:
|
|
|
|
|
log.error(f'Failed to sync commands for guild {guild_id}: {e}')
|
|
|
|
|
# Start the reminder check loop
|
|
|
|
|
if not self.check_reminders.is_running():
|
|
|
|
|
self.check_reminders.start()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def on_command_error(self, ctx, error):
|
|
|
|
|
if isinstance(error, commands.CommandNotFound):
|
|
|
|
|
await ctx.send('Command not found.')
|
|
|
|
|
log.warning(f'Command not found: {ctx.message.content}')
|
|
|
|
|
else:
|
|
|
|
|
await ctx.send('An error occurred.')
|
|
|
|
|
log.error(f'An error occurred: {error}')
|
2021-06-06 22:08:18 +02:00
|
|
|
|
2023-03-19 21:01:53 +01:00
|
|
|
|
2022-11-09 14:10:46 +01:00
|
|
|
async def main():
|
2024-07-17 15:52:39 +02:00
|
|
|
bot = Jeeves()
|
|
|
|
|
await bot.load_extensions()
|
|
|
|
|
await bot.start(env.TOKEN)
|
2023-03-19 21:01:53 +01:00
|
|
|
|
2024-07-17 15:52:39 +02:00
|
|
|
if __name__ == "__main__":
|
|
|
|
|
asyncio.run(main())
|