@digitaldefiance/node-express-suite 3.7.5 → 3.7.6

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 (813) hide show
  1. package/package.json +5 -4
  2. package/src/__tests__/fixtures/{index.ts → index.d.ts} +1 -0
  3. package/src/__tests__/fixtures/index.d.ts.map +1 -0
  4. package/src/__tests__/fixtures/index.js +5 -0
  5. package/src/__tests__/fixtures/index.js.map +1 -0
  6. package/src/__tests__/fixtures/model-mocks.mock.d.ts +12 -0
  7. package/src/__tests__/fixtures/model-mocks.mock.d.ts.map +1 -0
  8. package/src/__tests__/fixtures/model-mocks.mock.js +102 -0
  9. package/src/__tests__/fixtures/model-mocks.mock.js.map +1 -0
  10. package/src/__tests__/helpers/application.mock.d.ts +8 -0
  11. package/src/__tests__/helpers/application.mock.d.ts.map +1 -0
  12. package/src/__tests__/helpers/application.mock.js +77 -0
  13. package/src/__tests__/helpers/application.mock.js.map +1 -0
  14. package/src/__tests__/helpers/{index.ts → index.d.ts} +1 -0
  15. package/src/__tests__/helpers/index.d.ts.map +1 -0
  16. package/src/__tests__/helpers/index.js +7 -0
  17. package/src/__tests__/helpers/index.js.map +1 -0
  18. package/src/__tests__/helpers/setup-test-env.d.ts +12 -0
  19. package/src/__tests__/helpers/setup-test-env.d.ts.map +1 -0
  20. package/src/__tests__/helpers/setup-test-env.js +121 -0
  21. package/src/__tests__/helpers/setup-test-env.js.map +1 -0
  22. package/src/__tests__/{index.ts → index.d.ts} +1 -0
  23. package/src/__tests__/index.d.ts.map +1 -0
  24. package/src/__tests__/index.js +6 -0
  25. package/src/__tests__/index.js.map +1 -0
  26. package/src/application-base.d.ts +128 -0
  27. package/src/application-base.d.ts.map +1 -0
  28. package/src/application-base.js +364 -0
  29. package/src/application-base.js.map +1 -0
  30. package/src/application-concrete.d.ts +26 -0
  31. package/src/application-concrete.d.ts.map +1 -0
  32. package/src/application-concrete.js +34 -0
  33. package/src/application-concrete.js.map +1 -0
  34. package/src/application.d.ts +34 -0
  35. package/src/application.d.ts.map +1 -0
  36. package/src/application.js +172 -0
  37. package/src/application.js.map +1 -0
  38. package/src/backup-code.d.ts +72 -0
  39. package/src/backup-code.d.ts.map +1 -0
  40. package/src/backup-code.js +243 -0
  41. package/src/backup-code.js.map +1 -0
  42. package/src/builders/application-builder.d.ts +47 -0
  43. package/src/builders/application-builder.d.ts.map +1 -0
  44. package/src/builders/application-builder.js +76 -0
  45. package/src/builders/application-builder.js.map +1 -0
  46. package/src/builders/{index.ts → index.d.ts} +1 -0
  47. package/src/builders/index.d.ts.map +1 -0
  48. package/src/builders/index.js +5 -0
  49. package/src/builders/index.js.map +1 -0
  50. package/src/constants.d.ts +21 -0
  51. package/src/constants.d.ts.map +1 -0
  52. package/src/constants.js +63 -0
  53. package/src/constants.js.map +1 -0
  54. package/src/container/{index.ts → index.d.ts} +1 -0
  55. package/src/container/index.d.ts.map +1 -0
  56. package/src/container/index.js +6 -0
  57. package/src/container/index.js.map +1 -0
  58. package/src/container/service-container.d.ts +45 -0
  59. package/src/container/service-container.d.ts.map +1 -0
  60. package/src/container/service-container.js +68 -0
  61. package/src/container/service-container.js.map +1 -0
  62. package/src/container/{service-definitions.ts → service-definitions.d.ts} +10 -11
  63. package/src/container/service-definitions.d.ts.map +1 -0
  64. package/src/container/service-definitions.js +21 -0
  65. package/src/container/service-definitions.js.map +1 -0
  66. package/src/controllers/base.d.ts +80 -0
  67. package/src/controllers/base.d.ts.map +1 -0
  68. package/src/controllers/base.js +318 -0
  69. package/src/controllers/base.js.map +1 -0
  70. package/src/controllers/{index.ts → index.d.ts} +1 -0
  71. package/src/controllers/index.d.ts.map +1 -0
  72. package/src/controllers/index.js +6 -0
  73. package/src/controllers/index.js.map +1 -0
  74. package/src/controllers/user.d.ts +66 -0
  75. package/src/controllers/user.d.ts.map +1 -0
  76. package/src/controllers/user.js +936 -0
  77. package/src/controllers/user.js.map +1 -0
  78. package/src/database/{database-initializer.ts → database-initializer.d.ts} +3 -4
  79. package/src/database/database-initializer.d.ts.map +1 -0
  80. package/src/database/database-initializer.js +8 -0
  81. package/src/database/database-initializer.js.map +1 -0
  82. package/src/database/{index.ts → index.d.ts} +1 -0
  83. package/src/database/index.d.ts.map +1 -0
  84. package/src/database/index.js +5 -0
  85. package/src/database/index.js.map +1 -0
  86. package/src/decorators/base-controller.d.ts +22 -0
  87. package/src/decorators/base-controller.d.ts.map +1 -0
  88. package/src/decorators/base-controller.js +71 -0
  89. package/src/decorators/base-controller.js.map +1 -0
  90. package/src/decorators/controller.d.ts +43 -0
  91. package/src/decorators/controller.d.ts.map +1 -0
  92. package/src/decorators/controller.js +73 -0
  93. package/src/decorators/controller.js.map +1 -0
  94. package/src/decorators/{index.ts → index.d.ts} +1 -0
  95. package/src/decorators/index.d.ts.map +1 -0
  96. package/src/decorators/index.js +7 -0
  97. package/src/decorators/index.js.map +1 -0
  98. package/src/decorators/zod-validation.d.ts +10 -0
  99. package/src/decorators/zod-validation.d.ts.map +1 -0
  100. package/src/decorators/zod-validation.js +53 -0
  101. package/src/decorators/zod-validation.js.map +1 -0
  102. package/src/defaults.d.ts +12 -0
  103. package/src/defaults.d.ts.map +1 -0
  104. package/src/defaults.js +210 -0
  105. package/src/defaults.js.map +1 -0
  106. package/src/documents/{base.ts → base.d.ts} +2 -4
  107. package/src/documents/base.d.ts.map +1 -0
  108. package/src/documents/base.js +8 -0
  109. package/src/documents/base.js.map +1 -0
  110. package/src/documents/{email-token.ts → email-token.d.ts} +3 -8
  111. package/src/documents/email-token.d.ts.map +1 -0
  112. package/src/documents/email-token.js +8 -0
  113. package/src/documents/email-token.js.map +1 -0
  114. package/src/documents/{index.ts → index.d.ts} +1 -0
  115. package/src/documents/index.d.ts.map +1 -0
  116. package/src/documents/index.js +3 -0
  117. package/src/documents/index.js.map +1 -0
  118. package/src/documents/{mnemonic.ts → mnemonic.d.ts} +2 -6
  119. package/src/documents/mnemonic.d.ts.map +1 -0
  120. package/src/documents/mnemonic.js +8 -0
  121. package/src/documents/mnemonic.js.map +1 -0
  122. package/src/documents/{role.ts → role.d.ts} +2 -6
  123. package/src/documents/role.d.ts.map +1 -0
  124. package/src/documents/role.js +8 -0
  125. package/src/documents/role.js.map +1 -0
  126. package/src/documents/{used-direct-login-token.ts → used-direct-login-token.d.ts} +2 -4
  127. package/src/documents/used-direct-login-token.d.ts.map +1 -0
  128. package/src/documents/used-direct-login-token.js +8 -0
  129. package/src/documents/used-direct-login-token.js.map +1 -0
  130. package/src/documents/{user-role.ts → user-role.d.ts} +2 -6
  131. package/src/documents/user-role.d.ts.map +1 -0
  132. package/src/documents/user-role.js +8 -0
  133. package/src/documents/user-role.js.map +1 -0
  134. package/src/documents/{user.ts → user.d.ts} +2 -6
  135. package/src/documents/user.d.ts.map +1 -0
  136. package/src/documents/user.js +8 -0
  137. package/src/documents/user.js.map +1 -0
  138. package/src/enumerations/base-model-name.d.ts +43 -0
  139. package/src/enumerations/base-model-name.d.ts.map +1 -0
  140. package/src/enumerations/base-model-name.js +39 -0
  141. package/src/enumerations/base-model-name.js.map +1 -0
  142. package/src/enumerations/{index.ts → index.d.ts} +1 -0
  143. package/src/enumerations/index.d.ts.map +1 -0
  144. package/src/enumerations/index.js +8 -0
  145. package/src/enumerations/index.js.map +1 -0
  146. package/src/enumerations/{length-encoding-type.ts → length-encoding-type.d.ts} +6 -6
  147. package/src/enumerations/length-encoding-type.d.ts.map +1 -0
  148. package/src/enumerations/length-encoding-type.js +20 -0
  149. package/src/enumerations/length-encoding-type.js.map +1 -0
  150. package/src/enumerations/schema-collection.d.ts +39 -0
  151. package/src/enumerations/schema-collection.d.ts.map +1 -0
  152. package/src/enumerations/schema-collection.js +43 -0
  153. package/src/enumerations/schema-collection.js.map +1 -0
  154. package/src/enumerations/{symmetric-error-type.ts → symmetric-error-type.d.ts} +4 -4
  155. package/src/enumerations/symmetric-error-type.d.ts.map +1 -0
  156. package/src/enumerations/symmetric-error-type.js +17 -0
  157. package/src/enumerations/symmetric-error-type.js.map +1 -0
  158. package/src/environment.d.ts +194 -0
  159. package/src/environment.d.ts.map +1 -0
  160. package/src/environment.js +646 -0
  161. package/src/environment.js.map +1 -0
  162. package/src/errors/express-validation.d.ts +24 -0
  163. package/src/errors/express-validation.d.ts.map +1 -0
  164. package/src/errors/express-validation.js +33 -0
  165. package/src/errors/express-validation.js.map +1 -0
  166. package/src/errors/{index.ts → index.d.ts} +1 -0
  167. package/src/errors/index.d.ts.map +1 -0
  168. package/src/errors/index.js +16 -0
  169. package/src/errors/index.js.map +1 -0
  170. package/src/errors/invalid-backup-code-version.d.ts +19 -0
  171. package/src/errors/invalid-backup-code-version.d.ts.map +1 -0
  172. package/src/errors/invalid-backup-code-version.js +29 -0
  173. package/src/errors/invalid-backup-code-version.js.map +1 -0
  174. package/src/errors/invalid-jwt-token.d.ts +17 -0
  175. package/src/errors/invalid-jwt-token.d.ts.map +1 -0
  176. package/src/errors/invalid-jwt-token.js +24 -0
  177. package/src/errors/invalid-jwt-token.js.map +1 -0
  178. package/src/errors/invalid-model.d.ts +18 -0
  179. package/src/errors/invalid-model.d.ts.map +1 -0
  180. package/src/errors/invalid-model.js +26 -0
  181. package/src/errors/invalid-model.js.map +1 -0
  182. package/src/errors/invalid-new-password.d.ts +19 -0
  183. package/src/errors/invalid-new-password.d.ts.map +1 -0
  184. package/src/errors/invalid-new-password.js +28 -0
  185. package/src/errors/invalid-new-password.js.map +1 -0
  186. package/src/errors/invalid-password.d.ts +19 -0
  187. package/src/errors/invalid-password.d.ts.map +1 -0
  188. package/src/errors/invalid-password.js +28 -0
  189. package/src/errors/invalid-password.js.map +1 -0
  190. package/src/errors/missing-validated-data.d.ts +24 -0
  191. package/src/errors/missing-validated-data.d.ts.map +1 -0
  192. package/src/errors/missing-validated-data.js +53 -0
  193. package/src/errors/missing-validated-data.js.map +1 -0
  194. package/src/errors/mnemonic-or-password-required.d.ts +17 -0
  195. package/src/errors/mnemonic-or-password-required.d.ts.map +1 -0
  196. package/src/errors/mnemonic-or-password-required.js +26 -0
  197. package/src/errors/mnemonic-or-password-required.js.map +1 -0
  198. package/src/errors/model-not-registered.d.ts +18 -0
  199. package/src/errors/model-not-registered.d.ts.map +1 -0
  200. package/src/errors/model-not-registered.js +26 -0
  201. package/src/errors/model-not-registered.js.map +1 -0
  202. package/src/errors/mongoose-validation.d.ts +28 -0
  203. package/src/errors/mongoose-validation.d.ts.map +1 -0
  204. package/src/errors/mongoose-validation.js +33 -0
  205. package/src/errors/mongoose-validation.js.map +1 -0
  206. package/src/errors/symmetric.d.ts +23 -0
  207. package/src/errors/symmetric.d.ts.map +1 -0
  208. package/src/errors/symmetric.js +37 -0
  209. package/src/errors/symmetric.js.map +1 -0
  210. package/src/errors/token-expired.d.ts +17 -0
  211. package/src/errors/token-expired.d.ts.map +1 -0
  212. package/src/errors/token-expired.js +24 -0
  213. package/src/errors/token-expired.js.map +1 -0
  214. package/src/get-language.d.ts +12 -0
  215. package/src/get-language.d.ts.map +1 -0
  216. package/src/get-language.js +40 -0
  217. package/src/get-language.js.map +1 -0
  218. package/src/get-timezone.d.ts +12 -0
  219. package/src/get-timezone.d.ts.map +1 -0
  220. package/src/get-timezone.js +53 -0
  221. package/src/get-timezone.js.map +1 -0
  222. package/src/{index.ts → index.d.ts} +2 -44
  223. package/src/index.d.ts.map +1 -0
  224. package/src/index.js +80 -0
  225. package/src/index.js.map +1 -0
  226. package/src/interfaces/{api-error-response.ts → api-error-response.d.ts} +2 -3
  227. package/src/interfaces/api-error-response.d.ts.map +1 -0
  228. package/src/interfaces/api-error-response.js +8 -0
  229. package/src/interfaces/api-error-response.js.map +1 -0
  230. package/src/interfaces/{api-express-validation-error-response.ts → api-express-validation-error-response.d.ts} +3 -4
  231. package/src/interfaces/api-express-validation-error-response.d.ts.map +1 -0
  232. package/src/interfaces/api-express-validation-error-response.js +8 -0
  233. package/src/interfaces/api-express-validation-error-response.js.map +1 -0
  234. package/src/interfaces/{api-message-response.ts → api-message-response.d.ts} +2 -2
  235. package/src/interfaces/api-message-response.d.ts.map +1 -0
  236. package/src/interfaces/api-message-response.js +8 -0
  237. package/src/interfaces/api-message-response.js.map +1 -0
  238. package/src/interfaces/{api-mongo-validation-error-response.ts → api-mongo-validation-error-response.d.ts} +2 -3
  239. package/src/interfaces/api-mongo-validation-error-response.d.ts.map +1 -0
  240. package/src/interfaces/api-mongo-validation-error-response.js +8 -0
  241. package/src/interfaces/api-mongo-validation-error-response.js.map +1 -0
  242. package/src/interfaces/api-responses/{backup-codes-response.ts → backup-codes-response.d.ts} +2 -3
  243. package/src/interfaces/api-responses/backup-codes-response.d.ts.map +1 -0
  244. package/src/interfaces/api-responses/backup-codes-response.js +8 -0
  245. package/src/interfaces/api-responses/backup-codes-response.js.map +1 -0
  246. package/src/interfaces/api-responses/{challenge-response.ts → challenge-response.d.ts} +5 -6
  247. package/src/interfaces/api-responses/challenge-response.d.ts.map +1 -0
  248. package/src/interfaces/api-responses/challenge-response.js +7 -0
  249. package/src/interfaces/api-responses/challenge-response.js.map +1 -0
  250. package/src/interfaces/api-responses/{code-count-response.ts → code-count-response.d.ts} +2 -3
  251. package/src/interfaces/api-responses/code-count-response.d.ts.map +1 -0
  252. package/src/interfaces/api-responses/code-count-response.js +8 -0
  253. package/src/interfaces/api-responses/code-count-response.js.map +1 -0
  254. package/src/interfaces/api-responses/{index.ts → index.d.ts} +1 -0
  255. package/src/interfaces/api-responses/index.d.ts.map +1 -0
  256. package/src/interfaces/api-responses/index.js +12 -0
  257. package/src/interfaces/api-responses/index.js.map +1 -0
  258. package/src/interfaces/api-responses/{login-response.ts → login-response.d.ts} +4 -5
  259. package/src/interfaces/api-responses/login-response.d.ts.map +1 -0
  260. package/src/interfaces/api-responses/login-response.js +8 -0
  261. package/src/interfaces/api-responses/login-response.js.map +1 -0
  262. package/src/interfaces/api-responses/{mnemonic-response.ts → mnemonic-response.d.ts} +3 -4
  263. package/src/interfaces/api-responses/mnemonic-response.d.ts.map +1 -0
  264. package/src/interfaces/api-responses/mnemonic-response.js +7 -0
  265. package/src/interfaces/api-responses/mnemonic-response.js.map +1 -0
  266. package/src/interfaces/api-responses/{registration-response.ts → registration-response.d.ts} +5 -6
  267. package/src/interfaces/api-responses/registration-response.d.ts.map +1 -0
  268. package/src/interfaces/api-responses/registration-response.js +7 -0
  269. package/src/interfaces/api-responses/registration-response.js.map +1 -0
  270. package/src/interfaces/api-responses/{request-user-response.ts → request-user-response.d.ts} +2 -3
  271. package/src/interfaces/api-responses/request-user-response.d.ts.map +1 -0
  272. package/src/interfaces/api-responses/request-user-response.js +8 -0
  273. package/src/interfaces/api-responses/request-user-response.js.map +1 -0
  274. package/src/interfaces/api-responses/{user-settings-response.ts → user-settings-response.d.ts} +9 -10
  275. package/src/interfaces/api-responses/user-settings-response.d.ts.map +1 -0
  276. package/src/interfaces/api-responses/user-settings-response.js +8 -0
  277. package/src/interfaces/api-responses/user-settings-response.js.map +1 -0
  278. package/src/interfaces/application.d.ts +39 -0
  279. package/src/interfaces/application.d.ts.map +1 -0
  280. package/src/interfaces/application.js +8 -0
  281. package/src/interfaces/application.js.map +1 -0
  282. package/src/interfaces/backend-objects/{email-token.ts → email-token.d.ts} +3 -8
  283. package/src/interfaces/backend-objects/email-token.d.ts.map +1 -0
  284. package/src/interfaces/backend-objects/email-token.js +8 -0
  285. package/src/interfaces/backend-objects/email-token.js.map +1 -0
  286. package/src/interfaces/backend-objects/{index.ts → index.d.ts} +1 -0
  287. package/src/interfaces/backend-objects/index.d.ts.map +1 -0
  288. package/src/interfaces/backend-objects/index.js +8 -0
  289. package/src/interfaces/backend-objects/index.js.map +1 -0
  290. package/src/interfaces/backend-objects/{request-user.ts → request-user.d.ts} +2 -6
  291. package/src/interfaces/backend-objects/request-user.d.ts.map +1 -0
  292. package/src/interfaces/backend-objects/request-user.js +8 -0
  293. package/src/interfaces/backend-objects/request-user.js.map +1 -0
  294. package/src/interfaces/backend-objects/{role.ts → role.d.ts} +2 -7
  295. package/src/interfaces/backend-objects/role.d.ts.map +1 -0
  296. package/src/interfaces/backend-objects/role.js +8 -0
  297. package/src/interfaces/backend-objects/role.js.map +1 -0
  298. package/src/interfaces/backend-objects/{user.ts → user.d.ts} +2 -6
  299. package/src/interfaces/backend-objects/user.d.ts.map +1 -0
  300. package/src/interfaces/backend-objects/user.js +8 -0
  301. package/src/interfaces/backend-objects/user.js.map +1 -0
  302. package/src/interfaces/{checksum-config.ts → checksum-config.d.ts} +3 -3
  303. package/src/interfaces/checksum-config.d.ts.map +1 -0
  304. package/src/interfaces/checksum-config.js +8 -0
  305. package/src/interfaces/checksum-config.js.map +1 -0
  306. package/src/interfaces/checksum-consts.d.ts +20 -0
  307. package/src/interfaces/checksum-consts.d.ts.map +1 -0
  308. package/src/interfaces/checksum-consts.js +8 -0
  309. package/src/interfaces/checksum-consts.js.map +1 -0
  310. package/src/interfaces/constants.d.ts +107 -0
  311. package/src/interfaces/constants.d.ts.map +1 -0
  312. package/src/interfaces/constants.js +8 -0
  313. package/src/interfaces/constants.js.map +1 -0
  314. package/src/interfaces/{controller-config.ts → controller-config.d.ts} +15 -31
  315. package/src/interfaces/controller-config.d.ts.map +1 -0
  316. package/src/interfaces/controller-config.js +8 -0
  317. package/src/interfaces/controller-config.js.map +1 -0
  318. package/src/interfaces/{create-user-basics.ts → create-user-basics.d.ts} +13 -13
  319. package/src/interfaces/create-user-basics.d.ts.map +1 -0
  320. package/src/interfaces/create-user-basics.js +8 -0
  321. package/src/interfaces/create-user-basics.js.map +1 -0
  322. package/src/interfaces/{csp-config.ts → csp-config.d.ts} +5 -15
  323. package/src/interfaces/csp-config.d.ts.map +1 -0
  324. package/src/interfaces/csp-config.js +23 -0
  325. package/src/interfaces/csp-config.js.map +1 -0
  326. package/src/interfaces/{csp-definition.ts → csp-definition.d.ts} +9 -46
  327. package/src/interfaces/csp-definition.d.ts.map +1 -0
  328. package/src/interfaces/csp-definition.js +32 -0
  329. package/src/interfaces/csp-definition.js.map +1 -0
  330. package/src/interfaces/{db-init-result.ts → db-init-result.d.ts} +2 -3
  331. package/src/interfaces/db-init-result.d.ts.map +1 -0
  332. package/src/interfaces/db-init-result.js +8 -0
  333. package/src/interfaces/db-init-result.js.map +1 -0
  334. package/src/interfaces/{deep-partial.ts → deep-partial.d.ts} +2 -2
  335. package/src/interfaces/deep-partial.d.ts.map +1 -0
  336. package/src/interfaces/deep-partial.js +8 -0
  337. package/src/interfaces/deep-partial.js.map +1 -0
  338. package/src/interfaces/{discriminator-collections.ts → discriminator-collections.d.ts} +4 -8
  339. package/src/interfaces/discriminator-collections.d.ts.map +1 -0
  340. package/src/interfaces/discriminator-collections.js +8 -0
  341. package/src/interfaces/discriminator-collections.js.map +1 -0
  342. package/src/interfaces/email-service.d.ts +21 -0
  343. package/src/interfaces/email-service.d.ts.map +1 -0
  344. package/src/interfaces/email-service.js +8 -0
  345. package/src/interfaces/email-service.js.map +1 -0
  346. package/src/interfaces/environment-mongo.d.ts +85 -0
  347. package/src/interfaces/environment-mongo.d.ts.map +1 -0
  348. package/src/interfaces/environment-mongo.js +8 -0
  349. package/src/interfaces/environment-mongo.js.map +1 -0
  350. package/src/interfaces/environment.d.ts +190 -0
  351. package/src/interfaces/environment.d.ts.map +1 -0
  352. package/src/interfaces/environment.js +8 -0
  353. package/src/interfaces/environment.js.map +1 -0
  354. package/src/interfaces/{failable-result.ts → failable-result.d.ts} +5 -5
  355. package/src/interfaces/failable-result.d.ts.map +1 -0
  356. package/src/interfaces/failable-result.js +8 -0
  357. package/src/interfaces/failable-result.js.map +1 -0
  358. package/src/interfaces/{fec-consts.ts → fec-consts.d.ts} +3 -3
  359. package/src/interfaces/fec-consts.d.ts.map +1 -0
  360. package/src/interfaces/fec-consts.js +8 -0
  361. package/src/interfaces/fec-consts.js.map +1 -0
  362. package/src/interfaces/{flexible-csp.ts → flexible-csp.d.ts} +5 -16
  363. package/src/interfaces/flexible-csp.d.ts.map +1 -0
  364. package/src/interfaces/flexible-csp.js +24 -0
  365. package/src/interfaces/flexible-csp.js.map +1 -0
  366. package/src/interfaces/{handleable-error-options.ts → handleable-error-options.d.ts} +5 -5
  367. package/src/interfaces/handleable-error-options.d.ts.map +1 -0
  368. package/src/interfaces/handleable-error-options.js +8 -0
  369. package/src/interfaces/handleable-error-options.js.map +1 -0
  370. package/src/interfaces/{index.ts → index.d.ts} +1 -0
  371. package/src/interfaces/index.d.ts.map +1 -0
  372. package/src/interfaces/index.js +38 -0
  373. package/src/interfaces/index.js.map +1 -0
  374. package/src/interfaces/jwt-consts.d.ts +20 -0
  375. package/src/interfaces/jwt-consts.d.ts.map +1 -0
  376. package/src/interfaces/jwt-consts.js +8 -0
  377. package/src/interfaces/jwt-consts.js.map +1 -0
  378. package/src/interfaces/{jwt-sign-response.ts → jwt-sign-response.d.ts} +9 -18
  379. package/src/interfaces/jwt-sign-response.d.ts.map +1 -0
  380. package/src/interfaces/jwt-sign-response.js +8 -0
  381. package/src/interfaces/jwt-sign-response.js.map +1 -0
  382. package/src/interfaces/models/{email-token.ts → email-token.d.ts} +1 -2
  383. package/src/interfaces/models/email-token.d.ts.map +1 -0
  384. package/src/interfaces/models/email-token.js +8 -0
  385. package/src/interfaces/models/email-token.js.map +1 -0
  386. package/src/interfaces/models/{index.ts → index.d.ts} +1 -0
  387. package/src/interfaces/models/index.d.ts.map +1 -0
  388. package/src/interfaces/models/index.js +11 -0
  389. package/src/interfaces/models/index.js.map +1 -0
  390. package/src/interfaces/models/{mnemonic.ts → mnemonic.d.ts} +1 -2
  391. package/src/interfaces/models/mnemonic.d.ts.map +1 -0
  392. package/src/interfaces/models/mnemonic.js +8 -0
  393. package/src/interfaces/models/mnemonic.js.map +1 -0
  394. package/src/interfaces/models/{role.ts → role.d.ts} +1 -2
  395. package/src/interfaces/models/role.d.ts.map +1 -0
  396. package/src/interfaces/models/role.js +8 -0
  397. package/src/interfaces/models/role.js.map +1 -0
  398. package/src/interfaces/models/{token-role.ts → token-role.d.ts} +2 -6
  399. package/src/interfaces/models/token-role.d.ts.map +1 -0
  400. package/src/interfaces/models/token-role.js +8 -0
  401. package/src/interfaces/models/token-role.js.map +1 -0
  402. package/src/interfaces/models/{used-direct-login-token.ts → used-direct-login-token.d.ts} +2 -4
  403. package/src/interfaces/models/used-direct-login-token.d.ts.map +1 -0
  404. package/src/interfaces/models/used-direct-login-token.js +8 -0
  405. package/src/interfaces/models/used-direct-login-token.js.map +1 -0
  406. package/src/interfaces/models/{user-role.ts → user-role.d.ts} +2 -6
  407. package/src/interfaces/models/user-role.d.ts.map +1 -0
  408. package/src/interfaces/models/user-role.js +8 -0
  409. package/src/interfaces/models/user-role.js.map +1 -0
  410. package/src/interfaces/models/{user.ts → user.d.ts} +3 -12
  411. package/src/interfaces/models/user.d.ts.map +1 -0
  412. package/src/interfaces/models/user.js +8 -0
  413. package/src/interfaces/models/user.js.map +1 -0
  414. package/src/interfaces/{mongo-errors.ts → mongo-errors.d.ts} +2 -3
  415. package/src/interfaces/mongo-errors.d.ts.map +1 -0
  416. package/src/interfaces/mongo-errors.js +8 -0
  417. package/src/interfaces/mongo-errors.js.map +1 -0
  418. package/src/interfaces/request-user.d.ts +67 -0
  419. package/src/interfaces/request-user.d.ts.map +1 -0
  420. package/src/interfaces/request-user.js +8 -0
  421. package/src/interfaces/request-user.js.map +1 -0
  422. package/src/interfaces/required-string-keys.d.ts +28 -0
  423. package/src/interfaces/required-string-keys.d.ts.map +1 -0
  424. package/src/interfaces/required-string-keys.js +8 -0
  425. package/src/interfaces/required-string-keys.js.map +1 -0
  426. package/src/interfaces/{schema.ts → schema.d.ts} +22 -28
  427. package/src/interfaces/schema.d.ts.map +1 -0
  428. package/src/interfaces/schema.js +8 -0
  429. package/src/interfaces/schema.js.map +1 -0
  430. package/src/interfaces/server-init-result.d.ts +45 -0
  431. package/src/interfaces/server-init-result.d.ts.map +1 -0
  432. package/src/interfaces/server-init-result.js +8 -0
  433. package/src/interfaces/server-init-result.js.map +1 -0
  434. package/src/interfaces/{status-code-response.ts → status-code-response.d.ts} +4 -5
  435. package/src/interfaces/status-code-response.d.ts.map +1 -0
  436. package/src/interfaces/status-code-response.js +8 -0
  437. package/src/interfaces/status-code-response.js.map +1 -0
  438. package/src/interfaces/{symmetric-encryption-results.ts → symmetric-encryption-results.d.ts} +3 -3
  439. package/src/interfaces/symmetric-encryption-results.d.ts.map +1 -1
  440. package/src/interfaces/symmetric-encryption-results.js +5 -0
  441. package/src/interfaces/symmetric-encryption-results.js.map +1 -1
  442. package/src/interfaces/{test-environment.ts → test-environment.d.ts} +6 -7
  443. package/src/interfaces/test-environment.d.ts.map +1 -0
  444. package/src/interfaces/test-environment.js +8 -0
  445. package/src/interfaces/test-environment.js.map +1 -0
  446. package/src/interfaces/{token-response.ts → token-response.d.ts} +2 -3
  447. package/src/interfaces/token-response.d.ts.map +1 -0
  448. package/src/interfaces/token-response.js +8 -0
  449. package/src/interfaces/token-response.js.map +1 -0
  450. package/src/middleware-utils.d.ts +31 -0
  451. package/src/middleware-utils.d.ts.map +1 -0
  452. package/src/middleware-utils.js +117 -0
  453. package/src/middleware-utils.js.map +1 -0
  454. package/src/middlewares/authenticate-crypto.d.ts +27 -0
  455. package/src/middlewares/authenticate-crypto.d.ts.map +1 -0
  456. package/src/middlewares/authenticate-crypto.js +143 -0
  457. package/src/middlewares/authenticate-crypto.js.map +1 -0
  458. package/src/middlewares/authenticate-token.d.ts +34 -0
  459. package/src/middlewares/authenticate-token.d.ts.map +1 -0
  460. package/src/middlewares/authenticate-token.js +117 -0
  461. package/src/middlewares/authenticate-token.js.map +1 -0
  462. package/src/middlewares/cleanup-crypto.d.ts +16 -0
  463. package/src/middlewares/cleanup-crypto.d.ts.map +1 -0
  464. package/src/middlewares/cleanup-crypto.js +41 -0
  465. package/src/middlewares/cleanup-crypto.js.map +1 -0
  466. package/src/middlewares/{index.ts → index.d.ts} +1 -0
  467. package/src/middlewares/index.d.ts.map +1 -0
  468. package/src/middlewares/index.js +8 -0
  469. package/src/middlewares/index.js.map +1 -0
  470. package/src/middlewares/{set-global-context-language.ts → set-global-context-language.d.ts} +2 -24
  471. package/src/middlewares/set-global-context-language.d.ts.map +1 -0
  472. package/src/middlewares/set-global-context-language.js +27 -0
  473. package/src/middlewares/set-global-context-language.js.map +1 -0
  474. package/src/model-registry.d.ts +79 -0
  475. package/src/model-registry.d.ts.map +1 -0
  476. package/src/model-registry.js +97 -0
  477. package/src/model-registry.js.map +1 -0
  478. package/src/models/{email-token.ts → email-token.d.ts} +2 -27
  479. package/src/models/email-token.d.ts.map +1 -0
  480. package/src/models/email-token.js +16 -0
  481. package/src/models/email-token.js.map +1 -0
  482. package/src/models/{index.ts → index.d.ts} +1 -0
  483. package/src/models/index.d.ts.map +1 -0
  484. package/src/models/index.js +10 -0
  485. package/src/models/index.js.map +1 -0
  486. package/src/models/{mnemonic.ts → mnemonic.d.ts} +2 -20
  487. package/src/models/mnemonic.d.ts.map +1 -0
  488. package/src/models/mnemonic.js +27 -0
  489. package/src/models/mnemonic.js.map +1 -0
  490. package/src/models/{role.ts → role.d.ts} +2 -16
  491. package/src/models/role.d.ts.map +1 -0
  492. package/src/models/role.js +27 -0
  493. package/src/models/role.js.map +1 -0
  494. package/src/models/{used-direct-login-token.ts → used-direct-login-token.d.ts} +2 -27
  495. package/src/models/used-direct-login-token.d.ts.map +1 -0
  496. package/src/models/used-direct-login-token.js +16 -0
  497. package/src/models/used-direct-login-token.js.map +1 -0
  498. package/src/models/{user-role.ts → user-role.d.ts} +2 -19
  499. package/src/models/user-role.d.ts.map +1 -0
  500. package/src/models/user-role.js +26 -0
  501. package/src/models/user-role.js.map +1 -0
  502. package/src/models/{user.ts → user.d.ts} +2 -20
  503. package/src/models/user.d.ts.map +1 -0
  504. package/src/models/user.js +27 -0
  505. package/src/models/user.js.map +1 -0
  506. package/src/pipeline/{index.ts → index.d.ts} +1 -0
  507. package/src/pipeline/index.d.ts.map +1 -0
  508. package/src/pipeline/index.js +5 -0
  509. package/src/pipeline/index.js.map +1 -0
  510. package/src/pipeline/pipeline-builder.d.ts +16 -0
  511. package/src/pipeline/pipeline-builder.d.ts.map +1 -0
  512. package/src/pipeline/pipeline-builder.js +26 -0
  513. package/src/pipeline/pipeline-builder.js.map +1 -0
  514. package/src/plugins/{index.ts → index.d.ts} +1 -0
  515. package/src/plugins/index.d.ts.map +1 -0
  516. package/src/plugins/index.js +6 -0
  517. package/src/plugins/index.js.map +1 -0
  518. package/src/plugins/{plugin-interface.ts → plugin-interface.d.ts} +5 -6
  519. package/src/plugins/plugin-interface.d.ts.map +1 -0
  520. package/src/plugins/plugin-interface.js +8 -0
  521. package/src/plugins/plugin-interface.js.map +1 -0
  522. package/src/plugins/plugin-manager.d.ts +22 -0
  523. package/src/plugins/plugin-manager.d.ts.map +1 -0
  524. package/src/plugins/plugin-manager.js +46 -0
  525. package/src/plugins/plugin-manager.js.map +1 -0
  526. package/src/registry/email-service-registry.d.ts +49 -0
  527. package/src/registry/email-service-registry.d.ts.map +1 -0
  528. package/src/registry/email-service-registry.js +64 -0
  529. package/src/registry/email-service-registry.js.map +1 -0
  530. package/src/registry/{index.ts → index.d.ts} +1 -0
  531. package/src/registry/index.d.ts.map +1 -0
  532. package/src/registry/index.js +6 -0
  533. package/src/registry/index.js.map +1 -0
  534. package/src/responses/{index.ts → index.d.ts} +1 -0
  535. package/src/responses/index.d.ts.map +1 -0
  536. package/src/responses/index.js +5 -0
  537. package/src/responses/index.js.map +1 -0
  538. package/src/responses/response-builder.d.ts +103 -0
  539. package/src/responses/response-builder.d.ts.map +1 -0
  540. package/src/responses/response-builder.js +142 -0
  541. package/src/responses/response-builder.js.map +1 -0
  542. package/src/routers/api.d.ts +59 -0
  543. package/src/routers/api.d.ts.map +1 -0
  544. package/src/routers/api.js +110 -0
  545. package/src/routers/api.js.map +1 -0
  546. package/src/routers/app.d.ts +87 -0
  547. package/src/routers/app.d.ts.map +1 -0
  548. package/src/routers/app.js +285 -0
  549. package/src/routers/app.js.map +1 -0
  550. package/src/routers/{base.ts → base.d.ts} +11 -19
  551. package/src/routers/base.d.ts.map +1 -0
  552. package/src/routers/base.js +31 -0
  553. package/src/routers/base.js.map +1 -0
  554. package/src/routers/{index.ts → index.d.ts} +1 -0
  555. package/src/routers/index.d.ts.map +1 -0
  556. package/src/routers/index.js +7 -0
  557. package/src/routers/index.js.map +1 -0
  558. package/src/routers/router-config.d.ts +35 -0
  559. package/src/routers/router-config.d.ts.map +1 -0
  560. package/src/routers/router-config.js +16 -0
  561. package/src/routers/router-config.js.map +1 -0
  562. package/src/routing/index.d.ts +2 -0
  563. package/src/routing/index.d.ts.map +1 -0
  564. package/src/routing/index.js +5 -0
  565. package/src/routing/index.js.map +1 -0
  566. package/src/routing/route-builder.d.ts +121 -0
  567. package/src/routing/route-builder.d.ts.map +1 -0
  568. package/src/routing/route-builder.js +167 -0
  569. package/src/routing/route-builder.js.map +1 -0
  570. package/src/schemas/email-token.d.ts +65 -0
  571. package/src/schemas/email-token.d.ts.map +1 -0
  572. package/src/schemas/email-token.js +68 -0
  573. package/src/schemas/email-token.js.map +1 -0
  574. package/src/schemas/{index.ts → index.d.ts} +1 -0
  575. package/src/schemas/index.d.ts.map +1 -0
  576. package/src/schemas/index.js +11 -0
  577. package/src/schemas/index.js.map +1 -0
  578. package/src/schemas/mnemonic.d.ts +37 -0
  579. package/src/schemas/mnemonic.d.ts.map +1 -0
  580. package/src/schemas/mnemonic.js +41 -0
  581. package/src/schemas/mnemonic.js.map +1 -0
  582. package/src/schemas/role.d.ts +57 -0
  583. package/src/schemas/role.d.ts.map +1 -0
  584. package/src/schemas/role.js +102 -0
  585. package/src/schemas/role.js.map +1 -0
  586. package/src/schemas/schema.d.ts +62 -0
  587. package/src/schemas/schema.d.ts.map +1 -0
  588. package/src/schemas/schema.js +81 -0
  589. package/src/schemas/schema.js.map +1 -0
  590. package/src/schemas/used-direct-login-token.d.ts +49 -0
  591. package/src/schemas/used-direct-login-token.d.ts.map +1 -0
  592. package/src/schemas/used-direct-login-token.js +35 -0
  593. package/src/schemas/used-direct-login-token.js.map +1 -0
  594. package/src/schemas/user-role.d.ts +52 -0
  595. package/src/schemas/user-role.d.ts.map +1 -0
  596. package/src/schemas/user-role.js +67 -0
  597. package/src/schemas/user-role.js.map +1 -0
  598. package/src/schemas/user.d.ts +43 -0
  599. package/src/schemas/user.d.ts.map +1 -0
  600. package/src/schemas/user.js +214 -0
  601. package/src/schemas/user.js.map +1 -0
  602. package/src/services/backup-code.d.ts +80 -0
  603. package/src/services/backup-code.d.ts.map +1 -0
  604. package/src/services/backup-code.js +189 -0
  605. package/src/services/backup-code.js.map +1 -0
  606. package/src/services/base.d.ts +22 -0
  607. package/src/services/base.d.ts.map +1 -0
  608. package/src/services/base.js +26 -0
  609. package/src/services/base.js.map +1 -0
  610. package/src/services/checksum.d.ts +90 -0
  611. package/src/services/checksum.d.ts.map +1 -0
  612. package/src/services/checksum.js +166 -0
  613. package/src/services/checksum.js.map +1 -0
  614. package/src/services/database-initialization.d.ts +138 -0
  615. package/src/services/database-initialization.d.ts.map +1 -0
  616. package/src/services/database-initialization.js +904 -0
  617. package/src/services/database-initialization.js.map +1 -0
  618. package/src/services/{db-init-cache.ts → db-init-cache.d.ts} +6 -16
  619. package/src/services/db-init-cache.d.ts.map +1 -0
  620. package/src/services/db-init-cache.js +7 -0
  621. package/src/services/db-init-cache.js.map +1 -0
  622. package/src/services/direct-login-token.d.ts +28 -0
  623. package/src/services/direct-login-token.d.ts.map +1 -0
  624. package/src/services/direct-login-token.js +62 -0
  625. package/src/services/direct-login-token.js.map +1 -0
  626. package/src/services/dummy-email-service.d.ts +30 -0
  627. package/src/services/dummy-email-service.d.ts.map +1 -0
  628. package/src/services/dummy-email-service.js +35 -0
  629. package/src/services/dummy-email-service.js.map +1 -0
  630. package/src/services/fec-usage-example.d.ts +58 -0
  631. package/src/services/fec-usage-example.d.ts.map +1 -0
  632. package/src/services/fec-usage-example.js +95 -0
  633. package/src/services/fec-usage-example.js.map +1 -0
  634. package/src/services/fec.d.ts +88 -0
  635. package/src/services/fec.d.ts.map +1 -0
  636. package/src/services/fec.js +246 -0
  637. package/src/services/fec.js.map +1 -0
  638. package/src/services/{index.ts → index.d.ts} +1 -0
  639. package/src/services/index.d.ts.map +1 -0
  640. package/src/services/index.js +22 -0
  641. package/src/services/index.js.map +1 -0
  642. package/src/services/jwt.d.ts +45 -0
  643. package/src/services/jwt.d.ts.map +1 -0
  644. package/src/services/jwt.js +105 -0
  645. package/src/services/jwt.js.map +1 -0
  646. package/src/services/key-wrapping.d.ts +139 -0
  647. package/src/services/key-wrapping.d.ts.map +1 -0
  648. package/src/services/key-wrapping.js +372 -0
  649. package/src/services/key-wrapping.js.map +1 -0
  650. package/src/services/mnemonic.d.ts +68 -0
  651. package/src/services/mnemonic.d.ts.map +1 -0
  652. package/src/services/mnemonic.js +120 -0
  653. package/src/services/mnemonic.js.map +1 -0
  654. package/src/services/request-user.d.ts +45 -0
  655. package/src/services/request-user.d.ts.map +1 -0
  656. package/src/services/request-user.js +90 -0
  657. package/src/services/request-user.js.map +1 -0
  658. package/src/services/role.d.ts +97 -0
  659. package/src/services/role.d.ts.map +1 -0
  660. package/src/services/role.js +289 -0
  661. package/src/services/role.js.map +1 -0
  662. package/src/services/symmetric.d.ts +60 -0
  663. package/src/services/symmetric.d.ts.map +1 -0
  664. package/src/services/symmetric.js +125 -0
  665. package/src/services/symmetric.js.map +1 -0
  666. package/src/services/system-user.d.ts +22 -0
  667. package/src/services/system-user.d.ts.map +1 -0
  668. package/src/services/system-user.js +52 -0
  669. package/src/services/system-user.js.map +1 -0
  670. package/src/services/user.d.ts +368 -0
  671. package/src/services/user.d.ts.map +1 -0
  672. package/src/services/user.js +1470 -0
  673. package/src/services/user.js.map +1 -0
  674. package/src/services/xor.d.ts +28 -0
  675. package/src/services/xor.d.ts.map +1 -0
  676. package/src/services/xor.js +45 -0
  677. package/src/services/xor.js.map +1 -0
  678. package/src/{testing.ts → testing.d.ts} +1 -2
  679. package/src/testing.d.ts.map +1 -0
  680. package/src/testing.js +12 -0
  681. package/src/testing.js.map +1 -0
  682. package/src/transactions/{index.ts → index.d.ts} +1 -0
  683. package/src/transactions/index.d.ts.map +1 -0
  684. package/src/transactions/index.js +5 -0
  685. package/src/transactions/index.js.map +1 -0
  686. package/src/transactions/transaction-manager.d.ts +37 -0
  687. package/src/transactions/transaction-manager.d.ts.map +1 -0
  688. package/src/transactions/transaction-manager.js +50 -0
  689. package/src/transactions/transaction-manager.js.map +1 -0
  690. package/src/types/{app-config.ts → app-config.d.ts} +10 -16
  691. package/src/types/app-config.d.ts.map +1 -0
  692. package/src/types/app-config.js +8 -0
  693. package/src/types/app-config.js.map +1 -0
  694. package/src/types/{controller-config.ts → controller-config.d.ts} +7 -9
  695. package/src/types/controller-config.d.ts.map +1 -0
  696. package/src/types/controller-config.js +8 -0
  697. package/src/types/controller-config.js.map +1 -0
  698. package/src/types/{environment-variables.ts → environment-variables.d.ts} +5 -27
  699. package/src/types/environment-variables.d.ts.map +1 -0
  700. package/src/types/environment-variables.js +41 -0
  701. package/src/types/environment-variables.js.map +1 -0
  702. package/src/types/{index.ts → index.d.ts} +1 -0
  703. package/src/types/index.d.ts.map +1 -0
  704. package/src/types/index.js +6 -0
  705. package/src/types/index.js.map +1 -0
  706. package/src/types/{mongoose-helpers.ts → mongoose-helpers.d.ts} +2 -3
  707. package/src/types/mongoose-helpers.d.ts.map +1 -0
  708. package/src/types/mongoose-helpers.js +8 -0
  709. package/src/types/mongoose-helpers.js.map +1 -0
  710. package/src/types.d.ts +118 -0
  711. package/src/types.d.ts.map +1 -0
  712. package/src/types.js +28 -0
  713. package/src/types.js.map +1 -0
  714. package/src/utils.d.ts +240 -0
  715. package/src/utils.d.ts.map +1 -0
  716. package/src/utils.js +843 -0
  717. package/src/utils.js.map +1 -0
  718. package/src/validation/{index.ts → index.d.ts} +1 -0
  719. package/src/validation/index.d.ts.map +1 -0
  720. package/src/validation/index.js +5 -0
  721. package/src/validation/index.js.map +1 -0
  722. package/src/validation/validation-builder.d.ts +71 -0
  723. package/src/validation/validation-builder.d.ts.map +1 -0
  724. package/src/validation/validation-builder.js +120 -0
  725. package/src/validation/validation-builder.js.map +1 -0
  726. package/LICENSE +0 -21
  727. package/src/__tests__/fixtures/model-mocks.mock.ts +0 -164
  728. package/src/__tests__/helpers/application.mock.ts +0 -89
  729. package/src/__tests__/helpers/setup-test-env.ts +0 -202
  730. package/src/application-base.ts +0 -548
  731. package/src/application-concrete.ts +0 -62
  732. package/src/application.ts +0 -330
  733. package/src/backup-code.ts +0 -348
  734. package/src/builders/application-builder.ts +0 -147
  735. package/src/constants.ts +0 -89
  736. package/src/container/service-container.ts +0 -85
  737. package/src/controllers/base.ts +0 -512
  738. package/src/controllers/user.ts +0 -1734
  739. package/src/decorators/base-controller.ts +0 -91
  740. package/src/decorators/controller.ts +0 -152
  741. package/src/decorators/zod-validation.ts +0 -64
  742. package/src/defaults.ts +0 -259
  743. package/src/enumerations/base-model-name.ts +0 -47
  744. package/src/enumerations/schema-collection.ts +0 -39
  745. package/src/environment.ts +0 -859
  746. package/src/errors/express-validation.ts +0 -38
  747. package/src/errors/invalid-backup-code-version.ts +0 -30
  748. package/src/errors/invalid-jwt-token.ts +0 -24
  749. package/src/errors/invalid-model.ts +0 -24
  750. package/src/errors/invalid-new-password.ts +0 -33
  751. package/src/errors/invalid-password.ts +0 -28
  752. package/src/errors/missing-validated-data.ts +0 -55
  753. package/src/errors/mnemonic-or-password-required.ts +0 -26
  754. package/src/errors/model-not-registered.ts +0 -24
  755. package/src/errors/mongoose-validation.ts +0 -56
  756. package/src/errors/symmetric.ts +0 -53
  757. package/src/errors/token-expired.ts +0 -24
  758. package/src/get-language.ts +0 -64
  759. package/src/get-timezone.ts +0 -76
  760. package/src/interfaces/application.ts +0 -40
  761. package/src/interfaces/checksum-consts.ts +0 -23
  762. package/src/interfaces/constants.ts +0 -114
  763. package/src/interfaces/email-service.ts +0 -26
  764. package/src/interfaces/environment-mongo.ts +0 -86
  765. package/src/interfaces/environment.ts +0 -191
  766. package/src/interfaces/jwt-consts.ts +0 -33
  767. package/src/interfaces/request-user.ts +0 -80
  768. package/src/interfaces/required-string-keys.ts +0 -33
  769. package/src/interfaces/server-init-result.ts +0 -48
  770. package/src/middleware-utils.ts +0 -138
  771. package/src/middlewares/authenticate-crypto.ts +0 -237
  772. package/src/middlewares/authenticate-token.ts +0 -165
  773. package/src/middlewares/cleanup-crypto.ts +0 -47
  774. package/src/model-registry.ts +0 -142
  775. package/src/pipeline/pipeline-builder.ts +0 -27
  776. package/src/plugins/plugin-manager.ts +0 -53
  777. package/src/registry/email-service-registry.ts +0 -76
  778. package/src/responses/response-builder.ts +0 -166
  779. package/src/routers/api.ts +0 -233
  780. package/src/routers/app.ts +0 -395
  781. package/src/routers/router-config.ts +0 -34
  782. package/src/routing/index.ts +0 -1
  783. package/src/routing/route-builder.ts +0 -214
  784. package/src/schemas/email-token.ts +0 -112
  785. package/src/schemas/mnemonic.ts +0 -48
  786. package/src/schemas/role.ts +0 -153
  787. package/src/schemas/schema.ts +0 -185
  788. package/src/schemas/used-direct-login-token.ts +0 -58
  789. package/src/schemas/user-role.ts +0 -93
  790. package/src/schemas/user.ts +0 -244
  791. package/src/services/backup-code.ts +0 -327
  792. package/src/services/base.ts +0 -46
  793. package/src/services/checksum.ts +0 -189
  794. package/src/services/database-initialization.ts +0 -1653
  795. package/src/services/direct-login-token.ts +0 -83
  796. package/src/services/dummy-email-service.ts +0 -43
  797. package/src/services/fec-usage-example.ts +0 -123
  798. package/src/services/fec.ts +0 -399
  799. package/src/services/jwt.ts +0 -146
  800. package/src/services/key-wrapping.ts +0 -528
  801. package/src/services/mnemonic.ts +0 -174
  802. package/src/services/request-user.ts +0 -127
  803. package/src/services/role.ts +0 -417
  804. package/src/services/symmetric.ts +0 -164
  805. package/src/services/system-user.ts +0 -87
  806. package/src/services/user.ts +0 -2324
  807. package/src/services/xor.ts +0 -39
  808. package/src/transactions/transaction-manager.ts +0 -63
  809. package/src/types/mongoose-override.d.ts +0 -1
  810. package/src/types/mongoose.d.ts +0 -1
  811. package/src/types.ts +0 -189
  812. package/src/utils.ts +0 -1116
  813. package/src/validation/validation-builder.ts +0 -155
@@ -1,330 +0,0 @@
1
- /**
2
- * @fileoverview Main application class with Express server.
3
- * Extends BaseApplication with HTTP/HTTPS server and routing.
4
- * @module application
5
- */
6
-
7
- import { HandleableError } from '@digitaldefiance/i18n-lib';
8
- import mongoose from '@digitaldefiance/mongoose-types';
9
- import {
10
- Constants,
11
- getSuiteCoreI18nEngine,
12
- SuiteCoreComponentId,
13
- SuiteCoreStringKey,
14
- TranslatableSuiteError,
15
- } from '@digitaldefiance/suite-core-lib';
16
- import express, {
17
- Application as ExpressApplication,
18
- NextFunction,
19
- Request,
20
- Response,
21
- } from 'express';
22
- import { readFileSync } from 'fs';
23
- import { HelmetOptions } from 'helmet';
24
- import { Server } from 'http';
25
- import { createServer } from 'https';
26
- import { isAbsolute, normalize, resolve } from 'path';
27
- import { BaseApplication } from './application-base';
28
- import { IBaseDocument } from './documents/base';
29
- import { Environment } from './environment';
30
- import {
31
- IApplication,
32
- ICSPConfig,
33
- IFailableResult,
34
- isCSPConfig,
35
- IServerInitResult,
36
- } from './interfaces';
37
- import { IConstants } from './interfaces/constants';
38
- import { IFlexibleCSP, isFlexibleCSP } from './interfaces/flexible-csp';
39
- import { initMiddleware, isHelmetOptions } from './middleware-utils';
40
- import { AppRouter } from './routers/app';
41
- import { BaseRouter } from './routers/base';
42
- import { DatabaseInitializationService } from './services';
43
- import { SchemaMap } from './types';
44
- import { debugLog, handleError, sendApiMessageResponse } from './utils';
45
- import type { PlatformID } from '@digitaldefiance/node-ecies-lib';
46
-
47
- /**
48
- * Application class
49
- */
50
- type ServerWithOptionalClose = Server & { closeAllConnections?: () => void };
51
-
52
- export class Application<
53
- TInitResults extends IServerInitResult<TID>,
54
- TModelDocs extends Record<string, IBaseDocument<any, TID>>,
55
- TID extends PlatformID = Buffer,
56
- TEnvironment extends Environment<TID> = Environment<TID>,
57
- TConstants extends IConstants = IConstants,
58
- TAppRouter extends AppRouter<TID> = AppRouter<TID>,
59
- >
60
- extends BaseApplication<TID, TModelDocs, TInitResults, TConstants>
61
- implements IApplication<TID>
62
- {
63
- public readonly expressApp: ExpressApplication;
64
- private server: ServerWithOptionalClose | null = null;
65
- private readonly _cspConfig: ICSPConfig | HelmetOptions | IFlexibleCSP;
66
- private readonly _apiRouterFactory: (
67
- app: IApplication<TID>,
68
- ) => BaseRouter<TID>;
69
- private readonly _appRouterFactory: (
70
- apiRouter: BaseRouter<TID>,
71
- ) => TAppRouter;
72
- private readonly _initMiddleware: typeof initMiddleware;
73
- private _apiRouter?: BaseRouter<TID>;
74
-
75
- public override get environment(): TEnvironment {
76
- return super.environment as TEnvironment;
77
- }
78
-
79
- protected registerServices(): void {
80
- // Services will be registered by subclasses or ApiRouter
81
- // Base implementation does nothing
82
- }
83
-
84
- constructor(
85
- environment: TEnvironment,
86
- apiRouterFactory: (app: IApplication<TID>) => BaseRouter<TID>,
87
- schemaMapFactory: (
88
- connection: mongoose.Connection,
89
- ) => SchemaMap<TID, TModelDocs>,
90
- databaseInitFunction: (
91
- application: BaseApplication<TID, TModelDocs, TInitResults>,
92
- ) => Promise<IFailableResult<TInitResults>>,
93
- initResultHashFunction: (initResults: TInitResults) => string,
94
- cspConfig: ICSPConfig | HelmetOptions | IFlexibleCSP = {
95
- corsWhitelist: [],
96
- csp: {
97
- defaultSrc: [],
98
- imgSrc: [],
99
- connectSrc: [],
100
- scriptSrc: [],
101
- styleSrc: [],
102
- fontSrc: [],
103
- frameSrc: [],
104
- },
105
- },
106
- constants: TConstants = Constants as TConstants,
107
- appRouterFactory: (apiRouter: BaseRouter<TID>) => TAppRouter = (
108
- apiRouter,
109
- ) => new AppRouter(apiRouter) as TAppRouter,
110
- customInitMiddleware: typeof initMiddleware = initMiddleware,
111
- ) {
112
- super(
113
- environment,
114
- schemaMapFactory,
115
- databaseInitFunction,
116
- initResultHashFunction,
117
- constants,
118
- );
119
- this._apiRouterFactory = apiRouterFactory;
120
- this._appRouterFactory = appRouterFactory;
121
- this._initMiddleware = customInitMiddleware;
122
- this.expressApp = express();
123
- this.server = null;
124
- this._cspConfig = cspConfig;
125
- this.registerServices();
126
- }
127
-
128
- public override async start(mongoUri?: string): Promise<void> {
129
- const engine = getSuiteCoreI18nEngine({ constants: this.constants });
130
- await super.start(mongoUri, true);
131
- if (this.devDatabase) {
132
- const result = await this.initializeDevDatabase();
133
- DatabaseInitializationService.printServerInitResults(result, false);
134
- }
135
- try {
136
- this._apiRouter = this._apiRouterFactory(this);
137
- if (isFlexibleCSP(this._cspConfig) || isCSPConfig(this._cspConfig)) {
138
- this._initMiddleware(
139
- this.expressApp,
140
- this._cspConfig.corsWhitelist,
141
- this._cspConfig.csp,
142
- );
143
- } else if (isHelmetOptions(this._cspConfig)) {
144
- this._initMiddleware(this.expressApp, [], this._cspConfig);
145
- }
146
- const appRouter = this._appRouterFactory(this._apiRouter);
147
-
148
- appRouter.init(this.expressApp);
149
- this.expressApp.use(
150
- (
151
- err: HandleableError | Error,
152
- req: Request,
153
- res: Response,
154
- _next: NextFunction,
155
- ) => {
156
- if (
157
- res.headersSent ||
158
- (err as { _errorHandlerProcessing?: boolean })
159
- ._errorHandlerProcessing
160
- ) {
161
- return;
162
- }
163
- (
164
- err as { _errorHandlerProcessing?: boolean }
165
- )._errorHandlerProcessing = true;
166
-
167
- const safeHandle = () => {
168
- try {
169
- const handleableError =
170
- err instanceof HandleableError
171
- ? err
172
- : new HandleableError(
173
- err instanceof Error ? err : new Error(String(err)),
174
- { cause: err },
175
- );
176
- handleError(
177
- handleableError,
178
- res,
179
- sendApiMessageResponse,
180
- () => {},
181
- );
182
- } catch {
183
- res.status(500).json({
184
- message: engine.translate(
185
- SuiteCoreComponentId,
186
- SuiteCoreStringKey.Error_RecursiveErrorHandlingDetected,
187
- ),
188
- error: {
189
- message:
190
- err instanceof Error
191
- ? err.message
192
- : engine.translate(
193
- SuiteCoreComponentId,
194
- SuiteCoreStringKey.Common_UnexpectedError,
195
- ),
196
- },
197
- });
198
- }
199
- };
200
-
201
- setImmediate(safeHandle);
202
- },
203
- );
204
-
205
- const serversReady: Promise<void>[] = [];
206
- serversReady.push(
207
- new Promise<void>((resolve) => {
208
- this.server = this.expressApp.listen(
209
- this.environment.port,
210
- this.environment.host,
211
- () => {
212
- debugLog(
213
- this.environment.debug,
214
- 'log',
215
- `[ ${engine.translate(
216
- SuiteCoreComponentId,
217
- SuiteCoreStringKey.Common_Ready,
218
- )} ] http://${this.environment.host}:${this.environment.port}`,
219
- );
220
- resolve();
221
- },
222
- ) as ServerWithOptionalClose;
223
- }),
224
- );
225
-
226
- if (this.environment.httpsDevCertRoot) {
227
- try {
228
- const certRoot = normalize(this.environment.httpsDevCertRoot);
229
- if (!isAbsolute(certRoot) || certRoot.includes('..')) {
230
- throw new TranslatableSuiteError(
231
- SuiteCoreStringKey.Error_InvalidCertificatePathMustBeAbsolute,
232
- );
233
- }
234
- const certPath = normalize(resolve(certRoot + '.pem'));
235
- const keyPath = normalize(resolve(certRoot + '-key.pem'));
236
- if (certPath.includes('..') || keyPath.includes('..')) {
237
- throw new TranslatableSuiteError(
238
- SuiteCoreStringKey.Error_InvalidCertificatePathAfterResolution,
239
- );
240
- }
241
- const options = {
242
- // amazonq-ignore-next-line fixed above
243
- key: readFileSync(keyPath),
244
- // amazonq-ignore-next-line fixed above
245
- cert: readFileSync(certPath),
246
- };
247
-
248
- serversReady.push(
249
- new Promise<void>((resolve) => {
250
- createServer(options, this.expressApp).listen(
251
- this.environment.httpsDevPort,
252
- this.environment.host,
253
- () => {
254
- console.log(
255
- `[ ${engine.translate(
256
- SuiteCoreComponentId,
257
- SuiteCoreStringKey.Common_Ready,
258
- )} ] https://${this.environment.host}:${
259
- this.environment.httpsDevPort
260
- }`,
261
- );
262
- resolve();
263
- },
264
- );
265
- }),
266
- );
267
- } catch (err) {
268
- console.error('Failed to start HTTPS server:', err);
269
- }
270
- }
271
-
272
- await Promise.all(serversReady);
273
- this._ready = true;
274
- } catch (err) {
275
- console.error(
276
- engine.translate(
277
- SuiteCoreComponentId,
278
- SuiteCoreStringKey.Error_FailedToStartApplication,
279
- ),
280
- err,
281
- );
282
- if (process.env['NODE_ENV'] === 'test') {
283
- throw err;
284
- }
285
- process.exit(1);
286
- }
287
- }
288
-
289
- public override async stop(): Promise<void> {
290
- const engine = getSuiteCoreI18nEngine({ constants: this.constants });
291
- if (this.server) {
292
- debugLog(
293
- this.environment.debug,
294
- 'log',
295
- `[ ${engine.translate(
296
- SuiteCoreComponentId,
297
- SuiteCoreStringKey.Common_Stopping,
298
- )} ] ${engine.translate(
299
- SuiteCoreComponentId,
300
- SuiteCoreStringKey.Common_ApplicationAndDatabase,
301
- )}`,
302
- );
303
- await new Promise<void>((resolve, reject) => {
304
- this.server!.closeAllConnections?.();
305
- this.server!.close((err) => {
306
- if (err) {
307
- reject(err);
308
- } else {
309
- resolve();
310
- }
311
- });
312
- });
313
- this.server = null;
314
- }
315
-
316
- await super.stop();
317
- this._ready = false;
318
- debugLog(
319
- this.environment.debug,
320
- 'log',
321
- `[ ${engine.translate(
322
- SuiteCoreComponentId,
323
- SuiteCoreStringKey.Common_Stopped,
324
- )} ] ${engine.translate(
325
- SuiteCoreComponentId,
326
- SuiteCoreStringKey.Common_ApplicationAndDatabase,
327
- )}`,
328
- );
329
- }
330
- }
@@ -1,348 +0,0 @@
1
- /**
2
- * @fileoverview Backup code implementation with v1.0.0 encryption scheme.
3
- * Provides secure backup code generation, encryption, validation using Argon2id and HKDF-SHA256.
4
- * @module backup-code
5
- */
6
-
7
- import { MemberType } from '@digitaldefiance/ecies-lib';
8
- import {
9
- Constants as ApiConstants,
10
- Member as BackendMember,
11
- PlatformID,
12
- } from '@digitaldefiance/node-ecies-lib';
13
- import {
14
- BackupCodeString,
15
- IBackupCode,
16
- InvalidBackupCodeError,
17
- PrivateKeyRequiredError,
18
- SuiteCoreStringKey,
19
- TranslatableSuiteError,
20
- } from '@digitaldefiance/suite-core-lib';
21
- import * as argon2 from 'argon2';
22
- import { createHmac, randomBytes, timingSafeEqual } from 'crypto';
23
- import { LocalhostConstants } from './constants';
24
- import { InvalidBackupCodeVersionError } from './errors/invalid-backup-code-version';
25
- import { IConstants } from './interfaces';
26
- import { SymmetricService } from './services/symmetric';
27
-
28
- /**
29
- * Class representing a backup code string with associated operations.
30
- *
31
- * v1 scheme:
32
- * - Code: 32 lowercase alphanumerics (a–z0–9), displayed as 8 groups of 4: xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx
33
- * - Checksum/tag: HKDF-SHA256(codeUtf8, salt, "backup-checksum") → 32 bytes (stored as hex)
34
- * - KDF for encryption key: Argon2id(codeUtf8, salt) → 32 bytes
35
- * - Encryption: SymmetricService AEAD (encryptedData must embed IV + authTag + ciphertext)
36
- * - Wrapping: AEAD blob wrapped with system user's asymmetric key (ECIES)
37
- */
38
- export class BackupCode extends BackupCodeString {
39
- /** Current backup code scheme version implemented by this service. */
40
- public static readonly BackupCodeVersion = '1.0.0';
41
- // Centralized Argon2id parameters (tunable)
42
- private static readonly Argon2Params = {
43
- type: argon2.argon2id,
44
- hashLength: 32, // derive AES-256 key
45
- timeCost: 3,
46
- memoryCost: 65536, // 64 MiB
47
- parallelism: 1,
48
- raw: true as const,
49
- } as const;
50
-
51
- constructor(code: string) {
52
- super(code);
53
- }
54
-
55
- /**
56
- * Generate the configured number of backup codes.
57
- * Note: If generation alphabet/length is controlled elsewhere, prefer that path.
58
- */
59
- public static override generateBackupCodes(
60
- constants: IConstants = LocalhostConstants,
61
- ): Array<BackupCode> {
62
- const codes: Array<BackupCode> = [];
63
- for (let i = 0; i < constants.BACKUP_CODES.Count; i++) {
64
- codes.push(new BackupCode(BackupCode.generateBackupCode()));
65
- }
66
- return codes;
67
- }
68
-
69
- /**
70
- * HKDF-Extract-and-Expand using HMAC-SHA-256.
71
- *
72
- * PRK = HMAC(salt, ikm)
73
- * T(0) = empty
74
- * T(i) = HMAC(PRK, T(i-1) || info || i)
75
- * OKM = first 'length' bytes of T(1) || T(2) || ...
76
- */
77
- public static hkdfSha256(
78
- ikm: Buffer,
79
- salt: Buffer,
80
- info: Buffer,
81
- length: number,
82
- ): Buffer {
83
- if (length === 0) {
84
- return Buffer.alloc(0);
85
- }
86
-
87
- // HKDF-Extract: PRK = HMAC-Hash(salt, IKM)
88
- // If salt is empty, use a string of HashLen zeros
89
- const actualSalt = salt.length === 0 ? Buffer.alloc(32, 0) : salt;
90
- const prk = createHmac('sha256', actualSalt).update(ikm).digest();
91
-
92
- // HKDF-Expand
93
- const blocks: Buffer[] = [];
94
- let prev = Buffer.alloc(0);
95
- const n = Math.ceil(length / 32);
96
-
97
- for (let i = 1; i <= n; i++) {
98
- const hmac = createHmac('sha256', prk);
99
- hmac.update(prev);
100
- hmac.update(info);
101
- hmac.update(Buffer.from([i]));
102
- prev = Buffer.from(hmac.digest());
103
- blocks.push(prev);
104
- }
105
-
106
- return Buffer.concat(blocks).subarray(0, length);
107
- }
108
-
109
- /**
110
- * v1: Derive a 32-byte encryption key from a normalized backup code using Argon2id and the per-code salt.
111
- * Uses UTF-8 bytes of the normalized code (not hex).
112
- */
113
- public static async getBackupKeyV1(
114
- checksumSaltHex: string,
115
- normalizedCode: string,
116
- constants: IConstants = LocalhostConstants,
117
- ): Promise<Buffer> {
118
- if (!constants.BACKUP_CODES.NormalizedHexRegex.test(normalizedCode)) {
119
- throw new InvalidBackupCodeError();
120
- }
121
- const codeBytes = Buffer.from(normalizedCode, 'utf8');
122
- const checksumSalt = Buffer.from(checksumSaltHex, 'hex');
123
- try {
124
- const key = (await argon2.hash(codeBytes, {
125
- ...BackupCode.Argon2Params,
126
- salt: checksumSalt,
127
- })) as Buffer;
128
- return key; // 32-byte Buffer
129
- } finally {
130
- codeBytes.fill(0);
131
- }
132
- }
133
-
134
- /**
135
- * v1: Compute a 32-byte checksum/tag for a normalized code using HKDF-SHA256(codeUtf8, salt, "backup-checksum").
136
- */
137
- private static computeChecksumV1(
138
- normalizedCode: string,
139
- checksumSalt: Buffer,
140
- ): Buffer {
141
- const codeBytes = Buffer.from(normalizedCode, 'utf8');
142
- try {
143
- return BackupCode.hkdfSha256(
144
- codeBytes,
145
- checksumSalt,
146
- Buffer.from('backup-checksum'),
147
- 32,
148
- );
149
- } finally {
150
- codeBytes.fill(0);
151
- }
152
- }
153
-
154
- public async encrypt<TID extends PlatformID = Buffer>(
155
- backupUser: BackendMember<TID>,
156
- systemUser: BackendMember<TID>,
157
- constants: IConstants = LocalhostConstants,
158
- ): Promise<IBackupCode> {
159
- if (!backupUser.hasPrivateKey) {
160
- throw new PrivateKeyRequiredError();
161
- }
162
- if (systemUser.type !== MemberType.System) {
163
- throw new TranslatableSuiteError(
164
- SuiteCoreStringKey.Error_SystemUserMustBeSystemMemberType,
165
- );
166
- }
167
- const raw = this.value ?? '';
168
- const normalized = BackupCode.normalizeCode(raw);
169
- if (
170
- !(
171
- constants.BACKUP_CODES.DisplayRegex.test(raw) ||
172
- constants.BACKUP_CODES.NormalizedHexRegex.test(normalized)
173
- )
174
- ) {
175
- throw new InvalidBackupCodeError();
176
- }
177
-
178
- const checksumSalt = randomBytes(ApiConstants.PBKDF2.SALT_BYTES);
179
- const checksumBuf = BackupCode.computeChecksumV1(normalized, checksumSalt);
180
- const encryptionKey = await BackupCode.getBackupKeyV1(
181
- checksumSalt.toString('hex'),
182
- normalized,
183
- constants,
184
- );
185
-
186
- try {
187
- const sealed = SymmetricService.encryptBuffer(
188
- Buffer.from(backupUser.privateKey!.value),
189
- encryptionKey,
190
- );
191
- const wrappedEncryptedPrivateKey = systemUser
192
- .encryptData(sealed.encryptedData)
193
- .toString('hex');
194
-
195
- return {
196
- version: BackupCode.BackupCodeVersion,
197
- checksumSalt: checksumSalt.toString('hex'),
198
- checksum: checksumBuf.toString('hex'),
199
- encrypted: wrappedEncryptedPrivateKey,
200
- } as IBackupCode;
201
- } finally {
202
- encryptionKey.fill(0);
203
- checksumBuf.fill(0);
204
- }
205
- }
206
-
207
- /**
208
- * v1: Encrypt and wrap backup codes for a user.
209
- * - Validates code format (display or normalized)
210
- * - Computes HKDF checksum/tag
211
- * - Derives Argon2id encryption key (32 bytes) from UTF-8 code
212
- * - Encrypts the private key with AEAD and wraps with system user
213
- */
214
- public static async encryptBackupCodesV1<TID extends PlatformID = Buffer>(
215
- backupUser: BackendMember<TID>,
216
- systemUser: BackendMember<TID>,
217
- codes: Array<BackupCode>,
218
- ): Promise<Array<IBackupCode>> {
219
- const encryptedCodes: Array<IBackupCode> = [];
220
- for (const code of codes) {
221
- encryptedCodes.push(await code.encrypt(backupUser, systemUser));
222
- }
223
- return encryptedCodes;
224
- }
225
-
226
- /** Delegate to current version. */
227
- public static encryptBackupCodes<TID extends PlatformID = Buffer>(
228
- backupUser: BackendMember<TID>,
229
- systemUser: BackendMember<TID>,
230
- codes: Array<BackupCode>,
231
- ): Promise<Array<IBackupCode>> {
232
- return BackupCode.encryptBackupCodesV1(backupUser, systemUser, codes);
233
- }
234
-
235
- /**
236
- * v1: Validate whether a backup code exists (unused) in the provided collection.
237
- * Uses constant-time comparison of binary checksums (codeUtf8 + salt).
238
- */
239
- public static validateBackupCodeV1(
240
- encryptedBackupCodes: Array<IBackupCode>,
241
- backupCode: string,
242
- constants: IConstants = LocalhostConstants,
243
- ): boolean {
244
- const normalizedCode = BackupCodeString.normalizeCode(backupCode);
245
- if (!constants.BACKUP_CODES.NormalizedHexRegex.test(normalizedCode)) {
246
- return false;
247
- }
248
- const codeBytes = Buffer.from(normalizedCode, 'utf8');
249
- try {
250
- for (const code of encryptedBackupCodes) {
251
- if (code.version !== BackupCode.BackupCodeVersion) continue;
252
- const checksumSalt = Buffer.from(code.checksumSalt, 'hex');
253
- const expected = BackupCode.hkdfSha256(
254
- codeBytes,
255
- checksumSalt,
256
- Buffer.from('backup-checksum'),
257
- 32,
258
- );
259
- if (
260
- code.checksum.length === expected.length * 2 &&
261
- timingSafeEqual(Buffer.from(code.checksum, 'hex'), expected)
262
- ) {
263
- return true;
264
- }
265
- }
266
- return false;
267
- } finally {
268
- codeBytes.fill(0);
269
- }
270
- }
271
-
272
- /**
273
- * Validate a backup code against any supported version present in the collection.
274
- */
275
- public static validateBackupCode(
276
- encryptedBackupCodes: Array<IBackupCode>,
277
- backupCode: string,
278
- constants: IConstants = LocalhostConstants,
279
- ): boolean {
280
- const normalizedCode = BackupCodeString.normalizeCode(backupCode);
281
- if (!constants.BACKUP_CODES.NormalizedHexRegex.test(normalizedCode)) {
282
- return false;
283
- }
284
- if (
285
- encryptedBackupCodes.some(
286
- (c) => c.version === BackupCode.BackupCodeVersion,
287
- )
288
- ) {
289
- return this.validateBackupCodeV1(
290
- encryptedBackupCodes.filter(
291
- (c) => c.version === BackupCode.BackupCodeVersion,
292
- ),
293
- normalizedCode,
294
- );
295
- }
296
- return false;
297
- }
298
-
299
- /**
300
- * Detect the version by matching checksum against stored codes; returns the matched version.
301
- */
302
- public static detectBackupCodeVersion(
303
- encryptedBackupCodes: Array<IBackupCode>,
304
- backupCode: string,
305
- constants: IConstants = LocalhostConstants,
306
- ): string {
307
- const normalizedCode = BackupCodeString.normalizeCode(backupCode);
308
- if (!constants.BACKUP_CODES.NormalizedHexRegex.test(normalizedCode)) {
309
- throw new InvalidBackupCodeError();
310
- }
311
-
312
- const v1Set = encryptedBackupCodes.filter(
313
- (c) => c.version === BackupCode.BackupCodeVersion,
314
- );
315
- if (v1Set.length) {
316
- const codeBytes = Buffer.from(normalizedCode, 'utf8');
317
- try {
318
- for (const c of v1Set) {
319
- const checksumSalt = Buffer.from(c.checksumSalt, 'hex');
320
- const expected = BackupCode.hkdfSha256(
321
- codeBytes,
322
- checksumSalt,
323
- Buffer.from('backup-checksum'),
324
- 32,
325
- );
326
- if (
327
- c.checksum.length === expected.length * 2 &&
328
- timingSafeEqual(Buffer.from(c.checksum, 'hex'), expected)
329
- ) {
330
- return c.version;
331
- }
332
- }
333
- } finally {
334
- // zeroize
335
- codeBytes.fill(0);
336
- }
337
- }
338
-
339
- const versionsInSet = new Set(encryptedBackupCodes.map((c) => c.version));
340
- if (
341
- versionsInSet.size > 0 &&
342
- !versionsInSet.has(BackupCode.BackupCodeVersion)
343
- ) {
344
- throw new InvalidBackupCodeVersionError([...versionsInSet][0]);
345
- }
346
- throw new InvalidBackupCodeError();
347
- }
348
- }