@within-7/minto 0.4.1 → 0.4.2
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/dist/Tool.js +7 -0
- package/dist/Tool.js.map +2 -2
- package/dist/commands/agents/AgentsCommand.js +1 -1
- package/dist/commands/agents/AgentsCommand.js.map +2 -2
- package/dist/commands/agents/constants.js +2 -2
- package/dist/commands/agents/constants.js.map +2 -2
- package/dist/commands/clear.js +4 -3
- package/dist/commands/clear.js.map +2 -2
- package/dist/commands/compact.js +2 -2
- package/dist/commands/compact.js.map +1 -1
- package/dist/commands/context.js +3 -1
- package/dist/commands/context.js.map +2 -2
- package/dist/commands/login.js +128 -0
- package/dist/commands/login.js.map +7 -0
- package/dist/commands/memory.js +33 -82
- package/dist/commands/memory.js.map +2 -2
- package/dist/commands/quit.js +3 -1
- package/dist/commands/quit.js.map +2 -2
- package/dist/commands/resume.js +39 -239
- package/dist/commands/resume.js.map +2 -2
- package/dist/commands/tasks.js +1 -1
- package/dist/commands/tasks.js.map +2 -2
- package/dist/commands/terminalSetup.js +6 -2
- package/dist/commands/terminalSetup.js.map +2 -2
- package/dist/commands.js +2 -0
- package/dist/commands.js.map +2 -2
- package/dist/components/AgentDetailView.js +126 -0
- package/dist/components/AgentDetailView.js.map +7 -0
- package/dist/components/AgentThinkingBlock.js +1 -1
- package/dist/components/AgentThinkingBlock.js.map +2 -2
- package/dist/components/AgentViewBanner.js +22 -0
- package/dist/components/AgentViewBanner.js.map +7 -0
- package/dist/components/HeaderBar.js +1 -1
- package/dist/components/HeaderBar.js.map +2 -2
- package/dist/components/Help.js +8 -1
- package/dist/components/Help.js.map +2 -2
- package/dist/components/HotkeyHelpPanel.js +26 -8
- package/dist/components/HotkeyHelpPanel.js.map +2 -2
- package/dist/components/IdleNotificationBar.js +10 -0
- package/dist/components/IdleNotificationBar.js.map +7 -0
- package/dist/components/ModelSelector/ModelSelector.js +55 -20
- package/dist/components/ModelSelector/ModelSelector.js.map +2 -2
- package/dist/components/PromptInput.js +186 -115
- package/dist/components/PromptInput.js.map +2 -2
- package/dist/components/RewindPanel.js +272 -0
- package/dist/components/RewindPanel.js.map +7 -0
- package/dist/components/Spinner.js +10 -21
- package/dist/components/Spinner.js.map +2 -2
- package/dist/components/StreamingTextPreview.js +29 -0
- package/dist/components/StreamingTextPreview.js.map +7 -0
- package/dist/components/SubagentBlock.js +3 -2
- package/dist/components/SubagentBlock.js.map +2 -2
- package/dist/components/SubagentProgress.js +4 -4
- package/dist/components/SubagentProgress.js.map +2 -2
- package/dist/components/TabbedListView/SearchInput.js +1 -1
- package/dist/components/TabbedListView/SearchInput.js.map +2 -2
- package/dist/components/TabbedListView/TabbedListView.js +87 -41
- package/dist/components/TabbedListView/TabbedListView.js.map +2 -2
- package/dist/components/TaskCard.js +4 -4
- package/dist/components/TaskCard.js.map +2 -2
- package/dist/components/TeamMemberPanel.js +107 -0
- package/dist/components/TeamMemberPanel.js.map +7 -0
- package/dist/components/ThinkingSelector.js +84 -0
- package/dist/components/ThinkingSelector.js.map +7 -0
- package/dist/components/TitledDivider.js +26 -0
- package/dist/components/TitledDivider.js.map +7 -0
- package/dist/components/TodoPanel.js +31 -30
- package/dist/components/TodoPanel.js.map +2 -2
- package/dist/components/TokenWarning.js +28 -7
- package/dist/components/TokenWarning.js.map +2 -2
- package/dist/components/messages/AssistantTextMessage.js +5 -2
- package/dist/components/messages/AssistantTextMessage.js.map +2 -2
- package/dist/components/messages/AssistantToolUseMessage.js +9 -1
- package/dist/components/messages/AssistantToolUseMessage.js.map +2 -2
- package/dist/components/messages/DefaultToolResultFallback.js +11 -0
- package/dist/components/messages/DefaultToolResultFallback.js.map +7 -0
- package/dist/components/messages/ParallelTasksGroupView.js +14 -6
- package/dist/components/messages/ParallelTasksGroupView.js.map +2 -2
- package/dist/components/messages/TaskInModuleView.js +27 -27
- package/dist/components/messages/TaskInModuleView.js.map +2 -2
- package/dist/components/messages/UserGuidanceMessage.js +26 -0
- package/dist/components/messages/UserGuidanceMessage.js.map +7 -0
- package/dist/components/messages/UserPromptMessage.js +2 -1
- package/dist/components/messages/UserPromptMessage.js.map +2 -2
- package/dist/components/messages/UserTeamNotificationMessage.js +91 -0
- package/dist/components/messages/UserTeamNotificationMessage.js.map +7 -0
- package/dist/components/messages/UserTextMessage.js +8 -0
- package/dist/components/messages/UserTextMessage.js.map +2 -2
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +4 -2
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +2 -2
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +18 -1
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +2 -2
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +12 -1
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +2 -2
- package/dist/components/permissions/PermissionRequest.js +4 -0
- package/dist/components/permissions/PermissionRequest.js.map +2 -2
- package/dist/components/permissions/PlanApprovalRequest.js +164 -0
- package/dist/components/permissions/PlanApprovalRequest.js.map +7 -0
- package/dist/constants/agentTeams.js +17 -0
- package/dist/constants/agentTeams.js.map +7 -0
- package/dist/constants/macros.js +2 -1
- package/dist/constants/macros.js.map +2 -2
- package/dist/constants/prompts/agentPrompt.js +1 -0
- package/dist/constants/prompts/agentPrompt.js.map +2 -2
- package/dist/constants/prompts/autoMemory.js +39 -0
- package/dist/constants/prompts/autoMemory.js.map +7 -0
- package/dist/constants/prompts/codeConventions.js +1 -13
- package/dist/constants/prompts/codeConventions.js.map +2 -2
- package/dist/constants/prompts/doingTasks.js +21 -2
- package/dist/constants/prompts/doingTasks.js.map +2 -2
- package/dist/constants/prompts/envInfo.js +6 -7
- package/dist/constants/prompts/envInfo.js.map +2 -2
- package/dist/constants/prompts/index.js +27 -5
- package/dist/constants/prompts/index.js.map +2 -2
- package/dist/constants/prompts/taskManagement.js +2 -43
- package/dist/constants/prompts/taskManagement.js.map +2 -2
- package/dist/constants/prompts/teamOverlays.js +50 -0
- package/dist/constants/prompts/teamOverlays.js.map +7 -0
- package/dist/constants/prompts/toneAndStyle.js +4 -29
- package/dist/constants/prompts/toneAndStyle.js.map +2 -2
- package/dist/constants/prompts/toolUsagePolicy.js +7 -22
- package/dist/constants/prompts/toolUsagePolicy.js.map +2 -2
- package/dist/constants/toolInputExamples.js +2 -2
- package/dist/constants/toolInputExamples.js.map +2 -2
- package/dist/context.js +39 -6
- package/dist/context.js.map +2 -2
- package/dist/core/backupManager.js +1 -1
- package/dist/core/backupManager.js.map +2 -2
- package/dist/core/permissions/rules/planModeRule.js +1 -1
- package/dist/core/permissions/rules/planModeRule.js.map +1 -1
- package/dist/core/permissions/rules/safeModeRule.js +1 -1
- package/dist/core/permissions/rules/safeModeRule.js.map +1 -1
- package/dist/engine/AgentEngine.js +902 -0
- package/dist/engine/AgentEngine.js.map +7 -0
- package/dist/engine/EngineRegistry.js +89 -0
- package/dist/engine/EngineRegistry.js.map +7 -0
- package/dist/engine/foregroundAdapter.js +191 -0
- package/dist/engine/foregroundAdapter.js.map +7 -0
- package/dist/engine/index.js +15 -0
- package/dist/engine/index.js.map +7 -0
- package/dist/engine/types.js +1 -0
- package/dist/engine/types.js.map +7 -0
- package/dist/entrypoints/cli.js +410 -79
- package/dist/entrypoints/cli.js.map +3 -3
- package/dist/hooks/useAgentEngine.js +129 -0
- package/dist/hooks/useAgentEngine.js.map +7 -0
- package/dist/hooks/useAgentTokenStats.js +0 -16
- package/dist/hooks/useAgentTokenStats.js.map +2 -2
- package/dist/hooks/useCanUseTool.js +47 -2
- package/dist/hooks/useCanUseTool.js.map +2 -2
- package/dist/hooks/useDeferredLoading.js +4 -1
- package/dist/hooks/useDeferredLoading.js.map +2 -2
- package/dist/hooks/useIdleNotifications.js +66 -0
- package/dist/hooks/useIdleNotifications.js.map +7 -0
- package/dist/hooks/useSessionTracking.js +9 -7
- package/dist/hooks/useSessionTracking.js.map +2 -2
- package/dist/hooks/useTeamMembers.js +51 -0
- package/dist/hooks/useTeamMembers.js.map +7 -0
- package/dist/i18n/locales/en.js +77 -12
- package/dist/i18n/locales/en.js.map +2 -2
- package/dist/i18n/locales/zh-CN.js +77 -12
- package/dist/i18n/locales/zh-CN.js.map +2 -2
- package/dist/i18n/types.js.map +1 -1
- package/dist/messages.js.map +2 -2
- package/dist/permissions.js +113 -7
- package/dist/permissions.js.map +2 -2
- package/dist/query.js +135 -37
- package/dist/query.js.map +2 -2
- package/dist/screens/REPL.js +504 -361
- package/dist/screens/REPL.js.map +3 -3
- package/dist/screens/ResumeConversation.js +199 -14
- package/dist/screens/ResumeConversation.js.map +2 -2
- package/dist/services/adapters/base.js.map +1 -1
- package/dist/services/agentTeams/backends/headless.js +108 -0
- package/dist/services/agentTeams/backends/headless.js.map +7 -0
- package/dist/services/agentTeams/backends/inProcess.js +102 -0
- package/dist/services/agentTeams/backends/inProcess.js.map +7 -0
- package/dist/services/agentTeams/backends/resolver.js +18 -0
- package/dist/services/agentTeams/backends/resolver.js.map +7 -0
- package/dist/services/agentTeams/backends/tmux.js +168 -0
- package/dist/services/agentTeams/backends/tmux.js.map +7 -0
- package/dist/services/agentTeams/backends/types.js +1 -0
- package/dist/services/agentTeams/backends/types.js.map +7 -0
- package/dist/services/agentTeams/heartbeat.js +88 -0
- package/dist/services/agentTeams/heartbeat.js.map +7 -0
- package/dist/services/agentTeams/index.js +42 -2
- package/dist/services/agentTeams/index.js.map +2 -2
- package/dist/services/agentTeams/injectionChannel.js +105 -0
- package/dist/services/agentTeams/injectionChannel.js.map +7 -0
- package/dist/services/agentTeams/mailbox.js +410 -30
- package/dist/services/agentTeams/mailbox.js.map +2 -2
- package/dist/services/agentTeams/messageFormatter.js +80 -0
- package/dist/services/agentTeams/messageFormatter.js.map +7 -0
- package/dist/services/agentTeams/permissionDelegation.js +71 -0
- package/dist/services/agentTeams/permissionDelegation.js.map +7 -0
- package/dist/services/agentTeams/teamEvents.js +45 -0
- package/dist/services/agentTeams/teamEvents.js.map +7 -0
- package/dist/services/agentTeams/teamManager.js +251 -34
- package/dist/services/agentTeams/teamManager.js.map +2 -2
- package/dist/services/agentTeams/teamTaskStore.js +290 -61
- package/dist/services/agentTeams/teamTaskStore.js.map +2 -2
- package/dist/services/agentTeams/teammateSpawner.js +99 -18
- package/dist/services/agentTeams/teammateSpawner.js.map +2 -2
- package/dist/services/hookExecutor.js +51 -8
- package/dist/services/hookExecutor.js.map +2 -2
- package/dist/services/llm/anthropicProvider.js +56 -59
- package/dist/services/llm/anthropicProvider.js.map +2 -2
- package/dist/services/llm/dispatch.js +24 -5
- package/dist/services/llm/dispatch.js.map +2 -2
- package/dist/services/llm/openaiProvider.js +115 -136
- package/dist/services/llm/openaiProvider.js.map +3 -3
- package/dist/services/llm/types.js +89 -15
- package/dist/services/llm/types.js.map +2 -2
- package/dist/services/mcpClient.js +80 -4
- package/dist/services/mcpClient.js.map +2 -2
- package/dist/services/mintoAuth.js +299 -0
- package/dist/services/mintoAuth.js.map +7 -0
- package/dist/services/oauth.js +3 -3
- package/dist/services/oauth.js.map +2 -2
- package/dist/services/openai.js +91 -20
- package/dist/services/openai.js.map +2 -2
- package/dist/services/plugins/pluginRuntime.js +11 -5
- package/dist/services/plugins/pluginRuntime.js.map +2 -2
- package/dist/services/plugins/pluginValidation.js +4 -2
- package/dist/services/plugins/pluginValidation.js.map +2 -2
- package/dist/services/sandbox/sandboxController.js +11 -3
- package/dist/services/sandbox/sandboxController.js.map +2 -2
- package/dist/services/sessionMemoryInjector.js +77 -0
- package/dist/services/sessionMemoryInjector.js.map +7 -0
- package/dist/services/systemReminder.js +130 -8
- package/dist/services/systemReminder.js.map +2 -2
- package/dist/services/taskStore.js +199 -8
- package/dist/services/taskStore.js.map +3 -3
- package/dist/services/topicDetector.js +169 -0
- package/dist/services/topicDetector.js.map +7 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +0 -13
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +2 -2
- package/dist/tools/BashTool/BashTool.js +51 -28
- package/dist/tools/BashTool/BashTool.js.map +2 -2
- package/dist/tools/BashTool/prompt.js +95 -118
- package/dist/tools/BashTool/prompt.js.map +2 -2
- package/dist/tools/BashTool/utils.js +39 -1
- package/dist/tools/BashTool/utils.js.map +2 -2
- package/dist/tools/EnterWorktreeTool/EnterWorktreeTool.js +121 -0
- package/dist/tools/EnterWorktreeTool/EnterWorktreeTool.js.map +7 -0
- package/dist/tools/EnterWorktreeTool/prompt.js +22 -0
- package/dist/tools/EnterWorktreeTool/prompt.js.map +7 -0
- package/dist/tools/FileEditTool/FileEditTool.js +9 -4
- package/dist/tools/FileEditTool/FileEditTool.js.map +2 -2
- package/dist/tools/FileEditTool/prompt.js +3 -7
- package/dist/tools/FileEditTool/prompt.js.map +2 -2
- package/dist/tools/FileReadTool/FileReadTool.js +125 -3
- package/dist/tools/FileReadTool/FileReadTool.js.map +2 -2
- package/dist/tools/FileReadTool/prompt.js +1 -2
- package/dist/tools/FileReadTool/prompt.js.map +2 -2
- package/dist/tools/FileWriteTool/prompt.js +3 -5
- package/dist/tools/FileWriteTool/prompt.js.map +2 -2
- package/dist/tools/GlobTool/GlobTool.js +3 -2
- package/dist/tools/GlobTool/GlobTool.js.map +2 -2
- package/dist/tools/GrepTool/GrepTool.js +16 -5
- package/dist/tools/GrepTool/GrepTool.js.map +2 -2
- package/dist/tools/ListMcpResourcesTool/ListMcpResourcesTool.js.map +2 -2
- package/dist/tools/MCPSearchTool/MCPSearchTool.js +172 -0
- package/dist/tools/MCPSearchTool/MCPSearchTool.js.map +7 -0
- package/dist/tools/MCPSearchTool/prompt.js +77 -0
- package/dist/tools/MCPSearchTool/prompt.js.map +7 -0
- package/dist/tools/MultiEditTool/prompt.js +4 -7
- package/dist/tools/MultiEditTool/prompt.js.map +2 -2
- package/dist/tools/PlanModeTool/EnterPlanModeTool.js +12 -8
- package/dist/tools/PlanModeTool/EnterPlanModeTool.js.map +2 -2
- package/dist/tools/PlanModeTool/ExitPlanModeTool.js +54 -1
- package/dist/tools/PlanModeTool/ExitPlanModeTool.js.map +2 -2
- package/dist/tools/PlanModeTool/prompt.js +23 -74
- package/dist/tools/PlanModeTool/prompt.js.map +2 -2
- package/dist/tools/SendMessageTool/SendMessageTool.js +341 -0
- package/dist/tools/SendMessageTool/SendMessageTool.js.map +7 -0
- package/dist/tools/SendMessageTool/prompt.js +44 -0
- package/dist/tools/SendMessageTool/prompt.js.map +7 -0
- package/dist/tools/TaskCreateTool/prompt.js +15 -4
- package/dist/tools/TaskCreateTool/prompt.js.map +2 -2
- package/dist/tools/TaskListTool/prompt.js +18 -3
- package/dist/tools/TaskListTool/prompt.js.map +2 -2
- package/dist/tools/TaskOutputTool/prompt.js +4 -3
- package/dist/tools/TaskOutputTool/prompt.js.map +2 -2
- package/dist/tools/TaskTool/TaskTool.js +762 -98
- package/dist/tools/TaskTool/TaskTool.js.map +3 -3
- package/dist/tools/TaskTool/constants.js +8 -2
- package/dist/tools/TaskTool/constants.js.map +2 -2
- package/dist/tools/TaskTool/prompt.js +74 -70
- package/dist/tools/TaskTool/prompt.js.map +2 -2
- package/dist/tools/TaskUpdateTool/TaskUpdateTool.js +15 -1
- package/dist/tools/TaskUpdateTool/TaskUpdateTool.js.map +2 -2
- package/dist/tools/TeamCreateTool/TeamCreateTool.js +129 -0
- package/dist/tools/TeamCreateTool/TeamCreateTool.js.map +7 -0
- package/dist/tools/TeamCreateTool/prompt.js +58 -0
- package/dist/tools/TeamCreateTool/prompt.js.map +7 -0
- package/dist/tools/TeamDeleteTool/TeamDeleteTool.js +151 -0
- package/dist/tools/TeamDeleteTool/TeamDeleteTool.js.map +7 -0
- package/dist/tools/TeamDeleteTool/prompt.js +16 -0
- package/dist/tools/TeamDeleteTool/prompt.js.map +7 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +106 -15
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +2 -2
- package/dist/tools/URLFetcherTool/prompt.js +3 -2
- package/dist/tools/URLFetcherTool/prompt.js.map +2 -2
- package/dist/tools/WebSearchTool/WebSearchTool.js +2 -1
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +2 -2
- package/dist/tools/WebSearchTool/prompt.js +5 -4
- package/dist/tools/WebSearchTool/prompt.js.map +2 -2
- package/dist/tools.js +100 -20
- package/dist/tools.js.map +2 -2
- package/dist/types/PermissionMode.js +35 -6
- package/dist/types/PermissionMode.js.map +2 -2
- package/dist/types/hooks.js +2 -0
- package/dist/types/hooks.js.map +2 -2
- package/dist/types/plugin.js +2 -0
- package/dist/types/plugin.js.map +3 -3
- package/dist/utils/CircuitBreaker.js +15 -9
- package/dist/utils/CircuitBreaker.js.map +2 -2
- package/dist/utils/agentLoader.js +249 -112
- package/dist/utils/agentLoader.js.map +2 -2
- package/dist/utils/animationManager.js +40 -3
- package/dist/utils/animationManager.js.map +2 -2
- package/dist/utils/ask.js +7 -6
- package/dist/utils/ask.js.map +2 -2
- package/dist/utils/atomicWrite.js +23 -0
- package/dist/utils/atomicWrite.js.map +7 -0
- package/dist/utils/autoCompactCore.js +73 -56
- package/dist/utils/autoCompactCore.js.map +2 -2
- package/dist/utils/autoMemoryPaths.js +89 -0
- package/dist/utils/autoMemoryPaths.js.map +7 -0
- package/dist/utils/config.js +63 -38
- package/dist/utils/config.js.map +2 -2
- package/dist/utils/configSchema.js +13 -8
- package/dist/utils/configSchema.js.map +2 -2
- package/dist/utils/credentials/index.js +14 -0
- package/dist/utils/credentials/index.js.map +2 -2
- package/dist/utils/dualPath.js +24 -0
- package/dist/utils/dualPath.js.map +7 -0
- package/dist/utils/exit.js +66 -7
- package/dist/utils/exit.js.map +2 -2
- package/dist/utils/externalEditor.js +155 -0
- package/dist/utils/externalEditor.js.map +7 -0
- package/dist/utils/fileLock.js +67 -0
- package/dist/utils/fileLock.js.map +7 -0
- package/dist/utils/format.js +24 -14
- package/dist/utils/format.js.map +2 -2
- package/dist/utils/globalErrorHandler.js +5 -96
- package/dist/utils/globalErrorHandler.js.map +3 -3
- package/dist/utils/groupHandlers/parallelTasksHandler.js +5 -3
- package/dist/utils/groupHandlers/parallelTasksHandler.js.map +2 -2
- package/dist/utils/groupHandlers/taskHandler.js +2 -2
- package/dist/utils/groupHandlers/taskHandler.js.map +2 -2
- package/dist/utils/hookManager.js +64 -6
- package/dist/utils/hookManager.js.map +2 -2
- package/dist/utils/log.js +6 -2
- package/dist/utils/log.js.map +2 -2
- package/dist/utils/markdown.js +237 -19
- package/dist/utils/markdown.js.map +2 -2
- package/dist/utils/messageContextManager.js +18 -5
- package/dist/utils/messageContextManager.js.map +2 -2
- package/dist/utils/messageGroupManager.js +1 -1
- package/dist/utils/messageGroupManager.js.map +2 -2
- package/dist/utils/messages.js +104 -46
- package/dist/utils/messages.js.map +2 -2
- package/dist/utils/model.js +2 -2
- package/dist/utils/model.js.map +2 -2
- package/dist/utils/pasteCache.js +8 -4
- package/dist/utils/pasteCache.js.map +2 -2
- package/dist/utils/pluginLoader.js +18 -0
- package/dist/utils/pluginLoader.js.map +2 -2
- package/dist/utils/secureKeyStorage.js +36 -7
- package/dist/utils/secureKeyStorage.js.map +2 -2
- package/dist/utils/simpleMode.js +7 -0
- package/dist/utils/simpleMode.js.map +7 -0
- package/dist/utils/streamingState.js +11 -1
- package/dist/utils/streamingState.js.map +2 -2
- package/dist/utils/taskDisplayUtils.js +2 -1
- package/dist/utils/taskDisplayUtils.js.map +2 -2
- package/dist/utils/teamConfig.js +2 -2
- package/dist/utils/teamConfig.js.map +2 -2
- package/dist/utils/thinking.js +6 -2
- package/dist/utils/thinking.js.map +3 -3
- package/dist/utils/tokenProgress.js +55 -0
- package/dist/utils/tokenProgress.js.map +7 -0
- package/dist/utils/toolRiskClassification.js +26 -17
- package/dist/utils/toolRiskClassification.js.map +2 -2
- package/dist/utils/tooling/toolError.js +12 -0
- package/dist/utils/tooling/toolError.js.map +7 -0
- package/dist/version.js +2 -2
- package/dist/version.js.map +1 -1
- package/package.json +10 -8
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/entrypoints/cli.tsx"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env -S node --no-warnings=ExperimentalWarning --enable-source-maps\n\n/**\n * Minto CLI Main Entry Point\n *\n * NOTE: This module is loaded via dynamic import from bootstrap.ts.\n * The following initializations are handled in bootstrap.ts BEFORE this loads:\n * - process.env.DEV = 'false' (prevents Ink devtools loading)\n * - EventEmitter.defaultMaxListeners = 20 (prevents listener warnings)\n * - YOGA_WASM_PATH (Ink layout engine WASM path)\n *\n * See bootstrap.ts for details on why these must happen before ESM imports.\n */\n\nimport { initSentry } from '@services/sentry'\nimport { PRODUCT_COMMAND, PRODUCT_NAME } from '@constants/product'\nimport { initGlobalErrorHandlers } from '@utils/globalErrorHandler'\n\ninitSentry() // Initialize Sentry as early as possible\ninitGlobalErrorHandlers() // Initialize global error handlers early\n\n// XXX: Without this line (and the Object.keys, even though it seems like it does nothing!),\n// there is a bug in Bun only on Win32 that causes this import to be removed, even though\n// its use is solely because of its side-effects.\nimport * as dontcare from '@anthropic-ai/sdk/shims/node'\nObject.keys(dontcare)\n\nimport React from 'react'\nimport { ReadStream } from 'tty'\nimport { existsSync, openSync } from 'fs'\n// ink and REPL are imported lazily to avoid top-level awaits during module init\nimport type { RenderOptions } from 'ink'\nimport { validateRawModeSupport, requireRawModeOrExit } from '@utils/ptyCompat'\nimport { addToHistory } from '@history'\nimport { getContext, setContext, removeContext } from '@context'\nimport { Command } from '@commander-js/extra-typings'\nimport { ask } from '@utils/ask'\nimport { hasPermissionsToUseTool } from '@permissions'\nimport { getBuiltInTools, getTools } from '@tools'\nimport {\n getGlobalConfig,\n getCurrentProjectConfig,\n saveGlobalConfig,\n saveCurrentProjectConfig,\n getCustomApiKeyStatus,\n normalizeApiKeyForConfig,\n setConfigForCLI,\n deleteConfigForCLI,\n getConfigForCLI,\n listConfigForCLI,\n enableConfigs,\n validateAndRepairAllGPT5Profiles,\n} from '@utils/config'\nimport { cwd } from 'process'\nimport { dateToFilename, logError, parseLogFilename } from '@utils/log'\nimport { initDebugLogger } from '@utils/debugLogger'\nimport { Onboarding } from '@components/Onboarding'\nimport { TrustDialog } from '@components/TrustDialog'\nimport {\n checkHasTrustDialogAccepted,\n McpServerConfig,\n type SafetyMode,\n} from '@utils/config'\nimport { isDefaultSlowAndCapableModel } from '@utils/model'\nimport { LogList } from '@screens/LogList'\nimport { ResumeConversation } from '@screens/ResumeConversation'\nimport { startMCPServer } from './mcp'\nimport { env } from '@utils/env'\nimport { getCwd, setCwd, setOriginalCwd } from '@utils/state'\nimport { omit } from 'lodash-es'\nimport { getBuiltInCommands, getCommands } from '@commands'\nimport { getNextAvailableLogForkNumber, loadLogList } from '@utils/log'\nimport { loadMessagesFromLog } from '@utils/conversationRecovery'\nimport { cleanupOldMessageFilesInBackground } from '@utils/cleanup'\nimport { runLogRotationInBackground, shouldRotate } from '@utils/logRotation'\nimport {\n handleListApprovedTools,\n handleRemoveApprovedTool,\n} from '@commands/approvedTools'\nimport {\n addMcpServer,\n getMcpServer,\n listMCPServers,\n parseEnvVars,\n removeMcpServer,\n getClients,\n ensureConfigScope,\n shutdownMCPClients,\n} from '@services/mcpClient'\nimport { handleMcprcServerApprovals } from '@services/mcpServerApproval'\nimport {\n fetchTeamConfig,\n loadTeamConfigFromFile,\n applyTeamConfig,\n addMarketplaces,\n installPlugins,\n installRemoteAgents,\n installInlineAgents,\n installTeamHooks,\n type MergeStrategy,\n} from '@utils/teamConfig'\n\nimport { cursorShow } from 'ansi-escapes'\nimport {\n getLatestVersion,\n assertMinVersion,\n getUpdateCommandSuggestions,\n} from '@utils/autoUpdater'\nimport { ensureConfigDirs } from '@utils/configPaths'\nimport { runStartupMigration } from '@utils/migration'\nimport {\n initI18n,\n setLanguage,\n isLanguageSupported,\n type Language,\n} from '@i18n'\nimport { CACHE_PATHS } from '@utils/log'\n// import { checkAndNotifyUpdate } from '@utils/autoUpdater'\nimport { PersistentShell, onShellCrash } from '@utils/PersistentShell'\nimport { clearTerminal, prepareTerminalForREPL } from '@utils/terminal'\nimport { formatTotalCost } from '@costTracker'\nimport { setupExitHandlers } from '@utils/exit'\nimport { showInvalidConfigDialog } from '@components/InvalidConfigDialog'\nimport { ConfigParseError } from '@utils/errors'\nimport { grantReadPermissionForOriginalDir } from '@utils/permissions/filesystem'\nimport { MACRO } from '@constants/macros'\nimport { SEMANTIC_COLORS } from '@constants/colors'\nimport {\n needsSync as needsCCSync,\n syncFromClaudeCode,\n hasClaudeCodeInstallation,\n getClaudeCodePluginCount,\n} from '@utils/claudeCodeSync'\nexport function completeOnboarding(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n hasCompletedOnboarding: true,\n lastOnboardingVersion: MACRO.VERSION,\n })\n}\n\nasync function showSetupScreens(\n safeMode?: boolean,\n print?: boolean,\n rawModeSupported?: boolean,\n): Promise<void> {\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n const config = getGlobalConfig()\n if (\n !config.theme ||\n !config.hasCompletedOnboarding // always show onboarding at least once\n ) {\n // \uD83D\uDD27 If raw mode is not supported, auto-skip onboarding with default config\n if (rawModeSupported === false) {\n console.log(\n '\u26A0\uFE0F Interactive onboarding is not supported in this terminal environment',\n )\n console.log('\u2728 Auto-configuring with default settings...')\n console.log('')\n\n // Apply default configuration\n saveGlobalConfig({\n ...config,\n theme: config.theme || 'dark', // Use dark theme as default\n hasCompletedOnboarding: true,\n lastOnboardingVersion: MACRO.VERSION,\n })\n\n console.log('\u2705 Configuration completed automatically')\n console.log(\n '\uD83D\uDCA1 You can customize settings later with: minto config set -g <key> <value>',\n )\n console.log('')\n return\n }\n\n await clearTerminal()\n const { render } = await import('ink')\n await new Promise<void>(resolve => {\n render(\n <Onboarding\n onDone={async () => {\n completeOnboarding()\n await clearTerminal()\n resolve()\n }}\n />,\n {\n exitOnCtrlC: false,\n },\n )\n })\n }\n\n // In non-interactive mode, only show trust dialog in safe mode\n if (!print && safeMode) {\n if (!checkHasTrustDialogAccepted()) {\n // \uD83D\uDD27 If raw mode is not supported, auto-accept trust dialog\n if (rawModeSupported === false) {\n console.log('\u2728 Auto-granting read permissions for safe mode...')\n grantReadPermissionForOriginalDir()\n console.log('\u2705 Permissions granted')\n console.log('')\n } else {\n await new Promise<void>(resolve => {\n const onDone = () => {\n // Grant read permission to the current working directory\n grantReadPermissionForOriginalDir()\n resolve()\n }\n ;(async () => {\n const { render } = await import('ink')\n render(<TrustDialog onDone={onDone} />, {\n exitOnCtrlC: false,\n })\n })()\n })\n }\n }\n\n // After trust dialog, check for any mcprc servers that need approval\n if (process.env.USER_TYPE === 'ant') {\n await handleMcprcServerApprovals()\n }\n }\n}\n\nfunction logStartup(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n numStartups: (config.numStartups ?? 0) + 1,\n })\n}\n\nasync function setup(cwd: string, safeMode?: boolean): Promise<void> {\n // Set both current and original working directory if --cwd was provided\n if (cwd !== process.cwd()) {\n setOriginalCwd(cwd)\n }\n await setCwd(cwd)\n\n // Always grant read permissions for original working dir\n grantReadPermissionForOriginalDir()\n\n // Start watching agent configuration files for changes\n // Try ESM-friendly path first (compiled dist), then fall back to extensionless (dev/tsx)\n let agentLoader: any\n try {\n agentLoader = await import('@utils/agentLoader')\n } catch {\n agentLoader = await import('@utils/agentLoader')\n }\n const { startAgentWatcher, clearAgentCache } = agentLoader\n await startAgentWatcher(() => {\n // Cache is already cleared in the watcher, just log\n console.log('\u2705 Agent configurations hot-reloaded')\n })\n\n // If --safe mode is enabled, prevent root/sudo usage for security\n if (safeMode) {\n // Check if running as root/sudo on Unix-like systems\n if (\n process.platform !== 'win32' &&\n typeof process.getuid === 'function' &&\n process.getuid() === 0\n ) {\n console.error(\n `--safe mode cannot be used with root/sudo privileges for security reasons`,\n )\n process.exit(1)\n }\n }\n\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n cleanupOldMessageFilesInBackground()\n\n // Run log rotation if needed (in background, non-blocking)\n if (shouldRotate()) {\n runLogRotationInBackground()\n }\n\n getContext() // Pre-fetch all context data at once\n\n // Migrate old iterm2KeyBindingInstalled config to new shiftEnterKeyBindingInstalled\n const globalConfig = getGlobalConfig()\n if (\n globalConfig.iterm2KeyBindingInstalled === true &&\n globalConfig.shiftEnterKeyBindingInstalled !== true\n ) {\n const updatedConfig = {\n ...globalConfig,\n shiftEnterKeyBindingInstalled: true,\n }\n // Remove the old config property\n delete updatedConfig.iterm2KeyBindingInstalled\n saveGlobalConfig(updatedConfig)\n }\n\n // Check for last session's cost and duration\n const projectConfig = getCurrentProjectConfig()\n if (\n projectConfig.lastCost !== undefined &&\n projectConfig.lastDuration !== undefined\n ) {\n // Clear the values after logging\n // saveCurrentProjectConfig({\n // ...projectConfig,\n // lastCost: undefined,\n // lastAPIDuration: undefined,\n // lastDuration: undefined,\n // lastSessionId: undefined,\n // })\n }\n\n // Claude Code \u2192 Minto plugin auto-sync (fire-and-forget to avoid blocking startup)\n try {\n const cfg = getGlobalConfig()\n if (hasClaudeCodeInstallation() && needsCCSync()) {\n const shouldSync =\n cfg.autoSyncClaudeCode === true || cfg.autoSyncClaudeCode === undefined\n if (shouldSync) {\n syncFromClaudeCode()\n .then(result => {\n const changed = result.installed.length + result.updated.length\n const mpRegistered = result.marketplaces.registered.length\n if (changed > 0 || mpRegistered > 0) {\n const parts = []\n if (changed > 0) {\n parts.push(\n `${changed} plugin(s) (${result.installed.length} new, ${result.updated.length} updated)`,\n )\n }\n if (mpRegistered > 0) {\n parts.push(`${mpRegistered} marketplace(s)`)\n }\n console.log(`Synced from Claude Code: ${parts.join(', ')}`)\n }\n if (cfg.autoSyncClaudeCode === undefined) {\n saveGlobalConfig({\n ...getGlobalConfig(),\n autoSyncClaudeCode: true,\n })\n }\n })\n .catch(() => {\n // Non-fatal: don't block startup if CC sync fails\n })\n }\n // autoSyncClaudeCode === false \u2192 skip\n }\n } catch {\n // Non-fatal: don't block startup if CC sync fails\n }\n\n // Skip interactive auto-updater permission prompts during startup\n // Users can still run the doctor command manually if desired.\n}\n\n// Global error handler for setRawMode failures (last line of defense)\nif (process.env.NODE_ENV !== 'test') {\n process.on('uncaughtException', (error: Error) => {\n // Only catch specific setRawMode/PTY errors to avoid masking other issues\n const isSetRawModeError =\n error.message?.includes('setRawMode') ||\n error.message?.includes('EIO') ||\n error.message?.includes('ENOTTY') ||\n (error as any).code === 'EIO' ||\n (error as any).code === 'ENOTTY'\n\n if (isSetRawModeError) {\n console.error('')\n console.error('\uD83D\uDCA5 Fatal: Terminal compatibility issue detected')\n console.error(` Error: ${error.message}`)\n console.error('')\n console.error('This error typically occurs in:')\n console.error(\n ' \u2022 Docker containers without proper TTY allocation (-it flags)',\n )\n console.error(' \u2022 VS Code integrated terminal (some configurations)')\n console.error(' \u2022 SSH sessions with incomplete TTY forwarding')\n console.error(' \u2022 Nested tmux/screen sessions')\n console.error(' \u2022 Terminal emulators with incomplete PTY support')\n console.error('')\n console.error('Quick solutions:')\n console.error(' 1. Use a native terminal application:')\n console.error(' macOS: Terminal.app, iTerm2')\n console.error(' Linux: GNOME Terminal, Konsole')\n console.error(' Windows: Windows Terminal')\n console.error('')\n console.error(' 2. Skip interactive setup:')\n console.error(' export ANTHROPIC_API_KEY=\"sk-ant-...\"')\n console.error(' minto config set -g hasCompletedOnboarding true')\n console.error('')\n console.error(' 3. Use non-interactive mode:')\n console.error(' minto --print \"your prompt\"')\n console.error('')\n process.exit(1)\n }\n\n // Re-throw other errors to maintain normal error handling\n throw error\n })\n}\n\nasync function main() {\n // Initialize configuration directories before any config access\n // This ensures all required directories exist for config, logs, sessions, etc.\n const configDirsResult = ensureConfigDirs()\n if (configDirsResult.errors.length > 0) {\n // Log errors but don't fail - some directories may have permission issues\n for (const err of configDirsResult.errors) {\n console.warn(`\u26A0\uFE0F Config directory warning: ${err.path} - ${err.error}`)\n }\n }\n\n // Run startup migrations (e.g., migrate scattered todo files to new structure)\n // This is non-blocking and runs silently in the background\n runStartupMigration().catch(() => {\n // Migration errors are logged internally but don't block startup\n })\n\n // Initialize i18n system based on config\n const globalConfig = getGlobalConfig()\n const configLang = globalConfig.language\n if (configLang && isLanguageSupported(configLang)) {\n initI18n(configLang as Language)\n } else {\n initI18n('en') // Default to English\n }\n\n // \u521D\u59CB\u5316\u8C03\u8BD5\u65E5\u5FD7\u7CFB\u7EDF\n initDebugLogger()\n\n // Register shell crash listener to notify user\n onShellCrash((code, signal) => {\n console.error('')\n console.error(\n `\u26A0\uFE0F Shell process crashed unexpectedly (code: ${code}, signal: ${signal})`,\n )\n console.error(\n ' Bash commands may fail. Try running /clear or restart the CLI.',\n )\n console.error('')\n })\n\n // Validate configs are valid and enable configuration system\n try {\n enableConfigs()\n\n // \uD83D\uDD27 Validate and auto-repair GPT-5 model profiles\n try {\n const repairResult = validateAndRepairAllGPT5Profiles()\n if (repairResult.repaired > 0) {\n console.log(\n `\uD83D\uDD27 Auto-repaired ${repairResult.repaired} GPT-5 model configurations`,\n )\n }\n } catch (repairError) {\n // Don't block startup if GPT-5 validation fails\n console.warn('\u26A0\uFE0F GPT-5 configuration validation failed:', repairError)\n }\n } catch (error: unknown) {\n if (error instanceof ConfigParseError) {\n // Show the invalid config dialog with the error object\n await showInvalidConfigDialog({ error })\n return // Exit after handling the config error\n }\n }\n\n // Disabled background notifier to avoid mid-screen logs during REPL\n\n let inputPrompt = ''\n let renderContext: RenderOptions | undefined = {\n exitOnCtrlC: false,\n\n onFlicker() {},\n } as any\n\n if (\n !process.stdin.isTTY &&\n !process.env.CI &&\n // Input hijacking breaks MCP.\n !process.argv.includes('mcp')\n ) {\n inputPrompt = await stdin()\n if (process.platform !== 'win32') {\n try {\n const ttyFd = openSync('/dev/tty', 'r')\n renderContext = { ...renderContext, stdin: new ReadStream(ttyFd) }\n } catch (err) {\n logError(`Could not open /dev/tty: ${err}`)\n }\n }\n }\n\n // Validate raw mode support before starting interactive mode\n // This catches environments where isTTY=true but setRawMode fails (e.g., Docker, VS Code)\n const stdinStream = (renderContext?.stdin ||\n process.stdin) as NodeJS.ReadStream\n const rawModeCheck = validateRawModeSupport(stdinStream)\n\n // Store the check result in renderContext for components to use\n ;(renderContext as any).rawModeSupported = rawModeCheck.supported\n ;(renderContext as any).fallbackMode = !rawModeCheck.supported\n\n // Log warning if raw mode is not supported (but don't exit yet - some commands don't need it)\n if (!rawModeCheck.supported) {\n console.warn(\n '\u26A0\uFE0F Interactive mode unavailable: terminal does not support raw mode',\n )\n console.warn(` Reason: ${rawModeCheck.reason}`)\n if (rawModeCheck.environmentHint) {\n console.warn(` Environment: ${rawModeCheck.environmentHint}`)\n }\n console.warn(\n ' Note: Use --print for non-interactive mode or see error message if REPL fails',\n )\n console.warn('')\n }\n\n await parseArgs(inputPrompt, renderContext, rawModeCheck.supported)\n}\n\nasync function parseArgs(\n stdinContent: string,\n renderContext: RenderOptions | undefined,\n rawModeSupported?: boolean,\n): Promise<Command> {\n const program = new Command()\n\n const renderContextWithExitOnCtrlC = {\n ...renderContext,\n exitOnCtrlC: true,\n }\n\n // Get built-in commands synchronously for instant startup\n // Full commands (MCP, custom, plugin) are loaded in REPL background\n const commands = getBuiltInCommands()\n\n // Format command list for help text (using same filter as in help.ts)\n const commandList = commands\n .filter(cmd => !cmd.isHidden)\n .map(cmd => `/${cmd.name} - ${cmd.description}`)\n .join('\\n')\n\n program\n .name(PRODUCT_COMMAND)\n .description(\n `${PRODUCT_NAME} - starts an interactive session by default, use -p/--print for non-interactive output\n\nSlash commands available during an interactive session:\n${commandList}`,\n )\n .argument('[prompt]', 'Your prompt', String)\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-d, --debug', 'Enable debug mode', () => true)\n .option(\n '--debug-verbose',\n 'Enable verbose debug terminal output',\n () => true,\n )\n .option(\n '--verbose',\n 'Override verbose mode setting from config',\n () => true,\n )\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option(\n '-p, --print',\n 'Print response and exit (useful for pipes)',\n () => true,\n )\n .option(\n '--free',\n 'Enable Free safety mode (project directory operations auto-allowed, outside requires confirmation)',\n () => true,\n )\n .option(\n '--smart',\n 'Enable Smart safety mode (dangerous operations need confirmation)',\n () => true,\n )\n .option(\n '--strict',\n 'Enable Strict safety mode (all write operations need confirmation)',\n () => true,\n )\n .option(\n '-n, --new',\n 'Start a new conversation (skip auto-resume)',\n () => true,\n )\n .option(\n '-r, --resume',\n 'Select a previous conversation to resume',\n () => true,\n )\n .option(\n '-l, --lang <language>',\n 'Set interface language (en, zh-CN)',\n String,\n )\n .option(\n '--plugin-dir <dir>',\n 'Additional plugin directory to scan (merged with defaults)',\n String,\n )\n .action(\n async (\n prompt,\n {\n cwd,\n debug,\n verbose,\n enableArchitect,\n print,\n free,\n smart,\n strict,\n new: startNew,\n resume: selectResume,\n lang,\n pluginDir,\n },\n ) => {\n // Apply language override from CLI flag\n if (lang && isLanguageSupported(lang)) {\n setLanguage(lang as Language)\n }\n\n // Register extra plugin directory from CLI flag\n if (pluginDir) {\n const { addExtraPluginDir } = await import('@utils/pluginLoader')\n addExtraPluginDir(pluginDir)\n }\n\n // Determine safety mode: yolo (default) < free < smart < strict\n // Priority: strict > smart > free > yolo\n // Environment variable MINTO_SAFETY_MODE can override CLI flags\n const envSafetyMode = process.env.MINTO_SAFETY_MODE\n const safetyMode: SafetyMode = envSafetyMode\n ? (envSafetyMode as SafetyMode)\n : strict\n ? 'strict'\n : smart\n ? 'smart'\n : free\n ? 'free'\n : 'yolo'\n\n // Legacy safeMode for backward compatibility with showSetupScreens\n const safeMode = safetyMode !== 'yolo'\n\n // Preload dynamic imports early so they overlap with setup\n const inkPromise = import('ink')\n const replPromise = import('@screens/REPL')\n\n await showSetupScreens(safeMode, print, rawModeSupported)\n\n await setup(cwd, safeMode)\n\n assertMinVersion()\n\n // Fast startup: load only built-in tools (no MCP, no network I/O)\n // Skip description cache to avoid filesystem I/O from agent loading\n // MCP tools, descriptions, and update check are deferred to REPL background loading\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n const tools = await getBuiltInTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n { skipDescriptionCache: true },\n )\n const inputPrompt = [prompt, stdinContent].filter(Boolean).join('\\n')\n if (print) {\n if (!inputPrompt) {\n console.error(\n 'Error: Input must be provided either through stdin or as a prompt argument when using --print',\n )\n process.exit(1)\n }\n\n // Print mode needs full tools (including MCP) since there's no REPL to defer loading\n const fullTools = await getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n )\n addToHistory(inputPrompt)\n const { resultText: response } = await ask({\n commands,\n hasPermissionsToUseTool,\n messageLogName: dateToFilename(new Date()),\n prompt: inputPrompt,\n cwd,\n tools: fullTools,\n safeMode,\n safetyMode,\n })\n console.log(response)\n process.exit(0)\n } else {\n // Interactive REPL requires raw mode - check before rendering\n // We check fallbackMode instead of isTTY because we need raw mode support, not just TTY\n if ((renderContext as any)?.fallbackMode) {\n // Raw mode not supported - exit with helpful error\n requireRawModeOrExit(process.stdin, true)\n }\n\n // Handle -r/--resume: show conversation selector\n if (selectResume) {\n const logs = await loadLogList(CACHE_PATHS.messages())\n const context: { unmount?: () => void } = {}\n const { render } = await import('ink')\n const { unmount } = render(\n <ResumeConversation\n context={context}\n commands={commands}\n logs={logs}\n tools={tools}\n verbose={verbose}\n />,\n { ...renderContext, exitOnCtrlC: true },\n )\n context.unmount = unmount\n return\n }\n\n // Auto-resume is now deferred to REPL background loading\n const messageLogName = dateToFilename(new Date())\n const shouldAutoResume = !startNew && !inputPrompt\n\n {\n // Use preloaded imports (already resolved by now)\n const { render } = await inkPromise\n const { REPL } = await replPromise\n\n // Clear screen and prepare terminal for REPL\n // This provides a clean slate for the Minto interface\n await prepareTerminalForREPL()\n\n render(\n <REPL\n commands={commands}\n debug={debug}\n initialPrompt={inputPrompt}\n messageLogName={messageLogName}\n shouldShowPromptInput={true}\n verbose={verbose}\n tools={tools}\n safeMode={safeMode}\n safetyMode={safetyMode}\n mcpClients={[]}\n isDefaultModel={isDefaultModel}\n initialUpdateVersion={null}\n initialUpdateCommands={null}\n enableArchitect={\n enableArchitect ??\n getCurrentProjectConfig().enableArchitectTool\n }\n fallbackMode={(renderContext as any)?.fallbackMode}\n autoResume={shouldAutoResume}\n />,\n renderContext,\n )\n }\n }\n },\n )\n .version(MACRO.VERSION, '-v, --version')\n\n // Enable melon mode for ants if --melon is passed\n // For bun tree shaking to work, this has to be a top level --define, not inside MACRO\n // if (process.env.USER_TYPE === 'ant') {\n // program\n // .option('--melon', 'Enable melon mode')\n // .hook('preAction', async () => {\n // if ((program.opts() as { melon?: boolean }).melon) {\n // const { runMelonWrapper } = await import('../utils/melonWrapper')\n // const melonArgs = process.argv.slice(\n // process.argv.indexOf('--melon') + 1,\n // )\n // const exitCode = runMelonWrapper(melonArgs)\n // process.exit(exitCode)\n // }\n // })\n // }\n\n // claude config\n const config = program\n .command('config')\n .description(\n `Manage configuration (eg. ${PRODUCT_COMMAND} config set -g theme dark)`,\n )\n\n config\n .command('get <key>')\n .description('Get a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n console.log(getConfigForCLI(key, global ?? false))\n process.exit(0)\n })\n\n config\n .command('set <key> <value>')\n .description('Set a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, value, { cwd, global }) => {\n await setup(cwd, false)\n setConfigForCLI(key, value, global ?? false)\n console.log(`Set ${key} to ${value}`)\n process.exit(0)\n })\n\n config\n .command('remove <key>')\n .description('Remove a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n deleteConfigForCLI(key, global ?? false)\n console.log(`Removed ${key}`)\n process.exit(0)\n })\n\n config\n .command('list')\n .description('List all config values')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config', false)\n .action(async ({ cwd, global }) => {\n await setup(cwd, false)\n console.log(\n JSON.stringify(\n global ? listConfigForCLI(true) : listConfigForCLI(false),\n null,\n 2,\n ),\n )\n process.exit(0)\n })\n\n // minto setup - import team configuration\n program\n .command('setup')\n .description('Initialize Minto with team configuration from a URL or file')\n .requiredOption(\n '--from <source>',\n 'URL or file path to the team configuration JSON',\n )\n .option(\n '--strategy <strategy>',\n 'Merge strategy: merge, replace, or skip-existing',\n 'merge',\n )\n .option('--no-plugins', 'Skip installing plugins, agents, and hooks')\n .action(\n async (options: { from: string; strategy: string; plugins: boolean }) => {\n const {\n from: source,\n strategy,\n plugins: shouldInstallPlugins,\n } = options\n\n try {\n // Step 1: Load configuration\n console.log(`Loading configuration from ${source}...`)\n\n const teamConfig =\n source.startsWith('http://') || source.startsWith('https://')\n ? await fetchTeamConfig(source)\n : loadTeamConfigFromFile(source)\n\n // Step 2: Apply configuration\n console.log('Applying configuration...')\n\n const result = applyTeamConfig(teamConfig, strategy as MergeStrategy)\n\n // Step 3: Add marketplaces (if configured)\n let marketplacesAdded = 0\n if (shouldInstallPlugins && teamConfig.plugins?.marketplaces) {\n console.log(\n `Adding ${teamConfig.plugins.marketplaces.length} marketplace(s)...`,\n )\n const marketplaceResult = await addMarketplaces(\n teamConfig.plugins.marketplaces,\n )\n marketplacesAdded = marketplaceResult.added\n }\n\n // Step 4: Install plugins (if configured)\n let pluginsInstalled = 0\n if (shouldInstallPlugins && teamConfig.plugins?.install) {\n console.log(\n `Installing ${teamConfig.plugins.install.length} plugin(s)...`,\n )\n const pluginResult = await installPlugins(\n teamConfig.plugins.install,\n )\n pluginsInstalled = pluginResult.installed\n }\n\n // Step 5: Install agents (if configured)\n let agentsInstalled = 0\n if (shouldInstallPlugins && teamConfig.agents) {\n const remoteCount = teamConfig.agents.remoteAgents?.length || 0\n const inlineCount = teamConfig.agents.inlineAgents?.length || 0\n const totalAgents = remoteCount + inlineCount\n\n if (totalAgents > 0) {\n console.log(`Installing ${totalAgents} agent(s)...`)\n\n if (teamConfig.agents.remoteAgents) {\n const remoteResult = await installRemoteAgents(\n teamConfig.agents.remoteAgents,\n )\n agentsInstalled += remoteResult.installed\n }\n\n if (teamConfig.agents.inlineAgents) {\n const inlineResult = await installInlineAgents(\n teamConfig.agents.inlineAgents,\n )\n agentsInstalled += inlineResult.installed\n }\n }\n }\n\n // Step 6: Install hooks (if configured)\n let hooksInstalled = false\n if (shouldInstallPlugins && teamConfig.hooks) {\n console.log('Installing hooks...')\n const hookResult = await installTeamHooks(teamConfig.hooks)\n hooksInstalled = hookResult.installed\n }\n\n // Success output\n console.log('\\n\u2713 Configuration applied successfully!\\n')\n\n if (result.modelsAdded > 0) {\n console.log(` \u2022 Added ${result.modelsAdded} model profile(s)`)\n }\n if (result.mcpServersAdded > 0) {\n console.log(` \u2022 Added ${result.mcpServersAdded} MCP server(s)`)\n }\n if (result.settingsUpdated.length > 0) {\n console.log(\n ` \u2022 Updated ${result.settingsUpdated.length} setting(s): ${result.settingsUpdated.join(', ')}`,\n )\n }\n if (marketplacesAdded > 0) {\n console.log(` \u2022 Added ${marketplacesAdded} marketplace(s)`)\n }\n if (pluginsInstalled > 0) {\n console.log(` \u2022 Installed ${pluginsInstalled} plugin(s)`)\n }\n if (agentsInstalled > 0) {\n console.log(` \u2022 Installed ${agentsInstalled} agent(s)`)\n }\n if (hooksInstalled) {\n console.log(' \u2022 Installed hooks configuration')\n }\n\n if (teamConfig.postInstallInstructions) {\n console.log('\\n\uD83D\uDCCB Next Steps:')\n console.log(teamConfig.postInstallInstructions)\n }\n\n console.log(\n `\\nRun \"${PRODUCT_COMMAND}\" to start using your configured setup.`,\n )\n process.exit(0)\n } catch (error) {\n console.error(\n '\u2717 Setup failed:',\n error instanceof Error ? error.message : String(error),\n )\n process.exit(1)\n }\n },\n )\n\n // claude approved-tools\n\n const allowedTools = program\n .command('approved-tools')\n .description('Manage approved tools')\n\n allowedTools\n .command('list')\n .description('List all approved tools')\n .action(async () => {\n const result = handleListApprovedTools(getCwd())\n console.log(result)\n process.exit(0)\n })\n\n allowedTools\n .command('remove <tool>')\n .description('Remove a tool from the list of approved tools')\n .action(async (tool: string) => {\n const result = handleRemoveApprovedTool(tool)\n console.log(result.message)\n process.exit(result.success ? 0 : 1)\n })\n\n // claude mcp\n\n const mcp = program\n .command('mcp')\n .description('Configure and manage MCP servers')\n\n mcp\n .command('serve')\n .description(`Start the ${PRODUCT_NAME} MCP server`)\n .action(async () => {\n const providedCwd = (program.opts() as { cwd?: string }).cwd ?? cwd()\n\n // Verify the directory exists\n if (!existsSync(providedCwd)) {\n console.error(`Error: Directory ${providedCwd} does not exist`)\n process.exit(1)\n }\n\n try {\n await setup(providedCwd, false)\n await startMCPServer(providedCwd)\n } catch (error) {\n console.error('Error: Failed to start MCP server:', error)\n process.exit(1)\n }\n })\n\n mcp\n .command('add-sse <name> <url>')\n .description('Add an SSE server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, url, options) => {\n try {\n const scope = ensureConfigScope(options.scope)\n\n addMcpServer(name, { type: 'sse', url }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${url} to ${scope} config`,\n )\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('add [name] [commandOrUrl] [args...]')\n .description('Add a server (run without arguments for interactive wizard)')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .option(\n '-e, --env <env...>',\n 'Set environment variables (e.g. -e KEY=value)',\n )\n .action(async (name, commandOrUrl, args, options) => {\n try {\n // If name is not provided, start interactive wizard\n if (!name) {\n console.log('Interactive wizard mode: Enter the server details')\n const { createInterface } = await import('readline')\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n })\n\n const question = (query: string) =>\n new Promise<string>(resolve => rl.question(query, resolve))\n\n // Get server name\n const serverName = await question('Server name: ')\n if (!serverName) {\n console.error('Error: Server name is required')\n rl.close()\n process.exit(1)\n }\n\n // Get server type\n const serverType = await question(\n 'Server type (stdio or sse) [stdio]: ',\n )\n const type =\n serverType && ['stdio', 'sse'].includes(serverType)\n ? serverType\n : 'stdio'\n\n // Get command or URL\n const prompt = type === 'stdio' ? 'Command: ' : 'URL: '\n const commandOrUrlValue = await question(prompt)\n if (!commandOrUrlValue) {\n console.error(\n `Error: ${type === 'stdio' ? 'Command' : 'URL'} is required`,\n )\n rl.close()\n process.exit(1)\n }\n\n // Get args and env if stdio\n let serverArgs: string[] = []\n let serverEnv: Record<string, string> = {}\n\n if (type === 'stdio') {\n const argsStr = await question(\n 'Command arguments (space-separated): ',\n )\n serverArgs = argsStr ? argsStr.split(' ').filter(Boolean) : []\n\n const envStr = await question(\n 'Environment variables (format: KEY1=value1,KEY2=value2): ',\n )\n if (envStr) {\n const envPairs = envStr.split(',').map(pair => pair.trim())\n serverEnv = parseEnvVars(envPairs.map(pair => pair))\n }\n }\n\n // Get scope\n const scopeStr = await question(\n 'Configuration scope (project or global) [project]: ',\n )\n const serverScope = ensureConfigScope(scopeStr || 'project')\n\n rl.close()\n\n // Add the server\n if (type === 'sse') {\n addMcpServer(\n serverName,\n { type: 'sse', url: commandOrUrlValue },\n serverScope,\n )\n console.log(\n `Added SSE MCP server ${serverName} with URL ${commandOrUrlValue} to ${serverScope} config`,\n )\n } else {\n addMcpServer(\n serverName,\n {\n type: 'stdio',\n command: commandOrUrlValue,\n args: serverArgs,\n env: serverEnv,\n },\n serverScope,\n )\n\n console.log(\n `Added stdio MCP server ${serverName} with command: ${commandOrUrlValue} ${serverArgs.join(' ')} to ${serverScope} config`,\n )\n }\n } else if (name && commandOrUrl) {\n // Regular non-interactive flow\n const scope = ensureConfigScope(options.scope)\n\n // Check if it's an SSE URL (starts with http:// or https://)\n if (commandOrUrl.match(/^https?:\\/\\//)) {\n addMcpServer(name, { type: 'sse', url: commandOrUrl }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${commandOrUrl} to ${scope} config`,\n )\n } else {\n const env = parseEnvVars(options.env)\n addMcpServer(\n name,\n { type: 'stdio', command: commandOrUrl, args: args || [], env },\n scope,\n )\n\n console.log(\n `Added stdio MCP server ${name} with command: ${commandOrUrl} ${(args || []).join(' ')} to ${scope} config`,\n )\n }\n } else {\n console.error(\n 'Error: Missing required arguments. Either provide no arguments for interactive mode or specify name and command/URL.',\n )\n process.exit(1)\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n mcp\n .command('remove <name>')\n .description('Remove an MCP server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project, global, or mcprc)',\n 'project',\n )\n .action(async (name: string, options: { scope?: string }) => {\n try {\n const scope = ensureConfigScope(options.scope)\n\n removeMcpServer(name, scope)\n console.log(`Removed MCP server ${name} from ${scope} config`)\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('list')\n .description('List configured MCP servers')\n .action(() => {\n const servers = listMCPServers()\n if (Object.keys(servers).length === 0) {\n console.log(\n `No MCP servers configured. Use \\`${PRODUCT_COMMAND} mcp add\\` to add a server.`,\n )\n } else {\n for (const [name, server] of Object.entries(servers)) {\n if (server.type === 'sse') {\n console.log(`${name}: ${server.url} (SSE)`)\n } else if (server.type === 'http') {\n console.log(`${name}: ${(server as any).url} (HTTP)`)\n } else {\n console.log(\n `${name}: ${(server as any).command} ${((server as any).args || []).join(' ')}`,\n )\n }\n }\n }\n process.exit(0)\n })\n\n mcp\n .command('add-json <name> <json>')\n .description('Add an MCP server (stdio or SSE) with a JSON string')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, jsonStr, options) => {\n try {\n const scope = ensureConfigScope(options.scope)\n\n // Parse JSON string\n let serverConfig\n try {\n serverConfig = JSON.parse(jsonStr)\n } catch (e) {\n console.error('Error: Invalid JSON string')\n process.exit(1)\n }\n\n // Validate the server config\n if (\n !serverConfig.type ||\n !['stdio', 'sse'].includes(serverConfig.type)\n ) {\n console.error('Error: Server type must be \"stdio\" or \"sse\"')\n process.exit(1)\n }\n\n if (serverConfig.type === 'sse' && !serverConfig.url) {\n console.error('Error: SSE server must have a URL')\n process.exit(1)\n }\n\n if (serverConfig.type === 'stdio' && !serverConfig.command) {\n console.error('Error: stdio server must have a command')\n process.exit(1)\n }\n\n // Add server with the provided config\n\n addMcpServer(name, serverConfig, scope)\n\n if (serverConfig.type === 'sse') {\n console.log(\n `Added SSE MCP server ${name} with URL ${serverConfig.url} to ${scope} config`,\n )\n } else {\n console.log(\n `Added stdio MCP server ${name} with command: ${serverConfig.command} ${(\n serverConfig.args || []\n ).join(' ')} to ${scope} config`,\n )\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('get <name>')\n .description('Get details about an MCP server')\n .action((name: string) => {\n const server = getMcpServer(name)\n if (!server) {\n console.error(`No MCP server found with name: ${name}`)\n process.exit(1)\n }\n console.log(`${name}:`)\n console.log(` Scope: ${server.scope}`)\n if (server.type === 'sse') {\n console.log(` Type: sse`)\n console.log(` URL: ${server.url}`)\n } else if (server.type === 'http') {\n console.log(` Type: http`)\n console.log(` URL: ${(server as any).url}`)\n } else {\n console.log(` Type: stdio`)\n console.log(` Command: ${(server as any).command}`)\n console.log(` Args: ${((server as any).args || []).join(' ')}`)\n if ((server as any).env) {\n console.log(' Environment:')\n for (const [key, value] of Object.entries((server as any).env)) {\n console.log(` ${key}=${value}`)\n }\n }\n }\n process.exit(0)\n })\n\n // Import servers from Claude Desktop\n mcp\n .command('add-from-claude-desktop')\n .description(\n 'Import MCP servers from Claude Desktop (Mac, Windows and WSL)',\n )\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async options => {\n try {\n const scope = ensureConfigScope(options.scope)\n const platform = process.platform\n\n // Import fs and path modules\n const { existsSync, readFileSync } = await import('fs')\n const { join } = await import('path')\n const { exec } = await import('child_process')\n\n // Determine if running in WSL\n const isWSL =\n platform === 'linux' &&\n existsSync('/proc/version') &&\n readFileSync('/proc/version', 'utf-8')\n .toLowerCase()\n .includes('microsoft')\n\n if (platform !== 'darwin' && platform !== 'win32' && !isWSL) {\n console.error(\n 'Error: This command is only supported on macOS, Windows, and WSL',\n )\n process.exit(1)\n }\n\n // Get Claude Desktop config path\n let configPath\n if (platform === 'darwin') {\n configPath = join(\n process.env.HOME || '~',\n 'Library/Application Support/Claude/claude_desktop_config.json',\n )\n } else if (platform === 'win32') {\n configPath = join(\n process.env.APPDATA || '',\n 'Claude/claude_desktop_config.json',\n )\n } else if (isWSL) {\n // Get Windows username\n const whoamiCommand = await new Promise<string>((resolve, reject) => {\n exec(\n 'powershell.exe -Command \"whoami\"',\n (err: Error, stdout: string) => {\n if (err) reject(err)\n else resolve(stdout.trim().split('\\\\').pop() || '')\n },\n )\n })\n\n configPath = `/mnt/c/Users/${whoamiCommand}/AppData/Roaming/Claude/claude_desktop_config.json`\n }\n\n // Check if config file exists\n if (!existsSync(configPath)) {\n console.error(\n `Error: Claude Desktop config file not found at ${configPath}`,\n )\n process.exit(1)\n }\n\n // Read config file\n let config\n try {\n const configContent = readFileSync(configPath, 'utf-8')\n config = JSON.parse(configContent)\n } catch (err) {\n console.error(`Error reading config file: ${err}`)\n process.exit(1)\n }\n\n // Extract MCP servers\n const mcpServers = config.mcpServers || {}\n const serverNames = Object.keys(mcpServers)\n const numServers = serverNames.length\n\n if (numServers === 0) {\n console.log('No MCP servers found in Claude Desktop config')\n process.exit(0)\n }\n\n // Create server information for display\n const serversInfo = serverNames.map(name => {\n const server = mcpServers[name]\n let description = ''\n\n if (server.type === 'sse') {\n description = `SSE: ${server.url}`\n } else {\n description = `stdio: ${server.command} ${(server.args || []).join(' ')}`\n }\n\n return { name, description, server }\n })\n\n // First import all required modules outside the component\n // Import modules separately to avoid any issues\n const ink = await import('ink')\n const reactModule = await import('react')\n const inkjsui = await import('@inkjs/ui')\n const utilsTheme = await import('@utils/theme')\n\n const { render } = ink\n const React = reactModule // React is already the default export when imported this way\n const { MultiSelect } = inkjsui\n const { Box, Text } = ink\n const { getTheme } = utilsTheme\n\n // Use Ink to render a nice UI for selection\n await new Promise<void>(resolve => {\n // Create a component for the server selection\n function ClaudeDesktopImport() {\n const { useState } = reactModule\n const [isFinished, setIsFinished] = useState(false)\n const [importResults, setImportResults] = useState(\n [] as { name: string; success: boolean }[],\n )\n const [isImporting, setIsImporting] = useState(false)\n const theme = getTheme()\n\n // Function to import selected servers\n const importServers = async (selectedServers: string[]) => {\n setIsImporting(true)\n const results = []\n\n for (const name of selectedServers) {\n try {\n const server = mcpServers[name]\n\n // Check if server already exists\n const existingServer = getMcpServer(name)\n if (existingServer) {\n // Skip duplicates - we'll handle them in the confirmation step\n continue\n }\n\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results\n setTimeout(() => {\n resolve()\n }, 1000)\n }\n\n // Handle confirmation of selections\n const handleConfirm = async (selectedServers: string[]) => {\n // Check for existing servers and confirm overwrite\n const existingServers = selectedServers.filter(name =>\n getMcpServer(name),\n )\n\n if (existingServers.length > 0) {\n // We'll just handle it directly since we have a simple UI\n const results = []\n\n // Process non-existing servers first\n const newServers = selectedServers.filter(\n name => !getMcpServer(name),\n )\n for (const name of newServers) {\n try {\n const server = mcpServers[name]\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n // Now handle existing servers by prompting for each one\n for (const name of existingServers) {\n try {\n const server = mcpServers[name]\n // Overwrite existing server - in a real interactive UI you'd prompt here\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results before resolving\n setTimeout(() => {\n resolve()\n }, 1000)\n } else {\n // No existing servers, proceed with import\n await importServers(selectedServers)\n }\n }\n\n return (\n <Box flexDirection=\"column\" padding={1}>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={theme.minto}\n padding={1}\n width={'100%'}\n >\n <Text bold color={theme.minto}>\n Import MCP Servers from Claude Desktop\n </Text>\n\n <Box marginY={1}>\n <Text>\n Found {numServers} MCP servers in Claude Desktop.\n </Text>\n </Box>\n\n <Text>Please select the servers you want to import:</Text>\n\n <Box marginTop={1}>\n <MultiSelect\n options={serverNames.map(name => ({\n label: name,\n value: name,\n }))}\n defaultValue={serverNames}\n onSubmit={handleConfirm}\n />\n </Box>\n </Box>\n\n <Box marginTop={0} marginLeft={3}>\n <Text color={SEMANTIC_COLORS.dim}>\n Space to select \u00B7 Enter to confirm \u00B7 Esc to cancel\n </Text>\n </Box>\n\n {isFinished && (\n <Box marginTop={1}>\n <Text color={theme.success}>\n Successfully imported{' '}\n {importResults.filter(r => r.success).length} MCP server\n to local config.\n </Text>\n </Box>\n )}\n </Box>\n )\n }\n\n // Render the component\n const { unmount } = render(<ClaudeDesktopImport />)\n\n // Clean up when done\n setTimeout(() => {\n unmount()\n resolve()\n }, 30000) // Timeout after 30 seconds as a fallback\n })\n\n process.exit(0)\n } catch (error) {\n console.error(`Error: ${(error as Error).message}`)\n process.exit(1)\n }\n })\n\n // Function to reset MCP server choices\n const resetMcpChoices = () => {\n const config = getCurrentProjectConfig()\n saveCurrentProjectConfig({\n ...config,\n approvedMcprcServers: [],\n rejectedMcprcServers: [],\n })\n console.log('All .mcprc server approvals and rejections have been reset.')\n console.log(\n `You will be prompted for approval next time you start ${PRODUCT_NAME}.`,\n )\n process.exit(0)\n }\n\n // New command name to match Minto\n mcp\n .command('reset-project-choices')\n .description(\n 'Reset all approved and rejected project-scoped (.mcp.json) servers within this project',\n )\n .action(() => {\n resetMcpChoices()\n })\n\n // Keep old command for backward compatibility (visible only to ants)\n if (process.env.USER_TYPE === 'ant') {\n mcp\n .command('reset-mcprc-choices')\n .description(\n 'Reset all approved and rejected .mcprc servers for this project',\n )\n .action(() => {\n resetMcpChoices()\n })\n }\n\n // ant-only commands\n\n // claude update\n program\n .command('update')\n .description('Show manual upgrade commands (no auto-install)')\n .action(async () => {\n console.log(`Current version: ${MACRO.VERSION}`)\n console.log('Checking for updates...')\n\n const latestVersion = await getLatestVersion()\n\n if (!latestVersion) {\n console.error('Failed to check for updates')\n process.exit(1)\n }\n\n if (latestVersion === MACRO.VERSION) {\n console.log(`${PRODUCT_NAME} is up to date`)\n process.exit(0)\n }\n\n console.log(`New version available: ${latestVersion}`)\n const { getUpdateCommandSuggestions } = await import('@utils/autoUpdater')\n const cmds = await getUpdateCommandSuggestions()\n console.log('\\nRun one of the following commands to update:')\n for (const c of cmds) console.log(` ${c}`)\n if (process.platform !== 'win32') {\n console.log(\n '\\nNote: you may need to prefix with \"sudo\" on macOS/Linux.',\n )\n }\n process.exit(0)\n })\n\n // claude log\n program\n .command('log')\n .description('Manage conversation logs.')\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <LogList context={context} type=\"messages\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // claude resume\n program\n .command('resume')\n .description(\n 'Resume a previous conversation. Optionally provide a number (0, 1, 2, etc.) or file path to resume a specific conversation.',\n )\n .argument(\n '[identifier]',\n 'A number (0, 1, 2, etc.) or file path to resume a specific conversation',\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option('-v, --verbose', 'Do not truncate message output', () => true)\n .option(\n '--free',\n 'Enable Free safety mode (project directory operations auto-allowed, outside requires confirmation)',\n () => true,\n )\n .option(\n '--smart',\n 'Enable Smart safety mode (dangerous operations need confirmation)',\n () => true,\n )\n .option(\n '--strict',\n 'Enable Strict safety mode (all write operations need confirmation)',\n () => true,\n )\n .action(\n async (\n identifier,\n { cwd, enableArchitect, free, smart, strict, verbose },\n ) => {\n // Determine safety mode: yolo (default) < free < smart < strict\n const envSafetyMode = process.env.MINTO_SAFETY_MODE\n const safetyMode: SafetyMode = envSafetyMode\n ? (envSafetyMode as SafetyMode)\n : strict\n ? 'strict'\n : smart\n ? 'smart'\n : free\n ? 'free'\n : 'yolo'\n const safeMode = safetyMode !== 'yolo'\n await setup(cwd, safeMode)\n assertMinVersion()\n\n const [tools, commands, logs, mcpClients] = await Promise.all([\n getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n ),\n getCommands(),\n loadLogList(CACHE_PATHS.messages()),\n getClients(),\n ])\n\n // If a specific conversation is requested, load and resume it directly\n if (identifier !== undefined) {\n // Check if identifier is a number or a file path\n const number = Math.abs(parseInt(identifier))\n const isNumber = !isNaN(number)\n let messages, date, forkNumber\n try {\n if (isNumber) {\n const log = logs[number]\n if (!log) {\n console.error('No conversation found at index', number)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(log.fullPath, tools)\n ;({ date, forkNumber } = log)\n } else {\n // Handle file path case\n\n if (!existsSync(identifier)) {\n console.error('File does not exist:', identifier)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(identifier, tools)\n const pathSegments = identifier.split('/')\n const filename =\n pathSegments[pathSegments.length - 1] ?? 'unknown'\n ;({ date, forkNumber } = parseLogFilename(filename))\n }\n const fork = getNextAvailableLogForkNumber(date, forkNumber ?? 1, 0)\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n\n // Interactive REPL requires raw mode - always check (not just isTTY)\n // This handles cases where stdin is not TTY or setRawMode is not supported\n const forkRawModeCheck = validateRawModeSupport(process.stdin)\n if (!forkRawModeCheck.supported) {\n requireRawModeOrExit(process.stdin, true)\n }\n\n {\n const { render } = await import('ink')\n const { REPL } = await import('@screens/REPL')\n\n // Clear screen and prepare terminal for REPL\n await prepareTerminalForREPL()\n\n render(\n <REPL\n initialPrompt=\"\"\n messageLogName={date}\n initialForkNumber={fork}\n shouldShowPromptInput={true}\n verbose={verbose}\n commands={commands}\n tools={tools}\n safeMode={safeMode}\n safetyMode={safetyMode}\n initialMessages={messages}\n mcpClients={mcpClients}\n isDefaultModel={isDefaultModel}\n fallbackMode={false}\n />,\n { exitOnCtrlC: false },\n )\n }\n } catch (error) {\n logError(`Failed to load conversation: ${error}`)\n process.exit(1)\n }\n } else {\n // Show the conversation selector UI\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <ResumeConversation\n context={context}\n commands={commands}\n logs={logs}\n tools={tools}\n verbose={verbose}\n />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n }\n },\n )\n\n // claude error\n program\n .command('error')\n .description(\n 'View error logs. Optionally provide a number (0, -1, -2, etc.) to display a specific log.',\n )\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <LogList context={context} type=\"errors\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // legacy context (TODO: deprecate)\n const context = program\n .command('context')\n .description(\n `Set static context (eg. ${PRODUCT_COMMAND} context add-file ./src/*.py)`,\n )\n\n context\n .command('get <key>')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .description('Get a value from context')\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n )\n console.log(context[key])\n process.exit(0)\n })\n\n context\n .command('set <key> <value>')\n .description('Set a value in context')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, value, { cwd }) => {\n await setup(cwd, false)\n\n setContext(key, value)\n console.log(`Set context.${key} to \"${value}\"`)\n process.exit(0)\n })\n\n context\n .command('list')\n .description('List all context values')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async ({ cwd }) => {\n await setup(cwd, false)\n\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n 'gitStatus',\n )\n console.log(JSON.stringify(context, null, 2))\n process.exit(0)\n })\n\n context\n .command('remove <key>')\n .description('Remove a value from context')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n\n removeContext(key)\n console.log(`Removed context.${key}`)\n process.exit(0)\n })\n\n await program.parseAsync(process.argv)\n return program\n}\n\n// TODO: stream?\nasync function stdin() {\n if (process.stdin.isTTY) {\n return ''\n }\n\n let data = ''\n for await (const chunk of process.stdin) data += chunk\n return data\n}\n\n// Setup centralized exit handlers\nsetupExitHandlers()\n\nfunction resetCursor() {\n const terminal = process.stderr.isTTY\n ? process.stderr\n : process.stdout.isTTY\n ? process.stdout\n : undefined\n terminal?.write(`\\u001B[?25h${cursorShow}`)\n}\n\nmain()\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["cwd", "context", "env", "existsSync", "config", "React", "
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env -S node --no-warnings=ExperimentalWarning --enable-source-maps\n\n/**\n * Minto CLI Main Entry Point\n *\n * NOTE: This module is loaded via dynamic import from bootstrap.ts.\n * The following initializations are handled in bootstrap.ts BEFORE this loads:\n * - process.env.DEV = 'false' (prevents Ink devtools loading)\n * - EventEmitter.defaultMaxListeners = 20 (prevents listener warnings)\n * - YOGA_WASM_PATH (Ink layout engine WASM path)\n *\n * See bootstrap.ts for details on why these must happen before ESM imports.\n */\n\nimport { initSentry } from '@services/sentry'\nimport { PRODUCT_COMMAND, PRODUCT_NAME } from '@constants/product'\nimport { initGlobalErrorHandlers } from '@utils/globalErrorHandler'\n\ninitSentry() // Initialize Sentry as early as possible\ninitGlobalErrorHandlers() // Initialize global error handlers early\n\n// XXX: Without this line (and the Object.keys, even though it seems like it does nothing!),\n// there is a bug in Bun only on Win32 that causes this import to be removed, even though\n// its use is solely because of its side-effects.\nimport * as dontcare from '@anthropic-ai/sdk/shims/node'\nObject.keys(dontcare)\n\nimport React from 'react'\nimport { ReadStream } from 'tty'\nimport { existsSync, openSync } from 'fs'\n// ink and REPL are imported lazily to avoid top-level awaits during module init\nimport type { RenderOptions } from 'ink'\nimport { validateRawModeSupport, requireRawModeOrExit } from '@utils/ptyCompat'\nimport { addToHistory } from '@history'\nimport { getContext, setContext, removeContext } from '@context'\nimport { Command } from '@commander-js/extra-typings'\nimport { ask } from '@utils/ask'\nimport { hasPermissionsToUseTool } from '@permissions'\nimport { getBuiltInTools, getTools } from '@tools'\nimport {\n getGlobalConfig,\n getCurrentProjectConfig,\n saveGlobalConfig,\n saveCurrentProjectConfig,\n getCustomApiKeyStatus,\n normalizeApiKeyForConfig,\n setConfigForCLI,\n deleteConfigForCLI,\n getConfigForCLI,\n listConfigForCLI,\n enableConfigs,\n validateAndRepairAllGPT5Profiles,\n} from '@utils/config'\nimport { cwd } from 'process'\nimport { dateToFilename, logError, parseLogFilename } from '@utils/log'\nimport { initDebugLogger } from '@utils/debugLogger'\nimport {\n checkHasTrustDialogAccepted,\n McpServerConfig,\n type SafetyMode,\n} from '@utils/config'\nimport { isDefaultSlowAndCapableModel } from '@utils/model'\nimport { env } from '@utils/env'\nimport { getCwd, setCwd, setOriginalCwd } from '@utils/state'\nimport { omit } from 'lodash-es'\nimport { getBuiltInCommands, getCommands } from '@commands'\nimport { getNextAvailableLogForkNumber, loadLogList } from '@utils/log'\nimport { loadMessagesFromLog } from '@utils/conversationRecovery'\nimport { cleanupOldMessageFilesInBackground } from '@utils/cleanup'\nimport { runLogRotationInBackground, shouldRotate } from '@utils/logRotation'\n// Type-only imports (zero runtime cost, needed for type casts)\nimport type { MergeStrategy } from '@utils/teamConfig'\n\n// Lazy-loaded subcommand imports (loaded on-demand in .action() callbacks):\n// - @commands/approvedTools (approved-tools subcommand)\n// - @services/mcpClient (mcp subcommands, resume)\n// - @services/mcpServerApproval (setup screens)\n// - @utils/teamConfig (setup subcommand)\n// - @screens/LogList (log/error subcommands)\n// - @screens/ResumeConversation (resume subcommand)\n// - ./mcp (mcp serve subcommand)\n// - @components/Onboarding (onboarding flow)\n// - @components/TrustDialog (trust dialog flow)\n\nimport { cursorShow } from 'ansi-escapes'\nimport { assertMinVersion } from '@utils/autoUpdater'\nimport { ensureConfigDirs } from '@utils/configPaths'\nimport { runStartupMigration } from '@utils/migration'\nimport {\n initI18n,\n setLanguage,\n isLanguageSupported,\n type Language,\n} from '@i18n'\nimport { CACHE_PATHS } from '@utils/log'\n// import { checkAndNotifyUpdate } from '@utils/autoUpdater'\nimport { PersistentShell, onShellCrash } from '@utils/PersistentShell'\nimport { clearTerminal, prepareTerminalForREPL } from '@utils/terminal'\nimport { formatTotalCost } from '@costTracker'\nimport { setupExitHandlers } from '@utils/exit'\nimport { showInvalidConfigDialog } from '@components/InvalidConfigDialog'\nimport { ConfigParseError } from '@utils/errors'\nimport { grantReadPermissionForOriginalDir } from '@utils/permissions/filesystem'\nimport { MACRO } from '@constants/macros'\nimport { SEMANTIC_COLORS } from '@constants/colors'\n// @utils/claudeCodeSync is lazy-loaded in setup() where it's used conditionally\nexport function completeOnboarding(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n hasCompletedOnboarding: true,\n lastOnboardingVersion: MACRO.VERSION,\n })\n}\n\nasync function showSetupScreens(\n safeMode?: boolean,\n print?: boolean,\n rawModeSupported?: boolean,\n): Promise<void> {\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n const config = getGlobalConfig()\n if (\n !config.theme ||\n !config.hasCompletedOnboarding // always show onboarding at least once\n ) {\n // \uD83D\uDD27 If raw mode is not supported, auto-skip onboarding with default config\n if (rawModeSupported === false) {\n console.log(\n '\u26A0\uFE0F Interactive onboarding is not supported in this terminal environment',\n )\n console.log('\u2728 Auto-configuring with default settings...')\n console.log('')\n\n // Apply default configuration\n saveGlobalConfig({\n ...config,\n theme: config.theme || 'dark', // Use dark theme as default\n hasCompletedOnboarding: true,\n lastOnboardingVersion: MACRO.VERSION,\n })\n\n console.log('\u2705 Configuration completed automatically')\n console.log(\n '\uD83D\uDCA1 You can customize settings later with: minto config set -g <key> <value>',\n )\n console.log('')\n return\n }\n\n await clearTerminal()\n const { render } = await import('ink')\n const { Onboarding } = await import('@components/Onboarding')\n await new Promise<void>(resolve => {\n render(\n <Onboarding\n onDone={async () => {\n completeOnboarding()\n await clearTerminal()\n resolve()\n }}\n />,\n {\n exitOnCtrlC: false,\n },\n )\n })\n }\n\n // In non-interactive mode, only show trust dialog in safe mode\n if (!print && safeMode) {\n if (!checkHasTrustDialogAccepted()) {\n // \uD83D\uDD27 If raw mode is not supported, auto-accept trust dialog\n if (rawModeSupported === false) {\n console.log('\u2728 Auto-granting read permissions for safe mode...')\n grantReadPermissionForOriginalDir()\n console.log('\u2705 Permissions granted')\n console.log('')\n } else {\n await new Promise<void>(resolve => {\n const onDone = () => {\n // Grant read permission to the current working directory\n grantReadPermissionForOriginalDir()\n resolve()\n }\n ;(async () => {\n const { render } = await import('ink')\n const { TrustDialog } = await import('@components/TrustDialog')\n render(<TrustDialog onDone={onDone} />, {\n exitOnCtrlC: false,\n })\n })()\n })\n }\n }\n\n // After trust dialog, check for any mcprc servers that need approval\n if (process.env.USER_TYPE === 'ant') {\n const { handleMcprcServerApprovals } = await import(\n '@services/mcpServerApproval'\n )\n await handleMcprcServerApprovals()\n }\n }\n}\n\nfunction logStartup(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n numStartups: (config.numStartups ?? 0) + 1,\n })\n}\n\nasync function setup(cwd: string, safeMode?: boolean): Promise<void> {\n // Set both current and original working directory if --cwd was provided\n if (cwd !== process.cwd()) {\n setOriginalCwd(cwd)\n }\n await setCwd(cwd)\n\n // Always grant read permissions for original working dir\n grantReadPermissionForOriginalDir()\n\n // Start watching agent configuration files for changes\n const agentLoader = await import('@utils/agentLoader')\n const { startAgentWatcher, clearAgentCache } = agentLoader\n await startAgentWatcher(() => {\n // Cache is already cleared in the watcher, just log\n console.log('\u2705 Agent configurations hot-reloaded')\n })\n\n // If --safe mode is enabled, prevent root/sudo usage for security\n if (safeMode) {\n // Check if running as root/sudo on Unix-like systems\n if (\n process.platform !== 'win32' &&\n typeof process.getuid === 'function' &&\n process.getuid() === 0\n ) {\n console.error(\n `--safe mode cannot be used with root/sudo privileges for security reasons`,\n )\n process.exit(1)\n }\n }\n\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n cleanupOldMessageFilesInBackground()\n\n // Run log rotation if needed (in background, non-blocking)\n if (shouldRotate()) {\n runLogRotationInBackground()\n }\n\n getContext() // Pre-fetch all context data at once\n\n // Migrate old iterm2KeyBindingInstalled config to new shiftEnterKeyBindingInstalled\n const globalConfig = getGlobalConfig()\n if (\n globalConfig.iterm2KeyBindingInstalled === true &&\n globalConfig.shiftEnterKeyBindingInstalled !== true\n ) {\n const updatedConfig = {\n ...globalConfig,\n shiftEnterKeyBindingInstalled: true,\n }\n // Remove the old config property\n delete updatedConfig.iterm2KeyBindingInstalled\n saveGlobalConfig(updatedConfig)\n }\n\n // Check for last session's cost and duration\n const projectConfig = getCurrentProjectConfig()\n if (\n projectConfig.lastCost !== undefined &&\n projectConfig.lastDuration !== undefined\n ) {\n // Clear the values after logging\n // saveCurrentProjectConfig({\n // ...projectConfig,\n // lastCost: undefined,\n // lastAPIDuration: undefined,\n // lastDuration: undefined,\n // lastSessionId: undefined,\n // })\n }\n\n // Claude Code \u2192 Minto plugin auto-sync (fire-and-forget to avoid blocking startup)\n try {\n const cfg = getGlobalConfig()\n const {\n hasClaudeCodeInstallation,\n needsSync: needsCCSync,\n syncFromClaudeCode,\n } = await import('@utils/claudeCodeSync')\n if (hasClaudeCodeInstallation() && needsCCSync()) {\n const shouldSync =\n cfg.autoSyncClaudeCode === true || cfg.autoSyncClaudeCode === undefined\n if (shouldSync) {\n syncFromClaudeCode()\n .then(result => {\n const changed = result.installed.length + result.updated.length\n const mpRegistered = result.marketplaces.registered.length\n if (changed > 0 || mpRegistered > 0) {\n const parts = []\n if (changed > 0) {\n parts.push(\n `${changed} plugin(s) (${result.installed.length} new, ${result.updated.length} updated)`,\n )\n }\n if (mpRegistered > 0) {\n parts.push(`${mpRegistered} marketplace(s)`)\n }\n console.log(`Synced from Claude Code: ${parts.join(', ')}`)\n }\n if (cfg.autoSyncClaudeCode === undefined) {\n saveGlobalConfig({\n ...getGlobalConfig(),\n autoSyncClaudeCode: true,\n })\n }\n })\n .catch(() => {\n // Non-fatal: don't block startup if CC sync fails\n })\n }\n // autoSyncClaudeCode === false \u2192 skip\n }\n } catch {\n // Non-fatal: don't block startup if CC sync fails\n }\n\n // Skip interactive auto-updater permission prompts during startup\n // Users can still run the doctor command manually if desired.\n}\n\n// Global error handler for setRawMode failures (last line of defense)\nif (process.env.NODE_ENV !== 'test') {\n process.on('uncaughtException', (error: Error) => {\n // Only catch specific setRawMode/PTY errors to avoid masking other issues\n const isSetRawModeError =\n error.message?.includes('setRawMode') ||\n error.message?.includes('EIO') ||\n error.message?.includes('ENOTTY') ||\n (error as any).code === 'EIO' ||\n (error as any).code === 'ENOTTY'\n\n if (isSetRawModeError) {\n console.error('')\n console.error('\uD83D\uDCA5 Fatal: Terminal compatibility issue detected')\n console.error(` Error: ${error.message}`)\n console.error('')\n console.error('This error typically occurs in:')\n console.error(\n ' \u2022 Docker containers without proper TTY allocation (-it flags)',\n )\n console.error(' \u2022 VS Code integrated terminal (some configurations)')\n console.error(' \u2022 SSH sessions with incomplete TTY forwarding')\n console.error(' \u2022 Nested tmux/screen sessions')\n console.error(' \u2022 Terminal emulators with incomplete PTY support')\n console.error('')\n console.error('Quick solutions:')\n console.error(' 1. Use a native terminal application:')\n console.error(' macOS: Terminal.app, iTerm2')\n console.error(' Linux: GNOME Terminal, Konsole')\n console.error(' Windows: Windows Terminal')\n console.error('')\n console.error(' 2. Skip interactive setup:')\n console.error(' export ANTHROPIC_API_KEY=\"sk-ant-...\"')\n console.error(' minto config set -g hasCompletedOnboarding true')\n console.error('')\n console.error(' 3. Use non-interactive mode:')\n console.error(' minto --print \"your prompt\"')\n console.error('')\n process.exit(1)\n }\n\n // Re-throw other errors to maintain normal error handling\n throw error\n })\n}\n\n/**\n * Run as a headless teammate agent (no REPL UI).\n *\n * Launched by HeadlessBackend via child_process.fork().\n * Executes the agent query loop, checks inbox between turns,\n * listens for IPC abort/shutdown signals, and exits when done.\n */\nasync function runHeadlessAgent(options: {\n cwd: string\n teamName: string\n agentId: string\n agentName: string\n agentType: string\n prompt: string\n maxTurns?: number\n model?: string\n permissionMode?: string\n planModeRequired?: boolean\n agentColor?: string\n parentSessionId?: string\n}): Promise<void> {\n const {\n cwd: agentCwd,\n teamName,\n agentId,\n agentName,\n agentType,\n prompt,\n maxTurns,\n model,\n permissionMode,\n planModeRequired,\n agentColor,\n parentSessionId,\n } = options\n\n // Setup working directory\n await setCwd(agentCwd)\n\n // Initialize config system\n try {\n enableConfigs()\n } catch {\n // Non-fatal: continue with defaults\n }\n\n // Set environment for team discovery (MINTO_* + CLAUDE_CODE_* compat)\n process.env.MINTO_TEAM_NAME = teamName\n process.env.CLAUDE_CODE_TEAM_NAME = teamName\n process.env.MINTO_AGENT_ID = agentId\n process.env.CLAUDE_CODE_AGENT_ID = agentId\n process.env.MINTO_AGENT_TYPE = agentType\n process.env.CLAUDE_CODE_AGENT_TYPE = agentType\n process.env.MINTO_AGENT_NAME = agentName\n process.env.CLAUDE_CODE_AGENT_NAME = agentName\n process.env.MINTO_HEADLESS = '1'\n if (parentSessionId) process.env.MINTO_PARENT_SESSION_ID = parentSessionId\n if (agentColor) process.env.MINTO_AGENT_COLOR = agentColor\n if (planModeRequired) {\n process.env.MINTO_PLAN_MODE_REQUIRED = '1'\n process.env.CLAUDE_CODE_PLAN_MODE_REQUIRED = '1'\n }\n if (permissionMode) process.env.MINTO_AGENT_MODE = permissionMode\n\n // Load team mailbox and task store\n const { loadTeam, getTeam } = await import('@services/agentTeams/teamManager')\n const { markTeammateIdle } = await import(\n '@services/agentTeams/teammateSpawner'\n )\n loadTeam(teamName)\n\n // Build system prompt with team context\n const { getAgentPrompt } = await import('@constants/prompts')\n const { getContext } = await import('@context')\n const { getBuiltInTools } = await import('@tools')\n const { hasPermissionsToUseTool } = await import('@permissions')\n const { query } = await import('@query')\n const { createUserMessage } = await import('@utils/messages')\n const { getMaxThinkingTokens } = await import('@utils/thinking')\n const { dateToFilename } = await import('@utils/log')\n\n let teamDiscovery = ''\n const entry = getTeam(teamName)\n if (entry) {\n const otherMembers = entry.team.members\n .filter(m => m.id !== agentId && m.name !== agentName)\n .map(m => ` - ${m.name} (${m.agentType}): ${m.status}`)\n .join('\\n')\n if (otherMembers) {\n teamDiscovery = `\\nTeam members:\\n${otherMembers}`\n }\n }\n\n const teamContext = `\\n# Agent Teammate Communication\n\nYou are agent \"${agentName}\" in team \"${teamName}\".\n\n## CRITICAL: Reporting Results\n\n**You MUST use the SendMessage tool to report your results to the team lead.** Your text output is NOT visible to the team lead or any teammate. The ONLY way to deliver your findings is via SendMessage.\n\nWhen you finish your task:\n1. Use SendMessage with type \"message\", recipient \"team-lead\", and your findings as content\n2. Include a brief summary in the summary field\n3. Do NOT just output text \u2014 it will be lost\n\n## Communication\n\n- Use SendMessage with type \\`message\\` to send messages to specific teammates\n- Use SendMessage with type \\`broadcast\\` sparingly for team-wide announcements\n- Do NOT send acknowledgment messages (\"Got it\", \"\u5DF2\u6536\u5230\") \u2014 only send when you have actionable content\n- ALWAYS respond in the same language as the user's original request\n\nTeam: ${teamName}\nYour agent ID: ${agentId}\nYour agent type: ${agentType}${teamDiscovery}\n`\n // Wrap teamContext in <system-reminder> so UserPromptMessage filters it out\n const effectivePrompt =\n `<system-reminder>\\n${teamContext}\\n</system-reminder>\\n\\n` + prompt\n\n const messages: any[] = [createUserMessage(effectivePrompt)]\n // Use getBuiltInTools (not getTools) to avoid getMCPTools() which can hang\n // waiting for MCP server connections in a headless child process.\n const agentTools = await getBuiltInTools(false)\n const messageLogName = dateToFilename(new Date())\n\n // CLI arg takes priority, env var fallback for backward compatibility\n const agentModel = model || process.env.MINTO_AGENT_MODEL || 'task'\n\n const [taskPrompt, context, maxThinkingTokens] = await Promise.all([\n getAgentPrompt(),\n getContext(),\n getMaxThinkingTokens(messages),\n ])\n\n // Setup abort controller \u2014 listens for IPC signals from parent\n const abortController = new AbortController()\n\n process.on('message', (msg: any) => {\n if (msg?.type === 'abort' || msg?.type === 'shutdown') {\n abortController.abort()\n }\n })\n\n // Run the query loop\n let turnCount = 0\n\n try {\n for await (const message of query(\n messages,\n taskPrompt,\n context,\n hasPermissionsToUseTool,\n {\n abortController,\n messageId: undefined,\n options: {\n safeMode: false,\n tools: agentTools,\n commands: [] as any[],\n forkNumber: 0,\n messageLogName,\n verbose: false,\n maxThinkingTokens,\n model: agentModel,\n },\n readFileTimestamps: {},\n setToolJSX: () => {},\n },\n )) {\n messages.push(message)\n\n if (message.type !== 'assistant') continue\n\n // Inject pending team messages between turns\n if (entry) {\n const unread = entry.mailbox.getUnread(agentId)\n if (unread.length > 0) {\n const {\n formatTeamMessagesForInjection,\n humanizeProtocolMessage,\n } = require('@services/agentTeams/messageFormatter')\n // Humanize protocol JSON messages for readability\n const humanized = unread.map(m => {\n const friendly = humanizeProtocolMessage(m.text)\n return friendly ? { ...m, summary: friendly } : m\n })\n const deliveryText = formatTeamMessagesForInjection(humanized)\n messages.push(createUserMessage(deliveryText))\n entry.mailbox.markRead(unread.map(m => m.id))\n }\n }\n\n turnCount++\n if (maxTurns && turnCount >= maxTurns) break\n }\n } catch (error) {\n // Log error to stderr (piped to parent)\n console.error(\n `[headless-agent] ${agentId} error:`,\n error instanceof Error ? error.message : error,\n )\n }\n\n // Mark idle and notify team lead\n await markTeammateIdle(teamName, agentId, agentName).catch(() => {})\n\n process.exit(0)\n}\n\nasync function main() {\n // Initialize configuration directories before any config access\n // This ensures all required directories exist for config, logs, sessions, etc.\n const configDirsResult = ensureConfigDirs()\n if (configDirsResult.errors.length > 0) {\n // Log errors but don't fail - some directories may have permission issues\n for (const err of configDirsResult.errors) {\n console.warn(`\u26A0\uFE0F Config directory warning: ${err.path} - ${err.error}`)\n }\n }\n\n // Run startup migrations (e.g., migrate scattered todo files to new structure)\n // This is non-blocking and runs silently in the background\n runStartupMigration().catch(() => {\n // Migration errors are logged internally but don't block startup\n })\n\n // Initialize i18n system based on config\n const globalConfig = getGlobalConfig()\n const configLang = globalConfig.language\n if (configLang && isLanguageSupported(configLang)) {\n initI18n(configLang as Language)\n } else {\n initI18n('en') // Default to English\n }\n\n // \u521D\u59CB\u5316\u8C03\u8BD5\u65E5\u5FD7\u7CFB\u7EDF\n initDebugLogger()\n\n // Register shell crash listener to notify user\n onShellCrash((code, signal) => {\n console.error('')\n console.error(\n `\u26A0\uFE0F Shell process crashed unexpectedly (code: ${code}, signal: ${signal})`,\n )\n console.error(\n ' Bash commands may fail. Try running /clear or restart the CLI.',\n )\n console.error('')\n })\n\n // Validate configs are valid and enable configuration system\n try {\n enableConfigs()\n\n // \uD83D\uDD27 Validate and auto-repair GPT-5 model profiles\n try {\n const repairResult = validateAndRepairAllGPT5Profiles()\n if (repairResult.repaired > 0) {\n console.log(\n `\uD83D\uDD27 Auto-repaired ${repairResult.repaired} GPT-5 model configurations`,\n )\n }\n } catch (repairError) {\n // Don't block startup if GPT-5 validation fails\n console.warn('\u26A0\uFE0F GPT-5 configuration validation failed:', repairError)\n }\n } catch (error: unknown) {\n if (error instanceof ConfigParseError) {\n // Show the invalid config dialog with the error object\n await showInvalidConfigDialog({ error })\n return // Exit after handling the config error\n }\n }\n\n // Disabled background notifier to avoid mid-screen logs during REPL\n\n let inputPrompt = ''\n let renderContext: RenderOptions | undefined = {\n exitOnCtrlC: false,\n\n onFlicker() {},\n } as any\n\n if (\n !process.stdin.isTTY &&\n !process.env.CI &&\n // Input hijacking breaks MCP.\n !process.argv.includes('mcp') &&\n // Headless agents have piped stdin with no writer \u2014 reading would block forever.\n !process.env.MINTO_HEADLESS\n ) {\n inputPrompt = await stdin()\n if (process.platform !== 'win32') {\n try {\n const ttyFd = openSync('/dev/tty', 'r')\n renderContext = { ...renderContext, stdin: new ReadStream(ttyFd) }\n } catch (err) {\n logError(`Could not open /dev/tty: ${err}`)\n }\n }\n }\n\n // Headless agents skip all interactive checks \u2014 go straight to arg parsing\n if (process.env.MINTO_HEADLESS) {\n await parseArgs(inputPrompt, renderContext, false)\n return\n }\n\n // Validate raw mode support before starting interactive mode\n // This catches environments where isTTY=true but setRawMode fails (e.g., Docker, VS Code)\n const stdinStream = (renderContext?.stdin ||\n process.stdin) as NodeJS.ReadStream\n const rawModeCheck = validateRawModeSupport(stdinStream)\n\n // Store the check result in renderContext for components to use\n ;(renderContext as any).rawModeSupported = rawModeCheck.supported\n ;(renderContext as any).fallbackMode = !rawModeCheck.supported\n\n // Log warning if raw mode is not supported (but don't exit yet - some commands don't need it)\n if (!rawModeCheck.supported) {\n console.warn(\n '\u26A0\uFE0F Interactive mode unavailable: terminal does not support raw mode',\n )\n console.warn(` Reason: ${rawModeCheck.reason}`)\n if (rawModeCheck.environmentHint) {\n console.warn(` Environment: ${rawModeCheck.environmentHint}`)\n }\n console.warn(\n ' Note: Use --print for non-interactive mode or see error message if REPL fails',\n )\n console.warn('')\n }\n\n await parseArgs(inputPrompt, renderContext, rawModeCheck.supported)\n}\n\nasync function parseArgs(\n stdinContent: string,\n renderContext: RenderOptions | undefined,\n rawModeSupported?: boolean,\n): Promise<Command> {\n const program = new Command()\n\n const renderContextWithExitOnCtrlC = {\n ...renderContext,\n exitOnCtrlC: true,\n }\n\n // Get built-in commands synchronously for instant startup\n // Full commands (MCP, custom, plugin) are loaded in REPL background\n const commands = getBuiltInCommands()\n\n // Format command list for help text (using same filter as in help.ts)\n const commandList = commands\n .filter(cmd => !cmd.isHidden)\n .map(cmd => `/${cmd.name} - ${cmd.description}`)\n .join('\\n')\n\n program\n .name(PRODUCT_COMMAND)\n .description(\n `${PRODUCT_NAME} - starts an interactive session by default, use -p/--print for non-interactive output\n\nSlash commands available during an interactive session:\n${commandList}`,\n )\n .argument('[prompt]', 'Your prompt', String)\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .option(\n '-c, --continue',\n 'Load the most recent conversation in the current directory',\n () => true,\n )\n .option('-d, --debug', 'Enable debug mode', () => true)\n .option(\n '--debug-verbose',\n 'Enable verbose debug terminal output',\n () => true,\n )\n .option(\n '--verbose',\n 'Override verbose mode setting from config',\n () => true,\n )\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option(\n '-p, --print',\n 'Print response and exit (useful for pipes)',\n () => true,\n )\n .option(\n '--free',\n 'Enable Free safety mode (device-wide full permission, all operations auto-allowed)',\n () => true,\n )\n .option(\n '--smart',\n 'Enable Smart safety mode (dangerous operations need confirmation)',\n () => true,\n )\n .option(\n '--strict',\n 'Enable Strict safety mode (all write operations need confirmation)',\n () => true,\n )\n .option(\n '-r, --resume [session]',\n 'Resume a specific session by ID, or show an interactive picker to choose a session',\n String,\n )\n .option(\n '-l, --lang <language>',\n 'Set interface language (en, zh-CN)',\n String,\n )\n .option(\n '--plugin-dir <dir>',\n 'Additional plugin directory to scan (merged with defaults)',\n String,\n )\n .option(\n '--teammate-mode <mode>',\n 'Teammate display mode: auto, in-process, tmux',\n String,\n )\n .option(\n '--headless-agent',\n 'Run as a teammate agent process (internal use)',\n () => true,\n )\n .option('--team <name>', 'Team name (used with --headless-agent)', String)\n .option(\n '--agent-id <id>',\n 'Agent ID within team (used with --headless-agent)',\n String,\n )\n .option(\n '--agent-name <name>',\n 'Agent display name (used with --headless-agent)',\n String,\n )\n .option(\n '--agent-type <type>',\n 'Agent type/role (used with --headless-agent)',\n String,\n )\n .option(\n '--max-turns <n>',\n 'Maximum API round-trips (used with --headless-agent)',\n parseInt,\n )\n .option(\n '--model <name>',\n 'Model to use (used with --headless-agent)',\n String,\n )\n .option(\n '--permission-mode <mode>',\n 'Permission mode override (used with --headless-agent)',\n String,\n )\n .option(\n '--plan-mode-required',\n 'Force plan mode for this agent (used with --headless-agent)',\n () => true,\n )\n .option(\n '--agent-color <color>',\n 'Agent display color (used with --headless-agent)',\n String,\n )\n .option(\n '--parent-session-id <id>',\n 'Parent session ID (used with --headless-agent)',\n String,\n )\n .action(\n async (\n prompt,\n {\n cwd,\n debug,\n verbose,\n enableArchitect,\n print,\n free,\n smart,\n strict,\n continue: continueSession,\n resume: resumeSession,\n lang,\n pluginDir,\n teammateMode,\n headlessAgent,\n team: teamName,\n agentId,\n agentName,\n agentType,\n maxTurns,\n model: cliModel,\n permissionMode,\n planModeRequired,\n agentColor,\n parentSessionId,\n },\n ) => {\n // \u2500\u2500 Headless Agent Mode \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\n // When launched as a headless teammate via fork(), run agent\n // loop directly without REPL UI.\n if (headlessAgent) {\n await runHeadlessAgent({\n cwd,\n teamName: teamName!,\n agentId: agentId!,\n agentName: agentName!,\n agentType: agentType!,\n prompt: prompt || '',\n maxTurns,\n // CLI args override env var fallbacks (CC-compatible format)\n model: cliModel || process.env.MINTO_AGENT_MODEL,\n permissionMode: permissionMode || process.env.MINTO_AGENT_MODE,\n planModeRequired:\n planModeRequired || process.env.MINTO_PLAN_MODE_REQUIRED === '1',\n agentColor,\n parentSessionId:\n parentSessionId || process.env.MINTO_PARENT_SESSION_ID,\n })\n return\n }\n\n // Apply language override from CLI flag\n if (lang && isLanguageSupported(lang)) {\n setLanguage(lang as Language)\n }\n\n // Register extra plugin directory from CLI flag\n if (pluginDir) {\n const { addExtraPluginDir } = await import('@utils/pluginLoader')\n addExtraPluginDir(pluginDir)\n }\n\n // Determine safety mode: yolo (default, project-scoped) < free < smart < strict\n // Priority: strict > smart > free > yolo\n // Environment variable MINTO_SAFETY_MODE can override CLI flags\n const envSafetyMode = process.env.MINTO_SAFETY_MODE\n const safetyMode: SafetyMode = envSafetyMode\n ? (envSafetyMode as SafetyMode)\n : strict\n ? 'strict'\n : smart\n ? 'smart'\n : free\n ? 'free'\n : 'yolo'\n\n // Legacy safeMode for backward compatibility with showSetupScreens\n const safeMode = safetyMode !== 'yolo' && safetyMode !== 'free'\n\n // Preload dynamic imports early so they overlap with setup\n const inkPromise = import('ink')\n const replPromise = import('@screens/REPL')\n\n await showSetupScreens(safeMode, print, rawModeSupported)\n\n await setup(cwd, safeMode)\n\n assertMinVersion()\n\n // Fast startup: load only built-in tools (no MCP, no network I/O)\n // Skip description cache to avoid filesystem I/O from agent loading\n // MCP tools, descriptions, and update check are deferred to REPL background loading\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n const tools = await getBuiltInTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n { skipDescriptionCache: true },\n )\n const inputPrompt = [prompt, stdinContent].filter(Boolean).join('\\n')\n if (print) {\n if (!inputPrompt) {\n console.error(\n 'Error: Input must be provided either through stdin or as a prompt argument when using --print',\n )\n process.exit(1)\n }\n\n // Print mode needs full tools (including MCP) since there's no REPL to defer loading\n const fullTools = await getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n )\n addToHistory(inputPrompt)\n const { resultText: response } = await ask({\n commands,\n hasPermissionsToUseTool,\n messageLogName: dateToFilename(new Date()),\n prompt: inputPrompt,\n cwd,\n tools: fullTools,\n safeMode,\n safetyMode,\n })\n console.log(response)\n process.exit(0)\n } else {\n // Interactive REPL requires raw mode - check before rendering\n // We check fallbackMode instead of isTTY because we need raw mode support, not just TTY\n if ((renderContext as any)?.fallbackMode) {\n // Raw mode not supported - exit with helpful error\n requireRawModeOrExit(process.stdin, true)\n }\n\n // Handle -r/--resume: resume a specific session or show interactive picker\n if (resumeSession) {\n if (typeof resumeSession === 'string') {\n // Resume a specific session by ID\n const logs = await loadLogList(CACHE_PATHS.messages())\n const matchedLog = logs.find(\n log =>\n log.date === resumeSession ||\n log.fullPath.includes(resumeSession),\n )\n if (!matchedLog) {\n console.error(\n `Session not found: ${resumeSession}\\nUse \"minto -r\" to see available sessions.`,\n )\n process.exit(1)\n }\n const { deserializeMessages } = await import(\n '@utils/conversationRecovery'\n )\n const { render } = await inkPromise\n const { REPL } = await replPromise\n await prepareTerminalForREPL()\n render(\n <REPL\n commands={commands}\n debug={debug}\n messageLogName={matchedLog.date}\n initialPrompt=\"\"\n shouldShowPromptInput={true}\n verbose={verbose}\n tools={tools}\n safeMode={safeMode}\n safetyMode={safetyMode}\n mcpClients={[]}\n isDefaultModel={isDefaultModel}\n initialUpdateVersion={null}\n initialUpdateCommands={null}\n enableArchitect={\n enableArchitect ??\n getCurrentProjectConfig().enableArchitectTool\n }\n fallbackMode={(renderContext as any)?.fallbackMode}\n initialMessages={deserializeMessages(\n matchedLog.messages,\n tools,\n )}\n initialForkNumber={getNextAvailableLogForkNumber(\n matchedLog.date,\n matchedLog.forkNumber ?? 1,\n 0,\n )}\n isResumedConversation={true}\n />,\n renderContext,\n )\n return\n }\n\n // No session ID \u2014 show interactive picker\n const logs = await loadLogList(CACHE_PATHS.messages())\n const context: { unmount?: () => void } = {}\n const { render } = await import('ink')\n const { ResumeConversation } = await import(\n '@screens/ResumeConversation'\n )\n const { unmount } = render(\n <ResumeConversation\n context={context}\n commands={commands}\n logs={logs}\n tools={tools}\n verbose={verbose}\n />,\n { ...renderContext, exitOnCtrlC: true },\n )\n context.unmount = unmount\n return\n }\n\n // Handle -c/--continue: load most recent conversation in current directory\n if (continueSession) {\n const logs = await loadLogList(CACHE_PATHS.messages())\n // Find most recent conversation for the current project\n const projectLog = logs.find(log => {\n const firstMsg = log.messages[0]\n return firstMsg?.cwd === cwd\n })\n if (projectLog) {\n const { deserializeMessages } = await import(\n '@utils/conversationRecovery'\n )\n const { render } = await inkPromise\n const { REPL } = await replPromise\n await prepareTerminalForREPL()\n render(\n <REPL\n commands={commands}\n debug={debug}\n messageLogName={projectLog.date}\n initialPrompt={inputPrompt || ''}\n shouldShowPromptInput={true}\n verbose={verbose}\n tools={tools}\n safeMode={safeMode}\n safetyMode={safetyMode}\n mcpClients={[]}\n isDefaultModel={isDefaultModel}\n initialUpdateVersion={null}\n initialUpdateCommands={null}\n enableArchitect={\n enableArchitect ??\n getCurrentProjectConfig().enableArchitectTool\n }\n fallbackMode={(renderContext as any)?.fallbackMode}\n initialMessages={deserializeMessages(\n projectLog.messages,\n tools,\n )}\n initialForkNumber={getNextAvailableLogForkNumber(\n projectLog.date,\n projectLog.forkNumber ?? 1,\n 0,\n )}\n isResumedConversation={true}\n />,\n renderContext,\n )\n return\n }\n // No previous conversation found \u2014 fall through to new conversation\n }\n\n // Default: start a new conversation\n const messageLogName = dateToFilename(new Date())\n\n {\n // Use preloaded imports (already resolved by now)\n const { render } = await inkPromise\n const { REPL } = await replPromise\n\n // Clear screen and prepare terminal for REPL\n // This provides a clean slate for the Minto interface\n await prepareTerminalForREPL()\n\n render(\n <REPL\n commands={commands}\n debug={debug}\n initialPrompt={inputPrompt}\n messageLogName={messageLogName}\n shouldShowPromptInput={true}\n verbose={verbose}\n tools={tools}\n safeMode={safeMode}\n safetyMode={safetyMode}\n mcpClients={[]}\n isDefaultModel={isDefaultModel}\n initialUpdateVersion={null}\n initialUpdateCommands={null}\n enableArchitect={\n enableArchitect ??\n getCurrentProjectConfig().enableArchitectTool\n }\n fallbackMode={(renderContext as any)?.fallbackMode}\n />,\n renderContext,\n )\n }\n }\n },\n )\n .version(MACRO.VERSION, '-v, --version')\n\n // Enable melon mode for ants if --melon is passed\n // For bun tree shaking to work, this has to be a top level --define, not inside MACRO\n // if (process.env.USER_TYPE === 'ant') {\n // program\n // .option('--melon', 'Enable melon mode')\n // .hook('preAction', async () => {\n // if ((program.opts() as { melon?: boolean }).melon) {\n // const { runMelonWrapper } = await import('../utils/melonWrapper')\n // const melonArgs = process.argv.slice(\n // process.argv.indexOf('--melon') + 1,\n // )\n // const exitCode = runMelonWrapper(melonArgs)\n // process.exit(exitCode)\n // }\n // })\n // }\n\n // claude config\n const config = program\n .command('config')\n .description(\n `Manage configuration (eg. ${PRODUCT_COMMAND} config set -g theme dark)`,\n )\n\n config\n .command('get <key>')\n .description('Get a config value')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n console.log(getConfigForCLI(key, global ?? false))\n process.exit(0)\n })\n\n config\n .command('set <key> <value>')\n .description('Set a config value')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, value, { cwd, global }) => {\n await setup(cwd, false)\n setConfigForCLI(key, value, global ?? false)\n console.log(`Set ${key} to ${value}`)\n process.exit(0)\n })\n\n config\n .command('remove <key>')\n .description('Remove a config value')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n deleteConfigForCLI(key, global ?? false)\n console.log(`Removed ${key}`)\n process.exit(0)\n })\n\n config\n .command('list')\n .description('List all config values')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config', false)\n .action(async ({ cwd, global }) => {\n await setup(cwd, false)\n console.log(\n JSON.stringify(\n global ? listConfigForCLI(true) : listConfigForCLI(false),\n null,\n 2,\n ),\n )\n process.exit(0)\n })\n\n // minto setup - import team configuration\n program\n .command('setup')\n .description('Initialize Minto with team configuration from a URL or file')\n .requiredOption(\n '--from <source>',\n 'URL or file path to the team configuration JSON',\n )\n .option(\n '--strategy <strategy>',\n 'Merge strategy: merge, replace, or skip-existing',\n 'merge',\n )\n .option('--no-plugins', 'Skip installing plugins, agents, and hooks')\n .action(\n async (options: { from: string; strategy: string; plugins: boolean }) => {\n const {\n from: source,\n strategy,\n plugins: shouldInstallPlugins,\n } = options\n\n try {\n const {\n fetchTeamConfig,\n loadTeamConfigFromFile,\n applyTeamConfig,\n addMarketplaces,\n installPlugins,\n installRemoteAgents,\n installInlineAgents,\n installTeamHooks,\n } = await import('@utils/teamConfig')\n\n // Step 1: Load configuration\n console.log(`Loading configuration from ${source}...`)\n\n const teamConfig =\n source.startsWith('http://') || source.startsWith('https://')\n ? await fetchTeamConfig(source)\n : loadTeamConfigFromFile(source)\n\n // Step 2: Apply configuration\n console.log('Applying configuration...')\n\n const result = applyTeamConfig(teamConfig, strategy as MergeStrategy)\n\n // Step 3: Add marketplaces (if configured)\n let marketplacesAdded = 0\n if (shouldInstallPlugins && teamConfig.plugins?.marketplaces) {\n console.log(\n `Adding ${teamConfig.plugins.marketplaces.length} marketplace(s)...`,\n )\n const marketplaceResult = await addMarketplaces(\n teamConfig.plugins.marketplaces,\n )\n marketplacesAdded = marketplaceResult.added\n }\n\n // Step 4: Install plugins (if configured)\n let pluginsInstalled = 0\n if (shouldInstallPlugins && teamConfig.plugins?.install) {\n console.log(\n `Installing ${teamConfig.plugins.install.length} plugin(s)...`,\n )\n const pluginResult = await installPlugins(\n teamConfig.plugins.install,\n )\n pluginsInstalled = pluginResult.installed\n }\n\n // Step 5: Install agents (if configured)\n let agentsInstalled = 0\n if (shouldInstallPlugins && teamConfig.agents) {\n const remoteCount = teamConfig.agents.remoteAgents?.length || 0\n const inlineCount = teamConfig.agents.inlineAgents?.length || 0\n const totalAgents = remoteCount + inlineCount\n\n if (totalAgents > 0) {\n console.log(`Installing ${totalAgents} agent(s)...`)\n\n if (teamConfig.agents.remoteAgents) {\n const remoteResult = await installRemoteAgents(\n teamConfig.agents.remoteAgents,\n )\n agentsInstalled += remoteResult.installed\n }\n\n if (teamConfig.agents.inlineAgents) {\n const inlineResult = await installInlineAgents(\n teamConfig.agents.inlineAgents,\n )\n agentsInstalled += inlineResult.installed\n }\n }\n }\n\n // Step 6: Install hooks (if configured)\n let hooksInstalled = false\n if (shouldInstallPlugins && teamConfig.hooks) {\n console.log('Installing hooks...')\n const hookResult = await installTeamHooks(teamConfig.hooks)\n hooksInstalled = hookResult.installed\n }\n\n // Success output\n console.log('\\n\u2713 Configuration applied successfully!\\n')\n\n if (result.modelsAdded > 0) {\n console.log(` \u2022 Added ${result.modelsAdded} model profile(s)`)\n }\n if (result.mcpServersAdded > 0) {\n console.log(` \u2022 Added ${result.mcpServersAdded} MCP server(s)`)\n }\n if (result.settingsUpdated.length > 0) {\n console.log(\n ` \u2022 Updated ${result.settingsUpdated.length} setting(s): ${result.settingsUpdated.join(', ')}`,\n )\n }\n if (marketplacesAdded > 0) {\n console.log(` \u2022 Added ${marketplacesAdded} marketplace(s)`)\n }\n if (pluginsInstalled > 0) {\n console.log(` \u2022 Installed ${pluginsInstalled} plugin(s)`)\n }\n if (agentsInstalled > 0) {\n console.log(` \u2022 Installed ${agentsInstalled} agent(s)`)\n }\n if (hooksInstalled) {\n console.log(' \u2022 Installed hooks configuration')\n }\n\n if (teamConfig.postInstallInstructions) {\n console.log('\\n\uD83D\uDCCB Next Steps:')\n console.log(teamConfig.postInstallInstructions)\n }\n\n console.log(\n `\\nRun \"${PRODUCT_COMMAND}\" to start using your configured setup.`,\n )\n process.exit(0)\n } catch (error) {\n console.error(\n '\u2717 Setup failed:',\n error instanceof Error ? error.message : String(error),\n )\n process.exit(1)\n }\n },\n )\n\n // minto login\n program\n .command('login')\n .description('Login and auto-configure available models')\n .option('-u, --user <user>', 'Username')\n .option('-p, --password <password>', 'Password')\n .action(async (options: { user?: string; password?: string }) => {\n await setup(getCwd(), false)\n const { handleLoginCLI } = await import('@services/mintoAuth')\n await handleLoginCLI(options.user, options.password)\n process.exit(0)\n })\n\n // claude approved-tools\n\n const allowedTools = program\n .command('approved-tools')\n .description('Manage approved tools')\n\n allowedTools\n .command('list')\n .description('List all approved tools')\n .action(async () => {\n const { handleListApprovedTools } = await import(\n '@commands/approvedTools'\n )\n const result = handleListApprovedTools(getCwd())\n console.log(result)\n process.exit(0)\n })\n\n allowedTools\n .command('remove <tool>')\n .description('Remove a tool from the list of approved tools')\n .action(async (tool: string) => {\n const { handleRemoveApprovedTool } = await import(\n '@commands/approvedTools'\n )\n const result = handleRemoveApprovedTool(tool)\n console.log(result.message)\n process.exit(result.success ? 0 : 1)\n })\n\n // claude mcp\n\n const mcp = program\n .command('mcp')\n .description('Configure and manage MCP servers')\n\n mcp\n .command('serve')\n .description(`Start the ${PRODUCT_NAME} MCP server`)\n .action(async () => {\n const providedCwd = (program.opts() as { cwd?: string }).cwd ?? cwd()\n\n // Verify the directory exists\n if (!existsSync(providedCwd)) {\n console.error(`Error: Directory ${providedCwd} does not exist`)\n process.exit(1)\n }\n\n try {\n await setup(providedCwd, false)\n const { startMCPServer } = await import('./mcp')\n await startMCPServer(providedCwd)\n } catch (error) {\n console.error('Error: Failed to start MCP server:', error)\n process.exit(1)\n }\n })\n\n mcp\n .command('add-sse <name> <url>')\n .description('Add an SSE server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, url, options) => {\n try {\n const { addMcpServer, ensureConfigScope } = await import(\n '@services/mcpClient'\n )\n const scope = ensureConfigScope(options.scope)\n\n addMcpServer(name, { type: 'sse', url }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${url} to ${scope} config`,\n )\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('add [name] [commandOrUrl] [args...]')\n .description('Add a server (run without arguments for interactive wizard)')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .option(\n '-e, --env <env...>',\n 'Set environment variables (e.g. -e KEY=value)',\n )\n .action(async (name, commandOrUrl, args, options) => {\n try {\n const { addMcpServer, parseEnvVars, ensureConfigScope } = await import(\n '@services/mcpClient'\n )\n // If name is not provided, start interactive wizard\n if (!name) {\n console.log('Interactive wizard mode: Enter the server details')\n const { createInterface } = await import('readline')\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n })\n\n const question = (query: string) =>\n new Promise<string>(resolve => rl.question(query, resolve))\n\n // Get server name\n const serverName = await question('Server name: ')\n if (!serverName) {\n console.error('Error: Server name is required')\n rl.close()\n process.exit(1)\n }\n\n // Get server type\n const serverType = await question(\n 'Server type (stdio or sse) [stdio]: ',\n )\n const type =\n serverType && ['stdio', 'sse'].includes(serverType)\n ? serverType\n : 'stdio'\n\n // Get command or URL\n const prompt = type === 'stdio' ? 'Command: ' : 'URL: '\n const commandOrUrlValue = await question(prompt)\n if (!commandOrUrlValue) {\n console.error(\n `Error: ${type === 'stdio' ? 'Command' : 'URL'} is required`,\n )\n rl.close()\n process.exit(1)\n }\n\n // Get args and env if stdio\n let serverArgs: string[] = []\n let serverEnv: Record<string, string> = {}\n\n if (type === 'stdio') {\n const argsStr = await question(\n 'Command arguments (space-separated): ',\n )\n serverArgs = argsStr ? argsStr.split(' ').filter(Boolean) : []\n\n const envStr = await question(\n 'Environment variables (format: KEY1=value1,KEY2=value2): ',\n )\n if (envStr) {\n const envPairs = envStr.split(',').map(pair => pair.trim())\n serverEnv = parseEnvVars(envPairs.map(pair => pair))\n }\n }\n\n // Get scope\n const scopeStr = await question(\n 'Configuration scope (project or global) [project]: ',\n )\n const serverScope = ensureConfigScope(scopeStr || 'project')\n\n rl.close()\n\n // Add the server\n if (type === 'sse') {\n addMcpServer(\n serverName,\n { type: 'sse', url: commandOrUrlValue },\n serverScope,\n )\n console.log(\n `Added SSE MCP server ${serverName} with URL ${commandOrUrlValue} to ${serverScope} config`,\n )\n } else {\n addMcpServer(\n serverName,\n {\n type: 'stdio',\n command: commandOrUrlValue,\n args: serverArgs,\n env: serverEnv,\n },\n serverScope,\n )\n\n console.log(\n `Added stdio MCP server ${serverName} with command: ${commandOrUrlValue} ${serverArgs.join(' ')} to ${serverScope} config`,\n )\n }\n } else if (name && commandOrUrl) {\n // Regular non-interactive flow\n const scope = ensureConfigScope(options.scope)\n\n // Check if it's an SSE URL (starts with http:// or https://)\n if (commandOrUrl.match(/^https?:\\/\\//)) {\n addMcpServer(name, { type: 'sse', url: commandOrUrl }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${commandOrUrl} to ${scope} config`,\n )\n } else {\n const env = parseEnvVars(options.env)\n addMcpServer(\n name,\n { type: 'stdio', command: commandOrUrl, args: args || [], env },\n scope,\n )\n\n console.log(\n `Added stdio MCP server ${name} with command: ${commandOrUrl} ${(args || []).join(' ')} to ${scope} config`,\n )\n }\n } else {\n console.error(\n 'Error: Missing required arguments. Either provide no arguments for interactive mode or specify name and command/URL.',\n )\n process.exit(1)\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n mcp\n .command('remove <name>')\n .description('Remove an MCP server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project, global, or mcprc)',\n 'project',\n )\n .action(async (name: string, options: { scope?: string }) => {\n try {\n const { removeMcpServer, ensureConfigScope } = await import(\n '@services/mcpClient'\n )\n const scope = ensureConfigScope(options.scope)\n\n removeMcpServer(name, scope)\n console.log(`Removed MCP server ${name} from ${scope} config`)\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('list')\n .description('List configured MCP servers')\n .action(async () => {\n const { listMCPServers } = await import('@services/mcpClient')\n const servers = listMCPServers()\n if (Object.keys(servers).length === 0) {\n console.log(\n `No MCP servers configured. Use \\`${PRODUCT_COMMAND} mcp add\\` to add a server.`,\n )\n } else {\n for (const [name, server] of Object.entries(servers)) {\n if (server.type === 'sse') {\n console.log(`${name}: ${server.url} (SSE)`)\n } else if (server.type === 'http') {\n console.log(`${name}: ${(server as any).url} (HTTP)`)\n } else {\n console.log(\n `${name}: ${(server as any).command} ${((server as any).args || []).join(' ')}`,\n )\n }\n }\n }\n process.exit(0)\n })\n\n mcp\n .command('add-json <name> <json>')\n .description('Add an MCP server (stdio or SSE) with a JSON string')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, jsonStr, options) => {\n try {\n const { addMcpServer, ensureConfigScope } = await import(\n '@services/mcpClient'\n )\n const scope = ensureConfigScope(options.scope)\n\n // Parse JSON string\n let serverConfig\n try {\n serverConfig = JSON.parse(jsonStr)\n } catch (e) {\n console.error('Error: Invalid JSON string')\n process.exit(1)\n }\n\n // Validate the server config\n if (\n !serverConfig.type ||\n !['stdio', 'sse'].includes(serverConfig.type)\n ) {\n console.error('Error: Server type must be \"stdio\" or \"sse\"')\n process.exit(1)\n }\n\n if (serverConfig.type === 'sse' && !serverConfig.url) {\n console.error('Error: SSE server must have a URL')\n process.exit(1)\n }\n\n if (serverConfig.type === 'stdio' && !serverConfig.command) {\n console.error('Error: stdio server must have a command')\n process.exit(1)\n }\n\n // Add server with the provided config\n\n addMcpServer(name, serverConfig, scope)\n\n if (serverConfig.type === 'sse') {\n console.log(\n `Added SSE MCP server ${name} with URL ${serverConfig.url} to ${scope} config`,\n )\n } else {\n console.log(\n `Added stdio MCP server ${name} with command: ${serverConfig.command} ${(\n serverConfig.args || []\n ).join(' ')} to ${scope} config`,\n )\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('get <name>')\n .description('Get details about an MCP server')\n .action(async (name: string) => {\n const { getMcpServer } = await import('@services/mcpClient')\n const server = getMcpServer(name)\n if (!server) {\n console.error(`No MCP server found with name: ${name}`)\n process.exit(1)\n }\n console.log(`${name}:`)\n console.log(` Scope: ${server.scope}`)\n if (server.type === 'sse') {\n console.log(` Type: sse`)\n console.log(` URL: ${server.url}`)\n } else if (server.type === 'http') {\n console.log(` Type: http`)\n console.log(` URL: ${(server as any).url}`)\n } else {\n console.log(` Type: stdio`)\n console.log(` Command: ${(server as any).command}`)\n console.log(` Args: ${((server as any).args || []).join(' ')}`)\n if ((server as any).env) {\n console.log(' Environment:')\n for (const [key, value] of Object.entries((server as any).env)) {\n console.log(` ${key}=${value}`)\n }\n }\n }\n process.exit(0)\n })\n\n // Import servers from Claude Desktop\n mcp\n .command('add-from-claude-desktop')\n .description(\n 'Import MCP servers from Claude Desktop (Mac, Windows and WSL)',\n )\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async options => {\n try {\n const { addMcpServer, getMcpServer, ensureConfigScope } = await import(\n '@services/mcpClient'\n )\n const scope = ensureConfigScope(options.scope)\n const platform = process.platform\n\n // Import fs and path modules\n const { existsSync, readFileSync } = await import('fs')\n const { join } = await import('path')\n const { exec } = await import('child_process')\n\n // Determine if running in WSL\n const isWSL =\n platform === 'linux' &&\n existsSync('/proc/version') &&\n readFileSync('/proc/version', 'utf-8')\n .toLowerCase()\n .includes('microsoft')\n\n if (platform !== 'darwin' && platform !== 'win32' && !isWSL) {\n console.error(\n 'Error: This command is only supported on macOS, Windows, and WSL',\n )\n process.exit(1)\n }\n\n // Get Claude Desktop config path\n let configPath\n if (platform === 'darwin') {\n configPath = join(\n process.env.HOME || '~',\n 'Library/Application Support/Claude/claude_desktop_config.json',\n )\n } else if (platform === 'win32') {\n configPath = join(\n process.env.APPDATA || '',\n 'Claude/claude_desktop_config.json',\n )\n } else if (isWSL) {\n // Get Windows username\n const whoamiCommand = await new Promise<string>((resolve, reject) => {\n exec(\n 'powershell.exe -Command \"whoami\"',\n (err: Error, stdout: string) => {\n if (err) reject(err)\n else resolve(stdout.trim().split('\\\\').pop() || '')\n },\n )\n })\n\n configPath = `/mnt/c/Users/${whoamiCommand}/AppData/Roaming/Claude/claude_desktop_config.json`\n }\n\n // Check if config file exists\n if (!existsSync(configPath)) {\n console.error(\n `Error: Claude Desktop config file not found at ${configPath}`,\n )\n process.exit(1)\n }\n\n // Read config file\n let config\n try {\n const configContent = readFileSync(configPath, 'utf-8')\n config = JSON.parse(configContent)\n } catch (err) {\n console.error(`Error reading config file: ${err}`)\n process.exit(1)\n }\n\n // Extract MCP servers\n const mcpServers = config.mcpServers || {}\n const serverNames = Object.keys(mcpServers)\n const numServers = serverNames.length\n\n if (numServers === 0) {\n console.log('No MCP servers found in Claude Desktop config')\n process.exit(0)\n }\n\n // Create server information for display\n const serversInfo = serverNames.map(name => {\n const server = mcpServers[name]\n let description = ''\n\n if (server.type === 'sse') {\n description = `SSE: ${server.url}`\n } else {\n description = `stdio: ${server.command} ${(server.args || []).join(' ')}`\n }\n\n return { name, description, server }\n })\n\n // First import all required modules outside the component\n // Import modules separately to avoid any issues\n const ink = await import('ink')\n const reactModule = await import('react')\n const inkjsui = await import('@inkjs/ui')\n const utilsTheme = await import('@utils/theme')\n\n const { render } = ink\n const React = reactModule // React is already the default export when imported this way\n const { MultiSelect } = inkjsui\n const { Box, Text } = ink\n const { getTheme } = utilsTheme\n\n // Use Ink to render a nice UI for selection\n await new Promise<void>(resolve => {\n // Create a component for the server selection\n function ClaudeDesktopImport() {\n const { useState } = reactModule\n const [isFinished, setIsFinished] = useState(false)\n const [importResults, setImportResults] = useState(\n [] as { name: string; success: boolean }[],\n )\n const [isImporting, setIsImporting] = useState(false)\n const theme = getTheme()\n\n // Function to import selected servers\n const importServers = async (selectedServers: string[]) => {\n setIsImporting(true)\n const results = []\n\n for (const name of selectedServers) {\n try {\n const server = mcpServers[name]\n\n // Check if server already exists\n const existingServer = getMcpServer(name)\n if (existingServer) {\n // Skip duplicates - we'll handle them in the confirmation step\n continue\n }\n\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results\n setTimeout(() => {\n resolve()\n }, 1000)\n }\n\n // Handle confirmation of selections\n const handleConfirm = async (selectedServers: string[]) => {\n // Check for existing servers and confirm overwrite\n const existingServers = selectedServers.filter(name =>\n getMcpServer(name),\n )\n\n if (existingServers.length > 0) {\n // We'll just handle it directly since we have a simple UI\n const results = []\n\n // Process non-existing servers first\n const newServers = selectedServers.filter(\n name => !getMcpServer(name),\n )\n for (const name of newServers) {\n try {\n const server = mcpServers[name]\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n // Now handle existing servers by prompting for each one\n for (const name of existingServers) {\n try {\n const server = mcpServers[name]\n // Overwrite existing server - in a real interactive UI you'd prompt here\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results before resolving\n setTimeout(() => {\n resolve()\n }, 1000)\n } else {\n // No existing servers, proceed with import\n await importServers(selectedServers)\n }\n }\n\n return (\n <Box flexDirection=\"column\" padding={1}>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={theme.minto}\n padding={1}\n width={'100%'}\n >\n <Text bold color={theme.minto}>\n Import MCP Servers from Claude Desktop\n </Text>\n\n <Box marginY={1}>\n <Text>\n Found {numServers} MCP servers in Claude Desktop.\n </Text>\n </Box>\n\n <Text>Please select the servers you want to import:</Text>\n\n <Box marginTop={1}>\n <MultiSelect\n options={serverNames.map(name => ({\n label: name,\n value: name,\n }))}\n defaultValue={serverNames}\n onSubmit={handleConfirm}\n />\n </Box>\n </Box>\n\n <Box marginTop={0} marginLeft={3}>\n <Text color={SEMANTIC_COLORS.dim}>\n Space to select \u00B7 Enter to confirm \u00B7 Esc to cancel\n </Text>\n </Box>\n\n {isFinished && (\n <Box marginTop={1}>\n <Text color={theme.success}>\n Successfully imported{' '}\n {importResults.filter(r => r.success).length} MCP server\n to local config.\n </Text>\n </Box>\n )}\n </Box>\n )\n }\n\n // Render the component\n const { unmount } = render(<ClaudeDesktopImport />)\n\n // Clean up when done\n setTimeout(() => {\n unmount()\n resolve()\n }, 30000) // Timeout after 30 seconds as a fallback\n })\n\n process.exit(0)\n } catch (error) {\n console.error(`Error: ${(error as Error).message}`)\n process.exit(1)\n }\n })\n\n // Function to reset MCP server choices\n const resetMcpChoices = () => {\n const config = getCurrentProjectConfig()\n saveCurrentProjectConfig({\n ...config,\n approvedMcprcServers: [],\n rejectedMcprcServers: [],\n })\n console.log('All .mcprc server approvals and rejections have been reset.')\n console.log(\n `You will be prompted for approval next time you start ${PRODUCT_NAME}.`,\n )\n process.exit(0)\n }\n\n // New command name to match Minto\n mcp\n .command('reset-project-choices')\n .description(\n 'Reset all approved and rejected project-scoped (.mcp.json) servers within this project',\n )\n .action(() => {\n resetMcpChoices()\n })\n\n // Keep old command for backward compatibility (visible only to ants)\n if (process.env.USER_TYPE === 'ant') {\n mcp\n .command('reset-mcprc-choices')\n .description(\n 'Reset all approved and rejected .mcprc servers for this project',\n )\n .action(() => {\n resetMcpChoices()\n })\n }\n\n // ant-only commands\n\n // claude update\n program\n .command('update')\n .description('Show manual upgrade commands (no auto-install)')\n .action(async () => {\n console.log(`Current version: ${MACRO.VERSION}`)\n console.log('Checking for updates...')\n\n const { getLatestVersion } = await import('@utils/autoUpdater')\n const latestVersion = await getLatestVersion()\n\n if (!latestVersion) {\n console.error('Failed to check for updates')\n process.exit(1)\n }\n\n if (latestVersion === MACRO.VERSION) {\n console.log(`${PRODUCT_NAME} is up to date`)\n process.exit(0)\n }\n\n console.log(`New version available: ${latestVersion}`)\n const { getUpdateCommandSuggestions } = await import('@utils/autoUpdater')\n const cmds = await getUpdateCommandSuggestions()\n console.log('\\nRun one of the following commands to update:')\n for (const c of cmds) console.log(` ${c}`)\n if (process.platform !== 'win32') {\n console.log(\n '\\nNote: you may need to prefix with \"sudo\" on macOS/Linux.',\n )\n }\n process.exit(0)\n })\n\n // claude log\n program\n .command('log')\n .description('Manage conversation logs.')\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { LogList } = await import('@screens/LogList')\n const { unmount } = render(\n <LogList context={context} type=\"messages\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // claude resume\n program\n .command('resume')\n .description(\n 'Resume a previous conversation. Optionally provide a number (0, 1, 2, etc.) or file path to resume a specific conversation.',\n )\n .argument(\n '[identifier]',\n 'A number (0, 1, 2, etc.) or file path to resume a specific conversation',\n )\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option('-v, --verbose', 'Do not truncate message output', () => true)\n .option(\n '--free',\n 'Enable Free safety mode (device-wide full permission, all operations auto-allowed)',\n () => true,\n )\n .option(\n '--smart',\n 'Enable Smart safety mode (dangerous operations need confirmation)',\n () => true,\n )\n .option(\n '--strict',\n 'Enable Strict safety mode (all write operations need confirmation)',\n () => true,\n )\n .action(\n async (\n identifier,\n { cwd, enableArchitect, free, smart, strict, verbose },\n ) => {\n // Determine safety mode: yolo (default) < free < smart < strict\n const envSafetyMode = process.env.MINTO_SAFETY_MODE\n const safetyMode: SafetyMode = envSafetyMode\n ? (envSafetyMode as SafetyMode)\n : strict\n ? 'strict'\n : smart\n ? 'smart'\n : free\n ? 'free'\n : 'yolo'\n const safeMode = safetyMode !== 'yolo' && safetyMode !== 'free'\n await setup(cwd, safeMode)\n assertMinVersion()\n\n const { getClients } = await import('@services/mcpClient')\n const [tools, commands, logs, mcpClients] = await Promise.all([\n getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n ),\n getCommands(),\n loadLogList(CACHE_PATHS.messages()),\n getClients(),\n ])\n\n // If a specific conversation is requested, load and resume it directly\n if (identifier !== undefined) {\n // Check if identifier is a number or a file path\n const number = Math.abs(parseInt(identifier))\n const isNumber = !isNaN(number)\n let messages, date, forkNumber\n try {\n if (isNumber) {\n const log = logs[number]\n if (!log) {\n console.error('No conversation found at index', number)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(log.fullPath, tools)\n ;({ date, forkNumber } = log)\n } else {\n // Handle file path case\n\n if (!existsSync(identifier)) {\n console.error('File does not exist:', identifier)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(identifier, tools)\n const pathSegments = identifier.split('/')\n const filename =\n pathSegments[pathSegments.length - 1] ?? 'unknown'\n ;({ date, forkNumber } = parseLogFilename(filename))\n }\n const fork = getNextAvailableLogForkNumber(date, forkNumber ?? 1, 0)\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n\n // Interactive REPL requires raw mode - always check (not just isTTY)\n // This handles cases where stdin is not TTY or setRawMode is not supported\n const forkRawModeCheck = validateRawModeSupport(process.stdin)\n if (!forkRawModeCheck.supported) {\n requireRawModeOrExit(process.stdin, true)\n }\n\n {\n const { render } = await import('ink')\n const { REPL } = await import('@screens/REPL')\n\n // Clear screen and prepare terminal for REPL\n await prepareTerminalForREPL()\n\n render(\n <REPL\n initialPrompt=\"\"\n messageLogName={date}\n initialForkNumber={fork}\n shouldShowPromptInput={true}\n verbose={verbose}\n commands={commands}\n tools={tools}\n safeMode={safeMode}\n safetyMode={safetyMode}\n initialMessages={messages}\n mcpClients={mcpClients}\n isDefaultModel={isDefaultModel}\n fallbackMode={false}\n />,\n { exitOnCtrlC: false },\n )\n }\n } catch (error) {\n logError(`Failed to load conversation: ${error}`)\n process.exit(1)\n }\n } else {\n // Show the conversation selector UI\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { ResumeConversation } = await import(\n '@screens/ResumeConversation'\n )\n const { unmount } = render(\n <ResumeConversation\n context={context}\n commands={commands}\n logs={logs}\n tools={tools}\n verbose={verbose}\n />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n }\n },\n )\n\n // claude error\n program\n .command('error')\n .description(\n 'View error logs. Optionally provide a number (0, -1, -2, etc.) to display a specific log.',\n )\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { LogList } = await import('@screens/LogList')\n const { unmount } = render(\n <LogList context={context} type=\"errors\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // legacy context (TODO: deprecate)\n const context = program\n .command('context')\n .description(\n `Set static context (eg. ${PRODUCT_COMMAND} context add-file ./src/*.py)`,\n )\n\n context\n .command('get <key>')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .description('Get a value from context')\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n )\n console.log(context[key])\n process.exit(0)\n })\n\n context\n .command('set <key> <value>')\n .description('Set a value in context')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, value, { cwd }) => {\n await setup(cwd, false)\n\n setContext(key, value)\n console.log(`Set context.${key} to \"${value}\"`)\n process.exit(0)\n })\n\n context\n .command('list')\n .description('List all context values')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .action(async ({ cwd }) => {\n await setup(cwd, false)\n\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n 'gitStatus',\n )\n console.log(JSON.stringify(context, null, 2))\n process.exit(0)\n })\n\n context\n .command('remove <key>')\n .description('Remove a value from context')\n .option('--cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n\n removeContext(key)\n console.log(`Removed context.${key}`)\n process.exit(0)\n })\n\n await program.parseAsync(process.argv)\n return program\n}\n\n// TODO: stream?\nasync function stdin() {\n if (process.stdin.isTTY) {\n return ''\n }\n\n let data = ''\n for await (const chunk of process.stdin) data += chunk\n return data\n}\n\n// Setup centralized exit handlers\nsetupExitHandlers()\n\nfunction resetCursor() {\n const terminal = process.stderr.isTTY\n ? process.stderr\n : process.stdout.isTTY\n ? process.stdout\n : undefined\n terminal?.write(`\\u001B[?25h${cursorShow}`)\n}\n\nmain()\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["cwd", "getContext", "getBuiltInTools", "hasPermissionsToUseTool", "dateToFilename", "logs", "render", "context", "env", "existsSync", "config", "React", "commands"]
|
|
7
7
|
}
|