@nauth-toolkit/core 0.1.13 → 0.1.17

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 (623) hide show
  1. package/dist/adapters/database-columns.d.ts +70 -0
  2. package/dist/adapters/database-columns.d.ts.map +1 -1
  3. package/dist/adapters/database-columns.js +76 -2
  4. package/dist/adapters/database-columns.js.map +1 -1
  5. package/dist/adapters/express.adapter.d.ts +66 -0
  6. package/dist/adapters/express.adapter.d.ts.map +1 -1
  7. package/dist/adapters/express.adapter.js +80 -0
  8. package/dist/adapters/express.adapter.js.map +1 -1
  9. package/dist/adapters/fastify.adapter.d.ts +42 -0
  10. package/dist/adapters/fastify.adapter.d.ts.map +1 -1
  11. package/dist/adapters/fastify.adapter.js +86 -0
  12. package/dist/adapters/fastify.adapter.js.map +1 -1
  13. package/dist/adapters/index.d.ts +5 -0
  14. package/dist/adapters/index.d.ts.map +1 -1
  15. package/dist/adapters/index.js +9 -0
  16. package/dist/adapters/index.js.map +1 -1
  17. package/dist/adapters/storage.factory.d.ts +107 -0
  18. package/dist/adapters/storage.factory.d.ts.map +1 -1
  19. package/dist/adapters/storage.factory.js +114 -0
  20. package/dist/adapters/storage.factory.js.map +1 -1
  21. package/dist/adapters.d.ts +8 -0
  22. package/dist/adapters.d.ts.map +1 -1
  23. package/dist/adapters.js +8 -0
  24. package/dist/adapters.js.map +1 -1
  25. package/dist/bootstrap.d.ts +82 -0
  26. package/dist/bootstrap.d.ts.map +1 -1
  27. package/dist/bootstrap.js +106 -0
  28. package/dist/bootstrap.js.map +1 -1
  29. package/dist/dto/admin-set-password.dto.d.ts +90 -0
  30. package/dist/dto/admin-set-password.dto.d.ts.map +1 -1
  31. package/dist/dto/admin-set-password.dto.js +91 -0
  32. package/dist/dto/admin-set-password.dto.js.map +1 -1
  33. package/dist/dto/auth-challenge.dto.d.ts +170 -0
  34. package/dist/dto/auth-challenge.dto.d.ts.map +1 -1
  35. package/dist/dto/auth-challenge.dto.js +170 -0
  36. package/dist/dto/auth-challenge.dto.js.map +1 -1
  37. package/dist/dto/auth-response.dto.d.ts +196 -0
  38. package/dist/dto/auth-response.dto.d.ts.map +1 -1
  39. package/dist/dto/auth-response.dto.js +149 -0
  40. package/dist/dto/auth-response.dto.js.map +1 -1
  41. package/dist/dto/challenge-response.dto.d.ts +155 -0
  42. package/dist/dto/challenge-response.dto.d.ts.map +1 -1
  43. package/dist/dto/challenge-response.dto.js +8 -0
  44. package/dist/dto/challenge-response.dto.js.map +1 -1
  45. package/dist/dto/change-password-request.dto.d.ts +35 -0
  46. package/dist/dto/change-password-request.dto.d.ts.map +1 -1
  47. package/dist/dto/change-password-request.dto.js +35 -0
  48. package/dist/dto/change-password-request.dto.js.map +1 -1
  49. package/dist/dto/change-password-response.dto.d.ts +25 -0
  50. package/dist/dto/change-password-response.dto.d.ts.map +1 -1
  51. package/dist/dto/change-password-response.dto.js +25 -0
  52. package/dist/dto/change-password-response.dto.js.map +1 -1
  53. package/dist/dto/change-password.dto.d.ts +45 -0
  54. package/dist/dto/change-password.dto.d.ts.map +1 -1
  55. package/dist/dto/change-password.dto.js +45 -0
  56. package/dist/dto/change-password.dto.js.map +1 -1
  57. package/dist/dto/confirm-forgot-password.dto.d.ts +59 -0
  58. package/dist/dto/confirm-forgot-password.dto.d.ts.map +1 -1
  59. package/dist/dto/confirm-forgot-password.dto.js +59 -0
  60. package/dist/dto/confirm-forgot-password.dto.js.map +1 -1
  61. package/dist/dto/error-response.dto.d.ts +103 -0
  62. package/dist/dto/error-response.dto.d.ts.map +1 -1
  63. package/dist/dto/error-response.dto.js +103 -0
  64. package/dist/dto/error-response.dto.js.map +1 -1
  65. package/dist/dto/forgot-password.dto.d.ts +58 -0
  66. package/dist/dto/forgot-password.dto.d.ts.map +1 -1
  67. package/dist/dto/forgot-password.dto.js +58 -0
  68. package/dist/dto/forgot-password.dto.js.map +1 -1
  69. package/dist/dto/get-available-methods.dto.d.ts +37 -0
  70. package/dist/dto/get-available-methods.dto.d.ts.map +1 -1
  71. package/dist/dto/get-available-methods.dto.js +37 -0
  72. package/dist/dto/get-available-methods.dto.js.map +1 -1
  73. package/dist/dto/get-challenge-data-response.dto.d.ts +24 -0
  74. package/dist/dto/get-challenge-data-response.dto.d.ts.map +1 -1
  75. package/dist/dto/get-challenge-data-response.dto.js +24 -0
  76. package/dist/dto/get-challenge-data-response.dto.js.map +1 -1
  77. package/dist/dto/get-challenge-data.dto.d.ts +46 -0
  78. package/dist/dto/get-challenge-data.dto.d.ts.map +1 -1
  79. package/dist/dto/get-challenge-data.dto.js +46 -0
  80. package/dist/dto/get-challenge-data.dto.js.map +1 -1
  81. package/dist/dto/get-client-info.dto.d.ts +74 -0
  82. package/dist/dto/get-client-info.dto.d.ts.map +1 -1
  83. package/dist/dto/get-client-info.dto.js +74 -0
  84. package/dist/dto/get-client-info.dto.js.map +1 -1
  85. package/dist/dto/get-device-token-response.dto.d.ts +21 -0
  86. package/dist/dto/get-device-token-response.dto.d.ts.map +1 -1
  87. package/dist/dto/get-device-token-response.dto.js +21 -0
  88. package/dist/dto/get-device-token-response.dto.js.map +1 -1
  89. package/dist/dto/get-events-by-type.dto.d.ts +50 -0
  90. package/dist/dto/get-events-by-type.dto.d.ts.map +1 -1
  91. package/dist/dto/get-events-by-type.dto.js +50 -0
  92. package/dist/dto/get-events-by-type.dto.js.map +1 -1
  93. package/dist/dto/get-ip-address-response.dto.d.ts +20 -0
  94. package/dist/dto/get-ip-address-response.dto.d.ts.map +1 -1
  95. package/dist/dto/get-ip-address-response.dto.js +20 -0
  96. package/dist/dto/get-ip-address-response.dto.js.map +1 -1
  97. package/dist/dto/get-mfa-status.dto.d.ts +59 -0
  98. package/dist/dto/get-mfa-status.dto.d.ts.map +1 -1
  99. package/dist/dto/get-mfa-status.dto.js +59 -0
  100. package/dist/dto/get-mfa-status.dto.js.map +1 -1
  101. package/dist/dto/get-risk-assessment-history.dto.d.ts +28 -0
  102. package/dist/dto/get-risk-assessment-history.dto.d.ts.map +1 -1
  103. package/dist/dto/get-risk-assessment-history.dto.js +28 -0
  104. package/dist/dto/get-risk-assessment-history.dto.js.map +1 -1
  105. package/dist/dto/get-session-id-response.dto.d.ts +21 -0
  106. package/dist/dto/get-session-id-response.dto.d.ts.map +1 -1
  107. package/dist/dto/get-session-id-response.dto.js +21 -0
  108. package/dist/dto/get-session-id-response.dto.js.map +1 -1
  109. package/dist/dto/get-setup-data-response.dto.d.ts +27 -0
  110. package/dist/dto/get-setup-data-response.dto.d.ts.map +1 -1
  111. package/dist/dto/get-setup-data-response.dto.js +27 -0
  112. package/dist/dto/get-setup-data-response.dto.js.map +1 -1
  113. package/dist/dto/get-setup-data.dto.d.ts +51 -0
  114. package/dist/dto/get-setup-data.dto.d.ts.map +1 -1
  115. package/dist/dto/get-setup-data.dto.js +51 -0
  116. package/dist/dto/get-setup-data.dto.js.map +1 -1
  117. package/dist/dto/get-suspicious-activity.dto.d.ts +31 -0
  118. package/dist/dto/get-suspicious-activity.dto.d.ts.map +1 -1
  119. package/dist/dto/get-suspicious-activity.dto.js +31 -0
  120. package/dist/dto/get-suspicious-activity.dto.js.map +1 -1
  121. package/dist/dto/get-user-agent-response.dto.d.ts +19 -0
  122. package/dist/dto/get-user-agent-response.dto.d.ts.map +1 -1
  123. package/dist/dto/get-user-agent-response.dto.js +19 -0
  124. package/dist/dto/get-user-agent-response.dto.js.map +1 -1
  125. package/dist/dto/get-user-auth-history.dto.d.ts +64 -0
  126. package/dist/dto/get-user-auth-history.dto.d.ts.map +1 -1
  127. package/dist/dto/get-user-auth-history.dto.js +64 -0
  128. package/dist/dto/get-user-auth-history.dto.js.map +1 -1
  129. package/dist/dto/get-user-by-email.dto.d.ts +42 -0
  130. package/dist/dto/get-user-by-email.dto.d.ts.map +1 -1
  131. package/dist/dto/get-user-by-email.dto.js +42 -0
  132. package/dist/dto/get-user-by-email.dto.js.map +1 -1
  133. package/dist/dto/get-user-by-id.dto.d.ts +32 -0
  134. package/dist/dto/get-user-by-id.dto.d.ts.map +1 -1
  135. package/dist/dto/get-user-by-id.dto.js +32 -0
  136. package/dist/dto/get-user-by-id.dto.js.map +1 -1
  137. package/dist/dto/get-user-devices.dto.d.ts +34 -0
  138. package/dist/dto/get-user-devices.dto.d.ts.map +1 -1
  139. package/dist/dto/get-user-devices.dto.js +34 -0
  140. package/dist/dto/get-user-devices.dto.js.map +1 -1
  141. package/dist/dto/get-user-response.dto.d.ts +14 -0
  142. package/dist/dto/get-user-response.dto.d.ts.map +1 -1
  143. package/dist/dto/get-user-response.dto.js +15 -0
  144. package/dist/dto/get-user-response.dto.js.map +1 -1
  145. package/dist/dto/has-provider.dto.d.ts +33 -0
  146. package/dist/dto/has-provider.dto.d.ts.map +1 -1
  147. package/dist/dto/has-provider.dto.js +33 -0
  148. package/dist/dto/has-provider.dto.js.map +1 -1
  149. package/dist/dto/index.js +5 -0
  150. package/dist/dto/index.js.map +1 -1
  151. package/dist/dto/is-trusted-device-response.dto.d.ts +28 -0
  152. package/dist/dto/is-trusted-device-response.dto.d.ts.map +1 -1
  153. package/dist/dto/is-trusted-device-response.dto.js +28 -0
  154. package/dist/dto/is-trusted-device-response.dto.js.map +1 -1
  155. package/dist/dto/list-providers-response.dto.d.ts +19 -0
  156. package/dist/dto/list-providers-response.dto.d.ts.map +1 -1
  157. package/dist/dto/list-providers-response.dto.js +19 -0
  158. package/dist/dto/list-providers-response.dto.js.map +1 -1
  159. package/dist/dto/login.dto.d.ts +48 -0
  160. package/dist/dto/login.dto.d.ts.map +1 -1
  161. package/dist/dto/login.dto.js +50 -1
  162. package/dist/dto/login.dto.js.map +1 -1
  163. package/dist/dto/logout-all-response.dto.d.ts +20 -0
  164. package/dist/dto/logout-all-response.dto.d.ts.map +1 -1
  165. package/dist/dto/logout-all-response.dto.js +20 -0
  166. package/dist/dto/logout-all-response.dto.js.map +1 -1
  167. package/dist/dto/logout-all.dto.d.ts +42 -0
  168. package/dist/dto/logout-all.dto.d.ts.map +1 -1
  169. package/dist/dto/logout-all.dto.js +42 -0
  170. package/dist/dto/logout-all.dto.js.map +1 -1
  171. package/dist/dto/logout-response.dto.d.ts +21 -0
  172. package/dist/dto/logout-response.dto.d.ts.map +1 -1
  173. package/dist/dto/logout-response.dto.js +21 -0
  174. package/dist/dto/logout-response.dto.js.map +1 -1
  175. package/dist/dto/logout.dto.d.ts +45 -0
  176. package/dist/dto/logout.dto.d.ts.map +1 -1
  177. package/dist/dto/logout.dto.js +45 -0
  178. package/dist/dto/logout.dto.js.map +1 -1
  179. package/dist/dto/refresh-token.dto.d.ts +28 -0
  180. package/dist/dto/refresh-token.dto.d.ts.map +1 -1
  181. package/dist/dto/refresh-token.dto.js +28 -0
  182. package/dist/dto/refresh-token.dto.js.map +1 -1
  183. package/dist/dto/remove-devices.dto.d.ts +51 -0
  184. package/dist/dto/remove-devices.dto.d.ts.map +1 -1
  185. package/dist/dto/remove-devices.dto.js +51 -0
  186. package/dist/dto/remove-devices.dto.js.map +1 -1
  187. package/dist/dto/resend-code-response.dto.d.ts +28 -0
  188. package/dist/dto/resend-code-response.dto.d.ts.map +1 -1
  189. package/dist/dto/resend-code-response.dto.js +28 -0
  190. package/dist/dto/resend-code-response.dto.js.map +1 -1
  191. package/dist/dto/resend-code.dto.d.ts +37 -0
  192. package/dist/dto/resend-code.dto.d.ts.map +1 -1
  193. package/dist/dto/resend-code.dto.js +37 -0
  194. package/dist/dto/resend-code.dto.js.map +1 -1
  195. package/dist/dto/reset-password.dto.d.ts +74 -0
  196. package/dist/dto/reset-password.dto.d.ts.map +1 -1
  197. package/dist/dto/reset-password.dto.js +76 -1
  198. package/dist/dto/reset-password.dto.js.map +1 -1
  199. package/dist/dto/respond-challenge.dto.d.ts +147 -0
  200. package/dist/dto/respond-challenge.dto.d.ts.map +1 -1
  201. package/dist/dto/respond-challenge.dto.js +162 -0
  202. package/dist/dto/respond-challenge.dto.js.map +1 -1
  203. package/dist/dto/set-mfa-exemption.dto.d.ts +65 -0
  204. package/dist/dto/set-mfa-exemption.dto.d.ts.map +1 -1
  205. package/dist/dto/set-mfa-exemption.dto.js +65 -0
  206. package/dist/dto/set-mfa-exemption.dto.js.map +1 -1
  207. package/dist/dto/set-must-change-password-response.dto.d.ts +23 -0
  208. package/dist/dto/set-must-change-password-response.dto.d.ts.map +1 -1
  209. package/dist/dto/set-must-change-password-response.dto.js +23 -0
  210. package/dist/dto/set-must-change-password-response.dto.js.map +1 -1
  211. package/dist/dto/set-must-change-password.dto.d.ts +32 -0
  212. package/dist/dto/set-must-change-password.dto.d.ts.map +1 -1
  213. package/dist/dto/set-must-change-password.dto.js +32 -0
  214. package/dist/dto/set-must-change-password.dto.js.map +1 -1
  215. package/dist/dto/set-preferred-method.dto.d.ts +48 -0
  216. package/dist/dto/set-preferred-method.dto.d.ts.map +1 -1
  217. package/dist/dto/set-preferred-method.dto.js +48 -0
  218. package/dist/dto/set-preferred-method.dto.js.map +1 -1
  219. package/dist/dto/setup-mfa.dto.d.ts +62 -0
  220. package/dist/dto/setup-mfa.dto.d.ts.map +1 -1
  221. package/dist/dto/setup-mfa.dto.js +62 -0
  222. package/dist/dto/setup-mfa.dto.js.map +1 -1
  223. package/dist/dto/signup.dto.d.ts +92 -0
  224. package/dist/dto/signup.dto.d.ts.map +1 -1
  225. package/dist/dto/signup.dto.js +93 -0
  226. package/dist/dto/signup.dto.js.map +1 -1
  227. package/dist/dto/social-auth.dto.d.ts +234 -0
  228. package/dist/dto/social-auth.dto.d.ts.map +1 -1
  229. package/dist/dto/social-auth.dto.js +234 -0
  230. package/dist/dto/social-auth.dto.js.map +1 -1
  231. package/dist/dto/trust-device-response.dto.d.ts +26 -0
  232. package/dist/dto/trust-device-response.dto.d.ts.map +1 -1
  233. package/dist/dto/trust-device-response.dto.js +26 -0
  234. package/dist/dto/trust-device-response.dto.js.map +1 -1
  235. package/dist/dto/trust-device.dto.d.ts +9 -0
  236. package/dist/dto/trust-device.dto.d.ts.map +1 -1
  237. package/dist/dto/trust-device.dto.js +9 -0
  238. package/dist/dto/trust-device.dto.js.map +1 -1
  239. package/dist/dto/update-user-attributes-request.dto.d.ts +36 -0
  240. package/dist/dto/update-user-attributes-request.dto.d.ts.map +1 -1
  241. package/dist/dto/update-user-attributes-request.dto.js +36 -0
  242. package/dist/dto/update-user-attributes-request.dto.js.map +1 -1
  243. package/dist/dto/user-response.dto.d.ts +81 -0
  244. package/dist/dto/user-response.dto.d.ts.map +1 -1
  245. package/dist/dto/user-response.dto.js +84 -2
  246. package/dist/dto/user-response.dto.js.map +1 -1
  247. package/dist/dto/user-update.dto.d.ts +132 -0
  248. package/dist/dto/user-update.dto.d.ts.map +1 -1
  249. package/dist/dto/user-update.dto.js +133 -0
  250. package/dist/dto/user-update.dto.js.map +1 -1
  251. package/dist/dto/verify-email.dto.d.ts +171 -0
  252. package/dist/dto/verify-email.dto.d.ts.map +1 -1
  253. package/dist/dto/verify-email.dto.js +173 -1
  254. package/dist/dto/verify-email.dto.js.map +1 -1
  255. package/dist/dto/verify-mfa-code.dto.d.ts +65 -0
  256. package/dist/dto/verify-mfa-code.dto.d.ts.map +1 -1
  257. package/dist/dto/verify-mfa-code.dto.js +65 -0
  258. package/dist/dto/verify-mfa-code.dto.js.map +1 -1
  259. package/dist/dto/verify-phone-by-sub.dto.d.ts +49 -0
  260. package/dist/dto/verify-phone-by-sub.dto.d.ts.map +1 -1
  261. package/dist/dto/verify-phone-by-sub.dto.js +49 -0
  262. package/dist/dto/verify-phone-by-sub.dto.js.map +1 -1
  263. package/dist/dto/verify-phone.dto.d.ts +139 -0
  264. package/dist/dto/verify-phone.dto.d.ts.map +1 -1
  265. package/dist/dto/verify-phone.dto.js +142 -1
  266. package/dist/dto/verify-phone.dto.js.map +1 -1
  267. package/dist/dto.d.ts +10 -0
  268. package/dist/dto.d.ts.map +1 -1
  269. package/dist/dto.js +10 -0
  270. package/dist/dto.js.map +1 -1
  271. package/dist/entities/auth-audit.entity.d.ts +159 -0
  272. package/dist/entities/auth-audit.entity.d.ts.map +1 -1
  273. package/dist/entities/auth-audit.entity.js +166 -0
  274. package/dist/entities/auth-audit.entity.js.map +1 -1
  275. package/dist/entities/challenge-session.entity.d.ts +87 -0
  276. package/dist/entities/challenge-session.entity.d.ts.map +1 -1
  277. package/dist/entities/challenge-session.entity.js +87 -0
  278. package/dist/entities/challenge-session.entity.js.map +1 -1
  279. package/dist/entities/index.d.ts +18 -0
  280. package/dist/entities/index.d.ts.map +1 -1
  281. package/dist/entities/index.js +18 -0
  282. package/dist/entities/index.js.map +1 -1
  283. package/dist/entities/login-attempt.entity.d.ts +43 -0
  284. package/dist/entities/login-attempt.entity.d.ts.map +1 -1
  285. package/dist/entities/login-attempt.entity.js +43 -0
  286. package/dist/entities/login-attempt.entity.js.map +1 -1
  287. package/dist/entities/mfa-device.entity.d.ts +112 -0
  288. package/dist/entities/mfa-device.entity.d.ts.map +1 -1
  289. package/dist/entities/mfa-device.entity.js +112 -0
  290. package/dist/entities/mfa-device.entity.js.map +1 -1
  291. package/dist/entities/rate-limit.entity.d.ts +31 -0
  292. package/dist/entities/rate-limit.entity.d.ts.map +1 -1
  293. package/dist/entities/rate-limit.entity.js +31 -0
  294. package/dist/entities/rate-limit.entity.js.map +1 -1
  295. package/dist/entities/session.entity.d.ts +121 -0
  296. package/dist/entities/session.entity.d.ts.map +1 -1
  297. package/dist/entities/session.entity.js +121 -0
  298. package/dist/entities/session.entity.js.map +1 -1
  299. package/dist/entities/social-account.entity.d.ts +75 -0
  300. package/dist/entities/social-account.entity.d.ts.map +1 -1
  301. package/dist/entities/social-account.entity.js +75 -0
  302. package/dist/entities/social-account.entity.js.map +1 -1
  303. package/dist/entities/storage-lock.entity.d.ts +28 -0
  304. package/dist/entities/storage-lock.entity.d.ts.map +1 -1
  305. package/dist/entities/storage-lock.entity.js +28 -0
  306. package/dist/entities/storage-lock.entity.js.map +1 -1
  307. package/dist/entities/trusted-device.entity.d.ts +83 -0
  308. package/dist/entities/trusted-device.entity.d.ts.map +1 -1
  309. package/dist/entities/trusted-device.entity.js +83 -0
  310. package/dist/entities/trusted-device.entity.js.map +1 -1
  311. package/dist/entities/user.entity.d.ts +166 -0
  312. package/dist/entities/user.entity.d.ts.map +1 -1
  313. package/dist/entities/user.entity.js +166 -0
  314. package/dist/entities/user.entity.js.map +1 -1
  315. package/dist/entities/verification-token.entity.d.ts +102 -0
  316. package/dist/entities/verification-token.entity.d.ts.map +1 -1
  317. package/dist/entities/verification-token.entity.js +102 -0
  318. package/dist/entities/verification-token.entity.js.map +1 -1
  319. package/dist/entities.d.ts +8 -0
  320. package/dist/entities.d.ts.map +1 -1
  321. package/dist/entities.js +8 -0
  322. package/dist/entities.js.map +1 -1
  323. package/dist/enums/auth-audit-event-type.enum.d.ts +211 -0
  324. package/dist/enums/auth-audit-event-type.enum.d.ts.map +1 -1
  325. package/dist/enums/auth-audit-event-type.enum.js +244 -0
  326. package/dist/enums/auth-audit-event-type.enum.js.map +1 -1
  327. package/dist/enums/error-codes.enum.d.ts +296 -0
  328. package/dist/enums/error-codes.enum.d.ts.map +1 -1
  329. package/dist/enums/error-codes.enum.js +332 -0
  330. package/dist/enums/error-codes.enum.js.map +1 -1
  331. package/dist/enums/mfa-method.enum.d.ts +74 -0
  332. package/dist/enums/mfa-method.enum.d.ts.map +1 -1
  333. package/dist/enums/mfa-method.enum.js +64 -0
  334. package/dist/enums/mfa-method.enum.js.map +1 -1
  335. package/dist/enums/risk-factor.enum.d.ts +91 -0
  336. package/dist/enums/risk-factor.enum.d.ts.map +1 -1
  337. package/dist/enums/risk-factor.enum.js +97 -0
  338. package/dist/enums/risk-factor.enum.js.map +1 -1
  339. package/dist/exceptions/nauth.exception.d.ts +149 -0
  340. package/dist/exceptions/nauth.exception.d.ts.map +1 -1
  341. package/dist/exceptions/nauth.exception.js +159 -0
  342. package/dist/exceptions/nauth.exception.js.map +1 -1
  343. package/dist/handlers/auth.handler.d.ts +32 -0
  344. package/dist/handlers/auth.handler.d.ts.map +1 -1
  345. package/dist/handlers/auth.handler.js +47 -1
  346. package/dist/handlers/auth.handler.js.map +1 -1
  347. package/dist/handlers/client-info.handler.d.ts +25 -0
  348. package/dist/handlers/client-info.handler.d.ts.map +1 -1
  349. package/dist/handlers/client-info.handler.js +36 -2
  350. package/dist/handlers/client-info.handler.js.map +1 -1
  351. package/dist/handlers/csrf.handler.d.ts +32 -0
  352. package/dist/handlers/csrf.handler.d.ts.map +1 -1
  353. package/dist/handlers/csrf.handler.js +49 -1
  354. package/dist/handlers/csrf.handler.js.map +1 -1
  355. package/dist/handlers/token-delivery.handler.d.ts +16 -0
  356. package/dist/handlers/token-delivery.handler.d.ts.map +1 -1
  357. package/dist/handlers/token-delivery.handler.js +22 -1
  358. package/dist/handlers/token-delivery.handler.js.map +1 -1
  359. package/dist/index.d.ts +34 -0
  360. package/dist/index.d.ts.map +1 -1
  361. package/dist/index.js +67 -0
  362. package/dist/index.js.map +1 -1
  363. package/dist/interfaces/client-info.interface.d.ts +58 -0
  364. package/dist/interfaces/client-info.interface.d.ts.map +1 -1
  365. package/dist/interfaces/config.interface.d.ts +1774 -0
  366. package/dist/interfaces/config.interface.d.ts.map +1 -1
  367. package/dist/interfaces/config.interface.js +16 -0
  368. package/dist/interfaces/config.interface.js.map +1 -1
  369. package/dist/interfaces/entities.interface.d.ts +48 -0
  370. package/dist/interfaces/entities.interface.d.ts.map +1 -1
  371. package/dist/interfaces/entities.interface.js +8 -0
  372. package/dist/interfaces/entities.interface.js.map +1 -1
  373. package/dist/interfaces/index.js +5 -0
  374. package/dist/interfaces/index.js.map +1 -1
  375. package/dist/interfaces/logger.interface.d.ts +213 -0
  376. package/dist/interfaces/logger.interface.d.ts.map +1 -1
  377. package/dist/interfaces/logger.interface.js +35 -0
  378. package/dist/interfaces/logger.interface.js.map +1 -1
  379. package/dist/interfaces/mfa-provider.interface.d.ts +134 -0
  380. package/dist/interfaces/mfa-provider.interface.d.ts.map +1 -1
  381. package/dist/interfaces/oauth.interface.d.ts +110 -0
  382. package/dist/interfaces/oauth.interface.d.ts.map +1 -1
  383. package/dist/interfaces/provider.interface.d.ts +83 -0
  384. package/dist/interfaces/provider.interface.d.ts.map +1 -1
  385. package/dist/interfaces/sms-template.interface.d.ts +246 -0
  386. package/dist/interfaces/sms-template.interface.d.ts.map +1 -1
  387. package/dist/interfaces/sms-template.interface.js +26 -0
  388. package/dist/interfaces/sms-template.interface.js.map +1 -1
  389. package/dist/interfaces/social-auth-provider.interface.d.ts +115 -0
  390. package/dist/interfaces/social-auth-provider.interface.d.ts.map +1 -1
  391. package/dist/interfaces/storage-adapter.interface.d.ts +37 -0
  392. package/dist/interfaces/storage-adapter.interface.d.ts.map +1 -1
  393. package/dist/interfaces/template.interface.d.ts +351 -0
  394. package/dist/interfaces/template.interface.d.ts.map +1 -1
  395. package/dist/interfaces/template.interface.js +13 -0
  396. package/dist/interfaces/template.interface.js.map +1 -1
  397. package/dist/interfaces/token-verifier.interface.d.ts +101 -0
  398. package/dist/interfaces/token-verifier.interface.d.ts.map +1 -1
  399. package/dist/interfaces.d.ts +8 -0
  400. package/dist/interfaces.d.ts.map +1 -1
  401. package/dist/interfaces.js +8 -0
  402. package/dist/interfaces.js.map +1 -1
  403. package/dist/internal.d.ts +120 -0
  404. package/dist/internal.d.ts.map +1 -1
  405. package/dist/internal.js +138 -0
  406. package/dist/internal.js.map +1 -1
  407. package/dist/platform/interfaces.d.ts +187 -0
  408. package/dist/platform/interfaces.d.ts.map +1 -1
  409. package/dist/platform/interfaces.js +11 -0
  410. package/dist/platform/interfaces.js.map +1 -1
  411. package/dist/schemas/auth-config.schema.d.ts +48 -0
  412. package/dist/schemas/auth-config.schema.d.ts.map +1 -1
  413. package/dist/schemas/auth-config.schema.js +188 -9
  414. package/dist/schemas/auth-config.schema.js.map +1 -1
  415. package/dist/services/adaptive-mfa-decision.service.d.ts +144 -0
  416. package/dist/services/adaptive-mfa-decision.service.d.ts.map +1 -1
  417. package/dist/services/adaptive-mfa-decision.service.js +151 -5
  418. package/dist/services/adaptive-mfa-decision.service.js.map +1 -1
  419. package/dist/services/auth-audit.service.d.ts +195 -0
  420. package/dist/services/auth-audit.service.d.ts.map +1 -1
  421. package/dist/services/auth-audit.service.js +228 -1
  422. package/dist/services/auth-audit.service.js.map +1 -1
  423. package/dist/services/auth-challenge-helper.service.d.ts +144 -1
  424. package/dist/services/auth-challenge-helper.service.d.ts.map +1 -1
  425. package/dist/services/auth-challenge-helper.service.js +295 -16
  426. package/dist/services/auth-challenge-helper.service.js.map +1 -1
  427. package/dist/services/auth-flow-context-builder.service.d.ts +120 -1
  428. package/dist/services/auth-flow-context-builder.service.d.ts.map +1 -1
  429. package/dist/services/auth-flow-context-builder.service.js +184 -5
  430. package/dist/services/auth-flow-context-builder.service.js.map +1 -1
  431. package/dist/services/auth-flow-rules.d.ts +136 -0
  432. package/dist/services/auth-flow-rules.d.ts.map +1 -1
  433. package/dist/services/auth-flow-rules.js +137 -0
  434. package/dist/services/auth-flow-rules.js.map +1 -1
  435. package/dist/services/auth-flow-state-definitions.d.ts +40 -0
  436. package/dist/services/auth-flow-state-definitions.d.ts.map +1 -1
  437. package/dist/services/auth-flow-state-definitions.js +98 -0
  438. package/dist/services/auth-flow-state-definitions.js.map +1 -1
  439. package/dist/services/auth-flow-state-machine.service.d.ts +91 -0
  440. package/dist/services/auth-flow-state-machine.service.d.ts.map +1 -1
  441. package/dist/services/auth-flow-state-machine.service.js +102 -0
  442. package/dist/services/auth-flow-state-machine.service.js.map +1 -1
  443. package/dist/services/auth-flow-state-machine.types.d.ts +221 -0
  444. package/dist/services/auth-flow-state-machine.types.d.ts.map +1 -1
  445. package/dist/services/auth-flow-state-machine.types.js +47 -0
  446. package/dist/services/auth-flow-state-machine.types.js.map +1 -1
  447. package/dist/services/auth.service.d.ts +397 -1
  448. package/dist/services/auth.service.d.ts.map +1 -1
  449. package/dist/services/auth.service.js +943 -27
  450. package/dist/services/auth.service.js.map +1 -1
  451. package/dist/services/challenge.service.d.ts +255 -1
  452. package/dist/services/challenge.service.d.ts.map +1 -1
  453. package/dist/services/challenge.service.js +327 -3
  454. package/dist/services/challenge.service.js.map +1 -1
  455. package/dist/services/client-info.service.d.ts +143 -0
  456. package/dist/services/client-info.service.d.ts.map +1 -1
  457. package/dist/services/client-info.service.js +161 -0
  458. package/dist/services/client-info.service.js.map +1 -1
  459. package/dist/services/csrf.service.d.ts +15 -0
  460. package/dist/services/csrf.service.d.ts.map +1 -1
  461. package/dist/services/csrf.service.js +16 -0
  462. package/dist/services/csrf.service.js.map +1 -1
  463. package/dist/services/email-verification.service.d.ts +52 -0
  464. package/dist/services/email-verification.service.d.ts.map +1 -1
  465. package/dist/services/email-verification.service.js +149 -10
  466. package/dist/services/email-verification.service.js.map +1 -1
  467. package/dist/services/geo-location.service.d.ts +105 -0
  468. package/dist/services/geo-location.service.d.ts.map +1 -1
  469. package/dist/services/geo-location.service.js +188 -2
  470. package/dist/services/geo-location.service.js.map +1 -1
  471. package/dist/services/jwt.service.d.ts +257 -0
  472. package/dist/services/jwt.service.d.ts.map +1 -1
  473. package/dist/services/jwt.service.js +284 -1
  474. package/dist/services/jwt.service.js.map +1 -1
  475. package/dist/services/mfa-base.service.d.ts +179 -1
  476. package/dist/services/mfa-base.service.d.ts.map +1 -1
  477. package/dist/services/mfa-base.service.js +256 -2
  478. package/dist/services/mfa-base.service.js.map +1 -1
  479. package/dist/services/mfa.service.d.ts +304 -0
  480. package/dist/services/mfa.service.d.ts.map +1 -1
  481. package/dist/services/mfa.service.js +380 -0
  482. package/dist/services/mfa.service.js.map +1 -1
  483. package/dist/services/password-reset.service.d.ts +46 -0
  484. package/dist/services/password-reset.service.d.ts.map +1 -1
  485. package/dist/services/password-reset.service.js +79 -0
  486. package/dist/services/password-reset.service.js.map +1 -1
  487. package/dist/services/password.service.d.ts +139 -0
  488. package/dist/services/password.service.d.ts.map +1 -1
  489. package/dist/services/password.service.js +167 -9
  490. package/dist/services/password.service.js.map +1 -1
  491. package/dist/services/phone-verification.service.d.ts +75 -0
  492. package/dist/services/phone-verification.service.d.ts.map +1 -1
  493. package/dist/services/phone-verification.service.js +188 -6
  494. package/dist/services/phone-verification.service.js.map +1 -1
  495. package/dist/services/risk-detection.service.d.ts +198 -0
  496. package/dist/services/risk-detection.service.d.ts.map +1 -1
  497. package/dist/services/risk-detection.service.js +358 -11
  498. package/dist/services/risk-detection.service.js.map +1 -1
  499. package/dist/services/risk-scoring.service.d.ts +84 -0
  500. package/dist/services/risk-scoring.service.d.ts.map +1 -1
  501. package/dist/services/risk-scoring.service.js +87 -0
  502. package/dist/services/risk-scoring.service.js.map +1 -1
  503. package/dist/services/session.service.d.ts +204 -0
  504. package/dist/services/session.service.d.ts.map +1 -1
  505. package/dist/services/session.service.js +289 -4
  506. package/dist/services/session.service.js.map +1 -1
  507. package/dist/services/social-auth-base.service.d.ts +123 -1
  508. package/dist/services/social-auth-base.service.d.ts.map +1 -1
  509. package/dist/services/social-auth-base.service.js +155 -2
  510. package/dist/services/social-auth-base.service.js.map +1 -1
  511. package/dist/services/social-auth.service.d.ts +191 -0
  512. package/dist/services/social-auth.service.d.ts.map +1 -1
  513. package/dist/services/social-auth.service.js +215 -2
  514. package/dist/services/social-auth.service.js.map +1 -1
  515. package/dist/services/social-provider-registry.service.d.ts +86 -0
  516. package/dist/services/social-provider-registry.service.d.ts.map +1 -1
  517. package/dist/services/social-provider-registry.service.js +86 -0
  518. package/dist/services/social-provider-registry.service.js.map +1 -1
  519. package/dist/services/trusted-device.service.d.ts +105 -0
  520. package/dist/services/trusted-device.service.d.ts.map +1 -1
  521. package/dist/services/trusted-device.service.js +133 -4
  522. package/dist/services/trusted-device.service.js.map +1 -1
  523. package/dist/storage/account-lockout-storage.service.d.ts +35 -0
  524. package/dist/storage/account-lockout-storage.service.d.ts.map +1 -1
  525. package/dist/storage/account-lockout-storage.service.js +35 -0
  526. package/dist/storage/account-lockout-storage.service.js.map +1 -1
  527. package/dist/storage/memory-storage.adapter.d.ts +148 -0
  528. package/dist/storage/memory-storage.adapter.d.ts.map +1 -1
  529. package/dist/storage/memory-storage.adapter.js +201 -6
  530. package/dist/storage/memory-storage.adapter.js.map +1 -1
  531. package/dist/storage/rate-limit-storage.service.d.ts +3 -0
  532. package/dist/storage/rate-limit-storage.service.d.ts.map +1 -1
  533. package/dist/storage/rate-limit-storage.service.js +4 -0
  534. package/dist/storage/rate-limit-storage.service.js.map +1 -1
  535. package/dist/storage.d.ts +8 -0
  536. package/dist/storage.d.ts.map +1 -1
  537. package/dist/storage.js +8 -0
  538. package/dist/storage.js.map +1 -1
  539. package/dist/templates/html-template.engine.d.ts +110 -0
  540. package/dist/templates/html-template.engine.d.ts.map +1 -1
  541. package/dist/templates/html-template.engine.js +147 -0
  542. package/dist/templates/html-template.engine.js.map +1 -1
  543. package/dist/templates/index.d.ts +5 -0
  544. package/dist/templates/index.d.ts.map +1 -1
  545. package/dist/templates/index.js +5 -0
  546. package/dist/templates/index.js.map +1 -1
  547. package/dist/templates/sms-template.engine.d.ts +151 -0
  548. package/dist/templates/sms-template.engine.d.ts.map +1 -1
  549. package/dist/templates/sms-template.engine.js +171 -0
  550. package/dist/templates/sms-template.engine.js.map +1 -1
  551. package/dist/templates.d.ts +8 -0
  552. package/dist/templates.d.ts.map +1 -1
  553. package/dist/templates.js +8 -0
  554. package/dist/templates.js.map +1 -1
  555. package/dist/utils/common-passwords.d.ts +42 -0
  556. package/dist/utils/common-passwords.d.ts.map +1 -1
  557. package/dist/utils/common-passwords.js +88 -0
  558. package/dist/utils/common-passwords.js.map +1 -1
  559. package/dist/utils/context-storage.d.ts +129 -0
  560. package/dist/utils/context-storage.d.ts.map +1 -1
  561. package/dist/utils/context-storage.js +129 -0
  562. package/dist/utils/context-storage.js.map +1 -1
  563. package/dist/utils/cookie-names.util.d.ts +35 -0
  564. package/dist/utils/cookie-names.util.d.ts.map +1 -1
  565. package/dist/utils/cookie-names.util.js +37 -0
  566. package/dist/utils/cookie-names.util.js.map +1 -1
  567. package/dist/utils/cookies.util.d.ts +19 -0
  568. package/dist/utils/cookies.util.d.ts.map +1 -1
  569. package/dist/utils/cookies.util.js +30 -3
  570. package/dist/utils/cookies.util.js.map +1 -1
  571. package/dist/utils/index.d.ts +3 -0
  572. package/dist/utils/index.d.ts.map +1 -1
  573. package/dist/utils/index.js +4 -0
  574. package/dist/utils/index.js.map +1 -1
  575. package/dist/utils/ip-extractor.d.ts +88 -0
  576. package/dist/utils/ip-extractor.d.ts.map +1 -1
  577. package/dist/utils/ip-extractor.js +109 -16
  578. package/dist/utils/ip-extractor.js.map +1 -1
  579. package/dist/utils/nauth-logger.d.ts +70 -0
  580. package/dist/utils/nauth-logger.d.ts.map +1 -1
  581. package/dist/utils/nauth-logger.js +82 -4
  582. package/dist/utils/nauth-logger.js.map +1 -1
  583. package/dist/utils/pii-redactor.d.ts +70 -0
  584. package/dist/utils/pii-redactor.d.ts.map +1 -1
  585. package/dist/utils/pii-redactor.js +102 -0
  586. package/dist/utils/pii-redactor.js.map +1 -1
  587. package/dist/utils/setup/get-repositories.d.ts +16 -0
  588. package/dist/utils/setup/get-repositories.d.ts.map +1 -1
  589. package/dist/utils/setup/get-repositories.js +21 -0
  590. package/dist/utils/setup/get-repositories.js.map +1 -1
  591. package/dist/utils/setup/init-services.d.ts +40 -1
  592. package/dist/utils/setup/init-services.d.ts.map +1 -1
  593. package/dist/utils/setup/init-services.js +98 -0
  594. package/dist/utils/setup/init-services.js.map +1 -1
  595. package/dist/utils/setup/init-social.d.ts +27 -0
  596. package/dist/utils/setup/init-social.d.ts.map +1 -1
  597. package/dist/utils/setup/init-social.js +49 -0
  598. package/dist/utils/setup/init-social.js.map +1 -1
  599. package/dist/utils/setup/init-storage.d.ts +22 -0
  600. package/dist/utils/setup/init-storage.d.ts.map +1 -1
  601. package/dist/utils/setup/init-storage.js +36 -0
  602. package/dist/utils/setup/init-storage.js.map +1 -1
  603. package/dist/utils/setup/register-mfa.d.ts +22 -0
  604. package/dist/utils/setup/register-mfa.d.ts.map +1 -1
  605. package/dist/utils/setup/register-mfa.js +41 -0
  606. package/dist/utils/setup/register-mfa.js.map +1 -1
  607. package/dist/utils/setup/run-nauth-migrations.d.ts +7 -0
  608. package/dist/utils/setup/run-nauth-migrations.d.ts.map +1 -1
  609. package/dist/utils/setup/run-nauth-migrations.js +8 -0
  610. package/dist/utils/setup/run-nauth-migrations.js.map +1 -1
  611. package/dist/utils/token-delivery-policy.d.ts +17 -0
  612. package/dist/utils/token-delivery-policy.d.ts.map +1 -1
  613. package/dist/utils/token-delivery-policy.js +17 -0
  614. package/dist/utils/token-delivery-policy.js.map +1 -1
  615. package/dist/utils.d.ts +8 -0
  616. package/dist/utils.d.ts.map +1 -1
  617. package/dist/utils.js +8 -0
  618. package/dist/utils.js.map +1 -1
  619. package/dist/validators/template.validator.d.ts +80 -0
  620. package/dist/validators/template.validator.d.ts.map +1 -1
  621. package/dist/validators/template.validator.js +94 -0
  622. package/dist/validators/template.validator.js.map +1 -1
  623. package/package.json +7 -2
@@ -1,10 +1,36 @@
1
1
  "use strict";
2
+ /**
3
+ * SMS Template System Interfaces
4
+ *
5
+ * Provides flexible template system for SMS notifications with support for:
6
+ * - Text templates with placeholder tokens ({{variable}})
7
+ * - Built-in and custom variables
8
+ * - Multiple template types (verification, MFA, password reset)
9
+ * - Handlebars syntax for template rendering
10
+ */
2
11
  Object.defineProperty(exports, "__esModule", { value: true });
3
12
  exports.SMSTemplateType = void 0;
13
+ /**
14
+ * SMS Template Type
15
+ *
16
+ * Enum of available SMS template types
17
+ */
4
18
  var SMSTemplateType;
5
19
  (function (SMSTemplateType) {
20
+ /**
21
+ * Phone verification code template
22
+ * Required variables: {{code}}, {{expiryMinutes}}
23
+ */
6
24
  SMSTemplateType["VERIFICATION"] = "verification";
25
+ /**
26
+ * MFA code template
27
+ * Required variables: {{code}}, {{expiryMinutes}}
28
+ */
7
29
  SMSTemplateType["MFA"] = "mfa";
30
+ /**
31
+ * Password reset code template
32
+ * Required variables: {{code}}, {{expiryMinutes}}
33
+ */
8
34
  SMSTemplateType["PASSWORD_RESET"] = "passwordReset";
9
35
  })(SMSTemplateType || (exports.SMSTemplateType = SMSTemplateType = {}));
10
36
  //# sourceMappingURL=sms-template.interface.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"sms-template.interface.js","sourceRoot":"","sources":["../../src/interfaces/sms-template.interface.ts"],"names":[],"mappings":";;;AAeA,IAAY,eAkBX;AAlBD,WAAY,eAAe;IAKzB,gDAA6B,CAAA;IAM7B,8BAAW,CAAA;IAMX,mDAAgC,CAAA;AAClC,CAAC,EAlBW,eAAe,+BAAf,eAAe,QAkB1B"}
1
+ {"version":3,"file":"sms-template.interface.js","sourceRoot":"","sources":["../../src/interfaces/sms-template.interface.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;;;AAEH;;;;GAIG;AACH,IAAY,eAkBX;AAlBD,WAAY,eAAe;IACzB;;;OAGG;IACH,gDAA6B,CAAA;IAE7B;;;OAGG;IACH,8BAAW,CAAA;IAEX;;;OAGG;IACH,mDAAgC,CAAA;AAClC,CAAC,EAlBW,eAAe,+BAAf,eAAe,QAkB1B"}
@@ -1,13 +1,128 @@
1
1
  import { AuthResponseDTO } from '../dto';
2
2
  import { OAuthUserProfile } from '../interfaces/oauth.interface';
3
+ /**
4
+ * Social Auth Provider Service Interface
5
+ *
6
+ * Defines the contract for social authentication provider services.
7
+ * Each provider (Google, Apple, Facebook, etc.) must implement this interface
8
+ * to be registered with the core SocialAuthService.
9
+ *
10
+ * This allows for:
11
+ * - Modular provider imports (only install what you need)
12
+ * - Consistent API across all providers
13
+ * - Proper NestJS dependency injection
14
+ * - Easy addition of new providers without modifying core code
15
+ *
16
+ * @example
17
+ * ```typescript
18
+ * @Injectable()
19
+ * export class GoogleSocialAuthService implements ISocialAuthProviderService {
20
+ * readonly providerName = 'google';
21
+ *
22
+ * async getAuthUrl(state?: string): Promise<string> {
23
+ * // Generate Google OAuth URL
24
+ * }
25
+ *
26
+ * async handleCallback(code: string, state: string): Promise<AuthResponseDTO> {
27
+ * // Handle Google OAuth callback
28
+ * }
29
+ *
30
+ * async verifyToken(idToken: string, accessToken?: string, profileData?: any): Promise<AuthResponseDTO> {
31
+ * // Verify Google ID token
32
+ * }
33
+ * }
34
+ * ```
35
+ */
3
36
  export interface ISocialAuthProviderService {
37
+ /**
38
+ * Provider name (e.g., 'google', 'apple', 'facebook')
39
+ * Used as the key in the provider registry
40
+ */
4
41
  readonly providerName: string;
42
+ /**
43
+ * Generate OAuth authorization URL for this provider
44
+ *
45
+ * @param state - Optional state parameter for CSRF protection
46
+ * @returns Authorization URL to redirect user to
47
+ * @throws {BadRequestException} When provider is not properly configured
48
+ *
49
+ * @example
50
+ * ```typescript
51
+ * const authUrl = await provider.getAuthUrl('random-state-123');
52
+ * // Redirect user to authUrl
53
+ * ```
54
+ */
5
55
  getAuthUrl(state?: string): Promise<string>;
56
+ /**
57
+ * Handle OAuth callback and authenticate user
58
+ *
59
+ * Exchanges authorization code for access token, fetches user profile,
60
+ * and returns unified authentication response with JWT tokens.
61
+ *
62
+ * @param code - Authorization code from OAuth callback
63
+ * @param state - State parameter from OAuth callback (for CSRF protection)
64
+ * @returns Unified authentication response with tokens and user info
65
+ * @throws {BadRequestException} When callback is invalid
66
+ *
67
+ * @example
68
+ * ```typescript
69
+ * const result = await provider.handleCallback(code, state);
70
+ * console.log(result.accessToken); // JWT access token
71
+ * console.log(result.user.email); // User email
72
+ * ```
73
+ */
6
74
  handleCallback(code: string, state: string): Promise<AuthResponseDTO>;
75
+ /**
76
+ * Verify social authentication token from native mobile apps
77
+ *
78
+ * Handles authentication tokens from native mobile apps (iOS/Android)
79
+ * that use native SDKs (Google Sign-In SDK, Apple Sign In, etc.)
80
+ *
81
+ * @param idToken - ID token from native SDK
82
+ * @param accessToken - Optional access token from native SDK
83
+ * @param profileData - Optional profile data from native SDK (for name extraction)
84
+ * @returns Unified authentication response with tokens and user info
85
+ * @throws {BadRequestException} When token is invalid
86
+ *
87
+ * @example
88
+ * ```typescript
89
+ * const result = await provider.verifyToken(idToken, accessToken, profileData);
90
+ * return result; // Same format as login/signup
91
+ * ```
92
+ */
7
93
  verifyToken(idToken: string, accessToken?: string, profileData?: any): Promise<AuthResponseDTO>;
94
+ /**
95
+ * Link social account to existing user
96
+ *
97
+ * Used when an authenticated user wants to link a social account
98
+ * to their existing account.
99
+ *
100
+ * @param userId - User ID (sub)
101
+ * @param code - Authorization code from OAuth callback
102
+ * @param state - State parameter from OAuth callback
103
+ * @returns Success message
104
+ * @throws {NotFoundException} When user is not found
105
+ * @throws {ConflictException} When account is already linked
106
+ *
107
+ * @example
108
+ * ```typescript
109
+ * await provider.linkAccount(userId, code, state);
110
+ * ```
111
+ */
8
112
  linkAccount(userId: string, code: string, state: string): Promise<{
9
113
  message: string;
10
114
  }>;
115
+ /**
116
+ * Get OAuth user profile from callback
117
+ *
118
+ * Internal method used by handleCallback to extract user profile.
119
+ * Exposed for advanced use cases.
120
+ *
121
+ * @param code - Authorization code from OAuth callback
122
+ * @param state - State parameter from OAuth callback
123
+ * @returns OAuth user profile
124
+ * @private
125
+ */
11
126
  getUserProfileFromCallback(code: string, state: string): Promise<OAuthUserProfile>;
12
127
  }
13
128
  //# sourceMappingURL=social-auth-provider.interface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"social-auth-provider.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/social-auth-provider.interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAmCjE,MAAM,WAAW,0BAA0B;IAKzC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAe9B,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAoB5C,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IAoBtE,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IAoBhG,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAavF,0BAA0B,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;CACpF"}
1
+ {"version":3,"file":"social-auth-provider.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/social-auth-provider.interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAEjE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,MAAM,WAAW,0BAA0B;IACzC;;;OAGG;IACH,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAE9B;;;;;;;;;;;;OAYG;IACH,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAE5C;;;;;;;;;;;;;;;;;OAiBG;IACH,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IAEtE;;;;;;;;;;;;;;;;;OAiBG;IACH,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IAEhG;;;;;;;;;;;;;;;;;OAiBG;IACH,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAEvF;;;;;;;;;;OAUG;IACH,0BAA0B,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;CACpF"}
@@ -1,33 +1,70 @@
1
+ /**
2
+ * Storage adapter interface for shared state management
3
+ * Critical for multi-server deployments
4
+ */
1
5
  export interface StorageAdapter {
6
+ /**
7
+ * Initialize the storage adapter
8
+ */
2
9
  initialize(): Promise<void>;
10
+ /**
11
+ * Check if adapter is healthy
12
+ */
3
13
  isHealthy(): Promise<boolean>;
14
+ /**
15
+ * Basic key-value operations
16
+ */
4
17
  get(key: string): Promise<string | null>;
5
18
  set(key: string, value: string, ttlSeconds?: number, options?: {
6
19
  nx?: boolean;
7
20
  }): Promise<string | null | void>;
8
21
  del(key: string): Promise<void>;
9
22
  exists(key: string): Promise<boolean>;
23
+ /**
24
+ * Atomic operations
25
+ */
10
26
  incr(key: string, ttlSeconds?: number): Promise<number>;
11
27
  decr(key: string): Promise<number>;
12
28
  expire(key: string, ttl: number): Promise<void>;
13
29
  ttl(key: string): Promise<number>;
30
+ /**
31
+ * Hash operations (for complex data structures)
32
+ */
14
33
  hget(key: string, field: string): Promise<string | null>;
15
34
  hset(key: string, field: string, value: string): Promise<void>;
16
35
  hgetall(key: string): Promise<Record<string, string>>;
17
36
  hdel(key: string, ...fields: string[]): Promise<number>;
37
+ /**
38
+ * List operations (for token families)
39
+ */
18
40
  lpush(key: string, value: string): Promise<void>;
19
41
  lrange(key: string, start: number, stop: number): Promise<string[]>;
20
42
  llen(key: string): Promise<number>;
43
+ /**
44
+ * Pattern operations
45
+ */
21
46
  keys(pattern: string): Promise<string[]>;
22
47
  scan(cursor: number, pattern: string, count: number): Promise<[number, string[]]>;
48
+ /**
49
+ * Cleanup and disconnect
50
+ */
23
51
  cleanup(): Promise<void>;
24
52
  disconnect(): Promise<void>;
25
53
  }
54
+ /**
55
+ * Rate limiting specific operations
56
+ */
26
57
  export interface RateLimitStorage {
27
58
  incrementRateLimit(identifier: string, endpoint: string, windowMs: number): Promise<number>;
28
59
  getRateLimit(identifier: string, endpoint: string): Promise<number>;
29
60
  resetRateLimit(identifier: string, endpoint: string): Promise<void>;
30
61
  }
62
+ /**
63
+ * Account lockout specific operations
64
+ *
65
+ * SECURITY: Uses IP addresses instead of user identifiers to prevent
66
+ * attackers from locking out legitimate users by guessing their email/username.
67
+ */
31
68
  export interface AccountLockoutStorage {
32
69
  recordFailedAttempt(ipAddress: string): Promise<number>;
33
70
  getFailedAttempts(ipAddress: string): Promise<number>;
@@ -1 +1 @@
1
- {"version":3,"file":"storage-adapter.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/storage-adapter.interface.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"storage-adapter.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/storage-adapter.interface.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,17 @@
1
+ /**
2
+ * Email Template System Interfaces
3
+ *
4
+ * Provides flexible template system for email notifications with support for:
5
+ * - HTML templates with placeholder tokens ({{variable}})
6
+ * - Built-in and custom variables
7
+ * - Multiple template types (verification, password reset, etc.)
8
+ */
9
+ /**
10
+ * Template Variables
11
+ *
12
+ * Variables that can be used in email templates.
13
+ * All variables are optional as not all templates use all variables.
14
+ */
1
15
  export interface TemplateVariables {
2
16
  appName?: string;
3
17
  userName?: string;
@@ -24,11 +38,32 @@ export interface TemplateVariables {
24
38
  footerDisclaimer?: string;
25
39
  [key: string]: string | number | boolean | undefined;
26
40
  }
41
+ /**
42
+ * Email Template
43
+ *
44
+ * Defines the structure of an email template with subject and content.
45
+ * Both subject and content support placeholder variables.
46
+ */
27
47
  export interface EmailTemplate {
48
+ /**
49
+ * Email subject line (supports {{variables}})
50
+ */
28
51
  subject: string;
52
+ /**
53
+ * HTML content of the email (supports {{variables}})
54
+ */
29
55
  html: string;
56
+ /**
57
+ * Optional plain text version (supports {{variables}})
58
+ * Falls back to stripping HTML tags if not provided
59
+ */
30
60
  text?: string;
31
61
  }
62
+ /**
63
+ * Template Type
64
+ *
65
+ * Enum of available email template types
66
+ */
32
67
  export declare enum TemplateType {
33
68
  VERIFICATION = "verification",
34
69
  PASSWORD_RESET = "passwordReset",
@@ -39,37 +74,177 @@ export declare enum TemplateType {
39
74
  EMAIL_CHANGED = "emailChanged",
40
75
  MFA_ENABLED = "mfaEnabled"
41
76
  }
77
+ /**
78
+ * Template Source
79
+ *
80
+ * Defines how template content can be provided - as a string or file path
81
+ */
42
82
  export interface TemplateSource {
83
+ /**
84
+ * Template content as a string
85
+ */
43
86
  content?: string;
87
+ /**
88
+ * Path to template file (relative or absolute)
89
+ * Supports .hbs, .html, .txt, etc.
90
+ */
44
91
  filePath?: string;
45
92
  }
93
+ /**
94
+ * Template Files
95
+ *
96
+ * Defines template files for subject, HTML, and text content.
97
+ * Used for file-based template registration.
98
+ *
99
+ * @example
100
+ * ```typescript
101
+ * const templateFiles: TemplateFiles = {
102
+ * subject: { filePath: './templates/welcome.subject.hbs' },
103
+ * html: { filePath: './templates/welcome.html.hbs' },
104
+ * text: { filePath: './templates/welcome.text.hbs' }
105
+ * };
106
+ * ```
107
+ */
46
108
  export interface TemplateFiles {
109
+ /**
110
+ * Subject line template source
111
+ */
47
112
  subject: TemplateSource;
113
+ /**
114
+ * HTML content template source
115
+ */
48
116
  html: TemplateSource;
117
+ /**
118
+ * Plain text content template source (optional)
119
+ */
49
120
  text?: TemplateSource;
50
121
  }
122
+ /**
123
+ * Template Engine Interface
124
+ *
125
+ * Contract for template engines that can render email templates with variables.
126
+ * Implementations can support HTML, MJML, Handlebars, or other template formats.
127
+ *
128
+ * @example
129
+ * ```typescript
130
+ * const engine = new HandlebarsTemplateEngine();
131
+ * const result = await engine.render(
132
+ * TemplateType.VERIFICATION,
133
+ * { userName: 'John', code: '123456' }
134
+ * );
135
+ * logger.debug('Subject:', result.subject); // "Verify your email - My App"
136
+ * logger.debug('HTML generated'); // HTML with variables replaced
137
+ * ```
138
+ */
51
139
  export interface TemplateEngine {
140
+ /**
141
+ * Render a template with the provided variables
142
+ *
143
+ * @param type - Type of template to render
144
+ * @param variables - Variables to inject into the template
145
+ * @returns Rendered email template with subject and content
146
+ *
147
+ * @throws {Error} If template type is not found
148
+ *
149
+ * @example
150
+ * ```typescript
151
+ * const result = await engine.render(
152
+ * TemplateType.VERIFICATION,
153
+ * {
154
+ * userName: 'John Doe',
155
+ * code: '123456',
156
+ * expiryMinutes: 60
157
+ * }
158
+ * );
159
+ * ```
160
+ */
52
161
  render(type: TemplateType | string, variables: TemplateVariables): Promise<EmailTemplate>;
162
+ /**
163
+ * Register a custom template from inline strings
164
+ *
165
+ * Allows overriding default templates or adding new ones.
166
+ *
167
+ * @param type - Template type identifier
168
+ * @param template - Template definition with inline content
169
+ *
170
+ * @example
171
+ * ```typescript
172
+ * engine.registerTemplate(TemplateType.WELCOME, {
173
+ * subject: 'Welcome {{userName}}!',
174
+ * html: '<h1>Hello {{userName}}!</h1>',
175
+ * text: 'Hello {{userName}}!'
176
+ * });
177
+ * ```
178
+ */
53
179
  registerTemplate(type: TemplateType | string, template: EmailTemplate): void;
180
+ /**
181
+ * Register a custom template from mixed sources (strings or files)
182
+ *
183
+ * Flexible registration that supports both inline content and file paths.
184
+ *
185
+ * @param type - Template type identifier
186
+ * @param templateSources - Template sources (content or file paths)
187
+ *
188
+ * @example
189
+ * ```typescript
190
+ * engine.registerTemplateFromSources(TemplateType.WELCOME, {
191
+ * subject: { content: 'Welcome {{userName}}!' },
192
+ * html: { filePath: './templates/welcome.html.hbs' },
193
+ * text: { content: 'Welcome {{userName}}!' }
194
+ * });
195
+ * ```
196
+ */
54
197
  registerTemplateFromSources?(type: TemplateType | string, templateSources: TemplateFiles): Promise<void>;
198
+ /**
199
+ * Get available template types
200
+ *
201
+ * @returns Array of registered template type identifiers
202
+ */
55
203
  getAvailableTemplates(): string[];
204
+ /**
205
+ * Check if a template exists
206
+ *
207
+ * @param type - Template type to check
208
+ * @returns True if template is registered
209
+ */
56
210
  hasTemplate(type: TemplateType | string): boolean;
57
211
  }
212
+ /**
213
+ * Required template parameters for each template type
214
+ *
215
+ * Defines which variables MUST be present in custom templates.
216
+ * Optional variables (firstName, lastName, etc.) can be included but are not required.
217
+ */
58
218
  export interface TemplateRequiredParams {
219
+ /**
220
+ * Email verification template required parameters
221
+ */
59
222
  [TemplateType.VERIFICATION]: {
60
223
  code: string;
61
224
  link: string;
62
225
  expiryMinutes: number;
63
226
  };
227
+ /**
228
+ * Password reset template required parameters
229
+ */
64
230
  [TemplateType.PASSWORD_RESET]: {
65
231
  link: string;
66
232
  expiryMinutes: number;
67
233
  };
234
+ /**
235
+ * Welcome template required parameters
236
+ */
68
237
  [TemplateType.WELCOME]: Record<string, never>;
238
+ /**
239
+ * Account lockout template required parameters
240
+ */
69
241
  [TemplateType.ACCOUNT_LOCKOUT]: {
70
242
  reason: string;
71
243
  durationMinutes: number;
72
244
  };
245
+ /**
246
+ * New device template required parameters
247
+ */
73
248
  [TemplateType.NEW_DEVICE]: {
74
249
  deviceName: string;
75
250
  deviceType?: string;
@@ -77,22 +252,198 @@ export interface TemplateRequiredParams {
77
252
  location?: string;
78
253
  timestamp: string;
79
254
  };
255
+ /**
256
+ * Password changed template required parameters
257
+ */
80
258
  [TemplateType.PASSWORD_CHANGED]: Record<string, never>;
259
+ /**
260
+ * Email changed template required parameters
261
+ */
81
262
  [TemplateType.EMAIL_CHANGED]: {
82
263
  userEmail: string;
83
264
  };
265
+ /**
266
+ * MFA enabled template required parameters
267
+ */
84
268
  [TemplateType.MFA_ENABLED]: Record<string, never>;
85
269
  }
270
+ /**
271
+ * Custom template definition with file paths or content
272
+ *
273
+ * Allows specifying templates as file paths or inline content.
274
+ * All templates support Handlebars syntax for dynamic content.
275
+ *
276
+ * @example
277
+ * ```typescript
278
+ * const customTemplate: CustomTemplateDefinition = {
279
+ * htmlPath: './templates/verification.html.hbs',
280
+ * // OR
281
+ * html: '<html>{{code}}</html>',
282
+ * // Optional text version
283
+ * textPath: './templates/verification.text.hbs'
284
+ * };
285
+ * ```
286
+ */
86
287
  export interface CustomTemplateDefinition {
288
+ /**
289
+ * Path to HTML template file (supports frontmatter for subject)
290
+ * Mutually exclusive with `html`
291
+ */
87
292
  htmlPath?: string;
293
+ /**
294
+ * HTML template content as string (supports frontmatter for subject)
295
+ * Mutually exclusive with `htmlPath`
296
+ */
88
297
  html?: string;
298
+ /**
299
+ * Path to plain text template file
300
+ * Mutually exclusive with `text`
301
+ */
89
302
  textPath?: string;
303
+ /**
304
+ * Plain text template content as string
305
+ * Mutually exclusive with `textPath`
306
+ */
90
307
  text?: string;
308
+ /**
309
+ * Email subject (can include Handlebars variables)
310
+ * If not provided, will be extracted from HTML frontmatter
311
+ */
91
312
  subject?: string;
92
313
  }
314
+ /**
315
+ * Template Configuration
316
+ *
317
+ * Configuration options for the template system.
318
+ * Used in AuthModule.forRoot() configuration.
319
+ *
320
+ * Custom templates are validated at startup to ensure they include
321
+ * all required parameters for their template type.
322
+ *
323
+ * @example
324
+ * ```typescript
325
+ * AuthModule.forRoot({
326
+ * email: {
327
+ * templates: {
328
+ * // Global variables (optional, available to all templates)
329
+ * globalVariables: {
330
+ * appName: 'My Application',
331
+ * companyName: 'My Company Inc.',
332
+ * supportEmail: 'support@example.com',
333
+ * brandColor: '#4CAF50',
334
+ * logoUrl: 'https://example.com/logo.png'
335
+ * },
336
+ * // Custom templates (override defaults)
337
+ * customTemplates: {
338
+ * verification: {
339
+ * htmlPath: './templates/verification.html.hbs',
340
+ * textPath: './templates/verification.text.hbs'
341
+ * // Must include: {{code}}, {{link}}, {{expiryMinutes}}
342
+ * },
343
+ * welcome: {
344
+ * html: `
345
+ * ---
346
+ * subject: Welcome to {{appName}}!
347
+ * ---
348
+ * <h1>Hello {{firstName}}!</h1>
349
+ * `,
350
+ * // No required params for welcome
351
+ * }
352
+ * }
353
+ * }
354
+ * }
355
+ * })
356
+ * ```
357
+ */
93
358
  export interface TemplateConfig {
359
+ /**
360
+ * Template engine instance
361
+ *
362
+ * @default HandlebarsTemplateEngine with default templates
363
+ */
94
364
  engine?: TemplateEngine;
365
+ /**
366
+ * Global variables available to all templates
367
+ *
368
+ * These are merged with template-specific variables at render time.
369
+ * Template-specific variables take precedence over globals.
370
+ *
371
+ * Common global variables:
372
+ * - appName: Your application name
373
+ * - companyName: Your company name
374
+ * - supportEmail: Support contact email
375
+ * - brandColor: Primary brand color (hex)
376
+ * - logoUrl: URL to your logo image
377
+ * - dashboardUrl: URL to user dashboard
378
+ * - footerDisclaimer: Custom footer disclaimer text (optional, has default)
379
+ *
380
+ * Optional user-specific variables (injected at runtime):
381
+ * - firstName, lastName, userName: User information
382
+ * - currentYear: Current year (injected automatically)
383
+ *
384
+ * @example
385
+ * ```typescript
386
+ * globalVariables: {
387
+ * appName: process.env.APP_NAME || 'My App',
388
+ * companyName: 'My Company Inc.',
389
+ * supportEmail: 'support@example.com',
390
+ * brandColor: '#4f46e5',
391
+ * logoUrl: 'https://example.com/logo.png'
392
+ * }
393
+ * ```
394
+ */
95
395
  globalVariables?: TemplateVariables;
396
+ /**
397
+ * Custom template definitions
398
+ *
399
+ * Override default templates or add new ones.
400
+ * Templates are validated at startup to ensure required parameters are present.
401
+ *
402
+ * Key is the template type, value is the template definition.
403
+ * Templates can be provided as file paths or inline content.
404
+ *
405
+ * All templates support Handlebars syntax:
406
+ * - {{variable}}: Insert variable
407
+ * - {{#if variable}}...{{/if}}: Conditional
408
+ * - {{#each items}}...{{/each}}: Loop
409
+ *
410
+ * Required parameters by template type:
411
+ * - verification: {{code}}, {{link}}, {{expiryMinutes}}
412
+ * - passwordReset: {{link}}, {{expiryMinutes}}
413
+ * - accountLockout: {{reason}}, {{durationMinutes}}
414
+ * - newDevice: {{deviceName}}, {{timestamp}}
415
+ * - emailChanged: {{userEmail}}
416
+ * - welcome, passwordChanged, mfaEnabled: No required params
417
+ *
418
+ * @example
419
+ * ```typescript
420
+ * customTemplates: {
421
+ * // File-based template (with frontmatter for subject)
422
+ * verification: {
423
+ * htmlPath: './templates/verification.html.hbs',
424
+ * textPath: './templates/verification.text.hbs'
425
+ * },
426
+ * // Inline template (with frontmatter for subject)
427
+ * welcome: {
428
+ * html: `
429
+ * ---
430
+ * subject: Welcome to {{appName}}!
431
+ * ---
432
+ * <html>
433
+ * <h1>Hello {{firstName}}!</h1>
434
+ * <p>Welcome to our platform!</p>
435
+ * </html>
436
+ * `
437
+ * },
438
+ * // Mixed (HTML from file, explicit subject)
439
+ * passwordReset: {
440
+ * subject: 'Reset your password - {{appName}}',
441
+ * htmlPath: './templates/password-reset.html.hbs',
442
+ * text: 'Reset link: {{link}} (expires in {{expiryMinutes}} minutes)'
443
+ * }
444
+ * }
445
+ * ```
446
+ */
96
447
  customTemplates?: Record<string, CustomTemplateDefinition>;
97
448
  }
98
449
  //# sourceMappingURL=template.interface.d.ts.map