@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,241 +0,0 @@
1
- /**
2
- * OpenCode Spawn Provider
3
- *
4
- * Implements AdapterSpawnProvider for OpenCode CLI.
5
- * Migrated from src/core/spawn/adapters/opencode-adapter.ts
6
- *
7
- * Uses `opencode run --agent ... --format json` to spawn subagent
8
- * processes. Processes run detached and are tracked by PID for
9
- * listing and termination.
10
- *
11
- * @task T5240
12
- */
13
- import { exec, spawn as nodeSpawn } from 'node:child_process';
14
- import { mkdir, readFile, writeFile } from 'node:fs/promises';
15
- import { join } from 'node:path';
16
- import { promisify } from 'node:util';
17
- const execAsync = promisify(exec);
18
- /** Name used for the CLEO subagent definition in OpenCode's agent directory. */
19
- const OPENCODE_SUBAGENT_NAME = 'cleo-subagent';
20
- /** Fallback agent name when custom agent definition cannot be created. */
21
- const OPENCODE_FALLBACK_AGENT = 'general';
22
- /**
23
- * Build the markdown content for an OpenCode agent definition file.
24
- *
25
- * OpenCode agents are defined as markdown files with YAML frontmatter
26
- * in the .opencode/agent/ directory.
27
- *
28
- * @remarks
29
- * The generated markdown uses YAML frontmatter with `mode: subagent`
30
- * and `hidden: true` so the agent does not appear in OpenCode's
31
- * interactive agent selection menu.
32
- *
33
- * @param description - Agent description for frontmatter
34
- * @param instructions - Markdown instructions body
35
- * @returns Complete agent definition markdown with YAML frontmatter
36
- *
37
- * @example
38
- * ```typescript
39
- * import { buildOpenCodeAgentMarkdown } from '@cleocode/adapters/providers/opencode/spawn';
40
- *
41
- * const md = buildOpenCodeAgentMarkdown(
42
- * 'CLEO task executor',
43
- * '# Subagent\n\nExecute the delegated task.',
44
- * );
45
- * ```
46
- */
47
- export function buildOpenCodeAgentMarkdown(description, instructions) {
48
- const normalizedDesc = description.replace(/\s+/g, ' ').trim();
49
- return [
50
- '---',
51
- `description: ${JSON.stringify(normalizedDesc)}`,
52
- 'mode: subagent',
53
- 'hidden: true',
54
- '---',
55
- '',
56
- instructions.trim(),
57
- '',
58
- ].join('\n');
59
- }
60
- /**
61
- * Ensure the CLEO subagent definition exists in the project's
62
- * .opencode/agent/ directory.
63
- *
64
- * Creates or updates the agent definition file if the content has changed.
65
- *
66
- * @param workingDirectory - Project root directory
67
- * @returns The agent name to use for spawning
68
- */
69
- async function ensureSubagentDefinition(workingDirectory) {
70
- const agentDir = join(workingDirectory, '.opencode', 'agent');
71
- const agentPath = join(agentDir, `${OPENCODE_SUBAGENT_NAME}.md`);
72
- const description = 'CLEO task executor with protocol compliance.';
73
- const instructions = [
74
- '# CLEO Subagent',
75
- '',
76
- 'You are a CLEO subagent executing a delegated task.',
77
- 'Follow the CLEO protocol and complete the assigned work.',
78
- '',
79
- '@~/.cleo/templates/CLEO-INJECTION.md',
80
- ].join('\n');
81
- const content = buildOpenCodeAgentMarkdown(description, instructions);
82
- await mkdir(agentDir, { recursive: true });
83
- let existing = null;
84
- try {
85
- existing = await readFile(agentPath, 'utf-8');
86
- }
87
- catch {
88
- existing = null;
89
- }
90
- if (existing !== content) {
91
- await writeFile(agentPath, content, 'utf-8');
92
- }
93
- return OPENCODE_SUBAGENT_NAME;
94
- }
95
- /**
96
- * Spawn provider for OpenCode.
97
- *
98
- * Spawns detached OpenCode CLI processes for subagent execution.
99
- * Each spawn ensures a CLEO subagent definition exists, then runs
100
- * `opencode run --format json --agent <name> --title <title> <prompt>`
101
- * as a detached, unref'd child process.
102
- *
103
- * @remarks
104
- * Before spawning, the provider ensures a `cleo-subagent` agent definition
105
- * exists in `.opencode/agent/`. If the definition cannot be created, it
106
- * falls back to the built-in `general` agent. Processes are tracked by
107
- * instance ID in an in-memory map and verified via `kill(pid, 0)` liveness
108
- * checks.
109
- */
110
- export class OpenCodeSpawnProvider {
111
- /** Map of instance IDs to tracked process info. */
112
- processMap = new Map();
113
- /**
114
- * Check if the OpenCode CLI is available in PATH.
115
- *
116
- * @returns true if `opencode` is found via `which`
117
- */
118
- async canSpawn() {
119
- try {
120
- await execAsync('which opencode');
121
- return true;
122
- }
123
- catch {
124
- return false;
125
- }
126
- }
127
- /**
128
- * Spawn a subagent via OpenCode CLI.
129
- *
130
- * Ensures the CLEO subagent definition exists in the project's
131
- * .opencode/agent/ directory, then spawns a detached OpenCode
132
- * process. The process runs independently of the parent.
133
- *
134
- * @param context - Spawn context with taskId, prompt, and options
135
- * @returns Spawn result with instance ID and status
136
- */
137
- async spawn(context) {
138
- const instanceId = `opencode-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
139
- const startTime = new Date().toISOString();
140
- const workingDirectory = context.workingDirectory ?? process.cwd();
141
- try {
142
- let agentName;
143
- try {
144
- agentName = await ensureSubagentDefinition(workingDirectory);
145
- }
146
- catch {
147
- agentName = OPENCODE_FALLBACK_AGENT;
148
- }
149
- const child = nodeSpawn('opencode', [
150
- 'run',
151
- '--format',
152
- 'json',
153
- '--agent',
154
- agentName,
155
- '--title',
156
- `CLEO ${context.taskId}`,
157
- context.prompt,
158
- ], {
159
- cwd: workingDirectory,
160
- detached: true,
161
- stdio: 'ignore',
162
- });
163
- child.unref();
164
- if (child.pid) {
165
- this.processMap.set(instanceId, {
166
- pid: child.pid,
167
- taskId: context.taskId,
168
- startTime,
169
- });
170
- }
171
- child.on('exit', () => {
172
- this.processMap.delete(instanceId);
173
- });
174
- return {
175
- instanceId,
176
- taskId: context.taskId,
177
- providerId: 'opencode',
178
- status: 'running',
179
- startTime,
180
- };
181
- }
182
- catch {
183
- return {
184
- instanceId,
185
- taskId: context.taskId,
186
- providerId: 'opencode',
187
- status: 'failed',
188
- startTime,
189
- endTime: new Date().toISOString(),
190
- };
191
- }
192
- }
193
- /**
194
- * List currently running OpenCode subagent processes.
195
- *
196
- * Checks each tracked process via kill(pid, 0) to verify it is still alive.
197
- * Dead processes are automatically cleaned from the tracking map.
198
- *
199
- * @returns Array of spawn results for running processes
200
- */
201
- async listRunning() {
202
- const running = [];
203
- for (const [instanceId, tracked] of this.processMap.entries()) {
204
- try {
205
- process.kill(tracked.pid, 0);
206
- running.push({
207
- instanceId,
208
- taskId: tracked.taskId,
209
- providerId: 'opencode',
210
- status: 'running',
211
- startTime: tracked.startTime,
212
- });
213
- }
214
- catch {
215
- this.processMap.delete(instanceId);
216
- }
217
- }
218
- return running;
219
- }
220
- /**
221
- * Terminate a running spawn by instance ID.
222
- *
223
- * Sends SIGTERM to the tracked process. If the process is not found
224
- * or has already exited, this is a no-op.
225
- *
226
- * @param instanceId - ID of the spawn instance to terminate
227
- */
228
- async terminate(instanceId) {
229
- const tracked = this.processMap.get(instanceId);
230
- if (!tracked)
231
- return;
232
- try {
233
- process.kill(tracked.pid, 'SIGTERM');
234
- }
235
- catch {
236
- // Process may have already exited
237
- }
238
- this.processMap.delete(instanceId);
239
- }
240
- }
241
- //# sourceMappingURL=spawn.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/opencode/spawn.ts"],"names":[],"mappings":"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"}
@@ -1,58 +0,0 @@
1
- /**
2
- * Shared transcript-reading utility for provider hook adapters.
3
- *
4
- * Several providers (Gemini CLI, Codex CLI) store session data in a
5
- * flat directory of JSON/JSONL files using the same role/content schema.
6
- * This module centralises the "find most-recent file, parse turns"
7
- * logic to avoid duplicating it in each hook provider.
8
- *
9
- * Usage:
10
- * ```ts
11
- * import { readLatestTranscript } from '../shared/transcript-reader.js';
12
- *
13
- * async getTranscript(_sessionId: string, _projectDir: string) {
14
- * return readLatestTranscript(join(homedir(), '.gemini'));
15
- * }
16
- * ```
17
- *
18
- * @task T161
19
- * @epic T134
20
- */
21
- /**
22
- * Read the most recent JSON or JSONL session file from `providerDir` and
23
- * return its contents as a flat transcript string.
24
- *
25
- * Files are sorted in descending order by filename — this works naturally
26
- * for providers that embed timestamps in filenames. The most recently named
27
- * file is read first.
28
- *
29
- * Returns `null` when:
30
- * - `providerDir` does not exist or cannot be read
31
- * - No JSON/JSONL files are present
32
- * - The most recent file contains no parseable turns
33
- *
34
- * @remarks
35
- * This utility is shared by Gemini CLI and Codex CLI hook providers which
36
- * both store session data in the same flat JSON/JSONL format. Only the
37
- * most recent file is read to keep memory usage bounded.
38
- *
39
- * @param providerDir - Absolute path to the provider's session directory
40
- * (e.g. `~/.gemini` or `~/.codex`).
41
- * @returns A plain-text transcript with lines of the form `role: content`,
42
- * or `null` if no transcript could be extracted.
43
- *
44
- * @example
45
- * ```typescript
46
- * import { readLatestTranscript } from '../shared/transcript-reader.js';
47
- *
48
- * const transcript = await readLatestTranscript('/home/user/.gemini');
49
- * if (transcript) {
50
- * console.log(transcript);
51
- * }
52
- * ```
53
- *
54
- * @task T161
55
- * @epic T134
56
- */
57
- export declare function readLatestTranscript(providerDir: string): Promise<string | null>;
58
- //# sourceMappingURL=transcript-reader.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transcript-reader.d.ts","sourceRoot":"","sources":["../../../src/providers/shared/transcript-reader.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAoDH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,wBAAsB,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CA8BtF"}
@@ -1,124 +0,0 @@
1
- /**
2
- * Shared transcript-reading utility for provider hook adapters.
3
- *
4
- * Several providers (Gemini CLI, Codex CLI) store session data in a
5
- * flat directory of JSON/JSONL files using the same role/content schema.
6
- * This module centralises the "find most-recent file, parse turns"
7
- * logic to avoid duplicating it in each hook provider.
8
- *
9
- * Usage:
10
- * ```ts
11
- * import { readLatestTranscript } from '../shared/transcript-reader.js';
12
- *
13
- * async getTranscript(_sessionId: string, _projectDir: string) {
14
- * return readLatestTranscript(join(homedir(), '.gemini'));
15
- * }
16
- * ```
17
- *
18
- * @task T161
19
- * @epic T134
20
- */
21
- import { readdir, readFile } from 'node:fs/promises';
22
- import { join } from 'node:path';
23
- // ---------------------------------------------------------------------------
24
- // Helpers
25
- // ---------------------------------------------------------------------------
26
- /**
27
- * Parse a raw JSONL or JSON session file into an array of transcript turns.
28
- *
29
- * Lines that are not valid JSON, or that lack a string `role` and string
30
- * `content`, are silently skipped.
31
- *
32
- * @param raw - Raw file contents (UTF-8 string).
33
- * @returns Array of `{ role, content }` pairs, in file order.
34
- */
35
- function parseTranscriptLines(raw) {
36
- const turns = [];
37
- const lines = raw.split('\n').filter((l) => l.trim());
38
- for (const line of lines) {
39
- try {
40
- const entry = JSON.parse(line);
41
- const role = entry.role;
42
- const content = entry.content;
43
- if (typeof role === 'string' && typeof content === 'string') {
44
- turns.push({ role, content });
45
- }
46
- }
47
- catch {
48
- // Skip malformed lines
49
- }
50
- }
51
- return turns;
52
- }
53
- // ---------------------------------------------------------------------------
54
- // Public API
55
- // ---------------------------------------------------------------------------
56
- /**
57
- * Read the most recent JSON or JSONL session file from `providerDir` and
58
- * return its contents as a flat transcript string.
59
- *
60
- * Files are sorted in descending order by filename — this works naturally
61
- * for providers that embed timestamps in filenames. The most recently named
62
- * file is read first.
63
- *
64
- * Returns `null` when:
65
- * - `providerDir` does not exist or cannot be read
66
- * - No JSON/JSONL files are present
67
- * - The most recent file contains no parseable turns
68
- *
69
- * @remarks
70
- * This utility is shared by Gemini CLI and Codex CLI hook providers which
71
- * both store session data in the same flat JSON/JSONL format. Only the
72
- * most recent file is read to keep memory usage bounded.
73
- *
74
- * @param providerDir - Absolute path to the provider's session directory
75
- * (e.g. `~/.gemini` or `~/.codex`).
76
- * @returns A plain-text transcript with lines of the form `role: content`,
77
- * or `null` if no transcript could be extracted.
78
- *
79
- * @example
80
- * ```typescript
81
- * import { readLatestTranscript } from '../shared/transcript-reader.js';
82
- *
83
- * const transcript = await readLatestTranscript('/home/user/.gemini');
84
- * if (transcript) {
85
- * console.log(transcript);
86
- * }
87
- * ```
88
- *
89
- * @task T161
90
- * @epic T134
91
- */
92
- export async function readLatestTranscript(providerDir) {
93
- let allFiles = [];
94
- try {
95
- const entries = await readdir(providerDir, { withFileTypes: true });
96
- for (const entry of entries) {
97
- if (!entry.isFile())
98
- continue;
99
- const name = entry.name;
100
- if (name.endsWith('.json') || name.endsWith('.jsonl')) {
101
- allFiles.push(join(providerDir, name));
102
- }
103
- }
104
- }
105
- catch {
106
- return null;
107
- }
108
- if (allFiles.length === 0)
109
- return null;
110
- // Sort descending — timestamps in filenames sort naturally
111
- allFiles = allFiles.sort((a, b) => b.localeCompare(a));
112
- const mostRecent = allFiles[0];
113
- if (!mostRecent)
114
- return null;
115
- try {
116
- const raw = await readFile(mostRecent, 'utf-8');
117
- const turns = parseTranscriptLines(raw);
118
- return turns.length > 0 ? turns.map((t) => `${t.role}: ${t.content}`).join('\n') : null;
119
- }
120
- catch {
121
- return null;
122
- }
123
- }
124
- //# sourceMappingURL=transcript-reader.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transcript-reader.js","sourceRoot":"","sources":["../../../src/providers/shared/transcript-reader.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAYjC,8EAA8E;AAC9E,UAAU;AACV,8EAA8E;AAE9E;;;;;;;;GAQG;AACH,SAAS,oBAAoB,CAAC,GAAW;IACvC,MAAM,KAAK,GAAqB,EAAE,CAAC;IACnC,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAEtD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAA4B,CAAC;YAC1D,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;YACxB,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;YAC9B,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;gBAC5D,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;YAChC,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,uBAAuB;QACzB,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,8EAA8E;AAC9E,aAAa;AACb,8EAA8E;AAE9E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,WAAmB;IAC5D,IAAI,QAAQ,GAAa,EAAE,CAAC;IAE5B,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,WAAW,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QACpE,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;gBAAE,SAAS;YAC9B,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;YACxB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACtD,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;YACzC,CAAC;QACH,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAEvC,2DAA2D;IAC3D,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;IACvD,MAAM,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC/B,IAAI,CAAC,UAAU;QAAE,OAAO,IAAI,CAAC;IAE7B,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAChD,MAAM,KAAK,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC;QACxC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1F,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
@@ -1,88 +0,0 @@
1
- /**
2
- * Adapter registry — discovers and provides access to provider manifests.
3
- *
4
- * Scans the providers/ directory for manifest.json files and returns
5
- * the discovered adapter manifests for use by AdapterManager.
6
- *
7
- * @task T5240
8
- */
9
- /**
10
- * Minimal manifest shape for provider discovery.
11
- *
12
- * @remarks
13
- * Each provider adapter ships a `manifest.json` in its directory under
14
- * `providers/`. The registry reads these at startup to populate the
15
- * adapter discovery surface. The shape is intentionally minimal -- only
16
- * the fields needed for dynamic loading and detection are required.
17
- */
18
- export interface AdapterManifest {
19
- /** Unique provider identifier (e.g. "claude-code", "cursor"). */
20
- id: string;
21
- /** Human-readable display name for the provider. */
22
- name: string;
23
- /** Semantic version of the adapter. */
24
- version: string;
25
- /** Short description of what the provider integrates with. */
26
- description: string;
27
- /** Provider slug used for directory lookups. */
28
- provider: string;
29
- /** Relative path to the adapter's entry point module. */
30
- entryPoint: string;
31
- /** Capability flags declared by the adapter. */
32
- capabilities: Record<string, unknown>;
33
- /** Patterns used to auto-detect the provider in a project. */
34
- detectionPatterns: Array<{
35
- /** Detection strategy type (e.g. "file", "env"). */
36
- type: string;
37
- /** Glob or regex pattern to match. */
38
- pattern: string;
39
- /** Human-readable explanation of this detection rule. */
40
- description: string;
41
- }>;
42
- }
43
- /**
44
- * Get the manifests for all bundled provider adapters.
45
- *
46
- * @remarks
47
- * Scans the known provider directories for `manifest.json` files.
48
- * Providers whose manifests cannot be loaded (missing or malformed)
49
- * are silently skipped.
50
- *
51
- * @returns Array of adapter manifests for successfully loaded providers
52
- *
53
- * @example
54
- * ```typescript
55
- * import { getProviderManifests } from '@cleocode/adapters';
56
- *
57
- * const manifests = getProviderManifests();
58
- * for (const m of manifests) {
59
- * console.log(`${m.id}: ${m.name} v${m.version}`);
60
- * }
61
- * ```
62
- */
63
- export declare function getProviderManifests(): AdapterManifest[];
64
- /**
65
- * Discover all available provider adapters.
66
- *
67
- * Returns a map of provider ID to adapter factory function.
68
- *
69
- * @remarks
70
- * Each factory lazily imports the provider module and constructs a new
71
- * adapter instance. This avoids loading all provider code upfront and
72
- * keeps startup fast.
73
- *
74
- * @returns Map of provider ID to async factory function that creates an adapter instance
75
- *
76
- * @example
77
- * ```typescript
78
- * import { discoverProviders } from '@cleocode/adapters';
79
- *
80
- * const providers = await discoverProviders();
81
- * const factory = providers.get('claude-code');
82
- * if (factory) {
83
- * const adapter = await factory();
84
- * }
85
- * ```
86
- */
87
- export declare function discoverProviders(): Promise<Map<string, () => Promise<unknown>>>;
88
- //# sourceMappingURL=registry.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH;;;;;;;;GAQG;AACH,MAAM,WAAW,eAAe;IAC9B,iEAAiE;IACjE,EAAE,EAAE,MAAM,CAAC;IACX,oDAAoD;IACpD,IAAI,EAAE,MAAM,CAAC;IACb,uCAAuC;IACvC,OAAO,EAAE,MAAM,CAAC;IAChB,8DAA8D;IAC9D,WAAW,EAAE,MAAM,CAAC;IACpB,gDAAgD;IAChD,QAAQ,EAAE,MAAM,CAAC;IACjB,yDAAyD;IACzD,UAAU,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,8DAA8D;IAC9D,iBAAiB,EAAE,KAAK,CAAC;QACvB,oDAAoD;QACpD,IAAI,EAAE,MAAM,CAAC;QACb,sCAAsC;QACtC,OAAO,EAAE,MAAM,CAAC;QAChB,yDAAyD;QACzD,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC,CAAC;CACJ;AAKD;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,oBAAoB,IAAI,eAAe,EAAE,CAexD;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAsB,iBAAiB,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAmBtF"}
package/dist/registry.js DELETED
@@ -1,88 +0,0 @@
1
- /**
2
- * Adapter registry — discovers and provides access to provider manifests.
3
- *
4
- * Scans the providers/ directory for manifest.json files and returns
5
- * the discovered adapter manifests for use by AdapterManager.
6
- *
7
- * @task T5240
8
- */
9
- import { readFileSync } from 'node:fs';
10
- import { dirname, join, resolve } from 'node:path';
11
- import { fileURLToPath } from 'node:url';
12
- /** Known provider IDs bundled with @cleocode/adapters. */
13
- const PROVIDER_IDS = ['claude-code', 'opencode', 'cursor'];
14
- /**
15
- * Get the manifests for all bundled provider adapters.
16
- *
17
- * @remarks
18
- * Scans the known provider directories for `manifest.json` files.
19
- * Providers whose manifests cannot be loaded (missing or malformed)
20
- * are silently skipped.
21
- *
22
- * @returns Array of adapter manifests for successfully loaded providers
23
- *
24
- * @example
25
- * ```typescript
26
- * import { getProviderManifests } from '@cleocode/adapters';
27
- *
28
- * const manifests = getProviderManifests();
29
- * for (const m of manifests) {
30
- * console.log(`${m.id}: ${m.name} v${m.version}`);
31
- * }
32
- * ```
33
- */
34
- export function getProviderManifests() {
35
- const manifests = [];
36
- const baseDir = resolve(dirname(fileURLToPath(import.meta.url)), 'providers');
37
- for (const providerId of PROVIDER_IDS) {
38
- try {
39
- const manifestPath = join(baseDir, providerId, 'manifest.json');
40
- const raw = readFileSync(manifestPath, 'utf-8');
41
- manifests.push(JSON.parse(raw));
42
- }
43
- catch {
44
- // Skip providers whose manifests cannot be loaded
45
- }
46
- }
47
- return manifests;
48
- }
49
- /**
50
- * Discover all available provider adapters.
51
- *
52
- * Returns a map of provider ID to adapter factory function.
53
- *
54
- * @remarks
55
- * Each factory lazily imports the provider module and constructs a new
56
- * adapter instance. This avoids loading all provider code upfront and
57
- * keeps startup fast.
58
- *
59
- * @returns Map of provider ID to async factory function that creates an adapter instance
60
- *
61
- * @example
62
- * ```typescript
63
- * import { discoverProviders } from '@cleocode/adapters';
64
- *
65
- * const providers = await discoverProviders();
66
- * const factory = providers.get('claude-code');
67
- * if (factory) {
68
- * const adapter = await factory();
69
- * }
70
- * ```
71
- */
72
- export async function discoverProviders() {
73
- const providers = new Map();
74
- providers.set('claude-code', async () => {
75
- const { ClaudeCodeAdapter } = await import('./providers/claude-code/index.js');
76
- return new ClaudeCodeAdapter();
77
- });
78
- providers.set('opencode', async () => {
79
- const { OpenCodeAdapter } = await import('./providers/opencode/index.js');
80
- return new OpenCodeAdapter();
81
- });
82
- providers.set('cursor', async () => {
83
- const { CursorAdapter } = await import('./providers/cursor/index.js');
84
- return new CursorAdapter();
85
- });
86
- return providers;
87
- }
88
- //# sourceMappingURL=registry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"registry.js","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAqCzC,0DAA0D;AAC1D,MAAM,YAAY,GAAG,CAAC,aAAa,EAAE,UAAU,EAAE,QAAQ,CAAU,CAAC;AAEpE;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,oBAAoB;IAClC,MAAM,SAAS,GAAsB,EAAE,CAAC;IACxC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;IAE9E,KAAK,MAAM,UAAU,IAAI,YAAY,EAAE,CAAC;QACtC,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,eAAe,CAAC,CAAC;YAChE,MAAM,GAAG,GAAG,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAChD,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAoB,CAAC,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,kDAAkD;QACpD,CAAC;IACH,CAAC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB;IACrC,MAAM,SAAS,GAAG,IAAI,GAAG,EAAkC,CAAC;IAE5D,SAAS,CAAC,GAAG,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE;QACtC,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,MAAM,CAAC,kCAAkC,CAAC,CAAC;QAC/E,OAAO,IAAI,iBAAiB,EAAE,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,CAAC,UAAU,EAAE,KAAK,IAAI,EAAE;QACnC,MAAM,EAAE,eAAe,EAAE,GAAG,MAAM,MAAM,CAAC,+BAA+B,CAAC,CAAC;QAC1E,OAAO,IAAI,eAAe,EAAE,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE;QACjC,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,6BAA6B,CAAC,CAAC;QACtE,OAAO,IAAI,aAAa,EAAE,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,OAAO,SAAS,CAAC;AACnB,CAAC"}