@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,1564 +0,0 @@
1
- import {
2
- ECIES,
3
- EmailString,
4
- IECIESConfig,
5
- MemberType,
6
- SecureBuffer,
7
- SecureString,
8
- } from '@digitaldefiance/ecies-lib';
9
- import {
10
- TranslatableGenericError,
11
- TranslatableHandleableGenericError,
12
- } from '@digitaldefiance/i18n-lib';
13
- import {
14
- Member as BackendMember,
15
- ECIESService,
16
- } from '@digitaldefiance/node-ecies-lib';
17
- import {
18
- AccountStatus,
19
- getSuiteCoreI18nEngine,
20
- IFailableResult,
21
- SuiteCoreComponentId,
22
- SuiteCoreStringKey,
23
- TranslatableSuiteError,
24
- TranslatableSuiteHandleableError,
25
- } from '@digitaldefiance/suite-core-lib';
26
- import { crc32 } from 'crc';
27
- import { createHash, randomBytes } from 'crypto';
28
- import { ObjectId as MongoObjectId } from 'mongodb';
29
- import { Connection, Types } from '@digitaldefiance/mongoose-types';
30
- import { BackupCode } from '../backup-code';
31
- import { IMnemonicDocument } from '../documents/mnemonic';
32
- import { IRoleDocument } from '../documents/role';
33
- import { IUserDocument } from '../documents/user';
34
- import { IUserRoleDocument } from '../documents/user-role';
35
- import { BaseModelName } from '../enumerations/base-model-name';
36
- import { Environment } from '../environment';
37
- import { IDBInitResult } from '../interfaces';
38
- import { IApplication } from '../interfaces/application';
39
- import { IServerInitResult } from '../interfaces/server-init-result';
40
- import { ModelRegistry } from '../model-registry';
41
- import { KeyWrappingService } from '../services/key-wrapping';
42
- import { convertObjectIdToGenericId } from '../types/id-converters';
43
- import { debugLog, directLog, withTransaction } from '../utils';
44
- import { BackupCodeService } from './backup-code';
45
- import { MnemonicService } from './mnemonic';
46
- import { RoleService } from './role';
47
- import { SystemUserService } from './system-user';
48
-
49
- export abstract class DatabaseInitializationService {
50
- // Static initialization state management
51
- protected static initializationPromises = new Map<
52
- string,
53
- Promise<IFailableResult<IServerInitResult>>
54
- >();
55
- protected static initializationLock = new Map<string, boolean>();
56
- protected static defaultI18nTFunc(
57
- str: string,
58
- variables?: Record<string, any>,
59
- language?: string,
60
- application?: IApplication,
61
- ): string {
62
- // All callers pass template strings with {{component.key}} syntax
63
- return getSuiteCoreI18nEngine(
64
- application ? { constants: application.constants } : undefined,
65
- ).t(str, variables, language);
66
- }
67
-
68
- /**
69
- * Get the mnemonic or generate a new one if not present
70
- * @param mnemonic The existing mnemonic or undefined
71
- * @param eciesService The ECIES service to generate a new mnemonic
72
- * @returns The existing or new mnemonic
73
- */
74
- public static mnemonicOrNew(
75
- mnemonic: SecureString | undefined,
76
- eciesService: ECIESService,
77
- ): SecureString {
78
- return mnemonic && mnemonic.hasValue
79
- ? mnemonic
80
- : eciesService.generateNewMnemonic();
81
- }
82
- /**
83
- * Generate a cache key for a user based on their details
84
- * @param username The username
85
- * @param email The email address
86
- * @param mnemonic The mnemonic
87
- * @param id The user ID
88
- * @returns The generated cache key
89
- */
90
- public static cacheKey<I extends Types.ObjectId | string = Types.ObjectId>(
91
- username: string,
92
- email: EmailString,
93
- mnemonic: SecureString,
94
- id: I,
95
- idToString: (id: I) => string = (id) => String(id),
96
- ): string {
97
- const combined = `${username}|${email.email}|${mnemonic.value}|${idToString(
98
- id,
99
- )}`;
100
- const buffer = Buffer.from(combined, 'utf-8');
101
- const crcHash = crc32(buffer);
102
- return crcHash.toString(16).padStart(8, '0');
103
- }
104
- /**
105
- * Get a cached BackendMember or create a new one if not cached
106
- * @param username The username
107
- * @param email The email address
108
- * @param mnemonic The mnemonic or undefined to generate a new one
109
- * @param memberType The type of member (Admin, Member, System)
110
- * @param eciesService The ECIES service to handle key generation
111
- * @param memberId Optional specific member ID to use
112
- * @param createdBy Optional ID of the user who created this member
113
- * @returns The cached or newly created BackendMember and the mnemonic used
114
- */
115
- public static cacheOrNew<I extends Types.ObjectId | string = Types.ObjectId>(
116
- username: string,
117
- email: EmailString,
118
- mnemonic: SecureString | undefined,
119
- memberType: MemberType,
120
- eciesService: ECIESService,
121
- memberId?: I,
122
- createdBy?: I,
123
- idGenerator?: () => I,
124
- idToString: (id: I) => string = (id) => String(id),
125
- ): {
126
- member: BackendMember<I>;
127
- mnemonic: SecureString;
128
- } {
129
- const m = this.mnemonicOrNew(mnemonic, eciesService);
130
-
131
- const newId: I = memberId
132
- ? memberId
133
- : idGenerator
134
- ? idGenerator()
135
- : convertObjectIdToGenericId<I>(new MongoObjectId());
136
- const key = DatabaseInitializationService.cacheKey(
137
- username,
138
- email,
139
- m,
140
- newId,
141
- idToString,
142
- );
143
- if (!global.__MEMBER_CACHE__) {
144
- global.__MEMBER_CACHE__ = new Map<
145
- string,
146
- {
147
- member: BackendMember<any>;
148
- mnemonic: SecureString;
149
- }
150
- >();
151
- }
152
- if (!global.__MEMBER_CACHE__.has(key)) {
153
- const { wallet } = eciesService.walletAndSeedFromMnemonic(m);
154
-
155
- // Get private key from wallet
156
- const privateKey = wallet.getPrivateKey();
157
- // Get public key with 0x04 prefix
158
- const publicKeyWithPrefix = Buffer.concat([
159
- Buffer.from([ECIES.PUBLIC_KEY_MAGIC]),
160
- wallet.getPublicKey(),
161
- ]) as Buffer;
162
-
163
- const user: BackendMember<I> = new BackendMember<I>(
164
- eciesService,
165
- memberType,
166
- username,
167
- email,
168
- publicKeyWithPrefix,
169
- new SecureBuffer(privateKey),
170
- wallet,
171
- newId,
172
- undefined,
173
- undefined,
174
- createdBy,
175
- );
176
- global.__MEMBER_CACHE__.set(key, { mnemonic: m, member: user });
177
- return { mnemonic: m, member: user };
178
- } else {
179
- return global.__MEMBER_CACHE__.get(key)!;
180
- }
181
- }
182
-
183
- /**
184
- * Generate a random password
185
- * @param length The length of the password
186
- * @returns The generated password
187
- */
188
- public static generatePassword(length: number): string {
189
- const specialCharacters = "!@#$%^&*()_+-=[]{};':|,.<>/?";
190
- const numbers = '0123456789';
191
- const letters = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
192
-
193
- // Get a random character from a string
194
- const getRandomChar = (chars: string): string => {
195
- // amazonq-ignore-next-line false positive
196
- const randomIndex = randomBytes(1)[0] % chars.length;
197
- return chars[randomIndex];
198
- };
199
-
200
- // Start with one of each required character type
201
- // amazonq-ignore-next-line false positive
202
- let password = '';
203
- password += getRandomChar(letters);
204
- password += getRandomChar(numbers);
205
- password += getRandomChar(specialCharacters);
206
-
207
- // Fill the rest with random characters from all types
208
- const allCharacters = specialCharacters + numbers + letters;
209
- for (let i = password.length; i < length; i++) {
210
- password += getRandomChar(allCharacters);
211
- }
212
-
213
- // Shuffle the password characters to avoid predictable pattern
214
- const chars = password.split('');
215
- for (let i = chars.length - 1; i > 0; i--) {
216
- // amazonq-ignore-next-line already fixed
217
- const j = randomBytes(1)[0] % (i + 1);
218
- [chars[i], chars[j]] = [chars[j], chars[i]];
219
- }
220
- return chars.join('');
221
- }
222
-
223
- /**
224
- * Drops the database
225
- * @param connection The database connection
226
- * @returns True if the database was dropped, false if not connected
227
- */
228
- public static async dropDatabase(connection: Connection): Promise<boolean> {
229
- if (!connection.db) return false;
230
- debugLog(
231
- true,
232
- 'warn',
233
- this.defaultI18nTFunc('{{SuiteCoreStringKey.Admin_DroppingDatabase}}'),
234
- );
235
- return connection.db.dropDatabase();
236
- }
237
-
238
- public static getInitOptions<
239
- I extends Types.ObjectId | string = Types.ObjectId,
240
- >(
241
- application: IApplication,
242
- ): {
243
- adminId?: I;
244
- adminMnemonic?: SecureString;
245
- adminPassword?: SecureString;
246
- adminRoleId?: I;
247
- adminUserRoleId?: I;
248
- adminBackupCodes?: BackupCode[];
249
- memberId?: I;
250
- memberMnemonic?: SecureString;
251
- memberPassword?: SecureString;
252
- memberRoleId?: I;
253
- memberUserRoleId?: I;
254
- memberBackupCodes?: BackupCode[];
255
- systemId?: I;
256
- systemMnemonic?: SecureString;
257
- systemPassword?: SecureString;
258
- systemRoleId?: I;
259
- systemUserRoleId?: I;
260
- systemBackupCodes?: BackupCode[];
261
- } {
262
- const env = application.environment as Environment<I>;
263
- return {
264
- adminId: env.adminId,
265
- adminMnemonic: env.adminMnemonic?.hasValue
266
- ? env.adminMnemonic
267
- : undefined,
268
- adminPassword: env.adminPassword?.hasValue
269
- ? env.adminPassword
270
- : undefined,
271
- adminRoleId: env.adminRoleId as I,
272
- adminUserRoleId: env.adminUserRoleId,
273
- adminBackupCodes: env.adminBackupCodes,
274
- memberId: env.memberId,
275
- memberMnemonic: env.memberMnemonic?.hasValue
276
- ? env.memberMnemonic
277
- : undefined,
278
- memberPassword: env.memberPassword?.hasValue
279
- ? env.memberPassword
280
- : undefined,
281
- memberRoleId: env.memberRoleId as I,
282
- memberUserRoleId: env.memberUserRoleId,
283
- memberBackupCodes: env.memberBackupCodes,
284
- systemId: env.systemId,
285
- systemMnemonic: env.systemMnemonic?.hasValue
286
- ? env.systemMnemonic
287
- : undefined,
288
- systemPassword: env.systemPassword?.hasValue
289
- ? env.systemPassword
290
- : undefined,
291
- systemRoleId: env.systemRoleId as I,
292
- systemUserRoleId: env.systemUserRoleId,
293
- systemBackupCodes: env.systemBackupCodes,
294
- };
295
- }
296
-
297
- public static serverInitResultHash<
298
- I extends Types.ObjectId | string = Types.ObjectId,
299
- >(
300
- serverInitResult: IServerInitResult<I>,
301
- idToString: (id: I) => string = (id) => String(id),
302
- ): string {
303
- const h = createHash('sha256');
304
- h.update(idToString(serverInitResult.adminUser._id as I));
305
- h.update(idToString(serverInitResult.adminRole._id as I));
306
- h.update(idToString(serverInitResult.adminUserRole._id as I));
307
- h.update(serverInitResult.adminUsername);
308
- h.update(serverInitResult.adminEmail);
309
- h.update(serverInitResult.adminMnemonic);
310
- h.update(serverInitResult.adminPassword);
311
- h.update(serverInitResult.adminUser.publicKey);
312
- serverInitResult.adminBackupCodes.map((bc) => h.update(bc));
313
- h.update(idToString(serverInitResult.memberUser._id as I));
314
- h.update(idToString(serverInitResult.memberRole._id as I));
315
- h.update(idToString(serverInitResult.memberUserRole._id as I));
316
- h.update(serverInitResult.memberUsername);
317
- h.update(serverInitResult.memberEmail);
318
- h.update(serverInitResult.memberMnemonic);
319
- h.update(serverInitResult.memberPassword);
320
- h.update(serverInitResult.memberUser.publicKey);
321
- serverInitResult.memberBackupCodes.map((bc) => h.update(bc));
322
- h.update(idToString(serverInitResult.systemUser._id as I));
323
- h.update(idToString(serverInitResult.systemRole._id as I));
324
- h.update(idToString(serverInitResult.systemUserRole._id as I));
325
- h.update(serverInitResult.systemUsername);
326
- h.update(serverInitResult.systemEmail);
327
- h.update(serverInitResult.systemMnemonic);
328
- h.update(serverInitResult.systemPassword);
329
- h.update(serverInitResult.systemUser.publicKey);
330
- serverInitResult.systemBackupCodes.map((bc) => h.update(bc));
331
- return h.digest('hex');
332
- }
333
-
334
- /**
335
- * Initialize the user database with default users and roles (with dependency injection)
336
- * @param application The application
337
- * @param keyWrappingService The key wrapping service
338
- * @param mnemonicService The mnemonic service
339
- * @param eciesService The ECIES service
340
- * @param roleService The role service
341
- * @param backupCodeService The backup code service
342
- * @returns The result of the initialization
343
- */
344
- public static async initUserDbWithServices<
345
- I extends Types.ObjectId | string = Types.ObjectId,
346
- >(
347
- application: IApplication,
348
- keyWrappingService: KeyWrappingService,
349
- mnemonicService: MnemonicService<I>,
350
- eciesService: ECIESService,
351
- roleService: RoleService<I>,
352
- backupCodeService: BackupCodeService<I>,
353
- idGenerator?: () => I,
354
- idToString: (id: I) => string = (id) =>
355
- application.constants.idProvider.idToString(id),
356
- ): Promise<IDBInitResult<IServerInitResult<I>>> {
357
- const engine = getSuiteCoreI18nEngine({ constants: application.constants });
358
- const isTestEnvironment = process.env['NODE_ENV'] === 'test';
359
- const options =
360
- DatabaseInitializationService.getInitOptions<I>(application);
361
- const effectiveIdGenerator: () => I = (idGenerator ??
362
- (() =>
363
- application.environment.idAdapter(
364
- application.constants.idProvider.generate(),
365
- ))) as () => I;
366
- const UserModel = ModelRegistry.instance.getTypedModel<
367
- IUserDocument<string, I>
368
- >(BaseModelName.User);
369
- const RoleModel = ModelRegistry.instance.getTypedModel<IRoleDocument<I>>(
370
- BaseModelName.Role,
371
- );
372
- const adminUserId: I = options.adminId ?? effectiveIdGenerator();
373
- const adminRoleId: I = options.adminRoleId ?? effectiveIdGenerator();
374
- const adminUserRoleId: I =
375
- options.adminUserRoleId ?? effectiveIdGenerator();
376
- const memberUserId: I = options.memberId ?? effectiveIdGenerator();
377
- const memberRoleId: I = options.memberRoleId ?? effectiveIdGenerator();
378
- const memberUserRoleId: I =
379
- options.memberUserRoleId ?? effectiveIdGenerator();
380
- const systemUserId: I = options.systemId ?? effectiveIdGenerator();
381
- const systemRoleId: I = options.systemRoleId ?? effectiveIdGenerator();
382
- const systemUserRoleId: I =
383
- options.systemUserRoleId ?? effectiveIdGenerator();
384
-
385
- // Check for existing users and roles with optimized queries
386
- // Use lean() for better performance on read-only operations
387
- const [existingUsers, existingRoles] = await Promise.all([
388
- UserModel.find({
389
- username: {
390
- $in: [
391
- application.constants.SystemUser,
392
- application.constants.AdministratorUser,
393
- application.constants.MemberUser,
394
- ],
395
- },
396
- }).lean(),
397
- RoleModel.find({
398
- name: {
399
- $in: [
400
- application.constants.AdministratorRole,
401
- application.constants.MemberRole,
402
- application.constants.SystemRole,
403
- ],
404
- },
405
- }).lean(),
406
- ]);
407
-
408
- if (existingUsers.length > 0 || existingRoles.length > 0) {
409
- // Database is already initialized, return the existing data
410
- const existingAdminUser = existingUsers.find(
411
- (u) => u.username === application.constants.AdministratorUser,
412
- );
413
- const existingMemberUser = existingUsers.find(
414
- (u) => u.username === application.constants.MemberUser,
415
- );
416
- const existingSystemUser = existingUsers.find(
417
- (u) => u.username === application.constants.SystemUser,
418
- );
419
-
420
- if (existingAdminUser && existingMemberUser && existingSystemUser) {
421
- const adminUserDoc = UserModel.hydrate(existingAdminUser);
422
- const memberUserDoc = UserModel.hydrate(existingMemberUser);
423
- const systemUserDoc = UserModel.hydrate(existingSystemUser);
424
-
425
- // Try to construct a minimal result from existing data
426
- // Note: This is a fallback case and some data may not be available
427
- const UserRoleModel = ModelRegistry.instance.getTypedModel<
428
- IUserRoleDocument<I>
429
- >(BaseModelName.UserRole);
430
- const [
431
- adminRole,
432
- memberRole,
433
- systemRole,
434
- adminUserRole,
435
- memberUserRole,
436
- systemUserRole,
437
- ] = await Promise.all([
438
- RoleModel.findOne({ name: application.constants.AdministratorRole }),
439
- RoleModel.findOne({ name: application.constants.MemberRole }),
440
- RoleModel.findOne({ name: application.constants.SystemRole }),
441
- UserRoleModel.findOne({ userId: adminUserDoc._id }),
442
- UserRoleModel.findOne({ userId: memberUserDoc._id }),
443
- UserRoleModel.findOne({ userId: systemUserDoc._id }),
444
- ]);
445
-
446
- // detailed case
447
- if (
448
- adminRole &&
449
- memberRole &&
450
- systemRole &&
451
- adminUserRole &&
452
- memberUserRole &&
453
- systemUserRole
454
- ) {
455
- return {
456
- alreadyInitialized: true,
457
- success: false,
458
- data: {
459
- adminRole,
460
- adminUserRole,
461
- adminUser: adminUserDoc,
462
- adminUsername: adminUserDoc.username,
463
- adminEmail: adminUserDoc.email,
464
- adminMnemonic: '', // Not available in fallback
465
- adminPassword: '', // Not available in fallback
466
- adminBackupCodes: [], // Not available in fallback
467
- adminMember: {} as BackendMember<I>, // Not available in fallback
468
- memberRole,
469
- memberUserRole,
470
- memberUser: memberUserDoc,
471
- memberUsername: memberUserDoc.username,
472
- memberEmail: memberUserDoc.email,
473
- memberMnemonic: '', // Not available in fallback
474
- memberPassword: '', // Not available in fallback
475
- memberBackupCodes: [], // Not available in fallback
476
- memberMember: {} as BackendMember<I>, // Not available in fallback
477
- systemRole,
478
- systemUserRole,
479
- systemUser: systemUserDoc,
480
- systemUsername: systemUserDoc.username,
481
- systemEmail: systemUserDoc.email,
482
- systemMnemonic: '', // Not available in fallback
483
- systemPassword: '', // Not available in fallback
484
- systemBackupCodes: [], // Not available in fallback
485
- systemMember: {} as BackendMember<I>, // Not available in fallback
486
- },
487
- message: engine.translate(
488
- SuiteCoreComponentId,
489
- SuiteCoreStringKey.Admin_DatabaseAlreadyInitialized,
490
- ),
491
- error: new Error(
492
- engine.translate(
493
- SuiteCoreComponentId,
494
- SuiteCoreStringKey.Admin_DatabaseAlreadyInitialized,
495
- ),
496
- ),
497
- };
498
- }
499
- }
500
-
501
- // basic case
502
- return {
503
- alreadyInitialized: true,
504
- success: false,
505
- message: engine.translate(
506
- SuiteCoreComponentId,
507
- SuiteCoreStringKey.Admin_DatabaseAlreadyInitialized,
508
- ),
509
- error: new Error(
510
- engine.translate(
511
- SuiteCoreComponentId,
512
- SuiteCoreStringKey.Admin_DatabaseAlreadyInitialized,
513
- ),
514
- ),
515
- };
516
- }
517
-
518
- debugLog(
519
- application.environment.detailedDebug,
520
- 'log',
521
- engine.translate(
522
- SuiteCoreComponentId,
523
- SuiteCoreStringKey.Admin_SettingUpUsersAndRoles,
524
- ),
525
- );
526
- const now = new Date();
527
-
528
- // Add a small random delay in test environments to reduce collision probability
529
- if (isTestEnvironment) {
530
- const delay = (randomBytes(1)[0] % 50) + 10; // 10-60ms random delay (reduced)
531
- await new Promise((resolve) => setTimeout(resolve, delay));
532
- }
533
-
534
- try {
535
- // Use test-optimized settings for better performance
536
- const transactionOptions = isTestEnvironment
537
- ? { timeoutMs: 15000, retryAttempts: 2 } // Reduced timeout and retries for tests
538
- : { timeoutMs: 120000 }; // Keep original production timeout
539
-
540
- const result = await withTransaction<{
541
- adminRole: IRoleDocument<I>;
542
- memberRole: IRoleDocument<I>;
543
- systemRole: IRoleDocument<I>;
544
- systemDoc: IUserDocument<string, I>;
545
- systemUserRoleDoc: IUserRoleDocument<I>;
546
- systemPassword: string;
547
- systemMnemonic: string;
548
- systemBackupCodes: BackupCode[];
549
- systemMember: BackendMember<I>;
550
- adminDoc: IUserDocument<string, I>;
551
- adminUserRoleDoc: IUserRoleDocument<I>;
552
- adminPassword: string;
553
- adminMnemonic: string;
554
- adminBackupCodes: BackupCode[];
555
- adminMember: BackendMember<I>;
556
- memberDoc: IUserDocument<string, I>;
557
- memberUserRoleDoc: IUserRoleDocument<I>;
558
- memberPassword: string;
559
- memberMnemonic: string;
560
- memberBackupCodes: BackupCode[];
561
- memberUser: BackendMember<I>;
562
- }>(
563
- application.db.connection,
564
- application.environment.mongo.useTransactions,
565
- undefined,
566
- async (sess) => {
567
- // Check if admin role already exists
568
- let adminRole = await RoleModel.findOne({
569
- name: application.constants.AdministratorRole,
570
- }).session(sess ?? null);
571
- if (!adminRole) {
572
- const adminRoleDocs = await RoleModel.create(
573
- [
574
- {
575
- _id: adminRoleId as I,
576
- name: application.constants.AdministratorRole,
577
- admin: true,
578
- member: true,
579
- system: false,
580
- child: false,
581
- createdAt: now,
582
- updatedAt: now,
583
- createdBy: systemUserId as I,
584
- updatedBy: systemUserId as I,
585
- },
586
- ],
587
- { session: sess },
588
- );
589
- if (adminRoleDocs.length !== 1) {
590
- throw new TranslatableSuiteError(
591
- SuiteCoreStringKey.Error_FailedToCreateRoleTemplate,
592
- {
593
- NAME: application.constants.AdministratorRole,
594
- },
595
- );
596
- }
597
- adminRole = adminRoleDocs[0];
598
- }
599
-
600
- // Check if member role already exists
601
- let memberRole = await RoleModel.findOne({
602
- name: application.constants.MemberRole,
603
- }).session(sess ?? null);
604
- if (!memberRole) {
605
- const memberRoleDocs = await RoleModel.create(
606
- [
607
- {
608
- _id: memberRoleId as I,
609
- name: application.constants.MemberRole,
610
- admin: false,
611
- member: true,
612
- child: false,
613
- system: false,
614
- createdAt: now,
615
- updatedAt: now,
616
- createdBy: systemUserId as I,
617
- updatedBy: systemUserId as I,
618
- },
619
- ],
620
- { session: sess },
621
- );
622
- if (memberRoleDocs.length !== 1) {
623
- throw new TranslatableSuiteError(
624
- SuiteCoreStringKey.Error_FailedToCreateRoleTemplate,
625
- {
626
- NAME: engine.translate(
627
- SuiteCoreComponentId,
628
- SuiteCoreStringKey.Common_Member,
629
- ),
630
- },
631
- );
632
- }
633
- memberRole = memberRoleDocs[0];
634
- }
635
-
636
- // Check if system role already exists
637
- let systemRole = await RoleModel.findOne({
638
- name: application.constants.SystemRole,
639
- }).session(sess ?? null);
640
- if (!systemRole) {
641
- const systemRoleDocs = await RoleModel.create(
642
- [
643
- {
644
- _id: systemRoleId as I,
645
- name: application.constants.SystemRole,
646
- admin: true,
647
- member: true,
648
- system: true,
649
- child: false,
650
- createdAt: now,
651
- updatedAt: now,
652
- createdBy: systemUserId as I,
653
- updatedBy: systemUserId as I,
654
- },
655
- ],
656
- { session: sess },
657
- );
658
- if (systemRoleDocs.length !== 1) {
659
- throw new TranslatableSuiteError(
660
- SuiteCoreStringKey.Error_FailedToCreateRoleTemplate,
661
- );
662
- }
663
- systemRole = systemRoleDocs[0];
664
- }
665
-
666
- const systemUser = DatabaseInitializationService.cacheOrNew<I>(
667
- application.constants.SystemUser,
668
- new EmailString(application.constants.SystemEmail),
669
- options.systemMnemonic!,
670
- MemberType.System,
671
- eciesService,
672
- systemUserId as I,
673
- systemUserId as I,
674
- effectiveIdGenerator,
675
- idToString,
676
- );
677
- backupCodeService.setSystemUser(systemUser.member);
678
- SystemUserService.setSystemUser(
679
- systemUser.member,
680
- application.constants,
681
- );
682
- // Encrypt mnemonic for recovery
683
- const systemEncryptedMnemonic = systemUser.member
684
- .encryptData(Buffer.from(systemUser.mnemonic.value ?? '', 'utf-8'))
685
- .toString('hex');
686
- const systemMnemonicDoc = await mnemonicService.addMnemonic(
687
- systemUser.mnemonic,
688
- sess,
689
- );
690
- if (!systemMnemonicDoc) {
691
- throw new Error(
692
- engine.translate(
693
- SuiteCoreComponentId,
694
- SuiteCoreStringKey.Error_FailedToStoreUserMnemonicTemplate,
695
- {
696
- NAME: engine.translate(
697
- SuiteCoreComponentId,
698
- SuiteCoreStringKey.Common_System,
699
- ),
700
- },
701
- ),
702
- );
703
- }
704
- const systemPasswordSecure = options.systemPassword
705
- ? options.systemPassword
706
- : new SecureString(this.generatePassword(16));
707
-
708
- const systemWrapped = keyWrappingService.wrapSecret(
709
- systemUser.member.privateKey!,
710
- systemPasswordSecure,
711
- application.constants,
712
- );
713
- const systemBackupCodes =
714
- options.systemBackupCodes ?? BackupCode.generateBackupCodes();
715
- const encryptedSystemBackupCodes =
716
- await BackupCode.encryptBackupCodes(
717
- systemUser.member,
718
- systemUser.member,
719
- systemBackupCodes,
720
- );
721
- const systemDocs = await UserModel.create(
722
- [
723
- {
724
- _id: systemUserId as I,
725
- username: application.constants.SystemUser,
726
- email: application.constants.SystemEmail,
727
- publicKey: systemUser.member.publicKey.toString('hex'),
728
- duressPasswords: [],
729
- mnemonicRecovery: systemEncryptedMnemonic,
730
- mnemonicId: systemMnemonicDoc._id,
731
- passwordWrappedPrivateKey: systemWrapped,
732
- backupCodes: encryptedSystemBackupCodes,
733
- timezone: application.environment.timezone,
734
- siteLanguage: 'en-US',
735
- emailVerified: true,
736
- darkMode: false,
737
- accountStatus: AccountStatus.Active,
738
- directChallenge: true, // allow direct challenge login by default
739
- createdAt: now,
740
- updatedAt: now,
741
- createdBy: systemUserId as I,
742
- updatedBy: systemUserId as I,
743
- },
744
- ],
745
- { session: sess },
746
- );
747
- if (systemDocs.length !== 1) {
748
- throw new Error(
749
- engine.translate(
750
- SuiteCoreComponentId,
751
- SuiteCoreStringKey.Error_FailedToCreateUserTemplate,
752
- {
753
- NAME: engine.translate(
754
- SuiteCoreComponentId,
755
- SuiteCoreStringKey.Common_System,
756
- ),
757
- },
758
- ),
759
- );
760
- }
761
-
762
- const systemDoc = systemDocs[0];
763
-
764
- // Create admin user-role relationship
765
- const systemUserRoleDoc = await roleService.addUserToRole(
766
- systemRoleId as I,
767
- systemUserId as I,
768
- systemUserId as I,
769
- sess,
770
- systemUserRoleId,
771
- );
772
-
773
- if (!systemUser.mnemonic.value) {
774
- throw new Error(
775
- engine.translate(
776
- SuiteCoreComponentId,
777
- SuiteCoreStringKey.Error_MnemonicIsNullTemplate,
778
- {
779
- NAME: SuiteCoreStringKey.Common_System,
780
- },
781
- ),
782
- );
783
- }
784
-
785
- const adminUser = DatabaseInitializationService.cacheOrNew<I>(
786
- application.constants.AdministratorUser,
787
- new EmailString(application.constants.AdministratorEmail),
788
- options.adminMnemonic,
789
- MemberType.User,
790
- eciesService,
791
- adminUserId as I,
792
- systemDoc._id,
793
- effectiveIdGenerator,
794
- idToString,
795
- );
796
- // Encrypt mnemonic for recovery
797
- const adminEncryptedMnemonic = adminUser.member
798
- .encryptData(Buffer.from(adminUser.mnemonic.value ?? '', 'utf-8'))
799
- .toString('hex');
800
- const adminMnemonicDoc = await mnemonicService.addMnemonic(
801
- adminUser.mnemonic,
802
- sess,
803
- );
804
- if (!adminMnemonicDoc) {
805
- throw new Error(
806
- engine.translate(
807
- SuiteCoreComponentId,
808
- SuiteCoreStringKey.Error_FailedToStoreUserMnemonicTemplate,
809
- {
810
- NAME: engine.translate(
811
- SuiteCoreComponentId,
812
- SuiteCoreStringKey.Common_Admin,
813
- ),
814
- },
815
- ),
816
- );
817
- }
818
- const adminPasswordSecure = options.adminPassword
819
- ? options.adminPassword
820
- : new SecureString(this.generatePassword(16));
821
-
822
- const adminWrapped = keyWrappingService.wrapSecret(
823
- adminUser.member.privateKey!,
824
- adminPasswordSecure,
825
- );
826
- const adminBackupCodes =
827
- options.adminBackupCodes ?? BackupCode.generateBackupCodes();
828
- const encryptedAdminBackupCodes = await BackupCode.encryptBackupCodes(
829
- adminUser.member,
830
- systemUser.member,
831
- adminBackupCodes,
832
- );
833
- const adminDocs = await UserModel.create(
834
- [
835
- {
836
- _id: adminUserId as I,
837
- username: application.constants.AdministratorUser,
838
- email: application.constants.AdministratorEmail,
839
- publicKey: adminUser.member.publicKey.toString('hex'),
840
- duressPasswords: [],
841
- mnemonicRecovery: adminEncryptedMnemonic,
842
- mnemonicId: adminMnemonicDoc._id,
843
- passwordWrappedPrivateKey: adminWrapped,
844
- backupCodes: encryptedAdminBackupCodes,
845
- timezone: application.environment.timezone,
846
- siteLanguage: 'en-US',
847
- emailVerified: true,
848
- accountStatus: AccountStatus.Active,
849
- directChallenge: true,
850
- createdAt: now,
851
- updatedAt: now,
852
- createdBy: systemUserId as I,
853
- updatedBy: systemUserId as I,
854
- },
855
- ],
856
- { session: sess },
857
- );
858
- if (adminDocs.length !== 1) {
859
- throw new Error(
860
- engine.translate(
861
- SuiteCoreComponentId,
862
- SuiteCoreStringKey.Error_FailedToCreateUserTemplate,
863
- {
864
- NAME: engine.translate(
865
- SuiteCoreComponentId,
866
- SuiteCoreStringKey.Common_Admin,
867
- ),
868
- },
869
- ),
870
- );
871
- }
872
-
873
- const adminDoc = adminDocs[0];
874
-
875
- // Create admin user-role relationship
876
- const adminUserRoleDoc = await roleService.addUserToRole(
877
- adminRoleId as I,
878
- adminUserId as I,
879
- systemUserId as I,
880
- sess,
881
- adminUserRoleId,
882
- );
883
-
884
- if (!adminUser.mnemonic.value) {
885
- throw new Error(
886
- engine.translate(
887
- SuiteCoreComponentId,
888
- SuiteCoreStringKey.Error_MnemonicIsNullTemplate,
889
- {
890
- NAME: engine.translate(
891
- SuiteCoreComponentId,
892
- SuiteCoreStringKey.Common_Admin,
893
- ),
894
- },
895
- ),
896
- );
897
- }
898
-
899
- const memberUser = DatabaseInitializationService.cacheOrNew<I>(
900
- application.constants.MemberUser,
901
- new EmailString(application.constants.MemberEmail),
902
- options.memberMnemonic,
903
- MemberType.User,
904
- eciesService,
905
- memberUserId as I,
906
- systemDoc._id,
907
- effectiveIdGenerator,
908
- idToString,
909
- );
910
- const memberPasswordSecure = options.memberPassword
911
- ? options.memberPassword
912
- : new SecureString(this.generatePassword(16));
913
-
914
- const memberMnemonicDoc = await mnemonicService.addMnemonic(
915
- memberUser.mnemonic,
916
- sess,
917
- );
918
- if (!memberMnemonicDoc) {
919
- throw new Error(
920
- engine.translate(
921
- SuiteCoreComponentId,
922
- SuiteCoreStringKey.Error_FailedToStoreUserMnemonicTemplate,
923
- {
924
- NAME: engine.translate(
925
- SuiteCoreComponentId,
926
- SuiteCoreStringKey.Common_Member,
927
- ),
928
- },
929
- ),
930
- );
931
- }
932
-
933
- // Encrypt mnemonic for recovery
934
- const encryptedMemberMnemonic = memberUser.member
935
- .encryptData(Buffer.from(memberUser.mnemonic.value ?? '', 'utf-8'))
936
- .toString('hex');
937
- const memberWrapped = keyWrappingService.wrapSecret(
938
- memberUser.member.privateKey!,
939
- memberPasswordSecure,
940
- );
941
- const memberBackupCodes =
942
- options.memberBackupCodes ?? BackupCode.generateBackupCodes();
943
- const encryptedMemberBackupCodes =
944
- await BackupCode.encryptBackupCodes(
945
- memberUser.member,
946
- systemUser.member,
947
- memberBackupCodes,
948
- );
949
- const memberDocs = await UserModel.create(
950
- [
951
- {
952
- _id: memberUserId as I,
953
- username: application.constants.MemberUser,
954
- email: application.constants.MemberEmail,
955
- publicKey: memberUser.member.publicKey.toString('hex'),
956
- mnemonicId: memberMnemonicDoc._id,
957
- mnemonicRecovery: encryptedMemberMnemonic,
958
- passwordWrappedPrivateKey: memberWrapped,
959
- backupCodes: encryptedMemberBackupCodes,
960
- duressPasswords: [],
961
- timezone: application.environment.timezone,
962
- siteLanguage: 'en-US',
963
- emailVerified: true,
964
- accountStatus: AccountStatus.Active,
965
- directChallenge: true,
966
- createdAt: now,
967
- updatedAt: now,
968
- createdBy: systemUserId as I,
969
- updatedBy: systemUserId as I,
970
- },
971
- ],
972
- { session: sess },
973
- );
974
- if (memberDocs.length !== 1) {
975
- throw new Error(
976
- engine.translate(
977
- SuiteCoreComponentId,
978
- SuiteCoreStringKey.Error_FailedToCreateUserTemplate,
979
- {
980
- NAME: engine.translate(
981
- SuiteCoreComponentId,
982
- SuiteCoreStringKey.Common_Member,
983
- ),
984
- },
985
- ),
986
- );
987
- }
988
-
989
- const memberDoc = memberDocs[0];
990
-
991
- // Create member user-role relationship
992
- const memberUserRoleDoc = await roleService.addUserToRole(
993
- memberRoleId as I,
994
- memberUserId as I,
995
- systemUserId as I,
996
- sess,
997
- memberUserRoleId,
998
- );
999
-
1000
- if (!memberUser.mnemonic.value) {
1001
- throw new Error(
1002
- engine.translate(
1003
- SuiteCoreComponentId,
1004
- SuiteCoreStringKey.Error_MnemonicIsNullTemplate,
1005
- {
1006
- NAME: engine.translate(
1007
- SuiteCoreComponentId,
1008
- SuiteCoreStringKey.Common_Member,
1009
- ),
1010
- },
1011
- ),
1012
- );
1013
- }
1014
-
1015
- return {
1016
- adminRole,
1017
- memberRole,
1018
- systemRole,
1019
- systemDoc,
1020
- systemUserRoleDoc,
1021
- systemPassword: systemPasswordSecure.notNullValue,
1022
- systemMnemonic: systemUser.mnemonic.notNullValue,
1023
- systemBackupCodes: systemBackupCodes,
1024
- systemMember: systemUser.member,
1025
- adminDoc,
1026
- adminUserRoleDoc,
1027
- adminPassword: adminPasswordSecure.notNullValue,
1028
- adminMnemonic: adminUser.mnemonic.notNullValue,
1029
- adminBackupCodes: adminBackupCodes,
1030
- adminMember: adminUser.member,
1031
- memberDoc,
1032
- memberUserRoleDoc,
1033
- memberPassword: memberPasswordSecure.notNullValue,
1034
- memberMnemonic: memberUser.mnemonic.notNullValue,
1035
- memberBackupCodes: memberBackupCodes,
1036
- memberUser: memberUser.member,
1037
- };
1038
- },
1039
- transactionOptions,
1040
- );
1041
-
1042
- return {
1043
- alreadyInitialized: false,
1044
- success: true,
1045
- data: {
1046
- adminRole: result.adminRole,
1047
- adminUserRole: result.adminUserRoleDoc,
1048
- adminUser: result.adminDoc,
1049
- adminUsername: result.adminDoc.username,
1050
- adminEmail: result.adminDoc.email,
1051
- adminMnemonic: result.adminMnemonic,
1052
- adminPassword: result.adminPassword,
1053
- adminBackupCodes: result.adminBackupCodes.map((bc) => bc.value ?? ''),
1054
- adminMember: result.adminMember,
1055
- memberRole: result.memberRole,
1056
- memberUserRole: result.memberUserRoleDoc,
1057
- memberUser: result.memberDoc,
1058
- memberUsername: result.memberDoc.username,
1059
- memberEmail: result.memberDoc.email,
1060
- memberMnemonic: result.memberMnemonic,
1061
- memberPassword: result.memberPassword,
1062
- memberBackupCodes: result.memberBackupCodes.map(
1063
- (bc) => bc.value ?? '',
1064
- ),
1065
- memberMember: result.memberUser,
1066
- systemRole: result.systemRole,
1067
- systemUserRole: result.systemUserRoleDoc,
1068
- systemUser: result.systemDoc,
1069
- systemUsername: result.systemDoc.username,
1070
- systemEmail: result.systemDoc.email,
1071
- systemMnemonic: result.systemMnemonic,
1072
- systemPassword: result.systemPassword,
1073
- systemBackupCodes: result.systemBackupCodes.map(
1074
- (bc) => bc.value ?? '',
1075
- ),
1076
- systemMember: result.systemMember,
1077
- },
1078
- };
1079
- } catch (error) {
1080
- // Check if it's a translatable error and display cleanly
1081
- if (
1082
- error instanceof TranslatableGenericError ||
1083
- error instanceof TranslatableHandleableGenericError ||
1084
- error instanceof TranslatableSuiteError ||
1085
- error instanceof TranslatableSuiteHandleableError
1086
- ) {
1087
- return {
1088
- alreadyInitialized: false,
1089
- success: false,
1090
- message: (error as Error).message,
1091
- error: error as Error,
1092
- };
1093
- }
1094
-
1095
- return {
1096
- alreadyInitialized: false,
1097
- success: false,
1098
- message: engine.translate(
1099
- SuiteCoreComponentId,
1100
- SuiteCoreStringKey.Admin_Error_FailedToInitializeUserDatabase,
1101
- ),
1102
- error:
1103
- error instanceof Error
1104
- ? error
1105
- : new Error(
1106
- engine.translate(
1107
- SuiteCoreComponentId,
1108
- SuiteCoreStringKey.Admin_Error_FailedToInitializeUserDatabase,
1109
- ),
1110
- ),
1111
- };
1112
- }
1113
- }
1114
-
1115
- public static serverInitResultsToDotEnv<
1116
- I extends Types.ObjectId | string = Types.ObjectId,
1117
- >(
1118
- serverInitResult: IServerInitResult<I>,
1119
- idToString: (id: I) => string = (id) => String(id),
1120
- ): string {
1121
- return `ADMIN_ID="${idToString(serverInitResult.adminUser._id as I)}"
1122
- ADMIN_MNEMONIC="${serverInitResult.adminMnemonic}"
1123
- ADMIN_ROLE_ID="${idToString(serverInitResult.adminRole._id as I)}"
1124
- ADMIN_USER_ROLE_ID="${idToString(serverInitResult.adminUserRole._id as I)}"
1125
- ADMIN_PASSWORD="${serverInitResult.adminPassword}"
1126
- MEMBER_ID="${idToString(serverInitResult.memberUser._id as I)}"
1127
- MEMBER_MNEMONIC="${serverInitResult.memberMnemonic}"
1128
- MEMBER_ROLE_ID="${idToString(serverInitResult.memberRole._id as I)}"
1129
- MEMBER_USER_ROLE_ID="${idToString(serverInitResult.memberUserRole._id as I)}"
1130
- MEMBER_PASSWORD="${serverInitResult.memberPassword}"
1131
- SYSTEM_ID="${idToString(serverInitResult.systemUser._id as I)}"
1132
- SYSTEM_MNEMONIC="${serverInitResult.systemMnemonic}"
1133
- SYSTEM_PUBLIC_KEY="${serverInitResult.systemUser.publicKey}"
1134
- SYSTEM_ROLE_ID="${idToString(serverInitResult.systemRole._id as I)}"
1135
- SYSTEM_USER_ROLE_ID="${idToString(serverInitResult.systemUserRole._id as I)}"
1136
- SYSTEM_PASSWORD="${serverInitResult.systemPassword}"
1137
- `;
1138
- }
1139
-
1140
- public static printServerInitResults<
1141
- I extends Types.ObjectId | string = Types.ObjectId,
1142
- >(
1143
- result: IServerInitResult<I>,
1144
- printDotEnv: boolean = true,
1145
- idToString: (id: I) => string = (id) => String(id),
1146
- ): void {
1147
- debugLog(
1148
- true,
1149
- 'log',
1150
- this.defaultI18nTFunc(
1151
- '\n=== {{SuiteCoreStringKey.Admin_AccountCredentials}} ===',
1152
- ),
1153
- );
1154
- directLog(
1155
- true,
1156
- 'log',
1157
- this.defaultI18nTFunc(
1158
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_ID}}: {id}',
1159
- {
1160
- id: idToString(result.systemUser._id as I),
1161
- },
1162
- ),
1163
- );
1164
- directLog(
1165
- true,
1166
- 'log',
1167
- this.defaultI18nTFunc(
1168
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_Role}}: {roleName}',
1169
- {
1170
- roleName: result.systemRole.name,
1171
- },
1172
- ),
1173
- );
1174
- directLog(
1175
- true,
1176
- 'log',
1177
- this.defaultI18nTFunc(
1178
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_Role}} {{SuiteCoreStringKey.Common_ID}}: {roleId}',
1179
- {
1180
- roleId: idToString(result.systemRole._id as I),
1181
- },
1182
- ),
1183
- );
1184
- directLog(
1185
- true,
1186
- 'log',
1187
- this.defaultI18nTFunc(
1188
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_User}} {{SuiteCoreStringKey.Common_Role}} {{SuiteCoreStringKey.Common_ID}}: {userRoleId}',
1189
- {
1190
- userRoleId: idToString(result.systemUserRole._id as I),
1191
- },
1192
- ),
1193
- );
1194
- directLog(
1195
- true,
1196
- 'log',
1197
- this.defaultI18nTFunc(
1198
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_Username}}: {username}',
1199
- {
1200
- username: result.systemUsername,
1201
- },
1202
- ),
1203
- );
1204
- directLog(
1205
- true,
1206
- 'log',
1207
- this.defaultI18nTFunc(
1208
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_Email}}: {email}',
1209
- {
1210
- email: result.systemEmail,
1211
- },
1212
- ),
1213
- );
1214
- directLog(
1215
- true,
1216
- 'log',
1217
- this.defaultI18nTFunc(
1218
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_Password}}: {password}',
1219
- {
1220
- password: result.systemPassword,
1221
- },
1222
- ),
1223
- );
1224
- directLog(
1225
- true,
1226
- 'log',
1227
- this.defaultI18nTFunc(
1228
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_Mnemonic}}: {mnemonic}',
1229
- {
1230
- mnemonic: result.systemMnemonic,
1231
- },
1232
- ),
1233
- );
1234
- directLog(
1235
- true,
1236
- 'log',
1237
- this.defaultI18nTFunc(
1238
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_PublicKey}}: {publicKey}',
1239
- {
1240
- publicKey: result.systemUser.publicKey,
1241
- },
1242
- ),
1243
- );
1244
- directLog(
1245
- true,
1246
- 'log',
1247
- `${this.defaultI18nTFunc(
1248
- '{{SuiteCoreStringKey.Common_System}} {{SuiteCoreStringKey.Common_BackupCodes}}',
1249
- )}: ${result.systemBackupCodes.join(', ')}`,
1250
- );
1251
- directLog(true, 'log', '');
1252
- directLog(
1253
- true,
1254
- 'log',
1255
- this.defaultI18nTFunc(
1256
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_ID}}: {id}',
1257
- {
1258
- id: idToString(result.adminUser._id as I),
1259
- },
1260
- ),
1261
- );
1262
- directLog(
1263
- true,
1264
- 'log',
1265
- this.defaultI18nTFunc(
1266
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_Role}}: {roleName}',
1267
- {
1268
- roleName: result.adminRole.name,
1269
- },
1270
- ),
1271
- );
1272
- directLog(
1273
- true,
1274
- 'log',
1275
- this.defaultI18nTFunc(
1276
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_Role}} {{SuiteCoreStringKey.Common_ID}}: {roleId}',
1277
- {
1278
- roleId: idToString(result.adminRole._id as I),
1279
- },
1280
- ),
1281
- );
1282
- directLog(
1283
- true,
1284
- 'log',
1285
- this.defaultI18nTFunc(
1286
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_User}} {{SuiteCoreStringKey.Common_Role}} {{SuiteCoreStringKey.Common_ID}}: {userRoleId}',
1287
- {
1288
- userRoleId: idToString(result.adminUserRole._id as I),
1289
- },
1290
- ),
1291
- );
1292
- directLog(
1293
- true,
1294
- 'log',
1295
- this.defaultI18nTFunc(
1296
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_Username}}: {username}',
1297
- {
1298
- username: result.adminUsername,
1299
- },
1300
- ),
1301
- );
1302
- directLog(
1303
- true,
1304
- 'log',
1305
- this.defaultI18nTFunc(
1306
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_Email}}: {email}',
1307
- {
1308
- email: result.adminEmail,
1309
- },
1310
- ),
1311
- );
1312
- directLog(
1313
- true,
1314
- 'log',
1315
- this.defaultI18nTFunc(
1316
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_Password}}: {password}',
1317
- {
1318
- password: result.adminPassword,
1319
- },
1320
- ),
1321
- );
1322
- directLog(
1323
- true,
1324
- 'log',
1325
- this.defaultI18nTFunc(
1326
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_Mnemonic}}: {mnemonic}',
1327
- {
1328
- mnemonic: result.adminMnemonic,
1329
- },
1330
- ),
1331
- );
1332
- directLog(
1333
- true,
1334
- 'log',
1335
- this.defaultI18nTFunc(
1336
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_PublicKey}}: {publicKey}',
1337
- {
1338
- publicKey: result.adminUser.publicKey,
1339
- },
1340
- ),
1341
- );
1342
- directLog(
1343
- true,
1344
- 'log',
1345
- `${this.defaultI18nTFunc(
1346
- '{{SuiteCoreStringKey.Common_Admin}} {{SuiteCoreStringKey.Common_BackupCodes}}',
1347
- )}: ${result.adminBackupCodes.join(', ')}`,
1348
- );
1349
- directLog(true, 'log', '');
1350
- directLog(
1351
- true,
1352
- 'log',
1353
- this.defaultI18nTFunc(
1354
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_ID}}: {id}',
1355
- {
1356
- id: idToString(result.memberUser._id as I),
1357
- },
1358
- ),
1359
- );
1360
- directLog(
1361
- true,
1362
- 'log',
1363
- this.defaultI18nTFunc(
1364
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_Role}}: {roleName}',
1365
- {
1366
- roleName: result.memberRole.name,
1367
- },
1368
- ),
1369
- );
1370
- directLog(
1371
- true,
1372
- 'log',
1373
- this.defaultI18nTFunc(
1374
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_Role}} {{SuiteCoreStringKey.Common_ID}}: {roleId}',
1375
- {
1376
- roleId: idToString(result.memberRole._id as I),
1377
- },
1378
- ),
1379
- );
1380
- directLog(
1381
- true,
1382
- 'log',
1383
- this.defaultI18nTFunc(
1384
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_User}} {{SuiteCoreStringKey.Common_Role}} {{SuiteCoreStringKey.Common_ID}}: {userRoleId}',
1385
- {
1386
- userRoleId: idToString(result.memberUserRole._id as I),
1387
- },
1388
- ),
1389
- );
1390
- directLog(
1391
- true,
1392
- 'log',
1393
- this.defaultI18nTFunc(
1394
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_Username}}: {username}',
1395
- {
1396
- username: result.memberUsername,
1397
- },
1398
- ),
1399
- );
1400
- directLog(
1401
- true,
1402
- 'log',
1403
- this.defaultI18nTFunc(
1404
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_Email}}: {email}',
1405
- {
1406
- email: result.memberEmail,
1407
- },
1408
- ),
1409
- );
1410
- directLog(
1411
- true,
1412
- 'log',
1413
- this.defaultI18nTFunc(
1414
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_Password}}: {password}',
1415
- {
1416
- password: result.memberPassword,
1417
- },
1418
- ),
1419
- );
1420
- directLog(
1421
- true,
1422
- 'log',
1423
- this.defaultI18nTFunc(
1424
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_Mnemonic}}: {mnemonic}',
1425
- {
1426
- mnemonic: result.memberMnemonic,
1427
- },
1428
- ),
1429
- );
1430
- directLog(
1431
- true,
1432
- 'log',
1433
- this.defaultI18nTFunc(
1434
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_PublicKey}}: {publicKey}',
1435
- {
1436
- publicKey: result.memberUser.publicKey,
1437
- },
1438
- ),
1439
- );
1440
- directLog(
1441
- true,
1442
- 'log',
1443
- `${this.defaultI18nTFunc(
1444
- '{{SuiteCoreStringKey.Common_Member}} {{SuiteCoreStringKey.Common_BackupCodes}}',
1445
- )}: ${result.memberBackupCodes.join(', ')}`,
1446
- );
1447
- directLog(
1448
- true,
1449
- 'log',
1450
- this.defaultI18nTFunc(
1451
- '\n=== {{SuiteCoreStringKey.Admin_EndCredentials}} ===',
1452
- ),
1453
- );
1454
-
1455
- if (printDotEnv) {
1456
- directLog(true, 'log', '');
1457
- debugLog(
1458
- true,
1459
- 'log',
1460
- this.defaultI18nTFunc(
1461
- '=== {{SuiteCoreStringKey.Admin_DotEnvFormat}} ===',
1462
- ),
1463
- );
1464
- directLog(
1465
- true,
1466
- 'log',
1467
- this.serverInitResultsToDotEnv(result, idToString),
1468
- );
1469
- debugLog(
1470
- true,
1471
- 'log',
1472
- this.defaultI18nTFunc(
1473
- '=== {{SuiteCoreStringKey.Admin_EndDotEnvFormat}} ===',
1474
- ),
1475
- );
1476
- }
1477
- }
1478
-
1479
- public static setEnvFromInitResults<
1480
- I extends Types.ObjectId | string = Types.ObjectId,
1481
- >(
1482
- result: IServerInitResult<I>,
1483
- idToString: (id: I) => string = (id) => String(id),
1484
- ): void {
1485
- process.env['ADMIN_ID'] = idToString(result.adminUser._id as I);
1486
- process.env['ADMIN_PUBLIC_KEY'] = result.adminUser.publicKey;
1487
- process.env['ADMIN_MNEMONIC'] = result.adminMnemonic;
1488
- process.env['ADMIN_PASSWORD'] = result.adminPassword;
1489
- process.env['ADMIN_ROLE_ID'] = idToString(result.adminRole._id as I);
1490
- process.env['ADMIN_USER_ROLE_ID'] = idToString(
1491
- result.adminUserRole._id as I,
1492
- );
1493
- //
1494
- process.env['MEMBER_ID'] = idToString(result.memberUser._id as I);
1495
- process.env['MEMBER_PUBLIC_KEY'] = result.memberUser.publicKey;
1496
- process.env['MEMBER_MNEMONIC'] = result.memberMnemonic;
1497
- process.env['MEMBER_PASSWORD'] = result.memberPassword;
1498
- process.env['MEMBER_ROLE_ID'] = idToString(result.memberRole._id as I);
1499
- process.env['MEMBER_USER_ROLE_ID'] = idToString(
1500
- result.memberUserRole._id as I,
1501
- );
1502
- //
1503
- process.env['SYSTEM_ID'] = idToString(result.systemUser._id as I);
1504
- process.env['SYSTEM_PUBLIC_KEY'] = result.systemUser.publicKey;
1505
- process.env['SYSTEM_MNEMONIC'] = result.systemMnemonic;
1506
- process.env['SYSTEM_PASSWORD'] = result.systemPassword;
1507
- process.env['SYSTEM_ROLE_ID'] = idToString(result.systemRole._id as I);
1508
- process.env['SYSTEM_USER_ROLE_ID'] = idToString(
1509
- result.systemUserRole._id as I,
1510
- );
1511
- }
1512
-
1513
- /**
1514
- * Initialize the user database with default users and roles (convenience method)
1515
- * This method creates the necessary services and calls initUserDbWithServices
1516
- * @param application The application
1517
- * @returns The result of the initialization
1518
- */
1519
- public static async initUserDb<
1520
- I extends Types.ObjectId | string = Types.ObjectId,
1521
- >(
1522
- application: IApplication,
1523
- idGenerator?: () => I,
1524
- idToString: (id: I) => string = (id) =>
1525
- application.constants.idProvider.idToString(id),
1526
- ): Promise<IFailableResult<IServerInitResult<I>>> {
1527
- const mnemonicModel = ModelRegistry.instance.getTypedModel<
1528
- IMnemonicDocument<I>
1529
- >(BaseModelName.Mnemonic);
1530
- const mnemonicService = new MnemonicService(
1531
- mnemonicModel,
1532
- application.environment.mnemonicHmacSecret,
1533
- application.constants,
1534
- );
1535
- const config: IECIESConfig = {
1536
- curveName: ECIES.CURVE_NAME,
1537
- primaryKeyDerivationPath: ECIES.PRIMARY_KEY_DERIVATION_PATH,
1538
- mnemonicStrength: ECIES.MNEMONIC_STRENGTH,
1539
- symmetricAlgorithm: ECIES.SYMMETRIC_ALGORITHM_CONFIGURATION,
1540
- symmetricKeyBits: ECIES.SYMMETRIC.KEY_BITS,
1541
- symmetricKeyMode: ECIES.SYMMETRIC.MODE,
1542
- };
1543
- const eciesService = new ECIESService(config);
1544
- const roleService = new RoleService<I>(application);
1545
- const keyWrappingService = new KeyWrappingService();
1546
- const backupCodeService = new BackupCodeService<I>(
1547
- application,
1548
- eciesService,
1549
- keyWrappingService,
1550
- roleService,
1551
- );
1552
-
1553
- return this.initUserDbWithServices<I>(
1554
- application,
1555
- keyWrappingService,
1556
- mnemonicService,
1557
- eciesService,
1558
- roleService,
1559
- backupCodeService,
1560
- idGenerator,
1561
- idToString,
1562
- );
1563
- }
1564
- }