0d293422ac
- Replace image_extractor with pdf_image_extractor service - Enhance pi_client with expanded API capabilities - Improve summarizer service with additional features - Update admin routes with more endpoints - Add login page template - Enhance detail page with comprehensive layout - Improve search and trends pages - Update base template with additional elements - Refactor tests for better coverage - Add validate_summary script - Update project configuration and dependencies
76 lines
1.9 KiB
Python
76 lines
1.9 KiB
Python
"""应用配置 — 从 .env / 环境变量加载。"""
|
|
|
|
from pathlib import Path
|
|
|
|
from pydantic_settings import BaseSettings
|
|
|
|
BASE_DIR = Path(__file__).resolve().parent.parent
|
|
|
|
|
|
class Settings(BaseSettings):
|
|
# 应用
|
|
APP_HOST: str = "127.0.0.1"
|
|
APP_PORT: int = 8000
|
|
APP_DEBUG: bool = False
|
|
BASE_URL: str = "http://127.0.0.1:8000"
|
|
APP_TIMEZONE: str = "Asia/Shanghai"
|
|
|
|
# 安全
|
|
ADMIN_USERNAME: str = "admin"
|
|
ADMIN_PASSWORD: str = ""
|
|
SECRET_KEY: str = "change-me"
|
|
|
|
# HuggingFace / arXiv
|
|
HF_API_BASE: str = "https://huggingface.co/api"
|
|
HF_PROXY: str = ""
|
|
TOP_N: int = 20
|
|
HTTP_TIMEOUT_SECONDS: int = 30
|
|
HTTP_MAX_RETRIES: int = 3
|
|
HTTP_USER_AGENT: str = "hf-daily-papers-local/0.1"
|
|
|
|
# AI 总结
|
|
PI_BIN: str = ""
|
|
SUMMARY_SKILL: str = "daily-paper-summary"
|
|
SUMMARY_CONCURRENCY: int = 3
|
|
SUMMARY_TIMEOUT_SECONDS: int = 300
|
|
SUMMARY_MAX_RETRIES: int = 1
|
|
|
|
# 调度
|
|
SCHEDULER_ENABLED: bool = False
|
|
SCHEDULE_HOUR: int = 8
|
|
SCHEDULE_MINUTE: int = 0
|
|
APP_WORKERS: int = 1
|
|
|
|
# 数据库
|
|
DATABASE_URL: str = "sqlite:///data/db/papers.db"
|
|
|
|
# 语义搜索
|
|
CHROMA_ENABLED: bool = False
|
|
CHROMA_DIR: str = "data/chroma"
|
|
EMBED_API_BASE: str = ""
|
|
EMBED_API_KEY: str = ""
|
|
EMBED_MODEL: str = ""
|
|
EMBED_DIMENSIONS: int = 0
|
|
|
|
model_config = {
|
|
"env_file": str(BASE_DIR / ".env"),
|
|
"env_file_encoding": "utf-8",
|
|
"extra": "ignore",
|
|
}
|
|
|
|
@property
|
|
def db_path(self) -> Path:
|
|
"""从 DATABASE_URL 解析出 SQLite 文件路径。"""
|
|
# sqlite:///data/db/papers.db → data/db/papers.db
|
|
url = self.DATABASE_URL
|
|
if url.startswith("sqlite:///"):
|
|
return BASE_DIR / url[len("sqlite:///") :]
|
|
raise ValueError(f"Unsupported DATABASE_URL: {url}")
|
|
|
|
@property
|
|
def http_proxy(self) -> str | None:
|
|
return self.HF_PROXY or None
|
|
|
|
|
|
settings = Settings()
|