@kilnai/cli 0.23.2 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +33 -0
- package/dist/application/__tests__/plan-exit-tool.test.d.ts +2 -0
- package/dist/application/__tests__/plan-exit-tool.test.d.ts.map +1 -0
- package/dist/application/__tests__/plan-exit-tool.test.js +12 -0
- package/dist/application/__tests__/plan-exit-tool.test.js.map +1 -0
- package/dist/application/agent-loader.d.ts +12 -0
- package/dist/application/agent-loader.d.ts.map +1 -0
- package/dist/application/agent-loader.js +114 -0
- package/dist/application/agent-loader.js.map +1 -0
- package/dist/application/agent-loader.test.d.ts +2 -0
- package/dist/application/agent-loader.test.d.ts.map +1 -0
- package/dist/application/agent-loader.test.js +151 -0
- package/dist/application/agent-loader.test.js.map +1 -0
- package/dist/application/context-artifact-keys.d.ts +5 -0
- package/dist/application/context-artifact-keys.d.ts.map +1 -0
- package/dist/application/context-artifact-keys.js +14 -0
- package/dist/application/context-artifact-keys.js.map +1 -0
- package/dist/application/context-governance.d.ts +6 -0
- package/dist/application/context-governance.d.ts.map +1 -0
- package/dist/application/context-governance.js +20 -0
- package/dist/application/context-governance.js.map +1 -0
- package/dist/application/context-governor.d.ts +26 -0
- package/dist/application/context-governor.d.ts.map +1 -0
- package/dist/application/context-governor.js +164 -0
- package/dist/application/context-governor.js.map +1 -0
- package/dist/application/context-types.d.ts +20 -0
- package/dist/application/context-types.d.ts.map +1 -0
- package/dist/application/context-types.js +21 -0
- package/dist/application/context-types.js.map +1 -0
- package/dist/application/plan-exit-tool.d.ts +19 -0
- package/dist/application/plan-exit-tool.d.ts.map +1 -0
- package/dist/application/plan-exit-tool.js +13 -0
- package/dist/application/plan-exit-tool.js.map +1 -0
- package/dist/application/repo-summary-cache.d.ts +5 -0
- package/dist/application/repo-summary-cache.d.ts.map +1 -0
- package/dist/application/repo-summary-cache.js +82 -0
- package/dist/application/repo-summary-cache.js.map +1 -0
- package/dist/application/resume-strategy-feedback.d.ts +5 -0
- package/dist/application/resume-strategy-feedback.d.ts.map +1 -0
- package/dist/application/resume-strategy-feedback.js +81 -0
- package/dist/application/resume-strategy-feedback.js.map +1 -0
- package/dist/application/resume-strategy-policy.d.ts +26 -0
- package/dist/application/resume-strategy-policy.d.ts.map +1 -0
- package/dist/application/resume-strategy-policy.js +35 -0
- package/dist/application/resume-strategy-policy.js.map +1 -0
- package/dist/application/run-session.d.ts +39 -0
- package/dist/application/run-session.d.ts.map +1 -0
- package/dist/application/run-session.js +349 -0
- package/dist/application/run-session.js.map +1 -0
- package/dist/application/session-hooks.d.ts +20 -0
- package/dist/application/session-hooks.d.ts.map +1 -0
- package/dist/application/session-hooks.js +55 -0
- package/dist/application/session-hooks.js.map +1 -0
- package/dist/application/session-ledger.d.ts +12 -0
- package/dist/application/session-ledger.d.ts.map +1 -0
- package/dist/application/session-ledger.js +29 -0
- package/dist/application/session-ledger.js.map +1 -0
- package/dist/application/session-report.d.ts +19 -0
- package/dist/application/session-report.d.ts.map +1 -0
- package/dist/application/session-report.js +207 -0
- package/dist/application/session-report.js.map +1 -0
- package/dist/application/session-resume.d.ts +3 -0
- package/dist/application/session-resume.d.ts.map +1 -0
- package/dist/application/session-resume.js +16 -0
- package/dist/application/session-resume.js.map +1 -0
- package/dist/commands/auth.d.ts +2 -0
- package/dist/commands/auth.d.ts.map +1 -0
- package/dist/commands/auth.js +138 -0
- package/dist/commands/auth.js.map +1 -0
- package/dist/commands/config.d.ts +1 -1
- package/dist/commands/config.d.ts.map +1 -1
- package/dist/commands/config.js +141 -27
- package/dist/commands/config.js.map +1 -1
- package/dist/commands/cron.d.ts +3 -0
- package/dist/commands/cron.d.ts.map +1 -0
- package/dist/commands/cron.js +201 -0
- package/dist/commands/cron.js.map +1 -0
- package/dist/commands/dev.js +2 -2
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/domain.js +17 -17
- package/dist/commands/domain.js.map +1 -1
- package/dist/commands/init.d.ts +2 -11
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +14 -25
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/mcp-config.d.ts +7 -1
- package/dist/commands/mcp-config.d.ts.map +1 -1
- package/dist/commands/mcp-config.js +26 -10
- package/dist/commands/mcp-config.js.map +1 -1
- package/dist/commands/memory.d.ts +1 -1
- package/dist/commands/memory.d.ts.map +1 -1
- package/dist/commands/memory.js +10 -10
- package/dist/commands/memory.js.map +1 -1
- package/dist/commands/run.d.ts +15 -3
- package/dist/commands/run.d.ts.map +1 -1
- package/dist/commands/run.js +464 -85
- package/dist/commands/run.js.map +1 -1
- package/dist/commands/serve.d.ts +1 -1
- package/dist/commands/serve.d.ts.map +1 -1
- package/dist/commands/serve.js +3 -3
- package/dist/commands/serve.js.map +1 -1
- package/dist/commands/skill-capture.d.ts +13 -0
- package/dist/commands/skill-capture.d.ts.map +1 -0
- package/dist/commands/skill-capture.js +212 -0
- package/dist/commands/skill-capture.js.map +1 -0
- package/dist/commands/skill.d.ts.map +1 -1
- package/dist/commands/skill.js +7 -3
- package/dist/commands/skill.js.map +1 -1
- package/dist/commands/status.d.ts +1 -1
- package/dist/commands/status.d.ts.map +1 -1
- package/dist/commands/status.js +15 -16
- package/dist/commands/status.js.map +1 -1
- package/dist/commands/sync.d.ts +11 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +114 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/commands/tools.d.ts +6 -0
- package/dist/commands/tools.d.ts.map +1 -0
- package/dist/commands/tools.js +28 -0
- package/dist/commands/tools.js.map +1 -0
- package/dist/commands/tui.d.ts +29 -0
- package/dist/commands/tui.d.ts.map +1 -0
- package/dist/commands/tui.js +444 -0
- package/dist/commands/tui.js.map +1 -0
- package/dist/config/config-merger.d.ts +5 -0
- package/dist/config/config-merger.d.ts.map +1 -0
- package/dist/config/config-merger.js +25 -0
- package/dist/config/config-merger.js.map +1 -0
- package/dist/config/config-merger.test.d.ts +2 -0
- package/dist/config/config-merger.test.d.ts.map +1 -0
- package/dist/config/config-merger.test.js +165 -0
- package/dist/config/config-merger.test.js.map +1 -0
- package/dist/config/env-config.d.ts +5 -0
- package/dist/config/env-config.d.ts.map +1 -0
- package/dist/config/env-config.js +24 -0
- package/dist/config/env-config.js.map +1 -0
- package/dist/config/env-config.test.d.ts +2 -0
- package/dist/config/env-config.test.d.ts.map +1 -0
- package/dist/config/env-config.test.js +79 -0
- package/dist/config/env-config.test.js.map +1 -0
- package/dist/config/global-config.d.ts +23 -0
- package/dist/config/global-config.d.ts.map +1 -0
- package/dist/config/global-config.js +48 -0
- package/dist/config/global-config.js.map +1 -0
- package/dist/config/global-config.test.d.ts +2 -0
- package/dist/config/global-config.test.d.ts.map +1 -0
- package/dist/config/global-config.test.js +96 -0
- package/dist/config/global-config.test.js.map +1 -0
- package/dist/config-resolver.d.ts +5 -0
- package/dist/config-resolver.d.ts.map +1 -0
- package/dist/config-resolver.js +19 -0
- package/dist/config-resolver.js.map +1 -0
- package/dist/config.d.ts +8 -7
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +14 -1
- package/dist/config.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +193 -16
- package/dist/index.js.map +1 -1
- package/dist/kiln-yaml-types.d.ts +127 -0
- package/dist/kiln-yaml-types.d.ts.map +1 -0
- package/dist/kiln-yaml-types.js +42 -0
- package/dist/kiln-yaml-types.js.map +1 -0
- package/dist/kiln-yaml.d.ts +10 -0
- package/dist/kiln-yaml.d.ts.map +1 -0
- package/dist/kiln-yaml.js +109 -0
- package/dist/kiln-yaml.js.map +1 -0
- package/dist/mcp/config-generator.d.ts +9 -2
- package/dist/mcp/config-generator.d.ts.map +1 -1
- package/dist/mcp/config-generator.js +132 -2
- package/dist/mcp/config-generator.js.map +1 -1
- package/dist/mcp/index.d.ts.map +1 -1
- package/dist/mcp/index.js +2 -1
- package/dist/mcp/index.js.map +1 -1
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +2 -1
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp-entry.js +0 -5
- package/dist/mcp-entry.js.map +1 -1
- package/dist/sync/agent-sync.d.ts +13 -0
- package/dist/sync/agent-sync.d.ts.map +1 -0
- package/dist/sync/agent-sync.js +130 -0
- package/dist/sync/agent-sync.js.map +1 -0
- package/dist/sync/agent-sync.test.d.ts +2 -0
- package/dist/sync/agent-sync.test.d.ts.map +1 -0
- package/dist/sync/agent-sync.test.js +130 -0
- package/dist/sync/agent-sync.test.js.map +1 -0
- package/dist/sync/agents-md-sync.d.ts +7 -0
- package/dist/sync/agents-md-sync.d.ts.map +1 -0
- package/dist/sync/agents-md-sync.js +44 -0
- package/dist/sync/agents-md-sync.js.map +1 -0
- package/dist/sync/agents-md-sync.test.d.ts +2 -0
- package/dist/sync/agents-md-sync.test.d.ts.map +1 -0
- package/dist/sync/agents-md-sync.test.js +154 -0
- package/dist/sync/agents-md-sync.test.js.map +1 -0
- package/dist/sync/hook-sync.d.ts +8 -0
- package/dist/sync/hook-sync.d.ts.map +1 -0
- package/dist/sync/hook-sync.js +90 -0
- package/dist/sync/hook-sync.js.map +1 -0
- package/dist/sync/security-sync.d.ts +9 -0
- package/dist/sync/security-sync.d.ts.map +1 -0
- package/dist/sync/security-sync.js +161 -0
- package/dist/sync/security-sync.js.map +1 -0
- package/dist/sync/skill-sync.d.ts +10 -0
- package/dist/sync/skill-sync.d.ts.map +1 -0
- package/dist/sync/skill-sync.js +87 -0
- package/dist/sync/skill-sync.js.map +1 -0
- package/dist/sync/skill-sync.test.d.ts +2 -0
- package/dist/sync/skill-sync.test.d.ts.map +1 -0
- package/dist/sync/skill-sync.test.js +163 -0
- package/dist/sync/skill-sync.test.js.map +1 -0
- package/dist/wrapper/approval-memory-store.d.ts +40 -0
- package/dist/wrapper/approval-memory-store.d.ts.map +1 -0
- package/dist/wrapper/approval-memory-store.js +132 -0
- package/dist/wrapper/approval-memory-store.js.map +1 -0
- package/dist/wrapper/claude-code-process.d.ts +32 -34
- package/dist/wrapper/claude-code-process.d.ts.map +1 -1
- package/dist/wrapper/claude-code-process.js +181 -66
- package/dist/wrapper/claude-code-process.js.map +1 -1
- package/dist/wrapper/cleanup-registry.d.ts +7 -0
- package/dist/wrapper/cleanup-registry.d.ts.map +1 -0
- package/dist/wrapper/cleanup-registry.js +11 -0
- package/dist/wrapper/cleanup-registry.js.map +1 -0
- package/dist/wrapper/codex-session.d.ts +49 -0
- package/dist/wrapper/codex-session.d.ts.map +1 -0
- package/dist/wrapper/codex-session.js +470 -0
- package/dist/wrapper/codex-session.js.map +1 -0
- package/dist/wrapper/debug.d.ts +2 -0
- package/dist/wrapper/debug.d.ts.map +1 -0
- package/dist/wrapper/debug.js +7 -0
- package/dist/wrapper/debug.js.map +1 -0
- package/dist/wrapper/executable-provider-session.d.ts +26 -0
- package/dist/wrapper/executable-provider-session.d.ts.map +1 -0
- package/dist/wrapper/executable-provider-session.js +214 -0
- package/dist/wrapper/executable-provider-session.js.map +1 -0
- package/dist/wrapper/hook-executor.d.ts +21 -0
- package/dist/wrapper/hook-executor.d.ts.map +1 -0
- package/dist/wrapper/hook-executor.js +100 -0
- package/dist/wrapper/hook-executor.js.map +1 -0
- package/dist/wrapper/hook-registry.d.ts +10 -0
- package/dist/wrapper/hook-registry.d.ts.map +1 -0
- package/dist/wrapper/hook-registry.js +57 -0
- package/dist/wrapper/hook-registry.js.map +1 -0
- package/dist/wrapper/index.d.ts +83 -2
- package/dist/wrapper/index.d.ts.map +1 -1
- package/dist/wrapper/index.js +11 -0
- package/dist/wrapper/index.js.map +1 -1
- package/dist/wrapper/mcp-selector.d.ts +2 -0
- package/dist/wrapper/mcp-selector.d.ts.map +1 -0
- package/dist/wrapper/mcp-selector.js +8 -0
- package/dist/wrapper/mcp-selector.js.map +1 -0
- package/dist/wrapper/opencode-session.d.ts +69 -0
- package/dist/wrapper/opencode-session.d.ts.map +1 -0
- package/dist/wrapper/opencode-session.js +568 -0
- package/dist/wrapper/opencode-session.js.map +1 -0
- package/dist/wrapper/permission-evaluator.d.ts +57 -0
- package/dist/wrapper/permission-evaluator.d.ts.map +1 -0
- package/dist/wrapper/permission-evaluator.js +310 -0
- package/dist/wrapper/permission-evaluator.js.map +1 -0
- package/dist/wrapper/permission-normalizer.d.ts +13 -0
- package/dist/wrapper/permission-normalizer.d.ts.map +1 -0
- package/dist/wrapper/permission-normalizer.js +88 -0
- package/dist/wrapper/permission-normalizer.js.map +1 -0
- package/dist/wrapper/permission-policy-authorizer.d.ts +12 -0
- package/dist/wrapper/permission-policy-authorizer.d.ts.map +1 -0
- package/dist/wrapper/permission-policy-authorizer.js +64 -0
- package/dist/wrapper/permission-policy-authorizer.js.map +1 -0
- package/dist/wrapper/preamble-builder.d.ts +7 -0
- package/dist/wrapper/preamble-builder.d.ts.map +1 -0
- package/dist/wrapper/preamble-builder.js +103 -0
- package/dist/wrapper/preamble-builder.js.map +1 -0
- package/dist/wrapper/provider-context.d.ts +20 -0
- package/dist/wrapper/provider-context.d.ts.map +1 -0
- package/dist/wrapper/provider-context.js +58 -0
- package/dist/wrapper/provider-context.js.map +1 -0
- package/dist/wrapper/provider-session.d.ts +27 -0
- package/dist/wrapper/provider-session.d.ts.map +1 -0
- package/dist/wrapper/provider-session.js +208 -0
- package/dist/wrapper/provider-session.js.map +1 -0
- package/dist/wrapper/session-manager.d.ts +21 -4
- package/dist/wrapper/session-manager.d.ts.map +1 -1
- package/dist/wrapper/session-manager.js +173 -14
- package/dist/wrapper/session-manager.js.map +1 -1
- package/dist/wrapper/session-registry.d.ts +136 -0
- package/dist/wrapper/session-registry.d.ts.map +1 -0
- package/dist/wrapper/session-registry.js +977 -0
- package/dist/wrapper/session-registry.js.map +1 -0
- package/dist/wrapper/session-store.d.ts +63 -0
- package/dist/wrapper/session-store.d.ts.map +1 -0
- package/dist/wrapper/session-store.js +215 -0
- package/dist/wrapper/session-store.js.map +1 -0
- package/dist/wrapper/session.d.ts +127 -0
- package/dist/wrapper/session.d.ts.map +1 -0
- package/dist/wrapper/session.js +14 -0
- package/dist/wrapper/session.js.map +1 -0
- package/dist/wrapper/worktree-manager.d.ts +30 -0
- package/dist/wrapper/worktree-manager.d.ts.map +1 -0
- package/dist/wrapper/worktree-manager.js +139 -0
- package/dist/wrapper/worktree-manager.js.map +1 -0
- package/package.json +11 -7
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
import { buildPreamble } from "../wrapper/preamble-builder.js";
|
|
2
|
+
import { createPermissionEvaluator } from "../wrapper/index.js";
|
|
3
|
+
import { isDirectApiProvider } from "../wrapper/session-registry.js";
|
|
4
|
+
import { normalizeMcpSelector } from "../wrapper/mcp-selector.js";
|
|
5
|
+
import { governSessionContext } from "./context-governance.js";
|
|
6
|
+
export async function runSession(options) {
|
|
7
|
+
const governedContext = governSessionContext(options.context, options.permissionPolicy);
|
|
8
|
+
const permissionEvaluator = createPermissionEvaluator(options.permissionPolicy, { agent: options.permissionAgent });
|
|
9
|
+
const preferredProvider = options.requirements.preferredProvider;
|
|
10
|
+
const candidates = (preferredProvider && isDirectApiProvider(preferredProvider))
|
|
11
|
+
? [preferredProvider]
|
|
12
|
+
: (() => {
|
|
13
|
+
const selection = options.registry.selectBest(options.requirements);
|
|
14
|
+
return [selection.primary, ...selection.orderedFallbacks];
|
|
15
|
+
})();
|
|
16
|
+
let finalCostUsd = 0;
|
|
17
|
+
let sessionSucceeded = false;
|
|
18
|
+
let lastError = null;
|
|
19
|
+
let accumulatedText = "";
|
|
20
|
+
let toolCallCount = 0;
|
|
21
|
+
let turnDepth = 0;
|
|
22
|
+
let successfulProviderId;
|
|
23
|
+
const transcript = [];
|
|
24
|
+
const exactArtifacts = new Set();
|
|
25
|
+
let submittedPlan;
|
|
26
|
+
let transcriptSeq = 0;
|
|
27
|
+
let isFirstDeltaOfTurn = false;
|
|
28
|
+
let awaitingTurnStart = true;
|
|
29
|
+
let lastToolName;
|
|
30
|
+
for (let candidateIndex = 0; candidateIndex < candidates.length; candidateIndex += 1) {
|
|
31
|
+
const providerId = candidates[candidateIndex];
|
|
32
|
+
let isPreflightCrash = false;
|
|
33
|
+
let providerDeniedByPolicy = false;
|
|
34
|
+
const session = options.registry.createSession(providerId, options.sessionConfig);
|
|
35
|
+
options.cleanupRegistry.register(async () => session.dispose());
|
|
36
|
+
try {
|
|
37
|
+
for await (const event of session.run({
|
|
38
|
+
prompt: buildPreamble(governedContext, options.permissionPolicy, undefined),
|
|
39
|
+
cwd: process.cwd(),
|
|
40
|
+
env: options.env,
|
|
41
|
+
})) {
|
|
42
|
+
switch (event.type) {
|
|
43
|
+
case "text_delta": {
|
|
44
|
+
transcript.push({
|
|
45
|
+
seq: ++transcriptSeq,
|
|
46
|
+
ts: new Date().toISOString(),
|
|
47
|
+
event: { type: "text_delta", content: event.content },
|
|
48
|
+
});
|
|
49
|
+
if (awaitingTurnStart) {
|
|
50
|
+
turnDepth++;
|
|
51
|
+
awaitingTurnStart = false;
|
|
52
|
+
}
|
|
53
|
+
if (isFirstDeltaOfTurn) {
|
|
54
|
+
isFirstDeltaOfTurn = false;
|
|
55
|
+
options.sessionHooks.userPromptSubmit();
|
|
56
|
+
}
|
|
57
|
+
process.stdout.write(event.content);
|
|
58
|
+
accumulatedText += event.content;
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
case "tool_use": {
|
|
62
|
+
const decision = permissionEvaluator.evaluateTool(event.toolName);
|
|
63
|
+
const stableSessionId = options.sessionId;
|
|
64
|
+
let matchedToolApprovalMemory = null;
|
|
65
|
+
if (decision.action === "deny") {
|
|
66
|
+
matchedToolApprovalMemory = await findToolApprovalMemory(options.approvalMemoryStore, event.toolName, stableSessionId);
|
|
67
|
+
if (!matchedToolApprovalMemory) {
|
|
68
|
+
transcript.push({
|
|
69
|
+
seq: ++transcriptSeq,
|
|
70
|
+
ts: new Date().toISOString(),
|
|
71
|
+
event: { type: "tool_use", toolName: `${event.toolName} [DENIED]` },
|
|
72
|
+
});
|
|
73
|
+
lastError = `Provider ${providerId} denied tool "${event.toolName}" by policy`;
|
|
74
|
+
options.registry.reportFailure(providerId, false);
|
|
75
|
+
providerDeniedByPolicy = true;
|
|
76
|
+
break;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
const scopedMcpTools = permissionEvaluator.scope.mcpTools;
|
|
80
|
+
const hasScopedMcpRestriction = event.source === "mcp"
|
|
81
|
+
&& permissionEvaluator.scope.matchedScope
|
|
82
|
+
&& scopedMcpTools !== undefined;
|
|
83
|
+
if (hasScopedMcpRestriction) {
|
|
84
|
+
const normalizedScopedMcpTools = new Set(scopedMcpTools.map((selector) => normalizeMcpSelector(selector)));
|
|
85
|
+
const eventSelector = normalizeMcpSelector(event.mcpSelector ?? event.toolName);
|
|
86
|
+
if (!normalizedScopedMcpTools.has(eventSelector)) {
|
|
87
|
+
transcript.push({
|
|
88
|
+
seq: ++transcriptSeq,
|
|
89
|
+
ts: new Date().toISOString(),
|
|
90
|
+
event: { type: "tool_use", toolName: `${event.toolName} [DENIED]` },
|
|
91
|
+
});
|
|
92
|
+
lastError = `Provider ${providerId} denied MCP tool "${event.toolName}" by policy`;
|
|
93
|
+
options.registry.reportFailure(providerId, false);
|
|
94
|
+
providerDeniedByPolicy = true;
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
const isBashLikeTool = event.toolName === "Bash" || event.toolName === "bash";
|
|
99
|
+
const command = extractCommandFromToolInput(event.input);
|
|
100
|
+
if (command !== undefined) {
|
|
101
|
+
exactArtifacts.add(`Command executed: ${command}`);
|
|
102
|
+
}
|
|
103
|
+
let matchedCommandApprovalMemory = null;
|
|
104
|
+
if (isBashLikeTool && command !== undefined) {
|
|
105
|
+
const commandDecision = permissionEvaluator.evaluateCommand(command, "bash");
|
|
106
|
+
matchedCommandApprovalMemory = commandDecision.action === "deny"
|
|
107
|
+
? await findCommandApprovalMemory(options.approvalMemoryStore, command, stableSessionId)
|
|
108
|
+
: null;
|
|
109
|
+
if (commandDecision.action === "deny") {
|
|
110
|
+
if (!matchedCommandApprovalMemory) {
|
|
111
|
+
transcript.push({
|
|
112
|
+
seq: ++transcriptSeq,
|
|
113
|
+
ts: new Date().toISOString(),
|
|
114
|
+
event: { type: "tool_use", toolName: `${event.toolName} [DENIED]` },
|
|
115
|
+
});
|
|
116
|
+
lastError = `Provider ${providerId} denied command "${command}" by policy`;
|
|
117
|
+
options.registry.reportFailure(providerId, false);
|
|
118
|
+
providerDeniedByPolicy = true;
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
const filePath = extractFilePathFromToolInput(event.input);
|
|
124
|
+
if (filePath !== undefined) {
|
|
125
|
+
exactArtifacts.add(`File path touched: ${filePath}`);
|
|
126
|
+
}
|
|
127
|
+
if (filePath !== undefined) {
|
|
128
|
+
const fileDecision = permissionEvaluator.evaluateFile(filePath);
|
|
129
|
+
if (fileDecision.action === "deny") {
|
|
130
|
+
transcript.push({
|
|
131
|
+
seq: ++transcriptSeq,
|
|
132
|
+
ts: new Date().toISOString(),
|
|
133
|
+
event: { type: "tool_use", toolName: `${event.toolName} [DENIED]` },
|
|
134
|
+
});
|
|
135
|
+
lastError = `Provider ${providerId} denied file path "${filePath}" by policy`;
|
|
136
|
+
exactArtifacts.add(lastError);
|
|
137
|
+
options.registry.reportFailure(providerId, false);
|
|
138
|
+
providerDeniedByPolicy = true;
|
|
139
|
+
break;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
if (matchedToolApprovalMemory?.scope === "once") {
|
|
143
|
+
const consumed = await consumeToolApprovalOnce(options.approvalMemoryStore, event.toolName, stableSessionId);
|
|
144
|
+
if (!consumed) {
|
|
145
|
+
transcript.push({
|
|
146
|
+
seq: ++transcriptSeq,
|
|
147
|
+
ts: new Date().toISOString(),
|
|
148
|
+
event: { type: "tool_use", toolName: `${event.toolName} [DENIED]` },
|
|
149
|
+
});
|
|
150
|
+
lastError = `Provider ${providerId} denied tool "${event.toolName}" by policy`;
|
|
151
|
+
options.registry.reportFailure(providerId, false);
|
|
152
|
+
providerDeniedByPolicy = true;
|
|
153
|
+
break;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
if (matchedCommandApprovalMemory?.scope === "once" && command !== undefined) {
|
|
157
|
+
const consumed = await consumeCommandApprovalOnce(options.approvalMemoryStore, command, stableSessionId);
|
|
158
|
+
if (!consumed) {
|
|
159
|
+
transcript.push({
|
|
160
|
+
seq: ++transcriptSeq,
|
|
161
|
+
ts: new Date().toISOString(),
|
|
162
|
+
event: { type: "tool_use", toolName: `${event.toolName} [DENIED]` },
|
|
163
|
+
});
|
|
164
|
+
lastError = `Provider ${providerId} denied command "${command}" by policy`;
|
|
165
|
+
options.registry.reportFailure(providerId, false);
|
|
166
|
+
providerDeniedByPolicy = true;
|
|
167
|
+
break;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
transcript.push({
|
|
171
|
+
seq: ++transcriptSeq,
|
|
172
|
+
ts: new Date().toISOString(),
|
|
173
|
+
event: { type: "tool_use", toolName: event.toolName },
|
|
174
|
+
});
|
|
175
|
+
if (event.toolName === "submit_plan") {
|
|
176
|
+
const submitted = extractPlanFromToolInput(event.input);
|
|
177
|
+
if (submitted !== undefined) {
|
|
178
|
+
submittedPlan = submitted;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
console.log(`[tool] ${event.toolName}`);
|
|
182
|
+
toolCallCount++;
|
|
183
|
+
lastToolName = event.toolName;
|
|
184
|
+
options.sessionHooks.preToolUse(event.toolName);
|
|
185
|
+
break;
|
|
186
|
+
}
|
|
187
|
+
case "tool_result": {
|
|
188
|
+
transcript.push({
|
|
189
|
+
seq: ++transcriptSeq,
|
|
190
|
+
ts: new Date().toISOString(),
|
|
191
|
+
event: { type: "tool_result" },
|
|
192
|
+
});
|
|
193
|
+
isFirstDeltaOfTurn = true;
|
|
194
|
+
awaitingTurnStart = true;
|
|
195
|
+
if (lastToolName) {
|
|
196
|
+
options.sessionHooks.postToolUse(lastToolName);
|
|
197
|
+
}
|
|
198
|
+
break;
|
|
199
|
+
}
|
|
200
|
+
case "cost_update": {
|
|
201
|
+
finalCostUsd = event.usd;
|
|
202
|
+
options.manager.trackCostUpdate(event.inputTokens ?? 0, event.outputTokens ?? 0, event.cacheReadTokens ?? 0, event.usd);
|
|
203
|
+
break;
|
|
204
|
+
}
|
|
205
|
+
case "completed": {
|
|
206
|
+
isPreflightCrash = event.isPreflightCrash;
|
|
207
|
+
if (event.isPreflightCrash) {
|
|
208
|
+
lastError = `Provider ${providerId} crashed before starting`;
|
|
209
|
+
exactArtifacts.add(lastError);
|
|
210
|
+
options.registry.reportFailure(providerId, true);
|
|
211
|
+
break;
|
|
212
|
+
}
|
|
213
|
+
if (event.isError) {
|
|
214
|
+
lastError = `Provider ${providerId} ended with error`;
|
|
215
|
+
exactArtifacts.add(lastError);
|
|
216
|
+
options.registry.reportFailure(providerId, false);
|
|
217
|
+
break;
|
|
218
|
+
}
|
|
219
|
+
sessionSucceeded = true;
|
|
220
|
+
successfulProviderId = providerId;
|
|
221
|
+
options.registry.reportSuccess(providerId);
|
|
222
|
+
break;
|
|
223
|
+
}
|
|
224
|
+
case "error": {
|
|
225
|
+
lastError = event.message;
|
|
226
|
+
if (event.message.trim() !== "") {
|
|
227
|
+
exactArtifacts.add(`Provider error: ${event.message}`);
|
|
228
|
+
}
|
|
229
|
+
if (!event.isRetryable) {
|
|
230
|
+
options.registry.reportFailure(providerId, false);
|
|
231
|
+
}
|
|
232
|
+
break;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
if (providerDeniedByPolicy) {
|
|
236
|
+
break;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
finally {
|
|
241
|
+
await session.dispose();
|
|
242
|
+
}
|
|
243
|
+
if (sessionSucceeded)
|
|
244
|
+
break;
|
|
245
|
+
const hasMoreCandidates = candidateIndex < candidates.length - 1;
|
|
246
|
+
if (!isPreflightCrash && !sessionSucceeded && hasMoreCandidates) {
|
|
247
|
+
console.error(`[kiln] Provider ${providerId} failed, trying next...`);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
return {
|
|
251
|
+
finalCostUsd,
|
|
252
|
+
sessionSucceeded,
|
|
253
|
+
lastError,
|
|
254
|
+
accumulatedText,
|
|
255
|
+
toolCallCount,
|
|
256
|
+
turnDepth,
|
|
257
|
+
successfulProviderId,
|
|
258
|
+
transcript,
|
|
259
|
+
exactArtifacts: [...exactArtifacts],
|
|
260
|
+
submittedPlan,
|
|
261
|
+
};
|
|
262
|
+
}
|
|
263
|
+
function extractCommandFromToolInput(input) {
|
|
264
|
+
if (typeof input !== "object" || input === null)
|
|
265
|
+
return undefined;
|
|
266
|
+
const withCommand = input;
|
|
267
|
+
return typeof withCommand.command === "string" ? withCommand.command : undefined;
|
|
268
|
+
}
|
|
269
|
+
function extractFilePathFromToolInput(input) {
|
|
270
|
+
if (typeof input !== "object" || input === null)
|
|
271
|
+
return undefined;
|
|
272
|
+
const withPath = input;
|
|
273
|
+
if (typeof withPath.filePath === "string")
|
|
274
|
+
return withPath.filePath;
|
|
275
|
+
if (typeof withPath.path === "string")
|
|
276
|
+
return withPath.path;
|
|
277
|
+
return undefined;
|
|
278
|
+
}
|
|
279
|
+
function extractPlanFromToolInput(input) {
|
|
280
|
+
if (typeof input !== "object" || input === null)
|
|
281
|
+
return undefined;
|
|
282
|
+
const withPlan = input;
|
|
283
|
+
return typeof withPlan.plan === "string" ? withPlan.plan : undefined;
|
|
284
|
+
}
|
|
285
|
+
async function findToolApprovalMemory(approvalMemoryStore, toolName, sessionId) {
|
|
286
|
+
if (!approvalMemoryStore || sessionId === undefined)
|
|
287
|
+
return null;
|
|
288
|
+
const query = {
|
|
289
|
+
surface: "tool",
|
|
290
|
+
selector: toolName,
|
|
291
|
+
action: "allow",
|
|
292
|
+
sessionId,
|
|
293
|
+
};
|
|
294
|
+
try {
|
|
295
|
+
return await approvalMemoryStore.findMatch(query);
|
|
296
|
+
}
|
|
297
|
+
catch {
|
|
298
|
+
return null;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
async function consumeToolApprovalOnce(approvalMemoryStore, toolName, sessionId) {
|
|
302
|
+
if (!approvalMemoryStore || sessionId === undefined)
|
|
303
|
+
return false;
|
|
304
|
+
const query = {
|
|
305
|
+
surface: "tool",
|
|
306
|
+
selector: toolName,
|
|
307
|
+
action: "allow",
|
|
308
|
+
sessionId,
|
|
309
|
+
};
|
|
310
|
+
try {
|
|
311
|
+
return (await approvalMemoryStore.consumeOnce(query)) !== null;
|
|
312
|
+
}
|
|
313
|
+
catch {
|
|
314
|
+
return false;
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
async function findCommandApprovalMemory(approvalMemoryStore, command, sessionId) {
|
|
318
|
+
if (!approvalMemoryStore || sessionId === undefined)
|
|
319
|
+
return null;
|
|
320
|
+
const query = {
|
|
321
|
+
surface: "command",
|
|
322
|
+
selector: command,
|
|
323
|
+
action: "allow",
|
|
324
|
+
sessionId,
|
|
325
|
+
};
|
|
326
|
+
try {
|
|
327
|
+
return await approvalMemoryStore.findMatch(query);
|
|
328
|
+
}
|
|
329
|
+
catch {
|
|
330
|
+
return null;
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
async function consumeCommandApprovalOnce(approvalMemoryStore, command, sessionId) {
|
|
334
|
+
if (!approvalMemoryStore || sessionId === undefined)
|
|
335
|
+
return false;
|
|
336
|
+
const query = {
|
|
337
|
+
surface: "command",
|
|
338
|
+
selector: command,
|
|
339
|
+
action: "allow",
|
|
340
|
+
sessionId,
|
|
341
|
+
};
|
|
342
|
+
try {
|
|
343
|
+
return (await approvalMemoryStore.consumeOnce(query)) !== null;
|
|
344
|
+
}
|
|
345
|
+
catch {
|
|
346
|
+
return false;
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
//# sourceMappingURL=run-session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-session.js","sourceRoot":"","sources":["../../src/application/run-session.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { KilnHooksConfig } from "../kiln-yaml-types.js";
|
|
2
|
+
interface SessionHooksOptions {
|
|
3
|
+
readonly sessionId: string;
|
|
4
|
+
readonly workingDirectory: string;
|
|
5
|
+
}
|
|
6
|
+
export declare class SessionHooks {
|
|
7
|
+
private readonly registry;
|
|
8
|
+
private readonly executor;
|
|
9
|
+
private readonly sessionId;
|
|
10
|
+
private readonly workingDirectory;
|
|
11
|
+
constructor(config: KilnHooksConfig | undefined, options: SessionHooksOptions);
|
|
12
|
+
sessionStart(): void;
|
|
13
|
+
sessionEnd(): void;
|
|
14
|
+
userPromptSubmit(): void;
|
|
15
|
+
preToolUse(toolName: string): void;
|
|
16
|
+
postToolUse(toolName: string): void;
|
|
17
|
+
private fire;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=session-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-hooks.d.ts","sourceRoot":"","sources":["../../src/application/session-hooks.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAS7D,UAAU,mBAAmB;IAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC;CACnC;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAe;IACxC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAe;IACxC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;gBAE9B,MAAM,EAAE,eAAe,GAAG,SAAS,EAAE,OAAO,EAAE,mBAAmB;IAO7E,YAAY,IAAI,IAAI;IAIpB,UAAU,IAAI,IAAI;IAIlB,gBAAgB,IAAI,IAAI;IAIxB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIlC,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAInC,OAAO,CAAC,IAAI;CA0Bb"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { HookExecutor, HookRegistry } from "../wrapper/index.js";
|
|
2
|
+
export class SessionHooks {
|
|
3
|
+
registry;
|
|
4
|
+
executor;
|
|
5
|
+
sessionId;
|
|
6
|
+
workingDirectory;
|
|
7
|
+
constructor(config, options) {
|
|
8
|
+
this.registry = new HookRegistry(config ?? {});
|
|
9
|
+
this.executor = new HookExecutor();
|
|
10
|
+
this.sessionId = options.sessionId;
|
|
11
|
+
this.workingDirectory = options.workingDirectory;
|
|
12
|
+
}
|
|
13
|
+
sessionStart() {
|
|
14
|
+
this.fire("SessionStart");
|
|
15
|
+
}
|
|
16
|
+
sessionEnd() {
|
|
17
|
+
this.fire("SessionEnd");
|
|
18
|
+
}
|
|
19
|
+
userPromptSubmit() {
|
|
20
|
+
this.fire("UserPromptSubmit");
|
|
21
|
+
}
|
|
22
|
+
preToolUse(toolName) {
|
|
23
|
+
this.fire("PreToolUse", toolName);
|
|
24
|
+
}
|
|
25
|
+
postToolUse(toolName) {
|
|
26
|
+
this.fire("PostToolUse", toolName);
|
|
27
|
+
}
|
|
28
|
+
fire(event, toolName) {
|
|
29
|
+
const handlers = this.registry.getRules(event, toolName);
|
|
30
|
+
if (handlers.length === 0)
|
|
31
|
+
return;
|
|
32
|
+
this.executor
|
|
33
|
+
.run(handlers, {
|
|
34
|
+
event,
|
|
35
|
+
toolName,
|
|
36
|
+
sessionId: this.sessionId,
|
|
37
|
+
workingDirectory: this.workingDirectory,
|
|
38
|
+
})
|
|
39
|
+
.then((results) => {
|
|
40
|
+
for (const result of results) {
|
|
41
|
+
if (result.exitCode !== 0) {
|
|
42
|
+
console.error(`[hook:${event}] non-zero exit ${result.exitCode} from: ${result.handler.command}`);
|
|
43
|
+
if (result.stderr) {
|
|
44
|
+
console.error(`[hook:${event}] stderr: ${result.stderr.trim()}`);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
})
|
|
49
|
+
.catch((err) => {
|
|
50
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
51
|
+
console.error(`[hook:${event}] hook execution failed: ${message}`);
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=session-hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-hooks.js","sourceRoot":"","sources":["../../src/application/session-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAejE,MAAM,OAAO,YAAY;IACN,QAAQ,CAAe;IACvB,QAAQ,CAAe;IACvB,SAAS,CAAS;IAClB,gBAAgB,CAAS;IAE1C,YAAY,MAAmC,EAAE,OAA4B;QAC3E,IAAI,CAAC,QAAQ,GAAG,IAAI,YAAY,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;QAC/C,IAAI,CAAC,QAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;QACnC,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IACnD,CAAC;IAED,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1B,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,QAAgB;QACzB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACrC,CAAC;IAEO,IAAI,CAAC,KAAyB,EAAE,QAAiB;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACzD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAElC,IAAI,CAAC,QAAQ;aACV,GAAG,CAAC,QAAQ,EAAE;YACb,KAAK;YACL,QAAQ;YACR,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;SACxC,CAAC;aACD,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;YAChB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC7B,IAAI,MAAM,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;oBAC1B,OAAO,CAAC,KAAK,CAAC,SAAS,KAAK,mBAAmB,MAAM,CAAC,QAAQ,UAAU,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;oBAClG,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;wBAClB,OAAO,CAAC,KAAK,CAAC,SAAS,KAAK,aAAa,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACnE,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;YACtB,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjE,OAAO,CAAC,KAAK,CAAC,SAAS,KAAK,4BAA4B,OAAO,EAAE,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACP,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface SessionLedger {
|
|
2
|
+
readonly currentPhase: string;
|
|
3
|
+
readonly resumedFrom?: string;
|
|
4
|
+
readonly workingDirectory?: string;
|
|
5
|
+
readonly worktreePath?: string;
|
|
6
|
+
readonly lastError?: string;
|
|
7
|
+
readonly lastProvider?: string;
|
|
8
|
+
readonly toolCallCount?: number;
|
|
9
|
+
readonly turnDepth?: number;
|
|
10
|
+
}
|
|
11
|
+
export declare function renderSessionLedger(ledger: SessionLedger): string | undefined;
|
|
12
|
+
//# sourceMappingURL=session-ledger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-ledger.d.ts","sourceRoot":"","sources":["../../src/application/session-ledger.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IACnC,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC;IAChC,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,aAAa,GAAG,MAAM,GAAG,SAAS,CA6B7E"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export function renderSessionLedger(ledger) {
|
|
2
|
+
const lines = [];
|
|
3
|
+
if (ledger.currentPhase.trim() !== "") {
|
|
4
|
+
lines.push(`Current phase: ${ledger.currentPhase}`);
|
|
5
|
+
}
|
|
6
|
+
if (ledger.resumedFrom && ledger.resumedFrom.trim() !== "") {
|
|
7
|
+
lines.push(`Resumed from session: ${ledger.resumedFrom}`);
|
|
8
|
+
}
|
|
9
|
+
if (ledger.workingDirectory && ledger.workingDirectory.trim() !== "") {
|
|
10
|
+
lines.push(`Working directory: ${ledger.workingDirectory}`);
|
|
11
|
+
}
|
|
12
|
+
if (ledger.worktreePath && ledger.worktreePath.trim() !== "") {
|
|
13
|
+
lines.push(`Isolated worktree: ${ledger.worktreePath}`);
|
|
14
|
+
}
|
|
15
|
+
if (ledger.lastProvider && ledger.lastProvider.trim() !== "") {
|
|
16
|
+
lines.push(`Last successful provider: ${ledger.lastProvider}`);
|
|
17
|
+
}
|
|
18
|
+
if (ledger.toolCallCount !== undefined) {
|
|
19
|
+
lines.push(`Tool calls so far: ${ledger.toolCallCount}`);
|
|
20
|
+
}
|
|
21
|
+
if (ledger.turnDepth !== undefined) {
|
|
22
|
+
lines.push(`Turn depth so far: ${ledger.turnDepth}`);
|
|
23
|
+
}
|
|
24
|
+
if (ledger.lastError && ledger.lastError.trim() !== "") {
|
|
25
|
+
lines.push(`Last error: ${ledger.lastError}`);
|
|
26
|
+
}
|
|
27
|
+
return lines.length > 0 ? lines.join("\n") : undefined;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=session-ledger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-ledger.js","sourceRoot":"","sources":["../../src/application/session-ledger.ts"],"names":[],"mappings":"AAWA,MAAM,UAAU,mBAAmB,CAAC,MAAqB;IACvD,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,IAAI,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QACtC,KAAK,CAAC,IAAI,CAAC,kBAAkB,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;IACtD,CAAC;IACD,IAAI,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QAC3D,KAAK,CAAC,IAAI,CAAC,yBAAyB,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5D,CAAC;IACD,IAAI,MAAM,CAAC,gBAAgB,IAAI,MAAM,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QACrE,KAAK,CAAC,IAAI,CAAC,sBAAsB,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC9D,CAAC;IACD,IAAI,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QAC7D,KAAK,CAAC,IAAI,CAAC,sBAAsB,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;IAC1D,CAAC;IACD,IAAI,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QAC7D,KAAK,CAAC,IAAI,CAAC,6BAA6B,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;IACjE,CAAC;IACD,IAAI,MAAM,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;QACvC,KAAK,CAAC,IAAI,CAAC,sBAAsB,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC;IAC3D,CAAC;IACD,IAAI,MAAM,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;QACnC,KAAK,CAAC,IAAI,CAAC,sBAAsB,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;IACvD,CAAC;IACD,IAAI,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QACvD,KAAK,CAAC,IAAI,CAAC,eAAe,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;IAChD,CAAC;IAED,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;AACzD,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { SessionReport, ContextGovernanceSummary } from "../wrapper/index.js";
|
|
2
|
+
import type { ProjectedContext } from "./context-types.js";
|
|
3
|
+
type EvalScoreLabel = "excellent" | "good" | "fair" | "poor";
|
|
4
|
+
export declare function summarizeContextGovernance(projectedContext: ProjectedContext): ContextGovernanceSummary;
|
|
5
|
+
export declare function printContextGovernancePreview(summary: ContextGovernanceSummary): void;
|
|
6
|
+
export declare function computeEvalScore(opts: {
|
|
7
|
+
succeeded: boolean;
|
|
8
|
+
durationMs: number;
|
|
9
|
+
costUsd: number;
|
|
10
|
+
verificationPassed: boolean | undefined;
|
|
11
|
+
toolCallCount: number;
|
|
12
|
+
}): {
|
|
13
|
+
score: number;
|
|
14
|
+
label: EvalScoreLabel;
|
|
15
|
+
signals: string[];
|
|
16
|
+
};
|
|
17
|
+
export declare function printReport(report: SessionReport, appName: string): void;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=session-report.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-report.d.ts","sourceRoot":"","sources":["../../src/application/session-report.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AACnF,OAAO,KAAK,EAAE,gBAAgB,EAA6B,MAAM,oBAAoB,CAAC;AAEtF,KAAK,cAAc,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAiD7D,wBAAgB,0BAA0B,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,wBAAwB,CA2BvG;AAED,wBAAgB,6BAA6B,CAAC,OAAO,EAAE,wBAAwB,GAAG,IAAI,CA6BrF;AAED,wBAAgB,gBAAgB,CAAC,IAAI,EAAE;IACrC,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,kBAAkB,EAAE,OAAO,GAAG,SAAS,CAAC;IACxC,aAAa,EAAE,MAAM,CAAC;CACvB,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,cAAc,CAAC;IAAC,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,CA0C9D;AAED,wBAAgB,WAAW,CAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CA6ExE"}
|