@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 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/kimi/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Kimi Hook Provider
|
|
3
|
-
*
|
|
4
|
-
* Kimi has no native hook system (hookSystem is "none").
|
|
5
|
-
* This provider implements the minimal AdapterHookProvider interface
|
|
6
|
-
* with a no-op mapProviderEvent that always returns null.
|
|
7
|
-
*
|
|
8
|
-
* @task T163
|
|
9
|
-
* @epic T134
|
|
10
|
-
*/
|
|
11
|
-
/**
|
|
12
|
-
* Hook provider for Kimi.
|
|
13
|
-
*
|
|
14
|
-
* Kimi does not expose a native hook or event system.
|
|
15
|
-
* All hook-related methods are no-ops; mapProviderEvent always
|
|
16
|
-
* returns null since there are no events to map.
|
|
17
|
-
*
|
|
18
|
-
* @task T163
|
|
19
|
-
* @epic T134
|
|
20
|
-
*/
|
|
21
|
-
export class KimiHookProvider {
|
|
22
|
-
registered = false;
|
|
23
|
-
/**
|
|
24
|
-
* Map a Kimi native event name to a CAAMP hook event name.
|
|
25
|
-
*
|
|
26
|
-
* Kimi has no hook system, so this always returns null.
|
|
27
|
-
*
|
|
28
|
-
* @param _providerEvent - Unused; Kimi emits no hookable events
|
|
29
|
-
* @returns Always null
|
|
30
|
-
* @task T163
|
|
31
|
-
*/
|
|
32
|
-
mapProviderEvent(_providerEvent) {
|
|
33
|
-
return null;
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* Register native hooks for a project.
|
|
37
|
-
*
|
|
38
|
-
* Kimi has no hook system. This method is a no-op and only
|
|
39
|
-
* tracks registration state for interface compliance.
|
|
40
|
-
*
|
|
41
|
-
* @param _projectDir - Project directory (unused)
|
|
42
|
-
* @task T163
|
|
43
|
-
*/
|
|
44
|
-
async registerNativeHooks(_projectDir) {
|
|
45
|
-
this.registered = true;
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Unregister native hooks.
|
|
49
|
-
*
|
|
50
|
-
* Kimi has no hook system. This method is a no-op.
|
|
51
|
-
* @task T163
|
|
52
|
-
*/
|
|
53
|
-
async unregisterNativeHooks() {
|
|
54
|
-
this.registered = false;
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Check whether hooks have been registered via registerNativeHooks.
|
|
58
|
-
* @task T163
|
|
59
|
-
*/
|
|
60
|
-
isRegistered() {
|
|
61
|
-
return this.registered;
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Get the full event mapping for introspection/debugging.
|
|
65
|
-
*
|
|
66
|
-
* Returns an empty map since Kimi has no hookable events.
|
|
67
|
-
* @task T163
|
|
68
|
-
*/
|
|
69
|
-
getEventMap() {
|
|
70
|
-
return {};
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
//# sourceMappingURL=hooks.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/kimi/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH;;;;;;;;;GASG;AACH,MAAM,OAAO,gBAAgB;IACnB,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;;;OAQG;IACH,gBAAgB,CAAC,cAAsB;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;OAKG;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;;;;;OAKG;IACH,WAAW;QACT,OAAO,EAAE,CAAC;IACZ,CAAC;CACF"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Kimi provider adapter.
|
|
3
|
-
*
|
|
4
|
-
* CLEO provider adapter for Moonshot AI Kimi.
|
|
5
|
-
* Default export is the adapter class for dynamic loading by AdapterManager.
|
|
6
|
-
*
|
|
7
|
-
* @task T163
|
|
8
|
-
* @epic T134
|
|
9
|
-
*/
|
|
10
|
-
import { KimiAdapter } from './adapter.js';
|
|
11
|
-
export { KimiAdapter } from './adapter.js';
|
|
12
|
-
export { KimiHookProvider } from './hooks.js';
|
|
13
|
-
export { KimiInstallProvider } from './install.js';
|
|
14
|
-
export default KimiAdapter;
|
|
15
|
-
/**
|
|
16
|
-
* Factory function for creating adapter instances.
|
|
17
|
-
* Used by AdapterManager's dynamic import fallback.
|
|
18
|
-
*
|
|
19
|
-
* @task T163
|
|
20
|
-
*/
|
|
21
|
-
export function createAdapter() {
|
|
22
|
-
return new KimiAdapter();
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/kimi/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,eAAe,WAAW,CAAC;AAE3B;;;;;GAKG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,WAAW,EAAE,CAAC;AAC3B,CAAC"}
|
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Kimi Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into Kimi environments:
|
|
5
|
-
* - Registers CLEO MCP server in ~/.kimi/mcp.json
|
|
6
|
-
* - Ensures AGENTS.md has CLEO @-references
|
|
7
|
-
*
|
|
8
|
-
* Kimi has no native hook system, so this is the primary integration
|
|
9
|
-
* mechanism: registering the MCP server so CLEO can be accessed as a tool.
|
|
10
|
-
*
|
|
11
|
-
* @task T163
|
|
12
|
-
* @epic T134
|
|
13
|
-
*/
|
|
14
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
|
|
15
|
-
import { homedir } from 'node:os';
|
|
16
|
-
import { join } from 'node:path';
|
|
17
|
-
/** Lines that should appear in AGENTS.md to reference CLEO. */
|
|
18
|
-
const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
|
|
19
|
-
/** MCP server registration key used in Kimi MCP config. */
|
|
20
|
-
const MCP_SERVER_KEY = 'cleo';
|
|
21
|
-
/**
|
|
22
|
-
* Install provider for Kimi.
|
|
23
|
-
*
|
|
24
|
-
* Manages CLEO's integration with Kimi by:
|
|
25
|
-
* 1. Registering the CLEO MCP server in ~/.kimi/mcp.json
|
|
26
|
-
* 2. Ensuring AGENTS.md contains @-references to CLEO instruction files
|
|
27
|
-
*
|
|
28
|
-
* Since Kimi has no native hook system, MCP registration is the only
|
|
29
|
-
* mechanism for surfacing CLEO capabilities inside a Kimi session.
|
|
30
|
-
*
|
|
31
|
-
* @task T163
|
|
32
|
-
* @epic T134
|
|
33
|
-
*/
|
|
34
|
-
export class KimiInstallProvider {
|
|
35
|
-
/**
|
|
36
|
-
* Install CLEO into a Kimi environment.
|
|
37
|
-
*
|
|
38
|
-
* @param options - Installation options including project directory and MCP server path
|
|
39
|
-
* @returns Result describing what was installed
|
|
40
|
-
* @task T163
|
|
41
|
-
*/
|
|
42
|
-
async install(options) {
|
|
43
|
-
const { projectDir, mcpServerPath } = options;
|
|
44
|
-
const installedAt = new Date().toISOString();
|
|
45
|
-
let instructionFileUpdated = false;
|
|
46
|
-
let mcpRegistered = false;
|
|
47
|
-
const details = {};
|
|
48
|
-
// Step 1: Register MCP server in ~/.kimi/mcp.json
|
|
49
|
-
if (mcpServerPath) {
|
|
50
|
-
mcpRegistered = this.registerMcpServer(mcpServerPath);
|
|
51
|
-
if (mcpRegistered) {
|
|
52
|
-
details.mcpConfigPath = join(homedir(), '.kimi', 'mcp.json');
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
// Step 2: Ensure AGENTS.md has @-references
|
|
56
|
-
instructionFileUpdated = this.updateInstructionFile(projectDir);
|
|
57
|
-
if (instructionFileUpdated) {
|
|
58
|
-
details.instructionFile = join(projectDir, 'AGENTS.md');
|
|
59
|
-
}
|
|
60
|
-
return {
|
|
61
|
-
success: true,
|
|
62
|
-
installedAt,
|
|
63
|
-
instructionFileUpdated,
|
|
64
|
-
mcpRegistered,
|
|
65
|
-
details,
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
/**
|
|
69
|
-
* Uninstall CLEO from the Kimi environment.
|
|
70
|
-
*
|
|
71
|
-
* Removes the MCP server registration from ~/.kimi/mcp.json.
|
|
72
|
-
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
73
|
-
* @task T163
|
|
74
|
-
*/
|
|
75
|
-
async uninstall() {
|
|
76
|
-
const mcpPath = join(homedir(), '.kimi', 'mcp.json');
|
|
77
|
-
if (existsSync(mcpPath)) {
|
|
78
|
-
try {
|
|
79
|
-
const raw = readFileSync(mcpPath, 'utf-8');
|
|
80
|
-
const config = JSON.parse(raw);
|
|
81
|
-
const mcpServers = config.mcpServers;
|
|
82
|
-
if (mcpServers && MCP_SERVER_KEY in mcpServers) {
|
|
83
|
-
delete mcpServers[MCP_SERVER_KEY];
|
|
84
|
-
writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
catch {
|
|
88
|
-
// Ignore errors during uninstall
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
/**
|
|
93
|
-
* Check whether CLEO is installed in the Kimi environment.
|
|
94
|
-
*
|
|
95
|
-
* Checks for MCP server registered in ~/.kimi/mcp.json.
|
|
96
|
-
* Returns true if the CLEO MCP server entry is found.
|
|
97
|
-
* @task T163
|
|
98
|
-
*/
|
|
99
|
-
async isInstalled() {
|
|
100
|
-
const mcpPath = join(homedir(), '.kimi', 'mcp.json');
|
|
101
|
-
if (existsSync(mcpPath)) {
|
|
102
|
-
try {
|
|
103
|
-
const config = JSON.parse(readFileSync(mcpPath, 'utf-8'));
|
|
104
|
-
const mcpServers = config.mcpServers;
|
|
105
|
-
if (mcpServers && MCP_SERVER_KEY in mcpServers) {
|
|
106
|
-
return true;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
catch {
|
|
110
|
-
// Fall through
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
return false;
|
|
114
|
-
}
|
|
115
|
-
/**
|
|
116
|
-
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
117
|
-
*
|
|
118
|
-
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
119
|
-
*
|
|
120
|
-
* @param projectDir - Project root directory
|
|
121
|
-
* @task T163
|
|
122
|
-
*/
|
|
123
|
-
async ensureInstructionReferences(projectDir) {
|
|
124
|
-
this.updateInstructionFile(projectDir);
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Register the CLEO MCP server in ~/.kimi/mcp.json.
|
|
128
|
-
*
|
|
129
|
-
* Kimi stores its MCP server configuration in ~/.kimi/mcp.json
|
|
130
|
-
* under the mcpServers key.
|
|
131
|
-
*
|
|
132
|
-
* @param mcpServerPath - Absolute path to the MCP server entry point
|
|
133
|
-
* @returns true if registration was performed or updated
|
|
134
|
-
*/
|
|
135
|
-
registerMcpServer(mcpServerPath) {
|
|
136
|
-
const kimiDir = join(homedir(), '.kimi');
|
|
137
|
-
const mcpPath = join(kimiDir, 'mcp.json');
|
|
138
|
-
let config = {};
|
|
139
|
-
mkdirSync(kimiDir, { recursive: true });
|
|
140
|
-
if (existsSync(mcpPath)) {
|
|
141
|
-
try {
|
|
142
|
-
config = JSON.parse(readFileSync(mcpPath, 'utf-8'));
|
|
143
|
-
}
|
|
144
|
-
catch {
|
|
145
|
-
// Start fresh on parse error
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
if (!config.mcpServers || typeof config.mcpServers !== 'object') {
|
|
149
|
-
config.mcpServers = {};
|
|
150
|
-
}
|
|
151
|
-
const mcpServers = config.mcpServers;
|
|
152
|
-
mcpServers[MCP_SERVER_KEY] = {
|
|
153
|
-
command: 'node',
|
|
154
|
-
args: [mcpServerPath],
|
|
155
|
-
};
|
|
156
|
-
writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
|
|
157
|
-
return true;
|
|
158
|
-
}
|
|
159
|
-
/**
|
|
160
|
-
* Update AGENTS.md with CLEO @-references.
|
|
161
|
-
*
|
|
162
|
-
* @param projectDir - Project root directory
|
|
163
|
-
* @returns true if the file was created or modified
|
|
164
|
-
*/
|
|
165
|
-
updateInstructionFile(projectDir) {
|
|
166
|
-
const agentsMdPath = join(projectDir, 'AGENTS.md');
|
|
167
|
-
let content = '';
|
|
168
|
-
let existed = false;
|
|
169
|
-
if (existsSync(agentsMdPath)) {
|
|
170
|
-
content = readFileSync(agentsMdPath, 'utf-8');
|
|
171
|
-
existed = true;
|
|
172
|
-
}
|
|
173
|
-
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
174
|
-
if (missingRefs.length === 0) {
|
|
175
|
-
return false;
|
|
176
|
-
}
|
|
177
|
-
const refsBlock = missingRefs.join('\n');
|
|
178
|
-
if (existed) {
|
|
179
|
-
const separator = content.endsWith('\n') ? '' : '\n';
|
|
180
|
-
content = content + separator + refsBlock + '\n';
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
content = refsBlock + '\n';
|
|
184
|
-
}
|
|
185
|
-
writeFileSync(agentsMdPath, content, 'utf-8');
|
|
186
|
-
return true;
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
//# sourceMappingURL=install.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/kimi/install.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Adapter
|
|
3
|
-
*
|
|
4
|
-
* Main CLEOProviderAdapter implementation for OpenCode AI coding assistant.
|
|
5
|
-
* Provides spawn, hooks, and install capabilities for CLEO integration.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { exec } from 'node:child_process';
|
|
10
|
-
import { existsSync } from 'node:fs';
|
|
11
|
-
import { join } from 'node:path';
|
|
12
|
-
import { promisify } from 'node:util';
|
|
13
|
-
import { OpenCodeHookProvider } from './hooks.js';
|
|
14
|
-
import { OpenCodeInstallProvider } from './install.js';
|
|
15
|
-
import { OpenCodeSpawnProvider } from './spawn.js';
|
|
16
|
-
const execAsync = promisify(exec);
|
|
17
|
-
/**
|
|
18
|
-
* CLEO provider adapter for OpenCode AI coding assistant.
|
|
19
|
-
*
|
|
20
|
-
* Bridges CLEO's adapter system with OpenCode's native capabilities:
|
|
21
|
-
* - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events
|
|
22
|
-
* - Spawn: Launches subagent processes via the `opencode` CLI
|
|
23
|
-
* - Install: Registers MCP server in .opencode/config.json and ensures AGENTS.md references
|
|
24
|
-
*/
|
|
25
|
-
export class OpenCodeAdapter {
|
|
26
|
-
id = 'opencode';
|
|
27
|
-
name = 'OpenCode';
|
|
28
|
-
version = '1.0.0';
|
|
29
|
-
capabilities = {
|
|
30
|
-
supportsHooks: true,
|
|
31
|
-
// 10/16 canonical events — derived from getProviderHookProfile('opencode') in CAAMP 1.9.1.
|
|
32
|
-
// PostToolUseFailure, SubagentStart, SubagentStop, Notification, ConfigChange are
|
|
33
|
-
// not supported by OpenCode's plugin system.
|
|
34
|
-
supportedHookEvents: [
|
|
35
|
-
'SessionStart',
|
|
36
|
-
'SessionEnd',
|
|
37
|
-
'PromptSubmit',
|
|
38
|
-
'ResponseComplete',
|
|
39
|
-
'PreToolUse',
|
|
40
|
-
'PostToolUse',
|
|
41
|
-
'PermissionRequest',
|
|
42
|
-
'PreModel',
|
|
43
|
-
'PreCompact',
|
|
44
|
-
'PostCompact',
|
|
45
|
-
],
|
|
46
|
-
supportsSpawn: true,
|
|
47
|
-
supportsInstall: true,
|
|
48
|
-
supportsMcp: true,
|
|
49
|
-
supportsInstructionFiles: true,
|
|
50
|
-
instructionFilePattern: 'AGENTS.md',
|
|
51
|
-
supportsContextMonitor: false,
|
|
52
|
-
supportsStatusline: false,
|
|
53
|
-
supportsProviderPaths: true,
|
|
54
|
-
supportsTransport: false,
|
|
55
|
-
supportsTaskSync: false,
|
|
56
|
-
};
|
|
57
|
-
hooks;
|
|
58
|
-
spawn;
|
|
59
|
-
install;
|
|
60
|
-
projectDir = null;
|
|
61
|
-
initialized = false;
|
|
62
|
-
constructor() {
|
|
63
|
-
this.hooks = new OpenCodeHookProvider();
|
|
64
|
-
this.spawn = new OpenCodeSpawnProvider();
|
|
65
|
-
this.install = new OpenCodeInstallProvider();
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Initialize the adapter for a given project directory.
|
|
69
|
-
*
|
|
70
|
-
* Validates the environment by checking for the OpenCode CLI
|
|
71
|
-
* and OpenCode configuration directory.
|
|
72
|
-
*
|
|
73
|
-
* @param projectDir - Root directory of the project
|
|
74
|
-
*/
|
|
75
|
-
async initialize(projectDir) {
|
|
76
|
-
this.projectDir = projectDir;
|
|
77
|
-
this.initialized = true;
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* Dispose the adapter and clean up resources.
|
|
81
|
-
*
|
|
82
|
-
* Unregisters hooks and releases any tracked state.
|
|
83
|
-
*/
|
|
84
|
-
async dispose() {
|
|
85
|
-
if (this.hooks.isRegistered()) {
|
|
86
|
-
await this.hooks.unregisterNativeHooks();
|
|
87
|
-
}
|
|
88
|
-
this.initialized = false;
|
|
89
|
-
this.projectDir = null;
|
|
90
|
-
}
|
|
91
|
-
/**
|
|
92
|
-
* Run a health check to verify OpenCode is accessible.
|
|
93
|
-
*
|
|
94
|
-
* Checks:
|
|
95
|
-
* 1. Adapter has been initialized
|
|
96
|
-
* 2. OpenCode CLI is available in PATH
|
|
97
|
-
* 3. .opencode/ configuration directory exists in the project
|
|
98
|
-
*
|
|
99
|
-
* @returns Health status with details about each check
|
|
100
|
-
*/
|
|
101
|
-
async healthCheck() {
|
|
102
|
-
const details = {};
|
|
103
|
-
if (!this.initialized) {
|
|
104
|
-
return {
|
|
105
|
-
healthy: false,
|
|
106
|
-
provider: this.id,
|
|
107
|
-
details: { error: 'Adapter not initialized' },
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
// Check OpenCode CLI availability
|
|
111
|
-
let cliAvailable = false;
|
|
112
|
-
try {
|
|
113
|
-
const { stdout } = await execAsync('which opencode');
|
|
114
|
-
cliAvailable = stdout.trim().length > 0;
|
|
115
|
-
details.cliPath = stdout.trim();
|
|
116
|
-
}
|
|
117
|
-
catch {
|
|
118
|
-
details.cliAvailable = false;
|
|
119
|
-
}
|
|
120
|
-
// Check for OpenCode config directory in the project
|
|
121
|
-
if (this.projectDir) {
|
|
122
|
-
const openCodeConfigDir = join(this.projectDir, '.opencode');
|
|
123
|
-
const configExists = existsSync(openCodeConfigDir);
|
|
124
|
-
details.configDirExists = configExists;
|
|
125
|
-
}
|
|
126
|
-
// Check for OPENCODE_VERSION env var
|
|
127
|
-
const versionEnvSet = process.env.OPENCODE_VERSION !== undefined;
|
|
128
|
-
details.versionEnvSet = versionEnvSet;
|
|
129
|
-
// Healthy if CLI is available (primary requirement)
|
|
130
|
-
const healthy = cliAvailable;
|
|
131
|
-
details.cliAvailable = cliAvailable;
|
|
132
|
-
return {
|
|
133
|
-
healthy,
|
|
134
|
-
provider: this.id,
|
|
135
|
-
details,
|
|
136
|
-
};
|
|
137
|
-
}
|
|
138
|
-
/**
|
|
139
|
-
* Check whether the adapter has been initialized.
|
|
140
|
-
*/
|
|
141
|
-
isInitialized() {
|
|
142
|
-
return this.initialized;
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Get the project directory this adapter was initialized with.
|
|
146
|
-
*/
|
|
147
|
-
getProjectDir() {
|
|
148
|
-
return this.projectDir;
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
//# sourceMappingURL=adapter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/opencode/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,197 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Hook Provider
|
|
3
|
-
*
|
|
4
|
-
* Maps OpenCode's native hook events to CAAMP canonical hook events.
|
|
5
|
-
* OpenCode supports 10 of 16 canonical events through its plugin system.
|
|
6
|
-
*
|
|
7
|
-
* Event translation uses CAAMP normalizer APIs:
|
|
8
|
-
* - `toCanonical(nativeName, 'opencode')` for runtime event name resolution
|
|
9
|
-
* - `getSupportedEvents('opencode')` to enumerate supported canonical events
|
|
10
|
-
* - `getProviderHookProfile('opencode')` for the full provider profile
|
|
11
|
-
*
|
|
12
|
-
* OpenCode uses a JavaScript plugin system with event-prefixed names
|
|
13
|
-
* (e.g. `event:session.created`) for some hooks and bare names for others.
|
|
14
|
-
* The map is derived from `getProviderHookProfile('opencode').mappings` in
|
|
15
|
-
* CAAMP 1.9.1. PostToolUseFailure, SubagentStart, SubagentStop, Notification,
|
|
16
|
-
* and ConfigChange are not supported by OpenCode.
|
|
17
|
-
*
|
|
18
|
-
* @task T164
|
|
19
|
-
* @epic T134
|
|
20
|
-
*/
|
|
21
|
-
/** CAAMP provider identifier for OpenCode. */
|
|
22
|
-
const PROVIDER_ID = 'opencode';
|
|
23
|
-
/**
|
|
24
|
-
* Fallback map from OpenCode native event names to CAAMP canonical names.
|
|
25
|
-
*
|
|
26
|
-
* Derived from `getProviderHookProfile('opencode').mappings` in CAAMP 1.9.1.
|
|
27
|
-
* Covers all 10 supported events. PostToolUseFailure, SubagentStart,
|
|
28
|
-
* SubagentStop, Notification, and ConfigChange are not supported by OpenCode
|
|
29
|
-
* and are absent from this map.
|
|
30
|
-
*
|
|
31
|
-
* OpenCode uses dot-delimited and event-prefixed names (e.g. "event:session.created")
|
|
32
|
-
* while CAAMP canonical names are PascalCase (e.g. "SessionStart").
|
|
33
|
-
*/
|
|
34
|
-
const OPENCODE_EVENT_MAP = {
|
|
35
|
-
// CAAMP: toNative('SessionStart', 'opencode') = 'event:session.created'
|
|
36
|
-
'event:session.created': 'SessionStart',
|
|
37
|
-
// CAAMP: toNative('SessionEnd', 'opencode') = 'event:session.deleted'
|
|
38
|
-
'event:session.deleted': 'SessionEnd',
|
|
39
|
-
// CAAMP: toNative('PromptSubmit', 'opencode') = 'chat.message'
|
|
40
|
-
'chat.message': 'PromptSubmit',
|
|
41
|
-
// CAAMP: toNative('ResponseComplete', 'opencode') = 'event:session.idle'
|
|
42
|
-
'event:session.idle': 'ResponseComplete',
|
|
43
|
-
// CAAMP: toNative('PreToolUse', 'opencode') = 'tool.execute.before'
|
|
44
|
-
'tool.execute.before': 'PreToolUse',
|
|
45
|
-
// CAAMP: toNative('PostToolUse', 'opencode') = 'tool.execute.after'
|
|
46
|
-
'tool.execute.after': 'PostToolUse',
|
|
47
|
-
// CAAMP: toNative('PermissionRequest', 'opencode') = 'permission.ask'
|
|
48
|
-
'permission.ask': 'PermissionRequest',
|
|
49
|
-
// CAAMP: toNative('PreModel', 'opencode') = 'chat.params'
|
|
50
|
-
'chat.params': 'PreModel',
|
|
51
|
-
// CAAMP: toNative('PreCompact', 'opencode') = 'experimental.session.compacting'
|
|
52
|
-
'experimental.session.compacting': 'PreCompact',
|
|
53
|
-
// CAAMP: toNative('PostCompact', 'opencode') = 'event:session.compacted'
|
|
54
|
-
'event:session.compacted': 'PostCompact',
|
|
55
|
-
};
|
|
56
|
-
/**
|
|
57
|
-
* Hook provider for OpenCode.
|
|
58
|
-
*
|
|
59
|
-
* OpenCode registers hooks via its JavaScript plugin system at
|
|
60
|
-
* `.opencode/plugins/`. Supported handler type: plugin (JavaScript).
|
|
61
|
-
*
|
|
62
|
-
* Event mapping is based on `getProviderHookProfile('opencode')` from
|
|
63
|
-
* CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
|
|
64
|
-
* `getProviderProfile`) call CAAMP directly when available.
|
|
65
|
-
*
|
|
66
|
-
* Since hooks are registered through the plugin system (managed by the install
|
|
67
|
-
* provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
|
|
68
|
-
* state without performing filesystem operations.
|
|
69
|
-
*
|
|
70
|
-
* @task T164
|
|
71
|
-
* @epic T134
|
|
72
|
-
*/
|
|
73
|
-
export class OpenCodeHookProvider {
|
|
74
|
-
registered = false;
|
|
75
|
-
/**
|
|
76
|
-
* Map an OpenCode native event name to a CAAMP canonical hook event name.
|
|
77
|
-
*
|
|
78
|
-
* Looks up the native event name in the map derived from
|
|
79
|
-
* `getProviderHookProfile('opencode').mappings` (CAAMP 1.9.1).
|
|
80
|
-
* Returns null for unsupported events (PostToolUseFailure, SubagentStart,
|
|
81
|
-
* SubagentStop, Notification, ConfigChange).
|
|
82
|
-
*
|
|
83
|
-
* @param providerEvent - OpenCode native event (e.g. "event:session.created", "tool.execute.before")
|
|
84
|
-
* @returns CAAMP canonical event name, or null if unmapped
|
|
85
|
-
* @task T164
|
|
86
|
-
*/
|
|
87
|
-
mapProviderEvent(providerEvent) {
|
|
88
|
-
return OPENCODE_EVENT_MAP[providerEvent] ?? null;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Register native hooks for a project.
|
|
92
|
-
*
|
|
93
|
-
* For OpenCode, hooks are registered via the plugin system
|
|
94
|
-
* (`.opencode/plugins/`), managed by the install provider.
|
|
95
|
-
* This method marks hooks as registered without performing filesystem operations.
|
|
96
|
-
*
|
|
97
|
-
* Iterating supported events is handled at install time using
|
|
98
|
-
* `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
|
|
99
|
-
*
|
|
100
|
-
* @param _projectDir - Project directory (unused; config manages registration)
|
|
101
|
-
* @task T164
|
|
102
|
-
*/
|
|
103
|
-
async registerNativeHooks(_projectDir) {
|
|
104
|
-
this.registered = true;
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* Unregister native hooks.
|
|
108
|
-
*
|
|
109
|
-
* For OpenCode, this is a no-op since hooks are managed through the plugin
|
|
110
|
-
* system. Unregistration happens via the install provider's uninstall method.
|
|
111
|
-
*
|
|
112
|
-
* @task T164
|
|
113
|
-
*/
|
|
114
|
-
async unregisterNativeHooks() {
|
|
115
|
-
this.registered = false;
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* Check whether hooks have been registered via `registerNativeHooks`.
|
|
119
|
-
*/
|
|
120
|
-
isRegistered() {
|
|
121
|
-
return this.registered;
|
|
122
|
-
}
|
|
123
|
-
/**
|
|
124
|
-
* Get the native→canonical event mapping for introspection and debugging.
|
|
125
|
-
*
|
|
126
|
-
* Returns the map derived from `getProviderHookProfile('opencode').mappings`
|
|
127
|
-
* (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
|
|
128
|
-
* names via live CAAMP APIs.
|
|
129
|
-
*
|
|
130
|
-
* @returns Immutable record of native event name → canonical event name
|
|
131
|
-
*/
|
|
132
|
-
getEventMap() {
|
|
133
|
-
return { ...OPENCODE_EVENT_MAP };
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
|
|
137
|
-
*
|
|
138
|
-
* Calls `getSupportedEvents('opencode')` from the CAAMP normalizer to get the
|
|
139
|
-
* authoritative list. OpenCode supports 10 of 16 canonical events via its
|
|
140
|
-
* plugin system. Falls back to the values of the static event map when
|
|
141
|
-
* CAAMP is unavailable at runtime.
|
|
142
|
-
*
|
|
143
|
-
* @returns Array of CAAMP canonical event names supported by OpenCode
|
|
144
|
-
* @task T164
|
|
145
|
-
*/
|
|
146
|
-
async getSupportedCanonicalEvents() {
|
|
147
|
-
try {
|
|
148
|
-
const { getSupportedEvents } = await import('@cleocode/caamp');
|
|
149
|
-
return getSupportedEvents(PROVIDER_ID);
|
|
150
|
-
}
|
|
151
|
-
catch {
|
|
152
|
-
return [...new Set(Object.values(OPENCODE_EVENT_MAP))];
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Retrieve the full provider hook profile from CAAMP.
|
|
157
|
-
*
|
|
158
|
-
* Calls `getProviderHookProfile('opencode')` from the CAAMP normalizer to
|
|
159
|
-
* get the complete profile: hook system type (`plugin`), config path
|
|
160
|
-
* (`.opencode/plugins/`), handler types, and all event mappings.
|
|
161
|
-
* Returns null when CAAMP is unavailable at runtime.
|
|
162
|
-
*
|
|
163
|
-
* @returns Provider hook profile or null if CAAMP is unavailable
|
|
164
|
-
* @task T164
|
|
165
|
-
*/
|
|
166
|
-
async getProviderProfile() {
|
|
167
|
-
try {
|
|
168
|
-
const { getProviderHookProfile } = await import('@cleocode/caamp');
|
|
169
|
-
return getProviderHookProfile(PROVIDER_ID) ?? null;
|
|
170
|
-
}
|
|
171
|
-
catch {
|
|
172
|
-
return null;
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
/**
|
|
176
|
-
* Translate a CAAMP canonical event to its OpenCode native name via CAAMP.
|
|
177
|
-
*
|
|
178
|
-
* Calls `toNative(canonical, 'opencode')` from the CAAMP normalizer.
|
|
179
|
-
* Returns null for unsupported events or when CAAMP is unavailable.
|
|
180
|
-
*
|
|
181
|
-
* @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
|
|
182
|
-
* @returns OpenCode native event name or null
|
|
183
|
-
* @task T164
|
|
184
|
-
*/
|
|
185
|
-
async toNativeEvent(canonical) {
|
|
186
|
-
try {
|
|
187
|
-
const { toNative } = await import('@cleocode/caamp');
|
|
188
|
-
return toNative(canonical, PROVIDER_ID);
|
|
189
|
-
}
|
|
190
|
-
catch {
|
|
191
|
-
// Invert the static map as fallback
|
|
192
|
-
const entry = Object.entries(OPENCODE_EVENT_MAP).find(([, v]) => v === canonical);
|
|
193
|
-
return entry?.[0] ?? null;
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
//# sourceMappingURL=hooks.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/opencode/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAIH,8CAA8C;AAC9C,MAAM,WAAW,GAAG,UAAmB,CAAC;AAExC;;;;;;;;;;GAUG;AACH,MAAM,kBAAkB,GAA2B;IACjD,8EAA8E;IAC9E,uBAAuB,EAAE,cAAc;IACvC,8EAA8E;IAC9E,uBAAuB,EAAE,YAAY;IACrC,qEAAqE;IACrE,cAAc,EAAE,cAAc;IAC9B,2EAA2E;IAC3E,oBAAoB,EAAE,kBAAkB;IACxC,4EAA4E;IAC5E,qBAAqB,EAAE,YAAY;IACnC,2EAA2E;IAC3E,oBAAoB,EAAE,aAAa;IACnC,uEAAuE;IACvE,gBAAgB,EAAE,mBAAmB;IACrC,oEAAoE;IACpE,aAAa,EAAE,UAAU;IACzB,wFAAwF;IACxF,iCAAiC,EAAE,YAAY;IAC/C,gFAAgF;IAChF,yBAAyB,EAAE,aAAa;CACzC,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,OAAO,oBAAoB;IACvB,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;;;;;;OAWG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,kBAAkB,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IACnD,CAAC;IAED;;;;;;;;;;;;OAYG;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;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;;OAQG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,kBAAkB,EAAE,CAAC;IACnC,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,2BAA2B;QAC/B,IAAI,CAAC;YACH,MAAM,EAAE,kBAAkB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAC/D,OAAO,kBAAkB,CAAC,WAAW,CAAa,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,kBAAkB;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,sBAAsB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACnE,OAAO,sBAAsB,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,aAAa,CAAC,SAAiB;QACnC,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACrD,OAAO,QAAQ,CAAC,SAA2C,EAAE,WAAW,CAAC,CAAC;QAC5E,CAAC;QAAC,MAAM,CAAC;YACP,oCAAoC;YACpC,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;YAClF,OAAO,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;CACF"}
|