@cleocode/adapters 2026.4.11 → 2026.4.13

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 (159) hide show
  1. package/package.json +3 -3
  2. package/src/__tests__/claude-code-adapter.test.ts +1 -3
  3. package/src/__tests__/cursor-adapter.test.ts +1 -3
  4. package/src/__tests__/opencode-adapter.test.ts +1 -3
  5. package/src/providers/claude-code/__tests__/adapter.test.ts +0 -12
  6. package/src/providers/claude-code/adapter.ts +0 -1
  7. package/src/providers/claude-code/install.ts +0 -1
  8. package/src/providers/codex/adapter.ts +0 -1
  9. package/src/providers/codex/install.ts +0 -1
  10. package/src/providers/cursor/__tests__/adapter.test.ts +0 -12
  11. package/src/providers/cursor/adapter.ts +0 -1
  12. package/src/providers/cursor/install.ts +0 -1
  13. package/src/providers/gemini-cli/adapter.ts +0 -1
  14. package/src/providers/gemini-cli/install.ts +0 -1
  15. package/src/providers/kimi/adapter.ts +0 -1
  16. package/src/providers/kimi/install.ts +0 -1
  17. package/src/providers/opencode/__tests__/adapter.test.ts +0 -12
  18. package/src/providers/opencode/adapter.ts +0 -1
  19. package/src/providers/opencode/install.ts +0 -1
  20. package/dist/index.d.ts +0 -23
  21. package/dist/index.d.ts.map +0 -1
  22. package/dist/index.js +0 -3258
  23. package/dist/index.js.map +0 -7
  24. package/dist/providers/claude-code/adapter.d.ts +0 -95
  25. package/dist/providers/claude-code/adapter.d.ts.map +0 -1
  26. package/dist/providers/claude-code/adapter.js +0 -185
  27. package/dist/providers/claude-code/adapter.js.map +0 -1
  28. package/dist/providers/claude-code/context-monitor.d.ts +0 -35
  29. package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
  30. package/dist/providers/claude-code/context-monitor.js +0 -159
  31. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  32. package/dist/providers/claude-code/hooks.d.ts +0 -146
  33. package/dist/providers/claude-code/hooks.d.ts.map +0 -1
  34. package/dist/providers/claude-code/hooks.js +0 -286
  35. package/dist/providers/claude-code/hooks.js.map +0 -1
  36. package/dist/providers/claude-code/index.d.ts +0 -39
  37. package/dist/providers/claude-code/index.d.ts.map +0 -1
  38. package/dist/providers/claude-code/index.js +0 -41
  39. package/dist/providers/claude-code/index.js.map +0 -1
  40. package/dist/providers/claude-code/install.d.ts +0 -67
  41. package/dist/providers/claude-code/install.d.ts.map +0 -1
  42. package/dist/providers/claude-code/install.js +0 -161
  43. package/dist/providers/claude-code/install.js.map +0 -1
  44. package/dist/providers/claude-code/paths.d.ts +0 -32
  45. package/dist/providers/claude-code/paths.d.ts.map +0 -1
  46. package/dist/providers/claude-code/paths.js +0 -41
  47. package/dist/providers/claude-code/paths.js.map +0 -1
  48. package/dist/providers/claude-code/spawn.d.ts +0 -67
  49. package/dist/providers/claude-code/spawn.d.ts.map +0 -1
  50. package/dist/providers/claude-code/spawn.js +0 -171
  51. package/dist/providers/claude-code/spawn.js.map +0 -1
  52. package/dist/providers/claude-code/statusline.d.ts +0 -68
  53. package/dist/providers/claude-code/statusline.d.ts.map +0 -1
  54. package/dist/providers/claude-code/statusline.js +0 -130
  55. package/dist/providers/claude-code/statusline.js.map +0 -1
  56. package/dist/providers/claude-code/task-sync.d.ts +0 -32
  57. package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
  58. package/dist/providers/claude-code/task-sync.js +0 -119
  59. package/dist/providers/claude-code/task-sync.js.map +0 -1
  60. package/dist/providers/claude-code/transport.d.ts +0 -25
  61. package/dist/providers/claude-code/transport.d.ts.map +0 -1
  62. package/dist/providers/claude-code/transport.js +0 -29
  63. package/dist/providers/claude-code/transport.js.map +0 -1
  64. package/dist/providers/codex/adapter.d.ts +0 -83
  65. package/dist/providers/codex/adapter.d.ts.map +0 -1
  66. package/dist/providers/codex/adapter.js +0 -147
  67. package/dist/providers/codex/adapter.js.map +0 -1
  68. package/dist/providers/codex/hooks.d.ts +0 -91
  69. package/dist/providers/codex/hooks.d.ts.map +0 -1
  70. package/dist/providers/codex/hooks.js +0 -113
  71. package/dist/providers/codex/hooks.js.map +0 -1
  72. package/dist/providers/codex/index.d.ts +0 -37
  73. package/dist/providers/codex/index.d.ts.map +0 -1
  74. package/dist/providers/codex/index.js +0 -39
  75. package/dist/providers/codex/index.js.map +0 -1
  76. package/dist/providers/codex/install.d.ts +0 -65
  77. package/dist/providers/codex/install.d.ts.map +0 -1
  78. package/dist/providers/codex/install.js +0 -125
  79. package/dist/providers/codex/install.js.map +0 -1
  80. package/dist/providers/cursor/adapter.d.ts +0 -76
  81. package/dist/providers/cursor/adapter.d.ts.map +0 -1
  82. package/dist/providers/cursor/adapter.js +0 -152
  83. package/dist/providers/cursor/adapter.js.map +0 -1
  84. package/dist/providers/cursor/hooks.d.ts +0 -140
  85. package/dist/providers/cursor/hooks.d.ts.map +0 -1
  86. package/dist/providers/cursor/hooks.js +0 -208
  87. package/dist/providers/cursor/hooks.js.map +0 -1
  88. package/dist/providers/cursor/index.d.ts +0 -34
  89. package/dist/providers/cursor/index.d.ts.map +0 -1
  90. package/dist/providers/cursor/index.js +0 -36
  91. package/dist/providers/cursor/index.js.map +0 -1
  92. package/dist/providers/cursor/install.d.ts +0 -87
  93. package/dist/providers/cursor/install.d.ts.map +0 -1
  94. package/dist/providers/cursor/install.js +0 -181
  95. package/dist/providers/cursor/install.js.map +0 -1
  96. package/dist/providers/cursor/spawn.d.ts +0 -50
  97. package/dist/providers/cursor/spawn.d.ts.map +0 -1
  98. package/dist/providers/cursor/spawn.js +0 -59
  99. package/dist/providers/cursor/spawn.js.map +0 -1
  100. package/dist/providers/gemini-cli/adapter.d.ts +0 -84
  101. package/dist/providers/gemini-cli/adapter.d.ts.map +0 -1
  102. package/dist/providers/gemini-cli/adapter.js +0 -159
  103. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  104. package/dist/providers/gemini-cli/hooks.d.ts +0 -99
  105. package/dist/providers/gemini-cli/hooks.d.ts.map +0 -1
  106. package/dist/providers/gemini-cli/hooks.js +0 -128
  107. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  108. package/dist/providers/gemini-cli/index.d.ts +0 -37
  109. package/dist/providers/gemini-cli/index.d.ts.map +0 -1
  110. package/dist/providers/gemini-cli/index.js +0 -39
  111. package/dist/providers/gemini-cli/index.js.map +0 -1
  112. package/dist/providers/gemini-cli/install.d.ts +0 -65
  113. package/dist/providers/gemini-cli/install.d.ts.map +0 -1
  114. package/dist/providers/gemini-cli/install.js +0 -125
  115. package/dist/providers/gemini-cli/install.js.map +0 -1
  116. package/dist/providers/kimi/adapter.d.ts +0 -85
  117. package/dist/providers/kimi/adapter.d.ts.map +0 -1
  118. package/dist/providers/kimi/adapter.js +0 -146
  119. package/dist/providers/kimi/adapter.js.map +0 -1
  120. package/dist/providers/kimi/hooks.d.ts +0 -70
  121. package/dist/providers/kimi/hooks.d.ts.map +0 -1
  122. package/dist/providers/kimi/hooks.js +0 -79
  123. package/dist/providers/kimi/hooks.js.map +0 -1
  124. package/dist/providers/kimi/index.d.ts +0 -37
  125. package/dist/providers/kimi/index.d.ts.map +0 -1
  126. package/dist/providers/kimi/index.js +0 -39
  127. package/dist/providers/kimi/index.js.map +0 -1
  128. package/dist/providers/kimi/install.d.ts +0 -65
  129. package/dist/providers/kimi/install.d.ts.map +0 -1
  130. package/dist/providers/kimi/install.js +0 -125
  131. package/dist/providers/kimi/install.js.map +0 -1
  132. package/dist/providers/opencode/adapter.d.ts +0 -83
  133. package/dist/providers/opencode/adapter.d.ts.map +0 -1
  134. package/dist/providers/opencode/adapter.js +0 -167
  135. package/dist/providers/opencode/adapter.js.map +0 -1
  136. package/dist/providers/opencode/hooks.d.ts +0 -136
  137. package/dist/providers/opencode/hooks.d.ts.map +0 -1
  138. package/dist/providers/opencode/hooks.js +0 -206
  139. package/dist/providers/opencode/hooks.js.map +0 -1
  140. package/dist/providers/opencode/index.d.ts +0 -35
  141. package/dist/providers/opencode/index.d.ts.map +0 -1
  142. package/dist/providers/opencode/index.js +0 -37
  143. package/dist/providers/opencode/index.js.map +0 -1
  144. package/dist/providers/opencode/install.d.ts +0 -56
  145. package/dist/providers/opencode/install.d.ts.map +0 -1
  146. package/dist/providers/opencode/install.js +0 -116
  147. package/dist/providers/opencode/install.js.map +0 -1
  148. package/dist/providers/opencode/spawn.d.ts +0 -94
  149. package/dist/providers/opencode/spawn.d.ts.map +0 -1
  150. package/dist/providers/opencode/spawn.js +0 -241
  151. package/dist/providers/opencode/spawn.js.map +0 -1
  152. package/dist/providers/shared/transcript-reader.d.ts +0 -58
  153. package/dist/providers/shared/transcript-reader.d.ts.map +0 -1
  154. package/dist/providers/shared/transcript-reader.js +0 -124
  155. package/dist/providers/shared/transcript-reader.js.map +0 -1
  156. package/dist/registry.d.ts +0 -88
  157. package/dist/registry.d.ts.map +0 -1
  158. package/dist/registry.js +0 -88
  159. package/dist/registry.js.map +0 -1
@@ -1,286 +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 { readdir, readFile } from 'node:fs/promises';
19
- import { join } from 'node:path';
20
- /** CAAMP provider identifier for Claude Code. */
21
- const PROVIDER_ID = 'claude-code';
22
- /**
23
- * Fallback map from Claude Code native event names to CAAMP canonical names.
24
- *
25
- * Derived from `getProviderHookProfile('claude-code').mappings` in CAAMP 1.9.1.
26
- * Covers all 14 supported events. PreModel and PostModel are not supported
27
- * by Claude Code and are absent from this map.
28
- *
29
- * Used as fallback when CAAMP runtime is unavailable, and as the synchronous
30
- * implementation of `mapProviderEvent()`.
31
- */
32
- const CLAUDE_CODE_EVENT_MAP = {
33
- // CAAMP: toNative('SessionStart', 'claude-code') = 'SessionStart'
34
- SessionStart: 'SessionStart',
35
- // CAAMP: toNative('SessionEnd', 'claude-code') = 'SessionEnd'
36
- SessionEnd: 'SessionEnd',
37
- // CAAMP: toNative('PromptSubmit', 'claude-code') = 'UserPromptSubmit'
38
- UserPromptSubmit: 'PromptSubmit',
39
- // CAAMP: toNative('ResponseComplete', 'claude-code') = 'Stop'
40
- Stop: 'ResponseComplete',
41
- // CAAMP: toNative('PreToolUse', 'claude-code') = 'PreToolUse'
42
- PreToolUse: 'PreToolUse',
43
- // CAAMP: toNative('PostToolUse', 'claude-code') = 'PostToolUse'
44
- PostToolUse: 'PostToolUse',
45
- // CAAMP: toNative('PostToolUseFailure','claude-code') = 'PostToolUseFailure'
46
- PostToolUseFailure: 'PostToolUseFailure',
47
- // CAAMP: toNative('PermissionRequest', 'claude-code') = 'PermissionRequest'
48
- PermissionRequest: 'PermissionRequest',
49
- // CAAMP: toNative('SubagentStart', 'claude-code') = 'SubagentStart'
50
- SubagentStart: 'SubagentStart',
51
- // CAAMP: toNative('SubagentStop', 'claude-code') = 'SubagentStop'
52
- SubagentStop: 'SubagentStop',
53
- // CAAMP: toNative('PreCompact', 'claude-code') = 'PreCompact'
54
- PreCompact: 'PreCompact',
55
- // CAAMP: toNative('PostCompact', 'claude-code') = 'PostCompact'
56
- PostCompact: 'PostCompact',
57
- // CAAMP: toNative('Notification', 'claude-code') = 'Notification'
58
- Notification: 'Notification',
59
- // CAAMP: toNative('ConfigChange', 'claude-code') = 'ConfigChange'
60
- ConfigChange: 'ConfigChange',
61
- };
62
- /**
63
- * Hook provider for Claude Code.
64
- *
65
- * Claude Code registers hooks via its global config at `~/.claude/settings.json`.
66
- * Supported handler types: command, http, prompt, agent.
67
- *
68
- * Event mapping is based on `getProviderHookProfile('claude-code')` from
69
- * CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
70
- * `getProviderProfile`) call CAAMP directly when available.
71
- *
72
- * Since hooks are registered through the config system (managed by the install
73
- * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
74
- * state without performing filesystem operations.
75
- *
76
- * @remarks
77
- * Claude Code is the only provider that supports all 14 of its declared
78
- * canonical events at runtime. The static event map is maintained as a
79
- * synchronous fallback; async methods like {@link getSupportedCanonicalEvents}
80
- * and {@link getProviderProfile} call CAAMP directly when available.
81
- *
82
- * @task T164
83
- * @epic T134
84
- */
85
- export class ClaudeCodeHookProvider {
86
- /** Whether hooks have been registered for the current session. */
87
- registered = false;
88
- /**
89
- * Map a Claude Code native event name to a CAAMP canonical hook event name.
90
- *
91
- * Looks up the native event name in the map derived from
92
- * `getProviderHookProfile('claude-code').mappings` (CAAMP 1.9.1).
93
- * Returns null for unrecognised events (e.g. PreModel, PostModel which
94
- * Claude Code does not support).
95
- *
96
- * @param providerEvent - Claude Code native event (e.g. "UserPromptSubmit", "Stop")
97
- * @returns CAAMP canonical event name, or null if unmapped
98
- * @task T164
99
- */
100
- mapProviderEvent(providerEvent) {
101
- return CLAUDE_CODE_EVENT_MAP[providerEvent] ?? null;
102
- }
103
- /**
104
- * Register native hooks for a project.
105
- *
106
- * For Claude Code, hooks are registered via the config system
107
- * (`~/.claude/settings.json`), managed by the install provider.
108
- * This method marks hooks as registered without performing filesystem operations.
109
- *
110
- * Iterating supported events is handled at install time using
111
- * `getSupportedCanonicalEvents()` to enumerate all 14 supported hooks.
112
- *
113
- * @param _projectDir - Project directory (unused; Claude Code uses global config)
114
- * @task T164
115
- */
116
- async registerNativeHooks(_projectDir) {
117
- this.registered = true;
118
- }
119
- /**
120
- * Unregister native hooks.
121
- *
122
- * For Claude Code, this is a no-op since hooks are managed through the config
123
- * system. Unregistration happens via the install provider's uninstall method.
124
- *
125
- * @task T164
126
- */
127
- async unregisterNativeHooks() {
128
- this.registered = false;
129
- }
130
- /**
131
- * Check whether hooks have been registered via `registerNativeHooks`.
132
- */
133
- isRegistered() {
134
- return this.registered;
135
- }
136
- /**
137
- * Get the native→canonical event mapping for introspection and debugging.
138
- *
139
- * Returns the map derived from `getProviderHookProfile('claude-code').mappings`
140
- * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
141
- * names via live CAAMP APIs.
142
- *
143
- * @returns Immutable record of native event name → canonical event name
144
- */
145
- getEventMap() {
146
- return { ...CLAUDE_CODE_EVENT_MAP };
147
- }
148
- /**
149
- * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
150
- *
151
- * Calls `getSupportedEvents('claude-code')` from the CAAMP normalizer to
152
- * get the authoritative list. Claude Code supports 14 of 16 canonical events
153
- * (PreModel and PostModel are not supported). Falls back to the values of
154
- * the static event map when CAAMP is unavailable at runtime.
155
- *
156
- * @returns Array of CAAMP canonical event names supported by Claude Code
157
- * @task T164
158
- */
159
- async getSupportedCanonicalEvents() {
160
- try {
161
- const { getSupportedEvents } = await import('@cleocode/caamp');
162
- return getSupportedEvents(PROVIDER_ID);
163
- }
164
- catch {
165
- return [...new Set(Object.values(CLAUDE_CODE_EVENT_MAP))];
166
- }
167
- }
168
- /**
169
- * Retrieve the full provider hook profile from CAAMP.
170
- *
171
- * Calls `getProviderHookProfile('claude-code')` from the CAAMP normalizer to
172
- * get the complete profile: hook system type (`config`), config path
173
- * (`~/.claude/settings.json`), handler types, and all event mappings.
174
- * Returns null when CAAMP is unavailable at runtime.
175
- *
176
- * @returns Provider hook profile or null if CAAMP is unavailable
177
- * @task T164
178
- */
179
- async getProviderProfile() {
180
- try {
181
- const { getProviderHookProfile } = await import('@cleocode/caamp');
182
- return getProviderHookProfile(PROVIDER_ID) ?? null;
183
- }
184
- catch {
185
- return null;
186
- }
187
- }
188
- /**
189
- * Translate a CAAMP canonical event to its Claude Code native name via CAAMP.
190
- *
191
- * Calls `toNative(canonical, 'claude-code')` from the CAAMP normalizer.
192
- * Returns null for unsupported events (PreModel, PostModel) or when
193
- * CAAMP is unavailable.
194
- *
195
- * @param canonical - CAAMP canonical event name (e.g. "PromptSubmit")
196
- * @returns Claude Code native event name or null
197
- * @task T164
198
- */
199
- async toNativeEvent(canonical) {
200
- try {
201
- const { toNative } = await import('@cleocode/caamp');
202
- return toNative(canonical, PROVIDER_ID);
203
- }
204
- catch {
205
- // Invert the static map as fallback
206
- const entry = Object.entries(CLAUDE_CODE_EVENT_MAP).find(([, v]) => v === canonical);
207
- return entry?.[0] ?? null;
208
- }
209
- }
210
- /**
211
- * Extract a plain-text transcript from Claude Code session JSONL files.
212
- *
213
- * Reads the most recent .jsonl file under `~/.claude/projects/` and
214
- * extracts user/assistant turn text into a flat string for brain
215
- * observation extraction.
216
- *
217
- * Returns null when no session data is found or on any read error.
218
- *
219
- * @param _sessionId - CLEO session ID (unused; reads the most recent file)
220
- * @param _projectDir - Project directory (unused; Claude Code uses global paths)
221
- * @task T144 @epic T134
222
- */
223
- async getTranscript(_sessionId, _projectDir) {
224
- try {
225
- const homeDir = process.env.HOME ?? process.env.USERPROFILE ?? '/root';
226
- const projectsDir = join(homeDir, '.claude', 'projects');
227
- // Find all JSONL files across project subdirectories
228
- let allFiles = [];
229
- try {
230
- const projectDirs = await readdir(projectsDir, { withFileTypes: true });
231
- for (const entry of projectDirs) {
232
- if (!entry.isDirectory())
233
- continue;
234
- const subDir = join(projectsDir, entry.name);
235
- try {
236
- const files = await readdir(subDir);
237
- for (const file of files) {
238
- if (!file.endsWith('.jsonl'))
239
- continue;
240
- const filePath = join(subDir, file);
241
- // Use file path modification heuristic (filename usually includes timestamp)
242
- allFiles.push({ path: filePath, mtime: 0 });
243
- }
244
- }
245
- catch {
246
- // Skip unreadable subdirectories
247
- }
248
- }
249
- }
250
- catch {
251
- return null;
252
- }
253
- if (allFiles.length === 0)
254
- return null;
255
- // Sort by path descending (timestamps in filenames sort naturally)
256
- allFiles = allFiles.sort((a, b) => b.path.localeCompare(a.path));
257
- const mostRecent = allFiles[0];
258
- if (!mostRecent)
259
- return null;
260
- const raw = await readFile(mostRecent.path, 'utf-8');
261
- const lines = raw.split('\n').filter((l) => l.trim());
262
- const turns = [];
263
- for (const line of lines) {
264
- try {
265
- const entry = JSON.parse(line);
266
- const role = entry.role;
267
- const content = entry.content;
268
- if (role === 'assistant' && typeof content === 'string') {
269
- turns.push(`assistant: ${content}`);
270
- }
271
- else if (role === 'user' && typeof content === 'string') {
272
- turns.push(`user: ${content}`);
273
- }
274
- }
275
- catch {
276
- // Skip malformed lines
277
- }
278
- }
279
- return turns.length > 0 ? turns.join('\n') : null;
280
- }
281
- catch {
282
- return null;
283
- }
284
- }
285
- }
286
- //# 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,39 +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 declare function createAdapter(): ClaudeCodeAdapter;
39
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","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,wBAAgB,aAAa,IAAI,iBAAiB,CAEjD"}
@@ -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,67 +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 type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
13
- /**
14
- * Install provider for Claude Code.
15
- *
16
- * Manages CLEO's integration with Claude Code by:
17
- * 1. Ensuring CLAUDE.md contains @-references to CLEO instruction files
18
- * 2. Registering the brain observation plugin in ~/.claude/settings.json
19
- *
20
- * @remarks
21
- * Installation is idempotent -- running install multiple times on the same
22
- * project produces the same result. The provider disables the legacy
23
- * `claude-mem\@thedotmack` plugin if present and enables the unified
24
- * `cleo\@cleocode` plugin instead.
25
- */
26
- export declare class ClaudeCodeInstallProvider implements AdapterInstallProvider {
27
- /**
28
- * Install CLEO into a Claude Code project.
29
- *
30
- * @param options - Installation options including project directory
31
- * @returns Result describing what was installed
32
- */
33
- install(options: InstallOptions): Promise<InstallResult>;
34
- /**
35
- * Uninstall CLEO from the current Claude Code project.
36
- *
37
- * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
38
- */
39
- uninstall(): Promise<void>;
40
- /**
41
- * Check whether CLEO is installed in the current environment.
42
- *
43
- * Checks for plugin enabled in ~/.claude/settings.json.
44
- */
45
- isInstalled(): Promise<boolean>;
46
- /**
47
- * Ensure CLAUDE.md contains @-references to CLEO instruction files.
48
- *
49
- * Creates CLAUDE.md if it does not exist. Appends any missing references.
50
- *
51
- * @param projectDir - Project root directory
52
- */
53
- ensureInstructionReferences(projectDir: string): Promise<void>;
54
- /**
55
- * Update CLAUDE.md with CLEO @-references.
56
- *
57
- * @returns true if the file was created or modified
58
- */
59
- private updateInstructionFile;
60
- /**
61
- * Register the CLEO brain plugin in ~/.claude/settings.json.
62
- *
63
- * @returns Description of what was registered, or null if no change needed
64
- */
65
- private registerPlugin;
66
- }
67
- //# sourceMappingURL=install.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAKH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;;;GAYG;AACH,qBAAa,yBAA0B,YAAW,sBAAsB;IACtE;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IA2B9D;;;;OAIG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAEhC;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAkBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IA+B7B;;;;OAIG;IACH,OAAO,CAAC,cAAc;CAiCvB"}
@@ -1,161 +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 { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
13
- import { homedir } from 'node:os';
14
- import { join } from 'node:path';
15
- /** Lines that should appear in CLAUDE.md to reference CLEO. */
16
- const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
17
- /**
18
- * Install provider for Claude Code.
19
- *
20
- * Manages CLEO's integration with Claude Code by:
21
- * 1. Ensuring CLAUDE.md contains @-references to CLEO instruction files
22
- * 2. Registering the brain observation plugin in ~/.claude/settings.json
23
- *
24
- * @remarks
25
- * Installation is idempotent -- running install multiple times on the same
26
- * project produces the same result. The provider disables the legacy
27
- * `claude-mem\@thedotmack` plugin if present and enables the unified
28
- * `cleo\@cleocode` plugin instead.
29
- */
30
- export class ClaudeCodeInstallProvider {
31
- /**
32
- * Install CLEO into a Claude Code project.
33
- *
34
- * @param options - Installation options including project directory
35
- * @returns Result describing what was installed
36
- */
37
- async install(options) {
38
- const { projectDir } = options;
39
- const installedAt = new Date().toISOString();
40
- let instructionFileUpdated = false;
41
- const details = {};
42
- // Step 1: Ensure CLAUDE.md has @-references
43
- instructionFileUpdated = this.updateInstructionFile(projectDir);
44
- if (instructionFileUpdated) {
45
- details.instructionFile = join(projectDir, 'CLAUDE.md');
46
- }
47
- // Step 2: Register plugin in ~/.claude/settings.json
48
- const pluginResult = this.registerPlugin();
49
- if (pluginResult) {
50
- details.plugin = pluginResult;
51
- }
52
- return {
53
- success: true,
54
- installedAt,
55
- instructionFileUpdated,
56
- mcpRegistered: false,
57
- details,
58
- };
59
- }
60
- /**
61
- * Uninstall CLEO from the current Claude Code project.
62
- *
63
- * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
64
- */
65
- async uninstall() { }
66
- /**
67
- * Check whether CLEO is installed in the current environment.
68
- *
69
- * Checks for plugin enabled in ~/.claude/settings.json.
70
- */
71
- async isInstalled() {
72
- // Check ~/.claude/settings.json for plugin registration
73
- const settingsPath = join(homedir(), '.claude', 'settings.json');
74
- if (existsSync(settingsPath)) {
75
- try {
76
- const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
77
- const plugins = settings.enabledPlugins;
78
- if (plugins && plugins['cleo@cleocode'] === true) {
79
- return true;
80
- }
81
- }
82
- catch {
83
- // Fall through
84
- }
85
- }
86
- return false;
87
- }
88
- /**
89
- * Ensure CLAUDE.md contains @-references to CLEO instruction files.
90
- *
91
- * Creates CLAUDE.md if it does not exist. Appends any missing references.
92
- *
93
- * @param projectDir - Project root directory
94
- */
95
- async ensureInstructionReferences(projectDir) {
96
- this.updateInstructionFile(projectDir);
97
- }
98
- /**
99
- * Update CLAUDE.md with CLEO @-references.
100
- *
101
- * @returns true if the file was created or modified
102
- */
103
- updateInstructionFile(projectDir) {
104
- const claudeMdPath = join(projectDir, 'CLAUDE.md');
105
- let content = '';
106
- let existed = false;
107
- if (existsSync(claudeMdPath)) {
108
- content = readFileSync(claudeMdPath, 'utf-8');
109
- existed = true;
110
- }
111
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
112
- if (missingRefs.length === 0) {
113
- return false;
114
- }
115
- const refsBlock = missingRefs.join('\n');
116
- if (existed) {
117
- // Append missing references
118
- const separator = content.endsWith('\n') ? '' : '\n';
119
- content = content + separator + refsBlock + '\n';
120
- }
121
- else {
122
- // Create new CLAUDE.md with references
123
- content = refsBlock + '\n';
124
- }
125
- writeFileSync(claudeMdPath, content, 'utf-8');
126
- return true;
127
- }
128
- /**
129
- * Register the CLEO brain plugin in ~/.claude/settings.json.
130
- *
131
- * @returns Description of what was registered, or null if no change needed
132
- */
133
- registerPlugin() {
134
- const home = homedir();
135
- const settingsPath = join(home, '.claude', 'settings.json');
136
- let settings = {};
137
- if (existsSync(settingsPath)) {
138
- try {
139
- settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
140
- }
141
- catch {
142
- // Start fresh
143
- }
144
- }
145
- const enabledPlugins = settings.enabledPlugins ?? {};
146
- const pluginKey = 'cleo@cleocode';
147
- if (enabledPlugins[pluginKey] === true) {
148
- return null;
149
- }
150
- // Disable old claude-mem if present
151
- if (enabledPlugins['claude-mem@thedotmack'] === true) {
152
- enabledPlugins['claude-mem@thedotmack'] = false;
153
- }
154
- enabledPlugins[pluginKey] = true;
155
- settings.enabledPlugins = enabledPlugins;
156
- mkdirSync(join(home, '.claude'), { recursive: true });
157
- writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
158
- return `Enabled ${pluginKey} in ~/.claude/settings.json`;
159
- }
160
- }
161
- //# 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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"}
@@ -1,32 +0,0 @@
1
- /**
2
- * Claude Code path provider.
3
- *
4
- * Implements AdapterPathProvider with Claude Code-specific directory locations.
5
- *
6
- * @task T5240
7
- */
8
- import type { AdapterPathProvider } from '@cleocode/contracts';
9
- /**
10
- * Path provider for Anthropic Claude Code CLI.
11
- *
12
- * Resolves Claude Code's standard directory layout:
13
- * - Config dir: ~/.claude (or CLAUDE_HOME)
14
- * - Settings: ~/.claude/settings.json (or CLAUDE_SETTINGS)
15
- * - Agents: ~/.claude/agents
16
- * - Memory DB: ~/.claude-mem/claude-mem.db (or CLAUDE_MEM_DB)
17
- *
18
- * @remarks
19
- * All paths respect environment variable overrides for CI and non-standard
20
- * installations. When env vars are unset, the canonical default paths are used.
21
- */
22
- export declare class ClaudeCodePathProvider implements AdapterPathProvider {
23
- /** Get the provider's root configuration directory. */
24
- getProviderDir(): string;
25
- /** Get the path to the provider's settings file, or null if unavailable. */
26
- getSettingsPath(): string | null;
27
- /** Get the directory where agents are installed, or null if unsupported. */
28
- getAgentInstallDir(): string | null;
29
- /** Get the path to the provider's memory database, or null if unsupported. */
30
- getMemoryDbPath(): string | null;
31
- }
32
- //# sourceMappingURL=paths.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"paths.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/paths.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE/D;;;;;;;;;;;;GAYG;AACH,qBAAa,sBAAuB,YAAW,mBAAmB;IAChE,uDAAuD;IACvD,cAAc,IAAI,MAAM;IAIxB,4EAA4E;IAC5E,eAAe,IAAI,MAAM,GAAG,IAAI;IAIhC,4EAA4E;IAC5E,kBAAkB,IAAI,MAAM,GAAG,IAAI;IAInC,8EAA8E;IAC9E,eAAe,IAAI,MAAM,GAAG,IAAI;CAGjC"}