@digitaldefiance/node-express-suite 3.6.14 → 3.6.16

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