@agenticmail/enterprise 0.5.327 → 0.5.329

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 (888) hide show
  1. package/dist/agent-tools-F3CYENMK.js +13949 -0
  2. package/dist/browser-tool-P57PLVW2.js +4002 -0
  3. package/dist/chunk-3RI3AIJN.js +1519 -0
  4. package/dist/chunk-AD4DFKHR.js +4928 -0
  5. package/dist/chunk-UQXPVWXG.js +5101 -0
  6. package/dist/cli-agent-K6UFZRXC.js +2473 -0
  7. package/dist/cli-serve-4MT7RDEL.js +260 -0
  8. package/dist/cli.js +3 -3
  9. package/dist/dashboard/app.js +1 -1
  10. package/dist/dashboard/components/transport-encryption.js +0 -62
  11. package/dist/dashboard/pages/agent-detail/index.js +5 -2
  12. package/dist/dashboard/pages/agent-detail/manager.js +1 -1
  13. package/dist/dashboard/pages/agent-detail/overview.js +4 -2
  14. package/dist/dashboard/pages/agent-detail/tool-security.js +1 -1
  15. package/dist/dashboard/pages/domain-status.js +3 -6
  16. package/dist/dashboard/pages/memory-transfer.js +1 -1
  17. package/dist/dashboard/pages/messages.js +0 -1
  18. package/dist/dashboard/pages/roles.js +0 -2
  19. package/dist/dashboard/pages/workforce.js +0 -1
  20. package/dist/index.js +3 -3
  21. package/dist/runtime-L5ADJORP.js +45 -0
  22. package/dist/server-KSN56EZQ.js +28 -0
  23. package/dist/setup-UUNBBOQH.js +20 -0
  24. package/logs/cloudflared-error.log +42 -0
  25. package/logs/enterprise-out.log +6 -0
  26. package/package.json +1 -1
  27. package/src/admin/page-registry.ts +0 -290
  28. package/src/admin/routes.ts +0 -2968
  29. package/src/agent-tools/common.ts +0 -260
  30. package/src/agent-tools/index.ts +0 -542
  31. package/src/agent-tools/merge.ts +0 -62
  32. package/src/agent-tools/middleware.ts +0 -436
  33. package/src/agent-tools/schema/typebox.ts +0 -25
  34. package/src/agent-tools/security.ts +0 -352
  35. package/src/agent-tools/tool-resolver.ts +0 -1018
  36. package/src/agent-tools/tools/agenticmail.ts +0 -1017
  37. package/src/agent-tools/tools/bash.ts +0 -179
  38. package/src/agent-tools/tools/browser-tool.schema.ts +0 -112
  39. package/src/agent-tools/tools/browser-tool.ts +0 -388
  40. package/src/agent-tools/tools/browser.ts +0 -764
  41. package/src/agent-tools/tools/edit.ts +0 -100
  42. package/src/agent-tools/tools/enterprise-code-sandbox.ts +0 -395
  43. package/src/agent-tools/tools/enterprise-database.ts +0 -377
  44. package/src/agent-tools/tools/enterprise-diff.ts +0 -580
  45. package/src/agent-tools/tools/enterprise-documents.ts +0 -896
  46. package/src/agent-tools/tools/enterprise-http.ts +0 -485
  47. package/src/agent-tools/tools/enterprise-security-scan.ts +0 -528
  48. package/src/agent-tools/tools/enterprise-spreadsheet.ts +0 -825
  49. package/src/agent-tools/tools/glob.ts +0 -129
  50. package/src/agent-tools/tools/google/calendar.ts +0 -230
  51. package/src/agent-tools/tools/google/chat.ts +0 -725
  52. package/src/agent-tools/tools/google/contacts.ts +0 -209
  53. package/src/agent-tools/tools/google/docs.ts +0 -162
  54. package/src/agent-tools/tools/google/drive.ts +0 -392
  55. package/src/agent-tools/tools/google/forms.ts +0 -367
  56. package/src/agent-tools/tools/google/gmail.ts +0 -897
  57. package/src/agent-tools/tools/google/index.ts +0 -86
  58. package/src/agent-tools/tools/google/maps.ts +0 -543
  59. package/src/agent-tools/tools/google/meeting-voice.ts +0 -885
  60. package/src/agent-tools/tools/google/meetings.ts +0 -1094
  61. package/src/agent-tools/tools/google/sheets.ts +0 -215
  62. package/src/agent-tools/tools/google/slides.ts +0 -559
  63. package/src/agent-tools/tools/google/tasks.ts +0 -200
  64. package/src/agent-tools/tools/grep.ts +0 -178
  65. package/src/agent-tools/tools/integrations/_factory.ts +0 -102
  66. package/src/agent-tools/tools/integrations/activecampaign.ts +0 -14
  67. package/src/agent-tools/tools/integrations/adobe-sign.ts +0 -14
  68. package/src/agent-tools/tools/integrations/adp.ts +0 -14
  69. package/src/agent-tools/tools/integrations/airtable.ts +0 -14
  70. package/src/agent-tools/tools/integrations/apollo.ts +0 -14
  71. package/src/agent-tools/tools/integrations/asana.ts +0 -14
  72. package/src/agent-tools/tools/integrations/auth0.ts +0 -14
  73. package/src/agent-tools/tools/integrations/aws.ts +0 -14
  74. package/src/agent-tools/tools/integrations/azure-devops.ts +0 -14
  75. package/src/agent-tools/tools/integrations/bamboohr.ts +0 -14
  76. package/src/agent-tools/tools/integrations/basecamp.ts +0 -14
  77. package/src/agent-tools/tools/integrations/bigcommerce.ts +0 -14
  78. package/src/agent-tools/tools/integrations/bitbucket.ts +0 -14
  79. package/src/agent-tools/tools/integrations/box.ts +0 -14
  80. package/src/agent-tools/tools/integrations/brex.ts +0 -14
  81. package/src/agent-tools/tools/integrations/buffer.ts +0 -14
  82. package/src/agent-tools/tools/integrations/calendly.ts +0 -14
  83. package/src/agent-tools/tools/integrations/canva.ts +0 -14
  84. package/src/agent-tools/tools/integrations/chargebee.ts +0 -14
  85. package/src/agent-tools/tools/integrations/circleci.ts +0 -14
  86. package/src/agent-tools/tools/integrations/clickup.ts +0 -14
  87. package/src/agent-tools/tools/integrations/close.ts +0 -14
  88. package/src/agent-tools/tools/integrations/cloudflare.ts +0 -14
  89. package/src/agent-tools/tools/integrations/confluence.ts +0 -14
  90. package/src/agent-tools/tools/integrations/contentful.ts +0 -14
  91. package/src/agent-tools/tools/integrations/copper.ts +0 -14
  92. package/src/agent-tools/tools/integrations/crisp.ts +0 -14
  93. package/src/agent-tools/tools/integrations/crowdstrike.ts +0 -14
  94. package/src/agent-tools/tools/integrations/datadog.ts +0 -14
  95. package/src/agent-tools/tools/integrations/digitalocean.ts +0 -14
  96. package/src/agent-tools/tools/integrations/discord.ts +0 -14
  97. package/src/agent-tools/tools/integrations/docker.ts +0 -14
  98. package/src/agent-tools/tools/integrations/docusign.ts +0 -14
  99. package/src/agent-tools/tools/integrations/drift.ts +0 -14
  100. package/src/agent-tools/tools/integrations/dropbox.ts +0 -14
  101. package/src/agent-tools/tools/integrations/figma.ts +0 -14
  102. package/src/agent-tools/tools/integrations/firebase.ts +0 -14
  103. package/src/agent-tools/tools/integrations/flyio.ts +0 -14
  104. package/src/agent-tools/tools/integrations/freshbooks.ts +0 -14
  105. package/src/agent-tools/tools/integrations/freshdesk.ts +0 -14
  106. package/src/agent-tools/tools/integrations/freshsales.ts +0 -14
  107. package/src/agent-tools/tools/integrations/freshservice.ts +0 -14
  108. package/src/agent-tools/tools/integrations/front.ts +0 -14
  109. package/src/agent-tools/tools/integrations/github-actions.ts +0 -14
  110. package/src/agent-tools/tools/integrations/github.ts +0 -14
  111. package/src/agent-tools/tools/integrations/gitlab.ts +0 -14
  112. package/src/agent-tools/tools/integrations/gong.ts +0 -14
  113. package/src/agent-tools/tools/integrations/google-ads.ts +0 -14
  114. package/src/agent-tools/tools/integrations/google-analytics.ts +0 -14
  115. package/src/agent-tools/tools/integrations/google-cloud.ts +0 -14
  116. package/src/agent-tools/tools/integrations/gotomeeting.ts +0 -14
  117. package/src/agent-tools/tools/integrations/grafana.ts +0 -14
  118. package/src/agent-tools/tools/integrations/greenhouse.ts +0 -14
  119. package/src/agent-tools/tools/integrations/gusto.ts +0 -14
  120. package/src/agent-tools/tools/integrations/hashicorp-vault.ts +0 -14
  121. package/src/agent-tools/tools/integrations/heroku.ts +0 -14
  122. package/src/agent-tools/tools/integrations/hibob.ts +0 -14
  123. package/src/agent-tools/tools/integrations/hootsuite.ts +0 -14
  124. package/src/agent-tools/tools/integrations/hubspot.ts +0 -14
  125. package/src/agent-tools/tools/integrations/huggingface.ts +0 -14
  126. package/src/agent-tools/tools/integrations/index.ts +0 -474
  127. package/src/agent-tools/tools/integrations/intercom.ts +0 -14
  128. package/src/agent-tools/tools/integrations/jira.ts +0 -14
  129. package/src/agent-tools/tools/integrations/klaviyo.ts +0 -14
  130. package/src/agent-tools/tools/integrations/kubernetes.ts +0 -14
  131. package/src/agent-tools/tools/integrations/lattice.ts +0 -14
  132. package/src/agent-tools/tools/integrations/launchdarkly.ts +0 -14
  133. package/src/agent-tools/tools/integrations/lever.ts +0 -14
  134. package/src/agent-tools/tools/integrations/linear.ts +0 -14
  135. package/src/agent-tools/tools/integrations/linkedin.ts +0 -14
  136. package/src/agent-tools/tools/integrations/livechat.ts +0 -14
  137. package/src/agent-tools/tools/integrations/loom.ts +0 -14
  138. package/src/agent-tools/tools/integrations/mailchimp.ts +0 -14
  139. package/src/agent-tools/tools/integrations/mailgun.ts +0 -14
  140. package/src/agent-tools/tools/integrations/miro.ts +0 -14
  141. package/src/agent-tools/tools/integrations/mixpanel.ts +0 -14
  142. package/src/agent-tools/tools/integrations/monday.ts +0 -14
  143. package/src/agent-tools/tools/integrations/mongodb-atlas.ts +0 -14
  144. package/src/agent-tools/tools/integrations/neon.ts +0 -14
  145. package/src/agent-tools/tools/integrations/netlify.ts +0 -14
  146. package/src/agent-tools/tools/integrations/netsuite.ts +0 -14
  147. package/src/agent-tools/tools/integrations/newrelic.ts +0 -14
  148. package/src/agent-tools/tools/integrations/notion.ts +0 -14
  149. package/src/agent-tools/tools/integrations/okta.ts +0 -14
  150. package/src/agent-tools/tools/integrations/openai.ts +0 -14
  151. package/src/agent-tools/tools/integrations/opsgenie.ts +0 -14
  152. package/src/agent-tools/tools/integrations/outreach.ts +0 -14
  153. package/src/agent-tools/tools/integrations/paddle.ts +0 -14
  154. package/src/agent-tools/tools/integrations/pagerduty.ts +0 -14
  155. package/src/agent-tools/tools/integrations/pandadoc.ts +0 -14
  156. package/src/agent-tools/tools/integrations/paypal.ts +0 -14
  157. package/src/agent-tools/tools/integrations/personio.ts +0 -14
  158. package/src/agent-tools/tools/integrations/pinecone.ts +0 -14
  159. package/src/agent-tools/tools/integrations/pipedrive.ts +0 -14
  160. package/src/agent-tools/tools/integrations/plaid.ts +0 -14
  161. package/src/agent-tools/tools/integrations/postmark.ts +0 -14
  162. package/src/agent-tools/tools/integrations/power-automate.ts +0 -14
  163. package/src/agent-tools/tools/integrations/quickbooks.ts +0 -14
  164. package/src/agent-tools/tools/integrations/recurly.ts +0 -14
  165. package/src/agent-tools/tools/integrations/reddit.ts +0 -14
  166. package/src/agent-tools/tools/integrations/render.ts +0 -14
  167. package/src/agent-tools/tools/integrations/ringcentral.ts +0 -14
  168. package/src/agent-tools/tools/integrations/rippling.ts +0 -14
  169. package/src/agent-tools/tools/integrations/salesforce.ts +0 -14
  170. package/src/agent-tools/tools/integrations/salesloft.ts +0 -14
  171. package/src/agent-tools/tools/integrations/sanity.ts +0 -14
  172. package/src/agent-tools/tools/integrations/sap.ts +0 -14
  173. package/src/agent-tools/tools/integrations/segment.ts +0 -14
  174. package/src/agent-tools/tools/integrations/sendgrid.ts +0 -14
  175. package/src/agent-tools/tools/integrations/sentry.ts +0 -14
  176. package/src/agent-tools/tools/integrations/servicenow.ts +0 -14
  177. package/src/agent-tools/tools/integrations/shopify.ts +0 -14
  178. package/src/agent-tools/tools/integrations/shortcut.ts +0 -14
  179. package/src/agent-tools/tools/integrations/slack.ts +0 -14
  180. package/src/agent-tools/tools/integrations/smartsheet.ts +0 -14
  181. package/src/agent-tools/tools/integrations/snowflake.ts +0 -14
  182. package/src/agent-tools/tools/integrations/snyk.ts +0 -14
  183. package/src/agent-tools/tools/integrations/splunk.ts +0 -14
  184. package/src/agent-tools/tools/integrations/square.ts +0 -14
  185. package/src/agent-tools/tools/integrations/statuspage.ts +0 -14
  186. package/src/agent-tools/tools/integrations/stripe.ts +0 -14
  187. package/src/agent-tools/tools/integrations/supabase.ts +0 -14
  188. package/src/agent-tools/tools/integrations/teamwork.ts +0 -14
  189. package/src/agent-tools/tools/integrations/telegram.ts +0 -14
  190. package/src/agent-tools/tools/integrations/terraform.ts +0 -14
  191. package/src/agent-tools/tools/integrations/todoist.ts +0 -14
  192. package/src/agent-tools/tools/integrations/trello.ts +0 -14
  193. package/src/agent-tools/tools/integrations/twilio.ts +0 -14
  194. package/src/agent-tools/tools/integrations/twitter.ts +0 -14
  195. package/src/agent-tools/tools/integrations/vercel.ts +0 -14
  196. package/src/agent-tools/tools/integrations/weaviate.ts +0 -14
  197. package/src/agent-tools/tools/integrations/webex.ts +0 -14
  198. package/src/agent-tools/tools/integrations/webflow.ts +0 -14
  199. package/src/agent-tools/tools/integrations/whatsapp.ts +0 -14
  200. package/src/agent-tools/tools/integrations/whereby.ts +0 -14
  201. package/src/agent-tools/tools/integrations/woocommerce.ts +0 -14
  202. package/src/agent-tools/tools/integrations/wordpress.ts +0 -14
  203. package/src/agent-tools/tools/integrations/workday.ts +0 -14
  204. package/src/agent-tools/tools/integrations/wrike.ts +0 -14
  205. package/src/agent-tools/tools/integrations/xero.ts +0 -14
  206. package/src/agent-tools/tools/integrations/youtube.ts +0 -14
  207. package/src/agent-tools/tools/integrations/zendesk.ts +0 -14
  208. package/src/agent-tools/tools/integrations/zoho-crm.ts +0 -14
  209. package/src/agent-tools/tools/integrations/zoom.ts +0 -14
  210. package/src/agent-tools/tools/integrations/zuora.ts +0 -14
  211. package/src/agent-tools/tools/knowledge-search.ts +0 -318
  212. package/src/agent-tools/tools/local/coding.ts +0 -626
  213. package/src/agent-tools/tools/local/dependency-manager.ts +0 -647
  214. package/src/agent-tools/tools/local/file-edit.ts +0 -31
  215. package/src/agent-tools/tools/local/file-list.ts +0 -39
  216. package/src/agent-tools/tools/local/file-ops.ts +0 -48
  217. package/src/agent-tools/tools/local/file-read.ts +0 -39
  218. package/src/agent-tools/tools/local/file-search.ts +0 -46
  219. package/src/agent-tools/tools/local/file-write.ts +0 -28
  220. package/src/agent-tools/tools/local/filesystem.ts +0 -5
  221. package/src/agent-tools/tools/local/index.ts +0 -55
  222. package/src/agent-tools/tools/local/resolve-path.ts +0 -18
  223. package/src/agent-tools/tools/local/shell.ts +0 -277
  224. package/src/agent-tools/tools/local/system-info.ts +0 -29
  225. package/src/agent-tools/tools/management.ts +0 -425
  226. package/src/agent-tools/tools/mcp-bridge.ts +0 -142
  227. package/src/agent-tools/tools/mcp-server-tools.ts +0 -91
  228. package/src/agent-tools/tools/meeting-lifecycle.ts +0 -438
  229. package/src/agent-tools/tools/memory.ts +0 -509
  230. package/src/agent-tools/tools/messaging/index.ts +0 -6
  231. package/src/agent-tools/tools/messaging/telegram.ts +0 -167
  232. package/src/agent-tools/tools/messaging/whatsapp.ts +0 -651
  233. package/src/agent-tools/tools/microsoft/contacts.ts +0 -176
  234. package/src/agent-tools/tools/microsoft/excel-vba.ts +0 -331
  235. package/src/agent-tools/tools/microsoft/excel.ts +0 -261
  236. package/src/agent-tools/tools/microsoft/graph-api.ts +0 -161
  237. package/src/agent-tools/tools/microsoft/index.ts +0 -95
  238. package/src/agent-tools/tools/microsoft/onedrive.ts +0 -429
  239. package/src/agent-tools/tools/microsoft/onenote.ts +0 -186
  240. package/src/agent-tools/tools/microsoft/outlook-calendar.ts +0 -286
  241. package/src/agent-tools/tools/microsoft/outlook-mail.ts +0 -723
  242. package/src/agent-tools/tools/microsoft/planner.ts +0 -200
  243. package/src/agent-tools/tools/microsoft/powerbi.ts +0 -266
  244. package/src/agent-tools/tools/microsoft/powerpoint.ts +0 -186
  245. package/src/agent-tools/tools/microsoft/sharepoint.ts +0 -328
  246. package/src/agent-tools/tools/microsoft/teams.ts +0 -463
  247. package/src/agent-tools/tools/microsoft/todo.ts +0 -181
  248. package/src/agent-tools/tools/oauth-token-provider.ts +0 -101
  249. package/src/agent-tools/tools/read.ts +0 -160
  250. package/src/agent-tools/tools/visual-memory/capture.ts +0 -217
  251. package/src/agent-tools/tools/visual-memory/diff.ts +0 -283
  252. package/src/agent-tools/tools/visual-memory/index.ts +0 -698
  253. package/src/agent-tools/tools/visual-memory/phash.ts +0 -120
  254. package/src/agent-tools/tools/visual-memory/similarity.ts +0 -354
  255. package/src/agent-tools/tools/visual-memory/storage.ts +0 -534
  256. package/src/agent-tools/tools/visual-memory/types.ts +0 -100
  257. package/src/agent-tools/tools/web-fetch-utils.ts +0 -202
  258. package/src/agent-tools/tools/web-fetch.ts +0 -464
  259. package/src/agent-tools/tools/web-search.ts +0 -480
  260. package/src/agent-tools/tools/web-shared.ts +0 -232
  261. package/src/agent-tools/tools/write.ts +0 -68
  262. package/src/agent-tools/types.ts +0 -214
  263. package/src/agenticmail/index.ts +0 -34
  264. package/src/agenticmail/manager.ts +0 -253
  265. package/src/agenticmail/providers/google.ts +0 -391
  266. package/src/agenticmail/providers/imap.ts +0 -454
  267. package/src/agenticmail/providers/index.ts +0 -28
  268. package/src/agenticmail/providers/microsoft.ts +0 -260
  269. package/src/agenticmail/types.ts +0 -173
  270. package/src/auth/routes.ts +0 -1589
  271. package/src/browser/bridge-auth-registry.ts +0 -34
  272. package/src/browser/bridge-server.ts +0 -93
  273. package/src/browser/cdp.helpers.ts +0 -180
  274. package/src/browser/cdp.ts +0 -466
  275. package/src/browser/chrome.executables.ts +0 -625
  276. package/src/browser/chrome.profile-decoration.ts +0 -198
  277. package/src/browser/chrome.ts +0 -349
  278. package/src/browser/client-actions-core.ts +0 -259
  279. package/src/browser/client-actions-observe.ts +0 -184
  280. package/src/browser/client-actions-state.ts +0 -284
  281. package/src/browser/client-actions-types.ts +0 -16
  282. package/src/browser/client-actions-url.ts +0 -11
  283. package/src/browser/client-actions.ts +0 -4
  284. package/src/browser/client-fetch.ts +0 -253
  285. package/src/browser/client.ts +0 -337
  286. package/src/browser/config.ts +0 -301
  287. package/src/browser/constants.ts +0 -8
  288. package/src/browser/control-auth.ts +0 -94
  289. package/src/browser/control-service.ts +0 -81
  290. package/src/browser/csrf.ts +0 -87
  291. package/src/browser/enterprise-compat.ts +0 -562
  292. package/src/browser/extension-relay.ts +0 -834
  293. package/src/browser/http-auth.ts +0 -63
  294. package/src/browser/navigation-guard.ts +0 -50
  295. package/src/browser/paths.ts +0 -49
  296. package/src/browser/playwright.d.ts +0 -12
  297. package/src/browser/profiles-service.ts +0 -187
  298. package/src/browser/profiles.ts +0 -114
  299. package/src/browser/proxy-files.ts +0 -41
  300. package/src/browser/pw-ai-module.ts +0 -52
  301. package/src/browser/pw-ai-state.ts +0 -9
  302. package/src/browser/pw-ai.ts +0 -65
  303. package/src/browser/pw-role-snapshot.ts +0 -434
  304. package/src/browser/pw-session.ts +0 -810
  305. package/src/browser/pw-tools-core.activity.ts +0 -68
  306. package/src/browser/pw-tools-core.downloads.ts +0 -281
  307. package/src/browser/pw-tools-core.interactions.ts +0 -646
  308. package/src/browser/pw-tools-core.responses.ts +0 -124
  309. package/src/browser/pw-tools-core.shared.ts +0 -70
  310. package/src/browser/pw-tools-core.snapshot.ts +0 -213
  311. package/src/browser/pw-tools-core.state.ts +0 -209
  312. package/src/browser/pw-tools-core.storage.ts +0 -128
  313. package/src/browser/pw-tools-core.trace.ts +0 -37
  314. package/src/browser/pw-tools-core.ts +0 -8
  315. package/src/browser/resolved-config-refresh.ts +0 -59
  316. package/src/browser/routes/agent.act.shared.ts +0 -52
  317. package/src/browser/routes/agent.act.ts +0 -575
  318. package/src/browser/routes/agent.debug.ts +0 -149
  319. package/src/browser/routes/agent.shared.ts +0 -143
  320. package/src/browser/routes/agent.snapshot.ts +0 -333
  321. package/src/browser/routes/agent.storage.ts +0 -451
  322. package/src/browser/routes/agent.ts +0 -13
  323. package/src/browser/routes/basic.ts +0 -202
  324. package/src/browser/routes/dispatcher.ts +0 -126
  325. package/src/browser/routes/index.ts +0 -11
  326. package/src/browser/routes/path-output.ts +0 -1
  327. package/src/browser/routes/tabs.ts +0 -217
  328. package/src/browser/routes/types.ts +0 -26
  329. package/src/browser/routes/utils.ts +0 -73
  330. package/src/browser/screenshot.ts +0 -54
  331. package/src/browser/server-context.ts +0 -688
  332. package/src/browser/server-context.types.ts +0 -65
  333. package/src/browser/server-lifecycle.ts +0 -48
  334. package/src/browser/server-middleware.ts +0 -37
  335. package/src/browser/server.ts +0 -110
  336. package/src/browser/target-id.ts +0 -30
  337. package/src/browser/trash.ts +0 -21
  338. package/src/cli-agent.ts +0 -2452
  339. package/src/cli-reset-password.ts +0 -138
  340. package/src/cli-serve.ts +0 -314
  341. package/src/cli.ts +0 -103
  342. package/src/dashboard/app.js +0 -579
  343. package/src/dashboard/assets/brand-logos.js +0 -350
  344. package/src/dashboard/assets/icons/emoji-icons.js +0 -893
  345. package/src/dashboard/assets/logo.png +0 -0
  346. package/src/dashboard/assets/provider-logos.js +0 -139
  347. package/src/dashboard/components/error-boundary.js +0 -21
  348. package/src/dashboard/components/help-button.js +0 -65
  349. package/src/dashboard/components/icons.js +0 -64
  350. package/src/dashboard/components/knowledge-link.js +0 -79
  351. package/src/dashboard/components/modal.js +0 -125
  352. package/src/dashboard/components/org-switcher.js +0 -156
  353. package/src/dashboard/components/persona-fields.js +0 -460
  354. package/src/dashboard/components/settings-help.js +0 -193
  355. package/src/dashboard/components/tag-input.js +0 -96
  356. package/src/dashboard/components/timezones.js +0 -352
  357. package/src/dashboard/components/transport-encryption.js +0 -288
  358. package/src/dashboard/components/utils.js +0 -205
  359. package/src/dashboard/data/countries.js +0 -255
  360. package/src/dashboard/docs/activity.html +0 -253
  361. package/src/dashboard/docs/agent-activity.html +0 -199
  362. package/src/dashboard/docs/agent-autonomy.html +0 -161
  363. package/src/dashboard/docs/agent-budget.html +0 -190
  364. package/src/dashboard/docs/agent-channels.html +0 -189
  365. package/src/dashboard/docs/agent-communication.html +0 -171
  366. package/src/dashboard/docs/agent-configuration.html +0 -194
  367. package/src/dashboard/docs/agent-deployment.html +0 -323
  368. package/src/dashboard/docs/agent-email.html +0 -184
  369. package/src/dashboard/docs/agent-guardrails.html +0 -206
  370. package/src/dashboard/docs/agent-manager.html +0 -226
  371. package/src/dashboard/docs/agent-memory.html +0 -215
  372. package/src/dashboard/docs/agent-overview.html +0 -226
  373. package/src/dashboard/docs/agent-permissions.html +0 -305
  374. package/src/dashboard/docs/agent-personal.html +0 -155
  375. package/src/dashboard/docs/agent-security.html +0 -188
  376. package/src/dashboard/docs/agent-skills.html +0 -224
  377. package/src/dashboard/docs/agent-tool-security.html +0 -205
  378. package/src/dashboard/docs/agent-tools.html +0 -238
  379. package/src/dashboard/docs/agent-whatsapp.html +0 -210
  380. package/src/dashboard/docs/agent-workforce.html +0 -199
  381. package/src/dashboard/docs/agents.html +0 -258
  382. package/src/dashboard/docs/approvals.html +0 -200
  383. package/src/dashboard/docs/audit.html +0 -206
  384. package/src/dashboard/docs/browser-providers.html +0 -313
  385. package/src/dashboard/docs/cluster.html +0 -285
  386. package/src/dashboard/docs/community-skills.html +0 -253
  387. package/src/dashboard/docs/compliance.html +0 -221
  388. package/src/dashboard/docs/dashboard.html +0 -84
  389. package/src/dashboard/docs/database-access.html +0 -322
  390. package/src/dashboard/docs/dlp.html +0 -268
  391. package/src/dashboard/docs/docs-style.css +0 -26
  392. package/src/dashboard/docs/domain-status.html +0 -294
  393. package/src/dashboard/docs/guardrails.html +0 -265
  394. package/src/dashboard/docs/journal.html +0 -197
  395. package/src/dashboard/docs/knowledge-contributions.html +0 -286
  396. package/src/dashboard/docs/knowledge.html +0 -268
  397. package/src/dashboard/docs/memory-transfer.html +0 -311
  398. package/src/dashboard/docs/messages.html +0 -217
  399. package/src/dashboard/docs/multi-tenant.html +0 -311
  400. package/src/dashboard/docs/org-chart.html +0 -239
  401. package/src/dashboard/docs/organizations.html +0 -182
  402. package/src/dashboard/docs/roles.html +0 -195
  403. package/src/dashboard/docs/settings-network.html +0 -321
  404. package/src/dashboard/docs/settings-security.html +0 -347
  405. package/src/dashboard/docs/settings-tool-security.html +0 -176
  406. package/src/dashboard/docs/settings.html +0 -280
  407. package/src/dashboard/docs/skill-connections.html +0 -270
  408. package/src/dashboard/docs/skills.html +0 -206
  409. package/src/dashboard/docs/task-pipeline.html +0 -261
  410. package/src/dashboard/docs/transport-encryption.html +0 -359
  411. package/src/dashboard/docs/users.html +0 -225
  412. package/src/dashboard/docs/vault.html +0 -260
  413. package/src/dashboard/docs/workforce.html +0 -245
  414. package/src/dashboard/index.html +0 -444
  415. package/src/dashboard/pages/activity.js +0 -379
  416. package/src/dashboard/pages/agent-detail/activity.js +0 -277
  417. package/src/dashboard/pages/agent-detail/autonomy.js +0 -244
  418. package/src/dashboard/pages/agent-detail/budget.js +0 -269
  419. package/src/dashboard/pages/agent-detail/channels.js +0 -494
  420. package/src/dashboard/pages/agent-detail/communication.js +0 -296
  421. package/src/dashboard/pages/agent-detail/configuration.js +0 -882
  422. package/src/dashboard/pages/agent-detail/deployment.js +0 -958
  423. package/src/dashboard/pages/agent-detail/email.js +0 -674
  424. package/src/dashboard/pages/agent-detail/guardrails.js +0 -521
  425. package/src/dashboard/pages/agent-detail/index.js +0 -261
  426. package/src/dashboard/pages/agent-detail/manager.js +0 -357
  427. package/src/dashboard/pages/agent-detail/meeting-browser.js +0 -933
  428. package/src/dashboard/pages/agent-detail/memory.js +0 -368
  429. package/src/dashboard/pages/agent-detail/overview.js +0 -844
  430. package/src/dashboard/pages/agent-detail/permissions.js +0 -1163
  431. package/src/dashboard/pages/agent-detail/personal-details.js +0 -404
  432. package/src/dashboard/pages/agent-detail/security.js +0 -409
  433. package/src/dashboard/pages/agent-detail/shared.js +0 -85
  434. package/src/dashboard/pages/agent-detail/skills-section.js +0 -183
  435. package/src/dashboard/pages/agent-detail/tool-security.js +0 -380
  436. package/src/dashboard/pages/agent-detail/tools.js +0 -322
  437. package/src/dashboard/pages/agent-detail/whatsapp.js +0 -824
  438. package/src/dashboard/pages/agent-detail/workforce.js +0 -683
  439. package/src/dashboard/pages/agents.js +0 -1242
  440. package/src/dashboard/pages/approvals.js +0 -100
  441. package/src/dashboard/pages/audit.js +0 -198
  442. package/src/dashboard/pages/cluster.js +0 -512
  443. package/src/dashboard/pages/community-skills.js +0 -1219
  444. package/src/dashboard/pages/compliance.js +0 -475
  445. package/src/dashboard/pages/dashboard.js +0 -180
  446. package/src/dashboard/pages/database-access.js +0 -812
  447. package/src/dashboard/pages/dlp.js +0 -293
  448. package/src/dashboard/pages/domain-status.js +0 -951
  449. package/src/dashboard/pages/guardrails.js +0 -1035
  450. package/src/dashboard/pages/journal.js +0 -172
  451. package/src/dashboard/pages/knowledge-contributions.js +0 -1682
  452. package/src/dashboard/pages/knowledge-import.js +0 -455
  453. package/src/dashboard/pages/knowledge.js +0 -582
  454. package/src/dashboard/pages/login.js +0 -1056
  455. package/src/dashboard/pages/memory-transfer.js +0 -631
  456. package/src/dashboard/pages/messages.js +0 -303
  457. package/src/dashboard/pages/org-chart.js +0 -349
  458. package/src/dashboard/pages/organizations.js +0 -1081
  459. package/src/dashboard/pages/roles.js +0 -780
  460. package/src/dashboard/pages/settings.js +0 -3790
  461. package/src/dashboard/pages/skill-connections.js +0 -982
  462. package/src/dashboard/pages/skills.js +0 -879
  463. package/src/dashboard/pages/task-pipeline.js +0 -684
  464. package/src/dashboard/pages/users.js +0 -867
  465. package/src/dashboard/pages/vault.js +0 -791
  466. package/src/dashboard/pages/workforce.js +0 -851
  467. package/src/dashboard/vendor/react-dom.development.js +0 -29924
  468. package/src/dashboard/vendor/react-dom.production.min.js +0 -267
  469. package/src/dashboard/vendor/react.development.js +0 -3343
  470. package/src/dashboard/vendor/react.production.min.js +0 -31
  471. package/src/database-access/agent-tools.ts +0 -193
  472. package/src/database-access/connection-manager.ts +0 -1341
  473. package/src/database-access/index.ts +0 -21
  474. package/src/database-access/query-sanitizer.ts +0 -220
  475. package/src/database-access/routes.ts +0 -226
  476. package/src/database-access/types.ts +0 -226
  477. package/src/db/adapter.ts +0 -510
  478. package/src/db/dynamodb.ts +0 -454
  479. package/src/db/factory.ts +0 -129
  480. package/src/db/mongodb.ts +0 -360
  481. package/src/db/mysql.ts +0 -531
  482. package/src/db/postgres.ts +0 -863
  483. package/src/db/proxy.ts +0 -39
  484. package/src/db/resolve-driver.ts +0 -29
  485. package/src/db/sql-schema.ts +0 -124
  486. package/src/db/sqlite.ts +0 -493
  487. package/src/db/turso.ts +0 -470
  488. package/src/deploy/fly.ts +0 -368
  489. package/src/deploy/managed.ts +0 -235
  490. package/src/domain-lock/cli-recover.ts +0 -591
  491. package/src/domain-lock/cli-verify.ts +0 -190
  492. package/src/domain-lock/index.ts +0 -220
  493. package/src/engine/activity-routes.ts +0 -154
  494. package/src/engine/activity.ts +0 -568
  495. package/src/engine/agent-autonomy.ts +0 -974
  496. package/src/engine/agent-config.ts +0 -646
  497. package/src/engine/agent-heartbeat.ts +0 -720
  498. package/src/engine/agent-hierarchy.ts +0 -1064
  499. package/src/engine/agent-memory.ts +0 -806
  500. package/src/engine/agent-notify.ts +0 -50
  501. package/src/engine/agent-routes.ts +0 -2583
  502. package/src/engine/agent-status.ts +0 -311
  503. package/src/engine/ambient-memory.ts +0 -401
  504. package/src/engine/approvals.ts +0 -615
  505. package/src/engine/assets/thinking-hum.mp3 +0 -0
  506. package/src/engine/catalog-routes.ts +0 -232
  507. package/src/engine/chat-poller.ts +0 -913
  508. package/src/engine/chat-webhook-routes.ts +0 -304
  509. package/src/engine/cli-build-skill.ts +0 -285
  510. package/src/engine/cli-submit-skill.ts +0 -200
  511. package/src/engine/cli-validate.ts +0 -188
  512. package/src/engine/cluster.ts +0 -278
  513. package/src/engine/communication-routes.ts +0 -139
  514. package/src/engine/communication.ts +0 -765
  515. package/src/engine/community-registry.ts +0 -1529
  516. package/src/engine/community-routes.ts +0 -260
  517. package/src/engine/compliance-routes.ts +0 -133
  518. package/src/engine/compliance.ts +0 -1679
  519. package/src/engine/config-bus.ts +0 -103
  520. package/src/engine/db-adapter.ts +0 -1156
  521. package/src/engine/db-schema.ts +0 -1945
  522. package/src/engine/deploy-schema-routes.ts +0 -176
  523. package/src/engine/deployer.ts +0 -957
  524. package/src/engine/dlp-routes.ts +0 -101
  525. package/src/engine/dlp.ts +0 -410
  526. package/src/engine/email-poller.ts +0 -855
  527. package/src/engine/emoji.ts +0 -106
  528. package/src/engine/guardrail-routes.ts +0 -125
  529. package/src/engine/guardrails.ts +0 -465
  530. package/src/engine/index.ts +0 -255
  531. package/src/engine/journal-routes.ts +0 -56
  532. package/src/engine/journal.ts +0 -249
  533. package/src/engine/knowledge-contribution-routes.ts +0 -633
  534. package/src/engine/knowledge-contribution.ts +0 -1386
  535. package/src/engine/knowledge-import/chunker.ts +0 -241
  536. package/src/engine/knowledge-import/import-manager.ts +0 -416
  537. package/src/engine/knowledge-import/index.ts +0 -27
  538. package/src/engine/knowledge-import/processors/clean.ts +0 -149
  539. package/src/engine/knowledge-import/processors/extract-gdrive.ts +0 -102
  540. package/src/engine/knowledge-import/processors/extract-github.ts +0 -74
  541. package/src/engine/knowledge-import/processors/extract-sharepoint.ts +0 -69
  542. package/src/engine/knowledge-import/processors/extract-web.ts +0 -275
  543. package/src/engine/knowledge-import/processors/index.ts +0 -18
  544. package/src/engine/knowledge-import/processors/pipeline.ts +0 -171
  545. package/src/engine/knowledge-import/processors/types.ts +0 -78
  546. package/src/engine/knowledge-import/processors/validate.ts +0 -150
  547. package/src/engine/knowledge-import/provider-file-upload.ts +0 -95
  548. package/src/engine/knowledge-import/provider-github.ts +0 -144
  549. package/src/engine/knowledge-import/provider-google-sites.ts +0 -323
  550. package/src/engine/knowledge-import/provider-sharepoint.ts +0 -276
  551. package/src/engine/knowledge-import/provider-url.ts +0 -218
  552. package/src/engine/knowledge-import/routes.ts +0 -94
  553. package/src/engine/knowledge-import/types.ts +0 -92
  554. package/src/engine/knowledge-routes.ts +0 -231
  555. package/src/engine/knowledge.ts +0 -587
  556. package/src/engine/lifecycle.ts +0 -1420
  557. package/src/engine/mcp-process-manager.ts +0 -573
  558. package/src/engine/meeting-monitor.ts +0 -483
  559. package/src/engine/meeting-voice-intelligence.ts +0 -340
  560. package/src/engine/memory-routes.ts +0 -142
  561. package/src/engine/memory-transfer-routes.ts +0 -339
  562. package/src/engine/messaging-history.ts +0 -177
  563. package/src/engine/messaging-poller.ts +0 -786
  564. package/src/engine/model-fallback.ts +0 -141
  565. package/src/engine/oauth-connect-routes.ts +0 -603
  566. package/src/engine/oauth-connect.ts +0 -304
  567. package/src/engine/onboarding-routes.ts +0 -148
  568. package/src/engine/onboarding.ts +0 -574
  569. package/src/engine/org-approval-routes.ts +0 -146
  570. package/src/engine/org-integration-routes.ts +0 -399
  571. package/src/engine/org-integrations.ts +0 -608
  572. package/src/engine/org-policies.ts +0 -502
  573. package/src/engine/policy-import-routes.ts +0 -125
  574. package/src/engine/policy-import.ts +0 -1186
  575. package/src/engine/policy-routes.ts +0 -163
  576. package/src/engine/routes.ts +0 -1236
  577. package/src/engine/screen-unlock.ts +0 -136
  578. package/src/engine/session-router.ts +0 -212
  579. package/src/engine/skill-updater-routes.ts +0 -132
  580. package/src/engine/skill-updater.ts +0 -480
  581. package/src/engine/skill-validator.ts +0 -331
  582. package/src/engine/skills/agent-management.ts +0 -119
  583. package/src/engine/skills/agent-memory.ts +0 -19
  584. package/src/engine/skills/agenticmail.ts +0 -116
  585. package/src/engine/skills/core-tools.ts +0 -25
  586. package/src/engine/skills/database-access.ts +0 -78
  587. package/src/engine/skills/enterprise-code-sandbox.ts +0 -113
  588. package/src/engine/skills/enterprise-database.ts +0 -123
  589. package/src/engine/skills/enterprise-diff.ts +0 -95
  590. package/src/engine/skills/enterprise-documents.ts +0 -162
  591. package/src/engine/skills/enterprise-http.ts +0 -99
  592. package/src/engine/skills/enterprise-security-scan.ts +0 -125
  593. package/src/engine/skills/enterprise-spreadsheet.ts +0 -171
  594. package/src/engine/skills/gws-admin.ts +0 -18
  595. package/src/engine/skills/gws-calendar.ts +0 -21
  596. package/src/engine/skills/gws-chat.ts +0 -29
  597. package/src/engine/skills/gws-contacts.ts +0 -20
  598. package/src/engine/skills/gws-docs.ts +0 -18
  599. package/src/engine/skills/gws-drive.ts +0 -23
  600. package/src/engine/skills/gws-forms.ts +0 -23
  601. package/src/engine/skills/gws-gmail.ts +0 -30
  602. package/src/engine/skills/gws-groups.ts +0 -17
  603. package/src/engine/skills/gws-keep.ts +0 -17
  604. package/src/engine/skills/gws-maps.ts +0 -25
  605. package/src/engine/skills/gws-meet.ts +0 -23
  606. package/src/engine/skills/gws-sheets.ts +0 -22
  607. package/src/engine/skills/gws-sites.ts +0 -16
  608. package/src/engine/skills/gws-slides.ts +0 -27
  609. package/src/engine/skills/gws-tasks.ts +0 -22
  610. package/src/engine/skills/gws-vault.ts +0 -17
  611. package/src/engine/skills/index.ts +0 -159
  612. package/src/engine/skills/knowledge-search.ts +0 -18
  613. package/src/engine/skills/local-system.ts +0 -61
  614. package/src/engine/skills/m365-admin.ts +0 -18
  615. package/src/engine/skills/m365-bookings.ts +0 -17
  616. package/src/engine/skills/m365-copilot.ts +0 -17
  617. package/src/engine/skills/m365-excel.ts +0 -60
  618. package/src/engine/skills/m365-forms.ts +0 -17
  619. package/src/engine/skills/m365-onedrive.ts +0 -60
  620. package/src/engine/skills/m365-onenote.ts +0 -17
  621. package/src/engine/skills/m365-outlook.ts +0 -27
  622. package/src/engine/skills/m365-planner.ts +0 -18
  623. package/src/engine/skills/m365-power-automate.ts +0 -18
  624. package/src/engine/skills/m365-power-bi.ts +0 -19
  625. package/src/engine/skills/m365-powerpoint.ts +0 -33
  626. package/src/engine/skills/m365-sharepoint.ts +0 -20
  627. package/src/engine/skills/m365-teams.ts +0 -21
  628. package/src/engine/skills/m365-todo.ts +0 -17
  629. package/src/engine/skills/m365-whiteboard.ts +0 -16
  630. package/src/engine/skills/m365-word.ts +0 -42
  631. package/src/engine/skills/mcp-bridge.ts +0 -45
  632. package/src/engine/skills/meeting-lifecycle.ts +0 -20
  633. package/src/engine/skills/messaging.ts +0 -46
  634. package/src/engine/skills/visual-memory.ts +0 -25
  635. package/src/engine/skills.ts +0 -688
  636. package/src/engine/soul-library.ts +0 -142
  637. package/src/engine/soul-templates.json +0 -1525
  638. package/src/engine/storage-manager.ts +0 -252
  639. package/src/engine/storage-routes.ts +0 -113
  640. package/src/engine/storage.ts +0 -528
  641. package/src/engine/task-poller.ts +0 -394
  642. package/src/engine/task-queue-after-spawn.ts +0 -66
  643. package/src/engine/task-queue-before-spawn.ts +0 -113
  644. package/src/engine/task-queue-routes.ts +0 -161
  645. package/src/engine/task-queue.ts +0 -664
  646. package/src/engine/tenant.ts +0 -409
  647. package/src/engine/tool-catalog.ts +0 -354
  648. package/src/engine/vault-routes.ts +0 -134
  649. package/src/engine/vault.ts +0 -601
  650. package/src/engine/workforce-routes.ts +0 -331
  651. package/src/engine/workforce.ts +0 -1161
  652. package/src/index.ts +0 -77
  653. package/src/lib/cidr.ts +0 -122
  654. package/src/lib/config-store.ts +0 -86
  655. package/src/lib/resilience.ts +0 -326
  656. package/src/lib/text-search.ts +0 -358
  657. package/src/mcp/adapters/activecampaign.adapter.ts +0 -391
  658. package/src/mcp/adapters/adobe-sign.adapter.ts +0 -469
  659. package/src/mcp/adapters/adp.adapter.ts +0 -358
  660. package/src/mcp/adapters/airtable.adapter.ts +0 -273
  661. package/src/mcp/adapters/apollo.adapter.ts +0 -420
  662. package/src/mcp/adapters/asana.adapter.ts +0 -315
  663. package/src/mcp/adapters/auth0.adapter.ts +0 -386
  664. package/src/mcp/adapters/aws.adapter.ts +0 -345
  665. package/src/mcp/adapters/azure-devops.adapter.ts +0 -389
  666. package/src/mcp/adapters/bamboohr.adapter.ts +0 -376
  667. package/src/mcp/adapters/basecamp.adapter.ts +0 -366
  668. package/src/mcp/adapters/bigcommerce.adapter.ts +0 -429
  669. package/src/mcp/adapters/bitbucket.adapter.ts +0 -260
  670. package/src/mcp/adapters/box.adapter.ts +0 -350
  671. package/src/mcp/adapters/brex.adapter.ts +0 -367
  672. package/src/mcp/adapters/buffer.adapter.ts +0 -303
  673. package/src/mcp/adapters/calendly.adapter.ts +0 -262
  674. package/src/mcp/adapters/canva.adapter.ts +0 -256
  675. package/src/mcp/adapters/chargebee.adapter.ts +0 -448
  676. package/src/mcp/adapters/circleci.adapter.ts +0 -216
  677. package/src/mcp/adapters/clickup.adapter.ts +0 -335
  678. package/src/mcp/adapters/close.adapter.ts +0 -390
  679. package/src/mcp/adapters/cloudflare.adapter.ts +0 -378
  680. package/src/mcp/adapters/confluence.adapter.ts +0 -301
  681. package/src/mcp/adapters/contentful.adapter.ts +0 -355
  682. package/src/mcp/adapters/copper.adapter.ts +0 -468
  683. package/src/mcp/adapters/crisp.adapter.ts +0 -415
  684. package/src/mcp/adapters/crowdstrike.adapter.ts +0 -413
  685. package/src/mcp/adapters/datadog.adapter.ts +0 -373
  686. package/src/mcp/adapters/digitalocean.adapter.ts +0 -336
  687. package/src/mcp/adapters/discord.adapter.ts +0 -248
  688. package/src/mcp/adapters/docker.adapter.ts +0 -238
  689. package/src/mcp/adapters/docusign.adapter.ts +0 -431
  690. package/src/mcp/adapters/drift.adapter.ts +0 -386
  691. package/src/mcp/adapters/dropbox.adapter.ts +0 -315
  692. package/src/mcp/adapters/figma.adapter.ts +0 -302
  693. package/src/mcp/adapters/firebase.adapter.ts +0 -446
  694. package/src/mcp/adapters/flyio.adapter.ts +0 -302
  695. package/src/mcp/adapters/freshbooks.adapter.ts +0 -474
  696. package/src/mcp/adapters/freshdesk.adapter.ts +0 -441
  697. package/src/mcp/adapters/freshsales.adapter.ts +0 -457
  698. package/src/mcp/adapters/freshservice.adapter.ts +0 -481
  699. package/src/mcp/adapters/front.adapter.ts +0 -357
  700. package/src/mcp/adapters/github-actions.adapter.ts +0 -329
  701. package/src/mcp/adapters/github.adapter.ts +0 -387
  702. package/src/mcp/adapters/gitlab.adapter.ts +0 -368
  703. package/src/mcp/adapters/gong.adapter.ts +0 -386
  704. package/src/mcp/adapters/google-ads.adapter.ts +0 -363
  705. package/src/mcp/adapters/google-analytics.adapter.ts +0 -316
  706. package/src/mcp/adapters/google-cloud.adapter.ts +0 -312
  707. package/src/mcp/adapters/gotomeeting.adapter.ts +0 -255
  708. package/src/mcp/adapters/grafana.adapter.ts +0 -361
  709. package/src/mcp/adapters/greenhouse.adapter.ts +0 -354
  710. package/src/mcp/adapters/gusto.adapter.ts +0 -329
  711. package/src/mcp/adapters/hashicorp-vault.adapter.ts +0 -355
  712. package/src/mcp/adapters/heroku.adapter.ts +0 -291
  713. package/src/mcp/adapters/hibob.adapter.ts +0 -334
  714. package/src/mcp/adapters/hootsuite.adapter.ts +0 -322
  715. package/src/mcp/adapters/hubspot.adapter.ts +0 -400
  716. package/src/mcp/adapters/huggingface.adapter.ts +0 -349
  717. package/src/mcp/adapters/index.ts +0 -524
  718. package/src/mcp/adapters/intercom.adapter.ts +0 -269
  719. package/src/mcp/adapters/jira.adapter.ts +0 -482
  720. package/src/mcp/adapters/klaviyo.adapter.ts +0 -353
  721. package/src/mcp/adapters/kubernetes.adapter.ts +0 -431
  722. package/src/mcp/adapters/lattice.adapter.ts +0 -339
  723. package/src/mcp/adapters/launchdarkly.adapter.ts +0 -368
  724. package/src/mcp/adapters/lever.adapter.ts +0 -347
  725. package/src/mcp/adapters/linear.adapter.ts +0 -300
  726. package/src/mcp/adapters/linkedin.adapter.ts +0 -331
  727. package/src/mcp/adapters/livechat.adapter.ts +0 -259
  728. package/src/mcp/adapters/loom.adapter.ts +0 -230
  729. package/src/mcp/adapters/mailchimp.adapter.ts +0 -394
  730. package/src/mcp/adapters/mailgun.adapter.ts +0 -425
  731. package/src/mcp/adapters/miro.adapter.ts +0 -274
  732. package/src/mcp/adapters/mixpanel.adapter.ts +0 -324
  733. package/src/mcp/adapters/monday.adapter.ts +0 -308
  734. package/src/mcp/adapters/mongodb-atlas.adapter.ts +0 -345
  735. package/src/mcp/adapters/neon.adapter.ts +0 -312
  736. package/src/mcp/adapters/netlify.adapter.ts +0 -324
  737. package/src/mcp/adapters/netsuite.adapter.ts +0 -411
  738. package/src/mcp/adapters/newrelic.adapter.ts +0 -339
  739. package/src/mcp/adapters/notion.adapter.ts +0 -338
  740. package/src/mcp/adapters/okta.adapter.ts +0 -394
  741. package/src/mcp/adapters/openai.adapter.ts +0 -315
  742. package/src/mcp/adapters/opsgenie.adapter.ts +0 -375
  743. package/src/mcp/adapters/outreach.adapter.ts +0 -372
  744. package/src/mcp/adapters/paddle.adapter.ts +0 -467
  745. package/src/mcp/adapters/pagerduty.adapter.ts +0 -412
  746. package/src/mcp/adapters/pandadoc.adapter.ts +0 -389
  747. package/src/mcp/adapters/paypal.adapter.ts +0 -465
  748. package/src/mcp/adapters/personio.adapter.ts +0 -401
  749. package/src/mcp/adapters/pinecone.adapter.ts +0 -340
  750. package/src/mcp/adapters/pipedrive.adapter.ts +0 -324
  751. package/src/mcp/adapters/plaid.adapter.ts +0 -444
  752. package/src/mcp/adapters/postmark.adapter.ts +0 -387
  753. package/src/mcp/adapters/power-automate.adapter.ts +0 -388
  754. package/src/mcp/adapters/quickbooks.adapter.ts +0 -431
  755. package/src/mcp/adapters/recurly.adapter.ts +0 -433
  756. package/src/mcp/adapters/reddit.adapter.ts +0 -371
  757. package/src/mcp/adapters/render.adapter.ts +0 -332
  758. package/src/mcp/adapters/ringcentral.adapter.ts +0 -281
  759. package/src/mcp/adapters/rippling.adapter.ts +0 -287
  760. package/src/mcp/adapters/salesforce.adapter.ts +0 -321
  761. package/src/mcp/adapters/salesloft.adapter.ts +0 -413
  762. package/src/mcp/adapters/sanity.adapter.ts +0 -363
  763. package/src/mcp/adapters/sap.adapter.ts +0 -483
  764. package/src/mcp/adapters/segment.adapter.ts +0 -260
  765. package/src/mcp/adapters/sendgrid.adapter.ts +0 -265
  766. package/src/mcp/adapters/sentry.adapter.ts +0 -331
  767. package/src/mcp/adapters/servicenow.adapter.ts +0 -468
  768. package/src/mcp/adapters/shopify.adapter.ts +0 -451
  769. package/src/mcp/adapters/shortcut.adapter.ts +0 -290
  770. package/src/mcp/adapters/slack.adapter.ts +0 -380
  771. package/src/mcp/adapters/smartsheet.adapter.ts +0 -326
  772. package/src/mcp/adapters/snowflake.adapter.ts +0 -347
  773. package/src/mcp/adapters/snyk.adapter.ts +0 -394
  774. package/src/mcp/adapters/splunk.adapter.ts +0 -403
  775. package/src/mcp/adapters/square.adapter.ts +0 -467
  776. package/src/mcp/adapters/statuspage.adapter.ts +0 -401
  777. package/src/mcp/adapters/stripe.adapter.ts +0 -380
  778. package/src/mcp/adapters/supabase.adapter.ts +0 -334
  779. package/src/mcp/adapters/teamwork.adapter.ts +0 -404
  780. package/src/mcp/adapters/telegram.adapter.ts +0 -299
  781. package/src/mcp/adapters/terraform.adapter.ts +0 -300
  782. package/src/mcp/adapters/todoist.adapter.ts +0 -239
  783. package/src/mcp/adapters/trello.adapter.ts +0 -316
  784. package/src/mcp/adapters/twilio.adapter.ts +0 -233
  785. package/src/mcp/adapters/twitter.adapter.ts +0 -348
  786. package/src/mcp/adapters/vercel.adapter.ts +0 -219
  787. package/src/mcp/adapters/weaviate.adapter.ts +0 -371
  788. package/src/mcp/adapters/webex.adapter.ts +0 -237
  789. package/src/mcp/adapters/webflow.adapter.ts +0 -287
  790. package/src/mcp/adapters/whatsapp.adapter.ts +0 -273
  791. package/src/mcp/adapters/whereby.adapter.ts +0 -240
  792. package/src/mcp/adapters/woocommerce.adapter.ts +0 -454
  793. package/src/mcp/adapters/wordpress.adapter.ts +0 -455
  794. package/src/mcp/adapters/workday.adapter.ts +0 -354
  795. package/src/mcp/adapters/wrike.adapter.ts +0 -349
  796. package/src/mcp/adapters/xero.adapter.ts +0 -472
  797. package/src/mcp/adapters/youtube.adapter.ts +0 -401
  798. package/src/mcp/adapters/zendesk.adapter.ts +0 -399
  799. package/src/mcp/adapters/zoho-crm.adapter.ts +0 -410
  800. package/src/mcp/adapters/zoom.adapter.ts +0 -241
  801. package/src/mcp/adapters/zuora.adapter.ts +0 -476
  802. package/src/mcp/framework/api-executor.ts +0 -192
  803. package/src/mcp/framework/aws-sigv4.ts +0 -216
  804. package/src/mcp/framework/credential-resolver.ts +0 -128
  805. package/src/mcp/framework/oauth-token-manager.ts +0 -22
  806. package/src/mcp/framework/skill-mcp-framework.ts +0 -226
  807. package/src/mcp/framework/types.ts +0 -130
  808. package/src/mcp/index.ts +0 -124
  809. package/src/mcp/integration-catalog.ts +0 -178
  810. package/src/middleware/dns-rebinding.ts +0 -44
  811. package/src/middleware/egress-filter.ts +0 -104
  812. package/src/middleware/firewall.ts +0 -192
  813. package/src/middleware/geo-ip.ts +0 -156
  814. package/src/middleware/index.ts +0 -390
  815. package/src/middleware/network-config.ts +0 -90
  816. package/src/middleware/proxy-config.ts +0 -71
  817. package/src/middleware/request-limits.ts +0 -59
  818. package/src/middleware/transport-encryption.ts +0 -398
  819. package/src/registry/cli.ts +0 -63
  820. package/src/registry/server.ts +0 -504
  821. package/src/runtime/agent-loop.ts +0 -779
  822. package/src/runtime/compaction.ts +0 -638
  823. package/src/runtime/email-channel.ts +0 -120
  824. package/src/runtime/environment.ts +0 -300
  825. package/src/runtime/followup.ts +0 -211
  826. package/src/runtime/gateway.ts +0 -260
  827. package/src/runtime/hooks.ts +0 -564
  828. package/src/runtime/index.ts +0 -1110
  829. package/src/runtime/llm-client.ts +0 -1056
  830. package/src/runtime/model-router.ts +0 -97
  831. package/src/runtime/providers.ts +0 -228
  832. package/src/runtime/session-manager.ts +0 -345
  833. package/src/runtime/subagent.ts +0 -153
  834. package/src/runtime/tool-executor.ts +0 -208
  835. package/src/runtime/types.ts +0 -255
  836. package/src/security/brute-force.ts +0 -423
  837. package/src/security/config.ts +0 -159
  838. package/src/security/csp.ts +0 -407
  839. package/src/security/external-content.ts +0 -299
  840. package/src/security/index.ts +0 -557
  841. package/src/security/input-sanitizer.ts +0 -452
  842. package/src/security/output-filter.ts +0 -575
  843. package/src/security/port-scanner.ts +0 -342
  844. package/src/security/prompt-guard.ts +0 -387
  845. package/src/security/sql-guard.ts +0 -338
  846. package/src/security/threat-logger.ts +0 -484
  847. package/src/server.ts +0 -828
  848. package/src/setup/company.ts +0 -183
  849. package/src/setup/database.ts +0 -153
  850. package/src/setup/deployment.ts +0 -561
  851. package/src/setup/domain.ts +0 -112
  852. package/src/setup/index.ts +0 -171
  853. package/src/setup/provision.ts +0 -532
  854. package/src/setup/registration.ts +0 -302
  855. package/src/system-prompts/catchup.ts +0 -48
  856. package/src/system-prompts/google/calendar.ts +0 -37
  857. package/src/system-prompts/google/chat.ts +0 -92
  858. package/src/system-prompts/google/contacts.ts +0 -25
  859. package/src/system-prompts/google/docs.ts +0 -29
  860. package/src/system-prompts/google/drive.ts +0 -34
  861. package/src/system-prompts/google/forms.ts +0 -25
  862. package/src/system-prompts/google/gmail.ts +0 -50
  863. package/src/system-prompts/google/index.ts +0 -23
  864. package/src/system-prompts/google/maps.ts +0 -20
  865. package/src/system-prompts/google/meet.ts +0 -130
  866. package/src/system-prompts/google/sheets.ts +0 -32
  867. package/src/system-prompts/google/slides.ts +0 -26
  868. package/src/system-prompts/google/tasks.ts +0 -27
  869. package/src/system-prompts/index.ts +0 -88
  870. package/src/system-prompts/microsoft/contacts.ts +0 -34
  871. package/src/system-prompts/microsoft/excel.ts +0 -52
  872. package/src/system-prompts/microsoft/index.ts +0 -31
  873. package/src/system-prompts/microsoft/onedrive.ts +0 -41
  874. package/src/system-prompts/microsoft/onenote.ts +0 -36
  875. package/src/system-prompts/microsoft/outlook-calendar.ts +0 -37
  876. package/src/system-prompts/microsoft/outlook-mail.ts +0 -46
  877. package/src/system-prompts/microsoft/planner.ts +0 -37
  878. package/src/system-prompts/microsoft/powerbi.ts +0 -38
  879. package/src/system-prompts/microsoft/powerpoint.ts +0 -35
  880. package/src/system-prompts/microsoft/sharepoint.ts +0 -44
  881. package/src/system-prompts/microsoft/teams.ts +0 -49
  882. package/src/system-prompts/microsoft/todo.ts +0 -37
  883. package/src/system-prompts/shared-blocks.ts +0 -87
  884. package/src/system-prompts/task.ts +0 -21
  885. package/src/system-prompts/triage.ts +0 -34
  886. package/src/types/hono-env.ts +0 -18
  887. package/src/types/optional-deps.d.ts +0 -10
  888. /package/{src → dist}/dashboard/HELP-TOOLTIPS-GUIDE.md +0 -0
@@ -0,0 +1,1519 @@
1
+ import {
2
+ getSupportedDatabases
3
+ } from "./chunk-PAHT4ABL.js";
4
+
5
+ // src/setup/index.ts
6
+ import { execSync as execSync2 } from "child_process";
7
+ import { createRequire } from "module";
8
+ import { join as join2 } from "path";
9
+
10
+ // src/setup/company.ts
11
+ function toSlug(name) {
12
+ return name.toLowerCase().replace(/[^a-z0-9]+/g, "-").replace(/^-|-$/g, "").slice(0, 63);
13
+ }
14
+ function generateAlternatives(companyName) {
15
+ const base = toSlug(companyName);
16
+ const words = companyName.trim().split(/\s+/).map((w) => w.toLowerCase().replace(/[^a-z0-9]/g, "")).filter(Boolean);
17
+ const suggestions = /* @__PURE__ */ new Set();
18
+ suggestions.add(base);
19
+ if (words.length >= 2) {
20
+ const initials = words.map((w) => w[0]).join("");
21
+ if (initials.length >= 2) suggestions.add(initials);
22
+ }
23
+ if (words[0] && words[0] !== base) {
24
+ suggestions.add(words[0]);
25
+ }
26
+ if (words.length >= 3) {
27
+ suggestions.add(`${words[0]}-${words[words.length - 1]}`);
28
+ }
29
+ suggestions.add(`team-${base}`);
30
+ suggestions.add(`app-${base}`);
31
+ suggestions.add(`mail-${words[0] || base}`);
32
+ suggestions.add(`ai-${words[0] || base}`);
33
+ suggestions.add(`${words[0] || base}-hq`);
34
+ suggestions.delete(base);
35
+ return [...suggestions].map((s) => s.slice(0, 63)).slice(0, 5);
36
+ }
37
+ function validateSubdomain(v) {
38
+ const s = v.trim();
39
+ if (!s) return "Subdomain is required";
40
+ if (s.length < 2) return "Subdomain must be at least 2 characters";
41
+ if (s.length > 63) return "Subdomain must be 63 characters or fewer";
42
+ if (!/^[a-z0-9]([a-z0-9-]*[a-z0-9])?$/.test(s)) {
43
+ return "Subdomain must be lowercase letters, numbers, and hyphens (cannot start or end with a hyphen)";
44
+ }
45
+ return true;
46
+ }
47
+ async function promptCompanyInfo(inquirer, chalk) {
48
+ console.log(chalk.bold.cyan(" Step 1 of 5: Company Info"));
49
+ console.log(chalk.dim(" Tell us about your organization.\n"));
50
+ const { companyName, adminEmail, adminPassword } = await inquirer.prompt([
51
+ {
52
+ type: "input",
53
+ name: "companyName",
54
+ message: "Company name:",
55
+ validate: (v) => {
56
+ if (!v.trim()) return "Company name is required";
57
+ if (v.length > 100) return "Company name must be under 100 characters";
58
+ return true;
59
+ }
60
+ },
61
+ {
62
+ type: "input",
63
+ name: "adminEmail",
64
+ message: "Admin email:",
65
+ validate: (v) => {
66
+ if (!v.includes("@") || !v.includes(".")) return "Enter a valid email address";
67
+ return true;
68
+ }
69
+ },
70
+ {
71
+ type: "password",
72
+ name: "adminPassword",
73
+ message: "Admin password:",
74
+ mask: "*",
75
+ validate: (v) => {
76
+ if (v.length < 8) return "Password must be at least 8 characters";
77
+ if (!/[A-Z]/.test(v) && !/[0-9]/.test(v)) {
78
+ return "Password should contain at least one uppercase letter or number";
79
+ }
80
+ return true;
81
+ }
82
+ }
83
+ ]);
84
+ const suggested = toSlug(companyName);
85
+ const alternatives = generateAlternatives(companyName);
86
+ console.log("");
87
+ console.log(chalk.bold(" Subdomain"));
88
+ console.log(chalk.dim(" Used for your dashboard URL and internal routing.\n"));
89
+ const choices = [
90
+ { name: `${suggested} ${chalk.dim("(recommended)")}`, value: suggested },
91
+ ...alternatives.map((alt) => ({ name: alt, value: alt })),
92
+ new inquirer.Separator(),
93
+ { name: `${chalk.italic("Enter my own...")}`, value: "__custom__" },
94
+ { name: `${chalk.italic("Generate more suggestions")}`, value: "__regenerate__" }
95
+ ];
96
+ let subdomain = suggested;
97
+ let choosing = true;
98
+ while (choosing) {
99
+ const { subdomainChoice } = await inquirer.prompt([{
100
+ type: "list",
101
+ name: "subdomainChoice",
102
+ message: "Choose a subdomain:",
103
+ choices
104
+ }]);
105
+ if (subdomainChoice === "__custom__") {
106
+ const { custom } = await inquirer.prompt([{
107
+ type: "input",
108
+ name: "custom",
109
+ message: "Custom subdomain:",
110
+ suffix: chalk.dim(" (lowercase, letters/numbers/hyphens)"),
111
+ validate: validateSubdomain,
112
+ filter: (v) => v.trim().toLowerCase()
113
+ }]);
114
+ subdomain = custom;
115
+ choosing = false;
116
+ } else if (subdomainChoice === "__regenerate__") {
117
+ const base = toSlug(companyName);
118
+ const words = companyName.trim().split(/\s+/).map((w2) => w2.toLowerCase().replace(/[^a-z0-9]/g, "")).filter(Boolean);
119
+ const w = words[0] || base;
120
+ const rand = () => Math.random().toString(36).slice(2, 5);
121
+ const fresh = [
122
+ `${w}-${rand()}`,
123
+ `${base}-${rand()}`,
124
+ `${w}-agents`,
125
+ `${w}-mail`,
126
+ `${w}-platform`
127
+ ];
128
+ choices.splice(
129
+ 1,
130
+ alternatives.length,
131
+ ...fresh.map((alt) => ({ name: alt, value: alt }))
132
+ );
133
+ } else {
134
+ subdomain = subdomainChoice;
135
+ choosing = false;
136
+ }
137
+ }
138
+ console.log(chalk.dim(` Your subdomain: ${chalk.white(subdomain)}
139
+ `));
140
+ return { companyName, adminEmail, adminPassword, subdomain };
141
+ }
142
+
143
+ // src/setup/database.ts
144
+ var CONNECTION_HINTS = {
145
+ postgres: "postgresql://user:pass@host:5432/dbname",
146
+ mysql: "mysql://user:pass@host:3306/dbname",
147
+ mongodb: "mongodb+srv://user:pass@cluster.mongodb.net/dbname",
148
+ supabase: "postgresql://postgres:pass@db.xxxx.supabase.co:5432/postgres",
149
+ neon: "postgresql://user:pass@ep-xxx.us-east-1.aws.neon.tech/dbname?sslmode=require",
150
+ planetscale: 'mysql://user:pass@aws.connect.psdb.cloud/dbname?ssl={"rejectUnauthorized":true}',
151
+ cockroachdb: "postgresql://user:pass@cluster.cockroachlabs.cloud:26257/dbname?sslmode=verify-full"
152
+ };
153
+ async function promptDatabase(inquirer, chalk) {
154
+ console.log("");
155
+ console.log(chalk.bold.cyan(" Step 2 of 4: Database"));
156
+ console.log(chalk.dim(" Where should your data live?\n"));
157
+ const databases = getSupportedDatabases();
158
+ const supabaseIdx = databases.findIndex((d) => d.type === "supabase");
159
+ const choices = databases.map((d, _i) => ({
160
+ name: d.type === "supabase" ? `${d.label} ${chalk.green("\u2190 recommended (free tier)")} ${chalk.dim("(cloud)")}` : `${d.label} ${chalk.dim(`(${d.group})`)}`,
161
+ value: d.type
162
+ }));
163
+ if (supabaseIdx > 0) {
164
+ const [sb] = choices.splice(supabaseIdx, 1);
165
+ choices.unshift(sb);
166
+ }
167
+ const { dbType } = await inquirer.prompt([
168
+ {
169
+ type: "list",
170
+ name: "dbType",
171
+ message: "Database backend:",
172
+ choices
173
+ }
174
+ ]);
175
+ if (dbType === "supabase") {
176
+ console.log("");
177
+ console.log(chalk.bold(" Supabase \u2014 Free PostgreSQL Database"));
178
+ console.log("");
179
+ console.log(chalk.dim(" If you don't have a Supabase account yet:"));
180
+ console.log("");
181
+ console.log(` 1. Go to ${chalk.cyan.underline("https://supabase.com/dashboard")}`);
182
+ console.log(` 2. Click ${chalk.bold('"Start your project"')} \u2014 sign up with GitHub or email`);
183
+ console.log(` 3. Create a new project (any name, choose a strong password)`);
184
+ console.log(` 4. Go to ${chalk.bold("Settings \u2192 Database \u2192 Connection string")}`);
185
+ console.log(` 5. Select ${chalk.bold('"URI"')} and copy the connection string`);
186
+ console.log(` 6. Replace ${chalk.yellow("[YOUR-PASSWORD]")} with your project password`);
187
+ console.log("");
188
+ console.log(chalk.dim(" Free tier includes: 500MB storage, unlimited API requests, 2 projects"));
189
+ console.log(chalk.dim(" The connection string looks like:"));
190
+ console.log(chalk.dim(" postgresql://postgres.[ref]:[password]@aws-0-[region].pooler.supabase.com:6543/postgres"));
191
+ console.log("");
192
+ }
193
+ if (dbType === "sqlite") {
194
+ const { dbPath } = await inquirer.prompt([{
195
+ type: "input",
196
+ name: "dbPath",
197
+ message: "Database file path:",
198
+ default: "./agenticmail-enterprise.db"
199
+ }]);
200
+ return { type: dbType, connectionString: dbPath };
201
+ }
202
+ if (dbType === "dynamodb") {
203
+ const answers = await inquirer.prompt([
204
+ {
205
+ type: "input",
206
+ name: "region",
207
+ message: "AWS Region:",
208
+ default: "us-east-1"
209
+ },
210
+ {
211
+ type: "input",
212
+ name: "accessKeyId",
213
+ message: "AWS Access Key ID:",
214
+ validate: (v) => v.length > 0 || "Required"
215
+ },
216
+ {
217
+ type: "password",
218
+ name: "secretAccessKey",
219
+ message: "AWS Secret Access Key:",
220
+ mask: "*",
221
+ validate: (v) => v.length > 0 || "Required"
222
+ }
223
+ ]);
224
+ return { type: dbType, ...answers };
225
+ }
226
+ if (dbType === "turso") {
227
+ const answers = await inquirer.prompt([
228
+ {
229
+ type: "input",
230
+ name: "connectionString",
231
+ message: "Turso database URL:",
232
+ suffix: chalk.dim(" (e.g. libsql://db-org.turso.io)"),
233
+ validate: (v) => v.length > 0 || "Required"
234
+ },
235
+ {
236
+ type: "password",
237
+ name: "authToken",
238
+ message: "Turso auth token:",
239
+ mask: "*",
240
+ validate: (v) => v.length > 0 || "Required"
241
+ }
242
+ ]);
243
+ return { type: dbType, connectionString: answers.connectionString, authToken: answers.authToken };
244
+ }
245
+ const hint = CONNECTION_HINTS[dbType] || "";
246
+ const { connectionString } = await inquirer.prompt([{
247
+ type: "input",
248
+ name: "connectionString",
249
+ message: "Connection string:",
250
+ suffix: hint ? chalk.dim(` (e.g. ${hint})`) : "",
251
+ validate: (v) => v.length > 0 || "Connection string is required"
252
+ }]);
253
+ return { type: dbType, connectionString };
254
+ }
255
+
256
+ // src/setup/deployment.ts
257
+ import { execSync, exec as execCb } from "child_process";
258
+ import { promisify } from "util";
259
+ import { existsSync, writeFileSync, readFileSync } from "fs";
260
+ import { join } from "path";
261
+ import { homedir, platform, arch } from "os";
262
+ var execP = promisify(execCb);
263
+ var SUBDOMAIN_REGISTRY_URL = process.env.AGENTICMAIL_SUBDOMAIN_REGISTRY_URL || "https://registry.agenticmail.io";
264
+ async function promptDeployment(inquirer, chalk) {
265
+ console.log("");
266
+ console.log(chalk.bold.cyan(" Step 3 of 4: Deployment"));
267
+ console.log(chalk.dim(" Where should your dashboard run?\n"));
268
+ const { deployTarget } = await inquirer.prompt([{
269
+ type: "list",
270
+ name: "deployTarget",
271
+ message: "Deploy to:",
272
+ choices: [
273
+ {
274
+ name: `AgenticMail Cloud ${chalk.green("\u2190 recommended")} ${chalk.dim("(instant URL, zero config)")}`,
275
+ value: "cloud"
276
+ },
277
+ {
278
+ name: `Cloudflare Tunnel ${chalk.dim("(self-hosted, free, no ports)")}`,
279
+ value: "cloudflare-tunnel"
280
+ },
281
+ {
282
+ name: `Fly.io ${chalk.dim("(your account)")}`,
283
+ value: "fly"
284
+ },
285
+ {
286
+ name: `Railway ${chalk.dim("(your account)")}`,
287
+ value: "railway"
288
+ },
289
+ {
290
+ name: `Docker ${chalk.dim("(self-hosted)")}`,
291
+ value: "docker"
292
+ },
293
+ {
294
+ name: `Local ${chalk.dim("(dev/testing, runs here)")}`,
295
+ value: "local"
296
+ }
297
+ ]
298
+ }]);
299
+ if (deployTarget === "cloud") {
300
+ const cloud = await runCloudSetup(inquirer, chalk);
301
+ return { target: deployTarget, cloud };
302
+ }
303
+ if (deployTarget === "cloudflare-tunnel") {
304
+ const tunnel = await runTunnelSetup(inquirer, chalk);
305
+ return { target: deployTarget, tunnel };
306
+ }
307
+ return { target: deployTarget };
308
+ }
309
+ async function runCloudSetup(inquirer, chalk) {
310
+ console.log("");
311
+ console.log(chalk.bold(" AgenticMail Cloud Setup"));
312
+ console.log(chalk.dim(" Get a free subdomain on agenticmail.io \u2014 no Cloudflare account needed."));
313
+ console.log(chalk.dim(" Your instance will be live at https://yourname.agenticmail.io\n"));
314
+ let subdomain = "";
315
+ let claimResult = null;
316
+ while (!subdomain) {
317
+ const { name } = await inquirer.prompt([{
318
+ type: "input",
319
+ name: "name",
320
+ message: "Choose your subdomain:",
321
+ suffix: chalk.dim(".agenticmail.io"),
322
+ validate: (input) => {
323
+ const cleaned2 = input.toLowerCase().trim();
324
+ if (cleaned2.length < 3) return "Must be at least 3 characters";
325
+ if (cleaned2.length > 32) return "Must be 32 characters or fewer";
326
+ if (!/^[a-z0-9]([a-z0-9-]*[a-z0-9])?$/.test(cleaned2)) return "Only lowercase letters, numbers, and hyphens allowed";
327
+ return true;
328
+ }
329
+ }]);
330
+ const cleaned = name.toLowerCase().trim();
331
+ process.stdout.write(chalk.dim(` Checking ${cleaned}.agenticmail.io... `));
332
+ try {
333
+ const checkResp = await fetch(`${SUBDOMAIN_REGISTRY_URL}/check?name=${encodeURIComponent(cleaned)}`);
334
+ const checkData = await checkResp.json();
335
+ if (!checkData.available) {
336
+ console.log(chalk.red("\u2717 " + (checkData.reason || "Not available")));
337
+ continue;
338
+ }
339
+ console.log(chalk.green("\u2713 Available!"));
340
+ } catch (err) {
341
+ console.log(chalk.yellow("\u26A0 Could not check availability: " + err.message));
342
+ console.log(chalk.dim(" Proceeding anyway \u2014 the claim step will verify.\n"));
343
+ }
344
+ const { confirmed } = await inquirer.prompt([{
345
+ type: "confirm",
346
+ name: "confirmed",
347
+ message: `Claim ${chalk.bold(cleaned + ".agenticmail.io")}?`,
348
+ default: true
349
+ }]);
350
+ if (!confirmed) continue;
351
+ const { createHash, randomUUID: randomUUID2 } = await import("crypto");
352
+ let vaultKey = process.env.AGENTICMAIL_VAULT_KEY;
353
+ if (!vaultKey) {
354
+ vaultKey = randomUUID2() + randomUUID2();
355
+ process.env.AGENTICMAIL_VAULT_KEY = vaultKey;
356
+ }
357
+ const vaultKeyHash = createHash("sha256").update(vaultKey).digest("hex");
358
+ process.stdout.write(chalk.dim(" Provisioning subdomain... "));
359
+ try {
360
+ const claimResp = await fetch(`${SUBDOMAIN_REGISTRY_URL}/claim`, {
361
+ method: "POST",
362
+ headers: { "Content-Type": "application/json" },
363
+ body: JSON.stringify({ name: cleaned, vaultKeyHash })
364
+ });
365
+ claimResult = await claimResp.json();
366
+ if (claimResult.error) {
367
+ console.log(chalk.red("\u2717 " + claimResult.error));
368
+ if (claimResult.error.includes("already has subdomain")) {
369
+ const { wantsRecover } = await inquirer.prompt([{
370
+ type: "confirm",
371
+ name: "wantsRecover",
372
+ message: "Recover your existing subdomain instead?",
373
+ default: true
374
+ }]);
375
+ if (wantsRecover) {
376
+ const recoverResp = await fetch(`${SUBDOMAIN_REGISTRY_URL}/recover`, {
377
+ method: "POST",
378
+ headers: { "Content-Type": "application/json" },
379
+ body: JSON.stringify({ vaultKeyHash })
380
+ });
381
+ claimResult = await recoverResp.json();
382
+ if (claimResult.success) {
383
+ subdomain = claimResult.subdomain;
384
+ console.log(chalk.green(`\u2713 Recovered: ${claimResult.fqdn}`));
385
+ } else {
386
+ console.log(chalk.red("\u2717 Recovery failed: " + (claimResult.error || "Unknown error")));
387
+ }
388
+ }
389
+ }
390
+ continue;
391
+ }
392
+ if (claimResult.success) {
393
+ subdomain = claimResult.subdomain || cleaned;
394
+ if (claimResult.recovered) {
395
+ console.log(chalk.green("\u2713 Recovered existing subdomain"));
396
+ } else {
397
+ console.log(chalk.green("\u2713 Subdomain claimed!"));
398
+ }
399
+ }
400
+ } catch (err) {
401
+ console.log(chalk.red("\u2717 Failed: " + err.message));
402
+ console.log(chalk.dim(" Check your internet connection and try again.\n"));
403
+ }
404
+ }
405
+ console.log("");
406
+ console.log(chalk.bold(" Installing cloudflared connector..."));
407
+ let cloudflaredPath = "";
408
+ try {
409
+ cloudflaredPath = execSync("which cloudflared", { encoding: "utf8" }).trim();
410
+ console.log(chalk.green(` \u2713 cloudflared found at ${cloudflaredPath}`));
411
+ } catch {
412
+ console.log(chalk.dim(" cloudflared not found \u2014 installing..."));
413
+ try {
414
+ const os = platform();
415
+ if (os === "darwin") {
416
+ execSync("brew install cloudflared", { stdio: "pipe" });
417
+ } else if (os === "linux") {
418
+ const archStr = arch() === "arm64" ? "arm64" : "amd64";
419
+ execSync(`curl -L https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-${archStr} -o /usr/local/bin/cloudflared && chmod +x /usr/local/bin/cloudflared`, { stdio: "pipe" });
420
+ } else {
421
+ console.log(chalk.yellow(" Please install cloudflared manually: https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/install-and-setup/installation/"));
422
+ }
423
+ cloudflaredPath = execSync("which cloudflared", { encoding: "utf8" }).trim();
424
+ console.log(chalk.green(` \u2713 cloudflared installed at ${cloudflaredPath}`));
425
+ } catch (e) {
426
+ console.log(chalk.yellow(" \u26A0 Could not auto-install cloudflared."));
427
+ console.log(chalk.dim(" Install manually: https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/install-and-setup/installation/"));
428
+ }
429
+ }
430
+ const port = 3100;
431
+ const fqdn = claimResult?.fqdn || `${subdomain}.agenticmail.io`;
432
+ const tunnelToken = claimResult?.tunnelToken;
433
+ const tunnelId = claimResult?.tunnelId;
434
+ console.log("");
435
+ console.log(chalk.bold.green(" \u2713 Setup Complete!"));
436
+ console.log("");
437
+ console.log(` Your dashboard: ${chalk.bold.cyan("https://" + fqdn)}`);
438
+ console.log("");
439
+ console.log(chalk.bgYellow.black.bold(" \u26A0 BACK UP ~/.agenticmail/.env \u26A0 "));
440
+ console.log("");
441
+ console.log(chalk.yellow(" This file contains EVERYTHING needed to recover if your machine crashes:"));
442
+ console.log("");
443
+ console.log(chalk.yellow(" DATABASE_URL \u2014 your database connection"));
444
+ console.log(chalk.yellow(" JWT_SECRET \u2014 login session signing key"));
445
+ console.log(chalk.yellow(" AGENTICMAIL_VAULT_KEY \u2014 encrypted credentials + subdomain recovery"));
446
+ console.log(chalk.yellow(" CLOUDFLARED_TOKEN \u2014 tunnel connection token"));
447
+ console.log(chalk.yellow(" PORT \u2014 server port"));
448
+ console.log("");
449
+ console.log(chalk.bold.yellow(" Copy this file to a safe place (password manager, cloud drive, etc.)"));
450
+ console.log(chalk.bold.yellow(" Without it, you CANNOT recover your subdomain or encrypted data."));
451
+ console.log("");
452
+ console.log(chalk.dim(" To recover on a new machine:"));
453
+ console.log(chalk.cyan(" npx @agenticmail/enterprise recover --cloud"));
454
+ console.log("");
455
+ console.log("");
456
+ console.log(chalk.dim(" To start your instance, run these two processes:"));
457
+ console.log("");
458
+ console.log(` ${chalk.cyan("cloudflared tunnel --no-autoupdate run --token " + (tunnelToken || "<your-tunnel-token>"))}`);
459
+ console.log(` ${chalk.cyan("npx @agenticmail/enterprise start")}`);
460
+ console.log("");
461
+ console.log(chalk.dim(" Or let the setup wizard start them with PM2 (next step).\n"));
462
+ const envPath = join(homedir(), ".agenticmail", ".env");
463
+ try {
464
+ let envContent = "";
465
+ if (existsSync(envPath)) {
466
+ envContent = readFileSync(envPath, "utf8");
467
+ }
468
+ if (tunnelToken && !envContent.includes("CLOUDFLARED_TOKEN=")) {
469
+ envContent += `
470
+ CLOUDFLARED_TOKEN=${tunnelToken}
471
+ `;
472
+ }
473
+ if (!envContent.includes("AGENTICMAIL_SUBDOMAIN=")) {
474
+ envContent += `AGENTICMAIL_SUBDOMAIN=${subdomain}
475
+ `;
476
+ }
477
+ if (!envContent.includes("AGENTICMAIL_DOMAIN=")) {
478
+ envContent += `AGENTICMAIL_DOMAIN=${fqdn}
479
+ `;
480
+ }
481
+ const { mkdirSync } = await import("fs");
482
+ mkdirSync(join(homedir(), ".agenticmail"), { recursive: true });
483
+ writeFileSync(envPath, envContent, { mode: 384 });
484
+ } catch {
485
+ }
486
+ return {
487
+ subdomain,
488
+ fqdn,
489
+ tunnelId: tunnelId || "",
490
+ tunnelToken: tunnelToken || "",
491
+ port
492
+ };
493
+ }
494
+ async function runTunnelSetup(inquirer, chalk) {
495
+ console.log("");
496
+ console.log(chalk.bold(" Cloudflare Tunnel Setup"));
497
+ console.log(chalk.dim(" Exposes your local server to the internet via Cloudflare."));
498
+ console.log(chalk.dim(" No open ports, free TLS, auto-DNS.\n"));
499
+ console.log(chalk.bold(" 1. Cloudflared CLI"));
500
+ let installed = false;
501
+ let version = "";
502
+ try {
503
+ version = execSync("cloudflared --version 2>&1", { encoding: "utf8", timeout: 5e3 }).trim();
504
+ installed = true;
505
+ } catch {
506
+ }
507
+ if (installed) {
508
+ console.log(chalk.green(` \u2713 Installed (${version})
509
+ `));
510
+ } else {
511
+ console.log(chalk.yellow(" Not installed."));
512
+ const { doInstall } = await inquirer.prompt([{
513
+ type: "confirm",
514
+ name: "doInstall",
515
+ message: "Install cloudflared now?",
516
+ default: true
517
+ }]);
518
+ if (!doInstall) {
519
+ console.log(chalk.red("\n cloudflared is required for tunnel deployment."));
520
+ console.log(chalk.dim(" Install it manually: https://developers.cloudflare.com/cloudflare-one/connections/connect-networks/downloads/\n"));
521
+ process.exit(1);
522
+ }
523
+ console.log(chalk.dim(" Installing..."));
524
+ try {
525
+ await installCloudflared();
526
+ version = execSync("cloudflared --version 2>&1", { encoding: "utf8", timeout: 5e3 }).trim();
527
+ console.log(chalk.green(` \u2713 Installed (${version})
528
+ `));
529
+ } catch (err) {
530
+ console.log(chalk.red(` \u2717 Installation failed: ${err.message}`));
531
+ console.log(chalk.dim(" Install manually and re-run setup.\n"));
532
+ process.exit(1);
533
+ }
534
+ }
535
+ console.log(chalk.bold(" 2. Cloudflare Authentication"));
536
+ const cfDir = join(homedir(), ".cloudflared");
537
+ const certPath = join(cfDir, "cert.pem");
538
+ const loggedIn = existsSync(certPath);
539
+ if (loggedIn) {
540
+ console.log(chalk.green(" \u2713 Already authenticated\n"));
541
+ } else {
542
+ console.log(chalk.dim(" This will open your browser to authorize Cloudflare.\n"));
543
+ const { doLogin } = await inquirer.prompt([{
544
+ type: "confirm",
545
+ name: "doLogin",
546
+ message: "Open browser to login to Cloudflare?",
547
+ default: true
548
+ }]);
549
+ if (!doLogin) {
550
+ console.log(chalk.red("\n Cloudflare auth is required. Run `cloudflared tunnel login` manually.\n"));
551
+ process.exit(1);
552
+ }
553
+ console.log(chalk.dim(" Waiting for browser authorization..."));
554
+ try {
555
+ await execP("cloudflared tunnel login", { timeout: 12e4 });
556
+ console.log(chalk.green(" \u2713 Authenticated\n"));
557
+ } catch (err) {
558
+ console.log(chalk.red(` \u2717 Login failed or timed out: ${err.message}`));
559
+ console.log(chalk.dim(" Complete the browser authorization and try again.\n"));
560
+ process.exit(1);
561
+ }
562
+ }
563
+ console.log(chalk.bold(" 3. Tunnel Configuration"));
564
+ const { domain, port, tunnelName } = await inquirer.prompt([
565
+ {
566
+ type: "input",
567
+ name: "domain",
568
+ message: "Domain (e.g. dashboard.yourcompany.com):",
569
+ validate: (v) => v.includes(".") ? true : "Enter a valid domain"
570
+ },
571
+ {
572
+ type: "number",
573
+ name: "port",
574
+ message: "Local port:",
575
+ default: 3200
576
+ },
577
+ {
578
+ type: "input",
579
+ name: "tunnelName",
580
+ message: "Tunnel name:",
581
+ default: "agenticmail-enterprise"
582
+ }
583
+ ]);
584
+ console.log("");
585
+ console.log(chalk.bold(" 4. Deploying"));
586
+ let tunnelId = "";
587
+ try {
588
+ console.log(chalk.dim(" Creating tunnel..."));
589
+ const out = execSync(`cloudflared tunnel create ${tunnelName} 2>&1`, { encoding: "utf8", timeout: 3e4 });
590
+ const match = out.match(/Created tunnel .+ with id ([a-f0-9-]+)/);
591
+ tunnelId = match?.[1] || "";
592
+ console.log(chalk.green(` \u2713 Tunnel created: ${tunnelName} (${tunnelId})`));
593
+ } catch (e) {
594
+ if (e.message?.includes("already exists") || e.stderr?.includes("already exists")) {
595
+ try {
596
+ const listOut = execSync("cloudflared tunnel list --output json 2>&1", { encoding: "utf8", timeout: 15e3 });
597
+ const tunnels = JSON.parse(listOut);
598
+ const existing = tunnels.find((t) => t.name === tunnelName);
599
+ if (existing) {
600
+ tunnelId = existing.id;
601
+ console.log(chalk.green(` \u2713 Using existing tunnel: ${tunnelName} (${tunnelId})`));
602
+ }
603
+ } catch {
604
+ console.log(chalk.red(` \u2717 Tunnel "${tunnelName}" exists but couldn't read its ID`));
605
+ process.exit(1);
606
+ }
607
+ } else {
608
+ console.log(chalk.red(` \u2717 Failed to create tunnel: ${e.message}`));
609
+ process.exit(1);
610
+ }
611
+ }
612
+ if (!tunnelId) {
613
+ console.log(chalk.red(" \u2717 Could not determine tunnel ID"));
614
+ process.exit(1);
615
+ }
616
+ const config = [
617
+ `tunnel: ${tunnelId}`,
618
+ `credentials-file: ${join(cfDir, tunnelId + ".json")}`,
619
+ "",
620
+ "ingress:",
621
+ ` - hostname: ${domain}`,
622
+ ` service: http://localhost:${port}`,
623
+ " - service: http_status:404"
624
+ ].join("\n");
625
+ writeFileSync(join(cfDir, "config.yml"), config);
626
+ console.log(chalk.green(` \u2713 Config written: ${domain} \u2192 localhost:${port}`));
627
+ try {
628
+ execSync(`cloudflared tunnel route dns ${tunnelId} ${domain} 2>&1`, { encoding: "utf8", timeout: 3e4 });
629
+ console.log(chalk.green(` \u2713 DNS CNAME created: ${domain}`));
630
+ } catch (e) {
631
+ if (e.message?.includes("already exists") || e.stderr?.includes("already exists")) {
632
+ console.log(chalk.green(` \u2713 DNS CNAME already exists for ${domain}`));
633
+ } else {
634
+ console.log(chalk.yellow(` \u26A0 DNS routing failed \u2014 add CNAME manually: ${domain} \u2192 ${tunnelId}.cfargotunnel.com`));
635
+ }
636
+ }
637
+ let started = false;
638
+ try {
639
+ execSync("which pm2", { timeout: 3e3 });
640
+ try {
641
+ execSync("pm2 delete cloudflared 2>/dev/null", { timeout: 5e3 });
642
+ } catch {
643
+ }
644
+ execSync(`pm2 start cloudflared --name cloudflared -- tunnel run`, { encoding: "utf8", timeout: 15e3 });
645
+ try {
646
+ execSync("pm2 save 2>/dev/null", { timeout: 5e3 });
647
+ } catch {
648
+ }
649
+ try {
650
+ const startupOut = execSync("pm2 startup 2>&1", { encoding: "utf8", timeout: 15e3 });
651
+ const sudoMatch = startupOut.match(/sudo .+$/m);
652
+ if (sudoMatch) try {
653
+ execSync(sudoMatch[0], { timeout: 15e3, stdio: "pipe" });
654
+ } catch {
655
+ }
656
+ } catch {
657
+ }
658
+ console.log(chalk.green(" \u2713 Tunnel running via PM2 (auto-restarts on crash + reboot)"));
659
+ started = true;
660
+ } catch {
661
+ }
662
+ if (!started) {
663
+ try {
664
+ console.log(chalk.dim(" Installing PM2 for process management..."));
665
+ execSync("npm install -g pm2", { timeout: 6e4, stdio: "pipe" });
666
+ try {
667
+ execSync("pm2 delete cloudflared 2>/dev/null", { timeout: 5e3 });
668
+ } catch {
669
+ }
670
+ execSync(`pm2 start cloudflared --name cloudflared -- tunnel run`, { encoding: "utf8", timeout: 15e3 });
671
+ try {
672
+ execSync("pm2 save 2>/dev/null", { timeout: 5e3 });
673
+ } catch {
674
+ }
675
+ try {
676
+ const startupOut = execSync("pm2 startup 2>&1", { encoding: "utf8", timeout: 15e3 });
677
+ const sudoMatch = startupOut.match(/sudo .+$/m);
678
+ if (sudoMatch) try {
679
+ execSync(sudoMatch[0], { timeout: 15e3, stdio: "pipe" });
680
+ } catch {
681
+ }
682
+ } catch {
683
+ }
684
+ console.log(chalk.green(" \u2713 PM2 installed + tunnel running (auto-restarts on crash + reboot)"));
685
+ started = true;
686
+ } catch {
687
+ console.log(chalk.yellow(" \u26A0 PM2 not available \u2014 tunnel started in background"));
688
+ console.log(chalk.dim(" Install PM2 for auto-restart: npm install -g pm2"));
689
+ try {
690
+ const { spawn } = await import("child_process");
691
+ const child = spawn("cloudflared", ["tunnel", "run"], { detached: true, stdio: "ignore" });
692
+ child.unref();
693
+ started = true;
694
+ } catch {
695
+ }
696
+ }
697
+ }
698
+ console.log("");
699
+ console.log(chalk.green.bold(` \u2713 Tunnel deployed! Your dashboard will be at https://${domain}`));
700
+ console.log("");
701
+ return { tunnelId, domain, port, tunnelName };
702
+ }
703
+ async function installCloudflared() {
704
+ const plat = platform();
705
+ const a = arch();
706
+ if (plat === "darwin") {
707
+ try {
708
+ execSync("which brew", { timeout: 3e3 });
709
+ execSync("brew install cloudflared 2>&1", { encoding: "utf8", timeout: 12e4 });
710
+ return;
711
+ } catch {
712
+ }
713
+ const cfArch = a === "arm64" ? "arm64" : "amd64";
714
+ execSync(
715
+ `curl -L -o /usr/local/bin/cloudflared https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-darwin-${cfArch} && chmod +x /usr/local/bin/cloudflared`,
716
+ { timeout: 6e4 }
717
+ );
718
+ } else if (plat === "linux") {
719
+ const cfArch = a === "arm64" ? "arm64" : "amd64";
720
+ execSync(
721
+ `curl -L -o /usr/local/bin/cloudflared https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-${cfArch} && chmod +x /usr/local/bin/cloudflared`,
722
+ { timeout: 6e4 }
723
+ );
724
+ } else {
725
+ throw new Error("Unsupported platform: " + plat);
726
+ }
727
+ }
728
+
729
+ // src/setup/domain.ts
730
+ async function promptDomain(inquirer, chalk, deployTarget) {
731
+ if (deployTarget === "local") {
732
+ return {};
733
+ }
734
+ console.log("");
735
+ console.log(chalk.bold.cyan(" Step 4 of 5: Custom Domain"));
736
+ console.log(chalk.dim(" Configure how your team will access the dashboard.\n"));
737
+ const targetHints = {
738
+ cloud: "By default, your dashboard is at <subdomain>.agenticmail.io. Add a custom domain for a branded URL.",
739
+ docker: "Configure your reverse proxy (nginx, Caddy, etc.) to route your domain to the Docker container.",
740
+ fly: "After deploying, run `fly certs add <domain>` to provision TLS for your domain.",
741
+ railway: "Add your domain in Railway project settings after deploying."
742
+ };
743
+ if (targetHints[deployTarget]) {
744
+ console.log(chalk.dim(` ${targetHints[deployTarget]}`));
745
+ console.log("");
746
+ }
747
+ const { domainMode } = await inquirer.prompt([{
748
+ type: "list",
749
+ name: "domainMode",
750
+ message: "Domain setup:",
751
+ choices: [
752
+ {
753
+ name: `Use default subdomain only ${chalk.dim("(<subdomain>.agenticmail.io)")}`,
754
+ value: "subdomain_only"
755
+ },
756
+ {
757
+ name: `Add a custom subdomain ${chalk.dim("(e.g. agents.yourcompany.com)")}`,
758
+ value: "custom_subdomain"
759
+ },
760
+ {
761
+ name: `Deploy on my root domain ${chalk.dim("(e.g. yourcompany.com \u2014 no subdomain)")}`,
762
+ value: "root_domain"
763
+ }
764
+ ]
765
+ }]);
766
+ if (domainMode === "subdomain_only") {
767
+ return {};
768
+ }
769
+ const isRoot = domainMode === "root_domain";
770
+ const { domain } = await inquirer.prompt([{
771
+ type: "input",
772
+ name: "domain",
773
+ message: isRoot ? "Your domain:" : "Custom domain:",
774
+ suffix: isRoot ? chalk.dim(" (e.g. yourcompany.com)") : chalk.dim(" (e.g. agents.yourcompany.com)"),
775
+ validate: (v) => {
776
+ const d = v.trim().toLowerCase();
777
+ if (!d.includes(".")) return "Enter a valid domain (e.g. yourcompany.com)";
778
+ if (d.startsWith("http")) return "Enter just the domain, not a URL";
779
+ if (d.endsWith(".")) return "Do not include a trailing dot";
780
+ return true;
781
+ },
782
+ filter: (v) => v.trim().toLowerCase()
783
+ }]);
784
+ if (isRoot) {
785
+ console.log("");
786
+ console.log(chalk.bold(" Root Domain Deployment"));
787
+ console.log(chalk.dim(` Your dashboard will be accessible at: ${chalk.white("https://" + domain)}`));
788
+ console.log(chalk.dim(" This means the entire domain is dedicated to your AgenticMail deployment."));
789
+ console.log("");
790
+ }
791
+ console.log("");
792
+ console.log(chalk.dim(" After setup, you will need DNS records for this domain:"));
793
+ console.log("");
794
+ if (isRoot) {
795
+ console.log(chalk.dim(` 1. ${chalk.white("A record")} \u2014 point ${domain} to your server IP`));
796
+ console.log(chalk.dim(` (or CNAME if your provider allows it at the apex)`));
797
+ } else {
798
+ console.log(chalk.dim(` 1. ${chalk.white("CNAME or A record")} \u2014 routes traffic to your server`));
799
+ }
800
+ console.log(chalk.dim(` 2. ${chalk.white("TXT record")} \u2014 proves domain ownership (next step)`));
801
+ console.log("");
802
+ return {
803
+ customDomain: domain,
804
+ useRootDomain: isRoot || void 0
805
+ };
806
+ }
807
+
808
+ // src/setup/registration.ts
809
+ import { randomBytes } from "crypto";
810
+ var REGISTRY_BASE_URL = process.env.AGENTICMAIL_REGISTRY_URL || "https://agenticmail.io/enterprise/v1";
811
+ async function promptRegistration(inquirer, chalk, ora, domain, companyName, adminEmail) {
812
+ if (!domain) {
813
+ return { registered: false, verificationStatus: "skipped" };
814
+ }
815
+ console.log("");
816
+ console.log(chalk.bold.cyan(" Step 5 of 5: Domain Registration"));
817
+ console.log(chalk.dim(" Protect your deployment from unauthorized duplication.\n"));
818
+ const { wantsRegistration } = await inquirer.prompt([{
819
+ type: "confirm",
820
+ name: "wantsRegistration",
821
+ message: `Register ${chalk.bold(domain)} with AgenticMail?`,
822
+ default: true
823
+ }]);
824
+ if (!wantsRegistration) {
825
+ console.log(chalk.dim(" Skipped. You can register later from the dashboard.\n"));
826
+ return { registered: false, verificationStatus: "skipped" };
827
+ }
828
+ const spinner = ora("Generating deployment key...").start();
829
+ const { createHash } = await import("crypto");
830
+ const plaintextKey = randomBytes(32).toString("hex");
831
+ const keyHash = createHash("sha256").update(plaintextKey).digest("hex");
832
+ spinner.succeed("Deployment key generated");
833
+ spinner.start("Registering domain with AgenticMail registry...");
834
+ const registryUrl = REGISTRY_BASE_URL.replace(/\/$/, "");
835
+ let registrationId;
836
+ let dnsChallenge;
837
+ try {
838
+ const res = await fetch(`${registryUrl}/domains/register`, {
839
+ method: "POST",
840
+ headers: { "Content-Type": "application/json" },
841
+ body: JSON.stringify({
842
+ domain: domain.toLowerCase().trim(),
843
+ keyHash,
844
+ sha256Hash: keyHash,
845
+ orgName: companyName,
846
+ contactEmail: adminEmail
847
+ }),
848
+ signal: AbortSignal.timeout(15e3)
849
+ });
850
+ const data = await res.json().catch(() => ({}));
851
+ if (res.status === 409) {
852
+ spinner.info("Domain already registered \u2014 verifying ownership");
853
+ console.log("");
854
+ console.log(chalk.yellow(" This domain is already registered and verified."));
855
+ console.log(chalk.dim(" Enter your deployment key to prove ownership and continue.\n"));
856
+ const { deploymentKey } = await inquirer.prompt([{
857
+ type: "password",
858
+ name: "deploymentKey",
859
+ message: "Deployment key:",
860
+ mask: "*",
861
+ validate: (v) => v.length === 64 || "Deployment key should be 64 hex characters"
862
+ }]);
863
+ const recoverSpinner = ora("Verifying deployment key...").start();
864
+ try {
865
+ const recoverRes = await fetch(`${registryUrl}/domains/recover`, {
866
+ method: "POST",
867
+ headers: { "Content-Type": "application/json" },
868
+ body: JSON.stringify({
869
+ domain: domain.toLowerCase().trim(),
870
+ deploymentKey
871
+ }),
872
+ signal: AbortSignal.timeout(15e3)
873
+ });
874
+ const recoverData = await recoverRes.json().catch(() => ({}));
875
+ if (recoverRes.status === 403) {
876
+ recoverSpinner.fail("Invalid deployment key");
877
+ console.log("");
878
+ console.log(chalk.red(" The deployment key does not match this domain."));
879
+ console.log("");
880
+ const { continueAnyway } = await inquirer.prompt([{
881
+ type: "confirm",
882
+ name: "continueAnyway",
883
+ message: "Continue setup without registration?",
884
+ default: true
885
+ }]);
886
+ if (continueAnyway) {
887
+ return { registered: false, verificationStatus: "skipped" };
888
+ }
889
+ process.exit(1);
890
+ }
891
+ if (!recoverRes.ok) {
892
+ throw new Error(recoverData.error || `HTTP ${recoverRes.status}`);
893
+ }
894
+ recoverSpinner.succeed("Ownership verified \u2014 domain recovered");
895
+ registrationId = recoverData.registrationId;
896
+ dnsChallenge = recoverData.dnsChallenge;
897
+ const verifyRes = await fetch(`${registryUrl}/domains/verify`, {
898
+ method: "POST",
899
+ headers: { "Content-Type": "application/json" },
900
+ body: JSON.stringify({ domain: domain.toLowerCase().trim() }),
901
+ signal: AbortSignal.timeout(15e3)
902
+ });
903
+ const verifyData = await verifyRes.json().catch(() => ({}));
904
+ const { createHash: createHash2 } = await import("crypto");
905
+ const localKeyHash = createHash2("sha256").update(deploymentKey).digest("hex");
906
+ return {
907
+ registered: true,
908
+ deploymentKeyHash: localKeyHash,
909
+ dnsChallenge,
910
+ registrationId,
911
+ verificationStatus: verifyData?.verified ? "verified" : "pending_dns"
912
+ };
913
+ } catch (err) {
914
+ recoverSpinner.fail(`Recovery failed: ${err.message}`);
915
+ const { continueAnyway } = await inquirer.prompt([{
916
+ type: "confirm",
917
+ name: "continueAnyway",
918
+ message: "Continue setup without registration?",
919
+ default: true
920
+ }]);
921
+ if (continueAnyway) {
922
+ return { registered: false, verificationStatus: "skipped" };
923
+ }
924
+ process.exit(1);
925
+ }
926
+ }
927
+ if (!res.ok) {
928
+ throw new Error(data.error || `HTTP ${res.status}`);
929
+ }
930
+ registrationId = data.registrationId;
931
+ dnsChallenge = data.dnsChallenge;
932
+ spinner.succeed("Domain registered");
933
+ } catch (err) {
934
+ spinner.warn("Registry unavailable");
935
+ console.log("");
936
+ console.log(chalk.yellow(` Could not reach registry: ${err.message}`));
937
+ console.log(chalk.dim(" You can register later with: npx @agenticmail/enterprise verify-domain"));
938
+ console.log("");
939
+ const { continueAnyway } = await inquirer.prompt([{
940
+ type: "confirm",
941
+ name: "continueAnyway",
942
+ message: "Continue setup without registration?",
943
+ default: true
944
+ }]);
945
+ if (continueAnyway) {
946
+ return { registered: false, verificationStatus: "skipped" };
947
+ }
948
+ process.exit(1);
949
+ }
950
+ console.log("");
951
+ console.log(chalk.red.bold(" \u2554\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2557"));
952
+ console.log(chalk.red.bold(" \u2551") + chalk.white.bold(" DEPLOYMENT KEY \u2014 SAVE THIS NOW ") + chalk.red.bold("\u2551"));
953
+ console.log(chalk.red.bold(" \u2551") + " " + chalk.red.bold("\u2551"));
954
+ console.log(chalk.red.bold(" \u2551") + ` ${chalk.green.bold(plaintextKey)} ` + chalk.red.bold("\u2551"));
955
+ console.log(chalk.red.bold(" \u2551") + " " + chalk.red.bold("\u2551"));
956
+ console.log(chalk.red.bold(" \u2551") + chalk.dim(" This key is shown ONCE. Store it securely (password manager, ") + chalk.red.bold("\u2551"));
957
+ console.log(chalk.red.bold(" \u2551") + chalk.dim(" vault, printed backup). You need it to recover this domain. ") + chalk.red.bold("\u2551"));
958
+ console.log(chalk.red.bold(" \u255A\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u255D"));
959
+ console.log("");
960
+ console.log(chalk.bold(" Add this DNS TXT record to prove domain ownership:"));
961
+ console.log("");
962
+ console.log(` ${chalk.bold("Host:")} ${chalk.cyan(`_agenticmail-verify.${domain}`)}`);
963
+ console.log(` ${chalk.bold("Type:")} ${chalk.cyan("TXT")}`);
964
+ console.log(` ${chalk.bold("Value:")} ${chalk.cyan(dnsChallenge)}`);
965
+ console.log("");
966
+ console.log(chalk.dim(" DNS changes can take up to 48 hours to propagate."));
967
+ console.log("");
968
+ await inquirer.prompt([{
969
+ type: "confirm",
970
+ name: "keySaved",
971
+ message: "I have saved my deployment key",
972
+ default: false
973
+ }]);
974
+ const { checkNow } = await inquirer.prompt([{
975
+ type: "confirm",
976
+ name: "checkNow",
977
+ message: "Check DNS verification now?",
978
+ default: false
979
+ }]);
980
+ let verificationStatus = "pending_dns";
981
+ if (checkNow) {
982
+ for (let attempt = 1; attempt <= 5; attempt++) {
983
+ spinner.start(`Checking DNS (attempt ${attempt}/5)...`);
984
+ try {
985
+ const res = await fetch(`${registryUrl}/domains/verify`, {
986
+ method: "POST",
987
+ headers: { "Content-Type": "application/json" },
988
+ body: JSON.stringify({ domain: domain.toLowerCase().trim() }),
989
+ signal: AbortSignal.timeout(15e3)
990
+ });
991
+ const data = await res.json().catch(() => ({}));
992
+ if (data.verified) {
993
+ spinner.succeed("Domain verified!");
994
+ verificationStatus = "verified";
995
+ break;
996
+ }
997
+ } catch {
998
+ }
999
+ if (attempt < 5) {
1000
+ spinner.text = `DNS record not found yet. Retrying in 10s (attempt ${attempt}/5)...`;
1001
+ await new Promise((r) => setTimeout(r, 1e4));
1002
+ } else {
1003
+ spinner.info("DNS record not found yet");
1004
+ console.log(chalk.dim(" Run later: npx @agenticmail/enterprise verify-domain"));
1005
+ }
1006
+ }
1007
+ } else {
1008
+ console.log(chalk.dim(" Run when ready: npx @agenticmail/enterprise verify-domain"));
1009
+ }
1010
+ console.log("");
1011
+ return {
1012
+ registered: true,
1013
+ deploymentKeyHash: keyHash,
1014
+ dnsChallenge,
1015
+ registrationId,
1016
+ verificationStatus
1017
+ };
1018
+ }
1019
+
1020
+ // src/setup/provision.ts
1021
+ import { randomUUID, randomBytes as randomBytes2 } from "crypto";
1022
+ function generateOrgId() {
1023
+ const chars = "ABCDEFGHJKLMNPQRSTUVWXYZ23456789";
1024
+ const bytes = randomBytes2(10);
1025
+ let id = "";
1026
+ for (let i = 0; i < 10; i++) id += chars[bytes[i] % chars.length];
1027
+ return id;
1028
+ }
1029
+ async function provision(config, ora, chalk) {
1030
+ const spinner = ora("Connecting to database...").start();
1031
+ const jwtSecret = randomUUID() + randomUUID();
1032
+ const vaultKey = randomUUID() + randomUUID();
1033
+ try {
1034
+ const { createAdapter } = await import("./factory-4V2W4BSV.js");
1035
+ const db = await createAdapter({
1036
+ type: config.database.type,
1037
+ connectionString: config.database.connectionString,
1038
+ region: config.database.region,
1039
+ accessKeyId: config.database.accessKeyId,
1040
+ secretAccessKey: config.database.secretAccessKey,
1041
+ authToken: config.database.authToken
1042
+ });
1043
+ spinner.text = "Running migrations...";
1044
+ await db.migrate();
1045
+ spinner.succeed("Database ready");
1046
+ const engineDbInterface = db.getEngineDB();
1047
+ if (engineDbInterface) {
1048
+ spinner.start("Initializing engine...");
1049
+ const { EngineDatabase } = await import("./db-adapter-2T56ORSD.js");
1050
+ const dialectMap = {
1051
+ sqlite: "sqlite",
1052
+ postgres: "postgres",
1053
+ supabase: "postgres",
1054
+ neon: "postgres",
1055
+ cockroachdb: "postgres",
1056
+ mysql: "mysql",
1057
+ planetscale: "mysql",
1058
+ turso: "turso"
1059
+ };
1060
+ const engineDialect = dialectMap[db.getDialect()] || db.getDialect();
1061
+ const engineDb = new EngineDatabase(engineDbInterface, engineDialect);
1062
+ const migResult = await engineDb.migrate();
1063
+ spinner.succeed(`Engine ready (${migResult.applied} migrations applied)`);
1064
+ }
1065
+ spinner.start("Creating company...");
1066
+ const orgId = generateOrgId();
1067
+ const corsOrigins = [];
1068
+ if (config.domain.customDomain) {
1069
+ corsOrigins.push(`https://${config.domain.customDomain}`);
1070
+ }
1071
+ if (config.company.subdomain) {
1072
+ corsOrigins.push(`https://${config.company.subdomain}.agenticmail.io`);
1073
+ }
1074
+ if (config.deployTarget === "local") {
1075
+ corsOrigins.push("http://localhost:3000", "http://localhost:8080", "http://127.0.0.1:3000", "http://127.0.0.1:8080");
1076
+ }
1077
+ await db.updateSettings({
1078
+ name: config.company.companyName,
1079
+ subdomain: config.company.subdomain,
1080
+ domain: config.domain.customDomain,
1081
+ orgId,
1082
+ ...corsOrigins.length > 0 ? {
1083
+ firewallConfig: {
1084
+ network: { corsOrigins }
1085
+ }
1086
+ } : {}
1087
+ });
1088
+ spinner.succeed(`Company created (org: ${orgId})`);
1089
+ if (config.registration?.registered) {
1090
+ spinner.start("Saving domain registration...");
1091
+ await db.updateSettings({
1092
+ deploymentKeyHash: config.registration.deploymentKeyHash,
1093
+ domainRegistrationId: config.registration.registrationId,
1094
+ domainDnsChallenge: config.registration.dnsChallenge,
1095
+ domainRegisteredAt: (/* @__PURE__ */ new Date()).toISOString(),
1096
+ domainStatus: config.registration.verificationStatus === "verified" ? "verified" : "pending_dns",
1097
+ ...config.registration.verificationStatus === "verified" ? { domainVerifiedAt: (/* @__PURE__ */ new Date()).toISOString() } : {}
1098
+ });
1099
+ spinner.succeed("Domain registration saved");
1100
+ }
1101
+ spinner.start("Creating admin account...");
1102
+ let admin;
1103
+ try {
1104
+ admin = await db.createUser({
1105
+ email: config.company.adminEmail,
1106
+ name: "Admin",
1107
+ role: "owner",
1108
+ password: config.company.adminPassword
1109
+ });
1110
+ } catch (err) {
1111
+ if (err.message?.includes("duplicate key") || err.message?.includes("UNIQUE constraint") || err.code === "23505") {
1112
+ admin = await db.getUserByEmail(config.company.adminEmail);
1113
+ if (!admin) throw err;
1114
+ spinner.text = "Admin account already exists, reusing...";
1115
+ } else {
1116
+ throw err;
1117
+ }
1118
+ }
1119
+ await db.logEvent({
1120
+ actor: admin.id,
1121
+ actorType: "system",
1122
+ action: "setup.complete",
1123
+ resource: `company:${config.company.subdomain}`,
1124
+ details: {
1125
+ dbType: config.database.type,
1126
+ deployTarget: config.deployTarget,
1127
+ companyName: config.company.companyName
1128
+ }
1129
+ });
1130
+ spinner.succeed("Admin account created");
1131
+ try {
1132
+ const { writeFileSync: writeFileSync2, existsSync: existsSync2, mkdirSync } = await import("fs");
1133
+ const { join: join3 } = await import("path");
1134
+ const { homedir: homedir2 } = await import("os");
1135
+ const envDir = join3(homedir2(), ".agenticmail");
1136
+ if (!existsSync2(envDir)) mkdirSync(envDir, { recursive: true });
1137
+ const port = config.tunnel?.port || (config.deployTarget === "local" ? 3e3 : void 0) || (config.deployTarget === "docker" ? 3e3 : void 0) || 3200;
1138
+ let existingEnv = "";
1139
+ const envFilePath = join3(envDir, ".env");
1140
+ if (existsSync2(envFilePath)) {
1141
+ try {
1142
+ existingEnv = (await import("fs")).readFileSync(envFilePath, "utf8");
1143
+ } catch {
1144
+ }
1145
+ }
1146
+ const envMap = /* @__PURE__ */ new Map();
1147
+ for (const line of existingEnv.split("\n")) {
1148
+ const t = line.trim();
1149
+ if (!t || t.startsWith("#")) continue;
1150
+ const eq = t.indexOf("=");
1151
+ if (eq > 0) envMap.set(t.slice(0, eq).trim(), t.slice(eq + 1).trim());
1152
+ }
1153
+ envMap.set("DATABASE_URL", config.database.connectionString || "");
1154
+ envMap.set("JWT_SECRET", jwtSecret);
1155
+ envMap.set("AGENTICMAIL_VAULT_KEY", vaultKey);
1156
+ envMap.set("PORT", String(port));
1157
+ if (config.cloud?.tunnelToken) envMap.set("CLOUDFLARED_TOKEN", config.cloud.tunnelToken);
1158
+ if (config.cloud?.subdomain) envMap.set("AGENTICMAIL_SUBDOMAIN", config.cloud.subdomain);
1159
+ if (config.cloud?.fqdn) envMap.set("AGENTICMAIL_DOMAIN", config.cloud.fqdn);
1160
+ const envContent = [
1161
+ "# AgenticMail Enterprise \u2014 auto-generated by setup wizard",
1162
+ "# BACK UP THIS FILE! You need it to recover on a new machine.",
1163
+ ...Array.from(envMap.entries()).map(([k, v]) => `${k}=${v}`)
1164
+ ].join("\n") + "\n";
1165
+ writeFileSync2(join3(envDir, ".env"), envContent, { mode: 384 });
1166
+ spinner.succeed(`Config saved to ~/.agenticmail/.env`);
1167
+ } catch {
1168
+ }
1169
+ const result = await deploy(config, db, jwtSecret, vaultKey, spinner, chalk);
1170
+ return {
1171
+ success: true,
1172
+ url: result.url,
1173
+ jwtSecret,
1174
+ db,
1175
+ serverClose: result.close
1176
+ };
1177
+ } catch (err) {
1178
+ spinner.fail(`Setup failed: ${err.message}`);
1179
+ return {
1180
+ success: false,
1181
+ error: err.message,
1182
+ jwtSecret,
1183
+ db: null
1184
+ };
1185
+ }
1186
+ }
1187
+ async function deploy(config, db, jwtSecret, vaultKey, spinner, chalk) {
1188
+ const { deployTarget, company, database, domain, tunnel, cloud } = config;
1189
+ if (deployTarget === "cloudflare-tunnel" && tunnel) {
1190
+ spinner.start(`Starting local server on port ${tunnel.port}...`);
1191
+ const { createServer: createServer2 } = await import("./server-KSN56EZQ.js");
1192
+ const server2 = createServer2({ port: tunnel.port, db, jwtSecret });
1193
+ const handle2 = await server2.start();
1194
+ spinner.succeed("Server running");
1195
+ console.log("");
1196
+ console.log(chalk.green.bold(" AgenticMail Enterprise is live!"));
1197
+ console.log("");
1198
+ console.log(` ${chalk.bold("Public URL:")} ${chalk.cyan("https://" + tunnel.domain)}`);
1199
+ console.log(` ${chalk.bold("Local:")} ${chalk.cyan("http://localhost:" + tunnel.port)}`);
1200
+ console.log(` ${chalk.bold("Tunnel:")} ${tunnel.tunnelName} (${tunnel.tunnelId})`);
1201
+ console.log(` ${chalk.bold("Admin:")} ${company.adminEmail}`);
1202
+ console.log("");
1203
+ console.log(chalk.dim(" Tunnel is managed by PM2 \u2014 auto-restarts on crash."));
1204
+ console.log(chalk.dim(" Manage: pm2 status | pm2 logs cloudflared | pm2 restart cloudflared"));
1205
+ console.log(chalk.dim(" Press Ctrl+C to stop the server"));
1206
+ return { url: "https://" + tunnel.domain, close: handle2.close };
1207
+ }
1208
+ if (deployTarget === "cloud" && cloud) {
1209
+ spinner.start("Configuring agenticmail.io deployment...");
1210
+ try {
1211
+ const pm2 = await import("pm2");
1212
+ await new Promise((resolve, reject) => {
1213
+ pm2.connect((err) => {
1214
+ if (err) {
1215
+ reject(err);
1216
+ return;
1217
+ }
1218
+ pm2.start({
1219
+ name: "cloudflared",
1220
+ script: "cloudflared",
1221
+ args: `tunnel --no-autoupdate run --token ${cloud.tunnelToken}`,
1222
+ interpreter: "none",
1223
+ autorestart: true
1224
+ }, (e) => {
1225
+ if (e) console.warn(`PM2 cloudflared start: ${e.message}`);
1226
+ pm2.start({
1227
+ name: "enterprise",
1228
+ script: "npx",
1229
+ args: "@agenticmail/enterprise start",
1230
+ env: {
1231
+ PORT: String(cloud.port || 3100),
1232
+ DATABASE_URL: database.connectionString || "",
1233
+ JWT_SECRET: jwtSecret,
1234
+ AGENTICMAIL_VAULT_KEY: vaultKey,
1235
+ AGENTICMAIL_DOMAIN: cloud.fqdn
1236
+ },
1237
+ autorestart: true
1238
+ }, (e2) => {
1239
+ pm2.disconnect();
1240
+ if (e2) reject(e2);
1241
+ else resolve();
1242
+ });
1243
+ });
1244
+ });
1245
+ });
1246
+ try {
1247
+ const { execSync: execSync3 } = await import("child_process");
1248
+ execSync3("pm2 save", { timeout: 1e4, stdio: "pipe" });
1249
+ try {
1250
+ const startupOut = execSync3("pm2 startup 2>&1", { encoding: "utf8", timeout: 15e3 });
1251
+ const sudoMatch = startupOut.match(/sudo .+$/m);
1252
+ if (sudoMatch) {
1253
+ try {
1254
+ execSync3(sudoMatch[0], { timeout: 15e3, stdio: "pipe" });
1255
+ } catch {
1256
+ }
1257
+ }
1258
+ } catch {
1259
+ }
1260
+ } catch {
1261
+ }
1262
+ spinner.succeed(`Live at https://${cloud.fqdn}`);
1263
+ console.log(chalk.dim(" PM2 will auto-restart on crash and survive reboots."));
1264
+ } catch (e) {
1265
+ spinner.warn(`PM2 setup failed: ${e.message}`);
1266
+ console.log(` Start manually:`);
1267
+ console.log(` cloudflared tunnel --no-autoupdate run --token ${cloud.tunnelToken}`);
1268
+ console.log(` npx @agenticmail/enterprise start`);
1269
+ }
1270
+ console.log("");
1271
+ console.log(` Dashboard: https://${cloud.fqdn}`);
1272
+ console.log(` To recover on a new machine, keep your AGENTICMAIL_VAULT_KEY safe.`);
1273
+ console.log("");
1274
+ return { url: `https://${cloud.fqdn}` };
1275
+ }
1276
+ if (deployTarget === "docker") {
1277
+ const { generateDockerCompose, generateEnvFile } = await import("./managed-T2RBYB2W.js");
1278
+ const compose = generateDockerCompose({ port: 3e3 });
1279
+ const envFile = generateEnvFile({
1280
+ dbType: database.type,
1281
+ dbConnectionString: database.connectionString || "",
1282
+ jwtSecret,
1283
+ vaultKey
1284
+ });
1285
+ const { writeFileSync: writeFileSync2, existsSync: existsSync2, appendFileSync } = await import("fs");
1286
+ writeFileSync2("docker-compose.yml", compose);
1287
+ writeFileSync2(".env", envFile);
1288
+ if (existsSync2(".gitignore")) {
1289
+ const content = await import("fs").then((f) => f.readFileSync(".gitignore", "utf-8"));
1290
+ if (!content.includes(".env")) {
1291
+ appendFileSync(".gitignore", "\n# Secrets\n.env\n");
1292
+ }
1293
+ } else {
1294
+ writeFileSync2(".gitignore", "# Secrets\n.env\nnode_modules/\n");
1295
+ }
1296
+ spinner.succeed("docker-compose.yml + .env generated");
1297
+ console.log("");
1298
+ console.log(chalk.green.bold(" Docker deployment ready!"));
1299
+ console.log("");
1300
+ console.log(` Run: ${chalk.cyan("docker compose up -d")}`);
1301
+ console.log(` Dashboard: ${chalk.cyan("http://localhost:3000")}`);
1302
+ console.log(chalk.dim(" Secrets stored in .env \u2014 do not commit to git"));
1303
+ if (domain.customDomain) {
1304
+ printCustomDomainInstructions(chalk, domain.customDomain, "docker");
1305
+ }
1306
+ return { url: "http://localhost:3000" };
1307
+ }
1308
+ if (deployTarget === "fly") {
1309
+ const { generateFlyToml } = await import("./managed-T2RBYB2W.js");
1310
+ const flyToml = generateFlyToml(`am-${company.subdomain}`, "iad");
1311
+ const { writeFileSync: writeFileSync2 } = await import("fs");
1312
+ writeFileSync2("fly.toml", flyToml);
1313
+ spinner.succeed("fly.toml generated");
1314
+ console.log("");
1315
+ console.log(chalk.green.bold(" Fly.io deployment ready!"));
1316
+ console.log("");
1317
+ console.log(` 1. ${chalk.cyan("fly launch --copy-config")}`);
1318
+ console.log(` 2. ${chalk.cyan(`fly secrets set DATABASE_URL="${database.connectionString}" JWT_SECRET="${jwtSecret}" AGENTICMAIL_VAULT_KEY="${vaultKey}"`)}`);
1319
+ console.log(` 3. ${chalk.cyan("fly deploy")}`);
1320
+ if (domain.customDomain) {
1321
+ console.log(` 4. ${chalk.cyan(`fly certs add ${domain.customDomain}`)}`);
1322
+ printCustomDomainInstructions(chalk, domain.customDomain, "fly", `am-${company.subdomain}.fly.dev`);
1323
+ }
1324
+ return {};
1325
+ }
1326
+ if (deployTarget === "railway") {
1327
+ const { generateRailwayConfig } = await import("./managed-T2RBYB2W.js");
1328
+ const railwayConfig = generateRailwayConfig();
1329
+ const { writeFileSync: writeFileSync2 } = await import("fs");
1330
+ writeFileSync2("railway.toml", railwayConfig);
1331
+ spinner.succeed("railway.toml generated");
1332
+ console.log("");
1333
+ console.log(chalk.green.bold(" Railway deployment ready!"));
1334
+ console.log("");
1335
+ console.log(` 1. ${chalk.cyan("railway init")}`);
1336
+ console.log(` 2. ${chalk.cyan("railway link")}`);
1337
+ console.log(` 3. ${chalk.cyan("railway up")}`);
1338
+ if (domain.customDomain) {
1339
+ printCustomDomainInstructions(chalk, domain.customDomain, "railway");
1340
+ }
1341
+ return {};
1342
+ }
1343
+ spinner.start("Starting local server...");
1344
+ const { createServer } = await import("./server-KSN56EZQ.js");
1345
+ const server = createServer({ port: 3e3, db, jwtSecret });
1346
+ const handle = await server.start();
1347
+ spinner.succeed("Server running");
1348
+ console.log("");
1349
+ console.log(chalk.green.bold(" AgenticMail Enterprise is running!"));
1350
+ console.log("");
1351
+ console.log(` ${chalk.bold("Dashboard:")} ${chalk.cyan("http://localhost:3000")}`);
1352
+ console.log(` ${chalk.bold("API:")} ${chalk.cyan("http://localhost:3000/api")}`);
1353
+ console.log(` ${chalk.bold("Admin:")} ${company.adminEmail}`);
1354
+ console.log("");
1355
+ console.log(chalk.dim(" Press Ctrl+C to stop"));
1356
+ return { url: "http://localhost:3000", close: handle.close };
1357
+ }
1358
+ function printCustomDomainInstructions(chalk, domain, target, cnameTarget) {
1359
+ console.log("");
1360
+ console.log(chalk.bold(" Custom Domain DNS Setup"));
1361
+ console.log(chalk.dim(` Route ${chalk.white(domain)} to your deployment.
1362
+ `));
1363
+ if (target === "cloud" && cnameTarget) {
1364
+ console.log(chalk.bold(" Add this DNS record at your domain registrar:"));
1365
+ console.log("");
1366
+ console.log(` ${chalk.bold("Type:")} ${chalk.cyan("CNAME")}`);
1367
+ console.log(` ${chalk.bold("Host:")} ${chalk.cyan(domain)}`);
1368
+ console.log(` ${chalk.bold("Value:")} ${chalk.cyan(cnameTarget)}`);
1369
+ } else if (target === "fly" && cnameTarget) {
1370
+ console.log(chalk.bold(" Add this DNS record at your domain registrar:"));
1371
+ console.log("");
1372
+ console.log(` ${chalk.bold("Type:")} ${chalk.cyan("CNAME")}`);
1373
+ console.log(` ${chalk.bold("Host:")} ${chalk.cyan(domain)}`);
1374
+ console.log(` ${chalk.bold("Value:")} ${chalk.cyan(cnameTarget)}`);
1375
+ console.log("");
1376
+ console.log(chalk.dim(" Fly.io will automatically provision a TLS certificate."));
1377
+ } else if (target === "railway") {
1378
+ console.log(chalk.bold(" After deploying:"));
1379
+ console.log("");
1380
+ console.log(` 1. Open your Railway project dashboard`);
1381
+ console.log(` 2. Go to ${chalk.bold("Settings")} \u2192 ${chalk.bold("Domains")}`);
1382
+ console.log(` 3. Add ${chalk.cyan(domain)} as a custom domain`);
1383
+ console.log(` 4. Railway will show you a ${chalk.bold("CNAME")} target \u2014 add it at your DNS provider`);
1384
+ } else if (target === "docker") {
1385
+ console.log(chalk.bold(" Configure your reverse proxy to route traffic:"));
1386
+ console.log("");
1387
+ console.log(` ${chalk.bold("Domain:")} ${chalk.cyan(domain)}`);
1388
+ console.log(` ${chalk.bold("Target:")} ${chalk.cyan("localhost:3000")} ${chalk.dim("(or your Docker host IP)")}`);
1389
+ console.log("");
1390
+ console.log(chalk.dim(" Example with nginx:"));
1391
+ console.log(chalk.dim(""));
1392
+ console.log(chalk.dim(" server {"));
1393
+ console.log(chalk.dim(` server_name ${domain};`));
1394
+ console.log(chalk.dim(" location / {"));
1395
+ console.log(chalk.dim(" proxy_pass http://localhost:3000;"));
1396
+ console.log(chalk.dim(" proxy_set_header Host $host;"));
1397
+ console.log(chalk.dim(" proxy_set_header X-Real-IP $remote_addr;"));
1398
+ console.log(chalk.dim(" }"));
1399
+ console.log(chalk.dim(" }"));
1400
+ console.log("");
1401
+ console.log(chalk.dim(" Then add a DNS A record pointing to your server IP,"));
1402
+ console.log(chalk.dim(" or a CNAME if you have an existing hostname."));
1403
+ }
1404
+ console.log("");
1405
+ console.log(chalk.dim(" Note: This CNAME/A record routes traffic. A separate TXT record"));
1406
+ console.log(chalk.dim(" for domain verification was (or will be) configured in Step 5."));
1407
+ console.log("");
1408
+ }
1409
+
1410
+ // src/setup/index.ts
1411
+ var DB_DRIVER_MAP = {
1412
+ postgres: ["pg"],
1413
+ supabase: ["pg"],
1414
+ neon: ["pg"],
1415
+ cockroachdb: ["pg"],
1416
+ mysql: ["mysql2"],
1417
+ planetscale: ["mysql2"],
1418
+ mongodb: ["mongodb"],
1419
+ sqlite: ["better-sqlite3"],
1420
+ turso: ["@libsql/client"],
1421
+ dynamodb: ["@aws-sdk/client-dynamodb", "@aws-sdk/lib-dynamodb"]
1422
+ };
1423
+ async function ensureDbDriver(dbType, ora, chalk) {
1424
+ const packages = DB_DRIVER_MAP[dbType];
1425
+ if (!packages?.length) return;
1426
+ const missing = [];
1427
+ for (const pkg of packages) {
1428
+ let found = false;
1429
+ try {
1430
+ await import(pkg);
1431
+ found = true;
1432
+ } catch {
1433
+ }
1434
+ if (!found) {
1435
+ try {
1436
+ const req = createRequire(join2(process.cwd(), "index.js"));
1437
+ req.resolve(pkg);
1438
+ found = true;
1439
+ } catch {
1440
+ }
1441
+ }
1442
+ if (!found) {
1443
+ try {
1444
+ const globalPrefix = execSync2("npm prefix -g", { encoding: "utf-8", stdio: ["pipe", "pipe", "pipe"] }).trim();
1445
+ const req = createRequire(join2(globalPrefix, "lib", "node_modules", ".package-lock.json"));
1446
+ req.resolve(pkg);
1447
+ found = true;
1448
+ } catch {
1449
+ }
1450
+ }
1451
+ if (!found) missing.push(pkg);
1452
+ }
1453
+ if (!missing.length) return;
1454
+ const spinner = ora(`Installing database driver: ${missing.join(", ")}...`).start();
1455
+ try {
1456
+ execSync2(`npm install --no-save ${missing.join(" ")}`, {
1457
+ stdio: "pipe",
1458
+ timeout: 12e4,
1459
+ cwd: process.cwd()
1460
+ });
1461
+ spinner.succeed(`Database driver installed: ${missing.join(", ")}`);
1462
+ } catch (err) {
1463
+ spinner.fail(`Failed to install ${missing.join(", ")}`);
1464
+ console.error(chalk.red(`
1465
+ Run manually: npm install ${missing.join(" ")}
1466
+ `));
1467
+ process.exit(1);
1468
+ }
1469
+ }
1470
+ async function runSetupWizard() {
1471
+ const { default: inquirer } = await import("inquirer");
1472
+ const { default: ora } = await import("ora");
1473
+ const { default: chalk } = await import("chalk");
1474
+ console.log("");
1475
+ console.log(chalk.bold(" AgenticMail Enterprise"));
1476
+ console.log(chalk.dim(" AI Agent Identity & Email for Organizations"));
1477
+ console.log("");
1478
+ console.log(chalk.dim(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"));
1479
+ console.log("");
1480
+ const company = await promptCompanyInfo(inquirer, chalk);
1481
+ const database = await promptDatabase(inquirer, chalk);
1482
+ const deploymentResult = await promptDeployment(inquirer, chalk);
1483
+ const deployTarget = deploymentResult.target;
1484
+ const domain = deploymentResult.tunnel ? { customDomain: deploymentResult.tunnel.domain } : deploymentResult.cloud ? { customDomain: deploymentResult.cloud.fqdn } : await promptDomain(inquirer, chalk, deployTarget);
1485
+ const registration = deploymentResult.tunnel || deploymentResult.cloud ? { registered: true, verificationStatus: "verified" } : await promptRegistration(
1486
+ inquirer,
1487
+ chalk,
1488
+ ora,
1489
+ domain.customDomain,
1490
+ company.companyName,
1491
+ company.adminEmail
1492
+ );
1493
+ await ensureDbDriver(database.type, ora, chalk);
1494
+ console.log("");
1495
+ console.log(chalk.dim(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"));
1496
+ console.log("");
1497
+ const result = await provision(
1498
+ { company, database, deployTarget, domain, registration, tunnel: deploymentResult.tunnel, cloud: deploymentResult.cloud },
1499
+ ora,
1500
+ chalk
1501
+ );
1502
+ if (!result.success) {
1503
+ console.error("");
1504
+ console.error(chalk.red(` Setup failed: ${result.error}`));
1505
+ console.error(chalk.dim(" Check your database connection and try again."));
1506
+ process.exit(1);
1507
+ }
1508
+ console.log("");
1509
+ }
1510
+
1511
+ export {
1512
+ promptCompanyInfo,
1513
+ promptDatabase,
1514
+ promptDeployment,
1515
+ promptDomain,
1516
+ promptRegistration,
1517
+ provision,
1518
+ runSetupWizard
1519
+ };