@jingyi0605/codingns 0.1.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 (405) hide show
  1. package/README.md +24 -0
  2. package/bin/codingns.mjs +173 -0
  3. package/dist/public/assets/TerminalPage-6GBZ9nXN.css +32 -0
  4. package/dist/public/assets/TerminalPage-Dj_VDew3.js +54 -0
  5. package/dist/public/assets/index-C1GZV2wq.js +106 -0
  6. package/dist/public/assets/index-DU7f8NaZ.css +1 -0
  7. package/dist/public/index.html +13 -0
  8. package/dist/public/logo.png +0 -0
  9. package/dist/public/logo.svg +162 -0
  10. package/dist/server/config/env.d.ts +24 -0
  11. package/dist/server/config/env.js +152 -0
  12. package/dist/server/config/env.js.map +1 -0
  13. package/dist/server/config/opencode-base-url-resolver.d.ts +37 -0
  14. package/dist/server/config/opencode-base-url-resolver.js +422 -0
  15. package/dist/server/config/opencode-base-url-resolver.js.map +1 -0
  16. package/dist/server/main.d.ts +1 -0
  17. package/dist/server/main.js +3 -0
  18. package/dist/server/main.js.map +1 -0
  19. package/dist/server/middlewares/auth-guard.d.ts +4 -0
  20. package/dist/server/middlewares/auth-guard.js +35 -0
  21. package/dist/server/middlewares/auth-guard.js.map +1 -0
  22. package/dist/server/modules/auth/auth-controller.d.ts +15 -0
  23. package/dist/server/modules/auth/auth-controller.js +20 -0
  24. package/dist/server/modules/auth/auth-controller.js.map +1 -0
  25. package/dist/server/modules/auth/auth-service.d.ts +44 -0
  26. package/dist/server/modules/auth/auth-service.js +151 -0
  27. package/dist/server/modules/auth/auth-service.js.map +1 -0
  28. package/dist/server/modules/bootstrap/bootstrap-controller.d.ts +10 -0
  29. package/dist/server/modules/bootstrap/bootstrap-controller.js +13 -0
  30. package/dist/server/modules/bootstrap/bootstrap-controller.js.map +1 -0
  31. package/dist/server/modules/bootstrap/bootstrap-service.d.ts +20 -0
  32. package/dist/server/modules/bootstrap/bootstrap-service.js +71 -0
  33. package/dist/server/modules/bootstrap/bootstrap-service.js.map +1 -0
  34. package/dist/server/modules/client/client-controller.d.ts +9 -0
  35. package/dist/server/modules/client/client-controller.js +65 -0
  36. package/dist/server/modules/client/client-controller.js.map +1 -0
  37. package/dist/server/modules/client/client-service.d.ts +37 -0
  38. package/dist/server/modules/client/client-service.js +186 -0
  39. package/dist/server/modules/client/client-service.js.map +1 -0
  40. package/dist/server/modules/file/file-access-guard.d.ts +27 -0
  41. package/dist/server/modules/file/file-access-guard.js +99 -0
  42. package/dist/server/modules/file/file-access-guard.js.map +1 -0
  43. package/dist/server/modules/file/file-constants.d.ts +6 -0
  44. package/dist/server/modules/file/file-constants.js +7 -0
  45. package/dist/server/modules/file/file-constants.js.map +1 -0
  46. package/dist/server/modules/file/file-content-service.d.ts +65 -0
  47. package/dist/server/modules/file/file-content-service.js +239 -0
  48. package/dist/server/modules/file/file-content-service.js.map +1 -0
  49. package/dist/server/modules/file/file-context-controller.d.ts +29 -0
  50. package/dist/server/modules/file/file-context-controller.js +52 -0
  51. package/dist/server/modules/file/file-context-controller.js.map +1 -0
  52. package/dist/server/modules/file/file-context-service.d.ts +22 -0
  53. package/dist/server/modules/file/file-context-service.js +90 -0
  54. package/dist/server/modules/file/file-context-service.js.map +1 -0
  55. package/dist/server/modules/file/file-controller.d.ts +68 -0
  56. package/dist/server/modules/file/file-controller.js +111 -0
  57. package/dist/server/modules/file/file-controller.js.map +1 -0
  58. package/dist/server/modules/file/file-preview-service.d.ts +19 -0
  59. package/dist/server/modules/file/file-preview-service.js +60 -0
  60. package/dist/server/modules/file/file-preview-service.js.map +1 -0
  61. package/dist/server/modules/file/file-search-service.d.ts +13 -0
  62. package/dist/server/modules/file/file-search-service.js +62 -0
  63. package/dist/server/modules/file/file-search-service.js.map +1 -0
  64. package/dist/server/modules/file/file-tree-service.d.ts +7 -0
  65. package/dist/server/modules/file/file-tree-service.js +43 -0
  66. package/dist/server/modules/file/file-tree-service.js.map +1 -0
  67. package/dist/server/modules/file/file-version-checker.d.ts +10 -0
  68. package/dist/server/modules/file/file-version-checker.js +30 -0
  69. package/dist/server/modules/file/file-version-checker.js.map +1 -0
  70. package/dist/server/modules/file/path-normalizer.d.ts +2 -0
  71. package/dist/server/modules/file/path-normalizer.js +80 -0
  72. package/dist/server/modules/file/path-normalizer.js.map +1 -0
  73. package/dist/server/modules/file/recent-file-service.d.ts +10 -0
  74. package/dist/server/modules/file/recent-file-service.js +28 -0
  75. package/dist/server/modules/file/recent-file-service.js.map +1 -0
  76. package/dist/server/modules/git/commit-draft-service.d.ts +7 -0
  77. package/dist/server/modules/git/commit-draft-service.js +76 -0
  78. package/dist/server/modules/git/commit-draft-service.js.map +1 -0
  79. package/dist/server/modules/git/commit-orchestrator.d.ts +28 -0
  80. package/dist/server/modules/git/commit-orchestrator.js +47 -0
  81. package/dist/server/modules/git/commit-orchestrator.js.map +1 -0
  82. package/dist/server/modules/git/commit-rule-engine.d.ts +5 -0
  83. package/dist/server/modules/git/commit-rule-engine.js +22 -0
  84. package/dist/server/modules/git/commit-rule-engine.js.map +1 -0
  85. package/dist/server/modules/git/git-command-runner.d.ts +16 -0
  86. package/dist/server/modules/git/git-command-runner.js +102 -0
  87. package/dist/server/modules/git/git-command-runner.js.map +1 -0
  88. package/dist/server/modules/git/git-controller.d.ts +104 -0
  89. package/dist/server/modules/git/git-controller.js +140 -0
  90. package/dist/server/modules/git/git-controller.js.map +1 -0
  91. package/dist/server/modules/git/git-read-service.d.ts +15 -0
  92. package/dist/server/modules/git/git-read-service.js +393 -0
  93. package/dist/server/modules/git/git-read-service.js.map +1 -0
  94. package/dist/server/modules/git/git-rule-repository.d.ts +9 -0
  95. package/dist/server/modules/git/git-rule-repository.js +43 -0
  96. package/dist/server/modules/git/git-rule-repository.js.map +1 -0
  97. package/dist/server/modules/git/git-write-service.d.ts +28 -0
  98. package/dist/server/modules/git/git-write-service.js +330 -0
  99. package/dist/server/modules/git/git-write-service.js.map +1 -0
  100. package/dist/server/modules/git/types.d.ts +99 -0
  101. package/dist/server/modules/git/types.js +2 -0
  102. package/dist/server/modules/git/types.js.map +1 -0
  103. package/dist/server/modules/git/workspace-repo-guard.d.ts +17 -0
  104. package/dist/server/modules/git/workspace-repo-guard.js +124 -0
  105. package/dist/server/modules/git/workspace-repo-guard.js.map +1 -0
  106. package/dist/server/modules/preferences/quick-phrase-controller.d.ts +17 -0
  107. package/dist/server/modules/preferences/quick-phrase-controller.js +37 -0
  108. package/dist/server/modules/preferences/quick-phrase-controller.js.map +1 -0
  109. package/dist/server/modules/preferences/quick-phrase-service.d.ts +13 -0
  110. package/dist/server/modules/preferences/quick-phrase-service.js +67 -0
  111. package/dist/server/modules/preferences/quick-phrase-service.js.map +1 -0
  112. package/dist/server/modules/provider/claude-model-options.d.ts +5 -0
  113. package/dist/server/modules/provider/claude-model-options.js +116 -0
  114. package/dist/server/modules/provider/claude-model-options.js.map +1 -0
  115. package/dist/server/modules/provider/codex-model-options.d.ts +23 -0
  116. package/dist/server/modules/provider/codex-model-options.js +308 -0
  117. package/dist/server/modules/provider/codex-model-options.js.map +1 -0
  118. package/dist/server/modules/provider/opencode-model-options.d.ts +30 -0
  119. package/dist/server/modules/provider/opencode-model-options.js +362 -0
  120. package/dist/server/modules/provider/opencode-model-options.js.map +1 -0
  121. package/dist/server/modules/provider/provider-controller.d.ts +33 -0
  122. package/dist/server/modules/provider/provider-controller.js +50 -0
  123. package/dist/server/modules/provider/provider-controller.js.map +1 -0
  124. package/dist/server/modules/sessions/session-activity-inspector.d.ts +10 -0
  125. package/dist/server/modules/sessions/session-activity-inspector.js +271 -0
  126. package/dist/server/modules/sessions/session-activity-inspector.js.map +1 -0
  127. package/dist/server/modules/sessions/session-changed-file-service.d.ts +14 -0
  128. package/dist/server/modules/sessions/session-changed-file-service.js +175 -0
  129. package/dist/server/modules/sessions/session-changed-file-service.js.map +1 -0
  130. package/dist/server/modules/sessions/session-controller.d.ts +134 -0
  131. package/dist/server/modules/sessions/session-controller.js +253 -0
  132. package/dist/server/modules/sessions/session-controller.js.map +1 -0
  133. package/dist/server/modules/sessions/session-history-service.d.ts +128 -0
  134. package/dist/server/modules/sessions/session-history-service.js +1558 -0
  135. package/dist/server/modules/sessions/session-history-service.js.map +1 -0
  136. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +191 -0
  137. package/dist/server/modules/sessions/session-live-runtime-service.js +1303 -0
  138. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -0
  139. package/dist/server/modules/sessions/session-message-attachment-service.d.ts +42 -0
  140. package/dist/server/modules/sessions/session-message-attachment-service.js +244 -0
  141. package/dist/server/modules/sessions/session-message-attachment-service.js.map +1 -0
  142. package/dist/server/modules/sessions/session-provider-error-mapper.d.ts +2 -0
  143. package/dist/server/modules/sessions/session-provider-error-mapper.js +101 -0
  144. package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -0
  145. package/dist/server/modules/terminal/command-template-service.d.ts +48 -0
  146. package/dist/server/modules/terminal/command-template-service.js +273 -0
  147. package/dist/server/modules/terminal/command-template-service.js.map +1 -0
  148. package/dist/server/modules/terminal/runtime/adapters/embedded-pty-runtime-adapter.d.ts +22 -0
  149. package/dist/server/modules/terminal/runtime/adapters/embedded-pty-runtime-adapter.js +30 -0
  150. package/dist/server/modules/terminal/runtime/adapters/embedded-pty-runtime-adapter.js.map +1 -0
  151. package/dist/server/modules/terminal/runtime/adapters/tmux-runtime-adapter.d.ts +31 -0
  152. package/dist/server/modules/terminal/runtime/adapters/tmux-runtime-adapter.js +199 -0
  153. package/dist/server/modules/terminal/runtime/adapters/tmux-runtime-adapter.js.map +1 -0
  154. package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.d.ts +36 -0
  155. package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.js +141 -0
  156. package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.js.map +1 -0
  157. package/dist/server/modules/terminal/runtime/pty-runtime-manager.d.ts +29 -0
  158. package/dist/server/modules/terminal/runtime/pty-runtime-manager.js +138 -0
  159. package/dist/server/modules/terminal/runtime/pty-runtime-manager.js.map +1 -0
  160. package/dist/server/modules/terminal/runtime/terminal-log-file-store.d.ts +14 -0
  161. package/dist/server/modules/terminal/runtime/terminal-log-file-store.js +47 -0
  162. package/dist/server/modules/terminal/runtime/terminal-log-file-store.js.map +1 -0
  163. package/dist/server/modules/terminal/runtime/terminal-log-spooler.d.ts +28 -0
  164. package/dist/server/modules/terminal/runtime/terminal-log-spooler.js +162 -0
  165. package/dist/server/modules/terminal/runtime/terminal-log-spooler.js.map +1 -0
  166. package/dist/server/modules/terminal/runtime/terminal-output-buffer.d.ts +18 -0
  167. package/dist/server/modules/terminal/runtime/terminal-output-buffer.js +109 -0
  168. package/dist/server/modules/terminal/runtime/terminal-output-buffer.js.map +1 -0
  169. package/dist/server/modules/terminal/runtime/terminal-runtime-adapter.d.ts +34 -0
  170. package/dist/server/modules/terminal/runtime/terminal-runtime-adapter.js +2 -0
  171. package/dist/server/modules/terminal/runtime/terminal-runtime-adapter.js.map +1 -0
  172. package/dist/server/modules/terminal/runtime/terminal-runtime-manager.d.ts +41 -0
  173. package/dist/server/modules/terminal/runtime/terminal-runtime-manager.js +138 -0
  174. package/dist/server/modules/terminal/runtime/terminal-runtime-manager.js.map +1 -0
  175. package/dist/server/modules/terminal/template-port-runtime.d.ts +6 -0
  176. package/dist/server/modules/terminal/template-port-runtime.js +199 -0
  177. package/dist/server/modules/terminal/template-port-runtime.js.map +1 -0
  178. package/dist/server/modules/terminal/terminal-controller.d.ts +94 -0
  179. package/dist/server/modules/terminal/terminal-controller.js +236 -0
  180. package/dist/server/modules/terminal/terminal-controller.js.map +1 -0
  181. package/dist/server/modules/terminal/terminal-history.d.ts +18 -0
  182. package/dist/server/modules/terminal/terminal-history.js +2 -0
  183. package/dist/server/modules/terminal/terminal-history.js.map +1 -0
  184. package/dist/server/modules/terminal/terminal-paths.d.ts +1 -0
  185. package/dist/server/modules/terminal/terminal-paths.js +27 -0
  186. package/dist/server/modules/terminal/terminal-paths.js.map +1 -0
  187. package/dist/server/modules/terminal/terminal-service.d.ts +112 -0
  188. package/dist/server/modules/terminal/terminal-service.js +794 -0
  189. package/dist/server/modules/terminal/terminal-service.js.map +1 -0
  190. package/dist/server/modules/terminal/terminal-shell.d.ts +13 -0
  191. package/dist/server/modules/terminal/terminal-shell.js +293 -0
  192. package/dist/server/modules/terminal/terminal-shell.js.map +1 -0
  193. package/dist/server/modules/workbench/workbench-controller.d.ts +7 -0
  194. package/dist/server/modules/workbench/workbench-controller.js +22 -0
  195. package/dist/server/modules/workbench/workbench-controller.js.map +1 -0
  196. package/dist/server/modules/workbench/workbench-service.d.ts +19 -0
  197. package/dist/server/modules/workbench/workbench-service.js +46 -0
  198. package/dist/server/modules/workbench/workbench-service.js.map +1 -0
  199. package/dist/server/modules/workbench/workspace-panel-snapshot-service.d.ts +65 -0
  200. package/dist/server/modules/workbench/workspace-panel-snapshot-service.js +176 -0
  201. package/dist/server/modules/workbench/workspace-panel-snapshot-service.js.map +1 -0
  202. package/dist/server/modules/workspace/workspace-controller.d.ts +57 -0
  203. package/dist/server/modules/workspace/workspace-controller.js +38 -0
  204. package/dist/server/modules/workspace/workspace-controller.js.map +1 -0
  205. package/dist/server/modules/workspace/workspace-service.d.ts +81 -0
  206. package/dist/server/modules/workspace/workspace-service.js +659 -0
  207. package/dist/server/modules/workspace/workspace-service.js.map +1 -0
  208. package/dist/server/routes/auth.d.ts +3 -0
  209. package/dist/server/routes/auth.js +6 -0
  210. package/dist/server/routes/auth.js.map +1 -0
  211. package/dist/server/routes/client.d.ts +3 -0
  212. package/dist/server/routes/client.js +6 -0
  213. package/dist/server/routes/client.js.map +1 -0
  214. package/dist/server/routes/files.d.ts +3 -0
  215. package/dist/server/routes/files.js +15 -0
  216. package/dist/server/routes/files.js.map +1 -0
  217. package/dist/server/routes/git.d.ts +3 -0
  218. package/dist/server/routes/git.js +18 -0
  219. package/dist/server/routes/git.js.map +1 -0
  220. package/dist/server/routes/preferences.d.ts +3 -0
  221. package/dist/server/routes/preferences.js +5 -0
  222. package/dist/server/routes/preferences.js.map +1 -0
  223. package/dist/server/routes/providers.d.ts +3 -0
  224. package/dist/server/routes/providers.js +6 -0
  225. package/dist/server/routes/providers.js.map +1 -0
  226. package/dist/server/routes/public.d.ts +3 -0
  227. package/dist/server/routes/public.js +5 -0
  228. package/dist/server/routes/public.js.map +1 -0
  229. package/dist/server/routes/session-contexts.d.ts +3 -0
  230. package/dist/server/routes/session-contexts.js +6 -0
  231. package/dist/server/routes/session-contexts.js.map +1 -0
  232. package/dist/server/routes/sessions.d.ts +3 -0
  233. package/dist/server/routes/sessions.js +24 -0
  234. package/dist/server/routes/sessions.js.map +1 -0
  235. package/dist/server/routes/terminals.d.ts +3 -0
  236. package/dist/server/routes/terminals.js +17 -0
  237. package/dist/server/routes/terminals.js.map +1 -0
  238. package/dist/server/routes/workbench.d.ts +3 -0
  239. package/dist/server/routes/workbench.js +4 -0
  240. package/dist/server/routes/workbench.js.map +1 -0
  241. package/dist/server/routes/workspaces.d.ts +3 -0
  242. package/dist/server/routes/workspaces.js +10 -0
  243. package/dist/server/routes/workspaces.js.map +1 -0
  244. package/dist/server/server/create-server.d.ts +103 -0
  245. package/dist/server/server/create-server.js +259 -0
  246. package/dist/server/server/create-server.js.map +1 -0
  247. package/dist/server/server/start-host.d.ts +8 -0
  248. package/dist/server/server/start-host.js +40 -0
  249. package/dist/server/server/start-host.js.map +1 -0
  250. package/dist/server/server/static-web.d.ts +2 -0
  251. package/dist/server/server/static-web.js +75 -0
  252. package/dist/server/server/static-web.js.map +1 -0
  253. package/dist/server/shared/errors/app-error.d.ts +13 -0
  254. package/dist/server/shared/errors/app-error.js +16 -0
  255. package/dist/server/shared/errors/app-error.js.map +1 -0
  256. package/dist/server/shared/http/error-handler.d.ts +9 -0
  257. package/dist/server/shared/http/error-handler.js +25 -0
  258. package/dist/server/shared/http/error-handler.js.map +1 -0
  259. package/dist/server/shared/utils/hash.d.ts +4 -0
  260. package/dist/server/shared/utils/hash.js +27 -0
  261. package/dist/server/shared/utils/hash.js.map +1 -0
  262. package/dist/server/shared/utils/id.d.ts +1 -0
  263. package/dist/server/shared/utils/id.js +5 -0
  264. package/dist/server/shared/utils/id.js.map +1 -0
  265. package/dist/server/shared/utils/perf-log.d.ts +6 -0
  266. package/dist/server/shared/utils/perf-log.js +40 -0
  267. package/dist/server/shared/utils/perf-log.js.map +1 -0
  268. package/dist/server/shared/utils/time.d.ts +2 -0
  269. package/dist/server/shared/utils/time.js +7 -0
  270. package/dist/server/shared/utils/time.js.map +1 -0
  271. package/dist/server/shared/utils/tokens.d.ts +1 -0
  272. package/dist/server/shared/utils/tokens.js +5 -0
  273. package/dist/server/shared/utils/tokens.js.map +1 -0
  274. package/dist/server/storage/repositories/auth-token-repository.d.ts +9 -0
  275. package/dist/server/storage/repositories/auth-token-repository.js +45 -0
  276. package/dist/server/storage/repositories/auth-token-repository.js.map +1 -0
  277. package/dist/server/storage/repositories/auth-user-repository.d.ts +11 -0
  278. package/dist/server/storage/repositories/auth-user-repository.js +61 -0
  279. package/dist/server/storage/repositories/auth-user-repository.js.map +1 -0
  280. package/dist/server/storage/repositories/bootstrap-state-repository.d.ts +8 -0
  281. package/dist/server/storage/repositories/bootstrap-state-repository.js +29 -0
  282. package/dist/server/storage/repositories/bootstrap-state-repository.js.map +1 -0
  283. package/dist/server/storage/repositories/commit-rule-profile-repository.d.ts +8 -0
  284. package/dist/server/storage/repositories/commit-rule-profile-repository.js +48 -0
  285. package/dist/server/storage/repositories/commit-rule-profile-repository.js.map +1 -0
  286. package/dist/server/storage/repositories/file-context-binding-repository.d.ts +12 -0
  287. package/dist/server/storage/repositories/file-context-binding-repository.js +130 -0
  288. package/dist/server/storage/repositories/file-context-binding-repository.js.map +1 -0
  289. package/dist/server/storage/repositories/recent-file-repository.d.ts +10 -0
  290. package/dist/server/storage/repositories/recent-file-repository.js +64 -0
  291. package/dist/server/storage/repositories/recent-file-repository.js.map +1 -0
  292. package/dist/server/storage/repositories/session-binding-repository.d.ts +10 -0
  293. package/dist/server/storage/repositories/session-binding-repository.js +63 -0
  294. package/dist/server/storage/repositories/session-binding-repository.js.map +1 -0
  295. package/dist/server/storage/repositories/session-changed-file-repository.d.ts +11 -0
  296. package/dist/server/storage/repositories/session-changed-file-repository.js +94 -0
  297. package/dist/server/storage/repositories/session-changed-file-repository.js.map +1 -0
  298. package/dist/server/storage/repositories/session-index-repository.d.ts +11 -0
  299. package/dist/server/storage/repositories/session-index-repository.js +200 -0
  300. package/dist/server/storage/repositories/session-index-repository.js.map +1 -0
  301. package/dist/server/storage/repositories/session-message-attachment-repository.d.ts +13 -0
  302. package/dist/server/storage/repositories/session-message-attachment-repository.js +139 -0
  303. package/dist/server/storage/repositories/session-message-attachment-repository.js.map +1 -0
  304. package/dist/server/storage/repositories/session-send-queue-repository.d.ts +15 -0
  305. package/dist/server/storage/repositories/session-send-queue-repository.js +165 -0
  306. package/dist/server/storage/repositories/session-send-queue-repository.js.map +1 -0
  307. package/dist/server/storage/repositories/session-state-repository.d.ts +8 -0
  308. package/dist/server/storage/repositories/session-state-repository.js +60 -0
  309. package/dist/server/storage/repositories/session-state-repository.js.map +1 -0
  310. package/dist/server/storage/repositories/session-status-snapshot-repository.d.ts +8 -0
  311. package/dist/server/storage/repositories/session-status-snapshot-repository.js +49 -0
  312. package/dist/server/storage/repositories/session-status-snapshot-repository.js.map +1 -0
  313. package/dist/server/storage/repositories/terminal-command-template-repository.d.ts +11 -0
  314. package/dist/server/storage/repositories/terminal-command-template-repository.js +99 -0
  315. package/dist/server/storage/repositories/terminal-command-template-repository.js.map +1 -0
  316. package/dist/server/storage/repositories/terminal-instance-repository.d.ts +23 -0
  317. package/dist/server/storage/repositories/terminal-instance-repository.js +149 -0
  318. package/dist/server/storage/repositories/terminal-instance-repository.js.map +1 -0
  319. package/dist/server/storage/repositories/terminal-log-file-repository.d.ts +20 -0
  320. package/dist/server/storage/repositories/terminal-log-file-repository.js +106 -0
  321. package/dist/server/storage/repositories/terminal-log-file-repository.js.map +1 -0
  322. package/dist/server/storage/repositories/terminal-log-segment-repository.d.ts +11 -0
  323. package/dist/server/storage/repositories/terminal-log-segment-repository.js +110 -0
  324. package/dist/server/storage/repositories/terminal-log-segment-repository.js.map +1 -0
  325. package/dist/server/storage/repositories/terminal-runtime-session-repository.d.ts +24 -0
  326. package/dist/server/storage/repositories/terminal-runtime-session-repository.js +134 -0
  327. package/dist/server/storage/repositories/terminal-runtime-session-repository.js.map +1 -0
  328. package/dist/server/storage/repositories/user-quick-phrase-preference-repository.d.ts +8 -0
  329. package/dist/server/storage/repositories/user-quick-phrase-preference-repository.js +37 -0
  330. package/dist/server/storage/repositories/user-quick-phrase-preference-repository.js.map +1 -0
  331. package/dist/server/storage/repositories/workspace-repository.d.ts +16 -0
  332. package/dist/server/storage/repositories/workspace-repository.js +71 -0
  333. package/dist/server/storage/repositories/workspace-repository.js.map +1 -0
  334. package/dist/server/storage/sqlite/client.d.ts +6 -0
  335. package/dist/server/storage/sqlite/client.js +446 -0
  336. package/dist/server/storage/sqlite/client.js.map +1 -0
  337. package/dist/server/storage/sqlite/schema.sql +357 -0
  338. package/dist/server/types/domain.d.ts +306 -0
  339. package/dist/server/types/domain.js +2 -0
  340. package/dist/server/types/domain.js.map +1 -0
  341. package/dist/server/ws/terminal-ws-hub.d.ts +32 -0
  342. package/dist/server/ws/terminal-ws-hub.js +181 -0
  343. package/dist/server/ws/terminal-ws-hub.js.map +1 -0
  344. package/dist/server/ws/workbench-ws-hub.d.ts +30 -0
  345. package/dist/server/ws/workbench-ws-hub.js +480 -0
  346. package/dist/server/ws/workbench-ws-hub.js.map +1 -0
  347. package/dist/server/ws/ws-auth-guard.d.ts +7 -0
  348. package/dist/server/ws/ws-auth-guard.js +28 -0
  349. package/dist/server/ws/ws-auth-guard.js.map +1 -0
  350. package/dist/server/ws/ws-server.d.ts +11 -0
  351. package/dist/server/ws/ws-server.js +218 -0
  352. package/dist/server/ws/ws-server.js.map +1 -0
  353. package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.d.ts +36 -0
  354. package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.js +213 -0
  355. package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.js.map +1 -0
  356. package/node_modules/@codingns/session-sync-core/dist/index.d.ts +12 -0
  357. package/node_modules/@codingns/session-sync-core/dist/index.js +13 -0
  358. package/node_modules/@codingns/session-sync-core/dist/index.js.map +1 -0
  359. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.d.ts +30 -0
  360. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +567 -0
  361. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js.map +1 -0
  362. package/node_modules/@codingns/session-sync-core/dist/providers/codex.d.ts +41 -0
  363. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +1365 -0
  364. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -0
  365. package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.d.ts +41 -0
  366. package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.js +280 -0
  367. package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.js.map +1 -0
  368. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.d.ts +53 -0
  369. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +745 -0
  370. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -0
  371. package/node_modules/@codingns/session-sync-core/dist/providers/utils.d.ts +25 -0
  372. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +284 -0
  373. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +1 -0
  374. package/node_modules/@codingns/session-sync-core/dist/registry.d.ts +7 -0
  375. package/node_modules/@codingns/session-sync-core/dist/registry.js +22 -0
  376. package/node_modules/@codingns/session-sync-core/dist/registry.js.map +1 -0
  377. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.d.ts +18 -0
  378. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js +236 -0
  379. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js.map +1 -0
  380. package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.d.ts +21 -0
  381. package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js +732 -0
  382. package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js.map +1 -0
  383. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.d.ts +1 -0
  384. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js +16 -0
  385. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js.map +1 -0
  386. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +26 -0
  387. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +892 -0
  388. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -0
  389. package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.d.ts +31 -0
  390. package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js +626 -0
  391. package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js.map +1 -0
  392. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.d.ts +18 -0
  393. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js +148 -0
  394. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js.map +1 -0
  395. package/node_modules/@codingns/session-sync-core/dist/runtime/types.d.ts +141 -0
  396. package/node_modules/@codingns/session-sync-core/dist/runtime/types.js +2 -0
  397. package/node_modules/@codingns/session-sync-core/dist/runtime/types.js.map +1 -0
  398. package/node_modules/@codingns/session-sync-core/dist/services.d.ts +26 -0
  399. package/node_modules/@codingns/session-sync-core/dist/services.js +85 -0
  400. package/node_modules/@codingns/session-sync-core/dist/services.js.map +1 -0
  401. package/node_modules/@codingns/session-sync-core/dist/types.d.ts +159 -0
  402. package/node_modules/@codingns/session-sync-core/dist/types.js +2 -0
  403. package/node_modules/@codingns/session-sync-core/dist/types.js.map +1 -0
  404. package/node_modules/@codingns/session-sync-core/package.json +25 -0
  405. package/package.json +34 -0
@@ -0,0 +1,892 @@
1
+ import { randomUUID } from "node:crypto";
2
+ import { existsSync, readdirSync, readFileSync, statSync } from "node:fs";
3
+ import { homedir } from "node:os";
4
+ import { basename, dirname, join, resolve } from "node:path";
5
+ import { DatabaseSync } from "node:sqlite";
6
+ import { appendJsonLine, createRawRef, ensureDirectory, extractTextBlocks, messageIdFromRawRef, nextTimestamp, normalizeWorkspacePath } from "../providers/utils.js";
7
+ import { createCodexThreadPermissionOptions } from "./codex-permissions.js";
8
+ export class CodexRuntimeAdapter {
9
+ options;
10
+ providerId = "codex";
11
+ constructor(options = {}) {
12
+ this.options = options;
13
+ }
14
+ async startSession(request, sink) {
15
+ const launchedAtMs = Date.now();
16
+ const client = await loadCodexClient();
17
+ const thread = client.startThread(createThreadOptions(request));
18
+ const abortController = new AbortController();
19
+ const streamed = await thread.runStreamed(createCodexInput(request), {
20
+ signal: abortController.signal
21
+ });
22
+ const events = streamed.events[Symbol.asyncIterator]();
23
+ const startedSession = await this.awaitThreadStarted(thread, events, request.workspacePath, request.options.content, launchedAtMs);
24
+ const providerSessionId = startedSession.providerSessionId;
25
+ const fallbackRawStoreRef = request.rawStoreRef ?? buildRuntimeRawStoreRef(resolveRuntimeStoreKey(providerSessionId, request.sessionId));
26
+ const resolvedBinding = await this.resolveExistingSessionBinding(providerSessionId, fallbackRawStoreRef, request.workspacePath);
27
+ const rawStoreRef = resolvedBinding?.rawStoreRef ?? fallbackRawStoreRef;
28
+ sink.updateSessionBinding({
29
+ providerSessionId,
30
+ rawStoreRef
31
+ });
32
+ return {
33
+ providerSessionId,
34
+ rawStoreRef,
35
+ interrupt: async () => {
36
+ abortController.abort();
37
+ },
38
+ completed: this.runTurn(null, request, sink, providerSessionId, rawStoreRef, abortController, events, startedSession.bufferedEvents, launchedAtMs)
39
+ };
40
+ }
41
+ async continueSession(request, sink) {
42
+ const providerSessionId = resolveResumeThreadId(request.providerSessionId, request.rawStoreRef);
43
+ if (!providerSessionId) {
44
+ throw new Error("PROVIDER_SESSION_ID_REQUIRED");
45
+ }
46
+ const client = await loadCodexClient();
47
+ const thread = client.resumeThread(providerSessionId, createThreadOptions(request));
48
+ const fallbackRawStoreRef = request.rawStoreRef ?? buildRuntimeRawStoreRef(providerSessionId);
49
+ const resolvedBinding = await this.resolveExistingSessionBinding(providerSessionId, fallbackRawStoreRef, request.workspacePath);
50
+ const resolvedSessionId = resolvedBinding?.providerSessionId ?? providerSessionId;
51
+ const rawStoreRef = resolvedBinding?.rawStoreRef ?? fallbackRawStoreRef;
52
+ const abortController = new AbortController();
53
+ sink.updateSessionBinding({
54
+ providerSessionId: resolvedSessionId,
55
+ rawStoreRef
56
+ });
57
+ return {
58
+ providerSessionId: resolvedSessionId,
59
+ rawStoreRef,
60
+ interrupt: async () => {
61
+ abortController.abort();
62
+ },
63
+ completed: this.runTurn(thread, request, sink, resolvedSessionId, rawStoreRef, abortController, undefined, [], Date.now())
64
+ };
65
+ }
66
+ async runTurn(thread, request, sink, providerSessionId, rawStoreRef, abortController, preparedEvents, bufferedEvents = [], launchedAtMs = Date.now()) {
67
+ const context = {
68
+ providerSessionId,
69
+ rawStoreRef,
70
+ sequence: 0,
71
+ toolNameByCallId: new Map(),
72
+ sink,
73
+ workspacePath: request.workspacePath,
74
+ firstUserMessage: request.options.content,
75
+ launchedAtMs
76
+ };
77
+ try {
78
+ await this.refreshSessionBindingIfNeeded(context);
79
+ persistSyntheticUserMessageIfNeeded(context.rawStoreRef, context.providerSessionId, {
80
+ workspacePath: request.workspacePath,
81
+ content: request.options.content,
82
+ timestamp: nextTimestamp()
83
+ });
84
+ for (const event of bufferedEvents) {
85
+ await this.refreshSessionBindingIfNeeded(context);
86
+ persistSyntheticEventIfNeeded(context.rawStoreRef, context.providerSessionId, event);
87
+ await this.handleEvent(event, request, context, abortController.signal.aborted);
88
+ }
89
+ const events = preparedEvents ??
90
+ (await thread.runStreamed(createCodexInput(request), {
91
+ signal: abortController.signal
92
+ })).events[Symbol.asyncIterator]();
93
+ while (true) {
94
+ const next = await events.next();
95
+ if (next.done) {
96
+ return;
97
+ }
98
+ await this.refreshSessionBindingIfNeeded(context);
99
+ persistSyntheticEventIfNeeded(context.rawStoreRef, context.providerSessionId, next.value);
100
+ await this.handleEvent(next.value, request, context, abortController.signal.aborted);
101
+ }
102
+ }
103
+ catch (error) {
104
+ if (abortController.signal.aborted) {
105
+ await sink.emit({
106
+ type: "interrupted",
107
+ status: "interrupted",
108
+ providerSessionId: context.providerSessionId,
109
+ rawStoreRef: context.rawStoreRef,
110
+ detail: "codex turn interrupted",
111
+ timestamp: nextTimestamp()
112
+ });
113
+ return;
114
+ }
115
+ const failure = classifyCodexRuntimeFailure(error);
116
+ await sink.emit({
117
+ type: "error",
118
+ status: "failed",
119
+ providerSessionId: context.providerSessionId,
120
+ rawStoreRef: context.rawStoreRef,
121
+ errorCode: failure.errorCode,
122
+ detail: failure.detail,
123
+ timestamp: nextTimestamp()
124
+ });
125
+ }
126
+ }
127
+ async handleEvent(event, request, context, interrupted) {
128
+ const eventType = ensureText(readProp(event, "type")).trim();
129
+ if (eventType.length === 0) {
130
+ return;
131
+ }
132
+ if (eventType === "turn.completed") {
133
+ await context.sink.emit({
134
+ type: "complete",
135
+ status: "completed",
136
+ providerSessionId: context.providerSessionId,
137
+ rawStoreRef: context.rawStoreRef,
138
+ detail: "codex turn completed",
139
+ timestamp: pickTimestamp(event)
140
+ });
141
+ return;
142
+ }
143
+ if (eventType === "turn.failed") {
144
+ const detail = extractTextBlocks(readProp(event, "error")).trim() || "codex turn failed";
145
+ await context.sink.emit({
146
+ type: "error",
147
+ status: "failed",
148
+ providerSessionId: context.providerSessionId,
149
+ rawStoreRef: context.rawStoreRef,
150
+ errorCode: "CODEX_CLI_TURN_FAILED",
151
+ detail,
152
+ timestamp: pickTimestamp(event)
153
+ });
154
+ return;
155
+ }
156
+ if (interrupted) {
157
+ return;
158
+ }
159
+ if (!eventType.startsWith("item.")) {
160
+ return;
161
+ }
162
+ const item = readProp(event, "item");
163
+ const itemType = ensureText(readProp(item, "type")).trim();
164
+ if (itemType.length === 0) {
165
+ return;
166
+ }
167
+ if (itemType === "agent_message" && eventType === "item.completed") {
168
+ const content = pickFirstNonEmpty(ensureText(readProp(item, "text")).trim(), extractTextBlocks(readProp(item, "content")).trim());
169
+ if (content.length > 0) {
170
+ await context.sink.emit({
171
+ type: "message",
172
+ message: this.buildMessage(request, context, {
173
+ role: "assistant",
174
+ kind: "text",
175
+ content
176
+ }),
177
+ providerSessionId: context.providerSessionId,
178
+ rawStoreRef: context.rawStoreRef,
179
+ timestamp: pickTimestamp(item, event)
180
+ });
181
+ }
182
+ return;
183
+ }
184
+ if (itemType === "reasoning" && eventType === "item.completed") {
185
+ const content = pickFirstNonEmpty(ensureText(readProp(item, "text")).trim(), extractTextBlocks(readProp(item, "summary")).trim(), extractTextBlocks(readProp(item, "content")).trim());
186
+ if (content.length > 0) {
187
+ await context.sink.emit({
188
+ type: "message",
189
+ message: this.buildMessage(request, context, {
190
+ role: "assistant",
191
+ kind: "thinking",
192
+ content
193
+ }),
194
+ providerSessionId: context.providerSessionId,
195
+ rawStoreRef: context.rawStoreRef,
196
+ timestamp: pickTimestamp(item, event)
197
+ });
198
+ }
199
+ return;
200
+ }
201
+ if (!isToolItem(itemType)) {
202
+ return;
203
+ }
204
+ const callId = pickFirstNonEmpty(ensureText(readProp(item, "id")).trim(), ensureText(readProp(item, "call_id")).trim(), `${itemType}-${randomUUID()}`);
205
+ const name = pickFirstNonEmpty(ensureText(readProp(item, "name")).trim(), ensureText(readProp(item, "tool")).trim(), itemType);
206
+ if (eventType === "item.started") {
207
+ const input = pickFirstNonEmpty(extractTextBlocks(readProp(item, "arguments")).trim(), extractTextBlocks(readProp(item, "input")).trim(), extractTextBlocks(readProp(item, "command")).trim());
208
+ const toolCall = {
209
+ callId,
210
+ name,
211
+ input,
212
+ output: null,
213
+ error: null,
214
+ status: "running"
215
+ };
216
+ context.toolNameByCallId.set(callId, name);
217
+ await context.sink.emit({
218
+ type: "message",
219
+ message: this.buildMessage(request, context, {
220
+ role: "tool",
221
+ kind: "tool_call",
222
+ content: input,
223
+ toolCall
224
+ }),
225
+ providerSessionId: context.providerSessionId,
226
+ rawStoreRef: context.rawStoreRef,
227
+ timestamp: pickTimestamp(item, event)
228
+ });
229
+ return;
230
+ }
231
+ if (eventType === "item.completed") {
232
+ const output = pickFirstNonEmpty(extractTextBlocks(readProp(item, "result")).trim(), extractTextBlocks(readProp(item, "output")).trim(), extractTextBlocks(readProp(item, "aggregated_output")).trim(), extractTextBlocks(readProp(item, "error")).trim());
233
+ const success = inferToolSuccess(item, output);
234
+ const knownName = context.toolNameByCallId.get(callId) ?? name;
235
+ const toolCall = {
236
+ callId,
237
+ name: knownName,
238
+ input: "",
239
+ output: success ? output : null,
240
+ error: success ? null : output,
241
+ status: success ? "completed" : "failed"
242
+ };
243
+ await context.sink.emit({
244
+ type: "message",
245
+ message: this.buildMessage(request, context, {
246
+ role: "tool",
247
+ kind: "tool_result",
248
+ content: output,
249
+ toolCall
250
+ }),
251
+ providerSessionId: context.providerSessionId,
252
+ rawStoreRef: context.rawStoreRef,
253
+ timestamp: pickTimestamp(item, event)
254
+ });
255
+ }
256
+ }
257
+ async refreshSessionBindingIfNeeded(context) {
258
+ if (!isSyntheticRawStoreRef(context.rawStoreRef)) {
259
+ return;
260
+ }
261
+ const resolved = await this.resolveExistingSessionBinding(context.providerSessionId, context.rawStoreRef, context.workspacePath) ??
262
+ await this.resolveLaunchedSessionBinding(context.workspacePath, context.firstUserMessage, context.launchedAtMs);
263
+ if (!resolved ||
264
+ (resolved.providerSessionId === context.providerSessionId &&
265
+ resolved.rawStoreRef === context.rawStoreRef)) {
266
+ return;
267
+ }
268
+ context.providerSessionId = resolved.providerSessionId;
269
+ context.rawStoreRef = resolved.rawStoreRef;
270
+ context.sink.updateSessionBinding({
271
+ providerSessionId: resolved.providerSessionId,
272
+ rawStoreRef: resolved.rawStoreRef
273
+ });
274
+ }
275
+ async resolveExistingSessionBinding(providerSessionId, rawStoreRef, workspacePath) {
276
+ const normalizedProviderSessionId = providerSessionId.trim();
277
+ const meta = readSessionMeta(rawStoreRef);
278
+ if (meta && meta.threadId === normalizedProviderSessionId && existsSync(rawStoreRef)) {
279
+ return {
280
+ providerSessionId: meta.threadId,
281
+ rawStoreRef
282
+ };
283
+ }
284
+ if (!normalizedProviderSessionId) {
285
+ return null;
286
+ }
287
+ const resolvedRawStoreRef = await this.resolveRealRawStoreRef(normalizedProviderSessionId, workspacePath);
288
+ if (!resolvedRawStoreRef) {
289
+ return null;
290
+ }
291
+ return {
292
+ providerSessionId: normalizedProviderSessionId,
293
+ rawStoreRef: resolvedRawStoreRef
294
+ };
295
+ }
296
+ async resolveLaunchedSessionBinding(workspacePath, firstUserMessage, launchedAtMs) {
297
+ for (let attempt = 0; attempt < 20; attempt += 1) {
298
+ const matched = this.findLaunchedSessionBindingOnce(workspacePath, firstUserMessage, launchedAtMs);
299
+ if (matched) {
300
+ return matched;
301
+ }
302
+ if (attempt < 19) {
303
+ await sleep(100);
304
+ }
305
+ }
306
+ return null;
307
+ }
308
+ async resolveRealRawStoreRef(providerSessionId, workspacePath) {
309
+ for (let attempt = 0; attempt < 10; attempt += 1) {
310
+ const matched = this.findRawStoreRefOnce(providerSessionId, workspacePath);
311
+ if (matched) {
312
+ return matched;
313
+ }
314
+ if (attempt < 9) {
315
+ await sleep(150);
316
+ }
317
+ }
318
+ return null;
319
+ }
320
+ findRawStoreRefOnce(providerSessionId, workspacePath) {
321
+ const homeDir = this.options.homeDir?.trim() || process.env.CODINGNS_CODEX_HOME || join(homedir(), ".codex");
322
+ const candidates = this.listSessionFiles(homeDir);
323
+ const normalizedWorkspace = normalizeWorkspacePath(workspacePath);
324
+ for (const filePath of candidates) {
325
+ const meta = readSessionMeta(filePath);
326
+ if (!meta) {
327
+ continue;
328
+ }
329
+ if (meta.threadId !== providerSessionId) {
330
+ continue;
331
+ }
332
+ if (meta.cwd && normalizeWorkspacePath(meta.cwd) !== normalizedWorkspace) {
333
+ continue;
334
+ }
335
+ return filePath;
336
+ }
337
+ return null;
338
+ }
339
+ listSessionFiles(homeDir) {
340
+ const now = new Date();
341
+ const currentYear = String(now.getUTCFullYear());
342
+ const currentMonth = String(now.getUTCMonth() + 1).padStart(2, "0");
343
+ const currentDay = String(now.getUTCDate()).padStart(2, "0");
344
+ const preferredRoots = [
345
+ join(homeDir, "sessions", currentYear, currentMonth, currentDay),
346
+ join(homeDir, "sessions"),
347
+ join(homeDir, "archived_sessions")
348
+ ];
349
+ const seen = new Set();
350
+ const files = [];
351
+ for (const root of preferredRoots) {
352
+ for (const file of walkJsonlFiles(root)) {
353
+ if (seen.has(file)) {
354
+ continue;
355
+ }
356
+ seen.add(file);
357
+ files.push(file);
358
+ }
359
+ }
360
+ return files;
361
+ }
362
+ findLaunchedSessionBindingOnce(workspacePath, firstUserMessage, launchedAtMs) {
363
+ const dbPath = findLatestCodexStateDatabase(this.getCodexHomeDir());
364
+ if (!dbPath) {
365
+ return null;
366
+ }
367
+ let db = null;
368
+ try {
369
+ db = new DatabaseSync(dbPath, { open: true, readOnly: true });
370
+ const rows = db.prepare(`SELECT id, rollout_path, cwd, first_user_message, created_at
371
+ FROM threads
372
+ WHERE source = 'exec'
373
+ AND created_at >= ?
374
+ ORDER BY created_at DESC
375
+ LIMIT 30`).all(Math.max(0, Math.floor((launchedAtMs - 30_000) / 1000)));
376
+ const normalizedWorkspace = normalizeWorkspacePath(workspacePath);
377
+ const normalizedMessage = firstUserMessage.trim();
378
+ for (const row of rows) {
379
+ if (normalizeWorkspacePath(row.cwd) !== normalizedWorkspace ||
380
+ row.first_user_message.trim() !== normalizedMessage ||
381
+ !existsSync(row.rollout_path)) {
382
+ continue;
383
+ }
384
+ return {
385
+ providerSessionId: row.id,
386
+ rawStoreRef: row.rollout_path
387
+ };
388
+ }
389
+ }
390
+ catch {
391
+ return null;
392
+ }
393
+ finally {
394
+ db?.close();
395
+ }
396
+ return null;
397
+ }
398
+ getCodexHomeDir() {
399
+ return this.options.homeDir?.trim() || process.env.CODINGNS_CODEX_HOME || join(homedir(), ".codex");
400
+ }
401
+ buildMessage(request, context, input) {
402
+ context.sequence += 1;
403
+ const rawRef = createRawRef(this.providerId, context.rawStoreRef, context.sequence);
404
+ return {
405
+ messageId: messageIdFromRawRef(rawRef),
406
+ provider: this.providerId,
407
+ providerSessionId: context.providerSessionId,
408
+ role: input.role,
409
+ kind: input.kind,
410
+ content: input.content,
411
+ toolCall: input.toolCall ?? null,
412
+ timestamp: nextTimestamp(),
413
+ sequence: context.sequence,
414
+ rawRef
415
+ };
416
+ }
417
+ async awaitThreadStarted(thread, events, workspacePath, firstUserMessage, launchedAtMs) {
418
+ const bufferedEvents = [];
419
+ while (true) {
420
+ const next = await events.next();
421
+ if (next.done) {
422
+ const resolved = await this.resolveLaunchedSessionBinding(workspacePath, firstUserMessage, launchedAtMs);
423
+ if (resolved) {
424
+ return {
425
+ providerSessionId: resolved.providerSessionId,
426
+ bufferedEvents
427
+ };
428
+ }
429
+ throw new Error("CODEX_THREAD_START_MISSING");
430
+ }
431
+ const eventType = ensureText(readProp(next.value, "type")).trim();
432
+ if (eventType === "thread.started") {
433
+ const providerSessionId = pickFirstNonEmpty(ensureText(readProp(next.value, "thread_id")).trim(), ensureText(thread.id).trim());
434
+ if (providerSessionId.length === 0) {
435
+ throw new Error("CODEX_THREAD_ID_MISSING");
436
+ }
437
+ return {
438
+ providerSessionId,
439
+ bufferedEvents
440
+ };
441
+ }
442
+ bufferedEvents.push(next.value);
443
+ const resolved = await this.resolveLaunchedSessionBinding(workspacePath, firstUserMessage, launchedAtMs);
444
+ if (resolved) {
445
+ return {
446
+ providerSessionId: resolved.providerSessionId,
447
+ bufferedEvents
448
+ };
449
+ }
450
+ }
451
+ }
452
+ }
453
+ export function createThreadOptions(request) {
454
+ const options = {
455
+ workingDirectory: request.workspacePath,
456
+ skipGitRepoCheck: true,
457
+ ...createCodexThreadPermissionOptions(request.options.permissionMode ?? "default")
458
+ };
459
+ if (request.options.model) {
460
+ options.model = request.options.model;
461
+ }
462
+ const reasoningEffort = normalizeCodexReasoningEffort(request.options.reasoningLevel);
463
+ if (reasoningEffort) {
464
+ options.modelReasoningEffort = reasoningEffort;
465
+ }
466
+ const additionalDirectories = Array.from(new Set(request.options.attachments.map((attachment) => dirname(attachment.filePath))));
467
+ if (additionalDirectories.length > 0) {
468
+ options.additionalDirectories = additionalDirectories;
469
+ }
470
+ return options;
471
+ }
472
+ function normalizeCodexReasoningEffort(value) {
473
+ const normalized = value?.trim().toLowerCase() ?? null;
474
+ if (!normalized) {
475
+ return null;
476
+ }
477
+ if (normalized === "maximum") {
478
+ return "xhigh";
479
+ }
480
+ if (normalized === "minimal" ||
481
+ normalized === "low" ||
482
+ normalized === "medium" ||
483
+ normalized === "high" ||
484
+ normalized === "xhigh") {
485
+ return normalized;
486
+ }
487
+ return null;
488
+ }
489
+ function createCodexInput(request) {
490
+ if (request.options.attachments.length === 0) {
491
+ return request.options.content;
492
+ }
493
+ const input = [];
494
+ const promptText = request.options.content.trim();
495
+ if (promptText.length > 0) {
496
+ input.push({
497
+ type: "text",
498
+ text: promptText
499
+ });
500
+ }
501
+ request.options.attachments.forEach((attachment) => {
502
+ input.push({
503
+ type: "local_image",
504
+ path: attachment.filePath
505
+ });
506
+ });
507
+ return input;
508
+ }
509
+ async function loadCodexClient() {
510
+ const moduleName = "@openai/codex-sdk";
511
+ const runtimeImport = new Function("name", "return import(name);");
512
+ const module = (await runtimeImport(moduleName));
513
+ if (!module.Codex) {
514
+ throw new Error("CODEX_SDK_UNAVAILABLE");
515
+ }
516
+ return new module.Codex();
517
+ }
518
+ function buildRuntimeRawStoreRef(providerSessionId) {
519
+ return resolve(process.cwd(), "runtime", "codex", `${providerSessionId}.stream`);
520
+ }
521
+ function resolveRuntimeStoreKey(providerSessionId, sessionId) {
522
+ return providerSessionId.trim() || sessionId;
523
+ }
524
+ function resolveResumeThreadId(providerSessionId, rawStoreRef) {
525
+ const normalizedProviderSessionId = ensureText(providerSessionId).trim();
526
+ const fromRawStore = readThreadIdFromRawStore(rawStoreRef);
527
+ if (fromRawStore) {
528
+ return fromRawStore;
529
+ }
530
+ if (normalizedProviderSessionId.length > 0) {
531
+ return normalizedProviderSessionId;
532
+ }
533
+ return null;
534
+ }
535
+ function readProp(value, key) {
536
+ if (!value || typeof value !== "object") {
537
+ return null;
538
+ }
539
+ return value[key];
540
+ }
541
+ function ensureText(value) {
542
+ if (typeof value === "string") {
543
+ return value;
544
+ }
545
+ if (value === undefined || value === null) {
546
+ return "";
547
+ }
548
+ try {
549
+ return JSON.stringify(value);
550
+ }
551
+ catch {
552
+ return String(value);
553
+ }
554
+ }
555
+ function readThreadIdFromRawStore(rawStoreRef) {
556
+ const filePath = ensureText(rawStoreRef).trim();
557
+ if (!filePath || !existsSync(filePath)) {
558
+ return null;
559
+ }
560
+ const firstLine = readFileSync(filePath, "utf8")
561
+ .split(/\r?\n/, 1)
562
+ .at(0)
563
+ ?.trim();
564
+ if (!firstLine) {
565
+ return null;
566
+ }
567
+ try {
568
+ const record = JSON.parse(firstLine);
569
+ if (ensureText(record.type).trim() !== "session_meta") {
570
+ return null;
571
+ }
572
+ const threadId = ensureText(record.payload?.id).trim();
573
+ return threadId.length > 0 ? threadId : null;
574
+ }
575
+ catch {
576
+ return null;
577
+ }
578
+ }
579
+ function looksLikeCodexThreadId(value) {
580
+ return /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(value);
581
+ }
582
+ function readSessionMeta(filePath) {
583
+ if (!existsSync(filePath)) {
584
+ return null;
585
+ }
586
+ const firstLine = readFileSync(filePath, "utf8")
587
+ .split(/\r?\n/, 1)
588
+ .at(0)
589
+ ?.trim();
590
+ if (!firstLine) {
591
+ return null;
592
+ }
593
+ try {
594
+ const record = JSON.parse(firstLine);
595
+ if (ensureText(record.type).trim() !== "session_meta") {
596
+ return null;
597
+ }
598
+ const metaThreadId = ensureText(record.payload?.id).trim();
599
+ const fileThreadId = basename(filePath, ".jsonl").trim();
600
+ const threadId = looksLikeCodexThreadId(metaThreadId)
601
+ ? metaThreadId
602
+ : looksLikeCodexThreadId(fileThreadId)
603
+ ? fileThreadId
604
+ : metaThreadId;
605
+ if (!threadId) {
606
+ return null;
607
+ }
608
+ const cwdText = ensureText(record.payload?.cwd).trim();
609
+ return {
610
+ threadId,
611
+ cwd: cwdText.length > 0 ? cwdText : null
612
+ };
613
+ }
614
+ catch {
615
+ return null;
616
+ }
617
+ }
618
+ function isSyntheticRawStoreRef(rawStoreRef) {
619
+ const normalized = rawStoreRef.replaceAll("\\", "/").toLowerCase();
620
+ return normalized.includes("/runtime/codex/") || normalized.startsWith("runtime/codex/");
621
+ }
622
+ function walkJsonlFiles(rootDir) {
623
+ if (!existsSync(rootDir)) {
624
+ return [];
625
+ }
626
+ const queue = [rootDir];
627
+ const files = [];
628
+ while (queue.length > 0) {
629
+ const current = queue.shift();
630
+ if (!current) {
631
+ continue;
632
+ }
633
+ for (const entry of readdirSync(current, { withFileTypes: true })) {
634
+ const fullPath = join(current, entry.name);
635
+ if (entry.isDirectory()) {
636
+ queue.push(fullPath);
637
+ continue;
638
+ }
639
+ if (entry.isFile() && basename(fullPath).endsWith(".jsonl")) {
640
+ files.push(fullPath);
641
+ }
642
+ }
643
+ }
644
+ return files;
645
+ }
646
+ function sleep(ms) {
647
+ return new Promise((resolve) => {
648
+ setTimeout(resolve, ms);
649
+ });
650
+ }
651
+ function findLatestCodexStateDatabase(homeDir) {
652
+ if (!existsSync(homeDir)) {
653
+ return null;
654
+ }
655
+ const candidates = readdirSync(homeDir, { withFileTypes: true })
656
+ .filter((entry) => entry.isFile() && /^state_\d+\.sqlite$/i.test(entry.name))
657
+ .map((entry) => {
658
+ const filePath = join(homeDir, entry.name);
659
+ return {
660
+ filePath,
661
+ mtimeMs: statSync(filePath).mtimeMs
662
+ };
663
+ })
664
+ .sort((left, right) => right.mtimeMs - left.mtimeMs);
665
+ return candidates[0]?.filePath ?? null;
666
+ }
667
+ function pickTimestamp(...candidates) {
668
+ for (const candidate of candidates) {
669
+ const raw = ensureText(readProp(candidate, "timestamp")).trim();
670
+ if (raw.length > 0) {
671
+ return raw;
672
+ }
673
+ }
674
+ return nextTimestamp();
675
+ }
676
+ function pickFirstNonEmpty(...values) {
677
+ for (const value of values) {
678
+ if (value.trim().length > 0) {
679
+ return value.trim();
680
+ }
681
+ }
682
+ return "";
683
+ }
684
+ function isToolItem(itemType) {
685
+ return (itemType === "command_execution" ||
686
+ itemType === "mcp_tool_call" ||
687
+ itemType === "function_call" ||
688
+ itemType === "custom_tool_call");
689
+ }
690
+ function inferToolSuccess(item, output) {
691
+ const status = ensureText(readProp(item, "status")).trim().toLowerCase();
692
+ if (status === "failed" || status === "error") {
693
+ return false;
694
+ }
695
+ if (status === "completed" || status === "success" || status === "succeeded") {
696
+ return true;
697
+ }
698
+ const exitCode = readProp(item, "exit_code");
699
+ if (typeof exitCode === "number") {
700
+ return exitCode === 0;
701
+ }
702
+ const lowered = output.toLowerCase();
703
+ if (lowered.includes("error")) {
704
+ return false;
705
+ }
706
+ return true;
707
+ }
708
+ function classifyCodexRuntimeFailure(error) {
709
+ const detail = error instanceof Error ? error.message : "codex runtime error";
710
+ if (detail.includes("PROVIDER_SESSION_ID_REQUIRED")) {
711
+ return {
712
+ errorCode: "CODEX_PROVIDER_SESSION_ID_REQUIRED",
713
+ detail
714
+ };
715
+ }
716
+ if (detail.includes("Cannot find package") || detail.includes("ERR_MODULE_NOT_FOUND")) {
717
+ return {
718
+ errorCode: "CODEX_RUNTIME_SDK_MISSING",
719
+ detail
720
+ };
721
+ }
722
+ if (detail.includes("ENOENT") || detail.includes("spawn")) {
723
+ return {
724
+ errorCode: "CODEX_CLI_LAUNCH_FAILED",
725
+ detail
726
+ };
727
+ }
728
+ return {
729
+ errorCode: "CODEX_RUNTIME_ERROR",
730
+ detail
731
+ };
732
+ }
733
+ function persistSyntheticUserMessageIfNeeded(rawStoreRef, providerSessionId, input) {
734
+ if (!isSyntheticRawStoreRef(rawStoreRef) || input.content.trim().length === 0) {
735
+ return;
736
+ }
737
+ ensureSyntheticRuntimeFile(rawStoreRef, providerSessionId, input.workspacePath, input.timestamp);
738
+ appendJsonLine(rawStoreRef, {
739
+ timestamp: input.timestamp,
740
+ type: "event_msg",
741
+ payload: {
742
+ type: "user_message",
743
+ message: input.content
744
+ }
745
+ });
746
+ }
747
+ function persistSyntheticEventIfNeeded(rawStoreRef, providerSessionId, event) {
748
+ if (!isSyntheticRawStoreRef(rawStoreRef)) {
749
+ return;
750
+ }
751
+ const serialized = toSyntheticRuntimeRecord(event, providerSessionId);
752
+ if (!serialized) {
753
+ return;
754
+ }
755
+ ensureSyntheticRuntimeFile(rawStoreRef, providerSessionId, null, serialized.timestamp);
756
+ appendJsonLine(rawStoreRef, serialized.record);
757
+ }
758
+ function ensureSyntheticRuntimeFile(rawStoreRef, providerSessionId, workspacePath, timestamp) {
759
+ if (existsSync(rawStoreRef)) {
760
+ return;
761
+ }
762
+ ensureDirectory(dirname(rawStoreRef));
763
+ appendJsonLine(rawStoreRef, {
764
+ timestamp,
765
+ type: "session_meta",
766
+ payload: {
767
+ id: providerSessionId,
768
+ timestamp,
769
+ cwd: workspacePath ?? "",
770
+ originator: "CodingNS Runtime",
771
+ source: "codingns-runtime"
772
+ }
773
+ });
774
+ }
775
+ function toSyntheticRuntimeRecord(event, providerSessionId) {
776
+ const eventType = ensureText(readProp(event, "type")).trim();
777
+ const timestamp = pickTimestamp(event);
778
+ if (eventType === "turn.completed") {
779
+ return {
780
+ timestamp,
781
+ record: {
782
+ timestamp,
783
+ type: "event_msg",
784
+ payload: {
785
+ type: "task_complete"
786
+ }
787
+ }
788
+ };
789
+ }
790
+ if (eventType === "turn.failed") {
791
+ return {
792
+ timestamp,
793
+ record: {
794
+ timestamp,
795
+ type: "event_msg",
796
+ payload: {
797
+ type: "task_failed",
798
+ error: extractTextBlocks(readProp(event, "error")).trim()
799
+ }
800
+ }
801
+ };
802
+ }
803
+ if (!eventType.startsWith("item.")) {
804
+ return null;
805
+ }
806
+ const item = readProp(event, "item");
807
+ const itemType = ensureText(readProp(item, "type")).trim();
808
+ if (itemType.length === 0) {
809
+ return null;
810
+ }
811
+ if (itemType === "agent_message" && eventType === "item.completed") {
812
+ const content = pickFirstNonEmpty(ensureText(readProp(item, "text")).trim(), extractTextBlocks(readProp(item, "content")).trim());
813
+ if (content.length === 0) {
814
+ return null;
815
+ }
816
+ return {
817
+ timestamp,
818
+ record: {
819
+ timestamp,
820
+ type: "event_msg",
821
+ payload: {
822
+ type: "agent_message",
823
+ message: content
824
+ }
825
+ }
826
+ };
827
+ }
828
+ if (itemType === "reasoning" && eventType === "item.completed") {
829
+ const content = pickFirstNonEmpty(ensureText(readProp(item, "text")).trim(), extractTextBlocks(readProp(item, "summary")).trim(), extractTextBlocks(readProp(item, "content")).trim());
830
+ if (content.length === 0) {
831
+ return null;
832
+ }
833
+ return {
834
+ timestamp,
835
+ record: {
836
+ timestamp,
837
+ type: "event_msg",
838
+ payload: {
839
+ type: "agent_reasoning",
840
+ text: content
841
+ }
842
+ }
843
+ };
844
+ }
845
+ if (!isToolItem(itemType)) {
846
+ return null;
847
+ }
848
+ const callId = pickFirstNonEmpty(ensureText(readProp(item, "id")).trim(), ensureText(readProp(item, "call_id")).trim(), `${itemType}-${providerSessionId}`);
849
+ const name = pickFirstNonEmpty(ensureText(readProp(item, "name")).trim(), ensureText(readProp(item, "tool")).trim(), itemType);
850
+ if (eventType === "item.started") {
851
+ const input = pickFirstNonEmpty(extractTextBlocks(readProp(item, "arguments")).trim(), extractTextBlocks(readProp(item, "input")).trim(), extractTextBlocks(readProp(item, "command")).trim());
852
+ return {
853
+ timestamp,
854
+ record: {
855
+ timestamp,
856
+ type: "response_item",
857
+ payload: {
858
+ type: mapToolStartItemType(itemType),
859
+ call_id: callId,
860
+ name,
861
+ arguments: input,
862
+ input
863
+ }
864
+ }
865
+ };
866
+ }
867
+ if (eventType !== "item.completed") {
868
+ return null;
869
+ }
870
+ const output = pickFirstNonEmpty(extractTextBlocks(readProp(item, "result")).trim(), extractTextBlocks(readProp(item, "output")).trim(), extractTextBlocks(readProp(item, "aggregated_output")).trim(), extractTextBlocks(readProp(item, "error")).trim());
871
+ return {
872
+ timestamp,
873
+ record: {
874
+ timestamp,
875
+ type: "response_item",
876
+ payload: {
877
+ type: mapToolResultItemType(itemType),
878
+ call_id: callId,
879
+ name,
880
+ output,
881
+ status: inferToolSuccess(item, output) ? "completed" : "failed"
882
+ }
883
+ }
884
+ };
885
+ }
886
+ function mapToolStartItemType(itemType) {
887
+ return itemType === "custom_tool_call" ? "custom_tool_call" : "function_call";
888
+ }
889
+ function mapToolResultItemType(itemType) {
890
+ return itemType === "custom_tool_call" ? "custom_tool_call_output" : "function_call_output";
891
+ }
892
+ //# sourceMappingURL=codex-runtime.js.map