@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.
- package/deploy/stack-manifests/v0.9.json +62 -13
- package/dist/bin/backfill-conversations.js +282 -7
- package/dist/bin/backfill-responses.js +282 -7
- package/dist/bin/backfill-vectors.js +119 -7
- package/dist/bin/cc-doctor.js +376 -0
- package/dist/bin/cleanup-stale-review-tasks.js +282 -7
- package/dist/bin/cli.js +455 -77
- package/dist/bin/customer-readiness.js +33 -0
- package/dist/bin/exe-agent-config.js +2 -2
- package/dist/bin/exe-agent.js +3 -3
- package/dist/bin/exe-assign.js +282 -7
- package/dist/bin/exe-boot.js +125 -13
- package/dist/bin/exe-call.js +3 -3
- package/dist/bin/exe-cloud.js +2 -2
- package/dist/bin/exe-dispatch.js +282 -7
- package/dist/bin/exe-doctor.js +119 -7
- package/dist/bin/exe-export-behaviors.js +282 -7
- package/dist/bin/exe-forget.js +336 -7
- package/dist/bin/exe-gateway.js +282 -7
- package/dist/bin/exe-heartbeat.js +284 -9
- package/dist/bin/exe-kill.js +282 -7
- package/dist/bin/exe-launch-agent.js +282 -7
- package/dist/bin/exe-link.js +121 -9
- package/dist/bin/exe-new-employee.js +50 -21
- package/dist/bin/exe-pending-messages.js +282 -7
- package/dist/bin/exe-pending-notifications.js +282 -7
- package/dist/bin/exe-pending-reviews.js +282 -7
- package/dist/bin/exe-rename.js +282 -7
- package/dist/bin/exe-review.js +282 -7
- package/dist/bin/exe-search.js +306 -8
- package/dist/bin/exe-session-cleanup.js +282 -7
- package/dist/bin/exe-settings.js +2 -2
- package/dist/bin/exe-start-codex.js +326 -21
- package/dist/bin/exe-start-opencode.js +304 -10
- package/dist/bin/exe-status.js +282 -7
- package/dist/bin/exe-team.js +282 -7
- package/dist/bin/git-sweep.js +282 -7
- package/dist/bin/graph-backfill.js +282 -7
- package/dist/bin/graph-export.js +282 -7
- package/dist/bin/install.js +58 -33
- package/dist/bin/intercom-check.js +282 -7
- package/dist/bin/pre-build-guard.js +98 -0
- package/dist/bin/scan-tasks.js +282 -7
- package/dist/bin/setup.js +122 -10
- package/dist/bin/shard-migrate.js +282 -7
- package/dist/bin/stack-update.js +79 -11
- package/dist/bin/update.js +2 -2
- package/dist/gateway/index.js +288 -13
- package/dist/hooks/bug-report-worker.js +282 -7
- package/dist/hooks/codex-stop-task-finalizer.js +282 -7
- package/dist/hooks/commit-complete.js +282 -7
- package/dist/hooks/error-recall.js +306 -8
- package/dist/hooks/exe-heartbeat-hook.js +2 -2
- package/dist/hooks/ingest-worker.js +2 -2
- package/dist/hooks/ingest.js +282 -7
- package/dist/hooks/instructions-loaded.js +282 -7
- package/dist/hooks/notification.js +282 -7
- package/dist/hooks/post-compact.js +282 -7
- package/dist/hooks/post-tool-combined.js +306 -8
- package/dist/hooks/pre-compact.js +282 -7
- package/dist/hooks/pre-tool-use.js +282 -7
- package/dist/hooks/prompt-submit.js +306 -8
- package/dist/hooks/session-end.js +282 -7
- package/dist/hooks/session-start.js +308 -10
- package/dist/hooks/stop.js +282 -7
- package/dist/hooks/subagent-stop.js +282 -7
- package/dist/hooks/summary-worker.js +125 -13
- package/dist/index.js +288 -13
- package/dist/lib/agent-config.js +2 -2
- package/dist/lib/cloud-sync.js +121 -9
- package/dist/lib/config.js +2 -2
- package/dist/lib/consolidation.js +2 -2
- package/dist/lib/database.js +115 -3
- package/dist/lib/db-daemon-client.js +2 -2
- package/dist/lib/db.js +115 -3
- package/dist/lib/device-registry.js +115 -3
- package/dist/lib/embedder.js +2 -2
- package/dist/lib/employee-templates.js +3 -3
- package/dist/lib/employees.js +2 -2
- package/dist/lib/exe-daemon-client.js +2 -2
- package/dist/lib/exe-daemon.js +339 -31
- package/dist/lib/hybrid-search.js +306 -8
- package/dist/lib/identity.js +2 -2
- package/dist/lib/license.js +2 -2
- package/dist/lib/messaging.js +2 -2
- package/dist/lib/reminders.js +2 -2
- package/dist/lib/schedules.js +119 -7
- package/dist/lib/skill-learning.js +2 -2
- package/dist/lib/store.js +282 -7
- package/dist/lib/task-router.js +2 -2
- package/dist/lib/tasks.js +2 -2
- package/dist/lib/tmux-routing.js +2 -2
- package/dist/lib/token-spend.js +2 -2
- package/dist/mcp/server.js +339 -31
- package/dist/mcp/tools/complete-reminder.js +2 -2
- package/dist/mcp/tools/create-reminder.js +2 -2
- package/dist/mcp/tools/create-task.js +2 -2
- package/dist/mcp/tools/deactivate-behavior.js +2 -2
- package/dist/mcp/tools/list-reminders.js +2 -2
- package/dist/mcp/tools/list-tasks.js +2 -2
- package/dist/mcp/tools/send-message.js +2 -2
- package/dist/mcp/tools/update-task.js +2 -2
- package/dist/runtime/index.js +282 -7
- package/dist/tui/App.js +290 -15
- package/package.json +3 -2
- 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:
|
|
206
|
-
returnTopK:
|
|
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
|
|
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.
|
|
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
|
|
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
|
|
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
|
|
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 {
|