agent-relay 1.1.0 → 1.2.3

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 (567) hide show
  1. package/.gitattributes +3 -0
  2. package/.nvmrc +1 -0
  3. package/.trajectories/completed/2026-01/traj_1dviorhnkcb5.json +65 -0
  4. package/.trajectories/completed/2026-01/traj_1dviorhnkcb5.md +37 -0
  5. package/.trajectories/completed/2026-01/traj_1k5if5snst2e.json +65 -0
  6. package/.trajectories/completed/2026-01/traj_1k5if5snst2e.md +37 -0
  7. package/.trajectories/completed/2026-01/traj_1rp3rges5811.json +49 -0
  8. package/.trajectories/completed/2026-01/traj_1rp3rges5811.md +31 -0
  9. package/.trajectories/completed/2026-01/traj_22bhyulruouw.json +113 -0
  10. package/.trajectories/completed/2026-01/traj_22bhyulruouw.md +57 -0
  11. package/.trajectories/completed/2026-01/traj_2dao7ddgnta0.json +53 -0
  12. package/.trajectories/completed/2026-01/traj_2dao7ddgnta0.md +32 -0
  13. package/.trajectories/completed/2026-01/traj_3t0440mjeunc.json +26 -0
  14. package/.trajectories/completed/2026-01/traj_3t0440mjeunc.md +6 -0
  15. package/.trajectories/completed/2026-01/traj_45x9494d9xnr.json +47 -0
  16. package/.trajectories/completed/2026-01/traj_45x9494d9xnr.md +32 -0
  17. package/.trajectories/completed/2026-01/traj_4aa0bb77s4nh.json +53 -0
  18. package/.trajectories/completed/2026-01/traj_4aa0bb77s4nh.md +32 -0
  19. package/.trajectories/completed/2026-01/traj_5lhmzq8rxpqv.json +59 -0
  20. package/.trajectories/completed/2026-01/traj_5lhmzq8rxpqv.md +33 -0
  21. package/.trajectories/completed/2026-01/traj_5vr4e9erb1fs.json +53 -0
  22. package/.trajectories/completed/2026-01/traj_5vr4e9erb1fs.md +32 -0
  23. package/.trajectories/completed/2026-01/traj_6fgiwdoklvym.json +48 -0
  24. package/.trajectories/completed/2026-01/traj_6fgiwdoklvym.md +24 -0
  25. package/.trajectories/completed/2026-01/traj_7ludwvz45veh.json +209 -0
  26. package/.trajectories/completed/2026-01/traj_7ludwvz45veh.md +97 -0
  27. package/.trajectories/completed/2026-01/traj_9921cuhel0pj.json +48 -0
  28. package/.trajectories/completed/2026-01/traj_9921cuhel0pj.md +24 -0
  29. package/.trajectories/completed/2026-01/traj_ajs7zqfux4wc.json +49 -0
  30. package/.trajectories/completed/2026-01/traj_ajs7zqfux4wc.md +23 -0
  31. package/.trajectories/completed/2026-01/traj_cvtqhlwcq9s0.json +53 -0
  32. package/.trajectories/completed/2026-01/traj_cvtqhlwcq9s0.md +32 -0
  33. package/.trajectories/completed/2026-01/traj_cxofprm2m2en.json +49 -0
  34. package/.trajectories/completed/2026-01/traj_cxofprm2m2en.md +31 -0
  35. package/.trajectories/completed/2026-01/traj_d2hhz3k0vrhn.json +26 -0
  36. package/.trajectories/completed/2026-01/traj_d2hhz3k0vrhn.md +6 -0
  37. package/.trajectories/completed/2026-01/traj_dfuvww9pege5.json +59 -0
  38. package/.trajectories/completed/2026-01/traj_dfuvww9pege5.md +37 -0
  39. package/.trajectories/completed/2026-01/traj_g0fisy9h51mf.json +77 -0
  40. package/.trajectories/completed/2026-01/traj_g0fisy9h51mf.md +42 -0
  41. package/.trajectories/completed/2026-01/traj_gjdre5voouod.json +53 -0
  42. package/.trajectories/completed/2026-01/traj_gjdre5voouod.md +32 -0
  43. package/.trajectories/completed/2026-01/traj_gtlyqtta3x8l.json +25 -0
  44. package/.trajectories/completed/2026-01/traj_gtlyqtta3x8l.md +15 -0
  45. package/.trajectories/completed/2026-01/traj_h4xijiuip3w4.json +101 -0
  46. package/.trajectories/completed/2026-01/traj_h4xijiuip3w4.md +44 -0
  47. package/.trajectories/completed/2026-01/traj_hhxte7w4gjjx.json +22 -0
  48. package/.trajectories/completed/2026-01/traj_hhxte7w4gjjx.md +5 -0
  49. package/.trajectories/completed/2026-01/traj_hpungyhoj6v5.json +53 -0
  50. package/.trajectories/completed/2026-01/traj_hpungyhoj6v5.md +32 -0
  51. package/.trajectories/completed/2026-01/traj_m2xkjv0w2sq7.json +25 -0
  52. package/.trajectories/completed/2026-01/traj_m2xkjv0w2sq7.md +15 -0
  53. package/.trajectories/completed/2026-01/traj_noq5zbvnrdvz.json +53 -0
  54. package/.trajectories/completed/2026-01/traj_noq5zbvnrdvz.md +32 -0
  55. package/.trajectories/completed/2026-01/traj_ntbs6ppopf46.json +53 -0
  56. package/.trajectories/completed/2026-01/traj_ntbs6ppopf46.md +32 -0
  57. package/.trajectories/completed/2026-01/traj_ozd98si6a7ns.json +48 -0
  58. package/.trajectories/completed/2026-01/traj_ozd98si6a7ns.md +24 -0
  59. package/.trajectories/completed/2026-01/traj_prdza7a5cxp5.json +53 -0
  60. package/.trajectories/completed/2026-01/traj_prdza7a5cxp5.md +32 -0
  61. package/.trajectories/completed/2026-01/traj_qb3twvvywfwi.json +77 -0
  62. package/.trajectories/completed/2026-01/traj_qb3twvvywfwi.md +42 -0
  63. package/.trajectories/completed/2026-01/traj_qft54mi7nfor.json +53 -0
  64. package/.trajectories/completed/2026-01/traj_qft54mi7nfor.md +32 -0
  65. package/.trajectories/completed/2026-01/traj_qx9uhf8whhxo.json +83 -0
  66. package/.trajectories/completed/2026-01/traj_qx9uhf8whhxo.md +47 -0
  67. package/.trajectories/completed/2026-01/traj_rd9toccj18a0.json +59 -0
  68. package/.trajectories/completed/2026-01/traj_rd9toccj18a0.md +37 -0
  69. package/.trajectories/completed/2026-01/traj_rt4fiw3ecp50.json +48 -0
  70. package/.trajectories/completed/2026-01/traj_rt4fiw3ecp50.md +16 -0
  71. package/.trajectories/completed/2026-01/traj_st8j35b0hrlc.json +59 -0
  72. package/.trajectories/completed/2026-01/traj_st8j35b0hrlc.md +37 -0
  73. package/.trajectories/completed/2026-01/traj_t1yy8m7hbuxp.json +53 -0
  74. package/.trajectories/completed/2026-01/traj_t1yy8m7hbuxp.md +32 -0
  75. package/.trajectories/completed/2026-01/traj_tmux_orchestrator_analysis.json +84 -0
  76. package/.trajectories/completed/2026-01/traj_tmux_orchestrator_analysis.md +109 -0
  77. package/.trajectories/completed/2026-01/traj_u9n9eqasw16k.json +53 -0
  78. package/.trajectories/completed/2026-01/traj_u9n9eqasw16k.md +32 -0
  79. package/.trajectories/completed/2026-01/traj_v87hypnongqx.json +71 -0
  80. package/.trajectories/completed/2026-01/traj_v87hypnongqx.md +42 -0
  81. package/.trajectories/completed/2026-01/traj_wkp2fgzdyinb.json +53 -0
  82. package/.trajectories/completed/2026-01/traj_wkp2fgzdyinb.md +32 -0
  83. package/.trajectories/completed/2026-01/traj_x14t8w8rn7xg.json +20 -0
  84. package/.trajectories/completed/2026-01/traj_x14t8w8rn7xg.md +6 -0
  85. package/.trajectories/completed/2026-01/traj_xnwbznkvv8ua.json +175 -0
  86. package/.trajectories/completed/2026-01/traj_xnwbznkvv8ua.md +82 -0
  87. package/.trajectories/completed/2026-01/traj_ysjc8zaeqtd3.json +47 -0
  88. package/.trajectories/completed/2026-01/traj_ysjc8zaeqtd3.md +32 -0
  89. package/.trajectories/completed/2026-01/traj_yvdadtvdgnz3.json +59 -0
  90. package/.trajectories/completed/2026-01/traj_yvdadtvdgnz3.md +37 -0
  91. package/.trajectories/completed/2026-01/traj_z0vcw1wrzide.json +53 -0
  92. package/.trajectories/completed/2026-01/traj_z0vcw1wrzide.md +32 -0
  93. package/.trajectories/index.json +314 -0
  94. package/ARCHITECTURE.md +1245 -0
  95. package/README.md +1 -1
  96. package/TESTING.md +278 -0
  97. package/deploy/init-db.sql +5 -0
  98. package/deploy/scripts/setup-fly-workspaces.sh +69 -0
  99. package/deploy/scripts/setup-railway.sh +75 -0
  100. package/deploy/workspace/entrypoint-browser.sh +118 -0
  101. package/deploy/workspace/entrypoint.sh +348 -0
  102. package/deploy/workspace/git-credential-relay +111 -0
  103. package/dist/bridge/spawner.d.ts +53 -0
  104. package/dist/bridge/spawner.js +203 -19
  105. package/dist/bridge/types.d.ts +12 -0
  106. package/dist/cli/index.js +618 -5
  107. package/dist/cloud/api/auth.d.ts +3 -2
  108. package/dist/cloud/api/auth.js +10 -98
  109. package/dist/cloud/api/billing.js +30 -9
  110. package/dist/cloud/api/cli-pty-runner.d.ts +54 -0
  111. package/dist/cloud/api/cli-pty-runner.js +119 -0
  112. package/dist/cloud/api/codex-auth-helper.d.ts +15 -0
  113. package/dist/cloud/api/codex-auth-helper.js +100 -0
  114. package/dist/cloud/api/generic-webhooks.d.ts +8 -0
  115. package/dist/cloud/api/generic-webhooks.js +129 -0
  116. package/dist/cloud/api/git.d.ts +8 -0
  117. package/dist/cloud/api/git.js +152 -0
  118. package/dist/cloud/api/github-app.d.ts +11 -0
  119. package/dist/cloud/api/github-app.js +189 -0
  120. package/dist/cloud/api/middleware/planLimits.d.ts +7 -0
  121. package/dist/cloud/api/middleware/planLimits.js +39 -1
  122. package/dist/cloud/api/monitoring.d.ts +11 -0
  123. package/dist/cloud/api/monitoring.js +578 -0
  124. package/dist/cloud/api/nango-auth.d.ts +9 -0
  125. package/dist/cloud/api/nango-auth.js +377 -0
  126. package/dist/cloud/api/onboarding.d.ts +8 -1
  127. package/dist/cloud/api/onboarding.js +313 -119
  128. package/dist/cloud/api/policy.d.ts +8 -0
  129. package/dist/cloud/api/policy.js +229 -0
  130. package/dist/cloud/api/providers.js +114 -42
  131. package/dist/cloud/api/repos.d.ts +1 -0
  132. package/dist/cloud/api/repos.js +186 -0
  133. package/dist/cloud/api/test-helpers.d.ts +10 -0
  134. package/dist/cloud/api/test-helpers.js +575 -0
  135. package/dist/cloud/api/webhooks.d.ts +8 -0
  136. package/dist/cloud/api/webhooks.js +645 -0
  137. package/dist/cloud/api/workspaces.js +320 -12
  138. package/dist/cloud/billing/plans.js +32 -19
  139. package/dist/cloud/billing/types.d.ts +9 -3
  140. package/dist/cloud/config.d.ts +9 -2
  141. package/dist/cloud/config.js +13 -4
  142. package/dist/cloud/db/drizzle.d.ts +84 -1
  143. package/dist/cloud/db/drizzle.js +470 -0
  144. package/dist/cloud/db/index.d.ts +9 -4
  145. package/dist/cloud/db/index.js +11 -3
  146. package/dist/cloud/db/schema.d.ts +3283 -556
  147. package/dist/cloud/db/schema.js +314 -1
  148. package/dist/cloud/index.d.ts +1 -0
  149. package/dist/cloud/index.js +2 -0
  150. package/dist/cloud/provisioner/index.d.ts +56 -0
  151. package/dist/cloud/provisioner/index.js +676 -34
  152. package/dist/cloud/server.d.ts +1 -0
  153. package/dist/cloud/server.js +362 -13
  154. package/dist/cloud/services/auto-scaler.d.ts +152 -0
  155. package/dist/cloud/services/auto-scaler.js +439 -0
  156. package/dist/cloud/services/capacity-manager.d.ts +148 -0
  157. package/dist/cloud/services/capacity-manager.js +449 -0
  158. package/dist/cloud/services/ci-agent-spawner.d.ts +49 -0
  159. package/dist/cloud/services/ci-agent-spawner.js +373 -0
  160. package/dist/cloud/services/index.d.ts +12 -0
  161. package/dist/cloud/services/index.js +15 -0
  162. package/dist/cloud/services/mention-handler.d.ts +65 -0
  163. package/dist/cloud/services/mention-handler.js +405 -0
  164. package/dist/cloud/services/nango.d.ts +186 -0
  165. package/dist/cloud/services/nango.js +344 -0
  166. package/dist/cloud/services/persistence.d.ts +131 -0
  167. package/dist/cloud/services/persistence.js +200 -0
  168. package/dist/cloud/services/planLimits.d.ts +37 -0
  169. package/dist/cloud/services/planLimits.js +86 -5
  170. package/dist/cloud/services/scaling-orchestrator.d.ts +159 -0
  171. package/dist/cloud/services/scaling-orchestrator.js +502 -0
  172. package/dist/cloud/services/scaling-policy.d.ts +121 -0
  173. package/dist/cloud/services/scaling-policy.js +415 -0
  174. package/dist/cloud/vault/index.js +1 -1
  175. package/dist/cloud/webhooks/index.d.ts +24 -0
  176. package/dist/cloud/webhooks/index.js +29 -0
  177. package/dist/cloud/webhooks/parsers/github.d.ts +8 -0
  178. package/dist/cloud/webhooks/parsers/github.js +234 -0
  179. package/dist/cloud/webhooks/parsers/index.d.ts +23 -0
  180. package/dist/cloud/webhooks/parsers/index.js +30 -0
  181. package/dist/cloud/webhooks/parsers/linear.d.ts +9 -0
  182. package/dist/cloud/webhooks/parsers/linear.js +258 -0
  183. package/dist/cloud/webhooks/parsers/slack.d.ts +9 -0
  184. package/dist/cloud/webhooks/parsers/slack.js +214 -0
  185. package/dist/cloud/webhooks/responders/github.d.ts +8 -0
  186. package/dist/cloud/webhooks/responders/github.js +73 -0
  187. package/dist/cloud/webhooks/responders/index.d.ts +23 -0
  188. package/dist/cloud/webhooks/responders/index.js +30 -0
  189. package/dist/cloud/webhooks/responders/linear.d.ts +9 -0
  190. package/dist/cloud/webhooks/responders/linear.js +149 -0
  191. package/dist/cloud/webhooks/responders/slack.d.ts +20 -0
  192. package/dist/cloud/webhooks/responders/slack.js +178 -0
  193. package/dist/cloud/webhooks/router.d.ts +25 -0
  194. package/dist/cloud/webhooks/router.js +504 -0
  195. package/dist/cloud/webhooks/rules-engine.d.ts +24 -0
  196. package/dist/cloud/webhooks/rules-engine.js +287 -0
  197. package/dist/cloud/webhooks/types.d.ts +186 -0
  198. package/dist/cloud/webhooks/types.js +8 -0
  199. package/dist/continuity/formatter.d.ts +51 -0
  200. package/dist/continuity/formatter.js +313 -0
  201. package/dist/continuity/handoff-store.d.ts +67 -0
  202. package/dist/continuity/handoff-store.js +472 -0
  203. package/dist/continuity/index.d.ts +45 -0
  204. package/dist/continuity/index.js +48 -0
  205. package/dist/continuity/ledger-store.d.ts +110 -0
  206. package/dist/continuity/ledger-store.js +500 -0
  207. package/dist/continuity/manager.d.ts +178 -0
  208. package/dist/continuity/manager.js +562 -0
  209. package/dist/continuity/parser.d.ts +76 -0
  210. package/dist/continuity/parser.js +579 -0
  211. package/dist/continuity/types.d.ts +180 -0
  212. package/dist/continuity/types.js +9 -0
  213. package/dist/daemon/agent-manager.d.ts +27 -0
  214. package/dist/daemon/agent-manager.js +107 -6
  215. package/dist/daemon/agent-registry.d.ts +32 -0
  216. package/dist/daemon/agent-registry.js +42 -2
  217. package/dist/daemon/api.d.ts +12 -0
  218. package/dist/daemon/api.js +131 -2
  219. package/dist/daemon/cli-auth.d.ts +67 -0
  220. package/dist/daemon/cli-auth.js +537 -0
  221. package/dist/daemon/cloud-sync.js +9 -7
  222. package/dist/daemon/orchestrator.js +30 -0
  223. package/dist/daemon/router.d.ts +5 -0
  224. package/dist/daemon/router.js +78 -26
  225. package/dist/daemon/server.d.ts +5 -0
  226. package/dist/daemon/server.js +9 -1
  227. package/dist/daemon/services/browser-testing.d.ts +88 -0
  228. package/dist/daemon/services/browser-testing.js +244 -0
  229. package/dist/daemon/services/container-spawner.d.ts +135 -0
  230. package/dist/daemon/services/container-spawner.js +313 -0
  231. package/dist/daemon/types.d.ts +5 -1
  232. package/dist/dashboard/out/404.html +1 -1
  233. package/dist/dashboard/out/_next/static/chunks/116-2502180def231162.js +1 -0
  234. package/dist/dashboard/out/_next/static/chunks/282-980c2eb8fff20123.js +1 -0
  235. package/dist/dashboard/out/_next/static/chunks/699-3b1cd6618a45d259.js +1 -0
  236. package/dist/dashboard/out/_next/static/chunks/724-2dae7627550ab88f.js +9 -0
  237. package/dist/dashboard/out/_next/static/chunks/766-1f2dd8cb7f766b0b.js +1 -0
  238. package/dist/dashboard/out/_next/static/chunks/app/app/onboarding/page-3fdfa60e53f2810d.js +1 -0
  239. package/dist/dashboard/out/_next/static/chunks/app/app/page-e6381e5a6e1fbcfd.js +1 -0
  240. package/dist/dashboard/out/_next/static/chunks/app/connect-repos/page-3538dfe0ffe984b8.js +1 -0
  241. package/dist/dashboard/out/_next/static/chunks/app/history/{page-b6edd4dde8d08194.js → page-abb9ab2d329f56e9.js} +1 -1
  242. package/dist/dashboard/out/_next/static/chunks/app/layout-c0d118c0f92d969c.js +1 -0
  243. package/dist/dashboard/out/_next/static/chunks/app/login/page-c22d080201cbd9fb.js +1 -0
  244. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-67a3e98d9a43a6ed.js +1 -0
  245. package/dist/dashboard/out/_next/static/chunks/app/page-77e9c65420a06cfb.js +1 -0
  246. package/dist/dashboard/out/_next/static/chunks/app/pricing/page-b08ed1c34d14434a.js +1 -0
  247. package/dist/dashboard/out/_next/static/chunks/app/providers/page-e88bc117ef7671c3.js +1 -0
  248. package/dist/dashboard/out/_next/static/chunks/app/signup/page-68d34f50baa8ab6b.js +1 -0
  249. package/dist/dashboard/out/_next/static/chunks/e868780c-48e5f147c90a3a41.js +18 -0
  250. package/dist/dashboard/out/_next/static/chunks/{main-app-5d692157a8eb1fd9.js → main-app-6e8e8d3ef4e0192a.js} +1 -1
  251. package/dist/dashboard/out/_next/static/chunks/{main-c2f423b9c9f4591b.js → main-ed4e1fb6f29c34cf.js} +1 -1
  252. package/dist/dashboard/out/_next/static/chunks/webpack-1cdd8ed57114d5e1.js +1 -0
  253. package/dist/dashboard/out/_next/static/css/29852f26181969a0.css +1 -0
  254. package/dist/dashboard/out/_next/static/css/7c3ae9e8617d42a5.css +1 -0
  255. package/dist/dashboard/out/app/onboarding.html +1 -0
  256. package/dist/dashboard/out/app/onboarding.txt +7 -0
  257. package/dist/dashboard/out/app.html +1 -14
  258. package/dist/dashboard/out/app.txt +2 -2
  259. package/dist/dashboard/out/connect-repos.html +1 -0
  260. package/dist/dashboard/out/connect-repos.txt +7 -0
  261. package/dist/dashboard/out/history.html +1 -1
  262. package/dist/dashboard/out/history.txt +2 -2
  263. package/dist/dashboard/out/index.html +1 -1
  264. package/dist/dashboard/out/index.txt +2 -2
  265. package/dist/dashboard/out/login.html +6 -0
  266. package/dist/dashboard/out/login.txt +7 -0
  267. package/dist/dashboard/out/metrics.html +1 -1
  268. package/dist/dashboard/out/metrics.txt +2 -2
  269. package/dist/dashboard/out/pricing.html +3 -3
  270. package/dist/dashboard/out/pricing.txt +2 -2
  271. package/dist/dashboard/out/providers.html +1 -0
  272. package/dist/dashboard/out/providers.txt +7 -0
  273. package/dist/dashboard/out/signup.html +6 -0
  274. package/dist/dashboard/out/signup.txt +7 -0
  275. package/dist/dashboard-server/server.js +1308 -8
  276. package/dist/hooks/emitter.d.ts +40 -0
  277. package/dist/hooks/emitter.js +63 -0
  278. package/dist/hooks/index.d.ts +3 -0
  279. package/dist/hooks/index.js +3 -0
  280. package/dist/hooks/registry.d.ts +173 -0
  281. package/dist/hooks/registry.js +476 -0
  282. package/dist/hooks/trajectory-hooks.d.ts +52 -0
  283. package/dist/hooks/trajectory-hooks.js +183 -0
  284. package/dist/hooks/types.d.ts +141 -0
  285. package/dist/index.d.ts +2 -0
  286. package/dist/index.js +3 -0
  287. package/dist/memory/adapters/index.d.ts +8 -0
  288. package/dist/memory/adapters/index.js +8 -0
  289. package/dist/memory/adapters/inmemory.d.ts +59 -0
  290. package/dist/memory/adapters/inmemory.js +195 -0
  291. package/dist/memory/adapters/supermemory.d.ts +71 -0
  292. package/dist/memory/adapters/supermemory.js +338 -0
  293. package/dist/memory/factory.d.ts +48 -0
  294. package/dist/memory/factory.js +143 -0
  295. package/dist/memory/index.d.ts +32 -0
  296. package/dist/memory/index.js +32 -0
  297. package/dist/memory/memory-hooks.d.ts +60 -0
  298. package/dist/memory/memory-hooks.js +313 -0
  299. package/dist/memory/service.d.ts +49 -0
  300. package/dist/memory/service.js +146 -0
  301. package/dist/memory/types.d.ts +195 -0
  302. package/dist/memory/types.js +8 -0
  303. package/dist/policy/agent-policy.d.ts +225 -0
  304. package/dist/policy/agent-policy.js +665 -0
  305. package/dist/policy/cloud-policy-fetcher.d.ts +12 -0
  306. package/dist/policy/cloud-policy-fetcher.js +64 -0
  307. package/dist/resiliency/crash-insights.d.ts +156 -0
  308. package/dist/resiliency/crash-insights.js +492 -0
  309. package/dist/resiliency/gossip-health.d.ts +137 -0
  310. package/dist/resiliency/gossip-health.js +241 -0
  311. package/dist/resiliency/index.d.ts +5 -0
  312. package/dist/resiliency/index.js +5 -0
  313. package/dist/resiliency/leader-watchdog.d.ts +109 -0
  314. package/dist/resiliency/leader-watchdog.js +189 -0
  315. package/dist/resiliency/memory-monitor.d.ts +172 -0
  316. package/dist/resiliency/memory-monitor.js +593 -0
  317. package/dist/resiliency/stateless-lead.d.ts +149 -0
  318. package/dist/resiliency/stateless-lead.js +308 -0
  319. package/dist/resiliency/supervisor.d.ts +38 -0
  320. package/dist/resiliency/supervisor.js +122 -0
  321. package/dist/shared/cli-auth-config.d.ts +91 -0
  322. package/dist/shared/cli-auth-config.js +264 -0
  323. package/dist/storage/adapter.d.ts +1 -1
  324. package/dist/trajectory/config.d.ts +84 -0
  325. package/dist/trajectory/config.js +163 -0
  326. package/dist/trajectory/index.d.ts +8 -0
  327. package/dist/trajectory/index.js +8 -0
  328. package/dist/trajectory/integration.d.ts +292 -0
  329. package/dist/trajectory/integration.js +834 -0
  330. package/dist/utils/logger.js +1 -1
  331. package/dist/utils/project-namespace.d.ts +24 -0
  332. package/dist/utils/project-namespace.js +84 -0
  333. package/dist/wrapper/parser.d.ts +10 -0
  334. package/dist/wrapper/parser.js +100 -33
  335. package/dist/wrapper/pty-wrapper.d.ts +197 -16
  336. package/dist/wrapper/pty-wrapper.js +943 -106
  337. package/dist/wrapper/shared.d.ts +165 -0
  338. package/dist/wrapper/shared.js +270 -0
  339. package/dist/wrapper/tmux-wrapper.d.ts +73 -11
  340. package/dist/wrapper/tmux-wrapper.js +541 -120
  341. package/package.json +16 -16
  342. package/scripts/postinstall.js +60 -0
  343. package/test-push.txt +1 -0
  344. package/bin/tmux +0 -0
  345. package/dist/bridge/config.d.ts.map +0 -1
  346. package/dist/bridge/config.js.map +0 -1
  347. package/dist/bridge/index.d.ts.map +0 -1
  348. package/dist/bridge/index.js.map +0 -1
  349. package/dist/bridge/multi-project-client.d.ts.map +0 -1
  350. package/dist/bridge/multi-project-client.js.map +0 -1
  351. package/dist/bridge/shadow-cli.d.ts.map +0 -1
  352. package/dist/bridge/shadow-cli.js.map +0 -1
  353. package/dist/bridge/shadow-config.d.ts.map +0 -1
  354. package/dist/bridge/shadow-config.js.map +0 -1
  355. package/dist/bridge/spawner.d.ts.map +0 -1
  356. package/dist/bridge/spawner.js.map +0 -1
  357. package/dist/bridge/teams-config.d.ts.map +0 -1
  358. package/dist/bridge/teams-config.js.map +0 -1
  359. package/dist/bridge/types.d.ts.map +0 -1
  360. package/dist/bridge/types.js.map +0 -1
  361. package/dist/bridge/utils.d.ts.map +0 -1
  362. package/dist/bridge/utils.js.map +0 -1
  363. package/dist/cli/index.d.ts.map +0 -1
  364. package/dist/cli/index.js.map +0 -1
  365. package/dist/cloud/api/auth.d.ts.map +0 -1
  366. package/dist/cloud/api/auth.js.map +0 -1
  367. package/dist/cloud/api/billing.d.ts.map +0 -1
  368. package/dist/cloud/api/billing.js.map +0 -1
  369. package/dist/cloud/api/coordinators.d.ts.map +0 -1
  370. package/dist/cloud/api/coordinators.js.map +0 -1
  371. package/dist/cloud/api/daemons.d.ts.map +0 -1
  372. package/dist/cloud/api/daemons.js.map +0 -1
  373. package/dist/cloud/api/middleware/planLimits.d.ts.map +0 -1
  374. package/dist/cloud/api/middleware/planLimits.js.map +0 -1
  375. package/dist/cloud/api/onboarding.d.ts.map +0 -1
  376. package/dist/cloud/api/onboarding.js.map +0 -1
  377. package/dist/cloud/api/providers.d.ts.map +0 -1
  378. package/dist/cloud/api/providers.js.map +0 -1
  379. package/dist/cloud/api/repos.d.ts.map +0 -1
  380. package/dist/cloud/api/repos.js.map +0 -1
  381. package/dist/cloud/api/teams.d.ts.map +0 -1
  382. package/dist/cloud/api/teams.js.map +0 -1
  383. package/dist/cloud/api/usage.d.ts.map +0 -1
  384. package/dist/cloud/api/usage.js.map +0 -1
  385. package/dist/cloud/api/workspaces.d.ts.map +0 -1
  386. package/dist/cloud/api/workspaces.js.map +0 -1
  387. package/dist/cloud/billing/index.d.ts.map +0 -1
  388. package/dist/cloud/billing/index.js.map +0 -1
  389. package/dist/cloud/billing/plans.d.ts.map +0 -1
  390. package/dist/cloud/billing/plans.js.map +0 -1
  391. package/dist/cloud/billing/service.d.ts.map +0 -1
  392. package/dist/cloud/billing/service.js.map +0 -1
  393. package/dist/cloud/billing/types.d.ts.map +0 -1
  394. package/dist/cloud/billing/types.js.map +0 -1
  395. package/dist/cloud/config.d.ts.map +0 -1
  396. package/dist/cloud/config.js.map +0 -1
  397. package/dist/cloud/db/drizzle.d.ts.map +0 -1
  398. package/dist/cloud/db/drizzle.js.map +0 -1
  399. package/dist/cloud/db/index.d.ts.map +0 -1
  400. package/dist/cloud/db/index.js.map +0 -1
  401. package/dist/cloud/db/schema.d.ts.map +0 -1
  402. package/dist/cloud/db/schema.js.map +0 -1
  403. package/dist/cloud/index.d.ts.map +0 -1
  404. package/dist/cloud/index.js.map +0 -1
  405. package/dist/cloud/provisioner/index.d.ts.map +0 -1
  406. package/dist/cloud/provisioner/index.js.map +0 -1
  407. package/dist/cloud/server.d.ts.map +0 -1
  408. package/dist/cloud/server.js.map +0 -1
  409. package/dist/cloud/services/coordinator.d.ts.map +0 -1
  410. package/dist/cloud/services/coordinator.js.map +0 -1
  411. package/dist/cloud/services/planLimits.d.ts.map +0 -1
  412. package/dist/cloud/services/planLimits.js.map +0 -1
  413. package/dist/cloud/vault/index.d.ts.map +0 -1
  414. package/dist/cloud/vault/index.js.map +0 -1
  415. package/dist/daemon/agent-manager.d.ts.map +0 -1
  416. package/dist/daemon/agent-manager.js.map +0 -1
  417. package/dist/daemon/agent-registry.d.ts.map +0 -1
  418. package/dist/daemon/agent-registry.js.map +0 -1
  419. package/dist/daemon/api.d.ts.map +0 -1
  420. package/dist/daemon/api.js.map +0 -1
  421. package/dist/daemon/auth.d.ts.map +0 -1
  422. package/dist/daemon/auth.js.map +0 -1
  423. package/dist/daemon/cloud-sync.d.ts.map +0 -1
  424. package/dist/daemon/cloud-sync.js.map +0 -1
  425. package/dist/daemon/connection.d.ts.map +0 -1
  426. package/dist/daemon/connection.js.map +0 -1
  427. package/dist/daemon/index.d.ts.map +0 -1
  428. package/dist/daemon/index.js.map +0 -1
  429. package/dist/daemon/orchestrator.d.ts.map +0 -1
  430. package/dist/daemon/orchestrator.js.map +0 -1
  431. package/dist/daemon/registry.d.ts.map +0 -1
  432. package/dist/daemon/registry.js.map +0 -1
  433. package/dist/daemon/router.d.ts.map +0 -1
  434. package/dist/daemon/router.js.map +0 -1
  435. package/dist/daemon/server.d.ts.map +0 -1
  436. package/dist/daemon/server.js.map +0 -1
  437. package/dist/daemon/types.d.ts.map +0 -1
  438. package/dist/daemon/types.js.map +0 -1
  439. package/dist/daemon/workspace-manager.d.ts.map +0 -1
  440. package/dist/daemon/workspace-manager.js.map +0 -1
  441. package/dist/dashboard/out/_next/static/chunks/693-7b3301d8f6bc5014.js +0 -1
  442. package/dist/dashboard/out/_next/static/chunks/713-f78477eb185f1f4d.js +0 -1
  443. package/dist/dashboard/out/_next/static/chunks/766-e53e1cfe39b0b5b5.js +0 -1
  444. package/dist/dashboard/out/_next/static/chunks/900-037c64bfd797fb2a.js +0 -1
  445. package/dist/dashboard/out/_next/static/chunks/app/app/page-e3d9e1f4466b9bae.js +0 -1
  446. package/dist/dashboard/out/_next/static/chunks/app/layout-2433bb48965f4333.js +0 -1
  447. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-e68825a81db67ba1.js +0 -1
  448. package/dist/dashboard/out/_next/static/chunks/app/page-cc108bf68c8a657f.js +0 -1
  449. package/dist/dashboard/out/_next/static/chunks/app/pricing/page-d80e03a5297f95b6.js +0 -1
  450. package/dist/dashboard/out/_next/static/chunks/webpack-a5acc2831d094776.js +0 -1
  451. package/dist/dashboard/out/_next/static/css/79b80143647a07d7.css +0 -1
  452. package/dist/dashboard/out/_next/static/css/8cf277370ad48cfe.css +0 -1
  453. package/dist/dashboard-server/metrics.d.ts.map +0 -1
  454. package/dist/dashboard-server/metrics.js.map +0 -1
  455. package/dist/dashboard-server/needs-attention.d.ts.map +0 -1
  456. package/dist/dashboard-server/needs-attention.js.map +0 -1
  457. package/dist/dashboard-server/server.d.ts.map +0 -1
  458. package/dist/dashboard-server/server.js.map +0 -1
  459. package/dist/dashboard-server/start.d.ts.map +0 -1
  460. package/dist/dashboard-server/start.js.map +0 -1
  461. package/dist/hooks/inbox-check/hook.d.ts.map +0 -1
  462. package/dist/hooks/inbox-check/hook.js.map +0 -1
  463. package/dist/hooks/inbox-check/index.d.ts.map +0 -1
  464. package/dist/hooks/inbox-check/index.js.map +0 -1
  465. package/dist/hooks/inbox-check/types.d.ts.map +0 -1
  466. package/dist/hooks/inbox-check/types.js.map +0 -1
  467. package/dist/hooks/inbox-check/utils.d.ts.map +0 -1
  468. package/dist/hooks/inbox-check/utils.js.map +0 -1
  469. package/dist/hooks/index.d.ts.map +0 -1
  470. package/dist/hooks/index.js.map +0 -1
  471. package/dist/hooks/types.d.ts.map +0 -1
  472. package/dist/hooks/types.js.map +0 -1
  473. package/dist/index.d.ts.map +0 -1
  474. package/dist/index.js.map +0 -1
  475. package/dist/protocol/framing.d.ts.map +0 -1
  476. package/dist/protocol/framing.js.map +0 -1
  477. package/dist/protocol/index.d.ts.map +0 -1
  478. package/dist/protocol/index.js.map +0 -1
  479. package/dist/protocol/types.d.ts.map +0 -1
  480. package/dist/protocol/types.js.map +0 -1
  481. package/dist/resiliency/context-persistence.d.ts.map +0 -1
  482. package/dist/resiliency/context-persistence.js.map +0 -1
  483. package/dist/resiliency/health-monitor.d.ts.map +0 -1
  484. package/dist/resiliency/health-monitor.js.map +0 -1
  485. package/dist/resiliency/index.d.ts.map +0 -1
  486. package/dist/resiliency/index.js.map +0 -1
  487. package/dist/resiliency/logger.d.ts.map +0 -1
  488. package/dist/resiliency/logger.js.map +0 -1
  489. package/dist/resiliency/metrics.d.ts.map +0 -1
  490. package/dist/resiliency/metrics.js.map +0 -1
  491. package/dist/resiliency/provider-context.d.ts.map +0 -1
  492. package/dist/resiliency/provider-context.js.map +0 -1
  493. package/dist/resiliency/supervisor.d.ts.map +0 -1
  494. package/dist/resiliency/supervisor.js.map +0 -1
  495. package/dist/state/agent-state.d.ts.map +0 -1
  496. package/dist/state/agent-state.js.map +0 -1
  497. package/dist/storage/adapter.d.ts.map +0 -1
  498. package/dist/storage/adapter.js.map +0 -1
  499. package/dist/storage/sqlite-adapter.d.ts.map +0 -1
  500. package/dist/storage/sqlite-adapter.js.map +0 -1
  501. package/dist/utils/agent-config.d.ts.map +0 -1
  502. package/dist/utils/agent-config.js.map +0 -1
  503. package/dist/utils/command-resolver.d.ts.map +0 -1
  504. package/dist/utils/command-resolver.js.map +0 -1
  505. package/dist/utils/index.d.ts.map +0 -1
  506. package/dist/utils/index.js.map +0 -1
  507. package/dist/utils/logger.d.ts.map +0 -1
  508. package/dist/utils/logger.js.map +0 -1
  509. package/dist/utils/name-generator.d.ts.map +0 -1
  510. package/dist/utils/name-generator.js.map +0 -1
  511. package/dist/utils/project-namespace.d.ts.map +0 -1
  512. package/dist/utils/project-namespace.js.map +0 -1
  513. package/dist/utils/tmux-resolver.d.ts.map +0 -1
  514. package/dist/utils/tmux-resolver.js.map +0 -1
  515. package/dist/utils/update-checker.d.ts.map +0 -1
  516. package/dist/utils/update-checker.js.map +0 -1
  517. package/dist/wrapper/client.d.ts.map +0 -1
  518. package/dist/wrapper/client.js.map +0 -1
  519. package/dist/wrapper/inbox.d.ts.map +0 -1
  520. package/dist/wrapper/inbox.js.map +0 -1
  521. package/dist/wrapper/index.d.ts.map +0 -1
  522. package/dist/wrapper/index.js.map +0 -1
  523. package/dist/wrapper/parser.d.ts.map +0 -1
  524. package/dist/wrapper/parser.js.map +0 -1
  525. package/dist/wrapper/pty-wrapper.d.ts.map +0 -1
  526. package/dist/wrapper/pty-wrapper.js.map +0 -1
  527. package/dist/wrapper/tmux-wrapper.d.ts.map +0 -1
  528. package/dist/wrapper/tmux-wrapper.js.map +0 -1
  529. package/docs/AGENTS.md +0 -513
  530. package/docs/ARCHITECTURE_DECISIONS.md +0 -175
  531. package/docs/CHANGELOG.md +0 -11
  532. package/docs/CLI-SIMPLIFICATION-COMPLETE.md +0 -48
  533. package/docs/CLOUD-ARCHITECTURE.md +0 -652
  534. package/docs/CLOUD-ONBOARDING-DESIGN.md +0 -1983
  535. package/docs/COMPETITIVE_ANALYSIS.md +0 -897
  536. package/docs/CONTRIBUTING.md +0 -151
  537. package/docs/DESIGN_BRIDGE_STAFFING.md +0 -878
  538. package/docs/DESIGN_V2.md +0 -1079
  539. package/docs/INTEGRATION-GUIDE.md +0 -926
  540. package/docs/MONETIZATION.md +0 -1679
  541. package/docs/PROPOSAL-trajectories.md +0 -1582
  542. package/docs/PROTOCOL.md +0 -325
  543. package/docs/SCALING_ANALYSIS.md +0 -280
  544. package/docs/TESTING_PRESENCE_FEATURES.md +0 -327
  545. package/docs/TMUX_IMPLEMENTATION_NOTES.md +0 -364
  546. package/docs/TMUX_IMPROVEMENTS.md +0 -968
  547. package/docs/agent-relay-snippet.md +0 -168
  548. package/docs/competitive-analysis-mcp-agent-mail.md +0 -389
  549. package/docs/dashboard-v2-plan.md +0 -179
  550. package/docs/guides/CLOUD.md +0 -236
  551. package/docs/guides/LOCAL.md +0 -535
  552. package/docs/guides/SELF-HOSTED.md +0 -494
  553. package/docs/proposals/shadow-as-subagent.md +0 -765
  554. package/docs/proposals/slack-bot-integration.md +0 -1457
  555. package/docs/removable-code-analysis.md +0 -24
  556. package/scripts/dev/PUBLIC_RELEASE_PLAN.md +0 -88
  557. package/scripts/dev/dev-team-setup.sh +0 -431
  558. package/scripts/e2e-test.sh +0 -119
  559. package/scripts/games/game-protocol.md +0 -79
  560. package/scripts/games/hearts-setup.sh +0 -264
  561. package/scripts/tictactoe-setup.sh +0 -181
  562. /package/dist/dashboard/out/_next/static/chunks/{117-b2cd8d6485aacf2b.js → 117-f7b8ab0809342e77.js} +0 -0
  563. /package/dist/dashboard/out/_next/static/chunks/{648-8f3f26864ce515e5.js → 648-5cc6e1921389a58a.js} +0 -0
  564. /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-0b990dbb71d72a98.js → page-53b8a69f76db17d0.js} +0 -0
  565. /package/dist/dashboard/out/_next/static/chunks/{fd9d1056-bf46c09eb57e019c.js → fd9d1056-609918ca7b6280bb.js} +0 -0
  566. /package/dist/dashboard/out/_next/static/{6HHWb2ZmnJ4OSm0zUP7h4 → wPgKJtcOmTFLpUncDg16A}/_buildManifest.js +0 -0
  567. /package/dist/dashboard/out/_next/static/{6HHWb2ZmnJ4OSm0zUP7h4 → wPgKJtcOmTFLpUncDg16A}/_ssgManifest.js +0 -0
@@ -0,0 +1,593 @@
1
+ /**
2
+ * Agent Memory Monitor
3
+ *
4
+ * Comprehensive memory monitoring for agent processes:
5
+ * - Detailed memory metrics (RSS, heap, external)
6
+ * - Memory trend analysis (growing/stable/shrinking)
7
+ * - High watermark tracking
8
+ * - Configurable thresholds for proactive alerting
9
+ * - Memory history for trend analysis
10
+ * - Crash prevention through memory pressure detection
11
+ */
12
+ import { EventEmitter } from 'events';
13
+ import { execSync } from 'child_process';
14
+ import * as os from 'os';
15
+ const DEFAULT_THRESHOLDS = {
16
+ warningBytes: 512 * 1024 * 1024, // 512MB
17
+ criticalBytes: 1024 * 1024 * 1024, // 1GB
18
+ oomImminentBytes: 1.5 * 1024 * 1024 * 1024, // 1.5GB
19
+ trendGrowthRateWarning: 10 * 1024 * 1024, // 10MB per minute
20
+ historyRetentionMinutes: 60, // Keep 1 hour of history
21
+ historyMaxSamples: 360, // Max 360 samples (every 10s for 1 hour)
22
+ };
23
+ const DEFAULT_CONFIG = {
24
+ checkIntervalMs: 10000, // Every 10 seconds
25
+ thresholds: DEFAULT_THRESHOLDS,
26
+ enableTrendAnalysis: true,
27
+ enableProactiveAlerts: true,
28
+ };
29
+ export class AgentMemoryMonitor extends EventEmitter {
30
+ agents = new Map();
31
+ pids = new Map(); // name -> pid
32
+ intervalId;
33
+ config;
34
+ isRunning = false;
35
+ alertCooldowns = new Map(); // Prevent alert spam
36
+ constructor(config = {}) {
37
+ super();
38
+ this.config = {
39
+ ...DEFAULT_CONFIG,
40
+ ...config,
41
+ thresholds: {
42
+ ...DEFAULT_THRESHOLDS,
43
+ ...config.thresholds,
44
+ },
45
+ };
46
+ }
47
+ /**
48
+ * Register an agent for memory monitoring
49
+ */
50
+ register(name, pid) {
51
+ const now = new Date();
52
+ const initialSnapshot = {
53
+ timestamp: now,
54
+ rssBytes: 0,
55
+ heapUsedBytes: 0,
56
+ heapTotalBytes: 0,
57
+ externalBytes: 0,
58
+ cpuPercent: 0,
59
+ };
60
+ this.agents.set(name, {
61
+ name,
62
+ pid,
63
+ current: initialSnapshot,
64
+ highWatermark: 0,
65
+ lowWatermark: Infinity,
66
+ averageRss: 0,
67
+ trend: 'unknown',
68
+ trendRatePerMinute: 0,
69
+ alertLevel: 'normal',
70
+ memoryHistory: [],
71
+ startedAt: now,
72
+ uptimeMs: 0,
73
+ });
74
+ this.pids.set(name, pid);
75
+ this.emit('registered', { name, pid });
76
+ this.log('info', `Registered agent for memory monitoring: ${name} (PID: ${pid})`);
77
+ // Immediate first sample
78
+ if (this.isRunning) {
79
+ this.sampleAgent(name).catch(() => { });
80
+ }
81
+ }
82
+ /**
83
+ * Update PID for an agent (after restart)
84
+ */
85
+ updatePid(name, newPid) {
86
+ const metrics = this.agents.get(name);
87
+ if (metrics) {
88
+ metrics.pid = newPid;
89
+ // Reset metrics but keep history for trend continuity
90
+ metrics.highWatermark = 0;
91
+ metrics.lowWatermark = Infinity;
92
+ metrics.alertLevel = 'normal';
93
+ metrics.startedAt = new Date();
94
+ }
95
+ this.pids.set(name, newPid);
96
+ this.log('info', `Updated PID for ${name}: ${newPid}`);
97
+ }
98
+ /**
99
+ * Unregister an agent
100
+ */
101
+ unregister(name) {
102
+ const metrics = this.agents.get(name);
103
+ this.agents.delete(name);
104
+ this.pids.delete(name);
105
+ this.alertCooldowns.delete(name);
106
+ if (metrics) {
107
+ this.emit('unregistered', { name, finalMetrics: metrics });
108
+ }
109
+ this.log('info', `Unregistered agent: ${name}`);
110
+ }
111
+ /**
112
+ * Start memory monitoring
113
+ */
114
+ start() {
115
+ if (this.isRunning)
116
+ return;
117
+ this.isRunning = true;
118
+ this.log('info', 'Memory monitor started', {
119
+ checkInterval: this.config.checkIntervalMs,
120
+ thresholds: this.config.thresholds,
121
+ });
122
+ this.intervalId = setInterval(() => {
123
+ this.sampleAll().catch((err) => {
124
+ this.log('error', 'Failed to sample agents', { error: String(err) });
125
+ });
126
+ }, this.config.checkIntervalMs);
127
+ // Initial sample
128
+ this.sampleAll().catch(() => { });
129
+ }
130
+ /**
131
+ * Stop memory monitoring
132
+ */
133
+ stop() {
134
+ if (this.intervalId) {
135
+ clearInterval(this.intervalId);
136
+ this.intervalId = undefined;
137
+ }
138
+ this.isRunning = false;
139
+ this.log('info', 'Memory monitor stopped');
140
+ }
141
+ /**
142
+ * Get memory metrics for all agents
143
+ */
144
+ getAll() {
145
+ return Array.from(this.agents.values()).map((m) => ({
146
+ ...m,
147
+ uptimeMs: Date.now() - m.startedAt.getTime(),
148
+ }));
149
+ }
150
+ /**
151
+ * Get memory metrics for a specific agent
152
+ */
153
+ get(name) {
154
+ const metrics = this.agents.get(name);
155
+ if (metrics) {
156
+ return {
157
+ ...metrics,
158
+ uptimeMs: Date.now() - metrics.startedAt.getTime(),
159
+ };
160
+ }
161
+ return undefined;
162
+ }
163
+ /**
164
+ * Get crash context for an agent (for crash analysis)
165
+ */
166
+ getCrashContext(name) {
167
+ const metrics = this.agents.get(name);
168
+ const now = new Date();
169
+ if (!metrics) {
170
+ return {
171
+ agentName: name,
172
+ pid: this.pids.get(name) || 0,
173
+ crashTime: now,
174
+ lastKnownMemory: null,
175
+ peakMemory: 0,
176
+ averageMemory: 0,
177
+ memoryTrend: 'unknown',
178
+ recentHistory: [],
179
+ likelyCause: 'unknown',
180
+ analysisNotes: ['No memory data available - agent was not being monitored'],
181
+ };
182
+ }
183
+ const recentHistory = metrics.memoryHistory.slice(-30); // Last 30 samples
184
+ const analysisNotes = [];
185
+ let likelyCause = 'unknown';
186
+ // Analyze crash cause
187
+ const lastMemory = metrics.current.rssBytes;
188
+ const { thresholds } = this.config;
189
+ if (lastMemory >= thresholds.oomImminentBytes) {
190
+ likelyCause = 'oom';
191
+ analysisNotes.push(`Memory was at OOM-imminent level: ${formatBytes(lastMemory)}`);
192
+ }
193
+ else if (metrics.trend === 'growing' && metrics.trendRatePerMinute > thresholds.trendGrowthRateWarning) {
194
+ likelyCause = 'memory_leak';
195
+ analysisNotes.push(`Memory was growing at ${formatBytes(metrics.trendRatePerMinute)}/min`);
196
+ }
197
+ else if (recentHistory.length >= 2) {
198
+ const prevMemory = recentHistory[recentHistory.length - 2]?.rssBytes || 0;
199
+ const spike = lastMemory - prevMemory;
200
+ if (spike > 100 * 1024 * 1024) {
201
+ // 100MB spike
202
+ likelyCause = 'sudden_spike';
203
+ analysisNotes.push(`Sudden memory spike of ${formatBytes(spike)} detected`);
204
+ }
205
+ }
206
+ // Add general analysis notes
207
+ analysisNotes.push(`Peak memory: ${formatBytes(metrics.highWatermark)}`);
208
+ analysisNotes.push(`Average memory: ${formatBytes(metrics.averageRss)}`);
209
+ analysisNotes.push(`Memory trend: ${metrics.trend} (${formatBytes(metrics.trendRatePerMinute)}/min)`);
210
+ analysisNotes.push(`Alert level at crash: ${metrics.alertLevel}`);
211
+ return {
212
+ agentName: name,
213
+ pid: metrics.pid,
214
+ crashTime: now,
215
+ lastKnownMemory: metrics.current,
216
+ peakMemory: metrics.highWatermark,
217
+ averageMemory: metrics.averageRss,
218
+ memoryTrend: metrics.trend,
219
+ recentHistory,
220
+ likelyCause,
221
+ analysisNotes,
222
+ };
223
+ }
224
+ /**
225
+ * Get system-wide memory summary
226
+ */
227
+ getSystemSummary() {
228
+ const allMetrics = this.getAll();
229
+ const byAlertLevel = {
230
+ normal: 0,
231
+ warning: 0,
232
+ critical: 0,
233
+ oom_imminent: 0,
234
+ };
235
+ for (const m of allMetrics) {
236
+ byAlertLevel[m.alertLevel] = (byAlertLevel[m.alertLevel] || 0) + 1;
237
+ }
238
+ const totalMemory = allMetrics.reduce((sum, m) => sum + m.current.rssBytes, 0);
239
+ const topConsumers = allMetrics
240
+ .sort((a, b) => b.current.rssBytes - a.current.rssBytes)
241
+ .slice(0, 5)
242
+ .map((m) => ({ name: m.name, rssBytes: m.current.rssBytes }));
243
+ return {
244
+ totalAgents: allMetrics.length,
245
+ totalMemoryBytes: totalMemory,
246
+ agentsByAlertLevel: byAlertLevel,
247
+ topMemoryConsumers: topConsumers,
248
+ systemMemory: this.getSystemMemory(),
249
+ };
250
+ }
251
+ /**
252
+ * Sample memory for all registered agents
253
+ */
254
+ async sampleAll() {
255
+ const promises = Array.from(this.agents.keys()).map((name) => this.sampleAgent(name).catch((err) => {
256
+ this.log('warn', `Failed to sample ${name}`, { error: String(err) });
257
+ }));
258
+ await Promise.all(promises);
259
+ }
260
+ /**
261
+ * Sample memory for a single agent
262
+ */
263
+ async sampleAgent(name) {
264
+ const metrics = this.agents.get(name);
265
+ if (!metrics)
266
+ return;
267
+ const pid = metrics.pid;
268
+ // Check if process is still alive
269
+ if (!this.isProcessAlive(pid)) {
270
+ this.log('warn', `Process ${pid} for ${name} is not alive`);
271
+ return;
272
+ }
273
+ try {
274
+ const snapshot = await this.getProcessMemory(pid);
275
+ this.updateMetrics(name, snapshot);
276
+ }
277
+ catch (error) {
278
+ this.log('warn', `Failed to get memory for ${name}`, { error: String(error) });
279
+ }
280
+ }
281
+ /**
282
+ * Update metrics with new snapshot
283
+ */
284
+ updateMetrics(name, snapshot) {
285
+ const metrics = this.agents.get(name);
286
+ if (!metrics)
287
+ return;
288
+ const { thresholds } = this.config;
289
+ const _previousRss = metrics.current.rssBytes;
290
+ const previousAlertLevel = metrics.alertLevel;
291
+ // Update current snapshot
292
+ metrics.current = snapshot;
293
+ metrics.uptimeMs = Date.now() - metrics.startedAt.getTime();
294
+ // Update watermarks
295
+ if (snapshot.rssBytes > metrics.highWatermark) {
296
+ metrics.highWatermark = snapshot.rssBytes;
297
+ }
298
+ if (snapshot.rssBytes < metrics.lowWatermark && snapshot.rssBytes > 0) {
299
+ metrics.lowWatermark = snapshot.rssBytes;
300
+ }
301
+ // Add to history
302
+ metrics.memoryHistory.push(snapshot);
303
+ // Trim history
304
+ const maxAge = Date.now() - thresholds.historyRetentionMinutes * 60 * 1000;
305
+ metrics.memoryHistory = metrics.memoryHistory
306
+ .filter((s) => s.timestamp.getTime() > maxAge)
307
+ .slice(-thresholds.historyMaxSamples);
308
+ // Calculate rolling average
309
+ if (metrics.memoryHistory.length > 0) {
310
+ const sum = metrics.memoryHistory.reduce((acc, s) => acc + s.rssBytes, 0);
311
+ metrics.averageRss = sum / metrics.memoryHistory.length;
312
+ }
313
+ // Analyze trend
314
+ if (this.config.enableTrendAnalysis && metrics.memoryHistory.length >= 6) {
315
+ this.analyzeTrend(metrics);
316
+ }
317
+ // Update alert level
318
+ if (snapshot.rssBytes >= thresholds.oomImminentBytes) {
319
+ metrics.alertLevel = 'oom_imminent';
320
+ }
321
+ else if (snapshot.rssBytes >= thresholds.criticalBytes) {
322
+ metrics.alertLevel = 'critical';
323
+ }
324
+ else if (snapshot.rssBytes >= thresholds.warningBytes) {
325
+ metrics.alertLevel = 'warning';
326
+ }
327
+ else {
328
+ metrics.alertLevel = 'normal';
329
+ }
330
+ // Emit events
331
+ this.emit('sample', { name, snapshot, metrics });
332
+ // Check for alerts
333
+ if (this.config.enableProactiveAlerts) {
334
+ this.checkAlerts(name, metrics, previousAlertLevel);
335
+ }
336
+ }
337
+ /**
338
+ * Analyze memory trend
339
+ */
340
+ analyzeTrend(metrics) {
341
+ const history = metrics.memoryHistory;
342
+ if (history.length < 6) {
343
+ metrics.trend = 'unknown';
344
+ return;
345
+ }
346
+ // Use last 6 samples for trend (1 minute at 10s intervals)
347
+ const recent = history.slice(-6);
348
+ const oldest = recent[0];
349
+ const newest = recent[recent.length - 1];
350
+ const timeDeltaMs = newest.timestamp.getTime() - oldest.timestamp.getTime();
351
+ const memoryDelta = newest.rssBytes - oldest.rssBytes;
352
+ // Calculate rate per minute
353
+ const ratePerMinute = timeDeltaMs > 0 ? (memoryDelta / timeDeltaMs) * 60000 : 0;
354
+ metrics.trendRatePerMinute = ratePerMinute;
355
+ // Determine trend (threshold: 1MB/min change)
356
+ const threshold = 1024 * 1024; // 1MB
357
+ if (ratePerMinute > threshold) {
358
+ metrics.trend = 'growing';
359
+ }
360
+ else if (ratePerMinute < -threshold) {
361
+ metrics.trend = 'shrinking';
362
+ }
363
+ else {
364
+ metrics.trend = 'stable';
365
+ }
366
+ }
367
+ /**
368
+ * Check and emit alerts
369
+ */
370
+ checkAlerts(name, metrics, previousLevel) {
371
+ const { thresholds } = this.config;
372
+ const now = new Date();
373
+ // Check cooldown (don't spam alerts)
374
+ const lastAlert = this.alertCooldowns.get(name);
375
+ const cooldownMs = 60000; // 1 minute cooldown
376
+ if (lastAlert && now.getTime() - lastAlert.getTime() < cooldownMs) {
377
+ return;
378
+ }
379
+ let alert = null;
380
+ // Check for level transitions
381
+ if (metrics.alertLevel !== previousLevel) {
382
+ if (metrics.alertLevel === 'oom_imminent') {
383
+ alert = {
384
+ type: 'oom_imminent',
385
+ agentName: name,
386
+ pid: metrics.pid,
387
+ currentRss: metrics.current.rssBytes,
388
+ threshold: thresholds.oomImminentBytes,
389
+ message: `Agent ${name} is about to run out of memory!`,
390
+ recommendation: 'Consider restarting the agent or killing heavy operations',
391
+ timestamp: now,
392
+ };
393
+ }
394
+ else if (metrics.alertLevel === 'critical') {
395
+ alert = {
396
+ type: 'critical',
397
+ agentName: name,
398
+ pid: metrics.pid,
399
+ currentRss: metrics.current.rssBytes,
400
+ threshold: thresholds.criticalBytes,
401
+ message: `Agent ${name} memory usage is critical`,
402
+ recommendation: 'Monitor closely, may need intervention soon',
403
+ timestamp: now,
404
+ };
405
+ }
406
+ else if (metrics.alertLevel === 'warning') {
407
+ alert = {
408
+ type: 'warning',
409
+ agentName: name,
410
+ pid: metrics.pid,
411
+ currentRss: metrics.current.rssBytes,
412
+ threshold: thresholds.warningBytes,
413
+ message: `Agent ${name} memory usage is elevated`,
414
+ recommendation: 'Keep monitoring, consider investigation if trend continues',
415
+ timestamp: now,
416
+ };
417
+ }
418
+ else if (previousLevel !== 'normal' && metrics.alertLevel === 'normal') {
419
+ alert = {
420
+ type: 'recovered',
421
+ agentName: name,
422
+ pid: metrics.pid,
423
+ currentRss: metrics.current.rssBytes,
424
+ threshold: thresholds.warningBytes,
425
+ message: `Agent ${name} memory usage returned to normal`,
426
+ recommendation: 'No action needed',
427
+ timestamp: now,
428
+ };
429
+ }
430
+ }
431
+ // Check for rapid growth trend
432
+ if (metrics.trend === 'growing' &&
433
+ metrics.trendRatePerMinute > thresholds.trendGrowthRateWarning &&
434
+ !alert) {
435
+ alert = {
436
+ type: 'trend_warning',
437
+ agentName: name,
438
+ pid: metrics.pid,
439
+ currentRss: metrics.current.rssBytes,
440
+ threshold: thresholds.trendGrowthRateWarning,
441
+ message: `Agent ${name} memory is growing rapidly: ${formatBytes(metrics.trendRatePerMinute)}/min`,
442
+ recommendation: 'Investigate for potential memory leak',
443
+ timestamp: now,
444
+ };
445
+ }
446
+ if (alert) {
447
+ metrics.lastAlertAt = now;
448
+ this.alertCooldowns.set(name, now);
449
+ this.emit('alert', alert);
450
+ this.log(alert.type === 'recovered' ? 'info' : 'warn', alert.message, {
451
+ agent: name,
452
+ type: alert.type,
453
+ rss: formatBytes(alert.currentRss),
454
+ });
455
+ }
456
+ }
457
+ /**
458
+ * Get memory for a process using ps
459
+ */
460
+ async getProcessMemory(pid) {
461
+ try {
462
+ // ps command for detailed memory: rss, vsz, and CPU
463
+ const output = execSync(`ps -o rss=,vsz=,pcpu= -p ${pid}`, {
464
+ encoding: 'utf8',
465
+ timeout: 5000,
466
+ }).trim();
467
+ const parts = output.split(/\s+/);
468
+ const rssKb = parseInt(parts[0] || '0', 10);
469
+ const _vszKb = parseInt(parts[1] || '0', 10);
470
+ const cpu = parseFloat(parts[2] || '0');
471
+ // Try to get more detailed memory from /proc on Linux
472
+ let heapUsed = 0;
473
+ const heapTotal = 0;
474
+ const external = 0;
475
+ try {
476
+ const smaps = execSync(`cat /proc/${pid}/smaps_rollup 2>/dev/null || echo ""`, {
477
+ encoding: 'utf8',
478
+ timeout: 2000,
479
+ });
480
+ const rssMatch = smaps.match(/Rss:\s+(\d+)\s+kB/);
481
+ if (rssMatch) {
482
+ // Use smaps for more accurate RSS
483
+ }
484
+ // For heap estimation on Linux
485
+ const heapMatch = smaps.match(/Private_Dirty:\s+(\d+)\s+kB/);
486
+ if (heapMatch) {
487
+ heapUsed = parseInt(heapMatch[1], 10) * 1024;
488
+ }
489
+ }
490
+ catch {
491
+ // Not on Linux or no access to /proc
492
+ }
493
+ return {
494
+ timestamp: new Date(),
495
+ rssBytes: rssKb * 1024,
496
+ heapUsedBytes: heapUsed || rssKb * 1024 * 0.6, // Estimate heap as 60% of RSS
497
+ heapTotalBytes: heapTotal || rssKb * 1024 * 0.8,
498
+ externalBytes: external,
499
+ cpuPercent: cpu,
500
+ };
501
+ }
502
+ catch {
503
+ return {
504
+ timestamp: new Date(),
505
+ rssBytes: 0,
506
+ heapUsedBytes: 0,
507
+ heapTotalBytes: 0,
508
+ externalBytes: 0,
509
+ cpuPercent: 0,
510
+ };
511
+ }
512
+ }
513
+ /**
514
+ * Get system memory info
515
+ */
516
+ getSystemMemory() {
517
+ try {
518
+ const meminfo = execSync('cat /proc/meminfo', { encoding: 'utf8' });
519
+ const total = parseInt(meminfo.match(/MemTotal:\s+(\d+)/)?.[1] || '0', 10) * 1024;
520
+ const free = parseInt(meminfo.match(/MemFree:\s+(\d+)/)?.[1] || '0', 10) * 1024;
521
+ const available = parseInt(meminfo.match(/MemAvailable:\s+(\d+)/)?.[1] || '0', 10) * 1024;
522
+ return { total, free, available };
523
+ }
524
+ catch {
525
+ // Fallback for non-Linux
526
+ return {
527
+ total: os.totalmem(),
528
+ free: os.freemem(),
529
+ available: os.freemem(),
530
+ };
531
+ }
532
+ }
533
+ /**
534
+ * Check if a process is alive
535
+ */
536
+ isProcessAlive(pid) {
537
+ try {
538
+ process.kill(pid, 0);
539
+ return true;
540
+ }
541
+ catch {
542
+ return false;
543
+ }
544
+ }
545
+ /**
546
+ * Structured logging
547
+ */
548
+ log(level, message, context) {
549
+ const entry = {
550
+ timestamp: new Date().toISOString(),
551
+ level,
552
+ component: 'memory-monitor',
553
+ message,
554
+ ...context,
555
+ };
556
+ this.emit('log', entry);
557
+ const prefix = `[memory-monitor]`;
558
+ switch (level) {
559
+ case 'info':
560
+ console.log(prefix, message, context ? JSON.stringify(context) : '');
561
+ break;
562
+ case 'warn':
563
+ console.warn(prefix, message, context ? JSON.stringify(context) : '');
564
+ break;
565
+ case 'error':
566
+ console.error(prefix, message, context ? JSON.stringify(context) : '');
567
+ break;
568
+ }
569
+ }
570
+ }
571
+ /**
572
+ * Format bytes for human-readable display
573
+ */
574
+ function formatBytes(bytes) {
575
+ if (bytes === 0)
576
+ return '0 B';
577
+ const k = 1024;
578
+ const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];
579
+ const i = Math.floor(Math.log(Math.abs(bytes)) / Math.log(k));
580
+ const value = bytes / Math.pow(k, i);
581
+ return `${value.toFixed(2)} ${sizes[i]}`;
582
+ }
583
+ // Export utility
584
+ export { formatBytes };
585
+ // Singleton instance
586
+ let _memoryMonitor = null;
587
+ export function getMemoryMonitor(config) {
588
+ if (!_memoryMonitor) {
589
+ _memoryMonitor = new AgentMemoryMonitor(config);
590
+ }
591
+ return _memoryMonitor;
592
+ }
593
+ //# sourceMappingURL=memory-monitor.js.map