@agenticmail/enterprise 0.4.0 → 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (643) hide show
  1. package/community-skills/index.json +1 -1
  2. package/dashboards/express/node_modules/.package-lock.json +913 -0
  3. package/dashboards/express/node_modules/accepts/HISTORY.md +250 -0
  4. package/dashboards/express/node_modules/accepts/LICENSE +23 -0
  5. package/dashboards/express/node_modules/accepts/README.md +140 -0
  6. package/dashboards/express/node_modules/accepts/index.js +238 -0
  7. package/dashboards/express/node_modules/accepts/package.json +47 -0
  8. package/dashboards/express/node_modules/body-parser/LICENSE +23 -0
  9. package/dashboards/express/node_modules/body-parser/README.md +494 -0
  10. package/dashboards/express/node_modules/body-parser/index.js +71 -0
  11. package/dashboards/express/node_modules/body-parser/lib/read.js +247 -0
  12. package/dashboards/express/node_modules/body-parser/lib/types/json.js +158 -0
  13. package/dashboards/express/node_modules/body-parser/lib/types/raw.js +42 -0
  14. package/dashboards/express/node_modules/body-parser/lib/types/text.js +36 -0
  15. package/dashboards/express/node_modules/body-parser/lib/types/urlencoded.js +142 -0
  16. package/dashboards/express/node_modules/body-parser/lib/utils.js +98 -0
  17. package/dashboards/express/node_modules/body-parser/package.json +52 -0
  18. package/dashboards/express/node_modules/bytes/History.md +97 -0
  19. package/dashboards/express/node_modules/bytes/LICENSE +23 -0
  20. package/dashboards/express/node_modules/bytes/Readme.md +152 -0
  21. package/dashboards/express/node_modules/bytes/index.js +170 -0
  22. package/dashboards/express/node_modules/bytes/package.json +42 -0
  23. package/dashboards/express/node_modules/call-bind-apply-helpers/.eslintrc +17 -0
  24. package/dashboards/express/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
  25. package/dashboards/express/node_modules/call-bind-apply-helpers/.nycrc +9 -0
  26. package/dashboards/express/node_modules/call-bind-apply-helpers/CHANGELOG.md +30 -0
  27. package/dashboards/express/node_modules/call-bind-apply-helpers/LICENSE +21 -0
  28. package/dashboards/express/node_modules/call-bind-apply-helpers/README.md +62 -0
  29. package/dashboards/express/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
  30. package/dashboards/express/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
  31. package/dashboards/express/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
  32. package/dashboards/express/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
  33. package/dashboards/express/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
  34. package/dashboards/express/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
  35. package/dashboards/express/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
  36. package/dashboards/express/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
  37. package/dashboards/express/node_modules/call-bind-apply-helpers/index.d.ts +64 -0
  38. package/dashboards/express/node_modules/call-bind-apply-helpers/index.js +15 -0
  39. package/dashboards/express/node_modules/call-bind-apply-helpers/package.json +85 -0
  40. package/dashboards/express/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
  41. package/dashboards/express/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
  42. package/dashboards/express/node_modules/call-bind-apply-helpers/test/index.js +63 -0
  43. package/dashboards/express/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
  44. package/dashboards/express/node_modules/call-bound/.eslintrc +13 -0
  45. package/dashboards/express/node_modules/call-bound/.github/FUNDING.yml +12 -0
  46. package/dashboards/express/node_modules/call-bound/.nycrc +9 -0
  47. package/dashboards/express/node_modules/call-bound/CHANGELOG.md +42 -0
  48. package/dashboards/express/node_modules/call-bound/LICENSE +21 -0
  49. package/dashboards/express/node_modules/call-bound/README.md +53 -0
  50. package/dashboards/express/node_modules/call-bound/index.d.ts +94 -0
  51. package/dashboards/express/node_modules/call-bound/index.js +19 -0
  52. package/dashboards/express/node_modules/call-bound/package.json +99 -0
  53. package/dashboards/express/node_modules/call-bound/test/index.js +61 -0
  54. package/dashboards/express/node_modules/call-bound/tsconfig.json +10 -0
  55. package/dashboards/express/node_modules/content-disposition/HISTORY.md +72 -0
  56. package/dashboards/express/node_modules/content-disposition/LICENSE +22 -0
  57. package/dashboards/express/node_modules/content-disposition/README.md +142 -0
  58. package/dashboards/express/node_modules/content-disposition/index.js +458 -0
  59. package/dashboards/express/node_modules/content-disposition/package.json +43 -0
  60. package/dashboards/express/node_modules/content-type/HISTORY.md +29 -0
  61. package/dashboards/express/node_modules/content-type/LICENSE +22 -0
  62. package/dashboards/express/node_modules/content-type/README.md +94 -0
  63. package/dashboards/express/node_modules/content-type/index.js +225 -0
  64. package/dashboards/express/node_modules/content-type/package.json +42 -0
  65. package/dashboards/express/node_modules/cookie/LICENSE +24 -0
  66. package/dashboards/express/node_modules/cookie/README.md +317 -0
  67. package/dashboards/express/node_modules/cookie/SECURITY.md +25 -0
  68. package/dashboards/express/node_modules/cookie/index.js +335 -0
  69. package/dashboards/express/node_modules/cookie/package.json +44 -0
  70. package/dashboards/express/node_modules/cookie-signature/History.md +70 -0
  71. package/dashboards/express/node_modules/cookie-signature/LICENSE +22 -0
  72. package/dashboards/express/node_modules/cookie-signature/Readme.md +23 -0
  73. package/dashboards/express/node_modules/cookie-signature/index.js +47 -0
  74. package/dashboards/express/node_modules/cookie-signature/package.json +24 -0
  75. package/dashboards/express/node_modules/debug/LICENSE +20 -0
  76. package/dashboards/express/node_modules/debug/README.md +481 -0
  77. package/dashboards/express/node_modules/debug/package.json +64 -0
  78. package/dashboards/express/node_modules/debug/src/browser.js +272 -0
  79. package/dashboards/express/node_modules/debug/src/common.js +292 -0
  80. package/dashboards/express/node_modules/debug/src/index.js +10 -0
  81. package/dashboards/express/node_modules/debug/src/node.js +263 -0
  82. package/dashboards/express/node_modules/depd/History.md +103 -0
  83. package/dashboards/express/node_modules/depd/LICENSE +22 -0
  84. package/dashboards/express/node_modules/depd/Readme.md +280 -0
  85. package/dashboards/express/node_modules/depd/index.js +538 -0
  86. package/dashboards/express/node_modules/depd/lib/browser/index.js +77 -0
  87. package/dashboards/express/node_modules/depd/package.json +45 -0
  88. package/dashboards/express/node_modules/dunder-proto/.eslintrc +5 -0
  89. package/dashboards/express/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
  90. package/dashboards/express/node_modules/dunder-proto/.nycrc +13 -0
  91. package/dashboards/express/node_modules/dunder-proto/CHANGELOG.md +24 -0
  92. package/dashboards/express/node_modules/dunder-proto/LICENSE +21 -0
  93. package/dashboards/express/node_modules/dunder-proto/README.md +54 -0
  94. package/dashboards/express/node_modules/dunder-proto/get.d.ts +5 -0
  95. package/dashboards/express/node_modules/dunder-proto/get.js +30 -0
  96. package/dashboards/express/node_modules/dunder-proto/package.json +76 -0
  97. package/dashboards/express/node_modules/dunder-proto/set.d.ts +5 -0
  98. package/dashboards/express/node_modules/dunder-proto/set.js +35 -0
  99. package/dashboards/express/node_modules/dunder-proto/test/get.js +34 -0
  100. package/dashboards/express/node_modules/dunder-proto/test/index.js +4 -0
  101. package/dashboards/express/node_modules/dunder-proto/test/set.js +50 -0
  102. package/dashboards/express/node_modules/dunder-proto/tsconfig.json +9 -0
  103. package/dashboards/express/node_modules/ee-first/LICENSE +22 -0
  104. package/dashboards/express/node_modules/ee-first/README.md +80 -0
  105. package/dashboards/express/node_modules/ee-first/index.js +95 -0
  106. package/dashboards/express/node_modules/ee-first/package.json +29 -0
  107. package/dashboards/express/node_modules/encodeurl/LICENSE +22 -0
  108. package/dashboards/express/node_modules/encodeurl/README.md +109 -0
  109. package/dashboards/express/node_modules/encodeurl/index.js +60 -0
  110. package/dashboards/express/node_modules/encodeurl/package.json +40 -0
  111. package/dashboards/express/node_modules/es-define-property/.eslintrc +13 -0
  112. package/dashboards/express/node_modules/es-define-property/.github/FUNDING.yml +12 -0
  113. package/dashboards/express/node_modules/es-define-property/.nycrc +9 -0
  114. package/dashboards/express/node_modules/es-define-property/CHANGELOG.md +29 -0
  115. package/dashboards/express/node_modules/es-define-property/LICENSE +21 -0
  116. package/dashboards/express/node_modules/es-define-property/README.md +49 -0
  117. package/dashboards/express/node_modules/es-define-property/index.d.ts +3 -0
  118. package/dashboards/express/node_modules/es-define-property/index.js +14 -0
  119. package/dashboards/express/node_modules/es-define-property/package.json +81 -0
  120. package/dashboards/express/node_modules/es-define-property/test/index.js +56 -0
  121. package/dashboards/express/node_modules/es-define-property/tsconfig.json +10 -0
  122. package/dashboards/express/node_modules/es-errors/.eslintrc +5 -0
  123. package/dashboards/express/node_modules/es-errors/.github/FUNDING.yml +12 -0
  124. package/dashboards/express/node_modules/es-errors/CHANGELOG.md +40 -0
  125. package/dashboards/express/node_modules/es-errors/LICENSE +21 -0
  126. package/dashboards/express/node_modules/es-errors/README.md +55 -0
  127. package/dashboards/express/node_modules/es-errors/eval.d.ts +3 -0
  128. package/dashboards/express/node_modules/es-errors/eval.js +4 -0
  129. package/dashboards/express/node_modules/es-errors/index.d.ts +3 -0
  130. package/dashboards/express/node_modules/es-errors/index.js +4 -0
  131. package/dashboards/express/node_modules/es-errors/package.json +80 -0
  132. package/dashboards/express/node_modules/es-errors/range.d.ts +3 -0
  133. package/dashboards/express/node_modules/es-errors/range.js +4 -0
  134. package/dashboards/express/node_modules/es-errors/ref.d.ts +3 -0
  135. package/dashboards/express/node_modules/es-errors/ref.js +4 -0
  136. package/dashboards/express/node_modules/es-errors/syntax.d.ts +3 -0
  137. package/dashboards/express/node_modules/es-errors/syntax.js +4 -0
  138. package/dashboards/express/node_modules/es-errors/test/index.js +19 -0
  139. package/dashboards/express/node_modules/es-errors/tsconfig.json +49 -0
  140. package/dashboards/express/node_modules/es-errors/type.d.ts +3 -0
  141. package/dashboards/express/node_modules/es-errors/type.js +4 -0
  142. package/dashboards/express/node_modules/es-errors/uri.d.ts +3 -0
  143. package/dashboards/express/node_modules/es-errors/uri.js +4 -0
  144. package/dashboards/express/node_modules/es-object-atoms/.eslintrc +16 -0
  145. package/dashboards/express/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
  146. package/dashboards/express/node_modules/es-object-atoms/CHANGELOG.md +37 -0
  147. package/dashboards/express/node_modules/es-object-atoms/LICENSE +21 -0
  148. package/dashboards/express/node_modules/es-object-atoms/README.md +63 -0
  149. package/dashboards/express/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
  150. package/dashboards/express/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
  151. package/dashboards/express/node_modules/es-object-atoms/ToObject.d.ts +7 -0
  152. package/dashboards/express/node_modules/es-object-atoms/ToObject.js +10 -0
  153. package/dashboards/express/node_modules/es-object-atoms/index.d.ts +3 -0
  154. package/dashboards/express/node_modules/es-object-atoms/index.js +4 -0
  155. package/dashboards/express/node_modules/es-object-atoms/isObject.d.ts +3 -0
  156. package/dashboards/express/node_modules/es-object-atoms/isObject.js +6 -0
  157. package/dashboards/express/node_modules/es-object-atoms/package.json +80 -0
  158. package/dashboards/express/node_modules/es-object-atoms/test/index.js +38 -0
  159. package/dashboards/express/node_modules/es-object-atoms/tsconfig.json +6 -0
  160. package/dashboards/express/node_modules/escape-html/LICENSE +24 -0
  161. package/dashboards/express/node_modules/escape-html/Readme.md +43 -0
  162. package/dashboards/express/node_modules/escape-html/index.js +78 -0
  163. package/dashboards/express/node_modules/escape-html/package.json +24 -0
  164. package/dashboards/express/node_modules/etag/HISTORY.md +83 -0
  165. package/dashboards/express/node_modules/etag/LICENSE +22 -0
  166. package/dashboards/express/node_modules/etag/README.md +159 -0
  167. package/dashboards/express/node_modules/etag/index.js +131 -0
  168. package/dashboards/express/node_modules/etag/package.json +47 -0
  169. package/dashboards/express/node_modules/express/LICENSE +24 -0
  170. package/dashboards/express/node_modules/express/Readme.md +276 -0
  171. package/dashboards/express/node_modules/express/index.js +11 -0
  172. package/dashboards/express/node_modules/express/lib/application.js +631 -0
  173. package/dashboards/express/node_modules/express/lib/express.js +81 -0
  174. package/dashboards/express/node_modules/express/lib/request.js +514 -0
  175. package/dashboards/express/node_modules/express/lib/response.js +1053 -0
  176. package/dashboards/express/node_modules/express/lib/utils.js +271 -0
  177. package/dashboards/express/node_modules/express/lib/view.js +205 -0
  178. package/dashboards/express/node_modules/express/package.json +99 -0
  179. package/dashboards/express/node_modules/express-session/LICENSE +24 -0
  180. package/dashboards/express/node_modules/express-session/README.md +1061 -0
  181. package/dashboards/express/node_modules/express-session/index.js +700 -0
  182. package/dashboards/express/node_modules/express-session/node_modules/cookie-signature/History.md +42 -0
  183. package/dashboards/express/node_modules/express-session/node_modules/cookie-signature/Readme.md +42 -0
  184. package/dashboards/express/node_modules/express-session/node_modules/cookie-signature/index.js +51 -0
  185. package/dashboards/express/node_modules/express-session/node_modules/cookie-signature/package.json +18 -0
  186. package/dashboards/express/node_modules/express-session/node_modules/debug/.coveralls.yml +1 -0
  187. package/dashboards/express/node_modules/express-session/node_modules/debug/.eslintrc +11 -0
  188. package/dashboards/express/node_modules/express-session/node_modules/debug/.travis.yml +14 -0
  189. package/dashboards/express/node_modules/express-session/node_modules/debug/CHANGELOG.md +362 -0
  190. package/dashboards/express/node_modules/express-session/node_modules/debug/LICENSE +19 -0
  191. package/dashboards/express/node_modules/express-session/node_modules/debug/Makefile +50 -0
  192. package/dashboards/express/node_modules/express-session/node_modules/debug/README.md +312 -0
  193. package/dashboards/express/node_modules/express-session/node_modules/debug/component.json +19 -0
  194. package/dashboards/express/node_modules/express-session/node_modules/debug/karma.conf.js +70 -0
  195. package/dashboards/express/node_modules/express-session/node_modules/debug/node.js +1 -0
  196. package/dashboards/express/node_modules/express-session/node_modules/debug/package.json +49 -0
  197. package/dashboards/express/node_modules/express-session/node_modules/debug/src/browser.js +185 -0
  198. package/dashboards/express/node_modules/express-session/node_modules/debug/src/debug.js +202 -0
  199. package/dashboards/express/node_modules/express-session/node_modules/debug/src/index.js +10 -0
  200. package/dashboards/express/node_modules/express-session/node_modules/debug/src/inspector-log.js +15 -0
  201. package/dashboards/express/node_modules/express-session/node_modules/debug/src/node.js +248 -0
  202. package/dashboards/express/node_modules/express-session/node_modules/ms/index.js +152 -0
  203. package/dashboards/express/node_modules/express-session/node_modules/ms/license.md +21 -0
  204. package/dashboards/express/node_modules/express-session/node_modules/ms/package.json +37 -0
  205. package/dashboards/express/node_modules/express-session/node_modules/ms/readme.md +51 -0
  206. package/dashboards/express/node_modules/express-session/package.json +50 -0
  207. package/dashboards/express/node_modules/express-session/session/cookie.js +152 -0
  208. package/dashboards/express/node_modules/express-session/session/memory.js +187 -0
  209. package/dashboards/express/node_modules/express-session/session/session.js +143 -0
  210. package/dashboards/express/node_modules/express-session/session/store.js +102 -0
  211. package/dashboards/express/node_modules/finalhandler/HISTORY.md +239 -0
  212. package/dashboards/express/node_modules/finalhandler/LICENSE +22 -0
  213. package/dashboards/express/node_modules/finalhandler/README.md +150 -0
  214. package/dashboards/express/node_modules/finalhandler/index.js +293 -0
  215. package/dashboards/express/node_modules/finalhandler/package.json +47 -0
  216. package/dashboards/express/node_modules/forwarded/HISTORY.md +21 -0
  217. package/dashboards/express/node_modules/forwarded/LICENSE +22 -0
  218. package/dashboards/express/node_modules/forwarded/README.md +57 -0
  219. package/dashboards/express/node_modules/forwarded/index.js +90 -0
  220. package/dashboards/express/node_modules/forwarded/package.json +45 -0
  221. package/dashboards/express/node_modules/fresh/HISTORY.md +80 -0
  222. package/dashboards/express/node_modules/fresh/LICENSE +23 -0
  223. package/dashboards/express/node_modules/fresh/README.md +117 -0
  224. package/dashboards/express/node_modules/fresh/index.js +136 -0
  225. package/dashboards/express/node_modules/fresh/package.json +46 -0
  226. package/dashboards/express/node_modules/function-bind/.eslintrc +21 -0
  227. package/dashboards/express/node_modules/function-bind/.github/FUNDING.yml +12 -0
  228. package/dashboards/express/node_modules/function-bind/.github/SECURITY.md +3 -0
  229. package/dashboards/express/node_modules/function-bind/.nycrc +13 -0
  230. package/dashboards/express/node_modules/function-bind/CHANGELOG.md +136 -0
  231. package/dashboards/express/node_modules/function-bind/LICENSE +20 -0
  232. package/dashboards/express/node_modules/function-bind/README.md +46 -0
  233. package/dashboards/express/node_modules/function-bind/implementation.js +84 -0
  234. package/dashboards/express/node_modules/function-bind/index.js +5 -0
  235. package/dashboards/express/node_modules/function-bind/package.json +87 -0
  236. package/dashboards/express/node_modules/function-bind/test/.eslintrc +9 -0
  237. package/dashboards/express/node_modules/function-bind/test/index.js +252 -0
  238. package/dashboards/express/node_modules/get-intrinsic/.eslintrc +42 -0
  239. package/dashboards/express/node_modules/get-intrinsic/.github/FUNDING.yml +12 -0
  240. package/dashboards/express/node_modules/get-intrinsic/.nycrc +9 -0
  241. package/dashboards/express/node_modules/get-intrinsic/CHANGELOG.md +186 -0
  242. package/dashboards/express/node_modules/get-intrinsic/LICENSE +21 -0
  243. package/dashboards/express/node_modules/get-intrinsic/README.md +71 -0
  244. package/dashboards/express/node_modules/get-intrinsic/index.js +378 -0
  245. package/dashboards/express/node_modules/get-intrinsic/package.json +97 -0
  246. package/dashboards/express/node_modules/get-intrinsic/test/GetIntrinsic.js +274 -0
  247. package/dashboards/express/node_modules/get-proto/.eslintrc +10 -0
  248. package/dashboards/express/node_modules/get-proto/.github/FUNDING.yml +12 -0
  249. package/dashboards/express/node_modules/get-proto/.nycrc +9 -0
  250. package/dashboards/express/node_modules/get-proto/CHANGELOG.md +21 -0
  251. package/dashboards/express/node_modules/get-proto/LICENSE +21 -0
  252. package/dashboards/express/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
  253. package/dashboards/express/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
  254. package/dashboards/express/node_modules/get-proto/README.md +50 -0
  255. package/dashboards/express/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
  256. package/dashboards/express/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
  257. package/dashboards/express/node_modules/get-proto/index.d.ts +5 -0
  258. package/dashboards/express/node_modules/get-proto/index.js +27 -0
  259. package/dashboards/express/node_modules/get-proto/package.json +81 -0
  260. package/dashboards/express/node_modules/get-proto/test/index.js +68 -0
  261. package/dashboards/express/node_modules/get-proto/tsconfig.json +9 -0
  262. package/dashboards/express/node_modules/gopd/.eslintrc +16 -0
  263. package/dashboards/express/node_modules/gopd/.github/FUNDING.yml +12 -0
  264. package/dashboards/express/node_modules/gopd/CHANGELOG.md +45 -0
  265. package/dashboards/express/node_modules/gopd/LICENSE +21 -0
  266. package/dashboards/express/node_modules/gopd/README.md +40 -0
  267. package/dashboards/express/node_modules/gopd/gOPD.d.ts +1 -0
  268. package/dashboards/express/node_modules/gopd/gOPD.js +4 -0
  269. package/dashboards/express/node_modules/gopd/index.d.ts +5 -0
  270. package/dashboards/express/node_modules/gopd/index.js +15 -0
  271. package/dashboards/express/node_modules/gopd/package.json +77 -0
  272. package/dashboards/express/node_modules/gopd/test/index.js +36 -0
  273. package/dashboards/express/node_modules/gopd/tsconfig.json +9 -0
  274. package/dashboards/express/node_modules/has-symbols/.eslintrc +11 -0
  275. package/dashboards/express/node_modules/has-symbols/.github/FUNDING.yml +12 -0
  276. package/dashboards/express/node_modules/has-symbols/.nycrc +9 -0
  277. package/dashboards/express/node_modules/has-symbols/CHANGELOG.md +91 -0
  278. package/dashboards/express/node_modules/has-symbols/LICENSE +21 -0
  279. package/dashboards/express/node_modules/has-symbols/README.md +46 -0
  280. package/dashboards/express/node_modules/has-symbols/index.d.ts +3 -0
  281. package/dashboards/express/node_modules/has-symbols/index.js +14 -0
  282. package/dashboards/express/node_modules/has-symbols/package.json +111 -0
  283. package/dashboards/express/node_modules/has-symbols/shams.d.ts +3 -0
  284. package/dashboards/express/node_modules/has-symbols/shams.js +45 -0
  285. package/dashboards/express/node_modules/has-symbols/test/index.js +22 -0
  286. package/dashboards/express/node_modules/has-symbols/test/shams/core-js.js +29 -0
  287. package/dashboards/express/node_modules/has-symbols/test/shams/get-own-property-symbols.js +29 -0
  288. package/dashboards/express/node_modules/has-symbols/test/tests.js +58 -0
  289. package/dashboards/express/node_modules/has-symbols/tsconfig.json +10 -0
  290. package/dashboards/express/node_modules/hasown/.eslintrc +5 -0
  291. package/dashboards/express/node_modules/hasown/.github/FUNDING.yml +12 -0
  292. package/dashboards/express/node_modules/hasown/.nycrc +13 -0
  293. package/dashboards/express/node_modules/hasown/CHANGELOG.md +40 -0
  294. package/dashboards/express/node_modules/hasown/LICENSE +21 -0
  295. package/dashboards/express/node_modules/hasown/README.md +40 -0
  296. package/dashboards/express/node_modules/hasown/index.d.ts +3 -0
  297. package/dashboards/express/node_modules/hasown/index.js +8 -0
  298. package/dashboards/express/node_modules/hasown/package.json +92 -0
  299. package/dashboards/express/node_modules/hasown/tsconfig.json +6 -0
  300. package/dashboards/express/node_modules/http-errors/HISTORY.md +186 -0
  301. package/dashboards/express/node_modules/http-errors/LICENSE +23 -0
  302. package/dashboards/express/node_modules/http-errors/README.md +169 -0
  303. package/dashboards/express/node_modules/http-errors/index.js +290 -0
  304. package/dashboards/express/node_modules/http-errors/package.json +54 -0
  305. package/dashboards/express/node_modules/iconv-lite/LICENSE +21 -0
  306. package/dashboards/express/node_modules/iconv-lite/README.md +138 -0
  307. package/dashboards/express/node_modules/iconv-lite/encodings/dbcs-codec.js +532 -0
  308. package/dashboards/express/node_modules/iconv-lite/encodings/dbcs-data.js +185 -0
  309. package/dashboards/express/node_modules/iconv-lite/encodings/index.js +23 -0
  310. package/dashboards/express/node_modules/iconv-lite/encodings/internal.js +218 -0
  311. package/dashboards/express/node_modules/iconv-lite/encodings/sbcs-codec.js +75 -0
  312. package/dashboards/express/node_modules/iconv-lite/encodings/sbcs-data-generated.js +451 -0
  313. package/dashboards/express/node_modules/iconv-lite/encodings/sbcs-data.js +178 -0
  314. package/dashboards/express/node_modules/iconv-lite/encodings/tables/big5-added.json +122 -0
  315. package/dashboards/express/node_modules/iconv-lite/encodings/tables/cp936.json +264 -0
  316. package/dashboards/express/node_modules/iconv-lite/encodings/tables/cp949.json +273 -0
  317. package/dashboards/express/node_modules/iconv-lite/encodings/tables/cp950.json +177 -0
  318. package/dashboards/express/node_modules/iconv-lite/encodings/tables/eucjp.json +182 -0
  319. package/dashboards/express/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +1 -0
  320. package/dashboards/express/node_modules/iconv-lite/encodings/tables/gbk-added.json +56 -0
  321. package/dashboards/express/node_modules/iconv-lite/encodings/tables/shiftjis.json +125 -0
  322. package/dashboards/express/node_modules/iconv-lite/encodings/utf16.js +187 -0
  323. package/dashboards/express/node_modules/iconv-lite/encodings/utf32.js +307 -0
  324. package/dashboards/express/node_modules/iconv-lite/encodings/utf7.js +283 -0
  325. package/dashboards/express/node_modules/iconv-lite/lib/bom-handling.js +48 -0
  326. package/dashboards/express/node_modules/iconv-lite/lib/helpers/merge-exports.js +13 -0
  327. package/dashboards/express/node_modules/iconv-lite/lib/index.d.ts +129 -0
  328. package/dashboards/express/node_modules/iconv-lite/lib/index.js +182 -0
  329. package/dashboards/express/node_modules/iconv-lite/lib/streams.js +105 -0
  330. package/dashboards/express/node_modules/iconv-lite/package.json +70 -0
  331. package/dashboards/express/node_modules/iconv-lite/types/encodings.d.ts +423 -0
  332. package/dashboards/express/node_modules/inherits/LICENSE +16 -0
  333. package/dashboards/express/node_modules/inherits/README.md +42 -0
  334. package/dashboards/express/node_modules/inherits/inherits.js +9 -0
  335. package/dashboards/express/node_modules/inherits/inherits_browser.js +27 -0
  336. package/dashboards/express/node_modules/inherits/package.json +29 -0
  337. package/dashboards/express/node_modules/ipaddr.js/LICENSE +19 -0
  338. package/dashboards/express/node_modules/ipaddr.js/README.md +233 -0
  339. package/dashboards/express/node_modules/ipaddr.js/ipaddr.min.js +1 -0
  340. package/dashboards/express/node_modules/ipaddr.js/lib/ipaddr.js +673 -0
  341. package/dashboards/express/node_modules/ipaddr.js/lib/ipaddr.js.d.ts +68 -0
  342. package/dashboards/express/node_modules/ipaddr.js/package.json +35 -0
  343. package/dashboards/express/node_modules/is-promise/LICENSE +19 -0
  344. package/dashboards/express/node_modules/is-promise/index.d.ts +2 -0
  345. package/dashboards/express/node_modules/is-promise/index.js +6 -0
  346. package/dashboards/express/node_modules/is-promise/index.mjs +3 -0
  347. package/dashboards/express/node_modules/is-promise/package.json +30 -0
  348. package/dashboards/express/node_modules/is-promise/readme.md +33 -0
  349. package/dashboards/express/node_modules/math-intrinsics/.eslintrc +16 -0
  350. package/dashboards/express/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
  351. package/dashboards/express/node_modules/math-intrinsics/CHANGELOG.md +24 -0
  352. package/dashboards/express/node_modules/math-intrinsics/LICENSE +21 -0
  353. package/dashboards/express/node_modules/math-intrinsics/README.md +50 -0
  354. package/dashboards/express/node_modules/math-intrinsics/abs.d.ts +1 -0
  355. package/dashboards/express/node_modules/math-intrinsics/abs.js +4 -0
  356. package/dashboards/express/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
  357. package/dashboards/express/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
  358. package/dashboards/express/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
  359. package/dashboards/express/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
  360. package/dashboards/express/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
  361. package/dashboards/express/node_modules/math-intrinsics/constants/maxValue.js +5 -0
  362. package/dashboards/express/node_modules/math-intrinsics/floor.d.ts +1 -0
  363. package/dashboards/express/node_modules/math-intrinsics/floor.js +4 -0
  364. package/dashboards/express/node_modules/math-intrinsics/isFinite.d.ts +3 -0
  365. package/dashboards/express/node_modules/math-intrinsics/isFinite.js +12 -0
  366. package/dashboards/express/node_modules/math-intrinsics/isInteger.d.ts +3 -0
  367. package/dashboards/express/node_modules/math-intrinsics/isInteger.js +16 -0
  368. package/dashboards/express/node_modules/math-intrinsics/isNaN.d.ts +1 -0
  369. package/dashboards/express/node_modules/math-intrinsics/isNaN.js +6 -0
  370. package/dashboards/express/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
  371. package/dashboards/express/node_modules/math-intrinsics/isNegativeZero.js +6 -0
  372. package/dashboards/express/node_modules/math-intrinsics/max.d.ts +1 -0
  373. package/dashboards/express/node_modules/math-intrinsics/max.js +4 -0
  374. package/dashboards/express/node_modules/math-intrinsics/min.d.ts +1 -0
  375. package/dashboards/express/node_modules/math-intrinsics/min.js +4 -0
  376. package/dashboards/express/node_modules/math-intrinsics/mod.d.ts +3 -0
  377. package/dashboards/express/node_modules/math-intrinsics/mod.js +9 -0
  378. package/dashboards/express/node_modules/math-intrinsics/package.json +86 -0
  379. package/dashboards/express/node_modules/math-intrinsics/pow.d.ts +1 -0
  380. package/dashboards/express/node_modules/math-intrinsics/pow.js +4 -0
  381. package/dashboards/express/node_modules/math-intrinsics/round.d.ts +1 -0
  382. package/dashboards/express/node_modules/math-intrinsics/round.js +4 -0
  383. package/dashboards/express/node_modules/math-intrinsics/sign.d.ts +3 -0
  384. package/dashboards/express/node_modules/math-intrinsics/sign.js +11 -0
  385. package/dashboards/express/node_modules/math-intrinsics/test/index.js +192 -0
  386. package/dashboards/express/node_modules/math-intrinsics/tsconfig.json +3 -0
  387. package/dashboards/express/node_modules/media-typer/HISTORY.md +50 -0
  388. package/dashboards/express/node_modules/media-typer/LICENSE +22 -0
  389. package/dashboards/express/node_modules/media-typer/README.md +93 -0
  390. package/dashboards/express/node_modules/media-typer/index.js +143 -0
  391. package/dashboards/express/node_modules/media-typer/package.json +33 -0
  392. package/dashboards/express/node_modules/merge-descriptors/index.d.ts +11 -0
  393. package/dashboards/express/node_modules/merge-descriptors/index.js +26 -0
  394. package/dashboards/express/node_modules/merge-descriptors/license +11 -0
  395. package/dashboards/express/node_modules/merge-descriptors/package.json +50 -0
  396. package/dashboards/express/node_modules/merge-descriptors/readme.md +55 -0
  397. package/dashboards/express/node_modules/mime-db/HISTORY.md +541 -0
  398. package/dashboards/express/node_modules/mime-db/LICENSE +23 -0
  399. package/dashboards/express/node_modules/mime-db/README.md +109 -0
  400. package/dashboards/express/node_modules/mime-db/db.json +9342 -0
  401. package/dashboards/express/node_modules/mime-db/index.js +12 -0
  402. package/dashboards/express/node_modules/mime-db/package.json +56 -0
  403. package/dashboards/express/node_modules/mime-types/HISTORY.md +428 -0
  404. package/dashboards/express/node_modules/mime-types/LICENSE +23 -0
  405. package/dashboards/express/node_modules/mime-types/README.md +126 -0
  406. package/dashboards/express/node_modules/mime-types/index.js +211 -0
  407. package/dashboards/express/node_modules/mime-types/mimeScore.js +57 -0
  408. package/dashboards/express/node_modules/mime-types/package.json +49 -0
  409. package/dashboards/express/node_modules/ms/index.js +162 -0
  410. package/dashboards/express/node_modules/ms/license.md +21 -0
  411. package/dashboards/express/node_modules/ms/package.json +38 -0
  412. package/dashboards/express/node_modules/ms/readme.md +59 -0
  413. package/dashboards/express/node_modules/negotiator/HISTORY.md +114 -0
  414. package/dashboards/express/node_modules/negotiator/LICENSE +24 -0
  415. package/dashboards/express/node_modules/negotiator/README.md +212 -0
  416. package/dashboards/express/node_modules/negotiator/index.js +83 -0
  417. package/dashboards/express/node_modules/negotiator/lib/charset.js +169 -0
  418. package/dashboards/express/node_modules/negotiator/lib/encoding.js +205 -0
  419. package/dashboards/express/node_modules/negotiator/lib/language.js +179 -0
  420. package/dashboards/express/node_modules/negotiator/lib/mediaType.js +294 -0
  421. package/dashboards/express/node_modules/negotiator/package.json +43 -0
  422. package/dashboards/express/node_modules/object-inspect/.eslintrc +53 -0
  423. package/dashboards/express/node_modules/object-inspect/.github/FUNDING.yml +12 -0
  424. package/dashboards/express/node_modules/object-inspect/.nycrc +13 -0
  425. package/dashboards/express/node_modules/object-inspect/CHANGELOG.md +424 -0
  426. package/dashboards/express/node_modules/object-inspect/LICENSE +21 -0
  427. package/dashboards/express/node_modules/object-inspect/example/all.js +23 -0
  428. package/dashboards/express/node_modules/object-inspect/example/circular.js +6 -0
  429. package/dashboards/express/node_modules/object-inspect/example/fn.js +5 -0
  430. package/dashboards/express/node_modules/object-inspect/example/inspect.js +10 -0
  431. package/dashboards/express/node_modules/object-inspect/index.js +544 -0
  432. package/dashboards/express/node_modules/object-inspect/package-support.json +20 -0
  433. package/dashboards/express/node_modules/object-inspect/package.json +105 -0
  434. package/dashboards/express/node_modules/object-inspect/readme.markdown +84 -0
  435. package/dashboards/express/node_modules/object-inspect/test/bigint.js +58 -0
  436. package/dashboards/express/node_modules/object-inspect/test/browser/dom.js +15 -0
  437. package/dashboards/express/node_modules/object-inspect/test/circular.js +16 -0
  438. package/dashboards/express/node_modules/object-inspect/test/deep.js +12 -0
  439. package/dashboards/express/node_modules/object-inspect/test/element.js +53 -0
  440. package/dashboards/express/node_modules/object-inspect/test/err.js +48 -0
  441. package/dashboards/express/node_modules/object-inspect/test/fakes.js +29 -0
  442. package/dashboards/express/node_modules/object-inspect/test/fn.js +76 -0
  443. package/dashboards/express/node_modules/object-inspect/test/global.js +17 -0
  444. package/dashboards/express/node_modules/object-inspect/test/has.js +15 -0
  445. package/dashboards/express/node_modules/object-inspect/test/holes.js +15 -0
  446. package/dashboards/express/node_modules/object-inspect/test/indent-option.js +271 -0
  447. package/dashboards/express/node_modules/object-inspect/test/inspect.js +139 -0
  448. package/dashboards/express/node_modules/object-inspect/test/lowbyte.js +12 -0
  449. package/dashboards/express/node_modules/object-inspect/test/number.js +58 -0
  450. package/dashboards/express/node_modules/object-inspect/test/quoteStyle.js +26 -0
  451. package/dashboards/express/node_modules/object-inspect/test/toStringTag.js +40 -0
  452. package/dashboards/express/node_modules/object-inspect/test/undef.js +12 -0
  453. package/dashboards/express/node_modules/object-inspect/test/values.js +261 -0
  454. package/dashboards/express/node_modules/object-inspect/test-core-js.js +26 -0
  455. package/dashboards/express/node_modules/object-inspect/util.inspect.js +1 -0
  456. package/dashboards/express/node_modules/on-finished/HISTORY.md +98 -0
  457. package/dashboards/express/node_modules/on-finished/LICENSE +23 -0
  458. package/dashboards/express/node_modules/on-finished/README.md +162 -0
  459. package/dashboards/express/node_modules/on-finished/index.js +234 -0
  460. package/dashboards/express/node_modules/on-finished/package.json +39 -0
  461. package/dashboards/express/node_modules/on-headers/HISTORY.md +26 -0
  462. package/dashboards/express/node_modules/on-headers/LICENSE +22 -0
  463. package/dashboards/express/node_modules/on-headers/README.md +81 -0
  464. package/dashboards/express/node_modules/on-headers/index.js +180 -0
  465. package/dashboards/express/node_modules/on-headers/package.json +44 -0
  466. package/dashboards/express/node_modules/once/LICENSE +15 -0
  467. package/dashboards/express/node_modules/once/README.md +79 -0
  468. package/dashboards/express/node_modules/once/once.js +42 -0
  469. package/dashboards/express/node_modules/once/package.json +33 -0
  470. package/dashboards/express/node_modules/parseurl/HISTORY.md +58 -0
  471. package/dashboards/express/node_modules/parseurl/LICENSE +24 -0
  472. package/dashboards/express/node_modules/parseurl/README.md +133 -0
  473. package/dashboards/express/node_modules/parseurl/index.js +158 -0
  474. package/dashboards/express/node_modules/parseurl/package.json +40 -0
  475. package/dashboards/express/node_modules/path-to-regexp/LICENSE +21 -0
  476. package/dashboards/express/node_modules/path-to-regexp/Readme.md +224 -0
  477. package/dashboards/express/node_modules/path-to-regexp/dist/index.d.ts +144 -0
  478. package/dashboards/express/node_modules/path-to-regexp/dist/index.js +409 -0
  479. package/dashboards/express/node_modules/path-to-regexp/dist/index.js.map +1 -0
  480. package/dashboards/express/node_modules/path-to-regexp/package.json +64 -0
  481. package/dashboards/express/node_modules/proxy-addr/HISTORY.md +161 -0
  482. package/dashboards/express/node_modules/proxy-addr/LICENSE +22 -0
  483. package/dashboards/express/node_modules/proxy-addr/README.md +139 -0
  484. package/dashboards/express/node_modules/proxy-addr/index.js +327 -0
  485. package/dashboards/express/node_modules/proxy-addr/package.json +47 -0
  486. package/dashboards/express/node_modules/qs/.editorconfig +46 -0
  487. package/dashboards/express/node_modules/qs/.github/FUNDING.yml +12 -0
  488. package/dashboards/express/node_modules/qs/.github/SECURITY.md +11 -0
  489. package/dashboards/express/node_modules/qs/.github/THREAT_MODEL.md +78 -0
  490. package/dashboards/express/node_modules/qs/.nycrc +13 -0
  491. package/dashboards/express/node_modules/qs/CHANGELOG.md +806 -0
  492. package/dashboards/express/node_modules/qs/LICENSE.md +29 -0
  493. package/dashboards/express/node_modules/qs/README.md +758 -0
  494. package/dashboards/express/node_modules/qs/dist/qs.js +141 -0
  495. package/dashboards/express/node_modules/qs/eslint.config.mjs +56 -0
  496. package/dashboards/express/node_modules/qs/lib/formats.js +23 -0
  497. package/dashboards/express/node_modules/qs/lib/index.js +11 -0
  498. package/dashboards/express/node_modules/qs/lib/parse.js +373 -0
  499. package/dashboards/express/node_modules/qs/lib/stringify.js +356 -0
  500. package/dashboards/express/node_modules/qs/lib/utils.js +342 -0
  501. package/dashboards/express/node_modules/qs/package.json +94 -0
  502. package/dashboards/express/node_modules/qs/test/empty-keys-cases.js +267 -0
  503. package/dashboards/express/node_modules/qs/test/parse.js +1568 -0
  504. package/dashboards/express/node_modules/qs/test/stringify.js +1310 -0
  505. package/dashboards/express/node_modules/qs/test/utils.js +404 -0
  506. package/dashboards/express/node_modules/random-bytes/HISTORY.md +4 -0
  507. package/dashboards/express/node_modules/random-bytes/LICENSE +21 -0
  508. package/dashboards/express/node_modules/random-bytes/README.md +77 -0
  509. package/dashboards/express/node_modules/random-bytes/index.js +101 -0
  510. package/dashboards/express/node_modules/random-bytes/package.json +36 -0
  511. package/dashboards/express/node_modules/range-parser/HISTORY.md +56 -0
  512. package/dashboards/express/node_modules/range-parser/LICENSE +23 -0
  513. package/dashboards/express/node_modules/range-parser/README.md +84 -0
  514. package/dashboards/express/node_modules/range-parser/index.js +162 -0
  515. package/dashboards/express/node_modules/range-parser/package.json +44 -0
  516. package/dashboards/express/node_modules/raw-body/LICENSE +22 -0
  517. package/dashboards/express/node_modules/raw-body/README.md +223 -0
  518. package/dashboards/express/node_modules/raw-body/index.d.ts +85 -0
  519. package/dashboards/express/node_modules/raw-body/index.js +336 -0
  520. package/dashboards/express/node_modules/raw-body/package.json +46 -0
  521. package/dashboards/express/node_modules/router/HISTORY.md +228 -0
  522. package/dashboards/express/node_modules/router/LICENSE +23 -0
  523. package/dashboards/express/node_modules/router/README.md +416 -0
  524. package/dashboards/express/node_modules/router/index.js +748 -0
  525. package/dashboards/express/node_modules/router/lib/layer.js +247 -0
  526. package/dashboards/express/node_modules/router/lib/route.js +242 -0
  527. package/dashboards/express/node_modules/router/package.json +44 -0
  528. package/dashboards/express/node_modules/safe-buffer/LICENSE +21 -0
  529. package/dashboards/express/node_modules/safe-buffer/README.md +584 -0
  530. package/dashboards/express/node_modules/safe-buffer/index.d.ts +187 -0
  531. package/dashboards/express/node_modules/safe-buffer/index.js +65 -0
  532. package/dashboards/express/node_modules/safe-buffer/package.json +51 -0
  533. package/dashboards/express/node_modules/safer-buffer/LICENSE +21 -0
  534. package/dashboards/express/node_modules/safer-buffer/Porting-Buffer.md +268 -0
  535. package/dashboards/express/node_modules/safer-buffer/Readme.md +156 -0
  536. package/dashboards/express/node_modules/safer-buffer/dangerous.js +58 -0
  537. package/dashboards/express/node_modules/safer-buffer/package.json +34 -0
  538. package/dashboards/express/node_modules/safer-buffer/safer.js +77 -0
  539. package/dashboards/express/node_modules/safer-buffer/tests.js +406 -0
  540. package/dashboards/express/node_modules/send/LICENSE +23 -0
  541. package/dashboards/express/node_modules/send/README.md +317 -0
  542. package/dashboards/express/node_modules/send/index.js +997 -0
  543. package/dashboards/express/node_modules/send/package.json +63 -0
  544. package/dashboards/express/node_modules/serve-static/LICENSE +25 -0
  545. package/dashboards/express/node_modules/serve-static/README.md +253 -0
  546. package/dashboards/express/node_modules/serve-static/index.js +208 -0
  547. package/dashboards/express/node_modules/serve-static/package.json +44 -0
  548. package/dashboards/express/node_modules/setprototypeof/LICENSE +13 -0
  549. package/dashboards/express/node_modules/setprototypeof/README.md +31 -0
  550. package/dashboards/express/node_modules/setprototypeof/index.d.ts +2 -0
  551. package/dashboards/express/node_modules/setprototypeof/index.js +17 -0
  552. package/dashboards/express/node_modules/setprototypeof/package.json +38 -0
  553. package/dashboards/express/node_modules/setprototypeof/test/index.js +24 -0
  554. package/dashboards/express/node_modules/side-channel/.editorconfig +9 -0
  555. package/dashboards/express/node_modules/side-channel/.eslintrc +12 -0
  556. package/dashboards/express/node_modules/side-channel/.github/FUNDING.yml +12 -0
  557. package/dashboards/express/node_modules/side-channel/.nycrc +13 -0
  558. package/dashboards/express/node_modules/side-channel/CHANGELOG.md +110 -0
  559. package/dashboards/express/node_modules/side-channel/LICENSE +21 -0
  560. package/dashboards/express/node_modules/side-channel/README.md +61 -0
  561. package/dashboards/express/node_modules/side-channel/index.d.ts +14 -0
  562. package/dashboards/express/node_modules/side-channel/index.js +43 -0
  563. package/dashboards/express/node_modules/side-channel/package.json +85 -0
  564. package/dashboards/express/node_modules/side-channel/test/index.js +104 -0
  565. package/dashboards/express/node_modules/side-channel/tsconfig.json +9 -0
  566. package/dashboards/express/node_modules/side-channel-list/.editorconfig +9 -0
  567. package/dashboards/express/node_modules/side-channel-list/.eslintrc +11 -0
  568. package/dashboards/express/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
  569. package/dashboards/express/node_modules/side-channel-list/.nycrc +13 -0
  570. package/dashboards/express/node_modules/side-channel-list/CHANGELOG.md +15 -0
  571. package/dashboards/express/node_modules/side-channel-list/LICENSE +21 -0
  572. package/dashboards/express/node_modules/side-channel-list/README.md +62 -0
  573. package/dashboards/express/node_modules/side-channel-list/index.d.ts +13 -0
  574. package/dashboards/express/node_modules/side-channel-list/index.js +113 -0
  575. package/dashboards/express/node_modules/side-channel-list/list.d.ts +14 -0
  576. package/dashboards/express/node_modules/side-channel-list/package.json +77 -0
  577. package/dashboards/express/node_modules/side-channel-list/test/index.js +104 -0
  578. package/dashboards/express/node_modules/side-channel-list/tsconfig.json +9 -0
  579. package/dashboards/express/node_modules/side-channel-map/.editorconfig +9 -0
  580. package/dashboards/express/node_modules/side-channel-map/.eslintrc +11 -0
  581. package/dashboards/express/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
  582. package/dashboards/express/node_modules/side-channel-map/.nycrc +13 -0
  583. package/dashboards/express/node_modules/side-channel-map/CHANGELOG.md +22 -0
  584. package/dashboards/express/node_modules/side-channel-map/LICENSE +21 -0
  585. package/dashboards/express/node_modules/side-channel-map/README.md +62 -0
  586. package/dashboards/express/node_modules/side-channel-map/index.d.ts +15 -0
  587. package/dashboards/express/node_modules/side-channel-map/index.js +68 -0
  588. package/dashboards/express/node_modules/side-channel-map/package.json +80 -0
  589. package/dashboards/express/node_modules/side-channel-map/test/index.js +114 -0
  590. package/dashboards/express/node_modules/side-channel-map/tsconfig.json +9 -0
  591. package/dashboards/express/node_modules/side-channel-weakmap/.editorconfig +9 -0
  592. package/dashboards/express/node_modules/side-channel-weakmap/.eslintrc +12 -0
  593. package/dashboards/express/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
  594. package/dashboards/express/node_modules/side-channel-weakmap/.nycrc +13 -0
  595. package/dashboards/express/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
  596. package/dashboards/express/node_modules/side-channel-weakmap/LICENSE +21 -0
  597. package/dashboards/express/node_modules/side-channel-weakmap/README.md +62 -0
  598. package/dashboards/express/node_modules/side-channel-weakmap/index.d.ts +15 -0
  599. package/dashboards/express/node_modules/side-channel-weakmap/index.js +84 -0
  600. package/dashboards/express/node_modules/side-channel-weakmap/package.json +87 -0
  601. package/dashboards/express/node_modules/side-channel-weakmap/test/index.js +114 -0
  602. package/dashboards/express/node_modules/side-channel-weakmap/tsconfig.json +9 -0
  603. package/dashboards/express/node_modules/statuses/HISTORY.md +87 -0
  604. package/dashboards/express/node_modules/statuses/LICENSE +23 -0
  605. package/dashboards/express/node_modules/statuses/README.md +139 -0
  606. package/dashboards/express/node_modules/statuses/codes.json +65 -0
  607. package/dashboards/express/node_modules/statuses/index.js +146 -0
  608. package/dashboards/express/node_modules/statuses/package.json +49 -0
  609. package/dashboards/express/node_modules/toidentifier/HISTORY.md +9 -0
  610. package/dashboards/express/node_modules/toidentifier/LICENSE +21 -0
  611. package/dashboards/express/node_modules/toidentifier/README.md +61 -0
  612. package/dashboards/express/node_modules/toidentifier/index.js +32 -0
  613. package/dashboards/express/node_modules/toidentifier/package.json +38 -0
  614. package/dashboards/express/node_modules/type-is/HISTORY.md +292 -0
  615. package/dashboards/express/node_modules/type-is/LICENSE +23 -0
  616. package/dashboards/express/node_modules/type-is/README.md +198 -0
  617. package/dashboards/express/node_modules/type-is/index.js +250 -0
  618. package/dashboards/express/node_modules/type-is/package.json +47 -0
  619. package/dashboards/express/node_modules/uid-safe/HISTORY.md +61 -0
  620. package/dashboards/express/node_modules/uid-safe/LICENSE +22 -0
  621. package/dashboards/express/node_modules/uid-safe/README.md +77 -0
  622. package/dashboards/express/node_modules/uid-safe/index.js +107 -0
  623. package/dashboards/express/node_modules/uid-safe/package.json +46 -0
  624. package/dashboards/express/node_modules/unpipe/HISTORY.md +4 -0
  625. package/dashboards/express/node_modules/unpipe/LICENSE +22 -0
  626. package/dashboards/express/node_modules/unpipe/README.md +43 -0
  627. package/dashboards/express/node_modules/unpipe/index.js +69 -0
  628. package/dashboards/express/node_modules/unpipe/package.json +27 -0
  629. package/dashboards/express/node_modules/vary/HISTORY.md +39 -0
  630. package/dashboards/express/node_modules/vary/LICENSE +22 -0
  631. package/dashboards/express/node_modules/vary/README.md +101 -0
  632. package/dashboards/express/node_modules/vary/index.js +149 -0
  633. package/dashboards/express/node_modules/vary/package.json +43 -0
  634. package/dashboards/express/node_modules/wrappy/LICENSE +15 -0
  635. package/dashboards/express/node_modules/wrappy/README.md +36 -0
  636. package/dashboards/express/node_modules/wrappy/package.json +29 -0
  637. package/dashboards/express/node_modules/wrappy/wrappy.js +33 -0
  638. package/package.json +1 -1
  639. package/CLAUDE.md +0 -40
  640. package/live-test.mjs +0 -165
  641. package/serve.mjs +0 -29
  642. package/start-live.mjs +0 -48
  643. package/test-integration.mjs +0 -754
@@ -1,754 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * AgenticMail Enterprise — Integration Test Suite
4
- *
5
- * Tests all major flows end-to-end with SQLite.
6
- */
7
-
8
- import { rmSync } from 'fs';
9
-
10
- const TEST_DB = './test-enterprise.db';
11
- const PORT = 3199;
12
- const BASE = `http://localhost:${PORT}`;
13
-
14
- let passed = 0;
15
- let failed = 0;
16
- let serverHandle = null;
17
-
18
- function assert(condition, name) {
19
- try {
20
- if (condition) {
21
- passed++;
22
- console.log(` ✅ ${name}`);
23
- } else {
24
- failed++;
25
- console.error(` ❌ ${name}`);
26
- }
27
- } catch (e) {
28
- failed++;
29
- console.error(` ❌ ${name} — threw: ${e.message}`);
30
- }
31
- }
32
-
33
- async function test(name, fn) {
34
- try {
35
- await fn();
36
- } catch (e) {
37
- failed++;
38
- console.error(` ❌ ${name} — threw: ${e.message}`);
39
- }
40
- }
41
-
42
- async function section(label, fn) {
43
- console.log(`─── ${label} ───`);
44
- try {
45
- await fn();
46
- } catch (e) {
47
- failed++;
48
- console.error(` 💥 SECTION CRASHED: ${e.message}`);
49
- console.error(` ${e.stack?.split('\n').slice(1, 3).join('\n ') || ''}`);
50
- }
51
- console.log('');
52
- }
53
-
54
- async function req(path, opts = {}) {
55
- const url = path.startsWith('http') ? path : `${BASE}${path}`;
56
- const res = await fetch(url, {
57
- headers: { 'Content-Type': 'application/json', ...opts.headers },
58
- ...opts,
59
- });
60
- const data = await res.json().catch(() => ({}));
61
- return { status: res.status, data, headers: res.headers };
62
- }
63
-
64
- // Cleanup
65
- for (const f of [TEST_DB, TEST_DB + '-shm', TEST_DB + '-wal']) {
66
- try { rmSync(f); } catch {}
67
- }
68
-
69
- console.log('\n🏢 AgenticMail Enterprise — Integration Tests\n');
70
-
71
- // ═══════════════════════════════════════════════════════
72
- // 1. DATABASE ADAPTER
73
- // ═══════════════════════════════════════════════════════
74
-
75
- // Shared state: these must be accessible to later sections
76
- const { createAdapter, getSupportedDatabases } = await import('./dist/index.js');
77
- let db = null;
78
- let user = null;
79
-
80
- db = await createAdapter({ type: 'sqlite', connectionString: TEST_DB });
81
- await db.migrate();
82
- user = await db.createUser({ email: 'admin@test.com', name: 'Admin', role: 'owner', password: 'TestPass123!' });
83
-
84
- await section('1. Database Adapter (SQLite)', async () => {
85
- await test('getSupportedDatabases()', async () => {
86
- const databases = getSupportedDatabases();
87
- assert(databases.length >= 6, `getSupportedDatabases() → ${databases.length} backends`);
88
- assert(databases.some(d => d.type === 'sqlite'), 'SQLite in list');
89
- assert(databases.some(d => d.type === 'postgres'), 'Postgres in list');
90
- assert(databases.some(d => d.type === 'mongodb'), 'MongoDB in list');
91
- assert(databases.some(d => d.type === 'dynamodb'), 'DynamoDB in list');
92
- });
93
-
94
- await test('SQLite adapter created + migrated', async () => {
95
- assert(true, 'SQLite adapter created + migrated');
96
- });
97
-
98
- await test('getStats()', async () => {
99
- const stats = await db.getStats();
100
- assert(typeof stats === 'object', 'getStats() returns object');
101
- });
102
-
103
- await test('Users', async () => {
104
- assert(user.id && user.email === 'admin@test.com', `createUser() → ${user.id}`);
105
- assert(await db.getUserByEmail('admin@test.com'), 'getUserByEmail() works');
106
- });
107
-
108
- await test('Agents CRUD', async () => {
109
- const agent = await db.createAgent({ name: 'test-agent', email: 'test@localhost', role: 'assistant', status: 'active', createdBy: user.id });
110
- assert(agent.id, `createAgent() → ${agent.id}`);
111
- assert((await db.listAgents()).length >= 1, 'listAgents() returns agents');
112
- assert((await db.getAgent(agent.id))?.name === 'test-agent', 'getAgent() by id');
113
- assert((await db.updateAgent(agent.id, { status: 'suspended' })).status === 'suspended', 'updateAgent()');
114
- await db.deleteAgent(agent.id);
115
- assert(!(await db.getAgent(agent.id)), 'deleteAgent() works');
116
- });
117
-
118
- await test('API Keys', async () => {
119
- const keyResult = await db.createApiKey({ name: 'k1', createdBy: user.id, scopes: ['read', 'write'] });
120
- assert(keyResult.plaintext?.startsWith('ek_'), `createApiKey() → ${keyResult.plaintext?.slice(0, 12)}...`);
121
- assert(await db.validateApiKey(keyResult.plaintext), 'validateApiKey() valid');
122
- assert(!(await db.validateApiKey('ek_bogus')), 'validateApiKey() rejects bogus');
123
- await db.revokeApiKey(keyResult.key.id);
124
- assert(!(await db.validateApiKey(keyResult.plaintext)), 'revokeApiKey() works');
125
- });
126
-
127
- await test('Audit', async () => {
128
- await db.logEvent({ actor: user.id, actorType: 'user', action: 'test', resource: 'test:1', details: {} });
129
- const audit = await db.queryAudit({});
130
- assert(audit.events.length >= 1, `queryAudit() → ${audit.events.length} events`);
131
- });
132
-
133
- await test('Settings', async () => {
134
- const settings = await db.getSettings();
135
- assert(settings?.name, 'getSettings() returns default settings');
136
- await db.updateSettings({ name: 'Test Corp', subdomain: 'test-corp' });
137
- assert((await db.getSettings()).name === 'Test Corp', 'updateSettings() persists');
138
- });
139
- });
140
-
141
- // ═══════════════════════════════════════════════════════
142
- // 2. SERVER + AUTH
143
- // ═══════════════════════════════════════════════════════
144
-
145
- // Shared state: these must be accessible to later sections
146
- const { createServer } = await import('./dist/index.js');
147
- const jwtSecret = 'test-jwt-secret-1234567890-abcdef';
148
-
149
- await db.createAgent({ name: 'srv-agent', email: 'srv@localhost', role: 'assistant', status: 'active', createdBy: user.id });
150
- const srvKey = await db.createApiKey({ name: 'srv-key', createdBy: user.id, scopes: ['read', 'write'] });
151
-
152
- const server = createServer({ port: PORT, db, jwtSecret, logging: false, rateLimit: 1000 });
153
- serverHandle = await server.start();
154
- await new Promise(r => setTimeout(r, 500));
155
-
156
- let jwt = null;
157
- let auth = {};
158
-
159
- // Login must succeed before later sections, so do it outside section
160
- const login = await req('/auth/login', {
161
- method: 'POST',
162
- body: JSON.stringify({ email: 'admin@test.com', password: 'TestPass123!' }),
163
- });
164
- jwt = login.data.token;
165
- auth = { Authorization: `Bearer ${jwt}` };
166
-
167
- await section('2. Server + Auth', async () => {
168
- await test('createServer()', async () => {
169
- assert(server.app && server.start, 'createServer() returns app + start');
170
- assert(true, `Server started on :${PORT}`);
171
- });
172
-
173
- await test('Health endpoints', async () => {
174
- assert((await req('/health')).status === 200, 'GET /health → 200');
175
- const ready = await req('/ready');
176
- assert(ready.status === 200 || ready.status === 503, `GET /ready → ${ready.status}`);
177
- });
178
-
179
- await test('404', async () => {
180
- assert((await req('/nope')).status === 404, 'GET /nope → 404');
181
- });
182
-
183
- await test('Login', async () => {
184
- assert(login.status === 200 && login.data.token, 'POST /auth/login → JWT');
185
- });
186
-
187
- await test('Bad login', async () => {
188
- assert((await req('/auth/login', {
189
- method: 'POST',
190
- body: JSON.stringify({ email: 'admin@test.com', password: 'wrong' }),
191
- })).status === 401, 'Bad password → 401');
192
- });
193
-
194
- await test('No auth', async () => {
195
- assert((await req('/api/stats')).status === 401, 'No auth → 401');
196
- });
197
- });
198
-
199
- await section('3. Admin Routes', async () => {
200
- await test('GET /api/stats', async () => {
201
- assert((await req('/api/stats', { headers: auth })).status === 200, 'GET /api/stats → 200');
202
- });
203
-
204
- await test('GET /api/agents', async () => {
205
- const agentsRes = await req('/api/agents', { headers: auth });
206
- assert(agentsRes.status === 200 && agentsRes.data.agents, `GET /api/agents → ${agentsRes.data.agents?.length} agents`);
207
- });
208
-
209
- await test('Agent CRUD (create → get → update → delete)', async () => {
210
- const createRes = await req('/api/agents', {
211
- method: 'POST', headers: auth,
212
- body: JSON.stringify({ name: 'api-agent', email: 'api-agent@test.com', role: 'researcher' }),
213
- });
214
- assert(createRes.status === 201, `POST /api/agents → ${createRes.status}`);
215
-
216
- if (createRes.data?.id) {
217
- assert((await req(`/api/agents/${createRes.data.id}`, { headers: auth })).status === 200, 'GET /api/agents/:id → 200');
218
- assert((await req(`/api/agents/${createRes.data.id}`, {
219
- method: 'PATCH', headers: auth,
220
- body: JSON.stringify({ status: 'suspended' }),
221
- })).status === 200, 'PATCH /api/agents/:id → 200');
222
- assert((await req(`/api/agents/${createRes.data.id}`, {
223
- method: 'DELETE', headers: auth,
224
- })).status === 200 || true, 'DELETE /api/agents/:id');
225
- }
226
- });
227
-
228
- await test('GET /api/users', async () => {
229
- assert((await req('/api/users', { headers: auth })).status === 200, 'GET /api/users → 200');
230
- });
231
-
232
- await test('GET /api/audit', async () => {
233
- assert((await req('/api/audit', { headers: auth })).status === 200, 'GET /api/audit → 200');
234
- });
235
-
236
- await test('Settings GET + PATCH', async () => {
237
- assert((await req('/api/settings', { headers: auth })).status === 200, 'GET /api/settings → 200');
238
- const patchSettings = await req('/api/settings', {
239
- method: 'PATCH', headers: auth,
240
- body: JSON.stringify({ name: 'Updated Corp' }),
241
- });
242
- assert(patchSettings.status === 200, `PATCH /api/settings → ${patchSettings.status}`);
243
- });
244
-
245
- await test('API key auth', async () => {
246
- assert((await req('/api/stats', { headers: { 'X-API-Key': srvKey.plaintext } })).status === 200, 'API key auth → 200');
247
- assert((await req('/api/stats', { headers: { 'X-API-Key': 'ek_invalid' } })).status === 401, 'Bad API key → 401');
248
- });
249
- });
250
-
251
- await section('4. Engine Routes', async () => {
252
- await test('Skills', async () => {
253
- const skillsRes = await req('/api/engine/skills', { headers: auth });
254
- assert(skillsRes.status === 200, `GET /engine/skills → ${skillsRes.status}`);
255
- const skillsArr = skillsRes.data?.skills || skillsRes.data;
256
- assert(Array.isArray(skillsArr) && skillsArr.length >= 30, `Skills count: ${skillsArr?.length}`);
257
-
258
- if (skillsArr?.length) {
259
- const s = skillsArr[0];
260
- const singleSkill = await req(`/api/engine/skills/${s.id}`, { headers: auth });
261
- assert(singleSkill.status === 200, `GET /engine/skills/:id → ${singleSkill.status}`);
262
- }
263
- });
264
-
265
- await test('Presets', async () => {
266
- const presetsRes = await req('/api/engine/profiles/presets', { headers: auth });
267
- assert(presetsRes.status === 200, `GET /engine/profiles/presets → ${presetsRes.status}`);
268
- const presetsArr = presetsRes.data?.presets || presetsRes.data;
269
- assert(Array.isArray(presetsArr) && presetsArr.length >= 5, `Presets count: ${presetsArr?.length}`);
270
- });
271
-
272
- await test('Permission check', async () => {
273
- const permRes = await req('/api/engine/permissions/check', {
274
- method: 'POST', headers: auth,
275
- body: JSON.stringify({ agentId: 'test', tool: 'web_search' }),
276
- });
277
- assert(permRes.status === 200, `POST /engine/permissions/check → ${permRes.status}`);
278
- });
279
- });
280
-
281
- await section('5. Middleware', async () => {
282
- await test('Security headers', async () => {
283
- const hRes = await req('/health');
284
- assert(hRes.headers.get('x-request-id'), 'X-Request-Id present');
285
- assert(hRes.headers.get('x-content-type-options') === 'nosniff', 'X-Content-Type-Options: nosniff');
286
- assert(hRes.headers.get('x-frame-options') === 'DENY', 'X-Frame-Options: DENY');
287
- });
288
-
289
- await test('CORS preflight', async () => {
290
- const corsRes = await fetch(`${BASE}/health`, {
291
- method: 'OPTIONS',
292
- headers: { Origin: 'https://test.com', 'Access-Control-Request-Method': 'GET' },
293
- });
294
- assert(corsRes.status === 204 || corsRes.status === 200, 'CORS preflight OK');
295
- });
296
- });
297
-
298
- const mod = await import('./dist/index.js');
299
-
300
- await section('6. Exports', async () => {
301
- await test('Expected exports present', async () => {
302
- const expectedExports = [
303
- 'createAdapter', 'createServer', 'getSupportedDatabases',
304
- 'PermissionEngine', 'AgentConfigGenerator', 'DeploymentEngine',
305
- 'ApprovalEngine', 'AgentLifecycleManager', 'KnowledgeBaseEngine',
306
- 'TenantManager', 'ActivityTracker', 'EngineDatabase',
307
- 'CircuitBreaker', 'HealthMonitor', 'withRetry', 'RateLimiter',
308
- 'generateDockerCompose', 'generateFlyToml',
309
- 'BUILTIN_SKILLS', 'PRESET_PROFILES', 'ALL_TOOLS',
310
- 'getToolsBySkill', 'generateToolPolicy',
311
- 'AgentRuntime', 'createAgentRuntime',
312
- ];
313
- for (const name of expectedExports) {
314
- assert(mod[name] !== undefined, `export: ${name}`);
315
- }
316
- });
317
-
318
- await test('Deploy generators', async () => {
319
- assert(mod.generateDockerCompose({ dbType: 'postgres', dbConnectionString: 'x', port: 3000, jwtSecret: 'x' }).includes('agenticmail'), 'DockerCompose output');
320
- assert(mod.generateFlyToml('test', 'iad').includes('test'), 'FlyToml output');
321
- });
322
- });
323
-
324
- await section('7. Resilience', async () => {
325
- await test('CircuitBreaker', async () => {
326
- const { CircuitBreaker } = mod;
327
- const cb = new CircuitBreaker({ failureThreshold: 3, recoveryTimeMs: 100, timeout: 5000 });
328
- assert(await cb.execute(() => Promise.resolve('ok')) === 'ok', 'CircuitBreaker success');
329
- assert(cb.getState() === 'closed', 'CircuitBreaker state: closed');
330
-
331
- for (let i = 0; i < 4; i++) await cb.execute(() => Promise.reject(new Error('x'))).catch(() => {});
332
- try {
333
- await cb.execute(() => Promise.resolve('nope'));
334
- assert(false, 'Should be open');
335
- } catch {
336
- assert(cb.getState() === 'open', 'CircuitBreaker opens after failures');
337
- }
338
- });
339
-
340
- await test('withRetry', async () => {
341
- const { withRetry } = mod;
342
- let attempts = 0;
343
- const retryVal = await withRetry(async () => { attempts++; if (attempts < 3) throw new Error('x'); return 'done'; }, { maxRetries: 5, baseDelayMs: 5 });
344
- assert(retryVal === 'done' && attempts === 3, `withRetry() → ${attempts} attempts`);
345
- });
346
-
347
- await test('RateLimiter', async () => {
348
- const { RateLimiter } = mod;
349
- const rl = new RateLimiter({ maxTokens: 3, refillRate: 1, refillIntervalMs: 60000 });
350
- const t1 = rl.tryConsume();
351
- const t2 = rl.tryConsume();
352
- const t3 = rl.tryConsume();
353
- const t4 = rl.tryConsume();
354
- assert(t1 && t2 && t3, 'RateLimiter allows 3 tokens');
355
- assert(!t4, 'RateLimiter blocks 4th token');
356
- });
357
- });
358
-
359
- await section('8. Engine Classes', async () => {
360
- await test('BUILTIN_SKILLS + PRESET_PROFILES', async () => {
361
- assert(mod.BUILTIN_SKILLS.length >= 38, `BUILTIN_SKILLS: ${mod.BUILTIN_SKILLS.length}`);
362
- assert(mod.PRESET_PROFILES.length >= 5, `PRESET_PROFILES: ${mod.PRESET_PROFILES.length}`);
363
- });
364
-
365
- await test('Tool catalog', async () => {
366
- assert(mod.ALL_TOOLS.length > 50, `ALL_TOOLS: ${mod.ALL_TOOLS.length}`);
367
- const toolMap = mod.getToolsBySkill();
368
- assert(toolMap instanceof Map && toolMap.size > 0, `getToolsBySkill() → Map with ${toolMap.size} skills`);
369
- const emailToolIds = toolMap.get('agenticmail') || [];
370
- assert(emailToolIds.length > 0, `agenticmail tools: ${emailToolIds.length}`);
371
- const policy = mod.generateToolPolicy(emailToolIds, []);
372
- assert(policy, 'generateToolPolicy() returns policy');
373
- });
374
-
375
- await test('AgentConfigGenerator', async () => {
376
- const cg = new mod.AgentConfigGenerator();
377
- const workspace = cg.generateWorkspace({
378
- id: 'test-1', name: 'test-bot', displayName: 'Test Bot',
379
- identity: { personality: 'Helpful assistant', role: 'Tester', tone: 'professional', language: 'en' },
380
- model: { provider: 'anthropic', modelId: 'claude-sonnet-4-20250514', thinkingLevel: 'low' },
381
- channels: { enabled: [], primaryChannel: 'email' },
382
- email: { enabled: false, provider: 'none' },
383
- workspace: { persistentMemory: true, memoryMaxSizeMb: 10, workingDirectory: '/tmp', sharedDirectories: [], gitEnabled: false },
384
- heartbeat: { enabled: false, intervalMinutes: 30, checks: [] },
385
- context: {},
386
- permissionProfileId: 'research-assistant',
387
- deployment: { target: 'docker', config: {}, status: 'pending' },
388
- createdAt: new Date().toISOString(), updatedAt: new Date().toISOString(),
389
- });
390
- assert(workspace && workspace['SOUL.md'] && workspace['AGENTS.md'], 'AgentConfigGenerator.generateWorkspace() produces files');
391
- });
392
- });
393
-
394
- await section('9. Dashboard', async () => {
395
- await test('GET /dashboard', async () => {
396
- const dashRes = await fetch(`${BASE}/dashboard`);
397
- assert(dashRes.status === 200, 'GET /dashboard → 200');
398
- const html = await dashRes.text();
399
- assert(html.includes('AgenticMail') || html.includes('React'), 'Dashboard HTML valid');
400
- });
401
-
402
- await test('GET / redirects', async () => {
403
- const rootRes = await fetch(`${BASE}/`, { redirect: 'manual' });
404
- assert(rootRes.status === 301 || rootRes.status === 302, `GET / redirects (${rootRes.status})`);
405
- });
406
- });
407
-
408
- await section('10. Soul Library', async () => {
409
- await test('GET /engine/souls', async () => {
410
- const soulsRes = await req('/api/engine/souls', { headers: auth });
411
- assert(soulsRes.status === 200, 'GET /engine/souls → 200');
412
- assert(soulsRes.data.templates?.length >= 50, `Soul templates: ${soulsRes.data.templates?.length} (≥50)`);
413
- assert(soulsRes.data.total >= 50, `Soul total count: ${soulsRes.data.total}`);
414
- });
415
-
416
- await test('GET /engine/souls/by-category', async () => {
417
- const soulsCatRes = await req('/api/engine/souls/by-category', { headers: auth });
418
- assert(soulsCatRes.status === 200, 'GET /engine/souls/by-category → 200');
419
- assert(Object.keys(soulsCatRes.data.categories || {}).length >= 10, `Soul categories: ${Object.keys(soulsCatRes.data.categories || {}).length}`);
420
- assert(soulsCatRes.data.categoryMeta?.support?.name === 'Support', 'Category meta: support');
421
- });
422
-
423
- await test('GET /engine/souls/search', async () => {
424
- const soulSearchRes = await req('/api/engine/souls/search?q=engineer', { headers: auth });
425
- assert(soulSearchRes.status === 200, 'GET /engine/souls/search?q=engineer → 200');
426
- assert(soulSearchRes.data.templates?.length > 0, `Soul search results: ${soulSearchRes.data.templates?.length}`);
427
- });
428
-
429
- await test('GET /engine/souls/:id', async () => {
430
- const soulByIdRes = await req('/api/engine/souls/customer-support-lead', { headers: auth });
431
- assert(soulByIdRes.status === 200, 'GET /engine/souls/:id → 200');
432
- assert(soulByIdRes.data.template?.name === 'Customer Support Lead', 'Soul template name matches');
433
- assert(soulByIdRes.data.template?.personality?.length > 50, 'Soul personality has content');
434
- });
435
-
436
- await test('GET /engine/souls/nonexistent → 404', async () => {
437
- const soulNotFound = await req('/api/engine/souls/nonexistent', { headers: auth });
438
- assert(soulNotFound.status === 404, 'GET /engine/souls/nonexistent → 404');
439
- });
440
- });
441
-
442
- await section('11. DLP', async () => {
443
- let ruleId = null;
444
-
445
- await test('DLP rule CRUD', async () => {
446
- const dlpRule = await req('/api/engine/dlp/rules', {
447
- method: 'POST', headers: auth,
448
- body: JSON.stringify({ orgId: 'default', name: 'SSN Detection', patternType: 'regex', pattern: '\\d{3}-\\d{2}-\\d{4}', action: 'block', appliesTo: 'both', severity: 'critical', enabled: true }),
449
- });
450
- assert(dlpRule.status === 201, 'POST /engine/dlp/rules → 201');
451
- ruleId = dlpRule.data.rule?.id;
452
-
453
- const dlpRules = await req('/api/engine/dlp/rules?orgId=default', { headers: auth });
454
- assert(dlpRules.status === 200, 'GET /engine/dlp/rules → 200');
455
- assert(dlpRules.data.rules?.length >= 1, `DLP rules: ${dlpRules.data.rules?.length}`);
456
-
457
- const dlpRuleGet = await req(`/api/engine/dlp/rules/${ruleId}`, { headers: auth });
458
- assert(dlpRuleGet.status === 200, 'GET /engine/dlp/rules/:id → 200');
459
- });
460
-
461
- await test('DLP scan', async () => {
462
- const dlpScan = await req('/api/engine/dlp/scan', {
463
- method: 'POST', headers: auth,
464
- body: JSON.stringify({ orgId: 'default', content: 'My SSN is 123-45-6789' }),
465
- });
466
- assert(dlpScan.status === 200, 'POST /engine/dlp/scan → 200');
467
-
468
- const dlpScanParams = await req('/api/engine/dlp/scan-parameters', {
469
- method: 'POST', headers: auth,
470
- body: JSON.stringify({ orgId: 'default', agentId: 'test', toolId: 'email.send', parameters: { body: 'No sensitive data here' } }),
471
- });
472
- assert(dlpScanParams.status === 200, 'POST /engine/dlp/scan-parameters → 200');
473
- });
474
-
475
- await test('DLP violations + cleanup', async () => {
476
- const dlpViolations = await req('/api/engine/dlp/violations', { headers: auth });
477
- assert(dlpViolations.status === 200, 'GET /engine/dlp/violations → 200');
478
-
479
- const dlpDel = await req(`/api/engine/dlp/rules/${ruleId}`, { method: 'DELETE', headers: auth });
480
- assert(dlpDel.status === 200, 'DELETE /engine/dlp/rules/:id → 200');
481
- });
482
- });
483
-
484
- await section('12. Guardrails', async () => {
485
- let grAgentId = null;
486
-
487
- await test('Guardrail pause/resume lifecycle', async () => {
488
- const grAgent = await req('/api/engine/agents', {
489
- method: 'POST', headers: auth,
490
- body: JSON.stringify({
491
- orgId: 'default',
492
- config: { name: 'guardrail-test', displayName: 'Guardrail Test', identity: { role: 'tester' }, model: { provider: 'test', modelId: 'test' }, deployment: { target: 'docker', config: {} } },
493
- createdBy: 'test',
494
- }),
495
- });
496
- grAgentId = grAgent.data.agent?.id;
497
-
498
- const pauseRes = await req(`/api/engine/guardrails/pause/${grAgentId}`, {
499
- method: 'POST', headers: auth,
500
- body: JSON.stringify({ reason: 'Routine maintenance' }),
501
- });
502
- assert(pauseRes.status === 200, 'POST /engine/guardrails/pause/:id → 200');
503
- assert(pauseRes.data.intervention != null, 'Pause returns intervention record');
504
-
505
- const grStatus = await req(`/api/engine/guardrails/status/${grAgentId}`, { headers: auth });
506
- assert(grStatus.status === 200, 'GET /engine/guardrails/status/:id → 200');
507
-
508
- const resumeRes = await req(`/api/engine/guardrails/resume/${grAgentId}`, {
509
- method: 'POST', headers: auth,
510
- body: JSON.stringify({ reason: 'Maintenance complete' }),
511
- });
512
- assert(resumeRes.status === 200, 'POST /engine/guardrails/resume/:id → 200');
513
-
514
- const interventions = await req('/api/engine/guardrails/interventions', { headers: auth });
515
- assert(interventions.status === 200, 'GET /engine/guardrails/interventions → 200');
516
- assert(interventions.data.interventions?.length >= 2, `Interventions: ${interventions.data.interventions?.length} (pause + resume)`);
517
- });
518
-
519
- await test('Anomaly rules CRUD', async () => {
520
- const anomalyRule = await req('/api/engine/anomaly-rules', {
521
- method: 'POST', headers: auth,
522
- body: JSON.stringify({ orgId: 'default', name: 'High error rate', ruleType: 'error_rate', config: { maxErrorsPerHour: 50, windowMinutes: 5 }, action: 'pause', enabled: true }),
523
- });
524
- assert(anomalyRule.status === 201, 'POST /engine/anomaly-rules → 201');
525
-
526
- const anomalyRules = await req('/api/engine/anomaly-rules', { headers: auth });
527
- assert(anomalyRules.status === 200, 'GET /engine/anomaly-rules → 200');
528
- assert(anomalyRules.data.rules?.length >= 1, `Anomaly rules: ${anomalyRules.data.rules?.length}`);
529
-
530
- const anomDel = await req(`/api/engine/anomaly-rules/${anomalyRule.data.rule?.id}`, { method: 'DELETE', headers: auth });
531
- assert(anomDel.status === 200, 'DELETE /engine/anomaly-rules/:id → 200');
532
- });
533
-
534
- // Clean up test agent
535
- if (grAgentId) await req(`/api/engine/agents/${grAgentId}`, { method: 'DELETE', headers: auth, body: JSON.stringify({ destroyedBy: 'test' }) });
536
- });
537
-
538
- await section('13. Journal', async () => {
539
- let entryId = null;
540
-
541
- await test('Journal record + list + get', async () => {
542
- const journalEntry = await req('/api/engine/journal/record', {
543
- method: 'POST', headers: auth,
544
- body: JSON.stringify({ orgId: 'default', agentId: 'test-agent', toolId: 'agenticmail_send', toolName: 'Send Email', parameters: { to: 'user@test.com', subject: 'Test' }, result: { messageId: 'msg-1' } }),
545
- });
546
- assert(journalEntry.status === 201, 'POST /engine/journal/record → 201');
547
- entryId = journalEntry.data.entry?.id;
548
-
549
- const journalList = await req('/api/engine/journal?orgId=default', { headers: auth });
550
- assert(journalList.status === 200, 'GET /engine/journal → 200');
551
- assert(journalList.data.entries?.length >= 1, `Journal entries: ${journalList.data.entries?.length}`);
552
-
553
- const journalGet = await req(`/api/engine/journal/${entryId}`, { headers: auth });
554
- assert(journalGet.status === 200, 'GET /engine/journal/:id → 200');
555
- });
556
-
557
- await test('Journal stats + rollback', async () => {
558
- const journalStats = await req('/api/engine/journal/stats/default', { headers: auth });
559
- assert(journalStats.status === 200, 'GET /engine/journal/stats/:orgId → 200');
560
-
561
- const rollbackRes = await req(`/api/engine/journal/${entryId}/rollback`, {
562
- method: 'POST', headers: auth,
563
- body: JSON.stringify({ rolledBackBy: 'admin' }),
564
- });
565
- assert(rollbackRes.status === 200, 'POST /engine/journal/:id/rollback → 200');
566
- });
567
-
568
- await test('Journal validation', async () => {
569
- const journalBad = await req('/api/engine/journal/record', {
570
- method: 'POST', headers: auth,
571
- body: JSON.stringify({ orgId: 'default' }),
572
- });
573
- assert(journalBad.status === 400, 'POST /engine/journal/record (missing fields) → 400');
574
- });
575
- });
576
-
577
- await section('14. Communication Bus', async () => {
578
- let msgId = null;
579
- let taskId = null;
580
-
581
- await test('Send a message', async () => {
582
- const msgRes = await req('/api/engine/messages', {
583
- method: 'POST',
584
- headers: auth,
585
- body: JSON.stringify({ orgId: 'default', fromAgentId: 'agent-a', toAgentId: 'agent-b', subject: 'Test message', content: 'Hello from A', priority: 'normal' }),
586
- });
587
- assert(msgRes.status === 201, 'POST /engine/messages → 201');
588
- msgId = msgRes.data.message?.id;
589
- });
590
-
591
- await test('List messages', async () => {
592
- const msgList = await req('/api/engine/messages?orgId=default', { headers: auth });
593
- assert(msgList.status === 200, 'GET /engine/messages → 200');
594
- assert(msgList.data.messages?.length >= 1, `Messages: ${msgList.data.messages?.length}`);
595
- });
596
-
597
- await test('Get single message', async () => {
598
- const msgGet = await req(`/api/engine/messages/${msgId}`, { headers: auth });
599
- assert(msgGet.status === 200, 'GET /engine/messages/:id → 200');
600
- });
601
-
602
- await test('Mark as read', async () => {
603
- const msgRead = await req(`/api/engine/messages/${msgId}/read`, { method: 'POST', headers: auth });
604
- assert(msgRead.status === 200, 'POST /engine/messages/:id/read → 200');
605
- });
606
-
607
- await test('Get topology', async () => {
608
- const topologyRes = await req('/api/engine/messages/topology?orgId=default', { headers: auth });
609
- assert(topologyRes.status === 200, 'GET /engine/messages/topology → 200');
610
- assert(topologyRes.data.topology != null, 'Topology data present');
611
- });
612
-
613
- await test('Inbox', async () => {
614
- const inboxRes = await req('/api/engine/messages/inbox/agent-b', { headers: auth });
615
- assert(inboxRes.status === 200, 'GET /engine/messages/inbox/:agentId → 200');
616
- assert(inboxRes.data.messages?.length >= 1, 'Inbox has messages');
617
- });
618
-
619
- await test('Broadcast', async () => {
620
- const broadRes = await req('/api/engine/messages/broadcast', {
621
- method: 'POST',
622
- headers: auth,
623
- body: JSON.stringify({ orgId: 'default', fromAgentId: 'agent-a', agentIds: ['agent-b', 'agent-c'], subject: 'Broadcast', content: 'Hello all' }),
624
- });
625
- assert(broadRes.status === 200, 'POST /engine/messages/broadcast → 200');
626
- assert(broadRes.data.messages?.length === 2, 'Broadcast sent to 2 agents');
627
- });
628
-
629
- await test('Delegate task', async () => {
630
- const taskRes = await req('/api/engine/tasks/delegate', {
631
- method: 'POST',
632
- headers: auth,
633
- body: JSON.stringify({ orgId: 'default', fromAgentId: 'agent-a', toAgentId: 'agent-b', subject: 'Research task', content: 'Do research' }),
634
- });
635
- assert(taskRes.status === 201, 'POST /engine/tasks/delegate → 201');
636
- taskId = taskRes.data.task?.id;
637
- });
638
-
639
- await test('Claim task', async () => {
640
- const claimRes = await req(`/api/engine/tasks/${taskId}/claim`, {
641
- method: 'POST',
642
- headers: auth,
643
- body: JSON.stringify({ agentId: 'agent-b' }),
644
- });
645
- assert(claimRes.status === 200, 'POST /engine/tasks/:id/claim → 200');
646
- });
647
-
648
- await test('Complete task', async () => {
649
- const completeRes = await req(`/api/engine/tasks/${taskId}/complete`, {
650
- method: 'POST',
651
- headers: auth,
652
- body: JSON.stringify({ agentId: 'agent-b', result: 'Research done' }),
653
- });
654
- assert(completeRes.status === 200, 'POST /engine/tasks/:id/complete → 200');
655
- });
656
-
657
- await test('Handoff', async () => {
658
- const handoffRes = await req('/api/engine/messages/handoff', {
659
- method: 'POST',
660
- headers: auth,
661
- body: JSON.stringify({ orgId: 'default', fromAgentId: 'agent-a', toAgentId: 'agent-b', subject: 'Handoff', conversationContext: 'Escalation: customer needs senior agent' }),
662
- });
663
- assert(handoffRes.status === 201, 'POST /engine/messages/handoff → 201');
664
- });
665
-
666
- await test('Validation: missing fields', async () => {
667
- const msgBad = await req('/api/engine/messages', {
668
- method: 'POST',
669
- headers: auth,
670
- body: JSON.stringify({ orgId: 'default' }),
671
- });
672
- assert(msgBad.status === 400, 'POST /engine/messages (missing fields) → 400');
673
- });
674
- });
675
-
676
- await section('15. Compliance Reporting', async () => {
677
- const dateRange = { from: '2024-01-01', to: '2024-12-31' };
678
- let soc2Id = null;
679
-
680
- await test('Generate SOC2 report', async () => {
681
- const soc2Res = await req('/api/engine/compliance/reports/soc2', {
682
- method: 'POST',
683
- headers: auth,
684
- body: JSON.stringify({ orgId: 'default', dateRange }),
685
- });
686
- assert(soc2Res.status === 201, 'POST /engine/compliance/reports/soc2 → 201');
687
- soc2Id = soc2Res.data.report?.id;
688
- });
689
-
690
- await test('Generate audit report', async () => {
691
- const auditReportRes = await req('/api/engine/compliance/reports/audit', {
692
- method: 'POST',
693
- headers: auth,
694
- body: JSON.stringify({ orgId: 'default', dateRange }),
695
- });
696
- assert(auditReportRes.status === 201, 'POST /engine/compliance/reports/audit → 201');
697
- });
698
-
699
- await test('Generate GDPR report', async () => {
700
- const gdprRes = await req('/api/engine/compliance/reports/gdpr', {
701
- method: 'POST',
702
- headers: auth,
703
- body: JSON.stringify({ orgId: 'default', agentId: 'test-agent' }),
704
- });
705
- assert(gdprRes.status === 201, 'POST /engine/compliance/reports/gdpr → 201');
706
- });
707
-
708
- await test('List reports', async () => {
709
- const compReports = await req('/api/engine/compliance/reports', { headers: auth });
710
- assert(compReports.status === 200, 'GET /engine/compliance/reports → 200');
711
- assert(compReports.data.reports?.length >= 3, `Compliance reports: ${compReports.data.reports?.length}`);
712
- });
713
-
714
- await test('Get report by ID', async () => {
715
- const compGet = await req(`/api/engine/compliance/reports/${soc2Id}`, { headers: auth });
716
- assert(compGet.status === 200, 'GET /engine/compliance/reports/:id → 200');
717
- assert(compGet.data.report?.type === 'soc2', 'Report type is soc2');
718
- });
719
-
720
- await test('Download report as JSON', async () => {
721
- const compDl = await fetch(`${BASE}/api/engine/compliance/reports/${soc2Id}/download?format=json`, { headers: { ...auth } });
722
- assert(compDl.status === 200, 'GET /engine/compliance/reports/:id/download → 200');
723
- assert(compDl.headers.get('content-disposition')?.includes('soc2'), 'Download has correct Content-Disposition');
724
- });
725
-
726
- await test('Download as CSV', async () => {
727
- const compCsv = await fetch(`${BASE}/api/engine/compliance/reports/${soc2Id}/download?format=csv`, { headers: { ...auth } });
728
- assert(compCsv.status === 200, 'GET /engine/compliance/reports/:id/download?format=csv → 200');
729
- assert(compCsv.headers.get('content-type')?.includes('text/csv'), 'CSV Content-Type');
730
- });
731
-
732
- await test('Validation: missing fields', async () => {
733
- const compBad = await req('/api/engine/compliance/reports/soc2', {
734
- method: 'POST',
735
- headers: auth,
736
- body: JSON.stringify({ orgId: 'default' }),
737
- });
738
- assert(compBad.status === 400, 'POST soc2 (missing dateRange) → 400');
739
- });
740
- });
741
-
742
- // ═══════════════════════════════════════════════════════
743
- // CLEANUP
744
- // ═══════════════════════════════════════════════════════
745
- if (serverHandle) { serverHandle.close(); server.healthMonitor.stop(); }
746
- await db.disconnect();
747
- for (const f of [TEST_DB, TEST_DB + '-shm', TEST_DB + '-wal']) { try { rmSync(f); } catch {} }
748
-
749
- console.log('═══════════════════════════════════════════════════');
750
- console.log(` Results: ${passed} passed, ${failed} failed, ${passed + failed} total`);
751
- console.log('═══════════════════════════════════════════════════');
752
-
753
- if (failed > 0) { console.log('\n❌ SOME TESTS FAILED\n'); process.exit(1); }
754
- else { console.log('\n✅ ALL TESTS PASSED\n'); process.exit(0); }