| """
|
| Database configuration and base models
|
| """
|
| from sqlalchemy import create_engine
|
| from sqlalchemy.ext.declarative import declarative_base
|
| from sqlalchemy.orm import sessionmaker
|
| import os
|
|
|
|
|
| DB_PATH = os.path.join(os.path.dirname(os.path.dirname(__file__)), 'data', 'vpn.db')
|
| os.makedirs(os.path.dirname(DB_PATH), exist_ok=True)
|
|
|
|
|
| SQLALCHEMY_DATABASE_URL = f"sqlite:///{DB_PATH}"
|
| engine = create_engine(
|
| SQLALCHEMY_DATABASE_URL, connect_args={"check_same_thread": False}
|
| )
|
|
|
|
|
| SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
|
|
|
|
| Base = declarative_base()
|
|
|
| def get_db():
|
| """Dependency to get database session"""
|
| db = SessionLocal()
|
| try:
|
| yield db
|
| finally:
|
| db.close()
|
|
|