@cleocode/adapters 2026.5.4 → 2026.5.5
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/package.json +4 -4
- package/dist/cant-context.js +0 -711
- package/dist/cant-context.js.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -222
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -159
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -428
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.js +0 -41
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.js +0 -310
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -41
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -198
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -130
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -119
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -29
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/claude-sdk/adapter.js +0 -88
- package/dist/providers/claude-sdk/adapter.js.map +0 -1
- package/dist/providers/claude-sdk/index.js +0 -34
- package/dist/providers/claude-sdk/index.js.map +0 -1
- package/dist/providers/claude-sdk/install.js +0 -61
- package/dist/providers/claude-sdk/install.js.map +0 -1
- package/dist/providers/claude-sdk/mcp-registry.js +0 -66
- package/dist/providers/claude-sdk/mcp-registry.js.map +0 -1
- package/dist/providers/claude-sdk/session-store.js +0 -84
- package/dist/providers/claude-sdk/session-store.js.map +0 -1
- package/dist/providers/claude-sdk/spawn.js +0 -251
- package/dist/providers/claude-sdk/spawn.js.map +0 -1
- package/dist/providers/claude-sdk/tool-bridge.js +0 -50
- package/dist/providers/claude-sdk/tool-bridge.js.map +0 -1
- package/dist/providers/codex/adapter.js +0 -146
- package/dist/providers/codex/adapter.js.map +0 -1
- package/dist/providers/codex/hooks.js +0 -113
- package/dist/providers/codex/hooks.js.map +0 -1
- package/dist/providers/codex/index.js +0 -40
- package/dist/providers/codex/index.js.map +0 -1
- package/dist/providers/codex/install.js +0 -132
- package/dist/providers/codex/install.js.map +0 -1
- package/dist/providers/codex/spawn.js +0 -203
- package/dist/providers/codex/spawn.js.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -151
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -208
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.js +0 -36
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.js +0 -281
- package/dist/providers/cursor/install.js.map +0 -1
- package/dist/providers/cursor/spawn.js +0 -59
- package/dist/providers/cursor/spawn.js.map +0 -1
- package/dist/providers/gemini-cli/adapter.js +0 -158
- package/dist/providers/gemini-cli/adapter.js.map +0 -1
- package/dist/providers/gemini-cli/hooks.js +0 -128
- package/dist/providers/gemini-cli/hooks.js.map +0 -1
- package/dist/providers/gemini-cli/index.js +0 -40
- package/dist/providers/gemini-cli/index.js.map +0 -1
- package/dist/providers/gemini-cli/install.js +0 -124
- package/dist/providers/gemini-cli/install.js.map +0 -1
- package/dist/providers/gemini-cli/spawn.js +0 -195
- package/dist/providers/gemini-cli/spawn.js.map +0 -1
- package/dist/providers/kimi/adapter.js +0 -145
- package/dist/providers/kimi/adapter.js.map +0 -1
- package/dist/providers/kimi/hooks.js +0 -79
- package/dist/providers/kimi/hooks.js.map +0 -1
- package/dist/providers/kimi/index.js +0 -40
- package/dist/providers/kimi/index.js.map +0 -1
- package/dist/providers/kimi/install.js +0 -124
- package/dist/providers/kimi/install.js.map +0 -1
- package/dist/providers/kimi/spawn.js +0 -225
- package/dist/providers/kimi/spawn.js.map +0 -1
- package/dist/providers/openai-sdk/adapter.js +0 -121
- package/dist/providers/openai-sdk/adapter.js.map +0 -1
- package/dist/providers/openai-sdk/guardrails.js +0 -174
- package/dist/providers/openai-sdk/guardrails.js.map +0 -1
- package/dist/providers/openai-sdk/handoff.js +0 -128
- package/dist/providers/openai-sdk/handoff.js.map +0 -1
- package/dist/providers/openai-sdk/index.js +0 -40
- package/dist/providers/openai-sdk/index.js.map +0 -1
- package/dist/providers/openai-sdk/install.js +0 -120
- package/dist/providers/openai-sdk/install.js.map +0 -1
- package/dist/providers/openai-sdk/spawn.js +0 -361
- package/dist/providers/openai-sdk/spawn.js.map +0 -1
- package/dist/providers/openai-sdk/tracing.js +0 -159
- package/dist/providers/openai-sdk/tracing.js.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -166
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -206
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.js +0 -37
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.js +0 -242
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -257
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/providers/pi/adapter.js +0 -220
- package/dist/providers/pi/adapter.js.map +0 -1
- package/dist/providers/pi/hooks.js +0 -223
- package/dist/providers/pi/hooks.js.map +0 -1
- package/dist/providers/pi/index.js +0 -38
- package/dist/providers/pi/index.js.map +0 -1
- package/dist/providers/pi/install.js +0 -183
- package/dist/providers/pi/install.js.map +0 -1
- package/dist/providers/pi/spawn.js +0 -187
- package/dist/providers/pi/spawn.js.map +0 -1
- package/dist/providers/shared/conduit-trace-writer.js +0 -65
- package/dist/providers/shared/conduit-trace-writer.js.map +0 -1
- package/dist/providers/shared/hook-template-installer.js +0 -209
- package/dist/providers/shared/hook-template-installer.js.map +0 -1
- package/dist/providers/shared/paths.js +0 -77
- package/dist/providers/shared/paths.js.map +0 -1
- package/dist/providers/shared/sdk-result-mapper.js +0 -55
- package/dist/providers/shared/sdk-result-mapper.js.map +0 -1
- package/dist/providers/shared/transcript-reader.js +0 -124
- package/dist/providers/shared/transcript-reader.js.map +0 -1
- package/dist/registry.js +0 -92
- package/dist/registry.js.map +0 -1
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Statusline integration for the Claude Code adapter.
|
|
3
|
-
*
|
|
4
|
-
* Implements the statusline portion of AdapterContextMonitorProvider.
|
|
5
|
-
* Checks and configures Claude Code status line for context monitoring.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { existsSync, readFileSync } from 'node:fs';
|
|
10
|
-
import { homedir } from 'node:os';
|
|
11
|
-
import { join } from 'node:path';
|
|
12
|
-
/**
|
|
13
|
-
* Get the path to Claude Code's settings.json.
|
|
14
|
-
* Respects CLAUDE_SETTINGS env var, defaults to ~/.claude/settings.json.
|
|
15
|
-
*/
|
|
16
|
-
function getClaudeSettingsPath() {
|
|
17
|
-
return (process.env['CLAUDE_SETTINGS'] ??
|
|
18
|
-
join(process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude'), 'settings.json'));
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Check if statusline integration is configured.
|
|
22
|
-
* Returns the current integration status.
|
|
23
|
-
*
|
|
24
|
-
* @remarks
|
|
25
|
-
* Reads Claude Code's settings.json and inspects the `statusLine` field
|
|
26
|
-
* to determine whether CLEO context monitoring is active.
|
|
27
|
-
*
|
|
28
|
-
* @returns One of: 'configured', 'not_configured', 'custom_no_cleo', 'no_settings'
|
|
29
|
-
*
|
|
30
|
-
* @example
|
|
31
|
-
* ```typescript
|
|
32
|
-
* import { checkStatuslineIntegration } from './statusline.js';
|
|
33
|
-
*
|
|
34
|
-
* const status = checkStatuslineIntegration();
|
|
35
|
-
* if (status === 'not_configured') {
|
|
36
|
-
* console.log('Run cleo install to set up context monitoring');
|
|
37
|
-
* }
|
|
38
|
-
* ```
|
|
39
|
-
*/
|
|
40
|
-
export function checkStatuslineIntegration() {
|
|
41
|
-
const settingsPath = getClaudeSettingsPath();
|
|
42
|
-
if (!existsSync(settingsPath))
|
|
43
|
-
return 'no_settings';
|
|
44
|
-
try {
|
|
45
|
-
const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
|
|
46
|
-
const statusLine = settings.statusLine;
|
|
47
|
-
if (!statusLine?.type)
|
|
48
|
-
return 'not_configured';
|
|
49
|
-
if (statusLine.type !== 'command')
|
|
50
|
-
return 'custom_no_cleo';
|
|
51
|
-
const cmd = statusLine.command ?? '';
|
|
52
|
-
// Check if it's a CLEO statusline integration
|
|
53
|
-
if (cmd.includes('context-monitor.sh') ||
|
|
54
|
-
cmd.includes('cleo-statusline') ||
|
|
55
|
-
cmd.includes('.context-state.json') ||
|
|
56
|
-
cmd.includes('context-states')) {
|
|
57
|
-
return 'configured';
|
|
58
|
-
}
|
|
59
|
-
// Check if the script writes to CLEO state file
|
|
60
|
-
const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;
|
|
61
|
-
if (existsSync(scriptPath)) {
|
|
62
|
-
try {
|
|
63
|
-
const content = readFileSync(scriptPath, 'utf-8');
|
|
64
|
-
if (content.includes('context-state.json'))
|
|
65
|
-
return 'configured';
|
|
66
|
-
}
|
|
67
|
-
catch {
|
|
68
|
-
/* unreadable */
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
return 'custom_no_cleo';
|
|
72
|
-
}
|
|
73
|
-
catch {
|
|
74
|
-
return 'no_settings';
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Get the statusline setup command for Claude Code settings.
|
|
79
|
-
*
|
|
80
|
-
* @remarks
|
|
81
|
-
* Returns a JSON-serializable object that can be merged into
|
|
82
|
-
* Claude Code's settings.json to enable context monitoring.
|
|
83
|
-
*
|
|
84
|
-
* @param cleoHome - Absolute path to the CLEO home directory
|
|
85
|
-
* @returns Settings object containing the statusLine configuration
|
|
86
|
-
*
|
|
87
|
-
* @example
|
|
88
|
-
* ```typescript
|
|
89
|
-
* import { getStatuslineConfig } from './statusline.js';
|
|
90
|
-
*
|
|
91
|
-
* const config = getStatuslineConfig('/home/user/.cleo');
|
|
92
|
-
* ```
|
|
93
|
-
*/
|
|
94
|
-
export function getStatuslineConfig(cleoHome) {
|
|
95
|
-
return {
|
|
96
|
-
statusLine: {
|
|
97
|
-
type: 'command',
|
|
98
|
-
command: join(cleoHome, 'lib', 'session', 'context-monitor.sh'),
|
|
99
|
-
},
|
|
100
|
-
};
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Get human-readable setup instructions.
|
|
104
|
-
*
|
|
105
|
-
* @remarks
|
|
106
|
-
* Returns a multi-line string with file path, JSON config, and explanation
|
|
107
|
-
* suitable for display to the user.
|
|
108
|
-
*
|
|
109
|
-
* @param cleoHome - Absolute path to the CLEO home directory
|
|
110
|
-
* @returns Formatted setup instructions string
|
|
111
|
-
*
|
|
112
|
-
* @example
|
|
113
|
-
* ```typescript
|
|
114
|
-
* import { getSetupInstructions } from './statusline.js';
|
|
115
|
-
*
|
|
116
|
-
* console.log(getSetupInstructions('/home/user/.cleo'));
|
|
117
|
-
* ```
|
|
118
|
-
*/
|
|
119
|
-
export function getSetupInstructions(cleoHome) {
|
|
120
|
-
const settingsPath = getClaudeSettingsPath();
|
|
121
|
-
return [
|
|
122
|
-
'To enable context monitoring, add to your Claude Code settings:',
|
|
123
|
-
`File: ${settingsPath}`,
|
|
124
|
-
'',
|
|
125
|
-
JSON.stringify(getStatuslineConfig(cleoHome), null, 2),
|
|
126
|
-
'',
|
|
127
|
-
'This enables real-time context window tracking in the CLI.',
|
|
128
|
-
].join('\n');
|
|
129
|
-
}
|
|
130
|
-
//# sourceMappingURL=statusline.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"statusline.js","sourceRoot":"","sources":["../../../src/providers/claude-code/statusline.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC;;;GAGG;AACH,SAAS,qBAAqB;IAC5B,OAAO,CACL,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,CAAC,EAAE,eAAe,CAAC,CAChF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,0BAA0B;IACxC,MAAM,YAAY,GAAG,qBAAqB,EAAE,CAAC;IAE7C,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;QAAE,OAAO,aAAa,CAAC;IAEpD,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC;QACjE,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC;QAEvC,IAAI,CAAC,UAAU,EAAE,IAAI;YAAE,OAAO,gBAAgB,CAAC;QAC/C,IAAI,UAAU,CAAC,IAAI,KAAK,SAAS;YAAE,OAAO,gBAAgB,CAAC;QAE3D,MAAM,GAAG,GAAG,UAAU,CAAC,OAAO,IAAI,EAAE,CAAC;QAErC,8CAA8C;QAC9C,IACE,GAAG,CAAC,QAAQ,CAAC,oBAAoB,CAAC;YAClC,GAAG,CAAC,QAAQ,CAAC,iBAAiB,CAAC;YAC/B,GAAG,CAAC,QAAQ,CAAC,qBAAqB,CAAC;YACnC,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAC9B,CAAC;YACD,OAAO,YAAY,CAAC;QACtB,CAAC;QAED,gDAAgD;QAChD,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QAE3E,IAAI,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;gBAClD,IAAI,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC;oBAAE,OAAO,YAAY,CAAC;YAClE,CAAC;YAAC,MAAM,CAAC;gBACP,gBAAgB;YAClB,CAAC;QACH,CAAC;QAED,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,aAAa,CAAC;IACvB,CAAC;AACH,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,mBAAmB,CAAC,QAAgB;IAClD,OAAO;QACL,UAAU,EAAE;YACV,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,oBAAoB,CAAC;SAChE;KACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,oBAAoB,CAAC,QAAgB;IACnD,MAAM,YAAY,GAAG,qBAAqB,EAAE,CAAC;IAE7C,OAAO;QACL,iEAAiE;QACjE,SAAS,YAAY,EAAE;QACvB,EAAE;QACF,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;QACtD,EAAE;QACF,4DAA4D;KAC7D,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC"}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude Code TaskSyncProvider — bridges Claude's TodoWrite format
|
|
3
|
-
* to the provider-agnostic reconciliation system.
|
|
4
|
-
*
|
|
5
|
-
* All Claude Code / TodoWrite-specific parsing lives here.
|
|
6
|
-
* The core reconciliation engine never sees TodoWrite formats.
|
|
7
|
-
*/
|
|
8
|
-
import { readFile, stat } from 'node:fs/promises';
|
|
9
|
-
import { join } from 'node:path';
|
|
10
|
-
// ---------------------------------------------------------------------------
|
|
11
|
-
// Parsing helpers
|
|
12
|
-
// ---------------------------------------------------------------------------
|
|
13
|
-
/**
|
|
14
|
-
* Parse a CLEO task ID from TodoWrite content prefix: "[T001] ..." -> "T001".
|
|
15
|
-
*/
|
|
16
|
-
function parseTaskId(content) {
|
|
17
|
-
const match = content.match(/^\[T(\d+)\]/);
|
|
18
|
-
return match ? `T${match[1]}` : null;
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Strip ID and status prefixes from content to extract the clean title.
|
|
22
|
-
*/
|
|
23
|
-
function stripPrefixes(content) {
|
|
24
|
-
return content
|
|
25
|
-
.replace(/^\[T\d+\]\s*/, '')
|
|
26
|
-
.replace(/^\[!\]\s*/, '')
|
|
27
|
-
.replace(/^\[BLOCKED\]\s*/, '');
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Map TodoWrite status to normalized ExternalTaskStatus.
|
|
31
|
-
*/
|
|
32
|
-
function mapStatus(twStatus) {
|
|
33
|
-
switch (twStatus) {
|
|
34
|
-
case 'completed':
|
|
35
|
-
return 'completed';
|
|
36
|
-
case 'in_progress':
|
|
37
|
-
return 'active';
|
|
38
|
-
case 'pending':
|
|
39
|
-
return 'pending';
|
|
40
|
-
default:
|
|
41
|
-
return 'pending';
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* Resolve the TodoWrite state file path.
|
|
46
|
-
* Claude Code writes its TodoWrite state to a known location.
|
|
47
|
-
*/
|
|
48
|
-
function getTodoWriteFilePath(projectDir) {
|
|
49
|
-
return join(projectDir, '.cleo', 'sync', 'todowrite-state.json');
|
|
50
|
-
}
|
|
51
|
-
// ---------------------------------------------------------------------------
|
|
52
|
-
// Provider implementation
|
|
53
|
-
// ---------------------------------------------------------------------------
|
|
54
|
-
/**
|
|
55
|
-
* Claude Code TaskSyncProvider.
|
|
56
|
-
*
|
|
57
|
-
* Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs
|
|
58
|
-
* and status, and returns normalized ExternalTask[].
|
|
59
|
-
*
|
|
60
|
-
* Optional: accepts a custom file path for testing.
|
|
61
|
-
*
|
|
62
|
-
* @remarks
|
|
63
|
-
* TodoWrite items with `[T001]`-style prefixes are mapped to their CLEO
|
|
64
|
-
* task IDs. Items without a prefix receive a synthetic `tw-new-N` ID
|
|
65
|
-
* for reconciliation. The provider reads from
|
|
66
|
-
* `.cleo/sync/todowrite-state.json` by default.
|
|
67
|
-
*/
|
|
68
|
-
export class ClaudeCodeTaskSyncProvider {
|
|
69
|
-
/** Optional override path for the TodoWrite state file (used in tests). */
|
|
70
|
-
customFilePath;
|
|
71
|
-
constructor(options) {
|
|
72
|
-
this.customFilePath = options?.filePath;
|
|
73
|
-
}
|
|
74
|
-
/** Retrieve external tasks from Claude's TodoWrite state file. */
|
|
75
|
-
async getExternalTasks(projectDir) {
|
|
76
|
-
const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);
|
|
77
|
-
// Check file exists
|
|
78
|
-
try {
|
|
79
|
-
await stat(filePath);
|
|
80
|
-
}
|
|
81
|
-
catch {
|
|
82
|
-
// No TodoWrite state — return empty (no tasks to sync)
|
|
83
|
-
return [];
|
|
84
|
-
}
|
|
85
|
-
// Parse the TodoWrite JSON
|
|
86
|
-
const raw = await readFile(filePath, 'utf-8');
|
|
87
|
-
let state;
|
|
88
|
-
try {
|
|
89
|
-
state = JSON.parse(raw);
|
|
90
|
-
}
|
|
91
|
-
catch {
|
|
92
|
-
return []; // Malformed JSON — treat as empty
|
|
93
|
-
}
|
|
94
|
-
if (!state.todos || !Array.isArray(state.todos)) {
|
|
95
|
-
return [];
|
|
96
|
-
}
|
|
97
|
-
const tasks = [];
|
|
98
|
-
let syntheticIndex = 0;
|
|
99
|
-
for (const item of state.todos) {
|
|
100
|
-
const cleoTaskId = parseTaskId(item.content);
|
|
101
|
-
const title = cleoTaskId ? stripPrefixes(item.content).trim() : item.content.trim();
|
|
102
|
-
if (!title)
|
|
103
|
-
continue;
|
|
104
|
-
tasks.push({
|
|
105
|
-
externalId: cleoTaskId ?? `tw-new-${syntheticIndex++}`,
|
|
106
|
-
title,
|
|
107
|
-
status: mapStatus(item.status),
|
|
108
|
-
providerMeta: {
|
|
109
|
-
source: 'todowrite',
|
|
110
|
-
cleoTaskId,
|
|
111
|
-
activeForm: item.activeForm,
|
|
112
|
-
rawContent: item.content,
|
|
113
|
-
},
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
return tasks;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
//# sourceMappingURL=task-sync.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"task-sync.js","sourceRoot":"","sources":["../../../src/providers/claude-code/task-sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Transport provider for the Claude Code adapter.
|
|
3
|
-
*
|
|
4
|
-
* Implements AdapterTransportProvider to supply Claude Code's
|
|
5
|
-
* native inter-agent transport mechanism.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
/**
|
|
10
|
-
* Transport provider for Claude Code inter-agent communication.
|
|
11
|
-
*
|
|
12
|
-
* @remarks
|
|
13
|
-
* Currently returns null from {@link createTransport} because actual transport
|
|
14
|
-
* creation is handled by the signaldock factory which checks for this adapter's
|
|
15
|
-
* transport capability flag. Full wiring will be completed in Phase 5 of the
|
|
16
|
-
* adapter system rollout.
|
|
17
|
-
*/
|
|
18
|
-
export class ClaudeCodeTransportProvider {
|
|
19
|
-
/** Provider-specific transport name used for capability negotiation. */
|
|
20
|
-
transportName = 'claude-code';
|
|
21
|
-
/** Create a transport instance for inter-agent messaging. */
|
|
22
|
-
createTransport() {
|
|
23
|
-
// Returns null — actual transport creation is handled by the signaldock factory
|
|
24
|
-
// which checks for this adapter's transport capability.
|
|
25
|
-
// Full wiring will be completed in Phase 5.
|
|
26
|
-
return null;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
//# sourceMappingURL=transport.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH;;;;;;;;GAQG;AACH,MAAM,OAAO,2BAA2B;IACtC,wEAAwE;IAC/D,aAAa,GAAG,aAAa,CAAC;IAEvC,6DAA6D;IAC7D,eAAe;QACb,gFAAgF;QAChF,wDAAwD;QACxD,4CAA4C;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude SDK provider adapter.
|
|
3
|
-
*
|
|
4
|
-
* Wraps {@link ClaudeSDKSpawnProvider} in the standard
|
|
5
|
-
* {@link CLEOProviderAdapter} contract so registry and sovereignty probes can
|
|
6
|
-
* treat the SDK-backed Claude provider like every other CLEO provider.
|
|
7
|
-
*
|
|
8
|
-
* @task T933
|
|
9
|
-
* @packageDocumentation
|
|
10
|
-
*/
|
|
11
|
-
import { ClaudeSDKInstallProvider } from './install.js';
|
|
12
|
-
import { ClaudeSDKSpawnProvider } from './spawn.js';
|
|
13
|
-
/**
|
|
14
|
-
* CLEO provider adapter for Anthropic Claude via the Vercel AI SDK.
|
|
15
|
-
*
|
|
16
|
-
* @remarks
|
|
17
|
-
* This adapter intentionally exposes spawn only. Hooks, instruction files, and
|
|
18
|
-
* provider-native paths belong to CLI providers such as `claude-code`; the SDK
|
|
19
|
-
* provider is the programmatic LLM bridge used when `provider.claude.mode` is
|
|
20
|
-
* configured as `sdk`.
|
|
21
|
-
*/
|
|
22
|
-
export class ClaudeSDKAdapter {
|
|
23
|
-
/** Unique provider identifier. */
|
|
24
|
-
id = 'claude-sdk';
|
|
25
|
-
/** Human-readable provider name. */
|
|
26
|
-
name = 'Claude SDK (Vercel AI SDK)';
|
|
27
|
-
/** Adapter version string. */
|
|
28
|
-
version = '2.0.0';
|
|
29
|
-
/** Declared capabilities for this provider. */
|
|
30
|
-
capabilities = {
|
|
31
|
-
supportsHooks: false,
|
|
32
|
-
supportedHookEvents: [],
|
|
33
|
-
supportsSpawn: true,
|
|
34
|
-
supportsInstall: false,
|
|
35
|
-
supportsInstructionFiles: false,
|
|
36
|
-
supportsContextMonitor: false,
|
|
37
|
-
supportsStatusline: false,
|
|
38
|
-
supportsProviderPaths: false,
|
|
39
|
-
supportsTransport: false,
|
|
40
|
-
supportsTaskSync: false,
|
|
41
|
-
};
|
|
42
|
-
/** Spawn provider for SDK-backed Claude runs. */
|
|
43
|
-
spawn;
|
|
44
|
-
/** No-op install provider required by the adapter contract. */
|
|
45
|
-
install;
|
|
46
|
-
projectDir = null;
|
|
47
|
-
initialized = false;
|
|
48
|
-
constructor() {
|
|
49
|
-
this.spawn = new ClaudeSDKSpawnProvider();
|
|
50
|
-
this.install = new ClaudeSDKInstallProvider();
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Initialize the adapter for a project directory.
|
|
54
|
-
*
|
|
55
|
-
* @param projectDir - Root directory of the project using this adapter.
|
|
56
|
-
*/
|
|
57
|
-
async initialize(projectDir) {
|
|
58
|
-
this.projectDir = projectDir;
|
|
59
|
-
this.initialized = true;
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Dispose the adapter and clear tracked project state.
|
|
63
|
-
*/
|
|
64
|
-
async dispose() {
|
|
65
|
-
this.projectDir = null;
|
|
66
|
-
this.initialized = false;
|
|
67
|
-
}
|
|
68
|
-
/**
|
|
69
|
-
* Check whether SDK-backed spawning can run in the current environment.
|
|
70
|
-
*
|
|
71
|
-
* @returns Adapter health with credential availability and initialization
|
|
72
|
-
* state.
|
|
73
|
-
*/
|
|
74
|
-
async healthCheck() {
|
|
75
|
-
const credentialsAvailable = await this.spawn.canSpawn();
|
|
76
|
-
return {
|
|
77
|
-
healthy: this.initialized && credentialsAvailable,
|
|
78
|
-
provider: this.id,
|
|
79
|
-
details: {
|
|
80
|
-
initialized: this.initialized,
|
|
81
|
-
credentialsAvailable,
|
|
82
|
-
projectDir: this.projectDir,
|
|
83
|
-
sdkVersion: 'ai@6 + @ai-sdk/anthropic',
|
|
84
|
-
},
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
//# sourceMappingURL=adapter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/claude-sdk/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAOH,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAEpD;;;;;;;;GAQG;AACH,MAAM,OAAO,gBAAgB;IAC3B,kCAAkC;IACzB,EAAE,GAAG,YAAY,CAAC;IAC3B,oCAAoC;IAC3B,IAAI,GAAG,4BAA4B,CAAC;IAC7C,8BAA8B;IACrB,OAAO,GAAG,OAAO,CAAC;IAE3B,+CAA+C;IAC/C,YAAY,GAAwB;QAClC,aAAa,EAAE,KAAK;QACpB,mBAAmB,EAAE,EAAE;QACvB,aAAa,EAAE,IAAI;QACnB,eAAe,EAAE,KAAK;QACtB,wBAAwB,EAAE,KAAK;QAC/B,sBAAsB,EAAE,KAAK;QAC7B,kBAAkB,EAAE,KAAK;QACzB,qBAAqB,EAAE,KAAK;QAC5B,iBAAiB,EAAE,KAAK;QACxB,gBAAgB,EAAE,KAAK;KACxB,CAAC;IAEF,iDAAiD;IACjD,KAAK,CAAyB;IAC9B,+DAA+D;IAC/D,OAAO,CAA2B;IAE1B,UAAU,GAAkB,IAAI,CAAC;IACjC,WAAW,GAAG,KAAK,CAAC;IAE5B;QACE,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAsB,EAAE,CAAC;QAC1C,IAAI,CAAC,OAAO,GAAG,IAAI,wBAAwB,EAAE,CAAC;IAChD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,UAAU,CAAC,UAAkB;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,oBAAoB,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACzD,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,WAAW,IAAI,oBAAoB;YACjD,QAAQ,EAAE,IAAI,CAAC,EAAE;YACjB,OAAO,EAAE;gBACP,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,oBAAoB;gBACpB,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,UAAU,EAAE,0BAA0B;aACvC;SACF,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @packageDocumentation
|
|
3
|
-
*
|
|
4
|
-
* Claude SDK spawn provider for CLEO — Vercel AI SDK edition.
|
|
5
|
-
*
|
|
6
|
-
* Uses `@ai-sdk/anthropic` via the Vercel AI SDK (`ai` v6) instead of the
|
|
7
|
-
* legacy `@anthropic-ai/claude-agent-sdk`. CLEO retains its own orchestration
|
|
8
|
-
* primitives (composeSpawnPayload, playbook runtime, agent registry); this
|
|
9
|
-
* provider exposes the LLM bridge for programmatic subagent execution with
|
|
10
|
-
* structured output and session tracking.
|
|
11
|
-
*
|
|
12
|
-
* Enabled via `provider.claude.mode = 'sdk'` in CLEO config.
|
|
13
|
-
*
|
|
14
|
-
* @task T581 (original)
|
|
15
|
-
* @task T933 (SDK consolidation — Vercel AI SDK migration)
|
|
16
|
-
* @see ADR-052 — SDK consolidation decision
|
|
17
|
-
*/
|
|
18
|
-
import { ClaudeSDKAdapter } from './adapter.js';
|
|
19
|
-
export { ClaudeSDKAdapter } from './adapter.js';
|
|
20
|
-
export { ClaudeSDKInstallProvider } from './install.js';
|
|
21
|
-
export { getServers } from './mcp-registry.js';
|
|
22
|
-
export { SessionStore } from './session-store.js';
|
|
23
|
-
export { ClaudeSDKSpawnProvider } from './spawn.js';
|
|
24
|
-
export { DEFAULT_TOOLS, resolveTools } from './tool-bridge.js';
|
|
25
|
-
export default ClaudeSDKAdapter;
|
|
26
|
-
/**
|
|
27
|
-
* Create a Claude SDK adapter instance for dynamic adapter loading.
|
|
28
|
-
*
|
|
29
|
-
* @returns A fresh {@link ClaudeSDKAdapter}.
|
|
30
|
-
*/
|
|
31
|
-
export function createAdapter() {
|
|
32
|
-
return new ClaudeSDKAdapter();
|
|
33
|
-
}
|
|
34
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/claude-sdk/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEhD,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAExD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAE/D,eAAe,gBAAgB,CAAC;AAEhC;;;;GAIG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,gBAAgB,EAAE,CAAC;AAChC,CAAC"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude SDK install provider.
|
|
3
|
-
*
|
|
4
|
-
* The Claude SDK adapter is a programmatic LLM bridge, not a native CLI
|
|
5
|
-
* integration surface. CLEO installation is therefore a no-op: project
|
|
6
|
-
* instruction files are managed by the active CLI provider (for example
|
|
7
|
-
* `claude-code`) while this provider supplies SDK-backed spawning.
|
|
8
|
-
*
|
|
9
|
-
* @task T933
|
|
10
|
-
* @packageDocumentation
|
|
11
|
-
*/
|
|
12
|
-
/**
|
|
13
|
-
* No-op install provider for the SDK-backed Claude provider.
|
|
14
|
-
*
|
|
15
|
-
* @remarks
|
|
16
|
-
* `CLEOProviderAdapter` requires an install provider. This implementation
|
|
17
|
-
* preserves that contract without pretending the Anthropic SDK has a native
|
|
18
|
-
* instruction-file or hook installation target.
|
|
19
|
-
*/
|
|
20
|
-
export class ClaudeSDKInstallProvider {
|
|
21
|
-
/**
|
|
22
|
-
* Report a successful no-op installation.
|
|
23
|
-
*
|
|
24
|
-
* @param options - Installation options. Currently accepted for contract
|
|
25
|
-
* parity and not mutated.
|
|
26
|
-
* @returns A successful install result with `instructionFileUpdated=false`.
|
|
27
|
-
*/
|
|
28
|
-
async install(options) {
|
|
29
|
-
return {
|
|
30
|
-
success: true,
|
|
31
|
-
installedAt: new Date().toISOString(),
|
|
32
|
-
instructionFileUpdated: false,
|
|
33
|
-
details: {
|
|
34
|
-
provider: 'claude-sdk',
|
|
35
|
-
projectDir: options.projectDir,
|
|
36
|
-
mode: 'programmatic-sdk',
|
|
37
|
-
},
|
|
38
|
-
};
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* No-op uninstall for the SDK provider.
|
|
42
|
-
*/
|
|
43
|
-
async uninstall() { }
|
|
44
|
-
/**
|
|
45
|
-
* Return true because the SDK provider requires no filesystem installation.
|
|
46
|
-
*
|
|
47
|
-
* @returns Always `true`.
|
|
48
|
-
*/
|
|
49
|
-
async isInstalled() {
|
|
50
|
-
return true;
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* No-op instruction-file reference hook.
|
|
54
|
-
*
|
|
55
|
-
* @param projectDir - Project directory accepted for interface parity.
|
|
56
|
-
*/
|
|
57
|
-
async ensureInstructionReferences(projectDir) {
|
|
58
|
-
void projectDir;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
//# sourceMappingURL=install.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/claude-sdk/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAIH;;;;;;;GAOG;AACH,MAAM,OAAO,wBAAwB;IACnC;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CAAC,OAAuB;QACnC,OAAO;YACL,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACrC,sBAAsB,EAAE,KAAK;YAC7B,OAAO,EAAE;gBACP,QAAQ,EAAE,YAAY;gBACtB,UAAU,EAAE,OAAO,CAAC,UAAU;gBAC9B,IAAI,EAAE,kBAAkB;aACzB;SACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAS,KAAmB,CAAC;IAEnC;;;;OAIG;IACH,KAAK,CAAC,WAAW;QACf,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,2BAA2B,CAAC,UAAkB;QAClD,KAAK,UAAU,CAAC;IAClB,CAAC;CACF"}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MCP Registry for Claude SDK Spawn Provider
|
|
3
|
-
*
|
|
4
|
-
* Resolves available CLEO MCP servers and returns their configurations in the
|
|
5
|
-
* format expected by the SDK's `mcpServers` option. Each server is represented
|
|
6
|
-
* as an `McpStdioServerConfig` (command + optional args/env).
|
|
7
|
-
*
|
|
8
|
-
* Resolution is best-effort: if a server binary cannot be found in PATH or
|
|
9
|
-
* `node_modules/.bin/`, it is silently omitted from the returned map. This
|
|
10
|
-
* ensures agents always spawn even when some MCP servers are unavailable.
|
|
11
|
-
*
|
|
12
|
-
* @task T581
|
|
13
|
-
*/
|
|
14
|
-
import { existsSync } from 'node:fs';
|
|
15
|
-
import { join } from 'node:path';
|
|
16
|
-
/** Known CLEO MCP servers, in resolution priority order. */
|
|
17
|
-
const CLEO_MCP_CANDIDATES = [
|
|
18
|
-
{ name: 'brain', binary: 'cleo-mcp-brain' },
|
|
19
|
-
{ name: 'nexus', binary: 'cleo-mcp-nexus' },
|
|
20
|
-
{ name: 'tasks', binary: 'cleo-mcp-tasks' },
|
|
21
|
-
];
|
|
22
|
-
/**
|
|
23
|
-
* Locate a binary in `node_modules/.bin/` relative to the given directory.
|
|
24
|
-
*
|
|
25
|
-
* @param binary - Executable name without path
|
|
26
|
-
* @param workingDir - Project root to resolve `.bin/` from
|
|
27
|
-
* @returns Absolute path if found, otherwise undefined
|
|
28
|
-
*/
|
|
29
|
-
function findInNodeModules(binary, workingDir) {
|
|
30
|
-
const binPath = join(workingDir, 'node_modules', '.bin', binary);
|
|
31
|
-
if (existsSync(binPath)) {
|
|
32
|
-
return binPath;
|
|
33
|
-
}
|
|
34
|
-
return undefined;
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Resolve available CLEO MCP servers for the given working directory.
|
|
38
|
-
*
|
|
39
|
-
* Checks each known CLEO MCP server candidate against `node_modules/.bin/`
|
|
40
|
-
* in the provided directory. Only servers whose binary can be located are
|
|
41
|
-
* included in the returned map.
|
|
42
|
-
*
|
|
43
|
-
* @param workingDirectory - Project root directory for binary resolution
|
|
44
|
-
* @returns Map of available server name to stdio config (may be empty)
|
|
45
|
-
*
|
|
46
|
-
* @example
|
|
47
|
-
* ```typescript
|
|
48
|
-
* const servers = getServers('/path/to/project');
|
|
49
|
-
* // { brain: { type: 'stdio', command: '/path/to/project/node_modules/.bin/cleo-mcp-brain' } }
|
|
50
|
-
* ```
|
|
51
|
-
*/
|
|
52
|
-
export function getServers(workingDirectory) {
|
|
53
|
-
const result = {};
|
|
54
|
-
for (const candidate of CLEO_MCP_CANDIDATES) {
|
|
55
|
-
const resolvedPath = findInNodeModules(candidate.binary, workingDirectory);
|
|
56
|
-
if (resolvedPath) {
|
|
57
|
-
result[candidate.name] = {
|
|
58
|
-
type: 'stdio',
|
|
59
|
-
command: resolvedPath,
|
|
60
|
-
...(candidate.args ? { args: candidate.args } : {}),
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
return result;
|
|
65
|
-
}
|
|
66
|
-
//# sourceMappingURL=mcp-registry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-registry.js","sourceRoot":"","sources":["../../../src/providers/claude-sdk/mcp-registry.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AA2BjC,4DAA4D;AAC5D,MAAM,mBAAmB,GAAkC;IACzD,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE;IAC3C,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE;IAC3C,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE;CACnC,CAAC;AAEX;;;;;;GAMG;AACH,SAAS,iBAAiB,CAAC,MAAc,EAAE,UAAkB;IAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACjE,IAAI,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QACxB,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,UAAU,UAAU,CAAC,gBAAwB;IACjD,MAAM,MAAM,GAAiB,EAAE,CAAC;IAEhC,KAAK,MAAM,SAAS,IAAI,mBAAmB,EAAE,CAAC;QAC5C,MAAM,YAAY,GAAG,iBAAiB,CAAC,SAAS,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAC3E,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG;gBACvB,IAAI,EAAE,OAAO;gBACb,OAAO,EAAE,YAAY;gBACrB,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aACpD,CAAC;QACJ,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Session Store for Claude SDK Spawn Provider
|
|
3
|
-
*
|
|
4
|
-
* Maintains an in-memory map of active SDK sessions keyed by instanceId.
|
|
5
|
-
* Each entry records the session ID returned by the SDK, the task ID, and
|
|
6
|
-
* the start time. Session IDs can be used with `options: { resume: sessionId }`
|
|
7
|
-
* in subsequent `query()` calls for multi-turn continuations.
|
|
8
|
-
*
|
|
9
|
-
* Persistence to conduit.db is intentionally deferred: the in-memory store
|
|
10
|
-
* is sufficient for single-process lifetimes and avoids coupling the spawn
|
|
11
|
-
* provider to the conduit subsystem at construction time.
|
|
12
|
-
*
|
|
13
|
-
* @task T581
|
|
14
|
-
*/
|
|
15
|
-
/**
|
|
16
|
-
* In-memory store for active Claude SDK sessions.
|
|
17
|
-
*
|
|
18
|
-
* Provides CRUD operations over a `Map<instanceId, SessionEntry>`.
|
|
19
|
-
* Thread-safe within a single Node.js process (single-threaded event loop).
|
|
20
|
-
*/
|
|
21
|
-
export class SessionStore {
|
|
22
|
-
store = new Map();
|
|
23
|
-
/**
|
|
24
|
-
* Register a new session entry.
|
|
25
|
-
*
|
|
26
|
-
* @param entry - The session entry to add
|
|
27
|
-
*/
|
|
28
|
-
add(entry) {
|
|
29
|
-
this.store.set(entry.instanceId, entry);
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Update the SDK session ID for an existing entry once it is received
|
|
33
|
-
* from the first SDK message.
|
|
34
|
-
*
|
|
35
|
-
* No-op if the instanceId is not found.
|
|
36
|
-
*
|
|
37
|
-
* @param instanceId - ID of the spawn instance
|
|
38
|
-
* @param sessionId - SDK-assigned session identifier
|
|
39
|
-
*/
|
|
40
|
-
setSessionId(instanceId, sessionId) {
|
|
41
|
-
const entry = this.store.get(instanceId);
|
|
42
|
-
if (entry) {
|
|
43
|
-
entry.sessionId = sessionId;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Retrieve an entry by instance ID.
|
|
48
|
-
*
|
|
49
|
-
* @param instanceId - ID of the spawn instance
|
|
50
|
-
* @returns The session entry, or undefined if not found
|
|
51
|
-
*/
|
|
52
|
-
get(instanceId) {
|
|
53
|
-
return this.store.get(instanceId);
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Remove an entry by instance ID.
|
|
57
|
-
*
|
|
58
|
-
* @param instanceId - ID of the spawn instance to remove
|
|
59
|
-
*/
|
|
60
|
-
remove(instanceId) {
|
|
61
|
-
this.store.delete(instanceId);
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* List all active session entries.
|
|
65
|
-
*
|
|
66
|
-
* @returns Array of all tracked session entries
|
|
67
|
-
*/
|
|
68
|
-
listActive() {
|
|
69
|
-
return Array.from(this.store.values());
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* Return the number of tracked sessions.
|
|
73
|
-
*/
|
|
74
|
-
size() {
|
|
75
|
-
return this.store.size;
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Clear all tracked sessions. Intended for testing only.
|
|
79
|
-
*/
|
|
80
|
-
clear() {
|
|
81
|
-
this.store.clear();
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
//# sourceMappingURL=session-store.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session-store.js","sourceRoot":"","sources":["../../../src/providers/claude-sdk/session-store.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAcH;;;;;GAKG;AACH,MAAM,OAAO,YAAY;IACN,KAAK,GAAG,IAAI,GAAG,EAAwB,CAAC;IAEzD;;;;OAIG;IACH,GAAG,CAAC,KAAmB;QACrB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;;;OAQG;IACH,YAAY,CAAC,UAAkB,EAAE,SAAiB;QAChD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACzC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;QAC9B,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,GAAG,CAAC,UAAkB;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,UAAkB;QACvB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACH,UAAU;QACR,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,IAAI;QACF,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;IACzB,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF"}
|