d35771f97d
* fix: patch pip distlib finder for frozen electron runtime * fix: use certifi CA bundle for runtime SSL requests * fix: configure certifi CA before core imports * fix: improve mac font fallback for dashboard text * fix: harden frozen pip patch and unify TLS connector * refactor: centralize dashboard CJK font fallback stacks * perf: reuse TLS context and avoid repeated frozen pip patch * refactor: bootstrap TLS setup before core imports * fix: use async confirm dialog for provider deletions * fix: replace native confirm dialogs in dashboard - Add shared confirm helper in dashboard/src/utils/confirmDialog.ts for async dialog usage with safe fallback. - Migrate provider, chat, config, session, platform, persona, MCP, backup, and knowledge-base delete/close confirmations to use the shared helper. - Remove scattered inline confirm handling to keep behavior consistent and avoid native blocking dialog focus/caret issues in Electron. * fix: capture runtime bootstrap logs after logger init - Add bootstrap record buffer in runtime_bootstrap for early TLS patch logs before logger is ready. - Flush buffered bootstrap logs to astrbot logger at process startup in main.py. - Include concrete exception details for TLS bootstrap failures to improve diagnosis. * fix: harden runtime bootstrap and unify confirm handling - Simplify bootstrap log buffering and add a public initialize hook for non-main startup paths. - Guard aiohttp TLS patching with feature/type checks and keep graceful fallback when internals are unavailable. - Standardize dashboard confirmation flow via shared confirm helpers across composition and options API components. * refactor: simplify runtime tls bootstrap and tighten confirm typing * refactor: align ssl helper namespace and confirm usage
67 lines
2.2 KiB
Python
67 lines
2.2 KiB
Python
from typing import Literal, TypedDict
|
|
|
|
import aiohttp
|
|
|
|
from astrbot.core import logger
|
|
from astrbot.core.utils.http_ssl import build_tls_connector
|
|
|
|
|
|
class LLMModalities(TypedDict):
|
|
input: list[Literal["text", "image", "audio", "video"]]
|
|
output: list[Literal["text", "image", "audio", "video"]]
|
|
|
|
|
|
class LLMLimit(TypedDict):
|
|
context: int
|
|
output: int
|
|
|
|
|
|
class LLMMetadata(TypedDict):
|
|
id: str
|
|
reasoning: bool
|
|
tool_call: bool
|
|
knowledge: str
|
|
release_date: str
|
|
modalities: LLMModalities
|
|
open_weights: bool
|
|
limit: LLMLimit
|
|
|
|
|
|
LLM_METADATAS: dict[str, LLMMetadata] = {}
|
|
|
|
|
|
async def update_llm_metadata() -> None:
|
|
url = "https://models.dev/api.json"
|
|
try:
|
|
async with aiohttp.ClientSession(
|
|
trust_env=True, connector=build_tls_connector()
|
|
) as session:
|
|
async with session.get(url) as response:
|
|
data = await response.json()
|
|
global LLM_METADATAS
|
|
models = {}
|
|
for info in data.values():
|
|
for model in info.get("models", {}).values():
|
|
model_id = model.get("id")
|
|
if not model_id:
|
|
continue
|
|
models[model_id] = LLMMetadata(
|
|
id=model_id,
|
|
reasoning=model.get("reasoning", False),
|
|
tool_call=model.get("tool_call", False),
|
|
knowledge=model.get("knowledge", "none"),
|
|
release_date=model.get("release_date", ""),
|
|
modalities=model.get(
|
|
"modalities", {"input": [], "output": []}
|
|
),
|
|
open_weights=model.get("open_weights", False),
|
|
limit=model.get("limit", {"context": 0, "output": 0}),
|
|
)
|
|
# Replace the global cache in-place so references remain valid
|
|
LLM_METADATAS.clear()
|
|
LLM_METADATAS.update(models)
|
|
logger.info(f"Successfully fetched metadata for {len(models)} LLMs.")
|
|
except Exception as e:
|
|
logger.error(f"Failed to fetch LLM metadata: {e}")
|
|
return
|