@within-7/minto 0.0.5-dev.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +1097 -0
- package/README.zh-CN.md +1097 -0
- package/cli.js +59 -0
- package/dist/Tool.js +1 -0
- package/dist/Tool.js.map +7 -0
- package/dist/commands/agents.js +2086 -0
- package/dist/commands/agents.js.map +7 -0
- package/dist/commands/approvedTools.js +36 -0
- package/dist/commands/approvedTools.js.map +7 -0
- package/dist/commands/bug.js +21 -0
- package/dist/commands/bug.js.map +7 -0
- package/dist/commands/build.js +74 -0
- package/dist/commands/build.js.map +7 -0
- package/dist/commands/clear.js +37 -0
- package/dist/commands/clear.js.map +7 -0
- package/dist/commands/compact.js +82 -0
- package/dist/commands/compact.js.map +7 -0
- package/dist/commands/compression.js +57 -0
- package/dist/commands/compression.js.map +7 -0
- package/dist/commands/config.js +20 -0
- package/dist/commands/config.js.map +7 -0
- package/dist/commands/cost.js +19 -0
- package/dist/commands/cost.js.map +7 -0
- package/dist/commands/ctx_viz.js +152 -0
- package/dist/commands/ctx_viz.js.map +7 -0
- package/dist/commands/doctor.js +25 -0
- package/dist/commands/doctor.js.map +7 -0
- package/dist/commands/help.js +20 -0
- package/dist/commands/help.js.map +7 -0
- package/dist/commands/init.js +38 -0
- package/dist/commands/init.js.map +7 -0
- package/dist/commands/listen.js +37 -0
- package/dist/commands/listen.js.map +7 -0
- package/dist/commands/login.js +37 -0
- package/dist/commands/login.js.map +7 -0
- package/dist/commands/logout.js +33 -0
- package/dist/commands/logout.js.map +7 -0
- package/dist/commands/mcp-interactive.js +267 -0
- package/dist/commands/mcp-interactive.js.map +7 -0
- package/dist/commands/mcp.js +40 -0
- package/dist/commands/mcp.js.map +7 -0
- package/dist/commands/mcp_refresh.js +40 -0
- package/dist/commands/mcp_refresh.js.map +7 -0
- package/dist/commands/model.js +41 -0
- package/dist/commands/model.js.map +7 -0
- package/dist/commands/modelstatus.js +21 -0
- package/dist/commands/modelstatus.js.map +7 -0
- package/dist/commands/onboarding.js +36 -0
- package/dist/commands/onboarding.js.map +7 -0
- package/dist/commands/plugin/AddMarketplaceForm.js +62 -0
- package/dist/commands/plugin/AddMarketplaceForm.js.map +7 -0
- package/dist/commands/plugin/ConfirmDialog.js +71 -0
- package/dist/commands/plugin/ConfirmDialog.js.map +7 -0
- package/dist/commands/plugin/ErrorView.js +33 -0
- package/dist/commands/plugin/ErrorView.js.map +7 -0
- package/dist/commands/plugin/InstalledPluginsByMarketplace.js +135 -0
- package/dist/commands/plugin/InstalledPluginsByMarketplace.js.map +7 -0
- package/dist/commands/plugin/InstalledPluginsManager.js +99 -0
- package/dist/commands/plugin/InstalledPluginsManager.js.map +7 -0
- package/dist/commands/plugin/LoadingView.js +14 -0
- package/dist/commands/plugin/LoadingView.js.map +7 -0
- package/dist/commands/plugin/MainMenu.js +57 -0
- package/dist/commands/plugin/MainMenu.js.map +7 -0
- package/dist/commands/plugin/MarketplaceManager.js +155 -0
- package/dist/commands/plugin/MarketplaceManager.js.map +7 -0
- package/dist/commands/plugin/MarketplaceSelector.js +119 -0
- package/dist/commands/plugin/MarketplaceSelector.js.map +7 -0
- package/dist/commands/plugin/PlaceholderScreen.js +16 -0
- package/dist/commands/plugin/PlaceholderScreen.js.map +7 -0
- package/dist/commands/plugin/PluginBrowser.js +180 -0
- package/dist/commands/plugin/PluginBrowser.js.map +7 -0
- package/dist/commands/plugin/PluginDetailsInstall.js +152 -0
- package/dist/commands/plugin/PluginDetailsInstall.js.map +7 -0
- package/dist/commands/plugin/PluginDetailsManage.js +200 -0
- package/dist/commands/plugin/PluginDetailsManage.js.map +7 -0
- package/dist/commands/plugin/components.js +16 -0
- package/dist/commands/plugin/components.js.map +7 -0
- package/dist/commands/plugin/example-usage.js +63 -0
- package/dist/commands/plugin/example-usage.js.map +7 -0
- package/dist/commands/plugin/types.js +1 -0
- package/dist/commands/plugin/types.js.map +7 -0
- package/dist/commands/plugin/utils.js +77 -0
- package/dist/commands/plugin/utils.js.map +7 -0
- package/dist/commands/plugin-interactive.js +446 -0
- package/dist/commands/plugin-interactive.js.map +7 -0
- package/dist/commands/plugin.js +523 -0
- package/dist/commands/plugin.js.map +7 -0
- package/dist/commands/pr_comments.js +61 -0
- package/dist/commands/pr_comments.js.map +7 -0
- package/dist/commands/quit.js +16 -0
- package/dist/commands/quit.js.map +7 -0
- package/dist/commands/refreshCommands.js +43 -0
- package/dist/commands/refreshCommands.js.map +7 -0
- package/dist/commands/release-notes.js +30 -0
- package/dist/commands/release-notes.js.map +7 -0
- package/dist/commands/resume.js +35 -0
- package/dist/commands/resume.js.map +7 -0
- package/dist/commands/review.js +51 -0
- package/dist/commands/review.js.map +7 -0
- package/dist/commands/terminalSetup.js +164 -0
- package/dist/commands/terminalSetup.js.map +7 -0
- package/dist/commands.js +104 -0
- package/dist/commands.js.map +7 -0
- package/dist/components/AgentResponseBlock.js +41 -0
- package/dist/components/AgentResponseBlock.js.map +7 -0
- package/dist/components/AgentThinkingBlock.js +40 -0
- package/dist/components/AgentThinkingBlock.js.map +7 -0
- package/dist/components/AsciiLogo.js +19 -0
- package/dist/components/AsciiLogo.js.map +7 -0
- package/dist/components/BackgroundTasksPanel.js +124 -0
- package/dist/components/BackgroundTasksPanel.js.map +7 -0
- package/dist/components/Bug.js +147 -0
- package/dist/components/Bug.js.map +7 -0
- package/dist/components/Config.js +166 -0
- package/dist/components/Config.js.map +7 -0
- package/dist/components/ConsoleOAuthFlow.js +178 -0
- package/dist/components/ConsoleOAuthFlow.js.map +7 -0
- package/dist/components/Cost.js +13 -0
- package/dist/components/Cost.js.map +7 -0
- package/dist/components/CostThresholdDialog.js +38 -0
- package/dist/components/CostThresholdDialog.js.map +7 -0
- package/dist/components/CustomSelect/option-map.js +32 -0
- package/dist/components/CustomSelect/option-map.js.map +7 -0
- package/dist/components/CustomSelect/select-option.js +34 -0
- package/dist/components/CustomSelect/select-option.js.map +7 -0
- package/dist/components/CustomSelect/select.js +64 -0
- package/dist/components/CustomSelect/select.js.map +7 -0
- package/dist/components/CustomSelect/theme.js +1 -0
- package/dist/components/CustomSelect/theme.js.map +7 -0
- package/dist/components/CustomSelect/use-select-state.js +220 -0
- package/dist/components/CustomSelect/use-select-state.js.map +7 -0
- package/dist/components/CustomSelect/use-select.js +21 -0
- package/dist/components/CustomSelect/use-select.js.map +7 -0
- package/dist/components/FallbackToolUseRejectedMessage.js +11 -0
- package/dist/components/FallbackToolUseRejectedMessage.js.map +7 -0
- package/dist/components/FileEditToolUpdatedMessage.js +32 -0
- package/dist/components/FileEditToolUpdatedMessage.js.map +7 -0
- package/dist/components/HeaderBar.js +57 -0
- package/dist/components/HeaderBar.js.map +7 -0
- package/dist/components/Help.js +46 -0
- package/dist/components/Help.js.map +7 -0
- package/dist/components/HighlightedCode.js +30 -0
- package/dist/components/HighlightedCode.js.map +7 -0
- package/dist/components/HistorySearchOverlay.js +48 -0
- package/dist/components/HistorySearchOverlay.js.map +7 -0
- package/dist/components/InteractionRoundBlock.js +56 -0
- package/dist/components/InteractionRoundBlock.js.map +7 -0
- package/dist/components/InvalidConfigDialog.js +83 -0
- package/dist/components/InvalidConfigDialog.js.map +7 -0
- package/dist/components/Link.js +18 -0
- package/dist/components/Link.js.map +7 -0
- package/dist/components/LogSelector.js +50 -0
- package/dist/components/LogSelector.js.map +7 -0
- package/dist/components/Logo.js +96 -0
- package/dist/components/Logo.js.map +7 -0
- package/dist/components/MCPServerApprovalDialog.js +79 -0
- package/dist/components/MCPServerApprovalDialog.js.map +7 -0
- package/dist/components/MCPServerDialogCopy.js +11 -0
- package/dist/components/MCPServerDialogCopy.js.map +7 -0
- package/dist/components/MCPServerMultiselectDialog.js +80 -0
- package/dist/components/MCPServerMultiselectDialog.js.map +7 -0
- package/dist/components/Message.js +146 -0
- package/dist/components/Message.js.map +7 -0
- package/dist/components/MessageResponse.js +9 -0
- package/dist/components/MessageResponse.js.map +7 -0
- package/dist/components/MessageSelector.js +125 -0
- package/dist/components/MessageSelector.js.map +7 -0
- package/dist/components/ModeIndicator.js +38 -0
- package/dist/components/ModeIndicator.js.map +7 -0
- package/dist/components/ModelConfig.js +208 -0
- package/dist/components/ModelConfig.js.map +7 -0
- package/dist/components/ModelListManager.js +140 -0
- package/dist/components/ModelListManager.js.map +7 -0
- package/dist/components/ModelSelector.js +2062 -0
- package/dist/components/ModelSelector.js.map +7 -0
- package/dist/components/ModelStatusDisplay.js +87 -0
- package/dist/components/ModelStatusDisplay.js.map +7 -0
- package/dist/components/Onboarding.js +153 -0
- package/dist/components/Onboarding.js.map +7 -0
- package/dist/components/PressEnterToContinue.js +10 -0
- package/dist/components/PressEnterToContinue.js.map +7 -0
- package/dist/components/ProjectOnboarding.js +99 -0
- package/dist/components/ProjectOnboarding.js.map +7 -0
- package/dist/components/PromptInput.js +755 -0
- package/dist/components/PromptInput.js.map +7 -0
- package/dist/components/QuitSummary.js +81 -0
- package/dist/components/QuitSummary.js.map +7 -0
- package/dist/components/SentryErrorBoundary.js +27 -0
- package/dist/components/SentryErrorBoundary.js.map +7 -0
- package/dist/components/Spinner.js +101 -0
- package/dist/components/Spinner.js.map +7 -0
- package/dist/components/SpinnerSymbol.js +78 -0
- package/dist/components/SpinnerSymbol.js.map +7 -0
- package/dist/components/StreamingBashOutput.js +70 -0
- package/dist/components/StreamingBashOutput.js.map +7 -0
- package/dist/components/StructuredDiff.js +148 -0
- package/dist/components/StructuredDiff.js.map +7 -0
- package/dist/components/SubagentBlock.js +157 -0
- package/dist/components/SubagentBlock.js.map +7 -0
- package/dist/components/SubagentManager.js +65 -0
- package/dist/components/SubagentManager.js.map +7 -0
- package/dist/components/SubagentProgress.js +109 -0
- package/dist/components/SubagentProgress.js.map +7 -0
- package/dist/components/SubagentStatusMarker.js +37 -0
- package/dist/components/SubagentStatusMarker.js.map +7 -0
- package/dist/components/TaskCard.js +170 -0
- package/dist/components/TaskCard.js.map +7 -0
- package/dist/components/TextInput.js +100 -0
- package/dist/components/TextInput.js.map +7 -0
- package/dist/components/TimelineRenderer.js +31 -0
- package/dist/components/TimelineRenderer.js.map +7 -0
- package/dist/components/TodoChangeBlock.js +29 -0
- package/dist/components/TodoChangeBlock.js.map +7 -0
- package/dist/components/TodoChangeLine.js +22 -0
- package/dist/components/TodoChangeLine.js.map +7 -0
- package/dist/components/TodoItem.js +35 -0
- package/dist/components/TodoItem.js.map +7 -0
- package/dist/components/TodoPanel.js +55 -0
- package/dist/components/TodoPanel.js.map +7 -0
- package/dist/components/TokenWarning.js +19 -0
- package/dist/components/TokenWarning.js.map +7 -0
- package/dist/components/ToolExecutionBlock.js +18 -0
- package/dist/components/ToolExecutionBlock.js.map +7 -0
- package/dist/components/ToolUseLoader.js +24 -0
- package/dist/components/ToolUseLoader.js.map +7 -0
- package/dist/components/TrustDialog.js +71 -0
- package/dist/components/TrustDialog.js.map +7 -0
- package/dist/components/UserQueryBlock.js +12 -0
- package/dist/components/UserQueryBlock.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedback.js +50 -0
- package/dist/components/binary-feedback/BinaryFeedback.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js +94 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js +139 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +7 -0
- package/dist/components/binary-feedback/utils.js +108 -0
- package/dist/components/binary-feedback/utils.js.map +7 -0
- package/dist/components/messages/AssistantBashOutputMessage.js +23 -0
- package/dist/components/messages/AssistantBashOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js +36 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js +12 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantTextMessage.js +78 -0
- package/dist/components/messages/AssistantTextMessage.js.map +7 -0
- package/dist/components/messages/AssistantThinkingMessage.js +27 -0
- package/dist/components/messages/AssistantThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantToolUseMessage.js +91 -0
- package/dist/components/messages/AssistantToolUseMessage.js.map +7 -0
- package/dist/components/messages/TaskProgressMessage.js +11 -0
- package/dist/components/messages/TaskProgressMessage.js.map +7 -0
- package/dist/components/messages/TaskToolMessage.js +39 -0
- package/dist/components/messages/TaskToolMessage.js.map +7 -0
- package/dist/components/messages/UserBashInputMessage.js +18 -0
- package/dist/components/messages/UserBashInputMessage.js.map +7 -0
- package/dist/components/messages/UserCommandMessage.js +20 -0
- package/dist/components/messages/UserCommandMessage.js.map +7 -0
- package/dist/components/messages/UserKodingInputMessage.js +18 -0
- package/dist/components/messages/UserKodingInputMessage.js.map +7 -0
- package/dist/components/messages/UserPromptMessage.js +20 -0
- package/dist/components/messages/UserPromptMessage.js.map +7 -0
- package/dist/components/messages/UserTextMessage.js +25 -0
- package/dist/components/messages/UserTextMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +10 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +15 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +25 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +47 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +23 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/utils.js +50 -0
- package/dist/components/messages/UserToolResultMessage/utils.js.map +7 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +112 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FallbackPermissionRequest.js +131 -0
- package/dist/components/permissions/FallbackPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +159 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +58 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +153 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +70 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +7 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +212 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequest.js +70 -0
- package/dist/components/permissions/PermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequestTitle.js +52 -0
- package/dist/components/permissions/PermissionRequestTitle.js.map +7 -0
- package/dist/components/permissions/hooks.js +23 -0
- package/dist/components/permissions/hooks.js.map +7 -0
- package/dist/components/permissions/toolUseOptions.js +46 -0
- package/dist/components/permissions/toolUseOptions.js.map +7 -0
- package/dist/components/permissions/utils.js +21 -0
- package/dist/components/permissions/utils.js.map +7 -0
- package/dist/constants/claude-asterisk-ascii-art.js +242 -0
- package/dist/constants/claude-asterisk-ascii-art.js.map +7 -0
- package/dist/constants/colors.js +126 -0
- package/dist/constants/colors.js.map +7 -0
- package/dist/constants/compressionPrompts.js +73 -0
- package/dist/constants/compressionPrompts.js.map +7 -0
- package/dist/constants/figures.js +6 -0
- package/dist/constants/figures.js.map +7 -0
- package/dist/constants/macros.js +11 -0
- package/dist/constants/macros.js.map +7 -0
- package/dist/constants/modelCapabilities.js +154 -0
- package/dist/constants/modelCapabilities.js.map +7 -0
- package/dist/constants/models.js +1034 -0
- package/dist/constants/models.js.map +7 -0
- package/dist/constants/oauth.js +18 -0
- package/dist/constants/oauth.js.map +7 -0
- package/dist/constants/product.js +26 -0
- package/dist/constants/product.js.map +7 -0
- package/dist/constants/prompts.js +168 -0
- package/dist/constants/prompts.js.map +7 -0
- package/dist/constants/releaseNotes.js +9 -0
- package/dist/constants/releaseNotes.js.map +7 -0
- package/dist/constants/symbols.js +50 -0
- package/dist/constants/symbols.js.map +7 -0
- package/dist/context/PermissionContext.js +111 -0
- package/dist/context/PermissionContext.js.map +7 -0
- package/dist/context.js +278 -0
- package/dist/context.js.map +7 -0
- package/dist/cost-tracker.js +76 -0
- package/dist/cost-tracker.js.map +7 -0
- package/dist/entrypoints/cli-wrapper.js +61 -0
- package/dist/entrypoints/cli-wrapper.js.map +7 -0
- package/dist/entrypoints/cli.js +1115 -0
- package/dist/entrypoints/cli.js.map +7 -0
- package/dist/entrypoints/mcp.js +150 -0
- package/dist/entrypoints/mcp.js.map +7 -0
- package/dist/history.js +25 -0
- package/dist/history.js.map +7 -0
- package/dist/hooks/useApiKeyVerification.js +12 -0
- package/dist/hooks/useApiKeyVerification.js.map +7 -0
- package/dist/hooks/useArrowKeyHistory.js +50 -0
- package/dist/hooks/useArrowKeyHistory.js.map +7 -0
- package/dist/hooks/useCanUseTool.js +87 -0
- package/dist/hooks/useCanUseTool.js.map +7 -0
- package/dist/hooks/useCancelRequest.js +28 -0
- package/dist/hooks/useCancelRequest.js.map +7 -0
- package/dist/hooks/useDoublePress.js +31 -0
- package/dist/hooks/useDoublePress.js.map +7 -0
- package/dist/hooks/useExitOnCtrlCD.js +26 -0
- package/dist/hooks/useExitOnCtrlCD.js.map +7 -0
- package/dist/hooks/useHistorySearch.js +62 -0
- package/dist/hooks/useHistorySearch.js.map +7 -0
- package/dist/hooks/useInterval.js +18 -0
- package/dist/hooks/useInterval.js.map +7 -0
- package/dist/hooks/useLogMessages.js +14 -0
- package/dist/hooks/useLogMessages.js.map +7 -0
- package/dist/hooks/useLogStartupTime.js +10 -0
- package/dist/hooks/useLogStartupTime.js.map +7 -0
- package/dist/hooks/useNotifyAfterTimeout.js +42 -0
- package/dist/hooks/useNotifyAfterTimeout.js.map +7 -0
- package/dist/hooks/usePermissionRequestLogging.js +23 -0
- package/dist/hooks/usePermissionRequestLogging.js.map +7 -0
- package/dist/hooks/useTerminalSize.js +38 -0
- package/dist/hooks/useTerminalSize.js.map +7 -0
- package/dist/hooks/useTextInput.js +252 -0
- package/dist/hooks/useTextInput.js.map +7 -0
- package/dist/hooks/useUnifiedCompletion.js +929 -0
- package/dist/hooks/useUnifiedCompletion.js.map +7 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +7 -0
- package/dist/messages.js +33 -0
- package/dist/messages.js.map +7 -0
- package/dist/package.json +4 -0
- package/dist/permissions.js +194 -0
- package/dist/permissions.js.map +7 -0
- package/dist/query.js +499 -0
- package/dist/query.js.map +7 -0
- package/dist/screens/Doctor.js +22 -0
- package/dist/screens/Doctor.js.map +7 -0
- package/dist/screens/LogList.js +55 -0
- package/dist/screens/LogList.js.map +7 -0
- package/dist/screens/REPL.js +671 -0
- package/dist/screens/REPL.js.map +7 -0
- package/dist/screens/ResumeConversation.js +56 -0
- package/dist/screens/ResumeConversation.js.map +7 -0
- package/dist/services/adapters/base.js +29 -0
- package/dist/services/adapters/base.js.map +7 -0
- package/dist/services/adapters/chatCompletions.js +69 -0
- package/dist/services/adapters/chatCompletions.js.map +7 -0
- package/dist/services/adapters/responsesAPI.js +126 -0
- package/dist/services/adapters/responsesAPI.js.map +7 -0
- package/dist/services/claude.js +1573 -0
- package/dist/services/claude.js.map +7 -0
- package/dist/services/compressionService.js +210 -0
- package/dist/services/compressionService.js.map +7 -0
- package/dist/services/customCommands.js +437 -0
- package/dist/services/customCommands.js.map +7 -0
- package/dist/services/fileFreshness.js +275 -0
- package/dist/services/fileFreshness.js.map +7 -0
- package/dist/services/gpt5ConnectionTest.js +248 -0
- package/dist/services/gpt5ConnectionTest.js.map +7 -0
- package/dist/services/hookExecutor.js +276 -0
- package/dist/services/hookExecutor.js.map +7 -0
- package/dist/services/mainAgentCompressor.js +84 -0
- package/dist/services/mainAgentCompressor.js.map +7 -0
- package/dist/services/mcpClient.js +449 -0
- package/dist/services/mcpClient.js.map +7 -0
- package/dist/services/mcpServerApproval.js +55 -0
- package/dist/services/mcpServerApproval.js.map +7 -0
- package/dist/services/mentionProcessor.js +201 -0
- package/dist/services/mentionProcessor.js.map +7 -0
- package/dist/services/modelAdapterFactory.js +47 -0
- package/dist/services/modelAdapterFactory.js.map +7 -0
- package/dist/services/notifier.js +35 -0
- package/dist/services/notifier.js.map +7 -0
- package/dist/services/oauth.js +247 -0
- package/dist/services/oauth.js.map +7 -0
- package/dist/services/openai.js +995 -0
- package/dist/services/openai.js.map +7 -0
- package/dist/services/responseStateManager.js +68 -0
- package/dist/services/responseStateManager.js.map +7 -0
- package/dist/services/sentry.js +9 -0
- package/dist/services/sentry.js.map +7 -0
- package/dist/services/subagentAbortManager.js +95 -0
- package/dist/services/subagentAbortManager.js.map +7 -0
- package/dist/services/subagentCompressor.js +146 -0
- package/dist/services/subagentCompressor.js.map +7 -0
- package/dist/services/systemReminder.js +335 -0
- package/dist/services/systemReminder.js.map +7 -0
- package/dist/services/vcr.js +133 -0
- package/dist/services/vcr.js.map +7 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js +119 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +7 -0
- package/dist/tools/ArchitectTool/prompt.js +18 -0
- package/dist/tools/ArchitectTool/prompt.js.map +7 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +423 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +7 -0
- package/dist/tools/BashOutputTool/BashOutputTool.js +120 -0
- package/dist/tools/BashOutputTool/BashOutputTool.js.map +7 -0
- package/dist/tools/BashOutputTool/BashOutputToolResultMessage.js +11 -0
- package/dist/tools/BashOutputTool/BashOutputToolResultMessage.js.map +7 -0
- package/dist/tools/BashOutputTool/prompt.js +13 -0
- package/dist/tools/BashOutputTool/prompt.js.map +7 -0
- package/dist/tools/BashTool/BashTool.js +209 -0
- package/dist/tools/BashTool/BashTool.js.map +7 -0
- package/dist/tools/BashTool/BashToolResultMessage.js +21 -0
- package/dist/tools/BashTool/BashToolResultMessage.js.map +7 -0
- package/dist/tools/BashTool/OutputLine.js +30 -0
- package/dist/tools/BashTool/OutputLine.js.map +7 -0
- package/dist/tools/BashTool/prompt.js +180 -0
- package/dist/tools/BashTool/prompt.js.map +7 -0
- package/dist/tools/BashTool/utils.js +51 -0
- package/dist/tools/BashTool/utils.js.map +7 -0
- package/dist/tools/FileEditTool/FileEditTool.js +226 -0
- package/dist/tools/FileEditTool/FileEditTool.js.map +7 -0
- package/dist/tools/FileEditTool/prompt.js +54 -0
- package/dist/tools/FileEditTool/prompt.js.map +7 -0
- package/dist/tools/FileEditTool/utils.js +42 -0
- package/dist/tools/FileEditTool/utils.js.map +7 -0
- package/dist/tools/FileReadTool/FileReadTool.js +272 -0
- package/dist/tools/FileReadTool/FileReadTool.js.map +7 -0
- package/dist/tools/FileReadTool/prompt.js +10 -0
- package/dist/tools/FileReadTool/prompt.js.map +7 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js +202 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +7 -0
- package/dist/tools/FileWriteTool/prompt.js +14 -0
- package/dist/tools/FileWriteTool/prompt.js.map +7 -0
- package/dist/tools/GlobTool/GlobTool.js +88 -0
- package/dist/tools/GlobTool/GlobTool.js.map +7 -0
- package/dist/tools/GlobTool/prompt.js +12 -0
- package/dist/tools/GlobTool/prompt.js.map +7 -0
- package/dist/tools/GrepTool/GrepTool.js +107 -0
- package/dist/tools/GrepTool/GrepTool.js.map +7 -0
- package/dist/tools/GrepTool/prompt.js +15 -0
- package/dist/tools/GrepTool/prompt.js.map +7 -0
- package/dist/tools/KillShellTool/KillShellTool.js +92 -0
- package/dist/tools/KillShellTool/KillShellTool.js.map +7 -0
- package/dist/tools/KillShellTool/KillShellToolResultMessage.js +11 -0
- package/dist/tools/KillShellTool/KillShellToolResultMessage.js.map +7 -0
- package/dist/tools/KillShellTool/prompt.js +12 -0
- package/dist/tools/KillShellTool/prompt.js.map +7 -0
- package/dist/tools/MCPTool/MCPTool.js +90 -0
- package/dist/tools/MCPTool/MCPTool.js.map +7 -0
- package/dist/tools/MCPTool/prompt.js +7 -0
- package/dist/tools/MCPTool/prompt.js.map +7 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +103 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +7 -0
- package/dist/tools/MemoryReadTool/prompt.js +7 -0
- package/dist/tools/MemoryReadTool/prompt.js.map +7 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +77 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js.map +7 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js +301 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +7 -0
- package/dist/tools/MultiEditTool/prompt.js +48 -0
- package/dist/tools/MultiEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +238 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +7 -0
- package/dist/tools/NotebookEditTool/prompt.js +7 -0
- package/dist/tools/NotebookEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js +212 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +7 -0
- package/dist/tools/NotebookReadTool/prompt.js +7 -0
- package/dist/tools/NotebookReadTool/prompt.js.map +7 -0
- package/dist/tools/SkillTool/SkillTool.js +209 -0
- package/dist/tools/SkillTool/SkillTool.js.map +7 -0
- package/dist/tools/SkillTool/prompt.js +81 -0
- package/dist/tools/SkillTool/prompt.js.map +7 -0
- package/dist/tools/TaskTool/TaskTool.js +381 -0
- package/dist/tools/TaskTool/TaskTool.js.map +7 -0
- package/dist/tools/TaskTool/constants.js +5 -0
- package/dist/tools/TaskTool/constants.js.map +7 -0
- package/dist/tools/TaskTool/prompt.js +111 -0
- package/dist/tools/TaskTool/prompt.js.map +7 -0
- package/dist/tools/ThinkTool/ThinkTool.js +40 -0
- package/dist/tools/ThinkTool/ThinkTool.js.map +7 -0
- package/dist/tools/ThinkTool/prompt.js +16 -0
- package/dist/tools/ThinkTool/prompt.js.map +7 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +243 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +7 -0
- package/dist/tools/TodoWriteTool/prompt.js +66 -0
- package/dist/tools/TodoWriteTool/prompt.js.map +7 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +137 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +7 -0
- package/dist/tools/URLFetcherTool/cache.js +45 -0
- package/dist/tools/URLFetcherTool/cache.js.map +7 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js +42 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +7 -0
- package/dist/tools/URLFetcherTool/prompt.js +22 -0
- package/dist/tools/URLFetcherTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js +86 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +7 -0
- package/dist/tools/WebSearchTool/prompt.js +17 -0
- package/dist/tools/WebSearchTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/searchProviders.js +48 -0
- package/dist/tools/WebSearchTool/searchProviders.js.map +7 -0
- package/dist/tools/lsTool/lsTool.js +201 -0
- package/dist/tools/lsTool/lsTool.js.map +7 -0
- package/dist/tools/lsTool/prompt.js +5 -0
- package/dist/tools/lsTool/prompt.js.map +7 -0
- package/dist/tools.js +70 -0
- package/dist/tools.js.map +7 -0
- package/dist/types/PermissionMode.js +82 -0
- package/dist/types/PermissionMode.js.map +7 -0
- package/dist/types/RequestContext.js +47 -0
- package/dist/types/RequestContext.js.map +7 -0
- package/dist/types/common.d.js +1 -0
- package/dist/types/common.d.js.map +7 -0
- package/dist/types/conversation.js +1 -0
- package/dist/types/conversation.js.map +7 -0
- package/dist/types/hooks.js +38 -0
- package/dist/types/hooks.js.map +7 -0
- package/dist/types/interactionRound.js +1 -0
- package/dist/types/interactionRound.js.map +7 -0
- package/dist/types/logs.js +1 -0
- package/dist/types/logs.js.map +7 -0
- package/dist/types/marketplace.js +101 -0
- package/dist/types/marketplace.js.map +7 -0
- package/dist/types/modelCapabilities.js +1 -0
- package/dist/types/modelCapabilities.js.map +7 -0
- package/dist/types/notebook.js +1 -0
- package/dist/types/notebook.js.map +7 -0
- package/dist/types/plugin.js +83 -0
- package/dist/types/plugin.js.map +7 -0
- package/dist/types/subagent.js +1 -0
- package/dist/types/subagent.js.map +7 -0
- package/dist/utils/BackgroundShellManager.js +215 -0
- package/dist/utils/BackgroundShellManager.js.map +7 -0
- package/dist/utils/Cursor.js +315 -0
- package/dist/utils/Cursor.js.map +7 -0
- package/dist/utils/PersistentShell.js +371 -0
- package/dist/utils/PersistentShell.js.map +7 -0
- package/dist/utils/advancedFuzzyMatcher.js +206 -0
- package/dist/utils/advancedFuzzyMatcher.js.map +7 -0
- package/dist/utils/agentLoader.js +244 -0
- package/dist/utils/agentLoader.js.map +7 -0
- package/dist/utils/agentStorage.js +59 -0
- package/dist/utils/agentStorage.js.map +7 -0
- package/dist/utils/array.js +7 -0
- package/dist/utils/array.js.map +7 -0
- package/dist/utils/ask.js +77 -0
- package/dist/utils/ask.js.map +7 -0
- package/dist/utils/auth.js +11 -0
- package/dist/utils/auth.js.map +7 -0
- package/dist/utils/autoCompactCore.js +126 -0
- package/dist/utils/autoCompactCore.js.map +7 -0
- package/dist/utils/autoUpdater.js +107 -0
- package/dist/utils/autoUpdater.js.map +7 -0
- package/dist/utils/browser.js +15 -0
- package/dist/utils/browser.js.map +7 -0
- package/dist/utils/cleanup.js +54 -0
- package/dist/utils/cleanup.js.map +7 -0
- package/dist/utils/commands.js +207 -0
- package/dist/utils/commands.js.map +7 -0
- package/dist/utils/commonUnixCommands.js +687 -0
- package/dist/utils/commonUnixCommands.js.map +7 -0
- package/dist/utils/compressionMode.js +47 -0
- package/dist/utils/compressionMode.js.map +7 -0
- package/dist/utils/config.js +651 -0
- package/dist/utils/config.js.map +7 -0
- package/dist/utils/conversationRecovery.js +35 -0
- package/dist/utils/conversationRecovery.js.map +7 -0
- package/dist/utils/debugLogger.js +889 -0
- package/dist/utils/debugLogger.js.map +7 -0
- package/dist/utils/diff.js +32 -0
- package/dist/utils/diff.js.map +7 -0
- package/dist/utils/env.js +44 -0
- package/dist/utils/env.js.map +7 -0
- package/dist/utils/errors.js +23 -0
- package/dist/utils/errors.js.map +7 -0
- package/dist/utils/execFileNoThrow.js +44 -0
- package/dist/utils/execFileNoThrow.js.map +7 -0
- package/dist/utils/expertChatStorage.js +78 -0
- package/dist/utils/expertChatStorage.js.map +7 -0
- package/dist/utils/file.js +282 -0
- package/dist/utils/file.js.map +7 -0
- package/dist/utils/fileRecoveryCore.js +41 -0
- package/dist/utils/fileRecoveryCore.js.map +7 -0
- package/dist/utils/format.js +41 -0
- package/dist/utils/format.js.map +7 -0
- package/dist/utils/fuzzyMatcher.js +252 -0
- package/dist/utils/fuzzyMatcher.js.map +7 -0
- package/dist/utils/generators.js +46 -0
- package/dist/utils/generators.js.map +7 -0
- package/dist/utils/git.js +83 -0
- package/dist/utils/git.js.map +7 -0
- package/dist/utils/hookManager.js +238 -0
- package/dist/utils/hookManager.js.map +7 -0
- package/dist/utils/http.js +7 -0
- package/dist/utils/http.js.map +7 -0
- package/dist/utils/imagePaste.js +29 -0
- package/dist/utils/imagePaste.js.map +7 -0
- package/dist/utils/json.js +16 -0
- package/dist/utils/json.js.map +7 -0
- package/dist/utils/log.js +329 -0
- package/dist/utils/log.js.map +7 -0
- package/dist/utils/markdown.js +187 -0
- package/dist/utils/markdown.js.map +7 -0
- package/dist/utils/marketplaceManager.js +474 -0
- package/dist/utils/marketplaceManager.js.map +7 -0
- package/dist/utils/messageContextManager.js +195 -0
- package/dist/utils/messageContextManager.js.map +7 -0
- package/dist/utils/messages.js +650 -0
- package/dist/utils/messages.js.map +7 -0
- package/dist/utils/model.js +677 -0
- package/dist/utils/model.js.map +7 -0
- package/dist/utils/permissions/filesystem.js +80 -0
- package/dist/utils/permissions/filesystem.js.map +7 -0
- package/dist/utils/pluginInstaller.js +491 -0
- package/dist/utils/pluginInstaller.js.map +7 -0
- package/dist/utils/pluginLoader.js +582 -0
- package/dist/utils/pluginLoader.js.map +7 -0
- package/dist/utils/pluginRegistry.js +111 -0
- package/dist/utils/pluginRegistry.js.map +7 -0
- package/dist/utils/pluginValidator.js +774 -0
- package/dist/utils/pluginValidator.js.map +7 -0
- package/dist/utils/ptyCompat.js +125 -0
- package/dist/utils/ptyCompat.js.map +7 -0
- package/dist/utils/replStateMachine.js +145 -0
- package/dist/utils/replStateMachine.js.map +7 -0
- package/dist/utils/ripgrep.js +131 -0
- package/dist/utils/ripgrep.js.map +7 -0
- package/dist/utils/roundConverter.js +262 -0
- package/dist/utils/roundConverter.js.map +7 -0
- package/dist/utils/secureFile.js +483 -0
- package/dist/utils/secureFile.js.map +7 -0
- package/dist/utils/sessionState.js +22 -0
- package/dist/utils/sessionState.js.map +7 -0
- package/dist/utils/skillLoader.js +79 -0
- package/dist/utils/skillLoader.js.map +7 -0
- package/dist/utils/state.js +24 -0
- package/dist/utils/state.js.map +7 -0
- package/dist/utils/style.js +31 -0
- package/dist/utils/style.js.map +7 -0
- package/dist/utils/terminal.js +47 -0
- package/dist/utils/terminal.js.map +7 -0
- package/dist/utils/theme.js +102 -0
- package/dist/utils/theme.js.map +7 -0
- package/dist/utils/thinking.js +59 -0
- package/dist/utils/thinking.js.map +7 -0
- package/dist/utils/todoChangeCalculator.js +64 -0
- package/dist/utils/todoChangeCalculator.js.map +7 -0
- package/dist/utils/todoStorage.js +291 -0
- package/dist/utils/todoStorage.js.map +7 -0
- package/dist/utils/tokens.js +30 -0
- package/dist/utils/tokens.js.map +7 -0
- package/dist/utils/toolExecutionController.js +109 -0
- package/dist/utils/toolExecutionController.js.map +7 -0
- package/dist/utils/unaryLogging.js +6 -0
- package/dist/utils/unaryLogging.js.map +7 -0
- package/dist/utils/user.js +40 -0
- package/dist/utils/user.js.map +7 -0
- package/dist/utils/validate.js +132 -0
- package/dist/utils/validate.js.map +7 -0
- package/dist/version.js +7 -0
- package/dist/version.js.map +7 -0
- package/dist/yoga.wasm +0 -0
- package/package.json +113 -0
- package/scripts/postinstall.js +18 -0
- package/yoga.wasm +0 -0
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
import { statSync, existsSync, watchFile, unwatchFile } from "fs";
|
|
2
|
+
import {
|
|
3
|
+
emitReminderEvent,
|
|
4
|
+
systemReminderService
|
|
5
|
+
} from "./systemReminder.js";
|
|
6
|
+
import { getAgentFilePath } from "../utils/agentStorage.js";
|
|
7
|
+
class FileFreshnessService {
|
|
8
|
+
state = {
|
|
9
|
+
readTimestamps: /* @__PURE__ */ new Map(),
|
|
10
|
+
editConflicts: /* @__PURE__ */ new Set(),
|
|
11
|
+
sessionFiles: /* @__PURE__ */ new Set(),
|
|
12
|
+
watchedTodoFiles: /* @__PURE__ */ new Map()
|
|
13
|
+
};
|
|
14
|
+
constructor() {
|
|
15
|
+
this.setupEventListeners();
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Setup event listeners for session management
|
|
19
|
+
*/
|
|
20
|
+
setupEventListeners() {
|
|
21
|
+
systemReminderService.addEventListener(
|
|
22
|
+
"session:startup",
|
|
23
|
+
(context) => {
|
|
24
|
+
this.resetSession();
|
|
25
|
+
}
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Record file read operation with timestamp tracking
|
|
30
|
+
*/
|
|
31
|
+
recordFileRead(filePath) {
|
|
32
|
+
try {
|
|
33
|
+
if (!existsSync(filePath)) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const stats = statSync(filePath);
|
|
37
|
+
const timestamp = {
|
|
38
|
+
path: filePath,
|
|
39
|
+
lastRead: Date.now(),
|
|
40
|
+
lastModified: stats.mtimeMs,
|
|
41
|
+
size: stats.size
|
|
42
|
+
};
|
|
43
|
+
this.state.readTimestamps.set(filePath, timestamp);
|
|
44
|
+
this.state.sessionFiles.add(filePath);
|
|
45
|
+
emitReminderEvent("file:read", {
|
|
46
|
+
filePath,
|
|
47
|
+
timestamp: timestamp.lastRead,
|
|
48
|
+
size: timestamp.size,
|
|
49
|
+
modified: timestamp.lastModified
|
|
50
|
+
});
|
|
51
|
+
} catch (error) {
|
|
52
|
+
console.error(`Error recording file read for ${filePath}:`, error);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Check if file has been modified since last read
|
|
57
|
+
*/
|
|
58
|
+
checkFileFreshness(filePath) {
|
|
59
|
+
const recorded = this.state.readTimestamps.get(filePath);
|
|
60
|
+
if (!recorded) {
|
|
61
|
+
return { isFresh: true, conflict: false };
|
|
62
|
+
}
|
|
63
|
+
try {
|
|
64
|
+
if (!existsSync(filePath)) {
|
|
65
|
+
return { isFresh: false, conflict: true };
|
|
66
|
+
}
|
|
67
|
+
const currentStats = statSync(filePath);
|
|
68
|
+
const isFresh = currentStats.mtimeMs <= recorded.lastModified;
|
|
69
|
+
const conflict = !isFresh;
|
|
70
|
+
if (conflict) {
|
|
71
|
+
this.state.editConflicts.add(filePath);
|
|
72
|
+
emitReminderEvent("file:conflict", {
|
|
73
|
+
filePath,
|
|
74
|
+
lastRead: recorded.lastRead,
|
|
75
|
+
lastModified: recorded.lastModified,
|
|
76
|
+
currentModified: currentStats.mtimeMs,
|
|
77
|
+
sizeDiff: currentStats.size - recorded.size
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
isFresh,
|
|
82
|
+
lastRead: recorded.lastRead,
|
|
83
|
+
currentModified: currentStats.mtimeMs,
|
|
84
|
+
conflict
|
|
85
|
+
};
|
|
86
|
+
} catch (error) {
|
|
87
|
+
console.error(`Error checking freshness for ${filePath}:`, error);
|
|
88
|
+
return { isFresh: false, conflict: true };
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Record file edit operation by Agent
|
|
93
|
+
*/
|
|
94
|
+
recordFileEdit(filePath, content) {
|
|
95
|
+
try {
|
|
96
|
+
const now = Date.now();
|
|
97
|
+
if (existsSync(filePath)) {
|
|
98
|
+
const stats = statSync(filePath);
|
|
99
|
+
const existing = this.state.readTimestamps.get(filePath);
|
|
100
|
+
if (existing) {
|
|
101
|
+
existing.lastModified = stats.mtimeMs;
|
|
102
|
+
existing.size = stats.size;
|
|
103
|
+
existing.lastAgentEdit = now;
|
|
104
|
+
this.state.readTimestamps.set(filePath, existing);
|
|
105
|
+
} else {
|
|
106
|
+
const timestamp = {
|
|
107
|
+
path: filePath,
|
|
108
|
+
lastRead: now,
|
|
109
|
+
lastModified: stats.mtimeMs,
|
|
110
|
+
size: stats.size,
|
|
111
|
+
lastAgentEdit: now
|
|
112
|
+
};
|
|
113
|
+
this.state.readTimestamps.set(filePath, timestamp);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
this.state.editConflicts.delete(filePath);
|
|
117
|
+
emitReminderEvent("file:edited", {
|
|
118
|
+
filePath,
|
|
119
|
+
timestamp: now,
|
|
120
|
+
contentLength: content?.length || 0,
|
|
121
|
+
source: "agent"
|
|
122
|
+
});
|
|
123
|
+
} catch (error) {
|
|
124
|
+
console.error(`Error recording file edit for ${filePath}:`, error);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
generateFileModificationReminder(filePath) {
|
|
128
|
+
const recorded = this.state.readTimestamps.get(filePath);
|
|
129
|
+
if (!recorded) {
|
|
130
|
+
return null;
|
|
131
|
+
}
|
|
132
|
+
try {
|
|
133
|
+
if (!existsSync(filePath)) {
|
|
134
|
+
return `Note: ${filePath} was deleted since last read.`;
|
|
135
|
+
}
|
|
136
|
+
const currentStats = statSync(filePath);
|
|
137
|
+
const isModified = currentStats.mtimeMs > recorded.lastModified;
|
|
138
|
+
if (!isModified) {
|
|
139
|
+
return null;
|
|
140
|
+
}
|
|
141
|
+
const TIME_TOLERANCE_MS = 100;
|
|
142
|
+
if (recorded.lastAgentEdit && recorded.lastAgentEdit >= recorded.lastModified - TIME_TOLERANCE_MS) {
|
|
143
|
+
return null;
|
|
144
|
+
}
|
|
145
|
+
return `Note: ${filePath} was modified externally since last read. The file may have changed outside of this session.`;
|
|
146
|
+
} catch (error) {
|
|
147
|
+
console.error(`Error checking modification for ${filePath}:`, error);
|
|
148
|
+
return null;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
getConflictedFiles() {
|
|
152
|
+
return Array.from(this.state.editConflicts);
|
|
153
|
+
}
|
|
154
|
+
getSessionFiles() {
|
|
155
|
+
return Array.from(this.state.sessionFiles);
|
|
156
|
+
}
|
|
157
|
+
resetSession() {
|
|
158
|
+
this.state.watchedTodoFiles.forEach((filePath) => {
|
|
159
|
+
try {
|
|
160
|
+
unwatchFile(filePath);
|
|
161
|
+
} catch (error) {
|
|
162
|
+
console.error(`Error unwatching file ${filePath}:`, error);
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
this.state = {
|
|
166
|
+
readTimestamps: /* @__PURE__ */ new Map(),
|
|
167
|
+
editConflicts: /* @__PURE__ */ new Set(),
|
|
168
|
+
sessionFiles: /* @__PURE__ */ new Set(),
|
|
169
|
+
watchedTodoFiles: /* @__PURE__ */ new Map()
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Start watching todo file for an agent
|
|
174
|
+
*/
|
|
175
|
+
startWatchingTodoFile(agentId) {
|
|
176
|
+
try {
|
|
177
|
+
const filePath = getAgentFilePath(agentId);
|
|
178
|
+
if (this.state.watchedTodoFiles.has(agentId)) {
|
|
179
|
+
return;
|
|
180
|
+
}
|
|
181
|
+
this.state.watchedTodoFiles.set(agentId, filePath);
|
|
182
|
+
if (existsSync(filePath)) {
|
|
183
|
+
this.recordFileRead(filePath);
|
|
184
|
+
}
|
|
185
|
+
watchFile(filePath, { interval: 1e3 }, (curr, prev) => {
|
|
186
|
+
const reminder = this.generateFileModificationReminder(filePath);
|
|
187
|
+
if (reminder) {
|
|
188
|
+
emitReminderEvent("todo:file_changed", {
|
|
189
|
+
agentId,
|
|
190
|
+
filePath,
|
|
191
|
+
reminder,
|
|
192
|
+
timestamp: Date.now(),
|
|
193
|
+
currentStats: { mtime: curr.mtime, size: curr.size },
|
|
194
|
+
previousStats: { mtime: prev.mtime, size: prev.size }
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
} catch (error) {
|
|
199
|
+
console.error(
|
|
200
|
+
`Error starting todo file watch for agent ${agentId}:`,
|
|
201
|
+
error
|
|
202
|
+
);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Stop watching todo file for an agent
|
|
207
|
+
*/
|
|
208
|
+
stopWatchingTodoFile(agentId) {
|
|
209
|
+
try {
|
|
210
|
+
const filePath = this.state.watchedTodoFiles.get(agentId);
|
|
211
|
+
if (filePath) {
|
|
212
|
+
unwatchFile(filePath);
|
|
213
|
+
this.state.watchedTodoFiles.delete(agentId);
|
|
214
|
+
}
|
|
215
|
+
} catch (error) {
|
|
216
|
+
console.error(
|
|
217
|
+
`Error stopping todo file watch for agent ${agentId}:`,
|
|
218
|
+
error
|
|
219
|
+
);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
getFileInfo(filePath) {
|
|
223
|
+
return this.state.readTimestamps.get(filePath) || null;
|
|
224
|
+
}
|
|
225
|
+
isFileTracked(filePath) {
|
|
226
|
+
return this.state.readTimestamps.has(filePath);
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Retrieves files prioritized for recovery during conversation compression
|
|
230
|
+
*
|
|
231
|
+
* Selects recently accessed files based on:
|
|
232
|
+
* - File access recency (most recent first)
|
|
233
|
+
* - File type relevance (excludes dependencies, build artifacts)
|
|
234
|
+
* - Development workflow importance
|
|
235
|
+
*
|
|
236
|
+
* Used to maintain coding context when conversation history is compressed
|
|
237
|
+
*/
|
|
238
|
+
getImportantFiles(maxFiles = 5) {
|
|
239
|
+
return Array.from(this.state.readTimestamps.entries()).map(([path, info]) => ({
|
|
240
|
+
path,
|
|
241
|
+
timestamp: info.lastRead,
|
|
242
|
+
size: info.size
|
|
243
|
+
})).filter((file) => this.isValidForRecovery(file.path)).sort((a, b) => b.timestamp - a.timestamp).slice(0, maxFiles);
|
|
244
|
+
}
|
|
245
|
+
/**
|
|
246
|
+
* Determines which files are suitable for automatic recovery
|
|
247
|
+
*
|
|
248
|
+
* Excludes files that are typically not relevant for development context:
|
|
249
|
+
* - Build artifacts and generated files
|
|
250
|
+
* - Dependencies and cached files
|
|
251
|
+
* - Temporary files and system directories
|
|
252
|
+
*/
|
|
253
|
+
isValidForRecovery(filePath) {
|
|
254
|
+
return !filePath.includes("node_modules") && !filePath.includes(".git") && !filePath.startsWith("/tmp") && !filePath.includes(".cache") && !filePath.includes("dist/") && !filePath.includes("build/");
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
const fileFreshnessService = new FileFreshnessService();
|
|
258
|
+
const recordFileRead = (filePath) => fileFreshnessService.recordFileRead(filePath);
|
|
259
|
+
const recordFileEdit = (filePath, content) => fileFreshnessService.recordFileEdit(filePath, content);
|
|
260
|
+
const checkFileFreshness = (filePath) => fileFreshnessService.checkFileFreshness(filePath);
|
|
261
|
+
const generateFileModificationReminder = (filePath) => fileFreshnessService.generateFileModificationReminder(filePath);
|
|
262
|
+
const resetFileFreshnessSession = () => fileFreshnessService.resetSession();
|
|
263
|
+
const startWatchingTodoFile = (agentId) => fileFreshnessService.startWatchingTodoFile(agentId);
|
|
264
|
+
const stopWatchingTodoFile = (agentId) => fileFreshnessService.stopWatchingTodoFile(agentId);
|
|
265
|
+
export {
|
|
266
|
+
checkFileFreshness,
|
|
267
|
+
fileFreshnessService,
|
|
268
|
+
generateFileModificationReminder,
|
|
269
|
+
recordFileEdit,
|
|
270
|
+
recordFileRead,
|
|
271
|
+
resetFileFreshnessSession,
|
|
272
|
+
startWatchingTodoFile,
|
|
273
|
+
stopWatchingTodoFile
|
|
274
|
+
};
|
|
275
|
+
//# sourceMappingURL=fileFreshness.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/services/fileFreshness.ts"],
|
|
4
|
+
"sourcesContent": ["import { statSync, existsSync, watchFile, unwatchFile } from 'fs'\nimport {\n emitReminderEvent,\n systemReminderService,\n} from '@services/systemReminder'\nimport { getAgentFilePath } from '@utils/agentStorage'\n\ninterface FileTimestamp {\n path: string\n lastRead: number\n lastModified: number\n size: number\n lastAgentEdit?: number // Track when Agent last edited this file\n}\n\ninterface FileFreshnessState {\n readTimestamps: Map<string, FileTimestamp>\n editConflicts: Set<string>\n sessionFiles: Set<string>\n watchedTodoFiles: Map<string, string> // agentId -> filePath\n}\n\nclass FileFreshnessService {\n private state: FileFreshnessState = {\n readTimestamps: new Map(),\n editConflicts: new Set(),\n sessionFiles: new Set(),\n watchedTodoFiles: new Map(),\n }\n\n constructor() {\n this.setupEventListeners()\n }\n\n /**\n * Setup event listeners for session management\n */\n private setupEventListeners(): void {\n // Listen for session startup events through the SystemReminderService\n systemReminderService.addEventListener(\n 'session:startup',\n (context: any) => {\n // Reset session state on startup\n this.resetSession()\n\n \n },\n )\n }\n\n /**\n * Record file read operation with timestamp tracking\n */\n public recordFileRead(filePath: string): void {\n try {\n if (!existsSync(filePath)) {\n return\n }\n\n const stats = statSync(filePath)\n const timestamp: FileTimestamp = {\n path: filePath,\n lastRead: Date.now(),\n lastModified: stats.mtimeMs,\n size: stats.size,\n }\n\n this.state.readTimestamps.set(filePath, timestamp)\n this.state.sessionFiles.add(filePath)\n\n // Emit file read event for system reminders\n emitReminderEvent('file:read', {\n filePath,\n timestamp: timestamp.lastRead,\n size: timestamp.size,\n modified: timestamp.lastModified,\n })\n } catch (error) {\n console.error(`Error recording file read for ${filePath}:`, error)\n }\n }\n\n /**\n * Check if file has been modified since last read\n */\n public checkFileFreshness(filePath: string): {\n isFresh: boolean\n lastRead?: number\n currentModified?: number\n conflict: boolean\n } {\n const recorded = this.state.readTimestamps.get(filePath)\n\n if (!recorded) {\n return { isFresh: true, conflict: false }\n }\n\n try {\n if (!existsSync(filePath)) {\n return { isFresh: false, conflict: true }\n }\n\n const currentStats = statSync(filePath)\n const isFresh = currentStats.mtimeMs <= recorded.lastModified\n const conflict = !isFresh\n\n if (conflict) {\n this.state.editConflicts.add(filePath)\n\n // Emit file conflict event\n emitReminderEvent('file:conflict', {\n filePath,\n lastRead: recorded.lastRead,\n lastModified: recorded.lastModified,\n currentModified: currentStats.mtimeMs,\n sizeDiff: currentStats.size - recorded.size,\n })\n }\n\n return {\n isFresh,\n lastRead: recorded.lastRead,\n currentModified: currentStats.mtimeMs,\n conflict,\n }\n } catch (error) {\n console.error(`Error checking freshness for ${filePath}:`, error)\n return { isFresh: false, conflict: true }\n }\n }\n\n /**\n * Record file edit operation by Agent\n */\n public recordFileEdit(filePath: string, content?: string): void {\n try {\n const now = Date.now()\n\n // Update recorded timestamp after edit\n if (existsSync(filePath)) {\n const stats = statSync(filePath)\n const existing = this.state.readTimestamps.get(filePath)\n\n if (existing) {\n existing.lastModified = stats.mtimeMs\n existing.size = stats.size\n existing.lastAgentEdit = now // Mark this as Agent-initiated edit\n this.state.readTimestamps.set(filePath, existing)\n } else {\n // Create new record for Agent-edited file\n const timestamp: FileTimestamp = {\n path: filePath,\n lastRead: now,\n lastModified: stats.mtimeMs,\n size: stats.size,\n lastAgentEdit: now,\n }\n this.state.readTimestamps.set(filePath, timestamp)\n }\n }\n\n // Remove from conflicts since we just edited it\n this.state.editConflicts.delete(filePath)\n\n // Emit file edit event\n emitReminderEvent('file:edited', {\n filePath,\n timestamp: now,\n contentLength: content?.length || 0,\n source: 'agent',\n })\n } catch (error) {\n console.error(`Error recording file edit for ${filePath}:`, error)\n }\n }\n\n public generateFileModificationReminder(filePath: string): string | null {\n const recorded = this.state.readTimestamps.get(filePath)\n\n if (!recorded) {\n return null\n }\n\n try {\n if (!existsSync(filePath)) {\n return `Note: ${filePath} was deleted since last read.`\n }\n\n const currentStats = statSync(filePath)\n const isModified = currentStats.mtimeMs > recorded.lastModified\n\n if (!isModified) {\n return null\n }\n\n // Check if this was an Agent-initiated change\n // Use small time tolerance to handle filesystem timestamp precision issues\n const TIME_TOLERANCE_MS = 100\n if (\n recorded.lastAgentEdit &&\n recorded.lastAgentEdit >= recorded.lastModified - TIME_TOLERANCE_MS\n ) {\n // Agent modified this file recently, no reminder needed\n // (context already contains before/after content)\n return null\n }\n\n // External modification detected - generate reminder\n return `Note: ${filePath} was modified externally since last read. The file may have changed outside of this session.`\n } catch (error) {\n console.error(`Error checking modification for ${filePath}:`, error)\n return null\n }\n }\n\n public getConflictedFiles(): string[] {\n return Array.from(this.state.editConflicts)\n }\n\n public getSessionFiles(): string[] {\n return Array.from(this.state.sessionFiles)\n }\n\n public resetSession(): void {\n // Clean up existing todo file watchers\n this.state.watchedTodoFiles.forEach(filePath => {\n try {\n unwatchFile(filePath)\n } catch (error) {\n console.error(`Error unwatching file ${filePath}:`, error)\n }\n })\n\n this.state = {\n readTimestamps: new Map(),\n editConflicts: new Set(),\n sessionFiles: new Set(),\n watchedTodoFiles: new Map(),\n }\n }\n\n /**\n * Start watching todo file for an agent\n */\n public startWatchingTodoFile(agentId: string): void {\n try {\n const filePath = getAgentFilePath(agentId)\n\n // Don't watch if already watching\n if (this.state.watchedTodoFiles.has(agentId)) {\n return\n }\n\n this.state.watchedTodoFiles.set(agentId, filePath)\n\n // Record initial state if file exists\n if (existsSync(filePath)) {\n this.recordFileRead(filePath)\n }\n\n // Start watching for changes\n watchFile(filePath, { interval: 1000 }, (curr, prev) => {\n // Check if this was an external modification\n const reminder = this.generateFileModificationReminder(filePath)\n if (reminder) {\n // File was modified externally, emit todo change reminder\n emitReminderEvent('todo:file_changed', {\n agentId,\n filePath,\n reminder,\n timestamp: Date.now(),\n currentStats: { mtime: curr.mtime, size: curr.size },\n previousStats: { mtime: prev.mtime, size: prev.size },\n })\n }\n })\n } catch (error) {\n console.error(\n `Error starting todo file watch for agent ${agentId}:`,\n error,\n )\n }\n }\n\n /**\n * Stop watching todo file for an agent\n */\n public stopWatchingTodoFile(agentId: string): void {\n try {\n const filePath = this.state.watchedTodoFiles.get(agentId)\n if (filePath) {\n unwatchFile(filePath)\n this.state.watchedTodoFiles.delete(agentId)\n }\n } catch (error) {\n console.error(\n `Error stopping todo file watch for agent ${agentId}:`,\n error,\n )\n }\n }\n\n public getFileInfo(filePath: string): FileTimestamp | null {\n return this.state.readTimestamps.get(filePath) || null\n }\n\n public isFileTracked(filePath: string): boolean {\n return this.state.readTimestamps.has(filePath)\n }\n\n /**\n * Retrieves files prioritized for recovery during conversation compression\n *\n * Selects recently accessed files based on:\n * - File access recency (most recent first)\n * - File type relevance (excludes dependencies, build artifacts)\n * - Development workflow importance\n *\n * Used to maintain coding context when conversation history is compressed\n */\n public getImportantFiles(maxFiles: number = 5): Array<{\n path: string\n timestamp: number\n size: number\n }> {\n return Array.from(this.state.readTimestamps.entries())\n .map(([path, info]) => ({\n path,\n timestamp: info.lastRead,\n size: info.size,\n }))\n .filter(file => this.isValidForRecovery(file.path))\n .sort((a, b) => b.timestamp - a.timestamp) // Newest first\n .slice(0, maxFiles)\n }\n\n /**\n * Determines which files are suitable for automatic recovery\n *\n * Excludes files that are typically not relevant for development context:\n * - Build artifacts and generated files\n * - Dependencies and cached files\n * - Temporary files and system directories\n */\n private isValidForRecovery(filePath: string): boolean {\n return (\n !filePath.includes('node_modules') &&\n !filePath.includes('.git') &&\n !filePath.startsWith('/tmp') &&\n !filePath.includes('.cache') &&\n !filePath.includes('dist/') &&\n !filePath.includes('build/')\n )\n }\n}\n\nexport const fileFreshnessService = new FileFreshnessService()\n\nexport const recordFileRead = (filePath: string) =>\n fileFreshnessService.recordFileRead(filePath)\nexport const recordFileEdit = (filePath: string, content?: string) =>\n fileFreshnessService.recordFileEdit(filePath, content)\nexport const checkFileFreshness = (filePath: string) =>\n fileFreshnessService.checkFileFreshness(filePath)\nexport const generateFileModificationReminder = (filePath: string) =>\n fileFreshnessService.generateFileModificationReminder(filePath)\nexport const resetFileFreshnessSession = () =>\n fileFreshnessService.resetSession()\nexport const startWatchingTodoFile = (agentId: string) =>\n fileFreshnessService.startWatchingTodoFile(agentId)\nexport const stopWatchingTodoFile = (agentId: string) =>\n fileFreshnessService.stopWatchingTodoFile(agentId)\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import { getModelFeatures } from "./openai.js";
|
|
2
|
+
async function testGPT5Connection(config) {
|
|
3
|
+
const startTime = Date.now();
|
|
4
|
+
if (!config.model || !config.apiKey) {
|
|
5
|
+
return {
|
|
6
|
+
success: false,
|
|
7
|
+
message: "Invalid configuration",
|
|
8
|
+
details: "Model name and API key are required"
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
const isGPT5 = config.model.toLowerCase().includes("gpt-5");
|
|
12
|
+
const modelFeatures = getModelFeatures(config.model);
|
|
13
|
+
const baseURL = config.baseURL || "https://api.openai.com/v1";
|
|
14
|
+
const isOfficialOpenAI = !config.baseURL || config.baseURL.includes("api.openai.com");
|
|
15
|
+
console.log(`\u{1F527} Testing GPT-5 connection for model: ${config.model}`);
|
|
16
|
+
console.log(`\u{1F527} Base URL: ${baseURL}`);
|
|
17
|
+
console.log(`\u{1F527} Official OpenAI: ${isOfficialOpenAI}`);
|
|
18
|
+
console.log(`\u{1F527} Supports Responses API: ${modelFeatures.supportsResponsesAPI}`);
|
|
19
|
+
if (isGPT5 && modelFeatures.supportsResponsesAPI && isOfficialOpenAI) {
|
|
20
|
+
console.log(`\u{1F680} Attempting Responses API for ${config.model}`);
|
|
21
|
+
const responsesResult = await testResponsesAPI(config, baseURL, startTime);
|
|
22
|
+
if (responsesResult.success) {
|
|
23
|
+
console.log(`\u2705 Responses API test successful for ${config.model}`);
|
|
24
|
+
return responsesResult;
|
|
25
|
+
} else {
|
|
26
|
+
console.log(`\u26A0\uFE0F Responses API failed, falling back to Chat Completions: ${responsesResult.details}`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
console.log(`\u{1F504} Using Chat Completions API for ${config.model}`);
|
|
30
|
+
return await testChatCompletionsAPI(config, baseURL, startTime);
|
|
31
|
+
}
|
|
32
|
+
async function testResponsesAPI(config, baseURL, startTime) {
|
|
33
|
+
const testURL = `${baseURL.replace(/\/+$/, "")}/responses`;
|
|
34
|
+
const testPayload = {
|
|
35
|
+
model: config.model,
|
|
36
|
+
input: [
|
|
37
|
+
{
|
|
38
|
+
role: "user",
|
|
39
|
+
content: 'Please respond with exactly "YES" (in capital letters) to confirm this connection is working.'
|
|
40
|
+
}
|
|
41
|
+
],
|
|
42
|
+
max_completion_tokens: Math.max(config.maxTokens || 8192, 8192),
|
|
43
|
+
temperature: 1,
|
|
44
|
+
// GPT-5 requirement
|
|
45
|
+
reasoning: {
|
|
46
|
+
effort: "low"
|
|
47
|
+
// Fast response for connection test
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
const headers = {
|
|
51
|
+
"Content-Type": "application/json",
|
|
52
|
+
"Authorization": `Bearer ${config.apiKey}`
|
|
53
|
+
};
|
|
54
|
+
console.log(`\u{1F527} Responses API URL: ${testURL}`);
|
|
55
|
+
console.log(`\u{1F527} Responses API payload:`, JSON.stringify(testPayload, null, 2));
|
|
56
|
+
try {
|
|
57
|
+
const response = await fetch(testURL, {
|
|
58
|
+
method: "POST",
|
|
59
|
+
headers,
|
|
60
|
+
body: JSON.stringify(testPayload)
|
|
61
|
+
});
|
|
62
|
+
const responseTime = Date.now() - startTime;
|
|
63
|
+
if (response.ok) {
|
|
64
|
+
const data = await response.json();
|
|
65
|
+
console.log(`\u2705 Responses API successful response:`, data);
|
|
66
|
+
let responseContent = "";
|
|
67
|
+
if (data.output_text) {
|
|
68
|
+
responseContent = data.output_text;
|
|
69
|
+
} else if (data.output && Array.isArray(data.output)) {
|
|
70
|
+
const messageOutput = data.output.find((item) => item.type === "message");
|
|
71
|
+
if (messageOutput && messageOutput.content) {
|
|
72
|
+
const textContent = messageOutput.content.find((c) => c.type === "output_text");
|
|
73
|
+
responseContent = textContent?.text || "";
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
const containsYes = responseContent.toLowerCase().includes("yes");
|
|
77
|
+
if (containsYes) {
|
|
78
|
+
return {
|
|
79
|
+
success: true,
|
|
80
|
+
message: "\u2705 GPT-5 Responses API connection successful",
|
|
81
|
+
endpoint: "/responses",
|
|
82
|
+
details: `Model responded correctly: "${responseContent.trim()}"`,
|
|
83
|
+
apiUsed: "responses",
|
|
84
|
+
responseTime
|
|
85
|
+
};
|
|
86
|
+
} else {
|
|
87
|
+
return {
|
|
88
|
+
success: false,
|
|
89
|
+
message: "\u26A0\uFE0F Responses API connected but unexpected response",
|
|
90
|
+
endpoint: "/responses",
|
|
91
|
+
details: `Expected "YES" but got: "${responseContent.trim() || "(empty response)"}"`,
|
|
92
|
+
apiUsed: "responses",
|
|
93
|
+
responseTime
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
} else {
|
|
97
|
+
const errorData = await response.json().catch(() => null);
|
|
98
|
+
const errorMessage = errorData?.error?.message || errorData?.message || response.statusText;
|
|
99
|
+
console.log(`\u274C Responses API error (${response.status}):`, errorData);
|
|
100
|
+
return {
|
|
101
|
+
success: false,
|
|
102
|
+
message: `\u274C Responses API failed (${response.status})`,
|
|
103
|
+
endpoint: "/responses",
|
|
104
|
+
details: `Error: ${errorMessage}`,
|
|
105
|
+
apiUsed: "responses",
|
|
106
|
+
responseTime: Date.now() - startTime
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
} catch (error) {
|
|
110
|
+
console.log(`\u274C Responses API connection error:`, error);
|
|
111
|
+
return {
|
|
112
|
+
success: false,
|
|
113
|
+
message: "\u274C Responses API connection failed",
|
|
114
|
+
endpoint: "/responses",
|
|
115
|
+
details: error instanceof Error ? error.message : String(error),
|
|
116
|
+
apiUsed: "responses",
|
|
117
|
+
responseTime: Date.now() - startTime
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
async function testChatCompletionsAPI(config, baseURL, startTime) {
|
|
122
|
+
const testURL = `${baseURL.replace(/\/+$/, "")}/chat/completions`;
|
|
123
|
+
const isGPT5 = config.model.toLowerCase().includes("gpt-5");
|
|
124
|
+
const testPayload = {
|
|
125
|
+
model: config.model,
|
|
126
|
+
messages: [
|
|
127
|
+
{
|
|
128
|
+
role: "user",
|
|
129
|
+
content: 'Please respond with exactly "YES" (in capital letters) to confirm this connection is working.'
|
|
130
|
+
}
|
|
131
|
+
],
|
|
132
|
+
temperature: isGPT5 ? 1 : 0,
|
|
133
|
+
// GPT-5 requires temperature=1
|
|
134
|
+
stream: false
|
|
135
|
+
};
|
|
136
|
+
if (isGPT5) {
|
|
137
|
+
testPayload.max_completion_tokens = Math.max(config.maxTokens || 8192, 8192);
|
|
138
|
+
delete testPayload.max_tokens;
|
|
139
|
+
console.log(`\u{1F527} GPT-5 mode: Using max_completion_tokens = ${testPayload.max_completion_tokens}`);
|
|
140
|
+
} else {
|
|
141
|
+
testPayload.max_tokens = Math.max(config.maxTokens || 8192, 8192);
|
|
142
|
+
}
|
|
143
|
+
const headers = {
|
|
144
|
+
"Content-Type": "application/json"
|
|
145
|
+
};
|
|
146
|
+
if (config.provider === "azure") {
|
|
147
|
+
headers["api-key"] = config.apiKey;
|
|
148
|
+
} else {
|
|
149
|
+
headers["Authorization"] = `Bearer ${config.apiKey}`;
|
|
150
|
+
}
|
|
151
|
+
console.log(`\u{1F527} Chat Completions URL: ${testURL}`);
|
|
152
|
+
console.log(`\u{1F527} Chat Completions payload:`, JSON.stringify(testPayload, null, 2));
|
|
153
|
+
try {
|
|
154
|
+
const response = await fetch(testURL, {
|
|
155
|
+
method: "POST",
|
|
156
|
+
headers,
|
|
157
|
+
body: JSON.stringify(testPayload)
|
|
158
|
+
});
|
|
159
|
+
const responseTime = Date.now() - startTime;
|
|
160
|
+
if (response.ok) {
|
|
161
|
+
const data = await response.json();
|
|
162
|
+
console.log(`\u2705 Chat Completions successful response:`, data);
|
|
163
|
+
const responseContent = data.choices?.[0]?.message?.content || "";
|
|
164
|
+
const containsYes = responseContent.toLowerCase().includes("yes");
|
|
165
|
+
if (containsYes) {
|
|
166
|
+
return {
|
|
167
|
+
success: true,
|
|
168
|
+
message: `\u2705 ${isGPT5 ? "GPT-5" : "Model"} Chat Completions connection successful`,
|
|
169
|
+
endpoint: "/chat/completions",
|
|
170
|
+
details: `Model responded correctly: "${responseContent.trim()}"`,
|
|
171
|
+
apiUsed: "chat_completions",
|
|
172
|
+
responseTime
|
|
173
|
+
};
|
|
174
|
+
} else {
|
|
175
|
+
return {
|
|
176
|
+
success: false,
|
|
177
|
+
message: "\u26A0\uFE0F Chat Completions connected but unexpected response",
|
|
178
|
+
endpoint: "/chat/completions",
|
|
179
|
+
details: `Expected "YES" but got: "${responseContent.trim() || "(empty response)"}"`,
|
|
180
|
+
apiUsed: "chat_completions",
|
|
181
|
+
responseTime
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
} else {
|
|
185
|
+
const errorData = await response.json().catch(() => null);
|
|
186
|
+
const errorMessage = errorData?.error?.message || errorData?.message || response.statusText;
|
|
187
|
+
console.log(`\u274C Chat Completions error (${response.status}):`, errorData);
|
|
188
|
+
let details = `Error: ${errorMessage}`;
|
|
189
|
+
if (response.status === 400 && errorMessage.includes("max_tokens") && isGPT5) {
|
|
190
|
+
details += "\n\n\u{1F527} GPT-5 Fix Applied: This error suggests a parameter compatibility issue. Please check if the provider supports GPT-5 with max_completion_tokens.";
|
|
191
|
+
}
|
|
192
|
+
return {
|
|
193
|
+
success: false,
|
|
194
|
+
message: `\u274C Chat Completions failed (${response.status})`,
|
|
195
|
+
endpoint: "/chat/completions",
|
|
196
|
+
details,
|
|
197
|
+
apiUsed: "chat_completions",
|
|
198
|
+
responseTime: Date.now() - startTime
|
|
199
|
+
};
|
|
200
|
+
}
|
|
201
|
+
} catch (error) {
|
|
202
|
+
console.log(`\u274C Chat Completions connection error:`, error);
|
|
203
|
+
return {
|
|
204
|
+
success: false,
|
|
205
|
+
message: "\u274C Chat Completions connection failed",
|
|
206
|
+
endpoint: "/chat/completions",
|
|
207
|
+
details: error instanceof Error ? error.message : String(error),
|
|
208
|
+
apiUsed: "chat_completions",
|
|
209
|
+
responseTime: Date.now() - startTime
|
|
210
|
+
};
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
function validateGPT5Config(config) {
|
|
214
|
+
console.log(`\u{1F527} validateGPT5Config called with:`, {
|
|
215
|
+
model: config.model,
|
|
216
|
+
hasApiKey: !!config.apiKey,
|
|
217
|
+
baseURL: config.baseURL,
|
|
218
|
+
provider: config.provider
|
|
219
|
+
});
|
|
220
|
+
const errors = [];
|
|
221
|
+
if (!config.model) {
|
|
222
|
+
errors.push("Model name is required");
|
|
223
|
+
}
|
|
224
|
+
if (!config.apiKey) {
|
|
225
|
+
errors.push("API key is required");
|
|
226
|
+
}
|
|
227
|
+
if (config.apiKey && config.apiKey.length < 10) {
|
|
228
|
+
errors.push("API key appears to be invalid (too short)");
|
|
229
|
+
}
|
|
230
|
+
const isGPT5 = config.model?.toLowerCase().includes("gpt-5");
|
|
231
|
+
if (isGPT5) {
|
|
232
|
+
console.log(`\u{1F527} GPT-5 validation: model=${config.model}, maxTokens=${config.maxTokens}`);
|
|
233
|
+
if (config.maxTokens && config.maxTokens < 1e3) {
|
|
234
|
+
errors.push("GPT-5 models typically require at least 1000 max tokens");
|
|
235
|
+
}
|
|
236
|
+
console.log(`\u{1F527} No third-party restrictions applied for GPT-5`);
|
|
237
|
+
}
|
|
238
|
+
console.log(`\u{1F527} Validation result:`, { valid: errors.length === 0, errors });
|
|
239
|
+
return {
|
|
240
|
+
valid: errors.length === 0,
|
|
241
|
+
errors
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
export {
|
|
245
|
+
testGPT5Connection,
|
|
246
|
+
validateGPT5Config
|
|
247
|
+
};
|
|
248
|
+
//# sourceMappingURL=gpt5ConnectionTest.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/services/gpt5ConnectionTest.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * \uD83D\uDD25 GPT-5 Connection Test Service\n * \n * Specialized connection testing for GPT-5 models that supports both\n * Responses API and Chat Completions API with proper fallback handling.\n */\n\nimport { getModelFeatures } from './openai'\n\nexport interface ConnectionTestResult {\n success: boolean\n message: string\n endpoint?: string\n details?: string\n apiUsed?: 'responses' | 'chat_completions'\n responseTime?: number\n}\n\nexport interface GPT5TestConfig {\n model: string\n apiKey: string\n baseURL?: string\n maxTokens?: number\n provider?: string\n}\n\n/**\n * Test GPT-5 model connection with intelligent API selection\n */\nexport async function testGPT5Connection(config: GPT5TestConfig): Promise<ConnectionTestResult> {\n const startTime = Date.now()\n \n // Validate configuration\n if (!config.model || !config.apiKey) {\n return {\n success: false,\n message: 'Invalid configuration',\n details: 'Model name and API key are required',\n }\n }\n\n const isGPT5 = config.model.toLowerCase().includes('gpt-5')\n const modelFeatures = getModelFeatures(config.model)\n const baseURL = config.baseURL || 'https://api.openai.com/v1'\n const isOfficialOpenAI = !config.baseURL || config.baseURL.includes('api.openai.com')\n\n console.log(`\uD83D\uDD27 Testing GPT-5 connection for model: ${config.model}`)\n console.log(`\uD83D\uDD27 Base URL: ${baseURL}`)\n console.log(`\uD83D\uDD27 Official OpenAI: ${isOfficialOpenAI}`)\n console.log(`\uD83D\uDD27 Supports Responses API: ${modelFeatures.supportsResponsesAPI}`)\n\n // Try Responses API first for official GPT-5 models\n if (isGPT5 && modelFeatures.supportsResponsesAPI && isOfficialOpenAI) {\n console.log(`\uD83D\uDE80 Attempting Responses API for ${config.model}`)\n const responsesResult = await testResponsesAPI(config, baseURL, startTime)\n \n if (responsesResult.success) {\n console.log(`\u2705 Responses API test successful for ${config.model}`)\n return responsesResult\n } else {\n console.log(`\u26A0\uFE0F Responses API failed, falling back to Chat Completions: ${responsesResult.details}`)\n }\n }\n\n // Fallback to Chat Completions API\n console.log(`\uD83D\uDD04 Using Chat Completions API for ${config.model}`)\n return await testChatCompletionsAPI(config, baseURL, startTime)\n}\n\n/**\n * Test using GPT-5 Responses API\n */\nasync function testResponsesAPI(\n config: GPT5TestConfig, \n baseURL: string, \n startTime: number\n): Promise<ConnectionTestResult> {\n const testURL = `${baseURL.replace(/\\/+$/, '')}/responses`\n \n const testPayload = {\n model: config.model,\n input: [\n {\n role: 'user',\n content: 'Please respond with exactly \"YES\" (in capital letters) to confirm this connection is working.',\n },\n ],\n max_completion_tokens: Math.max(config.maxTokens || 8192, 8192),\n temperature: 1, // GPT-5 requirement\n reasoning: {\n effort: 'low', // Fast response for connection test\n },\n }\n\n const headers = {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${config.apiKey}`,\n }\n\n console.log(`\uD83D\uDD27 Responses API URL: ${testURL}`)\n console.log(`\uD83D\uDD27 Responses API payload:`, JSON.stringify(testPayload, null, 2))\n\n try {\n const response = await fetch(testURL, {\n method: 'POST',\n headers,\n body: JSON.stringify(testPayload),\n })\n\n const responseTime = Date.now() - startTime\n\n if (response.ok) {\n const data = await response.json()\n console.log(`\u2705 Responses API successful response:`, data)\n\n // Extract content from Responses API format\n let responseContent = ''\n if (data.output_text) {\n responseContent = data.output_text\n } else if (data.output && Array.isArray(data.output)) {\n // Extract from structured output format\n const messageOutput = data.output.find(item => item.type === 'message')\n if (messageOutput && messageOutput.content) {\n const textContent = messageOutput.content.find(c => c.type === 'output_text')\n responseContent = textContent?.text || ''\n }\n }\n\n const containsYes = responseContent.toLowerCase().includes('yes')\n\n if (containsYes) {\n return {\n success: true,\n message: '\u2705 GPT-5 Responses API connection successful',\n endpoint: '/responses',\n details: `Model responded correctly: \"${responseContent.trim()}\"`,\n apiUsed: 'responses',\n responseTime,\n }\n } else {\n return {\n success: false,\n message: '\u26A0\uFE0F Responses API connected but unexpected response',\n endpoint: '/responses',\n details: `Expected \"YES\" but got: \"${responseContent.trim() || '(empty response)'}\"`,\n apiUsed: 'responses',\n responseTime,\n }\n }\n } else {\n const errorData = await response.json().catch(() => null)\n const errorMessage = errorData?.error?.message || errorData?.message || response.statusText\n\n console.log(`\u274C Responses API error (${response.status}):`, errorData)\n\n return {\n success: false,\n message: `\u274C Responses API failed (${response.status})`,\n endpoint: '/responses',\n details: `Error: ${errorMessage}`,\n apiUsed: 'responses',\n responseTime: Date.now() - startTime,\n }\n }\n } catch (error) {\n console.log(`\u274C Responses API connection error:`, error)\n \n return {\n success: false,\n message: '\u274C Responses API connection failed',\n endpoint: '/responses',\n details: error instanceof Error ? error.message : String(error),\n apiUsed: 'responses',\n responseTime: Date.now() - startTime,\n }\n }\n}\n\n/**\n * Test using Chat Completions API with GPT-5 compatibility\n */\nasync function testChatCompletionsAPI(\n config: GPT5TestConfig, \n baseURL: string, \n startTime: number\n): Promise<ConnectionTestResult> {\n const testURL = `${baseURL.replace(/\\/+$/, '')}/chat/completions`\n \n const isGPT5 = config.model.toLowerCase().includes('gpt-5')\n \n // Create test payload with GPT-5 compatibility\n const testPayload: any = {\n model: config.model,\n messages: [\n {\n role: 'user',\n content: 'Please respond with exactly \"YES\" (in capital letters) to confirm this connection is working.',\n },\n ],\n temperature: isGPT5 ? 1 : 0, // GPT-5 requires temperature=1\n stream: false,\n }\n\n // \uD83D\uDD27 Apply GPT-5 parameter transformations\n if (isGPT5) {\n testPayload.max_completion_tokens = Math.max(config.maxTokens || 8192, 8192)\n delete testPayload.max_tokens // \uD83D\uDD25 CRITICAL: Remove max_tokens for GPT-5\n console.log(`\uD83D\uDD27 GPT-5 mode: Using max_completion_tokens = ${testPayload.max_completion_tokens}`)\n } else {\n testPayload.max_tokens = Math.max(config.maxTokens || 8192, 8192)\n }\n\n const headers = {\n 'Content-Type': 'application/json',\n }\n\n // Add provider-specific headers\n if (config.provider === 'azure') {\n headers['api-key'] = config.apiKey\n } else {\n headers['Authorization'] = `Bearer ${config.apiKey}`\n }\n\n console.log(`\uD83D\uDD27 Chat Completions URL: ${testURL}`)\n console.log(`\uD83D\uDD27 Chat Completions payload:`, JSON.stringify(testPayload, null, 2))\n\n try {\n const response = await fetch(testURL, {\n method: 'POST',\n headers,\n body: JSON.stringify(testPayload),\n })\n\n const responseTime = Date.now() - startTime\n\n if (response.ok) {\n const data = await response.json()\n console.log(`\u2705 Chat Completions successful response:`, data)\n\n const responseContent = data.choices?.[0]?.message?.content || ''\n const containsYes = responseContent.toLowerCase().includes('yes')\n\n if (containsYes) {\n return {\n success: true,\n message: `\u2705 ${isGPT5 ? 'GPT-5' : 'Model'} Chat Completions connection successful`,\n endpoint: '/chat/completions',\n details: `Model responded correctly: \"${responseContent.trim()}\"`,\n apiUsed: 'chat_completions',\n responseTime,\n }\n } else {\n return {\n success: false,\n message: '\u26A0\uFE0F Chat Completions connected but unexpected response',\n endpoint: '/chat/completions',\n details: `Expected \"YES\" but got: \"${responseContent.trim() || '(empty response)'}\"`,\n apiUsed: 'chat_completions',\n responseTime,\n }\n }\n } else {\n const errorData = await response.json().catch(() => null)\n const errorMessage = errorData?.error?.message || errorData?.message || response.statusText\n\n console.log(`\u274C Chat Completions error (${response.status}):`, errorData)\n\n // \uD83D\uDD27 Provide specific guidance for GPT-5 errors\n let details = `Error: ${errorMessage}`\n if (response.status === 400 && errorMessage.includes('max_tokens') && isGPT5) {\n details += '\\n\\n\uD83D\uDD27 GPT-5 Fix Applied: This error suggests a parameter compatibility issue. Please check if the provider supports GPT-5 with max_completion_tokens.'\n }\n\n return {\n success: false,\n message: `\u274C Chat Completions failed (${response.status})`,\n endpoint: '/chat/completions',\n details: details,\n apiUsed: 'chat_completions',\n responseTime: Date.now() - startTime,\n }\n }\n } catch (error) {\n console.log(`\u274C Chat Completions connection error:`, error)\n \n return {\n success: false,\n message: '\u274C Chat Completions connection failed',\n endpoint: '/chat/completions',\n details: error instanceof Error ? error.message : String(error),\n apiUsed: 'chat_completions',\n responseTime: Date.now() - startTime,\n }\n }\n}\n\n/**\n * Quick validation for GPT-5 configuration\n */\nexport function validateGPT5Config(config: GPT5TestConfig): { valid: boolean; errors: string[] } {\n console.log(`\uD83D\uDD27 validateGPT5Config called with:`, {\n model: config.model,\n hasApiKey: !!config.apiKey,\n baseURL: config.baseURL,\n provider: config.provider,\n })\n \n const errors: string[] = []\n\n if (!config.model) {\n errors.push('Model name is required')\n }\n\n if (!config.apiKey) {\n errors.push('API key is required')\n }\n\n if (config.apiKey && config.apiKey.length < 10) {\n errors.push('API key appears to be invalid (too short)')\n }\n\n const isGPT5 = config.model?.toLowerCase().includes('gpt-5')\n if (isGPT5) {\n console.log(`\uD83D\uDD27 GPT-5 validation: model=${config.model}, maxTokens=${config.maxTokens}`)\n \n if (config.maxTokens && config.maxTokens < 1000) {\n errors.push('GPT-5 models typically require at least 1000 max tokens')\n }\n \n // \u5B8C\u5168\u79FB\u9664\u7B2C\u4E09\u65B9provider\u9650\u5236\uFF0C\u5141\u8BB8\u6240\u6709\u4EE3\u7406\u4E2D\u8F6C\u7AD9\u4F7F\u7528GPT-5\n console.log(`\uD83D\uDD27 No third-party restrictions applied for GPT-5`)\n }\n\n console.log(`\uD83D\uDD27 Validation result:`, { valid: errors.length === 0, errors })\n\n return {\n valid: errors.length === 0,\n errors,\n }\n}"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|