@cleocode/adapters 2026.4.57 → 2026.4.59
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/cant-context.js +711 -0
- package/dist/cant-context.js.map +1 -0
- package/dist/providers/claude-code/adapter.js +222 -0
- package/dist/providers/claude-code/adapter.js.map +1 -0
- package/dist/providers/claude-code/context-monitor.js +159 -0
- package/dist/providers/claude-code/context-monitor.js.map +1 -0
- package/dist/providers/claude-code/hooks.js +395 -0
- package/dist/providers/claude-code/hooks.js.map +1 -0
- package/dist/providers/claude-code/index.js +41 -0
- package/dist/providers/claude-code/index.js.map +1 -0
- package/dist/providers/claude-code/install.js +199 -0
- package/dist/providers/claude-code/install.js.map +1 -0
- package/dist/providers/claude-code/paths.js +41 -0
- package/dist/providers/claude-code/paths.js.map +1 -0
- package/dist/providers/claude-code/spawn.js +198 -0
- package/dist/providers/claude-code/spawn.js.map +1 -0
- package/dist/providers/claude-code/statusline.js +130 -0
- package/dist/providers/claude-code/statusline.js.map +1 -0
- package/dist/providers/claude-code/task-sync.js +119 -0
- package/dist/providers/claude-code/task-sync.js.map +1 -0
- package/dist/providers/claude-code/transport.js +29 -0
- package/dist/providers/claude-code/transport.js.map +1 -0
- package/dist/providers/claude-sdk/index.js +16 -0
- package/dist/providers/claude-sdk/index.js.map +1 -0
- package/dist/providers/claude-sdk/mcp-registry.js +66 -0
- package/dist/providers/claude-sdk/mcp-registry.js.map +1 -0
- package/dist/providers/claude-sdk/session-store.js +84 -0
- package/dist/providers/claude-sdk/session-store.js.map +1 -0
- package/dist/providers/claude-sdk/spawn.js +225 -0
- package/dist/providers/claude-sdk/spawn.js.map +1 -0
- package/dist/providers/claude-sdk/tool-bridge.js +50 -0
- package/dist/providers/claude-sdk/tool-bridge.js.map +1 -0
- package/dist/providers/codex/adapter.js +146 -0
- package/dist/providers/codex/adapter.js.map +1 -0
- package/dist/providers/codex/hooks.js +113 -0
- package/dist/providers/codex/hooks.js.map +1 -0
- package/dist/providers/codex/index.js +39 -0
- package/dist/providers/codex/index.js.map +1 -0
- package/dist/providers/codex/install.js +124 -0
- package/dist/providers/codex/install.js.map +1 -0
- package/dist/providers/cursor/adapter.js +151 -0
- package/dist/providers/cursor/adapter.js.map +1 -0
- package/dist/providers/cursor/hooks.js +208 -0
- package/dist/providers/cursor/hooks.js.map +1 -0
- package/dist/providers/cursor/index.js +36 -0
- package/dist/providers/cursor/index.js.map +1 -0
- package/dist/providers/cursor/install.js +180 -0
- package/dist/providers/cursor/install.js.map +1 -0
- package/dist/providers/cursor/spawn.js +59 -0
- package/dist/providers/cursor/spawn.js.map +1 -0
- package/dist/providers/gemini-cli/adapter.js +158 -0
- package/dist/providers/gemini-cli/adapter.js.map +1 -0
- package/dist/providers/gemini-cli/hooks.js +128 -0
- package/dist/providers/gemini-cli/hooks.js.map +1 -0
- package/dist/providers/gemini-cli/index.js +39 -0
- package/dist/providers/gemini-cli/index.js.map +1 -0
- package/dist/providers/gemini-cli/install.js +124 -0
- package/dist/providers/gemini-cli/install.js.map +1 -0
- package/dist/providers/kimi/adapter.js +145 -0
- package/dist/providers/kimi/adapter.js.map +1 -0
- package/dist/providers/kimi/hooks.js +79 -0
- package/dist/providers/kimi/hooks.js.map +1 -0
- package/dist/providers/kimi/index.js +39 -0
- package/dist/providers/kimi/index.js.map +1 -0
- package/dist/providers/kimi/install.js +124 -0
- package/dist/providers/kimi/install.js.map +1 -0
- package/dist/providers/openai-sdk/adapter.js +120 -0
- package/dist/providers/openai-sdk/adapter.js.map +1 -0
- package/dist/providers/openai-sdk/guardrails.js +139 -0
- package/dist/providers/openai-sdk/guardrails.js.map +1 -0
- package/dist/providers/openai-sdk/handoff.js +124 -0
- package/dist/providers/openai-sdk/handoff.js.map +1 -0
- package/dist/providers/openai-sdk/index.js +39 -0
- package/dist/providers/openai-sdk/index.js.map +1 -0
- package/dist/providers/openai-sdk/install.js +120 -0
- package/dist/providers/openai-sdk/install.js.map +1 -0
- package/dist/providers/openai-sdk/spawn.js +214 -0
- package/dist/providers/openai-sdk/spawn.js.map +1 -0
- package/dist/providers/openai-sdk/tracing.js +157 -0
- package/dist/providers/openai-sdk/tracing.js.map +1 -0
- package/dist/providers/opencode/adapter.js +166 -0
- package/dist/providers/opencode/adapter.js.map +1 -0
- package/dist/providers/opencode/hooks.js +206 -0
- package/dist/providers/opencode/hooks.js.map +1 -0
- package/dist/providers/opencode/index.js +37 -0
- package/dist/providers/opencode/index.js.map +1 -0
- package/dist/providers/opencode/install.js +115 -0
- package/dist/providers/opencode/install.js.map +1 -0
- package/dist/providers/opencode/spawn.js +256 -0
- package/dist/providers/opencode/spawn.js.map +1 -0
- package/dist/providers/pi/adapter.js +220 -0
- package/dist/providers/pi/adapter.js.map +1 -0
- package/dist/providers/pi/hooks.js +223 -0
- package/dist/providers/pi/hooks.js.map +1 -0
- package/dist/providers/pi/index.js +38 -0
- package/dist/providers/pi/index.js.map +1 -0
- package/dist/providers/pi/install.js +175 -0
- package/dist/providers/pi/install.js.map +1 -0
- package/dist/providers/pi/spawn.js +187 -0
- package/dist/providers/pi/spawn.js.map +1 -0
- package/dist/providers/shared/conduit-trace-writer.js +65 -0
- package/dist/providers/shared/conduit-trace-writer.js.map +1 -0
- package/dist/providers/shared/sdk-result-mapper.js +54 -0
- package/dist/providers/shared/sdk-result-mapper.js.map +1 -0
- package/dist/providers/shared/transcript-reader.js +124 -0
- package/dist/providers/shared/transcript-reader.js.map +1 -0
- package/dist/registry.js +92 -0
- package/dist/registry.js.map +1 -0
- package/package.json +3 -3
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Gemini CLI Install Provider
|
|
3
|
+
*
|
|
4
|
+
* Handles CLEO installation into Gemini CLI environments:
|
|
5
|
+
* - Ensures AGENTS.md has CLEO @-references
|
|
6
|
+
*
|
|
7
|
+
* @task T161
|
|
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 Gemini CLI.
|
|
16
|
+
*
|
|
17
|
+
* Manages CLEO's integration with Gemini CLI 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; Gemini CLI
|
|
23
|
+
* does not have an MCP or plugin registration mechanism.
|
|
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
|
|
33
|
+
* @returns Result describing what was installed
|
|
34
|
+
* @task T161
|
|
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
|
+
details,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Uninstall CLEO from the Gemini CLI environment.
|
|
55
|
+
*
|
|
56
|
+
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
57
|
+
* @task T161
|
|
58
|
+
*/
|
|
59
|
+
async uninstall() {
|
|
60
|
+
// No-op: no MCP registration to remove
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Check whether CLEO is installed in the Gemini CLI environment.
|
|
64
|
+
*
|
|
65
|
+
* Checks for CLEO references in AGENTS.md.
|
|
66
|
+
* @task T161
|
|
67
|
+
*/
|
|
68
|
+
async isInstalled() {
|
|
69
|
+
const agentsMdPath = join(process.cwd(), 'AGENTS.md');
|
|
70
|
+
if (existsSync(agentsMdPath)) {
|
|
71
|
+
try {
|
|
72
|
+
const content = readFileSync(agentsMdPath, 'utf-8');
|
|
73
|
+
if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
catch {
|
|
78
|
+
// Fall through
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
85
|
+
*
|
|
86
|
+
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
87
|
+
*
|
|
88
|
+
* @param projectDir - Project root directory
|
|
89
|
+
* @task T161
|
|
90
|
+
*/
|
|
91
|
+
async ensureInstructionReferences(projectDir) {
|
|
92
|
+
this.updateInstructionFile(projectDir);
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Update AGENTS.md with CLEO @-references.
|
|
96
|
+
*
|
|
97
|
+
* @param projectDir - Project root directory
|
|
98
|
+
* @returns true if the file was created or modified
|
|
99
|
+
*/
|
|
100
|
+
updateInstructionFile(projectDir) {
|
|
101
|
+
const agentsMdPath = join(projectDir, 'AGENTS.md');
|
|
102
|
+
let content = '';
|
|
103
|
+
let existed = false;
|
|
104
|
+
if (existsSync(agentsMdPath)) {
|
|
105
|
+
content = readFileSync(agentsMdPath, 'utf-8');
|
|
106
|
+
existed = true;
|
|
107
|
+
}
|
|
108
|
+
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
109
|
+
if (missingRefs.length === 0) {
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
const refsBlock = missingRefs.join('\n');
|
|
113
|
+
if (existed) {
|
|
114
|
+
const separator = content.endsWith('\n') ? '' : '\n';
|
|
115
|
+
content = content + separator + refsBlock + '\n';
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
content = refsBlock + '\n';
|
|
119
|
+
}
|
|
120
|
+
writeFileSync(agentsMdPath, content, 'utf-8');
|
|
121
|
+
return true;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=install.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/gemini-cli/install.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,145 @@
|
|
|
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; integration is via instruction files.
|
|
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: Ensures AGENTS.md references for CLEO instruction files
|
|
25
|
+
*
|
|
26
|
+
* @remarks
|
|
27
|
+
* Kimi has no native hook or event system, so all hook-related capabilities
|
|
28
|
+
* are disabled. The adapter is install-only, managing AGENTS.md references
|
|
29
|
+
* for CLEO instruction injection.
|
|
30
|
+
*
|
|
31
|
+
* @task T163
|
|
32
|
+
* @epic T134
|
|
33
|
+
*/
|
|
34
|
+
export class KimiAdapter {
|
|
35
|
+
/** Unique provider identifier. */
|
|
36
|
+
id = 'kimi';
|
|
37
|
+
/** Human-readable provider name. */
|
|
38
|
+
name = 'Kimi';
|
|
39
|
+
/** Adapter version string. */
|
|
40
|
+
version = '1.0.0';
|
|
41
|
+
/** Declared capabilities for this provider. */
|
|
42
|
+
capabilities = {
|
|
43
|
+
supportsHooks: false,
|
|
44
|
+
supportedHookEvents: [],
|
|
45
|
+
supportsSpawn: false,
|
|
46
|
+
supportsInstall: true,
|
|
47
|
+
supportsInstructionFiles: false,
|
|
48
|
+
supportsContextMonitor: false,
|
|
49
|
+
supportsStatusline: false,
|
|
50
|
+
supportsProviderPaths: false,
|
|
51
|
+
supportsTransport: false,
|
|
52
|
+
supportsTaskSync: false,
|
|
53
|
+
};
|
|
54
|
+
/** Hook provider (no-op since Kimi has no event system). */
|
|
55
|
+
hooks;
|
|
56
|
+
/** Install provider for managing instruction files. */
|
|
57
|
+
install;
|
|
58
|
+
/** Project directory this adapter was initialized with, or null. */
|
|
59
|
+
projectDir = null;
|
|
60
|
+
/** Whether {@link initialize} has been called. */
|
|
61
|
+
initialized = false;
|
|
62
|
+
constructor() {
|
|
63
|
+
this.hooks = new KimiHookProvider();
|
|
64
|
+
this.install = new KimiInstallProvider();
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Initialize the adapter for a given project directory.
|
|
68
|
+
*
|
|
69
|
+
* @param projectDir - Root directory of the project
|
|
70
|
+
* @task T163
|
|
71
|
+
*/
|
|
72
|
+
async initialize(projectDir) {
|
|
73
|
+
this.projectDir = projectDir;
|
|
74
|
+
this.initialized = true;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Dispose the adapter and clean up resources.
|
|
78
|
+
*
|
|
79
|
+
* Releases tracked state. No hooks to unregister since Kimi
|
|
80
|
+
* has no native hook system.
|
|
81
|
+
* @task T163
|
|
82
|
+
*/
|
|
83
|
+
async dispose() {
|
|
84
|
+
this.initialized = false;
|
|
85
|
+
this.projectDir = null;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Run a health check to verify Kimi is accessible.
|
|
89
|
+
*
|
|
90
|
+
* Checks:
|
|
91
|
+
* 1. Adapter has been initialized
|
|
92
|
+
* 2. Kimi CLI binary is available in PATH
|
|
93
|
+
* 3. ~/.kimi/ configuration directory exists
|
|
94
|
+
*
|
|
95
|
+
* @returns Health status with details about each check
|
|
96
|
+
* @task T163
|
|
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 Kimi CLI availability
|
|
108
|
+
let cliAvailable = false;
|
|
109
|
+
try {
|
|
110
|
+
const { stdout } = await execAsync('which kimi');
|
|
111
|
+
cliAvailable = stdout.trim().length > 0;
|
|
112
|
+
details.cliPath = stdout.trim();
|
|
113
|
+
}
|
|
114
|
+
catch {
|
|
115
|
+
details.cliAvailable = false;
|
|
116
|
+
}
|
|
117
|
+
// Check for Kimi config directory
|
|
118
|
+
const kimiConfigDir = join(homedir(), '.kimi');
|
|
119
|
+
const configExists = existsSync(kimiConfigDir);
|
|
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 T163
|
|
133
|
+
*/
|
|
134
|
+
isInitialized() {
|
|
135
|
+
return this.initialized;
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Get the project directory this adapter was initialized with.
|
|
139
|
+
* @task T163
|
|
140
|
+
*/
|
|
141
|
+
getProjectDir() {
|
|
142
|
+
return this.projectDir;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/kimi/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,79 @@
|
|
|
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
|
+
* @remarks
|
|
19
|
+
* Since Kimi has no hookable events, the event map is empty and
|
|
20
|
+
* `mapProviderEvent` always returns null. Registration state is tracked
|
|
21
|
+
* purely for interface compliance with {@link AdapterHookProvider}.
|
|
22
|
+
*
|
|
23
|
+
* @task T163
|
|
24
|
+
* @epic T134
|
|
25
|
+
*/
|
|
26
|
+
export class KimiHookProvider {
|
|
27
|
+
/** Whether hooks have been registered (always a no-op for Kimi). */
|
|
28
|
+
registered = false;
|
|
29
|
+
/**
|
|
30
|
+
* Map a Kimi native event name to a CAAMP hook event name.
|
|
31
|
+
*
|
|
32
|
+
* Kimi has no hook system, so this always returns null.
|
|
33
|
+
*
|
|
34
|
+
* @param _providerEvent - Unused; Kimi emits no hookable events
|
|
35
|
+
* @returns Always null
|
|
36
|
+
* @task T163
|
|
37
|
+
*/
|
|
38
|
+
mapProviderEvent(_providerEvent) {
|
|
39
|
+
return null;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Register native hooks for a project.
|
|
43
|
+
*
|
|
44
|
+
* Kimi has no hook system. This method is a no-op and only
|
|
45
|
+
* tracks registration state for interface compliance.
|
|
46
|
+
*
|
|
47
|
+
* @param _projectDir - Project directory (unused)
|
|
48
|
+
* @task T163
|
|
49
|
+
*/
|
|
50
|
+
async registerNativeHooks(_projectDir) {
|
|
51
|
+
this.registered = true;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Unregister native hooks.
|
|
55
|
+
*
|
|
56
|
+
* Kimi has no hook system. This method is a no-op.
|
|
57
|
+
* @task T163
|
|
58
|
+
*/
|
|
59
|
+
async unregisterNativeHooks() {
|
|
60
|
+
this.registered = false;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Check whether hooks have been registered via registerNativeHooks.
|
|
64
|
+
* @task T163
|
|
65
|
+
*/
|
|
66
|
+
isRegistered() {
|
|
67
|
+
return this.registered;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Get the full event mapping for introspection/debugging.
|
|
71
|
+
*
|
|
72
|
+
* Returns an empty map since Kimi has no hookable events.
|
|
73
|
+
* @task T163
|
|
74
|
+
*/
|
|
75
|
+
getEventMap() {
|
|
76
|
+
return {};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/kimi/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH;;;;;;;;;;;;;;GAcG;AACH,MAAM,OAAO,gBAAgB;IAC3B,oEAAoE;IAC5D,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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
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
|
+
* @remarks
|
|
20
|
+
* This is the primary entry point for dynamic adapter loading.
|
|
21
|
+
* AdapterManager calls this function when it resolves the kimi
|
|
22
|
+
* provider via its import-based discovery mechanism.
|
|
23
|
+
*
|
|
24
|
+
* @returns A new {@link KimiAdapter} instance ready for initialization
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```typescript
|
|
28
|
+
* import { createAdapter } from '@cleocode/adapters/providers/kimi';
|
|
29
|
+
*
|
|
30
|
+
* const adapter = createAdapter();
|
|
31
|
+
* await adapter.initialize('/path/to/project');
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
* @task T163
|
|
35
|
+
*/
|
|
36
|
+
export function createAdapter() {
|
|
37
|
+
return new KimiAdapter();
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,124 @@
|
|
|
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
|
+
details,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Uninstall CLEO from the Kimi environment.
|
|
55
|
+
*
|
|
56
|
+
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
57
|
+
* @task T163
|
|
58
|
+
*/
|
|
59
|
+
async uninstall() {
|
|
60
|
+
// No-op: no MCP registration to remove
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Check whether CLEO is installed in the Kimi environment.
|
|
64
|
+
*
|
|
65
|
+
* Checks for CLEO references in AGENTS.md.
|
|
66
|
+
* @task T163
|
|
67
|
+
*/
|
|
68
|
+
async isInstalled() {
|
|
69
|
+
const agentsMdPath = join(process.cwd(), 'AGENTS.md');
|
|
70
|
+
if (existsSync(agentsMdPath)) {
|
|
71
|
+
try {
|
|
72
|
+
const content = readFileSync(agentsMdPath, 'utf-8');
|
|
73
|
+
if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
catch {
|
|
78
|
+
// Fall through
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
85
|
+
*
|
|
86
|
+
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
87
|
+
*
|
|
88
|
+
* @param projectDir - Project root directory
|
|
89
|
+
* @task T163
|
|
90
|
+
*/
|
|
91
|
+
async ensureInstructionReferences(projectDir) {
|
|
92
|
+
this.updateInstructionFile(projectDir);
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Update AGENTS.md with CLEO @-references.
|
|
96
|
+
*
|
|
97
|
+
* @param projectDir - Project root directory
|
|
98
|
+
* @returns true if the file was created or modified
|
|
99
|
+
*/
|
|
100
|
+
updateInstructionFile(projectDir) {
|
|
101
|
+
const agentsMdPath = join(projectDir, 'AGENTS.md');
|
|
102
|
+
let content = '';
|
|
103
|
+
let existed = false;
|
|
104
|
+
if (existsSync(agentsMdPath)) {
|
|
105
|
+
content = readFileSync(agentsMdPath, 'utf-8');
|
|
106
|
+
existed = true;
|
|
107
|
+
}
|
|
108
|
+
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
109
|
+
if (missingRefs.length === 0) {
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
const refsBlock = missingRefs.join('\n');
|
|
113
|
+
if (existed) {
|
|
114
|
+
const separator = content.endsWith('\n') ? '' : '\n';
|
|
115
|
+
content = content + separator + refsBlock + '\n';
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
content = refsBlock + '\n';
|
|
119
|
+
}
|
|
120
|
+
writeFileSync(agentsMdPath, content, 'utf-8');
|
|
121
|
+
return true;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=install.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/kimi/install.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OpenAI Agents SDK Adapter.
|
|
3
|
+
*
|
|
4
|
+
* Main `CLEOProviderAdapter` implementation for the OpenAI Agents SDK.
|
|
5
|
+
* Provides spawn and install capabilities. Hooks are not supported (the
|
|
6
|
+
* SDK does not expose a CLI hook system equivalent to Claude Code's).
|
|
7
|
+
*
|
|
8
|
+
* @task T582
|
|
9
|
+
*/
|
|
10
|
+
import { OpenAiSdkInstallProvider } from './install.js';
|
|
11
|
+
import { OpenAiSdkSpawnProvider } from './spawn.js';
|
|
12
|
+
/**
|
|
13
|
+
* CLEO provider adapter for the OpenAI Agents SDK.
|
|
14
|
+
*
|
|
15
|
+
* Bridges CLEO's adapter system with the `@openai/agents` SDK:
|
|
16
|
+
* - Spawn: Launches agents via the SDK runner with handoff topology
|
|
17
|
+
* - Install: Manages AGENTS.md @-references and .openai/ config directory
|
|
18
|
+
* - Tracing: Default-on conduit span persistence via `CleoConduitTraceProcessor`
|
|
19
|
+
*
|
|
20
|
+
* @remarks
|
|
21
|
+
* This adapter is the only CLEO provider with first-class handoff support.
|
|
22
|
+
* Team Lead → Worker topology is declared in `SpawnContext.options.handoffs`
|
|
23
|
+
* and wired directly to SDK `Agent.handoffs`. The SDK handles routing
|
|
24
|
+
* internally without any CLEO glue code.
|
|
25
|
+
*
|
|
26
|
+
* This is also the only provider supporting 100+ LLMs via the Vercel AI SDK
|
|
27
|
+
* bridge (capability flag: `supportsMultiModel`).
|
|
28
|
+
*/
|
|
29
|
+
export class OpenAiSdkAdapter {
|
|
30
|
+
/** Unique provider identifier. */
|
|
31
|
+
id = 'openai-sdk';
|
|
32
|
+
/** Human-readable provider name. */
|
|
33
|
+
name = 'OpenAI Agents SDK';
|
|
34
|
+
/** Adapter version string. */
|
|
35
|
+
version = '1.0.0';
|
|
36
|
+
/** Declared capabilities for this provider. */
|
|
37
|
+
capabilities = {
|
|
38
|
+
supportsHooks: false,
|
|
39
|
+
// The SDK does not expose CLI lifecycle hooks equivalent to Claude Code.
|
|
40
|
+
supportedHookEvents: [],
|
|
41
|
+
supportsSpawn: true,
|
|
42
|
+
supportsInstall: true,
|
|
43
|
+
supportsInstructionFiles: true,
|
|
44
|
+
instructionFilePattern: 'AGENTS.md',
|
|
45
|
+
supportsContextMonitor: false,
|
|
46
|
+
supportsStatusline: false,
|
|
47
|
+
supportsProviderPaths: false,
|
|
48
|
+
supportsTransport: false,
|
|
49
|
+
supportsTaskSync: false,
|
|
50
|
+
};
|
|
51
|
+
/** Spawn provider for SDK-backed agent runs with handoff topology. */
|
|
52
|
+
spawn;
|
|
53
|
+
/** Install provider for AGENTS.md and .openai/ config directory management. */
|
|
54
|
+
install;
|
|
55
|
+
/** Project directory this adapter was initialized with, or null. */
|
|
56
|
+
projectDir = null;
|
|
57
|
+
/** Whether {@link initialize} has been called. */
|
|
58
|
+
initialized = false;
|
|
59
|
+
constructor() {
|
|
60
|
+
this.spawn = new OpenAiSdkSpawnProvider();
|
|
61
|
+
this.install = new OpenAiSdkInstallProvider();
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Initialize the adapter for a given project directory.
|
|
65
|
+
*
|
|
66
|
+
* @param projectDir - Root directory of the project.
|
|
67
|
+
*/
|
|
68
|
+
async initialize(projectDir) {
|
|
69
|
+
this.projectDir = projectDir;
|
|
70
|
+
this.initialized = true;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Dispose the adapter and release all resources.
|
|
74
|
+
*/
|
|
75
|
+
async dispose() {
|
|
76
|
+
this.initialized = false;
|
|
77
|
+
this.projectDir = null;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Run a health check to verify the OpenAI SDK is usable.
|
|
81
|
+
*
|
|
82
|
+
* Checks:
|
|
83
|
+
* 1. Adapter has been initialized
|
|
84
|
+
* 2. `OPENAI_API_KEY` is set in the environment
|
|
85
|
+
*
|
|
86
|
+
* @returns Health status with details about each check.
|
|
87
|
+
*/
|
|
88
|
+
async healthCheck() {
|
|
89
|
+
if (!this.initialized) {
|
|
90
|
+
return {
|
|
91
|
+
healthy: false,
|
|
92
|
+
provider: this.id,
|
|
93
|
+
details: { error: 'Adapter not initialized' },
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
const apiKeyPresent = typeof process.env.OPENAI_API_KEY === 'string' && process.env.OPENAI_API_KEY.length > 0;
|
|
97
|
+
return {
|
|
98
|
+
healthy: apiKeyPresent,
|
|
99
|
+
provider: this.id,
|
|
100
|
+
details: {
|
|
101
|
+
apiKeyPresent,
|
|
102
|
+
projectDir: this.projectDir,
|
|
103
|
+
sdkVersion: '0.8.3',
|
|
104
|
+
},
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Check whether the adapter has been initialized.
|
|
109
|
+
*/
|
|
110
|
+
isInitialized() {
|
|
111
|
+
return this.initialized;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Get the project directory this adapter was initialized with.
|
|
115
|
+
*/
|
|
116
|
+
getProjectDir() {
|
|
117
|
+
return this.projectDir;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/openai-sdk/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAOH,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAEpD;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,OAAO,gBAAgB;IAC3B,kCAAkC;IACzB,EAAE,GAAG,YAAY,CAAC;IAC3B,oCAAoC;IAC3B,IAAI,GAAG,mBAAmB,CAAC;IACpC,8BAA8B;IACrB,OAAO,GAAG,OAAO,CAAC;IAE3B,+CAA+C;IAC/C,YAAY,GAAwB;QAClC,aAAa,EAAE,KAAK;QACpB,yEAAyE;QACzE,mBAAmB,EAAE,EAAE;QACvB,aAAa,EAAE,IAAI;QACnB,eAAe,EAAE,IAAI;QACrB,wBAAwB,EAAE,IAAI;QAC9B,sBAAsB,EAAE,WAAW;QACnC,sBAAsB,EAAE,KAAK;QAC7B,kBAAkB,EAAE,KAAK;QACzB,qBAAqB,EAAE,KAAK;QAC5B,iBAAiB,EAAE,KAAK;QACxB,gBAAgB,EAAE,KAAK;KACxB,CAAC;IAEF,sEAAsE;IACtE,KAAK,CAAyB;IAC9B,+EAA+E;IAC/E,OAAO,CAA2B;IAElC,oEAAoE;IAC5D,UAAU,GAAkB,IAAI,CAAC;IACzC,kDAAkD;IAC1C,WAAW,GAAG,KAAK,CAAC;IAE5B;QACE,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAsB,EAAE,CAAC;QAC1C,IAAI,CAAC,OAAO,GAAG,IAAI,wBAAwB,EAAE,CAAC;IAChD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,UAAU,CAAC,UAAkB;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,WAAW;QACf,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,IAAI,CAAC,EAAE;gBACjB,OAAO,EAAE,EAAE,KAAK,EAAE,yBAAyB,EAAE;aAC9C,CAAC;QACJ,CAAC;QAED,MAAM,aAAa,GACjB,OAAO,OAAO,CAAC,GAAG,CAAC,cAAc,KAAK,QAAQ,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;QAE1F,OAAO;YACL,OAAO,EAAE,aAAa;YACtB,QAAQ,EAAE,IAAI,CAAC,EAAE;YACjB,OAAO,EAAE;gBACP,aAAa;gBACb,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,UAAU,EAAE,OAAO;aACpB;SACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;CACF"}
|