aws-runtime-bridge 1.0.0

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 (462) hide show
  1. package/README.md +56 -0
  2. package/dist/adapter/AdapterRegistry.d.ts +53 -0
  3. package/dist/adapter/AdapterRegistry.d.ts.map +1 -0
  4. package/dist/adapter/AdapterRegistry.js +100 -0
  5. package/dist/adapter/AdapterRegistry.test.d.ts +5 -0
  6. package/dist/adapter/AdapterRegistry.test.d.ts.map +1 -0
  7. package/dist/adapter/AdapterRegistry.test.js +109 -0
  8. package/dist/adapter/ClaudeSdkAdapter.d.ts +120 -0
  9. package/dist/adapter/ClaudeSdkAdapter.d.ts.map +1 -0
  10. package/dist/adapter/ClaudeSdkAdapter.js +1140 -0
  11. package/dist/adapter/ClaudeSdkAdapter.test.d.ts +2 -0
  12. package/dist/adapter/ClaudeSdkAdapter.test.d.ts.map +1 -0
  13. package/dist/adapter/ClaudeSdkAdapter.test.js +95 -0
  14. package/dist/adapter/CodexSdkAdapter.d.ts +48 -0
  15. package/dist/adapter/CodexSdkAdapter.d.ts.map +1 -0
  16. package/dist/adapter/CodexSdkAdapter.js +750 -0
  17. package/dist/adapter/CodexSdkAdapter.test.d.ts +2 -0
  18. package/dist/adapter/CodexSdkAdapter.test.d.ts.map +1 -0
  19. package/dist/adapter/CodexSdkAdapter.test.js +245 -0
  20. package/dist/adapter/OpencodeSdkAdapter.d.ts +45 -0
  21. package/dist/adapter/OpencodeSdkAdapter.d.ts.map +1 -0
  22. package/dist/adapter/OpencodeSdkAdapter.js +622 -0
  23. package/dist/adapter/OpencodeSdkAdapter.test.d.ts +2 -0
  24. package/dist/adapter/OpencodeSdkAdapter.test.d.ts.map +1 -0
  25. package/dist/adapter/OpencodeSdkAdapter.test.js +14 -0
  26. package/dist/adapter/SdkProviderSpi.d.ts +15 -0
  27. package/dist/adapter/SdkProviderSpi.d.ts.map +1 -0
  28. package/dist/adapter/SdkProviderSpi.js +46 -0
  29. package/dist/adapter/adapter.test.d.ts +5 -0
  30. package/dist/adapter/adapter.test.d.ts.map +1 -0
  31. package/dist/adapter/adapter.test.js +180 -0
  32. package/dist/adapter/index.d.ts +11 -0
  33. package/dist/adapter/index.d.ts.map +1 -0
  34. package/dist/adapter/index.js +10 -0
  35. package/dist/adapter/types.d.ts +278 -0
  36. package/dist/adapter/types.d.ts.map +1 -0
  37. package/dist/adapter/types.js +278 -0
  38. package/dist/adapter/types.test.d.ts +2 -0
  39. package/dist/adapter/types.test.d.ts.map +1 -0
  40. package/dist/adapter/types.test.js +59 -0
  41. package/dist/adapters/cc-switch/common.d.ts +52 -0
  42. package/dist/adapters/cc-switch/common.d.ts.map +1 -0
  43. package/dist/adapters/cc-switch/common.js +61 -0
  44. package/dist/adapters/cc-switch/index.d.ts +25 -0
  45. package/dist/adapters/cc-switch/index.d.ts.map +1 -0
  46. package/dist/adapters/cc-switch/index.js +51 -0
  47. package/dist/adapters/cc-switch/mcp-claude.d.ts +15 -0
  48. package/dist/adapters/cc-switch/mcp-claude.d.ts.map +1 -0
  49. package/dist/adapters/cc-switch/mcp-claude.js +88 -0
  50. package/dist/adapters/cc-switch/mcp-claudecode.d.ts +15 -0
  51. package/dist/adapters/cc-switch/mcp-claudecode.d.ts.map +1 -0
  52. package/dist/adapters/cc-switch/mcp-claudecode.js +77 -0
  53. package/dist/adapters/cc-switch/mcp-codex.d.ts +17 -0
  54. package/dist/adapters/cc-switch/mcp-codex.d.ts.map +1 -0
  55. package/dist/adapters/cc-switch/mcp-codex.js +248 -0
  56. package/dist/adapters/cc-switch/mcp-codex.test.d.ts +2 -0
  57. package/dist/adapters/cc-switch/mcp-codex.test.d.ts.map +1 -0
  58. package/dist/adapters/cc-switch/mcp-codex.test.js +125 -0
  59. package/dist/adapters/cc-switch/mcp-opencode.d.ts +23 -0
  60. package/dist/adapters/cc-switch/mcp-opencode.d.ts.map +1 -0
  61. package/dist/adapters/cc-switch/mcp-opencode.js +100 -0
  62. package/dist/adapters/cc-switch/mcp-placeholder.d.ts +14 -0
  63. package/dist/adapters/cc-switch/mcp-placeholder.d.ts.map +1 -0
  64. package/dist/adapters/cc-switch/mcp-placeholder.js +19 -0
  65. package/dist/adapters/cc-switch/skill-claude.d.ts +15 -0
  66. package/dist/adapters/cc-switch/skill-claude.d.ts.map +1 -0
  67. package/dist/adapters/cc-switch/skill-claude.js +91 -0
  68. package/dist/adapters/cc-switch/skill-claudecode.d.ts +15 -0
  69. package/dist/adapters/cc-switch/skill-claudecode.d.ts.map +1 -0
  70. package/dist/adapters/cc-switch/skill-claudecode.js +91 -0
  71. package/dist/adapters/cc-switch/skill-opencode.d.ts +15 -0
  72. package/dist/adapters/cc-switch/skill-opencode.d.ts.map +1 -0
  73. package/dist/adapters/cc-switch/skill-opencode.js +95 -0
  74. package/dist/adapters/cc-switch/skill-placeholder.d.ts +14 -0
  75. package/dist/adapters/cc-switch/skill-placeholder.d.ts.map +1 -0
  76. package/dist/adapters/cc-switch/skill-placeholder.js +19 -0
  77. package/dist/config.d.ts +76 -0
  78. package/dist/config.d.ts.map +1 -0
  79. package/dist/config.js +109 -0
  80. package/dist/index.d.ts +8 -0
  81. package/dist/index.d.ts.map +1 -0
  82. package/dist/index.js +503 -0
  83. package/dist/middleware/auth.d.ts +12 -0
  84. package/dist/middleware/auth.d.ts.map +1 -0
  85. package/dist/middleware/auth.js +18 -0
  86. package/dist/routes/ai-sources.d.ts +2 -0
  87. package/dist/routes/ai-sources.d.ts.map +1 -0
  88. package/dist/routes/ai-sources.js +136 -0
  89. package/dist/routes/ai-sources.test.d.ts +2 -0
  90. package/dist/routes/ai-sources.test.d.ts.map +1 -0
  91. package/dist/routes/ai-sources.test.js +148 -0
  92. package/dist/routes/aws-mcp.d.ts +10 -0
  93. package/dist/routes/aws-mcp.d.ts.map +1 -0
  94. package/dist/routes/aws-mcp.js +74 -0
  95. package/dist/routes/aws-mcp.test.d.ts +2 -0
  96. package/dist/routes/aws-mcp.test.d.ts.map +1 -0
  97. package/dist/routes/aws-mcp.test.js +42 -0
  98. package/dist/routes/file-browser.d.ts +7 -0
  99. package/dist/routes/file-browser.d.ts.map +1 -0
  100. package/dist/routes/file-browser.js +227 -0
  101. package/dist/routes/file-browser.test.d.ts +5 -0
  102. package/dist/routes/file-browser.test.d.ts.map +1 -0
  103. package/dist/routes/file-browser.test.js +88 -0
  104. package/dist/routes/git.d.ts +7 -0
  105. package/dist/routes/git.d.ts.map +1 -0
  106. package/dist/routes/git.js +470 -0
  107. package/dist/routes/git.test.d.ts +5 -0
  108. package/dist/routes/git.test.d.ts.map +1 -0
  109. package/dist/routes/git.test.js +87 -0
  110. package/dist/routes/instance.d.ts +3 -0
  111. package/dist/routes/instance.d.ts.map +1 -0
  112. package/dist/routes/instance.js +170 -0
  113. package/dist/routes/instance.test.d.ts +5 -0
  114. package/dist/routes/instance.test.d.ts.map +1 -0
  115. package/dist/routes/instance.test.js +64 -0
  116. package/dist/routes/mcp.d.ts +2 -0
  117. package/dist/routes/mcp.d.ts.map +1 -0
  118. package/dist/routes/mcp.js +171 -0
  119. package/dist/routes/mcp.test.d.ts +5 -0
  120. package/dist/routes/mcp.test.d.ts.map +1 -0
  121. package/dist/routes/mcp.test.js +84 -0
  122. package/dist/routes/memory.d.ts +13 -0
  123. package/dist/routes/memory.d.ts.map +1 -0
  124. package/dist/routes/memory.js +429 -0
  125. package/dist/routes/processes.d.ts +7 -0
  126. package/dist/routes/processes.d.ts.map +1 -0
  127. package/dist/routes/processes.js +245 -0
  128. package/dist/routes/properties.d.ts +7 -0
  129. package/dist/routes/properties.d.ts.map +1 -0
  130. package/dist/routes/properties.js +72 -0
  131. package/dist/routes/properties.test.d.ts +5 -0
  132. package/dist/routes/properties.test.d.ts.map +1 -0
  133. package/dist/routes/properties.test.js +72 -0
  134. package/dist/routes/sessions.d.ts +7 -0
  135. package/dist/routes/sessions.d.ts.map +1 -0
  136. package/dist/routes/sessions.js +808 -0
  137. package/dist/routes/sessions.test.d.ts +5 -0
  138. package/dist/routes/sessions.test.d.ts.map +1 -0
  139. package/dist/routes/sessions.test.js +70 -0
  140. package/dist/routes/skills.d.ts +2 -0
  141. package/dist/routes/skills.d.ts.map +1 -0
  142. package/dist/routes/skills.js +162 -0
  143. package/dist/routes/skills.test.d.ts +5 -0
  144. package/dist/routes/skills.test.d.ts.map +1 -0
  145. package/dist/routes/skills.test.js +42 -0
  146. package/dist/routes/terminal.d.ts +18 -0
  147. package/dist/routes/terminal.d.ts.map +1 -0
  148. package/dist/routes/terminal.js +663 -0
  149. package/dist/routes/terminal.test.d.ts +2 -0
  150. package/dist/routes/terminal.test.d.ts.map +1 -0
  151. package/dist/routes/terminal.test.js +91 -0
  152. package/dist/routes/yml.d.ts +7 -0
  153. package/dist/routes/yml.d.ts.map +1 -0
  154. package/dist/routes/yml.js +223 -0
  155. package/dist/routes/yml.test.d.ts +5 -0
  156. package/dist/routes/yml.test.d.ts.map +1 -0
  157. package/dist/routes/yml.test.js +58 -0
  158. package/dist/services/agent-process-manager.d.ts +241 -0
  159. package/dist/services/agent-process-manager.d.ts.map +1 -0
  160. package/dist/services/agent-process-manager.js +762 -0
  161. package/dist/services/auto-register.d.ts +94 -0
  162. package/dist/services/auto-register.d.ts.map +1 -0
  163. package/dist/services/auto-register.js +510 -0
  164. package/dist/services/aws-client-agent-mcp.d.ts +26 -0
  165. package/dist/services/aws-client-agent-mcp.d.ts.map +1 -0
  166. package/dist/services/aws-client-agent-mcp.js +142 -0
  167. package/dist/services/aws-client-agent-mcp.test.d.ts +2 -0
  168. package/dist/services/aws-client-agent-mcp.test.d.ts.map +1 -0
  169. package/dist/services/aws-client-agent-mcp.test.js +89 -0
  170. package/dist/services/aws-mcp-http.d.ts +11 -0
  171. package/dist/services/aws-mcp-http.d.ts.map +1 -0
  172. package/dist/services/aws-mcp-http.js +225 -0
  173. package/dist/services/aws-mcp-http.test.d.ts +2 -0
  174. package/dist/services/aws-mcp-http.test.d.ts.map +1 -0
  175. package/dist/services/aws-mcp-http.test.js +27 -0
  176. package/dist/services/cc-switch-sdk.d.ts +18 -0
  177. package/dist/services/cc-switch-sdk.d.ts.map +1 -0
  178. package/dist/services/cc-switch-sdk.js +117 -0
  179. package/dist/services/easytier-manager.d.ts +106 -0
  180. package/dist/services/easytier-manager.d.ts.map +1 -0
  181. package/dist/services/easytier-manager.js +331 -0
  182. package/dist/services/easytier-manager.test.d.ts +5 -0
  183. package/dist/services/easytier-manager.test.d.ts.map +1 -0
  184. package/dist/services/easytier-manager.test.js +98 -0
  185. package/dist/services/instance-init-service.d.ts +35 -0
  186. package/dist/services/instance-init-service.d.ts.map +1 -0
  187. package/dist/services/instance-init-service.js +190 -0
  188. package/dist/services/instance-service.d.ts +88 -0
  189. package/dist/services/instance-service.d.ts.map +1 -0
  190. package/dist/services/instance-service.js +236 -0
  191. package/dist/services/instance-state.d.ts +36 -0
  192. package/dist/services/instance-state.d.ts.map +1 -0
  193. package/dist/services/instance-state.js +79 -0
  194. package/dist/services/instance-state.test.d.ts +2 -0
  195. package/dist/services/instance-state.test.d.ts.map +1 -0
  196. package/dist/services/instance-state.test.js +213 -0
  197. package/dist/services/memory-service.d.ts +195 -0
  198. package/dist/services/memory-service.d.ts.map +1 -0
  199. package/dist/services/memory-service.js +650 -0
  200. package/dist/services/orphan-monitor.d.ts +94 -0
  201. package/dist/services/orphan-monitor.d.ts.map +1 -0
  202. package/dist/services/orphan-monitor.js +321 -0
  203. package/dist/services/process-detector.d.ts +175 -0
  204. package/dist/services/process-detector.d.ts.map +1 -0
  205. package/dist/services/process-detector.js +992 -0
  206. package/dist/services/process-registry.d.ts +208 -0
  207. package/dist/services/process-registry.d.ts.map +1 -0
  208. package/dist/services/process-registry.js +354 -0
  209. package/dist/services/session-lookup.d.ts +20 -0
  210. package/dist/services/session-lookup.d.ts.map +1 -0
  211. package/dist/services/session-lookup.js +43 -0
  212. package/dist/services/session-output.d.ts +56 -0
  213. package/dist/services/session-output.d.ts.map +1 -0
  214. package/dist/services/session-output.js +122 -0
  215. package/dist/services/session-output.test.d.ts +5 -0
  216. package/dist/services/session-output.test.d.ts.map +1 -0
  217. package/dist/services/session-output.test.js +68 -0
  218. package/dist/services/terminal-persistence.d.ts +51 -0
  219. package/dist/services/terminal-persistence.d.ts.map +1 -0
  220. package/dist/services/terminal-persistence.js +125 -0
  221. package/dist/services/terminal-persistence.test.d.ts +5 -0
  222. package/dist/services/terminal-persistence.test.d.ts.map +1 -0
  223. package/dist/services/terminal-persistence.test.js +88 -0
  224. package/dist/services/tool-installer.d.ts +15 -0
  225. package/dist/services/tool-installer.d.ts.map +1 -0
  226. package/dist/services/tool-installer.js +297 -0
  227. package/dist/services/tool-installer.test.d.ts +2 -0
  228. package/dist/services/tool-installer.test.d.ts.map +1 -0
  229. package/dist/services/tool-installer.test.js +102 -0
  230. package/dist/services/user-api-key-service.d.ts +28 -0
  231. package/dist/services/user-api-key-service.d.ts.map +1 -0
  232. package/dist/services/user-api-key-service.js +75 -0
  233. package/dist/services/workspace-files.d.ts +85 -0
  234. package/dist/services/workspace-files.d.ts.map +1 -0
  235. package/dist/services/workspace-files.js +224 -0
  236. package/dist/services/workspace-files.test.d.ts +2 -0
  237. package/dist/services/workspace-files.test.d.ts.map +1 -0
  238. package/dist/services/workspace-files.test.js +117 -0
  239. package/dist/types.d.ts +233 -0
  240. package/dist/types.d.ts.map +1 -0
  241. package/dist/types.js +1 -0
  242. package/dist/utils/file-utils.d.ts +13 -0
  243. package/dist/utils/file-utils.d.ts.map +1 -0
  244. package/dist/utils/file-utils.js +140 -0
  245. package/dist/utils/file-utils.test.d.ts +2 -0
  246. package/dist/utils/file-utils.test.d.ts.map +1 -0
  247. package/dist/utils/file-utils.test.js +201 -0
  248. package/dist/utils/logger.d.ts +39 -0
  249. package/dist/utils/logger.d.ts.map +1 -0
  250. package/dist/utils/logger.js +110 -0
  251. package/dist/utils/logger.test.d.ts +2 -0
  252. package/dist/utils/logger.test.d.ts.map +1 -0
  253. package/dist/utils/logger.test.js +93 -0
  254. package/dist/utils/mcp-utils.d.ts +73 -0
  255. package/dist/utils/mcp-utils.d.ts.map +1 -0
  256. package/dist/utils/mcp-utils.js +165 -0
  257. package/dist/utils/path-utils.d.ts +24 -0
  258. package/dist/utils/path-utils.d.ts.map +1 -0
  259. package/dist/utils/path-utils.js +44 -0
  260. package/dist/utils/validation.d.ts +23 -0
  261. package/dist/utils/validation.d.ts.map +1 -0
  262. package/dist/utils/validation.js +53 -0
  263. package/dist/utils/validation.test.d.ts +2 -0
  264. package/dist/utils/validation.test.d.ts.map +1 -0
  265. package/dist/utils/validation.test.js +88 -0
  266. package/dist/utils/yaml-utils.d.ts +73 -0
  267. package/dist/utils/yaml-utils.d.ts.map +1 -0
  268. package/dist/utils/yaml-utils.js +309 -0
  269. package/dist/utils/yaml-utils.test.d.ts +2 -0
  270. package/dist/utils/yaml-utils.test.d.ts.map +1 -0
  271. package/dist/utils/yaml-utils.test.js +363 -0
  272. package/package/aws-client-agent-mcp/README.md +288 -0
  273. package/package/aws-client-agent-mcp/dist/activity-reporter.d.ts +150 -0
  274. package/package/aws-client-agent-mcp/dist/activity-reporter.d.ts.map +1 -0
  275. package/package/aws-client-agent-mcp/dist/activity-reporter.js +353 -0
  276. package/package/aws-client-agent-mcp/dist/activity-reporter.js.map +1 -0
  277. package/package/aws-client-agent-mcp/dist/activity-reporter.test.d.ts +2 -0
  278. package/package/aws-client-agent-mcp/dist/activity-reporter.test.d.ts.map +1 -0
  279. package/package/aws-client-agent-mcp/dist/activity-reporter.test.js +75 -0
  280. package/package/aws-client-agent-mcp/dist/activity-reporter.test.js.map +1 -0
  281. package/package/aws-client-agent-mcp/dist/activity-types.d.ts +96 -0
  282. package/package/aws-client-agent-mcp/dist/activity-types.d.ts.map +1 -0
  283. package/package/aws-client-agent-mcp/dist/activity-types.js +141 -0
  284. package/package/aws-client-agent-mcp/dist/activity-types.js.map +1 -0
  285. package/package/aws-client-agent-mcp/dist/agent-client.d.ts +165 -0
  286. package/package/aws-client-agent-mcp/dist/agent-client.d.ts.map +1 -0
  287. package/package/aws-client-agent-mcp/dist/agent-client.js +588 -0
  288. package/package/aws-client-agent-mcp/dist/agent-client.js.map +1 -0
  289. package/package/aws-client-agent-mcp/dist/agent-client.test.d.ts +2 -0
  290. package/package/aws-client-agent-mcp/dist/agent-client.test.d.ts.map +1 -0
  291. package/package/aws-client-agent-mcp/dist/agent-client.test.js +534 -0
  292. package/package/aws-client-agent-mcp/dist/agent-client.test.js.map +1 -0
  293. package/package/aws-client-agent-mcp/dist/config.d.ts +21 -0
  294. package/package/aws-client-agent-mcp/dist/config.d.ts.map +1 -0
  295. package/package/aws-client-agent-mcp/dist/config.js +67 -0
  296. package/package/aws-client-agent-mcp/dist/config.js.map +1 -0
  297. package/package/aws-client-agent-mcp/dist/config.test.d.ts +2 -0
  298. package/package/aws-client-agent-mcp/dist/config.test.d.ts.map +1 -0
  299. package/package/aws-client-agent-mcp/dist/config.test.js +139 -0
  300. package/package/aws-client-agent-mcp/dist/config.test.js.map +1 -0
  301. package/package/aws-client-agent-mcp/dist/constants.d.ts +15 -0
  302. package/package/aws-client-agent-mcp/dist/constants.d.ts.map +1 -0
  303. package/package/aws-client-agent-mcp/dist/constants.js +19 -0
  304. package/package/aws-client-agent-mcp/dist/constants.js.map +1 -0
  305. package/package/aws-client-agent-mcp/dist/http-client.d.ts +27 -0
  306. package/package/aws-client-agent-mcp/dist/http-client.d.ts.map +1 -0
  307. package/package/aws-client-agent-mcp/dist/http-client.js +65 -0
  308. package/package/aws-client-agent-mcp/dist/http-client.js.map +1 -0
  309. package/package/aws-client-agent-mcp/dist/http-client.test.d.ts +2 -0
  310. package/package/aws-client-agent-mcp/dist/http-client.test.d.ts.map +1 -0
  311. package/package/aws-client-agent-mcp/dist/http-client.test.js +228 -0
  312. package/package/aws-client-agent-mcp/dist/http-client.test.js.map +1 -0
  313. package/package/aws-client-agent-mcp/dist/index.d.ts +14 -0
  314. package/package/aws-client-agent-mcp/dist/index.d.ts.map +1 -0
  315. package/package/aws-client-agent-mcp/dist/index.js +30 -0
  316. package/package/aws-client-agent-mcp/dist/index.js.map +1 -0
  317. package/package/aws-client-agent-mcp/dist/logger.d.ts +7 -0
  318. package/package/aws-client-agent-mcp/dist/logger.d.ts.map +1 -0
  319. package/package/aws-client-agent-mcp/dist/logger.js +19 -0
  320. package/package/aws-client-agent-mcp/dist/logger.js.map +1 -0
  321. package/package/aws-client-agent-mcp/dist/mcp-server.d.ts +77 -0
  322. package/package/aws-client-agent-mcp/dist/mcp-server.d.ts.map +1 -0
  323. package/package/aws-client-agent-mcp/dist/mcp-server.js +427 -0
  324. package/package/aws-client-agent-mcp/dist/mcp-server.js.map +1 -0
  325. package/package/aws-client-agent-mcp/dist/mcp-server.test.d.ts +2 -0
  326. package/package/aws-client-agent-mcp/dist/mcp-server.test.d.ts.map +1 -0
  327. package/package/aws-client-agent-mcp/dist/mcp-server.test.js +624 -0
  328. package/package/aws-client-agent-mcp/dist/mcp-server.test.js.map +1 -0
  329. package/package/aws-client-agent-mcp/dist/mcp-tools.d.ts +78 -0
  330. package/package/aws-client-agent-mcp/dist/mcp-tools.d.ts.map +1 -0
  331. package/package/aws-client-agent-mcp/dist/mcp-tools.js +420 -0
  332. package/package/aws-client-agent-mcp/dist/mcp-tools.js.map +1 -0
  333. package/package/aws-client-agent-mcp/dist/memory-store.d.ts +61 -0
  334. package/package/aws-client-agent-mcp/dist/memory-store.d.ts.map +1 -0
  335. package/package/aws-client-agent-mcp/dist/memory-store.js +268 -0
  336. package/package/aws-client-agent-mcp/dist/memory-store.js.map +1 -0
  337. package/package/aws-client-agent-mcp/dist/memory-store.test.d.ts +2 -0
  338. package/package/aws-client-agent-mcp/dist/memory-store.test.d.ts.map +1 -0
  339. package/package/aws-client-agent-mcp/dist/memory-store.test.js +164 -0
  340. package/package/aws-client-agent-mcp/dist/memory-store.test.js.map +1 -0
  341. package/package/aws-client-agent-mcp/dist/message-buffer.d.ts +74 -0
  342. package/package/aws-client-agent-mcp/dist/message-buffer.d.ts.map +1 -0
  343. package/package/aws-client-agent-mcp/dist/message-buffer.js +159 -0
  344. package/package/aws-client-agent-mcp/dist/message-buffer.js.map +1 -0
  345. package/package/aws-client-agent-mcp/dist/message-buffer.test.d.ts +2 -0
  346. package/package/aws-client-agent-mcp/dist/message-buffer.test.d.ts.map +1 -0
  347. package/package/aws-client-agent-mcp/dist/message-buffer.test.js +44 -0
  348. package/package/aws-client-agent-mcp/dist/message-buffer.test.js.map +1 -0
  349. package/package/aws-client-agent-mcp/dist/messageContent.d.ts +53 -0
  350. package/package/aws-client-agent-mcp/dist/messageContent.d.ts.map +1 -0
  351. package/package/aws-client-agent-mcp/dist/messageContent.js +125 -0
  352. package/package/aws-client-agent-mcp/dist/messageContent.js.map +1 -0
  353. package/package/aws-client-agent-mcp/dist/orchestration-tools.d.ts +19 -0
  354. package/package/aws-client-agent-mcp/dist/orchestration-tools.d.ts.map +1 -0
  355. package/package/aws-client-agent-mcp/dist/orchestration-tools.js +317 -0
  356. package/package/aws-client-agent-mcp/dist/orchestration-tools.js.map +1 -0
  357. package/package/aws-client-agent-mcp/dist/status-reporter.d.ts +66 -0
  358. package/package/aws-client-agent-mcp/dist/status-reporter.d.ts.map +1 -0
  359. package/package/aws-client-agent-mcp/dist/status-reporter.js +220 -0
  360. package/package/aws-client-agent-mcp/dist/status-reporter.js.map +1 -0
  361. package/package/aws-client-agent-mcp/dist/status-reporter.test.d.ts +2 -0
  362. package/package/aws-client-agent-mcp/dist/status-reporter.test.d.ts.map +1 -0
  363. package/package/aws-client-agent-mcp/dist/status-reporter.test.js +45 -0
  364. package/package/aws-client-agent-mcp/dist/status-reporter.test.js.map +1 -0
  365. package/package/aws-client-agent-mcp/dist/types.d.ts +286 -0
  366. package/package/aws-client-agent-mcp/dist/types.d.ts.map +1 -0
  367. package/package/aws-client-agent-mcp/dist/types.js +9 -0
  368. package/package/aws-client-agent-mcp/dist/types.js.map +1 -0
  369. package/package/aws-client-agent-mcp/dist/user-config-reader.d.ts +63 -0
  370. package/package/aws-client-agent-mcp/dist/user-config-reader.d.ts.map +1 -0
  371. package/package/aws-client-agent-mcp/dist/user-config-reader.js +161 -0
  372. package/package/aws-client-agent-mcp/dist/user-config-reader.js.map +1 -0
  373. package/package/aws-client-agent-mcp/dist/websocket-client.d.ts +94 -0
  374. package/package/aws-client-agent-mcp/dist/websocket-client.d.ts.map +1 -0
  375. package/package/aws-client-agent-mcp/dist/websocket-client.js +316 -0
  376. package/package/aws-client-agent-mcp/dist/websocket-client.js.map +1 -0
  377. package/package/aws-client-agent-mcp/dist/websocket-client.test.d.ts +2 -0
  378. package/package/aws-client-agent-mcp/dist/websocket-client.test.d.ts.map +1 -0
  379. package/package/aws-client-agent-mcp/dist/websocket-client.test.js +191 -0
  380. package/package/aws-client-agent-mcp/dist/websocket-client.test.js.map +1 -0
  381. package/package/aws-client-agent-mcp/package.json +51 -0
  382. package/package/cc-switch-sdk/README.md +541 -0
  383. package/package/cc-switch-sdk/dist/adapters/common.d.ts +38 -0
  384. package/package/cc-switch-sdk/dist/adapters/common.d.ts.map +1 -0
  385. package/package/cc-switch-sdk/dist/adapters/common.js +47 -0
  386. package/package/cc-switch-sdk/dist/adapters/index.d.ts +5 -0
  387. package/package/cc-switch-sdk/dist/adapters/index.d.ts.map +1 -0
  388. package/package/cc-switch-sdk/dist/adapters/index.js +28 -0
  389. package/package/cc-switch-sdk/dist/adapters/mcp-claude.d.ts +10 -0
  390. package/package/cc-switch-sdk/dist/adapters/mcp-claude.d.ts.map +1 -0
  391. package/package/cc-switch-sdk/dist/adapters/mcp-claude.js +39 -0
  392. package/package/cc-switch-sdk/dist/adapters/mcp-claudecode.d.ts +10 -0
  393. package/package/cc-switch-sdk/dist/adapters/mcp-claudecode.d.ts.map +1 -0
  394. package/package/cc-switch-sdk/dist/adapters/mcp-claudecode.js +40 -0
  395. package/package/cc-switch-sdk/dist/adapters/mcp-opencode.d.ts +18 -0
  396. package/package/cc-switch-sdk/dist/adapters/mcp-opencode.d.ts.map +1 -0
  397. package/package/cc-switch-sdk/dist/adapters/mcp-opencode.js +63 -0
  398. package/package/cc-switch-sdk/dist/adapters/mcp-opencode.test.d.ts +2 -0
  399. package/package/cc-switch-sdk/dist/adapters/mcp-opencode.test.d.ts.map +1 -0
  400. package/package/cc-switch-sdk/dist/adapters/mcp-opencode.test.js +86 -0
  401. package/package/cc-switch-sdk/dist/adapters/mcp-placeholder.d.ts +9 -0
  402. package/package/cc-switch-sdk/dist/adapters/mcp-placeholder.d.ts.map +1 -0
  403. package/package/cc-switch-sdk/dist/adapters/mcp-placeholder.js +14 -0
  404. package/package/cc-switch-sdk/dist/adapters/skill-claude.d.ts +10 -0
  405. package/package/cc-switch-sdk/dist/adapters/skill-claude.d.ts.map +1 -0
  406. package/package/cc-switch-sdk/dist/adapters/skill-claude.js +51 -0
  407. package/package/cc-switch-sdk/dist/adapters/skill-claudecode.d.ts +10 -0
  408. package/package/cc-switch-sdk/dist/adapters/skill-claudecode.d.ts.map +1 -0
  409. package/package/cc-switch-sdk/dist/adapters/skill-claudecode.js +51 -0
  410. package/package/cc-switch-sdk/dist/adapters/skill-opencode.d.ts +10 -0
  411. package/package/cc-switch-sdk/dist/adapters/skill-opencode.d.ts.map +1 -0
  412. package/package/cc-switch-sdk/dist/adapters/skill-opencode.js +51 -0
  413. package/package/cc-switch-sdk/dist/adapters/skill-placeholder.d.ts +9 -0
  414. package/package/cc-switch-sdk/dist/adapters/skill-placeholder.d.ts.map +1 -0
  415. package/package/cc-switch-sdk/dist/adapters/skill-placeholder.js +14 -0
  416. package/package/cc-switch-sdk/dist/constants.d.ts +9 -0
  417. package/package/cc-switch-sdk/dist/constants.d.ts.map +1 -0
  418. package/package/cc-switch-sdk/dist/constants.js +54 -0
  419. package/package/cc-switch-sdk/dist/errors.d.ts +6 -0
  420. package/package/cc-switch-sdk/dist/errors.d.ts.map +1 -0
  421. package/package/cc-switch-sdk/dist/errors.js +8 -0
  422. package/package/cc-switch-sdk/dist/index.d.ts +11 -0
  423. package/package/cc-switch-sdk/dist/index.d.ts.map +1 -0
  424. package/package/cc-switch-sdk/dist/index.js +9 -0
  425. package/package/cc-switch-sdk/dist/schemas.d.ts +8 -0
  426. package/package/cc-switch-sdk/dist/schemas.d.ts.map +1 -0
  427. package/package/cc-switch-sdk/dist/schemas.js +37 -0
  428. package/package/cc-switch-sdk/dist/sdk.d.ts +91 -0
  429. package/package/cc-switch-sdk/dist/sdk.d.ts.map +1 -0
  430. package/package/cc-switch-sdk/dist/sdk.js +427 -0
  431. package/package/cc-switch-sdk/dist/services/ai-config-service.d.ts +75 -0
  432. package/package/cc-switch-sdk/dist/services/ai-config-service.d.ts.map +1 -0
  433. package/package/cc-switch-sdk/dist/services/ai-config-service.js +280 -0
  434. package/package/cc-switch-sdk/dist/services/instance-service.d.ts +78 -0
  435. package/package/cc-switch-sdk/dist/services/instance-service.d.ts.map +1 -0
  436. package/package/cc-switch-sdk/dist/services/instance-service.js +180 -0
  437. package/package/cc-switch-sdk/dist/services/mcp-model.d.ts +17 -0
  438. package/package/cc-switch-sdk/dist/services/mcp-model.d.ts.map +1 -0
  439. package/package/cc-switch-sdk/dist/services/mcp-model.js +34 -0
  440. package/package/cc-switch-sdk/dist/services/mcp-service.d.ts +18 -0
  441. package/package/cc-switch-sdk/dist/services/mcp-service.d.ts.map +1 -0
  442. package/package/cc-switch-sdk/dist/services/mcp-service.js +9 -0
  443. package/package/cc-switch-sdk/dist/services/skill-model.d.ts +17 -0
  444. package/package/cc-switch-sdk/dist/services/skill-model.d.ts.map +1 -0
  445. package/package/cc-switch-sdk/dist/services/skill-model.js +38 -0
  446. package/package/cc-switch-sdk/dist/services/skill-service.d.ts +17 -0
  447. package/package/cc-switch-sdk/dist/services/skill-service.d.ts.map +1 -0
  448. package/package/cc-switch-sdk/dist/services/skill-service.js +9 -0
  449. package/package/cc-switch-sdk/dist/state.d.ts +4 -0
  450. package/package/cc-switch-sdk/dist/state.d.ts.map +1 -0
  451. package/package/cc-switch-sdk/dist/state.js +19 -0
  452. package/package/cc-switch-sdk/dist/types.d.ts +75 -0
  453. package/package/cc-switch-sdk/dist/types.d.ts.map +1 -0
  454. package/package/cc-switch-sdk/dist/types.js +1 -0
  455. package/package/cc-switch-sdk/dist/utils/fs.d.ts +10 -0
  456. package/package/cc-switch-sdk/dist/utils/fs.d.ts.map +1 -0
  457. package/package/cc-switch-sdk/dist/utils/fs.js +91 -0
  458. package/package/cc-switch-sdk/dist/utils/id.d.ts +4 -0
  459. package/package/cc-switch-sdk/dist/utils/id.d.ts.map +1 -0
  460. package/package/cc-switch-sdk/dist/utils/id.js +12 -0
  461. package/package/cc-switch-sdk/package.json +31 -0
  462. package/package.json +73 -0
@@ -0,0 +1,750 @@
1
+ /**
2
+ * OpenAI Codex SDK Adapter
3
+ *
4
+ * 通过 @openai/codex-sdk 的 Thread/runStreamed() API
5
+ * 将 Codex 事件流映射到 runtime-bridge 统一 ProviderEvent。
6
+ */
7
+ import { EventEmitter } from 'node:events';
8
+ import { Codex, } from '@openai/codex-sdk';
9
+ import { v4 as uuidv4 } from 'uuid';
10
+ import { getToolActionInfo } from './types.js';
11
+ const CODEX_IDLE_THRESHOLD_MS = 1500;
12
+ function isRecord(value) {
13
+ return typeof value === 'object' && value !== null && !Array.isArray(value);
14
+ }
15
+ function toRecord(value) {
16
+ return isRecord(value) ? value : { value };
17
+ }
18
+ function serializeValue(value) {
19
+ if (typeof value === 'string') {
20
+ return value;
21
+ }
22
+ try {
23
+ return JSON.stringify(value);
24
+ }
25
+ catch {
26
+ return String(value);
27
+ }
28
+ }
29
+ function toEnvRecord(env, overrides) {
30
+ const result = {};
31
+ for (const [key, value] of Object.entries(env)) {
32
+ if (typeof value === 'string') {
33
+ result[key] = value;
34
+ }
35
+ }
36
+ return { ...result, ...(overrides ?? {}) };
37
+ }
38
+ function splitCommandLine(command) {
39
+ const tokens = [];
40
+ let current = '';
41
+ let quote = null;
42
+ let escaping = false;
43
+ for (const char of command.trim()) {
44
+ if (escaping) {
45
+ current += char;
46
+ escaping = false;
47
+ continue;
48
+ }
49
+ if (char === '\\' && quote !== "'") {
50
+ escaping = true;
51
+ continue;
52
+ }
53
+ if ((char === '"' || char === "'") && quote === null) {
54
+ quote = char;
55
+ continue;
56
+ }
57
+ if (char === quote) {
58
+ quote = null;
59
+ continue;
60
+ }
61
+ if (/\s/.test(char) && quote === null) {
62
+ if (current.length > 0) {
63
+ tokens.push(current);
64
+ current = '';
65
+ }
66
+ continue;
67
+ }
68
+ current += char;
69
+ }
70
+ if (escaping) {
71
+ current += '\\';
72
+ }
73
+ if (current.length > 0) {
74
+ tokens.push(current);
75
+ }
76
+ return tokens;
77
+ }
78
+ function commandName(command) {
79
+ const normalized = (command || '').replace(/\\/g, '/').toLowerCase();
80
+ const lastSegment = normalized.split('/').pop() || normalized;
81
+ return lastSegment.replace(/\.(cmd|exe)$/i, '');
82
+ }
83
+ function isPathLikeCommand(command) {
84
+ return command.includes('/') || command.includes('\\') || /^[a-zA-Z]:/.test(command);
85
+ }
86
+ function parseCodexCommand(command) {
87
+ const tokens = splitCommandLine(command || 'codex');
88
+ if (tokens.length === 0) {
89
+ return { args: [] };
90
+ }
91
+ const [first, second, ...rest] = tokens;
92
+ const firstName = commandName(first);
93
+ if (isPathLikeCommand(first)) {
94
+ return { executablePath: first, args: tokens.slice(1) };
95
+ }
96
+ if ((firstName === 'npx' || firstName === 'pnpm' || firstName === 'yarn' || firstName === 'bun') && commandName(second) === 'codex') {
97
+ return { args: rest };
98
+ }
99
+ if (firstName === 'codex') {
100
+ return { args: tokens.slice(1) };
101
+ }
102
+ return { executablePath: first, args: tokens.slice(1) };
103
+ }
104
+ function parseBoolean(value) {
105
+ if (/^(true|1|yes)$/i.test(value))
106
+ return true;
107
+ if (/^(false|0|no)$/i.test(value))
108
+ return false;
109
+ return undefined;
110
+ }
111
+ function stripQuotes(value) {
112
+ if ((value.startsWith('"') && value.endsWith('"')) || (value.startsWith("'") && value.endsWith("'"))) {
113
+ return value.slice(1, -1);
114
+ }
115
+ return value;
116
+ }
117
+ function setNestedConfig(target, dottedKey, rawValue) {
118
+ const parts = dottedKey.split('.').filter(Boolean);
119
+ if (parts.length === 0)
120
+ return;
121
+ let cursor = target;
122
+ for (const part of parts.slice(0, -1)) {
123
+ const existing = cursor[part];
124
+ if (!isRecord(existing)) {
125
+ cursor[part] = {};
126
+ }
127
+ cursor = cursor[part];
128
+ }
129
+ const value = stripQuotes(rawValue);
130
+ const boolValue = parseBoolean(value);
131
+ cursor[parts[parts.length - 1]] = boolValue ?? value;
132
+ }
133
+ function readOptionValue(args, index, option) {
134
+ const token = args[index];
135
+ const inlinePrefix = `${option}=`;
136
+ if (token.startsWith(inlinePrefix)) {
137
+ return { value: token.slice(inlinePrefix.length), nextIndex: index };
138
+ }
139
+ return { value: args[index + 1], nextIndex: index + 1 };
140
+ }
141
+ function parseCodexCommandOverrides(args) {
142
+ const overrides = { additionalDirectories: [], config: {} };
143
+ for (let i = 0; i < args.length; i++) {
144
+ const token = args[i];
145
+ switch (token) {
146
+ case '--model':
147
+ case '-m': {
148
+ const parsed = readOptionValue(args, i, token);
149
+ overrides.model = parsed.value;
150
+ i = parsed.nextIndex;
151
+ break;
152
+ }
153
+ case '--sandbox': {
154
+ const parsed = readOptionValue(args, i, token);
155
+ if (parsed.value === 'read-only' || parsed.value === 'workspace-write' || parsed.value === 'danger-full-access') {
156
+ overrides.sandboxMode = parsed.value;
157
+ }
158
+ i = parsed.nextIndex;
159
+ break;
160
+ }
161
+ case '--skip-git-repo-check':
162
+ overrides.skipGitRepoCheck = true;
163
+ break;
164
+ case '--add-dir': {
165
+ const parsed = readOptionValue(args, i, token);
166
+ if (parsed.value)
167
+ overrides.additionalDirectories.push(parsed.value);
168
+ i = parsed.nextIndex;
169
+ break;
170
+ }
171
+ case '--config':
172
+ case '-c': {
173
+ const parsed = readOptionValue(args, i, token);
174
+ if (parsed.value) {
175
+ const equalsIndex = parsed.value.indexOf('=');
176
+ if (equalsIndex > 0) {
177
+ const key = parsed.value.slice(0, equalsIndex);
178
+ const value = parsed.value.slice(equalsIndex + 1);
179
+ if (key === 'model_reasoning_effort') {
180
+ const effort = stripQuotes(value);
181
+ if (effort === 'minimal' || effort === 'low' || effort === 'medium' || effort === 'high' || effort === 'xhigh') {
182
+ overrides.modelReasoningEffort = effort;
183
+ }
184
+ }
185
+ else if (key === 'web_search') {
186
+ const mode = stripQuotes(value);
187
+ if (mode === 'disabled' || mode === 'cached' || mode === 'live') {
188
+ overrides.webSearchMode = mode;
189
+ }
190
+ }
191
+ else if (key === 'sandbox_workspace_write.network_access') {
192
+ overrides.networkAccessEnabled = parseBoolean(stripQuotes(value));
193
+ }
194
+ else if (key === 'approval_policy') {
195
+ const approval = stripQuotes(value);
196
+ if (approval === 'never' || approval === 'on-request' || approval === 'on-failure' || approval === 'untrusted') {
197
+ overrides.approvalPolicy = approval;
198
+ }
199
+ }
200
+ else {
201
+ setNestedConfig(overrides.config, key, value);
202
+ }
203
+ }
204
+ }
205
+ i = parsed.nextIndex;
206
+ break;
207
+ }
208
+ default: {
209
+ if (token.startsWith('--model=')) {
210
+ overrides.model = token.slice('--model='.length);
211
+ }
212
+ else if (token.startsWith('--sandbox=')) {
213
+ const sandbox = token.slice('--sandbox='.length);
214
+ if (sandbox === 'read-only' || sandbox === 'workspace-write' || sandbox === 'danger-full-access') {
215
+ overrides.sandboxMode = sandbox;
216
+ }
217
+ }
218
+ }
219
+ }
220
+ }
221
+ return overrides;
222
+ }
223
+ function mapUsage(usage) {
224
+ return {
225
+ inputTokens: usage?.input_tokens ?? 0,
226
+ outputTokens: usage?.output_tokens ?? 0,
227
+ };
228
+ }
229
+ export class CodexSdkAdapter extends EventEmitter {
230
+ constructor() {
231
+ super(...arguments);
232
+ this.providerId = 'codex';
233
+ this.displayName = 'Codex';
234
+ this.sessions = new Map();
235
+ }
236
+ async startSession(sessionId, config) {
237
+ console.log(`[CodexSdkAdapter] ★★★ 启动 Codex SDK 会话 ★★★ sessionId="${sessionId}", workingDirectory="${config.workingDirectory}"`);
238
+ const adapterSession = {
239
+ sessionId,
240
+ status: 'starting',
241
+ messages: [],
242
+ createdAt: new Date().toISOString(),
243
+ totalUsage: { inputTokens: 0, outputTokens: 0 },
244
+ };
245
+ try {
246
+ const codex = new Codex(this.buildCodexOptions(config));
247
+ this.warnUnsupportedMcpConfig(config);
248
+ const thread = codex.startThread(this.buildThreadOptions(config));
249
+ const entry = {
250
+ adapterSession,
251
+ config,
252
+ thread,
253
+ terminating: false,
254
+ currentAssistantText: '',
255
+ emittedToolStarts: new Set(),
256
+ emittedTextLengths: new Map(),
257
+ emittedReasoningLengths: new Map(),
258
+ lastActivityAt: Date.now(),
259
+ };
260
+ this.sessions.set(sessionId, entry);
261
+ if (config.initialPrompt) {
262
+ queueMicrotask(() => {
263
+ void this.sendMessage(sessionId, config.initialPrompt).catch((promptError) => {
264
+ const promptErrorMessage = promptError instanceof Error ? promptError.message : String(promptError);
265
+ const currentSession = this.sessions.get(sessionId);
266
+ if (currentSession) {
267
+ currentSession.adapterSession.status = 'error';
268
+ }
269
+ this.emit('status-change', sessionId, 'error');
270
+ this.emitEvent({
271
+ type: 'error',
272
+ sessionId,
273
+ timestamp: new Date().toISOString(),
274
+ data: { text: `Codex initial prompt failed: ${promptErrorMessage}` },
275
+ });
276
+ });
277
+ });
278
+ }
279
+ else {
280
+ adapterSession.status = 'waiting_input';
281
+ this.emit('status-change', sessionId, 'waiting_input');
282
+ }
283
+ }
284
+ catch (error) {
285
+ const message = error instanceof Error ? error.message : String(error);
286
+ adapterSession.status = 'error';
287
+ this.emit('status-change', sessionId, 'error');
288
+ this.emitEvent({
289
+ type: 'error',
290
+ sessionId,
291
+ timestamp: new Date().toISOString(),
292
+ data: { text: `Codex start failed: ${message}` },
293
+ });
294
+ throw error;
295
+ }
296
+ }
297
+ async sendMessage(sessionId, message) {
298
+ const session = this.sessions.get(sessionId);
299
+ if (!session) {
300
+ throw new Error(`Session ${sessionId} not found`);
301
+ }
302
+ if (session.runningTurn) {
303
+ throw new Error(`Session ${sessionId} already has a running Codex turn`);
304
+ }
305
+ const userMsg = {
306
+ id: uuidv4(),
307
+ sessionId,
308
+ role: 'user',
309
+ content: message,
310
+ timestamp: new Date().toISOString(),
311
+ };
312
+ session.adapterSession.messages.push(userMsg);
313
+ this.emit('conversation-message', sessionId, userMsg);
314
+ session.adapterSession.status = 'thinking';
315
+ this.emit('status-change', sessionId, 'thinking');
316
+ this.stopIdleDetection(sessionId);
317
+ session.lastActivityAt = Date.now();
318
+ const abortController = new AbortController();
319
+ session.currentAbortController = abortController;
320
+ session.runningTurn = this.runTurn(sessionId, session, message, abortController);
321
+ try {
322
+ await session.runningTurn;
323
+ }
324
+ finally {
325
+ session.runningTurn = undefined;
326
+ session.currentAbortController = undefined;
327
+ }
328
+ }
329
+ async sendConfirmation(_sessionId, _accept) {
330
+ // Codex SDK exposes approval behavior through thread options; there is no
331
+ // separate permission response API in the current SDK surface.
332
+ }
333
+ async sendQuestionAnswer(_sessionId, _answers) {
334
+ // Codex SDK does not expose an AskUserQuestion channel in the current event model.
335
+ }
336
+ setIdleCommands(sessionId, commands) {
337
+ const session = this.sessions.get(sessionId);
338
+ if (session) {
339
+ session.idleCommands = commands;
340
+ if (session.adapterSession.status === 'waiting_input' &&
341
+ (commands.idleInputCommand || commands.nonInputCommand)) {
342
+ this.startIdleDetection(sessionId);
343
+ }
344
+ }
345
+ }
346
+ async abortCurrentTurn(sessionId) {
347
+ const session = this.sessions.get(sessionId);
348
+ session?.currentAbortController?.abort();
349
+ }
350
+ async terminateSession(sessionId) {
351
+ const session = this.sessions.get(sessionId);
352
+ if (!session)
353
+ return;
354
+ this.stopIdleDetection(sessionId);
355
+ session.terminating = true;
356
+ session.currentAbortController?.abort();
357
+ session.adapterSession.status = 'terminated';
358
+ this.emit('status-change', sessionId, 'terminated');
359
+ this.emitEvent({
360
+ type: 'session_complete',
361
+ sessionId,
362
+ timestamp: new Date().toISOString(),
363
+ data: { exitCode: 0 },
364
+ });
365
+ this.sessions.delete(sessionId);
366
+ }
367
+ async resumeSession(sessionId, providerSessionId, config) {
368
+ const codex = new Codex(this.buildCodexOptions(config));
369
+ this.warnUnsupportedMcpConfig(config);
370
+ const thread = codex.resumeThread(providerSessionId, this.buildThreadOptions(config));
371
+ const adapterSession = {
372
+ sessionId,
373
+ providerSessionId,
374
+ status: 'waiting_input',
375
+ messages: [],
376
+ createdAt: new Date().toISOString(),
377
+ totalUsage: { inputTokens: 0, outputTokens: 0 },
378
+ };
379
+ this.sessions.set(sessionId, {
380
+ adapterSession,
381
+ config,
382
+ thread,
383
+ terminating: false,
384
+ currentAssistantText: '',
385
+ emittedToolStarts: new Set(),
386
+ emittedTextLengths: new Map(),
387
+ emittedReasoningLengths: new Map(),
388
+ lastActivityAt: Date.now(),
389
+ });
390
+ this.emit('status-change', sessionId, 'waiting_input');
391
+ }
392
+ getConversation(sessionId) {
393
+ return this.sessions.get(sessionId)?.adapterSession.messages ?? [];
394
+ }
395
+ hasSession(sessionId) {
396
+ return this.sessions.has(sessionId);
397
+ }
398
+ getProviderSessionId(sessionId) {
399
+ const threadId = this.sessions.get(sessionId)?.thread.id;
400
+ return threadId ?? undefined;
401
+ }
402
+ getSessionStatus(sessionId) {
403
+ return this.sessions.get(sessionId)?.adapterSession.status;
404
+ }
405
+ getSessionPid(_sessionId) {
406
+ return undefined;
407
+ }
408
+ cleanup() {
409
+ for (const [sessionId] of this.sessions) {
410
+ void this.terminateSession(sessionId);
411
+ }
412
+ this.sessions.clear();
413
+ }
414
+ buildCodexOptions(config) {
415
+ const env = toEnvRecord(process.env, config.envOverrides);
416
+ const options = { env };
417
+ const apiKey = env.CODEX_API_KEY || env.OPENAI_API_KEY;
418
+ if (apiKey) {
419
+ options.apiKey = apiKey;
420
+ }
421
+ const baseUrl = env.CODEX_BASE_URL || env.OPENAI_BASE_URL;
422
+ if (baseUrl) {
423
+ options.baseUrl = baseUrl;
424
+ }
425
+ const parsedCommand = parseCodexCommand(config.command);
426
+ if (config.executablePath) {
427
+ options.codexPathOverride = config.executablePath;
428
+ }
429
+ else if (parsedCommand.executablePath) {
430
+ options.codexPathOverride = parsedCommand.executablePath;
431
+ }
432
+ const commandOverrides = parseCodexCommandOverrides(parsedCommand.args);
433
+ if (Object.keys(commandOverrides.config).length > 0) {
434
+ options.config = commandOverrides.config;
435
+ }
436
+ return options;
437
+ }
438
+ warnUnsupportedMcpConfig(config) {
439
+ const hasExtraMcpServers = Boolean(config.extraMcpServers && Object.keys(config.extraMcpServers).length > 0);
440
+ if (config.mcpConfigPath || hasExtraMcpServers) {
441
+ console.warn('[CodexSdkAdapter] Codex SDK ThreadOptions do not expose dynamic MCP server injection; ' +
442
+ 'mcpConfigPath/extraMcpServers are ignored for Codex SDK sessions.');
443
+ }
444
+ }
445
+ buildThreadOptions(config) {
446
+ const parsedCommand = parseCodexCommand(config.command);
447
+ const commandOverrides = parseCodexCommandOverrides(parsedCommand.args);
448
+ const options = {
449
+ workingDirectory: config.workingDirectory,
450
+ skipGitRepoCheck: commandOverrides.skipGitRepoCheck ?? false,
451
+ approvalPolicy: commandOverrides.approvalPolicy ?? (config.autoAccept ? 'never' : 'on-request'),
452
+ };
453
+ if (config.model || commandOverrides.model) {
454
+ options.model = config.model ?? commandOverrides.model;
455
+ }
456
+ if (config.additionalDirectories || commandOverrides.additionalDirectories.length > 0) {
457
+ options.additionalDirectories = [
458
+ ...(config.additionalDirectories ?? []),
459
+ ...commandOverrides.additionalDirectories,
460
+ ];
461
+ }
462
+ if (commandOverrides.sandboxMode) {
463
+ options.sandboxMode = commandOverrides.sandboxMode;
464
+ }
465
+ if (commandOverrides.modelReasoningEffort) {
466
+ options.modelReasoningEffort = commandOverrides.modelReasoningEffort;
467
+ }
468
+ if (commandOverrides.networkAccessEnabled !== undefined) {
469
+ options.networkAccessEnabled = commandOverrides.networkAccessEnabled;
470
+ }
471
+ if (commandOverrides.webSearchMode) {
472
+ options.webSearchMode = commandOverrides.webSearchMode;
473
+ }
474
+ if (commandOverrides.webSearchEnabled !== undefined) {
475
+ options.webSearchEnabled = commandOverrides.webSearchEnabled;
476
+ }
477
+ return options;
478
+ }
479
+ async runTurn(sessionId, session, message, abortController) {
480
+ try {
481
+ const streamed = await session.thread.runStreamed(message, { signal: abortController.signal });
482
+ for await (const event of streamed.events) {
483
+ this.handleThreadEvent(sessionId, session, event);
484
+ }
485
+ }
486
+ catch (error) {
487
+ if (abortController.signal.aborted) {
488
+ if (!this.sessions.has(sessionId) || session.terminating || session.adapterSession.status === 'terminated') {
489
+ return;
490
+ }
491
+ session.adapterSession.status = 'waiting_input';
492
+ this.emit('status-change', sessionId, 'waiting_input');
493
+ return;
494
+ }
495
+ const text = error instanceof Error ? error.message : String(error);
496
+ session.adapterSession.status = 'error';
497
+ this.emit('status-change', sessionId, 'error');
498
+ this.emitEvent({
499
+ type: 'error',
500
+ sessionId,
501
+ timestamp: new Date().toISOString(),
502
+ data: { text },
503
+ });
504
+ }
505
+ }
506
+ handleThreadEvent(sessionId, session, event) {
507
+ const timestamp = new Date().toISOString();
508
+ switch (event.type) {
509
+ case 'thread.started':
510
+ session.adapterSession.providerSessionId = event.thread_id;
511
+ break;
512
+ case 'turn.started':
513
+ session.adapterSession.status = 'thinking';
514
+ this.emit('status-change', sessionId, 'thinking');
515
+ break;
516
+ case 'item.started':
517
+ case 'item.updated':
518
+ case 'item.completed':
519
+ this.handleThreadItem(sessionId, session, event.item, event.type, timestamp);
520
+ break;
521
+ case 'turn.completed':
522
+ this.completeTurn(sessionId, session, event.usage, timestamp);
523
+ break;
524
+ case 'turn.failed':
525
+ session.adapterSession.status = 'error';
526
+ this.emit('status-change', sessionId, 'error');
527
+ this.emitEvent({ type: 'error', sessionId, timestamp, data: { text: event.error.message } });
528
+ break;
529
+ case 'error':
530
+ session.adapterSession.status = 'error';
531
+ this.emit('status-change', sessionId, 'error');
532
+ this.emitEvent({ type: 'error', sessionId, timestamp, data: { text: event.message } });
533
+ break;
534
+ }
535
+ }
536
+ handleThreadItem(sessionId, session, item, eventType, timestamp) {
537
+ switch (item.type) {
538
+ case 'agent_message':
539
+ this.emitTextDelta(sessionId, session, item.id, item.text, timestamp);
540
+ break;
541
+ case 'reasoning':
542
+ this.emitReasoningDelta(sessionId, session, item.id, item.text, timestamp);
543
+ break;
544
+ case 'command_execution':
545
+ this.handleToolLikeItem(sessionId, session, {
546
+ id: item.id,
547
+ toolName: 'bash',
548
+ toolInput: { command: item.command },
549
+ result: item.aggregated_output,
550
+ isError: item.status === 'failed',
551
+ isRunning: item.status === 'in_progress',
552
+ eventType,
553
+ timestamp,
554
+ });
555
+ break;
556
+ case 'mcp_tool_call': {
557
+ const metadata = { mcpServer: item.server };
558
+ this.handleToolLikeItem(sessionId, session, {
559
+ id: item.id,
560
+ toolName: item.tool,
561
+ toolInput: toRecord(item.arguments),
562
+ result: item.error?.message ?? serializeValue(item.result),
563
+ isError: item.status === 'failed',
564
+ isRunning: item.status === 'in_progress',
565
+ eventType,
566
+ timestamp,
567
+ metadata,
568
+ });
569
+ break;
570
+ }
571
+ case 'file_change':
572
+ this.handleToolLikeItem(sessionId, session, {
573
+ id: item.id,
574
+ toolName: 'apply_patch',
575
+ toolInput: { changes: item.changes },
576
+ result: item.status,
577
+ isError: item.status === 'failed',
578
+ isRunning: eventType !== 'item.completed',
579
+ eventType,
580
+ timestamp,
581
+ });
582
+ break;
583
+ case 'web_search':
584
+ this.handleToolLikeItem(sessionId, session, {
585
+ id: item.id,
586
+ toolName: 'web_search',
587
+ toolInput: { query: item.query },
588
+ result: item.query,
589
+ isError: false,
590
+ isRunning: eventType !== 'item.completed',
591
+ eventType,
592
+ timestamp,
593
+ });
594
+ break;
595
+ case 'todo_list':
596
+ this.emitEvent({
597
+ type: 'thinking',
598
+ sessionId,
599
+ timestamp,
600
+ data: { text: item.items.map((todo) => `${todo.completed ? '✓' : '•'} ${todo.text}`).join('\n') },
601
+ });
602
+ break;
603
+ case 'error':
604
+ this.emitEvent({ type: 'error', sessionId, timestamp, data: { text: item.message } });
605
+ break;
606
+ }
607
+ }
608
+ emitTextDelta(sessionId, session, itemId, text, timestamp) {
609
+ const emittedLength = session.emittedTextLengths.get(itemId) ?? 0;
610
+ const delta = text.slice(emittedLength);
611
+ session.emittedTextLengths.set(itemId, text.length);
612
+ if (!delta)
613
+ return;
614
+ session.currentAssistantText += delta;
615
+ this.emitEvent({ type: 'text_delta', sessionId, timestamp, data: { text: delta } });
616
+ }
617
+ emitReasoningDelta(sessionId, session, itemId, text, timestamp) {
618
+ const emittedLength = session.emittedReasoningLengths.get(itemId) ?? 0;
619
+ const delta = text.slice(emittedLength);
620
+ session.emittedReasoningLengths.set(itemId, text.length);
621
+ if (!delta)
622
+ return;
623
+ this.emitEvent({ type: 'thinking', sessionId, timestamp, data: { text: delta } });
624
+ }
625
+ handleToolLikeItem(sessionId, session, item) {
626
+ if (!session.emittedToolStarts.has(item.id)) {
627
+ session.emittedToolStarts.add(item.id);
628
+ const actionInfo = getToolActionInfo(item.toolName, item.toolInput, item.metadata);
629
+ this.emitEvent({
630
+ type: 'tool_use_start',
631
+ sessionId,
632
+ timestamp: item.timestamp,
633
+ data: { toolName: item.toolName, toolInput: item.toolInput, toolUseId: item.id, ...actionInfo },
634
+ });
635
+ this.emit('status-change', sessionId, 'tool_using', actionInfo);
636
+ session.adapterSession.messages.push({
637
+ id: uuidv4(),
638
+ sessionId,
639
+ role: 'tool_use',
640
+ content: `${item.toolName}: ${JSON.stringify(item.toolInput).slice(0, 100)}`,
641
+ timestamp: item.timestamp,
642
+ toolName: item.toolName,
643
+ toolInput: item.toolInput,
644
+ toolUseId: item.id,
645
+ });
646
+ }
647
+ if (item.isRunning || item.eventType !== 'item.completed') {
648
+ return;
649
+ }
650
+ this.emitEvent({
651
+ type: 'tool_use_end',
652
+ sessionId,
653
+ timestamp: item.timestamp,
654
+ data: {
655
+ toolName: item.toolName,
656
+ toolResult: item.result,
657
+ isError: item.isError,
658
+ toolUseId: item.id,
659
+ },
660
+ });
661
+ session.emittedToolStarts.delete(item.id);
662
+ }
663
+ completeTurn(sessionId, session, usage, timestamp) {
664
+ const mappedUsage = mapUsage(usage);
665
+ session.adapterSession.totalUsage = mappedUsage;
666
+ if (session.currentAssistantText) {
667
+ session.adapterSession.messages.push({
668
+ id: uuidv4(),
669
+ sessionId,
670
+ role: 'assistant',
671
+ content: session.currentAssistantText,
672
+ timestamp,
673
+ });
674
+ session.currentAssistantText = '';
675
+ }
676
+ this.emitEvent({ type: 'turn_complete', sessionId, timestamp, data: { usage: mappedUsage } });
677
+ session.adapterSession.status = 'waiting_input';
678
+ this.emit('status-change', sessionId, 'waiting_input');
679
+ session.lastActivityAt = Date.now();
680
+ this.startIdleDetection(sessionId);
681
+ }
682
+ emitEvent(event) {
683
+ this.emit('event', event);
684
+ }
685
+ startIdleDetection(sessionId) {
686
+ this.stopIdleDetection(sessionId);
687
+ const session = this.sessions.get(sessionId);
688
+ if (!session?.idleCommands?.idleInputCommand)
689
+ return;
690
+ if (this.isMessagePollingIdleCommand(session.idleCommands.idleInputCommand))
691
+ return;
692
+ session.lastActivityAt = Date.now();
693
+ const timer = setInterval(() => {
694
+ this.checkIdleState(sessionId);
695
+ }, 500);
696
+ session.idleTimer = timer;
697
+ }
698
+ stopIdleDetection(sessionId) {
699
+ const session = this.sessions.get(sessionId);
700
+ if (session?.idleTimer) {
701
+ clearInterval(session.idleTimer);
702
+ session.idleTimer = undefined;
703
+ }
704
+ }
705
+ checkIdleState(sessionId) {
706
+ const session = this.sessions.get(sessionId);
707
+ if (!session || session.adapterSession.status !== 'waiting_input')
708
+ return;
709
+ if (!session.idleCommands?.idleInputCommand)
710
+ return;
711
+ const lastActivityAt = session.lastActivityAt ?? 0;
712
+ const idleTime = Date.now() - lastActivityAt;
713
+ if (idleTime < CODEX_IDLE_THRESHOLD_MS)
714
+ return;
715
+ session.lastActivityAt = Date.now();
716
+ void this.sendIdlePrompt(sessionId, session.idleCommands.idleInputCommand);
717
+ this.stopIdleDetection(sessionId);
718
+ }
719
+ async sendIdlePrompt(sessionId, command) {
720
+ const session = this.sessions.get(sessionId);
721
+ if (!session)
722
+ return;
723
+ if (session.runningTurn)
724
+ return;
725
+ const prompt = this.toIdlePrompt(command);
726
+ if (!prompt)
727
+ return;
728
+ session.adapterSession.status = 'thinking';
729
+ this.emit('status-change', sessionId, 'thinking');
730
+ const abortController = new AbortController();
731
+ session.currentAbortController = abortController;
732
+ session.runningTurn = this.runTurn(sessionId, session, prompt, abortController);
733
+ try {
734
+ await session.runningTurn;
735
+ }
736
+ finally {
737
+ session.runningTurn = undefined;
738
+ session.currentAbortController = undefined;
739
+ }
740
+ }
741
+ toIdlePrompt(command) {
742
+ return command.trim();
743
+ }
744
+ isMessagePollingIdleCommand(command) {
745
+ const normalized = command.trim();
746
+ if (!normalized)
747
+ return false;
748
+ return normalized.toLowerCase().includes('poll_message') || normalized.includes('取消息');
749
+ }
750
+ }