sandbox-toggle.tsx
commands/sandbox-toggle/sandbox-toggle.tsx
83
Lines
13157
Bytes
1
Exports
9
Imports
10
Keywords
What this is
This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.
Beginner explanation
This file lives in the command layer. It likely turns a user action into concrete program behavior.
How it is used
Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.
Expert explanation
Architecturally, this file intersects with shell-safety, commands. It contains 83 lines, 9 detected imports, and 1 detected exports.
Important relationships
Detected exports
call
Keywords
messagethemenamesettingsondonecolorsubcommandplatformexcludesandboxsandboxmanager
Detected imports
pathreact../../bootstrap/state.js../../components/sandbox/SandboxSettings.js../../ink.js../../utils/platform.js../../utils/sandbox/sandbox-adapter.js../../utils/settings/settings.js../../utils/theme.js
Source notes
This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.
Full source
import { relative } from 'path';
import React from 'react';
import { getCwdState } from '../../bootstrap/state.js';
import { SandboxSettings } from '../../components/sandbox/SandboxSettings.js';
import { color } from '../../ink.js';
import { getPlatform } from '../../utils/platform.js';
import { addToExcludedCommands, SandboxManager } from '../../utils/sandbox/sandbox-adapter.js';
import { getSettings_DEPRECATED, getSettingsFilePathForSource } from '../../utils/settings/settings.js';
import type { ThemeName } from '../../utils/theme.js';
export async function call(onDone: (result?: string) => void, _context: unknown, args?: string): Promise<React.ReactNode | null> {
const settings = getSettings_DEPRECATED();
const themeName: ThemeName = settings.theme as ThemeName || 'light';
const platform = getPlatform();
if (!SandboxManager.isSupportedPlatform()) {
// WSL1 users will see this since isSupportedPlatform returns false for WSL1
const errorMessage = platform === 'wsl' ? 'Error: Sandboxing requires WSL2. WSL1 is not supported.' : 'Error: Sandboxing is currently only supported on macOS, Linux, and WSL2.';
const message = color('error', themeName)(errorMessage);
onDone(message);
return null;
}
// Check dependencies - get structured result with errors/warnings
const depCheck = SandboxManager.checkDependencies();
// Check if platform is in enabledPlatforms list (undocumented enterprise setting)
if (!SandboxManager.isPlatformInEnabledList()) {
const message = color('error', themeName)(`Error: Sandboxing is disabled for this platform (${platform}) via the enabledPlatforms setting.`);
onDone(message);
return null;
}
// Check if sandbox settings are locked by higher-priority settings
if (SandboxManager.areSandboxSettingsLockedByPolicy()) {
const message = color('error', themeName)('Error: Sandbox settings are overridden by a higher-priority configuration and cannot be changed locally.');
onDone(message);
return null;
}
// Parse the arguments
const trimmedArgs = args?.trim() || '';
// If no args, show the interactive menu
if (!trimmedArgs) {
return <SandboxSettings onComplete={onDone} depCheck={depCheck} />;
}
// Handle subcommands
if (trimmedArgs) {
const parts = trimmedArgs.split(' ');
const subcommand = parts[0];
if (subcommand === 'exclude') {
// Handle exclude subcommand
const commandPattern = trimmedArgs.slice('exclude '.length).trim();
if (!commandPattern) {
const message = color('error', themeName)('Error: Please provide a command pattern to exclude (e.g., /sandbox exclude "npm run test:*")');
onDone(message);
return null;
}
// Remove quotes if present
const cleanPattern = commandPattern.replace(/^["']|["']$/g, '');
// Add to excludedCommands
addToExcludedCommands(cleanPattern);
// Get the local settings path and make it relative to cwd
const localSettingsPath = getSettingsFilePathForSource('localSettings');
const relativePath = localSettingsPath ? relative(getCwdState(), localSettingsPath) : '.claude/settings.local.json';
const message = color('success', themeName)(`Added "${cleanPattern}" to excluded commands in ${relativePath}`);
onDone(message);
return null;
} else {
// Unknown subcommand
const message = color('error', themeName)(`Error: Unknown subcommand "${subcommand}". Available subcommand: exclude`);
onDone(message);
return null;
}
}
// Should never reach here since we handle all cases above
return null;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["relative","React","getCwdState","SandboxSettings","color","getPlatform","addToExcludedCommands","SandboxManager","getSettings_DEPRECATED","getSettingsFilePathForSource","ThemeName","call","onDone","result","_context","args","Promise","ReactNode","settings","themeName","theme","platform","isSupportedPlatform","errorMessage","message","depCheck","checkDependencies","isPlatformInEnabledList","areSandboxSettingsLockedByPolicy","trimmedArgs","trim","parts","split","subcommand","commandPattern","slice","length","cleanPattern","replace","localSettingsPath","relativePath"],"sources":["sandbox-toggle.tsx"],"sourcesContent":["import { relative } from 'path'\nimport React from 'react'\nimport { getCwdState } from '../../bootstrap/state.js'\nimport { SandboxSettings } from '../../components/sandbox/SandboxSettings.js'\nimport { color } from '../../ink.js'\nimport { getPlatform } from '../../utils/platform.js'\nimport {\n  addToExcludedCommands,\n  SandboxManager,\n} from '../../utils/sandbox/sandbox-adapter.js'\nimport {\n  getSettings_DEPRECATED,\n  getSettingsFilePathForSource,\n} from '../../utils/settings/settings.js'\nimport type { ThemeName } from '../../utils/theme.js'\n\nexport async function call(\n  onDone: (result?: string) => void,\n  _context: unknown,\n  args?: string,\n): Promise<React.ReactNode | null> {\n  const settings = getSettings_DEPRECATED()\n  const themeName: ThemeName = (settings.theme as ThemeName) || 'light'\n\n  const platform = getPlatform()\n\n  if (!SandboxManager.isSupportedPlatform()) {\n    // WSL1 users will see this since isSupportedPlatform returns false for WSL1\n    const errorMessage =\n      platform === 'wsl'\n        ? 'Error: Sandboxing requires WSL2. WSL1 is not supported.'\n        : 'Error: Sandboxing is currently only supported on macOS, Linux, and WSL2.'\n    const message = color('error', themeName)(errorMessage)\n    onDone(message)\n    return null\n  }\n\n  // Check dependencies - get structured result with errors/warnings\n  const depCheck = SandboxManager.checkDependencies()\n\n  // Check if platform is in enabledPlatforms list (undocumented enterprise setting)\n  if (!SandboxManager.isPlatformInEnabledList()) {\n    const message = color(\n      'error',\n      themeName,\n    )(\n      `Error: Sandboxing is disabled for this platform (${platform}) via the enabledPlatforms setting.`,\n    )\n    onDone(message)\n    return null\n  }\n\n  // Check if sandbox settings are locked by higher-priority settings\n  if (SandboxManager.areSandboxSettingsLockedByPolicy()) {\n    const message = color(\n      'error',\n      themeName,\n    )(\n      'Error: Sandbox settings are overridden by a higher-priority configuration and cannot be changed locally.',\n    )\n    onDone(message)\n    return null\n  }\n\n  // Parse the arguments\n  const trimmedArgs = args?.trim() || ''\n\n  // If no args, show the interactive menu\n  if (!trimmedArgs) {\n    return <SandboxSettings onComplete={onDone} depCheck={depCheck} />\n  }\n\n  // Handle subcommands\n  if (trimmedArgs) {\n    const parts = trimmedArgs.split(' ')\n    const subcommand = parts[0]\n\n    if (subcommand === 'exclude') {\n      // Handle exclude subcommand\n      const commandPattern = trimmedArgs.slice('exclude '.length).trim()\n\n      if (!commandPattern) {\n        const message = color(\n          'error',\n          themeName,\n        )(\n          'Error: Please provide a command pattern to exclude (e.g., /sandbox exclude \"npm run test:*\")',\n        )\n        onDone(message)\n        return null\n      }\n\n      // Remove quotes if present\n      const cleanPattern = commandPattern.replace(/^[\"']|[\"']$/g, '')\n\n      // Add to excludedCommands\n      addToExcludedCommands(cleanPattern)\n\n      // Get the local settings path and make it relative to cwd\n      const localSettingsPath = getSettingsFilePathForSource('localSettings')\n      const relativePath = localSettingsPath\n        ? relative(getCwdState(), localSettingsPath)\n        : '.claude/settings.local.json'\n\n      const message = color(\n        'success',\n        themeName,\n      )(`Added \"${cleanPattern}\" to excluded commands in ${relativePath}`)\n\n      onDone(message)\n      return null\n    } else {\n      // Unknown subcommand\n      const message = color(\n        'error',\n        themeName,\n      )(\n        `Error: Unknown subcommand \"${subcommand}\". Available subcommand: exclude`,\n      )\n      onDone(message)\n      return null\n    }\n  }\n\n  // Should never reach here since we handle all cases above\n  return null\n}\n"],"mappings":"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","ignoreList":[]}