@shareai-lab/kode 1.1.13 → 1.1.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/entrypoints/cli.js +2 -1
- package/dist/entrypoints/cli.js.map +2 -2
- package/dist/index.js +5 -26
- package/dist/package.json +4 -1
- package/package.json +9 -104
- package/dist/test/testAdapters.js +0 -88
- package/dist/test/testAdapters.js.map +0 -1
- package/src/ProjectOnboarding.tsx +0 -198
- package/src/Tool.ts +0 -83
- package/src/commands/agents.tsx +0 -3416
- package/src/commands/approvedTools.ts +0 -53
- package/src/commands/bug.tsx +0 -20
- package/src/commands/clear.ts +0 -43
- package/src/commands/compact.ts +0 -120
- package/src/commands/config.tsx +0 -19
- package/src/commands/cost.ts +0 -18
- package/src/commands/ctx_viz.ts +0 -209
- package/src/commands/doctor.ts +0 -24
- package/src/commands/help.tsx +0 -19
- package/src/commands/init.ts +0 -37
- package/src/commands/listen.ts +0 -42
- package/src/commands/login.tsx +0 -51
- package/src/commands/logout.tsx +0 -40
- package/src/commands/mcp.ts +0 -41
- package/src/commands/model.tsx +0 -40
- package/src/commands/modelstatus.tsx +0 -20
- package/src/commands/onboarding.tsx +0 -34
- package/src/commands/pr_comments.ts +0 -59
- package/src/commands/refreshCommands.ts +0 -54
- package/src/commands/release-notes.ts +0 -34
- package/src/commands/resume.tsx +0 -31
- package/src/commands/review.ts +0 -49
- package/src/commands/terminalSetup.ts +0 -221
- package/src/commands.ts +0 -139
- package/src/components/ApproveApiKey.tsx +0 -93
- package/src/components/AsciiLogo.tsx +0 -13
- package/src/components/AutoUpdater.tsx +0 -148
- package/src/components/Bug.tsx +0 -367
- package/src/components/Config.tsx +0 -293
- package/src/components/ConsoleOAuthFlow.tsx +0 -327
- package/src/components/Cost.tsx +0 -23
- package/src/components/CostThresholdDialog.tsx +0 -46
- package/src/components/CustomSelect/option-map.ts +0 -42
- package/src/components/CustomSelect/select-option.tsx +0 -78
- package/src/components/CustomSelect/select.tsx +0 -152
- package/src/components/CustomSelect/theme.ts +0 -45
- package/src/components/CustomSelect/use-select-state.ts +0 -414
- package/src/components/CustomSelect/use-select.ts +0 -35
- package/src/components/FallbackToolUseRejectedMessage.tsx +0 -15
- package/src/components/FileEditToolUpdatedMessage.tsx +0 -66
- package/src/components/Help.tsx +0 -215
- package/src/components/HighlightedCode.tsx +0 -33
- package/src/components/InvalidConfigDialog.tsx +0 -113
- package/src/components/Link.tsx +0 -32
- package/src/components/LogSelector.tsx +0 -86
- package/src/components/Logo.tsx +0 -170
- package/src/components/MCPServerApprovalDialog.tsx +0 -100
- package/src/components/MCPServerDialogCopy.tsx +0 -25
- package/src/components/MCPServerMultiselectDialog.tsx +0 -109
- package/src/components/Message.tsx +0 -221
- package/src/components/MessageResponse.tsx +0 -15
- package/src/components/MessageSelector.tsx +0 -211
- package/src/components/ModeIndicator.tsx +0 -88
- package/src/components/ModelConfig.tsx +0 -301
- package/src/components/ModelListManager.tsx +0 -227
- package/src/components/ModelSelector.tsx +0 -3387
- package/src/components/ModelStatusDisplay.tsx +0 -230
- package/src/components/Onboarding.tsx +0 -274
- package/src/components/PressEnterToContinue.tsx +0 -11
- package/src/components/PromptInput.tsx +0 -760
- package/src/components/SentryErrorBoundary.ts +0 -39
- package/src/components/Spinner.tsx +0 -129
- package/src/components/StickerRequestForm.tsx +0 -16
- package/src/components/StructuredDiff.tsx +0 -191
- package/src/components/TextInput.tsx +0 -259
- package/src/components/TodoItem.tsx +0 -47
- package/src/components/TokenWarning.tsx +0 -31
- package/src/components/ToolUseLoader.tsx +0 -40
- package/src/components/TrustDialog.tsx +0 -106
- package/src/components/binary-feedback/BinaryFeedback.tsx +0 -63
- package/src/components/binary-feedback/BinaryFeedbackOption.tsx +0 -111
- package/src/components/binary-feedback/BinaryFeedbackView.tsx +0 -172
- package/src/components/binary-feedback/utils.ts +0 -220
- package/src/components/messages/AssistantBashOutputMessage.tsx +0 -22
- package/src/components/messages/AssistantLocalCommandOutputMessage.tsx +0 -49
- package/src/components/messages/AssistantRedactedThinkingMessage.tsx +0 -19
- package/src/components/messages/AssistantTextMessage.tsx +0 -144
- package/src/components/messages/AssistantThinkingMessage.tsx +0 -40
- package/src/components/messages/AssistantToolUseMessage.tsx +0 -132
- package/src/components/messages/TaskProgressMessage.tsx +0 -32
- package/src/components/messages/TaskToolMessage.tsx +0 -58
- package/src/components/messages/UserBashInputMessage.tsx +0 -28
- package/src/components/messages/UserCommandMessage.tsx +0 -30
- package/src/components/messages/UserKodingInputMessage.tsx +0 -28
- package/src/components/messages/UserPromptMessage.tsx +0 -35
- package/src/components/messages/UserTextMessage.tsx +0 -39
- package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +0 -12
- package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +0 -36
- package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +0 -31
- package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +0 -57
- package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +0 -35
- package/src/components/messages/UserToolResultMessage/utils.tsx +0 -56
- package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +0 -121
- package/src/components/permissions/FallbackPermissionRequest.tsx +0 -153
- package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +0 -182
- package/src/components/permissions/FileEditPermissionRequest/FileEditToolDiff.tsx +0 -77
- package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +0 -164
- package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +0 -83
- package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +0 -240
- package/src/components/permissions/PermissionRequest.tsx +0 -101
- package/src/components/permissions/PermissionRequestTitle.tsx +0 -69
- package/src/components/permissions/hooks.ts +0 -44
- package/src/components/permissions/toolUseOptions.ts +0 -59
- package/src/components/permissions/utils.ts +0 -23
- package/src/constants/betas.ts +0 -5
- package/src/constants/claude-asterisk-ascii-art.tsx +0 -238
- package/src/constants/figures.ts +0 -4
- package/src/constants/keys.ts +0 -3
- package/src/constants/macros.ts +0 -11
- package/src/constants/modelCapabilities.ts +0 -179
- package/src/constants/models.ts +0 -1025
- package/src/constants/oauth.ts +0 -18
- package/src/constants/product.ts +0 -17
- package/src/constants/prompts.ts +0 -168
- package/src/constants/releaseNotes.ts +0 -7
- package/src/context/PermissionContext.tsx +0 -149
- package/src/context.ts +0 -278
- package/src/cost-tracker.ts +0 -84
- package/src/entrypoints/cli.tsx +0 -1561
- package/src/entrypoints/mcp.ts +0 -175
- package/src/history.ts +0 -25
- package/src/hooks/useApiKeyVerification.ts +0 -59
- package/src/hooks/useArrowKeyHistory.ts +0 -55
- package/src/hooks/useCanUseTool.ts +0 -138
- package/src/hooks/useCancelRequest.ts +0 -39
- package/src/hooks/useDoublePress.ts +0 -41
- package/src/hooks/useExitOnCtrlCD.ts +0 -31
- package/src/hooks/useInterval.ts +0 -25
- package/src/hooks/useLogMessages.ts +0 -16
- package/src/hooks/useLogStartupTime.ts +0 -12
- package/src/hooks/useNotifyAfterTimeout.ts +0 -65
- package/src/hooks/usePermissionRequestLogging.ts +0 -44
- package/src/hooks/useTerminalSize.ts +0 -49
- package/src/hooks/useTextInput.ts +0 -317
- package/src/hooks/useUnifiedCompletion.ts +0 -1405
- package/src/index.ts +0 -34
- package/src/messages.ts +0 -38
- package/src/permissions.ts +0 -268
- package/src/query.ts +0 -720
- package/src/screens/ConfigureNpmPrefix.tsx +0 -197
- package/src/screens/Doctor.tsx +0 -219
- package/src/screens/LogList.tsx +0 -68
- package/src/screens/REPL.tsx +0 -813
- package/src/screens/ResumeConversation.tsx +0 -68
- package/src/services/adapters/base.ts +0 -38
- package/src/services/adapters/chatCompletions.ts +0 -90
- package/src/services/adapters/responsesAPI.ts +0 -170
- package/src/services/browserMocks.ts +0 -66
- package/src/services/claude.ts +0 -2197
- package/src/services/customCommands.ts +0 -704
- package/src/services/fileFreshness.ts +0 -377
- package/src/services/gpt5ConnectionTest.ts +0 -340
- package/src/services/mcpClient.ts +0 -564
- package/src/services/mcpServerApproval.tsx +0 -50
- package/src/services/mentionProcessor.ts +0 -273
- package/src/services/modelAdapterFactory.ts +0 -69
- package/src/services/notifier.ts +0 -40
- package/src/services/oauth.ts +0 -357
- package/src/services/openai.ts +0 -1359
- package/src/services/responseStateManager.ts +0 -90
- package/src/services/sentry.ts +0 -3
- package/src/services/statsig.ts +0 -172
- package/src/services/statsigStorage.ts +0 -86
- package/src/services/systemReminder.ts +0 -507
- package/src/services/vcr.ts +0 -161
- package/src/test/testAdapters.ts +0 -96
- package/src/tools/ArchitectTool/ArchitectTool.tsx +0 -135
- package/src/tools/ArchitectTool/prompt.ts +0 -15
- package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +0 -576
- package/src/tools/BashTool/BashTool.tsx +0 -243
- package/src/tools/BashTool/BashToolResultMessage.tsx +0 -38
- package/src/tools/BashTool/OutputLine.tsx +0 -49
- package/src/tools/BashTool/prompt.ts +0 -174
- package/src/tools/BashTool/utils.ts +0 -56
- package/src/tools/FileEditTool/FileEditTool.tsx +0 -319
- package/src/tools/FileEditTool/prompt.ts +0 -51
- package/src/tools/FileEditTool/utils.ts +0 -58
- package/src/tools/FileReadTool/FileReadTool.tsx +0 -404
- package/src/tools/FileReadTool/prompt.ts +0 -7
- package/src/tools/FileWriteTool/FileWriteTool.tsx +0 -301
- package/src/tools/FileWriteTool/prompt.ts +0 -10
- package/src/tools/GlobTool/GlobTool.tsx +0 -119
- package/src/tools/GlobTool/prompt.ts +0 -8
- package/src/tools/GrepTool/GrepTool.tsx +0 -147
- package/src/tools/GrepTool/prompt.ts +0 -11
- package/src/tools/MCPTool/MCPTool.tsx +0 -107
- package/src/tools/MCPTool/prompt.ts +0 -3
- package/src/tools/MemoryReadTool/MemoryReadTool.tsx +0 -127
- package/src/tools/MemoryReadTool/prompt.ts +0 -3
- package/src/tools/MemoryWriteTool/MemoryWriteTool.tsx +0 -89
- package/src/tools/MemoryWriteTool/prompt.ts +0 -3
- package/src/tools/MultiEditTool/MultiEditTool.tsx +0 -388
- package/src/tools/MultiEditTool/prompt.ts +0 -45
- package/src/tools/NotebookEditTool/NotebookEditTool.tsx +0 -298
- package/src/tools/NotebookEditTool/prompt.ts +0 -3
- package/src/tools/NotebookReadTool/NotebookReadTool.tsx +0 -258
- package/src/tools/NotebookReadTool/prompt.ts +0 -3
- package/src/tools/StickerRequestTool/StickerRequestTool.tsx +0 -107
- package/src/tools/StickerRequestTool/prompt.ts +0 -19
- package/src/tools/TaskTool/TaskTool.tsx +0 -438
- package/src/tools/TaskTool/constants.ts +0 -1
- package/src/tools/TaskTool/prompt.ts +0 -92
- package/src/tools/ThinkTool/ThinkTool.tsx +0 -54
- package/src/tools/ThinkTool/prompt.ts +0 -12
- package/src/tools/TodoWriteTool/TodoWriteTool.tsx +0 -313
- package/src/tools/TodoWriteTool/prompt.ts +0 -63
- package/src/tools/URLFetcherTool/URLFetcherTool.tsx +0 -178
- package/src/tools/URLFetcherTool/cache.ts +0 -55
- package/src/tools/URLFetcherTool/htmlToMarkdown.ts +0 -55
- package/src/tools/URLFetcherTool/prompt.ts +0 -17
- package/src/tools/WebSearchTool/WebSearchTool.tsx +0 -103
- package/src/tools/WebSearchTool/prompt.ts +0 -13
- package/src/tools/WebSearchTool/searchProviders.ts +0 -66
- package/src/tools/lsTool/lsTool.tsx +0 -272
- package/src/tools/lsTool/prompt.ts +0 -2
- package/src/tools.ts +0 -67
- package/src/types/PermissionMode.ts +0 -120
- package/src/types/RequestContext.ts +0 -72
- package/src/types/common.d.ts +0 -2
- package/src/types/conversation.ts +0 -51
- package/src/types/logs.ts +0 -58
- package/src/types/modelCapabilities.ts +0 -64
- package/src/types/notebook.ts +0 -87
- package/src/utils/Cursor.ts +0 -436
- package/src/utils/PersistentShell.ts +0 -552
- package/src/utils/advancedFuzzyMatcher.ts +0 -290
- package/src/utils/agentLoader.ts +0 -278
- package/src/utils/agentStorage.ts +0 -97
- package/src/utils/array.ts +0 -3
- package/src/utils/ask.tsx +0 -99
- package/src/utils/auth.ts +0 -13
- package/src/utils/autoCompactCore.ts +0 -223
- package/src/utils/autoUpdater.ts +0 -458
- package/src/utils/betas.ts +0 -20
- package/src/utils/browser.ts +0 -14
- package/src/utils/cleanup.ts +0 -72
- package/src/utils/commands.ts +0 -261
- package/src/utils/commonUnixCommands.ts +0 -161
- package/src/utils/config.ts +0 -945
- package/src/utils/conversationRecovery.ts +0 -55
- package/src/utils/debugLogger.ts +0 -1235
- package/src/utils/diff.ts +0 -42
- package/src/utils/env.ts +0 -57
- package/src/utils/errors.ts +0 -21
- package/src/utils/exampleCommands.ts +0 -109
- package/src/utils/execFileNoThrow.ts +0 -51
- package/src/utils/expertChatStorage.ts +0 -136
- package/src/utils/file.ts +0 -405
- package/src/utils/fileRecoveryCore.ts +0 -71
- package/src/utils/format.tsx +0 -44
- package/src/utils/fuzzyMatcher.ts +0 -328
- package/src/utils/generators.ts +0 -62
- package/src/utils/git.ts +0 -92
- package/src/utils/globalLogger.ts +0 -77
- package/src/utils/http.ts +0 -10
- package/src/utils/imagePaste.ts +0 -38
- package/src/utils/json.ts +0 -13
- package/src/utils/log.ts +0 -382
- package/src/utils/markdown.ts +0 -213
- package/src/utils/messageContextManager.ts +0 -294
- package/src/utils/messages.tsx +0 -945
- package/src/utils/model.ts +0 -914
- package/src/utils/permissions/filesystem.ts +0 -127
- package/src/utils/responseState.ts +0 -23
- package/src/utils/ripgrep.ts +0 -167
- package/src/utils/secureFile.ts +0 -564
- package/src/utils/sessionState.ts +0 -49
- package/src/utils/state.ts +0 -25
- package/src/utils/style.ts +0 -29
- package/src/utils/terminal.ts +0 -50
- package/src/utils/theme.ts +0 -127
- package/src/utils/thinking.ts +0 -144
- package/src/utils/todoStorage.ts +0 -431
- package/src/utils/tokens.ts +0 -43
- package/src/utils/toolExecutionController.ts +0 -163
- package/src/utils/unaryLogging.ts +0 -26
- package/src/utils/user.ts +0 -37
- package/src/utils/validate.ts +0 -165
package/src/utils/commands.ts
DELETED
|
@@ -1,261 +0,0 @@
|
|
|
1
|
-
import { memoize } from 'lodash-es'
|
|
2
|
-
import { API_ERROR_MESSAGE_PREFIX, queryQuick } from '../services/claude'
|
|
3
|
-
import { type ControlOperator, parse, ParseEntry } from 'shell-quote'
|
|
4
|
-
import { PRODUCT_NAME } from '../constants/product'
|
|
5
|
-
|
|
6
|
-
const SINGLE_QUOTE = '__SINGLE_QUOTE__'
|
|
7
|
-
const DOUBLE_QUOTE = '__DOUBLE_QUOTE__'
|
|
8
|
-
|
|
9
|
-
export type CommandPrefixResult =
|
|
10
|
-
| {
|
|
11
|
-
commandPrefix: string | null
|
|
12
|
-
commandInjectionDetected: false
|
|
13
|
-
}
|
|
14
|
-
| { commandInjectionDetected: true }
|
|
15
|
-
|
|
16
|
-
// Command prefix result alongside subcommand prefixes
|
|
17
|
-
export type CommandSubcommandPrefixResult = CommandPrefixResult & {
|
|
18
|
-
subcommandPrefixes: Map<string, CommandPrefixResult>
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Splits a command string into individual commands based on shell operators
|
|
23
|
-
*/
|
|
24
|
-
export function splitCommand(command: string): string[] {
|
|
25
|
-
const parts: ParseEntry[] = []
|
|
26
|
-
|
|
27
|
-
// 1. Collapse adjacent strings
|
|
28
|
-
for (const part of parse(
|
|
29
|
-
command
|
|
30
|
-
.replaceAll('"', `"${DOUBLE_QUOTE}`) // parse() strips out quotes :P
|
|
31
|
-
.replaceAll("'", `'${SINGLE_QUOTE}`), // parse() strips out quotes :P
|
|
32
|
-
varName => `$${varName}`, // Preserve shell variables
|
|
33
|
-
)) {
|
|
34
|
-
if (typeof part === 'string') {
|
|
35
|
-
if (parts.length > 0 && typeof parts[parts.length - 1] === 'string') {
|
|
36
|
-
parts[parts.length - 1] += ' ' + part
|
|
37
|
-
continue
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
parts.push(part)
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
// 2. Map tokens to strings
|
|
44
|
-
const stringParts = parts
|
|
45
|
-
.map(part => {
|
|
46
|
-
if (typeof part === 'string') {
|
|
47
|
-
return part
|
|
48
|
-
}
|
|
49
|
-
if ('comment' in part) {
|
|
50
|
-
// TODO: make this less hacky
|
|
51
|
-
return '#' + part.comment
|
|
52
|
-
}
|
|
53
|
-
if ('op' in part && part.op === 'glob') {
|
|
54
|
-
return part.pattern
|
|
55
|
-
}
|
|
56
|
-
if ('op' in part) {
|
|
57
|
-
return part.op
|
|
58
|
-
}
|
|
59
|
-
return null
|
|
60
|
-
})
|
|
61
|
-
.filter(_ => _ !== null)
|
|
62
|
-
|
|
63
|
-
// 3. Map quotes back to their original form
|
|
64
|
-
const quotedParts = stringParts.map(part => {
|
|
65
|
-
return part
|
|
66
|
-
.replaceAll(`${SINGLE_QUOTE}`, "'")
|
|
67
|
-
.replaceAll(`${DOUBLE_QUOTE}`, '"')
|
|
68
|
-
})
|
|
69
|
-
|
|
70
|
-
// 4. Filter out separators
|
|
71
|
-
return quotedParts.filter(
|
|
72
|
-
part => !(COMMAND_LIST_SEPARATORS as Set<string>).has(part),
|
|
73
|
-
)
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
export const getCommandSubcommandPrefix = memoize(
|
|
77
|
-
async (
|
|
78
|
-
command: string,
|
|
79
|
-
abortSignal: AbortSignal,
|
|
80
|
-
): Promise<CommandSubcommandPrefixResult | null> => {
|
|
81
|
-
const subcommands = splitCommand(command)
|
|
82
|
-
|
|
83
|
-
const [fullCommandPrefix, ...subcommandPrefixesResults] = await Promise.all(
|
|
84
|
-
[
|
|
85
|
-
getCommandPrefix(command, abortSignal),
|
|
86
|
-
...subcommands.map(async subcommand => ({
|
|
87
|
-
subcommand,
|
|
88
|
-
prefix: await getCommandPrefix(subcommand, abortSignal),
|
|
89
|
-
})),
|
|
90
|
-
],
|
|
91
|
-
)
|
|
92
|
-
if (!fullCommandPrefix) {
|
|
93
|
-
return null
|
|
94
|
-
}
|
|
95
|
-
const subcommandPrefixes = subcommandPrefixesResults.reduce(
|
|
96
|
-
(acc, { subcommand, prefix }) => {
|
|
97
|
-
if (prefix) {
|
|
98
|
-
acc.set(subcommand, prefix)
|
|
99
|
-
}
|
|
100
|
-
return acc
|
|
101
|
-
},
|
|
102
|
-
new Map<string, CommandPrefixResult>(),
|
|
103
|
-
)
|
|
104
|
-
|
|
105
|
-
return {
|
|
106
|
-
...fullCommandPrefix,
|
|
107
|
-
subcommandPrefixes,
|
|
108
|
-
}
|
|
109
|
-
},
|
|
110
|
-
command => command, // memoize by command only
|
|
111
|
-
)
|
|
112
|
-
|
|
113
|
-
const getCommandPrefix = memoize(
|
|
114
|
-
async (
|
|
115
|
-
command: string,
|
|
116
|
-
abortSignal: AbortSignal,
|
|
117
|
-
): Promise<CommandPrefixResult | null> => {
|
|
118
|
-
const response = await queryQuick({
|
|
119
|
-
systemPrompt: [
|
|
120
|
-
`Your task is to process Bash commands that an AI coding agent wants to run.
|
|
121
|
-
|
|
122
|
-
This policy spec defines how to determine the prefix of a Bash command:`,
|
|
123
|
-
],
|
|
124
|
-
userPrompt: `<policy_spec>
|
|
125
|
-
# ${PRODUCT_NAME} Code Bash command prefix detection
|
|
126
|
-
|
|
127
|
-
This document defines risk levels for actions that the ${PRODUCT_NAME} agent may take. This classification system is part of a broader safety framework and is used to determine when additional user confirmation or oversight may be needed.
|
|
128
|
-
|
|
129
|
-
## Definitions
|
|
130
|
-
|
|
131
|
-
**Command Injection:** Any technique used that would result in a command being run other than the detected prefix.
|
|
132
|
-
|
|
133
|
-
## Command prefix extraction examples
|
|
134
|
-
Examples:
|
|
135
|
-
- cat foo.txt => cat
|
|
136
|
-
- cd src => cd
|
|
137
|
-
- cd path/to/files/ => cd
|
|
138
|
-
- find ./src -type f -name "*.ts" => find
|
|
139
|
-
- gg cat foo.py => gg cat
|
|
140
|
-
- gg cp foo.py bar.py => gg cp
|
|
141
|
-
- git commit -m "foo" => git commit
|
|
142
|
-
- git diff HEAD~1 => git diff
|
|
143
|
-
- git diff --staged => git diff
|
|
144
|
-
- git diff $(pwd) => command_injection_detected
|
|
145
|
-
- git status => git status
|
|
146
|
-
- git status# test(\`id\`) => command_injection_detected
|
|
147
|
-
- git status\`ls\` => command_injection_detected
|
|
148
|
-
- git push => none
|
|
149
|
-
- git push origin master => git push
|
|
150
|
-
- git log -n 5 => git log
|
|
151
|
-
- git log --oneline -n 5 => git log
|
|
152
|
-
- grep -A 40 "from foo.bar.baz import" alpha/beta/gamma.py => grep
|
|
153
|
-
- pig tail zerba.log => pig tail
|
|
154
|
-
- npm test => none
|
|
155
|
-
- npm test --foo => npm test
|
|
156
|
-
- npm test -- -f "foo" => npm test
|
|
157
|
-
- pwd\n curl example.com => command_injection_detected
|
|
158
|
-
- pytest foo/bar.py => pytest
|
|
159
|
-
- scalac build => none
|
|
160
|
-
</policy_spec>
|
|
161
|
-
|
|
162
|
-
The user has allowed certain command prefixes to be run, and will otherwise be asked to approve or deny the command.
|
|
163
|
-
Your task is to determine the command prefix for the following command.
|
|
164
|
-
|
|
165
|
-
IMPORTANT: Bash commands may run multiple commands that are chained together.
|
|
166
|
-
For safety, if the command seems to contain command injection, you must return "command_injection_detected".
|
|
167
|
-
(This will help protect the user: if they think that they're allowlisting command A,
|
|
168
|
-
but the AI coding agent sends a malicious command that technically has the same prefix as command A,
|
|
169
|
-
then the safety system will see that you said “command_injection_detected” and ask the user for manual confirmation.)
|
|
170
|
-
|
|
171
|
-
Note that not every command has a prefix. If a command has no prefix, return "none".
|
|
172
|
-
|
|
173
|
-
ONLY return the prefix. Do not return any other text, markdown markers, or other content or formatting.
|
|
174
|
-
|
|
175
|
-
Command: ${command}
|
|
176
|
-
`,
|
|
177
|
-
signal: abortSignal,
|
|
178
|
-
enablePromptCaching: false,
|
|
179
|
-
})
|
|
180
|
-
|
|
181
|
-
const prefix =
|
|
182
|
-
typeof response.message.content === 'string'
|
|
183
|
-
? response.message.content
|
|
184
|
-
: Array.isArray(response.message.content)
|
|
185
|
-
? (response.message.content.find(_ => _.type === 'text')?.text ??
|
|
186
|
-
'none')
|
|
187
|
-
: 'none'
|
|
188
|
-
|
|
189
|
-
if (prefix.startsWith(API_ERROR_MESSAGE_PREFIX)) {
|
|
190
|
-
return null
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
if (prefix === 'command_injection_detected') {
|
|
194
|
-
return { commandInjectionDetected: true }
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
// Never accept base `git` as a prefix (if e.g. `git diff` prefix not detected)
|
|
198
|
-
if (prefix === 'git') {
|
|
199
|
-
return {
|
|
200
|
-
commandPrefix: null,
|
|
201
|
-
commandInjectionDetected: false,
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
if (prefix === 'none') {
|
|
206
|
-
return {
|
|
207
|
-
commandPrefix: null,
|
|
208
|
-
commandInjectionDetected: false,
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
return {
|
|
213
|
-
commandPrefix: prefix,
|
|
214
|
-
commandInjectionDetected: false,
|
|
215
|
-
}
|
|
216
|
-
},
|
|
217
|
-
command => command, // memoize by command only
|
|
218
|
-
)
|
|
219
|
-
|
|
220
|
-
const COMMAND_LIST_SEPARATORS = new Set<ControlOperator>([
|
|
221
|
-
'&&',
|
|
222
|
-
'||',
|
|
223
|
-
';',
|
|
224
|
-
';;',
|
|
225
|
-
])
|
|
226
|
-
|
|
227
|
-
// Checks if this is just a list of commands
|
|
228
|
-
function isCommandList(command: string): boolean {
|
|
229
|
-
for (const part of parse(
|
|
230
|
-
command
|
|
231
|
-
.replaceAll('"', `"${DOUBLE_QUOTE}`) // parse() strips out quotes :P
|
|
232
|
-
.replaceAll("'", `'${SINGLE_QUOTE}`), // parse() strips out quotes :P
|
|
233
|
-
varName => `$${varName}`, // Preserve shell variables
|
|
234
|
-
)) {
|
|
235
|
-
if (typeof part === 'string') {
|
|
236
|
-
// Strings are safe
|
|
237
|
-
continue
|
|
238
|
-
}
|
|
239
|
-
if ('comment' in part) {
|
|
240
|
-
// Don't trust comments, they can contain command injection
|
|
241
|
-
return false
|
|
242
|
-
}
|
|
243
|
-
if ('op' in part) {
|
|
244
|
-
if (part.op === 'glob') {
|
|
245
|
-
// Globs are safe
|
|
246
|
-
continue
|
|
247
|
-
} else if (COMMAND_LIST_SEPARATORS.has(part.op)) {
|
|
248
|
-
// Command list separators are safe
|
|
249
|
-
continue
|
|
250
|
-
}
|
|
251
|
-
// Other operators are unsafe
|
|
252
|
-
return false
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
// No unsafe operators found in entire command
|
|
256
|
-
return true
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
export function isUnsafeCompoundCommand(command: string): boolean {
|
|
260
|
-
return splitCommand(command).length > 1 && !isCommandList(command)
|
|
261
|
-
}
|
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Common Unix Commands Database
|
|
3
|
-
*
|
|
4
|
-
* A curated list of 500+ most frequently used Unix/Linux commands
|
|
5
|
-
* for developers and system administrators.
|
|
6
|
-
*
|
|
7
|
-
* Categories:
|
|
8
|
-
* - File & Directory Operations
|
|
9
|
-
* - Text Processing
|
|
10
|
-
* - Process Management
|
|
11
|
-
* - Network Tools
|
|
12
|
-
* - Development Tools
|
|
13
|
-
* - System Administration
|
|
14
|
-
* - Package Management
|
|
15
|
-
* - Version Control
|
|
16
|
-
*/
|
|
17
|
-
|
|
18
|
-
export const COMMON_UNIX_COMMANDS = [
|
|
19
|
-
// File & Directory Operations (50+)
|
|
20
|
-
'ls', 'cd', 'pwd', 'mkdir', 'rmdir', 'rm', 'cp', 'mv', 'touch', 'cat',
|
|
21
|
-
'less', 'more', 'head', 'tail', 'file', 'stat', 'ln', 'readlink', 'basename', 'dirname',
|
|
22
|
-
'find', 'locate', 'which', 'whereis', 'type', 'tree', 'du', 'df', 'mount', 'umount',
|
|
23
|
-
'chmod', 'chown', 'chgrp', 'umask', 'setfacl', 'getfacl', 'lsattr', 'chattr', 'realpath', 'mktemp',
|
|
24
|
-
'rsync', 'scp', 'sftp', 'ftp', 'wget', 'curl', 'tar', 'gzip', 'gunzip', 'zip',
|
|
25
|
-
'unzip', 'bzip2', 'bunzip2', 'xz', 'unxz', '7z', 'rar', 'unrar', 'zcat', 'zless',
|
|
26
|
-
|
|
27
|
-
// Text Processing (50+)
|
|
28
|
-
'grep', 'egrep', 'fgrep', 'rg', 'ag', 'ack', 'sed', 'awk', 'cut', 'paste',
|
|
29
|
-
'sort', 'uniq', 'wc', 'tr', 'col', 'column', 'expand', 'unexpand', 'fold', 'fmt',
|
|
30
|
-
'pr', 'nl', 'od', 'hexdump', 'xxd', 'strings', 'split', 'csplit', 'join', 'comm',
|
|
31
|
-
'diff', 'sdiff', 'vimdiff', 'patch', 'diffstat', 'cmp', 'md5sum', 'sha1sum', 'sha256sum', 'sha512sum',
|
|
32
|
-
'base64', 'uuencode', 'uudecode', 'rev', 'tac', 'shuf', 'jq', 'yq', 'xmllint', 'tidy',
|
|
33
|
-
|
|
34
|
-
// Process Management (40+)
|
|
35
|
-
'ps', 'top', 'htop', 'atop', 'iotop', 'iftop', 'nethogs', 'pgrep', 'pkill', 'kill',
|
|
36
|
-
'killall', 'jobs', 'bg', 'fg', 'nohup', 'disown', 'nice', 'renice', 'ionice', 'taskset',
|
|
37
|
-
'pstree', 'fuser', 'lsof', 'strace', 'ltrace', 'ptrace', 'gdb', 'valgrind', 'time', 'timeout',
|
|
38
|
-
'watch', 'screen', 'tmux', 'byobu', 'dtach', 'nmon', 'dstat', 'vmstat', 'iostat', 'mpstat',
|
|
39
|
-
|
|
40
|
-
// Network Tools (50+)
|
|
41
|
-
'ping', 'ping6', 'traceroute', 'tracepath', 'mtr', 'netstat', 'ss', 'ip', 'ifconfig', 'route',
|
|
42
|
-
'arp', 'hostname', 'hostnamectl', 'nslookup', 'dig', 'host', 'whois', 'nc', 'netcat', 'ncat',
|
|
43
|
-
'socat', 'telnet', 'ssh', 'ssh-keygen', 'ssh-copy-id', 'ssh-add', 'ssh-agent', 'sshd', 'tcpdump', 'wireshark',
|
|
44
|
-
'tshark', 'nmap', 'masscan', 'zmap', 'iptables', 'ip6tables', 'firewall-cmd', 'ufw', 'fail2ban', 'nginx',
|
|
45
|
-
'apache2', 'httpd', 'curl', 'wget', 'aria2', 'axel', 'links', 'lynx', 'w3m', 'elinks',
|
|
46
|
-
|
|
47
|
-
// Development Tools - Languages (60+)
|
|
48
|
-
'gcc', 'g++', 'clang', 'clang++', 'make', 'cmake', 'autoconf', 'automake', 'libtool', 'pkg-config',
|
|
49
|
-
'python3', 'pip', 'pip3', 'pipenv', 'poetry', 'virtualenv', 'pyenv',
|
|
50
|
-
'node', 'npm', 'uv', 'npx', 'yarn', 'pnpm', 'nvm', 'volta', 'deno', 'bun', 'tsx',
|
|
51
|
-
'ruby', 'gem', 'bundle', 'bundler', 'rake', 'rbenv', 'rvm', 'irb', 'pry', 'rails',
|
|
52
|
-
'java', 'javac', 'jar', 'javadoc', 'maven', 'mvn', 'gradle', 'ant', 'kotlin', 'kotlinc',
|
|
53
|
-
'go', 'gofmt', 'golint', 'govet', 'godoc', 'rust', 'rustc', 'cargo', 'rustup', 'rustfmt',
|
|
54
|
-
|
|
55
|
-
// Development Tools - Utilities (40+)
|
|
56
|
-
'git', 'svn', 'hg', 'bzr', 'cvs', 'fossil', 'tig', 'gitk', 'git-flow', 'hub',
|
|
57
|
-
'gh', 'glab', 'docker', 'docker-compose', 'podman', 'kubectl', 'helm', 'minikube', 'kind', 'k3s',
|
|
58
|
-
'vagrant', 'terraform', 'ansible', 'puppet', 'chef', 'salt', 'packer', 'consul', 'vault', 'nomad',
|
|
59
|
-
'vim', 'vi', 'nvim', 'emacs', 'nano', 'pico', 'ed', 'code', 'subl', 'atom',
|
|
60
|
-
|
|
61
|
-
// Database & Data Tools (30+)
|
|
62
|
-
'mysql', 'mysqldump', 'mysqladmin', 'psql', 'pg_dump', 'pg_restore', 'sqlite3', 'redis-cli', 'mongo', 'mongodump',
|
|
63
|
-
'mongorestore', 'cqlsh', 'influx', 'clickhouse-client', 'mariadb', 'cockroach', 'etcdctl', 'consul', 'vault', 'nomad',
|
|
64
|
-
'jq', 'yq', 'xmlstarlet', 'csvkit', 'miller', 'awk', 'sed', 'perl', 'lua', 'tcl',
|
|
65
|
-
|
|
66
|
-
// System Administration (50+)
|
|
67
|
-
'sudo', 'su', 'passwd', 'useradd', 'userdel', 'usermod', 'groupadd', 'groupdel', 'groupmod', 'id',
|
|
68
|
-
'who', 'w', 'last', 'lastlog', 'finger', 'chfn', 'chsh', 'login', 'logout', 'exit',
|
|
69
|
-
'systemctl', 'service', 'journalctl', 'systemd-analyze', 'init', 'telinit', 'runlevel', 'shutdown', 'reboot', 'halt',
|
|
70
|
-
'poweroff', 'uptime', 'uname', 'hostname', 'hostnamectl', 'timedatectl', 'localectl', 'loginctl', 'machinectl', 'bootctl',
|
|
71
|
-
'cron', 'crontab', 'at', 'batch', 'anacron', 'systemd-run', 'systemd-timer', 'logrotate', 'logger', 'dmesg',
|
|
72
|
-
|
|
73
|
-
// Package Management (30+)
|
|
74
|
-
'apt', 'apt-get', 'apt-cache', 'dpkg', 'dpkg-reconfigure', 'aptitude', 'snap', 'flatpak', 'appimage', 'alien',
|
|
75
|
-
'yum', 'dnf', 'rpm', 'zypper', 'pacman', 'yaourt', 'yay', 'makepkg', 'abs', 'aur',
|
|
76
|
-
'brew', 'port', 'pkg', 'emerge', 'portage', 'nix', 'guix', 'conda', 'mamba', 'micromamba',
|
|
77
|
-
|
|
78
|
-
// Monitoring & Performance (30+)
|
|
79
|
-
'top', 'htop', 'atop', 'btop', 'gtop', 'gotop', 'bashtop', 'bpytop', 'glances', 'nmon',
|
|
80
|
-
'sar', 'iostat', 'mpstat', 'vmstat', 'pidstat', 'free', 'uptime', 'tload', 'slabtop', 'powertop',
|
|
81
|
-
'iotop', 'iftop', 'nethogs', 'bmon', 'nload', 'speedtest', 'speedtest-cli', 'fast', 'mtr', 'smokeping',
|
|
82
|
-
|
|
83
|
-
// Security Tools (30+)
|
|
84
|
-
'gpg', 'gpg2', 'openssl', 'ssh-keygen', 'ssh-keyscan', 'ssl-cert', 'certbot', 'acme.sh', 'mkcert', 'step',
|
|
85
|
-
'pass', 'keepassxc-cli', 'bitwarden', '1password', 'hashcat', 'john', 'hydra', 'ncrack', 'medusa', 'aircrack-ng',
|
|
86
|
-
'chkrootkit', 'rkhunter', 'clamav', 'clamscan', 'freshclam', 'aide', 'tripwire', 'samhain', 'ossec', 'wazuh',
|
|
87
|
-
|
|
88
|
-
// Shell & Scripting (30+)
|
|
89
|
-
'bash', 'sh', 'zsh', 'fish', 'ksh', 'tcsh', 'csh', 'dash', 'ash', 'elvish',
|
|
90
|
-
'export', 'alias', 'unalias', 'history', 'fc', 'source', 'eval', 'exec', 'command', 'builtin',
|
|
91
|
-
'set', 'unset', 'env', 'printenv', 'echo', 'printf', 'read', 'test', 'expr', 'let',
|
|
92
|
-
|
|
93
|
-
// Archive & Compression (20+)
|
|
94
|
-
'tar', 'gzip', 'gunzip', 'bzip2', 'bunzip2', 'xz', 'unxz', 'lzma', 'unlzma', 'compress',
|
|
95
|
-
'uncompress', 'zip', 'unzip', '7z', '7za', 'rar', 'unrar', 'ar', 'cpio', 'pax',
|
|
96
|
-
|
|
97
|
-
// Media Tools (20+)
|
|
98
|
-
'ffmpeg', 'ffplay', 'ffprobe', 'sox', 'play', 'rec', 'mpg123', 'mpg321', 'ogg123', 'flac',
|
|
99
|
-
'lame', 'oggenc', 'opusenc', 'convert', 'mogrify', 'identify', 'display', 'import', 'animate', 'montage',
|
|
100
|
-
|
|
101
|
-
// Math & Calculation (15+)
|
|
102
|
-
'bc', 'dc', 'calc', 'qalc', 'units', 'factor', 'primes', 'seq', 'shuf', 'random',
|
|
103
|
-
'octave', 'maxima', 'sage', 'r', 'julia',
|
|
104
|
-
|
|
105
|
-
// Documentation & Help (15+)
|
|
106
|
-
'man', 'info', 'help', 'apropos', 'whatis', 'whereis', 'which', 'type', 'command', 'hash',
|
|
107
|
-
'tldr', 'cheat', 'howdoi', 'stackoverflow', 'explainshell',
|
|
108
|
-
|
|
109
|
-
// Miscellaneous Utilities (30+)
|
|
110
|
-
'date', 'cal', 'ncal', 'timedatectl', 'zdump', 'tzselect', 'hwclock', 'ntpdate', 'chrony', 'timeshift',
|
|
111
|
-
'yes', 'true', 'false', 'sleep', 'usleep', 'seq', 'jot', 'shuf', 'tee', 'xargs',
|
|
112
|
-
'parallel', 'rush', 'dsh', 'pssh', 'clusterssh', 'terminator', 'tilix', 'alacritty', 'kitty', 'wezterm',
|
|
113
|
-
] as const
|
|
114
|
-
|
|
115
|
-
/**
|
|
116
|
-
* Get common commands that exist on the current system
|
|
117
|
-
* @param systemCommands Array of commands available on the system
|
|
118
|
-
* @returns Deduplicated intersection of common commands and system commands
|
|
119
|
-
*/
|
|
120
|
-
export function getCommonSystemCommands(systemCommands: string[]): string[] {
|
|
121
|
-
const systemSet = new Set(systemCommands.map(cmd => cmd.toLowerCase()))
|
|
122
|
-
const commonIntersection = COMMON_UNIX_COMMANDS.filter(cmd => systemSet.has(cmd.toLowerCase()))
|
|
123
|
-
// Remove duplicates using Set
|
|
124
|
-
return Array.from(new Set(commonIntersection))
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* Get a priority score for a command based on its position in the common list
|
|
129
|
-
* Earlier commands get higher priority (more commonly used)
|
|
130
|
-
*/
|
|
131
|
-
export function getCommandPriority(command: string): number {
|
|
132
|
-
const index = COMMON_UNIX_COMMANDS.indexOf(command.toLowerCase() as any)
|
|
133
|
-
if (index === -1) return 0
|
|
134
|
-
|
|
135
|
-
// Convert index to priority score (earlier = higher score)
|
|
136
|
-
const maxScore = 100
|
|
137
|
-
const score = maxScore - (index / COMMON_UNIX_COMMANDS.length) * maxScore
|
|
138
|
-
return Math.round(score)
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
/**
|
|
142
|
-
* Get essential fallback commands for when PATH is empty or unavailable
|
|
143
|
-
* These are the most basic commands that should always be available
|
|
144
|
-
*/
|
|
145
|
-
export function getEssentialCommands(): string[] {
|
|
146
|
-
return [
|
|
147
|
-
'ls', 'cd', 'pwd', 'cat', 'grep', 'find', 'which', 'man', 'cp', 'mv', 'rm', 'mkdir',
|
|
148
|
-
'touch', 'chmod', 'ps', 'top', 'kill', 'git', 'node', 'npm', 'python3',
|
|
149
|
-
'curl', 'wget', 'docker', 'vim', 'nano', 'echo', 'export', 'env', 'sudo'
|
|
150
|
-
]
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
/**
|
|
154
|
-
* Get minimal fallback commands for error scenarios
|
|
155
|
-
* These are absolute minimum commands for basic functionality
|
|
156
|
-
*/
|
|
157
|
-
export function getMinimalFallbackCommands(): string[] {
|
|
158
|
-
return [
|
|
159
|
-
'ls', 'cd', 'pwd', 'cat', 'grep', 'find', 'git', 'node', 'npm', 'python3', 'vim', 'nano'
|
|
160
|
-
]
|
|
161
|
-
}
|