@agenticmail/enterprise 0.5.326 → 0.5.328

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 (868) hide show
  1. package/dist/dashboard/app.js +1 -1
  2. package/dist/dashboard/pages/cluster.js +1 -1
  3. package/logs/cloudflared-error.log +6 -0
  4. package/logs/enterprise-out.log +2 -0
  5. package/package.json +1 -1
  6. package/god_is_great.html +0 -35
  7. package/src/admin/page-registry.ts +0 -290
  8. package/src/admin/routes.ts +0 -2968
  9. package/src/agent-tools/common.ts +0 -260
  10. package/src/agent-tools/index.ts +0 -542
  11. package/src/agent-tools/merge.ts +0 -62
  12. package/src/agent-tools/middleware.ts +0 -436
  13. package/src/agent-tools/schema/typebox.ts +0 -25
  14. package/src/agent-tools/security.ts +0 -352
  15. package/src/agent-tools/tool-resolver.ts +0 -1018
  16. package/src/agent-tools/tools/agenticmail.ts +0 -1017
  17. package/src/agent-tools/tools/bash.ts +0 -179
  18. package/src/agent-tools/tools/browser-tool.schema.ts +0 -112
  19. package/src/agent-tools/tools/browser-tool.ts +0 -388
  20. package/src/agent-tools/tools/browser.ts +0 -764
  21. package/src/agent-tools/tools/edit.ts +0 -100
  22. package/src/agent-tools/tools/enterprise-code-sandbox.ts +0 -395
  23. package/src/agent-tools/tools/enterprise-database.ts +0 -377
  24. package/src/agent-tools/tools/enterprise-diff.ts +0 -580
  25. package/src/agent-tools/tools/enterprise-documents.ts +0 -896
  26. package/src/agent-tools/tools/enterprise-http.ts +0 -485
  27. package/src/agent-tools/tools/enterprise-security-scan.ts +0 -528
  28. package/src/agent-tools/tools/enterprise-spreadsheet.ts +0 -825
  29. package/src/agent-tools/tools/glob.ts +0 -129
  30. package/src/agent-tools/tools/google/calendar.ts +0 -230
  31. package/src/agent-tools/tools/google/chat.ts +0 -725
  32. package/src/agent-tools/tools/google/contacts.ts +0 -209
  33. package/src/agent-tools/tools/google/docs.ts +0 -162
  34. package/src/agent-tools/tools/google/drive.ts +0 -392
  35. package/src/agent-tools/tools/google/forms.ts +0 -367
  36. package/src/agent-tools/tools/google/gmail.ts +0 -897
  37. package/src/agent-tools/tools/google/index.ts +0 -86
  38. package/src/agent-tools/tools/google/maps.ts +0 -543
  39. package/src/agent-tools/tools/google/meeting-voice.ts +0 -885
  40. package/src/agent-tools/tools/google/meetings.ts +0 -1094
  41. package/src/agent-tools/tools/google/sheets.ts +0 -215
  42. package/src/agent-tools/tools/google/slides.ts +0 -559
  43. package/src/agent-tools/tools/google/tasks.ts +0 -200
  44. package/src/agent-tools/tools/grep.ts +0 -178
  45. package/src/agent-tools/tools/integrations/_factory.ts +0 -102
  46. package/src/agent-tools/tools/integrations/activecampaign.ts +0 -14
  47. package/src/agent-tools/tools/integrations/adobe-sign.ts +0 -14
  48. package/src/agent-tools/tools/integrations/adp.ts +0 -14
  49. package/src/agent-tools/tools/integrations/airtable.ts +0 -14
  50. package/src/agent-tools/tools/integrations/apollo.ts +0 -14
  51. package/src/agent-tools/tools/integrations/asana.ts +0 -14
  52. package/src/agent-tools/tools/integrations/auth0.ts +0 -14
  53. package/src/agent-tools/tools/integrations/aws.ts +0 -14
  54. package/src/agent-tools/tools/integrations/azure-devops.ts +0 -14
  55. package/src/agent-tools/tools/integrations/bamboohr.ts +0 -14
  56. package/src/agent-tools/tools/integrations/basecamp.ts +0 -14
  57. package/src/agent-tools/tools/integrations/bigcommerce.ts +0 -14
  58. package/src/agent-tools/tools/integrations/bitbucket.ts +0 -14
  59. package/src/agent-tools/tools/integrations/box.ts +0 -14
  60. package/src/agent-tools/tools/integrations/brex.ts +0 -14
  61. package/src/agent-tools/tools/integrations/buffer.ts +0 -14
  62. package/src/agent-tools/tools/integrations/calendly.ts +0 -14
  63. package/src/agent-tools/tools/integrations/canva.ts +0 -14
  64. package/src/agent-tools/tools/integrations/chargebee.ts +0 -14
  65. package/src/agent-tools/tools/integrations/circleci.ts +0 -14
  66. package/src/agent-tools/tools/integrations/clickup.ts +0 -14
  67. package/src/agent-tools/tools/integrations/close.ts +0 -14
  68. package/src/agent-tools/tools/integrations/cloudflare.ts +0 -14
  69. package/src/agent-tools/tools/integrations/confluence.ts +0 -14
  70. package/src/agent-tools/tools/integrations/contentful.ts +0 -14
  71. package/src/agent-tools/tools/integrations/copper.ts +0 -14
  72. package/src/agent-tools/tools/integrations/crisp.ts +0 -14
  73. package/src/agent-tools/tools/integrations/crowdstrike.ts +0 -14
  74. package/src/agent-tools/tools/integrations/datadog.ts +0 -14
  75. package/src/agent-tools/tools/integrations/digitalocean.ts +0 -14
  76. package/src/agent-tools/tools/integrations/discord.ts +0 -14
  77. package/src/agent-tools/tools/integrations/docker.ts +0 -14
  78. package/src/agent-tools/tools/integrations/docusign.ts +0 -14
  79. package/src/agent-tools/tools/integrations/drift.ts +0 -14
  80. package/src/agent-tools/tools/integrations/dropbox.ts +0 -14
  81. package/src/agent-tools/tools/integrations/figma.ts +0 -14
  82. package/src/agent-tools/tools/integrations/firebase.ts +0 -14
  83. package/src/agent-tools/tools/integrations/flyio.ts +0 -14
  84. package/src/agent-tools/tools/integrations/freshbooks.ts +0 -14
  85. package/src/agent-tools/tools/integrations/freshdesk.ts +0 -14
  86. package/src/agent-tools/tools/integrations/freshsales.ts +0 -14
  87. package/src/agent-tools/tools/integrations/freshservice.ts +0 -14
  88. package/src/agent-tools/tools/integrations/front.ts +0 -14
  89. package/src/agent-tools/tools/integrations/github-actions.ts +0 -14
  90. package/src/agent-tools/tools/integrations/github.ts +0 -14
  91. package/src/agent-tools/tools/integrations/gitlab.ts +0 -14
  92. package/src/agent-tools/tools/integrations/gong.ts +0 -14
  93. package/src/agent-tools/tools/integrations/google-ads.ts +0 -14
  94. package/src/agent-tools/tools/integrations/google-analytics.ts +0 -14
  95. package/src/agent-tools/tools/integrations/google-cloud.ts +0 -14
  96. package/src/agent-tools/tools/integrations/gotomeeting.ts +0 -14
  97. package/src/agent-tools/tools/integrations/grafana.ts +0 -14
  98. package/src/agent-tools/tools/integrations/greenhouse.ts +0 -14
  99. package/src/agent-tools/tools/integrations/gusto.ts +0 -14
  100. package/src/agent-tools/tools/integrations/hashicorp-vault.ts +0 -14
  101. package/src/agent-tools/tools/integrations/heroku.ts +0 -14
  102. package/src/agent-tools/tools/integrations/hibob.ts +0 -14
  103. package/src/agent-tools/tools/integrations/hootsuite.ts +0 -14
  104. package/src/agent-tools/tools/integrations/hubspot.ts +0 -14
  105. package/src/agent-tools/tools/integrations/huggingface.ts +0 -14
  106. package/src/agent-tools/tools/integrations/index.ts +0 -474
  107. package/src/agent-tools/tools/integrations/intercom.ts +0 -14
  108. package/src/agent-tools/tools/integrations/jira.ts +0 -14
  109. package/src/agent-tools/tools/integrations/klaviyo.ts +0 -14
  110. package/src/agent-tools/tools/integrations/kubernetes.ts +0 -14
  111. package/src/agent-tools/tools/integrations/lattice.ts +0 -14
  112. package/src/agent-tools/tools/integrations/launchdarkly.ts +0 -14
  113. package/src/agent-tools/tools/integrations/lever.ts +0 -14
  114. package/src/agent-tools/tools/integrations/linear.ts +0 -14
  115. package/src/agent-tools/tools/integrations/linkedin.ts +0 -14
  116. package/src/agent-tools/tools/integrations/livechat.ts +0 -14
  117. package/src/agent-tools/tools/integrations/loom.ts +0 -14
  118. package/src/agent-tools/tools/integrations/mailchimp.ts +0 -14
  119. package/src/agent-tools/tools/integrations/mailgun.ts +0 -14
  120. package/src/agent-tools/tools/integrations/miro.ts +0 -14
  121. package/src/agent-tools/tools/integrations/mixpanel.ts +0 -14
  122. package/src/agent-tools/tools/integrations/monday.ts +0 -14
  123. package/src/agent-tools/tools/integrations/mongodb-atlas.ts +0 -14
  124. package/src/agent-tools/tools/integrations/neon.ts +0 -14
  125. package/src/agent-tools/tools/integrations/netlify.ts +0 -14
  126. package/src/agent-tools/tools/integrations/netsuite.ts +0 -14
  127. package/src/agent-tools/tools/integrations/newrelic.ts +0 -14
  128. package/src/agent-tools/tools/integrations/notion.ts +0 -14
  129. package/src/agent-tools/tools/integrations/okta.ts +0 -14
  130. package/src/agent-tools/tools/integrations/openai.ts +0 -14
  131. package/src/agent-tools/tools/integrations/opsgenie.ts +0 -14
  132. package/src/agent-tools/tools/integrations/outreach.ts +0 -14
  133. package/src/agent-tools/tools/integrations/paddle.ts +0 -14
  134. package/src/agent-tools/tools/integrations/pagerduty.ts +0 -14
  135. package/src/agent-tools/tools/integrations/pandadoc.ts +0 -14
  136. package/src/agent-tools/tools/integrations/paypal.ts +0 -14
  137. package/src/agent-tools/tools/integrations/personio.ts +0 -14
  138. package/src/agent-tools/tools/integrations/pinecone.ts +0 -14
  139. package/src/agent-tools/tools/integrations/pipedrive.ts +0 -14
  140. package/src/agent-tools/tools/integrations/plaid.ts +0 -14
  141. package/src/agent-tools/tools/integrations/postmark.ts +0 -14
  142. package/src/agent-tools/tools/integrations/power-automate.ts +0 -14
  143. package/src/agent-tools/tools/integrations/quickbooks.ts +0 -14
  144. package/src/agent-tools/tools/integrations/recurly.ts +0 -14
  145. package/src/agent-tools/tools/integrations/reddit.ts +0 -14
  146. package/src/agent-tools/tools/integrations/render.ts +0 -14
  147. package/src/agent-tools/tools/integrations/ringcentral.ts +0 -14
  148. package/src/agent-tools/tools/integrations/rippling.ts +0 -14
  149. package/src/agent-tools/tools/integrations/salesforce.ts +0 -14
  150. package/src/agent-tools/tools/integrations/salesloft.ts +0 -14
  151. package/src/agent-tools/tools/integrations/sanity.ts +0 -14
  152. package/src/agent-tools/tools/integrations/sap.ts +0 -14
  153. package/src/agent-tools/tools/integrations/segment.ts +0 -14
  154. package/src/agent-tools/tools/integrations/sendgrid.ts +0 -14
  155. package/src/agent-tools/tools/integrations/sentry.ts +0 -14
  156. package/src/agent-tools/tools/integrations/servicenow.ts +0 -14
  157. package/src/agent-tools/tools/integrations/shopify.ts +0 -14
  158. package/src/agent-tools/tools/integrations/shortcut.ts +0 -14
  159. package/src/agent-tools/tools/integrations/slack.ts +0 -14
  160. package/src/agent-tools/tools/integrations/smartsheet.ts +0 -14
  161. package/src/agent-tools/tools/integrations/snowflake.ts +0 -14
  162. package/src/agent-tools/tools/integrations/snyk.ts +0 -14
  163. package/src/agent-tools/tools/integrations/splunk.ts +0 -14
  164. package/src/agent-tools/tools/integrations/square.ts +0 -14
  165. package/src/agent-tools/tools/integrations/statuspage.ts +0 -14
  166. package/src/agent-tools/tools/integrations/stripe.ts +0 -14
  167. package/src/agent-tools/tools/integrations/supabase.ts +0 -14
  168. package/src/agent-tools/tools/integrations/teamwork.ts +0 -14
  169. package/src/agent-tools/tools/integrations/telegram.ts +0 -14
  170. package/src/agent-tools/tools/integrations/terraform.ts +0 -14
  171. package/src/agent-tools/tools/integrations/todoist.ts +0 -14
  172. package/src/agent-tools/tools/integrations/trello.ts +0 -14
  173. package/src/agent-tools/tools/integrations/twilio.ts +0 -14
  174. package/src/agent-tools/tools/integrations/twitter.ts +0 -14
  175. package/src/agent-tools/tools/integrations/vercel.ts +0 -14
  176. package/src/agent-tools/tools/integrations/weaviate.ts +0 -14
  177. package/src/agent-tools/tools/integrations/webex.ts +0 -14
  178. package/src/agent-tools/tools/integrations/webflow.ts +0 -14
  179. package/src/agent-tools/tools/integrations/whatsapp.ts +0 -14
  180. package/src/agent-tools/tools/integrations/whereby.ts +0 -14
  181. package/src/agent-tools/tools/integrations/woocommerce.ts +0 -14
  182. package/src/agent-tools/tools/integrations/wordpress.ts +0 -14
  183. package/src/agent-tools/tools/integrations/workday.ts +0 -14
  184. package/src/agent-tools/tools/integrations/wrike.ts +0 -14
  185. package/src/agent-tools/tools/integrations/xero.ts +0 -14
  186. package/src/agent-tools/tools/integrations/youtube.ts +0 -14
  187. package/src/agent-tools/tools/integrations/zendesk.ts +0 -14
  188. package/src/agent-tools/tools/integrations/zoho-crm.ts +0 -14
  189. package/src/agent-tools/tools/integrations/zoom.ts +0 -14
  190. package/src/agent-tools/tools/integrations/zuora.ts +0 -14
  191. package/src/agent-tools/tools/knowledge-search.ts +0 -318
  192. package/src/agent-tools/tools/local/coding.ts +0 -626
  193. package/src/agent-tools/tools/local/dependency-manager.ts +0 -647
  194. package/src/agent-tools/tools/local/file-edit.ts +0 -31
  195. package/src/agent-tools/tools/local/file-list.ts +0 -39
  196. package/src/agent-tools/tools/local/file-ops.ts +0 -48
  197. package/src/agent-tools/tools/local/file-read.ts +0 -39
  198. package/src/agent-tools/tools/local/file-search.ts +0 -46
  199. package/src/agent-tools/tools/local/file-write.ts +0 -28
  200. package/src/agent-tools/tools/local/filesystem.ts +0 -5
  201. package/src/agent-tools/tools/local/index.ts +0 -55
  202. package/src/agent-tools/tools/local/resolve-path.ts +0 -18
  203. package/src/agent-tools/tools/local/shell.ts +0 -277
  204. package/src/agent-tools/tools/local/system-info.ts +0 -29
  205. package/src/agent-tools/tools/management.ts +0 -425
  206. package/src/agent-tools/tools/mcp-bridge.ts +0 -142
  207. package/src/agent-tools/tools/mcp-server-tools.ts +0 -91
  208. package/src/agent-tools/tools/meeting-lifecycle.ts +0 -438
  209. package/src/agent-tools/tools/memory.ts +0 -509
  210. package/src/agent-tools/tools/messaging/index.ts +0 -6
  211. package/src/agent-tools/tools/messaging/telegram.ts +0 -167
  212. package/src/agent-tools/tools/messaging/whatsapp.ts +0 -651
  213. package/src/agent-tools/tools/microsoft/contacts.ts +0 -176
  214. package/src/agent-tools/tools/microsoft/excel-vba.ts +0 -331
  215. package/src/agent-tools/tools/microsoft/excel.ts +0 -261
  216. package/src/agent-tools/tools/microsoft/graph-api.ts +0 -161
  217. package/src/agent-tools/tools/microsoft/index.ts +0 -95
  218. package/src/agent-tools/tools/microsoft/onedrive.ts +0 -429
  219. package/src/agent-tools/tools/microsoft/onenote.ts +0 -186
  220. package/src/agent-tools/tools/microsoft/outlook-calendar.ts +0 -286
  221. package/src/agent-tools/tools/microsoft/outlook-mail.ts +0 -723
  222. package/src/agent-tools/tools/microsoft/planner.ts +0 -200
  223. package/src/agent-tools/tools/microsoft/powerbi.ts +0 -266
  224. package/src/agent-tools/tools/microsoft/powerpoint.ts +0 -186
  225. package/src/agent-tools/tools/microsoft/sharepoint.ts +0 -328
  226. package/src/agent-tools/tools/microsoft/teams.ts +0 -463
  227. package/src/agent-tools/tools/microsoft/todo.ts +0 -181
  228. package/src/agent-tools/tools/oauth-token-provider.ts +0 -101
  229. package/src/agent-tools/tools/read.ts +0 -160
  230. package/src/agent-tools/tools/visual-memory/capture.ts +0 -217
  231. package/src/agent-tools/tools/visual-memory/diff.ts +0 -283
  232. package/src/agent-tools/tools/visual-memory/index.ts +0 -698
  233. package/src/agent-tools/tools/visual-memory/phash.ts +0 -120
  234. package/src/agent-tools/tools/visual-memory/similarity.ts +0 -354
  235. package/src/agent-tools/tools/visual-memory/storage.ts +0 -534
  236. package/src/agent-tools/tools/visual-memory/types.ts +0 -100
  237. package/src/agent-tools/tools/web-fetch-utils.ts +0 -202
  238. package/src/agent-tools/tools/web-fetch.ts +0 -464
  239. package/src/agent-tools/tools/web-search.ts +0 -480
  240. package/src/agent-tools/tools/web-shared.ts +0 -232
  241. package/src/agent-tools/tools/write.ts +0 -68
  242. package/src/agent-tools/types.ts +0 -214
  243. package/src/agenticmail/index.ts +0 -34
  244. package/src/agenticmail/manager.ts +0 -253
  245. package/src/agenticmail/providers/google.ts +0 -391
  246. package/src/agenticmail/providers/imap.ts +0 -454
  247. package/src/agenticmail/providers/index.ts +0 -28
  248. package/src/agenticmail/providers/microsoft.ts +0 -260
  249. package/src/agenticmail/types.ts +0 -173
  250. package/src/auth/routes.ts +0 -1589
  251. package/src/browser/bridge-auth-registry.ts +0 -34
  252. package/src/browser/bridge-server.ts +0 -93
  253. package/src/browser/cdp.helpers.ts +0 -180
  254. package/src/browser/cdp.ts +0 -466
  255. package/src/browser/chrome.executables.ts +0 -625
  256. package/src/browser/chrome.profile-decoration.ts +0 -198
  257. package/src/browser/chrome.ts +0 -349
  258. package/src/browser/client-actions-core.ts +0 -259
  259. package/src/browser/client-actions-observe.ts +0 -184
  260. package/src/browser/client-actions-state.ts +0 -284
  261. package/src/browser/client-actions-types.ts +0 -16
  262. package/src/browser/client-actions-url.ts +0 -11
  263. package/src/browser/client-actions.ts +0 -4
  264. package/src/browser/client-fetch.ts +0 -253
  265. package/src/browser/client.ts +0 -337
  266. package/src/browser/config.ts +0 -301
  267. package/src/browser/constants.ts +0 -8
  268. package/src/browser/control-auth.ts +0 -94
  269. package/src/browser/control-service.ts +0 -81
  270. package/src/browser/csrf.ts +0 -87
  271. package/src/browser/enterprise-compat.ts +0 -562
  272. package/src/browser/extension-relay.ts +0 -834
  273. package/src/browser/http-auth.ts +0 -63
  274. package/src/browser/navigation-guard.ts +0 -50
  275. package/src/browser/paths.ts +0 -49
  276. package/src/browser/playwright.d.ts +0 -12
  277. package/src/browser/profiles-service.ts +0 -187
  278. package/src/browser/profiles.ts +0 -114
  279. package/src/browser/proxy-files.ts +0 -41
  280. package/src/browser/pw-ai-module.ts +0 -52
  281. package/src/browser/pw-ai-state.ts +0 -9
  282. package/src/browser/pw-ai.ts +0 -65
  283. package/src/browser/pw-role-snapshot.ts +0 -434
  284. package/src/browser/pw-session.ts +0 -810
  285. package/src/browser/pw-tools-core.activity.ts +0 -68
  286. package/src/browser/pw-tools-core.downloads.ts +0 -281
  287. package/src/browser/pw-tools-core.interactions.ts +0 -646
  288. package/src/browser/pw-tools-core.responses.ts +0 -124
  289. package/src/browser/pw-tools-core.shared.ts +0 -70
  290. package/src/browser/pw-tools-core.snapshot.ts +0 -213
  291. package/src/browser/pw-tools-core.state.ts +0 -209
  292. package/src/browser/pw-tools-core.storage.ts +0 -128
  293. package/src/browser/pw-tools-core.trace.ts +0 -37
  294. package/src/browser/pw-tools-core.ts +0 -8
  295. package/src/browser/resolved-config-refresh.ts +0 -59
  296. package/src/browser/routes/agent.act.shared.ts +0 -52
  297. package/src/browser/routes/agent.act.ts +0 -575
  298. package/src/browser/routes/agent.debug.ts +0 -149
  299. package/src/browser/routes/agent.shared.ts +0 -143
  300. package/src/browser/routes/agent.snapshot.ts +0 -333
  301. package/src/browser/routes/agent.storage.ts +0 -451
  302. package/src/browser/routes/agent.ts +0 -13
  303. package/src/browser/routes/basic.ts +0 -202
  304. package/src/browser/routes/dispatcher.ts +0 -126
  305. package/src/browser/routes/index.ts +0 -11
  306. package/src/browser/routes/path-output.ts +0 -1
  307. package/src/browser/routes/tabs.ts +0 -217
  308. package/src/browser/routes/types.ts +0 -26
  309. package/src/browser/routes/utils.ts +0 -73
  310. package/src/browser/screenshot.ts +0 -54
  311. package/src/browser/server-context.ts +0 -688
  312. package/src/browser/server-context.types.ts +0 -65
  313. package/src/browser/server-lifecycle.ts +0 -48
  314. package/src/browser/server-middleware.ts +0 -37
  315. package/src/browser/server.ts +0 -110
  316. package/src/browser/target-id.ts +0 -30
  317. package/src/browser/trash.ts +0 -21
  318. package/src/cli-agent.ts +0 -2452
  319. package/src/cli-reset-password.ts +0 -138
  320. package/src/cli-serve.ts +0 -314
  321. package/src/cli.ts +0 -103
  322. package/src/dashboard/HELP-TOOLTIPS-GUIDE.md +0 -45
  323. package/src/dashboard/app.js +0 -579
  324. package/src/dashboard/assets/brand-logos.js +0 -350
  325. package/src/dashboard/assets/icons/emoji-icons.js +0 -893
  326. package/src/dashboard/assets/logo.png +0 -0
  327. package/src/dashboard/assets/provider-logos.js +0 -139
  328. package/src/dashboard/components/error-boundary.js +0 -21
  329. package/src/dashboard/components/help-button.js +0 -65
  330. package/src/dashboard/components/icons.js +0 -64
  331. package/src/dashboard/components/knowledge-link.js +0 -79
  332. package/src/dashboard/components/modal.js +0 -125
  333. package/src/dashboard/components/org-switcher.js +0 -156
  334. package/src/dashboard/components/persona-fields.js +0 -460
  335. package/src/dashboard/components/settings-help.js +0 -193
  336. package/src/dashboard/components/tag-input.js +0 -96
  337. package/src/dashboard/components/timezones.js +0 -352
  338. package/src/dashboard/components/transport-encryption.js +0 -288
  339. package/src/dashboard/components/utils.js +0 -205
  340. package/src/dashboard/data/countries.js +0 -255
  341. package/src/dashboard/docs/activity.html +0 -253
  342. package/src/dashboard/docs/agent-activity.html +0 -199
  343. package/src/dashboard/docs/agent-autonomy.html +0 -161
  344. package/src/dashboard/docs/agent-budget.html +0 -190
  345. package/src/dashboard/docs/agent-channels.html +0 -189
  346. package/src/dashboard/docs/agent-communication.html +0 -171
  347. package/src/dashboard/docs/agent-configuration.html +0 -194
  348. package/src/dashboard/docs/agent-deployment.html +0 -323
  349. package/src/dashboard/docs/agent-email.html +0 -184
  350. package/src/dashboard/docs/agent-guardrails.html +0 -206
  351. package/src/dashboard/docs/agent-manager.html +0 -226
  352. package/src/dashboard/docs/agent-memory.html +0 -215
  353. package/src/dashboard/docs/agent-overview.html +0 -226
  354. package/src/dashboard/docs/agent-permissions.html +0 -305
  355. package/src/dashboard/docs/agent-personal.html +0 -155
  356. package/src/dashboard/docs/agent-security.html +0 -188
  357. package/src/dashboard/docs/agent-skills.html +0 -224
  358. package/src/dashboard/docs/agent-tool-security.html +0 -205
  359. package/src/dashboard/docs/agent-tools.html +0 -238
  360. package/src/dashboard/docs/agent-whatsapp.html +0 -210
  361. package/src/dashboard/docs/agent-workforce.html +0 -199
  362. package/src/dashboard/docs/agents.html +0 -258
  363. package/src/dashboard/docs/approvals.html +0 -200
  364. package/src/dashboard/docs/audit.html +0 -206
  365. package/src/dashboard/docs/browser-providers.html +0 -313
  366. package/src/dashboard/docs/cluster.html +0 -285
  367. package/src/dashboard/docs/community-skills.html +0 -253
  368. package/src/dashboard/docs/compliance.html +0 -221
  369. package/src/dashboard/docs/dashboard.html +0 -84
  370. package/src/dashboard/docs/database-access.html +0 -322
  371. package/src/dashboard/docs/dlp.html +0 -268
  372. package/src/dashboard/docs/docs-style.css +0 -26
  373. package/src/dashboard/docs/domain-status.html +0 -294
  374. package/src/dashboard/docs/guardrails.html +0 -265
  375. package/src/dashboard/docs/journal.html +0 -197
  376. package/src/dashboard/docs/knowledge-contributions.html +0 -286
  377. package/src/dashboard/docs/knowledge.html +0 -268
  378. package/src/dashboard/docs/memory-transfer.html +0 -311
  379. package/src/dashboard/docs/messages.html +0 -217
  380. package/src/dashboard/docs/multi-tenant.html +0 -311
  381. package/src/dashboard/docs/org-chart.html +0 -239
  382. package/src/dashboard/docs/organizations.html +0 -182
  383. package/src/dashboard/docs/roles.html +0 -195
  384. package/src/dashboard/docs/settings-network.html +0 -321
  385. package/src/dashboard/docs/settings-security.html +0 -347
  386. package/src/dashboard/docs/settings-tool-security.html +0 -176
  387. package/src/dashboard/docs/settings.html +0 -280
  388. package/src/dashboard/docs/skill-connections.html +0 -270
  389. package/src/dashboard/docs/skills.html +0 -206
  390. package/src/dashboard/docs/task-pipeline.html +0 -261
  391. package/src/dashboard/docs/transport-encryption.html +0 -359
  392. package/src/dashboard/docs/users.html +0 -225
  393. package/src/dashboard/docs/vault.html +0 -260
  394. package/src/dashboard/docs/workforce.html +0 -245
  395. package/src/dashboard/index.html +0 -444
  396. package/src/dashboard/pages/activity.js +0 -379
  397. package/src/dashboard/pages/agent-detail/activity.js +0 -277
  398. package/src/dashboard/pages/agent-detail/autonomy.js +0 -244
  399. package/src/dashboard/pages/agent-detail/budget.js +0 -269
  400. package/src/dashboard/pages/agent-detail/channels.js +0 -494
  401. package/src/dashboard/pages/agent-detail/communication.js +0 -296
  402. package/src/dashboard/pages/agent-detail/configuration.js +0 -882
  403. package/src/dashboard/pages/agent-detail/deployment.js +0 -958
  404. package/src/dashboard/pages/agent-detail/email.js +0 -674
  405. package/src/dashboard/pages/agent-detail/guardrails.js +0 -521
  406. package/src/dashboard/pages/agent-detail/index.js +0 -261
  407. package/src/dashboard/pages/agent-detail/manager.js +0 -357
  408. package/src/dashboard/pages/agent-detail/meeting-browser.js +0 -933
  409. package/src/dashboard/pages/agent-detail/memory.js +0 -368
  410. package/src/dashboard/pages/agent-detail/overview.js +0 -844
  411. package/src/dashboard/pages/agent-detail/permissions.js +0 -1163
  412. package/src/dashboard/pages/agent-detail/personal-details.js +0 -404
  413. package/src/dashboard/pages/agent-detail/security.js +0 -409
  414. package/src/dashboard/pages/agent-detail/shared.js +0 -85
  415. package/src/dashboard/pages/agent-detail/skills-section.js +0 -183
  416. package/src/dashboard/pages/agent-detail/tool-security.js +0 -380
  417. package/src/dashboard/pages/agent-detail/tools.js +0 -322
  418. package/src/dashboard/pages/agent-detail/whatsapp.js +0 -824
  419. package/src/dashboard/pages/agent-detail/workforce.js +0 -683
  420. package/src/dashboard/pages/agents.js +0 -1242
  421. package/src/dashboard/pages/approvals.js +0 -100
  422. package/src/dashboard/pages/audit.js +0 -198
  423. package/src/dashboard/pages/cluster.js +0 -512
  424. package/src/dashboard/pages/community-skills.js +0 -1219
  425. package/src/dashboard/pages/compliance.js +0 -475
  426. package/src/dashboard/pages/dashboard.js +0 -180
  427. package/src/dashboard/pages/database-access.js +0 -812
  428. package/src/dashboard/pages/dlp.js +0 -293
  429. package/src/dashboard/pages/domain-status.js +0 -951
  430. package/src/dashboard/pages/guardrails.js +0 -1035
  431. package/src/dashboard/pages/journal.js +0 -172
  432. package/src/dashboard/pages/knowledge-contributions.js +0 -1682
  433. package/src/dashboard/pages/knowledge-import.js +0 -455
  434. package/src/dashboard/pages/knowledge.js +0 -582
  435. package/src/dashboard/pages/login.js +0 -1056
  436. package/src/dashboard/pages/memory-transfer.js +0 -631
  437. package/src/dashboard/pages/messages.js +0 -303
  438. package/src/dashboard/pages/org-chart.js +0 -349
  439. package/src/dashboard/pages/organizations.js +0 -1081
  440. package/src/dashboard/pages/roles.js +0 -780
  441. package/src/dashboard/pages/settings.js +0 -3790
  442. package/src/dashboard/pages/skill-connections.js +0 -982
  443. package/src/dashboard/pages/skills.js +0 -879
  444. package/src/dashboard/pages/task-pipeline.js +0 -684
  445. package/src/dashboard/pages/users.js +0 -867
  446. package/src/dashboard/pages/vault.js +0 -791
  447. package/src/dashboard/pages/workforce.js +0 -851
  448. package/src/dashboard/vendor/react-dom.development.js +0 -29924
  449. package/src/dashboard/vendor/react-dom.production.min.js +0 -267
  450. package/src/dashboard/vendor/react.development.js +0 -3343
  451. package/src/dashboard/vendor/react.production.min.js +0 -31
  452. package/src/database-access/agent-tools.ts +0 -193
  453. package/src/database-access/connection-manager.ts +0 -1341
  454. package/src/database-access/index.ts +0 -21
  455. package/src/database-access/query-sanitizer.ts +0 -220
  456. package/src/database-access/routes.ts +0 -226
  457. package/src/database-access/types.ts +0 -226
  458. package/src/db/adapter.ts +0 -510
  459. package/src/db/dynamodb.ts +0 -454
  460. package/src/db/factory.ts +0 -129
  461. package/src/db/mongodb.ts +0 -360
  462. package/src/db/mysql.ts +0 -531
  463. package/src/db/postgres.ts +0 -863
  464. package/src/db/proxy.ts +0 -39
  465. package/src/db/resolve-driver.ts +0 -29
  466. package/src/db/sql-schema.ts +0 -124
  467. package/src/db/sqlite.ts +0 -493
  468. package/src/db/turso.ts +0 -470
  469. package/src/deploy/fly.ts +0 -368
  470. package/src/deploy/managed.ts +0 -235
  471. package/src/domain-lock/cli-recover.ts +0 -591
  472. package/src/domain-lock/cli-verify.ts +0 -190
  473. package/src/domain-lock/index.ts +0 -220
  474. package/src/engine/activity-routes.ts +0 -154
  475. package/src/engine/activity.ts +0 -568
  476. package/src/engine/agent-autonomy.ts +0 -974
  477. package/src/engine/agent-config.ts +0 -646
  478. package/src/engine/agent-heartbeat.ts +0 -720
  479. package/src/engine/agent-hierarchy.ts +0 -1064
  480. package/src/engine/agent-memory.ts +0 -806
  481. package/src/engine/agent-notify.ts +0 -50
  482. package/src/engine/agent-routes.ts +0 -2583
  483. package/src/engine/agent-status.ts +0 -311
  484. package/src/engine/ambient-memory.ts +0 -401
  485. package/src/engine/approvals.ts +0 -615
  486. package/src/engine/assets/thinking-hum.mp3 +0 -0
  487. package/src/engine/catalog-routes.ts +0 -232
  488. package/src/engine/chat-poller.ts +0 -913
  489. package/src/engine/chat-webhook-routes.ts +0 -304
  490. package/src/engine/cli-build-skill.ts +0 -285
  491. package/src/engine/cli-submit-skill.ts +0 -200
  492. package/src/engine/cli-validate.ts +0 -188
  493. package/src/engine/cluster.ts +0 -278
  494. package/src/engine/communication-routes.ts +0 -139
  495. package/src/engine/communication.ts +0 -765
  496. package/src/engine/community-registry.ts +0 -1529
  497. package/src/engine/community-routes.ts +0 -260
  498. package/src/engine/compliance-routes.ts +0 -133
  499. package/src/engine/compliance.ts +0 -1679
  500. package/src/engine/config-bus.ts +0 -103
  501. package/src/engine/db-adapter.ts +0 -1156
  502. package/src/engine/db-schema.ts +0 -1945
  503. package/src/engine/deploy-schema-routes.ts +0 -176
  504. package/src/engine/deployer.ts +0 -957
  505. package/src/engine/dlp-routes.ts +0 -101
  506. package/src/engine/dlp.ts +0 -410
  507. package/src/engine/email-poller.ts +0 -855
  508. package/src/engine/emoji.ts +0 -106
  509. package/src/engine/guardrail-routes.ts +0 -125
  510. package/src/engine/guardrails.ts +0 -465
  511. package/src/engine/index.ts +0 -255
  512. package/src/engine/journal-routes.ts +0 -56
  513. package/src/engine/journal.ts +0 -249
  514. package/src/engine/knowledge-contribution-routes.ts +0 -633
  515. package/src/engine/knowledge-contribution.ts +0 -1386
  516. package/src/engine/knowledge-import/chunker.ts +0 -241
  517. package/src/engine/knowledge-import/import-manager.ts +0 -416
  518. package/src/engine/knowledge-import/index.ts +0 -27
  519. package/src/engine/knowledge-import/processors/clean.ts +0 -149
  520. package/src/engine/knowledge-import/processors/extract-gdrive.ts +0 -102
  521. package/src/engine/knowledge-import/processors/extract-github.ts +0 -74
  522. package/src/engine/knowledge-import/processors/extract-sharepoint.ts +0 -69
  523. package/src/engine/knowledge-import/processors/extract-web.ts +0 -275
  524. package/src/engine/knowledge-import/processors/index.ts +0 -18
  525. package/src/engine/knowledge-import/processors/pipeline.ts +0 -171
  526. package/src/engine/knowledge-import/processors/types.ts +0 -78
  527. package/src/engine/knowledge-import/processors/validate.ts +0 -150
  528. package/src/engine/knowledge-import/provider-file-upload.ts +0 -95
  529. package/src/engine/knowledge-import/provider-github.ts +0 -144
  530. package/src/engine/knowledge-import/provider-google-sites.ts +0 -323
  531. package/src/engine/knowledge-import/provider-sharepoint.ts +0 -276
  532. package/src/engine/knowledge-import/provider-url.ts +0 -218
  533. package/src/engine/knowledge-import/routes.ts +0 -94
  534. package/src/engine/knowledge-import/types.ts +0 -92
  535. package/src/engine/knowledge-routes.ts +0 -231
  536. package/src/engine/knowledge.ts +0 -587
  537. package/src/engine/lifecycle.ts +0 -1420
  538. package/src/engine/mcp-process-manager.ts +0 -573
  539. package/src/engine/meeting-monitor.ts +0 -483
  540. package/src/engine/meeting-voice-intelligence.ts +0 -340
  541. package/src/engine/memory-routes.ts +0 -142
  542. package/src/engine/memory-transfer-routes.ts +0 -339
  543. package/src/engine/messaging-history.ts +0 -177
  544. package/src/engine/messaging-poller.ts +0 -786
  545. package/src/engine/model-fallback.ts +0 -141
  546. package/src/engine/oauth-connect-routes.ts +0 -603
  547. package/src/engine/oauth-connect.ts +0 -304
  548. package/src/engine/onboarding-routes.ts +0 -148
  549. package/src/engine/onboarding.ts +0 -574
  550. package/src/engine/org-approval-routes.ts +0 -146
  551. package/src/engine/org-integration-routes.ts +0 -399
  552. package/src/engine/org-integrations.ts +0 -608
  553. package/src/engine/org-policies.ts +0 -502
  554. package/src/engine/policy-import-routes.ts +0 -125
  555. package/src/engine/policy-import.ts +0 -1186
  556. package/src/engine/policy-routes.ts +0 -163
  557. package/src/engine/routes.ts +0 -1236
  558. package/src/engine/screen-unlock.ts +0 -136
  559. package/src/engine/session-router.ts +0 -212
  560. package/src/engine/skill-updater-routes.ts +0 -132
  561. package/src/engine/skill-updater.ts +0 -480
  562. package/src/engine/skill-validator.ts +0 -331
  563. package/src/engine/skills/agent-management.ts +0 -119
  564. package/src/engine/skills/agent-memory.ts +0 -19
  565. package/src/engine/skills/agenticmail.ts +0 -116
  566. package/src/engine/skills/core-tools.ts +0 -25
  567. package/src/engine/skills/database-access.ts +0 -78
  568. package/src/engine/skills/enterprise-code-sandbox.ts +0 -113
  569. package/src/engine/skills/enterprise-database.ts +0 -123
  570. package/src/engine/skills/enterprise-diff.ts +0 -95
  571. package/src/engine/skills/enterprise-documents.ts +0 -162
  572. package/src/engine/skills/enterprise-http.ts +0 -99
  573. package/src/engine/skills/enterprise-security-scan.ts +0 -125
  574. package/src/engine/skills/enterprise-spreadsheet.ts +0 -171
  575. package/src/engine/skills/gws-admin.ts +0 -18
  576. package/src/engine/skills/gws-calendar.ts +0 -21
  577. package/src/engine/skills/gws-chat.ts +0 -29
  578. package/src/engine/skills/gws-contacts.ts +0 -20
  579. package/src/engine/skills/gws-docs.ts +0 -18
  580. package/src/engine/skills/gws-drive.ts +0 -23
  581. package/src/engine/skills/gws-forms.ts +0 -23
  582. package/src/engine/skills/gws-gmail.ts +0 -30
  583. package/src/engine/skills/gws-groups.ts +0 -17
  584. package/src/engine/skills/gws-keep.ts +0 -17
  585. package/src/engine/skills/gws-maps.ts +0 -25
  586. package/src/engine/skills/gws-meet.ts +0 -23
  587. package/src/engine/skills/gws-sheets.ts +0 -22
  588. package/src/engine/skills/gws-sites.ts +0 -16
  589. package/src/engine/skills/gws-slides.ts +0 -27
  590. package/src/engine/skills/gws-tasks.ts +0 -22
  591. package/src/engine/skills/gws-vault.ts +0 -17
  592. package/src/engine/skills/index.ts +0 -159
  593. package/src/engine/skills/knowledge-search.ts +0 -18
  594. package/src/engine/skills/local-system.ts +0 -61
  595. package/src/engine/skills/m365-admin.ts +0 -18
  596. package/src/engine/skills/m365-bookings.ts +0 -17
  597. package/src/engine/skills/m365-copilot.ts +0 -17
  598. package/src/engine/skills/m365-excel.ts +0 -60
  599. package/src/engine/skills/m365-forms.ts +0 -17
  600. package/src/engine/skills/m365-onedrive.ts +0 -60
  601. package/src/engine/skills/m365-onenote.ts +0 -17
  602. package/src/engine/skills/m365-outlook.ts +0 -27
  603. package/src/engine/skills/m365-planner.ts +0 -18
  604. package/src/engine/skills/m365-power-automate.ts +0 -18
  605. package/src/engine/skills/m365-power-bi.ts +0 -19
  606. package/src/engine/skills/m365-powerpoint.ts +0 -33
  607. package/src/engine/skills/m365-sharepoint.ts +0 -20
  608. package/src/engine/skills/m365-teams.ts +0 -21
  609. package/src/engine/skills/m365-todo.ts +0 -17
  610. package/src/engine/skills/m365-whiteboard.ts +0 -16
  611. package/src/engine/skills/m365-word.ts +0 -42
  612. package/src/engine/skills/mcp-bridge.ts +0 -45
  613. package/src/engine/skills/meeting-lifecycle.ts +0 -20
  614. package/src/engine/skills/messaging.ts +0 -46
  615. package/src/engine/skills/visual-memory.ts +0 -25
  616. package/src/engine/skills.ts +0 -688
  617. package/src/engine/soul-library.ts +0 -142
  618. package/src/engine/soul-templates.json +0 -1525
  619. package/src/engine/storage-manager.ts +0 -252
  620. package/src/engine/storage-routes.ts +0 -113
  621. package/src/engine/storage.ts +0 -528
  622. package/src/engine/task-poller.ts +0 -394
  623. package/src/engine/task-queue-after-spawn.ts +0 -66
  624. package/src/engine/task-queue-before-spawn.ts +0 -113
  625. package/src/engine/task-queue-routes.ts +0 -161
  626. package/src/engine/task-queue.ts +0 -664
  627. package/src/engine/tenant.ts +0 -409
  628. package/src/engine/tool-catalog.ts +0 -354
  629. package/src/engine/vault-routes.ts +0 -134
  630. package/src/engine/vault.ts +0 -601
  631. package/src/engine/workforce-routes.ts +0 -331
  632. package/src/engine/workforce.ts +0 -1161
  633. package/src/index.ts +0 -77
  634. package/src/lib/cidr.ts +0 -122
  635. package/src/lib/config-store.ts +0 -86
  636. package/src/lib/resilience.ts +0 -326
  637. package/src/lib/text-search.ts +0 -358
  638. package/src/mcp/adapters/activecampaign.adapter.ts +0 -391
  639. package/src/mcp/adapters/adobe-sign.adapter.ts +0 -469
  640. package/src/mcp/adapters/adp.adapter.ts +0 -358
  641. package/src/mcp/adapters/airtable.adapter.ts +0 -273
  642. package/src/mcp/adapters/apollo.adapter.ts +0 -420
  643. package/src/mcp/adapters/asana.adapter.ts +0 -315
  644. package/src/mcp/adapters/auth0.adapter.ts +0 -386
  645. package/src/mcp/adapters/aws.adapter.ts +0 -345
  646. package/src/mcp/adapters/azure-devops.adapter.ts +0 -389
  647. package/src/mcp/adapters/bamboohr.adapter.ts +0 -376
  648. package/src/mcp/adapters/basecamp.adapter.ts +0 -366
  649. package/src/mcp/adapters/bigcommerce.adapter.ts +0 -429
  650. package/src/mcp/adapters/bitbucket.adapter.ts +0 -260
  651. package/src/mcp/adapters/box.adapter.ts +0 -350
  652. package/src/mcp/adapters/brex.adapter.ts +0 -367
  653. package/src/mcp/adapters/buffer.adapter.ts +0 -303
  654. package/src/mcp/adapters/calendly.adapter.ts +0 -262
  655. package/src/mcp/adapters/canva.adapter.ts +0 -256
  656. package/src/mcp/adapters/chargebee.adapter.ts +0 -448
  657. package/src/mcp/adapters/circleci.adapter.ts +0 -216
  658. package/src/mcp/adapters/clickup.adapter.ts +0 -335
  659. package/src/mcp/adapters/close.adapter.ts +0 -390
  660. package/src/mcp/adapters/cloudflare.adapter.ts +0 -378
  661. package/src/mcp/adapters/confluence.adapter.ts +0 -301
  662. package/src/mcp/adapters/contentful.adapter.ts +0 -355
  663. package/src/mcp/adapters/copper.adapter.ts +0 -468
  664. package/src/mcp/adapters/crisp.adapter.ts +0 -415
  665. package/src/mcp/adapters/crowdstrike.adapter.ts +0 -413
  666. package/src/mcp/adapters/datadog.adapter.ts +0 -373
  667. package/src/mcp/adapters/digitalocean.adapter.ts +0 -336
  668. package/src/mcp/adapters/discord.adapter.ts +0 -248
  669. package/src/mcp/adapters/docker.adapter.ts +0 -238
  670. package/src/mcp/adapters/docusign.adapter.ts +0 -431
  671. package/src/mcp/adapters/drift.adapter.ts +0 -386
  672. package/src/mcp/adapters/dropbox.adapter.ts +0 -315
  673. package/src/mcp/adapters/figma.adapter.ts +0 -302
  674. package/src/mcp/adapters/firebase.adapter.ts +0 -446
  675. package/src/mcp/adapters/flyio.adapter.ts +0 -302
  676. package/src/mcp/adapters/freshbooks.adapter.ts +0 -474
  677. package/src/mcp/adapters/freshdesk.adapter.ts +0 -441
  678. package/src/mcp/adapters/freshsales.adapter.ts +0 -457
  679. package/src/mcp/adapters/freshservice.adapter.ts +0 -481
  680. package/src/mcp/adapters/front.adapter.ts +0 -357
  681. package/src/mcp/adapters/github-actions.adapter.ts +0 -329
  682. package/src/mcp/adapters/github.adapter.ts +0 -387
  683. package/src/mcp/adapters/gitlab.adapter.ts +0 -368
  684. package/src/mcp/adapters/gong.adapter.ts +0 -386
  685. package/src/mcp/adapters/google-ads.adapter.ts +0 -363
  686. package/src/mcp/adapters/google-analytics.adapter.ts +0 -316
  687. package/src/mcp/adapters/google-cloud.adapter.ts +0 -312
  688. package/src/mcp/adapters/gotomeeting.adapter.ts +0 -255
  689. package/src/mcp/adapters/grafana.adapter.ts +0 -361
  690. package/src/mcp/adapters/greenhouse.adapter.ts +0 -354
  691. package/src/mcp/adapters/gusto.adapter.ts +0 -329
  692. package/src/mcp/adapters/hashicorp-vault.adapter.ts +0 -355
  693. package/src/mcp/adapters/heroku.adapter.ts +0 -291
  694. package/src/mcp/adapters/hibob.adapter.ts +0 -334
  695. package/src/mcp/adapters/hootsuite.adapter.ts +0 -322
  696. package/src/mcp/adapters/hubspot.adapter.ts +0 -400
  697. package/src/mcp/adapters/huggingface.adapter.ts +0 -349
  698. package/src/mcp/adapters/index.ts +0 -524
  699. package/src/mcp/adapters/intercom.adapter.ts +0 -269
  700. package/src/mcp/adapters/jira.adapter.ts +0 -482
  701. package/src/mcp/adapters/klaviyo.adapter.ts +0 -353
  702. package/src/mcp/adapters/kubernetes.adapter.ts +0 -431
  703. package/src/mcp/adapters/lattice.adapter.ts +0 -339
  704. package/src/mcp/adapters/launchdarkly.adapter.ts +0 -368
  705. package/src/mcp/adapters/lever.adapter.ts +0 -347
  706. package/src/mcp/adapters/linear.adapter.ts +0 -300
  707. package/src/mcp/adapters/linkedin.adapter.ts +0 -331
  708. package/src/mcp/adapters/livechat.adapter.ts +0 -259
  709. package/src/mcp/adapters/loom.adapter.ts +0 -230
  710. package/src/mcp/adapters/mailchimp.adapter.ts +0 -394
  711. package/src/mcp/adapters/mailgun.adapter.ts +0 -425
  712. package/src/mcp/adapters/miro.adapter.ts +0 -274
  713. package/src/mcp/adapters/mixpanel.adapter.ts +0 -324
  714. package/src/mcp/adapters/monday.adapter.ts +0 -308
  715. package/src/mcp/adapters/mongodb-atlas.adapter.ts +0 -345
  716. package/src/mcp/adapters/neon.adapter.ts +0 -312
  717. package/src/mcp/adapters/netlify.adapter.ts +0 -324
  718. package/src/mcp/adapters/netsuite.adapter.ts +0 -411
  719. package/src/mcp/adapters/newrelic.adapter.ts +0 -339
  720. package/src/mcp/adapters/notion.adapter.ts +0 -338
  721. package/src/mcp/adapters/okta.adapter.ts +0 -394
  722. package/src/mcp/adapters/openai.adapter.ts +0 -315
  723. package/src/mcp/adapters/opsgenie.adapter.ts +0 -375
  724. package/src/mcp/adapters/outreach.adapter.ts +0 -372
  725. package/src/mcp/adapters/paddle.adapter.ts +0 -467
  726. package/src/mcp/adapters/pagerduty.adapter.ts +0 -412
  727. package/src/mcp/adapters/pandadoc.adapter.ts +0 -389
  728. package/src/mcp/adapters/paypal.adapter.ts +0 -465
  729. package/src/mcp/adapters/personio.adapter.ts +0 -401
  730. package/src/mcp/adapters/pinecone.adapter.ts +0 -340
  731. package/src/mcp/adapters/pipedrive.adapter.ts +0 -324
  732. package/src/mcp/adapters/plaid.adapter.ts +0 -444
  733. package/src/mcp/adapters/postmark.adapter.ts +0 -387
  734. package/src/mcp/adapters/power-automate.adapter.ts +0 -388
  735. package/src/mcp/adapters/quickbooks.adapter.ts +0 -431
  736. package/src/mcp/adapters/recurly.adapter.ts +0 -433
  737. package/src/mcp/adapters/reddit.adapter.ts +0 -371
  738. package/src/mcp/adapters/render.adapter.ts +0 -332
  739. package/src/mcp/adapters/ringcentral.adapter.ts +0 -281
  740. package/src/mcp/adapters/rippling.adapter.ts +0 -287
  741. package/src/mcp/adapters/salesforce.adapter.ts +0 -321
  742. package/src/mcp/adapters/salesloft.adapter.ts +0 -413
  743. package/src/mcp/adapters/sanity.adapter.ts +0 -363
  744. package/src/mcp/adapters/sap.adapter.ts +0 -483
  745. package/src/mcp/adapters/segment.adapter.ts +0 -260
  746. package/src/mcp/adapters/sendgrid.adapter.ts +0 -265
  747. package/src/mcp/adapters/sentry.adapter.ts +0 -331
  748. package/src/mcp/adapters/servicenow.adapter.ts +0 -468
  749. package/src/mcp/adapters/shopify.adapter.ts +0 -451
  750. package/src/mcp/adapters/shortcut.adapter.ts +0 -290
  751. package/src/mcp/adapters/slack.adapter.ts +0 -380
  752. package/src/mcp/adapters/smartsheet.adapter.ts +0 -326
  753. package/src/mcp/adapters/snowflake.adapter.ts +0 -347
  754. package/src/mcp/adapters/snyk.adapter.ts +0 -394
  755. package/src/mcp/adapters/splunk.adapter.ts +0 -403
  756. package/src/mcp/adapters/square.adapter.ts +0 -467
  757. package/src/mcp/adapters/statuspage.adapter.ts +0 -401
  758. package/src/mcp/adapters/stripe.adapter.ts +0 -380
  759. package/src/mcp/adapters/supabase.adapter.ts +0 -334
  760. package/src/mcp/adapters/teamwork.adapter.ts +0 -404
  761. package/src/mcp/adapters/telegram.adapter.ts +0 -299
  762. package/src/mcp/adapters/terraform.adapter.ts +0 -300
  763. package/src/mcp/adapters/todoist.adapter.ts +0 -239
  764. package/src/mcp/adapters/trello.adapter.ts +0 -316
  765. package/src/mcp/adapters/twilio.adapter.ts +0 -233
  766. package/src/mcp/adapters/twitter.adapter.ts +0 -348
  767. package/src/mcp/adapters/vercel.adapter.ts +0 -219
  768. package/src/mcp/adapters/weaviate.adapter.ts +0 -371
  769. package/src/mcp/adapters/webex.adapter.ts +0 -237
  770. package/src/mcp/adapters/webflow.adapter.ts +0 -287
  771. package/src/mcp/adapters/whatsapp.adapter.ts +0 -273
  772. package/src/mcp/adapters/whereby.adapter.ts +0 -240
  773. package/src/mcp/adapters/woocommerce.adapter.ts +0 -454
  774. package/src/mcp/adapters/wordpress.adapter.ts +0 -455
  775. package/src/mcp/adapters/workday.adapter.ts +0 -354
  776. package/src/mcp/adapters/wrike.adapter.ts +0 -349
  777. package/src/mcp/adapters/xero.adapter.ts +0 -472
  778. package/src/mcp/adapters/youtube.adapter.ts +0 -401
  779. package/src/mcp/adapters/zendesk.adapter.ts +0 -399
  780. package/src/mcp/adapters/zoho-crm.adapter.ts +0 -410
  781. package/src/mcp/adapters/zoom.adapter.ts +0 -241
  782. package/src/mcp/adapters/zuora.adapter.ts +0 -476
  783. package/src/mcp/framework/api-executor.ts +0 -192
  784. package/src/mcp/framework/aws-sigv4.ts +0 -216
  785. package/src/mcp/framework/credential-resolver.ts +0 -128
  786. package/src/mcp/framework/oauth-token-manager.ts +0 -22
  787. package/src/mcp/framework/skill-mcp-framework.ts +0 -226
  788. package/src/mcp/framework/types.ts +0 -130
  789. package/src/mcp/index.ts +0 -124
  790. package/src/mcp/integration-catalog.ts +0 -178
  791. package/src/middleware/dns-rebinding.ts +0 -44
  792. package/src/middleware/egress-filter.ts +0 -104
  793. package/src/middleware/firewall.ts +0 -192
  794. package/src/middleware/geo-ip.ts +0 -156
  795. package/src/middleware/index.ts +0 -390
  796. package/src/middleware/network-config.ts +0 -90
  797. package/src/middleware/proxy-config.ts +0 -71
  798. package/src/middleware/request-limits.ts +0 -59
  799. package/src/middleware/transport-encryption.ts +0 -398
  800. package/src/registry/cli.ts +0 -63
  801. package/src/registry/server.ts +0 -504
  802. package/src/runtime/agent-loop.ts +0 -779
  803. package/src/runtime/compaction.ts +0 -638
  804. package/src/runtime/email-channel.ts +0 -120
  805. package/src/runtime/environment.ts +0 -300
  806. package/src/runtime/followup.ts +0 -211
  807. package/src/runtime/gateway.ts +0 -260
  808. package/src/runtime/hooks.ts +0 -564
  809. package/src/runtime/index.ts +0 -1110
  810. package/src/runtime/llm-client.ts +0 -1056
  811. package/src/runtime/model-router.ts +0 -97
  812. package/src/runtime/providers.ts +0 -228
  813. package/src/runtime/session-manager.ts +0 -345
  814. package/src/runtime/subagent.ts +0 -153
  815. package/src/runtime/tool-executor.ts +0 -208
  816. package/src/runtime/types.ts +0 -255
  817. package/src/security/brute-force.ts +0 -423
  818. package/src/security/config.ts +0 -159
  819. package/src/security/csp.ts +0 -407
  820. package/src/security/external-content.ts +0 -299
  821. package/src/security/index.ts +0 -557
  822. package/src/security/input-sanitizer.ts +0 -452
  823. package/src/security/output-filter.ts +0 -575
  824. package/src/security/port-scanner.ts +0 -342
  825. package/src/security/prompt-guard.ts +0 -387
  826. package/src/security/sql-guard.ts +0 -338
  827. package/src/security/threat-logger.ts +0 -484
  828. package/src/server.ts +0 -828
  829. package/src/setup/company.ts +0 -183
  830. package/src/setup/database.ts +0 -153
  831. package/src/setup/deployment.ts +0 -561
  832. package/src/setup/domain.ts +0 -112
  833. package/src/setup/index.ts +0 -171
  834. package/src/setup/provision.ts +0 -532
  835. package/src/setup/registration.ts +0 -302
  836. package/src/system-prompts/catchup.ts +0 -48
  837. package/src/system-prompts/google/calendar.ts +0 -37
  838. package/src/system-prompts/google/chat.ts +0 -92
  839. package/src/system-prompts/google/contacts.ts +0 -25
  840. package/src/system-prompts/google/docs.ts +0 -29
  841. package/src/system-prompts/google/drive.ts +0 -34
  842. package/src/system-prompts/google/forms.ts +0 -25
  843. package/src/system-prompts/google/gmail.ts +0 -50
  844. package/src/system-prompts/google/index.ts +0 -23
  845. package/src/system-prompts/google/maps.ts +0 -20
  846. package/src/system-prompts/google/meet.ts +0 -130
  847. package/src/system-prompts/google/sheets.ts +0 -32
  848. package/src/system-prompts/google/slides.ts +0 -26
  849. package/src/system-prompts/google/tasks.ts +0 -27
  850. package/src/system-prompts/index.ts +0 -88
  851. package/src/system-prompts/microsoft/contacts.ts +0 -34
  852. package/src/system-prompts/microsoft/excel.ts +0 -52
  853. package/src/system-prompts/microsoft/index.ts +0 -31
  854. package/src/system-prompts/microsoft/onedrive.ts +0 -41
  855. package/src/system-prompts/microsoft/onenote.ts +0 -36
  856. package/src/system-prompts/microsoft/outlook-calendar.ts +0 -37
  857. package/src/system-prompts/microsoft/outlook-mail.ts +0 -46
  858. package/src/system-prompts/microsoft/planner.ts +0 -37
  859. package/src/system-prompts/microsoft/powerbi.ts +0 -38
  860. package/src/system-prompts/microsoft/powerpoint.ts +0 -35
  861. package/src/system-prompts/microsoft/sharepoint.ts +0 -44
  862. package/src/system-prompts/microsoft/teams.ts +0 -49
  863. package/src/system-prompts/microsoft/todo.ts +0 -37
  864. package/src/system-prompts/shared-blocks.ts +0 -87
  865. package/src/system-prompts/task.ts +0 -21
  866. package/src/system-prompts/triage.ts +0 -34
  867. package/src/types/hono-env.ts +0 -18
  868. package/src/types/optional-deps.d.ts +0 -10
@@ -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
- }