@cleocode/adapters 2026.3.72 → 2026.3.73

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,24 @@
1
+ {
2
+ "id": "kimi",
3
+ "name": "Kimi Adapter",
4
+ "version": "1.0.0",
5
+ "description": "CLEO adapter for Moonshot AI Kimi",
6
+ "provider": "kimi",
7
+ "entryPoint": "src/index.ts",
8
+ "capabilities": {
9
+ "supportsHooks": false,
10
+ "supportedHookEvents": [],
11
+ "supportsSpawn": false,
12
+ "supportsInstall": true,
13
+ "supportsMcp": true,
14
+ "supportsInstructionFiles": false,
15
+ "supportsContextMonitor": false,
16
+ "supportsStatusline": false,
17
+ "supportsProviderPaths": false,
18
+ "supportsTransport": false
19
+ },
20
+ "detectionPatterns": [
21
+ { "type": "cli", "pattern": "kimi", "description": "Kimi CLI binary available in PATH" },
22
+ { "type": "directory", "pattern": "~/.kimi", "description": "Kimi config directory" }
23
+ ]
24
+ }
@@ -37,13 +37,20 @@ export class OpenCodeAdapter implements CLEOProviderAdapter {
37
37
 
38
38
  capabilities: AdapterCapabilities = {
39
39
  supportsHooks: true,
40
+ // 10/16 canonical events — derived from getProviderHookProfile('opencode') in CAAMP 1.9.1.
41
+ // PostToolUseFailure, SubagentStart, SubagentStop, Notification, ConfigChange are
42
+ // not supported by OpenCode's plugin system.
40
43
  supportedHookEvents: [
41
- 'onSessionStart',
42
- 'onSessionEnd',
43
- 'onToolStart',
44
- 'onToolComplete',
45
- 'onError',
46
- 'onPromptSubmit',
44
+ 'SessionStart',
45
+ 'SessionEnd',
46
+ 'PromptSubmit',
47
+ 'ResponseComplete',
48
+ 'PreToolUse',
49
+ 'PostToolUse',
50
+ 'PermissionRequest',
51
+ 'PreModel',
52
+ 'PreCompact',
53
+ 'PostCompact',
47
54
  ],
48
55
  supportsSpawn: true,
49
56
  supportsInstall: true,
@@ -1,56 +1,94 @@
1
1
  /**
2
2
  * OpenCode Hook Provider
3
3
  *
4
- * Maps OpenCode's native hook events to CAAMP hook events.
5
- * OpenCode supports 6 of 8 CAAMP events through its agent/hook system.
4
+ * Maps OpenCode's native hook events to CAAMP canonical hook events.
5
+ * OpenCode supports 10 of 16 canonical events through its plugin system.
6
6
  *
7
- * OpenCode event mapping:
8
- * - session.start -> onSessionStart
9
- * - session.end -> onSessionEnd
10
- * - tool.start -> onToolStart
11
- * - tool.complete -> onToolComplete
12
- * - error -> onError
13
- * - prompt.submit -> onPromptSubmit
7
+ * Event translation uses CAAMP normalizer APIs:
8
+ * - `toCanonical(nativeName, 'opencode')` for runtime event name resolution
9
+ * - `getSupportedEvents('opencode')` to enumerate supported canonical events
10
+ * - `getProviderHookProfile('opencode')` for the full provider profile
14
11
  *
15
- * @task T5240
12
+ * OpenCode uses a JavaScript plugin system with event-prefixed names
13
+ * (e.g. `event:session.created`) for some hooks and bare names for others.
14
+ * The map is derived from `getProviderHookProfile('opencode').mappings` in
15
+ * CAAMP 1.9.1. PostToolUseFailure, SubagentStart, SubagentStop, Notification,
16
+ * and ConfigChange are not supported by OpenCode.
17
+ *
18
+ * @task T164
19
+ * @epic T134
16
20
  */
17
21
 
18
22
  import type { AdapterHookProvider } from '@cleocode/contracts';
19
23
 
24
+ /** CAAMP provider identifier for OpenCode. */
25
+ const PROVIDER_ID = 'opencode' as const;
26
+
20
27
  /**
21
- * Mapping from OpenCode native event names to CAAMP event names.
28
+ * Fallback map from OpenCode native event names to CAAMP canonical names.
22
29
  *
23
- * OpenCode uses dot-delimited event names (e.g. "session.start")
24
- * while CAAMP uses camelCase (e.g. "onSessionStart").
30
+ * Derived from `getProviderHookProfile('opencode').mappings` in CAAMP 1.9.1.
31
+ * Covers all 10 supported events. PostToolUseFailure, SubagentStart,
32
+ * SubagentStop, Notification, and ConfigChange are not supported by OpenCode
33
+ * and are absent from this map.
34
+ *
35
+ * OpenCode uses dot-delimited and event-prefixed names (e.g. "event:session.created")
36
+ * while CAAMP canonical names are PascalCase (e.g. "SessionStart").
25
37
  */
26
38
  const OPENCODE_EVENT_MAP: Record<string, string> = {
27
- 'session.start': 'onSessionStart',
28
- 'session.end': 'onSessionEnd',
29
- 'tool.start': 'onToolStart',
30
- 'tool.complete': 'onToolComplete',
31
- error: 'onError',
32
- 'prompt.submit': 'onPromptSubmit',
39
+ // CAAMP: toNative('SessionStart', 'opencode') = 'event:session.created'
40
+ 'event:session.created': 'SessionStart',
41
+ // CAAMP: toNative('SessionEnd', 'opencode') = 'event:session.deleted'
42
+ 'event:session.deleted': 'SessionEnd',
43
+ // CAAMP: toNative('PromptSubmit', 'opencode') = 'chat.message'
44
+ 'chat.message': 'PromptSubmit',
45
+ // CAAMP: toNative('ResponseComplete', 'opencode') = 'event:session.idle'
46
+ 'event:session.idle': 'ResponseComplete',
47
+ // CAAMP: toNative('PreToolUse', 'opencode') = 'tool.execute.before'
48
+ 'tool.execute.before': 'PreToolUse',
49
+ // CAAMP: toNative('PostToolUse', 'opencode') = 'tool.execute.after'
50
+ 'tool.execute.after': 'PostToolUse',
51
+ // CAAMP: toNative('PermissionRequest', 'opencode') = 'permission.ask'
52
+ 'permission.ask': 'PermissionRequest',
53
+ // CAAMP: toNative('PreModel', 'opencode') = 'chat.params'
54
+ 'chat.params': 'PreModel',
55
+ // CAAMP: toNative('PreCompact', 'opencode') = 'experimental.session.compacting'
56
+ 'experimental.session.compacting': 'PreCompact',
57
+ // CAAMP: toNative('PostCompact', 'opencode') = 'event:session.compacted'
58
+ 'event:session.compacted': 'PostCompact',
33
59
  };
34
60
 
35
61
  /**
36
62
  * Hook provider for OpenCode.
37
63
  *
38
- * OpenCode registers hooks via its configuration system at
39
- * .opencode/config.json. Hook handlers are defined as shell commands
40
- * or script paths that execute when the corresponding event fires.
64
+ * OpenCode registers hooks via its JavaScript plugin system at
65
+ * `.opencode/plugins/`. Supported handler type: plugin (JavaScript).
66
+ *
67
+ * Event mapping is based on `getProviderHookProfile('opencode')` from
68
+ * CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
69
+ * `getProviderProfile`) call CAAMP directly when available.
41
70
  *
42
- * Since hooks are registered through the config system (managed by
43
- * the install provider), registerNativeHooks and unregisterNativeHooks
44
- * track registration state without performing filesystem operations.
71
+ * Since hooks are registered through the plugin system (managed by the install
72
+ * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
73
+ * state without performing filesystem operations.
74
+ *
75
+ * @task T164
76
+ * @epic T134
45
77
  */
46
78
  export class OpenCodeHookProvider implements AdapterHookProvider {
47
79
  private registered = false;
48
80
 
49
81
  /**
50
- * Map an OpenCode native event name to a CAAMP hook event name.
82
+ * Map an OpenCode native event name to a CAAMP canonical hook event name.
83
+ *
84
+ * Looks up the native event name in the map derived from
85
+ * `getProviderHookProfile('opencode').mappings` (CAAMP 1.9.1).
86
+ * Returns null for unsupported events (PostToolUseFailure, SubagentStart,
87
+ * SubagentStop, Notification, ConfigChange).
51
88
  *
52
- * @param providerEvent - OpenCode event name (e.g. "session.start", "tool.complete")
53
- * @returns CAAMP event name or null if unmapped
89
+ * @param providerEvent - OpenCode native event (e.g. "event:session.created", "tool.execute.before")
90
+ * @returns CAAMP canonical event name, or null if unmapped
91
+ * @task T164
54
92
  */
55
93
  mapProviderEvent(providerEvent: string): string | null {
56
94
  return OPENCODE_EVENT_MAP[providerEvent] ?? null;
@@ -59,12 +97,15 @@ export class OpenCodeHookProvider implements AdapterHookProvider {
59
97
  /**
60
98
  * Register native hooks for a project.
61
99
  *
62
- * For OpenCode, hooks are registered via the config system
63
- * (.opencode/config.json), which is handled by the install provider.
64
- * This method marks hooks as registered without performing
65
- * filesystem operations.
100
+ * For OpenCode, hooks are registered via the plugin system
101
+ * (`.opencode/plugins/`), managed by the install provider.
102
+ * This method marks hooks as registered without performing filesystem operations.
103
+ *
104
+ * Iterating supported events is handled at install time using
105
+ * `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
66
106
  *
67
107
  * @param _projectDir - Project directory (unused; config manages registration)
108
+ * @task T164
68
109
  */
69
110
  async registerNativeHooks(_projectDir: string): Promise<void> {
70
111
  this.registered = true;
@@ -73,25 +114,93 @@ export class OpenCodeHookProvider implements AdapterHookProvider {
73
114
  /**
74
115
  * Unregister native hooks.
75
116
  *
76
- * For OpenCode, this is a no-op since hooks are managed through
77
- * the config system. Unregistration happens via the install
78
- * provider's uninstall method.
117
+ * For OpenCode, this is a no-op since hooks are managed through the plugin
118
+ * system. Unregistration happens via the install provider's uninstall method.
119
+ *
120
+ * @task T164
79
121
  */
80
122
  async unregisterNativeHooks(): Promise<void> {
81
123
  this.registered = false;
82
124
  }
83
125
 
84
126
  /**
85
- * Check whether hooks have been registered via registerNativeHooks.
127
+ * Check whether hooks have been registered via `registerNativeHooks`.
86
128
  */
87
129
  isRegistered(): boolean {
88
130
  return this.registered;
89
131
  }
90
132
 
91
133
  /**
92
- * Get the full event mapping for introspection/debugging.
134
+ * Get the native→canonical event mapping for introspection and debugging.
135
+ *
136
+ * Returns the map derived from `getProviderHookProfile('opencode').mappings`
137
+ * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
138
+ * names via live CAAMP APIs.
139
+ *
140
+ * @returns Immutable record of native event name → canonical event name
93
141
  */
94
142
  getEventMap(): Readonly<Record<string, string>> {
95
143
  return { ...OPENCODE_EVENT_MAP };
96
144
  }
145
+
146
+ /**
147
+ * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
148
+ *
149
+ * Calls `getSupportedEvents('opencode')` from the CAAMP normalizer to get the
150
+ * authoritative list. OpenCode supports 10 of 16 canonical events via its
151
+ * plugin system. Falls back to the values of the static event map when
152
+ * CAAMP is unavailable at runtime.
153
+ *
154
+ * @returns Array of CAAMP canonical event names supported by OpenCode
155
+ * @task T164
156
+ */
157
+ async getSupportedCanonicalEvents(): Promise<string[]> {
158
+ try {
159
+ const { getSupportedEvents } = await import('@cleocode/caamp');
160
+ return getSupportedEvents(PROVIDER_ID) as string[];
161
+ } catch {
162
+ return [...new Set(Object.values(OPENCODE_EVENT_MAP))];
163
+ }
164
+ }
165
+
166
+ /**
167
+ * Retrieve the full provider hook profile from CAAMP.
168
+ *
169
+ * Calls `getProviderHookProfile('opencode')` from the CAAMP normalizer to
170
+ * get the complete profile: hook system type (`plugin`), config path
171
+ * (`.opencode/plugins/`), handler types, and all event mappings.
172
+ * Returns null when CAAMP is unavailable at runtime.
173
+ *
174
+ * @returns Provider hook profile or null if CAAMP is unavailable
175
+ * @task T164
176
+ */
177
+ async getProviderProfile(): Promise<unknown | null> {
178
+ try {
179
+ const { getProviderHookProfile } = await import('@cleocode/caamp');
180
+ return getProviderHookProfile(PROVIDER_ID) ?? null;
181
+ } catch {
182
+ return null;
183
+ }
184
+ }
185
+
186
+ /**
187
+ * Translate a CAAMP canonical event to its OpenCode native name via CAAMP.
188
+ *
189
+ * Calls `toNative(canonical, 'opencode')` from the CAAMP normalizer.
190
+ * Returns null for unsupported events or when CAAMP is unavailable.
191
+ *
192
+ * @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
193
+ * @returns OpenCode native event name or null
194
+ * @task T164
195
+ */
196
+ async toNativeEvent(canonical: string): Promise<string | null> {
197
+ try {
198
+ const { toNative } = await import('@cleocode/caamp');
199
+ return toNative(canonical as Parameters<typeof toNative>[0], PROVIDER_ID);
200
+ } catch {
201
+ // Invert the static map as fallback
202
+ const entry = Object.entries(OPENCODE_EVENT_MAP).find(([, v]) => v === canonical);
203
+ return entry?.[0] ?? null;
204
+ }
205
+ }
97
206
  }