LightRAG/service/init_db.py

34 lines
1 KiB
Python

import sys
import os
import logging
# Add the service directory to sys.path
sys.path.append(os.path.dirname(os.path.abspath(__file__)))
from dotenv import load_dotenv
load_dotenv(os.path.join(os.path.dirname(os.path.abspath(__file__)), "../.env"))
from app.core.database import engine, Base, SessionLocal
from app.models.models import ChatSession, ChatMessage, MessageCitation # Import models to register them
from app.core.config import settings
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)
def init_db():
logger.info("Creating database tables...")
try:
Base.metadata.create_all(bind=engine)
logger.info("Tables created successfully!")
# Create default users from AUTH_ACCOUNTS
# User table removed, so we don't need to create users anymore.
# Logic kept as comment or removed.
logger.info("Database initialized.")
except Exception as e:
logger.error(f"Error creating tables: {e}")
raise
if __name__ == "__main__":
init_db()