@digitaldefiance/node-express-suite 1.0.21 → 1.0.23

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 (633) hide show
  1. package/README.md +9 -0
  2. package/package.json +27 -32
  3. package/src/application-base.ts +492 -0
  4. package/src/application.ts +254 -0
  5. package/src/backup-code.ts +336 -0
  6. package/src/constants.ts +69 -0
  7. package/src/controllers/base.ts +440 -0
  8. package/{dist/controllers/index.d.ts → src/controllers/index.ts} +0 -1
  9. package/src/controllers/user.ts +1451 -0
  10. package/src/decorators/base-controller.ts +61 -0
  11. package/src/decorators/controller.ts +109 -0
  12. package/{dist/decorators/index.d.ts → src/decorators/index.ts} +0 -1
  13. package/src/decorators/zod-validation.ts +57 -0
  14. package/src/defaults.ts +94 -0
  15. package/src/documents/base.ts +7 -0
  16. package/src/documents/email-token.ts +14 -0
  17. package/{dist/documents/index.d.ts → src/documents/index.ts} +0 -1
  18. package/{dist/documents/mnemonic.d.ts → src/documents/mnemonic.ts} +5 -2
  19. package/{dist/documents/role.d.ts → src/documents/role.ts} +5 -2
  20. package/src/documents/used-direct-login-token.ts +7 -0
  21. package/{dist/documents/user-role.d.ts → src/documents/user-role.ts} +5 -2
  22. package/{dist/documents/user.d.ts → src/documents/user.ts} +4 -2
  23. package/src/enumerations/base-model-name.ts +41 -0
  24. package/{dist/enumerations/index.d.ts → src/enumerations/index.ts} +0 -1
  25. package/src/enumerations/length-encoding-type.ts +6 -0
  26. package/src/enumerations/schema-collection.ts +33 -0
  27. package/src/enumerations/symmetric-error-type.ts +4 -0
  28. package/src/environment.ts +770 -0
  29. package/src/errors/express-validation.ts +21 -0
  30. package/{dist/errors/index.d.ts → src/errors/index.ts} +0 -1
  31. package/src/errors/invalid-backup-code-version.ts +14 -0
  32. package/src/errors/invalid-jwt-token.ts +10 -0
  33. package/src/errors/invalid-model.ts +11 -0
  34. package/src/errors/invalid-new-password.ts +18 -0
  35. package/src/errors/invalid-password.ts +13 -0
  36. package/src/errors/missing-validated-data.ts +36 -0
  37. package/src/errors/mnemonic-or-password-required.ts +12 -0
  38. package/src/errors/model-not-registered.ts +11 -0
  39. package/src/errors/mongoose-validation.ts +34 -0
  40. package/src/errors/symmetric.ts +41 -0
  41. package/src/errors/token-expired.ts +10 -0
  42. package/src/get-language.ts +53 -0
  43. package/src/get-timezone.ts +45 -0
  44. package/{dist/index.d.ts → src/index.ts} +3 -2
  45. package/{dist/interfaces/api-error-response.d.ts → src/interfaces/api-error-response.ts} +2 -2
  46. package/src/interfaces/api-express-validation-error-response.ts +8 -0
  47. package/src/interfaces/api-message-response.ts +3 -0
  48. package/{dist/interfaces/api-mongo-validation-error-response.d.ts → src/interfaces/api-mongo-validation-error-response.ts} +2 -2
  49. package/{dist/interfaces/api-responses/backup-codes-response.d.ts → src/interfaces/api-responses/backup-codes-response.ts} +2 -2
  50. package/{dist/interfaces/api-responses/challenge-response.d.ts → src/interfaces/api-responses/challenge-response.ts} +3 -3
  51. package/{dist/interfaces/api-responses/code-count-response.d.ts → src/interfaces/api-responses/code-count-response.ts} +2 -2
  52. package/{dist/interfaces/api-responses/index.d.ts → src/interfaces/api-responses/index.ts} +0 -1
  53. package/{dist/interfaces/api-responses/login-response.d.ts → src/interfaces/api-responses/login-response.ts} +4 -4
  54. package/{dist/interfaces/api-responses/mnemonic-response.d.ts → src/interfaces/api-responses/mnemonic-response.ts} +2 -2
  55. package/{dist/interfaces/api-responses/registration-response.d.ts → src/interfaces/api-responses/registration-response.ts} +3 -3
  56. package/{dist/interfaces/api-responses/request-user-response.d.ts → src/interfaces/api-responses/request-user-response.ts} +2 -2
  57. package/{dist/interfaces/application.d.ts → src/interfaces/application.ts} +7 -7
  58. package/src/interfaces/backend-objects/email-token.ts +11 -0
  59. package/{dist/interfaces/backend-objects/index.d.ts → src/interfaces/backend-objects/index.ts} +0 -1
  60. package/{dist/interfaces/backend-objects/request-user.d.ts → src/interfaces/backend-objects/request-user.ts} +7 -2
  61. package/{dist/interfaces/backend-objects/role.d.ts → src/interfaces/backend-objects/role.ts} +1 -1
  62. package/src/interfaces/backend-objects/user.ts +9 -0
  63. package/src/interfaces/checksum-config.ts +4 -0
  64. package/src/interfaces/checksum-consts.ts +13 -0
  65. package/{dist/interfaces/constants.d.ts → src/interfaces/constants.ts} +5 -5
  66. package/src/interfaces/create-user-basics.ts +17 -0
  67. package/src/interfaces/csp-config.ts +35 -0
  68. package/src/interfaces/deep-partial.ts +3 -0
  69. package/{dist/interfaces/discriminator-collections.d.ts → src/interfaces/discriminator-collections.ts} +3 -3
  70. package/src/interfaces/email-service.ts +8 -0
  71. package/src/interfaces/environment-mongo.ts +76 -0
  72. package/src/interfaces/environment.ts +181 -0
  73. package/src/interfaces/failable-result.ts +6 -0
  74. package/src/interfaces/fec-consts.ts +4 -0
  75. package/src/interfaces/handleable-error-options.ts +6 -0
  76. package/{dist/interfaces/index.d.ts → src/interfaces/index.ts} +0 -1
  77. package/src/interfaces/jwt-consts.ts +23 -0
  78. package/src/interfaces/jwt-sign-response.ts +19 -0
  79. package/src/interfaces/mongo-errors.ts +5 -0
  80. package/src/interfaces/request-user.ts +50 -0
  81. package/src/interfaces/required-string-keys.ts +26 -0
  82. package/src/interfaces/schema.ts +31 -0
  83. package/src/interfaces/server-init-result.ts +37 -0
  84. package/src/interfaces/status-code-response.ts +7 -0
  85. package/src/interfaces/symmetric-encryption-results.d.ts +5 -0
  86. package/src/interfaces/symmetric-encryption-results.d.ts.map +1 -0
  87. package/src/interfaces/symmetric-encryption-results.js.map +1 -0
  88. package/src/interfaces/symmetric-encryption-results.ts +4 -0
  89. package/{dist/interfaces/token-response.d.ts → src/interfaces/token-response.ts} +2 -2
  90. package/src/middlewares/authenticate-crypto.ts +243 -0
  91. package/src/middlewares/authenticate-token.ts +152 -0
  92. package/src/middlewares/cleanup-crypto.ts +40 -0
  93. package/{dist/middlewares/index.d.ts → src/middlewares/index.ts} +0 -1
  94. package/src/middlewares/set-global-context-language.ts +24 -0
  95. package/src/middlewares.ts +120 -0
  96. package/src/model-registry.ts +75 -0
  97. package/src/models/email-token.ts +19 -0
  98. package/{dist/models/index.d.ts → src/models/index.ts} +0 -1
  99. package/src/models/mnemonic.ts +19 -0
  100. package/src/models/role.ts +19 -0
  101. package/src/models/used-direct-login-token.ts +23 -0
  102. package/src/models/user-role.ts +17 -0
  103. package/src/models/user.ts +19 -0
  104. package/src/registry/email-service-registry.ts +24 -0
  105. package/{dist/registry/index.d.ts → src/registry/index.ts} +0 -1
  106. package/src/routers/api.ts +151 -0
  107. package/src/routers/app.ts +258 -0
  108. package/src/routers/base.ts +17 -0
  109. package/{dist/routers/index.d.ts → src/routers/index.ts} +0 -1
  110. package/src/schemas/email-token.ts +91 -0
  111. package/{dist/schemas/index.d.ts → src/schemas/index.ts} +1 -2
  112. package/src/schemas/mnemonic.ts +37 -0
  113. package/src/schemas/role.ts +127 -0
  114. package/src/schemas/schema.ts +140 -0
  115. package/src/schemas/used-direct-login-token.ts +38 -0
  116. package/src/schemas/user-role.ts +75 -0
  117. package/src/schemas/user.ts +202 -0
  118. package/src/services/backup-code.ts +316 -0
  119. package/src/services/base.ts +33 -0
  120. package/src/services/checksum.ts +161 -0
  121. package/src/services/crc.ts +213 -0
  122. package/src/services/database-initialization.ts +1479 -0
  123. package/src/services/db-init-cache.d.ts +16 -0
  124. package/src/services/direct-login-token.ts +62 -0
  125. package/src/services/fec-usage-example.ts +102 -0
  126. package/src/services/fec.ts +296 -0
  127. package/{dist/services/index.d.ts → src/services/index.ts} +0 -1
  128. package/src/services/jwt.ts +134 -0
  129. package/src/services/key-wrapping.ts +434 -0
  130. package/src/services/mnemonic.ts +167 -0
  131. package/src/services/request-user.ts +62 -0
  132. package/src/services/role.ts +396 -0
  133. package/src/services/symmetric.ts +139 -0
  134. package/src/services/system-user.ts +82 -0
  135. package/src/services/user.ts +2137 -0
  136. package/src/services/xor.ts +34 -0
  137. package/src/types.d.ts +44 -0
  138. package/src/types.ts +128 -0
  139. package/src/utils.ts +1022 -0
  140. package/dist/application-base.d.ts +0 -112
  141. package/dist/application-base.d.ts.map +0 -1
  142. package/dist/application-base.js +0 -301
  143. package/dist/application-base.js.map +0 -1
  144. package/dist/application.d.ts +0 -23
  145. package/dist/application.d.ts.map +0 -1
  146. package/dist/application.js +0 -126
  147. package/dist/application.js.map +0 -1
  148. package/dist/backup-code.d.ts +0 -67
  149. package/dist/backup-code.d.ts.map +0 -1
  150. package/dist/backup-code.js +0 -270
  151. package/dist/backup-code.js.map +0 -1
  152. package/dist/constants.d.ts +0 -16
  153. package/dist/constants.d.ts.map +0 -1
  154. package/dist/constants.js +0 -54
  155. package/dist/constants.js.map +0 -1
  156. package/dist/controllers/base.d.ts +0 -63
  157. package/dist/controllers/base.d.ts.map +0 -1
  158. package/dist/controllers/base.js +0 -269
  159. package/dist/controllers/base.js.map +0 -1
  160. package/dist/controllers/index.d.ts.map +0 -1
  161. package/dist/controllers/index.js +0 -19
  162. package/dist/controllers/index.js.map +0 -1
  163. package/dist/controllers/user.d.ts +0 -45
  164. package/dist/controllers/user.d.ts.map +0 -1
  165. package/dist/controllers/user.js +0 -750
  166. package/dist/controllers/user.js.map +0 -1
  167. package/dist/decorators/base-controller.d.ts +0 -14
  168. package/dist/decorators/base-controller.d.ts.map +0 -1
  169. package/dist/decorators/base-controller.js +0 -49
  170. package/dist/decorators/base-controller.js.map +0 -1
  171. package/dist/decorators/controller.d.ts +0 -32
  172. package/dist/decorators/controller.d.ts.map +0 -1
  173. package/dist/decorators/controller.js +0 -67
  174. package/dist/decorators/controller.js.map +0 -1
  175. package/dist/decorators/index.d.ts.map +0 -1
  176. package/dist/decorators/index.js +0 -20
  177. package/dist/decorators/index.js.map +0 -1
  178. package/dist/decorators/zod-validation.d.ts +0 -5
  179. package/dist/decorators/zod-validation.d.ts.map +0 -1
  180. package/dist/decorators/zod-validation.js +0 -47
  181. package/dist/decorators/zod-validation.js.map +0 -1
  182. package/dist/defaults.d.ts +0 -7
  183. package/dist/defaults.d.ts.map +0 -1
  184. package/dist/defaults.js +0 -83
  185. package/dist/defaults.js.map +0 -1
  186. package/dist/documents/base.d.ts +0 -3
  187. package/dist/documents/base.d.ts.map +0 -1
  188. package/dist/documents/base.js +0 -3
  189. package/dist/documents/base.js.map +0 -1
  190. package/dist/documents/email-token.d.ts +0 -8
  191. package/dist/documents/email-token.d.ts.map +0 -1
  192. package/dist/documents/email-token.js +0 -3
  193. package/dist/documents/email-token.js.map +0 -1
  194. package/dist/documents/index.d.ts.map +0 -1
  195. package/dist/documents/index.js +0 -3
  196. package/dist/documents/index.js.map +0 -1
  197. package/dist/documents/mnemonic.d.ts.map +0 -1
  198. package/dist/documents/mnemonic.js +0 -3
  199. package/dist/documents/mnemonic.js.map +0 -1
  200. package/dist/documents/role.d.ts.map +0 -1
  201. package/dist/documents/role.js +0 -3
  202. package/dist/documents/role.js.map +0 -1
  203. package/dist/documents/used-direct-login-token.d.ts +0 -5
  204. package/dist/documents/used-direct-login-token.d.ts.map +0 -1
  205. package/dist/documents/used-direct-login-token.js +0 -3
  206. package/dist/documents/used-direct-login-token.js.map +0 -1
  207. package/dist/documents/user-role.d.ts.map +0 -1
  208. package/dist/documents/user-role.js +0 -3
  209. package/dist/documents/user-role.js.map +0 -1
  210. package/dist/documents/user.d.ts.map +0 -1
  211. package/dist/documents/user.js +0 -3
  212. package/dist/documents/user.js.map +0 -1
  213. package/dist/enumerations/base-model-name.d.ts +0 -38
  214. package/dist/enumerations/base-model-name.d.ts.map +0 -1
  215. package/dist/enumerations/base-model-name.js +0 -34
  216. package/dist/enumerations/base-model-name.js.map +0 -1
  217. package/dist/enumerations/index.d.ts.map +0 -1
  218. package/dist/enumerations/index.js +0 -21
  219. package/dist/enumerations/index.js.map +0 -1
  220. package/dist/enumerations/length-encoding-type.d.ts +0 -7
  221. package/dist/enumerations/length-encoding-type.d.ts.map +0 -1
  222. package/dist/enumerations/length-encoding-type.js +0 -11
  223. package/dist/enumerations/length-encoding-type.js.map +0 -1
  224. package/dist/enumerations/schema-collection.d.ts +0 -34
  225. package/dist/enumerations/schema-collection.d.ts.map +0 -1
  226. package/dist/enumerations/schema-collection.js +0 -38
  227. package/dist/enumerations/schema-collection.js.map +0 -1
  228. package/dist/enumerations/symmetric-error-type.d.ts +0 -5
  229. package/dist/enumerations/symmetric-error-type.d.ts.map +0 -1
  230. package/dist/enumerations/symmetric-error-type.js +0 -9
  231. package/dist/enumerations/symmetric-error-type.js.map +0 -1
  232. package/dist/environment.d.ts +0 -189
  233. package/dist/environment.d.ts.map +0 -1
  234. package/dist/environment.js +0 -618
  235. package/dist/environment.js.map +0 -1
  236. package/dist/errors/express-validation.d.ts +0 -9
  237. package/dist/errors/express-validation.d.ts.map +0 -1
  238. package/dist/errors/express-validation.js +0 -17
  239. package/dist/errors/express-validation.js.map +0 -1
  240. package/dist/errors/index.d.ts.map +0 -1
  241. package/dist/errors/index.js +0 -29
  242. package/dist/errors/index.js.map +0 -1
  243. package/dist/errors/invalid-backup-code-version.d.ts +0 -6
  244. package/dist/errors/invalid-backup-code-version.d.ts.map +0 -1
  245. package/dist/errors/invalid-backup-code-version.js +0 -14
  246. package/dist/errors/invalid-backup-code-version.js.map +0 -1
  247. package/dist/errors/invalid-jwt-token.d.ts +0 -5
  248. package/dist/errors/invalid-jwt-token.d.ts.map +0 -1
  249. package/dist/errors/invalid-jwt-token.js +0 -11
  250. package/dist/errors/invalid-jwt-token.js.map +0 -1
  251. package/dist/errors/invalid-model.d.ts +0 -6
  252. package/dist/errors/invalid-model.d.ts.map +0 -1
  253. package/dist/errors/invalid-model.js +0 -13
  254. package/dist/errors/invalid-model.js.map +0 -1
  255. package/dist/errors/invalid-new-password.d.ts +0 -5
  256. package/dist/errors/invalid-new-password.d.ts.map +0 -1
  257. package/dist/errors/invalid-new-password.js +0 -14
  258. package/dist/errors/invalid-new-password.js.map +0 -1
  259. package/dist/errors/invalid-password.d.ts +0 -5
  260. package/dist/errors/invalid-password.d.ts.map +0 -1
  261. package/dist/errors/invalid-password.js +0 -14
  262. package/dist/errors/invalid-password.js.map +0 -1
  263. package/dist/errors/missing-validated-data.d.ts +0 -7
  264. package/dist/errors/missing-validated-data.d.ts.map +0 -1
  265. package/dist/errors/missing-validated-data.js +0 -34
  266. package/dist/errors/missing-validated-data.js.map +0 -1
  267. package/dist/errors/mnemonic-or-password-required.d.ts +0 -5
  268. package/dist/errors/mnemonic-or-password-required.d.ts.map +0 -1
  269. package/dist/errors/mnemonic-or-password-required.js +0 -13
  270. package/dist/errors/mnemonic-or-password-required.js.map +0 -1
  271. package/dist/errors/model-not-registered.d.ts +0 -5
  272. package/dist/errors/model-not-registered.d.ts.map +0 -1
  273. package/dist/errors/model-not-registered.js +0 -12
  274. package/dist/errors/model-not-registered.js.map +0 -1
  275. package/dist/errors/mongoose-validation.d.ts +0 -11
  276. package/dist/errors/mongoose-validation.d.ts.map +0 -1
  277. package/dist/errors/mongoose-validation.js +0 -16
  278. package/dist/errors/mongoose-validation.js.map +0 -1
  279. package/dist/errors/symmetric.d.ts +0 -8
  280. package/dist/errors/symmetric.d.ts.map +0 -1
  281. package/dist/errors/symmetric.js +0 -23
  282. package/dist/errors/symmetric.js.map +0 -1
  283. package/dist/errors/token-expired.d.ts +0 -5
  284. package/dist/errors/token-expired.d.ts.map +0 -1
  285. package/dist/errors/token-expired.js +0 -11
  286. package/dist/errors/token-expired.js.map +0 -1
  287. package/dist/get-language.d.ts +0 -2
  288. package/dist/get-language.d.ts.map +0 -1
  289. package/dist/get-language.js +0 -30
  290. package/dist/get-language.js.map +0 -1
  291. package/dist/get-timezone.d.ts +0 -3
  292. package/dist/get-timezone.d.ts.map +0 -1
  293. package/dist/get-timezone.js +0 -31
  294. package/dist/get-timezone.js.map +0 -1
  295. package/dist/index.d.ts.map +0 -1
  296. package/dist/index.js +0 -40
  297. package/dist/index.js.map +0 -1
  298. package/dist/interfaces/api-error-response.d.ts.map +0 -1
  299. package/dist/interfaces/api-error-response.js +0 -3
  300. package/dist/interfaces/api-error-response.js.map +0 -1
  301. package/dist/interfaces/api-express-validation-error-response.d.ts +0 -7
  302. package/dist/interfaces/api-express-validation-error-response.d.ts.map +0 -1
  303. package/dist/interfaces/api-express-validation-error-response.js +0 -3
  304. package/dist/interfaces/api-express-validation-error-response.js.map +0 -1
  305. package/dist/interfaces/api-message-response.d.ts +0 -4
  306. package/dist/interfaces/api-message-response.d.ts.map +0 -1
  307. package/dist/interfaces/api-message-response.js +0 -3
  308. package/dist/interfaces/api-message-response.js.map +0 -1
  309. package/dist/interfaces/api-mongo-validation-error-response.d.ts.map +0 -1
  310. package/dist/interfaces/api-mongo-validation-error-response.js +0 -3
  311. package/dist/interfaces/api-mongo-validation-error-response.js.map +0 -1
  312. package/dist/interfaces/api-responses/backup-codes-response.d.ts.map +0 -1
  313. package/dist/interfaces/api-responses/backup-codes-response.js +0 -3
  314. package/dist/interfaces/api-responses/backup-codes-response.js.map +0 -1
  315. package/dist/interfaces/api-responses/challenge-response.d.ts.map +0 -1
  316. package/dist/interfaces/api-responses/challenge-response.js +0 -3
  317. package/dist/interfaces/api-responses/challenge-response.js.map +0 -1
  318. package/dist/interfaces/api-responses/code-count-response.d.ts.map +0 -1
  319. package/dist/interfaces/api-responses/code-count-response.js +0 -3
  320. package/dist/interfaces/api-responses/code-count-response.js.map +0 -1
  321. package/dist/interfaces/api-responses/index.d.ts.map +0 -1
  322. package/dist/interfaces/api-responses/index.js +0 -24
  323. package/dist/interfaces/api-responses/index.js.map +0 -1
  324. package/dist/interfaces/api-responses/login-response.d.ts.map +0 -1
  325. package/dist/interfaces/api-responses/login-response.js +0 -3
  326. package/dist/interfaces/api-responses/login-response.js.map +0 -1
  327. package/dist/interfaces/api-responses/mnemonic-response.d.ts.map +0 -1
  328. package/dist/interfaces/api-responses/mnemonic-response.js +0 -3
  329. package/dist/interfaces/api-responses/mnemonic-response.js.map +0 -1
  330. package/dist/interfaces/api-responses/registration-response.d.ts.map +0 -1
  331. package/dist/interfaces/api-responses/registration-response.js +0 -3
  332. package/dist/interfaces/api-responses/registration-response.js.map +0 -1
  333. package/dist/interfaces/api-responses/request-user-response.d.ts.map +0 -1
  334. package/dist/interfaces/api-responses/request-user-response.js +0 -3
  335. package/dist/interfaces/api-responses/request-user-response.js.map +0 -1
  336. package/dist/interfaces/application.d.ts.map +0 -1
  337. package/dist/interfaces/application.js +0 -3
  338. package/dist/interfaces/application.js.map +0 -1
  339. package/dist/interfaces/backend-objects/email-token.d.ts +0 -4
  340. package/dist/interfaces/backend-objects/email-token.d.ts.map +0 -1
  341. package/dist/interfaces/backend-objects/email-token.js +0 -3
  342. package/dist/interfaces/backend-objects/email-token.js.map +0 -1
  343. package/dist/interfaces/backend-objects/index.d.ts.map +0 -1
  344. package/dist/interfaces/backend-objects/index.js +0 -21
  345. package/dist/interfaces/backend-objects/index.js.map +0 -1
  346. package/dist/interfaces/backend-objects/request-user.d.ts.map +0 -1
  347. package/dist/interfaces/backend-objects/request-user.js +0 -3
  348. package/dist/interfaces/backend-objects/request-user.js.map +0 -1
  349. package/dist/interfaces/backend-objects/role.d.ts.map +0 -1
  350. package/dist/interfaces/backend-objects/role.js +0 -3
  351. package/dist/interfaces/backend-objects/role.js.map +0 -1
  352. package/dist/interfaces/backend-objects/user.d.ts +0 -4
  353. package/dist/interfaces/backend-objects/user.d.ts.map +0 -1
  354. package/dist/interfaces/backend-objects/user.js +0 -3
  355. package/dist/interfaces/backend-objects/user.js.map +0 -1
  356. package/dist/interfaces/checksum-config.d.ts +0 -5
  357. package/dist/interfaces/checksum-config.d.ts.map +0 -1
  358. package/dist/interfaces/checksum-config.js +0 -3
  359. package/dist/interfaces/checksum-config.js.map +0 -1
  360. package/dist/interfaces/checksum-consts.d.ts +0 -11
  361. package/dist/interfaces/checksum-consts.d.ts.map +0 -1
  362. package/dist/interfaces/checksum-consts.js +0 -3
  363. package/dist/interfaces/checksum-consts.js.map +0 -1
  364. package/dist/interfaces/constants.d.ts.map +0 -1
  365. package/dist/interfaces/constants.js +0 -3
  366. package/dist/interfaces/constants.js.map +0 -1
  367. package/dist/interfaces/create-user-basics.d.ts +0 -18
  368. package/dist/interfaces/create-user-basics.d.ts.map +0 -1
  369. package/dist/interfaces/create-user-basics.js +0 -3
  370. package/dist/interfaces/create-user-basics.js.map +0 -1
  371. package/dist/interfaces/csp-config.d.ts +0 -14
  372. package/dist/interfaces/csp-config.d.ts.map +0 -1
  373. package/dist/interfaces/csp-config.js +0 -3
  374. package/dist/interfaces/csp-config.js.map +0 -1
  375. package/dist/interfaces/deep-partial.d.ts +0 -4
  376. package/dist/interfaces/deep-partial.d.ts.map +0 -1
  377. package/dist/interfaces/deep-partial.js +0 -3
  378. package/dist/interfaces/deep-partial.js.map +0 -1
  379. package/dist/interfaces/discriminator-collections.d.ts.map +0 -1
  380. package/dist/interfaces/discriminator-collections.js +0 -3
  381. package/dist/interfaces/discriminator-collections.js.map +0 -1
  382. package/dist/interfaces/email-service.d.ts +0 -4
  383. package/dist/interfaces/email-service.d.ts.map +0 -1
  384. package/dist/interfaces/email-service.js +0 -3
  385. package/dist/interfaces/email-service.js.map +0 -1
  386. package/dist/interfaces/environment-mongo.d.ts +0 -76
  387. package/dist/interfaces/environment-mongo.d.ts.map +0 -1
  388. package/dist/interfaces/environment-mongo.js +0 -3
  389. package/dist/interfaces/environment-mongo.js.map +0 -1
  390. package/dist/interfaces/environment.d.ts +0 -181
  391. package/dist/interfaces/environment.d.ts.map +0 -1
  392. package/dist/interfaces/environment.js +0 -3
  393. package/dist/interfaces/environment.js.map +0 -1
  394. package/dist/interfaces/failable-result.d.ts +0 -7
  395. package/dist/interfaces/failable-result.d.ts.map +0 -1
  396. package/dist/interfaces/failable-result.js +0 -3
  397. package/dist/interfaces/failable-result.js.map +0 -1
  398. package/dist/interfaces/fec-consts.d.ts +0 -5
  399. package/dist/interfaces/fec-consts.d.ts.map +0 -1
  400. package/dist/interfaces/fec-consts.js +0 -3
  401. package/dist/interfaces/fec-consts.js.map +0 -1
  402. package/dist/interfaces/handleable-error-options.d.ts +0 -7
  403. package/dist/interfaces/handleable-error-options.d.ts.map +0 -1
  404. package/dist/interfaces/handleable-error-options.js +0 -3
  405. package/dist/interfaces/handleable-error-options.js.map +0 -1
  406. package/dist/interfaces/index.d.ts.map +0 -1
  407. package/dist/interfaces/index.js +0 -46
  408. package/dist/interfaces/index.js.map +0 -1
  409. package/dist/interfaces/jwt-consts.d.ts +0 -11
  410. package/dist/interfaces/jwt-consts.d.ts.map +0 -1
  411. package/dist/interfaces/jwt-consts.js +0 -3
  412. package/dist/interfaces/jwt-consts.js.map +0 -1
  413. package/dist/interfaces/jwt-sign-response.d.ts +0 -11
  414. package/dist/interfaces/jwt-sign-response.d.ts.map +0 -1
  415. package/dist/interfaces/jwt-sign-response.js +0 -3
  416. package/dist/interfaces/jwt-sign-response.js.map +0 -1
  417. package/dist/interfaces/mongo-errors.d.ts +0 -5
  418. package/dist/interfaces/mongo-errors.d.ts.map +0 -1
  419. package/dist/interfaces/mongo-errors.js +0 -3
  420. package/dist/interfaces/mongo-errors.js.map +0 -1
  421. package/dist/interfaces/request-user.d.ts +0 -42
  422. package/dist/interfaces/request-user.d.ts.map +0 -1
  423. package/dist/interfaces/request-user.js +0 -3
  424. package/dist/interfaces/request-user.js.map +0 -1
  425. package/dist/interfaces/required-string-keys.d.ts +0 -22
  426. package/dist/interfaces/required-string-keys.d.ts.map +0 -1
  427. package/dist/interfaces/required-string-keys.js +0 -3
  428. package/dist/interfaces/required-string-keys.js.map +0 -1
  429. package/dist/interfaces/schema.d.ts +0 -29
  430. package/dist/interfaces/schema.d.ts.map +0 -1
  431. package/dist/interfaces/schema.js +0 -3
  432. package/dist/interfaces/schema.js.map +0 -1
  433. package/dist/interfaces/server-init-result.d.ts +0 -35
  434. package/dist/interfaces/server-init-result.d.ts.map +0 -1
  435. package/dist/interfaces/server-init-result.js +0 -3
  436. package/dist/interfaces/server-init-result.js.map +0 -1
  437. package/dist/interfaces/status-code-response.d.ts +0 -7
  438. package/dist/interfaces/status-code-response.d.ts.map +0 -1
  439. package/dist/interfaces/status-code-response.js +0 -3
  440. package/dist/interfaces/status-code-response.js.map +0 -1
  441. package/dist/interfaces/symmetric-encryption-results.d.ts +0 -5
  442. package/dist/interfaces/symmetric-encryption-results.d.ts.map +0 -1
  443. package/dist/interfaces/symmetric-encryption-results.js.map +0 -1
  444. package/dist/interfaces/token-response.d.ts.map +0 -1
  445. package/dist/interfaces/token-response.js +0 -3
  446. package/dist/interfaces/token-response.js.map +0 -1
  447. package/dist/middlewares/authenticate-crypto.d.ts +0 -13
  448. package/dist/middlewares/authenticate-crypto.d.ts.map +0 -1
  449. package/dist/middlewares/authenticate-crypto.js +0 -146
  450. package/dist/middlewares/authenticate-crypto.js.map +0 -1
  451. package/dist/middlewares/authenticate-token.d.ts +0 -24
  452. package/dist/middlewares/authenticate-token.d.ts.map +0 -1
  453. package/dist/middlewares/authenticate-token.js +0 -102
  454. package/dist/middlewares/authenticate-token.js.map +0 -1
  455. package/dist/middlewares/cleanup-crypto.d.ts +0 -7
  456. package/dist/middlewares/cleanup-crypto.d.ts.map +0 -1
  457. package/dist/middlewares/cleanup-crypto.js +0 -32
  458. package/dist/middlewares/cleanup-crypto.js.map +0 -1
  459. package/dist/middlewares/index.d.ts.map +0 -1
  460. package/dist/middlewares/index.js +0 -21
  461. package/dist/middlewares/index.js.map +0 -1
  462. package/dist/middlewares/set-global-context-language.d.ts +0 -3
  463. package/dist/middlewares/set-global-context-language.d.ts.map +0 -1
  464. package/dist/middlewares/set-global-context-language.js +0 -14
  465. package/dist/middlewares/set-global-context-language.js.map +0 -1
  466. package/dist/middlewares.d.ts +0 -18
  467. package/dist/middlewares.d.ts.map +0 -1
  468. package/dist/middlewares.js +0 -76
  469. package/dist/middlewares.js.map +0 -1
  470. package/dist/model-registry.d.ts +0 -23
  471. package/dist/model-registry.d.ts.map +0 -1
  472. package/dist/model-registry.js +0 -47
  473. package/dist/model-registry.js.map +0 -1
  474. package/dist/models/email-token.d.ts +0 -11
  475. package/dist/models/email-token.d.ts.map +0 -1
  476. package/dist/models/email-token.js +0 -11
  477. package/dist/models/email-token.js.map +0 -1
  478. package/dist/models/index.d.ts.map +0 -1
  479. package/dist/models/index.js +0 -23
  480. package/dist/models/index.js.map +0 -1
  481. package/dist/models/mnemonic.d.ts +0 -11
  482. package/dist/models/mnemonic.d.ts.map +0 -1
  483. package/dist/models/mnemonic.js +0 -11
  484. package/dist/models/mnemonic.js.map +0 -1
  485. package/dist/models/role.d.ts +0 -11
  486. package/dist/models/role.d.ts.map +0 -1
  487. package/dist/models/role.js +0 -11
  488. package/dist/models/role.js.map +0 -1
  489. package/dist/models/used-direct-login-token.d.ts +0 -11
  490. package/dist/models/used-direct-login-token.d.ts.map +0 -1
  491. package/dist/models/used-direct-login-token.js +0 -11
  492. package/dist/models/used-direct-login-token.js.map +0 -1
  493. package/dist/models/user-role.d.ts +0 -6
  494. package/dist/models/user-role.d.ts.map +0 -1
  495. package/dist/models/user-role.js +0 -10
  496. package/dist/models/user-role.js.map +0 -1
  497. package/dist/models/user.d.ts +0 -7
  498. package/dist/models/user.d.ts.map +0 -1
  499. package/dist/models/user.js +0 -11
  500. package/dist/models/user.js.map +0 -1
  501. package/dist/registry/email-service-registry.d.ts +0 -9
  502. package/dist/registry/email-service-registry.d.ts.map +0 -1
  503. package/dist/registry/email-service-registry.js +0 -17
  504. package/dist/registry/email-service-registry.js.map +0 -1
  505. package/dist/registry/index.d.ts.map +0 -1
  506. package/dist/registry/index.js +0 -6
  507. package/dist/registry/index.js.map +0 -1
  508. package/dist/routers/api.d.ts +0 -27
  509. package/dist/routers/api.d.ts.map +0 -1
  510. package/dist/routers/api.js +0 -44
  511. package/dist/routers/api.js.map +0 -1
  512. package/dist/routers/app.d.ts +0 -28
  513. package/dist/routers/app.d.ts.map +0 -1
  514. package/dist/routers/app.js +0 -182
  515. package/dist/routers/app.js.map +0 -1
  516. package/dist/routers/base.d.ts +0 -12
  517. package/dist/routers/base.d.ts.map +0 -1
  518. package/dist/routers/base.js +0 -12
  519. package/dist/routers/base.js.map +0 -1
  520. package/dist/routers/index.d.ts.map +0 -1
  521. package/dist/routers/index.js +0 -20
  522. package/dist/routers/index.js.map +0 -1
  523. package/dist/schemas/email-token.d.ts +0 -38
  524. package/dist/schemas/email-token.d.ts.map +0 -1
  525. package/dist/schemas/email-token.js +0 -56
  526. package/dist/schemas/email-token.js.map +0 -1
  527. package/dist/schemas/index.d.ts.map +0 -1
  528. package/dist/schemas/index.js +0 -24
  529. package/dist/schemas/index.js.map +0 -1
  530. package/dist/schemas/mnemonic.d.ts +0 -20
  531. package/dist/schemas/mnemonic.d.ts.map +0 -1
  532. package/dist/schemas/mnemonic.js +0 -30
  533. package/dist/schemas/mnemonic.js.map +0 -1
  534. package/dist/schemas/role.d.ts +0 -32
  535. package/dist/schemas/role.d.ts.map +0 -1
  536. package/dist/schemas/role.js +0 -86
  537. package/dist/schemas/role.js.map +0 -1
  538. package/dist/schemas/schema.d.ts +0 -40
  539. package/dist/schemas/schema.d.ts.map +0 -1
  540. package/dist/schemas/schema.js +0 -64
  541. package/dist/schemas/schema.js.map +0 -1
  542. package/dist/schemas/used-direct-login-token.d.ts +0 -27
  543. package/dist/schemas/used-direct-login-token.d.ts.map +0 -1
  544. package/dist/schemas/used-direct-login-token.js +0 -23
  545. package/dist/schemas/used-direct-login-token.js.map +0 -1
  546. package/dist/schemas/user-role.d.ts +0 -29
  547. package/dist/schemas/user-role.d.ts.map +0 -1
  548. package/dist/schemas/user-role.js +0 -54
  549. package/dist/schemas/user-role.js.map +0 -1
  550. package/dist/schemas/user.d.ts +0 -21
  551. package/dist/schemas/user.d.ts.map +0 -1
  552. package/dist/schemas/user.js +0 -178
  553. package/dist/schemas/user.js.map +0 -1
  554. package/dist/services/backup-code.d.ts +0 -78
  555. package/dist/services/backup-code.d.ts.map +0 -1
  556. package/dist/services/backup-code.js +0 -180
  557. package/dist/services/backup-code.js.map +0 -1
  558. package/dist/services/base.d.ts +0 -13
  559. package/dist/services/base.d.ts.map +0 -1
  560. package/dist/services/base.js +0 -14
  561. package/dist/services/base.js.map +0 -1
  562. package/dist/services/checksum.d.ts +0 -67
  563. package/dist/services/checksum.d.ts.map +0 -1
  564. package/dist/services/checksum.js +0 -175
  565. package/dist/services/checksum.js.map +0 -1
  566. package/dist/services/crc.d.ts +0 -87
  567. package/dist/services/crc.d.ts.map +0 -1
  568. package/dist/services/crc.js +0 -198
  569. package/dist/services/crc.js.map +0 -1
  570. package/dist/services/database-initialization.d.ts +0 -105
  571. package/dist/services/database-initialization.d.ts.map +0 -1
  572. package/dist/services/database-initialization.js +0 -779
  573. package/dist/services/database-initialization.js.map +0 -1
  574. package/dist/services/direct-login-token.d.ts +0 -9
  575. package/dist/services/direct-login-token.d.ts.map +0 -1
  576. package/dist/services/direct-login-token.js +0 -41
  577. package/dist/services/direct-login-token.js.map +0 -1
  578. package/dist/services/fec-usage-example.d.ts +0 -38
  579. package/dist/services/fec-usage-example.d.ts.map +0 -1
  580. package/dist/services/fec-usage-example.js +0 -77
  581. package/dist/services/fec-usage-example.js.map +0 -1
  582. package/dist/services/fec.d.ts +0 -46
  583. package/dist/services/fec.d.ts.map +0 -1
  584. package/dist/services/fec.js +0 -192
  585. package/dist/services/fec.js.map +0 -1
  586. package/dist/services/index.d.ts.map +0 -1
  587. package/dist/services/index.js +0 -35
  588. package/dist/services/index.js.map +0 -1
  589. package/dist/services/jwt.d.ts +0 -33
  590. package/dist/services/jwt.d.ts.map +0 -1
  591. package/dist/services/jwt.js +0 -90
  592. package/dist/services/jwt.js.map +0 -1
  593. package/dist/services/key-wrapping.d.ts +0 -60
  594. package/dist/services/key-wrapping.d.ts.map +0 -1
  595. package/dist/services/key-wrapping.js +0 -311
  596. package/dist/services/key-wrapping.js.map +0 -1
  597. package/dist/services/mnemonic.d.ts +0 -61
  598. package/dist/services/mnemonic.d.ts.map +0 -1
  599. package/dist/services/mnemonic.js +0 -112
  600. package/dist/services/mnemonic.js.map +0 -1
  601. package/dist/services/request-user.d.ts +0 -20
  602. package/dist/services/request-user.d.ts.map +0 -1
  603. package/dist/services/request-user.js +0 -50
  604. package/dist/services/request-user.js.map +0 -1
  605. package/dist/services/role.d.ts +0 -88
  606. package/dist/services/role.d.ts.map +0 -1
  607. package/dist/services/role.js +0 -263
  608. package/dist/services/role.js.map +0 -1
  609. package/dist/services/symmetric.d.ts +0 -42
  610. package/dist/services/symmetric.d.ts.map +0 -1
  611. package/dist/services/symmetric.js +0 -101
  612. package/dist/services/symmetric.js.map +0 -1
  613. package/dist/services/system-user.d.ts +0 -17
  614. package/dist/services/system-user.d.ts.map +0 -1
  615. package/dist/services/system-user.js +0 -46
  616. package/dist/services/system-user.js.map +0 -1
  617. package/dist/services/user.d.ts +0 -320
  618. package/dist/services/user.d.ts.map +0 -1
  619. package/dist/services/user.js +0 -1374
  620. package/dist/services/user.js.map +0 -1
  621. package/dist/services/xor.d.ts +0 -24
  622. package/dist/services/xor.d.ts.map +0 -1
  623. package/dist/services/xor.js +0 -37
  624. package/dist/services/xor.js.map +0 -1
  625. package/dist/types.d.ts +0 -70
  626. package/dist/types.d.ts.map +0 -1
  627. package/dist/types.js +0 -14
  628. package/dist/types.js.map +0 -1
  629. package/dist/utils.d.ts +0 -202
  630. package/dist/utils.d.ts.map +0 -1
  631. package/dist/utils.js +0 -786
  632. package/dist/utils.js.map +0 -1
  633. /package/{dist → src}/interfaces/symmetric-encryption-results.js +0 -0
@@ -0,0 +1,243 @@
1
+ import { IECIESConfig, SecureString } from '@digitaldefiance/ecies-lib';
2
+ import {
3
+ Member as BackendMember,
4
+ ECIESService,
5
+ } from '@digitaldefiance/node-ecies-lib';
6
+ import {
7
+ AccountStatus,
8
+ getSuiteCoreTranslation,
9
+ InvalidCredentialsError,
10
+ SuiteCoreStringKey,
11
+ } from '@digitaldefiance/suite-core-lib';
12
+ import { NextFunction, Request, Response } from 'express';
13
+ import { ClientSession, Types } from 'mongoose';
14
+ import { IUserDocument } from '../documents/user';
15
+ import { BaseModelName } from '../enumerations';
16
+ import { InvalidPasswordError } from '../errors';
17
+ import { IApplication } from '../interfaces/application';
18
+ import { emailServiceRegistry } from '../registry';
19
+ import { BackupCodeService } from '../services/backup-code';
20
+ import { KeyWrappingService } from '../services/key-wrapping';
21
+ import { RoleService } from '../services/role';
22
+ import { UserService } from '../services/user';
23
+ import { withTransaction } from '../utils';
24
+ import { IBaseDocument } from '../documents';
25
+ import { Environment } from '../environment';
26
+ import { IConstants } from '../interfaces';
27
+
28
+ /**
29
+ * Middleware to authenticate crypto operations requiring private key access
30
+ * Expects mnemonic or password in request body for fresh authentication
31
+ */
32
+ export async function authenticateCrypto<
33
+ TAccountStatus extends string = AccountStatus,
34
+ >(
35
+ application: IApplication<any, Types.ObjectId, IBaseDocument<any, Types.ObjectId>, Environment, IConstants>,
36
+ req: Request,
37
+ res: Response,
38
+ next: NextFunction,
39
+ activeStatusValue: TAccountStatus = AccountStatus.Active as TAccountStatus,
40
+ ): Promise<Response | void> {
41
+ if (!req.user) {
42
+ return res
43
+ .status(401)
44
+ .send(
45
+ // amazonq-ignore-next-line false positive, hardcoded string
46
+ getSuiteCoreTranslation(SuiteCoreStringKey.Validation_InvalidToken),
47
+ );
48
+ }
49
+
50
+ // Try validatedBody first (if validation has run), then fall back to raw body
51
+ // Note: This middleware runs BEFORE validation, so validatedBody may not exist yet
52
+ const validatedBody = (req as Request & { validatedBody?: unknown })
53
+ .validatedBody as Record<string, unknown> | undefined;
54
+ const rawBody = req.body as Record<string, unknown> | undefined;
55
+ const sourceBody = validatedBody ?? rawBody;
56
+
57
+ if (!sourceBody) {
58
+ return res.status(400).send({
59
+ // amazonq-ignore-next-line false positive, hardcoded string
60
+ message: getSuiteCoreTranslation(
61
+ SuiteCoreStringKey.Validation_MnemonicOrPasswordRequired,
62
+ ),
63
+ });
64
+ }
65
+
66
+ const mnemonic =
67
+ typeof sourceBody['mnemonic'] === 'string'
68
+ ? (sourceBody['mnemonic'] as string)
69
+ : undefined;
70
+ const password =
71
+ // amazonq-ignore-next-line false positive
72
+ typeof sourceBody['password'] === 'string'
73
+ ? (sourceBody['password'] as string)
74
+ : undefined;
75
+ if (!mnemonic && !password) {
76
+ return res.status(400).send({
77
+ // amazonq-ignore-next-line false positive, hardcoded string
78
+ message: getSuiteCoreTranslation(
79
+ SuiteCoreStringKey.Validation_MnemonicOrPasswordRequired,
80
+ ),
81
+ });
82
+ }
83
+ const UserModel = application.getModel<IUserDocument<string>>(
84
+ BaseModelName.User,
85
+ );
86
+ const config: IECIESConfig = {
87
+ curveName: application.constants.ECIES.CURVE_NAME,
88
+ primaryKeyDerivationPath:
89
+ application.constants.ECIES.PRIMARY_KEY_DERIVATION_PATH,
90
+ mnemonicStrength: application.constants.ECIES.MNEMONIC_STRENGTH,
91
+ symmetricAlgorithm:
92
+ application.constants.ECIES.SYMMETRIC_ALGORITHM_CONFIGURATION,
93
+ symmetricKeyBits: application.constants.ECIES.SYMMETRIC.KEY_BITS,
94
+ symmetricKeyMode: application.constants.ECIES.SYMMETRIC.MODE,
95
+ };
96
+ const keyWrappingService = new KeyWrappingService();
97
+
98
+ const roleService = new RoleService(application);
99
+ const userService = new UserService(
100
+ application,
101
+ roleService,
102
+ emailServiceRegistry.getService(),
103
+ keyWrappingService,
104
+ new BackupCodeService(
105
+ application,
106
+ new ECIESService(config),
107
+ keyWrappingService,
108
+ roleService,
109
+ ),
110
+ );
111
+
112
+ try {
113
+ return await withTransaction<Response | void>(
114
+ application.db.connection,
115
+ application.environment.mongo.useTransactions,
116
+ undefined,
117
+ async (sess: ClientSession | undefined) => {
118
+ const userDoc = await UserModel.findById(req.user!.id)
119
+ .session(sess ?? null)
120
+ .exec();
121
+
122
+ if (!userDoc || userDoc.accountStatus !== activeStatusValue) {
123
+ return (
124
+ res
125
+ .status(403)
126
+ .send(
127
+ // amazonq-ignore-next-line false positive, hardcoded string
128
+ getSuiteCoreTranslation(
129
+ SuiteCoreStringKey.Validation_UserNotFound,
130
+ ),
131
+ )
132
+ );
133
+ }
134
+
135
+ // Ensure we're only authenticating the currently logged-in user
136
+ if (userDoc._id.toString() !== req.user!.id) {
137
+ return (
138
+ res
139
+ .status(403)
140
+ .send(
141
+ // amazonq-ignore-next-line false positive, hardcoded string
142
+ getSuiteCoreTranslation(
143
+ SuiteCoreStringKey.Validation_InvalidCredentials,
144
+ ),
145
+ )
146
+ );
147
+ }
148
+
149
+ let loginResult: {
150
+ userDoc: IUserDocument;
151
+ userMember: BackendMember;
152
+ adminMember: BackendMember;
153
+ };
154
+
155
+ if (mnemonic) {
156
+ // Authenticate with mnemonic
157
+ const userMnemonic = new SecureString(mnemonic);
158
+ try {
159
+ loginResult = await userService.loginWithMnemonic(
160
+ userDoc.email,
161
+ userMnemonic,
162
+ sess,
163
+ );
164
+ } finally {
165
+ userMnemonic.dispose();
166
+ }
167
+ } else if (password) {
168
+ // Authenticate with password
169
+ loginResult = await userService.loginWithPassword(
170
+ userDoc.email,
171
+ password,
172
+ sess,
173
+ );
174
+ } else {
175
+ // Should not happen due to earlier guard; keeps TypeScript happy
176
+ return res.status(400).send({
177
+ // amazonq-ignore-next-line false positive, hardcoded string
178
+ message: getSuiteCoreTranslation(
179
+ SuiteCoreStringKey.Validation_MnemonicOrPasswordRequired,
180
+ ),
181
+ });
182
+ }
183
+
184
+ // Double-check authenticated user matches logged-in user
185
+ if (loginResult.userDoc._id.toString() !== req.user!.id) {
186
+ return (
187
+ res
188
+ .status(403)
189
+ .send(
190
+ // amazonq-ignore-next-line false positive, hardcoded string
191
+ getSuiteCoreTranslation(
192
+ SuiteCoreStringKey.Validation_InvalidCredentials,
193
+ ),
194
+ )
195
+ );
196
+ }
197
+
198
+ // Attach the fully authenticated member (with private key) to the request
199
+ req.eciesUser = loginResult.userMember;
200
+ // Do not attach the admin user to the request; it's a process-wide singleton
201
+ // and must not be disposed as part of request cleanup.
202
+
203
+ next();
204
+ return;
205
+ },
206
+ {
207
+ timeoutMs: application.environment.mongo.transactionTimeout,
208
+ },
209
+ );
210
+ } catch (err) {
211
+ if (
212
+ err instanceof InvalidCredentialsError ||
213
+ err instanceof InvalidPasswordError
214
+ ) {
215
+ // amazonq-ignore-next-line false positive
216
+ console.error(
217
+ 'Crypto authentication failed:',
218
+ `userId=${String(req.user?.id || 'unknown').replace(
219
+ /[\r\n]/g,
220
+ '',
221
+ )} hasPassword=${!!password} hasMnemonic=${!!mnemonic}`,
222
+ );
223
+ return res.status(401).send({
224
+ // amazonq-ignore-next-line false positive, hardcoded string
225
+ message: getSuiteCoreTranslation(
226
+ SuiteCoreStringKey.Validation_InvalidCredentials,
227
+ ),
228
+ });
229
+ }
230
+ const sanitizedErr =
231
+ err instanceof Error
232
+ ? err.message.replace(/[\r\n]/g, ' ')
233
+ : String(err).replace(/[\r\n]/g, ' ');
234
+ console.error('Unexpected error in authenticateCrypto:', sanitizedErr);
235
+ return res.status(500).send({
236
+ // amazonq-ignore-next-line false positive, hardcoded string
237
+ message: getSuiteCoreTranslation(
238
+ SuiteCoreStringKey.Common_UnexpectedError,
239
+ ),
240
+ error: err,
241
+ });
242
+ }
243
+ }
@@ -0,0 +1,152 @@
1
+ import { GlobalActiveContext, Timezone } from '@digitaldefiance/i18n-lib';
2
+ import {
3
+ AccountStatus,
4
+ getSuiteCoreTranslation,
5
+ ITokenRole,
6
+ ITokenUser,
7
+ SuiteCoreStringKey,
8
+ } from '@digitaldefiance/suite-core-lib';
9
+ import { NextFunction, Request, Response } from 'express';
10
+ import { IncomingHttpHeaders } from 'http';
11
+ import { ClientSession, Types } from 'mongoose';
12
+ import { IUserDocument } from '../documents/user';
13
+ import { BaseModelName } from '../enumerations/base-model-name';
14
+ import { TokenExpiredError } from '../errors/token-expired';
15
+ import { IApplication } from '../interfaces/application';
16
+ import { JwtService } from '../services/jwt';
17
+ import { RequestUserService } from '../services/request-user';
18
+ import { RoleService } from '../services/role';
19
+ import { withTransaction } from '../utils';
20
+ import { IBaseDocument } from '../documents';
21
+ import { Environment } from '../environment';
22
+ import { IConstants } from '../interfaces';
23
+
24
+ /**
25
+ * Find the auth token in the headers
26
+ * @param headers The headers
27
+ * @returns The auth token
28
+ */
29
+ export function findAuthToken(headers: IncomingHttpHeaders): string | null {
30
+ const authHeader = headers['Authorization'] || headers['authorization'];
31
+ if (authHeader && typeof authHeader === 'string') {
32
+ const parts = authHeader.split(' ');
33
+ if (parts.length === 2 && parts[0].toLowerCase() === 'bearer') {
34
+ return parts[1];
35
+ }
36
+ }
37
+ return null;
38
+ }
39
+
40
+ /**
41
+ * Middleware to authenticate a token
42
+ * @param application The application
43
+ * @param req The request
44
+ * @param res The response
45
+ * @param next The next function
46
+ * @returns The response
47
+ */
48
+ export async function authenticateToken<
49
+ I = Types.ObjectId,
50
+ D extends Date = Date,
51
+ TTokenRole extends ITokenRole<I, D> = ITokenRole<I, D>,
52
+ TTokenUser extends ITokenUser = ITokenUser,
53
+ TApplication extends IApplication<any, Types.ObjectId, IBaseDocument<any, Types.ObjectId>, Environment, IConstants> = IApplication<any, Types.ObjectId, IBaseDocument<any, Types.ObjectId>, Environment, IConstants>,
54
+ >(
55
+ application: TApplication,
56
+ req: Request,
57
+ res: Response,
58
+ next: NextFunction,
59
+ ): Promise<Response> {
60
+ const UserModel = application.getModel<IUserDocument>(BaseModelName.User);
61
+ const token = findAuthToken(req.headers);
62
+ if (token == null) {
63
+ return res
64
+ .status(401)
65
+ .send(
66
+ getSuiteCoreTranslation(SuiteCoreStringKey.Validation_InvalidToken),
67
+ );
68
+ }
69
+
70
+ try {
71
+ return await withTransaction<Response>(
72
+ application.db.connection,
73
+ application.environment.mongo.useTransactions,
74
+ undefined,
75
+ async (sess: ClientSession | undefined) => {
76
+ const jwtService = new JwtService<
77
+ I,
78
+ D,
79
+ TTokenRole,
80
+ TTokenUser,
81
+ TApplication
82
+ >(application);
83
+ const user: TTokenUser | null = await jwtService.verifyToken(token);
84
+ if (user === null) {
85
+ return (
86
+ res
87
+ .status(403)
88
+ .send(
89
+ // amazonq-ignore-next-line false positive, hardcoded string
90
+ getSuiteCoreTranslation(
91
+ SuiteCoreStringKey.Validation_UserNotFound,
92
+ ),
93
+ )
94
+ );
95
+ }
96
+ const userDoc = await UserModel.findById(user.userId, {
97
+ password: 0,
98
+ })
99
+ .session(sess ?? null)
100
+ .exec();
101
+ if (!userDoc || userDoc.accountStatus !== AccountStatus.Active) {
102
+ return (
103
+ res
104
+ .status(403)
105
+ .send(
106
+ // amazonq-ignore-next-line false positive, hardcoded string
107
+ getSuiteCoreTranslation(
108
+ SuiteCoreStringKey.Validation_UserNotFound,
109
+ ),
110
+ )
111
+ );
112
+ }
113
+ const roleService: RoleService = new RoleService(application);
114
+ const roles = await roleService.getUserRoles(userDoc._id, sess);
115
+ const tokenRoles = roleService.rolesToTokenRoles(roles);
116
+ req.user = RequestUserService.makeRequestUserDTO(userDoc, tokenRoles);
117
+ const context = GlobalActiveContext.getInstance();
118
+ context.userLanguage = userDoc.siteLanguage ?? context.userLanguage;
119
+ context.setLanguageContextSpace('user');
120
+ context.userTimezone = new Timezone(userDoc.timezone);
121
+ next();
122
+ return res;
123
+ },
124
+ {
125
+ timeoutMs: application.environment.mongo.transactionTimeout,
126
+ },
127
+ );
128
+ } catch (err) {
129
+ if (err instanceof TokenExpiredError) {
130
+ return res.status(401).send({
131
+ message: getSuiteCoreTranslation(
132
+ SuiteCoreStringKey.Validation_TokenExpired,
133
+ ),
134
+ error: err,
135
+ });
136
+ } else if (err instanceof Error && err.name === 'JsonWebTokenError') {
137
+ return res.status(400).send({
138
+ message: getSuiteCoreTranslation(
139
+ SuiteCoreStringKey.Validation_InvalidToken,
140
+ ),
141
+ error: err,
142
+ });
143
+ } else {
144
+ return res.status(500).send({
145
+ message: getSuiteCoreTranslation(
146
+ SuiteCoreStringKey.Common_UnexpectedError,
147
+ ),
148
+ error: err,
149
+ });
150
+ }
151
+ }
152
+ }
@@ -0,0 +1,40 @@
1
+ import { NextFunction, Request, Response } from 'express';
2
+
3
+ /**
4
+ * Middleware to clean up crypto resources after request completion
5
+ * Should be used after crypto operations to ensure private keys are disposed
6
+ */
7
+ export function cleanupCrypto(
8
+ req: Request,
9
+ res: Response,
10
+ next: NextFunction,
11
+ ): void {
12
+ // Store original end function
13
+ const originalEnd = res.end;
14
+
15
+ // Override end function to cleanup before response
16
+ const wrappedEnd = function (this: Response, ...args: unknown[]) {
17
+ // Cleanup eciesUser if it exists
18
+ if (req.eciesUser) {
19
+ try {
20
+ // Dispose of sensitive cryptographic material
21
+ req.eciesUser.dispose();
22
+ req.eciesUser = undefined;
23
+ } catch (error) {
24
+ console.error('Error cleaning up crypto resources:', error);
25
+ }
26
+ }
27
+ // Do not dispose system user here; it may be a process-wide singleton
28
+
29
+ // Call original end function
30
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
31
+ return (originalEnd as unknown as (...a: any[]) => Response).apply(
32
+ this,
33
+ args,
34
+ );
35
+ } as unknown as typeof res.end;
36
+
37
+ res.end = wrappedEnd;
38
+
39
+ next();
40
+ }
@@ -2,4 +2,3 @@ export * from './authenticate-crypto';
2
2
  export * from './authenticate-token';
3
3
  export * from './cleanup-crypto';
4
4
  export * from './set-global-context-language';
5
- //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,24 @@
1
+ // src/middlewares/injectMongooseContext.ts
2
+
3
+ import {
4
+ GlobalActiveContext,
5
+ LanguageRegistry,
6
+ } from '@digitaldefiance/i18n-lib';
7
+ import { NextFunction, Request, Response } from 'express';
8
+
9
+ export function setGlobalContextLanguageFromRequest(
10
+ req: Request,
11
+ res: Response,
12
+ next: NextFunction,
13
+ ) {
14
+ // Use fallback chain: accept-language -> user preference -> site default
15
+ const language = LanguageRegistry.getMatchingLanguageCode(
16
+ req.headers['accept-language'] as string,
17
+ req.user?.siteLanguage as string,
18
+ );
19
+
20
+ const context = GlobalActiveContext.getInstance();
21
+ context.setUserLanguage(language);
22
+ context.setLanguageContextSpace('user');
23
+ next();
24
+ }
@@ -0,0 +1,120 @@
1
+ import cors from 'cors';
2
+ import { randomBytes } from 'crypto';
3
+ import {
4
+ Application,
5
+ json,
6
+ NextFunction,
7
+ Request,
8
+ Response,
9
+ urlencoded,
10
+ } from 'express';
11
+ import helmet from 'helmet';
12
+ import { IncomingMessage, ServerResponse } from 'http';
13
+
14
+ const corsOptionsDelegate = (corsWhitelist: string[]) => {
15
+ return (
16
+ req: cors.CorsRequest,
17
+ callback: (
18
+ error: Error | null,
19
+ options: cors.CorsOptions | undefined,
20
+ ) => void,
21
+ ) => {
22
+ let corsOptions: cors.CorsOptions;
23
+ const origin = req.headers.origin;
24
+ if (
25
+ origin &&
26
+ corsWhitelist.find((w: string | RegExp) => {
27
+ if (w instanceof RegExp) {
28
+ return w.test(origin);
29
+ } else {
30
+ return w === origin;
31
+ }
32
+ })
33
+ ) {
34
+ corsOptions = { origin: true };
35
+ } else {
36
+ corsOptions = { origin: false };
37
+ }
38
+ callback(null, corsOptions);
39
+ };
40
+ };
41
+
42
+ export class Middlewares {
43
+ /**
44
+ * Initialize the middleware
45
+ * @param app - Express application
46
+ */
47
+ public static init(
48
+ app: Application,
49
+ corsWhitelist: string[],
50
+ csp: {
51
+ defaultSrc: (
52
+ | string
53
+ | ((req: IncomingMessage, res: ServerResponse) => string)
54
+ )[];
55
+ imgSrc: (
56
+ | string
57
+ | ((req: IncomingMessage, res: ServerResponse) => string)
58
+ )[];
59
+ connectSrc: (
60
+ | string
61
+ | ((req: IncomingMessage, res: ServerResponse) => string)
62
+ )[];
63
+ scriptSrc: (
64
+ | string
65
+ | ((req: IncomingMessage, res: ServerResponse) => string)
66
+ )[];
67
+ styleSrc: (
68
+ | string
69
+ | ((req: IncomingMessage, res: ServerResponse) => string)
70
+ )[];
71
+ fontSrc: (
72
+ | string
73
+ | ((req: IncomingMessage, res: ServerResponse) => string)
74
+ )[];
75
+ frameSrc: (
76
+ | string
77
+ | ((req: IncomingMessage, res: ServerResponse) => string)
78
+ )[];
79
+ },
80
+ ): void {
81
+ // Helmet helps you secure your Express apps by setting various HTTP headers
82
+ // CSP nonce
83
+ app.use((req: Request, res: Response, next: NextFunction) => {
84
+ res.locals['cspNonce'] = randomBytes(32).toString('hex');
85
+ next();
86
+ });
87
+ app.use(
88
+ helmet({
89
+ contentSecurityPolicy: {
90
+ directives: {
91
+ defaultSrc: ["'self'", ...csp.defaultSrc],
92
+ imgSrc: ["'self'", 'data:', 'blob:', ...csp.imgSrc],
93
+ connectSrc: ["'self'", ...csp.connectSrc],
94
+ scriptSrc: [
95
+ "'self'",
96
+ //"'unsafe-inline'",
97
+ "'strict-dynamic'",
98
+ (req: IncomingMessage, res: ServerResponse) =>
99
+ `'nonce-${(res as Response).locals['cspNonce']}'`,
100
+ ...csp.scriptSrc,
101
+ ],
102
+ styleSrc: [
103
+ "'self'",
104
+ // "'unsafe-inline'",
105
+ ...csp.styleSrc,
106
+ ],
107
+ fontSrc: ["'self'", ...csp.fontSrc],
108
+ frameSrc: ["'self'", ...csp.frameSrc],
109
+ },
110
+ },
111
+ }),
112
+ );
113
+ // Enable CORS
114
+ app.use(cors(corsOptionsDelegate(corsWhitelist)));
115
+ // Parse incoming requests with JSON payloads
116
+ app.use(json());
117
+ // Parse incoming requests with urlencoded payloads
118
+ app.use(urlencoded({ extended: true }));
119
+ }
120
+ }
@@ -0,0 +1,75 @@
1
+ import { Model, Document as MongooseDocument, Schema } from 'mongoose';
2
+ import { IBaseDocument } from './documents/base';
3
+ import { InvalidModelError } from './errors';
4
+
5
+ export type ModelRegistration<T, U extends IBaseDocument<T>> = {
6
+ modelName: string;
7
+ schema: Schema;
8
+ model: Model<U>;
9
+ collection: string;
10
+ discriminators?: unknown;
11
+ };
12
+
13
+ class ModelRegistry {
14
+ protected static _instance: ModelRegistry;
15
+ protected _models: Map<string, ModelRegistration<any, IBaseDocument<any>>> =
16
+ new Map();
17
+
18
+ private constructor() {}
19
+
20
+ public static get instance(): ModelRegistry {
21
+ if (!ModelRegistry._instance) {
22
+ ModelRegistry._instance = new ModelRegistry();
23
+ }
24
+ return ModelRegistry._instance;
25
+ }
26
+
27
+ public register<T, U extends IBaseDocument<T>>(
28
+ registration: ModelRegistration<T, U>,
29
+ ): void {
30
+ this._models.set(
31
+ registration.modelName,
32
+ registration as ModelRegistration<T, U>,
33
+ );
34
+ }
35
+
36
+ public get<T, U extends IBaseDocument<T>>(
37
+ modelName: string,
38
+ ): ModelRegistration<T, U> {
39
+ const result = this._models.get(modelName) as ModelRegistration<T, U>;
40
+ if (result === undefined) {
41
+ throw new InvalidModelError(modelName);
42
+ }
43
+ return result;
44
+ }
45
+
46
+ public getTypedModel<TDoc extends MongooseDocument>(
47
+ modelName: string,
48
+ ): Model<TDoc> {
49
+ const result = this._models.get(modelName);
50
+ if (result === undefined) {
51
+ throw new InvalidModelError(modelName);
52
+ }
53
+ return result.model as Model<TDoc>;
54
+ }
55
+
56
+ public getTypedSchema<TDoc extends MongooseDocument>(
57
+ modelName: string,
58
+ ): Schema<TDoc> {
59
+ const result = this._models.get(modelName);
60
+ if (result === undefined) {
61
+ throw new InvalidModelError(modelName);
62
+ }
63
+ return result.schema as Schema<TDoc>;
64
+ }
65
+
66
+ public has(modelName: string): boolean {
67
+ return this._models.has(modelName);
68
+ }
69
+
70
+ public list(): string[] {
71
+ return Array.from(this._models.keys());
72
+ }
73
+ }
74
+
75
+ export { ModelRegistry };
@@ -0,0 +1,19 @@
1
+ import { Connection, Schema } from 'mongoose';
2
+ import { IEmailTokenDocument } from '../documents/email-token';
3
+ import { BaseModelName } from '../enumerations';
4
+ import { SchemaCollection } from '../enumerations/schema-collection';
5
+ import { EmailTokenSchema } from '../schemas/email-token';
6
+
7
+ export function EmailTokenModel<
8
+ TModelName extends string = BaseModelName,
9
+ TCollection extends string = SchemaCollection,
10
+ >(
11
+ connection: Connection,
12
+ modelName: TModelName = BaseModelName.EmailToken as TModelName,
13
+ collection: TCollection = SchemaCollection.EmailToken as TCollection,
14
+ schema: Schema<IEmailTokenDocument> = EmailTokenSchema,
15
+ ) {
16
+ return connection.model<IEmailTokenDocument>(modelName, schema, collection);
17
+ }
18
+
19
+ export default EmailTokenModel;
@@ -4,4 +4,3 @@ export * from './role';
4
4
  export * from './used-direct-login-token';
5
5
  export * from './user';
6
6
  export * from './user-role';
7
- //# sourceMappingURL=index.d.ts.map