@slaw-ai/server 2026.611.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 (1198) hide show
  1. package/LICENSE +26 -0
  2. package/dist/adapters/builtin-adapter-types.d.ts +5 -0
  3. package/dist/adapters/builtin-adapter-types.d.ts.map +1 -0
  4. package/dist/adapters/builtin-adapter-types.js +18 -0
  5. package/dist/adapters/builtin-adapter-types.js.map +1 -0
  6. package/dist/adapters/codex-models.d.ts +5 -0
  7. package/dist/adapters/codex-models.d.ts.map +1 -0
  8. package/dist/adapters/codex-models.js +105 -0
  9. package/dist/adapters/codex-models.js.map +1 -0
  10. package/dist/adapters/cursor-models.d.ts +13 -0
  11. package/dist/adapters/cursor-models.d.ts.map +1 -0
  12. package/dist/adapters/cursor-models.js +148 -0
  13. package/dist/adapters/cursor-models.js.map +1 -0
  14. package/dist/adapters/http/execute.d.ts +3 -0
  15. package/dist/adapters/http/execute.d.ts.map +1 -0
  16. package/dist/adapters/http/execute.js +51 -0
  17. package/dist/adapters/http/execute.js.map +1 -0
  18. package/dist/adapters/http/execute.test.d.ts +2 -0
  19. package/dist/adapters/http/execute.test.d.ts.map +1 -0
  20. package/dist/adapters/http/execute.test.js +40 -0
  21. package/dist/adapters/http/execute.test.js.map +1 -0
  22. package/dist/adapters/http/index.d.ts +3 -0
  23. package/dist/adapters/http/index.d.ts.map +1 -0
  24. package/dist/adapters/http/index.js +20 -0
  25. package/dist/adapters/http/index.js.map +1 -0
  26. package/dist/adapters/http/test.d.ts +3 -0
  27. package/dist/adapters/http/test.d.ts.map +1 -0
  28. package/dist/adapters/http/test.js +106 -0
  29. package/dist/adapters/http/test.js.map +1 -0
  30. package/dist/adapters/index.d.ts +4 -0
  31. package/dist/adapters/index.d.ts.map +1 -0
  32. package/dist/adapters/index.js +3 -0
  33. package/dist/adapters/index.js.map +1 -0
  34. package/dist/adapters/plugin-loader.d.ts +28 -0
  35. package/dist/adapters/plugin-loader.d.ts.map +1 -0
  36. package/dist/adapters/plugin-loader.js +196 -0
  37. package/dist/adapters/plugin-loader.js.map +1 -0
  38. package/dist/adapters/process/execute.d.ts +3 -0
  39. package/dist/adapters/process/execute.d.ts.map +1 -0
  40. package/dist/adapters/process/execute.js +70 -0
  41. package/dist/adapters/process/execute.js.map +1 -0
  42. package/dist/adapters/process/index.d.ts +3 -0
  43. package/dist/adapters/process/index.d.ts.map +1 -0
  44. package/dist/adapters/process/index.js +23 -0
  45. package/dist/adapters/process/index.js.map +1 -0
  46. package/dist/adapters/process/test.d.ts +3 -0
  47. package/dist/adapters/process/test.d.ts.map +1 -0
  48. package/dist/adapters/process/test.js +77 -0
  49. package/dist/adapters/process/test.js.map +1 -0
  50. package/dist/adapters/registry.d.ts +69 -0
  51. package/dist/adapters/registry.d.ts.map +1 -0
  52. package/dist/adapters/registry.js +598 -0
  53. package/dist/adapters/registry.js.map +1 -0
  54. package/dist/adapters/types.d.ts +2 -0
  55. package/dist/adapters/types.d.ts.map +1 -0
  56. package/dist/adapters/types.js +2 -0
  57. package/dist/adapters/types.js.map +1 -0
  58. package/dist/adapters/utils.d.ts +43 -0
  59. package/dist/adapters/utils.d.ts.map +1 -0
  60. package/dist/adapters/utils.js +52 -0
  61. package/dist/adapters/utils.js.map +1 -0
  62. package/dist/agent-auth-jwt.d.ts +14 -0
  63. package/dist/agent-auth-jwt.d.ts.map +1 -0
  64. package/dist/agent-auth-jwt.js +117 -0
  65. package/dist/agent-auth-jwt.js.map +1 -0
  66. package/dist/app.d.ts +39 -0
  67. package/dist/app.d.ts.map +1 -0
  68. package/dist/app.js +386 -0
  69. package/dist/app.js.map +1 -0
  70. package/dist/attachment-types.d.ts +23 -0
  71. package/dist/attachment-types.d.ts.map +1 -0
  72. package/dist/attachment-types.js +98 -0
  73. package/dist/attachment-types.js.map +1 -0
  74. package/dist/auth/better-auth.d.ts +40 -0
  75. package/dist/auth/better-auth.d.ts.map +1 -0
  76. package/dist/auth/better-auth.js +148 -0
  77. package/dist/auth/better-auth.js.map +1 -0
  78. package/dist/config-file.d.ts +24 -0
  79. package/dist/config-file.d.ts.map +1 -0
  80. package/dist/config-file.js +73 -0
  81. package/dist/config-file.js.map +1 -0
  82. package/dist/config.d.ts +44 -0
  83. package/dist/config.d.ts.map +1 -0
  84. package/dist/config.js +247 -0
  85. package/dist/config.js.map +1 -0
  86. package/dist/dev-runner-worktree.d.ts +15 -0
  87. package/dist/dev-runner-worktree.d.ts.map +1 -0
  88. package/dist/dev-runner-worktree.js +101 -0
  89. package/dist/dev-runner-worktree.js.map +1 -0
  90. package/dist/dev-server-status.d.ts +33 -0
  91. package/dist/dev-server-status.d.ts.map +1 -0
  92. package/dist/dev-server-status.js +89 -0
  93. package/dist/dev-server-status.js.map +1 -0
  94. package/dist/dev-watch-ignore.d.ts +2 -0
  95. package/dist/dev-watch-ignore.d.ts.map +1 -0
  96. package/dist/dev-watch-ignore.js +36 -0
  97. package/dist/dev-watch-ignore.js.map +1 -0
  98. package/dist/errors.d.ts +12 -0
  99. package/dist/errors.d.ts.map +1 -0
  100. package/dist/errors.js +28 -0
  101. package/dist/errors.js.map +1 -0
  102. package/dist/first-admin-claim.d.ts +17 -0
  103. package/dist/first-admin-claim.d.ts.map +1 -0
  104. package/dist/first-admin-claim.js +30 -0
  105. package/dist/first-admin-claim.js.map +1 -0
  106. package/dist/home-paths.d.ts +15 -0
  107. package/dist/home-paths.d.ts.map +1 -0
  108. package/dist/home-paths.js +48 -0
  109. package/dist/home-paths.js.map +1 -0
  110. package/dist/http/body-limits.d.ts +4 -0
  111. package/dist/http/body-limits.d.ts.map +1 -0
  112. package/dist/http/body-limits.js +4 -0
  113. package/dist/http/body-limits.js.map +1 -0
  114. package/dist/index.d.ts +10 -0
  115. package/dist/index.d.ts.map +1 -0
  116. package/dist/index.js +786 -0
  117. package/dist/index.js.map +1 -0
  118. package/dist/instance-claim.d.ts +23 -0
  119. package/dist/instance-claim.d.ts.map +1 -0
  120. package/dist/instance-claim.js +126 -0
  121. package/dist/instance-claim.js.map +1 -0
  122. package/dist/lib/join-request-dedupe.d.ts +11 -0
  123. package/dist/lib/join-request-dedupe.d.ts.map +1 -0
  124. package/dist/lib/join-request-dedupe.js +49 -0
  125. package/dist/lib/join-request-dedupe.js.map +1 -0
  126. package/dist/log-redaction.d.ts +11 -0
  127. package/dist/log-redaction.d.ts.map +1 -0
  128. package/dist/log-redaction.js +122 -0
  129. package/dist/log-redaction.js.map +1 -0
  130. package/dist/middleware/auth.d.ts +12 -0
  131. package/dist/middleware/auth.d.ts.map +1 -0
  132. package/dist/middleware/auth.js +302 -0
  133. package/dist/middleware/auth.js.map +1 -0
  134. package/dist/middleware/error-handler.d.ts +17 -0
  135. package/dist/middleware/error-handler.d.ts.map +1 -0
  136. package/dist/middleware/error-handler.js +46 -0
  137. package/dist/middleware/error-handler.js.map +1 -0
  138. package/dist/middleware/http-log-policy.d.ts +2 -0
  139. package/dist/middleware/http-log-policy.d.ts.map +1 -0
  140. package/dist/middleware/http-log-policy.js +52 -0
  141. package/dist/middleware/http-log-policy.js.map +1 -0
  142. package/dist/middleware/index.d.ts +4 -0
  143. package/dist/middleware/index.d.ts.map +1 -0
  144. package/dist/middleware/index.js +4 -0
  145. package/dist/middleware/index.js.map +1 -0
  146. package/dist/middleware/logger.d.ts +4 -0
  147. package/dist/middleware/logger.d.ts.map +1 -0
  148. package/dist/middleware/logger.js +92 -0
  149. package/dist/middleware/logger.js.map +1 -0
  150. package/dist/middleware/operator-mutation-guard.d.ts +3 -0
  151. package/dist/middleware/operator-mutation-guard.d.ts.map +1 -0
  152. package/dist/middleware/operator-mutation-guard.js +70 -0
  153. package/dist/middleware/operator-mutation-guard.js.map +1 -0
  154. package/dist/middleware/private-hostname-guard.d.ts +11 -0
  155. package/dist/middleware/private-hostname-guard.d.ts.map +1 -0
  156. package/dist/middleware/private-hostname-guard.js +78 -0
  157. package/dist/middleware/private-hostname-guard.js.map +1 -0
  158. package/dist/middleware/validate.d.ts +4 -0
  159. package/dist/middleware/validate.d.ts.map +1 -0
  160. package/dist/middleware/validate.js +7 -0
  161. package/dist/middleware/validate.js.map +1 -0
  162. package/dist/onboarding-assets/default/AGENTS.md +18 -0
  163. package/dist/onboarding-assets/squad_lead/AGENTS.md +61 -0
  164. package/dist/onboarding-assets/squad_lead/HEARTBEAT.md +85 -0
  165. package/dist/onboarding-assets/squad_lead/SOUL.md +33 -0
  166. package/dist/onboarding-assets/squad_lead/TOOLS.md +3 -0
  167. package/dist/paths.d.ts +3 -0
  168. package/dist/paths.d.ts.map +1 -0
  169. package/dist/paths.js +31 -0
  170. package/dist/paths.js.map +1 -0
  171. package/dist/realtime/live-events-ws.d.ts +28 -0
  172. package/dist/realtime/live-events-ws.d.ts.map +1 -0
  173. package/dist/realtime/live-events-ws.js +187 -0
  174. package/dist/realtime/live-events-ws.js.map +1 -0
  175. package/dist/redaction.d.ts +5 -0
  176. package/dist/redaction.d.ts.map +1 -0
  177. package/dist/redaction.js +125 -0
  178. package/dist/redaction.js.map +1 -0
  179. package/dist/routes/access.d.ts +75 -0
  180. package/dist/routes/access.d.ts.map +1 -0
  181. package/dist/routes/access.js +3070 -0
  182. package/dist/routes/access.js.map +1 -0
  183. package/dist/routes/activity.d.ts +3 -0
  184. package/dist/routes/activity.d.ts.map +1 -0
  185. package/dist/routes/activity.js +90 -0
  186. package/dist/routes/activity.js.map +1 -0
  187. package/dist/routes/adapters.d.ts +16 -0
  188. package/dist/routes/adapters.d.ts.map +1 -0
  189. package/dist/routes/adapters.js +539 -0
  190. package/dist/routes/adapters.js.map +1 -0
  191. package/dist/routes/agents.d.ts +6 -0
  192. package/dist/routes/agents.d.ts.map +1 -0
  193. package/dist/routes/agents.js +2733 -0
  194. package/dist/routes/agents.js.map +1 -0
  195. package/dist/routes/approvals.d.ts +6 -0
  196. package/dist/routes/approvals.d.ts.map +1 -0
  197. package/dist/routes/approvals.js +300 -0
  198. package/dist/routes/approvals.js.map +1 -0
  199. package/dist/routes/assets.d.ts +4 -0
  200. package/dist/routes/assets.d.ts.map +1 -0
  201. package/dist/routes/assets.js +309 -0
  202. package/dist/routes/assets.js.map +1 -0
  203. package/dist/routes/auth.d.ts +3 -0
  204. package/dist/routes/auth.d.ts.map +1 -0
  205. package/dist/routes/auth.js +82 -0
  206. package/dist/routes/auth.js.map +1 -0
  207. package/dist/routes/authz.d.ts +19 -0
  208. package/dist/routes/authz.d.ts.map +1 -0
  209. package/dist/routes/authz.js +75 -0
  210. package/dist/routes/authz.js.map +1 -0
  211. package/dist/routes/botfather.d.ts +9 -0
  212. package/dist/routes/botfather.d.ts.map +1 -0
  213. package/dist/routes/botfather.js +127 -0
  214. package/dist/routes/botfather.js.map +1 -0
  215. package/dist/routes/cloud-upstreams.d.ts +5 -0
  216. package/dist/routes/cloud-upstreams.d.ts.map +1 -0
  217. package/dist/routes/cloud-upstreams.js +103 -0
  218. package/dist/routes/cloud-upstreams.js.map +1 -0
  219. package/dist/routes/costs.d.ts +11 -0
  220. package/dist/routes/costs.d.ts.map +1 -0
  221. package/dist/routes/costs.js +285 -0
  222. package/dist/routes/costs.js.map +1 -0
  223. package/dist/routes/dashboard.d.ts +3 -0
  224. package/dist/routes/dashboard.d.ts.map +1 -0
  225. package/dist/routes/dashboard.js +15 -0
  226. package/dist/routes/dashboard.js.map +1 -0
  227. package/dist/routes/environment-selection.d.ts +13 -0
  228. package/dist/routes/environment-selection.d.ts.map +1 -0
  229. package/dist/routes/environment-selection.js +30 -0
  230. package/dist/routes/environment-selection.js.map +1 -0
  231. package/dist/routes/environments.d.ts +6 -0
  232. package/dist/routes/environments.d.ts.map +1 -0
  233. package/dist/routes/environments.js +414 -0
  234. package/dist/routes/environments.js.map +1 -0
  235. package/dist/routes/execution-workspaces.d.ts +3 -0
  236. package/dist/routes/execution-workspaces.d.ts.map +1 -0
  237. package/dist/routes/execution-workspaces.js +537 -0
  238. package/dist/routes/execution-workspaces.js.map +1 -0
  239. package/dist/routes/goals.d.ts +3 -0
  240. package/dist/routes/goals.d.ts.map +1 -0
  241. package/dist/routes/goals.js +95 -0
  242. package/dist/routes/goals.js.map +1 -0
  243. package/dist/routes/health.d.ts +9 -0
  244. package/dist/routes/health.d.ts.map +1 -0
  245. package/dist/routes/health.js +143 -0
  246. package/dist/routes/health.js.map +1 -0
  247. package/dist/routes/inbox-dismissals.d.ts +3 -0
  248. package/dist/routes/inbox-dismissals.d.ts.map +1 -0
  249. package/dist/routes/inbox-dismissals.js +58 -0
  250. package/dist/routes/inbox-dismissals.js.map +1 -0
  251. package/dist/routes/index.d.ts +24 -0
  252. package/dist/routes/index.d.ts.map +1 -0
  253. package/dist/routes/index.js +24 -0
  254. package/dist/routes/index.js.map +1 -0
  255. package/dist/routes/instance-database-backups.d.ts +15 -0
  256. package/dist/routes/instance-database-backups.d.ts.map +1 -0
  257. package/dist/routes/instance-database-backups.js +12 -0
  258. package/dist/routes/instance-database-backups.js.map +1 -0
  259. package/dist/routes/instance-settings.d.ts +3 -0
  260. package/dist/routes/instance-settings.d.ts.map +1 -0
  261. package/dist/routes/instance-settings.js +110 -0
  262. package/dist/routes/instance-settings.js.map +1 -0
  263. package/dist/routes/issue-tree-control.d.ts +3 -0
  264. package/dist/routes/issue-tree-control.d.ts.map +1 -0
  265. package/dist/routes/issue-tree-control.js +373 -0
  266. package/dist/routes/issue-tree-control.js.map +1 -0
  267. package/dist/routes/issues-checkout-wakeup.d.ts +9 -0
  268. package/dist/routes/issues-checkout-wakeup.d.ts.map +1 -0
  269. package/dist/routes/issues-checkout-wakeup.js +12 -0
  270. package/dist/routes/issues-checkout-wakeup.js.map +1 -0
  271. package/dist/routes/issues.d.ts +15 -0
  272. package/dist/routes/issues.d.ts.map +1 -0
  273. package/dist/routes/issues.js +5276 -0
  274. package/dist/routes/issues.js.map +1 -0
  275. package/dist/routes/llms.d.ts +3 -0
  276. package/dist/routes/llms.d.ts.map +1 -0
  277. package/dist/routes/llms.js +80 -0
  278. package/dist/routes/llms.js.map +1 -0
  279. package/dist/routes/openapi.d.ts +4 -0
  280. package/dist/routes/openapi.d.ts.map +1 -0
  281. package/dist/routes/openapi.js +3284 -0
  282. package/dist/routes/openapi.js.map +1 -0
  283. package/dist/routes/org-chart-svg.d.ts +25 -0
  284. package/dist/routes/org-chart-svg.d.ts.map +1 -0
  285. package/dist/routes/org-chart-svg.js +656 -0
  286. package/dist/routes/org-chart-svg.js.map +1 -0
  287. package/dist/routes/plugin-ui-static.d.ts +69 -0
  288. package/dist/routes/plugin-ui-static.d.ts.map +1 -0
  289. package/dist/routes/plugin-ui-static.js +411 -0
  290. package/dist/routes/plugin-ui-static.js.map +1 -0
  291. package/dist/routes/plugins.d.ts +121 -0
  292. package/dist/routes/plugins.d.ts.map +1 -0
  293. package/dist/routes/plugins.js +2390 -0
  294. package/dist/routes/plugins.js.map +1 -0
  295. package/dist/routes/projects.d.ts +3 -0
  296. package/dist/routes/projects.d.ts.map +1 -0
  297. package/dist/routes/projects.js +566 -0
  298. package/dist/routes/projects.js.map +1 -0
  299. package/dist/routes/resource-memberships.d.ts +3 -0
  300. package/dist/routes/resource-memberships.d.ts.map +1 -0
  301. package/dist/routes/resource-memberships.js +97 -0
  302. package/dist/routes/resource-memberships.js.map +1 -0
  303. package/dist/routes/routines.d.ts +6 -0
  304. package/dist/routes/routines.d.ts.map +1 -0
  305. package/dist/routes/routines.js +411 -0
  306. package/dist/routes/routines.js.map +1 -0
  307. package/dist/routes/secrets.d.ts +3 -0
  308. package/dist/routes/secrets.d.ts.map +1 -0
  309. package/dist/routes/secrets.js +419 -0
  310. package/dist/routes/secrets.js.map +1 -0
  311. package/dist/routes/sidebar-badges.d.ts +3 -0
  312. package/dist/routes/sidebar-badges.d.ts.map +1 -0
  313. package/dist/routes/sidebar-badges.js +68 -0
  314. package/dist/routes/sidebar-badges.js.map +1 -0
  315. package/dist/routes/sidebar-preferences.d.ts +3 -0
  316. package/dist/routes/sidebar-preferences.d.ts.map +1 -0
  317. package/dist/routes/sidebar-preferences.js +63 -0
  318. package/dist/routes/sidebar-preferences.js.map +1 -0
  319. package/dist/routes/squad-import-paths.d.ts +3 -0
  320. package/dist/routes/squad-import-paths.d.ts.map +1 -0
  321. package/dist/routes/squad-import-paths.js +3 -0
  322. package/dist/routes/squad-import-paths.js.map +1 -0
  323. package/dist/routes/squad-skills.d.ts +3 -0
  324. package/dist/routes/squad-skills.d.ts.map +1 -0
  325. package/dist/routes/squad-skills.js +366 -0
  326. package/dist/routes/squad-skills.js.map +1 -0
  327. package/dist/routes/squads.d.ts +4 -0
  328. package/dist/routes/squads.d.ts.map +1 -0
  329. package/dist/routes/squads.js +450 -0
  330. package/dist/routes/squads.js.map +1 -0
  331. package/dist/routes/user-profiles.d.ts +3 -0
  332. package/dist/routes/user-profiles.d.ts.map +1 -0
  333. package/dist/routes/user-profiles.js +337 -0
  334. package/dist/routes/user-profiles.js.map +1 -0
  335. package/dist/routes/workspace-command-authz.d.ts +14 -0
  336. package/dist/routes/workspace-command-authz.d.ts.map +1 -0
  337. package/dist/routes/workspace-command-authz.js +83 -0
  338. package/dist/routes/workspace-command-authz.js.map +1 -0
  339. package/dist/routes/workspace-runtime-service-authz.d.ts +12 -0
  340. package/dist/routes/workspace-runtime-service-authz.d.ts.map +1 -0
  341. package/dist/routes/workspace-runtime-service-authz.js +96 -0
  342. package/dist/routes/workspace-runtime-service-authz.js.map +1 -0
  343. package/dist/runtime-api.d.ts +19 -0
  344. package/dist/runtime-api.d.ts.map +1 -0
  345. package/dist/runtime-api.js +137 -0
  346. package/dist/runtime-api.js.map +1 -0
  347. package/dist/secrets/aws-secrets-manager-provider.d.ts +87 -0
  348. package/dist/secrets/aws-secrets-manager-provider.d.ts.map +1 -0
  349. package/dist/secrets/aws-secrets-manager-provider.js +964 -0
  350. package/dist/secrets/aws-secrets-manager-provider.js.map +1 -0
  351. package/dist/secrets/configured-provider.d.ts +3 -0
  352. package/dist/secrets/configured-provider.d.ts.map +1 -0
  353. package/dist/secrets/configured-provider.js +8 -0
  354. package/dist/secrets/configured-provider.js.map +1 -0
  355. package/dist/secrets/external-stub-providers.d.ts +5 -0
  356. package/dist/secrets/external-stub-providers.d.ts.map +1 -0
  357. package/dist/secrets/external-stub-providers.js +71 -0
  358. package/dist/secrets/external-stub-providers.js.map +1 -0
  359. package/dist/secrets/local-encrypted-provider.d.ts +3 -0
  360. package/dist/secrets/local-encrypted-provider.d.ts.map +1 -0
  361. package/dist/secrets/local-encrypted-provider.js +244 -0
  362. package/dist/secrets/local-encrypted-provider.js.map +1 -0
  363. package/dist/secrets/provider-registry.d.ts +6 -0
  364. package/dist/secrets/provider-registry.d.ts.map +1 -0
  365. package/dist/secrets/provider-registry.js +24 -0
  366. package/dist/secrets/provider-registry.js.map +1 -0
  367. package/dist/secrets/types.d.ts +138 -0
  368. package/dist/secrets/types.d.ts.map +1 -0
  369. package/dist/secrets/types.js +36 -0
  370. package/dist/secrets/types.js.map +1 -0
  371. package/dist/services/access.d.ts +184 -0
  372. package/dist/services/access.d.ts.map +1 -0
  373. package/dist/services/access.js +542 -0
  374. package/dist/services/access.js.map +1 -0
  375. package/dist/services/activity-log.d.ts +19 -0
  376. package/dist/services/activity-log.d.ts.map +1 -0
  377. package/dist/services/activity-log.js +99 -0
  378. package/dist/services/activity-log.js.map +1 -0
  379. package/dist/services/activity.d.ts +462 -0
  380. package/dist/services/activity.d.ts.map +1 -0
  381. package/dist/services/activity.js +443 -0
  382. package/dist/services/activity.js.map +1 -0
  383. package/dist/services/adapter-plugin-store.d.ts +36 -0
  384. package/dist/services/adapter-plugin-store.d.ts.map +1 -0
  385. package/dist/services/adapter-plugin-store.js +154 -0
  386. package/dist/services/adapter-plugin-store.js.map +1 -0
  387. package/dist/services/agent-instructions.d.ts +91 -0
  388. package/dist/services/agent-instructions.d.ts.map +1 -0
  389. package/dist/services/agent-instructions.js +580 -0
  390. package/dist/services/agent-instructions.js.map +1 -0
  391. package/dist/services/agent-permissions.d.ts +6 -0
  392. package/dist/services/agent-permissions.d.ts.map +1 -0
  393. package/dist/services/agent-permissions.js +20 -0
  394. package/dist/services/agent-permissions.js.map +1 -0
  395. package/dist/services/agent-start-lock.d.ts +2 -0
  396. package/dist/services/agent-start-lock.d.ts.map +1 -0
  397. package/dist/services/agent-start-lock.js +43 -0
  398. package/dist/services/agent-start-lock.js.map +1 -0
  399. package/dist/services/agents.d.ts +2253 -0
  400. package/dist/services/agents.d.ts.map +1 -0
  401. package/dist/services/agents.js +609 -0
  402. package/dist/services/agents.js.map +1 -0
  403. package/dist/services/approvals.d.ts +546 -0
  404. package/dist/services/approvals.d.ts.map +1 -0
  405. package/dist/services/approvals.js +212 -0
  406. package/dist/services/approvals.js.map +1 -0
  407. package/dist/services/assets.d.ts +33 -0
  408. package/dist/services/assets.d.ts.map +1 -0
  409. package/dist/services/assets.js +17 -0
  410. package/dist/services/assets.js.map +1 -0
  411. package/dist/services/authorization.d.ts +67 -0
  412. package/dist/services/authorization.d.ts.map +1 -0
  413. package/dist/services/authorization.js +608 -0
  414. package/dist/services/authorization.js.map +1 -0
  415. package/dist/services/botfather/authoring-lock.d.ts +17 -0
  416. package/dist/services/botfather/authoring-lock.d.ts.map +1 -0
  417. package/dist/services/botfather/authoring-lock.js +23 -0
  418. package/dist/services/botfather/authoring-lock.js.map +1 -0
  419. package/dist/services/botfather/authoring-lock.test.d.ts +2 -0
  420. package/dist/services/botfather/authoring-lock.test.d.ts.map +1 -0
  421. package/dist/services/botfather/authoring-lock.test.js +25 -0
  422. package/dist/services/botfather/authoring-lock.test.js.map +1 -0
  423. package/dist/services/botfather/client.d.ts +26 -0
  424. package/dist/services/botfather/client.d.ts.map +1 -0
  425. package/dist/services/botfather/client.js +113 -0
  426. package/dist/services/botfather/client.js.map +1 -0
  427. package/dist/services/botfather/credentials.d.ts +15 -0
  428. package/dist/services/botfather/credentials.d.ts.map +1 -0
  429. package/dist/services/botfather/credentials.js +39 -0
  430. package/dist/services/botfather/credentials.js.map +1 -0
  431. package/dist/services/botfather/enrollment.d.ts +49 -0
  432. package/dist/services/botfather/enrollment.d.ts.map +1 -0
  433. package/dist/services/botfather/enrollment.js +145 -0
  434. package/dist/services/botfather/enrollment.js.map +1 -0
  435. package/dist/services/botfather/instance-limit-enforcement.d.ts +44 -0
  436. package/dist/services/botfather/instance-limit-enforcement.d.ts.map +1 -0
  437. package/dist/services/botfather/instance-limit-enforcement.js +83 -0
  438. package/dist/services/botfather/instance-limit-enforcement.js.map +1 -0
  439. package/dist/services/botfather/instance-limit-enforcement.test.d.ts +2 -0
  440. package/dist/services/botfather/instance-limit-enforcement.test.d.ts.map +1 -0
  441. package/dist/services/botfather/instance-limit-enforcement.test.js +66 -0
  442. package/dist/services/botfather/instance-limit-enforcement.test.js.map +1 -0
  443. package/dist/services/botfather/limits-store.d.ts +36 -0
  444. package/dist/services/botfather/limits-store.d.ts.map +1 -0
  445. package/dist/services/botfather/limits-store.js +94 -0
  446. package/dist/services/botfather/limits-store.js.map +1 -0
  447. package/dist/services/botfather/limits-store.test.d.ts +2 -0
  448. package/dist/services/botfather/limits-store.test.d.ts.map +1 -0
  449. package/dist/services/botfather/limits-store.test.js +70 -0
  450. package/dist/services/botfather/limits-store.test.js.map +1 -0
  451. package/dist/services/botfather/reporter.d.ts +41 -0
  452. package/dist/services/botfather/reporter.d.ts.map +1 -0
  453. package/dist/services/botfather/reporter.js +448 -0
  454. package/dist/services/botfather/reporter.js.map +1 -0
  455. package/dist/services/botfather/service.d.ts +84 -0
  456. package/dist/services/botfather/service.d.ts.map +1 -0
  457. package/dist/services/botfather/service.js +229 -0
  458. package/dist/services/botfather/service.js.map +1 -0
  459. package/dist/services/botfather/service.test.d.ts +2 -0
  460. package/dist/services/botfather/service.test.d.ts.map +1 -0
  461. package/dist/services/botfather/service.test.js +120 -0
  462. package/dist/services/botfather/service.test.js.map +1 -0
  463. package/dist/services/botfather/skill-catalog.d.ts +28 -0
  464. package/dist/services/botfather/skill-catalog.d.ts.map +1 -0
  465. package/dist/services/botfather/skill-catalog.js +101 -0
  466. package/dist/services/botfather/skill-catalog.js.map +1 -0
  467. package/dist/services/botfather/skill-catalog.test.d.ts +2 -0
  468. package/dist/services/botfather/skill-catalog.test.d.ts.map +1 -0
  469. package/dist/services/botfather/skill-catalog.test.js +151 -0
  470. package/dist/services/botfather/skill-catalog.test.js.map +1 -0
  471. package/dist/services/budgets.d.ts +38 -0
  472. package/dist/services/budgets.d.ts.map +1 -0
  473. package/dist/services/budgets.js +833 -0
  474. package/dist/services/budgets.js.map +1 -0
  475. package/dist/services/catalog-provenance.d.ts +7 -0
  476. package/dist/services/catalog-provenance.d.ts.map +1 -0
  477. package/dist/services/catalog-provenance.js +64 -0
  478. package/dist/services/catalog-provenance.js.map +1 -0
  479. package/dist/services/cloud-upstreams.d.ts +42 -0
  480. package/dist/services/cloud-upstreams.d.ts.map +1 -0
  481. package/dist/services/cloud-upstreams.js +1071 -0
  482. package/dist/services/cloud-upstreams.js.map +1 -0
  483. package/dist/services/costs.d.ts +127 -0
  484. package/dist/services/costs.d.ts.map +1 -0
  485. package/dist/services/costs.js +409 -0
  486. package/dist/services/costs.js.map +1 -0
  487. package/dist/services/cron.d.ts +80 -0
  488. package/dist/services/cron.d.ts.map +1 -0
  489. package/dist/services/cron.js +300 -0
  490. package/dist/services/cron.js.map +1 -0
  491. package/dist/services/dashboard.d.ts +34 -0
  492. package/dist/services/dashboard.d.ts.map +1 -0
  493. package/dist/services/dashboard.js +142 -0
  494. package/dist/services/dashboard.js.map +1 -0
  495. package/dist/services/default-agent-instructions.d.ts +9 -0
  496. package/dist/services/default-agent-instructions.d.ts.map +1 -0
  497. package/dist/services/default-agent-instructions.js +20 -0
  498. package/dist/services/default-agent-instructions.js.map +1 -0
  499. package/dist/services/document-annotations.d.ts +160 -0
  500. package/dist/services/document-annotations.d.ts.map +1 -0
  501. package/dist/services/document-annotations.js +324 -0
  502. package/dist/services/document-annotations.js.map +1 -0
  503. package/dist/services/documents.d.ts +347 -0
  504. package/dist/services/documents.d.ts.map +1 -0
  505. package/dist/services/documents.js +638 -0
  506. package/dist/services/documents.js.map +1 -0
  507. package/dist/services/environment-config.d.ts +55 -0
  508. package/dist/services/environment-config.d.ts.map +1 -0
  509. package/dist/services/environment-config.js +441 -0
  510. package/dist/services/environment-config.js.map +1 -0
  511. package/dist/services/environment-execution-target.d.ts +21 -0
  512. package/dist/services/environment-execution-target.d.ts.map +1 -0
  513. package/dist/services/environment-execution-target.js +121 -0
  514. package/dist/services/environment-execution-target.js.map +1 -0
  515. package/dist/services/environment-probe.d.ts +9 -0
  516. package/dist/services/environment-probe.d.ts.map +1 -0
  517. package/dist/services/environment-probe.js +106 -0
  518. package/dist/services/environment-probe.js.map +1 -0
  519. package/dist/services/environment-run-orchestrator.d.ts +124 -0
  520. package/dist/services/environment-run-orchestrator.d.ts.map +1 -0
  521. package/dist/services/environment-run-orchestrator.js +392 -0
  522. package/dist/services/environment-run-orchestrator.js.map +1 -0
  523. package/dist/services/environment-runtime.d.ts +90 -0
  524. package/dist/services/environment-runtime.d.ts.map +1 -0
  525. package/dist/services/environment-runtime.js +968 -0
  526. package/dist/services/environment-runtime.js.map +1 -0
  527. package/dist/services/environments.d.ts +36 -0
  528. package/dist/services/environments.d.ts.map +1 -0
  529. package/dist/services/environments.js +260 -0
  530. package/dist/services/environments.js.map +1 -0
  531. package/dist/services/execution-workspace-policy.d.ts +42 -0
  532. package/dist/services/execution-workspace-policy.d.ts.map +1 -0
  533. package/dist/services/execution-workspace-policy.js +262 -0
  534. package/dist/services/execution-workspace-policy.js.map +1 -0
  535. package/dist/services/execution-workspaces.d.ts +30 -0
  536. package/dist/services/execution-workspaces.d.ts.map +1 -0
  537. package/dist/services/execution-workspaces.js +645 -0
  538. package/dist/services/execution-workspaces.js.map +1 -0
  539. package/dist/services/finance.d.ts +93 -0
  540. package/dist/services/finance.d.ts.map +1 -0
  541. package/dist/services/finance.js +120 -0
  542. package/dist/services/finance.js.map +1 -0
  543. package/dist/services/github-fetch.d.ts +4 -0
  544. package/dist/services/github-fetch.d.ts.map +1 -0
  545. package/dist/services/github-fetch.js +23 -0
  546. package/dist/services/github-fetch.js.map +1 -0
  547. package/dist/services/goals.d.ts +433 -0
  548. package/dist/services/goals.d.ts.map +1 -0
  549. package/dist/services/goals.js +54 -0
  550. package/dist/services/goals.js.map +1 -0
  551. package/dist/services/heartbeat-circuit-breaker.d.ts +89 -0
  552. package/dist/services/heartbeat-circuit-breaker.d.ts.map +1 -0
  553. package/dist/services/heartbeat-circuit-breaker.js +156 -0
  554. package/dist/services/heartbeat-circuit-breaker.js.map +1 -0
  555. package/dist/services/heartbeat-circuit-breaker.test.d.ts +2 -0
  556. package/dist/services/heartbeat-circuit-breaker.test.d.ts.map +1 -0
  557. package/dist/services/heartbeat-circuit-breaker.test.js +97 -0
  558. package/dist/services/heartbeat-circuit-breaker.test.js.map +1 -0
  559. package/dist/services/heartbeat-run-summary.d.ts +7 -0
  560. package/dist/services/heartbeat-run-summary.d.ts.map +1 -0
  561. package/dist/services/heartbeat-run-summary.js +84 -0
  562. package/dist/services/heartbeat-run-summary.js.map +1 -0
  563. package/dist/services/heartbeat-stop-metadata.d.ts +28 -0
  564. package/dist/services/heartbeat-stop-metadata.d.ts.map +1 -0
  565. package/dist/services/heartbeat-stop-metadata.js +86 -0
  566. package/dist/services/heartbeat-stop-metadata.js.map +1 -0
  567. package/dist/services/heartbeat-stop-metadata.test.d.ts +2 -0
  568. package/dist/services/heartbeat-stop-metadata.test.d.ts.map +1 -0
  569. package/dist/services/heartbeat-stop-metadata.test.js +93 -0
  570. package/dist/services/heartbeat-stop-metadata.test.js.map +1 -0
  571. package/dist/services/heartbeat.d.ts +1578 -0
  572. package/dist/services/heartbeat.d.ts.map +1 -0
  573. package/dist/services/heartbeat.js +8274 -0
  574. package/dist/services/heartbeat.js.map +1 -0
  575. package/dist/services/hire-hook.d.ts +14 -0
  576. package/dist/services/hire-hook.d.ts.map +1 -0
  577. package/dist/services/hire-hook.js +85 -0
  578. package/dist/services/hire-hook.js.map +1 -0
  579. package/dist/services/inbox-dismissals.d.ts +22 -0
  580. package/dist/services/inbox-dismissals.d.ts.map +1 -0
  581. package/dist/services/inbox-dismissals.js +33 -0
  582. package/dist/services/inbox-dismissals.js.map +1 -0
  583. package/dist/services/index.d.ts +50 -0
  584. package/dist/services/index.d.ts.map +1 -0
  585. package/dist/services/index.js +49 -0
  586. package/dist/services/index.js.map +1 -0
  587. package/dist/services/instance-settings.d.ts +12 -0
  588. package/dist/services/instance-settings.d.ts.map +1 -0
  589. package/dist/services/instance-settings.js +142 -0
  590. package/dist/services/instance-settings.js.map +1 -0
  591. package/dist/services/invite-grants.d.ts +15 -0
  592. package/dist/services/invite-grants.d.ts.map +1 -0
  593. package/dist/services/invite-grants.js +50 -0
  594. package/dist/services/invite-grants.js.map +1 -0
  595. package/dist/services/issue-approvals.d.ts +56 -0
  596. package/dist/services/issue-approvals.d.ts.map +1 -0
  597. package/dist/services/issue-approvals.js +153 -0
  598. package/dist/services/issue-approvals.js.map +1 -0
  599. package/dist/services/issue-assignment-wakeup.d.ts +29 -0
  600. package/dist/services/issue-assignment-wakeup.d.ts.map +1 -0
  601. package/dist/services/issue-assignment-wakeup.js +22 -0
  602. package/dist/services/issue-assignment-wakeup.js.map +1 -0
  603. package/dist/services/issue-continuation-summary.d.ts +71 -0
  604. package/dist/services/issue-continuation-summary.d.ts.map +1 -0
  605. package/dist/services/issue-continuation-summary.js +222 -0
  606. package/dist/services/issue-continuation-summary.js.map +1 -0
  607. package/dist/services/issue-execution-policy.d.ts +93 -0
  608. package/dist/services/issue-execution-policy.d.ts.map +1 -0
  609. package/dist/services/issue-execution-policy.js +838 -0
  610. package/dist/services/issue-execution-policy.js.map +1 -0
  611. package/dist/services/issue-goal-fallback.d.ts +18 -0
  612. package/dist/services/issue-goal-fallback.d.ts.map +1 -0
  613. package/dist/services/issue-goal-fallback.js +33 -0
  614. package/dist/services/issue-goal-fallback.js.map +1 -0
  615. package/dist/services/issue-liveness.d.ts +3 -0
  616. package/dist/services/issue-liveness.d.ts.map +1 -0
  617. package/dist/services/issue-liveness.js +2 -0
  618. package/dist/services/issue-liveness.js.map +1 -0
  619. package/dist/services/issue-recovery-actions.d.ts +40 -0
  620. package/dist/services/issue-recovery-actions.d.ts.map +1 -0
  621. package/dist/services/issue-recovery-actions.js +204 -0
  622. package/dist/services/issue-recovery-actions.js.map +1 -0
  623. package/dist/services/issue-references.d.ts +22 -0
  624. package/dist/services/issue-references.d.ts.map +1 -0
  625. package/dist/services/issue-references.js +341 -0
  626. package/dist/services/issue-references.js.map +1 -0
  627. package/dist/services/issue-thread-interactions.d.ts +81 -0
  628. package/dist/services/issue-thread-interactions.d.ts.map +1 -0
  629. package/dist/services/issue-thread-interactions.js +1017 -0
  630. package/dist/services/issue-thread-interactions.js.map +1 -0
  631. package/dist/services/issue-thread-interactions.test.d.ts +2 -0
  632. package/dist/services/issue-thread-interactions.test.d.ts.map +1 -0
  633. package/dist/services/issue-thread-interactions.test.js +195 -0
  634. package/dist/services/issue-thread-interactions.test.js.map +1 -0
  635. package/dist/services/issue-tree-control.d.ts +89 -0
  636. package/dist/services/issue-tree-control.d.ts.map +1 -0
  637. package/dist/services/issue-tree-control.js +933 -0
  638. package/dist/services/issue-tree-control.js.map +1 -0
  639. package/dist/services/issues.d.ts +898 -0
  640. package/dist/services/issues.d.ts.map +1 -0
  641. package/dist/services/issues.js +4705 -0
  642. package/dist/services/issues.js.map +1 -0
  643. package/dist/services/json-schema-secret-refs.d.ts +5 -0
  644. package/dist/services/json-schema-secret-refs.d.ts.map +1 -0
  645. package/dist/services/json-schema-secret-refs.js +67 -0
  646. package/dist/services/json-schema-secret-refs.js.map +1 -0
  647. package/dist/services/live-events.d.ts +17 -0
  648. package/dist/services/live-events.d.ts.map +1 -0
  649. package/dist/services/live-events.js +33 -0
  650. package/dist/services/live-events.js.map +1 -0
  651. package/dist/services/local-service-supervisor.d.ts +56 -0
  652. package/dist/services/local-service-supervisor.d.ts.map +1 -0
  653. package/dist/services/local-service-supervisor.js +284 -0
  654. package/dist/services/local-service-supervisor.js.map +1 -0
  655. package/dist/services/operator-auth.d.ts +271 -0
  656. package/dist/services/operator-auth.d.ts.map +1 -0
  657. package/dist/services/operator-auth.js +361 -0
  658. package/dist/services/operator-auth.js.map +1 -0
  659. package/dist/services/plugin-capability-validator.d.ts +108 -0
  660. package/dist/services/plugin-capability-validator.d.ts.map +1 -0
  661. package/dist/services/plugin-capability-validator.js +314 -0
  662. package/dist/services/plugin-capability-validator.js.map +1 -0
  663. package/dist/services/plugin-config-validator.d.ts +26 -0
  664. package/dist/services/plugin-config-validator.d.ts.map +1 -0
  665. package/dist/services/plugin-config-validator.js +41 -0
  666. package/dist/services/plugin-config-validator.js.map +1 -0
  667. package/dist/services/plugin-database.d.ts +49 -0
  668. package/dist/services/plugin-database.d.ts.map +1 -0
  669. package/dist/services/plugin-database.js +475 -0
  670. package/dist/services/plugin-database.js.map +1 -0
  671. package/dist/services/plugin-dev-watcher.d.ts +30 -0
  672. package/dist/services/plugin-dev-watcher.d.ts.map +1 -0
  673. package/dist/services/plugin-dev-watcher.js +246 -0
  674. package/dist/services/plugin-dev-watcher.js.map +1 -0
  675. package/dist/services/plugin-environment-driver.d.ts +126 -0
  676. package/dist/services/plugin-environment-driver.d.ts.map +1 -0
  677. package/dist/services/plugin-environment-driver.js +226 -0
  678. package/dist/services/plugin-environment-driver.js.map +1 -0
  679. package/dist/services/plugin-event-bus.d.ts +149 -0
  680. package/dist/services/plugin-event-bus.d.ts.map +1 -0
  681. package/dist/services/plugin-event-bus.js +258 -0
  682. package/dist/services/plugin-event-bus.js.map +1 -0
  683. package/dist/services/plugin-host-service-cleanup.d.ts +14 -0
  684. package/dist/services/plugin-host-service-cleanup.d.ts.map +1 -0
  685. package/dist/services/plugin-host-service-cleanup.js +37 -0
  686. package/dist/services/plugin-host-service-cleanup.js.map +1 -0
  687. package/dist/services/plugin-host-services.d.ts +17 -0
  688. package/dist/services/plugin-host-services.d.ts.map +1 -0
  689. package/dist/services/plugin-host-services.js +2460 -0
  690. package/dist/services/plugin-host-services.js.map +1 -0
  691. package/dist/services/plugin-job-coordinator.d.ts +81 -0
  692. package/dist/services/plugin-job-coordinator.d.ts.map +1 -0
  693. package/dist/services/plugin-job-coordinator.js +172 -0
  694. package/dist/services/plugin-job-coordinator.js.map +1 -0
  695. package/dist/services/plugin-job-scheduler.d.ts +163 -0
  696. package/dist/services/plugin-job-scheduler.d.ts.map +1 -0
  697. package/dist/services/plugin-job-scheduler.js +454 -0
  698. package/dist/services/plugin-job-scheduler.js.map +1 -0
  699. package/dist/services/plugin-job-store.d.ts +208 -0
  700. package/dist/services/plugin-job-store.d.ts.map +1 -0
  701. package/dist/services/plugin-job-store.js +350 -0
  702. package/dist/services/plugin-job-store.js.map +1 -0
  703. package/dist/services/plugin-lifecycle.d.ts +203 -0
  704. package/dist/services/plugin-lifecycle.d.ts.map +1 -0
  705. package/dist/services/plugin-lifecycle.js +501 -0
  706. package/dist/services/plugin-lifecycle.js.map +1 -0
  707. package/dist/services/plugin-loader.d.ts +453 -0
  708. package/dist/services/plugin-loader.d.ts.map +1 -0
  709. package/dist/services/plugin-loader.js +1295 -0
  710. package/dist/services/plugin-loader.js.map +1 -0
  711. package/dist/services/plugin-local-folders.d.ts +49 -0
  712. package/dist/services/plugin-local-folders.d.ts.map +1 -0
  713. package/dist/services/plugin-local-folders.js +510 -0
  714. package/dist/services/plugin-local-folders.js.map +1 -0
  715. package/dist/services/plugin-log-retention.d.ts +20 -0
  716. package/dist/services/plugin-log-retention.d.ts.map +1 -0
  717. package/dist/services/plugin-log-retention.js +63 -0
  718. package/dist/services/plugin-log-retention.js.map +1 -0
  719. package/dist/services/plugin-managed-agents.d.ts +15 -0
  720. package/dist/services/plugin-managed-agents.d.ts.map +1 -0
  721. package/dist/services/plugin-managed-agents.js +457 -0
  722. package/dist/services/plugin-managed-agents.js.map +1 -0
  723. package/dist/services/plugin-managed-routines.d.ts +42 -0
  724. package/dist/services/plugin-managed-routines.d.ts.map +1 -0
  725. package/dist/services/plugin-managed-routines.js +416 -0
  726. package/dist/services/plugin-managed-routines.js.map +1 -0
  727. package/dist/services/plugin-managed-skills.d.ts +14 -0
  728. package/dist/services/plugin-managed-skills.d.ts.map +1 -0
  729. package/dist/services/plugin-managed-skills.js +264 -0
  730. package/dist/services/plugin-managed-skills.js.map +1 -0
  731. package/dist/services/plugin-manifest-validator.d.ts +79 -0
  732. package/dist/services/plugin-manifest-validator.d.ts.map +1 -0
  733. package/dist/services/plugin-manifest-validator.js +84 -0
  734. package/dist/services/plugin-manifest-validator.js.map +1 -0
  735. package/dist/services/plugin-registry.d.ts +2550 -0
  736. package/dist/services/plugin-registry.d.ts.map +1 -0
  737. package/dist/services/plugin-registry.js +581 -0
  738. package/dist/services/plugin-registry.js.map +1 -0
  739. package/dist/services/plugin-runtime-sandbox.d.ts +40 -0
  740. package/dist/services/plugin-runtime-sandbox.d.ts.map +1 -0
  741. package/dist/services/plugin-runtime-sandbox.js +154 -0
  742. package/dist/services/plugin-runtime-sandbox.js.map +1 -0
  743. package/dist/services/plugin-secrets-handler.d.ts +83 -0
  744. package/dist/services/plugin-secrets-handler.d.ts.map +1 -0
  745. package/dist/services/plugin-secrets-handler.js +168 -0
  746. package/dist/services/plugin-secrets-handler.js.map +1 -0
  747. package/dist/services/plugin-state-store.d.ts +92 -0
  748. package/dist/services/plugin-state-store.d.ts.map +1 -0
  749. package/dist/services/plugin-state-store.js +190 -0
  750. package/dist/services/plugin-state-store.js.map +1 -0
  751. package/dist/services/plugin-stream-bus.d.ts +29 -0
  752. package/dist/services/plugin-stream-bus.d.ts.map +1 -0
  753. package/dist/services/plugin-stream-bus.js +48 -0
  754. package/dist/services/plugin-stream-bus.js.map +1 -0
  755. package/dist/services/plugin-tool-dispatcher.d.ts +181 -0
  756. package/dist/services/plugin-tool-dispatcher.d.ts.map +1 -0
  757. package/dist/services/plugin-tool-dispatcher.js +224 -0
  758. package/dist/services/plugin-tool-dispatcher.js.map +1 -0
  759. package/dist/services/plugin-tool-registry.d.ts +192 -0
  760. package/dist/services/plugin-tool-registry.d.ts.map +1 -0
  761. package/dist/services/plugin-tool-registry.js +224 -0
  762. package/dist/services/plugin-tool-registry.js.map +1 -0
  763. package/dist/services/plugin-worker-manager.d.ts +262 -0
  764. package/dist/services/plugin-worker-manager.d.ts.map +1 -0
  765. package/dist/services/plugin-worker-manager.js +942 -0
  766. package/dist/services/plugin-worker-manager.js.map +1 -0
  767. package/dist/services/portable-path.d.ts +2 -0
  768. package/dist/services/portable-path.d.ts.map +1 -0
  769. package/dist/services/portable-path.js +15 -0
  770. package/dist/services/portable-path.js.map +1 -0
  771. package/dist/services/principal-access-compatibility.d.ts +26 -0
  772. package/dist/services/principal-access-compatibility.d.ts.map +1 -0
  773. package/dist/services/principal-access-compatibility.js +94 -0
  774. package/dist/services/principal-access-compatibility.js.map +1 -0
  775. package/dist/services/productivity-review.d.ts +83 -0
  776. package/dist/services/productivity-review.d.ts.map +1 -0
  777. package/dist/services/productivity-review.js +652 -0
  778. package/dist/services/productivity-review.js.map +1 -0
  779. package/dist/services/project-workspace-runtime-config.d.ts +4 -0
  780. package/dist/services/project-workspace-runtime-config.d.ts.map +1 -0
  781. package/dist/services/project-workspace-runtime-config.js +54 -0
  782. package/dist/services/project-workspace-runtime-config.js.map +1 -0
  783. package/dist/services/projects.d.ts +99 -0
  784. package/dist/services/projects.d.ts.map +1 -0
  785. package/dist/services/projects.js +879 -0
  786. package/dist/services/projects.js.map +1 -0
  787. package/dist/services/quota-windows.d.ts +9 -0
  788. package/dist/services/quota-windows.d.ts.map +1 -0
  789. package/dist/services/quota-windows.js +56 -0
  790. package/dist/services/quota-windows.js.map +1 -0
  791. package/dist/services/recovery/index.d.ts +10 -0
  792. package/dist/services/recovery/index.d.ts.map +1 -0
  793. package/dist/services/recovery/index.js +6 -0
  794. package/dist/services/recovery/index.js.map +1 -0
  795. package/dist/services/recovery/issue-graph-liveness.d.ts +85 -0
  796. package/dist/services/recovery/issue-graph-liveness.d.ts.map +1 -0
  797. package/dist/services/recovery/issue-graph-liveness.js +356 -0
  798. package/dist/services/recovery/issue-graph-liveness.js.map +1 -0
  799. package/dist/services/recovery/model-profile-hint.d.ts +21 -0
  800. package/dist/services/recovery/model-profile-hint.d.ts.map +1 -0
  801. package/dist/services/recovery/model-profile-hint.js +36 -0
  802. package/dist/services/recovery/model-profile-hint.js.map +1 -0
  803. package/dist/services/recovery/model-profile-hint.test.d.ts +2 -0
  804. package/dist/services/recovery/model-profile-hint.test.d.ts.map +1 -0
  805. package/dist/services/recovery/model-profile-hint.test.js +38 -0
  806. package/dist/services/recovery/model-profile-hint.test.js.map +1 -0
  807. package/dist/services/recovery/origins.d.ts +36 -0
  808. package/dist/services/recovery/origins.d.ts.map +1 -0
  809. package/dist/services/recovery/origins.js +45 -0
  810. package/dist/services/recovery/origins.js.map +1 -0
  811. package/dist/services/recovery/pause-hold-guard.d.ts +6 -0
  812. package/dist/services/recovery/pause-hold-guard.d.ts.map +1 -0
  813. package/dist/services/recovery/pause-hold-guard.js +6 -0
  814. package/dist/services/recovery/pause-hold-guard.js.map +1 -0
  815. package/dist/services/recovery/run-liveness-continuations.d.ts +50 -0
  816. package/dist/services/recovery/run-liveness-continuations.d.ts.map +1 -0
  817. package/dist/services/recovery/run-liveness-continuations.js +117 -0
  818. package/dist/services/recovery/run-liveness-continuations.js.map +1 -0
  819. package/dist/services/recovery/service.d.ts +258 -0
  820. package/dist/services/recovery/service.d.ts.map +1 -0
  821. package/dist/services/recovery/service.js +2892 -0
  822. package/dist/services/recovery/service.js.map +1 -0
  823. package/dist/services/recovery/successful-run-handoff.d.ts +89 -0
  824. package/dist/services/recovery/successful-run-handoff.d.ts.map +1 -0
  825. package/dist/services/recovery/successful-run-handoff.js +304 -0
  826. package/dist/services/recovery/successful-run-handoff.js.map +1 -0
  827. package/dist/services/recovery/successful-run-handoff.test.d.ts +2 -0
  828. package/dist/services/recovery/successful-run-handoff.test.d.ts.map +1 -0
  829. package/dist/services/recovery/successful-run-handoff.test.js +276 -0
  830. package/dist/services/recovery/successful-run-handoff.test.js.map +1 -0
  831. package/dist/services/resource-memberships.d.ts +55 -0
  832. package/dist/services/resource-memberships.d.ts.map +1 -0
  833. package/dist/services/resource-memberships.js +213 -0
  834. package/dist/services/resource-memberships.js.map +1 -0
  835. package/dist/services/routines.d.ts +170 -0
  836. package/dist/services/routines.d.ts.map +1 -0
  837. package/dist/services/routines.js +2015 -0
  838. package/dist/services/routines.js.map +1 -0
  839. package/dist/services/run-continuations.d.ts +3 -0
  840. package/dist/services/run-continuations.d.ts.map +1 -0
  841. package/dist/services/run-continuations.js +2 -0
  842. package/dist/services/run-continuations.js.map +1 -0
  843. package/dist/services/run-liveness.d.ts +46 -0
  844. package/dist/services/run-liveness.d.ts.map +1 -0
  845. package/dist/services/run-liveness.js +275 -0
  846. package/dist/services/run-liveness.js.map +1 -0
  847. package/dist/services/run-log-store.d.ts +34 -0
  848. package/dist/services/run-log-store.d.ts.map +1 -0
  849. package/dist/services/run-log-store.js +111 -0
  850. package/dist/services/run-log-store.js.map +1 -0
  851. package/dist/services/sandbox-provider-runtime.d.ts +132 -0
  852. package/dist/services/sandbox-provider-runtime.d.ts.map +1 -0
  853. package/dist/services/sandbox-provider-runtime.js +216 -0
  854. package/dist/services/sandbox-provider-runtime.js.map +1 -0
  855. package/dist/services/secrets.d.ts +1991 -0
  856. package/dist/services/secrets.d.ts.map +1 -0
  857. package/dist/services/secrets.js +1781 -0
  858. package/dist/services/secrets.js.map +1 -0
  859. package/dist/services/session-workspace-cwd.d.ts +2 -0
  860. package/dist/services/session-workspace-cwd.d.ts.map +1 -0
  861. package/dist/services/session-workspace-cwd.js +24 -0
  862. package/dist/services/session-workspace-cwd.js.map +1 -0
  863. package/dist/services/session-workspace-cwd.test.d.ts +2 -0
  864. package/dist/services/session-workspace-cwd.test.d.ts.map +1 -0
  865. package/dist/services/session-workspace-cwd.test.js +25 -0
  866. package/dist/services/session-workspace-cwd.test.js.map +1 -0
  867. package/dist/services/sidebar-badges.d.ts +14 -0
  868. package/dist/services/sidebar-badges.d.ts.map +1 -0
  869. package/dist/services/sidebar-badges.js +48 -0
  870. package/dist/services/sidebar-badges.js.map +1 -0
  871. package/dist/services/sidebar-preferences.d.ts +9 -0
  872. package/dist/services/sidebar-preferences.d.ts.map +1 -0
  873. package/dist/services/sidebar-preferences.js +82 -0
  874. package/dist/services/sidebar-preferences.js.map +1 -0
  875. package/dist/services/skills-catalog.d.ts +14 -0
  876. package/dist/services/skills-catalog.d.ts.map +1 -0
  877. package/dist/services/skills-catalog.js +171 -0
  878. package/dist/services/skills-catalog.js.map +1 -0
  879. package/dist/services/squad-export-readme.d.ts +17 -0
  880. package/dist/services/squad-export-readme.d.ts.map +1 -0
  881. package/dist/services/squad-export-readme.js +148 -0
  882. package/dist/services/squad-export-readme.js.map +1 -0
  883. package/dist/services/squad-member-roles.d.ts +9 -0
  884. package/dist/services/squad-member-roles.d.ts.map +1 -0
  885. package/dist/services/squad-member-roles.js +48 -0
  886. package/dist/services/squad-member-roles.js.map +1 -0
  887. package/dist/services/squad-portability.d.ts +24 -0
  888. package/dist/services/squad-portability.d.ts.map +1 -0
  889. package/dist/services/squad-portability.js +4093 -0
  890. package/dist/services/squad-portability.js.map +1 -0
  891. package/dist/services/squad-search-rate-limit.d.ts +22 -0
  892. package/dist/services/squad-search-rate-limit.d.ts.map +1 -0
  893. package/dist/services/squad-search-rate-limit.js +38 -0
  894. package/dist/services/squad-search-rate-limit.js.map +1 -0
  895. package/dist/services/squad-search.d.ts +8 -0
  896. package/dist/services/squad-search.d.ts.map +1 -0
  897. package/dist/services/squad-search.js +626 -0
  898. package/dist/services/squad-search.js.map +1 -0
  899. package/dist/services/squad-skills.d.ts +107 -0
  900. package/dist/services/squad-skills.d.ts.map +1 -0
  901. package/dist/services/squad-skills.js +3044 -0
  902. package/dist/services/squad-skills.js.map +1 -0
  903. package/dist/services/squads.d.ts +154 -0
  904. package/dist/services/squads.d.ts.map +1 -0
  905. package/dist/services/squads.js +278 -0
  906. package/dist/services/squads.js.map +1 -0
  907. package/dist/services/wake-cycle-guard.d.ts +44 -0
  908. package/dist/services/wake-cycle-guard.d.ts.map +1 -0
  909. package/dist/services/wake-cycle-guard.js +79 -0
  910. package/dist/services/wake-cycle-guard.js.map +1 -0
  911. package/dist/services/wake-cycle-guard.test.d.ts +2 -0
  912. package/dist/services/wake-cycle-guard.test.d.ts.map +1 -0
  913. package/dist/services/wake-cycle-guard.test.js +67 -0
  914. package/dist/services/wake-cycle-guard.test.js.map +1 -0
  915. package/dist/services/work-products.d.ts +14 -0
  916. package/dist/services/work-products.d.ts.map +1 -0
  917. package/dist/services/work-products.js +100 -0
  918. package/dist/services/work-products.js.map +1 -0
  919. package/dist/services/workspace-operation-log-store.d.ts +33 -0
  920. package/dist/services/workspace-operation-log-store.d.ts.map +1 -0
  921. package/dist/services/workspace-operation-log-store.js +110 -0
  922. package/dist/services/workspace-operation-log-store.js.map +1 -0
  923. package/dist/services/workspace-operations.d.ts +44 -0
  924. package/dist/services/workspace-operations.d.ts.map +1 -0
  925. package/dist/services/workspace-operations.js +211 -0
  926. package/dist/services/workspace-operations.js.map +1 -0
  927. package/dist/services/workspace-realization.d.ts +33 -0
  928. package/dist/services/workspace-realization.d.ts.map +1 -0
  929. package/dist/services/workspace-realization.js +221 -0
  930. package/dist/services/workspace-realization.js.map +1 -0
  931. package/dist/services/workspace-runtime-read-model.d.ts +92 -0
  932. package/dist/services/workspace-runtime-read-model.d.ts.map +1 -0
  933. package/dist/services/workspace-runtime-read-model.js +67 -0
  934. package/dist/services/workspace-runtime-read-model.js.map +1 -0
  935. package/dist/services/workspace-runtime.d.ts +252 -0
  936. package/dist/services/workspace-runtime.d.ts.map +1 -0
  937. package/dist/services/workspace-runtime.js +2519 -0
  938. package/dist/services/workspace-runtime.js.map +1 -0
  939. package/dist/startup-banner.d.ts +32 -0
  940. package/dist/startup-banner.d.ts.map +1 -0
  941. package/dist/startup-banner.js +118 -0
  942. package/dist/startup-banner.js.map +1 -0
  943. package/dist/static-index-html.d.ts +2 -0
  944. package/dist/static-index-html.d.ts.map +1 -0
  945. package/dist/static-index-html.js +7 -0
  946. package/dist/static-index-html.js.map +1 -0
  947. package/dist/storage/index.d.ts +6 -0
  948. package/dist/storage/index.d.ts.map +1 -0
  949. package/dist/storage/index.js +29 -0
  950. package/dist/storage/index.js.map +1 -0
  951. package/dist/storage/local-disk-provider.d.ts +3 -0
  952. package/dist/storage/local-disk-provider.d.ts.map +1 -0
  953. package/dist/storage/local-disk-provider.js +85 -0
  954. package/dist/storage/local-disk-provider.js.map +1 -0
  955. package/dist/storage/provider-registry.d.ts +4 -0
  956. package/dist/storage/provider-registry.d.ts.map +1 -0
  957. package/dist/storage/provider-registry.js +15 -0
  958. package/dist/storage/provider-registry.js.map +1 -0
  959. package/dist/storage/s3-provider.d.ts +11 -0
  960. package/dist/storage/s3-provider.d.ts.map +1 -0
  961. package/dist/storage/s3-provider.js +124 -0
  962. package/dist/storage/s3-provider.js.map +1 -0
  963. package/dist/storage/service.d.ts +3 -0
  964. package/dist/storage/service.d.ts.map +1 -0
  965. package/dist/storage/service.js +120 -0
  966. package/dist/storage/service.js.map +1 -0
  967. package/dist/storage/types.d.ts +59 -0
  968. package/dist/storage/types.d.ts.map +1 -0
  969. package/dist/storage/types.js +2 -0
  970. package/dist/storage/types.js.map +1 -0
  971. package/dist/ui-branding.d.ts +13 -0
  972. package/dist/ui-branding.d.ts.map +1 -0
  973. package/dist/ui-branding.js +187 -0
  974. package/dist/ui-branding.js.map +1 -0
  975. package/dist/version.d.ts +2 -0
  976. package/dist/version.d.ts.map +1 -0
  977. package/dist/version.js +5 -0
  978. package/dist/version.js.map +1 -0
  979. package/dist/vite-html-renderer.d.ts +18 -0
  980. package/dist/vite-html-renderer.d.ts.map +1 -0
  981. package/dist/vite-html-renderer.js +61 -0
  982. package/dist/vite-html-renderer.js.map +1 -0
  983. package/dist/worktree-config.d.ts +19 -0
  984. package/dist/worktree-config.d.ts.map +1 -0
  985. package/dist/worktree-config.js +373 -0
  986. package/dist/worktree-config.js.map +1 -0
  987. package/package.json +92 -0
  988. package/skills/diagnose-why-work-stopped/SKILL.md +161 -0
  989. package/skills/para-memory-files/SKILL.md +104 -0
  990. package/skills/para-memory-files/references/schemas.md +35 -0
  991. package/skills/slaw/SKILL.md +371 -0
  992. package/skills/slaw/references/api-reference.md +879 -0
  993. package/skills/slaw/references/artifacts.md +44 -0
  994. package/skills/slaw/references/issue-workspaces.md +80 -0
  995. package/skills/slaw/references/routines.md +187 -0
  996. package/skills/slaw/references/squad-skills.md +258 -0
  997. package/skills/slaw/references/workflows.md +113 -0
  998. package/skills/slaw/scripts/slaw-upload-artifact.sh +371 -0
  999. package/skills/slaw-converting-plans-to-tasks/SKILL.md +42 -0
  1000. package/skills/slaw-create-agent/SKILL.md +163 -0
  1001. package/skills/slaw-create-agent/references/agent-instruction-templates.md +123 -0
  1002. package/skills/slaw-create-agent/references/agents/coder.md +64 -0
  1003. package/skills/slaw-create-agent/references/agents/qa.md +88 -0
  1004. package/skills/slaw-create-agent/references/agents/securityengineer.md +135 -0
  1005. package/skills/slaw-create-agent/references/agents/uxdesigner.md +115 -0
  1006. package/skills/slaw-create-agent/references/api-reference.md +110 -0
  1007. package/skills/slaw-create-agent/references/baseline-role-guide.md +168 -0
  1008. package/skills/slaw-create-agent/references/draft-review-checklist.md +95 -0
  1009. package/skills/slaw-create-plugin/SKILL.md +154 -0
  1010. package/skills/slaw-dev/SKILL.md +267 -0
  1011. package/skills/terminal-bench-loop/SKILL.md +236 -0
  1012. package/ui-dist/android-chrome-192x192.png +0 -0
  1013. package/ui-dist/android-chrome-512x512.png +0 -0
  1014. package/ui-dist/apple-touch-icon.png +0 -0
  1015. package/ui-dist/assets/apl-B4CMkyY2.js +1 -0
  1016. package/ui-dist/assets/arc-xbLjL0VN.js +1 -0
  1017. package/ui-dist/assets/architectureDiagram-3BPJPVTR-KcFd4B-U.js +36 -0
  1018. package/ui-dist/assets/asciiarmor-Df11BRmG.js +1 -0
  1019. package/ui-dist/assets/asn1-EdZsLKOL.js +1 -0
  1020. package/ui-dist/assets/asterisk-B-8jnY81.js +1 -0
  1021. package/ui-dist/assets/blockDiagram-GPEHLZMM-CSD4otEL.js +132 -0
  1022. package/ui-dist/assets/brainfuck-C4LP7Hcl.js +1 -0
  1023. package/ui-dist/assets/c4Diagram-AAUBKEIU-Cre_NEHp.js +10 -0
  1024. package/ui-dist/assets/channel-BFN8obi8.js +1 -0
  1025. package/ui-dist/assets/chunk-2J33WTMH-CssLBsbh.js +1 -0
  1026. package/ui-dist/assets/chunk-4BX2VUAB-DjiavNFv.js +1 -0
  1027. package/ui-dist/assets/chunk-55IACEB6-C_F0yeYq.js +1 -0
  1028. package/ui-dist/assets/chunk-727SXJPM-B1FAOW4a.js +206 -0
  1029. package/ui-dist/assets/chunk-AQP2D5EJ-Do1241W-.js +231 -0
  1030. package/ui-dist/assets/chunk-FMBD7UC4-BQRrOMZD.js +15 -0
  1031. package/ui-dist/assets/chunk-ND2GUHAM-BPSt3kZ1.js +1 -0
  1032. package/ui-dist/assets/chunk-QZHKN3VN-BSpmhWDD.js +1 -0
  1033. package/ui-dist/assets/classDiagram-4FO5ZUOK-1Ay0zFCU.js +1 -0
  1034. package/ui-dist/assets/classDiagram-v2-Q7XG4LA2-1Ay0zFCU.js +1 -0
  1035. package/ui-dist/assets/clike-B9uivgTg.js +1 -0
  1036. package/ui-dist/assets/clojure-BMjYHr_A.js +1 -0
  1037. package/ui-dist/assets/cmake-BQqOBYOt.js +1 -0
  1038. package/ui-dist/assets/cobol-CWcv1MsR.js +1 -0
  1039. package/ui-dist/assets/coffeescript-S37ZYGWr.js +1 -0
  1040. package/ui-dist/assets/commonlisp-DBKNyK5s.js +1 -0
  1041. package/ui-dist/assets/cose-bilkent-S5V4N54A-CK2f2Te4.js +1 -0
  1042. package/ui-dist/assets/crystal-SjHAIU92.js +1 -0
  1043. package/ui-dist/assets/css-BnMrqG3P.js +1 -0
  1044. package/ui-dist/assets/cypher-C_CwsFkJ.js +1 -0
  1045. package/ui-dist/assets/cytoscape.esm-D8joxN9f.js +321 -0
  1046. package/ui-dist/assets/d-pRatUO7H.js +1 -0
  1047. package/ui-dist/assets/dagre-BM42HDAG-DaOXTN9-.js +4 -0
  1048. package/ui-dist/assets/defaultLocale-DX6XiGOO.js +1 -0
  1049. package/ui-dist/assets/diagram-2AECGRRQ-D0ScQUGy.js +43 -0
  1050. package/ui-dist/assets/diagram-5GNKFQAL-7mH4Cncd.js +10 -0
  1051. package/ui-dist/assets/diagram-KO2AKTUF-aA9kuK-7.js +3 -0
  1052. package/ui-dist/assets/diagram-LMA3HP47-C9UXfmdK.js +24 -0
  1053. package/ui-dist/assets/diagram-OG6HWLK6-Ba3U-x1r.js +24 -0
  1054. package/ui-dist/assets/diff-DbItnlRl.js +1 -0
  1055. package/ui-dist/assets/dockerfile-BKs6k2Af.js +1 -0
  1056. package/ui-dist/assets/dtd-DF_7sFjM.js +1 -0
  1057. package/ui-dist/assets/dylan-DwRh75JA.js +1 -0
  1058. package/ui-dist/assets/ebnf-CDyGwa7X.js +1 -0
  1059. package/ui-dist/assets/ecl-Cabwm37j.js +1 -0
  1060. package/ui-dist/assets/eiffel-CnydiIhH.js +1 -0
  1061. package/ui-dist/assets/elm-vLlmbW-K.js +1 -0
  1062. package/ui-dist/assets/erDiagram-TEJ5UH35-CmskPKH1.js +85 -0
  1063. package/ui-dist/assets/erlang-BNw1qcRV.js +1 -0
  1064. package/ui-dist/assets/factor-kuTfRLto.js +1 -0
  1065. package/ui-dist/assets/fcl-Kvtd6kyn.js +1 -0
  1066. package/ui-dist/assets/flowDiagram-I6XJVG4X-B0iEPqGd.js +162 -0
  1067. package/ui-dist/assets/forth-Ffai-XNe.js +1 -0
  1068. package/ui-dist/assets/fortran-DYz_wnZ1.js +1 -0
  1069. package/ui-dist/assets/ganttDiagram-6RSMTGT7-DtpxlgWQ.js +292 -0
  1070. package/ui-dist/assets/gas-Bneqetm1.js +1 -0
  1071. package/ui-dist/assets/gherkin-heZmZLOM.js +1 -0
  1072. package/ui-dist/assets/gitGraphDiagram-PVQCEYII-VefBjqya.js +106 -0
  1073. package/ui-dist/assets/graph-CAnANduQ.js +1 -0
  1074. package/ui-dist/assets/groovy-D9Dt4D0W.js +1 -0
  1075. package/ui-dist/assets/haskell-Cw1EW3IL.js +1 -0
  1076. package/ui-dist/assets/haxe-H-WmDvRZ.js +1 -0
  1077. package/ui-dist/assets/http-DBlCnlav.js +1 -0
  1078. package/ui-dist/assets/idl-BEugSyMb.js +1 -0
  1079. package/ui-dist/assets/index-B9KxOFt-.js +1 -0
  1080. package/ui-dist/assets/index-BMPCuc-W.js +1 -0
  1081. package/ui-dist/assets/index-Bbfs2D7R.js +1 -0
  1082. package/ui-dist/assets/index-BrgHE5Lg.js +1 -0
  1083. package/ui-dist/assets/index-C5q-Cwlp.js +7 -0
  1084. package/ui-dist/assets/index-C6LpKpr3.js +1 -0
  1085. package/ui-dist/assets/index-CIzt5DFV.js +1 -0
  1086. package/ui-dist/assets/index-CRwAuYPj.js +1 -0
  1087. package/ui-dist/assets/index-CTEnIXsJ.js +1 -0
  1088. package/ui-dist/assets/index-CXGemv2V.js +1 -0
  1089. package/ui-dist/assets/index-ClDiS51u.js +1 -0
  1090. package/ui-dist/assets/index-CvKYfvpz.js +1 -0
  1091. package/ui-dist/assets/index-D2IqxlXD.js +1 -0
  1092. package/ui-dist/assets/index-D97fJMFR.js +522 -0
  1093. package/ui-dist/assets/index-DDHdUa2f.js +1 -0
  1094. package/ui-dist/assets/index-DMZ0QXqi.js +1 -0
  1095. package/ui-dist/assets/index-DMi4KpxO.js +6 -0
  1096. package/ui-dist/assets/index-DZB48Gve.js +1 -0
  1097. package/ui-dist/assets/index-Drr9zRdK.css +1 -0
  1098. package/ui-dist/assets/index-DtGqpE43.js +1 -0
  1099. package/ui-dist/assets/index-Du18kURt.js +2 -0
  1100. package/ui-dist/assets/index-KaLXuTqA.js +1 -0
  1101. package/ui-dist/assets/index-j5NgiILm.js +13 -0
  1102. package/ui-dist/assets/index-u0SfLZ3g.js +3 -0
  1103. package/ui-dist/assets/infoDiagram-5YYISTIA-D2OGH-dO.js +2 -0
  1104. package/ui-dist/assets/init-Gi6I4Gst.js +1 -0
  1105. package/ui-dist/assets/ishikawaDiagram-YF4QCWOH-CnMf3BJj.js +70 -0
  1106. package/ui-dist/assets/javascript-iXu5QeM3.js +1 -0
  1107. package/ui-dist/assets/journeyDiagram-JHISSGLW-BaXdD53T.js +139 -0
  1108. package/ui-dist/assets/julia-DuME0IfC.js +1 -0
  1109. package/ui-dist/assets/kanban-definition-UN3LZRKU-Brt7LjHm.js +89 -0
  1110. package/ui-dist/assets/katex-yT8l5JNH.js +257 -0
  1111. package/ui-dist/assets/layout-DGIYPm2g.js +1 -0
  1112. package/ui-dist/assets/linear-536T6Mkh.js +1 -0
  1113. package/ui-dist/assets/livescript-BwQOo05w.js +1 -0
  1114. package/ui-dist/assets/lua-VAEuO923.js +1 -0
  1115. package/ui-dist/assets/mathematica-DTrFuWx2.js +1 -0
  1116. package/ui-dist/assets/mbox-CNhZ1qSd.js +1 -0
  1117. package/ui-dist/assets/mermaid.core-CURTLVBm.js +303 -0
  1118. package/ui-dist/assets/mindmap-definition-RKZ34NQL-S2tDCU-U.js +96 -0
  1119. package/ui-dist/assets/mirc-CjQqDB4T.js +1 -0
  1120. package/ui-dist/assets/mllike-CXdrOF99.js +1 -0
  1121. package/ui-dist/assets/modelica-Dc1JOy9r.js +1 -0
  1122. package/ui-dist/assets/mscgen-BA5vi2Kp.js +1 -0
  1123. package/ui-dist/assets/mumps-BT43cFF4.js +1 -0
  1124. package/ui-dist/assets/nginx-DdIZxoE0.js +1 -0
  1125. package/ui-dist/assets/nsis-LdVXkNf5.js +1 -0
  1126. package/ui-dist/assets/ntriples-BfvgReVJ.js +1 -0
  1127. package/ui-dist/assets/octave-Ck1zUtKM.js +1 -0
  1128. package/ui-dist/assets/ordinal-Cboi1Yqb.js +1 -0
  1129. package/ui-dist/assets/oz-BzwKVEFT.js +1 -0
  1130. package/ui-dist/assets/pascal--L3eBynH.js +1 -0
  1131. package/ui-dist/assets/perl-CdXCOZ3F.js +1 -0
  1132. package/ui-dist/assets/pieDiagram-4H26LBE5-DD_Ih32z.js +30 -0
  1133. package/ui-dist/assets/pig-CevX1Tat.js +1 -0
  1134. package/ui-dist/assets/powershell-CFHJl5sT.js +1 -0
  1135. package/ui-dist/assets/properties-C78fOPTZ.js +1 -0
  1136. package/ui-dist/assets/protobuf-ChK-085T.js +1 -0
  1137. package/ui-dist/assets/pug-DeIclll2.js +1 -0
  1138. package/ui-dist/assets/puppet-DMA9R1ak.js +1 -0
  1139. package/ui-dist/assets/python-BuPzkPfP.js +1 -0
  1140. package/ui-dist/assets/q-pXgVlZs6.js +1 -0
  1141. package/ui-dist/assets/quadrantDiagram-W4KKPZXB-DA5BPBIK.js +7 -0
  1142. package/ui-dist/assets/r-B6wPVr8A.js +1 -0
  1143. package/ui-dist/assets/requirementDiagram-4Y6WPE33-Em8SPCro.js +84 -0
  1144. package/ui-dist/assets/rpm-CTu-6PCP.js +1 -0
  1145. package/ui-dist/assets/ruby-B2Rjki9n.js +1 -0
  1146. package/ui-dist/assets/sankeyDiagram-5OEKKPKP-BJVC4haY.js +40 -0
  1147. package/ui-dist/assets/sas-B4kiWyti.js +1 -0
  1148. package/ui-dist/assets/scheme-C41bIUwD.js +1 -0
  1149. package/ui-dist/assets/sequenceDiagram-3UESZ5HK-Cskntadf.js +162 -0
  1150. package/ui-dist/assets/shell-CjFT_Tl9.js +1 -0
  1151. package/ui-dist/assets/sieve-C3Gn_uJK.js +1 -0
  1152. package/ui-dist/assets/simple-mode-GW_nhZxv.js +1 -0
  1153. package/ui-dist/assets/smalltalk-CnHTOXQT.js +1 -0
  1154. package/ui-dist/assets/solr-DehyRSwq.js +1 -0
  1155. package/ui-dist/assets/sparql-DkYu6x3z.js +1 -0
  1156. package/ui-dist/assets/spreadsheet-BCZA_wO0.js +1 -0
  1157. package/ui-dist/assets/sql-D0XecflT.js +1 -0
  1158. package/ui-dist/assets/stateDiagram-AJRCARHV-CxlfdaOi.js +1 -0
  1159. package/ui-dist/assets/stateDiagram-v2-BHNVJYJU-eTgftUjW.js +1 -0
  1160. package/ui-dist/assets/stex-C3f8Ysf7.js +1 -0
  1161. package/ui-dist/assets/stylus-B533Al4x.js +1 -0
  1162. package/ui-dist/assets/swift-BzpIVaGY.js +1 -0
  1163. package/ui-dist/assets/tcl-DVfN8rqt.js +1 -0
  1164. package/ui-dist/assets/textile-CnDTJFAw.js +1 -0
  1165. package/ui-dist/assets/tiddlywiki-DO-Gjzrf.js +1 -0
  1166. package/ui-dist/assets/tiki-DGYXhP31.js +1 -0
  1167. package/ui-dist/assets/timeline-definition-PNZ67QCA-LOdaWSSa.js +120 -0
  1168. package/ui-dist/assets/toml-Bm5Em-hy.js +1 -0
  1169. package/ui-dist/assets/troff-wAsdV37c.js +1 -0
  1170. package/ui-dist/assets/ttcn-CfJYG6tj.js +1 -0
  1171. package/ui-dist/assets/ttcn-cfg-B9xdYoR4.js +1 -0
  1172. package/ui-dist/assets/turtle-B1tBg_DP.js +1 -0
  1173. package/ui-dist/assets/vb-CmGdzxic.js +1 -0
  1174. package/ui-dist/assets/vbscript-BuJXcnF6.js +1 -0
  1175. package/ui-dist/assets/velocity-D8B20fx6.js +1 -0
  1176. package/ui-dist/assets/vennDiagram-CIIHVFJN-CJ4ji6B3.js +34 -0
  1177. package/ui-dist/assets/verilog-C6RDOZhf.js +1 -0
  1178. package/ui-dist/assets/vhdl-lSbBsy5d.js +1 -0
  1179. package/ui-dist/assets/wardley-L42UT6IY-CxnVdUVH.js +153 -0
  1180. package/ui-dist/assets/wardleyDiagram-YWT4CUSO-CgGDttpl.js +78 -0
  1181. package/ui-dist/assets/webidl-ZXfAyPTL.js +1 -0
  1182. package/ui-dist/assets/xquery-DzFWVndE.js +1 -0
  1183. package/ui-dist/assets/xychartDiagram-2RQKCTM6-zuQa7bqx.js +7 -0
  1184. package/ui-dist/assets/yacas-BJ4BC0dw.js +1 -0
  1185. package/ui-dist/assets/z80-Hz9HOZM7.js +1 -0
  1186. package/ui-dist/brands/opencode-logo-dark-square.svg +18 -0
  1187. package/ui-dist/brands/opencode-logo-light-square.svg +18 -0
  1188. package/ui-dist/favicon-16x16.png +0 -0
  1189. package/ui-dist/favicon-32x32.png +0 -0
  1190. package/ui-dist/favicon.ico +0 -0
  1191. package/ui-dist/favicon.svg +8 -0
  1192. package/ui-dist/index.html +46 -0
  1193. package/ui-dist/site.webmanifest +30 -0
  1194. package/ui-dist/sw.js +42 -0
  1195. package/ui-dist/worktree-favicon-16x16.png +0 -0
  1196. package/ui-dist/worktree-favicon-32x32.png +0 -0
  1197. package/ui-dist/worktree-favicon.ico +0 -0
  1198. package/ui-dist/worktree-favicon.svg +9 -0
@@ -0,0 +1,1071 @@
1
+ import crypto, { sign } from "node:crypto";
2
+ import { and, count, desc, eq, sql } from "drizzle-orm";
3
+ import { agents, cloudUpstreamConnections, cloudUpstreamRuns, squads, goals, issueComments, issues, projects, routines, } from "@slaw-ai/db";
4
+ import { badRequest, conflict, HttpError, notFound } from "../errors.js";
5
+ import { squadPortabilityService } from "./squad-portability.js";
6
+ import { localEncryptedProvider } from "../secrets/local-encrypted-provider.js";
7
+ const DEFAULT_SCOPES = ["upstream_import:preview", "upstream_import:write", "upstream_import:read"];
8
+ const TRANSFER_SCHEMA = {
9
+ family: "slaw-upstream-transfer",
10
+ version: "1.0.0",
11
+ major: 1,
12
+ minor: 0,
13
+ };
14
+ const DEFAULT_MAX_ENTITIES_PER_CHUNK = 100;
15
+ const DISCOVERY_FETCH_TIMEOUT_MS = 30_000;
16
+ const REMOTE_FETCH_TIMEOUT_MS = 120_000;
17
+ const CLOUD_CREDENTIAL_PREFIX = "slaw-cloud-credential:";
18
+ export function cloudUpstreamService(db, options = {}) {
19
+ const sourceInstanceId = `slaw-local-${options.instanceId ?? "default"}`;
20
+ const portability = squadPortabilityService(db);
21
+ return {
22
+ list: async (squadId) => {
23
+ const [connectionRows, runRows] = await Promise.all([
24
+ db
25
+ .select()
26
+ .from(cloudUpstreamConnections)
27
+ .where(eq(cloudUpstreamConnections.squadId, squadId))
28
+ .orderBy(desc(cloudUpstreamConnections.updatedAt)),
29
+ db
30
+ .select()
31
+ .from(cloudUpstreamRuns)
32
+ .where(eq(cloudUpstreamRuns.squadId, squadId))
33
+ .orderBy(desc(cloudUpstreamRuns.createdAt))
34
+ .limit(50),
35
+ ]);
36
+ return {
37
+ connections: connectionRows.map(connectionFromRow),
38
+ runs: runRows.map(runFromRow),
39
+ };
40
+ },
41
+ startConnect: async (input) => {
42
+ await requireSquad(input.squadId);
43
+ const remoteUrl = input.remoteUrl.trim();
44
+ if (!remoteUrl)
45
+ throw badRequest("Remote URL is required");
46
+ const discovery = await fetchDiscovery(remoteUrl);
47
+ const target = targetFromDiscovery(discovery);
48
+ const connectionId = crypto.randomUUID();
49
+ const state = crypto.randomBytes(24).toString("base64url");
50
+ const codeVerifier = crypto.randomBytes(32).toString("base64url");
51
+ const codeChallenge = crypto.createHash("sha256").update(codeVerifier, "utf8").digest("base64url");
52
+ const { publicKey, privateKey } = crypto.generateKeyPairSync("ed25519");
53
+ const sourcePublicKey = publicKey.export({ type: "spki", format: "pem" }).toString();
54
+ const sourceInstanceFingerprint = `sha256:${crypto
55
+ .createHash("sha256")
56
+ .update(publicKey.export({ type: "spki", format: "der" }))
57
+ .digest("hex")}`;
58
+ const [row] = await db.insert(cloudUpstreamConnections).values({
59
+ id: connectionId,
60
+ squadId: input.squadId,
61
+ remoteUrl,
62
+ sourceInstanceId,
63
+ sourceInstanceFingerprint,
64
+ sourcePublicKey,
65
+ privateKeyPem: await sealCloudUpstreamCredential(privateKey.export({ type: "pkcs8", format: "pem" }).toString()),
66
+ tokenStatus: "pending",
67
+ scopes: scopesFromDiscovery(discovery),
68
+ targetStackId: target.stackId,
69
+ targetStackSlug: target.stackSlug,
70
+ targetStackDisplayName: target.stackDisplayName,
71
+ targetSquadId: target.squadId,
72
+ targetOrigin: target.origin,
73
+ targetPrimaryHost: target.primaryHost,
74
+ targetProduct: target.product,
75
+ targetSchemaMajor: target.schemaMajor,
76
+ targetMaxChunkBytes: target.maxChunkBytes,
77
+ pendingState: state,
78
+ pendingCodeVerifier: await sealCloudUpstreamCredential(codeVerifier),
79
+ pendingRedirectUri: input.redirectUri,
80
+ pendingTokenUrl: tokenUrlFromDiscovery(discovery),
81
+ }).returning();
82
+ if (!row)
83
+ throw badRequest("Failed to create cloud upstream connection");
84
+ const authorizationUrl = new URL(consentUrlFromDiscovery(discovery));
85
+ authorizationUrl.searchParams.set("stackId", target.stackId);
86
+ authorizationUrl.searchParams.set("redirectUri", input.redirectUri);
87
+ authorizationUrl.searchParams.set("state", state);
88
+ authorizationUrl.searchParams.set("codeChallenge", codeChallenge);
89
+ authorizationUrl.searchParams.set("codeChallengeMethod", "S256");
90
+ authorizationUrl.searchParams.set("sourceInstanceId", sourceInstanceId);
91
+ authorizationUrl.searchParams.set("sourceInstanceFingerprint", sourceInstanceFingerprint);
92
+ authorizationUrl.searchParams.set("sourcePublicKey", sourcePublicKey);
93
+ authorizationUrl.searchParams.set("scopes", row.scopes.join(" "));
94
+ return {
95
+ pendingConnectionId: row.id,
96
+ authorizationUrl: authorizationUrl.toString(),
97
+ connection: connectionFromRow(row),
98
+ };
99
+ },
100
+ finishConnect: async (input) => {
101
+ const pending = await getConnectionRow(input.pendingConnectionId);
102
+ if (!pending.pendingState || !pending.pendingCodeVerifier || !pending.pendingRedirectUri || !pending.pendingTokenUrl) {
103
+ throw notFound("Pending cloud upstream connection was not found");
104
+ }
105
+ if (input.state !== pending.pendingState)
106
+ throw badRequest("Cloud upstream state did not match");
107
+ const tokenResponse = await postJson(pending.pendingTokenUrl, {
108
+ grantType: "authorization_code",
109
+ code: input.code,
110
+ redirectUri: pending.pendingRedirectUri,
111
+ codeVerifier: await unsealCloudUpstreamCredential(pending.pendingCodeVerifier),
112
+ });
113
+ const accessToken = stringField(tokenResponse, "accessToken");
114
+ const token = objectField(tokenResponse, "token");
115
+ const expiresAt = optionalString(token.expiresAt) ?? optionalString(tokenResponse.expiresAt);
116
+ const [updated] = await db
117
+ .update(cloudUpstreamConnections)
118
+ .set({
119
+ tokenStatus: "connected",
120
+ authorizedGlobalUserId: optionalString(token.globalUserId),
121
+ accessToken: await sealCloudUpstreamCredential(accessToken),
122
+ tokenId: optionalString(token.id),
123
+ tokenExpiresAt: expiresAt ? new Date(expiresAt) : null,
124
+ pendingState: null,
125
+ pendingCodeVerifier: null,
126
+ pendingRedirectUri: null,
127
+ pendingTokenUrl: null,
128
+ updatedAt: new Date(),
129
+ })
130
+ .where(eq(cloudUpstreamConnections.id, pending.id))
131
+ .returning();
132
+ if (!updated)
133
+ throw notFound("Cloud upstream connection was not found");
134
+ return connectionFromRow(updated);
135
+ },
136
+ preview: async (connectionId, squadId) => {
137
+ const connection = await getConnectionRow(connectionId, squadId);
138
+ const basePreview = await localPreview(connection);
139
+ if (!basePreview.schemaCompatible || connection.tokenStatus !== "connected") {
140
+ return basePreview;
141
+ }
142
+ const bundle = await buildBundle(connection, "preview");
143
+ const conflictKeysBySource = {};
144
+ for (const entity of bundle.entities) {
145
+ if (!entity.conflictKeys || entity.conflictKeys.length === 0)
146
+ continue;
147
+ conflictKeysBySource[sourceEntityKeyString(entity.record.key)] = [...entity.conflictKeys];
148
+ }
149
+ const remotePreview = await remotePost(connection, `/api/squads/${encodeURIComponent(connection.targetSquadId)}/upstream-imports/preview`, {
150
+ manifest: bundle.manifest,
151
+ previewShape: "manifest_only",
152
+ conflictKeysBySource,
153
+ });
154
+ return {
155
+ ...basePreview,
156
+ warnings: mergeWarnings(basePreview.warnings, warningsFromRemote(remotePreview)),
157
+ conflicts: conflictsFromRemote(remotePreview),
158
+ };
159
+ },
160
+ createRun: async (input) => {
161
+ const connection = await getConnectionRow(input.connectionId, input.squadId);
162
+ if (connection.tokenStatus !== "connected") {
163
+ throw badRequest("Cloud upstream connection is not connected");
164
+ }
165
+ await assertNoRunningRun(input.connectionId, input.squadId, db);
166
+ const preview = await localPreview(connection);
167
+ if (!preview.schemaCompatible) {
168
+ throw badRequest("Cloud stack schema is not compatible with this local Slaw version");
169
+ }
170
+ const bundle = await buildBundle(connection, "apply");
171
+ const runId = crypto.randomUUID();
172
+ const now = new Date();
173
+ const initialEvents = [
174
+ event(now.toISOString(), "connect", "completed", "Connected to the target Slaw Cloud stack."),
175
+ event(now.toISOString(), "scan", "completed", "Scanned the local squad inventory."),
176
+ event(now.toISOString(), "preview", "completed", "Generated the transfer manifest."),
177
+ ...(input.retryOfRunId
178
+ ? [event(now.toISOString(), "push", "retrying", `Retrying run ${input.retryOfRunId} with the same import ledger idempotency key.`)]
179
+ : []),
180
+ ];
181
+ const created = await db.transaction(async (tx) => {
182
+ await tx.execute(sql `select ${cloudUpstreamConnections.id} from ${cloudUpstreamConnections} where ${cloudUpstreamConnections.id} = ${connection.id} and ${cloudUpstreamConnections.squadId} = ${connection.squadId} for update`);
183
+ await assertNoRunningRun(input.connectionId, input.squadId, tx);
184
+ const [row] = await tx.insert(cloudUpstreamRuns).values({
185
+ id: runId,
186
+ connectionId: connection.id,
187
+ squadId: connection.squadId,
188
+ status: "running",
189
+ activeStep: "push",
190
+ progressPercent: 45,
191
+ dryRun: false,
192
+ retryOfRunId: input.retryOfRunId ?? null,
193
+ summary: preview.summary,
194
+ warnings: preview.warnings,
195
+ conflicts: preview.conflicts,
196
+ events: initialEvents,
197
+ report: {},
198
+ idempotencyKey: bundle.manifest.idempotencyKey,
199
+ manifestHash: bundle.manifest.manifestHash,
200
+ targetUrl: connection.targetOrigin,
201
+ createdAt: now,
202
+ updatedAt: now,
203
+ }).returning();
204
+ return row;
205
+ });
206
+ if (!created)
207
+ throw badRequest("Failed to create cloud upstream run");
208
+ try {
209
+ const remoteRun = await remotePost(connection, `/api/squads/${encodeURIComponent(connection.targetSquadId)}/upstream-imports/runs`, {
210
+ mode: "apply",
211
+ manifest: bundle.manifest,
212
+ entities: bundle.entities,
213
+ });
214
+ const remoteRunId = remoteRunIdFromResponse(remoteRun);
215
+ const pushedRun = await updateRunIfRunning(runId, {
216
+ remoteRunId,
217
+ activeStep: "push",
218
+ progressPercent: 60,
219
+ events: [
220
+ ...initialEvents,
221
+ event(new Date().toISOString(), "push", "updated", "Created or resumed the cloud import ledger run."),
222
+ ],
223
+ });
224
+ if (pushedRun.status !== "running")
225
+ return pushedRun;
226
+ for (const chunk of bundle.chunks) {
227
+ await remotePost(connection, `/api/upstream-import-runs/${encodeURIComponent(remoteRunId)}/chunks`, chunk);
228
+ }
229
+ const verifiedRun = await updateRunIfRunning(runId, {
230
+ activeStep: "verify",
231
+ progressPercent: 82,
232
+ events: [
233
+ ...initialEvents,
234
+ event(new Date().toISOString(), "push", "completed", `Uploaded ${bundle.chunks.length} manifest chunk${bundle.chunks.length === 1 ? "" : "s"}.`),
235
+ ],
236
+ });
237
+ if (verifiedRun.status !== "running")
238
+ return verifiedRun;
239
+ const applied = await remotePost(connection, `/api/upstream-import-runs/${encodeURIComponent(remoteRunId)}/apply`, {});
240
+ const remoteEvents = await remoteGet(connection, `/api/upstream-import-runs/${encodeURIComponent(remoteRunId)}/events`).catch(() => null);
241
+ const completedAt = new Date();
242
+ const finalEvents = [
243
+ ...initialEvents,
244
+ event(completedAt.toISOString(), "push", "completed", "Pushed mapped objects without duplicate creation."),
245
+ event(completedAt.toISOString(), "verify", "completed", "Verified the cloud import ledger and generated a run report."),
246
+ event(completedAt.toISOString(), "activate", "completed", "Activation checklist is ready for manual unpause decisions."),
247
+ ...eventsFromRemote(remoteEvents),
248
+ ];
249
+ const finalRun = await updateRunIfRunning(runId, {
250
+ remoteRunId,
251
+ status: "succeeded",
252
+ activeStep: "activate",
253
+ progressPercent: 100,
254
+ warnings: mergeWarnings(preview.warnings, warningsFromRemote(applied)),
255
+ conflicts: conflictsFromRemote(applied),
256
+ events: finalEvents,
257
+ report: {
258
+ runId,
259
+ remoteRunId,
260
+ target: targetFromConnectionRow(connection),
261
+ manifestHash: bundle.manifest.manifestHash,
262
+ idempotencyKey: bundle.manifest.idempotencyKey,
263
+ retryOfRunId: input.retryOfRunId ?? null,
264
+ result: applied,
265
+ events: remoteEvents,
266
+ },
267
+ completedAt,
268
+ });
269
+ if (finalRun.status === "succeeded") {
270
+ await db
271
+ .update(cloudUpstreamConnections)
272
+ .set({ lastRunId: finalRun.id, updatedAt: new Date() })
273
+ .where(eq(cloudUpstreamConnections.id, connection.id));
274
+ }
275
+ return finalRun;
276
+ }
277
+ catch (error) {
278
+ const failedAt = new Date();
279
+ const failure = cloudUpstreamRemoteFailureReport(error);
280
+ return updateRunIfRunning(runId, {
281
+ status: "failed",
282
+ activeStep: "push",
283
+ progressPercent: 100,
284
+ events: [
285
+ ...initialEvents,
286
+ event(failedAt.toISOString(), "push", "failed", failure.errorMessage ?? failure.error),
287
+ ],
288
+ report: {
289
+ runId,
290
+ target: targetFromConnectionRow(connection),
291
+ manifestHash: bundle.manifest.manifestHash,
292
+ idempotencyKey: bundle.manifest.idempotencyKey,
293
+ retryOfRunId: input.retryOfRunId ?? null,
294
+ ...failure,
295
+ },
296
+ completedAt: failedAt,
297
+ });
298
+ }
299
+ },
300
+ readRun: async (connectionId, runId, squadId) => {
301
+ const row = await getRunRow(connectionId, runId, squadId);
302
+ return runFromRow(row);
303
+ },
304
+ cancelRun: async (connectionId, runId, squadId) => {
305
+ const row = await getRunRow(connectionId, runId, squadId);
306
+ if (row.status !== "running")
307
+ return runFromRow(row);
308
+ const connection = await getConnectionRow(connectionId, squadId);
309
+ if (row.remoteRunId) {
310
+ await remotePost(connection, `/api/upstream-import-runs/${encodeURIComponent(row.remoteRunId)}/cancel`, {}).catch(() => null);
311
+ }
312
+ return updateRun(row.id, {
313
+ status: "cancelled",
314
+ activeStep: "push",
315
+ progressPercent: 100,
316
+ completedAt: new Date(),
317
+ events: [
318
+ ...row.events,
319
+ event(new Date().toISOString(), "push", "failed", "Push cancelled locally before remote apply completed."),
320
+ ],
321
+ });
322
+ },
323
+ activateRunEntities: async (input) => {
324
+ const row = await getRunRow(input.connectionId, input.runId, input.squadId);
325
+ assertActivationEntityType(input.entityType);
326
+ if (row.status !== "succeeded") {
327
+ throw badRequest("Only succeeded cloud upstream runs can activate imported entities");
328
+ }
329
+ const activatedAt = new Date().toISOString();
330
+ const count = summaryCount(row.summary, input.entityType);
331
+ const nextDecision = {
332
+ entityType: input.entityType,
333
+ count,
334
+ status: "activated",
335
+ activatedAt,
336
+ };
337
+ const report = asRecord(row.report);
338
+ const activationChecklist = activationChecklistFromReport(report);
339
+ const label = activationEntityLabel(input.entityType, count);
340
+ return updateRun(row.id, {
341
+ report: {
342
+ ...report,
343
+ activationChecklist: {
344
+ ...activationChecklist,
345
+ [input.entityType]: nextDecision,
346
+ },
347
+ },
348
+ events: [
349
+ ...row.events,
350
+ event(activatedAt, "activate", "completed", `Activated ${count} imported ${label}.`),
351
+ ],
352
+ });
353
+ },
354
+ };
355
+ async function requireSquad(squadId) {
356
+ const row = await db.select({ id: squads.id }).from(squads).where(eq(squads.id, squadId)).then((rows) => rows[0]);
357
+ if (!row)
358
+ throw notFound("Squad was not found");
359
+ }
360
+ async function getConnectionRow(connectionId, squadId) {
361
+ const row = await db
362
+ .select()
363
+ .from(cloudUpstreamConnections)
364
+ .where(squadId
365
+ ? and(eq(cloudUpstreamConnections.id, connectionId), eq(cloudUpstreamConnections.squadId, squadId))
366
+ : eq(cloudUpstreamConnections.id, connectionId))
367
+ .then((rows) => rows[0]);
368
+ if (!row)
369
+ throw notFound("Cloud upstream connection was not found");
370
+ return row;
371
+ }
372
+ async function getRunRow(connectionId, runId, squadId) {
373
+ const row = await db
374
+ .select()
375
+ .from(cloudUpstreamRuns)
376
+ .where(and(eq(cloudUpstreamRuns.id, runId), eq(cloudUpstreamRuns.connectionId, connectionId), eq(cloudUpstreamRuns.squadId, squadId)))
377
+ .then((rows) => rows[0]);
378
+ if (!row)
379
+ throw notFound("Cloud upstream run was not found");
380
+ return row;
381
+ }
382
+ async function assertNoRunningRun(connectionId, squadId, database) {
383
+ const [running] = await database
384
+ .select({ id: cloudUpstreamRuns.id })
385
+ .from(cloudUpstreamRuns)
386
+ .where(and(eq(cloudUpstreamRuns.connectionId, connectionId), eq(cloudUpstreamRuns.squadId, squadId), eq(cloudUpstreamRuns.status, "running")))
387
+ .limit(1);
388
+ if (running) {
389
+ throw conflict("A cloud upstream run is already running for this connection", { runId: running.id });
390
+ }
391
+ }
392
+ async function updateRun(runId, patch) {
393
+ const [updated] = await db
394
+ .update(cloudUpstreamRuns)
395
+ .set({ ...patch, updatedAt: new Date() })
396
+ .where(eq(cloudUpstreamRuns.id, runId))
397
+ .returning();
398
+ if (!updated)
399
+ throw notFound("Cloud upstream run was not found");
400
+ return runFromRow(updated);
401
+ }
402
+ async function updateRunIfRunning(runId, patch) {
403
+ const [updated] = await db
404
+ .update(cloudUpstreamRuns)
405
+ .set({ ...patch, updatedAt: new Date() })
406
+ .where(and(eq(cloudUpstreamRuns.id, runId), eq(cloudUpstreamRuns.status, "running")))
407
+ .returning();
408
+ if (updated)
409
+ return runFromRow(updated);
410
+ const [current] = await db
411
+ .select()
412
+ .from(cloudUpstreamRuns)
413
+ .where(eq(cloudUpstreamRuns.id, runId))
414
+ .limit(1);
415
+ if (!current)
416
+ throw notFound("Cloud upstream run was not found");
417
+ return runFromRow(current);
418
+ }
419
+ async function localPreview(connection) {
420
+ return {
421
+ connectionId: connection.id,
422
+ sourceSquadId: connection.squadId,
423
+ target: targetFromConnectionRow(connection),
424
+ schemaCompatible: connection.targetSchemaMajor === TRANSFER_SCHEMA.major,
425
+ summary: await buildSummary(connection.squadId),
426
+ warnings: buildWarnings(connection.targetSchemaMajor),
427
+ conflicts: [],
428
+ generatedAt: new Date().toISOString(),
429
+ };
430
+ }
431
+ async function buildSummary(squadId) {
432
+ const [agentCount, projectCount, goalCount, issueCount, commentCount, routineCount] = await Promise.all([
433
+ db.select({ count: count() }).from(agents).where(eq(agents.squadId, squadId)).then((rows) => rows[0]?.count ?? 0),
434
+ db.select({ count: count() }).from(projects).where(eq(projects.squadId, squadId)).then((rows) => rows[0]?.count ?? 0),
435
+ db.select({ count: count() }).from(goals).where(eq(goals.squadId, squadId)).then((rows) => rows[0]?.count ?? 0),
436
+ db.select({ count: count() }).from(issues).where(eq(issues.squadId, squadId)).then((rows) => rows[0]?.count ?? 0),
437
+ db.select({ count: count() }).from(issueComments).where(eq(issueComments.squadId, squadId)).then((rows) => rows[0]?.count ?? 0),
438
+ db.select({ count: count() }).from(routines).where(eq(routines.squadId, squadId)).then((rows) => rows[0]?.count ?? 0),
439
+ ]);
440
+ return [
441
+ { key: "squads", label: "Squads", count: 1 },
442
+ { key: "goals", label: "Goals", count: goalCount },
443
+ { key: "projects", label: "Projects", count: projectCount },
444
+ { key: "agents", label: "Agents", count: agentCount },
445
+ { key: "issues", label: "Issues", count: issueCount },
446
+ { key: "comments", label: "Comments", count: commentCount },
447
+ { key: "routines", label: "Routines", count: routineCount },
448
+ { key: "warnings", label: "Warnings", count: buildWarnings(TRANSFER_SCHEMA.major).length },
449
+ ];
450
+ }
451
+ async function buildBundle(connection, mode) {
452
+ const exported = await portability.exportBundle(connection.squadId, {
453
+ include: {
454
+ squad: true,
455
+ agents: true,
456
+ projects: true,
457
+ issues: true,
458
+ skills: true,
459
+ },
460
+ expandReferencedSkills: true,
461
+ });
462
+ const sourceHash = normalizedContentHash({
463
+ manifest: exported.manifest,
464
+ files: exported.files,
465
+ });
466
+ const source = {
467
+ sourceInstanceId: connection.sourceInstanceId,
468
+ sourceSquadId: connection.squadId,
469
+ sourceInstanceKeyFingerprint: connection.sourceInstanceFingerprint,
470
+ exporterVersion: "slaw-local-cloud-ui-v1",
471
+ sourceSchemaVersion: TRANSFER_SCHEMA.version,
472
+ };
473
+ const target = {
474
+ targetStackId: connection.targetStackId,
475
+ targetSquadId: connection.targetSquadId,
476
+ targetOrigin: connection.targetOrigin,
477
+ supportedSchemaMajor: connection.targetSchemaMajor,
478
+ };
479
+ const idempotencyKey = [
480
+ mode,
481
+ connection.sourceInstanceId,
482
+ connection.squadId,
483
+ connection.targetStackId,
484
+ sourceHash,
485
+ ].join(":");
486
+ return buildLocalUpstreamExportBundle({
487
+ source,
488
+ target,
489
+ runId: `local-${mode}-${shortHash(idempotencyKey)}`,
490
+ idempotencyKey,
491
+ entities: buildEntitiesFromPortableExport(connection.squadId, connection.sourceInstanceId, exported),
492
+ warnings: exported.warnings.map((message) => ({
493
+ code: "local_squad_export_warning",
494
+ severity: "warning",
495
+ message,
496
+ })),
497
+ featureFlags: ["cloud_sync"],
498
+ maxEntitiesPerChunk: DEFAULT_MAX_ENTITIES_PER_CHUNK,
499
+ });
500
+ }
501
+ }
502
+ async function fetchDiscovery(remoteUrl) {
503
+ const parsed = new URL(remoteUrl);
504
+ if (parsed.protocol !== "https:" && parsed.hostname !== "localhost" && parsed.hostname !== "127.0.0.1") {
505
+ throw badRequest("Cloud upstream targets require HTTPS except localhost development");
506
+ }
507
+ const stackId = firstPathSegment(parsed.pathname);
508
+ const discoveryUrl = new URL("/.well-known/slaw-upstream", parsed.origin);
509
+ if (stackId) {
510
+ discoveryUrl.searchParams.set("stackId", stackId);
511
+ }
512
+ const response = await fetchWithTimeout(discoveryUrl, undefined, DISCOVERY_FETCH_TIMEOUT_MS);
513
+ if (!response.ok) {
514
+ throw badRequest(`Cloud upstream discovery failed: ${response.status}`);
515
+ }
516
+ return await response.json();
517
+ }
518
+ export async function reconcileCloudUpstreamRunsOnStartup(db, now = new Date()) {
519
+ const runningRows = await db
520
+ .select()
521
+ .from(cloudUpstreamRuns)
522
+ .where(eq(cloudUpstreamRuns.status, "running"));
523
+ if (runningRows.length === 0)
524
+ return { reconciled: 0 };
525
+ for (const row of runningRows) {
526
+ const report = asRecord(row.report);
527
+ await db
528
+ .update(cloudUpstreamRuns)
529
+ .set({
530
+ status: "failed",
531
+ activeStep: row.activeStep,
532
+ progressPercent: 100,
533
+ completedAt: now,
534
+ updatedAt: now,
535
+ events: [
536
+ ...safeRunEvents(row.events),
537
+ event(now.toISOString(), cloudUpstreamStep(row.activeStep), "failed", "Marked failed on server startup because the previous process stopped while the cloud upstream run was in progress."),
538
+ ],
539
+ report: {
540
+ ...report,
541
+ error: optionalString(report.error) ?? "orphaned_running_run",
542
+ errorMessage: optionalString(report.errorMessage)
543
+ ?? "The server restarted while this cloud upstream run was running, so Slaw marked it failed instead of leaving it stuck.",
544
+ reconciledAt: now.toISOString(),
545
+ },
546
+ })
547
+ .where(eq(cloudUpstreamRuns.id, row.id));
548
+ }
549
+ return { reconciled: runningRows.length };
550
+ }
551
+ function firstPathSegment(pathname) {
552
+ const segment = pathname.split("/").find(Boolean);
553
+ return segment && segment.toLowerCase() !== "dashboard" ? segment : null;
554
+ }
555
+ function targetFromDiscovery(discovery) {
556
+ const stack = objectField(discovery, "stack");
557
+ const transfer = objectField(discovery, "transfer");
558
+ const schema = optionalObject(transfer.schema);
559
+ const origin = stringField(stack, "origin");
560
+ return {
561
+ stackId: stringField(stack, "id"),
562
+ stackSlug: optionalString(stack.slug),
563
+ stackDisplayName: optionalString(stack.displayName),
564
+ squadId: stringField(stack, "squadId"),
565
+ primaryHost: optionalString(stack.primaryHost) ?? new URL(origin).host,
566
+ origin,
567
+ product: optionalString(discovery.product) ?? "Slaw Cloud",
568
+ schemaMajor: optionalNumber(schema?.major) ?? numberField(transfer, "supportedSchemaMajor"),
569
+ maxChunkBytes: optionalNumber(transfer.maxChunkBytes) ?? 8 * 1024 * 1024,
570
+ };
571
+ }
572
+ function targetFromConnectionRow(row) {
573
+ return {
574
+ stackId: row.targetStackId,
575
+ stackSlug: row.targetStackSlug,
576
+ stackDisplayName: row.targetStackDisplayName,
577
+ squadId: row.targetSquadId,
578
+ primaryHost: row.targetPrimaryHost,
579
+ origin: row.targetOrigin,
580
+ product: row.targetProduct,
581
+ schemaMajor: row.targetSchemaMajor,
582
+ maxChunkBytes: row.targetMaxChunkBytes,
583
+ };
584
+ }
585
+ function connectionFromRow(row) {
586
+ return {
587
+ id: row.id,
588
+ squadId: row.squadId,
589
+ remoteUrl: row.remoteUrl,
590
+ target: targetFromConnectionRow(row),
591
+ tokenStatus: cloudUpstreamTokenStatus(row.tokenStatus),
592
+ scopes: row.scopes,
593
+ authorizedGlobalUserId: row.authorizedGlobalUserId,
594
+ expiresAt: row.tokenExpiresAt?.toISOString() ?? null,
595
+ createdAt: row.createdAt.toISOString(),
596
+ updatedAt: row.updatedAt.toISOString(),
597
+ lastRunId: row.lastRunId,
598
+ };
599
+ }
600
+ function runFromRow(row) {
601
+ return {
602
+ id: row.id,
603
+ connectionId: row.connectionId,
604
+ squadId: row.squadId,
605
+ status: cloudUpstreamRunStatus(row.status),
606
+ activeStep: cloudUpstreamStep(row.activeStep),
607
+ progressPercent: row.progressPercent,
608
+ dryRun: row.dryRun,
609
+ summary: row.summary,
610
+ warnings: row.warnings,
611
+ conflicts: row.conflicts,
612
+ events: row.events,
613
+ targetUrl: row.targetUrl,
614
+ report: row.report,
615
+ retryOfRunId: row.retryOfRunId,
616
+ createdAt: row.createdAt.toISOString(),
617
+ updatedAt: row.updatedAt.toISOString(),
618
+ completedAt: row.completedAt?.toISOString() ?? null,
619
+ };
620
+ }
621
+ function scopesFromDiscovery(discovery) {
622
+ const auth = objectField(discovery, "auth");
623
+ const scopes = Array.isArray(auth.scopes) ? auth.scopes.map(String).filter(Boolean) : [];
624
+ return scopes.length > 0 ? scopes : [...DEFAULT_SCOPES];
625
+ }
626
+ function consentUrlFromDiscovery(discovery) {
627
+ const pkce = objectField(objectField(discovery, "auth"), "pkce");
628
+ return optionalString(pkce.consentUrl) ?? stringField(pkce, "authorizeUrl");
629
+ }
630
+ function tokenUrlFromDiscovery(discovery) {
631
+ return stringField(objectField(objectField(discovery, "auth"), "pkce"), "tokenUrl");
632
+ }
633
+ function buildWarnings(schemaMajor) {
634
+ const warnings = [
635
+ {
636
+ code: "imported_automations_paused",
637
+ severity: "warning",
638
+ title: "Automations stay paused",
639
+ detail: "Imported agents, routines, and monitors require explicit activation after the push.",
640
+ },
641
+ {
642
+ code: "unmatched_users_import_as_historical_authors",
643
+ severity: "warning",
644
+ title: "Unmatched users become historical authors",
645
+ detail: "Invite now remains a secondary action after the transfer is complete.",
646
+ },
647
+ {
648
+ code: "secret_values_redacted",
649
+ severity: "warning",
650
+ title: "Secret values are not transferred",
651
+ detail: "The push carries secret requirements only. Configure cloud secrets before activating automations.",
652
+ },
653
+ ];
654
+ if (schemaMajor !== TRANSFER_SCHEMA.major) {
655
+ warnings.unshift({
656
+ code: "schema_mismatch",
657
+ severity: "blocker",
658
+ title: "Cloud stack upgrade required",
659
+ detail: `This local build uses upstream schema ${TRANSFER_SCHEMA.major}, but the cloud stack reports schema ${schemaMajor}.`,
660
+ });
661
+ }
662
+ return warnings;
663
+ }
664
+ function buildEntitiesFromPortableExport(localSquadId, sourceInstanceId, exported) {
665
+ const squadKey = {
666
+ sourceInstanceId,
667
+ sourceSquadId: localSquadId,
668
+ sourceEntityType: "squad",
669
+ sourceEntityId: localSquadId,
670
+ sourceNaturalKey: exported.manifest.squad?.name ?? localSquadId,
671
+ };
672
+ const entities = [
673
+ {
674
+ key: squadKey,
675
+ body: {
676
+ kind: "slaw_squad_portability_manifest",
677
+ manifest: exported.manifest,
678
+ rootPath: exported.rootPath,
679
+ slawExtensionPath: exported.slawExtensionPath,
680
+ fileCount: Object.keys(exported.files).length,
681
+ },
682
+ conflictKeys: [`squad:${squadKey.sourceNaturalKey ?? localSquadId}`],
683
+ },
684
+ ];
685
+ for (const [filePath, entry] of Object.entries(exported.files).sort(([left], [right]) => left.localeCompare(right))) {
686
+ entities.push({
687
+ key: {
688
+ sourceInstanceId,
689
+ sourceSquadId: localSquadId,
690
+ sourceEntityType: "squad_setting",
691
+ sourceEntityId: shortHash(filePath),
692
+ sourceNaturalKey: filePath,
693
+ },
694
+ body: {
695
+ kind: "slaw_portable_file",
696
+ path: filePath,
697
+ entry: normalizePortableFileEntry(entry),
698
+ },
699
+ dependencies: [squadKey],
700
+ conflictKeys: [`portable_file:${filePath}`],
701
+ });
702
+ }
703
+ return entities;
704
+ }
705
+ function normalizePortableFileEntry(entry) {
706
+ if (typeof entry === "string") {
707
+ return { encoding: "utf8", data: entry };
708
+ }
709
+ return { ...entry };
710
+ }
711
+ function buildLocalUpstreamExportBundle(input) {
712
+ const entities = input.entities.map((entity) => ({
713
+ record: {
714
+ key: entity.key,
715
+ contentHash: normalizedContentHash(entity.body),
716
+ dependencies: entity.dependencies ?? [],
717
+ warnings: entity.warnings ?? [],
718
+ },
719
+ body: entity.body,
720
+ conflictKeys: entity.conflictKeys,
721
+ }));
722
+ const chunksWithoutManifestHash = buildLocalChunks(entities, input.maxEntitiesPerChunk ?? DEFAULT_MAX_ENTITIES_PER_CHUNK);
723
+ const manifestWithoutHash = {
724
+ schema: TRANSFER_SCHEMA,
725
+ source: input.source,
726
+ target: input.target,
727
+ runId: input.runId,
728
+ idempotencyKey: input.idempotencyKey,
729
+ generatedAt: new Date(0).toISOString(),
730
+ entityCount: entities.length,
731
+ perEntityTypeCounts: countEntityTypesForManifest(entities),
732
+ entities: entities.map((entity) => entity.record),
733
+ chunks: chunksWithoutManifestHash.map(({ payload: _payload, ...chunk }) => chunk),
734
+ warnings: input.warnings ?? [],
735
+ featureFlags: (input.featureFlags ?? ["cloud_sync"]).slice().sort(),
736
+ };
737
+ const manifestHash = normalizedContentHash(manifestWithoutHash);
738
+ return {
739
+ manifest: {
740
+ ...manifestWithoutHash,
741
+ chunks: chunksWithoutManifestHash.map(({ payload: _payload, ...chunk }) => ({ ...chunk, manifestHash })),
742
+ manifestHash,
743
+ },
744
+ entities,
745
+ chunks: chunksWithoutManifestHash,
746
+ };
747
+ }
748
+ function countEntityTypesForManifest(entities) {
749
+ const counts = {};
750
+ for (const entity of entities) {
751
+ const entityType = entity.record.key.sourceEntityType;
752
+ counts[entityType] = (counts[entityType] ?? 0) + 1;
753
+ }
754
+ return counts;
755
+ }
756
+ function buildLocalChunks(entities, maxEntitiesPerChunk) {
757
+ if (!Number.isInteger(maxEntitiesPerChunk) || maxEntitiesPerChunk < 1) {
758
+ throw new Error("maxEntitiesPerChunk must be a positive integer");
759
+ }
760
+ if (entities.length === 0)
761
+ return [];
762
+ const groups = [];
763
+ for (let index = 0; index < entities.length; index += maxEntitiesPerChunk) {
764
+ groups.push(entities.slice(index, index + maxEntitiesPerChunk));
765
+ }
766
+ return groups.map((group, index) => {
767
+ const payload = {
768
+ entityKeys: group.map((entity) => entity.record.key),
769
+ };
770
+ return {
771
+ chunkIndex: index,
772
+ totalChunks: groups.length,
773
+ byteLength: Buffer.byteLength(canonicalJson(payload)),
774
+ sha256: normalizedContentHash(payload),
775
+ payload,
776
+ };
777
+ });
778
+ }
779
+ async function remoteGet(connection, path) {
780
+ const response = await fetchWithTimeout(`${connection.targetOrigin}${path}`, {
781
+ method: "GET",
782
+ headers: await proofHeaders(connection, "GET", path),
783
+ }, REMOTE_FETCH_TIMEOUT_MS);
784
+ return parseRemoteResponse(response);
785
+ }
786
+ async function remotePost(connection, path, body) {
787
+ const response = await fetchWithTimeout(`${connection.targetOrigin}${path}`, {
788
+ method: "POST",
789
+ headers: {
790
+ "Content-Type": "application/json",
791
+ ...await proofHeaders(connection, "POST", path),
792
+ },
793
+ body: JSON.stringify(body),
794
+ }, REMOTE_FETCH_TIMEOUT_MS);
795
+ return parseRemoteResponse(response);
796
+ }
797
+ async function proofHeaders(connection, method, pathAndSearch) {
798
+ if (!connection.accessToken || !connection.tokenId) {
799
+ throw badRequest("Cloud upstream connection is missing an import token");
800
+ }
801
+ const accessToken = await unsealCloudUpstreamCredential(connection.accessToken);
802
+ const privateKeyPem = await unsealCloudUpstreamCredential(connection.privateKeyPem);
803
+ const timestamp = new Date().toISOString();
804
+ const nonce = crypto.randomUUID();
805
+ const payload = [
806
+ method,
807
+ new URL(connection.targetOrigin).host.toLowerCase(),
808
+ pathAndSearch,
809
+ connection.tokenId,
810
+ connection.sourceInstanceId,
811
+ timestamp,
812
+ nonce,
813
+ ].join("\n");
814
+ return {
815
+ Authorization: `Bearer ${accessToken}`,
816
+ "X-Slaw-Upstream-Source-Instance-Id": connection.sourceInstanceId,
817
+ "X-Slaw-Upstream-Proof-Timestamp": timestamp,
818
+ "X-Slaw-Upstream-Proof-Nonce": nonce,
819
+ "X-Slaw-Upstream-Proof-Signature": sign(null, Buffer.from(payload, "utf8"), privateKeyPem).toString("base64url"),
820
+ };
821
+ }
822
+ async function parseRemoteResponse(response) {
823
+ const text = await response.text();
824
+ const parsed = text.trim() ? safeParseJson(text) : {};
825
+ if (!response.ok) {
826
+ const message = typeof parsed === "object" && parsed !== null && "error" in parsed
827
+ ? String(parsed.error)
828
+ : `Cloud upstream request failed: ${response.status}`;
829
+ throw badRequest(message, parsed);
830
+ }
831
+ return parsed;
832
+ }
833
+ async function fetchWithTimeout(input, init, timeoutMs) {
834
+ return fetch(input, {
835
+ ...init,
836
+ signal: AbortSignal.timeout(timeoutMs),
837
+ });
838
+ }
839
+ export async function sealCloudUpstreamCredential(value) {
840
+ const prepared = await localEncryptedProvider.createSecret({ value });
841
+ return `${CLOUD_CREDENTIAL_PREFIX}${JSON.stringify(prepared.material)}`;
842
+ }
843
+ export async function unsealCloudUpstreamCredential(value) {
844
+ if (!value.startsWith(CLOUD_CREDENTIAL_PREFIX))
845
+ return value;
846
+ const encoded = value.slice(CLOUD_CREDENTIAL_PREFIX.length);
847
+ const parsed = safeParseJson(encoded);
848
+ const material = optionalObject(parsed);
849
+ if (!material) {
850
+ throw badRequest("Invalid encrypted cloud upstream credential material");
851
+ }
852
+ return localEncryptedProvider.resolveVersion({
853
+ material,
854
+ externalRef: null,
855
+ });
856
+ }
857
+ export function cloudUpstreamRemoteFailureReport(error) {
858
+ const fallback = error instanceof Error ? error.message : String(error);
859
+ if (!(error instanceof HttpError)) {
860
+ return { error: fallback };
861
+ }
862
+ const remote = remoteErrorBody(error.details);
863
+ return {
864
+ error: remote.error ?? error.message,
865
+ ...(remote.message ? { errorMessage: remote.message } : {}),
866
+ ...(error.details !== undefined ? { details: error.details } : {}),
867
+ };
868
+ }
869
+ function remoteErrorBody(details) {
870
+ const record = optionalObject(details);
871
+ if (!record)
872
+ return {};
873
+ return {
874
+ error: optionalString(record.error) ?? undefined,
875
+ message: optionalString(record.message) ?? undefined,
876
+ };
877
+ }
878
+ async function postJson(url, body) {
879
+ const response = await fetchWithTimeout(url, {
880
+ method: "POST",
881
+ headers: { "Content-Type": "application/json" },
882
+ body: JSON.stringify(body),
883
+ }, DISCOVERY_FETCH_TIMEOUT_MS);
884
+ const payload = await response.json().catch(() => null);
885
+ if (!response.ok) {
886
+ throw badRequest(payload?.error ?? `Cloud upstream request failed: ${response.status}`);
887
+ }
888
+ return payload;
889
+ }
890
+ function remoteRunIdFromResponse(value) {
891
+ const record = asRecord(value);
892
+ const run = asRecord(record.run);
893
+ const id = optionalString(run.id);
894
+ if (!id)
895
+ throw badRequest("Remote upstream importer did not return a run id");
896
+ return id;
897
+ }
898
+ function warningsFromRemote(value) {
899
+ const record = asRecord(value);
900
+ const warnings = Array.isArray(record.warnings) ? record.warnings : [];
901
+ return warnings.map((warning, index) => {
902
+ const item = asRecord(warning);
903
+ const code = optionalString(item.code) ?? `remote_warning_${index}`;
904
+ const severity = item.severity === "blocker" ? "blocker" : "warning";
905
+ const message = optionalString(item.message) ?? optionalString(item.detail) ?? "Remote importer warning.";
906
+ return {
907
+ code,
908
+ severity,
909
+ title: titleFromCode(code),
910
+ detail: message,
911
+ };
912
+ });
913
+ }
914
+ function conflictsFromRemote(value) {
915
+ const record = asRecord(value);
916
+ const conflicts = Array.isArray(record.conflicts) ? record.conflicts : [];
917
+ return conflicts.map((conflict, index) => {
918
+ const item = asRecord(conflict);
919
+ const source = asRecord(item.source);
920
+ return {
921
+ id: optionalString(item.id) ?? `remote-conflict-${index}`,
922
+ entityType: optionalString(item.entityType) ?? optionalString(source.sourceEntityType) ?? "entity",
923
+ sourceLabel: optionalString(item.sourceLabel) ?? optionalString(source.sourceNaturalKey) ?? optionalString(source.sourceEntityId) ?? "Source entity",
924
+ targetLabel: optionalString(item.targetLabel) ?? optionalString(item.targetEntityId) ?? "Cloud entity",
925
+ plannedAction: "blocked",
926
+ reason: optionalString(item.reason) ?? "Remote importer reported a conflict.",
927
+ };
928
+ });
929
+ }
930
+ function eventsFromRemote(value) {
931
+ const record = asRecord(value);
932
+ const events = Array.isArray(record.events) ? record.events : [];
933
+ return events.slice(-25).map((remote, index) => {
934
+ const item = asRecord(remote);
935
+ const action = optionalString(item.action) ?? "updated";
936
+ return event(optionalString(item.createdAt) ?? new Date().toISOString(), "verify", action.includes("created") ? "created" : "updated", `Cloud importer ${action.replace(/_/g, " ")}${index >= 0 ? "." : "."}`);
937
+ });
938
+ }
939
+ function safeRunEvents(value) {
940
+ return Array.isArray(value) ? value : [];
941
+ }
942
+ function assertActivationEntityType(value) {
943
+ if (value !== "agents" && value !== "routines" && value !== "monitors") {
944
+ throw badRequest("entityType must be agents, routines, or monitors");
945
+ }
946
+ }
947
+ function summaryCount(summary, key) {
948
+ if (!Array.isArray(summary))
949
+ return 0;
950
+ const item = summary.find((entry) => asRecord(entry).key === key);
951
+ const count = asRecord(item).count;
952
+ return typeof count === "number" && Number.isFinite(count) ? count : 0;
953
+ }
954
+ function activationChecklistFromReport(report) {
955
+ const value = asRecord(report.activationChecklist);
956
+ const decisions = {};
957
+ for (const [key, decision] of Object.entries(value)) {
958
+ if (key !== "agents" && key !== "routines" && key !== "monitors")
959
+ continue;
960
+ const item = asRecord(decision);
961
+ decisions[key] = {
962
+ entityType: key,
963
+ count: typeof item.count === "number" && Number.isFinite(item.count) ? item.count : 0,
964
+ status: item.status === "activated" ? "activated" : "paused",
965
+ activatedAt: optionalString(item.activatedAt),
966
+ };
967
+ }
968
+ return decisions;
969
+ }
970
+ function activationEntityLabel(entityType, count) {
971
+ const singular = entityType === "agents" ? "agent" : entityType === "routines" ? "routine" : "monitor";
972
+ return `${singular}${count === 1 ? "" : "s"}`;
973
+ }
974
+ function mergeWarnings(base, extra) {
975
+ const byCode = new Map();
976
+ for (const warning of [...base, ...extra])
977
+ byCode.set(warning.code, warning);
978
+ return [...byCode.values()];
979
+ }
980
+ function event(at, phase, type, message) {
981
+ return {
982
+ id: crypto.randomUUID(),
983
+ at,
984
+ phase,
985
+ type,
986
+ message,
987
+ };
988
+ }
989
+ function normalizedContentHash(value) {
990
+ return `sha256:${crypto.createHash("sha256").update(canonicalJson(value)).digest("hex")}`;
991
+ }
992
+ function canonicalJson(value) {
993
+ return JSON.stringify(sortJson(value));
994
+ }
995
+ function sortJson(value) {
996
+ if (Array.isArray(value))
997
+ return value.map(sortJson);
998
+ if (typeof value !== "object" || value === null)
999
+ return value;
1000
+ return Object.fromEntries(Object.entries(value)
1001
+ .sort(([left], [right]) => left.localeCompare(right))
1002
+ .map(([key, entry]) => [key, sortJson(entry)]));
1003
+ }
1004
+ function shortHash(value) {
1005
+ return crypto.createHash("sha256").update(value).digest("hex").slice(0, 12);
1006
+ }
1007
+ function sourceEntityKeyString(key) {
1008
+ return [key.sourceInstanceId, key.sourceSquadId, key.sourceEntityType, key.sourceEntityId]
1009
+ .map((part) => encodeURIComponent(part))
1010
+ .join("/");
1011
+ }
1012
+ function titleFromCode(code) {
1013
+ return code
1014
+ .replace(/_/g, " ")
1015
+ .replace(/\b\w/g, (letter) => letter.toUpperCase());
1016
+ }
1017
+ function objectField(value, key) {
1018
+ const field = value[key];
1019
+ if (!field || typeof field !== "object" || Array.isArray(field)) {
1020
+ throw badRequest(`Cloud upstream discovery missing ${key}`);
1021
+ }
1022
+ return field;
1023
+ }
1024
+ function stringField(value, key) {
1025
+ const field = value[key];
1026
+ if (typeof field !== "string" || field.length === 0) {
1027
+ throw badRequest(`Cloud upstream discovery missing ${key}`);
1028
+ }
1029
+ return field;
1030
+ }
1031
+ function numberField(value, key) {
1032
+ const field = value[key];
1033
+ if (typeof field !== "number" || !Number.isFinite(field)) {
1034
+ throw badRequest(`Cloud upstream discovery missing ${key}`);
1035
+ }
1036
+ return field;
1037
+ }
1038
+ function optionalString(value) {
1039
+ return typeof value === "string" && value.length > 0 ? value : null;
1040
+ }
1041
+ function optionalNumber(value) {
1042
+ return typeof value === "number" && Number.isFinite(value) ? value : null;
1043
+ }
1044
+ function optionalObject(value) {
1045
+ return value && typeof value === "object" && !Array.isArray(value) ? value : null;
1046
+ }
1047
+ function asRecord(value) {
1048
+ return value && typeof value === "object" && !Array.isArray(value) ? value : {};
1049
+ }
1050
+ function safeParseJson(text) {
1051
+ try {
1052
+ return JSON.parse(text);
1053
+ }
1054
+ catch {
1055
+ return text;
1056
+ }
1057
+ }
1058
+ function cloudUpstreamTokenStatus(value) {
1059
+ return value === "connected" || value === "expired" || value === "revoked" ? value : "pending";
1060
+ }
1061
+ function cloudUpstreamRunStatus(value) {
1062
+ return value === "previewed" || value === "running" || value === "succeeded" || value === "failed" || value === "cancelled"
1063
+ ? value
1064
+ : "failed";
1065
+ }
1066
+ function cloudUpstreamStep(value) {
1067
+ return value === "connect" || value === "scan" || value === "preview" || value === "push" || value === "verify" || value === "activate"
1068
+ ? value
1069
+ : "push";
1070
+ }
1071
+ //# sourceMappingURL=cloud-upstreams.js.map