@mndrk/agx 2.0.56 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (600) hide show
  1. package/cloud-runtime/standalone/apps/local/.next/BUILD_ID +1 -1
  2. package/cloud-runtime/standalone/apps/local/.next/app-path-routes-manifest.json +2 -0
  3. package/cloud-runtime/standalone/apps/local/.next/build-manifest.json +3 -3
  4. package/cloud-runtime/standalone/apps/local/.next/prerender-manifest.json +3 -3
  5. package/cloud-runtime/standalone/apps/local/.next/routes-manifest.json +15 -0
  6. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error/page.js +1 -1
  7. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error/page.js.nft.json +1 -1
  8. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.html +1 -1
  9. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.rsc +1 -1
  10. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  11. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  12. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  13. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  14. package/cloud-runtime/standalone/apps/local/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  15. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found/page.js +1 -1
  16. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found/page.js.nft.json +1 -1
  17. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  18. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.html +2 -2
  19. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.rsc +2 -2
  20. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  21. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  22. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  23. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  24. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  25. package/cloud-runtime/standalone/apps/local/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  26. package/cloud-runtime/standalone/apps/local/.next/server/app/agents/[id]/page.js +1 -1
  27. package/cloud-runtime/standalone/apps/local/.next/server/app/agents/[id]/page.js.nft.json +1 -1
  28. package/cloud-runtime/standalone/apps/local/.next/server/app/agents/[id]/page_client-reference-manifest.js +1 -1
  29. package/cloud-runtime/standalone/apps/local/.next/server/app/agents/page.js +1 -1
  30. package/cloud-runtime/standalone/apps/local/.next/server/app/agents/page.js.nft.json +1 -1
  31. package/cloud-runtime/standalone/apps/local/.next/server/app/agents/page_client-reference-manifest.js +1 -1
  32. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.html +2 -2
  33. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.rsc +3 -3
  34. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.segments/_full.segment.rsc +3 -3
  35. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.segments/_head.segment.rsc +1 -1
  36. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.segments/_index.segment.rsc +2 -2
  37. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.segments/_tree.segment.rsc +2 -2
  38. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.segments/agents/__PAGE__.segment.rsc +2 -2
  39. package/cloud-runtime/standalone/apps/local/.next/server/app/agents.segments/agents.segment.rsc +1 -1
  40. package/cloud-runtime/standalone/apps/local/.next/server/app/api/agent-specs/route.js +1 -1
  41. package/cloud-runtime/standalone/apps/local/.next/server/app/api/agent-specs/route.js.nft.json +1 -1
  42. package/cloud-runtime/standalone/apps/local/.next/server/app/api/agents/[id]/profile/route.js +4 -3
  43. package/cloud-runtime/standalone/apps/local/.next/server/app/api/agents/[id]/profile/route.js.nft.json +1 -1
  44. package/cloud-runtime/standalone/apps/local/.next/server/app/api/agents/export/route.js +1 -1
  45. package/cloud-runtime/standalone/apps/local/.next/server/app/api/agents/export/route.js.nft.json +1 -1
  46. package/cloud-runtime/standalone/apps/local/.next/server/app/api/automations/create/route.js +2 -2
  47. package/cloud-runtime/standalone/apps/local/.next/server/app/api/automations/create/route.js.nft.json +1 -1
  48. package/cloud-runtime/standalone/apps/local/.next/server/app/api/automations/route.js +1 -1
  49. package/cloud-runtime/standalone/apps/local/.next/server/app/api/automations/route.js.nft.json +1 -1
  50. package/cloud-runtime/standalone/apps/local/.next/server/app/api/chat/route.js +2 -2
  51. package/cloud-runtime/standalone/apps/local/.next/server/app/api/chat/route.js.nft.json +1 -1
  52. package/cloud-runtime/standalone/apps/local/.next/server/app/api/daemon/route.js +1 -1
  53. package/cloud-runtime/standalone/apps/local/.next/server/app/api/daemon/route.js.nft.json +1 -1
  54. package/cloud-runtime/standalone/apps/local/.next/server/app/api/file-search/route.js.nft.json +1 -1
  55. package/cloud-runtime/standalone/apps/local/.next/server/app/api/filesystem/analyze/route.js +1 -1
  56. package/cloud-runtime/standalone/apps/local/.next/server/app/api/filesystem/analyze/route.js.nft.json +1 -1
  57. package/cloud-runtime/standalone/apps/local/.next/server/app/api/graphs/[graphId]/nodes/[nodeId]/route.js +2 -3
  58. package/cloud-runtime/standalone/apps/local/.next/server/app/api/graphs/[graphId]/nodes/[nodeId]/route.js.nft.json +1 -1
  59. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/issues/[id]/route.js.nft.json +1 -1
  60. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/issues/context/route.js.nft.json +1 -1
  61. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/issues/route.js.nft.json +1 -1
  62. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/options/route.js.nft.json +1 -1
  63. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/runs/scripted/route.js +5 -4
  64. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/runs/scripted/route.js.nft.json +1 -1
  65. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/status/route.js.nft.json +1 -1
  66. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route/app-paths-manifest.json +3 -0
  67. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route/build-manifest.json +9 -0
  68. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route/server-reference-manifest.json +4 -0
  69. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route.js +13 -0
  70. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route.js.map +5 -0
  71. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route.js.nft.json +1 -0
  72. package/cloud-runtime/standalone/apps/local/.next/server/app/api/linear/worker/route_client-reference-manifest.js +3 -0
  73. package/cloud-runtime/standalone/apps/local/.next/server/app/api/participants/route.js +1 -1
  74. package/cloud-runtime/standalone/apps/local/.next/server/app/api/participants/route.js.nft.json +1 -1
  75. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/activities/route.js +4 -4
  76. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/activities/route.js.nft.json +1 -1
  77. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/linear-issues/route.js +4 -4
  78. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/linear-issues/route.js.nft.json +1 -1
  79. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/notes/[noteId]/route.js +2 -2
  80. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/notes/[noteId]/route.js.nft.json +1 -1
  81. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/notes/route.js +2 -2
  82. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/notes/route.js.nft.json +1 -1
  83. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/route.js +3 -3
  84. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/route.js.nft.json +1 -1
  85. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/scheduled-tasks/route.js +14 -13
  86. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/scheduled-tasks/route.js.nft.json +1 -1
  87. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/validate/route.js +3 -3
  88. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/validate/route.js.nft.json +1 -1
  89. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route/app-paths-manifest.json +3 -0
  90. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route/build-manifest.json +9 -0
  91. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route/server-reference-manifest.json +4 -0
  92. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route.js +28 -0
  93. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route.js.map +5 -0
  94. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route.js.nft.json +1 -0
  95. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/objectives/[objectiveId]/worker/route_client-reference-manifest.js +3 -0
  96. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/route.js +9 -5
  97. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/route.js.nft.json +1 -1
  98. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/search/route.js +1 -1
  99. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/search/route.js.nft.json +1 -1
  100. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/[id]/teams/route.js.nft.json +1 -1
  101. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/route.js +4 -4
  102. package/cloud-runtime/standalone/apps/local/.next/server/app/api/projects/route.js.nft.json +1 -1
  103. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/[id]/cancel/route.js +1 -1
  104. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/[id]/cancel/route.js.nft.json +1 -1
  105. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/[id]/route.js +1 -1
  106. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/[id]/route.js.nft.json +1 -1
  107. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/[id]/runs/route.js +1 -1
  108. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/[id]/runs/route.js.nft.json +1 -1
  109. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/poll/route.js +16 -15
  110. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/poll/route.js.nft.json +1 -1
  111. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/route.js +5 -5
  112. package/cloud-runtime/standalone/apps/local/.next/server/app/api/prompt-jobs/route.js.nft.json +1 -1
  113. package/cloud-runtime/standalone/apps/local/.next/server/app/api/providers/check/[id]/route.js.nft.json +1 -1
  114. package/cloud-runtime/standalone/apps/local/.next/server/app/api/providers/route.js.nft.json +1 -1
  115. package/cloud-runtime/standalone/apps/local/.next/server/app/api/queue/route.js +1 -1
  116. package/cloud-runtime/standalone/apps/local/.next/server/app/api/queue/route.js.nft.json +1 -1
  117. package/cloud-runtime/standalone/apps/local/.next/server/app/api/schedules/debug/route.js +1 -1
  118. package/cloud-runtime/standalone/apps/local/.next/server/app/api/schedules/debug/route.js.nft.json +1 -1
  119. package/cloud-runtime/standalone/apps/local/.next/server/app/api/schedules/poll/route.js +1 -1
  120. package/cloud-runtime/standalone/apps/local/.next/server/app/api/schedules/poll/route.js.nft.json +1 -1
  121. package/cloud-runtime/standalone/apps/local/.next/server/app/api/schedules/route.js +2 -2
  122. package/cloud-runtime/standalone/apps/local/.next/server/app/api/schedules/route.js.nft.json +1 -1
  123. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/assign/route.js.nft.json +1 -1
  124. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/available/route.js.nft.json +1 -1
  125. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/detail/route.js.nft.json +1 -1
  126. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/history/route.js.nft.json +1 -1
  127. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/learn/route.js.nft.json +1 -1
  128. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/route.js.nft.json +1 -1
  129. package/cloud-runtime/standalone/apps/local/.next/server/app/api/skills/unlearn/route.js.nft.json +1 -1
  130. package/cloud-runtime/standalone/apps/local/.next/server/app/api/status/route.js.nft.json +1 -1
  131. package/cloud-runtime/standalone/apps/local/.next/server/app/api/summarize/route.js.nft.json +1 -1
  132. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/comments/[commentId]/route.js.nft.json +1 -1
  133. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/comments/route.js.nft.json +1 -1
  134. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/events/route.js.nft.json +1 -1
  135. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/history/route.js.nft.json +1 -1
  136. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/metrics/route.js.nft.json +1 -1
  137. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/pause/route.js.nft.json +1 -1
  138. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/replan/route.js.nft.json +1 -1
  139. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/restart/route.js.nft.json +1 -1
  140. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/resume/route.js.nft.json +1 -1
  141. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/rollback/route.js.nft.json +1 -1
  142. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/route.js.nft.json +1 -1
  143. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/schedule/route.js.nft.json +1 -1
  144. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/graph/stop/route.js.nft.json +1 -1
  145. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/logs/route.js.nft.json +1 -1
  146. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/comments/route.js.nft.json +1 -1
  147. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/complete/route.js.nft.json +1 -1
  148. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/fail/route.js.nft.json +1 -1
  149. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/resume/route.js.nft.json +1 -1
  150. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/start/route.js.nft.json +1 -1
  151. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/stop/route.js.nft.json +1 -1
  152. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/nodes/[nodeId]/verify/route.js.nft.json +1 -1
  153. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/[id]/route.js.nft.json +1 -1
  154. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/extract/route.js.nft.json +1 -1
  155. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/route.js +5 -4
  156. package/cloud-runtime/standalone/apps/local/.next/server/app/api/tasks/route.js.nft.json +1 -1
  157. package/cloud-runtime/standalone/apps/local/.next/server/app/api/terminal/sessions/[id]/route.js +1 -1
  158. package/cloud-runtime/standalone/apps/local/.next/server/app/api/terminal/sessions/[id]/route.js.nft.json +1 -1
  159. package/cloud-runtime/standalone/apps/local/.next/server/app/api/threads/knowledge/route.js +1 -1
  160. package/cloud-runtime/standalone/apps/local/.next/server/app/api/threads/knowledge/route.js.nft.json +1 -1
  161. package/cloud-runtime/standalone/apps/local/.next/server/app/api/threads/route.js +1 -1
  162. package/cloud-runtime/standalone/apps/local/.next/server/app/api/threads/route.js.nft.json +1 -1
  163. package/cloud-runtime/standalone/apps/local/.next/server/app/automations/page.js +1 -1
  164. package/cloud-runtime/standalone/apps/local/.next/server/app/automations/page.js.nft.json +1 -1
  165. package/cloud-runtime/standalone/apps/local/.next/server/app/automations/page_client-reference-manifest.js +1 -1
  166. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.html +2 -2
  167. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.rsc +14 -14
  168. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.segments/_full.segment.rsc +14 -14
  169. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.segments/_head.segment.rsc +1 -1
  170. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.segments/_index.segment.rsc +2 -2
  171. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.segments/_tree.segment.rsc +2 -2
  172. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.segments/automations/__PAGE__.segment.rsc +2 -2
  173. package/cloud-runtime/standalone/apps/local/.next/server/app/automations.segments/automations.segment.rsc +1 -1
  174. package/cloud-runtime/standalone/apps/local/.next/server/app/board/page.js +1 -1
  175. package/cloud-runtime/standalone/apps/local/.next/server/app/board/page.js.nft.json +1 -1
  176. package/cloud-runtime/standalone/apps/local/.next/server/app/board/page_client-reference-manifest.js +1 -1
  177. package/cloud-runtime/standalone/apps/local/.next/server/app/board.html +2 -2
  178. package/cloud-runtime/standalone/apps/local/.next/server/app/board.rsc +2 -2
  179. package/cloud-runtime/standalone/apps/local/.next/server/app/board.segments/_full.segment.rsc +2 -2
  180. package/cloud-runtime/standalone/apps/local/.next/server/app/board.segments/_head.segment.rsc +1 -1
  181. package/cloud-runtime/standalone/apps/local/.next/server/app/board.segments/_index.segment.rsc +2 -2
  182. package/cloud-runtime/standalone/apps/local/.next/server/app/board.segments/_tree.segment.rsc +2 -2
  183. package/cloud-runtime/standalone/apps/local/.next/server/app/board.segments/board/__PAGE__.segment.rsc +1 -1
  184. package/cloud-runtime/standalone/apps/local/.next/server/app/board.segments/board.segment.rsc +1 -1
  185. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph/page.js +1 -1
  186. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph/page.js.nft.json +1 -1
  187. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph/page_client-reference-manifest.js +1 -1
  188. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.html +2 -2
  189. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.rsc +3 -3
  190. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.segments/_full.segment.rsc +3 -3
  191. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.segments/_head.segment.rsc +1 -1
  192. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.segments/_index.segment.rsc +2 -2
  193. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.segments/_tree.segment.rsc +2 -2
  194. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.segments/execution-graph/__PAGE__.segment.rsc +2 -2
  195. package/cloud-runtime/standalone/apps/local/.next/server/app/execution-graph.segments/execution-graph.segment.rsc +1 -1
  196. package/cloud-runtime/standalone/apps/local/.next/server/app/folders/page.js +1 -1
  197. package/cloud-runtime/standalone/apps/local/.next/server/app/folders/page.js.nft.json +1 -1
  198. package/cloud-runtime/standalone/apps/local/.next/server/app/folders/page_client-reference-manifest.js +1 -1
  199. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.html +2 -2
  200. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.rsc +2 -2
  201. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.segments/_full.segment.rsc +2 -2
  202. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.segments/_head.segment.rsc +1 -1
  203. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.segments/_index.segment.rsc +2 -2
  204. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.segments/_tree.segment.rsc +2 -2
  205. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.segments/folders/__PAGE__.segment.rsc +1 -1
  206. package/cloud-runtime/standalone/apps/local/.next/server/app/folders.segments/folders.segment.rsc +1 -1
  207. package/cloud-runtime/standalone/apps/local/.next/server/app/index.html +2 -2
  208. package/cloud-runtime/standalone/apps/local/.next/server/app/index.rsc +2 -2
  209. package/cloud-runtime/standalone/apps/local/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  210. package/cloud-runtime/standalone/apps/local/.next/server/app/index.segments/_full.segment.rsc +2 -2
  211. package/cloud-runtime/standalone/apps/local/.next/server/app/index.segments/_head.segment.rsc +1 -1
  212. package/cloud-runtime/standalone/apps/local/.next/server/app/index.segments/_index.segment.rsc +2 -2
  213. package/cloud-runtime/standalone/apps/local/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  214. package/cloud-runtime/standalone/apps/local/.next/server/app/page.js +1 -1
  215. package/cloud-runtime/standalone/apps/local/.next/server/app/page.js.nft.json +1 -1
  216. package/cloud-runtime/standalone/apps/local/.next/server/app/page_client-reference-manifest.js +1 -1
  217. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/automations/page.js +1 -1
  218. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/automations/page.js.nft.json +1 -1
  219. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/automations/page_client-reference-manifest.js +1 -1
  220. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/env-vars/page.js +1 -1
  221. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/env-vars/page.js.nft.json +1 -1
  222. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/env-vars/page_client-reference-manifest.js +1 -1
  223. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/folders/page.js +1 -1
  224. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/folders/page.js.nft.json +1 -1
  225. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/folders/page_client-reference-manifest.js +1 -1
  226. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/graph/[taskId]/page.js +1 -1
  227. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/graph/[taskId]/page.js.nft.json +1 -1
  228. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/graph/[taskId]/page_client-reference-manifest.js +1 -1
  229. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/knowledge/page.js +1 -1
  230. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/knowledge/page.js.nft.json +1 -1
  231. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/knowledge/page_client-reference-manifest.js +1 -1
  232. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/linear/page/react-loadable-manifest.json +6 -0
  233. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/linear/page.js +1 -1
  234. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/linear/page.js.nft.json +1 -1
  235. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/linear/page_client-reference-manifest.js +1 -1
  236. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/objectives/[objectiveId]/page.js +1 -1
  237. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/objectives/[objectiveId]/page.js.nft.json +1 -1
  238. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/objectives/[objectiveId]/page_client-reference-manifest.js +1 -1
  239. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/objectives/page.js +1 -1
  240. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/objectives/page.js.nft.json +1 -1
  241. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/objectives/page_client-reference-manifest.js +1 -1
  242. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/page.js +1 -1
  243. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/page.js.nft.json +1 -1
  244. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/page_client-reference-manifest.js +1 -1
  245. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/settings/page.js +1 -1
  246. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/settings/page.js.nft.json +1 -1
  247. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/settings/page_client-reference-manifest.js +1 -1
  248. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/[teamId]/agents/[agentId]/page.js +1 -1
  249. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/[teamId]/agents/[agentId]/page.js.nft.json +1 -1
  250. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/[teamId]/agents/[agentId]/page_client-reference-manifest.js +1 -1
  251. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/[teamId]/page.js +1 -1
  252. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/[teamId]/page.js.nft.json +1 -1
  253. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/[teamId]/page_client-reference-manifest.js +1 -1
  254. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/adopt/page.js +1 -1
  255. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/adopt/page.js.nft.json +1 -1
  256. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/adopt/page_client-reference-manifest.js +1 -1
  257. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/new/page.js +1 -1
  258. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/new/page.js.nft.json +1 -1
  259. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/new/page_client-reference-manifest.js +1 -1
  260. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/page.js +1 -1
  261. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/page.js.nft.json +1 -1
  262. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/page_client-reference-manifest.js +1 -1
  263. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/replace/page.js +1 -1
  264. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/replace/page.js.nft.json +1 -1
  265. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/teams/replace/page_client-reference-manifest.js +1 -1
  266. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/terminal/page.js +1 -1
  267. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/terminal/page.js.nft.json +1 -1
  268. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/terminal/page_client-reference-manifest.js +1 -1
  269. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/thread/[threadId]/page.js +1 -1
  270. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/thread/[threadId]/page.js.nft.json +1 -1
  271. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/[slug]/thread/[threadId]/page_client-reference-manifest.js +1 -1
  272. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans/page.js +1 -1
  273. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans/page.js.nft.json +1 -1
  274. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans/page_client-reference-manifest.js +1 -1
  275. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.html +2 -2
  276. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.rsc +3 -3
  277. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/_full.segment.rsc +3 -3
  278. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/_head.segment.rsc +1 -1
  279. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/_index.segment.rsc +2 -2
  280. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/_tree.segment.rsc +2 -2
  281. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/projects/orphans/__PAGE__.segment.rsc +2 -2
  282. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/projects/orphans.segment.rsc +1 -1
  283. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/orphans.segments/projects.segment.rsc +1 -1
  284. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/page.js +1 -1
  285. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/page.js.nft.json +1 -1
  286. package/cloud-runtime/standalone/apps/local/.next/server/app/projects/page_client-reference-manifest.js +1 -1
  287. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.html +2 -2
  288. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.rsc +2 -2
  289. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.segments/_full.segment.rsc +2 -2
  290. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.segments/_head.segment.rsc +1 -1
  291. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.segments/_index.segment.rsc +2 -2
  292. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.segments/_tree.segment.rsc +2 -2
  293. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.segments/projects/__PAGE__.segment.rsc +1 -1
  294. package/cloud-runtime/standalone/apps/local/.next/server/app/projects.segments/projects.segment.rsc +1 -1
  295. package/cloud-runtime/standalone/apps/local/.next/server/app/settings/page.js +1 -1
  296. package/cloud-runtime/standalone/apps/local/.next/server/app/settings/page.js.nft.json +1 -1
  297. package/cloud-runtime/standalone/apps/local/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  298. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.html +2 -2
  299. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.rsc +2 -2
  300. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.segments/_full.segment.rsc +2 -2
  301. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.segments/_head.segment.rsc +1 -1
  302. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.segments/_index.segment.rsc +2 -2
  303. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.segments/_tree.segment.rsc +2 -2
  304. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +1 -1
  305. package/cloud-runtime/standalone/apps/local/.next/server/app/settings.segments/settings.segment.rsc +1 -1
  306. package/cloud-runtime/standalone/apps/local/.next/server/app/setup/page.js +1 -1
  307. package/cloud-runtime/standalone/apps/local/.next/server/app/setup/page.js.nft.json +1 -1
  308. package/cloud-runtime/standalone/apps/local/.next/server/app/setup/page_client-reference-manifest.js +1 -1
  309. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.html +2 -2
  310. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.rsc +3 -3
  311. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.segments/_full.segment.rsc +3 -3
  312. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.segments/_head.segment.rsc +1 -1
  313. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.segments/_index.segment.rsc +2 -2
  314. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.segments/_tree.segment.rsc +2 -2
  315. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.segments/setup/__PAGE__.segment.rsc +2 -2
  316. package/cloud-runtime/standalone/apps/local/.next/server/app/setup.segments/setup.segment.rsc +1 -1
  317. package/cloud-runtime/standalone/apps/local/.next/server/app/skills/page.js +1 -1
  318. package/cloud-runtime/standalone/apps/local/.next/server/app/skills/page.js.nft.json +1 -1
  319. package/cloud-runtime/standalone/apps/local/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  320. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.html +2 -2
  321. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.rsc +2 -2
  322. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.segments/_full.segment.rsc +2 -2
  323. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.segments/_head.segment.rsc +1 -1
  324. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.segments/_index.segment.rsc +2 -2
  325. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.segments/_tree.segment.rsc +2 -2
  326. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.segments/skills/__PAGE__.segment.rsc +1 -1
  327. package/cloud-runtime/standalone/apps/local/.next/server/app/skills.segments/skills.segment.rsc +1 -1
  328. package/cloud-runtime/standalone/apps/local/.next/server/app/status/page.js +1 -1
  329. package/cloud-runtime/standalone/apps/local/.next/server/app/status/page.js.nft.json +1 -1
  330. package/cloud-runtime/standalone/apps/local/.next/server/app/status/page_client-reference-manifest.js +1 -1
  331. package/cloud-runtime/standalone/apps/local/.next/server/app/status.html +2 -2
  332. package/cloud-runtime/standalone/apps/local/.next/server/app/status.rsc +2 -2
  333. package/cloud-runtime/standalone/apps/local/.next/server/app/status.segments/_full.segment.rsc +2 -2
  334. package/cloud-runtime/standalone/apps/local/.next/server/app/status.segments/_head.segment.rsc +1 -1
  335. package/cloud-runtime/standalone/apps/local/.next/server/app/status.segments/_index.segment.rsc +2 -2
  336. package/cloud-runtime/standalone/apps/local/.next/server/app/status.segments/_tree.segment.rsc +2 -2
  337. package/cloud-runtime/standalone/apps/local/.next/server/app/status.segments/status/__PAGE__.segment.rsc +1 -1
  338. package/cloud-runtime/standalone/apps/local/.next/server/app/status.segments/status.segment.rsc +1 -1
  339. package/cloud-runtime/standalone/apps/local/.next/server/app/thread/[id]/page.js +1 -1
  340. package/cloud-runtime/standalone/apps/local/.next/server/app/thread/[id]/page.js.nft.json +1 -1
  341. package/cloud-runtime/standalone/apps/local/.next/server/app/thread/[id]/page_client-reference-manifest.js +1 -1
  342. package/cloud-runtime/standalone/apps/local/.next/server/app-paths-manifest.json +2 -0
  343. package/cloud-runtime/standalone/apps/local/.next/server/chunks/0jps_app_api_projects_[id]_objectives_[objectiveId]_worker_route_actions_0v8q3zz.js +3 -0
  344. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[externals]__0_au5u1._.js +3 -0
  345. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[externals]__13x93ar._.js +3 -0
  346. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0_10qfd._.js → [root-of-the-server]__0.6yz1u._.js} +2 -2
  347. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__01lsgl~._.js +4 -0
  348. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0205scg._.js → [root-of-the-server]__03.9arn._.js} +2 -2
  349. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__03h0gqp._.js +3 -0
  350. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__08jo91s._.js +9 -0
  351. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0o315az._.js → [root-of-the-server]__09j9jpf._.js} +2 -2
  352. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0-nye63._.js → [root-of-the-server]__09jghbu._.js} +2 -2
  353. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0_7hiof._.js +43 -0
  354. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0.jam.l._.js → [root-of-the-server]__0a0cq38._.js} +2 -2
  355. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0asvfdo._.js +54 -0
  356. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0c86535._.js +3 -0
  357. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0cj1krd._.js +3 -0
  358. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0aa-88e._.js → [root-of-the-server]__0dy3h2i._.js} +2 -2
  359. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0touqng._.js → [root-of-the-server]__0e8-2k_._.js} +2 -2
  360. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0enhv5p._.js +3 -0
  361. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0f9byr.._.js +1 -1
  362. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0t2jk2r._.js → [root-of-the-server]__0g7hc1-._.js} +2 -2
  363. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0g7p6pw._.js +55 -0
  364. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__019q25b._.js → [root-of-the-server]__0gj~dap._.js} +7 -7
  365. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0e6cj2y._.js → [root-of-the-server]__0hc45jw._.js} +2 -2
  366. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0hkcw03._.js +49 -0
  367. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0hmw36u._.js +1 -1
  368. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0l53ok5._.js +54 -0
  369. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0n.momw._.js +8 -0
  370. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0tjo9we._.js +7 -0
  371. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__0-~t2br._.js → [root-of-the-server]__0v7jjvl._.js} +2 -2
  372. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0x6w64i._.js +3 -0
  373. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__11nke7t._.js → [root-of-the-server]__0y3qxv1._.js} +2 -2
  374. package/cloud-runtime/standalone/apps/local/.next/server/chunks/{[root-of-the-server]__10z8f9h._.js → [root-of-the-server]__0ygidxe._.js} +2 -2
  375. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0z82z0-._.js +49 -0
  376. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0zsv-tb._.js +8 -0
  377. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0~nnfjr._.js +3 -0
  378. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0~x4jbk._.js +3 -0
  379. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__10d.dhd._.js +229 -0
  380. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__12qy318._.js +3 -0
  381. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_039.xxy._.js +1 -1
  382. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_06oeti1._.js +49 -0
  383. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0dyy7h.._.js +3 -0
  384. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0gi7c9x._.js +2 -2
  385. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0gr.psg._.js +1 -1
  386. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0sd8z0i._.js +21 -0
  387. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0y42h_~._.js +2 -2
  388. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0~ah49q._.js +1 -1
  389. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_01kqgle._.js +11 -0
  390. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_06qet8g._.js +36 -0
  391. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0_0m2ly._.js +397 -0
  392. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0_a~bj0._.js +25 -0
  393. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0a15wtk._.js +397 -0
  394. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0bjdpen._.js +29 -0
  395. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0fr1qq6._.js +1 -1
  396. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0g.q2r6._.js +41 -0
  397. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0h7wd0e._.js +29 -0
  398. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0i7fs.i._.js +397 -0
  399. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0ipg-p6._.js +3 -0
  400. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0npxy21._.js +11 -0
  401. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0uhfa93._.js +21 -0
  402. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_12wpldq._.js +25 -0
  403. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local__next-internal_server_app_api_linear_worker_route_actions_116303i.js +3 -0
  404. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_01hd2_5._.js +3 -0
  405. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_01pvj2g._.js +34 -0
  406. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_0ik933l._.js +55 -0
  407. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_0o1v.j4._.js +79 -0
  408. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_0pxj122._.js +55 -0
  409. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_automations_index_ts_0_8ch28._.js +10 -0
  410. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_graph_082u-ls._.js +41 -0
  411. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_0.xgxyl._.js +4 -0
  412. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_0yu3--n._.js +4 -0
  413. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_0ze8hzc._.js +4 -0
  414. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_get-store_ts_0p0aod1._.js +5 -5
  415. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_linear-worker_ts_0ycjwem._.js +5 -0
  416. package/cloud-runtime/standalone/apps/local/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0gips_c.js +1 -1
  417. package/cloud-runtime/standalone/apps/local/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0u_5kfo.js +1 -1
  418. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/0rhn_lucide-react_dist_esm_0tvwux2._.js +3 -0
  419. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/0rhn_lucide-react_dist_esm_icons_0hvpc.y._.js +3 -0
  420. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__006vr7.._.js +3 -0
  421. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0d18x53._.js +18 -0
  422. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0j9m72.._.js +18 -0
  423. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/{[root-of-the-server]__02.r909._.js → [root-of-the-server]__0n5g8ml._.js} +2 -2
  424. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0w.zmt6._.js +3 -0
  425. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0w1mm2j._.js +3 -0
  426. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0z7nw_r._.js +3 -0
  427. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__10h_7t0._.js +3 -0
  428. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__13h-0om._.js +3 -0
  429. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_00trrg8._.js +3 -0
  430. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0ejzn1e._.js +1 -1
  431. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0wk3skw._.js +1 -1
  432. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0yeuuy1._.js +25 -0
  433. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/{apps_local_075cq2j._.js → apps_local_0k4~c1x._.js} +2 -2
  434. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_0t6p.qm._.js +3 -0
  435. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/{apps_local_0_4hk8x._.js → apps_local_0v~bvwg._.js} +2 -2
  436. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_agents_[id]_page_tsx_06n47n~._.js +1 -1
  437. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_[slug]_graph_[taskId]_page_tsx_0bctfd-._.js +1 -1
  438. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_[slug]_linear_page_tsx_0a~n5y8._.js +2 -2
  439. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_[slug]_page_tsx_0kcaeqi._.js +1 -1
  440. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_[slug]_teams_new_page_tsx_0yqd0a5._.js +3 -0
  441. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_[slug]_teams_page_tsx_06czvz-._.js +1 -1
  442. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_[slug]_terminal_page_tsx_01n9qk.._.js +12 -12
  443. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_projects_orphans_page_tsx_0sdv.11._.js +1 -1
  444. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_app_setup_page_tsx_0ql2qmr._.js +1 -1
  445. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_components_PromptJobBoard_tsx_06zob36._.js +8 -0
  446. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_components_projects_ProjectObjectivesWorkspace_tsx_0k4tfip._.js +6 -6
  447. package/cloud-runtime/standalone/apps/local/.next/server/functions-config-manifest.json +2 -0
  448. package/cloud-runtime/standalone/apps/local/.next/server/middleware-build-manifest.js +3 -3
  449. package/cloud-runtime/standalone/apps/local/.next/server/middleware-manifest.json +5 -5
  450. package/cloud-runtime/standalone/apps/local/.next/server/pages/404.html +2 -2
  451. package/cloud-runtime/standalone/apps/local/.next/server/pages/500.html +1 -1
  452. package/cloud-runtime/standalone/apps/local/.next/server/server-reference-manifest.js +1 -1
  453. package/cloud-runtime/standalone/apps/local/.next/server/server-reference-manifest.json +1 -1
  454. package/cloud-runtime/standalone/apps/local/.next/static/chunks/003q-y3exxalk.js +1 -0
  455. package/cloud-runtime/standalone/apps/local/.next/static/chunks/00po4v2x~0x_z.js +1 -0
  456. package/cloud-runtime/standalone/apps/local/.next/static/chunks/013gtut17~fne.js +23 -0
  457. package/cloud-runtime/standalone/apps/local/.next/static/chunks/014z_yruiincl.js +1 -0
  458. package/cloud-runtime/standalone/apps/local/.next/static/chunks/041-dhls9zkl1.js +1 -0
  459. package/cloud-runtime/standalone/apps/local/.next/static/chunks/04yoml2rqnuot.js +16 -0
  460. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0_mrpyqcoyb_5.js +1 -0
  461. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{11-u35xqxu~i-.js → 0aewbg0i704w7.js} +1 -1
  462. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{08~pgzjb13k_v.js → 0dnw31436wd~..js} +2 -2
  463. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{0jonp-o8lh-4j.js → 0e307b-0c2jbx.js} +1 -1
  464. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0edewt9l~cs~k.css +1 -0
  465. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{0o9cxba_5mv2c.js → 0fonouj2i9qnb.js} +1 -1
  466. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0gj98094p~zn4.js +1 -0
  467. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0jrkacz_dyem6.js +37 -0
  468. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{02zcxdul-1jaf.js → 0mig99af4~uos.js} +3 -3
  469. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0pdrpsy-zdxp0.js +5 -0
  470. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0p~l5ap6qqx2o.js +1 -0
  471. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0stvi5btlxl4m.js +20 -0
  472. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{0rey9zfvm3yhd.js → 0tt1oh112yv-l.js} +1 -1
  473. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0w94x-v00osq0.js +1 -0
  474. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{0mvqoz13v0o2a.js → 0wh6p5~ft5rma.js} +2 -2
  475. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0zw85-xl9ysjs.js +1 -0
  476. package/cloud-runtime/standalone/apps/local/.next/static/chunks/{00lise4d-u8d1.js → 1011~1x9nj4ny.js} +1 -1
  477. package/cloud-runtime/standalone/apps/local/.next/static/chunks/119v0-idpg-cv.js +16 -0
  478. package/cloud-runtime/standalone/apps/local/.next/static/chunks/11l2tww5f0hsk.js +20 -0
  479. package/cloud-runtime/standalone/apps/local/.next/static/chunks/16d~es6h6k~rj.js +6 -0
  480. package/cloud-runtime/standalone/apps/local/app/agents/[id]/page.tsx +40 -5
  481. package/cloud-runtime/standalone/apps/local/app/api/agents/[id]/profile/route.ts +10 -0
  482. package/cloud-runtime/standalone/apps/local/app/api/linear/worker/route.ts +151 -0
  483. package/cloud-runtime/standalone/apps/local/app/api/projects/[id]/objectives/[objectiveId]/route.ts +0 -8
  484. package/cloud-runtime/standalone/apps/local/app/api/projects/[id]/objectives/[objectiveId]/scheduled-tasks/route.ts +6 -27
  485. package/cloud-runtime/standalone/apps/local/app/api/projects/[id]/objectives/[objectiveId]/worker/route.ts +89 -0
  486. package/cloud-runtime/standalone/apps/local/app/api/projects/[id]/route.ts +13 -0
  487. package/cloud-runtime/standalone/apps/local/app/api/projects/[id]/search/route.ts +4 -4
  488. package/cloud-runtime/standalone/apps/local/app/api/projects/[id]/teams/route.ts +5 -3
  489. package/cloud-runtime/standalone/apps/local/app/api/prompt-jobs/route.ts +7 -4
  490. package/cloud-runtime/standalone/apps/local/app/projects/[slug]/teams/new/page.tsx +236 -10
  491. package/cloud-runtime/standalone/apps/local/app/setup/page.tsx +9 -1
  492. package/cloud-runtime/standalone/apps/local/components/FloatingPanel.tsx +36 -8
  493. package/cloud-runtime/standalone/apps/local/components/LinearBoard.tsx +53 -24
  494. package/cloud-runtime/standalone/apps/local/components/PromptJobBoard.tsx +73 -0
  495. package/cloud-runtime/standalone/apps/local/components/graph/NodeDetailPanel.tsx +17 -12
  496. package/cloud-runtime/standalone/apps/local/components/linear/LinearSettingsModal.tsx +105 -0
  497. package/cloud-runtime/standalone/apps/local/components/linear/LinearWorkerConfig.tsx +367 -0
  498. package/cloud-runtime/standalone/apps/local/components/projects/ObjectiveHealthTrend.tsx +215 -0
  499. package/cloud-runtime/standalone/apps/local/components/projects/ObjectiveScheduledTasksPanel.tsx +170 -46
  500. package/cloud-runtime/standalone/apps/local/components/projects/ProjectHome.tsx +8 -2
  501. package/cloud-runtime/standalone/apps/local/components/projects/ProjectObjectivesWorkspace.tsx +211 -368
  502. package/cloud-runtime/standalone/apps/local/components/projects/RecentlyCompletedCard.tsx +213 -0
  503. package/cloud-runtime/standalone/apps/local/components/projects/TeamsView.tsx +121 -6
  504. package/cloud-runtime/standalone/apps/local/components/scheduling/ScheduleConditionPicker.tsx +1 -1
  505. package/cloud-runtime/standalone/apps/local/components/setup/McpSetupStep.tsx +242 -0
  506. package/cloud-runtime/standalone/apps/local/components/setup/ProjectStep.tsx +2 -2
  507. package/cloud-runtime/standalone/apps/local/components/setup/ProviderStep.tsx +1 -1
  508. package/cloud-runtime/standalone/apps/local/components/setup/TeamsStep.tsx +288 -15
  509. package/cloud-runtime/standalone/apps/local/components/terminal/ProjectTerminal.tsx +24 -14
  510. package/cloud-runtime/standalone/apps/local/hooks/useSetupFlow.ts +16 -2
  511. package/cloud-runtime/standalone/apps/local/lib/objective-health-history.ts +198 -0
  512. package/cloud-runtime/standalone/apps/local/lib/project-objective-context.ts +10 -0
  513. package/cloud-runtime/standalone/apps/local/lib/project-objectives.ts +0 -9
  514. package/cloud-runtime/standalone/apps/local/skills-lock.json +20 -0
  515. package/cloud-runtime/standalone/apps/local/src/automations/adapters.ts +5 -0
  516. package/cloud-runtime/standalone/apps/local/src/automations/types.ts +5 -0
  517. package/cloud-runtime/standalone/apps/local/src/automations/validation.ts +12 -5
  518. package/cloud-runtime/standalone/apps/local/src/objectives/parser.ts +0 -2
  519. package/cloud-runtime/standalone/apps/local/src/objectives/serializer.ts +0 -2
  520. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/linear-worker-constants.ts +38 -0
  521. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/linear-worker-job.ts +47 -0
  522. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/linear-worker.ts +482 -0
  523. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/objective-worker-job.ts +47 -0
  524. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/objective-worker.ts +511 -0
  525. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/processor.ts +51 -417
  526. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/store.ts +19 -4
  527. package/cloud-runtime/standalone/apps/local/src/prompt-scheduler/types.ts +12 -8
  528. package/cloud-runtime/standalone/apps/local/state/terminalTabs.ts +182 -106
  529. package/cloud-runtime/standalone/apps/local/worker/index.js +12 -13
  530. package/package.json +1 -1
  531. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0-0479y._.js +0 -54
  532. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__08oj_ky._.js +0 -49
  533. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__08y2lkj._.js +0 -3
  534. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__09joc_o._.js +0 -3
  535. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0g50c6p._.js +0 -237
  536. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0gtv0rq._.js +0 -8
  537. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0ksbs9p._.js +0 -3
  538. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0pz~m67._.js +0 -3
  539. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0q93mk3._.js +0 -7
  540. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0tdixb0._.js +0 -49
  541. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0vhcrdv._.js +0 -229
  542. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__0xdp_8-._.js +0 -237
  543. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__11s20j6._.js +0 -3
  544. package/cloud-runtime/standalone/apps/local/.next/server/chunks/[root-of-the-server]__12xhcor._.js +0 -54
  545. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_01rag2f._.js +0 -49
  546. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_03y4xss._.js +0 -21
  547. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0cm4i3i._.js +0 -3
  548. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0ijzgnb._.js +0 -3
  549. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_0~fjhfa._.js +0 -3
  550. package/cloud-runtime/standalone/apps/local/.next/server/chunks/_12yasaj._.js +0 -9
  551. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_03q7_.q._.js +0 -21
  552. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0m3e2d~._.js +0 -30
  553. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_0r-oiga._.js +0 -30
  554. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_00cwfvi._.js +0 -34
  555. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_0hx7xyz._.js +0 -34
  556. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_0rqcat4._.js +0 -55
  557. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_0sc_lek._.js +0 -79
  558. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_lib_135ddsu._.js +0 -55
  559. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_graph_store_ts_0h.2qy9._.js +0 -43
  560. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_processor_ts_022nz2u._.js +0 -3
  561. package/cloud-runtime/standalone/apps/local/.next/server/chunks/apps_local_src_prompt-scheduler_processor_ts_0i1av_r._.js +0 -475
  562. package/cloud-runtime/standalone/apps/local/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0yvelwy.js +0 -3
  563. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/0rhn_lucide-react_dist_esm_0qzjdog._.js +0 -3
  564. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/0rhn_lucide-react_dist_esm_icons_0a-mbbj._.js +0 -3
  565. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__07johgg._.js +0 -3
  566. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0bf346q._.js +0 -3
  567. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0r3w68h._.js +0 -18
  568. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0x7k~pk._.js +0 -3
  569. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0y8j6el._.js +0 -18
  570. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0yme9fy._.js +0 -3
  571. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__0~7q5sw._.js +0 -3
  572. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/[root-of-the-server]__13eqcxp._.js +0 -3
  573. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_09~glsn._.js +0 -3
  574. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0n80y4_._.js +0 -3
  575. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0ndrb_0._.js +0 -8
  576. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0ut3k~7._.js +0 -3
  577. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0vibfch._.js +0 -3
  578. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/_0yffwm4._.js +0 -8
  579. package/cloud-runtime/standalone/apps/local/.next/server/chunks/ssr/apps_local_04hvzn_._.js +0 -3
  580. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0.4d8rshxivwh.js +0 -20
  581. package/cloud-runtime/standalone/apps/local/.next/static/chunks/02p3n7faotpr9.js +0 -16
  582. package/cloud-runtime/standalone/apps/local/.next/static/chunks/051-7k0nnm-vm.js +0 -1
  583. package/cloud-runtime/standalone/apps/local/.next/static/chunks/055bzj5jfgzr0.js +0 -1
  584. package/cloud-runtime/standalone/apps/local/.next/static/chunks/05c-~4v_jrblf.css +0 -1
  585. package/cloud-runtime/standalone/apps/local/.next/static/chunks/09wzd7y~tk-3~.js +0 -1
  586. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0brmd4~76pthy.js +0 -20
  587. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0hudzktaaxr4g.js +0 -6
  588. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0hzq698w6f4m6.js +0 -1
  589. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0i.su2yr26wb6.js +0 -37
  590. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0jsbvcyub73d9.js +0 -1
  591. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0l2pt2td_87wr.js +0 -5
  592. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0p7s38p3bcffh.js +0 -1
  593. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0q2dgbluvgxf2.js +0 -16
  594. package/cloud-runtime/standalone/apps/local/.next/static/chunks/0ucg8e2wkd8gf.js +0 -1
  595. package/cloud-runtime/standalone/apps/local/.next/static/chunks/104xjvrf6y-zq.js +0 -1
  596. package/cloud-runtime/standalone/apps/local/.next/static/chunks/15jlly_p-g4c8.js +0 -6
  597. package/cloud-runtime/standalone/apps/local/.next/static/chunks/16nozeadjid9-.js +0 -5
  598. /package/cloud-runtime/standalone/apps/local/.next/static/{fPVnk_kTRzrxXr7U3TRFW → RnYHmEXBwXJjVrVVx2CuP}/_buildManifest.js +0 -0
  599. /package/cloud-runtime/standalone/apps/local/.next/static/{fPVnk_kTRzrxXr7U3TRFW → RnYHmEXBwXJjVrVVx2CuP}/_clientMiddlewareManifest.js +0 -0
  600. /package/cloud-runtime/standalone/apps/local/.next/static/{fPVnk_kTRzrxXr7U3TRFW → RnYHmEXBwXJjVrVVx2CuP}/_ssgManifest.js +0 -0
@@ -1,34 +0,0 @@
1
- module.exports=[209120,133878,930430,e=>{"use strict";function t(){let{createAdminDbClientSQLite:t}=e.r(633211);return t()}e.s(["createAdminDbClient",0,t],209120);let r="Waiting on dependencies";e.s(["formatDependencyBlockedReason",0,function(e){if(!e||0===e.length)return"";let t=e.slice(0,3).map(e=>`${e.title?e.title:e.slug?e.slug:e.id?e.id:"(unknown)"}${(e.stage?.toLowerCase()==="intake"?" (awaiting approval)":e.status?` (${e.status})`:null)??""}`),i=`${r}: ${t.join(", ")}`;return e.length>3&&(i+=` +${e.length-3} more`),i},"isDependencyBlockedReason",0,function(e){return"string"==typeof e&&e.startsWith(r)}],133878);let i=[{value:"task.created",label:"Task created",description:"Fires immediately when a new task is added to the queue."},{value:"task.stage_complete",label:"Stage completed",description:"Emitted whenever a stage finishes and the task advances."},{value:"task.completed",label:"Task completed",description:"When the task reaches a completed status (done)."},{value:"task.failed",label:"Task failed",description:"When the task may have errored, including cancellations."},{value:"task.blocked",label:"Task blocked",description:"When the agent raises the task as blocked awaiting manual input."}].map(e=>e.value);class o extends Error{}function n(e){let t=Array.isArray(e.events)?e.events.filter(e=>"string"==typeof e).map(e=>e.trim()).filter(e=>i.includes(e)):[];return{id:String(e.id),user_id:String(e.user_id),url:String(e.url),name:null!=e.name?String(e.name):null,events:t,enabled:!1!==e.enabled,created_at:String(e.created_at),updated_at:String(e.updated_at)}}async function a(e,t){if(function(e,t){if(!e||"object"!=typeof e)return!1;let r=e.code,i="string"==typeof e.message?e.message:"";return"42P01"===r||"PGRST205"===r||i.includes(`relation "${t}" does not exist`)||i.includes(`Could not find the table 'agx.${t}'`)||i.includes(`Could not find the table 'public.${t}'`)}(t,e))throw new o(`Missing relation: ${e}`);throw t}async function d(e){let r=t(),{data:i,error:o}=await r.from("notification_webhooks").select("*").eq("user_id",e).order("created_at",{ascending:!1});return(o&&await a("notification_webhooks",o),i)?(Array.isArray(i)?i:[i]).map(n):[]}async function s(e){if(!e.userId)return;let t=[];try{t=await d(e.userId)}catch(e){if(e instanceof o)return void console.debug("[notifications] notification_webhooks schema not ready, skipping");console.error("[notifications] failed to load webhooks",e);return}let r=t.filter(t=>t.enabled&&t.events.includes(e.eventType));if(!r.length)return;let i=e.timestamp||new Date().toISOString(),n={eventType:e.eventType,taskId:e.taskId,userId:e.userId,title:e.title||null,slug:e.slug||null,stage:e.stage||null,previousStage:e.previousStage||null,nextStage:e.nextStage||null,status:e.status||null,error:e.error||null,timestamp:i,details:e.details||{}};await Promise.all(r.map(async e=>{try{let t=await fetch(e.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(n)});t.ok||console.error(`[notifications] webhook ${e.url} responded with ${t.status}`)}catch(t){console.error(`[notifications] failed to send to ${e.url}`,t)}}))}e.s(["notifyTaskEvent",0,s],930430)},341902,e=>{"use strict";var t=e.i(902157),r=e.i(660526),i=e.i(750227),o=e.i(666680),n=e.i(180228),a=e.i(633211);let d=process.env.AGX_VAULT_ROOT||i.default.join(process.env.AGX_DATA_DIR||i.default.join(r.default.homedir(),".agx"),"vault");function s(){return new Date().toISOString()}function l(e,t="item"){return String(e||"").toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||t}function c(e){return"number"==typeof e&&Number.isFinite(e)?Math.max(0,Math.min(1,e)):null}function u(e){t.default.mkdirSync(e,{recursive:!0})}function p(e){t.default.existsSync(e)&&t.default.rmSync(e,{recursive:!0,force:!0})}function f(e,r){if(!t.default.existsSync(e))return r;try{return JSON.parse(t.default.readFileSync(e,"utf8"))}catch{return r}}function g(e,r){u(i.default.dirname(e));let o=`${e}.tmp-${process.pid}-${Date.now()}`;t.default.writeFileSync(o,r,"utf8"),t.default.renameSync(o,e)}function m(e,t){g(e,`${JSON.stringify(t,null,2)}
2
- `)}function _(e){return!!e&&"object"==typeof e&&!Array.isArray(e)}function h(e){return String(e||"").replace(/\r\n/g,"\n").split("\n").map(e=>e.replace(/\s+$/g,"")).join("\n").trim()}function y(e,t,r){let i=(0,n.dump)(t,{lineWidth:120,noRefs:!0,sortKeys:!0}).trimEnd(),o=h(r);g(e,o?`---
3
- ${i}
4
- ---
5
- ${o}
6
- `:`---
7
- ${i}
8
- ---
9
- `)}function w(e){if(!t.default.existsSync(e))return null;let r=t.default.readFileSync(e,"utf8"),i=r.match(/^---\n([\s\S]*?)\n---\n?([\s\S]*)$/);if(!i)return{frontmatter:{},body:h(r)};let o=(0,n.load)(i[1]);return{frontmatter:_(o)?o:{},body:h(i[2]??"")}}function j(e){return t.default.existsSync(e)?t.default.readdirSync(e,{withFileTypes:!0}).filter(e=>e.isFile()&&e.name.endsWith(".md")).map(t=>i.default.join(e,t.name)).sort((e,t)=>e.localeCompare(t)):[]}function k(e){let t=new Set,r=[];for(let i of e??[]){let e=String(i??"").trim().toLowerCase();!e||t.has(e)||(t.add(e),r.push(e))}return r}function b(e){let t=[];for(let r of e??[]){let e=String(r?.note??"").trim(),i="string"==typeof r?.id?r.id.trim():"";e&&t.push(i?{id:i,note:e}:{note:e})}return t}function v(e,t,r){return(0,o.createHash)("sha256").update(`${e}
10
- ${t}
11
- ${r}`).digest("hex")}function S(e){return[...e].sort((e,t)=>{let r=e.updatedAt||e.createdAt||"";return(t.updatedAt||t.createdAt||"").localeCompare(r)})}let D=new class{rootDir;constructor(e=d){this.rootDir=e}getRootDir(){return this.ensureRoot(),this.rootDir}registryPath(){return i.default.join(this.rootDir,".agx","registry.json")}globalDir(){return i.default.join(this.rootDir,"_global")}globalAgentsDir(){return i.default.join(this.globalDir(),"Agents")}globalImportedLearningsDir(){return i.default.join(this.globalDir(),"_generated","imported","learnings")}globalEvidenceDir(e){return i.default.join(this.globalDir(),"_generated","evidence",e)}globalPlaybookPath(){return i.default.join(this.globalDir(),"Playbook.md")}projectDir(e){return i.default.join(this.rootDir,e)}projectManifestPath(e){return i.default.join(this.projectDir(e),".agx","manifest.json")}projectContextPath(e){return i.default.join(this.projectDir(e),"Context","Project.md")}projectSkillsDir(e){return i.default.join(this.projectDir(e),"Context","Skills")}projectVariablesDir(e){return i.default.join(this.projectDir(e),"Context","Variables")}projectAgentsIndexPath(e){return i.default.join(this.projectDir(e),"Context","Agents","_index.md")}projectThreadsDir(e){return i.default.join(this.projectDir(e),"Threads")}repoDir(e,t){return i.default.join(this.projectDir(e),"Repos",t)}repoKnowledgePath(e,t){return i.default.join(this.repoDir(e,t),"Knowledge.md")}projectImportedDir(e,t){return i.default.join(this.projectDir(e),"_generated","imported",t)}projectEvidenceDir(e,t){return i.default.join(this.projectDir(e),"_generated","evidence",t)}ensureRoot(){u(i.default.join(this.rootDir,".agx")),u(this.globalDir()),u(this.globalAgentsDir()),u(this.globalImportedLearningsDir()),u(this.globalEvidenceDir("agent")),u(this.globalEvidenceDir("global")),t.default.existsSync(this.registryPath())||this.writeRegistry({version:1,updatedAt:s(),projects:[],agents:[]}),t.default.existsSync(i.default.join(this.globalDir(),"_Index.md"))||g(i.default.join(this.globalDir(),"_Index.md"),"# Global Knowledge\n\n- [[Playbook]]\n- [[Agents]]\n"),t.default.existsSync(this.globalPlaybookPath())||y(this.globalPlaybookPath(),{id:"global-playbook",type:"knowledge-note",scope:"global",subject_id:"playbook",slug:"playbook",title:"Playbook",created_at:s(),updated_at:s(),version:1},"")}readRegistry(){this.ensureRoot();let e={version:1,updatedAt:s(),projects:[],agents:[]},t=f(this.registryPath(),e);return Array.isArray(t.projects)||(t.projects=[]),Array.isArray(t.agents)||(t.agents=[]),t.version=1,t}writeRegistry(e){u(i.default.join(this.rootDir,".agx")),m(this.registryPath(),{version:1,updatedAt:s(),projects:[...e.projects].sort((e,t)=>e.slug.localeCompare(t.slug)),agents:[...e.agents].sort((e,t)=>e.slug.localeCompare(t.slug))})}readManifest(e){return f(this.projectManifestPath(e),null)}writeManifest(e,t){m(this.projectManifestPath(e),{...t,version:1,updatedAt:s(),repos:[...t.repos].sort((e,t)=>e.slug.localeCompare(t.slug)),agents:[...t.agents].sort((e,t)=>e.routing_order-t.routing_order),threads:[...t.threads].sort((e,t)=>e.created_at.localeCompare(t.created_at))})}findProjectRegistryEntry(e){let t=e.trim();return t?this.readRegistry().projects.find(e=>e.id===t||e.slug===t)??null:null}findProjectRegistryEntryById(e){let t=e.trim();return t?this.readRegistry().projects.find(e=>e.id===t)??null:null}findRepoEntry(e){let t=e.trim();if(!t)return null;for(let e of this.readRegistry().projects){let r=e.repos.find(e=>e.id===t);if(r)return{project:e,repo:r}}return null}findAgentEntry(e){let t=e.trim();return t?this.readRegistry().agents.find(e=>e.id===t||e.slug===t)??null:null}nextProjectSlug(e,t){let r=this.readRegistry(),i=l(e,"project"),o=i,n=1;for(;r.projects.some(e=>e.slug===o&&e.id!==t);)n+=1,o=`${i}-${n}`;return o}nextRepoSlug(e,t,r){let i=this.readManifest(e),o=l(t,"repo"),n=o,a=1;for(;i?.repos.some(e=>e.slug===n&&e.id!==r);)a+=1,n=`${o}-${a}`;return n}ensureProjectScaffold(e,r){let o=this.projectDir(e.slug);for(let n of(u(o),u(i.default.join(o,".agx")),u(i.default.join(o,"Context")),u(this.projectSkillsDir(e.slug)),u(this.projectVariablesDir(e.slug)),u(i.default.dirname(this.projectAgentsIndexPath(e.slug))),u(this.projectThreadsDir(e.slug)),u(i.default.join(o,"Repos")),u(this.projectImportedDir(e.slug,"project-memory")),u(this.projectImportedDir(e.slug,"learnings")),u(this.projectEvidenceDir(e.slug,"project")),u(this.projectEvidenceDir(e.slug,"repo")),u(this.projectEvidenceDir(e.slug,"agent")),r))u(this.repoDir(e.slug,n.slug)),u(this.projectImportedDir(e.slug,i.default.join("repo-knowledge",n.slug))),t.default.existsSync(i.default.join(this.repoDir(e.slug,n.slug),"_index.md"))||g(i.default.join(this.repoDir(e.slug,n.slug),"_index.md"),`# ${n.name}
12
-
13
- - [[Knowledge]]
14
- `),t.default.existsSync(this.repoKnowledgePath(e.slug,n.slug))||y(this.repoKnowledgePath(e.slug,n.slug),{id:n.id,type:"knowledge-note",scope:"repo",subject_id:n.id,project_id:e.id,repo_id:n.id,slug:n.slug,title:n.name,created_at:n.created_at,updated_at:n.updated_at,version:1},n.notes??"");t.default.existsSync(i.default.join(o,"_Index.md"))||g(i.default.join(o,"_Index.md"),`# ${e.name}
15
-
16
- - [[Overview]]
17
- - [[Architecture]]
18
- - [[Active Development]]
19
- - [[Design Decisions]]
20
- `),t.default.existsSync(i.default.join(o,"Overview.md"))||g(i.default.join(o,"Overview.md"),`# Overview
21
-
22
- ${e.description?.trim()||""}
23
- `),t.default.existsSync(i.default.join(o,"Architecture.md"))||g(i.default.join(o,"Architecture.md"),"# Architecture\n"),t.default.existsSync(i.default.join(o,"Active Development.md"))||g(i.default.join(o,"Active Development.md"),"# Active Development\n"),t.default.existsSync(i.default.join(o,"Design Decisions.md"))||g(i.default.join(o,"Design Decisions.md"),"# Design Decisions\n"),t.default.existsSync(this.projectContextPath(e.slug))||y(this.projectContextPath(e.slug),{id:e.id,type:"knowledge-note",scope:"project",subject_id:e.id,project_id:e.id,slug:e.slug,title:e.name,created_at:e.created_at,updated_at:e.updated_at,version:1},e.description?.trim()||""),t.default.existsSync(this.projectAgentsIndexPath(e.slug))||y(this.projectAgentsIndexPath(e.slug),{id:`project-agents:${e.id}`,type:"project-agents",project_id:e.id,title:`${e.name} Agents`,created_at:e.created_at,updated_at:e.updated_at,agents:[]},"# Project Agents\n")}toRegistryRepos(e){return e.map(e=>({id:e.id,slug:e.slug,name:e.name,path:e.path??null,git_url:e.git_url??null}))}updateProjectRegistryEntry(e,t){let r=this.readRegistry(),i={id:e.id,slug:e.slug,name:e.name,path:this.projectDir(e.slug),created_at:e.created_at,updated_at:e.updated_at,repos:this.toRegistryRepos(t)},o=r.projects.filter(t=>t.id!==e.id);o.push(i),this.writeRegistry({...r,projects:o})}removeProjectRegistryEntry(e){let t=this.readRegistry();this.writeRegistry({...t,projects:t.projects.filter(t=>t.id!==e)})}ensureAgentRegistryEntry(e,t){let r=this.readRegistry(),o=r.agents.find(t=>t.id===e);if(o)return o;let n=l(t||e,"agent"),a=s(),d={id:e,slug:n,name:t||e,path:i.default.join(this.globalAgentsDir(),`${n}.md`),created_at:a,updated_at:a};return this.writeRegistry({...r,agents:[...r.agents,d]}),d}updateAgentRegistryEntry(e,t){let r=this.readRegistry(),i=r.agents.find(t=>t.id===e);if(!i)return this.ensureAgentRegistryEntry(e,t);let o={...i,name:t,updated_at:s()};return this.writeRegistry({...r,agents:[...r.agents.filter(t=>t.id!==e),o]}),o}listProjects(e,t=!1){return this.readRegistry().projects.filter(e=>t||!e.archived_at).map(t=>this.getProjectWithRepos(t.id,e)).filter(e=>!!e)}getProjectBySlug(e,t){let r=this.getProjectWithRepos(e,t);return r?{...r,repos:void 0}:null}getProjectRepos(e){let t=this.getProjectWithRepos(e);return t?.repos??[]}getProjectWithRepos(e,t){let r=this.findProjectRegistryEntry(e);if(!r)return null;let i=this.readManifest(r.slug);if(!i||t&&i.project.user_id&&i.project.user_id!==t)return null;let o=i.repos.map(e=>({id:e.id,project_id:e.project_id,name:e.name,path:e.path??"",git_url:e.git_url??void 0,notes:this.getKnowledgeNote("repo",e.id)?.content||"",created_at:e.created_at,updated_at:e.updated_at}));return{...i.project,archived_at:r.archived_at??null,repos:o}}createProject(e,t){let r=s(),i=this.nextProjectSlug(t.name||"project"),n={id:(0,o.randomUUID)(),user_id:e,name:t.name.trim(),slug:i,description:t.description?.trim()||"",metadata:{},workflow_id:t.workflow_id??null,created_at:r,updated_at:r},a=(t.repos??[]).map(e=>{let t=this.nextRepoSlug(n.slug,e.name||e.path||"repo");return{id:e.id?.trim()||(0,o.randomUUID)(),project_id:n.id,name:e.name.trim(),path:e.path??"",git_url:e.git_url??void 0,notes:e.notes??"",created_at:r,updated_at:r,slug:t}});for(let e of(this.ensureProjectScaffold(n,a),this.writeManifest(n.slug,{version:1,updatedAt:r,project:n,repos:a,agents:[],threads:[]}),this.updateProjectRegistryEntry(n,a),a))e.notes?.trim()&&this.upsertKnowledgeNote({scope:"repo",subjectId:e.id,content:e.notes,changeSummary:"Initial repo note",sourceType:"manual",sourceId:"project-create",metadata:{project_id:n.id}});return this.getProjectWithRepos(n.id,e)}updateProject(e,r,i){let n=this.getProjectWithRepos(e,r);if(!n)return null;let a=this.readManifest(n.slug);if(!a)return null;let d=i.slug?.trim()?this.nextProjectSlug(i.slug.trim(),n.id):n.slug,l=s(),c={...a.project,name:"string"==typeof i.name&&i.name.trim()?i.name.trim():a.project.name,slug:d,description:void 0!==i.description?i.description??"":a.project.description??"",metadata:void 0!==i.metadata?i.metadata??{}:a.project.metadata??{},ci_cd_info:void 0!==i.ci_cd_info?i.ci_cd_info??void 0:a.project.ci_cd_info,workflow_id:void 0!==i.workflow_id?i.workflow_id??null:a.project.workflow_id,updated_at:l},u=a.repos;if(i.repos){let e=[],t=new Map(a.repos.map(e=>[e.id,e]));for(let r of i.repos){let i=r.id?t.get(r.id):void 0,a=i?.id||r.id?.trim()||(0,o.randomUUID)(),d=i?.slug||this.nextRepoSlug(c.slug,r.name||r.path||"repo",a);e.push({id:a,project_id:n.id,name:r.name.trim(),path:r.path??"",git_url:r.git_url??void 0,notes:r.notes??"",created_at:i?.created_at||l,updated_at:l,slug:d})}for(let t of a.repos)e.some(e=>e.id===t.id)||p(this.repoDir(n.slug,t.slug));u=e}for(let e of(d!==n.slug&&(p(this.projectDir(d)),t.default.renameSync(this.projectDir(n.slug),this.projectDir(d))),this.ensureProjectScaffold(c,u),this.writeManifest(c.slug,{version:1,updatedAt:l,project:c,repos:u,agents:a.agents,threads:a.threads}),this.updateProjectRegistryEntry(c,u),u)){let t=i.repos?.find(t=>(t.id||e.id)===e.id)?.notes;"string"==typeof t&&this.upsertKnowledgeNote({scope:"repo",subjectId:e.id,content:t,changeSummary:"Repo note updated",sourceType:"manual",sourceId:"project-update",metadata:{project_id:c.id}})}return this.getProjectWithRepos(c.id,r)}deleteProject(e,t){if(!this.findProjectRegistryEntryById(e))return;let r=this.readRegistry(),i=r.projects.map(t=>t.id===e?{...t,archived_at:s(),updated_at:s()}:t);this.writeRegistry({...r,projects:i})}getProjectAgents(e){let t=this.findProjectRegistryEntryById(e);if(!t)return[];let r=w(this.projectAgentsIndexPath(t.slug));return[...Array.isArray(r?.frontmatter?.agents)?r.frontmatter.agents:[]].sort((e,t)=>e.routing_order-t.routing_order)}addProjectAgent(e,t,r){let i=this.findProjectRegistryEntryById(e);if(!i)throw Error("Project not found");let o=this.getProjectAgents(e).filter(e=>e.agent_id!==t),n=r??o.length,a=s();o.push({project_id:e,agent_id:t,routing_order:n,created_at:a});let d=o.sort((e,t)=>e.routing_order-t.routing_order).map((e,t)=>({...e,routing_order:t}));return this.writeProjectAgents(i.slug,e,d),d.find(e=>e.agent_id===t)}removeProjectAgent(e,t){let r=this.findProjectRegistryEntryById(e);if(!r)return;let i=this.getProjectAgents(e).filter(e=>e.agent_id!==t).map((e,t)=>({...e,routing_order:t}));this.writeProjectAgents(r.slug,e,i)}reorderProjectAgents(e,t){let r=this.findProjectRegistryEntryById(e);if(!r)return[];let i=new Map(this.getProjectAgents(e).map(e=>[e.agent_id,e])),o=t.map((e,t)=>{let r=i.get(e);return r?{...r,routing_order:t}:null}).filter(e=>!!e);return this.writeProjectAgents(r.slug,e,o),o}writeProjectAgents(e,t,r){let i=this.projectAgentsIndexPath(e),o=w(i),n=o?.frontmatter?.created_at||s();y(i,{id:o?.frontmatter?.id||`project-agents:${t}`,type:"project-agents",project_id:t,title:"Project Agents",created_at:n,updated_at:s(),agents:r},"# Project Agents\n");let a=this.readManifest(e);a&&this.writeManifest(e,{...a,agents:r})}getProjectSkills(e){let t=this.findProjectRegistryEntryById(e);if(!t)return[];let r=[];for(let i of j(this.projectSkillsDir(t.slug))){let t=w(i);if(!t)continue;let o=String(t.frontmatter.id||"").trim(),n=String(t.frontmatter.file||"").trim(),a=String(t.frontmatter.created_at||"");o&&n&&r.push({id:o,project_id:String(t.frontmatter.project_id||e),file:n,condition:"string"==typeof t.frontmatter.condition?t.frontmatter.condition:void 0,created_at:a,updatedAt:a,createdAt:a})}return S(r).map(({updatedAt:e,createdAt:t,...r})=>r)}addProjectSkill(e,t,r){let n=this.findProjectRegistryEntryById(e);if(!n)throw Error("Project not found");let a=s(),d=(0,o.randomUUID)(),c=l(i.default.basename(t)||d,"skill");return y(i.default.join(this.projectSkillsDir(n.slug),`${c}-${d.slice(0,8)}.md`),{id:d,type:"project-skill",project_id:e,title:i.default.basename(t)||t,file:t,condition:r??null,created_at:a,updated_at:a},`# ${i.default.basename(t)||t}
24
- `),{id:d,project_id:e,file:t,condition:r,created_at:a}}removeProjectSkill(e){for(let r of this.readRegistry().projects)for(let i of j(this.projectSkillsDir(r.slug))){let r=w(i);if(r?.frontmatter?.id===e)return void t.default.unlinkSync(i)}}getProjectVariables(e){let t=this.findProjectRegistryEntryById(e);return t?j(this.projectVariablesDir(t.slug)).map(t=>{let r=w(t);return r?{project_id:String(r.frontmatter.project_id||e),key:String(r.frontmatter.key||""),value:String(r.frontmatter.value||"")}:null}).filter(e=>!!e?.key):[]}setProjectVariable(e,t,r){let o=this.findProjectRegistryEntryById(e);if(!o)throw Error("Project not found");let n=i.default.join(this.projectVariablesDir(o.slug),`${l(t,"var")}.md`),a=w(n),d=s();return y(n,{id:a?.frontmatter?.id||`project-variable:${e}:${t}`,type:"project-variable",project_id:e,title:t,key:t,value:r,created_at:a?.frontmatter?.created_at||d,updated_at:d},""),{project_id:e,key:t,value:r}}deleteProjectVariable(e,r){let o=this.findProjectRegistryEntryById(e);if(!o)return;let n=i.default.join(this.projectVariablesDir(o.slug),`${l(r,"var")}.md`);t.default.existsSync(n)&&t.default.unlinkSync(n)}getProjectMemory(e){let t=this.getKnowledgeNote("project",e);return t?.content.trim()?[{id:t.id,project_id:e,content:t.content,source:t.sourceType||"vault",producer:"human",created_at:t.updatedAt}]:[]}addProjectMemory(e,t,r,i="human"){let o=this.getKnowledgeNote("project",e)?.content??"",n=o.trim()?`${o.trim()}
25
-
26
- - ${t.trim().replace(/^\-\s*/,"")}`:t.trim(),{note:a}=this.upsertKnowledgeNote({scope:"project",subjectId:e,content:n,changeSummary:r||"Project memory updated",sourceType:"system"===i?"task_completion":"manual",sourceId:r||"manual-project-memory",metadata:{producer:i}});return{id:a.id,project_id:e,content:a.content,source:a.changeSummary||void 0,producer:i,created_at:a.updatedAt}}deleteProjectMemory(e){let t=this.findProjectRegistryEntryById(e);if(!t)return;let r=this.projectContextPath(t.slug),i=w(r);i&&y(r,{...i.frontmatter,updated_at:s()},"")}getProjectThreads(e){let t=this.findProjectRegistryEntryById(e);if(!t)return[];let r=this.readManifest(t.slug);return r?.threads??[]}addProjectThread(e,t){let r=this.findProjectRegistryEntryById(e);if(!r)throw Error("Project not found");let o=this.readManifest(r.slug);if(!o)throw Error("Project manifest missing");let n=o.threads.find(e=>e.thread_id===t);if(n)return n;let a=s(),d={project_id:e,thread_id:t,created_at:a};return y(i.default.join(this.projectThreadsDir(r.slug),`${encodeURIComponent(t)}.md`),{id:`project-thread:${e}:${t}`,type:"project-thread",project_id:e,thread_id:t,title:t,created_at:a,updated_at:a},`# Thread ${t}
27
- `),this.writeManifest(r.slug,{...o,threads:[...o.threads,d]}),d}removeProjectThread(e,r){let o=this.findProjectRegistryEntryById(e);if(!o)return;let n=this.readManifest(o.slug);if(!n)return;let a=i.default.join(this.projectThreadsDir(o.slug),`${encodeURIComponent(r)}.md`);t.default.existsSync(a)&&t.default.unlinkSync(a),this.writeManifest(o.slug,{...n,threads:n.threads.filter(e=>e.thread_id!==r)})}getProjectForThread(e){for(let t of this.readRegistry().projects){let r=this.readManifest(t.slug);if(r?.threads.some(t=>t.thread_id===e))return r.project.id}return null}getKnowledgeNote(e,t){let r=this.resolveKnowledgeNotePath(e,t);if(!r)return null;let i=w(r.path);if(!i)return null;let o=i.frontmatter;return{id:String(o.id||t),scope:e,subjectId:t,content:i.body,changeSummary:"string"==typeof o.change_summary?o.change_summary:null,sourceType:"string"==typeof o.source_type?o.source_type:"manual",sourceId:"string"==typeof o.source_id?o.source_id:"vault",metadata:_(o.metadata)?o.metadata:{},version:"number"==typeof o.version?o.version:1,createdAt:"string"==typeof o.created_at?o.created_at:s(),updatedAt:"string"==typeof o.updated_at?o.updated_at:s()}}upsertKnowledgeNote(e){let t=this.resolveKnowledgeNotePath(e.scope,e.subjectId,{createIfMissing:!0});if(!t)throw Error(`Cannot resolve knowledge note for ${e.scope}:${e.subjectId}`);let r=this.getKnowledgeNote(e.scope,e.subjectId),i=h(e.content);if(r&&h(r.content)===i)return{note:r,changed:!1};let o=r?.createdAt||s(),n=(r?.version||0)+1,a={...t.frontmatter,updated_at:s(),created_at:o,source_type:e.sourceType,source_id:e.sourceId,change_summary:e.changeSummary??null,version:n,metadata:e.metadata??{}};y(t.path,a,i);let d=this.getKnowledgeNote(e.scope,e.subjectId);if(!d)throw Error("Failed to read knowledge note after write");return{note:d,changed:!0}}resolveKnowledgeNotePath(e,t,r){if("global"===e){let e=s();return this.ensureRoot(),{path:this.globalPlaybookPath(),frontmatter:{id:"global-playbook",type:"knowledge-note",scope:"global",subject_id:t||"playbook",slug:"playbook",title:"Playbook",created_at:e,updated_at:e}}}if("project"===e){let e=this.findProjectRegistryEntryById(t);if(!e)return null;let r=s();return{path:this.projectContextPath(e.slug),frontmatter:{id:t,type:"knowledge-note",scope:"project",subject_id:t,project_id:t,slug:e.slug,title:e.name,created_at:r,updated_at:r}}}if("repo"===e){let e=this.findRepoEntry(t);if(!e)return null;let r=s();return{path:this.repoKnowledgePath(e.project.slug,e.repo.slug),frontmatter:{id:t,type:"knowledge-note",scope:"repo",subject_id:t,project_id:e.project.id,repo_id:t,slug:e.repo.slug,title:e.repo.name,created_at:r,updated_at:r}}}let i=this.findAgentEntry(t)??(r?.createIfMissing?this.ensureAgentRegistryEntry(t,t):null);if(!i)return null;let o=s();return{path:i.path,frontmatter:{id:t,type:"knowledge-note",scope:"agent",subject_id:t,agent_id:t,slug:i.slug,title:i.name,created_at:o,updated_at:o}}}listKnowledgeEntries(e){return S(this.knowledgeEntryFilesForScope(e.scope,e.subjectId).map(t=>{let r=w(t);return r?{id:String(r.frontmatter.id||""),scope:r.frontmatter.scope,subjectId:String(r.frontmatter.subject_id||e.subjectId),sourceType:r.frontmatter.source_type,sourceId:String(r.frontmatter.source_id||""),kind:r.frontmatter.kind,title:String(r.frontmatter.title||""),body:r.body,confidence:c(r.frontmatter.confidence),durability:c(r.frontmatter.durability),tags:k(r.frontmatter.tags),evidence:b(r.frontmatter.evidence),metadata:_(r.frontmatter.metadata)?r.frontmatter.metadata:{},createdAt:String(r.frontmatter.created_at||""),updatedAt:String(r.frontmatter.updated_at||"")}:null}).filter(e=>!!(e?.id&&e.body))).slice(0,e.limit??50)}storeKnowledgeEntries(e){let t=0;for(let r of e){let e=r.subjectId.trim(),i=r.title.trim(),n=r.body.trim(),a=r.sourceId.trim();if(!e||!i||!n||!a)continue;let d=v(r.scope,e,n);if(this.listKnowledgeEntries({scope:r.scope,subjectId:e,limit:500}).find(e=>e.metadata?.content_hash===d))continue;let l=this.nextKnowledgeEntryPath(r.scope,e,i),u=s();y(l,{id:(0,o.randomUUID)(),type:"knowledge-evidence",scope:r.scope,subject_id:e,source_type:r.sourceType,source_id:a,kind:r.kind,title:i,confidence:c(r.confidence),durability:c(r.durability),tags:k(r.tags),evidence:b(r.evidence),metadata:{...r.metadata??{},content_hash:d},content_hash:d,created_at:u,updated_at:u},n),t+=1}return t}knowledgeEntryFilesForScope(e,t){if("global"===e)return j(this.globalEvidenceDir("global"));if("agent"===e)return j(this.globalEvidenceDir("agent")).filter(e=>{let r=w(e);return r?.frontmatter?.subject_id===t});if("project"===e){let e=this.findProjectRegistryEntryById(t);return e?j(this.projectEvidenceDir(e.slug,"project")):[]}let r=this.findRepoEntry(t);return r?j(this.projectEvidenceDir(r.project.slug,"repo")).filter(e=>{let r=w(e);return r?.frontmatter?.subject_id===t}):[]}nextKnowledgeEntryPath(e,t,r){let n=(0,o.randomUUID)(),a=`${l(r,"entry")}-${n.slice(0,8)}.md`;if("global"===e)return i.default.join(this.globalEvidenceDir("global"),a);if("agent"===e)return i.default.join(this.globalEvidenceDir("agent"),a);if("project"===e){let e=this.findProjectRegistryEntryById(t);if(!e)throw Error("Project not found for knowledge entry");return i.default.join(this.projectEvidenceDir(e.slug,"project"),a)}let d=this.findRepoEntry(t);if(!d)throw Error("Repo not found for knowledge entry");return i.default.join(this.projectEvidenceDir(d.project.slug,"repo"),a)}getLearnings(e,t){if("task"===e)return[];if("global"===e){let e=this.getKnowledgeNote("global","playbook");return e?.content.trim()?[{id:e.id,scope:"global",scope_id:void 0,content:e.content,created_at:e.updatedAt}]:[]}if(!t)return[];let r=this.getKnowledgeNote("project",t);return r?.content.trim()?[{id:r.id,scope:"project",scope_id:t,content:r.content,created_at:r.updatedAt}]:[]}addLearning(e,t,r){if("task"===e)throw Error("Task learnings are not handled by VaultStore");let i="global"===e?"global":"project",o="global"===e?"playbook":String(r||"").trim();if(!o)throw Error("scopeId is required for project learnings");let n=this.getKnowledgeNote(i,o)?.content??"",a=`- ${t.trim().replace(/^\-\s*/,"")}`,d=n.trim()?`${n.trim()}
28
- ${a}`:a,{note:s}=this.upsertKnowledgeNote({scope:i,subjectId:o,content:d,changeSummary:"Learning added",sourceType:"manual",sourceId:"manual-learning",metadata:{scope:e}});return{id:s.id,scope:e,scope_id:r,content:s.content,created_at:s.updatedAt}}deleteLearning(e,t,r){if("task"===t)return;let i="global"===t?"playbook":String(r||"").trim();if(!i)return;let o=this.getKnowledgeNote("global"===t?"global":"project",i);o&&o.id===e&&this.upsertKnowledgeNote({scope:"global"===t?"global":"project",subjectId:i,content:"",changeSummary:"Learning cleared",sourceType:"manual",sourceId:"manual-learning-delete",metadata:{scope:t}})}migrateFromLegacyDb(){this.ensureRoot();let e=(0,a.getSQLiteDb)(),t=s(),r=t=>!!e.prepare("SELECT 1 FROM sqlite_master WHERE type='table' AND name = ? LIMIT 1").get(t),o=t=>r(t)?e.prepare(`SELECT * FROM ${t}`).all():[],n=o("projects"),d=o("project_repos"),c=o("project_agents"),u=o("project_skills"),f=o("project_variables"),g=o("project_threads"),m=o("project_memory"),_=r("repo_knowledge")?e.prepare("SELECT id, repo_id, content, producer, created_at FROM repo_knowledge").all():[],h=r("knowledge_notes")?e.prepare("SELECT * FROM knowledge_notes").all():[],w=r("knowledge_entries")?e.prepare("SELECT * FROM knowledge_entries").all():[],j=o("learnings"),k=o("agents"),b=r("agent_memory")?e.prepare("SELECT * FROM agent_memory").all():[];p(this.rootDir),this.ensureRoot();let S=j.filter(e=>"global"===e.scope),D=S.map(e=>`- ${e.content.trim().replace(/^\-\s*/,"")}`).join("\n");this.upsertKnowledgeNote({scope:"global",subjectId:"playbook",content:D,changeSummary:"Imported from legacy learnings",sourceType:"task_completion",sourceId:"vault-import",metadata:{imported_at:t}});let A=0,P=0;for(let e of S)y(i.default.join(this.globalImportedLearningsDir(),`${l(e.id,"learning")}.md`),{id:e.id,type:"imported-artifact",source_table:"learnings",scope:e.scope,created_at:e.created_at||t,updated_at:e.created_at||t,metadata:{scope_id:e.scope_id,user_id:e.user_id}},e.content),A+=1;for(let e of k){let r=h.find(t=>"agent"===t.scope&&t.subject_id===e.id),i=r?.content?.trim()||this.synthesizeAgentNote(e.id,b,w),o=this.updateAgentRegistryEntry(e.id,e.name);y(o.path,{id:e.id,type:"knowledge-note",scope:"agent",subject_id:e.id,agent_id:e.id,slug:o.slug,title:e.name,created_at:r?.created_at||e.created_at||t,updated_at:r?.updated_at||e.updated_at||t,source_type:r?.source_type||"task_completion",source_id:r?.source_id||"vault-import",change_summary:r?.change_summary||"Imported from legacy agent knowledge",version:r?.version||1,metadata:r?.metadata?JSON.parse(r.metadata):{}},this.composeAgentNoteBody(e.name,e.description,i))}for(let e of n){let r={id:e.id,user_id:e.user_id,name:e.name,slug:e.slug||this.nextProjectSlug(e.name||e.id,e.id),description:e.description??"",metadata:e.metadata??{},ci_cd_info:e.ci_cd_info??void 0,workflow_id:e.workflow_id??null,created_at:e.created_at||t,updated_at:e.updated_at||t},o=d.filter(t=>t.project_id===e.id).map(e=>({...e,slug:this.nextRepoSlug(r.slug,e.name||e.path||e.id,e.id)}));this.ensureProjectScaffold(r,o),this.writeManifest(r.slug,{version:1,updatedAt:t,project:r,repos:o,agents:c.filter(e=>e.project_id===r.id).sort((e,t)=>e.routing_order-t.routing_order),threads:g.filter(e=>e.project_id===r.id)}),this.updateProjectRegistryEntry(r,o);let n=h.find(e=>"project"===e.scope&&e.subject_id===r.id),a=n?.content?.trim()||this.synthesizeProjectNote(r.id,m,w);for(let e of(this.upsertKnowledgeNote({scope:"project",subjectId:r.id,content:a,changeSummary:n?.change_summary||"Imported from legacy project knowledge",sourceType:n?.source_type||"task_completion",sourceId:n?.source_id||"vault-import",metadata:n?.metadata?JSON.parse(n.metadata):{imported_at:t}}),y(this.projectContextPath(r.slug),{id:r.id,type:"knowledge-note",scope:"project",subject_id:r.id,project_id:r.id,slug:r.slug,title:r.name,created_at:n?.created_at||r.created_at,updated_at:n?.updated_at||r.updated_at,source_type:n?.source_type||"task_completion",source_id:n?.source_id||"vault-import",change_summary:n?.change_summary||"Imported from legacy project knowledge",version:n?.version||1,metadata:n?.metadata?JSON.parse(n.metadata):{}},a),j.filter(e=>"project"===e.scope&&e.scope_id===r.id)))y(i.default.join(this.projectImportedDir(r.slug,"learnings"),`${l(e.id,"learning")}.md`),{id:e.id,type:"imported-artifact",source_table:"learnings",scope:e.scope,project_id:r.id,created_at:e.created_at||t,updated_at:e.created_at||t,metadata:{scope_id:e.scope_id,user_id:e.user_id}},e.content),A+=1;for(let e of m.filter(e=>e.project_id===r.id))y(i.default.join(this.projectImportedDir(r.slug,"project-memory"),`${l(e.id,"memory")}.md`),{id:e.id,type:"imported-artifact",source_table:"project_memory",source_row_id:e.id,project_id:r.id,producer:e.producer,created_at:e.created_at||t,updated_at:e.created_at||t,metadata:{source:e.source??null}},e.content),A+=1;for(let e of o){let o=h.find(t=>"repo"===t.scope&&t.subject_id===e.id),n=o?.content?.trim()||this.synthesizeRepoNote(e.id,_,w);for(let a of(y(this.repoKnowledgePath(r.slug,e.slug),{id:e.id,type:"knowledge-note",scope:"repo",subject_id:e.id,project_id:r.id,repo_id:e.id,slug:e.slug,title:e.name,created_at:o?.created_at||e.created_at,updated_at:o?.updated_at||e.updated_at,source_type:o?.source_type||"task_completion",source_id:o?.source_id||"vault-import",change_summary:o?.change_summary||"Imported from legacy repo knowledge",version:o?.version||1,metadata:o?.metadata?JSON.parse(o.metadata):{}},n),e.notes?.trim()&&(y(i.default.join(this.projectImportedDir(r.slug,i.default.join("repo-knowledge",e.slug)),`${l(e.id,"repo-notes")}-project-repos-notes.md`),{id:`${e.id}:project_repos.notes`,type:"imported-artifact",source_table:"project_repos",source_row_id:e.id,project_id:r.id,repo_id:e.id,created_at:e.updated_at||e.created_at||t,updated_at:e.updated_at||e.created_at||t},e.notes),A+=1),_.filter(t=>t.repo_id===e.id)))y(i.default.join(this.projectImportedDir(r.slug,i.default.join("repo-knowledge",e.slug)),`${l(a.id,"repo-knowledge")}.md`),{id:a.id,type:"imported-artifact",source_table:"repo_knowledge",source_row_id:a.id,project_id:r.id,repo_id:e.id,producer:a.producer,created_at:a.created_at||t,updated_at:a.created_at||t},a.content),A+=1}for(let e of u.filter(e=>e.project_id===r.id))y(i.default.join(this.projectSkillsDir(r.slug),`${l(i.default.basename(e.file)||e.id,"skill")}-${e.id.slice(0,8)}.md`),{id:e.id,type:"project-skill",project_id:r.id,title:i.default.basename(e.file)||e.file,file:e.file,condition:e.condition??null,created_at:e.created_at||t,updated_at:e.created_at||t},`# ${i.default.basename(e.file)||e.file}
29
- `);for(let e of f.filter(e=>e.project_id===r.id))y(i.default.join(this.projectVariablesDir(r.slug),`${l(e.key,"var")}.md`),{id:`project-variable:${r.id}:${e.key}`,type:"project-variable",project_id:r.id,title:e.key,key:e.key,value:e.value,created_at:t,updated_at:t},"");for(let e of(y(this.projectAgentsIndexPath(r.slug),{id:`project-agents:${r.id}`,type:"project-agents",project_id:r.id,title:"Project Agents",created_at:r.created_at,updated_at:r.updated_at,agents:c.filter(e=>e.project_id===r.id).sort((e,t)=>e.routing_order-t.routing_order)},"# Project Agents\n"),g.filter(e=>e.project_id===r.id)))y(i.default.join(this.projectThreadsDir(r.slug),`${encodeURIComponent(e.thread_id)}.md`),{id:`project-thread:${r.id}:${e.thread_id}`,type:"project-thread",project_id:r.id,thread_id:e.thread_id,title:e.thread_id,created_at:e.created_at||t,updated_at:e.created_at||t},`# Thread ${e.thread_id}
30
- `)}for(let e of w)y(this.nextKnowledgeEntryPath(e.scope,e.subject_id,e.title||e.id),{id:e.id,type:"knowledge-evidence",scope:e.scope,subject_id:e.subject_id,source_type:e.source_type,source_id:e.source_id,kind:e.kind,title:e.title,confidence:e.confidence,durability:e.durability,tags:e.tags?JSON.parse(e.tags):[],evidence:e.evidence?JSON.parse(e.evidence):[],metadata:e.metadata?JSON.parse(e.metadata):{},content_hash:e.content_hash||v(e.scope,e.subject_id,e.body),created_at:e.created_at||t,updated_at:e.updated_at||e.created_at||t},e.body),P+=1;return{projects:n.length,repos:d.length,agents:k.length,importedArtifacts:A,evidenceFiles:P}}composeAgentNoteBody(e,t,r){let i=[`# ${e}`];return t?.trim()&&i.push(`## Identity
31
- ${t.trim()}`),r.trim()&&i.push(`## Portable Knowledge
32
- ${r.trim()}`),i.join("\n\n")}synthesizeProjectNote(e,t,r){return Array.from(new Set([...t.filter(t=>t.project_id===e&&"system"===t.producer).map(e=>e.content.trim()),...r.filter(t=>"project"===t.scope&&t.subject_id===e).map(e=>e.body.trim())].filter(Boolean))).map(e=>`- ${e.replace(/^\-\s*/,"")}`).join("\n")}synthesizeRepoNote(e,t,r){return Array.from(new Set([...t.filter(t=>t.repo_id===e&&"system"===t.producer).map(e=>e.content.trim()),...r.filter(t=>"repo"===t.scope&&t.subject_id===e).map(e=>e.body.trim())].filter(Boolean))).map(e=>`- ${e.replace(/^\-\s*/,"")}`).join("\n")}synthesizeAgentNote(e,t,r){return Array.from(new Set([...t.filter(t=>t.agent_id===e).map(e=>e.content.trim()),...r.filter(t=>"agent"===t.scope&&t.subject_id===e).map(e=>e.body.trim())].filter(Boolean))).map(e=>`- ${e.replace(/^\-\s*/,"")}`).join("\n")}};e.s(["vaultStore",0,D])},623775,e=>{"use strict";var t=e.i(209120),r=e.i(133878),i=e.i(930430),o=e.i(254799),n=e.i(341902);function a(e,t){if(!e)return!1;let r="string"==typeof e.message?e.message:"";return"42P01"===e.code||"PGRST205"===e.code||r.includes(`relation "${t}" does not exist`)||r.includes(`Could not find the table 'agx.${t}'`)||r.includes(`Could not find the table 'public.${t}'`)}async function d(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("user_settings").select("*").eq("user_id",e).maybeSingle();if(o){if(a(o,"user_settings"))return null;throw o}return i||null}async function s(e,r,i){let o=i?.onlyIfNewer!==!1,n=function(e){if("string"==typeof e){let t=Date.parse(e);if(Number.isFinite(t))return new Date(t).toISOString()}return new Date().toISOString()}(r.changed_at),a=await d(e);if(o&&a?.changed_at){let e=Date.parse(a.changed_at),t=Date.parse(n);if(Number.isFinite(e)&&Number.isFinite(t)&&t<=e)return{settings:a,updated:!1}}let s={user_id:e,default_provider:r.default_provider??a?.default_provider??null,models:r.models??a?.models??{},provenance:r.provenance,changed_at:n},l=(0,t.createAdminDbClient)(),{error:c}=await l.from("user_settings").upsert(s,{onConflict:"user_id"});if(c)throw c;let u=await d(e);if(!u)throw Error("Failed to load user_settings after upsert");return{settings:u,updated:!0}}function l(e){return e.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,40)||"task"}async function c(e,t){let r=l(e);for(let i=0;i<5;i++){let{data:i,error:o}=await t.from("tasks").select("id").eq("slug",r).limit(1);if(o)throw o;if(!i||0===i.length)return r;let n=Math.random().toString(36).slice(2,6);r=`${l(e)}-${n}`.slice(0,48)}return`${l(e)}-${Date.now().toString(36).slice(-4)}`.slice(0,48)}async function u(e,t,r,i){let o=l(e);for(let n=0;n<5;n++){let n=r.from("projects").select("id").eq("slug",o).eq("user_id",t);i&&(n=n.neq("id",i));let{data:a,error:d}=await n.limit(1);if(d)throw d;if(!a||0===a.length)return o;let s=Math.random().toString(36).slice(2,6);o=`${l(e)}-${s}`.slice(0,48)}return`${l(e)}-${Date.now().toString(36).slice(-4)}`.slice(0,48)}function p(e){return e??(0,t.createAdminDbClient)()}function f(e){let t=e.trim();if(!t)return[];try{let e=JSON.parse(t);if(Array.isArray(e))return e.map(e=>String(e||"").trim()).filter(Boolean)}catch{}return t.split(",").map(e=>e.trim()).filter(Boolean)}function g(e){let t;if(!e)return[];if(Array.isArray(e))t=e.map(e=>"string"==typeof e?e:null==e?"":String(e)).filter(Boolean);else{if("string"!=typeof e)return[];t=f(e)}return Array.from(new Set(t.map(e=>e.trim()).filter(Boolean)))}function m(e){let t=e.match(/^---\n([\s\S]*?)\n---\n([\s\S]*)$/);if(!t)return{frontmatter:{},body:e};let r={};for(let e of t[1].split("\n")){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t).trim(),o=e.slice(t+1).trim();if("depends_on"===i){r[i]=f(o);continue}"true"===o?r[i]=!0:"false"===o?r[i]=!1:/^\d+$/.test(o)?r[i]=parseInt(o):r[i]=o}}return{frontmatter:r,body:t[2]}}async function _(e,t,r){if(!e||!t?.length)return;let i=p(r),o=new Set,n=[...t];for(;n.length;){let t=n.pop();if(!t)continue;if(t===e)throw Error("Circular dependency detected");if(o.has(t))continue;o.add(t);let{data:r,error:a}=await i.from("tasks").select("depends_on").eq("id",t).maybeSingle();if(a){if("PGRST116"===a.code||"42703"===a.code)continue;throw a}if(r)for(let e of Array.isArray(r.depends_on)?r.depends_on:[])e&&!o.has(e)&&n.push(e)}}function h(e){let{body:t}=m(e),r=t.match(/^#\s+(.+)$/m);return r?r[1]:void 0}function y(e){return String(e||"").replace(/^#\s+.+(\r?\n|$)/,"").trim()}async function w(e,i){let o=Array.isArray(e.depends_on)?e.depends_on:[];if(!o.length)return;let n=(0,t.createAdminDbClient)(),{data:a,error:d}=await n.from("tasks").select("id, title, slug, status, stage").in("id",o);if(d)return;let s=(Array.isArray(a)?a:[]).filter(e=>"completed"!==(e?.status||""));if(s.length){let t=(0,r.formatDependencyBlockedReason)(s),o=n.from("tasks").update({status:"blocked",blocked_reason:t}).eq("id",e.id);i&&(o=o.eq("user_id",i));let{error:a}=await o;if(a&&"42703"!==a.code)throw a;return}if("blocked"===e.status&&(0,r.isDependencyBlockedReason)(e.blocked_reason)){let t=n.from("tasks").update({status:"queued",blocked_reason:null}).eq("id",e.id);i&&(t=t.eq("user_id",i));let{error:r}=await t;if(r&&"42703"!==r.code)throw r}}async function j(e,r){let i=(0,t.createAdminDbClient)().from("tasks").select("*").order("priority",{ascending:!0,nullsFirst:!1}).order("created_at",{ascending:!1});if(e&&(i=i.eq("user_id",e)),r?.project&&(i=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(r.project)?i.eq("project_id",r.project):i.eq("project",r.project)),r?.orphan&&(i=i.is("project_id",null)),r?.status&&(i=i.eq("status",r.status)),r?.search){let e=r.search;i=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(e)?i.or(`id.eq.${e},slug.ilike.%${e}%,title.ilike.%${e}%`):i.or(`id.ilike.%${e}%,slug.ilike.%${e}%,title.ilike.%${e}%`)}let{data:o,error:n}=await i;if(n)throw n;let a=o||[];return r?.orphan?a.filter(e=>{let t=String(e.project||"").trim().toLowerCase();return!t||"none"===t}):a}async function k(e,r){let i=(0,t.createAdminDbClient)().from("tasks").select("*").eq("id",e);r&&(i=i.eq("user_id",r));let{data:o,error:n}=await i.single();if(n){if("PGRST116"===n.code)return null;throw n}return o}async function b(e,r){let i=(0,t.createAdminDbClient)().from("tasks").select("*").eq("slug",e);r&&(i=i.eq("user_id",r));let{data:o,error:n}=await i.single();if(n){if("PGRST116"===n.code)return null;throw n}return o}async function v(e,r,n){let a=(0,t.createAdminDbClient)(),{frontmatter:d,body:s}=m(e),l="boolean"==typeof d.swarm?d.swarm:void 0,u=n?.title||h(e),p=String(d.slug||u||"task"),f=await c(p,a),j=n?.projectId||("string"==typeof d.project_id?d.project_id:void 0),b="string"==typeof d.workflow_id?d.workflow_id:void 0,v="string"==typeof d.project?d.project:void 0;if(!v&&j){let e=await E(j);e?.slug&&(v=e.slug)}/^---\n/.test(e);let S="string"==typeof d.provider?d.provider:null,D="string"==typeof d.model?d.model:null,A="string"==typeof d.engine?d.engine:null,P="ai"===d.created_by?"ai":"user",C=g(d.depends_on),q=g(n?.dependsOn),I=q.length>0?q:C,R={id:(0,o.randomUUID)(),content:e,description:y(s),title:u,slug:f,status:d.status||"queued",stage:d.stage||"intake",project:v||null,...void 0!==j?{project_id:j}:{},...void 0!==b?{workflow_id:b}:{},priority:d.priority,engine:A,provider:S,model:D,swarm:l,swarm_models:n?.swarmModels??null,depends_on:I.length?I:null,created_by:P,user_id:r,current_plan:n?.currentPlan||null,open_blockers:n?.openBlockers||[],next_action:n?.nextAction||null,version:1};await _(R.id,I,a);let{data:$,error:T}=await a.from("tasks").insert(R).select().single();if(T&&"42703"===T.code){let{swarm_models:e,swarm:t,workflow_id:r,current_plan:i,open_blockers:o,next_action:n,version:d,depends_on:s,...l}=R;({data:$,error:T}=await a.from("tasks").insert(l).select().single())}if(T)throw T;if(!$)throw Error("Failed to create task");await w($,r);let x=await k($.id,r)||$,N=r||x.user_id;if(N){let e=x.created_at||new Date().toISOString(),t={dependsOn:Array.isArray(x.depends_on)?x.depends_on:[],project:x.project||null,projectId:x.project_id||null,workflowId:x.workflow_id||null,createdBy:x.created_by||null};(0,i.notifyTaskEvent)({taskId:x.id,userId:N,eventType:"task.created",title:x.title||null,slug:x.slug||null,stage:x.stage||null,status:x.status||null,timestamp:e,details:t})}return x}async function S(e,r,o,n){let a=(0,t.createAdminDbClient)(),{frontmatter:d,body:s}=m(r),l="boolean"==typeof d.swarm?d.swarm:void 0,c=h(r),u="string"==typeof d.project_id?d.project_id:void 0,p=Object.prototype.hasOwnProperty.call(d,"provider"),f=Object.prototype.hasOwnProperty.call(d,"model"),j=Object.prototype.hasOwnProperty.call(d,"workflow_id"),b=Object.prototype.hasOwnProperty.call(d,"depends_on"),v=g(d.depends_on),S=g(n?.dependsOn),D=n?.dependsOn!==void 0||b,A=n?.dependsOn!==void 0?S:v,P={content:r,description:y(s),title:c,status:d.status,stage:d.stage,project:d.project,...void 0!==u?{project_id:u}:{},workflow_id:j?d.workflow_id:void 0,priority:d.priority,engine:d.engine,provider:p?d.provider:null,model:f?d.model:null,swarm:l,swarm_models:n?.swarmModels??void 0,...D?{depends_on:A.length?A:null}:{},updated_at:new Date().toISOString(),current_plan:n?.currentPlan??void 0,open_blockers:n?.openBlockers??void 0,next_action:n?.nextAction??void 0};Object.keys(P).forEach(e=>{void 0===P[e]&&delete P[e]}),D&&await _(e,A,a);let C=a.from("tasks").update({...P,version:a.rpc("increment_version")}).eq("id",e);o&&(C=C.eq("user_id",o)),n?.expectedVersion!==void 0&&(C=C.eq("version",n.expectedVersion));let{data:q,error:I}=await a.from("tasks").update({...P}).eq("id",e).select().maybeSingle();if(I&&console.error(`[db.updateTask] error updating task ${e}:`,I),q||I||console.warn(`[db.updateTask] UPDATE returned 0 rows for task ${e}, payload keys:`,Object.keys(P)),I&&"42703"===I.code){let{swarm_models:t,swarm:r,workflow_id:i,current_plan:n,open_blockers:d,next_action:s,version:l,depends_on:c,...u}=P,p=a.from("tasks").update(u).eq("id",e);o&&(p=p.eq("user_id",o)),{data:q,error:I}=await p.select().maybeSingle()}if(I)throw I;if(!q){let t=await k(e,o);if(!t)throw Error(`Task ${e} not found`);return t}await w(q,o);let R=await k(q.id,o)||q,E=o||R.user_id;if(E){let e=R.created_at||new Date().toISOString(),t={dependsOn:Array.isArray(R.depends_on)?R.depends_on:[],project:R.project||null,projectId:R.project_id||null,workflowId:R.workflow_id||null,createdBy:R.created_by||null};(0,i.notifyTaskEvent)({taskId:R.id,userId:E,eventType:"task.created",title:R.title||null,slug:R.slug||null,stage:R.stage||null,status:R.status||null,timestamp:e,details:t})}return R}async function D(e,r,i=25){let o=(0,t.createAdminDbClient)(),{data:n,error:a}=await o.from("tasks").select("run_index").eq("id",e).single();if(a){if(a?.code==="42703")return;throw a}let d=[r,...Array.isArray(n.run_index)?n.run_index:[]].slice(0,i),{error:s}=await o.from("tasks").update({run_index:d}).eq("id",e);if(s){if(s?.code==="42703")return;throw s}}async function A(e,r){let i=(0,t.createAdminDbClient)().from("tasks").delete().eq("id",e);r&&(i=i.eq("user_id",r));let{error:o}=await i;if(o)throw o}async function P(e){let r=(0,t.createAdminDbClient)().from("tasks").select("*").eq("status","queued").order("priority",{ascending:!0,nullsFirst:!1}).order("created_at",{ascending:!0}).limit(1);e&&(r=r.eq("engine",e));let{data:i,error:o}=await r.single();if(o){if("PGRST116"===o.code)return null;throw o}return i}async function C(e,r=!1){let i=(0,t.createAdminDbClient)().from("projects").select("*, project_repos(*)");e&&(i=i.eq("user_id",e)),r||(i=i.is("archived_at",null));let{data:o,error:n}=await i;if(n){if(a(n,"projects"))return[];throw n}return(o||[]).map(e=>({...e,repos:e.project_repos??[]}))}async function q(e,r){let i=(0,t.createAdminDbClient)().from("projects").select("*").eq("slug",e);r&&(i=i.eq("user_id",r));let{data:o,error:n}=await i.maybeSingle();if(n){if(a(n,"projects"))return null;throw n}return o||null}async function I(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("project_repos").select("*").eq("project_id",e);if(o){if(a(o,"project_repos"))return[];throw o}return i||[]}let R=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;async function E(e,r){let i=(0,t.createAdminDbClient)(),o=R.test(e),n=i.from("projects").select("*");n=o?n.eq("id",e):n.eq("slug",e),r&&(n=n.eq("user_id",r));let d=await n.maybeSingle();if(d.error){if(a(d.error,"projects"))return null;throw d.error}let s=d.data;if(!s)return null;let l=await I(s.id);return{...s,repos:l}}async function $(e,t,r){if(!t.length)return[];let i=t.map(t=>({...t.id?{id:t.id}:{},project_id:e,name:t.name,path:t.path??null,git_url:t.git_url??null,notes:t.notes??null})),{data:o,error:n}=await r.from("project_repos").insert(i).select("*");if(n){if(a(n,"project_repos"))return[];throw n}return o||[]}async function T(e,t,r){if(!t.name?.trim())throw Error("Project name is required");let i=p(r),o=t.name.trim()||"project",n=await u(o,e,i),a={user_id:e,name:t.name.trim(),slug:n,description:t.description??null,workflow_id:t.workflow_id??null},{data:d,error:s}=await i.from("projects").insert(a).select("*").single();if(s)throw s;let l=await $(d.id,t.repos??[],i);return{...d,repos:l}}async function x(e,t,r,i){let o=p(i),n=R.test(e),d=e;if(!n){let r=await q(e,t);if(!r)return null;d=r.id}let s={};if(void 0!==r.name){let e=r.name?.trim();if(!e)throw Error("Project name cannot be empty");s.name=e}if(void 0!==r.slug){let e=r.slug?.trim();e&&(s.slug=e)}if(void 0!==r.description&&(s.description=r.description),void 0!==r.metadata&&(s.metadata=r.metadata),void 0!==r.ci_cd_info&&(s.ci_cd_info=r.ci_cd_info),void 0!==r.workflow_id&&(s.workflow_id=r.workflow_id),Object.keys(s).length){let{error:e}=await o.from("projects").update(s).eq("id",d).eq("user_id",t);if(e)throw e}if(r.repos){let{data:e,error:t}=await o.from("project_repos").select("*").eq("project_id",d);if(t&&!a(t,"project_repos"))throw t;let i=e||[],n=new Set(i.map(e=>e.id)),s=new Set(r.repos.map(e=>e.id).filter(e=>!!e));for(let e of i){if(s.has(e.id))continue;let{error:t}=await o.from("project_repos").delete().eq("id",e.id).eq("project_id",d);if(t&&!a(t,"project_repos"))throw t}for(let e of r.repos){let t={name:e.name,path:e.path??null,git_url:e.git_url??null,notes:e.notes??null,project_id:d};if(e.id&&n.has(e.id)){let{error:r}=await o.from("project_repos").update(t).eq("id",e.id).eq("project_id",d);if(r&&!a(r,"project_repos"))throw r;continue}let{error:r}=await o.from("project_repos").insert({...e.id?{id:e.id}:{},...t});if(r&&!a(r,"project_repos"))throw r}}return E(d,t)}async function N(e,t,r){let i=p(r),{error:o}=await i.from("projects").update({archived_at:new Date().toISOString()}).eq("id",e).eq("user_id",t);if(o)throw o}async function O(e,t,r){let i=p(r),o=await E(e,t);if(!o)throw Error("Project not found");let{data:n,error:a}=await i.from("tasks").select("id, project").eq("user_id",t).is("project_id",null);if(a)throw a;let d=String(o.slug||"").trim().toLowerCase(),s=(n||[]).filter(e=>{let t=String(e.project||"").trim().toLowerCase();return!t||"none"===t||t===d}).map(e=>e.id);if(!s.length)return{updatedCount:0,taskIds:[]};let{error:l}=await i.from("tasks").update({project:o.slug,project_id:o.id,updated_at:new Date().toISOString()}).eq("user_id",t).is("project_id",null).in("id",s);if(l)throw l;return{updatedCount:s.length,taskIds:s}}let M="00000000-0000-0000-0000-000000000001",K=[{id:"00000000-0000-0000-0001-000000000001",name:"INTAKE",label:"Intake",prompt:"New task. Triage, scope, and prepare for work.",position:0,node_type:"step"},{id:"00000000-0000-0000-0001-000000000002",name:"PROGRESS",label:"Progress",prompt:"Task is actively being worked on.",position:1,node_type:"step"},{id:"00000000-0000-0000-0001-000000000003",name:"DONE",label:"Done",prompt:"Task completed.",position:2,node_type:"terminal"}],B=new Map(K.map(e=>[e.id,e]));async function F(e){let r=(0,t.createAdminDbClient)(),{error:i}=await r.from("workflows").upsert({id:M,user_id:e||"00000000-0000-0000-0000-000000000000",name:"Default Workflow",definition:{}},{onConflict:"id"});if(i)throw i;let{error:o}=await r.from("workflow_nodes").upsert(K.map(e=>({...e,workflow_id:M,metadata:{}})),{onConflict:"id"});if(o)throw o;let{error:n}=await r.from("workflow_transitions").upsert([{workflow_id:M,from_node_id:"00000000-0000-0000-0001-000000000001",to_node_id:"00000000-0000-0000-0001-000000000002",condition:"done",priority:0,metadata:{}},{workflow_id:M,from_node_id:"00000000-0000-0000-0001-000000000002",to_node_id:"00000000-0000-0000-0001-000000000003",condition:"done",priority:0,metadata:{}}],{onConflict:"workflow_id,from_node_id,condition"});if(n)throw n}async function L(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("workflows").select("*").or(`user_id.eq.${e},user_id.eq.00000000-0000-0000-0000-000000000000`).order("created_at",{ascending:!1});if(o){if(a(o,"workflows"))return[];throw o}return i||[]}async function W(e,r){let i=(0,t.createAdminDbClient)().from("workflows").select("*").eq("id",e),{data:o,error:n}=await i.maybeSingle();if(n){if(a(n,"workflows"))return null;throw n}return o}async function U(e,r,i){let o=(0,t.createAdminDbClient)(),n={updated_at:new Date().toISOString()};void 0!==i.definition&&(n.definition=i.definition),void 0!==i.name&&(n.name=i.name),void 0!==i.description&&(n.description=i.description);let{data:a,error:d}=await o.from("workflows").update(n).eq("id",e).select().single();if(d)throw d;return a}async function J(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("workflow_nodes").select("*").eq("workflow_id",e).order("position",{ascending:!0});if(o){if(a(o,"workflow_nodes"))return[];throw o}return i||[]}async function V(e,r,i){let o=(0,t.createAdminDbClient)();if(e===M&&await F(r),!await W(e,r))throw Error("Workflow not found");if(e===M){let t=i.map(t=>{let r=B.get(t.id);return r?{id:t.id,workflow_id:e,name:r.name,label:r.label,position:r.position,node_type:r.node_type,prompt:t.prompt??r.prompt,provider:t.provider??null,model:t.model??null,metadata:t.metadata??{}}:null}).filter(e=>!!e);if(t.length>0){let{error:e}=await o.from("workflow_nodes").upsert(t,{onConflict:"id"});if(e)throw e}return J(e)}return await Promise.all(i.map(async t=>{let r={};if(void 0!==t.prompt&&(r.prompt=t.prompt),void 0!==t.provider&&(r.provider=t.provider),void 0!==t.model&&(r.model=t.model),void 0!==t.metadata&&(r.metadata=t.metadata),0===Object.keys(r).length)return;let{error:i}=await o.from("workflow_nodes").update(r).eq("workflow_id",e).eq("id",t.id);if(i)throw i})),J(e)}async function G(e,r){let i=(0,t.createAdminDbClient)(),{data:o,error:n}=await i.from("workflow_nodes").select("*").eq("workflow_id",e).eq("name",r).maybeSingle();if(n){if(a(n,"workflow_nodes"))return null;throw n}return o}async function z(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("workflow_transitions").select("*").eq("workflow_id",e).order("priority",{ascending:!0});if(o){if(a(o,"workflow_transitions"))return[];throw o}return i||[]}async function H(e,r){let i=(0,t.createAdminDbClient)(),{data:o,error:n}=await i.from("workflow_transitions").select("*").eq("workflow_id",e).eq("from_node_id",r).order("priority",{ascending:!0});if(n){if(a(n,"workflow_transitions"))return[];throw n}return o||[]}async function Q(e,t){let r=await W(e,t);if(!r)return null;let[i,o]=await Promise.all([J(e),z(e)]);return{...r,nodes:i,transitions:o}}async function X(e,r={}){let i=(0,t.createAdminDbClient)(),o=Math.max(1,Math.min(2e3,Number(r.limit??r.tail??500))),n="string"==typeof r.after&&r.after.trim()?r.after.trim():null,a=n?null:void 0===r.tail?o:Number(r.tail),d=null!==a&&Number.isFinite(a)&&a>0,s=i.from("task_logs").select("*").eq("task_id",e);r.nodeId&&(s=s.eq("node_id",r.nodeId)),s=n?s.gt("created_at",n).order("created_at",{ascending:!0}).order("id",{ascending:!0}).limit(o):d?s.order("created_at",{ascending:!1}).order("id",{ascending:!1}).limit(o):s.order("created_at",{ascending:!0}).order("id",{ascending:!0}).limit(o);let{data:l,error:c}=await s;if(c)throw c;let u=l||[];return n?u:d?u.slice().reverse():u}async function Y(e,r,i,o){let n=(0,t.createAdminDbClient)(),{data:a,error:d}=await n.from("task_logs").insert({task_id:e,content:r,log_type:i,...o?{node_id:o}:{}}).select().single();if(d)throw d;return a}function Z(e){let t=Number(e??0);return Number.isFinite(t)?Math.max(0,Math.round(t)):0}function ee(e){let t=Number(e??0);return Number.isFinite(t)?Math.max(0,t):0}async function et(e){let r=(0,t.createAdminDbClient)(),i={task_id:e.taskId,stage:e.stage,provider:e.provider??null,model:e.model??null,input_tokens:Z(e.inputTokens),output_tokens:Z(e.outputTokens),estimated_cost:ee(e.estimatedCost)},{data:o,error:n}=await r.from("task_costs").insert(i).select().single();if(n)throw n;return o}async function er(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("task_costs").select("*").eq("task_id",e).order("created_at",{ascending:!0});if(o)throw o;return i||[]}function ei(e){let t={},r=0,i=0,o=0;for(let n of e){let e=n.stage||"unknown",a=Z(n.input_tokens),d=Z(n.output_tokens),s=ee(n.estimated_cost??0);r+=a,i+=d,o+=s;let l=t[e]||{stage:e,input_tokens:0,output_tokens:0,estimated_cost:0,entries:0};l.input_tokens+=a,l.output_tokens+=d,l.estimated_cost+=s,l.entries+=1,t[e]=l}return{total_input_tokens:r,total_output_tokens:i,total_cost:o,per_stage:Object.values(t).sort((e,t)=>e.stage.localeCompare(t.stage))}}async function eo(e){return ei(await er(e))}async function en(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("task_comments").select("*").eq("task_id",e).is("deleted_at",null).order("created_at",{ascending:!0}).order("id",{ascending:!0});if(o)throw o;return i||[]}async function ea(e,r,i,o){let n=(0,t.createAdminDbClient)(),{data:a,error:d}=await n.from("task_comments").insert({task_id:e,content:r,author_type:i,author_id:o??null}).select().single();if(d)throw d;return a}async function ed(e,r){let i=(0,t.createAdminDbClient)(),{data:o,error:n}=await i.from("task_comments").select("author_id, author_type").eq("id",e).single();if(n)throw n;if(!o)throw Error("Comment not found");if("user"!==o.author_type||o.author_id!==r)throw Error("Unauthorized");let{error:a}=await i.from("task_comments").update({deleted_at:new Date().toISOString()}).eq("id",e).is("deleted_at",null);if(a)throw a}async function es(e,r,i){if("task"!==e)return n.vaultStore.getLearnings(e,r);let o=(0,t.createAdminDbClient)().from("learnings").select("*").eq("scope",e).order("created_at",{ascending:!1});r&&(o=o.eq("scope_id",r)),i&&(o=o.eq("user_id",i));let{data:a,error:d}=await o;if(d)throw d;return a||[]}async function el(e,r,i,o){if("task"!==e)return n.vaultStore.addLearning(e,r,i);let a=(0,t.createAdminDbClient)(),{data:d,error:s}=await a.from("learnings").insert({scope:e,scope_id:i,content:r,user_id:o}).select().single();if(s)throw s;return d}async function ec(e,r){if("global-playbook"===e)return void n.vaultStore.deleteLearning(e,"global");let i=await E(e,r);if(i)return void n.vaultStore.deleteLearning(e,"project",i.id);let o=(0,t.createAdminDbClient)().from("learnings").delete().eq("id",e);r&&(o=o.eq("user_id",r));let{error:a}=await o;if(a)throw a}async function eu(e,r){let i=(0,t.createAdminDbClient)().from("stage_prompts").select("*").eq("workflow_id",r).order("stage",{ascending:!0});i=e?i.or(`user_id.eq.${e},is_default.eq.true`):i.eq("is_default",!0);let{data:o,error:n}=await i;if(n)throw n;return o||[]}async function ep(e,r,i){let o=(0,t.createAdminDbClient)();if(r){let{data:t}=await o.from("stage_prompts").select("*").eq("workflow_id",i).eq("stage",e).eq("user_id",r).single();if(t)return t}let{data:n}=await o.from("stage_prompts").select("*").eq("workflow_id",i).eq("stage",e).eq("is_default",!0).single();return n||null}async function ef(e,r,i=[],o,n,a){let d=(0,t.createAdminDbClient)(),s={stage:e,prompt:r,outputs:i,user_id:o,is_default:!o,workflow_id:a};n&&(void 0!==n.swarm&&(s.swarm=n.swarm),void 0!==n.provider&&(s.provider=n.provider),void 0!==n.model&&(s.model=n.model),void 0!==n.swarm_models&&(s.swarm_models=n.swarm_models));let{data:l,error:c}=await d.from("stage_prompts").upsert(s,{onConflict:o?"workflow_id,stage,user_id":"workflow_id,stage,is_default"}).select().single();if(c)throw c;return l}async function eg(e,r){let i=(0,t.createAdminDbClient)().from("stage_prompts").delete().eq("id",e);r&&(i=i.eq("user_id",r));let{error:o}=await i;if(o)throw o}async function em(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("agents").select("*").eq("user_id",e).order("created_at",{ascending:!1});if(o){if(a(o,"agents"))return[];throw o}return i||[]}async function e_(e,r){let i=(0,t.createAdminDbClient)(),{data:o,error:n}=await i.from("agents").select("*").eq("id",e).eq("user_id",r).maybeSingle();if(n){if("PGRST116"===n.code||a(n,"agents"))return null;throw n}return o}async function eh(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("agent_skills").select("*").eq("agent_id",e).order("created_at",{ascending:!0});if(o){if(a(o,"agent_skills"))return[];throw o}return i||[]}async function ey(e,r){let i=(0,t.createAdminDbClient)(),o=new Map;for(let t of r){let r=t.file.trim();r&&o.set(r,{agent_id:e,file:r,condition:t.condition?.trim()||null})}let n=await eh(e);for(let t of n)if(!o.has(t.file)){let{error:r}=await i.from("agent_skills").delete().eq("agent_id",e).eq("file",t.file);if(r&&!a(r,"agent_skills"))throw r}for(let t of o.values()){let r=n.find(e=>e.file===t.file);if(!r){let{error:e}=await i.from("agent_skills").insert(t);if(e&&!a(e,"agent_skills"))throw e;continue}if((r.condition??null)!==t.condition){let{error:r}=await i.from("agent_skills").update({condition:t.condition}).eq("agent_id",e).eq("file",t.file);if(r&&!a(r,"agent_skills"))throw r}}return eh(e)}async function ew(e,r){let i=(0,t.createAdminDbClient)(),o={user_id:e,name:r.name,style:r.style,description:r.description??null};void 0!==r.id&&(o.id=r.id),void 0!==r.title&&(o.title=r.title),void 0!==r.voice&&(o.voice=r.voice),void 0!==r.seed&&(o.seed=r.seed),void 0!==r.model&&(o.model=r.model),void 0!==r.provider&&(o.provider=r.provider),void 0!==r.color&&(o.color=r.color);let{data:n,error:d}=await i.from("agents").insert(o).select().single();if(d){if(a(d,"agents"))throw Error("Agents table does not exist");throw d}return n}async function ej(e,r,i){let o=(0,t.createAdminDbClient)(),n={updated_at:new Date().toISOString()};if(void 0!==i.name&&(n.name=i.name),void 0!==i.title&&(n.title=i.title),void 0!==i.style&&(n.style=i.style),void 0!==i.description&&(n.description=i.description),void 0!==i.voice&&(n.voice=i.voice),void 0!==i.seed&&(n.seed=i.seed),void 0!==i.model&&(n.model=i.model),void 0!==i.provider&&(n.provider=i.provider),void 0!==i.color&&(n.color=i.color),1===Object.keys(n).length)return e_(e,r);let{data:d,error:s}=await o.from("agents").update(n).eq("id",e).eq("user_id",r).select().single();if(s){if("PGRST116"===s.code||a(s,"agents"))return null;throw s}return d}async function ek(e,r){let i=(0,t.createAdminDbClient)(),{error:o}=await i.from("agents").delete().eq("id",e).eq("user_id",r);if(o&&!a(o,"agents"))throw o}async function eb(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("project_agents").select("*").eq("project_id",e).order("routing_order",{ascending:!0});if(o){if(a(o,"project_agents"))return[];throw o}return i||[]}async function ev(e,r,i){let o=(0,t.createAdminDbClient)();if(void 0===i){let{data:t}=await o.from("project_agents").select("routing_order").eq("project_id",e).order("routing_order",{ascending:!1}).limit(1);i=(t?.[0]?.routing_order??-1)+1}let{data:n,error:a}=await o.from("project_agents").upsert({project_id:e,agent_id:r,routing_order:i}).select().single();if(a)throw a;return n}async function eS(e,r){let i=(0,t.createAdminDbClient)(),{error:o}=await i.from("project_agents").delete().eq("project_id",e).eq("agent_id",r);if(o)throw o}async function eD(e,r){let i=(0,t.createAdminDbClient)();for(let t=0;t<r.length;t++)await i.from("project_agents").update({routing_order:t}).eq("project_id",e).eq("agent_id",r[t]);return eb(e)}async function eA(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("teams").select("*").eq("project_id",e).order("created_at",{ascending:!0});if(o){if(a(o,"teams"))return[];throw o}return(i||[]).map(e=>({...e,metadata:"string"==typeof e.metadata?JSON.parse(e.metadata):e.metadata||{}}))}async function eP(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("teams").select("*").eq("id",e).limit(1).single();if(o){if("PGRST116"===o.code||a(o,"teams"))return null;throw o}return i?{...i,metadata:"string"==typeof i.metadata?JSON.parse(i.metadata):i.metadata||{}}:null}async function eC(e,r,i,n){let a=(0,t.createAdminDbClient)(),d=(0,o.randomUUID)(),s=new Date().toISOString(),{data:l,error:c}=await a.from("teams").insert({id:d,project_id:e,name:r,template_id:i||null,metadata:JSON.stringify(n||{}),created_at:s,updated_at:s}).select().single();if(c)throw c;return{...l,metadata:"string"==typeof l.metadata?JSON.parse(l.metadata):l.metadata||{}}}async function eq(e,r){let i=(0,t.createAdminDbClient)(),o={};void 0!==r.name&&(o.name=r.name),void 0!==r.metadata&&(o.metadata=JSON.stringify(r.metadata));let{data:n,error:a}=await i.from("teams").update(o).eq("id",e).select().single();if(a){if("PGRST116"===a.code)return null;throw a}return{...n,metadata:"string"==typeof n.metadata?JSON.parse(n.metadata):n.metadata||{}}}async function eI(e){let r=(0,t.createAdminDbClient)(),{error:i}=await r.from("teams").delete().eq("id",e);if(i)throw i}async function eR(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("team_agents").select("*").eq("team_id",e).order("routing_order",{ascending:!0});if(o){if(a(o,"team_agents"))return[];throw o}return i||[]}async function eE(e,r,i,o){let n=(0,t.createAdminDbClient)();if(void 0===o){let{data:t}=await n.from("team_agents").select("routing_order").eq("team_id",e).order("routing_order",{ascending:!1}).limit(1);o=(t?.[0]?.routing_order??-1)+1}let{data:a,error:d}=await n.from("team_agents").upsert({team_id:e,agent_id:r,role_key:i,routing_order:o}).select().single();if(d)throw d;return a}async function e$(e,r){let i=(0,t.createAdminDbClient)(),{error:o}=await i.from("team_agents").delete().eq("team_id",e).eq("agent_id",r);if(o)throw o}async function eT(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("project_skills").select("*").eq("project_id",e).order("created_at",{ascending:!0});if(o){if(a(o,"project_skills"))return[];throw o}return i||[]}async function ex(e,r,i){let o=(0,t.createAdminDbClient)(),{data:n,error:a}=await o.from("project_skills").insert({project_id:e,file:r,condition:i??null}).select().single();if(a)throw a;return n}async function eN(e){let r=(0,t.createAdminDbClient)(),{error:i}=await r.from("project_skills").delete().eq("id",e);if(i)throw i}async function eO(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("project_variables").select("*").eq("project_id",e);if(o){if(a(o,"project_variables"))return[];throw o}return i||[]}async function eM(e,r,i){let o=(0,t.createAdminDbClient)(),{data:n,error:a}=await o.from("project_variables").upsert({project_id:e,key:r,value:i}).select().single();if(a)throw a;return n}async function eK(e,r){let i=(0,t.createAdminDbClient)(),{error:o}=await i.from("project_variables").delete().eq("project_id",e).eq("key",r);if(o)throw o}async function eB(e,t){return n.vaultStore.getProjectMemory(e)}async function eF(e,t,r,i="human"){return n.vaultStore.addProjectMemory(e,t,r,i)}async function eL(e){n.vaultStore.deleteProjectMemory(e)}async function eW(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("project_threads").select("*").eq("project_id",e).order("created_at",{ascending:!0});if(o){if(a(o,"project_threads"))return[];throw o}return i||[]}async function eU(e,r){let i=(0,t.createAdminDbClient)(),{error:o}=await i.from("project_threads").upsert({project_id:e,thread_id:r},{onConflict:"project_id,thread_id",ignoreDuplicates:!0});if(o)throw o;let{data:n,error:a}=await i.from("project_threads").select("*").eq("project_id",e).eq("thread_id",r).single();if(a)throw a;return n}async function eJ(e,r){let i=(0,t.createAdminDbClient)(),{error:o}=await i.from("project_threads").delete().eq("project_id",e).eq("thread_id",r);if(o)throw o}async function eV(e){let r=(0,t.createAdminDbClient)(),{data:i,error:o}=await r.from("project_threads").select("project_id").eq("thread_id",e).maybeSingle();return o?(a(o,"project_threads"),null):i?.project_id??null}function eG(e,t){let r=[],i=new Set;for(let t of e){let e=t.file.split("/").pop()||t.file;i.add(e),r.push({file:t.file,condition:t.condition,source:"agent"})}for(let e of t){let t=e.file.split("/").pop()||e.file;i.has(t)||r.push({file:e.file,condition:e.condition??void 0,source:"project"})}return r}function ez(e,t){let r=[];for(let e of t)r.push({content:e.content,source:"project",id:e.id});for(let t of e)r.push({content:t.content,source:"agent",id:t.id});return r}async function eH(e){return(await eO(e)).map(e=>({key:e.key,value:e.value,source:"project"}))}async function eQ(e,t,r,i){let o=await eT(t),n=await eB(t),a=await eH(t);return{skills:eG(r,o),memory:ez(i,n),variables:a}}e.s(["DEFAULT_WORKFLOW_ID",0,"00000000-0000-0000-0000-000000000001","addLearning",0,el,"addProjectAgent",0,ev,"addProjectMemory",0,eF,"addProjectSkill",0,ex,"addProjectThread",0,eU,"addTaskComment",0,ea,"addTaskCostEntry",0,et,"addTaskLog",0,Y,"addTeamAgent",0,eE,"appendRunToIndex",0,D,"assignOrphanTasksToProject",0,O,"buildExecutionProvenance",0,eQ,"createAgent",0,ew,"createProject",0,T,"createTask",0,v,"createTeam",0,eC,"defaultStagePrompts",0,{INTAKE:{prompt:"New task. Triage, scope, and prepare for work.",outputs:[],swarm:!1},PROGRESS:{prompt:"Task is actively being worked on.",outputs:[],swarm:!1},DONE:{prompt:"Task completed.",outputs:[],swarm:!1}},"deleteAgent",0,ek,"deleteLearning",0,ec,"deleteProject",0,N,"deleteProjectMemory",0,eL,"deleteProjectVariable",0,eK,"deleteStagePrompt",0,eg,"deleteTask",0,A,"deleteTaskComment",0,ed,"deleteTeam",0,eI,"ensureNoCircularDependency",0,_,"extractTitle",0,h,"getAgent",0,e_,"getAgentSkills",0,eh,"getAgents",0,em,"getDefaultWorkflowId",0,function(){return M},"getLearnings",0,es,"getNextQueuedTask",0,P,"getProjectAgents",0,eb,"getProjectBySlug",0,q,"getProjectForThread",0,eV,"getProjectMemory",0,eB,"getProjectRepos",0,I,"getProjectSkills",0,eT,"getProjectThreads",0,eW,"getProjectVariables",0,eO,"getProjectWithRepos",0,E,"getProjects",0,C,"getStagePrompt",0,ep,"getStagePrompts",0,eu,"getTask",0,k,"getTaskBySlug",0,b,"getTaskComments",0,en,"getTaskCostEntries",0,er,"getTaskCostSummary",0,eo,"getTaskLogs",0,X,"getTasks",0,j,"getTeam",0,eP,"getTeamAgents",0,eR,"getTeams",0,eA,"getUserSettings",0,d,"getWorkflow",0,W,"getWorkflowNodeByName",0,G,"getWorkflowNodes",0,J,"getWorkflowTransitions",0,z,"getWorkflowTransitionsFromNode",0,H,"getWorkflowWithGraph",0,Q,"getWorkflows",0,L,"parseFrontmatter",0,m,"removeProjectAgent",0,eS,"removeProjectSkill",0,eN,"removeProjectThread",0,eJ,"removeTeamAgent",0,e$,"reorderProjectAgents",0,eD,"resolveMemory",0,ez,"resolveSkills",0,eG,"resolveTaskConfig",0,function(t,r,i){let o=e=>"string"!=typeof e?null:e.trim()||null,n=null;try{let t=e.r(522734),r=e.r(814747).join(process.env.HOME||"",".agx","config.json"),i=JSON.parse(t.readFileSync(r,"utf-8"));n=o(i?.defaultProvider)||null}catch{}let a=o(i?.default_provider)||n||"claude",d=o(t.provider)||o(r?.provider)||a,s=o(i?.models?.[d])||null,l=o(t.model)||o(r?.model)||s||null;return{provider:d,model:l,swarm:t.swarm??r?.swarm??!1,swarm_models:t.swarm_models?.length?t.swarm_models:r?.swarm_models||[]}},"resolveVariables",0,eH,"setAgentSkills",0,ey,"setProjectVariable",0,eM,"summarizeTaskCosts",0,ei,"updateAgent",0,ej,"updateProject",0,x,"updateTask",0,S,"updateTeam",0,eq,"updateWorkflow",0,U,"updateWorkflowNodes",0,V,"upsertStagePrompt",0,ef,"upsertUserSettings",0,s])}];
33
-
34
- //# sourceMappingURL=apps_local_lib_0hx7xyz._.js.map
@@ -1,55 +0,0 @@
1
- module.exports=[828549,e=>{"use strict";var t=e.i(623775),r=e.i(633211);class n extends Error{constraint;detail;constructor(e,t){super(e),this.name="ConflictError",this.constraint=t?.constraint,this.detail=t?.detail}}class a extends Error{code;constructor(e,t){super(e),this.name="RetryableError",this.code=t}}class o extends Error{expectedVersion;actualVersion;entityId;entityType;constructor(e,t,r,n){super(void 0!==n?`Concurrent modification on ${e} ${t}: expected version ${r}, found ${n}`:`Concurrent modification on ${e} ${t}: expected version ${r}, row not updated`),this.name="ConcurrentModificationError",this.entityType=e,this.entityId=t,this.expectedVersion=r,this.actualVersion=n}}function s(e){if(!(e instanceof Error))throw e;let t=e.code??"",r=e.message??"";if("SQLITE_CONSTRAINT_UNIQUE"===t||"SQLITE_CONSTRAINT_PRIMARYKEY"===t||"SQLITE_CONSTRAINT"===t&&(r.includes("UNIQUE")||r.includes("PRIMARY KEY"))||r.includes("UNIQUE constraint failed")||r.includes("PRIMARY KEY constraint failed")){let e=r.match(/(?:UNIQUE|PRIMARY KEY) constraint failed: (.+)/);throw new n(r,{constraint:e?.[1],detail:r})}if("SQLITE_BUSY"===t||"SQLITE_LOCKED"===t||r.includes("database is locked"))throw new a(r,t||"SQLITE_BUSY");throw e}async function i(e){try{return await e()}catch(e){if(e instanceof n||e instanceof a||e instanceof o)throw e;s(e)}}e.s(["SQLiteAdapter",0,class{async transaction(e){let t=(0,r.getSQLiteDb)();t.exec("BEGIN IMMEDIATE");try{let r=await e(t);return t.exec("COMMIT"),r}catch(e){try{t.exec("ROLLBACK")}catch{}if(e instanceof n||e instanceof a||e instanceof o)throw e;s(e)}}getTasks(e,r){return t.getTasks(e,r)}getTask(e,r){return t.getTask(e,r)}getTaskBySlug(e,r){return t.getTaskBySlug(e,r)}createTask(e,r,n){return i(()=>t.createTask(e,r,n))}async updateTask(e,n,a,s){let l=s?.expectedVersion;if(void 0!==l){let d=(0,r.getSQLiteDb)();if(0===d.prepare("UPDATE tasks SET version = version + 1 WHERE id = ? AND version = ?").run(e,l).changes){let t=d.prepare("SELECT version FROM tasks WHERE id = ?").get(e);throw new o("task",e,l,t?.version)}let{expectedVersion:u,...c}=s??{};return i(()=>t.updateTask(e,n,a,c))}return(0,r.getSQLiteDb)().prepare("UPDATE tasks SET version = version + 1 WHERE id = ?").run(e),i(()=>t.updateTask(e,n,a,s))}appendRunToIndex(e,r,n){return t.appendRunToIndex(e,r,n)}deleteTask(e,r){return i(()=>t.deleteTask(e,r))}getNextQueuedTask(e){return t.getNextQueuedTask(e)}ensureNoCircularDependency(e,r,n){return t.ensureNoCircularDependency(e,r,n)}getProjects(e,r){return t.getProjects(e,r)}getProjectBySlug(e,r){return t.getProjectBySlug(e,r)}getProjectRepos(e){return t.getProjectRepos(e)}getProjectWithRepos(e,r){return t.getProjectWithRepos(e,r)}createProject(e,r,n){return i(()=>t.createProject(e,r,n))}updateProject(e,r,n,a){return t.updateProject(e,r,n,a)}deleteProject(e,r,n){return i(()=>t.deleteProject(e,r,n))}assignOrphanTasksToProject(e,r,n){return t.assignOrphanTasksToProject(e,r,n)}getWorkflows(e){return t.getWorkflows(e)}getWorkflow(e,r){return t.getWorkflow(e,r)}updateWorkflow(e,r,n){return t.updateWorkflow(e,r,n)}getWorkflowNodes(e){return t.getWorkflowNodes(e)}updateWorkflowNodes(e,r,n){return t.updateWorkflowNodes(e,r,n)}getWorkflowNodeByName(e,r){return t.getWorkflowNodeByName(e,r)}getWorkflowTransitions(e){return t.getWorkflowTransitions(e)}getWorkflowTransitionsFromNode(e,r){return t.getWorkflowTransitionsFromNode(e,r)}getWorkflowWithGraph(e,r){return t.getWorkflowWithGraph(e,r)}getTaskLogs(e,r){return t.getTaskLogs(e,r)}addTaskLog(e,r,n,a){return i(()=>t.addTaskLog(e,r,n,a))}addTaskCostEntry(e){return i(()=>t.addTaskCostEntry(e))}getTaskCostEntries(e){return t.getTaskCostEntries(e)}getTaskCostSummary(e){return t.getTaskCostSummary(e)}getTaskComments(e){return t.getTaskComments(e)}addTaskComment(e,r,n,a){return i(()=>t.addTaskComment(e,r,n,a))}deleteTaskComment(e,r){return i(()=>t.deleteTaskComment(e,r))}getLearnings(e,r,n){return t.getLearnings(e,r,n)}addLearning(e,r,n,a){return i(()=>t.addLearning(e,r,n,a))}deleteLearning(e,r){return i(()=>t.deleteLearning(e,r))}getStagePrompts(e,r){return t.getStagePrompts(e,r)}getStagePrompt(e,r,n){return t.getStagePrompt(e,r,n)}upsertStagePrompt(e,r,n,a,o,s){return i(()=>t.upsertStagePrompt(e,r,n,a,o,s))}deleteStagePrompt(e,r){return t.deleteStagePrompt(e,r)}getAgents(e){return t.getAgents(e)}getAgent(e,r){return t.getAgent(e,r)}createAgent(e,r){return i(()=>t.createAgent(e,r))}updateAgent(e,r,n){return t.updateAgent(e,r,n)}deleteAgent(e,r){return t.deleteAgent(e,r)}getProjectAgents(e){return t.getProjectAgents(e)}addProjectAgent(e,r,n){return i(()=>t.addProjectAgent(e,r,n))}removeProjectAgent(e,r){return t.removeProjectAgent(e,r)}reorderProjectAgents(e,r){return t.reorderProjectAgents(e,r)}getTeams(e){return t.getTeams(e)}getTeam(e){return t.getTeam(e)}createTeam(e,r,n,a){return i(()=>t.createTeam(e,r,n,a))}updateTeam(e,r){return t.updateTeam(e,r)}deleteTeam(e){return t.deleteTeam(e)}getTeamAgents(e){return t.getTeamAgents(e)}addTeamAgent(e,r,n,a){return i(()=>t.addTeamAgent(e,r,n,a))}removeTeamAgent(e,r){return t.removeTeamAgent(e,r)}getProjectSkills(e){return t.getProjectSkills(e)}addProjectSkill(e,r,n){return i(()=>t.addProjectSkill(e,r,n))}removeProjectSkill(e){return t.removeProjectSkill(e)}getProjectVariables(e){return t.getProjectVariables(e)}setProjectVariable(e,r,n){return i(()=>t.setProjectVariable(e,r,n))}deleteProjectVariable(e,r){return t.deleteProjectVariable(e,r)}getProjectMemory(e,r){return t.getProjectMemory(e,r)}addProjectMemory(e,r,n,a){return i(()=>t.addProjectMemory(e,r,n,a))}deleteProjectMemory(e){return t.deleteProjectMemory(e)}getProjectThreads(e){return t.getProjectThreads(e)}addProjectThread(e,r){return i(()=>t.addProjectThread(e,r))}removeProjectThread(e,r){return t.removeProjectThread(e,r)}getProjectForThread(e){return t.getProjectForThread(e)}getUserSettings(e){return t.getUserSettings(e)}upsertUserSettings(e,r,n){return i(()=>t.upsertUserSettings(e,r,n))}async healthCheck(){let e=performance.now();try{return(0,r.getSQLiteDb)().prepare("SELECT 1").get(),{adapter:"sqlite",connected:!0,latencyMs:Math.round(performance.now()-e)}}catch{return{adapter:"sqlite",connected:!1,latencyMs:Math.round(performance.now()-e)}}}}],828549)},929160,e=>{"use strict";let t=function(){let{SQLiteAdapter:t}=e.r(828549);return new t}();e.s(["db",0,t])},733545,e=>{"use strict";var t=e.i(341902);e.s(["getKnowledgeNote",0,function(e,r){return t.vaultStore.getKnowledgeNote(e,r)},"upsertKnowledgeNote",0,function(e){return t.vaultStore.upsertKnowledgeNote(e)}])},461419,e=>{"use strict";var t=e.i(623775);let r=[["INTAKE","PROGRESS","DONE"]];async function n({workflowId:e,currentNodeName:r,decision:a,retryCount:o,maxRetries:s=3}){if("done"===String(r).trim().toLowerCase())return{nextNodeName:"done",nextStatus:"completed",retryCount:0,error:null,appendLog:{content:"Task completed at done",logType:"checkpoint"},nodeConfig:null};let i=await (0,t.getWorkflowNodeByName)(e,r);if(!i)return{nextNodeName:r,nextStatus:"blocked",retryCount:o,error:`Node '${r}' not found in workflow`,appendLog:{content:`Workflow error: node '${r}' not found`,logType:"error"},nodeConfig:null};if("terminal"===i.node_type)return{nextNodeName:r,nextStatus:"completed",retryCount:0,error:null,appendLog:{content:`Task completed at ${i.label||r}`,logType:"checkpoint"},nodeConfig:i};if("blocked"===a)return{nextNodeName:r,nextStatus:"blocked",retryCount:o,error:null,appendLog:{content:"Blocked: additional input required.",logType:"system"},nodeConfig:i};let l=await (0,t.getWorkflowTransitionsFromNode)(e,i.id),d=function(e){switch(e){case"done":default:return"done";case"blocked":return"blocked";case"failed":case"not_done":return"failed"}}(a),u=l.find(e=>e.condition===d);if(u){let n=(await (0,t.getWorkflowNodes)(e)).find(e=>e.id===u.to_node_id);if(n){let e="terminal"===n.node_type;return{nextNodeName:n.name,nextStatus:e?"completed":"queued",retryCount:0,error:null,appendLog:{content:"done"===a?`Stage completed: ${i.label||r}`:`Transition to ${n.label||n.name}`,logType:"done"===a?"checkpoint":"system"},nodeConfig:n}}}if("done"===a)return{nextNodeName:r,nextStatus:"completed",retryCount:0,error:null,appendLog:{content:`Task completed at ${i.label||r}`,logType:"checkpoint"},nodeConfig:i};let c=o+1;return c<=s?{nextNodeName:r,nextStatus:"queued",retryCount:c,error:null,appendLog:{content:`Retrying (${c}/${s}) for ${i.label||r}`,logType:"system"},nodeConfig:i}:{nextNodeName:r,nextStatus:"failed",retryCount:c,error:"Task failed after max retries.",appendLog:{content:"Task failed after max retries.",logType:"error"},nodeConfig:i}}e.s(["getTicketType",0,function(e,t){for(let t of["ticket_type","type","issue_type","kind"])if("spike"===function(e){if("string"!=typeof e)return"task";let t=e.trim().toLowerCase();return"spike"===t||"spikes"===t?"spike":"task"}(e[t]))return"spike";let r=t.match(/^#\s+(.+)$/m),n=r?.[1]?.trim().toLowerCase()||"";return n.startsWith("spike:")||n.startsWith("[spike]")?"spike":"task"},"resolveStageTransition",0,function({currentStage:e,decision:t,ticketType:n,retryCount:a,maxRetries:o=3}){let s=function(e,t){if("spike"===t)return"INTAKE"===e?"PROGRESS":"DONE"===e?null:"DONE";for(let t of r){let r=t.indexOf(e);if(-1!==r){if(r>=t.length-1)return null;return t[r+1]}}return null}(e,n);if("done"===t)return s?{nextStage:s,nextStatus:"queued",retryCount:0,error:null,appendLog:{content:`Stage completed: ${e}`,logType:"checkpoint"}}:{nextStage:"DONE",nextStatus:"completed",retryCount:0,error:null,appendLog:{content:`Task completed at stage ${e}.`,logType:"checkpoint"}};if("blocked"===t)return{nextStage:e,nextStatus:"blocked",retryCount:a,error:null,appendLog:{content:"Blocked: additional input required.",logType:"system"}};if("PROGRESS"===e)return{nextStage:"PROGRESS",nextStatus:"queued",retryCount:0,error:null,appendLog:{content:"Stage not done. Retrying in PROGRESS.",logType:"system"}};let i=a+1;return i<=o?{nextStage:e,nextStatus:"queued",retryCount:i,error:null,appendLog:{content:`Retrying (${i}/${o}) for stage ${e}.`,logType:"system"}}:{nextStage:e,nextStatus:"failed",retryCount:i,error:"Task failed.",appendLog:{content:"Task failed.",logType:"error"}}},"resolveWorkflowTransition",0,n])},389344,e=>{"use strict";var t=e.i(929160),r=e.i(461419),n=e.i(623775),a=e.i(254799),o=e.i(374371),s=e.i(633211),i=e.i(476805),l=e.i(733545);let d=new Set(["outcome","decision","pattern","gotcha"]),u=`You are a memory extractor for a task execution system.
2
- Given a completed task, extract 0-3 memories worth remembering for future tasks.
3
-
4
- Each memory must be:
5
- { "memory_type": "outcome" | "decision" | "pattern" | "gotcha", "content": "one concise sentence" }
6
-
7
- - outcome: what happened (success/failure result)
8
- - decision: a choice that was made and why
9
- - pattern: a reusable approach or technique discovered
10
- - gotcha: a surprising pitfall or edge case encountered
11
-
12
- Return ONLY a JSON array. Return [] if nothing worth remembering.
13
- Do not wrap in markdown code blocks. Just raw JSON.`,c=`You are maintaining a living project knowledge note for a task execution system.
14
- Given the current project note and a completed or failed task, decide whether the note should change.
15
-
16
- Return ONLY a JSON object:
17
- {
18
- "updated_note": "full revised note in concise markdown",
19
- "change_summary": "short summary of what changed",
20
- "no_change": false
21
- }
22
-
23
- Rules:
24
- - Revise the current note instead of appending isolated bullets.
25
- - Write like a person's living project notes, not an extracted fact list.
26
- - The note should help someone understand what the project is, what it does, what has been decided, and what lessons now shape future work.
27
- - Prefer short sections and narrative paragraphs in markdown. Bullets are fine only when they genuinely improve clarity.
28
- - Preserve strong existing content when still valid.
29
- - Merge duplicate ideas, sharpen wording, and remove stale or unsupported claims.
30
- - Only include project-scoped knowledge likely useful across future work in the same project.
31
- - Do not include repo-specific durable truths that belong in repo knowledge.
32
- - Avoid generic filler and avoid sounding like an audit log.
33
- - If nothing project-scoped changed, return {"no_change": true}.
34
- - Do not wrap in markdown code blocks. Just raw JSON.`;async function g(e){let t=[`Goal: ${e.goal}`,`Status: ${e.status}`,e.nodeOutputs?`Node outputs: ${JSON.stringify(e.nodeOutputs).slice(0,2e3)}`:null].filter(Boolean).join("\n"),r=`${u}
35
-
36
- Task:
37
- ${t}`,n="";try{await (0,o.runCliResponse)({provider:"claude",model:"claude-haiku-4-5-20251001",prompt:r,onDelta:e=>{n+=e}})}catch(e){return console.warn("[memory-extractor] LLM call failed:",e),[]}var a=n;let s=a.trim().replace(/^```(?:json)?\s*/i,"").replace(/\s*```\s*$/,"").trim();try{let e=JSON.parse(s);if(!Array.isArray(e))return[];return e.filter(e=>"object"==typeof e&&null!==e&&d.has(e.memory_type)&&"string"==typeof e.content&&e.content.trim().length>0).slice(0,3)}catch{return console.warn("[memory-extractor] Failed to parse LLM response:",s.slice(0,200)),[]}}let p=new Set(["outcome","decision","pattern","gotcha"]),f=["agent_id","agentId","agent","participant_id","participantId","assigned_agent","assignedAgent"];function m(e){return"string"!=typeof e?null:e.trim()||null}function k(e){let t=m(e.explicitAgentId);if(t)return t;let r=e.frontmatter||{};for(let e of f){let t=m(r[e]);if(t)return t}return m(e.defaultUserId)||"system"}async function y(e,t,r){let n=(0,s.getSQLiteDb)().prepare(`INSERT OR IGNORE INTO agent_memory (id, agent_id, task_id, memory_type, content, content_hash, created_at)
38
- VALUES (?, ?, ?, ?, ?, ?, ?)`),o=0,l=Date.now();for(let s of r){if(!p.has(s.memory_type)||!s.content?.trim())continue;let r=(0,a.createHash)("sha256").update(s.content.trim()).digest("hex");n.run((0,a.randomUUID)(),t,e,s.memory_type,s.content.trim(),r,l).changes>0&&o++}return o>0&&(0,i.storeKnowledgeEntries)(r.map(r=>({scope:"agent",subjectId:t,sourceType:"task_completion",sourceId:e,kind:r.memory_type,title:r.content.trim().slice(0,80),body:r.content.trim(),confidence:.7,durability:.6,metadata:{task_id:e}}))),o}async function w(e,t,r){let n=await g(r);if(0===n.length)return;let a=await y(e,t,n);a>0&&console.log(`[memory-extractor] Stored ${a} memories for task ${e}`)}async function S(e){let t=m(e);if(!t)return null;if(/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(t))return t;let r=(0,s.getSQLiteDb)().prepare("SELECT id FROM projects WHERE slug = ? LIMIT 1").get(t);return r?.id??null}async function T(e,t){let r=[`Goal: ${e.goal}`,`Status: ${e.status}`,e.nodeOutputs?`Node outputs: ${JSON.stringify(e.nodeOutputs).slice(0,2e3)}`:null].filter(Boolean).join("\n"),n=`${c}
39
-
40
- Current note:
41
- ${t||"(empty)"}
42
-
43
- Task:
44
- ${r}`,a="";try{await (0,o.runCliResponse)({provider:"claude",model:"claude-haiku-4-5-20251001",prompt:n,onDelta:e=>{a+=e}})}catch(e){return console.warn("[project-knowledge] LLM call failed:",e),[]}let s=a.trim().replace(/^```(?:json)?\s*/i,"").replace(/\s*```\s*$/,"").trim();try{let e=JSON.parse(s);if(!e||"object"!=typeof e||Array.isArray(e))return[];let t="string"==typeof e.updated_note?e.updated_note.trim():"";if(e.no_change||!t)return[];return[{updated_note:t,change_summary:"string"==typeof e.change_summary?e.change_summary.trim():void 0,no_change:!1}]}catch{return console.warn("[project-knowledge] Failed to parse LLM response:",s.slice(0,200)),[]}}async function h(e,t,r){if(0===r.length)return 0;let n=r[0];return n&&n.updated_note?.trim()?+!!(0,l.upsertKnowledgeNote)({scope:"project",subjectId:e,content:n.updated_note.trim(),changeSummary:n.change_summary,sourceType:"task_completion",sourceId:t,metadata:{task_id:t}}).changed:0}async function x(e,t,r){let n=await S(t);if(!n)return;let a=await T(r,(0,l.getKnowledgeNote)("project",n)?.content??"");if(0===a.length)return;let o=await h(n,e,a);o>0&&console.log(`[project-knowledge] Stored ${o} project knowledge entries for task ${e}`)}var _=e.i(209120);function I(e,t){return`---
45
- ${Object.entries(e).map(([e,t])=>`${e}: ${null==t?"":String(t)}`).join("\n")}
46
- ---
47
- ${t}`}var $=e.i(295851),j=e.i(864075);function N(e){if(!e)return[];if(Array.isArray(e))return Array.from(new Set(e.map(e=>String(e||"").trim()).filter(Boolean)));if("string"==typeof e){let t=e.trim();if(!t)return[];try{let e=JSON.parse(t);if(Array.isArray(e))return Array.from(new Set(e.map(e=>String(e||"").trim()).filter(Boolean)))}catch{}return Array.from(new Set(t.split(",").map(e=>e.trim()).filter(Boolean)))}return[]}function b(e){if(!e)return[];let t=N(e.depends_on);if(t.length)return t;if("string"==typeof e.content){let{frontmatter:t}=(0,n.parseFrontmatter)(e.content||"");return N(t.depends_on)}return[]}async function P(e,t){if(!e.length)return[];let r=(0,_.createAdminDbClient)().from("tasks").select("id, title, slug, status, stage").in("id",e);t&&(r=r.eq("user_id",t));let{data:n}=await r,a=new Map;if(Array.isArray(n))for(let e of n){var o;e&&e.id&&a.set(e.id,(o=e.id,e?{id:e.id||o||"",title:e.title||void 0,slug:e.slug||void 0,status:e.status,stage:e.stage}:{id:o||""}))}return e.map(e=>a.get(e)).filter(e=>!!e)}async function A(e,t){let r=b(e);return r.length?(await P(r,t)).filter(e=>"completed"!==(e.status||"")):[]}async function E(e,a,o){let s=a||j.LOCAL_USER.id,i=await t.db.getTask(e,s);if(!i)throw Error(`Task not found: ${e}`);let l=await A(i,s);if(l.length){let t=function(e){if(!e.length)return"";let t=e.slice(0,3).map(e=>{let t=e.title||e.slug||e.id||"(unknown)",r="INTAKE"===e.stage?"awaiting approval":e.status||"",n=r?` (${r})`:"";return`${t}${n}`}),r=`Waiting on dependencies: ${t.join(", ")}`;return e.length>3&&(r+=` +${e.length-3} more`),r}(l),r=(0,_.createAdminDbClient)(),{error:n}=await r.from("tasks").update({status:"blocked",blocked_reason:t,updated_at:new Date().toISOString()}).eq("id",e);if(n&&"42703"!==n.code)throw n;return{started:!1,missingDependencies:l,blockedReason:t}}if(!o?.force&&"queued"===i.status&&!i.blocked_reason)return{started:!1,missingDependencies:[],alreadyQueued:!0};let{frontmatter:d,body:u}=(0,n.parseFrontmatter)(i.content||""),c=o?.ticketType??(0,r.getTicketType)(d,u),g=await (0,$.getQueue)(),p=await g.send($.QUEUE_NAMES.TASK_PROCESS,{taskId:e,userId:s,signal:"start",ticketType:c}),f=(0,_.createAdminDbClient)(),{error:m}=await f.from("tasks").update({status:"queued",blocked_reason:null,updated_at:new Date().toISOString()}).eq("id",e);if(m&&"42703"!==m.code)throw m;return{started:!!p,jobId:p,missingDependencies:[],ticketType:c}}async function C(e,t){let r=t||j.LOCAL_USER.id,n=(0,_.createAdminDbClient)(),a=n.from("tasks").select("id").contains("depends_on",[e]);t&&(a=a.eq("user_id",t));let{data:o,error:s}=await a,i=Array.isArray(o)?o.map(e=>e?.id).filter(Boolean):[];if(s&&"42703"===s.code){let r=n.from("tasks").select("id, content");t&&(r=r.eq("user_id",t));let{data:a}=await r;i=(Array.isArray(a)?a:[]).filter(t=>b(t).includes(e)).map(e=>e?.id).filter(Boolean)}i.length&&await Promise.all(i.map(e=>E(e,r)))}var v=e.i(930430);async function L(e){let t=(0,_.createAdminDbClient)();await t.from("tasks").update({stage:e.stage,status:"queued",updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId)}async function R(e){let t=(0,_.createAdminDbClient)(),{data:r}=await t.from("tasks").select("stage_decisions").eq("id",e.taskId).eq("user_id",e.userId).maybeSingle(),n={...r?.stage_decisions&&"object"==typeof r.stage_decisions?r.stage_decisions:{},[e.stage]:{decision:e.decision.decision,rationale:e.decision.explanation,final_result:e.decision.final_result,decided_at:new Date().toISOString()}},{error:a}=await t.from("tasks").update({stage_decisions:n,updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId);if(a&&!function(e){if(!e||"object"!=typeof e)return!1;let t="code"in e?String(e.code):"",r="message"in e?String(e.message).toLowerCase():"";return("PGRST204"===t||"42703"===t)&&r.includes("stage_decisions")}(a))throw a}async function O(e){let r=await t.db.getTask(e.taskId,e.userId);if(!r)throw Error(`Task ${e.taskId} not found`);let a=r.stage||null,o=new Date().toISOString(),s={taskId:e.taskId,userId:e.userId,title:r.title||null,slug:r.slug||null,timestamp:o},{frontmatter:i,body:l}=(0,n.parseFrontmatter)(r.content),d=k({defaultUserId:e.userId,frontmatter:i});i.stage=e.nextStage,i.status=e.nextStatus,e.error?i.error=e.error:"error"in i&&delete i.error;let u=I(i,l);await t.db.updateTask(e.taskId,u,e.userId);let c=(0,_.createAdminDbClient)(),{error:g}=await c.from("tasks").update({stage:e.nextStage,status:e.nextStatus,retry_count:e.retryCount,error:e.error,updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId);g?console.error(`[applyStageTransition] direct update failed for ${e.taskId}:`,g):console.log(`[applyStageTransition] set ${e.taskId} to status=${e.nextStatus}, stage=${e.nextStage}`),"completed"===e.nextStatus&&(await c.from("tasks").update({completed_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId),await C(e.taskId,e.userId)),("completed"===e.nextStatus||"failed"===e.nextStatus)&&(w(e.taskId,d,{goal:String(r.content||r.title||""),status:String(e.nextStatus)}).catch(e=>console.warn("[applyStageTransition] Memory extraction failed:",e)),x(e.taskId,r.project_id||r.project,{goal:String(r.content||r.title||""),status:String(e.nextStatus)}).catch(e=>console.warn("[applyStageTransition] Project knowledge extraction failed:",e))),"blocked"!==e.nextStatus&&"failed"!==e.nextStatus&&(0,v.notifyTaskEvent)({...s,eventType:"task.stage_complete",stage:a,previousStage:a,nextStage:e.nextStage,status:e.nextStatus,details:{nextStatus:e.nextStatus}}),"completed"===e.nextStatus&&(0,v.notifyTaskEvent)({...s,eventType:"task.completed",stage:e.nextStage,status:e.nextStatus,details:{previousStage:a,nextStage:e.nextStage}}),"failed"===e.nextStatus&&(0,v.notifyTaskEvent)({...s,eventType:"task.failed",stage:e.nextStage,status:e.nextStatus,error:e.error,details:{previousStage:a}})}async function D(e){await t.db.addTaskLog(e.taskId,e.content,e.logType)}async function W(e){await t.db.addTaskComment(e.taskId,e.content,e.authorType||"agent")}async function M(e){let r=await t.db.getTask(e.taskId,e.userId);if(!r)return;let{frontmatter:a,body:o}=(0,n.parseFrontmatter)(r.content),s=k({defaultUserId:e.userId,frontmatter:a});a.status="failed",a.error=e.reason||"Cancelled";let i=I(a,o);await t.db.updateTask(e.taskId,i,e.userId),await t.db.addTaskLog(e.taskId,e.reason||"Task cancelled","error"),w(e.taskId,s,{goal:String(r.content||r.title||""),status:"failed"}).catch(e=>console.warn("[markCancelled] Memory extraction failed:",e)),x(e.taskId,r.project_id||r.project,{goal:String(r.content||r.title||""),status:"failed"}).catch(e=>console.warn("[markCancelled] Project knowledge extraction failed:",e));let l=(0,_.createAdminDbClient)();await l.from("tasks").update({status:"failed",error:e.reason||"Cancelled",updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId),(0,v.notifyTaskEvent)({taskId:e.taskId,userId:e.userId,eventType:"task.failed",title:r.title||null,slug:r.slug||null,stage:r.stage||null,status:"failed",error:e.reason||"Cancelled",timestamp:new Date().toISOString(),details:{previousStage:r.stage||null}})}async function q(e){let{taskId:r,userId:n,signal:a,payload:o,ticketType:s="task"}=e.data,i=await t.db.getTask(r,n);if(!i)return void console.log(`[processor] Task ${r} not found, skipping`);if("completed"===i.status||"failed"===i.status)return void console.log(`[processor] Task ${r} is ${i.status}, skipping`);let l=i.stage;switch(a){case"start":await B(r,l,n);break;case"agentResult":await Q(r,l,n,o,s,i.retry_count||0,i.workflow_id&&/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(i.workflow_id)?i.workflow_id:null);break;case"humanInput":await K(r,o);break;case"daemonStep":await G(r,o);break;case"cancel":await Y(r,n,o?.reason);break;default:console.warn(`[processor] Unknown signal: ${a}`)}}async function U(e){for(let t of e)try{await q(t)}catch(e){throw console.error(`[processor] Error processing job ${t.id}:`,e),e}}async function B(e,t,r){console.log(`[processor] Starting task ${e} at stage ${t}`),await L({taskId:e,stage:t,userId:r}),await D({taskId:e,content:`Task started at stage: ${t}`,logType:"system"})}async function Q(e,t,n,a,o,s,i=null){let l,d,u;console.log(`[processor] Processing agent result for ${e}: ${a.decision}`),await R({taskId:e,stage:t,decision:a,userId:n});let c=Array.isArray(a.comments)?a.comments.map(e=>String(e||"").trim()).filter(Boolean):[],g=String(a.comment||a.log||a.final_result||"").trim();for(let t of c.length>0?c:g.split("\n").map(e=>e.trim()).filter(Boolean))await W({taskId:e,content:t,authorType:"agent"});let p=null,f=null;if(i){let e=await (0,r.resolveWorkflowTransition)({workflowId:i,currentNodeName:t,decision:a.decision,retryCount:s,maxRetries:3});l=e.nextNodeName,d=e.nextStatus,u=e.retryCount,p=e.error,f=e.appendLog,console.log(`[processor] Workflow transition: ${t} -> ${l} (workflow: ${i})`)}else{let e=(0,r.resolveStageTransition)({currentStage:t,decision:a.decision,ticketType:o,retryCount:s,maxRetries:3});l=e.nextStage,d=e.nextStatus,u=e.retryCount,p=e.error,f=e.appendLog}if(await O({taskId:e,nextStage:l,nextStatus:d,retryCount:u,error:p?a.explanation||p:null,userId:n}),f){let t="error"===f.logType&&a.explanation||"system"===f.logType&&a.explanation?a.explanation:f.content;await D({taskId:e,content:t,logType:f.logType})}console.log(`[processor] Task ${e} transitioned: ${t} -> ${l}`)}async function K(e,t){console.log(`[processor] Recording human input for ${e}`),await W({taskId:e,content:t.content,authorType:t.authorType||"user"})}async function G(e,t){let r=t.provider?` provider=${t.provider}`:"",n=t.model?` model=${t.model}`:"",a=t.role?` role=${t.role}`:"",o="number"==typeof t.iteration?` iter=${t.iteration}`:"",s="exit"===t.phase?` exit=${t.exit_code}`:"",i=t.error?` error=${t.error}`:"",l=Array.isArray(t.args)?t.args.join(" "):"",d=t.stdout_tail?`
48
- stdout_tail:
49
- ${t.stdout_tail}`:"",u=t.stderr_tail?`
50
- stderr_tail:
51
- ${t.stderr_tail}`:"",c=`[execution/${t.kind||"daemon"}] ${t.phase||"event"} ${t.label||""}${r}${n}${a}${o}${s}${i}`.trim()+(l?`
52
- args: ${l}`:"")+(t.duration_ms?`
53
- duration_ms: ${t.duration_ms}`:"")+d+u;await D({taskId:e,content:c,logType:"system"})}async function Y(e,t,r){console.log(`[processor] Cancelling task ${e}: ${r||"No reason"}`),await M({taskId:e,reason:r,userId:t})}e.s(["taskProcessor",0,U],389344)}];
54
-
55
- //# sourceMappingURL=apps_local_lib_0rqcat4._.js.map
@@ -1,79 +0,0 @@
1
- module.exports=[796283,e=>{"use strict";e.s(["BASH_FUNCTION_TIMEOUT_MS",0,3e4,"CHECK_NPM_BUILD_TIMEOUT_MS",0,6e5,"CHECK_NPM_COVERAGE_TIMEOUT_MS",0,3e5,"CHECK_NPM_LINT_TIMEOUT_MS",0,6e4,"CHECK_NPM_TEST_TIMEOUT_MS",0,3e5,"CHECK_NPM_TYPECHECK_TIMEOUT_MS",0,12e4,"GRAPH_TIMEOUT_DEFAULT_MS",0,864e5,"NODE_TIMEOUT_DEFAULT_MS",0,18e5,"PS_COMMAND_TIMEOUT_MS",0,5e3,"QUEUE_POLL_INTERVAL_MS",0,1e3,"SCHEDULE_POLL_INTERVAL_MS",0,5e3,"SHELL_COMMAND_TIMEOUT_MS",0,5e3,"SKILLS_CACHE_TTL_MS",0,36e5,"SKILL_DETAIL_CACHE_TTL_MS",0,36e5,"SKILL_FETCH_TIMEOUT_MS",0,12e4,"STEER_DUPLICATE_WINDOW_MS",0,9e5,"WRITE_RATE_SAMPLE_WINDOW_MS",0,1e4,"WRITE_RATE_WARNING_COOLDOWN_MS",0,6e4])},801243,e=>{"use strict";e.s(["pragmaAll",0,function(e,t){return e.prepare(`PRAGMA ${t}`).all()},"pragmaGet",0,function(e,t){let r=e.prepare(`PRAGMA ${t}`).get();if(!r)return;let a=Object.values(r);return a.length>0?a[0]:void 0},"pragmaSet",0,function(e,t){e.exec(`PRAGMA ${t}`)},"transaction",0,function(e,t){e.exec("BEGIN");try{let r=t();return e.exec("COMMIT"),r}catch(t){throw e.exec("ROLLBACK"),t}},"transactionFn",0,function(e,t){return(...r)=>{e.exec("BEGIN");try{let a=t(...r);return e.exec("COMMIT"),a}catch(t){throw e.exec("ROLLBACK"),t}}}])},610613,e=>{"use strict";e.x("node:sqlite",()=>require("node:sqlite"),!0);var t=e.i(801243),r=e.i(522734),a=e.i(446786),i=e.i(814747);let s="3.35.0",n=["json1"],o=["fts5"],l=["nfs","smb","cifs","efs","fuse.sshfs"];function u(e,t){try{if("json1"===t)return e.prepare("SELECT json('{}')").get(),!0;if("fts5"===t)return e.exec("CREATE VIRTUAL TABLE IF NOT EXISTS _fts5_check USING fts5(x)"),e.exec("DROP TABLE IF EXISTS _fts5_check"),!0;return!1}catch{return!1}}e.s(["validateSQLiteEnvironment",0,function(d,_){let E=[],c=d.prepare("SELECT sqlite_version() as v").get();for(let e of(0>function(e,t){let r=e.split(".").map(Number),a=t.split(".").map(Number);for(let e=0;e<3;e++){let t=(r[e]||0)-(a[e]||0);if(0!==t)return t}return 0}(c.v,s)&&E.push({kind:"version_mismatch",message:`SQLite version ${c.v} is below minimum ${s}`,found:c.v,required:`>= ${s}`,fix:"Ensure Node.js >= 22.16 is installed (node:sqlite is built-in)"}),n))u(d,e)||E.push({kind:"missing_extension",message:`Required SQLite extension '${e}' is not available`,required:e,fix:`Rebuild SQLite with -DSQLITE_ENABLE_${e.toUpperCase()}=1, or use a system SQLite that includes it`});for(let e of o)u(d,e)||console.warn(`[startup] Recommended SQLite extension '${e}' is not available. Full-text search will be disabled.`);let p=function(t){"linux"!==a.default.platform()&&a.default.platform();try{let s=i.default.resolve(t),{execSync:n}=e.r(233405);if("darwin"===a.default.platform());else{let e=r.default.readFileSync("/proc/mounts","utf-8"),t="",a="unknown";for(let r of e.split("\n")){let[,e,i]=r.split(/\s+/);e&&s.startsWith(e)&&e.length>t.length&&(t=e,a=i||"unknown")}return a}}catch{}return null}(_);p&&l.some(e=>p.toLowerCase().includes(e))&&E.push({kind:"filesystem_error",message:`Database path '${_}' is on a network filesystem (${p})`,path:_,found:p,fix:"Move the database file to a local SSD. WAL mode requires local filesystem with reliable fsync."});try{(0,t.pragmaSet)(d,"journal_mode = wal"),(0,t.pragmaSet)(d,"foreign_keys = 1"),(0,t.pragmaSet)(d,"busy_timeout = 5000"),(0,t.pragmaSet)(d,"synchronous = 1"),(0,t.pragmaSet)(d,"cache_size = -64000");let e=(0,t.pragmaGet)(d,"journal_mode").toLowerCase(),r=new Set(["wal","delete"]);if(!r.has(e)){(0,t.pragmaSet)(d,"journal_mode = DELETE");let e=(0,t.pragmaGet)(d,"journal_mode").toLowerCase();r.has(e)?((0,t.pragmaSet)(d,"synchronous = FULL"),console.warn(`[startup] WAL unavailable, using journal_mode=${e} with synchronous=FULL`)):E.push({kind:"pragma_error",message:`Failed to set journal_mode (got '${e}', tried WAL then DELETE)`,found:e,required:"wal or delete",fix:"Ensure the database file is on a local filesystem and no other process holds an exclusive lock."})}}catch(e){E.push({kind:"pragma_error",message:`Failed to apply required PRAGMAs: ${e.message}`,fix:"Check file permissions and ensure the database is not read-only."})}return E}])},476805,e=>{"use strict";var t=e.i(341902);e.s(["listKnowledgeEntries",0,function(e){return t.vaultStore.listKnowledgeEntries(e)},"storeKnowledgeEntries",0,function(e){return t.vaultStore.storeKnowledgeEntries(e)}])},295851,e=>{"use strict";var t=e.x("node:sqlite",()=>require("node:sqlite"),!0),r=e.i(801243),a=e.i(666680);let i={randomUUID:a.randomUUID},s=new Uint8Array(256),n=s.length,o=[];for(let e=0;e<256;++e)o.push((e+256).toString(16).slice(1));let l=function(e,t,r){if(i.randomUUID&&!t&&!e)return i.randomUUID();var l=e,u=r;let d=(l=l||{}).random??l.rng?.()??(n>s.length-16&&((0,a.randomFillSync)(s),n=0),s.slice(n,n+=16));if(d.length<16)throw Error("Random bytes length must be >= 16");if(d[6]=15&d[6]|64,d[8]=63&d[8]|128,t){if((u=u||0)<0||u+16>t.length)throw RangeError(`UUID byte range ${u}:${u+15} is out of buffer bounds`);for(let e=0;e<16;++e)t[u+e]=d[e];return t}return function(e,t=0){return(o[e[t+0]]+o[e[t+1]]+o[e[t+2]]+o[e[t+3]]+"-"+o[e[t+4]]+o[e[t+5]]+"-"+o[e[t+6]]+o[e[t+7]]+"-"+o[e[t+8]]+o[e[t+9]]+"-"+o[e[t+10]]+o[e[t+11]]+o[e[t+12]]+o[e[t+13]]+o[e[t+14]]+o[e[t+15]]).toLowerCase()}(d)};var u=e.i(814747),d=e.i(522734),_=e.i(446786),E=e.i(610613),c=e.i(796283);process.env.AGX_MAX_WORKERS;class p{timestamps=[];lastWarning=0;WARNING_COOLDOWN_MS=c.WRITE_RATE_WARNING_COOLDOWN_MS;record(){this.timestamps.push(Date.now())}check(){let e=Date.now(),t=e-c.WRITE_RATE_SAMPLE_WINDOW_MS;this.timestamps=this.timestamps.filter(e=>e>=t);let r=this.timestamps.length/(c.WRITE_RATE_SAMPLE_WINDOW_MS/1e3),a=r>=40;return a&&e-this.lastWarning>this.WARNING_COOLDOWN_MS&&(this.lastWarning=e,console.warn(`[limits] Write QPS at ${r.toFixed(1)} — approaching ceiling of 50. See docs/LIMITS.md for mitigation steps.`)),{qps:r,warning:a}}}var T=e.i(47973);let f=process.env.AGX_DATA_DIR||u.default.join(_.default.homedir(),".agx");function h(){let e=Number(process.env.AGX_QUEUE_STALE_MS);return Number.isFinite(e)&&e>0?e:6e5}class L{db;workers=new Map;pollingInterval=null;writeRateInterval=null;writeMonitor=new p;workerId;constructor(e){this.workerId=l();const r=e||process.env.SQLITE_QUEUE_PATH||u.default.join(f,"agx-queue.db"),a=u.default.dirname(r);d.default.existsSync(a)||d.default.mkdirSync(a,{recursive:!0}),this.db=new t.DatabaseSync(r);const i=(0,E.validateSQLiteEnvironment)(this.db,r);if(i.length>0){const e=i.map(e=>e.message).join("; ");console.error(`[SQLiteQueueAdapter] Startup validation failed: ${e}`)}}async start(){this.initSchema(),this.startPolling()}async stop(){this.stopPolling(),this.db.close()}initSchema(){this.db.exec(`
2
- CREATE TABLE IF NOT EXISTS agx_jobs (
3
- id TEXT PRIMARY KEY,
4
- queue TEXT NOT NULL,
5
- data TEXT NOT NULL,
6
- status TEXT NOT NULL CHECK(status IN ('pending', 'active', 'completed', 'failed', 'retry')),
7
- created_at INTEGER NOT NULL,
8
- start_after INTEGER NOT NULL DEFAULT 0,
9
- started_at INTEGER,
10
- completed_at INTEGER,
11
- failed_at INTEGER,
12
- worker_id TEXT,
13
- retry_count INTEGER DEFAULT 0,
14
- retry_limit INTEGER DEFAULT 0,
15
- priority INTEGER DEFAULT 0,
16
- error TEXT
17
- );
18
- CREATE INDEX IF NOT EXISTS idx_jobs_fetch ON agx_jobs (queue, status, start_after, priority DESC, created_at ASC);
19
- `);let e=new Set((0,r.pragmaAll)(this.db,"table_info(agx_jobs)").map(e=>e.name));e.has("failed_at")||this.db.exec("ALTER TABLE agx_jobs ADD COLUMN failed_at INTEGER"),e.has("error")||this.db.exec("ALTER TABLE agx_jobs ADD COLUMN error TEXT")}async send(e,t,r){let a=l(),i=Date.now(),s=r?.startAfter?r.startAfter instanceof Date?r.startAfter.getTime():r.startAfter:i;return this.db.prepare(`
20
- INSERT INTO agx_jobs (
21
- id, queue, data, status, created_at, start_after, retry_limit, priority
22
- ) VALUES (?, ?, ?, 'pending', ?, ?, ?, ?)
23
- `).run(a,e,JSON.stringify(t),i,s,r?.retryLimit??3,r?.priority??0),this.writeMonitor.record(),(0,T.writeDebugLog)("queue.send",{queue:e,jobId:a,startAfter:s,retryLimit:r?.retryLimit??3,priority:r?.priority??0,data:t}),a}async work(e,t,r){(0,T.writeDebugLog)("queue.worker.register",{queue:e,batchSize:r?.batchSize??1,pollInterval:r?.pollInterval??null,workerId:this.workerId}),this.workers.set(e,{handler:t,options:r||{},running:!0})}startPolling(){this.pollingInterval||(this.pollingInterval=setInterval(()=>this.poll(),c.QUEUE_POLL_INTERVAL_MS),this.writeRateInterval=setInterval(()=>this.writeMonitor.check(),c.WRITE_RATE_SAMPLE_WINDOW_MS))}stopPolling(){this.pollingInterval&&(clearInterval(this.pollingInterval),this.pollingInterval=null),this.writeRateInterval&&(clearInterval(this.writeRateInterval),this.writeRateInterval=null)}poll(){for(let[e,t]of this.workers)t.running&&this.processQueue(e,t)}processQueue(e,t){let a=t.options.batchSize||1,i=Date.now(),s=i-h(),n=(0,r.transaction)(this.db,()=>{let t=this.reapStaleJobs(e,i,s);t.length>0&&(0,T.writeDebugLog)("queue.reap_stale",{queue:e,workerId:this.workerId,staleBefore:s,jobs:t});let r=this.db.prepare(`
24
- SELECT id, data FROM agx_jobs
25
- WHERE queue = ?
26
- AND (status = 'pending' OR status = 'retry')
27
- AND start_after <= ?
28
- ORDER BY priority DESC, created_at ASC
29
- LIMIT ?
30
- `).all(e,i,a);if(0===r.length)return[];let n=r.map(e=>e.id),o=this.db.prepare(`
31
- UPDATE agx_jobs
32
- SET status = 'active', started_at = ?, worker_id = ?
33
- WHERE id = ?
34
- `);for(let e of n)o.run(i,this.workerId,e);return r.map(t=>({id:t.id,name:e,data:JSON.parse(t.data)}))});n.length>0&&((0,T.writeDebugLog)("queue.claim",{queue:e,workerId:this.workerId,jobIds:n.map(e=>e.id)}),this.executeJobs(n,t.handler))}async executeJobs(e,t){try{await t(e),this.completeJobs(e.map(e=>e.id)),(0,T.writeDebugLog)("queue.complete",{jobIds:e.map(e=>e.id)})}catch(t){this.failJobs(e.map(e=>e.id),t.message||String(t)),(0,T.writeDebugLog)("queue.fail",{jobIds:e.map(e=>e.id),error:t})}}completeJobs(e){let t=Date.now(),a=this.db.prepare(`
35
- UPDATE agx_jobs
36
- SET status = 'completed', completed_at = ?, worker_id = NULL
37
- WHERE id = ?
38
- `);(0,r.transaction)(this.db,()=>{for(let r of e)a.run(t,r)})}failJobs(e,t){let a=Date.now(),i=this.db.prepare(`
39
- SELECT id, retry_count, retry_limit FROM agx_jobs WHERE id = ?
40
- `),s=this.db.prepare(`
41
- UPDATE agx_jobs
42
- SET status = 'retry', retry_count = retry_count + 1,
43
- start_after = ? + (retry_count * 1000 * 2), -- Exponential backoff (kinda)
44
- started_at = NULL,
45
- worker_id = NULL,
46
- error = ?
47
- WHERE id = ?
48
- `),n=this.db.prepare(`
49
- UPDATE agx_jobs
50
- SET status = 'failed', failed_at = ?, started_at = NULL, worker_id = NULL, error = ?
51
- WHERE id = ?
52
- `);(0,r.transaction)(this.db,()=>{for(let r of e){let e=i.get(r);if(e&&e.retry_count<e.retry_limit){let i=(e.retry_count+1)*2e3;s.run(a+i,t,r)}else n.run(a,t,r)}})}reapStaleJobs(e,t,r){let a=this.db.prepare(`
53
- SELECT id, retry_count, retry_limit
54
- FROM agx_jobs
55
- WHERE queue = ?
56
- AND status = 'active'
57
- AND started_at IS NOT NULL
58
- AND started_at <= ?
59
- ORDER BY started_at ASC
60
- `).all(e,r);if(0===a.length)return[];let i=this.db.prepare(`
61
- UPDATE agx_jobs
62
- SET status = 'retry',
63
- retry_count = retry_count + 1,
64
- start_after = ?,
65
- started_at = NULL,
66
- worker_id = NULL,
67
- error = ?
68
- WHERE id = ?
69
- `),s=this.db.prepare(`
70
- UPDATE agx_jobs
71
- SET status = 'failed',
72
- failed_at = ?,
73
- started_at = NULL,
74
- worker_id = NULL,
75
- error = ?
76
- WHERE id = ?
77
- `),n=[];for(let e of a){let r=`Job exceeded active timeout of ${h()}ms`;e.retry_count<e.retry_limit?(i.run(t,r,e.id),n.push({id:e.id,fromStatus:"active",toStatus:"retry",retryCount:e.retry_count+1})):(s.run(t,r,e.id),n.push({id:e.id,fromStatus:"active",toStatus:"failed",retryCount:e.retry_count}))}return n}}let S=null;async function m(){return S||(S=new L,await S.start()),S}e.s(["QUEUE_NAMES",0,{TASK_PROCESS:"agx.task.process",CHAT_RUN_PROCESS:"agx.chat.process",TASK_CLEANUP:"agx.task.cleanup"},"getQueue",0,m],295851)}];
78
-
79
- //# sourceMappingURL=apps_local_lib_0sc_lek._.js.map
@@ -1,55 +0,0 @@
1
- module.exports=[828549,e=>{"use strict";var t=e.i(623775),r=e.i(633211);class n extends Error{constraint;detail;constructor(e,t){super(e),this.name="ConflictError",this.constraint=t?.constraint,this.detail=t?.detail}}class a extends Error{code;constructor(e,t){super(e),this.name="RetryableError",this.code=t}}class o extends Error{expectedVersion;actualVersion;entityId;entityType;constructor(e,t,r,n){super(void 0!==n?`Concurrent modification on ${e} ${t}: expected version ${r}, found ${n}`:`Concurrent modification on ${e} ${t}: expected version ${r}, row not updated`),this.name="ConcurrentModificationError",this.entityType=e,this.entityId=t,this.expectedVersion=r,this.actualVersion=n}}function s(e){if(!(e instanceof Error))throw e;let t=e.code??"",r=e.message??"";if("SQLITE_CONSTRAINT_UNIQUE"===t||"SQLITE_CONSTRAINT_PRIMARYKEY"===t||"SQLITE_CONSTRAINT"===t&&(r.includes("UNIQUE")||r.includes("PRIMARY KEY"))||r.includes("UNIQUE constraint failed")||r.includes("PRIMARY KEY constraint failed")){let e=r.match(/(?:UNIQUE|PRIMARY KEY) constraint failed: (.+)/);throw new n(r,{constraint:e?.[1],detail:r})}if("SQLITE_BUSY"===t||"SQLITE_LOCKED"===t||r.includes("database is locked"))throw new a(r,t||"SQLITE_BUSY");throw e}async function i(e){try{return await e()}catch(e){if(e instanceof n||e instanceof a||e instanceof o)throw e;s(e)}}e.s(["SQLiteAdapter",0,class{async transaction(e){let t=(0,r.getSQLiteDb)();t.exec("BEGIN IMMEDIATE");try{let r=await e(t);return t.exec("COMMIT"),r}catch(e){try{t.exec("ROLLBACK")}catch{}if(e instanceof n||e instanceof a||e instanceof o)throw e;s(e)}}getTasks(e,r){return t.getTasks(e,r)}getTask(e,r){return t.getTask(e,r)}getTaskBySlug(e,r){return t.getTaskBySlug(e,r)}createTask(e,r,n){return i(()=>t.createTask(e,r,n))}async updateTask(e,n,a,s){let l=s?.expectedVersion;if(void 0!==l){let d=(0,r.getSQLiteDb)();if(0===d.prepare("UPDATE tasks SET version = version + 1 WHERE id = ? AND version = ?").run(e,l).changes){let t=d.prepare("SELECT version FROM tasks WHERE id = ?").get(e);throw new o("task",e,l,t?.version)}let{expectedVersion:u,...c}=s??{};return i(()=>t.updateTask(e,n,a,c))}return(0,r.getSQLiteDb)().prepare("UPDATE tasks SET version = version + 1 WHERE id = ?").run(e),i(()=>t.updateTask(e,n,a,s))}appendRunToIndex(e,r,n){return t.appendRunToIndex(e,r,n)}deleteTask(e,r){return i(()=>t.deleteTask(e,r))}getNextQueuedTask(e){return t.getNextQueuedTask(e)}ensureNoCircularDependency(e,r,n){return t.ensureNoCircularDependency(e,r,n)}getProjects(e,r){return t.getProjects(e,r)}getProjectBySlug(e,r){return t.getProjectBySlug(e,r)}getProjectRepos(e){return t.getProjectRepos(e)}getProjectWithRepos(e,r){return t.getProjectWithRepos(e,r)}createProject(e,r,n){return i(()=>t.createProject(e,r,n))}updateProject(e,r,n,a){return t.updateProject(e,r,n,a)}deleteProject(e,r,n){return i(()=>t.deleteProject(e,r,n))}assignOrphanTasksToProject(e,r,n){return t.assignOrphanTasksToProject(e,r,n)}getWorkflows(e){return t.getWorkflows(e)}getWorkflow(e,r){return t.getWorkflow(e,r)}updateWorkflow(e,r,n){return t.updateWorkflow(e,r,n)}getWorkflowNodes(e){return t.getWorkflowNodes(e)}updateWorkflowNodes(e,r,n){return t.updateWorkflowNodes(e,r,n)}getWorkflowNodeByName(e,r){return t.getWorkflowNodeByName(e,r)}getWorkflowTransitions(e){return t.getWorkflowTransitions(e)}getWorkflowTransitionsFromNode(e,r){return t.getWorkflowTransitionsFromNode(e,r)}getWorkflowWithGraph(e,r){return t.getWorkflowWithGraph(e,r)}getTaskLogs(e,r){return t.getTaskLogs(e,r)}addTaskLog(e,r,n,a){return i(()=>t.addTaskLog(e,r,n,a))}addTaskCostEntry(e){return i(()=>t.addTaskCostEntry(e))}getTaskCostEntries(e){return t.getTaskCostEntries(e)}getTaskCostSummary(e){return t.getTaskCostSummary(e)}getTaskComments(e){return t.getTaskComments(e)}addTaskComment(e,r,n,a){return i(()=>t.addTaskComment(e,r,n,a))}deleteTaskComment(e,r){return i(()=>t.deleteTaskComment(e,r))}getLearnings(e,r,n){return t.getLearnings(e,r,n)}addLearning(e,r,n,a){return i(()=>t.addLearning(e,r,n,a))}deleteLearning(e,r){return i(()=>t.deleteLearning(e,r))}getStagePrompts(e,r){return t.getStagePrompts(e,r)}getStagePrompt(e,r,n){return t.getStagePrompt(e,r,n)}upsertStagePrompt(e,r,n,a,o,s){return i(()=>t.upsertStagePrompt(e,r,n,a,o,s))}deleteStagePrompt(e,r){return t.deleteStagePrompt(e,r)}getAgents(e){return t.getAgents(e)}getAgent(e,r){return t.getAgent(e,r)}createAgent(e,r){return i(()=>t.createAgent(e,r))}updateAgent(e,r,n){return t.updateAgent(e,r,n)}deleteAgent(e,r){return t.deleteAgent(e,r)}getProjectAgents(e){return t.getProjectAgents(e)}addProjectAgent(e,r,n){return i(()=>t.addProjectAgent(e,r,n))}removeProjectAgent(e,r){return t.removeProjectAgent(e,r)}reorderProjectAgents(e,r){return t.reorderProjectAgents(e,r)}getTeams(e){return t.getTeams(e)}getTeam(e){return t.getTeam(e)}createTeam(e,r,n,a){return i(()=>t.createTeam(e,r,n,a))}updateTeam(e,r){return t.updateTeam(e,r)}deleteTeam(e){return t.deleteTeam(e)}getTeamAgents(e){return t.getTeamAgents(e)}addTeamAgent(e,r,n,a){return i(()=>t.addTeamAgent(e,r,n,a))}removeTeamAgent(e,r){return t.removeTeamAgent(e,r)}getProjectSkills(e){return t.getProjectSkills(e)}addProjectSkill(e,r,n){return i(()=>t.addProjectSkill(e,r,n))}removeProjectSkill(e){return t.removeProjectSkill(e)}getProjectVariables(e){return t.getProjectVariables(e)}setProjectVariable(e,r,n){return i(()=>t.setProjectVariable(e,r,n))}deleteProjectVariable(e,r){return t.deleteProjectVariable(e,r)}getProjectMemory(e,r){return t.getProjectMemory(e,r)}addProjectMemory(e,r,n,a){return i(()=>t.addProjectMemory(e,r,n,a))}deleteProjectMemory(e){return t.deleteProjectMemory(e)}getProjectThreads(e){return t.getProjectThreads(e)}addProjectThread(e,r){return i(()=>t.addProjectThread(e,r))}removeProjectThread(e,r){return t.removeProjectThread(e,r)}getProjectForThread(e){return t.getProjectForThread(e)}getUserSettings(e){return t.getUserSettings(e)}upsertUserSettings(e,r,n){return i(()=>t.upsertUserSettings(e,r,n))}async healthCheck(){let e=performance.now();try{return(0,r.getSQLiteDb)().prepare("SELECT 1").get(),{adapter:"sqlite",connected:!0,latencyMs:Math.round(performance.now()-e)}}catch{return{adapter:"sqlite",connected:!1,latencyMs:Math.round(performance.now()-e)}}}}],828549)},929160,e=>{"use strict";let t=function(){let{SQLiteAdapter:t}=e.r(828549);return new t}();e.s(["db",0,t])},461419,e=>{"use strict";var t=e.i(623775);let r=[["INTAKE","PROGRESS","DONE"]];async function n({workflowId:e,currentNodeName:r,decision:a,retryCount:o,maxRetries:s=3}){if("done"===String(r).trim().toLowerCase())return{nextNodeName:"done",nextStatus:"completed",retryCount:0,error:null,appendLog:{content:"Task completed at done",logType:"checkpoint"},nodeConfig:null};let i=await (0,t.getWorkflowNodeByName)(e,r);if(!i)return{nextNodeName:r,nextStatus:"blocked",retryCount:o,error:`Node '${r}' not found in workflow`,appendLog:{content:`Workflow error: node '${r}' not found`,logType:"error"},nodeConfig:null};if("terminal"===i.node_type)return{nextNodeName:r,nextStatus:"completed",retryCount:0,error:null,appendLog:{content:`Task completed at ${i.label||r}`,logType:"checkpoint"},nodeConfig:i};if("blocked"===a)return{nextNodeName:r,nextStatus:"blocked",retryCount:o,error:null,appendLog:{content:"Blocked: additional input required.",logType:"system"},nodeConfig:i};let l=await (0,t.getWorkflowTransitionsFromNode)(e,i.id),d=function(e){switch(e){case"done":default:return"done";case"blocked":return"blocked";case"failed":case"not_done":return"failed"}}(a),u=l.find(e=>e.condition===d);if(u){let n=(await (0,t.getWorkflowNodes)(e)).find(e=>e.id===u.to_node_id);if(n){let e="terminal"===n.node_type;return{nextNodeName:n.name,nextStatus:e?"completed":"queued",retryCount:0,error:null,appendLog:{content:"done"===a?`Stage completed: ${i.label||r}`:`Transition to ${n.label||n.name}`,logType:"done"===a?"checkpoint":"system"},nodeConfig:n}}}if("done"===a)return{nextNodeName:r,nextStatus:"completed",retryCount:0,error:null,appendLog:{content:`Task completed at ${i.label||r}`,logType:"checkpoint"},nodeConfig:i};let c=o+1;return c<=s?{nextNodeName:r,nextStatus:"queued",retryCount:c,error:null,appendLog:{content:`Retrying (${c}/${s}) for ${i.label||r}`,logType:"system"},nodeConfig:i}:{nextNodeName:r,nextStatus:"failed",retryCount:c,error:"Task failed after max retries.",appendLog:{content:"Task failed after max retries.",logType:"error"},nodeConfig:i}}e.s(["getTicketType",0,function(e,t){for(let t of["ticket_type","type","issue_type","kind"])if("spike"===function(e){if("string"!=typeof e)return"task";let t=e.trim().toLowerCase();return"spike"===t||"spikes"===t?"spike":"task"}(e[t]))return"spike";let r=t.match(/^#\s+(.+)$/m),n=r?.[1]?.trim().toLowerCase()||"";return n.startsWith("spike:")||n.startsWith("[spike]")?"spike":"task"},"resolveStageTransition",0,function({currentStage:e,decision:t,ticketType:n,retryCount:a,maxRetries:o=3}){let s=function(e,t){if("spike"===t)return"INTAKE"===e?"PROGRESS":"DONE"===e?null:"DONE";for(let t of r){let r=t.indexOf(e);if(-1!==r){if(r>=t.length-1)return null;return t[r+1]}}return null}(e,n);if("done"===t)return s?{nextStage:s,nextStatus:"queued",retryCount:0,error:null,appendLog:{content:`Stage completed: ${e}`,logType:"checkpoint"}}:{nextStage:"DONE",nextStatus:"completed",retryCount:0,error:null,appendLog:{content:`Task completed at stage ${e}.`,logType:"checkpoint"}};if("blocked"===t)return{nextStage:e,nextStatus:"blocked",retryCount:a,error:null,appendLog:{content:"Blocked: additional input required.",logType:"system"}};if("PROGRESS"===e)return{nextStage:"PROGRESS",nextStatus:"queued",retryCount:0,error:null,appendLog:{content:"Stage not done. Retrying in PROGRESS.",logType:"system"}};let i=a+1;return i<=o?{nextStage:e,nextStatus:"queued",retryCount:i,error:null,appendLog:{content:`Retrying (${i}/${o}) for stage ${e}.`,logType:"system"}}:{nextStage:e,nextStatus:"failed",retryCount:i,error:"Task failed.",appendLog:{content:"Task failed.",logType:"error"}}},"resolveWorkflowTransition",0,n])},733545,e=>{"use strict";var t=e.i(341902);e.s(["getKnowledgeNote",0,function(e,r){return t.vaultStore.getKnowledgeNote(e,r)},"upsertKnowledgeNote",0,function(e){return t.vaultStore.upsertKnowledgeNote(e)}])},389344,e=>{"use strict";var t=e.i(929160),r=e.i(461419),n=e.i(623775),a=e.i(254799),o=e.i(374371),s=e.i(633211),i=e.i(476805),l=e.i(733545);let d=new Set(["outcome","decision","pattern","gotcha"]),u=`You are a memory extractor for a task execution system.
2
- Given a completed task, extract 0-3 memories worth remembering for future tasks.
3
-
4
- Each memory must be:
5
- { "memory_type": "outcome" | "decision" | "pattern" | "gotcha", "content": "one concise sentence" }
6
-
7
- - outcome: what happened (success/failure result)
8
- - decision: a choice that was made and why
9
- - pattern: a reusable approach or technique discovered
10
- - gotcha: a surprising pitfall or edge case encountered
11
-
12
- Return ONLY a JSON array. Return [] if nothing worth remembering.
13
- Do not wrap in markdown code blocks. Just raw JSON.`,c=`You are maintaining a living project knowledge note for a task execution system.
14
- Given the current project note and a completed or failed task, decide whether the note should change.
15
-
16
- Return ONLY a JSON object:
17
- {
18
- "updated_note": "full revised note in concise markdown",
19
- "change_summary": "short summary of what changed",
20
- "no_change": false
21
- }
22
-
23
- Rules:
24
- - Revise the current note instead of appending isolated bullets.
25
- - Write like a person's living project notes, not an extracted fact list.
26
- - The note should help someone understand what the project is, what it does, what has been decided, and what lessons now shape future work.
27
- - Prefer short sections and narrative paragraphs in markdown. Bullets are fine only when they genuinely improve clarity.
28
- - Preserve strong existing content when still valid.
29
- - Merge duplicate ideas, sharpen wording, and remove stale or unsupported claims.
30
- - Only include project-scoped knowledge likely useful across future work in the same project.
31
- - Do not include repo-specific durable truths that belong in repo knowledge.
32
- - Avoid generic filler and avoid sounding like an audit log.
33
- - If nothing project-scoped changed, return {"no_change": true}.
34
- - Do not wrap in markdown code blocks. Just raw JSON.`;async function g(e){let t=[`Goal: ${e.goal}`,`Status: ${e.status}`,e.nodeOutputs?`Node outputs: ${JSON.stringify(e.nodeOutputs).slice(0,2e3)}`:null].filter(Boolean).join("\n"),r=`${u}
35
-
36
- Task:
37
- ${t}`,n="";try{await (0,o.runCliResponse)({provider:"claude",model:"claude-haiku-4-5-20251001",prompt:r,onDelta:e=>{n+=e}})}catch(e){return console.warn("[memory-extractor] LLM call failed:",e),[]}var a=n;let s=a.trim().replace(/^```(?:json)?\s*/i,"").replace(/\s*```\s*$/,"").trim();try{let e=JSON.parse(s);if(!Array.isArray(e))return[];return e.filter(e=>"object"==typeof e&&null!==e&&d.has(e.memory_type)&&"string"==typeof e.content&&e.content.trim().length>0).slice(0,3)}catch{return console.warn("[memory-extractor] Failed to parse LLM response:",s.slice(0,200)),[]}}let p=new Set(["outcome","decision","pattern","gotcha"]),f=["agent_id","agentId","agent","participant_id","participantId","assigned_agent","assignedAgent"];function m(e){return"string"!=typeof e?null:e.trim()||null}function k(e){let t=m(e.explicitAgentId);if(t)return t;let r=e.frontmatter||{};for(let e of f){let t=m(r[e]);if(t)return t}return m(e.defaultUserId)||"system"}async function y(e,t,r){let n=(0,s.getSQLiteDb)().prepare(`INSERT OR IGNORE INTO agent_memory (id, agent_id, task_id, memory_type, content, content_hash, created_at)
38
- VALUES (?, ?, ?, ?, ?, ?, ?)`),o=0,l=Date.now();for(let s of r){if(!p.has(s.memory_type)||!s.content?.trim())continue;let r=(0,a.createHash)("sha256").update(s.content.trim()).digest("hex");n.run((0,a.randomUUID)(),t,e,s.memory_type,s.content.trim(),r,l).changes>0&&o++}return o>0&&(0,i.storeKnowledgeEntries)(r.map(r=>({scope:"agent",subjectId:t,sourceType:"task_completion",sourceId:e,kind:r.memory_type,title:r.content.trim().slice(0,80),body:r.content.trim(),confidence:.7,durability:.6,metadata:{task_id:e}}))),o}async function w(e,t,r){let n=await g(r);if(0===n.length)return;let a=await y(e,t,n);a>0&&console.log(`[memory-extractor] Stored ${a} memories for task ${e}`)}async function S(e){let t=m(e);if(!t)return null;if(/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(t))return t;let r=(0,s.getSQLiteDb)().prepare("SELECT id FROM projects WHERE slug = ? LIMIT 1").get(t);return r?.id??null}async function T(e,t){let r=[`Goal: ${e.goal}`,`Status: ${e.status}`,e.nodeOutputs?`Node outputs: ${JSON.stringify(e.nodeOutputs).slice(0,2e3)}`:null].filter(Boolean).join("\n"),n=`${c}
39
-
40
- Current note:
41
- ${t||"(empty)"}
42
-
43
- Task:
44
- ${r}`,a="";try{await (0,o.runCliResponse)({provider:"claude",model:"claude-haiku-4-5-20251001",prompt:n,onDelta:e=>{a+=e}})}catch(e){return console.warn("[project-knowledge] LLM call failed:",e),[]}let s=a.trim().replace(/^```(?:json)?\s*/i,"").replace(/\s*```\s*$/,"").trim();try{let e=JSON.parse(s);if(!e||"object"!=typeof e||Array.isArray(e))return[];let t="string"==typeof e.updated_note?e.updated_note.trim():"";if(e.no_change||!t)return[];return[{updated_note:t,change_summary:"string"==typeof e.change_summary?e.change_summary.trim():void 0,no_change:!1}]}catch{return console.warn("[project-knowledge] Failed to parse LLM response:",s.slice(0,200)),[]}}async function h(e,t,r){if(0===r.length)return 0;let n=r[0];return n&&n.updated_note?.trim()?+!!(0,l.upsertKnowledgeNote)({scope:"project",subjectId:e,content:n.updated_note.trim(),changeSummary:n.change_summary,sourceType:"task_completion",sourceId:t,metadata:{task_id:t}}).changed:0}async function x(e,t,r){let n=await S(t);if(!n)return;let a=await T(r,(0,l.getKnowledgeNote)("project",n)?.content??"");if(0===a.length)return;let o=await h(n,e,a);o>0&&console.log(`[project-knowledge] Stored ${o} project knowledge entries for task ${e}`)}var _=e.i(209120);function I(e,t){return`---
45
- ${Object.entries(e).map(([e,t])=>`${e}: ${null==t?"":String(t)}`).join("\n")}
46
- ---
47
- ${t}`}var $=e.i(295851),j=e.i(864075);function N(e){if(!e)return[];if(Array.isArray(e))return Array.from(new Set(e.map(e=>String(e||"").trim()).filter(Boolean)));if("string"==typeof e){let t=e.trim();if(!t)return[];try{let e=JSON.parse(t);if(Array.isArray(e))return Array.from(new Set(e.map(e=>String(e||"").trim()).filter(Boolean)))}catch{}return Array.from(new Set(t.split(",").map(e=>e.trim()).filter(Boolean)))}return[]}function b(e){if(!e)return[];let t=N(e.depends_on);if(t.length)return t;if("string"==typeof e.content){let{frontmatter:t}=(0,n.parseFrontmatter)(e.content||"");return N(t.depends_on)}return[]}async function P(e,t){if(!e.length)return[];let r=(0,_.createAdminDbClient)().from("tasks").select("id, title, slug, status, stage").in("id",e);t&&(r=r.eq("user_id",t));let{data:n}=await r,a=new Map;if(Array.isArray(n))for(let e of n){var o;e&&e.id&&a.set(e.id,(o=e.id,e?{id:e.id||o||"",title:e.title||void 0,slug:e.slug||void 0,status:e.status,stage:e.stage}:{id:o||""}))}return e.map(e=>a.get(e)).filter(e=>!!e)}async function A(e,t){let r=b(e);return r.length?(await P(r,t)).filter(e=>"completed"!==(e.status||"")):[]}async function E(e,a,o){let s=a||j.LOCAL_USER.id,i=await t.db.getTask(e,s);if(!i)throw Error(`Task not found: ${e}`);let l=await A(i,s);if(l.length){let t=function(e){if(!e.length)return"";let t=e.slice(0,3).map(e=>{let t=e.title||e.slug||e.id||"(unknown)",r="INTAKE"===e.stage?"awaiting approval":e.status||"",n=r?` (${r})`:"";return`${t}${n}`}),r=`Waiting on dependencies: ${t.join(", ")}`;return e.length>3&&(r+=` +${e.length-3} more`),r}(l),r=(0,_.createAdminDbClient)(),{error:n}=await r.from("tasks").update({status:"blocked",blocked_reason:t,updated_at:new Date().toISOString()}).eq("id",e);if(n&&"42703"!==n.code)throw n;return{started:!1,missingDependencies:l,blockedReason:t}}if(!o?.force&&"queued"===i.status&&!i.blocked_reason)return{started:!1,missingDependencies:[],alreadyQueued:!0};let{frontmatter:d,body:u}=(0,n.parseFrontmatter)(i.content||""),c=o?.ticketType??(0,r.getTicketType)(d,u),g=await (0,$.getQueue)(),p=await g.send($.QUEUE_NAMES.TASK_PROCESS,{taskId:e,userId:s,signal:"start",ticketType:c}),f=(0,_.createAdminDbClient)(),{error:m}=await f.from("tasks").update({status:"queued",blocked_reason:null,updated_at:new Date().toISOString()}).eq("id",e);if(m&&"42703"!==m.code)throw m;return{started:!!p,jobId:p,missingDependencies:[],ticketType:c}}async function C(e,t){let r=t||j.LOCAL_USER.id,n=(0,_.createAdminDbClient)(),a=n.from("tasks").select("id").contains("depends_on",[e]);t&&(a=a.eq("user_id",t));let{data:o,error:s}=await a,i=Array.isArray(o)?o.map(e=>e?.id).filter(Boolean):[];if(s&&"42703"===s.code){let r=n.from("tasks").select("id, content");t&&(r=r.eq("user_id",t));let{data:a}=await r;i=(Array.isArray(a)?a:[]).filter(t=>b(t).includes(e)).map(e=>e?.id).filter(Boolean)}i.length&&await Promise.all(i.map(e=>E(e,r)))}var v=e.i(930430);async function L(e){let t=(0,_.createAdminDbClient)();await t.from("tasks").update({stage:e.stage,status:"queued",updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId)}async function R(e){let t=(0,_.createAdminDbClient)(),{data:r}=await t.from("tasks").select("stage_decisions").eq("id",e.taskId).eq("user_id",e.userId).maybeSingle(),n={...r?.stage_decisions&&"object"==typeof r.stage_decisions?r.stage_decisions:{},[e.stage]:{decision:e.decision.decision,rationale:e.decision.explanation,final_result:e.decision.final_result,decided_at:new Date().toISOString()}},{error:a}=await t.from("tasks").update({stage_decisions:n,updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId);if(a&&!function(e){if(!e||"object"!=typeof e)return!1;let t="code"in e?String(e.code):"",r="message"in e?String(e.message).toLowerCase():"";return("PGRST204"===t||"42703"===t)&&r.includes("stage_decisions")}(a))throw a}async function O(e){let r=await t.db.getTask(e.taskId,e.userId);if(!r)throw Error(`Task ${e.taskId} not found`);let a=r.stage||null,o=new Date().toISOString(),s={taskId:e.taskId,userId:e.userId,title:r.title||null,slug:r.slug||null,timestamp:o},{frontmatter:i,body:l}=(0,n.parseFrontmatter)(r.content),d=k({defaultUserId:e.userId,frontmatter:i});i.stage=e.nextStage,i.status=e.nextStatus,e.error?i.error=e.error:"error"in i&&delete i.error;let u=I(i,l);await t.db.updateTask(e.taskId,u,e.userId);let c=(0,_.createAdminDbClient)(),{error:g}=await c.from("tasks").update({stage:e.nextStage,status:e.nextStatus,retry_count:e.retryCount,error:e.error,updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId);g?console.error(`[applyStageTransition] direct update failed for ${e.taskId}:`,g):console.log(`[applyStageTransition] set ${e.taskId} to status=${e.nextStatus}, stage=${e.nextStage}`),"completed"===e.nextStatus&&(await c.from("tasks").update({completed_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId),await C(e.taskId,e.userId)),("completed"===e.nextStatus||"failed"===e.nextStatus)&&(w(e.taskId,d,{goal:String(r.content||r.title||""),status:String(e.nextStatus)}).catch(e=>console.warn("[applyStageTransition] Memory extraction failed:",e)),x(e.taskId,r.project_id||r.project,{goal:String(r.content||r.title||""),status:String(e.nextStatus)}).catch(e=>console.warn("[applyStageTransition] Project knowledge extraction failed:",e))),"blocked"!==e.nextStatus&&"failed"!==e.nextStatus&&(0,v.notifyTaskEvent)({...s,eventType:"task.stage_complete",stage:a,previousStage:a,nextStage:e.nextStage,status:e.nextStatus,details:{nextStatus:e.nextStatus}}),"completed"===e.nextStatus&&(0,v.notifyTaskEvent)({...s,eventType:"task.completed",stage:e.nextStage,status:e.nextStatus,details:{previousStage:a,nextStage:e.nextStage}}),"failed"===e.nextStatus&&(0,v.notifyTaskEvent)({...s,eventType:"task.failed",stage:e.nextStage,status:e.nextStatus,error:e.error,details:{previousStage:a}})}async function D(e){await t.db.addTaskLog(e.taskId,e.content,e.logType)}async function W(e){await t.db.addTaskComment(e.taskId,e.content,e.authorType||"agent")}async function M(e){let r=await t.db.getTask(e.taskId,e.userId);if(!r)return;let{frontmatter:a,body:o}=(0,n.parseFrontmatter)(r.content),s=k({defaultUserId:e.userId,frontmatter:a});a.status="failed",a.error=e.reason||"Cancelled";let i=I(a,o);await t.db.updateTask(e.taskId,i,e.userId),await t.db.addTaskLog(e.taskId,e.reason||"Task cancelled","error"),w(e.taskId,s,{goal:String(r.content||r.title||""),status:"failed"}).catch(e=>console.warn("[markCancelled] Memory extraction failed:",e)),x(e.taskId,r.project_id||r.project,{goal:String(r.content||r.title||""),status:"failed"}).catch(e=>console.warn("[markCancelled] Project knowledge extraction failed:",e));let l=(0,_.createAdminDbClient)();await l.from("tasks").update({status:"failed",error:e.reason||"Cancelled",updated_at:new Date().toISOString()}).eq("id",e.taskId).eq("user_id",e.userId),(0,v.notifyTaskEvent)({taskId:e.taskId,userId:e.userId,eventType:"task.failed",title:r.title||null,slug:r.slug||null,stage:r.stage||null,status:"failed",error:e.reason||"Cancelled",timestamp:new Date().toISOString(),details:{previousStage:r.stage||null}})}async function q(e){let{taskId:r,userId:n,signal:a,payload:o,ticketType:s="task"}=e.data,i=await t.db.getTask(r,n);if(!i)return void console.log(`[processor] Task ${r} not found, skipping`);if("completed"===i.status||"failed"===i.status)return void console.log(`[processor] Task ${r} is ${i.status}, skipping`);let l=i.stage;switch(a){case"start":await B(r,l,n);break;case"agentResult":await Q(r,l,n,o,s,i.retry_count||0,i.workflow_id&&/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(i.workflow_id)?i.workflow_id:null);break;case"humanInput":await K(r,o);break;case"daemonStep":await G(r,o);break;case"cancel":await Y(r,n,o?.reason);break;default:console.warn(`[processor] Unknown signal: ${a}`)}}async function U(e){for(let t of e)try{await q(t)}catch(e){throw console.error(`[processor] Error processing job ${t.id}:`,e),e}}async function B(e,t,r){console.log(`[processor] Starting task ${e} at stage ${t}`),await L({taskId:e,stage:t,userId:r}),await D({taskId:e,content:`Task started at stage: ${t}`,logType:"system"})}async function Q(e,t,n,a,o,s,i=null){let l,d,u;console.log(`[processor] Processing agent result for ${e}: ${a.decision}`),await R({taskId:e,stage:t,decision:a,userId:n});let c=Array.isArray(a.comments)?a.comments.map(e=>String(e||"").trim()).filter(Boolean):[],g=String(a.comment||a.log||a.final_result||"").trim();for(let t of c.length>0?c:g.split("\n").map(e=>e.trim()).filter(Boolean))await W({taskId:e,content:t,authorType:"agent"});let p=null,f=null;if(i){let e=await (0,r.resolveWorkflowTransition)({workflowId:i,currentNodeName:t,decision:a.decision,retryCount:s,maxRetries:3});l=e.nextNodeName,d=e.nextStatus,u=e.retryCount,p=e.error,f=e.appendLog,console.log(`[processor] Workflow transition: ${t} -> ${l} (workflow: ${i})`)}else{let e=(0,r.resolveStageTransition)({currentStage:t,decision:a.decision,ticketType:o,retryCount:s,maxRetries:3});l=e.nextStage,d=e.nextStatus,u=e.retryCount,p=e.error,f=e.appendLog}if(await O({taskId:e,nextStage:l,nextStatus:d,retryCount:u,error:p?a.explanation||p:null,userId:n}),f){let t="error"===f.logType&&a.explanation||"system"===f.logType&&a.explanation?a.explanation:f.content;await D({taskId:e,content:t,logType:f.logType})}console.log(`[processor] Task ${e} transitioned: ${t} -> ${l}`)}async function K(e,t){console.log(`[processor] Recording human input for ${e}`),await W({taskId:e,content:t.content,authorType:t.authorType||"user"})}async function G(e,t){let r=t.provider?` provider=${t.provider}`:"",n=t.model?` model=${t.model}`:"",a=t.role?` role=${t.role}`:"",o="number"==typeof t.iteration?` iter=${t.iteration}`:"",s="exit"===t.phase?` exit=${t.exit_code}`:"",i=t.error?` error=${t.error}`:"",l=Array.isArray(t.args)?t.args.join(" "):"",d=t.stdout_tail?`
48
- stdout_tail:
49
- ${t.stdout_tail}`:"",u=t.stderr_tail?`
50
- stderr_tail:
51
- ${t.stderr_tail}`:"",c=`[execution/${t.kind||"daemon"}] ${t.phase||"event"} ${t.label||""}${r}${n}${a}${o}${s}${i}`.trim()+(l?`
52
- args: ${l}`:"")+(t.duration_ms?`
53
- duration_ms: ${t.duration_ms}`:"")+d+u;await D({taskId:e,content:c,logType:"system"})}async function Y(e,t,r){console.log(`[processor] Cancelling task ${e}: ${r||"No reason"}`),await M({taskId:e,reason:r,userId:t})}e.s(["taskProcessor",0,U],389344)}];
54
-
55
- //# sourceMappingURL=apps_local_lib_135ddsu._.js.map