@shareai-lab/kode 1.1.14 → 1.1.16-dev.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (289) hide show
  1. package/cli.js +77 -82
  2. package/dist/entrypoints/cli.js +59 -38
  3. package/dist/entrypoints/cli.js.map +3 -3
  4. package/dist/index.js +5 -26
  5. package/dist/package.json +4 -1
  6. package/package.json +11 -104
  7. package/dist/test/testAdapters.js +0 -88
  8. package/dist/test/testAdapters.js.map +0 -1
  9. package/src/ProjectOnboarding.tsx +0 -198
  10. package/src/Tool.ts +0 -83
  11. package/src/commands/agents.tsx +0 -3416
  12. package/src/commands/approvedTools.ts +0 -53
  13. package/src/commands/bug.tsx +0 -20
  14. package/src/commands/clear.ts +0 -43
  15. package/src/commands/compact.ts +0 -120
  16. package/src/commands/config.tsx +0 -19
  17. package/src/commands/cost.ts +0 -18
  18. package/src/commands/ctx_viz.ts +0 -209
  19. package/src/commands/doctor.ts +0 -24
  20. package/src/commands/help.tsx +0 -19
  21. package/src/commands/init.ts +0 -37
  22. package/src/commands/listen.ts +0 -42
  23. package/src/commands/login.tsx +0 -51
  24. package/src/commands/logout.tsx +0 -40
  25. package/src/commands/mcp.ts +0 -41
  26. package/src/commands/model.tsx +0 -40
  27. package/src/commands/modelstatus.tsx +0 -20
  28. package/src/commands/onboarding.tsx +0 -34
  29. package/src/commands/pr_comments.ts +0 -59
  30. package/src/commands/refreshCommands.ts +0 -54
  31. package/src/commands/release-notes.ts +0 -34
  32. package/src/commands/resume.tsx +0 -31
  33. package/src/commands/review.ts +0 -49
  34. package/src/commands/terminalSetup.ts +0 -221
  35. package/src/commands.ts +0 -139
  36. package/src/components/ApproveApiKey.tsx +0 -93
  37. package/src/components/AsciiLogo.tsx +0 -13
  38. package/src/components/AutoUpdater.tsx +0 -148
  39. package/src/components/Bug.tsx +0 -367
  40. package/src/components/Config.tsx +0 -293
  41. package/src/components/ConsoleOAuthFlow.tsx +0 -327
  42. package/src/components/Cost.tsx +0 -23
  43. package/src/components/CostThresholdDialog.tsx +0 -46
  44. package/src/components/CustomSelect/option-map.ts +0 -42
  45. package/src/components/CustomSelect/select-option.tsx +0 -78
  46. package/src/components/CustomSelect/select.tsx +0 -152
  47. package/src/components/CustomSelect/theme.ts +0 -45
  48. package/src/components/CustomSelect/use-select-state.ts +0 -414
  49. package/src/components/CustomSelect/use-select.ts +0 -35
  50. package/src/components/FallbackToolUseRejectedMessage.tsx +0 -15
  51. package/src/components/FileEditToolUpdatedMessage.tsx +0 -66
  52. package/src/components/Help.tsx +0 -215
  53. package/src/components/HighlightedCode.tsx +0 -33
  54. package/src/components/InvalidConfigDialog.tsx +0 -113
  55. package/src/components/Link.tsx +0 -32
  56. package/src/components/LogSelector.tsx +0 -86
  57. package/src/components/Logo.tsx +0 -170
  58. package/src/components/MCPServerApprovalDialog.tsx +0 -100
  59. package/src/components/MCPServerDialogCopy.tsx +0 -25
  60. package/src/components/MCPServerMultiselectDialog.tsx +0 -109
  61. package/src/components/Message.tsx +0 -221
  62. package/src/components/MessageResponse.tsx +0 -15
  63. package/src/components/MessageSelector.tsx +0 -211
  64. package/src/components/ModeIndicator.tsx +0 -88
  65. package/src/components/ModelConfig.tsx +0 -301
  66. package/src/components/ModelListManager.tsx +0 -227
  67. package/src/components/ModelSelector.tsx +0 -3387
  68. package/src/components/ModelStatusDisplay.tsx +0 -230
  69. package/src/components/Onboarding.tsx +0 -274
  70. package/src/components/PressEnterToContinue.tsx +0 -11
  71. package/src/components/PromptInput.tsx +0 -760
  72. package/src/components/SentryErrorBoundary.ts +0 -39
  73. package/src/components/Spinner.tsx +0 -129
  74. package/src/components/StickerRequestForm.tsx +0 -16
  75. package/src/components/StructuredDiff.tsx +0 -191
  76. package/src/components/TextInput.tsx +0 -259
  77. package/src/components/TodoItem.tsx +0 -47
  78. package/src/components/TokenWarning.tsx +0 -31
  79. package/src/components/ToolUseLoader.tsx +0 -40
  80. package/src/components/TrustDialog.tsx +0 -106
  81. package/src/components/binary-feedback/BinaryFeedback.tsx +0 -63
  82. package/src/components/binary-feedback/BinaryFeedbackOption.tsx +0 -111
  83. package/src/components/binary-feedback/BinaryFeedbackView.tsx +0 -172
  84. package/src/components/binary-feedback/utils.ts +0 -220
  85. package/src/components/messages/AssistantBashOutputMessage.tsx +0 -22
  86. package/src/components/messages/AssistantLocalCommandOutputMessage.tsx +0 -49
  87. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +0 -19
  88. package/src/components/messages/AssistantTextMessage.tsx +0 -144
  89. package/src/components/messages/AssistantThinkingMessage.tsx +0 -40
  90. package/src/components/messages/AssistantToolUseMessage.tsx +0 -132
  91. package/src/components/messages/TaskProgressMessage.tsx +0 -32
  92. package/src/components/messages/TaskToolMessage.tsx +0 -58
  93. package/src/components/messages/UserBashInputMessage.tsx +0 -28
  94. package/src/components/messages/UserCommandMessage.tsx +0 -30
  95. package/src/components/messages/UserKodingInputMessage.tsx +0 -28
  96. package/src/components/messages/UserPromptMessage.tsx +0 -35
  97. package/src/components/messages/UserTextMessage.tsx +0 -39
  98. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +0 -12
  99. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +0 -36
  100. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +0 -31
  101. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +0 -57
  102. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +0 -35
  103. package/src/components/messages/UserToolResultMessage/utils.tsx +0 -56
  104. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +0 -121
  105. package/src/components/permissions/FallbackPermissionRequest.tsx +0 -153
  106. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +0 -182
  107. package/src/components/permissions/FileEditPermissionRequest/FileEditToolDiff.tsx +0 -77
  108. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +0 -164
  109. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +0 -83
  110. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +0 -240
  111. package/src/components/permissions/PermissionRequest.tsx +0 -101
  112. package/src/components/permissions/PermissionRequestTitle.tsx +0 -69
  113. package/src/components/permissions/hooks.ts +0 -44
  114. package/src/components/permissions/toolUseOptions.ts +0 -59
  115. package/src/components/permissions/utils.ts +0 -23
  116. package/src/constants/betas.ts +0 -5
  117. package/src/constants/claude-asterisk-ascii-art.tsx +0 -238
  118. package/src/constants/figures.ts +0 -4
  119. package/src/constants/keys.ts +0 -3
  120. package/src/constants/macros.ts +0 -11
  121. package/src/constants/modelCapabilities.ts +0 -179
  122. package/src/constants/models.ts +0 -1025
  123. package/src/constants/oauth.ts +0 -18
  124. package/src/constants/product.ts +0 -17
  125. package/src/constants/prompts.ts +0 -168
  126. package/src/constants/releaseNotes.ts +0 -7
  127. package/src/context/PermissionContext.tsx +0 -149
  128. package/src/context.ts +0 -278
  129. package/src/cost-tracker.ts +0 -84
  130. package/src/entrypoints/cli.tsx +0 -1561
  131. package/src/entrypoints/mcp.ts +0 -175
  132. package/src/history.ts +0 -25
  133. package/src/hooks/useApiKeyVerification.ts +0 -59
  134. package/src/hooks/useArrowKeyHistory.ts +0 -55
  135. package/src/hooks/useCanUseTool.ts +0 -138
  136. package/src/hooks/useCancelRequest.ts +0 -39
  137. package/src/hooks/useDoublePress.ts +0 -41
  138. package/src/hooks/useExitOnCtrlCD.ts +0 -31
  139. package/src/hooks/useInterval.ts +0 -25
  140. package/src/hooks/useLogMessages.ts +0 -16
  141. package/src/hooks/useLogStartupTime.ts +0 -12
  142. package/src/hooks/useNotifyAfterTimeout.ts +0 -65
  143. package/src/hooks/usePermissionRequestLogging.ts +0 -44
  144. package/src/hooks/useTerminalSize.ts +0 -49
  145. package/src/hooks/useTextInput.ts +0 -317
  146. package/src/hooks/useUnifiedCompletion.ts +0 -1405
  147. package/src/index.ts +0 -34
  148. package/src/messages.ts +0 -38
  149. package/src/permissions.ts +0 -268
  150. package/src/query.ts +0 -720
  151. package/src/screens/ConfigureNpmPrefix.tsx +0 -197
  152. package/src/screens/Doctor.tsx +0 -219
  153. package/src/screens/LogList.tsx +0 -68
  154. package/src/screens/REPL.tsx +0 -813
  155. package/src/screens/ResumeConversation.tsx +0 -68
  156. package/src/services/adapters/base.ts +0 -38
  157. package/src/services/adapters/chatCompletions.ts +0 -90
  158. package/src/services/adapters/responsesAPI.ts +0 -170
  159. package/src/services/browserMocks.ts +0 -66
  160. package/src/services/claude.ts +0 -2197
  161. package/src/services/customCommands.ts +0 -704
  162. package/src/services/fileFreshness.ts +0 -377
  163. package/src/services/gpt5ConnectionTest.ts +0 -340
  164. package/src/services/mcpClient.ts +0 -564
  165. package/src/services/mcpServerApproval.tsx +0 -50
  166. package/src/services/mentionProcessor.ts +0 -273
  167. package/src/services/modelAdapterFactory.ts +0 -69
  168. package/src/services/notifier.ts +0 -40
  169. package/src/services/oauth.ts +0 -357
  170. package/src/services/openai.ts +0 -1359
  171. package/src/services/responseStateManager.ts +0 -90
  172. package/src/services/sentry.ts +0 -3
  173. package/src/services/statsig.ts +0 -172
  174. package/src/services/statsigStorage.ts +0 -86
  175. package/src/services/systemReminder.ts +0 -507
  176. package/src/services/vcr.ts +0 -161
  177. package/src/test/testAdapters.ts +0 -96
  178. package/src/tools/ArchitectTool/ArchitectTool.tsx +0 -135
  179. package/src/tools/ArchitectTool/prompt.ts +0 -15
  180. package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +0 -576
  181. package/src/tools/BashTool/BashTool.tsx +0 -243
  182. package/src/tools/BashTool/BashToolResultMessage.tsx +0 -38
  183. package/src/tools/BashTool/OutputLine.tsx +0 -49
  184. package/src/tools/BashTool/prompt.ts +0 -174
  185. package/src/tools/BashTool/utils.ts +0 -56
  186. package/src/tools/FileEditTool/FileEditTool.tsx +0 -319
  187. package/src/tools/FileEditTool/prompt.ts +0 -51
  188. package/src/tools/FileEditTool/utils.ts +0 -58
  189. package/src/tools/FileReadTool/FileReadTool.tsx +0 -404
  190. package/src/tools/FileReadTool/prompt.ts +0 -7
  191. package/src/tools/FileWriteTool/FileWriteTool.tsx +0 -301
  192. package/src/tools/FileWriteTool/prompt.ts +0 -10
  193. package/src/tools/GlobTool/GlobTool.tsx +0 -119
  194. package/src/tools/GlobTool/prompt.ts +0 -8
  195. package/src/tools/GrepTool/GrepTool.tsx +0 -147
  196. package/src/tools/GrepTool/prompt.ts +0 -11
  197. package/src/tools/MCPTool/MCPTool.tsx +0 -107
  198. package/src/tools/MCPTool/prompt.ts +0 -3
  199. package/src/tools/MemoryReadTool/MemoryReadTool.tsx +0 -127
  200. package/src/tools/MemoryReadTool/prompt.ts +0 -3
  201. package/src/tools/MemoryWriteTool/MemoryWriteTool.tsx +0 -89
  202. package/src/tools/MemoryWriteTool/prompt.ts +0 -3
  203. package/src/tools/MultiEditTool/MultiEditTool.tsx +0 -388
  204. package/src/tools/MultiEditTool/prompt.ts +0 -45
  205. package/src/tools/NotebookEditTool/NotebookEditTool.tsx +0 -298
  206. package/src/tools/NotebookEditTool/prompt.ts +0 -3
  207. package/src/tools/NotebookReadTool/NotebookReadTool.tsx +0 -258
  208. package/src/tools/NotebookReadTool/prompt.ts +0 -3
  209. package/src/tools/StickerRequestTool/StickerRequestTool.tsx +0 -107
  210. package/src/tools/StickerRequestTool/prompt.ts +0 -19
  211. package/src/tools/TaskTool/TaskTool.tsx +0 -438
  212. package/src/tools/TaskTool/constants.ts +0 -1
  213. package/src/tools/TaskTool/prompt.ts +0 -92
  214. package/src/tools/ThinkTool/ThinkTool.tsx +0 -54
  215. package/src/tools/ThinkTool/prompt.ts +0 -12
  216. package/src/tools/TodoWriteTool/TodoWriteTool.tsx +0 -313
  217. package/src/tools/TodoWriteTool/prompt.ts +0 -63
  218. package/src/tools/URLFetcherTool/URLFetcherTool.tsx +0 -178
  219. package/src/tools/URLFetcherTool/cache.ts +0 -55
  220. package/src/tools/URLFetcherTool/htmlToMarkdown.ts +0 -55
  221. package/src/tools/URLFetcherTool/prompt.ts +0 -17
  222. package/src/tools/WebSearchTool/WebSearchTool.tsx +0 -103
  223. package/src/tools/WebSearchTool/prompt.ts +0 -13
  224. package/src/tools/WebSearchTool/searchProviders.ts +0 -66
  225. package/src/tools/lsTool/lsTool.tsx +0 -272
  226. package/src/tools/lsTool/prompt.ts +0 -2
  227. package/src/tools.ts +0 -67
  228. package/src/types/PermissionMode.ts +0 -120
  229. package/src/types/RequestContext.ts +0 -72
  230. package/src/types/common.d.ts +0 -2
  231. package/src/types/conversation.ts +0 -51
  232. package/src/types/logs.ts +0 -58
  233. package/src/types/modelCapabilities.ts +0 -64
  234. package/src/types/notebook.ts +0 -87
  235. package/src/utils/Cursor.ts +0 -436
  236. package/src/utils/PersistentShell.ts +0 -552
  237. package/src/utils/advancedFuzzyMatcher.ts +0 -290
  238. package/src/utils/agentLoader.ts +0 -278
  239. package/src/utils/agentStorage.ts +0 -97
  240. package/src/utils/array.ts +0 -3
  241. package/src/utils/ask.tsx +0 -99
  242. package/src/utils/auth.ts +0 -13
  243. package/src/utils/autoCompactCore.ts +0 -223
  244. package/src/utils/autoUpdater.ts +0 -458
  245. package/src/utils/betas.ts +0 -20
  246. package/src/utils/browser.ts +0 -14
  247. package/src/utils/cleanup.ts +0 -72
  248. package/src/utils/commands.ts +0 -261
  249. package/src/utils/commonUnixCommands.ts +0 -161
  250. package/src/utils/config.ts +0 -945
  251. package/src/utils/conversationRecovery.ts +0 -55
  252. package/src/utils/debugLogger.ts +0 -1235
  253. package/src/utils/diff.ts +0 -42
  254. package/src/utils/env.ts +0 -57
  255. package/src/utils/errors.ts +0 -21
  256. package/src/utils/exampleCommands.ts +0 -109
  257. package/src/utils/execFileNoThrow.ts +0 -51
  258. package/src/utils/expertChatStorage.ts +0 -136
  259. package/src/utils/file.ts +0 -405
  260. package/src/utils/fileRecoveryCore.ts +0 -71
  261. package/src/utils/format.tsx +0 -44
  262. package/src/utils/fuzzyMatcher.ts +0 -328
  263. package/src/utils/generators.ts +0 -62
  264. package/src/utils/git.ts +0 -92
  265. package/src/utils/globalLogger.ts +0 -77
  266. package/src/utils/http.ts +0 -10
  267. package/src/utils/imagePaste.ts +0 -38
  268. package/src/utils/json.ts +0 -13
  269. package/src/utils/log.ts +0 -382
  270. package/src/utils/markdown.ts +0 -213
  271. package/src/utils/messageContextManager.ts +0 -294
  272. package/src/utils/messages.tsx +0 -945
  273. package/src/utils/model.ts +0 -914
  274. package/src/utils/permissions/filesystem.ts +0 -127
  275. package/src/utils/responseState.ts +0 -23
  276. package/src/utils/ripgrep.ts +0 -167
  277. package/src/utils/secureFile.ts +0 -564
  278. package/src/utils/sessionState.ts +0 -49
  279. package/src/utils/state.ts +0 -25
  280. package/src/utils/style.ts +0 -29
  281. package/src/utils/terminal.ts +0 -50
  282. package/src/utils/theme.ts +0 -127
  283. package/src/utils/thinking.ts +0 -144
  284. package/src/utils/todoStorage.ts +0 -431
  285. package/src/utils/tokens.ts +0 -43
  286. package/src/utils/toolExecutionController.ts +0 -163
  287. package/src/utils/unaryLogging.ts +0 -26
  288. package/src/utils/user.ts +0 -37
  289. package/src/utils/validate.ts +0 -165
@@ -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
- }