Skip to main content

codex_codes/
protocol.rs

1//! App-server protocol types for the Codex CLI.
2//!
3//! Every wire type is generated from the upstream JSON Schema bundle by
4//! `scripts/codegen_protocol.py` and lives in [`crate::protocol_generated::types`].
5//! This module re-exports them and adds the JSON-RPC method-name constants
6//! the dispatch layer matches against.
7//!
8//! # Parsing notifications
9//!
10//! Prefer the typed dispatch in [`crate::messages`] over manual `method` checks:
11//!
12//! ```
13//! use codex_codes::{Notification, ServerMessage};
14//!
15//! fn handle(msg: ServerMessage) {
16//!     if let ServerMessage::Notification(Notification::TurnCompleted(c)) = msg {
17//!         println!("Turn on thread {} completed", c.thread_id);
18//!     }
19//! }
20//! ```
21
22pub use crate::protocol_generated::types::*;
23
24/// JSON-RPC method names used by the app-server protocol.
25///
26/// Use these constants when matching on [`crate::ServerMessage::Notification`] or
27/// [`crate::ServerMessage::Request`] method fields to avoid typos.
28pub mod methods {
29    // Client → server requests
30    pub const INITIALIZE: &str = "initialize";
31    pub const INITIALIZED: &str = "initialized";
32    pub const THREAD_START: &str = "thread/start";
33    pub const THREAD_ARCHIVE: &str = "thread/archive";
34    pub const TURN_START: &str = "turn/start";
35    pub const TURN_INTERRUPT: &str = "turn/interrupt";
36    pub const TURN_STEER: &str = "turn/steer";
37    pub const THREAD_RESUME: &str = "thread/resume";
38    pub const THREAD_FORK: &str = "thread/fork";
39    pub const THREAD_UNSUBSCRIBE: &str = "thread/unsubscribe";
40    pub const THREAD_NAME_SET: &str = "thread/name/set";
41    pub const THREAD_METADATA_UPDATE: &str = "thread/metadata/update";
42    pub const THREAD_UNARCHIVE: &str = "thread/unarchive";
43    pub const THREAD_COMPACT_START: &str = "thread/compact/start";
44    pub const THREAD_SHELLCOMMAND: &str = "thread/shellCommand";
45    pub const THREAD_APPROVEGUARDIANDENIEDACTION: &str = "thread/approveGuardianDeniedAction";
46    pub const THREAD_ROLLBACK: &str = "thread/rollback";
47    pub const THREAD_LIST: &str = "thread/list";
48    pub const THREAD_LOADED_LIST: &str = "thread/loaded/list";
49    pub const THREAD_READ: &str = "thread/read";
50    pub const THREAD_INJECT_ITEMS: &str = "thread/inject_items";
51    pub const SKILLS_LIST: &str = "skills/list";
52    pub const HOOKS_LIST: &str = "hooks/list";
53    pub const MARKETPLACE_ADD: &str = "marketplace/add";
54    pub const MARKETPLACE_REMOVE: &str = "marketplace/remove";
55    pub const MARKETPLACE_UPGRADE: &str = "marketplace/upgrade";
56    pub const PLUGIN_LIST: &str = "plugin/list";
57    pub const PLUGIN_READ: &str = "plugin/read";
58    pub const PLUGIN_SKILL_READ: &str = "plugin/skill/read";
59    pub const PLUGIN_SHARE_SAVE: &str = "plugin/share/save";
60    pub const PLUGIN_SHARE_UPDATETARGETS: &str = "plugin/share/updateTargets";
61    pub const PLUGIN_SHARE_LIST: &str = "plugin/share/list";
62    pub const PLUGIN_SHARE_CHECKOUT: &str = "plugin/share/checkout";
63    pub const PLUGIN_SHARE_DELETE: &str = "plugin/share/delete";
64    pub const APP_LIST: &str = "app/list";
65    pub const FS_READFILE: &str = "fs/readFile";
66    pub const FS_WRITEFILE: &str = "fs/writeFile";
67    pub const FS_CREATEDIRECTORY: &str = "fs/createDirectory";
68    pub const FS_GETMETADATA: &str = "fs/getMetadata";
69    pub const FS_READDIRECTORY: &str = "fs/readDirectory";
70    pub const FS_REMOVE: &str = "fs/remove";
71    pub const FS_COPY: &str = "fs/copy";
72    pub const FS_WATCH: &str = "fs/watch";
73    pub const FS_UNWATCH: &str = "fs/unwatch";
74    pub const SKILLS_CONFIG_WRITE: &str = "skills/config/write";
75    pub const PLUGIN_INSTALL: &str = "plugin/install";
76    pub const PLUGIN_UNINSTALL: &str = "plugin/uninstall";
77    pub const REVIEW_START: &str = "review/start";
78    pub const MODEL_LIST: &str = "model/list";
79    pub const MODELPROVIDER_CAPABILITIES_READ: &str = "modelProvider/capabilities/read";
80    pub const EXPERIMENTALFEATURE_LIST: &str = "experimentalFeature/list";
81    pub const EXPERIMENTALFEATURE_ENABLEMENT_SET: &str = "experimentalFeature/enablement/set";
82    pub const MCPSERVER_OAUTH_LOGIN: &str = "mcpServer/oauth/login";
83    pub const CONFIG_MCPSERVER_RELOAD: &str = "config/mcpServer/reload";
84    pub const MCPSERVERSTATUS_LIST: &str = "mcpServerStatus/list";
85    pub const MCPSERVER_RESOURCE_READ: &str = "mcpServer/resource/read";
86    pub const MCPSERVER_TOOL_CALL: &str = "mcpServer/tool/call";
87    pub const WINDOWSSANDBOX_SETUPSTART: &str = "windowsSandbox/setupStart";
88    pub const WINDOWSSANDBOX_READINESS: &str = "windowsSandbox/readiness";
89    pub const ACCOUNT_LOGIN_START: &str = "account/login/start";
90    pub const ACCOUNT_LOGIN_CANCEL: &str = "account/login/cancel";
91    pub const ACCOUNT_LOGOUT: &str = "account/logout";
92    pub const ACCOUNT_RATELIMITS_READ: &str = "account/rateLimits/read";
93    pub const ACCOUNT_SENDADDCREDITSNUDGEEMAIL: &str = "account/sendAddCreditsNudgeEmail";
94    pub const FEEDBACK_UPLOAD: &str = "feedback/upload";
95    pub const COMMAND_EXEC: &str = "command/exec";
96    pub const COMMAND_EXEC_WRITE: &str = "command/exec/write";
97    pub const COMMAND_EXEC_TERMINATE: &str = "command/exec/terminate";
98    pub const COMMAND_EXEC_RESIZE: &str = "command/exec/resize";
99    pub const CONFIG_READ: &str = "config/read";
100    pub const EXTERNALAGENTCONFIG_DETECT: &str = "externalAgentConfig/detect";
101    pub const EXTERNALAGENTCONFIG_IMPORT: &str = "externalAgentConfig/import";
102    pub const CONFIG_VALUE_WRITE: &str = "config/value/write";
103    pub const CONFIG_BATCHWRITE: &str = "config/batchWrite";
104    pub const CONFIGREQUIREMENTS_READ: &str = "configRequirements/read";
105    pub const ACCOUNT_READ: &str = "account/read";
106    pub const FUZZYFILESEARCH: &str = "fuzzyFileSearch";
107    pub const ACCOUNT_USAGE_READ: &str = "account/usage/read";
108    pub const PERMISSION_PROFILE_LIST: &str = "permissionProfile/list";
109    pub const PLUGIN_INSTALLED: &str = "plugin/installed";
110    pub const SKILLS_EXTRA_ROOTS_SET: &str = "skills/extraRoots/set";
111    pub const THREAD_GOAL_GET: &str = "thread/goal/get";
112    pub const THREAD_GOAL_SET: &str = "thread/goal/set";
113    pub const THREAD_GOAL_CLEAR: &str = "thread/goal/clear";
114
115    // Server → client notifications
116    pub const THREAD_STARTED: &str = "thread/started";
117    pub const THREAD_STATUS_CHANGED: &str = "thread/status/changed";
118    pub const THREAD_TOKEN_USAGE_UPDATED: &str = "thread/tokenUsage/updated";
119    pub const TURN_STARTED: &str = "turn/started";
120    pub const TURN_COMPLETED: &str = "turn/completed";
121    pub const ITEM_STARTED: &str = "item/started";
122    pub const ITEM_COMPLETED: &str = "item/completed";
123    pub const AGENT_MESSAGE_DELTA: &str = "item/agentMessage/delta";
124    pub const CMD_OUTPUT_DELTA: &str = "item/commandExecution/outputDelta";
125    pub const FILE_CHANGE_OUTPUT_DELTA: &str = "item/fileChange/outputDelta";
126    pub const REASONING_DELTA: &str = "item/reasoning/summaryTextDelta";
127    pub const ERROR: &str = "error";
128    pub const ACCOUNT_RATE_LIMITS_UPDATED: &str = "account/rateLimits/updated";
129    pub const MCP_SERVER_STARTUP_STATUS_UPDATED: &str = "mcpServer/startupStatus/updated";
130    pub const MCP_SERVER_OAUTH_LOGIN_COMPLETED: &str = "mcpServer/oauthLogin/completed";
131    pub const REMOTE_CONTROL_STATUS_CHANGED: &str = "remoteControl/status/changed";
132    pub const FILE_CHANGE_PATCH_UPDATED: &str = "item/fileChange/patchUpdated";
133    pub const PLAN_DELTA: &str = "item/plan/delta";
134    pub const TURN_PLAN_UPDATED: &str = "turn/plan/updated";
135    pub const TURN_DIFF_UPDATED: &str = "turn/diff/updated";
136    pub const REASONING_SUMMARY_PART_ADDED: &str = "item/reasoning/summaryPartAdded";
137    pub const REASONING_TEXT_DELTA: &str = "item/reasoning/textDelta";
138    pub const ACCOUNT_LOGIN_COMPLETED: &str = "account/login/completed";
139    pub const DEPRECATION_NOTICE: &str = "deprecationNotice";
140    pub const GUARDIAN_WARNING: &str = "guardianWarning";
141    pub const WARNING: &str = "warning";
142    pub const THREAD_ARCHIVED: &str = "thread/archived";
143    pub const THREAD_CLOSED: &str = "thread/closed";
144    pub const THREAD_UNARCHIVED: &str = "thread/unarchived";
145    pub const THREAD_GOAL_CLEARED: &str = "thread/goal/cleared";
146    pub const THREAD_NAME_UPDATED: &str = "thread/name/updated";
147    pub const SKILLS_CHANGED: &str = "skills/changed";
148    pub const FS_CHANGED: &str = "fs/changed";
149    pub const CONFIG_WARNING: &str = "configWarning";
150    pub const ACCOUNT_UPDATED: &str = "account/updated";
151    pub const APP_LIST_UPDATED: &str = "app/list/updated";
152    pub const COMMAND_EXEC_OUTPUT_DELTA: &str = "command/exec/outputDelta";
153    pub const EXTERNAL_AGENT_CONFIG_IMPORT_COMPLETED: &str = "externalAgentConfig/import/completed";
154    pub const FUZZY_FILE_SEARCH_SESSION_COMPLETED: &str = "fuzzyFileSearch/sessionCompleted";
155    pub const FUZZY_FILE_SEARCH_SESSION_UPDATED: &str = "fuzzyFileSearch/sessionUpdated";
156    pub const HOOK_COMPLETED: &str = "hook/completed";
157    pub const HOOK_STARTED: &str = "hook/started";
158    pub const ITEM_AUTO_APPROVAL_REVIEW_COMPLETED: &str = "item/autoApprovalReview/completed";
159    pub const ITEM_AUTO_APPROVAL_REVIEW_STARTED: &str = "item/autoApprovalReview/started";
160    pub const ITEM_COMMAND_EXEC_TERMINAL_INTERACTION: &str =
161        "item/commandExecution/terminalInteraction";
162    pub const ITEM_MCP_TOOL_CALL_PROGRESS: &str = "item/mcpToolCall/progress";
163    pub const MODEL_REROUTED: &str = "model/rerouted";
164    pub const MODEL_VERIFICATION: &str = "model/verification";
165    pub const PROCESS_EXITED: &str = "process/exited";
166    pub const PROCESS_OUTPUT_DELTA: &str = "process/outputDelta";
167    pub const SERVER_REQUEST_RESOLVED: &str = "serverRequest/resolved";
168    pub const THREAD_COMPACTED: &str = "thread/compacted";
169    pub const THREAD_GOAL_UPDATED: &str = "thread/goal/updated";
170    pub const THREAD_REALTIME_CLOSED: &str = "thread/realtime/closed";
171    pub const THREAD_REALTIME_ERROR: &str = "thread/realtime/error";
172    pub const THREAD_REALTIME_ITEM_ADDED: &str = "thread/realtime/itemAdded";
173    pub const THREAD_REALTIME_OUTPUT_AUDIO_DELTA: &str = "thread/realtime/outputAudio/delta";
174    pub const THREAD_REALTIME_SDP: &str = "thread/realtime/sdp";
175    pub const THREAD_REALTIME_STARTED: &str = "thread/realtime/started";
176    pub const THREAD_REALTIME_TRANSCRIPT_DELTA: &str = "thread/realtime/transcript/delta";
177    pub const THREAD_REALTIME_TRANSCRIPT_DONE: &str = "thread/realtime/transcript/done";
178    pub const WINDOWS_WORLD_WRITABLE_WARNING: &str = "windows/worldWritableWarning";
179    pub const WINDOWS_SANDBOX_SETUP_COMPLETED: &str = "windowsSandbox/setupCompleted";
180    pub const THREAD_SETTINGS_UPDATED: &str = "thread/settings/updated";
181    pub const TURN_MODERATION_METADATA: &str = "turn/moderationMetadata";
182
183    // Server → client requests (approval flow, v2 envelope)
184    pub const CMD_EXEC_APPROVAL: &str = "item/commandExecution/requestApproval";
185    pub const FILE_CHANGE_APPROVAL: &str = "item/fileChange/requestApproval";
186    pub const TOOL_REQUEST_USER_INPUT: &str = "item/tool/requestUserInput";
187    pub const MCP_SERVER_ELICITATION_REQUEST: &str = "mcpServer/elicitation/request";
188    pub const PERMISSIONS_REQUEST_APPROVAL: &str = "item/permissions/requestApproval";
189    pub const ITEM_TOOL_CALL: &str = "item/tool/call";
190    pub const CHATGPT_AUTH_TOKENS_REFRESH: &str = "account/chatgptAuthTokens/refresh";
191    pub const ATTESTATION_GENERATE: &str = "attestation/generate";
192    pub const APPLY_PATCH_APPROVAL: &str = "applyPatchApproval";
193    pub const EXEC_COMMAND_APPROVAL: &str = "execCommandApproval";
194}