@ubundi/openclaw-cortex 0.7.2 → 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 +39 -6
- 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 +21 -1
- 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/plugin/config/schema.d.ts +10 -0
- package/dist/plugin/config/schema.d.ts.map +1 -1
- package/dist/plugin/config/schema.js +2 -0
- package/dist/plugin/config/schema.js.map +1 -1
- package/dist/plugin/index.d.ts +4 -0
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +97 -4
- package/dist/plugin/index.js.map +1 -1
- package/openclaw.plugin.json +30 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -13,13 +13,11 @@
|
|
|
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
|
|
20
20
|
|
|
21
|
-
> **Cortex availability:** Cortex is currently in early testing. The plugin ships with access built in — no API key or account required.
|
|
22
|
-
|
|
23
21
|
## Prerequisites
|
|
24
22
|
|
|
25
23
|
- Node.js `>=20`
|
|
@@ -109,6 +107,8 @@ Add to your `openclaw.json`:
|
|
|
109
107
|
| `toolTimeoutMs` | number | `10000` | Timeout for explicit tool calls (`cortex_search_memory`, `/memories`). Longer than auto-recall since the user is actively waiting. |
|
|
110
108
|
| `fileSync` | boolean | `true` | Watch and ingest `MEMORY.md` and daily log files |
|
|
111
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`. |
|
|
112
112
|
| `namespace` | string | `"openclaw"` | Memory namespace. Auto-derived from workspace directory when not set explicitly. |
|
|
113
113
|
|
|
114
114
|
## How It Works
|
|
@@ -132,7 +132,9 @@ src/
|
|
|
132
132
|
recall/
|
|
133
133
|
sync/
|
|
134
134
|
internal/ # Internal helpers (not stable public API)
|
|
135
|
+
audit/
|
|
135
136
|
fs/
|
|
137
|
+
identity/
|
|
136
138
|
metrics/
|
|
137
139
|
queue/
|
|
138
140
|
transcript/
|
|
@@ -153,6 +155,8 @@ Before every agent turn, the plugin queries Cortex's `/v1/recall` endpoint and p
|
|
|
153
155
|
|
|
154
156
|
If the request exceeds `recallTimeoutMs`, the agent proceeds without memories (silent degradation). After 3 consecutive failures, recall is disabled for 30 seconds (cold-start detection) to avoid hammering a cold ECS task.
|
|
155
157
|
|
|
158
|
+

|
|
159
|
+
|
|
156
160
|
### Auto-Capture
|
|
157
161
|
|
|
158
162
|
After each agent turn completes, the plugin flattens the turn's new messages into a `role: content` transcript and submits it to Cortex's `/v1/jobs/ingest` endpoint (async job queue). The job returns immediately and processes in the background — this avoids Lambda proxy timeouts that occur with synchronous ingestion. A watermark tracks how much of the conversation has already been ingested, so each message is sent exactly once — no overlap between turns. Tool call results (`role: "tool"`) are included alongside `user` and `assistant` messages, since tool output is where the substantive work of an agentic turn lives. A heuristic skips trivial exchanges (short messages, turns without a substantive response).
|
|
@@ -182,20 +186,25 @@ 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:
|
|
195
204
|
|
|
196
205
|
```json
|
|
197
206
|
{
|
|
198
|
-
"version": "0.
|
|
207
|
+
"version": "1.0.0",
|
|
199
208
|
"healthy": true,
|
|
200
209
|
"knowledgeState": { "hasMemories": true, "totalSessions": 42, "maturity": "mature", "tier": 3 },
|
|
201
210
|
"recallMetrics": { "count": 120, "p50": 95, "p95": 280, "p99": 450 },
|
|
@@ -216,6 +225,30 @@ Use this to tune `recallTimeoutMs` for your deployment.
|
|
|
216
225
|
|
|
217
226
|

|
|
218
227
|
|
|
228
|
+
## Privacy & Data
|
|
229
|
+
|
|
230
|
+
This plugin sends data to the Cortex API to provide memory functionality. Here's what leaves your machine:
|
|
231
|
+
|
|
232
|
+
| Data | When | How to disable |
|
|
233
|
+
|------|------|----------------|
|
|
234
|
+
| Conversation messages (user + assistant) | After each agent turn | `autoCapture: false` |
|
|
235
|
+
| Your current prompt | Before each agent turn | `autoRecall: false` |
|
|
236
|
+
| MEMORY.md changes (added lines only) | On file save | `fileSync: false` |
|
|
237
|
+
| Daily log files (`memory/*.md`) | On file save | `fileSync: false` |
|
|
238
|
+
| Session transcripts (`sessions/*.jsonl`) | On file save | `transcriptSync: false` |
|
|
239
|
+
|
|
240
|
+
Additionally, a randomly generated installation ID (`userId`) and a workspace namespace hash are sent with every request to scope your data. No personally identifiable information is collected.
|
|
241
|
+
|
|
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.
|
|
243
|
+
|
|
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.
|
|
249
|
+
|
|
250
|
+
To disable all network activity, set `autoRecall: false`, `autoCapture: false`, `fileSync: false`, and `transcriptSync: false` in your config.
|
|
251
|
+
|
|
219
252
|
## Compatibility with SKILL.md
|
|
220
253
|
|
|
221
254
|
If both this plugin and the Cortex SKILL.md are active, the `<cortex_memories>` tag in the prepended context signals to the skill that recall has already happened — the agent can skip manual `curl` calls.
|
|
@@ -231,7 +264,7 @@ If both this plugin and the Cortex SKILL.md are active, the `<cortex_memories>`
|
|
|
231
264
|
```bash
|
|
232
265
|
npm install
|
|
233
266
|
npm run build # TypeScript → dist/
|
|
234
|
-
npm test # Run vitest (
|
|
267
|
+
npm test # Run vitest (174 tests)
|
|
235
268
|
npm run test:watch # Watch mode
|
|
236
269
|
npm run test:integration # Live Cortex API tests (uses the baked-in API key)
|
|
237
270
|
```
|
|
@@ -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>, pluginSessionId?: string): (event: AgentEndEvent) => 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"}
|
|
@@ -33,7 +33,7 @@ function isWorthCapturing(messages) {
|
|
|
33
33
|
const KNOWLEDGE_REFRESH_EVERY_N = 5;
|
|
34
34
|
/** Minimum interval between knowledge refreshes */
|
|
35
35
|
const KNOWLEDGE_REFRESH_MIN_INTERVAL_MS = 5 * 60_000; // 5 minutes
|
|
36
|
-
export function createCaptureHandler(client, config, logger, retryQueue, knowledgeState, getUserId, userIdReady, pluginSessionId) {
|
|
36
|
+
export function createCaptureHandler(client, config, logger, retryQueue, knowledgeState, getUserId, userIdReady, pluginSessionId, auditLogger) {
|
|
37
37
|
let captureCounter = 0;
|
|
38
38
|
let lastCapturedAt = 0;
|
|
39
39
|
let capturesSinceRefresh = 0;
|
|
@@ -64,6 +64,15 @@ export function createCaptureHandler(client, config, logger, retryQueue, knowled
|
|
|
64
64
|
// API caps at 200 messages — take the most recent to stay within the limit
|
|
65
65
|
const MAX_MESSAGES = 200;
|
|
66
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
|
+
}
|
|
67
76
|
const totalChars = trimmed.reduce((sum, m) => sum + m.content.length, 0);
|
|
68
77
|
logger.info(`Cortex capture: ${trimmed.length} messages, ${totalChars} chars`);
|
|
69
78
|
// Advance watermark before async work so a second turn doesn't re-send this delta
|
|
@@ -87,6 +96,17 @@ export function createCaptureHandler(client, config, logger, retryQueue, knowled
|
|
|
87
96
|
const preview = (transcript.length > 200 ? transcript.slice(0, 200) + "…" : transcript).replace(/\n/g, " ");
|
|
88
97
|
logger.info(`Cortex capture summary: ${trimmed.length} msgs (${roleBreakdown}), ${transcript.length} chars, sessionId=${sessionId}`);
|
|
89
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
|
+
}
|
|
90
110
|
const doRemember = async () => {
|
|
91
111
|
// Re-evaluate userId at call time so retries pick up the resolved value
|
|
92
112
|
const userId = getUserId?.();
|
|
@@ -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"}
|
|
@@ -8,14 +8,16 @@ export class TranscriptsSync {
|
|
|
8
8
|
retryQueue;
|
|
9
9
|
allowedRoot;
|
|
10
10
|
getUserId;
|
|
11
|
+
auditLogger;
|
|
11
12
|
offsets = new Map();
|
|
12
|
-
constructor(client, sessionPrefix, logger, retryQueue, allowedRoot, getUserId) {
|
|
13
|
+
constructor(client, sessionPrefix, logger, retryQueue, allowedRoot, getUserId, auditLogger) {
|
|
13
14
|
this.client = client;
|
|
14
15
|
this.sessionPrefix = sessionPrefix;
|
|
15
16
|
this.logger = logger;
|
|
16
17
|
this.retryQueue = retryQueue;
|
|
17
18
|
this.allowedRoot = allowedRoot;
|
|
18
19
|
this.getUserId = getUserId;
|
|
20
|
+
this.auditLogger = auditLogger;
|
|
19
21
|
}
|
|
20
22
|
async onFileChange(filePath, filename) {
|
|
21
23
|
try {
|
|
@@ -42,6 +44,17 @@ export class TranscriptsSync {
|
|
|
42
44
|
const sessionName = filename.replace(/\.jsonl$/, "");
|
|
43
45
|
const sessionId = `${this.sessionPrefix}:session:${sessionName}`;
|
|
44
46
|
const referenceDate = new Date().toISOString().slice(0, 10);
|
|
47
|
+
if (this.auditLogger) {
|
|
48
|
+
void this.auditLogger.log({
|
|
49
|
+
feature: "file-sync-transcripts",
|
|
50
|
+
method: "POST",
|
|
51
|
+
endpoint: "/v1/remember",
|
|
52
|
+
payload: messages.map((m) => `${m.role}: ${m.content}`).join("\n\n"),
|
|
53
|
+
sessionId,
|
|
54
|
+
userId: this.getUserId?.(),
|
|
55
|
+
messageCount: messages.length,
|
|
56
|
+
});
|
|
57
|
+
}
|
|
45
58
|
const doRemember = () => {
|
|
46
59
|
// Re-evaluate userId at call time so retries use the resolved value
|
|
47
60
|
const userId = this.getUserId?.();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transcripts-sync.js","sourceRoot":"","sources":["../../../src/features/sync/transcripts-sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"transcripts-sync.js","sourceRoot":"","sources":["../../../src/features/sync/transcripts-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;
|
|
@@ -17,12 +18,13 @@ export declare class FileSyncWatcher {
|
|
|
17
18
|
private retryQueue?;
|
|
18
19
|
private options;
|
|
19
20
|
private getUserId?;
|
|
21
|
+
private auditLogger?;
|
|
20
22
|
private watchers;
|
|
21
23
|
private memoryMdSync;
|
|
22
24
|
private dailyLogsSync;
|
|
23
25
|
private transcriptsSync;
|
|
24
26
|
private started;
|
|
25
|
-
constructor(workspaceDir: string, client: CortexClient, sessionPrefix: string, logger: Logger, retryQueue?: RetryQueue | undefined, options?: FileSyncOptions, getUserId?: (() => string | undefined) | undefined);
|
|
27
|
+
constructor(workspaceDir: string, client: CortexClient, sessionPrefix: string, logger: Logger, retryQueue?: RetryQueue | undefined, options?: FileSyncOptions, getUserId?: (() => string | undefined) | undefined, auditLogger?: AuditLogger | undefined);
|
|
26
28
|
start(): void;
|
|
27
29
|
stop(): void;
|
|
28
30
|
private watchPath;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"watcher.d.ts","sourceRoot":"","sources":["../../../src/features/sync/watcher.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"watcher.d.ts","sourceRoot":"","sources":["../../../src/features/sync/watcher.ts"],"names":[],"mappings":"AAEA,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;AAKxE,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,MAAM,WAAW,eAAe;IAC9B,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,qBAAa,eAAe;IAQxB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU,CAAC;IACnB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,SAAS,CAAC;IAClB,OAAO,CAAC,WAAW,CAAC;IAdtB,OAAO,CAAC,QAAQ,CAAmB;IACnC,OAAO,CAAC,YAAY,CAA6B;IACjD,OAAO,CAAC,aAAa,CAA8B;IACnD,OAAO,CAAC,eAAe,CAAgC;IACvD,OAAO,CAAC,OAAO,CAAS;gBAGd,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,YAAY,EACpB,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,UAAU,YAAA,EACvB,OAAO,GAAE,eAAoB,EAC7B,SAAS,CAAC,GAAE,MAAM,MAAM,GAAG,SAAS,aAAA,EACpC,WAAW,CAAC,EAAE,WAAW,YAAA;IAGnC,KAAK,IAAI,IAAI;IA8Eb,IAAI,IAAI,IAAI;IAiBZ,OAAO,CAAC,SAAS;CAelB"}
|
|
@@ -11,12 +11,13 @@ export class FileSyncWatcher {
|
|
|
11
11
|
retryQueue;
|
|
12
12
|
options;
|
|
13
13
|
getUserId;
|
|
14
|
+
auditLogger;
|
|
14
15
|
watchers = [];
|
|
15
16
|
memoryMdSync = null;
|
|
16
17
|
dailyLogsSync = null;
|
|
17
18
|
transcriptsSync = null;
|
|
18
19
|
started = false;
|
|
19
|
-
constructor(workspaceDir, client, sessionPrefix, logger, retryQueue, options = {}, getUserId) {
|
|
20
|
+
constructor(workspaceDir, client, sessionPrefix, logger, retryQueue, options = {}, getUserId, auditLogger) {
|
|
20
21
|
this.workspaceDir = workspaceDir;
|
|
21
22
|
this.client = client;
|
|
22
23
|
this.sessionPrefix = sessionPrefix;
|
|
@@ -24,6 +25,7 @@ export class FileSyncWatcher {
|
|
|
24
25
|
this.retryQueue = retryQueue;
|
|
25
26
|
this.options = options;
|
|
26
27
|
this.getUserId = getUserId;
|
|
28
|
+
this.auditLogger = auditLogger;
|
|
27
29
|
}
|
|
28
30
|
start() {
|
|
29
31
|
if (this.started) {
|
|
@@ -34,8 +36,8 @@ export class FileSyncWatcher {
|
|
|
34
36
|
const memoryMdPath = join(this.workspaceDir, "MEMORY.md");
|
|
35
37
|
const memoryDir = join(this.workspaceDir, "memory");
|
|
36
38
|
const sessionsDir = join(this.workspaceDir, "sessions");
|
|
37
|
-
this.memoryMdSync = new MemoryMdSync(memoryMdPath, this.client, `${this.sessionPrefix}:memory-md`, this.logger, this.retryQueue, this.workspaceDir, this.getUserId);
|
|
38
|
-
this.dailyLogsSync = new DailyLogsSync(this.client, this.sessionPrefix, this.logger, this.retryQueue, memoryDir, this.getUserId);
|
|
39
|
+
this.memoryMdSync = new MemoryMdSync(memoryMdPath, this.client, `${this.sessionPrefix}:memory-md`, this.logger, this.retryQueue, this.workspaceDir, this.getUserId, this.auditLogger);
|
|
40
|
+
this.dailyLogsSync = new DailyLogsSync(this.client, this.sessionPrefix, this.logger, this.retryQueue, memoryDir, this.getUserId, this.auditLogger);
|
|
39
41
|
this.watchPath(memoryMdPath, () => {
|
|
40
42
|
this.memoryMdSync?.onFileChange();
|
|
41
43
|
}, "File sync: watching MEMORY.md", "File sync: MEMORY.md not found, skipping");
|
|
@@ -47,7 +49,7 @@ export class FileSyncWatcher {
|
|
|
47
49
|
}, "File sync: watching memory/*.md", "File sync: memory/ directory not found, skipping", { recursive: true });
|
|
48
50
|
// Watch sessions/*.jsonl (transcripts)
|
|
49
51
|
if (this.options.transcripts !== false) {
|
|
50
|
-
this.transcriptsSync = new TranscriptsSync(this.client, this.sessionPrefix, this.logger, this.retryQueue, sessionsDir, this.getUserId);
|
|
52
|
+
this.transcriptsSync = new TranscriptsSync(this.client, this.sessionPrefix, this.logger, this.retryQueue, sessionsDir, this.getUserId, this.auditLogger);
|
|
51
53
|
this.watchPath(sessionsDir, (_event, filename) => {
|
|
52
54
|
if (typeof filename !== "string" || !filename.endsWith(".jsonl"))
|
|
53
55
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"watcher.js","sourceRoot":"","sources":["../../../src/features/sync/watcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAkB,MAAM,SAAS,CAAC;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"watcher.js","sourceRoot":"","sources":["../../../src/features/sync/watcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
type Logger = {
|
|
2
|
+
debug?(...args: unknown[]): void;
|
|
3
|
+
info(...args: unknown[]): void;
|
|
4
|
+
warn(...args: unknown[]): void;
|
|
5
|
+
error(...args: unknown[]): void;
|
|
6
|
+
};
|
|
7
|
+
export interface AuditEntry {
|
|
8
|
+
feature: string;
|
|
9
|
+
method: string;
|
|
10
|
+
endpoint: string;
|
|
11
|
+
payload: string;
|
|
12
|
+
sessionId?: string;
|
|
13
|
+
userId?: string;
|
|
14
|
+
messageCount?: number;
|
|
15
|
+
}
|
|
16
|
+
export declare class AuditLogger {
|
|
17
|
+
private readonly logger;
|
|
18
|
+
private readonly auditDir;
|
|
19
|
+
private readonly payloadsDir;
|
|
20
|
+
private readonly indexPath;
|
|
21
|
+
private counter;
|
|
22
|
+
private initialized;
|
|
23
|
+
constructor(workspaceDir: string, logger: Logger);
|
|
24
|
+
log(entry: AuditEntry): Promise<void>;
|
|
25
|
+
private rotateIfNeeded;
|
|
26
|
+
}
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=audit-logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-logger.d.ts","sourceRoot":"","sources":["../../../src/internal/audit/audit-logger.ts"],"names":[],"mappings":"AAGA,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,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAID,qBAAa,WAAW;IASpB,OAAO,CAAC,QAAQ,CAAC,MAAM;IARzB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,WAAW,CAAS;gBAG1B,YAAY,EAAE,MAAM,EACH,MAAM,EAAE,MAAM;IAO3B,GAAG,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;YAoC7B,cAAc;CAW7B"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { mkdir, appendFile, writeFile, stat, rename } from "node:fs/promises";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
const MAX_INDEX_BYTES = 5 * 1024 * 1024; // 5MB
|
|
4
|
+
export class AuditLogger {
|
|
5
|
+
logger;
|
|
6
|
+
auditDir;
|
|
7
|
+
payloadsDir;
|
|
8
|
+
indexPath;
|
|
9
|
+
counter = 0;
|
|
10
|
+
initialized = false;
|
|
11
|
+
constructor(workspaceDir, logger) {
|
|
12
|
+
this.logger = logger;
|
|
13
|
+
this.auditDir = join(workspaceDir, ".cortex", "audit");
|
|
14
|
+
this.payloadsDir = join(this.auditDir, "payloads");
|
|
15
|
+
this.indexPath = join(this.auditDir, "index.jsonl");
|
|
16
|
+
}
|
|
17
|
+
async log(entry) {
|
|
18
|
+
try {
|
|
19
|
+
if (!this.initialized) {
|
|
20
|
+
await mkdir(this.payloadsDir, { recursive: true });
|
|
21
|
+
this.initialized = true;
|
|
22
|
+
}
|
|
23
|
+
const ts = new Date().toISOString();
|
|
24
|
+
const seq = String(++this.counter).padStart(3, "0");
|
|
25
|
+
const payloadFilename = `${ts.replace(/[:.]/g, "")}-${seq}.txt`;
|
|
26
|
+
const payloadPath = join(this.payloadsDir, payloadFilename);
|
|
27
|
+
await writeFile(payloadPath, entry.payload, { encoding: "utf-8", mode: 0o600 });
|
|
28
|
+
const indexLine = {
|
|
29
|
+
ts,
|
|
30
|
+
feature: entry.feature,
|
|
31
|
+
method: entry.method,
|
|
32
|
+
endpoint: entry.endpoint,
|
|
33
|
+
bytes: Buffer.byteLength(entry.payload, "utf-8"),
|
|
34
|
+
sessionId: entry.sessionId,
|
|
35
|
+
userId: entry.userId,
|
|
36
|
+
payloadFile: payloadFilename,
|
|
37
|
+
};
|
|
38
|
+
if (entry.messageCount !== undefined) {
|
|
39
|
+
indexLine.msgs = entry.messageCount;
|
|
40
|
+
}
|
|
41
|
+
await appendFile(this.indexPath, JSON.stringify(indexLine) + "\n", "utf-8");
|
|
42
|
+
await this.rotateIfNeeded();
|
|
43
|
+
}
|
|
44
|
+
catch (err) {
|
|
45
|
+
this.logger.warn(`Cortex audit log write failed: ${String(err)}`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async rotateIfNeeded() {
|
|
49
|
+
try {
|
|
50
|
+
const stats = await stat(this.indexPath);
|
|
51
|
+
if (stats.size > MAX_INDEX_BYTES) {
|
|
52
|
+
const rotatedPath = join(this.auditDir, `index.${Date.now()}.jsonl`);
|
|
53
|
+
await rename(this.indexPath, rotatedPath);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
// File may not exist yet or stat failed — ignore
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=audit-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-logger.js","sourceRoot":"","sources":["../../../src/internal/audit/audit-logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,6 +9,8 @@ export declare const CortexConfigSchema: z.ZodObject<{
|
|
|
9
9
|
toolTimeoutMs: z.ZodDefault<z.ZodNumber>;
|
|
10
10
|
fileSync: z.ZodDefault<z.ZodBoolean>;
|
|
11
11
|
transcriptSync: z.ZodDefault<z.ZodBoolean>;
|
|
12
|
+
captureMaxPayloadBytes: z.ZodDefault<z.ZodNumber>;
|
|
13
|
+
auditLog: z.ZodDefault<z.ZodBoolean>;
|
|
12
14
|
namespace: z.ZodDefault<z.ZodString>;
|
|
13
15
|
}, "strip", z.ZodTypeAny, {
|
|
14
16
|
baseUrl: string;
|
|
@@ -19,6 +21,8 @@ export declare const CortexConfigSchema: z.ZodObject<{
|
|
|
19
21
|
toolTimeoutMs: number;
|
|
20
22
|
fileSync: boolean;
|
|
21
23
|
transcriptSync: boolean;
|
|
24
|
+
captureMaxPayloadBytes: number;
|
|
25
|
+
auditLog: boolean;
|
|
22
26
|
namespace: string;
|
|
23
27
|
userId?: string | undefined;
|
|
24
28
|
}, {
|
|
@@ -31,6 +35,8 @@ export declare const CortexConfigSchema: z.ZodObject<{
|
|
|
31
35
|
toolTimeoutMs?: number | undefined;
|
|
32
36
|
fileSync?: boolean | undefined;
|
|
33
37
|
transcriptSync?: boolean | undefined;
|
|
38
|
+
captureMaxPayloadBytes?: number | undefined;
|
|
39
|
+
auditLog?: boolean | undefined;
|
|
34
40
|
namespace?: string | undefined;
|
|
35
41
|
}>;
|
|
36
42
|
export type CortexConfig = z.infer<typeof CortexConfigSchema>;
|
|
@@ -49,6 +55,8 @@ export declare const configSchema: {
|
|
|
49
55
|
toolTimeoutMs?: number | undefined;
|
|
50
56
|
fileSync?: boolean | undefined;
|
|
51
57
|
transcriptSync?: boolean | undefined;
|
|
58
|
+
captureMaxPayloadBytes?: number | undefined;
|
|
59
|
+
auditLog?: boolean | undefined;
|
|
52
60
|
namespace?: string | undefined;
|
|
53
61
|
}, {
|
|
54
62
|
baseUrl: string;
|
|
@@ -59,6 +67,8 @@ export declare const configSchema: {
|
|
|
59
67
|
toolTimeoutMs: number;
|
|
60
68
|
fileSync: boolean;
|
|
61
69
|
transcriptSync: boolean;
|
|
70
|
+
captureMaxPayloadBytes: number;
|
|
71
|
+
auditLog: boolean;
|
|
62
72
|
namespace: string;
|
|
63
73
|
userId?: string | undefined;
|
|
64
74
|
}>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/plugin/config/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAwBxB,eAAO,MAAM,kBAAkB
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/plugin/config/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAwBxB,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAe7B,CAAC;AAEH,MAAM,MAAM,YAAY,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAE9D;;;GAGG;AACH,eAAO,MAAM,YAAY;qBACN,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;CAGzB,CAAC"}
|
|
@@ -26,6 +26,8 @@ export const CortexConfigSchema = z.object({
|
|
|
26
26
|
toolTimeoutMs: z.number().int().min(1000).max(30000).default(10000),
|
|
27
27
|
fileSync: z.boolean().default(true),
|
|
28
28
|
transcriptSync: z.boolean().default(true),
|
|
29
|
+
captureMaxPayloadBytes: z.number().int().min(1024).max(1_048_576).default(262_144),
|
|
30
|
+
auditLog: z.boolean().default(false),
|
|
29
31
|
namespace: z.string().min(1).default("openclaw"),
|
|
30
32
|
});
|
|
31
33
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../src/plugin/config/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;GAEG;AACH,MAAM,QAAQ,GAAG,CAAC;KACf,MAAM,EAAE;KACR,GAAG,CAAC,6BAA6B,CAAC;KAClC,MAAM,CACL,CAAC,GAAG,EAAE,EAAE;IACN,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,IAAI,MAAM,CAAC,QAAQ,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAC9C,wDAAwD;IACxD,IACE,MAAM,CAAC,QAAQ,KAAK,OAAO;QAC3B,CAAC,MAAM,CAAC,QAAQ,KAAK,WAAW,IAAI,MAAM,CAAC,QAAQ,KAAK,WAAW,CAAC,EACpE,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,EACD,EAAE,OAAO,EAAE,0DAA0D,EAAE,CACxE,CAAC;AAEJ,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,OAAO,EAAE,QAAQ,CAAC,OAAO,CACvB,6DAA6D,CAC9D;IACD,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;IACpC,UAAU,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACrC,WAAW,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACtC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IACxD,eAAe,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACpE,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACnE,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACnC,cAAc,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACzC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;CACjD,CAAC,CAAC;AAIH;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,SAAS,CAAC,KAAc;QACtB,OAAO,kBAAkB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;CACF,CAAC"}
|
|
1
|
+
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../src/plugin/config/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;GAEG;AACH,MAAM,QAAQ,GAAG,CAAC;KACf,MAAM,EAAE;KACR,GAAG,CAAC,6BAA6B,CAAC;KAClC,MAAM,CACL,CAAC,GAAG,EAAE,EAAE;IACN,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,IAAI,MAAM,CAAC,QAAQ,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAC9C,wDAAwD;IACxD,IACE,MAAM,CAAC,QAAQ,KAAK,OAAO;QAC3B,CAAC,MAAM,CAAC,QAAQ,KAAK,WAAW,IAAI,MAAM,CAAC,QAAQ,KAAK,WAAW,CAAC,EACpE,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,EACD,EAAE,OAAO,EAAE,0DAA0D,EAAE,CACxE,CAAC;AAEJ,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,OAAO,EAAE,QAAQ,CAAC,OAAO,CACvB,6DAA6D,CAC9D;IACD,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;IACpC,UAAU,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACrC,WAAW,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACtC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IACxD,eAAe,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACpE,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACnE,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACnC,cAAc,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IACzC,sBAAsB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;IAClF,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACpC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;CACjD,CAAC,CAAC;AAIH;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,SAAS,CAAC,KAAc;QACtB,OAAO,kBAAkB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;CACF,CAAC"}
|
package/dist/plugin/index.d.ts
CHANGED
|
@@ -85,6 +85,8 @@ declare const plugin: {
|
|
|
85
85
|
toolTimeoutMs?: number | undefined;
|
|
86
86
|
fileSync?: boolean | undefined;
|
|
87
87
|
transcriptSync?: boolean | undefined;
|
|
88
|
+
captureMaxPayloadBytes?: number | undefined;
|
|
89
|
+
auditLog?: boolean | undefined;
|
|
88
90
|
namespace?: string | undefined;
|
|
89
91
|
}, {
|
|
90
92
|
baseUrl: string;
|
|
@@ -95,6 +97,8 @@ declare const plugin: {
|
|
|
95
97
|
toolTimeoutMs: number;
|
|
96
98
|
fileSync: boolean;
|
|
97
99
|
transcriptSync: boolean;
|
|
100
|
+
captureMaxPayloadBytes: number;
|
|
101
|
+
auditLog: boolean;
|
|
98
102
|
namespace: string;
|
|
99
103
|
userId?: string | undefined;
|
|
100
104
|
}>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/plugin/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/plugin/index.ts"],"names":[],"mappings":"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"}
|
package/dist/plugin/index.js
CHANGED
|
@@ -11,6 +11,7 @@ import { LatencyMetrics } from "../internal/metrics/latency-metrics.js";
|
|
|
11
11
|
import { loadOrCreateUserId } from "../internal/identity/user-id.js";
|
|
12
12
|
import { BAKED_API_KEY } from "../internal/identity/api-key.js";
|
|
13
13
|
import { formatMemories } from "../features/recall/formatter.js";
|
|
14
|
+
import { AuditLogger } from "../internal/audit/audit-logger.js";
|
|
14
15
|
export function deriveTier(totalSessions) {
|
|
15
16
|
if (totalSessions >= 30)
|
|
16
17
|
return 3;
|
|
@@ -112,6 +113,16 @@ const plugin = {
|
|
|
112
113
|
let namespace = config.namespace;
|
|
113
114
|
let started = false;
|
|
114
115
|
let watcher = null;
|
|
116
|
+
// Audit logger is created lazily in start(ctx) when workspaceDir is available,
|
|
117
|
+
// or on-demand via the /audit command. The proxy always exists so handlers can
|
|
118
|
+
// start logging without a restart when toggled on at runtime.
|
|
119
|
+
let auditLoggerInner;
|
|
120
|
+
let workspaceDirResolved;
|
|
121
|
+
const auditLoggerProxy = {
|
|
122
|
+
log(entry) {
|
|
123
|
+
return auditLoggerInner?.log(entry) ?? Promise.resolve();
|
|
124
|
+
},
|
|
125
|
+
};
|
|
115
126
|
// userId: use explicit config value if provided, otherwise load/create a
|
|
116
127
|
// stable UUID persisted at ~/.openclaw/cortex-user-id. Bootstrap is chained
|
|
117
128
|
// off the same promise so it always runs with a resolved userId. The capture
|
|
@@ -133,16 +144,30 @@ const plugin = {
|
|
|
133
144
|
api.logger.info(`Cortex user ID (from config): ${userId}`);
|
|
134
145
|
}
|
|
135
146
|
api.logger.info(`Cortex plugin registered (namespace=${namespace})`);
|
|
147
|
+
// First-run data disclosure — log what features are active so users know
|
|
148
|
+
// what data will be sent to the Cortex API.
|
|
149
|
+
const activeFeatures = [];
|
|
150
|
+
if (config.autoRecall)
|
|
151
|
+
activeFeatures.push("auto-recall (sends prompts)");
|
|
152
|
+
if (config.autoCapture)
|
|
153
|
+
activeFeatures.push("auto-capture (sends conversation transcripts)");
|
|
154
|
+
if (config.fileSync)
|
|
155
|
+
activeFeatures.push("file-sync (sends MEMORY.md and daily log changes)");
|
|
156
|
+
if (config.transcriptSync)
|
|
157
|
+
activeFeatures.push("transcript-sync (sends session transcripts)");
|
|
158
|
+
if (activeFeatures.length > 0) {
|
|
159
|
+
api.logger.info(`Cortex data features active: ${activeFeatures.join(", ")}. All data sent over HTTPS to ${config.baseUrl}. See README for details.`);
|
|
160
|
+
}
|
|
136
161
|
// Async health check + knowledge probe — chained after userId resolves
|
|
137
162
|
void userIdReady.then(() => bootstrapClient(client, api.logger, knowledgeState, userId));
|
|
138
163
|
// --- Hooks ---
|
|
139
164
|
// Auto-Recall: inject relevant memories before every agent turn
|
|
140
|
-
registerHookCompat(api, "before_agent_start", createRecallHandler(client, config, api.logger, recallMetrics, knowledgeState, () => userId), {
|
|
165
|
+
registerHookCompat(api, "before_agent_start", createRecallHandler(client, config, api.logger, recallMetrics, knowledgeState, () => userId, auditLoggerProxy), {
|
|
141
166
|
name: "openclaw-cortex.recall",
|
|
142
167
|
description: "Inject relevant Cortex memories before agent turn",
|
|
143
168
|
});
|
|
144
169
|
// Auto-Capture: extract facts after agent responses
|
|
145
|
-
registerHookCompat(api, "agent_end", createCaptureHandler(client, config, api.logger, retryQueue, knowledgeState, () => userId, userIdReady, sessionId), {
|
|
170
|
+
registerHookCompat(api, "agent_end", createCaptureHandler(client, config, api.logger, retryQueue, knowledgeState, () => userId, userIdReady, sessionId, auditLoggerProxy), {
|
|
146
171
|
name: "openclaw-cortex.capture",
|
|
147
172
|
description: "Extract and store facts from conversation after agent turn",
|
|
148
173
|
});
|
|
@@ -172,6 +197,13 @@ const plugin = {
|
|
|
172
197
|
api.logger.info(`Cortex tool: cortex_search_memory called (query="${query.slice(0, 80)}", limit=${limit})`);
|
|
173
198
|
if (userIdReady)
|
|
174
199
|
await userIdReady;
|
|
200
|
+
void auditLoggerProxy.log({
|
|
201
|
+
feature: "tool-search-memory",
|
|
202
|
+
method: "POST",
|
|
203
|
+
endpoint: "/v1/recall",
|
|
204
|
+
payload: query,
|
|
205
|
+
userId,
|
|
206
|
+
});
|
|
175
207
|
try {
|
|
176
208
|
const response = await client.recall(query, config.toolTimeoutMs, {
|
|
177
209
|
limit,
|
|
@@ -213,6 +245,14 @@ const plugin = {
|
|
|
213
245
|
api.logger.info(`Cortex tool: cortex_save_memory called (text="${text.slice(0, 80)}")`);
|
|
214
246
|
if (userIdReady)
|
|
215
247
|
await userIdReady;
|
|
248
|
+
void auditLoggerProxy.log({
|
|
249
|
+
feature: "tool-save-memory",
|
|
250
|
+
method: "POST",
|
|
251
|
+
endpoint: "/v1/remember",
|
|
252
|
+
payload: text,
|
|
253
|
+
sessionId,
|
|
254
|
+
userId,
|
|
255
|
+
});
|
|
216
256
|
try {
|
|
217
257
|
const res = await client.remember(text, sessionId, undefined, new Date().toISOString(), userId);
|
|
218
258
|
if (knowledgeState && res.memories_created > 0) {
|
|
@@ -279,6 +319,13 @@ const plugin = {
|
|
|
279
319
|
}
|
|
280
320
|
}
|
|
281
321
|
// With args — search memories
|
|
322
|
+
void auditLoggerProxy.log({
|
|
323
|
+
feature: "command-memories",
|
|
324
|
+
method: "POST",
|
|
325
|
+
endpoint: "/v1/recall",
|
|
326
|
+
payload: query,
|
|
327
|
+
userId,
|
|
328
|
+
});
|
|
282
329
|
try {
|
|
283
330
|
const response = await client.recall(query, config.toolTimeoutMs, {
|
|
284
331
|
limit: config.recallLimit,
|
|
@@ -296,7 +343,46 @@ const plugin = {
|
|
|
296
343
|
}
|
|
297
344
|
},
|
|
298
345
|
});
|
|
299
|
-
api.
|
|
346
|
+
api.registerCommand({
|
|
347
|
+
name: "audit",
|
|
348
|
+
description: "Toggle or check Cortex audit log (records all data sent to Cortex)",
|
|
349
|
+
acceptsArgs: true,
|
|
350
|
+
handler: (ctx) => {
|
|
351
|
+
const arg = ctx.args?.trim().toLowerCase();
|
|
352
|
+
if (arg === "on") {
|
|
353
|
+
if (!workspaceDirResolved) {
|
|
354
|
+
return { text: "Cannot enable audit log — no workspace directory available." };
|
|
355
|
+
}
|
|
356
|
+
if (auditLoggerInner) {
|
|
357
|
+
return { text: `Audit log is already on.\nLog path: ${workspaceDirResolved}/.cortex/audit/` };
|
|
358
|
+
}
|
|
359
|
+
auditLoggerInner = new AuditLogger(workspaceDirResolved, api.logger);
|
|
360
|
+
api.logger.info(`Cortex audit log enabled via command: ${workspaceDirResolved}/.cortex/audit/`);
|
|
361
|
+
return { text: `Audit log enabled.\nLog path: ${workspaceDirResolved}/.cortex/audit/` };
|
|
362
|
+
}
|
|
363
|
+
if (arg === "off") {
|
|
364
|
+
if (!auditLoggerInner) {
|
|
365
|
+
return { text: "Audit log is already off." };
|
|
366
|
+
}
|
|
367
|
+
auditLoggerInner = undefined;
|
|
368
|
+
api.logger.info("Cortex audit log disabled via command");
|
|
369
|
+
return { text: "Audit log disabled. Existing log files are preserved." };
|
|
370
|
+
}
|
|
371
|
+
// No args — show status
|
|
372
|
+
const status = auditLoggerInner ? "on" : "off";
|
|
373
|
+
const lines = [
|
|
374
|
+
`**Cortex Audit Log**`,
|
|
375
|
+
`- Status: ${status}`,
|
|
376
|
+
`- Config default: ${config.auditLog ? "on" : "off"}`,
|
|
377
|
+
];
|
|
378
|
+
if (workspaceDirResolved) {
|
|
379
|
+
lines.push(`- Log path: ${workspaceDirResolved}/.cortex/audit/`);
|
|
380
|
+
}
|
|
381
|
+
lines.push("", "Usage: `/audit on` · `/audit off`");
|
|
382
|
+
return { text: lines.join("\n") };
|
|
383
|
+
},
|
|
384
|
+
});
|
|
385
|
+
api.logger.info("Cortex commands registered: /memories, /audit");
|
|
300
386
|
}
|
|
301
387
|
// --- Gateway RPC ---
|
|
302
388
|
if (api.registerGatewayMethod) {
|
|
@@ -335,6 +421,13 @@ const plugin = {
|
|
|
335
421
|
}
|
|
336
422
|
started = true;
|
|
337
423
|
retryQueue.start();
|
|
424
|
+
// Capture workspaceDir for runtime audit toggle via /audit command
|
|
425
|
+
workspaceDirResolved = ctx.workspaceDir;
|
|
426
|
+
// Initialize audit logger if enabled via config
|
|
427
|
+
if (config.auditLog && ctx.workspaceDir) {
|
|
428
|
+
auditLoggerInner = new AuditLogger(ctx.workspaceDir, api.logger);
|
|
429
|
+
api.logger.info(`Cortex audit log enabled: ${ctx.workspaceDir}/.cortex/audit/`);
|
|
430
|
+
}
|
|
338
431
|
// Derive workspace-scoped namespace when user didn't set one explicitly
|
|
339
432
|
if (!userSetNamespace && ctx.workspaceDir) {
|
|
340
433
|
namespace = deriveNamespace(ctx.workspaceDir);
|
|
@@ -347,7 +440,7 @@ const plugin = {
|
|
|
347
440
|
api.logger.warn("Cortex file sync: no workspaceDir, skipping");
|
|
348
441
|
}
|
|
349
442
|
else {
|
|
350
|
-
const newWatcher = new FileSyncWatcher(workspaceDir, client, namespace, api.logger, retryQueue, { transcripts: config.transcriptSync }, () => userId);
|
|
443
|
+
const newWatcher = new FileSyncWatcher(workspaceDir, client, namespace, api.logger, retryQueue, { transcripts: config.transcriptSync }, () => userId, auditLoggerProxy);
|
|
351
444
|
newWatcher.start();
|
|
352
445
|
watcher = newWatcher;
|
|
353
446
|
api.logger.info("Cortex file sync started");
|
package/dist/plugin/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/plugin/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/plugin/index.ts"],"names":[],"mappings":"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"}
|
package/openclaw.plugin.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"id": "openclaw-cortex",
|
|
3
3
|
"name": "Cortex Memory",
|
|
4
4
|
"description": "Long-term memory powered by Cortex — Auto-Recall, Auto-Capture, agent tools, /memories command, transcript ingestion, and background file sync",
|
|
5
|
-
"version": "
|
|
5
|
+
"version": "1.1.0",
|
|
6
6
|
"kind": "memory",
|
|
7
7
|
"configSchema": {
|
|
8
8
|
"type": "object",
|
|
@@ -46,6 +46,21 @@
|
|
|
46
46
|
"description": "Watch sessions/*.jsonl and ingest cleaned transcripts",
|
|
47
47
|
"default": true
|
|
48
48
|
},
|
|
49
|
+
"toolTimeoutMs": {
|
|
50
|
+
"type": "number",
|
|
51
|
+
"description": "Timeout for explicit tool calls and /memories search (ms)",
|
|
52
|
+
"default": 10000
|
|
53
|
+
},
|
|
54
|
+
"captureMaxPayloadBytes": {
|
|
55
|
+
"type": "number",
|
|
56
|
+
"description": "Max byte size of capture payloads. Oversized transcripts are trimmed from oldest messages.",
|
|
57
|
+
"default": 262144
|
|
58
|
+
},
|
|
59
|
+
"auditLog": {
|
|
60
|
+
"type": "boolean",
|
|
61
|
+
"description": "Record all data sent to Cortex in a local audit log at .cortex/audit/",
|
|
62
|
+
"default": false
|
|
63
|
+
},
|
|
49
64
|
"namespace": {
|
|
50
65
|
"type": "string",
|
|
51
66
|
"description": "Session namespace to isolate memory per workspace/project. Auto-derived from workspace directory if not set.",
|
|
@@ -76,6 +91,20 @@
|
|
|
76
91
|
"label": "Transcript Sync",
|
|
77
92
|
"helpText": "Automatically ingest session transcripts (sessions/*.jsonl) after stripping system prompts and tool JSON."
|
|
78
93
|
},
|
|
94
|
+
"toolTimeoutMs": {
|
|
95
|
+
"label": "Tool Timeout (ms)",
|
|
96
|
+
"advanced": true,
|
|
97
|
+
"helpText": "Timeout for cortex_search_memory tool and /memories command searches."
|
|
98
|
+
},
|
|
99
|
+
"captureMaxPayloadBytes": {
|
|
100
|
+
"label": "Capture Max Payload Size",
|
|
101
|
+
"advanced": true,
|
|
102
|
+
"helpText": "Maximum byte size for capture payloads (default 256KB). Oversized transcripts are trimmed from oldest messages."
|
|
103
|
+
},
|
|
104
|
+
"auditLog": {
|
|
105
|
+
"label": "Audit Log",
|
|
106
|
+
"helpText": "Records every payload sent to Cortex at .cortex/audit/ in your workspace. Also toggleable at runtime via /audit on."
|
|
107
|
+
},
|
|
79
108
|
"namespace": {
|
|
80
109
|
"label": "Namespace",
|
|
81
110
|
"advanced": true,
|