@digitaldefiance/node-express-suite 1.0.23 → 1.0.25
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.
- package/README.md +8 -0
- package/package.json +8 -7
- package/src/application-base.d.ts +112 -0
- package/src/application-base.d.ts.map +1 -0
- package/src/application-base.js +335 -0
- package/src/application-base.js.map +1 -0
- package/src/application.d.ts +20 -0
- package/src/application.d.ts.map +1 -0
- package/src/application.js +124 -0
- package/src/application.js.map +1 -0
- package/src/backup-code.d.ts +67 -0
- package/src/backup-code.d.ts.map +1 -0
- package/src/backup-code.js +238 -0
- package/src/backup-code.js.map +1 -0
- package/src/constants.d.ts +16 -0
- package/src/constants.d.ts.map +1 -0
- package/src/constants.js +54 -0
- package/src/constants.js.map +1 -0
- package/src/controllers/base.d.ts +63 -0
- package/src/controllers/base.d.ts.map +1 -0
- package/src/controllers/base.js +272 -0
- package/src/controllers/base.js.map +1 -0
- package/src/controllers/{index.ts → index.d.ts} +1 -0
- package/src/controllers/index.d.ts.map +1 -0
- package/src/controllers/index.js +6 -0
- package/src/controllers/index.js.map +1 -0
- package/src/controllers/user.d.ts +45 -0
- package/src/controllers/user.d.ts.map +1 -0
- package/src/controllers/user.js +748 -0
- package/src/controllers/user.js.map +1 -0
- package/src/decorators/base-controller.d.ts +14 -0
- package/src/decorators/base-controller.d.ts.map +1 -0
- package/src/decorators/base-controller.js +49 -0
- package/src/decorators/base-controller.js.map +1 -0
- package/src/decorators/controller.d.ts +32 -0
- package/src/decorators/controller.d.ts.map +1 -0
- package/src/decorators/controller.js +67 -0
- package/src/decorators/controller.js.map +1 -0
- package/src/decorators/{index.ts → index.d.ts} +1 -0
- package/src/decorators/index.d.ts.map +1 -0
- package/src/decorators/index.js +7 -0
- package/src/decorators/index.js.map +1 -0
- package/src/decorators/zod-validation.d.ts +5 -0
- package/src/decorators/zod-validation.d.ts.map +1 -0
- package/src/decorators/zod-validation.js +47 -0
- package/src/decorators/zod-validation.js.map +1 -0
- package/src/defaults.d.ts +7 -0
- package/src/defaults.d.ts.map +1 -0
- package/src/defaults.js +83 -0
- package/src/defaults.js.map +1 -0
- package/src/documents/base.d.ts +3 -0
- package/src/documents/base.d.ts.map +1 -0
- package/src/documents/base.js +3 -0
- package/src/documents/base.js.map +1 -0
- package/src/documents/email-token.d.ts +8 -0
- package/src/documents/email-token.d.ts.map +1 -0
- package/src/documents/email-token.js +3 -0
- package/src/documents/email-token.js.map +1 -0
- package/src/documents/{index.ts → index.d.ts} +1 -0
- package/src/documents/index.d.ts.map +1 -0
- package/src/documents/index.js +3 -0
- package/src/documents/index.js.map +1 -0
- package/src/documents/{mnemonic.ts → mnemonic.d.ts} +2 -5
- package/src/documents/mnemonic.d.ts.map +1 -0
- package/src/documents/mnemonic.js +3 -0
- package/src/documents/mnemonic.js.map +1 -0
- package/src/documents/{role.ts → role.d.ts} +2 -5
- package/src/documents/role.d.ts.map +1 -0
- package/src/documents/role.js +3 -0
- package/src/documents/role.js.map +1 -0
- package/src/documents/used-direct-login-token.d.ts +5 -0
- package/src/documents/used-direct-login-token.d.ts.map +1 -0
- package/src/documents/used-direct-login-token.js +3 -0
- package/src/documents/used-direct-login-token.js.map +1 -0
- package/src/documents/{user-role.ts → user-role.d.ts} +2 -5
- package/src/documents/user-role.d.ts.map +1 -0
- package/src/documents/user-role.js +3 -0
- package/src/documents/user-role.js.map +1 -0
- package/src/documents/{user.ts → user.d.ts} +2 -4
- package/src/documents/user.d.ts.map +1 -0
- package/src/documents/user.js +3 -0
- package/src/documents/user.js.map +1 -0
- package/src/enumerations/base-model-name.d.ts +38 -0
- package/src/enumerations/base-model-name.d.ts.map +1 -0
- package/src/enumerations/base-model-name.js +34 -0
- package/src/enumerations/base-model-name.js.map +1 -0
- package/src/enumerations/{index.ts → index.d.ts} +1 -0
- package/src/enumerations/index.d.ts.map +1 -0
- package/src/enumerations/index.js +8 -0
- package/src/enumerations/index.js.map +1 -0
- package/src/enumerations/length-encoding-type.d.ts +7 -0
- package/src/enumerations/length-encoding-type.d.ts.map +1 -0
- package/src/enumerations/length-encoding-type.js +11 -0
- package/src/enumerations/length-encoding-type.js.map +1 -0
- package/src/enumerations/schema-collection.d.ts +34 -0
- package/src/enumerations/schema-collection.d.ts.map +1 -0
- package/src/enumerations/schema-collection.js +38 -0
- package/src/enumerations/schema-collection.js.map +1 -0
- package/src/enumerations/symmetric-error-type.d.ts +5 -0
- package/src/enumerations/symmetric-error-type.d.ts.map +1 -0
- package/src/enumerations/symmetric-error-type.js +9 -0
- package/src/enumerations/symmetric-error-type.js.map +1 -0
- package/src/environment.d.ts +189 -0
- package/src/environment.d.ts.map +1 -0
- package/src/environment.js +620 -0
- package/src/environment.js.map +1 -0
- package/src/errors/express-validation.d.ts +9 -0
- package/src/errors/express-validation.d.ts.map +1 -0
- package/src/errors/express-validation.js +18 -0
- package/src/errors/express-validation.js.map +1 -0
- package/src/errors/{index.ts → index.d.ts} +1 -0
- package/src/errors/index.d.ts.map +1 -0
- package/src/errors/index.js +16 -0
- package/src/errors/index.js.map +1 -0
- package/src/errors/invalid-backup-code-version.d.ts +6 -0
- package/src/errors/invalid-backup-code-version.d.ts.map +1 -0
- package/src/errors/invalid-backup-code-version.js +15 -0
- package/src/errors/invalid-backup-code-version.js.map +1 -0
- package/src/errors/invalid-jwt-token.d.ts +5 -0
- package/src/errors/invalid-jwt-token.d.ts.map +1 -0
- package/src/errors/invalid-jwt-token.js +11 -0
- package/src/errors/invalid-jwt-token.js.map +1 -0
- package/src/errors/invalid-model.d.ts +6 -0
- package/src/errors/invalid-model.d.ts.map +1 -0
- package/src/errors/invalid-model.js +14 -0
- package/src/errors/invalid-model.js.map +1 -0
- package/src/errors/invalid-new-password.d.ts +5 -0
- package/src/errors/invalid-new-password.d.ts.map +1 -0
- package/src/errors/invalid-new-password.js +14 -0
- package/src/errors/invalid-new-password.js.map +1 -0
- package/src/errors/invalid-password.d.ts +5 -0
- package/src/errors/invalid-password.d.ts.map +1 -0
- package/src/errors/invalid-password.js +14 -0
- package/src/errors/invalid-password.js.map +1 -0
- package/src/errors/missing-validated-data.d.ts +7 -0
- package/src/errors/missing-validated-data.d.ts.map +1 -0
- package/src/errors/missing-validated-data.js +36 -0
- package/src/errors/missing-validated-data.js.map +1 -0
- package/src/errors/mnemonic-or-password-required.d.ts +5 -0
- package/src/errors/mnemonic-or-password-required.d.ts.map +1 -0
- package/src/errors/mnemonic-or-password-required.js +13 -0
- package/src/errors/mnemonic-or-password-required.js.map +1 -0
- package/src/errors/model-not-registered.d.ts +5 -0
- package/src/errors/model-not-registered.d.ts.map +1 -0
- package/src/errors/model-not-registered.js +12 -0
- package/src/errors/model-not-registered.js.map +1 -0
- package/src/errors/mongoose-validation.d.ts +11 -0
- package/src/errors/mongoose-validation.d.ts.map +1 -0
- package/src/errors/mongoose-validation.js +17 -0
- package/src/errors/mongoose-validation.js.map +1 -0
- package/src/errors/symmetric.d.ts +8 -0
- package/src/errors/symmetric.d.ts.map +1 -0
- package/src/errors/symmetric.js +23 -0
- package/src/errors/symmetric.js.map +1 -0
- package/src/errors/token-expired.d.ts +5 -0
- package/src/errors/token-expired.d.ts.map +1 -0
- package/src/errors/token-expired.js +11 -0
- package/src/errors/token-expired.js.map +1 -0
- package/src/get-language.d.ts +2 -0
- package/src/get-language.d.ts.map +1 -0
- package/src/get-language.js +30 -0
- package/src/get-language.js.map +1 -0
- package/src/get-timezone.d.ts +3 -0
- package/src/get-timezone.d.ts.map +1 -0
- package/src/get-timezone.js +31 -0
- package/src/get-timezone.js.map +1 -0
- package/src/{index.ts → index.d.ts} +1 -1
- package/src/index.d.ts.map +1 -0
- package/src/index.js +28 -0
- package/src/index.js.map +1 -0
- package/src/interfaces/{api-error-response.ts → api-error-response.d.ts} +2 -2
- package/src/interfaces/api-error-response.d.ts.map +1 -0
- package/src/interfaces/api-error-response.js +3 -0
- package/src/interfaces/api-error-response.js.map +1 -0
- package/src/interfaces/api-express-validation-error-response.d.ts +7 -0
- package/src/interfaces/api-express-validation-error-response.d.ts.map +1 -0
- package/src/interfaces/api-express-validation-error-response.js +3 -0
- package/src/interfaces/api-express-validation-error-response.js.map +1 -0
- package/src/interfaces/api-message-response.d.ts +4 -0
- package/src/interfaces/api-message-response.d.ts.map +1 -0
- package/src/interfaces/api-message-response.js +3 -0
- package/src/interfaces/api-message-response.js.map +1 -0
- package/src/interfaces/{api-mongo-validation-error-response.ts → api-mongo-validation-error-response.d.ts} +2 -2
- package/src/interfaces/api-mongo-validation-error-response.d.ts.map +1 -0
- package/src/interfaces/api-mongo-validation-error-response.js +3 -0
- package/src/interfaces/api-mongo-validation-error-response.js.map +1 -0
- package/src/interfaces/api-responses/{backup-codes-response.ts → backup-codes-response.d.ts} +2 -2
- package/src/interfaces/api-responses/backup-codes-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/backup-codes-response.js +3 -0
- package/src/interfaces/api-responses/backup-codes-response.js.map +1 -0
- package/src/interfaces/api-responses/{challenge-response.ts → challenge-response.d.ts} +3 -3
- package/src/interfaces/api-responses/challenge-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/challenge-response.js +3 -0
- package/src/interfaces/api-responses/challenge-response.js.map +1 -0
- package/src/interfaces/api-responses/{code-count-response.ts → code-count-response.d.ts} +2 -2
- package/src/interfaces/api-responses/code-count-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/code-count-response.js +3 -0
- package/src/interfaces/api-responses/code-count-response.js.map +1 -0
- package/src/interfaces/api-responses/{index.ts → index.d.ts} +1 -0
- package/src/interfaces/api-responses/index.d.ts.map +1 -0
- package/src/interfaces/api-responses/index.js +11 -0
- package/src/interfaces/api-responses/index.js.map +1 -0
- package/src/interfaces/api-responses/{login-response.ts → login-response.d.ts} +4 -4
- package/src/interfaces/api-responses/login-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/login-response.js +3 -0
- package/src/interfaces/api-responses/login-response.js.map +1 -0
- package/src/interfaces/api-responses/{mnemonic-response.ts → mnemonic-response.d.ts} +2 -2
- package/src/interfaces/api-responses/mnemonic-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/mnemonic-response.js +3 -0
- package/src/interfaces/api-responses/mnemonic-response.js.map +1 -0
- package/src/interfaces/api-responses/{registration-response.ts → registration-response.d.ts} +3 -3
- package/src/interfaces/api-responses/registration-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/registration-response.js +3 -0
- package/src/interfaces/api-responses/registration-response.js.map +1 -0
- package/src/interfaces/api-responses/{request-user-response.ts → request-user-response.d.ts} +2 -2
- package/src/interfaces/api-responses/request-user-response.d.ts.map +1 -0
- package/src/interfaces/api-responses/request-user-response.js +3 -0
- package/src/interfaces/api-responses/request-user-response.js.map +1 -0
- package/src/interfaces/{application.ts → application.d.ts} +7 -7
- package/src/interfaces/application.d.ts.map +1 -0
- package/src/interfaces/application.js +3 -0
- package/src/interfaces/application.js.map +1 -0
- package/src/interfaces/backend-objects/email-token.d.ts +4 -0
- package/src/interfaces/backend-objects/email-token.d.ts.map +1 -0
- package/src/interfaces/backend-objects/email-token.js +3 -0
- package/src/interfaces/backend-objects/email-token.js.map +1 -0
- package/src/interfaces/backend-objects/{index.ts → index.d.ts} +1 -0
- package/src/interfaces/backend-objects/index.d.ts.map +1 -0
- package/src/interfaces/backend-objects/index.js +8 -0
- package/src/interfaces/backend-objects/index.js.map +1 -0
- package/src/interfaces/backend-objects/{request-user.ts → request-user.d.ts} +2 -7
- package/src/interfaces/backend-objects/request-user.d.ts.map +1 -0
- package/src/interfaces/backend-objects/request-user.js +3 -0
- package/src/interfaces/backend-objects/request-user.js.map +1 -0
- package/src/interfaces/backend-objects/{role.ts → role.d.ts} +1 -1
- package/src/interfaces/backend-objects/role.d.ts.map +1 -0
- package/src/interfaces/backend-objects/role.js +3 -0
- package/src/interfaces/backend-objects/role.js.map +1 -0
- package/src/interfaces/backend-objects/user.d.ts +4 -0
- package/src/interfaces/backend-objects/user.d.ts.map +1 -0
- package/src/interfaces/backend-objects/user.js +3 -0
- package/src/interfaces/backend-objects/user.js.map +1 -0
- package/src/interfaces/checksum-config.d.ts +5 -0
- package/src/interfaces/checksum-config.d.ts.map +1 -0
- package/src/interfaces/checksum-config.js +3 -0
- package/src/interfaces/checksum-config.js.map +1 -0
- package/src/interfaces/checksum-consts.d.ts +11 -0
- package/src/interfaces/checksum-consts.d.ts.map +1 -0
- package/src/interfaces/checksum-consts.js +3 -0
- package/src/interfaces/checksum-consts.js.map +1 -0
- package/src/interfaces/{constants.ts → constants.d.ts} +5 -5
- package/src/interfaces/constants.d.ts.map +1 -0
- package/src/interfaces/constants.js +3 -0
- package/src/interfaces/constants.js.map +1 -0
- package/src/interfaces/create-user-basics.d.ts +18 -0
- package/src/interfaces/create-user-basics.d.ts.map +1 -0
- package/src/interfaces/create-user-basics.js +3 -0
- package/src/interfaces/create-user-basics.js.map +1 -0
- package/src/interfaces/csp-config.d.ts +14 -0
- package/src/interfaces/csp-config.d.ts.map +1 -0
- package/src/interfaces/csp-config.js +3 -0
- package/src/interfaces/csp-config.js.map +1 -0
- package/src/interfaces/deep-partial.d.ts +4 -0
- package/src/interfaces/deep-partial.d.ts.map +1 -0
- package/src/interfaces/deep-partial.js +3 -0
- package/src/interfaces/deep-partial.js.map +1 -0
- package/src/interfaces/{discriminator-collections.ts → discriminator-collections.d.ts} +3 -3
- package/src/interfaces/discriminator-collections.d.ts.map +1 -0
- package/src/interfaces/discriminator-collections.js +3 -0
- package/src/interfaces/discriminator-collections.js.map +1 -0
- package/src/interfaces/email-service.d.ts +4 -0
- package/src/interfaces/email-service.d.ts.map +1 -0
- package/src/interfaces/email-service.js +3 -0
- package/src/interfaces/email-service.js.map +1 -0
- package/src/interfaces/environment-mongo.d.ts +76 -0
- package/src/interfaces/environment-mongo.d.ts.map +1 -0
- package/src/interfaces/environment-mongo.js +3 -0
- package/src/interfaces/environment-mongo.js.map +1 -0
- package/src/interfaces/environment.d.ts +181 -0
- package/src/interfaces/environment.d.ts.map +1 -0
- package/src/interfaces/environment.js +3 -0
- package/src/interfaces/environment.js.map +1 -0
- package/src/interfaces/failable-result.d.ts +7 -0
- package/src/interfaces/failable-result.d.ts.map +1 -0
- package/src/interfaces/failable-result.js +3 -0
- package/src/interfaces/failable-result.js.map +1 -0
- package/src/interfaces/fec-consts.d.ts +5 -0
- package/src/interfaces/fec-consts.d.ts.map +1 -0
- package/src/interfaces/fec-consts.js +3 -0
- package/src/interfaces/fec-consts.js.map +1 -0
- package/src/interfaces/handleable-error-options.d.ts +7 -0
- package/src/interfaces/handleable-error-options.d.ts.map +1 -0
- package/src/interfaces/handleable-error-options.js +3 -0
- package/src/interfaces/handleable-error-options.js.map +1 -0
- package/src/interfaces/{index.ts → index.d.ts} +1 -0
- package/src/interfaces/index.d.ts.map +1 -0
- package/src/interfaces/index.js +33 -0
- package/src/interfaces/index.js.map +1 -0
- package/src/interfaces/jwt-consts.d.ts +11 -0
- package/src/interfaces/jwt-consts.d.ts.map +1 -0
- package/src/interfaces/jwt-consts.js +3 -0
- package/src/interfaces/jwt-consts.js.map +1 -0
- package/src/interfaces/jwt-sign-response.d.ts +11 -0
- package/src/interfaces/jwt-sign-response.d.ts.map +1 -0
- package/src/interfaces/jwt-sign-response.js +3 -0
- package/src/interfaces/jwt-sign-response.js.map +1 -0
- package/src/interfaces/mongo-errors.d.ts +5 -0
- package/src/interfaces/mongo-errors.d.ts.map +1 -0
- package/src/interfaces/mongo-errors.js +3 -0
- package/src/interfaces/mongo-errors.js.map +1 -0
- package/src/interfaces/request-user.d.ts +42 -0
- package/src/interfaces/request-user.d.ts.map +1 -0
- package/src/interfaces/request-user.js +3 -0
- package/src/interfaces/request-user.js.map +1 -0
- package/src/interfaces/required-string-keys.d.ts +22 -0
- package/src/interfaces/required-string-keys.d.ts.map +1 -0
- package/src/interfaces/required-string-keys.js +3 -0
- package/src/interfaces/required-string-keys.js.map +1 -0
- package/src/interfaces/schema.d.ts +29 -0
- package/src/interfaces/schema.d.ts.map +1 -0
- package/src/interfaces/schema.js +3 -0
- package/src/interfaces/schema.js.map +1 -0
- package/src/interfaces/server-init-result.d.ts +35 -0
- package/src/interfaces/server-init-result.d.ts.map +1 -0
- package/src/interfaces/server-init-result.js +3 -0
- package/src/interfaces/server-init-result.js.map +1 -0
- package/src/interfaces/status-code-response.d.ts +7 -0
- package/src/interfaces/status-code-response.d.ts.map +1 -0
- package/src/interfaces/status-code-response.js +3 -0
- package/src/interfaces/status-code-response.js.map +1 -0
- package/src/interfaces/symmetric-encryption-results.d.ts +3 -3
- package/src/interfaces/symmetric-encryption-results.d.ts.map +1 -1
- package/src/interfaces/symmetric-encryption-results.js.map +1 -1
- package/src/interfaces/{token-response.ts → token-response.d.ts} +2 -2
- package/src/interfaces/token-response.d.ts.map +1 -0
- package/src/interfaces/token-response.js +3 -0
- package/src/interfaces/token-response.js.map +1 -0
- package/src/middlewares/authenticate-crypto.d.ts +13 -0
- package/src/middlewares/authenticate-crypto.d.ts.map +1 -0
- package/src/middlewares/authenticate-crypto.js +146 -0
- package/src/middlewares/authenticate-crypto.js.map +1 -0
- package/src/middlewares/authenticate-token.d.ts +24 -0
- package/src/middlewares/authenticate-token.d.ts.map +1 -0
- package/src/middlewares/authenticate-token.js +102 -0
- package/src/middlewares/authenticate-token.js.map +1 -0
- package/src/middlewares/cleanup-crypto.d.ts +7 -0
- package/src/middlewares/cleanup-crypto.d.ts.map +1 -0
- package/src/middlewares/cleanup-crypto.js +32 -0
- package/src/middlewares/cleanup-crypto.js.map +1 -0
- package/src/middlewares/{index.ts → index.d.ts} +1 -0
- package/src/middlewares/index.d.ts.map +1 -0
- package/src/middlewares/index.js +8 -0
- package/src/middlewares/index.js.map +1 -0
- package/src/middlewares/set-global-context-language.d.ts +3 -0
- package/src/middlewares/set-global-context-language.d.ts.map +1 -0
- package/src/middlewares/set-global-context-language.js +14 -0
- package/src/middlewares/set-global-context-language.js.map +1 -0
- package/src/middlewares.d.ts +18 -0
- package/src/middlewares.d.ts.map +1 -0
- package/src/middlewares.js +74 -0
- package/src/middlewares.js.map +1 -0
- package/src/model-registry.d.ts +23 -0
- package/src/model-registry.d.ts.map +1 -0
- package/src/model-registry.js +47 -0
- package/src/model-registry.js.map +1 -0
- package/src/models/email-token.d.ts +11 -0
- package/src/models/email-token.d.ts.map +1 -0
- package/src/models/email-token.js +11 -0
- package/src/models/email-token.js.map +1 -0
- package/src/models/{index.ts → index.d.ts} +1 -0
- package/src/models/index.d.ts.map +1 -0
- package/src/models/index.js +10 -0
- package/src/models/index.js.map +1 -0
- package/src/models/mnemonic.d.ts +11 -0
- package/src/models/mnemonic.d.ts.map +1 -0
- package/src/models/mnemonic.js +11 -0
- package/src/models/mnemonic.js.map +1 -0
- package/src/models/role.d.ts +11 -0
- package/src/models/role.d.ts.map +1 -0
- package/src/models/role.js +11 -0
- package/src/models/role.js.map +1 -0
- package/src/models/used-direct-login-token.d.ts +11 -0
- package/src/models/used-direct-login-token.d.ts.map +1 -0
- package/src/models/used-direct-login-token.js +11 -0
- package/src/models/used-direct-login-token.js.map +1 -0
- package/src/models/user-role.d.ts +6 -0
- package/src/models/user-role.d.ts.map +1 -0
- package/src/models/user-role.js +10 -0
- package/src/models/user-role.js.map +1 -0
- package/src/models/user.d.ts +7 -0
- package/src/models/user.d.ts.map +1 -0
- package/src/models/user.js +11 -0
- package/src/models/user.js.map +1 -0
- package/src/registry/email-service-registry.d.ts +9 -0
- package/src/registry/email-service-registry.d.ts.map +1 -0
- package/src/registry/email-service-registry.js +18 -0
- package/src/registry/email-service-registry.js.map +1 -0
- package/src/registry/{index.ts → index.d.ts} +1 -0
- package/src/registry/index.d.ts.map +1 -0
- package/src/registry/index.js +6 -0
- package/src/registry/index.js.map +1 -0
- package/src/routers/api.d.ts +27 -0
- package/src/routers/api.d.ts.map +1 -0
- package/src/routers/api.js +52 -0
- package/src/routers/api.js.map +1 -0
- package/src/routers/app.d.ts +28 -0
- package/src/routers/app.d.ts.map +1 -0
- package/src/routers/app.js +186 -0
- package/src/routers/app.js.map +1 -0
- package/src/routers/base.d.ts +12 -0
- package/src/routers/base.d.ts.map +1 -0
- package/src/routers/base.js +14 -0
- package/src/routers/base.js.map +1 -0
- package/src/routers/{index.ts → index.d.ts} +1 -0
- package/src/routers/index.d.ts.map +1 -0
- package/src/routers/index.js +7 -0
- package/src/routers/index.js.map +1 -0
- package/src/schemas/email-token.d.ts +38 -0
- package/src/schemas/email-token.d.ts.map +1 -0
- package/src/schemas/email-token.js +54 -0
- package/src/schemas/email-token.js.map +1 -0
- package/src/schemas/{index.ts → index.d.ts} +2 -1
- package/src/schemas/index.d.ts.map +1 -0
- package/src/schemas/index.js +11 -0
- package/src/schemas/index.js.map +1 -0
- package/src/schemas/mnemonic.d.ts +20 -0
- package/src/schemas/mnemonic.d.ts.map +1 -0
- package/src/schemas/mnemonic.js +30 -0
- package/src/schemas/mnemonic.js.map +1 -0
- package/src/schemas/role.d.ts +32 -0
- package/src/schemas/role.d.ts.map +1 -0
- package/src/schemas/role.js +86 -0
- package/src/schemas/role.js.map +1 -0
- package/src/schemas/schema.d.ts +40 -0
- package/src/schemas/schema.d.ts.map +1 -0
- package/src/schemas/schema.js +62 -0
- package/src/schemas/schema.js.map +1 -0
- package/src/schemas/used-direct-login-token.d.ts +27 -0
- package/src/schemas/used-direct-login-token.d.ts.map +1 -0
- package/src/schemas/used-direct-login-token.js +23 -0
- package/src/schemas/used-direct-login-token.js.map +1 -0
- package/src/schemas/user-role.d.ts +29 -0
- package/src/schemas/user-role.d.ts.map +1 -0
- package/src/schemas/user-role.js +54 -0
- package/src/schemas/user-role.js.map +1 -0
- package/src/schemas/user.d.ts +21 -0
- package/src/schemas/user.d.ts.map +1 -0
- package/src/schemas/user.js +176 -0
- package/src/schemas/user.js.map +1 -0
- package/src/services/backup-code.d.ts +78 -0
- package/src/services/backup-code.d.ts.map +1 -0
- package/src/services/backup-code.js +184 -0
- package/src/services/backup-code.js.map +1 -0
- package/src/services/base.d.ts +13 -0
- package/src/services/base.d.ts.map +1 -0
- package/src/services/base.js +15 -0
- package/src/services/base.js.map +1 -0
- package/src/services/checksum.d.ts +67 -0
- package/src/services/checksum.d.ts.map +1 -0
- package/src/services/checksum.js +143 -0
- package/src/services/checksum.js.map +1 -0
- package/src/services/crc.d.ts +87 -0
- package/src/services/crc.d.ts.map +1 -0
- package/src/services/crc.js +198 -0
- package/src/services/crc.js.map +1 -0
- package/src/services/database-initialization.d.ts +105 -0
- package/src/services/database-initialization.d.ts.map +1 -0
- package/src/services/database-initialization.js +782 -0
- package/src/services/database-initialization.js.map +1 -0
- package/src/services/db-init-cache.d.ts +7 -13
- package/src/services/db-init-cache.d.ts.map +1 -0
- package/src/services/db-init-cache.js +3 -0
- package/src/services/db-init-cache.js.map +1 -0
- package/src/services/direct-login-token.d.ts +9 -0
- package/src/services/direct-login-token.d.ts.map +1 -0
- package/src/services/direct-login-token.js +41 -0
- package/src/services/direct-login-token.js.map +1 -0
- package/src/services/fec-usage-example.d.ts +38 -0
- package/src/services/fec-usage-example.d.ts.map +1 -0
- package/src/services/fec-usage-example.js +75 -0
- package/src/services/fec-usage-example.js.map +1 -0
- package/src/services/fec.d.ts +46 -0
- package/src/services/fec.d.ts.map +1 -0
- package/src/services/fec.js +192 -0
- package/src/services/fec.js.map +1 -0
- package/src/services/{index.ts → index.d.ts} +1 -0
- package/src/services/index.d.ts.map +1 -0
- package/src/services/index.js +22 -0
- package/src/services/index.js.map +1 -0
- package/src/services/jwt.d.ts +33 -0
- package/src/services/jwt.d.ts.map +1 -0
- package/src/services/jwt.js +91 -0
- package/src/services/jwt.js.map +1 -0
- package/src/services/key-wrapping.d.ts +60 -0
- package/src/services/key-wrapping.d.ts.map +1 -0
- package/src/services/key-wrapping.js +311 -0
- package/src/services/key-wrapping.js.map +1 -0
- package/src/services/mnemonic.d.ts +61 -0
- package/src/services/mnemonic.d.ts.map +1 -0
- package/src/services/mnemonic.js +115 -0
- package/src/services/mnemonic.js.map +1 -0
- package/src/services/request-user.d.ts +20 -0
- package/src/services/request-user.d.ts.map +1 -0
- package/src/services/request-user.js +50 -0
- package/src/services/request-user.js.map +1 -0
- package/src/services/role.d.ts +88 -0
- package/src/services/role.d.ts.map +1 -0
- package/src/services/role.js +263 -0
- package/src/services/role.js.map +1 -0
- package/src/services/symmetric.d.ts +42 -0
- package/src/services/symmetric.d.ts.map +1 -0
- package/src/services/symmetric.js +101 -0
- package/src/services/symmetric.js.map +1 -0
- package/src/services/system-user.d.ts +17 -0
- package/src/services/system-user.d.ts.map +1 -0
- package/src/services/system-user.js +46 -0
- package/src/services/system-user.js.map +1 -0
- package/src/services/user.d.ts +320 -0
- package/src/services/user.d.ts.map +1 -0
- package/src/services/user.js +1378 -0
- package/src/services/user.js.map +1 -0
- package/src/services/xor.d.ts +24 -0
- package/src/services/xor.d.ts.map +1 -0
- package/src/services/xor.js +37 -0
- package/src/services/xor.js.map +1 -0
- package/src/types.d.ts +66 -40
- package/src/types.d.ts.map +1 -0
- package/src/types.js +14 -0
- package/src/types.js.map +1 -0
- package/src/utils.d.ts +202 -0
- package/src/utils.d.ts.map +1 -0
- package/src/utils.js +784 -0
- package/src/utils.js.map +1 -0
- package/LICENSE +0 -21
- package/src/application-base.ts +0 -492
- package/src/application.ts +0 -254
- package/src/backup-code.ts +0 -336
- package/src/constants.ts +0 -69
- package/src/controllers/base.ts +0 -440
- package/src/controllers/user.ts +0 -1451
- package/src/decorators/base-controller.ts +0 -61
- package/src/decorators/controller.ts +0 -109
- package/src/decorators/zod-validation.ts +0 -57
- package/src/defaults.ts +0 -94
- package/src/documents/base.ts +0 -7
- package/src/documents/email-token.ts +0 -14
- package/src/documents/used-direct-login-token.ts +0 -7
- package/src/enumerations/base-model-name.ts +0 -41
- package/src/enumerations/length-encoding-type.ts +0 -6
- package/src/enumerations/schema-collection.ts +0 -33
- package/src/enumerations/symmetric-error-type.ts +0 -4
- package/src/environment.ts +0 -770
- package/src/errors/express-validation.ts +0 -21
- package/src/errors/invalid-backup-code-version.ts +0 -14
- package/src/errors/invalid-jwt-token.ts +0 -10
- package/src/errors/invalid-model.ts +0 -11
- package/src/errors/invalid-new-password.ts +0 -18
- package/src/errors/invalid-password.ts +0 -13
- package/src/errors/missing-validated-data.ts +0 -36
- package/src/errors/mnemonic-or-password-required.ts +0 -12
- package/src/errors/model-not-registered.ts +0 -11
- package/src/errors/mongoose-validation.ts +0 -34
- package/src/errors/symmetric.ts +0 -41
- package/src/errors/token-expired.ts +0 -10
- package/src/get-language.ts +0 -53
- package/src/get-timezone.ts +0 -45
- package/src/interfaces/api-express-validation-error-response.ts +0 -8
- package/src/interfaces/api-message-response.ts +0 -3
- package/src/interfaces/backend-objects/email-token.ts +0 -11
- package/src/interfaces/backend-objects/user.ts +0 -9
- package/src/interfaces/checksum-config.ts +0 -4
- package/src/interfaces/checksum-consts.ts +0 -13
- package/src/interfaces/create-user-basics.ts +0 -17
- package/src/interfaces/csp-config.ts +0 -35
- package/src/interfaces/deep-partial.ts +0 -3
- package/src/interfaces/email-service.ts +0 -8
- package/src/interfaces/environment-mongo.ts +0 -76
- package/src/interfaces/environment.ts +0 -181
- package/src/interfaces/failable-result.ts +0 -6
- package/src/interfaces/fec-consts.ts +0 -4
- package/src/interfaces/handleable-error-options.ts +0 -6
- package/src/interfaces/jwt-consts.ts +0 -23
- package/src/interfaces/jwt-sign-response.ts +0 -19
- package/src/interfaces/mongo-errors.ts +0 -5
- package/src/interfaces/request-user.ts +0 -50
- package/src/interfaces/required-string-keys.ts +0 -26
- package/src/interfaces/schema.ts +0 -31
- package/src/interfaces/server-init-result.ts +0 -37
- package/src/interfaces/status-code-response.ts +0 -7
- package/src/interfaces/symmetric-encryption-results.ts +0 -4
- package/src/middlewares/authenticate-crypto.ts +0 -243
- package/src/middlewares/authenticate-token.ts +0 -152
- package/src/middlewares/cleanup-crypto.ts +0 -40
- package/src/middlewares/set-global-context-language.ts +0 -24
- package/src/middlewares.ts +0 -120
- package/src/model-registry.ts +0 -75
- package/src/models/email-token.ts +0 -19
- package/src/models/mnemonic.ts +0 -19
- package/src/models/role.ts +0 -19
- package/src/models/used-direct-login-token.ts +0 -23
- package/src/models/user-role.ts +0 -17
- package/src/models/user.ts +0 -19
- package/src/registry/email-service-registry.ts +0 -24
- package/src/routers/api.ts +0 -151
- package/src/routers/app.ts +0 -258
- package/src/routers/base.ts +0 -17
- package/src/schemas/email-token.ts +0 -91
- package/src/schemas/mnemonic.ts +0 -37
- package/src/schemas/role.ts +0 -127
- package/src/schemas/schema.ts +0 -140
- package/src/schemas/used-direct-login-token.ts +0 -38
- package/src/schemas/user-role.ts +0 -75
- package/src/schemas/user.ts +0 -202
- package/src/services/backup-code.ts +0 -316
- package/src/services/base.ts +0 -33
- package/src/services/checksum.ts +0 -161
- package/src/services/crc.ts +0 -213
- package/src/services/database-initialization.ts +0 -1479
- package/src/services/direct-login-token.ts +0 -62
- package/src/services/fec-usage-example.ts +0 -102
- package/src/services/fec.ts +0 -296
- package/src/services/jwt.ts +0 -134
- package/src/services/key-wrapping.ts +0 -434
- package/src/services/mnemonic.ts +0 -167
- package/src/services/request-user.ts +0 -62
- package/src/services/role.ts +0 -396
- package/src/services/symmetric.ts +0 -139
- package/src/services/system-user.ts +0 -82
- package/src/services/user.ts +0 -2137
- package/src/services/xor.ts +0 -34
- package/src/types.ts +0 -128
- package/src/utils.ts +0 -1022
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getSchemaMap = getSchemaMap;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const enumerations_1 = require("../enumerations");
|
|
6
|
+
const schema_collection_1 = require("../enumerations/schema-collection");
|
|
7
|
+
const email_token_1 = tslib_1.__importDefault(require("../models/email-token"));
|
|
8
|
+
const mnemonic_1 = tslib_1.__importDefault(require("../models/mnemonic"));
|
|
9
|
+
const role_1 = tslib_1.__importDefault(require("../models/role"));
|
|
10
|
+
const used_direct_login_token_1 = tslib_1.__importDefault(require("../models/used-direct-login-token"));
|
|
11
|
+
const user_1 = tslib_1.__importDefault(require("../models/user"));
|
|
12
|
+
const user_role_1 = tslib_1.__importDefault(require("../models/user-role"));
|
|
13
|
+
const email_token_2 = require("./email-token");
|
|
14
|
+
const mnemonic_2 = require("./mnemonic");
|
|
15
|
+
const role_2 = require("./role");
|
|
16
|
+
const used_direct_login_token_2 = require("./used-direct-login-token");
|
|
17
|
+
const user_2 = require("./user");
|
|
18
|
+
const user_role_2 = require("./user-role");
|
|
19
|
+
function getSchemaMap(connection, options = {}) {
|
|
20
|
+
const { schemas = {}, modelNames = {}, collections = {} } = options;
|
|
21
|
+
return {
|
|
22
|
+
EmailToken: {
|
|
23
|
+
collection: collections.EmailToken ?? schema_collection_1.SchemaCollection.EmailToken,
|
|
24
|
+
model: (0, email_token_1.default)(connection, modelNames.EmailToken ?? enumerations_1.BaseModelName.EmailToken, collections.EmailToken ?? schema_collection_1.SchemaCollection.EmailToken, schemas.EmailToken),
|
|
25
|
+
modelName: modelNames.EmailToken ?? enumerations_1.BaseModelName.EmailToken,
|
|
26
|
+
schema: schemas.EmailToken ?? email_token_2.EmailTokenSchema,
|
|
27
|
+
},
|
|
28
|
+
Mnemonic: {
|
|
29
|
+
collection: collections.Mnemonic ?? schema_collection_1.SchemaCollection.Mnemonic,
|
|
30
|
+
model: (0, mnemonic_1.default)(connection, modelNames.Mnemonic ?? enumerations_1.BaseModelName.Mnemonic, collections.Mnemonic ?? schema_collection_1.SchemaCollection.Mnemonic, schemas.Mnemonic),
|
|
31
|
+
modelName: modelNames.Mnemonic ?? enumerations_1.BaseModelName.Mnemonic,
|
|
32
|
+
schema: schemas.Mnemonic ?? mnemonic_2.MnemonicSchema,
|
|
33
|
+
},
|
|
34
|
+
Role: {
|
|
35
|
+
collection: collections.Role ?? schema_collection_1.SchemaCollection.Role,
|
|
36
|
+
model: (0, role_1.default)(connection, modelNames.Role ?? enumerations_1.BaseModelName.Role, collections.Role ?? schema_collection_1.SchemaCollection.Role, schemas.Role),
|
|
37
|
+
modelName: modelNames.Role ?? enumerations_1.BaseModelName.Role,
|
|
38
|
+
schema: schemas.Role ?? role_2.RoleSchema,
|
|
39
|
+
},
|
|
40
|
+
UsedDirectLoginToken: {
|
|
41
|
+
collection: collections.UsedDirectLoginToken ??
|
|
42
|
+
schema_collection_1.SchemaCollection.UsedDirectLoginToken,
|
|
43
|
+
model: (0, used_direct_login_token_1.default)(connection, modelNames.UsedDirectLoginToken ?? enumerations_1.BaseModelName.UsedDirectLoginToken, collections.UsedDirectLoginToken ??
|
|
44
|
+
schema_collection_1.SchemaCollection.UsedDirectLoginToken, schemas.UsedDirectLoginToken),
|
|
45
|
+
modelName: modelNames.UsedDirectLoginToken ?? enumerations_1.BaseModelName.UsedDirectLoginToken,
|
|
46
|
+
schema: schemas.UsedDirectLoginToken ?? used_direct_login_token_2.UsedDirectLoginTokenSchema,
|
|
47
|
+
},
|
|
48
|
+
User: {
|
|
49
|
+
collection: collections.User ?? schema_collection_1.SchemaCollection.User,
|
|
50
|
+
model: (0, user_1.default)(connection, modelNames.User ?? enumerations_1.BaseModelName.User, collections.User ?? schema_collection_1.SchemaCollection.User, schemas.User),
|
|
51
|
+
modelName: modelNames.User ?? enumerations_1.BaseModelName.User,
|
|
52
|
+
schema: schemas.User ?? user_2.UserSchema,
|
|
53
|
+
},
|
|
54
|
+
UserRole: {
|
|
55
|
+
collection: collections.UserRole ?? schema_collection_1.SchemaCollection.UserRole,
|
|
56
|
+
model: (0, user_role_1.default)(connection, modelNames.UserRole ?? enumerations_1.BaseModelName.UserRole, collections.UserRole ?? schema_collection_1.SchemaCollection.UserRole, schemas.UserRole),
|
|
57
|
+
modelName: modelNames.UserRole ?? enumerations_1.BaseModelName.UserRole,
|
|
58
|
+
schema: schemas.UserRole ?? user_role_2.UserRoleSchema,
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/schema.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Schema } from 'mongoose';
|
|
2
|
+
import { IUsedDirectLoginTokenDocument } from '../documents/used-direct-login-token';
|
|
3
|
+
import { BaseModelName } from '../enumerations';
|
|
4
|
+
/**
|
|
5
|
+
* Configuration options for creating a used direct login token schema
|
|
6
|
+
*/
|
|
7
|
+
export interface UsedDirectLoginTokenSchemaOptions<TModelName extends string = BaseModelName> {
|
|
8
|
+
/** Model name for user reference */
|
|
9
|
+
userModelName?: TModelName;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Factory function to create an extensible used direct login token schema
|
|
13
|
+
*/
|
|
14
|
+
export declare function createUsedDirectLoginTokenSchema<TModelName extends string = BaseModelName>(options?: UsedDirectLoginTokenSchemaOptions<TModelName>): Schema<IUsedDirectLoginTokenDocument>;
|
|
15
|
+
/**
|
|
16
|
+
* Default used direct login token schema with base configuration
|
|
17
|
+
*/
|
|
18
|
+
export declare const UsedDirectLoginTokenSchema: Schema<IUsedDirectLoginTokenDocument, import("mongoose").Model<IUsedDirectLoginTokenDocument, any, any, any, import("mongoose").Document<unknown, any, IUsedDirectLoginTokenDocument, any, {}> & import("mongoose").Document<import("mongoose").Types.ObjectId, any, any, Record<string, any>, {}> & import("dist/packages/digitaldefiance-suite-core-lib/src").IUsedDirectLoginTokenBase<import("mongoose").Types.ObjectId> & Required<{
|
|
19
|
+
_id: import("mongoose").Types.ObjectId;
|
|
20
|
+
}> & {
|
|
21
|
+
__v: number;
|
|
22
|
+
}, any>, {}, {}, {}, {}, import("mongoose").DefaultSchemaOptions, IUsedDirectLoginTokenDocument, import("mongoose").Document<unknown, {}, import("mongoose").FlatRecord<IUsedDirectLoginTokenDocument>, {}, import("mongoose").ResolveSchemaOptions<import("mongoose").DefaultSchemaOptions>> & import("mongoose").FlatRecord<IUsedDirectLoginTokenDocument> & Required<{
|
|
23
|
+
_id: import("mongoose").Types.ObjectId;
|
|
24
|
+
}> & {
|
|
25
|
+
__v: number;
|
|
26
|
+
}>;
|
|
27
|
+
//# sourceMappingURL=used-direct-login-token.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"used-direct-login-token.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/used-direct-login-token.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,6BAA6B,EAAE,MAAM,sCAAsC,CAAC;AACrF,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD;;GAEG;AACH,MAAM,WAAW,iCAAiC,CAChD,UAAU,SAAS,MAAM,GAAG,aAAa;IAEzC,oCAAoC;IACpC,aAAa,CAAC,EAAE,UAAU,CAAC;CAC5B;AAED;;GAEG;AACH,wBAAgB,gCAAgC,CAC9C,UAAU,SAAS,MAAM,GAAG,aAAa,EAEzC,OAAO,GAAE,iCAAiC,CAAC,UAAU,CAAM,GAC1D,MAAM,CAAC,6BAA6B,CAAC,CAWvC;AAED;;GAEG;AACH,eAAO,MAAM,0BAA0B;;;;;;;;EAAqC,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UsedDirectLoginTokenSchema = void 0;
|
|
4
|
+
exports.createUsedDirectLoginTokenSchema = createUsedDirectLoginTokenSchema;
|
|
5
|
+
const mongoose_1 = require("mongoose");
|
|
6
|
+
const enumerations_1 = require("../enumerations");
|
|
7
|
+
/**
|
|
8
|
+
* Factory function to create an extensible used direct login token schema
|
|
9
|
+
*/
|
|
10
|
+
function createUsedDirectLoginTokenSchema(options = {}) {
|
|
11
|
+
const { userModelName = enumerations_1.BaseModelName.User } = options;
|
|
12
|
+
const schema = new mongoose_1.Schema({
|
|
13
|
+
userId: { type: mongoose_1.Schema.Types.ObjectId, required: true, ref: userModelName },
|
|
14
|
+
token: { type: String, required: true },
|
|
15
|
+
});
|
|
16
|
+
schema.index({ userId: 1, token: 1 }, { unique: true });
|
|
17
|
+
return schema;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Default used direct login token schema with base configuration
|
|
21
|
+
*/
|
|
22
|
+
exports.UsedDirectLoginTokenSchema = createUsedDirectLoginTokenSchema();
|
|
23
|
+
//# sourceMappingURL=used-direct-login-token.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"used-direct-login-token.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/used-direct-login-token.ts"],"names":[],"mappings":";;;AAiBA,4EAeC;AAhCD,uCAAkC;AAElC,kDAAgD;AAYhD;;GAEG;AACH,SAAgB,gCAAgC,CAG9C,UAAyD,EAAE;IAE3D,MAAM,EAAE,aAAa,GAAG,4BAAa,CAAC,IAAkB,EAAE,GAAG,OAAO,CAAC;IAErE,MAAM,MAAM,GAAG,IAAI,iBAAM,CAAgC;QACvD,MAAM,EAAE,EAAE,IAAI,EAAE,iBAAM,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,EAAE,aAAa,EAAE;QAC3E,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;KACxC,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IAExD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;GAEG;AACU,QAAA,0BAA0B,GAAG,gCAAgC,EAAE,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Schema } from 'mongoose';
|
|
2
|
+
import { IUserRoleDocument } from '../documents/user-role';
|
|
3
|
+
import { BaseModelName } from '../enumerations';
|
|
4
|
+
/**
|
|
5
|
+
* Configuration options for creating a user-role schema
|
|
6
|
+
*/
|
|
7
|
+
export interface UserRoleSchemaOptions<TModelName extends string = BaseModelName> {
|
|
8
|
+
/** Model name for user reference */
|
|
9
|
+
userModelName?: TModelName;
|
|
10
|
+
/** Model name for role reference */
|
|
11
|
+
roleModelName?: TModelName;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Factory function to create an extensible user-role schema
|
|
15
|
+
*/
|
|
16
|
+
export declare function createUserRoleSchema<TModelName extends string = BaseModelName>(options?: UserRoleSchemaOptions<TModelName>): Schema<IUserRoleDocument>;
|
|
17
|
+
/**
|
|
18
|
+
* Default user-role schema with base configuration
|
|
19
|
+
*/
|
|
20
|
+
export declare const UserRoleSchema: Schema<IUserRoleDocument, import("mongoose").Model<IUserRoleDocument, any, any, any, import("mongoose").Document<unknown, any, IUserRoleDocument, any, {}> & import("mongoose").Document<import("mongoose").Types.ObjectId, any, any, Record<string, any>, {}> & import("dist/packages/digitaldefiance-suite-core-lib/src").IUserRoleBase<import("mongoose").Types.ObjectId, Date> & Required<{
|
|
21
|
+
_id: import("mongoose").Types.ObjectId;
|
|
22
|
+
}> & {
|
|
23
|
+
__v: number;
|
|
24
|
+
}, any>, {}, {}, {}, {}, import("mongoose").DefaultSchemaOptions, IUserRoleDocument, import("mongoose").Document<unknown, {}, import("mongoose").FlatRecord<IUserRoleDocument>, {}, import("mongoose").ResolveSchemaOptions<import("mongoose").DefaultSchemaOptions>> & import("mongoose").FlatRecord<IUserRoleDocument> & Required<{
|
|
25
|
+
_id: import("mongoose").Types.ObjectId;
|
|
26
|
+
}> & {
|
|
27
|
+
__v: number;
|
|
28
|
+
}>;
|
|
29
|
+
//# sourceMappingURL=user-role.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-role.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/user-role.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD;;GAEG;AACH,MAAM,WAAW,qBAAqB,CACpC,UAAU,SAAS,MAAM,GAAG,aAAa;IAEzC,oCAAoC;IACpC,aAAa,CAAC,EAAE,UAAU,CAAC;IAC3B,oCAAoC;IACpC,aAAa,CAAC,EAAE,UAAU,CAAC;CAC5B;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,UAAU,SAAS,MAAM,GAAG,aAAa,EAC5E,OAAO,GAAE,qBAAqB,CAAC,UAAU,CAAM,GAC9C,MAAM,CAAC,iBAAiB,CAAC,CAgD3B;AAED;;GAEG;AACH,eAAO,MAAM,cAAc;;;;;;;;EAAyB,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserRoleSchema = void 0;
|
|
4
|
+
exports.createUserRoleSchema = createUserRoleSchema;
|
|
5
|
+
const mongoose_1 = require("mongoose");
|
|
6
|
+
const enumerations_1 = require("../enumerations");
|
|
7
|
+
/**
|
|
8
|
+
* Factory function to create an extensible user-role schema
|
|
9
|
+
*/
|
|
10
|
+
function createUserRoleSchema(options = {}) {
|
|
11
|
+
const { userModelName = enumerations_1.BaseModelName.User, roleModelName = enumerations_1.BaseModelName.Role, } = options;
|
|
12
|
+
const schema = new mongoose_1.Schema({
|
|
13
|
+
userId: {
|
|
14
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
15
|
+
ref: userModelName,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
roleId: {
|
|
19
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
20
|
+
ref: roleModelName,
|
|
21
|
+
required: true,
|
|
22
|
+
},
|
|
23
|
+
createdBy: {
|
|
24
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
25
|
+
ref: userModelName,
|
|
26
|
+
required: true,
|
|
27
|
+
immutable: true,
|
|
28
|
+
},
|
|
29
|
+
updatedBy: {
|
|
30
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
31
|
+
ref: userModelName,
|
|
32
|
+
required: true,
|
|
33
|
+
},
|
|
34
|
+
deletedAt: {
|
|
35
|
+
type: Date,
|
|
36
|
+
optional: true,
|
|
37
|
+
},
|
|
38
|
+
deletedBy: {
|
|
39
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
40
|
+
ref: userModelName,
|
|
41
|
+
required: false,
|
|
42
|
+
optional: true,
|
|
43
|
+
},
|
|
44
|
+
}, { timestamps: true });
|
|
45
|
+
schema.index({ userId: 1, roleId: 1 }, { unique: true });
|
|
46
|
+
schema.index({ userId: 1 });
|
|
47
|
+
schema.index({ roleId: 1 });
|
|
48
|
+
return schema;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Default user-role schema with base configuration
|
|
52
|
+
*/
|
|
53
|
+
exports.UserRoleSchema = createUserRoleSchema();
|
|
54
|
+
//# sourceMappingURL=user-role.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-role.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/user-role.ts"],"names":[],"mappings":";;;AAmBA,oDAkDC;AArED,uCAAkC;AAElC,kDAAgD;AAchD;;GAEG;AACH,SAAgB,oBAAoB,CAClC,UAA6C,EAAE;IAE/C,MAAM,EACJ,aAAa,GAAG,4BAAa,CAAC,IAAkB,EAChD,aAAa,GAAG,4BAAa,CAAC,IAAkB,GACjD,GAAG,OAAO,CAAC;IAEZ,MAAM,MAAM,GAAG,IAAI,iBAAM,CACvB;QACE,MAAM,EAAE;YACN,IAAI,EAAE,iBAAM,CAAC,KAAK,CAAC,QAAQ;YAC3B,GAAG,EAAE,aAAa;YAClB,QAAQ,EAAE,IAAI;SACf;QACD,MAAM,EAAE;YACN,IAAI,EAAE,iBAAM,CAAC,KAAK,CAAC,QAAQ;YAC3B,GAAG,EAAE,aAAa;YAClB,QAAQ,EAAE,IAAI;SACf;QACD,SAAS,EAAE;YACT,IAAI,EAAE,iBAAM,CAAC,KAAK,CAAC,QAAQ;YAC3B,GAAG,EAAE,aAAa;YAClB,QAAQ,EAAE,IAAI;YACd,SAAS,EAAE,IAAI;SAChB;QACD,SAAS,EAAE;YACT,IAAI,EAAE,iBAAM,CAAC,KAAK,CAAC,QAAQ;YAC3B,GAAG,EAAE,aAAa;YAClB,QAAQ,EAAE,IAAI;SACf;QACD,SAAS,EAAE;YACT,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,IAAI;SACf;QACD,SAAS,EAAE;YACT,IAAI,EAAE,iBAAM,CAAC,KAAK,CAAC,QAAQ;YAC3B,GAAG,EAAE,aAAa;YAClB,QAAQ,EAAE,KAAK;YACf,QAAQ,EAAE,IAAI;SACf;KACF,EACD,EAAE,UAAU,EAAE,IAAI,EAAE,CACrB,CAAC;IAEF,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACzD,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;IAC5B,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;IAE5B,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;GAEG;AACU,QAAA,cAAc,GAAG,oBAAoB,EAAE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { AccountStatus } from '@digitaldefiance/suite-core-lib';
|
|
2
|
+
import { Schema } from 'mongoose';
|
|
3
|
+
import { IUserDocument } from '../documents/user';
|
|
4
|
+
import { IConstants } from '../interfaces/constants';
|
|
5
|
+
/**
|
|
6
|
+
* Create a user schema with custom or default constants
|
|
7
|
+
*/
|
|
8
|
+
export declare function createUserSchema<T extends IConstants = IConstants>(constants?: T, usernameValidationMessage?: () => string, emailValidationMessage?: () => string, timezoneValidationMessage?: () => string, supportedLanguages?: readonly string[]): Schema<IUserDocument>;
|
|
9
|
+
/**
|
|
10
|
+
* Default user schema with base configuration
|
|
11
|
+
*/
|
|
12
|
+
export declare const UserSchema: Schema<IUserDocument, import("mongoose").Model<IUserDocument, any, any, any, import("mongoose").Document<unknown, any, IUserDocument, any, {}> & import("mongoose").Document<import("mongoose").Types.ObjectId, any, any, Record<string, any>, {}> & import("@digitaldefiance/suite-core-lib").IUserBase<import("mongoose").Types.ObjectId, Date, import("@digitaldefiance/i18n-lib").DefaultLanguageCode, AccountStatus> & Required<{
|
|
13
|
+
_id: import("mongoose").Types.ObjectId;
|
|
14
|
+
}> & {
|
|
15
|
+
__v: number;
|
|
16
|
+
}, any>, {}, {}, {}, {}, import("mongoose").DefaultSchemaOptions, IUserDocument, import("mongoose").Document<unknown, {}, import("mongoose").FlatRecord<IUserDocument>, {}, import("mongoose").ResolveSchemaOptions<import("mongoose").DefaultSchemaOptions>> & import("mongoose").FlatRecord<IUserDocument> & Required<{
|
|
17
|
+
_id: import("mongoose").Types.ObjectId;
|
|
18
|
+
}> & {
|
|
19
|
+
__v: number;
|
|
20
|
+
}>;
|
|
21
|
+
//# sourceMappingURL=user.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/user.ts"],"names":[],"mappings":"AACA,OAAO,EACL,aAAa,EAId,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAGlC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,UAAU,GAAG,UAAU,EAChE,SAAS,GAAE,CAAqB,EAChC,yBAAyB,CAAC,EAAE,MAAM,MAAM,EACxC,sBAAsB,CAAC,EAAE,MAAM,MAAM,EACrC,yBAAyB,CAAC,EAAE,MAAM,MAAM,EACxC,kBAAkB,CAAC,EAAE,SAAS,MAAM,EAAE,GACrC,MAAM,CAAC,aAAa,CAAC,CA6KvB;AAED;;GAEG;AACH,eAAO,MAAM,UAAU;;;;;;;;EAAqB,CAAC"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserSchema = void 0;
|
|
4
|
+
exports.createUserSchema = createUserSchema;
|
|
5
|
+
const tslib_1 = require("tslib");
|
|
6
|
+
const i18n_lib_1 = require("@digitaldefiance/i18n-lib");
|
|
7
|
+
const suite_core_lib_1 = require("@digitaldefiance/suite-core-lib");
|
|
8
|
+
const mongoose_1 = require("mongoose");
|
|
9
|
+
const validator_1 = tslib_1.__importDefault(require("validator"));
|
|
10
|
+
const constants_1 = require("../constants");
|
|
11
|
+
const enumerations_1 = require("../enumerations");
|
|
12
|
+
/**
|
|
13
|
+
* Create a user schema with custom or default constants
|
|
14
|
+
*/
|
|
15
|
+
function createUserSchema(constants = constants_1.Constants, usernameValidationMessage, emailValidationMessage, timezoneValidationMessage, supportedLanguages) {
|
|
16
|
+
/**
|
|
17
|
+
* Schema for users
|
|
18
|
+
*/
|
|
19
|
+
return new mongoose_1.Schema({
|
|
20
|
+
/**
|
|
21
|
+
* The unique identifier for the user
|
|
22
|
+
*/
|
|
23
|
+
username: {
|
|
24
|
+
type: String,
|
|
25
|
+
required: true,
|
|
26
|
+
unique: true,
|
|
27
|
+
validate: {
|
|
28
|
+
validator: (v) => constants.UsernameRegex.test(v),
|
|
29
|
+
message: usernameValidationMessage ||
|
|
30
|
+
(() => (0, suite_core_lib_1.getSuiteCoreTranslation)(suite_core_lib_1.SuiteCoreStringKey.Validation_UsernameRegexErrorTemplate)),
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
/**
|
|
34
|
+
* The email address for the user
|
|
35
|
+
*/
|
|
36
|
+
email: {
|
|
37
|
+
type: String,
|
|
38
|
+
required: true,
|
|
39
|
+
unique: true,
|
|
40
|
+
validate: {
|
|
41
|
+
validator: (v) => validator_1.default.isEmail(v),
|
|
42
|
+
message: emailValidationMessage ||
|
|
43
|
+
((props) => (0, suite_core_lib_1.getSuiteCoreTranslation)(suite_core_lib_1.SuiteCoreStringKey.Error_InvalidEmailTemplate, { email: props.value })),
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
/**
|
|
47
|
+
* The user's public key, stored in hex format.
|
|
48
|
+
*/
|
|
49
|
+
publicKey: {
|
|
50
|
+
type: String,
|
|
51
|
+
required: true,
|
|
52
|
+
unique: true,
|
|
53
|
+
},
|
|
54
|
+
/**
|
|
55
|
+
* The timezone for the user
|
|
56
|
+
*/
|
|
57
|
+
timezone: {
|
|
58
|
+
type: String,
|
|
59
|
+
required: true,
|
|
60
|
+
default: 'UTC',
|
|
61
|
+
validate: {
|
|
62
|
+
validator: function (v) {
|
|
63
|
+
return (0, i18n_lib_1.isValidTimezone)(v);
|
|
64
|
+
},
|
|
65
|
+
message: timezoneValidationMessage ||
|
|
66
|
+
((props) => (0, suite_core_lib_1.getSuiteCoreTranslation)(suite_core_lib_1.SuiteCoreStringKey.Common_NotValidTimeZoneTemplate, { timezone: props.value })),
|
|
67
|
+
},
|
|
68
|
+
},
|
|
69
|
+
/**
|
|
70
|
+
* The language of the site for the user
|
|
71
|
+
*/
|
|
72
|
+
siteLanguage: {
|
|
73
|
+
type: String,
|
|
74
|
+
enum: supportedLanguages || Object.values(i18n_lib_1.LanguageCodes),
|
|
75
|
+
default: suite_core_lib_1.DefaultLanguageCode,
|
|
76
|
+
required: true,
|
|
77
|
+
},
|
|
78
|
+
directChallenge: {
|
|
79
|
+
type: Boolean,
|
|
80
|
+
default: false,
|
|
81
|
+
required: true,
|
|
82
|
+
},
|
|
83
|
+
/**
|
|
84
|
+
* The date the user last logged in
|
|
85
|
+
*/
|
|
86
|
+
lastLogin: { type: Date, required: false },
|
|
87
|
+
/**
|
|
88
|
+
* Whether the user has verified their email address
|
|
89
|
+
*/
|
|
90
|
+
emailVerified: { type: Boolean, default: false },
|
|
91
|
+
/**
|
|
92
|
+
* The status of the user's account
|
|
93
|
+
*/
|
|
94
|
+
accountStatus: {
|
|
95
|
+
type: String,
|
|
96
|
+
enum: Object.values(suite_core_lib_1.AccountStatus),
|
|
97
|
+
default: suite_core_lib_1.AccountStatus.PendingEmailVerification,
|
|
98
|
+
},
|
|
99
|
+
/**
|
|
100
|
+
* The user who created the user.
|
|
101
|
+
*/
|
|
102
|
+
createdBy: {
|
|
103
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
104
|
+
ref: enumerations_1.BaseModelName.User,
|
|
105
|
+
required: true,
|
|
106
|
+
immutable: true,
|
|
107
|
+
},
|
|
108
|
+
/**
|
|
109
|
+
* The user who last updated the user.
|
|
110
|
+
*/
|
|
111
|
+
updatedBy: {
|
|
112
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
113
|
+
ref: enumerations_1.BaseModelName.User,
|
|
114
|
+
optional: true,
|
|
115
|
+
},
|
|
116
|
+
/**
|
|
117
|
+
* The date/time the user was deleted.
|
|
118
|
+
*/
|
|
119
|
+
deletedAt: { type: Date, optional: true },
|
|
120
|
+
/**
|
|
121
|
+
* The user who deleted the user.
|
|
122
|
+
*/
|
|
123
|
+
deletedBy: {
|
|
124
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
125
|
+
ref: enumerations_1.BaseModelName.User,
|
|
126
|
+
optional: true,
|
|
127
|
+
},
|
|
128
|
+
/**
|
|
129
|
+
* Reference to the mnemonic document
|
|
130
|
+
*/
|
|
131
|
+
mnemonicId: {
|
|
132
|
+
type: mongoose_1.Schema.Types.ObjectId,
|
|
133
|
+
ref: enumerations_1.BaseModelName.Mnemonic,
|
|
134
|
+
required: false,
|
|
135
|
+
},
|
|
136
|
+
/**
|
|
137
|
+
* Copy of the mnemonic encrypted with the user's public key
|
|
138
|
+
*/
|
|
139
|
+
mnemonicRecovery: {
|
|
140
|
+
type: String,
|
|
141
|
+
required: false,
|
|
142
|
+
},
|
|
143
|
+
/**
|
|
144
|
+
* Password-wrapped ECIES private key (Option B)
|
|
145
|
+
*/
|
|
146
|
+
passwordWrappedPrivateKey: {
|
|
147
|
+
type: {
|
|
148
|
+
salt: { type: String, required: true },
|
|
149
|
+
iv: { type: String, required: true },
|
|
150
|
+
authTag: { type: String, required: true },
|
|
151
|
+
ciphertext: { type: String, required: true },
|
|
152
|
+
iterations: { type: Number, required: true },
|
|
153
|
+
},
|
|
154
|
+
required: false,
|
|
155
|
+
},
|
|
156
|
+
/**
|
|
157
|
+
* Array of backup codes to recover mnemonic/private key
|
|
158
|
+
*/
|
|
159
|
+
backupCodes: {
|
|
160
|
+
type: [
|
|
161
|
+
{
|
|
162
|
+
version: { type: String, required: true },
|
|
163
|
+
checksumSalt: { type: String, required: true },
|
|
164
|
+
checksum: { type: String, required: true },
|
|
165
|
+
encrypted: { type: String, required: true },
|
|
166
|
+
},
|
|
167
|
+
],
|
|
168
|
+
default: [],
|
|
169
|
+
},
|
|
170
|
+
}, { timestamps: true });
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Default user schema with base configuration
|
|
174
|
+
*/
|
|
175
|
+
exports.UserSchema = createUserSchema();
|
|
176
|
+
//# sourceMappingURL=user.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/schemas/user.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { SecureString } from '@digitaldefiance/ecies-lib';
|
|
2
|
+
import { Member as BackendMember, ECIESService } from '@digitaldefiance/node-ecies-lib';
|
|
3
|
+
import { IBackupCode, ITokenRole } from '@digitaldefiance/suite-core-lib';
|
|
4
|
+
import { ClientSession, Types } from 'mongoose';
|
|
5
|
+
import { IBaseDocument, IUserDocument } from '../documents';
|
|
6
|
+
import { IApplication } from '../interfaces/application';
|
|
7
|
+
import { BaseService } from './base';
|
|
8
|
+
import { KeyWrappingService } from './index';
|
|
9
|
+
import { RoleService } from './role';
|
|
10
|
+
import { Environment } from '../environment';
|
|
11
|
+
import { IConstants } from '../interfaces';
|
|
12
|
+
/**
|
|
13
|
+
* Service handling generation, storage, validation, consumption, and recovery using backup codes.
|
|
14
|
+
*
|
|
15
|
+
* v1 scheme:
|
|
16
|
+
* - Code: 32 lowercase alphanumerics (a–z0–9), displayed as 8 groups of 4: xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx
|
|
17
|
+
* - Checksum/tag: HKDF-SHA256(codeUtf8, salt, "backup-checksum") → 32 bytes (stored as hex)
|
|
18
|
+
* - KDF for encryption key: Argon2id(codeUtf8, salt) → 32 bytes
|
|
19
|
+
* - Encryption: SymmetricService AEAD (encryptedData must embed IV + authTag + ciphertext)
|
|
20
|
+
* - Wrapping: AEAD blob wrapped with system user's asymmetric key (ECIES)
|
|
21
|
+
*/
|
|
22
|
+
export declare class BackupCodeService<I = Types.ObjectId, D extends Date = Date, TTokenRole extends ITokenRole<I, D> = ITokenRole<I, D>, TApplication extends IApplication<any, Types.ObjectId, IBaseDocument<any, Types.ObjectId>, Environment, IConstants> = IApplication<any, Types.ObjectId, IBaseDocument<any, Types.ObjectId>, Environment, IConstants>> extends BaseService {
|
|
23
|
+
private readonly eciesService;
|
|
24
|
+
private systemUser?;
|
|
25
|
+
private readonly keyWrappingService;
|
|
26
|
+
private readonly roleService;
|
|
27
|
+
/**
|
|
28
|
+
* Construct a BackupCodeService.
|
|
29
|
+
*/
|
|
30
|
+
constructor(application: TApplication, eciesService: ECIESService, keyWrappingService: KeyWrappingService, roleService: RoleService<I, D, TTokenRole>);
|
|
31
|
+
/**
|
|
32
|
+
* Get the lazily-initialized system user for key wrapping/unwrapping.
|
|
33
|
+
*/
|
|
34
|
+
private getSystemUser;
|
|
35
|
+
/**
|
|
36
|
+
* Forcibly set the system user (for database initialization)
|
|
37
|
+
* @param user
|
|
38
|
+
*/
|
|
39
|
+
setSystemUser(user: BackendMember): void;
|
|
40
|
+
/**
|
|
41
|
+
* v1: Consume (validate and remove) a backup code via constant-time checksum match.
|
|
42
|
+
*/
|
|
43
|
+
useBackupCodeV1(encryptedBackupCodes: Array<IBackupCode>, backupCode: string): {
|
|
44
|
+
newCodesArray: Array<IBackupCode>;
|
|
45
|
+
code: IBackupCode;
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Consume a backup code by first detecting the version and then dispatching to the appropriate handler.
|
|
49
|
+
*/
|
|
50
|
+
useBackupCode(encryptedBackupCodes: Array<IBackupCode>, backupCode: string): {
|
|
51
|
+
newCodesArray: Array<IBackupCode>;
|
|
52
|
+
code: IBackupCode;
|
|
53
|
+
};
|
|
54
|
+
/**
|
|
55
|
+
* v1: Recover a user's private key using a backup code.
|
|
56
|
+
*/
|
|
57
|
+
recoverKeyWithBackupCodeV1(userDoc: IUserDocument, backupCode: string, newPassword?: SecureString, session?: ClientSession): Promise<{
|
|
58
|
+
userDoc: IUserDocument;
|
|
59
|
+
user: BackendMember;
|
|
60
|
+
codeCount: number;
|
|
61
|
+
}>;
|
|
62
|
+
/**
|
|
63
|
+
* Recover a user's private key using a backup code (version-dispatched).
|
|
64
|
+
*/
|
|
65
|
+
recoverKeyWithBackupCode(userDoc: IUserDocument, backupCode: string, newPassword?: SecureString, session?: ClientSession): Promise<{
|
|
66
|
+
userDoc: IUserDocument;
|
|
67
|
+
user: BackendMember;
|
|
68
|
+
codeCount: number;
|
|
69
|
+
}>;
|
|
70
|
+
/**
|
|
71
|
+
* Rewrap system-wrapped AEAD blobs from old system key to new one without touching inner AEAD.
|
|
72
|
+
*/
|
|
73
|
+
rewrapAllUsersBackupCodes(fetchBatch: (afterId?: string, limit?: number) => Promise<IUserDocument[]>, saveUser: (user: IUserDocument) => Promise<void>, oldSystem: BackendMember, newSystem: BackendMember, options?: {
|
|
74
|
+
batchSize?: number;
|
|
75
|
+
onProgress?: (count: number) => void;
|
|
76
|
+
}): Promise<number>;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=backup-code.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backup-code.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-express-suite/src/services/backup-code.ts"],"names":[],"mappings":"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"}
|