Spaces:
Sleeping
Sleeping
| import json | |
| from sqlalchemy import create_engine, Column, Integer, String, Text, DateTime, ForeignKey, func | |
| from sqlalchemy.ext.declarative import declarative_base | |
| from sqlalchemy.orm import sessionmaker, relationship | |
| from sqlalchemy.types import TypeDecorator, TEXT | |
| # Custom type for JSON storage | |
| class JSONText(TypeDecorator): | |
| impl = TEXT | |
| def process_bind_param(self, value, dialect): | |
| if value is not None: | |
| return json.dumps(value) | |
| return None | |
| def process_result_value(self, value, dialect): | |
| if value is not None: | |
| return json.loads(value) | |
| return None | |
| # Database connection URL (using SQLite) | |
| DATABASE_URL = "sqlite:///./api_proxy.db" | |
| # Create SQLAlchemy engine | |
| engine = create_engine(DATABASE_URL, connect_args={"check_same_thread": False}) | |
| # Create a configured "Session" class | |
| SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine) | |
| # Base class for declarative models | |
| Base = declarative_base() | |
| # Define the KeyCategory model | |
| class KeyCategory(Base): | |
| __tablename__ = "key_categories" | |
| id = Column(Integer, primary_key=True, index=True) | |
| name = Column(String, unique=True, index=True, nullable=False) | |
| type = Column(String, nullable=False) | |
| tags = Column(JSONText) # Stored as JSON string | |
| metadata_ = Column(JSONText, name="metadata") # Map to 'metadata' column in DB | |
| api_keys = relationship("APIKey", back_populates="category") | |
| created_at = Column(DateTime, server_default=func.now()) | |
| updated_at = Column(DateTime, server_default=func.now(), onupdate=func.now()) | |
| # Define the APIKey model | |
| class APIKey(Base): | |
| __tablename__ = "api_keys" | |
| id = Column(Integer, primary_key=True, index=True) | |
| value = Column(String, nullable=False) | |
| category_id = Column(Integer, ForeignKey("key_categories.id"), nullable=False) | |
| status = Column(String, default="active", nullable=False) # 'active', 'inactive' | |
| usage_count = Column(Integer, default=0, nullable=False) | |
| last_used = Column(DateTime) | |
| metadata_ = Column(JSONText, name="metadata") # Map to 'metadata' column in DB | |
| category = relationship("KeyCategory", back_populates="api_keys") | |
| created_at = Column(DateTime, server_default=func.now()) | |
| updated_at = Column(DateTime, server_default=func.now(), onupdate=func.now()) | |
| # Function to create database tables | |
| def create_db_tables(): | |
| Base.metadata.create_all(bind=engine) | |
| # Dependency to get DB session | |
| def get_db(): | |
| db = SessionLocal() | |
| try: | |
| yield db | |
| finally: | |
| db.close() | |