patchwork-os 0.2.0-alpha.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/LICENSE +21 -0
- package/README.bridge.md +352 -0
- package/README.md +72 -0
- package/deploy/README.md +172 -0
- package/deploy/bootstrap-new-vps.sh +364 -0
- package/deploy/claude-ide-bridge.service.template +67 -0
- package/deploy/claude-ide-bridge@.service +31 -0
- package/deploy/ecosystem.config.js.example +36 -0
- package/deploy/install-vps-service.sh +240 -0
- package/deploy/nginx-claude-bridge.conf.template +129 -0
- package/dist/activityLog.d.ts +112 -0
- package/dist/activityLog.js +399 -0
- package/dist/activityLog.js.map +1 -0
- package/dist/activityTypes.d.ts +28 -0
- package/dist/activityTypes.js +9 -0
- package/dist/activityTypes.js.map +1 -0
- package/dist/adapters/base.d.ts +78 -0
- package/dist/adapters/base.js +14 -0
- package/dist/adapters/base.js.map +1 -0
- package/dist/adapters/claude.d.ts +18 -0
- package/dist/adapters/claude.js +276 -0
- package/dist/adapters/claude.js.map +1 -0
- package/dist/adapters/gemini.d.ts +17 -0
- package/dist/adapters/gemini.js +218 -0
- package/dist/adapters/gemini.js.map +1 -0
- package/dist/adapters/grok.d.ts +7 -0
- package/dist/adapters/grok.js +21 -0
- package/dist/adapters/grok.js.map +1 -0
- package/dist/adapters/index.d.ts +5 -0
- package/dist/adapters/index.js +37 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/local.d.ts +7 -0
- package/dist/adapters/local.js +22 -0
- package/dist/adapters/local.js.map +1 -0
- package/dist/adapters/openai.d.ts +22 -0
- package/dist/adapters/openai.js +284 -0
- package/dist/adapters/openai.js.map +1 -0
- package/dist/adapters/sse.d.ts +13 -0
- package/dist/adapters/sse.js +58 -0
- package/dist/adapters/sse.js.map +1 -0
- package/dist/analyticsAggregator.d.ts +28 -0
- package/dist/analyticsAggregator.js +133 -0
- package/dist/analyticsAggregator.js.map +1 -0
- package/dist/analyticsPrefs.d.ts +9 -0
- package/dist/analyticsPrefs.js +50 -0
- package/dist/analyticsPrefs.js.map +1 -0
- package/dist/analyticsSend.d.ts +12 -0
- package/dist/analyticsSend.js +34 -0
- package/dist/analyticsSend.js.map +1 -0
- package/dist/approvalHttp.d.ts +46 -0
- package/dist/approvalHttp.js +370 -0
- package/dist/approvalHttp.js.map +1 -0
- package/dist/approvalQueue.d.ts +49 -0
- package/dist/approvalQueue.js +84 -0
- package/dist/approvalQueue.js.map +1 -0
- package/dist/automation.d.ts +675 -0
- package/dist/automation.js +1038 -0
- package/dist/automation.js.map +1 -0
- package/dist/bridge.d.ts +85 -0
- package/dist/bridge.js +1535 -0
- package/dist/bridge.js.map +1 -0
- package/dist/bridgeLockDiscovery.d.ts +11 -0
- package/dist/bridgeLockDiscovery.js +49 -0
- package/dist/bridgeLockDiscovery.js.map +1 -0
- package/dist/bridgeToken.d.ts +22 -0
- package/dist/bridgeToken.js +114 -0
- package/dist/bridgeToken.js.map +1 -0
- package/dist/bridgeToolsRules.d.ts +20 -0
- package/dist/bridgeToolsRules.js +79 -0
- package/dist/bridgeToolsRules.js.map +1 -0
- package/dist/ccPermissions.d.ts +59 -0
- package/dist/ccPermissions.js +163 -0
- package/dist/ccPermissions.js.map +1 -0
- package/dist/claudeDriver.d.ts +129 -0
- package/dist/claudeDriver.js +459 -0
- package/dist/claudeDriver.js.map +1 -0
- package/dist/claudeMdPatch.d.ts +29 -0
- package/dist/claudeMdPatch.js +164 -0
- package/dist/claudeMdPatch.js.map +1 -0
- package/dist/claudeOrchestrator.d.ts +171 -0
- package/dist/claudeOrchestrator.js +591 -0
- package/dist/claudeOrchestrator.js.map +1 -0
- package/dist/commands/install.d.ts +1 -0
- package/dist/commands/install.js +158 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/marketplace.d.ts +11 -0
- package/dist/commands/marketplace.js +120 -0
- package/dist/commands/marketplace.js.map +1 -0
- package/dist/commands/patchworkInit.d.ts +14 -0
- package/dist/commands/patchworkInit.js +155 -0
- package/dist/commands/patchworkInit.js.map +1 -0
- package/dist/commands/task.d.ts +14 -0
- package/dist/commands/task.js +289 -0
- package/dist/commands/task.js.map +1 -0
- package/dist/commands/tokenEfficiency.d.ts +9 -0
- package/dist/commands/tokenEfficiency.js +211 -0
- package/dist/commands/tokenEfficiency.js.map +1 -0
- package/dist/commands/tools.d.ts +28 -0
- package/dist/commands/tools.js +326 -0
- package/dist/commands/tools.js.map +1 -0
- package/dist/commitIssueLinkLog.d.ts +77 -0
- package/dist/commitIssueLinkLog.js +142 -0
- package/dist/commitIssueLinkLog.js.map +1 -0
- package/dist/companions/registry.d.ts +12 -0
- package/dist/companions/registry.js +71 -0
- package/dist/companions/registry.js.map +1 -0
- package/dist/config.d.ts +105 -0
- package/dist/config.js +720 -0
- package/dist/config.js.map +1 -0
- package/dist/crypto.d.ts +16 -0
- package/dist/crypto.js +34 -0
- package/dist/crypto.js.map +1 -0
- package/dist/dashboard.d.ts +12 -0
- package/dist/dashboard.js +149 -0
- package/dist/dashboard.js.map +1 -0
- package/dist/decisionTraceLog.d.ts +77 -0
- package/dist/decisionTraceLog.js +147 -0
- package/dist/decisionTraceLog.js.map +1 -0
- package/dist/errors.d.ts +32 -0
- package/dist/errors.js +34 -0
- package/dist/errors.js.map +1 -0
- package/dist/extensionClient.d.ts +279 -0
- package/dist/extensionClient.js +1253 -0
- package/dist/extensionClient.js.map +1 -0
- package/dist/fileLock.d.ts +36 -0
- package/dist/fileLock.js +121 -0
- package/dist/fileLock.js.map +1 -0
- package/dist/fp/activityAnalytics.d.ts +39 -0
- package/dist/fp/activityAnalytics.js +111 -0
- package/dist/fp/activityAnalytics.js.map +1 -0
- package/dist/fp/async.d.ts +48 -0
- package/dist/fp/async.js +60 -0
- package/dist/fp/async.js.map +1 -0
- package/dist/fp/automationInterpreter.d.ts +37 -0
- package/dist/fp/automationInterpreter.js +523 -0
- package/dist/fp/automationInterpreter.js.map +1 -0
- package/dist/fp/automationProgram.d.ts +89 -0
- package/dist/fp/automationProgram.js +29 -0
- package/dist/fp/automationProgram.js.map +1 -0
- package/dist/fp/automationState.d.ts +135 -0
- package/dist/fp/automationState.js +206 -0
- package/dist/fp/automationState.js.map +1 -0
- package/dist/fp/automationUtils.d.ts +31 -0
- package/dist/fp/automationUtils.js +61 -0
- package/dist/fp/automationUtils.js.map +1 -0
- package/dist/fp/brandedTypes.d.ts +32 -0
- package/dist/fp/brandedTypes.js +41 -0
- package/dist/fp/brandedTypes.js.map +1 -0
- package/dist/fp/commandDescription.d.ts +18 -0
- package/dist/fp/commandDescription.js +125 -0
- package/dist/fp/commandDescription.js.map +1 -0
- package/dist/fp/extensionSnapshot.d.ts +10 -0
- package/dist/fp/extensionSnapshot.js +14 -0
- package/dist/fp/extensionSnapshot.js.map +1 -0
- package/dist/fp/index.d.ts +8 -0
- package/dist/fp/index.js +9 -0
- package/dist/fp/index.js.map +1 -0
- package/dist/fp/interpreterContext.d.ts +69 -0
- package/dist/fp/interpreterContext.js +56 -0
- package/dist/fp/interpreterContext.js.map +1 -0
- package/dist/fp/policyParser.d.ts +16 -0
- package/dist/fp/policyParser.js +334 -0
- package/dist/fp/policyParser.js.map +1 -0
- package/dist/fp/result.d.ts +38 -0
- package/dist/fp/result.js +57 -0
- package/dist/fp/result.js.map +1 -0
- package/dist/fp/tokenBucket.d.ts +27 -0
- package/dist/fp/tokenBucket.js +36 -0
- package/dist/fp/tokenBucket.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1465 -0
- package/dist/index.js.map +1 -0
- package/dist/instructionsUtils.d.ts +17 -0
- package/dist/instructionsUtils.js +38 -0
- package/dist/instructionsUtils.js.map +1 -0
- package/dist/lockfile.d.ts +16 -0
- package/dist/lockfile.js +172 -0
- package/dist/lockfile.js.map +1 -0
- package/dist/logger.d.ts +16 -0
- package/dist/logger.js +68 -0
- package/dist/logger.js.map +1 -0
- package/dist/oauth.d.ts +105 -0
- package/dist/oauth.js +880 -0
- package/dist/oauth.js.map +1 -0
- package/dist/orchestrator/childBridgeClient.d.ts +33 -0
- package/dist/orchestrator/childBridgeClient.js +321 -0
- package/dist/orchestrator/childBridgeClient.js.map +1 -0
- package/dist/orchestrator/childBridgeRegistry.d.ts +67 -0
- package/dist/orchestrator/childBridgeRegistry.js +297 -0
- package/dist/orchestrator/childBridgeRegistry.js.map +1 -0
- package/dist/orchestrator/index.d.ts +3 -0
- package/dist/orchestrator/index.js +3 -0
- package/dist/orchestrator/index.js.map +1 -0
- package/dist/orchestrator/orchestratorBridge.d.ts +32 -0
- package/dist/orchestrator/orchestratorBridge.js +412 -0
- package/dist/orchestrator/orchestratorBridge.js.map +1 -0
- package/dist/orchestrator/orchestratorConfig.d.ts +11 -0
- package/dist/orchestrator/orchestratorConfig.js +85 -0
- package/dist/orchestrator/orchestratorConfig.js.map +1 -0
- package/dist/orchestrator/orchestratorTools.d.ts +16 -0
- package/dist/orchestrator/orchestratorTools.js +272 -0
- package/dist/orchestrator/orchestratorTools.js.map +1 -0
- package/dist/patchworkCli.d.ts +15 -0
- package/dist/patchworkCli.js +41 -0
- package/dist/patchworkCli.js.map +1 -0
- package/dist/patchworkConfig.d.ts +28 -0
- package/dist/patchworkConfig.js +30 -0
- package/dist/patchworkConfig.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.js +31 -0
- package/dist/plugin.js.map +1 -0
- package/dist/pluginLoader.d.ts +44 -0
- package/dist/pluginLoader.js +357 -0
- package/dist/pluginLoader.js.map +1 -0
- package/dist/pluginWatcher.d.ts +24 -0
- package/dist/pluginWatcher.js +139 -0
- package/dist/pluginWatcher.js.map +1 -0
- package/dist/preToolUseHook.d.ts +10 -0
- package/dist/preToolUseHook.js +57 -0
- package/dist/preToolUseHook.js.map +1 -0
- package/dist/probe.d.ts +35 -0
- package/dist/probe.js +143 -0
- package/dist/probe.js.map +1 -0
- package/dist/prompts.d.ts +27 -0
- package/dist/prompts.js +1680 -0
- package/dist/prompts.js.map +1 -0
- package/dist/quickTaskPresets.d.ts +64 -0
- package/dist/quickTaskPresets.js +156 -0
- package/dist/quickTaskPresets.js.map +1 -0
- package/dist/recipes/compiler.d.ts +44 -0
- package/dist/recipes/compiler.js +140 -0
- package/dist/recipes/compiler.js.map +1 -0
- package/dist/recipes/installer.d.ts +25 -0
- package/dist/recipes/installer.js +62 -0
- package/dist/recipes/installer.js.map +1 -0
- package/dist/recipes/parser.d.ts +18 -0
- package/dist/recipes/parser.js +160 -0
- package/dist/recipes/parser.js.map +1 -0
- package/dist/recipes/scheduler.d.ts +45 -0
- package/dist/recipes/scheduler.js +110 -0
- package/dist/recipes/scheduler.js.map +1 -0
- package/dist/recipes/schema.d.ts +71 -0
- package/dist/recipes/schema.js +11 -0
- package/dist/recipes/schema.js.map +1 -0
- package/dist/recipesHttp.d.ts +63 -0
- package/dist/recipesHttp.js +183 -0
- package/dist/recipesHttp.js.map +1 -0
- package/dist/resources.d.ts +33 -0
- package/dist/resources.js +266 -0
- package/dist/resources.js.map +1 -0
- package/dist/riskTier.d.ts +40 -0
- package/dist/riskTier.js +142 -0
- package/dist/riskTier.js.map +1 -0
- package/dist/runLog.d.ts +90 -0
- package/dist/runLog.js +143 -0
- package/dist/runLog.js.map +1 -0
- package/dist/server.d.ts +160 -0
- package/dist/server.js +1244 -0
- package/dist/server.js.map +1 -0
- package/dist/sessionCheckpoint.d.ts +37 -0
- package/dist/sessionCheckpoint.js +123 -0
- package/dist/sessionCheckpoint.js.map +1 -0
- package/dist/streamableHttp.d.ts +86 -0
- package/dist/streamableHttp.js +702 -0
- package/dist/streamableHttp.js.map +1 -0
- package/dist/telemetry.d.ts +18 -0
- package/dist/telemetry.js +95 -0
- package/dist/telemetry.js.map +1 -0
- package/dist/tools/activityLog.d.ts +140 -0
- package/dist/tools/activityLog.js +204 -0
- package/dist/tools/activityLog.js.map +1 -0
- package/dist/tools/auditDependencies.d.ts +67 -0
- package/dist/tools/auditDependencies.js +298 -0
- package/dist/tools/auditDependencies.js.map +1 -0
- package/dist/tools/batchLsp.d.ts +262 -0
- package/dist/tools/batchLsp.js +328 -0
- package/dist/tools/batchLsp.js.map +1 -0
- package/dist/tools/blame-utils.d.ts +30 -0
- package/dist/tools/blame-utils.js +60 -0
- package/dist/tools/blame-utils.js.map +1 -0
- package/dist/tools/bridgeDoctor.d.ts +78 -0
- package/dist/tools/bridgeDoctor.js +542 -0
- package/dist/tools/bridgeDoctor.js.map +1 -0
- package/dist/tools/bridgeStatus.d.ts +122 -0
- package/dist/tools/bridgeStatus.js +250 -0
- package/dist/tools/bridgeStatus.js.map +1 -0
- package/dist/tools/cancelClaudeTask.d.ts +48 -0
- package/dist/tools/cancelClaudeTask.js +56 -0
- package/dist/tools/cancelClaudeTask.js.map +1 -0
- package/dist/tools/checkDocumentDirty.d.ts +56 -0
- package/dist/tools/checkDocumentDirty.js +74 -0
- package/dist/tools/checkDocumentDirty.js.map +1 -0
- package/dist/tools/clipboard.d.ts +80 -0
- package/dist/tools/clipboard.js +211 -0
- package/dist/tools/clipboard.js.map +1 -0
- package/dist/tools/closeTabs.d.ts +84 -0
- package/dist/tools/closeTabs.js +97 -0
- package/dist/tools/closeTabs.js.map +1 -0
- package/dist/tools/codeLens.d.ts +50 -0
- package/dist/tools/codeLens.js +47 -0
- package/dist/tools/codeLens.js.map +1 -0
- package/dist/tools/contextBundle.d.ts +75 -0
- package/dist/tools/contextBundle.js +218 -0
- package/dist/tools/contextBundle.js.map +1 -0
- package/dist/tools/createIssueFromAIComment.d.ts +75 -0
- package/dist/tools/createIssueFromAIComment.js +119 -0
- package/dist/tools/createIssueFromAIComment.js.map +1 -0
- package/dist/tools/ctxGetTaskContext.d.ts +103 -0
- package/dist/tools/ctxGetTaskContext.js +274 -0
- package/dist/tools/ctxGetTaskContext.js.map +1 -0
- package/dist/tools/ctxQueryTraces.d.ts +142 -0
- package/dist/tools/ctxQueryTraces.js +194 -0
- package/dist/tools/ctxQueryTraces.js.map +1 -0
- package/dist/tools/ctxSaveTrace.d.ts +87 -0
- package/dist/tools/ctxSaveTrace.js +94 -0
- package/dist/tools/ctxSaveTrace.js.map +1 -0
- package/dist/tools/debug.d.ts +206 -0
- package/dist/tools/debug.js +234 -0
- package/dist/tools/debug.js.map +1 -0
- package/dist/tools/decorations.d.ts +130 -0
- package/dist/tools/decorations.js +160 -0
- package/dist/tools/decorations.js.map +1 -0
- package/dist/tools/detectUnusedCode.d.ts +78 -0
- package/dist/tools/detectUnusedCode.js +173 -0
- package/dist/tools/detectUnusedCode.js.map +1 -0
- package/dist/tools/documentLinks.d.ts +62 -0
- package/dist/tools/documentLinks.js +55 -0
- package/dist/tools/documentLinks.js.map +1 -0
- package/dist/tools/editText.d.ts +108 -0
- package/dist/tools/editText.js +318 -0
- package/dist/tools/editText.js.map +1 -0
- package/dist/tools/enrichCommit.d.ts +89 -0
- package/dist/tools/enrichCommit.js +201 -0
- package/dist/tools/enrichCommit.js.map +1 -0
- package/dist/tools/enrichStackTrace.d.ts +121 -0
- package/dist/tools/enrichStackTrace.js +194 -0
- package/dist/tools/enrichStackTrace.js.map +1 -0
- package/dist/tools/explainDiagnostic.d.ts +137 -0
- package/dist/tools/explainDiagnostic.js +230 -0
- package/dist/tools/explainDiagnostic.js.map +1 -0
- package/dist/tools/explainSymbol.d.ts +119 -0
- package/dist/tools/explainSymbol.js +177 -0
- package/dist/tools/explainSymbol.js.map +1 -0
- package/dist/tools/fileOperations.d.ts +186 -0
- package/dist/tools/fileOperations.js +330 -0
- package/dist/tools/fileOperations.js.map +1 -0
- package/dist/tools/fileWatcher.d.ts +107 -0
- package/dist/tools/fileWatcher.js +121 -0
- package/dist/tools/fileWatcher.js.map +1 -0
- package/dist/tools/findFiles.d.ts +65 -0
- package/dist/tools/findFiles.js +142 -0
- package/dist/tools/findFiles.js.map +1 -0
- package/dist/tools/findRelatedTests.d.ts +83 -0
- package/dist/tools/findRelatedTests.js +196 -0
- package/dist/tools/findRelatedTests.js.map +1 -0
- package/dist/tools/fixAllLintErrors.d.ts +66 -0
- package/dist/tools/fixAllLintErrors.js +128 -0
- package/dist/tools/fixAllLintErrors.js.map +1 -0
- package/dist/tools/foldingRanges.d.ts +50 -0
- package/dist/tools/foldingRanges.js +51 -0
- package/dist/tools/foldingRanges.js.map +1 -0
- package/dist/tools/formatAndSave.d.ts +57 -0
- package/dist/tools/formatAndSave.js +87 -0
- package/dist/tools/formatAndSave.js.map +1 -0
- package/dist/tools/formatDocument.d.ts +61 -0
- package/dist/tools/formatDocument.js +144 -0
- package/dist/tools/formatDocument.js.map +1 -0
- package/dist/tools/generateAPIDocumentation.d.ts +62 -0
- package/dist/tools/generateAPIDocumentation.js +249 -0
- package/dist/tools/generateAPIDocumentation.js.map +1 -0
- package/dist/tools/generateTests.d.ts +75 -0
- package/dist/tools/generateTests.js +226 -0
- package/dist/tools/generateTests.js.map +1 -0
- package/dist/tools/getAIComments.d.ts +79 -0
- package/dist/tools/getAIComments.js +93 -0
- package/dist/tools/getAIComments.js.map +1 -0
- package/dist/tools/getAnalyticsReport.d.ts +102 -0
- package/dist/tools/getAnalyticsReport.js +137 -0
- package/dist/tools/getAnalyticsReport.js.map +1 -0
- package/dist/tools/getArchitectureContext.d.ts +85 -0
- package/dist/tools/getArchitectureContext.js +135 -0
- package/dist/tools/getArchitectureContext.js.map +1 -0
- package/dist/tools/getBufferContent.d.ts +80 -0
- package/dist/tools/getBufferContent.js +207 -0
- package/dist/tools/getBufferContent.js.map +1 -0
- package/dist/tools/getChangeImpact.d.ts +76 -0
- package/dist/tools/getChangeImpact.js +184 -0
- package/dist/tools/getChangeImpact.js.map +1 -0
- package/dist/tools/getClaudeTaskStatus.d.ts +87 -0
- package/dist/tools/getClaudeTaskStatus.js +89 -0
- package/dist/tools/getClaudeTaskStatus.js.map +1 -0
- package/dist/tools/getCodeCoverage.d.ts +86 -0
- package/dist/tools/getCodeCoverage.js +237 -0
- package/dist/tools/getCodeCoverage.js.map +1 -0
- package/dist/tools/getCommitsForIssue.d.ts +98 -0
- package/dist/tools/getCommitsForIssue.js +106 -0
- package/dist/tools/getCommitsForIssue.js.map +1 -0
- package/dist/tools/getCurrentSelection.d.ts +123 -0
- package/dist/tools/getCurrentSelection.js +113 -0
- package/dist/tools/getCurrentSelection.js.map +1 -0
- package/dist/tools/getDebugState.d.ts +140 -0
- package/dist/tools/getDebugState.js +109 -0
- package/dist/tools/getDebugState.js.map +1 -0
- package/dist/tools/getDependencyTree.d.ts +59 -0
- package/dist/tools/getDependencyTree.js +207 -0
- package/dist/tools/getDependencyTree.js.map +1 -0
- package/dist/tools/getDiagnostics.d.ts +108 -0
- package/dist/tools/getDiagnostics.js +371 -0
- package/dist/tools/getDiagnostics.js.map +1 -0
- package/dist/tools/getDiffFromHandoff.d.ts +89 -0
- package/dist/tools/getDiffFromHandoff.js +163 -0
- package/dist/tools/getDiffFromHandoff.js.map +1 -0
- package/dist/tools/getDocumentSymbols.d.ts +74 -0
- package/dist/tools/getDocumentSymbols.js +177 -0
- package/dist/tools/getDocumentSymbols.js.map +1 -0
- package/dist/tools/getFileTree.d.ts +66 -0
- package/dist/tools/getFileTree.js +131 -0
- package/dist/tools/getFileTree.js.map +1 -0
- package/dist/tools/getGitDiff.d.ts +50 -0
- package/dist/tools/getGitDiff.js +73 -0
- package/dist/tools/getGitDiff.js.map +1 -0
- package/dist/tools/getGitHotspots.d.ts +88 -0
- package/dist/tools/getGitHotspots.js +145 -0
- package/dist/tools/getGitHotspots.js.map +1 -0
- package/dist/tools/getGitLog.d.ts +62 -0
- package/dist/tools/getGitLog.js +87 -0
- package/dist/tools/getGitLog.js.map +1 -0
- package/dist/tools/getGitStatus.d.ts +72 -0
- package/dist/tools/getGitStatus.js +126 -0
- package/dist/tools/getGitStatus.js.map +1 -0
- package/dist/tools/getImportTree.d.ts +73 -0
- package/dist/tools/getImportTree.js +223 -0
- package/dist/tools/getImportTree.js.map +1 -0
- package/dist/tools/getImportedSignatures.d.ts +62 -0
- package/dist/tools/getImportedSignatures.js +255 -0
- package/dist/tools/getImportedSignatures.js.map +1 -0
- package/dist/tools/getOpenEditors.d.ts +62 -0
- package/dist/tools/getOpenEditors.js +126 -0
- package/dist/tools/getOpenEditors.js.map +1 -0
- package/dist/tools/getPRTemplate.d.ts +68 -0
- package/dist/tools/getPRTemplate.js +187 -0
- package/dist/tools/getPRTemplate.js.map +1 -0
- package/dist/tools/getProjectContext.d.ts +114 -0
- package/dist/tools/getProjectContext.js +344 -0
- package/dist/tools/getProjectContext.js.map +1 -0
- package/dist/tools/getProjectInfo.d.ts +51 -0
- package/dist/tools/getProjectInfo.js +325 -0
- package/dist/tools/getProjectInfo.js.map +1 -0
- package/dist/tools/getSecurityAdvisories.d.ts +105 -0
- package/dist/tools/getSecurityAdvisories.js +472 -0
- package/dist/tools/getSecurityAdvisories.js.map +1 -0
- package/dist/tools/getSessionUsage.d.ts +58 -0
- package/dist/tools/getSessionUsage.js +57 -0
- package/dist/tools/getSessionUsage.js.map +1 -0
- package/dist/tools/getSymbolHistory.d.ts +157 -0
- package/dist/tools/getSymbolHistory.js +256 -0
- package/dist/tools/getSymbolHistory.js.map +1 -0
- package/dist/tools/getToolCapabilities.d.ts +69 -0
- package/dist/tools/getToolCapabilities.js +298 -0
- package/dist/tools/getToolCapabilities.js.map +1 -0
- package/dist/tools/getTypeSignature.d.ts +70 -0
- package/dist/tools/getTypeSignature.js +132 -0
- package/dist/tools/getTypeSignature.js.map +1 -0
- package/dist/tools/getWorkspaceFolders.d.ts +58 -0
- package/dist/tools/getWorkspaceFolders.js +69 -0
- package/dist/tools/getWorkspaceFolders.js.map +1 -0
- package/dist/tools/getWorkspaceSettings.d.ts +44 -0
- package/dist/tools/getWorkspaceSettings.js +70 -0
- package/dist/tools/getWorkspaceSettings.js.map +1 -0
- package/dist/tools/git-utils.d.ts +16 -0
- package/dist/tools/git-utils.js +46 -0
- package/dist/tools/git-utils.js.map +1 -0
- package/dist/tools/gitHistory.d.ts +110 -0
- package/dist/tools/gitHistory.js +167 -0
- package/dist/tools/gitHistory.js.map +1 -0
- package/dist/tools/gitWrite.d.ts +612 -0
- package/dist/tools/gitWrite.js +983 -0
- package/dist/tools/gitWrite.js.map +1 -0
- package/dist/tools/github/actions.d.ts +152 -0
- package/dist/tools/github/actions.js +195 -0
- package/dist/tools/github/actions.js.map +1 -0
- package/dist/tools/github/index.d.ts +3 -0
- package/dist/tools/github/index.js +4 -0
- package/dist/tools/github/index.js.map +1 -0
- package/dist/tools/github/issues.d.ts +281 -0
- package/dist/tools/github/issues.js +340 -0
- package/dist/tools/github/issues.js.map +1 -0
- package/dist/tools/github/pr.d.ts +433 -0
- package/dist/tools/github/pr.js +588 -0
- package/dist/tools/github/pr.js.map +1 -0
- package/dist/tools/github/shared.d.ts +4 -0
- package/dist/tools/github/shared.js +12 -0
- package/dist/tools/github/shared.js.map +1 -0
- package/dist/tools/handoffNote.d.ts +106 -0
- package/dist/tools/handoffNote.js +232 -0
- package/dist/tools/handoffNote.js.map +1 -0
- package/dist/tools/headless/lspClient.d.ts +26 -0
- package/dist/tools/headless/lspClient.js +221 -0
- package/dist/tools/headless/lspClient.js.map +1 -0
- package/dist/tools/headless/lspFallback.d.ts +28 -0
- package/dist/tools/headless/lspFallback.js +122 -0
- package/dist/tools/headless/lspFallback.js.map +1 -0
- package/dist/tools/hoverAtCursor.d.ts +54 -0
- package/dist/tools/hoverAtCursor.js +68 -0
- package/dist/tools/hoverAtCursor.js.map +1 -0
- package/dist/tools/httpClient.d.ts +141 -0
- package/dist/tools/httpClient.js +486 -0
- package/dist/tools/httpClient.js.map +1 -0
- package/dist/tools/index.d.ts +49 -0
- package/dist/tools/index.js +672 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/inlayHints.d.ts +81 -0
- package/dist/tools/inlayHints.js +76 -0
- package/dist/tools/inlayHints.js.map +1 -0
- package/dist/tools/issueRefs.d.ts +14 -0
- package/dist/tools/issueRefs.js +27 -0
- package/dist/tools/issueRefs.js.map +1 -0
- package/dist/tools/jumpToFirstError.d.ts +63 -0
- package/dist/tools/jumpToFirstError.js +124 -0
- package/dist/tools/jumpToFirstError.js.map +1 -0
- package/dist/tools/launchQuickTask.d.ts +76 -0
- package/dist/tools/launchQuickTask.js +170 -0
- package/dist/tools/launchQuickTask.js.map +1 -0
- package/dist/tools/linters/biome.d.ts +2 -0
- package/dist/tools/linters/biome.js +44 -0
- package/dist/tools/linters/biome.js.map +1 -0
- package/dist/tools/linters/cargo.d.ts +2 -0
- package/dist/tools/linters/cargo.js +45 -0
- package/dist/tools/linters/cargo.js.map +1 -0
- package/dist/tools/linters/eslint.d.ts +2 -0
- package/dist/tools/linters/eslint.js +59 -0
- package/dist/tools/linters/eslint.js.map +1 -0
- package/dist/tools/linters/govet.d.ts +2 -0
- package/dist/tools/linters/govet.js +37 -0
- package/dist/tools/linters/govet.js.map +1 -0
- package/dist/tools/linters/pyright.d.ts +2 -0
- package/dist/tools/linters/pyright.js +34 -0
- package/dist/tools/linters/pyright.js.map +1 -0
- package/dist/tools/linters/ruff.d.ts +2 -0
- package/dist/tools/linters/ruff.js +30 -0
- package/dist/tools/linters/ruff.js.map +1 -0
- package/dist/tools/linters/types.d.ts +16 -0
- package/dist/tools/linters/types.js +2 -0
- package/dist/tools/linters/types.js.map +1 -0
- package/dist/tools/linters/typescript.d.ts +2 -0
- package/dist/tools/linters/typescript.js +38 -0
- package/dist/tools/linters/typescript.js.map +1 -0
- package/dist/tools/listClaudeTasks.d.ts +84 -0
- package/dist/tools/listClaudeTasks.js +88 -0
- package/dist/tools/listClaudeTasks.js.map +1 -0
- package/dist/tools/listTerminals.d.ts +55 -0
- package/dist/tools/listTerminals.js +78 -0
- package/dist/tools/listTerminals.js.map +1 -0
- package/dist/tools/lsp.d.ts +1086 -0
- package/dist/tools/lsp.js +1339 -0
- package/dist/tools/lsp.js.map +1 -0
- package/dist/tools/navigateToSymbolByName.d.ts +56 -0
- package/dist/tools/navigateToSymbolByName.js +170 -0
- package/dist/tools/navigateToSymbolByName.js.map +1 -0
- package/dist/tools/openDiff.d.ts +66 -0
- package/dist/tools/openDiff.js +126 -0
- package/dist/tools/openDiff.js.map +1 -0
- package/dist/tools/openFile.d.ts +69 -0
- package/dist/tools/openFile.js +129 -0
- package/dist/tools/openFile.js.map +1 -0
- package/dist/tools/openInBrowser.d.ts +55 -0
- package/dist/tools/openInBrowser.js +129 -0
- package/dist/tools/openInBrowser.js.map +1 -0
- package/dist/tools/organizeImports.d.ts +56 -0
- package/dist/tools/organizeImports.js +115 -0
- package/dist/tools/organizeImports.js.map +1 -0
- package/dist/tools/performanceReport.d.ts +133 -0
- package/dist/tools/performanceReport.js +218 -0
- package/dist/tools/performanceReport.js.map +1 -0
- package/dist/tools/planPersistence.d.ts +306 -0
- package/dist/tools/planPersistence.js +485 -0
- package/dist/tools/planPersistence.js.map +1 -0
- package/dist/tools/previewEdit.d.ts +107 -0
- package/dist/tools/previewEdit.js +270 -0
- package/dist/tools/previewEdit.js.map +1 -0
- package/dist/tools/recentTracesDigest.d.ts +35 -0
- package/dist/tools/recentTracesDigest.js +98 -0
- package/dist/tools/recentTracesDigest.js.map +1 -0
- package/dist/tools/refactorAnalyze.d.ts +78 -0
- package/dist/tools/refactorAnalyze.js +141 -0
- package/dist/tools/refactorAnalyze.js.map +1 -0
- package/dist/tools/refactorExtractFunction.d.ts +52 -0
- package/dist/tools/refactorExtractFunction.js +121 -0
- package/dist/tools/refactorExtractFunction.js.map +1 -0
- package/dist/tools/refactorPreview.d.ts +75 -0
- package/dist/tools/refactorPreview.js +93 -0
- package/dist/tools/refactorPreview.js.map +1 -0
- package/dist/tools/replaceBlock.d.ts +62 -0
- package/dist/tools/replaceBlock.js +125 -0
- package/dist/tools/replaceBlock.js.map +1 -0
- package/dist/tools/resumeClaudeTask.d.ts +75 -0
- package/dist/tools/resumeClaudeTask.js +149 -0
- package/dist/tools/resumeClaudeTask.js.map +1 -0
- package/dist/tools/runClaudeTask.d.ts +97 -0
- package/dist/tools/runClaudeTask.js +224 -0
- package/dist/tools/runClaudeTask.js.map +1 -0
- package/dist/tools/runCommand.d.ts +82 -0
- package/dist/tools/runCommand.js +101 -0
- package/dist/tools/runCommand.js.map +1 -0
- package/dist/tools/runTests.d.ts +146 -0
- package/dist/tools/runTests.js +315 -0
- package/dist/tools/runTests.js.map +1 -0
- package/dist/tools/saveDocument.d.ts +50 -0
- package/dist/tools/saveDocument.js +73 -0
- package/dist/tools/saveDocument.js.map +1 -0
- package/dist/tools/screenshot.d.ts +23 -0
- package/dist/tools/screenshot.js +43 -0
- package/dist/tools/screenshot.js.map +1 -0
- package/dist/tools/screenshotAndAnnotate.d.ts +103 -0
- package/dist/tools/screenshotAndAnnotate.js +192 -0
- package/dist/tools/screenshotAndAnnotate.js.map +1 -0
- package/dist/tools/searchAndReplace.d.ts +108 -0
- package/dist/tools/searchAndReplace.js +281 -0
- package/dist/tools/searchAndReplace.js.map +1 -0
- package/dist/tools/searchTools.d.ts +61 -0
- package/dist/tools/searchTools.js +85 -0
- package/dist/tools/searchTools.js.map +1 -0
- package/dist/tools/searchWorkspace.d.ts +99 -0
- package/dist/tools/searchWorkspace.js +189 -0
- package/dist/tools/searchWorkspace.js.map +1 -0
- package/dist/tools/selectionRanges.d.ts +58 -0
- package/dist/tools/selectionRanges.js +61 -0
- package/dist/tools/selectionRanges.js.map +1 -0
- package/dist/tools/semanticTokens.d.ts +87 -0
- package/dist/tools/semanticTokens.js +86 -0
- package/dist/tools/semanticTokens.js.map +1 -0
- package/dist/tools/setActiveWorkspaceFolder.d.ts +41 -0
- package/dist/tools/setActiveWorkspaceFolder.js +38 -0
- package/dist/tools/setActiveWorkspaceFolder.js.map +1 -0
- package/dist/tools/signatureHelp.d.ts +86 -0
- package/dist/tools/signatureHelp.js +79 -0
- package/dist/tools/signatureHelp.js.map +1 -0
- package/dist/tools/spawnWorkspace.d.ts +103 -0
- package/dist/tools/spawnWorkspace.js +268 -0
- package/dist/tools/spawnWorkspace.js.map +1 -0
- package/dist/tools/stackTraceParser.d.ts +43 -0
- package/dist/tools/stackTraceParser.js +139 -0
- package/dist/tools/stackTraceParser.js.map +1 -0
- package/dist/tools/terminal.d.ts +352 -0
- package/dist/tools/terminal.js +670 -0
- package/dist/tools/terminal.js.map +1 -0
- package/dist/tools/testRunners/cargoTest.d.ts +2 -0
- package/dist/tools/testRunners/cargoTest.js +129 -0
- package/dist/tools/testRunners/cargoTest.js.map +1 -0
- package/dist/tools/testRunners/goTest.d.ts +2 -0
- package/dist/tools/testRunners/goTest.js +108 -0
- package/dist/tools/testRunners/goTest.js.map +1 -0
- package/dist/tools/testRunners/pytest.d.ts +2 -0
- package/dist/tools/testRunners/pytest.js +135 -0
- package/dist/tools/testRunners/pytest.js.map +1 -0
- package/dist/tools/testRunners/types.d.ts +18 -0
- package/dist/tools/testRunners/types.js +2 -0
- package/dist/tools/testRunners/types.js.map +1 -0
- package/dist/tools/testRunners/vitestJest.d.ts +3 -0
- package/dist/tools/testRunners/vitestJest.js +215 -0
- package/dist/tools/testRunners/vitestJest.js.map +1 -0
- package/dist/tools/testTraceToSource.d.ts +80 -0
- package/dist/tools/testTraceToSource.js +206 -0
- package/dist/tools/testTraceToSource.js.map +1 -0
- package/dist/tools/transaction.d.ts +243 -0
- package/dist/tools/transaction.js +309 -0
- package/dist/tools/transaction.js.map +1 -0
- package/dist/tools/typeHierarchy.d.ts +77 -0
- package/dist/tools/typeHierarchy.js +86 -0
- package/dist/tools/typeHierarchy.js.map +1 -0
- package/dist/tools/utils.d.ts +124 -0
- package/dist/tools/utils.js +566 -0
- package/dist/tools/utils.js.map +1 -0
- package/dist/tools/vscodeCommands.d.ts +90 -0
- package/dist/tools/vscodeCommands.js +112 -0
- package/dist/tools/vscodeCommands.js.map +1 -0
- package/dist/tools/vscodeTasks.d.ts +102 -0
- package/dist/tools/vscodeTasks.js +110 -0
- package/dist/tools/vscodeTasks.js.map +1 -0
- package/dist/tools/watchDiagnostics.d.ts +64 -0
- package/dist/tools/watchDiagnostics.js +270 -0
- package/dist/tools/watchDiagnostics.js.map +1 -0
- package/dist/tools/workspaceSettings.d.ts +57 -0
- package/dist/tools/workspaceSettings.js +80 -0
- package/dist/tools/workspaceSettings.js.map +1 -0
- package/dist/transport.d.ts +207 -0
- package/dist/transport.js +1272 -0
- package/dist/transport.js.map +1 -0
- package/dist/version.d.ts +13 -0
- package/dist/version.js +31 -0
- package/dist/version.js.map +1 -0
- package/dist/wsUtils.d.ts +8 -0
- package/dist/wsUtils.js +54 -0
- package/dist/wsUtils.js.map +1 -0
- package/package.json +118 -0
- package/scripts/gen-claude-desktop-config.sh +124 -0
- package/scripts/gen-mcp-config.sh +390 -0
- package/scripts/install-extension.sh +106 -0
- package/scripts/mcp-stdio-shim.cjs +482 -0
- package/scripts/postinstall.mjs +68 -0
- package/scripts/start-all.sh +502 -0
- package/scripts/start-orchestrator.sh +186 -0
- package/scripts/start-remote.sh +126 -0
- package/scripts/start-vps.sh +116 -0
- package/templates/CLAUDE.bridge.md +125 -0
- package/templates/automation-policies/security-first.json +46 -0
- package/templates/automation-policies/strict-lint.json +41 -0
- package/templates/automation-policies/test-driven.json +54 -0
- package/templates/automation-policy.example.json +105 -0
- package/templates/bridge-tools.md +111 -0
- package/templates/dispatch-context.md +33 -0
- package/templates/managed-agent/code-review-agent.md +50 -0
- package/templates/managed-agent/managed-agent-mcp.json +102 -0
- package/templates/recipes/ambient-journal.yaml +11 -0
- package/templates/recipes/daily-status.yaml +21 -0
- package/templates/recipes/lint-on-save.yaml +13 -0
- package/templates/recipes/stale-branches.yaml +18 -0
- package/templates/recipes/watch-failing-tests.yaml +15 -0
- package/templates/scheduled-tasks/dependency-audit/SKILL.md +77 -0
- package/templates/scheduled-tasks/health-check/SKILL.md +73 -0
- package/templates/scheduled-tasks/nightly-review/SKILL.md +69 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Pure command-description builder extracted from runCommand.ts.
|
|
3
|
+
* All allowlist/blocklist/path-traversal security checks live here.
|
|
4
|
+
* No side effects, no fs.*, no process.* (except INTERPRETER_COMMANDS import).
|
|
5
|
+
*/
|
|
6
|
+
import { INTERPRETER_COMMANDS } from "../config.js";
|
|
7
|
+
import { optionalInt, optionalString, requireString, resolveFilePath, } from "../tools/utils.js";
|
|
8
|
+
const MAX_ARGS = 100;
|
|
9
|
+
const MAX_ARG_LENGTH = 16_384;
|
|
10
|
+
/** Flags that allow interpreter commands to execute arbitrary code */
|
|
11
|
+
const DANGEROUS_INTERPRETER_FLAGS = new Set([
|
|
12
|
+
"-e",
|
|
13
|
+
"--eval",
|
|
14
|
+
"-c",
|
|
15
|
+
"--print",
|
|
16
|
+
"-p",
|
|
17
|
+
"--input-type",
|
|
18
|
+
"--import",
|
|
19
|
+
"--loader",
|
|
20
|
+
"--experimental-loader",
|
|
21
|
+
"-m",
|
|
22
|
+
"--inspect",
|
|
23
|
+
"--inspect-brk",
|
|
24
|
+
"--inspect-port",
|
|
25
|
+
]);
|
|
26
|
+
/** Flags that redirect where commands read config/manifests from */
|
|
27
|
+
const DANGEROUS_PATH_FLAGS = new Set([
|
|
28
|
+
"--prefix",
|
|
29
|
+
"--manifest-path",
|
|
30
|
+
"--config",
|
|
31
|
+
"--rcfile",
|
|
32
|
+
"--require",
|
|
33
|
+
"--userconfig",
|
|
34
|
+
"--globalconfig",
|
|
35
|
+
"--makefile",
|
|
36
|
+
"-o",
|
|
37
|
+
"--output",
|
|
38
|
+
"-O",
|
|
39
|
+
"--remote-name",
|
|
40
|
+
"-D",
|
|
41
|
+
"--dump-header",
|
|
42
|
+
"-K",
|
|
43
|
+
"--unix-socket",
|
|
44
|
+
"--abstract-unix-socket",
|
|
45
|
+
"--netrc-file",
|
|
46
|
+
]);
|
|
47
|
+
const DANGEROUS_FLAGS_FOR_COMMAND = {
|
|
48
|
+
make: new Set(["-f", "--file"]),
|
|
49
|
+
curl: new Set(["-w", "--write-out"]),
|
|
50
|
+
node: new Set(["-r"]),
|
|
51
|
+
"ts-node": new Set(["-r"]),
|
|
52
|
+
tsx: new Set(["-r"]),
|
|
53
|
+
};
|
|
54
|
+
const PATH_FLAG_EXEMPTIONS = {
|
|
55
|
+
psql: new Set(["--config"]),
|
|
56
|
+
pg_dump: new Set(["--config"]),
|
|
57
|
+
pg_restore: new Set(["--config"]),
|
|
58
|
+
};
|
|
59
|
+
function validateCommandName(command, allowlist) {
|
|
60
|
+
if (command.includes("/") ||
|
|
61
|
+
command.includes("\\") ||
|
|
62
|
+
command.includes("..") ||
|
|
63
|
+
command.includes(" ")) {
|
|
64
|
+
throw new Error(`Invalid command "${command}": must be a simple basename without /, \\, .., or spaces`);
|
|
65
|
+
}
|
|
66
|
+
if (!allowlist.some((entry) => entry.toLowerCase() === command)) {
|
|
67
|
+
throw new Error(`Command "${command}" is not in the allowlist. Use --allow-command ${command} to add it. Run getToolCapabilities to see allowed commands.`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function validateCommandArgs(args, command, workspace) {
|
|
71
|
+
if (args === undefined || args === null)
|
|
72
|
+
return [];
|
|
73
|
+
if (!Array.isArray(args)) {
|
|
74
|
+
throw new Error("args must be an array of strings");
|
|
75
|
+
}
|
|
76
|
+
if (args.length > MAX_ARGS) {
|
|
77
|
+
throw new Error(`args exceeds maximum length of ${MAX_ARGS}`);
|
|
78
|
+
}
|
|
79
|
+
const isInterpreter = INTERPRETER_COMMANDS.has(command);
|
|
80
|
+
for (let i = 0; i < args.length; i++) {
|
|
81
|
+
const arg = args[i];
|
|
82
|
+
if (typeof arg !== "string") {
|
|
83
|
+
throw new Error(`args[${i}] must be a string`);
|
|
84
|
+
}
|
|
85
|
+
if (arg.length > MAX_ARG_LENGTH) {
|
|
86
|
+
throw new Error(`args[${i}] exceeds maximum length of ${MAX_ARG_LENGTH}`);
|
|
87
|
+
}
|
|
88
|
+
const flag = arg.split("=")[0] ?? arg;
|
|
89
|
+
if (isInterpreter && DANGEROUS_INTERPRETER_FLAGS.has(flag)) {
|
|
90
|
+
throw new Error(`Flag "${flag}" is blocked for interpreter command "${command}" — it allows arbitrary code execution`);
|
|
91
|
+
}
|
|
92
|
+
const exemptions = PATH_FLAG_EXEMPTIONS[command];
|
|
93
|
+
if (DANGEROUS_PATH_FLAGS.has(flag) && !exemptions?.has(flag)) {
|
|
94
|
+
throw new Error(`Flag "${flag}" is blocked — it can redirect command execution outside the workspace`);
|
|
95
|
+
}
|
|
96
|
+
if (DANGEROUS_FLAGS_FOR_COMMAND[command]?.has(flag)) {
|
|
97
|
+
throw new Error(`Flag "${flag}" is blocked for command "${command}" — it can redirect command execution outside the workspace`);
|
|
98
|
+
}
|
|
99
|
+
if (!arg.startsWith("-") && (arg.startsWith("/") || arg.startsWith("~/"))) {
|
|
100
|
+
try {
|
|
101
|
+
resolveFilePath(arg, workspace);
|
|
102
|
+
}
|
|
103
|
+
catch {
|
|
104
|
+
throw new Error(`args[${i}] "${arg}" is an absolute path outside the workspace`);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return args;
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Validate raw tool arguments and return an immutable command description.
|
|
112
|
+
* Throws on any security violation (allowlist, blocklist, path-traversal).
|
|
113
|
+
* All security checks are performed here — executeCommand receives a trusted descriptor.
|
|
114
|
+
*/
|
|
115
|
+
export function buildCommandDescription(rawArgs, config, workspace) {
|
|
116
|
+
const command = requireString(rawArgs, "command", 256).toLowerCase();
|
|
117
|
+
validateCommandName(command, config.commandAllowlist);
|
|
118
|
+
const args = validateCommandArgs(rawArgs.args, command, workspace);
|
|
119
|
+
const cwdRaw = optionalString(rawArgs, "cwd");
|
|
120
|
+
const timeout = optionalInt(rawArgs, "timeout", 1000, 600_000) ?? config.commandTimeout;
|
|
121
|
+
const cwd = cwdRaw ? resolveFilePath(cwdRaw, workspace) : workspace;
|
|
122
|
+
const maxBuffer = config.maxResultSize * 1024;
|
|
123
|
+
return { command, args, cwd, timeout, maxBuffer };
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=commandDescription.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commandDescription.js","sourceRoot":"","sources":["../../src/fp/commandDescription.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { AIComment, DebugState, Diagnostic, ExtensionClient, SelectionState } from "../extensionClient.js";
|
|
2
|
+
export interface ExtensionSnapshot {
|
|
3
|
+
readonly diagnostics: ReadonlyMap<string, readonly Diagnostic[]>;
|
|
4
|
+
readonly selection: Readonly<SelectionState> | null;
|
|
5
|
+
readonly activeFile: string | null;
|
|
6
|
+
readonly aiComments: ReadonlyMap<string, readonly AIComment[]>;
|
|
7
|
+
readonly debugState: Readonly<DebugState> | null;
|
|
8
|
+
readonly capturedAt: number;
|
|
9
|
+
}
|
|
10
|
+
export declare function snapshotExtension(client: ExtensionClient): ExtensionSnapshot;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
// CRITICAL: Must deep-copy Maps — ReadonlyMap<K,V> is compile-time only.
|
|
2
|
+
// A notification arriving after snapshot creation would mutate the
|
|
3
|
+
// underlying Map if we just alias it.
|
|
4
|
+
export function snapshotExtension(client) {
|
|
5
|
+
return {
|
|
6
|
+
diagnostics: new Map([...client.latestDiagnostics.entries()].map(([k, v]) => [k, [...v]])),
|
|
7
|
+
selection: client.latestSelection,
|
|
8
|
+
activeFile: client.latestActiveFile,
|
|
9
|
+
aiComments: new Map([...client.latestAIComments.entries()].map(([k, v]) => [k, [...v]])),
|
|
10
|
+
debugState: client.latestDebugState,
|
|
11
|
+
capturedAt: Date.now(),
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=extensionSnapshot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extensionSnapshot.js","sourceRoot":"","sources":["../../src/fp/extensionSnapshot.ts"],"names":[],"mappings":"AAiBA,yEAAyE;AACzE,mEAAmE;AACnE,sCAAsC;AACtC,MAAM,UAAU,iBAAiB,CAAC,MAAuB;IACvD,OAAO;QACL,WAAW,EAAE,IAAI,GAAG,CAClB,CAAC,GAAG,MAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CACrE;QACD,SAAS,EAAE,MAAM,CAAC,eAAe;QACjC,UAAU,EAAE,MAAM,CAAC,gBAAgB;QACnC,UAAU,EAAE,IAAI,GAAG,CACjB,CAAC,GAAG,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CACpE;QACD,UAAU,EAAE,MAAM,CAAC,gBAAgB;QACnC,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE;KACvB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from "./automationInterpreter.js";
|
|
2
|
+
export * from "./automationProgram.js";
|
|
3
|
+
export * from "./automationState.js";
|
|
4
|
+
export * from "./brandedTypes.js";
|
|
5
|
+
export * from "./extensionSnapshot.js";
|
|
6
|
+
export * from "./interpreterContext.js";
|
|
7
|
+
export * from "./policyParser.js";
|
|
8
|
+
export * from "./result.js";
|
package/dist/fp/index.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from "./automationInterpreter.js";
|
|
2
|
+
export * from "./automationProgram.js";
|
|
3
|
+
export * from "./automationState.js";
|
|
4
|
+
export * from "./brandedTypes.js";
|
|
5
|
+
export * from "./extensionSnapshot.js";
|
|
6
|
+
export * from "./interpreterContext.js";
|
|
7
|
+
export * from "./policyParser.js";
|
|
8
|
+
export * from "./result.js";
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/fp/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* InterpreterContext — backend interface + concrete implementations for the
|
|
3
|
+
* AutomationProgram interpreter.
|
|
4
|
+
*/
|
|
5
|
+
import type { ClaudeOrchestrator } from "../claudeOrchestrator.js";
|
|
6
|
+
import type { AutomationState } from "./automationState.js";
|
|
7
|
+
export interface BackendEnqueueOpts {
|
|
8
|
+
prompt: string;
|
|
9
|
+
triggerSource: string;
|
|
10
|
+
sessionId: string;
|
|
11
|
+
isAutomationTask: true;
|
|
12
|
+
model?: string;
|
|
13
|
+
effort?: "low" | "medium" | "high" | "max";
|
|
14
|
+
systemPrompt?: string;
|
|
15
|
+
}
|
|
16
|
+
export interface Backend {
|
|
17
|
+
/** Enqueue a task and return the task ID. */
|
|
18
|
+
enqueueTask(opts: BackendEnqueueOpts): Promise<string>;
|
|
19
|
+
/** Schedule a retry after delayMs; returns a cancel function. */
|
|
20
|
+
scheduleRetry(key: string, delayMs: number, fn: () => void): () => void;
|
|
21
|
+
/** Emit an informational notification (fire-and-forget). */
|
|
22
|
+
notify(msg: string): void;
|
|
23
|
+
}
|
|
24
|
+
export interface InterpreterContext {
|
|
25
|
+
readonly state: AutomationState;
|
|
26
|
+
readonly now: number;
|
|
27
|
+
/** The event type that triggered this interpreter run (e.g. "onFileSave"). */
|
|
28
|
+
readonly eventType: string;
|
|
29
|
+
readonly eventData: Readonly<Record<string, string>>;
|
|
30
|
+
readonly backend: Backend;
|
|
31
|
+
readonly log: (msg: string) => void;
|
|
32
|
+
}
|
|
33
|
+
export interface InterpreterResult {
|
|
34
|
+
readonly taskIds: ReadonlyArray<string>;
|
|
35
|
+
readonly skipped: ReadonlyArray<{
|
|
36
|
+
reason: string;
|
|
37
|
+
hook: string;
|
|
38
|
+
}>;
|
|
39
|
+
readonly errors: ReadonlyArray<{
|
|
40
|
+
message: string;
|
|
41
|
+
hook: string;
|
|
42
|
+
}>;
|
|
43
|
+
readonly updatedState: AutomationState;
|
|
44
|
+
}
|
|
45
|
+
export declare class VsCodeBackend implements Backend {
|
|
46
|
+
private readonly orchestrator;
|
|
47
|
+
private readonly logger?;
|
|
48
|
+
constructor(orchestrator: ClaudeOrchestrator, logger?: {
|
|
49
|
+
info: (msg: string) => void;
|
|
50
|
+
} | undefined);
|
|
51
|
+
enqueueTask(opts: BackendEnqueueOpts): Promise<string>;
|
|
52
|
+
scheduleRetry(key: string, delayMs: number, fn: () => void): () => void;
|
|
53
|
+
notify(msg: string): void;
|
|
54
|
+
}
|
|
55
|
+
export interface TestBackendCollector {
|
|
56
|
+
enqueuedTasks: BackendEnqueueOpts[];
|
|
57
|
+
scheduledRetries: Array<{
|
|
58
|
+
key: string;
|
|
59
|
+
delayMs: number;
|
|
60
|
+
}>;
|
|
61
|
+
notifications: string[];
|
|
62
|
+
}
|
|
63
|
+
export declare class TestBackend implements Backend {
|
|
64
|
+
readonly collector: TestBackendCollector;
|
|
65
|
+
enqueueTask(opts: BackendEnqueueOpts): Promise<string>;
|
|
66
|
+
scheduleRetry(key: string, delayMs: number, _fn: () => void): () => void;
|
|
67
|
+
notify(msg: string): void;
|
|
68
|
+
reset(): void;
|
|
69
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
// ── VsCodeBackend ─────────────────────────────────────────────────────────────
|
|
2
|
+
export class VsCodeBackend {
|
|
3
|
+
orchestrator;
|
|
4
|
+
logger;
|
|
5
|
+
constructor(orchestrator, logger) {
|
|
6
|
+
this.orchestrator = orchestrator;
|
|
7
|
+
this.logger = logger;
|
|
8
|
+
}
|
|
9
|
+
async enqueueTask(opts) {
|
|
10
|
+
const taskId = this.orchestrator.enqueue({
|
|
11
|
+
prompt: opts.prompt,
|
|
12
|
+
sessionId: opts.sessionId,
|
|
13
|
+
isAutomationTask: opts.isAutomationTask,
|
|
14
|
+
triggerSource: opts.triggerSource,
|
|
15
|
+
model: opts.model,
|
|
16
|
+
effort: opts.effort,
|
|
17
|
+
systemPrompt: opts.systemPrompt,
|
|
18
|
+
});
|
|
19
|
+
return taskId;
|
|
20
|
+
}
|
|
21
|
+
scheduleRetry(key, delayMs, fn) {
|
|
22
|
+
const handle = setTimeout(() => {
|
|
23
|
+
this.logger?.info(`[automation] retrying ${key}`);
|
|
24
|
+
fn();
|
|
25
|
+
}, delayMs);
|
|
26
|
+
return () => clearTimeout(handle);
|
|
27
|
+
}
|
|
28
|
+
notify(msg) {
|
|
29
|
+
this.logger?.info(msg);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export class TestBackend {
|
|
33
|
+
collector = {
|
|
34
|
+
enqueuedTasks: [],
|
|
35
|
+
scheduledRetries: [],
|
|
36
|
+
notifications: [],
|
|
37
|
+
};
|
|
38
|
+
async enqueueTask(opts) {
|
|
39
|
+
this.collector.enqueuedTasks.push(opts);
|
|
40
|
+
return `task-${this.collector.enqueuedTasks.length}`;
|
|
41
|
+
}
|
|
42
|
+
scheduleRetry(key, delayMs, _fn) {
|
|
43
|
+
this.collector.scheduledRetries.push({ key, delayMs });
|
|
44
|
+
// Do not actually schedule in test environment
|
|
45
|
+
return () => { };
|
|
46
|
+
}
|
|
47
|
+
notify(msg) {
|
|
48
|
+
this.collector.notifications.push(msg);
|
|
49
|
+
}
|
|
50
|
+
reset() {
|
|
51
|
+
this.collector.enqueuedTasks = [];
|
|
52
|
+
this.collector.scheduledRetries = [];
|
|
53
|
+
this.collector.notifications = [];
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=interpreterContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interpreterContext.js","sourceRoot":"","sources":["../../src/fp/interpreterContext.ts"],"names":[],"mappings":"AAiDA,iFAAiF;AAEjF,MAAM,OAAO,aAAa;IAEL;IACA;IAFnB,YACmB,YAAgC,EAChC,MAAwC;QADxC,iBAAY,GAAZ,YAAY,CAAoB;QAChC,WAAM,GAAN,MAAM,CAAkC;IACxD,CAAC;IAEJ,KAAK,CAAC,WAAW,CAAC,IAAwB;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;YACvC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa,CAAC,GAAW,EAAE,OAAe,EAAE,EAAc;QACxD,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,yBAAyB,GAAG,EAAE,CAAC,CAAC;YAClD,EAAE,EAAE,CAAC;QACP,CAAC,EAAE,OAAO,CAAC,CAAC;QACZ,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;CACF;AAUD,MAAM,OAAO,WAAW;IACb,SAAS,GAAyB;QACzC,aAAa,EAAE,EAAE;QACjB,gBAAgB,EAAE,EAAE;QACpB,aAAa,EAAE,EAAE;KAClB,CAAC;IAEF,KAAK,CAAC,WAAW,CAAC,IAAwB;QACxC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxC,OAAO,QAAQ,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;IACvD,CAAC;IAED,aAAa,CAAC,GAAW,EAAE,OAAe,EAAE,GAAe;QACzD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC;QACvD,+CAA+C;QAC/C,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,EAAE,CAAC;QAClC,IAAI,CAAC,SAAS,CAAC,gBAAgB,GAAG,EAAE,CAAC;QACrC,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,EAAE,CAAC;IACpC,CAAC;CACF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* policyParser — converts a validated AutomationPolicy object into an
|
|
3
|
+
* AutomationProgram[] (the functional DSL).
|
|
4
|
+
*
|
|
5
|
+
* Pure function — no I/O, no Date.now().
|
|
6
|
+
*/
|
|
7
|
+
import type { AutomationPolicy } from "../automation.js";
|
|
8
|
+
import { type AutomationProgram } from "./automationProgram.js";
|
|
9
|
+
import { type ToolResult } from "./result.js";
|
|
10
|
+
/**
|
|
11
|
+
* Parse an already-validated AutomationPolicy into an AutomationProgram[].
|
|
12
|
+
*
|
|
13
|
+
* Returns ok([]) for an empty policy.
|
|
14
|
+
* Returns err("invalid_arg", ...) if any hook is misconfigured.
|
|
15
|
+
*/
|
|
16
|
+
export declare function parsePolicy(policy: AutomationPolicy): ToolResult<AutomationProgram[]>;
|
|
@@ -0,0 +1,334 @@
|
|
|
1
|
+
import { hook, withCooldown, withDedup, withRateLimit, withRetry, } from "./automationProgram.js";
|
|
2
|
+
import { err, ok } from "./result.js";
|
|
3
|
+
// ── Cooldown key per hook type ────────────────────────────────────────────────
|
|
4
|
+
function cooldownKey(hookType, condition) {
|
|
5
|
+
switch (hookType) {
|
|
6
|
+
case "onFileSave":
|
|
7
|
+
return `save:${condition ?? "*"}`;
|
|
8
|
+
case "onFileChanged":
|
|
9
|
+
return `change:${condition ?? "*"}`;
|
|
10
|
+
case "onDiagnosticsError":
|
|
11
|
+
return `diagnostics:${condition ?? "*"}`;
|
|
12
|
+
case "onDiagnosticsCleared":
|
|
13
|
+
return `cleared:${condition ?? "*"}`;
|
|
14
|
+
case "onGitCommit":
|
|
15
|
+
return "gitcommit";
|
|
16
|
+
case "onGitPush":
|
|
17
|
+
return "gitpush";
|
|
18
|
+
case "onGitPull":
|
|
19
|
+
return "gitpull";
|
|
20
|
+
case "onBranchCheckout":
|
|
21
|
+
return "checkout";
|
|
22
|
+
case "onPullRequest":
|
|
23
|
+
return "pr";
|
|
24
|
+
case "onTestRun":
|
|
25
|
+
return "testrun";
|
|
26
|
+
case "onTestPassAfterFailure":
|
|
27
|
+
return "testpass";
|
|
28
|
+
case "onTaskCreated":
|
|
29
|
+
return "taskcreated";
|
|
30
|
+
case "onTaskSuccess":
|
|
31
|
+
return "tasksuccess";
|
|
32
|
+
case "onPermissionDenied":
|
|
33
|
+
return "permdenied";
|
|
34
|
+
case "onCwdChanged":
|
|
35
|
+
return "cwdchanged";
|
|
36
|
+
case "onPreCompact":
|
|
37
|
+
return "precompact";
|
|
38
|
+
case "onPostCompact":
|
|
39
|
+
return "postcompact";
|
|
40
|
+
case "onInstructionsLoaded":
|
|
41
|
+
return "instructions";
|
|
42
|
+
case "onDebugSessionStart":
|
|
43
|
+
return "debugstart";
|
|
44
|
+
case "onDebugSessionEnd":
|
|
45
|
+
return "debugend";
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
// ── PromptSource → PromptSourceNode ──────────────────────────────────────────
|
|
49
|
+
function buildPromptSource(src) {
|
|
50
|
+
if (src.prompt !== undefined) {
|
|
51
|
+
return ok({ kind: "inline", prompt: src.prompt });
|
|
52
|
+
}
|
|
53
|
+
if (src.promptName !== undefined) {
|
|
54
|
+
return ok({
|
|
55
|
+
kind: "named",
|
|
56
|
+
promptName: src.promptName,
|
|
57
|
+
promptArgs: src.promptArgs,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
return err("invalid_arg", "Hook must specify either `prompt` or `promptName`");
|
|
61
|
+
}
|
|
62
|
+
// ── WhenCondition mapping ─────────────────────────────────────────────────────
|
|
63
|
+
function buildWhen(src) {
|
|
64
|
+
if (!src.when)
|
|
65
|
+
return undefined;
|
|
66
|
+
const w = src.when;
|
|
67
|
+
const parts = {};
|
|
68
|
+
if (w.minDiagnosticCount !== undefined)
|
|
69
|
+
parts.minDiagnosticCount = w.minDiagnosticCount;
|
|
70
|
+
if (w.diagnosticsMinSeverity !== undefined)
|
|
71
|
+
parts.diagnosticsMinSeverity = w.diagnosticsMinSeverity;
|
|
72
|
+
if (w.testRunnerLastStatus !== undefined)
|
|
73
|
+
parts.testRunnerLastStatus = w.testRunnerLastStatus;
|
|
74
|
+
return Object.keys(parts).length > 0
|
|
75
|
+
? parts
|
|
76
|
+
: undefined;
|
|
77
|
+
}
|
|
78
|
+
// ── Hook builder ──────────────────────────────────────────────────────────────
|
|
79
|
+
function buildHook(hookType, src, enabled, cooldownMs, condition, patterns, extras, model, effort, systemPrompt) {
|
|
80
|
+
const promptSourceResult = buildPromptSource(src);
|
|
81
|
+
if (!promptSourceResult.ok)
|
|
82
|
+
return promptSourceResult;
|
|
83
|
+
const hookNode = hook({
|
|
84
|
+
hookType,
|
|
85
|
+
enabled,
|
|
86
|
+
condition,
|
|
87
|
+
patterns,
|
|
88
|
+
when: buildWhen(src),
|
|
89
|
+
promptSource: promptSourceResult.value,
|
|
90
|
+
model,
|
|
91
|
+
effort,
|
|
92
|
+
systemPrompt,
|
|
93
|
+
extras,
|
|
94
|
+
});
|
|
95
|
+
const key = cooldownKey(hookType, condition);
|
|
96
|
+
// When dedupeByContent is active, the content-based dedup provides its own
|
|
97
|
+
// cooldown window — skip the standard per-file WithCooldown so that
|
|
98
|
+
// diagnostics with different content can fire within the cooldown window.
|
|
99
|
+
const useDedup = hookType === "onDiagnosticsError" &&
|
|
100
|
+
extras?.kind === "diagnosticsError" &&
|
|
101
|
+
extras.dedupeByContent;
|
|
102
|
+
let program = useDedup
|
|
103
|
+
? hookNode
|
|
104
|
+
: withCooldown(key, cooldownMs, hookNode);
|
|
105
|
+
// Wrap WithRetry around WithCooldown if retryCount > 0
|
|
106
|
+
const retryCount = src.retryCount ?? 0;
|
|
107
|
+
if (retryCount > 0) {
|
|
108
|
+
const retryDelayMs = Math.max(5_000, src.retryDelayMs ?? 30_000);
|
|
109
|
+
program = withRetry(key, retryCount, retryDelayMs, program);
|
|
110
|
+
}
|
|
111
|
+
// Wrap WithDedup for diagnostics error with dedupeByContent
|
|
112
|
+
if (useDedup) {
|
|
113
|
+
const dedupCooldown = Math.max(5_000, extras
|
|
114
|
+
.dedupeContentCooldownMs ?? 900_000);
|
|
115
|
+
program = withDedup(`dedup:${key}`, dedupCooldown, program);
|
|
116
|
+
}
|
|
117
|
+
return ok(program);
|
|
118
|
+
}
|
|
119
|
+
// ── Main parser ───────────────────────────────────────────────────────────────
|
|
120
|
+
/**
|
|
121
|
+
* Parse an already-validated AutomationPolicy into an AutomationProgram[].
|
|
122
|
+
*
|
|
123
|
+
* Returns ok([]) for an empty policy.
|
|
124
|
+
* Returns err("invalid_arg", ...) if any hook is misconfigured.
|
|
125
|
+
*/
|
|
126
|
+
export function parsePolicy(policy) {
|
|
127
|
+
const programs = [];
|
|
128
|
+
const defaultModel = policy.defaultModel ?? "claude-haiku-4-5-20251001";
|
|
129
|
+
const defaultEffort = policy.defaultEffort ?? "low";
|
|
130
|
+
const DEFAULT_SYSTEM_PROMPT = "You are a concise automation assistant. " +
|
|
131
|
+
"Respond in \u22645 lines. No preamble. No markdown headers. " +
|
|
132
|
+
"Call the tools listed in the task prompt, then report results only.";
|
|
133
|
+
const defaultSystemPrompt = policy.automationSystemPrompt ?? DEFAULT_SYSTEM_PROMPT;
|
|
134
|
+
// Helper to push a hook or return early on error
|
|
135
|
+
function push(result) {
|
|
136
|
+
if (!result.ok)
|
|
137
|
+
return false;
|
|
138
|
+
programs.push(result.value);
|
|
139
|
+
return true;
|
|
140
|
+
}
|
|
141
|
+
// onDiagnosticsError
|
|
142
|
+
if (policy.onDiagnosticsError?.enabled) {
|
|
143
|
+
const p = policy.onDiagnosticsError;
|
|
144
|
+
const extras = {
|
|
145
|
+
kind: "diagnosticsError",
|
|
146
|
+
diagnosticTypes: p.diagnosticTypes,
|
|
147
|
+
diagnosticsMinSeverity: p.minSeverity,
|
|
148
|
+
dedupeByContent: p.dedupeByContent,
|
|
149
|
+
dedupeContentCooldownMs: p.dedupeContentCooldownMs,
|
|
150
|
+
};
|
|
151
|
+
// Merge minSeverity into the `when` block so the interpreter's evaluateWhen()
|
|
152
|
+
// enforces it at evaluation time (extras are stored but not evaluated by the
|
|
153
|
+
// interpreter — only `when` fields are checked).
|
|
154
|
+
const diagSeverity = p.minSeverity;
|
|
155
|
+
const pWithSeverity = diagSeverity
|
|
156
|
+
? {
|
|
157
|
+
...p,
|
|
158
|
+
when: { ...p.when, diagnosticsMinSeverity: diagSeverity },
|
|
159
|
+
}
|
|
160
|
+
: p;
|
|
161
|
+
const result = buildHook("onDiagnosticsError", pWithSeverity, true, p.cooldownMs, p.condition, undefined, extras, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
162
|
+
if (!result.ok)
|
|
163
|
+
return result;
|
|
164
|
+
push(result);
|
|
165
|
+
}
|
|
166
|
+
// onDiagnosticsCleared
|
|
167
|
+
if (policy.onDiagnosticsCleared?.enabled) {
|
|
168
|
+
const p = policy.onDiagnosticsCleared;
|
|
169
|
+
const result = buildHook("onDiagnosticsCleared", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
170
|
+
if (!result.ok)
|
|
171
|
+
return result;
|
|
172
|
+
push(result);
|
|
173
|
+
}
|
|
174
|
+
// onFileSave
|
|
175
|
+
if (policy.onFileSave?.enabled) {
|
|
176
|
+
const p = policy.onFileSave;
|
|
177
|
+
const result = buildHook("onFileSave", p, true, p.cooldownMs, p.condition, p.patterns, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
178
|
+
if (!result.ok)
|
|
179
|
+
return result;
|
|
180
|
+
push(result);
|
|
181
|
+
}
|
|
182
|
+
// onFileChanged
|
|
183
|
+
if (policy.onFileChanged?.enabled) {
|
|
184
|
+
const p = policy.onFileChanged;
|
|
185
|
+
const result = buildHook("onFileChanged", p, true, p.cooldownMs, p.condition, p.patterns, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
186
|
+
if (!result.ok)
|
|
187
|
+
return result;
|
|
188
|
+
push(result);
|
|
189
|
+
}
|
|
190
|
+
// onPreCompact
|
|
191
|
+
if (policy.onPreCompact?.enabled) {
|
|
192
|
+
const p = policy.onPreCompact;
|
|
193
|
+
const result = buildHook("onPreCompact", p, true, p.cooldownMs, undefined, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
194
|
+
if (!result.ok)
|
|
195
|
+
return result;
|
|
196
|
+
push(result);
|
|
197
|
+
}
|
|
198
|
+
// onPostCompact
|
|
199
|
+
if (policy.onPostCompact?.enabled) {
|
|
200
|
+
const p = policy.onPostCompact;
|
|
201
|
+
const result = buildHook("onPostCompact", p, true, p.cooldownMs, undefined, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
202
|
+
if (!result.ok)
|
|
203
|
+
return result;
|
|
204
|
+
push(result);
|
|
205
|
+
}
|
|
206
|
+
// onInstructionsLoaded
|
|
207
|
+
if (policy.onInstructionsLoaded?.enabled) {
|
|
208
|
+
const p = policy.onInstructionsLoaded;
|
|
209
|
+
const result = buildHook("onInstructionsLoaded", p, true, p.cooldownMs ?? 60_000, undefined, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
210
|
+
if (!result.ok)
|
|
211
|
+
return result;
|
|
212
|
+
push(result);
|
|
213
|
+
}
|
|
214
|
+
// onCwdChanged
|
|
215
|
+
if (policy.onCwdChanged?.enabled) {
|
|
216
|
+
const p = policy.onCwdChanged;
|
|
217
|
+
const result = buildHook("onCwdChanged", p, true, p.cooldownMs, undefined, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
218
|
+
if (!result.ok)
|
|
219
|
+
return result;
|
|
220
|
+
push(result);
|
|
221
|
+
}
|
|
222
|
+
// onTestRun
|
|
223
|
+
if (policy.onTestRun?.enabled) {
|
|
224
|
+
const p = policy.onTestRun;
|
|
225
|
+
const extras = {
|
|
226
|
+
kind: "testRun",
|
|
227
|
+
onFailureOnly: p.onFailureOnly,
|
|
228
|
+
minDuration: p.minDuration,
|
|
229
|
+
};
|
|
230
|
+
const result = buildHook("onTestRun", p, true, p.cooldownMs, p.condition, undefined, extras, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
231
|
+
if (!result.ok)
|
|
232
|
+
return result;
|
|
233
|
+
push(result);
|
|
234
|
+
}
|
|
235
|
+
// onTestPassAfterFailure
|
|
236
|
+
if (policy.onTestPassAfterFailure?.enabled) {
|
|
237
|
+
const p = policy.onTestPassAfterFailure;
|
|
238
|
+
const result = buildHook("onTestPassAfterFailure", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
239
|
+
if (!result.ok)
|
|
240
|
+
return result;
|
|
241
|
+
push(result);
|
|
242
|
+
}
|
|
243
|
+
// onGitCommit
|
|
244
|
+
if (policy.onGitCommit?.enabled) {
|
|
245
|
+
const p = policy.onGitCommit;
|
|
246
|
+
const result = buildHook("onGitCommit", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
247
|
+
if (!result.ok)
|
|
248
|
+
return result;
|
|
249
|
+
push(result);
|
|
250
|
+
}
|
|
251
|
+
// onGitPush
|
|
252
|
+
if (policy.onGitPush?.enabled) {
|
|
253
|
+
const p = policy.onGitPush;
|
|
254
|
+
const result = buildHook("onGitPush", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
255
|
+
if (!result.ok)
|
|
256
|
+
return result;
|
|
257
|
+
push(result);
|
|
258
|
+
}
|
|
259
|
+
// onGitPull
|
|
260
|
+
if (policy.onGitPull?.enabled) {
|
|
261
|
+
const p = policy.onGitPull;
|
|
262
|
+
const result = buildHook("onGitPull", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
263
|
+
if (!result.ok)
|
|
264
|
+
return result;
|
|
265
|
+
push(result);
|
|
266
|
+
}
|
|
267
|
+
// onBranchCheckout
|
|
268
|
+
if (policy.onBranchCheckout?.enabled) {
|
|
269
|
+
const p = policy.onBranchCheckout;
|
|
270
|
+
const result = buildHook("onBranchCheckout", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
271
|
+
if (!result.ok)
|
|
272
|
+
return result;
|
|
273
|
+
push(result);
|
|
274
|
+
}
|
|
275
|
+
// onPullRequest
|
|
276
|
+
if (policy.onPullRequest?.enabled) {
|
|
277
|
+
const p = policy.onPullRequest;
|
|
278
|
+
const result = buildHook("onPullRequest", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
279
|
+
if (!result.ok)
|
|
280
|
+
return result;
|
|
281
|
+
push(result);
|
|
282
|
+
}
|
|
283
|
+
// onTaskCreated
|
|
284
|
+
if (policy.onTaskCreated?.enabled) {
|
|
285
|
+
const p = policy.onTaskCreated;
|
|
286
|
+
const result = buildHook("onTaskCreated", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
287
|
+
if (!result.ok)
|
|
288
|
+
return result;
|
|
289
|
+
push(result);
|
|
290
|
+
}
|
|
291
|
+
// onPermissionDenied
|
|
292
|
+
if (policy.onPermissionDenied?.enabled) {
|
|
293
|
+
const p = policy.onPermissionDenied;
|
|
294
|
+
const result = buildHook("onPermissionDenied", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
295
|
+
if (!result.ok)
|
|
296
|
+
return result;
|
|
297
|
+
push(result);
|
|
298
|
+
}
|
|
299
|
+
// onTaskSuccess
|
|
300
|
+
if (policy.onTaskSuccess?.enabled) {
|
|
301
|
+
const p = policy.onTaskSuccess;
|
|
302
|
+
const result = buildHook("onTaskSuccess", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
303
|
+
if (!result.ok)
|
|
304
|
+
return result;
|
|
305
|
+
push(result);
|
|
306
|
+
}
|
|
307
|
+
// onDebugSessionStart
|
|
308
|
+
if (policy.onDebugSessionStart?.enabled) {
|
|
309
|
+
const p = policy.onDebugSessionStart;
|
|
310
|
+
const result = buildHook("onDebugSessionStart", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
311
|
+
if (!result.ok)
|
|
312
|
+
return result;
|
|
313
|
+
push(result);
|
|
314
|
+
}
|
|
315
|
+
// onDebugSessionEnd
|
|
316
|
+
if (policy.onDebugSessionEnd?.enabled) {
|
|
317
|
+
const p = policy.onDebugSessionEnd;
|
|
318
|
+
const result = buildHook("onDebugSessionEnd", p, true, p.cooldownMs, p.condition, undefined, undefined, p.model ?? defaultModel, p.effort ?? defaultEffort, defaultSystemPrompt);
|
|
319
|
+
if (!result.ok)
|
|
320
|
+
return result;
|
|
321
|
+
push(result);
|
|
322
|
+
}
|
|
323
|
+
// Wrap entire array in WithRateLimit if maxTasksPerHour > 0
|
|
324
|
+
if (programs.length === 0)
|
|
325
|
+
return ok([]);
|
|
326
|
+
const maxPerHour = policy.maxTasksPerHour ?? 0;
|
|
327
|
+
if (maxPerHour > 0) {
|
|
328
|
+
// Wrap each program individually so each fires through the shared rate limiter
|
|
329
|
+
const wrapped = programs.map((p) => withRateLimit(maxPerHour, p));
|
|
330
|
+
return ok(wrapped);
|
|
331
|
+
}
|
|
332
|
+
return ok(programs);
|
|
333
|
+
}
|
|
334
|
+
//# sourceMappingURL=policyParser.js.map
|