@cleocode/adapters 2026.4.11 → 2026.4.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +3 -3
- package/src/__tests__/claude-code-adapter.test.ts +1 -3
- package/src/__tests__/cursor-adapter.test.ts +1 -3
- package/src/__tests__/opencode-adapter.test.ts +1 -3
- package/src/providers/claude-code/__tests__/adapter.test.ts +0 -12
- package/src/providers/claude-code/adapter.ts +0 -1
- package/src/providers/claude-code/install.ts +0 -1
- package/src/providers/codex/adapter.ts +0 -1
- package/src/providers/codex/install.ts +0 -1
- package/src/providers/cursor/__tests__/adapter.test.ts +0 -12
- package/src/providers/cursor/adapter.ts +0 -1
- package/src/providers/cursor/install.ts +0 -1
- package/src/providers/gemini-cli/adapter.ts +0 -1
- package/src/providers/gemini-cli/install.ts +0 -1
- package/src/providers/kimi/adapter.ts +0 -1
- package/src/providers/kimi/install.ts +0 -1
- package/src/providers/opencode/__tests__/adapter.test.ts +0 -12
- package/src/providers/opencode/adapter.ts +0 -1
- package/src/providers/opencode/install.ts +0 -1
- package/dist/index.d.ts +0 -23
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -3258
- package/dist/index.js.map +0 -7
- package/dist/providers/claude-code/adapter.d.ts +0 -95
- package/dist/providers/claude-code/adapter.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -185
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.d.ts +0 -35
- package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -159
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.d.ts +0 -146
- package/dist/providers/claude-code/hooks.d.ts.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -286
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.d.ts +0 -39
- package/dist/providers/claude-code/index.d.ts.map +0 -1
- package/dist/providers/claude-code/index.js +0 -41
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.d.ts +0 -67
- package/dist/providers/claude-code/install.d.ts.map +0 -1
- package/dist/providers/claude-code/install.js +0 -161
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.d.ts +0 -32
- package/dist/providers/claude-code/paths.d.ts.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -41
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.d.ts +0 -67
- package/dist/providers/claude-code/spawn.d.ts.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -171
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.d.ts +0 -68
- package/dist/providers/claude-code/statusline.d.ts.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -130
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.d.ts +0 -32
- package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -119
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.d.ts +0 -25
- package/dist/providers/claude-code/transport.d.ts.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -29
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/codex/adapter.d.ts +0 -83
- package/dist/providers/codex/adapter.d.ts.map +0 -1
- package/dist/providers/codex/adapter.js +0 -147
- package/dist/providers/codex/adapter.js.map +0 -1
- package/dist/providers/codex/hooks.d.ts +0 -91
- package/dist/providers/codex/hooks.d.ts.map +0 -1
- package/dist/providers/codex/hooks.js +0 -113
- package/dist/providers/codex/hooks.js.map +0 -1
- package/dist/providers/codex/index.d.ts +0 -37
- package/dist/providers/codex/index.d.ts.map +0 -1
- package/dist/providers/codex/index.js +0 -39
- package/dist/providers/codex/index.js.map +0 -1
- package/dist/providers/codex/install.d.ts +0 -65
- package/dist/providers/codex/install.d.ts.map +0 -1
- package/dist/providers/codex/install.js +0 -125
- package/dist/providers/codex/install.js.map +0 -1
- package/dist/providers/cursor/adapter.d.ts +0 -76
- package/dist/providers/cursor/adapter.d.ts.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -152
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.d.ts +0 -140
- package/dist/providers/cursor/hooks.d.ts.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -208
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.d.ts +0 -34
- package/dist/providers/cursor/index.d.ts.map +0 -1
- package/dist/providers/cursor/index.js +0 -36
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.d.ts +0 -87
- package/dist/providers/cursor/install.d.ts.map +0 -1
- package/dist/providers/cursor/install.js +0 -181
- package/dist/providers/cursor/install.js.map +0 -1
- package/dist/providers/cursor/spawn.d.ts +0 -50
- package/dist/providers/cursor/spawn.d.ts.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.d.ts +0 -84
- package/dist/providers/gemini-cli/adapter.d.ts.map +0 -1
- package/dist/providers/gemini-cli/adapter.js +0 -159
- package/dist/providers/gemini-cli/adapter.js.map +0 -1
- package/dist/providers/gemini-cli/hooks.d.ts +0 -99
- package/dist/providers/gemini-cli/hooks.d.ts.map +0 -1
- package/dist/providers/gemini-cli/hooks.js +0 -128
- package/dist/providers/gemini-cli/hooks.js.map +0 -1
- package/dist/providers/gemini-cli/index.d.ts +0 -37
- package/dist/providers/gemini-cli/index.d.ts.map +0 -1
- package/dist/providers/gemini-cli/index.js +0 -39
- package/dist/providers/gemini-cli/index.js.map +0 -1
- package/dist/providers/gemini-cli/install.d.ts +0 -65
- package/dist/providers/gemini-cli/install.d.ts.map +0 -1
- package/dist/providers/gemini-cli/install.js +0 -125
- package/dist/providers/gemini-cli/install.js.map +0 -1
- package/dist/providers/kimi/adapter.d.ts +0 -85
- package/dist/providers/kimi/adapter.d.ts.map +0 -1
- package/dist/providers/kimi/adapter.js +0 -146
- package/dist/providers/kimi/adapter.js.map +0 -1
- package/dist/providers/kimi/hooks.d.ts +0 -70
- package/dist/providers/kimi/hooks.d.ts.map +0 -1
- package/dist/providers/kimi/hooks.js +0 -79
- package/dist/providers/kimi/hooks.js.map +0 -1
- package/dist/providers/kimi/index.d.ts +0 -37
- package/dist/providers/kimi/index.d.ts.map +0 -1
- package/dist/providers/kimi/index.js +0 -39
- package/dist/providers/kimi/index.js.map +0 -1
- package/dist/providers/kimi/install.d.ts +0 -65
- package/dist/providers/kimi/install.d.ts.map +0 -1
- package/dist/providers/kimi/install.js +0 -125
- package/dist/providers/kimi/install.js.map +0 -1
- package/dist/providers/opencode/adapter.d.ts +0 -83
- package/dist/providers/opencode/adapter.d.ts.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -167
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.d.ts +0 -136
- package/dist/providers/opencode/hooks.d.ts.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -206
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.d.ts +0 -35
- package/dist/providers/opencode/index.d.ts.map +0 -1
- package/dist/providers/opencode/index.js +0 -37
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.d.ts +0 -56
- package/dist/providers/opencode/install.d.ts.map +0 -1
- package/dist/providers/opencode/install.js +0 -116
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.d.ts +0 -94
- package/dist/providers/opencode/spawn.d.ts.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -241
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/providers/shared/transcript-reader.d.ts +0 -58
- package/dist/providers/shared/transcript-reader.d.ts.map +0 -1
- package/dist/providers/shared/transcript-reader.js +0 -124
- package/dist/providers/shared/transcript-reader.js.map +0 -1
- package/dist/registry.d.ts +0 -88
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js +0 -88
- package/dist/registry.js.map +0 -1
|
@@ -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;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,WAAW,EAAE,CAAC;AAC3B,CAAC"}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Kimi Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into Kimi environments:
|
|
5
|
-
* - Ensures AGENTS.md has CLEO @-references
|
|
6
|
-
*
|
|
7
|
-
* @task T163
|
|
8
|
-
* @epic T134
|
|
9
|
-
*/
|
|
10
|
-
import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
|
|
11
|
-
/**
|
|
12
|
-
* Install provider for Kimi.
|
|
13
|
-
*
|
|
14
|
-
* Manages CLEO's integration with Kimi by:
|
|
15
|
-
* 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
|
|
16
|
-
*
|
|
17
|
-
* @remarks
|
|
18
|
-
* Installation is idempotent -- running install multiple times on the same
|
|
19
|
-
* project produces the same result. Only AGENTS.md is managed; Kimi does
|
|
20
|
-
* not have an MCP or plugin registration mechanism.
|
|
21
|
-
*
|
|
22
|
-
* @task T163
|
|
23
|
-
* @epic T134
|
|
24
|
-
*/
|
|
25
|
-
export declare class KimiInstallProvider implements AdapterInstallProvider {
|
|
26
|
-
/**
|
|
27
|
-
* Install CLEO into a Kimi environment.
|
|
28
|
-
*
|
|
29
|
-
* @param options - Installation options including project directory
|
|
30
|
-
* @returns Result describing what was installed
|
|
31
|
-
* @task T163
|
|
32
|
-
*/
|
|
33
|
-
install(options: InstallOptions): Promise<InstallResult>;
|
|
34
|
-
/**
|
|
35
|
-
* Uninstall CLEO from the Kimi environment.
|
|
36
|
-
*
|
|
37
|
-
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
38
|
-
* @task T163
|
|
39
|
-
*/
|
|
40
|
-
uninstall(): Promise<void>;
|
|
41
|
-
/**
|
|
42
|
-
* Check whether CLEO is installed in the Kimi environment.
|
|
43
|
-
*
|
|
44
|
-
* Checks for CLEO references in AGENTS.md.
|
|
45
|
-
* @task T163
|
|
46
|
-
*/
|
|
47
|
-
isInstalled(): Promise<boolean>;
|
|
48
|
-
/**
|
|
49
|
-
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
50
|
-
*
|
|
51
|
-
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
52
|
-
*
|
|
53
|
-
* @param projectDir - Project root directory
|
|
54
|
-
* @task T163
|
|
55
|
-
*/
|
|
56
|
-
ensureInstructionReferences(projectDir: string): Promise<void>;
|
|
57
|
-
/**
|
|
58
|
-
* Update AGENTS.md with CLEO @-references.
|
|
59
|
-
*
|
|
60
|
-
* @param projectDir - Project root directory
|
|
61
|
-
* @returns true if the file was created or modified
|
|
62
|
-
*/
|
|
63
|
-
private updateInstructionFile;
|
|
64
|
-
}
|
|
65
|
-
//# sourceMappingURL=install.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/kimi/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;;;;GAaG;AACH,qBAAa,mBAAoB,YAAW,sBAAsB;IAChE;;;;;;OAMG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAqB9D;;;;;OAKG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAIhC;;;;;OAKG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAgBrC;;;;;;;OAOG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;;OAKG;IACH,OAAO,CAAC,qBAAqB;CA4B9B"}
|
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Kimi Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into Kimi environments:
|
|
5
|
-
* - Ensures AGENTS.md has CLEO @-references
|
|
6
|
-
*
|
|
7
|
-
* @task T163
|
|
8
|
-
* @epic T134
|
|
9
|
-
*/
|
|
10
|
-
import { existsSync, readFileSync, writeFileSync } from 'node:fs';
|
|
11
|
-
import { join } from 'node:path';
|
|
12
|
-
/** Lines that should appear in AGENTS.md to reference CLEO. */
|
|
13
|
-
const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
|
|
14
|
-
/**
|
|
15
|
-
* Install provider for Kimi.
|
|
16
|
-
*
|
|
17
|
-
* Manages CLEO's integration with Kimi by:
|
|
18
|
-
* 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
|
|
19
|
-
*
|
|
20
|
-
* @remarks
|
|
21
|
-
* Installation is idempotent -- running install multiple times on the same
|
|
22
|
-
* project produces the same result. Only AGENTS.md is managed; Kimi does
|
|
23
|
-
* not have an MCP or plugin registration mechanism.
|
|
24
|
-
*
|
|
25
|
-
* @task T163
|
|
26
|
-
* @epic T134
|
|
27
|
-
*/
|
|
28
|
-
export class KimiInstallProvider {
|
|
29
|
-
/**
|
|
30
|
-
* Install CLEO into a Kimi environment.
|
|
31
|
-
*
|
|
32
|
-
* @param options - Installation options including project directory
|
|
33
|
-
* @returns Result describing what was installed
|
|
34
|
-
* @task T163
|
|
35
|
-
*/
|
|
36
|
-
async install(options) {
|
|
37
|
-
const { projectDir } = options;
|
|
38
|
-
const installedAt = new Date().toISOString();
|
|
39
|
-
let instructionFileUpdated = false;
|
|
40
|
-
const details = {};
|
|
41
|
-
// Step 1: Ensure AGENTS.md has @-references
|
|
42
|
-
instructionFileUpdated = this.updateInstructionFile(projectDir);
|
|
43
|
-
if (instructionFileUpdated) {
|
|
44
|
-
details.instructionFile = join(projectDir, 'AGENTS.md');
|
|
45
|
-
}
|
|
46
|
-
return {
|
|
47
|
-
success: true,
|
|
48
|
-
installedAt,
|
|
49
|
-
instructionFileUpdated,
|
|
50
|
-
mcpRegistered: false,
|
|
51
|
-
details,
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Uninstall CLEO from the Kimi environment.
|
|
56
|
-
*
|
|
57
|
-
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
58
|
-
* @task T163
|
|
59
|
-
*/
|
|
60
|
-
async uninstall() {
|
|
61
|
-
// No-op: no MCP registration to remove
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Check whether CLEO is installed in the Kimi environment.
|
|
65
|
-
*
|
|
66
|
-
* Checks for CLEO references in AGENTS.md.
|
|
67
|
-
* @task T163
|
|
68
|
-
*/
|
|
69
|
-
async isInstalled() {
|
|
70
|
-
const agentsMdPath = join(process.cwd(), 'AGENTS.md');
|
|
71
|
-
if (existsSync(agentsMdPath)) {
|
|
72
|
-
try {
|
|
73
|
-
const content = readFileSync(agentsMdPath, 'utf-8');
|
|
74
|
-
if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
|
|
75
|
-
return true;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
catch {
|
|
79
|
-
// Fall through
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return false;
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
86
|
-
*
|
|
87
|
-
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
88
|
-
*
|
|
89
|
-
* @param projectDir - Project root directory
|
|
90
|
-
* @task T163
|
|
91
|
-
*/
|
|
92
|
-
async ensureInstructionReferences(projectDir) {
|
|
93
|
-
this.updateInstructionFile(projectDir);
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Update AGENTS.md with CLEO @-references.
|
|
97
|
-
*
|
|
98
|
-
* @param projectDir - Project root directory
|
|
99
|
-
* @returns true if the file was created or modified
|
|
100
|
-
*/
|
|
101
|
-
updateInstructionFile(projectDir) {
|
|
102
|
-
const agentsMdPath = join(projectDir, 'AGENTS.md');
|
|
103
|
-
let content = '';
|
|
104
|
-
let existed = false;
|
|
105
|
-
if (existsSync(agentsMdPath)) {
|
|
106
|
-
content = readFileSync(agentsMdPath, 'utf-8');
|
|
107
|
-
existed = true;
|
|
108
|
-
}
|
|
109
|
-
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
110
|
-
if (missingRefs.length === 0) {
|
|
111
|
-
return false;
|
|
112
|
-
}
|
|
113
|
-
const refsBlock = missingRefs.join('\n');
|
|
114
|
-
if (existed) {
|
|
115
|
-
const separator = content.endsWith('\n') ? '' : '\n';
|
|
116
|
-
content = content + separator + refsBlock + '\n';
|
|
117
|
-
}
|
|
118
|
-
else {
|
|
119
|
-
content = refsBlock + '\n';
|
|
120
|
-
}
|
|
121
|
-
writeFileSync(agentsMdPath, content, 'utf-8');
|
|
122
|
-
return true;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
//# 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,83 +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 type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
|
|
10
|
-
import { OpenCodeHookProvider } from './hooks.js';
|
|
11
|
-
import { OpenCodeInstallProvider } from './install.js';
|
|
12
|
-
import { OpenCodeSpawnProvider } from './spawn.js';
|
|
13
|
-
/**
|
|
14
|
-
* CLEO provider adapter for OpenCode AI coding assistant.
|
|
15
|
-
*
|
|
16
|
-
* Bridges CLEO's adapter system with OpenCode's native capabilities:
|
|
17
|
-
* - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events
|
|
18
|
-
* - Spawn: Launches subagent processes via the `opencode` CLI
|
|
19
|
-
* - Install: Ensures AGENTS.md references for CLEO instruction files
|
|
20
|
-
*
|
|
21
|
-
* @remarks
|
|
22
|
-
* OpenCode is the second-most feature-complete adapter after Claude Code,
|
|
23
|
-
* supporting 10 canonical events through its JavaScript plugin system,
|
|
24
|
-
* subagent spawning via the `opencode run` CLI command, and instruction
|
|
25
|
-
* file management via AGENTS.md. It uniquely supports PreModel via the
|
|
26
|
-
* `chat.params` event, which allows pre-inference parameter injection.
|
|
27
|
-
*/
|
|
28
|
-
export declare class OpenCodeAdapter implements CLEOProviderAdapter {
|
|
29
|
-
/** Unique provider identifier. */
|
|
30
|
-
readonly id = "opencode";
|
|
31
|
-
/** Human-readable provider name. */
|
|
32
|
-
readonly name = "OpenCode";
|
|
33
|
-
/** Adapter version string. */
|
|
34
|
-
readonly version = "1.0.0";
|
|
35
|
-
/** Declared capabilities for this provider. */
|
|
36
|
-
capabilities: AdapterCapabilities;
|
|
37
|
-
/** Hook provider for CAAMP event mapping via OpenCode's plugin system. */
|
|
38
|
-
hooks: OpenCodeHookProvider;
|
|
39
|
-
/** Spawn provider for launching subagent processes via `opencode run`. */
|
|
40
|
-
spawn: OpenCodeSpawnProvider;
|
|
41
|
-
/** Install provider for managing AGENTS.md instruction files. */
|
|
42
|
-
install: OpenCodeInstallProvider;
|
|
43
|
-
/** Project directory this adapter was initialized with, or null. */
|
|
44
|
-
private projectDir;
|
|
45
|
-
/** Whether {@link initialize} has been called. */
|
|
46
|
-
private initialized;
|
|
47
|
-
constructor();
|
|
48
|
-
/**
|
|
49
|
-
* Initialize the adapter for a given project directory.
|
|
50
|
-
*
|
|
51
|
-
* Validates the environment by checking for the OpenCode CLI
|
|
52
|
-
* and OpenCode configuration directory.
|
|
53
|
-
*
|
|
54
|
-
* @param projectDir - Root directory of the project
|
|
55
|
-
*/
|
|
56
|
-
initialize(projectDir: string): Promise<void>;
|
|
57
|
-
/**
|
|
58
|
-
* Dispose the adapter and clean up resources.
|
|
59
|
-
*
|
|
60
|
-
* Unregisters hooks and releases any tracked state.
|
|
61
|
-
*/
|
|
62
|
-
dispose(): Promise<void>;
|
|
63
|
-
/**
|
|
64
|
-
* Run a health check to verify OpenCode is accessible.
|
|
65
|
-
*
|
|
66
|
-
* Checks:
|
|
67
|
-
* 1. Adapter has been initialized
|
|
68
|
-
* 2. OpenCode CLI is available in PATH
|
|
69
|
-
* 3. .opencode/ configuration directory exists in the project
|
|
70
|
-
*
|
|
71
|
-
* @returns Health status with details about each check
|
|
72
|
-
*/
|
|
73
|
-
healthCheck(): Promise<AdapterHealthStatus>;
|
|
74
|
-
/**
|
|
75
|
-
* Check whether the adapter has been initialized.
|
|
76
|
-
*/
|
|
77
|
-
isInitialized(): boolean;
|
|
78
|
-
/**
|
|
79
|
-
* Get the project directory this adapter was initialized with.
|
|
80
|
-
*/
|
|
81
|
-
getProjectDir(): string | null;
|
|
82
|
-
}
|
|
83
|
-
//# sourceMappingURL=adapter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAInD;;;;;;;;;;;;;;GAcG;AACH,qBAAa,eAAgB,YAAW,mBAAmB;IACzD,kCAAkC;IAClC,QAAQ,CAAC,EAAE,cAAc;IACzB,oCAAoC;IACpC,QAAQ,CAAC,IAAI,cAAc;IAC3B,8BAA8B;IAC9B,QAAQ,CAAC,OAAO,WAAW;IAE3B,+CAA+C;IAC/C,YAAY,EAAE,mBAAmB,CA2B/B;IAEF,0EAA0E;IAC1E,KAAK,EAAE,oBAAoB,CAAC;IAC5B,0EAA0E;IAC1E,KAAK,EAAE,qBAAqB,CAAC;IAC7B,iEAAiE;IACjE,OAAO,EAAE,uBAAuB,CAAC;IAEjC,oEAAoE;IACpE,OAAO,CAAC,UAAU,CAAuB;IACzC,kDAAkD;IAClD,OAAO,CAAC,WAAW,CAAS;;IAQ5B;;;;;;;OAOG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;;;OAIG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IA2CjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
|
|
@@ -1,167 +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: Ensures AGENTS.md references for CLEO instruction files
|
|
24
|
-
*
|
|
25
|
-
* @remarks
|
|
26
|
-
* OpenCode is the second-most feature-complete adapter after Claude Code,
|
|
27
|
-
* supporting 10 canonical events through its JavaScript plugin system,
|
|
28
|
-
* subagent spawning via the `opencode run` CLI command, and instruction
|
|
29
|
-
* file management via AGENTS.md. It uniquely supports PreModel via the
|
|
30
|
-
* `chat.params` event, which allows pre-inference parameter injection.
|
|
31
|
-
*/
|
|
32
|
-
export class OpenCodeAdapter {
|
|
33
|
-
/** Unique provider identifier. */
|
|
34
|
-
id = 'opencode';
|
|
35
|
-
/** Human-readable provider name. */
|
|
36
|
-
name = 'OpenCode';
|
|
37
|
-
/** Adapter version string. */
|
|
38
|
-
version = '1.0.0';
|
|
39
|
-
/** Declared capabilities for this provider. */
|
|
40
|
-
capabilities = {
|
|
41
|
-
supportsHooks: true,
|
|
42
|
-
// 10/16 canonical events — derived from getProviderHookProfile('opencode') in CAAMP 1.9.1.
|
|
43
|
-
// PostToolUseFailure, SubagentStart, SubagentStop, Notification, ConfigChange are
|
|
44
|
-
// not supported by OpenCode's plugin system.
|
|
45
|
-
supportedHookEvents: [
|
|
46
|
-
'SessionStart',
|
|
47
|
-
'SessionEnd',
|
|
48
|
-
'PromptSubmit',
|
|
49
|
-
'ResponseComplete',
|
|
50
|
-
'PreToolUse',
|
|
51
|
-
'PostToolUse',
|
|
52
|
-
'PermissionRequest',
|
|
53
|
-
'PreModel',
|
|
54
|
-
'PreCompact',
|
|
55
|
-
'PostCompact',
|
|
56
|
-
],
|
|
57
|
-
supportsSpawn: true,
|
|
58
|
-
supportsInstall: true,
|
|
59
|
-
supportsMcp: false,
|
|
60
|
-
supportsInstructionFiles: true,
|
|
61
|
-
instructionFilePattern: 'AGENTS.md',
|
|
62
|
-
supportsContextMonitor: false,
|
|
63
|
-
supportsStatusline: false,
|
|
64
|
-
supportsProviderPaths: true,
|
|
65
|
-
supportsTransport: false,
|
|
66
|
-
supportsTaskSync: false,
|
|
67
|
-
};
|
|
68
|
-
/** Hook provider for CAAMP event mapping via OpenCode's plugin system. */
|
|
69
|
-
hooks;
|
|
70
|
-
/** Spawn provider for launching subagent processes via `opencode run`. */
|
|
71
|
-
spawn;
|
|
72
|
-
/** Install provider for managing AGENTS.md instruction files. */
|
|
73
|
-
install;
|
|
74
|
-
/** Project directory this adapter was initialized with, or null. */
|
|
75
|
-
projectDir = null;
|
|
76
|
-
/** Whether {@link initialize} has been called. */
|
|
77
|
-
initialized = false;
|
|
78
|
-
constructor() {
|
|
79
|
-
this.hooks = new OpenCodeHookProvider();
|
|
80
|
-
this.spawn = new OpenCodeSpawnProvider();
|
|
81
|
-
this.install = new OpenCodeInstallProvider();
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Initialize the adapter for a given project directory.
|
|
85
|
-
*
|
|
86
|
-
* Validates the environment by checking for the OpenCode CLI
|
|
87
|
-
* and OpenCode configuration directory.
|
|
88
|
-
*
|
|
89
|
-
* @param projectDir - Root directory of the project
|
|
90
|
-
*/
|
|
91
|
-
async initialize(projectDir) {
|
|
92
|
-
this.projectDir = projectDir;
|
|
93
|
-
this.initialized = true;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Dispose the adapter and clean up resources.
|
|
97
|
-
*
|
|
98
|
-
* Unregisters hooks and releases any tracked state.
|
|
99
|
-
*/
|
|
100
|
-
async dispose() {
|
|
101
|
-
if (this.hooks.isRegistered()) {
|
|
102
|
-
await this.hooks.unregisterNativeHooks();
|
|
103
|
-
}
|
|
104
|
-
this.initialized = false;
|
|
105
|
-
this.projectDir = null;
|
|
106
|
-
}
|
|
107
|
-
/**
|
|
108
|
-
* Run a health check to verify OpenCode is accessible.
|
|
109
|
-
*
|
|
110
|
-
* Checks:
|
|
111
|
-
* 1. Adapter has been initialized
|
|
112
|
-
* 2. OpenCode CLI is available in PATH
|
|
113
|
-
* 3. .opencode/ configuration directory exists in the project
|
|
114
|
-
*
|
|
115
|
-
* @returns Health status with details about each check
|
|
116
|
-
*/
|
|
117
|
-
async healthCheck() {
|
|
118
|
-
const details = {};
|
|
119
|
-
if (!this.initialized) {
|
|
120
|
-
return {
|
|
121
|
-
healthy: false,
|
|
122
|
-
provider: this.id,
|
|
123
|
-
details: { error: 'Adapter not initialized' },
|
|
124
|
-
};
|
|
125
|
-
}
|
|
126
|
-
// Check OpenCode CLI availability
|
|
127
|
-
let cliAvailable = false;
|
|
128
|
-
try {
|
|
129
|
-
const { stdout } = await execAsync('which opencode');
|
|
130
|
-
cliAvailable = stdout.trim().length > 0;
|
|
131
|
-
details.cliPath = stdout.trim();
|
|
132
|
-
}
|
|
133
|
-
catch {
|
|
134
|
-
details.cliAvailable = false;
|
|
135
|
-
}
|
|
136
|
-
// Check for OpenCode config directory in the project
|
|
137
|
-
if (this.projectDir) {
|
|
138
|
-
const openCodeConfigDir = join(this.projectDir, '.opencode');
|
|
139
|
-
const configExists = existsSync(openCodeConfigDir);
|
|
140
|
-
details.configDirExists = configExists;
|
|
141
|
-
}
|
|
142
|
-
// Check for OPENCODE_VERSION env var
|
|
143
|
-
const versionEnvSet = process.env.OPENCODE_VERSION !== undefined;
|
|
144
|
-
details.versionEnvSet = versionEnvSet;
|
|
145
|
-
// Healthy if CLI is available (primary requirement)
|
|
146
|
-
const healthy = cliAvailable;
|
|
147
|
-
details.cliAvailable = cliAvailable;
|
|
148
|
-
return {
|
|
149
|
-
healthy,
|
|
150
|
-
provider: this.id,
|
|
151
|
-
details,
|
|
152
|
-
};
|
|
153
|
-
}
|
|
154
|
-
/**
|
|
155
|
-
* Check whether the adapter has been initialized.
|
|
156
|
-
*/
|
|
157
|
-
isInitialized() {
|
|
158
|
-
return this.initialized;
|
|
159
|
-
}
|
|
160
|
-
/**
|
|
161
|
-
* Get the project directory this adapter was initialized with.
|
|
162
|
-
*/
|
|
163
|
-
getProjectDir() {
|
|
164
|
-
return this.projectDir;
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
//# 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,136 +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
|
-
import type { AdapterHookProvider } from '@cleocode/contracts';
|
|
22
|
-
/**
|
|
23
|
-
* Hook provider for OpenCode.
|
|
24
|
-
*
|
|
25
|
-
* OpenCode registers hooks via its JavaScript plugin system at
|
|
26
|
-
* `.opencode/plugins/`. Supported handler type: plugin (JavaScript).
|
|
27
|
-
*
|
|
28
|
-
* Event mapping is based on `getProviderHookProfile('opencode')` from
|
|
29
|
-
* CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
|
|
30
|
-
* `getProviderProfile`) call CAAMP directly when available.
|
|
31
|
-
*
|
|
32
|
-
* Since hooks are registered through the plugin system (managed by the install
|
|
33
|
-
* provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
|
|
34
|
-
* state without performing filesystem operations.
|
|
35
|
-
*
|
|
36
|
-
* @remarks
|
|
37
|
-
* OpenCode uses dot-delimited and `event:`-prefixed event names
|
|
38
|
-
* (e.g. `event:session.created`, `tool.execute.before`) which differ
|
|
39
|
-
* significantly from the PascalCase CAAMP canonical names. The static
|
|
40
|
-
* event map covers all 10 supported events. Async CAAMP accessors
|
|
41
|
-
* (`getSupportedCanonicalEvents`, `getProviderProfile`, `toNativeEvent`)
|
|
42
|
-
* call the normalizer directly when available and fall back to the static map.
|
|
43
|
-
*
|
|
44
|
-
* @task T164
|
|
45
|
-
* @epic T134
|
|
46
|
-
*/
|
|
47
|
-
export declare class OpenCodeHookProvider implements AdapterHookProvider {
|
|
48
|
-
/** Whether hooks have been registered for the current session. */
|
|
49
|
-
private registered;
|
|
50
|
-
/**
|
|
51
|
-
* Map an OpenCode native event name to a CAAMP canonical hook event name.
|
|
52
|
-
*
|
|
53
|
-
* Looks up the native event name in the map derived from
|
|
54
|
-
* `getProviderHookProfile('opencode').mappings` (CAAMP 1.9.1).
|
|
55
|
-
* Returns null for unsupported events (PostToolUseFailure, SubagentStart,
|
|
56
|
-
* SubagentStop, Notification, ConfigChange).
|
|
57
|
-
*
|
|
58
|
-
* @param providerEvent - OpenCode native event (e.g. "event:session.created", "tool.execute.before")
|
|
59
|
-
* @returns CAAMP canonical event name, or null if unmapped
|
|
60
|
-
* @task T164
|
|
61
|
-
*/
|
|
62
|
-
mapProviderEvent(providerEvent: string): string | null;
|
|
63
|
-
/**
|
|
64
|
-
* Register native hooks for a project.
|
|
65
|
-
*
|
|
66
|
-
* For OpenCode, hooks are registered via the plugin system
|
|
67
|
-
* (`.opencode/plugins/`), managed by the install provider.
|
|
68
|
-
* This method marks hooks as registered without performing filesystem operations.
|
|
69
|
-
*
|
|
70
|
-
* Iterating supported events is handled at install time using
|
|
71
|
-
* `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
|
|
72
|
-
*
|
|
73
|
-
* @param _projectDir - Project directory (unused; config manages registration)
|
|
74
|
-
* @task T164
|
|
75
|
-
*/
|
|
76
|
-
registerNativeHooks(_projectDir: string): Promise<void>;
|
|
77
|
-
/**
|
|
78
|
-
* Unregister native hooks.
|
|
79
|
-
*
|
|
80
|
-
* For OpenCode, this is a no-op since hooks are managed through the plugin
|
|
81
|
-
* system. Unregistration happens via the install provider's uninstall method.
|
|
82
|
-
*
|
|
83
|
-
* @task T164
|
|
84
|
-
*/
|
|
85
|
-
unregisterNativeHooks(): Promise<void>;
|
|
86
|
-
/**
|
|
87
|
-
* Check whether hooks have been registered via `registerNativeHooks`.
|
|
88
|
-
*/
|
|
89
|
-
isRegistered(): boolean;
|
|
90
|
-
/**
|
|
91
|
-
* Get the native→canonical event mapping for introspection and debugging.
|
|
92
|
-
*
|
|
93
|
-
* Returns the map derived from `getProviderHookProfile('opencode').mappings`
|
|
94
|
-
* (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
|
|
95
|
-
* names via live CAAMP APIs.
|
|
96
|
-
*
|
|
97
|
-
* @returns Immutable record of native event name → canonical event name
|
|
98
|
-
*/
|
|
99
|
-
getEventMap(): Readonly<Record<string, string>>;
|
|
100
|
-
/**
|
|
101
|
-
* Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
|
|
102
|
-
*
|
|
103
|
-
* Calls `getSupportedEvents('opencode')` from the CAAMP normalizer to get the
|
|
104
|
-
* authoritative list. OpenCode supports 10 of 16 canonical events via its
|
|
105
|
-
* plugin system. Falls back to the values of the static event map when
|
|
106
|
-
* CAAMP is unavailable at runtime.
|
|
107
|
-
*
|
|
108
|
-
* @returns Array of CAAMP canonical event names supported by OpenCode
|
|
109
|
-
* @task T164
|
|
110
|
-
*/
|
|
111
|
-
getSupportedCanonicalEvents(): Promise<string[]>;
|
|
112
|
-
/**
|
|
113
|
-
* Retrieve the full provider hook profile from CAAMP.
|
|
114
|
-
*
|
|
115
|
-
* Calls `getProviderHookProfile('opencode')` from the CAAMP normalizer to
|
|
116
|
-
* get the complete profile: hook system type (`plugin`), config path
|
|
117
|
-
* (`.opencode/plugins/`), handler types, and all event mappings.
|
|
118
|
-
* Returns null when CAAMP is unavailable at runtime.
|
|
119
|
-
*
|
|
120
|
-
* @returns Provider hook profile or null if CAAMP is unavailable
|
|
121
|
-
* @task T164
|
|
122
|
-
*/
|
|
123
|
-
getProviderProfile(): Promise<unknown | null>;
|
|
124
|
-
/**
|
|
125
|
-
* Translate a CAAMP canonical event to its OpenCode native name via CAAMP.
|
|
126
|
-
*
|
|
127
|
-
* Calls `toNative(canonical, 'opencode')` from the CAAMP normalizer.
|
|
128
|
-
* Returns null for unsupported events or when CAAMP is unavailable.
|
|
129
|
-
*
|
|
130
|
-
* @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
|
|
131
|
-
* @returns OpenCode native event name or null
|
|
132
|
-
* @task T164
|
|
133
|
-
*/
|
|
134
|
-
toNativeEvent(canonical: string): Promise<string | null>;
|
|
135
|
-
}
|
|
136
|
-
//# sourceMappingURL=hooks.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAuC/D;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,qBAAa,oBAAqB,YAAW,mBAAmB;IAC9D,kEAAkE;IAClE,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;;;;;;;OAWG;IACH,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItD;;;;;;;;;;;;OAYG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;;;OAOG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;IAIvB;;;;;;;;OAQG;IACH,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAI/C;;;;;;;;;;OAUG;IACG,2BAA2B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAStD;;;;;;;;;;OAUG;IACG,kBAAkB,IAAI,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IASnD;;;;;;;;;OASG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAU/D"}
|