vibepulse 0.1.12 → 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 (547) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/app-path-routes-manifest.json +8 -0
  3. package/.next/build-manifest.json +2 -2
  4. package/.next/cache/.previewinfo +1 -1
  5. package/.next/cache/.rscinfo +1 -1
  6. package/.next/cache/.tsbuildinfo +1 -1
  7. package/.next/cache/config.json +3 -3
  8. package/.next/fallback-build-manifest.json +2 -2
  9. package/.next/prerender-manifest.json +3 -3
  10. package/.next/routes-manifest.json +56 -0
  11. package/.next/server/app/_global-error/page.js +1 -1
  12. package/.next/server/app/_global-error/page.js.nft.json +1 -1
  13. package/.next/server/app/_global-error.html +2 -2
  14. package/.next/server/app/_global-error.rsc +1 -1
  15. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  16. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  17. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  18. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  19. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  20. package/.next/server/app/_not-found/page.js +1 -1
  21. package/.next/server/app/_not-found/page.js.nft.json +1 -1
  22. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  23. package/.next/server/app/_not-found.html +1 -1
  24. package/.next/server/app/_not-found.rsc +2 -2
  25. package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  26. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  27. package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  28. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  29. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  30. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  31. package/.next/server/app/api/node/events/route/app-paths-manifest.json +3 -0
  32. package/.next/server/app/api/node/events/route/build-manifest.json +11 -0
  33. package/.next/server/app/api/node/events/route/server-reference-manifest.json +4 -0
  34. package/.next/server/app/api/node/events/route.js +7 -0
  35. package/.next/server/app/api/node/events/route.js.map +5 -0
  36. package/.next/server/app/api/node/events/route.js.nft.json +1 -0
  37. package/.next/server/app/api/node/events/route_client-reference-manifest.js +2 -0
  38. package/.next/server/app/api/node/health/route/app-paths-manifest.json +3 -0
  39. package/.next/server/app/api/node/health/route/build-manifest.json +11 -0
  40. package/.next/server/app/api/node/health/route/server-reference-manifest.json +4 -0
  41. package/.next/server/app/api/node/health/route.js +6 -0
  42. package/.next/server/app/api/node/health/route.js.map +5 -0
  43. package/.next/server/app/api/node/health/route.js.nft.json +1 -0
  44. package/.next/server/app/api/node/health/route_client-reference-manifest.js +2 -0
  45. package/.next/server/app/api/node/sessions/[id]/archive/route/app-paths-manifest.json +3 -0
  46. package/.next/server/app/api/node/sessions/[id]/archive/route/build-manifest.json +11 -0
  47. package/.next/server/app/api/node/sessions/[id]/archive/route/server-reference-manifest.json +4 -0
  48. package/.next/server/app/api/node/sessions/[id]/archive/route.js +6 -0
  49. package/.next/server/app/api/node/sessions/[id]/archive/route.js.map +5 -0
  50. package/.next/server/app/api/node/sessions/[id]/archive/route.js.nft.json +1 -0
  51. package/.next/server/app/api/node/sessions/[id]/archive/route_client-reference-manifest.js +2 -0
  52. package/.next/server/app/api/node/sessions/[id]/delete/route/app-paths-manifest.json +3 -0
  53. package/.next/server/app/api/node/sessions/[id]/delete/route/build-manifest.json +11 -0
  54. package/.next/server/app/api/node/sessions/[id]/delete/route/server-reference-manifest.json +4 -0
  55. package/.next/server/app/api/node/sessions/[id]/delete/route.js +7 -0
  56. package/.next/server/app/api/node/sessions/[id]/delete/route.js.map +5 -0
  57. package/.next/server/app/api/node/sessions/[id]/delete/route.js.nft.json +1 -0
  58. package/.next/server/app/api/node/sessions/[id]/delete/route_client-reference-manifest.js +2 -0
  59. package/.next/server/app/api/node/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  60. package/.next/server/app/api/node/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  61. package/.next/server/app/api/node/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  62. package/.next/server/app/api/node/sessions/[id]/open-editor/route.js +7 -0
  63. package/.next/server/app/api/node/sessions/[id]/open-editor/route.js.map +5 -0
  64. package/.next/server/app/api/node/sessions/[id]/open-editor/route.js.nft.json +1 -0
  65. package/.next/server/app/api/node/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  66. package/.next/server/app/api/node/sessions/route/app-paths-manifest.json +3 -0
  67. package/.next/server/app/api/node/sessions/route/build-manifest.json +11 -0
  68. package/.next/server/app/api/node/sessions/route/server-reference-manifest.json +4 -0
  69. package/.next/server/app/api/node/sessions/route.js +9 -0
  70. package/.next/server/app/api/node/sessions/route.js.map +5 -0
  71. package/.next/server/app/api/node/sessions/route.js.nft.json +1 -0
  72. package/.next/server/app/api/node/sessions/route_client-reference-manifest.js +2 -0
  73. package/.next/server/app/api/nodes/route/app-paths-manifest.json +3 -0
  74. package/.next/server/app/api/nodes/route/build-manifest.json +11 -0
  75. package/.next/server/app/api/nodes/route/server-reference-manifest.json +4 -0
  76. package/.next/server/app/api/nodes/route.js +8 -0
  77. package/.next/server/app/api/nodes/route.js.map +5 -0
  78. package/.next/server/app/api/nodes/route.js.nft.json +1 -0
  79. package/.next/server/app/api/nodes/route_client-reference-manifest.js +2 -0
  80. package/.next/server/app/api/opencode-config/route.js +1 -1
  81. package/.next/server/app/api/opencode-config/route.js.nft.json +1 -1
  82. package/.next/server/app/api/opencode-config/status/route.js +1 -1
  83. package/.next/server/app/api/opencode-config/status/route.js.nft.json +1 -1
  84. package/.next/server/app/api/opencode-events/route.js +4 -2
  85. package/.next/server/app/api/opencode-events/route.js.nft.json +1 -1
  86. package/.next/server/app/api/profiles/[id]/apply/route.js +1 -1
  87. package/.next/server/app/api/profiles/[id]/apply/route.js.nft.json +1 -1
  88. package/.next/server/app/api/profiles/[id]/export/route.js +2 -2
  89. package/.next/server/app/api/profiles/[id]/export/route.js.nft.json +1 -1
  90. package/.next/server/app/api/profiles/[id]/route.js +2 -2
  91. package/.next/server/app/api/profiles/[id]/route.js.nft.json +1 -1
  92. package/.next/server/app/api/profiles/import/route.js +2 -2
  93. package/.next/server/app/api/profiles/import/route.js.nft.json +1 -1
  94. package/.next/server/app/api/profiles/route.js +2 -2
  95. package/.next/server/app/api/profiles/route.js.nft.json +1 -1
  96. package/.next/server/app/api/sessions/[id]/archive/route.js +2 -1
  97. package/.next/server/app/api/sessions/[id]/archive/route.js.nft.json +1 -1
  98. package/.next/server/app/api/sessions/[id]/delete/route.js +3 -2
  99. package/.next/server/app/api/sessions/[id]/delete/route.js.nft.json +1 -1
  100. package/.next/server/app/api/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  101. package/.next/server/app/api/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  102. package/.next/server/app/api/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  103. package/.next/server/app/api/sessions/[id]/open-editor/route.js +7 -0
  104. package/.next/server/app/api/sessions/[id]/open-editor/route.js.map +5 -0
  105. package/.next/server/app/api/sessions/[id]/open-editor/route.js.nft.json +1 -0
  106. package/.next/server/app/api/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  107. package/.next/server/app/api/sessions/[id]/route.js +1 -1
  108. package/.next/server/app/api/sessions/[id]/route.js.nft.json +1 -1
  109. package/.next/server/app/api/sessions/route.js +3 -3
  110. package/.next/server/app/api/sessions/route.js.nft.json +1 -1
  111. package/.next/server/app/favicon.ico/route.js +1 -1
  112. package/.next/server/app/favicon.ico/route.js.nft.json +1 -1
  113. package/.next/server/app/index.html +1 -1
  114. package/.next/server/app/index.rsc +3 -3
  115. package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  116. package/.next/server/app/index.segments/_full.segment.rsc +3 -3
  117. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  118. package/.next/server/app/index.segments/_index.segment.rsc +2 -2
  119. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  120. package/.next/server/app/page.js +1 -1
  121. package/.next/server/app/page.js.nft.json +1 -1
  122. package/.next/server/app/page_client-reference-manifest.js +1 -1
  123. package/.next/server/app-paths-manifest.json +8 -0
  124. package/.next/server/chunks/{[root-of-the-server]__172a07b6._.js → [externals]_next_dist_84e7390b._.js} +2 -2
  125. package/.next/server/chunks/[root-of-the-server]__1211da38._.js +3 -0
  126. package/.next/server/chunks/[root-of-the-server]__1211da38._.js.map +1 -0
  127. package/.next/server/chunks/[root-of-the-server]__192ed2f4._.js +3 -0
  128. package/.next/server/chunks/[root-of-the-server]__192ed2f4._.js.map +1 -0
  129. package/.next/server/chunks/[root-of-the-server]__1b87ec42._.js +3 -0
  130. package/.next/server/chunks/[root-of-the-server]__1b87ec42._.js.map +1 -0
  131. package/.next/server/chunks/[root-of-the-server]__2b526e7a._.js +3 -0
  132. package/.next/server/chunks/[root-of-the-server]__2b526e7a._.js.map +1 -0
  133. package/.next/server/chunks/[root-of-the-server]__2f981540._.js +3 -0
  134. package/.next/server/chunks/[root-of-the-server]__2f981540._.js.map +1 -0
  135. package/.next/server/chunks/[root-of-the-server]__3745b314._.js +3 -0
  136. package/.next/server/chunks/[root-of-the-server]__3745b314._.js.map +1 -0
  137. package/.next/server/chunks/[root-of-the-server]__56690af0._.js +3 -0
  138. package/.next/server/chunks/[root-of-the-server]__56690af0._.js.map +1 -0
  139. package/.next/server/chunks/[root-of-the-server]__56f5f249._.js +3 -0
  140. package/.next/server/chunks/[root-of-the-server]__56f5f249._.js.map +1 -0
  141. package/.next/server/chunks/[root-of-the-server]__59175de4._.js +3 -0
  142. package/.next/server/chunks/[root-of-the-server]__59175de4._.js.map +1 -0
  143. package/.next/server/chunks/[root-of-the-server]__64fffc02._.js +3 -0
  144. package/.next/server/chunks/[root-of-the-server]__64fffc02._.js.map +1 -0
  145. package/.next/server/chunks/[root-of-the-server]__6c428a24._.js +3 -0
  146. package/.next/server/chunks/[root-of-the-server]__6c428a24._.js.map +1 -0
  147. package/.next/server/chunks/[root-of-the-server]__73a00b88._.js +3 -0
  148. package/.next/server/chunks/[root-of-the-server]__73a00b88._.js.map +1 -0
  149. package/.next/server/chunks/[root-of-the-server]__7e757f50._.js +3 -0
  150. package/.next/server/chunks/[root-of-the-server]__7e757f50._.js.map +1 -0
  151. package/.next/server/chunks/[root-of-the-server]__89c5eeab._.js +3 -0
  152. package/.next/server/chunks/[root-of-the-server]__89c5eeab._.js.map +1 -0
  153. package/.next/server/chunks/[root-of-the-server]__8da6c5a8._.js +3 -0
  154. package/.next/server/chunks/[root-of-the-server]__8da6c5a8._.js.map +1 -0
  155. package/.next/server/chunks/[root-of-the-server]__b796d06c._.js +3 -0
  156. package/.next/server/chunks/[root-of-the-server]__b796d06c._.js.map +1 -0
  157. package/.next/server/chunks/[root-of-the-server]__c2ce5c0f._.js +3 -0
  158. package/.next/server/chunks/[root-of-the-server]__c2ce5c0f._.js.map +1 -0
  159. package/.next/server/chunks/[root-of-the-server]__d8e61048._.js +3 -0
  160. package/.next/server/chunks/[root-of-the-server]__d8e61048._.js.map +1 -0
  161. package/.next/server/chunks/[root-of-the-server]__db285678._.js +3 -0
  162. package/.next/server/chunks/[root-of-the-server]__db285678._.js.map +1 -0
  163. package/.next/server/chunks/[root-of-the-server]__e00a9200._.js +5 -0
  164. package/.next/server/chunks/[root-of-the-server]__e00a9200._.js.map +1 -0
  165. package/.next/server/chunks/[root-of-the-server]__e5df5e5f._.js +3 -0
  166. package/.next/server/chunks/[root-of-the-server]__e5df5e5f._.js.map +1 -0
  167. package/.next/server/chunks/_next-internal_server_app_api_node_events_route_actions_f1abd32d.js +3 -0
  168. package/.next/server/chunks/_next-internal_server_app_api_node_events_route_actions_f1abd32d.js.map +1 -0
  169. package/.next/server/chunks/_next-internal_server_app_api_node_health_route_actions_c4c4c077.js +3 -0
  170. package/.next/server/chunks/_next-internal_server_app_api_node_health_route_actions_c4c4c077.js.map +1 -0
  171. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_archive_route_actions_237255a5.js +3 -0
  172. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_archive_route_actions_237255a5.js.map +1 -0
  173. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_delete_route_actions_e5d426f6.js +3 -0
  174. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_delete_route_actions_e5d426f6.js.map +1 -0
  175. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_route_actions_6b564c5a.js +3 -0
  176. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_route_actions_6b564c5a.js.map +1 -0
  177. package/.next/server/chunks/_next-internal_server_app_api_nodes_route_actions_3e496ee8.js +3 -0
  178. package/.next/server/chunks/_next-internal_server_app_api_nodes_route_actions_3e496ee8.js.map +1 -0
  179. package/.next/server/chunks/_next-internal_server_app_api_sessions_[id]_open-editor_route_actions_eaebf476.js +3 -0
  180. package/.next/server/chunks/_next-internal_server_app_api_sessions_[id]_open-editor_route_actions_eaebf476.js.map +1 -0
  181. package/.next/server/chunks/ce889_server_app_api_node_sessions_[id]_open-editor_route_actions_791cdf5b.js +3 -0
  182. package/.next/server/chunks/ce889_server_app_api_node_sessions_[id]_open-editor_route_actions_791cdf5b.js.map +1 -0
  183. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_7e181e75.js +1 -1
  184. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_7e181e75.js.map +1 -1
  185. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_aca45402.js +3 -0
  186. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_aca45402.js.map +1 -0
  187. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_b054aff3.js +1 -1
  188. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_b054aff3.js.map +1 -1
  189. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_fa835ac3.js +5 -0
  190. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_fa835ac3.js.map +1 -0
  191. package/.next/{standalone/.next/server/chunks/ssr/[root-of-the-server]__39eef6a5._.js → server/chunks/ssr/[root-of-the-server]__631e12d0._.js} +2 -2
  192. package/.next/{standalone/.next/server/chunks/ssr/[root-of-the-server]__535a2208._.js → server/chunks/ssr/[root-of-the-server]__a8cd3911._.js} +2 -2
  193. package/.next/server/chunks/ssr/src_app_page_tsx_a7111f3e._.js +3 -3
  194. package/.next/server/chunks/ssr/src_app_page_tsx_a7111f3e._.js.map +1 -1
  195. package/.next/server/pages/404.html +1 -1
  196. package/.next/server/pages/500.html +2 -2
  197. package/.next/server/server-reference-manifest.js +1 -1
  198. package/.next/server/server-reference-manifest.json +1 -1
  199. package/.next/standalone/.next/BUILD_ID +1 -1
  200. package/.next/standalone/.next/app-path-routes-manifest.json +8 -0
  201. package/.next/standalone/.next/build-manifest.json +2 -2
  202. package/.next/standalone/.next/prerender-manifest.json +3 -3
  203. package/.next/standalone/.next/routes-manifest.json +56 -0
  204. package/.next/standalone/.next/server/app/_global-error/page.js +1 -1
  205. package/.next/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
  206. package/.next/standalone/.next/server/app/_global-error.html +2 -2
  207. package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
  208. package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  209. package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  210. package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  211. package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  212. package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  213. package/.next/standalone/.next/server/app/_not-found/page.js +1 -1
  214. package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
  215. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  216. package/.next/standalone/.next/server/app/_not-found.html +1 -1
  217. package/.next/standalone/.next/server/app/_not-found.rsc +2 -2
  218. package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  219. package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  220. package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  221. package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  222. package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  223. package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  224. package/.next/standalone/.next/server/app/api/node/events/route/app-paths-manifest.json +3 -0
  225. package/.next/standalone/.next/server/app/api/node/events/route/build-manifest.json +11 -0
  226. package/.next/standalone/.next/server/app/api/node/events/route/server-reference-manifest.json +4 -0
  227. package/.next/standalone/.next/server/app/api/node/events/route.js +7 -0
  228. package/.next/standalone/.next/server/app/api/node/events/route.js.map +5 -0
  229. package/.next/standalone/.next/server/app/api/node/events/route.js.nft.json +1 -0
  230. package/.next/standalone/.next/server/app/api/node/events/route_client-reference-manifest.js +2 -0
  231. package/.next/standalone/.next/server/app/api/node/health/route/app-paths-manifest.json +3 -0
  232. package/.next/standalone/.next/server/app/api/node/health/route/build-manifest.json +11 -0
  233. package/.next/standalone/.next/server/app/api/node/health/route/server-reference-manifest.json +4 -0
  234. package/.next/standalone/.next/server/app/api/node/health/route.js +6 -0
  235. package/.next/standalone/.next/server/app/api/node/health/route.js.map +5 -0
  236. package/.next/standalone/.next/server/app/api/node/health/route.js.nft.json +1 -0
  237. package/.next/standalone/.next/server/app/api/node/health/route_client-reference-manifest.js +2 -0
  238. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route/app-paths-manifest.json +3 -0
  239. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route/build-manifest.json +11 -0
  240. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route/server-reference-manifest.json +4 -0
  241. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route.js +6 -0
  242. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route.js.map +5 -0
  243. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route.js.nft.json +1 -0
  244. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route_client-reference-manifest.js +2 -0
  245. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route/app-paths-manifest.json +3 -0
  246. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route/build-manifest.json +11 -0
  247. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route/server-reference-manifest.json +4 -0
  248. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route.js +7 -0
  249. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route.js.map +5 -0
  250. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route.js.nft.json +1 -0
  251. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route_client-reference-manifest.js +2 -0
  252. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  253. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  254. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  255. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route.js +7 -0
  256. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route.js.map +5 -0
  257. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route.js.nft.json +1 -0
  258. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  259. package/.next/standalone/.next/server/app/api/node/sessions/route/app-paths-manifest.json +3 -0
  260. package/.next/standalone/.next/server/app/api/node/sessions/route/build-manifest.json +11 -0
  261. package/.next/standalone/.next/server/app/api/node/sessions/route/server-reference-manifest.json +4 -0
  262. package/.next/standalone/.next/server/app/api/node/sessions/route.js +9 -0
  263. package/.next/standalone/.next/server/app/api/node/sessions/route.js.map +5 -0
  264. package/.next/standalone/.next/server/app/api/node/sessions/route.js.nft.json +1 -0
  265. package/.next/standalone/.next/server/app/api/node/sessions/route_client-reference-manifest.js +2 -0
  266. package/.next/standalone/.next/server/app/api/nodes/route/app-paths-manifest.json +3 -0
  267. package/.next/standalone/.next/server/app/api/nodes/route/build-manifest.json +11 -0
  268. package/.next/standalone/.next/server/app/api/nodes/route/server-reference-manifest.json +4 -0
  269. package/.next/standalone/.next/server/app/api/nodes/route.js +8 -0
  270. package/.next/standalone/.next/server/app/api/nodes/route.js.map +5 -0
  271. package/.next/standalone/.next/server/app/api/nodes/route.js.nft.json +1 -0
  272. package/.next/standalone/.next/server/app/api/nodes/route_client-reference-manifest.js +2 -0
  273. package/.next/standalone/.next/server/app/api/opencode-config/route.js +1 -1
  274. package/.next/standalone/.next/server/app/api/opencode-config/route.js.nft.json +1 -1
  275. package/.next/standalone/.next/server/app/api/opencode-config/status/route.js +1 -1
  276. package/.next/standalone/.next/server/app/api/opencode-config/status/route.js.nft.json +1 -1
  277. package/.next/standalone/.next/server/app/api/opencode-events/route.js +4 -2
  278. package/.next/standalone/.next/server/app/api/opencode-events/route.js.nft.json +1 -1
  279. package/.next/standalone/.next/server/app/api/profiles/[id]/apply/route.js +1 -1
  280. package/.next/standalone/.next/server/app/api/profiles/[id]/apply/route.js.nft.json +1 -1
  281. package/.next/standalone/.next/server/app/api/profiles/[id]/export/route.js +2 -2
  282. package/.next/standalone/.next/server/app/api/profiles/[id]/export/route.js.nft.json +1 -1
  283. package/.next/standalone/.next/server/app/api/profiles/[id]/route.js +2 -2
  284. package/.next/standalone/.next/server/app/api/profiles/[id]/route.js.nft.json +1 -1
  285. package/.next/standalone/.next/server/app/api/profiles/import/route.js +2 -2
  286. package/.next/standalone/.next/server/app/api/profiles/import/route.js.nft.json +1 -1
  287. package/.next/standalone/.next/server/app/api/profiles/route.js +2 -2
  288. package/.next/standalone/.next/server/app/api/profiles/route.js.nft.json +1 -1
  289. package/.next/standalone/.next/server/app/api/sessions/[id]/archive/route.js +2 -1
  290. package/.next/standalone/.next/server/app/api/sessions/[id]/archive/route.js.nft.json +1 -1
  291. package/.next/standalone/.next/server/app/api/sessions/[id]/delete/route.js +3 -2
  292. package/.next/standalone/.next/server/app/api/sessions/[id]/delete/route.js.nft.json +1 -1
  293. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  294. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  295. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  296. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route.js +7 -0
  297. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route.js.map +5 -0
  298. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route.js.nft.json +1 -0
  299. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  300. package/.next/standalone/.next/server/app/api/sessions/[id]/route.js +1 -1
  301. package/.next/standalone/.next/server/app/api/sessions/[id]/route.js.nft.json +1 -1
  302. package/.next/standalone/.next/server/app/api/sessions/route.js +3 -3
  303. package/.next/standalone/.next/server/app/api/sessions/route.js.nft.json +1 -1
  304. package/.next/standalone/.next/server/app/favicon.ico/route.js +1 -1
  305. package/.next/standalone/.next/server/app/favicon.ico/route.js.nft.json +1 -1
  306. package/.next/standalone/.next/server/app/index.html +1 -1
  307. package/.next/standalone/.next/server/app/index.rsc +3 -3
  308. package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  309. package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +3 -3
  310. package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  311. package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +2 -2
  312. package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  313. package/.next/standalone/.next/server/app/page.js +1 -1
  314. package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
  315. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  316. package/.next/standalone/.next/server/app-paths-manifest.json +8 -0
  317. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__172a07b6._.js → [externals]_next_dist_84e7390b._.js} +2 -2
  318. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1211da38._.js +3 -0
  319. package/.next/standalone/.next/server/chunks/[root-of-the-server]__192ed2f4._.js +3 -0
  320. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1b87ec42._.js +3 -0
  321. package/.next/standalone/.next/server/chunks/[root-of-the-server]__2b526e7a._.js +3 -0
  322. package/.next/standalone/.next/server/chunks/[root-of-the-server]__2f981540._.js +3 -0
  323. package/.next/standalone/.next/server/chunks/[root-of-the-server]__3745b314._.js +3 -0
  324. package/.next/standalone/.next/server/chunks/[root-of-the-server]__56690af0._.js +3 -0
  325. package/.next/standalone/.next/server/chunks/[root-of-the-server]__56f5f249._.js +3 -0
  326. package/.next/standalone/.next/server/chunks/[root-of-the-server]__59175de4._.js +3 -0
  327. package/.next/standalone/.next/server/chunks/[root-of-the-server]__64fffc02._.js +3 -0
  328. package/.next/standalone/.next/server/chunks/[root-of-the-server]__6c428a24._.js +3 -0
  329. package/.next/standalone/.next/server/chunks/[root-of-the-server]__73a00b88._.js +3 -0
  330. package/.next/standalone/.next/server/chunks/[root-of-the-server]__7e757f50._.js +3 -0
  331. package/.next/standalone/.next/server/chunks/[root-of-the-server]__89c5eeab._.js +3 -0
  332. package/.next/standalone/.next/server/chunks/[root-of-the-server]__8da6c5a8._.js +3 -0
  333. package/.next/standalone/.next/server/chunks/[root-of-the-server]__b796d06c._.js +3 -0
  334. package/.next/standalone/.next/server/chunks/[root-of-the-server]__c2ce5c0f._.js +3 -0
  335. package/.next/standalone/.next/server/chunks/[root-of-the-server]__d8e61048._.js +3 -0
  336. package/.next/standalone/.next/server/chunks/[root-of-the-server]__db285678._.js +3 -0
  337. package/.next/standalone/.next/server/chunks/[root-of-the-server]__e00a9200._.js +5 -0
  338. package/.next/standalone/.next/server/chunks/[root-of-the-server]__e5df5e5f._.js +3 -0
  339. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_events_route_actions_f1abd32d.js +3 -0
  340. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_health_route_actions_c4c4c077.js +3 -0
  341. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_archive_route_actions_237255a5.js +3 -0
  342. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_delete_route_actions_e5d426f6.js +3 -0
  343. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_sessions_route_actions_6b564c5a.js +3 -0
  344. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_nodes_route_actions_3e496ee8.js +3 -0
  345. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_sessions_[id]_open-editor_route_actions_eaebf476.js +3 -0
  346. package/.next/standalone/.next/server/chunks/ce889_server_app_api_node_sessions_[id]_open-editor_route_actions_791cdf5b.js +3 -0
  347. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_7e181e75.js +1 -1
  348. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_aca45402.js +3 -0
  349. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_b054aff3.js +1 -1
  350. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_fa835ac3.js +5 -0
  351. package/.next/{server/chunks/ssr/[root-of-the-server]__39eef6a5._.js → standalone/.next/server/chunks/ssr/[root-of-the-server]__631e12d0._.js} +2 -2
  352. package/.next/{server/chunks/ssr/[root-of-the-server]__535a2208._.js → standalone/.next/server/chunks/ssr/[root-of-the-server]__a8cd3911._.js} +2 -2
  353. package/.next/standalone/.next/server/chunks/ssr/src_app_page_tsx_a7111f3e._.js +3 -3
  354. package/.next/standalone/.next/server/pages/404.html +1 -1
  355. package/.next/standalone/.next/server/pages/500.html +2 -2
  356. package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
  357. package/.next/standalone/.next/server/server-reference-manifest.json +1 -1
  358. package/.next/standalone/.next/static/chunks/7ac19aaef01f4a03.js +13 -0
  359. package/.next/standalone/.next/static/chunks/f42202943f6742e5.css +3 -0
  360. package/.next/standalone/AGENTS.md +85 -0
  361. package/.next/standalone/README.md +76 -0
  362. package/.next/standalone/__mocks__/child_process.ts +4 -0
  363. package/.next/standalone/bin/dev-runtime.js +58 -0
  364. package/.next/standalone/bin/vibepulse.js +87 -0
  365. package/.next/standalone/check-hsql.mjs +71 -0
  366. package/.next/standalone/docs/session-status-detection.md +258 -0
  367. package/.next/standalone/eslint.config.mjs +31 -0
  368. package/.next/standalone/next.config.ts +8 -0
  369. package/.next/standalone/package-lock.json +10312 -0
  370. package/.next/standalone/package.json +4 -2
  371. package/.next/standalone/postcss.config.mjs +7 -0
  372. package/.next/standalone/public/readme-cover.png +0 -0
  373. package/.next/standalone/src/AGENTS.md +41 -0
  374. package/.next/standalone/src/app/api/AGENTS.md +40 -0
  375. package/.next/standalone/src/app/api/node/events/route.test.ts +196 -0
  376. package/.next/standalone/src/app/api/node/events/route.ts +259 -0
  377. package/.next/standalone/src/app/api/node/health/route.test.ts +190 -0
  378. package/.next/standalone/src/app/api/node/health/route.ts +48 -0
  379. package/.next/standalone/src/app/api/node/sessions/[id]/archive/route.test.ts +128 -0
  380. package/.next/standalone/src/app/api/node/sessions/[id]/archive/route.ts +97 -0
  381. package/.next/standalone/src/app/api/node/sessions/[id]/delete/route.test.ts +113 -0
  382. package/.next/standalone/src/app/api/node/sessions/[id]/delete/route.ts +81 -0
  383. package/.next/standalone/src/app/api/node/sessions/[id]/open-editor/route.test.ts +206 -0
  384. package/.next/standalone/src/app/api/node/sessions/[id]/open-editor/route.ts +123 -0
  385. package/.next/standalone/src/app/api/node/sessions/route.test.ts +408 -0
  386. package/.next/standalone/src/app/api/node/sessions/route.ts +1094 -0
  387. package/.next/standalone/src/app/api/nodes/route.test.ts +237 -0
  388. package/.next/standalone/src/app/api/nodes/route.ts +176 -0
  389. package/.next/standalone/src/app/api/opencode-config/route.test.ts +86 -0
  390. package/.next/standalone/src/app/api/opencode-config/route.ts +376 -0
  391. package/.next/standalone/src/app/api/opencode-config/status/route.ts +31 -0
  392. package/.next/standalone/src/app/api/opencode-events/route.test.ts +624 -0
  393. package/.next/standalone/src/app/api/opencode-events/route.ts +508 -0
  394. package/.next/standalone/src/app/api/opencode-models/route.test.ts +167 -0
  395. package/.next/standalone/src/app/api/opencode-models/route.ts +76 -0
  396. package/.next/standalone/src/app/api/profiles/[id]/apply/route.ts +49 -0
  397. package/.next/standalone/src/app/api/profiles/[id]/export/route.ts +31 -0
  398. package/.next/standalone/src/app/api/profiles/[id]/route.ts +160 -0
  399. package/.next/standalone/src/app/api/profiles/import/route.test.js +107 -0
  400. package/.next/standalone/src/app/api/profiles/import/route.ts +65 -0
  401. package/.next/standalone/src/app/api/profiles/route.ts +107 -0
  402. package/.next/standalone/src/app/api/sessions/[id]/archive/route.test.ts +136 -0
  403. package/.next/standalone/src/app/api/sessions/[id]/archive/route.ts +170 -0
  404. package/.next/standalone/src/app/api/sessions/[id]/delete/route.test.ts +113 -0
  405. package/.next/standalone/src/app/api/sessions/[id]/delete/route.ts +137 -0
  406. package/.next/standalone/src/app/api/sessions/[id]/open-editor/route.test.ts +218 -0
  407. package/.next/standalone/src/app/api/sessions/[id]/open-editor/route.ts +85 -0
  408. package/.next/standalone/src/app/api/sessions/[id]/route.test.ts +531 -0
  409. package/.next/standalone/src/app/api/sessions/[id]/route.ts +75 -0
  410. package/.next/standalone/src/app/api/sessions/route.test.ts +1298 -0
  411. package/.next/standalone/src/app/api/sessions/route.ts +1695 -0
  412. package/.next/standalone/src/app/favicon.ico +0 -0
  413. package/.next/standalone/src/app/globals.css +66 -0
  414. package/.next/standalone/src/app/layout.tsx +37 -0
  415. package/.next/standalone/src/app/page.test.tsx +134 -0
  416. package/.next/standalone/src/app/page.tsx +358 -0
  417. package/.next/standalone/src/components/AGENTS.md +42 -0
  418. package/.next/standalone/src/components/ErrorBoundary.tsx +72 -0
  419. package/.next/standalone/src/components/KanbanBoard.test.tsx +704 -0
  420. package/.next/standalone/src/components/KanbanBoard.tsx +852 -0
  421. package/.next/standalone/src/components/LoadingState.tsx +37 -0
  422. package/.next/standalone/src/components/ProjectCard.test.tsx +773 -0
  423. package/.next/standalone/src/components/ProjectCard.tsx +595 -0
  424. package/.next/standalone/src/components/QueryProvider.tsx +25 -0
  425. package/.next/standalone/src/components/SessionCard.test.tsx +566 -0
  426. package/.next/standalone/src/components/SessionCard.tsx +434 -0
  427. package/.next/standalone/src/components/SessionList.tsx +60 -0
  428. package/.next/standalone/src/components/host-config/HostManagerDialog.test.tsx +252 -0
  429. package/.next/standalone/src/components/host-config/HostManagerDialog.tsx +476 -0
  430. package/.next/standalone/src/components/opencode-config/AgentConfigForm.test.tsx +72 -0
  431. package/.next/standalone/src/components/opencode-config/AgentConfigForm.tsx +483 -0
  432. package/.next/standalone/src/components/opencode-config/AgentModelSelector.tsx +284 -0
  433. package/.next/standalone/src/components/opencode-config/AgentsConfigPanel.tsx +162 -0
  434. package/.next/standalone/src/components/opencode-config/ConfigButton.tsx +43 -0
  435. package/.next/standalone/src/components/opencode-config/ConfigPanel.tsx +91 -0
  436. package/.next/standalone/src/components/opencode-config/FullscreenConfigPanel.tsx +435 -0
  437. package/.next/standalone/src/components/opencode-config/GeneralSettingsForm.test.tsx +91 -0
  438. package/.next/standalone/src/components/opencode-config/GeneralSettingsForm.tsx +288 -0
  439. package/.next/standalone/src/components/opencode-config/categories/CategoriesList.tsx +382 -0
  440. package/.next/standalone/src/components/opencode-config/categories/CategoriesManager.test.tsx +111 -0
  441. package/.next/standalone/src/components/opencode-config/categories/CategoriesManager.tsx +174 -0
  442. package/.next/standalone/src/components/opencode-config/categories/CategoryConfigForm.tsx +453 -0
  443. package/.next/standalone/src/components/opencode-config/profiles/ProfileCard.tsx +140 -0
  444. package/.next/standalone/src/components/opencode-config/profiles/ProfileEditor.tsx +446 -0
  445. package/.next/standalone/src/components/opencode-config/profiles/ProfileList.tsx +446 -0
  446. package/.next/standalone/src/components/opencode-config/profiles/ProfileManager.test.tsx +225 -0
  447. package/.next/standalone/src/components/opencode-config/profiles/ProfileManager.tsx +405 -0
  448. package/.next/standalone/src/components/ui/Tabs.tsx +59 -0
  449. package/.next/standalone/src/hooks/useHostSources.test.ts +509 -0
  450. package/.next/standalone/src/hooks/useHostSources.ts +299 -0
  451. package/.next/standalone/src/hooks/useOpencodeSync.test.ts +387 -0
  452. package/.next/standalone/src/hooks/useOpencodeSync.ts +571 -0
  453. package/.next/standalone/src/index.ts +2 -0
  454. package/.next/standalone/src/lib/editorLauncher.server.ts +36 -0
  455. package/.next/standalone/src/lib/editorLauncher.test.ts +35 -0
  456. package/.next/standalone/src/lib/editorLauncher.ts +25 -0
  457. package/.next/standalone/src/lib/hostAccent.test.ts +58 -0
  458. package/.next/standalone/src/lib/hostAccent.ts +46 -0
  459. package/.next/standalone/src/lib/hostIdentity.test.ts +187 -0
  460. package/.next/standalone/src/lib/hostIdentity.ts +122 -0
  461. package/.next/standalone/src/lib/hostSourcesStorage.test.ts +141 -0
  462. package/.next/standalone/src/lib/hostSourcesStorage.ts +72 -0
  463. package/.next/standalone/src/lib/nodeProtocol.test.ts +159 -0
  464. package/.next/standalone/src/lib/nodeProtocol.ts +142 -0
  465. package/.next/standalone/src/lib/nodeRegistry.test.ts +173 -0
  466. package/.next/standalone/src/lib/nodeRegistry.ts +398 -0
  467. package/.next/standalone/src/lib/notificationSound.ts +292 -0
  468. package/.next/standalone/src/lib/opencodeConfig.test.ts +100 -0
  469. package/.next/standalone/src/lib/opencodeConfig.ts +76 -0
  470. package/.next/standalone/src/lib/opencodeDiscovery.ts +275 -0
  471. package/.next/standalone/src/lib/profiles/share.test.ts +91 -0
  472. package/.next/standalone/src/lib/profiles/share.ts +93 -0
  473. package/.next/standalone/src/lib/profiles/storage.test.ts +108 -0
  474. package/.next/standalone/src/lib/profiles/storage.ts +370 -0
  475. package/.next/standalone/src/lib/runtimeMode.test.ts +29 -0
  476. package/.next/standalone/src/lib/runtimeMode.ts +29 -0
  477. package/.next/standalone/src/lib/sessionActionErrors.ts +37 -0
  478. package/.next/standalone/src/lib/sessionArchiveOverrides.test.ts +43 -0
  479. package/.next/standalone/src/lib/sessionArchiveOverrides.ts +116 -0
  480. package/.next/standalone/src/lib/transform.test.ts +121 -0
  481. package/.next/standalone/src/lib/transform.ts +193 -0
  482. package/.next/standalone/src/test/setup.ts +8 -0
  483. package/.next/standalone/src/types/index.ts +152 -0
  484. package/.next/standalone/src/types/opencodeConfig.ts +149 -0
  485. package/.next/standalone/tsconfig.json +34 -0
  486. package/.next/standalone/tsconfig.lib.json +17 -0
  487. package/.next/standalone/vitest.config.ts +16 -0
  488. package/.next/static/chunks/7ac19aaef01f4a03.js +13 -0
  489. package/.next/static/chunks/f42202943f6742e5.css +3 -0
  490. package/.next/trace +1 -1
  491. package/.next/trace-build +1 -1
  492. package/.next/types/routes.d.ts +9 -1
  493. package/.next/types/validator.ts +72 -0
  494. package/README.md +28 -11
  495. package/bin/dev-runtime.js +58 -0
  496. package/bin/vibepulse.js +72 -39
  497. package/package.json +4 -2
  498. package/public/readme-cover.png +0 -0
  499. package/.next/server/chunks/[externals]_next_dist_16542d6b._.js +0 -3
  500. package/.next/server/chunks/[root-of-the-server]__07488412._.js +0 -3
  501. package/.next/server/chunks/[root-of-the-server]__07488412._.js.map +0 -1
  502. package/.next/server/chunks/[root-of-the-server]__07649a30._.js +0 -3
  503. package/.next/server/chunks/[root-of-the-server]__07649a30._.js.map +0 -1
  504. package/.next/server/chunks/[root-of-the-server]__172a07b6._.js.map +0 -1
  505. package/.next/server/chunks/[root-of-the-server]__1bf88ae0._.js +0 -3
  506. package/.next/server/chunks/[root-of-the-server]__1bf88ae0._.js.map +0 -1
  507. package/.next/server/chunks/[root-of-the-server]__2c3e3de2._.js +0 -3
  508. package/.next/server/chunks/[root-of-the-server]__2c3e3de2._.js.map +0 -1
  509. package/.next/server/chunks/[root-of-the-server]__560e7c61._.js +0 -3
  510. package/.next/server/chunks/[root-of-the-server]__560e7c61._.js.map +0 -1
  511. package/.next/server/chunks/[root-of-the-server]__9f034d03._.js +0 -5
  512. package/.next/server/chunks/[root-of-the-server]__9f034d03._.js.map +0 -1
  513. package/.next/server/chunks/[root-of-the-server]__a84faf4b._.js +0 -3
  514. package/.next/server/chunks/[root-of-the-server]__a84faf4b._.js.map +0 -1
  515. package/.next/server/chunks/[root-of-the-server]__b92251ea._.js +0 -3
  516. package/.next/server/chunks/[root-of-the-server]__b92251ea._.js.map +0 -1
  517. package/.next/server/chunks/[root-of-the-server]__e7a766a0._.js +0 -3
  518. package/.next/server/chunks/[root-of-the-server]__e7a766a0._.js.map +0 -1
  519. package/.next/server/chunks/[root-of-the-server]__f234882e._.js +0 -3
  520. package/.next/server/chunks/[root-of-the-server]__f234882e._.js.map +0 -1
  521. package/.next/server/chunks/[root-of-the-server]__f85221b8._.js +0 -3
  522. package/.next/server/chunks/[root-of-the-server]__f85221b8._.js.map +0 -1
  523. package/.next/standalone/.next/server/chunks/[externals]_next_dist_16542d6b._.js +0 -3
  524. package/.next/standalone/.next/server/chunks/[root-of-the-server]__07488412._.js +0 -3
  525. package/.next/standalone/.next/server/chunks/[root-of-the-server]__07649a30._.js +0 -3
  526. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1bf88ae0._.js +0 -3
  527. package/.next/standalone/.next/server/chunks/[root-of-the-server]__2c3e3de2._.js +0 -3
  528. package/.next/standalone/.next/server/chunks/[root-of-the-server]__560e7c61._.js +0 -3
  529. package/.next/standalone/.next/server/chunks/[root-of-the-server]__9f034d03._.js +0 -5
  530. package/.next/standalone/.next/server/chunks/[root-of-the-server]__a84faf4b._.js +0 -3
  531. package/.next/standalone/.next/server/chunks/[root-of-the-server]__b92251ea._.js +0 -3
  532. package/.next/standalone/.next/server/chunks/[root-of-the-server]__e7a766a0._.js +0 -3
  533. package/.next/standalone/.next/server/chunks/[root-of-the-server]__f234882e._.js +0 -3
  534. package/.next/standalone/.next/server/chunks/[root-of-the-server]__f85221b8._.js +0 -3
  535. package/.next/standalone/.next/static/chunks/ca49cb2092c277d2.js +0 -13
  536. package/.next/standalone/.next/static/chunks/dc07499869593595.css +0 -3
  537. package/.next/static/chunks/ca49cb2092c277d2.js +0 -13
  538. package/.next/static/chunks/dc07499869593595.css +0 -3
  539. /package/.next/server/chunks/{[externals]_next_dist_16542d6b._.js.map → [externals]_next_dist_84e7390b._.js.map} +0 -0
  540. /package/.next/server/chunks/ssr/{[root-of-the-server]__39eef6a5._.js.map → [root-of-the-server]__631e12d0._.js.map} +0 -0
  541. /package/.next/server/chunks/ssr/{[root-of-the-server]__535a2208._.js.map → [root-of-the-server]__a8cd3911._.js.map} +0 -0
  542. /package/.next/standalone/.next/static/{78EwnRx2m70qyfCL0X4sH → Fw2R3y-fHX4B2SWxNy_4X}/_buildManifest.js +0 -0
  543. /package/.next/standalone/.next/static/{78EwnRx2m70qyfCL0X4sH → Fw2R3y-fHX4B2SWxNy_4X}/_clientMiddlewareManifest.json +0 -0
  544. /package/.next/standalone/.next/static/{78EwnRx2m70qyfCL0X4sH → Fw2R3y-fHX4B2SWxNy_4X}/_ssgManifest.js +0 -0
  545. /package/.next/static/{78EwnRx2m70qyfCL0X4sH → Fw2R3y-fHX4B2SWxNy_4X}/_buildManifest.js +0 -0
  546. /package/.next/static/{78EwnRx2m70qyfCL0X4sH → Fw2R3y-fHX4B2SWxNy_4X}/_clientMiddlewareManifest.json +0 -0
  547. /package/.next/static/{78EwnRx2m70qyfCL0X4sH → Fw2R3y-fHX4B2SWxNy_4X}/_ssgManifest.js +0 -0
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vibepulse",
3
- "version": "0.1.12",
3
+ "version": "0.2.1",
4
4
  "private": false,
5
5
  "description": "Real-time dashboard for monitoring and managing OpenCode sessions",
6
6
  "repository": {
@@ -26,7 +26,9 @@
26
26
  }
27
27
  },
28
28
  "scripts": {
29
- "dev": "next dev -p 3456",
29
+ "dev": "node ./bin/dev-runtime.js",
30
+ "dev:hub": "node ./bin/dev-runtime.js hub",
31
+ "dev:node": "node ./bin/dev-runtime.js node",
30
32
  "build": "next build",
31
33
  "start": "next start -p 3456",
32
34
  "lint": "eslint",
@@ -0,0 +1,7 @@
1
+ const config = {
2
+ plugins: {
3
+ "@tailwindcss/postcss": {},
4
+ },
5
+ };
6
+
7
+ export default config;
@@ -0,0 +1,41 @@
1
+ # SOURCE KNOWLEDGE BASE
2
+
3
+ **Scope:** `src/`
4
+
5
+ ## OVERVIEW
6
+ `src/` contains the application runtime (Next.js App Router), UI modules, realtime hooks, shared utilities, and the package export surface.
7
+
8
+ ## STRUCTURE
9
+ ```text
10
+ src/
11
+ ├── app/ # Next.js page/layout + API routes
12
+ ├── components/ # board UI and config experience
13
+ ├── hooks/ # realtime stream/cache integration
14
+ ├── lib/ # discovery, transforms, config/profile IO
15
+ ├── test/ # test bootstrap (`setup.ts`)
16
+ ├── types/ # domain contracts
17
+ └── index.ts # publishable library exports
18
+ ```
19
+
20
+ ## WHERE TO LOOK
21
+ | Task | Location | Notes |
22
+ |------|----------|-------|
23
+ | Main page shell | `src/app/page.tsx` | top-level filters, mute, config panel state |
24
+ | Backend API behavior | `src/app/api/` | route handlers and OpenCode integration |
25
+ | Board data + degraded UX | `src/components/KanbanBoard.tsx` | polling, stale snapshot, errors |
26
+ | Realtime event sync | `src/hooks/useOpencodeSync.ts` | SSE events + optimistic cache updates |
27
+ | Session/card transforms | `src/lib/transform.ts` | source sessions -> kanban cards |
28
+ | Library public surface | `src/index.ts` | only exported runtime API for package consumers |
29
+
30
+ ## CONVENTIONS
31
+ - Keep Next.js route handlers under `src/app/api/**/route.ts`; avoid ad-hoc API helper entrypoints.
32
+ - Keep tests co-located (`*.test.ts`, `*.test.tsx`); shared test runtime setup stays in `src/test/setup.ts`.
33
+ - Keep package-facing exports centralized in `src/index.ts`.
34
+ - Keep cross-module imports on `@/` alias instead of deep relative paths when crossing feature boundaries.
35
+ - Keep profile/config persistence logic in `src/lib/profiles` and `src/lib/opencodeConfig.ts`, not in UI components.
36
+
37
+ ## ANTI-PATTERNS
38
+ - Do not add new package exports outside `src/index.ts`; `build:lib` only compiles from that entry.
39
+ - Do not bypass shared transform/discovery utilities by duplicating logic in page/components.
40
+ - Do not keep extending known hotspots (`src/app/api/sessions/route.ts`, `src/components/KanbanBoard.tsx`) without extracting helpers.
41
+ - Do not move tests to a separate global test tree; this codebase relies on co-location for context.
@@ -0,0 +1,40 @@
1
+ # API KNOWLEDGE BASE
2
+
3
+ **Scope:** `src/app/api/`
4
+
5
+ ## OVERVIEW
6
+ `src/app/api/` hosts Next.js route handlers that discover OpenCode instances, aggregate session state, stream events, and manage config/profile data.
7
+
8
+ ## STRUCTURE
9
+ ```text
10
+ src/app/api/
11
+ ├── sessions/ # session list/status aggregation
12
+ │ └── [id]/ # per-session read/archive/delete actions
13
+ ├── opencode-events/ # SSE fan-in endpoint
14
+ ├── opencode-config/ # config read/update + status helper
15
+ ├── opencode-models/ # model listing helpers
16
+ └── profiles/ # profile CRUD, apply, import/export
17
+ ```
18
+
19
+ ## WHERE TO LOOK
20
+ | Task | Location | Notes |
21
+ |------|----------|-------|
22
+ | Session list + parent/child merge | `src/app/api/sessions/route.ts` | 900+ line hub with sticky status logic |
23
+ | Per-session archive/delete | `src/app/api/sessions/[id]/archive/route.ts`, `src/app/api/sessions/[id]/delete/route.ts` | mutation endpoints |
24
+ | Realtime event proxy | `src/app/api/opencode-events/route.ts` | multi-port SSE connect + stream forwarding |
25
+ | Config filtering + validation | `src/app/api/opencode-config/route.ts` | allowlists + sensitive-field rejection |
26
+ | Profile import/export | `src/app/api/profiles/import/route.ts`, `src/app/api/profiles/[id]/export/route.ts` | schema validation + download response |
27
+
28
+ ## CONVENTIONS
29
+ - Route shape is file-based: one handler module per `route.ts`.
30
+ - Mutating resource actions are nested under resource id paths (`[id]/archive`, `[id]/delete`, `[id]/apply`, `[id]/export`).
31
+ - OpenCode access is discovery-first (`discoverOpencodePortsWithMeta`), then best-effort across all discovered ports.
32
+ - Error responses consistently use structured JSON with explicit HTTP statuses (`400` validation, `403` forbidden fields, `503` service unavailable).
33
+ - API tests are co-located with handlers (for example `route.test.ts` next to `route.ts`).
34
+
35
+ ## ANTI-PATTERNS
36
+ - Do not hardcode a single OpenCode port; all critical routes iterate discovered ports.
37
+ - Do not accept secret-like config keys in `/api/opencode-config`; sensitive field names are explicitly blocked.
38
+ - Do not add unknown config fields for agents/categories/vibepulse; handlers enforce per-field allowlists.
39
+ - Do not skip rollback on profile import failures; import route restores index state when config write fails.
40
+ - Do not collapse discovery timeout and not-found responses; handlers distinguish these cases for user guidance.
@@ -0,0 +1,196 @@
1
+ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
2
+
3
+ vi.mock('@opencode-ai/sdk', () => ({
4
+ createOpencodeClient: vi.fn(),
5
+ }));
6
+
7
+ vi.mock('@/lib/opencodeDiscovery', () => ({
8
+ discoverOpencodePortsWithMeta: vi.fn(),
9
+ }));
10
+
11
+ import { createOpencodeClient } from '@opencode-ai/sdk';
12
+ import { discoverOpencodePortsWithMeta } from '@/lib/opencodeDiscovery';
13
+ import { createNodeRequestHeaders } from '@/lib/nodeProtocol';
14
+
15
+ import { GET } from './route';
16
+
17
+ const mockCreateOpencodeClient: any = createOpencodeClient;
18
+ const mockDiscoverPortsWithMeta: any = discoverOpencodePortsWithMeta;
19
+ const mockGlobalEvent: any = vi.fn();
20
+
21
+ function resetClientMock(): void {
22
+ mockCreateOpencodeClient.mockImplementation(() => ({
23
+ global: {
24
+ event: mockGlobalEvent,
25
+ },
26
+ }) as never);
27
+ }
28
+
29
+ describe('/api/node/events', () => {
30
+ const originalRuntimeRole = process.env.VIBEPULSE_RUNTIME_ROLE;
31
+ const originalNodeToken = process.env.VIBEPULSE_NODE_TOKEN;
32
+
33
+ beforeEach(() => {
34
+ vi.clearAllMocks();
35
+ process.env.VIBEPULSE_RUNTIME_ROLE = 'node';
36
+ process.env.VIBEPULSE_NODE_TOKEN = 'shared-secret';
37
+ mockDiscoverPortsWithMeta.mockReturnValue({ ports: [7777], timedOut: false });
38
+ resetClientMock();
39
+ });
40
+
41
+ afterEach(() => {
42
+ process.env.VIBEPULSE_RUNTIME_ROLE = originalRuntimeRole;
43
+ process.env.VIBEPULSE_NODE_TOKEN = originalNodeToken;
44
+ });
45
+
46
+ it('rejects unauthenticated requests before opening SSE streams', async () => {
47
+ const response = await GET(
48
+ new Request('http://localhost/api/node/events', {
49
+ headers: { 'x-vibepulse-node-version': '1' },
50
+ })
51
+ );
52
+ const data = await response.json();
53
+
54
+ expect(response.status).toBe(401);
55
+ expect(data).toEqual({
56
+ ok: false,
57
+ reason: 'unauthorized',
58
+ protocolVersion: '1',
59
+ });
60
+ expect(mockDiscoverPortsWithMeta.mock.calls).toHaveLength(0);
61
+ expect(mockGlobalEvent.mock.calls).toHaveLength(0);
62
+ });
63
+
64
+ it('accepts version-only requests when node token is unset', async () => {
65
+ process.env.VIBEPULSE_NODE_TOKEN = ' ';
66
+
67
+ mockGlobalEvent.mockResolvedValue({
68
+ stream: {
69
+ [Symbol.asyncIterator]() {
70
+ let emitted = false;
71
+ return {
72
+ async next() {
73
+ if (!emitted) {
74
+ emitted = true;
75
+ return { done: false, value: { type: 'session.status', timestamp: 1 } };
76
+ }
77
+ return { done: true, value: undefined };
78
+ },
79
+ async return() {
80
+ return { done: true, value: undefined };
81
+ },
82
+ };
83
+ },
84
+ },
85
+ });
86
+
87
+ const response = await GET(
88
+ new Request('http://localhost/api/node/events', {
89
+ headers: { 'x-vibepulse-node-version': '1' },
90
+ })
91
+ );
92
+
93
+ expect(response.status).toBe(200);
94
+ expect(response.headers.get('Content-Type')).toBe('text/event-stream');
95
+ });
96
+
97
+ it('streams local-only envelopes and aborts cleanly', async () => {
98
+ let receivedSignal: AbortSignal | undefined;
99
+ let returnCalls = 0;
100
+
101
+ mockGlobalEvent.mockImplementation(({ signal }: { signal: AbortSignal }) => {
102
+ receivedSignal = signal;
103
+ let emitted = false;
104
+
105
+ const stream: AsyncIterable<unknown> = {
106
+ [Symbol.asyncIterator]() {
107
+ return {
108
+ async next() {
109
+ if (!emitted) {
110
+ emitted = true;
111
+ return {
112
+ done: false,
113
+ value: {
114
+ payload: {
115
+ type: 'session.status',
116
+ properties: {
117
+ sessionID: 'parent-1',
118
+ status: { type: 'busy' },
119
+ },
120
+ timestamp: 123,
121
+ },
122
+ directory: '/repo/project-one',
123
+ },
124
+ };
125
+ }
126
+
127
+ return await new Promise((resolve) => {
128
+ signal.addEventListener(
129
+ 'abort',
130
+ () => resolve({ done: true, value: undefined }),
131
+ { once: true }
132
+ );
133
+ });
134
+ },
135
+ async return() {
136
+ returnCalls += 1;
137
+ return { done: true, value: undefined };
138
+ },
139
+ };
140
+ },
141
+ };
142
+
143
+ return Promise.resolve({ stream });
144
+ });
145
+
146
+ const requestController = new AbortController();
147
+ const response = await GET(
148
+ new Request('http://localhost/api/node/events', {
149
+ headers: createNodeRequestHeaders('shared-secret'),
150
+ signal: requestController.signal,
151
+ })
152
+ );
153
+
154
+ expect(response.status).toBe(200);
155
+ expect(response.headers.get('Content-Type')).toBe('text/event-stream');
156
+
157
+ const reader = response.body?.getReader();
158
+ expect(reader).toBeTruthy();
159
+
160
+ const firstChunk = await reader!.read();
161
+ const text = new TextDecoder().decode(firstChunk.value);
162
+ expect(text.startsWith('data: ')).toBe(true);
163
+
164
+ const payload = JSON.parse(text.slice(6).trim());
165
+ expect(payload).toEqual({
166
+ role: 'node',
167
+ protocolVersion: '1',
168
+ source: {
169
+ hostId: 'local',
170
+ hostLabel: 'Local',
171
+ hostKind: 'local',
172
+ },
173
+ event: {
174
+ payload: {
175
+ type: 'session.status',
176
+ properties: {
177
+ sessionID: 'parent-1',
178
+ status: { type: 'busy' },
179
+ },
180
+ timestamp: 123,
181
+ },
182
+ directory: '/repo/project-one',
183
+ },
184
+ });
185
+ expect(JSON.stringify(payload).includes('baseUrl')).toBe(false);
186
+
187
+ requestController.abort();
188
+ await Promise.resolve();
189
+ await Promise.resolve();
190
+ await reader!.cancel();
191
+
192
+ expect(receivedSignal?.aborted).toBe(true);
193
+ expect(returnCalls).toBeGreaterThanOrEqual(1);
194
+ expect(mockCreateOpencodeClient.mock.calls).toEqual([[{ baseUrl: 'http://localhost:7777' }]]);
195
+ });
196
+ });
@@ -0,0 +1,259 @@
1
+ import { createOpencodeClient } from '@opencode-ai/sdk';
2
+ import { discoverOpencodePortsWithMeta } from '@/lib/opencodeDiscovery';
3
+ import {
4
+ NODE_PROTOCOL_VERSION,
5
+ createNodeFailureResponse,
6
+ guardNodeRequest,
7
+ toNodeRequestGuardResponse,
8
+ } from '@/lib/nodeProtocol';
9
+
10
+ const DEFAULT_EVENTS_PREFLIGHT_TIMEOUT_MS = 2500;
11
+
12
+ const LOCAL_SOURCE = {
13
+ hostId: 'local',
14
+ hostLabel: 'Local',
15
+ hostKind: 'local',
16
+ } as const;
17
+
18
+ type ConnectedStream = {
19
+ port: number;
20
+ stream: AsyncIterable<unknown>;
21
+ controller: AbortController;
22
+ };
23
+
24
+ function getPreflightTimeoutMs(): number {
25
+ const parsedTimeout = Number(process.env.OPENCODE_EVENTS_PREFLIGHT_TIMEOUT_MS);
26
+ return Number.isFinite(parsedTimeout) && parsedTimeout > 0
27
+ ? parsedTimeout
28
+ : DEFAULT_EVENTS_PREFLIGHT_TIMEOUT_MS;
29
+ }
30
+
31
+ function isTimeoutError(error: unknown): boolean {
32
+ const message = error instanceof Error ? error.message : String(error);
33
+ return message.toLowerCase().includes('timed out');
34
+ }
35
+
36
+ function createUpstreamFailureResponse(reason: 'upstream_unreachable' | 'upstream_timeout') {
37
+ return createNodeFailureResponse(reason, {
38
+ role: 'node',
39
+ source: LOCAL_SOURCE,
40
+ upstream: {
41
+ kind: 'opencode',
42
+ reachable: false,
43
+ },
44
+ });
45
+ }
46
+
47
+ async function connectEventStreamWithTimeout(
48
+ port: number,
49
+ timeoutMs: number,
50
+ controller?: AbortController
51
+ ): Promise<ConnectedStream> {
52
+ const connectionController = controller ?? new AbortController();
53
+ const client = createOpencodeClient({ baseUrl: `http://localhost:${port}` });
54
+
55
+ let timerId: ReturnType<typeof setTimeout> | null = null;
56
+ const timeoutPromise = new Promise<never>((_, reject) => {
57
+ timerId = setTimeout(() => {
58
+ connectionController.abort();
59
+ reject(new Error(`OpenCode event stream preflight timed out for port ${port} after ${timeoutMs}ms`));
60
+ }, timeoutMs);
61
+ });
62
+
63
+ try {
64
+ const connection = await Promise.race([
65
+ client.global.event({ signal: connectionController.signal }),
66
+ timeoutPromise,
67
+ ]);
68
+ return {
69
+ port,
70
+ stream: connection.stream as AsyncIterable<unknown>,
71
+ controller: connectionController,
72
+ };
73
+ } finally {
74
+ if (timerId) {
75
+ clearTimeout(timerId);
76
+ }
77
+ }
78
+ }
79
+
80
+ export const dynamic = 'force-dynamic';
81
+
82
+ export async function GET(request: Request) {
83
+ const guardResult = guardNodeRequest(request);
84
+ if (!guardResult.ok) {
85
+ return toNodeRequestGuardResponse(guardResult);
86
+ }
87
+
88
+ const { ports, timedOut } = discoverOpencodePortsWithMeta();
89
+
90
+ if (!ports.length) {
91
+ return createUpstreamFailureResponse(timedOut ? 'upstream_timeout' : 'upstream_unreachable');
92
+ }
93
+
94
+ try {
95
+ const encoder = new TextEncoder();
96
+ const preflightTimeoutMs = getPreflightTimeoutMs();
97
+ const preflightControllers = new Map<number, AbortController>();
98
+ const preflightAttempts = ports.map((port) => {
99
+ const controller = new AbortController();
100
+ preflightControllers.set(port, controller);
101
+ return connectEventStreamWithTimeout(port, preflightTimeoutMs, controller);
102
+ });
103
+
104
+ const firstConnectedStream = await Promise.any(preflightAttempts).catch(async () => {
105
+ const settled = await Promise.allSettled(preflightAttempts);
106
+ for (const result of settled) {
107
+ if (result.status === 'rejected') {
108
+ console.warn('Failed to connect to node-local OpenCode port during preflight:', result.reason);
109
+ }
110
+ }
111
+ return null;
112
+ });
113
+
114
+ if (!firstConnectedStream) {
115
+ const settled = await Promise.allSettled(preflightAttempts);
116
+ const failedReasons = settled
117
+ .filter((result): result is PromiseRejectedResult => result.status === 'rejected')
118
+ .map((result) => result.reason);
119
+ return createUpstreamFailureResponse(
120
+ failedReasons.length > 0 && failedReasons.every(isTimeoutError) ? 'upstream_timeout' : 'upstream_unreachable'
121
+ );
122
+ }
123
+
124
+ for (const [port, controller] of preflightControllers.entries()) {
125
+ if (port !== firstConnectedStream.port) {
126
+ controller.abort();
127
+ }
128
+ }
129
+
130
+ let teardown: (() => void) | null = null;
131
+ const stream = new ReadableStream({
132
+ async start(controller) {
133
+ let isClosed = false;
134
+ const activeControllers = new Set<AbortController>([firstConnectedStream.controller]);
135
+ const activeIterators = new Set<AsyncIterator<unknown>>();
136
+
137
+ const enqueueEvent = (event: unknown) => {
138
+ try {
139
+ controller.enqueue(
140
+ encoder.encode(
141
+ `data: ${JSON.stringify({
142
+ role: 'node',
143
+ protocolVersion: NODE_PROTOCOL_VERSION,
144
+ source: LOCAL_SOURCE,
145
+ event,
146
+ })}\n\n`
147
+ )
148
+ );
149
+ return true;
150
+ } catch {
151
+ return false;
152
+ }
153
+ };
154
+
155
+ const closeControllerSafely = () => {
156
+ try {
157
+ controller.close();
158
+ } catch {
159
+ }
160
+ };
161
+
162
+ const onAbort = () => {
163
+ if (teardown) {
164
+ teardown();
165
+ return;
166
+ }
167
+
168
+ isClosed = true;
169
+ closeControllerSafely();
170
+ };
171
+
172
+ teardown = () => {
173
+ isClosed = true;
174
+ for (const activeController of activeControllers) {
175
+ activeController.abort();
176
+ }
177
+ void Promise.allSettled(Array.from(activeIterators).map((iterator) => iterator.return?.()));
178
+ request.signal.removeEventListener('abort', onAbort);
179
+ closeControllerSafely();
180
+ };
181
+
182
+ request.signal.addEventListener('abort', onAbort);
183
+
184
+ const streamEvents = async (connected: ConnectedStream) => {
185
+ const iterator = connected.stream[Symbol.asyncIterator]();
186
+ activeIterators.add(iterator);
187
+ try {
188
+ while (!isClosed) {
189
+ const next = await iterator.next();
190
+ if (next.done) {
191
+ break;
192
+ }
193
+ if (isClosed) {
194
+ break;
195
+ }
196
+ if (!enqueueEvent(next.value)) {
197
+ break;
198
+ }
199
+ }
200
+ } catch (error) {
201
+ console.warn('Node-local OpenCode event stream failed for port:', connected.port, error);
202
+ } finally {
203
+ activeIterators.delete(iterator);
204
+ }
205
+ };
206
+
207
+ try {
208
+ const primaryTask = streamEvents(firstConnectedStream);
209
+
210
+ const remainingPorts = ports.filter((port) => port !== firstConnectedStream.port);
211
+ const secondaryTasks = remainingPorts.map(async (port) => {
212
+ if (isClosed) {
213
+ return;
214
+ }
215
+
216
+ try {
217
+ const connected = await connectEventStreamWithTimeout(port, preflightTimeoutMs);
218
+ activeControllers.add(connected.controller);
219
+ if (isClosed) {
220
+ connected.controller.abort();
221
+ activeControllers.delete(connected.controller);
222
+ return;
223
+ }
224
+ await streamEvents(connected);
225
+ activeControllers.delete(connected.controller);
226
+ } catch (error) {
227
+ console.warn('Failed to connect to secondary node-local OpenCode port:', port, error);
228
+ }
229
+ });
230
+
231
+ await Promise.allSettled([primaryTask, ...secondaryTasks]);
232
+ } catch (error) {
233
+ console.error('Error in node-local event stream:', error);
234
+ } finally {
235
+ isClosed = true;
236
+ teardown = null;
237
+ request.signal.removeEventListener('abort', onAbort);
238
+ closeControllerSafely();
239
+ }
240
+ },
241
+ cancel() {
242
+ if (teardown) {
243
+ teardown();
244
+ }
245
+ },
246
+ });
247
+
248
+ return new Response(stream, {
249
+ headers: {
250
+ 'Content-Type': 'text/event-stream',
251
+ 'Cache-Control': 'no-cache',
252
+ Connection: 'keep-alive',
253
+ },
254
+ });
255
+ } catch (error) {
256
+ console.error('Error creating node-local event stream:', error);
257
+ return createUpstreamFailureResponse(isTimeoutError(error) ? 'upstream_timeout' : 'upstream_unreachable');
258
+ }
259
+ }