source dump of claude code
at main 290 lines 32 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import { homedir } from 'os'; 3import React from 'react'; 4import { logEvent } from 'src/services/analytics/index.js'; 5import { setSessionTrustAccepted } from '../../bootstrap/state.js'; 6import type { Command } from '../../commands.js'; 7import { useExitOnCtrlCDWithKeybindings } from '../../hooks/useExitOnCtrlCDWithKeybindings.js'; 8import { Box, Link, Text } from '../../ink.js'; 9import { useKeybinding } from '../../keybindings/useKeybinding.js'; 10import { getMcpConfigsByScope } from '../../services/mcp/config.js'; 11import { BASH_TOOL_NAME } from '../../tools/BashTool/toolName.js'; 12import { checkHasTrustDialogAccepted, saveCurrentProjectConfig } from '../../utils/config.js'; 13import { getCwd } from '../../utils/cwd.js'; 14import { getFsImplementation } from '../../utils/fsOperations.js'; 15import { gracefulShutdownSync } from '../../utils/gracefulShutdown.js'; 16import { Select } from '../CustomSelect/index.js'; 17import { PermissionDialog } from '../permissions/PermissionDialog.js'; 18import { getApiKeyHelperSources, getAwsCommandsSources, getBashPermissionSources, getDangerousEnvVarsSources, getGcpCommandsSources, getHooksSources, getOtelHeadersHelperSources } from './utils.js'; 19type Props = { 20 onDone(): void; 21 commands?: Command[]; 22}; 23export function TrustDialog(t0) { 24 const $ = _c(33); 25 const { 26 onDone, 27 commands 28 } = t0; 29 let t1; 30 if ($[0] === Symbol.for("react.memo_cache_sentinel")) { 31 t1 = getMcpConfigsByScope("project"); 32 $[0] = t1; 33 } else { 34 t1 = $[0]; 35 } 36 const { 37 servers: projectServers 38 } = t1; 39 let t2; 40 if ($[1] === Symbol.for("react.memo_cache_sentinel")) { 41 t2 = Object.keys(projectServers); 42 $[1] = t2; 43 } else { 44 t2 = $[1]; 45 } 46 const hasMcpServers = t2.length > 0; 47 let t3; 48 if ($[2] === Symbol.for("react.memo_cache_sentinel")) { 49 t3 = getHooksSources(); 50 $[2] = t3; 51 } else { 52 t3 = $[2]; 53 } 54 const hooksSettingSources = t3; 55 const hasHooks = hooksSettingSources.length > 0; 56 let t4; 57 if ($[3] === Symbol.for("react.memo_cache_sentinel")) { 58 t4 = getBashPermissionSources(); 59 $[3] = t4; 60 } else { 61 t4 = $[3]; 62 } 63 const bashSettingSources = t4; 64 let t5; 65 if ($[4] === Symbol.for("react.memo_cache_sentinel")) { 66 t5 = getApiKeyHelperSources(); 67 $[4] = t5; 68 } else { 69 t5 = $[4]; 70 } 71 const apiKeyHelperSources = t5; 72 const hasApiKeyHelper = apiKeyHelperSources.length > 0; 73 let t6; 74 if ($[5] === Symbol.for("react.memo_cache_sentinel")) { 75 t6 = getAwsCommandsSources(); 76 $[5] = t6; 77 } else { 78 t6 = $[5]; 79 } 80 const awsCommandsSources = t6; 81 const hasAwsCommands = awsCommandsSources.length > 0; 82 let t7; 83 if ($[6] === Symbol.for("react.memo_cache_sentinel")) { 84 t7 = getGcpCommandsSources(); 85 $[6] = t7; 86 } else { 87 t7 = $[6]; 88 } 89 const gcpCommandsSources = t7; 90 const hasGcpCommands = gcpCommandsSources.length > 0; 91 let t8; 92 if ($[7] === Symbol.for("react.memo_cache_sentinel")) { 93 t8 = getOtelHeadersHelperSources(); 94 $[7] = t8; 95 } else { 96 t8 = $[7]; 97 } 98 const otelHeadersHelperSources = t8; 99 const hasOtelHeadersHelper = otelHeadersHelperSources.length > 0; 100 let t9; 101 if ($[8] === Symbol.for("react.memo_cache_sentinel")) { 102 t9 = getDangerousEnvVarsSources(); 103 $[8] = t9; 104 } else { 105 t9 = $[8]; 106 } 107 const dangerousEnvVarsSources = t9; 108 const hasDangerousEnvVars = dangerousEnvVarsSources.length > 0; 109 let t10; 110 if ($[9] !== commands) { 111 t10 = commands?.some(_temp2) ?? false; 112 $[9] = commands; 113 $[10] = t10; 114 } else { 115 t10 = $[10]; 116 } 117 const hasSlashCommandBash = t10; 118 let t11; 119 if ($[11] !== commands) { 120 t11 = commands?.some(_temp4) ?? false; 121 $[11] = commands; 122 $[12] = t11; 123 } else { 124 t11 = $[12]; 125 } 126 const hasSkillsBash = t11; 127 const hasAnyBashExecution = bashSettingSources.length > 0 || hasSlashCommandBash || hasSkillsBash; 128 const hasTrustDialogAccepted = checkHasTrustDialogAccepted(); 129 let t12; 130 let t13; 131 if ($[13] !== hasAnyBashExecution) { 132 t12 = () => { 133 const isHomeDir = homedir() === getCwd(); 134 logEvent("tengu_trust_dialog_shown", { 135 isHomeDir, 136 hasMcpServers, 137 hasHooks, 138 hasBashExecution: hasAnyBashExecution, 139 hasApiKeyHelper, 140 hasAwsCommands, 141 hasGcpCommands, 142 hasOtelHeadersHelper, 143 hasDangerousEnvVars 144 }); 145 }; 146 t13 = [hasMcpServers, hasHooks, hasAnyBashExecution, hasApiKeyHelper, hasAwsCommands, hasGcpCommands, hasOtelHeadersHelper, hasDangerousEnvVars]; 147 $[13] = hasAnyBashExecution; 148 $[14] = t12; 149 $[15] = t13; 150 } else { 151 t12 = $[14]; 152 t13 = $[15]; 153 } 154 React.useEffect(t12, t13); 155 let t14; 156 if ($[16] !== hasAnyBashExecution || $[17] !== onDone) { 157 t14 = function onChange(value) { 158 if (value === "exit") { 159 gracefulShutdownSync(1); 160 return; 161 } 162 const isHomeDir_0 = homedir() === getCwd(); 163 logEvent("tengu_trust_dialog_accept", { 164 isHomeDir: isHomeDir_0, 165 hasMcpServers, 166 hasHooks, 167 hasBashExecution: hasAnyBashExecution, 168 hasApiKeyHelper, 169 hasAwsCommands, 170 hasGcpCommands, 171 hasOtelHeadersHelper, 172 hasDangerousEnvVars 173 }); 174 if (isHomeDir_0) { 175 setSessionTrustAccepted(true); 176 } else { 177 saveCurrentProjectConfig(_temp5); 178 } 179 onDone(); 180 }; 181 $[16] = hasAnyBashExecution; 182 $[17] = onDone; 183 $[18] = t14; 184 } else { 185 t14 = $[18]; 186 } 187 const onChange = t14; 188 const exitState = useExitOnCtrlCDWithKeybindings(_temp6); 189 let t15; 190 if ($[19] === Symbol.for("react.memo_cache_sentinel")) { 191 t15 = { 192 context: "Confirmation" 193 }; 194 $[19] = t15; 195 } else { 196 t15 = $[19]; 197 } 198 useKeybinding("confirm:no", _temp7, t15); 199 if (hasTrustDialogAccepted) { 200 setTimeout(onDone); 201 return null; 202 } 203 let t16; 204 let t17; 205 let t18; 206 if ($[20] === Symbol.for("react.memo_cache_sentinel")) { 207 t16 = <Text bold={true}>{getFsImplementation().cwd()}</Text>; 208 t17 = <Text>Quick safety check: Is this a project you created or one you trust? (Like your own code, a well-known open source project, or work from your team). If not, take a moment to review what{"'"}s in this folder first.</Text>; 209 t18 = <Text>Claude Code{"'"}ll be able to read, edit, and execute files here.</Text>; 210 $[20] = t16; 211 $[21] = t17; 212 $[22] = t18; 213 } else { 214 t16 = $[20]; 215 t17 = $[21]; 216 t18 = $[22]; 217 } 218 let t19; 219 if ($[23] === Symbol.for("react.memo_cache_sentinel")) { 220 t19 = <Text dimColor={true}><Link url="https://code.claude.com/docs/en/security">Security guide</Link></Text>; 221 $[23] = t19; 222 } else { 223 t19 = $[23]; 224 } 225 let t20; 226 if ($[24] === Symbol.for("react.memo_cache_sentinel")) { 227 t20 = [{ 228 label: "Yes, I trust this folder", 229 value: "enable_all" 230 }, { 231 label: "No, exit", 232 value: "exit" 233 }]; 234 $[24] = t20; 235 } else { 236 t20 = $[24]; 237 } 238 let t21; 239 if ($[25] !== onChange) { 240 t21 = <Select options={t20} onChange={value_0 => onChange(value_0 as 'enable_all' | 'exit')} onCancel={() => onChange("exit")} />; 241 $[25] = onChange; 242 $[26] = t21; 243 } else { 244 t21 = $[26]; 245 } 246 let t22; 247 if ($[27] !== exitState.keyName || $[28] !== exitState.pending) { 248 t22 = <Text dimColor={true}>{exitState.pending ? <>Press {exitState.keyName} again to exit</> : <>Enter to confirm · Esc to cancel</>}</Text>; 249 $[27] = exitState.keyName; 250 $[28] = exitState.pending; 251 $[29] = t22; 252 } else { 253 t22 = $[29]; 254 } 255 let t23; 256 if ($[30] !== t21 || $[31] !== t22) { 257 t23 = <PermissionDialog color="warning" titleColor="warning" title="Accessing workspace:"><Box flexDirection="column" gap={1} paddingTop={1}>{t16}{t17}{t18}{t19}{t21}{t22}</Box></PermissionDialog>; 258 $[30] = t21; 259 $[31] = t22; 260 $[32] = t23; 261 } else { 262 t23 = $[32]; 263 } 264 return t23; 265} 266function _temp7() { 267 gracefulShutdownSync(0); 268} 269function _temp6() { 270 return gracefulShutdownSync(1); 271} 272function _temp5(current) { 273 return { 274 ...current, 275 hasTrustDialogAccepted: true 276 }; 277} 278function _temp4(command_0) { 279 return command_0.type === "prompt" && (command_0.loadedFrom === "skills" || command_0.loadedFrom === "plugin") && (command_0.source === "projectSettings" || command_0.source === "localSettings" || command_0.source === "plugin") && command_0.allowedTools?.some(_temp3); 280} 281function _temp3(tool_0) { 282 return tool_0 === BASH_TOOL_NAME || tool_0.startsWith(BASH_TOOL_NAME + "("); 283} 284function _temp2(command) { 285 return command.type === "prompt" && command.loadedFrom === "commands_DEPRECATED" && (command.source === "projectSettings" || command.source === "localSettings") && command.allowedTools?.some(_temp); 286} 287function _temp(tool) { 288 return tool === BASH_TOOL_NAME || tool.startsWith(BASH_TOOL_NAME + "("); 289} 290//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["homedir","React","logEvent","setSessionTrustAccepted","Command","useExitOnCtrlCDWithKeybindings","Box","Link","Text","useKeybinding","getMcpConfigsByScope","BASH_TOOL_NAME","checkHasTrustDialogAccepted","saveCurrentProjectConfig","getCwd","getFsImplementation","gracefulShutdownSync","Select","PermissionDialog","getApiKeyHelperSources","getAwsCommandsSources","getBashPermissionSources","getDangerousEnvVarsSources","getGcpCommandsSources","getHooksSources","getOtelHeadersHelperSources","Props","onDone","commands","TrustDialog","t0","$","_c","t1","Symbol","for","servers","projectServers","t2","Object","keys","hasMcpServers","length","t3","hooksSettingSources","hasHooks","t4","bashSettingSources","t5","apiKeyHelperSources","hasApiKeyHelper","t6","awsCommandsSources","hasAwsCommands","t7","gcpCommandsSources","hasGcpCommands","t8","otelHeadersHelperSources","hasOtelHeadersHelper","t9","dangerousEnvVarsSources","hasDangerousEnvVars","t10","some","_temp2","hasSlashCommandBash","t11","_temp4","hasSkillsBash","hasAnyBashExecution","hasTrustDialogAccepted","t12","t13","isHomeDir","hasBashExecution","useEffect","t14","onChange","value","isHomeDir_0","_temp5","exitState","_temp6","t15","context","_temp7","setTimeout","t16","t17","t18","cwd","t19","t20","label","t21","value_0","t22","keyName","pending","t23","current","command_0","command","type","loadedFrom","source","allowedTools","_temp3","tool_0","tool","startsWith","_temp"],"sources":["TrustDialog.tsx"],"sourcesContent":["import { homedir } from 'os'\nimport React from 'react'\nimport { logEvent } from 'src/services/analytics/index.js'\nimport { setSessionTrustAccepted } from '../../bootstrap/state.js'\nimport type { Command } from '../../commands.js'\nimport { useExitOnCtrlCDWithKeybindings } from '../../hooks/useExitOnCtrlCDWithKeybindings.js'\nimport { Box, Link, Text } from '../../ink.js'\nimport { useKeybinding } from '../../keybindings/useKeybinding.js'\nimport { getMcpConfigsByScope } from '../../services/mcp/config.js'\nimport { BASH_TOOL_NAME } from '../../tools/BashTool/toolName.js'\nimport {\n  checkHasTrustDialogAccepted,\n  saveCurrentProjectConfig,\n} from '../../utils/config.js'\nimport { getCwd } from '../../utils/cwd.js'\nimport { getFsImplementation } from '../../utils/fsOperations.js'\nimport { gracefulShutdownSync } from '../../utils/gracefulShutdown.js'\nimport { Select } from '../CustomSelect/index.js'\nimport { PermissionDialog } from '../permissions/PermissionDialog.js'\nimport {\n  getApiKeyHelperSources,\n  getAwsCommandsSources,\n  getBashPermissionSources,\n  getDangerousEnvVarsSources,\n  getGcpCommandsSources,\n  getHooksSources,\n  getOtelHeadersHelperSources,\n} from './utils.js'\n\ntype Props = {\n  onDone(): void\n  commands?: Command[]\n}\n\nexport function TrustDialog({ onDone, commands }: Props): React.ReactNode {\n  const { servers: projectServers } = getMcpConfigsByScope('project')\n\n  // In all cases, we generally check only the project-level and\n  // project-local-level settings, which we assume that users do not configure\n  // directly compared to user-level settings.\n\n  // Check for MCPs\n  const hasMcpServers = Object.keys(projectServers).length > 0\n  // Check for hooks\n  const hooksSettingSources = getHooksSources()\n  const hasHooks = hooksSettingSources.length > 0\n  // Check whether code execution is allowed in permissions and slash commands\n  const bashSettingSources = getBashPermissionSources()\n  // Check for apiKeyHelper which executes arbitrary commands\n  const apiKeyHelperSources = getApiKeyHelperSources()\n  const hasApiKeyHelper = apiKeyHelperSources.length > 0\n  // Check for AWS commands which execute arbitrary commands\n  const awsCommandsSources = getAwsCommandsSources()\n  const hasAwsCommands = awsCommandsSources.length > 0\n  // Check for GCP commands which execute arbitrary commands\n  const gcpCommandsSources = getGcpCommandsSources()\n  const hasGcpCommands = gcpCommandsSources.length > 0\n  // Check for otelHeadersHelper which executes arbitrary commands\n  const otelHeadersHelperSources = getOtelHeadersHelperSources()\n  const hasOtelHeadersHelper = otelHeadersHelperSources.length > 0\n  // Check for dangerous environment variables (not in SAFE_ENV_VARS)\n  const dangerousEnvVarsSources = getDangerousEnvVarsSources()\n  const hasDangerousEnvVars = dangerousEnvVarsSources.length > 0\n\n  const hasSlashCommandBash =\n    commands?.some(\n      command =>\n        command.type === 'prompt' &&\n        command.loadedFrom === 'commands_DEPRECATED' &&\n        (command.source === 'projectSettings' ||\n          command.source === 'localSettings') &&\n        command.allowedTools?.some(\n          (tool: string) =>\n            tool === BASH_TOOL_NAME || tool.startsWith(BASH_TOOL_NAME + '('),\n        ),\n    ) ?? false\n\n  const hasSkillsBash =\n    commands?.some(\n      command =>\n        command.type === 'prompt' &&\n        (command.loadedFrom === 'skills' || command.loadedFrom === 'plugin') &&\n        (command.source === 'projectSettings' ||\n          command.source === 'localSettings' ||\n          command.source === 'plugin') &&\n        command.allowedTools?.some(\n          (tool: string) =>\n            tool === BASH_TOOL_NAME || tool.startsWith(BASH_TOOL_NAME + '('),\n        ),\n    ) ?? false\n\n  const hasAnyBashExecution =\n    bashSettingSources.length > 0 || hasSlashCommandBash || hasSkillsBash\n\n  const hasTrustDialogAccepted = checkHasTrustDialogAccepted()\n\n  React.useEffect(() => {\n    const isHomeDir = homedir() === getCwd()\n    logEvent('tengu_trust_dialog_shown', {\n      isHomeDir,\n      hasMcpServers,\n      hasHooks,\n      hasBashExecution: hasAnyBashExecution,\n      hasApiKeyHelper,\n      hasAwsCommands,\n      hasGcpCommands,\n      hasOtelHeadersHelper,\n      hasDangerousEnvVars,\n    })\n  }, [\n    hasMcpServers,\n    hasHooks,\n    hasAnyBashExecution,\n    hasApiKeyHelper,\n    hasAwsCommands,\n    hasGcpCommands,\n    hasOtelHeadersHelper,\n    hasDangerousEnvVars,\n  ])\n\n  function onChange(value: 'enable_all' | 'exit') {\n    if (value === 'exit') {\n      gracefulShutdownSync(1)\n      return\n    }\n\n    const isHomeDir = homedir() === getCwd()\n\n    logEvent('tengu_trust_dialog_accept', {\n      isHomeDir,\n      hasMcpServers,\n      hasHooks,\n      hasBashExecution: hasAnyBashExecution,\n      hasApiKeyHelper,\n      hasAwsCommands,\n      hasGcpCommands,\n      hasOtelHeadersHelper,\n      hasDangerousEnvVars,\n    })\n\n    if (isHomeDir) {\n      // For home directory, store trust in session memory only (not persisted to disk)\n      // This allows hooks and other trust-requiring features to work during this session\n      // while preserving the security intent of not permanently trusting home dir\n      setSessionTrustAccepted(true)\n    } else {\n      saveCurrentProjectConfig(current => ({\n        ...current,\n        hasTrustDialogAccepted: true,\n      }))\n    }\n\n    // Do NOT write MCP server settings here. handleMcpjsonServerApprovals in\n    // interactiveHelpers.tsx runs right after this dialog and shows the per-server approval\n    // UI. Writing enabledMcpjsonServers/enableAllProjectMcpServers here would\n    // mark every server 'approved' and silently skip that dialog. See #15558.\n\n    onDone()\n  }\n\n  // Default onExit is useApp().exit() → Ink.unmount(), which tears down the\n  // React tree but never calls onDone(). showSetupScreens() in\n  // interactiveHelpers.tsx awaits a Promise that only resolves via onDone,\n  // so the default would hang the await forever. With keybinding\n  // customization enabled, the chokidar watcher (persistent: true) keeps the\n  // event loop alive and the process freezes. Explicitly exit 1 like \"No\".\n  const exitState = useExitOnCtrlCDWithKeybindings(() =>\n    gracefulShutdownSync(1),\n  )\n\n  // Use configurable keybinding for ESC to cancel/exit\n  useKeybinding(\n    'confirm:no',\n    () => {\n      gracefulShutdownSync(0)\n    },\n    { context: 'Confirmation' },\n  )\n\n  // Automatically resolve the trust dialog if there is nothing to be shown.\n  if (hasTrustDialogAccepted) {\n    setTimeout(onDone)\n    return null\n  }\n\n  return (\n    <PermissionDialog\n      color=\"warning\"\n      titleColor=\"warning\"\n      title=\"Accessing workspace:\"\n    >\n      <Box flexDirection=\"column\" gap={1} paddingTop={1}>\n        <Text bold>{getFsImplementation().cwd()}</Text>\n\n        <Text>\n          Quick safety check: Is this a project you created or one you trust?\n          (Like your own code, a well-known open source project, or work from\n          your team). If not, take a moment to review what{\"'\"}s in this folder\n          first.\n        </Text>\n        <Text>\n          Claude Code{\"'\"}ll be able to read, edit, and execute files here.\n        </Text>\n\n        <Text dimColor>\n          <Link url=\"https://code.claude.com/docs/en/security\">\n            Security guide\n          </Link>\n        </Text>\n\n        <Select\n          options={[\n            { label: 'Yes, I trust this folder', value: 'enable_all' },\n            { label: 'No, exit', value: 'exit' },\n          ]}\n          onChange={value => onChange(value as 'enable_all' | 'exit')}\n          onCancel={() => onChange('exit')}\n        />\n\n        <Text dimColor>\n          {exitState.pending ? (\n            <>Press {exitState.keyName} again to exit</>\n          ) : (\n            <>Enter to confirm · Esc to cancel</>\n          )}\n        </Text>\n      </Box>\n    </PermissionDialog>\n  )\n}\n"],"mappings":"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","ignoreList":[]}