@cleocode/adapters 2026.4.42 → 2026.4.43

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.
Files changed (88) hide show
  1. package/dist/cant-context.d.ts +35 -0
  2. package/dist/cant-context.d.ts.map +1 -1
  3. package/dist/index.js +153 -37
  4. package/dist/index.js.map +3 -3
  5. package/dist/providers/claude-code/install.d.ts.map +1 -1
  6. package/package.json +7 -5
  7. package/src/cant-context.ts +210 -20
  8. package/src/providers/claude-code/install.ts +1 -5
  9. package/dist/cant-context.js +0 -284
  10. package/dist/cant-context.js.map +0 -1
  11. package/dist/providers/claude-code/adapter.js +0 -187
  12. package/dist/providers/claude-code/adapter.js.map +0 -1
  13. package/dist/providers/claude-code/context-monitor.js +0 -159
  14. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  15. package/dist/providers/claude-code/hooks.js +0 -389
  16. package/dist/providers/claude-code/hooks.js.map +0 -1
  17. package/dist/providers/claude-code/index.js +0 -41
  18. package/dist/providers/claude-code/index.js.map +0 -1
  19. package/dist/providers/claude-code/install.js +0 -199
  20. package/dist/providers/claude-code/install.js.map +0 -1
  21. package/dist/providers/claude-code/paths.js +0 -41
  22. package/dist/providers/claude-code/paths.js.map +0 -1
  23. package/dist/providers/claude-code/spawn.js +0 -185
  24. package/dist/providers/claude-code/spawn.js.map +0 -1
  25. package/dist/providers/claude-code/statusline.js +0 -130
  26. package/dist/providers/claude-code/statusline.js.map +0 -1
  27. package/dist/providers/claude-code/task-sync.js +0 -119
  28. package/dist/providers/claude-code/task-sync.js.map +0 -1
  29. package/dist/providers/claude-code/transport.js +0 -29
  30. package/dist/providers/claude-code/transport.js.map +0 -1
  31. package/dist/providers/codex/adapter.js +0 -146
  32. package/dist/providers/codex/adapter.js.map +0 -1
  33. package/dist/providers/codex/hooks.js +0 -113
  34. package/dist/providers/codex/hooks.js.map +0 -1
  35. package/dist/providers/codex/index.js +0 -39
  36. package/dist/providers/codex/index.js.map +0 -1
  37. package/dist/providers/codex/install.js +0 -124
  38. package/dist/providers/codex/install.js.map +0 -1
  39. package/dist/providers/cursor/adapter.js +0 -151
  40. package/dist/providers/cursor/adapter.js.map +0 -1
  41. package/dist/providers/cursor/hooks.js +0 -208
  42. package/dist/providers/cursor/hooks.js.map +0 -1
  43. package/dist/providers/cursor/index.js +0 -36
  44. package/dist/providers/cursor/index.js.map +0 -1
  45. package/dist/providers/cursor/install.js +0 -180
  46. package/dist/providers/cursor/install.js.map +0 -1
  47. package/dist/providers/cursor/spawn.js +0 -59
  48. package/dist/providers/cursor/spawn.js.map +0 -1
  49. package/dist/providers/gemini-cli/adapter.js +0 -158
  50. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  51. package/dist/providers/gemini-cli/hooks.js +0 -128
  52. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  53. package/dist/providers/gemini-cli/index.js +0 -39
  54. package/dist/providers/gemini-cli/index.js.map +0 -1
  55. package/dist/providers/gemini-cli/install.js +0 -124
  56. package/dist/providers/gemini-cli/install.js.map +0 -1
  57. package/dist/providers/kimi/adapter.js +0 -145
  58. package/dist/providers/kimi/adapter.js.map +0 -1
  59. package/dist/providers/kimi/hooks.js +0 -79
  60. package/dist/providers/kimi/hooks.js.map +0 -1
  61. package/dist/providers/kimi/index.js +0 -39
  62. package/dist/providers/kimi/index.js.map +0 -1
  63. package/dist/providers/kimi/install.js +0 -124
  64. package/dist/providers/kimi/install.js.map +0 -1
  65. package/dist/providers/opencode/adapter.js +0 -166
  66. package/dist/providers/opencode/adapter.js.map +0 -1
  67. package/dist/providers/opencode/hooks.js +0 -206
  68. package/dist/providers/opencode/hooks.js.map +0 -1
  69. package/dist/providers/opencode/index.js +0 -37
  70. package/dist/providers/opencode/index.js.map +0 -1
  71. package/dist/providers/opencode/install.js +0 -115
  72. package/dist/providers/opencode/install.js.map +0 -1
  73. package/dist/providers/opencode/spawn.js +0 -256
  74. package/dist/providers/opencode/spawn.js.map +0 -1
  75. package/dist/providers/pi/adapter.js +0 -220
  76. package/dist/providers/pi/adapter.js.map +0 -1
  77. package/dist/providers/pi/hooks.js +0 -223
  78. package/dist/providers/pi/hooks.js.map +0 -1
  79. package/dist/providers/pi/index.js +0 -38
  80. package/dist/providers/pi/index.js.map +0 -1
  81. package/dist/providers/pi/install.js +0 -175
  82. package/dist/providers/pi/install.js.map +0 -1
  83. package/dist/providers/pi/spawn.js +0 -187
  84. package/dist/providers/pi/spawn.js.map +0 -1
  85. package/dist/providers/shared/transcript-reader.js +0 -124
  86. package/dist/providers/shared/transcript-reader.js.map +0 -1
  87. package/dist/registry.js +0 -92
  88. package/dist/registry.js.map +0 -1
@@ -1,389 +0,0 @@
1
- /**
2
- * Claude Code Hook Provider
3
- *
4
- * Maps Claude Code's native hook events to CAAMP canonical hook events.
5
- * Claude Code supports 14 of 16 canonical events (all except PreModel, PostModel).
6
- *
7
- * Event translation uses CAAMP normalizer APIs:
8
- * - `toCanonical(nativeName, 'claude-code')` for runtime event name resolution
9
- * - `getSupportedEvents('claude-code')` to enumerate supported canonical events
10
- * - `getProviderHookProfile('claude-code')` for the full provider profile
11
- *
12
- * A static map derived from CAAMP 1.9.1 hook-mappings.json is maintained as
13
- * a fallback for environments where CAAMP's runtime resolution is unavailable.
14
- *
15
- * @task T164
16
- * @epic T134
17
- */
18
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
19
- import { readdir, readFile } from 'node:fs/promises';
20
- import { homedir } from 'node:os';
21
- import { join } from 'node:path';
22
- /** CAAMP provider identifier for Claude Code. */
23
- const PROVIDER_ID = 'claude-code';
24
- /**
25
- * Fallback map from Claude Code native event names to CAAMP canonical names.
26
- *
27
- * Derived from `getProviderHookProfile('claude-code').mappings` in CAAMP 1.9.1.
28
- * Covers all 14 supported events. PreModel and PostModel are not supported
29
- * by Claude Code and are absent from this map.
30
- *
31
- * Used as fallback when CAAMP runtime is unavailable, and as the synchronous
32
- * implementation of `mapProviderEvent()`.
33
- */
34
- const CLAUDE_CODE_EVENT_MAP = {
35
- // CAAMP: toNative('SessionStart', 'claude-code') = 'SessionStart'
36
- SessionStart: 'SessionStart',
37
- // CAAMP: toNative('SessionEnd', 'claude-code') = 'SessionEnd'
38
- SessionEnd: 'SessionEnd',
39
- // CAAMP: toNative('PromptSubmit', 'claude-code') = 'UserPromptSubmit'
40
- UserPromptSubmit: 'PromptSubmit',
41
- // CAAMP: toNative('ResponseComplete', 'claude-code') = 'Stop'
42
- Stop: 'ResponseComplete',
43
- // CAAMP: toNative('PreToolUse', 'claude-code') = 'PreToolUse'
44
- PreToolUse: 'PreToolUse',
45
- // CAAMP: toNative('PostToolUse', 'claude-code') = 'PostToolUse'
46
- PostToolUse: 'PostToolUse',
47
- // CAAMP: toNative('PostToolUseFailure','claude-code') = 'PostToolUseFailure'
48
- PostToolUseFailure: 'PostToolUseFailure',
49
- // CAAMP: toNative('PermissionRequest', 'claude-code') = 'PermissionRequest'
50
- PermissionRequest: 'PermissionRequest',
51
- // CAAMP: toNative('SubagentStart', 'claude-code') = 'SubagentStart'
52
- SubagentStart: 'SubagentStart',
53
- // CAAMP: toNative('SubagentStop', 'claude-code') = 'SubagentStop'
54
- SubagentStop: 'SubagentStop',
55
- // CAAMP: toNative('PreCompact', 'claude-code') = 'PreCompact'
56
- PreCompact: 'PreCompact',
57
- // CAAMP: toNative('PostCompact', 'claude-code') = 'PostCompact'
58
- PostCompact: 'PostCompact',
59
- // CAAMP: toNative('Notification', 'claude-code') = 'Notification'
60
- Notification: 'Notification',
61
- // CAAMP: toNative('ConfigChange', 'claude-code') = 'ConfigChange'
62
- ConfigChange: 'ConfigChange',
63
- };
64
- /**
65
- * Hook provider for Claude Code.
66
- *
67
- * Claude Code registers hooks via its global config at `~/.claude/settings.json`.
68
- * Supported handler types: command, http, prompt, agent.
69
- *
70
- * Event mapping is based on `getProviderHookProfile('claude-code')` from
71
- * CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
72
- * `getProviderProfile`) call CAAMP directly when available.
73
- *
74
- * Since hooks are registered through the config system (managed by the install
75
- * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
76
- * state without performing filesystem operations.
77
- *
78
- * @remarks
79
- * Claude Code is the only provider that supports all 14 of its declared
80
- * canonical events at runtime. The static event map is maintained as a
81
- * synchronous fallback; async methods like {@link getSupportedCanonicalEvents}
82
- * and {@link getProviderProfile} call CAAMP directly when available.
83
- *
84
- * @task T164
85
- * @epic T134
86
- */
87
- export class ClaudeCodeHookProvider {
88
- /** Whether hooks have been registered for the current session. */
89
- registered = false;
90
- /**
91
- * Map a Claude Code native event name to a CAAMP canonical hook event name.
92
- *
93
- * Looks up the native event name in the map derived from
94
- * `getProviderHookProfile('claude-code').mappings` (CAAMP 1.9.1).
95
- * Returns null for unrecognised events (e.g. PreModel, PostModel which
96
- * Claude Code does not support).
97
- *
98
- * @param providerEvent - Claude Code native event (e.g. "UserPromptSubmit", "Stop")
99
- * @returns CAAMP canonical event name, or null if unmapped
100
- * @task T164
101
- */
102
- mapProviderEvent(providerEvent) {
103
- return CLAUDE_CODE_EVENT_MAP[providerEvent] ?? null;
104
- }
105
- /** Project directory this hook provider was registered for. */
106
- projectDir = null;
107
- /**
108
- * Register native hooks for a project.
109
- *
110
- * Writes CLEO hook entries to `~/.claude/settings.json` so that Claude Code's
111
- * native event system calls cleo CLI commands when events fire. This bridges
112
- * Claude Code's event loop to CLEO's internal hook dispatch.
113
- *
114
- * Idempotent: skips writing if CLEO hooks already exist in settings.json.
115
- *
116
- * Hook entries registered:
117
- * - `Stop` → `cleo session end --quiet` (triggers LLM extraction, reflector, consolidation)
118
- * - `PostToolUse` (Write|Edit) → brain observation for file modifications
119
- * - `SubagentStop` → brain observation for agent completion
120
- *
121
- * @param projectDir - Project directory for context-scoped hook commands
122
- * @task T164 @task T555
123
- */
124
- async registerNativeHooks(projectDir) {
125
- this.projectDir = projectDir;
126
- this.registered = true;
127
- // Write CLEO hook entries to ~/.claude/settings.json (idempotent)
128
- try {
129
- const home = homedir();
130
- const settingsPath = join(home, '.claude', 'settings.json');
131
- let settings = {};
132
- if (existsSync(settingsPath)) {
133
- try {
134
- settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
135
- }
136
- catch {
137
- // Start fresh if settings.json is corrupt
138
- }
139
- }
140
- const hooks = (settings.hooks ?? {});
141
- // Check if CLEO hooks already registered (look for our marker comment in commands)
142
- const alreadyRegistered = Object.values(hooks).some((entries) => Array.isArray(entries) &&
143
- entries.some((e) => typeof e === 'object' &&
144
- e !== null &&
145
- Array.isArray(e.hooks) &&
146
- e.hooks.some((h) => typeof h.command === 'string' && h.command.includes('# cleo-hook'))));
147
- if (alreadyRegistered) {
148
- return; // Already wired — idempotent
149
- }
150
- // Register Stop hook → triggers cleo session end (LLM extraction, reflector, consolidation)
151
- if (!hooks.Stop)
152
- hooks.Stop = [];
153
- hooks.Stop.push({
154
- matcher: '',
155
- hooks: [
156
- {
157
- type: 'command',
158
- command: `cleo session end --quiet # cleo-hook`,
159
- },
160
- ],
161
- });
162
- // Register PostToolUse hook → brain observation for file writes
163
- if (!hooks.PostToolUse)
164
- hooks.PostToolUse = [];
165
- hooks.PostToolUse.push({
166
- matcher: 'Write|Edit',
167
- hooks: [
168
- {
169
- type: 'command',
170
- command: `cleo observe "File modified via $TOOL_NAME" --title "tool-use" --quiet # cleo-hook`,
171
- },
172
- ],
173
- });
174
- settings.hooks = hooks;
175
- mkdirSync(join(home, '.claude'), { recursive: true });
176
- writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
177
- }
178
- catch {
179
- // Settings write failure is non-fatal — hooks can be registered manually
180
- }
181
- }
182
- /**
183
- * Unregister native hooks.
184
- *
185
- * Removes CLEO hook entries from `~/.claude/settings.json` by filtering out
186
- * entries containing the `# cleo-hook` marker.
187
- *
188
- * @task T164 @task T555
189
- */
190
- async unregisterNativeHooks() {
191
- this.registered = false;
192
- this.projectDir = null;
193
- try {
194
- const home = homedir();
195
- const settingsPath = join(home, '.claude', 'settings.json');
196
- if (!existsSync(settingsPath))
197
- return;
198
- const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
199
- const hooks = settings.hooks;
200
- if (!hooks)
201
- return;
202
- // Filter out entries with the cleo-hook marker
203
- let changed = false;
204
- for (const [event, entries] of Object.entries(hooks)) {
205
- if (!Array.isArray(entries))
206
- continue;
207
- const filtered = entries.filter((e) => !(typeof e === 'object' &&
208
- e !== null &&
209
- Array.isArray(e.hooks) &&
210
- e.hooks.some((h) => typeof h.command === 'string' && h.command.includes('# cleo-hook'))));
211
- if (filtered.length !== entries.length) {
212
- hooks[event] = filtered;
213
- changed = true;
214
- }
215
- }
216
- if (changed) {
217
- settings.hooks = hooks;
218
- writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
219
- }
220
- }
221
- catch {
222
- // Cleanup failure is non-fatal
223
- }
224
- }
225
- /**
226
- * Check whether hooks have been registered via `registerNativeHooks`.
227
- */
228
- isRegistered() {
229
- return this.registered;
230
- }
231
- /**
232
- * Get the project directory this hook provider was registered for.
233
- *
234
- * Returns null if hooks have not been registered yet.
235
- */
236
- getProjectDir() {
237
- return this.projectDir;
238
- }
239
- /**
240
- * Get the native→canonical event mapping for introspection and debugging.
241
- *
242
- * Returns the map derived from `getProviderHookProfile('claude-code').mappings`
243
- * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
244
- * names via live CAAMP APIs.
245
- *
246
- * @returns Immutable record of native event name → canonical event name
247
- */
248
- getEventMap() {
249
- return { ...CLAUDE_CODE_EVENT_MAP };
250
- }
251
- /**
252
- * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
253
- *
254
- * Calls `getSupportedEvents('claude-code')` from the CAAMP normalizer to
255
- * get the authoritative list. Claude Code supports 14 of 16 canonical events
256
- * (PreModel and PostModel are not supported). Falls back to the values of
257
- * the static event map when CAAMP is unavailable at runtime.
258
- *
259
- * @returns Array of CAAMP canonical event names supported by Claude Code
260
- * @task T164
261
- */
262
- async getSupportedCanonicalEvents() {
263
- try {
264
- const { getSupportedEvents } = await import('@cleocode/caamp');
265
- return getSupportedEvents(PROVIDER_ID);
266
- }
267
- catch {
268
- return [...new Set(Object.values(CLAUDE_CODE_EVENT_MAP))];
269
- }
270
- }
271
- /**
272
- * Retrieve the full provider hook profile from CAAMP.
273
- *
274
- * Calls `getProviderHookProfile('claude-code')` from the CAAMP normalizer to
275
- * get the complete profile: hook system type (`config`), config path
276
- * (`~/.claude/settings.json`), handler types, and all event mappings.
277
- * Returns null when CAAMP is unavailable at runtime.
278
- *
279
- * @returns Provider hook profile or null if CAAMP is unavailable
280
- * @task T164
281
- */
282
- async getProviderProfile() {
283
- try {
284
- const { getProviderHookProfile } = await import('@cleocode/caamp');
285
- return getProviderHookProfile(PROVIDER_ID) ?? null;
286
- }
287
- catch {
288
- return null;
289
- }
290
- }
291
- /**
292
- * Translate a CAAMP canonical event to its Claude Code native name via CAAMP.
293
- *
294
- * Calls `toNative(canonical, 'claude-code')` from the CAAMP normalizer.
295
- * Returns null for unsupported events (PreModel, PostModel) or when
296
- * CAAMP is unavailable.
297
- *
298
- * @param canonical - CAAMP canonical event name (e.g. "PromptSubmit")
299
- * @returns Claude Code native event name or null
300
- * @task T164
301
- */
302
- async toNativeEvent(canonical) {
303
- try {
304
- const { toNative } = await import('@cleocode/caamp');
305
- return toNative(canonical, PROVIDER_ID);
306
- }
307
- catch {
308
- // Invert the static map as fallback
309
- const entry = Object.entries(CLAUDE_CODE_EVENT_MAP).find(([, v]) => v === canonical);
310
- return entry?.[0] ?? null;
311
- }
312
- }
313
- /**
314
- * Extract a plain-text transcript from Claude Code session JSONL files.
315
- *
316
- * Reads the most recent .jsonl file under `~/.claude/projects/` and
317
- * extracts user/assistant turn text into a flat string for brain
318
- * observation extraction.
319
- *
320
- * Returns null when no session data is found or on any read error.
321
- *
322
- * @param _sessionId - CLEO session ID (unused; reads the most recent file)
323
- * @param _projectDir - Project directory (unused; Claude Code uses global paths)
324
- * @task T144 @epic T134
325
- */
326
- async getTranscript(_sessionId, _projectDir) {
327
- try {
328
- const homeDir = process.env.HOME ?? process.env.USERPROFILE ?? '/root';
329
- const projectsDir = join(homeDir, '.claude', 'projects');
330
- // Find all JSONL files across project subdirectories
331
- let allFiles = [];
332
- try {
333
- const projectDirs = await readdir(projectsDir, { withFileTypes: true });
334
- for (const entry of projectDirs) {
335
- if (!entry.isDirectory())
336
- continue;
337
- const subDir = join(projectsDir, entry.name);
338
- try {
339
- const files = await readdir(subDir);
340
- for (const file of files) {
341
- if (!file.endsWith('.jsonl'))
342
- continue;
343
- const filePath = join(subDir, file);
344
- // Use file path modification heuristic (filename usually includes timestamp)
345
- allFiles.push({ path: filePath, mtime: 0 });
346
- }
347
- }
348
- catch {
349
- // Skip unreadable subdirectories
350
- }
351
- }
352
- }
353
- catch {
354
- return null;
355
- }
356
- if (allFiles.length === 0)
357
- return null;
358
- // Sort by path descending (timestamps in filenames sort naturally)
359
- allFiles = allFiles.sort((a, b) => b.path.localeCompare(a.path));
360
- const mostRecent = allFiles[0];
361
- if (!mostRecent)
362
- return null;
363
- const raw = await readFile(mostRecent.path, 'utf-8');
364
- const lines = raw.split('\n').filter((l) => l.trim());
365
- const turns = [];
366
- for (const line of lines) {
367
- try {
368
- const entry = JSON.parse(line);
369
- const role = entry.role;
370
- const content = entry.content;
371
- if (role === 'assistant' && typeof content === 'string') {
372
- turns.push(`assistant: ${content}`);
373
- }
374
- else if (role === 'user' && typeof content === 'string') {
375
- turns.push(`user: ${content}`);
376
- }
377
- }
378
- catch {
379
- // Skip malformed lines
380
- }
381
- }
382
- return turns.length > 0 ? turns.join('\n') : null;
383
- }
384
- catch {
385
- return null;
386
- }
387
- }
388
- }
389
- //# sourceMappingURL=hooks.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/claude-code/hooks.ts"],"names":[],"mappings":"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"}
@@ -1,41 +0,0 @@
1
- /**
2
- * @packageDocumentation
3
- *
4
- * CLEO provider adapter for Anthropic Claude Code CLI.
5
- * Default export is the adapter class for dynamic loading by AdapterManager.
6
- *
7
- * @task T5240
8
- */
9
- import { ClaudeCodeAdapter } from './adapter.js';
10
- export { ClaudeCodeAdapter } from './adapter.js';
11
- export { ClaudeCodeContextMonitorProvider } from './context-monitor.js';
12
- export { ClaudeCodeHookProvider } from './hooks.js';
13
- export { ClaudeCodeInstallProvider } from './install.js';
14
- export { ClaudeCodePathProvider } from './paths.js';
15
- export { ClaudeCodeSpawnProvider } from './spawn.js';
16
- export { checkStatuslineIntegration, getSetupInstructions, getStatuslineConfig, } from './statusline.js';
17
- export { ClaudeCodeTransportProvider } from './transport.js';
18
- export default ClaudeCodeAdapter;
19
- /**
20
- * Factory function for creating adapter instances.
21
- * Used by AdapterManager's dynamic import fallback.
22
- *
23
- * @remarks
24
- * This is the primary entry point for dynamic adapter loading.
25
- * AdapterManager calls this function when it resolves the claude-code
26
- * provider via its import-based discovery mechanism.
27
- *
28
- * @returns A new {@link ClaudeCodeAdapter} instance ready for initialization
29
- *
30
- * @example
31
- * ```typescript
32
- * import { createAdapter } from '@cleocode/adapters/providers/claude-code';
33
- *
34
- * const adapter = createAdapter();
35
- * await adapter.initialize('/path/to/project');
36
- * ```
37
- */
38
- export function createAdapter() {
39
- return new ClaudeCodeAdapter();
40
- }
41
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/claude-code/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,gCAAgC,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AACrD,OAAO,EACL,0BAA0B,EAC1B,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,2BAA2B,EAAE,MAAM,gBAAgB,CAAC;AAE7D,eAAe,iBAAiB,CAAC;AAEjC;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,iBAAiB,EAAE,CAAC;AACjC,CAAC"}
@@ -1,199 +0,0 @@
1
- /**
2
- * Claude Code Install Provider
3
- *
4
- * Handles CLEO installation into Claude Code environments:
5
- * - Ensures CLAUDE.md has CLEO @-references
6
- * - Manages plugin registration in ~/.claude/settings.json
7
- *
8
- * Migrated from src/core/install/claude-plugin.ts
9
- *
10
- * @task T5240
11
- */
12
- import { copyFileSync, existsSync, mkdirSync, readdirSync, readFileSync, writeFileSync, } from 'node:fs';
13
- import { homedir } from 'node:os';
14
- import { dirname, join } from 'node:path';
15
- import { fileURLToPath } from 'node:url';
16
- /** Lines that should appear in CLAUDE.md to reference CLEO. */
17
- const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
18
- /** Resolve the commands directory bundled with this adapter. */
19
- function getAdapterCommandsDir() {
20
- // Works in both ESM (import.meta.url) and compiled output
21
- const thisDir = dirname(fileURLToPath(import.meta.url));
22
- return join(thisDir, 'commands');
23
- }
24
- /**
25
- * Install provider for Claude Code.
26
- *
27
- * Manages CLEO's integration with Claude Code by:
28
- * 1. Ensuring CLAUDE.md contains @-references to CLEO instruction files
29
- * 2. Installing adapter-provided commands to .claude/commands/
30
- * 3. Registering the brain observation plugin in ~/.claude/settings.json
31
- *
32
- * @remarks
33
- * Installation is idempotent -- running install multiple times on the same
34
- * project produces the same result. The provider disables the legacy
35
- * `claude-mem\@thedotmack` plugin if present and enables the unified
36
- * `cleo\@cleocode` plugin instead.
37
- */
38
- export class ClaudeCodeInstallProvider {
39
- /**
40
- * Install CLEO into a Claude Code project.
41
- *
42
- * @param options - Installation options including project directory
43
- * @returns Result describing what was installed
44
- */
45
- async install(options) {
46
- const { projectDir } = options;
47
- const installedAt = new Date().toISOString();
48
- let instructionFileUpdated = false;
49
- const details = {};
50
- // Step 1: Ensure CLAUDE.md has @-references
51
- instructionFileUpdated = this.updateInstructionFile(projectDir);
52
- if (instructionFileUpdated) {
53
- details.instructionFile = join(projectDir, 'CLAUDE.md');
54
- }
55
- // Step 2: Install adapter-provided commands to .claude/commands/
56
- const commandsInstalled = this.installCommands(projectDir);
57
- if (commandsInstalled.length > 0) {
58
- details.commands = commandsInstalled;
59
- }
60
- // Step 3: Register plugin in ~/.claude/settings.json
61
- const pluginResult = this.registerPlugin();
62
- if (pluginResult) {
63
- details.plugin = pluginResult;
64
- }
65
- return {
66
- success: true,
67
- installedAt,
68
- instructionFileUpdated,
69
- details,
70
- };
71
- }
72
- /**
73
- * Uninstall CLEO from the current Claude Code project.
74
- *
75
- * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
76
- */
77
- async uninstall() { }
78
- /**
79
- * Check whether CLEO is installed in the current environment.
80
- *
81
- * Checks for plugin enabled in ~/.claude/settings.json.
82
- */
83
- async isInstalled() {
84
- // Check ~/.claude/settings.json for plugin registration
85
- const settingsPath = join(homedir(), '.claude', 'settings.json');
86
- if (existsSync(settingsPath)) {
87
- try {
88
- const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
89
- const plugins = settings.enabledPlugins;
90
- if (plugins && plugins['cleo@cleocode'] === true) {
91
- return true;
92
- }
93
- }
94
- catch {
95
- // Fall through
96
- }
97
- }
98
- return false;
99
- }
100
- /**
101
- * Ensure CLAUDE.md contains @-references to CLEO instruction files.
102
- *
103
- * Creates CLAUDE.md if it does not exist. Appends any missing references.
104
- *
105
- * @param projectDir - Project root directory
106
- */
107
- async ensureInstructionReferences(projectDir) {
108
- this.updateInstructionFile(projectDir);
109
- }
110
- /**
111
- * Update CLAUDE.md with CLEO @-references.
112
- *
113
- * @returns true if the file was created or modified
114
- */
115
- updateInstructionFile(projectDir) {
116
- const claudeMdPath = join(projectDir, 'CLAUDE.md');
117
- let content = '';
118
- let existed = false;
119
- if (existsSync(claudeMdPath)) {
120
- content = readFileSync(claudeMdPath, 'utf-8');
121
- existed = true;
122
- }
123
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
124
- if (missingRefs.length === 0) {
125
- return false;
126
- }
127
- const refsBlock = missingRefs.join('\n');
128
- if (existed) {
129
- // Append missing references
130
- const separator = content.endsWith('\n') ? '' : '\n';
131
- content = content + separator + refsBlock + '\n';
132
- }
133
- else {
134
- // Create new CLAUDE.md with references
135
- content = refsBlock + '\n';
136
- }
137
- writeFileSync(claudeMdPath, content, 'utf-8');
138
- return true;
139
- }
140
- /**
141
- * Install Claude Code-specific commands to .claude/commands/ in the project.
142
- *
143
- * These commands extend CLEO's provider-neutral skills with Claude Code-specific
144
- * operational patterns (Agent tool spawn templates, model assignment, context guardrails).
145
- *
146
- * @param projectDir - Project root directory
147
- * @returns Array of installed command filenames
148
- */
149
- installCommands(projectDir) {
150
- const adapterCommandsDir = getAdapterCommandsDir();
151
- if (!existsSync(adapterCommandsDir)) {
152
- return [];
153
- }
154
- const targetDir = join(projectDir, '.claude', 'commands');
155
- mkdirSync(targetDir, { recursive: true });
156
- const installed = [];
157
- const files = readdirSync(adapterCommandsDir).filter((f) => f.endsWith('.md'));
158
- for (const file of files) {
159
- const src = join(adapterCommandsDir, file);
160
- const dest = join(targetDir, file);
161
- copyFileSync(src, dest);
162
- installed.push(file);
163
- }
164
- return installed;
165
- }
166
- /**
167
- * Register the CLEO brain plugin in ~/.claude/settings.json.
168
- *
169
- * @returns Description of what was registered, or null if no change needed
170
- */
171
- registerPlugin() {
172
- const home = homedir();
173
- const settingsPath = join(home, '.claude', 'settings.json');
174
- let settings = {};
175
- if (existsSync(settingsPath)) {
176
- try {
177
- settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
178
- }
179
- catch {
180
- // Start fresh
181
- }
182
- }
183
- const enabledPlugins = settings.enabledPlugins ?? {};
184
- const pluginKey = 'cleo@cleocode';
185
- if (enabledPlugins[pluginKey] === true) {
186
- return null;
187
- }
188
- // Disable old claude-mem if present
189
- if (enabledPlugins['claude-mem@thedotmack'] === true) {
190
- enabledPlugins['claude-mem@thedotmack'] = false;
191
- }
192
- enabledPlugins[pluginKey] = true;
193
- settings.enabledPlugins = enabledPlugins;
194
- mkdirSync(join(home, '.claude'), { recursive: true });
195
- writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
196
- return `Enabled ${pluginKey} in ~/.claude/settings.json`;
197
- }
198
- }
199
- //# sourceMappingURL=install.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/claude-code/install.ts"],"names":[],"mappings":"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"}