"""共享API管理模型""" from sqlalchemy import Column, Integer, String, Text, Boolean, DateTime, ForeignKey from sqlalchemy.sql import func from database import Base class SharedApiCategory(Base): """API分类""" __tablename__ = "shared_api_categories" id = Column(Integer, primary_key=True, index=True) name = Column(String(100), nullable=False, unique=True) icon = Column(String(500), default="") sort_order = Column(Integer, default=0) is_active = Column(Boolean, default=True, nullable=False) created_at = Column(DateTime(timezone=True), server_default=func.now()) class SharedApi(Base): """共享API""" __tablename__ = "shared_apis" id = Column(Integer, primary_key=True, index=True) category_id = Column(Integer, ForeignKey("shared_api_categories.id"), nullable=True, index=True) name = Column(String(200), nullable=False) description = Column(Text, default="") base_url = Column(String(500), nullable=False) doc_url = Column(String(500), default="") # 认证方式: none / api_key / bearer / basic auth_type = Column(String(20), default="none") # 加密存储的API Key api_key_encrypted = Column(Text, default="") # API Key 放在哪个请求头中, 如 Authorization, X-API-Key api_key_header = Column(String(100), default="Authorization") # 健康检查 health_check_url = Column(String(500), default="") last_check_time = Column(DateTime(timezone=True), nullable=True) last_check_status = Column(String(20), default="unknown") # ok / error / unknown # 元信息 added_by = Column(Integer, ForeignKey("users.id"), nullable=True) tags = Column(String(500), default="") # 逗号分隔 call_count = Column(Integer, default=0) is_active = Column(Boolean, default=True, nullable=False) created_at = Column(DateTime(timezone=True), server_default=func.now()) updated_at = Column(DateTime(timezone=True), server_default=func.now(), onupdate=func.now()) class SharedApiLog(Base): """API使用日志""" __tablename__ = "shared_api_logs" id = Column(Integer, primary_key=True, index=True) api_id = Column(Integer, ForeignKey("shared_apis.id"), nullable=False, index=True) user_id = Column(Integer, ForeignKey("users.id"), nullable=True) action = Column(String(20), default="test") # test / health_check request_url = Column(String(500), default="") response_status = Column(Integer, nullable=True) response_time_ms = Column(Integer, nullable=True) created_at = Column(DateTime(timezone=True), server_default=func.now())