@cleocode/adapters 2026.3.74 → 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.
- package/dist/index.js +132 -154
- package/dist/index.js.map +4 -4
- package/dist/providers/codex/hooks.d.ts +2 -2
- package/dist/providers/codex/hooks.d.ts.map +1 -1
- package/dist/providers/gemini-cli/hooks.d.ts +2 -2
- package/dist/providers/gemini-cli/hooks.d.ts.map +1 -1
- package/dist/providers/shared/transcript-reader.d.ts +43 -0
- package/dist/providers/shared/transcript-reader.d.ts.map +1 -0
- package/package.json +3 -3
- package/src/providers/codex/hooks.ts +5 -52
- package/src/providers/gemini-cli/hooks.ts +5 -52
- package/src/providers/shared/transcript-reader.ts +123 -0
- package/dist/providers/claude-code/adapter.js +0 -165
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -148
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -279
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.js +0 -26
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.js +0 -234
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -33
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -164
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -86
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -111
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -18
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/codex/adapter.js +0 -134
- package/dist/providers/codex/adapter.js.map +0 -1
- package/dist/providers/codex/hooks.js +0 -155
- package/dist/providers/codex/hooks.js.map +0 -1
- package/dist/providers/codex/index.js +0 -24
- package/dist/providers/codex/index.js.map +0 -1
- package/dist/providers/codex/install.js +0 -183
- package/dist/providers/codex/install.js.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -138
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -201
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.js +0 -21
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.js +0 -238
- package/dist/providers/cursor/install.js.map +0 -1
- package/dist/providers/cursor/spawn.js +0 -59
- package/dist/providers/cursor/spawn.js.map +0 -1
- package/dist/providers/gemini-cli/adapter.js +0 -145
- package/dist/providers/gemini-cli/adapter.js.map +0 -1
- package/dist/providers/gemini-cli/hooks.js +0 -169
- package/dist/providers/gemini-cli/hooks.js.map +0 -1
- package/dist/providers/gemini-cli/index.js +0 -24
- package/dist/providers/gemini-cli/index.js.map +0 -1
- package/dist/providers/gemini-cli/install.js +0 -183
- package/dist/providers/gemini-cli/install.js.map +0 -1
- package/dist/providers/kimi/adapter.js +0 -133
- package/dist/providers/kimi/adapter.js.map +0 -1
- package/dist/providers/kimi/hooks.js +0 -73
- package/dist/providers/kimi/hooks.js.map +0 -1
- package/dist/providers/kimi/index.js +0 -24
- package/dist/providers/kimi/index.js.map +0 -1
- package/dist/providers/kimi/install.js +0 -189
- package/dist/providers/kimi/install.js.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -151
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -197
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.js +0 -22
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.js +0 -180
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -219
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/registry.js +0 -55
- 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":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC;;GAEG;AACH,MAAM,oBAAoB,GAA2B;IACnD,YAAY,EAAE,cAAc;IAC5B,UAAU,EAAE,YAAY;IACxB,YAAY,EAAE,aAAa;IAC3B,gBAAgB,EAAE,YAAY;IAC9B,UAAU,EAAE,YAAY;IACxB,WAAW,EAAE,WAAW;IACxB,QAAQ,EAAE,aAAa;IACvB,SAAS,EAAE,YAAY;IACvB,UAAU,EAAE,aAAa;IACzB,YAAY,EAAE,cAAc;CAC7B,CAAC;AAEF;;;;;;;;;;;;;GAaG;AACH,MAAM,OAAO,qBAAqB;IACxB,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;OAMG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,oBAAoB,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IACrD,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,qBAAqB;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,oBAAoB,EAAE,CAAC;IACrC,CAAC;IAED;;;;;;;;;;;OAWG;IACH,KAAK,CAAC,aAAa,CAAC,UAAkB,EAAE,WAAmB;QACzD,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,OAAO,CAAC;YACvE,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;YAE3C,IAAI,QAAQ,GAAa,EAAE,CAAC;YAC5B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,SAAS,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;gBAClE,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;oBAC5B,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;wBAAE,SAAS;oBAC9B,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;oBACxB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;wBACtD,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC;oBACvC,CAAC;gBACH,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,IAAI,CAAC;YACd,CAAC;YAED,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,IAAI,CAAC;YAEvC,uEAAuE;YACvE,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;YACvD,MAAM,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC/B,IAAI,CAAC,UAAU;gBAAE,OAAO,IAAI,CAAC;YAE7B,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;YAChD,MAAM,KAAK,GAAa,EAAE,CAAC;YAE3B,gEAAgE;YAChE,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;YACtD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,IAAI,CAAC;oBACH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAA4B,CAAC;oBAC1D,MAAM,IAAI,GAAG,KAAK,CAAC,IAA0B,CAAC;oBAC9C,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;oBAC9B,IAAI,IAAI,KAAK,WAAW,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;wBACxD,KAAK,CAAC,IAAI,CAAC,cAAc,OAAO,EAAE,CAAC,CAAC;oBACtC,CAAC;yBAAM,IAAI,IAAI,KAAK,MAAM,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;wBAC1D,KAAK,CAAC,IAAI,CAAC,SAAS,OAAO,EAAE,CAAC,CAAC;oBACjC,CAAC;gBACH,CAAC;gBAAC,MAAM,CAAC;oBACP,uBAAuB;gBACzB,CAAC;YACH,CAAC;YAED,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACpD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;CACF"}
|
|
@@ -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
|