@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":"openapi.js","sourceRoot":"","sources":["../../src/api/openapi.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ export { createSession, verifySession, revokeSession, refreshSession } from "./session";
2
+ export type { SessionPayload, SessionOptions } from "./session";
3
+ export { hashPassword, verifyPassword, validatePasswordPolicy, checkPasswordBreach } from "./password";
4
+ export { generateTOTPSecret, verifyTOTP, generateBackupCodes, generateTOTPUri } from "./totp";
5
+ export { initiateOAuth, handleCallback, linkAccount } from "./oauth";
6
+ export { generateCodeVerifier, generateCodeChallenge, getAuthorizationUrl, exchangeCodeForTokens, getUserProfile, handleOAuthCallback, } from "./oauth";
7
+ export type { OAuthProviderConfig, OAuthProviders, OAuthState, OAuthCallbackResult, OAuthUserProfile } from "./oauth";
8
+ export { googleProvider } from "./providers/google";
9
+ export { githubProvider } from "./providers/github";
10
+ export { microsoftProvider } from "./providers/microsoft";
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACxF,YAAY,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEhE,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEvG,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE9F,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,mBAAmB,EACnB,qBAAqB,EACrB,cAAc,EACd,mBAAmB,GACpB,MAAM,SAAS,CAAC;AACjB,YAAY,EAAE,mBAAmB,EAAE,cAAc,EAAE,UAAU,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEtH,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,9 @@
1
+ export { createSession, verifySession, revokeSession, refreshSession } from "./session";
2
+ export { hashPassword, verifyPassword, validatePasswordPolicy, checkPasswordBreach } from "./password";
3
+ export { generateTOTPSecret, verifyTOTP, generateBackupCodes, generateTOTPUri } from "./totp";
4
+ export { initiateOAuth, handleCallback, linkAccount } from "./oauth";
5
+ export { generateCodeVerifier, generateCodeChallenge, getAuthorizationUrl, exchangeCodeForTokens, getUserProfile, handleOAuthCallback, } from "./oauth";
6
+ export { googleProvider } from "./providers/google";
7
+ export { githubProvider } from "./providers/github";
8
+ export { microsoftProvider } from "./providers/microsoft";
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAGxF,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEvG,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE9F,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,mBAAmB,EACnB,qBAAqB,EACrB,cAAc,EACd,mBAAmB,GACpB,MAAM,SAAS,CAAC;AAGjB,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,84 @@
1
+ import type { AuthProviderConfig } from '../config/types';
2
+ export interface OAuthProviderConfig {
3
+ clientId: string;
4
+ clientSecret: string;
5
+ redirectUri: string;
6
+ }
7
+ export interface OAuthProviders {
8
+ google?: OAuthProviderConfig;
9
+ github?: OAuthProviderConfig;
10
+ microsoft?: OAuthProviderConfig;
11
+ }
12
+ export interface OAuthState {
13
+ provider: string;
14
+ codeVerifier: string;
15
+ returnTo: string;
16
+ }
17
+ export interface OAuthCallbackResult {
18
+ provider: string;
19
+ providerAccountId: string;
20
+ email: string;
21
+ name?: string;
22
+ avatarUrl?: string;
23
+ accessToken: string;
24
+ refreshToken?: string;
25
+ expiresAt?: Date;
26
+ }
27
+ export interface OAuthUserProfile {
28
+ id: string;
29
+ email: string;
30
+ name: string;
31
+ avatar?: string;
32
+ }
33
+ declare const PROVIDER_URLS: {
34
+ readonly google: {
35
+ readonly authorize: "https://accounts.google.com/o/oauth2/v2/auth";
36
+ readonly token: "https://oauth2.googleapis.com/token";
37
+ readonly userinfo: "https://www.googleapis.com/oauth2/v3/userinfo";
38
+ readonly scopes: "openid email profile";
39
+ };
40
+ readonly github: {
41
+ readonly authorize: "https://github.com/login/oauth/authorize";
42
+ readonly token: "https://github.com/login/oauth/access_token";
43
+ readonly userinfo: "https://api.github.com/user";
44
+ readonly scopes: "read:user user:email";
45
+ };
46
+ readonly microsoft: {
47
+ readonly authorize: "https://login.microsoftonline.com/common/oauth2/v2.0/authorize";
48
+ readonly token: "https://login.microsoftonline.com/common/oauth2/v2.0/token";
49
+ readonly userinfo: "https://graph.microsoft.com/v1.0/me";
50
+ readonly scopes: "openid email profile";
51
+ };
52
+ };
53
+ export type OAuthProviderType = keyof typeof PROVIDER_URLS;
54
+ export declare function generateCodeVerifier(): string;
55
+ export declare function generateCodeChallenge(codeVerifier: string): Promise<string>;
56
+ export declare function generateState(provider: string, codeVerifier: string, returnTo: string, secret: string): Promise<string>;
57
+ export declare function verifyState(stateToken: string, secret: string): Promise<OAuthState>;
58
+ export declare function getAuthorizationUrl(provider: OAuthProviderType, config: OAuthProviderConfig, state: string, codeChallenge: string): string;
59
+ export declare function exchangeCodeForTokens(provider: OAuthProviderType, code: string, codeVerifier: string, config: OAuthProviderConfig): Promise<{
60
+ access_token: string;
61
+ id_token?: string;
62
+ refresh_token?: string;
63
+ }>;
64
+ export declare function getUserProfile(provider: OAuthProviderType, accessToken: string): Promise<OAuthUserProfile>;
65
+ export declare function handleOAuthCallback(provider: string, code: string, stateToken: string, providers: OAuthProviders, secret: string, db: any): Promise<{
66
+ token: string;
67
+ user: {
68
+ id: string;
69
+ email: string;
70
+ name: string;
71
+ role: string;
72
+ };
73
+ }>;
74
+ /** @deprecated Use `initiateOAuth` pattern — kept for backward compat with auth/index.ts re-exports */
75
+ export declare function initiateOAuth(_providerConfig: AuthProviderConfig, _callbackUrl: string): Promise<{
76
+ redirectUrl: string;
77
+ state: OAuthState;
78
+ }>;
79
+ /** @deprecated Use `handleOAuthCallback` — kept for backward compat with auth/index.ts re-exports */
80
+ export declare function handleCallback(_providerConfig: AuthProviderConfig, _code: string, _state: OAuthState): Promise<OAuthCallbackResult>;
81
+ /** Link an OAuth account to an existing user. */
82
+ export declare function linkAccount(userId: string, result: OAuthCallbackResult, db: unknown): Promise<void>;
83
+ export {};
84
+ //# sourceMappingURL=oauth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth.d.ts","sourceRoot":"","sources":["../../src/auth/oauth.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,201 @@
1
+ import { SignJWT, jwtVerify } from 'jose';
2
+ import { createSession } from './session';
3
+ const PROVIDER_URLS = {
4
+ google: {
5
+ authorize: 'https://accounts.google.com/o/oauth2/v2/auth',
6
+ token: 'https://oauth2.googleapis.com/token',
7
+ userinfo: 'https://www.googleapis.com/oauth2/v3/userinfo',
8
+ scopes: 'openid email profile',
9
+ },
10
+ github: {
11
+ authorize: 'https://github.com/login/oauth/authorize',
12
+ token: 'https://github.com/login/oauth/access_token',
13
+ userinfo: 'https://api.github.com/user',
14
+ scopes: 'read:user user:email',
15
+ },
16
+ microsoft: {
17
+ authorize: 'https://login.microsoftonline.com/common/oauth2/v2.0/authorize',
18
+ token: 'https://login.microsoftonline.com/common/oauth2/v2.0/token',
19
+ userinfo: 'https://graph.microsoft.com/v1.0/me',
20
+ scopes: 'openid email profile',
21
+ },
22
+ };
23
+ function base64url(buffer) {
24
+ const bytes = new Uint8Array(buffer);
25
+ let binary = '';
26
+ for (let i = 0; i < bytes.length; i++) {
27
+ binary += String.fromCharCode(bytes[i]);
28
+ }
29
+ return btoa(binary).replace(/\+/g, '-').replace(/\//g, '_').replace(/=+$/, '');
30
+ }
31
+ export function generateCodeVerifier() {
32
+ const bytes = crypto.getRandomValues(new Uint8Array(32));
33
+ return base64url(bytes.buffer);
34
+ }
35
+ export async function generateCodeChallenge(codeVerifier) {
36
+ const encoded = new TextEncoder().encode(codeVerifier);
37
+ const digest = await crypto.subtle.digest('SHA-256', encoded);
38
+ return base64url(digest);
39
+ }
40
+ export async function generateState(provider, codeVerifier, returnTo, secret) {
41
+ const secretKey = new TextEncoder().encode(secret);
42
+ return new SignJWT({ provider, codeVerifier, returnTo })
43
+ .setProtectedHeader({ alg: 'HS256' })
44
+ .setIssuedAt()
45
+ .setExpirationTime('10m')
46
+ .setIssuer('actuate-cms')
47
+ .sign(secretKey);
48
+ }
49
+ export async function verifyState(stateToken, secret) {
50
+ const secretKey = new TextEncoder().encode(secret);
51
+ const { payload } = await jwtVerify(stateToken, secretKey, { issuer: 'actuate-cms' });
52
+ return payload;
53
+ }
54
+ export function getAuthorizationUrl(provider, config, state, codeChallenge) {
55
+ const urls = PROVIDER_URLS[provider];
56
+ const params = new URLSearchParams({
57
+ response_type: 'code',
58
+ client_id: config.clientId,
59
+ redirect_uri: config.redirectUri,
60
+ scope: urls.scopes,
61
+ state,
62
+ code_challenge: codeChallenge,
63
+ code_challenge_method: 'S256',
64
+ });
65
+ return `${urls.authorize}?${params.toString()}`;
66
+ }
67
+ export async function exchangeCodeForTokens(provider, code, codeVerifier, config) {
68
+ const urls = PROVIDER_URLS[provider];
69
+ const body = new URLSearchParams({
70
+ grant_type: 'authorization_code',
71
+ code,
72
+ redirect_uri: config.redirectUri,
73
+ client_id: config.clientId,
74
+ client_secret: config.clientSecret,
75
+ code_verifier: codeVerifier,
76
+ });
77
+ const headers = {
78
+ 'Content-Type': 'application/x-www-form-urlencoded',
79
+ };
80
+ if (provider === 'github') {
81
+ headers['Accept'] = 'application/json';
82
+ }
83
+ const response = await fetch(urls.token, { method: 'POST', headers, body: body.toString() });
84
+ if (!response.ok) {
85
+ const text = await response.text();
86
+ throw new Error(`Token exchange failed (${response.status}): ${text}`);
87
+ }
88
+ return response.json();
89
+ }
90
+ export async function getUserProfile(provider, accessToken) {
91
+ const urls = PROVIDER_URLS[provider];
92
+ const response = await fetch(urls.userinfo, {
93
+ headers: { Authorization: `Bearer ${accessToken}` },
94
+ });
95
+ if (!response.ok) {
96
+ throw new Error(`Failed to fetch user profile (${response.status})`);
97
+ }
98
+ const data = await response.json();
99
+ if (provider === 'github') {
100
+ let email = data.email ?? '';
101
+ if (!email) {
102
+ const emailRes = await fetch('https://api.github.com/user/emails', {
103
+ headers: {
104
+ Authorization: `Bearer ${accessToken}`,
105
+ Accept: 'application/vnd.github+json',
106
+ },
107
+ });
108
+ if (emailRes.ok) {
109
+ const emails = await emailRes.json();
110
+ const primary = emails.find((e) => e.primary && e.verified) ?? emails.find((e) => e.verified);
111
+ if (primary)
112
+ email = primary.email;
113
+ }
114
+ }
115
+ return {
116
+ id: String(data.id),
117
+ email,
118
+ name: data.name ?? data.login ?? '',
119
+ avatar: data.avatar_url,
120
+ };
121
+ }
122
+ if (provider === 'microsoft') {
123
+ return {
124
+ id: data.id,
125
+ email: data.mail ?? data.userPrincipalName ?? '',
126
+ name: data.displayName ?? '',
127
+ };
128
+ }
129
+ // Google
130
+ return {
131
+ id: data.sub,
132
+ email: data.email ?? '',
133
+ name: data.name ?? '',
134
+ avatar: data.picture,
135
+ };
136
+ }
137
+ export async function handleOAuthCallback(provider, code, stateToken, providers, secret, db) {
138
+ const state = await verifyState(stateToken, secret);
139
+ if (state.provider !== provider) {
140
+ throw new Error('Provider mismatch in OAuth state');
141
+ }
142
+ const providerType = provider;
143
+ const providerConfig = providers[providerType];
144
+ if (!providerConfig) {
145
+ throw new Error(`OAuth provider "${provider}" is not configured`);
146
+ }
147
+ const tokens = await exchangeCodeForTokens(providerType, code, state.codeVerifier, providerConfig);
148
+ const profile = await getUserProfile(providerType, tokens.access_token);
149
+ if (!profile.email) {
150
+ throw new Error('OAuth provider did not return an email address');
151
+ }
152
+ let user = await db.user.findFirst({
153
+ where: { email: { equals: profile.email.toLowerCase(), mode: 'insensitive' } },
154
+ });
155
+ if (user) {
156
+ await db.user.update({
157
+ where: { id: user.id },
158
+ data: { oauthProvider: provider, oauthId: profile.id },
159
+ });
160
+ }
161
+ else {
162
+ user = await db.user.create({
163
+ data: {
164
+ email: profile.email.toLowerCase(),
165
+ name: profile.name,
166
+ role: 'CLIENT',
167
+ isActive: true,
168
+ oauthProvider: provider,
169
+ oauthId: profile.id,
170
+ passwordHash: '',
171
+ },
172
+ });
173
+ }
174
+ const oauthSession = await db.session.create({
175
+ data: {
176
+ userId: user.id,
177
+ expiresAt: new Date(Date.now() + 7 * 24 * 60 * 60 * 1000),
178
+ },
179
+ });
180
+ const token = await createSession({ userId: user.id, role: user.role, sessionId: oauthSession.id }, { secret });
181
+ return {
182
+ token,
183
+ user: { id: user.id, email: user.email, name: user.name, role: user.role },
184
+ };
185
+ }
186
+ /** @deprecated Use `initiateOAuth` pattern — kept for backward compat with auth/index.ts re-exports */
187
+ export async function initiateOAuth(_providerConfig, _callbackUrl) {
188
+ throw new Error('Use generateState + getAuthorizationUrl instead');
189
+ }
190
+ /** @deprecated Use `handleOAuthCallback` — kept for backward compat with auth/index.ts re-exports */
191
+ export async function handleCallback(_providerConfig, _code, _state) {
192
+ throw new Error('Use handleOAuthCallback instead');
193
+ }
194
+ /** Link an OAuth account to an existing user. */
195
+ export async function linkAccount(userId, result, db) {
196
+ await db.user.update({
197
+ where: { id: userId },
198
+ data: { oauthProvider: result.provider, oauthId: result.providerAccountId },
199
+ });
200
+ }
201
+ //# sourceMappingURL=oauth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../src/auth/oauth.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { PasswordPolicy } from "../config/types";
2
+ /** Hash a password using Web Crypto API (PBKDF2). */
3
+ export declare function hashPassword(password: string): Promise<string>;
4
+ /** Verify a password against its stored hash. */
5
+ export declare function verifyPassword(password: string, storedHash: string): Promise<boolean>;
6
+ /** Validate a password against the configured policy rules. */
7
+ export declare function validatePasswordPolicy(password: string, policy: PasswordPolicy): {
8
+ valid: boolean;
9
+ errors: string[];
10
+ };
11
+ /** Check if a password has appeared in a known data breach (k-anonymity). */
12
+ export { checkBreached as checkPasswordBreach } from '../security/breach-check';
13
+ //# sourceMappingURL=password.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password.d.ts","sourceRoot":"","sources":["../../src/auth/password.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAGtD,qDAAqD;AACrD,wBAAsB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAiBpE;AAED,iDAAiD;AACjD,wBAAsB,cAAc,CAClC,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,OAAO,CAAC,CAqBlB;AAED,+DAA+D;AAC/D,wBAAgB,sBAAsB,CACpC,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,cAAc,GACrB;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,MAAM,EAAE,CAAA;CAAE,CAoBtC;AAED,6EAA6E;AAC7E,OAAO,EAAE,aAAa,IAAI,mBAAmB,EAAE,MAAM,0BAA0B,CAAC"}
@@ -0,0 +1,47 @@
1
+ import { timingSafeEqual } from "node:crypto";
2
+ /** Hash a password using Web Crypto API (PBKDF2). */
3
+ export async function hashPassword(password) {
4
+ const salt = crypto.getRandomValues(new Uint8Array(16));
5
+ const key = await crypto.subtle.importKey("raw", new TextEncoder().encode(password), "PBKDF2", false, ["deriveBits"]);
6
+ const derived = await crypto.subtle.deriveBits({ name: "PBKDF2", salt, iterations: 100_000, hash: "SHA-256" }, key, 256);
7
+ const saltHex = Buffer.from(salt).toString("hex");
8
+ const hashHex = Buffer.from(derived).toString("hex");
9
+ return `pbkdf2:100000:${saltHex}:${hashHex}`;
10
+ }
11
+ /** Verify a password against its stored hash. */
12
+ export async function verifyPassword(password, storedHash) {
13
+ const [, , saltHex, hashHex] = storedHash.split(":");
14
+ if (!saltHex || !hashHex)
15
+ return false;
16
+ const salt = Buffer.from(saltHex, "hex");
17
+ const key = await crypto.subtle.importKey("raw", new TextEncoder().encode(password), "PBKDF2", false, ["deriveBits"]);
18
+ const derived = await crypto.subtle.deriveBits({ name: "PBKDF2", salt, iterations: 100_000, hash: "SHA-256" }, key, 256);
19
+ const derivedBuf = Buffer.from(derived);
20
+ const storedBuf = Buffer.from(hashHex, "hex");
21
+ if (derivedBuf.length !== storedBuf.length)
22
+ return false;
23
+ return timingSafeEqual(derivedBuf, storedBuf);
24
+ }
25
+ /** Validate a password against the configured policy rules. */
26
+ export function validatePasswordPolicy(password, policy) {
27
+ const errors = [];
28
+ if (policy.minLength && password.length < policy.minLength) {
29
+ errors.push(`Password must be at least ${policy.minLength} characters`);
30
+ }
31
+ if (policy.requireUppercase && !/[A-Z]/.test(password)) {
32
+ errors.push("Password must contain an uppercase letter");
33
+ }
34
+ if (policy.requireLowercase && !/[a-z]/.test(password)) {
35
+ errors.push("Password must contain a lowercase letter");
36
+ }
37
+ if (policy.requireNumbers && !/\d/.test(password)) {
38
+ errors.push("Password must contain a digit");
39
+ }
40
+ if (policy.requireSpecialChars && !/[^a-zA-Z0-9]/.test(password)) {
41
+ errors.push("Password must contain a special character");
42
+ }
43
+ return { valid: errors.length === 0, errors };
44
+ }
45
+ /** Check if a password has appeared in a known data breach (k-anonymity). */
46
+ export { checkBreached as checkPasswordBreach } from '../security/breach-check';
47
+ //# sourceMappingURL=password.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password.js","sourceRoot":"","sources":["../../src/auth/password.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type { AuthProviderConfig } from "../../config/types";
2
+ export interface GitHubProviderOptions {
3
+ clientId: string;
4
+ clientSecret: string;
5
+ allowedOrgs?: string[];
6
+ }
7
+ /** Create a GitHub OAuth provider configuration. */
8
+ export declare function githubProvider(options: GitHubProviderOptions): AuthProviderConfig;
9
+ //# sourceMappingURL=github.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../../src/auth/providers/github.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CACxB;AAED,oDAAoD;AACpD,wBAAgB,cAAc,CAAC,OAAO,EAAE,qBAAqB,GAAG,kBAAkB,CAOjF"}
@@ -0,0 +1,10 @@
1
+ /** Create a GitHub OAuth provider configuration. */
2
+ export function githubProvider(options) {
3
+ return {
4
+ id: "github",
5
+ type: "github",
6
+ clientId: options.clientId,
7
+ clientSecret: options.clientSecret,
8
+ };
9
+ }
10
+ //# sourceMappingURL=github.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"github.js","sourceRoot":"","sources":["../../../src/auth/providers/github.ts"],"names":[],"mappings":"AAQA,oDAAoD;AACpD,MAAM,UAAU,cAAc,CAAC,OAA8B;IAC3D,OAAO;QACL,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,YAAY,EAAE,OAAO,CAAC,YAAY;KACnC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { AuthProviderConfig } from "../../config/types";
2
+ export interface GoogleProviderOptions {
3
+ clientId: string;
4
+ clientSecret: string;
5
+ allowedDomains?: string[];
6
+ }
7
+ /** Create a Google OAuth provider configuration. */
8
+ export declare function googleProvider(options: GoogleProviderOptions): AuthProviderConfig;
9
+ //# sourceMappingURL=google.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"google.d.ts","sourceRoot":"","sources":["../../../src/auth/providers/google.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;CAC3B;AAED,oDAAoD;AACpD,wBAAgB,cAAc,CAAC,OAAO,EAAE,qBAAqB,GAAG,kBAAkB,CAOjF"}
@@ -0,0 +1,10 @@
1
+ /** Create a Google OAuth provider configuration. */
2
+ export function googleProvider(options) {
3
+ return {
4
+ id: "google",
5
+ type: "google",
6
+ clientId: options.clientId,
7
+ clientSecret: options.clientSecret,
8
+ };
9
+ }
10
+ //# sourceMappingURL=google.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"google.js","sourceRoot":"","sources":["../../../src/auth/providers/google.ts"],"names":[],"mappings":"AAQA,oDAAoD;AACpD,MAAM,UAAU,cAAc,CAAC,OAA8B;IAC3D,OAAO;QACL,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,YAAY,EAAE,OAAO,CAAC,YAAY;KACnC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { AuthProviderConfig } from "../../config/types";
2
+ export interface MicrosoftProviderOptions {
3
+ clientId: string;
4
+ clientSecret: string;
5
+ tenantId?: string;
6
+ }
7
+ /** Create a Microsoft Entra ID (Azure AD) OAuth provider configuration. */
8
+ export declare function microsoftProvider(options: MicrosoftProviderOptions): AuthProviderConfig;
9
+ //# sourceMappingURL=microsoft.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"microsoft.d.ts","sourceRoot":"","sources":["../../../src/auth/providers/microsoft.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,2EAA2E;AAC3E,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,wBAAwB,GAAG,kBAAkB,CAQvF"}
@@ -0,0 +1,11 @@
1
+ /** Create a Microsoft Entra ID (Azure AD) OAuth provider configuration. */
2
+ export function microsoftProvider(options) {
3
+ return {
4
+ id: "microsoft",
5
+ type: "microsoft",
6
+ clientId: options.clientId,
7
+ clientSecret: options.clientSecret,
8
+ tenantId: options.tenantId,
9
+ };
10
+ }
11
+ //# sourceMappingURL=microsoft.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"microsoft.js","sourceRoot":"","sources":["../../../src/auth/providers/microsoft.ts"],"names":[],"mappings":"AAQA,2EAA2E;AAC3E,MAAM,UAAU,iBAAiB,CAAC,OAAiC;IACjE,OAAO;QACL,EAAE,EAAE,WAAW;QACf,IAAI,EAAE,WAAW;QACjB,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,YAAY,EAAE,OAAO,CAAC,YAAY;QAClC,QAAQ,EAAE,OAAO,CAAC,QAAQ;KAC3B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,21 @@
1
+ export interface SessionPayload {
2
+ userId: string;
3
+ role: string;
4
+ sessionId: string;
5
+ fingerprint?: string;
6
+ }
7
+ export interface SessionOptions {
8
+ secret: string;
9
+ maxAge?: number;
10
+ issuer?: string;
11
+ audience?: string;
12
+ }
13
+ /** Create a signed JWT session token. */
14
+ export declare function createSession(payload: SessionPayload, options: SessionOptions): Promise<string>;
15
+ /** Verify and decode a JWT session token. */
16
+ export declare function verifySession(token: string, options: SessionOptions): Promise<SessionPayload>;
17
+ /** Revoke a session by marking it in the database. */
18
+ export declare function revokeSession(sessionId: string, db: any): Promise<void>;
19
+ /** Refresh a session token, issuing a new JWT with an extended expiry. */
20
+ export declare function refreshSession(token: string, options: SessionOptions): Promise<string>;
21
+ //# sourceMappingURL=session.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/auth/session.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAID,yCAAyC;AACzC,wBAAsB,aAAa,CACjC,OAAO,EAAE,cAAc,EACvB,OAAO,EAAE,cAAc,GACtB,OAAO,CAAC,MAAM,CAAC,CASjB;AAED,6CAA6C;AAC7C,wBAAsB,aAAa,CACjC,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,cAAc,GACtB,OAAO,CAAC,cAAc,CAAC,CAOzB;AAED,sDAAsD;AACtD,wBAAsB,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAK7E;AAED,0EAA0E;AAC1E,wBAAsB,cAAc,CAClC,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,cAAc,GACtB,OAAO,CAAC,MAAM,CAAC,CAGjB"}
@@ -0,0 +1,35 @@
1
+ import * as jose from "jose";
2
+ const DEFAULT_MAX_AGE = 60 * 60 * 24 * 7; // 7 days
3
+ /** Create a signed JWT session token. */
4
+ export async function createSession(payload, options) {
5
+ const secret = new TextEncoder().encode(options.secret);
6
+ return new jose.SignJWT({ ...payload })
7
+ .setProtectedHeader({ alg: "HS256" })
8
+ .setIssuedAt()
9
+ .setExpirationTime(`${options.maxAge ?? DEFAULT_MAX_AGE}s`)
10
+ .setIssuer(options.issuer ?? "actuate-cms")
11
+ .setAudience(options.audience ?? "actuate-cms")
12
+ .sign(secret);
13
+ }
14
+ /** Verify and decode a JWT session token. */
15
+ export async function verifySession(token, options) {
16
+ const secret = new TextEncoder().encode(options.secret);
17
+ const { payload } = await jose.jwtVerify(token, secret, {
18
+ issuer: options.issuer ?? "actuate-cms",
19
+ audience: options.audience ?? "actuate-cms",
20
+ });
21
+ return payload;
22
+ }
23
+ /** Revoke a session by marking it in the database. */
24
+ export async function revokeSession(sessionId, db) {
25
+ await db.session.update({
26
+ where: { id: sessionId },
27
+ data: { revokedAt: new Date() },
28
+ });
29
+ }
30
+ /** Refresh a session token, issuing a new JWT with an extended expiry. */
31
+ export async function refreshSession(token, options) {
32
+ const payload = await verifySession(token, options);
33
+ return createSession(payload, options);
34
+ }
35
+ //# sourceMappingURL=session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/auth/session.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAgB7B,MAAM,eAAe,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS;AAEnD,yCAAyC;AACzC,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,OAAuB,EACvB,OAAuB;IAEvB,MAAM,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACxD,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,GAAG,OAAO,EAAE,CAAC;SACpC,kBAAkB,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;SACpC,WAAW,EAAE;SACb,iBAAiB,CAAC,GAAG,OAAO,CAAC,MAAM,IAAI,eAAe,GAAG,CAAC;SAC1D,SAAS,CAAC,OAAO,CAAC,MAAM,IAAI,aAAa,CAAC;SAC1C,WAAW,CAAC,OAAO,CAAC,QAAQ,IAAI,aAAa,CAAC;SAC9C,IAAI,CAAC,MAAM,CAAC,CAAC;AAClB,CAAC;AAED,6CAA6C;AAC7C,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,KAAa,EACb,OAAuB;IAEvB,MAAM,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACxD,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE;QACtD,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,aAAa;QACvC,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,aAAa;KAC5C,CAAC,CAAC;IACH,OAAO,OAAoC,CAAC;AAC9C,CAAC;AAED,sDAAsD;AACtD,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,SAAiB,EAAE,EAAO;IAC5D,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;QACtB,KAAK,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE;QACxB,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,EAAE;KAChC,CAAC,CAAC;AACL,CAAC;AAED,0EAA0E;AAC1E,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAa,EACb,OAAuB;IAEvB,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACpD,OAAO,aAAa,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;AACzC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare function generateTOTPSecret(): string;
2
+ export declare function generateTOTPUri(secret: string, email: string, issuer?: string): string;
3
+ export declare function verifyTOTP(token: string, secret: string, window?: number): boolean;
4
+ export declare function generateBackupCodes(count?: number): string[];
5
+ //# sourceMappingURL=totp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"totp.d.ts","sourceRoot":"","sources":["../../src/auth/totp.ts"],"names":[],"mappings":"AAKA,wBAAgB,kBAAkB,IAAI,MAAM,CAI3C;AAED,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,SAAgB,GAAG,MAAM,CAE7F;AAED,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,SAAI,GAAG,OAAO,CAQ7E;AA2DD,wBAAgB,mBAAmB,CAAC,KAAK,SAAI,GAAG,MAAM,EAAE,CAQvD"}