@qduc/term2 0.1.0
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 +21 -0
- package/dist/agent.d.ts +19 -0
- package/dist/agent.d.ts.map +1 -0
- package/dist/agent.js +143 -0
- package/dist/agent.js.map +1 -0
- package/dist/app.d.ts +22 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/app.js +403 -0
- package/dist/app.js.map +1 -0
- package/dist/app.model-command-feedback.test.d.ts +2 -0
- package/dist/app.model-command-feedback.test.d.ts.map +1 -0
- package/dist/app.model-command-feedback.test.js +19 -0
- package/dist/app.model-command-feedback.test.js.map +1 -0
- package/dist/app.parseInput.test.d.ts +2 -0
- package/dist/app.parseInput.test.d.ts.map +1 -0
- package/dist/app.parseInput.test.js +97 -0
- package/dist/app.parseInput.test.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +241 -0
- package/dist/cli.js.map +1 -0
- package/dist/components/ApprovalPrompt.d.ts +10 -0
- package/dist/components/ApprovalPrompt.d.ts.map +1 -0
- package/dist/components/ApprovalPrompt.js +163 -0
- package/dist/components/ApprovalPrompt.js.map +1 -0
- package/dist/components/Banner.d.ts +9 -0
- package/dist/components/Banner.d.ts.map +1 -0
- package/dist/components/Banner.js +86 -0
- package/dist/components/Banner.js.map +1 -0
- package/dist/components/BottomArea.d.ts +33 -0
- package/dist/components/BottomArea.d.ts.map +1 -0
- package/dist/components/BottomArea.js +31 -0
- package/dist/components/BottomArea.js.map +1 -0
- package/dist/components/BottomArea.test.d.ts +2 -0
- package/dist/components/BottomArea.test.d.ts.map +1 -0
- package/dist/components/BottomArea.test.js +73 -0
- package/dist/components/BottomArea.test.js.map +1 -0
- package/dist/components/ChatMessage.d.ts +7 -0
- package/dist/components/ChatMessage.d.ts.map +1 -0
- package/dist/components/ChatMessage.js +10 -0
- package/dist/components/ChatMessage.js.map +1 -0
- package/dist/components/CommandMessage.d.ts +15 -0
- package/dist/components/CommandMessage.d.ts.map +1 -0
- package/dist/components/CommandMessage.js +188 -0
- package/dist/components/CommandMessage.js.map +1 -0
- package/dist/components/CommandMessage.test.d.ts +2 -0
- package/dist/components/CommandMessage.test.d.ts.map +1 -0
- package/dist/components/CommandMessage.test.js +35 -0
- package/dist/components/CommandMessage.test.js.map +1 -0
- package/dist/components/ErrorBoundary.d.ts +27 -0
- package/dist/components/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/ErrorBoundary.js +77 -0
- package/dist/components/ErrorBoundary.js.map +1 -0
- package/dist/components/ErrorBoundary.test.d.ts +2 -0
- package/dist/components/ErrorBoundary.test.d.ts.map +1 -0
- package/dist/components/ErrorBoundary.test.js +32 -0
- package/dist/components/ErrorBoundary.test.js.map +1 -0
- package/dist/components/Input/PopupManager.d.ts +42 -0
- package/dist/components/Input/PopupManager.d.ts.map +1 -0
- package/dist/components/Input/PopupManager.js +13 -0
- package/dist/components/Input/PopupManager.js.map +1 -0
- package/dist/components/InputBox.d.ts +18 -0
- package/dist/components/InputBox.d.ts.map +1 -0
- package/dist/components/InputBox.js +384 -0
- package/dist/components/InputBox.js.map +1 -0
- package/dist/components/InputBox.menu-logic.test.d.ts +2 -0
- package/dist/components/InputBox.menu-logic.test.d.ts.map +1 -0
- package/dist/components/InputBox.menu-logic.test.js +151 -0
- package/dist/components/InputBox.menu-logic.test.js.map +1 -0
- package/dist/components/InputBox.test.d.ts +2 -0
- package/dist/components/InputBox.test.d.ts.map +1 -0
- package/dist/components/InputBox.test.js +91 -0
- package/dist/components/InputBox.test.js.map +1 -0
- package/dist/components/LiveResponse.d.ts +13 -0
- package/dist/components/LiveResponse.d.ts.map +1 -0
- package/dist/components/LiveResponse.js +16 -0
- package/dist/components/LiveResponse.js.map +1 -0
- package/dist/components/MarkdownRenderer.d.ts +8 -0
- package/dist/components/MarkdownRenderer.d.ts.map +1 -0
- package/dist/components/MarkdownRenderer.js +225 -0
- package/dist/components/MarkdownRenderer.js.map +1 -0
- package/dist/components/MentorMode.test.d.ts +2 -0
- package/dist/components/MentorMode.test.d.ts.map +1 -0
- package/dist/components/MentorMode.test.js.map +1 -0
- package/dist/components/MessageList.d.ts +7 -0
- package/dist/components/MessageList.d.ts.map +1 -0
- package/dist/components/MessageList.js +29 -0
- package/dist/components/MessageList.js.map +1 -0
- package/dist/components/MessageList.test.d.ts +2 -0
- package/dist/components/MessageList.test.d.ts.map +1 -0
- package/dist/components/MessageList.test.js +15 -0
- package/dist/components/MessageList.test.js.map +1 -0
- package/dist/components/ModelSelectionMenu.d.ts +18 -0
- package/dist/components/ModelSelectionMenu.d.ts.map +1 -0
- package/dist/components/ModelSelectionMenu.js +91 -0
- package/dist/components/ModelSelectionMenu.js.map +1 -0
- package/dist/components/ModelSelectionMenu.test.d.ts +2 -0
- package/dist/components/ModelSelectionMenu.test.d.ts.map +1 -0
- package/dist/components/ModelSelectionMenu.test.js +83 -0
- package/dist/components/ModelSelectionMenu.test.js.map +1 -0
- package/dist/components/PathSelectionMenu.d.ts +12 -0
- package/dist/components/PathSelectionMenu.d.ts.map +1 -0
- package/dist/components/PathSelectionMenu.js +42 -0
- package/dist/components/PathSelectionMenu.js.map +1 -0
- package/dist/components/SettingsSelectionMenu.d.ts +9 -0
- package/dist/components/SettingsSelectionMenu.d.ts.map +1 -0
- package/dist/components/SettingsSelectionMenu.js +21 -0
- package/dist/components/SettingsSelectionMenu.js.map +1 -0
- package/dist/components/SlashCommandMenu.d.ts +15 -0
- package/dist/components/SlashCommandMenu.d.ts.map +1 -0
- package/dist/components/SlashCommandMenu.js +20 -0
- package/dist/components/SlashCommandMenu.js.map +1 -0
- package/dist/components/StatusBar.d.ts +11 -0
- package/dist/components/StatusBar.d.ts.map +1 -0
- package/dist/components/StatusBar.js +59 -0
- package/dist/components/StatusBar.js.map +1 -0
- package/dist/components/TextInput.d.ts +42 -0
- package/dist/components/TextInput.d.ts.map +1 -0
- package/dist/components/TextInput.js +397 -0
- package/dist/components/TextInput.js.map +1 -0
- package/dist/components/TextInput.test.d.ts +2 -0
- package/dist/components/TextInput.test.d.ts.map +1 -0
- package/dist/components/TextInput.test.js +75 -0
- package/dist/components/TextInput.test.js.map +1 -0
- package/dist/context/InputContext.d.ts +31 -0
- package/dist/context/InputContext.d.ts.map +1 -0
- package/dist/context/InputContext.js +36 -0
- package/dist/context/InputContext.js.map +1 -0
- package/dist/context/InputContext.stability.test.d.ts +2 -0
- package/dist/context/InputContext.stability.test.d.ts.map +1 -0
- package/dist/context/InputContext.stability.test.js +28 -0
- package/dist/context/InputContext.stability.test.js.map +1 -0
- package/dist/context/InputContext.test.d.ts +2 -0
- package/dist/context/InputContext.test.d.ts.map +1 -0
- package/dist/context/InputContext.test.js +168 -0
- package/dist/context/InputContext.test.js.map +1 -0
- package/dist/debug-schema.d.ts +2 -0
- package/dist/debug-schema.d.ts.map +1 -0
- package/dist/debug-schema.js +22 -0
- package/dist/debug-schema.js.map +1 -0
- package/dist/hooks/use-conversation.d.ts +78 -0
- package/dist/hooks/use-conversation.d.ts.map +1 -0
- package/dist/hooks/use-conversation.js +1017 -0
- package/dist/hooks/use-conversation.js.map +1 -0
- package/dist/hooks/use-input-history.d.ts +16 -0
- package/dist/hooks/use-input-history.d.ts.map +1 -0
- package/dist/hooks/use-input-history.js +71 -0
- package/dist/hooks/use-input-history.js.map +1 -0
- package/dist/hooks/use-model-selection.d.ts +27 -0
- package/dist/hooks/use-model-selection.d.ts.map +1 -0
- package/dist/hooks/use-model-selection.js +187 -0
- package/dist/hooks/use-model-selection.js.map +1 -0
- package/dist/hooks/use-model-selection.test.d.ts +2 -0
- package/dist/hooks/use-model-selection.test.d.ts.map +1 -0
- package/dist/hooks/use-model-selection.test.js +28 -0
- package/dist/hooks/use-model-selection.test.js.map +1 -0
- package/dist/hooks/use-path-completion.d.ts +22 -0
- package/dist/hooks/use-path-completion.d.ts.map +1 -0
- package/dist/hooks/use-path-completion.js +153 -0
- package/dist/hooks/use-path-completion.js.map +1 -0
- package/dist/hooks/use-path-completion.test.d.ts +2 -0
- package/dist/hooks/use-path-completion.test.d.ts.map +1 -0
- package/dist/hooks/use-path-completion.test.js +29 -0
- package/dist/hooks/use-path-completion.test.js.map +1 -0
- package/dist/hooks/use-setting.d.ts +7 -0
- package/dist/hooks/use-setting.d.ts.map +1 -0
- package/dist/hooks/use-setting.js +35 -0
- package/dist/hooks/use-setting.js.map +1 -0
- package/dist/hooks/use-settings-completion.d.ts +23 -0
- package/dist/hooks/use-settings-completion.d.ts.map +1 -0
- package/dist/hooks/use-settings-completion.js +164 -0
- package/dist/hooks/use-settings-completion.js.map +1 -0
- package/dist/hooks/use-settings-completion.test.d.ts +2 -0
- package/dist/hooks/use-settings-completion.test.d.ts.map +1 -0
- package/dist/hooks/use-settings-completion.test.js +334 -0
- package/dist/hooks/use-settings-completion.test.js.map +1 -0
- package/dist/hooks/use-slash-commands.d.ts +21 -0
- package/dist/hooks/use-slash-commands.d.ts.map +1 -0
- package/dist/hooks/use-slash-commands.js +87 -0
- package/dist/hooks/use-slash-commands.js.map +1 -0
- package/dist/hooks/use-slash-commands.test.d.ts +2 -0
- package/dist/hooks/use-slash-commands.test.d.ts.map +1 -0
- package/dist/hooks/use-slash-commands.test.js +246 -0
- package/dist/hooks/use-slash-commands.test.js.map +1 -0
- package/dist/lib/editor-impl.d.ts +23 -0
- package/dist/lib/editor-impl.d.ts.map +1 -0
- package/dist/lib/editor-impl.js +235 -0
- package/dist/lib/editor-impl.js.map +1 -0
- package/dist/lib/openai-agent-client.chat.test.d.ts +2 -0
- package/dist/lib/openai-agent-client.chat.test.d.ts.map +1 -0
- package/dist/lib/openai-agent-client.chat.test.js +68 -0
- package/dist/lib/openai-agent-client.chat.test.js.map +1 -0
- package/dist/lib/openai-agent-client.d.ts +48 -0
- package/dist/lib/openai-agent-client.d.ts.map +1 -0
- package/dist/lib/openai-agent-client.js +653 -0
- package/dist/lib/openai-agent-client.js.map +1 -0
- package/dist/lib/openai-agent-client.test.d.ts +2 -0
- package/dist/lib/openai-agent-client.test.d.ts.map +1 -0
- package/dist/lib/openai-agent-client.test.js +181 -0
- package/dist/lib/openai-agent-client.test.js.map +1 -0
- package/dist/lib/shell.d.ts +7 -0
- package/dist/lib/shell.d.ts.map +1 -0
- package/dist/lib/shell.js +56 -0
- package/dist/lib/shell.js.map +1 -0
- package/dist/lib/tool-invoke.d.ts +4 -0
- package/dist/lib/tool-invoke.d.ts.map +1 -0
- package/dist/lib/tool-invoke.js +26 -0
- package/dist/lib/tool-invoke.js.map +1 -0
- package/dist/lib/tool-invoke.test.d.ts +2 -0
- package/dist/lib/tool-invoke.test.d.ts.map +1 -0
- package/dist/lib/tool-invoke.test.js +19 -0
- package/dist/lib/tool-invoke.test.js.map +1 -0
- package/dist/no-singleton-imports.test.d.ts +2 -0
- package/dist/no-singleton-imports.test.d.ts.map +1 -0
- package/dist/no-singleton-imports.test.js +30 -0
- package/dist/no-singleton-imports.test.js.map +1 -0
- package/dist/prompts/anthropic.md +79 -0
- package/dist/prompts/codex.md +97 -0
- package/dist/prompts/default.md +77 -0
- package/dist/prompts/default.md.bak +77 -0
- package/dist/prompts/gpt-5.md +318 -0
- package/dist/prompts/lite.md +29 -0
- package/dist/prompts/simple-mentor.md +207 -0
- package/dist/prompts/simple.md +189 -0
- package/dist/providers/index.d.ts +5 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +8 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/openai-compatible/api.d.ts +17 -0
- package/dist/providers/openai-compatible/api.d.ts.map +1 -0
- package/dist/providers/openai-compatible/api.js +58 -0
- package/dist/providers/openai-compatible/api.js.map +1 -0
- package/dist/providers/openai-compatible/model.d.ts +17 -0
- package/dist/providers/openai-compatible/model.d.ts.map +1 -0
- package/dist/providers/openai-compatible/model.js +435 -0
- package/dist/providers/openai-compatible/model.js.map +1 -0
- package/dist/providers/openai-compatible/provider.d.ts +22 -0
- package/dist/providers/openai-compatible/provider.d.ts.map +1 -0
- package/dist/providers/openai-compatible/provider.js +43 -0
- package/dist/providers/openai-compatible/provider.js.map +1 -0
- package/dist/providers/openai-compatible/utils.d.ts +3 -0
- package/dist/providers/openai-compatible/utils.d.ts.map +1 -0
- package/dist/providers/openai-compatible/utils.js +11 -0
- package/dist/providers/openai-compatible/utils.js.map +1 -0
- package/dist/providers/openai-compatible.provider.d.ts +8 -0
- package/dist/providers/openai-compatible.provider.d.ts.map +1 -0
- package/dist/providers/openai-compatible.provider.js +71 -0
- package/dist/providers/openai-compatible.provider.js.map +1 -0
- package/dist/providers/openai.provider.d.ts +2 -0
- package/dist/providers/openai.provider.d.ts.map +1 -0
- package/dist/providers/openai.provider.js +36 -0
- package/dist/providers/openai.provider.js.map +1 -0
- package/dist/providers/openrouter/api.d.ts +39 -0
- package/dist/providers/openrouter/api.d.ts.map +1 -0
- package/dist/providers/openrouter/api.js +172 -0
- package/dist/providers/openrouter/api.js.map +1 -0
- package/dist/providers/openrouter/converters.d.ts +8 -0
- package/dist/providers/openrouter/converters.d.ts.map +1 -0
- package/dist/providers/openrouter/converters.js +382 -0
- package/dist/providers/openrouter/converters.js.map +1 -0
- package/dist/providers/openrouter/converters.test.d.ts +2 -0
- package/dist/providers/openrouter/converters.test.d.ts.map +1 -0
- package/dist/providers/openrouter/converters.test.js +158 -0
- package/dist/providers/openrouter/converters.test.js.map +1 -0
- package/dist/providers/openrouter/index.d.ts +4 -0
- package/dist/providers/openrouter/index.d.ts.map +1 -0
- package/dist/providers/openrouter/index.js +4 -0
- package/dist/providers/openrouter/index.js.map +1 -0
- package/dist/providers/openrouter/model.d.ts +14 -0
- package/dist/providers/openrouter/model.d.ts.map +1 -0
- package/dist/providers/openrouter/model.js +485 -0
- package/dist/providers/openrouter/model.js.map +1 -0
- package/dist/providers/openrouter/provider.d.ts +15 -0
- package/dist/providers/openrouter/provider.d.ts.map +1 -0
- package/dist/providers/openrouter/provider.js +21 -0
- package/dist/providers/openrouter/provider.js.map +1 -0
- package/dist/providers/openrouter/utils.d.ts +10 -0
- package/dist/providers/openrouter/utils.d.ts.map +1 -0
- package/dist/providers/openrouter/utils.js +27 -0
- package/dist/providers/openrouter/utils.js.map +1 -0
- package/dist/providers/openrouter.api.retry.test.d.ts +2 -0
- package/dist/providers/openrouter.api.retry.test.d.ts.map +1 -0
- package/dist/providers/openrouter.api.retry.test.js +148 -0
- package/dist/providers/openrouter.api.retry.test.js.map +1 -0
- package/dist/providers/openrouter.d.ts +2 -0
- package/dist/providers/openrouter.d.ts.map +1 -0
- package/dist/providers/openrouter.history.test.d.ts +2 -0
- package/dist/providers/openrouter.history.test.d.ts.map +1 -0
- package/dist/providers/openrouter.history.test.js +533 -0
- package/dist/providers/openrouter.history.test.js.map +1 -0
- package/dist/providers/openrouter.js +4 -0
- package/dist/providers/openrouter.js.map +1 -0
- package/dist/providers/openrouter.provider.createRunner.test.d.ts +2 -0
- package/dist/providers/openrouter.provider.createRunner.test.d.ts.map +1 -0
- package/dist/providers/openrouter.provider.createRunner.test.js +23 -0
- package/dist/providers/openrouter.provider.createRunner.test.js.map +1 -0
- package/dist/providers/openrouter.provider.d.ts +2 -0
- package/dist/providers/openrouter.provider.d.ts.map +1 -0
- package/dist/providers/openrouter.provider.js +56 -0
- package/dist/providers/openrouter.provider.js.map +1 -0
- package/dist/providers/openrouter.test.d.ts +2 -0
- package/dist/providers/openrouter.test.d.ts.map +1 -0
- package/dist/providers/openrouter.test.js +1382 -0
- package/dist/providers/openrouter.test.js.map +1 -0
- package/dist/providers/registry.d.ts +65 -0
- package/dist/providers/registry.d.ts.map +1 -0
- package/dist/providers/registry.js +44 -0
- package/dist/providers/registry.js.map +1 -0
- package/dist/providers/registry.test.d.ts +2 -0
- package/dist/providers/registry.test.d.ts.map +1 -0
- package/dist/providers/registry.test.js +76 -0
- package/dist/providers/registry.test.js.map +1 -0
- package/dist/providers/web-search/index.d.ts +8 -0
- package/dist/providers/web-search/index.d.ts.map +1 -0
- package/dist/providers/web-search/index.js +9 -0
- package/dist/providers/web-search/index.js.map +1 -0
- package/dist/providers/web-search/registry.d.ts +35 -0
- package/dist/providers/web-search/registry.d.ts.map +1 -0
- package/dist/providers/web-search/registry.js +56 -0
- package/dist/providers/web-search/registry.js.map +1 -0
- package/dist/providers/web-search/registry.test.d.ts +2 -0
- package/dist/providers/web-search/registry.test.d.ts.map +1 -0
- package/dist/providers/web-search/registry.test.js +105 -0
- package/dist/providers/web-search/registry.test.js.map +1 -0
- package/dist/providers/web-search/tavily.provider.d.ts +15 -0
- package/dist/providers/web-search/tavily.provider.d.ts.map +1 -0
- package/dist/providers/web-search/tavily.provider.js +69 -0
- package/dist/providers/web-search/tavily.provider.js.map +1 -0
- package/dist/providers/web-search/tavily.provider.test.d.ts +2 -0
- package/dist/providers/web-search/tavily.provider.test.d.ts.map +1 -0
- package/dist/providers/web-search/tavily.provider.test.js +67 -0
- package/dist/providers/web-search/tavily.provider.test.js.map +1 -0
- package/dist/providers/web-search/types.d.ts +55 -0
- package/dist/providers/web-search/types.d.ts.map +1 -0
- package/dist/providers/web-search/types.js +6 -0
- package/dist/providers/web-search/types.js.map +1 -0
- package/dist/safety-checker.js +57 -0
- package/dist/services/conversation-events.d.ts +76 -0
- package/dist/services/conversation-events.d.ts.map +1 -0
- package/dist/services/conversation-events.js +2 -0
- package/dist/services/conversation-events.js.map +1 -0
- package/dist/services/conversation-service.d.ts +31 -0
- package/dist/services/conversation-service.d.ts.map +1 -0
- package/dist/services/conversation-service.js +46 -0
- package/dist/services/conversation-service.js.map +1 -0
- package/dist/services/conversation-service.test.js +190 -0
- package/dist/services/conversation-session.d.ts +99 -0
- package/dist/services/conversation-session.d.ts.map +1 -0
- package/dist/services/conversation-session.js +978 -0
- package/dist/services/conversation-session.js.map +1 -0
- package/dist/services/conversation-store.d.ts +24 -0
- package/dist/services/conversation-store.d.ts.map +1 -0
- package/dist/services/conversation-store.js +216 -0
- package/dist/services/conversation-store.js.map +1 -0
- package/dist/services/conversation-store.test.d.ts +2 -0
- package/dist/services/conversation-store.test.d.ts.map +1 -0
- package/dist/services/conversation-store.test.js +167 -0
- package/dist/services/conversation-store.test.js.map +1 -0
- package/dist/services/execution-context.d.ts +10 -0
- package/dist/services/execution-context.d.ts.map +1 -0
- package/dist/services/execution-context.js +22 -0
- package/dist/services/execution-context.js.map +1 -0
- package/dist/services/execution-context.test.d.ts +2 -0
- package/dist/services/execution-context.test.d.ts.map +1 -0
- package/dist/services/execution-context.test.js +49 -0
- package/dist/services/execution-context.test.js.map +1 -0
- package/dist/services/file-service.d.ts +12 -0
- package/dist/services/file-service.d.ts.map +1 -0
- package/dist/services/file-service.js +90 -0
- package/dist/services/file-service.js.map +1 -0
- package/dist/services/history-service.d.ts +39 -0
- package/dist/services/history-service.d.ts.map +1 -0
- package/dist/services/history-service.js +152 -0
- package/dist/services/history-service.js.map +1 -0
- package/dist/services/logging-service.d.ts +75 -0
- package/dist/services/logging-service.d.ts.map +1 -0
- package/dist/services/logging-service.js +343 -0
- package/dist/services/logging-service.js.map +1 -0
- package/dist/services/model-service.d.ts +15 -0
- package/dist/services/model-service.d.ts.map +1 -0
- package/dist/services/model-service.js +46 -0
- package/dist/services/model-service.js.map +1 -0
- package/dist/services/model-service.test.d.ts +2 -0
- package/dist/services/model-service.test.d.ts.map +1 -0
- package/dist/services/model-service.test.js +128 -0
- package/dist/services/model-service.test.js.map +1 -0
- package/dist/services/service-interfaces.d.ts +33 -0
- package/dist/services/service-interfaces.d.ts.map +1 -0
- package/dist/services/service-interfaces.js +2 -0
- package/dist/services/service-interfaces.js.map +1 -0
- package/dist/services/settings-service.d.ts +316 -0
- package/dist/services/settings-service.d.ts.map +1 -0
- package/dist/services/settings-service.js +1128 -0
- package/dist/services/settings-service.js.map +1 -0
- package/dist/services/settings-service.mock.d.ts +20 -0
- package/dist/services/settings-service.mock.d.ts.map +1 -0
- package/dist/services/settings-service.mock.js +55 -0
- package/dist/services/settings-service.mock.js.map +1 -0
- package/dist/services/singleton-deprecation.test.d.ts +2 -0
- package/dist/services/singleton-deprecation.test.d.ts.map +1 -0
- package/dist/services/singleton-deprecation.test.js +59 -0
- package/dist/services/singleton-deprecation.test.js.map +1 -0
- package/dist/services/ssh-service.d.ts +32 -0
- package/dist/services/ssh-service.d.ts.map +1 -0
- package/dist/services/ssh-service.js +119 -0
- package/dist/services/ssh-service.js.map +1 -0
- package/dist/services/ssh-service.test.d.ts +2 -0
- package/dist/services/ssh-service.test.d.ts.map +1 -0
- package/dist/services/ssh-service.test.js +269 -0
- package/dist/services/ssh-service.test.js.map +1 -0
- package/dist/test-search-tool.d.ts +2 -0
- package/dist/test-search-tool.d.ts.map +1 -0
- package/dist/test-search-tool.js +36 -0
- package/dist/test-search-tool.js.map +1 -0
- package/dist/tools/apply-patch.d.ts +28 -0
- package/dist/tools/apply-patch.d.ts.map +1 -0
- package/dist/tools/apply-patch.js +399 -0
- package/dist/tools/apply-patch.js.map +1 -0
- package/dist/tools/apply-patch.test.d.ts +2 -0
- package/dist/tools/apply-patch.test.d.ts.map +1 -0
- package/dist/tools/apply-patch.test.js +155 -0
- package/dist/tools/apply-patch.test.js.map +1 -0
- package/dist/tools/ask-mentor.d.ts +11 -0
- package/dist/tools/ask-mentor.d.ts.map +1 -0
- package/dist/tools/ask-mentor.js +52 -0
- package/dist/tools/ask-mentor.js.map +1 -0
- package/dist/tools/ask-mentor.test.d.ts +2 -0
- package/dist/tools/ask-mentor.test.d.ts.map +1 -0
- package/dist/tools/ask-mentor.test.js +47 -0
- package/dist/tools/ask-mentor.test.js.map +1 -0
- package/dist/tools/bash.d.ts +10 -0
- package/dist/tools/bash.d.ts.map +1 -0
- package/dist/tools/bash.js +55 -0
- package/dist/tools/bash.js.map +1 -0
- package/dist/tools/find-files.d.ts +15 -0
- package/dist/tools/find-files.d.ts.map +1 -0
- package/dist/tools/find-files.js +179 -0
- package/dist/tools/find-files.js.map +1 -0
- package/dist/tools/find-files.test.d.ts +2 -0
- package/dist/tools/find-files.test.d.ts.map +1 -0
- package/dist/tools/find-files.test.js +131 -0
- package/dist/tools/find-files.test.js.map +1 -0
- package/dist/tools/format-helpers.d.ts +34 -0
- package/dist/tools/format-helpers.d.ts.map +1 -0
- package/dist/tools/format-helpers.js +131 -0
- package/dist/tools/format-helpers.js.map +1 -0
- package/dist/tools/grep.d.ts +16 -0
- package/dist/tools/grep.d.ts.map +1 -0
- package/dist/tools/grep.js +211 -0
- package/dist/tools/grep.js.map +1 -0
- package/dist/tools/read-file.d.ts +15 -0
- package/dist/tools/read-file.d.ts.map +1 -0
- package/dist/tools/read-file.js +114 -0
- package/dist/tools/read-file.js.map +1 -0
- package/dist/tools/read-file.test.d.ts +2 -0
- package/dist/tools/read-file.test.d.ts.map +1 -0
- package/dist/tools/read-file.test.js +122 -0
- package/dist/tools/read-file.test.js.map +1 -0
- package/dist/tools/search-replace.d.ts +19 -0
- package/dist/tools/search-replace.d.ts.map +1 -0
- package/dist/tools/search-replace.js +411 -0
- package/dist/tools/search-replace.js.map +1 -0
- package/dist/tools/search-replace.test.d.ts +2 -0
- package/dist/tools/search-replace.test.d.ts.map +1 -0
- package/dist/tools/search-replace.test.js +302 -0
- package/dist/tools/search-replace.test.js.map +1 -0
- package/dist/tools/search.d.ts +15 -0
- package/dist/tools/search.d.ts.map +1 -0
- package/dist/tools/search.js +143 -0
- package/dist/tools/search.js.map +1 -0
- package/dist/tools/shell.d.ts +19 -0
- package/dist/tools/shell.d.ts.map +1 -0
- package/dist/tools/shell.js +278 -0
- package/dist/tools/shell.js.map +1 -0
- package/dist/tools/tool-execution-context.d.ts +7 -0
- package/dist/tools/tool-execution-context.d.ts.map +1 -0
- package/dist/tools/tool-execution-context.js +7 -0
- package/dist/tools/tool-execution-context.js.map +1 -0
- package/dist/tools/types.d.ts +30 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +2 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/tools/utils.d.ts +12 -0
- package/dist/tools/utils.d.ts.map +1 -0
- package/dist/tools/utils.js +19 -0
- package/dist/tools/utils.js.map +1 -0
- package/dist/tools/web-search.d.ts +29 -0
- package/dist/tools/web-search.d.ts.map +1 -0
- package/dist/tools/web-search.js +106 -0
- package/dist/tools/web-search.js.map +1 -0
- package/dist/tools/web-search.test.d.ts +2 -0
- package/dist/tools/web-search.test.d.ts.map +1 -0
- package/dist/tools/web-search.test.js +176 -0
- package/dist/tools/web-search.test.js.map +1 -0
- package/dist/utils/command-logger.d.ts +11 -0
- package/dist/utils/command-logger.d.ts.map +1 -0
- package/dist/utils/command-logger.js +34 -0
- package/dist/utils/command-logger.js.map +1 -0
- package/dist/utils/command-safety/constants.d.ts +21 -0
- package/dist/utils/command-safety/constants.d.ts.map +1 -0
- package/dist/utils/command-safety/constants.js +245 -0
- package/dist/utils/command-safety/constants.js.map +1 -0
- package/dist/utils/command-safety/find-helpers.d.ts +15 -0
- package/dist/utils/command-safety/find-helpers.d.ts.map +1 -0
- package/dist/utils/command-safety/find-helpers.js +218 -0
- package/dist/utils/command-safety/find-helpers.js.map +1 -0
- package/dist/utils/command-safety/handlers/find-handler.d.ts +6 -0
- package/dist/utils/command-safety/handlers/find-handler.d.ts.map +1 -0
- package/dist/utils/command-safety/handlers/find-handler.js +113 -0
- package/dist/utils/command-safety/handlers/find-handler.js.map +1 -0
- package/dist/utils/command-safety/handlers/git-handler.d.ts +6 -0
- package/dist/utils/command-safety/handlers/git-handler.d.ts.map +1 -0
- package/dist/utils/command-safety/handlers/git-handler.js +68 -0
- package/dist/utils/command-safety/handlers/git-handler.js.map +1 -0
- package/dist/utils/command-safety/handlers/index.d.ts +13 -0
- package/dist/utils/command-safety/handlers/index.d.ts.map +1 -0
- package/dist/utils/command-safety/handlers/index.js +20 -0
- package/dist/utils/command-safety/handlers/index.js.map +1 -0
- package/dist/utils/command-safety/handlers/sed-handler.d.ts +6 -0
- package/dist/utils/command-safety/handlers/sed-handler.d.ts.map +1 -0
- package/dist/utils/command-safety/handlers/sed-handler.js +94 -0
- package/dist/utils/command-safety/handlers/sed-handler.js.map +1 -0
- package/dist/utils/command-safety/handlers/types.d.ts +36 -0
- package/dist/utils/command-safety/handlers/types.d.ts.map +1 -0
- package/dist/utils/command-safety/handlers/types.js +2 -0
- package/dist/utils/command-safety/handlers/types.js.map +1 -0
- package/dist/utils/command-safety/index.d.ts +14 -0
- package/dist/utils/command-safety/index.d.ts.map +1 -0
- package/dist/utils/command-safety/index.js +183 -0
- package/dist/utils/command-safety/index.js.map +1 -0
- package/dist/utils/command-safety/path-analysis.d.ts +4 -0
- package/dist/utils/command-safety/path-analysis.d.ts.map +1 -0
- package/dist/utils/command-safety/path-analysis.js +153 -0
- package/dist/utils/command-safety/path-analysis.js.map +1 -0
- package/dist/utils/command-safety/utils.d.ts +2 -0
- package/dist/utils/command-safety/utils.d.ts.map +1 -0
- package/dist/utils/command-safety/utils.js +22 -0
- package/dist/utils/command-safety/utils.js.map +1 -0
- package/dist/utils/command-safety.d.ts +21 -0
- package/dist/utils/command-safety.d.ts.map +1 -0
- package/dist/utils/command-safety.find.test.d.ts +2 -0
- package/dist/utils/command-safety.find.test.d.ts.map +1 -0
- package/dist/utils/command-safety.find.test.js +342 -0
- package/dist/utils/command-safety.find.test.js.map +1 -0
- package/dist/utils/command-safety.js +702 -0
- package/dist/utils/command-safety.js.map +1 -0
- package/dist/utils/command-safety.path.test.d.ts +2 -0
- package/dist/utils/command-safety.path.test.d.ts.map +1 -0
- package/dist/utils/command-safety.path.test.js +360 -0
- package/dist/utils/command-safety.path.test.js.map +1 -0
- package/dist/utils/diff.d.ts +2 -0
- package/dist/utils/diff.d.ts.map +1 -0
- package/dist/utils/diff.js +44 -0
- package/dist/utils/diff.js.map +1 -0
- package/dist/utils/diff.test.d.ts +2 -0
- package/dist/utils/diff.test.d.ts.map +1 -0
- package/dist/utils/diff.test.js +85 -0
- package/dist/utils/diff.test.js.map +1 -0
- package/dist/utils/error-helpers.d.ts +6 -0
- package/dist/utils/error-helpers.d.ts.map +1 -0
- package/dist/utils/error-helpers.js +46 -0
- package/dist/utils/error-helpers.js.map +1 -0
- package/dist/utils/error-helpers.test.d.ts +2 -0
- package/dist/utils/error-helpers.test.d.ts.map +1 -0
- package/dist/utils/error-helpers.test.js +152 -0
- package/dist/utils/error-helpers.test.js.map +1 -0
- package/dist/utils/execute-shell.d.ts +15 -0
- package/dist/utils/execute-shell.d.ts.map +1 -0
- package/dist/utils/execute-shell.js +34 -0
- package/dist/utils/execute-shell.js.map +1 -0
- package/dist/utils/execute-shell.test.d.ts +2 -0
- package/dist/utils/execute-shell.test.d.ts.map +1 -0
- package/dist/utils/execute-shell.test.js +20 -0
- package/dist/utils/execute-shell.test.js.map +1 -0
- package/dist/utils/extract-command-messages.d.ts +5 -0
- package/dist/utils/extract-command-messages.d.ts.map +1 -0
- package/dist/utils/extract-command-messages.js +140 -0
- package/dist/utils/extract-command-messages.js.map +1 -0
- package/dist/utils/extract-command-messages.repro.test.d.ts +2 -0
- package/dist/utils/extract-command-messages.repro.test.d.ts.map +1 -0
- package/dist/utils/extract-command-messages.repro.test.js +31 -0
- package/dist/utils/extract-command-messages.repro.test.js.map +1 -0
- package/dist/utils/extract-command-messages.test.js +57 -0
- package/dist/utils/message-buffer.d.ts +2 -0
- package/dist/utils/message-buffer.d.ts.map +1 -0
- package/dist/utils/message-buffer.js +15 -0
- package/dist/utils/message-buffer.js.map +1 -0
- package/dist/utils/message-buffer.test.d.ts +2 -0
- package/dist/utils/message-buffer.test.d.ts.map +1 -0
- package/dist/utils/message-buffer.test.js +17 -0
- package/dist/utils/message-buffer.test.js.map +1 -0
- package/dist/utils/output-trim.d.ts +31 -0
- package/dist/utils/output-trim.d.ts.map +1 -0
- package/dist/utils/output-trim.js +71 -0
- package/dist/utils/output-trim.js.map +1 -0
- package/dist/utils/provider-credentials.d.ts +10 -0
- package/dist/utils/provider-credentials.d.ts.map +1 -0
- package/dist/utils/provider-credentials.js +22 -0
- package/dist/utils/provider-credentials.js.map +1 -0
- package/dist/utils/settings-command.d.ts +13 -0
- package/dist/utils/settings-command.d.ts.map +1 -0
- package/dist/utils/settings-command.js +173 -0
- package/dist/utils/settings-command.js.map +1 -0
- package/dist/utils/ssh-config-parser.d.ts +21 -0
- package/dist/utils/ssh-config-parser.d.ts.map +1 -0
- package/dist/utils/ssh-config-parser.js +89 -0
- package/dist/utils/ssh-config-parser.js.map +1 -0
- package/dist/utils/ssh-config-parser.test.d.ts +2 -0
- package/dist/utils/ssh-config-parser.test.d.ts.map +1 -0
- package/dist/utils/ssh-config-parser.test.js +153 -0
- package/dist/utils/ssh-config-parser.test.js.map +1 -0
- package/dist/utils/streaming-updater.d.ts +7 -0
- package/dist/utils/streaming-updater.d.ts.map +1 -0
- package/dist/utils/streaming-updater.js +41 -0
- package/dist/utils/streaming-updater.js.map +1 -0
- package/dist/utils/throttle.d.ts +7 -0
- package/dist/utils/throttle.d.ts.map +1 -0
- package/dist/utils/throttle.js +49 -0
- package/dist/utils/throttle.js.map +1 -0
- package/package.json +108 -0
- package/readme.md +428 -0
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
import { extractWordText } from './utils.js';
|
|
2
|
+
/**
|
|
3
|
+
* Check if a find command has dangerous execution flags (-exec, -execdir, -ok, -okdir, -delete)
|
|
4
|
+
*/
|
|
5
|
+
export function hasFindDangerousExecution(args) {
|
|
6
|
+
for (let i = 0; i < args.length; i++) {
|
|
7
|
+
const argText = extractWordText(args[i]);
|
|
8
|
+
if (!argText)
|
|
9
|
+
continue;
|
|
10
|
+
// Check for -delete flag
|
|
11
|
+
if (argText === '-delete') {
|
|
12
|
+
return { dangerous: true, reason: 'find -delete (destructive)' };
|
|
13
|
+
}
|
|
14
|
+
// Check for execution flags
|
|
15
|
+
const execFlags = ['-exec', '-execdir', '-ok', '-okdir'];
|
|
16
|
+
if (!execFlags.includes(argText))
|
|
17
|
+
continue;
|
|
18
|
+
// Found an exec flag - analyze the command it executes
|
|
19
|
+
// Find the terminator (; or +)
|
|
20
|
+
let terminatorIndex = -1;
|
|
21
|
+
for (let j = i + 1; j < args.length; j++) {
|
|
22
|
+
const term = extractWordText(args[j]);
|
|
23
|
+
if (term === ';' ||
|
|
24
|
+
term === '+' ||
|
|
25
|
+
term === '\\;' ||
|
|
26
|
+
term === '\\+') {
|
|
27
|
+
terminatorIndex = j;
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (terminatorIndex === -1) {
|
|
32
|
+
// Malformed -exec (no terminator)
|
|
33
|
+
return {
|
|
34
|
+
dangerous: true,
|
|
35
|
+
reason: `find ${argText} without terminator`,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
// Extract the command between exec flag and terminator
|
|
39
|
+
const execArgs = args.slice(i + 1, terminatorIndex);
|
|
40
|
+
// Check for redirects (which indicate shell operations)
|
|
41
|
+
const hasRedirect = execArgs.some((a) => a?.type === 'Redirect');
|
|
42
|
+
if (hasRedirect) {
|
|
43
|
+
return {
|
|
44
|
+
dangerous: true,
|
|
45
|
+
reason: `find ${argText} with shell redirection`,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
const execCommand = execArgs
|
|
49
|
+
.map(a => extractWordText(a))
|
|
50
|
+
.filter(Boolean);
|
|
51
|
+
if (execCommand.length === 0) {
|
|
52
|
+
return {
|
|
53
|
+
dangerous: true,
|
|
54
|
+
reason: `find ${argText} with empty command`,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const cmdName = execCommand[0];
|
|
58
|
+
if (!cmdName) {
|
|
59
|
+
return {
|
|
60
|
+
dangerous: true,
|
|
61
|
+
reason: `find ${argText} with undefined command`,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
// Check if {} is the command itself (executing found files)
|
|
65
|
+
if (cmdName === '{}') {
|
|
66
|
+
return {
|
|
67
|
+
dangerous: true,
|
|
68
|
+
reason: `find ${argText} {} (executes found files directly)`,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
// Check for destructive commands
|
|
72
|
+
const destructiveCmds = [
|
|
73
|
+
'rm',
|
|
74
|
+
'shred',
|
|
75
|
+
'chmod',
|
|
76
|
+
'chown',
|
|
77
|
+
'mv',
|
|
78
|
+
'dd',
|
|
79
|
+
'mkfs',
|
|
80
|
+
'truncate',
|
|
81
|
+
'tee',
|
|
82
|
+
'cp',
|
|
83
|
+
'ln',
|
|
84
|
+
'install',
|
|
85
|
+
'rsync',
|
|
86
|
+
];
|
|
87
|
+
if (destructiveCmds.includes(cmdName)) {
|
|
88
|
+
return {
|
|
89
|
+
dangerous: true,
|
|
90
|
+
reason: `find ${argText} ${cmdName} (destructive)`,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
// Check for dangerous interpreters and meta-executors
|
|
94
|
+
// These can all invoke arbitrary commands or scripts
|
|
95
|
+
const dangerousInterpreters = [
|
|
96
|
+
// Shells
|
|
97
|
+
'sh',
|
|
98
|
+
'bash',
|
|
99
|
+
'zsh',
|
|
100
|
+
'ksh',
|
|
101
|
+
'dash',
|
|
102
|
+
'fish',
|
|
103
|
+
'tcsh',
|
|
104
|
+
'csh',
|
|
105
|
+
// Script interpreters
|
|
106
|
+
'perl',
|
|
107
|
+
'python',
|
|
108
|
+
'python2',
|
|
109
|
+
'python3',
|
|
110
|
+
'ruby',
|
|
111
|
+
'node',
|
|
112
|
+
'nodejs',
|
|
113
|
+
'php',
|
|
114
|
+
'lua',
|
|
115
|
+
// Meta-executors that can run commands
|
|
116
|
+
'env',
|
|
117
|
+
'xargs',
|
|
118
|
+
'parallel',
|
|
119
|
+
'nohup',
|
|
120
|
+
'nice',
|
|
121
|
+
'ionice',
|
|
122
|
+
'timeout',
|
|
123
|
+
'stdbuf',
|
|
124
|
+
'script',
|
|
125
|
+
'expect',
|
|
126
|
+
// Text processors that can execute
|
|
127
|
+
'awk',
|
|
128
|
+
'gawk',
|
|
129
|
+
'mawk',
|
|
130
|
+
'nawk',
|
|
131
|
+
'sed',
|
|
132
|
+
'ed',
|
|
133
|
+
// Editors that can run shell commands
|
|
134
|
+
'vim',
|
|
135
|
+
'nvim',
|
|
136
|
+
'emacs',
|
|
137
|
+
];
|
|
138
|
+
// Handle both bare names and full paths like /usr/bin/python
|
|
139
|
+
const isDangerousInterpreter = dangerousInterpreters.some(interp => cmdName === interp || cmdName.endsWith(`/${interp}`));
|
|
140
|
+
if (isDangerousInterpreter) {
|
|
141
|
+
return {
|
|
142
|
+
dangerous: true,
|
|
143
|
+
reason: `find ${argText} ${cmdName} (can execute commands)`,
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
// Check for shell metacharacters in command
|
|
147
|
+
const fullExecCmd = execCommand.join(' ');
|
|
148
|
+
if (/[|&;$`<>]/.test(fullExecCmd)) {
|
|
149
|
+
return {
|
|
150
|
+
dangerous: true,
|
|
151
|
+
reason: `find ${argText} with shell metacharacters`,
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
return { dangerous: false };
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Check for suspicious find flags that warrant YELLOW classification
|
|
159
|
+
*/
|
|
160
|
+
export function hasFindSuspiciousFlags(args) {
|
|
161
|
+
for (const arg of args) {
|
|
162
|
+
const argText = extractWordText(arg);
|
|
163
|
+
if (!argText)
|
|
164
|
+
continue;
|
|
165
|
+
// File output flags
|
|
166
|
+
if (['-fprint', '-fprint0', '-fprintf', '-fls'].some(flag => argText.startsWith(flag))) {
|
|
167
|
+
return {
|
|
168
|
+
suspicious: true,
|
|
169
|
+
reason: `find ${argText} (file output)`,
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
// Symlink following
|
|
173
|
+
if (['-L', '-follow', '-H'].includes(argText)) {
|
|
174
|
+
return {
|
|
175
|
+
suspicious: true,
|
|
176
|
+
reason: `find ${argText} (symlink following)`,
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
// SUID/SGID permission searches
|
|
180
|
+
if (argText === '-perm') {
|
|
181
|
+
// Check the next argument for dangerous permission patterns
|
|
182
|
+
const nextIdx = args.indexOf(arg) + 1;
|
|
183
|
+
if (nextIdx < args.length) {
|
|
184
|
+
const permValue = extractWordText(args[nextIdx]);
|
|
185
|
+
if (permValue) {
|
|
186
|
+
// Numeric SUID/SGID patterns (e.g., -4000, /6000)
|
|
187
|
+
const hasNumericSuid = /[-\/]?[2467]000/.test(permValue);
|
|
188
|
+
// Symbolic SUID/SGID patterns (e.g., -u+s, /g+s, +s)
|
|
189
|
+
const hasSymbolicSuid = /[ug]?\+s/.test(permValue);
|
|
190
|
+
if (hasNumericSuid || hasSymbolicSuid) {
|
|
191
|
+
return {
|
|
192
|
+
suspicious: true,
|
|
193
|
+
reason: `find -perm ${permValue} (SUID/SGID search)`,
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
// Inode-based searches (can bypass path restrictions)
|
|
200
|
+
if (argText === '-inum') {
|
|
201
|
+
return {
|
|
202
|
+
suspicious: true,
|
|
203
|
+
reason: 'find -inum (inode-based access bypasses path checks)',
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
// Read-only exec (still suspicious, requires approval)
|
|
207
|
+
if (['-exec', '-execdir', '-ok', '-okdir'].includes(argText)) {
|
|
208
|
+
// If we reach here, hasFindDangerousExecution already passed (not RED)
|
|
209
|
+
// but any -exec usage should still be YELLOW
|
|
210
|
+
return {
|
|
211
|
+
suspicious: true,
|
|
212
|
+
reason: `find ${argText} (command execution)`,
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
return { suspicious: false };
|
|
217
|
+
}
|
|
218
|
+
//# sourceMappingURL=find-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-helpers.js","sourceRoot":"","sources":["../../../source/utils/command-safety/find-helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-handler.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/find-handler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,cAAc,EAGjB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,eAAO,MAAM,WAAW,EAAE,cA+HzB,CAAC"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { SafetyStatus } from '../constants.js';
|
|
2
|
+
/**
|
|
3
|
+
* Handler for find command safety analysis
|
|
4
|
+
*/
|
|
5
|
+
export const findHandler = {
|
|
6
|
+
handle(node, helpers) {
|
|
7
|
+
const { extractWordText, analyzePathRisk, hasFindDangerousExecution, hasFindSuspiciousFlags, } = helpers;
|
|
8
|
+
const reasons = [];
|
|
9
|
+
let status = SafetyStatus.GREEN;
|
|
10
|
+
if (!node.suffix) {
|
|
11
|
+
return { status, reasons };
|
|
12
|
+
}
|
|
13
|
+
// Check for dangerous find operations first (RED)
|
|
14
|
+
const dangerResult = hasFindDangerousExecution(node.suffix);
|
|
15
|
+
if (dangerResult.dangerous) {
|
|
16
|
+
return {
|
|
17
|
+
status: SafetyStatus.RED,
|
|
18
|
+
reasons: [dangerResult.reason || 'find with dangerous flags'],
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
// Check for suspicious find flags (YELLOW)
|
|
22
|
+
const suspiciousResult = hasFindSuspiciousFlags(node.suffix);
|
|
23
|
+
if (suspiciousResult.suspicious) {
|
|
24
|
+
status = SafetyStatus.YELLOW;
|
|
25
|
+
reasons.push(suspiciousResult.reason || 'find with suspicious flags');
|
|
26
|
+
}
|
|
27
|
+
// Check path arguments for find
|
|
28
|
+
// Track if previous arg was a pattern flag like -name, -regex
|
|
29
|
+
let previousArgWasPatternFlag = false;
|
|
30
|
+
for (const arg of node.suffix) {
|
|
31
|
+
if (arg?.type === 'Redirect')
|
|
32
|
+
continue;
|
|
33
|
+
const argText = extractWordText(arg);
|
|
34
|
+
if (!argText)
|
|
35
|
+
continue;
|
|
36
|
+
// Track pattern flags
|
|
37
|
+
if ([
|
|
38
|
+
'-name',
|
|
39
|
+
'-iname',
|
|
40
|
+
'-path',
|
|
41
|
+
'-ipath',
|
|
42
|
+
'-regex',
|
|
43
|
+
'-iregex',
|
|
44
|
+
].includes(argText)) {
|
|
45
|
+
previousArgWasPatternFlag = true;
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
// Skip flags
|
|
49
|
+
if (argText.startsWith('-')) {
|
|
50
|
+
previousArgWasPatternFlag = false;
|
|
51
|
+
continue;
|
|
52
|
+
}
|
|
53
|
+
// Skip pattern arguments (the values after -name, -regex, etc.)
|
|
54
|
+
if (previousArgWasPatternFlag) {
|
|
55
|
+
previousArgWasPatternFlag = false;
|
|
56
|
+
continue;
|
|
57
|
+
}
|
|
58
|
+
// Skip glob patterns (contain wildcards)
|
|
59
|
+
if (/[*?[\]]/.test(argText))
|
|
60
|
+
continue;
|
|
61
|
+
// Skip safe relative paths (. and ./)
|
|
62
|
+
if (argText === '.' || argText === './')
|
|
63
|
+
continue;
|
|
64
|
+
// Skip patterns with backslashes (regex patterns)
|
|
65
|
+
if (argText.includes('\\'))
|
|
66
|
+
continue;
|
|
67
|
+
// Root traversal detection (DoS + information disclosure)
|
|
68
|
+
if (argText === '/' || argText === '//') {
|
|
69
|
+
status = SafetyStatus.YELLOW;
|
|
70
|
+
reasons.push('find / (root traversal - resource intensive)');
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
// For find, analyzing paths is more lenient:
|
|
74
|
+
// - System paths like /etc are YELLOW (not RED)
|
|
75
|
+
// - Home directories and dotfiles are still RED
|
|
76
|
+
const pathStatus = analyzePathRisk(argText);
|
|
77
|
+
if (pathStatus === SafetyStatus.RED) {
|
|
78
|
+
// Keep RED for home directories, dotfiles, and traversal
|
|
79
|
+
// Downgrade system paths to YELLOW
|
|
80
|
+
const homeRelatedPatterns = [
|
|
81
|
+
/^~/, // Tilde
|
|
82
|
+
/^\$/, // Variables like $HOME, $USER
|
|
83
|
+
/^\/home\//, // Linux home
|
|
84
|
+
/^\/Users\//, // macOS home
|
|
85
|
+
/^\/root/, // Root's home
|
|
86
|
+
/\/\.ssh/, // SSH keys
|
|
87
|
+
/\/\.env/, // Environment files
|
|
88
|
+
/\/\.git/, // Git config
|
|
89
|
+
/\/\.aws/, // AWS credentials
|
|
90
|
+
/\/\.kube/, // Kubernetes config
|
|
91
|
+
/\/\.gnupg/, // GPG keys
|
|
92
|
+
/\.\./, // Directory traversal
|
|
93
|
+
];
|
|
94
|
+
const isHomeRelated = homeRelatedPatterns.some(pattern => pattern.test(argText));
|
|
95
|
+
if (isHomeRelated) {
|
|
96
|
+
status = SafetyStatus.RED;
|
|
97
|
+
reasons.push(`find dangerous path: ${argText}`);
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
// System paths like /etc get downgraded to YELLOW
|
|
101
|
+
status = SafetyStatus.YELLOW;
|
|
102
|
+
reasons.push(`find system path: ${argText}`);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
else if (pathStatus === SafetyStatus.YELLOW) {
|
|
106
|
+
status = pathStatus;
|
|
107
|
+
reasons.push(`find path argument ${argText}`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return { status, reasons };
|
|
111
|
+
},
|
|
112
|
+
};
|
|
113
|
+
//# sourceMappingURL=find-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-handler.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/find-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-handler.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/git-handler.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACR,cAAc,EAGjB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,cAsExB,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { SafetyStatus, SAFE_GIT_COMMANDS, DANGEROUS_GIT_COMMANDS, } from '../constants.js';
|
|
2
|
+
/**
|
|
3
|
+
* Handler for git command safety analysis
|
|
4
|
+
*/
|
|
5
|
+
export const gitHandler = {
|
|
6
|
+
handle(node, helpers) {
|
|
7
|
+
const { extractWordText } = helpers;
|
|
8
|
+
const reasons = [];
|
|
9
|
+
let status = SafetyStatus.GREEN;
|
|
10
|
+
// Extract the git subcommand (first non-flag argument)
|
|
11
|
+
let gitSubcommand;
|
|
12
|
+
if (node.suffix) {
|
|
13
|
+
for (const arg of node.suffix) {
|
|
14
|
+
const argText = extractWordText(arg);
|
|
15
|
+
if (argText && !argText.startsWith('-')) {
|
|
16
|
+
gitSubcommand = argText;
|
|
17
|
+
break;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
if (!gitSubcommand) {
|
|
22
|
+
// No subcommand found (e.g., just "git" or "git --version")
|
|
23
|
+
return {
|
|
24
|
+
status: SafetyStatus.YELLOW,
|
|
25
|
+
reasons: ['git without subcommand'],
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
// Check if it's a known dangerous command
|
|
29
|
+
if (DANGEROUS_GIT_COMMANDS.has(gitSubcommand)) {
|
|
30
|
+
return {
|
|
31
|
+
status: SafetyStatus.YELLOW,
|
|
32
|
+
reasons: [`git ${gitSubcommand} (write operation)`],
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
// Check if it's a known safe command
|
|
36
|
+
if (SAFE_GIT_COMMANDS.has(gitSubcommand)) {
|
|
37
|
+
// Check for dangerous flags that might make it unsafe
|
|
38
|
+
const hasDangerousFlags = node.suffix.some((arg) => {
|
|
39
|
+
const argText = extractWordText(arg);
|
|
40
|
+
if (!argText)
|
|
41
|
+
return false;
|
|
42
|
+
// Flags that might modify repository state
|
|
43
|
+
return (argText.startsWith('--force') ||
|
|
44
|
+
argText.startsWith('-f') ||
|
|
45
|
+
argText.startsWith('--hard') ||
|
|
46
|
+
argText.startsWith('--delete') ||
|
|
47
|
+
argText.startsWith('-d') ||
|
|
48
|
+
argText.startsWith('-D'));
|
|
49
|
+
});
|
|
50
|
+
if (hasDangerousFlags) {
|
|
51
|
+
return {
|
|
52
|
+
status: SafetyStatus.YELLOW,
|
|
53
|
+
reasons: [
|
|
54
|
+
`git ${gitSubcommand} with potentially dangerous flags`,
|
|
55
|
+
],
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
// Otherwise stays GREEN - safe read-only git command
|
|
59
|
+
return { status, reasons };
|
|
60
|
+
}
|
|
61
|
+
// Unknown git subcommand
|
|
62
|
+
return {
|
|
63
|
+
status: SafetyStatus.YELLOW,
|
|
64
|
+
reasons: [`git ${gitSubcommand} (unknown subcommand)`],
|
|
65
|
+
};
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
//# sourceMappingURL=git-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-handler.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/git-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,iBAAiB,EACjB,sBAAsB,GACzB,MAAM,iBAAiB,CAAC;AAOzB;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAmB;IACtC,MAAM,CAAC,IAAS,EAAE,OAA8B;QAC5C,MAAM,EAAC,eAAe,EAAC,GAAG,OAAO,CAAC;QAClC,MAAM,OAAO,GAAa,EAAE,CAAC;QAC7B,IAAI,MAAM,GAAiB,YAAY,CAAC,KAAK,CAAC;QAE9C,uDAAuD;QACvD,IAAI,aAAiC,CAAC;QACtC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAC5B,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;oBACtC,aAAa,GAAG,OAAO,CAAC;oBACxB,MAAM;gBACV,CAAC;YACL,CAAC;QACL,CAAC;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,4DAA4D;YAC5D,OAAO;gBACH,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE,CAAC,wBAAwB,CAAC;aACtC,CAAC;QACN,CAAC;QAED,0CAA0C;QAC1C,IAAI,sBAAsB,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;YAC5C,OAAO;gBACH,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE,CAAC,OAAO,aAAa,oBAAoB,CAAC;aACtD,CAAC;QACN,CAAC;QAED,qCAAqC;QACrC,IAAI,iBAAiB,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;YACvC,sDAAsD;YACtD,MAAM,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACpD,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,CAAC,OAAO;oBAAE,OAAO,KAAK,CAAC;gBAE3B,2CAA2C;gBAC3C,OAAO,CACH,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC;oBAC7B,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;oBACxB,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC;oBAC5B,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC;oBAC9B,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;oBACxB,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAC3B,CAAC;YACN,CAAC,CAAC,CAAC;YAEH,IAAI,iBAAiB,EAAE,CAAC;gBACpB,OAAO;oBACH,MAAM,EAAE,YAAY,CAAC,MAAM;oBAC3B,OAAO,EAAE;wBACL,OAAO,aAAa,mCAAmC;qBAC1D;iBACJ,CAAC;YACN,CAAC;YACD,qDAAqD;YACrD,OAAO,EAAC,MAAM,EAAE,OAAO,EAAC,CAAC;QAC7B,CAAC;QAED,yBAAyB;QACzB,OAAO;YACH,MAAM,EAAE,YAAY,CAAC,MAAM;YAC3B,OAAO,EAAE,CAAC,OAAO,aAAa,uBAAuB,CAAC;SACzD,CAAC;IACN,CAAC;CACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { CommandHandler } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Registry of command-specific handlers
|
|
4
|
+
*/
|
|
5
|
+
export declare const commandHandlers: Map<string, CommandHandler>;
|
|
6
|
+
/**
|
|
7
|
+
* Get a handler for a specific command
|
|
8
|
+
* @param commandName The command name
|
|
9
|
+
* @returns The handler if one exists, undefined otherwise
|
|
10
|
+
*/
|
|
11
|
+
export declare function getCommandHandler(commandName: string): CommandHandler | undefined;
|
|
12
|
+
export type { CommandHandler, CommandHandlerHelpers, CommandHandlerResult, } from './types.js';
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,cAAc,EAAC,MAAM,YAAY,CAAC;AAK/C;;GAEG;AACH,eAAO,MAAM,eAAe,6BAI1B,CAAC;AAEH;;;;GAIG;AACH,wBAAgB,iBAAiB,CAC7B,WAAW,EAAE,MAAM,GACpB,cAAc,GAAG,SAAS,CAE5B;AAGD,YAAY,EACR,cAAc,EACd,qBAAqB,EACrB,oBAAoB,GACvB,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { gitHandler } from './git-handler.js';
|
|
2
|
+
import { findHandler } from './find-handler.js';
|
|
3
|
+
import { sedHandler } from './sed-handler.js';
|
|
4
|
+
/**
|
|
5
|
+
* Registry of command-specific handlers
|
|
6
|
+
*/
|
|
7
|
+
export const commandHandlers = new Map([
|
|
8
|
+
['git', gitHandler],
|
|
9
|
+
['find', findHandler],
|
|
10
|
+
['sed', sedHandler],
|
|
11
|
+
]);
|
|
12
|
+
/**
|
|
13
|
+
* Get a handler for a specific command
|
|
14
|
+
* @param commandName The command name
|
|
15
|
+
* @returns The handler if one exists, undefined otherwise
|
|
16
|
+
*/
|
|
17
|
+
export function getCommandHandler(commandName) {
|
|
18
|
+
return commandHandlers.get(commandName);
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAC,WAAW,EAAC,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAE5C;;GAEG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,GAAG,CAAyB;IAC3D,CAAC,KAAK,EAAE,UAAU,CAAC;IACnB,CAAC,MAAM,EAAE,WAAW,CAAC;IACrB,CAAC,KAAK,EAAE,UAAU,CAAC;CACtB,CAAC,CAAC;AAEH;;;;GAIG;AACH,MAAM,UAAU,iBAAiB,CAC7B,WAAmB;IAEnB,OAAO,eAAe,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;AAC5C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sed-handler.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/sed-handler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,cAAc,EAGjB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,cAqGxB,CAAC"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { SafetyStatus } from '../constants.js';
|
|
2
|
+
/**
|
|
3
|
+
* Handler for sed command safety analysis
|
|
4
|
+
*/
|
|
5
|
+
export const sedHandler = {
|
|
6
|
+
handle(node, helpers) {
|
|
7
|
+
const { extractWordText, analyzePathRisk } = helpers;
|
|
8
|
+
const reasons = [];
|
|
9
|
+
let status = SafetyStatus.GREEN;
|
|
10
|
+
if (!node.suffix) {
|
|
11
|
+
return { status, reasons };
|
|
12
|
+
}
|
|
13
|
+
let hasOutputRedirect = false;
|
|
14
|
+
let hasInPlaceEdit = false;
|
|
15
|
+
// First pass: detect dangerous sed patterns
|
|
16
|
+
for (const arg of node.suffix) {
|
|
17
|
+
if (arg?.type === 'Redirect') {
|
|
18
|
+
// Check if it's an output redirect (>, >>)
|
|
19
|
+
const op = arg.op?.text || arg.op;
|
|
20
|
+
if (op === '>' || op === '>>') {
|
|
21
|
+
hasOutputRedirect = true;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
const argText = extractWordText(arg);
|
|
25
|
+
if (argText && argText.startsWith('-')) {
|
|
26
|
+
if (argText.startsWith('-i')) {
|
|
27
|
+
hasInPlaceEdit = true;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
// Second pass: classify arguments
|
|
32
|
+
for (const arg of node.suffix) {
|
|
33
|
+
// Redirects: analyze path risk. For `sed`, only mark output redirects as YELLOW
|
|
34
|
+
if (arg?.type === 'Redirect') {
|
|
35
|
+
const fileText = extractWordText(arg.file ?? arg);
|
|
36
|
+
const op = arg.op?.text || arg.op;
|
|
37
|
+
if (op === '>' || op === '>>') {
|
|
38
|
+
status = SafetyStatus.YELLOW;
|
|
39
|
+
reasons.push(`sed with output redirection to ${fileText ?? '<unknown>'}`);
|
|
40
|
+
}
|
|
41
|
+
const pathStatus = analyzePathRisk(fileText);
|
|
42
|
+
if (pathStatus !== SafetyStatus.GREEN) {
|
|
43
|
+
status = pathStatus;
|
|
44
|
+
reasons.push(`redirect to ${fileText ?? '<unknown>'}`);
|
|
45
|
+
}
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
const argText = extractWordText(arg);
|
|
49
|
+
// Flags are normally ignored, but for `sed` the -i flag is dangerous
|
|
50
|
+
// because it performs in-place edits. Detect -i and variants (e.g. -i, -i.bak, -i'')
|
|
51
|
+
if (argText && argText.startsWith('-')) {
|
|
52
|
+
if (argText.startsWith('-i')) {
|
|
53
|
+
return {
|
|
54
|
+
status: SafetyStatus.RED,
|
|
55
|
+
reasons: [`sed in-place edit detected: ${argText}`],
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
continue; // other flags ignored
|
|
59
|
+
}
|
|
60
|
+
const pathStatus = analyzePathRisk(argText);
|
|
61
|
+
// For `sed`, file arguments are only risky if combined with dangerous operations
|
|
62
|
+
if (argText) {
|
|
63
|
+
// If there's an in-place edit or output redirect, path risk matters
|
|
64
|
+
// Otherwise, reading files with sed is safe (GREEN)
|
|
65
|
+
if (hasInPlaceEdit || hasOutputRedirect) {
|
|
66
|
+
if (pathStatus === SafetyStatus.RED) {
|
|
67
|
+
status = pathStatus;
|
|
68
|
+
reasons.push(`sed file argument ${argText}`);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
status = SafetyStatus.YELLOW;
|
|
72
|
+
reasons.push(`sed file argument ${argText}`);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
// Read-only sed: only escalate if path itself is risky
|
|
77
|
+
if (pathStatus !== SafetyStatus.GREEN) {
|
|
78
|
+
status = pathStatus;
|
|
79
|
+
reasons.push(`sed file argument ${argText}`);
|
|
80
|
+
}
|
|
81
|
+
// Otherwise GREEN - read-only sed is safe
|
|
82
|
+
}
|
|
83
|
+
continue;
|
|
84
|
+
}
|
|
85
|
+
// Unknown/opaque args fall back to YELLOW
|
|
86
|
+
if (!argText) {
|
|
87
|
+
status = SafetyStatus.YELLOW;
|
|
88
|
+
reasons.push('opaque or unparseable argument');
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return { status, reasons };
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
//# sourceMappingURL=sed-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sed-handler.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/sed-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { SafetyStatus } from '../constants.js';
|
|
2
|
+
/**
|
|
3
|
+
* Result from a command handler
|
|
4
|
+
*/
|
|
5
|
+
export interface CommandHandlerResult {
|
|
6
|
+
status: SafetyStatus;
|
|
7
|
+
reasons: string[];
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Helper functions passed to command handlers
|
|
11
|
+
*/
|
|
12
|
+
export interface CommandHandlerHelpers {
|
|
13
|
+
extractWordText: (arg: any) => string | undefined;
|
|
14
|
+
analyzePathRisk: (path: string | undefined) => SafetyStatus;
|
|
15
|
+
hasFindDangerousExecution: (suffix: any[]) => {
|
|
16
|
+
dangerous: boolean;
|
|
17
|
+
reason?: string;
|
|
18
|
+
};
|
|
19
|
+
hasFindSuspiciousFlags: (suffix: any[]) => {
|
|
20
|
+
suspicious: boolean;
|
|
21
|
+
reason?: string;
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Interface for command-specific safety handlers
|
|
26
|
+
*/
|
|
27
|
+
export interface CommandHandler {
|
|
28
|
+
/**
|
|
29
|
+
* Handle command-specific safety analysis
|
|
30
|
+
* @param node The AST node representing the command
|
|
31
|
+
* @param helpers Helper functions for analysis
|
|
32
|
+
* @returns Safety status and reasons
|
|
33
|
+
*/
|
|
34
|
+
handle(node: any, helpers: CommandHandlerHelpers): CommandHandlerResult;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAE7C;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACjC,MAAM,EAAE,YAAY,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IAClC,eAAe,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,MAAM,GAAG,SAAS,CAAC;IAClD,eAAe,EAAE,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,KAAK,YAAY,CAAC;IAC5D,yBAAyB,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK;QAC1C,SAAS,EAAE,OAAO,CAAC;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,sBAAsB,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK;QACvC,UAAU,EAAE,OAAO,CAAC;QACpB,MAAM,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACL;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC3B;;;;;OAKG;IACH,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,qBAAqB,GAAG,oBAAoB,CAAC;CAC3E"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/types.ts"],"names":[],"mappings":""}
|