@jcjeon/integration-cli 0.2.0 → 0.2.1

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 (820) hide show
  1. package/apps/server/dist/app.controller.d.ts +6 -0
  2. package/apps/server/dist/app.controller.js +35 -0
  3. package/apps/server/dist/app.controller.js.map +1 -0
  4. package/apps/server/dist/app.module.d.ts +2 -0
  5. package/apps/server/dist/app.module.js +30 -0
  6. package/apps/server/dist/app.module.js.map +1 -0
  7. package/apps/server/dist/app.service.d.ts +3 -0
  8. package/apps/server/dist/app.service.js +20 -0
  9. package/apps/server/dist/app.service.js.map +1 -0
  10. package/apps/server/dist/common/ji-paths.d.ts +22 -0
  11. package/apps/server/dist/common/ji-paths.js +77 -0
  12. package/apps/server/dist/common/ji-paths.js.map +1 -0
  13. package/apps/server/dist/database/database.module.d.ts +2 -0
  14. package/apps/server/dist/database/database.module.js +38 -0
  15. package/apps/server/dist/database/database.module.js.map +1 -0
  16. package/apps/server/dist/database/entities/agent-changelog.entity.d.ts +14 -0
  17. package/apps/server/dist/database/entities/agent-changelog.entity.js +75 -0
  18. package/apps/server/dist/database/entities/agent-changelog.entity.js.map +1 -0
  19. package/apps/server/dist/database/entities/agent-session.entity.d.ts +10 -0
  20. package/apps/server/dist/database/entities/agent-session.entity.js +60 -0
  21. package/apps/server/dist/database/entities/agent-session.entity.js.map +1 -0
  22. package/apps/server/dist/database/entities/conversation.entity.d.ts +12 -0
  23. package/apps/server/dist/database/entities/conversation.entity.js +66 -0
  24. package/apps/server/dist/database/entities/conversation.entity.js.map +1 -0
  25. package/apps/server/dist/database/entities/session.entity.d.ts +6 -0
  26. package/apps/server/dist/database/entities/session.entity.js +40 -0
  27. package/apps/server/dist/database/entities/session.entity.js.map +1 -0
  28. package/apps/server/dist/database/entities/task-agent-run.entity.d.ts +15 -0
  29. package/apps/server/dist/database/entities/task-agent-run.entity.js +77 -0
  30. package/apps/server/dist/database/entities/task-agent-run.entity.js.map +1 -0
  31. package/apps/server/dist/database/entities/task-agent.entity.d.ts +16 -0
  32. package/apps/server/dist/database/entities/task-agent.entity.js +76 -0
  33. package/apps/server/dist/database/entities/task-agent.entity.js.map +1 -0
  34. package/apps/server/dist/database/entities/task-requirement.entity.d.ts +10 -0
  35. package/apps/server/dist/database/entities/task-requirement.entity.js +56 -0
  36. package/apps/server/dist/database/entities/task-requirement.entity.js.map +1 -0
  37. package/apps/server/dist/database/entities/task-run.entity.d.ts +13 -0
  38. package/apps/server/dist/database/entities/task-run.entity.js +67 -0
  39. package/apps/server/dist/database/entities/task-run.entity.js.map +1 -0
  40. package/apps/server/dist/database/entities/task.entity.d.ts +14 -0
  41. package/apps/server/dist/database/entities/task.entity.js +72 -0
  42. package/apps/server/dist/database/entities/task.entity.js.map +1 -0
  43. package/apps/server/dist/main.d.ts +1 -0
  44. package/apps/server/dist/main.js +81 -0
  45. package/apps/server/dist/main.js.map +1 -0
  46. package/apps/server/dist/modules/agents/agents.module.d.ts +2 -0
  47. package/apps/server/dist/modules/agents/agents.module.js +23 -0
  48. package/apps/server/dist/modules/agents/agents.module.js.map +1 -0
  49. package/apps/server/dist/modules/agents/claude/claude-auth.manager.d.ts +15 -0
  50. package/apps/server/dist/modules/agents/claude/claude-auth.manager.js +71 -0
  51. package/apps/server/dist/modules/agents/claude/claude-auth.manager.js.map +1 -0
  52. package/apps/server/dist/modules/agents/claude/claude-pty.manager.d.ts +29 -0
  53. package/apps/server/dist/modules/agents/claude/claude-pty.manager.js +372 -0
  54. package/apps/server/dist/modules/agents/claude/claude-pty.manager.js.map +1 -0
  55. package/apps/server/dist/modules/agents/claude/claude.controller.d.ts +19 -0
  56. package/apps/server/dist/modules/agents/claude/claude.controller.js +125 -0
  57. package/apps/server/dist/modules/agents/claude/claude.controller.js.map +1 -0
  58. package/apps/server/dist/modules/agents/claude/claude.gateway.d.ts +27 -0
  59. package/apps/server/dist/modules/agents/claude/claude.gateway.js +148 -0
  60. package/apps/server/dist/modules/agents/claude/claude.gateway.js.map +1 -0
  61. package/apps/server/dist/modules/agents/claude/claude.module.d.ts +2 -0
  62. package/apps/server/dist/modules/agents/claude/claude.module.js +30 -0
  63. package/apps/server/dist/modules/agents/claude/claude.module.js.map +1 -0
  64. package/apps/server/dist/modules/agents/claude/claude.service.d.ts +28 -0
  65. package/apps/server/dist/modules/agents/claude/claude.service.js +94 -0
  66. package/apps/server/dist/modules/agents/claude/claude.service.js.map +1 -0
  67. package/apps/server/dist/modules/agents/claude/dto/create-session.dto.d.ts +6 -0
  68. package/apps/server/dist/modules/agents/claude/dto/create-session.dto.js +46 -0
  69. package/apps/server/dist/modules/agents/claude/dto/create-session.dto.js.map +1 -0
  70. package/apps/server/dist/modules/agents/claude/dto/resize-session.dto.d.ts +4 -0
  71. package/apps/server/dist/modules/agents/claude/dto/resize-session.dto.js +31 -0
  72. package/apps/server/dist/modules/agents/claude/dto/resize-session.dto.js.map +1 -0
  73. package/apps/server/dist/modules/agents/claude/dto/send-input.dto.d.ts +3 -0
  74. package/apps/server/dist/modules/agents/claude/dto/send-input.dto.js +25 -0
  75. package/apps/server/dist/modules/agents/claude/dto/send-input.dto.js.map +1 -0
  76. package/apps/server/dist/modules/agents/claude/interfaces/claude-session.interface.d.ts +22 -0
  77. package/apps/server/dist/modules/agents/claude/interfaces/claude-session.interface.js +3 -0
  78. package/apps/server/dist/modules/agents/claude/interfaces/claude-session.interface.js.map +1 -0
  79. package/apps/server/dist/modules/agents/claude/interfaces/pty-event.interface.d.ts +9 -0
  80. package/apps/server/dist/modules/agents/claude/interfaces/pty-event.interface.js +3 -0
  81. package/apps/server/dist/modules/agents/claude/interfaces/pty-event.interface.js.map +1 -0
  82. package/apps/server/dist/modules/agents/claude/interfaces/stream-event.interface.d.ts +53 -0
  83. package/apps/server/dist/modules/agents/claude/interfaces/stream-event.interface.js +3 -0
  84. package/apps/server/dist/modules/agents/claude/interfaces/stream-event.interface.js.map +1 -0
  85. package/apps/server/dist/modules/agents/codex/codex-auth.manager.d.ts +16 -0
  86. package/apps/server/dist/modules/agents/codex/codex-auth.manager.js +136 -0
  87. package/apps/server/dist/modules/agents/codex/codex-auth.manager.js.map +1 -0
  88. package/apps/server/dist/modules/agents/codex/codex-session.manager.d.ts +37 -0
  89. package/apps/server/dist/modules/agents/codex/codex-session.manager.js +319 -0
  90. package/apps/server/dist/modules/agents/codex/codex-session.manager.js.map +1 -0
  91. package/apps/server/dist/modules/agents/codex/codex.controller.d.ts +19 -0
  92. package/apps/server/dist/modules/agents/codex/codex.controller.js +95 -0
  93. package/apps/server/dist/modules/agents/codex/codex.controller.js.map +1 -0
  94. package/apps/server/dist/modules/agents/codex/codex.gateway.d.ts +27 -0
  95. package/apps/server/dist/modules/agents/codex/codex.gateway.js +123 -0
  96. package/apps/server/dist/modules/agents/codex/codex.gateway.js.map +1 -0
  97. package/apps/server/dist/modules/agents/codex/codex.module.d.ts +2 -0
  98. package/apps/server/dist/modules/agents/codex/codex.module.js +29 -0
  99. package/apps/server/dist/modules/agents/codex/codex.module.js.map +1 -0
  100. package/apps/server/dist/modules/agents/codex/dto/configure-auth.dto.d.ts +3 -0
  101. package/apps/server/dist/modules/agents/codex/dto/configure-auth.dto.js +23 -0
  102. package/apps/server/dist/modules/agents/codex/dto/configure-auth.dto.js.map +1 -0
  103. package/apps/server/dist/modules/agents/gemini/dto/configure-auth.dto.d.ts +5 -0
  104. package/apps/server/dist/modules/agents/gemini/dto/configure-auth.dto.js +31 -0
  105. package/apps/server/dist/modules/agents/gemini/dto/configure-auth.dto.js.map +1 -0
  106. package/apps/server/dist/modules/agents/gemini/dto/create-session.dto.d.ts +3 -0
  107. package/apps/server/dist/modules/agents/gemini/dto/create-session.dto.js +25 -0
  108. package/apps/server/dist/modules/agents/gemini/dto/create-session.dto.js.map +1 -0
  109. package/apps/server/dist/modules/agents/gemini/dto/send-input.dto.d.ts +3 -0
  110. package/apps/server/dist/modules/agents/gemini/dto/send-input.dto.js +25 -0
  111. package/apps/server/dist/modules/agents/gemini/dto/send-input.dto.js.map +1 -0
  112. package/apps/server/dist/modules/agents/gemini/gemini-auth.manager.d.ts +20 -0
  113. package/apps/server/dist/modules/agents/gemini/gemini-auth.manager.js +154 -0
  114. package/apps/server/dist/modules/agents/gemini/gemini-auth.manager.js.map +1 -0
  115. package/apps/server/dist/modules/agents/gemini/gemini-session.manager.d.ts +31 -0
  116. package/apps/server/dist/modules/agents/gemini/gemini-session.manager.js +304 -0
  117. package/apps/server/dist/modules/agents/gemini/gemini-session.manager.js.map +1 -0
  118. package/apps/server/dist/modules/agents/gemini/gemini.controller.d.ts +19 -0
  119. package/apps/server/dist/modules/agents/gemini/gemini.controller.js +135 -0
  120. package/apps/server/dist/modules/agents/gemini/gemini.controller.js.map +1 -0
  121. package/apps/server/dist/modules/agents/gemini/gemini.gateway.d.ts +24 -0
  122. package/apps/server/dist/modules/agents/gemini/gemini.gateway.js +142 -0
  123. package/apps/server/dist/modules/agents/gemini/gemini.gateway.js.map +1 -0
  124. package/apps/server/dist/modules/agents/gemini/gemini.module.d.ts +2 -0
  125. package/apps/server/dist/modules/agents/gemini/gemini.module.js +29 -0
  126. package/apps/server/dist/modules/agents/gemini/gemini.module.js.map +1 -0
  127. package/apps/server/dist/modules/agents/gemini/interfaces/gemini-session.interface.d.ts +16 -0
  128. package/apps/server/dist/modules/agents/gemini/interfaces/gemini-session.interface.js +3 -0
  129. package/apps/server/dist/modules/agents/gemini/interfaces/gemini-session.interface.js.map +1 -0
  130. package/apps/server/dist/modules/agents/gemini/interfaces/stream-event.interface.d.ts +12 -0
  131. package/apps/server/dist/modules/agents/gemini/interfaces/stream-event.interface.js +3 -0
  132. package/apps/server/dist/modules/agents/gemini/interfaces/stream-event.interface.js.map +1 -0
  133. package/apps/server/dist/modules/changelog/changelog.controller.d.ts +7 -0
  134. package/apps/server/dist/modules/changelog/changelog.controller.js +50 -0
  135. package/apps/server/dist/modules/changelog/changelog.controller.js.map +1 -0
  136. package/apps/server/dist/modules/changelog/changelog.module.d.ts +2 -0
  137. package/apps/server/dist/modules/changelog/changelog.module.js +26 -0
  138. package/apps/server/dist/modules/changelog/changelog.module.js.map +1 -0
  139. package/apps/server/dist/modules/changelog/changelog.service.d.ts +68 -0
  140. package/apps/server/dist/modules/changelog/changelog.service.js +598 -0
  141. package/apps/server/dist/modules/changelog/changelog.service.js.map +1 -0
  142. package/apps/server/dist/modules/conversations/conversation.controller.d.ts +11 -0
  143. package/apps/server/dist/modules/conversations/conversation.controller.js +95 -0
  144. package/apps/server/dist/modules/conversations/conversation.controller.js.map +1 -0
  145. package/apps/server/dist/modules/conversations/conversation.module.d.ts +2 -0
  146. package/apps/server/dist/modules/conversations/conversation.module.js +26 -0
  147. package/apps/server/dist/modules/conversations/conversation.module.js.map +1 -0
  148. package/apps/server/dist/modules/conversations/conversation.service.d.ts +13 -0
  149. package/apps/server/dist/modules/conversations/conversation.service.js +61 -0
  150. package/apps/server/dist/modules/conversations/conversation.service.js.map +1 -0
  151. package/apps/server/dist/modules/conversations/dto/create-conversation.dto.d.ts +10 -0
  152. package/apps/server/dist/modules/conversations/dto/create-conversation.dto.js +64 -0
  153. package/apps/server/dist/modules/conversations/dto/create-conversation.dto.js.map +1 -0
  154. package/apps/server/dist/modules/conversations/enums/conversation.enum.d.ts +12 -0
  155. package/apps/server/dist/modules/conversations/enums/conversation.enum.js +18 -0
  156. package/apps/server/dist/modules/conversations/enums/conversation.enum.js.map +1 -0
  157. package/apps/server/dist/modules/fs/fs.controller.d.ts +6 -0
  158. package/apps/server/dist/modules/fs/fs.controller.js +85 -0
  159. package/apps/server/dist/modules/fs/fs.controller.js.map +1 -0
  160. package/apps/server/dist/modules/fs/fs.module.d.ts +2 -0
  161. package/apps/server/dist/modules/fs/fs.module.js +20 -0
  162. package/apps/server/dist/modules/fs/fs.module.js.map +1 -0
  163. package/apps/server/dist/modules/harness/dto/save-harness.dto.d.ts +4 -0
  164. package/apps/server/dist/modules/harness/dto/save-harness.dto.js +27 -0
  165. package/apps/server/dist/modules/harness/dto/save-harness.dto.js.map +1 -0
  166. package/apps/server/dist/modules/harness/harness.controller.d.ts +14 -0
  167. package/apps/server/dist/modules/harness/harness.controller.js +72 -0
  168. package/apps/server/dist/modules/harness/harness.controller.js.map +1 -0
  169. package/apps/server/dist/modules/harness/harness.module.d.ts +2 -0
  170. package/apps/server/dist/modules/harness/harness.module.js +23 -0
  171. package/apps/server/dist/modules/harness/harness.module.js.map +1 -0
  172. package/apps/server/dist/modules/harness/harness.service.d.ts +20 -0
  173. package/apps/server/dist/modules/harness/harness.service.js +134 -0
  174. package/apps/server/dist/modules/harness/harness.service.js.map +1 -0
  175. package/apps/server/dist/modules/sessions/session.controller.d.ts +12 -0
  176. package/apps/server/dist/modules/sessions/session.controller.js +79 -0
  177. package/apps/server/dist/modules/sessions/session.controller.js.map +1 -0
  178. package/apps/server/dist/modules/sessions/session.module.d.ts +2 -0
  179. package/apps/server/dist/modules/sessions/session.module.js +26 -0
  180. package/apps/server/dist/modules/sessions/session.module.js.map +1 -0
  181. package/apps/server/dist/modules/sessions/session.service.d.ts +9 -0
  182. package/apps/server/dist/modules/sessions/session.service.js +49 -0
  183. package/apps/server/dist/modules/sessions/session.service.js.map +1 -0
  184. package/apps/server/dist/modules/tasks/dto/create-task.dto.d.ts +15 -0
  185. package/apps/server/dist/modules/tasks/dto/create-task.dto.js +88 -0
  186. package/apps/server/dist/modules/tasks/dto/create-task.dto.js.map +1 -0
  187. package/apps/server/dist/modules/tasks/dto/execute-task.dto.d.ts +7 -0
  188. package/apps/server/dist/modules/tasks/dto/execute-task.dto.js +43 -0
  189. package/apps/server/dist/modules/tasks/dto/execute-task.dto.js.map +1 -0
  190. package/apps/server/dist/modules/tasks/dto/merge-file.dto.d.ts +3 -0
  191. package/apps/server/dist/modules/tasks/dto/merge-file.dto.js +23 -0
  192. package/apps/server/dist/modules/tasks/dto/merge-file.dto.js.map +1 -0
  193. package/apps/server/dist/modules/tasks/dto/rerun-task.dto.d.ts +4 -0
  194. package/apps/server/dist/modules/tasks/dto/rerun-task.dto.js +32 -0
  195. package/apps/server/dist/modules/tasks/dto/rerun-task.dto.js.map +1 -0
  196. package/apps/server/dist/modules/tasks/dto/update-task.dto.d.ts +15 -0
  197. package/apps/server/dist/modules/tasks/dto/update-task.dto.js +89 -0
  198. package/apps/server/dist/modules/tasks/dto/update-task.dto.js.map +1 -0
  199. package/apps/server/dist/modules/tasks/task-execution.service.d.ts +105 -0
  200. package/apps/server/dist/modules/tasks/task-execution.service.js +842 -0
  201. package/apps/server/dist/modules/tasks/task-execution.service.js.map +1 -0
  202. package/apps/server/dist/modules/tasks/task.gateway.d.ts +17 -0
  203. package/apps/server/dist/modules/tasks/task.gateway.js +126 -0
  204. package/apps/server/dist/modules/tasks/task.gateway.js.map +1 -0
  205. package/apps/server/dist/modules/tasks/tasks.controller.d.ts +29 -0
  206. package/apps/server/dist/modules/tasks/tasks.controller.js +209 -0
  207. package/apps/server/dist/modules/tasks/tasks.controller.js.map +1 -0
  208. package/apps/server/dist/modules/tasks/tasks.module.d.ts +2 -0
  209. package/apps/server/dist/modules/tasks/tasks.module.js +42 -0
  210. package/apps/server/dist/modules/tasks/tasks.module.js.map +1 -0
  211. package/apps/server/dist/modules/tasks/tasks.service.d.ts +47 -0
  212. package/apps/server/dist/modules/tasks/tasks.service.js +341 -0
  213. package/apps/server/dist/modules/tasks/tasks.service.js.map +1 -0
  214. package/apps/server/dist/tsconfig.build.tsbuildinfo +1 -0
  215. package/apps/web/.next/BUILD_ID +1 -0
  216. package/apps/web/.next/app-path-routes-manifest.json +12 -0
  217. package/apps/web/.next/build/chunks/[root-of-the-server]__0cstldc._.js +206 -0
  218. package/apps/web/.next/build/chunks/[root-of-the-server]__0cstldc._.js.map +8 -0
  219. package/apps/web/.next/build/chunks/[root-of-the-server]__0s3ts0r._.js +500 -0
  220. package/apps/web/.next/build/chunks/[root-of-the-server]__0s3ts0r._.js.map +11 -0
  221. package/apps/web/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_0xqnjlz._.js +13 -0
  222. package/apps/web/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_0xqnjlz._.js.map +5 -0
  223. package/apps/web/.next/build/chunks/[turbopack]_runtime.js +890 -0
  224. package/apps/web/.next/build/chunks/[turbopack]_runtime.js.map +11 -0
  225. package/apps/web/.next/build/chunks/node_modules_13sb.px._.js +6820 -0
  226. package/apps/web/.next/build/chunks/node_modules_13sb.px._.js.map +47 -0
  227. package/apps/web/.next/build/package.json +1 -0
  228. package/apps/web/.next/build/postcss.js +6 -0
  229. package/apps/web/.next/build/postcss.js.map +5 -0
  230. package/apps/web/.next/build-manifest.json +21 -0
  231. package/apps/web/.next/diagnostics/build-diagnostics.json +6 -0
  232. package/apps/web/.next/diagnostics/framework.json +1 -0
  233. package/apps/web/.next/diagnostics/route-bundle-stats.json +118 -0
  234. package/apps/web/.next/export-marker.json +6 -0
  235. package/apps/web/.next/fallback-build-manifest.json +13 -0
  236. package/apps/web/.next/images-manifest.json +68 -0
  237. package/apps/web/.next/next-minimal-server.js.nft.json +1 -0
  238. package/apps/web/.next/next-server.js.nft.json +1 -0
  239. package/apps/web/.next/package.json +1 -0
  240. package/apps/web/.next/prerender-manifest.json +234 -0
  241. package/apps/web/.next/required-server-files.js +332 -0
  242. package/apps/web/.next/required-server-files.json +332 -0
  243. package/apps/web/.next/routes-manifest.json +108 -0
  244. package/apps/web/.next/server/app/_global-error/page/app-paths-manifest.json +3 -0
  245. package/apps/web/.next/server/app/_global-error/page/build-manifest.json +17 -0
  246. package/apps/web/.next/server/app/_global-error/page/next-font-manifest.json +6 -0
  247. package/apps/web/.next/server/app/_global-error/page/react-loadable-manifest.json +1 -0
  248. package/apps/web/.next/server/app/_global-error/page/server-reference-manifest.json +4 -0
  249. package/apps/web/.next/server/app/_global-error/page.js +10 -0
  250. package/apps/web/.next/server/app/_global-error/page.js.map +5 -0
  251. package/apps/web/.next/server/app/_global-error/page.js.nft.json +1 -0
  252. package/apps/web/.next/server/app/_global-error/page_client-reference-manifest.js +3 -0
  253. package/apps/web/.next/server/app/_global-error.html +1 -0
  254. package/apps/web/.next/server/app/_global-error.meta +15 -0
  255. package/apps/web/.next/server/app/_global-error.rsc +15 -0
  256. package/apps/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +5 -0
  257. package/apps/web/.next/server/app/_global-error.segments/_full.segment.rsc +15 -0
  258. package/apps/web/.next/server/app/_global-error.segments/_head.segment.rsc +6 -0
  259. package/apps/web/.next/server/app/_global-error.segments/_index.segment.rsc +5 -0
  260. package/apps/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -0
  261. package/apps/web/.next/server/app/_not-found/page/app-paths-manifest.json +3 -0
  262. package/apps/web/.next/server/app/_not-found/page/build-manifest.json +17 -0
  263. package/apps/web/.next/server/app/_not-found/page/next-font-manifest.json +11 -0
  264. package/apps/web/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -0
  265. package/apps/web/.next/server/app/_not-found/page/server-reference-manifest.json +4 -0
  266. package/apps/web/.next/server/app/_not-found/page.js +13 -0
  267. package/apps/web/.next/server/app/_not-found/page.js.map +5 -0
  268. package/apps/web/.next/server/app/_not-found/page.js.nft.json +1 -0
  269. package/apps/web/.next/server/app/_not-found/page_client-reference-manifest.js +3 -0
  270. package/apps/web/.next/server/app/_not-found.html +1 -0
  271. package/apps/web/.next/server/app/_not-found.meta +16 -0
  272. package/apps/web/.next/server/app/_not-found.rsc +19 -0
  273. package/apps/web/.next/server/app/_not-found.segments/_full.segment.rsc +19 -0
  274. package/apps/web/.next/server/app/_not-found.segments/_head.segment.rsc +6 -0
  275. package/apps/web/.next/server/app/_not-found.segments/_index.segment.rsc +8 -0
  276. package/apps/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +5 -0
  277. package/apps/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +5 -0
  278. package/apps/web/.next/server/app/_not-found.segments/_tree.segment.rsc +3 -0
  279. package/apps/web/.next/server/app/claude/page/app-paths-manifest.json +3 -0
  280. package/apps/web/.next/server/app/claude/page/build-manifest.json +17 -0
  281. package/apps/web/.next/server/app/claude/page/next-font-manifest.json +11 -0
  282. package/apps/web/.next/server/app/claude/page/react-loadable-manifest.json +1 -0
  283. package/apps/web/.next/server/app/claude/page/server-reference-manifest.json +4 -0
  284. package/apps/web/.next/server/app/claude/page.js +14 -0
  285. package/apps/web/.next/server/app/claude/page.js.map +5 -0
  286. package/apps/web/.next/server/app/claude/page.js.nft.json +1 -0
  287. package/apps/web/.next/server/app/claude/page_client-reference-manifest.js +3 -0
  288. package/apps/web/.next/server/app/claude.html +1 -0
  289. package/apps/web/.next/server/app/claude.meta +15 -0
  290. package/apps/web/.next/server/app/claude.rsc +22 -0
  291. package/apps/web/.next/server/app/claude.segments/_full.segment.rsc +22 -0
  292. package/apps/web/.next/server/app/claude.segments/_head.segment.rsc +6 -0
  293. package/apps/web/.next/server/app/claude.segments/_index.segment.rsc +8 -0
  294. package/apps/web/.next/server/app/claude.segments/_tree.segment.rsc +5 -0
  295. package/apps/web/.next/server/app/claude.segments/claude/__PAGE__.segment.rsc +6 -0
  296. package/apps/web/.next/server/app/claude.segments/claude.segment.rsc +5 -0
  297. package/apps/web/.next/server/app/codex/page/app-paths-manifest.json +3 -0
  298. package/apps/web/.next/server/app/codex/page/build-manifest.json +17 -0
  299. package/apps/web/.next/server/app/codex/page/next-font-manifest.json +11 -0
  300. package/apps/web/.next/server/app/codex/page/react-loadable-manifest.json +1 -0
  301. package/apps/web/.next/server/app/codex/page/server-reference-manifest.json +4 -0
  302. package/apps/web/.next/server/app/codex/page.js +14 -0
  303. package/apps/web/.next/server/app/codex/page.js.map +5 -0
  304. package/apps/web/.next/server/app/codex/page.js.nft.json +1 -0
  305. package/apps/web/.next/server/app/codex/page_client-reference-manifest.js +3 -0
  306. package/apps/web/.next/server/app/codex.html +1 -0
  307. package/apps/web/.next/server/app/codex.meta +15 -0
  308. package/apps/web/.next/server/app/codex.rsc +25 -0
  309. package/apps/web/.next/server/app/codex.segments/_full.segment.rsc +25 -0
  310. package/apps/web/.next/server/app/codex.segments/_head.segment.rsc +6 -0
  311. package/apps/web/.next/server/app/codex.segments/_index.segment.rsc +8 -0
  312. package/apps/web/.next/server/app/codex.segments/_tree.segment.rsc +5 -0
  313. package/apps/web/.next/server/app/codex.segments/codex/__PAGE__.segment.rsc +9 -0
  314. package/apps/web/.next/server/app/codex.segments/codex.segment.rsc +5 -0
  315. package/apps/web/.next/server/app/favicon.ico/route/app-paths-manifest.json +3 -0
  316. package/apps/web/.next/server/app/favicon.ico/route/build-manifest.json +9 -0
  317. package/apps/web/.next/server/app/favicon.ico/route.js +6 -0
  318. package/apps/web/.next/server/app/favicon.ico/route.js.map +5 -0
  319. package/apps/web/.next/server/app/favicon.ico/route.js.nft.json +1 -0
  320. package/apps/web/.next/server/app/favicon.ico.meta +1 -0
  321. package/apps/web/.next/server/app/gemini/page/app-paths-manifest.json +3 -0
  322. package/apps/web/.next/server/app/gemini/page/build-manifest.json +17 -0
  323. package/apps/web/.next/server/app/gemini/page/next-font-manifest.json +11 -0
  324. package/apps/web/.next/server/app/gemini/page/react-loadable-manifest.json +1 -0
  325. package/apps/web/.next/server/app/gemini/page/server-reference-manifest.json +4 -0
  326. package/apps/web/.next/server/app/gemini/page.js +14 -0
  327. package/apps/web/.next/server/app/gemini/page.js.map +5 -0
  328. package/apps/web/.next/server/app/gemini/page.js.nft.json +1 -0
  329. package/apps/web/.next/server/app/gemini/page_client-reference-manifest.js +3 -0
  330. package/apps/web/.next/server/app/gemini.html +1 -0
  331. package/apps/web/.next/server/app/gemini.meta +15 -0
  332. package/apps/web/.next/server/app/gemini.rsc +25 -0
  333. package/apps/web/.next/server/app/gemini.segments/_full.segment.rsc +25 -0
  334. package/apps/web/.next/server/app/gemini.segments/_head.segment.rsc +6 -0
  335. package/apps/web/.next/server/app/gemini.segments/_index.segment.rsc +8 -0
  336. package/apps/web/.next/server/app/gemini.segments/_tree.segment.rsc +5 -0
  337. package/apps/web/.next/server/app/gemini.segments/gemini/__PAGE__.segment.rsc +9 -0
  338. package/apps/web/.next/server/app/gemini.segments/gemini.segment.rsc +5 -0
  339. package/apps/web/.next/server/app/index.html +1 -0
  340. package/apps/web/.next/server/app/index.meta +14 -0
  341. package/apps/web/.next/server/app/index.rsc +23 -0
  342. package/apps/web/.next/server/app/index.segments/__PAGE__.segment.rsc +9 -0
  343. package/apps/web/.next/server/app/index.segments/_full.segment.rsc +23 -0
  344. package/apps/web/.next/server/app/index.segments/_head.segment.rsc +6 -0
  345. package/apps/web/.next/server/app/index.segments/_index.segment.rsc +8 -0
  346. package/apps/web/.next/server/app/index.segments/_tree.segment.rsc +5 -0
  347. package/apps/web/.next/server/app/login/page/app-paths-manifest.json +3 -0
  348. package/apps/web/.next/server/app/login/page/build-manifest.json +17 -0
  349. package/apps/web/.next/server/app/login/page/next-font-manifest.json +11 -0
  350. package/apps/web/.next/server/app/login/page/react-loadable-manifest.json +1 -0
  351. package/apps/web/.next/server/app/login/page/server-reference-manifest.json +4 -0
  352. package/apps/web/.next/server/app/login/page.js +14 -0
  353. package/apps/web/.next/server/app/login/page.js.map +5 -0
  354. package/apps/web/.next/server/app/login/page.js.nft.json +1 -0
  355. package/apps/web/.next/server/app/login/page_client-reference-manifest.js +3 -0
  356. package/apps/web/.next/server/app/login.html +1 -0
  357. package/apps/web/.next/server/app/login.meta +15 -0
  358. package/apps/web/.next/server/app/login.rsc +25 -0
  359. package/apps/web/.next/server/app/login.segments/_full.segment.rsc +25 -0
  360. package/apps/web/.next/server/app/login.segments/_head.segment.rsc +6 -0
  361. package/apps/web/.next/server/app/login.segments/_index.segment.rsc +8 -0
  362. package/apps/web/.next/server/app/login.segments/_tree.segment.rsc +5 -0
  363. package/apps/web/.next/server/app/login.segments/login/__PAGE__.segment.rsc +9 -0
  364. package/apps/web/.next/server/app/login.segments/login.segment.rsc +5 -0
  365. package/apps/web/.next/server/app/page/app-paths-manifest.json +3 -0
  366. package/apps/web/.next/server/app/page/build-manifest.json +17 -0
  367. package/apps/web/.next/server/app/page/next-font-manifest.json +11 -0
  368. package/apps/web/.next/server/app/page/react-loadable-manifest.json +1 -0
  369. package/apps/web/.next/server/app/page/server-reference-manifest.json +4 -0
  370. package/apps/web/.next/server/app/page.js +14 -0
  371. package/apps/web/.next/server/app/page.js.map +5 -0
  372. package/apps/web/.next/server/app/page.js.nft.json +1 -0
  373. package/apps/web/.next/server/app/page_client-reference-manifest.js +3 -0
  374. package/apps/web/.next/server/app/task/[id]/page/app-paths-manifest.json +3 -0
  375. package/apps/web/.next/server/app/task/[id]/page/build-manifest.json +17 -0
  376. package/apps/web/.next/server/app/task/[id]/page/next-font-manifest.json +11 -0
  377. package/apps/web/.next/server/app/task/[id]/page/react-loadable-manifest.json +1 -0
  378. package/apps/web/.next/server/app/task/[id]/page/server-reference-manifest.json +4 -0
  379. package/apps/web/.next/server/app/task/[id]/page.js +14 -0
  380. package/apps/web/.next/server/app/task/[id]/page.js.map +5 -0
  381. package/apps/web/.next/server/app/task/[id]/page.js.nft.json +1 -0
  382. package/apps/web/.next/server/app/task/[id]/page_client-reference-manifest.js +3 -0
  383. package/apps/web/.next/server/app/test/page/app-paths-manifest.json +3 -0
  384. package/apps/web/.next/server/app/test/page/build-manifest.json +17 -0
  385. package/apps/web/.next/server/app/test/page/next-font-manifest.json +11 -0
  386. package/apps/web/.next/server/app/test/page/react-loadable-manifest.json +1 -0
  387. package/apps/web/.next/server/app/test/page/server-reference-manifest.json +4 -0
  388. package/apps/web/.next/server/app/test/page.js +14 -0
  389. package/apps/web/.next/server/app/test/page.js.map +5 -0
  390. package/apps/web/.next/server/app/test/page.js.nft.json +1 -0
  391. package/apps/web/.next/server/app/test/page_client-reference-manifest.js +3 -0
  392. package/apps/web/.next/server/app/test.html +1 -0
  393. package/apps/web/.next/server/app/test.meta +15 -0
  394. package/apps/web/.next/server/app/test.rsc +25 -0
  395. package/apps/web/.next/server/app/test.segments/_full.segment.rsc +25 -0
  396. package/apps/web/.next/server/app/test.segments/_head.segment.rsc +6 -0
  397. package/apps/web/.next/server/app/test.segments/_index.segment.rsc +8 -0
  398. package/apps/web/.next/server/app/test.segments/_tree.segment.rsc +5 -0
  399. package/apps/web/.next/server/app/test.segments/test/__PAGE__.segment.rsc +9 -0
  400. package/apps/web/.next/server/app/test.segments/test.segment.rsc +5 -0
  401. package/apps/web/.next/server/app-paths-manifest.json +12 -0
  402. package/apps/web/.next/server/chunks/[externals]_next_dist_0arv.vj._.js +3 -0
  403. package/apps/web/.next/server/chunks/[externals]_next_dist_0arv.vj._.js.map +1 -0
  404. package/apps/web/.next/server/chunks/[root-of-the-server]__0xjvedo._.js +13 -0
  405. package/apps/web/.next/server/chunks/[root-of-the-server]__0xjvedo._.js.map +1 -0
  406. package/apps/web/.next/server/chunks/[turbopack]_runtime.js +903 -0
  407. package/apps/web/.next/server/chunks/[turbopack]_runtime.js.map +11 -0
  408. package/apps/web/.next/server/chunks/apps_web__next-internal_server_app_favicon_ico_route_actions_0h5n1et.js +3 -0
  409. package/apps/web/.next/server/chunks/apps_web__next-internal_server_app_favicon_ico_route_actions_0h5n1et.js.map +1 -0
  410. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__00707zu._.js +3 -0
  411. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__00707zu._.js.map +1 -0
  412. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__02w1lqw._.js +33 -0
  413. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__02w1lqw._.js.map +1 -0
  414. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__058frv2._.js +3 -0
  415. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__058frv2._.js.map +1 -0
  416. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05mnfv7._.js +3 -0
  417. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05mnfv7._.js.map +1 -0
  418. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05w0js1._.js +3 -0
  419. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05w0js1._.js.map +1 -0
  420. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05y8~sf._.js +3 -0
  421. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05y8~sf._.js.map +1 -0
  422. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0a~4k2j._.js +8 -0
  423. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0a~4k2j._.js.map +1 -0
  424. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0bzgqz2._.js +3 -0
  425. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0bzgqz2._.js.map +1 -0
  426. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0csq2e.._.js +3 -0
  427. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0csq2e.._.js.map +1 -0
  428. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0dgn1-d._.js +8 -0
  429. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0dgn1-d._.js.map +1 -0
  430. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g.z8rw._.js +3 -0
  431. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g.z8rw._.js.map +1 -0
  432. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g7.yrd._.js +3 -0
  433. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g7.yrd._.js.map +1 -0
  434. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0ill7bp._.js +4 -0
  435. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0ill7bp._.js.map +1 -0
  436. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0lxs646._.js +33 -0
  437. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0lxs646._.js.map +1 -0
  438. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0osecwm._.js +3 -0
  439. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0osecwm._.js.map +1 -0
  440. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0x5.eah._.js +3 -0
  441. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0x5.eah._.js.map +1 -0
  442. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10mg911._.js +9 -0
  443. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10mg911._.js.map +1 -0
  444. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10xopfz._.js +3 -0
  445. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10xopfz._.js.map +1 -0
  446. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__11illgy._.js +3 -0
  447. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__11illgy._.js.map +1 -0
  448. package/apps/web/.next/server/chunks/ssr/[turbopack]_runtime.js +903 -0
  449. package/apps/web/.next/server/chunks/ssr/[turbopack]_runtime.js.map +11 -0
  450. package/apps/web/.next/server/chunks/ssr/_0hy8~s0._.js +6 -0
  451. package/apps/web/.next/server/chunks/ssr/_0hy8~s0._.js.map +1 -0
  452. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__global-error_page_actions_0.u5cfa.js +3 -0
  453. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__global-error_page_actions_0.u5cfa.js.map +1 -0
  454. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__not-found_page_actions_0appun9.js +3 -0
  455. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__not-found_page_actions_0appun9.js.map +1 -0
  456. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_claude_page_actions_0_uv-yn.js +3 -0
  457. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_claude_page_actions_0_uv-yn.js.map +1 -0
  458. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_codex_page_actions_0ace7zi.js +3 -0
  459. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_codex_page_actions_0ace7zi.js.map +1 -0
  460. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_gemini_page_actions_0ux-r~z.js +3 -0
  461. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_gemini_page_actions_0ux-r~z.js.map +1 -0
  462. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_login_page_actions_0srfp5v.js +3 -0
  463. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_login_page_actions_0srfp5v.js.map +1 -0
  464. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_page_actions_0rm5_5w.js +3 -0
  465. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_page_actions_0rm5_5w.js.map +1 -0
  466. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_task_[id]_page_actions_0bd_3_p.js +3 -0
  467. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_task_[id]_page_actions_0bd_3_p.js.map +1 -0
  468. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_test_page_actions_0pn8asm.js +3 -0
  469. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_test_page_actions_0pn8asm.js.map +1 -0
  470. package/apps/web/.next/server/chunks/ssr/apps_web_src_0s6cw51._.js +8 -0
  471. package/apps/web/.next/server/chunks/ssr/apps_web_src_0s6cw51._.js.map +1 -0
  472. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_login_page_tsx_07oskhj._.js +3 -0
  473. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_login_page_tsx_07oskhj._.js.map +1 -0
  474. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_page_tsx_0kq.zh9._.js +3 -0
  475. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_page_tsx_0kq.zh9._.js.map +1 -0
  476. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_test_page_tsx_04ji_kt._.js +3 -0
  477. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_test_page_tsx_04ji_kt._.js.map +1 -0
  478. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_02y94.o._.js +3 -0
  479. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_02y94.o._.js.map +1 -0
  480. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_0y6q6xu._.js +3 -0
  481. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_0y6q6xu._.js.map +1 -0
  482. package/apps/web/.next/server/chunks/ssr/node_modules_09w7yel._.js +33 -0
  483. package/apps/web/.next/server/chunks/ssr/node_modules_09w7yel._.js.map +1 -0
  484. package/apps/web/.next/server/chunks/ssr/node_modules_0ck2~9g._.js +3 -0
  485. package/apps/web/.next/server/chunks/ssr/node_modules_0ck2~9g._.js.map +1 -0
  486. package/apps/web/.next/server/chunks/ssr/node_modules_0i2xw~e._.js +3 -0
  487. package/apps/web/.next/server/chunks/ssr/node_modules_0i2xw~e._.js.map +1 -0
  488. package/apps/web/.next/server/chunks/ssr/node_modules_0vtdjw7._.js +3 -0
  489. package/apps/web/.next/server/chunks/ssr/node_modules_0vtdjw7._.js.map +1 -0
  490. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_03nkrli._.js +19 -0
  491. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_03nkrli._.js.map +1 -0
  492. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_0h9llsw._.js +6 -0
  493. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_0h9llsw._.js.map +1 -0
  494. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_0inhx6q._.js +3 -0
  495. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_0inhx6q._.js.map +1 -0
  496. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js +3 -0
  497. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js.map +1 -0
  498. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_global-error_0lgvd_..js +3 -0
  499. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_global-error_0lgvd_..js.map +1 -0
  500. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js +3 -0
  501. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js.map +1 -0
  502. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_01s3o34.js +4 -0
  503. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_01s3o34.js.map +1 -0
  504. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0ax1b3s.js +4 -0
  505. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0ax1b3s.js.map +1 -0
  506. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0gl78zj.js +4 -0
  507. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0gl78zj.js.map +1 -0
  508. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0j~tyzr.js +4 -0
  509. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0j~tyzr.js.map +1 -0
  510. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0khf96-.js +4 -0
  511. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0khf96-.js.map +1 -0
  512. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0qgz_85.js +4 -0
  513. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0qgz_85.js.map +1 -0
  514. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0unh3f-.js +4 -0
  515. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0unh3f-.js.map +1 -0
  516. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0uq606i.js +4 -0
  517. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0uq606i.js.map +1 -0
  518. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_128e6.l.js +4 -0
  519. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_128e6.l.js.map +1 -0
  520. package/apps/web/.next/server/functions-config-manifest.json +4 -0
  521. package/apps/web/.next/server/interception-route-rewrite-manifest.js +1 -0
  522. package/apps/web/.next/server/middleware-build-manifest.js +21 -0
  523. package/apps/web/.next/server/middleware-manifest.json +6 -0
  524. package/apps/web/.next/server/next-font-manifest.js +1 -0
  525. package/apps/web/.next/server/next-font-manifest.json +39 -0
  526. package/apps/web/.next/server/pages/404.html +1 -0
  527. package/apps/web/.next/server/pages/500.html +1 -0
  528. package/apps/web/.next/server/pages-manifest.json +4 -0
  529. package/apps/web/.next/server/prefetch-hints.json +1 -0
  530. package/apps/web/.next/server/server-reference-manifest.js +1 -0
  531. package/apps/web/.next/server/server-reference-manifest.json +5 -0
  532. package/apps/web/.next/static/chunks/01xlw8hd842-c.js +1 -0
  533. package/apps/web/.next/static/chunks/03~yq9q893hmn.js +1 -0
  534. package/apps/web/.next/static/chunks/04w-clkdzn_sn.js +6 -0
  535. package/apps/web/.next/static/chunks/066jf0nk75nic.css +2 -0
  536. package/apps/web/.next/static/chunks/0bmpc66o4m-9z.js +1 -0
  537. package/apps/web/.next/static/chunks/0cctfc2jrxq_0.js +1 -0
  538. package/apps/web/.next/static/chunks/0dk1ec~jpoxa3.css +1 -0
  539. package/apps/web/.next/static/chunks/0e992tq36rg-i.js +6 -0
  540. package/apps/web/.next/static/chunks/0ieuc6bs-l0iy.js +7 -0
  541. package/apps/web/.next/static/chunks/0nd5y.4d2gl8g.js +1 -0
  542. package/apps/web/.next/static/chunks/0o-t4yw-v8ahl.js +6 -0
  543. package/apps/web/.next/static/chunks/0pqt~8bl3ukh4.js +4 -0
  544. package/apps/web/.next/static/chunks/0rjn.~e6pvni1.js +2 -0
  545. package/apps/web/.next/static/chunks/0t2xr05rlu96l.js +1 -0
  546. package/apps/web/.next/static/chunks/0uuu-x.ka3jyt.js +1 -0
  547. package/apps/web/.next/static/chunks/0x15z029u118o.js +1 -0
  548. package/apps/web/.next/static/chunks/0~.kxojjn0k1x.js +1 -0
  549. package/apps/web/.next/static/chunks/10t1c-qsk.cdw.js +1 -0
  550. package/apps/web/.next/static/chunks/14zwv8duu059g.js +31 -0
  551. package/apps/web/.next/static/chunks/turbopack-0gpa2pyrgntw-.js +1 -0
  552. package/apps/web/.next/static/fdXuROcW6IkgkI61bg3UM/_buildManifest.js +11 -0
  553. package/apps/web/.next/static/fdXuROcW6IkgkI61bg3UM/_clientMiddlewareManifest.js +1 -0
  554. package/apps/web/.next/static/fdXuROcW6IkgkI61bg3UM/_ssgManifest.js +1 -0
  555. package/apps/web/.next/static/media/4fa387ec64143e14-s.0wkzw~je483f-.woff2 +0 -0
  556. package/apps/web/.next/static/media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2 +0 -0
  557. package/apps/web/.next/static/media/5ce348bf30bf5439-s.0zgw-jeven.3w.woff2 +0 -0
  558. package/apps/web/.next/static/media/6306c77e7c8268e4-s.0rhz0arwfsn~5.woff2 +0 -0
  559. package/apps/web/.next/static/media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2 +0 -0
  560. package/apps/web/.next/static/media/797e433ab948586e-s.p.08e28id.o-okb.woff2 +0 -0
  561. package/apps/web/.next/static/media/7d817b4c03b0c5f1-s.0l76wvqk9d84w.woff2 +0 -0
  562. package/apps/web/.next/static/media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2 +0 -0
  563. package/apps/web/.next/static/media/bbc41e54d2fcbd21-s.0k4k9394f2q-k.woff2 +0 -0
  564. package/apps/web/.next/static/media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2 +0 -0
  565. package/apps/web/.next/static/media/favicon.0x3dzn~oxb6tn.ico +0 -0
  566. package/apps/web/.next/static/media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2 +0 -0
  567. package/apps/web/.next/trace +1 -0
  568. package/apps/web/.next/trace-build +1 -0
  569. package/apps/web/.next/turbopack +0 -0
  570. package/apps/web/.next/types/cache-life.d.ts +145 -0
  571. package/apps/web/.next/types/routes.d.ts +63 -0
  572. package/apps/web/.next/types/validator.ts +115 -0
  573. package/package.json +28 -42
  574. package/packages/cli/dist/commands/init.d.ts +1 -2
  575. package/packages/cli/dist/commands/init.js +14 -16
  576. package/packages/cli/dist/commands/start.js +41 -26
  577. package/packages/cli/dist/index.js +6 -23
  578. package/packages/cli/dist/utils/package-root.d.ts +3 -0
  579. package/packages/cli/dist/utils/package-root.js +62 -0
  580. package/.gitignore +0 -23
  581. package/.npmignore +0 -21
  582. package/.prettierignore +0 -6
  583. package/.prettierrc +0 -26
  584. package/AGENTS.md +0 -10
  585. package/CLAUDE.md +0 -10
  586. package/apps/server/eslint.config.mjs +0 -20
  587. package/apps/server/nest-cli.json +0 -8
  588. package/apps/server/package.json +0 -89
  589. package/apps/server/scripts/postinstall.js +0 -53
  590. package/apps/server/src/__mocks__/glob.js +0 -6
  591. package/apps/server/src/__mocks__/uuid.js +0 -5
  592. package/apps/server/src/app.controller.spec.ts +0 -24
  593. package/apps/server/src/app.controller.ts +0 -13
  594. package/apps/server/src/app.module.ts +0 -18
  595. package/apps/server/src/app.service.ts +0 -8
  596. package/apps/server/src/common/ji-paths.ts +0 -41
  597. package/apps/server/src/database/database.module.ts +0 -27
  598. package/apps/server/src/database/entities/agent-changelog.entity.ts +0 -39
  599. package/apps/server/src/database/entities/agent-session.entity.ts +0 -29
  600. package/apps/server/src/database/entities/conversation.entity.ts +0 -41
  601. package/apps/server/src/database/entities/session.entity.ts +0 -16
  602. package/apps/server/src/database/entities/task-agent-run.entity.ts +0 -40
  603. package/apps/server/src/database/entities/task-agent.entity.ts +0 -42
  604. package/apps/server/src/database/entities/task-requirement.entity.ts +0 -27
  605. package/apps/server/src/database/entities/task-run.entity.ts +0 -41
  606. package/apps/server/src/database/entities/task.entity.ts +0 -44
  607. package/apps/server/src/main.ts +0 -65
  608. package/apps/server/src/modules/agents/agent-model-settings.spec.ts +0 -80
  609. package/apps/server/src/modules/agents/agents.module.ts +0 -11
  610. package/apps/server/src/modules/agents/claude/claude-auth.manager.ts +0 -83
  611. package/apps/server/src/modules/agents/claude/claude-pty.manager.ts +0 -380
  612. package/apps/server/src/modules/agents/claude/claude.controller.ts +0 -85
  613. package/apps/server/src/modules/agents/claude/claude.gateway.ts +0 -158
  614. package/apps/server/src/modules/agents/claude/claude.module.ts +0 -18
  615. package/apps/server/src/modules/agents/claude/claude.service.ts +0 -67
  616. package/apps/server/src/modules/agents/claude/dto/create-session.dto.ts +0 -24
  617. package/apps/server/src/modules/agents/claude/dto/resize-session.dto.ts +0 -13
  618. package/apps/server/src/modules/agents/claude/dto/send-input.dto.ts +0 -9
  619. package/apps/server/src/modules/agents/claude/interfaces/claude-session.interface.ts +0 -26
  620. package/apps/server/src/modules/agents/claude/interfaces/pty-event.interface.ts +0 -10
  621. package/apps/server/src/modules/agents/claude/interfaces/stream-event.interface.ts +0 -61
  622. package/apps/server/src/modules/agents/codex/codex-auth.manager.ts +0 -107
  623. package/apps/server/src/modules/agents/codex/codex-session.manager.ts +0 -357
  624. package/apps/server/src/modules/agents/codex/codex.controller.ts +0 -64
  625. package/apps/server/src/modules/agents/codex/codex.gateway.ts +0 -97
  626. package/apps/server/src/modules/agents/codex/codex.module.ts +0 -17
  627. package/apps/server/src/modules/agents/codex/dto/configure-auth.dto.ts +0 -7
  628. package/apps/server/src/modules/agents/gemini/dto/configure-auth.dto.ts +0 -15
  629. package/apps/server/src/modules/agents/gemini/dto/create-session.dto.ts +0 -9
  630. package/apps/server/src/modules/agents/gemini/dto/send-input.dto.ts +0 -9
  631. package/apps/server/src/modules/agents/gemini/gemini-auth.manager.ts +0 -157
  632. package/apps/server/src/modules/agents/gemini/gemini-session.manager.ts +0 -287
  633. package/apps/server/src/modules/agents/gemini/gemini.controller.ts +0 -93
  634. package/apps/server/src/modules/agents/gemini/gemini.gateway.ts +0 -149
  635. package/apps/server/src/modules/agents/gemini/gemini.module.ts +0 -17
  636. package/apps/server/src/modules/agents/gemini/interfaces/gemini-session.interface.ts +0 -18
  637. package/apps/server/src/modules/agents/gemini/interfaces/stream-event.interface.ts +0 -14
  638. package/apps/server/src/modules/agents/session-termination.spec.ts +0 -103
  639. package/apps/server/src/modules/changelog/changelog.controller.ts +0 -20
  640. package/apps/server/src/modules/changelog/changelog.module.ts +0 -14
  641. package/apps/server/src/modules/changelog/changelog.service.spec.ts +0 -531
  642. package/apps/server/src/modules/changelog/changelog.service.ts +0 -690
  643. package/apps/server/src/modules/conversations/conversation.controller.spec.ts +0 -106
  644. package/apps/server/src/modules/conversations/conversation.controller.ts +0 -60
  645. package/apps/server/src/modules/conversations/conversation.module.ts +0 -14
  646. package/apps/server/src/modules/conversations/conversation.service.spec.ts +0 -176
  647. package/apps/server/src/modules/conversations/conversation.service.ts +0 -54
  648. package/apps/server/src/modules/conversations/dto/create-conversation.dto.ts +0 -37
  649. package/apps/server/src/modules/conversations/enums/conversation.enum.ts +0 -13
  650. package/apps/server/src/modules/fs/fs.controller.ts +0 -29
  651. package/apps/server/src/modules/fs/fs.module.ts +0 -8
  652. package/apps/server/src/modules/harness/dto/save-harness.dto.ts +0 -9
  653. package/apps/server/src/modules/harness/harness.controller.spec.ts +0 -95
  654. package/apps/server/src/modules/harness/harness.controller.ts +0 -35
  655. package/apps/server/src/modules/harness/harness.module.ts +0 -11
  656. package/apps/server/src/modules/harness/harness.service.spec.ts +0 -217
  657. package/apps/server/src/modules/harness/harness.service.ts +0 -112
  658. package/apps/server/src/modules/sessions/session.controller.spec.ts +0 -68
  659. package/apps/server/src/modules/sessions/session.controller.ts +0 -43
  660. package/apps/server/src/modules/sessions/session.module.ts +0 -14
  661. package/apps/server/src/modules/sessions/session.service.spec.ts +0 -106
  662. package/apps/server/src/modules/sessions/session.service.ts +0 -35
  663. package/apps/server/src/modules/tasks/dto/create-task.dto.ts +0 -54
  664. package/apps/server/src/modules/tasks/dto/execute-task.dto.ts +0 -22
  665. package/apps/server/src/modules/tasks/dto/merge-file.dto.ts +0 -7
  666. package/apps/server/src/modules/tasks/dto/rerun-task.dto.ts +0 -14
  667. package/apps/server/src/modules/tasks/dto/update-task.dto.ts +0 -55
  668. package/apps/server/src/modules/tasks/task-execution.service.ts +0 -978
  669. package/apps/server/src/modules/tasks/task.gateway.ts +0 -140
  670. package/apps/server/src/modules/tasks/tasks.controller.spec.ts +0 -210
  671. package/apps/server/src/modules/tasks/tasks.controller.ts +0 -139
  672. package/apps/server/src/modules/tasks/tasks.module.ts +0 -30
  673. package/apps/server/src/modules/tasks/tasks.service.spec.ts +0 -552
  674. package/apps/server/src/modules/tasks/tasks.service.ts +0 -333
  675. package/apps/server/test/app.e2e-spec.ts +0 -28
  676. package/apps/server/test/jest-e2e.json +0 -9
  677. package/apps/server/tsconfig.build.json +0 -4
  678. package/apps/server/tsconfig.json +0 -13
  679. package/apps/web/AGENTS.md +0 -7
  680. package/apps/web/CLAUDE.md +0 -1
  681. package/apps/web/eslint.config.mjs +0 -21
  682. package/apps/web/next-env.d.ts +0 -6
  683. package/apps/web/postcss.config.mjs +0 -7
  684. package/apps/web/src/app/claude/page.tsx +0 -5
  685. package/apps/web/src/app/codex/page.tsx +0 -126
  686. package/apps/web/src/app/gemini/page.tsx +0 -130
  687. package/apps/web/src/app/globals.css +0 -149
  688. package/apps/web/src/app/layout.tsx +0 -40
  689. package/apps/web/src/app/login/page.tsx +0 -67
  690. package/apps/web/src/app/page.tsx +0 -497
  691. package/apps/web/src/app/task/[id]/page.tsx +0 -11
  692. package/apps/web/src/app/test/page.tsx +0 -298
  693. package/apps/web/src/components/ui/Modal.tsx +0 -78
  694. package/apps/web/src/components/ui/WorkingDirPicker.tsx +0 -195
  695. package/apps/web/src/components/ui/__tests__/Modal.test.tsx +0 -68
  696. package/apps/web/src/features/auth/api/__tests__/auth.api.test.ts +0 -83
  697. package/apps/web/src/features/auth/api/auth.api.ts +0 -81
  698. package/apps/web/src/features/auth/hooks/__tests__/useClaudeAuth.test.ts +0 -166
  699. package/apps/web/src/features/auth/hooks/__tests__/useCodexAuth.test.ts +0 -127
  700. package/apps/web/src/features/auth/hooks/__tests__/useGeminiAuth.test.ts +0 -120
  701. package/apps/web/src/features/auth/hooks/useClaudeAuth.ts +0 -88
  702. package/apps/web/src/features/auth/hooks/useCodexAuth.ts +0 -149
  703. package/apps/web/src/features/auth/hooks/useGeminiAuth.ts +0 -125
  704. package/apps/web/src/features/auth/ui/CodexLoginPanel.tsx +0 -302
  705. package/apps/web/src/features/auth/ui/GeminiLoginPanel.tsx +0 -316
  706. package/apps/web/src/features/auth/ui/LoginForm.tsx +0 -190
  707. package/apps/web/src/features/auth/ui/LoginPanel.tsx +0 -114
  708. package/apps/web/src/features/auth/ui/__tests__/LoginPanel.test.tsx +0 -105
  709. package/apps/web/src/features/chat/api/__tests__/sessions.api.test.ts +0 -187
  710. package/apps/web/src/features/chat/api/sessions.api.ts +0 -161
  711. package/apps/web/src/features/chat/container/ClaudePageContainer.tsx +0 -152
  712. package/apps/web/src/features/chat/hooks/__tests__/useCodexSessions.test.ts +0 -131
  713. package/apps/web/src/features/chat/hooks/__tests__/useGeminiSessions.test.ts +0 -130
  714. package/apps/web/src/features/chat/hooks/useAgentModelSettings.ts +0 -54
  715. package/apps/web/src/features/chat/hooks/useClaudeSessions.ts +0 -323
  716. package/apps/web/src/features/chat/hooks/useCodexSessions.ts +0 -275
  717. package/apps/web/src/features/chat/hooks/useGeminiSessions.ts +0 -255
  718. package/apps/web/src/features/chat/hooks/useSessionCommand.ts +0 -66
  719. package/apps/web/src/features/chat/hooks/useSessionRename.ts +0 -61
  720. package/apps/web/src/features/chat/hooks/useSessionWorkingDirectories.ts +0 -34
  721. package/apps/web/src/features/chat/hooks/useUnifiedSessions.ts +0 -156
  722. package/apps/web/src/features/chat/lib/agentModelOptions.ts +0 -72
  723. package/apps/web/src/features/chat/ui/AgentModelPicker.tsx +0 -134
  724. package/apps/web/src/features/chat/ui/AgentSelectModal.tsx +0 -236
  725. package/apps/web/src/features/chat/ui/ChatInput.tsx +0 -162
  726. package/apps/web/src/features/chat/ui/ChatMessage.tsx +0 -204
  727. package/apps/web/src/features/chat/ui/ChatWorkspace.tsx +0 -207
  728. package/apps/web/src/features/chat/ui/CheckingSkeleton.tsx +0 -44
  729. package/apps/web/src/features/chat/ui/ClaudeLoginView.tsx +0 -44
  730. package/apps/web/src/features/chat/ui/PermissionCard.tsx +0 -37
  731. package/apps/web/src/features/chat/ui/SessionSidebar.tsx +0 -280
  732. package/apps/web/src/features/chat/ui/__tests__/AgentSelectModal.test.tsx +0 -58
  733. package/apps/web/src/features/chat/ui/__tests__/ChatInput.test.tsx +0 -134
  734. package/apps/web/src/features/chat/ui/__tests__/ChatMessage.test.tsx +0 -106
  735. package/apps/web/src/features/chat/ui/__tests__/ChatWorkspace.test.tsx +0 -66
  736. package/apps/web/src/features/diff/ui/DiffFileRow.tsx +0 -73
  737. package/apps/web/src/features/diff/ui/DiffHunk.tsx +0 -61
  738. package/apps/web/src/features/diff/ui/FileChangeBadge.tsx +0 -23
  739. package/apps/web/src/features/diff/ui/__tests__/DiffFileRow.test.tsx +0 -40
  740. package/apps/web/src/features/diff/ui/__tests__/DiffHunk.test.tsx +0 -24
  741. package/apps/web/src/features/diff/ui/__tests__/FileChangeBadge.test.tsx +0 -16
  742. package/apps/web/src/features/fs/api/fs.api.ts +0 -14
  743. package/apps/web/src/features/fs/hooks/useDirBrowser.ts +0 -50
  744. package/apps/web/src/features/harness/api/__tests__/harness.api.test.ts +0 -73
  745. package/apps/web/src/features/harness/api/harness.api.ts +0 -46
  746. package/apps/web/src/features/harness/hooks/__tests__/useHarness.test.ts +0 -65
  747. package/apps/web/src/features/harness/hooks/useHarness.ts +0 -66
  748. package/apps/web/src/features/harness/ui/HarnessModal.tsx +0 -171
  749. package/apps/web/src/features/harness/ui/__tests__/HarnessModal.test.tsx +0 -46
  750. package/apps/web/src/features/status/ui/AgentStatusModal.tsx +0 -267
  751. package/apps/web/src/features/status/ui/__tests__/AgentStatusModal.test.tsx +0 -71
  752. package/apps/web/src/features/tasks/api/__tests__/changelog.api.test.ts +0 -89
  753. package/apps/web/src/features/tasks/api/__tests__/tasks.api.test.ts +0 -282
  754. package/apps/web/src/features/tasks/api/changelog.api.ts +0 -52
  755. package/apps/web/src/features/tasks/api/tasks.api.ts +0 -175
  756. package/apps/web/src/features/tasks/container/TaskDetailPageContainer.tsx +0 -69
  757. package/apps/web/src/features/tasks/hooks/__tests__/useChangelogCodeCopy.test.ts +0 -48
  758. package/apps/web/src/features/tasks/hooks/__tests__/useTaskChangelog.test.ts +0 -48
  759. package/apps/web/src/features/tasks/hooks/__tests__/useTaskCreate.test.ts +0 -217
  760. package/apps/web/src/features/tasks/hooks/__tests__/useTaskEdit.test.ts +0 -152
  761. package/apps/web/src/features/tasks/hooks/__tests__/useTaskExecution.test.ts +0 -143
  762. package/apps/web/src/features/tasks/hooks/__tests__/useTaskList.test.ts +0 -168
  763. package/apps/web/src/features/tasks/hooks/__tests__/useTaskNotification.test.ts +0 -125
  764. package/apps/web/src/features/tasks/hooks/__tests__/useTaskRuns.test.ts +0 -51
  765. package/apps/web/src/features/tasks/hooks/useChangelogCodeCopy.ts +0 -52
  766. package/apps/web/src/features/tasks/hooks/useCopyToClipboard.ts +0 -47
  767. package/apps/web/src/features/tasks/hooks/useTaskChangelog.ts +0 -32
  768. package/apps/web/src/features/tasks/hooks/useTaskCreate.ts +0 -137
  769. package/apps/web/src/features/tasks/hooks/useTaskDetail.ts +0 -217
  770. package/apps/web/src/features/tasks/hooks/useTaskEdit.ts +0 -130
  771. package/apps/web/src/features/tasks/hooks/useTaskExecution.ts +0 -137
  772. package/apps/web/src/features/tasks/hooks/useTaskList.ts +0 -159
  773. package/apps/web/src/features/tasks/hooks/useTaskNotification.ts +0 -80
  774. package/apps/web/src/features/tasks/hooks/useTaskRuns.ts +0 -32
  775. package/apps/web/src/features/tasks/ui/AgentOutputPanel.tsx +0 -203
  776. package/apps/web/src/features/tasks/ui/AgentRoleSelect.tsx +0 -97
  777. package/apps/web/src/features/tasks/ui/ChangelogPanel.tsx +0 -321
  778. package/apps/web/src/features/tasks/ui/RunHistoryPanel.tsx +0 -193
  779. package/apps/web/src/features/tasks/ui/TaskCreateModal.tsx +0 -205
  780. package/apps/web/src/features/tasks/ui/TaskDetailView.tsx +0 -413
  781. package/apps/web/src/features/tasks/ui/TaskEditModal.tsx +0 -165
  782. package/apps/web/src/features/tasks/ui/TaskListModal.tsx +0 -591
  783. package/apps/web/src/features/tasks/ui/__tests__/AgentRoleSelect.test.tsx +0 -91
  784. package/apps/web/src/features/tasks/ui/__tests__/ChangelogPanel.test.tsx +0 -94
  785. package/apps/web/src/features/tasks/ui/__tests__/RunHistoryPanel.test.tsx +0 -71
  786. package/apps/web/src/features/tasks/ui/__tests__/TaskCreateModal.test.tsx +0 -153
  787. package/apps/web/src/features/tasks/ui/__tests__/TaskEditModal.test.tsx +0 -75
  788. package/apps/web/src/features/tasks/ui/__tests__/TaskListModal.test.tsx +0 -243
  789. package/apps/web/src/hooks/useWorkingDir.ts +0 -28
  790. package/apps/web/src/lib/__tests__/ansi.test.ts +0 -88
  791. package/apps/web/src/lib/ansi.ts +0 -105
  792. package/apps/web/src/lib/constants.ts +0 -4
  793. package/apps/web/src/lib/quota.ts +0 -22
  794. package/apps/web/src/lib/theme.tsx +0 -78
  795. package/apps/web/src/lib/toast.tsx +0 -175
  796. package/apps/web/src/store/agentStatusStore.ts +0 -38
  797. package/apps/web/tsconfig.json +0 -18
  798. package/apps/web/vitest.config.ts +0 -25
  799. package/apps/web/vitest.setup.ts +0 -10
  800. package/packages/cli/dist/utils/project-init.d.ts +0 -12
  801. package/packages/cli/dist/utils/project-init.js +0 -258
  802. package/packages/cli/package.json +0 -30
  803. package/packages/cli/src/commands/check.ts +0 -77
  804. package/packages/cli/src/commands/init.ts +0 -209
  805. package/packages/cli/src/commands/start.ts +0 -183
  806. package/packages/cli/src/index.ts +0 -91
  807. package/packages/cli/src/utils/agent-tools.ts +0 -201
  808. package/packages/cli/src/utils/project-init.ts +0 -252
  809. package/packages/cli/src/utils/proxy.ts +0 -123
  810. package/packages/cli/tsconfig.json +0 -14
  811. package/packages/eslint-config/base.mjs +0 -31
  812. package/packages/eslint-config/nest.mjs +0 -55
  813. package/packages/eslint-config/next.mjs +0 -23
  814. package/packages/eslint-config/package.json +0 -20
  815. package/packages/typescript-config/base.json +0 -16
  816. package/packages/typescript-config/nestjs.json +0 -17
  817. package/packages/typescript-config/nextjs.json +0 -15
  818. package/packages/typescript-config/package.json +0 -11
  819. package/turbo.json +0 -28
  820. /package/apps/web/{src/app/favicon.ico → .next/server/app/favicon.ico.body} +0 -0
@@ -1,131 +0,0 @@
1
- import { act, renderHook, waitFor } from "@testing-library/react";
2
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
3
-
4
- import * as sessionsApi from "../../api/sessions.api";
5
- import { useCodexSessions } from "../useCodexSessions";
6
-
7
- vi.mock("../../api/sessions.api", () => ({
8
- createCodexSession: vi.fn(),
9
- deleteCodexSession: vi.fn(),
10
- fetchConversations: vi.fn(),
11
- fetchDBSessions: vi.fn(),
12
- saveCodexConversation: vi.fn(),
13
- }));
14
-
15
- const socketMock = vi.hoisted(() => {
16
- const handlers: Record<string, (payload?: unknown) => void> = {};
17
- const socket = {
18
- on: vi.fn((event: string, handler: (payload?: unknown) => void) => {
19
- handlers[event] = handler;
20
- return socket;
21
- }),
22
- emit: vi.fn(),
23
- disconnect: vi.fn(),
24
- };
25
- return {
26
- handlers,
27
- socket,
28
- io: vi.fn(() => socket),
29
- reset() {
30
- for (const key of Object.keys(handlers)) delete handlers[key];
31
- socket.on.mockClear();
32
- socket.emit.mockClear();
33
- socket.disconnect.mockClear();
34
- this.io.mockClear();
35
- },
36
- };
37
- });
38
-
39
- vi.mock("socket.io-client", () => ({ io: socketMock.io }));
40
-
41
- const mockFetchDB = vi.mocked(sessionsApi.fetchDBSessions);
42
- const mockFetchConversations = vi.mocked(sessionsApi.fetchConversations);
43
- const mockCreateSession = vi.mocked(sessionsApi.createCodexSession);
44
- const mockDeleteSession = vi.mocked(sessionsApi.deleteCodexSession);
45
- const mockSave = vi.mocked(sessionsApi.saveCodexConversation);
46
-
47
- beforeEach(() => {
48
- mockFetchDB.mockResolvedValue([{ sessionId: "db-1", title: "DB", createdAt: "2024-01-01" }]);
49
- mockFetchConversations.mockResolvedValue([
50
- { id: "c1", sessionId: "db-1", promptId: "p1", type: "agent_message", content: "codex", createdAt: "2024-01-01", agentModel: "codex" },
51
- { id: "c2", sessionId: "db-1", promptId: "p2", type: "agent_message", content: "gemini", createdAt: "2024-01-01", agentModel: "gemini" },
52
- ]);
53
- mockCreateSession.mockResolvedValue({ id: "old-1", title: "Codex", createdAt: "2024-01-02", workingDirectory: "/tmp/codex" });
54
- });
55
-
56
- afterEach(() => {
57
- vi.clearAllMocks();
58
- socketMock.reset();
59
- });
60
-
61
- describe("useCodexSessions", () => {
62
- it("connects and loads DB sessions", async () => {
63
- const { result } = renderHook(() => useCodexSessions());
64
- act(() => { socketMock.handlers.connect?.(); });
65
-
66
- await waitFor(() => expect(result.current.connectionStatus).toBe("connected"));
67
- await waitFor(() => expect(result.current.sessions[0].agentId).toBe("codex"));
68
- });
69
-
70
- it("creates, sends, saves on result, and supports session replacement", async () => {
71
- const { result } = renderHook(() => useCodexSessions());
72
-
73
- await act(async () => { await result.current.createSession("/tmp/codex"); });
74
- expect(result.current.selectedSessionId).toBe("old-1");
75
-
76
- act(() => { result.current.sendMessage("old-1", "hello"); });
77
- expect(socketMock.socket.emit).toHaveBeenCalledWith("session:message", { sessionId: "old-1", input: "hello" });
78
- expect(mockSave).not.toHaveBeenCalled();
79
-
80
- act(() => {
81
- socketMock.handlers["session:text"]?.({ sessionId: "old-1", text: "answer" });
82
- socketMock.handlers["session:replaced"]?.({ oldSessionId: "old-1", newSessionId: "new-1" });
83
- socketMock.handlers["session:result"]?.({ sessionId: "new-1", isError: false });
84
- });
85
-
86
- expect(result.current.selectedSessionId).toBe("new-1");
87
- expect(mockSave).toHaveBeenCalledWith("new-1", expect.any(String), "hello", "user_message");
88
- expect(mockSave).toHaveBeenCalledWith("new-1", expect.any(String), "answer", "agent_message");
89
- });
90
-
91
- it("loads codex conversations and terminates selected session", async () => {
92
- const { result } = renderHook(() => useCodexSessions());
93
- act(() => { socketMock.handlers.connect?.(); });
94
- await waitFor(() => expect(result.current.sessions).toHaveLength(1));
95
-
96
- act(() => { result.current.selectSession("db-1"); });
97
- await waitFor(() => expect(mockFetchConversations).toHaveBeenCalledWith("db-1"));
98
- await waitFor(() => expect(result.current.selectedSession?.messages).toHaveLength(1));
99
-
100
- await act(async () => { await result.current.terminateSession("db-1"); });
101
- expect(mockDeleteSession).toHaveBeenCalledWith("db-1");
102
- expect(result.current.selectedSessionId).toBeNull();
103
- });
104
-
105
- it("keeps the session visible when terminate fails", async () => {
106
- mockDeleteSession.mockRejectedValueOnce(new Error("delete failed"));
107
- const { result } = renderHook(() => useCodexSessions());
108
- act(() => { socketMock.handlers.connect?.(); });
109
- await waitFor(() => expect(result.current.sessions).toHaveLength(1));
110
-
111
- await act(async () => { await result.current.terminateSession("db-1"); });
112
-
113
- expect(result.current.sessions).toHaveLength(1);
114
- expect(result.current.error).toBe("delete failed");
115
- });
116
-
117
- it("handles exit, disconnect, and socket errors", async () => {
118
- const { result } = renderHook(() => useCodexSessions());
119
- await act(async () => { await result.current.createSession(); });
120
- act(() => {
121
- socketMock.handlers["session:text"]?.({ sessionId: "old-1", text: "partial" });
122
- socketMock.handlers["session:exit"]?.({ sessionId: "old-1" });
123
- socketMock.handlers.disconnect?.();
124
- socketMock.handlers.error?.({ message: "socket failed" });
125
- });
126
-
127
- expect(result.current.selectedSession?.streaming).toBe("");
128
- expect(result.current.connectionStatus).toBe("disconnected");
129
- expect(result.current.error).toBe("socket failed");
130
- });
131
- });
@@ -1,130 +0,0 @@
1
- import { act, renderHook, waitFor } from "@testing-library/react";
2
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
3
-
4
- import * as sessionsApi from "../../api/sessions.api";
5
- import { useGeminiSessions } from "../useGeminiSessions";
6
-
7
- vi.mock("../../api/sessions.api", () => ({
8
- createGeminiSession: vi.fn(),
9
- deleteGeminiSession: vi.fn(),
10
- fetchConversations: vi.fn(),
11
- fetchDBSessions: vi.fn(),
12
- saveGeminiConversation: vi.fn(),
13
- }));
14
-
15
- const socketMock = vi.hoisted(() => {
16
- const handlers: Record<string, (payload?: unknown) => void> = {};
17
- const socket = {
18
- on: vi.fn((event: string, handler: (payload?: unknown) => void) => {
19
- handlers[event] = handler;
20
- return socket;
21
- }),
22
- emit: vi.fn(),
23
- disconnect: vi.fn(),
24
- };
25
- return {
26
- handlers,
27
- socket,
28
- io: vi.fn(() => socket),
29
- reset() {
30
- for (const key of Object.keys(handlers)) delete handlers[key];
31
- socket.on.mockClear();
32
- socket.emit.mockClear();
33
- socket.disconnect.mockClear();
34
- this.io.mockClear();
35
- },
36
- };
37
- });
38
-
39
- vi.mock("socket.io-client", () => ({ io: socketMock.io }));
40
-
41
- const mockFetchDB = vi.mocked(sessionsApi.fetchDBSessions);
42
- const mockFetchConversations = vi.mocked(sessionsApi.fetchConversations);
43
- const mockCreateSession = vi.mocked(sessionsApi.createGeminiSession);
44
- const mockDeleteSession = vi.mocked(sessionsApi.deleteGeminiSession);
45
- const mockSave = vi.mocked(sessionsApi.saveGeminiConversation);
46
-
47
- beforeEach(() => {
48
- mockFetchDB.mockResolvedValue([{ sessionId: "db-1", title: "DB", createdAt: "2024-01-01" }]);
49
- mockFetchConversations.mockResolvedValue([
50
- { id: "c1", sessionId: "db-1", promptId: "p1", type: "user_message", content: "hi", createdAt: "2024-01-01", agentModel: "gemini" },
51
- { id: "c2", sessionId: "db-1", promptId: "p2", type: "agent_message", content: "other", createdAt: "2024-01-01", agentModel: "codex" },
52
- ]);
53
- mockCreateSession.mockResolvedValue({ id: "new-1", title: "Gemini", createdAt: "2024-01-02", workingDirectory: "/tmp/project" });
54
- });
55
-
56
- afterEach(() => {
57
- vi.clearAllMocks();
58
- socketMock.reset();
59
- });
60
-
61
- describe("useGeminiSessions", () => {
62
- it("connects and loads DB sessions", async () => {
63
- const { result } = renderHook(() => useGeminiSessions());
64
-
65
- expect(result.current.connectionStatus).toBe("connecting");
66
- act(() => { socketMock.handlers.connect?.(); });
67
-
68
- await waitFor(() => expect(result.current.connectionStatus).toBe("connected"));
69
- await waitFor(() => expect(result.current.sessions[0].info.id).toBe("db-1"));
70
- });
71
-
72
- it("creates, selects, sends, streams, and finishes a session", async () => {
73
- const { result } = renderHook(() => useGeminiSessions());
74
-
75
- let id: string | null = null;
76
- await act(async () => { id = await result.current.createSession("/tmp/project"); });
77
- expect(id).toBe("new-1");
78
- expect(result.current.selectedSession?.info.title).toBe("project");
79
-
80
- act(() => { result.current.sendMessage("new-1", "hello"); });
81
- expect(socketMock.socket.emit).toHaveBeenCalledWith("session:message", { sessionId: "new-1", input: "hello" });
82
- expect(result.current.selectedSession?.messages[0].content).toBe("hello");
83
-
84
- act(() => {
85
- socketMock.handlers["session:text"]?.({ sessionId: "new-1", text: "answer" });
86
- socketMock.handlers["session:result"]?.({ sessionId: "new-1", isError: false });
87
- });
88
-
89
- expect(mockSave).toHaveBeenCalled();
90
- expect(result.current.selectedSession?.messages.at(-1)?.content).toBe("answer");
91
- expect(result.current.selectedSession?.isWaiting).toBe(false);
92
- });
93
-
94
- it("loads conversations when selecting a DB session and terminates it", async () => {
95
- const { result } = renderHook(() => useGeminiSessions());
96
- act(() => { socketMock.handlers.connect?.(); });
97
- await waitFor(() => expect(result.current.sessions).toHaveLength(1));
98
-
99
- act(() => { result.current.selectSession("db-1"); });
100
- await waitFor(() => expect(mockFetchConversations).toHaveBeenCalledWith("db-1"));
101
- await waitFor(() => expect(result.current.selectedSession?.messages).toHaveLength(1));
102
-
103
- await act(async () => { await result.current.terminateSession("db-1"); });
104
- expect(mockDeleteSession).toHaveBeenCalledWith("db-1");
105
- expect(result.current.sessions).toEqual([]);
106
- });
107
-
108
- it("keeps the session visible when terminate fails", async () => {
109
- mockDeleteSession.mockRejectedValueOnce(new Error("delete failed"));
110
- const { result } = renderHook(() => useGeminiSessions());
111
- act(() => { socketMock.handlers.connect?.(); });
112
- await waitFor(() => expect(result.current.sessions).toHaveLength(1));
113
-
114
- await act(async () => { await result.current.terminateSession("db-1"); });
115
-
116
- expect(result.current.sessions).toHaveLength(1);
117
- expect(result.current.error).toBe("delete failed");
118
- });
119
-
120
- it("sets errors from socket and create failures", async () => {
121
- mockCreateSession.mockRejectedValueOnce(new Error("create failed"));
122
- const { result } = renderHook(() => useGeminiSessions());
123
-
124
- await act(async () => { await result.current.createSession(); });
125
- expect(result.current.error).toBe("create failed");
126
-
127
- act(() => { socketMock.handlers.error?.({ message: "socket failed" }); });
128
- expect(result.current.error).toBe("socket failed");
129
- });
130
- });
@@ -1,54 +0,0 @@
1
- "use client";
2
-
3
- import { useCallback, useEffect, useState } from "react";
4
-
5
- import type { AgentId } from "../ui/AgentSelectModal";
6
- import type { AgentModelSettings, AgentModelSettingsByAgent } from "../lib/agentModelOptions";
7
-
8
- const STORAGE_KEY = "ji.agentModelSettings";
9
-
10
- const DEFAULT_SETTINGS: AgentModelSettingsByAgent = {
11
- claude: { model: "default", reasoning: "default" },
12
- codex: { model: "default", reasoning: "default" },
13
- };
14
-
15
- function readStoredSettings(): AgentModelSettingsByAgent {
16
- try {
17
- const raw = window.localStorage.getItem(STORAGE_KEY);
18
- if (!raw) return DEFAULT_SETTINGS;
19
- const parsed = JSON.parse(raw) as AgentModelSettingsByAgent;
20
- return { ...DEFAULT_SETTINGS, ...parsed };
21
- } catch {
22
- return DEFAULT_SETTINGS;
23
- }
24
- }
25
-
26
- export function useAgentModelSettings() {
27
- const [settingsByAgent, setSettingsByAgent] =
28
- useState<AgentModelSettingsByAgent>(DEFAULT_SETTINGS);
29
- const [hydrated, setHydrated] = useState(false);
30
-
31
- useEffect(() => {
32
- setSettingsByAgent(readStoredSettings());
33
- setHydrated(true);
34
- }, []);
35
-
36
- useEffect(() => {
37
- if (!hydrated) return;
38
- try {
39
- window.localStorage.setItem(STORAGE_KEY, JSON.stringify(settingsByAgent));
40
- } catch {}
41
- }, [hydrated, settingsByAgent]);
42
-
43
- const updateSettings = useCallback((agentId: AgentId, settings: AgentModelSettings) => {
44
- setSettingsByAgent((prev) => ({
45
- ...prev,
46
- [agentId]: {
47
- ...(prev[agentId] ?? {}),
48
- ...settings,
49
- },
50
- }));
51
- }, []);
52
-
53
- return { settingsByAgent, updateSettings };
54
- }
@@ -1,323 +0,0 @@
1
- "use client";
2
-
3
- import { useCallback, useEffect, useRef, useState } from "react";
4
- import { io, type Socket } from "socket.io-client";
5
-
6
- import { CLAUDE_WS_NAMESPACE, SERVER_URL } from "@/lib/constants";
7
- import {
8
- createSession as apiCreateSession,
9
- deleteSession,
10
- fetchConversations,
11
- fetchDBSessions,
12
- saveConversation,
13
- updateSessionTitle,
14
- } from "../api/sessions.api";
15
- import type { DBConversation, SessionInfo } from "../api/sessions.api";
16
- import type { AgentModelSettings } from "../lib/agentModelOptions";
17
- import type { AgentId } from "../ui/AgentSelectModal";
18
-
19
- // ─── 타입 ────────────────────────────────────────────────────────────────────
20
-
21
- export type ConnectionStatus = "disconnected" | "connecting" | "connected";
22
- export type MessageRole = "user" | "assistant" | "permission" | "system";
23
-
24
- export interface ToolUseBlock {
25
- tool: string;
26
- input: Record<string, unknown>;
27
- }
28
-
29
- export interface ResultMeta {
30
- result: string;
31
- isError: boolean;
32
- durationMs: number;
33
- costUsd: number;
34
- }
35
-
36
- export interface ChatMessage {
37
- id: string;
38
- role: MessageRole;
39
- content: string;
40
- toolUses?: ToolUseBlock[];
41
- meta?: ResultMeta;
42
- createdAt: Date;
43
- }
44
-
45
- export interface SessionState {
46
- info: SessionInfo;
47
- messages: ChatMessage[];
48
- streaming: string;
49
- isWaiting: boolean;
50
- messagesLoaded: boolean;
51
- agentId: AgentId;
52
- }
53
-
54
- export type { AgentId };
55
-
56
- export { SessionInfo };
57
-
58
- // ─── 헬퍼 ────────────────────────────────────────────────────────────────────
59
-
60
- let msgId = 0;
61
- const nextId = () => String(++msgId);
62
-
63
- function toMessages(convos: DBConversation[]): ChatMessage[] {
64
- return convos.map((c) => ({
65
- id: c.id,
66
- role: c.type === "user_message" ? "user" : "assistant",
67
- content: c.content,
68
- createdAt: new Date(c.createdAt),
69
- }));
70
- }
71
-
72
- // ─── Hook ────────────────────────────────────────────────────────────────────
73
-
74
- export function useClaudeSessions() {
75
- const socketRef = useRef<Socket | null>(null);
76
- const [connectionStatus, setConnectionStatus] = useState<ConnectionStatus>("disconnected");
77
- const [sessions, setSessions] = useState<SessionState[]>([]);
78
- const [selectedSessionId, setSelectedSessionId] = useState<string | null>(null);
79
- const [error, setError] = useState<string | null>(null);
80
-
81
- const streamingRef = useRef<Record<string, string>>({});
82
- const pendingToolsRef = useRef<Record<string, ToolUseBlock[]>>({});
83
- const pendingPromptIdRef = useRef<Record<string, string>>({});
84
- const loadingSessionsRef = useRef<Set<string>>(new Set());
85
-
86
- // ─── DB 세션 로드 ──────────────────────────────────────────────────────────
87
-
88
- const loadSessionsFromDB = useCallback(async () => {
89
- try {
90
- const dbSessions = await fetchDBSessions('claude');
91
- setSessions((prev) => {
92
- const existingIds = new Set(prev.map((s) => s.info.id));
93
- const newStates: SessionState[] = dbSessions
94
- .filter((s) => !existingIds.has(s.sessionId))
95
- .map((s) => ({
96
- info: { id: s.sessionId, title: !s.title || s.title === "server" ? "Claude" : s.title, createdAt: s.createdAt },
97
- messages: [],
98
- streaming: "",
99
- isWaiting: false,
100
- messagesLoaded: false,
101
- agentId: "claude" as AgentId,
102
- }));
103
- return [...prev, ...newStates].sort(
104
- (a, b) => new Date(b.info.createdAt).getTime() - new Date(a.info.createdAt).getTime(),
105
- );
106
- });
107
- } catch {}
108
- }, []);
109
-
110
- // ─── 대화 기록 로드 ────────────────────────────────────────────────────────
111
-
112
- const loadConversations = useCallback(async (sessionId: string) => {
113
- if (loadingSessionsRef.current.has(sessionId)) return;
114
- loadingSessionsRef.current.add(sessionId);
115
- try {
116
- const convos = await fetchConversations(sessionId);
117
- setSessions((prev) =>
118
- prev.map((s) =>
119
- s.info.id === sessionId ? { ...s, messages: toMessages(convos), messagesLoaded: true } : s,
120
- ),
121
- );
122
- } catch {
123
- setSessions((prev) =>
124
- prev.map((s) => (s.info.id === sessionId ? { ...s, messagesLoaded: true } : s)),
125
- );
126
- }
127
- }, []);
128
-
129
- // ─── WebSocket ─────────────────────────────────────────────────────────────
130
-
131
- useEffect(() => {
132
- const socket = io(`${SERVER_URL}${CLAUDE_WS_NAMESPACE}`, { transports: ["websocket"] });
133
- socketRef.current = socket;
134
- setConnectionStatus("connecting");
135
-
136
- socket.on("connect", () => {
137
- setConnectionStatus("connected");
138
- void loadSessionsFromDB();
139
- });
140
-
141
- socket.on("disconnect", () => setConnectionStatus("disconnected"));
142
-
143
- socket.on("session:text", ({ sessionId, text }: { sessionId: string; text: string }) => {
144
- streamingRef.current[sessionId] = (streamingRef.current[sessionId] ?? "") + text;
145
- const accumulated = streamingRef.current[sessionId];
146
- setSessions((prev) =>
147
- prev.map((s) =>
148
- s.info.id === sessionId ? { ...s, streaming: accumulated, isWaiting: true } : s,
149
- ),
150
- );
151
- });
152
-
153
- socket.on(
154
- "session:tool",
155
- ({ sessionId, tool, input }: { sessionId: string; tool: string; input: Record<string, unknown> }) => {
156
- if (!pendingToolsRef.current[sessionId]) pendingToolsRef.current[sessionId] = [];
157
- pendingToolsRef.current[sessionId].push({ tool, input });
158
- },
159
- );
160
-
161
- socket.on(
162
- "session:result",
163
- ({ sessionId, result, isError, durationMs, costUsd }: { sessionId: string } & ResultMeta) => {
164
- const content = (streamingRef.current[sessionId] ?? "").trim();
165
- const toolUses = pendingToolsRef.current[sessionId] ?? [];
166
- streamingRef.current[sessionId] = "";
167
- pendingToolsRef.current[sessionId] = [];
168
-
169
- const promptId = pendingPromptIdRef.current[sessionId];
170
- if (promptId && content) {
171
- saveConversation(sessionId, promptId, content, "agent_message");
172
- delete pendingPromptIdRef.current[sessionId];
173
- }
174
-
175
- setSessions((prev) =>
176
- prev.map((s) => {
177
- if (s.info.id !== sessionId) return s;
178
- const newMessages = [...s.messages];
179
- if (content || toolUses.length > 0) {
180
- newMessages.push({
181
- id: nextId(),
182
- role: "assistant",
183
- content,
184
- toolUses: toolUses.length > 0 ? toolUses : undefined,
185
- meta: { result, isError, durationMs, costUsd },
186
- createdAt: new Date(),
187
- });
188
- }
189
- return { ...s, messages: newMessages, streaming: "", isWaiting: false };
190
- }),
191
- );
192
- },
193
- );
194
-
195
- socket.on("session:exit", ({ sessionId }: { sessionId: string }) => {
196
- streamingRef.current[sessionId] = "";
197
- pendingToolsRef.current[sessionId] = [];
198
- setSessions((prev) =>
199
- prev.map((s) => (s.info.id === sessionId ? { ...s, streaming: "", isWaiting: false } : s)),
200
- );
201
- });
202
-
203
- socket.on("error", ({ message }: { message: string }) => setError(message));
204
-
205
- return () => { socket.disconnect(); };
206
- }, [loadSessionsFromDB]);
207
-
208
- // ─── 세션 선택 시 대화 기록 로드 ─────────────────────────────────────────
209
-
210
- useEffect(() => {
211
- if (!selectedSessionId) return;
212
- const session = sessions.find((s) => s.info.id === selectedSessionId);
213
- if (!session || session.messagesLoaded) return;
214
- void loadConversations(selectedSessionId);
215
- }, [selectedSessionId, sessions, loadConversations]);
216
-
217
- // ─── 공개 API ─────────────────────────────────────────────────────────────
218
-
219
- const renameSession = useCallback((sessionId: string, newTitle: string) => {
220
- setSessions((prev) =>
221
- prev.map((s) =>
222
- s.info.id === sessionId ? { ...s, info: { ...s.info, title: newTitle } } : s,
223
- ),
224
- );
225
- void updateSessionTitle(sessionId, newTitle).catch(() => undefined);
226
- }, []);
227
-
228
- const createSession = useCallback(async (
229
- agentId: AgentId,
230
- workingDirectory?: string,
231
- modelSettings?: AgentModelSettings,
232
- ): Promise<string | null> => {
233
- setError(null);
234
- try {
235
- const raw = await apiCreateSession({ workingDirectory, ...modelSettings });
236
- const title = raw.workingDirectory
237
- ? raw.workingDirectory.replace(/[/\\]+$/, "").split(/[/\\]/).filter(Boolean).at(-1) ?? "Claude"
238
- : "Claude";
239
-
240
- const newState: SessionState = {
241
- info: { ...raw, title },
242
- messages: [],
243
- streaming: "",
244
- isWaiting: false,
245
- messagesLoaded: true,
246
- agentId,
247
- };
248
-
249
- setSessions((prev) => [newState, ...prev]);
250
- setSelectedSessionId(raw.id);
251
- return raw.id;
252
- } catch (e) {
253
- setError(e instanceof Error ? e.message : "세션 생성 실패");
254
- return null;
255
- }
256
- }, []);
257
-
258
- const sendMessage = useCallback((sessionId: string, text: string, modelSettings?: AgentModelSettings) => {
259
- const promptId = crypto.randomUUID();
260
- pendingPromptIdRef.current[sessionId] = promptId;
261
-
262
- setSessions((prev) =>
263
- prev.map((s) =>
264
- s.info.id === sessionId
265
- ? {
266
- ...s,
267
- messages: [
268
- ...s.messages,
269
- { id: nextId(), role: "user", content: text, createdAt: new Date() },
270
- ],
271
- isWaiting: true,
272
- }
273
- : s,
274
- ),
275
- );
276
-
277
- saveConversation(sessionId, promptId, text, "user_message");
278
- socketRef.current?.emit("session:message", {
279
- sessionId,
280
- input: text,
281
- ...modelSettings,
282
- });
283
- }, []);
284
-
285
- const terminateSession = useCallback(async (sessionId: string) => {
286
- try {
287
- await deleteSession(sessionId);
288
- setSessions((prev) => prev.filter((s) => s.info.id !== sessionId));
289
- setSelectedSessionId((prev) => (prev === sessionId ? null : prev));
290
- } catch (err) {
291
- setError(err instanceof Error ? err.message : "세션 삭제 실패");
292
- }
293
- }, []);
294
-
295
- const injectMessage = useCallback(
296
- (sessionId: string, message: Omit<ChatMessage, "id" | "createdAt">) => {
297
- setSessions((prev) =>
298
- prev.map((s) =>
299
- s.info.id === sessionId
300
- ? { ...s, messages: [...s.messages, { ...message, id: nextId(), createdAt: new Date() }] }
301
- : s,
302
- ),
303
- );
304
- },
305
- [],
306
- );
307
-
308
- const selectedSession = sessions.find((s) => s.info.id === selectedSessionId) ?? null;
309
-
310
- return {
311
- connectionStatus,
312
- sessions,
313
- selectedSession,
314
- selectedSessionId,
315
- error,
316
- createSession,
317
- selectSession: setSelectedSessionId,
318
- sendMessage,
319
- terminateSession,
320
- injectMessage,
321
- renameSession,
322
- };
323
- }