@actuate-media/cms-core 0.1.0

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 (431) hide show
  1. package/dist/__tests__/actions/document-crud.test.d.ts +2 -0
  2. package/dist/__tests__/actions/document-crud.test.d.ts.map +1 -0
  3. package/dist/__tests__/actions/document-crud.test.js +156 -0
  4. package/dist/__tests__/actions/document-crud.test.js.map +1 -0
  5. package/dist/__tests__/auth/password.test.d.ts +2 -0
  6. package/dist/__tests__/auth/password.test.d.ts.map +1 -0
  7. package/dist/__tests__/auth/password.test.js +102 -0
  8. package/dist/__tests__/auth/password.test.js.map +1 -0
  9. package/dist/__tests__/auth/session.test.d.ts +2 -0
  10. package/dist/__tests__/auth/session.test.d.ts.map +1 -0
  11. package/dist/__tests__/auth/session.test.js +66 -0
  12. package/dist/__tests__/auth/session.test.js.map +1 -0
  13. package/dist/__tests__/codegen/generate-types.test.d.ts +2 -0
  14. package/dist/__tests__/codegen/generate-types.test.d.ts.map +1 -0
  15. package/dist/__tests__/codegen/generate-types.test.js +173 -0
  16. package/dist/__tests__/codegen/generate-types.test.js.map +1 -0
  17. package/dist/__tests__/scheduling/scheduling.test.d.ts +2 -0
  18. package/dist/__tests__/scheduling/scheduling.test.d.ts.map +1 -0
  19. package/dist/__tests__/scheduling/scheduling.test.js +84 -0
  20. package/dist/__tests__/scheduling/scheduling.test.js.map +1 -0
  21. package/dist/__tests__/security/access.test.d.ts +2 -0
  22. package/dist/__tests__/security/access.test.d.ts.map +1 -0
  23. package/dist/__tests__/security/access.test.js +181 -0
  24. package/dist/__tests__/security/access.test.js.map +1 -0
  25. package/dist/__tests__/security/csrf.test.d.ts +2 -0
  26. package/dist/__tests__/security/csrf.test.d.ts.map +1 -0
  27. package/dist/__tests__/security/csrf.test.js +40 -0
  28. package/dist/__tests__/security/csrf.test.js.map +1 -0
  29. package/dist/__tests__/security/rate-limit.test.d.ts +2 -0
  30. package/dist/__tests__/security/rate-limit.test.d.ts.map +1 -0
  31. package/dist/__tests__/security/rate-limit.test.js +62 -0
  32. package/dist/__tests__/security/rate-limit.test.js.map +1 -0
  33. package/dist/__tests__/security/reauth.test.d.ts +2 -0
  34. package/dist/__tests__/security/reauth.test.d.ts.map +1 -0
  35. package/dist/__tests__/security/reauth.test.js +30 -0
  36. package/dist/__tests__/security/reauth.test.js.map +1 -0
  37. package/dist/__tests__/security/sanitize.test.d.ts +2 -0
  38. package/dist/__tests__/security/sanitize.test.d.ts.map +1 -0
  39. package/dist/__tests__/security/sanitize.test.js +75 -0
  40. package/dist/__tests__/security/sanitize.test.js.map +1 -0
  41. package/dist/__tests__/webhooks/webhooks.test.d.ts +2 -0
  42. package/dist/__tests__/webhooks/webhooks.test.d.ts.map +1 -0
  43. package/dist/__tests__/webhooks/webhooks.test.js +96 -0
  44. package/dist/__tests__/webhooks/webhooks.test.js.map +1 -0
  45. package/dist/a11y/index.d.ts +25 -0
  46. package/dist/a11y/index.d.ts.map +1 -0
  47. package/dist/a11y/index.js +88 -0
  48. package/dist/a11y/index.js.map +1 -0
  49. package/dist/actions.d.ts +42 -0
  50. package/dist/actions.d.ts.map +1 -0
  51. package/dist/actions.js +391 -0
  52. package/dist/actions.js.map +1 -0
  53. package/dist/api/handler-factory.d.ts +7 -0
  54. package/dist/api/handler-factory.d.ts.map +1 -0
  55. package/dist/api/handler-factory.js +120 -0
  56. package/dist/api/handler-factory.js.map +1 -0
  57. package/dist/api/handlers.d.ts +4 -0
  58. package/dist/api/handlers.d.ts.map +1 -0
  59. package/dist/api/handlers.js +2119 -0
  60. package/dist/api/handlers.js.map +1 -0
  61. package/dist/api/index.d.ts +23 -0
  62. package/dist/api/index.d.ts.map +1 -0
  63. package/dist/api/index.js +57 -0
  64. package/dist/api/index.js.map +1 -0
  65. package/dist/api/openapi.d.ts +3 -0
  66. package/dist/api/openapi.d.ts.map +1 -0
  67. package/dist/api/openapi.js +348 -0
  68. package/dist/api/openapi.js.map +1 -0
  69. package/dist/auth/index.d.ts +11 -0
  70. package/dist/auth/index.d.ts.map +1 -0
  71. package/dist/auth/index.js +9 -0
  72. package/dist/auth/index.js.map +1 -0
  73. package/dist/auth/oauth.d.ts +84 -0
  74. package/dist/auth/oauth.d.ts.map +1 -0
  75. package/dist/auth/oauth.js +201 -0
  76. package/dist/auth/oauth.js.map +1 -0
  77. package/dist/auth/password.d.ts +13 -0
  78. package/dist/auth/password.d.ts.map +1 -0
  79. package/dist/auth/password.js +47 -0
  80. package/dist/auth/password.js.map +1 -0
  81. package/dist/auth/providers/github.d.ts +9 -0
  82. package/dist/auth/providers/github.d.ts.map +1 -0
  83. package/dist/auth/providers/github.js +10 -0
  84. package/dist/auth/providers/github.js.map +1 -0
  85. package/dist/auth/providers/google.d.ts +9 -0
  86. package/dist/auth/providers/google.d.ts.map +1 -0
  87. package/dist/auth/providers/google.js +10 -0
  88. package/dist/auth/providers/google.js.map +1 -0
  89. package/dist/auth/providers/microsoft.d.ts +9 -0
  90. package/dist/auth/providers/microsoft.d.ts.map +1 -0
  91. package/dist/auth/providers/microsoft.js +11 -0
  92. package/dist/auth/providers/microsoft.js.map +1 -0
  93. package/dist/auth/session.d.ts +21 -0
  94. package/dist/auth/session.d.ts.map +1 -0
  95. package/dist/auth/session.js +35 -0
  96. package/dist/auth/session.js.map +1 -0
  97. package/dist/auth/totp.d.ts +5 -0
  98. package/dist/auth/totp.d.ts.map +1 -0
  99. package/dist/auth/totp.js +86 -0
  100. package/dist/auth/totp.js.map +1 -0
  101. package/dist/backup/index.d.ts +19 -0
  102. package/dist/backup/index.d.ts.map +1 -0
  103. package/dist/backup/index.js +22 -0
  104. package/dist/backup/index.js.map +1 -0
  105. package/dist/cache/index.d.ts +15 -0
  106. package/dist/cache/index.d.ts.map +1 -0
  107. package/dist/cache/index.js +32 -0
  108. package/dist/cache/index.js.map +1 -0
  109. package/dist/client.d.ts +30 -0
  110. package/dist/client.d.ts.map +1 -0
  111. package/dist/client.js +50 -0
  112. package/dist/client.js.map +1 -0
  113. package/dist/codegen/index.d.ts +4 -0
  114. package/dist/codegen/index.d.ts.map +1 -0
  115. package/dist/codegen/index.js +370 -0
  116. package/dist/codegen/index.js.map +1 -0
  117. package/dist/collections/index.d.ts +17 -0
  118. package/dist/collections/index.d.ts.map +1 -0
  119. package/dist/collections/index.js +29 -0
  120. package/dist/collections/index.js.map +1 -0
  121. package/dist/config/index.d.ts +6 -0
  122. package/dist/config/index.d.ts.map +1 -0
  123. package/dist/config/index.js +74 -0
  124. package/dist/config/index.js.map +1 -0
  125. package/dist/config/types.d.ts +307 -0
  126. package/dist/config/types.d.ts.map +1 -0
  127. package/dist/config/types.js +3 -0
  128. package/dist/config/types.js.map +1 -0
  129. package/dist/content/ai-api.d.ts +21 -0
  130. package/dist/content/ai-api.d.ts.map +1 -0
  131. package/dist/content/ai-api.js +19 -0
  132. package/dist/content/ai-api.js.map +1 -0
  133. package/dist/content/content-graph.d.ts +25 -0
  134. package/dist/content/content-graph.d.ts.map +1 -0
  135. package/dist/content/content-graph.js +40 -0
  136. package/dist/content/content-graph.js.map +1 -0
  137. package/dist/content/extract.d.ts +7 -0
  138. package/dist/content/extract.d.ts.map +1 -0
  139. package/dist/content/extract.js +33 -0
  140. package/dist/content/extract.js.map +1 -0
  141. package/dist/content/index.d.ts +8 -0
  142. package/dist/content/index.d.ts.map +1 -0
  143. package/dist/content/index.js +5 -0
  144. package/dist/content/index.js.map +1 -0
  145. package/dist/content/structured-data.d.ts +80 -0
  146. package/dist/content/structured-data.d.ts.map +1 -0
  147. package/dist/content/structured-data.js +295 -0
  148. package/dist/content/structured-data.js.map +1 -0
  149. package/dist/db/adapters/mysql.d.ts +5 -0
  150. package/dist/db/adapters/mysql.d.ts.map +1 -0
  151. package/dist/db/adapters/mysql.js +18 -0
  152. package/dist/db/adapters/mysql.js.map +1 -0
  153. package/dist/db/adapters/postgres.d.ts +7 -0
  154. package/dist/db/adapters/postgres.d.ts.map +1 -0
  155. package/dist/db/adapters/postgres.js +20 -0
  156. package/dist/db/adapters/postgres.js.map +1 -0
  157. package/dist/db/adapters/sqlite.d.ts +5 -0
  158. package/dist/db/adapters/sqlite.d.ts.map +1 -0
  159. package/dist/db/adapters/sqlite.js +19 -0
  160. package/dist/db/adapters/sqlite.js.map +1 -0
  161. package/dist/db/create-adapter.d.ts +11 -0
  162. package/dist/db/create-adapter.d.ts.map +1 -0
  163. package/dist/db/create-adapter.js +43 -0
  164. package/dist/db/create-adapter.js.map +1 -0
  165. package/dist/db/index.d.ts +9 -0
  166. package/dist/db/index.d.ts.map +1 -0
  167. package/dist/db/index.js +5 -0
  168. package/dist/db/index.js.map +1 -0
  169. package/dist/db.d.ts +20 -0
  170. package/dist/db.d.ts.map +1 -0
  171. package/dist/db.js +35 -0
  172. package/dist/db.js.map +1 -0
  173. package/dist/fields/index.d.ts +15 -0
  174. package/dist/fields/index.d.ts.map +1 -0
  175. package/dist/fields/index.js +87 -0
  176. package/dist/fields/index.js.map +1 -0
  177. package/dist/forms/analytics.d.ts +62 -0
  178. package/dist/forms/analytics.d.ts.map +1 -0
  179. package/dist/forms/analytics.js +95 -0
  180. package/dist/forms/analytics.js.map +1 -0
  181. package/dist/forms/attribution.d.ts +29 -0
  182. package/dist/forms/attribution.d.ts.map +1 -0
  183. package/dist/forms/attribution.js +216 -0
  184. package/dist/forms/attribution.js.map +1 -0
  185. package/dist/forms/index.d.ts +5 -0
  186. package/dist/forms/index.d.ts.map +1 -0
  187. package/dist/forms/index.js +3 -0
  188. package/dist/forms/index.js.map +1 -0
  189. package/dist/graphql/index.d.ts +11 -0
  190. package/dist/graphql/index.d.ts.map +1 -0
  191. package/dist/graphql/index.js +58 -0
  192. package/dist/graphql/index.js.map +1 -0
  193. package/dist/graphql/resolvers.d.ts +8 -0
  194. package/dist/graphql/resolvers.d.ts.map +1 -0
  195. package/dist/graphql/resolvers.js +93 -0
  196. package/dist/graphql/resolvers.js.map +1 -0
  197. package/dist/graphql/schema-builder.d.ts +3 -0
  198. package/dist/graphql/schema-builder.d.ts.map +1 -0
  199. package/dist/graphql/schema-builder.js +103 -0
  200. package/dist/graphql/schema-builder.js.map +1 -0
  201. package/dist/health/index.d.ts +27 -0
  202. package/dist/health/index.d.ts.map +1 -0
  203. package/dist/health/index.js +43 -0
  204. package/dist/health/index.js.map +1 -0
  205. package/dist/i18n/index.d.ts +22 -0
  206. package/dist/i18n/index.d.ts.map +1 -0
  207. package/dist/i18n/index.js +37 -0
  208. package/dist/i18n/index.js.map +1 -0
  209. package/dist/index.d.ts +73 -0
  210. package/dist/index.d.ts.map +1 -0
  211. package/dist/index.js +81 -0
  212. package/dist/index.js.map +1 -0
  213. package/dist/media/index.d.ts +3 -0
  214. package/dist/media/index.d.ts.map +1 -0
  215. package/dist/media/index.js +2 -0
  216. package/dist/media/index.js.map +1 -0
  217. package/dist/media/optimize.d.ts +40 -0
  218. package/dist/media/optimize.d.ts.map +1 -0
  219. package/dist/media/optimize.js +137 -0
  220. package/dist/media/optimize.js.map +1 -0
  221. package/dist/middleware.d.ts +7 -0
  222. package/dist/middleware.d.ts.map +1 -0
  223. package/dist/middleware.js +86 -0
  224. package/dist/middleware.js.map +1 -0
  225. package/dist/multisite/index.d.ts +20 -0
  226. package/dist/multisite/index.d.ts.map +1 -0
  227. package/dist/multisite/index.js +26 -0
  228. package/dist/multisite/index.js.map +1 -0
  229. package/dist/next/preview.d.ts +10 -0
  230. package/dist/next/preview.d.ts.map +1 -0
  231. package/dist/next/preview.js +17 -0
  232. package/dist/next/preview.js.map +1 -0
  233. package/dist/next.d.ts +9 -0
  234. package/dist/next.d.ts.map +1 -0
  235. package/dist/next.js +35 -0
  236. package/dist/next.js.map +1 -0
  237. package/dist/notifications/index.d.ts +20 -0
  238. package/dist/notifications/index.d.ts.map +1 -0
  239. package/dist/notifications/index.js +22 -0
  240. package/dist/notifications/index.js.map +1 -0
  241. package/dist/presence/index.d.ts +24 -0
  242. package/dist/presence/index.d.ts.map +1 -0
  243. package/dist/presence/index.js +99 -0
  244. package/dist/presence/index.js.map +1 -0
  245. package/dist/preview/index.d.ts +14 -0
  246. package/dist/preview/index.d.ts.map +1 -0
  247. package/dist/preview/index.js +45 -0
  248. package/dist/preview/index.js.map +1 -0
  249. package/dist/privacy/index.d.ts +33 -0
  250. package/dist/privacy/index.d.ts.map +1 -0
  251. package/dist/privacy/index.js +15 -0
  252. package/dist/privacy/index.js.map +1 -0
  253. package/dist/relationships/index.d.ts +13 -0
  254. package/dist/relationships/index.d.ts.map +1 -0
  255. package/dist/relationships/index.js +12 -0
  256. package/dist/relationships/index.js.map +1 -0
  257. package/dist/scheduling/index.d.ts +44 -0
  258. package/dist/scheduling/index.d.ts.map +1 -0
  259. package/dist/scheduling/index.js +119 -0
  260. package/dist/scheduling/index.js.map +1 -0
  261. package/dist/search/index.d.ts +25 -0
  262. package/dist/search/index.d.ts.map +1 -0
  263. package/dist/search/index.js +168 -0
  264. package/dist/search/index.js.map +1 -0
  265. package/dist/security/access.d.ts +26 -0
  266. package/dist/security/access.d.ts.map +1 -0
  267. package/dist/security/access.js +92 -0
  268. package/dist/security/access.js.map +1 -0
  269. package/dist/security/anomaly-detection.d.ts +17 -0
  270. package/dist/security/anomaly-detection.d.ts.map +1 -0
  271. package/dist/security/anomaly-detection.js +17 -0
  272. package/dist/security/anomaly-detection.js.map +1 -0
  273. package/dist/security/api-key-enhanced.d.ts +25 -0
  274. package/dist/security/api-key-enhanced.d.ts.map +1 -0
  275. package/dist/security/api-key-enhanced.js +25 -0
  276. package/dist/security/api-key-enhanced.js.map +1 -0
  277. package/dist/security/audit.d.ts +39 -0
  278. package/dist/security/audit.d.ts.map +1 -0
  279. package/dist/security/audit.js +40 -0
  280. package/dist/security/audit.js.map +1 -0
  281. package/dist/security/breach-check.d.ts +3 -0
  282. package/dist/security/breach-check.d.ts.map +1 -0
  283. package/dist/security/breach-check.js +27 -0
  284. package/dist/security/breach-check.js.map +1 -0
  285. package/dist/security/cors.d.ts +11 -0
  286. package/dist/security/cors.d.ts.map +1 -0
  287. package/dist/security/cors.js +33 -0
  288. package/dist/security/cors.js.map +1 -0
  289. package/dist/security/csp-nonces.d.ts +5 -0
  290. package/dist/security/csp-nonces.d.ts.map +1 -0
  291. package/dist/security/csp-nonces.js +24 -0
  292. package/dist/security/csp-nonces.js.map +1 -0
  293. package/dist/security/csrf.d.ts +5 -0
  294. package/dist/security/csrf.d.ts.map +1 -0
  295. package/dist/security/csrf.js +20 -0
  296. package/dist/security/csrf.js.map +1 -0
  297. package/dist/security/encrypted-fields.d.ts +5 -0
  298. package/dist/security/encrypted-fields.d.ts.map +1 -0
  299. package/dist/security/encrypted-fields.js +40 -0
  300. package/dist/security/encrypted-fields.js.map +1 -0
  301. package/dist/security/headers.d.ts +11 -0
  302. package/dist/security/headers.d.ts.map +1 -0
  303. package/dist/security/headers.js +32 -0
  304. package/dist/security/headers.js.map +1 -0
  305. package/dist/security/index.d.ts +31 -0
  306. package/dist/security/index.d.ts.map +1 -0
  307. package/dist/security/index.js +20 -0
  308. package/dist/security/index.js.map +1 -0
  309. package/dist/security/ip-allowlist.d.ts +3 -0
  310. package/dist/security/ip-allowlist.d.ts.map +1 -0
  311. package/dist/security/ip-allowlist.js +35 -0
  312. package/dist/security/ip-allowlist.js.map +1 -0
  313. package/dist/security/middleware.d.ts +20 -0
  314. package/dist/security/middleware.d.ts.map +1 -0
  315. package/dist/security/middleware.js +45 -0
  316. package/dist/security/middleware.js.map +1 -0
  317. package/dist/security/rate-limit.d.ts +24 -0
  318. package/dist/security/rate-limit.d.ts.map +1 -0
  319. package/dist/security/rate-limit.js +84 -0
  320. package/dist/security/rate-limit.js.map +1 -0
  321. package/dist/security/reauth.d.ts +15 -0
  322. package/dist/security/reauth.d.ts.map +1 -0
  323. package/dist/security/reauth.js +38 -0
  324. package/dist/security/reauth.js.map +1 -0
  325. package/dist/security/sanitize.d.ts +13 -0
  326. package/dist/security/sanitize.d.ts.map +1 -0
  327. package/dist/security/sanitize.js +34 -0
  328. package/dist/security/sanitize.js.map +1 -0
  329. package/dist/security/security-txt.d.ts +12 -0
  330. package/dist/security/security-txt.d.ts.map +1 -0
  331. package/dist/security/security-txt.js +19 -0
  332. package/dist/security/security-txt.js.map +1 -0
  333. package/dist/security/session-limits.d.ts +17 -0
  334. package/dist/security/session-limits.d.ts.map +1 -0
  335. package/dist/security/session-limits.js +14 -0
  336. package/dist/security/session-limits.js.map +1 -0
  337. package/dist/security/upload.d.ts +13 -0
  338. package/dist/security/upload.d.ts.map +1 -0
  339. package/dist/security/upload.js +34 -0
  340. package/dist/security/upload.js.map +1 -0
  341. package/dist/security/webhook.d.ts +12 -0
  342. package/dist/security/webhook.d.ts.map +1 -0
  343. package/dist/security/webhook.js +38 -0
  344. package/dist/security/webhook.js.map +1 -0
  345. package/dist/seo/analysis.d.ts +66 -0
  346. package/dist/seo/analysis.d.ts.map +1 -0
  347. package/dist/seo/analysis.js +594 -0
  348. package/dist/seo/analysis.js.map +1 -0
  349. package/dist/seo/index.d.ts +9 -0
  350. package/dist/seo/index.d.ts.map +1 -0
  351. package/dist/seo/index.js +5 -0
  352. package/dist/seo/index.js.map +1 -0
  353. package/dist/seo/llms-txt.d.ts +16 -0
  354. package/dist/seo/llms-txt.d.ts.map +1 -0
  355. package/dist/seo/llms-txt.js +70 -0
  356. package/dist/seo/llms-txt.js.map +1 -0
  357. package/dist/seo/meta-tags.d.ts +33 -0
  358. package/dist/seo/meta-tags.d.ts.map +1 -0
  359. package/dist/seo/meta-tags.js +159 -0
  360. package/dist/seo/meta-tags.js.map +1 -0
  361. package/dist/seo/title-templates.d.ts +17 -0
  362. package/dist/seo/title-templates.d.ts.map +1 -0
  363. package/dist/seo/title-templates.js +28 -0
  364. package/dist/seo/title-templates.js.map +1 -0
  365. package/dist/setup/index.d.ts +38 -0
  366. package/dist/setup/index.d.ts.map +1 -0
  367. package/dist/setup/index.js +77 -0
  368. package/dist/setup/index.js.map +1 -0
  369. package/dist/storage/index.d.ts +11 -0
  370. package/dist/storage/index.d.ts.map +1 -0
  371. package/dist/storage/index.js +11 -0
  372. package/dist/storage/index.js.map +1 -0
  373. package/dist/templates/index.d.ts +16 -0
  374. package/dist/templates/index.d.ts.map +1 -0
  375. package/dist/templates/index.js +23 -0
  376. package/dist/templates/index.js.map +1 -0
  377. package/dist/upgrade/changelog.d.ts +13 -0
  378. package/dist/upgrade/changelog.d.ts.map +1 -0
  379. package/dist/upgrade/changelog.js +54 -0
  380. package/dist/upgrade/changelog.js.map +1 -0
  381. package/dist/upgrade/index.d.ts +7 -0
  382. package/dist/upgrade/index.d.ts.map +1 -0
  383. package/dist/upgrade/index.js +4 -0
  384. package/dist/upgrade/index.js.map +1 -0
  385. package/dist/upgrade/upgrade-pr.d.ts +16 -0
  386. package/dist/upgrade/upgrade-pr.d.ts.map +1 -0
  387. package/dist/upgrade/upgrade-pr.js +38 -0
  388. package/dist/upgrade/upgrade-pr.js.map +1 -0
  389. package/dist/upgrade/version-check.d.ts +17 -0
  390. package/dist/upgrade/version-check.d.ts.map +1 -0
  391. package/dist/upgrade/version-check.js +30 -0
  392. package/dist/upgrade/version-check.js.map +1 -0
  393. package/dist/webhooks/index.d.ts +46 -0
  394. package/dist/webhooks/index.d.ts.map +1 -0
  395. package/dist/webhooks/index.js +245 -0
  396. package/dist/webhooks/index.js.map +1 -0
  397. package/dist/workflow/index.d.ts +8 -0
  398. package/dist/workflow/index.d.ts.map +1 -0
  399. package/dist/workflow/index.js +56 -0
  400. package/dist/workflow/index.js.map +1 -0
  401. package/dist/workflows/index.d.ts +30 -0
  402. package/dist/workflows/index.d.ts.map +1 -0
  403. package/dist/workflows/index.js +14 -0
  404. package/dist/workflows/index.js.map +1 -0
  405. package/generated/browser.ts +109 -0
  406. package/generated/client.ts +133 -0
  407. package/generated/commonInputTypes.ts +709 -0
  408. package/generated/enums.ts +125 -0
  409. package/generated/internal/class.ts +376 -0
  410. package/generated/internal/prismaNamespace.ts +2617 -0
  411. package/generated/internal/prismaNamespaceBrowser.ts +611 -0
  412. package/generated/models/ApiKey.ts +1550 -0
  413. package/generated/models/AuditLog.ts +1206 -0
  414. package/generated/models/BackupRecord.ts +1250 -0
  415. package/generated/models/ContentLock.ts +1472 -0
  416. package/generated/models/ContentTemplate.ts +1416 -0
  417. package/generated/models/Document.ts +3005 -0
  418. package/generated/models/Folder.ts +1904 -0
  419. package/generated/models/FormSubmission.ts +1200 -0
  420. package/generated/models/InAppNotification.ts +1457 -0
  421. package/generated/models/Media.ts +2340 -0
  422. package/generated/models/MediaUsage.ts +1472 -0
  423. package/generated/models/OAuthAccount.ts +1463 -0
  424. package/generated/models/Redirect.ts +1284 -0
  425. package/generated/models/Session.ts +1492 -0
  426. package/generated/models/Site.ts +1206 -0
  427. package/generated/models/User.ts +3513 -0
  428. package/generated/models/Version.ts +1511 -0
  429. package/generated/models/WorkflowState.ts +1514 -0
  430. package/generated/models.ts +29 -0
  431. package/package.json +83 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"access.js","sourceRoot":"","sources":["../../src/security/access.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ export interface LoginAttempt {
2
+ userId: string;
3
+ ipAddress: string;
4
+ userAgent: string;
5
+ timestamp: Date;
6
+ success: boolean;
7
+ }
8
+ export interface AnomalyResult {
9
+ suspicious: boolean;
10
+ reasons: string[];
11
+ riskScore: number;
12
+ }
13
+ /** Analyze a login attempt for anomalous behavior. */
14
+ export declare function detectLoginAnomaly(attempt: LoginAttempt, _recentAttempts: LoginAttempt[]): Promise<AnomalyResult>;
15
+ /** Check if there are too many failed login attempts for an account. */
16
+ export declare function checkBruteForce(recentAttempts: LoginAttempt[], maxFailures?: number, windowMs?: number): boolean;
17
+ //# sourceMappingURL=anomaly-detection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anomaly-detection.d.ts","sourceRoot":"","sources":["../../src/security/anomaly-detection.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,UAAU,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,sDAAsD;AACtD,wBAAsB,kBAAkB,CACtC,OAAO,EAAE,YAAY,EACrB,eAAe,EAAE,YAAY,EAAE,GAC9B,OAAO,CAAC,aAAa,CAAC,CAWxB;AAED,wEAAwE;AACxE,wBAAgB,eAAe,CAC7B,cAAc,EAAE,YAAY,EAAE,EAC9B,WAAW,SAAI,EACf,QAAQ,SAAiB,GACxB,OAAO,CAMT"}
@@ -0,0 +1,17 @@
1
+ /** Analyze a login attempt for anomalous behavior. */
2
+ export async function detectLoginAnomaly(attempt, _recentAttempts) {
3
+ const reasons = [];
4
+ let riskScore = 0;
5
+ // TODO: implement geo-velocity check
6
+ // TODO: implement impossible-travel detection
7
+ // TODO: implement device fingerprint comparison
8
+ void attempt;
9
+ return { suspicious: riskScore > 50, reasons, riskScore };
10
+ }
11
+ /** Check if there are too many failed login attempts for an account. */
12
+ export function checkBruteForce(recentAttempts, maxFailures = 5, windowMs = 15 * 60 * 1000) {
13
+ const cutoff = Date.now() - windowMs;
14
+ const recentFailures = recentAttempts.filter((a) => !a.success && a.timestamp.getTime() > cutoff);
15
+ return recentFailures.length >= maxFailures;
16
+ }
17
+ //# sourceMappingURL=anomaly-detection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anomaly-detection.js","sourceRoot":"","sources":["../../src/security/anomaly-detection.ts"],"names":[],"mappings":"AAcA,sDAAsD;AACtD,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,OAAqB,EACrB,eAA+B;IAE/B,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,IAAI,SAAS,GAAG,CAAC,CAAC;IAElB,qCAAqC;IACrC,8CAA8C;IAC9C,gDAAgD;IAEhD,KAAK,OAAO,CAAC;IAEb,OAAO,EAAE,UAAU,EAAE,SAAS,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;AAC5D,CAAC;AAED,wEAAwE;AACxE,MAAM,UAAU,eAAe,CAC7B,cAA8B,EAC9B,WAAW,GAAG,CAAC,EACf,QAAQ,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;IAEzB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC;IACrC,MAAM,cAAc,GAAG,cAAc,CAAC,MAAM,CAC1C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,MAAM,CACpD,CAAC;IACF,OAAO,cAAc,CAAC,MAAM,IAAI,WAAW,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,25 @@
1
+ export interface ApiKeyScope {
2
+ collections?: string[];
3
+ actions?: ("read" | "create" | "update" | "delete")[];
4
+ globals?: string[];
5
+ media?: boolean;
6
+ }
7
+ export interface EnhancedApiKeyConfig {
8
+ prefix: string;
9
+ scopes: ApiKeyScope;
10
+ ipRestrictions?: string[];
11
+ expiresAt?: Date;
12
+ rateLimit?: {
13
+ maxRequests: number;
14
+ windowMs: number;
15
+ };
16
+ }
17
+ /** Generate a new API key with scoped permissions. */
18
+ export declare function generateApiKey(config: EnhancedApiKeyConfig): Promise<{
19
+ key: string;
20
+ keyHash: string;
21
+ keyPrefix: string;
22
+ }>;
23
+ /** Validate an API key's scopes against a requested action. */
24
+ export declare function validateApiKeyScope(scopes: ApiKeyScope, collection: string, action: "read" | "create" | "update" | "delete"): boolean;
25
+ //# sourceMappingURL=api-key-enhanced.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-key-enhanced.d.ts","sourceRoot":"","sources":["../../src/security/api-key-enhanced.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IAC1B,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,OAAO,CAAC,EAAE,CAAC,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC,EAAE,CAAC;IACtD,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,WAAW,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,SAAS,CAAC,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;CACvD;AAED,sDAAsD;AACtD,wBAAsB,cAAc,CAClC,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC,CAiB9D;AAED,+DAA+D;AAC/D,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,WAAW,EACnB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAC9C,OAAO,CAQT"}
@@ -0,0 +1,25 @@
1
+ /** Generate a new API key with scoped permissions. */
2
+ export async function generateApiKey(config) {
3
+ const rawBytes = crypto.getRandomValues(new Uint8Array(32));
4
+ const rawKey = Array.from(rawBytes)
5
+ .map((b) => b.toString(16).padStart(2, "0"))
6
+ .join("");
7
+ const key = `${config.prefix}_${rawKey}`;
8
+ const keyPrefix = key.slice(0, config.prefix.length + 9);
9
+ const hashBuffer = await crypto.subtle.digest("SHA-256", new TextEncoder().encode(key));
10
+ const keyHash = Array.from(new Uint8Array(hashBuffer))
11
+ .map((b) => b.toString(16).padStart(2, "0"))
12
+ .join("");
13
+ return { key, keyHash, keyPrefix };
14
+ }
15
+ /** Validate an API key's scopes against a requested action. */
16
+ export function validateApiKeyScope(scopes, collection, action) {
17
+ if (scopes.collections && !scopes.collections.includes(collection)) {
18
+ return false;
19
+ }
20
+ if (scopes.actions && !scopes.actions.includes(action)) {
21
+ return false;
22
+ }
23
+ return true;
24
+ }
25
+ //# sourceMappingURL=api-key-enhanced.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-key-enhanced.js","sourceRoot":"","sources":["../../src/security/api-key-enhanced.ts"],"names":[],"mappings":"AAeA,sDAAsD;AACtD,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,MAA4B;IAE5B,MAAM,QAAQ,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5D,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC;SAChC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SAC3C,IAAI,CAAC,EAAE,CAAC,CAAC;IACZ,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,MAAM,IAAI,MAAM,EAAE,CAAC;IACzC,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAEzD,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAC3C,SAAS,EACT,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAC9B,CAAC;IACF,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC;SACnD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SAC3C,IAAI,CAAC,EAAE,CAAC,CAAC;IAEZ,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;AACrC,CAAC;AAED,+DAA+D;AAC/D,MAAM,UAAU,mBAAmB,CACjC,MAAmB,EACnB,UAAkB,EAClB,MAA+C;IAE/C,IAAI,MAAM,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;QACnE,OAAO,KAAK,CAAC;IACf,CAAC;IACD,IAAI,MAAM,CAAC,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QACvD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC"}
@@ -0,0 +1,39 @@
1
+ export interface AuditEntry {
2
+ event: string;
3
+ userId?: string;
4
+ ipAddress?: string;
5
+ userAgent?: string;
6
+ details?: Record<string, unknown>;
7
+ timestamp?: Date;
8
+ }
9
+ export interface AuditLogQuery {
10
+ event?: string;
11
+ userId?: string;
12
+ from?: Date;
13
+ to?: Date;
14
+ limit?: number;
15
+ offset?: number;
16
+ }
17
+ export interface AuditLogResult {
18
+ entries: AuditEntry[];
19
+ total: number;
20
+ }
21
+ /** Record an audit log event. */
22
+ export declare function logEvent(event: {
23
+ event: string;
24
+ userId?: string;
25
+ ipAddress?: string;
26
+ userAgent?: string;
27
+ details?: Record<string, unknown>;
28
+ }): Promise<void>;
29
+ /** Query audit log entries with filters and pagination. */
30
+ export declare function getAuditLog(options?: {
31
+ userId?: string;
32
+ event?: string;
33
+ page?: number;
34
+ pageSize?: number;
35
+ }): Promise<{
36
+ entries: any[];
37
+ total: number;
38
+ }>;
39
+ //# sourceMappingURL=audit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit.d.ts","sourceRoot":"","sources":["../../src/security/audit.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ,EAAE,CAAC,EAAE,IAAI,CAAC;IACV,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,UAAU,EAAE,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,iCAAiC;AACjC,wBAAsB,QAAQ,CAAC,KAAK,EAAE;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC,GAAG,OAAO,CAAC,IAAI,CAAC,CAehB;AAED,2DAA2D;AAC3D,wBAAsB,WAAW,CAAC,OAAO,GAAE;IACzC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;CACd,GAAG,OAAO,CAAC;IAAE,OAAO,EAAE,GAAG,EAAE,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAmBlD"}
@@ -0,0 +1,40 @@
1
+ import { getDB } from '../db';
2
+ /** Record an audit log event. */
3
+ export async function logEvent(event) {
4
+ try {
5
+ const db = getDB();
6
+ await db.auditLog.create({
7
+ data: {
8
+ event: event.event,
9
+ userId: event.userId ?? null,
10
+ ipAddress: event.ipAddress ?? null,
11
+ userAgent: event.userAgent ?? null,
12
+ details: event.details ?? {},
13
+ },
14
+ });
15
+ }
16
+ catch {
17
+ // Fail open — audit logging should never block the primary operation
18
+ }
19
+ }
20
+ /** Query audit log entries with filters and pagination. */
21
+ export async function getAuditLog(options = {}) {
22
+ const db = getDB();
23
+ const { userId, event, page = 1, pageSize = 50 } = options;
24
+ const where = {};
25
+ if (userId)
26
+ where.userId = userId;
27
+ if (event)
28
+ where.event = event;
29
+ const [entries, total] = await Promise.all([
30
+ db.auditLog.findMany({
31
+ where,
32
+ orderBy: { timestamp: 'desc' },
33
+ skip: (page - 1) * pageSize,
34
+ take: pageSize,
35
+ }),
36
+ db.auditLog.count({ where }),
37
+ ]);
38
+ return { entries, total };
39
+ }
40
+ //# sourceMappingURL=audit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit.js","sourceRoot":"","sources":["../../src/security/audit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAyB9B,iCAAiC;AACjC,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,KAM9B;IACC,IAAI,CAAC;QACH,MAAM,EAAE,GAAG,KAAK,EAAO,CAAC;QACxB,MAAM,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC;YACvB,IAAI,EAAE;gBACJ,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI;gBAC5B,SAAS,EAAE,KAAK,CAAC,SAAS,IAAI,IAAI;gBAClC,SAAS,EAAE,KAAK,CAAC,SAAS,IAAI,IAAI;gBAClC,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,EAAE;aAC7B;SACF,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,qEAAqE;IACvE,CAAC;AACH,CAAC;AAED,2DAA2D;AAC3D,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,UAK9B,EAAE;IACJ,MAAM,EAAE,GAAG,KAAK,EAAO,CAAC;IACxB,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,GAAG,CAAC,EAAE,QAAQ,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC;IAE3D,MAAM,KAAK,GAAQ,EAAE,CAAC;IACtB,IAAI,MAAM;QAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;IAClC,IAAI,KAAK;QAAE,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;IAE/B,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACzC,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC;YACnB,KAAK;YACL,OAAO,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE;YAC9B,IAAI,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,QAAQ;YAC3B,IAAI,EAAE,QAAQ;SACf,CAAC;QACF,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,CAAC;KAC7B,CAAC,CAAC;IAEH,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;AAC5B,CAAC"}
@@ -0,0 +1,3 @@
1
+ /** Check a password against the HaveIBeenPwned Passwords API using k-anonymity. */
2
+ export declare function checkBreached(password: string): Promise<boolean>;
3
+ //# sourceMappingURL=breach-check.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"breach-check.d.ts","sourceRoot":"","sources":["../../src/security/breach-check.ts"],"names":[],"mappings":"AAAA,mFAAmF;AACnF,wBAAsB,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CA0BtE"}
@@ -0,0 +1,27 @@
1
+ /** Check a password against the HaveIBeenPwned Passwords API using k-anonymity. */
2
+ export async function checkBreached(password) {
3
+ const encoder = new TextEncoder();
4
+ const data = encoder.encode(password);
5
+ const hashBuffer = await crypto.subtle.digest('SHA-1', data);
6
+ const hashArray = Array.from(new Uint8Array(hashBuffer));
7
+ const hashHex = hashArray
8
+ .map((b) => b.toString(16).padStart(2, '0'))
9
+ .join('')
10
+ .toUpperCase();
11
+ const prefix = hashHex.substring(0, 5);
12
+ const suffix = hashHex.substring(5);
13
+ try {
14
+ const response = await fetch(`https://api.pwnedpasswords.com/range/${prefix}`, {
15
+ headers: { 'User-Agent': 'ActuateCMS-PasswordCheck' },
16
+ signal: AbortSignal.timeout(5000),
17
+ });
18
+ if (!response.ok)
19
+ return false;
20
+ const text = await response.text();
21
+ return text.split('\n').some((line) => line.startsWith(suffix));
22
+ }
23
+ catch {
24
+ return false;
25
+ }
26
+ }
27
+ //# sourceMappingURL=breach-check.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"breach-check.js","sourceRoot":"","sources":["../../src/security/breach-check.ts"],"names":[],"mappings":"AAAA,mFAAmF;AACnF,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,QAAgB;IAClD,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAClC,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACtC,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAC7D,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;IACzD,MAAM,OAAO,GAAG,SAAS;SACtB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SAC3C,IAAI,CAAC,EAAE,CAAC;SACR,WAAW,EAAE,CAAC;IAEjB,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACvC,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAEpC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,wCAAwC,MAAM,EAAE,EAAE;YAC7E,OAAO,EAAE,EAAE,YAAY,EAAE,0BAA0B,EAAE;YACrD,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC;SAClC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE;YAAE,OAAO,KAAK,CAAC;QAE/B,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QACnC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IAClE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC"}
@@ -0,0 +1,11 @@
1
+ export interface CorsConfig {
2
+ allowedOrigins: string[] | "*";
3
+ allowedMethods?: string[];
4
+ allowedHeaders?: string[];
5
+ exposedHeaders?: string[];
6
+ credentials?: boolean;
7
+ maxAge?: number;
8
+ }
9
+ /** Build CORS headers for a given request origin. */
10
+ export declare function getCorsHeaders(requestOrigin: string | null, config: CorsConfig): Record<string, string>;
11
+ //# sourceMappingURL=cors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cors.d.ts","sourceRoot":"","sources":["../../src/security/cors.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,cAAc,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;IAC/B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAKD,qDAAqD;AACrD,wBAAgB,cAAc,CAC5B,aAAa,EAAE,MAAM,GAAG,IAAI,EAC5B,MAAM,EAAE,UAAU,GACjB,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAwBxB"}
@@ -0,0 +1,33 @@
1
+ const DEFAULT_METHODS = ["GET", "POST", "PUT", "PATCH", "DELETE", "OPTIONS"];
2
+ const DEFAULT_HEADERS = ["Content-Type", "Authorization", "X-CSRF-Token"];
3
+ /** Build CORS headers for a given request origin. */
4
+ export function getCorsHeaders(requestOrigin, config) {
5
+ const headers = {};
6
+ const allowedOrigin = resolveOrigin(requestOrigin, config.allowedOrigins);
7
+ if (!allowedOrigin)
8
+ return headers;
9
+ headers["Access-Control-Allow-Origin"] = allowedOrigin;
10
+ headers["Access-Control-Allow-Methods"] = (config.allowedMethods ?? DEFAULT_METHODS).join(", ");
11
+ headers["Access-Control-Allow-Headers"] = (config.allowedHeaders ?? DEFAULT_HEADERS).join(", ");
12
+ if (config.exposedHeaders?.length) {
13
+ headers["Access-Control-Expose-Headers"] = config.exposedHeaders.join(", ");
14
+ }
15
+ if (config.credentials) {
16
+ headers["Access-Control-Allow-Credentials"] = "true";
17
+ }
18
+ if (config.maxAge !== undefined) {
19
+ headers["Access-Control-Max-Age"] = String(config.maxAge);
20
+ }
21
+ if (config.allowedOrigins !== "*") {
22
+ headers["Vary"] = "Origin";
23
+ }
24
+ return headers;
25
+ }
26
+ function resolveOrigin(requestOrigin, allowed) {
27
+ if (allowed === "*")
28
+ return "*";
29
+ if (!requestOrigin)
30
+ return null;
31
+ return allowed.includes(requestOrigin) ? requestOrigin : null;
32
+ }
33
+ //# sourceMappingURL=cors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cors.js","sourceRoot":"","sources":["../../src/security/cors.ts"],"names":[],"mappings":"AASA,MAAM,eAAe,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;AAC7E,MAAM,eAAe,GAAG,CAAC,cAAc,EAAE,eAAe,EAAE,cAAc,CAAC,CAAC;AAE1E,qDAAqD;AACrD,MAAM,UAAU,cAAc,CAC5B,aAA4B,EAC5B,MAAkB;IAElB,MAAM,OAAO,GAA2B,EAAE,CAAC;IAE3C,MAAM,aAAa,GAAG,aAAa,CAAC,aAAa,EAAE,MAAM,CAAC,cAAc,CAAC,CAAC;IAC1E,IAAI,CAAC,aAAa;QAAE,OAAO,OAAO,CAAC;IAEnC,OAAO,CAAC,6BAA6B,CAAC,GAAG,aAAa,CAAC;IACvD,OAAO,CAAC,8BAA8B,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,IAAI,eAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChG,OAAO,CAAC,8BAA8B,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,IAAI,eAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAEhG,IAAI,MAAM,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC;QAClC,OAAO,CAAC,+BAA+B,CAAC,GAAG,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9E,CAAC;IACD,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;QACvB,OAAO,CAAC,kCAAkC,CAAC,GAAG,MAAM,CAAC;IACvD,CAAC;IACD,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAChC,OAAO,CAAC,wBAAwB,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC5D,CAAC;IACD,IAAI,MAAM,CAAC,cAAc,KAAK,GAAG,EAAE,CAAC;QAClC,OAAO,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC;IAC7B,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,aAAa,CACpB,aAA4B,EAC5B,OAAuB;IAEvB,IAAI,OAAO,KAAK,GAAG;QAAE,OAAO,GAAG,CAAC;IAChC,IAAI,CAAC,aAAa;QAAE,OAAO,IAAI,CAAC;IAChC,OAAO,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC;AAChE,CAAC"}
@@ -0,0 +1,5 @@
1
+ /** Generate a cryptographically secure nonce for Content Security Policy inline scripts/styles. */
2
+ export declare function generateCspNonce(): string;
3
+ /** Build a CSP header value incorporating the generated nonce. */
4
+ export declare function buildCspHeader(nonce: string, directives?: Record<string, string[]>): string;
5
+ //# sourceMappingURL=csp-nonces.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"csp-nonces.d.ts","sourceRoot":"","sources":["../../src/security/csp-nonces.ts"],"names":[],"mappings":"AAAA,mGAAmG;AACnG,wBAAgB,gBAAgB,IAAI,MAAM,CAGzC;AAED,kEAAkE;AAClE,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,MAAM,CAiB3F"}
@@ -0,0 +1,24 @@
1
+ /** Generate a cryptographically secure nonce for Content Security Policy inline scripts/styles. */
2
+ export function generateCspNonce() {
3
+ const bytes = crypto.getRandomValues(new Uint8Array(16));
4
+ return btoa(String.fromCharCode(...bytes));
5
+ }
6
+ /** Build a CSP header value incorporating the generated nonce. */
7
+ export function buildCspHeader(nonce, directives) {
8
+ const defaults = {
9
+ "default-src": ["'self'"],
10
+ "script-src": ["'self'", `'nonce-${nonce}'`],
11
+ "style-src": ["'self'", `'nonce-${nonce}'`, "'unsafe-inline'"],
12
+ "img-src": ["'self'", "data:", "https:"],
13
+ "font-src": ["'self'"],
14
+ "connect-src": ["'self'"],
15
+ "frame-ancestors": ["'none'"],
16
+ "base-uri": ["'self'"],
17
+ "form-action": ["'self'"],
18
+ ...directives,
19
+ };
20
+ return Object.entries(defaults)
21
+ .map(([key, values]) => `${key} ${values.join(" ")}`)
22
+ .join("; ");
23
+ }
24
+ //# sourceMappingURL=csp-nonces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"csp-nonces.js","sourceRoot":"","sources":["../../src/security/csp-nonces.ts"],"names":[],"mappings":"AAAA,mGAAmG;AACnG,MAAM,UAAU,gBAAgB;IAC9B,MAAM,KAAK,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;IACzD,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC7C,CAAC;AAED,kEAAkE;AAClE,MAAM,UAAU,cAAc,CAAC,KAAa,EAAE,UAAqC;IACjF,MAAM,QAAQ,GAA6B;QACzC,aAAa,EAAE,CAAC,QAAQ,CAAC;QACzB,YAAY,EAAE,CAAC,QAAQ,EAAE,UAAU,KAAK,GAAG,CAAC;QAC5C,WAAW,EAAE,CAAC,QAAQ,EAAE,UAAU,KAAK,GAAG,EAAE,iBAAiB,CAAC;QAC9D,SAAS,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC;QACxC,UAAU,EAAE,CAAC,QAAQ,CAAC;QACtB,aAAa,EAAE,CAAC,QAAQ,CAAC;QACzB,iBAAiB,EAAE,CAAC,QAAQ,CAAC;QAC7B,UAAU,EAAE,CAAC,QAAQ,CAAC;QACtB,aAAa,EAAE,CAAC,QAAQ,CAAC;QACzB,GAAG,UAAU;KACd,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;SAC5B,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;SACpD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC"}
@@ -0,0 +1,5 @@
1
+ /** Generate a CSRF token using Web Crypto. */
2
+ export declare function generateToken(): Promise<string>;
3
+ /** Validate a submitted CSRF token against the stored value using constant-time comparison. */
4
+ export declare function validateToken(token: string, storedToken: string): boolean;
5
+ //# sourceMappingURL=csrf.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"csrf.d.ts","sourceRoot":"","sources":["../../src/security/csrf.ts"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,wBAAsB,aAAa,IAAI,OAAO,CAAC,MAAM,CAAC,CAKrD;AAED,+FAA+F;AAC/F,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAWzE"}
@@ -0,0 +1,20 @@
1
+ /** Generate a CSRF token using Web Crypto. */
2
+ export async function generateToken() {
3
+ const bytes = crypto.getRandomValues(new Uint8Array(32));
4
+ return Array.from(bytes)
5
+ .map((b) => b.toString(16).padStart(2, "0"))
6
+ .join("");
7
+ }
8
+ /** Validate a submitted CSRF token against the stored value using constant-time comparison. */
9
+ export function validateToken(token, storedToken) {
10
+ if (token.length !== storedToken.length)
11
+ return false;
12
+ const a = new TextEncoder().encode(token);
13
+ const b = new TextEncoder().encode(storedToken);
14
+ let diff = 0;
15
+ for (let i = 0; i < a.length; i++) {
16
+ diff |= (a[i] ?? 0) ^ (b[i] ?? 0);
17
+ }
18
+ return diff === 0;
19
+ }
20
+ //# sourceMappingURL=csrf.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"csrf.js","sourceRoot":"","sources":["../../src/security/csrf.ts"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,MAAM,CAAC,KAAK,UAAU,aAAa;IACjC,MAAM,KAAK,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;IACzD,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;SACrB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SAC3C,IAAI,CAAC,EAAE,CAAC,CAAC;AACd,CAAC;AAED,+FAA+F;AAC/F,MAAM,UAAU,aAAa,CAAC,KAAa,EAAE,WAAmB;IAC9D,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC;IAEtD,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC1C,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;IAEhD,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACpC,CAAC;IACD,OAAO,IAAI,KAAK,CAAC,CAAC;AACpB,CAAC"}
@@ -0,0 +1,5 @@
1
+ /** Encrypt a field value using AES-256-GCM. */
2
+ export declare function encryptField(value: string, keyHex: string): Promise<string>;
3
+ /** Decrypt a field value encrypted with AES-256-GCM. */
4
+ export declare function decryptField(encrypted: string, keyHex: string): Promise<string>;
5
+ //# sourceMappingURL=encrypted-fields.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypted-fields.d.ts","sourceRoot":"","sources":["../../src/security/encrypted-fields.ts"],"names":[],"mappings":"AAIA,+CAA+C;AAC/C,wBAAsB,YAAY,CAChC,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,MAAM,CAAC,CAgBjB;AAED,wDAAwD;AACxD,wBAAsB,YAAY,CAChC,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,MAAM,CAAC,CAajB"}
@@ -0,0 +1,40 @@
1
+ const ALGORITHM = "AES-GCM";
2
+ const IV_LENGTH = 12;
3
+ const TAG_LENGTH = 128;
4
+ /** Encrypt a field value using AES-256-GCM. */
5
+ export async function encryptField(value, keyHex) {
6
+ const key = await importKey(keyHex);
7
+ const iv = crypto.getRandomValues(new Uint8Array(IV_LENGTH));
8
+ const encoded = new TextEncoder().encode(value);
9
+ const ciphertext = await crypto.subtle.encrypt({ name: ALGORITHM, iv, tagLength: TAG_LENGTH }, key, encoded);
10
+ const combined = new Uint8Array(iv.length + ciphertext.byteLength);
11
+ combined.set(iv);
12
+ combined.set(new Uint8Array(ciphertext), iv.length);
13
+ return bufferToHex(combined);
14
+ }
15
+ /** Decrypt a field value encrypted with AES-256-GCM. */
16
+ export async function decryptField(encrypted, keyHex) {
17
+ const key = await importKey(keyHex);
18
+ const data = hexToBuffer(encrypted);
19
+ const iv = data.slice(0, IV_LENGTH);
20
+ const ciphertext = data.slice(IV_LENGTH);
21
+ const decrypted = await crypto.subtle.decrypt({ name: ALGORITHM, iv, tagLength: TAG_LENGTH }, key, ciphertext);
22
+ return new TextDecoder().decode(decrypted);
23
+ }
24
+ async function importKey(keyHex) {
25
+ const keyData = hexToBuffer(keyHex);
26
+ return crypto.subtle.importKey("raw", keyData, ALGORITHM, false, ["encrypt", "decrypt"]);
27
+ }
28
+ function bufferToHex(buffer) {
29
+ return Array.from(buffer)
30
+ .map((b) => b.toString(16).padStart(2, "0"))
31
+ .join("");
32
+ }
33
+ function hexToBuffer(hex) {
34
+ const bytes = new Uint8Array(hex.length / 2);
35
+ for (let i = 0; i < hex.length; i += 2) {
36
+ bytes[i / 2] = parseInt(hex.slice(i, i + 2), 16);
37
+ }
38
+ return bytes;
39
+ }
40
+ //# sourceMappingURL=encrypted-fields.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypted-fields.js","sourceRoot":"","sources":["../../src/security/encrypted-fields.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ export interface SecurityHeadersConfig {
2
+ contentSecurityPolicy?: string;
3
+ strictTransportSecurity?: string;
4
+ xContentTypeOptions?: string;
5
+ xFrameOptions?: string;
6
+ referrerPolicy?: string;
7
+ permissionsPolicy?: string;
8
+ }
9
+ /** Get the default security headers for HTTP responses. */
10
+ export declare function getSecurityHeaders(overrides?: SecurityHeadersConfig): Record<string, string>;
11
+ //# sourceMappingURL=headers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"headers.d.ts","sourceRoot":"","sources":["../../src/security/headers.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,qBAAqB;IACpC,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAWD,2DAA2D;AAC3D,wBAAgB,kBAAkB,CAChC,SAAS,CAAC,EAAE,qBAAqB,GAChC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAuBxB"}
@@ -0,0 +1,32 @@
1
+ const DEFAULT_HEADERS = {
2
+ "X-Content-Type-Options": "nosniff",
3
+ "X-Frame-Options": "DENY",
4
+ "X-XSS-Protection": "0",
5
+ "Referrer-Policy": "strict-origin-when-cross-origin",
6
+ "Strict-Transport-Security": "max-age=63072000; includeSubDomains; preload",
7
+ "Permissions-Policy": "camera=(), microphone=(), geolocation=()",
8
+ };
9
+ /** Get the default security headers for HTTP responses. */
10
+ export function getSecurityHeaders(overrides) {
11
+ const headers = { ...DEFAULT_HEADERS };
12
+ if (overrides?.contentSecurityPolicy) {
13
+ headers["Content-Security-Policy"] = overrides.contentSecurityPolicy;
14
+ }
15
+ if (overrides?.strictTransportSecurity) {
16
+ headers["Strict-Transport-Security"] = overrides.strictTransportSecurity;
17
+ }
18
+ if (overrides?.xContentTypeOptions) {
19
+ headers["X-Content-Type-Options"] = overrides.xContentTypeOptions;
20
+ }
21
+ if (overrides?.xFrameOptions) {
22
+ headers["X-Frame-Options"] = overrides.xFrameOptions;
23
+ }
24
+ if (overrides?.referrerPolicy) {
25
+ headers["Referrer-Policy"] = overrides.referrerPolicy;
26
+ }
27
+ if (overrides?.permissionsPolicy) {
28
+ headers["Permissions-Policy"] = overrides.permissionsPolicy;
29
+ }
30
+ return headers;
31
+ }
32
+ //# sourceMappingURL=headers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"headers.js","sourceRoot":"","sources":["../../src/security/headers.ts"],"names":[],"mappings":"AASA,MAAM,eAAe,GAA2B;IAC9C,wBAAwB,EAAE,SAAS;IACnC,iBAAiB,EAAE,MAAM;IACzB,kBAAkB,EAAE,GAAG;IACvB,iBAAiB,EAAE,iCAAiC;IACpD,2BAA2B,EAAE,8CAA8C;IAC3E,oBAAoB,EAAE,0CAA0C;CACjE,CAAC;AAEF,2DAA2D;AAC3D,MAAM,UAAU,kBAAkB,CAChC,SAAiC;IAEjC,MAAM,OAAO,GAAG,EAAE,GAAG,eAAe,EAAE,CAAC;IAEvC,IAAI,SAAS,EAAE,qBAAqB,EAAE,CAAC;QACrC,OAAO,CAAC,yBAAyB,CAAC,GAAG,SAAS,CAAC,qBAAqB,CAAC;IACvE,CAAC;IACD,IAAI,SAAS,EAAE,uBAAuB,EAAE,CAAC;QACvC,OAAO,CAAC,2BAA2B,CAAC,GAAG,SAAS,CAAC,uBAAuB,CAAC;IAC3E,CAAC;IACD,IAAI,SAAS,EAAE,mBAAmB,EAAE,CAAC;QACnC,OAAO,CAAC,wBAAwB,CAAC,GAAG,SAAS,CAAC,mBAAmB,CAAC;IACpE,CAAC;IACD,IAAI,SAAS,EAAE,aAAa,EAAE,CAAC;QAC7B,OAAO,CAAC,iBAAiB,CAAC,GAAG,SAAS,CAAC,aAAa,CAAC;IACvD,CAAC;IACD,IAAI,SAAS,EAAE,cAAc,EAAE,CAAC;QAC9B,OAAO,CAAC,iBAAiB,CAAC,GAAG,SAAS,CAAC,cAAc,CAAC;IACxD,CAAC;IACD,IAAI,SAAS,EAAE,iBAAiB,EAAE,CAAC;QACjC,OAAO,CAAC,oBAAoB,CAAC,GAAG,SAAS,CAAC,iBAAiB,CAAC;IAC9D,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,31 @@
1
+ export { checkAccess, getPermissionsForRole, filterFieldsByRole, filterWritableFields, applyFieldAccess } from "./access";
2
+ export type { Role, Permission, FieldAccessUser } from "./access";
3
+ export { generateToken as generateCsrfToken, validateToken as validateCsrfToken } from "./csrf";
4
+ export { createRateLimiter } from "./rate-limit";
5
+ export type { RateLimiter, RateLimitConfig, RateLimitResult } from "./rate-limit";
6
+ export { sanitizeHtml, stripHtml } from "./sanitize";
7
+ export { validateMimeType, checkMagicBytes } from "./upload";
8
+ export { validateWebhookUrl, resolveAndCheck } from "./webhook";
9
+ export { logEvent, getAuditLog } from "./audit";
10
+ export type { AuditEntry, AuditLogQuery, AuditLogResult } from "./audit";
11
+ export { getSecurityHeaders } from "./headers";
12
+ export type { SecurityHeadersConfig } from "./headers";
13
+ export { applySecurityMiddleware } from "./middleware";
14
+ export type { SecurityMiddlewareConfig, SecurityMiddlewareResult } from "./middleware";
15
+ export { checkBreached } from "./breach-check";
16
+ export { detectLoginAnomaly, checkBruteForce } from "./anomaly-detection";
17
+ export type { LoginAttempt, AnomalyResult } from "./anomaly-detection";
18
+ export { requiresReauth, verifyReauth } from "./reauth";
19
+ export type { ReauthConfig, ReauthContext } from "./reauth";
20
+ export { isIpAllowed } from "./ip-allowlist";
21
+ export { enforceSessionLimits } from "./session-limits";
22
+ export type { SessionInfo, SessionLimitConfig } from "./session-limits";
23
+ export { encryptField, decryptField } from "./encrypted-fields";
24
+ export { getCorsHeaders } from "./cors";
25
+ export type { CorsConfig } from "./cors";
26
+ export { generateCspNonce, buildCspHeader } from "./csp-nonces";
27
+ export { generateSecurityTxt } from "./security-txt";
28
+ export type { SecurityTxtConfig } from "./security-txt";
29
+ export { generateApiKey, validateApiKeyScope } from "./api-key-enhanced";
30
+ export type { ApiKeyScope, EnhancedApiKeyConfig } from "./api-key-enhanced";
31
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/security/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC1H,YAAY,EAAE,IAAI,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAElE,OAAO,EAAE,aAAa,IAAI,iBAAiB,EAAE,aAAa,IAAI,iBAAiB,EAAE,MAAM,QAAQ,CAAC;AAEhG,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,YAAY,EAAE,WAAW,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAElF,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAErD,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAEhE,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAChD,YAAY,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAC/C,YAAY,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AAEvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,YAAY,EAAE,wBAAwB,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAEvF,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC1E,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEvE,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxD,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE5D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,YAAY,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAExE,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEhE,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,YAAY,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEzC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAEhE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,YAAY,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAExD,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzE,YAAY,EAAE,WAAW,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,20 @@
1
+ export { checkAccess, getPermissionsForRole, filterFieldsByRole, filterWritableFields, applyFieldAccess } from "./access";
2
+ export { generateToken as generateCsrfToken, validateToken as validateCsrfToken } from "./csrf";
3
+ export { createRateLimiter } from "./rate-limit";
4
+ export { sanitizeHtml, stripHtml } from "./sanitize";
5
+ export { validateMimeType, checkMagicBytes } from "./upload";
6
+ export { validateWebhookUrl, resolveAndCheck } from "./webhook";
7
+ export { logEvent, getAuditLog } from "./audit";
8
+ export { getSecurityHeaders } from "./headers";
9
+ export { applySecurityMiddleware } from "./middleware";
10
+ export { checkBreached } from "./breach-check";
11
+ export { detectLoginAnomaly, checkBruteForce } from "./anomaly-detection";
12
+ export { requiresReauth, verifyReauth } from "./reauth";
13
+ export { isIpAllowed } from "./ip-allowlist";
14
+ export { enforceSessionLimits } from "./session-limits";
15
+ export { encryptField, decryptField } from "./encrypted-fields";
16
+ export { getCorsHeaders } from "./cors";
17
+ export { generateCspNonce, buildCspHeader } from "./csp-nonces";
18
+ export { generateSecurityTxt } from "./security-txt";
19
+ export { generateApiKey, validateApiKeyScope } from "./api-key-enhanced";
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/security/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAG1H,OAAO,EAAE,aAAa,IAAI,iBAAiB,EAAE,aAAa,IAAI,iBAAiB,EAAE,MAAM,QAAQ,CAAC;AAEhG,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAGjD,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAErD,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAEhE,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAGhD,OAAO,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAG/C,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAGvD,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAG1E,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAGxD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAGxD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEhE,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AAGxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAEhE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAGrD,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,3 @@
1
+ /** Check whether an IP address is within a list of allowed IPs or CIDR ranges. */
2
+ export declare function isIpAllowed(ip: string, allowlist: string[]): boolean;
3
+ //# sourceMappingURL=ip-allowlist.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ip-allowlist.d.ts","sourceRoot":"","sources":["../../src/security/ip-allowlist.ts"],"names":[],"mappings":"AAAA,kFAAkF;AAClF,wBAAgB,WAAW,CACzB,EAAE,EAAE,MAAM,EACV,SAAS,EAAE,MAAM,EAAE,GAClB,OAAO,CAWT"}
@@ -0,0 +1,35 @@
1
+ /** Check whether an IP address is within a list of allowed IPs or CIDR ranges. */
2
+ export function isIpAllowed(ip, allowlist) {
3
+ if (allowlist.length === 0)
4
+ return true;
5
+ for (const entry of allowlist) {
6
+ if (entry.includes("/")) {
7
+ if (isInCidr(ip, entry))
8
+ return true;
9
+ }
10
+ else if (ip === entry) {
11
+ return true;
12
+ }
13
+ }
14
+ return false;
15
+ }
16
+ function isInCidr(ip, cidr) {
17
+ const [range, bitsStr] = cidr.split("/");
18
+ if (!range || !bitsStr)
19
+ return false;
20
+ const bits = parseInt(bitsStr, 10);
21
+ const ipNum = ipToNumber(ip);
22
+ const rangeNum = ipToNumber(range);
23
+ if (ipNum === null || rangeNum === null)
24
+ return false;
25
+ const mask = ~((1 << (32 - bits)) - 1) >>> 0;
26
+ return (ipNum & mask) === (rangeNum & mask);
27
+ }
28
+ function ipToNumber(ip) {
29
+ const parts = ip.split(".").map(Number);
30
+ if (parts.length !== 4 || parts.some((p) => isNaN(p) || p < 0 || p > 255)) {
31
+ return null;
32
+ }
33
+ return ((parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8) | parts[3]) >>> 0;
34
+ }
35
+ //# sourceMappingURL=ip-allowlist.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ip-allowlist.js","sourceRoot":"","sources":["../../src/security/ip-allowlist.ts"],"names":[],"mappings":"AAAA,kFAAkF;AAClF,MAAM,UAAU,WAAW,CACzB,EAAU,EACV,SAAmB;IAEnB,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAExC,KAAK,MAAM,KAAK,IAAI,SAAS,EAAE,CAAC;QAC9B,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACxB,IAAI,QAAQ,CAAC,EAAE,EAAE,KAAK,CAAC;gBAAE,OAAO,IAAI,CAAC;QACvC,CAAC;aAAM,IAAI,EAAE,KAAK,KAAK,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,QAAQ,CAAC,EAAU,EAAE,IAAY;IACxC,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACzC,IAAI,CAAC,KAAK,IAAI,CAAC,OAAO;QAAE,OAAO,KAAK,CAAC;IAErC,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACnC,MAAM,KAAK,GAAG,UAAU,CAAC,EAAE,CAAC,CAAC;IAC7B,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;IAEnC,IAAI,KAAK,KAAK,IAAI,IAAI,QAAQ,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAEtD,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;IAC7C,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;AAC9C,CAAC;AAED,SAAS,UAAU,CAAC,EAAU;IAC5B,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACxC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC;QAC1E,OAAO,IAAI,CAAC;IACd,CAAC;IACD,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,CAAE,IAAI,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAE,IAAI,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAE,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAE,CAAC,KAAK,CAAC,CAAC;AACtF,CAAC"}