1
File size: 2,765 Bytes
3925cbd
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import os
import pathlib
import logging
from datetime import datetime, timedelta

# 基础目录设置
BASE_DIR = pathlib.Path(__file__).parent.parent

# 流式响应配置
FAKE_STREAMING = os.environ.get("FAKE_STREAMING", "true").lower() in ["true", "1", "yes"]
# 假流式请求的空内容返回间隔(秒)
FAKE_STREAMING_INTERVAL = float(os.environ.get("FAKE_STREAMING_INTERVAL", "1"))

# 日志配置
logging.getLogger("uvicorn").disabled = True
logging.getLogger("uvicorn.access").disabled = True

# 安全配置
PASSWORD = os.environ.get("PASSWORD", "123").strip('"')
MAX_REQUESTS_PER_MINUTE = int(os.environ.get("MAX_REQUESTS_PER_MINUTE", "30"))
MAX_REQUESTS_PER_DAY_PER_IP = int(os.environ.get("MAX_REQUESTS_PER_DAY_PER_IP", "600"))
RETRY_DELAY = 1
MAX_RETRY_DELAY = 16

# API密钥使用限制
# 默认每个API密钥每24小时可使用次数
API_KEY_DAILY_LIMIT = int(os.environ.get("API_KEY_DAILY_LIMIT", "25"))

# 缓存配置
CACHE_EXPIRY_TIME = int(os.environ.get("CACHE_EXPIRY_TIME", "1200"))  # 默认20分钟
MAX_CACHE_ENTRIES = int(os.environ.get("MAX_CACHE_ENTRIES", "500"))  # 默认最多缓存500条响应
REMOVE_CACHE_AFTER_USE = os.environ.get("REMOVE_CACHE_AFTER_USE", "true").lower() in ["true", "1", "yes"]

# 请求历史配置
REQUEST_HISTORY_EXPIRY_TIME = int(os.environ.get("REQUEST_HISTORY_EXPIRY_TIME", "600"))  # 默认10分钟
ENABLE_RECONNECT_DETECTION = os.environ.get("ENABLE_RECONNECT_DETECTION", "true").lower() in ["true", "1", "yes"]

# 版本信息
local_version = "0.0.4"
remote_version = "0.0.4"
has_update = False

# API调用统计
api_call_stats = {
    'last_24h': {
        'total': {},  # 按小时统计过去24小时总调用次数
        'by_endpoint': {}  # 按API端点分类的24小时统计(也用于API密钥统计)
    },
    'hourly': {
        'total': {},  # 按小时统计过去一小时总调用次数
        'by_endpoint': {}  # 按API端点分类的小时统计(也用于API密钥统计)
    },
    'minute': {
        'total': {},  # 按分钟统计过去一分钟总调用次数
        'by_endpoint': {}  # 按API端点分类的分钟统计(也用于API密钥统计)
    }
}

# 客户端IP到最近请求的映射,用于识别重连请求
client_request_history = {}

# 模型屏蔽列表配置
# 默认屏蔽的模型列表
DEFAULT_BLOCKED_MODELS = []

# 从环境变量中读取屏蔽模型列表,如果未设置则使用默认列表
# 环境变量格式应为逗号分隔的模型名称字符串
BLOCKED_MODELS = os.environ.get("BLOCKED_MODELS", ",".join(DEFAULT_BLOCKED_MODELS))
# 将字符串转换为列表
BLOCKED_MODELS = [model.strip() for model in BLOCKED_MODELS.split(",") if model.strip()]