-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbot.py
96 lines (80 loc) · 3.29 KB
/
bot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import discord
from discord.ext import commands
import logging
import os
from dotenv import load_dotenv
from cmds import setup_commands
from utils.ai_process import process_ai_response
from utils.database import get_blacklist
from utils.user_manager import set_guilds
from utils.langs import get_translation as tlt
from datetime import datetime, timedelta
from supabase import create_client, Client, ClientOptions
from discord.ext import tasks
import time
import json
load_dotenv()
TOKEN = os.getenv("BOT_TOKEN")
PREFIX = os.getenv("BOT_PREFIX")
GUILD_ID = int(os.getenv("GUILD_ID"))
intents = discord.Intents.default()
bot = commands.Bot(command_prefix=PREFIX,
owner_id=int(os.getenv("DEV_ID")),
intents=intents)
supabase = Client(
os.getenv("DB_URL"),
os.getenv("DB_KEY"),
options=ClientOptions(headers={"Authorization": f"Bearer {os.getenv('JWT_KEY')}"})
)
logger = logging.getLogger("AlphaLLM")
@bot.event
async def on_ready():
logger.info(f'{bot.user} connecté !')
activity = discord.CustomActivity(name="🌍 alphallm.fr.nf")
await bot.change_presence(activity=activity, status=discord.Status.idle)
logger.info("Statut mis à jour")
logger.info("Synchronisation des commandes...")
await bot.tree.sync()
guild = discord.Object(id=GUILD_ID)
await bot.tree.sync(guild=guild)
@bot.event
async def on_message(message):
if message.author.bot:
return
if not message.author.bot and message.channel.type == discord.ChannelType.text:
logger.debug(f"Message reçu de {message.author}: {message.content}")
bot_mentioned = (
bot.user.mentioned_in(message)
or any(role in message.role_mentions for role in message.guild.me.roles)
)
if bot_mentioned:
try:
blacklist_data = get_blacklist()
if any(entry.get('id_discord') == message.author.id for entry in blacklist_data):
logger.info(f"Message de {message.author} (ID: {message.author.id}) ignoré - Liste noire")
try:
await message.author.send("Vous êtes sur liste noire et ne pouvez pas interagir avec le bot.")
except discord.Forbidden:
logger.warning(f"Impossible de DM l'utilisateur {message.author.id}")
await message.channel.send("Vous êtes sur liste noire et ne pouvez pas interagir avec le bot.")
return
except Exception as e:
logger.error(f"Erreur vérification liste noire : {str(e)}")
await message.channel.send("Erreur système - Veuillez réessayer plus tard", delete_after=10)
return
await process_ai_response(message)
async def run_bot():
logger.info("Démarrage du bot en cours...")
await setup_commands(bot)
logger.info("Configuration des commandes terminée")
try:
await bot.start(TOKEN)
logger.info(f'{bot.user} connecté !')
except discord.LoginFailure as e:
logger.error(f"Erreur de connexion : {e}")
except Exception as e:
logger.error(f"Erreur inattendue : {e}")
await bot.close()
finally:
logger.info("Arrêt du bot.")
raise SystemExit(0)