@elizaos/agent 2.0.0-alpha.98 → 2.0.0-beta.2

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 (1227) hide show
  1. package/package.json +78 -923
  2. package/packages/agent/src/actions/connector-resolver.d.ts +74 -0
  3. package/packages/agent/src/actions/connector-resolver.d.ts.map +1 -0
  4. package/packages/agent/src/actions/connector-resolver.js +253 -0
  5. package/packages/agent/src/actions/contact.d.ts +35 -0
  6. package/packages/agent/src/actions/contact.d.ts.map +1 -0
  7. package/packages/agent/src/actions/contact.js +1698 -0
  8. package/packages/agent/src/actions/context-signal-lexicon.d.ts +17 -0
  9. package/packages/agent/src/actions/context-signal-lexicon.d.ts.map +1 -0
  10. package/packages/agent/src/actions/context-signal-lexicon.js +206 -0
  11. package/packages/agent/src/actions/context-signal.d.ts +48 -0
  12. package/packages/agent/src/actions/context-signal.d.ts.map +1 -0
  13. package/packages/agent/src/actions/context-signal.js +153 -0
  14. package/packages/agent/src/actions/database.d.ts +20 -0
  15. package/packages/agent/src/actions/database.d.ts.map +1 -0
  16. package/packages/agent/src/actions/database.js +671 -0
  17. package/packages/agent/src/actions/extract-page.d.ts +3 -0
  18. package/packages/agent/src/actions/extract-page.d.ts.map +1 -0
  19. package/packages/agent/src/actions/extract-page.js +153 -0
  20. package/packages/agent/src/actions/extract-params.d.ts +87 -0
  21. package/packages/agent/src/actions/extract-params.d.ts.map +1 -0
  22. package/packages/agent/src/actions/extract-params.js +187 -0
  23. package/packages/agent/src/actions/grounded-action-reply.d.ts +22 -0
  24. package/packages/agent/src/actions/grounded-action-reply.d.ts.map +1 -0
  25. package/packages/agent/src/actions/grounded-action-reply.js +287 -0
  26. package/packages/agent/src/actions/index.d.ts +22 -0
  27. package/packages/agent/src/actions/index.d.ts.map +1 -0
  28. package/packages/agent/src/actions/index.js +21 -0
  29. package/packages/agent/src/actions/logs.d.ts +11 -0
  30. package/packages/agent/src/actions/logs.d.ts.map +1 -0
  31. package/packages/agent/src/actions/logs.js +300 -0
  32. package/packages/agent/src/actions/media.d.ts +9 -0
  33. package/packages/agent/src/actions/media.d.ts.map +1 -0
  34. package/packages/agent/src/actions/media.js +135 -0
  35. package/packages/agent/src/actions/memories.d.ts +9 -0
  36. package/packages/agent/src/actions/memories.d.ts.map +1 -0
  37. package/packages/agent/src/actions/memories.js +369 -0
  38. package/packages/agent/src/actions/page-action-groups.d.ts +17 -0
  39. package/packages/agent/src/actions/page-action-groups.d.ts.map +1 -0
  40. package/packages/agent/src/actions/page-action-groups.js +413 -0
  41. package/packages/agent/src/actions/plugin.d.ts +32 -0
  42. package/packages/agent/src/actions/plugin.d.ts.map +1 -0
  43. package/packages/agent/src/actions/plugin.js +780 -0
  44. package/packages/agent/src/actions/recent-conversation-texts.d.ts +9 -0
  45. package/packages/agent/src/actions/recent-conversation-texts.d.ts.map +1 -0
  46. package/packages/agent/src/actions/recent-conversation-texts.js +76 -0
  47. package/packages/agent/src/actions/runtime.d.ts +19 -0
  48. package/packages/agent/src/actions/runtime.d.ts.map +1 -0
  49. package/packages/agent/src/actions/runtime.js +517 -0
  50. package/packages/agent/src/actions/settings-actions.d.ts +19 -0
  51. package/packages/agent/src/actions/settings-actions.d.ts.map +1 -0
  52. package/packages/agent/src/actions/settings-actions.js +478 -0
  53. package/packages/agent/src/actions/skill-command.d.ts +20 -0
  54. package/packages/agent/src/actions/skill-command.d.ts.map +1 -0
  55. package/packages/agent/src/actions/skill-command.js +170 -0
  56. package/packages/agent/src/actions/stream-control.d.ts +13 -8
  57. package/packages/agent/src/actions/stream-control.d.ts.map +1 -1
  58. package/packages/agent/src/actions/stream-control.js +127 -318
  59. package/packages/agent/src/actions/terminal.d.ts +4 -3
  60. package/packages/agent/src/actions/terminal.d.ts.map +1 -1
  61. package/packages/agent/src/actions/terminal.js +247 -96
  62. package/packages/agent/src/actions/trajectories.d.ts +8 -0
  63. package/packages/agent/src/actions/trajectories.d.ts.map +1 -0
  64. package/packages/agent/src/actions/trajectories.js +135 -0
  65. package/packages/agent/src/actions/trigger.d.ts +5 -0
  66. package/packages/agent/src/actions/trigger.d.ts.map +1 -0
  67. package/packages/agent/src/actions/trigger.js +514 -0
  68. package/packages/agent/src/api/accounts-routes.d.ts +38 -0
  69. package/packages/agent/src/api/accounts-routes.d.ts.map +1 -0
  70. package/packages/agent/src/api/accounts-routes.js +927 -0
  71. package/packages/agent/src/api/agent-admin-routes.d.ts +6 -5
  72. package/packages/agent/src/api/agent-admin-routes.d.ts.map +1 -1
  73. package/packages/agent/src/api/agent-admin-routes.js +106 -9
  74. package/packages/agent/src/api/agent-lifecycle-routes.d.ts +2 -2
  75. package/packages/agent/src/api/agent-lifecycle-routes.d.ts.map +1 -1
  76. package/packages/agent/src/api/agent-lifecycle-routes.js +22 -1
  77. package/packages/agent/src/api/agent-model.d.ts +2 -9
  78. package/packages/agent/src/api/agent-model.d.ts.map +1 -1
  79. package/packages/agent/src/api/agent-model.js +50 -3
  80. package/packages/agent/src/api/agent-status-routes.d.ts +75 -0
  81. package/packages/agent/src/api/agent-status-routes.d.ts.map +1 -0
  82. package/packages/agent/src/api/agent-status-routes.js +264 -0
  83. package/packages/agent/src/api/agent-transfer-routes.d.ts +1 -1
  84. package/packages/agent/src/api/agent-transfer-routes.js +1 -1
  85. package/packages/agent/src/api/app-package-routes.d.ts +7 -0
  86. package/packages/agent/src/api/app-package-routes.d.ts.map +1 -0
  87. package/packages/agent/src/api/app-package-routes.js +59 -0
  88. package/packages/agent/src/api/apps-routes.d.ts +16 -3
  89. package/packages/agent/src/api/apps-routes.d.ts.map +1 -1
  90. package/packages/agent/src/api/apps-routes.js +885 -15
  91. package/packages/agent/src/api/auth-routes.d.ts +1 -1
  92. package/packages/agent/src/api/auth-routes.d.ts.map +1 -1
  93. package/packages/agent/src/api/auth-routes.js +67 -2
  94. package/packages/agent/src/api/avatar-routes.d.ts +11 -0
  95. package/packages/agent/src/api/avatar-routes.d.ts.map +1 -0
  96. package/packages/agent/src/api/avatar-routes.js +205 -0
  97. package/packages/agent/src/api/binance-skill-helpers.d.ts +21 -0
  98. package/packages/agent/src/api/binance-skill-helpers.d.ts.map +1 -0
  99. package/packages/agent/src/api/binance-skill-helpers.js +745 -0
  100. package/packages/agent/src/api/bug-report-routes.d.ts +5 -2
  101. package/packages/agent/src/api/bug-report-routes.d.ts.map +1 -1
  102. package/packages/agent/src/api/bug-report-routes.js +155 -8
  103. package/packages/agent/src/api/build-variant-routes.d.ts +27 -0
  104. package/packages/agent/src/api/build-variant-routes.d.ts.map +1 -0
  105. package/packages/agent/src/api/build-variant-routes.js +27 -0
  106. package/packages/agent/src/api/character-routes.d.ts +7 -5
  107. package/packages/agent/src/api/character-routes.d.ts.map +1 -1
  108. package/packages/agent/src/api/character-routes.js +100 -49
  109. package/packages/agent/src/api/chat-augmentation.d.ts +70 -0
  110. package/packages/agent/src/api/chat-augmentation.d.ts.map +1 -0
  111. package/packages/agent/src/api/chat-augmentation.js +464 -0
  112. package/packages/agent/src/api/chat-routes.d.ts +124 -0
  113. package/packages/agent/src/api/chat-routes.d.ts.map +1 -0
  114. package/packages/agent/src/api/chat-routes.js +1841 -0
  115. package/packages/agent/src/api/chat-text-helpers.d.ts +11 -0
  116. package/packages/agent/src/api/chat-text-helpers.d.ts.map +1 -0
  117. package/packages/agent/src/api/chat-text-helpers.js +184 -0
  118. package/packages/agent/src/api/client-chat-admin.d.ts +19 -0
  119. package/packages/agent/src/api/client-chat-admin.d.ts.map +1 -0
  120. package/packages/agent/src/api/client-chat-admin.js +27 -0
  121. package/packages/agent/src/api/cloud-route-registry.d.ts +22 -0
  122. package/packages/agent/src/api/cloud-route-registry.d.ts.map +1 -0
  123. package/packages/agent/src/api/cloud-route-registry.js +20 -0
  124. package/packages/agent/src/api/compat-utils.d.ts.map +1 -1
  125. package/packages/agent/src/api/compat-utils.js +1 -5
  126. package/packages/agent/src/api/config-env.d.ts +43 -0
  127. package/packages/agent/src/api/config-env.d.ts.map +1 -0
  128. package/packages/agent/src/api/config-env.js +284 -0
  129. package/packages/agent/src/api/config-routes.d.ts +40 -0
  130. package/packages/agent/src/api/config-routes.d.ts.map +1 -0
  131. package/packages/agent/src/api/config-routes.js +429 -0
  132. package/packages/agent/src/api/connector-account-routes.d.ts +25 -0
  133. package/packages/agent/src/api/connector-account-routes.d.ts.map +1 -0
  134. package/packages/agent/src/api/connector-account-routes.js +740 -0
  135. package/packages/agent/src/api/connector-health.d.ts +9 -1
  136. package/packages/agent/src/api/connector-health.d.ts.map +1 -1
  137. package/packages/agent/src/api/connector-health.js +33 -10
  138. package/packages/agent/src/api/connector-oauth-callback-auth.d.ts +2 -0
  139. package/packages/agent/src/api/connector-oauth-callback-auth.d.ts.map +1 -0
  140. package/packages/agent/src/api/connector-oauth-callback-auth.js +4 -0
  141. package/packages/agent/src/api/connector-routes.d.ts +36 -0
  142. package/packages/agent/src/api/connector-routes.d.ts.map +1 -0
  143. package/packages/agent/src/api/connector-routes.js +184 -0
  144. package/packages/agent/src/api/conversation-metadata.d.ts +10 -0
  145. package/packages/agent/src/api/conversation-metadata.d.ts.map +1 -0
  146. package/packages/agent/src/api/conversation-metadata.js +107 -0
  147. package/packages/agent/src/api/conversation-routes.d.ts +43 -0
  148. package/packages/agent/src/api/conversation-routes.d.ts.map +1 -0
  149. package/packages/agent/src/api/conversation-routes.js +1208 -0
  150. package/packages/agent/src/api/coordinator-wiring.d.ts +4 -4
  151. package/packages/agent/src/api/coordinator-wiring.d.ts.map +1 -1
  152. package/packages/agent/src/api/coordinator-wiring.js +13 -6
  153. package/packages/agent/src/api/credit-detection.d.ts.map +1 -1
  154. package/packages/agent/src/api/credit-detection.js +12 -6
  155. package/packages/agent/src/api/curated-skills-routes.d.ts +22 -0
  156. package/packages/agent/src/api/curated-skills-routes.d.ts.map +1 -0
  157. package/packages/agent/src/api/curated-skills-routes.js +295 -0
  158. package/packages/agent/src/api/database.d.ts +2 -0
  159. package/packages/agent/src/api/database.d.ts.map +1 -1
  160. package/packages/agent/src/api/database.js +129 -8
  161. package/packages/agent/src/api/diagnostics-routes.d.ts +15 -2
  162. package/packages/agent/src/api/diagnostics-routes.d.ts.map +1 -1
  163. package/packages/agent/src/api/diagnostics-routes.js +145 -21
  164. package/packages/agent/src/api/documents-routes.d.ts +9 -0
  165. package/packages/agent/src/api/documents-routes.d.ts.map +1 -0
  166. package/packages/agent/src/api/documents-routes.js +26 -0
  167. package/packages/agent/src/api/documents-service-loader.d.ts +76 -0
  168. package/packages/agent/src/api/documents-service-loader.d.ts.map +1 -0
  169. package/packages/agent/src/api/{knowledge-service-loader.js → documents-service-loader.js} +10 -8
  170. package/packages/agent/src/api/health-routes.d.ts +46 -0
  171. package/packages/agent/src/api/health-routes.d.ts.map +1 -0
  172. package/packages/agent/src/api/health-routes.js +450 -0
  173. package/packages/agent/src/api/inbox-routes.d.ts +47 -0
  174. package/packages/agent/src/api/inbox-routes.d.ts.map +1 -0
  175. package/packages/agent/src/api/inbox-routes.js +1579 -0
  176. package/packages/agent/src/api/index.d.ts +45 -60
  177. package/packages/agent/src/api/index.d.ts.map +1 -1
  178. package/packages/agent/src/api/index.js +49 -59
  179. package/packages/agent/src/api/memory-routes.d.ts +1 -1
  180. package/packages/agent/src/api/memory-routes.d.ts.map +1 -1
  181. package/packages/agent/src/api/memory-routes.js +274 -41
  182. package/packages/agent/src/api/misc-routes.d.ts +64 -0
  183. package/packages/agent/src/api/misc-routes.d.ts.map +1 -0
  184. package/packages/agent/src/api/misc-routes.js +569 -0
  185. package/packages/agent/src/api/mobile-optional-routes.d.ts +3 -0
  186. package/packages/agent/src/api/mobile-optional-routes.d.ts.map +1 -0
  187. package/packages/agent/src/api/mobile-optional-routes.js +91 -0
  188. package/packages/agent/src/api/model-provider-helpers.d.ts +68 -0
  189. package/packages/agent/src/api/model-provider-helpers.d.ts.map +1 -0
  190. package/packages/agent/src/api/model-provider-helpers.js +623 -0
  191. package/packages/agent/src/api/models-routes.d.ts +1 -1
  192. package/packages/agent/src/api/models-routes.d.ts.map +1 -1
  193. package/packages/agent/src/api/music-player-route-fallback.d.ts +16 -0
  194. package/packages/agent/src/api/music-player-route-fallback.d.ts.map +1 -0
  195. package/packages/agent/src/api/music-player-route-fallback.js +65 -0
  196. package/packages/agent/src/api/nfa-routes.d.ts +2 -1
  197. package/packages/agent/src/api/nfa-routes.d.ts.map +1 -1
  198. package/packages/agent/src/api/nfa-routes.js +10 -10
  199. package/packages/agent/src/api/onboarding-routes.d.ts +50 -0
  200. package/packages/agent/src/api/onboarding-routes.d.ts.map +1 -0
  201. package/packages/agent/src/api/onboarding-routes.js +588 -0
  202. package/packages/agent/src/api/owner-contact-helpers.d.ts +39 -0
  203. package/packages/agent/src/api/owner-contact-helpers.d.ts.map +1 -0
  204. package/packages/agent/src/api/owner-contact-helpers.js +47 -0
  205. package/packages/agent/src/api/parse-action-block.d.ts +20 -3
  206. package/packages/agent/src/api/parse-action-block.d.ts.map +1 -1
  207. package/packages/agent/src/api/parse-action-block.js +77 -6
  208. package/packages/agent/src/api/permission-request-prompt.d.ts +19 -0
  209. package/packages/agent/src/api/permission-request-prompt.d.ts.map +1 -0
  210. package/packages/agent/src/api/permission-request-prompt.js +53 -0
  211. package/packages/agent/src/api/permissions-routes-extra.d.ts +30 -0
  212. package/packages/agent/src/api/permissions-routes-extra.d.ts.map +1 -0
  213. package/packages/agent/src/api/permissions-routes-extra.js +78 -0
  214. package/packages/agent/src/api/permissions-routes.d.ts +6 -11
  215. package/packages/agent/src/api/permissions-routes.d.ts.map +1 -1
  216. package/packages/agent/src/api/permissions-routes.js +230 -27
  217. package/packages/agent/src/api/plugin-discovery-helpers.d.ts +147 -0
  218. package/packages/agent/src/api/plugin-discovery-helpers.d.ts.map +1 -0
  219. package/packages/agent/src/api/plugin-discovery-helpers.js +1118 -0
  220. package/packages/agent/src/api/plugin-routes.d.ts +144 -0
  221. package/packages/agent/src/api/plugin-routes.d.ts.map +1 -0
  222. package/packages/agent/src/api/plugin-routes.js +1285 -0
  223. package/packages/agent/src/api/plugin-runtime-apply.d.ts +31 -0
  224. package/packages/agent/src/api/plugin-runtime-apply.d.ts.map +1 -0
  225. package/packages/agent/src/api/plugin-runtime-apply.js +217 -0
  226. package/packages/agent/src/api/plugin-validation.d.ts.map +1 -1
  227. package/packages/agent/src/api/plugin-validation.js +4 -2
  228. package/packages/agent/src/api/provider-switch-config.d.ts +32 -7
  229. package/packages/agent/src/api/provider-switch-config.d.ts.map +1 -1
  230. package/packages/agent/src/api/provider-switch-config.js +627 -225
  231. package/packages/agent/src/api/provider-switch-routes.d.ts +29 -0
  232. package/packages/agent/src/api/provider-switch-routes.d.ts.map +1 -0
  233. package/packages/agent/src/api/provider-switch-routes.js +142 -0
  234. package/packages/agent/src/api/rate-limiter.d.ts +29 -0
  235. package/packages/agent/src/api/rate-limiter.d.ts.map +1 -0
  236. package/packages/agent/src/api/rate-limiter.js +57 -0
  237. package/packages/agent/src/api/registry-routes.d.ts +5 -2
  238. package/packages/agent/src/api/registry-routes.d.ts.map +1 -1
  239. package/packages/agent/src/api/registry-routes.js +13 -5
  240. package/packages/agent/src/api/registry-service.d.ts +1 -1
  241. package/packages/agent/src/api/registry-service.d.ts.map +1 -1
  242. package/packages/agent/src/api/relationships-routes.d.ts +7 -0
  243. package/packages/agent/src/api/relationships-routes.d.ts.map +1 -0
  244. package/packages/agent/src/api/relationships-routes.js +287 -0
  245. package/packages/agent/src/api/runtime-plugin-routes.d.ts +27 -0
  246. package/packages/agent/src/api/runtime-plugin-routes.d.ts.map +1 -0
  247. package/packages/agent/src/api/runtime-plugin-routes.js +203 -0
  248. package/packages/agent/src/api/server-auth.d.ts +46 -0
  249. package/packages/agent/src/api/server-auth.d.ts.map +1 -0
  250. package/packages/agent/src/api/server-auth.js +507 -0
  251. package/packages/agent/src/api/server-autonomy-helpers.d.ts +5 -0
  252. package/packages/agent/src/api/server-autonomy-helpers.d.ts.map +1 -0
  253. package/packages/agent/src/api/server-autonomy-helpers.js +28 -0
  254. package/packages/agent/src/api/server-helpers-auth.d.ts +41 -0
  255. package/packages/agent/src/api/server-helpers-auth.d.ts.map +1 -0
  256. package/packages/agent/src/api/server-helpers-auth.js +627 -0
  257. package/packages/agent/src/api/server-helpers-config.d.ts +37 -0
  258. package/packages/agent/src/api/server-helpers-config.d.ts.map +1 -0
  259. package/packages/agent/src/api/server-helpers-config.js +293 -0
  260. package/packages/agent/src/api/server-helpers-fetch.d.ts +15 -0
  261. package/packages/agent/src/api/server-helpers-fetch.d.ts.map +1 -0
  262. package/packages/agent/src/api/server-helpers-fetch.js +149 -0
  263. package/packages/agent/src/api/server-helpers-mcp.d.ts +12 -0
  264. package/packages/agent/src/api/server-helpers-mcp.d.ts.map +1 -0
  265. package/packages/agent/src/api/server-helpers-mcp.js +315 -0
  266. package/packages/agent/src/api/server-helpers-plugin.d.ts +13 -0
  267. package/packages/agent/src/api/server-helpers-plugin.d.ts.map +1 -0
  268. package/packages/agent/src/api/server-helpers-plugin.js +160 -0
  269. package/packages/agent/src/api/server-helpers-swarm.d.ts +101 -0
  270. package/packages/agent/src/api/server-helpers-swarm.d.ts.map +1 -0
  271. package/packages/agent/src/api/server-helpers-swarm.js +646 -0
  272. package/packages/agent/src/api/server-helpers-wallet.d.ts +18 -0
  273. package/packages/agent/src/api/server-helpers-wallet.d.ts.map +1 -0
  274. package/packages/agent/src/api/server-helpers-wallet.js +177 -0
  275. package/packages/agent/src/api/server-helpers.d.ts +96 -0
  276. package/packages/agent/src/api/server-helpers.d.ts.map +1 -0
  277. package/packages/agent/src/api/server-helpers.js +595 -0
  278. package/packages/agent/src/api/server-route-dispatch.d.ts +30 -0
  279. package/packages/agent/src/api/server-route-dispatch.d.ts.map +1 -0
  280. package/packages/agent/src/api/server-route-dispatch.js +103 -0
  281. package/packages/agent/src/api/server-startup.d.ts +16 -0
  282. package/packages/agent/src/api/server-startup.d.ts.map +1 -0
  283. package/packages/agent/src/api/server-startup.js +14 -0
  284. package/packages/agent/src/api/server-types.d.ts +232 -0
  285. package/packages/agent/src/api/server-types.d.ts.map +1 -0
  286. package/packages/agent/src/api/server-types.js +6 -0
  287. package/packages/agent/src/api/server.d.ts +26 -383
  288. package/packages/agent/src/api/server.d.ts.map +1 -1
  289. package/packages/agent/src/api/server.js +2022 -12484
  290. package/packages/agent/src/api/skill-discovery-helpers.d.ts +80 -0
  291. package/packages/agent/src/api/skill-discovery-helpers.d.ts.map +1 -0
  292. package/packages/agent/src/api/skill-discovery-helpers.js +385 -0
  293. package/packages/agent/src/api/skills-routes.d.ts +32 -0
  294. package/packages/agent/src/api/skills-routes.d.ts.map +1 -0
  295. package/packages/agent/src/api/skills-routes.js +978 -0
  296. package/packages/agent/src/api/static-file-server.d.ts +19 -0
  297. package/packages/agent/src/api/static-file-server.d.ts.map +1 -0
  298. package/packages/agent/src/api/static-file-server.js +234 -0
  299. package/packages/agent/src/api/subscription-routes.d.ts +6 -6
  300. package/packages/agent/src/api/subscription-routes.d.ts.map +1 -1
  301. package/packages/agent/src/api/subscription-routes.js +84 -14
  302. package/packages/agent/src/api/task-agent-message-routing.d.ts +10 -0
  303. package/packages/agent/src/api/task-agent-message-routing.d.ts.map +1 -0
  304. package/packages/agent/src/api/task-agent-message-routing.js +62 -0
  305. package/packages/agent/src/api/terminal-execution-routing.d.ts +14 -0
  306. package/packages/agent/src/api/terminal-execution-routing.d.ts.map +1 -0
  307. package/packages/agent/src/api/terminal-execution-routing.js +23 -0
  308. package/packages/agent/src/api/terminal-run-limits.d.ts.map +1 -1
  309. package/packages/agent/src/api/terminal-run-limits.js +3 -5
  310. package/packages/agent/src/api/trade-safety.d.ts +35 -0
  311. package/packages/agent/src/api/trade-safety.d.ts.map +1 -0
  312. package/packages/agent/src/api/trade-safety.js +62 -0
  313. package/packages/agent/src/api/training-service-like.d.ts +3 -2
  314. package/packages/agent/src/api/training-service-like.d.ts.map +1 -1
  315. package/packages/agent/src/api/travel-provider-relay-routes.d.ts +9 -0
  316. package/packages/agent/src/api/travel-provider-relay-routes.d.ts.map +1 -0
  317. package/packages/agent/src/api/travel-provider-relay-routes.js +143 -0
  318. package/packages/agent/src/api/tx-service.d.ts +6 -0
  319. package/packages/agent/src/api/tx-service.d.ts.map +1 -1
  320. package/packages/agent/src/api/tx-service.js +64 -3
  321. package/packages/agent/src/api/update-routes.d.ts +19 -0
  322. package/packages/agent/src/api/update-routes.d.ts.map +1 -0
  323. package/packages/agent/src/api/update-routes.js +54 -0
  324. package/packages/agent/src/api/wallet-capability.d.ts +33 -0
  325. package/packages/agent/src/api/wallet-capability.d.ts.map +1 -0
  326. package/packages/agent/src/api/wallet-capability.js +193 -0
  327. package/packages/agent/src/api/wallet-dex-prices.d.ts +0 -18
  328. package/packages/agent/src/api/wallet-dex-prices.d.ts.map +1 -1
  329. package/packages/agent/src/api/wallet-dex-prices.js +14 -38
  330. package/packages/agent/src/api/wallet-env-sync.d.ts +2 -0
  331. package/packages/agent/src/api/wallet-env-sync.d.ts.map +1 -0
  332. package/packages/agent/src/api/wallet-env-sync.js +108 -0
  333. package/packages/agent/src/api/wallet-evm-balance.d.ts +8 -1
  334. package/packages/agent/src/api/wallet-evm-balance.d.ts.map +1 -1
  335. package/packages/agent/src/api/wallet-evm-balance.js +5 -5
  336. package/packages/agent/src/api/wallet-routes.d.ts +20 -12
  337. package/packages/agent/src/api/wallet-routes.d.ts.map +1 -1
  338. package/packages/agent/src/api/wallet-routes.js +593 -37
  339. package/packages/agent/src/api/wallet-rpc.d.ts +14 -11
  340. package/packages/agent/src/api/wallet-rpc.d.ts.map +1 -1
  341. package/packages/agent/src/api/wallet-rpc.js +108 -38
  342. package/packages/agent/src/api/wallet-trading-profile.d.ts +2 -22
  343. package/packages/agent/src/api/wallet-trading-profile.d.ts.map +1 -1
  344. package/packages/agent/src/api/wallet-trading-profile.js +27 -30
  345. package/packages/agent/src/api/wallet.d.ts +38 -5
  346. package/packages/agent/src/api/wallet.d.ts.map +1 -1
  347. package/packages/agent/src/api/wallet.js +469 -202
  348. package/packages/agent/src/api/workbench-helpers.d.ts +39 -0
  349. package/packages/agent/src/api/workbench-helpers.d.ts.map +1 -0
  350. package/packages/agent/src/api/workbench-helpers.js +137 -0
  351. package/packages/agent/src/api/workbench-routes.d.ts +43 -0
  352. package/packages/agent/src/api/workbench-routes.d.ts.map +1 -0
  353. package/packages/agent/src/api/workbench-routes.js +265 -0
  354. package/packages/agent/src/api/x-relay-routes.d.ts +27 -0
  355. package/packages/agent/src/api/x-relay-routes.d.ts.map +1 -0
  356. package/packages/agent/src/api/x-relay-routes.js +134 -0
  357. package/packages/agent/src/auth/account-storage.d.ts +48 -0
  358. package/packages/agent/src/auth/account-storage.d.ts.map +1 -0
  359. package/packages/agent/src/auth/account-storage.js +229 -0
  360. package/packages/agent/src/auth/anthropic.d.ts +3 -4
  361. package/packages/agent/src/auth/anthropic.d.ts.map +1 -1
  362. package/packages/agent/src/auth/anthropic.js +5 -7
  363. package/packages/agent/src/auth/claude-code-stealth-preload.d.ts +2 -0
  364. package/packages/agent/src/auth/claude-code-stealth-preload.d.ts.map +1 -0
  365. package/packages/agent/src/auth/claude-code-stealth-preload.js +2 -0
  366. package/packages/agent/src/auth/claude-code-stealth.d.ts.map +1 -1
  367. package/packages/agent/src/auth/claude-code-stealth.js +21 -9
  368. package/packages/agent/src/auth/credentials.d.ts +62 -17
  369. package/packages/agent/src/auth/credentials.d.ts.map +1 -1
  370. package/packages/agent/src/auth/credentials.js +492 -121
  371. package/packages/agent/src/auth/index.d.ts +7 -6
  372. package/packages/agent/src/auth/index.d.ts.map +1 -1
  373. package/packages/agent/src/auth/index.js +7 -3
  374. package/packages/agent/src/auth/oauth-flow.d.ts +106 -0
  375. package/packages/agent/src/auth/oauth-flow.d.ts.map +1 -0
  376. package/packages/agent/src/auth/oauth-flow.js +349 -0
  377. package/packages/agent/src/auth/openai-codex.d.ts +2 -2
  378. package/packages/agent/src/auth/openai-codex.d.ts.map +1 -1
  379. package/packages/agent/src/auth/openai-codex.js +17 -13
  380. package/packages/agent/src/auth/refresh-mutex.d.ts +19 -0
  381. package/packages/agent/src/auth/refresh-mutex.d.ts.map +1 -0
  382. package/packages/agent/src/auth/refresh-mutex.js +33 -0
  383. package/packages/agent/src/auth/types.d.ts +42 -2
  384. package/packages/agent/src/auth/types.d.ts.map +1 -1
  385. package/packages/agent/src/auth/types.js +142 -1
  386. package/packages/agent/src/auth/vendor/pi-oauth/anthropic-login.d.ts +48 -0
  387. package/packages/agent/src/auth/vendor/pi-oauth/anthropic-login.d.ts.map +1 -0
  388. package/packages/agent/src/auth/vendor/pi-oauth/anthropic-login.js +113 -0
  389. package/packages/agent/src/auth/vendor/pi-oauth/openai-codex-login.d.ts +26 -0
  390. package/packages/agent/src/auth/vendor/pi-oauth/openai-codex-login.d.ts.map +1 -0
  391. package/packages/agent/src/auth/vendor/pi-oauth/openai-codex-login.js +343 -0
  392. package/packages/agent/src/auth/vendor/pi-oauth/pkce.d.ts +9 -0
  393. package/packages/agent/src/auth/vendor/pi-oauth/pkce.d.ts.map +1 -0
  394. package/packages/agent/src/auth/vendor/pi-oauth/pkce.js +21 -0
  395. package/packages/agent/src/autonomy/index.d.ts +48 -0
  396. package/packages/agent/src/autonomy/index.d.ts.map +1 -0
  397. package/packages/agent/src/autonomy/index.js +344 -0
  398. package/packages/agent/src/awareness/index.d.ts +2 -0
  399. package/packages/agent/src/awareness/index.d.ts.map +1 -0
  400. package/packages/agent/src/awareness/index.js +1 -0
  401. package/packages/agent/src/awareness/registry.d.ts +1 -26
  402. package/packages/agent/src/awareness/registry.d.ts.map +1 -1
  403. package/packages/agent/src/awareness/registry.js +1 -161
  404. package/packages/agent/src/bin.js +46 -1
  405. package/packages/agent/src/cli/benchmark.d.ts +10 -0
  406. package/packages/agent/src/cli/benchmark.d.ts.map +1 -0
  407. package/packages/agent/src/cli/benchmark.js +293 -0
  408. package/packages/agent/src/cli/index.d.ts.map +1 -1
  409. package/packages/agent/src/cli/index.js +58 -4
  410. package/packages/agent/src/config/config.d.ts +2 -2
  411. package/packages/agent/src/config/config.d.ts.map +1 -1
  412. package/packages/agent/src/config/config.js +185 -18
  413. package/packages/agent/src/config/env-vars.d.ts +7 -1
  414. package/packages/agent/src/config/env-vars.d.ts.map +1 -1
  415. package/packages/agent/src/config/env-vars.js +205 -0
  416. package/packages/agent/src/config/feature-flags.d.ts +17 -0
  417. package/packages/agent/src/config/feature-flags.d.ts.map +1 -0
  418. package/packages/agent/src/config/feature-flags.js +37 -0
  419. package/packages/agent/src/config/includes.d.ts.map +1 -1
  420. package/packages/agent/src/config/includes.js +6 -5
  421. package/packages/agent/src/config/index.d.ts +10 -15
  422. package/packages/agent/src/config/index.d.ts.map +1 -1
  423. package/packages/agent/src/config/index.js +9 -15
  424. package/packages/agent/src/config/model-metadata.d.ts +20 -0
  425. package/packages/agent/src/config/model-metadata.d.ts.map +1 -0
  426. package/packages/agent/src/config/model-metadata.js +133 -0
  427. package/packages/agent/src/config/owner-contacts.d.ts +42 -0
  428. package/packages/agent/src/config/owner-contacts.d.ts.map +1 -0
  429. package/packages/agent/src/config/owner-contacts.js +238 -0
  430. package/packages/agent/src/config/paths.d.ts +10 -6
  431. package/packages/agent/src/config/paths.d.ts.map +1 -1
  432. package/packages/agent/src/config/paths.js +43 -45
  433. package/packages/agent/src/config/plugin-auto-enable.d.ts +12 -15
  434. package/packages/agent/src/config/plugin-auto-enable.d.ts.map +1 -1
  435. package/packages/agent/src/config/plugin-auto-enable.js +12 -384
  436. package/packages/agent/src/config/plugin-widgets.d.ts +29 -0
  437. package/packages/agent/src/config/plugin-widgets.d.ts.map +1 -0
  438. package/packages/agent/src/config/plugin-widgets.js +104 -0
  439. package/packages/agent/src/config/schema.d.ts +2 -2
  440. package/packages/agent/src/config/schema.d.ts.map +1 -1
  441. package/packages/agent/src/config/schema.js +24 -24
  442. package/packages/agent/src/config/types.agent-defaults.d.ts +1 -330
  443. package/packages/agent/src/config/types.agent-defaults.d.ts.map +1 -1
  444. package/packages/agent/src/config/types.agent-defaults.js +1 -1
  445. package/packages/agent/src/config/types.agents.d.ts +1 -109
  446. package/packages/agent/src/config/types.agents.d.ts.map +1 -1
  447. package/packages/agent/src/config/types.agents.js +1 -1
  448. package/packages/agent/src/config/types.d.ts +1 -7
  449. package/packages/agent/src/config/types.d.ts.map +1 -1
  450. package/packages/agent/src/config/types.eliza.d.ts +1 -635
  451. package/packages/agent/src/config/types.eliza.d.ts.map +1 -1
  452. package/packages/agent/src/config/types.eliza.js +1 -1
  453. package/packages/agent/src/config/types.gateway.d.ts +1 -215
  454. package/packages/agent/src/config/types.gateway.d.ts.map +1 -1
  455. package/packages/agent/src/config/types.gateway.js +1 -1
  456. package/packages/agent/src/config/types.hooks.d.ts +1 -106
  457. package/packages/agent/src/config/types.hooks.d.ts.map +1 -1
  458. package/packages/agent/src/config/types.hooks.js +1 -1
  459. package/packages/agent/src/config/types.js +1 -7
  460. package/packages/agent/src/config/types.messages.d.ts +1 -175
  461. package/packages/agent/src/config/types.messages.d.ts.map +1 -1
  462. package/packages/agent/src/config/types.messages.js +1 -1
  463. package/packages/agent/src/config/types.tools.d.ts +1 -399
  464. package/packages/agent/src/config/types.tools.d.ts.map +1 -1
  465. package/packages/agent/src/config/types.tools.js +1 -1
  466. package/packages/agent/src/config/zod-schema.agent-runtime.d.ts +111 -9
  467. package/packages/agent/src/config/zod-schema.agent-runtime.d.ts.map +1 -1
  468. package/packages/agent/src/config/zod-schema.agent-runtime.js +89 -2
  469. package/packages/agent/src/config/zod-schema.core.d.ts +308 -50
  470. package/packages/agent/src/config/zod-schema.core.d.ts.map +1 -1
  471. package/packages/agent/src/config/zod-schema.core.js +81 -14
  472. package/packages/agent/src/config/zod-schema.d.ts +500 -1913
  473. package/packages/agent/src/config/zod-schema.d.ts.map +1 -1
  474. package/packages/agent/src/config/zod-schema.js +84 -16
  475. package/packages/agent/src/config/zod-schema.providers-core.d.ts +135 -359
  476. package/packages/agent/src/config/zod-schema.providers-core.d.ts.map +1 -1
  477. package/packages/agent/src/config/zod-schema.providers-core.js +51 -88
  478. package/packages/agent/src/config/zod-schema.session.d.ts +1 -1
  479. package/packages/agent/src/config/zod-schema.session.js +1 -1
  480. package/packages/agent/src/contracts/awareness.d.ts +1 -1
  481. package/packages/agent/src/contracts/index.d.ts +1 -8
  482. package/packages/agent/src/contracts/index.d.ts.map +1 -1
  483. package/packages/agent/src/contracts/index.js +1 -8
  484. package/packages/agent/src/contracts/onboarding-provider-defaults.d.ts +177 -0
  485. package/packages/agent/src/contracts/onboarding-provider-defaults.d.ts.map +1 -0
  486. package/packages/agent/src/contracts/{onboarding.js → onboarding-provider-defaults.js} +21 -109
  487. package/packages/agent/src/diagnostics/index.d.ts +2 -0
  488. package/packages/agent/src/diagnostics/index.d.ts.map +1 -0
  489. package/packages/agent/src/diagnostics/index.js +1 -0
  490. package/packages/agent/src/diagnostics/integration-observability.d.ts +1 -1
  491. package/packages/agent/src/diagnostics/integration-observability.d.ts.map +1 -1
  492. package/packages/agent/src/diagnostics/integration-observability.js +13 -3
  493. package/packages/agent/src/hooks/discovery.d.ts +1 -1
  494. package/packages/agent/src/hooks/discovery.d.ts.map +1 -1
  495. package/packages/agent/src/hooks/discovery.js +10 -3
  496. package/packages/agent/src/hooks/eligibility.d.ts +2 -2
  497. package/packages/agent/src/hooks/eligibility.d.ts.map +1 -1
  498. package/packages/agent/src/hooks/eligibility.js +7 -2
  499. package/packages/agent/src/hooks/index.d.ts +2 -2
  500. package/packages/agent/src/hooks/index.d.ts.map +1 -1
  501. package/packages/agent/src/hooks/index.js +2 -2
  502. package/packages/agent/src/hooks/loader.d.ts +2 -2
  503. package/packages/agent/src/hooks/loader.d.ts.map +1 -1
  504. package/packages/agent/src/hooks/loader.js +50 -12
  505. package/packages/agent/src/hooks/registry.d.ts +1 -1
  506. package/packages/agent/src/hooks/registry.d.ts.map +1 -1
  507. package/packages/agent/src/index.d.ts +72 -19
  508. package/packages/agent/src/index.d.ts.map +1 -1
  509. package/packages/agent/src/index.js +104 -19
  510. package/packages/agent/src/providers/admin-panel.d.ts +4 -0
  511. package/packages/agent/src/providers/admin-panel.d.ts.map +1 -0
  512. package/packages/agent/src/providers/admin-panel.js +89 -0
  513. package/packages/agent/src/providers/admin-trust.d.ts.map +1 -1
  514. package/packages/agent/src/providers/admin-trust.js +20 -33
  515. package/packages/agent/src/providers/automation-terminal-bridge.d.ts +3 -0
  516. package/packages/agent/src/providers/automation-terminal-bridge.d.ts.map +1 -0
  517. package/packages/agent/src/providers/automation-terminal-bridge.js +77 -0
  518. package/packages/agent/src/providers/conversation-proximity.d.ts +3 -0
  519. package/packages/agent/src/providers/conversation-proximity.d.ts.map +1 -0
  520. package/packages/agent/src/providers/conversation-proximity.js +62 -0
  521. package/packages/agent/src/providers/escalation-trigger.d.ts +15 -0
  522. package/packages/agent/src/providers/escalation-trigger.d.ts.map +1 -0
  523. package/packages/agent/src/providers/escalation-trigger.js +171 -0
  524. package/packages/agent/src/providers/index.d.ts +19 -0
  525. package/packages/agent/src/providers/index.d.ts.map +1 -0
  526. package/packages/agent/src/providers/index.js +18 -0
  527. package/packages/agent/src/providers/local-models.d.ts +118 -0
  528. package/packages/agent/src/providers/local-models.d.ts.map +1 -0
  529. package/packages/agent/src/providers/local-models.js +418 -0
  530. package/packages/agent/src/providers/media-provider.d.ts +233 -0
  531. package/packages/agent/src/providers/media-provider.d.ts.map +1 -0
  532. package/packages/agent/src/providers/media-provider.js +1474 -0
  533. package/packages/agent/src/providers/page-scoped-context.d.ts +3 -0
  534. package/packages/agent/src/providers/page-scoped-context.d.ts.map +1 -0
  535. package/packages/agent/src/providers/page-scoped-context.js +551 -0
  536. package/packages/agent/src/providers/pending-permissions-provider.d.ts +19 -0
  537. package/packages/agent/src/providers/pending-permissions-provider.d.ts.map +1 -0
  538. package/packages/agent/src/providers/pending-permissions-provider.js +104 -0
  539. package/packages/agent/src/providers/recent-conversations.d.ts +3 -0
  540. package/packages/agent/src/providers/recent-conversations.d.ts.map +1 -0
  541. package/packages/agent/src/providers/recent-conversations.js +100 -0
  542. package/packages/agent/src/providers/relevant-conversations.d.ts +3 -0
  543. package/packages/agent/src/providers/relevant-conversations.d.ts.map +1 -0
  544. package/packages/agent/src/providers/relevant-conversations.js +99 -0
  545. package/packages/agent/src/providers/role-backfill.d.ts +18 -0
  546. package/packages/agent/src/providers/role-backfill.d.ts.map +1 -0
  547. package/packages/agent/src/providers/role-backfill.js +86 -0
  548. package/packages/agent/src/providers/rolodex.d.ts +3 -0
  549. package/packages/agent/src/providers/rolodex.d.ts.map +1 -0
  550. package/packages/agent/src/providers/rolodex.js +83 -0
  551. package/packages/agent/src/providers/self-status.d.ts +4 -0
  552. package/packages/agent/src/providers/self-status.d.ts.map +1 -0
  553. package/packages/agent/src/providers/self-status.js +22 -0
  554. package/packages/agent/src/providers/session-bridge.d.ts.map +1 -1
  555. package/packages/agent/src/providers/session-bridge.js +6 -1
  556. package/packages/agent/src/providers/session-utils.d.ts +1 -1
  557. package/packages/agent/src/providers/session-utils.d.ts.map +1 -1
  558. package/packages/agent/src/providers/session-utils.js +2 -3
  559. package/packages/agent/src/providers/simple-mode.d.ts.map +1 -1
  560. package/packages/agent/src/providers/simple-mode.js +18 -54
  561. package/packages/agent/src/providers/skill-provider.d.ts +16 -0
  562. package/packages/agent/src/providers/skill-provider.d.ts.map +1 -0
  563. package/packages/agent/src/providers/skill-provider.js +353 -0
  564. package/packages/agent/src/providers/tasks.d.ts +9 -0
  565. package/packages/agent/src/providers/tasks.d.ts.map +1 -0
  566. package/packages/agent/src/providers/tasks.js +118 -0
  567. package/packages/agent/src/providers/ui-catalog.d.ts.map +1 -1
  568. package/packages/agent/src/providers/ui-catalog.js +15 -38
  569. package/packages/agent/src/providers/user-name.d.ts +11 -0
  570. package/packages/agent/src/providers/user-name.d.ts.map +1 -0
  571. package/packages/agent/src/providers/user-name.js +46 -0
  572. package/packages/agent/src/providers/workspace-provider.d.ts +3 -11
  573. package/packages/agent/src/providers/workspace-provider.d.ts.map +1 -1
  574. package/packages/agent/src/providers/workspace-provider.js +27 -11
  575. package/packages/agent/src/providers/workspace.d.ts +2 -3
  576. package/packages/agent/src/providers/workspace.d.ts.map +1 -1
  577. package/packages/agent/src/providers/workspace.js +81 -68
  578. package/packages/agent/src/runtime/advanced-capabilities-config.d.ts +8 -0
  579. package/packages/agent/src/runtime/advanced-capabilities-config.d.ts.map +1 -0
  580. package/packages/agent/src/runtime/advanced-capabilities-config.js +41 -0
  581. package/packages/agent/src/runtime/agent-wallets.d.ts +138 -0
  582. package/packages/agent/src/runtime/agent-wallets.d.ts.map +1 -0
  583. package/packages/agent/src/runtime/agent-wallets.js +308 -0
  584. package/packages/agent/src/runtime/analysis-mode-flag.d.ts +93 -0
  585. package/packages/agent/src/runtime/analysis-mode-flag.d.ts.map +1 -0
  586. package/packages/agent/src/runtime/analysis-mode-flag.js +131 -0
  587. package/packages/agent/src/runtime/android-app-plugins.d.ts +13 -0
  588. package/packages/agent/src/runtime/android-app-plugins.d.ts.map +1 -0
  589. package/packages/agent/src/runtime/android-app-plugins.js +48 -0
  590. package/packages/agent/src/runtime/aosp-dflash-adapter.d.ts +99 -0
  591. package/packages/agent/src/runtime/aosp-dflash-adapter.d.ts.map +1 -0
  592. package/packages/agent/src/runtime/aosp-dflash-adapter.js +332 -0
  593. package/packages/agent/src/runtime/build-character-config.d.ts +2 -0
  594. package/packages/agent/src/runtime/build-character-config.d.ts.map +1 -0
  595. package/packages/agent/src/runtime/build-character-config.js +176 -0
  596. package/packages/agent/src/runtime/conversation-compactor-runtime.d.ts +141 -0
  597. package/packages/agent/src/runtime/conversation-compactor-runtime.d.ts.map +1 -0
  598. package/packages/agent/src/runtime/conversation-compactor-runtime.js +460 -0
  599. package/packages/agent/src/runtime/conversation-compactor.d.ts +38 -0
  600. package/packages/agent/src/runtime/conversation-compactor.d.ts.map +1 -0
  601. package/packages/agent/src/runtime/conversation-compactor.js +1121 -0
  602. package/packages/agent/src/runtime/conversation-compactor.types.d.ts +102 -0
  603. package/packages/agent/src/runtime/conversation-compactor.types.d.ts.map +1 -0
  604. package/packages/agent/src/runtime/conversation-compactor.types.js +30 -0
  605. package/packages/agent/src/runtime/core-plugins.d.ts +50 -0
  606. package/packages/agent/src/runtime/core-plugins.d.ts.map +1 -1
  607. package/packages/agent/src/runtime/core-plugins.js +85 -16
  608. package/packages/agent/src/runtime/custom-actions.d.ts +5 -2
  609. package/packages/agent/src/runtime/custom-actions.d.ts.map +1 -1
  610. package/packages/agent/src/runtime/custom-actions.js +93 -14
  611. package/packages/agent/src/runtime/default-documents.d.ts +21 -0
  612. package/packages/agent/src/runtime/default-documents.d.ts.map +1 -0
  613. package/packages/agent/src/runtime/default-documents.js +283 -0
  614. package/packages/agent/src/runtime/eliza-plugin.d.ts +1 -1
  615. package/packages/agent/src/runtime/eliza-plugin.d.ts.map +1 -1
  616. package/packages/agent/src/runtime/eliza-plugin.js +142 -67
  617. package/packages/agent/src/runtime/eliza.d.ts +23 -119
  618. package/packages/agent/src/runtime/eliza.d.ts.map +1 -1
  619. package/packages/agent/src/runtime/eliza.js +1512 -2085
  620. package/packages/agent/src/runtime/embedding-presets.d.ts.map +1 -1
  621. package/packages/agent/src/runtime/embedding-presets.js +27 -20
  622. package/packages/agent/src/runtime/first-time-setup.d.ts +47 -0
  623. package/packages/agent/src/runtime/first-time-setup.d.ts.map +1 -0
  624. package/packages/agent/src/runtime/first-time-setup.js +704 -0
  625. package/packages/agent/src/runtime/index.d.ts +19 -8
  626. package/packages/agent/src/runtime/index.d.ts.map +1 -1
  627. package/packages/agent/src/runtime/index.js +19 -8
  628. package/packages/agent/src/runtime/load-plugin-from-vfs.d.ts +54 -0
  629. package/packages/agent/src/runtime/load-plugin-from-vfs.d.ts.map +1 -0
  630. package/packages/agent/src/runtime/load-plugin-from-vfs.js +86 -0
  631. package/packages/agent/src/runtime/local-execution-mode.d.ts +11 -0
  632. package/packages/agent/src/runtime/local-execution-mode.d.ts.map +1 -0
  633. package/packages/agent/src/runtime/local-execution-mode.js +10 -0
  634. package/packages/agent/src/runtime/model-resolution.d.ts +2 -0
  635. package/packages/agent/src/runtime/model-resolution.d.ts.map +1 -0
  636. package/packages/agent/src/runtime/model-resolution.js +55 -0
  637. package/packages/agent/src/runtime/native-runtime-features.d.ts +4 -0
  638. package/packages/agent/src/runtime/native-runtime-features.d.ts.map +1 -0
  639. package/packages/agent/src/runtime/native-runtime-features.js +10 -0
  640. package/packages/agent/src/runtime/onboarding-names.d.ts +3 -3
  641. package/packages/agent/src/runtime/onboarding-names.d.ts.map +1 -1
  642. package/packages/agent/src/runtime/onboarding-names.js +14 -7
  643. package/packages/agent/src/runtime/operations/classifier.d.ts +36 -0
  644. package/packages/agent/src/runtime/operations/classifier.d.ts.map +1 -0
  645. package/packages/agent/src/runtime/operations/classifier.js +72 -0
  646. package/packages/agent/src/runtime/operations/cold-strategy.d.ts +19 -0
  647. package/packages/agent/src/runtime/operations/cold-strategy.d.ts.map +1 -0
  648. package/packages/agent/src/runtime/operations/cold-strategy.js +50 -0
  649. package/packages/agent/src/runtime/operations/health-checks.d.ts +25 -0
  650. package/packages/agent/src/runtime/operations/health-checks.d.ts.map +1 -0
  651. package/packages/agent/src/runtime/operations/health-checks.js +186 -0
  652. package/packages/agent/src/runtime/operations/health.d.ts +32 -0
  653. package/packages/agent/src/runtime/operations/health.d.ts.map +1 -0
  654. package/packages/agent/src/runtime/operations/health.js +139 -0
  655. package/packages/agent/src/runtime/operations/index.d.ts +17 -0
  656. package/packages/agent/src/runtime/operations/index.d.ts.map +1 -0
  657. package/packages/agent/src/runtime/operations/index.js +15 -0
  658. package/packages/agent/src/runtime/operations/manager.d.ts +70 -0
  659. package/packages/agent/src/runtime/operations/manager.d.ts.map +1 -0
  660. package/packages/agent/src/runtime/operations/manager.js +202 -0
  661. package/packages/agent/src/runtime/operations/reload-hot.d.ts +43 -0
  662. package/packages/agent/src/runtime/operations/reload-hot.d.ts.map +1 -0
  663. package/packages/agent/src/runtime/operations/reload-hot.js +181 -0
  664. package/packages/agent/src/runtime/operations/repository.d.ts +66 -0
  665. package/packages/agent/src/runtime/operations/repository.d.ts.map +1 -0
  666. package/packages/agent/src/runtime/operations/repository.js +319 -0
  667. package/packages/agent/src/runtime/operations/types.d.ts +203 -0
  668. package/packages/agent/src/runtime/operations/types.d.ts.map +1 -0
  669. package/packages/agent/src/runtime/operations/types.js +18 -0
  670. package/packages/agent/src/runtime/operations/vault-bridge.d.ts +81 -0
  671. package/packages/agent/src/runtime/operations/vault-bridge.d.ts.map +1 -0
  672. package/packages/agent/src/runtime/operations/vault-bridge.js +133 -0
  673. package/packages/agent/src/runtime/owner-entity.d.ts +4 -0
  674. package/packages/agent/src/runtime/owner-entity.d.ts.map +1 -0
  675. package/packages/agent/src/runtime/owner-entity.js +30 -0
  676. package/packages/agent/src/runtime/pglite-error-compat.d.ts +28 -0
  677. package/packages/agent/src/runtime/pglite-error-compat.d.ts.map +1 -0
  678. package/packages/agent/src/runtime/pglite-error-compat.js +54 -0
  679. package/packages/agent/src/runtime/plugin-collector.d.ts +22 -0
  680. package/packages/agent/src/runtime/plugin-collector.d.ts.map +1 -0
  681. package/packages/agent/src/runtime/plugin-collector.js +503 -0
  682. package/packages/agent/src/runtime/plugin-lifecycle.d.ts +45 -0
  683. package/packages/agent/src/runtime/plugin-lifecycle.d.ts.map +1 -0
  684. package/packages/agent/src/runtime/plugin-lifecycle.js +602 -0
  685. package/packages/agent/src/runtime/plugin-resolver.d.ts +46 -0
  686. package/packages/agent/src/runtime/plugin-resolver.d.ts.map +1 -0
  687. package/packages/agent/src/runtime/plugin-resolver.js +1375 -0
  688. package/packages/agent/src/runtime/plugin-role-gating.d.ts +24 -0
  689. package/packages/agent/src/runtime/plugin-role-gating.d.ts.map +1 -0
  690. package/packages/agent/src/runtime/plugin-role-gating.js +106 -0
  691. package/packages/agent/src/runtime/plugin-types.d.ts +64 -0
  692. package/packages/agent/src/runtime/plugin-types.d.ts.map +1 -0
  693. package/packages/agent/src/runtime/plugin-types.js +306 -0
  694. package/packages/agent/src/runtime/prompt-compaction.d.ts +98 -0
  695. package/packages/agent/src/runtime/prompt-compaction.d.ts.map +1 -0
  696. package/packages/agent/src/runtime/prompt-compaction.js +362 -0
  697. package/packages/agent/src/runtime/prompt-optimization.d.ts +47 -0
  698. package/packages/agent/src/runtime/prompt-optimization.d.ts.map +1 -0
  699. package/packages/agent/src/runtime/prompt-optimization.js +1123 -0
  700. package/packages/agent/src/runtime/release-plugin-policy.d.ts.map +1 -1
  701. package/packages/agent/src/runtime/release-plugin-policy.js +2 -4
  702. package/packages/agent/src/runtime/restart.d.ts +5 -41
  703. package/packages/agent/src/runtime/restart.d.ts.map +1 -1
  704. package/packages/agent/src/runtime/restart.js +5 -42
  705. package/packages/agent/src/runtime/roles/src/index.d.ts +24 -0
  706. package/packages/agent/src/runtime/roles/src/index.d.ts.map +1 -0
  707. package/packages/agent/src/runtime/roles/src/index.js +255 -0
  708. package/packages/agent/src/runtime/roles/src/provider.d.ts +7 -0
  709. package/packages/agent/src/runtime/roles/src/provider.d.ts.map +1 -0
  710. package/packages/agent/src/runtime/roles/src/provider.js +138 -0
  711. package/packages/agent/src/runtime/roles/src/types.d.ts +3 -0
  712. package/packages/agent/src/runtime/roles/src/types.d.ts.map +1 -0
  713. package/packages/agent/src/runtime/roles/src/types.js +1 -0
  714. package/packages/agent/src/runtime/roles/src/utils.d.ts +2 -0
  715. package/packages/agent/src/runtime/roles/src/utils.d.ts.map +1 -0
  716. package/packages/agent/src/runtime/roles/src/utils.js +1 -0
  717. package/packages/agent/src/runtime/roles.d.ts +3 -0
  718. package/packages/agent/src/runtime/roles.d.ts.map +1 -0
  719. package/packages/agent/src/runtime/roles.js +5 -0
  720. package/packages/agent/src/runtime/subagent-output.d.ts +51 -0
  721. package/packages/agent/src/runtime/subagent-output.d.ts.map +1 -0
  722. package/packages/agent/src/runtime/subagent-output.js +173 -0
  723. package/packages/agent/src/runtime/task-heartbeat.d.ts +22 -0
  724. package/packages/agent/src/runtime/task-heartbeat.d.ts.map +1 -0
  725. package/packages/agent/src/runtime/task-heartbeat.js +84 -0
  726. package/packages/agent/src/runtime/tool-call-cache/cache.d.ts +62 -0
  727. package/packages/agent/src/runtime/tool-call-cache/cache.d.ts.map +1 -0
  728. package/packages/agent/src/runtime/tool-call-cache/cache.js +123 -0
  729. package/packages/agent/src/runtime/tool-call-cache/disk-store.d.ts +23 -0
  730. package/packages/agent/src/runtime/tool-call-cache/disk-store.d.ts.map +1 -0
  731. package/packages/agent/src/runtime/tool-call-cache/disk-store.js +55 -0
  732. package/packages/agent/src/runtime/tool-call-cache/index.d.ts +7 -0
  733. package/packages/agent/src/runtime/tool-call-cache/index.d.ts.map +1 -0
  734. package/packages/agent/src/runtime/tool-call-cache/index.js +4 -0
  735. package/packages/agent/src/runtime/tool-call-cache/key.d.ts +11 -0
  736. package/packages/agent/src/runtime/tool-call-cache/key.d.ts.map +1 -0
  737. package/packages/agent/src/runtime/tool-call-cache/key.js +31 -0
  738. package/packages/agent/src/runtime/tool-call-cache/lru.d.ts +17 -0
  739. package/packages/agent/src/runtime/tool-call-cache/lru.d.ts.map +1 -0
  740. package/packages/agent/src/runtime/tool-call-cache/lru.js +46 -0
  741. package/packages/agent/src/runtime/tool-call-cache/redact.d.ts +17 -0
  742. package/packages/agent/src/runtime/tool-call-cache/redact.d.ts.map +1 -0
  743. package/packages/agent/src/runtime/tool-call-cache/redact.js +77 -0
  744. package/packages/agent/src/runtime/tool-call-cache/registry.d.ts +18 -0
  745. package/packages/agent/src/runtime/tool-call-cache/registry.d.ts.map +1 -0
  746. package/packages/agent/src/runtime/tool-call-cache/registry.js +66 -0
  747. package/packages/agent/src/runtime/tool-call-cache/types.d.ts +50 -0
  748. package/packages/agent/src/runtime/tool-call-cache/types.d.ts.map +1 -0
  749. package/packages/agent/src/runtime/tool-call-cache/types.js +10 -0
  750. package/packages/agent/src/runtime/tool-call-cache-wrapper.d.ts +39 -0
  751. package/packages/agent/src/runtime/tool-call-cache-wrapper.d.ts.map +1 -0
  752. package/packages/agent/src/runtime/tool-call-cache-wrapper.js +72 -0
  753. package/packages/agent/src/runtime/trajectory-export.d.ts +18 -0
  754. package/packages/agent/src/runtime/trajectory-export.d.ts.map +1 -0
  755. package/packages/agent/src/runtime/trajectory-export.js +109 -0
  756. package/packages/agent/src/runtime/trajectory-internals.d.ts +242 -0
  757. package/packages/agent/src/runtime/trajectory-internals.d.ts.map +1 -0
  758. package/packages/agent/src/runtime/trajectory-internals.js +1281 -0
  759. package/packages/agent/src/runtime/trajectory-persistence.d.ts +13 -212
  760. package/packages/agent/src/runtime/trajectory-persistence.d.ts.map +1 -1
  761. package/packages/agent/src/runtime/trajectory-persistence.js +25 -1952
  762. package/packages/agent/src/runtime/trajectory-query.d.ts +8 -0
  763. package/packages/agent/src/runtime/trajectory-query.d.ts.map +1 -0
  764. package/packages/agent/src/runtime/trajectory-query.js +27 -0
  765. package/packages/agent/src/runtime/trajectory-storage.d.ts +91 -0
  766. package/packages/agent/src/runtime/trajectory-storage.d.ts.map +1 -0
  767. package/packages/agent/src/runtime/trajectory-storage.js +1093 -0
  768. package/packages/agent/src/runtime/vault-profile-resolver.d.ts +37 -0
  769. package/packages/agent/src/runtime/vault-profile-resolver.d.ts.map +1 -0
  770. package/packages/agent/src/runtime/vault-profile-resolver.js +79 -0
  771. package/packages/agent/src/runtime/version.js +1 -1
  772. package/packages/agent/src/runtime/web-search-tools.d.ts +22 -0
  773. package/packages/agent/src/runtime/web-search-tools.d.ts.map +1 -0
  774. package/packages/agent/src/runtime/web-search-tools.js +151 -0
  775. package/packages/agent/src/security/access.d.ts +17 -0
  776. package/packages/agent/src/security/access.d.ts.map +1 -0
  777. package/packages/agent/src/security/access.js +54 -0
  778. package/packages/agent/src/security/audit-log.d.ts +0 -2
  779. package/packages/agent/src/security/audit-log.d.ts.map +1 -1
  780. package/packages/agent/src/security/index.d.ts +4 -0
  781. package/packages/agent/src/security/index.d.ts.map +1 -0
  782. package/packages/agent/src/security/index.js +3 -0
  783. package/packages/agent/src/services/agent-export.d.ts.map +1 -1
  784. package/packages/agent/src/services/agent-export.js +58 -23
  785. package/packages/agent/src/services/app-manager-agents-list-guard.d.ts +4 -0
  786. package/packages/agent/src/services/app-manager-agents-list-guard.d.ts.map +1 -0
  787. package/packages/agent/src/services/app-manager-agents-list-guard.js +15 -0
  788. package/packages/agent/src/services/app-manager.d.ts +78 -4
  789. package/packages/agent/src/services/app-manager.d.ts.map +1 -1
  790. package/packages/agent/src/services/app-manager.js +1429 -176
  791. package/packages/agent/src/services/app-package-modules.d.ts +22 -0
  792. package/packages/agent/src/services/app-package-modules.d.ts.map +1 -0
  793. package/packages/agent/src/services/app-package-modules.js +397 -0
  794. package/packages/agent/src/services/app-run-store.d.ts +6 -0
  795. package/packages/agent/src/services/app-run-store.d.ts.map +1 -0
  796. package/packages/agent/src/services/app-run-store.js +547 -0
  797. package/packages/agent/src/services/app-session-gate.d.ts +15 -0
  798. package/packages/agent/src/services/app-session-gate.d.ts.map +1 -0
  799. package/packages/agent/src/services/app-session-gate.js +71 -0
  800. package/packages/agent/src/services/capability-broker.d.ts +89 -0
  801. package/packages/agent/src/services/capability-broker.d.ts.map +1 -0
  802. package/packages/agent/src/services/capability-broker.js +339 -0
  803. package/packages/agent/src/services/character-history.d.ts +69 -0
  804. package/packages/agent/src/services/character-history.d.ts.map +1 -0
  805. package/packages/agent/src/services/character-history.js +280 -0
  806. package/packages/agent/src/services/character-persistence.d.ts +25 -0
  807. package/packages/agent/src/services/character-persistence.d.ts.map +1 -0
  808. package/packages/agent/src/services/character-persistence.js +167 -0
  809. package/packages/agent/src/services/client-chat-sender.d.ts +19 -0
  810. package/packages/agent/src/services/client-chat-sender.d.ts.map +1 -0
  811. package/packages/agent/src/services/client-chat-sender.js +88 -0
  812. package/packages/agent/src/services/config-plugin-manager.d.ts +6 -0
  813. package/packages/agent/src/services/config-plugin-manager.d.ts.map +1 -0
  814. package/packages/agent/src/services/config-plugin-manager.js +53 -0
  815. package/packages/agent/src/services/connector-setup-service.d.ts +48 -0
  816. package/packages/agent/src/services/connector-setup-service.d.ts.map +1 -0
  817. package/packages/agent/src/services/connector-setup-service.js +60 -0
  818. package/packages/agent/src/services/escalation.d.ts +35 -0
  819. package/packages/agent/src/services/escalation.d.ts.map +1 -0
  820. package/packages/agent/src/services/escalation.js +376 -0
  821. package/packages/agent/src/services/evm-signing-capability.d.ts +33 -0
  822. package/packages/agent/src/services/evm-signing-capability.d.ts.map +1 -0
  823. package/packages/agent/src/services/evm-signing-capability.js +52 -0
  824. package/packages/agent/src/services/external-bridge-state.d.ts +10 -0
  825. package/packages/agent/src/services/external-bridge-state.d.ts.map +1 -0
  826. package/packages/agent/src/services/external-bridge-state.js +14 -0
  827. package/packages/agent/src/services/hosted-tools.d.ts +70 -0
  828. package/packages/agent/src/services/hosted-tools.d.ts.map +1 -0
  829. package/packages/agent/src/services/hosted-tools.js +87 -0
  830. package/packages/agent/src/services/index.d.ts +26 -17
  831. package/packages/agent/src/services/index.d.ts.map +1 -1
  832. package/packages/agent/src/services/index.js +32 -17
  833. package/packages/agent/src/services/js-runtime-bridge.d.ts +105 -0
  834. package/packages/agent/src/services/js-runtime-bridge.d.ts.map +1 -0
  835. package/packages/agent/src/services/js-runtime-bridge.js +217 -0
  836. package/packages/agent/src/services/mcp-marketplace.js +1 -1
  837. package/packages/agent/src/services/media-generation.d.ts +10 -0
  838. package/packages/agent/src/services/media-generation.d.ts.map +1 -0
  839. package/packages/agent/src/services/media-generation.js +102 -0
  840. package/packages/agent/src/services/overlay-app-presence.d.ts +9 -0
  841. package/packages/agent/src/services/overlay-app-presence.d.ts.map +1 -0
  842. package/packages/agent/src/services/overlay-app-presence.js +18 -0
  843. package/packages/agent/src/services/owner-name.d.ts +4 -0
  844. package/packages/agent/src/services/owner-name.d.ts.map +1 -0
  845. package/packages/agent/src/services/owner-name.js +46 -0
  846. package/packages/agent/src/services/permissions/contracts.d.ts +9 -0
  847. package/packages/agent/src/services/permissions/contracts.d.ts.map +1 -0
  848. package/packages/agent/src/services/permissions/contracts.js +8 -0
  849. package/packages/agent/src/services/permissions/probers/_bridge.d.ts +77 -0
  850. package/packages/agent/src/services/permissions/probers/_bridge.d.ts.map +1 -0
  851. package/packages/agent/src/services/permissions/probers/_bridge.js +224 -0
  852. package/packages/agent/src/services/permissions/probers/accessibility.d.ts +16 -0
  853. package/packages/agent/src/services/permissions/probers/accessibility.d.ts.map +1 -0
  854. package/packages/agent/src/services/permissions/probers/accessibility.js +45 -0
  855. package/packages/agent/src/services/permissions/probers/automation.d.ts +17 -0
  856. package/packages/agent/src/services/permissions/probers/automation.d.ts.map +1 -0
  857. package/packages/agent/src/services/permissions/probers/automation.js +46 -0
  858. package/packages/agent/src/services/permissions/probers/calendar.d.ts +14 -0
  859. package/packages/agent/src/services/permissions/probers/calendar.d.ts.map +1 -0
  860. package/packages/agent/src/services/permissions/probers/calendar.js +33 -0
  861. package/packages/agent/src/services/permissions/probers/camera.d.ts +14 -0
  862. package/packages/agent/src/services/permissions/probers/camera.d.ts.map +1 -0
  863. package/packages/agent/src/services/permissions/probers/camera.js +39 -0
  864. package/packages/agent/src/services/permissions/probers/contacts.d.ts +13 -0
  865. package/packages/agent/src/services/permissions/probers/contacts.d.ts.map +1 -0
  866. package/packages/agent/src/services/permissions/probers/contacts.js +32 -0
  867. package/packages/agent/src/services/permissions/probers/full-disk.d.ts +22 -0
  868. package/packages/agent/src/services/permissions/probers/full-disk.d.ts.map +1 -0
  869. package/packages/agent/src/services/permissions/probers/full-disk.js +78 -0
  870. package/packages/agent/src/services/permissions/probers/health.d.ts +23 -0
  871. package/packages/agent/src/services/permissions/probers/health.d.ts.map +1 -0
  872. package/packages/agent/src/services/permissions/probers/health.js +82 -0
  873. package/packages/agent/src/services/permissions/probers/index.d.ts +27 -0
  874. package/packages/agent/src/services/permissions/probers/index.d.ts.map +1 -0
  875. package/packages/agent/src/services/permissions/probers/index.js +42 -0
  876. package/packages/agent/src/services/permissions/probers/location.d.ts +21 -0
  877. package/packages/agent/src/services/permissions/probers/location.d.ts.map +1 -0
  878. package/packages/agent/src/services/permissions/probers/location.js +47 -0
  879. package/packages/agent/src/services/permissions/probers/microphone.d.ts +14 -0
  880. package/packages/agent/src/services/permissions/probers/microphone.d.ts.map +1 -0
  881. package/packages/agent/src/services/permissions/probers/microphone.js +41 -0
  882. package/packages/agent/src/services/permissions/probers/notes.d.ts +19 -0
  883. package/packages/agent/src/services/permissions/probers/notes.d.ts.map +1 -0
  884. package/packages/agent/src/services/permissions/probers/notes.js +55 -0
  885. package/packages/agent/src/services/permissions/probers/notifications.d.ts +24 -0
  886. package/packages/agent/src/services/permissions/probers/notifications.d.ts.map +1 -0
  887. package/packages/agent/src/services/permissions/probers/notifications.js +47 -0
  888. package/packages/agent/src/services/permissions/probers/reminders.d.ts +22 -0
  889. package/packages/agent/src/services/permissions/probers/reminders.d.ts.map +1 -0
  890. package/packages/agent/src/services/permissions/probers/reminders.js +44 -0
  891. package/packages/agent/src/services/permissions/probers/screen-recording.d.ts +15 -0
  892. package/packages/agent/src/services/permissions/probers/screen-recording.d.ts.map +1 -0
  893. package/packages/agent/src/services/permissions/probers/screen-recording.js +39 -0
  894. package/packages/agent/src/services/permissions/probers/screentime.d.ts +21 -0
  895. package/packages/agent/src/services/permissions/probers/screentime.d.ts.map +1 -0
  896. package/packages/agent/src/services/permissions/probers/screentime.js +67 -0
  897. package/packages/agent/src/services/permissions/probers/shell.d.ts +19 -0
  898. package/packages/agent/src/services/permissions/probers/shell.d.ts.map +1 -0
  899. package/packages/agent/src/services/permissions/probers/shell.js +31 -0
  900. package/packages/agent/src/services/permissions/probers/website-blocking.d.ts +16 -0
  901. package/packages/agent/src/services/permissions/probers/website-blocking.d.ts.map +1 -0
  902. package/packages/agent/src/services/permissions/probers/website-blocking.js +27 -0
  903. package/packages/agent/src/services/permissions/register-probers.d.ts +29 -0
  904. package/packages/agent/src/services/permissions/register-probers.d.ts.map +1 -0
  905. package/packages/agent/src/services/permissions/register-probers.js +31 -0
  906. package/packages/agent/src/services/permissions-registry.d.ts +62 -0
  907. package/packages/agent/src/services/permissions-registry.d.ts.map +1 -0
  908. package/packages/agent/src/services/permissions-registry.js +213 -0
  909. package/packages/agent/src/services/plugin-compiler.d.ts +51 -0
  910. package/packages/agent/src/services/plugin-compiler.d.ts.map +1 -0
  911. package/packages/agent/src/services/plugin-compiler.js +90 -0
  912. package/packages/agent/src/services/plugin-installer.d.ts +93 -0
  913. package/packages/agent/src/services/plugin-installer.d.ts.map +1 -0
  914. package/packages/agent/src/services/plugin-installer.js +623 -0
  915. package/packages/agent/src/services/plugin-manager-types.d.ts +30 -55
  916. package/packages/agent/src/services/plugin-manager-types.d.ts.map +1 -1
  917. package/packages/agent/src/services/registry-client-app-meta.d.ts +1 -1
  918. package/packages/agent/src/services/registry-client-app-meta.d.ts.map +1 -1
  919. package/packages/agent/src/services/registry-client-app-meta.js +53 -32
  920. package/packages/agent/src/services/registry-client-endpoints.d.ts +2 -2
  921. package/packages/agent/src/services/registry-client-endpoints.d.ts.map +1 -1
  922. package/packages/agent/src/services/registry-client-endpoints.js +11 -4
  923. package/packages/agent/src/services/registry-client-local.d.ts +1 -1
  924. package/packages/agent/src/services/registry-client-local.d.ts.map +1 -1
  925. package/packages/agent/src/services/registry-client-local.js +239 -61
  926. package/packages/agent/src/services/registry-client-network.d.ts +6 -1
  927. package/packages/agent/src/services/registry-client-network.d.ts.map +1 -1
  928. package/packages/agent/src/services/registry-client-network.js +43 -5
  929. package/packages/agent/src/services/registry-client-queries.d.ts +16 -5
  930. package/packages/agent/src/services/registry-client-queries.d.ts.map +1 -1
  931. package/packages/agent/src/services/registry-client-queries.js +50 -3
  932. package/packages/agent/src/services/registry-client-types.d.ts +39 -40
  933. package/packages/agent/src/services/registry-client-types.d.ts.map +1 -1
  934. package/packages/agent/src/services/registry-client.d.ts +3 -3
  935. package/packages/agent/src/services/registry-client.d.ts.map +1 -1
  936. package/packages/agent/src/services/registry-client.js +116 -16
  937. package/packages/agent/src/services/relationships-graph.d.ts +13 -0
  938. package/packages/agent/src/services/relationships-graph.d.ts.map +1 -0
  939. package/packages/agent/src/services/relationships-graph.js +38 -0
  940. package/packages/agent/src/services/remote-signing-service.d.ts +2 -2
  941. package/packages/agent/src/services/remote-signing-service.d.ts.map +1 -1
  942. package/packages/agent/src/services/remote-signing-service.js +2 -2
  943. package/packages/agent/src/services/research-task-executor.d.ts +14 -0
  944. package/packages/agent/src/services/research-task-executor.d.ts.map +1 -0
  945. package/packages/agent/src/services/research-task-executor.js +138 -0
  946. package/packages/agent/src/services/sandbox-manager.d.ts +24 -1
  947. package/packages/agent/src/services/sandbox-manager.d.ts.map +1 -1
  948. package/packages/agent/src/services/sandbox-manager.js +174 -109
  949. package/packages/agent/src/services/self-updater.d.ts +1 -1
  950. package/packages/agent/src/services/self-updater.d.ts.map +1 -1
  951. package/packages/agent/src/services/self-updater.js +1 -1
  952. package/packages/agent/src/services/send-handler-availability.d.ts +5 -0
  953. package/packages/agent/src/services/send-handler-availability.d.ts.map +1 -0
  954. package/packages/agent/src/services/send-handler-availability.js +20 -0
  955. package/packages/agent/src/services/shell-execution-router.d.ts +67 -0
  956. package/packages/agent/src/services/shell-execution-router.d.ts.map +1 -0
  957. package/packages/agent/src/services/shell-execution-router.js +201 -0
  958. package/packages/agent/src/services/skill-marketplace.d.ts.map +1 -1
  959. package/packages/agent/src/services/skill-marketplace.js +36 -25
  960. package/packages/agent/src/services/task-executor.d.ts +47 -0
  961. package/packages/agent/src/services/task-executor.d.ts.map +1 -0
  962. package/packages/agent/src/services/task-executor.js +31 -0
  963. package/packages/agent/src/services/update-checker.d.ts +1 -1
  964. package/packages/agent/src/services/update-checker.d.ts.map +1 -1
  965. package/packages/agent/src/services/update-checker.js +4 -4
  966. package/packages/agent/src/services/version-compat.d.ts +4 -4
  967. package/packages/agent/src/services/version-compat.d.ts.map +1 -1
  968. package/packages/agent/src/services/version-compat.js +23 -7
  969. package/packages/agent/src/services/virtual-filesystem.d.ts +88 -0
  970. package/packages/agent/src/services/virtual-filesystem.d.ts.map +1 -0
  971. package/packages/agent/src/services/virtual-filesystem.js +410 -0
  972. package/packages/agent/src/shared/conversation-format.d.ts +11 -0
  973. package/packages/agent/src/shared/conversation-format.d.ts.map +1 -0
  974. package/packages/agent/src/shared/conversation-format.js +69 -0
  975. package/packages/agent/src/shared/index.d.ts +4 -0
  976. package/packages/agent/src/shared/index.d.ts.map +1 -0
  977. package/packages/agent/src/shared/index.js +3 -0
  978. package/packages/agent/src/shared/ui-catalog-prompt.d.ts +60 -18
  979. package/packages/agent/src/shared/ui-catalog-prompt.d.ts.map +1 -1
  980. package/packages/agent/src/shared/ui-catalog-prompt.js +116 -99
  981. package/packages/agent/src/shared/workspace-resolution.d.ts +5 -0
  982. package/packages/agent/src/shared/workspace-resolution.d.ts.map +1 -0
  983. package/packages/agent/src/shared/workspace-resolution.js +70 -0
  984. package/packages/agent/src/templates/skill-scaffold.d.ts +9 -0
  985. package/packages/agent/src/templates/skill-scaffold.d.ts.map +1 -0
  986. package/packages/agent/src/templates/skill-scaffold.js +26 -0
  987. package/packages/agent/src/test-support/index.d.ts +4 -0
  988. package/packages/agent/src/test-support/index.d.ts.map +1 -0
  989. package/packages/agent/src/test-support/index.js +3 -0
  990. package/packages/agent/src/test-support/route-test-helpers.d.ts +2 -2
  991. package/packages/agent/src/test-support/route-test-helpers.d.ts.map +1 -1
  992. package/packages/agent/src/test-support/route-test-helpers.js +1 -1
  993. package/packages/agent/src/test-support/test-helpers.d.ts +3 -3
  994. package/packages/agent/src/test-support/test-helpers.d.ts.map +1 -1
  995. package/packages/agent/src/test-support/test-helpers.js +35 -24
  996. package/packages/agent/src/test-utils/sqlite-compat.d.ts +23 -0
  997. package/packages/agent/src/test-utils/sqlite-compat.d.ts.map +1 -0
  998. package/packages/agent/src/test-utils/sqlite-compat.js +214 -0
  999. package/packages/agent/src/testing/index.d.ts +3 -3
  1000. package/packages/agent/src/testing/index.d.ts.map +1 -1
  1001. package/packages/agent/src/testing/index.js +3 -3
  1002. package/packages/agent/src/triggers/index.d.ts +5 -0
  1003. package/packages/agent/src/triggers/index.d.ts.map +1 -0
  1004. package/packages/agent/src/triggers/index.js +4 -0
  1005. package/packages/agent/src/triggers/runtime.d.ts +8 -2
  1006. package/packages/agent/src/triggers/runtime.d.ts.map +1 -1
  1007. package/packages/agent/src/triggers/runtime.js +197 -72
  1008. package/packages/agent/src/triggers/scheduling.d.ts +9 -1
  1009. package/packages/agent/src/triggers/scheduling.d.ts.map +1 -1
  1010. package/packages/agent/src/triggers/scheduling.js +103 -22
  1011. package/packages/agent/src/triggers/text-to-workflow.d.ts +58 -0
  1012. package/packages/agent/src/triggers/text-to-workflow.d.ts.map +1 -0
  1013. package/packages/agent/src/triggers/text-to-workflow.js +44 -0
  1014. package/packages/agent/src/triggers/types.d.ts +18 -37
  1015. package/packages/agent/src/triggers/types.d.ts.map +1 -1
  1016. package/packages/agent/src/triggers/types.js +1 -1
  1017. package/packages/agent/src/types/agent-skills.d.ts +19 -0
  1018. package/packages/agent/src/types/agent-skills.d.ts.map +1 -0
  1019. package/packages/agent/src/types/agent-skills.js +7 -0
  1020. package/packages/agent/src/types/config-like.d.ts +17 -0
  1021. package/packages/agent/src/types/config-like.d.ts.map +1 -0
  1022. package/packages/agent/src/types/config-like.js +7 -0
  1023. package/packages/agent/src/types/index.d.ts +4 -0
  1024. package/packages/agent/src/types/index.d.ts.map +1 -0
  1025. package/packages/agent/src/types/index.js +3 -0
  1026. package/packages/agent/src/types/trajectory.d.ts +20 -0
  1027. package/packages/agent/src/types/trajectory.d.ts.map +1 -0
  1028. package/packages/agent/src/types/trajectory.js +2 -0
  1029. package/packages/agent/src/utils/atomic-json.d.ts +37 -0
  1030. package/packages/agent/src/utils/atomic-json.d.ts.map +1 -0
  1031. package/packages/agent/src/utils/atomic-json.js +98 -0
  1032. package/packages/agent/src/utils/index.d.ts +2 -0
  1033. package/packages/agent/src/utils/index.d.ts.map +1 -0
  1034. package/packages/agent/src/utils/index.js +1 -0
  1035. package/packages/agent/src/utils/number-parsing.d.ts.map +1 -1
  1036. package/packages/agent/src/utils/number-parsing.js +1 -2
  1037. package/packages/agent/src/version-resolver.d.ts +0 -1
  1038. package/packages/agent/src/version-resolver.d.ts.map +1 -1
  1039. package/packages/agent/src/version-resolver.js +0 -1
  1040. package/LICENSE +0 -21
  1041. package/packages/agent/src/actions/emote.d.ts +0 -14
  1042. package/packages/agent/src/actions/emote.d.ts.map +0 -1
  1043. package/packages/agent/src/actions/emote.js +0 -91
  1044. package/packages/agent/src/actions/restart.d.ts +0 -19
  1045. package/packages/agent/src/actions/restart.d.ts.map +0 -1
  1046. package/packages/agent/src/actions/restart.js +0 -86
  1047. package/packages/agent/src/actions/send-message.d.ts +0 -3
  1048. package/packages/agent/src/actions/send-message.d.ts.map +0 -1
  1049. package/packages/agent/src/actions/send-message.js +0 -144
  1050. package/packages/agent/src/actions/switch-stream-source.d.ts +0 -16
  1051. package/packages/agent/src/actions/switch-stream-source.d.ts.map +0 -1
  1052. package/packages/agent/src/actions/switch-stream-source.js +0 -94
  1053. package/packages/agent/src/api/bsc-trade.d.ts +0 -34
  1054. package/packages/agent/src/api/bsc-trade.d.ts.map +0 -1
  1055. package/packages/agent/src/api/bsc-trade.js +0 -567
  1056. package/packages/agent/src/api/cloud-billing-routes.d.ts +0 -14
  1057. package/packages/agent/src/api/cloud-billing-routes.d.ts.map +0 -1
  1058. package/packages/agent/src/api/cloud-billing-routes.js +0 -400
  1059. package/packages/agent/src/api/cloud-compat-routes.d.ts +0 -15
  1060. package/packages/agent/src/api/cloud-compat-routes.d.ts.map +0 -1
  1061. package/packages/agent/src/api/cloud-compat-routes.js +0 -131
  1062. package/packages/agent/src/api/cloud-routes.d.ts +0 -62
  1063. package/packages/agent/src/api/cloud-routes.d.ts.map +0 -1
  1064. package/packages/agent/src/api/cloud-routes.js +0 -339
  1065. package/packages/agent/src/api/cloud-status-routes.d.ts +0 -15
  1066. package/packages/agent/src/api/cloud-status-routes.d.ts.map +0 -1
  1067. package/packages/agent/src/api/cloud-status-routes.js +0 -165
  1068. package/packages/agent/src/api/drop-service.d.ts +0 -26
  1069. package/packages/agent/src/api/drop-service.d.ts.map +0 -1
  1070. package/packages/agent/src/api/drop-service.js +0 -134
  1071. package/packages/agent/src/api/http-helpers.d.ts +0 -50
  1072. package/packages/agent/src/api/http-helpers.d.ts.map +0 -1
  1073. package/packages/agent/src/api/http-helpers.js +0 -145
  1074. package/packages/agent/src/api/knowledge-routes.d.ts +0 -23
  1075. package/packages/agent/src/api/knowledge-routes.d.ts.map +0 -1
  1076. package/packages/agent/src/api/knowledge-routes.js +0 -931
  1077. package/packages/agent/src/api/knowledge-service-loader.d.ts +0 -51
  1078. package/packages/agent/src/api/knowledge-service-loader.d.ts.map +0 -1
  1079. package/packages/agent/src/api/merkle-tree.d.ts +0 -90
  1080. package/packages/agent/src/api/merkle-tree.d.ts.map +0 -1
  1081. package/packages/agent/src/api/merkle-tree.js +0 -174
  1082. package/packages/agent/src/api/og-tracker.d.ts +0 -28
  1083. package/packages/agent/src/api/og-tracker.d.ts.map +0 -1
  1084. package/packages/agent/src/api/og-tracker.js +0 -60
  1085. package/packages/agent/src/api/route-helpers.d.ts +0 -16
  1086. package/packages/agent/src/api/route-helpers.d.ts.map +0 -1
  1087. package/packages/agent/src/api/route-helpers.js +0 -1
  1088. package/packages/agent/src/api/sandbox-routes.d.ts +0 -12
  1089. package/packages/agent/src/api/sandbox-routes.d.ts.map +0 -1
  1090. package/packages/agent/src/api/sandbox-routes.js +0 -1334
  1091. package/packages/agent/src/api/signal-routes.d.ts +0 -39
  1092. package/packages/agent/src/api/signal-routes.d.ts.map +0 -1
  1093. package/packages/agent/src/api/signal-routes.js +0 -168
  1094. package/packages/agent/src/api/stream-persistence.d.ts +0 -64
  1095. package/packages/agent/src/api/stream-persistence.d.ts.map +0 -1
  1096. package/packages/agent/src/api/stream-persistence.js +0 -231
  1097. package/packages/agent/src/api/stream-route-state.d.ts +0 -50
  1098. package/packages/agent/src/api/stream-route-state.d.ts.map +0 -1
  1099. package/packages/agent/src/api/stream-route-state.js +0 -1
  1100. package/packages/agent/src/api/stream-routes.d.ts +0 -45
  1101. package/packages/agent/src/api/stream-routes.d.ts.map +0 -1
  1102. package/packages/agent/src/api/stream-routes.js +0 -809
  1103. package/packages/agent/src/api/stream-voice-routes.d.ts +0 -36
  1104. package/packages/agent/src/api/stream-voice-routes.d.ts.map +0 -1
  1105. package/packages/agent/src/api/stream-voice-routes.js +0 -133
  1106. package/packages/agent/src/api/streaming-text.d.ts +0 -9
  1107. package/packages/agent/src/api/streaming-text.d.ts.map +0 -1
  1108. package/packages/agent/src/api/streaming-text.js +0 -85
  1109. package/packages/agent/src/api/streaming-types.d.ts +0 -30
  1110. package/packages/agent/src/api/streaming-types.d.ts.map +0 -1
  1111. package/packages/agent/src/api/streaming-types.js +0 -1
  1112. package/packages/agent/src/api/training-routes.d.ts +0 -44
  1113. package/packages/agent/src/api/training-routes.d.ts.map +0 -1
  1114. package/packages/agent/src/api/training-routes.js +0 -195
  1115. package/packages/agent/src/api/trajectory-routes.d.ts +0 -17
  1116. package/packages/agent/src/api/trajectory-routes.d.ts.map +0 -1
  1117. package/packages/agent/src/api/trajectory-routes.js +0 -405
  1118. package/packages/agent/src/api/trigger-routes.d.ts +0 -72
  1119. package/packages/agent/src/api/trigger-routes.d.ts.map +0 -1
  1120. package/packages/agent/src/api/trigger-routes.js +0 -268
  1121. package/packages/agent/src/api/twitter-verify.d.ts +0 -25
  1122. package/packages/agent/src/api/twitter-verify.d.ts.map +0 -1
  1123. package/packages/agent/src/api/twitter-verify.js +0 -168
  1124. package/packages/agent/src/api/whatsapp-routes.d.ts +0 -39
  1125. package/packages/agent/src/api/whatsapp-routes.d.ts.map +0 -1
  1126. package/packages/agent/src/api/whatsapp-routes.js +0 -182
  1127. package/packages/agent/src/auth/apply-stealth.d.ts +0 -8
  1128. package/packages/agent/src/auth/apply-stealth.d.ts.map +0 -1
  1129. package/packages/agent/src/auth/apply-stealth.js +0 -35
  1130. package/packages/agent/src/benchmark-server.d.ts +0 -2
  1131. package/packages/agent/src/benchmark-server.d.ts.map +0 -1
  1132. package/packages/agent/src/benchmark-server.js +0 -773
  1133. package/packages/agent/src/cloud/auth.d.ts +0 -19
  1134. package/packages/agent/src/cloud/auth.d.ts.map +0 -1
  1135. package/packages/agent/src/cloud/auth.js +0 -107
  1136. package/packages/agent/src/cloud/backup.d.ts +0 -18
  1137. package/packages/agent/src/cloud/backup.d.ts.map +0 -1
  1138. package/packages/agent/src/cloud/backup.js +0 -42
  1139. package/packages/agent/src/cloud/base-url.d.ts +0 -3
  1140. package/packages/agent/src/cloud/base-url.d.ts.map +0 -1
  1141. package/packages/agent/src/cloud/base-url.js +0 -40
  1142. package/packages/agent/src/cloud/bridge-client.d.ts +0 -56
  1143. package/packages/agent/src/cloud/bridge-client.d.ts.map +0 -1
  1144. package/packages/agent/src/cloud/bridge-client.js +0 -190
  1145. package/packages/agent/src/cloud/cloud-manager.d.ts +0 -32
  1146. package/packages/agent/src/cloud/cloud-manager.d.ts.map +0 -1
  1147. package/packages/agent/src/cloud/cloud-manager.js +0 -119
  1148. package/packages/agent/src/cloud/cloud-proxy.d.ts +0 -20
  1149. package/packages/agent/src/cloud/cloud-proxy.d.ts.map +0 -1
  1150. package/packages/agent/src/cloud/cloud-proxy.js +0 -34
  1151. package/packages/agent/src/cloud/index.d.ts +0 -7
  1152. package/packages/agent/src/cloud/index.d.ts.map +0 -1
  1153. package/packages/agent/src/cloud/index.js +0 -6
  1154. package/packages/agent/src/cloud/reconnect.d.ts +0 -26
  1155. package/packages/agent/src/cloud/reconnect.d.ts.map +0 -1
  1156. package/packages/agent/src/cloud/reconnect.js +0 -86
  1157. package/packages/agent/src/cloud/validate-url.d.ts +0 -2
  1158. package/packages/agent/src/cloud/validate-url.d.ts.map +0 -1
  1159. package/packages/agent/src/cloud/validate-url.js +0 -162
  1160. package/packages/agent/src/config/object-utils.d.ts +0 -2
  1161. package/packages/agent/src/config/object-utils.d.ts.map +0 -1
  1162. package/packages/agent/src/config/object-utils.js +0 -6
  1163. package/packages/agent/src/contracts/apps.d.ts +0 -42
  1164. package/packages/agent/src/contracts/apps.d.ts.map +0 -1
  1165. package/packages/agent/src/contracts/apps.js +0 -4
  1166. package/packages/agent/src/contracts/config.d.ts +0 -146
  1167. package/packages/agent/src/contracts/config.d.ts.map +0 -1
  1168. package/packages/agent/src/contracts/config.js +0 -4
  1169. package/packages/agent/src/contracts/drop.d.ts +0 -20
  1170. package/packages/agent/src/contracts/drop.d.ts.map +0 -1
  1171. package/packages/agent/src/contracts/drop.js +0 -4
  1172. package/packages/agent/src/contracts/onboarding.d.ts +0 -384
  1173. package/packages/agent/src/contracts/onboarding.d.ts.map +0 -1
  1174. package/packages/agent/src/contracts/permissions.d.ts +0 -35
  1175. package/packages/agent/src/contracts/permissions.d.ts.map +0 -1
  1176. package/packages/agent/src/contracts/permissions.js +0 -4
  1177. package/packages/agent/src/contracts/verification.d.ts +0 -9
  1178. package/packages/agent/src/contracts/verification.d.ts.map +0 -1
  1179. package/packages/agent/src/contracts/verification.js +0 -4
  1180. package/packages/agent/src/contracts/wallet.d.ts +0 -409
  1181. package/packages/agent/src/contracts/wallet.d.ts.map +0 -1
  1182. package/packages/agent/src/contracts/wallet.js +0 -60
  1183. package/packages/agent/src/emotes/catalog.d.ts +0 -31
  1184. package/packages/agent/src/emotes/catalog.d.ts.map +0 -1
  1185. package/packages/agent/src/emotes/catalog.js +0 -402
  1186. package/packages/agent/src/onboarding-presets.d.ts +0 -59
  1187. package/packages/agent/src/onboarding-presets.d.ts.map +0 -1
  1188. package/packages/agent/src/onboarding-presets.js +0 -1470
  1189. package/packages/agent/src/plugins/custom-rtmp/index.d.ts +0 -12
  1190. package/packages/agent/src/plugins/custom-rtmp/index.d.ts.map +0 -1
  1191. package/packages/agent/src/plugins/custom-rtmp/index.js +0 -26
  1192. package/packages/agent/src/runtime/cloud-onboarding.d.ts +0 -55
  1193. package/packages/agent/src/runtime/cloud-onboarding.d.ts.map +0 -1
  1194. package/packages/agent/src/runtime/cloud-onboarding.js +0 -279
  1195. package/packages/agent/src/server/index.d.ts +0 -3
  1196. package/packages/agent/src/server/index.d.ts.map +0 -1
  1197. package/packages/agent/src/server/index.js +0 -1
  1198. package/packages/agent/src/services/browser-capture.d.ts +0 -39
  1199. package/packages/agent/src/services/browser-capture.d.ts.map +0 -1
  1200. package/packages/agent/src/services/browser-capture.js +0 -162
  1201. package/packages/agent/src/services/coding-agent-context.d.ts +0 -310
  1202. package/packages/agent/src/services/coding-agent-context.d.ts.map +0 -1
  1203. package/packages/agent/src/services/coding-agent-context.js +0 -281
  1204. package/packages/agent/src/services/fallback-training-service.d.ts +0 -78
  1205. package/packages/agent/src/services/fallback-training-service.d.ts.map +0 -1
  1206. package/packages/agent/src/services/fallback-training-service.js +0 -126
  1207. package/packages/agent/src/services/privy-wallets.d.ts +0 -18
  1208. package/packages/agent/src/services/privy-wallets.d.ts.map +0 -1
  1209. package/packages/agent/src/services/privy-wallets.js +0 -225
  1210. package/packages/agent/src/services/signal-pairing.d.ts +0 -37
  1211. package/packages/agent/src/services/signal-pairing.d.ts.map +0 -1
  1212. package/packages/agent/src/services/signal-pairing.js +0 -124
  1213. package/packages/agent/src/services/stream-manager.d.ts +0 -121
  1214. package/packages/agent/src/services/stream-manager.d.ts.map +0 -1
  1215. package/packages/agent/src/services/stream-manager.js +0 -604
  1216. package/packages/agent/src/services/tts-stream-bridge.d.ts +0 -83
  1217. package/packages/agent/src/services/tts-stream-bridge.d.ts.map +0 -1
  1218. package/packages/agent/src/services/tts-stream-bridge.js +0 -349
  1219. package/packages/agent/src/services/whatsapp-pairing.d.ts +0 -41
  1220. package/packages/agent/src/services/whatsapp-pairing.d.ts.map +0 -1
  1221. package/packages/agent/src/services/whatsapp-pairing.js +0 -209
  1222. package/packages/agent/src/triggers/action.d.ts +0 -3
  1223. package/packages/agent/src/triggers/action.d.ts.map +0 -1
  1224. package/packages/agent/src/triggers/action.js +0 -267
  1225. package/packages/agent/src/utils/spoken-text.d.ts +0 -2
  1226. package/packages/agent/src/utils/spoken-text.d.ts.map +0 -1
  1227. package/packages/agent/src/utils/spoken-text.js +0 -56
@@ -1,1334 +0,0 @@
1
- /** Sandbox capability API routes: status, exec, browser, screen, audio, computer use. */
2
- import { execFileSync, execSync } from "node:child_process";
3
- import { readFileSync, unlinkSync, writeFileSync } from "node:fs";
4
- import { platform, tmpdir } from "node:os";
5
- import { join } from "node:path";
6
- import { readJsonBody as parseJsonBody, readRequestBody, sendJson as sendJsonResponse, } from "./http-helpers";
7
- const MAX_COMPUTER_INPUT_LENGTH = 4096;
8
- const MAX_KEYPRESS_LENGTH = 128;
9
- const SAFE_KEYPRESS_PATTERN = /^[A-Za-z0-9+_.,: -]+$/;
10
- const ALLOWED_AUDIO_FORMATS = new Set(["wav", "mp3", "ogg", "flac", "m4a"]);
11
- const MIN_AUDIO_RECORD_DURATION_MS = 250;
12
- const MAX_AUDIO_RECORD_DURATION_MS = 30_000;
13
- // ── Route handler ────────────────────────────────────────────────────────────
14
- /** Returns `true` if handled, `false` to fall through. */
15
- export async function handleSandboxRoute(req, res, pathname, method, state) {
16
- if (!pathname.startsWith("/api/sandbox")) {
17
- return false;
18
- }
19
- const mgr = state.sandboxManager;
20
- // Platform info doesn't require a running manager
21
- if (method === "GET" && pathname === "/api/sandbox/platform") {
22
- sendJson(res, 200, getPlatformInfo());
23
- return true;
24
- }
25
- // ── POST /api/sandbox/docker/start ────────────────────────────────
26
- // Attempt to start Docker Desktop (works on macOS/Windows desktop builds)
27
- if (method === "POST" && pathname === "/api/sandbox/docker/start") {
28
- try {
29
- const result = attemptDockerStart();
30
- sendJson(res, 200, result);
31
- }
32
- catch (err) {
33
- sendJson(res, 500, {
34
- success: false,
35
- error: `Failed to start Docker: ${err instanceof Error ? err.message : String(err)}`,
36
- });
37
- }
38
- return true;
39
- }
40
- if (!mgr) {
41
- sendJson(res, 503, {
42
- error: "Sandbox manager not initialized",
43
- });
44
- return true;
45
- }
46
- // ── GET /api/sandbox/status ─────────────────────────────────────────
47
- if (method === "GET" && pathname === "/api/sandbox/status") {
48
- sendJson(res, 200, mgr.getStatus());
49
- return true;
50
- }
51
- // ── GET /api/sandbox/events ─────────────────────────────────────────
52
- if (method === "GET" && pathname === "/api/sandbox/events") {
53
- const events = mgr.getEventLog();
54
- sendJson(res, 200, { events: events.slice(-100) });
55
- return true;
56
- }
57
- // ── POST /api/sandbox/start ─────────────────────────────────────────
58
- if (method === "POST" && pathname === "/api/sandbox/start") {
59
- try {
60
- await mgr.start();
61
- sendJson(res, 200, mgr.getStatus());
62
- }
63
- catch (err) {
64
- sendJson(res, 500, {
65
- error: `Failed to start sandbox: ${err instanceof Error ? err.message : String(err)}`,
66
- });
67
- }
68
- return true;
69
- }
70
- // ── POST /api/sandbox/stop ──────────────────────────────────────────
71
- if (method === "POST" && pathname === "/api/sandbox/stop") {
72
- try {
73
- await mgr.stop();
74
- sendJson(res, 200, mgr.getStatus());
75
- }
76
- catch (err) {
77
- sendJson(res, 500, {
78
- error: `Failed to stop sandbox: ${err instanceof Error ? err.message : String(err)}`,
79
- });
80
- }
81
- return true;
82
- }
83
- // ── POST /api/sandbox/recover ───────────────────────────────────────
84
- if (method === "POST" && pathname === "/api/sandbox/recover") {
85
- try {
86
- await mgr.recover();
87
- sendJson(res, 200, mgr.getStatus());
88
- }
89
- catch (err) {
90
- sendJson(res, 500, {
91
- error: `Recovery failed: ${err instanceof Error ? err.message : String(err)}`,
92
- });
93
- }
94
- return true;
95
- }
96
- // ── POST /api/sandbox/exec ──────────────────────────────────────────
97
- if (method === "POST" && pathname === "/api/sandbox/exec") {
98
- const parsed = await readJsonBody(req, res);
99
- if (!parsed)
100
- return true;
101
- if (!parsed.command || typeof parsed.command !== "string") {
102
- sendJson(res, 400, { error: "Missing 'command' field" });
103
- return true;
104
- }
105
- const result = await mgr.exec({
106
- command: parsed.command,
107
- workdir: parsed.workdir,
108
- timeoutMs: parsed.timeoutMs,
109
- });
110
- sendJson(res, result.exitCode === 0 ? 200 : 422, result);
111
- return true;
112
- }
113
- // ── GET /api/sandbox/browser ────────────────────────────────────────
114
- if (method === "GET" && pathname === "/api/sandbox/browser") {
115
- sendJson(res, 200, {
116
- cdpEndpoint: mgr.getBrowserCdpEndpoint(),
117
- wsEndpoint: mgr.getBrowserWsEndpoint(),
118
- noVncEndpoint: mgr.getBrowserNoVncEndpoint(),
119
- });
120
- return true;
121
- }
122
- // ── Capability bridges ──────────────────────────────────────────────
123
- if (method === "GET" && pathname === "/api/sandbox/screen/screenshot") {
124
- try {
125
- const screenshot = captureScreenshot();
126
- res.writeHead(200, {
127
- "Content-Type": "image/png",
128
- "Content-Length": screenshot.length,
129
- });
130
- res.end(screenshot);
131
- }
132
- catch (err) {
133
- sendJson(res, 500, {
134
- error: `Screenshot failed: ${err instanceof Error ? err.message : String(err)}`,
135
- });
136
- }
137
- return true;
138
- }
139
- // ── POST /api/sandbox/screen/screenshot ─────────────────────────────
140
- // Returns base64-encoded screenshot for easy consumption by agents
141
- if (method === "POST" && pathname === "/api/sandbox/screen/screenshot") {
142
- const rawBody = await readBody(req);
143
- if (!rawBody || !rawBody.trim()) {
144
- sendJson(res, 200, {
145
- format: "png",
146
- encoding: "base64",
147
- width: null,
148
- height: null,
149
- data: captureScreenshot().toString("base64"),
150
- });
151
- return true;
152
- }
153
- let regionInput;
154
- try {
155
- regionInput = JSON.parse(rawBody);
156
- }
157
- catch {
158
- sendJson(res, 400, { error: "Invalid JSON body" });
159
- return true;
160
- }
161
- const region = resolveScreenshotRegion(regionInput);
162
- if (region.error) {
163
- sendJson(res, 400, { error: region.error });
164
- return true;
165
- }
166
- try {
167
- const screenshot = captureScreenshot(region.region);
168
- const base64 = screenshot.toString("base64");
169
- sendJson(res, 200, {
170
- format: "png",
171
- encoding: "base64",
172
- width: null, // platform-dependent
173
- height: null,
174
- data: base64,
175
- });
176
- }
177
- catch (err) {
178
- sendJson(res, 500, {
179
- error: `Screenshot failed: ${err instanceof Error ? err.message : String(err)}`,
180
- });
181
- }
182
- return true;
183
- }
184
- // ── GET /api/sandbox/screen/windows ─────────────────────────────────
185
- if (method === "GET" && pathname === "/api/sandbox/screen/windows") {
186
- try {
187
- const windows = listWindows();
188
- sendJson(res, 200, { windows });
189
- }
190
- catch (err) {
191
- sendJson(res, 200, { windows: [], error: String(err) });
192
- }
193
- return true;
194
- }
195
- // ── POST /api/sandbox/audio/record ──────────────────────────────────
196
- if (method === "POST" && pathname === "/api/sandbox/audio/record") {
197
- const body = await readBody(req);
198
- let durationMs = 5000;
199
- if (body) {
200
- let parsed;
201
- try {
202
- parsed = JSON.parse(body);
203
- }
204
- catch {
205
- sendJson(res, 400, {
206
- error: "Invalid JSON in request body",
207
- });
208
- return true;
209
- }
210
- if (parsed === null ||
211
- typeof parsed !== "object" ||
212
- Array.isArray(parsed)) {
213
- sendJson(res, 400, { error: "Request body must be a JSON object" });
214
- return true;
215
- }
216
- const bodyValues = parsed;
217
- if (Object.hasOwn(bodyValues, "durationMs")) {
218
- const durationValue = bodyValues.durationMs;
219
- if (typeof durationValue !== "number") {
220
- sendJson(res, 400, {
221
- error: "durationMs must be a finite number",
222
- });
223
- return true;
224
- }
225
- // Defense in depth: JSON.parse only produces finite numbers, but this guard
226
- // keeps behavior explicit against future parser/runtime changes.
227
- if (!Number.isFinite(durationValue)) {
228
- sendJson(res, 400, {
229
- error: "durationMs must be a finite number",
230
- });
231
- return true;
232
- }
233
- if (!Number.isInteger(durationValue)) {
234
- sendJson(res, 400, {
235
- error: "durationMs must be an integer number of milliseconds",
236
- });
237
- return true;
238
- }
239
- if (durationValue < MIN_AUDIO_RECORD_DURATION_MS ||
240
- durationValue > MAX_AUDIO_RECORD_DURATION_MS) {
241
- sendJson(res, 400, {
242
- error: `durationMs must be between ${MIN_AUDIO_RECORD_DURATION_MS} and ${MAX_AUDIO_RECORD_DURATION_MS} milliseconds`,
243
- });
244
- return true;
245
- }
246
- durationMs = durationValue;
247
- }
248
- }
249
- try {
250
- const audio = await recordAudio(durationMs);
251
- sendJson(res, 200, {
252
- format: "wav",
253
- encoding: "base64",
254
- durationMs,
255
- data: audio.toString("base64"),
256
- });
257
- }
258
- catch (err) {
259
- sendJson(res, 500, {
260
- error: `Audio recording failed: ${err instanceof Error ? err.message : String(err)}`,
261
- });
262
- }
263
- return true;
264
- }
265
- // ── POST /api/sandbox/audio/play ────────────────────────────────────
266
- if (method === "POST" && pathname === "/api/sandbox/audio/play") {
267
- const parsed = await readJsonBody(req, res);
268
- if (!parsed)
269
- return true;
270
- if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
271
- sendJson(res, 400, { error: "Body must be a JSON object" });
272
- return true;
273
- }
274
- const payload = parsed;
275
- if (typeof payload.data !== "string" || !payload.data.trim()) {
276
- sendJson(res, 400, { error: "Missing 'data' field (base64 audio)" });
277
- return true;
278
- }
279
- const formatResult = resolveAudioFormat(payload.format);
280
- if (formatResult.error) {
281
- sendJson(res, 400, { error: formatResult.error });
282
- return true;
283
- }
284
- try {
285
- await playAudio(Buffer.from(payload.data, "base64"), formatResult.format);
286
- sendJson(res, 200, { success: true });
287
- }
288
- catch (err) {
289
- sendJson(res, 500, {
290
- error: `Audio playback failed: ${err instanceof Error ? err.message : String(err)}`,
291
- });
292
- }
293
- return true;
294
- }
295
- // ── POST /api/sandbox/computer/click ────────────────────────────────
296
- if (method === "POST" && pathname === "/api/sandbox/computer/click") {
297
- const parsed = await readJsonBody(req, res);
298
- if (!parsed)
299
- return true;
300
- const clickPayload = resolveClickPayload(parsed);
301
- if (clickPayload.error) {
302
- sendJson(res, 400, { error: clickPayload.error });
303
- return true;
304
- }
305
- try {
306
- const { x, y, button } = clickPayload;
307
- performClick(x, y, button);
308
- sendJson(res, 200, { success: true, x, y, button });
309
- }
310
- catch (err) {
311
- sendJson(res, 500, {
312
- error: `Click failed: ${err instanceof Error ? err.message : String(err)}`,
313
- });
314
- }
315
- return true;
316
- }
317
- // ── POST /api/sandbox/computer/type ─────────────────────────────────
318
- if (method === "POST" && pathname === "/api/sandbox/computer/type") {
319
- const parsed = await readJsonBody(req, res);
320
- if (!parsed)
321
- return true;
322
- const typePayload = resolveTypePayload(parsed);
323
- if (typePayload.error) {
324
- sendJson(res, 400, { error: typePayload.error });
325
- return true;
326
- }
327
- try {
328
- const { text } = typePayload;
329
- performType(text);
330
- sendJson(res, 200, { success: true, length: text.length });
331
- }
332
- catch (err) {
333
- sendJson(res, 500, {
334
- error: `Type failed: ${err instanceof Error ? err.message : String(err)}`,
335
- });
336
- }
337
- return true;
338
- }
339
- // ── POST /api/sandbox/computer/keypress ─────────────────────────────
340
- if (method === "POST" && pathname === "/api/sandbox/computer/keypress") {
341
- const parsed = await readJsonBody(req, res);
342
- if (!parsed)
343
- return true;
344
- const keypressPayload = resolveKeypressPayload(parsed);
345
- if (keypressPayload.error) {
346
- sendJson(res, 400, { error: keypressPayload.error });
347
- return true;
348
- }
349
- try {
350
- const { keys } = keypressPayload;
351
- performKeypress(keys);
352
- sendJson(res, 200, { success: true, keys });
353
- }
354
- catch (err) {
355
- sendJson(res, 500, {
356
- error: `Keypress failed: ${err instanceof Error ? err.message : String(err)}`,
357
- });
358
- }
359
- return true;
360
- }
361
- // ── Signing routes ─────────────────────────────────────────────────
362
- if (method === "POST" && pathname === "/api/sandbox/sign") {
363
- const signer = state.signingService;
364
- if (!signer) {
365
- sendJson(res, 503, { error: "Signing service not configured" });
366
- return true;
367
- }
368
- const body = await readJsonBody(req, res);
369
- if (body === null)
370
- return true;
371
- const parsed = resolveSigningRequestPayload(body);
372
- if ("error" in parsed) {
373
- sendJson(res, 400, { error: parsed.error });
374
- return true;
375
- }
376
- try {
377
- const result = await signer.submitSigningRequest(parsed.request);
378
- sendJson(res, result.success ? 200 : 403, result);
379
- }
380
- catch (err) {
381
- sendJson(res, 400, {
382
- error: `Invalid request: ${err instanceof Error ? err.message : String(err)}`,
383
- });
384
- }
385
- return true;
386
- }
387
- if (method === "POST" && pathname === "/api/sandbox/sign/approve") {
388
- const signer = state.signingService;
389
- if (!signer) {
390
- sendJson(res, 503, { error: "Signing service not configured" });
391
- return true;
392
- }
393
- const body = await readJsonBody(req, res);
394
- if (!body)
395
- return true;
396
- try {
397
- const { requestId } = body;
398
- const result = await signer.approveRequest(requestId);
399
- sendJson(res, result.success ? 200 : 403, result);
400
- }
401
- catch (err) {
402
- sendJson(res, 400, { error: String(err) });
403
- }
404
- return true;
405
- }
406
- if (method === "POST" && pathname === "/api/sandbox/sign/reject") {
407
- const signer = state.signingService;
408
- if (!signer) {
409
- sendJson(res, 503, { error: "Signing service not configured" });
410
- return true;
411
- }
412
- const body = await readJsonBody(req, res);
413
- if (!body)
414
- return true;
415
- try {
416
- const { requestId } = body;
417
- const rejected = signer.rejectRequest(requestId);
418
- sendJson(res, 200, { rejected });
419
- }
420
- catch (err) {
421
- sendJson(res, 400, { error: String(err) });
422
- }
423
- return true;
424
- }
425
- if (method === "GET" && pathname === "/api/sandbox/sign/pending") {
426
- const signer = state.signingService;
427
- if (!signer) {
428
- sendJson(res, 503, { error: "Signing service not configured" });
429
- return true;
430
- }
431
- sendJson(res, 200, { pending: signer.getPendingApprovals() });
432
- return true;
433
- }
434
- if (method === "GET" && pathname === "/api/sandbox/sign/address") {
435
- const signer = state.signingService;
436
- if (!signer) {
437
- sendJson(res, 503, { error: "Signing service not configured" });
438
- return true;
439
- }
440
- try {
441
- const address = await signer.getAddress();
442
- sendJson(res, 200, { address });
443
- }
444
- catch (err) {
445
- sendJson(res, 500, { error: String(err) });
446
- }
447
- return true;
448
- }
449
- // ── GET /api/sandbox/capabilities ───────────────────────────────────
450
- if (method === "GET" && pathname === "/api/sandbox/capabilities") {
451
- sendJson(res, 200, detectCapabilities());
452
- return true;
453
- }
454
- // ── Fallthrough ─────────────────────────────────────────────────────
455
- sendJson(res, 404, { error: `Unknown sandbox route: ${method} ${pathname}` });
456
- return true;
457
- }
458
- function asObject(value) {
459
- if (!value || typeof value !== "object" || Array.isArray(value))
460
- return null;
461
- return value;
462
- }
463
- function resolveSigningRequestPayload(input) {
464
- const obj = asObject(input);
465
- if (!obj) {
466
- return { error: "Signing payload must be a JSON object" };
467
- }
468
- const requestId = obj.requestId;
469
- const chainId = parseFiniteInteger(obj.chainId);
470
- const to = obj.to;
471
- const value = obj.value;
472
- const data = obj.data;
473
- const nonce = obj.nonce === undefined ? undefined : parseFiniteInteger(obj.nonce);
474
- const rawGasLimit = obj.gasLimit;
475
- const createdAt = parseFiniteInteger(obj.createdAt);
476
- if (typeof requestId !== "string" || !requestId.trim()) {
477
- return { error: "Signing payload requires a non-empty string 'requestId'" };
478
- }
479
- if (chainId === null || chainId < 0) {
480
- return { error: "Signing payload requires an integer 'chainId' >= 0" };
481
- }
482
- if (typeof to !== "string" || !/^0x[0-9a-fA-F]{40}$/.test(to.trim())) {
483
- return {
484
- error: "Signing payload requires a hex 'to' address (e.g., 0x followed by 40 hex characters)",
485
- };
486
- }
487
- if (typeof value !== "string" || !value.trim()) {
488
- return { error: "Signing payload requires a non-empty string 'value'" };
489
- }
490
- if (typeof data !== "string" || !data.trim()) {
491
- return { error: "Signing payload requires a non-empty string 'data'" };
492
- }
493
- if (nonce === null) {
494
- return { error: "'nonce' must be a non-negative integer when provided" };
495
- }
496
- if (createdAt === null) {
497
- return { error: "Signing payload requires an integer 'createdAt'" };
498
- }
499
- if (rawGasLimit !== undefined && typeof rawGasLimit !== "string") {
500
- return {
501
- error: "Signing payload 'gasLimit' must be a string when provided",
502
- };
503
- }
504
- const gasLimit = rawGasLimit?.trim();
505
- if (gasLimit === "") {
506
- return {
507
- error: "Signing payload 'gasLimit' cannot be empty when provided",
508
- };
509
- }
510
- return {
511
- request: {
512
- requestId: requestId.trim(),
513
- chainId,
514
- to: to.trim(),
515
- value: value.trim(),
516
- data,
517
- ...(nonce === undefined ? {} : { nonce }),
518
- ...(gasLimit === undefined ? {} : { gasLimit }),
519
- createdAt,
520
- },
521
- };
522
- }
523
- function parseFiniteInteger(value) {
524
- if (typeof value !== "number" || !Number.isFinite(value))
525
- return null;
526
- if (!Number.isInteger(value))
527
- return null;
528
- return value;
529
- }
530
- function resolveScreenshotRegion(input) {
531
- if (input === undefined || input === null)
532
- return {};
533
- const obj = asObject(input);
534
- if (!obj)
535
- return { error: "Screenshot region payload must be a JSON object" };
536
- const hasRegionField = "x" in obj || "y" in obj || "width" in obj || "height" in obj;
537
- if (!hasRegionField)
538
- return {};
539
- const x = parseFiniteInteger(obj.x);
540
- const y = parseFiniteInteger(obj.y);
541
- const width = parseFiniteInteger(obj.width);
542
- const height = parseFiniteInteger(obj.height);
543
- if (x === null || y === null || width === null || height === null) {
544
- return {
545
- error: "Region requires integer x, y, width, and height values",
546
- };
547
- }
548
- if (width <= 0 || height <= 0) {
549
- return { error: "Region width and height must be greater than 0" };
550
- }
551
- return {
552
- region: { x, y, width, height },
553
- };
554
- }
555
- function resolveClickPayload(input) {
556
- const obj = asObject(input);
557
- if (!obj) {
558
- return {
559
- x: 0,
560
- y: 0,
561
- button: "left",
562
- error: "Click payload must be a JSON object",
563
- };
564
- }
565
- const x = parseFiniteInteger(obj.x);
566
- const y = parseFiniteInteger(obj.y);
567
- if (x === null || y === null) {
568
- return {
569
- x: 0,
570
- y: 0,
571
- button: "left",
572
- error: "Click payload requires integer x and y coordinates",
573
- };
574
- }
575
- const rawButton = obj.button;
576
- let button = "left";
577
- if (rawButton !== undefined) {
578
- if (rawButton !== "left" && rawButton !== "right") {
579
- return {
580
- x,
581
- y,
582
- button,
583
- error: "button must be either 'left' or 'right'",
584
- };
585
- }
586
- button = rawButton;
587
- }
588
- return { x, y, button };
589
- }
590
- function resolveTypePayload(input) {
591
- const obj = asObject(input);
592
- if (!obj)
593
- return { text: "", error: "Type payload must be a JSON object" };
594
- if (typeof obj.text !== "string") {
595
- return { text: "", error: "Type payload requires a string 'text' field" };
596
- }
597
- if (obj.text.length === 0) {
598
- return { text: "", error: "text cannot be empty" };
599
- }
600
- if (obj.text.length > MAX_COMPUTER_INPUT_LENGTH) {
601
- return {
602
- text: "",
603
- error: `text exceeds maximum length (${MAX_COMPUTER_INPUT_LENGTH})`,
604
- };
605
- }
606
- return { text: obj.text };
607
- }
608
- function resolveKeypressPayload(input) {
609
- const obj = asObject(input);
610
- if (!obj) {
611
- return { keys: "", error: "Keypress payload must be a JSON object" };
612
- }
613
- if (typeof obj.keys !== "string") {
614
- return {
615
- keys: "",
616
- error: "Keypress payload requires a string 'keys' field",
617
- };
618
- }
619
- const keys = obj.keys.trim();
620
- if (!keys)
621
- return { keys: "", error: "keys cannot be empty" };
622
- if (keys.length > MAX_KEYPRESS_LENGTH) {
623
- return {
624
- keys: "",
625
- error: `keys exceeds maximum length (${MAX_KEYPRESS_LENGTH})`,
626
- };
627
- }
628
- if (!SAFE_KEYPRESS_PATTERN.test(keys)) {
629
- return {
630
- keys: "",
631
- error: "keys contains unsupported characters; allowed: letters, numbers, space, +, _, ., ,, :, -",
632
- };
633
- }
634
- return { keys };
635
- }
636
- function resolveAudioFormat(input) {
637
- if (input === undefined || input === null)
638
- return { format: "wav" };
639
- if (typeof input !== "string") {
640
- return { format: "wav", error: "format must be a string" };
641
- }
642
- const normalized = input.trim().toLowerCase();
643
- if (!normalized)
644
- return { format: "wav" };
645
- if (!/^[a-z0-9]+$/.test(normalized)) {
646
- return {
647
- format: "wav",
648
- error: "format contains unsupported characters; use one of: wav, mp3, ogg, flac, m4a",
649
- };
650
- }
651
- if (!ALLOWED_AUDIO_FORMATS.has(normalized)) {
652
- return {
653
- format: "wav",
654
- error: "format must be one of: wav, mp3, ogg, flac, m4a",
655
- };
656
- }
657
- return { format: normalized };
658
- }
659
- function runCommand(command, args, timeout) {
660
- execFileSync(command, args, {
661
- timeout,
662
- stdio: ["ignore", "pipe", "pipe"],
663
- });
664
- }
665
- function captureScreenshot(region) {
666
- const os = platform();
667
- const tmpFile = join(tmpdir(), `sandbox-screenshot-${Date.now()}.png`);
668
- try {
669
- if (os === "darwin") {
670
- if (region) {
671
- runCommand("screencapture", [
672
- `-R${region.x},${region.y},${region.width},${region.height}`,
673
- "-x",
674
- tmpFile,
675
- ], 10000);
676
- }
677
- else {
678
- runCommand("screencapture", ["-x", tmpFile], 10000);
679
- }
680
- }
681
- else if (os === "linux") {
682
- // Try tools in preference order
683
- if (commandExists("import")) {
684
- if (region) {
685
- runCommand("import", [
686
- "-window",
687
- "root",
688
- "-crop",
689
- `${region.width}x${region.height}+${region.x}+${region.y}`,
690
- tmpFile,
691
- ], 10000);
692
- }
693
- else {
694
- runCommand("import", ["-window", "root", tmpFile], 10000);
695
- }
696
- }
697
- else if (commandExists("scrot")) {
698
- runCommand("scrot", [tmpFile], 10000);
699
- }
700
- else if (commandExists("gnome-screenshot")) {
701
- runCommand("gnome-screenshot", ["-f", tmpFile], 10000);
702
- }
703
- else {
704
- throw new Error("No screenshot tool available. Install ImageMagick, scrot, or gnome-screenshot.");
705
- }
706
- }
707
- else if (os === "win32") {
708
- // PowerShell screenshot
709
- const psCmd = [
710
- `Add-Type -AssemblyName System.Windows.Forms`,
711
- `$screen = [System.Windows.Forms.Screen]::PrimaryScreen.Bounds`,
712
- `$bitmap = New-Object System.Drawing.Bitmap($screen.Width, $screen.Height)`,
713
- `$graphics = [System.Drawing.Graphics]::FromImage($bitmap)`,
714
- `$graphics.CopyFromScreen($screen.Location, [System.Drawing.Point]::Empty, $screen.Size)`,
715
- `$bitmap.Save('${tmpFile.replace(/\//g, "\\")}')`,
716
- `$graphics.Dispose()`,
717
- `$bitmap.Dispose()`,
718
- ].join("; ");
719
- execSync(`powershell -Command "${psCmd}"`, {
720
- timeout: 15000,
721
- stdio: ["ignore", "pipe", "pipe"],
722
- });
723
- }
724
- else {
725
- throw new Error(`Screenshot not supported on platform: ${os}`);
726
- }
727
- const data = readFileSync(tmpFile);
728
- try {
729
- unlinkSync(tmpFile);
730
- }
731
- catch {
732
- /* cleanup best effort */
733
- }
734
- return data;
735
- }
736
- catch (err) {
737
- // Clean up temp file on error
738
- try {
739
- unlinkSync(tmpFile);
740
- }
741
- catch {
742
- /* ignore */
743
- }
744
- throw err;
745
- }
746
- }
747
- function listWindows() {
748
- const os = platform();
749
- if (os === "darwin") {
750
- try {
751
- const script = `
752
- tell application "System Events"
753
- set windowList to {}
754
- repeat with proc in (every process whose visible is true)
755
- try
756
- repeat with w in (every window of proc)
757
- set end of windowList to (name of proc) & "|||" & (name of w) & "|||" & (id of w as text)
758
- end repeat
759
- end try
760
- end repeat
761
- return windowList as text
762
- end tell`;
763
- const output = execSync(`osascript -e '${script}'`, {
764
- encoding: "utf-8",
765
- timeout: 10000,
766
- stdio: ["ignore", "pipe", "ignore"],
767
- });
768
- return output
769
- .split(", ")
770
- .filter(Boolean)
771
- .map((entry) => {
772
- const parts = entry.split("|||");
773
- return {
774
- app: parts[0] ?? "unknown",
775
- title: parts[1] ?? "unknown",
776
- id: parts[2] ?? "0",
777
- };
778
- });
779
- }
780
- catch {
781
- return [];
782
- }
783
- }
784
- if (os === "linux") {
785
- try {
786
- const output = execSync('wmctrl -l 2>/dev/null || xdotool search --name "" getwindowname 2>/dev/null', {
787
- encoding: "utf-8",
788
- timeout: 5000,
789
- });
790
- return output
791
- .split("\n")
792
- .filter(Boolean)
793
- .map((line, i) => ({
794
- id: String(i),
795
- title: line.trim(),
796
- app: "unknown",
797
- }));
798
- }
799
- catch {
800
- return [];
801
- }
802
- }
803
- if (os === "win32") {
804
- try {
805
- const output = execSync(`powershell -Command "Get-Process | Where-Object {$_.MainWindowTitle} | Select-Object Id, MainWindowTitle | ConvertTo-Json"`, { encoding: "utf-8", timeout: 10000 });
806
- const processes = JSON.parse(output);
807
- const list = Array.isArray(processes) ? processes : [processes];
808
- return list.map((p) => ({
809
- id: String(p.Id),
810
- title: p.MainWindowTitle,
811
- app: "unknown",
812
- }));
813
- }
814
- catch {
815
- return [];
816
- }
817
- }
818
- return [];
819
- }
820
- async function recordAudio(durationMs) {
821
- const os = platform();
822
- const durationSec = Math.ceil(durationMs / 1000);
823
- const tmpFile = join(tmpdir(), `sandbox-audio-${Date.now()}.wav`);
824
- if (os === "darwin") {
825
- // Use sox (rec) on macOS
826
- if (commandExists("rec")) {
827
- execSync(`rec -q ${tmpFile} trim 0 ${durationSec}`, {
828
- timeout: durationMs + 5000,
829
- stdio: ["ignore", "pipe", "pipe"],
830
- });
831
- }
832
- else if (commandExists("ffmpeg")) {
833
- execSync(`ffmpeg -f avfoundation -i ":0" -t ${durationSec} -y ${tmpFile} 2>/dev/null`, { timeout: durationMs + 10000, stdio: ["ignore", "pipe", "pipe"] });
834
- }
835
- else {
836
- throw new Error("No audio recording tool available. Install sox or ffmpeg.");
837
- }
838
- }
839
- else if (os === "linux") {
840
- if (commandExists("arecord")) {
841
- execSync(`arecord -d ${durationSec} -f cd ${tmpFile}`, {
842
- timeout: durationMs + 5000,
843
- stdio: ["ignore", "pipe", "pipe"],
844
- });
845
- }
846
- else if (commandExists("ffmpeg")) {
847
- execSync(`ffmpeg -f pulse -i default -t ${durationSec} -y ${tmpFile} 2>/dev/null`, { timeout: durationMs + 10000, stdio: ["ignore", "pipe", "pipe"] });
848
- }
849
- else {
850
- throw new Error("No audio recording tool available. Install alsa-utils or ffmpeg.");
851
- }
852
- }
853
- else if (os === "win32") {
854
- // Use ffmpeg on Windows (most portable)
855
- if (commandExists("ffmpeg")) {
856
- execSync(`ffmpeg -f dshow -i audio="Microphone" -t ${durationSec} -y "${tmpFile.replace(/\//g, "\\")}" 2>NUL`, { timeout: durationMs + 10000, stdio: ["ignore", "pipe", "pipe"] });
857
- }
858
- else {
859
- throw new Error("No audio recording tool available. Install ffmpeg.");
860
- }
861
- }
862
- else {
863
- throw new Error(`Audio recording not supported on platform: ${os}`);
864
- }
865
- const data = readFileSync(tmpFile);
866
- try {
867
- unlinkSync(tmpFile);
868
- }
869
- catch {
870
- /* cleanup */
871
- }
872
- return data;
873
- }
874
- async function playAudio(data, format) {
875
- const os = platform();
876
- const tmpFile = join(tmpdir(), `sandbox-play-${Date.now()}.${format}`);
877
- writeFileSync(tmpFile, data);
878
- try {
879
- if (os === "darwin") {
880
- runCommand("afplay", [tmpFile], 60000);
881
- }
882
- else if (os === "linux") {
883
- if (commandExists("aplay")) {
884
- runCommand("aplay", [tmpFile], 60000);
885
- }
886
- else if (commandExists("paplay")) {
887
- runCommand("paplay", [tmpFile], 60000);
888
- }
889
- else if (commandExists("ffplay")) {
890
- runCommand("ffplay", ["-autoexit", "-nodisp", tmpFile], 60000);
891
- }
892
- else {
893
- throw new Error("No audio playback tool available.");
894
- }
895
- }
896
- else if (os === "win32") {
897
- const escapedPath = tmpFile.replace(/\//g, "\\").replace(/'/g, "''");
898
- runCommand("powershell", [
899
- "-Command",
900
- `(New-Object Media.SoundPlayer '${escapedPath}').PlaySync()`,
901
- ], 60000);
902
- }
903
- }
904
- finally {
905
- try {
906
- unlinkSync(tmpFile);
907
- }
908
- catch {
909
- /* cleanup */
910
- }
911
- }
912
- }
913
- function toAppleScriptStringLiteral(value) {
914
- return `"${value.replace(/\\/g, "\\\\").replace(/"/g, '\\"')}"`;
915
- }
916
- function performClick(x, y, button) {
917
- const os = platform();
918
- if (os === "darwin") {
919
- // Use cliclick on macOS (brew install cliclick)
920
- if (commandExists("cliclick")) {
921
- const btn = button === "right" ? "rc" : "c";
922
- runCommand("cliclick", [`${btn}:${x},${y}`], 5000);
923
- }
924
- else {
925
- // AppleScript fallback
926
- runCommand("osascript", ["-e", `tell application "System Events" to click at {${x}, ${y}}`], 5000);
927
- }
928
- }
929
- else if (os === "linux") {
930
- if (commandExists("xdotool")) {
931
- const btn = button === "right" ? "3" : "1";
932
- runCommand("xdotool", ["mousemove", String(x), String(y), "click", btn], 5000);
933
- }
934
- else {
935
- throw new Error("xdotool required for mouse control on Linux.");
936
- }
937
- }
938
- else if (os === "win32") {
939
- // Use Win32 API via PowerShell to perform an actual mouse click
940
- const psScript = [
941
- `Add-Type -AssemblyName System.Windows.Forms`,
942
- `[System.Windows.Forms.Cursor]::Position = New-Object System.Drawing.Point(${x},${y})`,
943
- `Add-Type -MemberDefinition '[DllImport("user32.dll")] public static extern void mouse_event(int dwFlags, int dx, int dy, int dwData, int dwExtraInfo);' -Name Win32Mouse -Namespace Win32`,
944
- button === "right"
945
- ? `[Win32.Win32Mouse]::mouse_event(0x0008, 0, 0, 0, 0); [Win32.Win32Mouse]::mouse_event(0x0010, 0, 0, 0, 0)` // right down + up
946
- : `[Win32.Win32Mouse]::mouse_event(0x0002, 0, 0, 0, 0); [Win32.Win32Mouse]::mouse_event(0x0004, 0, 0, 0, 0)`, // left down + up
947
- ].join("; ");
948
- runCommand("powershell", ["-Command", psScript], 5000);
949
- }
950
- }
951
- function performType(text) {
952
- const os = platform();
953
- if (os === "darwin") {
954
- if (commandExists("cliclick")) {
955
- runCommand("cliclick", [`t:${text}`], 10000);
956
- }
957
- else {
958
- runCommand("osascript", [
959
- "-e",
960
- `tell application "System Events" to keystroke ${toAppleScriptStringLiteral(text)}`,
961
- ], 10000);
962
- }
963
- }
964
- else if (os === "linux") {
965
- if (commandExists("xdotool")) {
966
- runCommand("xdotool", ["type", "--", text], 10000);
967
- }
968
- else {
969
- throw new Error("xdotool required for keyboard input on Linux.");
970
- }
971
- }
972
- else if (os === "win32") {
973
- const escaped = text.replace(/'/g, "''");
974
- runCommand("powershell", [
975
- "-Command",
976
- `Add-Type -AssemblyName System.Windows.Forms; [System.Windows.Forms.SendKeys]::SendWait('${escaped}')`,
977
- ], 10000);
978
- }
979
- }
980
- function performKeypress(keys) {
981
- const os = platform();
982
- if (os === "darwin") {
983
- if (commandExists("cliclick")) {
984
- runCommand("cliclick", [`kp:${keys}`], 5000);
985
- }
986
- else {
987
- const symbolicKeyCodes = {
988
- return: 36,
989
- enter: 36,
990
- tab: 48,
991
- space: 49,
992
- escape: 53,
993
- esc: 53,
994
- left: 123,
995
- right: 124,
996
- down: 125,
997
- up: 126,
998
- };
999
- const normalized = keys.trim().toLowerCase();
1000
- const mappedCode = symbolicKeyCodes[normalized];
1001
- const numericCode = mappedCode ??
1002
- (Number.isInteger(Number(keys.trim())) ? Number(keys.trim()) : null);
1003
- if (numericCode !== null) {
1004
- runCommand("osascript", ["-e", `tell application "System Events" to key code ${numericCode}`], 5000);
1005
- }
1006
- else {
1007
- runCommand("osascript", [
1008
- "-e",
1009
- `tell application "System Events" to keystroke ${toAppleScriptStringLiteral(keys)}`,
1010
- ], 5000);
1011
- }
1012
- }
1013
- }
1014
- else if (os === "linux") {
1015
- if (commandExists("xdotool")) {
1016
- runCommand("xdotool", ["key", keys], 5000);
1017
- }
1018
- else {
1019
- throw new Error("xdotool required for key input on Linux.");
1020
- }
1021
- }
1022
- else if (os === "win32") {
1023
- const escaped = keys.replace(/'/g, "''");
1024
- runCommand("powershell", [
1025
- "-Command",
1026
- `Add-Type -AssemblyName System.Windows.Forms; [System.Windows.Forms.SendKeys]::SendWait('${escaped}')`,
1027
- ], 5000);
1028
- }
1029
- }
1030
- function detectCapabilities() {
1031
- const os = platform();
1032
- const caps = {};
1033
- // Screenshot
1034
- if (os === "darwin") {
1035
- caps.screenshot = { available: true, tool: "screencapture (built-in)" };
1036
- }
1037
- else if (os === "linux") {
1038
- if (commandExists("import"))
1039
- caps.screenshot = { available: true, tool: "ImageMagick import" };
1040
- else if (commandExists("scrot"))
1041
- caps.screenshot = { available: true, tool: "scrot" };
1042
- else if (commandExists("gnome-screenshot"))
1043
- caps.screenshot = { available: true, tool: "gnome-screenshot" };
1044
- else
1045
- caps.screenshot = {
1046
- available: false,
1047
- tool: "none (install ImageMagick, scrot, or gnome-screenshot)",
1048
- };
1049
- }
1050
- else if (os === "win32") {
1051
- caps.screenshot = { available: true, tool: "PowerShell System.Drawing" };
1052
- }
1053
- else {
1054
- caps.screenshot = { available: false, tool: "unsupported platform" };
1055
- }
1056
- // Audio record
1057
- if (os === "darwin") {
1058
- if (commandExists("rec"))
1059
- caps.audioRecord = { available: true, tool: "sox rec" };
1060
- else if (commandExists("ffmpeg"))
1061
- caps.audioRecord = { available: true, tool: "ffmpeg" };
1062
- else
1063
- caps.audioRecord = {
1064
- available: false,
1065
- tool: "none (install sox or ffmpeg)",
1066
- };
1067
- }
1068
- else if (os === "linux") {
1069
- if (commandExists("arecord"))
1070
- caps.audioRecord = { available: true, tool: "arecord" };
1071
- else if (commandExists("ffmpeg"))
1072
- caps.audioRecord = { available: true, tool: "ffmpeg" };
1073
- else
1074
- caps.audioRecord = {
1075
- available: false,
1076
- tool: "none (install alsa-utils or ffmpeg)",
1077
- };
1078
- }
1079
- else if (os === "win32") {
1080
- if (commandExists("ffmpeg"))
1081
- caps.audioRecord = { available: true, tool: "ffmpeg" };
1082
- else
1083
- caps.audioRecord = { available: false, tool: "none (install ffmpeg)" };
1084
- }
1085
- else {
1086
- caps.audioRecord = { available: false, tool: "unsupported" };
1087
- }
1088
- // Audio play
1089
- if (os === "darwin")
1090
- caps.audioPlay = { available: true, tool: "afplay (built-in)" };
1091
- else if (os === "linux") {
1092
- if (commandExists("aplay"))
1093
- caps.audioPlay = { available: true, tool: "aplay" };
1094
- else if (commandExists("paplay"))
1095
- caps.audioPlay = { available: true, tool: "paplay" };
1096
- else if (commandExists("ffplay"))
1097
- caps.audioPlay = { available: true, tool: "ffplay" };
1098
- else
1099
- caps.audioPlay = { available: false, tool: "none" };
1100
- }
1101
- else if (os === "win32") {
1102
- caps.audioPlay = { available: true, tool: "PowerShell SoundPlayer" };
1103
- }
1104
- else {
1105
- caps.audioPlay = { available: false, tool: "unsupported" };
1106
- }
1107
- // Mouse/keyboard control
1108
- if (os === "darwin") {
1109
- if (commandExists("cliclick"))
1110
- caps.computerUse = { available: true, tool: "cliclick" };
1111
- else
1112
- caps.computerUse = { available: true, tool: "AppleScript (limited)" };
1113
- }
1114
- else if (os === "linux") {
1115
- if (commandExists("xdotool"))
1116
- caps.computerUse = { available: true, tool: "xdotool" };
1117
- else
1118
- caps.computerUse = { available: false, tool: "none (install xdotool)" };
1119
- }
1120
- else if (os === "win32") {
1121
- caps.computerUse = { available: true, tool: "PowerShell SendKeys" };
1122
- }
1123
- else {
1124
- caps.computerUse = { available: false, tool: "unsupported" };
1125
- }
1126
- // Window listing
1127
- if (os === "darwin")
1128
- caps.windowList = { available: true, tool: "AppleScript" };
1129
- else if (os === "linux") {
1130
- if (commandExists("wmctrl"))
1131
- caps.windowList = { available: true, tool: "wmctrl" };
1132
- else if (commandExists("xdotool"))
1133
- caps.windowList = { available: true, tool: "xdotool" };
1134
- else
1135
- caps.windowList = {
1136
- available: false,
1137
- tool: "none (install wmctrl or xdotool)",
1138
- };
1139
- }
1140
- else if (os === "win32") {
1141
- caps.windowList = { available: true, tool: "PowerShell Get-Process" };
1142
- }
1143
- else {
1144
- caps.windowList = { available: false, tool: "unsupported" };
1145
- }
1146
- // Browser
1147
- caps.browser = { available: true, tool: "CDP via sandbox browser container" };
1148
- // Shell
1149
- caps.shell = { available: true, tool: "docker exec" };
1150
- return caps;
1151
- }
1152
- function getPlatformInfo() {
1153
- const os = platform();
1154
- let dockerInstalled = false;
1155
- let dockerRunning = false;
1156
- let appleContainerAvailable = false;
1157
- // Check if docker binary exists (installed)
1158
- try {
1159
- const which = os === "win32" ? "where" : "which";
1160
- execSync(`${which} docker`, { stdio: "ignore", timeout: 3000 });
1161
- dockerInstalled = true;
1162
- }
1163
- catch {
1164
- /* not installed */
1165
- }
1166
- // Check if docker daemon is running (docker info succeeds only when daemon is up)
1167
- if (dockerInstalled) {
1168
- try {
1169
- execSync("docker info", { stdio: "ignore", timeout: 5000 });
1170
- dockerRunning = true;
1171
- }
1172
- catch {
1173
- /* installed but not running */
1174
- }
1175
- }
1176
- if (os === "darwin") {
1177
- try {
1178
- execSync("which container", { stdio: "ignore", timeout: 3000 });
1179
- appleContainerAvailable = true;
1180
- }
1181
- catch {
1182
- /* */
1183
- }
1184
- }
1185
- return {
1186
- platform: os,
1187
- arch: require("node:os").arch(),
1188
- dockerInstalled,
1189
- dockerRunning,
1190
- // Legacy compat: dockerAvailable = running (old clients check this)
1191
- dockerAvailable: dockerRunning,
1192
- appleContainerAvailable,
1193
- wsl2: os === "win32" ? isWsl2Available() : false,
1194
- recommended: os === "darwin" && appleContainerAvailable ? "apple-container" : "docker",
1195
- };
1196
- }
1197
- function isWsl2Available() {
1198
- try {
1199
- execSync("wsl --status", { stdio: "ignore", timeout: 5000 });
1200
- return true;
1201
- }
1202
- catch {
1203
- return false;
1204
- }
1205
- }
1206
- function attemptDockerStart() {
1207
- const os = platform();
1208
- try {
1209
- if (os === "darwin") {
1210
- execSync('open -a "Docker"', { timeout: 5000, stdio: "ignore" });
1211
- return {
1212
- success: true,
1213
- message: "Docker Desktop is starting on macOS. Give it a moment~",
1214
- waitMs: 15000,
1215
- };
1216
- }
1217
- if (os === "win32") {
1218
- // Try common install locations
1219
- const paths = [
1220
- '"C:\\Program Files\\Docker\\Docker\\Docker Desktop.exe"',
1221
- '"C:\\Program Files (x86)\\Docker\\Docker\\Docker Desktop.exe"',
1222
- ];
1223
- let started = false;
1224
- for (const p of paths) {
1225
- try {
1226
- execSync(`start "" ${p}`, {
1227
- timeout: 5000,
1228
- stdio: "ignore",
1229
- shell: "cmd.exe",
1230
- });
1231
- started = true;
1232
- break;
1233
- }
1234
- catch {
1235
- /* try next path */
1236
- }
1237
- }
1238
- if (!started) {
1239
- // Try via start menu
1240
- execSync('start "" "Docker Desktop"', {
1241
- timeout: 5000,
1242
- stdio: "ignore",
1243
- shell: "cmd.exe",
1244
- });
1245
- }
1246
- return {
1247
- success: true,
1248
- message: "Docker Desktop is starting on Windows. This may take 30 seconds~",
1249
- waitMs: 30000,
1250
- };
1251
- }
1252
- if (os === "linux") {
1253
- // Try systemctl first (most common)
1254
- try {
1255
- execSync("sudo systemctl start docker", {
1256
- timeout: 10000,
1257
- stdio: "ignore",
1258
- });
1259
- return {
1260
- success: true,
1261
- message: "Docker daemon started via systemctl",
1262
- waitMs: 5000,
1263
- };
1264
- }
1265
- catch {
1266
- /* systemctl may not be available */
1267
- }
1268
- // Try service command
1269
- try {
1270
- execSync("sudo service docker start", {
1271
- timeout: 10000,
1272
- stdio: "ignore",
1273
- });
1274
- return {
1275
- success: true,
1276
- message: "Docker daemon started via service",
1277
- waitMs: 5000,
1278
- };
1279
- }
1280
- catch {
1281
- /* */
1282
- }
1283
- return {
1284
- success: false,
1285
- message: "Could not auto-start Docker on Linux. Run: sudo systemctl start docker",
1286
- waitMs: 0,
1287
- };
1288
- }
1289
- return {
1290
- success: false,
1291
- message: `Auto-start not supported on ${os}`,
1292
- waitMs: 0,
1293
- };
1294
- }
1295
- catch (err) {
1296
- return {
1297
- success: false,
1298
- message: `Failed: ${err instanceof Error ? err.message : String(err)}`,
1299
- waitMs: 0,
1300
- };
1301
- }
1302
- }
1303
- // ── Helpers ──────────────────────────────────────────────────────────────────
1304
- function commandExists(cmd) {
1305
- try {
1306
- const which = platform() === "win32" ? "where" : "which";
1307
- execSync(`${which} ${cmd}`, { stdio: "ignore", timeout: 3000 });
1308
- return true;
1309
- }
1310
- catch {
1311
- return false;
1312
- }
1313
- }
1314
- function sendJson(res, status, data) {
1315
- sendJsonResponse(res, data, status);
1316
- }
1317
- function readBody(req) {
1318
- return readRequestBody(req, {
1319
- maxBytes: 10 * 1024 * 1024,
1320
- returnNullOnTooLarge: true,
1321
- returnNullOnError: true,
1322
- destroyOnTooLarge: true,
1323
- });
1324
- }
1325
- function readJsonBody(req, res) {
1326
- return parseJsonBody(req, res, {
1327
- maxBytes: 10 * 1024 * 1024,
1328
- requireObject: false,
1329
- readErrorStatus: 400,
1330
- parseErrorStatus: 400,
1331
- readErrorMessage: "Missing request body",
1332
- parseErrorMessage: "Invalid JSON in request body",
1333
- });
1334
- }