Untitled

mail@pastecode.io avatar
unknown
plain_text
5 months ago
1.9 kB
3
Indexable
import discord
from discord.ext import commands
from .DataBase import Database  # Ensure the correct import path
from mysql.connector import Error

class NewGuild(commands.Cog):
    def __init__(self, bot, db: Database):
        self.bot = bot
        self.db = db

    @commands.Cog.listener()
    async def on_guild_join(self, guild):
        await self.bot.wait_until_ready()  # Ensure the bot is ready before accessing DB
        self.create_guild_db(guild.id)

    def create_guild_db(self, guild_id):
        connection = None
        cursor = None
        try:
            create_table_query = f"""
                CREATE TABLE IF NOT EXISTS G_{guild_id} (
                    User VARCHAR(255) NOT NULL UNIQUE PRIMARY KEY,
                    Warns BIGINT NULL,
                    Xp BIGINT NULL,
                    Level BIGINT NULL,
                    Admin_Power BIGINT NULL
                );
            """
            # Get the database connection
            connection = self.db.get_connection()
            if connection is None:
                raise ConnectionError("Failed to obtain database connection.")

            cursor = connection.cursor()
            cursor.execute(create_table_query)
            print(f"Table 'G_{guild_id}' created successfully or already exists.")

        except ConnectionError as e:
            print(f"Connection Error: {e}")
        except Error as e:
            print(f"Database Error: {e}")
        except Exception as e:
            print(f"Unexpected Error: {e}")
        finally:
            if cursor:
                cursor.close()
            if connection:
                connection.close()

async def setup(bot):
    db = Database(host='host', user='user', password='pass', database='DB')
    await bot.add_cog(NewGuild(bot, db))
Leave a Comment