@telora/daemon 0.16.27 → 0.16.42
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/build-info.json +4 -3
- package/dist/assembly-resolvers.d.ts +13 -65
- package/dist/assembly-resolvers.d.ts.map +1 -1
- package/dist/assembly-resolvers.js +15 -1915
- package/dist/assembly-resolvers.js.map +1 -1
- package/dist/audit-phase.d.ts +2 -2
- package/dist/audit-phase.d.ts.map +1 -1
- package/dist/audit-phase.js +1 -1
- package/dist/audit-phase.js.map +1 -1
- package/dist/circuit-wedge-watcher.d.ts +48 -0
- package/dist/circuit-wedge-watcher.d.ts.map +1 -0
- package/dist/circuit-wedge-watcher.js +94 -0
- package/dist/circuit-wedge-watcher.js.map +1 -0
- package/dist/{completion-handler.d.ts → completion/agent-completion.d.ts} +3 -3
- package/dist/completion/agent-completion.d.ts.map +1 -0
- package/dist/{completion-handler.js → completion/agent-completion.js} +7 -7
- package/dist/completion/agent-completion.js.map +1 -0
- package/dist/{completion-detector.d.ts → completion/detector.d.ts} +1 -1
- package/dist/completion/detector.d.ts.map +1 -0
- package/dist/{completion-detector.js → completion/detector.js} +1 -1
- package/dist/completion/detector.js.map +1 -0
- package/dist/{focus-completion-event.d.ts → completion/event.d.ts} +21 -3
- package/dist/completion/event.d.ts.map +1 -0
- package/dist/{focus-completion-event.js → completion/event.js} +55 -9
- package/dist/completion/event.js.map +1 -0
- package/dist/completion/index.d.ts +24 -0
- package/dist/completion/index.d.ts.map +1 -0
- package/dist/completion/index.js +25 -0
- package/dist/completion/index.js.map +1 -0
- package/dist/{focus-completion.d.ts → completion/team-completion.d.ts} +11 -11
- package/dist/completion/team-completion.d.ts.map +1 -0
- package/dist/{focus-completion.js → completion/team-completion.js} +37 -26
- package/dist/completion/team-completion.js.map +1 -0
- package/dist/{focus-team-lifecycle.d.ts → completion/team-lifecycle.d.ts} +2 -2
- package/dist/completion/team-lifecycle.d.ts.map +1 -0
- package/dist/{focus-team-lifecycle.js → completion/team-lifecycle.js} +12 -12
- package/dist/completion/team-lifecycle.js.map +1 -0
- package/dist/directive-executor.d.ts +30 -0
- package/dist/directive-executor.d.ts.map +1 -1
- package/dist/directive-executor.js +46 -0
- package/dist/directive-executor.js.map +1 -1
- package/dist/focus-engine.d.ts.map +1 -1
- package/dist/focus-engine.js +1 -2
- package/dist/focus-engine.js.map +1 -1
- package/dist/focus-executor.d.ts +4 -4
- package/dist/focus-executor.d.ts.map +1 -1
- package/dist/focus-executor.js +11 -5
- package/dist/focus-executor.js.map +1 -1
- package/dist/focus-merge.js +1 -1
- package/dist/focus-merge.js.map +1 -1
- package/dist/focus-prompt-builder.d.ts.map +1 -1
- package/dist/focus-prompt-builder.js +5 -39
- package/dist/focus-prompt-builder.js.map +1 -1
- package/dist/listener.js +1 -1
- package/dist/listener.js.map +1 -1
- package/dist/output-monitor.d.ts +1 -1
- package/dist/output-monitor.d.ts.map +1 -1
- package/dist/output-monitor.js +1 -1
- package/dist/output-monitor.js.map +1 -1
- package/dist/prompt-listing.d.ts +26 -0
- package/dist/prompt-listing.d.ts.map +1 -0
- package/dist/prompt-listing.js +55 -0
- package/dist/prompt-listing.js.map +1 -0
- package/dist/queries/index.d.ts +13 -0
- package/dist/queries/index.d.ts.map +1 -1
- package/dist/queries/index.js +9 -0
- package/dist/queries/index.js.map +1 -1
- package/dist/queries/shared.d.ts +35 -0
- package/dist/queries/shared.d.ts.map +1 -1
- package/dist/queries/shared.js +64 -7
- package/dist/queries/shared.js.map +1 -1
- package/dist/resolvers/agent-escalations.d.ts +2 -0
- package/dist/resolvers/agent-escalations.d.ts.map +1 -0
- package/dist/resolvers/agent-escalations.js +33 -0
- package/dist/resolvers/agent-escalations.js.map +1 -0
- package/dist/resolvers/agent-session-summaries.d.ts +2 -0
- package/dist/resolvers/agent-session-summaries.d.ts.map +1 -0
- package/dist/resolvers/agent-session-summaries.js +28 -0
- package/dist/resolvers/agent-session-summaries.js.map +1 -0
- package/dist/resolvers/delivery-acceptance-criteria.d.ts +2 -0
- package/dist/resolvers/delivery-acceptance-criteria.d.ts.map +1 -0
- package/dist/resolvers/delivery-acceptance-criteria.js +19 -0
- package/dist/resolvers/delivery-acceptance-criteria.js.map +1 -0
- package/dist/resolvers/delivery-description.d.ts +2 -0
- package/dist/resolvers/delivery-description.d.ts.map +1 -0
- package/dist/resolvers/delivery-description.js +19 -0
- package/dist/resolvers/delivery-description.js.map +1 -0
- package/dist/resolvers/delivery-issues.d.ts +2 -0
- package/dist/resolvers/delivery-issues.d.ts.map +1 -0
- package/dist/resolvers/delivery-issues.js +58 -0
- package/dist/resolvers/delivery-issues.js.map +1 -0
- package/dist/resolvers/delivery-listing.d.ts +2 -0
- package/dist/resolvers/delivery-listing.d.ts.map +1 -0
- package/dist/resolvers/delivery-listing.js +54 -0
- package/dist/resolvers/delivery-listing.js.map +1 -0
- package/dist/resolvers/delivery-tech-context.d.ts +2 -0
- package/dist/resolvers/delivery-tech-context.d.ts.map +1 -0
- package/dist/resolvers/delivery-tech-context.js +19 -0
- package/dist/resolvers/delivery-tech-context.js.map +1 -0
- package/dist/resolvers/deployment-profile.d.ts +2 -0
- package/dist/resolvers/deployment-profile.d.ts.map +1 -0
- package/dist/resolvers/deployment-profile.js +28 -0
- package/dist/resolvers/deployment-profile.js.map +1 -0
- package/dist/resolvers/focus-anchoring-injections.d.ts +2 -0
- package/dist/resolvers/focus-anchoring-injections.d.ts.map +1 -0
- package/dist/resolvers/focus-anchoring-injections.js +123 -0
- package/dist/resolvers/focus-anchoring-injections.js.map +1 -0
- package/dist/resolvers/focus-context.d.ts +2 -0
- package/dist/resolvers/focus-context.d.ts.map +1 -0
- package/dist/resolvers/focus-context.js +47 -0
- package/dist/resolvers/focus-context.js.map +1 -0
- package/dist/resolvers/focus-injections.d.ts +2 -0
- package/dist/resolvers/focus-injections.d.ts.map +1 -0
- package/dist/resolvers/focus-injections.js +75 -0
- package/dist/resolvers/focus-injections.js.map +1 -0
- package/dist/resolvers/focus-last-review-report.d.ts +2 -0
- package/dist/resolvers/focus-last-review-report.d.ts.map +1 -0
- package/dist/resolvers/focus-last-review-report.js +46 -0
- package/dist/resolvers/focus-last-review-report.js.map +1 -0
- package/dist/resolvers/focus-reality-tree.d.ts +2 -0
- package/dist/resolvers/focus-reality-tree.d.ts.map +1 -0
- package/dist/resolvers/focus-reality-tree.js +50 -0
- package/dist/resolvers/focus-reality-tree.js.map +1 -0
- package/dist/resolvers/git-diff-against-base.d.ts +2 -0
- package/dist/resolvers/git-diff-against-base.d.ts.map +1 -0
- package/dist/resolvers/git-diff-against-base.js +39 -0
- package/dist/resolvers/git-diff-against-base.js.map +1 -0
- package/dist/resolvers/guards-evaluation-results.d.ts +2 -0
- package/dist/resolvers/guards-evaluation-results.d.ts.map +1 -0
- package/dist/resolvers/guards-evaluation-results.js +31 -0
- package/dist/resolvers/guards-evaluation-results.js.map +1 -0
- package/dist/resolvers/index.d.ts +50 -0
- package/dist/resolvers/index.d.ts.map +1 -0
- package/dist/resolvers/index.js +51 -0
- package/dist/resolvers/index.js.map +1 -0
- package/dist/resolvers/loop-context.d.ts +2 -0
- package/dist/resolvers/loop-context.d.ts.map +1 -0
- package/dist/resolvers/loop-context.js +113 -0
- package/dist/resolvers/loop-context.js.map +1 -0
- package/dist/resolvers/loop-delivery-index.d.ts +2 -0
- package/dist/resolvers/loop-delivery-index.d.ts.map +1 -0
- package/dist/resolvers/loop-delivery-index.js +69 -0
- package/dist/resolvers/loop-delivery-index.js.map +1 -0
- package/dist/resolvers/loop-documents.d.ts +2 -0
- package/dist/resolvers/loop-documents.d.ts.map +1 -0
- package/dist/resolvers/loop-documents.js +30 -0
- package/dist/resolvers/loop-documents.js.map +1 -0
- package/dist/resolvers/loop-expected-effects.d.ts +2 -0
- package/dist/resolvers/loop-expected-effects.d.ts.map +1 -0
- package/dist/resolvers/loop-expected-effects.js +68 -0
- package/dist/resolvers/loop-expected-effects.js.map +1 -0
- package/dist/resolvers/loop-frt-statement.d.ts +2 -0
- package/dist/resolvers/loop-frt-statement.d.ts.map +1 -0
- package/dist/resolvers/loop-frt-statement.js +39 -0
- package/dist/resolvers/loop-frt-statement.js.map +1 -0
- package/dist/resolvers/loop-injection.d.ts +2 -0
- package/dist/resolvers/loop-injection.d.ts.map +1 -0
- package/dist/resolvers/loop-injection.js +48 -0
- package/dist/resolvers/loop-injection.js.map +1 -0
- package/dist/resolvers/loop-persona.d.ts +2 -0
- package/dist/resolvers/loop-persona.d.ts.map +1 -0
- package/dist/resolvers/loop-persona.js +40 -0
- package/dist/resolvers/loop-persona.js.map +1 -0
- package/dist/resolvers/loop-questions.d.ts +2 -0
- package/dist/resolvers/loop-questions.d.ts.map +1 -0
- package/dist/resolvers/loop-questions.js +49 -0
- package/dist/resolvers/loop-questions.js.map +1 -0
- package/dist/resolvers/loop-upstream-udes.d.ts +2 -0
- package/dist/resolvers/loop-upstream-udes.d.ts.map +1 -0
- package/dist/resolvers/loop-upstream-udes.js +88 -0
- package/dist/resolvers/loop-upstream-udes.js.map +1 -0
- package/dist/resolvers/reality-metrics.d.ts +2 -0
- package/dist/resolvers/reality-metrics.d.ts.map +1 -0
- package/dist/resolvers/reality-metrics.js +86 -0
- package/dist/resolvers/reality-metrics.js.map +1 -0
- package/dist/resolvers/reality-projections.d.ts +2 -0
- package/dist/resolvers/reality-projections.d.ts.map +1 -0
- package/dist/resolvers/reality-projections.js +44 -0
- package/dist/resolvers/reality-projections.js.map +1 -0
- package/dist/resolvers/reality-tree-snapshot.d.ts +2 -0
- package/dist/resolvers/reality-tree-snapshot.d.ts.map +1 -0
- package/dist/resolvers/reality-tree-snapshot.js +45 -0
- package/dist/resolvers/reality-tree-snapshot.js.map +1 -0
- package/dist/resolvers/retired-injections.d.ts +2 -0
- package/dist/resolvers/retired-injections.d.ts.map +1 -0
- package/dist/resolvers/retired-injections.js +83 -0
- package/dist/resolvers/retired-injections.js.map +1 -0
- package/dist/resolvers/review-outcomes.d.ts +2 -0
- package/dist/resolvers/review-outcomes.d.ts.map +1 -0
- package/dist/resolvers/review-outcomes.js +38 -0
- package/dist/resolvers/review-outcomes.js.map +1 -0
- package/dist/resolvers/security-advisory.d.ts +2 -0
- package/dist/resolvers/security-advisory.d.ts.map +1 -0
- package/dist/resolvers/security-advisory.js +97 -0
- package/dist/resolvers/security-advisory.js.map +1 -0
- package/dist/resolvers/shared/audit.d.ts +19 -0
- package/dist/resolvers/shared/audit.d.ts.map +1 -0
- package/dist/resolvers/shared/audit.js +28 -0
- package/dist/resolvers/shared/audit.js.map +1 -0
- package/dist/resolvers/shared/format.d.ts +6 -0
- package/dist/resolvers/shared/format.d.ts.map +1 -0
- package/dist/resolvers/shared/format.js +17 -0
- package/dist/resolvers/shared/format.js.map +1 -0
- package/dist/resolvers/shared/git-diff.d.ts +14 -0
- package/dist/resolvers/shared/git-diff.d.ts.map +1 -0
- package/dist/resolvers/shared/git-diff.js +30 -0
- package/dist/resolvers/shared/git-diff.js.map +1 -0
- package/dist/resolvers/shared/loop-items.d.ts +30 -0
- package/dist/resolvers/shared/loop-items.d.ts.map +1 -0
- package/dist/resolvers/shared/loop-items.js +7 -0
- package/dist/resolvers/shared/loop-items.js.map +1 -0
- package/dist/resolvers/shared/loop.d.ts +48 -0
- package/dist/resolvers/shared/loop.d.ts.map +1 -0
- package/dist/resolvers/shared/loop.js +38 -0
- package/dist/resolvers/shared/loop.js.map +1 -0
- package/dist/resolvers/shared/reality-metrics.d.ts +63 -0
- package/dist/resolvers/shared/reality-metrics.d.ts.map +1 -0
- package/dist/resolvers/shared/reality-metrics.js +6 -0
- package/dist/resolvers/shared/reality-metrics.js.map +1 -0
- package/dist/resolvers/shared/reality-tree.d.ts +51 -0
- package/dist/resolvers/shared/reality-tree.d.ts.map +1 -0
- package/dist/resolvers/shared/reality-tree.js +125 -0
- package/dist/resolvers/shared/reality-tree.js.map +1 -0
- package/dist/resolvers/shared/wiki.d.ts +60 -0
- package/dist/resolvers/shared/wiki.d.ts.map +1 -0
- package/dist/resolvers/shared/wiki.js +122 -0
- package/dist/resolvers/shared/wiki.js.map +1 -0
- package/dist/resolvers/wiki-search.d.ts +2 -0
- package/dist/resolvers/wiki-search.d.ts.map +1 -0
- package/dist/resolvers/wiki-search.js +23 -0
- package/dist/resolvers/wiki-search.js.map +1 -0
- package/dist/resolvers/wiki-topic.d.ts +2 -0
- package/dist/resolvers/wiki-topic.d.ts.map +1 -0
- package/dist/resolvers/wiki-topic.js +29 -0
- package/dist/resolvers/wiki-topic.js.map +1 -0
- package/dist/resolvers/workflow-stages.d.ts +2 -0
- package/dist/resolvers/workflow-stages.d.ts.map +1 -0
- package/dist/resolvers/workflow-stages.js +26 -0
- package/dist/resolvers/workflow-stages.js.map +1 -0
- package/dist/session-lifecycle.d.ts +2 -2
- package/dist/session-lifecycle.d.ts.map +1 -1
- package/dist/session-lifecycle.js +3 -3
- package/dist/session-lifecycle.js.map +1 -1
- package/dist/{pending-spawn-guard.d.ts → spawner/guards.d.ts} +1 -1
- package/dist/spawner/guards.d.ts.map +1 -0
- package/dist/{pending-spawn-guard.js → spawner/guards.js} +2 -2
- package/dist/spawner/guards.js.map +1 -0
- package/dist/{focus-spawn-helpers.d.ts → spawner/helpers.d.ts} +6 -6
- package/dist/spawner/helpers.d.ts.map +1 -0
- package/dist/{focus-spawn-helpers.js → spawner/helpers.js} +8 -8
- package/dist/spawner/helpers.js.map +1 -0
- package/dist/spawner/index.d.ts +30 -0
- package/dist/spawner/index.d.ts.map +1 -0
- package/dist/spawner/index.js +32 -0
- package/dist/spawner/index.js.map +1 -0
- package/dist/{spawner-lifecycle.d.ts → spawner/lifecycle.d.ts} +3 -3
- package/dist/spawner/lifecycle.d.ts.map +1 -0
- package/dist/{spawner-lifecycle.js → spawner/lifecycle.js} +6 -6
- package/dist/spawner/lifecycle.js.map +1 -0
- package/dist/{spawner-liveness.d.ts → spawner/liveness.d.ts} +2 -2
- package/dist/spawner/liveness.d.ts.map +1 -0
- package/dist/{spawner-liveness.js → spawner/liveness.js} +4 -4
- package/dist/spawner/liveness.js.map +1 -0
- package/dist/{spawner-resolution.d.ts → spawner/resolution.d.ts} +2 -2
- package/dist/spawner/resolution.d.ts.map +1 -0
- package/dist/{spawner-resolution.js → spawner/resolution.js} +2 -2
- package/dist/spawner/resolution.js.map +1 -0
- package/dist/{team-spawner.d.ts → spawner/spawn-team.d.ts} +4 -4
- package/dist/spawner/spawn-team.d.ts.map +1 -0
- package/dist/{team-spawner.js → spawner/spawn-team.js} +24 -18
- package/dist/spawner/spawn-team.js.map +1 -0
- package/dist/{spawner.d.ts → spawner/state.d.ts} +8 -8
- package/dist/spawner/state.d.ts.map +1 -0
- package/dist/{spawner.js → spawner/state.js} +8 -8
- package/dist/spawner/state.js.map +1 -0
- package/dist/{spawner-stream-handlers.d.ts → spawner/stream-handlers.d.ts} +4 -4
- package/dist/spawner/stream-handlers.d.ts.map +1 -0
- package/dist/{spawner-stream-handlers.js → spawner/stream-handlers.js} +7 -7
- package/dist/spawner/stream-handlers.js.map +1 -0
- package/dist/{spawner-timeout.d.ts → spawner/timeout.d.ts} +2 -2
- package/dist/spawner/timeout.d.ts.map +1 -0
- package/dist/{spawner-timeout.js → spawner/timeout.js} +1 -1
- package/dist/spawner/timeout.js.map +1 -0
- package/dist/team-prompt-base.d.ts.map +1 -1
- package/dist/team-prompt-base.js +4 -27
- package/dist/team-prompt-base.js.map +1 -1
- package/dist/telemetry-writer.d.ts +20 -1
- package/dist/telemetry-writer.d.ts.map +1 -1
- package/dist/telemetry-writer.js +121 -7
- package/dist/telemetry-writer.js.map +1 -1
- package/dist/trigger-executor.d.ts.map +1 -1
- package/dist/trigger-executor.js +6 -0
- package/dist/trigger-executor.js.map +1 -1
- package/dist/types/focus.d.ts +1 -1
- package/dist/types/focus.d.ts.map +1 -1
- package/dist/unified-shell.d.ts.map +1 -1
- package/dist/unified-shell.js +8 -0
- package/dist/unified-shell.js.map +1 -1
- package/package.json +1 -1
- package/dist/completion-detector.d.ts.map +0 -1
- package/dist/completion-detector.js.map +0 -1
- package/dist/completion-handler.d.ts.map +0 -1
- package/dist/completion-handler.js.map +0 -1
- package/dist/focus-completion-event.d.ts.map +0 -1
- package/dist/focus-completion-event.js.map +0 -1
- package/dist/focus-completion.d.ts.map +0 -1
- package/dist/focus-completion.js.map +0 -1
- package/dist/focus-spawn-helpers.d.ts.map +0 -1
- package/dist/focus-spawn-helpers.js.map +0 -1
- package/dist/focus-team-lifecycle.d.ts.map +0 -1
- package/dist/focus-team-lifecycle.js.map +0 -1
- package/dist/pending-spawn-guard.d.ts.map +0 -1
- package/dist/pending-spawn-guard.js.map +0 -1
- package/dist/prompt-builder.d.ts +0 -14
- package/dist/prompt-builder.d.ts.map +0 -1
- package/dist/prompt-builder.js +0 -174
- package/dist/prompt-builder.js.map +0 -1
- package/dist/spawner-lifecycle.d.ts.map +0 -1
- package/dist/spawner-lifecycle.js.map +0 -1
- package/dist/spawner-liveness.d.ts.map +0 -1
- package/dist/spawner-liveness.js.map +0 -1
- package/dist/spawner-resolution.d.ts.map +0 -1
- package/dist/spawner-resolution.js.map +0 -1
- package/dist/spawner-stream-handlers.d.ts.map +0 -1
- package/dist/spawner-stream-handlers.js.map +0 -1
- package/dist/spawner-timeout.d.ts.map +0 -1
- package/dist/spawner-timeout.js.map +0 -1
- package/dist/spawner.d.ts.map +0 -1
- package/dist/spawner.js.map +0 -1
- package/dist/team-spawner.d.ts.map +0 -1
- package/dist/team-spawner.js.map +0 -1
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { getDeliveryInjectionPairs, fetchInjectionBundles } from './shared/loop.js';
|
|
3
|
+
/**
|
|
4
|
+
* loop.injection
|
|
5
|
+
*
|
|
6
|
+
* For each delivery in context.deliveryIds with a linked injection, render
|
|
7
|
+
* the injection node: statement, lifecycle status, what obstacle it
|
|
8
|
+
* dissolves. Plain markdown; no upstream/downstream walk (that lives in
|
|
9
|
+
* loop.upstream_udes / loop.expected_effects).
|
|
10
|
+
*/
|
|
11
|
+
registerSourceResolver('loop.injection', async (context) => {
|
|
12
|
+
try {
|
|
13
|
+
const pairs = await getDeliveryInjectionPairs(context);
|
|
14
|
+
if (pairs.length === 0)
|
|
15
|
+
return '';
|
|
16
|
+
const bundles = await fetchInjectionBundles(pairs.map((p) => p.injectionId));
|
|
17
|
+
if (bundles.size === 0)
|
|
18
|
+
return '';
|
|
19
|
+
const sections = [];
|
|
20
|
+
for (const { deliveryName, injectionId } of pairs) {
|
|
21
|
+
const bundle = bundles.get(injectionId);
|
|
22
|
+
if (!bundle)
|
|
23
|
+
continue;
|
|
24
|
+
const inj = bundle.injection;
|
|
25
|
+
const statusTag = inj.injectionStatus ? ` [${inj.injectionStatus}]` : '';
|
|
26
|
+
const dissolvesLine = inj.dissolvesObstacle
|
|
27
|
+
? `- **Dissolves obstacle:** ${inj.dissolvesObstacle}`
|
|
28
|
+
: null;
|
|
29
|
+
const lines = [
|
|
30
|
+
`### ${deliveryName}`,
|
|
31
|
+
'',
|
|
32
|
+
`- **Injection:** ${inj.statement}${statusTag}`,
|
|
33
|
+
`- **Injection status:** ${inj.injectionStatus ?? '_not set_'}`,
|
|
34
|
+
];
|
|
35
|
+
if (dissolvesLine)
|
|
36
|
+
lines.push(dissolvesLine);
|
|
37
|
+
sections.push(lines.join('\n'));
|
|
38
|
+
}
|
|
39
|
+
if (sections.length === 0)
|
|
40
|
+
return '';
|
|
41
|
+
return `## Loop Injection (per delivery)\n\n${sections.join('\n\n')}`;
|
|
42
|
+
}
|
|
43
|
+
catch (err) {
|
|
44
|
+
console.warn(`[assembly] loop.injection failed: ${err.message}`);
|
|
45
|
+
return '';
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=loop-injection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-injection.js","sourceRoot":"","sources":["../../src/resolvers/loop-injection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAEpF;;;;;;;GAOG;AACH,sBAAsB,CAAC,gBAAgB,EAAE,KAAK,EAAE,OAAwB,EAAmB,EAAE;IAC3F,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,yBAAyB,CAAC,OAAO,CAAC,CAAC;QACvD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAElC,MAAM,OAAO,GAAG,MAAM,qBAAqB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;QAC7E,IAAI,OAAO,CAAC,IAAI,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAElC,MAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,KAAK,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,IAAI,KAAK,EAAE,CAAC;YAClD,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YACxC,IAAI,CAAC,MAAM;gBAAE,SAAS;YACtB,MAAM,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC;YAC7B,MAAM,SAAS,GAAG,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YACzE,MAAM,aAAa,GAAG,GAAG,CAAC,iBAAiB;gBACzC,CAAC,CAAC,6BAA6B,GAAG,CAAC,iBAAiB,EAAE;gBACtD,CAAC,CAAC,IAAI,CAAC;YAET,MAAM,KAAK,GAAa;gBACtB,OAAO,YAAY,EAAE;gBACrB,EAAE;gBACF,oBAAoB,GAAG,CAAC,SAAS,GAAG,SAAS,EAAE;gBAC/C,2BAA2B,GAAG,CAAC,eAAe,IAAI,WAAW,EAAE;aAChE,CAAC;YACF,IAAI,aAAa;gBAAE,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC7C,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAClC,CAAC;QAED,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QACrC,OAAO,uCAAuC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;IACxE,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,qCAAsC,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QAC5E,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-persona.d.ts","sourceRoot":"","sources":["../../src/resolvers/loop-persona.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
import { buildCloseLoopBookkeeperPersona } from '../team-prompt-base.js';
|
|
4
|
+
/**
|
|
5
|
+
* loop.persona
|
|
6
|
+
*
|
|
7
|
+
* Fetches the active persona for the entity's loop layer.
|
|
8
|
+
* Returns the raw "You are..." prompt text, or empty string if none set.
|
|
9
|
+
*
|
|
10
|
+
* Stage variants:
|
|
11
|
+
* - `loop.persona(variant=close_loop)` -- returns the close-loop bookkeeper
|
|
12
|
+
* persona (from team-prompt-base.buildCloseLoopBookkeeperPersona). This
|
|
13
|
+
* is a built-in variant; the stored persona on the focus is ignored so
|
|
14
|
+
* close_loop stage spawns always carry the asymmetric, no-third-option
|
|
15
|
+
* bookkeeper framing regardless of what the human persona on the focus
|
|
16
|
+
* looks like. The close_loop stage dispatcher composes its assembly
|
|
17
|
+
* recipe with `loop.persona(variant=close_loop)` so the team lead
|
|
18
|
+
* receives this exact text.
|
|
19
|
+
*
|
|
20
|
+
* No-variant call returns the human-authored persona stored on the focus.
|
|
21
|
+
*/
|
|
22
|
+
registerSourceResolver('loop.persona', async (context, params) => {
|
|
23
|
+
if (params.variant === 'close_loop') {
|
|
24
|
+
return buildCloseLoopBookkeeperPersona();
|
|
25
|
+
}
|
|
26
|
+
try {
|
|
27
|
+
const result = await callApi('loop_persona_get', {
|
|
28
|
+
entityType: 'focus',
|
|
29
|
+
entityId: context.focusId,
|
|
30
|
+
});
|
|
31
|
+
if (!result.persona || !result.persona.content)
|
|
32
|
+
return '';
|
|
33
|
+
return result.persona.content;
|
|
34
|
+
}
|
|
35
|
+
catch (err) {
|
|
36
|
+
console.warn(`[assembly-engine] loop.persona: failed: ${err.message}`);
|
|
37
|
+
return '';
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
//# sourceMappingURL=loop-persona.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-persona.js","sourceRoot":"","sources":["../../src/resolvers/loop-persona.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,+BAA+B,EAAE,MAAM,wBAAwB,CAAC;AAGzE;;;;;;;;;;;;;;;;;GAiBG;AACH,sBAAsB,CAAC,cAAc,EAAE,KAAK,EAAE,OAAwB,EAAE,MAA8B,EAAmB,EAAE;IACzH,IAAI,MAAM,CAAC,OAAO,KAAK,YAAY,EAAE,CAAC;QACpC,OAAO,+BAA+B,EAAE,CAAC;IAC3C,CAAC;IACD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAoB,kBAAkB,EAAE;YAClE,UAAU,EAAE,OAAO;YACnB,QAAQ,EAAE,OAAO,CAAC,OAAO;SAC1B,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO;YAAE,OAAO,EAAE,CAAC;QAC1D,OAAO,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC;IAChC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,2CAA4C,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QAClF,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-questions.d.ts","sourceRoot":"","sources":["../../src/resolvers/loop-questions.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
/**
|
|
4
|
+
* loop.questions
|
|
5
|
+
*
|
|
6
|
+
* Fetches fixed + generated questions with current answers for the entity layer.
|
|
7
|
+
* Returns formatted markdown: fixed questions first, then generated in rank order.
|
|
8
|
+
*/
|
|
9
|
+
registerSourceResolver('loop.questions', async (context) => {
|
|
10
|
+
try {
|
|
11
|
+
const result = await callApi('loop_question_list', {
|
|
12
|
+
entityType: 'focus',
|
|
13
|
+
entityId: context.focusId,
|
|
14
|
+
detail: 'full',
|
|
15
|
+
});
|
|
16
|
+
const questions = result.items;
|
|
17
|
+
if (!questions || questions.length === 0)
|
|
18
|
+
return '';
|
|
19
|
+
const fixed = questions.filter((q) => q.questionType === 'fixed');
|
|
20
|
+
const generated = questions.filter((q) => q.questionType === 'generated');
|
|
21
|
+
const formatQuestion = async (q) => {
|
|
22
|
+
try {
|
|
23
|
+
const answerResult = await callApi('loop_answer_get', {
|
|
24
|
+
questionId: q.id,
|
|
25
|
+
});
|
|
26
|
+
const answer = answerResult.answer?.content || '_No answer yet._';
|
|
27
|
+
return `**Q:** ${q.text}\n**A:** ${answer}`;
|
|
28
|
+
}
|
|
29
|
+
catch {
|
|
30
|
+
return `**Q:** ${q.text}\n**A:** _No answer yet._`;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
const parts = [];
|
|
34
|
+
if (fixed.length > 0) {
|
|
35
|
+
const fixedLines = await Promise.all(fixed.map(formatQuestion));
|
|
36
|
+
parts.push(`### Fixed Questions\n\n${fixedLines.join('\n\n')}`);
|
|
37
|
+
}
|
|
38
|
+
if (generated.length > 0) {
|
|
39
|
+
const generatedLines = await Promise.all(generated.map(formatQuestion));
|
|
40
|
+
parts.push(`### Generated Questions\n\n${generatedLines.join('\n\n')}`);
|
|
41
|
+
}
|
|
42
|
+
return `## Loop Questions\n\n${parts.join('\n\n')}`;
|
|
43
|
+
}
|
|
44
|
+
catch (err) {
|
|
45
|
+
console.warn(`[assembly-engine] loop.questions: failed: ${err.message}`);
|
|
46
|
+
return '';
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=loop-questions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-questions.js","sourceRoot":"","sources":["../../src/resolvers/loop-questions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG/C;;;;;GAKG;AACH,sBAAsB,CAAC,gBAAgB,EAAE,KAAK,EAAE,OAAwB,EAAmB,EAAE;IAC3F,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAgC,oBAAoB,EAAE;YAChF,UAAU,EAAE,OAAO;YACnB,QAAQ,EAAE,OAAO,CAAC,OAAO;YACzB,MAAM,EAAE,MAAM;SACf,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC;QAC/B,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAEpD,MAAM,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAmB,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,CAAC;QACpF,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAmB,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,KAAK,WAAW,CAAC,CAAC;QAE5F,MAAM,cAAc,GAAG,KAAK,EAAE,CAAmB,EAAmB,EAAE;YACpE,IAAI,CAAC;gBACH,MAAM,YAAY,GAAG,MAAM,OAAO,CAAmB,iBAAiB,EAAE;oBACtE,UAAU,EAAE,CAAC,CAAC,EAAE;iBACjB,CAAC,CAAC;gBACH,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,EAAE,OAAO,IAAI,kBAAkB,CAAC;gBAClE,OAAO,UAAU,CAAC,CAAC,IAAI,YAAY,MAAM,EAAE,CAAC;YAC9C,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,UAAU,CAAC,CAAC,IAAI,2BAA2B,CAAC;YACrD,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,KAAK,GAAa,EAAE,CAAC;QAE3B,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACrB,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC;YAChE,KAAK,CAAC,IAAI,CAAC,0BAA0B,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAClE,CAAC;QAED,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzB,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC;YACxE,KAAK,CAAC,IAAI,CAAC,8BAA8B,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC1E,CAAC;QAED,OAAO,wBAAwB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;IACtD,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,6CAA8C,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QACpF,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-upstream-udes.d.ts","sourceRoot":"","sources":["../../src/resolvers/loop-upstream-udes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
import { getDeliveryInjectionPairs, fetchInjectionBundles, MAX_UPSTREAM_DEPTH } from './shared/loop.js';
|
|
4
|
+
/**
|
|
5
|
+
* loop.upstream_udes
|
|
6
|
+
*
|
|
7
|
+
* For each delivery's injection, find the nodes that the injection
|
|
8
|
+
* targets (via 'targets' edges), then BFS upstream from those targets
|
|
9
|
+
* along causal edges ('sufficient' and 'and' edge kinds) up to
|
|
10
|
+
* MAX_UPSTREAM_DEPTH hops. Returns a markdown list of upstream UDE/
|
|
11
|
+
* entity nodes the injection is indirectly meant to address. Cycle-safe.
|
|
12
|
+
*/
|
|
13
|
+
registerSourceResolver('loop.upstream_udes', async (context) => {
|
|
14
|
+
try {
|
|
15
|
+
const pairs = await getDeliveryInjectionPairs(context);
|
|
16
|
+
if (pairs.length === 0)
|
|
17
|
+
return '';
|
|
18
|
+
const bundles = await fetchInjectionBundles(pairs.map((p) => p.injectionId));
|
|
19
|
+
if (bundles.size === 0)
|
|
20
|
+
return '';
|
|
21
|
+
const sections = [];
|
|
22
|
+
for (const { deliveryName, injectionId } of pairs) {
|
|
23
|
+
const bundle = bundles.get(injectionId);
|
|
24
|
+
if (!bundle)
|
|
25
|
+
continue;
|
|
26
|
+
const treeId = bundle.injection.realityTreeId;
|
|
27
|
+
const [nodesResp, edgesResp] = await Promise.all([
|
|
28
|
+
callApi('reality_tree_node_list', { treeId, status: 'active' }),
|
|
29
|
+
callApi('reality_tree_edge_list', { treeId }),
|
|
30
|
+
]);
|
|
31
|
+
const nodes = nodesResp.items ?? [];
|
|
32
|
+
const edges = edgesResp.items ?? [];
|
|
33
|
+
const nodeById = new Map();
|
|
34
|
+
for (const n of nodes)
|
|
35
|
+
nodeById.set(n.id, n);
|
|
36
|
+
// Seed: the nodes the injection targets directly.
|
|
37
|
+
const seeds = edges
|
|
38
|
+
.filter((e) => e.edgeType === 'targets' && e.fromNodeId === injectionId)
|
|
39
|
+
.map((e) => e.toNodeId);
|
|
40
|
+
if (seeds.length === 0)
|
|
41
|
+
continue;
|
|
42
|
+
// BFS upstream along causal edges: walk edges where to_node_id is
|
|
43
|
+
// in the current frontier; the from_node_id of those edges is the
|
|
44
|
+
// upstream node. Bounded by MAX_UPSTREAM_DEPTH and cycle-safe via
|
|
45
|
+
// visited set. Seeds themselves are excluded from output (we want
|
|
46
|
+
// their upstream, not the seeds).
|
|
47
|
+
const visited = new Set(seeds);
|
|
48
|
+
const collected = [];
|
|
49
|
+
let frontier = new Set(seeds);
|
|
50
|
+
for (let depth = 0; depth < MAX_UPSTREAM_DEPTH; depth++) {
|
|
51
|
+
if (frontier.size === 0)
|
|
52
|
+
break;
|
|
53
|
+
const next = new Set();
|
|
54
|
+
for (const edge of edges) {
|
|
55
|
+
if (edge.edgeType !== 'sufficient' && edge.edgeType !== 'and')
|
|
56
|
+
continue;
|
|
57
|
+
if (!frontier.has(edge.toNodeId))
|
|
58
|
+
continue;
|
|
59
|
+
const upId = edge.fromNodeId;
|
|
60
|
+
if (visited.has(upId))
|
|
61
|
+
continue;
|
|
62
|
+
visited.add(upId);
|
|
63
|
+
next.add(upId);
|
|
64
|
+
const upNode = nodeById.get(upId);
|
|
65
|
+
if (upNode)
|
|
66
|
+
collected.push(upNode);
|
|
67
|
+
}
|
|
68
|
+
frontier = next;
|
|
69
|
+
}
|
|
70
|
+
if (collected.length === 0)
|
|
71
|
+
continue;
|
|
72
|
+
collected.sort((a, b) => a.seq - b.seq);
|
|
73
|
+
const lines = collected.map((n) => {
|
|
74
|
+
const typeTag = n.nodeType !== 'entity' ? ` [${n.nodeType}]` : '';
|
|
75
|
+
return `- #${n.seq} ${n.statement}${typeTag}`;
|
|
76
|
+
});
|
|
77
|
+
sections.push(`### ${deliveryName}\n\n${lines.join('\n')}`);
|
|
78
|
+
}
|
|
79
|
+
if (sections.length === 0)
|
|
80
|
+
return '';
|
|
81
|
+
return `## Upstream UDEs (per delivery, max depth ${MAX_UPSTREAM_DEPTH})\n\n${sections.join('\n\n')}`;
|
|
82
|
+
}
|
|
83
|
+
catch (err) {
|
|
84
|
+
console.warn(`[assembly] loop.upstream_udes failed: ${err.message}`);
|
|
85
|
+
return '';
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
//# sourceMappingURL=loop-upstream-udes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-upstream-udes.js","sourceRoot":"","sources":["../../src/resolvers/loop-upstream-udes.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reality-metrics.d.ts","sourceRoot":"","sources":["../../src/resolvers/reality-metrics.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
/**
|
|
4
|
+
* reality.metrics
|
|
5
|
+
*
|
|
6
|
+
* Fetches focus reality metrics + trajectory projections from the edge function.
|
|
7
|
+
* Formats as markdown for agent consumption (Wire B of the differential pair).
|
|
8
|
+
*/
|
|
9
|
+
registerSourceResolver('reality.metrics', async (context) => {
|
|
10
|
+
try {
|
|
11
|
+
const result = await callApi('reality_metrics_focus', {
|
|
12
|
+
focusId: context.focusId,
|
|
13
|
+
});
|
|
14
|
+
const m = result.metrics;
|
|
15
|
+
if (!m)
|
|
16
|
+
return '';
|
|
17
|
+
const parts = ['## Execution Reality\n'];
|
|
18
|
+
// Delivery status breakdown
|
|
19
|
+
parts.push('### Delivery Status');
|
|
20
|
+
parts.push(`- Planning: ${m.deliveries_planning} | Queued: ${m.deliveries_queued} | Coding: ${m.deliveries_coding} | Verify: ${m.deliveries_verify} | Done: ${m.deliveries_done} (${m.total_deliveries} total)`);
|
|
21
|
+
// Issue throughput
|
|
22
|
+
parts.push('\n### Issue Throughput');
|
|
23
|
+
parts.push(`- Total: ${m.total_issues} | To Do: ${m.issues_todo} | In Progress: ${m.issues_in_progress} | Done: ${m.issues_done} | Blocked: ${m.issues_blocked}`);
|
|
24
|
+
parts.push(`- Completed: ${m.issues_done_7d} (7d) | ${m.issues_done_14d} (14d) | ${m.issues_done_30d} (30d)`);
|
|
25
|
+
if (m.avg_cycle_time_days !== null) {
|
|
26
|
+
parts.push(`- Avg cycle time: ${m.avg_cycle_time_days} days`);
|
|
27
|
+
}
|
|
28
|
+
if (m.blocked_count > 0) {
|
|
29
|
+
parts.push(`- Blocked: ${m.blocked_count} issues${m.avg_blocked_duration_days !== null ? `, avg duration ${m.avg_blocked_duration_days} days` : ''}`);
|
|
30
|
+
}
|
|
31
|
+
// Agent cost
|
|
32
|
+
parts.push('\n### Agent Activity');
|
|
33
|
+
parts.push(`- Sessions: ${m.session_count} | Cost: $${m.total_agent_cost.toFixed(2)} | Escalations: ${m.escalation_count}`);
|
|
34
|
+
if (m.last_session_at) {
|
|
35
|
+
parts.push(`- Last session: ${m.last_session_at}`);
|
|
36
|
+
}
|
|
37
|
+
// Git merge metrics
|
|
38
|
+
if (m.merge_count !== undefined) {
|
|
39
|
+
parts.push('\n### Git Activity');
|
|
40
|
+
parts.push(`- Total merges: ${m.merge_count} | Last 7d: ${m.merges_7d ?? 0} | Last 30d: ${m.merges_30d ?? 0}`);
|
|
41
|
+
if (m.last_merge_at) {
|
|
42
|
+
parts.push(`- Last merge: ${m.last_merge_at}`);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
// Trajectory projections
|
|
46
|
+
const comp = result.projections?.completion;
|
|
47
|
+
const cost = result.projections?.cost;
|
|
48
|
+
if (comp || cost) {
|
|
49
|
+
parts.push('\n## Trajectory Projections\n');
|
|
50
|
+
}
|
|
51
|
+
if (comp) {
|
|
52
|
+
parts.push('### Completion Forecast');
|
|
53
|
+
if (comp.status === 'complete') {
|
|
54
|
+
parts.push('- Status: **complete** (all issues done)');
|
|
55
|
+
}
|
|
56
|
+
else if (comp.status === 'stalled') {
|
|
57
|
+
parts.push(`- Status: **stalled** -- ${comp.stalledReason || 'no recent throughput'}`);
|
|
58
|
+
parts.push(`- Remaining issues: ${comp.remainingIssues}`);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
parts.push(`- Projected completion: ${comp.projectedCompletionDate ? new Date(comp.projectedCompletionDate).toISOString().split('T')[0] : 'unknown'}`);
|
|
62
|
+
parts.push(`- Days remaining: ${comp.daysRemaining}`);
|
|
63
|
+
parts.push(`- Velocity: ${comp.velocity} issues/day (${comp.windowDays}d window, ${comp.completedInWindow} completed)`);
|
|
64
|
+
parts.push(`- Confidence: ${comp.confidence}`);
|
|
65
|
+
parts.push(`- Remaining issues: ${comp.remainingIssues}`);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
if (cost) {
|
|
69
|
+
parts.push('\n### Cost Forecast');
|
|
70
|
+
parts.push(`- Cost to date: $${cost.costToDate.toFixed(2)}`);
|
|
71
|
+
parts.push(`- Burn rate: $${cost.burnRatePerDay.toFixed(2)}/day`);
|
|
72
|
+
if (cost.avgCostPerIssue !== null) {
|
|
73
|
+
parts.push(`- Avg cost per issue: $${cost.avgCostPerIssue.toFixed(2)}`);
|
|
74
|
+
}
|
|
75
|
+
if (cost.projectedTotalCost !== null) {
|
|
76
|
+
parts.push(`- Projected total: $${cost.projectedTotalCost.toFixed(2)} ($${cost.projectedRemainingCost?.toFixed(2)} remaining)`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
return parts.join('\n');
|
|
80
|
+
}
|
|
81
|
+
catch (err) {
|
|
82
|
+
console.warn(`[assembly-engine] reality.metrics: failed: ${err.message}`);
|
|
83
|
+
return '';
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
//# sourceMappingURL=reality-metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reality-metrics.js","sourceRoot":"","sources":["../../src/resolvers/reality-metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reality-projections.d.ts","sourceRoot":"","sources":["../../src/resolvers/reality-projections.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
/**
|
|
4
|
+
* reality.projections
|
|
5
|
+
*
|
|
6
|
+
* Compact format: just the forecasted outcomes for quick delta computation.
|
|
7
|
+
*/
|
|
8
|
+
registerSourceResolver('reality.projections', async (context) => {
|
|
9
|
+
try {
|
|
10
|
+
const result = await callApi('reality_metrics_focus', {
|
|
11
|
+
focusId: context.focusId,
|
|
12
|
+
});
|
|
13
|
+
const comp = result.projections?.completion;
|
|
14
|
+
const cost = result.projections?.cost;
|
|
15
|
+
if (!comp && !cost)
|
|
16
|
+
return '';
|
|
17
|
+
const lines = ['## Trajectory Projections\n'];
|
|
18
|
+
if (comp) {
|
|
19
|
+
if (comp.status === 'complete') {
|
|
20
|
+
lines.push('- Completion: **complete**');
|
|
21
|
+
}
|
|
22
|
+
else if (comp.status === 'stalled') {
|
|
23
|
+
lines.push(`- Completion: **stalled** (${comp.remainingIssues} remaining)`);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
lines.push(`- Completion: ${comp.projectedCompletionDate ? new Date(comp.projectedCompletionDate).toISOString().split('T')[0] : '?'} (${comp.daysRemaining}d, confidence ${comp.confidence})`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
if (cost) {
|
|
30
|
+
if (cost.projectedTotalCost !== null) {
|
|
31
|
+
lines.push(`- Cost: $${cost.costToDate.toFixed(2)} spent, $${cost.projectedTotalCost.toFixed(2)} projected total`);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
lines.push(`- Cost: $${cost.costToDate.toFixed(2)} spent (insufficient data to project)`);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
return lines.join('\n');
|
|
38
|
+
}
|
|
39
|
+
catch (err) {
|
|
40
|
+
console.warn(`[assembly-engine] reality.projections: failed: ${err.message}`);
|
|
41
|
+
return '';
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
//# sourceMappingURL=reality-projections.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reality-projections.js","sourceRoot":"","sources":["../../src/resolvers/reality-projections.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG/C;;;;GAIG;AACH,sBAAsB,CAAC,qBAAqB,EAAE,KAAK,EAAE,OAAwB,EAAmB,EAAE;IAChG,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAqB,uBAAuB,EAAE;YACxE,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,EAAE,UAAU,CAAC;QAC5C,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,EAAE,IAAI,CAAC;QAEtC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI;YAAE,OAAO,EAAE,CAAC;QAE9B,MAAM,KAAK,GAAa,CAAC,6BAA6B,CAAC,CAAC;QAExD,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,EAAE,CAAC;gBAC/B,KAAK,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;YAC3C,CAAC;iBAAM,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBACrC,KAAK,CAAC,IAAI,CAAC,8BAA8B,IAAI,CAAC,eAAe,aAAa,CAAC,CAAC;YAC9E,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,IAAI,CAAC,iBAAiB,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,aAAa,iBAAiB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACjM,CAAC;QACH,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,IAAI,CAAC,kBAAkB,KAAK,IAAI,EAAE,CAAC;gBACrC,KAAK,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;YACrH,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,uCAAuC,CAAC,CAAC;YAC5F,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,kDAAmD,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QACzF,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reality-tree-snapshot.d.ts","sourceRoot":"","sources":["../../src/resolvers/reality-tree-snapshot.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
import { CRT_DUMP_BUDGET_CHARS, renderRealityTreeDump, } from './shared/reality-tree.js';
|
|
4
|
+
/**
|
|
5
|
+
* reality_tree.snapshot
|
|
6
|
+
*
|
|
7
|
+
* Returns the focus's reality tree(s) as a structured text dump for the
|
|
8
|
+
* audit assessor. Same shape as focus.reality_tree but with the "CRT Dump"
|
|
9
|
+
* heading renamed to "Snapshot" so the audit prompt distinguishes its
|
|
10
|
+
* "current graph" input from other tree-related sections. Fails soft.
|
|
11
|
+
*/
|
|
12
|
+
registerSourceResolver('reality_tree.snapshot', async (context) => {
|
|
13
|
+
try {
|
|
14
|
+
const treesResp = await callApi('reality_tree_list', {
|
|
15
|
+
focusId: context.focusId,
|
|
16
|
+
});
|
|
17
|
+
const trees = (treesResp.items ?? []).filter((t) => t.status === 'active');
|
|
18
|
+
if (trees.length === 0)
|
|
19
|
+
return '';
|
|
20
|
+
const sections = [];
|
|
21
|
+
let used = 0;
|
|
22
|
+
for (const tree of trees) {
|
|
23
|
+
if (used >= CRT_DUMP_BUDGET_CHARS)
|
|
24
|
+
break;
|
|
25
|
+
const remaining = CRT_DUMP_BUDGET_CHARS - used;
|
|
26
|
+
const [nodesResp, edgesResp] = await Promise.all([
|
|
27
|
+
callApi('reality_tree_node_list', { treeId: tree.id, status: 'active' }),
|
|
28
|
+
callApi('reality_tree_edge_list', { treeId: tree.id }),
|
|
29
|
+
]);
|
|
30
|
+
const dump = renderRealityTreeDump(tree, nodesResp.items ?? [], edgesResp.items ?? [], remaining);
|
|
31
|
+
if (dump.length === 0)
|
|
32
|
+
continue;
|
|
33
|
+
sections.push(dump);
|
|
34
|
+
used += dump.length;
|
|
35
|
+
}
|
|
36
|
+
if (sections.length === 0)
|
|
37
|
+
return '';
|
|
38
|
+
return `## Reality Tree Snapshot\n\n${sections.join('\n\n')}`;
|
|
39
|
+
}
|
|
40
|
+
catch (err) {
|
|
41
|
+
console.warn(`[assembly] reality_tree.snapshot failed: ${err.message}`);
|
|
42
|
+
return '';
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
//# sourceMappingURL=reality-tree-snapshot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reality-tree-snapshot.js","sourceRoot":"","sources":["../../src/resolvers/reality-tree-snapshot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EACL,qBAAqB,EACrB,qBAAqB,GAItB,MAAM,0BAA0B,CAAC;AAElC;;;;;;;GAOG;AACH,sBAAsB,CAAC,uBAAuB,EAAE,KAAK,EAAE,OAAwB,EAAmB,EAAE;IAClG,IAAI,CAAC;QACH,MAAM,SAAS,GAAG,MAAM,OAAO,CAA0B,mBAAmB,EAAE;YAC5E,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC;QAC3E,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAElC,MAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,IAAI,qBAAqB;gBAAE,MAAM;YACzC,MAAM,SAAS,GAAG,qBAAqB,GAAG,IAAI,CAAC;YAC/C,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAC/C,OAAO,CAAmB,wBAAwB,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;gBAC1F,OAAO,CAAmB,wBAAwB,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC;aACzE,CAAC,CAAC;YACH,MAAM,IAAI,GAAG,qBAAqB,CAChC,IAAI,EACJ,SAAS,CAAC,KAAK,IAAI,EAAE,EACrB,SAAS,CAAC,KAAK,IAAI,EAAE,EACrB,SAAS,CACV,CAAC;YACF,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;gBAAE,SAAS;YAChC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC;QACtB,CAAC;QACD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QACrC,OAAO,+BAA+B,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;IAChE,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,4CAA6C,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QACnF,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retired-injections.d.ts","sourceRoot":"","sources":["../../src/resolvers/retired-injections.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { registerSourceResolver } from '../assembly-engine.js';
|
|
2
|
+
import { callApi } from '../queries/shared.js';
|
|
3
|
+
import { getAuditCycleLowerBound } from './shared/audit.js';
|
|
4
|
+
/**
|
|
5
|
+
* retired_injections
|
|
6
|
+
*
|
|
7
|
+
* Lists injections retired in the focus's current audit cycle. Each entry
|
|
8
|
+
* includes the dissolvesObstacle text and the UDE statements the injection
|
|
9
|
+
* targeted (via 'targets' edges, looked up from the retired-injection's
|
|
10
|
+
* tree). Failures fail soft -- return ''.
|
|
11
|
+
*/
|
|
12
|
+
registerSourceResolver('retired_injections', async (context) => {
|
|
13
|
+
try {
|
|
14
|
+
const treesResp = await callApi('reality_tree_list', {
|
|
15
|
+
focusId: context.focusId,
|
|
16
|
+
});
|
|
17
|
+
const trees = (treesResp.items ?? []).filter((t) => t.status === 'active');
|
|
18
|
+
if (trees.length === 0)
|
|
19
|
+
return '';
|
|
20
|
+
const since = await getAuditCycleLowerBound(context.focusId);
|
|
21
|
+
const sections = [];
|
|
22
|
+
for (const tree of trees) {
|
|
23
|
+
const [retiredResp, edgesResp, nodesResp] = await Promise.all([
|
|
24
|
+
callApi('reality_tree_node_list', {
|
|
25
|
+
treeId: tree.id, nodeType: 'injection', status: 'retired',
|
|
26
|
+
}),
|
|
27
|
+
callApi('reality_tree_edge_list', { treeId: tree.id }),
|
|
28
|
+
// Pull the active node universe so we can resolve target statements
|
|
29
|
+
// even if a target was itself retired alongside the injection.
|
|
30
|
+
callApi('reality_tree_node_list', { treeId: tree.id, status: 'active' }),
|
|
31
|
+
]);
|
|
32
|
+
const retired = retiredResp.items ?? [];
|
|
33
|
+
if (retired.length === 0)
|
|
34
|
+
continue;
|
|
35
|
+
const filtered = since
|
|
36
|
+
? retired.filter((n) => {
|
|
37
|
+
// updated_at is not on the typed surface but the row carries it;
|
|
38
|
+
// fall back to including the node if the field isn't present so
|
|
39
|
+
// we don't accidentally drop a real retirement.
|
|
40
|
+
const updatedAt = n.updatedAt;
|
|
41
|
+
return !updatedAt || updatedAt >= since;
|
|
42
|
+
})
|
|
43
|
+
: retired;
|
|
44
|
+
if (filtered.length === 0)
|
|
45
|
+
continue;
|
|
46
|
+
const allNodes = [...(nodesResp.items ?? []), ...retired];
|
|
47
|
+
const nodeById = new Map();
|
|
48
|
+
for (const n of allNodes)
|
|
49
|
+
nodeById.set(n.id, n);
|
|
50
|
+
const targetsBySource = new Map();
|
|
51
|
+
for (const e of edgesResp.items ?? []) {
|
|
52
|
+
if (e.edgeType !== 'targets')
|
|
53
|
+
continue;
|
|
54
|
+
const list = targetsBySource.get(e.fromNodeId) ?? [];
|
|
55
|
+
list.push(e.toNodeId);
|
|
56
|
+
targetsBySource.set(e.fromNodeId, list);
|
|
57
|
+
}
|
|
58
|
+
const lines = [`### Tree: ${tree.name}`];
|
|
59
|
+
for (const inj of filtered.sort((a, b) => a.seq - b.seq)) {
|
|
60
|
+
lines.push('', `- **#${inj.seq} ${inj.statement}**`);
|
|
61
|
+
if (inj.dissolvesObstacle) {
|
|
62
|
+
lines.push(` - dissolves: ${inj.dissolvesObstacle.replace(/\n/g, ' ')}`);
|
|
63
|
+
}
|
|
64
|
+
const targetIds = targetsBySource.get(inj.id) ?? [];
|
|
65
|
+
for (const tid of targetIds) {
|
|
66
|
+
const t = nodeById.get(tid);
|
|
67
|
+
if (!t)
|
|
68
|
+
continue;
|
|
69
|
+
lines.push(` - target: #${t.seq} (${t.nodeType}) ${t.statement.replace(/\n/g, ' ')}`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
sections.push(lines.join('\n'));
|
|
73
|
+
}
|
|
74
|
+
if (sections.length === 0)
|
|
75
|
+
return '';
|
|
76
|
+
return `## Retired Injections (current cycle)\n\n${sections.join('\n\n')}`;
|
|
77
|
+
}
|
|
78
|
+
catch (err) {
|
|
79
|
+
console.warn(`[assembly] retired_injections failed: ${err.message}`);
|
|
80
|
+
return '';
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
//# sourceMappingURL=retired-injections.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retired-injections.js","sourceRoot":"","sources":["../../src/resolvers/retired-injections.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"review-outcomes.d.ts","sourceRoot":"","sources":["../../src/resolvers/review-outcomes.ts"],"names":[],"mappings":""}
|