whale-code 6.5.9 → 6.5.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"agent-loop.js","names":["LOCAL_TOOL_DEFINITIONS","executeLocalTool","isLocalTool","INTERACTIVE_TOOL_DEFINITIONS","executeInteractiveTool","waitForPlanApproval","loadConfig","resolveConfig","getProxyUrl","resolveDefaultAgentId","getValidToken","refreshSession","isServerTool","loadServerToolDefinitions","executeServerTool","getServerStatus","setServerToolContext","nextTurn","createTurnContext","createConversationContext","logSpan","generateSpanId","flushCliSpans","getConversationRootSpanId","captureError","addBreadcrumb","setGlobalEmitter","clearGlobalEmitter","mcpClientManager","loadHooks","runBeforeToolHook","runAfterToolHook","runSessionHook","LoopDetector","COMPACTION_TOTAL_BUDGET","getCompactionConfig","getContextManagement","DEFAULT_SESSION_COST_BUDGET_USD","emitCostWarningIfNeeded","resolveAgentLoopConfig","AGENT_DEFAULTS","loadCLIAgentConfig","resetAgentConfigCache","parseSSEStream","processStreamWithCallbacks","collectStreamResult","callServerProxy","callTranscribe","buildAPIRequest","buildSystemBlocks","prepareWithCaching","trimGeminiContext","trimOpenAIContext","requestProviderCompaction","getProvider","MODELS","dispatchTools","buildAssistantContent","loadMemory","addMemory","removeMemory","listMemories","refreshGitContext","resetGitContext","loadClaudeMd","reloadClaudeMd","resetClaudeMdCache","clearReadCache","setPermissionMode","getPermissionMode","isToolAllowedByPermission","setModel","setModelById","getModel","getModelShortName","estimateCostUsd","saveSession","loadSession","listSessions","findLatestSessionForCwd","updateSessionMeta","buildSystemPrompt","listProcesses","listBackgroundAgents","AgentEventEmitter","sessionInputTokens","sessionOutputTokens","getSessionTokens","input","output","resetSessionState","sessionLoopDetector","CLI_NO_LIMIT","Number","MAX_SAFE_INTEGER","SHELL_SUMMARIZE_LINE_THRESHOLD","SHELL_SUMMARIZE_SIZE_THRESHOLD","SHELL_SUMMARIZE_MAX_INPUT","SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES","shouldSummarizeShellOutput","length","lineCount","split","summarizeShellOutput","proxyUrl","token","storeId","truncatedForSummary","slice","summaryConfig","model","HAIKU","contextProfile","stream","system","type","text","messages","role","content","tools","apiConfig","timeoutMs","result","summary","trim","originalLines","preview","join","summarizeLongToolResults","toolResults","toolNames","shellSummarization","tasks","map","toolName","get","tool_use_id","summarized","Promise","all","getTools","allowedTools","disallowedTools","localTools","t","name","description","input_schema","skipPlanTools","interactiveTools","filter","push","serverTools","localNames","Set","uniqueServerTools","has","mcpTools","allTools","allowed","disallowed","serverToolCount","getServerToolCount","defs","runAgentLoop","opts","shouldUseSessionMode","runSessionAgentLoop","message","conversationHistory","callbacks","abortSignal","emitter","effectiveMaxTurns","maxTurns","hooksCwd","cwd","process","hooks","session_id","Date","now","catch","systemPrompt","effort","userContent","images","blocks","img","source","media_type","mediaType","data","base64","totalIn","totalOut","totalCacheCreation","totalCacheRead","totalThinking","allAssistantText","prevIterationInputTokens","sessionStart","turnNum","turnCtx","turnNumber","turnSpanId","spanId","action","durationMs","context","parentSpanId","undefined","details","conversation_id","conversationId","traceId","userId","userEmail","conversation_history_length","sessionCostUsd","compactionCount","consecutiveCompactions","maxTokensContinuations","costWarningsEmitted","activeModel","dbAgent","resolved","fromResolved","loopDetector","resetTurn","effectiveBudget","maxBudgetUsd","contextOverrides","session_cost_budget_usd","ctxOverrides","ctxMgmt","compactEdit","config","edits","find","e","effectiveCompactionTrigger","trigger","value","compactionTriggerTokens","effectiveCompactionBudget","compaction_total_budget","maxContinuations","INTERACTIVE_TOOL_NAMES","toolExecutor","success","effectiveInput","hookResult","allow","modifiedInput","decision","feedback","isMcpTool","callTool","afterResult","modifiedOutput","iteration","aborted","reason","onError","severity","session_cost_usd","max_budget_usd","toFixed","apiStart","apiSpanId","apiRowId","crypto","randomUUID","costContext","currentModel","thinkingEnabled","thinking","cachedTools","cachedMessages","provider","preTrimMessages","threshold","countToolResults","msgs","reduce","sum","m","Array","isArray","b","activeBefore","activeAfter","estimatedSaved","Math","round","max","onAutoCompact","emitCompact","Error","originalModel","signal","fallbackModel","onFallback","from","to","from_model","to_model","onRetry","attempt","err","msg","emitText","onText","onTokenRefresh","access_token","thinkingChunks","onThinking","emitThinking","onToolStart","emitToolStart","flushText","usage","inputTokens","outputTokens","iterCost","thinkingTokens","cacheReadTokens","cacheCreationTokens","emitUsage","contextManagementApplied","has_compaction_content","compactionContent","iterCostUsd","rowId","totalCost","stop_reason","stopReason","toolUseBlocks","tool_count","tool_names","compaction_count","consecutive","messages_before","MAX_CONSECUTIVE_COMPACTIONS","shouldWrapUp","compactedMessages","budgetMsg","truncatedText","assistantContent","thinkingBlocks","continuationText","results","bailOut","bailMessage","maxConcurrent","maxConcurrentTools","batchErrorLimit","loopBatchErrorLimit","onStart","onResult","onToolResult","parentId","error","tool_input","tool_result","truncateResult","error_type","classifyToolError","transcribeAudio","audioBase64","getSessionStats","toolNameMap","Map","id","finalToolResults","planCleanMarker","hasCleanPlanApproval","some","tr","startsWith","planResult","planText","beforeCount","compactionCfg","isNative","triggerTokens","totalBudget","input_tokens","trigger_tokens","output_tokens","total_tokens","cache_creation_tokens","cache_read_tokens","session_input_tokens","session_output_tokens","turnCostUsd","onUsage","finalText","emitDone","onDone","errorMsg","String","errorType","errorMessage","tags","turn","emitError","maxLen","lower","toLowerCase","includes","canUseAgent","hasToken","refresh_token","hasApiKey","env","ANTHROPIC_API_KEY","anthropic_api_key","ready","SessionClient","WHALE_SESSION_MODE","stdin","isTTY","client","healthCheck","agentId","defaultAgentId","resumeId","WHALE_RESUME_SESSION_ID","sessionId","session","createSession","surface","localSessionId","serverSessionId","synced","accumulatedText","errorHandled","sendMessage","tokens","costUsd","cacheRead","cacheCreation","_conversationId"],"sources":["../../../src/cli/services/agent-loop.ts"],"sourcesContent":["/**\n * Agent Loop — local-first agentic CLI with server tool support\n *\n * LLM calls proxy through the `agent-proxy` edge function (server holds API key).\n * User authenticates via Supabase JWT. Local tools execute on the client.\n * Server tools execute via direct import of executeTool() (same codebase).\n *\n * Fallback: if proxy is unavailable and ANTHROPIC_API_KEY is set, calls directly.\n *\n * This file is the thin orchestrator + re-export facade. Domain logic lives in:\n * - memory-manager.ts (loadMemory, addMemory, removeMemory, listMemories)\n * - git-context.ts (gatherGitContext, refreshGitContext)\n * - claude-md-loader.ts (loadClaudeMd, reloadClaudeMd)\n * - permission-modes.ts (PermissionMode, set/get/isAllowed)\n * - model-manager.ts (setModel, getModel, getModelShortName, estimateCostUsd)\n * - session-persistence.ts (SessionMeta, save/load/list/find sessions)\n * - system-prompt.ts (buildSystemPrompt)\n */\n\nimport type Anthropic from \"@anthropic-ai/sdk\";\nimport {\n LOCAL_TOOL_DEFINITIONS,\n executeLocalTool,\n isLocalTool,\n} from \"./local-tools.js\";\nimport {\n INTERACTIVE_TOOL_DEFINITIONS,\n executeInteractiveTool,\n waitForPlanApproval,\n type PlanApprovalDecision,\n} from \"./interactive-tools.js\";\nimport { loadConfig, resolveConfig, getProxyUrl, resolveDefaultAgentId } from \"./config-store.js\";\nimport { getValidToken, refreshSession } from \"./auth-service.js\";\nimport {\n isServerTool,\n loadServerToolDefinitions,\n executeServerTool,\n getServerStatus,\n setServerToolContext,\n type ServerStatus,\n} from \"./server-tools.js\";\nimport {\n nextTurn,\n createTurnContext,\n createConversationContext,\n logSpan,\n generateSpanId,\n flushCliSpans,\n getConversationTraceId,\n getConversationRootSpanId,\n} from \"./telemetry.js\";\nimport { captureError, addBreadcrumb } from \"./error-logger.js\";\nimport {\n AgentEventEmitter,\n setGlobalEmitter,\n clearGlobalEmitter,\n} from \"./agent-events.js\";\nimport { mcpClientManager } from \"./mcp-client.js\";\nimport { loadHooks, runBeforeToolHook, runAfterToolHook, runSessionHook, type HookConfig } from \"./hooks.js\";\nimport { LoopDetector, COMPACTION_TOTAL_BUDGET, getCompactionConfig, getContextManagement, DEFAULT_SESSION_COST_BUDGET_USD, emitCostWarningIfNeeded, resolveAgentLoopConfig, AGENT_DEFAULTS } from \"../../shared/agent-core.js\";\nimport { loadCLIAgentConfig, resetAgentConfigCache } from \"./agent-config.js\";\nimport { parseSSEStream, processStreamWithCallbacks, collectStreamResult } from \"../../shared/sse-parser.js\";\nimport { callServerProxy, callTranscribe, buildAPIRequest, buildSystemBlocks, prepareWithCaching, trimGeminiContext, trimOpenAIContext, requestProviderCompaction } from \"../../shared/api-client.js\";\nimport { getProvider, MODELS } from \"../../shared/constants.js\";\nimport { dispatchTools, buildAssistantContent } from \"../../shared/tool-dispatch.js\";\nimport type { StreamResult as SharedStreamResult, ToolResultMessage } from \"../../shared/types.js\";\n\n// ── Extracted modules (re-exported below for backward compatibility) ──\nimport { loadMemory, addMemory, removeMemory, listMemories } from \"./memory-manager.js\";\nimport { refreshGitContext, resetGitContext } from \"./git-context.js\";\nimport { loadClaudeMd, reloadClaudeMd, resetClaudeMdCache } from \"./claude-md-loader.js\";\nimport { clearReadCache } from \"./tools/file-ops.js\";\nimport { setPermissionMode, getPermissionMode, isToolAllowedByPermission, type PermissionMode } from \"./permission-modes.js\";\nimport { setModel, setModelById, getModel, getModelShortName, estimateCostUsd } from \"./model-manager.js\";\nimport { saveSession, loadSession, listSessions, findLatestSessionForCwd, updateSessionMeta, type SessionMeta } from \"./session-persistence.js\";\nimport { buildSystemPrompt } from \"./system-prompt.js\";\n\n// ============================================================================\n// RE-EXPORTS — legacy compatibility. Prefer importing from source modules directly:\n// memory-manager.ts, git-context.ts, claude-md-loader.ts,\n// permission-modes.ts, model-manager.ts, session-persistence.ts,\n// server-tools.ts, mcp-client.ts, background-processes.ts, agent-events.ts\n// ============================================================================\n\n// Memory → import from \"./memory-manager.js\"\nexport { loadMemory, addMemory, removeMemory, listMemories };\n\n// Git context → import from \"./git-context.js\"\nexport { refreshGitContext };\n\n// CLAUDE.md → import from \"./claude-md-loader.js\"\nexport { loadClaudeMd, reloadClaudeMd };\n\n// Permission modes → import from \"./permission-modes.js\"\nexport { setPermissionMode, getPermissionMode, isToolAllowedByPermission, type PermissionMode };\n\n// Model management → import from \"./model-manager.js\"\nexport { setModel, getModel, getModelShortName, estimateCostUsd };\n\n// Session persistence → import from \"./session-persistence.js\"\nexport { saveSession, loadSession, listSessions, findLatestSessionForCwd, updateSessionMeta, type SessionMeta };\n\n// Server status → import from \"./server-tools.js\"\nexport { getServerStatus, type ServerStatus };\n\n// MCP client manager → import from \"./mcp-client.js\"\nexport { mcpClientManager };\n\n// Background processes → import from \"./background-processes.js\"\nexport { listProcesses, listBackgroundAgents } from \"./background-processes.js\";\n\n// Event emitter → import from \"./agent-events.js\"\nexport { AgentEventEmitter, type AgentEvent } from \"./agent-events.js\";\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface AgentLoopCallbacks {\n onText: (text: string) => void;\n onToolStart: (name: string, input?: Record<string, unknown>) => void;\n onToolResult: (name: string, success: boolean, result: unknown, input?: Record<string, unknown>, durationMs?: number) => void;\n onUsage: (input_tokens: number, output_tokens: number, thinking_tokens?: number, model?: string, costUsd?: number, cacheReadTokens?: number, cacheCreationTokens?: number) => void;\n onDone: (finalMessages: Anthropic.MessageParam[]) => void;\n onError: (error: string, partialMessages?: Anthropic.MessageParam[]) => void;\n onAutoCompact?: (beforeMessages: number, afterMessages: number, tokensSaved: number) => void;\n}\n\nexport interface AgentLoopOptions {\n message: string;\n images?: { base64: string; mediaType: string }[]; // Image attachments (base64-encoded)\n conversationHistory: Anthropic.MessageParam[];\n callbacks: AgentLoopCallbacks;\n abortSignal?: AbortSignal;\n model?: string;\n emitter?: AgentEventEmitter; // Event emitter for decoupled UI\n // v4.7.0 extensions\n maxTurns?: number;\n maxBudgetUsd?: number;\n effort?: \"low\" | \"medium\" | \"high\";\n allowedTools?: string[];\n disallowedTools?: string[];\n fallbackModel?: string;\n // v5.1.0 — extended thinking\n thinking?: boolean;\n // v6.1.0 — shell output summarization\n shellSummarization?: boolean; // default: true\n // v6.1.0 — working directory for hooks\n cwd?: string;\n}\n\n// ============================================================================\n// SESSION STATE\n// ============================================================================\n\n// CLI-only: Session-wide token tracking (actual counts from API responses).\n// Reset via resetSessionState() when starting a new conversation.\nlet sessionInputTokens = 0;\nlet sessionOutputTokens = 0;\n\nexport function getSessionTokens(): { input: number; output: number } {\n return { input: sessionInputTokens, output: sessionOutputTokens };\n}\n\n/**\n * Reset all CLI-only session state. Call when starting a new conversation\n * (e.g., /clear command, new print-mode run) to prevent stale token counts,\n * loop detector state, and caches from leaking across sessions.\n *\n * Does NOT reset activeModel or permissionMode — those are user preferences\n * that persist intentionally until explicitly changed.\n */\nexport function resetSessionState(): void {\n sessionInputTokens = 0;\n sessionOutputTokens = 0;\n sessionLoopDetector = null;\n resetGitContext();\n resetClaudeMdCache();\n clearReadCache();\n resetAgentConfigCache();\n // Reset conversation-level trace context so the next conversation gets a fresh trace\n createConversationContext();\n}\n\n/** CLI-only: loop detector — persists session error state across turns (reset by resetSessionState) */\nlet sessionLoopDetector: LoopDetector | null = null;\n\n// No artificial turn cap — agent self-regulates via end_turn (Claude Code parity).\n// Safety: LoopDetector catches loops, cost budget catches runaway spending, user has Ctrl+C.\nconst CLI_NO_LIMIT = Number.MAX_SAFE_INTEGER;\n\n// ============================================================================\n// SHELL OUTPUT SUMMARIZATION\n// ============================================================================\n\nconst SHELL_SUMMARIZE_LINE_THRESHOLD = 800;\nconst SHELL_SUMMARIZE_SIZE_THRESHOLD = 200_000; // 200KB — only summarize truly huge outputs\nconst SHELL_SUMMARIZE_MAX_INPUT = 300_000; // 300KB max to summarizer\nconst SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES = 20;\n\n/**\n * Check if shell output should be summarized based on line count or size.\n */\nfunction shouldSummarizeShellOutput(output: string): boolean {\n if (output.length > SHELL_SUMMARIZE_SIZE_THRESHOLD) return true;\n const lineCount = output.split(\"\\n\").length;\n return lineCount > SHELL_SUMMARIZE_LINE_THRESHOLD;\n}\n\n/**\n * Summarize long shell output using Haiku via server proxy.\n * Returns summarized output or original if summarization fails.\n */\nasync function summarizeShellOutput(\n output: string,\n proxyUrl: string,\n token: string,\n storeId?: string,\n): Promise<string> {\n const lineCount = output.split(\"\\n\").length;\n const truncatedForSummary = output.length > SHELL_SUMMARIZE_MAX_INPUT\n ? output.slice(0, SHELL_SUMMARIZE_MAX_INPUT) + \"\\n... (truncated for summarization)\"\n : output;\n\n try {\n const summaryConfig = buildAPIRequest({\n model: MODELS.HAIKU,\n contextProfile: \"subagent\",\n });\n\n const stream = await callServerProxy({\n proxyUrl,\n token,\n model: MODELS.HAIKU,\n system: [{ type: \"text\", text: \"You are a concise technical summarizer. Summarize shell/command output preserving key information, errors, warnings, file paths, and actionable items. Be brief but thorough.\" }],\n messages: [{ role: \"user\", content: `Summarize this shell output concisely, preserving key information, errors, and actionable items:\\n\\n${truncatedForSummary}` }],\n tools: [],\n apiConfig: summaryConfig,\n storeId,\n timeoutMs: 15_000,\n });\n\n const result = await collectStreamResult(parseSSEStream(stream));\n const summary = result.text.trim();\n\n if (!summary) return output; // Summarization failed, return original\n\n // Build first N lines preview\n const originalLines = output.split(\"\\n\");\n const preview = originalLines.slice(0, SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES).join(\"\\n\");\n\n return `[Summarized from ${lineCount} lines]\\n\\n${summary}\\n\\n[First ${SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES} lines of original output]\\n${preview}`;\n } catch {\n // Summarization failed silently — return original output\n return output;\n }\n}\n\n/**\n * Post-process tool results to summarize long bash output.\n * Only affects bash tool results that exceed size/line thresholds.\n */\nasync function summarizeLongToolResults(\n toolResults: ToolResultMessage[],\n toolNames: Map<string, string>,\n proxyUrl: string,\n token: string,\n shellSummarization: boolean,\n storeId?: string,\n): Promise<ToolResultMessage[]> {\n if (!shellSummarization) return toolResults;\n\n const tasks = toolResults.map(async (result) => {\n // Only summarize bash tool string results\n const toolName = toolNames.get(result.tool_use_id);\n if (toolName !== \"bash\" || typeof result.content !== \"string\") return result;\n\n // Check thresholds\n if (!shouldSummarizeShellOutput(result.content)) return result;\n\n const summarized = await summarizeShellOutput(result.content, proxyUrl, token, storeId);\n return { ...result, content: summarized };\n });\n\n return Promise.all(tasks);\n}\n\n// ============================================================================\n// TOOL DEFINITIONS\n// ============================================================================\n\nasync function getTools(allowedTools?: string[], disallowedTools?: string[]): Promise<{ tools: Anthropic.Tool[]; serverToolCount: number }> {\n const localTools: Anthropic.Tool[] = LOCAL_TOOL_DEFINITIONS.map((t) => ({\n name: t.name,\n description: t.description,\n input_schema: t.input_schema as Anthropic.Tool[\"input_schema\"],\n }));\n\n // Add interactive tools — skip plan mode tools in yolo mode (user doesn't want plan gates)\n const skipPlanTools = getPermissionMode() === \"yolo\";\n const interactiveTools: Anthropic.Tool[] = INTERACTIVE_TOOL_DEFINITIONS\n .filter((t) => !skipPlanTools || (t.name !== \"enter_plan_mode\" && t.name !== \"exit_plan_mode\"))\n .map((t) => ({\n name: t.name,\n description: t.description,\n input_schema: t.input_schema as Anthropic.Tool[\"input_schema\"],\n }));\n localTools.push(...interactiveTools);\n\n let serverTools: Anthropic.Tool[] = [];\n try {\n serverTools = await loadServerToolDefinitions();\n } catch {\n // Server tools silently unavailable\n }\n\n // Deduplicate: local tools take priority over server tools with the same name\n const localNames = new Set(localTools.map(t => t.name));\n const uniqueServerTools = serverTools.filter(t => !localNames.has(t.name));\n\n // MCP tools from external servers\n const mcpTools = mcpClientManager.getTools();\n\n let allTools = [...localTools, ...uniqueServerTools, ...mcpTools];\n\n // Apply tool filtering\n if (allowedTools && allowedTools.length > 0) {\n const allowed = new Set(allowedTools);\n allTools = allTools.filter(t => allowed.has(t.name));\n }\n if (disallowedTools && disallowedTools.length > 0) {\n const disallowed = new Set(disallowedTools);\n allTools = allTools.filter(t => !disallowed.has(t.name));\n }\n\n return {\n tools: allTools,\n serverToolCount: uniqueServerTools.length,\n };\n}\n\n/** Exposed for /status command */\nexport async function getServerToolCount(): Promise<number> {\n try {\n const defs = await loadServerToolDefinitions();\n return defs.length;\n } catch {\n return 0;\n }\n}\n\n// ============================================================================\n// MAIN LOOP\n// ============================================================================\n\nexport async function runAgentLoop(opts: AgentLoopOptions): Promise<void> {\n // Session mode: delegate to server-side SessionManager when available\n if (await shouldUseSessionMode()) {\n return runSessionAgentLoop(opts);\n }\n\n const { message, conversationHistory, callbacks, abortSignal, emitter } = opts;\n if (opts.model) setModel(opts.model);\n\n // Set global emitter for subagents to use\n if (emitter) {\n setGlobalEmitter(emitter);\n }\n\n // effectiveMaxTurns resolved after DB config fetch below\n // 0 or unset = no limit (Claude Code parity — agent self-regulates via end_turn)\n let effectiveMaxTurns = opts.maxTurns || CLI_NO_LIMIT;\n\n // Load hooks from project and user config\n const hooksCwd = opts.cwd || process.cwd();\n const hooks = loadHooks(hooksCwd);\n\n // Fire SessionStart hook (non-blocking)\n if (hooks.length > 0) {\n runSessionHook(hooks, \"SessionStart\", { session_id: `turn-${Date.now()}` }).catch(() => {});\n }\n\n // Shell summarization config (default: true)\n const shellSummarization = opts.shellSummarization !== false;\n\n const { tools, serverToolCount } = await getTools(opts.allowedTools, opts.disallowedTools);\n const systemPrompt = await buildSystemPrompt(serverToolCount > 0, opts.effort);\n\n // Build user content — text-only string or content blocks array with images\n let userContent: string | Anthropic.ContentBlockParam[];\n if (opts.images && opts.images.length > 0) {\n const blocks: Anthropic.ContentBlockParam[] = [];\n for (const img of opts.images) {\n blocks.push({\n type: \"image\",\n source: {\n type: \"base64\",\n media_type: img.mediaType as \"image/png\" | \"image/jpeg\" | \"image/gif\" | \"image/webp\",\n data: img.base64,\n },\n } as any);\n }\n blocks.push({ type: \"text\", text: message || \"(see attached images)\" });\n userContent = blocks;\n } else {\n userContent = message;\n }\n\n const messages: Anthropic.MessageParam[] = [\n ...conversationHistory,\n { role: \"user\", content: userContent },\n ];\n\n let totalIn = 0;\n let totalOut = 0;\n let totalCacheCreation = 0;\n let totalCacheRead = 0;\n let totalThinking = 0;\n let allAssistantText: string[] = [];\n let prevIterationInputTokens = 0; // Tracks actual context size from last API call\n\n // Telemetry: one turn per user message (not per API call)\n const sessionStart = Date.now();\n const { storeId } = resolveConfig();\n const turnNum = nextTurn(); // ONCE per user message\n const turnCtx = createTurnContext({ model: getModel(), turnNumber: turnNum });\n const turnSpanId = turnCtx.spanId!; // Capture for child spans to reference as parent\n\n // Emit conversation root span on the first turn so the trace tree has a root node.\n // The root span has span_id = conversationRootSpanId, no parent, and serves as the\n // ancestor for all turn spans in this conversation.\n if (turnNum === 1) {\n logSpan({\n action: \"conversation.start\",\n durationMs: 0,\n context: {\n ...turnCtx,\n spanId: getConversationRootSpanId(),\n parentSpanId: undefined, // Root span has no parent\n },\n storeId: storeId || undefined,\n details: {\n conversation_id: turnCtx.conversationId,\n },\n });\n }\n\n addBreadcrumb(\"agent\", `Turn ${turnNum}: ${message.slice(0, 100)}`, \"info\");\n\n // Set server tool context so tool calls carry trace/user identity to Fly.io server\n setServerToolContext({\n traceId: turnCtx.traceId,\n conversationId: turnCtx.conversationId,\n userId: turnCtx.userId,\n userEmail: turnCtx.userEmail,\n source: \"whale-code\",\n });\n\n logSpan({\n action: \"chat.user_message\",\n durationMs: 0,\n context: turnCtx,\n storeId: storeId || undefined,\n details: {\n message: message,\n conversation_history_length: conversationHistory.length,\n },\n });\n\n let sessionCostUsd = 0;\n let compactionCount = 0;\n let consecutiveCompactions = 0; // Circuit breaker: consecutive compactions without progress\n let maxTokensContinuations = 0; // Cap continuation loops to prevent infinite looping\n const costWarningsEmitted = new Set<number>();\n const activeModel = getModel();\n\n // Fetch agent config from DB — single source of truth, nothing hardcoded.\n // Falls back to AGENT_DEFAULTS only if DB is unreachable (never blocks).\n const dbAgent = await loadCLIAgentConfig();\n const resolved = dbAgent\n ? resolveAgentLoopConfig(dbAgent, \"sse\")\n : null;\n\n // Session-level loop detector: persists failed strategies across turns.\n // Created once per conversation, reset only when user starts a new conversation.\n // Must be created AFTER config resolution so DB thresholds apply.\n if (!sessionLoopDetector || conversationHistory.length === 0) {\n sessionLoopDetector = resolved\n ? LoopDetector.fromResolved(resolved)\n : new LoopDetector();\n }\n const loopDetector = sessionLoopDetector;\n loopDetector.resetTurn();\n\n const effectiveBudget = opts.maxBudgetUsd\n ?? resolved?.contextOverrides.session_cost_budget_usd\n ?? DEFAULT_SESSION_COST_BUDGET_USD;\n\n // Compaction settings from DB via getContextManagement — pass DB overrides so\n // the trigger/budget values match what the Anthropic API actually uses.\n const ctxOverrides = resolved?.contextOverrides;\n const ctxMgmt = getContextManagement(activeModel, ctxOverrides);\n const compactEdit = ctxMgmt.config.edits.find((e) => e.type === \"compact_20260112\") as any;\n const effectiveCompactionTrigger = compactEdit?.trigger?.value ?? AGENT_DEFAULTS.compactionTriggerTokens;\n const effectiveCompactionBudget = ctxOverrides?.compaction_total_budget ?? COMPACTION_TOTAL_BUDGET;\n\n // Override maxTurns from DB config (if not explicitly set by caller)\n // 0 = no limit (Claude Code parity)\n if (!opts.maxTurns && resolved && resolved.maxTurns > 0) {\n effectiveMaxTurns = resolved.maxTurns;\n }\n\n // Max continuations: resolved from DB config → AGENT_DEFAULTS fallback\n const maxContinuations = resolved?.maxContinuations ?? AGENT_DEFAULTS.maxContinuations;\n\n // Tool executor — routes to interactive, local, server, or MCP tools.\n // Wraps execution with before/after hooks when hooks are loaded.\n const INTERACTIVE_TOOL_NAMES = new Set(INTERACTIVE_TOOL_DEFINITIONS.map(t => t.name));\n const toolExecutor = async (name: string, input: Record<string, unknown>): Promise<{ success: boolean; output: string }> => {\n if (!name) {\n return { success: false, output: \"Tool call missing name — skipping.\" };\n }\n\n // Permission mode enforcement\n if (!isToolAllowedByPermission(name)) {\n return { success: false, output: `Tool \"${name}\" blocked by ${getPermissionMode()} mode. Switch modes with /mode.` };\n }\n\n // BeforeTool hook — may block or modify input\n let effectiveInput = input;\n if (hooks.length > 0) {\n const hookResult = await runBeforeToolHook(hooks, name, input);\n if (!hookResult.allow) {\n return { success: false, output: hookResult.message || \"Blocked by hook\" };\n }\n if (hookResult.modifiedInput) {\n effectiveInput = hookResult.modifiedInput;\n }\n }\n\n let result: { success: boolean; output: string };\n if (INTERACTIVE_TOOL_NAMES.has(name)) {\n result = await executeInteractiveTool(name, effectiveInput);\n\n // For exit_plan_mode: wait for UI approval, then map decision to result\n if (name === \"exit_plan_mode\" && result.success) {\n const decision: PlanApprovalDecision = await waitForPlanApproval(abortSignal);\n switch (decision.action) {\n case \"execute\":\n result = { success: true, output: `__PLAN_APPROVED_CLEAN__\\n${result.output}` };\n break;\n case \"edit\":\n result = { success: true, output: \"Plan returned for revision. Make changes and use ExitPlanMode again when ready.\" };\n break;\n case \"feedback\":\n result = { success: true, output: `User feedback on plan:\\n\\n${decision.feedback || \"(no feedback provided)\"}\\n\\nRevise the plan based on this feedback, then use ExitPlanMode again.` };\n break;\n case \"cancel\":\n result = { success: true, output: \"Plan cancelled by user. Do not proceed with implementation.\" };\n break;\n }\n }\n } else if (isLocalTool(name)) {\n result = await executeLocalTool(name, effectiveInput, abortSignal);\n } else if (isServerTool(name)) {\n result = await executeServerTool(name, effectiveInput, emitter);\n } else if (mcpClientManager.isMcpTool(name)) {\n result = await mcpClientManager.callTool(name, effectiveInput);\n } else {\n result = { success: false, output: `Unknown tool: ${name}` };\n }\n\n // AfterTool hook — may modify output\n if (hooks.length > 0) {\n const afterResult = await runAfterToolHook(hooks, name, result.output, result.success);\n if (afterResult.modifiedOutput !== undefined) {\n result = { ...result, output: afterResult.modifiedOutput };\n }\n }\n\n return result;\n };\n\n try {\n for (let iteration = 0; iteration < effectiveMaxTurns; iteration++) {\n if (abortSignal?.aborted) {\n logSpan({ action: \"chat.cancelled\", durationMs: Date.now() - sessionStart, context: turnCtx, storeId: storeId || undefined, details: { iteration, reason: \"user_abort\" } });\n callbacks.onError(\"Cancelled\", messages);\n return;\n }\n\n // Budget enforcement — always enforced (defaults to DEFAULT_SESSION_COST_BUDGET_USD)\n if (sessionCostUsd >= effectiveBudget) {\n logSpan({ action: \"chat.budget_exceeded\", durationMs: Date.now() - sessionStart, context: turnCtx, storeId: storeId || undefined, severity: \"warn\", details: { session_cost_usd: sessionCostUsd, max_budget_usd: effectiveBudget, iteration } });\n callbacks.onError(`Budget exceeded: $${sessionCostUsd.toFixed(4)} >= $${effectiveBudget}`, messages);\n return;\n }\n\n const apiStart = Date.now();\n const apiSpanId = generateSpanId();\n const apiRowId = crypto.randomUUID(); // UUID for this span's row — children reference via parent_id\n const costContext = `Session cost: $${sessionCostUsd.toFixed(2)} | Budget remaining: $${(effectiveBudget - sessionCostUsd).toFixed(2)}`;\n\n // Build API request config\n const currentModel = getModel();\n const apiConfig = buildAPIRequest({\n model: currentModel,\n contextProfile: \"main\",\n thinkingEnabled: opts.thinking,\n contextOverrides: ctxOverrides,\n });\n\n // Prepare with prompt caching\n let { tools: cachedTools, messages: cachedMessages } = prepareWithCaching(tools, messages);\n const system = buildSystemBlocks(systemPrompt, costContext);\n\n // Client-side context trimming for non-Anthropic providers.\n // Uses prevIterationInputTokens (actual context size from last API call) — NOT\n // cumulative sessionInputTokens, which grows quadratically and would trigger too early.\n const provider = getProvider(currentModel);\n if (provider === \"gemini\" || provider === \"openai\") {\n const preTrimMessages = cachedMessages;\n if (provider === \"gemini\") {\n // Emergency fallback only — compaction fires at 700K first; trim at 950K catches failures\n cachedMessages = trimGeminiContext(cachedMessages, prevIterationInputTokens);\n } else {\n // Emergency fallback only — compaction fires at 120K first; trim at 190K catches failures\n // GPT-4o: 128K context → 96K threshold (no compaction headroom)\n const threshold = currentModel === \"gpt-4o\" ? 96_000 : 190_000;\n cachedMessages = trimOpenAIContext(cachedMessages, prevIterationInputTokens, threshold);\n }\n // Notify UI when trimming actually occurred (trim returns same ref if no-op)\n if (cachedMessages !== preTrimMessages) {\n // Count tool results before/after to report meaningful numbers\n const countToolResults = (msgs: Anthropic.MessageParam[]) =>\n msgs.reduce((sum, m) => sum + (Array.isArray(m.content)\n ? (m.content as Array<{type?: string; content?: unknown}>).filter(b => b.type === \"tool_result\" && b.content !== \"[trimmed]\").length\n : 0), 0);\n const activeBefore = countToolResults(preTrimMessages);\n const activeAfter = countToolResults(cachedMessages);\n const estimatedSaved = Math.round(prevIterationInputTokens * ((activeBefore - activeAfter) / Math.max(activeBefore, 1)));\n callbacks.onAutoCompact?.(activeBefore, activeAfter, estimatedSaved);\n emitter?.emitCompact(activeBefore, activeAfter, estimatedSaved);\n }\n }\n\n // Get auth token\n const token = await getValidToken();\n if (!token) {\n throw new Error(\"Not logged in. Run: whale login\");\n }\n\n // Call server proxy with built-in retry\n const originalModel = currentModel;\n const stream = await callServerProxy({\n proxyUrl: getProxyUrl(),\n token,\n model: currentModel,\n system,\n messages: cachedMessages,\n tools: cachedTools,\n apiConfig,\n signal: abortSignal,\n fallbackModel: opts.fallbackModel,\n storeId: storeId || undefined,\n onFallback: (from, to) => {\n setModel(to);\n logSpan({ action: \"claude_api_fallback\", durationMs: 0, context: { ...turnCtx, spanId: apiSpanId, parentSpanId: turnSpanId }, storeId: storeId || undefined, details: { from_model: from, to_model: to } });\n },\n onRetry: (attempt, max, err) => {\n const msg = `\\n\\x1b[33m\\u21BB Retrying (${attempt}/${max})... ${err.slice(0, 80)}\\x1b[0m\\n`;\n if (emitter) { emitter.emitText(msg); } else { callbacks.onText(msg); }\n },\n onTokenRefresh: async () => {\n const result = await refreshSession();\n return result.success ? result.config!.access_token! : null;\n },\n });\n\n // Process stream events with UI callbacks\n let thinkingChunks = 0;\n const result: SharedStreamResult = await processStreamWithCallbacks(\n parseSSEStream(stream, abortSignal),\n {\n onText: (text) => {\n if (emitter) {\n emitter.emitText(text);\n } else {\n callbacks.onText(text);\n }\n },\n onThinking: () => {\n thinkingChunks++;\n emitter?.emitThinking(thinkingChunks);\n },\n onToolStart: (name, input) => {\n // NOTE: Do NOT call callbacks.onToolStart here — dispatchTools.onStart\n // fires it once per tool at execution time. Calling it here too would\n // send duplicate tool_start events (stale spinners in WhaleChat).\n if (input) {\n // Tool block complete — emit structured start for CLI TUI only\n emitter?.emitToolStart(\"\", name);\n }\n },\n },\n abortSignal,\n );\n\n // Flush buffered text\n emitter?.flushText();\n\n // Restore original model after transient fallback\n if (getModel() !== originalModel && opts.fallbackModel) {\n setModelById(originalModel);\n }\n\n // Update session token tracking\n sessionInputTokens += result.usage.inputTokens;\n sessionOutputTokens += result.usage.outputTokens;\n prevIterationInputTokens = result.usage.inputTokens; // Actual context size for next trim check\n\n\n // Emit usage with model + cost context for all providers\n if (emitter && (result.usage.inputTokens > 0 || result.usage.outputTokens > 0)) {\n const iterCost = estimateCostUsd(result.usage.inputTokens, result.usage.outputTokens, currentModel, result.thinkingTokens, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n emitter.emitUsage(result.usage.inputTokens, result.usage.outputTokens, currentModel, iterCost, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n }\n\n totalIn += result.usage.inputTokens;\n totalOut += result.usage.outputTokens;\n totalCacheCreation += result.usage.cacheCreationTokens;\n totalCacheRead += result.usage.cacheReadTokens;\n totalThinking += result.thinkingTokens;\n sessionCostUsd += estimateCostUsd(result.usage.inputTokens, result.usage.outputTokens, currentModel, result.thinkingTokens, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n\n // Graduated cost warnings\n emitCostWarningIfNeeded(sessionCostUsd, effectiveBudget, costWarningsEmitted,\n (text) => { if (emitter) { emitter.emitText(text); } else { callbacks.onText(text); } });\n\n // Server-side context management notification\n if (result.contextManagementApplied) {\n callbacks.onAutoCompact?.(messages.length, messages.length, 0);\n emitter?.emitCompact(messages.length, messages.length, 0);\n logSpan({ action: \"chat.api_compaction\", durationMs: Date.now() - apiStart, context: turnCtx, storeId: storeId || undefined, details: { type: \"server_side\", has_compaction_content: result.compactionContent !== null, iteration } });\n }\n\n if (result.text) allAssistantText.push(result.text);\n\n // Telemetry: API call span\n const iterCostUsd = estimateCostUsd(result.usage.inputTokens, result.usage.outputTokens, currentModel, result.thinkingTokens, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n logSpan({\n action: \"claude_api_request\",\n durationMs: Date.now() - apiStart,\n context: { ...turnCtx, spanId: apiSpanId, parentSpanId: turnSpanId, rowId: apiRowId, inputTokens: result.usage.inputTokens, outputTokens: result.usage.outputTokens, totalCost: iterCostUsd, model: currentModel },\n storeId: storeId || undefined,\n details: {\n \"gen_ai.request.model\": currentModel,\n \"gen_ai.usage.input_tokens\": result.usage.inputTokens,\n \"gen_ai.usage.output_tokens\": result.usage.outputTokens,\n \"gen_ai.usage.cache_creation_tokens\": result.usage.cacheCreationTokens,\n \"gen_ai.usage.cache_read_tokens\": result.usage.cacheReadTokens,\n \"gen_ai.usage.cost\": iterCostUsd,\n stop_reason: result.stopReason === \"compaction\" ? \"compaction\" : result.toolUseBlocks.length > 0 ? \"tool_use\" : \"end_turn\",\n iteration,\n tool_count: result.toolUseBlocks.length,\n tool_names: result.toolUseBlocks.map(t => t.name),\n },\n });\n\n // Compaction handling — API paused after generating summary.\n // Per Anthropic docs: the compaction block replaces all prior context.\n // Do NOT preserve old messages — they can exceed the trigger threshold\n // and cause an infinite compaction loop. The summary captures all context.\n if (result.stopReason === \"compaction\" && result.compactionContent) {\n compactionCount++;\n consecutiveCompactions++;\n logSpan({ action: \"chat.compaction_pause\", durationMs: Date.now() - apiStart, context: turnCtx, storeId: storeId || undefined, details: { compaction_count: compactionCount, consecutive: consecutiveCompactions, messages_before: messages.length } });\n\n // Circuit breaker: if compaction fires repeatedly without progress,\n // the summary + system prompt alone may exceed the trigger. Force wrap-up.\n const MAX_CONSECUTIVE_COMPACTIONS = 3;\n const shouldWrapUp =\n consecutiveCompactions > MAX_CONSECUTIVE_COMPACTIONS ||\n compactionCount * effectiveCompactionTrigger >= effectiveCompactionBudget;\n\n const compactedMessages = [\n { role: \"assistant\", content: [{ type: \"compaction\", content: result.compactionContent }] },\n { role: \"user\", content: [{ type: \"text\", text: shouldWrapUp\n ? \"You have reached the context budget. Please wrap up your current work and provide a final summary of what was accomplished and what remains.\"\n : \"Continue with your task.\" }] },\n ];\n messages.length = 0;\n messages.push(...compactedMessages as Anthropic.MessageParam[]);\n\n if (shouldWrapUp) {\n const budgetMsg = consecutiveCompactions > MAX_CONSECUTIVE_COMPACTIONS\n ? \"\\n[Compaction loop detected — wrapping up.]\"\n : \"\\n[Context budget reached — wrapping up.]\";\n if (emitter) { emitter.emitText(budgetMsg); } else { callbacks.onText(budgetMsg); }\n }\n\n iteration--; // Don't count compaction as an iteration\n continue;\n }\n\n // No tool calls — check if we should continue or stop\n if (result.toolUseBlocks.length === 0) {\n // If model hit max_tokens, it was truncated mid-response — continue so it can finish.\n // Cap at MAX_CONTINUATIONS to prevent infinite loops on very large outputs (e.g. HTML reports).\n if (result.stopReason === \"max_tokens\" && maxTokensContinuations < maxContinuations) {\n maxTokensContinuations++;\n const truncatedText = result.text || \"\";\n const assistantContent = buildAssistantContent({\n text: truncatedText,\n toolUseBlocks: [],\n thinkingBlocks: result.thinkingBlocks,\n compactionContent: result.compactionContent,\n });\n messages.push({ role: \"assistant\", content: assistantContent } as unknown as Anthropic.MessageParam);\n\n // Escalating continuation prompts — if the model keeps hitting max_tokens,\n // it's probably trying to write a large file. Guide it toward smaller chunks.\n const continuationText = maxTokensContinuations === 1\n ? \"[Your response was truncated due to the output token limit. If you were writing a large file, split it into multiple smaller write_file calls (~200 lines each) or use run_command with a heredoc. Continue concisely.]\"\n : `[Your response was truncated again (attempt ${maxTokensContinuations}/${maxContinuations}). You MUST reduce output size. For large files: use multiple write_file calls of ~100-200 lines each, or write via run_command. Do NOT attempt to write the entire file in one call.]`;\n messages.push({ role: \"user\", content: [{ type: \"text\", text: continuationText }] } as Anthropic.MessageParam);\n continue;\n }\n break;\n }\n\n // Reset counters — model is taking tool actions, making progress\n maxTokensContinuations = 0;\n consecutiveCompactions = 0;\n\n // Execute tools via shared dispatch\n const { results: toolResults, bailOut, bailMessage } = await dispatchTools(\n result.toolUseBlocks,\n toolExecutor,\n {\n loopDetector,\n maxConcurrent: resolved?.maxConcurrentTools ?? AGENT_DEFAULTS.maxConcurrentTools,\n batchErrorLimit: resolved?.loopBatchErrorLimit ?? AGENT_DEFAULTS.loopBatchErrorLimit,\n onStart: (name, input) => {\n callbacks.onToolStart(name, input);\n },\n onResult: (name, success, output, durationMs) => {\n callbacks.onToolResult(name, success, output, undefined, durationMs);\n logSpan({\n action: `tool.${name}`,\n durationMs,\n context: { ...turnCtx, spanId: generateSpanId(), parentSpanId: apiSpanId, parentId: apiRowId },\n storeId: storeId || undefined,\n error: success ? undefined : output,\n details: {\n tool_input: {},\n tool_result: truncateResult(output, 2000),\n error_type: success ? undefined : classifyToolError(output),\n iteration,\n },\n });\n },\n signal: abortSignal,\n transcribeAudio: storeId\n ? async (base64, mediaType) => callTranscribe({\n proxyUrl: getProxyUrl(),\n token,\n storeId: storeId!,\n audioBase64: base64,\n mediaType,\n })\n : undefined,\n },\n );\n\n if (bailOut) {\n logSpan({ action: \"chat.bail_out\", durationMs: Date.now() - sessionStart, context: turnCtx, storeId: storeId || undefined, severity: \"warn\", details: { ...loopDetector.getSessionStats(), message: bailMessage, iteration } });\n }\n\n // Shell output summarization — summarize long bash output to save context window\n const toolNameMap = new Map(result.toolUseBlocks.map(t => [t.id, t.name]));\n const finalToolResults = await summarizeLongToolResults(\n toolResults,\n toolNameMap,\n getProxyUrl(),\n token,\n shellSummarization,\n storeId || undefined,\n );\n\n // Build assistant content and append to conversation\n const assistantContent = buildAssistantContent({\n text: result.text,\n toolUseBlocks: result.toolUseBlocks,\n thinkingBlocks: result.thinkingBlocks,\n compactionContent: result.compactionContent,\n });\n messages.push({ role: \"assistant\", content: assistantContent as any });\n\n // Check for __PLAN_APPROVED_CLEAN__ marker — clear context and start fresh with just the plan\n const planCleanMarker = \"__PLAN_APPROVED_CLEAN__\\n\";\n const hasCleanPlanApproval = finalToolResults.some((tr: any) => {\n const content = typeof tr.content === \"string\" ? tr.content : \"\";\n return content.startsWith(planCleanMarker);\n });\n if (hasCleanPlanApproval) {\n // Extract plan content from the marker\n const planResult = finalToolResults.find((tr: any) => {\n const content = typeof tr.content === \"string\" ? tr.content : \"\";\n return content.startsWith(planCleanMarker);\n }) as any;\n const planText = (planResult.content as string).slice(planCleanMarker.length);\n const beforeCount = messages.length;\n messages.length = 0;\n messages.push({ role: \"user\", content: [{ type: \"text\", text: `Implement this plan:\\n\\n${planText}` }] } as any);\n callbacks.onAutoCompact?.(beforeCount, 1, 0);\n continue;\n }\n\n messages.push({ role: \"user\", content: finalToolResults as any });\n\n // Non-native compaction for OpenAI/Gemini — fires after tool results appended\n const compactionCfg = getCompactionConfig(currentModel);\n if (!compactionCfg.isNative && result.usage.inputTokens >= compactionCfg.triggerTokens) {\n compactionCount++;\n\n if (compactionCount * compactionCfg.triggerTokens >= compactionCfg.totalBudget) {\n // Budget exhaustion — force wrap-up (same as native compaction budget logic)\n const budgetMsg = \"\\n[Context budget reached — wrapping up.]\";\n if (emitter) { emitter.emitText(budgetMsg); } else { callbacks.onText(budgetMsg); }\n\n const summary = await requestProviderCompaction({\n proxyUrl: getProxyUrl(),\n token,\n messages,\n systemPrompt,\n });\n const compactedMessages = [\n ...(summary\n ? [{ role: \"assistant\", content: [{ type: \"compaction\", content: summary }] }]\n : []),\n { role: \"user\", content: [{ type: \"text\", text: \"You have reached the context budget. Please wrap up your current work and provide a final summary of what was accomplished and what remains.\" }] },\n ];\n messages.length = 0;\n messages.push(...compactedMessages as Anthropic.MessageParam[]);\n continue;\n }\n\n // Normal compaction — summarize, don't preserve old messages (prevents loop)\n const summary = await requestProviderCompaction({\n proxyUrl: getProxyUrl(),\n token,\n messages: messages as any,\n systemPrompt,\n });\n\n if (summary) {\n const beforeCount = messages.length;\n const compactedMessages = [\n { role: \"assistant\", content: [{ type: \"compaction\", content: summary }] },\n { role: \"user\", content: [{ type: \"text\", text: \"Continue with your task.\" }] },\n ];\n messages.length = 0;\n messages.push(...compactedMessages as Anthropic.MessageParam[]);\n iteration--; // Don't count compaction as an iteration\n\n callbacks.onAutoCompact?.(beforeCount, messages.length, Math.round(result.usage.inputTokens * 0.7));\n emitter?.emitCompact(beforeCount, messages.length, Math.round(result.usage.inputTokens * 0.7));\n\n logSpan({ action: \"chat.provider_compaction\", durationMs: 0, context: turnCtx, storeId: storeId || undefined, details: { compaction_count: compactionCount, provider, model: currentModel, input_tokens: result.usage.inputTokens, trigger_tokens: compactionCfg.triggerTokens } });\n }\n }\n }\n\n // Telemetry: session summary\n logSpan({\n action: \"chat.session_complete\",\n durationMs: Date.now() - sessionStart,\n context: { ...turnCtx, inputTokens: totalIn, outputTokens: totalOut, model: activeModel },\n storeId: storeId || undefined,\n details: {\n input_tokens: totalIn, output_tokens: totalOut, total_tokens: totalIn + totalOut,\n cache_creation_tokens: totalCacheCreation, cache_read_tokens: totalCacheRead,\n session_input_tokens: sessionInputTokens, session_output_tokens: sessionOutputTokens,\n model: activeModel,\n },\n });\n\n const turnCostUsd = estimateCostUsd(totalIn, totalOut, activeModel, totalThinking, totalCacheRead, totalCacheCreation);\n callbacks.onUsage(totalIn, totalOut, totalThinking, activeModel, turnCostUsd, totalCacheRead, totalCacheCreation);\n\n // Flush telemetry spans to server before session ends\n flushCliSpans();\n\n // Fire SessionEnd hook (non-blocking)\n if (hooks.length > 0) {\n runSessionHook(hooks, \"SessionEnd\", { session_id: `turn-${sessionStart}` }).catch(() => {});\n }\n\n const finalText = allAssistantText.length > 0 ? allAssistantText[allAssistantText.length - 1] : \"\";\n emitter?.emitDone(finalText, messages);\n if (emitter) clearGlobalEmitter();\n callbacks.onDone(messages);\n } catch (err: any) {\n const errorMsg = abortSignal?.aborted || err?.message === \"Cancelled\"\n ? \"Cancelled\"\n : String(err?.message || err);\n\n logSpan({\n action: errorMsg === \"Cancelled\" ? \"chat.cancelled\" : \"chat.fatal_error\",\n durationMs: Date.now() - sessionStart,\n context: { ...turnCtx, inputTokens: totalIn, outputTokens: totalOut, model: activeModel },\n storeId: storeId || undefined,\n severity: errorMsg === \"Cancelled\" ? \"info\" : \"error\",\n error: errorMsg === \"Cancelled\" ? undefined : errorMsg,\n details: { input_tokens: totalIn, output_tokens: totalOut, session_cost_usd: sessionCostUsd, model: activeModel },\n });\n\n // Capture to error_events (not just audit_logs) for non-cancellations\n if (errorMsg !== \"Cancelled\") {\n captureError({\n error: err instanceof Error ? err : undefined,\n errorType: \"AgentLoopError\",\n errorMessage: errorMsg,\n severity: \"error\",\n traceId: turnCtx.traceId,\n spanId: turnCtx.spanId,\n storeId: storeId || undefined,\n tags: { model: activeModel, turn: String(turnNum) },\n });\n }\n\n // Flush telemetry on error path too\n flushCliSpans();\n\n emitter?.emitError(errorMsg);\n if (emitter) clearGlobalEmitter();\n callbacks.onError(errorMsg, messages);\n }\n}\n\n// ============================================================================\n// TELEMETRY HELPERS\n// ============================================================================\n\nexport function truncateResult(output: string, maxLen: number): string {\n if (output.length <= maxLen) return output;\n return output.slice(0, maxLen) + `... (${output.length} chars total)`;\n}\n\nexport function classifyToolError(output: string): string {\n const lower = output.toLowerCase();\n if (lower.includes(\"timed out\") || lower.includes(\"timeout\")) return \"timeout\";\n if (lower.includes(\"permission denied\") || lower.includes(\"eacces\")) return \"permission\";\n if (lower.includes(\"not found\") || lower.includes(\"no such file\")) return \"not_found\";\n if (lower.includes(\"command not found\") || lower.includes(\"exit code 127\")) return \"command_not_found\";\n if (lower.includes(\"import\") && lower.includes(\"error\")) return \"import_error\";\n if (lower.includes(\"syntax\") || lower.includes(\"parse\")) return \"syntax_error\";\n if (lower.includes(\"externally-managed\")) return \"env_managed\";\n return \"unknown\";\n}\n\n// Convenience: check if user can use the agent (logged in OR has API key)\nexport function canUseAgent(): { ready: boolean; reason?: string } {\n const config = loadConfig();\n const hasToken = !!(config.access_token && config.refresh_token);\n const hasApiKey = !!(process.env.ANTHROPIC_API_KEY || config.anthropic_api_key);\n\n if (hasToken || hasApiKey) return { ready: true };\n return { ready: false, reason: \"Run `whale login` to authenticate.\" };\n}\n\n// ============================================================================\n// SESSION MODE — delegate to server-side SessionManager\n// ============================================================================\n\nimport { SessionClient } from \"./session-client.js\";\n\n/** Check if session mode should be used (auto-detect by default). */\nasync function shouldUseSessionMode(): Promise<boolean> {\n if (process.env.WHALE_SESSION_MODE === \"off\") return false;\n if (process.env.WHALE_SESSION_MODE === \"on\") return true;\n\n // Never auto-activate for interactive CLI — the emitter-based TUI\n // requires the local loop. Session mode only activates via explicit\n // env var or `whale resume <id>` (which sets WHALE_SESSION_MODE=on).\n if (process.stdin.isTTY) return false;\n\n // Auto: if logged in + server reachable → session mode (non-TTY: print mode, MCP)\n const proxyUrl = getProxyUrl();\n if (!proxyUrl) return false;\n\n const config = resolveConfig();\n if (!config.storeId) return false;\n\n const client = new SessionClient(proxyUrl, getValidToken);\n return client.healthCheck();\n}\n\n/**\n * Run agent loop in session mode — all state managed server-side.\n * The entire existing local loop stays as offline fallback.\n */\nasync function runSessionAgentLoop(opts: AgentLoopOptions): Promise<void> {\n const { message, conversationHistory, callbacks, abortSignal, emitter } = opts;\n const proxyUrl = getProxyUrl();\n if (!proxyUrl) throw new Error(\"Session mode requires server connection\");\n\n // Set global emitter for subagents (mirrors local loop behavior)\n if (emitter) setGlobalEmitter(emitter);\n\n const client = new SessionClient(proxyUrl, getValidToken);\n const config = resolveConfig();\n const storeId = config.storeId;\n\n if (!storeId) {\n callbacks.onError(\"Session mode requires store_id in config. Falling back to local mode.\");\n if (emitter) clearGlobalEmitter();\n return;\n }\n\n // Resolve agent ID: use config, or query server for store's first active agent\n let agentId = config.defaultAgentId;\n if (!agentId) {\n agentId = (await resolveDefaultAgentId(proxyUrl, storeId, getValidToken)) || \"\";\n }\n if (!agentId) {\n callbacks.onError(\"No agent configured. Set default_agent_id in config or create an agent. Falling back to local mode.\");\n if (emitter) clearGlobalEmitter();\n return;\n }\n\n // Resume existing session or create new one\n const resumeId = process.env.WHALE_RESUME_SESSION_ID;\n let sessionId: string;\n if (resumeId) {\n sessionId = resumeId;\n delete process.env.WHALE_RESUME_SESSION_ID; // consume once\n } else {\n const session = await client.createSession({\n storeId,\n agentId,\n surface: \"cli\",\n message,\n });\n sessionId = session.id;\n }\n\n // Save local session backup with server session reference\n const localSessionId = saveSession(conversationHistory);\n updateSessionMeta(localSessionId, { serverSessionId: sessionId, synced: true });\n\n // Track accumulated text for emitDone — the TUI's handleDone handler\n // overwrites accTextRef with event.text, so we must pass the full text.\n let accumulatedText = \"\";\n // Guard against double-error: SessionClient.sendMessage calls onError AND\n // throws for HTTP errors. The catch must not re-fire emitter/callbacks.\n let errorHandled = false;\n\n try {\n await client.sendMessage(sessionId, message, {\n onText: (text) => {\n accumulatedText += text;\n if (emitter) {\n emitter.emitText(text);\n } else {\n callbacks.onText(text);\n }\n },\n onToolStart: (name: string, input?: unknown) => {\n callbacks.onToolStart(name, input as Record<string, unknown> | undefined);\n if (input) emitter?.emitToolStart(\"\", name);\n },\n onToolResult: (name, success, result) => {\n callbacks.onToolResult(name, success, result);\n },\n onUsage: (tokens, costUsd) => {\n callbacks.onUsage(tokens.input, tokens.output, 0, getModel(), costUsd, tokens.cacheRead, tokens.cacheCreation);\n if (emitter && (tokens.input > 0 || tokens.output > 0)) {\n emitter.emitUsage(tokens.input, tokens.output, getModel(), costUsd, tokens.cacheRead, tokens.cacheCreation);\n }\n },\n onDone: (_conversationId) => {\n emitter?.flushText();\n emitter?.emitDone(accumulatedText, conversationHistory);\n if (emitter) clearGlobalEmitter();\n callbacks.onDone(conversationHistory);\n },\n onError: (err) => {\n errorHandled = true;\n emitter?.emitError(err);\n if (emitter) clearGlobalEmitter();\n callbacks.onError(err);\n },\n }, abortSignal);\n } catch (err: any) {\n if (!errorHandled) {\n const errorMsg = abortSignal?.aborted || err?.message === \"Cancelled\"\n ? \"Cancelled\"\n : String(err?.message || err);\n emitter?.emitError(errorMsg);\n if (emitter) clearGlobalEmitter();\n callbacks.onError(errorMsg);\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"agent-loop.js","names":["LOCAL_TOOL_DEFINITIONS","executeLocalTool","isLocalTool","INTERACTIVE_TOOL_DEFINITIONS","executeInteractiveTool","waitForPlanApproval","loadConfig","resolveConfig","getProxyUrl","resolveDefaultAgentId","getValidToken","refreshSession","isServerTool","loadServerToolDefinitions","executeServerTool","getServerStatus","setServerToolContext","nextTurn","createTurnContext","createConversationContext","logSpan","generateSpanId","flushCliSpans","getConversationRootSpanId","captureError","addBreadcrumb","setGlobalEmitter","clearGlobalEmitter","mcpClientManager","loadHooks","runBeforeToolHook","runAfterToolHook","runSessionHook","LoopDetector","COMPACTION_TOTAL_BUDGET","getCompactionConfig","getContextManagement","DEFAULT_SESSION_COST_BUDGET_USD","emitCostWarningIfNeeded","resolveAgentLoopConfig","AGENT_DEFAULTS","loadCLIAgentConfig","resetAgentConfigCache","parseSSEStream","processStreamWithCallbacks","collectStreamResult","callServerProxy","callTranscribe","buildAPIRequest","buildSystemBlocks","prepareWithCaching","trimGeminiContext","trimOpenAIContext","requestProviderCompaction","getProvider","MODELS","dispatchTools","buildAssistantContent","loadMemory","addMemory","removeMemory","listMemories","refreshGitContext","resetGitContext","loadClaudeMd","reloadClaudeMd","resetClaudeMdCache","clearReadCache","setPermissionMode","getPermissionMode","isToolAllowedByPermission","setModel","setModelById","getModel","getModelShortName","estimateCostUsd","saveSession","loadSession","listSessions","findLatestSessionForCwd","updateSessionMeta","buildSystemPrompt","listProcesses","listBackgroundAgents","AgentEventEmitter","sessionInputTokens","sessionOutputTokens","getSessionTokens","input","output","resetSessionState","sessionLoopDetector","CLI_NO_LIMIT","Number","MAX_SAFE_INTEGER","SHELL_SUMMARIZE_LINE_THRESHOLD","SHELL_SUMMARIZE_SIZE_THRESHOLD","SHELL_SUMMARIZE_MAX_INPUT","SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES","shouldSummarizeShellOutput","length","lineCount","split","summarizeShellOutput","proxyUrl","token","storeId","truncatedForSummary","slice","summaryConfig","model","HAIKU","contextProfile","stream","system","type","text","messages","role","content","tools","apiConfig","timeoutMs","result","summary","trim","originalLines","preview","join","summarizeLongToolResults","toolResults","toolNames","shellSummarization","tasks","map","toolName","get","tool_use_id","summarized","Promise","all","getTools","allowedTools","disallowedTools","localTools","t","name","description","input_schema","skipPlanTools","interactiveTools","filter","push","serverTools","localNames","Set","uniqueServerTools","has","mcpTools","allTools","allowed","disallowed","serverToolCount","getServerToolCount","defs","runAgentLoop","opts","shouldUseSessionMode","runSessionAgentLoop","message","conversationHistory","callbacks","abortSignal","emitter","effectiveMaxTurns","maxTurns","hooksCwd","cwd","process","hooks","session_id","Date","now","catch","systemPrompt","effort","userContent","images","blocks","img","source","media_type","mediaType","data","base64","totalIn","totalOut","totalCacheCreation","totalCacheRead","totalThinking","allAssistantText","prevIterationInputTokens","sessionStart","turnNum","turnCtx","turnNumber","turnSpanId","spanId","action","durationMs","context","parentSpanId","undefined","details","conversation_id","conversationId","traceId","userId","userEmail","conversation_history_length","sessionCostUsd","compactionCount","consecutiveCompactions","maxTokensContinuations","costWarningsEmitted","activeModel","dbAgent","resolved","fromResolved","loopDetector","resetTurn","effectiveBudget","maxBudgetUsd","contextOverrides","session_cost_budget_usd","ctxOverrides","ctxMgmt","compactEdit","config","edits","find","e","effectiveCompactionTrigger","trigger","value","compactionTriggerTokens","effectiveCompactionBudget","compaction_total_budget","maxContinuations","INTERACTIVE_TOOL_NAMES","toolExecutor","success","effectiveInput","hookResult","allow","modifiedInput","decision","feedback","isMcpTool","callTool","afterResult","modifiedOutput","iteration","aborted","reason","onError","severity","session_cost_usd","max_budget_usd","toFixed","apiStart","apiSpanId","apiRowId","crypto","randomUUID","costContext","currentModel","thinkingEnabled","thinking","cachedTools","cachedMessages","provider","preTrimMessages","threshold","countToolResults","msgs","reduce","sum","m","Array","isArray","b","activeBefore","activeAfter","estimatedSaved","Math","round","max","onAutoCompact","emitCompact","Error","originalModel","signal","fallbackModel","onFallback","from","to","from_model","to_model","onRetry","attempt","err","msg","emitText","onText","onTokenRefresh","access_token","thinkingChunks","onThinking","emitThinking","onToolStart","emitToolStart","flushText","usage","inputTokens","outputTokens","iterCost","thinkingTokens","cacheReadTokens","cacheCreationTokens","emitUsage","contextManagementApplied","has_compaction_content","compactionContent","iterCostUsd","rowId","totalCost","stop_reason","stopReason","toolUseBlocks","tool_count","tool_names","compaction_count","consecutive","messages_before","MAX_CONSECUTIVE_COMPACTIONS","shouldWrapUp","compactedMessages","budgetMsg","truncatedText","assistantContent","thinkingBlocks","continuationText","results","bailOut","bailMessage","maxConcurrent","maxConcurrentTools","batchErrorLimit","loopBatchErrorLimit","onStart","onResult","onToolResult","parentId","error","tool_input","tool_result","truncateResult","error_type","classifyToolError","transcribeAudio","audioBase64","getSessionStats","toolNameMap","Map","id","finalToolResults","planCleanMarker","hasCleanPlanApproval","some","tr","startsWith","planResult","planText","beforeCount","compactionCfg","isNative","triggerTokens","totalBudget","input_tokens","trigger_tokens","output_tokens","total_tokens","cache_creation_tokens","cache_read_tokens","session_input_tokens","session_output_tokens","turnCostUsd","onUsage","finalText","emitDone","onDone","errorMsg","String","errorType","errorMessage","tags","turn","emitError","maxLen","lower","toLowerCase","includes","canUseAgent","hasToken","refresh_token","hasApiKey","env","ANTHROPIC_API_KEY","ready","SessionClient","WHALE_SESSION_MODE","stdin","isTTY","client","healthCheck","agentId","defaultAgentId","resumeId","WHALE_RESUME_SESSION_ID","sessionId","session","createSession","surface","localSessionId","serverSessionId","synced","accumulatedText","errorHandled","sendMessage","tokens","costUsd","cacheRead","cacheCreation","_conversationId"],"sources":["../../../src/cli/services/agent-loop.ts"],"sourcesContent":["/**\n * Agent Loop — local-first agentic CLI with server tool support\n *\n * LLM calls proxy through the `agent-proxy` edge function (server holds API key).\n * User authenticates via Supabase JWT. Local tools execute on the client.\n * Server tools execute via direct import of executeTool() (same codebase).\n *\n * Fallback: if proxy is unavailable and ANTHROPIC_API_KEY is set, calls directly.\n *\n * This file is the thin orchestrator + re-export facade. Domain logic lives in:\n * - memory-manager.ts (loadMemory, addMemory, removeMemory, listMemories)\n * - git-context.ts (gatherGitContext, refreshGitContext)\n * - claude-md-loader.ts (loadClaudeMd, reloadClaudeMd)\n * - permission-modes.ts (PermissionMode, set/get/isAllowed)\n * - model-manager.ts (setModel, getModel, getModelShortName, estimateCostUsd)\n * - session-persistence.ts (SessionMeta, save/load/list/find sessions)\n * - system-prompt.ts (buildSystemPrompt)\n */\n\nimport type Anthropic from \"@anthropic-ai/sdk\";\nimport {\n LOCAL_TOOL_DEFINITIONS,\n executeLocalTool,\n isLocalTool,\n} from \"./local-tools.js\";\nimport {\n INTERACTIVE_TOOL_DEFINITIONS,\n executeInteractiveTool,\n waitForPlanApproval,\n type PlanApprovalDecision,\n} from \"./interactive-tools.js\";\nimport { loadConfig, resolveConfig, getProxyUrl, resolveDefaultAgentId } from \"./config-store.js\";\nimport { getValidToken, refreshSession } from \"./auth-service.js\";\nimport {\n isServerTool,\n loadServerToolDefinitions,\n executeServerTool,\n getServerStatus,\n setServerToolContext,\n type ServerStatus,\n} from \"./server-tools.js\";\nimport {\n nextTurn,\n createTurnContext,\n createConversationContext,\n logSpan,\n generateSpanId,\n flushCliSpans,\n getConversationTraceId,\n getConversationRootSpanId,\n} from \"./telemetry.js\";\nimport { captureError, addBreadcrumb } from \"./error-logger.js\";\nimport {\n AgentEventEmitter,\n setGlobalEmitter,\n clearGlobalEmitter,\n} from \"./agent-events.js\";\nimport { mcpClientManager } from \"./mcp-client.js\";\nimport { loadHooks, runBeforeToolHook, runAfterToolHook, runSessionHook, type HookConfig } from \"./hooks.js\";\nimport { LoopDetector, COMPACTION_TOTAL_BUDGET, getCompactionConfig, getContextManagement, DEFAULT_SESSION_COST_BUDGET_USD, emitCostWarningIfNeeded, resolveAgentLoopConfig, AGENT_DEFAULTS } from \"../../shared/agent-core.js\";\nimport { loadCLIAgentConfig, resetAgentConfigCache } from \"./agent-config.js\";\nimport { parseSSEStream, processStreamWithCallbacks, collectStreamResult } from \"../../shared/sse-parser.js\";\nimport { callServerProxy, callTranscribe, buildAPIRequest, buildSystemBlocks, prepareWithCaching, trimGeminiContext, trimOpenAIContext, requestProviderCompaction } from \"../../shared/api-client.js\";\nimport { getProvider, MODELS } from \"../../shared/constants.js\";\nimport { dispatchTools, buildAssistantContent } from \"../../shared/tool-dispatch.js\";\nimport type { StreamResult as SharedStreamResult, ToolResultMessage } from \"../../shared/types.js\";\n\n// ── Extracted modules (re-exported below for backward compatibility) ──\nimport { loadMemory, addMemory, removeMemory, listMemories } from \"./memory-manager.js\";\nimport { refreshGitContext, resetGitContext } from \"./git-context.js\";\nimport { loadClaudeMd, reloadClaudeMd, resetClaudeMdCache } from \"./claude-md-loader.js\";\nimport { clearReadCache } from \"./tools/file-ops.js\";\nimport { setPermissionMode, getPermissionMode, isToolAllowedByPermission, type PermissionMode } from \"./permission-modes.js\";\nimport { setModel, setModelById, getModel, getModelShortName, estimateCostUsd } from \"./model-manager.js\";\nimport { saveSession, loadSession, listSessions, findLatestSessionForCwd, updateSessionMeta, type SessionMeta } from \"./session-persistence.js\";\nimport { buildSystemPrompt } from \"./system-prompt.js\";\n\n// ============================================================================\n// RE-EXPORTS — legacy compatibility. Prefer importing from source modules directly:\n// memory-manager.ts, git-context.ts, claude-md-loader.ts,\n// permission-modes.ts, model-manager.ts, session-persistence.ts,\n// server-tools.ts, mcp-client.ts, background-processes.ts, agent-events.ts\n// ============================================================================\n\n// Memory → import from \"./memory-manager.js\"\nexport { loadMemory, addMemory, removeMemory, listMemories };\n\n// Git context → import from \"./git-context.js\"\nexport { refreshGitContext };\n\n// CLAUDE.md → import from \"./claude-md-loader.js\"\nexport { loadClaudeMd, reloadClaudeMd };\n\n// Permission modes → import from \"./permission-modes.js\"\nexport { setPermissionMode, getPermissionMode, isToolAllowedByPermission, type PermissionMode };\n\n// Model management → import from \"./model-manager.js\"\nexport { setModel, getModel, getModelShortName, estimateCostUsd };\n\n// Session persistence → import from \"./session-persistence.js\"\nexport { saveSession, loadSession, listSessions, findLatestSessionForCwd, updateSessionMeta, type SessionMeta };\n\n// Server status → import from \"./server-tools.js\"\nexport { getServerStatus, type ServerStatus };\n\n// MCP client manager → import from \"./mcp-client.js\"\nexport { mcpClientManager };\n\n// Background processes → import from \"./background-processes.js\"\nexport { listProcesses, listBackgroundAgents } from \"./background-processes.js\";\n\n// Event emitter → import from \"./agent-events.js\"\nexport { AgentEventEmitter, type AgentEvent } from \"./agent-events.js\";\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface AgentLoopCallbacks {\n onText: (text: string) => void;\n onToolStart: (name: string, input?: Record<string, unknown>) => void;\n onToolResult: (name: string, success: boolean, result: unknown, input?: Record<string, unknown>, durationMs?: number) => void;\n onUsage: (input_tokens: number, output_tokens: number, thinking_tokens?: number, model?: string, costUsd?: number, cacheReadTokens?: number, cacheCreationTokens?: number) => void;\n onDone: (finalMessages: Anthropic.MessageParam[]) => void;\n onError: (error: string, partialMessages?: Anthropic.MessageParam[]) => void;\n onAutoCompact?: (beforeMessages: number, afterMessages: number, tokensSaved: number) => void;\n}\n\nexport interface AgentLoopOptions {\n message: string;\n images?: { base64: string; mediaType: string }[]; // Image attachments (base64-encoded)\n conversationHistory: Anthropic.MessageParam[];\n callbacks: AgentLoopCallbacks;\n abortSignal?: AbortSignal;\n model?: string;\n emitter?: AgentEventEmitter; // Event emitter for decoupled UI\n // v4.7.0 extensions\n maxTurns?: number;\n maxBudgetUsd?: number;\n effort?: \"low\" | \"medium\" | \"high\";\n allowedTools?: string[];\n disallowedTools?: string[];\n fallbackModel?: string;\n // v5.1.0 — extended thinking\n thinking?: boolean;\n // v6.1.0 — shell output summarization\n shellSummarization?: boolean; // default: true\n // v6.1.0 — working directory for hooks\n cwd?: string;\n}\n\n// ============================================================================\n// SESSION STATE\n// ============================================================================\n\n// CLI-only: Session-wide token tracking (actual counts from API responses).\n// Reset via resetSessionState() when starting a new conversation.\nlet sessionInputTokens = 0;\nlet sessionOutputTokens = 0;\n\nexport function getSessionTokens(): { input: number; output: number } {\n return { input: sessionInputTokens, output: sessionOutputTokens };\n}\n\n/**\n * Reset all CLI-only session state. Call when starting a new conversation\n * (e.g., /clear command, new print-mode run) to prevent stale token counts,\n * loop detector state, and caches from leaking across sessions.\n *\n * Does NOT reset activeModel or permissionMode — those are user preferences\n * that persist intentionally until explicitly changed.\n */\nexport function resetSessionState(): void {\n sessionInputTokens = 0;\n sessionOutputTokens = 0;\n sessionLoopDetector = null;\n resetGitContext();\n resetClaudeMdCache();\n clearReadCache();\n resetAgentConfigCache();\n // Reset conversation-level trace context so the next conversation gets a fresh trace\n createConversationContext();\n}\n\n/** CLI-only: loop detector — persists session error state across turns (reset by resetSessionState) */\nlet sessionLoopDetector: LoopDetector | null = null;\n\n// No artificial turn cap — agent self-regulates via end_turn (Claude Code parity).\n// Safety: LoopDetector catches loops, cost budget catches runaway spending, user has Ctrl+C.\nconst CLI_NO_LIMIT = Number.MAX_SAFE_INTEGER;\n\n// ============================================================================\n// SHELL OUTPUT SUMMARIZATION\n// ============================================================================\n\nconst SHELL_SUMMARIZE_LINE_THRESHOLD = 800;\nconst SHELL_SUMMARIZE_SIZE_THRESHOLD = 200_000; // 200KB — only summarize truly huge outputs\nconst SHELL_SUMMARIZE_MAX_INPUT = 300_000; // 300KB max to summarizer\nconst SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES = 20;\n\n/**\n * Check if shell output should be summarized based on line count or size.\n */\nfunction shouldSummarizeShellOutput(output: string): boolean {\n if (output.length > SHELL_SUMMARIZE_SIZE_THRESHOLD) return true;\n const lineCount = output.split(\"\\n\").length;\n return lineCount > SHELL_SUMMARIZE_LINE_THRESHOLD;\n}\n\n/**\n * Summarize long shell output using Haiku via server proxy.\n * Returns summarized output or original if summarization fails.\n */\nasync function summarizeShellOutput(\n output: string,\n proxyUrl: string,\n token: string,\n storeId?: string,\n): Promise<string> {\n const lineCount = output.split(\"\\n\").length;\n const truncatedForSummary = output.length > SHELL_SUMMARIZE_MAX_INPUT\n ? output.slice(0, SHELL_SUMMARIZE_MAX_INPUT) + \"\\n... (truncated for summarization)\"\n : output;\n\n try {\n const summaryConfig = buildAPIRequest({\n model: MODELS.HAIKU,\n contextProfile: \"subagent\",\n });\n\n const stream = await callServerProxy({\n proxyUrl,\n token,\n model: MODELS.HAIKU,\n system: [{ type: \"text\", text: \"You are a concise technical summarizer. Summarize shell/command output preserving key information, errors, warnings, file paths, and actionable items. Be brief but thorough.\" }],\n messages: [{ role: \"user\", content: `Summarize this shell output concisely, preserving key information, errors, and actionable items:\\n\\n${truncatedForSummary}` }],\n tools: [],\n apiConfig: summaryConfig,\n storeId,\n timeoutMs: 15_000,\n });\n\n const result = await collectStreamResult(parseSSEStream(stream));\n const summary = result.text.trim();\n\n if (!summary) return output; // Summarization failed, return original\n\n // Build first N lines preview\n const originalLines = output.split(\"\\n\");\n const preview = originalLines.slice(0, SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES).join(\"\\n\");\n\n return `[Summarized from ${lineCount} lines]\\n\\n${summary}\\n\\n[First ${SHELL_SUMMARIZE_ORIGINAL_PREVIEW_LINES} lines of original output]\\n${preview}`;\n } catch {\n // Summarization failed silently — return original output\n return output;\n }\n}\n\n/**\n * Post-process tool results to summarize long bash output.\n * Only affects bash tool results that exceed size/line thresholds.\n */\nasync function summarizeLongToolResults(\n toolResults: ToolResultMessage[],\n toolNames: Map<string, string>,\n proxyUrl: string,\n token: string,\n shellSummarization: boolean,\n storeId?: string,\n): Promise<ToolResultMessage[]> {\n if (!shellSummarization) return toolResults;\n\n const tasks = toolResults.map(async (result) => {\n // Only summarize bash tool string results\n const toolName = toolNames.get(result.tool_use_id);\n if (toolName !== \"bash\" || typeof result.content !== \"string\") return result;\n\n // Check thresholds\n if (!shouldSummarizeShellOutput(result.content)) return result;\n\n const summarized = await summarizeShellOutput(result.content, proxyUrl, token, storeId);\n return { ...result, content: summarized };\n });\n\n return Promise.all(tasks);\n}\n\n// ============================================================================\n// TOOL DEFINITIONS\n// ============================================================================\n\nasync function getTools(allowedTools?: string[], disallowedTools?: string[]): Promise<{ tools: Anthropic.Tool[]; serverToolCount: number }> {\n const localTools: Anthropic.Tool[] = LOCAL_TOOL_DEFINITIONS.map((t) => ({\n name: t.name,\n description: t.description,\n input_schema: t.input_schema as Anthropic.Tool[\"input_schema\"],\n }));\n\n // Add interactive tools — skip plan mode tools in yolo mode (user doesn't want plan gates)\n const skipPlanTools = getPermissionMode() === \"yolo\";\n const interactiveTools: Anthropic.Tool[] = INTERACTIVE_TOOL_DEFINITIONS\n .filter((t) => !skipPlanTools || (t.name !== \"enter_plan_mode\" && t.name !== \"exit_plan_mode\"))\n .map((t) => ({\n name: t.name,\n description: t.description,\n input_schema: t.input_schema as Anthropic.Tool[\"input_schema\"],\n }));\n localTools.push(...interactiveTools);\n\n let serverTools: Anthropic.Tool[] = [];\n try {\n serverTools = await loadServerToolDefinitions();\n } catch {\n // Server tools silently unavailable\n }\n\n // Deduplicate: local tools take priority over server tools with the same name\n const localNames = new Set(localTools.map(t => t.name));\n const uniqueServerTools = serverTools.filter(t => !localNames.has(t.name));\n\n // MCP tools from external servers\n const mcpTools = mcpClientManager.getTools();\n\n let allTools = [...localTools, ...uniqueServerTools, ...mcpTools];\n\n // Apply tool filtering\n if (allowedTools && allowedTools.length > 0) {\n const allowed = new Set(allowedTools);\n allTools = allTools.filter(t => allowed.has(t.name));\n }\n if (disallowedTools && disallowedTools.length > 0) {\n const disallowed = new Set(disallowedTools);\n allTools = allTools.filter(t => !disallowed.has(t.name));\n }\n\n return {\n tools: allTools,\n serverToolCount: uniqueServerTools.length,\n };\n}\n\n/** Exposed for /status command */\nexport async function getServerToolCount(): Promise<number> {\n try {\n const defs = await loadServerToolDefinitions();\n return defs.length;\n } catch {\n return 0;\n }\n}\n\n// ============================================================================\n// MAIN LOOP\n// ============================================================================\n\nexport async function runAgentLoop(opts: AgentLoopOptions): Promise<void> {\n // Session mode: delegate to server-side SessionManager when available\n if (await shouldUseSessionMode()) {\n return runSessionAgentLoop(opts);\n }\n\n const { message, conversationHistory, callbacks, abortSignal, emitter } = opts;\n if (opts.model) setModel(opts.model);\n\n // Set global emitter for subagents to use\n if (emitter) {\n setGlobalEmitter(emitter);\n }\n\n // effectiveMaxTurns resolved after DB config fetch below\n // 0 or unset = no limit (Claude Code parity — agent self-regulates via end_turn)\n let effectiveMaxTurns = opts.maxTurns || CLI_NO_LIMIT;\n\n // Load hooks from project and user config\n const hooksCwd = opts.cwd || process.cwd();\n const hooks = loadHooks(hooksCwd);\n\n // Fire SessionStart hook (non-blocking)\n if (hooks.length > 0) {\n runSessionHook(hooks, \"SessionStart\", { session_id: `turn-${Date.now()}` }).catch(() => {});\n }\n\n // Shell summarization config (default: true)\n const shellSummarization = opts.shellSummarization !== false;\n\n const { tools, serverToolCount } = await getTools(opts.allowedTools, opts.disallowedTools);\n const systemPrompt = await buildSystemPrompt(serverToolCount > 0, opts.effort);\n\n // Build user content — text-only string or content blocks array with images\n let userContent: string | Anthropic.ContentBlockParam[];\n if (opts.images && opts.images.length > 0) {\n const blocks: Anthropic.ContentBlockParam[] = [];\n for (const img of opts.images) {\n blocks.push({\n type: \"image\",\n source: {\n type: \"base64\",\n media_type: img.mediaType as \"image/png\" | \"image/jpeg\" | \"image/gif\" | \"image/webp\",\n data: img.base64,\n },\n } as any);\n }\n blocks.push({ type: \"text\", text: message || \"(see attached images)\" });\n userContent = blocks;\n } else {\n userContent = message;\n }\n\n const messages: Anthropic.MessageParam[] = [\n ...conversationHistory,\n { role: \"user\", content: userContent },\n ];\n\n let totalIn = 0;\n let totalOut = 0;\n let totalCacheCreation = 0;\n let totalCacheRead = 0;\n let totalThinking = 0;\n let allAssistantText: string[] = [];\n let prevIterationInputTokens = 0; // Tracks actual context size from last API call\n\n // Telemetry: one turn per user message (not per API call)\n const sessionStart = Date.now();\n const { storeId } = resolveConfig();\n const turnNum = nextTurn(); // ONCE per user message\n const turnCtx = createTurnContext({ model: getModel(), turnNumber: turnNum });\n const turnSpanId = turnCtx.spanId!; // Capture for child spans to reference as parent\n\n // Emit conversation root span on the first turn so the trace tree has a root node.\n // The root span has span_id = conversationRootSpanId, no parent, and serves as the\n // ancestor for all turn spans in this conversation.\n if (turnNum === 1) {\n logSpan({\n action: \"conversation.start\",\n durationMs: 0,\n context: {\n ...turnCtx,\n spanId: getConversationRootSpanId(),\n parentSpanId: undefined, // Root span has no parent\n },\n storeId: storeId || undefined,\n details: {\n conversation_id: turnCtx.conversationId,\n },\n });\n }\n\n addBreadcrumb(\"agent\", `Turn ${turnNum}: ${message.slice(0, 100)}`, \"info\");\n\n // Set server tool context so tool calls carry trace/user identity to Fly.io server\n setServerToolContext({\n traceId: turnCtx.traceId,\n conversationId: turnCtx.conversationId,\n userId: turnCtx.userId,\n userEmail: turnCtx.userEmail,\n source: \"whale-code\",\n });\n\n logSpan({\n action: \"chat.user_message\",\n durationMs: 0,\n context: turnCtx,\n storeId: storeId || undefined,\n details: {\n message: message,\n conversation_history_length: conversationHistory.length,\n },\n });\n\n let sessionCostUsd = 0;\n let compactionCount = 0;\n let consecutiveCompactions = 0; // Circuit breaker: consecutive compactions without progress\n let maxTokensContinuations = 0; // Cap continuation loops to prevent infinite looping\n const costWarningsEmitted = new Set<number>();\n const activeModel = getModel();\n\n // Fetch agent config from DB — single source of truth, nothing hardcoded.\n // Falls back to AGENT_DEFAULTS only if DB is unreachable (never blocks).\n const dbAgent = await loadCLIAgentConfig();\n const resolved = dbAgent\n ? resolveAgentLoopConfig(dbAgent, \"sse\")\n : null;\n\n // Session-level loop detector: persists failed strategies across turns.\n // Created once per conversation, reset only when user starts a new conversation.\n // Must be created AFTER config resolution so DB thresholds apply.\n if (!sessionLoopDetector || conversationHistory.length === 0) {\n sessionLoopDetector = resolved\n ? LoopDetector.fromResolved(resolved)\n : new LoopDetector();\n }\n const loopDetector = sessionLoopDetector;\n loopDetector.resetTurn();\n\n const effectiveBudget = opts.maxBudgetUsd\n ?? resolved?.contextOverrides.session_cost_budget_usd\n ?? DEFAULT_SESSION_COST_BUDGET_USD;\n\n // Compaction settings from DB via getContextManagement — pass DB overrides so\n // the trigger/budget values match what the Anthropic API actually uses.\n const ctxOverrides = resolved?.contextOverrides;\n const ctxMgmt = getContextManagement(activeModel, ctxOverrides);\n const compactEdit = ctxMgmt.config.edits.find((e) => e.type === \"compact_20260112\") as any;\n const effectiveCompactionTrigger = compactEdit?.trigger?.value ?? AGENT_DEFAULTS.compactionTriggerTokens;\n const effectiveCompactionBudget = ctxOverrides?.compaction_total_budget ?? COMPACTION_TOTAL_BUDGET;\n\n // Override maxTurns from DB config (if not explicitly set by caller)\n // 0 = no limit (Claude Code parity)\n if (!opts.maxTurns && resolved && resolved.maxTurns > 0) {\n effectiveMaxTurns = resolved.maxTurns;\n }\n\n // Max continuations: resolved from DB config → AGENT_DEFAULTS fallback\n const maxContinuations = resolved?.maxContinuations ?? AGENT_DEFAULTS.maxContinuations;\n\n // Tool executor — routes to interactive, local, server, or MCP tools.\n // Wraps execution with before/after hooks when hooks are loaded.\n const INTERACTIVE_TOOL_NAMES = new Set(INTERACTIVE_TOOL_DEFINITIONS.map(t => t.name));\n const toolExecutor = async (name: string, input: Record<string, unknown>): Promise<{ success: boolean; output: string }> => {\n if (!name) {\n return { success: false, output: \"Tool call missing name — skipping.\" };\n }\n\n // Permission mode enforcement\n if (!isToolAllowedByPermission(name)) {\n return { success: false, output: `Tool \"${name}\" blocked by ${getPermissionMode()} mode. Switch modes with /mode.` };\n }\n\n // BeforeTool hook — may block or modify input\n let effectiveInput = input;\n if (hooks.length > 0) {\n const hookResult = await runBeforeToolHook(hooks, name, input);\n if (!hookResult.allow) {\n return { success: false, output: hookResult.message || \"Blocked by hook\" };\n }\n if (hookResult.modifiedInput) {\n effectiveInput = hookResult.modifiedInput;\n }\n }\n\n let result: { success: boolean; output: string };\n if (INTERACTIVE_TOOL_NAMES.has(name)) {\n result = await executeInteractiveTool(name, effectiveInput);\n\n // For exit_plan_mode: wait for UI approval, then map decision to result\n if (name === \"exit_plan_mode\" && result.success) {\n const decision: PlanApprovalDecision = await waitForPlanApproval(abortSignal);\n switch (decision.action) {\n case \"execute\":\n result = { success: true, output: `__PLAN_APPROVED_CLEAN__\\n${result.output}` };\n break;\n case \"edit\":\n result = { success: true, output: \"Plan returned for revision. Make changes and use ExitPlanMode again when ready.\" };\n break;\n case \"feedback\":\n result = { success: true, output: `User feedback on plan:\\n\\n${decision.feedback || \"(no feedback provided)\"}\\n\\nRevise the plan based on this feedback, then use ExitPlanMode again.` };\n break;\n case \"cancel\":\n result = { success: true, output: \"Plan cancelled by user. Do not proceed with implementation.\" };\n break;\n }\n }\n } else if (isLocalTool(name)) {\n result = await executeLocalTool(name, effectiveInput, abortSignal);\n } else if (isServerTool(name)) {\n result = await executeServerTool(name, effectiveInput, emitter);\n } else if (mcpClientManager.isMcpTool(name)) {\n result = await mcpClientManager.callTool(name, effectiveInput);\n } else {\n result = { success: false, output: `Unknown tool: ${name}` };\n }\n\n // AfterTool hook — may modify output\n if (hooks.length > 0) {\n const afterResult = await runAfterToolHook(hooks, name, result.output, result.success);\n if (afterResult.modifiedOutput !== undefined) {\n result = { ...result, output: afterResult.modifiedOutput };\n }\n }\n\n return result;\n };\n\n try {\n for (let iteration = 0; iteration < effectiveMaxTurns; iteration++) {\n if (abortSignal?.aborted) {\n logSpan({ action: \"chat.cancelled\", durationMs: Date.now() - sessionStart, context: turnCtx, storeId: storeId || undefined, details: { iteration, reason: \"user_abort\" } });\n callbacks.onError(\"Cancelled\", messages);\n return;\n }\n\n // Budget enforcement — always enforced (defaults to DEFAULT_SESSION_COST_BUDGET_USD)\n if (sessionCostUsd >= effectiveBudget) {\n logSpan({ action: \"chat.budget_exceeded\", durationMs: Date.now() - sessionStart, context: turnCtx, storeId: storeId || undefined, severity: \"warn\", details: { session_cost_usd: sessionCostUsd, max_budget_usd: effectiveBudget, iteration } });\n callbacks.onError(`Budget exceeded: $${sessionCostUsd.toFixed(4)} >= $${effectiveBudget}`, messages);\n return;\n }\n\n const apiStart = Date.now();\n const apiSpanId = generateSpanId();\n const apiRowId = crypto.randomUUID(); // UUID for this span's row — children reference via parent_id\n const costContext = `Session cost: $${sessionCostUsd.toFixed(2)} | Budget remaining: $${(effectiveBudget - sessionCostUsd).toFixed(2)}`;\n\n // Build API request config\n const currentModel = getModel();\n const apiConfig = buildAPIRequest({\n model: currentModel,\n contextProfile: \"main\",\n thinkingEnabled: opts.thinking,\n contextOverrides: ctxOverrides,\n });\n\n // Prepare with prompt caching\n let { tools: cachedTools, messages: cachedMessages } = prepareWithCaching(tools, messages);\n const system = buildSystemBlocks(systemPrompt, costContext);\n\n // Client-side context trimming for non-Anthropic providers.\n // Uses prevIterationInputTokens (actual context size from last API call) — NOT\n // cumulative sessionInputTokens, which grows quadratically and would trigger too early.\n const provider = getProvider(currentModel);\n if (provider === \"gemini\" || provider === \"openai\") {\n const preTrimMessages = cachedMessages;\n if (provider === \"gemini\") {\n // Emergency fallback only — compaction fires at 700K first; trim at 950K catches failures\n cachedMessages = trimGeminiContext(cachedMessages, prevIterationInputTokens);\n } else {\n // Emergency fallback only — compaction fires at 120K first; trim at 190K catches failures\n // GPT-4o: 128K context → 96K threshold (no compaction headroom)\n const threshold = currentModel === \"gpt-4o\" ? 96_000 : 190_000;\n cachedMessages = trimOpenAIContext(cachedMessages, prevIterationInputTokens, threshold);\n }\n // Notify UI when trimming actually occurred (trim returns same ref if no-op)\n if (cachedMessages !== preTrimMessages) {\n // Count tool results before/after to report meaningful numbers\n const countToolResults = (msgs: Anthropic.MessageParam[]) =>\n msgs.reduce((sum, m) => sum + (Array.isArray(m.content)\n ? (m.content as Array<{type?: string; content?: unknown}>).filter(b => b.type === \"tool_result\" && b.content !== \"[trimmed]\").length\n : 0), 0);\n const activeBefore = countToolResults(preTrimMessages);\n const activeAfter = countToolResults(cachedMessages);\n const estimatedSaved = Math.round(prevIterationInputTokens * ((activeBefore - activeAfter) / Math.max(activeBefore, 1)));\n callbacks.onAutoCompact?.(activeBefore, activeAfter, estimatedSaved);\n emitter?.emitCompact(activeBefore, activeAfter, estimatedSaved);\n }\n }\n\n // Get auth token\n const token = await getValidToken();\n if (!token) {\n throw new Error(\"Not logged in. Run: whale login\");\n }\n\n // Call server proxy with built-in retry\n const originalModel = currentModel;\n const stream = await callServerProxy({\n proxyUrl: getProxyUrl(),\n token,\n model: currentModel,\n system,\n messages: cachedMessages,\n tools: cachedTools,\n apiConfig,\n signal: abortSignal,\n fallbackModel: opts.fallbackModel,\n storeId: storeId || undefined,\n onFallback: (from, to) => {\n setModel(to);\n logSpan({ action: \"claude_api_fallback\", durationMs: 0, context: { ...turnCtx, spanId: apiSpanId, parentSpanId: turnSpanId }, storeId: storeId || undefined, details: { from_model: from, to_model: to } });\n },\n onRetry: (attempt, max, err) => {\n const msg = `\\n\\x1b[33m\\u21BB Retrying (${attempt}/${max})... ${err.slice(0, 80)}\\x1b[0m\\n`;\n if (emitter) { emitter.emitText(msg); } else { callbacks.onText(msg); }\n },\n onTokenRefresh: async () => {\n const result = await refreshSession();\n return result.success ? result.config!.access_token! : null;\n },\n });\n\n // Process stream events with UI callbacks\n let thinkingChunks = 0;\n const result: SharedStreamResult = await processStreamWithCallbacks(\n parseSSEStream(stream, abortSignal),\n {\n onText: (text) => {\n if (emitter) {\n emitter.emitText(text);\n } else {\n callbacks.onText(text);\n }\n },\n onThinking: () => {\n thinkingChunks++;\n emitter?.emitThinking(thinkingChunks);\n },\n onToolStart: (name, input) => {\n // NOTE: Do NOT call callbacks.onToolStart here — dispatchTools.onStart\n // fires it once per tool at execution time. Calling it here too would\n // send duplicate tool_start events (stale spinners in WhaleChat).\n if (input) {\n // Tool block complete — emit structured start for CLI TUI only\n emitter?.emitToolStart(\"\", name);\n }\n },\n },\n abortSignal,\n );\n\n // Flush buffered text\n emitter?.flushText();\n\n // Restore original model after transient fallback\n if (getModel() !== originalModel && opts.fallbackModel) {\n setModelById(originalModel);\n }\n\n // Update session token tracking\n sessionInputTokens += result.usage.inputTokens;\n sessionOutputTokens += result.usage.outputTokens;\n prevIterationInputTokens = result.usage.inputTokens; // Actual context size for next trim check\n\n\n // Emit usage with model + cost context for all providers\n if (emitter && (result.usage.inputTokens > 0 || result.usage.outputTokens > 0)) {\n const iterCost = estimateCostUsd(result.usage.inputTokens, result.usage.outputTokens, currentModel, result.thinkingTokens, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n emitter.emitUsage(result.usage.inputTokens, result.usage.outputTokens, currentModel, iterCost, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n }\n\n totalIn += result.usage.inputTokens;\n totalOut += result.usage.outputTokens;\n totalCacheCreation += result.usage.cacheCreationTokens;\n totalCacheRead += result.usage.cacheReadTokens;\n totalThinking += result.thinkingTokens;\n sessionCostUsd += estimateCostUsd(result.usage.inputTokens, result.usage.outputTokens, currentModel, result.thinkingTokens, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n\n // Graduated cost warnings\n emitCostWarningIfNeeded(sessionCostUsd, effectiveBudget, costWarningsEmitted,\n (text) => { if (emitter) { emitter.emitText(text); } else { callbacks.onText(text); } });\n\n // Server-side context management notification\n if (result.contextManagementApplied) {\n callbacks.onAutoCompact?.(messages.length, messages.length, 0);\n emitter?.emitCompact(messages.length, messages.length, 0);\n logSpan({ action: \"chat.api_compaction\", durationMs: Date.now() - apiStart, context: turnCtx, storeId: storeId || undefined, details: { type: \"server_side\", has_compaction_content: result.compactionContent !== null, iteration } });\n }\n\n if (result.text) allAssistantText.push(result.text);\n\n // Telemetry: API call span\n const iterCostUsd = estimateCostUsd(result.usage.inputTokens, result.usage.outputTokens, currentModel, result.thinkingTokens, result.usage.cacheReadTokens, result.usage.cacheCreationTokens);\n logSpan({\n action: \"claude_api_request\",\n durationMs: Date.now() - apiStart,\n context: { ...turnCtx, spanId: apiSpanId, parentSpanId: turnSpanId, rowId: apiRowId, inputTokens: result.usage.inputTokens, outputTokens: result.usage.outputTokens, totalCost: iterCostUsd, model: currentModel },\n storeId: storeId || undefined,\n details: {\n \"gen_ai.request.model\": currentModel,\n \"gen_ai.usage.input_tokens\": result.usage.inputTokens,\n \"gen_ai.usage.output_tokens\": result.usage.outputTokens,\n \"gen_ai.usage.cache_creation_tokens\": result.usage.cacheCreationTokens,\n \"gen_ai.usage.cache_read_tokens\": result.usage.cacheReadTokens,\n \"gen_ai.usage.cost\": iterCostUsd,\n stop_reason: result.stopReason === \"compaction\" ? \"compaction\" : result.toolUseBlocks.length > 0 ? \"tool_use\" : \"end_turn\",\n iteration,\n tool_count: result.toolUseBlocks.length,\n tool_names: result.toolUseBlocks.map(t => t.name),\n },\n });\n\n // Compaction handling — API paused after generating summary.\n // Per Anthropic docs: the compaction block replaces all prior context.\n // Do NOT preserve old messages — they can exceed the trigger threshold\n // and cause an infinite compaction loop. The summary captures all context.\n if (result.stopReason === \"compaction\" && result.compactionContent) {\n compactionCount++;\n consecutiveCompactions++;\n logSpan({ action: \"chat.compaction_pause\", durationMs: Date.now() - apiStart, context: turnCtx, storeId: storeId || undefined, details: { compaction_count: compactionCount, consecutive: consecutiveCompactions, messages_before: messages.length } });\n\n // Circuit breaker: if compaction fires repeatedly without progress,\n // the summary + system prompt alone may exceed the trigger. Force wrap-up.\n const MAX_CONSECUTIVE_COMPACTIONS = 3;\n const shouldWrapUp =\n consecutiveCompactions > MAX_CONSECUTIVE_COMPACTIONS ||\n compactionCount * effectiveCompactionTrigger >= effectiveCompactionBudget;\n\n const compactedMessages = [\n { role: \"assistant\", content: [{ type: \"compaction\", content: result.compactionContent }] },\n { role: \"user\", content: [{ type: \"text\", text: shouldWrapUp\n ? \"You have reached the context budget. Please wrap up your current work and provide a final summary of what was accomplished and what remains.\"\n : \"Continue with your task.\" }] },\n ];\n messages.length = 0;\n messages.push(...compactedMessages as Anthropic.MessageParam[]);\n\n if (shouldWrapUp) {\n const budgetMsg = consecutiveCompactions > MAX_CONSECUTIVE_COMPACTIONS\n ? \"\\n[Compaction loop detected — wrapping up.]\"\n : \"\\n[Context budget reached — wrapping up.]\";\n if (emitter) { emitter.emitText(budgetMsg); } else { callbacks.onText(budgetMsg); }\n }\n\n iteration--; // Don't count compaction as an iteration\n continue;\n }\n\n // No tool calls — check if we should continue or stop\n if (result.toolUseBlocks.length === 0) {\n // If model hit max_tokens, it was truncated mid-response — continue so it can finish.\n // Cap at MAX_CONTINUATIONS to prevent infinite loops on very large outputs (e.g. HTML reports).\n if (result.stopReason === \"max_tokens\" && maxTokensContinuations < maxContinuations) {\n maxTokensContinuations++;\n const truncatedText = result.text || \"\";\n const assistantContent = buildAssistantContent({\n text: truncatedText,\n toolUseBlocks: [],\n thinkingBlocks: result.thinkingBlocks,\n compactionContent: result.compactionContent,\n });\n messages.push({ role: \"assistant\", content: assistantContent } as unknown as Anthropic.MessageParam);\n\n // Escalating continuation prompts — if the model keeps hitting max_tokens,\n // it's probably trying to write a large file. Guide it toward smaller chunks.\n const continuationText = maxTokensContinuations === 1\n ? \"[Your response was truncated due to the output token limit. If you were writing a large file, split it into multiple smaller write_file calls (~200 lines each) or use run_command with a heredoc. Continue concisely.]\"\n : `[Your response was truncated again (attempt ${maxTokensContinuations}/${maxContinuations}). You MUST reduce output size. For large files: use multiple write_file calls of ~100-200 lines each, or write via run_command. Do NOT attempt to write the entire file in one call.]`;\n messages.push({ role: \"user\", content: [{ type: \"text\", text: continuationText }] } as Anthropic.MessageParam);\n continue;\n }\n break;\n }\n\n // Reset counters — model is taking tool actions, making progress\n maxTokensContinuations = 0;\n consecutiveCompactions = 0;\n\n // Execute tools via shared dispatch\n const { results: toolResults, bailOut, bailMessage } = await dispatchTools(\n result.toolUseBlocks,\n toolExecutor,\n {\n loopDetector,\n maxConcurrent: resolved?.maxConcurrentTools ?? AGENT_DEFAULTS.maxConcurrentTools,\n batchErrorLimit: resolved?.loopBatchErrorLimit ?? AGENT_DEFAULTS.loopBatchErrorLimit,\n onStart: (name, input) => {\n callbacks.onToolStart(name, input);\n },\n onResult: (name, success, output, durationMs) => {\n callbacks.onToolResult(name, success, output, undefined, durationMs);\n logSpan({\n action: `tool.${name}`,\n durationMs,\n context: { ...turnCtx, spanId: generateSpanId(), parentSpanId: apiSpanId, parentId: apiRowId },\n storeId: storeId || undefined,\n error: success ? undefined : output,\n details: {\n tool_input: {},\n tool_result: truncateResult(output, 2000),\n error_type: success ? undefined : classifyToolError(output),\n iteration,\n },\n });\n },\n signal: abortSignal,\n transcribeAudio: storeId\n ? async (base64, mediaType) => callTranscribe({\n proxyUrl: getProxyUrl(),\n token,\n storeId: storeId!,\n audioBase64: base64,\n mediaType,\n })\n : undefined,\n },\n );\n\n if (bailOut) {\n logSpan({ action: \"chat.bail_out\", durationMs: Date.now() - sessionStart, context: turnCtx, storeId: storeId || undefined, severity: \"warn\", details: { ...loopDetector.getSessionStats(), message: bailMessage, iteration } });\n }\n\n // Shell output summarization — summarize long bash output to save context window\n const toolNameMap = new Map(result.toolUseBlocks.map(t => [t.id, t.name]));\n const finalToolResults = await summarizeLongToolResults(\n toolResults,\n toolNameMap,\n getProxyUrl(),\n token,\n shellSummarization,\n storeId || undefined,\n );\n\n // Build assistant content and append to conversation\n const assistantContent = buildAssistantContent({\n text: result.text,\n toolUseBlocks: result.toolUseBlocks,\n thinkingBlocks: result.thinkingBlocks,\n compactionContent: result.compactionContent,\n });\n messages.push({ role: \"assistant\", content: assistantContent as any });\n\n // Check for __PLAN_APPROVED_CLEAN__ marker — clear context and start fresh with just the plan\n const planCleanMarker = \"__PLAN_APPROVED_CLEAN__\\n\";\n const hasCleanPlanApproval = finalToolResults.some((tr: any) => {\n const content = typeof tr.content === \"string\" ? tr.content : \"\";\n return content.startsWith(planCleanMarker);\n });\n if (hasCleanPlanApproval) {\n // Extract plan content from the marker\n const planResult = finalToolResults.find((tr: any) => {\n const content = typeof tr.content === \"string\" ? tr.content : \"\";\n return content.startsWith(planCleanMarker);\n }) as any;\n const planText = (planResult.content as string).slice(planCleanMarker.length);\n const beforeCount = messages.length;\n messages.length = 0;\n messages.push({ role: \"user\", content: [{ type: \"text\", text: `Implement this plan:\\n\\n${planText}` }] } as any);\n callbacks.onAutoCompact?.(beforeCount, 1, 0);\n continue;\n }\n\n messages.push({ role: \"user\", content: finalToolResults as any });\n\n // Non-native compaction for OpenAI/Gemini — fires after tool results appended\n const compactionCfg = getCompactionConfig(currentModel);\n if (!compactionCfg.isNative && result.usage.inputTokens >= compactionCfg.triggerTokens) {\n compactionCount++;\n\n if (compactionCount * compactionCfg.triggerTokens >= compactionCfg.totalBudget) {\n // Budget exhaustion — force wrap-up (same as native compaction budget logic)\n const budgetMsg = \"\\n[Context budget reached — wrapping up.]\";\n if (emitter) { emitter.emitText(budgetMsg); } else { callbacks.onText(budgetMsg); }\n\n const summary = await requestProviderCompaction({\n proxyUrl: getProxyUrl(),\n token,\n messages,\n systemPrompt,\n });\n const compactedMessages = [\n ...(summary\n ? [{ role: \"assistant\", content: [{ type: \"compaction\", content: summary }] }]\n : []),\n { role: \"user\", content: [{ type: \"text\", text: \"You have reached the context budget. Please wrap up your current work and provide a final summary of what was accomplished and what remains.\" }] },\n ];\n messages.length = 0;\n messages.push(...compactedMessages as Anthropic.MessageParam[]);\n continue;\n }\n\n // Normal compaction — summarize, don't preserve old messages (prevents loop)\n const summary = await requestProviderCompaction({\n proxyUrl: getProxyUrl(),\n token,\n messages: messages as any,\n systemPrompt,\n });\n\n if (summary) {\n const beforeCount = messages.length;\n const compactedMessages = [\n { role: \"assistant\", content: [{ type: \"compaction\", content: summary }] },\n { role: \"user\", content: [{ type: \"text\", text: \"Continue with your task.\" }] },\n ];\n messages.length = 0;\n messages.push(...compactedMessages as Anthropic.MessageParam[]);\n iteration--; // Don't count compaction as an iteration\n\n callbacks.onAutoCompact?.(beforeCount, messages.length, Math.round(result.usage.inputTokens * 0.7));\n emitter?.emitCompact(beforeCount, messages.length, Math.round(result.usage.inputTokens * 0.7));\n\n logSpan({ action: \"chat.provider_compaction\", durationMs: 0, context: turnCtx, storeId: storeId || undefined, details: { compaction_count: compactionCount, provider, model: currentModel, input_tokens: result.usage.inputTokens, trigger_tokens: compactionCfg.triggerTokens } });\n }\n }\n }\n\n // Telemetry: session summary\n logSpan({\n action: \"chat.session_complete\",\n durationMs: Date.now() - sessionStart,\n context: { ...turnCtx, inputTokens: totalIn, outputTokens: totalOut, model: activeModel },\n storeId: storeId || undefined,\n details: {\n input_tokens: totalIn, output_tokens: totalOut, total_tokens: totalIn + totalOut,\n cache_creation_tokens: totalCacheCreation, cache_read_tokens: totalCacheRead,\n session_input_tokens: sessionInputTokens, session_output_tokens: sessionOutputTokens,\n model: activeModel,\n },\n });\n\n const turnCostUsd = estimateCostUsd(totalIn, totalOut, activeModel, totalThinking, totalCacheRead, totalCacheCreation);\n callbacks.onUsage(totalIn, totalOut, totalThinking, activeModel, turnCostUsd, totalCacheRead, totalCacheCreation);\n\n // Flush telemetry spans to server before session ends\n flushCliSpans();\n\n // Fire SessionEnd hook (non-blocking)\n if (hooks.length > 0) {\n runSessionHook(hooks, \"SessionEnd\", { session_id: `turn-${sessionStart}` }).catch(() => {});\n }\n\n const finalText = allAssistantText.length > 0 ? allAssistantText[allAssistantText.length - 1] : \"\";\n emitter?.emitDone(finalText, messages);\n if (emitter) clearGlobalEmitter();\n callbacks.onDone(messages);\n } catch (err: any) {\n const errorMsg = abortSignal?.aborted || err?.message === \"Cancelled\"\n ? \"Cancelled\"\n : String(err?.message || err);\n\n logSpan({\n action: errorMsg === \"Cancelled\" ? \"chat.cancelled\" : \"chat.fatal_error\",\n durationMs: Date.now() - sessionStart,\n context: { ...turnCtx, inputTokens: totalIn, outputTokens: totalOut, model: activeModel },\n storeId: storeId || undefined,\n severity: errorMsg === \"Cancelled\" ? \"info\" : \"error\",\n error: errorMsg === \"Cancelled\" ? undefined : errorMsg,\n details: { input_tokens: totalIn, output_tokens: totalOut, session_cost_usd: sessionCostUsd, model: activeModel },\n });\n\n // Capture to error_events (not just audit_logs) for non-cancellations\n if (errorMsg !== \"Cancelled\") {\n captureError({\n error: err instanceof Error ? err : undefined,\n errorType: \"AgentLoopError\",\n errorMessage: errorMsg,\n severity: \"error\",\n traceId: turnCtx.traceId,\n spanId: turnCtx.spanId,\n storeId: storeId || undefined,\n tags: { model: activeModel, turn: String(turnNum) },\n });\n }\n\n // Flush telemetry on error path too\n flushCliSpans();\n\n emitter?.emitError(errorMsg);\n if (emitter) clearGlobalEmitter();\n callbacks.onError(errorMsg, messages);\n }\n}\n\n// ============================================================================\n// TELEMETRY HELPERS\n// ============================================================================\n\nexport function truncateResult(output: string, maxLen: number): string {\n if (output.length <= maxLen) return output;\n return output.slice(0, maxLen) + `... (${output.length} chars total)`;\n}\n\nexport function classifyToolError(output: string): string {\n const lower = output.toLowerCase();\n if (lower.includes(\"timed out\") || lower.includes(\"timeout\")) return \"timeout\";\n if (lower.includes(\"permission denied\") || lower.includes(\"eacces\")) return \"permission\";\n if (lower.includes(\"not found\") || lower.includes(\"no such file\")) return \"not_found\";\n if (lower.includes(\"command not found\") || lower.includes(\"exit code 127\")) return \"command_not_found\";\n if (lower.includes(\"import\") && lower.includes(\"error\")) return \"import_error\";\n if (lower.includes(\"syntax\") || lower.includes(\"parse\")) return \"syntax_error\";\n if (lower.includes(\"externally-managed\")) return \"env_managed\";\n return \"unknown\";\n}\n\n// Convenience: check if user can use the agent (logged in OR has API key)\nexport function canUseAgent(): { ready: boolean; reason?: string } {\n const config = loadConfig();\n const hasToken = !!(config.access_token && config.refresh_token);\n const hasApiKey = !!process.env.ANTHROPIC_API_KEY;\n\n if (hasToken || hasApiKey) return { ready: true };\n return { ready: false, reason: \"Run `whale login` to authenticate.\" };\n}\n\n// ============================================================================\n// SESSION MODE — delegate to server-side SessionManager\n// ============================================================================\n\nimport { SessionClient } from \"./session-client.js\";\n\n/** Check if session mode should be used (auto-detect by default). */\nasync function shouldUseSessionMode(): Promise<boolean> {\n if (process.env.WHALE_SESSION_MODE === \"off\") return false;\n if (process.env.WHALE_SESSION_MODE === \"on\") return true;\n\n // Never auto-activate for interactive CLI — the emitter-based TUI\n // requires the local loop. Session mode only activates via explicit\n // env var or `whale resume <id>` (which sets WHALE_SESSION_MODE=on).\n if (process.stdin.isTTY) return false;\n\n // Auto: if logged in + server reachable → session mode (non-TTY: print mode, MCP)\n const proxyUrl = getProxyUrl();\n if (!proxyUrl) return false;\n\n const config = resolveConfig();\n if (!config.storeId) return false;\n\n const client = new SessionClient(proxyUrl, getValidToken);\n return client.healthCheck();\n}\n\n/**\n * Run agent loop in session mode — all state managed server-side.\n * The entire existing local loop stays as offline fallback.\n */\nasync function runSessionAgentLoop(opts: AgentLoopOptions): Promise<void> {\n const { message, conversationHistory, callbacks, abortSignal, emitter } = opts;\n const proxyUrl = getProxyUrl();\n if (!proxyUrl) throw new Error(\"Session mode requires server connection\");\n\n // Set global emitter for subagents (mirrors local loop behavior)\n if (emitter) setGlobalEmitter(emitter);\n\n const client = new SessionClient(proxyUrl, getValidToken);\n const config = resolveConfig();\n const storeId = config.storeId;\n\n if (!storeId) {\n callbacks.onError(\"Session mode requires store_id in config. Falling back to local mode.\");\n if (emitter) clearGlobalEmitter();\n return;\n }\n\n // Resolve agent ID: use config, or query server for store's first active agent\n let agentId = config.defaultAgentId;\n if (!agentId) {\n agentId = (await resolveDefaultAgentId(proxyUrl, storeId, getValidToken)) || \"\";\n }\n if (!agentId) {\n callbacks.onError(\"No agent configured. Set default_agent_id in config or create an agent. Falling back to local mode.\");\n if (emitter) clearGlobalEmitter();\n return;\n }\n\n // Resume existing session or create new one\n const resumeId = process.env.WHALE_RESUME_SESSION_ID;\n let sessionId: string;\n if (resumeId) {\n sessionId = resumeId;\n delete process.env.WHALE_RESUME_SESSION_ID; // consume once\n } else {\n const session = await client.createSession({\n storeId,\n agentId,\n surface: \"cli\",\n message,\n });\n sessionId = session.id;\n }\n\n // Save local session backup with server session reference\n const localSessionId = saveSession(conversationHistory);\n updateSessionMeta(localSessionId, { serverSessionId: sessionId, synced: true });\n\n // Track accumulated text for emitDone — the TUI's handleDone handler\n // overwrites accTextRef with event.text, so we must pass the full text.\n let accumulatedText = \"\";\n // Guard against double-error: SessionClient.sendMessage calls onError AND\n // throws for HTTP errors. The catch must not re-fire emitter/callbacks.\n let errorHandled = false;\n\n try {\n await client.sendMessage(sessionId, message, {\n onText: (text) => {\n accumulatedText += text;\n if (emitter) {\n emitter.emitText(text);\n } else {\n callbacks.onText(text);\n }\n },\n onToolStart: (name: string, input?: unknown) => {\n callbacks.onToolStart(name, input as Record<string, unknown> | undefined);\n if (input) emitter?.emitToolStart(\"\", name);\n },\n onToolResult: (name, success, result) => {\n callbacks.onToolResult(name, success, result);\n },\n onUsage: (tokens, costUsd) => {\n callbacks.onUsage(tokens.input, tokens.output, 0, getModel(), costUsd, tokens.cacheRead, tokens.cacheCreation);\n if (emitter && (tokens.input > 0 || tokens.output > 0)) {\n emitter.emitUsage(tokens.input, tokens.output, getModel(), costUsd, tokens.cacheRead, tokens.cacheCreation);\n }\n },\n onDone: (_conversationId) => {\n emitter?.flushText();\n emitter?.emitDone(accumulatedText, conversationHistory);\n if (emitter) clearGlobalEmitter();\n callbacks.onDone(conversationHistory);\n },\n onError: (err) => {\n errorHandled = true;\n emitter?.emitError(err);\n if (emitter) clearGlobalEmitter();\n callbacks.onError(err);\n },\n }, abortSignal);\n } catch (err: any) {\n if (!errorHandled) {\n const errorMsg = abortSignal?.aborted || err?.message === \"Cancelled\"\n ? \"Cancelled\"\n : String(err?.message || err);\n emitter?.emitError(errorMsg);\n if (emitter) clearGlobalEmitter();\n callbacks.onError(errorMsg);\n }\n }\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA,SACEA,sBAAsB,EACtBC,gBAAgB,EAChBC,WAAW,QACN,kBAAkB;AACzB,SACEC,4BAA4B,EAC5BC,sBAAsB,EACtBC,mBAAmB,QAEd,wBAAwB;AAC/B,SAASC,UAAU,EAAEC,aAAa,EAAEC,WAAW,EAAEC,qBAAqB,QAAQ,mBAAmB;AACjG,SAASC,aAAa,EAAEC,cAAc,QAAQ,mBAAmB;AACjE,SACEC,YAAY,EACZC,yBAAyB,EACzBC,iBAAiB,EACjBC,eAAe,EACfC,oBAAoB,QAEf,mBAAmB;AAC1B,SACEC,QAAQ,EACRC,iBAAiB,EACjBC,yBAAyB,EACzBC,OAAO,EACPC,cAAc,EACdC,aAAa,EAEbC,yBAAyB,QACpB,gBAAgB;AACvB,SAASC,YAAY,EAAEC,aAAa,QAAQ,mBAAmB;AAC/D,SAEEC,gBAAgB,EAChBC,kBAAkB,QACb,mBAAmB;AAC1B,SAASC,gBAAgB,QAAQ,iBAAiB;AAClD,SAASC,SAAS,EAAEC,iBAAiB,EAAEC,gBAAgB,EAAEC,cAAc,QAAyB,YAAY;AAC5G,SAASC,YAAY,EAAEC,uBAAuB,EAAEC,mBAAmB,EAAEC,oBAAoB,EAAEC,+BAA+B,EAAEC,uBAAuB,EAAEC,sBAAsB,EAAEC,cAAc,QAAQ,4BAA4B;AAC/N,SAASC,kBAAkB,EAAEC,qBAAqB,QAAQ,mBAAmB;AAC7E,SAASC,cAAc,EAAEC,0BAA0B,EAAEC,mBAAmB,QAAQ,4BAA4B;AAC5G,SAASC,eAAe,EAAEC,cAAc,EAAEC,eAAe,EAAEC,iBAAiB,EAAEC,kBAAkB,EAAEC,iBAAiB,EAAEC,iBAAiB,EAAEC,yBAAyB,QAAQ,4BAA4B;AACrM,SAASC,WAAW,EAAEC,MAAM,QAAQ,2BAA2B;AAC/D,SAASC,aAAa,EAAEC,qBAAqB,QAAQ,+BAA+B;AAGpF;AACA,SAASC,UAAU,EAAEC,SAAS,EAAEC,YAAY,EAAEC,YAAY,QAAQ,qBAAqB;AACvF,SAASC,iBAAiB,EAAEC,eAAe,QAAQ,kBAAkB;AACrE,SAASC,YAAY,EAAEC,cAAc,EAAEC,kBAAkB,QAAQ,uBAAuB;AACxF,SAASC,cAAc,QAAQ,qBAAqB;AACpD,SAASC,iBAAiB,EAAEC,iBAAiB,EAAEC,yBAAyB,QAA6B,uBAAuB;AAC5H,SAASC,QAAQ,EAAEC,YAAY,EAAEC,QAAQ,EAAEC,iBAAiB,EAAEC,eAAe,QAAQ,oBAAoB;AACzG,SAASC,WAAW,EAAEC,WAAW,EAAEC,YAAY,EAAEC,uBAAuB,EAAEC,iBAAiB,QAA0B,0BAA0B;AAC/I,SAASC,iBAAiB,QAAQ,oBAAoB;;AAEtD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,SAASvB,UAAU,EAAEC,SAAS,EAAEC,YAAY,EAAEC,YAAY;;AAE1D;AACA,SAASC,iBAAiB;;AAE1B;AACA,SAASE,YAAY,EAAEC,cAAc;;AAErC;AACA,SAASG,iBAAiB,EAAEC,iBAAiB,EAAEC,yBAAyB;;AAExE;AACA,SAASC,QAAQ,EAAEE,QAAQ,EAAEC,iBAAiB,EAAEC,eAAe;;AAE/D;AACA,SAASC,WAAW,EAAEC,WAAW,EAAEC,YAAY,EAAEC,uBAAuB,EAAEC,iBAAiB;;AAE3F;AACA,SAASjE,eAAe;;AAExB;AACA,SAASa,gBAAgB;;AAEzB;AACA,SAASsD,aAAa,EAAEC,oBAAoB,QAAQ,2BAA2B;;AAE/E;AACA,SAASC,iBAAiB,QAAyB,mBAAmB;;AAEtE;AACA;AACA;;AAmCA;AACA;AACA;;AAEA;AACA;AACA,IAAIC,kBAAkB,GAAG,CAAC;AAC1B,IAAIC,mBAAmB,GAAG,CAAC;AAE3B,OAAO,SAASC,gBAAgBA,CAAA,EAAsC;EACpE,OAAO;IAAEC,KAAK,EAAEH,kBAAkB;IAAEI,MAAM,EAAEH;EAAoB,CAAC;AACnE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASI,iBAAiBA,CAAA,EAAS;EACxCL,kBAAkB,GAAG,CAAC;EACtBC,mBAAmB,GAAG,CAAC;EACvBK,mBAAmB,GAAG,IAAI;EAC1B5B,eAAe,CAAC,CAAC;EACjBG,kBAAkB,CAAC,CAAC;EACpBC,cAAc,CAAC,CAAC;EAChBzB,qBAAqB,CAAC,CAAC;EACvB;EACAvB,yBAAyB,CAAC,CAAC;AAC7B;;AAEA;AACA,IAAIwE,mBAAwC,GAAG,IAAI;;AAEnD;AACA;AACA,MAAMC,YAAY,GAAGC,MAAM,CAACC,gBAAgB;;AAE5C;AACA;AACA;;AAEA,MAAMC,8BAA8B,GAAG,GAAG;AAC1C,MAAMC,8BAA8B,GAAG,OAAO,CAAC,CAAC;AAChD,MAAMC,yBAAyB,GAAG,OAAO,CAAC,CAAC;AAC3C,MAAMC,sCAAsC,GAAG,EAAE;;AAEjD;AACA;AACA;AACA,SAASC,0BAA0BA,CAACV,MAAc,EAAW;EAC3D,IAAIA,MAAM,CAACW,MAAM,GAAGJ,8BAA8B,EAAE,OAAO,IAAI;EAC/D,MAAMK,SAAS,GAAGZ,MAAM,CAACa,KAAK,CAAC,IAAI,CAAC,CAACF,MAAM;EAC3C,OAAOC,SAAS,GAAGN,8BAA8B;AACnD;;AAEA;AACA;AACA;AACA;AACA,eAAeQ,oBAAoBA,CACjCd,MAAc,EACde,QAAgB,EAChBC,KAAa,EACbC,OAAgB,EACC;EACjB,MAAML,SAAS,GAAGZ,MAAM,CAACa,KAAK,CAAC,IAAI,CAAC,CAACF,MAAM;EAC3C,MAAMO,mBAAmB,GAAGlB,MAAM,CAACW,MAAM,GAAGH,yBAAyB,GACjER,MAAM,CAACmB,KAAK,CAAC,CAAC,EAAEX,yBAAyB,CAAC,GAAG,qCAAqC,GAClFR,MAAM;EAEV,IAAI;IACF,MAAMoB,aAAa,GAAG7D,eAAe,CAAC;MACpC8D,KAAK,EAAEvD,MAAM,CAACwD,KAAK;MACnBC,cAAc,EAAE;IAClB,CAAC,CAAC;IAEF,MAAMC,MAAM,GAAG,MAAMnE,eAAe,CAAC;MACnC0D,QAAQ;MACRC,KAAK;MACLK,KAAK,EAAEvD,MAAM,CAACwD,KAAK;MACnBG,MAAM,EAAE,CAAC;QAAEC,IAAI,EAAE,MAAM;QAAEC,IAAI,EAAE;MAAgL,CAAC,CAAC;MACjNC,QAAQ,EAAE,CAAC;QAAEC,IAAI,EAAE,MAAM;QAAEC,OAAO,EAAE,uGAAuGZ,mBAAmB;MAAG,CAAC,CAAC;MACnKa,KAAK,EAAE,EAAE;MACTC,SAAS,EAAEZ,aAAa;MACxBH,OAAO;MACPgB,SAAS,EAAE;IACb,CAAC,CAAC;IAEF,MAAMC,MAAM,GAAG,MAAM9E,mBAAmB,CAACF,cAAc,CAACsE,MAAM,CAAC,CAAC;IAChE,MAAMW,OAAO,GAAGD,MAAM,CAACP,IAAI,CAACS,IAAI,CAAC,CAAC;IAElC,IAAI,CAACD,OAAO,EAAE,OAAOnC,MAAM,CAAC,CAAC;;IAE7B;IACA,MAAMqC,aAAa,GAAGrC,MAAM,CAACa,KAAK,CAAC,IAAI,CAAC;IACxC,MAAMyB,OAAO,GAAGD,aAAa,CAAClB,KAAK,CAAC,CAAC,EAAEV,sCAAsC,CAAC,CAAC8B,IAAI,CAAC,IAAI,CAAC;IAEzF,OAAO,oBAAoB3B,SAAS,cAAcuB,OAAO,cAAc1B,sCAAsC,+BAA+B6B,OAAO,EAAE;EACvJ,CAAC,CAAC,MAAM;IACN;IACA,OAAOtC,MAAM;EACf;AACF;;AAEA;AACA;AACA;AACA;AACA,eAAewC,wBAAwBA,CACrCC,WAAgC,EAChCC,SAA8B,EAC9B3B,QAAgB,EAChBC,KAAa,EACb2B,kBAA2B,EAC3B1B,OAAgB,EACc;EAC9B,IAAI,CAAC0B,kBAAkB,EAAE,OAAOF,WAAW;EAE3C,MAAMG,KAAK,GAAGH,WAAW,CAACI,GAAG,CAAC,MAAOX,MAAM,IAAK;IAC9C;IACA,MAAMY,QAAQ,GAAGJ,SAAS,CAACK,GAAG,CAACb,MAAM,CAACc,WAAW,CAAC;IAClD,IAAIF,QAAQ,KAAK,MAAM,IAAI,OAAOZ,MAAM,CAACJ,OAAO,KAAK,QAAQ,EAAE,OAAOI,MAAM;;IAE5E;IACA,IAAI,CAACxB,0BAA0B,CAACwB,MAAM,CAACJ,OAAO,CAAC,EAAE,OAAOI,MAAM;IAE9D,MAAMe,UAAU,GAAG,MAAMnC,oBAAoB,CAACoB,MAAM,CAACJ,OAAO,EAAEf,QAAQ,EAAEC,KAAK,EAAEC,OAAO,CAAC;IACvF,OAAO;MAAE,GAAGiB,MAAM;MAAEJ,OAAO,EAAEmB;IAAW,CAAC;EAC3C,CAAC,CAAC;EAEF,OAAOC,OAAO,CAACC,GAAG,CAACP,KAAK,CAAC;AAC3B;;AAEA;AACA;AACA;;AAEA,eAAeQ,QAAQA,CAACC,YAAuB,EAAEC,eAA0B,EAAiE;EAC1I,MAAMC,UAA4B,GAAGhJ,sBAAsB,CAACsI,GAAG,CAAEW,CAAC,KAAM;IACtEC,IAAI,EAAED,CAAC,CAACC,IAAI;IACZC,WAAW,EAAEF,CAAC,CAACE,WAAW;IAC1BC,YAAY,EAAEH,CAAC,CAACG;EAClB,CAAC,CAAC,CAAC;;EAEH;EACA,MAAMC,aAAa,GAAGhF,iBAAiB,CAAC,CAAC,KAAK,MAAM;EACpD,MAAMiF,gBAAkC,GAAGnJ,4BAA4B,CACpEoJ,MAAM,CAAEN,CAAC,IAAK,CAACI,aAAa,IAAKJ,CAAC,CAACC,IAAI,KAAK,iBAAiB,IAAID,CAAC,CAACC,IAAI,KAAK,gBAAiB,CAAC,CAC9FZ,GAAG,CAAEW,CAAC,KAAM;IACXC,IAAI,EAAED,CAAC,CAACC,IAAI;IACZC,WAAW,EAAEF,CAAC,CAACE,WAAW;IAC1BC,YAAY,EAAEH,CAAC,CAACG;EAClB,CAAC,CAAC,CAAC;EACLJ,UAAU,CAACQ,IAAI,CAAC,GAAGF,gBAAgB,CAAC;EAEpC,IAAIG,WAA6B,GAAG,EAAE;EACtC,IAAI;IACFA,WAAW,GAAG,MAAM5I,yBAAyB,CAAC,CAAC;EACjD,CAAC,CAAC,MAAM;IACN;EAAA;;EAGF;EACA,MAAM6I,UAAU,GAAG,IAAIC,GAAG,CAACX,UAAU,CAACV,GAAG,CAACW,CAAC,IAAIA,CAAC,CAACC,IAAI,CAAC,CAAC;EACvD,MAAMU,iBAAiB,GAAGH,WAAW,CAACF,MAAM,CAACN,CAAC,IAAI,CAACS,UAAU,CAACG,GAAG,CAACZ,CAAC,CAACC,IAAI,CAAC,CAAC;;EAE1E;EACA,MAAMY,QAAQ,GAAGlI,gBAAgB,CAACiH,QAAQ,CAAC,CAAC;EAE5C,IAAIkB,QAAQ,GAAG,CAAC,GAAGf,UAAU,EAAE,GAAGY,iBAAiB,EAAE,GAAGE,QAAQ,CAAC;;EAEjE;EACA,IAAIhB,YAAY,IAAIA,YAAY,CAAC1C,MAAM,GAAG,CAAC,EAAE;IAC3C,MAAM4D,OAAO,GAAG,IAAIL,GAAG,CAACb,YAAY,CAAC;IACrCiB,QAAQ,GAAGA,QAAQ,CAACR,MAAM,CAACN,CAAC,IAAIe,OAAO,CAACH,GAAG,CAACZ,CAAC,CAACC,IAAI,CAAC,CAAC;EACtD;EACA,IAAIH,eAAe,IAAIA,eAAe,CAAC3C,MAAM,GAAG,CAAC,EAAE;IACjD,MAAM6D,UAAU,GAAG,IAAIN,GAAG,CAACZ,eAAe,CAAC;IAC3CgB,QAAQ,GAAGA,QAAQ,CAACR,MAAM,CAACN,CAAC,IAAI,CAACgB,UAAU,CAACJ,GAAG,CAACZ,CAAC,CAACC,IAAI,CAAC,CAAC;EAC1D;EAEA,OAAO;IACL1B,KAAK,EAAEuC,QAAQ;IACfG,eAAe,EAAEN,iBAAiB,CAACxD;EACrC,CAAC;AACH;;AAEA;AACA,OAAO,eAAe+D,kBAAkBA,CAAA,EAAoB;EAC1D,IAAI;IACF,MAAMC,IAAI,GAAG,MAAMvJ,yBAAyB,CAAC,CAAC;IAC9C,OAAOuJ,IAAI,CAAChE,MAAM;EACpB,CAAC,CAAC,MAAM;IACN,OAAO,CAAC;EACV;AACF;;AAEA;AACA;AACA;;AAEA,OAAO,eAAeiE,YAAYA,CAACC,IAAsB,EAAiB;EACxE;EACA,IAAI,MAAMC,oBAAoB,CAAC,CAAC,EAAE;IAChC,OAAOC,mBAAmB,CAACF,IAAI,CAAC;EAClC;EAEA,MAAM;IAAEG,OAAO;IAAEC,mBAAmB;IAAEC,SAAS;IAAEC,WAAW;IAAEC;EAAQ,CAAC,GAAGP,IAAI;EAC9E,IAAIA,IAAI,CAACxD,KAAK,EAAEvC,QAAQ,CAAC+F,IAAI,CAACxD,KAAK,CAAC;;EAEpC;EACA,IAAI+D,OAAO,EAAE;IACXnJ,gBAAgB,CAACmJ,OAAO,CAAC;EAC3B;;EAEA;EACA;EACA,IAAIC,iBAAiB,GAAGR,IAAI,CAACS,QAAQ,IAAInF,YAAY;;EAErD;EACA,MAAMoF,QAAQ,GAAGV,IAAI,CAACW,GAAG,IAAIC,OAAO,CAACD,GAAG,CAAC,CAAC;EAC1C,MAAME,KAAK,GAAGtJ,SAAS,CAACmJ,QAAQ,CAAC;;EAEjC;EACA,IAAIG,KAAK,CAAC/E,MAAM,GAAG,CAAC,EAAE;IACpBpE,cAAc,CAACmJ,KAAK,EAAE,cAAc,EAAE;MAAEC,UAAU,EAAE,QAAQC,IAAI,CAACC,GAAG,CAAC,CAAC;IAAG,CAAC,CAAC,CAACC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;EAC7F;;EAEA;EACA,MAAMnD,kBAAkB,GAAGkC,IAAI,CAAClC,kBAAkB,KAAK,KAAK;EAE5D,MAAM;IAAEZ,KAAK;IAAE0C;EAAgB,CAAC,GAAG,MAAMrB,QAAQ,CAACyB,IAAI,CAACxB,YAAY,EAAEwB,IAAI,CAACvB,eAAe,CAAC;EAC1F,MAAMyC,YAAY,GAAG,MAAMvG,iBAAiB,CAACiF,eAAe,GAAG,CAAC,EAAEI,IAAI,CAACmB,MAAM,CAAC;;EAE9E;EACA,IAAIC,WAAmD;EACvD,IAAIpB,IAAI,CAACqB,MAAM,IAAIrB,IAAI,CAACqB,MAAM,CAACvF,MAAM,GAAG,CAAC,EAAE;IACzC,MAAMwF,MAAqC,GAAG,EAAE;IAChD,KAAK,MAAMC,GAAG,IAAIvB,IAAI,CAACqB,MAAM,EAAE;MAC7BC,MAAM,CAACpC,IAAI,CAAC;QACVrC,IAAI,EAAE,OAAO;QACb2E,MAAM,EAAE;UACN3E,IAAI,EAAE,QAAQ;UACd4E,UAAU,EAAEF,GAAG,CAACG,SAAoE;UACpFC,IAAI,EAAEJ,GAAG,CAACK;QACZ;MACF,CAAQ,CAAC;IACX;IACAN,MAAM,CAACpC,IAAI,CAAC;MAAErC,IAAI,EAAE,MAAM;MAAEC,IAAI,EAAEqD,OAAO,IAAI;IAAwB,CAAC,CAAC;IACvEiB,WAAW,GAAGE,MAAM;EACtB,CAAC,MAAM;IACLF,WAAW,GAAGjB,OAAO;EACvB;EAEA,MAAMpD,QAAkC,GAAG,CACzC,GAAGqD,mBAAmB,EACtB;IAAEpD,IAAI,EAAE,MAAM;IAAEC,OAAO,EAAEmE;EAAY,CAAC,CACvC;EAED,IAAIS,OAAO,GAAG,CAAC;EACf,IAAIC,QAAQ,GAAG,CAAC;EAChB,IAAIC,kBAAkB,GAAG,CAAC;EAC1B,IAAIC,cAAc,GAAG,CAAC;EACtB,IAAIC,aAAa,GAAG,CAAC;EACrB,IAAIC,gBAA0B,GAAG,EAAE;EACnC,IAAIC,wBAAwB,GAAG,CAAC,CAAC,CAAC;;EAElC;EACA,MAAMC,YAAY,GAAGrB,IAAI,CAACC,GAAG,CAAC,CAAC;EAC/B,MAAM;IAAE5E;EAAQ,CAAC,GAAGnG,aAAa,CAAC,CAAC;EACnC,MAAMoM,OAAO,GAAG1L,QAAQ,CAAC,CAAC,CAAC,CAAC;EAC5B,MAAM2L,OAAO,GAAG1L,iBAAiB,CAAC;IAAE4F,KAAK,EAAErC,QAAQ,CAAC,CAAC;IAAEoI,UAAU,EAAEF;EAAQ,CAAC,CAAC;EAC7E,MAAMG,UAAU,GAAGF,OAAO,CAACG,MAAO,CAAC,CAAC;;EAEpC;EACA;EACA;EACA,IAAIJ,OAAO,KAAK,CAAC,EAAE;IACjBvL,OAAO,CAAC;MACN4L,MAAM,EAAE,oBAAoB;MAC5BC,UAAU,EAAE,CAAC;MACbC,OAAO,EAAE;QACP,GAAGN,OAAO;QACVG,MAAM,EAAExL,yBAAyB,CAAC,CAAC;QACnC4L,YAAY,EAAEC,SAAS,CAAE;MAC3B,CAAC;MACD1G,OAAO,EAAEA,OAAO,IAAI0G,SAAS;MAC7BC,OAAO,EAAE;QACPC,eAAe,EAAEV,OAAO,CAACW;MAC3B;IACF,CAAC,CAAC;EACJ;EAEA9L,aAAa,CAAC,OAAO,EAAE,QAAQkL,OAAO,KAAKlC,OAAO,CAAC7D,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,EAAE,MAAM,CAAC;;EAE3E;EACA5F,oBAAoB,CAAC;IACnBwM,OAAO,EAAEZ,OAAO,CAACY,OAAO;IACxBD,cAAc,EAAEX,OAAO,CAACW,cAAc;IACtCE,MAAM,EAAEb,OAAO,CAACa,MAAM;IACtBC,SAAS,EAAEd,OAAO,CAACc,SAAS;IAC5B5B,MAAM,EAAE;EACV,CAAC,CAAC;EAEF1K,OAAO,CAAC;IACN4L,MAAM,EAAE,mBAAmB;IAC3BC,UAAU,EAAE,CAAC;IACbC,OAAO,EAAEN,OAAO;IAChBlG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;IAC7BC,OAAO,EAAE;MACP5C,OAAO,EAAEA,OAAO;MAChBkD,2BAA2B,EAAEjD,mBAAmB,CAACtE;IACnD;EACF,CAAC,CAAC;EAEF,IAAIwH,cAAc,GAAG,CAAC;EACtB,IAAIC,eAAe,GAAG,CAAC;EACvB,IAAIC,sBAAsB,GAAG,CAAC,CAAC,CAAE;EACjC,IAAIC,sBAAsB,GAAG,CAAC,CAAC,CAAE;EACjC,MAAMC,mBAAmB,GAAG,IAAIrE,GAAG,CAAS,CAAC;EAC7C,MAAMsE,WAAW,GAAGxJ,QAAQ,CAAC,CAAC;;EAE9B;EACA;EACA,MAAMyJ,OAAO,GAAG,MAAMzL,kBAAkB,CAAC,CAAC;EAC1C,MAAM0L,QAAQ,GAAGD,OAAO,GACpB3L,sBAAsB,CAAC2L,OAAO,EAAE,KAAK,CAAC,GACtC,IAAI;;EAER;EACA;EACA;EACA,IAAI,CAACvI,mBAAmB,IAAI+E,mBAAmB,CAACtE,MAAM,KAAK,CAAC,EAAE;IAC5DT,mBAAmB,GAAGwI,QAAQ,GAC1BlM,YAAY,CAACmM,YAAY,CAACD,QAAQ,CAAC,GACnC,IAAIlM,YAAY,CAAC,CAAC;EACxB;EACA,MAAMoM,YAAY,GAAG1I,mBAAmB;EACxC0I,YAAY,CAACC,SAAS,CAAC,CAAC;EAExB,MAAMC,eAAe,GAAGjE,IAAI,CAACkE,YAAY,IACpCL,QAAQ,EAAEM,gBAAgB,CAACC,uBAAuB,IAClDrM,+BAA+B;;EAEpC;EACA;EACA,MAAMsM,YAAY,GAAGR,QAAQ,EAAEM,gBAAgB;EAC/C,MAAMG,OAAO,GAAGxM,oBAAoB,CAAC6L,WAAW,EAAEU,YAAY,CAAC;EAC/D,MAAME,WAAW,GAAGD,OAAO,CAACE,MAAM,CAACC,KAAK,CAACC,IAAI,CAAEC,CAAC,IAAKA,CAAC,CAAC9H,IAAI,KAAK,kBAAkB,CAAQ;EAC1F,MAAM+H,0BAA0B,GAAGL,WAAW,EAAEM,OAAO,EAAEC,KAAK,IAAI5M,cAAc,CAAC6M,uBAAuB;EACxG,MAAMC,yBAAyB,GAAGX,YAAY,EAAEY,uBAAuB,IAAIrN,uBAAuB;;EAElG;EACA;EACA,IAAI,CAACoI,IAAI,CAACS,QAAQ,IAAIoD,QAAQ,IAAIA,QAAQ,CAACpD,QAAQ,GAAG,CAAC,EAAE;IACvDD,iBAAiB,GAAGqD,QAAQ,CAACpD,QAAQ;EACvC;;EAEA;EACA,MAAMyE,gBAAgB,GAAGrB,QAAQ,EAAEqB,gBAAgB,IAAIhN,cAAc,CAACgN,gBAAgB;;EAEtF;EACA;EACA,MAAMC,sBAAsB,GAAG,IAAI9F,GAAG,CAACxJ,4BAA4B,CAACmI,GAAG,CAACW,CAAC,IAAIA,CAAC,CAACC,IAAI,CAAC,CAAC;EACrF,MAAMwG,YAAY,GAAG,MAAAA,CAAOxG,IAAY,EAAE1D,KAA8B,KAAoD;IAC1H,IAAI,CAAC0D,IAAI,EAAE;MACT,OAAO;QAAEyG,OAAO,EAAE,KAAK;QAAElK,MAAM,EAAE;MAAqC,CAAC;IACzE;;IAEA;IACA,IAAI,CAACnB,yBAAyB,CAAC4E,IAAI,CAAC,EAAE;MACpC,OAAO;QAAEyG,OAAO,EAAE,KAAK;QAAElK,MAAM,EAAE,SAASyD,IAAI,gBAAgB7E,iBAAiB,CAAC,CAAC;MAAkC,CAAC;IACtH;;IAEA;IACA,IAAIuL,cAAc,GAAGpK,KAAK;IAC1B,IAAI2F,KAAK,CAAC/E,MAAM,GAAG,CAAC,EAAE;MACpB,MAAMyJ,UAAU,GAAG,MAAM/N,iBAAiB,CAACqJ,KAAK,EAAEjC,IAAI,EAAE1D,KAAK,CAAC;MAC9D,IAAI,CAACqK,UAAU,CAACC,KAAK,EAAE;QACrB,OAAO;UAAEH,OAAO,EAAE,KAAK;UAAElK,MAAM,EAAEoK,UAAU,CAACpF,OAAO,IAAI;QAAkB,CAAC;MAC5E;MACA,IAAIoF,UAAU,CAACE,aAAa,EAAE;QAC5BH,cAAc,GAAGC,UAAU,CAACE,aAAa;MAC3C;IACF;IAEA,IAAIpI,MAA4C;IAChD,IAAI8H,sBAAsB,CAAC5F,GAAG,CAACX,IAAI,CAAC,EAAE;MACpCvB,MAAM,GAAG,MAAMvH,sBAAsB,CAAC8I,IAAI,EAAE0G,cAAc,CAAC;;MAE3D;MACA,IAAI1G,IAAI,KAAK,gBAAgB,IAAIvB,MAAM,CAACgI,OAAO,EAAE;QAC/C,MAAMK,QAA8B,GAAG,MAAM3P,mBAAmB,CAACuK,WAAW,CAAC;QAC7E,QAAQoF,QAAQ,CAAChD,MAAM;UACrB,KAAK,SAAS;YACZrF,MAAM,GAAG;cAAEgI,OAAO,EAAE,IAAI;cAAElK,MAAM,EAAE,4BAA4BkC,MAAM,CAAClC,MAAM;YAAG,CAAC;YAC/E;UACF,KAAK,MAAM;YACTkC,MAAM,GAAG;cAAEgI,OAAO,EAAE,IAAI;cAAElK,MAAM,EAAE;YAAkF,CAAC;YACrH;UACF,KAAK,UAAU;YACbkC,MAAM,GAAG;cAAEgI,OAAO,EAAE,IAAI;cAAElK,MAAM,EAAE,6BAA6BuK,QAAQ,CAACC,QAAQ,IAAI,wBAAwB;YAA2E,CAAC;YACxL;UACF,KAAK,QAAQ;YACXtI,MAAM,GAAG;cAAEgI,OAAO,EAAE,IAAI;cAAElK,MAAM,EAAE;YAA8D,CAAC;YACjG;QACJ;MACF;IACF,CAAC,MAAM,IAAIvF,WAAW,CAACgJ,IAAI,CAAC,EAAE;MAC5BvB,MAAM,GAAG,MAAM1H,gBAAgB,CAACiJ,IAAI,EAAE0G,cAAc,EAAEhF,WAAW,CAAC;IACpE,CAAC,MAAM,IAAIhK,YAAY,CAACsI,IAAI,CAAC,EAAE;MAC7BvB,MAAM,GAAG,MAAM7G,iBAAiB,CAACoI,IAAI,EAAE0G,cAAc,EAAE/E,OAAO,CAAC;IACjE,CAAC,MAAM,IAAIjJ,gBAAgB,CAACsO,SAAS,CAAChH,IAAI,CAAC,EAAE;MAC3CvB,MAAM,GAAG,MAAM/F,gBAAgB,CAACuO,QAAQ,CAACjH,IAAI,EAAE0G,cAAc,CAAC;IAChE,CAAC,MAAM;MACLjI,MAAM,GAAG;QAAEgI,OAAO,EAAE,KAAK;QAAElK,MAAM,EAAE,iBAAiByD,IAAI;MAAG,CAAC;IAC9D;;IAEA;IACA,IAAIiC,KAAK,CAAC/E,MAAM,GAAG,CAAC,EAAE;MACpB,MAAMgK,WAAW,GAAG,MAAMrO,gBAAgB,CAACoJ,KAAK,EAAEjC,IAAI,EAAEvB,MAAM,CAAClC,MAAM,EAAEkC,MAAM,CAACgI,OAAO,CAAC;MACtF,IAAIS,WAAW,CAACC,cAAc,KAAKjD,SAAS,EAAE;QAC5CzF,MAAM,GAAG;UAAE,GAAGA,MAAM;UAAElC,MAAM,EAAE2K,WAAW,CAACC;QAAe,CAAC;MAC5D;IACF;IAEA,OAAO1I,MAAM;EACf,CAAC;EAED,IAAI;IACF,KAAK,IAAI2I,SAAS,GAAG,CAAC,EAAEA,SAAS,GAAGxF,iBAAiB,EAAEwF,SAAS,EAAE,EAAE;MAClE,IAAI1F,WAAW,EAAE2F,OAAO,EAAE;QACxBnP,OAAO,CAAC;UAAE4L,MAAM,EAAE,gBAAgB;UAAEC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGoB,YAAY;UAAEQ,OAAO,EAAEN,OAAO;UAAElG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;UAAEC,OAAO,EAAE;YAAEiD,SAAS;YAAEE,MAAM,EAAE;UAAa;QAAE,CAAC,CAAC;QAC3K7F,SAAS,CAAC8F,OAAO,CAAC,WAAW,EAAEpJ,QAAQ,CAAC;QACxC;MACF;;MAEA;MACA,IAAIuG,cAAc,IAAIW,eAAe,EAAE;QACrCnN,OAAO,CAAC;UAAE4L,MAAM,EAAE,sBAAsB;UAAEC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGoB,YAAY;UAAEQ,OAAO,EAAEN,OAAO;UAAElG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;UAAEsD,QAAQ,EAAE,MAAM;UAAErD,OAAO,EAAE;YAAEsD,gBAAgB,EAAE/C,cAAc;YAAEgD,cAAc,EAAErC,eAAe;YAAE+B;UAAU;QAAE,CAAC,CAAC;QAChP3F,SAAS,CAAC8F,OAAO,CAAC,qBAAqB7C,cAAc,CAACiD,OAAO,CAAC,CAAC,CAAC,QAAQtC,eAAe,EAAE,EAAElH,QAAQ,CAAC;QACpG;MACF;MAEA,MAAMyJ,QAAQ,GAAGzF,IAAI,CAACC,GAAG,CAAC,CAAC;MAC3B,MAAMyF,SAAS,GAAG1P,cAAc,CAAC,CAAC;MAClC,MAAM2P,QAAQ,GAAGC,MAAM,CAACC,UAAU,CAAC,CAAC,CAAC,CAAC;MACtC,MAAMC,WAAW,GAAG,kBAAkBvD,cAAc,CAACiD,OAAO,CAAC,CAAC,CAAC,yBAAyB,CAACtC,eAAe,GAAGX,cAAc,EAAEiD,OAAO,CAAC,CAAC,CAAC,EAAE;;MAEvI;MACA,MAAMO,YAAY,GAAG3M,QAAQ,CAAC,CAAC;MAC/B,MAAMgD,SAAS,GAAGzE,eAAe,CAAC;QAChC8D,KAAK,EAAEsK,YAAY;QACnBpK,cAAc,EAAE,MAAM;QACtBqK,eAAe,EAAE/G,IAAI,CAACgH,QAAQ;QAC9B7C,gBAAgB,EAAEE;MACpB,CAAC,CAAC;;MAEF;MACA,IAAI;QAAEnH,KAAK,EAAE+J,WAAW;QAAElK,QAAQ,EAAEmK;MAAe,CAAC,GAAGtO,kBAAkB,CAACsE,KAAK,EAAEH,QAAQ,CAAC;MAC1F,MAAMH,MAAM,GAAGjE,iBAAiB,CAACuI,YAAY,EAAE2F,WAAW,CAAC;;MAE3D;MACA;MACA;MACA,MAAMM,QAAQ,GAAGnO,WAAW,CAAC8N,YAAY,CAAC;MAC1C,IAAIK,QAAQ,KAAK,QAAQ,IAAIA,QAAQ,KAAK,QAAQ,EAAE;QAClD,MAAMC,eAAe,GAAGF,cAAc;QACtC,IAAIC,QAAQ,KAAK,QAAQ,EAAE;UACzB;UACAD,cAAc,GAAGrO,iBAAiB,CAACqO,cAAc,EAAE/E,wBAAwB,CAAC;QAC9E,CAAC,MAAM;UACL;UACA;UACA,MAAMkF,SAAS,GAAGP,YAAY,KAAK,QAAQ,GAAG,MAAM,GAAG,OAAO;UAC9DI,cAAc,GAAGpO,iBAAiB,CAACoO,cAAc,EAAE/E,wBAAwB,EAAEkF,SAAS,CAAC;QACzF;QACA;QACA,IAAIH,cAAc,KAAKE,eAAe,EAAE;UACtC;UACA,MAAME,gBAAgB,GAAIC,IAA8B,IACtDA,IAAI,CAACC,MAAM,CAAC,CAACC,GAAG,EAAEC,CAAC,KAAKD,GAAG,IAAIE,KAAK,CAACC,OAAO,CAACF,CAAC,CAACzK,OAAO,CAAC,GAClDyK,CAAC,CAACzK,OAAO,CAA+CgC,MAAM,CAAC4I,CAAC,IAAIA,CAAC,CAAChL,IAAI,KAAK,aAAa,IAAIgL,CAAC,CAAC5K,OAAO,KAAK,WAAW,CAAC,CAACnB,MAAM,GAClI,CAAC,CAAC,EAAE,CAAC,CAAC;UACZ,MAAMgM,YAAY,GAAGR,gBAAgB,CAACF,eAAe,CAAC;UACtD,MAAMW,WAAW,GAAGT,gBAAgB,CAACJ,cAAc,CAAC;UACpD,MAAMc,cAAc,GAAGC,IAAI,CAACC,KAAK,CAAC/F,wBAAwB,IAAI,CAAC2F,YAAY,GAAGC,WAAW,IAAIE,IAAI,CAACE,GAAG,CAACL,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;UACxHzH,SAAS,CAAC+H,aAAa,GAAGN,YAAY,EAAEC,WAAW,EAAEC,cAAc,CAAC;UACpEzH,OAAO,EAAE8H,WAAW,CAACP,YAAY,EAAEC,WAAW,EAAEC,cAAc,CAAC;QACjE;MACF;;MAEA;MACA,MAAM7L,KAAK,GAAG,MAAM/F,aAAa,CAAC,CAAC;MACnC,IAAI,CAAC+F,KAAK,EAAE;QACV,MAAM,IAAImM,KAAK,CAAC,iCAAiC,CAAC;MACpD;;MAEA;MACA,MAAMC,aAAa,GAAGzB,YAAY;MAClC,MAAMnK,MAAM,GAAG,MAAMnE,eAAe,CAAC;QACnC0D,QAAQ,EAAEhG,WAAW,CAAC,CAAC;QACvBiG,KAAK;QACLK,KAAK,EAAEsK,YAAY;QACnBlK,MAAM;QACNG,QAAQ,EAAEmK,cAAc;QACxBhK,KAAK,EAAE+J,WAAW;QAClB9J,SAAS;QACTqL,MAAM,EAAElI,WAAW;QACnBmI,aAAa,EAAEzI,IAAI,CAACyI,aAAa;QACjCrM,OAAO,EAAEA,OAAO,IAAI0G,SAAS;QAC7B4F,UAAU,EAAEA,CAACC,IAAI,EAAEC,EAAE,KAAK;UACxB3O,QAAQ,CAAC2O,EAAE,CAAC;UACZ9R,OAAO,CAAC;YAAE4L,MAAM,EAAE,qBAAqB;YAAEC,UAAU,EAAE,CAAC;YAAEC,OAAO,EAAE;cAAE,GAAGN,OAAO;cAAEG,MAAM,EAAEgE,SAAS;cAAE5D,YAAY,EAAEL;YAAW,CAAC;YAAEpG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;YAAEC,OAAO,EAAE;cAAE8F,UAAU,EAAEF,IAAI;cAAEG,QAAQ,EAAEF;YAAG;UAAE,CAAC,CAAC;QAC7M,CAAC;QACDG,OAAO,EAAEA,CAACC,OAAO,EAAEb,GAAG,EAAEc,GAAG,KAAK;UAC9B,MAAMC,GAAG,GAAG,8BAA8BF,OAAO,IAAIb,GAAG,QAAQc,GAAG,CAAC3M,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW;UAC3F,IAAIiE,OAAO,EAAE;YAAEA,OAAO,CAAC4I,QAAQ,CAACD,GAAG,CAAC;UAAE,CAAC,MAAM;YAAE7I,SAAS,CAAC+I,MAAM,CAACF,GAAG,CAAC;UAAE;QACxE,CAAC;QACDG,cAAc,EAAE,MAAAA,CAAA,KAAY;UAC1B,MAAMhM,MAAM,GAAG,MAAMhH,cAAc,CAAC,CAAC;UACrC,OAAOgH,MAAM,CAACgI,OAAO,GAAGhI,MAAM,CAACmH,MAAM,CAAE8E,YAAY,GAAI,IAAI;QAC7D;MACF,CAAC,CAAC;;MAEF;MACA,IAAIC,cAAc,GAAG,CAAC;MACtB,MAAMlM,MAA0B,GAAG,MAAM/E,0BAA0B,CACjED,cAAc,CAACsE,MAAM,EAAE2D,WAAW,CAAC,EACnC;QACE8I,MAAM,EAAGtM,IAAI,IAAK;UAChB,IAAIyD,OAAO,EAAE;YACXA,OAAO,CAAC4I,QAAQ,CAACrM,IAAI,CAAC;UACxB,CAAC,MAAM;YACLuD,SAAS,CAAC+I,MAAM,CAACtM,IAAI,CAAC;UACxB;QACF,CAAC;QACD0M,UAAU,EAAEA,CAAA,KAAM;UAChBD,cAAc,EAAE;UAChBhJ,OAAO,EAAEkJ,YAAY,CAACF,cAAc,CAAC;QACvC,CAAC;QACDG,WAAW,EAAEA,CAAC9K,IAAI,EAAE1D,KAAK,KAAK;UAC5B;UACA;UACA;UACA,IAAIA,KAAK,EAAE;YACT;YACAqF,OAAO,EAAEoJ,aAAa,CAAC,EAAE,EAAE/K,IAAI,CAAC;UAClC;QACF;MACF,CAAC,EACD0B,WACF,CAAC;;MAED;MACAC,OAAO,EAAEqJ,SAAS,CAAC,CAAC;;MAEpB;MACA,IAAIzP,QAAQ,CAAC,CAAC,KAAKoO,aAAa,IAAIvI,IAAI,CAACyI,aAAa,EAAE;QACtDvO,YAAY,CAACqO,aAAa,CAAC;MAC7B;;MAEA;MACAxN,kBAAkB,IAAIsC,MAAM,CAACwM,KAAK,CAACC,WAAW;MAC9C9O,mBAAmB,IAAIqC,MAAM,CAACwM,KAAK,CAACE,YAAY;MAChD5H,wBAAwB,GAAG9E,MAAM,CAACwM,KAAK,CAACC,WAAW,CAAC,CAAC;;MAGrD;MACA,IAAIvJ,OAAO,KAAKlD,MAAM,CAACwM,KAAK,CAACC,WAAW,GAAG,CAAC,IAAIzM,MAAM,CAACwM,KAAK,CAACE,YAAY,GAAG,CAAC,CAAC,EAAE;QAC9E,MAAMC,QAAQ,GAAG3P,eAAe,CAACgD,MAAM,CAACwM,KAAK,CAACC,WAAW,EAAEzM,MAAM,CAACwM,KAAK,CAACE,YAAY,EAAEjD,YAAY,EAAEzJ,MAAM,CAAC4M,cAAc,EAAE5M,MAAM,CAACwM,KAAK,CAACK,eAAe,EAAE7M,MAAM,CAACwM,KAAK,CAACM,mBAAmB,CAAC;QAC1L5J,OAAO,CAAC6J,SAAS,CAAC/M,MAAM,CAACwM,KAAK,CAACC,WAAW,EAAEzM,MAAM,CAACwM,KAAK,CAACE,YAAY,EAAEjD,YAAY,EAAEkD,QAAQ,EAAE3M,MAAM,CAACwM,KAAK,CAACK,eAAe,EAAE7M,MAAM,CAACwM,KAAK,CAACM,mBAAmB,CAAC;MAChK;MAEAtI,OAAO,IAAIxE,MAAM,CAACwM,KAAK,CAACC,WAAW;MACnChI,QAAQ,IAAIzE,MAAM,CAACwM,KAAK,CAACE,YAAY;MACrChI,kBAAkB,IAAI1E,MAAM,CAACwM,KAAK,CAACM,mBAAmB;MACtDnI,cAAc,IAAI3E,MAAM,CAACwM,KAAK,CAACK,eAAe;MAC9CjI,aAAa,IAAI5E,MAAM,CAAC4M,cAAc;MACtC3G,cAAc,IAAIjJ,eAAe,CAACgD,MAAM,CAACwM,KAAK,CAACC,WAAW,EAAEzM,MAAM,CAACwM,KAAK,CAACE,YAAY,EAAEjD,YAAY,EAAEzJ,MAAM,CAAC4M,cAAc,EAAE5M,MAAM,CAACwM,KAAK,CAACK,eAAe,EAAE7M,MAAM,CAACwM,KAAK,CAACM,mBAAmB,CAAC;;MAE3L;MACAnS,uBAAuB,CAACsL,cAAc,EAAEW,eAAe,EAAEP,mBAAmB,EACzE5G,IAAI,IAAK;QAAE,IAAIyD,OAAO,EAAE;UAAEA,OAAO,CAAC4I,QAAQ,CAACrM,IAAI,CAAC;QAAE,CAAC,MAAM;UAAEuD,SAAS,CAAC+I,MAAM,CAACtM,IAAI,CAAC;QAAE;MAAE,CAAC,CAAC;;MAE1F;MACA,IAAIO,MAAM,CAACgN,wBAAwB,EAAE;QACnChK,SAAS,CAAC+H,aAAa,GAAGrL,QAAQ,CAACjB,MAAM,EAAEiB,QAAQ,CAACjB,MAAM,EAAE,CAAC,CAAC;QAC9DyE,OAAO,EAAE8H,WAAW,CAACtL,QAAQ,CAACjB,MAAM,EAAEiB,QAAQ,CAACjB,MAAM,EAAE,CAAC,CAAC;QACzDhF,OAAO,CAAC;UAAE4L,MAAM,EAAE,qBAAqB;UAAEC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGwF,QAAQ;UAAE5D,OAAO,EAAEN,OAAO;UAAElG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;UAAEC,OAAO,EAAE;YAAElG,IAAI,EAAE,aAAa;YAAEyN,sBAAsB,EAAEjN,MAAM,CAACkN,iBAAiB,KAAK,IAAI;YAAEvE;UAAU;QAAE,CAAC,CAAC;MACxO;MAEA,IAAI3I,MAAM,CAACP,IAAI,EAAEoF,gBAAgB,CAAChD,IAAI,CAAC7B,MAAM,CAACP,IAAI,CAAC;;MAEnD;MACA,MAAM0N,WAAW,GAAGnQ,eAAe,CAACgD,MAAM,CAACwM,KAAK,CAACC,WAAW,EAAEzM,MAAM,CAACwM,KAAK,CAACE,YAAY,EAAEjD,YAAY,EAAEzJ,MAAM,CAAC4M,cAAc,EAAE5M,MAAM,CAACwM,KAAK,CAACK,eAAe,EAAE7M,MAAM,CAACwM,KAAK,CAACM,mBAAmB,CAAC;MAC7LrT,OAAO,CAAC;QACN4L,MAAM,EAAE,oBAAoB;QAC5BC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGwF,QAAQ;QACjC5D,OAAO,EAAE;UAAE,GAAGN,OAAO;UAAEG,MAAM,EAAEgE,SAAS;UAAE5D,YAAY,EAAEL,UAAU;UAAEiI,KAAK,EAAE/D,QAAQ;UAAEoD,WAAW,EAAEzM,MAAM,CAACwM,KAAK,CAACC,WAAW;UAAEC,YAAY,EAAE1M,MAAM,CAACwM,KAAK,CAACE,YAAY;UAAEW,SAAS,EAAEF,WAAW;UAAEhO,KAAK,EAAEsK;QAAa,CAAC;QAClN1K,OAAO,EAAEA,OAAO,IAAI0G,SAAS;QAC7BC,OAAO,EAAE;UACP,sBAAsB,EAAE+D,YAAY;UACpC,2BAA2B,EAAEzJ,MAAM,CAACwM,KAAK,CAACC,WAAW;UACrD,4BAA4B,EAAEzM,MAAM,CAACwM,KAAK,CAACE,YAAY;UACvD,oCAAoC,EAAE1M,MAAM,CAACwM,KAAK,CAACM,mBAAmB;UACtE,gCAAgC,EAAE9M,MAAM,CAACwM,KAAK,CAACK,eAAe;UAC9D,mBAAmB,EAAEM,WAAW;UAChCG,WAAW,EAAEtN,MAAM,CAACuN,UAAU,KAAK,YAAY,GAAG,YAAY,GAAGvN,MAAM,CAACwN,aAAa,CAAC/O,MAAM,GAAG,CAAC,GAAG,UAAU,GAAG,UAAU;UAC1HkK,SAAS;UACT8E,UAAU,EAAEzN,MAAM,CAACwN,aAAa,CAAC/O,MAAM;UACvCiP,UAAU,EAAE1N,MAAM,CAACwN,aAAa,CAAC7M,GAAG,CAACW,CAAC,IAAIA,CAAC,CAACC,IAAI;QAClD;MACF,CAAC,CAAC;;MAEF;MACA;MACA;MACA;MACA,IAAIvB,MAAM,CAACuN,UAAU,KAAK,YAAY,IAAIvN,MAAM,CAACkN,iBAAiB,EAAE;QAClEhH,eAAe,EAAE;QACjBC,sBAAsB,EAAE;QACxB1M,OAAO,CAAC;UAAE4L,MAAM,EAAE,uBAAuB;UAAEC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGwF,QAAQ;UAAE5D,OAAO,EAAEN,OAAO;UAAElG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;UAAEC,OAAO,EAAE;YAAEiI,gBAAgB,EAAEzH,eAAe;YAAE0H,WAAW,EAAEzH,sBAAsB;YAAE0H,eAAe,EAAEnO,QAAQ,CAACjB;UAAO;QAAE,CAAC,CAAC;;QAEvP;QACA;QACA,MAAMqP,2BAA2B,GAAG,CAAC;QACrC,MAAMC,YAAY,GAChB5H,sBAAsB,GAAG2H,2BAA2B,IACpD5H,eAAe,GAAGqB,0BAA0B,IAAII,yBAAyB;QAE3E,MAAMqG,iBAAiB,GAAG,CACxB;UAAErO,IAAI,EAAE,WAAW;UAAEC,OAAO,EAAE,CAAC;YAAEJ,IAAI,EAAE,YAAY;YAAEI,OAAO,EAAEI,MAAM,CAACkN;UAAkB,CAAC;QAAE,CAAC,EAC3F;UAAEvN,IAAI,EAAE,MAAM;UAAEC,OAAO,EAAE,CAAC;YAAEJ,IAAI,EAAE,MAAM;YAAEC,IAAI,EAAEsO,YAAY,GACxD,8IAA8I,GAC9I;UAA2B,CAAC;QAAE,CAAC,CACpC;QACDrO,QAAQ,CAACjB,MAAM,GAAG,CAAC;QACnBiB,QAAQ,CAACmC,IAAI,CAAC,GAAGmM,iBAA6C,CAAC;QAE/D,IAAID,YAAY,EAAE;UAChB,MAAME,SAAS,GAAG9H,sBAAsB,GAAG2H,2BAA2B,GAClE,6CAA6C,GAC7C,2CAA2C;UAC/C,IAAI5K,OAAO,EAAE;YAAEA,OAAO,CAAC4I,QAAQ,CAACmC,SAAS,CAAC;UAAE,CAAC,MAAM;YAAEjL,SAAS,CAAC+I,MAAM,CAACkC,SAAS,CAAC;UAAE;QACpF;QAEAtF,SAAS,EAAE,CAAC,CAAC;QACb;MACF;;MAEA;MACA,IAAI3I,MAAM,CAACwN,aAAa,CAAC/O,MAAM,KAAK,CAAC,EAAE;QACrC;QACA;QACA,IAAIuB,MAAM,CAACuN,UAAU,KAAK,YAAY,IAAInH,sBAAsB,GAAGyB,gBAAgB,EAAE;UACnFzB,sBAAsB,EAAE;UACxB,MAAM8H,aAAa,GAAGlO,MAAM,CAACP,IAAI,IAAI,EAAE;UACvC,MAAM0O,gBAAgB,GAAGrS,qBAAqB,CAAC;YAC7C2D,IAAI,EAAEyO,aAAa;YACnBV,aAAa,EAAE,EAAE;YACjBY,cAAc,EAAEpO,MAAM,CAACoO,cAAc;YACrClB,iBAAiB,EAAElN,MAAM,CAACkN;UAC5B,CAAC,CAAC;UACFxN,QAAQ,CAACmC,IAAI,CAAC;YAAElC,IAAI,EAAE,WAAW;YAAEC,OAAO,EAAEuO;UAAiB,CAAsC,CAAC;;UAEpG;UACA;UACA,MAAME,gBAAgB,GAAGjI,sBAAsB,KAAK,CAAC,GACjD,yNAAyN,GACzN,+CAA+CA,sBAAsB,IAAIyB,gBAAgB,wLAAwL;UACrRnI,QAAQ,CAACmC,IAAI,CAAC;YAAElC,IAAI,EAAE,MAAM;YAAEC,OAAO,EAAE,CAAC;cAAEJ,IAAI,EAAE,MAAM;cAAEC,IAAI,EAAE4O;YAAiB,CAAC;UAAE,CAA2B,CAAC;UAC9G;QACF;QACA;MACF;;MAEA;MACAjI,sBAAsB,GAAG,CAAC;MAC1BD,sBAAsB,GAAG,CAAC;;MAE1B;MACA,MAAM;QAAEmI,OAAO,EAAE/N,WAAW;QAAEgO,OAAO;QAAEC;MAAY,CAAC,GAAG,MAAM3S,aAAa,CACxEmE,MAAM,CAACwN,aAAa,EACpBzF,YAAY,EACZ;QACErB,YAAY;QACZ+H,aAAa,EAAEjI,QAAQ,EAAEkI,kBAAkB,IAAI7T,cAAc,CAAC6T,kBAAkB;QAChFC,eAAe,EAAEnI,QAAQ,EAAEoI,mBAAmB,IAAI/T,cAAc,CAAC+T,mBAAmB;QACpFC,OAAO,EAAEA,CAACtN,IAAI,EAAE1D,KAAK,KAAK;UACxBmF,SAAS,CAACqJ,WAAW,CAAC9K,IAAI,EAAE1D,KAAK,CAAC;QACpC,CAAC;QACDiR,QAAQ,EAAEA,CAACvN,IAAI,EAAEyG,OAAO,EAAElK,MAAM,EAAEwH,UAAU,KAAK;UAC/CtC,SAAS,CAAC+L,YAAY,CAACxN,IAAI,EAAEyG,OAAO,EAAElK,MAAM,EAAE2H,SAAS,EAAEH,UAAU,CAAC;UACpE7L,OAAO,CAAC;YACN4L,MAAM,EAAE,QAAQ9D,IAAI,EAAE;YACtB+D,UAAU;YACVC,OAAO,EAAE;cAAE,GAAGN,OAAO;cAAEG,MAAM,EAAE1L,cAAc,CAAC,CAAC;cAAE8L,YAAY,EAAE4D,SAAS;cAAE4F,QAAQ,EAAE3F;YAAS,CAAC;YAC9FtK,OAAO,EAAEA,OAAO,IAAI0G,SAAS;YAC7BwJ,KAAK,EAAEjH,OAAO,GAAGvC,SAAS,GAAG3H,MAAM;YACnC4H,OAAO,EAAE;cACPwJ,UAAU,EAAE,CAAC,CAAC;cACdC,WAAW,EAAEC,cAAc,CAACtR,MAAM,EAAE,IAAI,CAAC;cACzCuR,UAAU,EAAErH,OAAO,GAAGvC,SAAS,GAAG6J,iBAAiB,CAACxR,MAAM,CAAC;cAC3D6K;YACF;UACF,CAAC,CAAC;QACJ,CAAC;QACDwC,MAAM,EAAElI,WAAW;QACnBsM,eAAe,EAAExQ,OAAO,GACpB,OAAOwF,MAAM,EAAEF,SAAS,KAAKjJ,cAAc,CAAC;UAC1CyD,QAAQ,EAAEhG,WAAW,CAAC,CAAC;UACvBiG,KAAK;UACLC,OAAO,EAAEA,OAAQ;UACjByQ,WAAW,EAAEjL,MAAM;UACnBF;QACF,CAAC,CAAC,GACFoB;MACN,CACF,CAAC;MAED,IAAI8I,OAAO,EAAE;QACX9U,OAAO,CAAC;UAAE4L,MAAM,EAAE,eAAe;UAAEC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGoB,YAAY;UAAEQ,OAAO,EAAEN,OAAO;UAAElG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;UAAEsD,QAAQ,EAAE,MAAM;UAAErD,OAAO,EAAE;YAAE,GAAGgB,YAAY,CAAC+I,eAAe,CAAC,CAAC;YAAE3M,OAAO,EAAE0L,WAAW;YAAE7F;UAAU;QAAE,CAAC,CAAC;MACjO;;MAEA;MACA,MAAM+G,WAAW,GAAG,IAAIC,GAAG,CAAC3P,MAAM,CAACwN,aAAa,CAAC7M,GAAG,CAACW,CAAC,IAAI,CAACA,CAAC,CAACsO,EAAE,EAAEtO,CAAC,CAACC,IAAI,CAAC,CAAC,CAAC;MAC1E,MAAMsO,gBAAgB,GAAG,MAAMvP,wBAAwB,CACrDC,WAAW,EACXmP,WAAW,EACX7W,WAAW,CAAC,CAAC,EACbiG,KAAK,EACL2B,kBAAkB,EAClB1B,OAAO,IAAI0G,SACb,CAAC;;MAED;MACA,MAAM0I,gBAAgB,GAAGrS,qBAAqB,CAAC;QAC7C2D,IAAI,EAAEO,MAAM,CAACP,IAAI;QACjB+N,aAAa,EAAExN,MAAM,CAACwN,aAAa;QACnCY,cAAc,EAAEpO,MAAM,CAACoO,cAAc;QACrClB,iBAAiB,EAAElN,MAAM,CAACkN;MAC5B,CAAC,CAAC;MACFxN,QAAQ,CAACmC,IAAI,CAAC;QAAElC,IAAI,EAAE,WAAW;QAAEC,OAAO,EAAEuO;MAAwB,CAAC,CAAC;;MAEtE;MACA,MAAM2B,eAAe,GAAG,2BAA2B;MACnD,MAAMC,oBAAoB,GAAGF,gBAAgB,CAACG,IAAI,CAAEC,EAAO,IAAK;QAC9D,MAAMrQ,OAAO,GAAG,OAAOqQ,EAAE,CAACrQ,OAAO,KAAK,QAAQ,GAAGqQ,EAAE,CAACrQ,OAAO,GAAG,EAAE;QAChE,OAAOA,OAAO,CAACsQ,UAAU,CAACJ,eAAe,CAAC;MAC5C,CAAC,CAAC;MACF,IAAIC,oBAAoB,EAAE;QACxB;QACA,MAAMI,UAAU,GAAGN,gBAAgB,CAACxI,IAAI,CAAE4I,EAAO,IAAK;UACpD,MAAMrQ,OAAO,GAAG,OAAOqQ,EAAE,CAACrQ,OAAO,KAAK,QAAQ,GAAGqQ,EAAE,CAACrQ,OAAO,GAAG,EAAE;UAChE,OAAOA,OAAO,CAACsQ,UAAU,CAACJ,eAAe,CAAC;QAC5C,CAAC,CAAQ;QACT,MAAMM,QAAQ,GAAID,UAAU,CAACvQ,OAAO,CAAYX,KAAK,CAAC6Q,eAAe,CAACrR,MAAM,CAAC;QAC7E,MAAM4R,WAAW,GAAG3Q,QAAQ,CAACjB,MAAM;QACnCiB,QAAQ,CAACjB,MAAM,GAAG,CAAC;QACnBiB,QAAQ,CAACmC,IAAI,CAAC;UAAElC,IAAI,EAAE,MAAM;UAAEC,OAAO,EAAE,CAAC;YAAEJ,IAAI,EAAE,MAAM;YAAEC,IAAI,EAAE,2BAA2B2Q,QAAQ;UAAG,CAAC;QAAE,CAAQ,CAAC;QAChHpN,SAAS,CAAC+H,aAAa,GAAGsF,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC;QAC5C;MACF;MAEA3Q,QAAQ,CAACmC,IAAI,CAAC;QAAElC,IAAI,EAAE,MAAM;QAAEC,OAAO,EAAEiQ;MAAwB,CAAC,CAAC;;MAEjE;MACA,MAAMS,aAAa,GAAG9V,mBAAmB,CAACiP,YAAY,CAAC;MACvD,IAAI,CAAC6G,aAAa,CAACC,QAAQ,IAAIvQ,MAAM,CAACwM,KAAK,CAACC,WAAW,IAAI6D,aAAa,CAACE,aAAa,EAAE;QACtFtK,eAAe,EAAE;QAEjB,IAAIA,eAAe,GAAGoK,aAAa,CAACE,aAAa,IAAIF,aAAa,CAACG,WAAW,EAAE;UAC9E;UACA,MAAMxC,SAAS,GAAG,2CAA2C;UAC7D,IAAI/K,OAAO,EAAE;YAAEA,OAAO,CAAC4I,QAAQ,CAACmC,SAAS,CAAC;UAAE,CAAC,MAAM;YAAEjL,SAAS,CAAC+I,MAAM,CAACkC,SAAS,CAAC;UAAE;UAElF,MAAMhO,OAAO,GAAG,MAAMvE,yBAAyB,CAAC;YAC9CmD,QAAQ,EAAEhG,WAAW,CAAC,CAAC;YACvBiG,KAAK;YACLY,QAAQ;YACRmE;UACF,CAAC,CAAC;UACF,MAAMmK,iBAAiB,GAAG,CACxB,IAAI/N,OAAO,GACP,CAAC;YAAEN,IAAI,EAAE,WAAW;YAAEC,OAAO,EAAE,CAAC;cAAEJ,IAAI,EAAE,YAAY;cAAEI,OAAO,EAAEK;YAAQ,CAAC;UAAE,CAAC,CAAC,GAC5E,EAAE,CAAC,EACP;YAAEN,IAAI,EAAE,MAAM;YAAEC,OAAO,EAAE,CAAC;cAAEJ,IAAI,EAAE,MAAM;cAAEC,IAAI,EAAE;YAA+I,CAAC;UAAE,CAAC,CACpM;UACDC,QAAQ,CAACjB,MAAM,GAAG,CAAC;UACnBiB,QAAQ,CAACmC,IAAI,CAAC,GAAGmM,iBAA6C,CAAC;UAC/D;QACF;;QAEA;QACA,MAAM/N,OAAO,GAAG,MAAMvE,yBAAyB,CAAC;UAC9CmD,QAAQ,EAAEhG,WAAW,CAAC,CAAC;UACvBiG,KAAK;UACLY,QAAQ,EAAEA,QAAe;UACzBmE;QACF,CAAC,CAAC;QAEF,IAAI5D,OAAO,EAAE;UACX,MAAMoQ,WAAW,GAAG3Q,QAAQ,CAACjB,MAAM;UACnC,MAAMuP,iBAAiB,GAAG,CACxB;YAAErO,IAAI,EAAE,WAAW;YAAEC,OAAO,EAAE,CAAC;cAAEJ,IAAI,EAAE,YAAY;cAAEI,OAAO,EAAEK;YAAQ,CAAC;UAAE,CAAC,EAC1E;YAAEN,IAAI,EAAE,MAAM;YAAEC,OAAO,EAAE,CAAC;cAAEJ,IAAI,EAAE,MAAM;cAAEC,IAAI,EAAE;YAA2B,CAAC;UAAE,CAAC,CAChF;UACDC,QAAQ,CAACjB,MAAM,GAAG,CAAC;UACnBiB,QAAQ,CAACmC,IAAI,CAAC,GAAGmM,iBAA6C,CAAC;UAC/DrF,SAAS,EAAE,CAAC,CAAC;;UAEb3F,SAAS,CAAC+H,aAAa,GAAGsF,WAAW,EAAE3Q,QAAQ,CAACjB,MAAM,EAAEmM,IAAI,CAACC,KAAK,CAAC7K,MAAM,CAACwM,KAAK,CAACC,WAAW,GAAG,GAAG,CAAC,CAAC;UACnGvJ,OAAO,EAAE8H,WAAW,CAACqF,WAAW,EAAE3Q,QAAQ,CAACjB,MAAM,EAAEmM,IAAI,CAACC,KAAK,CAAC7K,MAAM,CAACwM,KAAK,CAACC,WAAW,GAAG,GAAG,CAAC,CAAC;UAE9FhT,OAAO,CAAC;YAAE4L,MAAM,EAAE,0BAA0B;YAAEC,UAAU,EAAE,CAAC;YAAEC,OAAO,EAAEN,OAAO;YAAElG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;YAAEC,OAAO,EAAE;cAAEiI,gBAAgB,EAAEzH,eAAe;cAAE4D,QAAQ;cAAE3K,KAAK,EAAEsK,YAAY;cAAEiH,YAAY,EAAE1Q,MAAM,CAACwM,KAAK,CAACC,WAAW;cAAEkE,cAAc,EAAEL,aAAa,CAACE;YAAc;UAAE,CAAC,CAAC;QACrR;MACF;IACF;;IAEA;IACA/W,OAAO,CAAC;MACN4L,MAAM,EAAE,uBAAuB;MAC/BC,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGoB,YAAY;MACrCQ,OAAO,EAAE;QAAE,GAAGN,OAAO;QAAEwH,WAAW,EAAEjI,OAAO;QAAEkI,YAAY,EAAEjI,QAAQ;QAAEtF,KAAK,EAAEmH;MAAY,CAAC;MACzFvH,OAAO,EAAEA,OAAO,IAAI0G,SAAS;MAC7BC,OAAO,EAAE;QACPgL,YAAY,EAAElM,OAAO;QAAEoM,aAAa,EAAEnM,QAAQ;QAAEoM,YAAY,EAAErM,OAAO,GAAGC,QAAQ;QAChFqM,qBAAqB,EAAEpM,kBAAkB;QAAEqM,iBAAiB,EAAEpM,cAAc;QAC5EqM,oBAAoB,EAAEtT,kBAAkB;QAAEuT,qBAAqB,EAAEtT,mBAAmB;QACpFwB,KAAK,EAAEmH;MACT;IACF,CAAC,CAAC;IAEF,MAAM4K,WAAW,GAAGlU,eAAe,CAACwH,OAAO,EAAEC,QAAQ,EAAE6B,WAAW,EAAE1B,aAAa,EAAED,cAAc,EAAED,kBAAkB,CAAC;IACtH1B,SAAS,CAACmO,OAAO,CAAC3M,OAAO,EAAEC,QAAQ,EAAEG,aAAa,EAAE0B,WAAW,EAAE4K,WAAW,EAAEvM,cAAc,EAAED,kBAAkB,CAAC;;IAEjH;IACA/K,aAAa,CAAC,CAAC;;IAEf;IACA,IAAI6J,KAAK,CAAC/E,MAAM,GAAG,CAAC,EAAE;MACpBpE,cAAc,CAACmJ,KAAK,EAAE,YAAY,EAAE;QAAEC,UAAU,EAAE,QAAQsB,YAAY;MAAG,CAAC,CAAC,CAACnB,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IAC7F;IAEA,MAAMwN,SAAS,GAAGvM,gBAAgB,CAACpG,MAAM,GAAG,CAAC,GAAGoG,gBAAgB,CAACA,gBAAgB,CAACpG,MAAM,GAAG,CAAC,CAAC,GAAG,EAAE;IAClGyE,OAAO,EAAEmO,QAAQ,CAACD,SAAS,EAAE1R,QAAQ,CAAC;IACtC,IAAIwD,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;IACjCgJ,SAAS,CAACsO,MAAM,CAAC5R,QAAQ,CAAC;EAC5B,CAAC,CAAC,OAAOkM,GAAQ,EAAE;IACjB,MAAM2F,QAAQ,GAAGtO,WAAW,EAAE2F,OAAO,IAAIgD,GAAG,EAAE9I,OAAO,KAAK,WAAW,GACjE,WAAW,GACX0O,MAAM,CAAC5F,GAAG,EAAE9I,OAAO,IAAI8I,GAAG,CAAC;IAE/BnS,OAAO,CAAC;MACN4L,MAAM,EAAEkM,QAAQ,KAAK,WAAW,GAAG,gBAAgB,GAAG,kBAAkB;MACxEjM,UAAU,EAAE5B,IAAI,CAACC,GAAG,CAAC,CAAC,GAAGoB,YAAY;MACrCQ,OAAO,EAAE;QAAE,GAAGN,OAAO;QAAEwH,WAAW,EAAEjI,OAAO;QAAEkI,YAAY,EAAEjI,QAAQ;QAAEtF,KAAK,EAAEmH;MAAY,CAAC;MACzFvH,OAAO,EAAEA,OAAO,IAAI0G,SAAS;MAC7BsD,QAAQ,EAAEwI,QAAQ,KAAK,WAAW,GAAG,MAAM,GAAG,OAAO;MACrDtC,KAAK,EAAEsC,QAAQ,KAAK,WAAW,GAAG9L,SAAS,GAAG8L,QAAQ;MACtD7L,OAAO,EAAE;QAAEgL,YAAY,EAAElM,OAAO;QAAEoM,aAAa,EAAEnM,QAAQ;QAAEuE,gBAAgB,EAAE/C,cAAc;QAAE9G,KAAK,EAAEmH;MAAY;IAClH,CAAC,CAAC;;IAEF;IACA,IAAIiL,QAAQ,KAAK,WAAW,EAAE;MAC5B1X,YAAY,CAAC;QACXoV,KAAK,EAAErD,GAAG,YAAYX,KAAK,GAAGW,GAAG,GAAGnG,SAAS;QAC7CgM,SAAS,EAAE,gBAAgB;QAC3BC,YAAY,EAAEH,QAAQ;QACtBxI,QAAQ,EAAE,OAAO;QACjBlD,OAAO,EAAEZ,OAAO,CAACY,OAAO;QACxBT,MAAM,EAAEH,OAAO,CAACG,MAAM;QACtBrG,OAAO,EAAEA,OAAO,IAAI0G,SAAS;QAC7BkM,IAAI,EAAE;UAAExS,KAAK,EAAEmH,WAAW;UAAEsL,IAAI,EAAEJ,MAAM,CAACxM,OAAO;QAAE;MACpD,CAAC,CAAC;IACJ;;IAEA;IACArL,aAAa,CAAC,CAAC;IAEfuJ,OAAO,EAAE2O,SAAS,CAACN,QAAQ,CAAC;IAC5B,IAAIrO,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;IACjCgJ,SAAS,CAAC8F,OAAO,CAACyI,QAAQ,EAAE7R,QAAQ,CAAC;EACvC;AACF;;AAEA;AACA;AACA;;AAEA,OAAO,SAAS0P,cAAcA,CAACtR,MAAc,EAAEgU,MAAc,EAAU;EACrE,IAAIhU,MAAM,CAACW,MAAM,IAAIqT,MAAM,EAAE,OAAOhU,MAAM;EAC1C,OAAOA,MAAM,CAACmB,KAAK,CAAC,CAAC,EAAE6S,MAAM,CAAC,GAAG,QAAQhU,MAAM,CAACW,MAAM,eAAe;AACvE;AAEA,OAAO,SAAS6Q,iBAAiBA,CAACxR,MAAc,EAAU;EACxD,MAAMiU,KAAK,GAAGjU,MAAM,CAACkU,WAAW,CAAC,CAAC;EAClC,IAAID,KAAK,CAACE,QAAQ,CAAC,WAAW,CAAC,IAAIF,KAAK,CAACE,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,SAAS;EAC9E,IAAIF,KAAK,CAACE,QAAQ,CAAC,mBAAmB,CAAC,IAAIF,KAAK,CAACE,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,YAAY;EACxF,IAAIF,KAAK,CAACE,QAAQ,CAAC,WAAW,CAAC,IAAIF,KAAK,CAACE,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,WAAW;EACrF,IAAIF,KAAK,CAACE,QAAQ,CAAC,mBAAmB,CAAC,IAAIF,KAAK,CAACE,QAAQ,CAAC,eAAe,CAAC,EAAE,OAAO,mBAAmB;EACtG,IAAIF,KAAK,CAACE,QAAQ,CAAC,QAAQ,CAAC,IAAIF,KAAK,CAACE,QAAQ,CAAC,OAAO,CAAC,EAAE,OAAO,cAAc;EAC9E,IAAIF,KAAK,CAACE,QAAQ,CAAC,QAAQ,CAAC,IAAIF,KAAK,CAACE,QAAQ,CAAC,OAAO,CAAC,EAAE,OAAO,cAAc;EAC9E,IAAIF,KAAK,CAACE,QAAQ,CAAC,oBAAoB,CAAC,EAAE,OAAO,aAAa;EAC9D,OAAO,SAAS;AAClB;;AAEA;AACA,OAAO,SAASC,WAAWA,CAAA,EAAwC;EACjE,MAAM/K,MAAM,GAAGxO,UAAU,CAAC,CAAC;EAC3B,MAAMwZ,QAAQ,GAAG,CAAC,EAAEhL,MAAM,CAAC8E,YAAY,IAAI9E,MAAM,CAACiL,aAAa,CAAC;EAChE,MAAMC,SAAS,GAAG,CAAC,CAAC9O,OAAO,CAAC+O,GAAG,CAACC,iBAAiB;EAEjD,IAAIJ,QAAQ,IAAIE,SAAS,EAAE,OAAO;IAAEG,KAAK,EAAE;EAAK,CAAC;EACjD,OAAO;IAAEA,KAAK,EAAE,KAAK;IAAE3J,MAAM,EAAE;EAAqC,CAAC;AACvE;;AAEA;AACA;AACA;;AAEA,SAAS4J,aAAa,QAAQ,qBAAqB;;AAEnD;AACA,eAAe7P,oBAAoBA,CAAA,EAAqB;EACtD,IAAIW,OAAO,CAAC+O,GAAG,CAACI,kBAAkB,KAAK,KAAK,EAAE,OAAO,KAAK;EAC1D,IAAInP,OAAO,CAAC+O,GAAG,CAACI,kBAAkB,KAAK,IAAI,EAAE,OAAO,IAAI;;EAExD;EACA;EACA;EACA,IAAInP,OAAO,CAACoP,KAAK,CAACC,KAAK,EAAE,OAAO,KAAK;;EAErC;EACA,MAAM/T,QAAQ,GAAGhG,WAAW,CAAC,CAAC;EAC9B,IAAI,CAACgG,QAAQ,EAAE,OAAO,KAAK;EAE3B,MAAMsI,MAAM,GAAGvO,aAAa,CAAC,CAAC;EAC9B,IAAI,CAACuO,MAAM,CAACpI,OAAO,EAAE,OAAO,KAAK;EAEjC,MAAM8T,MAAM,GAAG,IAAIJ,aAAa,CAAC5T,QAAQ,EAAE9F,aAAa,CAAC;EACzD,OAAO8Z,MAAM,CAACC,WAAW,CAAC,CAAC;AAC7B;;AAEA;AACA;AACA;AACA;AACA,eAAejQ,mBAAmBA,CAACF,IAAsB,EAAiB;EACxE,MAAM;IAAEG,OAAO;IAAEC,mBAAmB;IAAEC,SAAS;IAAEC,WAAW;IAAEC;EAAQ,CAAC,GAAGP,IAAI;EAC9E,MAAM9D,QAAQ,GAAGhG,WAAW,CAAC,CAAC;EAC9B,IAAI,CAACgG,QAAQ,EAAE,MAAM,IAAIoM,KAAK,CAAC,yCAAyC,CAAC;;EAEzE;EACA,IAAI/H,OAAO,EAAEnJ,gBAAgB,CAACmJ,OAAO,CAAC;EAEtC,MAAM2P,MAAM,GAAG,IAAIJ,aAAa,CAAC5T,QAAQ,EAAE9F,aAAa,CAAC;EACzD,MAAMoO,MAAM,GAAGvO,aAAa,CAAC,CAAC;EAC9B,MAAMmG,OAAO,GAAGoI,MAAM,CAACpI,OAAO;EAE9B,IAAI,CAACA,OAAO,EAAE;IACZiE,SAAS,CAAC8F,OAAO,CAAC,uEAAuE,CAAC;IAC1F,IAAI5F,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;IACjC;EACF;;EAEA;EACA,IAAI+Y,OAAO,GAAG5L,MAAM,CAAC6L,cAAc;EACnC,IAAI,CAACD,OAAO,EAAE;IACZA,OAAO,GAAG,CAAC,MAAMja,qBAAqB,CAAC+F,QAAQ,EAAEE,OAAO,EAAEhG,aAAa,CAAC,KAAK,EAAE;EACjF;EACA,IAAI,CAACga,OAAO,EAAE;IACZ/P,SAAS,CAAC8F,OAAO,CAAC,qGAAqG,CAAC;IACxH,IAAI5F,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;IACjC;EACF;;EAEA;EACA,MAAMiZ,QAAQ,GAAG1P,OAAO,CAAC+O,GAAG,CAACY,uBAAuB;EACpD,IAAIC,SAAiB;EACrB,IAAIF,QAAQ,EAAE;IACZE,SAAS,GAAGF,QAAQ;IACpB,OAAO1P,OAAO,CAAC+O,GAAG,CAACY,uBAAuB,CAAC,CAAC;EAC9C,CAAC,MAAM;IACL,MAAME,OAAO,GAAG,MAAMP,MAAM,CAACQ,aAAa,CAAC;MACzCtU,OAAO;MACPgU,OAAO;MACPO,OAAO,EAAE,KAAK;MACdxQ;IACF,CAAC,CAAC;IACFqQ,SAAS,GAAGC,OAAO,CAACxD,EAAE;EACxB;;EAEA;EACA,MAAM2D,cAAc,GAAGtW,WAAW,CAAC8F,mBAAmB,CAAC;EACvD1F,iBAAiB,CAACkW,cAAc,EAAE;IAAEC,eAAe,EAAEL,SAAS;IAAEM,MAAM,EAAE;EAAK,CAAC,CAAC;;EAE/E;EACA;EACA,IAAIC,eAAe,GAAG,EAAE;EACxB;EACA;EACA,IAAIC,YAAY,GAAG,KAAK;EAExB,IAAI;IACF,MAAMd,MAAM,CAACe,WAAW,CAACT,SAAS,EAAErQ,OAAO,EAAE;MAC3CiJ,MAAM,EAAGtM,IAAI,IAAK;QAChBiU,eAAe,IAAIjU,IAAI;QACvB,IAAIyD,OAAO,EAAE;UACXA,OAAO,CAAC4I,QAAQ,CAACrM,IAAI,CAAC;QACxB,CAAC,MAAM;UACLuD,SAAS,CAAC+I,MAAM,CAACtM,IAAI,CAAC;QACxB;MACF,CAAC;MACD4M,WAAW,EAAEA,CAAC9K,IAAY,EAAE1D,KAAe,KAAK;QAC9CmF,SAAS,CAACqJ,WAAW,CAAC9K,IAAI,EAAE1D,KAA4C,CAAC;QACzE,IAAIA,KAAK,EAAEqF,OAAO,EAAEoJ,aAAa,CAAC,EAAE,EAAE/K,IAAI,CAAC;MAC7C,CAAC;MACDwN,YAAY,EAAEA,CAACxN,IAAI,EAAEyG,OAAO,EAAEhI,MAAM,KAAK;QACvCgD,SAAS,CAAC+L,YAAY,CAACxN,IAAI,EAAEyG,OAAO,EAAEhI,MAAM,CAAC;MAC/C,CAAC;MACDmR,OAAO,EAAEA,CAAC0C,MAAM,EAAEC,OAAO,KAAK;QAC5B9Q,SAAS,CAACmO,OAAO,CAAC0C,MAAM,CAAChW,KAAK,EAAEgW,MAAM,CAAC/V,MAAM,EAAE,CAAC,EAAEhB,QAAQ,CAAC,CAAC,EAAEgX,OAAO,EAAED,MAAM,CAACE,SAAS,EAAEF,MAAM,CAACG,aAAa,CAAC;QAC9G,IAAI9Q,OAAO,KAAK2Q,MAAM,CAAChW,KAAK,GAAG,CAAC,IAAIgW,MAAM,CAAC/V,MAAM,GAAG,CAAC,CAAC,EAAE;UACtDoF,OAAO,CAAC6J,SAAS,CAAC8G,MAAM,CAAChW,KAAK,EAAEgW,MAAM,CAAC/V,MAAM,EAAEhB,QAAQ,CAAC,CAAC,EAAEgX,OAAO,EAAED,MAAM,CAACE,SAAS,EAAEF,MAAM,CAACG,aAAa,CAAC;QAC7G;MACF,CAAC;MACD1C,MAAM,EAAG2C,eAAe,IAAK;QAC3B/Q,OAAO,EAAEqJ,SAAS,CAAC,CAAC;QACpBrJ,OAAO,EAAEmO,QAAQ,CAACqC,eAAe,EAAE3Q,mBAAmB,CAAC;QACvD,IAAIG,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;QACjCgJ,SAAS,CAACsO,MAAM,CAACvO,mBAAmB,CAAC;MACvC,CAAC;MACD+F,OAAO,EAAG8C,GAAG,IAAK;QAChB+H,YAAY,GAAG,IAAI;QACnBzQ,OAAO,EAAE2O,SAAS,CAACjG,GAAG,CAAC;QACvB,IAAI1I,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;QACjCgJ,SAAS,CAAC8F,OAAO,CAAC8C,GAAG,CAAC;MACxB;IACF,CAAC,EAAE3I,WAAW,CAAC;EACjB,CAAC,CAAC,OAAO2I,GAAQ,EAAE;IACjB,IAAI,CAAC+H,YAAY,EAAE;MACjB,MAAMpC,QAAQ,GAAGtO,WAAW,EAAE2F,OAAO,IAAIgD,GAAG,EAAE9I,OAAO,KAAK,WAAW,GACjE,WAAW,GACX0O,MAAM,CAAC5F,GAAG,EAAE9I,OAAO,IAAI8I,GAAG,CAAC;MAC/B1I,OAAO,EAAE2O,SAAS,CAACN,QAAQ,CAAC;MAC5B,IAAIrO,OAAO,EAAElJ,kBAAkB,CAAC,CAAC;MACjCgJ,SAAS,CAAC8F,OAAO,CAACyI,QAAQ,CAAC;IAC7B;EACF;AACF","ignoreList":[]}
@@ -4,17 +4,14 @@
4
4
  * Unified auth session at ~/.whaletools/session.json
5
5
  * User preferences at ~/.whaletools/preferences.json
6
6
  *
7
- * v2.0: Raw Supabase/Anthropic keys (for MCP server env vars)
8
- * v2.1: Auth tokens from login flow (for CLI chat/status)
9
- * v4.0: Shared auth with Swift apps via ~/.whaletools/session.json
7
+ * Platform credentials (Supabase URL, anon key) are built-in constants —
8
+ * users never need to provide API keys. Authentication is handled by
9
+ * `whale login` (browser OAuth JWT stored in session.json).
10
10
  *
11
- * Environment variables always override file-based config for MCP server mode.
11
+ * Environment variables (SUPABASE_SERVICE_ROLE_KEY, etc.) are only for
12
+ * dev/self-hosted deployments and override the built-in defaults.
12
13
  */
13
14
  export interface WhaleConfig {
14
- supabase_url?: string;
15
- supabase_key?: string;
16
- anthropic_api_key?: string;
17
- default_agent_id?: string;
18
15
  access_token?: string;
19
16
  refresh_token?: string;
20
17
  user_id?: string;
@@ -22,10 +19,11 @@ export interface WhaleConfig {
22
19
  store_id?: string;
23
20
  store_name?: string;
24
21
  expires_at?: number;
22
+ default_agent_id?: string;
23
+ agent_api_key?: string;
25
24
  default_model?: string;
26
25
  thinking_enabled?: boolean;
27
26
  permission_mode?: string;
28
- agent_api_key?: string;
29
27
  platform_url?: string;
30
28
  stores?: Array<{
31
29
  id: string;
@@ -49,9 +47,9 @@ export declare function loadPreferences(): WhalePreferences;
49
47
  export declare function savePreferences(prefs: WhalePreferences): void;
50
48
  export interface ResolvedConfig {
51
49
  supabaseUrl: string;
50
+ /** Service role key — only set via SUPABASE_SERVICE_ROLE_KEY env var (dev/self-hosted). Empty for normal users. */
52
51
  supabaseKey: string;
53
52
  storeId: string;
54
- anthropicApiKey: string;
55
53
  defaultAgentId: string;
56
54
  serverUrl: string;
57
55
  platformUrl: string;
@@ -4,11 +4,12 @@
4
4
  * Unified auth session at ~/.whaletools/session.json
5
5
  * User preferences at ~/.whaletools/preferences.json
6
6
  *
7
- * v2.0: Raw Supabase/Anthropic keys (for MCP server env vars)
8
- * v2.1: Auth tokens from login flow (for CLI chat/status)
9
- * v4.0: Shared auth with Swift apps via ~/.whaletools/session.json
7
+ * Platform credentials (Supabase URL, anon key) are built-in constants —
8
+ * users never need to provide API keys. Authentication is handled by
9
+ * `whale login` (browser OAuth JWT stored in session.json).
10
10
  *
11
- * Environment variables always override file-based config for MCP server mode.
11
+ * Environment variables (SUPABASE_SERVICE_ROLE_KEY, etc.) are only for
12
+ * dev/self-hosted deployments and override the built-in defaults.
12
13
  */
13
14
 
14
15
  import { existsSync, mkdirSync, readFileSync, writeFileSync, unlinkSync } from "fs";
@@ -244,17 +245,15 @@ export function savePreferences(prefs) {
244
245
  /** Default Fly.io agent server URL */
245
246
  export const WHALE_SERVER_URL = "https://whale-agent.fly.dev";
246
247
 
247
- /** Default Supabase URL — fallback when env var and config are both empty */
248
+ /** Built-in platform Supabase URL */
248
249
  const DEFAULT_SUPABASE_URL = "https://uaednwpxursknmwdeejn.supabase.co";
249
250
  export function resolveConfig() {
250
251
  const file = loadConfig();
251
252
  return {
252
- supabaseUrl: process.env.SUPABASE_URL || file.supabase_url || DEFAULT_SUPABASE_URL,
253
- // User JWT preferred over legacy service role key from config file;
254
- // env var SUPABASE_SERVICE_ROLE_KEY still wins (explicit MCP setup)
255
- supabaseKey: process.env.SUPABASE_SERVICE_ROLE_KEY || file.access_token || file.supabase_key || "",
253
+ supabaseUrl: process.env.SUPABASE_URL || DEFAULT_SUPABASE_URL,
254
+ // Service role key env var only, never from user config file
255
+ supabaseKey: process.env.SUPABASE_SERVICE_ROLE_KEY || "",
256
256
  storeId: process.env.STORE_ID || file.store_id || "",
257
- anthropicApiKey: process.env.ANTHROPIC_API_KEY || file.anthropic_api_key || "",
258
257
  defaultAgentId: file.default_agent_id || "",
259
258
  serverUrl: process.env.WHALE_SERVER_URL || WHALE_SERVER_URL,
260
259
  platformUrl: process.env.WHALETOOLS_PLATFORM_URL || file.platform_url || "https://whaletools.dev"
@@ -286,7 +285,7 @@ export async function resolveDefaultAgentId(_serverUrl, storeId, getToken) {
286
285
  } = await import("@supabase/supabase-js");
287
286
  const token = await getToken();
288
287
  if (!token) return null;
289
- const supabaseUrl = process.env.SUPABASE_URL || config.supabase_url || DEFAULT_SUPABASE_URL;
288
+ const supabaseUrl = process.env.SUPABASE_URL || DEFAULT_SUPABASE_URL;
290
289
  const anonKey = process.env.SUPABASE_ANON_KEY || DEFAULT_SUPABASE_ANON_KEY;
291
290
  const supabase = createClient(supabaseUrl, anonKey, {
292
291
  global: {