@cleocode/adapters 2026.3.73 → 2026.3.76

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 (78) hide show
  1. package/dist/index.js +132 -154
  2. package/dist/index.js.map +4 -4
  3. package/dist/providers/codex/hooks.d.ts +2 -2
  4. package/dist/providers/codex/hooks.d.ts.map +1 -1
  5. package/dist/providers/gemini-cli/hooks.d.ts +2 -2
  6. package/dist/providers/gemini-cli/hooks.d.ts.map +1 -1
  7. package/dist/providers/shared/transcript-reader.d.ts +43 -0
  8. package/dist/providers/shared/transcript-reader.d.ts.map +1 -0
  9. package/package.json +3 -3
  10. package/src/providers/codex/hooks.ts +5 -52
  11. package/src/providers/gemini-cli/hooks.ts +5 -52
  12. package/src/providers/shared/transcript-reader.ts +123 -0
  13. package/dist/providers/claude-code/adapter.js +0 -165
  14. package/dist/providers/claude-code/adapter.js.map +0 -1
  15. package/dist/providers/claude-code/context-monitor.js +0 -148
  16. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  17. package/dist/providers/claude-code/hooks.js +0 -279
  18. package/dist/providers/claude-code/hooks.js.map +0 -1
  19. package/dist/providers/claude-code/index.js +0 -26
  20. package/dist/providers/claude-code/index.js.map +0 -1
  21. package/dist/providers/claude-code/install.js +0 -234
  22. package/dist/providers/claude-code/install.js.map +0 -1
  23. package/dist/providers/claude-code/paths.js +0 -33
  24. package/dist/providers/claude-code/paths.js.map +0 -1
  25. package/dist/providers/claude-code/spawn.js +0 -164
  26. package/dist/providers/claude-code/spawn.js.map +0 -1
  27. package/dist/providers/claude-code/statusline.js +0 -86
  28. package/dist/providers/claude-code/statusline.js.map +0 -1
  29. package/dist/providers/claude-code/task-sync.js +0 -111
  30. package/dist/providers/claude-code/task-sync.js.map +0 -1
  31. package/dist/providers/claude-code/transport.js +0 -18
  32. package/dist/providers/claude-code/transport.js.map +0 -1
  33. package/dist/providers/codex/adapter.js +0 -134
  34. package/dist/providers/codex/adapter.js.map +0 -1
  35. package/dist/providers/codex/hooks.js +0 -155
  36. package/dist/providers/codex/hooks.js.map +0 -1
  37. package/dist/providers/codex/index.js +0 -24
  38. package/dist/providers/codex/index.js.map +0 -1
  39. package/dist/providers/codex/install.js +0 -183
  40. package/dist/providers/codex/install.js.map +0 -1
  41. package/dist/providers/cursor/adapter.js +0 -138
  42. package/dist/providers/cursor/adapter.js.map +0 -1
  43. package/dist/providers/cursor/hooks.js +0 -201
  44. package/dist/providers/cursor/hooks.js.map +0 -1
  45. package/dist/providers/cursor/index.js +0 -21
  46. package/dist/providers/cursor/index.js.map +0 -1
  47. package/dist/providers/cursor/install.js +0 -238
  48. package/dist/providers/cursor/install.js.map +0 -1
  49. package/dist/providers/cursor/spawn.js +0 -59
  50. package/dist/providers/cursor/spawn.js.map +0 -1
  51. package/dist/providers/gemini-cli/adapter.js +0 -145
  52. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  53. package/dist/providers/gemini-cli/hooks.js +0 -169
  54. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  55. package/dist/providers/gemini-cli/index.js +0 -24
  56. package/dist/providers/gemini-cli/index.js.map +0 -1
  57. package/dist/providers/gemini-cli/install.js +0 -183
  58. package/dist/providers/gemini-cli/install.js.map +0 -1
  59. package/dist/providers/kimi/adapter.js +0 -133
  60. package/dist/providers/kimi/adapter.js.map +0 -1
  61. package/dist/providers/kimi/hooks.js +0 -73
  62. package/dist/providers/kimi/hooks.js.map +0 -1
  63. package/dist/providers/kimi/index.js +0 -24
  64. package/dist/providers/kimi/index.js.map +0 -1
  65. package/dist/providers/kimi/install.js +0 -189
  66. package/dist/providers/kimi/install.js.map +0 -1
  67. package/dist/providers/opencode/adapter.js +0 -151
  68. package/dist/providers/opencode/adapter.js.map +0 -1
  69. package/dist/providers/opencode/hooks.js +0 -197
  70. package/dist/providers/opencode/hooks.js.map +0 -1
  71. package/dist/providers/opencode/index.js +0 -22
  72. package/dist/providers/opencode/index.js.map +0 -1
  73. package/dist/providers/opencode/install.js +0 -180
  74. package/dist/providers/opencode/install.js.map +0 -1
  75. package/dist/providers/opencode/spawn.js +0 -219
  76. package/dist/providers/opencode/spawn.js.map +0 -1
  77. package/dist/registry.js +0 -55
  78. package/dist/registry.js.map +0 -1
@@ -1,145 +0,0 @@
1
- /**
2
- * Gemini CLI Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for Google Gemini CLI.
5
- * Provides hooks and install capabilities for CLEO integration.
6
- *
7
- * @task T161
8
- * @epic T134
9
- */
10
- import { exec } from 'node:child_process';
11
- import { existsSync } from 'node:fs';
12
- import { homedir } from 'node:os';
13
- import { join } from 'node:path';
14
- import { promisify } from 'node:util';
15
- import { GeminiCliHookProvider } from './hooks.js';
16
- import { GeminiCliInstallProvider } from './install.js';
17
- const execAsync = promisify(exec);
18
- /**
19
- * CLEO provider adapter for Google Gemini CLI.
20
- *
21
- * Bridges CLEO's adapter system with Gemini CLI's native capabilities:
22
- * - Hooks: Maps Gemini CLI events (SessionStart, PreToolUse, etc.) to CAAMP events
23
- * - Install: Registers MCP server in ~/.gemini/settings.json and ensures AGENTS.md references
24
- *
25
- * @task T161
26
- * @epic T134
27
- */
28
- export class GeminiCliAdapter {
29
- id = 'gemini-cli';
30
- name = 'Gemini CLI';
31
- version = '1.0.0';
32
- capabilities = {
33
- supportsHooks: true,
34
- supportedHookEvents: [
35
- 'SessionStart',
36
- 'SessionEnd',
37
- 'BeforeAgent',
38
- 'AfterAgent',
39
- 'BeforeTool',
40
- 'AfterTool',
41
- 'BeforeModel',
42
- 'AfterModel',
43
- 'PreCompress',
44
- 'Notification',
45
- ],
46
- supportsSpawn: false,
47
- supportsInstall: true,
48
- supportsMcp: true,
49
- supportsInstructionFiles: false,
50
- supportsContextMonitor: false,
51
- supportsStatusline: false,
52
- supportsProviderPaths: false,
53
- supportsTransport: false,
54
- supportsTaskSync: false,
55
- };
56
- hooks;
57
- install;
58
- projectDir = null;
59
- initialized = false;
60
- constructor() {
61
- this.hooks = new GeminiCliHookProvider();
62
- this.install = new GeminiCliInstallProvider();
63
- }
64
- /**
65
- * Initialize the adapter for a given project directory.
66
- *
67
- * @param projectDir - Root directory of the project
68
- * @task T161
69
- */
70
- async initialize(projectDir) {
71
- this.projectDir = projectDir;
72
- this.initialized = true;
73
- }
74
- /**
75
- * Dispose the adapter and clean up resources.
76
- *
77
- * Unregisters hooks and releases any tracked state.
78
- * @task T161
79
- */
80
- async dispose() {
81
- if (this.hooks.isRegistered()) {
82
- await this.hooks.unregisterNativeHooks();
83
- }
84
- this.initialized = false;
85
- this.projectDir = null;
86
- }
87
- /**
88
- * Run a health check to verify Gemini CLI is accessible.
89
- *
90
- * Checks:
91
- * 1. Adapter has been initialized
92
- * 2. Gemini CLI binary is available in PATH
93
- * 3. ~/.gemini/ configuration directory exists
94
- *
95
- * @returns Health status with details about each check
96
- * @task T161
97
- */
98
- async healthCheck() {
99
- const details = {};
100
- if (!this.initialized) {
101
- return {
102
- healthy: false,
103
- provider: this.id,
104
- details: { error: 'Adapter not initialized' },
105
- };
106
- }
107
- // Check Gemini CLI availability
108
- let cliAvailable = false;
109
- try {
110
- const { stdout } = await execAsync('which gemini');
111
- cliAvailable = stdout.trim().length > 0;
112
- details.cliPath = stdout.trim();
113
- }
114
- catch {
115
- details.cliAvailable = false;
116
- }
117
- // Check for Gemini CLI config directory
118
- const geminiConfigDir = join(homedir(), '.gemini');
119
- const configExists = existsSync(geminiConfigDir);
120
- details.configDirExists = configExists;
121
- // Healthy if CLI is available (primary requirement)
122
- const healthy = cliAvailable;
123
- details.cliAvailable = cliAvailable;
124
- return {
125
- healthy,
126
- provider: this.id,
127
- details,
128
- };
129
- }
130
- /**
131
- * Check whether the adapter has been initialized.
132
- * @task T161
133
- */
134
- isInitialized() {
135
- return this.initialized;
136
- }
137
- /**
138
- * Get the project directory this adapter was initialized with.
139
- * @task T161
140
- */
141
- getProjectDir() {
142
- return this.projectDir;
143
- }
144
- }
145
- //# sourceMappingURL=adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/gemini-cli/adapter.ts"],"names":[],"mappings":"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"}
@@ -1,169 +0,0 @@
1
- /**
2
- * Gemini CLI Hook Provider
3
- *
4
- * Maps Gemini CLI's native hook events to CAAMP canonical hook events.
5
- * Gemini CLI supports 11 canonical events through its hook system.
6
- *
7
- * Gemini CLI event mapping:
8
- * - SessionStart -> SessionStart
9
- * - SessionEnd -> SessionEnd
10
- * - PromptSubmit -> BeforeAgent
11
- * - ResponseComplete -> AfterAgent
12
- * - PreToolUse -> BeforeTool
13
- * - PostToolUse -> AfterTool
14
- * - PreModel -> BeforeModel
15
- * - PostModel -> AfterModel
16
- * - PreCompact -> PreCompress
17
- * - Notification -> Notification
18
- *
19
- * @task T161
20
- * @epic T134
21
- */
22
- import { readdir, readFile } from 'node:fs/promises';
23
- import { join } from 'node:path';
24
- /**
25
- * Mapping from Gemini CLI native event names to CAAMP canonical event names.
26
- */
27
- const GEMINI_CLI_EVENT_MAP = {
28
- SessionStart: 'SessionStart',
29
- SessionEnd: 'SessionEnd',
30
- PromptSubmit: 'BeforeAgent',
31
- ResponseComplete: 'AfterAgent',
32
- PreToolUse: 'BeforeTool',
33
- PostToolUse: 'AfterTool',
34
- PreModel: 'BeforeModel',
35
- PostModel: 'AfterModel',
36
- PreCompact: 'PreCompress',
37
- Notification: 'Notification',
38
- };
39
- /**
40
- * Hook provider for Gemini CLI.
41
- *
42
- * Gemini CLI registers hooks via its configuration system at
43
- * ~/.gemini/. Hook handlers are shell scripts or commands that
44
- * execute when the corresponding event fires.
45
- *
46
- * Since hooks are registered through the config system (managed by
47
- * the install provider), registerNativeHooks and unregisterNativeHooks
48
- * track registration state without performing filesystem operations.
49
- *
50
- * @task T161
51
- * @epic T134
52
- */
53
- export class GeminiCliHookProvider {
54
- registered = false;
55
- /**
56
- * Map a Gemini CLI native event name to a CAAMP hook event name.
57
- *
58
- * @param providerEvent - Gemini CLI event name (e.g. "SessionStart", "PreToolUse")
59
- * @returns CAAMP event name or null if unmapped
60
- * @task T161
61
- */
62
- mapProviderEvent(providerEvent) {
63
- return GEMINI_CLI_EVENT_MAP[providerEvent] ?? null;
64
- }
65
- /**
66
- * Register native hooks for a project.
67
- *
68
- * For Gemini CLI, hooks are registered via the config system
69
- * (~/.gemini/), which is handled by the install provider.
70
- * This method marks hooks as registered without performing
71
- * filesystem operations.
72
- *
73
- * @param _projectDir - Project directory (unused; hooks are global)
74
- * @task T161
75
- */
76
- async registerNativeHooks(_projectDir) {
77
- this.registered = true;
78
- }
79
- /**
80
- * Unregister native hooks.
81
- *
82
- * For Gemini CLI, this is a no-op since hooks are managed through
83
- * the config system. Unregistration happens via the install
84
- * provider's uninstall method.
85
- * @task T161
86
- */
87
- async unregisterNativeHooks() {
88
- this.registered = false;
89
- }
90
- /**
91
- * Check whether hooks have been registered via registerNativeHooks.
92
- * @task T161
93
- */
94
- isRegistered() {
95
- return this.registered;
96
- }
97
- /**
98
- * Get the full event mapping for introspection/debugging.
99
- * @task T161
100
- */
101
- getEventMap() {
102
- return { ...GEMINI_CLI_EVENT_MAP };
103
- }
104
- /**
105
- * Extract a plain-text transcript from Gemini CLI session data.
106
- *
107
- * Reads the most recent session file under ~/.gemini/ and extracts
108
- * turn text into a flat string for brain observation extraction.
109
- *
110
- * Returns null when no session data is found or on any read error.
111
- *
112
- * @param _sessionId - CLEO session ID (unused; reads the most recent file)
113
- * @param _projectDir - Project directory (unused; Gemini CLI uses global paths)
114
- * @task T161 @epic T134
115
- */
116
- async getTranscript(_sessionId, _projectDir) {
117
- try {
118
- const homeDir = process.env.HOME ?? process.env.USERPROFILE ?? '/root';
119
- const geminiDir = join(homeDir, '.gemini');
120
- let allFiles = [];
121
- try {
122
- const entries = await readdir(geminiDir, { withFileTypes: true });
123
- for (const entry of entries) {
124
- if (!entry.isFile())
125
- continue;
126
- const name = entry.name;
127
- if (name.endsWith('.json') || name.endsWith('.jsonl')) {
128
- allFiles.push(join(geminiDir, name));
129
- }
130
- }
131
- }
132
- catch {
133
- return null;
134
- }
135
- if (allFiles.length === 0)
136
- return null;
137
- // Sort descending by filename (timestamps in filenames sort naturally)
138
- allFiles = allFiles.sort((a, b) => b.localeCompare(a));
139
- const mostRecent = allFiles[0];
140
- if (!mostRecent)
141
- return null;
142
- const raw = await readFile(mostRecent, 'utf-8');
143
- const turns = [];
144
- // Support both JSONL (one JSON per line) and JSON array formats
145
- const lines = raw.split('\n').filter((l) => l.trim());
146
- for (const line of lines) {
147
- try {
148
- const entry = JSON.parse(line);
149
- const role = entry.role;
150
- const content = entry.content;
151
- if (role === 'assistant' && typeof content === 'string') {
152
- turns.push(`assistant: ${content}`);
153
- }
154
- else if (role === 'user' && typeof content === 'string') {
155
- turns.push(`user: ${content}`);
156
- }
157
- }
158
- catch {
159
- // Skip malformed lines
160
- }
161
- }
162
- return turns.length > 0 ? turns.join('\n') : null;
163
- }
164
- catch {
165
- return null;
166
- }
167
- }
168
- }
169
- //# sourceMappingURL=hooks.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/gemini-cli/hooks.ts"],"names":[],"mappings":"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"}
@@ -1,24 +0,0 @@
1
- /**
2
- * Gemini CLI provider adapter.
3
- *
4
- * CLEO provider adapter for Google Gemini CLI.
5
- * Default export is the adapter class for dynamic loading by AdapterManager.
6
- *
7
- * @task T161
8
- * @epic T134
9
- */
10
- import { GeminiCliAdapter } from './adapter.js';
11
- export { GeminiCliAdapter } from './adapter.js';
12
- export { GeminiCliHookProvider } from './hooks.js';
13
- export { GeminiCliInstallProvider } from './install.js';
14
- export default GeminiCliAdapter;
15
- /**
16
- * Factory function for creating adapter instances.
17
- * Used by AdapterManager's dynamic import fallback.
18
- *
19
- * @task T161
20
- */
21
- export function createAdapter() {
22
- return new GeminiCliAdapter();
23
- }
24
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/gemini-cli/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEhD,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAExD,eAAe,gBAAgB,CAAC;AAEhC;;;;;GAKG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,gBAAgB,EAAE,CAAC;AAChC,CAAC"}
@@ -1,183 +0,0 @@
1
- /**
2
- * Gemini CLI Install Provider
3
- *
4
- * Handles CLEO installation into Gemini CLI environments:
5
- * - Registers CLEO MCP server in ~/.gemini/settings.json
6
- * - Ensures AGENTS.md has CLEO @-references
7
- *
8
- * @task T161
9
- * @epic T134
10
- */
11
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
12
- import { homedir } from 'node:os';
13
- import { join } from 'node:path';
14
- /** Lines that should appear in AGENTS.md to reference CLEO. */
15
- const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
16
- /** MCP server registration key used in Gemini CLI settings. */
17
- const MCP_SERVER_KEY = 'cleo';
18
- /**
19
- * Install provider for Gemini CLI.
20
- *
21
- * Manages CLEO's integration with Gemini CLI by:
22
- * 1. Registering the CLEO MCP server in ~/.gemini/settings.json
23
- * 2. Ensuring AGENTS.md contains @-references to CLEO instruction files
24
- *
25
- * @task T161
26
- * @epic T134
27
- */
28
- export class GeminiCliInstallProvider {
29
- /**
30
- * Install CLEO into a Gemini CLI environment.
31
- *
32
- * @param options - Installation options including project directory and MCP server path
33
- * @returns Result describing what was installed
34
- * @task T161
35
- */
36
- async install(options) {
37
- const { projectDir, mcpServerPath } = options;
38
- const installedAt = new Date().toISOString();
39
- let instructionFileUpdated = false;
40
- let mcpRegistered = false;
41
- const details = {};
42
- // Step 1: Register MCP server in ~/.gemini/settings.json
43
- if (mcpServerPath) {
44
- mcpRegistered = this.registerMcpServer(mcpServerPath);
45
- if (mcpRegistered) {
46
- details.mcpConfigPath = join(homedir(), '.gemini', 'settings.json');
47
- }
48
- }
49
- // Step 2: Ensure AGENTS.md has @-references
50
- instructionFileUpdated = this.updateInstructionFile(projectDir);
51
- if (instructionFileUpdated) {
52
- details.instructionFile = join(projectDir, 'AGENTS.md');
53
- }
54
- return {
55
- success: true,
56
- installedAt,
57
- instructionFileUpdated,
58
- mcpRegistered,
59
- details,
60
- };
61
- }
62
- /**
63
- * Uninstall CLEO from the Gemini CLI environment.
64
- *
65
- * Removes the MCP server registration from ~/.gemini/settings.json.
66
- * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
67
- * @task T161
68
- */
69
- async uninstall() {
70
- const settingsPath = join(homedir(), '.gemini', 'settings.json');
71
- if (existsSync(settingsPath)) {
72
- try {
73
- const raw = readFileSync(settingsPath, 'utf-8');
74
- const config = JSON.parse(raw);
75
- const mcpServers = config.mcpServers;
76
- if (mcpServers && MCP_SERVER_KEY in mcpServers) {
77
- delete mcpServers[MCP_SERVER_KEY];
78
- writeFileSync(settingsPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
79
- }
80
- }
81
- catch {
82
- // Ignore errors during uninstall
83
- }
84
- }
85
- }
86
- /**
87
- * Check whether CLEO is installed in the Gemini CLI environment.
88
- *
89
- * Checks for MCP server registered in ~/.gemini/settings.json.
90
- * Returns true if the CLEO MCP server entry is found.
91
- * @task T161
92
- */
93
- async isInstalled() {
94
- const settingsPath = join(homedir(), '.gemini', 'settings.json');
95
- if (existsSync(settingsPath)) {
96
- try {
97
- const config = JSON.parse(readFileSync(settingsPath, 'utf-8'));
98
- const mcpServers = config.mcpServers;
99
- if (mcpServers && MCP_SERVER_KEY in mcpServers) {
100
- return true;
101
- }
102
- }
103
- catch {
104
- // Fall through
105
- }
106
- }
107
- return false;
108
- }
109
- /**
110
- * Ensure AGENTS.md contains @-references to CLEO instruction files.
111
- *
112
- * Creates AGENTS.md if it does not exist. Appends any missing references.
113
- *
114
- * @param projectDir - Project root directory
115
- * @task T161
116
- */
117
- async ensureInstructionReferences(projectDir) {
118
- this.updateInstructionFile(projectDir);
119
- }
120
- /**
121
- * Register the CLEO MCP server in ~/.gemini/settings.json.
122
- *
123
- * Gemini CLI stores its MCP server configuration in ~/.gemini/settings.json
124
- * under the mcpServers key.
125
- *
126
- * @param mcpServerPath - Absolute path to the MCP server entry point
127
- * @returns true if registration was performed or updated
128
- */
129
- registerMcpServer(mcpServerPath) {
130
- const geminiDir = join(homedir(), '.gemini');
131
- const settingsPath = join(geminiDir, 'settings.json');
132
- let config = {};
133
- mkdirSync(geminiDir, { recursive: true });
134
- if (existsSync(settingsPath)) {
135
- try {
136
- config = JSON.parse(readFileSync(settingsPath, 'utf-8'));
137
- }
138
- catch {
139
- // Start fresh on parse error
140
- }
141
- }
142
- if (!config.mcpServers || typeof config.mcpServers !== 'object') {
143
- config.mcpServers = {};
144
- }
145
- const mcpServers = config.mcpServers;
146
- mcpServers[MCP_SERVER_KEY] = {
147
- command: 'node',
148
- args: [mcpServerPath],
149
- };
150
- writeFileSync(settingsPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
151
- return true;
152
- }
153
- /**
154
- * Update AGENTS.md with CLEO @-references.
155
- *
156
- * @param projectDir - Project root directory
157
- * @returns true if the file was created or modified
158
- */
159
- updateInstructionFile(projectDir) {
160
- const agentsMdPath = join(projectDir, 'AGENTS.md');
161
- let content = '';
162
- let existed = false;
163
- if (existsSync(agentsMdPath)) {
164
- content = readFileSync(agentsMdPath, 'utf-8');
165
- existed = true;
166
- }
167
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
168
- if (missingRefs.length === 0) {
169
- return false;
170
- }
171
- const refsBlock = missingRefs.join('\n');
172
- if (existed) {
173
- const separator = content.endsWith('\n') ? '' : '\n';
174
- content = content + separator + refsBlock + '\n';
175
- }
176
- else {
177
- content = refsBlock + '\n';
178
- }
179
- writeFileSync(agentsMdPath, content, 'utf-8');
180
- return true;
181
- }
182
- }
183
- //# sourceMappingURL=install.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/gemini-cli/install.ts"],"names":[],"mappings":"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"}
@@ -1,133 +0,0 @@
1
- /**
2
- * Kimi Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for Moonshot AI Kimi.
5
- * Provides install-only capabilities for CLEO integration.
6
- * Kimi has no native hook system, so integration is via MCP only.
7
- *
8
- * @task T163
9
- * @epic T134
10
- */
11
- import { exec } from 'node:child_process';
12
- import { existsSync } from 'node:fs';
13
- import { homedir } from 'node:os';
14
- import { join } from 'node:path';
15
- import { promisify } from 'node:util';
16
- import { KimiHookProvider } from './hooks.js';
17
- import { KimiInstallProvider } from './install.js';
18
- const execAsync = promisify(exec);
19
- /**
20
- * CLEO provider adapter for Moonshot AI Kimi.
21
- *
22
- * Bridges CLEO's adapter system with Kimi's integration surface:
23
- * - Hooks: No-op (Kimi has no native hook system)
24
- * - Install: Registers MCP server in ~/.kimi/mcp.json and ensures AGENTS.md references
25
- *
26
- * @task T163
27
- * @epic T134
28
- */
29
- export class KimiAdapter {
30
- id = 'kimi';
31
- name = 'Kimi';
32
- version = '1.0.0';
33
- capabilities = {
34
- supportsHooks: false,
35
- supportedHookEvents: [],
36
- supportsSpawn: false,
37
- supportsInstall: true,
38
- supportsMcp: true,
39
- supportsInstructionFiles: false,
40
- supportsContextMonitor: false,
41
- supportsStatusline: false,
42
- supportsProviderPaths: false,
43
- supportsTransport: false,
44
- supportsTaskSync: false,
45
- };
46
- hooks;
47
- install;
48
- projectDir = null;
49
- initialized = false;
50
- constructor() {
51
- this.hooks = new KimiHookProvider();
52
- this.install = new KimiInstallProvider();
53
- }
54
- /**
55
- * Initialize the adapter for a given project directory.
56
- *
57
- * @param projectDir - Root directory of the project
58
- * @task T163
59
- */
60
- async initialize(projectDir) {
61
- this.projectDir = projectDir;
62
- this.initialized = true;
63
- }
64
- /**
65
- * Dispose the adapter and clean up resources.
66
- *
67
- * Releases tracked state. No hooks to unregister since Kimi
68
- * has no native hook system.
69
- * @task T163
70
- */
71
- async dispose() {
72
- this.initialized = false;
73
- this.projectDir = null;
74
- }
75
- /**
76
- * Run a health check to verify Kimi is accessible.
77
- *
78
- * Checks:
79
- * 1. Adapter has been initialized
80
- * 2. Kimi CLI binary is available in PATH
81
- * 3. ~/.kimi/ configuration directory exists
82
- *
83
- * @returns Health status with details about each check
84
- * @task T163
85
- */
86
- async healthCheck() {
87
- const details = {};
88
- if (!this.initialized) {
89
- return {
90
- healthy: false,
91
- provider: this.id,
92
- details: { error: 'Adapter not initialized' },
93
- };
94
- }
95
- // Check Kimi CLI availability
96
- let cliAvailable = false;
97
- try {
98
- const { stdout } = await execAsync('which kimi');
99
- cliAvailable = stdout.trim().length > 0;
100
- details.cliPath = stdout.trim();
101
- }
102
- catch {
103
- details.cliAvailable = false;
104
- }
105
- // Check for Kimi config directory
106
- const kimiConfigDir = join(homedir(), '.kimi');
107
- const configExists = existsSync(kimiConfigDir);
108
- details.configDirExists = configExists;
109
- // Healthy if CLI is available (primary requirement)
110
- const healthy = cliAvailable;
111
- details.cliAvailable = cliAvailable;
112
- return {
113
- healthy,
114
- provider: this.id,
115
- details,
116
- };
117
- }
118
- /**
119
- * Check whether the adapter has been initialized.
120
- * @task T163
121
- */
122
- isInitialized() {
123
- return this.initialized;
124
- }
125
- /**
126
- * Get the project directory this adapter was initialized with.
127
- * @task T163
128
- */
129
- getProjectDir() {
130
- return this.projectDir;
131
- }
132
- }
133
- //# sourceMappingURL=adapter.js.map