初始提交:极码 GeekCode 全栈项目(FastAPI + Vue3)
This commit is contained in:
59
backend/models/shared_api.py
Normal file
59
backend/models/shared_api.py
Normal file
@@ -0,0 +1,59 @@
|
||||
"""共享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())
|
||||
Reference in New Issue
Block a user