Spaces:
Running
Running
| import os | |
| from sqlalchemy import create_engine, Column, Integer, String, Text, DateTime, ForeignKey, Boolean | |
| from sqlalchemy.orm import sessionmaker, declarative_base, relationship | |
| from datetime import datetime, timezone | |
| # --- 1. DATABASE CONNECTION SETUP --- | |
| # π₯ Step A: Environment se Database URL uthao | |
| DATABASE_URL = os.getenv("DATABASE_URL", "sqlite:///./avii_pro.db") | |
| # π₯ Step B: Render/Railway/Neon Fix (PostgreSQL URL correction) | |
| # Cloud providers aksar 'postgres://' dete hain, par SQLAlchemy ko 'postgresql://' chahiye. | |
| if DATABASE_URL and DATABASE_URL.startswith("postgres://"): | |
| DATABASE_URL = DATABASE_URL.replace("postgres://", "postgresql://", 1) | |
| # π₯ Step C: Engine Arguments Logic (UPDATED FOR NEON STABILITY) | |
| engine_args = {} | |
| if "sqlite" in DATABASE_URL: | |
| # SQLite ko "check_same_thread" chahiye hota hai | |
| engine_args["connect_args"] = {"check_same_thread": False} | |
| else: | |
| # π’ POSTGRESQL / NEON SPECIFIC SETTINGS (Ye hai wo Fix) | |
| engine_args["pool_pre_ping"] = True # Connection use karne se pehle check karega "Zinda hai ya nahi" | |
| engine_args["pool_recycle"] = 300 # Har 5 minute (300s) mein connection refresh karega taaki Neon disconnect na kare | |
| engine_args["pool_size"] = 10 # 10 Connections hamesha ready rakhega | |
| engine_args["max_overflow"] = 20 # Load badhne par 20 tak ja sakta hai | |
| # Engine Create karo (Arguments pass kar diye) | |
| engine = create_engine(DATABASE_URL, **engine_args) | |
| SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine) | |
| Base = declarative_base() | |
| # --- 2. DATABASE MODELS (TABLES) --- | |
| class User(Base): | |
| __tablename__ = "users" | |
| id = Column(Integer, primary_key=True, index=True) | |
| email = Column(String, unique=True, index=True) | |
| hashed_password = Column(String) | |
| is_active = Column(Boolean, default=True) # User account status | |
| # π₯ Role Column (Admin Panel ke liye) | |
| role = Column(String, default="user") | |
| # User delete hoga toh uske sessions bhi udd jayenge | |
| sessions = relationship("ChatSession", back_populates="owner", cascade="all, delete-orphan") | |
| class ChatSession(Base): | |
| __tablename__ = "sessions" | |
| id = Column(String, primary_key=True, index=True) # Frontend se UUID aayega | |
| user_id = Column(Integer, ForeignKey("users.id")) | |
| title = Column(String) | |
| created_at = Column(DateTime, default=lambda: datetime.now(timezone.utc)) | |
| owner = relationship("User", back_populates="sessions") | |
| # Session delete hoga toh uske messages bhi udd jayenge | |
| messages = relationship("ChatMessage", back_populates="session", cascade="all, delete-orphan") | |
| class ChatMessage(Base): | |
| __tablename__ = "messages" | |
| id = Column(Integer, primary_key=True, index=True) | |
| session_id = Column(String, ForeignKey("sessions.id")) | |
| role = Column(String) # 'user' or 'model' | |
| content = Column(Text) | |
| timestamp = Column(DateTime, default=lambda: datetime.now(timezone.utc)) | |
| session = relationship("ChatSession", back_populates="messages") | |
| # --- 3. CREATE TABLES --- | |
| # Ye line automatic tables bana degi (Local ya Cloud dono jagah) | |
| Base.metadata.create_all(bind=engine) | |
| # --- 4. DEPENDENCY --- | |
| def get_db(): | |
| db = SessionLocal() | |
| try: | |
| yield db | |
| finally: | |
| db.close() |