@tenex-chat/backend 0.9.1
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.
- package/README.md +194 -0
- package/dist/backend-wrapper.cjs +3 -0
- package/dist/src/index.js +331928 -0
- package/package.json +103 -0
- package/src/agents/AgentRegistry.ts +418 -0
- package/src/agents/AgentStorage.ts +1133 -0
- package/src/agents/ConfigResolver.ts +229 -0
- package/src/agents/agent-installer.ts +236 -0
- package/src/agents/agent-loader.ts +241 -0
- package/src/agents/constants.ts +82 -0
- package/src/agents/errors.ts +48 -0
- package/src/agents/execution/AgentExecutor.ts +561 -0
- package/src/agents/execution/ExecutionContextFactory.ts +112 -0
- package/src/agents/execution/MessageCompiler.ts +597 -0
- package/src/agents/execution/MessageSyncer.ts +100 -0
- package/src/agents/execution/PostCompletionChecker.ts +278 -0
- package/src/agents/execution/ProgressMonitor.ts +50 -0
- package/src/agents/execution/RALResolver.ts +177 -0
- package/src/agents/execution/SessionManager.ts +181 -0
- package/src/agents/execution/StreamCallbacks.ts +312 -0
- package/src/agents/execution/StreamExecutionHandler.ts +579 -0
- package/src/agents/execution/StreamSetup.ts +313 -0
- package/src/agents/execution/ToolEventHandlers.ts +239 -0
- package/src/agents/execution/ToolExecutionTracker.ts +498 -0
- package/src/agents/execution/ToolResultUtils.ts +97 -0
- package/src/agents/execution/ToolSupervisionWrapper.ts +174 -0
- package/src/agents/execution/constants.ts +16 -0
- package/src/agents/execution/index.ts +3 -0
- package/src/agents/execution/types.ts +96 -0
- package/src/agents/execution/utils.ts +26 -0
- package/src/agents/index.ts +4 -0
- package/src/agents/script-installer.ts +266 -0
- package/src/agents/supervision/SupervisorLLMService.ts +253 -0
- package/src/agents/supervision/SupervisorOrchestrator.ts +471 -0
- package/src/agents/supervision/heuristics/ConsecutiveToolsWithoutTodoHeuristic.ts +73 -0
- package/src/agents/supervision/heuristics/DelegationClaimHeuristic.ts +80 -0
- package/src/agents/supervision/heuristics/HeuristicRegistry.ts +114 -0
- package/src/agents/supervision/heuristics/PendingTodosHeuristic.ts +93 -0
- package/src/agents/supervision/heuristics/SilentAgentHeuristic.ts +54 -0
- package/src/agents/supervision/heuristics/index.ts +5 -0
- package/src/agents/supervision/index.ts +28 -0
- package/src/agents/supervision/registerHeuristics.ts +110 -0
- package/src/agents/supervision/supervisionHealthCheck.ts +123 -0
- package/src/agents/supervision/types.ts +171 -0
- package/src/agents/tool-names.ts +46 -0
- package/src/agents/tool-normalization.ts +184 -0
- package/src/agents/types/index.ts +2 -0
- package/src/agents/types/runtime.ts +74 -0
- package/src/agents/types/storage.ts +145 -0
- package/src/commands/agent/import/index.ts +6 -0
- package/src/commands/agent/import/openclaw-distiller.ts +57 -0
- package/src/commands/agent/import/openclaw-reader.ts +141 -0
- package/src/commands/agent/import/openclaw.ts +154 -0
- package/src/commands/agent/index.ts +6 -0
- package/src/commands/agent.ts +215 -0
- package/src/commands/daemon.ts +198 -0
- package/src/commands/doctor.ts +134 -0
- package/src/commands/setup/embed.ts +228 -0
- package/src/commands/setup/global-system-prompt.ts +223 -0
- package/src/commands/setup/image.ts +179 -0
- package/src/commands/setup/index.ts +16 -0
- package/src/commands/setup/interactive.ts +95 -0
- package/src/commands/setup/llm.ts +38 -0
- package/src/commands/setup/onboarding.ts +294 -0
- package/src/commands/setup/providers.ts +27 -0
- package/src/constants.ts +34 -0
- package/src/conversations/ConversationDiskReader.ts +148 -0
- package/src/conversations/ConversationRegistry.ts +728 -0
- package/src/conversations/ConversationStore.ts +868 -0
- package/src/conversations/MessageBuilder.ts +866 -0
- package/src/conversations/executionTime.ts +62 -0
- package/src/conversations/formatters/DelegationXmlFormatter.ts +64 -0
- package/src/conversations/formatters/ThreadedConversationFormatter.ts +303 -0
- package/src/conversations/formatters/index.ts +9 -0
- package/src/conversations/formatters/utils/MessageFormatter.ts +46 -0
- package/src/conversations/formatters/utils/TimestampFormatter.ts +56 -0
- package/src/conversations/formatters/utils/TreeBuilder.ts +131 -0
- package/src/conversations/formatters/utils/TreeRenderer.ts +49 -0
- package/src/conversations/index.ts +2 -0
- package/src/conversations/persistence/ToolMessageStorage.ts +143 -0
- package/src/conversations/search/ConversationIndexManager.ts +393 -0
- package/src/conversations/search/QueryParser.ts +114 -0
- package/src/conversations/search/SearchEngine.ts +175 -0
- package/src/conversations/search/SnippetExtractor.ts +345 -0
- package/src/conversations/search/embeddings/ConversationEmbeddingService.ts +484 -0
- package/src/conversations/search/embeddings/ConversationIndexingJob.ts +320 -0
- package/src/conversations/search/embeddings/IndexingStateManager.ts +338 -0
- package/src/conversations/search/embeddings/index.ts +18 -0
- package/src/conversations/search/index.ts +49 -0
- package/src/conversations/search/types.ts +124 -0
- package/src/conversations/services/CategoryManager.ts +160 -0
- package/src/conversations/services/ConversationResolver.ts +296 -0
- package/src/conversations/services/ConversationSummarizer.ts +234 -0
- package/src/conversations/services/MetadataDebounceManager.ts +188 -0
- package/src/conversations/services/index.ts +2 -0
- package/src/conversations/types.ts +148 -0
- package/src/conversations/utils/content-utils.ts +69 -0
- package/src/conversations/utils/image-placeholder.ts +281 -0
- package/src/conversations/utils/image-url-utils.ts +171 -0
- package/src/conversations/utils/multimodal-content.ts +90 -0
- package/src/conversations/utils/tool-result-truncator.ts +159 -0
- package/src/daemon/Daemon.ts +1883 -0
- package/src/daemon/ProjectRuntime.ts +657 -0
- package/src/daemon/RestartState.ts +152 -0
- package/src/daemon/RuntimeLifecycle.ts +268 -0
- package/src/daemon/SubscriptionManager.ts +305 -0
- package/src/daemon/UnixSocketTransport.ts +318 -0
- package/src/daemon/filters/SubscriptionFilterBuilder.ts +119 -0
- package/src/daemon/index.ts +9 -0
- package/src/daemon/routing/DaemonRouter.ts +491 -0
- package/src/daemon/types.ts +150 -0
- package/src/daemon/utils/routing-log.ts +76 -0
- package/src/daemon/utils/telemetry.ts +173 -0
- package/src/event-handler/agentDeletion.ts +383 -0
- package/src/event-handler/index.ts +749 -0
- package/src/event-handler/newConversation.ts +165 -0
- package/src/event-handler/project.ts +166 -0
- package/src/event-handler/reply.ts +18 -0
- package/src/events/NDKAgentDefinition.ts +292 -0
- package/src/events/NDKAgentLesson.ts +106 -0
- package/src/events/NDKEventMetadata.ts +34 -0
- package/src/events/NDKMCPTool.ts +60 -0
- package/src/events/NDKProjectStatus.ts +384 -0
- package/src/events/index.ts +4 -0
- package/src/index.ts +126 -0
- package/src/lib/agent-home.ts +334 -0
- package/src/lib/error-formatter.ts +200 -0
- package/src/lib/fs/filesystem.ts +128 -0
- package/src/lib/fs/index.ts +1 -0
- package/src/lib/json-parser.ts +30 -0
- package/src/lib/string.ts +15 -0
- package/src/lib/time.ts +74 -0
- package/src/llm/ChunkHandler.ts +277 -0
- package/src/llm/FinishHandler.ts +250 -0
- package/src/llm/LLMConfigEditor.ts +154 -0
- package/src/llm/LLMServiceFactory.ts +230 -0
- package/src/llm/MessageProcessor.ts +90 -0
- package/src/llm/RecordingState.ts +37 -0
- package/src/llm/StreamPublisher.ts +40 -0
- package/src/llm/TracingUtils.ts +77 -0
- package/src/llm/chunk-validators.ts +57 -0
- package/src/llm/constants.ts +6 -0
- package/src/llm/index.ts +12 -0
- package/src/llm/meta/MetaModelResolver.ts +352 -0
- package/src/llm/meta/index.ts +11 -0
- package/src/llm/middleware/flight-recorder.ts +188 -0
- package/src/llm/providers/MockProvider.ts +332 -0
- package/src/llm/providers/agent/ClaudeCodeProvider.ts +343 -0
- package/src/llm/providers/agent/ClaudeCodeToolsAdapter.ts +203 -0
- package/src/llm/providers/agent/CodexAppServerProvider.ts +214 -0
- package/src/llm/providers/agent/CodexAppServerToolsAdapter.ts +91 -0
- package/src/llm/providers/agent/index.ts +10 -0
- package/src/llm/providers/base/AgentProvider.ts +107 -0
- package/src/llm/providers/base/BaseProvider.ts +114 -0
- package/src/llm/providers/base/StandardProvider.ts +38 -0
- package/src/llm/providers/base/index.ts +9 -0
- package/src/llm/providers/index.ts +106 -0
- package/src/llm/providers/key-manager.ts +238 -0
- package/src/llm/providers/ollama-models.ts +105 -0
- package/src/llm/providers/openrouter-models.ts +102 -0
- package/src/llm/providers/provider-ids.ts +18 -0
- package/src/llm/providers/registry/ProviderRegistry.ts +414 -0
- package/src/llm/providers/registry/index.ts +7 -0
- package/src/llm/providers/standard/AnthropicProvider.ts +71 -0
- package/src/llm/providers/standard/OllamaProvider.ts +59 -0
- package/src/llm/providers/standard/OpenAIProvider.ts +44 -0
- package/src/llm/providers/standard/OpenRouterProvider.ts +103 -0
- package/src/llm/providers/standard/index.ts +10 -0
- package/src/llm/providers/types.ts +194 -0
- package/src/llm/providers/usage-metadata.ts +78 -0
- package/src/llm/service.ts +713 -0
- package/src/llm/types.ts +167 -0
- package/src/llm/utils/ConfigurationManager.ts +650 -0
- package/src/llm/utils/ConfigurationTester.ts +229 -0
- package/src/llm/utils/ModelSelector.ts +212 -0
- package/src/llm/utils/ProviderConfigUI.ts +177 -0
- package/src/llm/utils/claudeCodePromptCompiler.ts +141 -0
- package/src/llm/utils/codex-models.ts +53 -0
- package/src/llm/utils/context-window-cache.ts +30 -0
- package/src/llm/utils/models-dev-cache.ts +267 -0
- package/src/llm/utils/provider-setup.ts +50 -0
- package/src/llm/utils/tool-errors.ts +78 -0
- package/src/llm/utils/usage.ts +74 -0
- package/src/logging/EventRoutingLogger.ts +205 -0
- package/src/nostr/AgentEventDecoder.ts +357 -0
- package/src/nostr/AgentEventEncoder.ts +677 -0
- package/src/nostr/AgentProfilePublisher.ts +657 -0
- package/src/nostr/AgentPublisher.ts +437 -0
- package/src/nostr/BlossomService.ts +226 -0
- package/src/nostr/InterventionPublisher.ts +132 -0
- package/src/nostr/TagExtractor.ts +228 -0
- package/src/nostr/collectEvents.ts +83 -0
- package/src/nostr/constants.ts +38 -0
- package/src/nostr/encryption.ts +26 -0
- package/src/nostr/index.ts +31 -0
- package/src/nostr/keys.ts +17 -0
- package/src/nostr/kinds.ts +37 -0
- package/src/nostr/ndkClient.ts +72 -0
- package/src/nostr/relays.ts +43 -0
- package/src/nostr/trace-context.ts +39 -0
- package/src/nostr/types.ts +227 -0
- package/src/nostr/utils.ts +84 -0
- package/src/prompts/core/FragmentRegistry.ts +30 -0
- package/src/prompts/core/PromptBuilder.ts +98 -0
- package/src/prompts/core/index.ts +3 -0
- package/src/prompts/core/types.ts +13 -0
- package/src/prompts/fragments/00-global-system-prompt.ts +44 -0
- package/src/prompts/fragments/01-agent-identity.ts +69 -0
- package/src/prompts/fragments/02-agent-home-directory.ts +114 -0
- package/src/prompts/fragments/03-system-reminders-explanation.ts +14 -0
- package/src/prompts/fragments/04-relay-configuration.ts +38 -0
- package/src/prompts/fragments/05-delegation-chain.ts +45 -0
- package/src/prompts/fragments/06-agent-todos.ts +74 -0
- package/src/prompts/fragments/06-todo-usage-guidance.ts +34 -0
- package/src/prompts/fragments/07-meta-project-context.ts +234 -0
- package/src/prompts/fragments/08-active-conversations.ts +382 -0
- package/src/prompts/fragments/09-recent-conversations.ts +153 -0
- package/src/prompts/fragments/10-referenced-article.ts +21 -0
- package/src/prompts/fragments/11-nudges.ts +134 -0
- package/src/prompts/fragments/12-skills.ts +127 -0
- package/src/prompts/fragments/13-available-nudges.ts +122 -0
- package/src/prompts/fragments/15-available-agents.ts +53 -0
- package/src/prompts/fragments/16-stay-in-your-lane.ts +41 -0
- package/src/prompts/fragments/17-todo-before-delegation.ts +39 -0
- package/src/prompts/fragments/20-voice-mode.ts +62 -0
- package/src/prompts/fragments/22-scheduled-tasks.ts +175 -0
- package/src/prompts/fragments/24-retrieved-lessons.ts +26 -0
- package/src/prompts/fragments/25-rag-instructions.ts +333 -0
- package/src/prompts/fragments/26-mcp-resources.ts +237 -0
- package/src/prompts/fragments/27-memorized-reports.ts +77 -0
- package/src/prompts/fragments/28-agent-directed-monitoring.ts +32 -0
- package/src/prompts/fragments/29-rag-collections.ts +50 -0
- package/src/prompts/fragments/30-worktree-context.ts +98 -0
- package/src/prompts/fragments/31-agents-md-guidance.ts +96 -0
- package/src/prompts/fragments/32-process-metrics.ts +72 -0
- package/src/prompts/fragments/debug-mode.ts +48 -0
- package/src/prompts/fragments/delegation-completion.ts +44 -0
- package/src/prompts/fragments/index.ts +91 -0
- package/src/prompts/index.ts +21 -0
- package/src/prompts/utils/systemPromptBuilder.ts +777 -0
- package/src/scripts/migrate-prefix-index.ts +157 -0
- package/src/services/AgentDefinitionMonitor.ts +701 -0
- package/src/services/ConfigService.ts +723 -0
- package/src/services/CooldownRegistry.ts +199 -0
- package/src/services/LLMOperationsRegistry.ts +424 -0
- package/src/services/OwnerAgentListService.ts +354 -0
- package/src/services/PubkeyService.ts +308 -0
- package/src/services/agents/AgentMetadataStore.ts +72 -0
- package/src/services/agents/AgentResolution.ts +59 -0
- package/src/services/agents/EscalationService.ts +281 -0
- package/src/services/agents/NDKAgentDiscovery.ts +95 -0
- package/src/services/agents/index.ts +7 -0
- package/src/services/agents-md/AgentsMdService.ts +184 -0
- package/src/services/agents-md/SystemReminderInjector.ts +238 -0
- package/src/services/agents-md/index.ts +11 -0
- package/src/services/apns/APNsClient.ts +203 -0
- package/src/services/apns/APNsService.ts +358 -0
- package/src/services/apns/index.ts +11 -0
- package/src/services/apns/types.ts +80 -0
- package/src/services/compression/CompressionService.ts +445 -0
- package/src/services/compression/compression-schema.ts +28 -0
- package/src/services/compression/compression-types.ts +74 -0
- package/src/services/compression/compression-utils.ts +587 -0
- package/src/services/config/types.ts +394 -0
- package/src/services/dispatch/AgentDispatchService.ts +937 -0
- package/src/services/dispatch/AgentRouter.ts +181 -0
- package/src/services/dispatch/DelegationCompletionHandler.ts +232 -0
- package/src/services/embedding/EmbeddingProvider.ts +188 -0
- package/src/services/embedding/index.ts +5 -0
- package/src/services/event-context/EventContextService.ts +108 -0
- package/src/services/event-context/index.ts +2 -0
- package/src/services/heuristics/ContextBuilder.ts +106 -0
- package/src/services/heuristics/HeuristicEngine.ts +200 -0
- package/src/services/heuristics/formatters.ts +58 -0
- package/src/services/heuristics/index.ts +12 -0
- package/src/services/heuristics/rules/index.ts +25 -0
- package/src/services/heuristics/rules/todoBeforeDelegation.ts +69 -0
- package/src/services/heuristics/rules/todoReminderOnToolUse.ts +63 -0
- package/src/services/heuristics/types.ts +144 -0
- package/src/services/image/ImageGenerationService.ts +389 -0
- package/src/services/image/index.ts +12 -0
- package/src/services/intervention/InterventionService.ts +1352 -0
- package/src/services/intervention/index.ts +7 -0
- package/src/services/mcp/MCPManager.ts +683 -0
- package/src/services/mcp/McpNotificationDelivery.ts +139 -0
- package/src/services/mcp/McpSubscriptionService.ts +653 -0
- package/src/services/mcp/mcpInstaller.ts +130 -0
- package/src/services/nip46/Nip46SigningLog.ts +81 -0
- package/src/services/nip46/Nip46SigningService.ts +467 -0
- package/src/services/nip46/index.ts +4 -0
- package/src/services/nudge/NudgeService.ts +224 -0
- package/src/services/nudge/NudgeWhitelistService.ts +382 -0
- package/src/services/nudge/index.ts +5 -0
- package/src/services/nudge/types.ts +83 -0
- package/src/services/projects/ProjectContext.ts +672 -0
- package/src/services/projects/ProjectContextStore.ts +102 -0
- package/src/services/projects/index.ts +6 -0
- package/src/services/prompt-compiler/index.ts +15 -0
- package/src/services/prompt-compiler/prompt-compiler-service.ts +1143 -0
- package/src/services/pubkey-gate/PubkeyGateService.ts +93 -0
- package/src/services/pubkey-gate/index.ts +1 -0
- package/src/services/rag/EmbeddingProviderFactory.ts +292 -0
- package/src/services/rag/LanceDBMaintenanceService.ts +211 -0
- package/src/services/rag/RAGDatabaseService.ts +173 -0
- package/src/services/rag/RAGOperations.ts +682 -0
- package/src/services/rag/RAGService.ts +240 -0
- package/src/services/rag/RagSubscriptionService.ts +618 -0
- package/src/services/rag/rag-utils.ts +174 -0
- package/src/services/ral/PendingDelegationsRegistry.ts +168 -0
- package/src/services/ral/RALRegistry.ts +2782 -0
- package/src/services/ral/index.ts +4 -0
- package/src/services/ral/types.ts +292 -0
- package/src/services/reports/LocalReportStore.ts +380 -0
- package/src/services/reports/ReportEmbeddingService.ts +430 -0
- package/src/services/reports/ReportService.ts +440 -0
- package/src/services/reports/articleUtils.ts +52 -0
- package/src/services/reports/index.ts +7 -0
- package/src/services/scheduling/SchedulerService.ts +1057 -0
- package/src/services/scheduling/errors.ts +14 -0
- package/src/services/scheduling/index.ts +7 -0
- package/src/services/scheduling/utils.ts +77 -0
- package/src/services/search/SearchProviderRegistry.ts +78 -0
- package/src/services/search/UnifiedSearchService.ts +218 -0
- package/src/services/search/index.ts +47 -0
- package/src/services/search/projectFilter.ts +22 -0
- package/src/services/search/providers/ConversationSearchProvider.ts +48 -0
- package/src/services/search/providers/LessonSearchProvider.ts +75 -0
- package/src/services/search/providers/ReportSearchProvider.ts +49 -0
- package/src/services/search/types.ts +144 -0
- package/src/services/skill/SkillService.ts +482 -0
- package/src/services/skill/index.ts +2 -0
- package/src/services/skill/types.ts +70 -0
- package/src/services/status/OperationsStatusService.ts +276 -0
- package/src/services/status/ProjectStatusService.ts +522 -0
- package/src/services/status/index.ts +11 -0
- package/src/services/storage/PrefixKVStore.ts +242 -0
- package/src/services/storage/index.ts +1 -0
- package/src/services/system-reminder/SystemReminderUtils.ts +96 -0
- package/src/services/system-reminder/index.ts +7 -0
- package/src/services/trust-pubkeys/TrustPubkeyService.ts +325 -0
- package/src/services/trust-pubkeys/index.ts +2 -0
- package/src/telemetry/ConversationSpanManager.ts +111 -0
- package/src/telemetry/EventLoopMonitor.ts +206 -0
- package/src/telemetry/LLMSpanRegistry.ts +20 -0
- package/src/telemetry/NostrSpanProcessor.ts +89 -0
- package/src/telemetry/ToolCallSpanProcessor.ts +66 -0
- package/src/telemetry/diagnostics.ts +27 -0
- package/src/telemetry/setup.ts +120 -0
- package/src/tools/implementations/agents_discover.ts +121 -0
- package/src/tools/implementations/agents_hire.ts +127 -0
- package/src/tools/implementations/agents_list.ts +96 -0
- package/src/tools/implementations/agents_publish.ts +611 -0
- package/src/tools/implementations/agents_read.ts +173 -0
- package/src/tools/implementations/agents_write.ts +200 -0
- package/src/tools/implementations/ask.ts +411 -0
- package/src/tools/implementations/change_model.ts +141 -0
- package/src/tools/implementations/conversation_get.ts +661 -0
- package/src/tools/implementations/conversation_list.ts +377 -0
- package/src/tools/implementations/conversation_search.ts +370 -0
- package/src/tools/implementations/delegate.ts +327 -0
- package/src/tools/implementations/delegate_crossproject.ts +209 -0
- package/src/tools/implementations/delegate_followup.ts +300 -0
- package/src/tools/implementations/fs_edit.ts +162 -0
- package/src/tools/implementations/fs_glob.ts +182 -0
- package/src/tools/implementations/fs_grep.ts +513 -0
- package/src/tools/implementations/fs_read.ts +332 -0
- package/src/tools/implementations/fs_write.ts +113 -0
- package/src/tools/implementations/generate_image.ts +259 -0
- package/src/tools/implementations/home_fs.ts +515 -0
- package/src/tools/implementations/kill.ts +651 -0
- package/src/tools/implementations/learn.ts +166 -0
- package/src/tools/implementations/lesson-formatter.ts +38 -0
- package/src/tools/implementations/lesson_delete.ts +164 -0
- package/src/tools/implementations/lesson_get.ts +105 -0
- package/src/tools/implementations/lessons_list.ts +153 -0
- package/src/tools/implementations/mcp_resource_read.ts +161 -0
- package/src/tools/implementations/mcp_subscribe.ts +158 -0
- package/src/tools/implementations/mcp_subscription_stop.ts +85 -0
- package/src/tools/implementations/nostr_fetch.ts +149 -0
- package/src/tools/implementations/nostr_publish_as_user.ts +353 -0
- package/src/tools/implementations/project_list.ts +146 -0
- package/src/tools/implementations/rag_add_documents.ts +573 -0
- package/src/tools/implementations/rag_create_collection.ts +65 -0
- package/src/tools/implementations/rag_delete_collection.ts +68 -0
- package/src/tools/implementations/rag_list_collections.ts +77 -0
- package/src/tools/implementations/rag_query.ts +107 -0
- package/src/tools/implementations/rag_subscription_create.ts +105 -0
- package/src/tools/implementations/rag_subscription_delete.ts +80 -0
- package/src/tools/implementations/rag_subscription_get.ts +123 -0
- package/src/tools/implementations/rag_subscription_list.ts +128 -0
- package/src/tools/implementations/report_delete.ts +79 -0
- package/src/tools/implementations/report_read.ts +160 -0
- package/src/tools/implementations/report_write.ts +278 -0
- package/src/tools/implementations/reports_list.ts +77 -0
- package/src/tools/implementations/schedule_task.ts +104 -0
- package/src/tools/implementations/schedule_task_cancel.ts +62 -0
- package/src/tools/implementations/schedule_task_once.ts +128 -0
- package/src/tools/implementations/schedule_tasks_list.ts +79 -0
- package/src/tools/implementations/search.ts +160 -0
- package/src/tools/implementations/shell.ts +553 -0
- package/src/tools/implementations/todo.ts +260 -0
- package/src/tools/implementations/upload_blob.ts +381 -0
- package/src/tools/implementations/web_fetch.ts +153 -0
- package/src/tools/implementations/web_search.ts +250 -0
- package/src/tools/registry.ts +670 -0
- package/src/tools/types.ts +177 -0
- package/src/tools/utils.ts +256 -0
- package/src/types/event-ids.ts +320 -0
- package/src/types/index.ts +46 -0
- package/src/utils/agentFetcher.ts +107 -0
- package/src/utils/cli-error.ts +29 -0
- package/src/utils/conversation-id.ts +27 -0
- package/src/utils/conversation-utils.ts +1 -0
- package/src/utils/delegation-chain.ts +357 -0
- package/src/utils/error-handler.ts +42 -0
- package/src/utils/git/gitignore.ts +69 -0
- package/src/utils/git/index.ts +2 -0
- package/src/utils/git/initializeGitRepo.ts +204 -0
- package/src/utils/git/worktree.ts +260 -0
- package/src/utils/lessonFormatter.ts +70 -0
- package/src/utils/lessonTrust.ts +24 -0
- package/src/utils/lockfile.ts +123 -0
- package/src/utils/logger.ts +149 -0
- package/src/utils/nostr-entity-parser.ts +365 -0
- package/src/utils/process.ts +49 -0
- package/src/wrapper.ts +262 -0
- package/tsconfig.json +41 -0
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import type { AgentInstance } from "@/agents/types";
|
|
2
|
+
import { logger } from "@/utils/logger";
|
|
3
|
+
import type { NDKEvent } from "@nostr-dev-kit/ndk";
|
|
4
|
+
|
|
5
|
+
export type EventFilter = (event: NDKEvent) => boolean;
|
|
6
|
+
|
|
7
|
+
export interface SessionData {
|
|
8
|
+
sessionId?: string;
|
|
9
|
+
lastSentEventId?: string;
|
|
10
|
+
lastSentMessageIndex?: number;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Manages session state for agent execution, including session resumption
|
|
15
|
+
* and event filtering for providers that support it (like Claude Code)
|
|
16
|
+
*/
|
|
17
|
+
export class SessionManager {
|
|
18
|
+
private sessionId?: string;
|
|
19
|
+
private lastSentEventId?: string;
|
|
20
|
+
private lastSentMessageIndex?: number;
|
|
21
|
+
private storedWorkingDirectory?: string;
|
|
22
|
+
|
|
23
|
+
constructor(
|
|
24
|
+
private agent: AgentInstance,
|
|
25
|
+
private conversationId: string,
|
|
26
|
+
private workingDirectory: string
|
|
27
|
+
) {
|
|
28
|
+
this.loadSession();
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Load session data from metadata store.
|
|
33
|
+
* Only loads sessionId if the stored workingDirectory matches current one.
|
|
34
|
+
* This prevents resuming sessions created in a different worktree/branch.
|
|
35
|
+
*/
|
|
36
|
+
private loadSession(): void {
|
|
37
|
+
const metadataStore = this.agent.createMetadataStore(this.conversationId);
|
|
38
|
+
const storedSessionId = metadataStore.get<string>("sessionId");
|
|
39
|
+
this.storedWorkingDirectory = metadataStore.get<string>("workingDirectory");
|
|
40
|
+
this.lastSentEventId = metadataStore.get<string>("lastSentEventId");
|
|
41
|
+
this.lastSentMessageIndex = metadataStore.get<number>("lastSentMessageIndex");
|
|
42
|
+
|
|
43
|
+
// Only resume session if workingDirectory matches
|
|
44
|
+
if (storedSessionId && this.storedWorkingDirectory === this.workingDirectory) {
|
|
45
|
+
this.sessionId = storedSessionId;
|
|
46
|
+
logger.info("[SessionManager] ✅ Found existing session to resume", {
|
|
47
|
+
sessionId: this.sessionId,
|
|
48
|
+
agent: this.agent.name,
|
|
49
|
+
conversationId: this.conversationId.substring(0, 8),
|
|
50
|
+
lastSentEventId: this.lastSentEventId || "NONE",
|
|
51
|
+
lastSentMessageIndex: this.lastSentMessageIndex ?? "NONE",
|
|
52
|
+
workingDirectory: this.workingDirectory,
|
|
53
|
+
});
|
|
54
|
+
} else if (storedSessionId) {
|
|
55
|
+
// Session exists but workingDirectory changed - don't resume
|
|
56
|
+
logger.info("[SessionManager] ⚠️ Session exists but workingDirectory changed, starting fresh", {
|
|
57
|
+
storedSessionId,
|
|
58
|
+
storedWorkingDirectory: this.storedWorkingDirectory,
|
|
59
|
+
currentWorkingDirectory: this.workingDirectory,
|
|
60
|
+
agent: this.agent.name,
|
|
61
|
+
conversationId: this.conversationId.substring(0, 8),
|
|
62
|
+
});
|
|
63
|
+
this.lastSentMessageIndex = undefined;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Get current session data
|
|
69
|
+
*/
|
|
70
|
+
getSession(): SessionData {
|
|
71
|
+
return {
|
|
72
|
+
sessionId: this.sessionId,
|
|
73
|
+
lastSentEventId: this.lastSentEventId,
|
|
74
|
+
lastSentMessageIndex: this.lastSentMessageIndex,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Store session ID, last sent event ID, and working directory
|
|
80
|
+
*/
|
|
81
|
+
saveSession(sessionId: string, lastSentEventId: string, lastSentMessageIndex?: number): void {
|
|
82
|
+
const metadataStore = this.agent.createMetadataStore(this.conversationId);
|
|
83
|
+
metadataStore.set("sessionId", sessionId);
|
|
84
|
+
metadataStore.set("lastSentEventId", lastSentEventId);
|
|
85
|
+
if (lastSentMessageIndex !== undefined) {
|
|
86
|
+
metadataStore.set("lastSentMessageIndex", lastSentMessageIndex);
|
|
87
|
+
}
|
|
88
|
+
metadataStore.set("workingDirectory", this.workingDirectory);
|
|
89
|
+
|
|
90
|
+
// Update local state
|
|
91
|
+
this.sessionId = sessionId;
|
|
92
|
+
this.lastSentEventId = lastSentEventId;
|
|
93
|
+
if (lastSentMessageIndex !== undefined) {
|
|
94
|
+
this.lastSentMessageIndex = lastSentMessageIndex;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
logger.info("[SessionManager] 💾 Stored session ID and last sent event", {
|
|
98
|
+
sessionId,
|
|
99
|
+
lastSentEventId: lastSentEventId.substring(0, 8),
|
|
100
|
+
lastSentMessageIndex: lastSentMessageIndex ?? "NONE",
|
|
101
|
+
agent: this.agent.name,
|
|
102
|
+
conversationId: this.conversationId.substring(0, 8),
|
|
103
|
+
workingDirectory: this.workingDirectory,
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* Store only the last sent event ID (for new sessions without a session ID yet)
|
|
109
|
+
*/
|
|
110
|
+
saveLastSentEventId(lastSentEventId: string): void {
|
|
111
|
+
const metadataStore = this.agent.createMetadataStore(this.conversationId);
|
|
112
|
+
metadataStore.set("lastSentEventId", lastSentEventId);
|
|
113
|
+
|
|
114
|
+
this.lastSentEventId = lastSentEventId;
|
|
115
|
+
|
|
116
|
+
logger.info("[SessionManager] 📝 Stored lastSentEventId", {
|
|
117
|
+
lastSentEventId: lastSentEventId.substring(0, 8),
|
|
118
|
+
agent: this.agent.name,
|
|
119
|
+
conversationId: this.conversationId.substring(0, 8),
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Store the last sent conversation message index
|
|
125
|
+
*/
|
|
126
|
+
saveLastSentMessageIndex(lastSentMessageIndex: number): void {
|
|
127
|
+
const metadataStore = this.agent.createMetadataStore(this.conversationId);
|
|
128
|
+
metadataStore.set("lastSentMessageIndex", lastSentMessageIndex);
|
|
129
|
+
|
|
130
|
+
this.lastSentMessageIndex = lastSentMessageIndex;
|
|
131
|
+
|
|
132
|
+
logger.info("[SessionManager] 📝 Stored lastSentMessageIndex", {
|
|
133
|
+
lastSentMessageIndex,
|
|
134
|
+
agent: this.agent.name,
|
|
135
|
+
conversationId: this.conversationId.substring(0, 8),
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Create an event filter for session resumption
|
|
141
|
+
* Filters out events before and including the last sent event
|
|
142
|
+
*/
|
|
143
|
+
createEventFilter(): EventFilter | undefined {
|
|
144
|
+
if (!this.sessionId || !this.lastSentEventId) {
|
|
145
|
+
return undefined;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
const lastSentEventId = this.lastSentEventId;
|
|
149
|
+
|
|
150
|
+
logger.info("[SessionManager] 📋 Created event filter for resumed session", {
|
|
151
|
+
lastSentEventId: lastSentEventId.substring(0, 8),
|
|
152
|
+
willFilterEvents: true,
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
let foundLastSent = false;
|
|
156
|
+
return (event: NDKEvent) => {
|
|
157
|
+
// Skip events until we find the last sent one
|
|
158
|
+
if (!foundLastSent) {
|
|
159
|
+
if (event.id === lastSentEventId) {
|
|
160
|
+
foundLastSent = true;
|
|
161
|
+
logger.debug("[SessionManager] 🎯 Found last sent event, excluding it", {
|
|
162
|
+
eventId: event.id.substring(0, 8),
|
|
163
|
+
content: event.content?.substring(0, 50),
|
|
164
|
+
});
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
logger.debug("[SessionManager] ⏭️ Skipping event (before last sent)", {
|
|
168
|
+
eventId: event.id.substring(0, 8),
|
|
169
|
+
content: event.content?.substring(0, 50),
|
|
170
|
+
lookingFor: lastSentEventId.substring(0, 8),
|
|
171
|
+
});
|
|
172
|
+
return false;
|
|
173
|
+
}
|
|
174
|
+
logger.debug("[SessionManager] ✅ Including event (after last sent)", {
|
|
175
|
+
eventId: event.id.substring(0, 8),
|
|
176
|
+
content: event.content?.substring(0, 50),
|
|
177
|
+
});
|
|
178
|
+
return true;
|
|
179
|
+
};
|
|
180
|
+
}
|
|
181
|
+
}
|
|
@@ -0,0 +1,312 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* StreamCallbacks - Callback factories for LLM streaming
|
|
3
|
+
*
|
|
4
|
+
* This module provides factory functions for creating the prepareStep and onStopCheck
|
|
5
|
+
* callbacks used during LLM streaming execution.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { formatAnyError } from "@/lib/error-formatter";
|
|
9
|
+
import { LLMService } from "@/llm/service";
|
|
10
|
+
import { llmServiceFactory } from "@/llm/LLMServiceFactory";
|
|
11
|
+
import { shortenConversationId } from "@/utils/conversation-id";
|
|
12
|
+
import { config as configService } from "@/services/ConfigService";
|
|
13
|
+
import { RALRegistry } from "@/services/ral";
|
|
14
|
+
import type { SkillData } from "@/services/skill";
|
|
15
|
+
import { logger } from "@/utils/logger";
|
|
16
|
+
import { SpanStatusCode, trace } from "@opentelemetry/api";
|
|
17
|
+
import type { LanguageModel, ModelMessage } from "ai";
|
|
18
|
+
|
|
19
|
+
const tracer = trace.getTracer("tenex.stream-callbacks");
|
|
20
|
+
import { MessageCompiler } from "./MessageCompiler";
|
|
21
|
+
import { MessageSyncer } from "./MessageSyncer";
|
|
22
|
+
import type { FullRuntimeContext, RALExecutionContext } from "./types";
|
|
23
|
+
import { getHeuristicEngine } from "@/services/heuristics";
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Step data passed to prepareStep callback
|
|
27
|
+
*/
|
|
28
|
+
export interface StepData {
|
|
29
|
+
messages: ModelMessage[];
|
|
30
|
+
stepNumber: number;
|
|
31
|
+
steps: Array<{
|
|
32
|
+
toolCalls: Array<{ toolName: string }>;
|
|
33
|
+
text: string;
|
|
34
|
+
reasoningText?: string;
|
|
35
|
+
usage?: { inputTokens?: number; outputTokens?: number };
|
|
36
|
+
providerMetadata?: {
|
|
37
|
+
openrouter?: {
|
|
38
|
+
usage?: {
|
|
39
|
+
promptTokens?: number;
|
|
40
|
+
completionTokens?: number;
|
|
41
|
+
totalTokens?: number;
|
|
42
|
+
cost?: number;
|
|
43
|
+
promptTokensDetails?: { cachedTokens?: number };
|
|
44
|
+
completionTokensDetails?: { reasoningTokens?: number };
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
}>;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Configuration for creating the prepareStep callback
|
|
53
|
+
*/
|
|
54
|
+
export interface PrepareStepConfig {
|
|
55
|
+
context: FullRuntimeContext;
|
|
56
|
+
llmService: { provider: string; updateUsageFromSteps: (steps: StepData["steps"]) => void };
|
|
57
|
+
messageCompiler: MessageCompiler;
|
|
58
|
+
ephemeralMessages: Array<{ role: "user" | "system"; content: string }>;
|
|
59
|
+
nudgeContent: string;
|
|
60
|
+
/** Concatenated skill content */
|
|
61
|
+
skillContent: string;
|
|
62
|
+
/** Individual skill data for system prompt rendering */
|
|
63
|
+
skills: SkillData[];
|
|
64
|
+
ralNumber: number;
|
|
65
|
+
execContext: RALExecutionContext;
|
|
66
|
+
executionSpan?: ReturnType<typeof trace.getActiveSpan>;
|
|
67
|
+
modelState: {
|
|
68
|
+
lastUsedVariant: string | undefined;
|
|
69
|
+
currentModel: LanguageModel | undefined;
|
|
70
|
+
setVariant: (variant: string | undefined) => void;
|
|
71
|
+
setModel: (model: LanguageModel | undefined) => void;
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Create the prepareStep callback for message rebuilding and dynamic model switching
|
|
77
|
+
*/
|
|
78
|
+
export function createPrepareStep(
|
|
79
|
+
config: PrepareStepConfig
|
|
80
|
+
): (step: StepData) => Promise<{ model?: LanguageModel; messages?: ModelMessage[] } | undefined> {
|
|
81
|
+
const {
|
|
82
|
+
context,
|
|
83
|
+
llmService,
|
|
84
|
+
messageCompiler,
|
|
85
|
+
ephemeralMessages,
|
|
86
|
+
nudgeContent,
|
|
87
|
+
skillContent,
|
|
88
|
+
skills,
|
|
89
|
+
ralNumber,
|
|
90
|
+
execContext,
|
|
91
|
+
executionSpan,
|
|
92
|
+
modelState,
|
|
93
|
+
} = config;
|
|
94
|
+
const conversationStore = context.conversationStore;
|
|
95
|
+
const ralRegistry = RALRegistry.getInstance();
|
|
96
|
+
const isMetaModel = configService.isMetaModelConfig(context.agent.llmConfig);
|
|
97
|
+
|
|
98
|
+
// Import project context lazily to avoid circular dependencies
|
|
99
|
+
let projectContextModulePromise: Promise<typeof import("@/services/projects")> | null = null;
|
|
100
|
+
const loadProjectContextModule = async (): Promise<typeof import("@/services/projects")> => {
|
|
101
|
+
if (!projectContextModulePromise) {
|
|
102
|
+
projectContextModulePromise = import("@/services/projects");
|
|
103
|
+
}
|
|
104
|
+
return projectContextModulePromise;
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
return async (step: StepData) => {
|
|
108
|
+
const { getProjectContext } = await loadProjectContextModule();
|
|
109
|
+
const projectContext = getProjectContext();
|
|
110
|
+
const conversation = context.getConversation();
|
|
111
|
+
if (!conversation) {
|
|
112
|
+
throw new Error("Conversation store unavailable during prepareStep");
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
return tracer.startActiveSpan("tenex.agent.prepare_step", async (span) => {
|
|
116
|
+
try {
|
|
117
|
+
span.setAttribute("ral.number", ralNumber);
|
|
118
|
+
span.setAttribute("agent.pubkey", context.agent.pubkey.substring(0, 8));
|
|
119
|
+
span.setAttribute("conversation.id", shortenConversationId(context.conversationId));
|
|
120
|
+
span.setAttribute("step.number", step.stepNumber);
|
|
121
|
+
|
|
122
|
+
// Pass steps to LLM service for usage tracking
|
|
123
|
+
llmService.updateUsageFromSteps(step.steps);
|
|
124
|
+
|
|
125
|
+
// Update execution context with latest messages
|
|
126
|
+
execContext.accumulatedMessages = step.messages;
|
|
127
|
+
|
|
128
|
+
// Sync any tool calls/results from AI SDK to ConversationStore
|
|
129
|
+
// (sub-span removed - parent prepare_step span is sufficient)
|
|
130
|
+
const syncer = new MessageSyncer(conversationStore, context.agent.pubkey, ralNumber);
|
|
131
|
+
syncer.syncFromSDK(step.messages);
|
|
132
|
+
|
|
133
|
+
// Process any new injections (sub-span removed - parent prepare_step span is sufficient)
|
|
134
|
+
const newInjections = ralRegistry.getAndConsumeInjections(
|
|
135
|
+
context.agent.pubkey,
|
|
136
|
+
context.conversationId,
|
|
137
|
+
ralNumber
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
const midStepEphemeralMessages: Array<{ role: "user" | "system"; content: string }> = [];
|
|
141
|
+
|
|
142
|
+
if (newInjections.length > 0) {
|
|
143
|
+
for (const injection of newInjections) {
|
|
144
|
+
if (injection.ephemeral) {
|
|
145
|
+
midStepEphemeralMessages.push({
|
|
146
|
+
role: injection.role,
|
|
147
|
+
content: injection.content,
|
|
148
|
+
});
|
|
149
|
+
} else {
|
|
150
|
+
conversationStore.addMessage({
|
|
151
|
+
pubkey: context.triggeringEvent.pubkey,
|
|
152
|
+
ral: ralNumber,
|
|
153
|
+
content: injection.content,
|
|
154
|
+
messageType: "text",
|
|
155
|
+
targetedPubkeys: [context.agent.pubkey],
|
|
156
|
+
senderPubkey: injection.senderPubkey,
|
|
157
|
+
eventId: injection.eventId,
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
executionSpan?.addEvent("ral_injection.process", {
|
|
163
|
+
"injection.message_count": newInjections.length,
|
|
164
|
+
"injection.ephemeral_count": midStepEphemeralMessages.length,
|
|
165
|
+
"ral.number": ralNumber,
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
// === HEURISTIC VIOLATIONS INJECTION ===
|
|
170
|
+
// Inject pending heuristic violations as ephemeral system messages
|
|
171
|
+
const heuristicViolations = ralRegistry.getAndConsumeHeuristicViolations(
|
|
172
|
+
context.agent.pubkey,
|
|
173
|
+
context.conversationId,
|
|
174
|
+
ralNumber
|
|
175
|
+
);
|
|
176
|
+
|
|
177
|
+
if (heuristicViolations.length > 0) {
|
|
178
|
+
const heuristicEngine = getHeuristicEngine();
|
|
179
|
+
const warningMessage = heuristicEngine.formatForInjection(heuristicViolations);
|
|
180
|
+
|
|
181
|
+
if (warningMessage) {
|
|
182
|
+
// Add as ephemeral system message (not persisted, just for this LLM step)
|
|
183
|
+
midStepEphemeralMessages.push({
|
|
184
|
+
role: "system",
|
|
185
|
+
content: warningMessage,
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
executionSpan?.addEvent("heuristic.violations_injected", {
|
|
189
|
+
"ral.number": ralNumber,
|
|
190
|
+
"violation.count": heuristicViolations.length,
|
|
191
|
+
"violation.ids": heuristicViolations.map((v) => v.id).join(","),
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
logger.info("[StreamCallbacks] Injected heuristic violations", {
|
|
195
|
+
agent: context.agent.slug,
|
|
196
|
+
ralNumber,
|
|
197
|
+
violationCount: heuristicViolations.length,
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
const pendingDelegations = ralRegistry.getConversationPendingDelegations(
|
|
203
|
+
context.agent.pubkey,
|
|
204
|
+
context.conversationId,
|
|
205
|
+
ralNumber
|
|
206
|
+
);
|
|
207
|
+
const completedDelegations = ralRegistry.getConversationCompletedDelegations(
|
|
208
|
+
context.agent.pubkey,
|
|
209
|
+
context.conversationId,
|
|
210
|
+
ralNumber
|
|
211
|
+
);
|
|
212
|
+
|
|
213
|
+
// Compile messages (sub-span removed - MessageCompiler.compile has its own span)
|
|
214
|
+
const { messages: rebuiltMessages, mode } = await messageCompiler.compile({
|
|
215
|
+
agent: context.agent,
|
|
216
|
+
project: projectContext.project,
|
|
217
|
+
conversation,
|
|
218
|
+
projectBasePath: context.projectBasePath,
|
|
219
|
+
workingDirectory: context.workingDirectory,
|
|
220
|
+
currentBranch: context.currentBranch,
|
|
221
|
+
availableAgents: Array.from(projectContext.agents.values()),
|
|
222
|
+
mcpManager: projectContext.mcpManager,
|
|
223
|
+
agentLessons: projectContext.agentLessons,
|
|
224
|
+
nudgeContent,
|
|
225
|
+
skillContent,
|
|
226
|
+
skills,
|
|
227
|
+
respondingToPubkey: context.triggeringEvent.pubkey,
|
|
228
|
+
pendingDelegations,
|
|
229
|
+
completedDelegations,
|
|
230
|
+
ralNumber,
|
|
231
|
+
ephemeralMessages:
|
|
232
|
+
[...ephemeralMessages, ...midStepEphemeralMessages].length > 0
|
|
233
|
+
? [...ephemeralMessages, ...midStepEphemeralMessages]
|
|
234
|
+
: undefined,
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
span.setAttribute("compilation.mode", mode);
|
|
238
|
+
span.setAttribute("compiled.message_count", rebuiltMessages.length);
|
|
239
|
+
|
|
240
|
+
// For delta mode with no new messages, keep original
|
|
241
|
+
if (mode === "delta" && rebuiltMessages.length === 0) {
|
|
242
|
+
logger.debug("[StreamCallbacks] prepareStep: delta mode with no new messages, keeping original");
|
|
243
|
+
return undefined;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
// Dynamic model switching
|
|
247
|
+
if (isMetaModel) {
|
|
248
|
+
const currentVariant = conversationStore.getMetaModelVariantOverride(context.agent.pubkey);
|
|
249
|
+
|
|
250
|
+
if (currentVariant !== modelState.lastUsedVariant) {
|
|
251
|
+
const resolution = configService.resolveMetaModel(
|
|
252
|
+
context.agent.llmConfig,
|
|
253
|
+
undefined,
|
|
254
|
+
currentVariant
|
|
255
|
+
);
|
|
256
|
+
|
|
257
|
+
if (resolution.isMetaModel) {
|
|
258
|
+
const newLlmConfig = configService.getLLMConfig(resolution.configName);
|
|
259
|
+
|
|
260
|
+
try {
|
|
261
|
+
const registry = llmServiceFactory.getRegistry();
|
|
262
|
+
const newModel = LLMService.createLanguageModelFromRegistry(
|
|
263
|
+
newLlmConfig.provider,
|
|
264
|
+
newLlmConfig.model,
|
|
265
|
+
registry
|
|
266
|
+
);
|
|
267
|
+
|
|
268
|
+
const previousVariant = modelState.lastUsedVariant;
|
|
269
|
+
|
|
270
|
+
executionSpan?.addEvent("executor.model_switched", {
|
|
271
|
+
"ral.number": ralNumber,
|
|
272
|
+
"meta_model.previous_variant": previousVariant || "default",
|
|
273
|
+
"meta_model.new_variant": currentVariant || "default",
|
|
274
|
+
"meta_model.new_config": resolution.configName,
|
|
275
|
+
"meta_model.new_provider": newLlmConfig.provider,
|
|
276
|
+
"meta_model.new_model": newLlmConfig.model,
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
logger.info("[StreamCallbacks] Dynamic model switch via change_model tool", {
|
|
280
|
+
agent: context.agent.slug,
|
|
281
|
+
previousVariant: previousVariant || "default",
|
|
282
|
+
newVariant: currentVariant || "default",
|
|
283
|
+
newConfig: resolution.configName,
|
|
284
|
+
});
|
|
285
|
+
|
|
286
|
+
modelState.setVariant(currentVariant);
|
|
287
|
+
modelState.setModel(newModel);
|
|
288
|
+
} catch (modelError) {
|
|
289
|
+
logger.error("[StreamCallbacks] Failed to create new model for variant switch", {
|
|
290
|
+
error: formatAnyError(modelError),
|
|
291
|
+
variant: currentVariant,
|
|
292
|
+
config: resolution.configName,
|
|
293
|
+
});
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
return modelState.currentModel
|
|
300
|
+
? { model: modelState.currentModel, messages: rebuiltMessages }
|
|
301
|
+
: { messages: rebuiltMessages };
|
|
302
|
+
} catch (error) {
|
|
303
|
+
span.recordException(error as Error);
|
|
304
|
+
span.setStatus({ code: SpanStatusCode.ERROR });
|
|
305
|
+
throw error;
|
|
306
|
+
} finally {
|
|
307
|
+
span.end();
|
|
308
|
+
}
|
|
309
|
+
});
|
|
310
|
+
};
|
|
311
|
+
}
|
|
312
|
+
|