@cleocode/adapters 2026.4.9 → 2026.4.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/providers/claude-code/adapter.js +185 -0
- package/dist/providers/claude-code/adapter.js.map +1 -0
- package/dist/providers/claude-code/context-monitor.js +159 -0
- package/dist/providers/claude-code/context-monitor.js.map +1 -0
- package/dist/providers/claude-code/hooks.js +286 -0
- package/dist/providers/claude-code/hooks.js.map +1 -0
- package/dist/providers/claude-code/index.js +41 -0
- package/dist/providers/claude-code/index.js.map +1 -0
- package/dist/providers/claude-code/install.js +161 -0
- package/dist/providers/claude-code/install.js.map +1 -0
- package/dist/providers/claude-code/paths.js +41 -0
- package/dist/providers/claude-code/paths.js.map +1 -0
- package/dist/providers/claude-code/spawn.js +171 -0
- package/dist/providers/claude-code/spawn.js.map +1 -0
- package/dist/providers/claude-code/statusline.js +130 -0
- package/dist/providers/claude-code/statusline.js.map +1 -0
- package/dist/providers/claude-code/task-sync.js +119 -0
- package/dist/providers/claude-code/task-sync.js.map +1 -0
- package/dist/providers/claude-code/transport.js +29 -0
- package/dist/providers/claude-code/transport.js.map +1 -0
- package/dist/providers/codex/adapter.js +147 -0
- package/dist/providers/codex/adapter.js.map +1 -0
- package/dist/providers/codex/hooks.js +113 -0
- package/dist/providers/codex/hooks.js.map +1 -0
- package/dist/providers/codex/index.js +39 -0
- package/dist/providers/codex/index.js.map +1 -0
- package/dist/providers/codex/install.js +125 -0
- package/dist/providers/codex/install.js.map +1 -0
- package/dist/providers/cursor/adapter.js +152 -0
- package/dist/providers/cursor/adapter.js.map +1 -0
- package/dist/providers/cursor/hooks.js +208 -0
- package/dist/providers/cursor/hooks.js.map +1 -0
- package/dist/providers/cursor/index.js +36 -0
- package/dist/providers/cursor/index.js.map +1 -0
- package/dist/providers/cursor/install.js +181 -0
- package/dist/providers/cursor/install.js.map +1 -0
- package/dist/providers/cursor/spawn.js +59 -0
- package/dist/providers/cursor/spawn.js.map +1 -0
- package/dist/providers/gemini-cli/adapter.js +159 -0
- package/dist/providers/gemini-cli/adapter.js.map +1 -0
- package/dist/providers/gemini-cli/hooks.js +128 -0
- package/dist/providers/gemini-cli/hooks.js.map +1 -0
- package/dist/providers/gemini-cli/index.js +39 -0
- package/dist/providers/gemini-cli/index.js.map +1 -0
- package/dist/providers/gemini-cli/install.js +125 -0
- package/dist/providers/gemini-cli/install.js.map +1 -0
- package/dist/providers/kimi/adapter.js +146 -0
- package/dist/providers/kimi/adapter.js.map +1 -0
- package/dist/providers/kimi/hooks.js +79 -0
- package/dist/providers/kimi/hooks.js.map +1 -0
- package/dist/providers/kimi/index.js +39 -0
- package/dist/providers/kimi/index.js.map +1 -0
- package/dist/providers/kimi/install.js +125 -0
- package/dist/providers/kimi/install.js.map +1 -0
- package/dist/providers/opencode/adapter.js +167 -0
- package/dist/providers/opencode/adapter.js.map +1 -0
- package/dist/providers/opencode/hooks.js +206 -0
- package/dist/providers/opencode/hooks.js.map +1 -0
- package/dist/providers/opencode/index.js +37 -0
- package/dist/providers/opencode/index.js.map +1 -0
- package/dist/providers/opencode/install.js +116 -0
- package/dist/providers/opencode/install.js.map +1 -0
- package/dist/providers/opencode/spawn.js +241 -0
- package/dist/providers/opencode/spawn.js.map +1 -0
- package/dist/providers/shared/transcript-reader.js +124 -0
- package/dist/providers/shared/transcript-reader.js.map +1 -0
- package/dist/registry.js +88 -0
- package/dist/registry.js.map +1 -0
- package/package.json +3 -3
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Claude Code TaskSyncProvider — bridges Claude's TodoWrite format
|
|
3
|
+
* to the provider-agnostic reconciliation system.
|
|
4
|
+
*
|
|
5
|
+
* All Claude Code / TodoWrite-specific parsing lives here.
|
|
6
|
+
* The core reconciliation engine never sees TodoWrite formats.
|
|
7
|
+
*/
|
|
8
|
+
import { readFile, stat } from 'node:fs/promises';
|
|
9
|
+
import { join } from 'node:path';
|
|
10
|
+
// ---------------------------------------------------------------------------
|
|
11
|
+
// Parsing helpers
|
|
12
|
+
// ---------------------------------------------------------------------------
|
|
13
|
+
/**
|
|
14
|
+
* Parse a CLEO task ID from TodoWrite content prefix: "[T001] ..." -> "T001".
|
|
15
|
+
*/
|
|
16
|
+
function parseTaskId(content) {
|
|
17
|
+
const match = content.match(/^\[T(\d+)\]/);
|
|
18
|
+
return match ? `T${match[1]}` : null;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Strip ID and status prefixes from content to extract the clean title.
|
|
22
|
+
*/
|
|
23
|
+
function stripPrefixes(content) {
|
|
24
|
+
return content
|
|
25
|
+
.replace(/^\[T\d+\]\s*/, '')
|
|
26
|
+
.replace(/^\[!\]\s*/, '')
|
|
27
|
+
.replace(/^\[BLOCKED\]\s*/, '');
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Map TodoWrite status to normalized ExternalTaskStatus.
|
|
31
|
+
*/
|
|
32
|
+
function mapStatus(twStatus) {
|
|
33
|
+
switch (twStatus) {
|
|
34
|
+
case 'completed':
|
|
35
|
+
return 'completed';
|
|
36
|
+
case 'in_progress':
|
|
37
|
+
return 'active';
|
|
38
|
+
case 'pending':
|
|
39
|
+
return 'pending';
|
|
40
|
+
default:
|
|
41
|
+
return 'pending';
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Resolve the TodoWrite state file path.
|
|
46
|
+
* Claude Code writes its TodoWrite state to a known location.
|
|
47
|
+
*/
|
|
48
|
+
function getTodoWriteFilePath(projectDir) {
|
|
49
|
+
return join(projectDir, '.cleo', 'sync', 'todowrite-state.json');
|
|
50
|
+
}
|
|
51
|
+
// ---------------------------------------------------------------------------
|
|
52
|
+
// Provider implementation
|
|
53
|
+
// ---------------------------------------------------------------------------
|
|
54
|
+
/**
|
|
55
|
+
* Claude Code TaskSyncProvider.
|
|
56
|
+
*
|
|
57
|
+
* Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs
|
|
58
|
+
* and status, and returns normalized ExternalTask[].
|
|
59
|
+
*
|
|
60
|
+
* Optional: accepts a custom file path for testing.
|
|
61
|
+
*
|
|
62
|
+
* @remarks
|
|
63
|
+
* TodoWrite items with `[T001]`-style prefixes are mapped to their CLEO
|
|
64
|
+
* task IDs. Items without a prefix receive a synthetic `tw-new-N` ID
|
|
65
|
+
* for reconciliation. The provider reads from
|
|
66
|
+
* `.cleo/sync/todowrite-state.json` by default.
|
|
67
|
+
*/
|
|
68
|
+
export class ClaudeCodeTaskSyncProvider {
|
|
69
|
+
/** Optional override path for the TodoWrite state file (used in tests). */
|
|
70
|
+
customFilePath;
|
|
71
|
+
constructor(options) {
|
|
72
|
+
this.customFilePath = options?.filePath;
|
|
73
|
+
}
|
|
74
|
+
/** Retrieve external tasks from Claude's TodoWrite state file. */
|
|
75
|
+
async getExternalTasks(projectDir) {
|
|
76
|
+
const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);
|
|
77
|
+
// Check file exists
|
|
78
|
+
try {
|
|
79
|
+
await stat(filePath);
|
|
80
|
+
}
|
|
81
|
+
catch {
|
|
82
|
+
// No TodoWrite state — return empty (no tasks to sync)
|
|
83
|
+
return [];
|
|
84
|
+
}
|
|
85
|
+
// Parse the TodoWrite JSON
|
|
86
|
+
const raw = await readFile(filePath, 'utf-8');
|
|
87
|
+
let state;
|
|
88
|
+
try {
|
|
89
|
+
state = JSON.parse(raw);
|
|
90
|
+
}
|
|
91
|
+
catch {
|
|
92
|
+
return []; // Malformed JSON — treat as empty
|
|
93
|
+
}
|
|
94
|
+
if (!state.todos || !Array.isArray(state.todos)) {
|
|
95
|
+
return [];
|
|
96
|
+
}
|
|
97
|
+
const tasks = [];
|
|
98
|
+
let syntheticIndex = 0;
|
|
99
|
+
for (const item of state.todos) {
|
|
100
|
+
const cleoTaskId = parseTaskId(item.content);
|
|
101
|
+
const title = cleoTaskId ? stripPrefixes(item.content).trim() : item.content.trim();
|
|
102
|
+
if (!title)
|
|
103
|
+
continue;
|
|
104
|
+
tasks.push({
|
|
105
|
+
externalId: cleoTaskId ?? `tw-new-${syntheticIndex++}`,
|
|
106
|
+
title,
|
|
107
|
+
status: mapStatus(item.status),
|
|
108
|
+
providerMeta: {
|
|
109
|
+
source: 'todowrite',
|
|
110
|
+
cleoTaskId,
|
|
111
|
+
activeForm: item.activeForm,
|
|
112
|
+
rawContent: item.content,
|
|
113
|
+
},
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
return tasks;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=task-sync.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-sync.js","sourceRoot":"","sources":["../../../src/providers/claude-code/task-sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
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
|
+
/**
|
|
10
|
+
* Transport provider for Claude Code inter-agent communication.
|
|
11
|
+
*
|
|
12
|
+
* @remarks
|
|
13
|
+
* Currently returns null from {@link createTransport} because actual transport
|
|
14
|
+
* creation is handled by the signaldock factory which checks for this adapter's
|
|
15
|
+
* transport capability flag. Full wiring will be completed in Phase 5 of the
|
|
16
|
+
* adapter system rollout.
|
|
17
|
+
*/
|
|
18
|
+
export class ClaudeCodeTransportProvider {
|
|
19
|
+
/** Provider-specific transport name used for capability negotiation. */
|
|
20
|
+
transportName = 'claude-code';
|
|
21
|
+
/** Create a transport instance for inter-agent messaging. */
|
|
22
|
+
createTransport() {
|
|
23
|
+
// Returns null — actual transport creation is handled by the signaldock factory
|
|
24
|
+
// which checks for this adapter's transport capability.
|
|
25
|
+
// Full wiring will be completed in Phase 5.
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=transport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH;;;;;;;;GAQG;AACH,MAAM,OAAO,2BAA2B;IACtC,wEAAwE;IAC/D,aAAa,GAAG,aAAa,CAAC;IAEvC,6DAA6D;IAC7D,eAAe;QACb,gFAAgF;QAChF,wDAAwD;QACxD,4CAA4C;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1,147 @@
|
|
|
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: Ensures AGENTS.md references for CLEO instruction files
|
|
24
|
+
*
|
|
25
|
+
* @remarks
|
|
26
|
+
* Codex CLI supports only 3 canonical events (SessionStart, PromptSubmit,
|
|
27
|
+
* ResponseComplete) and has no spawn or transport capabilities. Integration
|
|
28
|
+
* is primarily through instruction files (AGENTS.md).
|
|
29
|
+
*
|
|
30
|
+
* @task T162
|
|
31
|
+
* @epic T134
|
|
32
|
+
*/
|
|
33
|
+
export class CodexAdapter {
|
|
34
|
+
/** Unique provider identifier. */
|
|
35
|
+
id = 'codex';
|
|
36
|
+
/** Human-readable provider name. */
|
|
37
|
+
name = 'Codex';
|
|
38
|
+
/** Adapter version string. */
|
|
39
|
+
version = '1.0.0';
|
|
40
|
+
/** Declared capabilities for this provider. */
|
|
41
|
+
capabilities = {
|
|
42
|
+
supportsHooks: true,
|
|
43
|
+
supportedHookEvents: ['SessionStart', 'UserPromptSubmit', 'Stop'],
|
|
44
|
+
supportsSpawn: false,
|
|
45
|
+
supportsInstall: true,
|
|
46
|
+
supportsMcp: false,
|
|
47
|
+
supportsInstructionFiles: false,
|
|
48
|
+
supportsContextMonitor: false,
|
|
49
|
+
supportsStatusline: false,
|
|
50
|
+
supportsProviderPaths: false,
|
|
51
|
+
supportsTransport: false,
|
|
52
|
+
supportsTaskSync: false,
|
|
53
|
+
};
|
|
54
|
+
/** Hook provider for CAAMP event mapping. */
|
|
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 CodexHookProvider();
|
|
64
|
+
this.install = new CodexInstallProvider();
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Initialize the adapter for a given project directory.
|
|
68
|
+
*
|
|
69
|
+
* @param projectDir - Root directory of the project
|
|
70
|
+
* @task T162
|
|
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
|
+
* Unregisters hooks and releases any tracked state.
|
|
80
|
+
* @task T162
|
|
81
|
+
*/
|
|
82
|
+
async dispose() {
|
|
83
|
+
if (this.hooks.isRegistered()) {
|
|
84
|
+
await this.hooks.unregisterNativeHooks();
|
|
85
|
+
}
|
|
86
|
+
this.initialized = false;
|
|
87
|
+
this.projectDir = null;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Run a health check to verify Codex CLI is accessible.
|
|
91
|
+
*
|
|
92
|
+
* Checks:
|
|
93
|
+
* 1. Adapter has been initialized
|
|
94
|
+
* 2. Codex CLI binary is available in PATH
|
|
95
|
+
* 3. ~/.codex/ configuration directory exists
|
|
96
|
+
*
|
|
97
|
+
* @returns Health status with details about each check
|
|
98
|
+
* @task T162
|
|
99
|
+
*/
|
|
100
|
+
async healthCheck() {
|
|
101
|
+
const details = {};
|
|
102
|
+
if (!this.initialized) {
|
|
103
|
+
return {
|
|
104
|
+
healthy: false,
|
|
105
|
+
provider: this.id,
|
|
106
|
+
details: { error: 'Adapter not initialized' },
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
// Check Codex CLI availability
|
|
110
|
+
let cliAvailable = false;
|
|
111
|
+
try {
|
|
112
|
+
const { stdout } = await execAsync('which codex');
|
|
113
|
+
cliAvailable = stdout.trim().length > 0;
|
|
114
|
+
details.cliPath = stdout.trim();
|
|
115
|
+
}
|
|
116
|
+
catch {
|
|
117
|
+
details.cliAvailable = false;
|
|
118
|
+
}
|
|
119
|
+
// Check for Codex CLI config directory
|
|
120
|
+
const codexConfigDir = join(homedir(), '.codex');
|
|
121
|
+
const configExists = existsSync(codexConfigDir);
|
|
122
|
+
details.configDirExists = configExists;
|
|
123
|
+
// Healthy if CLI is available (primary requirement)
|
|
124
|
+
const healthy = cliAvailable;
|
|
125
|
+
details.cliAvailable = cliAvailable;
|
|
126
|
+
return {
|
|
127
|
+
healthy,
|
|
128
|
+
provider: this.id,
|
|
129
|
+
details,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Check whether the adapter has been initialized.
|
|
134
|
+
* @task T162
|
|
135
|
+
*/
|
|
136
|
+
isInitialized() {
|
|
137
|
+
return this.initialized;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Get the project directory this adapter was initialized with.
|
|
141
|
+
* @task T162
|
|
142
|
+
*/
|
|
143
|
+
getProjectDir() {
|
|
144
|
+
return this.projectDir;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/codex/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,113 @@
|
|
|
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 { homedir } from 'node:os';
|
|
16
|
+
import { join } from 'node:path';
|
|
17
|
+
import { readLatestTranscript } from '../shared/transcript-reader.js';
|
|
18
|
+
/**
|
|
19
|
+
* Mapping from Codex CLI native event names to CAAMP canonical event names.
|
|
20
|
+
*/
|
|
21
|
+
const CODEX_EVENT_MAP = {
|
|
22
|
+
SessionStart: 'SessionStart',
|
|
23
|
+
PromptSubmit: 'UserPromptSubmit',
|
|
24
|
+
ResponseComplete: 'Stop',
|
|
25
|
+
};
|
|
26
|
+
/**
|
|
27
|
+
* Hook provider for Codex CLI.
|
|
28
|
+
*
|
|
29
|
+
* Codex CLI registers hooks via its configuration system at
|
|
30
|
+
* ~/.codex/. Hook handlers are shell commands or script paths that
|
|
31
|
+
* execute when the corresponding event fires.
|
|
32
|
+
*
|
|
33
|
+
* Since hooks are registered through the config system (managed by
|
|
34
|
+
* the install provider), registerNativeHooks and unregisterNativeHooks
|
|
35
|
+
* track registration state without performing filesystem operations.
|
|
36
|
+
*
|
|
37
|
+
* @remarks
|
|
38
|
+
* Codex CLI has a minimal hook surface with only 3 canonical events.
|
|
39
|
+
* Registration state is tracked in-memory because Codex CLI manages
|
|
40
|
+
* hooks through its own configuration system at `~/.codex/`.
|
|
41
|
+
*
|
|
42
|
+
* @task T162
|
|
43
|
+
* @epic T134
|
|
44
|
+
*/
|
|
45
|
+
export class CodexHookProvider {
|
|
46
|
+
/** Whether hooks have been registered for the current session. */
|
|
47
|
+
registered = false;
|
|
48
|
+
/**
|
|
49
|
+
* Map a Codex CLI native event name to a CAAMP hook event name.
|
|
50
|
+
*
|
|
51
|
+
* @param providerEvent - Codex CLI event name (e.g. "SessionStart", "PromptSubmit")
|
|
52
|
+
* @returns CAAMP event name or null if unmapped
|
|
53
|
+
* @task T162
|
|
54
|
+
*/
|
|
55
|
+
mapProviderEvent(providerEvent) {
|
|
56
|
+
return CODEX_EVENT_MAP[providerEvent] ?? null;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Register native hooks for a project.
|
|
60
|
+
*
|
|
61
|
+
* For Codex CLI, hooks are registered via the config system
|
|
62
|
+
* (~/.codex/), which is handled by the install provider.
|
|
63
|
+
* This method marks hooks as registered without performing
|
|
64
|
+
* filesystem operations.
|
|
65
|
+
*
|
|
66
|
+
* @param _projectDir - Project directory (unused; hooks are global)
|
|
67
|
+
* @task T162
|
|
68
|
+
*/
|
|
69
|
+
async registerNativeHooks(_projectDir) {
|
|
70
|
+
this.registered = true;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Unregister native hooks.
|
|
74
|
+
*
|
|
75
|
+
* For Codex CLI, this is a no-op since hooks are managed through
|
|
76
|
+
* the config system. Unregistration happens via the install
|
|
77
|
+
* provider's uninstall method.
|
|
78
|
+
* @task T162
|
|
79
|
+
*/
|
|
80
|
+
async unregisterNativeHooks() {
|
|
81
|
+
this.registered = false;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Check whether hooks have been registered via registerNativeHooks.
|
|
85
|
+
* @task T162
|
|
86
|
+
*/
|
|
87
|
+
isRegistered() {
|
|
88
|
+
return this.registered;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get the full event mapping for introspection/debugging.
|
|
92
|
+
* @task T162
|
|
93
|
+
*/
|
|
94
|
+
getEventMap() {
|
|
95
|
+
return { ...CODEX_EVENT_MAP };
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Extract a plain-text transcript from Codex CLI session data.
|
|
99
|
+
*
|
|
100
|
+
* Reads the most recent JSON/JSONL session file under `~/.codex/`
|
|
101
|
+
* and returns its turns as a flat string for brain observation extraction.
|
|
102
|
+
*
|
|
103
|
+
* Returns null when no session data is found or on any read error.
|
|
104
|
+
*
|
|
105
|
+
* @param _sessionId - CLEO session ID (unused; reads the most recent file)
|
|
106
|
+
* @param _projectDir - Project directory (unused; Codex CLI uses global paths)
|
|
107
|
+
* @task T162 @epic T134
|
|
108
|
+
*/
|
|
109
|
+
async getTranscript(_sessionId, _projectDir) {
|
|
110
|
+
return readLatestTranscript(join(homedir(), '.codex'));
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/codex/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAEtE;;GAEG;AACH,MAAM,eAAe,GAA2B;IAC9C,YAAY,EAAE,cAAc;IAC5B,YAAY,EAAE,kBAAkB;IAChC,gBAAgB,EAAE,MAAM;CACzB,CAAC;AAEF;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,OAAO,iBAAiB;IAC5B,kEAAkE;IAC1D,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;OAMG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,eAAe,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IAChD,CAAC;IAED;;;;;;;;;;OAUG;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;;;OAGG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,eAAe,EAAE,CAAC;IAChC,CAAC;IAED;;;;;;;;;;;OAWG;IACH,KAAK,CAAC,aAAa,CAAC,UAAkB,EAAE,WAAmB;QACzD,OAAO,oBAAoB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC;IACzD,CAAC;CACF"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
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
|
+
* @remarks
|
|
20
|
+
* This is the primary entry point for dynamic adapter loading.
|
|
21
|
+
* AdapterManager calls this function when it resolves the codex
|
|
22
|
+
* provider via its import-based discovery mechanism.
|
|
23
|
+
*
|
|
24
|
+
* @returns A new {@link CodexAdapter} instance ready for initialization
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```typescript
|
|
28
|
+
* import { createAdapter } from '@cleocode/adapters/providers/codex';
|
|
29
|
+
*
|
|
30
|
+
* const adapter = createAdapter();
|
|
31
|
+
* await adapter.initialize('/path/to/project');
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
* @task T162
|
|
35
|
+
*/
|
|
36
|
+
export function createAdapter() {
|
|
37
|
+
return new CodexAdapter();
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,YAAY,EAAE,CAAC;AAC5B,CAAC"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Codex CLI Install Provider
|
|
3
|
+
*
|
|
4
|
+
* Handles CLEO installation into Codex CLI environments:
|
|
5
|
+
* - Ensures AGENTS.md has CLEO @-references
|
|
6
|
+
*
|
|
7
|
+
* @task T162
|
|
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 Codex CLI.
|
|
16
|
+
*
|
|
17
|
+
* Manages CLEO's integration with Codex 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; Codex CLI
|
|
23
|
+
* does not have an MCP or plugin registration mechanism.
|
|
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
|
|
33
|
+
* @returns Result describing what was installed
|
|
34
|
+
* @task T162
|
|
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
|
+
mcpRegistered: false,
|
|
51
|
+
details,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Uninstall CLEO from the Codex CLI environment.
|
|
56
|
+
*
|
|
57
|
+
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
58
|
+
* @task T162
|
|
59
|
+
*/
|
|
60
|
+
async uninstall() {
|
|
61
|
+
// No-op: no MCP registration to remove
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Check whether CLEO is installed in the Codex CLI environment.
|
|
65
|
+
*
|
|
66
|
+
* Checks for CLEO references in AGENTS.md.
|
|
67
|
+
* @task T162
|
|
68
|
+
*/
|
|
69
|
+
async isInstalled() {
|
|
70
|
+
const agentsMdPath = join(process.cwd(), 'AGENTS.md');
|
|
71
|
+
if (existsSync(agentsMdPath)) {
|
|
72
|
+
try {
|
|
73
|
+
const content = readFileSync(agentsMdPath, 'utf-8');
|
|
74
|
+
if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
catch {
|
|
79
|
+
// Fall through
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
86
|
+
*
|
|
87
|
+
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
88
|
+
*
|
|
89
|
+
* @param projectDir - Project root directory
|
|
90
|
+
* @task T162
|
|
91
|
+
*/
|
|
92
|
+
async ensureInstructionReferences(projectDir) {
|
|
93
|
+
this.updateInstructionFile(projectDir);
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Update AGENTS.md with CLEO @-references.
|
|
97
|
+
*
|
|
98
|
+
* @param projectDir - Project root directory
|
|
99
|
+
* @returns true if the file was created or modified
|
|
100
|
+
*/
|
|
101
|
+
updateInstructionFile(projectDir) {
|
|
102
|
+
const agentsMdPath = join(projectDir, 'AGENTS.md');
|
|
103
|
+
let content = '';
|
|
104
|
+
let existed = false;
|
|
105
|
+
if (existsSync(agentsMdPath)) {
|
|
106
|
+
content = readFileSync(agentsMdPath, 'utf-8');
|
|
107
|
+
existed = true;
|
|
108
|
+
}
|
|
109
|
+
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
110
|
+
if (missingRefs.length === 0) {
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
const refsBlock = missingRefs.join('\n');
|
|
114
|
+
if (existed) {
|
|
115
|
+
const separator = content.endsWith('\n') ? '' : '\n';
|
|
116
|
+
content = content + separator + refsBlock + '\n';
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
content = refsBlock + '\n';
|
|
120
|
+
}
|
|
121
|
+
writeFileSync(agentsMdPath, content, 'utf-8');
|
|
122
|
+
return true;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
//# 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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"}
|