@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.
Files changed (109) hide show
  1. package/dist/cant-context.js +711 -0
  2. package/dist/cant-context.js.map +1 -0
  3. package/dist/providers/claude-code/adapter.js +222 -0
  4. package/dist/providers/claude-code/adapter.js.map +1 -0
  5. package/dist/providers/claude-code/context-monitor.js +159 -0
  6. package/dist/providers/claude-code/context-monitor.js.map +1 -0
  7. package/dist/providers/claude-code/hooks.js +395 -0
  8. package/dist/providers/claude-code/hooks.js.map +1 -0
  9. package/dist/providers/claude-code/index.js +41 -0
  10. package/dist/providers/claude-code/index.js.map +1 -0
  11. package/dist/providers/claude-code/install.js +199 -0
  12. package/dist/providers/claude-code/install.js.map +1 -0
  13. package/dist/providers/claude-code/paths.js +41 -0
  14. package/dist/providers/claude-code/paths.js.map +1 -0
  15. package/dist/providers/claude-code/spawn.js +198 -0
  16. package/dist/providers/claude-code/spawn.js.map +1 -0
  17. package/dist/providers/claude-code/statusline.js +130 -0
  18. package/dist/providers/claude-code/statusline.js.map +1 -0
  19. package/dist/providers/claude-code/task-sync.js +119 -0
  20. package/dist/providers/claude-code/task-sync.js.map +1 -0
  21. package/dist/providers/claude-code/transport.js +29 -0
  22. package/dist/providers/claude-code/transport.js.map +1 -0
  23. package/dist/providers/claude-sdk/index.js +16 -0
  24. package/dist/providers/claude-sdk/index.js.map +1 -0
  25. package/dist/providers/claude-sdk/mcp-registry.js +66 -0
  26. package/dist/providers/claude-sdk/mcp-registry.js.map +1 -0
  27. package/dist/providers/claude-sdk/session-store.js +84 -0
  28. package/dist/providers/claude-sdk/session-store.js.map +1 -0
  29. package/dist/providers/claude-sdk/spawn.js +225 -0
  30. package/dist/providers/claude-sdk/spawn.js.map +1 -0
  31. package/dist/providers/claude-sdk/tool-bridge.js +50 -0
  32. package/dist/providers/claude-sdk/tool-bridge.js.map +1 -0
  33. package/dist/providers/codex/adapter.js +146 -0
  34. package/dist/providers/codex/adapter.js.map +1 -0
  35. package/dist/providers/codex/hooks.js +113 -0
  36. package/dist/providers/codex/hooks.js.map +1 -0
  37. package/dist/providers/codex/index.js +39 -0
  38. package/dist/providers/codex/index.js.map +1 -0
  39. package/dist/providers/codex/install.js +124 -0
  40. package/dist/providers/codex/install.js.map +1 -0
  41. package/dist/providers/cursor/adapter.js +151 -0
  42. package/dist/providers/cursor/adapter.js.map +1 -0
  43. package/dist/providers/cursor/hooks.js +208 -0
  44. package/dist/providers/cursor/hooks.js.map +1 -0
  45. package/dist/providers/cursor/index.js +36 -0
  46. package/dist/providers/cursor/index.js.map +1 -0
  47. package/dist/providers/cursor/install.js +180 -0
  48. package/dist/providers/cursor/install.js.map +1 -0
  49. package/dist/providers/cursor/spawn.js +59 -0
  50. package/dist/providers/cursor/spawn.js.map +1 -0
  51. package/dist/providers/gemini-cli/adapter.js +158 -0
  52. package/dist/providers/gemini-cli/adapter.js.map +1 -0
  53. package/dist/providers/gemini-cli/hooks.js +128 -0
  54. package/dist/providers/gemini-cli/hooks.js.map +1 -0
  55. package/dist/providers/gemini-cli/index.js +39 -0
  56. package/dist/providers/gemini-cli/index.js.map +1 -0
  57. package/dist/providers/gemini-cli/install.js +124 -0
  58. package/dist/providers/gemini-cli/install.js.map +1 -0
  59. package/dist/providers/kimi/adapter.js +145 -0
  60. package/dist/providers/kimi/adapter.js.map +1 -0
  61. package/dist/providers/kimi/hooks.js +79 -0
  62. package/dist/providers/kimi/hooks.js.map +1 -0
  63. package/dist/providers/kimi/index.js +39 -0
  64. package/dist/providers/kimi/index.js.map +1 -0
  65. package/dist/providers/kimi/install.js +124 -0
  66. package/dist/providers/kimi/install.js.map +1 -0
  67. package/dist/providers/openai-sdk/adapter.js +120 -0
  68. package/dist/providers/openai-sdk/adapter.js.map +1 -0
  69. package/dist/providers/openai-sdk/guardrails.js +139 -0
  70. package/dist/providers/openai-sdk/guardrails.js.map +1 -0
  71. package/dist/providers/openai-sdk/handoff.js +124 -0
  72. package/dist/providers/openai-sdk/handoff.js.map +1 -0
  73. package/dist/providers/openai-sdk/index.js +39 -0
  74. package/dist/providers/openai-sdk/index.js.map +1 -0
  75. package/dist/providers/openai-sdk/install.js +120 -0
  76. package/dist/providers/openai-sdk/install.js.map +1 -0
  77. package/dist/providers/openai-sdk/spawn.js +214 -0
  78. package/dist/providers/openai-sdk/spawn.js.map +1 -0
  79. package/dist/providers/openai-sdk/tracing.js +157 -0
  80. package/dist/providers/openai-sdk/tracing.js.map +1 -0
  81. package/dist/providers/opencode/adapter.js +166 -0
  82. package/dist/providers/opencode/adapter.js.map +1 -0
  83. package/dist/providers/opencode/hooks.js +206 -0
  84. package/dist/providers/opencode/hooks.js.map +1 -0
  85. package/dist/providers/opencode/index.js +37 -0
  86. package/dist/providers/opencode/index.js.map +1 -0
  87. package/dist/providers/opencode/install.js +115 -0
  88. package/dist/providers/opencode/install.js.map +1 -0
  89. package/dist/providers/opencode/spawn.js +256 -0
  90. package/dist/providers/opencode/spawn.js.map +1 -0
  91. package/dist/providers/pi/adapter.js +220 -0
  92. package/dist/providers/pi/adapter.js.map +1 -0
  93. package/dist/providers/pi/hooks.js +223 -0
  94. package/dist/providers/pi/hooks.js.map +1 -0
  95. package/dist/providers/pi/index.js +38 -0
  96. package/dist/providers/pi/index.js.map +1 -0
  97. package/dist/providers/pi/install.js +175 -0
  98. package/dist/providers/pi/install.js.map +1 -0
  99. package/dist/providers/pi/spawn.js +187 -0
  100. package/dist/providers/pi/spawn.js.map +1 -0
  101. package/dist/providers/shared/conduit-trace-writer.js +65 -0
  102. package/dist/providers/shared/conduit-trace-writer.js.map +1 -0
  103. package/dist/providers/shared/sdk-result-mapper.js +54 -0
  104. package/dist/providers/shared/sdk-result-mapper.js.map +1 -0
  105. package/dist/providers/shared/transcript-reader.js +124 -0
  106. package/dist/providers/shared/transcript-reader.js.map +1 -0
  107. package/dist/registry.js +92 -0
  108. package/dist/registry.js.map +1 -0
  109. 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"}