@cleocode/adapters 2026.3.72 → 2026.3.74

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 (96) hide show
  1. package/dist/index.d.ts +3 -0
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +1227 -101
  4. package/dist/index.js.map +4 -4
  5. package/dist/providers/claude-code/adapter.d.ts.map +1 -1
  6. package/dist/providers/claude-code/adapter.js +16 -5
  7. package/dist/providers/claude-code/adapter.js.map +1 -1
  8. package/dist/providers/claude-code/hooks.d.ts +89 -25
  9. package/dist/providers/claude-code/hooks.d.ts.map +1 -1
  10. package/dist/providers/claude-code/hooks.js +230 -28
  11. package/dist/providers/claude-code/hooks.js.map +1 -1
  12. package/dist/providers/codex/adapter.d.ts +70 -0
  13. package/dist/providers/codex/adapter.d.ts.map +1 -0
  14. package/dist/providers/codex/adapter.js +134 -0
  15. package/dist/providers/codex/adapter.js.map +1 -0
  16. package/dist/providers/codex/hooks.d.ts +85 -0
  17. package/dist/providers/codex/hooks.d.ts.map +1 -0
  18. package/dist/providers/codex/hooks.js +155 -0
  19. package/dist/providers/codex/hooks.js.map +1 -0
  20. package/dist/providers/codex/index.d.ts +22 -0
  21. package/dist/providers/codex/index.d.ts.map +1 -0
  22. package/dist/providers/codex/index.js +24 -0
  23. package/dist/providers/codex/index.js.map +1 -0
  24. package/dist/providers/codex/install.d.ts +74 -0
  25. package/dist/providers/codex/install.d.ts.map +1 -0
  26. package/dist/providers/codex/install.js +183 -0
  27. package/dist/providers/codex/install.js.map +1 -0
  28. package/dist/providers/cursor/adapter.d.ts.map +1 -1
  29. package/dist/providers/cursor/adapter.js +16 -2
  30. package/dist/providers/cursor/adapter.js.map +1 -1
  31. package/dist/providers/cursor/hooks.d.ts +102 -17
  32. package/dist/providers/cursor/hooks.d.ts.map +1 -1
  33. package/dist/providers/cursor/hooks.js +164 -18
  34. package/dist/providers/cursor/hooks.js.map +1 -1
  35. package/dist/providers/gemini-cli/adapter.d.ts +70 -0
  36. package/dist/providers/gemini-cli/adapter.d.ts.map +1 -0
  37. package/dist/providers/gemini-cli/adapter.js +145 -0
  38. package/dist/providers/gemini-cli/adapter.js.map +1 -0
  39. package/dist/providers/gemini-cli/hooks.d.ts +92 -0
  40. package/dist/providers/gemini-cli/hooks.d.ts.map +1 -0
  41. package/dist/providers/gemini-cli/hooks.js +169 -0
  42. package/dist/providers/gemini-cli/hooks.js.map +1 -0
  43. package/dist/providers/gemini-cli/index.d.ts +22 -0
  44. package/dist/providers/gemini-cli/index.d.ts.map +1 -0
  45. package/dist/providers/gemini-cli/index.js +24 -0
  46. package/dist/providers/gemini-cli/index.js.map +1 -0
  47. package/dist/providers/gemini-cli/install.d.ts +74 -0
  48. package/dist/providers/gemini-cli/install.d.ts.map +1 -0
  49. package/dist/providers/gemini-cli/install.js +183 -0
  50. package/dist/providers/gemini-cli/install.js.map +1 -0
  51. package/dist/providers/kimi/adapter.d.ts +72 -0
  52. package/dist/providers/kimi/adapter.d.ts.map +1 -0
  53. package/dist/providers/kimi/adapter.js +133 -0
  54. package/dist/providers/kimi/adapter.js.map +1 -0
  55. package/dist/providers/kimi/hooks.d.ts +64 -0
  56. package/dist/providers/kimi/hooks.d.ts.map +1 -0
  57. package/dist/providers/kimi/hooks.js +73 -0
  58. package/dist/providers/kimi/hooks.js.map +1 -0
  59. package/dist/providers/kimi/index.d.ts +22 -0
  60. package/dist/providers/kimi/index.d.ts.map +1 -0
  61. package/dist/providers/kimi/index.js +24 -0
  62. package/dist/providers/kimi/index.js.map +1 -0
  63. package/dist/providers/kimi/install.d.ts +80 -0
  64. package/dist/providers/kimi/install.d.ts.map +1 -0
  65. package/dist/providers/kimi/install.js +189 -0
  66. package/dist/providers/kimi/install.js.map +1 -0
  67. package/dist/providers/opencode/adapter.d.ts.map +1 -1
  68. package/dist/providers/opencode/adapter.js +13 -6
  69. package/dist/providers/opencode/adapter.js.map +1 -1
  70. package/dist/providers/opencode/hooks.d.ts +89 -28
  71. package/dist/providers/opencode/hooks.d.ts.map +1 -1
  72. package/dist/providers/opencode/hooks.js +145 -37
  73. package/dist/providers/opencode/hooks.js.map +1 -1
  74. package/package.json +3 -2
  75. package/src/index.ts +18 -0
  76. package/src/providers/claude-code/adapter.ts +16 -5
  77. package/src/providers/claude-code/hooks.ts +154 -30
  78. package/src/providers/codex/adapter.ts +154 -0
  79. package/src/providers/codex/hooks.ts +163 -0
  80. package/src/providers/codex/index.ts +27 -0
  81. package/src/providers/codex/install.ts +203 -0
  82. package/src/providers/codex/manifest.json +28 -0
  83. package/src/providers/cursor/adapter.ts +16 -2
  84. package/src/providers/cursor/hooks.ts +167 -18
  85. package/src/providers/gemini-cli/adapter.ts +165 -0
  86. package/src/providers/gemini-cli/hooks.ts +177 -0
  87. package/src/providers/gemini-cli/index.ts +27 -0
  88. package/src/providers/gemini-cli/install.ts +203 -0
  89. package/src/providers/gemini-cli/manifest.json +35 -0
  90. package/src/providers/kimi/adapter.ts +153 -0
  91. package/src/providers/kimi/hooks.ts +80 -0
  92. package/src/providers/kimi/index.ts +27 -0
  93. package/src/providers/kimi/install.ts +209 -0
  94. package/src/providers/kimi/manifest.json +24 -0
  95. package/src/providers/opencode/adapter.ts +13 -6
  96. package/src/providers/opencode/hooks.ts +146 -37
@@ -0,0 +1,183 @@
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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/codex/install.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAErD;;;;;;;GAOG;AACH,qBAAa,aAAc,YAAW,mBAAmB;IACvD,QAAQ,CAAC,EAAE,YAAY;IACvB,QAAQ,CAAC,IAAI,YAAY;IACzB,QAAQ,CAAC,OAAO,WAAW;IAE3B,YAAY,EAAE,mBAAmB,CAa/B;IAEF,KAAK,EAAE,kBAAkB,CAAC;IAC1B,OAAO,EAAE,qBAAqB,CAAC;IAE/B,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAS;;IAO5B;;;;OAIG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAwCjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
1
+ {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAErD;;;;;;;GAOG;AACH,qBAAa,aAAc,YAAW,mBAAmB;IACvD,QAAQ,CAAC,EAAE,YAAY;IACvB,QAAQ,CAAC,IAAI,YAAY;IACzB,QAAQ,CAAC,OAAO,WAAW;IAE3B,YAAY,EAAE,mBAAmB,CA2B/B;IAEF,KAAK,EAAE,kBAAkB,CAAC;IAC1B,OAAO,EAAE,qBAAqB,CAAC;IAE/B,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAS;;IAO5B;;;;OAIG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAwCjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
@@ -25,8 +25,22 @@ export class CursorAdapter {
25
25
  name = 'Cursor';
26
26
  version = '1.0.0';
27
27
  capabilities = {
28
- supportsHooks: false,
29
- supportedHookEvents: [],
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
+ ],
30
44
  supportsSpawn: false,
31
45
  supportsInstall: true,
32
46
  supportsMcp: true,
@@ -1 +1 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"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"}
@@ -1,48 +1,133 @@
1
1
  /**
2
2
  * Cursor Hook Provider
3
3
  *
4
- * Cursor does not have a native hook/event system for external tools.
5
- * This provider returns null for all event mappings and marks hooks
6
- * as unsupported. It exists to satisfy the AdapterHookProvider contract
7
- * so the adapter can be used uniformly by the AdapterManager.
4
+ * Maps Cursor's native hook events to CAAMP canonical hook events.
5
+ * Cursor supports 10 of 16 canonical events through its config-based hook system.
8
6
  *
9
- * @task T5240
7
+ * Event translation uses CAAMP normalizer APIs:
8
+ * - `toCanonical(nativeName, 'cursor')` for runtime event name resolution
9
+ * - `getSupportedEvents('cursor')` to enumerate supported canonical events
10
+ * - `getProviderHookProfile('cursor')` for the full provider profile
11
+ *
12
+ * Cursor uses camelCase native event names (e.g. `sessionStart`, `preToolUse`).
13
+ * Hooks are configured via `.cursor/hooks.json`. Supported handler types:
14
+ * command, prompt.
15
+ *
16
+ * Unsupported events: PermissionRequest, PreModel, PostModel, PostCompact,
17
+ * Notification, ConfigChange.
18
+ *
19
+ * @task T165
20
+ * @epic T134
10
21
  */
11
22
  import type { AdapterHookProvider } from '@cleocode/contracts';
12
23
  /**
13
- * Hook provider for Cursor (stub).
24
+ * Hook provider for Cursor.
25
+ *
26
+ * Cursor registers hooks via its config system at `.cursor/hooks.json`.
27
+ * Supported handler types: command, prompt.
28
+ *
29
+ * CAAMP 1.9.1 reveals Cursor supports 10 of 16 canonical events. Previously
30
+ * this provider was a no-op stub. It now provides full event mapping and CAAMP
31
+ * normalizer integration.
32
+ *
33
+ * Event mapping is based on `getProviderHookProfile('cursor')` from CAAMP 1.9.1.
34
+ * Async accessors (`getSupportedCanonicalEvents`, `getProviderProfile`) call
35
+ * CAAMP directly when available.
36
+ *
37
+ * Since hooks are registered through the config system (managed by the install
38
+ * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
39
+ * state without performing filesystem operations.
14
40
  *
15
- * Cursor lacks a hook-based lifecycle event system. All mapping
16
- * operations return null. Registration is a no-op.
41
+ * @task T165
42
+ * @epic T134
17
43
  */
18
44
  export declare class CursorHookProvider implements AdapterHookProvider {
19
45
  private registered;
20
46
  /**
21
- * Map a provider event name to a CAAMP hook event name.
47
+ * Map a Cursor native event name to a CAAMP canonical hook event name.
22
48
  *
23
- * Always returns null since Cursor does not emit hook events.
49
+ * Looks up the native event name in the map derived from
50
+ * `getProviderHookProfile('cursor').mappings` (CAAMP 1.9.1). Cursor uses
51
+ * camelCase names (e.g. "preToolUse", "sessionStart").
24
52
  *
25
- * @param _providerEvent - Ignored; Cursor has no hook events
26
- * @returns null (no mapping available)
53
+ * Returns null for unsupported events (PermissionRequest, PreModel,
54
+ * PostModel, PostCompact, Notification, ConfigChange).
55
+ *
56
+ * @param providerEvent - Cursor native event name (e.g. "preToolUse", "sessionStart")
57
+ * @returns CAAMP canonical event name, or null if unmapped
58
+ * @task T165
27
59
  */
28
- mapProviderEvent(_providerEvent: string): string | null;
60
+ mapProviderEvent(providerEvent: string): string | null;
29
61
  /**
30
62
  * Register native hooks for a project.
31
63
  *
32
- * No-op for Cursor since it has no hook system.
64
+ * For Cursor, hooks are registered via the config system
65
+ * (`.cursor/hooks.json`), managed by the install provider.
66
+ * This method marks hooks as registered without performing filesystem operations.
67
+ *
68
+ * Iterating supported events is handled at install time using
69
+ * `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
33
70
  *
34
- * @param _projectDir - Ignored
71
+ * @param _projectDir - Project directory (unused; Cursor config manages registration)
72
+ * @task T165
35
73
  */
36
74
  registerNativeHooks(_projectDir: string): Promise<void>;
37
75
  /**
38
76
  * Unregister native hooks.
39
77
  *
40
- * No-op for Cursor since it has no hook system.
78
+ * For Cursor, this is a no-op since hooks are managed through the config
79
+ * system. Unregistration happens via the install provider's uninstall method.
80
+ *
81
+ * @task T165
41
82
  */
42
83
  unregisterNativeHooks(): Promise<void>;
43
84
  /**
44
- * Check whether hooks have been registered.
85
+ * Check whether hooks have been registered via `registerNativeHooks`.
45
86
  */
46
87
  isRegistered(): boolean;
88
+ /**
89
+ * Get the native→canonical event mapping for introspection and debugging.
90
+ *
91
+ * Returns the map derived from `getProviderHookProfile('cursor').mappings`
92
+ * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
93
+ * names via live CAAMP APIs.
94
+ *
95
+ * @returns Immutable record of native event name → canonical event name
96
+ */
97
+ getEventMap(): Readonly<Record<string, string>>;
98
+ /**
99
+ * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
100
+ *
101
+ * Calls `getSupportedEvents('cursor')` from the CAAMP normalizer to get the
102
+ * authoritative list. Cursor supports 10 of 16 canonical events. Falls back
103
+ * to the values of the static event map when CAAMP is unavailable at runtime.
104
+ *
105
+ * @returns Array of CAAMP canonical event names supported by Cursor
106
+ * @task T165
107
+ */
108
+ getSupportedCanonicalEvents(): Promise<string[]>;
109
+ /**
110
+ * Retrieve the full provider hook profile from CAAMP.
111
+ *
112
+ * Calls `getProviderHookProfile('cursor')` from the CAAMP normalizer to
113
+ * get the complete profile: hook system type (`config`), config path
114
+ * (`.cursor/hooks.json`), handler types (command, prompt), and all event
115
+ * mappings. Returns null when CAAMP is unavailable at runtime.
116
+ *
117
+ * @returns Provider hook profile or null if CAAMP is unavailable
118
+ * @task T165
119
+ */
120
+ getProviderProfile(): Promise<unknown | null>;
121
+ /**
122
+ * Translate a CAAMP canonical event to its Cursor native name via CAAMP.
123
+ *
124
+ * Calls `toNative(canonical, 'cursor')` from the CAAMP normalizer.
125
+ * Returns null for unsupported events or when CAAMP is unavailable.
126
+ *
127
+ * @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
128
+ * @returns Cursor native event name (e.g. "preToolUse") or null
129
+ * @task T165
130
+ */
131
+ toNativeEvent(canonical: string): Promise<string | null>;
47
132
  }
48
133
  //# sourceMappingURL=hooks.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE/D;;;;;GAKG;AACH,qBAAa,kBAAmB,YAAW,mBAAmB;IAC5D,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;;;OAOG;IACH,gBAAgB,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIvD;;;;;;OAMG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;OAIG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;CAGxB"}
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAqC/D;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,qBAAa,kBAAmB,YAAW,mBAAmB;IAC5D,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;;;;;;;;;OAaG;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;;;;;;;;;OASG;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"}
@@ -1,38 +1,109 @@
1
1
  /**
2
2
  * Cursor Hook Provider
3
3
  *
4
- * Cursor does not have a native hook/event system for external tools.
5
- * This provider returns null for all event mappings and marks hooks
6
- * as unsupported. It exists to satisfy the AdapterHookProvider contract
7
- * so the adapter can be used uniformly by the AdapterManager.
4
+ * Maps Cursor's native hook events to CAAMP canonical hook events.
5
+ * Cursor supports 10 of 16 canonical events through its config-based hook system.
8
6
  *
9
- * @task T5240
7
+ * Event translation uses CAAMP normalizer APIs:
8
+ * - `toCanonical(nativeName, 'cursor')` for runtime event name resolution
9
+ * - `getSupportedEvents('cursor')` to enumerate supported canonical events
10
+ * - `getProviderHookProfile('cursor')` for the full provider profile
11
+ *
12
+ * Cursor uses camelCase native event names (e.g. `sessionStart`, `preToolUse`).
13
+ * Hooks are configured via `.cursor/hooks.json`. Supported handler types:
14
+ * command, prompt.
15
+ *
16
+ * Unsupported events: PermissionRequest, PreModel, PostModel, PostCompact,
17
+ * Notification, ConfigChange.
18
+ *
19
+ * @task T165
20
+ * @epic T134
10
21
  */
22
+ /** CAAMP provider identifier for Cursor. */
23
+ const PROVIDER_ID = 'cursor';
11
24
  /**
12
- * Hook provider for Cursor (stub).
25
+ * Fallback map from Cursor native event names to CAAMP canonical names.
13
26
  *
14
- * Cursor lacks a hook-based lifecycle event system. All mapping
15
- * operations return null. Registration is a no-op.
27
+ * Derived from `getProviderHookProfile('cursor').mappings` in CAAMP 1.9.1.
28
+ * Covers all 10 supported events. PermissionRequest, PreModel, PostModel,
29
+ * PostCompact, Notification, and ConfigChange are not supported by Cursor.
30
+ *
31
+ * Cursor uses camelCase names while CAAMP canonical names are PascalCase.
32
+ */
33
+ const CURSOR_EVENT_MAP = {
34
+ // CAAMP: toNative('SessionStart', 'cursor') = 'sessionStart'
35
+ sessionStart: 'SessionStart',
36
+ // CAAMP: toNative('SessionEnd', 'cursor') = 'sessionEnd'
37
+ sessionEnd: 'SessionEnd',
38
+ // CAAMP: toNative('PromptSubmit', 'cursor') = 'beforeSubmitPrompt'
39
+ beforeSubmitPrompt: 'PromptSubmit',
40
+ // CAAMP: toNative('ResponseComplete', 'cursor') = 'stop'
41
+ stop: 'ResponseComplete',
42
+ // CAAMP: toNative('PreToolUse', 'cursor') = 'preToolUse'
43
+ preToolUse: 'PreToolUse',
44
+ // CAAMP: toNative('PostToolUse', 'cursor') = 'postToolUse'
45
+ postToolUse: 'PostToolUse',
46
+ // CAAMP: toNative('PostToolUseFailure', 'cursor') = 'postToolUseFailure'
47
+ postToolUseFailure: 'PostToolUseFailure',
48
+ // CAAMP: toNative('SubagentStart', 'cursor') = 'subagentStart'
49
+ subagentStart: 'SubagentStart',
50
+ // CAAMP: toNative('SubagentStop', 'cursor') = 'subagentStop'
51
+ subagentStop: 'SubagentStop',
52
+ // CAAMP: toNative('PreCompact', 'cursor') = 'preCompact'
53
+ preCompact: 'PreCompact',
54
+ };
55
+ /**
56
+ * Hook provider for Cursor.
57
+ *
58
+ * Cursor registers hooks via its config system at `.cursor/hooks.json`.
59
+ * Supported handler types: command, prompt.
60
+ *
61
+ * CAAMP 1.9.1 reveals Cursor supports 10 of 16 canonical events. Previously
62
+ * this provider was a no-op stub. It now provides full event mapping and CAAMP
63
+ * normalizer integration.
64
+ *
65
+ * Event mapping is based on `getProviderHookProfile('cursor')` from CAAMP 1.9.1.
66
+ * Async accessors (`getSupportedCanonicalEvents`, `getProviderProfile`) call
67
+ * CAAMP directly when available.
68
+ *
69
+ * Since hooks are registered through the config system (managed by the install
70
+ * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
71
+ * state without performing filesystem operations.
72
+ *
73
+ * @task T165
74
+ * @epic T134
16
75
  */
17
76
  export class CursorHookProvider {
18
77
  registered = false;
19
78
  /**
20
- * Map a provider event name to a CAAMP hook event name.
79
+ * Map a Cursor native event name to a CAAMP canonical hook event name.
21
80
  *
22
- * Always returns null since Cursor does not emit hook events.
81
+ * Looks up the native event name in the map derived from
82
+ * `getProviderHookProfile('cursor').mappings` (CAAMP 1.9.1). Cursor uses
83
+ * camelCase names (e.g. "preToolUse", "sessionStart").
23
84
  *
24
- * @param _providerEvent - Ignored; Cursor has no hook events
25
- * @returns null (no mapping available)
85
+ * Returns null for unsupported events (PermissionRequest, PreModel,
86
+ * PostModel, PostCompact, Notification, ConfigChange).
87
+ *
88
+ * @param providerEvent - Cursor native event name (e.g. "preToolUse", "sessionStart")
89
+ * @returns CAAMP canonical event name, or null if unmapped
90
+ * @task T165
26
91
  */
27
- mapProviderEvent(_providerEvent) {
28
- return null;
92
+ mapProviderEvent(providerEvent) {
93
+ return CURSOR_EVENT_MAP[providerEvent] ?? null;
29
94
  }
30
95
  /**
31
96
  * Register native hooks for a project.
32
97
  *
33
- * No-op for Cursor since it has no hook system.
98
+ * For Cursor, hooks are registered via the config system
99
+ * (`.cursor/hooks.json`), managed by the install provider.
100
+ * This method marks hooks as registered without performing filesystem operations.
101
+ *
102
+ * Iterating supported events is handled at install time using
103
+ * `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
34
104
  *
35
- * @param _projectDir - Ignored
105
+ * @param _projectDir - Project directory (unused; Cursor config manages registration)
106
+ * @task T165
36
107
  */
37
108
  async registerNativeHooks(_projectDir) {
38
109
  this.registered = true;
@@ -40,16 +111,91 @@ export class CursorHookProvider {
40
111
  /**
41
112
  * Unregister native hooks.
42
113
  *
43
- * No-op for Cursor since it has no hook system.
114
+ * For Cursor, this is a no-op since hooks are managed through the config
115
+ * system. Unregistration happens via the install provider's uninstall method.
116
+ *
117
+ * @task T165
44
118
  */
45
119
  async unregisterNativeHooks() {
46
120
  this.registered = false;
47
121
  }
48
122
  /**
49
- * Check whether hooks have been registered.
123
+ * Check whether hooks have been registered via `registerNativeHooks`.
50
124
  */
51
125
  isRegistered() {
52
126
  return this.registered;
53
127
  }
128
+ /**
129
+ * Get the native→canonical event mapping for introspection and debugging.
130
+ *
131
+ * Returns the map derived from `getProviderHookProfile('cursor').mappings`
132
+ * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
133
+ * names via live CAAMP APIs.
134
+ *
135
+ * @returns Immutable record of native event name → canonical event name
136
+ */
137
+ getEventMap() {
138
+ return { ...CURSOR_EVENT_MAP };
139
+ }
140
+ /**
141
+ * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
142
+ *
143
+ * Calls `getSupportedEvents('cursor')` from the CAAMP normalizer to get the
144
+ * authoritative list. Cursor supports 10 of 16 canonical events. Falls back
145
+ * to the values of the static event map when CAAMP is unavailable at runtime.
146
+ *
147
+ * @returns Array of CAAMP canonical event names supported by Cursor
148
+ * @task T165
149
+ */
150
+ async getSupportedCanonicalEvents() {
151
+ try {
152
+ const { getSupportedEvents } = await import('@cleocode/caamp');
153
+ return getSupportedEvents(PROVIDER_ID);
154
+ }
155
+ catch {
156
+ return [...new Set(Object.values(CURSOR_EVENT_MAP))];
157
+ }
158
+ }
159
+ /**
160
+ * Retrieve the full provider hook profile from CAAMP.
161
+ *
162
+ * Calls `getProviderHookProfile('cursor')` from the CAAMP normalizer to
163
+ * get the complete profile: hook system type (`config`), config path
164
+ * (`.cursor/hooks.json`), handler types (command, prompt), and all event
165
+ * mappings. Returns null when CAAMP is unavailable at runtime.
166
+ *
167
+ * @returns Provider hook profile or null if CAAMP is unavailable
168
+ * @task T165
169
+ */
170
+ async getProviderProfile() {
171
+ try {
172
+ const { getProviderHookProfile } = await import('@cleocode/caamp');
173
+ return getProviderHookProfile(PROVIDER_ID) ?? null;
174
+ }
175
+ catch {
176
+ return null;
177
+ }
178
+ }
179
+ /**
180
+ * Translate a CAAMP canonical event to its Cursor native name via CAAMP.
181
+ *
182
+ * Calls `toNative(canonical, 'cursor')` from the CAAMP normalizer.
183
+ * Returns null for unsupported events or when CAAMP is unavailable.
184
+ *
185
+ * @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
186
+ * @returns Cursor native event name (e.g. "preToolUse") or null
187
+ * @task T165
188
+ */
189
+ async toNativeEvent(canonical) {
190
+ try {
191
+ const { toNative } = await import('@cleocode/caamp');
192
+ return toNative(canonical, PROVIDER_ID);
193
+ }
194
+ catch {
195
+ // Invert the static map as fallback
196
+ const entry = Object.entries(CURSOR_EVENT_MAP).find(([, v]) => v === canonical);
197
+ return entry?.[0] ?? null;
198
+ }
199
+ }
54
200
  }
55
201
  //# sourceMappingURL=hooks.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/cursor/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH;;;;;GAKG;AACH,MAAM,OAAO,kBAAkB;IACrB,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;;OAOG;IACH,gBAAgB,CAAC,cAAsB;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,qBAAqB;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;CACF"}
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/cursor/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAIH,4CAA4C;AAC5C,MAAM,WAAW,GAAG,QAAiB,CAAC;AAEtC;;;;;;;;GAQG;AACH,MAAM,gBAAgB,GAA2B;IAC/C,mEAAmE;IACnE,YAAY,EAAE,cAAc;IAC5B,iEAAiE;IACjE,UAAU,EAAE,YAAY;IACxB,yEAAyE;IACzE,kBAAkB,EAAE,cAAc;IAClC,2DAA2D;IAC3D,IAAI,EAAE,kBAAkB;IACxB,iEAAiE;IACjE,UAAU,EAAE,YAAY;IACxB,kEAAkE;IAClE,WAAW,EAAE,aAAa;IAC1B,yEAAyE;IACzE,kBAAkB,EAAE,oBAAoB;IACxC,oEAAoE;IACpE,aAAa,EAAE,eAAe;IAC9B,mEAAmE;IACnE,YAAY,EAAE,cAAc;IAC5B,iEAAiE;IACjE,UAAU,EAAE,YAAY;CACzB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,OAAO,kBAAkB;IACrB,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;;;;;;;;OAaG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,gBAAgB,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IACjD,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,qBAAqB;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;;OAQG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACjC,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,2BAA2B;QAC/B,IAAI,CAAC;YACH,MAAM,EAAE,kBAAkB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAC/D,OAAO,kBAAkB,CAAC,WAAW,CAAa,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,kBAAkB;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,sBAAsB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACnE,OAAO,sBAAsB,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,aAAa,CAAC,SAAiB;QACnC,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACrD,OAAO,QAAQ,CAAC,SAA2C,EAAE,WAAW,CAAC,CAAC;QAC5E,CAAC;QAAC,MAAM,CAAC;YACP,oCAAoC;YACpC,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;YAChF,OAAO,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;CACF"}