@ubundi/openclaw-cortex 1.0.0 → 1.1.0
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 +17 -4
- package/dist/adapters/cortex/client.d.ts +7 -1
- package/dist/adapters/cortex/client.d.ts.map +1 -1
- package/dist/adapters/cortex/client.js +4 -2
- package/dist/adapters/cortex/client.js.map +1 -1
- package/dist/features/capture/handler.d.ts +2 -1
- package/dist/features/capture/handler.d.ts.map +1 -1
- package/dist/features/capture/handler.js +50 -6
- package/dist/features/capture/handler.js.map +1 -1
- package/dist/features/recall/handler.d.ts +2 -1
- package/dist/features/recall/handler.d.ts.map +1 -1
- package/dist/features/recall/handler.js +12 -2
- package/dist/features/recall/handler.js.map +1 -1
- package/dist/features/sync/daily-logs-sync.d.ts +3 -1
- package/dist/features/sync/daily-logs-sync.d.ts.map +1 -1
- package/dist/features/sync/daily-logs-sync.js +13 -1
- package/dist/features/sync/daily-logs-sync.js.map +1 -1
- package/dist/features/sync/memory-md-sync.d.ts +3 -1
- package/dist/features/sync/memory-md-sync.d.ts.map +1 -1
- package/dist/features/sync/memory-md-sync.js +13 -1
- package/dist/features/sync/memory-md-sync.js.map +1 -1
- package/dist/features/sync/transcripts-sync.d.ts +3 -1
- package/dist/features/sync/transcripts-sync.d.ts.map +1 -1
- package/dist/features/sync/transcripts-sync.js +14 -1
- package/dist/features/sync/transcripts-sync.js.map +1 -1
- package/dist/features/sync/watcher.d.ts +3 -1
- package/dist/features/sync/watcher.d.ts.map +1 -1
- package/dist/features/sync/watcher.js +6 -4
- package/dist/features/sync/watcher.js.map +1 -1
- package/dist/internal/audit/audit-logger.d.ts +28 -0
- package/dist/internal/audit/audit-logger.d.ts.map +1 -0
- package/dist/internal/audit/audit-logger.js +61 -0
- package/dist/internal/audit/audit-logger.js.map +1 -0
- package/dist/internal/identity/api-key.js +1 -1
- package/dist/plugin/config/schema.d.ts +15 -0
- package/dist/plugin/config/schema.d.ts.map +1 -1
- package/dist/plugin/config/schema.js +4 -1
- package/dist/plugin/config/schema.js.map +1 -1
- package/dist/plugin/index.d.ts +6 -0
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +121 -12
- package/dist/plugin/index.js.map +1 -1
- package/openclaw.plugin.json +30 -1
- package/package.json +1 -1
- package/dist/core/config/schema.d.ts +0 -61
- package/dist/core/config/schema.d.ts.map +0 -1
- package/dist/core/config/schema.js +0 -39
- package/dist/core/config/schema.js.map +0 -1
- package/dist/core/plugin.d.ts +0 -61
- package/dist/core/plugin.d.ts.map +0 -1
- package/dist/core/plugin.js +0 -147
- package/dist/core/plugin.js.map +0 -1
- package/dist/cortex/client.d.ts +0 -142
- package/dist/cortex/client.d.ts.map +0 -1
- package/dist/cortex/client.js +0 -145
- package/dist/cortex/client.js.map +0 -1
- package/dist/features/reflect/service.d.ts +0 -19
- package/dist/features/reflect/service.d.ts.map +0 -1
- package/dist/features/reflect/service.js +0 -38
- package/dist/features/reflect/service.js.map +0 -1
- package/dist/shared/fs/safe-path.d.ts +0 -8
- package/dist/shared/fs/safe-path.d.ts.map +0 -1
- package/dist/shared/fs/safe-path.js +0 -32
- package/dist/shared/fs/safe-path.js.map +0 -1
- package/dist/shared/metrics/latency-metrics.d.ts +0 -19
- package/dist/shared/metrics/latency-metrics.d.ts.map +0 -1
- package/dist/shared/metrics/latency-metrics.js +0 -45
- package/dist/shared/metrics/latency-metrics.js.map +0 -1
- package/dist/shared/queue/retry-queue.d.ts +0 -31
- package/dist/shared/queue/retry-queue.d.ts.map +0 -1
- package/dist/shared/queue/retry-queue.js +0 -115
- package/dist/shared/queue/retry-queue.js.map +0 -1
- package/dist/shared/transcript/cleaner.d.ts +0 -24
- package/dist/shared/transcript/cleaner.d.ts.map +0 -1
- package/dist/shared/transcript/cleaner.js +0 -96
- package/dist/shared/transcript/cleaner.js.map +0 -1
package/README.md
CHANGED
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
- **Auto-Recall** — injects relevant memories before every agent turn via `before_agent_start` hook
|
|
14
14
|
- **Auto-Capture** — extracts facts from conversations via `agent_end` hook
|
|
15
15
|
- **Agent Tools** — `cortex_search_memory` and `cortex_save_memory` tools the LLM can invoke directly
|
|
16
|
-
- **Commands** — `/memories`
|
|
16
|
+
- **Commands** — `/memories` for status and search, `/audit` to toggle local audit logging
|
|
17
17
|
- **File Sync** — watches `MEMORY.md`, daily logs, and session transcripts for background ingestion
|
|
18
18
|
- **Gateway RPC** — `cortex.status` method for programmatic health and metrics access
|
|
19
19
|
- **Resilience** — retry queue with exponential backoff, cold-start detection, latency metrics
|
|
@@ -107,6 +107,8 @@ Add to your `openclaw.json`:
|
|
|
107
107
|
| `toolTimeoutMs` | number | `10000` | Timeout for explicit tool calls (`cortex_search_memory`, `/memories`). Longer than auto-recall since the user is actively waiting. |
|
|
108
108
|
| `fileSync` | boolean | `true` | Watch and ingest `MEMORY.md` and daily log files |
|
|
109
109
|
| `transcriptSync` | boolean | `true` | Watch and ingest session transcript files |
|
|
110
|
+
| `captureMaxPayloadBytes` | number | `262144` | Max byte size of capture payloads (256KB default). Oversized transcripts are trimmed from the oldest messages. |
|
|
111
|
+
| `auditLog` | boolean | `false` | Enable local audit log. Records every payload sent to Cortex at `.cortex/audit/` in the workspace. Also toggleable at runtime via `/audit on`. |
|
|
110
112
|
| `namespace` | string | `"openclaw"` | Memory namespace. Auto-derived from workspace directory when not set explicitly. |
|
|
111
113
|
|
|
112
114
|
## How It Works
|
|
@@ -130,7 +132,9 @@ src/
|
|
|
130
132
|
recall/
|
|
131
133
|
sync/
|
|
132
134
|
internal/ # Internal helpers (not stable public API)
|
|
135
|
+
audit/
|
|
133
136
|
fs/
|
|
137
|
+
identity/
|
|
134
138
|
metrics/
|
|
135
139
|
queue/
|
|
136
140
|
transcript/
|
|
@@ -182,13 +186,18 @@ These work alongside Auto-Recall/Auto-Capture — the automatic hooks handle bac
|
|
|
182
186
|
|
|
183
187
|
### Commands
|
|
184
188
|
|
|
185
|
-
The plugin registers
|
|
189
|
+
The plugin registers auto-reply commands that execute without invoking the AI agent:
|
|
186
190
|
|
|
187
191
|
```
|
|
188
192
|
/memories # Show memory status (count, maturity, tier, latency)
|
|
189
193
|
/memories dark mode # Search memories for "dark mode"
|
|
194
|
+
/audit # Show audit log status
|
|
195
|
+
/audit on # Start recording all data sent to Cortex
|
|
196
|
+
/audit off # Stop recording (existing logs preserved)
|
|
190
197
|
```
|
|
191
198
|
|
|
199
|
+
The audit log writes to `.cortex/audit/` in your workspace — an `index.jsonl` with metadata and a `payloads/` directory with full content of every transmission. Useful for compliance, debugging, or verifying exactly what data leaves your machine.
|
|
200
|
+
|
|
192
201
|
### Gateway RPC
|
|
193
202
|
|
|
194
203
|
The `cortex.status` RPC method exposes plugin health and metrics programmatically:
|
|
@@ -232,7 +241,11 @@ Additionally, a randomly generated installation ID (`userId`) and a workspace na
|
|
|
232
241
|
|
|
233
242
|
Before transmission, the plugin strips system prompts, tool call JSON, and base64-encoded images from transcripts. Prior recalled memories are also stripped from captured messages to prevent feedback loops.
|
|
234
243
|
|
|
235
|
-
All data is transmitted over HTTPS. Each installation's data is isolated server-side by its unique `userId` — no other installation can access your memories.
|
|
244
|
+
All data is transmitted over HTTPS. Each installation's data is isolated server-side by its unique `userId` — no other installation can access your memories. This isolation has been verified via cross-user recall testing.
|
|
245
|
+
|
|
246
|
+
Capture payloads are capped at 256KB by default (`captureMaxPayloadBytes`) to prevent oversized transmissions from pasted files or long tool outputs.
|
|
247
|
+
|
|
248
|
+
To see exactly what data leaves your machine, enable the audit log with `/audit on` or `auditLog: true` in your config. This records every payload to `.cortex/audit/` in your workspace.
|
|
236
249
|
|
|
237
250
|
To disable all network activity, set `autoRecall: false`, `autoCapture: false`, `fileSync: false`, and `transcriptSync: false` in your config.
|
|
238
251
|
|
|
@@ -251,7 +264,7 @@ If both this plugin and the Cortex SKILL.md are active, the `<cortex_memories>`
|
|
|
251
264
|
```bash
|
|
252
265
|
npm install
|
|
253
266
|
npm run build # TypeScript → dist/
|
|
254
|
-
npm test # Run vitest (
|
|
267
|
+
npm test # Run vitest (174 tests)
|
|
255
268
|
npm run test:watch # Watch mode
|
|
256
269
|
npm run test:integration # Live Cortex API tests (uses the baked-in API key)
|
|
257
270
|
```
|
|
@@ -87,6 +87,10 @@ export interface RememberResponse {
|
|
|
87
87
|
memories_created: number;
|
|
88
88
|
entities_found: string[];
|
|
89
89
|
facts: string[];
|
|
90
|
+
emotions: string[];
|
|
91
|
+
values: string[];
|
|
92
|
+
beliefs: string[];
|
|
93
|
+
insights: string[];
|
|
90
94
|
}
|
|
91
95
|
export interface ForgetResponse {
|
|
92
96
|
memories_removed: number;
|
|
@@ -125,7 +129,7 @@ export declare class CortexClient {
|
|
|
125
129
|
result?: IngestResponse;
|
|
126
130
|
error?: string;
|
|
127
131
|
}>;
|
|
128
|
-
submitIngest(text: string, sessionId?: string, referenceDate?: string): Promise<JobSubmitResponse>;
|
|
132
|
+
submitIngest(text: string, sessionId?: string, referenceDate?: string, userId?: string): Promise<JobSubmitResponse>;
|
|
129
133
|
submitIngestConversation(messages: ConversationMessage[], sessionId?: string, referenceDate?: string): Promise<JobSubmitResponse>;
|
|
130
134
|
batchIngest(items: BatchIngestItem[], timeoutMs?: number): Promise<BatchIngestResponse>;
|
|
131
135
|
reflect(sessionId?: string, timeoutMs?: number): Promise<ReflectResponse>;
|
|
@@ -137,6 +141,8 @@ export declare class CortexClient {
|
|
|
137
141
|
sessionFilter?: string;
|
|
138
142
|
userId?: string;
|
|
139
143
|
queryType?: QueryType;
|
|
144
|
+
minConfidence?: number;
|
|
145
|
+
includeUngrounded?: boolean;
|
|
140
146
|
}): Promise<RecallResponse>;
|
|
141
147
|
forgetSession(sessionId: string, timeoutMs?: number): Promise<ForgetResponse>;
|
|
142
148
|
forgetEntity(entityName: string, timeoutMs?: number): Promise<ForgetResponse>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/adapters/cortex/client.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAChB,MAAM,GACN,QAAQ,GACR,SAAS,GACT,SAAS,GACT,OAAO,GACP,QAAQ,GACR,aAAa,GACb,SAAS,GACT,WAAW,CAAC;AAEhB,MAAM,WAAW,sBAAsB;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,QAAQ,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,sBAAsB,CAAC;CACnC;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,cAAc,EAAE,CAAC;CAC3B;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,MAAM,WAAW,cAAc;IAC7B,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,UAAU,EAAE,CAAC;IACpB,QAAQ,EAAE,YAAY,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,MAAM,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,UAAU,CAAC;AAE7D,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAID,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,IAAI,CAAC,EAAE,QAAQ,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,YAAY,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,EAAE,CAAC;IACzB,KAAK,EAAE,MAAM,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/adapters/cortex/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -101,8 +101,8 @@ export class CortexClient {
|
|
|
101
101
|
clearTimeout(timeout);
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
|
-
async submitIngest(text, sessionId, referenceDate) {
|
|
105
|
-
return this.fetchJsonWithTimeout(`${this.baseUrl}/v1/jobs/ingest`, { text, session_id: sessionId, reference_date: referenceDate ?? null }, DEFAULT_SUBMIT_TIMEOUT_MS, "jobs/ingest");
|
|
104
|
+
async submitIngest(text, sessionId, referenceDate, userId) {
|
|
105
|
+
return this.fetchJsonWithTimeout(`${this.baseUrl}/v1/jobs/ingest`, { text, session_id: sessionId, reference_date: referenceDate ?? null, ...(userId ? { user_id: userId } : {}) }, DEFAULT_SUBMIT_TIMEOUT_MS, "jobs/ingest");
|
|
106
106
|
}
|
|
107
107
|
async submitIngestConversation(messages, sessionId, referenceDate) {
|
|
108
108
|
return this.fetchJsonWithTimeout(`${this.baseUrl}/v1/jobs/ingest/conversation`, { messages, session_id: sessionId, reference_date: referenceDate ?? null }, DEFAULT_SUBMIT_TIMEOUT_MS, "jobs/ingest/conversation");
|
|
@@ -138,6 +138,8 @@ export class CortexClient {
|
|
|
138
138
|
session_filter: options?.sessionFilter ?? undefined,
|
|
139
139
|
user_id: options?.userId ?? undefined,
|
|
140
140
|
query_type: options?.queryType ?? undefined,
|
|
141
|
+
min_confidence: options?.minConfidence ?? undefined,
|
|
142
|
+
include_ungrounded: options?.includeUngrounded ?? undefined,
|
|
141
143
|
}, timeoutMs, "recall");
|
|
142
144
|
}
|
|
143
145
|
async forgetSession(sessionId, timeoutMs = DEFAULT_RECALL_TIMEOUT_MS) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/adapters/cortex/client.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/adapters/cortex/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,6 +2,7 @@ import type { CortexClient } from "../../adapters/cortex/client.js";
|
|
|
2
2
|
import type { CortexConfig } from "../../plugin/config/schema.js";
|
|
3
3
|
import type { KnowledgeState } from "../../plugin/index.js";
|
|
4
4
|
import type { RetryQueue } from "../../internal/queue/retry-queue.js";
|
|
5
|
+
import type { AuditLogger } from "../../internal/audit/audit-logger.js";
|
|
5
6
|
interface AgentEndEvent {
|
|
6
7
|
runId?: string;
|
|
7
8
|
sessionKey?: string;
|
|
@@ -23,6 +24,6 @@ type Logger = {
|
|
|
23
24
|
warn(...args: unknown[]): void;
|
|
24
25
|
error(...args: unknown[]): void;
|
|
25
26
|
};
|
|
26
|
-
export declare function createCaptureHandler(client: CortexClient, config: CortexConfig, logger: Logger, retryQueue?: RetryQueue, knowledgeState?: KnowledgeState, getUserId?: () => string | undefined, userIdReady?: Promise<void
|
|
27
|
+
export declare function createCaptureHandler(client: CortexClient, config: CortexConfig, logger: Logger, retryQueue?: RetryQueue, knowledgeState?: KnowledgeState, getUserId?: () => string | undefined, userIdReady?: Promise<void>, pluginSessionId?: string, auditLogger?: AuditLogger): (event: AgentEndEvent) => Promise<void>;
|
|
27
28
|
export {};
|
|
28
29
|
//# sourceMappingURL=handler.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../src/features/capture/handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAuB,MAAM,iCAAiC,CAAC;AACzF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../src/features/capture/handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAuB,MAAM,iCAAiC,CAAC;AACzF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAExE,UAAU,aAAa;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE;QACZ,WAAW,EAAE,MAAM,CAAC;QACpB,YAAY,EAAE,MAAM,CAAC;QACrB,eAAe,EAAE,MAAM,CAAC;QACxB,gBAAgB,EAAE,MAAM,CAAC;QACzB,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;CACH;AAED,KAAK,MAAM,GAAG;IACZ,KAAK,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACjC,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,KAAK,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CACjC,CAAC;AAyCF,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,UAAU,EACvB,cAAc,CAAC,EAAE,cAAc,EAC/B,SAAS,CAAC,EAAE,MAAM,MAAM,GAAG,SAAS,EACpC,WAAW,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,EAC3B,eAAe,CAAC,EAAE,MAAM,EACxB,WAAW,CAAC,EAAE,WAAW,IAMX,OAAO,aAAa,KAAG,OAAO,CAAC,IAAI,CAAC,CAqInD"}
|
|
@@ -1,4 +1,9 @@
|
|
|
1
1
|
const MIN_CONTENT_LENGTH = 20;
|
|
2
|
+
/** Strip injected recall block so we don't re-ingest recalled memories as new content */
|
|
3
|
+
const RECALL_BLOCK_RE = /\s*<cortex_memories>[\s\S]*?<\/cortex_memories>\s*/g;
|
|
4
|
+
function stripRecallBlock(text) {
|
|
5
|
+
return text.replace(RECALL_BLOCK_RE, "").trim();
|
|
6
|
+
}
|
|
2
7
|
function extractContent(content) {
|
|
3
8
|
if (typeof content === "string")
|
|
4
9
|
return content;
|
|
@@ -28,7 +33,7 @@ function isWorthCapturing(messages) {
|
|
|
28
33
|
const KNOWLEDGE_REFRESH_EVERY_N = 5;
|
|
29
34
|
/** Minimum interval between knowledge refreshes */
|
|
30
35
|
const KNOWLEDGE_REFRESH_MIN_INTERVAL_MS = 5 * 60_000; // 5 minutes
|
|
31
|
-
export function createCaptureHandler(client, config, logger, retryQueue, knowledgeState, getUserId, userIdReady) {
|
|
36
|
+
export function createCaptureHandler(client, config, logger, retryQueue, knowledgeState, getUserId, userIdReady, pluginSessionId, auditLogger) {
|
|
32
37
|
let captureCounter = 0;
|
|
33
38
|
let lastCapturedAt = 0;
|
|
34
39
|
let capturesSinceRefresh = 0;
|
|
@@ -49,7 +54,7 @@ export function createCaptureHandler(client, config, logger, retryQueue, knowled
|
|
|
49
54
|
"content" in msg)
|
|
50
55
|
.map((msg) => ({
|
|
51
56
|
role: String(msg.role),
|
|
52
|
-
content: extractContent(msg.content),
|
|
57
|
+
content: stripRecallBlock(extractContent(msg.content)),
|
|
53
58
|
}))
|
|
54
59
|
.filter((msg) => msg.content.length > 0);
|
|
55
60
|
if (!isWorthCapturing(normalized)) {
|
|
@@ -59,19 +64,58 @@ export function createCaptureHandler(client, config, logger, retryQueue, knowled
|
|
|
59
64
|
// API caps at 200 messages — take the most recent to stay within the limit
|
|
60
65
|
const MAX_MESSAGES = 200;
|
|
61
66
|
const trimmed = normalized.length > MAX_MESSAGES ? normalized.slice(-MAX_MESSAGES) : normalized;
|
|
67
|
+
// Enforce byte-size cap — drop oldest messages until the transcript fits.
|
|
68
|
+
// This prevents oversized payloads from pasted files or long tool outputs.
|
|
69
|
+
const maxBytes = config.captureMaxPayloadBytes ?? 262_144;
|
|
70
|
+
while (trimmed.length > 2) {
|
|
71
|
+
const estimatedSize = trimmed.reduce((sum, m) => sum + Buffer.byteLength(m.role, "utf-8") + 2 + Buffer.byteLength(m.content, "utf-8") + 2, 0);
|
|
72
|
+
if (estimatedSize <= maxBytes)
|
|
73
|
+
break;
|
|
74
|
+
trimmed.shift();
|
|
75
|
+
}
|
|
76
|
+
const totalChars = trimmed.reduce((sum, m) => sum + m.content.length, 0);
|
|
77
|
+
logger.info(`Cortex capture: ${trimmed.length} messages, ${totalChars} chars`);
|
|
62
78
|
// Advance watermark before async work so a second turn doesn't re-send this delta
|
|
63
79
|
lastCapturedAt = event.messages.length;
|
|
64
80
|
// Ensure userId is resolved before sending — in practice this resolves in <100ms
|
|
65
81
|
// at startup, well before agent_end fires, but we await explicitly to be correct.
|
|
66
82
|
if (userIdReady)
|
|
67
83
|
await userIdReady;
|
|
68
|
-
const sessionId = event.sessionKey ?? event.sessionId;
|
|
84
|
+
const sessionId = event.sessionKey ?? event.sessionId ?? pluginSessionId;
|
|
85
|
+
logger.debug?.(`Cortex capture: sessionId=${sessionId}, userId=${getUserId?.()}`);
|
|
86
|
+
// Flatten messages into a role: content transcript for ingestion
|
|
87
|
+
const transcript = trimmed
|
|
88
|
+
.map((m) => `${m.role}: ${m.content}`)
|
|
89
|
+
.join("\n\n");
|
|
90
|
+
// Log a summary of what's being sent
|
|
91
|
+
const roleCounts = {};
|
|
92
|
+
for (const m of trimmed) {
|
|
93
|
+
roleCounts[m.role] = (roleCounts[m.role] ?? 0) + 1;
|
|
94
|
+
}
|
|
95
|
+
const roleBreakdown = Object.entries(roleCounts).map(([r, n]) => `${r}=${n}`).join(", ");
|
|
96
|
+
const preview = (transcript.length > 200 ? transcript.slice(0, 200) + "…" : transcript).replace(/\n/g, " ");
|
|
97
|
+
logger.info(`Cortex capture summary: ${trimmed.length} msgs (${roleBreakdown}), ${transcript.length} chars, sessionId=${sessionId}`);
|
|
98
|
+
logger.info(`Cortex capture preview: ${preview}`);
|
|
99
|
+
if (auditLogger) {
|
|
100
|
+
void auditLogger.log({
|
|
101
|
+
feature: "auto-capture",
|
|
102
|
+
method: "POST",
|
|
103
|
+
endpoint: "/v1/jobs/ingest",
|
|
104
|
+
payload: transcript,
|
|
105
|
+
sessionId,
|
|
106
|
+
userId: getUserId?.(),
|
|
107
|
+
messageCount: trimmed.length,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
69
110
|
const doRemember = async () => {
|
|
70
111
|
// Re-evaluate userId at call time so retries pick up the resolved value
|
|
71
112
|
const userId = getUserId?.();
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
113
|
+
// Use async job endpoint — /v1/remember and /v1/ingest both 503 under
|
|
114
|
+
// the Lambda proxy timeout when the RESONATE pipeline is slow.
|
|
115
|
+
// /v1/jobs/ingest returns immediately and processes in the background.
|
|
116
|
+
const job = await client.submitIngest(transcript, sessionId, new Date().toISOString(), userId);
|
|
117
|
+
logger.info(`Cortex capture: submitted job ${job.job_id} (status=${job.status})`);
|
|
118
|
+
if (knowledgeState) {
|
|
75
119
|
knowledgeState.hasMemories = true;
|
|
76
120
|
}
|
|
77
121
|
// Periodically refresh knowledge state so totalSessions (and thus
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../src/features/capture/handler.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../src/features/capture/handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { CortexClient } from "../../adapters/cortex/client.js";
|
|
2
2
|
import type { CortexConfig } from "../../plugin/config/schema.js";
|
|
3
3
|
import type { KnowledgeState } from "../../plugin/index.js";
|
|
4
|
+
import type { AuditLogger } from "../../internal/audit/audit-logger.js";
|
|
4
5
|
import { LatencyMetrics } from "../../internal/metrics/latency-metrics.js";
|
|
5
6
|
interface BeforeAgentStartEvent {
|
|
6
7
|
prompt: string;
|
|
@@ -26,7 +27,7 @@ type Logger = {
|
|
|
26
27
|
* Higher tiers run heavier pipelines (reranking, graph traversal) that need more time.
|
|
27
28
|
*/
|
|
28
29
|
export declare function deriveEffectiveTimeout(configuredMs: number, totalSessions: number): number;
|
|
29
|
-
export declare function createRecallHandler(client: CortexClient, config: CortexConfig, logger: Logger, metrics?: LatencyMetrics, knowledgeState?: KnowledgeState, getUserId?: () => string | undefined): {
|
|
30
|
+
export declare function createRecallHandler(client: CortexClient, config: CortexConfig, logger: Logger, metrics?: LatencyMetrics, knowledgeState?: KnowledgeState, getUserId?: () => string | undefined, auditLogger?: AuditLogger): {
|
|
30
31
|
(event: BeforeAgentStartEvent, _ctx: AgentContext): Promise<BeforeAgentStartResult | void>;
|
|
31
32
|
metrics: LatencyMetrics;
|
|
32
33
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../src/features/recall/handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../src/features/recall/handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAExE,OAAO,EAAE,cAAc,EAAE,MAAM,2CAA2C,CAAC;AAE3E,UAAU,qBAAqB;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,EAAE,CAAC;CACtB;AAED,UAAU,YAAY;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,UAAU,sBAAsB;IAC9B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,KAAK,MAAM,GAAG;IACZ,KAAK,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACjC,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,KAAK,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CACjC,CAAC;AAUF;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,CAI1F;AAED,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,cAAc,EACxB,cAAc,CAAC,EAAE,cAAc,EAC/B,SAAS,CAAC,EAAE,MAAM,MAAM,GAAG,SAAS,EACpC,WAAW,CAAC,EAAE,WAAW;YAOhB,qBAAqB,QACtB,YAAY,GACjB,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC;;EAqF1C"}
|
|
@@ -18,7 +18,7 @@ export function deriveEffectiveTimeout(configuredMs, totalSessions) {
|
|
|
18
18
|
return Math.max(configuredMs, 1500); // Tier 2
|
|
19
19
|
return configuredMs; // Tier 1
|
|
20
20
|
}
|
|
21
|
-
export function createRecallHandler(client, config, logger, metrics, knowledgeState, getUserId) {
|
|
21
|
+
export function createRecallHandler(client, config, logger, metrics, knowledgeState, getUserId, auditLogger) {
|
|
22
22
|
const recallMetrics = metrics ?? new LatencyMetrics();
|
|
23
23
|
let consecutiveFailures = 0;
|
|
24
24
|
let coldStartUntil = 0;
|
|
@@ -44,7 +44,17 @@ export function createRecallHandler(client, config, logger, metrics, knowledgeSt
|
|
|
44
44
|
? deriveEffectiveTimeout(config.recallTimeoutMs, knowledgeState.totalSessions)
|
|
45
45
|
: config.recallTimeoutMs;
|
|
46
46
|
try {
|
|
47
|
-
const
|
|
47
|
+
const currentUserId = getUserId?.();
|
|
48
|
+
if (auditLogger) {
|
|
49
|
+
void auditLogger.log({
|
|
50
|
+
feature: "auto-recall",
|
|
51
|
+
method: "POST",
|
|
52
|
+
endpoint: "/v1/recall",
|
|
53
|
+
payload: prompt,
|
|
54
|
+
userId: currentUserId,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
const response = await client.recall(prompt, effectiveTimeout, { limit: config.recallLimit, userId: currentUserId, queryType: "factual" });
|
|
48
58
|
const elapsed = Date.now() - start;
|
|
49
59
|
recallMetrics.record(elapsed);
|
|
50
60
|
consecutiveFailures = 0; // reset on success
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../src/features/recall/handler.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../src/features/recall/handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { CortexClient } from "../../adapters/cortex/client.js";
|
|
2
2
|
import type { RetryQueue } from "../../internal/queue/retry-queue.js";
|
|
3
|
+
import type { AuditLogger } from "../../internal/audit/audit-logger.js";
|
|
3
4
|
type Logger = {
|
|
4
5
|
debug?(...args: unknown[]): void;
|
|
5
6
|
info(...args: unknown[]): void;
|
|
@@ -13,8 +14,9 @@ export declare class DailyLogsSync {
|
|
|
13
14
|
private retryQueue?;
|
|
14
15
|
private allowedRoot?;
|
|
15
16
|
private getUserId?;
|
|
17
|
+
private auditLogger?;
|
|
16
18
|
private offsets;
|
|
17
|
-
constructor(client: CortexClient, sessionPrefix: string, logger: Logger, retryQueue?: RetryQueue | undefined, allowedRoot?: string | undefined, getUserId?: (() => string | undefined) | undefined);
|
|
19
|
+
constructor(client: CortexClient, sessionPrefix: string, logger: Logger, retryQueue?: RetryQueue | undefined, allowedRoot?: string | undefined, getUserId?: (() => string | undefined) | undefined, auditLogger?: AuditLogger | undefined);
|
|
18
20
|
onFileChange(filePath: string, filename: string): Promise<void>;
|
|
19
21
|
stop(): void;
|
|
20
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"daily-logs-sync.d.ts","sourceRoot":"","sources":["../../../src/features/sync/daily-logs-sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"daily-logs-sync.d.ts","sourceRoot":"","sources":["../../../src/features/sync/daily-logs-sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAGxE,KAAK,MAAM,GAAG;IACZ,KAAK,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACjC,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,KAAK,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CACjC,CAAC;AAEF,qBAAa,aAAa;IAItB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU,CAAC;IACnB,OAAO,CAAC,WAAW,CAAC;IACpB,OAAO,CAAC,SAAS,CAAC;IAClB,OAAO,CAAC,WAAW,CAAC;IATtB,OAAO,CAAC,OAAO,CAA6B;gBAGlC,MAAM,EAAE,YAAY,EACpB,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,UAAU,YAAA,EACvB,WAAW,CAAC,EAAE,MAAM,YAAA,EACpB,SAAS,CAAC,GAAE,MAAM,MAAM,GAAG,SAAS,aAAA,EACpC,WAAW,CAAC,EAAE,WAAW,YAAA;IAG7B,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAmDrE,IAAI,IAAI,IAAI;CAGb;AAID,wBAAgB,uBAAuB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAG5E"}
|
|
@@ -7,14 +7,16 @@ export class DailyLogsSync {
|
|
|
7
7
|
retryQueue;
|
|
8
8
|
allowedRoot;
|
|
9
9
|
getUserId;
|
|
10
|
+
auditLogger;
|
|
10
11
|
offsets = new Map();
|
|
11
|
-
constructor(client, sessionPrefix, logger, retryQueue, allowedRoot, getUserId) {
|
|
12
|
+
constructor(client, sessionPrefix, logger, retryQueue, allowedRoot, getUserId, auditLogger) {
|
|
12
13
|
this.client = client;
|
|
13
14
|
this.sessionPrefix = sessionPrefix;
|
|
14
15
|
this.logger = logger;
|
|
15
16
|
this.retryQueue = retryQueue;
|
|
16
17
|
this.allowedRoot = allowedRoot;
|
|
17
18
|
this.getUserId = getUserId;
|
|
19
|
+
this.auditLogger = auditLogger;
|
|
18
20
|
}
|
|
19
21
|
async onFileChange(filePath, filename) {
|
|
20
22
|
try {
|
|
@@ -34,6 +36,16 @@ export class DailyLogsSync {
|
|
|
34
36
|
return;
|
|
35
37
|
const sessionId = `${this.sessionPrefix}:daily:${filename}`;
|
|
36
38
|
const referenceDate = extractDateFromFilename(filename);
|
|
39
|
+
if (this.auditLogger) {
|
|
40
|
+
void this.auditLogger.log({
|
|
41
|
+
feature: "file-sync-daily-logs",
|
|
42
|
+
method: "POST",
|
|
43
|
+
endpoint: "/v1/remember",
|
|
44
|
+
payload: newContent,
|
|
45
|
+
sessionId,
|
|
46
|
+
userId: this.getUserId?.(),
|
|
47
|
+
});
|
|
48
|
+
}
|
|
37
49
|
const doRemember = () => {
|
|
38
50
|
// Re-evaluate userId at call time so retries use the resolved value
|
|
39
51
|
const userId = this.getUserId?.();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"daily-logs-sync.js","sourceRoot":"","sources":["../../../src/features/sync/daily-logs-sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"daily-logs-sync.js","sourceRoot":"","sources":["../../../src/features/sync/daily-logs-sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { CortexClient } from "../../adapters/cortex/client.js";
|
|
2
2
|
import type { RetryQueue } from "../../internal/queue/retry-queue.js";
|
|
3
|
+
import type { AuditLogger } from "../../internal/audit/audit-logger.js";
|
|
3
4
|
type Logger = {
|
|
4
5
|
debug?(...args: unknown[]): void;
|
|
5
6
|
info(...args: unknown[]): void;
|
|
@@ -14,10 +15,11 @@ export declare class MemoryMdSync {
|
|
|
14
15
|
private retryQueue?;
|
|
15
16
|
private allowedRoot?;
|
|
16
17
|
private getUserId?;
|
|
18
|
+
private auditLogger?;
|
|
17
19
|
private lastContent;
|
|
18
20
|
private debounceTimer;
|
|
19
21
|
private syncCounter;
|
|
20
|
-
constructor(filePath: string, client: CortexClient, sessionId: string, logger: Logger, retryQueue?: RetryQueue | undefined, allowedRoot?: string | undefined, getUserId?: (() => string | undefined) | undefined);
|
|
22
|
+
constructor(filePath: string, client: CortexClient, sessionId: string, logger: Logger, retryQueue?: RetryQueue | undefined, allowedRoot?: string | undefined, getUserId?: (() => string | undefined) | undefined, auditLogger?: AuditLogger | undefined);
|
|
21
23
|
onFileChange(): void;
|
|
22
24
|
private diffAndIngest;
|
|
23
25
|
stop(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"memory-md-sync.d.ts","sourceRoot":"","sources":["../../../src/features/sync/memory-md-sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"memory-md-sync.d.ts","sourceRoot":"","sources":["../../../src/features/sync/memory-md-sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAGxE,KAAK,MAAM,GAAG;IACZ,KAAK,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACjC,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,KAAK,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CACjC,CAAC;AAIF,qBAAa,YAAY;IAMrB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU,CAAC;IACnB,OAAO,CAAC,WAAW,CAAC;IACpB,OAAO,CAAC,SAAS,CAAC;IAClB,OAAO,CAAC,WAAW,CAAC;IAZtB,OAAO,CAAC,WAAW,CAAM;IACzB,OAAO,CAAC,aAAa,CAA8C;IACnE,OAAO,CAAC,WAAW,CAAK;gBAGd,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,YAAY,EACpB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,UAAU,YAAA,EACvB,WAAW,CAAC,EAAE,MAAM,YAAA,EACpB,SAAS,CAAC,GAAE,MAAM,MAAM,GAAG,SAAS,aAAA,EACpC,WAAW,CAAC,EAAE,WAAW,YAAA;IAGnC,YAAY,IAAI,IAAI;YAUN,aAAa;IAqD3B,IAAI,IAAI,IAAI;CAMb;AAED,wBAAgB,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,CAMlE"}
|
|
@@ -9,10 +9,11 @@ export class MemoryMdSync {
|
|
|
9
9
|
retryQueue;
|
|
10
10
|
allowedRoot;
|
|
11
11
|
getUserId;
|
|
12
|
+
auditLogger;
|
|
12
13
|
lastContent = "";
|
|
13
14
|
debounceTimer = null;
|
|
14
15
|
syncCounter = 0;
|
|
15
|
-
constructor(filePath, client, sessionId, logger, retryQueue, allowedRoot, getUserId) {
|
|
16
|
+
constructor(filePath, client, sessionId, logger, retryQueue, allowedRoot, getUserId, auditLogger) {
|
|
16
17
|
this.filePath = filePath;
|
|
17
18
|
this.client = client;
|
|
18
19
|
this.sessionId = sessionId;
|
|
@@ -20,6 +21,7 @@ export class MemoryMdSync {
|
|
|
20
21
|
this.retryQueue = retryQueue;
|
|
21
22
|
this.allowedRoot = allowedRoot;
|
|
22
23
|
this.getUserId = getUserId;
|
|
24
|
+
this.auditLogger = auditLogger;
|
|
23
25
|
}
|
|
24
26
|
onFileChange() {
|
|
25
27
|
if (this.debounceTimer)
|
|
@@ -53,6 +55,16 @@ export class MemoryMdSync {
|
|
|
53
55
|
this.lastContent = current;
|
|
54
56
|
if (!added.trim())
|
|
55
57
|
return;
|
|
58
|
+
if (this.auditLogger) {
|
|
59
|
+
void this.auditLogger.log({
|
|
60
|
+
feature: "file-sync-memory-md",
|
|
61
|
+
method: "POST",
|
|
62
|
+
endpoint: "/v1/remember",
|
|
63
|
+
payload: added,
|
|
64
|
+
sessionId: this.sessionId,
|
|
65
|
+
userId: this.getUserId?.(),
|
|
66
|
+
});
|
|
67
|
+
}
|
|
56
68
|
const doRemember = () => {
|
|
57
69
|
// Re-evaluate userId at call time so retries use the resolved value
|
|
58
70
|
const userId = this.getUserId?.();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"memory-md-sync.js","sourceRoot":"","sources":["../../../src/features/sync/memory-md-sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"memory-md-sync.js","sourceRoot":"","sources":["../../../src/features/sync/memory-md-sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { CortexClient } from "../../adapters/cortex/client.js";
|
|
2
2
|
import type { RetryQueue } from "../../internal/queue/retry-queue.js";
|
|
3
|
+
import type { AuditLogger } from "../../internal/audit/audit-logger.js";
|
|
3
4
|
type Logger = {
|
|
4
5
|
debug?(...args: unknown[]): void;
|
|
5
6
|
info(...args: unknown[]): void;
|
|
@@ -13,8 +14,9 @@ export declare class TranscriptsSync {
|
|
|
13
14
|
private retryQueue?;
|
|
14
15
|
private allowedRoot?;
|
|
15
16
|
private getUserId?;
|
|
17
|
+
private auditLogger?;
|
|
16
18
|
private offsets;
|
|
17
|
-
constructor(client: CortexClient, sessionPrefix: string, logger: Logger, retryQueue?: RetryQueue | undefined, allowedRoot?: string | undefined, getUserId?: (() => string | undefined) | undefined);
|
|
19
|
+
constructor(client: CortexClient, sessionPrefix: string, logger: Logger, retryQueue?: RetryQueue | undefined, allowedRoot?: string | undefined, getUserId?: (() => string | undefined) | undefined, auditLogger?: AuditLogger | undefined);
|
|
18
20
|
onFileChange(filePath: string, filename: string): Promise<void>;
|
|
19
21
|
stop(): void;
|
|
20
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transcripts-sync.d.ts","sourceRoot":"","sources":["../../../src/features/sync/transcripts-sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"transcripts-sync.d.ts","sourceRoot":"","sources":["../../../src/features/sync/transcripts-sync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAIxE,KAAK,MAAM,GAAG;IACZ,KAAK,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACjC,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAC/B,KAAK,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CACjC,CAAC;AAEF,qBAAa,eAAe;IAIxB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU,CAAC;IACnB,OAAO,CAAC,WAAW,CAAC;IACpB,OAAO,CAAC,SAAS,CAAC;IAClB,OAAO,CAAC,WAAW,CAAC;IATtB,OAAO,CAAC,OAAO,CAA6B;gBAGlC,MAAM,EAAE,YAAY,EACpB,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,UAAU,YAAA,EACvB,WAAW,CAAC,EAAE,MAAM,YAAA,EACpB,SAAS,CAAC,GAAE,MAAM,MAAM,GAAG,SAAS,aAAA,EACpC,WAAW,CAAC,EAAE,WAAW,YAAA;IAG7B,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA6DrE,IAAI,IAAI,IAAI;CAGb"}
|