mirror of
https://github.com/fawney19/Aether.git
synced 2026-01-09 19:22:26 +08:00
- 新增 Management Token(访问令牌)功能,支持创建、更新、删除和管理 - 前端添加访问令牌管理页面,支持普通用户和管理员 - 后端实现完整的令牌生命周期管理 API - 添加数据库迁移脚本创建 management_tokens 表 - Nginx 配置添加 gzip 压缩,优化响应传输 - Dialog 组件添加 persistent 属性,防止意外关闭 - 为管理后台 API 添加详细的中文文档注释 - 简化多处类型注解,统一代码风格
84 lines
2.4 KiB
Python
84 lines
2.4 KiB
Python
from __future__ import annotations
|
|
|
|
from abc import ABC, abstractmethod
|
|
from enum import Enum
|
|
from typing import Any, Dict, Optional
|
|
|
|
from fastapi import Request, Response
|
|
|
|
from .context import ApiRequestContext
|
|
|
|
|
|
class ApiMode(str, Enum):
|
|
STANDARD = "standard"
|
|
PROXY = "proxy"
|
|
ADMIN = "admin"
|
|
USER = "user" # JWT 认证的普通用户(不要求管理员权限)
|
|
PUBLIC = "public"
|
|
MANAGEMENT = "management" # Management Token 认证
|
|
|
|
|
|
class ApiAdapter(ABC):
|
|
"""所有API格式适配器的抽象基类。"""
|
|
|
|
name: str = "base"
|
|
mode: ApiMode = ApiMode.STANDARD
|
|
api_format: Optional[str] = None # 对应 Provider API 格式提示
|
|
audit_log_enabled: bool = True
|
|
audit_success_event = None
|
|
audit_failure_event = None
|
|
|
|
@abstractmethod
|
|
async def handle(self, context: ApiRequestContext) -> Response:
|
|
"""处理请求并返回 FastAPI Response。"""
|
|
|
|
def authorize(self, context: ApiRequestContext) -> None:
|
|
"""可选的授权钩子,默认允许通过。"""
|
|
return None
|
|
|
|
def extract_api_key(self, request: Request) -> Optional[str]:
|
|
"""
|
|
从请求中提取客户端 API 密钥。
|
|
|
|
子类应覆盖此方法以支持各自的认证头格式。
|
|
|
|
Args:
|
|
request: FastAPI Request 对象
|
|
|
|
Returns:
|
|
提取的 API 密钥,如果未找到则返回 None
|
|
"""
|
|
return None
|
|
|
|
def get_audit_metadata(
|
|
self,
|
|
context: ApiRequestContext,
|
|
*,
|
|
success: bool,
|
|
status_code: Optional[int],
|
|
error: Optional[str] = None,
|
|
) -> Dict[str, Any]:
|
|
"""允许适配器在审计日志中追加自定义字段。"""
|
|
return {}
|
|
|
|
def detect_capability_requirements(
|
|
self,
|
|
headers: Dict[str, str],
|
|
request_body: Optional[Dict[str, Any]] = None,
|
|
) -> Dict[str, bool]:
|
|
"""
|
|
检测请求中隐含的能力需求(子类可覆盖)
|
|
|
|
不同 API 格式有不同的能力声明方式,例如:
|
|
- Claude: anthropic-beta: context-1m-xxx 表示需要 1M 上下文
|
|
- 其他格式可能有不同的请求头或请求体字段
|
|
|
|
Args:
|
|
headers: 请求头字典
|
|
request_body: 请求体字典(可选)
|
|
|
|
Returns:
|
|
检测到的能力需求,如 {"context_1m": True}
|
|
"""
|
|
return {}
|