@cleocode/adapters 2026.3.74 → 2026.3.76

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (78) hide show
  1. package/dist/index.js +132 -154
  2. package/dist/index.js.map +4 -4
  3. package/dist/providers/codex/hooks.d.ts +2 -2
  4. package/dist/providers/codex/hooks.d.ts.map +1 -1
  5. package/dist/providers/gemini-cli/hooks.d.ts +2 -2
  6. package/dist/providers/gemini-cli/hooks.d.ts.map +1 -1
  7. package/dist/providers/shared/transcript-reader.d.ts +43 -0
  8. package/dist/providers/shared/transcript-reader.d.ts.map +1 -0
  9. package/package.json +3 -3
  10. package/src/providers/codex/hooks.ts +5 -52
  11. package/src/providers/gemini-cli/hooks.ts +5 -52
  12. package/src/providers/shared/transcript-reader.ts +123 -0
  13. package/dist/providers/claude-code/adapter.js +0 -165
  14. package/dist/providers/claude-code/adapter.js.map +0 -1
  15. package/dist/providers/claude-code/context-monitor.js +0 -148
  16. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  17. package/dist/providers/claude-code/hooks.js +0 -279
  18. package/dist/providers/claude-code/hooks.js.map +0 -1
  19. package/dist/providers/claude-code/index.js +0 -26
  20. package/dist/providers/claude-code/index.js.map +0 -1
  21. package/dist/providers/claude-code/install.js +0 -234
  22. package/dist/providers/claude-code/install.js.map +0 -1
  23. package/dist/providers/claude-code/paths.js +0 -33
  24. package/dist/providers/claude-code/paths.js.map +0 -1
  25. package/dist/providers/claude-code/spawn.js +0 -164
  26. package/dist/providers/claude-code/spawn.js.map +0 -1
  27. package/dist/providers/claude-code/statusline.js +0 -86
  28. package/dist/providers/claude-code/statusline.js.map +0 -1
  29. package/dist/providers/claude-code/task-sync.js +0 -111
  30. package/dist/providers/claude-code/task-sync.js.map +0 -1
  31. package/dist/providers/claude-code/transport.js +0 -18
  32. package/dist/providers/claude-code/transport.js.map +0 -1
  33. package/dist/providers/codex/adapter.js +0 -134
  34. package/dist/providers/codex/adapter.js.map +0 -1
  35. package/dist/providers/codex/hooks.js +0 -155
  36. package/dist/providers/codex/hooks.js.map +0 -1
  37. package/dist/providers/codex/index.js +0 -24
  38. package/dist/providers/codex/index.js.map +0 -1
  39. package/dist/providers/codex/install.js +0 -183
  40. package/dist/providers/codex/install.js.map +0 -1
  41. package/dist/providers/cursor/adapter.js +0 -138
  42. package/dist/providers/cursor/adapter.js.map +0 -1
  43. package/dist/providers/cursor/hooks.js +0 -201
  44. package/dist/providers/cursor/hooks.js.map +0 -1
  45. package/dist/providers/cursor/index.js +0 -21
  46. package/dist/providers/cursor/index.js.map +0 -1
  47. package/dist/providers/cursor/install.js +0 -238
  48. package/dist/providers/cursor/install.js.map +0 -1
  49. package/dist/providers/cursor/spawn.js +0 -59
  50. package/dist/providers/cursor/spawn.js.map +0 -1
  51. package/dist/providers/gemini-cli/adapter.js +0 -145
  52. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  53. package/dist/providers/gemini-cli/hooks.js +0 -169
  54. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  55. package/dist/providers/gemini-cli/index.js +0 -24
  56. package/dist/providers/gemini-cli/index.js.map +0 -1
  57. package/dist/providers/gemini-cli/install.js +0 -183
  58. package/dist/providers/gemini-cli/install.js.map +0 -1
  59. package/dist/providers/kimi/adapter.js +0 -133
  60. package/dist/providers/kimi/adapter.js.map +0 -1
  61. package/dist/providers/kimi/hooks.js +0 -73
  62. package/dist/providers/kimi/hooks.js.map +0 -1
  63. package/dist/providers/kimi/index.js +0 -24
  64. package/dist/providers/kimi/index.js.map +0 -1
  65. package/dist/providers/kimi/install.js +0 -189
  66. package/dist/providers/kimi/install.js.map +0 -1
  67. package/dist/providers/opencode/adapter.js +0 -151
  68. package/dist/providers/opencode/adapter.js.map +0 -1
  69. package/dist/providers/opencode/hooks.js +0 -197
  70. package/dist/providers/opencode/hooks.js.map +0 -1
  71. package/dist/providers/opencode/index.js +0 -22
  72. package/dist/providers/opencode/index.js.map +0 -1
  73. package/dist/providers/opencode/install.js +0 -180
  74. package/dist/providers/opencode/install.js.map +0 -1
  75. package/dist/providers/opencode/spawn.js +0 -219
  76. package/dist/providers/opencode/spawn.js.map +0 -1
  77. package/dist/registry.js +0 -55
  78. package/dist/registry.js.map +0 -1
@@ -1,18 +0,0 @@
1
- /**
2
- * Transport provider for the Claude Code adapter.
3
- *
4
- * Implements AdapterTransportProvider to supply Claude Code's
5
- * native inter-agent transport mechanism.
6
- *
7
- * @task T5240
8
- */
9
- export class ClaudeCodeTransportProvider {
10
- transportName = 'claude-code';
11
- createTransport() {
12
- // Returns null — actual transport creation is handled by the signaldock factory
13
- // which checks for this adapter's transport capability.
14
- // Full wiring will be completed in Phase 5.
15
- return null;
16
- }
17
- }
18
- //# sourceMappingURL=transport.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,MAAM,OAAO,2BAA2B;IAC7B,aAAa,GAAG,aAAa,CAAC;IAEvC,eAAe;QACb,gFAAgF;QAChF,wDAAwD;QACxD,4CAA4C;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -1,134 +0,0 @@
1
- /**
2
- * Codex CLI Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for OpenAI Codex CLI.
5
- * Provides hooks and install capabilities for CLEO integration.
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { exec } from 'node:child_process';
11
- import { existsSync } from 'node:fs';
12
- import { homedir } from 'node:os';
13
- import { join } from 'node:path';
14
- import { promisify } from 'node:util';
15
- import { CodexHookProvider } from './hooks.js';
16
- import { CodexInstallProvider } from './install.js';
17
- const execAsync = promisify(exec);
18
- /**
19
- * CLEO provider adapter for OpenAI Codex CLI.
20
- *
21
- * Bridges CLEO's adapter system with Codex CLI's native capabilities:
22
- * - Hooks: Maps Codex events (SessionStart, PromptSubmit, ResponseComplete) to CAAMP events
23
- * - Install: Registers MCP server in ~/.codex/config.json and ensures AGENTS.md references
24
- *
25
- * @task T162
26
- * @epic T134
27
- */
28
- export class CodexAdapter {
29
- id = 'codex';
30
- name = 'Codex';
31
- version = '1.0.0';
32
- capabilities = {
33
- supportsHooks: true,
34
- supportedHookEvents: ['SessionStart', 'UserPromptSubmit', 'Stop'],
35
- supportsSpawn: false,
36
- supportsInstall: true,
37
- supportsMcp: true,
38
- supportsInstructionFiles: false,
39
- supportsContextMonitor: false,
40
- supportsStatusline: false,
41
- supportsProviderPaths: false,
42
- supportsTransport: false,
43
- supportsTaskSync: false,
44
- };
45
- hooks;
46
- install;
47
- projectDir = null;
48
- initialized = false;
49
- constructor() {
50
- this.hooks = new CodexHookProvider();
51
- this.install = new CodexInstallProvider();
52
- }
53
- /**
54
- * Initialize the adapter for a given project directory.
55
- *
56
- * @param projectDir - Root directory of the project
57
- * @task T162
58
- */
59
- async initialize(projectDir) {
60
- this.projectDir = projectDir;
61
- this.initialized = true;
62
- }
63
- /**
64
- * Dispose the adapter and clean up resources.
65
- *
66
- * Unregisters hooks and releases any tracked state.
67
- * @task T162
68
- */
69
- async dispose() {
70
- if (this.hooks.isRegistered()) {
71
- await this.hooks.unregisterNativeHooks();
72
- }
73
- this.initialized = false;
74
- this.projectDir = null;
75
- }
76
- /**
77
- * Run a health check to verify Codex CLI is accessible.
78
- *
79
- * Checks:
80
- * 1. Adapter has been initialized
81
- * 2. Codex CLI binary is available in PATH
82
- * 3. ~/.codex/ configuration directory exists
83
- *
84
- * @returns Health status with details about each check
85
- * @task T162
86
- */
87
- async healthCheck() {
88
- const details = {};
89
- if (!this.initialized) {
90
- return {
91
- healthy: false,
92
- provider: this.id,
93
- details: { error: 'Adapter not initialized' },
94
- };
95
- }
96
- // Check Codex CLI availability
97
- let cliAvailable = false;
98
- try {
99
- const { stdout } = await execAsync('which codex');
100
- cliAvailable = stdout.trim().length > 0;
101
- details.cliPath = stdout.trim();
102
- }
103
- catch {
104
- details.cliAvailable = false;
105
- }
106
- // Check for Codex CLI config directory
107
- const codexConfigDir = join(homedir(), '.codex');
108
- const configExists = existsSync(codexConfigDir);
109
- details.configDirExists = configExists;
110
- // Healthy if CLI is available (primary requirement)
111
- const healthy = cliAvailable;
112
- details.cliAvailable = cliAvailable;
113
- return {
114
- healthy,
115
- provider: this.id,
116
- details,
117
- };
118
- }
119
- /**
120
- * Check whether the adapter has been initialized.
121
- * @task T162
122
- */
123
- isInitialized() {
124
- return this.initialized;
125
- }
126
- /**
127
- * Get the project directory this adapter was initialized with.
128
- * @task T162
129
- */
130
- getProjectDir() {
131
- return this.projectDir;
132
- }
133
- }
134
- //# sourceMappingURL=adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/codex/adapter.ts"],"names":[],"mappings":"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"}
@@ -1,155 +0,0 @@
1
- /**
2
- * Codex CLI Hook Provider
3
- *
4
- * Maps Codex CLI's native hook events to CAAMP canonical hook events.
5
- * Codex CLI supports 3 canonical events through its hook system.
6
- *
7
- * Codex CLI event mapping:
8
- * - SessionStart -> SessionStart
9
- * - PromptSubmit -> UserPromptSubmit
10
- * - ResponseComplete -> Stop
11
- *
12
- * @task T162
13
- * @epic T134
14
- */
15
- import { readdir, readFile } from 'node:fs/promises';
16
- import { join } from 'node:path';
17
- /**
18
- * Mapping from Codex CLI native event names to CAAMP canonical event names.
19
- */
20
- const CODEX_EVENT_MAP = {
21
- SessionStart: 'SessionStart',
22
- PromptSubmit: 'UserPromptSubmit',
23
- ResponseComplete: 'Stop',
24
- };
25
- /**
26
- * Hook provider for Codex CLI.
27
- *
28
- * Codex CLI registers hooks via its configuration system at
29
- * ~/.codex/. Hook handlers are shell commands or script paths that
30
- * execute when the corresponding event fires.
31
- *
32
- * Since hooks are registered through the config system (managed by
33
- * the install provider), registerNativeHooks and unregisterNativeHooks
34
- * track registration state without performing filesystem operations.
35
- *
36
- * @task T162
37
- * @epic T134
38
- */
39
- export class CodexHookProvider {
40
- registered = false;
41
- /**
42
- * Map a Codex CLI native event name to a CAAMP hook event name.
43
- *
44
- * @param providerEvent - Codex CLI event name (e.g. "SessionStart", "PromptSubmit")
45
- * @returns CAAMP event name or null if unmapped
46
- * @task T162
47
- */
48
- mapProviderEvent(providerEvent) {
49
- return CODEX_EVENT_MAP[providerEvent] ?? null;
50
- }
51
- /**
52
- * Register native hooks for a project.
53
- *
54
- * For Codex CLI, hooks are registered via the config system
55
- * (~/.codex/), which is handled by the install provider.
56
- * This method marks hooks as registered without performing
57
- * filesystem operations.
58
- *
59
- * @param _projectDir - Project directory (unused; hooks are global)
60
- * @task T162
61
- */
62
- async registerNativeHooks(_projectDir) {
63
- this.registered = true;
64
- }
65
- /**
66
- * Unregister native hooks.
67
- *
68
- * For Codex CLI, this is a no-op since hooks are managed through
69
- * the config system. Unregistration happens via the install
70
- * provider's uninstall method.
71
- * @task T162
72
- */
73
- async unregisterNativeHooks() {
74
- this.registered = false;
75
- }
76
- /**
77
- * Check whether hooks have been registered via registerNativeHooks.
78
- * @task T162
79
- */
80
- isRegistered() {
81
- return this.registered;
82
- }
83
- /**
84
- * Get the full event mapping for introspection/debugging.
85
- * @task T162
86
- */
87
- getEventMap() {
88
- return { ...CODEX_EVENT_MAP };
89
- }
90
- /**
91
- * Extract a plain-text transcript from Codex CLI session data.
92
- *
93
- * Reads the most recent session file under ~/.codex/ and extracts
94
- * turn text into a flat string for brain observation extraction.
95
- *
96
- * Returns null when no session data is found or on any read error.
97
- *
98
- * @param _sessionId - CLEO session ID (unused; reads the most recent file)
99
- * @param _projectDir - Project directory (unused; Codex CLI uses global paths)
100
- * @task T162 @epic T134
101
- */
102
- async getTranscript(_sessionId, _projectDir) {
103
- try {
104
- const homeDir = process.env.HOME ?? process.env.USERPROFILE ?? '/root';
105
- const codexDir = join(homeDir, '.codex');
106
- let allFiles = [];
107
- try {
108
- const entries = await readdir(codexDir, { withFileTypes: true });
109
- for (const entry of entries) {
110
- if (!entry.isFile())
111
- continue;
112
- const name = entry.name;
113
- if (name.endsWith('.json') || name.endsWith('.jsonl')) {
114
- allFiles.push(join(codexDir, name));
115
- }
116
- }
117
- }
118
- catch {
119
- return null;
120
- }
121
- if (allFiles.length === 0)
122
- return null;
123
- // Sort descending by filename (timestamps in filenames sort naturally)
124
- allFiles = allFiles.sort((a, b) => b.localeCompare(a));
125
- const mostRecent = allFiles[0];
126
- if (!mostRecent)
127
- return null;
128
- const raw = await readFile(mostRecent, 'utf-8');
129
- const turns = [];
130
- // Support both JSONL (one JSON per line) and JSON array formats
131
- const lines = raw.split('\n').filter((l) => l.trim());
132
- for (const line of lines) {
133
- try {
134
- const entry = JSON.parse(line);
135
- const role = entry.role;
136
- const content = entry.content;
137
- if (role === 'assistant' && typeof content === 'string') {
138
- turns.push(`assistant: ${content}`);
139
- }
140
- else if (role === 'user' && typeof content === 'string') {
141
- turns.push(`user: ${content}`);
142
- }
143
- }
144
- catch {
145
- // Skip malformed lines
146
- }
147
- }
148
- return turns.length > 0 ? turns.join('\n') : null;
149
- }
150
- catch {
151
- return null;
152
- }
153
- }
154
- }
155
- //# sourceMappingURL=hooks.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/codex/hooks.ts"],"names":[],"mappings":"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"}
@@ -1,24 +0,0 @@
1
- /**
2
- * Codex CLI provider adapter.
3
- *
4
- * CLEO provider adapter for OpenAI Codex CLI.
5
- * Default export is the adapter class for dynamic loading by AdapterManager.
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { CodexAdapter } from './adapter.js';
11
- export { CodexAdapter } from './adapter.js';
12
- export { CodexHookProvider } from './hooks.js';
13
- export { CodexInstallProvider } from './install.js';
14
- export default CodexAdapter;
15
- /**
16
- * Factory function for creating adapter instances.
17
- * Used by AdapterManager's dynamic import fallback.
18
- *
19
- * @task T162
20
- */
21
- export function createAdapter() {
22
- return new CodexAdapter();
23
- }
24
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/codex/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAE5C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAEpD,eAAe,YAAY,CAAC;AAE5B;;;;;GAKG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,YAAY,EAAE,CAAC;AAC5B,CAAC"}
@@ -1,183 +0,0 @@
1
- /**
2
- * Codex CLI Install Provider
3
- *
4
- * Handles CLEO installation into Codex CLI environments:
5
- * - Registers CLEO MCP server in ~/.codex/config.json
6
- * - Ensures AGENTS.md has CLEO @-references
7
- *
8
- * @task T162
9
- * @epic T134
10
- */
11
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
12
- import { homedir } from 'node:os';
13
- import { join } from 'node:path';
14
- /** Lines that should appear in AGENTS.md to reference CLEO. */
15
- const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
16
- /** MCP server registration key used in Codex CLI config. */
17
- const MCP_SERVER_KEY = 'cleo';
18
- /**
19
- * Install provider for Codex CLI.
20
- *
21
- * Manages CLEO's integration with Codex CLI by:
22
- * 1. Registering the CLEO MCP server in ~/.codex/config.json
23
- * 2. Ensuring AGENTS.md contains @-references to CLEO instruction files
24
- *
25
- * @task T162
26
- * @epic T134
27
- */
28
- export class CodexInstallProvider {
29
- /**
30
- * Install CLEO into a Codex CLI environment.
31
- *
32
- * @param options - Installation options including project directory and MCP server path
33
- * @returns Result describing what was installed
34
- * @task T162
35
- */
36
- async install(options) {
37
- const { projectDir, mcpServerPath } = options;
38
- const installedAt = new Date().toISOString();
39
- let instructionFileUpdated = false;
40
- let mcpRegistered = false;
41
- const details = {};
42
- // Step 1: Register MCP server in ~/.codex/config.json
43
- if (mcpServerPath) {
44
- mcpRegistered = this.registerMcpServer(mcpServerPath);
45
- if (mcpRegistered) {
46
- details.mcpConfigPath = join(homedir(), '.codex', 'config.json');
47
- }
48
- }
49
- // Step 2: Ensure AGENTS.md has @-references
50
- instructionFileUpdated = this.updateInstructionFile(projectDir);
51
- if (instructionFileUpdated) {
52
- details.instructionFile = join(projectDir, 'AGENTS.md');
53
- }
54
- return {
55
- success: true,
56
- installedAt,
57
- instructionFileUpdated,
58
- mcpRegistered,
59
- details,
60
- };
61
- }
62
- /**
63
- * Uninstall CLEO from the Codex CLI environment.
64
- *
65
- * Removes the MCP server registration from ~/.codex/config.json.
66
- * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
67
- * @task T162
68
- */
69
- async uninstall() {
70
- const configPath = join(homedir(), '.codex', 'config.json');
71
- if (existsSync(configPath)) {
72
- try {
73
- const raw = readFileSync(configPath, 'utf-8');
74
- const config = JSON.parse(raw);
75
- const mcpServers = config.mcpServers;
76
- if (mcpServers && MCP_SERVER_KEY in mcpServers) {
77
- delete mcpServers[MCP_SERVER_KEY];
78
- writeFileSync(configPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
79
- }
80
- }
81
- catch {
82
- // Ignore errors during uninstall
83
- }
84
- }
85
- }
86
- /**
87
- * Check whether CLEO is installed in the Codex CLI environment.
88
- *
89
- * Checks for MCP server registered in ~/.codex/config.json.
90
- * Returns true if the CLEO MCP server entry is found.
91
- * @task T162
92
- */
93
- async isInstalled() {
94
- const configPath = join(homedir(), '.codex', 'config.json');
95
- if (existsSync(configPath)) {
96
- try {
97
- const config = JSON.parse(readFileSync(configPath, 'utf-8'));
98
- const mcpServers = config.mcpServers;
99
- if (mcpServers && MCP_SERVER_KEY in mcpServers) {
100
- return true;
101
- }
102
- }
103
- catch {
104
- // Fall through
105
- }
106
- }
107
- return false;
108
- }
109
- /**
110
- * Ensure AGENTS.md contains @-references to CLEO instruction files.
111
- *
112
- * Creates AGENTS.md if it does not exist. Appends any missing references.
113
- *
114
- * @param projectDir - Project root directory
115
- * @task T162
116
- */
117
- async ensureInstructionReferences(projectDir) {
118
- this.updateInstructionFile(projectDir);
119
- }
120
- /**
121
- * Register the CLEO MCP server in ~/.codex/config.json.
122
- *
123
- * Codex CLI stores its MCP server configuration in ~/.codex/config.json
124
- * under the mcpServers key.
125
- *
126
- * @param mcpServerPath - Absolute path to the MCP server entry point
127
- * @returns true if registration was performed or updated
128
- */
129
- registerMcpServer(mcpServerPath) {
130
- const codexDir = join(homedir(), '.codex');
131
- const configPath = join(codexDir, 'config.json');
132
- let config = {};
133
- mkdirSync(codexDir, { recursive: true });
134
- if (existsSync(configPath)) {
135
- try {
136
- config = JSON.parse(readFileSync(configPath, 'utf-8'));
137
- }
138
- catch {
139
- // Start fresh on parse error
140
- }
141
- }
142
- if (!config.mcpServers || typeof config.mcpServers !== 'object') {
143
- config.mcpServers = {};
144
- }
145
- const mcpServers = config.mcpServers;
146
- mcpServers[MCP_SERVER_KEY] = {
147
- command: 'node',
148
- args: [mcpServerPath],
149
- };
150
- writeFileSync(configPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
151
- return true;
152
- }
153
- /**
154
- * Update AGENTS.md with CLEO @-references.
155
- *
156
- * @param projectDir - Project root directory
157
- * @returns true if the file was created or modified
158
- */
159
- updateInstructionFile(projectDir) {
160
- const agentsMdPath = join(projectDir, 'AGENTS.md');
161
- let content = '';
162
- let existed = false;
163
- if (existsSync(agentsMdPath)) {
164
- content = readFileSync(agentsMdPath, 'utf-8');
165
- existed = true;
166
- }
167
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
168
- if (missingRefs.length === 0) {
169
- return false;
170
- }
171
- const refsBlock = missingRefs.join('\n');
172
- if (existed) {
173
- const separator = content.endsWith('\n') ? '' : '\n';
174
- content = content + separator + refsBlock + '\n';
175
- }
176
- else {
177
- content = refsBlock + '\n';
178
- }
179
- writeFileSync(agentsMdPath, content, 'utf-8');
180
- return true;
181
- }
182
- }
183
- //# sourceMappingURL=install.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/codex/install.ts"],"names":[],"mappings":"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"}
@@ -1,138 +0,0 @@
1
- /**
2
- * Cursor Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for Cursor AI code editor.
5
- * Provides install capabilities for CLEO integration. Hooks and spawn
6
- * are not supported since Cursor lacks CLI-based lifecycle events
7
- * and subagent spawning.
8
- *
9
- * @task T5240
10
- */
11
- import { existsSync } from 'node:fs';
12
- import { join } from 'node:path';
13
- import { CursorHookProvider } from './hooks.js';
14
- import { CursorInstallProvider } from './install.js';
15
- /**
16
- * CLEO provider adapter for Cursor AI code editor.
17
- *
18
- * Bridges CLEO's adapter system with Cursor's capabilities:
19
- * - Install: Registers MCP server in .cursor/mcp.json and manages rule files
20
- * - Hooks: Stub provider (Cursor has no lifecycle event system)
21
- * - Spawn: Not supported (Cursor has no CLI for subagent spawning)
22
- */
23
- export class CursorAdapter {
24
- id = 'cursor';
25
- name = 'Cursor';
26
- version = '1.0.0';
27
- capabilities = {
28
- supportsHooks: true,
29
- // 10/16 canonical events — derived from getProviderHookProfile('cursor') in CAAMP 1.9.1.
30
- // PermissionRequest, PreModel, PostModel, PostCompact, Notification, ConfigChange are
31
- // not supported by Cursor's hook system.
32
- supportedHookEvents: [
33
- 'SessionStart',
34
- 'SessionEnd',
35
- 'PromptSubmit',
36
- 'ResponseComplete',
37
- 'PreToolUse',
38
- 'PostToolUse',
39
- 'PostToolUseFailure',
40
- 'SubagentStart',
41
- 'SubagentStop',
42
- 'PreCompact',
43
- ],
44
- supportsSpawn: false,
45
- supportsInstall: true,
46
- supportsMcp: true,
47
- supportsInstructionFiles: true,
48
- instructionFilePattern: '.cursor/rules/*.mdc',
49
- supportsContextMonitor: false,
50
- supportsStatusline: false,
51
- supportsProviderPaths: true,
52
- supportsTransport: false,
53
- supportsTaskSync: false,
54
- };
55
- hooks;
56
- install;
57
- projectDir = null;
58
- initialized = false;
59
- constructor() {
60
- this.hooks = new CursorHookProvider();
61
- this.install = new CursorInstallProvider();
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 clean up resources.
74
- */
75
- async dispose() {
76
- if (this.hooks.isRegistered()) {
77
- await this.hooks.unregisterNativeHooks();
78
- }
79
- this.initialized = false;
80
- this.projectDir = null;
81
- }
82
- /**
83
- * Run a health check to verify Cursor is accessible.
84
- *
85
- * Checks:
86
- * 1. Adapter has been initialized
87
- * 2. .cursor/ configuration directory exists in the project
88
- * 3. CURSOR_EDITOR env var is set
89
- *
90
- * @returns Health status with details about each check
91
- */
92
- async healthCheck() {
93
- const details = {};
94
- if (!this.initialized) {
95
- return {
96
- healthy: false,
97
- provider: this.id,
98
- details: { error: 'Adapter not initialized' },
99
- };
100
- }
101
- // Check for Cursor config directory in the project
102
- let configExists = false;
103
- if (this.projectDir) {
104
- const cursorConfigDir = join(this.projectDir, '.cursor');
105
- configExists = existsSync(cursorConfigDir);
106
- details.configDirExists = configExists;
107
- }
108
- // Check for CURSOR_EDITOR env var
109
- const editorEnvSet = process.env.CURSOR_EDITOR !== undefined;
110
- details.editorEnvSet = editorEnvSet;
111
- // Check for legacy .cursorrules file
112
- if (this.projectDir) {
113
- const legacyRulesExist = existsSync(join(this.projectDir, '.cursorrules'));
114
- details.legacyRulesExist = legacyRulesExist;
115
- }
116
- // Healthy if we detect Cursor presence (config dir or env var)
117
- const healthy = configExists || editorEnvSet;
118
- details.detected = healthy;
119
- return {
120
- healthy,
121
- provider: this.id,
122
- details,
123
- };
124
- }
125
- /**
126
- * Check whether the adapter has been initialized.
127
- */
128
- isInitialized() {
129
- return this.initialized;
130
- }
131
- /**
132
- * Get the project directory this adapter was initialized with.
133
- */
134
- getProjectDir() {
135
- return this.projectDir;
136
- }
137
- }
138
- //# sourceMappingURL=adapter.js.map