@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
@@ -1,974 +0,0 @@
1
- /**
2
- * Agent Autonomy System
3
- *
4
- * Provides enterprise-grade autonomous behaviors:
5
- * 1. Auto Clock-In/Out based on work schedule
6
- * 2. Daily/Weekly Manager Catchup Emails
7
- * 3. Goal Setting & Auto-Reminders
8
- * 4. Friday Knowledge Contribution
9
- * 5. Smart Answer Escalation (memory → Drive → Sites → manager)
10
- * 6. Guardrail Rule Enforcement at runtime
11
- */
12
-
13
- import type { EngineDatabase } from './db-adapter.js';
14
-
15
- // ─── Types ──────────────────────────────────────────────
16
-
17
- /**
18
- * Autonomy settings — all configurable via dashboard.
19
- * Stored in managed_agents.config.autonomy JSON field.
20
- */
21
- export interface AutonomySettings {
22
- /** Master switch — disables all autonomy features */
23
- enabled: boolean;
24
-
25
- /** Auto clock-in/out based on work schedule */
26
- clockEnabled: boolean;
27
-
28
- /**
29
- * Daily/Weekly catchup: times are read from config.dailyCatchUp (Manager & Catch-Up tab).
30
- * These booleans just enable/disable the behavior.
31
- */
32
- dailyCatchupEnabled: boolean;
33
- weeklyCatchupEnabled: boolean;
34
- weeklyCatchupDay: number; // 0=Sun..6=Sat, default 1 (Monday)
35
-
36
- /** Goal progress check */
37
- goalCheckEnabled: boolean;
38
- goalCheckHours: number[]; // hours of day to check, default [14, 17]
39
-
40
- /** Knowledge contribution */
41
- knowledgeContribEnabled: boolean;
42
- knowledgeContribDay: number; // 0=Sun..6=Sat, default 5 (Friday)
43
- knowledgeContribHour: number; // default 15
44
-
45
- /** Smart escalation */
46
- escalationEnabled: boolean;
47
-
48
- /** Guardrail enforcement at runtime */
49
- guardrailEnforcementEnabled: boolean;
50
-
51
- /** Drive access request on 403 */
52
- driveAccessRequestEnabled: boolean;
53
- }
54
-
55
- export const DEFAULT_AUTONOMY_SETTINGS: AutonomySettings = {
56
- enabled: true,
57
- clockEnabled: true,
58
- dailyCatchupEnabled: true,
59
- weeklyCatchupEnabled: true,
60
- weeklyCatchupDay: 1,
61
- goalCheckEnabled: true,
62
- goalCheckHours: [14, 17],
63
- knowledgeContribEnabled: true,
64
- knowledgeContribDay: 5,
65
- knowledgeContribHour: 15,
66
- escalationEnabled: true,
67
- guardrailEnforcementEnabled: true,
68
- driveAccessRequestEnabled: true,
69
- };
70
-
71
- export interface AutonomyConfig {
72
- agentId: string;
73
- orgId: string;
74
- agentName: string;
75
- role: string;
76
- managerEmail?: string;
77
- timezone: string;
78
- schedule?: { start: string; end: string; days: number[] };
79
- emailProvider?: any;
80
- runtime?: any;
81
- engineDb: EngineDatabase;
82
- memoryManager?: any;
83
- lifecycle?: any;
84
- settings?: Partial<AutonomySettings>;
85
- }
86
-
87
- export interface ClockState {
88
- clockedIn: boolean;
89
- clockInTime?: string;
90
- clockOutTime?: string;
91
- lastCheckTime?: string;
92
- }
93
-
94
- interface CatchupData {
95
- emailsHandled: number;
96
- sessionsRun: number;
97
- memoriesStored: number;
98
- tasksCompleted: string[];
99
- issuesEncountered: string[];
100
- knowledgeGained: string[];
101
- }
102
-
103
- // ─── Agent Autonomy Manager ─────────────────────────────
104
-
105
- export class AgentAutonomyManager {
106
- private config: AutonomyConfig;
107
- private settings: AutonomySettings;
108
- public clockState: ClockState = { clockedIn: false };
109
- private schedulerInterval?: NodeJS.Timeout;
110
- private catchupInterval?: NodeJS.Timeout;
111
- private knowledgeInterval?: NodeJS.Timeout;
112
- private goalCheckInterval?: NodeJS.Timeout;
113
-
114
- constructor(config: AutonomyConfig) {
115
- this.config = config;
116
- this.settings = { ...DEFAULT_AUTONOMY_SETTINGS, ...(config.settings || {}) };
117
- }
118
-
119
- /** Reload settings from DB (called when config changes via dashboard) */
120
- async reloadSettings(): Promise<void> {
121
- try {
122
- const rows = await this.config.engineDb.query<any>(
123
- `SELECT config FROM managed_agents WHERE id = $1`, [this.config.agentId]
124
- );
125
- if (rows?.[0]?.config) {
126
- const cfg = typeof rows[0].config === 'string' ? JSON.parse(rows[0].config) : rows[0].config;
127
- if (cfg.autonomy) {
128
- this.settings = { ...DEFAULT_AUTONOMY_SETTINGS, ...cfg.autonomy };
129
- }
130
- }
131
-
132
- // Reload work schedule from work_schedules table
133
- const schedRows = await this.config.engineDb.query<any>(
134
- `SELECT config, timezone FROM work_schedules WHERE agent_id = $1 AND enabled = TRUE ORDER BY created_at DESC LIMIT 1`,
135
- [this.config.agentId]
136
- );
137
- if (schedRows?.[0]) {
138
- const schedConfig = typeof schedRows[0].config === 'string' ? JSON.parse(schedRows[0].config) : schedRows[0].config;
139
- if (schedConfig?.standardHours) {
140
- this.config.schedule = {
141
- start: schedConfig.standardHours.start,
142
- end: schedConfig.standardHours.end,
143
- days: schedConfig.standardHours.daysOfWeek || [1, 2, 3, 4, 5],
144
- };
145
- if (schedRows[0].timezone) this.config.timezone = schedRows[0].timezone;
146
- }
147
- }
148
- } catch (err: any) {
149
- console.warn(`[autonomy] Failed to reload settings: ${err.message}`);
150
- }
151
- }
152
-
153
- getSettings(): AutonomySettings { return { ...this.settings }; }
154
-
155
- async start(): Promise<void> {
156
- if (!this.settings.enabled) {
157
- console.log('[autonomy] Disabled via settings, skipping');
158
- return;
159
- }
160
-
161
- console.log('[autonomy] Starting agent autonomy system...');
162
-
163
- // Load latest settings from DB
164
- await this.reloadSettings();
165
-
166
- // Check clock state on boot
167
- if (this.settings.clockEnabled) await this.checkClockState();
168
-
169
- // Schedule checker runs every minute
170
- this.schedulerInterval = setInterval(() => {
171
- if (this.settings.clockEnabled) this.checkClockState();
172
- }, 60_000);
173
-
174
- // Catchup email checker runs every 15 minutes
175
- this.catchupInterval = setInterval(() => this.checkCatchupSchedule(), 15 * 60_000);
176
- setTimeout(() => this.checkCatchupSchedule(), 30_000);
177
-
178
- // Knowledge contribution checker runs every hour
179
- this.knowledgeInterval = setInterval(() => this.checkKnowledgeContribution(), 60 * 60_000);
180
-
181
- // Goal progress checker runs every 30 minutes (more granular than 2h)
182
- this.goalCheckInterval = setInterval(() => this.checkGoalProgress(), 30 * 60_000);
183
-
184
- // Reload settings from DB every 10 minutes (picks up dashboard changes)
185
- setInterval(() => this.reloadSettings(), 10 * 60_000);
186
-
187
- const features = [];
188
- if (this.settings.clockEnabled) features.push('clock');
189
- if (this.settings.dailyCatchupEnabled) features.push('daily-catchup(time from Manager tab)');
190
- if (this.settings.weeklyCatchupEnabled) features.push('weekly-catchup@' + ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'][this.settings.weeklyCatchupDay]);
191
- if (this.settings.goalCheckEnabled) features.push('goals@' + this.settings.goalCheckHours.join(','));
192
- if (this.settings.knowledgeContribEnabled) features.push('knowledge@' + ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'][this.settings.knowledgeContribDay]);
193
- console.log('[autonomy] Active features: ' + features.join(', '));
194
- }
195
-
196
- stop(): void {
197
- if (this.schedulerInterval) clearInterval(this.schedulerInterval);
198
- if (this.catchupInterval) clearInterval(this.catchupInterval);
199
- if (this.knowledgeInterval) clearInterval(this.knowledgeInterval);
200
- if (this.goalCheckInterval) clearInterval(this.goalCheckInterval);
201
- console.log('[autonomy] System stopped');
202
- }
203
-
204
- // ─── 1. Auto Clock-In/Out ──────────────────────────
205
-
206
- private async checkClockState(): Promise<void> {
207
- const schedule = this.config.schedule;
208
- if (!schedule) return;
209
-
210
- const now = new Date();
211
- const tz = this.config.timezone || 'UTC';
212
- const localTime = new Date(now.toLocaleString('en-US', { timeZone: tz }));
213
- const currentHour = localTime.getHours();
214
- const currentMinute = localTime.getMinutes();
215
- const currentDay = localTime.getDay(); // 0=Sun
216
- const currentTimeStr = `${String(currentHour).padStart(2, '0')}:${String(currentMinute).padStart(2, '0')}`;
217
-
218
- // Check if today is a scheduled workday
219
- const isWorkday = schedule.days.includes(currentDay);
220
- const isWithinHours = currentTimeStr >= schedule.start && currentTimeStr < schedule.end;
221
-
222
- if (isWorkday && isWithinHours && !this.clockState.clockedIn) {
223
- await this.clockIn();
224
- // Morning triage — scan accumulated off-hours items
225
- await this.morningTriage();
226
- } else if ((!isWorkday || !isWithinHours) && this.clockState.clockedIn) {
227
- await this.clockOut();
228
- }
229
-
230
- this.clockState.lastCheckTime = now.toISOString();
231
- }
232
-
233
- private async clockIn(): Promise<void> {
234
- const now = new Date().toISOString();
235
- this.clockState.clockedIn = true;
236
- this.clockState.clockInTime = now;
237
-
238
- try {
239
- await this.config.engineDb.execute(
240
- `INSERT INTO clock_records (id, org_id, agent_id, type, triggered_by, actual_at, created_at) VALUES ($1, $2, $3, 'clock_in', 'auto_scheduler', $4, $4)`,
241
- [crypto.randomUUID(), this.config.orgId, this.config.agentId, now]
242
- );
243
- console.log(`[autonomy] ⏰ Clocked IN at ${now}`);
244
-
245
- // Store in memory
246
- if (this.config.memoryManager) {
247
- await this.config.memoryManager.storeMemory(this.config.agentId, {
248
- content: `Clocked in at ${now}. Starting work shift.`,
249
- category: 'context',
250
- importance: 'low',
251
- confidence: 1.0,
252
- }).catch(() => {});
253
- }
254
- } catch (err: any) {
255
- console.error(`[autonomy] Clock-in error: ${err.message}`);
256
- }
257
- }
258
-
259
- private async clockOut(): Promise<void> {
260
- const now = new Date().toISOString();
261
- this.clockState.clockedIn = false;
262
- this.clockState.clockOutTime = now;
263
-
264
- try {
265
- await this.config.engineDb.execute(
266
- `INSERT INTO clock_records (id, org_id, agent_id, type, triggered_by, reason, actual_at, created_at) VALUES ($1, $2, $3, 'clock_out', 'auto_scheduler', 'End of scheduled hours', $4, $4)`,
267
- [crypto.randomUUID(), this.config.orgId, this.config.agentId, now]
268
- );
269
- console.log(`[autonomy] ⏰ Clocked OUT at ${now}`);
270
-
271
- // Store in memory
272
- if (this.config.memoryManager) {
273
- await this.config.memoryManager.storeMemory(this.config.agentId, {
274
- content: `Clocked out at ${now}. Work shift ended.`,
275
- category: 'context',
276
- importance: 'low',
277
- confidence: 1.0,
278
- }).catch(() => {});
279
- }
280
- } catch (err: any) {
281
- console.error(`[autonomy] Clock-out error: ${err.message}`);
282
- }
283
- }
284
-
285
- /**
286
- * Morning Triage — runs once after clock-in.
287
- * Scans for off-hours accumulated items (emails, chats, failed sessions)
288
- * and creates a single LLM session to triage everything into tasks.
289
- *
290
- * This avoids the problem of 15 emails = 15 separate sessions.
291
- * Instead: 1 triage session → creates Google Tasks → then handles them in order.
292
- */
293
- private async morningTriage(): Promise<void> {
294
- if (!this.config.runtime) return;
295
-
296
- const dateStr = new Date().toISOString().split('T')[0];
297
- const triageKey = `morning_triage_${dateStr}`;
298
- const alreadyDone = await this.checkMemoryFlag(triageKey);
299
- if (alreadyDone) return;
300
-
301
- console.log('[autonomy] 🌅 Morning triage — scanning off-hours accumulation...');
302
-
303
- const db = this.config.engineDb;
304
- const agentId = this.config.agentId;
305
-
306
- // Count off-hours items (pure DB — no tokens)
307
- let unhandledEmails = 0;
308
- let failedSessions = 0;
309
- let failedChats = 0;
310
-
311
- try {
312
- // Emails that arrived since last clock-out (or last 16h as fallback)
313
- const lastClockOut = this.clockState.clockOutTime || new Date(Date.now() - 16 * 60 * 60 * 1000).toISOString();
314
-
315
- const emailRows = await db.query<any>(
316
- `SELECT COUNT(*) as cnt FROM agent_sessions
317
- WHERE agent_id = $1 AND created_at > $2 AND metadata::text LIKE '%email%'`,
318
- [agentId, lastClockOut]
319
- );
320
- unhandledEmails = parseInt(emailRows?.[0]?.cnt || '0');
321
-
322
- const failedRows = await db.query<any>(
323
- `SELECT COUNT(*) as cnt FROM agent_sessions
324
- WHERE agent_id = $1 AND status = 'failed' AND created_at > $2`,
325
- [agentId, lastClockOut]
326
- );
327
- failedSessions = parseInt(failedRows?.[0]?.cnt || '0');
328
-
329
- const chatRows = await db.query<any>(
330
- `SELECT COUNT(*) as cnt FROM agent_sessions
331
- WHERE agent_id = $1 AND status = 'failed' AND metadata::text LIKE '%chat%' AND created_at > $2`,
332
- [agentId, lastClockOut]
333
- );
334
- failedChats = parseInt(chatRows?.[0]?.cnt || '0');
335
- } catch {}
336
-
337
- const totalItems = unhandledEmails + failedSessions + failedChats;
338
-
339
- // If nothing accumulated, skip the LLM session entirely (zero tokens)
340
- if (totalItems === 0) {
341
- console.log('[autonomy] 🌅 Morning triage: nothing accumulated overnight. Clean start!');
342
- await this.setMemoryFlag(triageKey);
343
- return;
344
- }
345
-
346
- console.log(`[autonomy] 🌅 Morning triage: ${unhandledEmails} emails, ${failedSessions} failed sessions, ${failedChats} failed chats`);
347
-
348
- // Only spawn LLM session if there's enough to warrant triage (> 3 items)
349
- if (totalItems <= 3) {
350
- console.log('[autonomy] 🌅 Only a few items — skipping triage session, they\'ll be handled individually.');
351
- await this.setMemoryFlag(triageKey);
352
- return;
353
- }
354
-
355
- // Spawn one triage session
356
- const prompt = `Good morning! You just clocked in. Here's what accumulated while you were off:
357
-
358
- - ${unhandledEmails} email session(s) were created overnight
359
- - ${failedSessions} session(s) failed (may need retry)
360
- - ${failedChats} chat message(s) may be unanswered
361
-
362
- Your morning routine:
363
- 1. Check your inbox with gmail_search (unread only) — scan subjects and senders
364
- 2. For each important email, create a Google Task: google_tasks_create with title, notes, and priority
365
- 3. Check Google Chat for any unanswered messages: google_chat_list_messages
366
- 4. For any failed sessions that look important, add them as tasks too
367
- 5. Send your manager (${this.config.managerEmail}) a brief "starting my day" message listing your top priorities
368
- 6. After triage, start working through tasks in priority order
369
-
370
- Prioritize: manager emails > urgent requests > routine items > FYI messages.
371
- Create tasks in a "Today" list so you can track progress throughout the day.`;
372
-
373
- const systemPrompt = `You are ${this.config.agentName}, a ${this.config.role}.
374
- You just clocked in for the day. Your first task is to triage everything that accumulated overnight.
375
- Be systematic: scan, prioritize, create tasks, then execute. Don't just dive into the first email you see.
376
- Work schedule: ${this.config.schedule ? `${this.config.schedule.start}-${this.config.schedule.end} ${this.config.timezone}` : 'Standard hours'}`;
377
-
378
- try {
379
- const session = await this.config.runtime.spawnSession({
380
- agentId,
381
- message: prompt,
382
- systemPrompt,
383
- });
384
- console.log(`[autonomy] 🌅 Morning triage session ${session.id} created`);
385
- await this.setMemoryFlag(triageKey);
386
- } catch (err: any) {
387
- console.error(`[autonomy] Morning triage error: ${err.message}`);
388
- }
389
- }
390
-
391
- isWorkingHours(): boolean {
392
- return this.clockState.clockedIn;
393
- }
394
-
395
- getClockState(): ClockState {
396
- return { ...this.clockState };
397
- }
398
-
399
- // ─── 2. Manager Catchup Emails ─────────────────────
400
-
401
- private async checkCatchupSchedule(): Promise<void> {
402
- if (!this.config.managerEmail || !this.config.runtime) return;
403
-
404
- // Read catchup time from config.dailyCatchUp (set in Manager & Catch-Up tab)
405
- let catchUpHour = 9;
406
- let catchUpMinute = 0;
407
- let catchUpTz = this.config.timezone || 'UTC';
408
- try {
409
- const rows = await this.config.engineDb.query<any>(
410
- `SELECT config FROM managed_agents WHERE id = $1`, [this.config.agentId]
411
- );
412
- if (rows?.[0]?.config) {
413
- const cfg = typeof rows[0].config === 'string' ? JSON.parse(rows[0].config) : rows[0].config;
414
- if (cfg.dailyCatchUp?.time) {
415
- const parts = cfg.dailyCatchUp.time.split(':');
416
- catchUpHour = parseInt(parts[0]) || 9;
417
- catchUpMinute = parseInt(parts[1]) || 0;
418
- }
419
- if (cfg.dailyCatchUp?.timezone) catchUpTz = cfg.dailyCatchUp.timezone;
420
- // If dailyCatchUp is explicitly disabled in Manager tab, respect that
421
- if (cfg.dailyCatchUp && cfg.dailyCatchUp.enabled === false) return;
422
- }
423
- } catch {}
424
-
425
- const now = new Date();
426
- const localTime = new Date(now.toLocaleString('en-US', { timeZone: catchUpTz }));
427
- const hour = localTime.getHours();
428
- const minute = localTime.getMinutes();
429
- const dayOfWeek = localTime.getDay();
430
- const dateStr = localTime.toISOString().split('T')[0];
431
-
432
- // Weekly catchup: configurable day, same time as daily
433
- const isWeeklyCatchupTime = this.settings.weeklyCatchupEnabled
434
- && dayOfWeek === this.settings.weeklyCatchupDay
435
- && hour === catchUpHour
436
- && minute >= catchUpMinute && minute < catchUpMinute + 15;
437
-
438
- // Daily catchup: uses time from Manager & Catch-Up tab
439
- const isDailyCatchupTime = this.settings.dailyCatchupEnabled
440
- && hour === catchUpHour
441
- && minute >= catchUpMinute && minute < catchUpMinute + 15;
442
-
443
- if (!isDailyCatchupTime && !isWeeklyCatchupTime) return;
444
-
445
- // Check if we already sent today's catchup
446
- const catchupKey = isWeeklyCatchupTime ? `weekly_catchup_${dateStr}` : `daily_catchup_${dateStr}`;
447
- const alreadySent = await this.checkMemoryFlag(catchupKey);
448
- if (alreadySent) return;
449
-
450
- console.log(`[autonomy] ${isWeeklyCatchupTime ? 'Weekly' : 'Daily'} catchup time — generating report...`);
451
-
452
- try {
453
- const catchupData = await this.gatherCatchupData(isWeeklyCatchupTime ? 7 : 1);
454
- await this.sendCatchupEmail(catchupData, isWeeklyCatchupTime);
455
- await this.setMemoryFlag(catchupKey);
456
- } catch (err: any) {
457
- console.error(`[autonomy] Catchup email error: ${err.message}`);
458
- }
459
- }
460
-
461
- private async gatherCatchupData(daysBack: number): Promise<CatchupData> {
462
- const since = new Date(Date.now() - daysBack * 24 * 60 * 60 * 1000).toISOString();
463
- const db = this.config.engineDb;
464
- const agentId = this.config.agentId;
465
-
466
- // Count processed emails
467
- let emailsHandled = 0;
468
- try {
469
- const rows = await db.query<any>(
470
- `SELECT COUNT(*) as cnt FROM agent_memory WHERE agent_id = $1 AND category = 'processed_email' AND created_at >= $2`,
471
- [agentId, since]
472
- );
473
- emailsHandled = rows?.[0]?.cnt || 0;
474
- } catch {}
475
-
476
- // Count sessions
477
- let sessionsRun = 0;
478
- try {
479
- const rows = await db.query<any>(
480
- `SELECT COUNT(*) as cnt FROM agent_sessions WHERE agent_id = $1 AND created_at >= $2`,
481
- [agentId, since]
482
- );
483
- sessionsRun = rows?.[0]?.cnt || 0;
484
- } catch {}
485
-
486
- // Count memories stored
487
- let memoriesStored = 0;
488
- try {
489
- const rows = await db.query<any>(
490
- `SELECT COUNT(*) as cnt FROM agent_memory WHERE agent_id = $1 AND created_at >= $2`,
491
- [agentId, since]
492
- );
493
- memoriesStored = rows?.[0]?.cnt || 0;
494
- } catch {}
495
-
496
- // Get key tasks completed (from Google Tasks memories)
497
- let tasksCompleted: string[] = [];
498
- try {
499
- const taskRows = await db.query<any>(
500
- `SELECT content FROM agent_memory WHERE agent_id = $1 AND category = 'skill' AND content LIKE '%task%complete%' AND created_at >= $2 ORDER BY created_at DESC LIMIT 10`,
501
- [agentId, since]
502
- );
503
- tasksCompleted = (taskRows || []).map((r: any) => r.content?.slice(0, 200));
504
- } catch {}
505
-
506
- // Get issues encountered (corrections/errors)
507
- let issuesEncountered: string[] = [];
508
- try {
509
- const issueRows = await db.query<any>(
510
- `SELECT content FROM agent_memory WHERE agent_id = $1 AND category = 'correction' AND created_at >= $2 ORDER BY created_at DESC LIMIT 5`,
511
- [agentId, since]
512
- );
513
- issuesEncountered = (issueRows || []).map((r: any) => r.content?.slice(0, 200));
514
- } catch {}
515
-
516
- // Get knowledge gained
517
- let knowledgeGained: string[] = [];
518
- try {
519
- const knowRows = await db.query<any>(
520
- `SELECT content FROM agent_memory WHERE agent_id = $1 AND (category = 'skill' OR category = 'org_knowledge') AND created_at >= $2 ORDER BY created_at DESC LIMIT 10`,
521
- [agentId, since]
522
- );
523
- knowledgeGained = (knowRows || []).map((r: any) => r.content?.slice(0, 200));
524
- } catch {}
525
-
526
- return { emailsHandled, sessionsRun, memoriesStored, tasksCompleted, issuesEncountered, knowledgeGained };
527
- }
528
-
529
- private async sendCatchupEmail(data: CatchupData, isWeekly: boolean): Promise<void> {
530
- const runtime = this.config.runtime;
531
- const managerEmail = this.config.managerEmail;
532
- const agentName = this.config.agentName;
533
- const role = this.config.role;
534
- const period = isWeekly ? 'last week' : 'yesterday';
535
- const nextPeriod = isWeekly ? 'this week' : 'today';
536
-
537
- const prompt = `You need to send your ${isWeekly ? 'weekly' : 'daily'} catchup email to your manager at ${managerEmail}.
538
-
539
- Here's what you accomplished ${period}:
540
- - Emails handled: ${data.emailsHandled}
541
- - Sessions/conversations: ${data.sessionsRun}
542
- - Memories stored: ${data.memoriesStored}
543
- - Tasks completed: ${data.tasksCompleted.length > 0 ? data.tasksCompleted.join('; ') : 'None tracked'}
544
- - Issues encountered: ${data.issuesEncountered.length > 0 ? data.issuesEncountered.join('; ') : 'None'}
545
- - Knowledge gained: ${data.knowledgeGained.length > 0 ? data.knowledgeGained.join('; ') : 'None tracked'}
546
-
547
- Write and send a concise, professional ${isWeekly ? 'weekly' : 'daily'} summary email. Include:
548
- 1. What you accomplished ${period} (be specific, not generic)
549
- 2. Any issues or blockers you encountered
550
- 3. What you plan to focus on ${nextPeriod}
551
- ${isWeekly ? '4. Goals for the week (create Google Tasks for each goal)' : ''}
552
- ${isWeekly ? '5. Any suggestions for improvement or areas where you need guidance' : ''}
553
-
554
- Keep it under ${isWeekly ? '400' : '250'} words. Be genuine and specific — your manager reads these to stay informed.
555
- Use gmail_send to send the email. Subject: "${isWeekly ? 'Weekly' : 'Daily'} Update — ${agentName}"
556
-
557
- ${isWeekly ? 'After sending the email, create Google Tasks for your goals this week using google_tasks_create.' : ''}`;
558
-
559
- const systemPrompt = `You are ${agentName}, a ${role}. You are sending your ${isWeekly ? 'weekly' : 'daily'} catchup email to your manager.
560
- Be professional but genuine. Use real data from the summary — don't make up accomplishments.
561
- Available tools: gmail_send (to, subject, body), google_tasks_create (listId, title, notes, dueDate).`;
562
-
563
- try {
564
- const session = await runtime.spawnSession({
565
- agentId: this.config.agentId,
566
- message: prompt,
567
- systemPrompt,
568
- });
569
- console.log(`[autonomy] ✅ ${isWeekly ? 'Weekly' : 'Daily'} catchup email session ${session.id} created`);
570
- } catch (err: any) {
571
- console.error(`[autonomy] Failed to send catchup email: ${err.message}`);
572
- }
573
- }
574
-
575
- // ─── 3. Goal Setting & Auto-Reminders ──────────────
576
-
577
- private async checkGoalProgress(): Promise<void> {
578
- if (!this.settings.goalCheckEnabled || !this.config.runtime || !this.clockState.clockedIn) return;
579
-
580
- const now = new Date();
581
- const tz = this.config.timezone || 'UTC';
582
- const localTime = new Date(now.toLocaleString('en-US', { timeZone: tz }));
583
- const hour = localTime.getHours();
584
-
585
- // Check goals at configured hours
586
- const goalHours = this.settings.goalCheckHours || [14, 17];
587
- if (!goalHours.includes(hour)) return;
588
-
589
- const dateStr = localTime.toISOString().split('T')[0];
590
- const checkKey = `goal_check_${dateStr}_${hour}`;
591
- const alreadyChecked = await this.checkMemoryFlag(checkKey);
592
- if (alreadyChecked) return;
593
-
594
- console.log(`[autonomy] Goal progress check at ${hour}:00`);
595
-
596
- try {
597
- const isEndOfDay = hour === Math.max(...goalHours);
598
- const prompt = isEndOfDay
599
- ? `It's end of day. Review your goals and tasks:
600
- 1. Call google_tasks_list to see your current tasks
601
- 2. Review what you completed today
602
- 3. Mark completed tasks as done with google_tasks_complete
603
- 4. For incomplete tasks, update notes with progress
604
- 5. Store a brief end-of-day reflection in memory about what went well and what to improve tomorrow
605
- 6. If any task is blocked, email your manager at ${this.config.managerEmail || 'your manager'} about it`
606
- : `Mid-day goal check:
607
- 1. Call google_tasks_list to see your current tasks
608
- 2. Review progress on today's priorities
609
- 3. If you're behind on any task, adjust your approach
610
- 4. Store any insights in memory for future reference`;
611
-
612
- const session = await this.config.runtime.spawnSession({
613
- agentId: this.config.agentId,
614
- message: prompt,
615
- systemPrompt: `You are ${this.config.agentName}, a ${this.config.role}. You are doing a ${isEndOfDay ? 'end-of-day' : 'mid-day'} goal review. Be thorough but efficient.`,
616
- });
617
- console.log(`[autonomy] ✅ Goal check session ${session.id} created`);
618
- await this.setMemoryFlag(checkKey);
619
- } catch (err: any) {
620
- console.error(`[autonomy] Goal check error: ${err.message}`);
621
- }
622
- }
623
-
624
- // ─── 4. Knowledge Contribution (Friday) ────────────
625
-
626
- private async checkKnowledgeContribution(): Promise<void> {
627
- if (!this.settings.knowledgeContribEnabled || !this.config.runtime || !this.clockState.clockedIn) return;
628
-
629
- const now = new Date();
630
- const tz = this.config.timezone || 'UTC';
631
- const localTime = new Date(now.toLocaleString('en-US', { timeZone: tz }));
632
- const dayOfWeek = localTime.getDay();
633
- const hour = localTime.getHours();
634
- const dateStr = localTime.toISOString().split('T')[0];
635
-
636
- // Configurable day and hour
637
- if (dayOfWeek !== this.settings.knowledgeContribDay || hour !== this.settings.knowledgeContribHour) return;
638
-
639
- const contribKey = `knowledge_contribution_${dateStr}`;
640
- const alreadyDone = await this.checkMemoryFlag(contribKey);
641
- if (alreadyDone) return;
642
-
643
- console.log('[autonomy] Friday knowledge contribution time!');
644
-
645
- try {
646
- // Determine role-based category
647
- const roleCategory = this.mapRoleToKnowledgeCategory(this.config.role);
648
-
649
- const prompt = `It's Friday — time for your weekly knowledge contribution.
650
-
651
- Your role is ${this.config.role}, so focus on ${roleCategory} knowledge.
652
-
653
- Steps:
654
- 1. Search your memory for key learnings this week: memory(action: "search", query: "learned this week")
655
- 2. Search for tool patterns you discovered: memory(action: "search", query: "tool")
656
- 3. Search for corrections and gotchas: memory(action: "search", query: "correction")
657
- 4. Compile the most valuable learnings into knowledge entries
658
- 5. For each entry, store it with a clear title and category:
659
- - memory(action: "set", key: "knowledge-contrib-[topic]", value: "Clear description of the learning, including steps and examples", category: "org_knowledge", importance: "high")
660
-
661
- Categories to contribute to (pick the most relevant):
662
- ${roleCategory === 'support' ? '- customer-issues: Common customer problems and solutions\n- escalation-procedures: When and how to escalate\n- tool-patterns: Efficient ways to use tools\n- communication-templates: Effective response patterns' : ''}
663
- ${roleCategory === 'sales' ? '- objection-handling: How to address common objections\n- product-knowledge: Product features and benefits\n- prospect-research: Effective research methods' : ''}
664
- ${roleCategory === 'engineering' ? '- debugging-patterns: Common issues and fixes\n- architecture-decisions: Design choices and rationale\n- tool-expertise: Development tool tips' : ''}
665
- ${roleCategory === 'general' ? '- best-practices: General workflow improvements\n- tool-patterns: Tool usage tips\n- process-improvements: Better ways to do things' : ''}
666
-
667
- After storing knowledge entries, email your manager a brief summary of what you contributed.
668
- Aim for 3-5 high-quality entries. Quality over quantity.`;
669
-
670
- const session = await this.config.runtime.spawnSession({
671
- agentId: this.config.agentId,
672
- message: prompt,
673
- systemPrompt: `You are ${this.config.agentName}, a ${this.config.role}. You are contributing weekly knowledge to your organization's knowledge base. Focus on ${roleCategory}-related insights. Be specific and actionable — vague entries are useless.`,
674
- });
675
- console.log(`[autonomy] ✅ Knowledge contribution session ${session.id} created`);
676
- await this.setMemoryFlag(contribKey);
677
- } catch (err: any) {
678
- console.error(`[autonomy] Knowledge contribution error: ${err.message}`);
679
- }
680
- }
681
-
682
- private mapRoleToKnowledgeCategory(role: string): string {
683
- const roleLower = (role || '').toLowerCase();
684
- if (roleLower.includes('support') || roleLower.includes('customer') || roleLower.includes('service')) return 'support';
685
- if (roleLower.includes('sales') || roleLower.includes('business dev')) return 'sales';
686
- if (roleLower.includes('engineer') || roleLower.includes('developer') || roleLower.includes('technical')) return 'engineering';
687
- if (roleLower.includes('marketing') || roleLower.includes('content')) return 'marketing';
688
- if (roleLower.includes('hr') || roleLower.includes('human resource') || roleLower.includes('people')) return 'hr';
689
- if (roleLower.includes('finance') || roleLower.includes('accounting')) return 'finance';
690
- if (roleLower.includes('legal') || roleLower.includes('compliance')) return 'legal';
691
- if (roleLower.includes('research') || roleLower.includes('analyst')) return 'research';
692
- if (roleLower.includes('operations') || roleLower.includes('ops')) return 'operations';
693
- return 'general';
694
- }
695
-
696
- // ─── 5. Smart Answer Escalation ────────────────────
697
-
698
- /**
699
- * Generates a system prompt addendum that teaches the agent the escalation workflow.
700
- * This is injected into every email-handling session.
701
- */
702
- static getEscalationPrompt(managerEmail: string | undefined, orgDriveFolderId?: string): string {
703
- return `
704
- == SMART ANSWER WORKFLOW (MANDATORY) ==
705
- When you receive a question or request you're not 100% confident about, follow this escalation chain:
706
-
707
- STEP 1: Search your own memory
708
- - memory(action: "search", query: "relevant keywords")
709
- - Check for similar past questions, corrections, and learned patterns
710
-
711
- STEP 2: Search organization Drive (shared knowledge)
712
- ${orgDriveFolderId ? `- google_drive_list with query "fullText contains 'search terms'" and parents in '${orgDriveFolderId}'` : '- google_drive_list with query "fullText contains \'search terms\'" to search shared docs'}
713
- - Read relevant documents with google_drive_get to find the answer
714
- - Check Google Sheets for data tables, Google Docs for procedures
715
-
716
- STEP 3: If still unsure — ESCALATE to manager
717
- ${managerEmail ? `- Send an email to ${managerEmail} with:` : '- Send an email to your manager with:'}
718
- Subject: "Need Guidance: [Brief topic]"
719
- Body must include:
720
- a) The original question/request (who asked, what they need)
721
- b) What you found in your search (memory + Drive results)
722
- c) Your proposed answer (what you THINK the answer should be)
723
- d) What specifically you're unsure about
724
- e) Ask for approval or correction before responding
725
-
726
- NEVER guess or fabricate an answer. It's better to escalate than to be wrong.
727
-
728
- After receiving manager feedback:
729
- - Store the correct answer in memory as a "correction" or "org_knowledge" entry
730
- - Apply the correction to your response
731
- - Thank the requester for their patience
732
-
733
- The goal: build confidence over time. Today you escalate often. In a month, you'll know most answers from memory.`;
734
- }
735
-
736
- // ─── Helper Methods ────────────────────────────────
737
-
738
- private async checkMemoryFlag(key: string): Promise<boolean> {
739
- if (!this.config.memoryManager) return false;
740
- try {
741
- const results = await this.config.memoryManager.recall(this.config.agentId, key, 1);
742
- return results.some((m: any) => m.content?.includes(key));
743
- } catch {
744
- // Fallback to DB check
745
- try {
746
- const rows = await this.config.engineDb.query<any>(
747
- `SELECT id FROM agent_memory WHERE agent_id = $1 AND content LIKE $2 LIMIT 1`,
748
- [this.config.agentId, `%${key}%`]
749
- );
750
- return (rows && rows.length > 0);
751
- } catch { return false; }
752
- }
753
- }
754
-
755
- private async setMemoryFlag(key: string): Promise<void> {
756
- if (!this.config.memoryManager) return;
757
- try {
758
- await this.config.memoryManager.storeMemory(this.config.agentId, {
759
- content: `${key}: completed at ${new Date().toISOString()}`,
760
- category: 'context',
761
- importance: 'low',
762
- confidence: 1.0,
763
- });
764
- } catch {}
765
- }
766
- }
767
-
768
- // ─── Guardrail Runtime Enforcement ──────────────────────
769
-
770
- /**
771
- * Evaluates guardrail rules against a runtime event.
772
- * Called from runtime hooks (beforeToolCall, afterToolCall, etc.)
773
- */
774
- export class GuardrailEnforcer {
775
- private engineDb: EngineDatabase;
776
- private rules: Map<string, any> = new Map();
777
- private lastLoad = 0;
778
- private readonly RELOAD_INTERVAL = 5 * 60_000; // reload rules every 5 min
779
-
780
- constructor(engineDb: EngineDatabase) {
781
- this.engineDb = engineDb;
782
- }
783
-
784
- private async ensureRulesLoaded(): Promise<void> {
785
- if (Date.now() - this.lastLoad < this.RELOAD_INTERVAL && this.rules.size > 0) return;
786
- try {
787
- const rows = await this.engineDb.query<any>('SELECT * FROM guardrail_rules WHERE enabled = TRUE');
788
- this.rules.clear();
789
- for (const r of (rows || [])) {
790
- this.rules.set(r.id, {
791
- id: r.id, orgId: r.org_id, name: r.name, category: r.category,
792
- ruleType: r.rule_type,
793
- conditions: typeof r.conditions === 'string' ? JSON.parse(r.conditions) : (r.conditions || {}),
794
- action: r.action, severity: r.severity || 'medium',
795
- cooldownMinutes: r.cooldown_minutes || 0,
796
- lastTriggeredAt: r.last_triggered_at, triggerCount: r.trigger_count || 0,
797
- });
798
- }
799
- this.lastLoad = Date.now();
800
- } catch (err: any) {
801
- console.warn(`[guardrail-enforcer] Failed to load rules: ${err.message}`);
802
- }
803
- }
804
-
805
- /**
806
- * Check if an agent action should be blocked or flagged.
807
- * Returns { allowed: true } or { allowed: false, reason, action }
808
- */
809
- async evaluate(event: {
810
- agentId: string;
811
- orgId: string;
812
- type: 'tool_call' | 'email_send' | 'session_start' | 'memory_write';
813
- toolName?: string;
814
- content?: string;
815
- metadata?: Record<string, any>;
816
- }): Promise<{ allowed: boolean; reason?: string; action?: string; ruleId?: string }> {
817
- await this.ensureRulesLoaded();
818
-
819
- for (const rule of this.rules.values()) {
820
- // Check agent scope
821
- if (rule.conditions.agentIds?.length > 0 && !rule.conditions.agentIds.includes(event.agentId)) continue;
822
- // Check org scope
823
- if (rule.orgId !== event.orgId) continue;
824
- // Check cooldown
825
- if (rule.lastTriggeredAt && rule.cooldownMinutes > 0) {
826
- const cooldownUntil = new Date(rule.lastTriggeredAt).getTime() + rule.cooldownMinutes * 60_000;
827
- if (Date.now() < cooldownUntil) continue;
828
- }
829
-
830
- const triggered = await this.evaluateRule(rule, event);
831
- if (triggered) {
832
- await this.recordTrigger(rule, event, triggered);
833
- if (rule.action === 'kill' || rule.action === 'pause') {
834
- return { allowed: false, reason: triggered, action: rule.action, ruleId: rule.id };
835
- }
836
- // alert/notify/log — allow but log
837
- console.warn(`[guardrail-enforcer] Rule "${rule.name}" triggered: ${triggered} (action: ${rule.action})`);
838
- }
839
- }
840
-
841
- return { allowed: true };
842
- }
843
-
844
- private async evaluateRule(rule: any, event: any): Promise<string | null> {
845
- switch (rule.ruleType) {
846
- case 'keyword_detection': {
847
- if (!event.content) return null;
848
- const keywords = rule.conditions.keywords || [];
849
- const contentLower = event.content.toLowerCase();
850
- for (const kw of keywords) {
851
- if (contentLower.includes(kw.toLowerCase())) {
852
- return `Keyword detected: "${kw}" in ${event.type}`;
853
- }
854
- }
855
- return null;
856
- }
857
-
858
- case 'prompt_injection': {
859
- if (!event.content) return null;
860
- const patterns = rule.conditions.patterns || [
861
- 'ignore previous', 'ignore all previous', 'disregard your instructions',
862
- 'you are now', 'new instructions:', 'system prompt:',
863
- 'forget everything', 'override your',
864
- ];
865
- const contentLower = event.content.toLowerCase();
866
- for (const pattern of patterns) {
867
- if (contentLower.includes(pattern.toLowerCase())) {
868
- return `Potential prompt injection detected: "${pattern}"`;
869
- }
870
- }
871
- return null;
872
- }
873
-
874
- case 'data_leak_attempt': {
875
- if (!event.content) return null;
876
- const patterns = rule.conditions.patterns || [
877
- '\\b\\d{3}-\\d{2}-\\d{4}\\b', // SSN
878
- '\\b\\d{4}[- ]?\\d{4}[- ]?\\d{4}[- ]?\\d{4}\\b', // Credit card
879
- '\\bpassword\\s*[:=]\\s*\\S+', // Password in text
880
- ];
881
- for (const pattern of patterns) {
882
- try {
883
- if (new RegExp(pattern, 'i').test(event.content)) {
884
- return `Potential data leak: pattern "${pattern}" matched`;
885
- }
886
- } catch {} // invalid regex, skip
887
- }
888
- return null;
889
- }
890
-
891
- case 'off_hours': {
892
- if (event.type !== 'session_start' && event.type !== 'tool_call') return null;
893
- // Check against agent's schedule
894
- try {
895
- const schedRows = await this.engineDb.query<any>(
896
- `SELECT * FROM work_schedules WHERE agent_id = $1 ORDER BY created_at DESC LIMIT 1`,
897
- [event.agentId]
898
- );
899
- if (schedRows && schedRows.length > 0) {
900
- const sched = schedRows[0];
901
- const config = typeof sched.config === 'string' ? JSON.parse(sched.config) : (sched.config || {});
902
- const hours = config.standardHours;
903
- if (hours?.start && hours?.end) {
904
- const tz = config.timezone || 'UTC';
905
- const localTime = new Date(new Date().toLocaleString('en-US', { timeZone: tz }));
906
- const currentHour = `${String(localTime.getHours()).padStart(2, '0')}:${String(localTime.getMinutes()).padStart(2, '0')}`;
907
- if (currentHour < hours.start || currentHour >= hours.end) {
908
- return `Activity outside work hours (${hours.start}-${hours.end} ${tz})`;
909
- }
910
- }
911
- }
912
- } catch {}
913
- return null;
914
- }
915
-
916
- case 'memory_flood': {
917
- if (event.type !== 'memory_write') return null;
918
- const maxPerHour = rule.conditions.maxPerHour || 50;
919
- try {
920
- const since = new Date(Date.now() - 60 * 60_000).toISOString();
921
- const rows = await this.engineDb.query<any>(
922
- `SELECT COUNT(*) as cnt FROM agent_memory WHERE agent_id = $1 AND created_at >= $2`,
923
- [event.agentId, since]
924
- );
925
- const count = rows?.[0]?.cnt || 0;
926
- if (count > maxPerHour) {
927
- return `Memory flood: ${count} writes in last hour (max: ${maxPerHour})`;
928
- }
929
- } catch {}
930
- return null;
931
- }
932
-
933
- case 'tone_violation': {
934
- if (!event.content || event.type !== 'email_send') return null;
935
- const keywords = rule.conditions.keywords || ['urgent', 'asap', 'immediately'];
936
- const contentLower = event.content.toLowerCase();
937
- let violations = 0;
938
- for (const kw of keywords) {
939
- if (contentLower.includes(kw.toLowerCase())) violations++;
940
- }
941
- if (violations >= (rule.conditions.threshold || 2)) {
942
- return `Tone issue: ${violations} flagged words in outgoing email`;
943
- }
944
- return null;
945
- }
946
-
947
- default:
948
- return null;
949
- }
950
- }
951
-
952
- private async recordTrigger(rule: any, event: any, detail: string): Promise<void> {
953
- try {
954
- // Update trigger count and last triggered
955
- await this.engineDb.execute(
956
- `UPDATE guardrail_rules SET trigger_count = trigger_count + 1, last_triggered_at = $1 WHERE id = $2`,
957
- [new Date().toISOString(), rule.id]
958
- );
959
- // Update cached rule
960
- rule.triggerCount = (rule.triggerCount || 0) + 1;
961
- rule.lastTriggeredAt = new Date().toISOString();
962
-
963
- // Record intervention
964
- await this.engineDb.execute(
965
- `INSERT INTO interventions (id, org_id, agent_id, type, reason, triggered_by, metadata, created_at) VALUES ($1, $2, $3, 'anomaly_detected', $4, 'guardrail_enforcer', $5, $6)`,
966
- [crypto.randomUUID(), rule.orgId, event.agentId, `Rule "${rule.name}": ${detail}`,
967
- JSON.stringify({ ruleId: rule.id, ruleType: rule.ruleType, eventType: event.type, severity: rule.severity }),
968
- new Date().toISOString()]
969
- );
970
- } catch (err: any) {
971
- console.warn(`[guardrail-enforcer] Failed to record trigger: ${err.message}`);
972
- }
973
- }
974
- }