@askexenow/exe-os 0.9.60 → 0.9.62

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.
Files changed (106) hide show
  1. package/deploy/stack-manifests/v0.9.json +62 -13
  2. package/dist/bin/backfill-conversations.js +282 -7
  3. package/dist/bin/backfill-responses.js +282 -7
  4. package/dist/bin/backfill-vectors.js +119 -7
  5. package/dist/bin/cc-doctor.js +376 -0
  6. package/dist/bin/cleanup-stale-review-tasks.js +282 -7
  7. package/dist/bin/cli.js +455 -77
  8. package/dist/bin/customer-readiness.js +33 -0
  9. package/dist/bin/exe-agent-config.js +2 -2
  10. package/dist/bin/exe-agent.js +3 -3
  11. package/dist/bin/exe-assign.js +282 -7
  12. package/dist/bin/exe-boot.js +125 -13
  13. package/dist/bin/exe-call.js +3 -3
  14. package/dist/bin/exe-cloud.js +2 -2
  15. package/dist/bin/exe-dispatch.js +282 -7
  16. package/dist/bin/exe-doctor.js +119 -7
  17. package/dist/bin/exe-export-behaviors.js +282 -7
  18. package/dist/bin/exe-forget.js +336 -7
  19. package/dist/bin/exe-gateway.js +282 -7
  20. package/dist/bin/exe-heartbeat.js +284 -9
  21. package/dist/bin/exe-kill.js +282 -7
  22. package/dist/bin/exe-launch-agent.js +282 -7
  23. package/dist/bin/exe-link.js +121 -9
  24. package/dist/bin/exe-new-employee.js +50 -21
  25. package/dist/bin/exe-pending-messages.js +282 -7
  26. package/dist/bin/exe-pending-notifications.js +282 -7
  27. package/dist/bin/exe-pending-reviews.js +282 -7
  28. package/dist/bin/exe-rename.js +282 -7
  29. package/dist/bin/exe-review.js +282 -7
  30. package/dist/bin/exe-search.js +306 -8
  31. package/dist/bin/exe-session-cleanup.js +282 -7
  32. package/dist/bin/exe-settings.js +2 -2
  33. package/dist/bin/exe-start-codex.js +326 -21
  34. package/dist/bin/exe-start-opencode.js +304 -10
  35. package/dist/bin/exe-status.js +282 -7
  36. package/dist/bin/exe-team.js +282 -7
  37. package/dist/bin/git-sweep.js +282 -7
  38. package/dist/bin/graph-backfill.js +282 -7
  39. package/dist/bin/graph-export.js +282 -7
  40. package/dist/bin/install.js +58 -33
  41. package/dist/bin/intercom-check.js +282 -7
  42. package/dist/bin/pre-build-guard.js +98 -0
  43. package/dist/bin/scan-tasks.js +282 -7
  44. package/dist/bin/setup.js +122 -10
  45. package/dist/bin/shard-migrate.js +282 -7
  46. package/dist/bin/stack-update.js +79 -11
  47. package/dist/bin/update.js +2 -2
  48. package/dist/gateway/index.js +288 -13
  49. package/dist/hooks/bug-report-worker.js +282 -7
  50. package/dist/hooks/codex-stop-task-finalizer.js +282 -7
  51. package/dist/hooks/commit-complete.js +282 -7
  52. package/dist/hooks/error-recall.js +306 -8
  53. package/dist/hooks/exe-heartbeat-hook.js +2 -2
  54. package/dist/hooks/ingest-worker.js +2 -2
  55. package/dist/hooks/ingest.js +282 -7
  56. package/dist/hooks/instructions-loaded.js +282 -7
  57. package/dist/hooks/notification.js +282 -7
  58. package/dist/hooks/post-compact.js +282 -7
  59. package/dist/hooks/post-tool-combined.js +306 -8
  60. package/dist/hooks/pre-compact.js +282 -7
  61. package/dist/hooks/pre-tool-use.js +282 -7
  62. package/dist/hooks/prompt-submit.js +306 -8
  63. package/dist/hooks/session-end.js +282 -7
  64. package/dist/hooks/session-start.js +308 -10
  65. package/dist/hooks/stop.js +282 -7
  66. package/dist/hooks/subagent-stop.js +282 -7
  67. package/dist/hooks/summary-worker.js +125 -13
  68. package/dist/index.js +288 -13
  69. package/dist/lib/agent-config.js +2 -2
  70. package/dist/lib/cloud-sync.js +121 -9
  71. package/dist/lib/config.js +2 -2
  72. package/dist/lib/consolidation.js +2 -2
  73. package/dist/lib/database.js +115 -3
  74. package/dist/lib/db-daemon-client.js +2 -2
  75. package/dist/lib/db.js +115 -3
  76. package/dist/lib/device-registry.js +115 -3
  77. package/dist/lib/embedder.js +2 -2
  78. package/dist/lib/employee-templates.js +3 -3
  79. package/dist/lib/employees.js +2 -2
  80. package/dist/lib/exe-daemon-client.js +2 -2
  81. package/dist/lib/exe-daemon.js +339 -31
  82. package/dist/lib/hybrid-search.js +306 -8
  83. package/dist/lib/identity.js +2 -2
  84. package/dist/lib/license.js +2 -2
  85. package/dist/lib/messaging.js +2 -2
  86. package/dist/lib/reminders.js +2 -2
  87. package/dist/lib/schedules.js +119 -7
  88. package/dist/lib/skill-learning.js +2 -2
  89. package/dist/lib/store.js +282 -7
  90. package/dist/lib/task-router.js +2 -2
  91. package/dist/lib/tasks.js +2 -2
  92. package/dist/lib/tmux-routing.js +2 -2
  93. package/dist/lib/token-spend.js +2 -2
  94. package/dist/mcp/server.js +339 -31
  95. package/dist/mcp/tools/complete-reminder.js +2 -2
  96. package/dist/mcp/tools/create-reminder.js +2 -2
  97. package/dist/mcp/tools/create-task.js +2 -2
  98. package/dist/mcp/tools/deactivate-behavior.js +2 -2
  99. package/dist/mcp/tools/list-reminders.js +2 -2
  100. package/dist/mcp/tools/list-tasks.js +2 -2
  101. package/dist/mcp/tools/send-message.js +2 -2
  102. package/dist/mcp/tools/update-task.js +2 -2
  103. package/dist/runtime/index.js +282 -7
  104. package/dist/tui/App.js +290 -15
  105. package/package.json +3 -2
  106. package/stack.release.json +23 -7
@@ -202,8 +202,8 @@ var init_config = __esm({
202
202
  rerankerAutoTrigger: {
203
203
  enabled: true,
204
204
  broadQueryMinCardinality: 5e4,
205
- fetchTopK: 150,
206
- returnTopK: 5
205
+ fetchTopK: 200,
206
+ returnTopK: 20
207
207
  }
208
208
  },
209
209
  graphRagEnabled: true,
@@ -2801,7 +2801,7 @@ async function ensureSchema() {
2801
2801
  ON session_kills(agent_id);
2802
2802
  `);
2803
2803
  await client.execute(`
2804
- CREATE TABLE IF NOT EXISTS global_procedures (
2804
+ CREATE TABLE IF NOT EXISTS company_procedures (
2805
2805
  id TEXT PRIMARY KEY,
2806
2806
  title TEXT NOT NULL,
2807
2807
  content TEXT NOT NULL,
@@ -2812,6 +2812,73 @@ async function ensureSchema() {
2812
2812
  updated_at TEXT NOT NULL
2813
2813
  )
2814
2814
  `);
2815
+ const legacyProcedureObject = await client.execute({
2816
+ sql: "SELECT type FROM sqlite_master WHERE name = 'global_procedures'",
2817
+ args: []
2818
+ });
2819
+ const legacyProcedureType = legacyProcedureObject.rows[0]?.type == null ? null : String(legacyProcedureObject.rows[0].type);
2820
+ if (legacyProcedureType === "table") {
2821
+ await client.execute(`
2822
+ INSERT OR IGNORE INTO company_procedures
2823
+ (id, title, content, priority, domain, active, created_at, updated_at)
2824
+ SELECT id, title, content, priority, domain, active, created_at, updated_at
2825
+ FROM global_procedures
2826
+ `);
2827
+ await client.executeMultiple(`
2828
+ CREATE TRIGGER IF NOT EXISTS global_procedures_mirror_insert
2829
+ AFTER INSERT ON global_procedures
2830
+ BEGIN
2831
+ INSERT OR IGNORE INTO company_procedures
2832
+ (id, title, content, priority, domain, active, created_at, updated_at)
2833
+ VALUES
2834
+ (NEW.id, NEW.title, NEW.content, NEW.priority, NEW.domain, NEW.active, NEW.created_at, NEW.updated_at);
2835
+ END;
2836
+
2837
+ CREATE TRIGGER IF NOT EXISTS global_procedures_mirror_update
2838
+ AFTER UPDATE ON global_procedures
2839
+ BEGIN
2840
+ UPDATE company_procedures
2841
+ SET title = NEW.title,
2842
+ content = NEW.content,
2843
+ priority = NEW.priority,
2844
+ domain = NEW.domain,
2845
+ active = NEW.active,
2846
+ created_at = NEW.created_at,
2847
+ updated_at = NEW.updated_at
2848
+ WHERE id = OLD.id;
2849
+ END;
2850
+ `);
2851
+ } else {
2852
+ await client.execute(`
2853
+ CREATE VIEW IF NOT EXISTS global_procedures AS
2854
+ SELECT id, title, content, priority, domain, active, created_at, updated_at
2855
+ FROM company_procedures
2856
+ `);
2857
+ await client.executeMultiple(`
2858
+ CREATE TRIGGER IF NOT EXISTS global_procedures_insert
2859
+ INSTEAD OF INSERT ON global_procedures
2860
+ BEGIN
2861
+ INSERT INTO company_procedures
2862
+ (id, title, content, priority, domain, active, created_at, updated_at)
2863
+ VALUES
2864
+ (NEW.id, NEW.title, NEW.content, NEW.priority, NEW.domain, NEW.active, NEW.created_at, NEW.updated_at);
2865
+ END;
2866
+
2867
+ CREATE TRIGGER IF NOT EXISTS global_procedures_update
2868
+ INSTEAD OF UPDATE ON global_procedures
2869
+ BEGIN
2870
+ UPDATE company_procedures
2871
+ SET title = NEW.title,
2872
+ content = NEW.content,
2873
+ priority = NEW.priority,
2874
+ domain = NEW.domain,
2875
+ active = NEW.active,
2876
+ created_at = NEW.created_at,
2877
+ updated_at = NEW.updated_at
2878
+ WHERE id = OLD.id;
2879
+ END;
2880
+ `);
2881
+ }
2815
2882
  await client.executeMultiple(`
2816
2883
  CREATE TABLE IF NOT EXISTS conversations (
2817
2884
  id TEXT PRIMARY KEY,
@@ -2951,6 +3018,51 @@ async function ensureSchema() {
2951
3018
  VALUES (new.rowid, new.content_text, new.sender_name, new.agent_response);
2952
3019
  END;
2953
3020
  `);
3021
+ await client.executeMultiple(`
3022
+ CREATE TABLE IF NOT EXISTS memory_cards (
3023
+ id TEXT PRIMARY KEY,
3024
+ memory_id TEXT NOT NULL,
3025
+ agent_id TEXT NOT NULL,
3026
+ session_id TEXT NOT NULL,
3027
+ project_name TEXT,
3028
+ timestamp TEXT NOT NULL,
3029
+ card_type TEXT NOT NULL,
3030
+ subject TEXT,
3031
+ predicate TEXT,
3032
+ object TEXT,
3033
+ content TEXT NOT NULL,
3034
+ source_ref TEXT,
3035
+ confidence REAL DEFAULT 0.6,
3036
+ active INTEGER DEFAULT 1,
3037
+ created_at TEXT NOT NULL
3038
+ );
3039
+
3040
+ CREATE INDEX IF NOT EXISTS idx_memory_cards_agent
3041
+ ON memory_cards(agent_id, active, timestamp);
3042
+
3043
+ CREATE INDEX IF NOT EXISTS idx_memory_cards_memory
3044
+ ON memory_cards(memory_id);
3045
+
3046
+ CREATE VIRTUAL TABLE IF NOT EXISTS memory_cards_fts
3047
+ USING fts5(content, subject, predicate, object, content='memory_cards', content_rowid='rowid');
3048
+
3049
+ CREATE TRIGGER IF NOT EXISTS memory_cards_fts_ai AFTER INSERT ON memory_cards BEGIN
3050
+ INSERT INTO memory_cards_fts(rowid, content, subject, predicate, object)
3051
+ VALUES (new.rowid, new.content, new.subject, new.predicate, new.object);
3052
+ END;
3053
+
3054
+ CREATE TRIGGER IF NOT EXISTS memory_cards_fts_ad AFTER DELETE ON memory_cards BEGIN
3055
+ INSERT INTO memory_cards_fts(memory_cards_fts, rowid, content, subject, predicate, object)
3056
+ VALUES('delete', old.rowid, old.content, old.subject, old.predicate, old.object);
3057
+ END;
3058
+
3059
+ CREATE TRIGGER IF NOT EXISTS memory_cards_fts_au AFTER UPDATE ON memory_cards BEGIN
3060
+ INSERT INTO memory_cards_fts(memory_cards_fts, rowid, content, subject, predicate, object)
3061
+ VALUES('delete', old.rowid, old.content, old.subject, old.predicate, old.object);
3062
+ INSERT INTO memory_cards_fts(rowid, content, subject, predicate, object)
3063
+ VALUES (new.rowid, new.content, new.subject, new.predicate, new.object);
3064
+ END;
3065
+ `);
2954
3066
  try {
2955
3067
  await client.execute({
2956
3068
  sql: `ALTER TABLE memories ADD COLUMN tier INTEGER DEFAULT 3`,
@@ -4303,7 +4415,7 @@ var init_platform_procedures = __esm({
4303
4415
  title: "MCP tools \u2014 advanced (triggers, skills, orchestration)",
4304
4416
  domain: "tool-use",
4305
4417
  priority: "p1",
4306
- content: "create_trigger: set up a scheduled recurring agent job (cron). list_triggers: view active triggers. load_skill: load a slash-command skill dynamically. apply_starter_pack: import a pre-built behavior + identity pack for a role. export_orchestration: export full org state (tasks, behaviors, identities) as portable JSON. import_orchestration: import org state into a new instance. deploy_client: deploy a customer client instance. query_company_brain: unified RAG query across all company knowledge. create_reminder: set a text reminder (shown in boot brief). list_reminders: view pending reminders. complete_reminder: mark a reminder done. global_procedure: manage customer-owned company procedures (Layer 0; actions: store, list, deactivate). Legacy aliases: store_global_procedure, list_global_procedures, deactivate_global_procedure."
4418
+ content: "create_trigger: set up a scheduled recurring agent job (cron). list_triggers: view active triggers. load_skill: load a slash-command skill dynamically. apply_starter_pack: import a pre-built behavior + identity pack for a role. export_orchestration: export full org state (tasks, behaviors, identities) as portable JSON. import_orchestration: import org state into a new instance. deploy_client: deploy a customer client instance. query_company_brain: unified RAG query across all company knowledge. create_reminder: set a text reminder (shown in boot brief). list_reminders: view pending reminders. complete_reminder: mark a reminder done. company_procedure: manage customer-owned company procedures (Layer 0; actions: store, list, deactivate). Legacy aliases: global_procedure, store_global_procedure, list_global_procedures, deactivate_global_procedure."
4307
4419
  }
4308
4420
  ];
4309
4421
  PLATFORM_PROCEDURE_TITLES = new Set(
@@ -4324,7 +4436,7 @@ import { randomUUID as randomUUID3 } from "crypto";
4324
4436
  async function loadGlobalProcedures() {
4325
4437
  const client = getClient();
4326
4438
  const result = await client.execute({
4327
- sql: "SELECT * FROM global_procedures WHERE active = 1 ORDER BY priority ASC, created_at ASC",
4439
+ sql: "SELECT * FROM company_procedures WHERE active = 1 ORDER BY priority ASC, created_at ASC",
4328
4440
  args: []
4329
4441
  });
4330
4442
  const allRows = result.rows;
@@ -4353,7 +4465,7 @@ async function storeGlobalProcedure(input2) {
4353
4465
  const now = (/* @__PURE__ */ new Date()).toISOString();
4354
4466
  const client = getClient();
4355
4467
  await client.execute({
4356
- sql: `INSERT INTO global_procedures (id, title, content, priority, domain, active, created_at, updated_at)
4468
+ sql: `INSERT INTO company_procedures (id, title, content, priority, domain, active, created_at, updated_at)
4357
4469
  VALUES (?, ?, ?, ?, ?, 1, ?, ?)`,
4358
4470
  args: [id, input2.title, input2.content, input2.priority ?? "p0", input2.domain ?? null, now, now]
4359
4471
  });
@@ -4364,7 +4476,7 @@ async function deactivateGlobalProcedure(id) {
4364
4476
  const now = (/* @__PURE__ */ new Date()).toISOString();
4365
4477
  const client = getClient();
4366
4478
  const result = await client.execute({
4367
- sql: "UPDATE global_procedures SET active = 0, updated_at = ? WHERE id = ?",
4479
+ sql: "UPDATE company_procedures SET active = 0, updated_at = ? WHERE id = ?",
4368
4480
  args: [now, id]
4369
4481
  });
4370
4482
  await loadGlobalProcedures();
@@ -4383,6 +4495,164 @@ ${p.content}`).join("\n\n");
4383
4495
  }
4384
4496
  });
4385
4497
 
4498
+ // src/lib/memory-cards.ts
4499
+ var memory_cards_exports = {};
4500
+ __export(memory_cards_exports, {
4501
+ extractMemoryCards: () => extractMemoryCards,
4502
+ insertMemoryCardsForBatch: () => insertMemoryCardsForBatch,
4503
+ searchMemoryCards: () => searchMemoryCards
4504
+ });
4505
+ import { createHash as createHash2 } from "crypto";
4506
+ function stableId(memoryId, type, content) {
4507
+ return createHash2("sha256").update(`${memoryId}:${type}:${content}`).digest("hex").slice(0, 32);
4508
+ }
4509
+ function cleanText(text) {
4510
+ return text.replace(/```[\s\S]*?```/g, " ").replace(/<[^>]+>/g, " ").replace(/\s+/g, " ").trim();
4511
+ }
4512
+ function splitSentences(text) {
4513
+ return cleanText(text).split(/(?<=[.!?])\s+|\n+/).map((s) => s.trim()).filter((s) => s.length >= 24 && s.length <= MAX_SENTENCE_CHARS);
4514
+ }
4515
+ function inferCardType(sentence, toolName) {
4516
+ const lower = sentence.toLowerCase();
4517
+ if (toolName === "store_decision" || /\b(decided|decision|adr|approved|rejected)\b/.test(lower)) return "decision";
4518
+ if (/\b(prefers|preference|likes|dislikes|wants|doesn't want|does not want)\b/.test(lower)) return "preference";
4519
+ if (/\b(changed|updated|replaced|now|no longer|instead|supersedes)\b/.test(lower)) return "belief_update";
4520
+ if (toolName && ["Read", "Write", "Edit", "Bash"].includes(toolName)) return "code";
4521
+ if (/\b(meeting|deadline|shipped|launched|completed|failed|blocked|assigned|created)\b/.test(lower)) return "event";
4522
+ return "fact";
4523
+ }
4524
+ function extractSubject(sentence, agentId) {
4525
+ const explicit = sentence.match(/\b([A-Z][a-zA-Z0-9_-]{2,}(?:\s+[A-Z][a-zA-Z0-9_-]{2,})?)\b/);
4526
+ return explicit?.[1] ?? agentId;
4527
+ }
4528
+ function predicateFor(type) {
4529
+ switch (type) {
4530
+ case "preference":
4531
+ return "prefers";
4532
+ case "belief_update":
4533
+ return "updated";
4534
+ case "decision":
4535
+ return "decided";
4536
+ case "event":
4537
+ return "happened";
4538
+ case "code":
4539
+ return "implemented";
4540
+ default:
4541
+ return "states";
4542
+ }
4543
+ }
4544
+ function extractMemoryCards(row) {
4545
+ const sentences = splitSentences(row.raw_text);
4546
+ const cards = [];
4547
+ for (const sentence of sentences) {
4548
+ const type = inferCardType(sentence, row.tool_name);
4549
+ const subject = extractSubject(sentence, row.agent_id);
4550
+ const content = sentence.length > MAX_SENTENCE_CHARS ? `${sentence.slice(0, MAX_SENTENCE_CHARS - 1)}\u2026` : sentence;
4551
+ cards.push({
4552
+ id: stableId(row.id, type, content),
4553
+ memory_id: row.id,
4554
+ agent_id: row.agent_id,
4555
+ session_id: row.session_id,
4556
+ project_name: row.project_name ?? null,
4557
+ timestamp: row.timestamp,
4558
+ card_type: type,
4559
+ subject,
4560
+ predicate: predicateFor(type),
4561
+ object: content,
4562
+ content,
4563
+ source_ref: row.id,
4564
+ confidence: type === "fact" ? 0.55 : 0.65
4565
+ });
4566
+ if (cards.length >= MAX_CARDS_PER_MEMORY) break;
4567
+ }
4568
+ return cards;
4569
+ }
4570
+ async function insertMemoryCardsForBatch(rows) {
4571
+ const cards = rows.flatMap(extractMemoryCards);
4572
+ if (cards.length === 0) return 0;
4573
+ const now = (/* @__PURE__ */ new Date()).toISOString();
4574
+ const client = getClient();
4575
+ const stmts = cards.map((card) => ({
4576
+ sql: `INSERT OR IGNORE INTO memory_cards
4577
+ (id, memory_id, agent_id, session_id, project_name, timestamp, card_type,
4578
+ subject, predicate, object, content, source_ref, confidence, active, created_at)
4579
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, 1, ?)`,
4580
+ args: [
4581
+ card.id,
4582
+ card.memory_id,
4583
+ card.agent_id,
4584
+ card.session_id,
4585
+ card.project_name,
4586
+ card.timestamp,
4587
+ card.card_type,
4588
+ card.subject,
4589
+ card.predicate,
4590
+ card.object,
4591
+ card.content,
4592
+ card.source_ref,
4593
+ card.confidence,
4594
+ now
4595
+ ]
4596
+ }));
4597
+ await client.batch(stmts, "write");
4598
+ return cards.length;
4599
+ }
4600
+ function buildMatchExpr(queryText) {
4601
+ const terms = queryText.toLowerCase().split(/\s+/).filter((t) => t.length >= 3).map((t) => t.replace(/[^a-z0-9_]/g, "")).filter((t) => t.length >= 3).slice(0, 12);
4602
+ if (terms.length === 0) return null;
4603
+ return terms.map((t) => `${t}*`).join(terms.length >= 3 ? " AND " : " OR ");
4604
+ }
4605
+ async function searchMemoryCards(queryText, agentId, options) {
4606
+ const limit = options?.limit ?? 10;
4607
+ const matchExpr = buildMatchExpr(queryText);
4608
+ if (!matchExpr) return [];
4609
+ let sql = `SELECT c.id, c.memory_id, c.agent_id, c.session_id, c.project_name,
4610
+ c.timestamp, c.card_type, c.content, c.source_ref, c.confidence
4611
+ FROM memory_cards c
4612
+ JOIN memory_cards_fts fts ON c.rowid = fts.rowid
4613
+ WHERE memory_cards_fts MATCH ?
4614
+ AND c.agent_id = ?
4615
+ AND COALESCE(c.active, 1) = 1`;
4616
+ const args = [matchExpr, agentId];
4617
+ if (options?.projectName) {
4618
+ sql += ` AND c.project_name = ?`;
4619
+ args.push(options.projectName);
4620
+ }
4621
+ if (options?.since) {
4622
+ sql += ` AND c.timestamp >= ?`;
4623
+ args.push(options.since);
4624
+ }
4625
+ sql += ` ORDER BY rank LIMIT ?`;
4626
+ args.push(limit);
4627
+ const result = await getClient().execute({ sql, args });
4628
+ return result.rows.map((row) => ({
4629
+ id: `card:${String(row.id)}`,
4630
+ agent_id: String(row.agent_id),
4631
+ agent_role: "memory_card",
4632
+ session_id: String(row.session_id),
4633
+ timestamp: String(row.timestamp),
4634
+ tool_name: `memory_card:${String(row.card_type)}`,
4635
+ project_name: row.project_name == null ? "" : String(row.project_name),
4636
+ has_error: false,
4637
+ raw_text: `[${String(row.card_type)}] ${String(row.content)}
4638
+ Source memory: ${String(row.source_ref ?? row.memory_id)}`,
4639
+ vector: [],
4640
+ importance: 6,
4641
+ status: "active",
4642
+ confidence: Number(row.confidence ?? 0.6),
4643
+ last_accessed: String(row.timestamp)
4644
+ }));
4645
+ }
4646
+ var MAX_CARDS_PER_MEMORY, MAX_SENTENCE_CHARS;
4647
+ var init_memory_cards = __esm({
4648
+ "src/lib/memory-cards.ts"() {
4649
+ "use strict";
4650
+ init_database();
4651
+ MAX_CARDS_PER_MEMORY = 6;
4652
+ MAX_SENTENCE_CHARS = 360;
4653
+ }
4654
+ });
4655
+
4386
4656
  // src/lib/store.ts
4387
4657
  var store_exports = {};
4388
4658
  __export(store_exports, {
@@ -4721,6 +4991,11 @@ async function flushBatch() {
4721
4991
  const globalClient = getClient();
4722
4992
  const globalStmts = batch.map(buildStmt);
4723
4993
  await globalClient.batch(globalStmts, "write");
4994
+ try {
4995
+ const { insertMemoryCardsForBatch: insertMemoryCardsForBatch2 } = await Promise.resolve().then(() => (init_memory_cards(), memory_cards_exports));
4996
+ await insertMemoryCardsForBatch2(batch);
4997
+ } catch {
4998
+ }
4724
4999
  schedulePostWriteMemoryHygiene(batch.map((row) => row.id));
4725
5000
  _pendingRecords.splice(0, batch.length);
4726
5001
  try {