mirror of
https://github.com/alterware/aw-bot.git
synced 2025-10-26 06:05:54 +00:00
feat: DB for patterns
This commit is contained in:
14
Dockerfile
14
Dockerfile
@@ -2,13 +2,17 @@ FROM python:alpine
|
||||
|
||||
WORKDIR /aw-bot
|
||||
|
||||
COPY requirements.txt .
|
||||
RUN pip install --no-cache-dir -r requirements.txt
|
||||
COPY requirements.txt .
|
||||
RUN pip install --no-cache-dir -r requirements.txt
|
||||
|
||||
COPY bot /aw-bot/bot
|
||||
COPY aw.py .
|
||||
COPY patterns.json .
|
||||
COPY bot /aw-bot/bot
|
||||
COPY database /aw-bot/database
|
||||
COPY aw.py .
|
||||
COPY patterns.json .
|
||||
|
||||
ENV BOT_TOKEN=""
|
||||
|
||||
# Where the database will be stored
|
||||
ENV BOT_DATA_DIR = ""
|
||||
|
||||
CMD ["python", "aw.py"]
|
||||
|
||||
4
aw.py
4
aw.py
@@ -3,6 +3,8 @@ import os
|
||||
import discord
|
||||
from discord.ext import commands
|
||||
|
||||
from database import initialize_db
|
||||
|
||||
GUILD_ID = 1110531063161299074
|
||||
BOT_LOG = 1112049391482703873
|
||||
GENERAL_CHANNEL = 1110531063744303138
|
||||
@@ -11,6 +13,8 @@ OFFTOPIC_CHANNEL = 1112048063448617142
|
||||
intents = discord.Intents.all()
|
||||
bot = commands.Bot(command_prefix="!", intents=intents)
|
||||
|
||||
initialize_db()
|
||||
|
||||
|
||||
@bot.event
|
||||
async def on_ready():
|
||||
|
||||
@@ -3,6 +3,9 @@ from typing import Literal
|
||||
import discord
|
||||
from discord import app_commands
|
||||
|
||||
from database import add_pattern
|
||||
|
||||
from bot.config import update_patterns
|
||||
from bot.utils import compile_stats, fetch_game_stats, perform_search
|
||||
|
||||
GUILD_ID = 1110531063161299074
|
||||
@@ -25,6 +28,22 @@ async def setup(bot):
|
||||
|
||||
bot.tree.on_error = on_tree_error
|
||||
|
||||
@bot.tree.command(
|
||||
name="add_pattern",
|
||||
description="Add a new message pattern to the database.",
|
||||
guild=discord.Object(id=GUILD_ID),
|
||||
)
|
||||
@app_commands.checks.has_permissions(administrator=True)
|
||||
async def add_pattern_cmd(
|
||||
interaction: discord.Interaction, regex: str, response: str
|
||||
):
|
||||
"""Slash command to add a new message pattern to the database."""
|
||||
add_pattern(regex, response)
|
||||
update_patterns(regex, response)
|
||||
await interaction.response.send_message(
|
||||
f"Pattern added!\n**Regex:** `{regex}`\n**Response:** `{response}`"
|
||||
)
|
||||
|
||||
@bot.tree.command(
|
||||
name="search",
|
||||
description="Search for servers by hostname or IP.",
|
||||
|
||||
@@ -1,7 +1,43 @@
|
||||
import json
|
||||
import os
|
||||
from database import get_patterns, add_pattern
|
||||
|
||||
try:
|
||||
with open("patterns.json", "r") as f:
|
||||
message_patterns = json.load(f)
|
||||
except FileNotFoundError:
|
||||
message_patterns = [] # Fallback to an empty list if the file doesn't exist
|
||||
PATTERNS_FILE = "patterns.json"
|
||||
|
||||
BOT_DATA_DIR = os.getenv("BOT_DATA_DIR", "/bot-data")
|
||||
MIGRATION_FLAG = os.path.join(BOT_DATA_DIR, "migration_done.flag")
|
||||
|
||||
|
||||
def migrate_patterns():
|
||||
"""Migrate patterns.json to the database if not already done."""
|
||||
if os.path.exists(MIGRATION_FLAG):
|
||||
print("Not performing migration: already done")
|
||||
return
|
||||
|
||||
if not os.path.exists(PATTERNS_FILE):
|
||||
return
|
||||
|
||||
try:
|
||||
with open(PATTERNS_FILE, "r") as f:
|
||||
patterns = json.load(f)
|
||||
except (json.JSONDecodeError, FileNotFoundError):
|
||||
patterns = []
|
||||
|
||||
for pattern in patterns:
|
||||
add_pattern(pattern["regex"], pattern["response"])
|
||||
|
||||
with open(MIGRATION_FLAG, "w") as f:
|
||||
f.write("done")
|
||||
|
||||
print("Migration completed: patterns.json -> Database")
|
||||
|
||||
|
||||
migrate_patterns()
|
||||
|
||||
message_patterns = get_patterns()
|
||||
|
||||
|
||||
def update_patterns(regex: str, response: str):
|
||||
"""update patterns in memory."""
|
||||
message_patterns.append({"regex": regex, "response": response})
|
||||
print(f"Pattern added in memory: {regex}")
|
||||
|
||||
55
database/__init__.py
Normal file
55
database/__init__.py
Normal file
@@ -0,0 +1,55 @@
|
||||
import sqlite3
|
||||
import os
|
||||
|
||||
DB_DIR = os.getenv("BOT_DATA_DIR", "/bot-data")
|
||||
DB_PATH = os.path.join(DB_DIR, "database.db")
|
||||
|
||||
os.makedirs(DB_DIR, exist_ok=True)
|
||||
|
||||
|
||||
def initialize_db():
|
||||
"""Creates the database tables if they don't exist."""
|
||||
print(f"Opening database: {DB_PATH}")
|
||||
conn = sqlite3.connect(DB_PATH)
|
||||
cursor = conn.cursor()
|
||||
|
||||
with open(os.path.join(os.path.dirname(__file__), "schema.sql"), "r") as f:
|
||||
cursor.executescript(f.read())
|
||||
|
||||
conn.commit()
|
||||
conn.close()
|
||||
|
||||
|
||||
def add_pattern(regex: str, response: str):
|
||||
"""Adds a new pattern to the database."""
|
||||
conn = sqlite3.connect(DB_PATH)
|
||||
cursor = conn.cursor()
|
||||
|
||||
cursor.execute(
|
||||
"INSERT INTO message_patterns (regex, response) VALUES (?, ?)",
|
||||
(regex, response),
|
||||
)
|
||||
conn.commit()
|
||||
conn.close()
|
||||
|
||||
|
||||
def get_patterns():
|
||||
"""Fetches all regex-response pairs from the database."""
|
||||
conn = sqlite3.connect(DB_PATH)
|
||||
cursor = conn.cursor()
|
||||
|
||||
cursor.execute("SELECT regex, response FROM message_patterns")
|
||||
patterns = cursor.fetchall()
|
||||
conn.close()
|
||||
|
||||
return [{"regex": row[0], "response": row[1]} for row in patterns]
|
||||
|
||||
|
||||
def remove_pattern(pattern_id: int):
|
||||
"""Removes a pattern by ID."""
|
||||
conn = sqlite3.connect(DB_PATH)
|
||||
cursor = conn.cursor()
|
||||
|
||||
cursor.execute("DELETE FROM message_patterns WHERE id = ?", (pattern_id,))
|
||||
conn.commit()
|
||||
conn.close()
|
||||
5
database/schema.sql
Normal file
5
database/schema.sql
Normal file
@@ -0,0 +1,5 @@
|
||||
CREATE TABLE IF NOT EXISTS message_patterns (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
regex TEXT NOT NULL,
|
||||
response TEXT NOT NULL
|
||||
)
|
||||
@@ -330,5 +330,9 @@
|
||||
{
|
||||
"regex": "andrew tate",
|
||||
"response": "https://cdn.discordapp.com/attachments/1112049391482703873/1346497706964815952/GlEMX4TWQAAUqlc.jpg"
|
||||
},
|
||||
{
|
||||
"regex": "suicide",
|
||||
"response": "https://cdn.discordapp.com/attachments/1160511084143312959/1346587278499119234/Snapinst.app_video_AQPJue2aNWd3IuxSsCqEwyFbm7FweOLHfRPFQIfk4U7J9krpIydfGSTdmXqa04ozGljyxNCVBjqu-cHgEAw1LMX4ImX1Zr849d7cUc4.mp4"
|
||||
}
|
||||
]
|
||||
Reference in New Issue
Block a user