@terminai/core 0.21.0 → 0.25.0
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/docs/assets/image.png +0 -0
- package/dist/src/audit/redaction.js +24 -0
- package/dist/src/audit/redaction.js.map +1 -1
- package/dist/src/audit/redaction.test.d.ts +7 -0
- package/dist/src/audit/redaction.test.js +45 -0
- package/dist/src/audit/redaction.test.js.map +1 -0
- package/dist/src/auth/geminiAuthStatus.js +1 -1
- package/dist/src/auth/geminiAuthStatus.js.map +1 -1
- package/dist/src/auth/geminiAuthStatus.test.js +1 -1
- package/dist/src/auth/geminiAuthStatus.test.js.map +1 -1
- package/dist/src/auth/providerRegistry.js +20 -0
- package/dist/src/auth/providerRegistry.js.map +1 -1
- package/dist/src/auth/wizardSettings.d.ts +5 -0
- package/dist/src/auth/wizardSettings.js +48 -1
- package/dist/src/auth/wizardSettings.js.map +1 -1
- package/dist/src/auth/wizardSettings.test.js +30 -2
- package/dist/src/auth/wizardSettings.test.js.map +1 -1
- package/dist/src/auth/wizardState.d.ts +1 -1
- package/dist/src/auth/wizardState.js +6 -0
- package/dist/src/auth/wizardState.js.map +1 -1
- package/dist/src/auth/wizardState.test.js +23 -0
- package/dist/src/auth/wizardState.test.js.map +1 -1
- package/dist/src/availability/policyHelpers.test.js +4 -4
- package/dist/src/availability/policyHelpers.test.js.map +1 -1
- package/dist/src/brain/__tests__/environmentDetector.test.js +2 -1
- package/dist/src/brain/__tests__/environmentDetector.test.js.map +1 -1
- package/dist/src/brain/__tests__/orchestratorFlag.test.d.ts +7 -0
- package/dist/src/brain/__tests__/orchestratorFlag.test.js +47 -0
- package/dist/src/brain/__tests__/orchestratorFlag.test.js.map +1 -0
- package/dist/src/brain/__tests__/orchestratorRecovery.test.d.ts +7 -0
- package/dist/src/brain/__tests__/orchestratorRecovery.test.js +85 -0
- package/dist/src/brain/__tests__/orchestratorRecovery.test.js.map +1 -0
- package/dist/src/brain/__tests__/thinkingOrchestrator.test.js +1 -0
- package/dist/src/brain/__tests__/thinkingOrchestrator.test.js.map +1 -1
- package/dist/src/brain/__tests__/toolIntegration.test.d.ts +7 -0
- package/dist/src/brain/__tests__/toolIntegration.test.js +154 -0
- package/dist/src/brain/__tests__/toolIntegration.test.js.map +1 -0
- package/dist/src/brain/advisors/codeGenerator.js +3 -2
- package/dist/src/brain/advisors/codeGenerator.js.map +1 -1
- package/dist/src/brain/advisors/depScanner.js +3 -2
- package/dist/src/brain/advisors/depScanner.js.map +1 -1
- package/dist/src/brain/advisors/enumerator.js +3 -2
- package/dist/src/brain/advisors/enumerator.js.map +1 -1
- package/dist/src/brain/advisors/fallbackChain.js +3 -2
- package/dist/src/brain/advisors/fallbackChain.js.map +1 -1
- package/dist/src/brain/advisors/patternMatcher.js +3 -2
- package/dist/src/brain/advisors/patternMatcher.js.map +1 -1
- package/dist/src/brain/consensus.js +2 -1
- package/dist/src/brain/consensus.js.map +1 -1
- package/dist/src/brain/environmentDetector.d.ts +1 -0
- package/dist/src/brain/environmentDetector.js +35 -20
- package/dist/src/brain/environmentDetector.js.map +1 -1
- package/dist/src/brain/pacLoop.js +2 -1
- package/dist/src/brain/pacLoop.js.map +1 -1
- package/dist/src/brain/riskAssessor.d.ts +6 -2
- package/dist/src/brain/riskAssessor.js +7 -4
- package/dist/src/brain/riskAssessor.js.map +1 -1
- package/dist/src/brain/stepBackEvaluator.js +2 -1
- package/dist/src/brain/stepBackEvaluator.js.map +1 -1
- package/dist/src/brain/thinkingOrchestrator.d.ts +9 -1
- package/dist/src/brain/thinkingOrchestrator.js +47 -1
- package/dist/src/brain/thinkingOrchestrator.js.map +1 -1
- package/dist/src/brain/toolIntegration.d.ts +51 -0
- package/dist/src/brain/toolIntegration.js +202 -0
- package/dist/src/brain/toolIntegration.js.map +1 -0
- package/dist/src/code_assist/oauth2.begin.test.js +4 -1
- package/dist/src/code_assist/oauth2.begin.test.js.map +1 -1
- package/dist/src/code_assist/oauth2.d.ts +1 -1
- package/dist/src/code_assist/oauth2.js +9 -13
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/code_assist/oauth2.test.js +69 -41
- package/dist/src/code_assist/oauth2.test.js.map +1 -1
- package/dist/src/commands/init.js +5 -0
- package/dist/src/commands/init.js.map +1 -1
- package/dist/src/computer/PersistentShell.d.ts +5 -0
- package/dist/src/computer/PersistentShell.js +21 -2
- package/dist/src/computer/PersistentShell.js.map +1 -1
- package/dist/src/computer/PersistentShell.test.js +23 -11
- package/dist/src/computer/PersistentShell.test.js.map +1 -1
- package/dist/src/config/builder.js +78 -5
- package/dist/src/config/builder.js.map +1 -1
- package/dist/src/config/config.d.ts +12 -1
- package/dist/src/config/config.js +64 -0
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +39 -0
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/models.d.ts +2 -2
- package/dist/src/config/models.js +2 -2
- package/dist/src/config/models.js.map +1 -1
- package/dist/src/config/models.test.js +1 -1
- package/dist/src/config/settings/schema.d.ts +78 -4
- package/dist/src/config/settings/schema.js +76 -4
- package/dist/src/config/settings/schema.js.map +1 -1
- package/dist/src/core/chatGptCodexContentGenerator.d.ts +35 -0
- package/dist/src/core/chatGptCodexContentGenerator.js +605 -0
- package/dist/src/core/chatGptCodexContentGenerator.js.map +1 -0
- package/dist/src/core/chatGptCodexContentGenerator.test.d.ts +7 -0
- package/dist/src/core/chatGptCodexContentGenerator.test.js +250 -0
- package/dist/src/core/chatGptCodexContentGenerator.test.js.map +1 -0
- package/dist/src/core/contentGenerator.d.ts +2 -1
- package/dist/src/core/contentGenerator.js +10 -0
- package/dist/src/core/contentGenerator.js.map +1 -1
- package/dist/src/core/contentGenerator.test.js +36 -0
- package/dist/src/core/contentGenerator.test.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.d.ts +1 -0
- package/dist/src/core/loggingContentGenerator.js +30 -0
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.test.js +62 -0
- package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
- package/dist/src/core/openaiContentGenerator.d.ts +16 -0
- package/dist/src/core/openaiContentGenerator.js +252 -53
- package/dist/src/core/openaiContentGenerator.js.map +1 -1
- package/dist/src/core/openaiContentGenerator.test.js +176 -7
- package/dist/src/core/openaiContentGenerator.test.js.map +1 -1
- package/dist/src/core/providerTypes.d.ts +17 -1
- package/dist/src/core/providerTypes.js +10 -0
- package/dist/src/core/providerTypes.js.map +1 -1
- package/dist/src/core/providerTypes.test.js +11 -0
- package/dist/src/core/providerTypes.test.js.map +1 -1
- package/dist/src/core/turn.js +1 -1
- package/dist/src/core/turn.js.map +1 -1
- package/dist/src/core/turn.test.js +1 -1
- package/dist/src/core/turn.test.js.map +1 -1
- package/dist/src/fallback/handler.test.js +14 -14
- package/dist/src/fallback/handler.test.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/generated/git-commit.js.map +1 -1
- package/dist/src/gui/drivers/__tests__/sidecarContract.test.d.ts +2 -2
- package/dist/src/gui/drivers/__tests__/sidecarContract.test.js +3 -4
- package/dist/src/gui/drivers/__tests__/sidecarContract.test.js.map +1 -1
- package/dist/src/gui/drivers/linuxAtspiDriver.js +11 -4
- package/dist/src/gui/drivers/linuxAtspiDriver.js.map +1 -1
- package/dist/src/gui/drivers/windowsUiaDriver.js +2 -2
- package/dist/src/gui/drivers/windowsUiaDriver.js.map +1 -1
- package/dist/src/gui/selectors/__tests__/selectors.test.js +5 -2
- package/dist/src/gui/selectors/__tests__/selectors.test.js.map +1 -1
- package/dist/src/gui/selectors/parser.d.ts +1 -1
- package/dist/src/gui/selectors/parser.js +1 -1
- package/dist/src/gui/selectors/parser.js.map +1 -1
- package/dist/src/gui/service/DesktopAutomationService.d.ts +1 -1
- package/dist/src/gui/service/DesktopAutomationService.js +8 -9
- package/dist/src/gui/service/DesktopAutomationService.js.map +1 -1
- package/dist/src/gui/service/__tests__/capabilities.test.d.ts +6 -0
- package/dist/src/gui/service/__tests__/capabilities.test.js +32 -4
- package/dist/src/gui/service/__tests__/capabilities.test.js.map +1 -1
- package/dist/src/gui/service/__tests__/diagnose.test.d.ts +6 -0
- package/dist/src/gui/service/__tests__/diagnose.test.js +6 -0
- package/dist/src/gui/service/__tests__/diagnose.test.js.map +1 -1
- package/dist/src/gui/service/__tests__/progressive.test.d.ts +6 -0
- package/dist/src/gui/service/__tests__/progressive.test.js +30 -3
- package/dist/src/gui/service/__tests__/progressive.test.js.map +1 -1
- package/dist/src/gui/service/__tests__/redaction.test.d.ts +6 -0
- package/dist/src/gui/service/__tests__/redaction.test.js +27 -1
- package/dist/src/gui/service/__tests__/redaction.test.js.map +1 -1
- package/dist/src/gui/service/__tests__/selectorError.test.d.ts +6 -0
- package/dist/src/gui/service/__tests__/selectorError.test.js +6 -0
- package/dist/src/gui/service/__tests__/selectorError.test.js.map +1 -1
- package/dist/src/gui/service/__tests__/wait.test.d.ts +6 -0
- package/dist/src/gui/service/__tests__/wait.test.js +29 -2
- package/dist/src/gui/service/__tests__/wait.test.js.map +1 -1
- package/dist/src/index.d.ts +6 -0
- package/dist/src/index.js +7 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/openai_chatgpt/constants.d.ts +23 -0
- package/dist/src/openai_chatgpt/constants.js +35 -0
- package/dist/src/openai_chatgpt/constants.js.map +1 -0
- package/dist/src/openai_chatgpt/credentialStorage.d.ts +18 -0
- package/dist/src/openai_chatgpt/credentialStorage.js +116 -0
- package/dist/src/openai_chatgpt/credentialStorage.js.map +1 -0
- package/dist/src/openai_chatgpt/credentialStorage.test.d.ts +7 -0
- package/dist/src/openai_chatgpt/credentialStorage.test.js +73 -0
- package/dist/src/openai_chatgpt/credentialStorage.test.js.map +1 -0
- package/dist/src/openai_chatgpt/imports.d.ts +10 -0
- package/dist/src/openai_chatgpt/imports.js +164 -0
- package/dist/src/openai_chatgpt/imports.js.map +1 -0
- package/dist/src/openai_chatgpt/imports.test.d.ts +7 -0
- package/dist/src/openai_chatgpt/imports.test.js +82 -0
- package/dist/src/openai_chatgpt/imports.test.js.map +1 -0
- package/dist/src/openai_chatgpt/jwt.d.ts +7 -0
- package/dist/src/openai_chatgpt/jwt.js +31 -0
- package/dist/src/openai_chatgpt/jwt.js.map +1 -0
- package/dist/src/openai_chatgpt/jwt.test.d.ts +7 -0
- package/dist/src/openai_chatgpt/jwt.test.js +23 -0
- package/dist/src/openai_chatgpt/jwt.test.js.map +1 -0
- package/dist/src/openai_chatgpt/oauthClient.d.ts +52 -0
- package/dist/src/openai_chatgpt/oauthClient.js +196 -0
- package/dist/src/openai_chatgpt/oauthClient.js.map +1 -0
- package/dist/src/openai_chatgpt/oauthClient.test.d.ts +7 -0
- package/dist/src/openai_chatgpt/oauthClient.test.js +138 -0
- package/dist/src/openai_chatgpt/oauthClient.test.js.map +1 -0
- package/dist/src/openai_chatgpt/types.d.ts +34 -0
- package/dist/src/openai_chatgpt/types.js +8 -0
- package/dist/src/openai_chatgpt/types.js.map +1 -0
- package/dist/src/policy/shell-safety.test.js +2 -1
- package/dist/src/policy/shell-safety.test.js.map +1 -1
- package/dist/src/safety/approval-ladder/__tests__/buildShellActionProfile.test.js +2 -1
- package/dist/src/safety/approval-ladder/__tests__/buildShellActionProfile.test.js.map +1 -1
- package/dist/src/safety/built-in.test.js +4 -2
- package/dist/src/safety/built-in.test.js.map +1 -1
- package/dist/src/telemetry/metrics.test.js +95 -75
- package/dist/src/telemetry/metrics.test.js.map +1 -1
- package/dist/src/tools/__tests__/edit.risk.test.d.ts +7 -0
- package/dist/src/tools/__tests__/edit.risk.test.js +138 -0
- package/dist/src/tools/__tests__/edit.risk.test.js.map +1 -0
- package/dist/src/tools/__tests__/memoryToolDedupe.test.d.ts +7 -0
- package/dist/src/tools/__tests__/memoryToolDedupe.test.js +53 -0
- package/dist/src/tools/__tests__/memoryToolDedupe.test.js.map +1 -0
- package/dist/src/tools/__tests__/shell.pin.test.js +2 -1
- package/dist/src/tools/__tests__/shell.pin.test.js.map +1 -1
- package/dist/src/tools/__tests__/shell.provenance.test.js +14 -4
- package/dist/src/tools/__tests__/shell.provenance.test.js.map +1 -1
- package/dist/src/tools/__tests__/ui-diagnose.test.d.ts +6 -0
- package/dist/src/tools/__tests__/ui-diagnose.test.js +11 -8
- package/dist/src/tools/__tests__/ui-diagnose.test.js.map +1 -1
- package/dist/src/tools/__tests__/ui-health.test.d.ts +6 -0
- package/dist/src/tools/__tests__/ui-health.test.js +37 -37
- package/dist/src/tools/__tests__/ui-health.test.js.map +1 -1
- package/dist/src/tools/agent-control.js +6 -18
- package/dist/src/tools/agent-control.js.map +1 -1
- package/dist/src/tools/agent-control.test.js +2 -28
- package/dist/src/tools/agent-control.test.js.map +1 -1
- package/dist/src/tools/edit.js +49 -9
- package/dist/src/tools/edit.js.map +1 -1
- package/dist/src/tools/edit.test.js +1 -19
- package/dist/src/tools/edit.test.js.map +1 -1
- package/dist/src/tools/file-ops.js +9 -10
- package/dist/src/tools/file-ops.js.map +1 -1
- package/dist/src/tools/file-ops.test.js +0 -7
- package/dist/src/tools/file-ops.test.js.map +1 -1
- package/dist/src/tools/glob.js +4 -16
- package/dist/src/tools/glob.js.map +1 -1
- package/dist/src/tools/glob.test.js +0 -29
- package/dist/src/tools/glob.test.js.map +1 -1
- package/dist/src/tools/grep.js +4 -10
- package/dist/src/tools/grep.js.map +1 -1
- package/dist/src/tools/ls.d.ts +1 -1
- package/dist/src/tools/ls.js +8 -7
- package/dist/src/tools/ls.js.map +1 -1
- package/dist/src/tools/ls.test.js +0 -7
- package/dist/src/tools/ls.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.js +8 -6
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.test.js +0 -10
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
- package/dist/src/tools/memoryTool.js +10 -0
- package/dist/src/tools/memoryTool.js.map +1 -1
- package/dist/src/tools/process-manager.js +6 -5
- package/dist/src/tools/process-manager.js.map +1 -1
- package/dist/src/tools/process-manager.test.js +2 -1
- package/dist/src/tools/process-manager.test.js.map +1 -1
- package/dist/src/tools/read-file.js +8 -10
- package/dist/src/tools/read-file.js.map +1 -1
- package/dist/src/tools/read-file.test.js +0 -12
- package/dist/src/tools/read-file.test.js.map +1 -1
- package/dist/src/tools/read-many-files.js +2 -7
- package/dist/src/tools/read-many-files.js.map +1 -1
- package/dist/src/tools/repl.js +10 -45
- package/dist/src/tools/repl.js.map +1 -1
- package/dist/src/tools/ripGrep.js +2 -5
- package/dist/src/tools/ripGrep.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +1 -1
- package/dist/src/tools/ripGrep.test.js.map +1 -1
- package/dist/src/tools/shell.d.ts +2 -11
- package/dist/src/tools/shell.js +31 -191
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +2 -1
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/smart-edit.js +2 -5
- package/dist/src/tools/smart-edit.js.map +1 -1
- package/dist/src/tools/smart-edit.test.js +0 -9
- package/dist/src/tools/smart-edit.test.js.map +1 -1
- package/dist/src/tools/tools.d.ts +5 -0
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/ui-click.js +69 -3
- package/dist/src/tools/ui-click.js.map +1 -1
- package/dist/src/tools/write-file.js +34 -8
- package/dist/src/tools/write-file.js.map +1 -1
- package/dist/src/tools/write-file.test.js +1 -15
- package/dist/src/tools/write-file.test.js.map +1 -1
- package/dist/src/utils/errorReporting.js +1 -1
- package/dist/src/utils/errorReporting.js.map +1 -1
- package/dist/src/utils/errorReporting.test.js +1 -1
- package/dist/src/utils/errorReporting.test.js.map +1 -1
- package/dist/src/utils/events.d.ts +11 -0
- package/dist/src/utils/events.js +1 -0
- package/dist/src/utils/events.js.map +1 -1
- package/dist/src/utils/fileUtils.js +2 -7
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/processUtils.d.ts +43 -0
- package/dist/src/utils/processUtils.js +134 -0
- package/dist/src/utils/processUtils.js.map +1 -0
- package/dist/src/utils/shell-permissions.d.ts +1 -0
- package/dist/src/utils/shell-permissions.js +3 -3
- package/dist/src/utils/shell-permissions.js.map +1 -1
- package/dist/src/utils/shell-permissions.test.js +11 -5
- package/dist/src/utils/shell-permissions.test.js.map +1 -1
- package/dist/src/utils/shell-utils.js +6 -3
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/shell-utils.test.js +6 -2
- package/dist/src/utils/shell-utils.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -3
|
@@ -32,43 +32,58 @@ function gatherSignals() {
|
|
|
32
32
|
user: os.userInfo().username,
|
|
33
33
|
};
|
|
34
34
|
}
|
|
35
|
+
let cachedEnvironment = null;
|
|
36
|
+
let lastCheck = 0;
|
|
37
|
+
const CACHE_TTL_MS = 60000; // 1 minute
|
|
38
|
+
export function resetEnvironmentCache() {
|
|
39
|
+
cachedEnvironment = null;
|
|
40
|
+
lastCheck = 0;
|
|
41
|
+
}
|
|
35
42
|
export function detectEnvironment() {
|
|
43
|
+
const now = Date.now();
|
|
44
|
+
if (cachedEnvironment && now - lastCheck < CACHE_TTL_MS) {
|
|
45
|
+
return cachedEnvironment;
|
|
46
|
+
}
|
|
36
47
|
const signals = gatherSignals();
|
|
48
|
+
let env = 'unknown';
|
|
37
49
|
if (signals.hostname.includes('prod') || signals.hostname.includes('prd')) {
|
|
38
|
-
|
|
50
|
+
env = 'prod';
|
|
39
51
|
}
|
|
40
|
-
if (signals.dockerContainers.some((c) => c.includes('prod'))) {
|
|
41
|
-
|
|
52
|
+
else if (signals.dockerContainers.some((c) => c.includes('prod'))) {
|
|
53
|
+
env = 'prod';
|
|
42
54
|
}
|
|
43
|
-
if (signals.nodeEnv === 'production') {
|
|
44
|
-
|
|
55
|
+
else if (signals.nodeEnv === 'production') {
|
|
56
|
+
env = 'prod';
|
|
45
57
|
}
|
|
46
|
-
if (signals.user === 'www-data' || signals.user === 'nginx') {
|
|
47
|
-
|
|
58
|
+
else if (signals.user === 'www-data' || signals.user === 'nginx') {
|
|
59
|
+
env = 'prod';
|
|
48
60
|
}
|
|
49
|
-
if (signals.hostname.includes('dev') ||
|
|
50
|
-
|
|
61
|
+
else if (signals.hostname.includes('dev') ||
|
|
62
|
+
signals.hostname.includes('local')) {
|
|
63
|
+
env = 'dev';
|
|
51
64
|
}
|
|
52
|
-
if (signals.hostname.includes('laptop') ||
|
|
65
|
+
else if (signals.hostname.includes('laptop') ||
|
|
53
66
|
signals.hostname.includes('macbook')) {
|
|
54
|
-
|
|
67
|
+
env = 'dev';
|
|
55
68
|
}
|
|
56
|
-
if (signals.nodeEnv === 'development') {
|
|
57
|
-
|
|
69
|
+
else if (signals.nodeEnv === 'development') {
|
|
70
|
+
env = 'dev';
|
|
58
71
|
}
|
|
59
|
-
if (process.env['HOME']?.includes('/Users/')) {
|
|
60
|
-
|
|
72
|
+
else if (process.env['HOME']?.includes('/Users/')) {
|
|
73
|
+
env = 'dev';
|
|
61
74
|
}
|
|
62
|
-
if (signals.hostname.includes('staging') ||
|
|
75
|
+
else if (signals.hostname.includes('staging') ||
|
|
63
76
|
signals.hostname.includes('stg')) {
|
|
64
|
-
|
|
77
|
+
env = 'staging';
|
|
65
78
|
}
|
|
66
|
-
if (signals.hasNginx &&
|
|
79
|
+
else if (signals.hasNginx &&
|
|
67
80
|
signals.hasSystemd &&
|
|
68
81
|
!signals.hostname.includes('dev')) {
|
|
69
|
-
|
|
82
|
+
env = 'prod';
|
|
70
83
|
}
|
|
71
|
-
|
|
84
|
+
cachedEnvironment = env;
|
|
85
|
+
lastCheck = now;
|
|
86
|
+
return env;
|
|
72
87
|
}
|
|
73
88
|
export function getCeremonyMultiplier(env) {
|
|
74
89
|
switch (env) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"environmentDetector.js","sourceRoot":"","sources":["../../../src/brain/environmentDetector.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAc9B,SAAS,aAAa;IACpB,MAAM,QAAQ,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC;IAC7C,MAAM,SAAS,GAAG,EAAE,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC;IAExD,IAAI,gBAAgB,GAAa,EAAE,CAAC;IACpC,IAAI,SAAS,EAAE,CAAC;QACd,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,QAAQ,CAAC,iCAAiC,EAAE;gBACzD,OAAO,EAAE,IAAI;aACd,CAAC,CAAC,QAAQ,EAAE,CAAC;YACd,gBAAgB,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACxD,CAAC;QAAC,OAAO,MAAM,EAAE,CAAC;YAChB,8DAA8D;QAChE,CAAC;IACH,CAAC;IAED,OAAO;QACL,QAAQ;QACR,SAAS;QACT,gBAAgB;QAChB,QAAQ,EAAE,EAAE,CAAC,UAAU,CAAC,0BAA0B,CAAC;QACnD,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,qBAAqB,CAAC;QAChD,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC;QAChC,IAAI,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ;KAC7B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB;IAC/B,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;IAEhC,IAAI,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1E,
|
|
1
|
+
{"version":3,"file":"environmentDetector.js","sourceRoot":"","sources":["../../../src/brain/environmentDetector.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@
|
|
|
4
4
|
* Portions Copyright 2025 TerminaI Authors
|
|
5
5
|
* SPDX-License-Identifier: Apache-2.0
|
|
6
6
|
*/
|
|
7
|
+
import { debugLogger } from '../utils/debugLogger.js';
|
|
7
8
|
/**
|
|
8
9
|
* Implements the Plan-Act-Check loop.
|
|
9
10
|
*/
|
|
@@ -94,7 +95,7 @@ Respond in JSON:
|
|
|
94
95
|
}
|
|
95
96
|
}
|
|
96
97
|
catch (error) {
|
|
97
|
-
|
|
98
|
+
debugLogger.error('PACLoop Verification Error:', error);
|
|
98
99
|
}
|
|
99
100
|
// Fallback: if verification fails or errors out, trust the tool result but log it
|
|
100
101
|
this.failureCount = 0;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pacLoop.js","sourceRoot":"","sources":["../../../src/brain/pacLoop.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"pacLoop.js","sourceRoot":"","sources":["../../../src/brain/pacLoop.ts"],"names":[],"mappings":"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"}
|
|
@@ -35,7 +35,11 @@ export interface RiskAssessment {
|
|
|
35
35
|
export declare function assessRiskHeuristic(command: string): Partial<RiskDimensions> | null;
|
|
36
36
|
export declare function calculateOverallRisk(dimensions: RiskDimensions): RiskAssessment['overallRisk'];
|
|
37
37
|
export declare function selectStrategy(risk: RiskAssessment['overallRisk'], env: RiskDimensions['environment']): RiskAssessment['suggestedStrategy'];
|
|
38
|
-
export declare function assessRiskWithLLM(request: string, systemContext: string, model: GenerativeModelAdapter
|
|
38
|
+
export declare function assessRiskWithLLM(request: string, systemContext: string, model: GenerativeModelAdapter, options?: {
|
|
39
|
+
abortSignal?: AbortSignal;
|
|
40
|
+
}): Promise<RiskDimensions & {
|
|
39
41
|
reasoning: string;
|
|
40
42
|
}>;
|
|
41
|
-
export declare function assessRisk(request: string, command: string | null, systemContext: string, model?: GenerativeModelAdapter
|
|
43
|
+
export declare function assessRisk(request: string, command: string | null, systemContext: string, model?: GenerativeModelAdapter, options?: {
|
|
44
|
+
abortSignal?: AbortSignal;
|
|
45
|
+
}): Promise<RiskAssessment>;
|
|
@@ -101,9 +101,12 @@ function readResponseText(response, fallbackReason) {
|
|
|
101
101
|
}
|
|
102
102
|
return { text: rawText, reasoning: undefined };
|
|
103
103
|
}
|
|
104
|
-
export async function assessRiskWithLLM(request, systemContext, model) {
|
|
104
|
+
export async function assessRiskWithLLM(request, systemContext, model, options) {
|
|
105
105
|
const prompt = RISK_ASSESSMENT_PROMPT.replace('{request}', request).replace('{systemContext}', systemContext);
|
|
106
|
-
const result = await model.generateContent(prompt
|
|
106
|
+
const result = await model.generateContent(prompt, {
|
|
107
|
+
tier: 'flash',
|
|
108
|
+
abortSignal: options?.abortSignal,
|
|
109
|
+
});
|
|
107
110
|
const { text, reasoning: defaultReasoning } = readResponseText(result, 'LLM returned empty response');
|
|
108
111
|
const parsed = parseResponseText(text);
|
|
109
112
|
const reasoning = typeof parsed['reasoning'] === 'string'
|
|
@@ -141,7 +144,7 @@ function buildReasoning(base, historyNote) {
|
|
|
141
144
|
}
|
|
142
145
|
return base;
|
|
143
146
|
}
|
|
144
|
-
export async function assessRisk(request, command, systemContext, model) {
|
|
147
|
+
export async function assessRisk(request, command, systemContext, model, options) {
|
|
145
148
|
const environment = detectEnvironment();
|
|
146
149
|
const heuristic = command ? assessRiskHeuristic(command) : null;
|
|
147
150
|
if (heuristic && heuristic.confidence && heuristic.confidence > 80) {
|
|
@@ -160,7 +163,7 @@ export async function assessRisk(request, command, systemContext, model) {
|
|
|
160
163
|
const heuristicFallback = heuristic ?? {};
|
|
161
164
|
if (model) {
|
|
162
165
|
try {
|
|
163
|
-
const llmResult = await assessRiskWithLLM(request, systemContext, model);
|
|
166
|
+
const llmResult = await assessRiskWithLLM(request, systemContext, model, options);
|
|
164
167
|
dimensions = applyDefaults(llmResult, environment);
|
|
165
168
|
reasoning = llmResult.reasoning;
|
|
166
169
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"riskAssessor.js","sourceRoot":"","sources":["../../../src/brain/riskAssessor.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"riskAssessor.js","sourceRoot":"","sources":["../../../src/brain/riskAssessor.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@
|
|
|
4
4
|
* Portions Copyright 2025 TerminaI Authors
|
|
5
5
|
* SPDX-License-Identifier: Apache-2.0
|
|
6
6
|
*/
|
|
7
|
+
import { debugLogger } from '../utils/debugLogger.js';
|
|
7
8
|
/**
|
|
8
9
|
* Evaluates failures and triggers step-back logic.
|
|
9
10
|
*/
|
|
@@ -26,7 +27,7 @@ export class StepBackEvaluator {
|
|
|
26
27
|
* @returns A new advisor proposal
|
|
27
28
|
*/
|
|
28
29
|
async handleStepBack(task, failedApproach, orchestrator, systemSpec) {
|
|
29
|
-
|
|
30
|
+
debugLogger.debug(`Approach "${failedApproach}" failed twice. Re-evaluating strategy...`);
|
|
30
31
|
// In a more advanced implementation, we could blacklist the failed approach
|
|
31
32
|
// or pass it as "failed" to the orchestrator to avoid loops.
|
|
32
33
|
return orchestrator.selectApproach(task, systemSpec);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stepBackEvaluator.js","sourceRoot":"","sources":["../../../src/brain/stepBackEvaluator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"stepBackEvaluator.js","sourceRoot":"","sources":["../../../src/brain/stepBackEvaluator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAKtD;;GAEG;AACH,MAAM,OAAO,iBAAiB;IACpB,MAAM,CAAU,YAAY,GAAG,CAAC,CAAC;IAEzC;;;;OAIG;IACH,cAAc,CAAC,YAAoB;QACjC,OAAO,YAAY,IAAI,iBAAiB,CAAC,YAAY,CAAC;IACxD,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,cAAc,CAClB,IAAY,EACZ,cAAsB,EACtB,YAAmC,EACnC,UAAsB;QAEtB,WAAW,CAAC,KAAK,CACf,aAAa,cAAc,2CAA2C,CACvE,CAAC;QAEF,4EAA4E;QAC5E,6DAA6D;QAC7D,OAAO,YAAY,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACvD,CAAC"}
|
|
@@ -8,7 +8,7 @@ import type { Config } from '../config/config.js';
|
|
|
8
8
|
import { PACLoop } from './pacLoop.js';
|
|
9
9
|
import { StepBackEvaluator } from './stepBackEvaluator.js';
|
|
10
10
|
import type { GenerativeModelAdapter } from './riskAssessor.js';
|
|
11
|
-
import type
|
|
11
|
+
import { type Logger } from '../core/logger.js';
|
|
12
12
|
import type { ToolCallRequestInfo } from '../core/turn.js';
|
|
13
13
|
/**
|
|
14
14
|
* Result of a brain execution attempt.
|
|
@@ -43,6 +43,14 @@ export declare class ThinkingOrchestrator {
|
|
|
43
43
|
* @returns Structured execution plan
|
|
44
44
|
*/
|
|
45
45
|
executeTask(task: string, _signal: AbortSignal): Promise<BrainExecutionPlan>;
|
|
46
|
+
/**
|
|
47
|
+
* Attempts to recover from repeated failures using Step-Back logic.
|
|
48
|
+
* @param task Original user task
|
|
49
|
+
* @param failedApproach The approach that failed
|
|
50
|
+
* @param failureCount Number of consecutive failures
|
|
51
|
+
* @returns New execution plan or null if recovery not triggered
|
|
52
|
+
*/
|
|
53
|
+
recoverFromFailure(task: string, failedApproach: string, failureCount: number): Promise<BrainExecutionPlan | null>;
|
|
46
54
|
getPACLoop(): PACLoop;
|
|
47
55
|
getStepBack(): StepBackEvaluator;
|
|
48
56
|
}
|
|
@@ -12,6 +12,8 @@ import { CodeThinker } from './codeThinker.js';
|
|
|
12
12
|
import { PACLoop } from './pacLoop.js';
|
|
13
13
|
import { StepBackEvaluator } from './stepBackEvaluator.js';
|
|
14
14
|
import { loadSystemSpec } from './systemSpec.js';
|
|
15
|
+
import {} from '../core/logger.js';
|
|
16
|
+
import { debugLogger } from '../utils/debugLogger.js';
|
|
15
17
|
import { REPL_TOOL_NAME } from '../tools/tool-names.js';
|
|
16
18
|
/**
|
|
17
19
|
* Orchestrates the execution of different thinking frameworks.
|
|
@@ -48,6 +50,16 @@ export class ThinkingOrchestrator {
|
|
|
48
50
|
if (!systemSpec) {
|
|
49
51
|
throw new Error('System spec not initialized. Run initialization first.');
|
|
50
52
|
}
|
|
53
|
+
if (!this.config.experimentalBrainFrameworks) {
|
|
54
|
+
return {
|
|
55
|
+
frameworkId: 'FW_DIRECT',
|
|
56
|
+
approach: 'Direct',
|
|
57
|
+
reasoning: 'Experimental brain frameworks are disabled.',
|
|
58
|
+
suggestedAction: 'fallback_to_direct',
|
|
59
|
+
explanation: 'Standard tool execution path.',
|
|
60
|
+
confidence: 100,
|
|
61
|
+
};
|
|
62
|
+
}
|
|
51
63
|
// Phase 3: Use Flash for selection
|
|
52
64
|
let selection = selectFrameworkHeuristic(task);
|
|
53
65
|
if (!selection) {
|
|
@@ -57,7 +69,7 @@ export class ThinkingOrchestrator {
|
|
|
57
69
|
}
|
|
58
70
|
const frameworkId = selection?.frameworkId || 'FW_DIRECT';
|
|
59
71
|
if (this.config.getDebugMode()) {
|
|
60
|
-
|
|
72
|
+
debugLogger.debug(`[Thinking] Selected framework: ${frameworkId} (${selection?.reasoning || 'Default'})`);
|
|
61
73
|
}
|
|
62
74
|
await this.logger?.logEventFull('thought', {
|
|
63
75
|
frameworkId,
|
|
@@ -140,6 +152,40 @@ export class ThinkingOrchestrator {
|
|
|
140
152
|
};
|
|
141
153
|
}
|
|
142
154
|
}
|
|
155
|
+
/**
|
|
156
|
+
* Attempts to recover from repeated failures using Step-Back logic.
|
|
157
|
+
* @param task Original user task
|
|
158
|
+
* @param failedApproach The approach that failed
|
|
159
|
+
* @param failureCount Number of consecutive failures
|
|
160
|
+
* @returns New execution plan or null if recovery not triggered
|
|
161
|
+
*/
|
|
162
|
+
async recoverFromFailure(task, failedApproach, failureCount) {
|
|
163
|
+
if (!this.config.experimentalBrainFrameworks) {
|
|
164
|
+
return null;
|
|
165
|
+
}
|
|
166
|
+
if (this.stepBack.shouldStepBack(failureCount)) {
|
|
167
|
+
const systemSpec = loadSystemSpec();
|
|
168
|
+
if (!systemSpec) {
|
|
169
|
+
return null;
|
|
170
|
+
}
|
|
171
|
+
const proposal = await this.stepBack.handleStepBack(task, failedApproach, this.consensus, systemSpec);
|
|
172
|
+
// Log the recovery thought
|
|
173
|
+
await this.logger?.logEventFull('thought', {
|
|
174
|
+
frameworkId: 'FW_SC_RECOVERY',
|
|
175
|
+
reasoning: `Step-Back triggered after ${failureCount} failures. New approach: ${proposal.approach}`,
|
|
176
|
+
task,
|
|
177
|
+
});
|
|
178
|
+
return {
|
|
179
|
+
frameworkId: 'FW_CONSENSUS', // We piggyback on consensus for the new plan
|
|
180
|
+
approach: proposal.approach,
|
|
181
|
+
reasoning: proposal.reasoning,
|
|
182
|
+
suggestedAction: 'inject_prompt',
|
|
183
|
+
explanation: `Recovery Strategy: ${proposal.approach}`,
|
|
184
|
+
confidence: proposal.confidence,
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
return null;
|
|
188
|
+
}
|
|
143
189
|
// Exposed for PAC loop and StepBack usage in the future
|
|
144
190
|
getPACLoop() {
|
|
145
191
|
return this.pacLoop;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"thinkingOrchestrator.js","sourceRoot":"","sources":["../../../src/brain/thinkingOrchestrator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EACL,wBAAwB,EACxB,sBAAsB,GACvB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"thinkingOrchestrator.js","sourceRoot":"","sources":["../../../src/brain/thinkingOrchestrator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* Portions Copyright 2025 TerminaI Authors
|
|
5
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
6
|
+
*/
|
|
7
|
+
import type { Config } from '../config/config.js';
|
|
8
|
+
import type { BrainAuthority } from '../config/brainAuthority.js';
|
|
9
|
+
import { type ConfidenceAction, type ExecutionDecision, type RiskAssessment, type GenerativeModelAdapter } from './index.js';
|
|
10
|
+
import type { DeterministicReviewResult } from '../safety/approval-ladder/types.js';
|
|
11
|
+
export interface BrainContext {
|
|
12
|
+
assessment: RiskAssessment;
|
|
13
|
+
decision: ExecutionDecision;
|
|
14
|
+
confidenceAction: ConfidenceAction;
|
|
15
|
+
request: string;
|
|
16
|
+
}
|
|
17
|
+
export declare class BrainRiskManager {
|
|
18
|
+
private readonly config;
|
|
19
|
+
private brainContext;
|
|
20
|
+
constructor(config: Config);
|
|
21
|
+
/**
|
|
22
|
+
* Builds a generative model adapter from the config.
|
|
23
|
+
*/
|
|
24
|
+
buildGenerativeModelAdapter(): GenerativeModelAdapter | null;
|
|
25
|
+
/**
|
|
26
|
+
* Evaluates the risk of a command or action using the brain.
|
|
27
|
+
*/
|
|
28
|
+
evaluateBrain(request: string, commandOrAction: string, systemContext: string, abortSignal?: AbortSignal): Promise<BrainContext | null>;
|
|
29
|
+
/**
|
|
30
|
+
* Applies brain authority to escalate the review level if necessary.
|
|
31
|
+
*/
|
|
32
|
+
applyBrainAuthority(review: DeterministicReviewResult, authority: BrainAuthority): DeterministicReviewResult;
|
|
33
|
+
private getBrainReviewLevel;
|
|
34
|
+
private isReviewLevelAtLeast;
|
|
35
|
+
/**
|
|
36
|
+
* Formats a risk preamble to be displayed to the user or LLM.
|
|
37
|
+
*/
|
|
38
|
+
formatRiskPreamble(): {
|
|
39
|
+
text: string;
|
|
40
|
+
surfaceToUser: boolean;
|
|
41
|
+
};
|
|
42
|
+
/**
|
|
43
|
+
* Records the outcome of the action for future learning.
|
|
44
|
+
* @param commandOrAction - The command or action that was executed
|
|
45
|
+
* @param outcome - The outcome of the execution
|
|
46
|
+
* @param userApproved - Whether the user approved the action (false if cancelled/rejected)
|
|
47
|
+
* @param errorMessage - Optional error message if outcome is failure
|
|
48
|
+
*/
|
|
49
|
+
recordOutcome(commandOrAction: string, outcome: 'success' | 'failure' | 'cancelled', userApproved?: boolean, errorMessage?: string): void;
|
|
50
|
+
getBrainContext(): BrainContext | null;
|
|
51
|
+
}
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* Portions Copyright 2025 TerminaI Authors
|
|
5
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
6
|
+
*/
|
|
7
|
+
import { debugLogger } from '../utils/debugLogger.js';
|
|
8
|
+
import { getErrorMessage } from '../utils/errors.js';
|
|
9
|
+
import { getResponseText } from '../utils/partUtils.js';
|
|
10
|
+
import { coreEvents, CoreEvent } from '../utils/events.js';
|
|
11
|
+
import { assessRisk, handleConfidence, logOutcome, routeExecution, } from './index.js';
|
|
12
|
+
export class BrainRiskManager {
|
|
13
|
+
config;
|
|
14
|
+
brainContext = null;
|
|
15
|
+
constructor(config) {
|
|
16
|
+
this.config = config;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Builds a generative model adapter from the config.
|
|
20
|
+
*/
|
|
21
|
+
buildGenerativeModelAdapter() {
|
|
22
|
+
try {
|
|
23
|
+
if (typeof this.config
|
|
24
|
+
.getBaseLlmClient !== 'function') {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
const baseLlm = this.config.getBaseLlmClient();
|
|
28
|
+
const defaultAbortController = new AbortController();
|
|
29
|
+
return {
|
|
30
|
+
generateContent: async (prompt, options) => {
|
|
31
|
+
// Always use the configured active model for provider-agnostic operation.
|
|
32
|
+
// The tier hint is currently ignored; a future enhancement could add
|
|
33
|
+
// a provider-specific tier resolution strategy (e.g., config.getModelForTier).
|
|
34
|
+
const modelName = this.config.getActiveModel();
|
|
35
|
+
const modelConfigKey = { model: modelName };
|
|
36
|
+
const response = await baseLlm.generateContent({
|
|
37
|
+
modelConfigKey,
|
|
38
|
+
contents: [{ role: 'user', parts: [{ text: prompt }] }],
|
|
39
|
+
abortSignal: options?.abortSignal ?? defaultAbortController.signal,
|
|
40
|
+
promptId: this.config.getSessionId(),
|
|
41
|
+
});
|
|
42
|
+
const text = getResponseText(response) ?? '';
|
|
43
|
+
return {
|
|
44
|
+
response: {
|
|
45
|
+
text: () => text,
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
catch (error) {
|
|
52
|
+
debugLogger.error(`Failed to build LLM adapter for risk assessment: ${getErrorMessage(error)}`);
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Evaluates the risk of a command or action using the brain.
|
|
58
|
+
*/
|
|
59
|
+
async evaluateBrain(request, commandOrAction, systemContext, abortSignal) {
|
|
60
|
+
if (this.brainContext) {
|
|
61
|
+
return this.brainContext;
|
|
62
|
+
}
|
|
63
|
+
const model = this.buildGenerativeModelAdapter();
|
|
64
|
+
try {
|
|
65
|
+
const assessment = await assessRisk(request, commandOrAction, systemContext, model ?? undefined, { abortSignal });
|
|
66
|
+
const decision = routeExecution(assessment);
|
|
67
|
+
const confidenceAction = handleConfidence(assessment.dimensions.confidence, request);
|
|
68
|
+
coreEvents.emit(CoreEvent.Thought, {
|
|
69
|
+
frameworkId: 'risk-assessment',
|
|
70
|
+
reasoning: assessment.reasoning,
|
|
71
|
+
task: request,
|
|
72
|
+
approach: assessment.suggestedStrategy,
|
|
73
|
+
confidence: assessment.dimensions.confidence,
|
|
74
|
+
explanation: `Risk: ${assessment.overallRisk}. Environment: ${assessment.dimensions.environment}`,
|
|
75
|
+
suggestedAction: decision.requiresConfirmation ? 'confirm' : 'execute',
|
|
76
|
+
});
|
|
77
|
+
this.brainContext = { assessment, decision, confidenceAction, request };
|
|
78
|
+
return this.brainContext;
|
|
79
|
+
}
|
|
80
|
+
catch (error) {
|
|
81
|
+
debugLogger.error(`Failed to run risk assessment: ${getErrorMessage(error)}`);
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Applies brain authority to escalate the review level if necessary.
|
|
87
|
+
*/
|
|
88
|
+
applyBrainAuthority(review, authority) {
|
|
89
|
+
if (!this.brainContext) {
|
|
90
|
+
return review;
|
|
91
|
+
}
|
|
92
|
+
const requiredLevel = this.getBrainReviewLevel(authority, this.brainContext);
|
|
93
|
+
if (!requiredLevel) {
|
|
94
|
+
return review;
|
|
95
|
+
}
|
|
96
|
+
if (this.isReviewLevelAtLeast(review.level, requiredLevel)) {
|
|
97
|
+
return review;
|
|
98
|
+
}
|
|
99
|
+
const nextReasons = [
|
|
100
|
+
...review.reasons,
|
|
101
|
+
`Brain risk assessment marked this as ${this.brainContext.assessment.overallRisk}; require ${requiredLevel} review.`,
|
|
102
|
+
];
|
|
103
|
+
return {
|
|
104
|
+
level: requiredLevel,
|
|
105
|
+
reasons: nextReasons,
|
|
106
|
+
requiresClick: requiredLevel !== 'A',
|
|
107
|
+
requiresPin: requiredLevel === 'C',
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
getBrainReviewLevel(authority, brainContext) {
|
|
111
|
+
const risk = brainContext.assessment.overallRisk;
|
|
112
|
+
if (authority === 'advisory') {
|
|
113
|
+
return undefined;
|
|
114
|
+
}
|
|
115
|
+
if (authority === 'escalate-only') {
|
|
116
|
+
if (!brainContext.decision.requiresConfirmation) {
|
|
117
|
+
return undefined;
|
|
118
|
+
}
|
|
119
|
+
return risk === 'critical' ? 'C' : 'B';
|
|
120
|
+
}
|
|
121
|
+
if (risk === 'critical') {
|
|
122
|
+
return 'C';
|
|
123
|
+
}
|
|
124
|
+
if (risk === 'elevated' || risk === 'normal') {
|
|
125
|
+
return 'B';
|
|
126
|
+
}
|
|
127
|
+
return undefined;
|
|
128
|
+
}
|
|
129
|
+
isReviewLevelAtLeast(current, required) {
|
|
130
|
+
const rank = { A: 0, B: 1, C: 2 };
|
|
131
|
+
return rank[current] >= rank[required];
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Formats a risk preamble to be displayed to the user or LLM.
|
|
135
|
+
*/
|
|
136
|
+
formatRiskPreamble() {
|
|
137
|
+
if (!this.brainContext) {
|
|
138
|
+
return { text: '', surfaceToUser: false };
|
|
139
|
+
}
|
|
140
|
+
const { assessment, decision, confidenceAction } = this.brainContext;
|
|
141
|
+
const lines = [
|
|
142
|
+
`Risk: ${assessment.overallRisk} (${assessment.reasoning})`,
|
|
143
|
+
`Environment: ${assessment.dimensions.environment}`,
|
|
144
|
+
`Suggested strategy: ${assessment.suggestedStrategy}`,
|
|
145
|
+
];
|
|
146
|
+
if (decision.shouldWarn && decision.warningMessage) {
|
|
147
|
+
lines.push(decision.warningMessage);
|
|
148
|
+
}
|
|
149
|
+
if (confidenceAction.type === 'narrate-uncertainty') {
|
|
150
|
+
if (confidenceAction.message) {
|
|
151
|
+
lines.push(confidenceAction.message);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
if (confidenceAction.type === 'diagnostic-first') {
|
|
155
|
+
if (confidenceAction.message) {
|
|
156
|
+
lines.push(confidenceAction.message);
|
|
157
|
+
}
|
|
158
|
+
if (confidenceAction.diagnosticCommand) {
|
|
159
|
+
lines.push(`Diagnostic: ${confidenceAction.diagnosticCommand}`);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
if (confidenceAction.type === 'ask-clarification') {
|
|
163
|
+
if (confidenceAction.clarificationQuestion) {
|
|
164
|
+
lines.push(confidenceAction.clarificationQuestion);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
const surfaceToUser = decision.shouldWarn ||
|
|
168
|
+
assessment.overallRisk !== 'trivial' ||
|
|
169
|
+
confidenceAction.type !== 'proceed';
|
|
170
|
+
return { text: lines.filter(Boolean).join('\n'), surfaceToUser };
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Records the outcome of the action for future learning.
|
|
174
|
+
* @param commandOrAction - The command or action that was executed
|
|
175
|
+
* @param outcome - The outcome of the execution
|
|
176
|
+
* @param userApproved - Whether the user approved the action (false if cancelled/rejected)
|
|
177
|
+
* @param errorMessage - Optional error message if outcome is failure
|
|
178
|
+
*/
|
|
179
|
+
recordOutcome(commandOrAction, outcome, userApproved = outcome !== 'cancelled', errorMessage) {
|
|
180
|
+
if (!this.brainContext) {
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
try {
|
|
184
|
+
logOutcome({
|
|
185
|
+
timestamp: new Date().toISOString(),
|
|
186
|
+
request: this.brainContext.request,
|
|
187
|
+
command: commandOrAction,
|
|
188
|
+
assessedRisk: this.brainContext.assessment.overallRisk,
|
|
189
|
+
actualOutcome: outcome,
|
|
190
|
+
userApproved,
|
|
191
|
+
errorMessage,
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
catch (error) {
|
|
195
|
+
debugLogger.error(`Failed to log outcome: ${getErrorMessage(error)}`);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
getBrainContext() {
|
|
199
|
+
return this.brainContext;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
//# sourceMappingURL=toolIntegration.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolIntegration.js","sourceRoot":"","sources":["../../../src/brain/toolIntegration.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC3D,OAAO,EACL,UAAU,EACV,gBAAgB,EAChB,UAAU,EACV,cAAc,GAKf,MAAM,YAAY,CAAC;AAapB,MAAM,OAAO,gBAAgB;IAGE;IAFrB,YAAY,GAAwB,IAAI,CAAC;IAEjD,YAA6B,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IAAG,CAAC;IAE/C;;OAEG;IACH,2BAA2B;QACzB,IAAI,CAAC;YACH,IACE,OAAQ,IAAI,CAAC,MAAoD;iBAC9D,gBAAgB,KAAK,UAAU,EAClC,CAAC;gBACD,OAAO,IAAI,CAAC;YACd,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;YAC/C,MAAM,sBAAsB,GAAG,IAAI,eAAe,EAAE,CAAC;YAErD,OAAO;gBACL,eAAe,EAAE,KAAK,EACpB,MAAc,EACd,OAA+D,EAC/D,EAAE;oBACF,0EAA0E;oBAC1E,qEAAqE;oBACrE,+EAA+E;oBAC/E,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;oBAE/C,MAAM,cAAc,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;oBAC5C,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,eAAe,CAAC;wBAC7C,cAAc;wBACd,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;wBACvD,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,sBAAsB,CAAC,MAAM;wBAClE,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE;qBACrC,CAAC,CAAC;oBAEH,MAAM,IAAI,GAAG,eAAe,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;oBAC7C,OAAO;wBACL,QAAQ,EAAE;4BACR,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;yBACjB;qBACiD,CAAC;gBACvD,CAAC;aACF,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,WAAW,CAAC,KAAK,CACf,oDAAoD,eAAe,CAAC,KAAK,CAAC,EAAE,CAC7E,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa,CACjB,OAAe,EACf,eAAuB,EACvB,aAAqB,EACrB,WAAyB;QAEzB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC,YAAY,CAAC;QAC3B,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,2BAA2B,EAAE,CAAC;QAEjD,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,MAAM,UAAU,CACjC,OAAO,EACP,eAAe,EACf,aAAa,EACb,KAAK,IAAI,SAAS,EAClB,EAAE,WAAW,EAAE,CAChB,CAAC;YACF,MAAM,QAAQ,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;YAC5C,MAAM,gBAAgB,GAAG,gBAAgB,CACvC,UAAU,CAAC,UAAU,CAAC,UAAU,EAChC,OAAO,CACR,CAAC;YAEF,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;gBACjC,WAAW,EAAE,iBAAiB;gBAC9B,SAAS,EAAE,UAAU,CAAC,SAAS;gBAC/B,IAAI,EAAE,OAAO;gBACb,QAAQ,EAAE,UAAU,CAAC,iBAAiB;gBACtC,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,UAAU;gBAC5C,WAAW,EAAE,SAAS,UAAU,CAAC,WAAW,kBAAkB,UAAU,CAAC,UAAU,CAAC,WAAW,EAAE;gBACjG,eAAe,EAAE,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;aACvE,CAAC,CAAC;YAEH,IAAI,CAAC,YAAY,GAAG,EAAE,UAAU,EAAE,QAAQ,EAAE,gBAAgB,EAAE,OAAO,EAAE,CAAC;YACxE,OAAO,IAAI,CAAC,YAAY,CAAC;QAC3B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,WAAW,CAAC,KAAK,CACf,kCAAkC,eAAe,CAAC,KAAK,CAAC,EAAE,CAC3D,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED;;OAEG;IACH,mBAAmB,CACjB,MAAiC,EACjC,SAAyB;QAEzB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,OAAO,MAAM,CAAC;QAChB,CAAC;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAC5C,SAAS,EACT,IAAI,CAAC,YAAY,CAClB,CAAC;QACF,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,OAAO,MAAM,CAAC;QAChB,CAAC;QAED,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,KAAK,EAAE,aAAa,CAAC,EAAE,CAAC;YAC3D,OAAO,MAAM,CAAC;QAChB,CAAC;QAED,MAAM,WAAW,GAAG;YAClB,GAAG,MAAM,CAAC,OAAO;YACjB,wCAAwC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,WAAW,aAAa,aAAa,UAAU;SACrH,CAAC;QAEF,OAAO;YACL,KAAK,EAAE,aAAa;YACpB,OAAO,EAAE,WAAW;YACpB,aAAa,EAAE,aAAa,KAAK,GAAG;YACpC,WAAW,EAAE,aAAa,KAAK,GAAG;SACnC,CAAC;IACJ,CAAC;IAEO,mBAAmB,CACzB,SAAyB,EACzB,YAA0B;QAE1B,MAAM,IAAI,GAAG,YAAY,CAAC,UAAU,CAAC,WAAW,CAAC;QAEjD,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;YAC7B,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,IAAI,SAAS,KAAK,eAAe,EAAE,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,oBAAoB,EAAE,CAAC;gBAChD,OAAO,SAAS,CAAC;YACnB,CAAC;YACD,OAAO,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QACzC,CAAC;QAED,IAAI,IAAI,KAAK,UAAU,EAAE,CAAC;YACxB,OAAO,GAAG,CAAC;QACb,CAAC;QACD,IAAI,IAAI,KAAK,UAAU,IAAI,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7C,OAAO,GAAG,CAAC;QACb,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,oBAAoB,CAC1B,OAAoB,EACpB,QAAqB;QAErB,MAAM,IAAI,GAAgC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;QAC/D,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,kBAAkB;QAIhB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;QAC5C,CAAC;QAED,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC;QACrE,MAAM,KAAK,GAAG;YACZ,SAAS,UAAU,CAAC,WAAW,KAAK,UAAU,CAAC,SAAS,GAAG;YAC3D,gBAAgB,UAAU,CAAC,UAAU,CAAC,WAAW,EAAE;YACnD,uBAAuB,UAAU,CAAC,iBAAiB,EAAE;SACtD,CAAC;QAEF,IAAI,QAAQ,CAAC,UAAU,IAAI,QAAQ,CAAC,cAAc,EAAE,CAAC;YACnD,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,gBAAgB,CAAC,IAAI,KAAK,qBAAqB,EAAE,CAAC;YACpD,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;QAED,IAAI,gBAAgB,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YACjD,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YACvC,CAAC;YACD,IAAI,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;gBACvC,KAAK,CAAC,IAAI,CAAC,eAAe,gBAAgB,CAAC,iBAAiB,EAAE,CAAC,CAAC;YAClE,CAAC;QACH,CAAC;QAED,IAAI,gBAAgB,CAAC,IAAI,KAAK,mBAAmB,EAAE,CAAC;YAClD,IAAI,gBAAgB,CAAC,qBAAqB,EAAE,CAAC;gBAC3C,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,CAAC;YACrD,CAAC;QACH,CAAC;QAED,MAAM,aAAa,GACjB,QAAQ,CAAC,UAAU;YACnB,UAAU,CAAC,WAAW,KAAK,SAAS;YACpC,gBAAgB,CAAC,IAAI,KAAK,SAAS,CAAC;QACtC,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,CAAC;IACnE,CAAC;IAED;;;;;;OAMG;IACH,aAAa,CACX,eAAuB,EACvB,OAA4C,EAC5C,YAAY,GAAG,OAAO,KAAK,WAAW,EACtC,YAAqB;QAErB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,UAAU,CAAC;gBACT,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACnC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO;gBAClC,OAAO,EAAE,eAAe;gBACxB,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,WAAW;gBACtD,aAAa,EAAE,OAAO;gBACtB,YAAY;gBACZ,YAAY;aACb,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,WAAW,CAAC,KAAK,CAAC,0BAA0B,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;CACF"}
|