2024-06-18 23:19:31 -04:00
|
|
|
import discord
|
|
|
|
from discord.ext import commands
|
|
|
|
import aiosqlite
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import subprocess
|
2024-06-18 23:44:13 -04:00
|
|
|
import asyncio
|
2024-06-18 23:19:31 -04:00
|
|
|
from dotenv import load_dotenv
|
|
|
|
|
|
|
|
load_dotenv()
|
|
|
|
|
|
|
|
TOKEN = os.getenv('DISCORD_TOKEN')
|
2024-06-19 08:18:39 -04:00
|
|
|
GUILD_ID = int(os.getenv('GUILD_ID'))
|
2024-06-18 23:19:31 -04:00
|
|
|
|
|
|
|
intents = discord.Intents.default()
|
|
|
|
intents.message_content = True
|
|
|
|
intents.members = True
|
|
|
|
|
|
|
|
|
2024-06-18 23:44:13 -04:00
|
|
|
class Ariella(commands.Bot):
|
2024-06-18 23:19:31 -04:00
|
|
|
def __init__(self):
|
2024-06-18 23:44:13 -04:00
|
|
|
super().__init__(command_prefix='!', intents=intents)
|
2024-06-18 23:19:31 -04:00
|
|
|
|
|
|
|
async def setup_hook(self):
|
|
|
|
await self.load_extension('commands')
|
2024-06-19 08:18:39 -04:00
|
|
|
self.tree.copy_global_to(guild=discord.Object(id=GUILD_ID))
|
|
|
|
await self.tree.sync(guild=discord.Object(id=GUILD_ID))
|
2024-06-18 23:19:31 -04:00
|
|
|
|
|
|
|
|
|
|
|
bot = Ariella()
|
|
|
|
|
|
|
|
|
|
|
|
# Database setup
|
|
|
|
async def init_db():
|
2024-06-19 07:59:32 -04:00
|
|
|
async with aiosqlite.connect("ariella.db") as db:
|
2024-06-18 23:19:31 -04:00
|
|
|
await db.execute("""
|
|
|
|
CREATE TABLE IF NOT EXISTS user_notes (
|
|
|
|
user_id INTEGER PRIMARY KEY,
|
|
|
|
notes TEXT,
|
|
|
|
strikes INTEGER
|
|
|
|
)
|
|
|
|
""")
|
|
|
|
await db.commit()
|
|
|
|
|
|
|
|
|
|
|
|
@bot.event
|
|
|
|
async def on_ready():
|
|
|
|
print(f'Logged in as {bot.user} (ID: {bot.user.id})')
|
|
|
|
print('------')
|
|
|
|
await init_db()
|
|
|
|
|
|
|
|
|
|
|
|
@bot.event
|
|
|
|
async def on_guild_join(guild):
|
|
|
|
await bot.tree.sync(guild=guild)
|
|
|
|
|
2024-06-18 23:44:13 -04:00
|
|
|
bot.run(TOKEN)
|