@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
package/src/index.ts DELETED
@@ -1,34 +0,0 @@
1
- // Unified CLI entry (lightweight)
2
- // - Development: use `bun run src/entrypoints/cli.tsx`
3
- // - Production: transpiled to `dist/index.js` and used as bin/main
4
-
5
- import { createRequire } from 'module'
6
- const require = createRequire(import.meta.url)
7
-
8
- function hasFlag(...flags: string[]): boolean {
9
- return process.argv.some(arg => flags.includes(arg))
10
- }
11
-
12
- // Minimal pre-parse: handle version/help early without loading heavy UI modules
13
- if (hasFlag('--version', '-v')) {
14
- try {
15
- const pkg = require('../package.json')
16
- console.log(pkg.version || '')
17
- } catch {
18
- console.log('')
19
- }
20
- process.exit(0)
21
- }
22
-
23
- if (hasFlag('--help-lite')) {
24
- console.log(`Usage: kode [options] [command] [prompt]\n\n` +
25
- `Common options:\n` +
26
- ` -h, --help Show full help\n` +
27
- ` -v, --version Show version\n` +
28
- ` -p, --print Print response and exit (non-interactive)\n` +
29
- ` -c, --cwd <cwd> Set working directory`)
30
- process.exit(0)
31
- }
32
-
33
- // For compatibility, --help loads full CLI help
34
- await import('./entrypoints/cli.js')
package/src/messages.ts DELETED
@@ -1,38 +0,0 @@
1
- import React from 'react'
2
- import type { Message } from './query'
3
-
4
- let getMessages: () => Message[] = () => []
5
- let setMessages: React.Dispatch<React.SetStateAction<Message[]>> = () => {}
6
-
7
- export function setMessagesGetter(getter: () => Message[]) {
8
- getMessages = getter
9
- }
10
-
11
- export function getMessagesGetter(): () => Message[] {
12
- return getMessages
13
- }
14
-
15
- export function setMessagesSetter(
16
- setter: React.Dispatch<React.SetStateAction<Message[]>>,
17
- ) {
18
- setMessages = setter
19
- }
20
-
21
- export function getMessagesSetter(): React.Dispatch<
22
- React.SetStateAction<Message[]>
23
- > {
24
- return setMessages
25
- }
26
-
27
- // Global UI refresh mechanism for model configuration changes
28
- let onModelConfigChange: (() => void) | null = null
29
-
30
- export function setModelConfigChangeHandler(handler: () => void) {
31
- onModelConfigChange = handler
32
- }
33
-
34
- export function triggerModelConfigChange() {
35
- if (onModelConfigChange) {
36
- onModelConfigChange()
37
- }
38
- }
@@ -1,268 +0,0 @@
1
- import type { CanUseToolFn } from './hooks/useCanUseTool'
2
- import { Tool, ToolUseContext } from './Tool'
3
- import { BashTool, inputSchema } from './tools/BashTool/BashTool'
4
- import { FileEditTool } from './tools/FileEditTool/FileEditTool'
5
- import { FileWriteTool } from './tools/FileWriteTool/FileWriteTool'
6
- import { NotebookEditTool } from './tools/NotebookEditTool/NotebookEditTool'
7
- import { getCommandSubcommandPrefix, splitCommand } from './utils/commands'
8
- import {
9
- getCurrentProjectConfig,
10
- saveCurrentProjectConfig,
11
- } from './utils/config.js'
12
- import { AbortError } from './utils/errors'
13
- import { logError } from './utils/log'
14
- import { grantWritePermissionForOriginalDir } from './utils/permissions/filesystem'
15
- import { getCwd } from './utils/state'
16
- import { PRODUCT_NAME } from './constants/product'
17
-
18
- // Commands that are known to be safe for execution
19
- const SAFE_COMMANDS = new Set([
20
- 'git status',
21
- 'git diff',
22
- 'git log',
23
- 'git branch',
24
- 'pwd',
25
- 'tree',
26
- 'date',
27
- 'which',
28
- ])
29
-
30
- export const bashToolCommandHasExactMatchPermission = (
31
- tool: Tool,
32
- command: string,
33
- allowedTools: string[],
34
- ): boolean => {
35
- if (SAFE_COMMANDS.has(command)) {
36
- return true
37
- }
38
- // Check exact match first
39
- if (allowedTools.includes(getPermissionKey(tool, { command }, null))) {
40
- return true
41
- }
42
- // Check if command is an exact match with an approved prefix
43
- if (allowedTools.includes(getPermissionKey(tool, { command }, command))) {
44
- return true
45
- }
46
- return false
47
- }
48
-
49
- export const bashToolCommandHasPermission = (
50
- tool: Tool,
51
- command: string,
52
- prefix: string | null,
53
- allowedTools: string[],
54
- ): boolean => {
55
- // Check exact match first
56
- if (bashToolCommandHasExactMatchPermission(tool, command, allowedTools)) {
57
- return true
58
- }
59
- return allowedTools.includes(getPermissionKey(tool, { command }, prefix))
60
- }
61
-
62
- export const bashToolHasPermission = async (
63
- tool: Tool,
64
- command: string,
65
- context: ToolUseContext,
66
- allowedTools: string[],
67
- getCommandSubcommandPrefixFn = getCommandSubcommandPrefix,
68
- ): Promise<PermissionResult> => {
69
- if (bashToolCommandHasExactMatchPermission(tool, command, allowedTools)) {
70
- // This is an exact match for a command that is allowed, so we can skip the prefix check
71
- return { result: true }
72
- }
73
-
74
- const subCommands = splitCommand(command).filter(_ => {
75
- // Denim likes to add this, we strip it out so we don't need to prompt the user each time
76
- if (_ === `cd ${getCwd()}`) {
77
- return false
78
- }
79
- return true
80
- })
81
- const commandSubcommandPrefix = await getCommandSubcommandPrefixFn(
82
- command,
83
- context.abortController.signal,
84
- )
85
- if (context.abortController.signal.aborted) {
86
- throw new AbortError()
87
- }
88
-
89
- if (commandSubcommandPrefix === null) {
90
- // Fail closed and ask for user approval if the command prefix query failed (e.g. due to network error)
91
- // This is NOT the same as `fullCommandPrefix.commandPrefix === null`, which means no prefix was detected
92
- return {
93
- result: false,
94
- message: `${PRODUCT_NAME} requested permissions to use ${tool.name}, but you haven't granted it yet.`,
95
- }
96
- }
97
-
98
- if (commandSubcommandPrefix.commandInjectionDetected) {
99
- // Only allow exact matches for potential command injections
100
- if (bashToolCommandHasExactMatchPermission(tool, command, allowedTools)) {
101
- return { result: true }
102
- } else {
103
- return {
104
- result: false,
105
- message: `${PRODUCT_NAME} requested permissions to use ${tool.name}, but you haven't granted it yet.`,
106
- }
107
- }
108
- }
109
-
110
- // If there is only one command, no need to process subCommands
111
- if (subCommands.length < 2) {
112
- if (
113
- bashToolCommandHasPermission(
114
- tool,
115
- command,
116
- commandSubcommandPrefix.commandPrefix,
117
- allowedTools,
118
- )
119
- ) {
120
- return { result: true }
121
- } else {
122
- return {
123
- result: false,
124
- message: `${PRODUCT_NAME} requested permissions to use ${tool.name}, but you haven't granted it yet.`,
125
- }
126
- }
127
- }
128
- if (
129
- subCommands.every(subCommand => {
130
- const prefixResult =
131
- commandSubcommandPrefix.subcommandPrefixes.get(subCommand)
132
- if (prefixResult === undefined || prefixResult.commandInjectionDetected) {
133
- // If prefix result is missing or command injection is detected, always ask for permission
134
- return false
135
- }
136
- const hasPermission = bashToolCommandHasPermission(
137
- tool,
138
- subCommand,
139
- prefixResult ? prefixResult.commandPrefix : null,
140
- allowedTools,
141
- )
142
- return hasPermission
143
- })
144
- ) {
145
- return { result: true }
146
- }
147
- return {
148
- result: false,
149
- message: `${PRODUCT_NAME} requested permissions to use ${tool.name}, but you haven't granted it yet.`,
150
- }
151
- }
152
-
153
- type PermissionResult = { result: true } | { result: false; message: string }
154
-
155
- export const hasPermissionsToUseTool: CanUseToolFn = async (
156
- tool,
157
- input,
158
- context,
159
- _assistantMessage,
160
- ): Promise<PermissionResult> => {
161
- // If safe mode is not enabled, allow all tools (permissive by default)
162
- if (!context.options.safeMode) {
163
- return { result: true }
164
- }
165
-
166
- if (context.abortController.signal.aborted) {
167
- throw new AbortError()
168
- }
169
-
170
- // Check if the tool needs permissions
171
- try {
172
- if (!tool.needsPermissions(input as never)) {
173
- return { result: true }
174
- }
175
- } catch (e) {
176
- logError(`Error checking permissions: ${e}`)
177
- return { result: false, message: 'Error checking permissions' }
178
- }
179
-
180
- const projectConfig = getCurrentProjectConfig()
181
- const allowedTools = projectConfig.allowedTools ?? []
182
- // Special case for BashTool to allow blanket commands without exposing them in the UI
183
- if (tool === BashTool && allowedTools.includes(BashTool.name)) {
184
- return { result: true }
185
- }
186
-
187
- // TODO: Move this into tool definitions (done for read tools!)
188
- switch (tool) {
189
- // For bash tool, check each sub-command's permissions separately
190
- case BashTool: {
191
- // The types have already been validated by the tool,
192
- // so we can safely parse the input (as opposed to safeParse).
193
- const { command } = inputSchema.parse(input)
194
- return await bashToolHasPermission(tool, command, context, allowedTools)
195
- }
196
- // For file editing tools, check session-only permissions
197
- case FileEditTool:
198
- case FileWriteTool:
199
- case NotebookEditTool: {
200
- // The types have already been validated by the tool,
201
- // so we can safely pass this in
202
- if (!tool.needsPermissions(input)) {
203
- return { result: true }
204
- }
205
- return {
206
- result: false,
207
- message: `${PRODUCT_NAME} requested permissions to use ${tool.name}, but you haven't granted it yet.`,
208
- }
209
- }
210
- // For other tools, check persistent permissions
211
- default: {
212
- const permissionKey = getPermissionKey(tool, input, null)
213
- if (allowedTools.includes(permissionKey)) {
214
- return { result: true }
215
- }
216
-
217
- return {
218
- result: false,
219
- message: `${PRODUCT_NAME} requested permissions to use ${tool.name}, but you haven't granted it yet.`,
220
- }
221
- }
222
- }
223
- }
224
-
225
- export async function savePermission(
226
- tool: Tool,
227
- input: { [k: string]: unknown },
228
- prefix: string | null,
229
- ): Promise<void> {
230
- const key = getPermissionKey(tool, input, prefix)
231
-
232
- // For file editing tools, store write permissions only in memory
233
- if (
234
- tool === FileEditTool ||
235
- tool === FileWriteTool ||
236
- tool === NotebookEditTool
237
- ) {
238
- grantWritePermissionForOriginalDir()
239
- return
240
- }
241
-
242
- // For other tools, store permissions on disk
243
- const projectConfig = getCurrentProjectConfig()
244
- if (projectConfig.allowedTools.includes(key)) {
245
- return
246
- }
247
-
248
- projectConfig.allowedTools.push(key)
249
- projectConfig.allowedTools.sort()
250
-
251
- saveCurrentProjectConfig(projectConfig)
252
- }
253
-
254
- function getPermissionKey(
255
- tool: Tool,
256
- input: { [k: string]: unknown },
257
- prefix: string | null,
258
- ): string {
259
- switch (tool) {
260
- case BashTool:
261
- if (prefix) {
262
- return `${BashTool.name}(${prefix}:*)`
263
- }
264
- return `${BashTool.name}(${BashTool.renderToolUseMessage(input as never)})`
265
- default:
266
- return tool.name
267
- }
268
- }