@agenticmail/enterprise 0.5.327 → 0.5.329

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (888) hide show
  1. package/dist/agent-tools-F3CYENMK.js +13949 -0
  2. package/dist/browser-tool-P57PLVW2.js +4002 -0
  3. package/dist/chunk-3RI3AIJN.js +1519 -0
  4. package/dist/chunk-AD4DFKHR.js +4928 -0
  5. package/dist/chunk-UQXPVWXG.js +5101 -0
  6. package/dist/cli-agent-K6UFZRXC.js +2473 -0
  7. package/dist/cli-serve-4MT7RDEL.js +260 -0
  8. package/dist/cli.js +3 -3
  9. package/dist/dashboard/app.js +1 -1
  10. package/dist/dashboard/components/transport-encryption.js +0 -62
  11. package/dist/dashboard/pages/agent-detail/index.js +5 -2
  12. package/dist/dashboard/pages/agent-detail/manager.js +1 -1
  13. package/dist/dashboard/pages/agent-detail/overview.js +4 -2
  14. package/dist/dashboard/pages/agent-detail/tool-security.js +1 -1
  15. package/dist/dashboard/pages/domain-status.js +3 -6
  16. package/dist/dashboard/pages/memory-transfer.js +1 -1
  17. package/dist/dashboard/pages/messages.js +0 -1
  18. package/dist/dashboard/pages/roles.js +0 -2
  19. package/dist/dashboard/pages/workforce.js +0 -1
  20. package/dist/index.js +3 -3
  21. package/dist/runtime-L5ADJORP.js +45 -0
  22. package/dist/server-KSN56EZQ.js +28 -0
  23. package/dist/setup-UUNBBOQH.js +20 -0
  24. package/logs/cloudflared-error.log +42 -0
  25. package/logs/enterprise-out.log +6 -0
  26. package/package.json +1 -1
  27. package/src/admin/page-registry.ts +0 -290
  28. package/src/admin/routes.ts +0 -2968
  29. package/src/agent-tools/common.ts +0 -260
  30. package/src/agent-tools/index.ts +0 -542
  31. package/src/agent-tools/merge.ts +0 -62
  32. package/src/agent-tools/middleware.ts +0 -436
  33. package/src/agent-tools/schema/typebox.ts +0 -25
  34. package/src/agent-tools/security.ts +0 -352
  35. package/src/agent-tools/tool-resolver.ts +0 -1018
  36. package/src/agent-tools/tools/agenticmail.ts +0 -1017
  37. package/src/agent-tools/tools/bash.ts +0 -179
  38. package/src/agent-tools/tools/browser-tool.schema.ts +0 -112
  39. package/src/agent-tools/tools/browser-tool.ts +0 -388
  40. package/src/agent-tools/tools/browser.ts +0 -764
  41. package/src/agent-tools/tools/edit.ts +0 -100
  42. package/src/agent-tools/tools/enterprise-code-sandbox.ts +0 -395
  43. package/src/agent-tools/tools/enterprise-database.ts +0 -377
  44. package/src/agent-tools/tools/enterprise-diff.ts +0 -580
  45. package/src/agent-tools/tools/enterprise-documents.ts +0 -896
  46. package/src/agent-tools/tools/enterprise-http.ts +0 -485
  47. package/src/agent-tools/tools/enterprise-security-scan.ts +0 -528
  48. package/src/agent-tools/tools/enterprise-spreadsheet.ts +0 -825
  49. package/src/agent-tools/tools/glob.ts +0 -129
  50. package/src/agent-tools/tools/google/calendar.ts +0 -230
  51. package/src/agent-tools/tools/google/chat.ts +0 -725
  52. package/src/agent-tools/tools/google/contacts.ts +0 -209
  53. package/src/agent-tools/tools/google/docs.ts +0 -162
  54. package/src/agent-tools/tools/google/drive.ts +0 -392
  55. package/src/agent-tools/tools/google/forms.ts +0 -367
  56. package/src/agent-tools/tools/google/gmail.ts +0 -897
  57. package/src/agent-tools/tools/google/index.ts +0 -86
  58. package/src/agent-tools/tools/google/maps.ts +0 -543
  59. package/src/agent-tools/tools/google/meeting-voice.ts +0 -885
  60. package/src/agent-tools/tools/google/meetings.ts +0 -1094
  61. package/src/agent-tools/tools/google/sheets.ts +0 -215
  62. package/src/agent-tools/tools/google/slides.ts +0 -559
  63. package/src/agent-tools/tools/google/tasks.ts +0 -200
  64. package/src/agent-tools/tools/grep.ts +0 -178
  65. package/src/agent-tools/tools/integrations/_factory.ts +0 -102
  66. package/src/agent-tools/tools/integrations/activecampaign.ts +0 -14
  67. package/src/agent-tools/tools/integrations/adobe-sign.ts +0 -14
  68. package/src/agent-tools/tools/integrations/adp.ts +0 -14
  69. package/src/agent-tools/tools/integrations/airtable.ts +0 -14
  70. package/src/agent-tools/tools/integrations/apollo.ts +0 -14
  71. package/src/agent-tools/tools/integrations/asana.ts +0 -14
  72. package/src/agent-tools/tools/integrations/auth0.ts +0 -14
  73. package/src/agent-tools/tools/integrations/aws.ts +0 -14
  74. package/src/agent-tools/tools/integrations/azure-devops.ts +0 -14
  75. package/src/agent-tools/tools/integrations/bamboohr.ts +0 -14
  76. package/src/agent-tools/tools/integrations/basecamp.ts +0 -14
  77. package/src/agent-tools/tools/integrations/bigcommerce.ts +0 -14
  78. package/src/agent-tools/tools/integrations/bitbucket.ts +0 -14
  79. package/src/agent-tools/tools/integrations/box.ts +0 -14
  80. package/src/agent-tools/tools/integrations/brex.ts +0 -14
  81. package/src/agent-tools/tools/integrations/buffer.ts +0 -14
  82. package/src/agent-tools/tools/integrations/calendly.ts +0 -14
  83. package/src/agent-tools/tools/integrations/canva.ts +0 -14
  84. package/src/agent-tools/tools/integrations/chargebee.ts +0 -14
  85. package/src/agent-tools/tools/integrations/circleci.ts +0 -14
  86. package/src/agent-tools/tools/integrations/clickup.ts +0 -14
  87. package/src/agent-tools/tools/integrations/close.ts +0 -14
  88. package/src/agent-tools/tools/integrations/cloudflare.ts +0 -14
  89. package/src/agent-tools/tools/integrations/confluence.ts +0 -14
  90. package/src/agent-tools/tools/integrations/contentful.ts +0 -14
  91. package/src/agent-tools/tools/integrations/copper.ts +0 -14
  92. package/src/agent-tools/tools/integrations/crisp.ts +0 -14
  93. package/src/agent-tools/tools/integrations/crowdstrike.ts +0 -14
  94. package/src/agent-tools/tools/integrations/datadog.ts +0 -14
  95. package/src/agent-tools/tools/integrations/digitalocean.ts +0 -14
  96. package/src/agent-tools/tools/integrations/discord.ts +0 -14
  97. package/src/agent-tools/tools/integrations/docker.ts +0 -14
  98. package/src/agent-tools/tools/integrations/docusign.ts +0 -14
  99. package/src/agent-tools/tools/integrations/drift.ts +0 -14
  100. package/src/agent-tools/tools/integrations/dropbox.ts +0 -14
  101. package/src/agent-tools/tools/integrations/figma.ts +0 -14
  102. package/src/agent-tools/tools/integrations/firebase.ts +0 -14
  103. package/src/agent-tools/tools/integrations/flyio.ts +0 -14
  104. package/src/agent-tools/tools/integrations/freshbooks.ts +0 -14
  105. package/src/agent-tools/tools/integrations/freshdesk.ts +0 -14
  106. package/src/agent-tools/tools/integrations/freshsales.ts +0 -14
  107. package/src/agent-tools/tools/integrations/freshservice.ts +0 -14
  108. package/src/agent-tools/tools/integrations/front.ts +0 -14
  109. package/src/agent-tools/tools/integrations/github-actions.ts +0 -14
  110. package/src/agent-tools/tools/integrations/github.ts +0 -14
  111. package/src/agent-tools/tools/integrations/gitlab.ts +0 -14
  112. package/src/agent-tools/tools/integrations/gong.ts +0 -14
  113. package/src/agent-tools/tools/integrations/google-ads.ts +0 -14
  114. package/src/agent-tools/tools/integrations/google-analytics.ts +0 -14
  115. package/src/agent-tools/tools/integrations/google-cloud.ts +0 -14
  116. package/src/agent-tools/tools/integrations/gotomeeting.ts +0 -14
  117. package/src/agent-tools/tools/integrations/grafana.ts +0 -14
  118. package/src/agent-tools/tools/integrations/greenhouse.ts +0 -14
  119. package/src/agent-tools/tools/integrations/gusto.ts +0 -14
  120. package/src/agent-tools/tools/integrations/hashicorp-vault.ts +0 -14
  121. package/src/agent-tools/tools/integrations/heroku.ts +0 -14
  122. package/src/agent-tools/tools/integrations/hibob.ts +0 -14
  123. package/src/agent-tools/tools/integrations/hootsuite.ts +0 -14
  124. package/src/agent-tools/tools/integrations/hubspot.ts +0 -14
  125. package/src/agent-tools/tools/integrations/huggingface.ts +0 -14
  126. package/src/agent-tools/tools/integrations/index.ts +0 -474
  127. package/src/agent-tools/tools/integrations/intercom.ts +0 -14
  128. package/src/agent-tools/tools/integrations/jira.ts +0 -14
  129. package/src/agent-tools/tools/integrations/klaviyo.ts +0 -14
  130. package/src/agent-tools/tools/integrations/kubernetes.ts +0 -14
  131. package/src/agent-tools/tools/integrations/lattice.ts +0 -14
  132. package/src/agent-tools/tools/integrations/launchdarkly.ts +0 -14
  133. package/src/agent-tools/tools/integrations/lever.ts +0 -14
  134. package/src/agent-tools/tools/integrations/linear.ts +0 -14
  135. package/src/agent-tools/tools/integrations/linkedin.ts +0 -14
  136. package/src/agent-tools/tools/integrations/livechat.ts +0 -14
  137. package/src/agent-tools/tools/integrations/loom.ts +0 -14
  138. package/src/agent-tools/tools/integrations/mailchimp.ts +0 -14
  139. package/src/agent-tools/tools/integrations/mailgun.ts +0 -14
  140. package/src/agent-tools/tools/integrations/miro.ts +0 -14
  141. package/src/agent-tools/tools/integrations/mixpanel.ts +0 -14
  142. package/src/agent-tools/tools/integrations/monday.ts +0 -14
  143. package/src/agent-tools/tools/integrations/mongodb-atlas.ts +0 -14
  144. package/src/agent-tools/tools/integrations/neon.ts +0 -14
  145. package/src/agent-tools/tools/integrations/netlify.ts +0 -14
  146. package/src/agent-tools/tools/integrations/netsuite.ts +0 -14
  147. package/src/agent-tools/tools/integrations/newrelic.ts +0 -14
  148. package/src/agent-tools/tools/integrations/notion.ts +0 -14
  149. package/src/agent-tools/tools/integrations/okta.ts +0 -14
  150. package/src/agent-tools/tools/integrations/openai.ts +0 -14
  151. package/src/agent-tools/tools/integrations/opsgenie.ts +0 -14
  152. package/src/agent-tools/tools/integrations/outreach.ts +0 -14
  153. package/src/agent-tools/tools/integrations/paddle.ts +0 -14
  154. package/src/agent-tools/tools/integrations/pagerduty.ts +0 -14
  155. package/src/agent-tools/tools/integrations/pandadoc.ts +0 -14
  156. package/src/agent-tools/tools/integrations/paypal.ts +0 -14
  157. package/src/agent-tools/tools/integrations/personio.ts +0 -14
  158. package/src/agent-tools/tools/integrations/pinecone.ts +0 -14
  159. package/src/agent-tools/tools/integrations/pipedrive.ts +0 -14
  160. package/src/agent-tools/tools/integrations/plaid.ts +0 -14
  161. package/src/agent-tools/tools/integrations/postmark.ts +0 -14
  162. package/src/agent-tools/tools/integrations/power-automate.ts +0 -14
  163. package/src/agent-tools/tools/integrations/quickbooks.ts +0 -14
  164. package/src/agent-tools/tools/integrations/recurly.ts +0 -14
  165. package/src/agent-tools/tools/integrations/reddit.ts +0 -14
  166. package/src/agent-tools/tools/integrations/render.ts +0 -14
  167. package/src/agent-tools/tools/integrations/ringcentral.ts +0 -14
  168. package/src/agent-tools/tools/integrations/rippling.ts +0 -14
  169. package/src/agent-tools/tools/integrations/salesforce.ts +0 -14
  170. package/src/agent-tools/tools/integrations/salesloft.ts +0 -14
  171. package/src/agent-tools/tools/integrations/sanity.ts +0 -14
  172. package/src/agent-tools/tools/integrations/sap.ts +0 -14
  173. package/src/agent-tools/tools/integrations/segment.ts +0 -14
  174. package/src/agent-tools/tools/integrations/sendgrid.ts +0 -14
  175. package/src/agent-tools/tools/integrations/sentry.ts +0 -14
  176. package/src/agent-tools/tools/integrations/servicenow.ts +0 -14
  177. package/src/agent-tools/tools/integrations/shopify.ts +0 -14
  178. package/src/agent-tools/tools/integrations/shortcut.ts +0 -14
  179. package/src/agent-tools/tools/integrations/slack.ts +0 -14
  180. package/src/agent-tools/tools/integrations/smartsheet.ts +0 -14
  181. package/src/agent-tools/tools/integrations/snowflake.ts +0 -14
  182. package/src/agent-tools/tools/integrations/snyk.ts +0 -14
  183. package/src/agent-tools/tools/integrations/splunk.ts +0 -14
  184. package/src/agent-tools/tools/integrations/square.ts +0 -14
  185. package/src/agent-tools/tools/integrations/statuspage.ts +0 -14
  186. package/src/agent-tools/tools/integrations/stripe.ts +0 -14
  187. package/src/agent-tools/tools/integrations/supabase.ts +0 -14
  188. package/src/agent-tools/tools/integrations/teamwork.ts +0 -14
  189. package/src/agent-tools/tools/integrations/telegram.ts +0 -14
  190. package/src/agent-tools/tools/integrations/terraform.ts +0 -14
  191. package/src/agent-tools/tools/integrations/todoist.ts +0 -14
  192. package/src/agent-tools/tools/integrations/trello.ts +0 -14
  193. package/src/agent-tools/tools/integrations/twilio.ts +0 -14
  194. package/src/agent-tools/tools/integrations/twitter.ts +0 -14
  195. package/src/agent-tools/tools/integrations/vercel.ts +0 -14
  196. package/src/agent-tools/tools/integrations/weaviate.ts +0 -14
  197. package/src/agent-tools/tools/integrations/webex.ts +0 -14
  198. package/src/agent-tools/tools/integrations/webflow.ts +0 -14
  199. package/src/agent-tools/tools/integrations/whatsapp.ts +0 -14
  200. package/src/agent-tools/tools/integrations/whereby.ts +0 -14
  201. package/src/agent-tools/tools/integrations/woocommerce.ts +0 -14
  202. package/src/agent-tools/tools/integrations/wordpress.ts +0 -14
  203. package/src/agent-tools/tools/integrations/workday.ts +0 -14
  204. package/src/agent-tools/tools/integrations/wrike.ts +0 -14
  205. package/src/agent-tools/tools/integrations/xero.ts +0 -14
  206. package/src/agent-tools/tools/integrations/youtube.ts +0 -14
  207. package/src/agent-tools/tools/integrations/zendesk.ts +0 -14
  208. package/src/agent-tools/tools/integrations/zoho-crm.ts +0 -14
  209. package/src/agent-tools/tools/integrations/zoom.ts +0 -14
  210. package/src/agent-tools/tools/integrations/zuora.ts +0 -14
  211. package/src/agent-tools/tools/knowledge-search.ts +0 -318
  212. package/src/agent-tools/tools/local/coding.ts +0 -626
  213. package/src/agent-tools/tools/local/dependency-manager.ts +0 -647
  214. package/src/agent-tools/tools/local/file-edit.ts +0 -31
  215. package/src/agent-tools/tools/local/file-list.ts +0 -39
  216. package/src/agent-tools/tools/local/file-ops.ts +0 -48
  217. package/src/agent-tools/tools/local/file-read.ts +0 -39
  218. package/src/agent-tools/tools/local/file-search.ts +0 -46
  219. package/src/agent-tools/tools/local/file-write.ts +0 -28
  220. package/src/agent-tools/tools/local/filesystem.ts +0 -5
  221. package/src/agent-tools/tools/local/index.ts +0 -55
  222. package/src/agent-tools/tools/local/resolve-path.ts +0 -18
  223. package/src/agent-tools/tools/local/shell.ts +0 -277
  224. package/src/agent-tools/tools/local/system-info.ts +0 -29
  225. package/src/agent-tools/tools/management.ts +0 -425
  226. package/src/agent-tools/tools/mcp-bridge.ts +0 -142
  227. package/src/agent-tools/tools/mcp-server-tools.ts +0 -91
  228. package/src/agent-tools/tools/meeting-lifecycle.ts +0 -438
  229. package/src/agent-tools/tools/memory.ts +0 -509
  230. package/src/agent-tools/tools/messaging/index.ts +0 -6
  231. package/src/agent-tools/tools/messaging/telegram.ts +0 -167
  232. package/src/agent-tools/tools/messaging/whatsapp.ts +0 -651
  233. package/src/agent-tools/tools/microsoft/contacts.ts +0 -176
  234. package/src/agent-tools/tools/microsoft/excel-vba.ts +0 -331
  235. package/src/agent-tools/tools/microsoft/excel.ts +0 -261
  236. package/src/agent-tools/tools/microsoft/graph-api.ts +0 -161
  237. package/src/agent-tools/tools/microsoft/index.ts +0 -95
  238. package/src/agent-tools/tools/microsoft/onedrive.ts +0 -429
  239. package/src/agent-tools/tools/microsoft/onenote.ts +0 -186
  240. package/src/agent-tools/tools/microsoft/outlook-calendar.ts +0 -286
  241. package/src/agent-tools/tools/microsoft/outlook-mail.ts +0 -723
  242. package/src/agent-tools/tools/microsoft/planner.ts +0 -200
  243. package/src/agent-tools/tools/microsoft/powerbi.ts +0 -266
  244. package/src/agent-tools/tools/microsoft/powerpoint.ts +0 -186
  245. package/src/agent-tools/tools/microsoft/sharepoint.ts +0 -328
  246. package/src/agent-tools/tools/microsoft/teams.ts +0 -463
  247. package/src/agent-tools/tools/microsoft/todo.ts +0 -181
  248. package/src/agent-tools/tools/oauth-token-provider.ts +0 -101
  249. package/src/agent-tools/tools/read.ts +0 -160
  250. package/src/agent-tools/tools/visual-memory/capture.ts +0 -217
  251. package/src/agent-tools/tools/visual-memory/diff.ts +0 -283
  252. package/src/agent-tools/tools/visual-memory/index.ts +0 -698
  253. package/src/agent-tools/tools/visual-memory/phash.ts +0 -120
  254. package/src/agent-tools/tools/visual-memory/similarity.ts +0 -354
  255. package/src/agent-tools/tools/visual-memory/storage.ts +0 -534
  256. package/src/agent-tools/tools/visual-memory/types.ts +0 -100
  257. package/src/agent-tools/tools/web-fetch-utils.ts +0 -202
  258. package/src/agent-tools/tools/web-fetch.ts +0 -464
  259. package/src/agent-tools/tools/web-search.ts +0 -480
  260. package/src/agent-tools/tools/web-shared.ts +0 -232
  261. package/src/agent-tools/tools/write.ts +0 -68
  262. package/src/agent-tools/types.ts +0 -214
  263. package/src/agenticmail/index.ts +0 -34
  264. package/src/agenticmail/manager.ts +0 -253
  265. package/src/agenticmail/providers/google.ts +0 -391
  266. package/src/agenticmail/providers/imap.ts +0 -454
  267. package/src/agenticmail/providers/index.ts +0 -28
  268. package/src/agenticmail/providers/microsoft.ts +0 -260
  269. package/src/agenticmail/types.ts +0 -173
  270. package/src/auth/routes.ts +0 -1589
  271. package/src/browser/bridge-auth-registry.ts +0 -34
  272. package/src/browser/bridge-server.ts +0 -93
  273. package/src/browser/cdp.helpers.ts +0 -180
  274. package/src/browser/cdp.ts +0 -466
  275. package/src/browser/chrome.executables.ts +0 -625
  276. package/src/browser/chrome.profile-decoration.ts +0 -198
  277. package/src/browser/chrome.ts +0 -349
  278. package/src/browser/client-actions-core.ts +0 -259
  279. package/src/browser/client-actions-observe.ts +0 -184
  280. package/src/browser/client-actions-state.ts +0 -284
  281. package/src/browser/client-actions-types.ts +0 -16
  282. package/src/browser/client-actions-url.ts +0 -11
  283. package/src/browser/client-actions.ts +0 -4
  284. package/src/browser/client-fetch.ts +0 -253
  285. package/src/browser/client.ts +0 -337
  286. package/src/browser/config.ts +0 -301
  287. package/src/browser/constants.ts +0 -8
  288. package/src/browser/control-auth.ts +0 -94
  289. package/src/browser/control-service.ts +0 -81
  290. package/src/browser/csrf.ts +0 -87
  291. package/src/browser/enterprise-compat.ts +0 -562
  292. package/src/browser/extension-relay.ts +0 -834
  293. package/src/browser/http-auth.ts +0 -63
  294. package/src/browser/navigation-guard.ts +0 -50
  295. package/src/browser/paths.ts +0 -49
  296. package/src/browser/playwright.d.ts +0 -12
  297. package/src/browser/profiles-service.ts +0 -187
  298. package/src/browser/profiles.ts +0 -114
  299. package/src/browser/proxy-files.ts +0 -41
  300. package/src/browser/pw-ai-module.ts +0 -52
  301. package/src/browser/pw-ai-state.ts +0 -9
  302. package/src/browser/pw-ai.ts +0 -65
  303. package/src/browser/pw-role-snapshot.ts +0 -434
  304. package/src/browser/pw-session.ts +0 -810
  305. package/src/browser/pw-tools-core.activity.ts +0 -68
  306. package/src/browser/pw-tools-core.downloads.ts +0 -281
  307. package/src/browser/pw-tools-core.interactions.ts +0 -646
  308. package/src/browser/pw-tools-core.responses.ts +0 -124
  309. package/src/browser/pw-tools-core.shared.ts +0 -70
  310. package/src/browser/pw-tools-core.snapshot.ts +0 -213
  311. package/src/browser/pw-tools-core.state.ts +0 -209
  312. package/src/browser/pw-tools-core.storage.ts +0 -128
  313. package/src/browser/pw-tools-core.trace.ts +0 -37
  314. package/src/browser/pw-tools-core.ts +0 -8
  315. package/src/browser/resolved-config-refresh.ts +0 -59
  316. package/src/browser/routes/agent.act.shared.ts +0 -52
  317. package/src/browser/routes/agent.act.ts +0 -575
  318. package/src/browser/routes/agent.debug.ts +0 -149
  319. package/src/browser/routes/agent.shared.ts +0 -143
  320. package/src/browser/routes/agent.snapshot.ts +0 -333
  321. package/src/browser/routes/agent.storage.ts +0 -451
  322. package/src/browser/routes/agent.ts +0 -13
  323. package/src/browser/routes/basic.ts +0 -202
  324. package/src/browser/routes/dispatcher.ts +0 -126
  325. package/src/browser/routes/index.ts +0 -11
  326. package/src/browser/routes/path-output.ts +0 -1
  327. package/src/browser/routes/tabs.ts +0 -217
  328. package/src/browser/routes/types.ts +0 -26
  329. package/src/browser/routes/utils.ts +0 -73
  330. package/src/browser/screenshot.ts +0 -54
  331. package/src/browser/server-context.ts +0 -688
  332. package/src/browser/server-context.types.ts +0 -65
  333. package/src/browser/server-lifecycle.ts +0 -48
  334. package/src/browser/server-middleware.ts +0 -37
  335. package/src/browser/server.ts +0 -110
  336. package/src/browser/target-id.ts +0 -30
  337. package/src/browser/trash.ts +0 -21
  338. package/src/cli-agent.ts +0 -2452
  339. package/src/cli-reset-password.ts +0 -138
  340. package/src/cli-serve.ts +0 -314
  341. package/src/cli.ts +0 -103
  342. package/src/dashboard/app.js +0 -579
  343. package/src/dashboard/assets/brand-logos.js +0 -350
  344. package/src/dashboard/assets/icons/emoji-icons.js +0 -893
  345. package/src/dashboard/assets/logo.png +0 -0
  346. package/src/dashboard/assets/provider-logos.js +0 -139
  347. package/src/dashboard/components/error-boundary.js +0 -21
  348. package/src/dashboard/components/help-button.js +0 -65
  349. package/src/dashboard/components/icons.js +0 -64
  350. package/src/dashboard/components/knowledge-link.js +0 -79
  351. package/src/dashboard/components/modal.js +0 -125
  352. package/src/dashboard/components/org-switcher.js +0 -156
  353. package/src/dashboard/components/persona-fields.js +0 -460
  354. package/src/dashboard/components/settings-help.js +0 -193
  355. package/src/dashboard/components/tag-input.js +0 -96
  356. package/src/dashboard/components/timezones.js +0 -352
  357. package/src/dashboard/components/transport-encryption.js +0 -288
  358. package/src/dashboard/components/utils.js +0 -205
  359. package/src/dashboard/data/countries.js +0 -255
  360. package/src/dashboard/docs/activity.html +0 -253
  361. package/src/dashboard/docs/agent-activity.html +0 -199
  362. package/src/dashboard/docs/agent-autonomy.html +0 -161
  363. package/src/dashboard/docs/agent-budget.html +0 -190
  364. package/src/dashboard/docs/agent-channels.html +0 -189
  365. package/src/dashboard/docs/agent-communication.html +0 -171
  366. package/src/dashboard/docs/agent-configuration.html +0 -194
  367. package/src/dashboard/docs/agent-deployment.html +0 -323
  368. package/src/dashboard/docs/agent-email.html +0 -184
  369. package/src/dashboard/docs/agent-guardrails.html +0 -206
  370. package/src/dashboard/docs/agent-manager.html +0 -226
  371. package/src/dashboard/docs/agent-memory.html +0 -215
  372. package/src/dashboard/docs/agent-overview.html +0 -226
  373. package/src/dashboard/docs/agent-permissions.html +0 -305
  374. package/src/dashboard/docs/agent-personal.html +0 -155
  375. package/src/dashboard/docs/agent-security.html +0 -188
  376. package/src/dashboard/docs/agent-skills.html +0 -224
  377. package/src/dashboard/docs/agent-tool-security.html +0 -205
  378. package/src/dashboard/docs/agent-tools.html +0 -238
  379. package/src/dashboard/docs/agent-whatsapp.html +0 -210
  380. package/src/dashboard/docs/agent-workforce.html +0 -199
  381. package/src/dashboard/docs/agents.html +0 -258
  382. package/src/dashboard/docs/approvals.html +0 -200
  383. package/src/dashboard/docs/audit.html +0 -206
  384. package/src/dashboard/docs/browser-providers.html +0 -313
  385. package/src/dashboard/docs/cluster.html +0 -285
  386. package/src/dashboard/docs/community-skills.html +0 -253
  387. package/src/dashboard/docs/compliance.html +0 -221
  388. package/src/dashboard/docs/dashboard.html +0 -84
  389. package/src/dashboard/docs/database-access.html +0 -322
  390. package/src/dashboard/docs/dlp.html +0 -268
  391. package/src/dashboard/docs/docs-style.css +0 -26
  392. package/src/dashboard/docs/domain-status.html +0 -294
  393. package/src/dashboard/docs/guardrails.html +0 -265
  394. package/src/dashboard/docs/journal.html +0 -197
  395. package/src/dashboard/docs/knowledge-contributions.html +0 -286
  396. package/src/dashboard/docs/knowledge.html +0 -268
  397. package/src/dashboard/docs/memory-transfer.html +0 -311
  398. package/src/dashboard/docs/messages.html +0 -217
  399. package/src/dashboard/docs/multi-tenant.html +0 -311
  400. package/src/dashboard/docs/org-chart.html +0 -239
  401. package/src/dashboard/docs/organizations.html +0 -182
  402. package/src/dashboard/docs/roles.html +0 -195
  403. package/src/dashboard/docs/settings-network.html +0 -321
  404. package/src/dashboard/docs/settings-security.html +0 -347
  405. package/src/dashboard/docs/settings-tool-security.html +0 -176
  406. package/src/dashboard/docs/settings.html +0 -280
  407. package/src/dashboard/docs/skill-connections.html +0 -270
  408. package/src/dashboard/docs/skills.html +0 -206
  409. package/src/dashboard/docs/task-pipeline.html +0 -261
  410. package/src/dashboard/docs/transport-encryption.html +0 -359
  411. package/src/dashboard/docs/users.html +0 -225
  412. package/src/dashboard/docs/vault.html +0 -260
  413. package/src/dashboard/docs/workforce.html +0 -245
  414. package/src/dashboard/index.html +0 -444
  415. package/src/dashboard/pages/activity.js +0 -379
  416. package/src/dashboard/pages/agent-detail/activity.js +0 -277
  417. package/src/dashboard/pages/agent-detail/autonomy.js +0 -244
  418. package/src/dashboard/pages/agent-detail/budget.js +0 -269
  419. package/src/dashboard/pages/agent-detail/channels.js +0 -494
  420. package/src/dashboard/pages/agent-detail/communication.js +0 -296
  421. package/src/dashboard/pages/agent-detail/configuration.js +0 -882
  422. package/src/dashboard/pages/agent-detail/deployment.js +0 -958
  423. package/src/dashboard/pages/agent-detail/email.js +0 -674
  424. package/src/dashboard/pages/agent-detail/guardrails.js +0 -521
  425. package/src/dashboard/pages/agent-detail/index.js +0 -261
  426. package/src/dashboard/pages/agent-detail/manager.js +0 -357
  427. package/src/dashboard/pages/agent-detail/meeting-browser.js +0 -933
  428. package/src/dashboard/pages/agent-detail/memory.js +0 -368
  429. package/src/dashboard/pages/agent-detail/overview.js +0 -844
  430. package/src/dashboard/pages/agent-detail/permissions.js +0 -1163
  431. package/src/dashboard/pages/agent-detail/personal-details.js +0 -404
  432. package/src/dashboard/pages/agent-detail/security.js +0 -409
  433. package/src/dashboard/pages/agent-detail/shared.js +0 -85
  434. package/src/dashboard/pages/agent-detail/skills-section.js +0 -183
  435. package/src/dashboard/pages/agent-detail/tool-security.js +0 -380
  436. package/src/dashboard/pages/agent-detail/tools.js +0 -322
  437. package/src/dashboard/pages/agent-detail/whatsapp.js +0 -824
  438. package/src/dashboard/pages/agent-detail/workforce.js +0 -683
  439. package/src/dashboard/pages/agents.js +0 -1242
  440. package/src/dashboard/pages/approvals.js +0 -100
  441. package/src/dashboard/pages/audit.js +0 -198
  442. package/src/dashboard/pages/cluster.js +0 -512
  443. package/src/dashboard/pages/community-skills.js +0 -1219
  444. package/src/dashboard/pages/compliance.js +0 -475
  445. package/src/dashboard/pages/dashboard.js +0 -180
  446. package/src/dashboard/pages/database-access.js +0 -812
  447. package/src/dashboard/pages/dlp.js +0 -293
  448. package/src/dashboard/pages/domain-status.js +0 -951
  449. package/src/dashboard/pages/guardrails.js +0 -1035
  450. package/src/dashboard/pages/journal.js +0 -172
  451. package/src/dashboard/pages/knowledge-contributions.js +0 -1682
  452. package/src/dashboard/pages/knowledge-import.js +0 -455
  453. package/src/dashboard/pages/knowledge.js +0 -582
  454. package/src/dashboard/pages/login.js +0 -1056
  455. package/src/dashboard/pages/memory-transfer.js +0 -631
  456. package/src/dashboard/pages/messages.js +0 -303
  457. package/src/dashboard/pages/org-chart.js +0 -349
  458. package/src/dashboard/pages/organizations.js +0 -1081
  459. package/src/dashboard/pages/roles.js +0 -780
  460. package/src/dashboard/pages/settings.js +0 -3790
  461. package/src/dashboard/pages/skill-connections.js +0 -982
  462. package/src/dashboard/pages/skills.js +0 -879
  463. package/src/dashboard/pages/task-pipeline.js +0 -684
  464. package/src/dashboard/pages/users.js +0 -867
  465. package/src/dashboard/pages/vault.js +0 -791
  466. package/src/dashboard/pages/workforce.js +0 -851
  467. package/src/dashboard/vendor/react-dom.development.js +0 -29924
  468. package/src/dashboard/vendor/react-dom.production.min.js +0 -267
  469. package/src/dashboard/vendor/react.development.js +0 -3343
  470. package/src/dashboard/vendor/react.production.min.js +0 -31
  471. package/src/database-access/agent-tools.ts +0 -193
  472. package/src/database-access/connection-manager.ts +0 -1341
  473. package/src/database-access/index.ts +0 -21
  474. package/src/database-access/query-sanitizer.ts +0 -220
  475. package/src/database-access/routes.ts +0 -226
  476. package/src/database-access/types.ts +0 -226
  477. package/src/db/adapter.ts +0 -510
  478. package/src/db/dynamodb.ts +0 -454
  479. package/src/db/factory.ts +0 -129
  480. package/src/db/mongodb.ts +0 -360
  481. package/src/db/mysql.ts +0 -531
  482. package/src/db/postgres.ts +0 -863
  483. package/src/db/proxy.ts +0 -39
  484. package/src/db/resolve-driver.ts +0 -29
  485. package/src/db/sql-schema.ts +0 -124
  486. package/src/db/sqlite.ts +0 -493
  487. package/src/db/turso.ts +0 -470
  488. package/src/deploy/fly.ts +0 -368
  489. package/src/deploy/managed.ts +0 -235
  490. package/src/domain-lock/cli-recover.ts +0 -591
  491. package/src/domain-lock/cli-verify.ts +0 -190
  492. package/src/domain-lock/index.ts +0 -220
  493. package/src/engine/activity-routes.ts +0 -154
  494. package/src/engine/activity.ts +0 -568
  495. package/src/engine/agent-autonomy.ts +0 -974
  496. package/src/engine/agent-config.ts +0 -646
  497. package/src/engine/agent-heartbeat.ts +0 -720
  498. package/src/engine/agent-hierarchy.ts +0 -1064
  499. package/src/engine/agent-memory.ts +0 -806
  500. package/src/engine/agent-notify.ts +0 -50
  501. package/src/engine/agent-routes.ts +0 -2583
  502. package/src/engine/agent-status.ts +0 -311
  503. package/src/engine/ambient-memory.ts +0 -401
  504. package/src/engine/approvals.ts +0 -615
  505. package/src/engine/assets/thinking-hum.mp3 +0 -0
  506. package/src/engine/catalog-routes.ts +0 -232
  507. package/src/engine/chat-poller.ts +0 -913
  508. package/src/engine/chat-webhook-routes.ts +0 -304
  509. package/src/engine/cli-build-skill.ts +0 -285
  510. package/src/engine/cli-submit-skill.ts +0 -200
  511. package/src/engine/cli-validate.ts +0 -188
  512. package/src/engine/cluster.ts +0 -278
  513. package/src/engine/communication-routes.ts +0 -139
  514. package/src/engine/communication.ts +0 -765
  515. package/src/engine/community-registry.ts +0 -1529
  516. package/src/engine/community-routes.ts +0 -260
  517. package/src/engine/compliance-routes.ts +0 -133
  518. package/src/engine/compliance.ts +0 -1679
  519. package/src/engine/config-bus.ts +0 -103
  520. package/src/engine/db-adapter.ts +0 -1156
  521. package/src/engine/db-schema.ts +0 -1945
  522. package/src/engine/deploy-schema-routes.ts +0 -176
  523. package/src/engine/deployer.ts +0 -957
  524. package/src/engine/dlp-routes.ts +0 -101
  525. package/src/engine/dlp.ts +0 -410
  526. package/src/engine/email-poller.ts +0 -855
  527. package/src/engine/emoji.ts +0 -106
  528. package/src/engine/guardrail-routes.ts +0 -125
  529. package/src/engine/guardrails.ts +0 -465
  530. package/src/engine/index.ts +0 -255
  531. package/src/engine/journal-routes.ts +0 -56
  532. package/src/engine/journal.ts +0 -249
  533. package/src/engine/knowledge-contribution-routes.ts +0 -633
  534. package/src/engine/knowledge-contribution.ts +0 -1386
  535. package/src/engine/knowledge-import/chunker.ts +0 -241
  536. package/src/engine/knowledge-import/import-manager.ts +0 -416
  537. package/src/engine/knowledge-import/index.ts +0 -27
  538. package/src/engine/knowledge-import/processors/clean.ts +0 -149
  539. package/src/engine/knowledge-import/processors/extract-gdrive.ts +0 -102
  540. package/src/engine/knowledge-import/processors/extract-github.ts +0 -74
  541. package/src/engine/knowledge-import/processors/extract-sharepoint.ts +0 -69
  542. package/src/engine/knowledge-import/processors/extract-web.ts +0 -275
  543. package/src/engine/knowledge-import/processors/index.ts +0 -18
  544. package/src/engine/knowledge-import/processors/pipeline.ts +0 -171
  545. package/src/engine/knowledge-import/processors/types.ts +0 -78
  546. package/src/engine/knowledge-import/processors/validate.ts +0 -150
  547. package/src/engine/knowledge-import/provider-file-upload.ts +0 -95
  548. package/src/engine/knowledge-import/provider-github.ts +0 -144
  549. package/src/engine/knowledge-import/provider-google-sites.ts +0 -323
  550. package/src/engine/knowledge-import/provider-sharepoint.ts +0 -276
  551. package/src/engine/knowledge-import/provider-url.ts +0 -218
  552. package/src/engine/knowledge-import/routes.ts +0 -94
  553. package/src/engine/knowledge-import/types.ts +0 -92
  554. package/src/engine/knowledge-routes.ts +0 -231
  555. package/src/engine/knowledge.ts +0 -587
  556. package/src/engine/lifecycle.ts +0 -1420
  557. package/src/engine/mcp-process-manager.ts +0 -573
  558. package/src/engine/meeting-monitor.ts +0 -483
  559. package/src/engine/meeting-voice-intelligence.ts +0 -340
  560. package/src/engine/memory-routes.ts +0 -142
  561. package/src/engine/memory-transfer-routes.ts +0 -339
  562. package/src/engine/messaging-history.ts +0 -177
  563. package/src/engine/messaging-poller.ts +0 -786
  564. package/src/engine/model-fallback.ts +0 -141
  565. package/src/engine/oauth-connect-routes.ts +0 -603
  566. package/src/engine/oauth-connect.ts +0 -304
  567. package/src/engine/onboarding-routes.ts +0 -148
  568. package/src/engine/onboarding.ts +0 -574
  569. package/src/engine/org-approval-routes.ts +0 -146
  570. package/src/engine/org-integration-routes.ts +0 -399
  571. package/src/engine/org-integrations.ts +0 -608
  572. package/src/engine/org-policies.ts +0 -502
  573. package/src/engine/policy-import-routes.ts +0 -125
  574. package/src/engine/policy-import.ts +0 -1186
  575. package/src/engine/policy-routes.ts +0 -163
  576. package/src/engine/routes.ts +0 -1236
  577. package/src/engine/screen-unlock.ts +0 -136
  578. package/src/engine/session-router.ts +0 -212
  579. package/src/engine/skill-updater-routes.ts +0 -132
  580. package/src/engine/skill-updater.ts +0 -480
  581. package/src/engine/skill-validator.ts +0 -331
  582. package/src/engine/skills/agent-management.ts +0 -119
  583. package/src/engine/skills/agent-memory.ts +0 -19
  584. package/src/engine/skills/agenticmail.ts +0 -116
  585. package/src/engine/skills/core-tools.ts +0 -25
  586. package/src/engine/skills/database-access.ts +0 -78
  587. package/src/engine/skills/enterprise-code-sandbox.ts +0 -113
  588. package/src/engine/skills/enterprise-database.ts +0 -123
  589. package/src/engine/skills/enterprise-diff.ts +0 -95
  590. package/src/engine/skills/enterprise-documents.ts +0 -162
  591. package/src/engine/skills/enterprise-http.ts +0 -99
  592. package/src/engine/skills/enterprise-security-scan.ts +0 -125
  593. package/src/engine/skills/enterprise-spreadsheet.ts +0 -171
  594. package/src/engine/skills/gws-admin.ts +0 -18
  595. package/src/engine/skills/gws-calendar.ts +0 -21
  596. package/src/engine/skills/gws-chat.ts +0 -29
  597. package/src/engine/skills/gws-contacts.ts +0 -20
  598. package/src/engine/skills/gws-docs.ts +0 -18
  599. package/src/engine/skills/gws-drive.ts +0 -23
  600. package/src/engine/skills/gws-forms.ts +0 -23
  601. package/src/engine/skills/gws-gmail.ts +0 -30
  602. package/src/engine/skills/gws-groups.ts +0 -17
  603. package/src/engine/skills/gws-keep.ts +0 -17
  604. package/src/engine/skills/gws-maps.ts +0 -25
  605. package/src/engine/skills/gws-meet.ts +0 -23
  606. package/src/engine/skills/gws-sheets.ts +0 -22
  607. package/src/engine/skills/gws-sites.ts +0 -16
  608. package/src/engine/skills/gws-slides.ts +0 -27
  609. package/src/engine/skills/gws-tasks.ts +0 -22
  610. package/src/engine/skills/gws-vault.ts +0 -17
  611. package/src/engine/skills/index.ts +0 -159
  612. package/src/engine/skills/knowledge-search.ts +0 -18
  613. package/src/engine/skills/local-system.ts +0 -61
  614. package/src/engine/skills/m365-admin.ts +0 -18
  615. package/src/engine/skills/m365-bookings.ts +0 -17
  616. package/src/engine/skills/m365-copilot.ts +0 -17
  617. package/src/engine/skills/m365-excel.ts +0 -60
  618. package/src/engine/skills/m365-forms.ts +0 -17
  619. package/src/engine/skills/m365-onedrive.ts +0 -60
  620. package/src/engine/skills/m365-onenote.ts +0 -17
  621. package/src/engine/skills/m365-outlook.ts +0 -27
  622. package/src/engine/skills/m365-planner.ts +0 -18
  623. package/src/engine/skills/m365-power-automate.ts +0 -18
  624. package/src/engine/skills/m365-power-bi.ts +0 -19
  625. package/src/engine/skills/m365-powerpoint.ts +0 -33
  626. package/src/engine/skills/m365-sharepoint.ts +0 -20
  627. package/src/engine/skills/m365-teams.ts +0 -21
  628. package/src/engine/skills/m365-todo.ts +0 -17
  629. package/src/engine/skills/m365-whiteboard.ts +0 -16
  630. package/src/engine/skills/m365-word.ts +0 -42
  631. package/src/engine/skills/mcp-bridge.ts +0 -45
  632. package/src/engine/skills/meeting-lifecycle.ts +0 -20
  633. package/src/engine/skills/messaging.ts +0 -46
  634. package/src/engine/skills/visual-memory.ts +0 -25
  635. package/src/engine/skills.ts +0 -688
  636. package/src/engine/soul-library.ts +0 -142
  637. package/src/engine/soul-templates.json +0 -1525
  638. package/src/engine/storage-manager.ts +0 -252
  639. package/src/engine/storage-routes.ts +0 -113
  640. package/src/engine/storage.ts +0 -528
  641. package/src/engine/task-poller.ts +0 -394
  642. package/src/engine/task-queue-after-spawn.ts +0 -66
  643. package/src/engine/task-queue-before-spawn.ts +0 -113
  644. package/src/engine/task-queue-routes.ts +0 -161
  645. package/src/engine/task-queue.ts +0 -664
  646. package/src/engine/tenant.ts +0 -409
  647. package/src/engine/tool-catalog.ts +0 -354
  648. package/src/engine/vault-routes.ts +0 -134
  649. package/src/engine/vault.ts +0 -601
  650. package/src/engine/workforce-routes.ts +0 -331
  651. package/src/engine/workforce.ts +0 -1161
  652. package/src/index.ts +0 -77
  653. package/src/lib/cidr.ts +0 -122
  654. package/src/lib/config-store.ts +0 -86
  655. package/src/lib/resilience.ts +0 -326
  656. package/src/lib/text-search.ts +0 -358
  657. package/src/mcp/adapters/activecampaign.adapter.ts +0 -391
  658. package/src/mcp/adapters/adobe-sign.adapter.ts +0 -469
  659. package/src/mcp/adapters/adp.adapter.ts +0 -358
  660. package/src/mcp/adapters/airtable.adapter.ts +0 -273
  661. package/src/mcp/adapters/apollo.adapter.ts +0 -420
  662. package/src/mcp/adapters/asana.adapter.ts +0 -315
  663. package/src/mcp/adapters/auth0.adapter.ts +0 -386
  664. package/src/mcp/adapters/aws.adapter.ts +0 -345
  665. package/src/mcp/adapters/azure-devops.adapter.ts +0 -389
  666. package/src/mcp/adapters/bamboohr.adapter.ts +0 -376
  667. package/src/mcp/adapters/basecamp.adapter.ts +0 -366
  668. package/src/mcp/adapters/bigcommerce.adapter.ts +0 -429
  669. package/src/mcp/adapters/bitbucket.adapter.ts +0 -260
  670. package/src/mcp/adapters/box.adapter.ts +0 -350
  671. package/src/mcp/adapters/brex.adapter.ts +0 -367
  672. package/src/mcp/adapters/buffer.adapter.ts +0 -303
  673. package/src/mcp/adapters/calendly.adapter.ts +0 -262
  674. package/src/mcp/adapters/canva.adapter.ts +0 -256
  675. package/src/mcp/adapters/chargebee.adapter.ts +0 -448
  676. package/src/mcp/adapters/circleci.adapter.ts +0 -216
  677. package/src/mcp/adapters/clickup.adapter.ts +0 -335
  678. package/src/mcp/adapters/close.adapter.ts +0 -390
  679. package/src/mcp/adapters/cloudflare.adapter.ts +0 -378
  680. package/src/mcp/adapters/confluence.adapter.ts +0 -301
  681. package/src/mcp/adapters/contentful.adapter.ts +0 -355
  682. package/src/mcp/adapters/copper.adapter.ts +0 -468
  683. package/src/mcp/adapters/crisp.adapter.ts +0 -415
  684. package/src/mcp/adapters/crowdstrike.adapter.ts +0 -413
  685. package/src/mcp/adapters/datadog.adapter.ts +0 -373
  686. package/src/mcp/adapters/digitalocean.adapter.ts +0 -336
  687. package/src/mcp/adapters/discord.adapter.ts +0 -248
  688. package/src/mcp/adapters/docker.adapter.ts +0 -238
  689. package/src/mcp/adapters/docusign.adapter.ts +0 -431
  690. package/src/mcp/adapters/drift.adapter.ts +0 -386
  691. package/src/mcp/adapters/dropbox.adapter.ts +0 -315
  692. package/src/mcp/adapters/figma.adapter.ts +0 -302
  693. package/src/mcp/adapters/firebase.adapter.ts +0 -446
  694. package/src/mcp/adapters/flyio.adapter.ts +0 -302
  695. package/src/mcp/adapters/freshbooks.adapter.ts +0 -474
  696. package/src/mcp/adapters/freshdesk.adapter.ts +0 -441
  697. package/src/mcp/adapters/freshsales.adapter.ts +0 -457
  698. package/src/mcp/adapters/freshservice.adapter.ts +0 -481
  699. package/src/mcp/adapters/front.adapter.ts +0 -357
  700. package/src/mcp/adapters/github-actions.adapter.ts +0 -329
  701. package/src/mcp/adapters/github.adapter.ts +0 -387
  702. package/src/mcp/adapters/gitlab.adapter.ts +0 -368
  703. package/src/mcp/adapters/gong.adapter.ts +0 -386
  704. package/src/mcp/adapters/google-ads.adapter.ts +0 -363
  705. package/src/mcp/adapters/google-analytics.adapter.ts +0 -316
  706. package/src/mcp/adapters/google-cloud.adapter.ts +0 -312
  707. package/src/mcp/adapters/gotomeeting.adapter.ts +0 -255
  708. package/src/mcp/adapters/grafana.adapter.ts +0 -361
  709. package/src/mcp/adapters/greenhouse.adapter.ts +0 -354
  710. package/src/mcp/adapters/gusto.adapter.ts +0 -329
  711. package/src/mcp/adapters/hashicorp-vault.adapter.ts +0 -355
  712. package/src/mcp/adapters/heroku.adapter.ts +0 -291
  713. package/src/mcp/adapters/hibob.adapter.ts +0 -334
  714. package/src/mcp/adapters/hootsuite.adapter.ts +0 -322
  715. package/src/mcp/adapters/hubspot.adapter.ts +0 -400
  716. package/src/mcp/adapters/huggingface.adapter.ts +0 -349
  717. package/src/mcp/adapters/index.ts +0 -524
  718. package/src/mcp/adapters/intercom.adapter.ts +0 -269
  719. package/src/mcp/adapters/jira.adapter.ts +0 -482
  720. package/src/mcp/adapters/klaviyo.adapter.ts +0 -353
  721. package/src/mcp/adapters/kubernetes.adapter.ts +0 -431
  722. package/src/mcp/adapters/lattice.adapter.ts +0 -339
  723. package/src/mcp/adapters/launchdarkly.adapter.ts +0 -368
  724. package/src/mcp/adapters/lever.adapter.ts +0 -347
  725. package/src/mcp/adapters/linear.adapter.ts +0 -300
  726. package/src/mcp/adapters/linkedin.adapter.ts +0 -331
  727. package/src/mcp/adapters/livechat.adapter.ts +0 -259
  728. package/src/mcp/adapters/loom.adapter.ts +0 -230
  729. package/src/mcp/adapters/mailchimp.adapter.ts +0 -394
  730. package/src/mcp/adapters/mailgun.adapter.ts +0 -425
  731. package/src/mcp/adapters/miro.adapter.ts +0 -274
  732. package/src/mcp/adapters/mixpanel.adapter.ts +0 -324
  733. package/src/mcp/adapters/monday.adapter.ts +0 -308
  734. package/src/mcp/adapters/mongodb-atlas.adapter.ts +0 -345
  735. package/src/mcp/adapters/neon.adapter.ts +0 -312
  736. package/src/mcp/adapters/netlify.adapter.ts +0 -324
  737. package/src/mcp/adapters/netsuite.adapter.ts +0 -411
  738. package/src/mcp/adapters/newrelic.adapter.ts +0 -339
  739. package/src/mcp/adapters/notion.adapter.ts +0 -338
  740. package/src/mcp/adapters/okta.adapter.ts +0 -394
  741. package/src/mcp/adapters/openai.adapter.ts +0 -315
  742. package/src/mcp/adapters/opsgenie.adapter.ts +0 -375
  743. package/src/mcp/adapters/outreach.adapter.ts +0 -372
  744. package/src/mcp/adapters/paddle.adapter.ts +0 -467
  745. package/src/mcp/adapters/pagerduty.adapter.ts +0 -412
  746. package/src/mcp/adapters/pandadoc.adapter.ts +0 -389
  747. package/src/mcp/adapters/paypal.adapter.ts +0 -465
  748. package/src/mcp/adapters/personio.adapter.ts +0 -401
  749. package/src/mcp/adapters/pinecone.adapter.ts +0 -340
  750. package/src/mcp/adapters/pipedrive.adapter.ts +0 -324
  751. package/src/mcp/adapters/plaid.adapter.ts +0 -444
  752. package/src/mcp/adapters/postmark.adapter.ts +0 -387
  753. package/src/mcp/adapters/power-automate.adapter.ts +0 -388
  754. package/src/mcp/adapters/quickbooks.adapter.ts +0 -431
  755. package/src/mcp/adapters/recurly.adapter.ts +0 -433
  756. package/src/mcp/adapters/reddit.adapter.ts +0 -371
  757. package/src/mcp/adapters/render.adapter.ts +0 -332
  758. package/src/mcp/adapters/ringcentral.adapter.ts +0 -281
  759. package/src/mcp/adapters/rippling.adapter.ts +0 -287
  760. package/src/mcp/adapters/salesforce.adapter.ts +0 -321
  761. package/src/mcp/adapters/salesloft.adapter.ts +0 -413
  762. package/src/mcp/adapters/sanity.adapter.ts +0 -363
  763. package/src/mcp/adapters/sap.adapter.ts +0 -483
  764. package/src/mcp/adapters/segment.adapter.ts +0 -260
  765. package/src/mcp/adapters/sendgrid.adapter.ts +0 -265
  766. package/src/mcp/adapters/sentry.adapter.ts +0 -331
  767. package/src/mcp/adapters/servicenow.adapter.ts +0 -468
  768. package/src/mcp/adapters/shopify.adapter.ts +0 -451
  769. package/src/mcp/adapters/shortcut.adapter.ts +0 -290
  770. package/src/mcp/adapters/slack.adapter.ts +0 -380
  771. package/src/mcp/adapters/smartsheet.adapter.ts +0 -326
  772. package/src/mcp/adapters/snowflake.adapter.ts +0 -347
  773. package/src/mcp/adapters/snyk.adapter.ts +0 -394
  774. package/src/mcp/adapters/splunk.adapter.ts +0 -403
  775. package/src/mcp/adapters/square.adapter.ts +0 -467
  776. package/src/mcp/adapters/statuspage.adapter.ts +0 -401
  777. package/src/mcp/adapters/stripe.adapter.ts +0 -380
  778. package/src/mcp/adapters/supabase.adapter.ts +0 -334
  779. package/src/mcp/adapters/teamwork.adapter.ts +0 -404
  780. package/src/mcp/adapters/telegram.adapter.ts +0 -299
  781. package/src/mcp/adapters/terraform.adapter.ts +0 -300
  782. package/src/mcp/adapters/todoist.adapter.ts +0 -239
  783. package/src/mcp/adapters/trello.adapter.ts +0 -316
  784. package/src/mcp/adapters/twilio.adapter.ts +0 -233
  785. package/src/mcp/adapters/twitter.adapter.ts +0 -348
  786. package/src/mcp/adapters/vercel.adapter.ts +0 -219
  787. package/src/mcp/adapters/weaviate.adapter.ts +0 -371
  788. package/src/mcp/adapters/webex.adapter.ts +0 -237
  789. package/src/mcp/adapters/webflow.adapter.ts +0 -287
  790. package/src/mcp/adapters/whatsapp.adapter.ts +0 -273
  791. package/src/mcp/adapters/whereby.adapter.ts +0 -240
  792. package/src/mcp/adapters/woocommerce.adapter.ts +0 -454
  793. package/src/mcp/adapters/wordpress.adapter.ts +0 -455
  794. package/src/mcp/adapters/workday.adapter.ts +0 -354
  795. package/src/mcp/adapters/wrike.adapter.ts +0 -349
  796. package/src/mcp/adapters/xero.adapter.ts +0 -472
  797. package/src/mcp/adapters/youtube.adapter.ts +0 -401
  798. package/src/mcp/adapters/zendesk.adapter.ts +0 -399
  799. package/src/mcp/adapters/zoho-crm.adapter.ts +0 -410
  800. package/src/mcp/adapters/zoom.adapter.ts +0 -241
  801. package/src/mcp/adapters/zuora.adapter.ts +0 -476
  802. package/src/mcp/framework/api-executor.ts +0 -192
  803. package/src/mcp/framework/aws-sigv4.ts +0 -216
  804. package/src/mcp/framework/credential-resolver.ts +0 -128
  805. package/src/mcp/framework/oauth-token-manager.ts +0 -22
  806. package/src/mcp/framework/skill-mcp-framework.ts +0 -226
  807. package/src/mcp/framework/types.ts +0 -130
  808. package/src/mcp/index.ts +0 -124
  809. package/src/mcp/integration-catalog.ts +0 -178
  810. package/src/middleware/dns-rebinding.ts +0 -44
  811. package/src/middleware/egress-filter.ts +0 -104
  812. package/src/middleware/firewall.ts +0 -192
  813. package/src/middleware/geo-ip.ts +0 -156
  814. package/src/middleware/index.ts +0 -390
  815. package/src/middleware/network-config.ts +0 -90
  816. package/src/middleware/proxy-config.ts +0 -71
  817. package/src/middleware/request-limits.ts +0 -59
  818. package/src/middleware/transport-encryption.ts +0 -398
  819. package/src/registry/cli.ts +0 -63
  820. package/src/registry/server.ts +0 -504
  821. package/src/runtime/agent-loop.ts +0 -779
  822. package/src/runtime/compaction.ts +0 -638
  823. package/src/runtime/email-channel.ts +0 -120
  824. package/src/runtime/environment.ts +0 -300
  825. package/src/runtime/followup.ts +0 -211
  826. package/src/runtime/gateway.ts +0 -260
  827. package/src/runtime/hooks.ts +0 -564
  828. package/src/runtime/index.ts +0 -1110
  829. package/src/runtime/llm-client.ts +0 -1056
  830. package/src/runtime/model-router.ts +0 -97
  831. package/src/runtime/providers.ts +0 -228
  832. package/src/runtime/session-manager.ts +0 -345
  833. package/src/runtime/subagent.ts +0 -153
  834. package/src/runtime/tool-executor.ts +0 -208
  835. package/src/runtime/types.ts +0 -255
  836. package/src/security/brute-force.ts +0 -423
  837. package/src/security/config.ts +0 -159
  838. package/src/security/csp.ts +0 -407
  839. package/src/security/external-content.ts +0 -299
  840. package/src/security/index.ts +0 -557
  841. package/src/security/input-sanitizer.ts +0 -452
  842. package/src/security/output-filter.ts +0 -575
  843. package/src/security/port-scanner.ts +0 -342
  844. package/src/security/prompt-guard.ts +0 -387
  845. package/src/security/sql-guard.ts +0 -338
  846. package/src/security/threat-logger.ts +0 -484
  847. package/src/server.ts +0 -828
  848. package/src/setup/company.ts +0 -183
  849. package/src/setup/database.ts +0 -153
  850. package/src/setup/deployment.ts +0 -561
  851. package/src/setup/domain.ts +0 -112
  852. package/src/setup/index.ts +0 -171
  853. package/src/setup/provision.ts +0 -532
  854. package/src/setup/registration.ts +0 -302
  855. package/src/system-prompts/catchup.ts +0 -48
  856. package/src/system-prompts/google/calendar.ts +0 -37
  857. package/src/system-prompts/google/chat.ts +0 -92
  858. package/src/system-prompts/google/contacts.ts +0 -25
  859. package/src/system-prompts/google/docs.ts +0 -29
  860. package/src/system-prompts/google/drive.ts +0 -34
  861. package/src/system-prompts/google/forms.ts +0 -25
  862. package/src/system-prompts/google/gmail.ts +0 -50
  863. package/src/system-prompts/google/index.ts +0 -23
  864. package/src/system-prompts/google/maps.ts +0 -20
  865. package/src/system-prompts/google/meet.ts +0 -130
  866. package/src/system-prompts/google/sheets.ts +0 -32
  867. package/src/system-prompts/google/slides.ts +0 -26
  868. package/src/system-prompts/google/tasks.ts +0 -27
  869. package/src/system-prompts/index.ts +0 -88
  870. package/src/system-prompts/microsoft/contacts.ts +0 -34
  871. package/src/system-prompts/microsoft/excel.ts +0 -52
  872. package/src/system-prompts/microsoft/index.ts +0 -31
  873. package/src/system-prompts/microsoft/onedrive.ts +0 -41
  874. package/src/system-prompts/microsoft/onenote.ts +0 -36
  875. package/src/system-prompts/microsoft/outlook-calendar.ts +0 -37
  876. package/src/system-prompts/microsoft/outlook-mail.ts +0 -46
  877. package/src/system-prompts/microsoft/planner.ts +0 -37
  878. package/src/system-prompts/microsoft/powerbi.ts +0 -38
  879. package/src/system-prompts/microsoft/powerpoint.ts +0 -35
  880. package/src/system-prompts/microsoft/sharepoint.ts +0 -44
  881. package/src/system-prompts/microsoft/teams.ts +0 -49
  882. package/src/system-prompts/microsoft/todo.ts +0 -37
  883. package/src/system-prompts/shared-blocks.ts +0 -87
  884. package/src/system-prompts/task.ts +0 -21
  885. package/src/system-prompts/triage.ts +0 -34
  886. package/src/types/hono-env.ts +0 -18
  887. package/src/types/optional-deps.d.ts +0 -10
  888. /package/{src → dist}/dashboard/HELP-TOOLTIPS-GUIDE.md +0 -0
@@ -1,1186 +0,0 @@
1
- /**
2
- * Bulk Policy Import Engine
3
- *
4
- * Supports batch import of organization policies from multiple formats:
5
- * JSON arrays, CSV, Markdown documents, HTML, plain text, remote URLs,
6
- * and pre-built industry template packs.
7
- *
8
- * Reuses text extraction patterns from knowledge.ts.
9
- * Each import creates a tracked job with progress reporting.
10
- */
11
-
12
- import { createHash } from 'crypto';
13
- import type { EngineDatabase } from './db-adapter.js';
14
- import type { OrgPolicyEngine, OrgPolicy, CreatePolicyInput, PolicyCategory, PolicyEnforcement } from './org-policies.js';
15
- import type { StorageManager } from './storage-manager.js';
16
-
17
- // ─── Types ──────────────────────────────────────────────
18
-
19
- export type ImportFormat = 'json' | 'csv' | 'markdown' | 'text' | 'html' | 'url';
20
- export type ImportStatus = 'pending' | 'processing' | 'completed' | 'failed' | 'partial';
21
- export type DeduplicationMode = 'skip' | 'replace' | 'version';
22
-
23
- export interface ImportJob {
24
- id: string;
25
- orgId: string;
26
- format: ImportFormat;
27
- status: ImportStatus;
28
- progress: {
29
- total: number;
30
- processed: number;
31
- succeeded: number;
32
- failed: number;
33
- duplicates: number;
34
- };
35
- errors: ImportError[];
36
- policyIds: string[];
37
- createdBy: string;
38
- createdAt: string;
39
- completedAt?: string;
40
- }
41
-
42
- export interface ImportError {
43
- index: number;
44
- name?: string;
45
- error: string;
46
- }
47
-
48
- export interface PolicyImportInput {
49
- orgId: string;
50
- createdBy?: string;
51
- deduplication?: DeduplicationMode;
52
- defaultCategory?: PolicyCategory;
53
- defaultEnforcement?: PolicyEnforcement;
54
- dryRun?: boolean;
55
- }
56
-
57
- export interface JsonImportInput extends PolicyImportInput {
58
- policies: Array<{
59
- name: string;
60
- category?: PolicyCategory;
61
- content: string;
62
- enforcement?: PolicyEnforcement;
63
- description?: string;
64
- priority?: number;
65
- tags?: string[];
66
- appliesTo?: string[];
67
- }>;
68
- }
69
-
70
- export interface DocumentImportInput extends PolicyImportInput {
71
- documents: Array<{
72
- name: string;
73
- content: string; // base64 or utf-8
74
- format: 'markdown' | 'text' | 'html' | 'csv';
75
- encoding?: 'base64' | 'utf-8';
76
- metadata?: Record<string, any>;
77
- }>;
78
- }
79
-
80
- export interface UrlImportInput extends PolicyImportInput {
81
- urls: Array<{
82
- url: string;
83
- name?: string;
84
- format?: ImportFormat;
85
- }>;
86
- }
87
-
88
- interface ParsedPolicy {
89
- name: string;
90
- category: PolicyCategory;
91
- content: string;
92
- enforcement: PolicyEnforcement;
93
- description?: string;
94
- priority: number;
95
- tags: string[];
96
- }
97
-
98
- // ─── Template Packs ─────────────────────────────────────
99
-
100
- export interface TemplatePack {
101
- id: string;
102
- name: string;
103
- description: string;
104
- industry: string;
105
- policies: Array<{
106
- name: string;
107
- category: PolicyCategory;
108
- content: string;
109
- enforcement: PolicyEnforcement;
110
- description: string;
111
- priority: number;
112
- tags: string[];
113
- }>;
114
- }
115
-
116
- // Define 4 template packs with 5-8 comprehensive policies each:
117
-
118
- const TEMPLATE_PACKS: Record<string, TemplatePack> = {
119
- healthcare: {
120
- id: 'healthcare',
121
- name: 'Healthcare Compliance Pack',
122
- description: 'HIPAA-compliant policies for healthcare organizations',
123
- industry: 'healthcare',
124
- policies: [
125
- {
126
- name: 'HIPAA Compliance & PHI Protection',
127
- category: 'data_handling',
128
- enforcement: 'mandatory',
129
- description: 'Protected Health Information handling requirements under HIPAA',
130
- priority: 100,
131
- tags: ['hipaa', 'phi', 'compliance'],
132
- content: `# HIPAA Compliance & PHI Protection
133
-
134
- ## Protected Health Information (PHI)
135
- You must NEVER disclose, share, or process Protected Health Information without proper authorization. PHI includes:
136
- - Patient names, addresses, dates of birth, Social Security numbers
137
- - Medical record numbers, health plan beneficiary numbers
138
- - Any information that could identify a patient
139
-
140
- ## Minimum Necessary Standard
141
- Only access, use, or disclose the minimum amount of PHI necessary to accomplish the task at hand.
142
-
143
- ## De-identification
144
- When discussing patient cases or generating reports, always de-identify information by removing all 18 HIPAA identifiers.
145
-
146
- ## Breach Notification
147
- If you detect or suspect a PHI breach, immediately flag it for human review and halt any further processing of the affected data.
148
-
149
- ## Business Associate Requirements
150
- When interacting with third-party systems, ensure all data transfers comply with Business Associate Agreement (BAA) requirements.
151
-
152
- ## Penalties
153
- Violations of HIPAA can result in fines from $100 to $50,000 per violation, with annual maximums of $1.5 million. Take this seriously.`,
154
- },
155
- {
156
- name: 'Patient Communication Standards',
157
- category: 'communication',
158
- enforcement: 'mandatory',
159
- description: 'Guidelines for communicating with patients and caregivers',
160
- priority: 90,
161
- tags: ['patient', 'communication', 'empathy'],
162
- content: `# Patient Communication Standards
163
-
164
- ## Tone & Empathy
165
- Always communicate with empathy, patience, and clarity. Patients may be anxious, confused, or in distress. Use plain language and avoid medical jargon unless the patient demonstrates medical literacy.
166
-
167
- ## Consent & Authorization
168
- Never provide medical advice, diagnoses, or treatment recommendations. Always direct patients to their healthcare provider for clinical decisions. You may share general health information and help schedule appointments.
169
-
170
- ## Emergency Protocols
171
- If a patient describes symptoms of a medical emergency (chest pain, difficulty breathing, severe bleeding, suicidal ideation), immediately provide emergency contact information (911) and escalate to a human operator.
172
-
173
- ## Sensitive Topics
174
- Handle mental health, substance abuse, reproductive health, and terminal illness discussions with extra sensitivity. Never be judgmental. Always offer to connect with specialized support resources.
175
-
176
- ## Minors & Guardians
177
- When communicating about minors, verify that the requester has appropriate parental or guardian authority before sharing any information.`,
178
- },
179
- {
180
- name: 'Clinical Data Handling',
181
- category: 'data_handling',
182
- enforcement: 'mandatory',
183
- description: 'Rules for handling clinical data, lab results, and medical records',
184
- priority: 95,
185
- tags: ['clinical', 'data', 'records'],
186
- content: `# Clinical Data Handling
187
-
188
- ## Data Classification
189
- - **Critical**: Lab results, diagnoses, prescriptions, surgical records — require explicit authorization for access
190
- - **Sensitive**: Appointment history, billing records, insurance information — standard access controls
191
- - **General**: Facility hours, general health information, provider directories — publicly available
192
-
193
- ## Data Retention
194
- Follow your organization's data retention policy. Default: retain clinical records for 7 years from last encounter, or as required by state law (whichever is longer).
195
-
196
- ## Audit Trail
197
- All access to clinical data must be logged with: who accessed it, when, why, and what was viewed or modified.
198
-
199
- ## Data Transmission
200
- Clinical data must only be transmitted through encrypted channels. Never send PHI via unencrypted email, chat, or SMS.
201
-
202
- ## Research & Analytics
203
- De-identify all data before use in research or analytics. Obtain IRB approval when required.`,
204
- },
205
- {
206
- name: 'Emergency Response Protocol',
207
- category: 'escalation',
208
- enforcement: 'mandatory',
209
- description: 'Procedures for handling medical emergencies and urgent situations',
210
- priority: 100,
211
- tags: ['emergency', 'escalation', 'urgent'],
212
- content: `# Emergency Response Protocol
213
-
214
- ## Immediate Escalation Triggers
215
- Escalate IMMEDIATELY to a human operator when any of these are detected:
216
- - Life-threatening symptoms described by patient
217
- - Suicidal or homicidal ideation
218
- - Child abuse or elder abuse disclosures
219
- - Adverse drug reactions
220
- - Post-surgical complications
221
-
222
- ## Response Steps
223
- 1. Acknowledge the urgency calmly
224
- 2. If life-threatening: provide 911 and local emergency numbers immediately
225
- 3. Do NOT attempt to diagnose or provide medical advice
226
- 4. Flag the conversation for urgent human review
227
- 5. Stay with the patient (keep conversation open) until human takes over
228
-
229
- ## Documentation
230
- After any emergency escalation, generate a summary including: time of escalation, nature of emergency, actions taken, and outcome.`,
231
- },
232
- {
233
- name: 'Healthcare Security Standards',
234
- category: 'security',
235
- enforcement: 'mandatory',
236
- description: 'Security protocols specific to healthcare environments',
237
- priority: 90,
238
- tags: ['security', 'healthcare', 'access-control'],
239
- content: `# Healthcare Security Standards
240
-
241
- ## Authentication
242
- All clinical system access requires multi-factor authentication. Never bypass or work around authentication controls.
243
-
244
- ## Access Control
245
- Follow role-based access control (RBAC). Only access systems and data that your assigned role permits. Report any unauthorized access attempts.
246
-
247
- ## Audit Logging
248
- All actions involving patient data must generate audit log entries. Audit logs are immutable and retained for 6 years minimum.
249
-
250
- ## Incident Response
251
- Report any suspected security incidents immediately. Do not attempt to investigate or remediate without authorization. Preserve all evidence.
252
-
253
- ## Device Security
254
- When operating in clinical environments, ensure all connections are encrypted (TLS 1.2+). Never store credentials in plaintext. Rotate API keys every 90 days.`,
255
- },
256
- ],
257
- },
258
- finance: {
259
- id: 'finance',
260
- name: 'Financial Services Compliance Pack',
261
- description: 'SOX, KYC/AML, and financial regulation policies',
262
- industry: 'finance',
263
- policies: [
264
- {
265
- name: 'SOX Compliance & Financial Controls',
266
- category: 'code_of_conduct',
267
- enforcement: 'mandatory',
268
- description: 'Sarbanes-Oxley compliance requirements for financial reporting',
269
- priority: 100,
270
- tags: ['sox', 'compliance', 'financial'],
271
- content: `# SOX Compliance & Financial Controls
272
-
273
- ## Internal Controls
274
- All financial data processing must maintain proper internal controls. Never modify financial records without proper authorization and an audit trail.
275
-
276
- ## Segregation of Duties
277
- No single agent should have the ability to both initiate and approve financial transactions. Always require human approval for transactions above configured thresholds.
278
-
279
- ## Financial Reporting Accuracy
280
- All financial summaries, reports, and calculations must be accurate and verifiable. Double-check all numerical computations. Flag any discrepancies immediately.
281
-
282
- ## Record Retention
283
- Financial records must be retained for 7 years minimum. Never delete, modify, or overwrite financial records without explicit authorization from compliance officers.
284
-
285
- ## Whistleblower Protection
286
- If you detect potential fraud, accounting irregularities, or compliance violations, report them through the designated compliance channel. Never suppress or ignore such findings.`,
287
- },
288
- {
289
- name: 'KYC/AML Protocols',
290
- category: 'security',
291
- enforcement: 'mandatory',
292
- description: 'Know Your Customer and Anti-Money Laundering procedures',
293
- priority: 100,
294
- tags: ['kyc', 'aml', 'compliance'],
295
- content: `# KYC/AML Protocols
296
-
297
- ## Customer Identification
298
- Verify customer identity before processing any financial transaction. Required identification includes government-issued ID, proof of address, and tax identification number.
299
-
300
- ## Suspicious Activity Detection
301
- Flag transactions that exhibit these patterns:
302
- - Unusual transaction amounts or frequency
303
- - Transactions just below reporting thresholds (structuring)
304
- - Transfers to/from high-risk jurisdictions
305
- - Rapid movement of funds between accounts
306
- - Inconsistency between transaction patterns and customer profile
307
-
308
- ## Reporting Requirements
309
- File Suspicious Activity Reports (SARs) for any flagged transactions. Do not inform the customer that a SAR has been filed (tipping-off is illegal).
310
-
311
- ## Sanctions Screening
312
- Screen all parties against OFAC, EU, and UN sanctions lists before processing transactions. Block any transactions involving sanctioned entities.
313
-
314
- ## Enhanced Due Diligence
315
- Apply enhanced scrutiny for: politically exposed persons (PEPs), high-risk countries, unusual business structures, and transactions over $10,000.`,
316
- },
317
- {
318
- name: 'Transaction Limits & Approvals',
319
- category: 'escalation',
320
- enforcement: 'mandatory',
321
- description: 'Transaction thresholds and approval chains',
322
- priority: 95,
323
- tags: ['transactions', 'limits', 'approvals'],
324
- content: `# Transaction Limits & Approvals
325
-
326
- ## Automated Processing Limits
327
- - Under $1,000: May process automatically with standard verification
328
- - $1,000 - $10,000: Requires single human approval
329
- - $10,000 - $100,000: Requires dual human approval
330
- - Over $100,000: Requires compliance officer review plus dual approval
331
-
332
- ## Wire Transfers
333
- All international wire transfers require human verification regardless of amount. Domestic wires over $5,000 require human approval.
334
-
335
- ## Recurring Transactions
336
- Recurring transaction setup requires initial human approval. Any modification to recurring amounts above 20% triggers re-approval.
337
-
338
- ## Failed Transaction Handling
339
- Never retry failed transactions automatically more than once. If a transaction fails twice, escalate to human review.
340
-
341
- ## Refund Processing
342
- Refunds over $500 require human approval. All refunds must reference the original transaction and include a documented reason.`,
343
- },
344
- {
345
- name: 'Financial Advice Disclaimers',
346
- category: 'communication',
347
- enforcement: 'mandatory',
348
- description: 'Required disclaimers when discussing financial products',
349
- priority: 85,
350
- tags: ['disclaimer', 'advice', 'fiduciary'],
351
- content: `# Financial Advice Disclaimers
352
-
353
- ## General Disclaimer
354
- You are NOT a licensed financial advisor. Always include this disclaimer when discussing financial products or strategies: "This information is for educational purposes only and does not constitute financial advice. Please consult a licensed financial advisor for personalized recommendations."
355
-
356
- ## Investment Discussions
357
- Never recommend specific investments, predict market performance, or guarantee returns. You may explain how financial products work in general terms.
358
-
359
- ## Insurance Products
360
- Do not recommend specific insurance policies or coverage amounts. Provide general information and direct to licensed insurance agents.
361
-
362
- ## Tax Information
363
- Provide general tax information only. Always recommend consulting a CPA or tax professional for specific tax situations. Include: "Tax laws vary by jurisdiction and change frequently."
364
-
365
- ## Suitability
366
- Never make suitability determinations for financial products. This requires human assessment of the customer's complete financial situation.`,
367
- },
368
- {
369
- name: 'Financial Data Security',
370
- category: 'data_handling',
371
- enforcement: 'mandatory',
372
- description: 'PCI-DSS and financial data protection requirements',
373
- priority: 95,
374
- tags: ['pci', 'security', 'data'],
375
- content: `# Financial Data Security
376
-
377
- ## PCI-DSS Compliance
378
- Never store full credit card numbers, CVV codes, or PINs in any form. Display only the last 4 digits when referencing card numbers. All payment data must be processed through PCI-DSS compliant channels.
379
-
380
- ## Account Numbers
381
- Mask all account numbers in responses and logs. Display only the last 4 digits. Full account numbers may only be used in encrypted API calls to verified financial systems.
382
-
383
- ## Data Encryption
384
- All financial data must be encrypted in transit (TLS 1.2+) and at rest (AES-256). Never log financial data in plaintext.
385
-
386
- ## Access Logging
387
- Log all access to financial data with: timestamp, accessor ID, data accessed, and business justification. Logs are immutable and retained for 7 years.
388
-
389
- ## Data Residency
390
- Financial data must remain within the designated geographic regions as required by regulation. Do not transfer data across borders without compliance review.`,
391
- },
392
- ],
393
- },
394
- tech: {
395
- id: 'tech',
396
- name: 'Technology Company Pack',
397
- description: 'Policies for software companies and tech organizations',
398
- industry: 'technology',
399
- policies: [
400
- {
401
- name: 'Code Review & Quality Standards',
402
- category: 'code_of_conduct',
403
- enforcement: 'mandatory',
404
- description: 'Standards for code generation, review, and quality assurance',
405
- priority: 90,
406
- tags: ['code', 'quality', 'review'],
407
- content: `# Code Review & Quality Standards
408
-
409
- ## Code Generation
410
- When generating or modifying code:
411
- - Follow the project's existing coding style and conventions
412
- - Include appropriate error handling for all operations
413
- - Never introduce known security vulnerabilities (SQL injection, XSS, etc.)
414
- - Write code that is readable and maintainable
415
- - Add comments only where logic is non-obvious
416
-
417
- ## Security-First Coding
418
- - Never hardcode credentials, API keys, or secrets in code
419
- - Use parameterized queries for all database operations
420
- - Validate and sanitize all user inputs
421
- - Follow the principle of least privilege
422
-
423
- ## Testing
424
- - Suggest tests for any new functionality
425
- - Never bypass or skip existing tests
426
- - Flag any code changes that break existing test coverage
427
-
428
- ## Dependencies
429
- - Only recommend well-maintained, reputable packages
430
- - Check for known vulnerabilities before suggesting dependencies
431
- - Prefer packages with permissive licenses (MIT, Apache 2.0) unless specified otherwise`,
432
- },
433
- {
434
- name: 'Incident Response Procedures',
435
- category: 'escalation',
436
- enforcement: 'mandatory',
437
- description: 'Procedures for handling production incidents and outages',
438
- priority: 100,
439
- tags: ['incident', 'response', 'production'],
440
- content: `# Incident Response Procedures
441
-
442
- ## Severity Levels
443
- - **SEV1 (Critical)**: Complete service outage, data breach, security incident → Escalate immediately to on-call engineer AND engineering leadership
444
- - **SEV2 (Major)**: Partial outage, significant degradation, data loss risk → Escalate to on-call engineer within 5 minutes
445
- - **SEV3 (Minor)**: Non-critical feature failure, performance degradation → Create ticket, notify team channel
446
- - **SEV4 (Low)**: Cosmetic issues, minor bugs → Create ticket for next sprint
447
-
448
- ## Response Actions
449
- 1. Acknowledge the incident and classify severity
450
- 2. Notify appropriate personnel based on severity
451
- 3. Begin gathering diagnostic information
452
- 4. DO NOT attempt automated remediation for SEV1/SEV2 without human approval
453
- 5. Document all actions taken during incident
454
-
455
- ## Post-Incident
456
- - Generate incident summary within 1 hour of resolution
457
- - Include: timeline, root cause, impact assessment, remediation steps
458
- - Flag for post-mortem review`,
459
- },
460
- {
461
- name: 'SLA Commitments & Communication',
462
- category: 'communication',
463
- enforcement: 'mandatory',
464
- description: 'Service Level Agreement guidelines for customer communication',
465
- priority: 85,
466
- tags: ['sla', 'customer', 'support'],
467
- content: `# SLA Commitments & Communication
468
-
469
- ## Response Times
470
- - Critical issues: Acknowledge within 15 minutes, update every 30 minutes
471
- - High priority: Acknowledge within 1 hour, update every 2 hours
472
- - Normal priority: Acknowledge within 4 hours, update daily
473
- - Low priority: Acknowledge within 24 hours, update weekly
474
-
475
- ## Status Communication
476
- - Always be transparent about known issues
477
- - Provide estimated time to resolution when possible (with appropriate caveats)
478
- - Never make promises about specific resolution times unless authorized
479
- - Use status page for broad communication about outages
480
-
481
- ## Escalation Paths
482
- - If you cannot resolve within SLA timeframe, escalate before SLA breach
483
- - Document all escalation decisions with reasoning
484
- - Follow up on escalated issues until confirmed resolved
485
-
486
- ## Customer Communication
487
- - Be professional, empathetic, and solution-focused
488
- - Acknowledge the customer's frustration without making excuses
489
- - Focus on what you CAN do, not what you can't`,
490
- },
491
- {
492
- name: 'API & System Security',
493
- category: 'security',
494
- enforcement: 'mandatory',
495
- description: 'Security standards for APIs, systems, and infrastructure',
496
- priority: 95,
497
- tags: ['api', 'security', 'infrastructure'],
498
- content: `# API & System Security
499
-
500
- ## Authentication & Authorization
501
- - All API calls must be authenticated (API keys, OAuth tokens, or JWT)
502
- - Implement rate limiting on all public endpoints
503
- - Use scoped permissions — never use admin credentials for routine operations
504
- - Rotate all credentials every 90 days
505
-
506
- ## Data Protection
507
- - Encrypt all data in transit (TLS 1.2+) and at rest
508
- - Never log sensitive data (passwords, tokens, PII) in application logs
509
- - Implement proper CORS policies for web-facing services
510
- - Use Content Security Policy (CSP) headers
511
-
512
- ## Infrastructure
513
- - Never expose internal services directly to the internet
514
- - Use network segmentation and firewalls
515
- - Keep all systems patched and updated
516
- - Monitor for unusual access patterns
517
-
518
- ## Secret Management
519
- - Use a secrets manager (vault) for all credentials
520
- - Never store secrets in environment variables in production
521
- - Never commit secrets to version control
522
- - Implement secret rotation automation`,
523
- },
524
- {
525
- name: 'Data Handling & Privacy',
526
- category: 'data_handling',
527
- enforcement: 'mandatory',
528
- description: 'GDPR, CCPA, and general data privacy requirements',
529
- priority: 90,
530
- tags: ['privacy', 'gdpr', 'ccpa', 'data'],
531
- content: `# Data Handling & Privacy
532
-
533
- ## User Consent
534
- - Never process personal data without documented consent
535
- - Honor opt-out requests within 30 days
536
- - Maintain records of consent for all data processing activities
537
-
538
- ## Data Minimization
539
- - Only collect data that is strictly necessary for the stated purpose
540
- - Do not retain data longer than needed
541
- - Anonymize or pseudonymize data when possible
542
-
543
- ## Right to Erasure (GDPR/CCPA)
544
- - Support "right to be forgotten" requests
545
- - Ensure deletion propagates to all systems including backups
546
- - Document all deletion requests and actions taken
547
-
548
- ## Cross-Border Transfer
549
- - Verify data transfer agreements before moving data between regions
550
- - Use Standard Contractual Clauses (SCCs) for EU data transfers
551
- - Maintain data residency compliance per customer agreements
552
-
553
- ## Breach Notification
554
- - Report data breaches within 72 hours (GDPR) or as required by applicable law
555
- - Document: what data was affected, how many records, remediation steps`,
556
- },
557
- ],
558
- },
559
- retail: {
560
- id: 'retail',
561
- name: 'Retail & E-Commerce Pack',
562
- description: 'Policies for retail businesses and e-commerce platforms',
563
- industry: 'retail',
564
- policies: [
565
- {
566
- name: 'Customer Return & Refund Policy',
567
- category: 'code_of_conduct',
568
- enforcement: 'mandatory',
569
- description: 'Rules for handling returns, refunds, and exchanges',
570
- priority: 90,
571
- tags: ['returns', 'refunds', 'customer'],
572
- content: `# Customer Return & Refund Policy
573
-
574
- ## Standard Returns
575
- - Accept returns within 30 days of purchase with valid receipt/order number
576
- - Items must be in original condition with tags attached
577
- - Process refund to original payment method within 5-7 business days
578
-
579
- ## Exceptions
580
- - Final sale items are non-returnable — inform customer politely
581
- - Electronics: 15-day return window, must include all accessories
582
- - Perishable goods: non-returnable unless defective
583
- - Custom/personalized items: non-returnable unless manufacturing defect
584
-
585
- ## Refund Processing
586
- - Under $50: Process automatically
587
- - $50-$500: Process with single verification
588
- - Over $500: Escalate to supervisor for approval
589
- - Store credit: Can be offered as alternative at any amount
590
-
591
- ## Escalation
592
- - If customer disputes the policy, offer to escalate to customer service manager
593
- - Never argue with a customer about policy — explain once, then escalate
594
- - Document all escalated return requests`,
595
- },
596
- {
597
- name: 'Pricing & Promotions Accuracy',
598
- category: 'communication',
599
- enforcement: 'mandatory',
600
- description: 'Guidelines for communicating prices, discounts, and promotions',
601
- priority: 95,
602
- tags: ['pricing', 'promotions', 'accuracy'],
603
- content: `# Pricing & Promotions Accuracy
604
-
605
- ## Price Accuracy
606
- - Always quote the current listed price from the product database
607
- - If a price discrepancy is reported, escalate — do not adjust manually
608
- - Include all applicable taxes and fees in price quotes when possible
609
- - Never promise a price match without verifying the competitor's current price
610
-
611
- ## Promotions & Discounts
612
- - Only apply promotions that are currently active and valid
613
- - Verify coupon codes against the promotion database before confirming discounts
614
- - Do not stack promotions unless the promotion rules explicitly allow it
615
- - Clearly communicate promotion terms (expiry date, exclusions, minimum purchase)
616
-
617
- ## Price Changes
618
- - Do not honor expired promotions without supervisor approval
619
- - If a price drops within 14 days of purchase, the customer may request a price adjustment
620
- - Communicate any upcoming price changes only if authorized to do so
621
-
622
- ## Transparency
623
- - Always disclose shipping costs before checkout
624
- - Clearly explain any recurring charges or subscription terms
625
- - Be upfront about out-of-stock items and estimated restock dates`,
626
- },
627
- {
628
- name: 'Inventory & Order Communication',
629
- category: 'communication',
630
- enforcement: 'recommended',
631
- description: 'How to communicate about inventory, orders, and shipping',
632
- priority: 80,
633
- tags: ['inventory', 'orders', 'shipping'],
634
- content: `# Inventory & Order Communication
635
-
636
- ## Stock Status
637
- - Always check real-time inventory before confirming availability
638
- - If an item is out of stock, offer: waitlist signup, similar alternatives, or estimated restock date
639
- - Never guarantee availability without checking inventory systems
640
-
641
- ## Order Status
642
- - Provide tracking information as soon as available
643
- - Proactively communicate delays — don't wait for the customer to ask
644
- - For delayed orders, offer: expedited shipping upgrade, partial refund, or store credit
645
-
646
- ## Shipping Information
647
- - Quote delivery estimates based on actual carrier data, not optimistic guesses
648
- - Clearly communicate which shipping options are available
649
- - Inform customers about international shipping restrictions and customs duties
650
-
651
- ## Order Modifications
652
- - Allow cancellations only if order hasn't shipped
653
- - Address changes: possible before shipping label is created
654
- - Item modifications: process as cancel + reorder if already in fulfillment`,
655
- },
656
- {
657
- name: 'Loyalty Program Management',
658
- category: 'code_of_conduct',
659
- enforcement: 'recommended',
660
- description: 'Rules for managing loyalty programs and reward points',
661
- priority: 75,
662
- tags: ['loyalty', 'rewards', 'points'],
663
- content: `# Loyalty Program Management
664
-
665
- ## Points & Rewards
666
- - Calculate points accurately based on the current program rules
667
- - Points are earned on the post-discount, pre-tax amount
668
- - Points cannot be earned on gift card purchases
669
- - Display current point balance when relevant to the conversation
670
-
671
- ## Redemption
672
- - Verify point balance before confirming redemption
673
- - Points cannot be combined with certain promotions (check exclusion rules)
674
- - Redeemed points are non-refundable — warn customers before redemption
675
- - Allow partial point redemption
676
-
677
- ## Account Management
678
- - Verify account ownership before making any changes
679
- - Points transfers between accounts require supervisor approval
680
- - Expired points cannot be reinstated without supervisor approval
681
- - Merge requests for duplicate accounts: escalate to customer service
682
-
683
- ## Communication
684
- - Inform customers about points expiration 30 days in advance
685
- - Proactively suggest point redemption opportunities when relevant
686
- - Never encourage unnecessary purchases just to earn points`,
687
- },
688
- {
689
- name: 'Retail Data Protection',
690
- category: 'data_handling',
691
- enforcement: 'mandatory',
692
- description: 'Data protection policies specific to retail operations',
693
- priority: 90,
694
- tags: ['data', 'privacy', 'pci', 'retail'],
695
- content: `# Retail Data Protection
696
-
697
- ## Payment Card Data (PCI-DSS)
698
- - NEVER store, log, or display full credit card numbers
699
- - Only reference the last 4 digits of card numbers
700
- - All payment processing must go through PCI-compliant channels
701
- - Never ask customers to provide full card numbers via chat or email
702
-
703
- ## Customer Personal Data
704
- - Collect only necessary information for order fulfillment
705
- - Do not share customer data with third parties without consent
706
- - Honor data deletion requests within 30 days
707
- - Mask email addresses and phone numbers in internal communications
708
-
709
- ## Purchase History
710
- - Purchase history is private — only share with the verified account holder
711
- - Do not reference purchase history in marketing without opt-in consent
712
- - Anonymize purchase data before use in analytics
713
-
714
- ## Employee Data
715
- - Do not disclose employee schedules, personal information, or performance data
716
- - Store access credentials are for authorized personnel only
717
- - Report any unauthorized access to customer or employee data immediately`,
718
- },
719
- ],
720
- },
721
- };
722
-
723
- // ─── Policy Importer ────────────────────────────────────
724
-
725
- export class PolicyImporter {
726
- private policyEngine: OrgPolicyEngine;
727
- private storageManager?: StorageManager;
728
- private jobs = new Map<string, ImportJob>();
729
- private engineDb?: EngineDatabase;
730
-
731
- constructor(opts: { policyEngine: OrgPolicyEngine; storageManager?: StorageManager }) {
732
- this.policyEngine = opts.policyEngine;
733
- this.storageManager = opts.storageManager;
734
- }
735
-
736
- async setDb(db: EngineDatabase): Promise<void> {
737
- this.engineDb = db;
738
- await this.loadJobsFromDb();
739
- }
740
-
741
- private async loadJobsFromDb(): Promise<void> {
742
- if (!this.engineDb) return;
743
- try {
744
- const rows = await this.engineDb.query<any>('SELECT * FROM policy_import_jobs ORDER BY created_at DESC LIMIT 100');
745
- for (const r of rows) {
746
- this.jobs.set(r.id, {
747
- id: r.id, orgId: r.org_id, format: r.format, status: r.status,
748
- progress: typeof r.progress === "string" ? JSON.parse(r.progress || "{}") : (r.progress || {}),
749
- errors: typeof r.errors === "string" ? JSON.parse(r.errors || "[]") : (r.errors || []),
750
- policyIds: typeof r.policy_ids === "string" ? JSON.parse(r.policy_ids || "[]") : (r.policy_ids || []),
751
- createdBy: r.created_by, createdAt: r.created_at,
752
- completedAt: r.completed_at || undefined,
753
- });
754
- }
755
- } catch { /* table may not exist yet */ }
756
- }
757
-
758
- // ─── Job Management ──────────────────────────────────
759
-
760
- private createJob(orgId: string, format: ImportFormat, total: number, createdBy: string): ImportJob {
761
- const job: ImportJob = {
762
- id: crypto.randomUUID(), orgId, format, status: 'processing',
763
- progress: { total, processed: 0, succeeded: 0, failed: 0, duplicates: 0 },
764
- errors: [], policyIds: [], createdBy, createdAt: new Date().toISOString(),
765
- };
766
- this.jobs.set(job.id, job);
767
- this.persistJob(job);
768
- return job;
769
- }
770
-
771
- private completeJob(job: ImportJob): void {
772
- job.completedAt = new Date().toISOString();
773
- job.status = job.errors.length > 0 ? (job.progress.succeeded > 0 ? 'partial' : 'failed') : 'completed';
774
- this.persistJob(job);
775
- }
776
-
777
- private async persistJob(job: ImportJob): Promise<void> {
778
- if (!this.engineDb) return;
779
- try {
780
- // Upsert via DELETE + INSERT (works across all SQL dialects)
781
- await this.engineDb.execute('DELETE FROM policy_import_jobs WHERE id = ?', [job.id]);
782
- await this.engineDb.execute(
783
- 'INSERT INTO policy_import_jobs (id, org_id, format, status, progress, errors, policy_ids, created_by, created_at, completed_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)',
784
- [job.id, job.orgId, job.format, job.status, JSON.stringify(job.progress), JSON.stringify(job.errors), JSON.stringify(job.policyIds), job.createdBy, job.createdAt, job.completedAt || null]
785
- );
786
- } catch { /* ignore persistence errors */ }
787
- }
788
-
789
- getJob(id: string): ImportJob | undefined { return this.jobs.get(id); }
790
-
791
- getJobsByOrg(orgId: string): ImportJob[] {
792
- return Array.from(this.jobs.values()).filter(j => j.orgId === orgId).sort((a, b) => b.createdAt.localeCompare(a.createdAt));
793
- }
794
-
795
- // ─── Import Methods ──────────────────────────────────
796
-
797
- async importJson(input: JsonImportInput): Promise<ImportJob> {
798
- const createdBy = input.createdBy || 'admin';
799
- const job = this.createJob(input.orgId, 'json', input.policies.length, createdBy);
800
-
801
- for (let i = 0; i < input.policies.length; i++) {
802
- const p = input.policies[i];
803
- try {
804
- const contentHash = this.hashContent(p.content);
805
- const dedup = await this.checkDuplicate(input.orgId, contentHash, input.deduplication || 'skip');
806
-
807
- if (dedup === 'skip') {
808
- job.progress.duplicates++;
809
- } else {
810
- if (!input.dryRun) {
811
- const policy = await this.policyEngine.createPolicy({
812
- orgId: input.orgId,
813
- name: p.name,
814
- category: p.category || input.defaultCategory || 'custom',
815
- content: p.content,
816
- enforcement: p.enforcement || input.defaultEnforcement || 'mandatory',
817
- description: p.description,
818
- priority: p.priority || 0,
819
- tags: p.tags || [],
820
- appliesTo: p.appliesTo || ['*'],
821
- enabled: true,
822
- createdBy,
823
- });
824
- job.policyIds.push(policy.id);
825
- }
826
- job.progress.succeeded++;
827
- }
828
- } catch (e: any) {
829
- job.errors.push({ index: i, name: p.name, error: e.message });
830
- job.progress.failed++;
831
- }
832
- job.progress.processed++;
833
- }
834
-
835
- this.completeJob(job);
836
- return job;
837
- }
838
-
839
- async importDocuments(input: DocumentImportInput): Promise<ImportJob> {
840
- const createdBy = input.createdBy || 'admin';
841
- // First, parse all documents into policies
842
- const allParsed: { docName: string; policies: ParsedPolicy[] }[] = [];
843
-
844
- for (const doc of input.documents) {
845
- const content = doc.encoding === 'base64' ? Buffer.from(doc.content, 'base64').toString('utf-8') : doc.content;
846
- let parsed: ParsedPolicy[];
847
-
848
- switch (doc.format) {
849
- case 'markdown': parsed = this.parseMarkdown(content, input.defaultCategory, input.defaultEnforcement); break;
850
- case 'csv': parsed = this.parseCsv(content, input.defaultCategory, input.defaultEnforcement); break;
851
- case 'html': parsed = this.parseHtml(content, input.defaultCategory, input.defaultEnforcement); break;
852
- case 'text':
853
- default: parsed = this.parsePlainText(content, doc.name, input.defaultCategory, input.defaultEnforcement); break;
854
- }
855
- allParsed.push({ docName: doc.name, policies: parsed });
856
- }
857
-
858
- const totalPolicies = allParsed.reduce((sum, d) => sum + d.policies.length, 0);
859
- const job = this.createJob(input.orgId, input.documents[0]?.format as ImportFormat || 'text', totalPolicies, createdBy);
860
-
861
- let idx = 0;
862
- for (const { policies } of allParsed) {
863
- for (const p of policies) {
864
- try {
865
- const contentHash = this.hashContent(p.content);
866
- const dedup = await this.checkDuplicate(input.orgId, contentHash, input.deduplication || 'skip');
867
-
868
- if (dedup === 'skip') {
869
- job.progress.duplicates++;
870
- } else {
871
- if (!input.dryRun) {
872
- const policy = await this.policyEngine.createPolicy({
873
- orgId: input.orgId, name: p.name, category: p.category,
874
- content: p.content, enforcement: p.enforcement,
875
- description: p.description, priority: p.priority,
876
- tags: p.tags, appliesTo: ['*'], enabled: true, createdBy,
877
- });
878
- job.policyIds.push(policy.id);
879
- }
880
- job.progress.succeeded++;
881
- }
882
- } catch (e: any) {
883
- job.errors.push({ index: idx, name: p.name, error: e.message });
884
- job.progress.failed++;
885
- }
886
- job.progress.processed++;
887
- idx++;
888
- }
889
- }
890
-
891
- this.completeJob(job);
892
- return job;
893
- }
894
-
895
- async importFromUrls(input: UrlImportInput): Promise<ImportJob> {
896
- const createdBy = input.createdBy || 'admin';
897
- const job = this.createJob(input.orgId, 'url', input.urls.length, createdBy);
898
-
899
- for (let i = 0; i < input.urls.length; i++) {
900
- const u = input.urls[i];
901
- try {
902
- const response = await fetch(u.url);
903
- if (!response.ok) throw new Error(`HTTP ${response.status}: ${response.statusText}`);
904
- const content = await response.text();
905
- const contentType = response.headers.get('content-type') || '';
906
-
907
- // Auto-detect format
908
- let format: 'markdown' | 'html' | 'csv' | 'text' = 'text';
909
- if (u.format === 'markdown' || u.url.endsWith('.md')) format = 'markdown';
910
- else if (u.format === 'html' || contentType.includes('html')) format = 'html';
911
- else if (u.format === 'csv' || u.url.endsWith('.csv')) format = 'csv';
912
- else if (contentType.includes('markdown')) format = 'markdown';
913
-
914
- let parsed: ParsedPolicy[];
915
- switch (format) {
916
- case 'markdown': parsed = this.parseMarkdown(content, input.defaultCategory, input.defaultEnforcement); break;
917
- case 'csv': parsed = this.parseCsv(content, input.defaultCategory, input.defaultEnforcement); break;
918
- case 'html': parsed = this.parseHtml(content, input.defaultCategory, input.defaultEnforcement); break;
919
- default: parsed = this.parsePlainText(content, u.name || u.url, input.defaultCategory, input.defaultEnforcement); break;
920
- }
921
-
922
- for (const p of parsed) {
923
- if (!input.dryRun) {
924
- const policy = await this.policyEngine.createPolicy({
925
- orgId: input.orgId, name: p.name, category: p.category,
926
- content: p.content, enforcement: p.enforcement,
927
- description: p.description, priority: p.priority,
928
- tags: p.tags, appliesTo: ['*'], enabled: true, createdBy,
929
- });
930
- job.policyIds.push(policy.id);
931
- }
932
- job.progress.succeeded++;
933
- }
934
- } catch (e: any) {
935
- job.errors.push({ index: i, name: u.name || u.url, error: e.message });
936
- job.progress.failed++;
937
- }
938
- job.progress.processed++;
939
- }
940
-
941
- this.completeJob(job);
942
- return job;
943
- }
944
-
945
- async importTemplatePack(orgId: string, packId: string, createdBy: string): Promise<ImportJob> {
946
- const pack = TEMPLATE_PACKS[packId];
947
- if (!pack) throw new Error(`Template pack '${packId}' not found. Available: ${Object.keys(TEMPLATE_PACKS).join(', ')}`);
948
-
949
- const job = this.createJob(orgId, 'json', pack.policies.length, createdBy);
950
-
951
- for (let i = 0; i < pack.policies.length; i++) {
952
- const p = pack.policies[i];
953
- try {
954
- const policy = await this.policyEngine.createPolicy({
955
- orgId, name: p.name, category: p.category, content: p.content,
956
- enforcement: p.enforcement, description: p.description,
957
- priority: p.priority, tags: [...p.tags, `template:${packId}`],
958
- appliesTo: ['*'], enabled: true, createdBy,
959
- });
960
- job.policyIds.push(policy.id);
961
- job.progress.succeeded++;
962
- } catch (e: any) {
963
- job.errors.push({ index: i, name: p.name, error: e.message });
964
- job.progress.failed++;
965
- }
966
- job.progress.processed++;
967
- }
968
-
969
- this.completeJob(job);
970
- return job;
971
- }
972
-
973
- // ─── Template Packs ──────────────────────────────────
974
-
975
- static getTemplatePacks(): Record<string, { id: string; name: string; description: string; industry: string; policyCount: number }> {
976
- const result: Record<string, any> = {};
977
- for (const [id, pack] of Object.entries(TEMPLATE_PACKS)) {
978
- result[id] = { id, name: pack.name, description: pack.description, industry: pack.industry, policyCount: pack.policies.length };
979
- }
980
- return result;
981
- }
982
-
983
- static getTemplatePack(packId: string): TemplatePack | undefined {
984
- return TEMPLATE_PACKS[packId];
985
- }
986
-
987
- // ─── Document Parsing ────────────────────────────────
988
-
989
- private parseMarkdown(content: string, defaultCategory?: PolicyCategory, defaultEnforcement?: PolicyEnforcement): ParsedPolicy[] {
990
- const policies: ParsedPolicy[] = [];
991
-
992
- // Check for YAML frontmatter
993
- let frontmatter: Record<string, any> = {};
994
- const fmMatch = content.match(/^---\n([\s\S]*?)\n---\n([\s\S]*)$/);
995
- if (fmMatch) {
996
- // Simple YAML-like parsing (key: value pairs)
997
- for (const line of fmMatch[1].split('\n')) {
998
- const [k, ...vParts] = line.split(':');
999
- if (k && vParts.length) frontmatter[k.trim()] = vParts.join(':').trim();
1000
- }
1001
- content = fmMatch[2];
1002
- }
1003
-
1004
- // Split on top-level headings (# or ##)
1005
- const sections = content.split(/^(?=#{1,2}\s)/m).filter(s => s.trim());
1006
-
1007
- if (sections.length <= 1) {
1008
- // No headings — treat as single policy
1009
- const name = frontmatter.name || frontmatter.title || 'Imported Policy';
1010
- policies.push({
1011
- name,
1012
- category: (frontmatter.category as PolicyCategory) || defaultCategory || 'custom',
1013
- content: content.trim(),
1014
- enforcement: (frontmatter.enforcement as PolicyEnforcement) || defaultEnforcement || 'mandatory',
1015
- description: frontmatter.description,
1016
- priority: parseInt(frontmatter.priority) || 0,
1017
- tags: frontmatter.tags ? frontmatter.tags.split(',').map((t: string) => t.trim()) : [],
1018
- });
1019
- } else {
1020
- for (const section of sections) {
1021
- const headingMatch = section.match(/^#{1,2}\s+(.+)\n([\s\S]*)/);
1022
- if (!headingMatch) continue;
1023
- const name = headingMatch[1].trim();
1024
- const body = headingMatch[2].trim();
1025
- if (body.length < 10) continue; // Skip very short sections
1026
-
1027
- policies.push({
1028
- name,
1029
- category: defaultCategory || this.inferCategory(name, body),
1030
- content: section.trim(),
1031
- enforcement: defaultEnforcement || 'mandatory',
1032
- priority: 0,
1033
- tags: [],
1034
- });
1035
- }
1036
- }
1037
-
1038
- return policies;
1039
- }
1040
-
1041
- private parseCsv(content: string, defaultCategory?: PolicyCategory, defaultEnforcement?: PolicyEnforcement): ParsedPolicy[] {
1042
- const policies: ParsedPolicy[] = [];
1043
- const lines = content.split('\n').filter(l => l.trim());
1044
- if (lines.length < 2) return policies;
1045
-
1046
- // Detect delimiter (comma, tab, semicolon, pipe)
1047
- const firstLine = lines[0];
1048
- const delimiter = [',', '\t', ';', '|'].reduce((best, d) =>
1049
- firstLine.split(d).length > firstLine.split(best).length ? d : best, ',');
1050
-
1051
- // Parse header row
1052
- const headers = this.parseCsvLine(lines[0], delimiter).map(h => h.toLowerCase().trim());
1053
- const nameIdx = headers.findIndex(h => ['name', 'title', 'policy_name', 'policy'].includes(h));
1054
- const contentIdx = headers.findIndex(h => ['content', 'body', 'text', 'description', 'policy_content'].includes(h));
1055
- const categoryIdx = headers.findIndex(h => ['category', 'type', 'group'].includes(h));
1056
- const enforcementIdx = headers.findIndex(h => ['enforcement', 'level', 'severity'].includes(h));
1057
- const tagsIdx = headers.findIndex(h => ['tags', 'labels', 'keywords'].includes(h));
1058
- const priorityIdx = headers.findIndex(h => ['priority', 'order', 'weight'].includes(h));
1059
- const descIdx = headers.findIndex(h => ['desc', 'summary', 'note'].includes(h));
1060
-
1061
- if (nameIdx === -1 || contentIdx === -1) {
1062
- // Fallback: first column = name, second = content
1063
- for (let i = 1; i < lines.length; i++) {
1064
- const cols = this.parseCsvLine(lines[i], delimiter);
1065
- if (cols.length >= 2) {
1066
- policies.push({
1067
- name: cols[0], category: defaultCategory || 'custom',
1068
- content: cols[1], enforcement: defaultEnforcement || 'mandatory',
1069
- priority: 0, tags: [],
1070
- });
1071
- }
1072
- }
1073
- return policies;
1074
- }
1075
-
1076
- for (let i = 1; i < lines.length; i++) {
1077
- const cols = this.parseCsvLine(lines[i], delimiter);
1078
- const name = cols[nameIdx]?.trim();
1079
- const pContent = cols[contentIdx]?.trim();
1080
- if (!name || !pContent) continue;
1081
-
1082
- policies.push({
1083
- name,
1084
- content: pContent,
1085
- category: (categoryIdx >= 0 ? cols[categoryIdx]?.trim() as PolicyCategory : undefined) || defaultCategory || 'custom',
1086
- enforcement: (enforcementIdx >= 0 ? cols[enforcementIdx]?.trim() as PolicyEnforcement : undefined) || defaultEnforcement || 'mandatory',
1087
- tags: tagsIdx >= 0 ? (cols[tagsIdx] || '').split(/[,;]/).map(t => t.trim()).filter(Boolean) : [],
1088
- priority: priorityIdx >= 0 ? parseInt(cols[priorityIdx]) || 0 : 0,
1089
- description: descIdx >= 0 ? cols[descIdx]?.trim() : undefined,
1090
- });
1091
- }
1092
-
1093
- return policies;
1094
- }
1095
-
1096
- private parseCsvLine(line: string, delimiter: string): string[] {
1097
- const result: string[] = [];
1098
- let current = '';
1099
- let inQuotes = false;
1100
- for (let i = 0; i < line.length; i++) {
1101
- const ch = line[i];
1102
- if (ch === '"') {
1103
- if (inQuotes && line[i + 1] === '"') { current += '"'; i++; }
1104
- else inQuotes = !inQuotes;
1105
- } else if (ch === delimiter && !inQuotes) {
1106
- result.push(current); current = '';
1107
- } else {
1108
- current += ch;
1109
- }
1110
- }
1111
- result.push(current);
1112
- return result;
1113
- }
1114
-
1115
- private parseHtml(content: string, defaultCategory?: PolicyCategory, defaultEnforcement?: PolicyEnforcement): ParsedPolicy[] {
1116
- // Strip HTML tags, then parse as markdown
1117
- const text = content
1118
- .replace(/<script[^>]*>[\s\S]*?<\/script>/gi, '')
1119
- .replace(/<style[^>]*>[\s\S]*?<\/style>/gi, '')
1120
- .replace(/<br\s*\/?>/gi, '\n')
1121
- .replace(/<\/?(p|div|li|tr|td|th|h[1-6])[^>]*>/gi, '\n')
1122
- .replace(/<[^>]*>/g, '')
1123
- .replace(/&nbsp;/g, ' ')
1124
- .replace(/&amp;/g, '&')
1125
- .replace(/&lt;/g, '<')
1126
- .replace(/&gt;/g, '>')
1127
- .replace(/&quot;/g, '"')
1128
- .replace(/\n{3,}/g, '\n\n')
1129
- .trim();
1130
- return this.parseMarkdown(text, defaultCategory, defaultEnforcement);
1131
- }
1132
-
1133
- private parsePlainText(content: string, name: string, defaultCategory?: PolicyCategory, defaultEnforcement?: PolicyEnforcement): ParsedPolicy[] {
1134
- // If content has clear paragraph breaks, split into multiple policies
1135
- const sections = content.split(/\n{3,}/).filter(s => s.trim().length > 50);
1136
-
1137
- if (sections.length > 1) {
1138
- return sections.map((section, i) => {
1139
- const firstLine = section.trim().split('\n')[0].substring(0, 80);
1140
- return {
1141
- name: `${name} - Section ${i + 1}: ${firstLine}`,
1142
- category: defaultCategory || 'custom',
1143
- content: section.trim(),
1144
- enforcement: defaultEnforcement || 'mandatory',
1145
- priority: 0,
1146
- tags: [],
1147
- };
1148
- });
1149
- }
1150
-
1151
- return [{
1152
- name: name.replace(/\.(txt|md|html|csv)$/i, ''),
1153
- category: defaultCategory || 'custom',
1154
- content: content.trim(),
1155
- enforcement: defaultEnforcement || 'mandatory',
1156
- priority: 0,
1157
- tags: [],
1158
- }];
1159
- }
1160
-
1161
- // ─── Helpers ─────────────────────────────────────────
1162
-
1163
- private hashContent(content: string): string {
1164
- return createHash('sha256').update(content.trim()).digest('hex');
1165
- }
1166
-
1167
- private async checkDuplicate(orgId: string, contentHash: string, mode: DeduplicationMode): Promise<'skip' | 'create'> {
1168
- if (mode === 'skip') {
1169
- // Check if a policy with this content hash already exists
1170
- const existing = this.policyEngine.findByContentHash?.(orgId, contentHash);
1171
- if (existing) return 'skip';
1172
- }
1173
- return 'create';
1174
- }
1175
-
1176
- private inferCategory(name: string, content: string): PolicyCategory {
1177
- const text = (name + ' ' + content).toLowerCase();
1178
- if (/\b(conduct|ethic|behavior|professional|integrity)\b/.test(text)) return 'code_of_conduct';
1179
- if (/\b(communicat|tone|voice|messag|email|chat)\b/.test(text)) return 'communication';
1180
- if (/\b(data|privacy|pii|gdpr|ccpa|hipaa|encrypt|confidential)\b/.test(text)) return 'data_handling';
1181
- if (/\b(brand|style|logo|trademark|marketing)\b/.test(text)) return 'brand_voice';
1182
- if (/\b(security|auth|password|credential|access|firewall|threat)\b/.test(text)) return 'security';
1183
- if (/\b(escalat|emergency|urgent|incident|crisis)\b/.test(text)) return 'escalation';
1184
- return 'custom';
1185
- }
1186
- }