opcode-pg-memory 2.4.1 → 2.4.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # opcode-pg-memory
2
2
 
3
- **OpenCode 长期记忆插件** — PostgreSQL + pgvector 四层记忆架构,话题隔离 · Agent 自主调用 · OmO Agent 协调
3
+ **OpenCode 长期记忆插件** — PostgreSQL + pgvector 四层记忆架构,11 Agent 记忆隔离 · 跨会话语义检索 · MCP 工具
4
4
 
5
5
  [![npm](https://img.shields.io/npm/v/opcode-pg-memory)](https://www.npmjs.com/package/opcode-pg-memory)
6
6
  [![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
@@ -142,10 +142,10 @@ src/
142
142
  ├── db/init-db.ts # 数据库初始化 + 迁移
143
143
  ├── hooks/ # 生命周期钩子
144
144
  ├── mcp/ # MCP 工具实现
145
+ ├── services/ # Agent 上下文 · 同步管道 · 日志
145
146
  ├── topic/ # 话题段管理器
146
- ├── services/ # 日志 · 关键词 · 隐私过滤
147
147
  ├── cache/ # 语义缓存
148
- └── omo/ # OmO 适配器
148
+ └── utils/ # 嵌入生成 · Token 预算
149
149
  mcp-server.ts # MCP 服务入口
150
150
  ```
151
151
 
@@ -203,7 +203,7 @@ node scripts/backfill-embeddings.js --limit 100
203
203
  |------|------|
204
204
  | [USAGE_GUIDE.md](./USAGE_GUIDE.md) | 完整使用指南 — 配置 · 工具 · 运维 |
205
205
  | [PLUGIN_DOCUMENTATION.md](./PLUGIN_DOCUMENTATION.md) | 架构详解 — 钩子系统 · 数据库设计 |
206
- | [AGENTS.template.md](./AGENTS.template.md) | AGENTS.md 模板OmO directory-agents-injector 自动通知子代理 |
206
+ | [AGENTS.template.md](./AGENTS.template.md) | Agent 记忆使用指南11 Agent 能力表 · 跨 Agent 共享规则 · 环境变量 |
207
207
 
208
208
  ## License
209
209
 
@@ -1 +1 @@
1
- {"version":3,"file":"session-created.d.ts","sourceRoot":"","sources":["../../../src/hooks/session-created.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAC1B,OAAO,EACL,mBAAmB,EACnB,oBAAoB,EAIrB,MAAM,UAAU,CAAC;AAWlB,MAAM,WAAW,2BAA2B;IAC1C,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;CACnB;AAUD;;;;;;;;;;GAUG;AACH,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,mBAAmB,EAC1B,MAAM,EAAE,oBAAoB,EAAK,iBAAiB;AAClD,IAAI,EAAE,IAAI,EACV,MAAM,GAAE,OAAO,CAAC,2BAA2B,CAAM,GAChD,OAAO,CAAC,IAAI,CAAC,CAyCf"}
1
+ {"version":3,"file":"session-created.d.ts","sourceRoot":"","sources":["../../../src/hooks/session-created.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAC1B,OAAO,EACL,mBAAmB,EACnB,oBAAoB,EAIrB,MAAM,UAAU,CAAC;AAYlB,MAAM,WAAW,2BAA2B;IAC1C,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;CACnB;AAUD;;;;;;;;;;GAUG;AACH,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,mBAAmB,EAC1B,MAAM,EAAE,oBAAoB,EAAK,iBAAiB;AAClD,IAAI,EAAE,IAAI,EACV,MAAM,GAAE,OAAO,CAAC,2BAA2B,CAAM,GAChD,OAAO,CAAC,IAAI,CAAC,CAyCf"}
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.handleSessionCreated = handleSessionCreated;
4
4
  const token_budget_1 = require("../utils/token-budget");
5
5
  const logger_1 = require("../services/logger");
6
+ const agent_context_1 = require("../services/agent-context");
6
7
  const logger = (0, logger_1.createLogger)('session-created');
7
8
  const DEFAULT_CONFIG = {
8
9
  contextLimitRatio: 0.05,
@@ -54,15 +55,17 @@ pool, config = {}) {
54
55
  * 创建或更新 session 记录
55
56
  */
56
57
  async function upsertSession(session, pool) {
58
+ const agentId = (0, agent_context_1.detectAgentId)();
57
59
  const query = `
58
- INSERT INTO session_map (opencode_session_id, project_id, model_context_limit, metadata)
59
- VALUES ($1, $2, $3, $4)
60
+ INSERT INTO session_map (opencode_session_id, project_id, model_context_limit, metadata, agent_id)
61
+ VALUES ($1, $2, $3, $4, $5)
60
62
  ON CONFLICT (opencode_session_id)
61
63
  DO UPDATE SET
62
64
  project_id = EXCLUDED.project_id,
63
65
  model_context_limit = EXCLUDED.model_context_limit,
64
66
  last_active_at = NOW(),
65
- metadata = session_map.metadata || EXCLUDED.metadata
67
+ metadata = session_map.metadata || EXCLUDED.metadata,
68
+ agent_id = COALESCE(session_map.agent_id, EXCLUDED.agent_id)
66
69
  `;
67
70
  await pool.query(query, [
68
71
  session.id,
@@ -71,7 +74,8 @@ async function upsertSession(session, pool) {
71
74
  JSON.stringify({
72
75
  modelId: session.model.id,
73
76
  modelName: session.model.name
74
- })
77
+ }),
78
+ agentId,
75
79
  ]);
76
80
  }
77
81
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"session-created.js","sourceRoot":"","sources":["../../../src/hooks/session-created.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"session-created.js","sourceRoot":"","sources":["../../../src/hooks/session-created.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { Pool } from 'pg';
2
2
  export interface BackfillEmbeddingsInput {
3
- /** Max observations to enqueue. 0 = unlimited. */
3
+ /** Max observations to enqueue. 0 = unlimited (all pending). */
4
4
  limit?: number;
5
5
  }
6
6
  export interface BackfillEmbeddingsOutput {
@@ -11,6 +11,7 @@ export interface BackfillEmbeddingsOutput {
11
11
  }
12
12
  /**
13
13
  * Enqueue observations with NULL embedding into the AsyncEmbedder queue.
14
+ * Uses cursor-based batching to process large backfills without loading everything at once.
14
15
  * The embedder processes them sequentially (with Ollama cooldown/retry).
15
16
  * Already-embedded observations are never touched (WHERE embedding IS NULL).
16
17
  */
@@ -1 +1 @@
1
- {"version":3,"file":"backfill-embeddings.d.ts","sourceRoot":"","sources":["../../../src/mcp/backfill-embeddings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAM1B,MAAM,WAAW,uBAAuB;IACtC,kDAAkD;IAClD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CACd;AAED;;;;GAIG;AACH,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,uBAAuB,EAC9B,IAAI,EAAE,IAAI,GACT,OAAO,CAAC,wBAAwB,CAAC,CAqDnC"}
1
+ {"version":3,"file":"backfill-embeddings.d.ts","sourceRoot":"","sources":["../../../src/mcp/backfill-embeddings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAQ1B,MAAM,WAAW,uBAAuB;IACtC,gEAAgE;IAChE,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CACd;AAED;;;;;GAKG;AACH,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,uBAAuB,EAC9B,IAAI,EAAE,IAAI,GACT,OAAO,CAAC,wBAAwB,CAAC,CA+EnC"}
@@ -4,8 +4,10 @@ exports.backfillEmbeddings = backfillEmbeddings;
4
4
  const async_embedder_1 = require("../services/async-embedder");
5
5
  const logger_1 = require("../services/logger");
6
6
  const logger = (0, logger_1.createLogger)('backfill-embeddings');
7
+ const BATCH_SIZE = 100;
7
8
  /**
8
9
  * Enqueue observations with NULL embedding into the AsyncEmbedder queue.
10
+ * Uses cursor-based batching to process large backfills without loading everything at once.
9
11
  * The embedder processes them sequentially (with Ollama cooldown/retry).
10
12
  * Already-embedded observations are never touched (WHERE embedding IS NULL).
11
13
  */
@@ -15,6 +17,9 @@ async function backfillEmbeddings(input, pool) {
15
17
  return { enqueued: 0, skipped: 0, pending: 0, note: 'Embedder not initialized. Check plugin startup.' };
16
18
  }
17
19
  const limit = input.limit || 0;
20
+ let totalEnqueued = 0;
21
+ let totalSkipped = 0;
22
+ let cursor = null;
18
23
  try {
19
24
  // Count pending
20
25
  const countResult = await pool.query(`SELECT count(*)::int AS cnt FROM observations WHERE importance >= 3 AND embedding IS NULL`);
@@ -22,33 +27,57 @@ async function backfillEmbeddings(input, pool) {
22
27
  if (pending === 0) {
23
28
  return { enqueued: 0, skipped: 0, pending: 0, note: 'All observations already have embeddings.' };
24
29
  }
25
- const fetchLimit = limit > 0 ? Math.min(limit, pending) : pending;
26
- const result = await pool.query(`SELECT id, tool_name, tool_input_summary, tool_output_summary, importance
27
- FROM observations
28
- WHERE importance >= 3 AND embedding IS NULL
29
- ORDER BY created_at ASC
30
- LIMIT $1`, [fetchLimit]);
31
- let enqueuedCount = 0;
32
- for (const row of result.rows) {
33
- const text = `[${row.tool_name || 'tool'}] ${row.tool_output_summary || row.tool_input_summary || ''}`;
34
- if (!text || text.length <= 3)
35
- continue;
36
- embedder.enqueue('observations', row.id, text, row.importance);
37
- enqueuedCount++;
30
+ const maxToProcess = limit > 0 ? Math.min(limit, pending) : pending;
31
+ // Cursor-based batch loop
32
+ while (totalEnqueued < maxToProcess) {
33
+ const remaining = maxToProcess - totalEnqueued;
34
+ const batchSize = Math.min(BATCH_SIZE, remaining);
35
+ let query;
36
+ let params;
37
+ if (cursor) {
38
+ query = `SELECT id, tool_name, tool_input_summary, tool_output_summary, importance
39
+ FROM observations
40
+ WHERE importance >= 3 AND embedding IS NULL AND id > $1
41
+ ORDER BY id ASC
42
+ LIMIT $2`;
43
+ params = [cursor, batchSize];
44
+ }
45
+ else {
46
+ query = `SELECT id, tool_name, tool_input_summary, tool_output_summary, importance
47
+ FROM observations
48
+ WHERE importance >= 3 AND embedding IS NULL
49
+ ORDER BY id ASC
50
+ LIMIT $1`;
51
+ params = [batchSize];
52
+ }
53
+ const result = await pool.query(query, params);
54
+ if (result.rows.length === 0)
55
+ break;
56
+ for (const row of result.rows) {
57
+ if (totalEnqueued >= maxToProcess)
58
+ break;
59
+ const text = `[${row.tool_name || 'tool'}] ${row.tool_output_summary || row.tool_input_summary || ''}`;
60
+ if (!text || text.length <= 3) {
61
+ totalSkipped++;
62
+ continue;
63
+ }
64
+ embedder.enqueue('observations', row.id, text, row.importance);
65
+ totalEnqueued++;
66
+ cursor = row.id;
67
+ }
38
68
  }
39
- const skipped = fetchLimit - enqueuedCount;
40
- const remaining = pending - enqueuedCount;
41
- logger.info(`Backfill: enqueued ${enqueuedCount}, ${remaining} remaining`);
69
+ const remaining = pending - totalEnqueued;
70
+ logger.info(`Backfill: enqueued ${totalEnqueued}, skipped ${totalSkipped}, ${remaining} remaining`);
42
71
  return {
43
- enqueued: enqueuedCount,
44
- skipped,
72
+ enqueued: totalEnqueued,
73
+ skipped: totalSkipped,
45
74
  pending: remaining,
46
- note: `Enqueued ${enqueuedCount} observations. Use sync_health() to monitor progress. Approx ${Math.ceil(remaining * 1.2)}s remaining at current rate.`,
75
+ note: `Enqueued ${totalEnqueued} observations (${remaining} remaining). Use sync_health() to monitor progress.`,
47
76
  };
48
77
  }
49
78
  catch (err) {
50
79
  logger.error('backfill_embeddings query failed', err);
51
- return { enqueued: 0, skipped: 0, pending: 0, note: 'Query failed: ' + err.message };
80
+ return { enqueued: totalEnqueued, skipped: totalSkipped, pending: 0, note: 'Error: ' + err.message };
52
81
  }
53
82
  }
54
83
  //# sourceMappingURL=backfill-embeddings.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"backfill-embeddings.js","sourceRoot":"","sources":["../../../src/mcp/backfill-embeddings.ts"],"names":[],"mappings":";;AAuBA,gDAwDC;AA9ED,+DAA8D;AAC9D,+CAAkD;AAElD,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,qBAAqB,CAAC,CAAC;AAcnD;;;;GAIG;AACI,KAAK,UAAU,kBAAkB,CACtC,KAA8B,EAC9B,IAAU;IAEV,MAAM,QAAQ,GAAG,IAAA,iCAAgB,GAAE,CAAC;IACpC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,iDAAiD,EAAE,CAAC;IAC1G,CAAC;IAED,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,CAAC,CAAC;IAE/B,IAAI,CAAC;QACH,gBAAgB;QAChB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,KAAK,CAClC,2FAA2F,CAC5F,CAAC;QACF,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;QAE9C,IAAI,OAAO,KAAK,CAAC,EAAE,CAAC;YAClB,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,2CAA2C,EAAE,CAAC;QACpG,CAAC;QAED,MAAM,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAElE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAC7B;;;;gBAIU,EACV,CAAC,UAAU,CAAC,CACb,CAAC;QAEF,IAAI,aAAa,GAAG,CAAC,CAAC;QACtB,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;YAC9B,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,SAAS,IAAI,MAAM,KAAK,GAAG,CAAC,mBAAmB,IAAI,GAAG,CAAC,kBAAkB,IAAI,EAAE,EAAE,CAAC;YACvG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC;gBAAE,SAAS;YACxC,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;YAC/D,aAAa,EAAE,CAAC;QAClB,CAAC;QAED,MAAM,OAAO,GAAG,UAAU,GAAG,aAAa,CAAC;QAC3C,MAAM,SAAS,GAAG,OAAO,GAAG,aAAa,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,sBAAsB,aAAa,KAAK,SAAS,YAAY,CAAC,CAAC;QAE3E,OAAO;YACL,QAAQ,EAAE,aAAa;YACvB,OAAO;YACP,OAAO,EAAE,SAAS;YAClB,IAAI,EAAE,YAAY,aAAa,gEAAgE,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,8BAA8B;SACxJ,CAAC;IACJ,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,MAAM,CAAC,KAAK,CAAC,kCAAkC,EAAE,GAAG,CAAC,CAAC;QACtD,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,gBAAgB,GAAG,GAAG,CAAC,OAAO,EAAE,CAAC;IACvF,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"backfill-embeddings.js","sourceRoot":"","sources":["../../../src/mcp/backfill-embeddings.ts"],"names":[],"mappings":"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"}
@@ -10,7 +10,7 @@ export interface SyncHealthOutput {
10
10
  sessions_with_obs: number;
11
11
  };
12
12
  embedder: {
13
- queue_length: number;
13
+ queue_length: number | null;
14
14
  cooldown_remaining_s: number | null;
15
15
  };
16
16
  warnings: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"sync-health.d.ts","sourceRoot":"","sources":["../../../src/mcp/sync-health.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAU1B,MAAM,WAAW,eAAe;CAE/B;AAED,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,SAAS,GAAG,UAAU,GAAG,OAAO,CAAC;IACzC,YAAY,EAAE;QACZ,KAAK,EAAE,MAAM,CAAC;QACd,cAAc,EAAE,MAAM,CAAC;QACvB,aAAa,EAAE,MAAM,CAAC;QACtB,iBAAiB,EAAE,MAAM,CAAC;KAC3B,CAAC;IACF,QAAQ,EAAE;QACR,YAAY,EAAE,MAAM,CAAC;QACrB,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;KACrC,CAAC;IACF,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAMD;;;GAGG;AACH,wBAAsB,UAAU,CAC9B,MAAM,EAAE,eAAe,EACvB,IAAI,EAAE,IAAI,GACT,OAAO,CAAC,gBAAgB,CAAC,CAqE3B"}
1
+ {"version":3,"file":"sync-health.d.ts","sourceRoot":"","sources":["../../../src/mcp/sync-health.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAU1B,MAAM,WAAW,eAAe;CAE/B;AAED,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,SAAS,GAAG,UAAU,GAAG,OAAO,CAAC;IACzC,YAAY,EAAE;QACZ,KAAK,EAAE,MAAM,CAAC;QACd,cAAc,EAAE,MAAM,CAAC;QACvB,aAAa,EAAE,MAAM,CAAC;QACtB,iBAAiB,EAAE,MAAM,CAAC;KAC3B,CAAC;IACF,QAAQ,EAAE;QACR,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;QAC5B,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;KACrC,CAAC;IACF,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAMD;;;GAGG;AACH,wBAAsB,UAAU,CAC9B,MAAM,EAAE,eAAe,EACvB,IAAI,EAAE,IAAI,GACT,OAAO,CAAC,gBAAgB,CAAC,CAqE3B"}
@@ -36,13 +36,13 @@ async function syncHealth(_input, pool) {
36
36
  return {
37
37
  status: 'error',
38
38
  observations: { total: 0, with_embedding: 0, embedding_pct: 0, sessions_with_obs: 0 },
39
- embedder: { queue_length: 0, cooldown_remaining_s: null },
39
+ embedder: { queue_length: null, cooldown_remaining_s: null },
40
40
  warnings: ['PG query failed: ' + err.message],
41
41
  };
42
42
  }
43
43
  // Embedder stats
44
44
  const embedder = (0, async_embedder_1.getAsyncEmbedder)();
45
- const queueLength = embedder ? embedder.getQueueLength() : -1;
45
+ const queueLength = embedder ? embedder.getQueueLength() : null;
46
46
  const cooldownUntil = embedder ? embedder.getCooldownUntil() : null;
47
47
  const cooldownRemaining = cooldownUntil
48
48
  ? Math.max(0, Math.round((cooldownUntil - Date.now()) / 1000))
@@ -1 +1 @@
1
- {"version":3,"file":"sync-health.js","sourceRoot":"","sources":["../../../src/mcp/sync-health.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sync-health.js","sourceRoot":"","sources":["../../../src/mcp/sync-health.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export interface AgentCapability {
2
+ role: string;
3
+ share: string[];
4
+ }
5
+ export declare const AGENT_CAPABILITIES: Record<string, AgentCapability>;
6
+ export declare function detectAgentId(): string | null;
7
+ export declare function getAgentCapabilities(agentId: string | null): AgentCapability | null;
8
+ export declare function canAccessMemory(ownerAgent: string | null, requesterAgent: string | null): boolean;
9
+ //# sourceMappingURL=agent-context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-context.d.ts","sourceRoot":"","sources":["../../../src/services/agent-context.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAY9D,CAAC;AAEF,wBAAgB,aAAa,IAAI,MAAM,GAAG,IAAI,CAM7C;AAED,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,eAAe,GAAG,IAAI,CAGnF;AAED,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,EAAE,cAAc,EAAE,MAAM,GAAG,IAAI,GAAG,OAAO,CAOjG"}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AGENT_CAPABILITIES = void 0;
4
+ exports.detectAgentId = detectAgentId;
5
+ exports.getAgentCapabilities = getAgentCapabilities;
6
+ exports.canAccessMemory = canAccessMemory;
7
+ const logger_1 = require("./logger");
8
+ const logger = (0, logger_1.createLogger)('agent-context');
9
+ exports.AGENT_CAPABILITIES = {
10
+ sisyphus: { role: 'general', share: ['sisyphus-junior'] },
11
+ hephaestus: { role: 'build', share: ['sisyphus'] },
12
+ oracle: { role: 'reasoning', share: ['sisyphus', 'metis'] },
13
+ librarian: { role: 'search', share: ['sisyphus', 'explore'] },
14
+ explore: { role: 'discovery', share: ['sisyphus', 'librarian'] },
15
+ 'multimodal-looker': { role: 'vision', share: ['sisyphus'] },
16
+ prometheus: { role: 'plan', share: ['sisyphus', 'atlas'] },
17
+ metis: { role: 'meta', share: ['oracle', 'sisyphus'] },
18
+ momus: { role: 'creative', share: ['sisyphus'] },
19
+ atlas: { role: 'navigate', share: ['sisyphus', 'prometheus'] },
20
+ 'sisyphus-junior': { role: 'execute', share: ['sisyphus'] },
21
+ };
22
+ function detectAgentId() {
23
+ const agent = process.env['OMO_AGENT_ID'] ?? process.env['OPENCODE_AGENT'] ?? null;
24
+ if (agent && !exports.AGENT_CAPABILITIES[agent]) {
25
+ logger.warn(`Unknown agent: ${agent}, expected one of: ${Object.keys(exports.AGENT_CAPABILITIES).join(', ')}`);
26
+ }
27
+ return agent;
28
+ }
29
+ function getAgentCapabilities(agentId) {
30
+ if (!agentId)
31
+ return null;
32
+ return exports.AGENT_CAPABILITIES[agentId] ?? null;
33
+ }
34
+ function canAccessMemory(ownerAgent, requesterAgent) {
35
+ if (!ownerAgent || !requesterAgent)
36
+ return true;
37
+ if (ownerAgent === requesterAgent)
38
+ return true;
39
+ const ownerCaps = exports.AGENT_CAPABILITIES[ownerAgent];
40
+ const requesterCaps = exports.AGENT_CAPABILITIES[requesterAgent];
41
+ return (ownerCaps?.share.includes(requesterAgent) ?? false) ||
42
+ (requesterCaps?.share.includes(ownerAgent) ?? false);
43
+ }
44
+ //# sourceMappingURL=agent-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-context.js","sourceRoot":"","sources":["../../../src/services/agent-context.ts"],"names":[],"mappings":";;;AAuBA,sCAMC;AAED,oDAGC;AAED,0CAOC;AA3CD,qCAAwC;AAExC,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,eAAe,CAAC,CAAC;AAOhC,QAAA,kBAAkB,GAAoC;IACjE,QAAQ,EAAe,EAAE,IAAI,EAAE,SAAS,EAAK,KAAK,EAAE,CAAC,iBAAiB,CAAC,EAAE;IACzE,UAAU,EAAa,EAAE,IAAI,EAAE,OAAO,EAAO,KAAK,EAAE,CAAC,UAAU,CAAC,EAAE;IAClE,MAAM,EAAiB,EAAE,IAAI,EAAE,WAAW,EAAG,KAAK,EAAE,CAAC,UAAU,EAAE,OAAO,CAAC,EAAE;IAC3E,SAAS,EAAc,EAAE,IAAI,EAAE,QAAQ,EAAM,KAAK,EAAE,CAAC,UAAU,EAAE,SAAS,CAAC,EAAE;IAC7E,OAAO,EAAgB,EAAE,IAAI,EAAE,WAAW,EAAG,KAAK,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC,EAAE;IAC/E,mBAAmB,EAAI,EAAE,IAAI,EAAE,QAAQ,EAAM,KAAK,EAAE,CAAC,UAAU,CAAC,EAAE;IAClE,UAAU,EAAa,EAAE,IAAI,EAAE,MAAM,EAAQ,KAAK,EAAE,CAAC,UAAU,EAAE,OAAO,CAAC,EAAE;IAC3E,KAAK,EAAkB,EAAE,IAAI,EAAE,MAAM,EAAQ,KAAK,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC,EAAE;IAC5E,KAAK,EAAkB,EAAE,IAAI,EAAE,UAAU,EAAI,KAAK,EAAE,CAAC,UAAU,CAAC,EAAE;IAClE,KAAK,EAAkB,EAAE,IAAI,EAAE,UAAU,EAAI,KAAK,EAAE,CAAC,UAAU,EAAE,YAAY,CAAC,EAAE;IAChF,iBAAiB,EAAM,EAAE,IAAI,EAAE,SAAS,EAAK,KAAK,EAAE,CAAC,UAAU,CAAC,EAAE;CACnE,CAAC;AAEF,SAAgB,aAAa;IAC3B,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,IAAI,IAAI,CAAC;IACnF,IAAI,KAAK,IAAI,CAAC,0BAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;QACxC,MAAM,CAAC,IAAI,CAAC,kBAAkB,KAAK,sBAAsB,MAAM,CAAC,IAAI,CAAC,0BAAkB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACzG,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAgB,oBAAoB,CAAC,OAAsB;IACzD,IAAI,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC;IAC1B,OAAO,0BAAkB,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC;AAC7C,CAAC;AAED,SAAgB,eAAe,CAAC,UAAyB,EAAE,cAA6B;IACtF,IAAI,CAAC,UAAU,IAAI,CAAC,cAAc;QAAE,OAAO,IAAI,CAAC;IAChD,IAAI,UAAU,KAAK,cAAc;QAAE,OAAO,IAAI,CAAC;IAC/C,MAAM,SAAS,GAAG,0BAAkB,CAAC,UAAU,CAAC,CAAC;IACjD,MAAM,aAAa,GAAG,0BAAkB,CAAC,cAAc,CAAC,CAAC;IACzD,OAAO,CAAC,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,KAAK,CAAC;QACpD,CAAC,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,KAAK,CAAC,CAAC;AAC9D,CAAC"}
@@ -6,6 +6,7 @@ export declare class AsyncEmbedder {
6
6
  private cooldownUntil;
7
7
  private readonly cooldownMs;
8
8
  private readonly minImportance;
9
+ private droppedJobs;
9
10
  constructor(pool: Pool, config?: {
10
11
  cooldownMs?: number;
11
12
  minImportance?: number;
@@ -16,6 +17,7 @@ export declare class AsyncEmbedder {
16
17
  */
17
18
  enqueue(table: string, rowId: string, text: string, importance?: number): void;
18
19
  getQueueLength(): number;
20
+ getDroppedCount(): number;
19
21
  /**
20
22
  * Returns timestamp (ms) when cooldown expires, or null if not cooling.
21
23
  */
@@ -1 +1 @@
1
- {"version":3,"file":"async-embedder.d.ts","sourceRoot":"","sources":["../../../src/services/async-embedder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAY1B,qBAAa,aAAa;IACxB,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,KAAK,CAAsB;IACnC,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;gBAE3B,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,MAAM,CAAA;KAAE;IAMhF;;;OAGG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI;IAY9E,cAAc,IAAI,MAAM;IAIxB;;OAEG;IACH,gBAAgB,IAAI,MAAM,GAAG,IAAI;YAInB,KAAK;IAqDnB,OAAO,CAAC,KAAK;CAGd;AAQD,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE;IAAE,UAAU,CAAC,EAAE,MAAM,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,aAAa,CAGrH;AAED,wBAAgB,gBAAgB,IAAI,aAAa,GAAG,IAAI,CAEvD"}
1
+ {"version":3,"file":"async-embedder.d.ts","sourceRoot":"","sources":["../../../src/services/async-embedder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAc1B,qBAAa,aAAa;IACxB,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,KAAK,CAAsB;IACnC,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,WAAW,CAAK;gBAEZ,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,MAAM,CAAA;KAAE;IAMhF;;;OAGG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI;IAkB9E,cAAc,IAAI,MAAM;IAIxB,eAAe,IAAI,MAAM;IAIzB;;OAEG;IACH,gBAAgB,IAAI,MAAM,GAAG,IAAI;YAInB,KAAK;IAqDnB,OAAO,CAAC,KAAK;CAGd;AAQD,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE;IAAE,UAAU,CAAC,EAAE,MAAM,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,aAAa,CAGrH;AAED,wBAAgB,gBAAgB,IAAI,aAAa,GAAG,IAAI,CAEvD"}
@@ -6,6 +6,7 @@ exports.getAsyncEmbedder = getAsyncEmbedder;
6
6
  const embedding_1 = require("../utils/embedding");
7
7
  const logger_1 = require("./logger");
8
8
  const logger = (0, logger_1.createLogger)('async-embedder');
9
+ const MAX_QUEUE = 5000;
9
10
  class AsyncEmbedder {
10
11
  pool;
11
12
  queue = [];
@@ -13,6 +14,7 @@ class AsyncEmbedder {
13
14
  cooldownUntil = 0;
14
15
  cooldownMs;
15
16
  minImportance;
17
+ droppedJobs = 0;
16
18
  constructor(pool, config) {
17
19
  this.pool = pool;
18
20
  this.cooldownMs = config?.cooldownMs ?? 300000;
@@ -27,6 +29,11 @@ class AsyncEmbedder {
27
29
  return;
28
30
  if (importance !== undefined && importance < this.minImportance)
29
31
  return;
32
+ if (this.queue.length >= MAX_QUEUE) {
33
+ this.droppedJobs++;
34
+ logger.warn(`Embedder queue full (${MAX_QUEUE}), dropping observation ${rowId.substring(0, 8)}`);
35
+ return;
36
+ }
30
37
  this.queue.push({ table, rowId, text });
31
38
  if (!this.processing) {
32
39
  this.processing = true;
@@ -36,6 +43,9 @@ class AsyncEmbedder {
36
43
  getQueueLength() {
37
44
  return this.queue.length;
38
45
  }
46
+ getDroppedCount() {
47
+ return this.droppedJobs;
48
+ }
39
49
  /**
40
50
  * Returns timestamp (ms) when cooldown expires, or null if not cooling.
41
51
  */
@@ -1 +1 @@
1
- {"version":3,"file":"async-embedder.js","sourceRoot":"","sources":["../../../src/services/async-embedder.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"async-embedder.js","sourceRoot":"","sources":["../../../src/services/async-embedder.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opcode-pg-memory",
3
- "version": "2.4.1",
3
+ "version": "2.4.3",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "bin": {