import { config, ready } from "$lib/server/config"; import { logger } from "$lib/server/logger"; import { initExitHandler, onExit } from "$lib/server/exitHandler"; import { checkAndRunMigrations } from "$lib/migrations/migrations"; import { refreshConversationStats } from "$lib/jobs/refresh-conversation-stats"; import { loadMcpServersOnStartup } from "$lib/server/mcp/registry"; import { AbortedGenerations } from "$lib/server/abortedGenerations"; import { adminTokenManager } from "$lib/server/adminToken"; import { MetricsServer } from "$lib/server/metrics"; export async function initServer(): Promise { // Wait for config to be fully loaded await ready; // Ensure legacy env expected by some libs: map OPENAI_API_KEY -> HF_TOKEN if absent const canonicalToken = config.OPENAI_API_KEY || config.HF_TOKEN; if (canonicalToken) { process.env.HF_TOKEN ??= canonicalToken; } // Warn if legacy-only var is used if (!config.OPENAI_API_KEY && config.HF_TOKEN) { logger.warn( "HF_TOKEN is deprecated in favor of OPENAI_API_KEY. Please migrate to OPENAI_API_KEY." ); } logger.info("Starting server..."); initExitHandler(); if (config.METRICS_ENABLED === "true") { MetricsServer.getInstance(); } checkAndRunMigrations(); refreshConversationStats(); // Load MCP servers at startup loadMcpServersOnStartup(); // Init AbortedGenerations refresh process AbortedGenerations.getInstance(); adminTokenManager.displayToken(); // Register Langfuse flush on graceful shutdown const { shutdownLangfuse } = await import("$lib/server/tracing/langfuse"); onExit(() => shutdownLangfuse()); if (config.EXPOSE_API) { logger.warn( "The EXPOSE_API flag has been deprecated. The API is now required for chat-ui to work." ); } }