gitmem-mcp 1.0.0 → 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/CLAUDE.md.template +63 -55
- package/README.md +60 -29
- package/bin/gitmem.js +233 -109
- package/bin/init-wizard.js +642 -0
- package/bin/uninstall.js +288 -0
- package/dist/commands/check.js +20 -20
- package/dist/commands/check.js.map +1 -1
- package/dist/constants/closing-questions.d.ts +6 -0
- package/dist/constants/closing-questions.d.ts.map +1 -1
- package/dist/constants/closing-questions.js +65 -0
- package/dist/constants/closing-questions.js.map +1 -1
- package/dist/hooks/format-utils.d.ts +52 -0
- package/dist/hooks/format-utils.d.ts.map +1 -0
- package/dist/hooks/format-utils.js +89 -0
- package/dist/hooks/format-utils.js.map +1 -0
- package/dist/hooks/quick-retrieve.d.ts +30 -0
- package/dist/hooks/quick-retrieve.d.ts.map +1 -0
- package/dist/hooks/quick-retrieve.js +149 -0
- package/dist/hooks/quick-retrieve.js.map +1 -0
- package/dist/index.js +0 -0
- package/dist/schemas/active-sessions.d.ts +8 -8
- package/dist/schemas/analyze.d.ts +3 -3
- package/dist/schemas/common.d.ts +2 -2
- package/dist/schemas/common.d.ts.map +1 -1
- package/dist/schemas/common.js +1 -1
- package/dist/schemas/common.js.map +1 -1
- package/dist/schemas/create-decision.d.ts +3 -3
- package/dist/schemas/create-learning.d.ts +13 -13
- package/dist/schemas/log.d.ts +3 -3
- package/dist/schemas/prepare-context.d.ts +3 -3
- package/dist/schemas/recall.d.ts +3 -3
- package/dist/schemas/record-scar-usage-batch.d.ts +8 -3
- package/dist/schemas/record-scar-usage-batch.d.ts.map +1 -1
- package/dist/schemas/record-scar-usage.d.ts +3 -0
- package/dist/schemas/record-scar-usage.d.ts.map +1 -1
- package/dist/schemas/record-scar-usage.js +1 -0
- package/dist/schemas/record-scar-usage.js.map +1 -1
- package/dist/schemas/registry.d.ts +18 -0
- package/dist/schemas/registry.d.ts.map +1 -0
- package/dist/schemas/registry.js +158 -0
- package/dist/schemas/registry.js.map +1 -0
- package/dist/schemas/save-transcript.d.ts +3 -3
- package/dist/schemas/search-transcripts.d.ts +33 -0
- package/dist/schemas/search-transcripts.d.ts.map +1 -0
- package/dist/schemas/search-transcripts.js +26 -0
- package/dist/schemas/search-transcripts.js.map +1 -0
- package/dist/schemas/search.d.ts +3 -3
- package/dist/schemas/session-close.d.ts +43 -15
- package/dist/schemas/session-close.d.ts.map +1 -1
- package/dist/schemas/session-close.js +7 -2
- package/dist/schemas/session-close.js.map +1 -1
- package/dist/schemas/session-start.d.ts +3 -3
- package/dist/schemas/thread.d.ts +3 -3
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +82 -28
- package/dist/server.js.map +1 -1
- package/dist/services/active-sessions.d.ts +2 -1
- package/dist/services/active-sessions.d.ts.map +1 -1
- package/dist/services/active-sessions.js +130 -84
- package/dist/services/active-sessions.js.map +1 -1
- package/dist/services/analytics.d.ts.map +1 -1
- package/dist/services/analytics.js +1 -0
- package/dist/services/analytics.js.map +1 -1
- package/dist/services/behavioral-decay.d.ts +40 -0
- package/dist/services/behavioral-decay.d.ts.map +1 -0
- package/dist/services/behavioral-decay.js +110 -0
- package/dist/services/behavioral-decay.js.map +1 -0
- package/dist/services/bm25.d.ts +39 -0
- package/dist/services/bm25.d.ts.map +1 -0
- package/dist/services/bm25.js +132 -0
- package/dist/services/bm25.js.map +1 -0
- package/dist/services/cache.d.ts.map +1 -1
- package/dist/services/cache.js +9 -8
- package/dist/services/cache.js.map +1 -1
- package/dist/services/cache.test.js +17 -17
- package/dist/services/cache.test.js.map +1 -1
- package/dist/services/compliance-validator.d.ts.map +1 -1
- package/dist/services/compliance-validator.js +12 -1
- package/dist/services/compliance-validator.js.map +1 -1
- package/dist/services/display-protocol.d.ts +31 -0
- package/dist/services/display-protocol.d.ts.map +1 -0
- package/dist/services/display-protocol.js +73 -0
- package/dist/services/display-protocol.js.map +1 -0
- package/dist/services/effect-tracker.d.ts +81 -0
- package/dist/services/effect-tracker.d.ts.map +1 -0
- package/dist/services/effect-tracker.js +181 -0
- package/dist/services/effect-tracker.js.map +1 -0
- package/dist/services/file-lock.d.ts +31 -0
- package/dist/services/file-lock.d.ts.map +1 -0
- package/dist/services/file-lock.js +124 -0
- package/dist/services/file-lock.js.map +1 -0
- package/dist/services/gitmem-dir.d.ts +7 -0
- package/dist/services/gitmem-dir.d.ts.map +1 -1
- package/dist/services/gitmem-dir.js +21 -0
- package/dist/services/gitmem-dir.js.map +1 -1
- package/dist/services/local-file-storage.d.ts +3 -2
- package/dist/services/local-file-storage.d.ts.map +1 -1
- package/dist/services/local-file-storage.js +30 -43
- package/dist/services/local-file-storage.js.map +1 -1
- package/dist/services/local-vector-search.d.ts +10 -9
- package/dist/services/local-vector-search.d.ts.map +1 -1
- package/dist/services/local-vector-search.js +28 -23
- package/dist/services/local-vector-search.js.map +1 -1
- package/dist/services/metrics.d.ts +7 -2
- package/dist/services/metrics.d.ts.map +1 -1
- package/dist/services/metrics.js +41 -33
- package/dist/services/metrics.js.map +1 -1
- package/dist/services/session-state.d.ts +8 -0
- package/dist/services/session-state.d.ts.map +1 -1
- package/dist/services/session-state.js +9 -2
- package/dist/services/session-state.js.map +1 -1
- package/dist/services/startup.d.ts +12 -13
- package/dist/services/startup.d.ts.map +1 -1
- package/dist/services/startup.js +104 -57
- package/dist/services/startup.js.map +1 -1
- package/dist/services/supabase-client.d.ts +2 -1
- package/dist/services/supabase-client.d.ts.map +1 -1
- package/dist/services/supabase-client.js +22 -16
- package/dist/services/supabase-client.js.map +1 -1
- package/dist/services/thread-dedup.d.ts +9 -0
- package/dist/services/thread-dedup.d.ts.map +1 -1
- package/dist/services/thread-dedup.js +27 -0
- package/dist/services/thread-dedup.js.map +1 -1
- package/dist/services/thread-manager.d.ts.map +1 -1
- package/dist/services/thread-manager.js +38 -16
- package/dist/services/thread-manager.js.map +1 -1
- package/dist/services/thread-suggestions.d.ts.map +1 -1
- package/dist/services/thread-suggestions.js +1 -1
- package/dist/services/thread-suggestions.js.map +1 -1
- package/dist/services/thread-supabase.d.ts +0 -1
- package/dist/services/thread-supabase.d.ts.map +1 -1
- package/dist/services/thread-supabase.js +83 -54
- package/dist/services/thread-supabase.js.map +1 -1
- package/dist/services/timezone.d.ts.map +1 -1
- package/dist/services/timezone.js +1 -0
- package/dist/services/timezone.js.map +1 -1
- package/dist/services/transcript-chunker.d.ts.map +1 -1
- package/dist/services/transcript-chunker.js +18 -4
- package/dist/services/transcript-chunker.js.map +1 -1
- package/dist/services/variant-generation.d.ts +41 -0
- package/dist/services/variant-generation.d.ts.map +1 -0
- package/dist/services/variant-generation.js +263 -0
- package/dist/services/variant-generation.js.map +1 -0
- package/dist/tools/absorb-observations.d.ts.map +1 -1
- package/dist/tools/absorb-observations.js +9 -0
- package/dist/tools/absorb-observations.js.map +1 -1
- package/dist/tools/analyze.d.ts.map +1 -1
- package/dist/tools/analyze.js +13 -2
- package/dist/tools/analyze.js.map +1 -1
- package/dist/tools/archive-learning.d.ts +28 -0
- package/dist/tools/archive-learning.d.ts.map +1 -0
- package/dist/tools/archive-learning.js +81 -0
- package/dist/tools/archive-learning.js.map +1 -0
- package/dist/tools/cleanup-threads.d.ts +1 -0
- package/dist/tools/cleanup-threads.d.ts.map +1 -1
- package/dist/tools/cleanup-threads.js +111 -18
- package/dist/tools/cleanup-threads.js.map +1 -1
- package/dist/tools/confirm-scars.d.ts.map +1 -1
- package/dist/tools/confirm-scars.js +8 -2
- package/dist/tools/confirm-scars.js.map +1 -1
- package/dist/tools/create-decision.d.ts.map +1 -1
- package/dist/tools/create-decision.js +11 -8
- package/dist/tools/create-decision.js.map +1 -1
- package/dist/tools/create-learning.d.ts.map +1 -1
- package/dist/tools/create-learning.js +35 -11
- package/dist/tools/create-learning.js.map +1 -1
- package/dist/tools/create-linear-issue.d.ts +18 -0
- package/dist/tools/create-linear-issue.d.ts.map +1 -0
- package/dist/tools/create-linear-issue.js +197 -0
- package/dist/tools/create-linear-issue.js.map +1 -0
- package/dist/tools/create-thread.d.ts +2 -1
- package/dist/tools/create-thread.d.ts.map +1 -1
- package/dist/tools/create-thread.js +9 -4
- package/dist/tools/create-thread.js.map +1 -1
- package/dist/tools/definitions.d.ts +785 -34
- package/dist/tools/definitions.d.ts.map +1 -1
- package/dist/tools/definitions.js +239 -95
- package/dist/tools/definitions.js.map +1 -1
- package/dist/tools/dismiss-suggestion.d.ts +1 -0
- package/dist/tools/dismiss-suggestion.d.ts.map +1 -1
- package/dist/tools/dismiss-suggestion.js +4 -0
- package/dist/tools/dismiss-suggestion.js.map +1 -1
- package/dist/tools/graph-traverse.d.ts +1 -0
- package/dist/tools/graph-traverse.d.ts.map +1 -1
- package/dist/tools/graph-traverse.js +24 -9
- package/dist/tools/graph-traverse.js.map +1 -1
- package/dist/tools/list-threads.d.ts.map +1 -1
- package/dist/tools/list-threads.js +49 -5
- package/dist/tools/list-threads.js.map +1 -1
- package/dist/tools/log.d.ts +1 -0
- package/dist/tools/log.d.ts.map +1 -1
- package/dist/tools/log.js +84 -17
- package/dist/tools/log.js.map +1 -1
- package/dist/tools/prepare-context.d.ts +1 -0
- package/dist/tools/prepare-context.d.ts.map +1 -1
- package/dist/tools/prepare-context.js +15 -85
- package/dist/tools/prepare-context.js.map +1 -1
- package/dist/tools/promote-suggestion.d.ts +1 -0
- package/dist/tools/promote-suggestion.d.ts.map +1 -1
- package/dist/tools/promote-suggestion.js +5 -0
- package/dist/tools/promote-suggestion.js.map +1 -1
- package/dist/tools/recall.d.ts +2 -0
- package/dist/tools/recall.d.ts.map +1 -1
- package/dist/tools/recall.js +43 -10
- package/dist/tools/recall.js.map +1 -1
- package/dist/tools/recall.test.js +6 -6
- package/dist/tools/recall.test.js.map +1 -1
- package/dist/tools/record-scar-usage-batch.d.ts.map +1 -1
- package/dist/tools/record-scar-usage-batch.js +13 -0
- package/dist/tools/record-scar-usage-batch.js.map +1 -1
- package/dist/tools/record-scar-usage.d.ts.map +1 -1
- package/dist/tools/record-scar-usage.js +6 -0
- package/dist/tools/record-scar-usage.js.map +1 -1
- package/dist/tools/resolve-thread.d.ts.map +1 -1
- package/dist/tools/resolve-thread.js +57 -6
- package/dist/tools/resolve-thread.js.map +1 -1
- package/dist/tools/save-transcript.d.ts +1 -0
- package/dist/tools/save-transcript.d.ts.map +1 -1
- package/dist/tools/save-transcript.js +3 -1
- package/dist/tools/save-transcript.js.map +1 -1
- package/dist/tools/search-transcripts.d.ts +44 -0
- package/dist/tools/search-transcripts.d.ts.map +1 -0
- package/dist/tools/search-transcripts.js +158 -0
- package/dist/tools/search-transcripts.js.map +1 -0
- package/dist/tools/search.d.ts +1 -0
- package/dist/tools/search.d.ts.map +1 -1
- package/dist/tools/search.js +74 -3
- package/dist/tools/search.js.map +1 -1
- package/dist/tools/session-close.d.ts.map +1 -1
- package/dist/tools/session-close.js +563 -326
- package/dist/tools/session-close.js.map +1 -1
- package/dist/tools/session-start.d.ts +10 -6
- package/dist/tools/session-start.d.ts.map +1 -1
- package/dist/tools/session-start.js +317 -426
- package/dist/tools/session-start.js.map +1 -1
- package/dist/types/index.d.ts +37 -4
- package/dist/types/index.d.ts.map +1 -1
- package/hooks/hooks/hooks.json +8 -37
- package/hooks/scripts/auto-retrieve-hook.sh +163 -0
- package/hooks/scripts/post-tool-use.sh +0 -16
- package/hooks/scripts/recall-check.sh +0 -11
- package/hooks/scripts/session-close-check.sh +1 -1
- package/hooks/scripts/session-start.sh +89 -13
- package/hooks/tests/test-hooks.sh +3 -49
- package/package.json +3 -2
- package/schema/setup.sql +1 -1
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* archive_learning Tool
|
|
3
|
+
*
|
|
4
|
+
* Archives a learning (scar/win/pattern) by setting is_active=false
|
|
5
|
+
* and recording archived_at timestamp. Archived learnings are excluded
|
|
6
|
+
* from recall and search results but preserved for audit trail.
|
|
7
|
+
*
|
|
8
|
+
* Also triggers a local cache flush so the archived scar is immediately
|
|
9
|
+
* removed from in-memory search results.
|
|
10
|
+
*/
|
|
11
|
+
import { directPatch, isConfigured } from "../services/supabase-client.js";
|
|
12
|
+
import { hasSupabase } from "../services/tier.js";
|
|
13
|
+
import { flushCache } from "../services/startup.js";
|
|
14
|
+
import { Timer } from "../services/metrics.js";
|
|
15
|
+
import { wrapDisplay } from "../services/display-protocol.js";
|
|
16
|
+
export async function archiveLearning(params) {
|
|
17
|
+
const timer = new Timer();
|
|
18
|
+
if (!params.id || typeof params.id !== "string") {
|
|
19
|
+
const msg = "Missing required parameter: id (UUID of the learning to archive)";
|
|
20
|
+
return {
|
|
21
|
+
success: false,
|
|
22
|
+
id: "",
|
|
23
|
+
cache_flushed: false,
|
|
24
|
+
display: wrapDisplay(msg),
|
|
25
|
+
error: msg,
|
|
26
|
+
performance_ms: timer.stop(),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
if (!hasSupabase() || !isConfigured()) {
|
|
30
|
+
const msg = "archive_learning requires Supabase (pro/dev tier)";
|
|
31
|
+
return {
|
|
32
|
+
success: false,
|
|
33
|
+
id: params.id,
|
|
34
|
+
cache_flushed: false,
|
|
35
|
+
display: wrapDisplay(msg),
|
|
36
|
+
error: msg,
|
|
37
|
+
performance_ms: timer.stop(),
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
try {
|
|
41
|
+
const archivedAt = new Date().toISOString();
|
|
42
|
+
await directPatch("orchestra_learnings", { id: `eq.${params.id}` }, {
|
|
43
|
+
is_active: false,
|
|
44
|
+
archived_at: archivedAt,
|
|
45
|
+
});
|
|
46
|
+
// Flush local cache so archived scar is immediately excluded
|
|
47
|
+
let cacheFlushed = false;
|
|
48
|
+
try {
|
|
49
|
+
await flushCache();
|
|
50
|
+
cacheFlushed = true;
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
console.error("[archive-learning] Cache flush failed (non-fatal)");
|
|
54
|
+
}
|
|
55
|
+
const latencyMs = timer.stop();
|
|
56
|
+
const reasonText = params.reason ? ` Reason: ${params.reason}` : "";
|
|
57
|
+
const display = `Archived learning ${params.id}.${reasonText}\nCache ${cacheFlushed ? "flushed" : "flush failed"} (${latencyMs}ms)`;
|
|
58
|
+
return {
|
|
59
|
+
success: true,
|
|
60
|
+
id: params.id,
|
|
61
|
+
archived_at: archivedAt,
|
|
62
|
+
reason: params.reason,
|
|
63
|
+
cache_flushed: cacheFlushed,
|
|
64
|
+
display: wrapDisplay(display),
|
|
65
|
+
performance_ms: latencyMs,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
catch (error) {
|
|
69
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
70
|
+
const latencyMs = timer.stop();
|
|
71
|
+
return {
|
|
72
|
+
success: false,
|
|
73
|
+
id: params.id,
|
|
74
|
+
cache_flushed: false,
|
|
75
|
+
display: wrapDisplay(`Failed to archive learning: ${message}`),
|
|
76
|
+
error: message,
|
|
77
|
+
performance_ms: latencyMs,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=archive-learning.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"archive-learning.js","sourceRoot":"","sources":["../../src/tools/archive-learning.ts"],"names":[],"mappings":"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"}
|
|
@@ -40,6 +40,7 @@ export interface CleanupThreadsResult {
|
|
|
40
40
|
};
|
|
41
41
|
archived_count: number;
|
|
42
42
|
archived_ids: string[];
|
|
43
|
+
display?: string;
|
|
43
44
|
performance: PerformanceData;
|
|
44
45
|
}
|
|
45
46
|
export declare function cleanupThreads(params: CleanupThreadsParams): Promise<CleanupThreadsResult>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cleanup-threads.d.ts","sourceRoot":"","sources":["../../src/tools/cleanup-threads.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;
|
|
1
|
+
{"version":3,"file":"cleanup-threads.d.ts","sourceRoot":"","sources":["../../src/tools/cleanup-threads.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAUH,OAAO,KAAK,EAAe,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAOnF,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAI9D,MAAM,WAAW,oBAAoB;IACnC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,4EAA4E;IAC5E,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,UAAU,aAAa;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,EAAE,eAAe,CAAC;IAClC,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE;QACP,QAAQ,EAAE,MAAM,CAAC;QACjB,MAAM,EAAE,MAAM,CAAC;QACf,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,MAAM,EAAE;QACN,QAAQ,EAAE,aAAa,EAAE,CAAC;QAC1B,MAAM,EAAE,aAAa,EAAE,CAAC;QACxB,OAAO,EAAE,aAAa,EAAE,CAAC;QACzB,OAAO,EAAE,aAAa,EAAE,CAAC;KAC1B,CAAC;IACF,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,eAAe,CAAC;CAC9B;AAqDD,wBAAsB,cAAc,CAClC,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,oBAAoB,CAAC,CA2L/B"}
|
|
@@ -9,23 +9,113 @@
|
|
|
9
9
|
import { v4 as uuidv4 } from "uuid";
|
|
10
10
|
import * as supabase from "../services/supabase-client.js";
|
|
11
11
|
import { hasSupabase } from "../services/tier.js";
|
|
12
|
+
import { getProject } from "../services/session-state.js";
|
|
12
13
|
import { computeLifecycleStatus } from "../services/thread-vitality.js";
|
|
13
14
|
import { archiveDormantThreads } from "../services/thread-supabase.js";
|
|
15
|
+
import { loadThreadsFile } from "../services/thread-manager.js";
|
|
14
16
|
import { Timer, recordMetrics, buildPerformanceData, } from "../services/metrics.js";
|
|
17
|
+
import { wrapDisplay, truncate } from "../services/display-protocol.js";
|
|
18
|
+
// --- Display Formatting ---
|
|
19
|
+
function formatDaysAgo(days) {
|
|
20
|
+
if (days < 1)
|
|
21
|
+
return "now";
|
|
22
|
+
if (days < 7)
|
|
23
|
+
return `${days}d ago`;
|
|
24
|
+
const wk = Math.floor(days / 7);
|
|
25
|
+
if (wk < 52)
|
|
26
|
+
return `${wk}w ago`;
|
|
27
|
+
return `${Math.floor(days / 365)}y ago`;
|
|
28
|
+
}
|
|
29
|
+
function buildCleanupDisplay(summary, groups, archivedCount) {
|
|
30
|
+
const lines = [];
|
|
31
|
+
lines.push(`gitmem cleanup · ${summary.total_open} open · ${summary.active} active · ${summary.cooling} cooling · ${summary.dormant} dormant`);
|
|
32
|
+
lines.push("");
|
|
33
|
+
const totalItems = summary.total_open;
|
|
34
|
+
if (totalItems === 0 && archivedCount === 0) {
|
|
35
|
+
lines.push("No threads found.");
|
|
36
|
+
return wrapDisplay(lines.join("\n"));
|
|
37
|
+
}
|
|
38
|
+
const sections = [
|
|
39
|
+
["Active", groups.active],
|
|
40
|
+
["Emerging", groups.emerging],
|
|
41
|
+
["Cooling", groups.cooling],
|
|
42
|
+
["Dormant", groups.dormant],
|
|
43
|
+
];
|
|
44
|
+
for (const [label, items] of sections) {
|
|
45
|
+
if (items.length === 0)
|
|
46
|
+
continue;
|
|
47
|
+
lines.push(`${label} (${items.length}):`);
|
|
48
|
+
for (const t of items) {
|
|
49
|
+
const text = truncate(t.text, 48);
|
|
50
|
+
const time = formatDaysAgo(t.days_since_touch);
|
|
51
|
+
lines.push(` ${t.thread_id} ${text.padEnd(50)} ${time.padStart(8)}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
lines.push("");
|
|
55
|
+
lines.push(`Archived: ${archivedCount}`);
|
|
56
|
+
return wrapDisplay(lines.join("\n"));
|
|
57
|
+
}
|
|
15
58
|
// ---------- Tool Implementation ----------
|
|
16
59
|
export async function cleanupThreads(params) {
|
|
17
60
|
const timer = new Timer();
|
|
18
61
|
const metricsId = uuidv4();
|
|
19
|
-
const project = (params.project || "
|
|
62
|
+
const project = (params.project || getProject() || "default");
|
|
20
63
|
if (!hasSupabase() || !supabase.isConfigured()) {
|
|
64
|
+
// Free tier: read threads from local .gitmem/threads.json
|
|
65
|
+
const localThreads = loadThreadsFile().filter(t => t.status === "open");
|
|
66
|
+
const now = new Date();
|
|
67
|
+
const localGroups = {
|
|
68
|
+
emerging: [],
|
|
69
|
+
active: [],
|
|
70
|
+
cooling: [],
|
|
71
|
+
dormant: [],
|
|
72
|
+
};
|
|
73
|
+
for (const t of localThreads) {
|
|
74
|
+
const lastTouched = t.last_touched_at || t.created_at;
|
|
75
|
+
const { lifecycle_status, vitality } = computeLifecycleStatus({
|
|
76
|
+
last_touched_at: lastTouched,
|
|
77
|
+
touch_count: 1,
|
|
78
|
+
created_at: t.created_at,
|
|
79
|
+
thread_class: "backlog",
|
|
80
|
+
current_status: t.status,
|
|
81
|
+
}, now);
|
|
82
|
+
const daysSinceTouch = Math.max((now.getTime() - new Date(lastTouched).getTime()) / (1000 * 60 * 60 * 24), 0);
|
|
83
|
+
const summary = {
|
|
84
|
+
thread_id: t.id,
|
|
85
|
+
text: t.text,
|
|
86
|
+
lifecycle_status,
|
|
87
|
+
vitality_score: vitality.vitality_score,
|
|
88
|
+
thread_class: "backlog",
|
|
89
|
+
days_since_touch: Math.round(daysSinceTouch),
|
|
90
|
+
};
|
|
91
|
+
const bucket = lifecycle_status === "archived" ? "dormant" : lifecycle_status;
|
|
92
|
+
if (localGroups[bucket]) {
|
|
93
|
+
localGroups[bucket].push(summary);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
21
96
|
const latencyMs = timer.stop();
|
|
97
|
+
const totalOpen = localGroups.emerging.length + localGroups.active.length + localGroups.cooling.length + localGroups.dormant.length;
|
|
98
|
+
const localSummary = {
|
|
99
|
+
emerging: localGroups.emerging.length,
|
|
100
|
+
active: localGroups.active.length,
|
|
101
|
+
cooling: localGroups.cooling.length,
|
|
102
|
+
dormant: localGroups.dormant.length,
|
|
103
|
+
total_open: totalOpen,
|
|
104
|
+
};
|
|
105
|
+
const localResult = {
|
|
106
|
+
emerging: localGroups.emerging,
|
|
107
|
+
active: localGroups.active,
|
|
108
|
+
cooling: localGroups.cooling,
|
|
109
|
+
dormant: localGroups.dormant,
|
|
110
|
+
};
|
|
22
111
|
return {
|
|
23
|
-
success:
|
|
24
|
-
summary:
|
|
25
|
-
groups:
|
|
112
|
+
success: true,
|
|
113
|
+
summary: localSummary,
|
|
114
|
+
groups: localResult,
|
|
26
115
|
archived_count: 0,
|
|
27
116
|
archived_ids: [],
|
|
28
|
-
|
|
117
|
+
display: buildCleanupDisplay(localSummary, localResult, 0),
|
|
118
|
+
performance: buildPerformanceData("cleanup_threads", latencyMs, totalOpen),
|
|
29
119
|
};
|
|
30
120
|
}
|
|
31
121
|
// Step 1: Auto-archive if requested
|
|
@@ -104,23 +194,26 @@ export async function cleanupThreads(params) {
|
|
|
104
194
|
archived_count,
|
|
105
195
|
},
|
|
106
196
|
}).catch(() => { });
|
|
197
|
+
const resultSummary = {
|
|
198
|
+
emerging: groups.emerging.length,
|
|
199
|
+
active: groups.active.length,
|
|
200
|
+
cooling: groups.cooling.length,
|
|
201
|
+
dormant: groups.dormant.length,
|
|
202
|
+
total_open: totalOpen,
|
|
203
|
+
};
|
|
204
|
+
const resultGroups = {
|
|
205
|
+
emerging: groups.emerging,
|
|
206
|
+
active: groups.active,
|
|
207
|
+
cooling: groups.cooling,
|
|
208
|
+
dormant: groups.dormant,
|
|
209
|
+
};
|
|
107
210
|
return {
|
|
108
211
|
success: true,
|
|
109
|
-
summary:
|
|
110
|
-
|
|
111
|
-
active: groups.active.length,
|
|
112
|
-
cooling: groups.cooling.length,
|
|
113
|
-
dormant: groups.dormant.length,
|
|
114
|
-
total_open: totalOpen,
|
|
115
|
-
},
|
|
116
|
-
groups: {
|
|
117
|
-
emerging: groups.emerging,
|
|
118
|
-
active: groups.active,
|
|
119
|
-
cooling: groups.cooling,
|
|
120
|
-
dormant: groups.dormant,
|
|
121
|
-
},
|
|
212
|
+
summary: resultSummary,
|
|
213
|
+
groups: resultGroups,
|
|
122
214
|
archived_count,
|
|
123
215
|
archived_ids,
|
|
216
|
+
display: buildCleanupDisplay(resultSummary, resultGroups, archived_count),
|
|
124
217
|
performance: perfData,
|
|
125
218
|
};
|
|
126
219
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cleanup-threads.js","sourceRoot":"","sources":["../../src/tools/cleanup-threads.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,QAAQ,MAAM,gCAAgC,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"cleanup-threads.js","sourceRoot":"","sources":["../../src/tools/cleanup-threads.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"confirm-scars.d.ts","sourceRoot":"","sources":["../../src/tools/confirm-scars.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;
|
|
1
|
+
{"version":3,"file":"confirm-scars.d.ts","sourceRoot":"","sources":["../../src/tools/confirm-scars.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAUH,OAAO,KAAK,EACV,kBAAkB,EAClB,kBAAkB,EAKnB,MAAM,mBAAmB,CAAC;AAwH3B;;GAEG;AACH,wBAAsB,YAAY,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAwG1F"}
|
|
@@ -18,6 +18,7 @@
|
|
|
18
18
|
import { getCurrentSession, getSurfacedScars, addConfirmations, } from "../services/session-state.js";
|
|
19
19
|
import { Timer, buildPerformanceData } from "../services/metrics.js";
|
|
20
20
|
import { getSessionPath } from "../services/gitmem-dir.js";
|
|
21
|
+
import { wrapDisplay } from "../services/display-protocol.js";
|
|
21
22
|
import * as fs from "fs";
|
|
22
23
|
// Minimum evidence length per decision type
|
|
23
24
|
const MIN_EVIDENCE_LENGTH = 50;
|
|
@@ -122,12 +123,14 @@ export async function confirmScars(params) {
|
|
|
122
123
|
const session = getCurrentSession();
|
|
123
124
|
if (!session) {
|
|
124
125
|
const performance = buildPerformanceData("confirm_scars", timer.elapsed(), 0);
|
|
126
|
+
const noSessionMsg = "⛔ No active session. Call session_start before confirm_scars.";
|
|
125
127
|
return {
|
|
126
128
|
valid: false,
|
|
127
129
|
errors: ["No active session. Call session_start first."],
|
|
128
130
|
confirmations: [],
|
|
129
131
|
missing_scars: [],
|
|
130
|
-
formatted_response:
|
|
132
|
+
formatted_response: noSessionMsg,
|
|
133
|
+
display: wrapDisplay(noSessionMsg),
|
|
131
134
|
performance,
|
|
132
135
|
};
|
|
133
136
|
}
|
|
@@ -136,12 +139,14 @@ export async function confirmScars(params) {
|
|
|
136
139
|
const recallScars = allSurfacedScars.filter(s => s.source === "recall");
|
|
137
140
|
if (recallScars.length === 0) {
|
|
138
141
|
const performance = buildPerformanceData("confirm_scars", timer.elapsed(), 0);
|
|
142
|
+
const noScarsMsg = "✅ No recall-surfaced scars to confirm. Proceed freely.";
|
|
139
143
|
return {
|
|
140
144
|
valid: true,
|
|
141
145
|
errors: [],
|
|
142
146
|
confirmations: [],
|
|
143
147
|
missing_scars: [],
|
|
144
|
-
formatted_response:
|
|
148
|
+
formatted_response: noScarsMsg,
|
|
149
|
+
display: wrapDisplay(noScarsMsg),
|
|
145
150
|
performance,
|
|
146
151
|
};
|
|
147
152
|
}
|
|
@@ -203,6 +208,7 @@ export async function confirmScars(params) {
|
|
|
203
208
|
confirmations: validConfirmations,
|
|
204
209
|
missing_scars: missingScars,
|
|
205
210
|
formatted_response,
|
|
211
|
+
display: wrapDisplay(formatted_response),
|
|
206
212
|
performance,
|
|
207
213
|
};
|
|
208
214
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"confirm-scars.js","sourceRoot":"","sources":["../../src/tools/confirm-scars.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAEH,OAAO,EACL,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,KAAK,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"confirm-scars.js","sourceRoot":"","sources":["../../src/tools/confirm-scars.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-decision.d.ts","sourceRoot":"","sources":["../../src/tools/create-decision.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;
|
|
1
|
+
{"version":3,"file":"create-decision.d.ts","sourceRoot":"","sources":["../../src/tools/create-decision.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAiBH,OAAO,KAAK,EACV,oBAAoB,EACpB,oBAAoB,EAErB,MAAM,mBAAmB,CAAC;AAE3B;;GAEG;AACH,wBAAsB,cAAc,CAClC,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,oBAAoB,CAAC,CA2H/B"}
|
|
@@ -10,10 +10,13 @@
|
|
|
10
10
|
import { v4 as uuidv4 } from "uuid";
|
|
11
11
|
import * as supabase from "../services/supabase-client.js";
|
|
12
12
|
import { embed, isEmbeddingAvailable } from "../services/embedding.js";
|
|
13
|
+
import { wrapDisplay } from "../services/display-protocol.js";
|
|
13
14
|
import { getAgentIdentity } from "../services/agent-detection.js";
|
|
14
15
|
import { writeTriplesForDecision } from "../services/triple-writer.js";
|
|
16
|
+
import { getEffectTracker } from "../services/effect-tracker.js";
|
|
15
17
|
import { hasSupabase } from "../services/tier.js";
|
|
16
18
|
import { getStorage } from "../services/storage.js";
|
|
19
|
+
import { getProject } from "../services/session-state.js";
|
|
17
20
|
import { Timer, recordMetrics, buildPerformanceData, } from "../services/metrics.js";
|
|
18
21
|
/**
|
|
19
22
|
* Execute create_decision tool
|
|
@@ -34,7 +37,7 @@ export async function createDecision(params) {
|
|
|
34
37
|
docs_affected: params.docs_affected || [],
|
|
35
38
|
linear_issue: params.linear_issue || null,
|
|
36
39
|
session_id: params.session_id || null,
|
|
37
|
-
project: params.project || "
|
|
40
|
+
project: params.project || getProject() || "default",
|
|
38
41
|
created_at: new Date().toISOString(),
|
|
39
42
|
};
|
|
40
43
|
try {
|
|
@@ -71,8 +74,8 @@ export async function createDecision(params) {
|
|
|
71
74
|
cache_status: "not_applicable",
|
|
72
75
|
network_call: true,
|
|
73
76
|
};
|
|
74
|
-
// OD-466: Auto-create knowledge triples (fire-and-forget)
|
|
75
|
-
writeTriplesForDecision({
|
|
77
|
+
// OD-466: Auto-create knowledge triples (tracked fire-and-forget)
|
|
78
|
+
getEffectTracker().track("triple_write", "decision", () => writeTriplesForDecision({
|
|
76
79
|
id: decisionId,
|
|
77
80
|
title: params.title,
|
|
78
81
|
decision: params.decision,
|
|
@@ -81,11 +84,9 @@ export async function createDecision(params) {
|
|
|
81
84
|
docs_affected: params.docs_affected,
|
|
82
85
|
linear_issue: params.linear_issue,
|
|
83
86
|
session_id: params.session_id,
|
|
84
|
-
project: (params.project || "
|
|
87
|
+
project: (params.project || getProject() || "default"),
|
|
85
88
|
agent: getAgentIdentity(),
|
|
86
|
-
})
|
|
87
|
-
console.warn("[create_decision] Triple generation failed (non-fatal):", err);
|
|
88
|
-
});
|
|
89
|
+
}));
|
|
89
90
|
}
|
|
90
91
|
else {
|
|
91
92
|
// Free tier: Store locally without embedding
|
|
@@ -113,7 +114,7 @@ export async function createDecision(params) {
|
|
|
113
114
|
phase_tag: "decision_capture",
|
|
114
115
|
linear_issue: params.linear_issue,
|
|
115
116
|
metadata: {
|
|
116
|
-
project: params.project || "
|
|
117
|
+
project: params.project || getProject() || "default",
|
|
117
118
|
alternatives_count: (params.alternatives_considered || []).length,
|
|
118
119
|
write_path: "directUpsert",
|
|
119
120
|
},
|
|
@@ -122,6 +123,7 @@ export async function createDecision(params) {
|
|
|
122
123
|
success: true,
|
|
123
124
|
decision_id: decisionId,
|
|
124
125
|
performance: perfData,
|
|
126
|
+
display: wrapDisplay(`Decision logged: "${params.title}"\nID: ${decisionId}`),
|
|
125
127
|
};
|
|
126
128
|
}
|
|
127
129
|
catch (error) {
|
|
@@ -132,6 +134,7 @@ export async function createDecision(params) {
|
|
|
132
134
|
success: false,
|
|
133
135
|
decision_id: "",
|
|
134
136
|
performance: perfData,
|
|
137
|
+
display: wrapDisplay(`Failed to log decision`),
|
|
135
138
|
};
|
|
136
139
|
}
|
|
137
140
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-decision.js","sourceRoot":"","sources":["../../src/tools/create-decision.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,QAAQ,MAAM,gCAAgC,CAAC;AAC3D,OAAO,EAAE,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EACL,KAAK,EACL,aAAa,EACb,oBAAoB,GACrB,MAAM,wBAAwB,CAAC;AAOhC;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,MAA4B;IAE5B,MAAM,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;IAC1B,MAAM,SAAS,GAAG,MAAM,EAAE,CAAC;IAC3B,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC;IAC5B,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAErD,MAAM,YAAY,GAA4B;QAC5C,EAAE,EAAE,UAAU;QACd,aAAa,EAAE,KAAK;QACpB,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,uBAAuB,EAAE,MAAM,CAAC,uBAAuB,IAAI,EAAE;QAC7D,iBAAiB,EAAE,MAAM,CAAC,iBAAiB,IAAI,EAAE;QACjD,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,EAAE;QACzC,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,IAAI;QACzC,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,IAAI;QACrC,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,
|
|
1
|
+
{"version":3,"file":"create-decision.js","sourceRoot":"","sources":["../../src/tools/create-decision.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-learning.d.ts","sourceRoot":"","sources":["../../src/tools/create-learning.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;
|
|
1
|
+
{"version":3,"file":"create-learning.d.ts","sourceRoot":"","sources":["../../src/tools/create-learning.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAmBH,OAAO,KAAK,EACV,oBAAoB,EACpB,oBAAoB,EAIrB,MAAM,mBAAmB,CAAC;AAsC3B;;GAEG;AACH,wBAAsB,cAAc,CAClC,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,oBAAoB,CAAC,CAwN/B"}
|
|
@@ -11,10 +11,14 @@ import { v4 as uuidv4 } from "uuid";
|
|
|
11
11
|
import * as supabase from "../services/supabase-client.js";
|
|
12
12
|
import { embed, isEmbeddingAvailable } from "../services/embedding.js";
|
|
13
13
|
import { getAgentIdentity } from "../services/agent-detection.js";
|
|
14
|
+
import { wrapDisplay, TYPE, SEV } from "../services/display-protocol.js";
|
|
14
15
|
import { flushCache } from "../services/startup.js";
|
|
15
16
|
import { writeTriplesForLearning } from "../services/triple-writer.js";
|
|
17
|
+
import { generateVariantsForScar } from "../services/variant-generation.js";
|
|
18
|
+
import { getEffectTracker } from "../services/effect-tracker.js";
|
|
16
19
|
import { hasSupabase } from "../services/tier.js";
|
|
17
20
|
import { getStorage } from "../services/storage.js";
|
|
21
|
+
import { getProject } from "../services/session-state.js";
|
|
18
22
|
import { Timer, recordMetrics, buildPerformanceData, } from "../services/metrics.js";
|
|
19
23
|
/**
|
|
20
24
|
* Validate scar-specific requirements
|
|
@@ -61,7 +65,9 @@ export async function createLearning(params) {
|
|
|
61
65
|
success: false,
|
|
62
66
|
learning_id: "",
|
|
63
67
|
embedding_generated: false,
|
|
68
|
+
errors,
|
|
64
69
|
performance: perfData,
|
|
70
|
+
display: wrapDisplay(`Failed to create ${params.learning_type}: ${errors.join("; ")}`),
|
|
65
71
|
};
|
|
66
72
|
}
|
|
67
73
|
}
|
|
@@ -74,7 +80,7 @@ export async function createLearning(params) {
|
|
|
74
80
|
learning_type: params.learning_type,
|
|
75
81
|
title: params.title,
|
|
76
82
|
description: params.description,
|
|
77
|
-
project: params.project || "
|
|
83
|
+
project: params.project || getProject() || "default",
|
|
78
84
|
source_linear_issue: params.source_linear_issue || null,
|
|
79
85
|
keywords: params.keywords || [],
|
|
80
86
|
domain: params.domain || [],
|
|
@@ -134,7 +140,7 @@ export async function createLearning(params) {
|
|
|
134
140
|
console.warn("[create_learning] No embedding provider configured — storing without embedding");
|
|
135
141
|
}
|
|
136
142
|
console.error(`[create_learning] Attempting directUpsert for learning ${learningId}`);
|
|
137
|
-
console.error(`[create_learning] Learning type: ${params.learning_type}, Project: ${params.project || "
|
|
143
|
+
console.error(`[create_learning] Learning type: ${params.learning_type}, Project: ${params.project || getProject() || "default"}`);
|
|
138
144
|
// Write directly to Supabase REST API (bypasses ww-mcp)
|
|
139
145
|
const upsertStart = Date.now();
|
|
140
146
|
const writeResult = await supabase.directUpsert("orchestra_learnings", learningData);
|
|
@@ -152,8 +158,8 @@ export async function createLearning(params) {
|
|
|
152
158
|
`Expected record with id field.`);
|
|
153
159
|
}
|
|
154
160
|
console.error(`[create_learning] directUpsert succeeded, verified ID: ${writeResult.id}`);
|
|
155
|
-
// OD-466: Auto-create knowledge triples (fire-and-forget)
|
|
156
|
-
writeTriplesForLearning({
|
|
161
|
+
// OD-466: Auto-create knowledge triples (tracked fire-and-forget)
|
|
162
|
+
getEffectTracker().track("triple_write", "learning", () => writeTriplesForLearning({
|
|
157
163
|
id: learningId,
|
|
158
164
|
learning_type: params.learning_type,
|
|
159
165
|
title: params.title,
|
|
@@ -162,12 +168,24 @@ export async function createLearning(params) {
|
|
|
162
168
|
source_linear_issue: params.source_linear_issue,
|
|
163
169
|
persona_name: agentIdentity,
|
|
164
170
|
domain: params.domain,
|
|
165
|
-
project: (params.project || "
|
|
166
|
-
})
|
|
167
|
-
|
|
168
|
-
|
|
171
|
+
project: (params.project || getProject() || "default"),
|
|
172
|
+
}));
|
|
173
|
+
// Auto-generate A/B testing variants for scars (tracked fire-and-forget)
|
|
174
|
+
if (params.learning_type === "scar") {
|
|
175
|
+
getEffectTracker().track("variant_generation", "learning", () => generateVariantsForScar({
|
|
176
|
+
id: learningId,
|
|
177
|
+
title: params.title,
|
|
178
|
+
description: params.description,
|
|
179
|
+
counter_arguments: params.counter_arguments,
|
|
180
|
+
action_protocol: params.action_protocol,
|
|
181
|
+
self_check_criteria: params.self_check_criteria,
|
|
182
|
+
why_this_matters: params.why_this_matters,
|
|
183
|
+
keywords: params.keywords,
|
|
184
|
+
domain: params.domain,
|
|
185
|
+
}));
|
|
186
|
+
}
|
|
169
187
|
// Invalidate local cache so next recall picks up the new learning
|
|
170
|
-
const project = (params.project || "
|
|
188
|
+
const project = (params.project || getProject() || "default");
|
|
171
189
|
flushCache(project).catch((err) => {
|
|
172
190
|
console.warn("[create_learning] Cache invalidation failed (non-fatal):", err);
|
|
173
191
|
});
|
|
@@ -198,28 +216,34 @@ export async function createLearning(params) {
|
|
|
198
216
|
phase_tag: "learning_capture",
|
|
199
217
|
metadata: {
|
|
200
218
|
learning_type: params.learning_type,
|
|
201
|
-
project: params.project || "
|
|
219
|
+
project: params.project || getProject() || "default",
|
|
202
220
|
embedding_generated: embeddingGenerated,
|
|
203
221
|
write_path: "directUpsert",
|
|
204
222
|
},
|
|
205
223
|
}).catch(() => { });
|
|
224
|
+
const te = TYPE[params.learning_type] || "·";
|
|
225
|
+
const se = params.severity ? (SEV[params.severity] || "") + " " : "";
|
|
206
226
|
return {
|
|
207
227
|
success: true,
|
|
208
228
|
learning_id: learningId,
|
|
209
229
|
embedding_generated: embeddingGenerated,
|
|
210
230
|
performance: perfData,
|
|
231
|
+
display: wrapDisplay(`${te} Created ${params.learning_type}: "${params.title}"\n${se}ID: ${learningId}`),
|
|
211
232
|
};
|
|
212
233
|
}
|
|
213
234
|
catch (error) {
|
|
235
|
+
const errorMsg = error instanceof Error ? error.message : String(error);
|
|
214
236
|
console.error("[create_learning] Failed:", error);
|
|
215
|
-
console.error("[create_learning] Error details:",
|
|
237
|
+
console.error("[create_learning] Error details:", errorMsg);
|
|
216
238
|
const latencyMs = timer.stop();
|
|
217
239
|
const perfData = buildPerformanceData("create_learning", latencyMs, 0);
|
|
218
240
|
return {
|
|
219
241
|
success: false,
|
|
220
242
|
learning_id: "",
|
|
221
243
|
embedding_generated: false,
|
|
244
|
+
errors: [errorMsg],
|
|
222
245
|
performance: perfData,
|
|
246
|
+
display: wrapDisplay(`Failed to create learning: ${errorMsg}`),
|
|
223
247
|
};
|
|
224
248
|
}
|
|
225
249
|
}
|