mongodb-dynamic-api 2.3.17 → 2.4.1
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/CHANGELOG.md +9 -0
- package/package.json +5 -2
- package/src/adapters/socket-adapter.d.ts +8 -0
- package/src/adapters/socket-adapter.js +11 -0
- package/src/adapters/socket-adapter.js.map +1 -0
- package/src/builders/route-decorators/auth-decorators.builder.d.ts +4 -4
- package/src/builders/route-decorators/auth-decorators.builder.js +9 -6
- package/src/builders/route-decorators/auth-decorators.builder.js.map +1 -1
- package/src/dtos/index.d.ts +1 -1
- package/src/dtos/index.js +1 -1
- package/src/dtos/index.js.map +1 -1
- package/src/dtos/many-entity.query.d.ts +3 -0
- package/src/dtos/{delete-many-entity.query.js → many-entity.query.js} +5 -5
- package/src/dtos/many-entity.query.js.map +1 -0
- package/src/dynamic-api.module.d.ts +2 -2
- package/src/dynamic-api.module.js +10 -7
- package/src/dynamic-api.module.js.map +1 -1
- package/src/filters/ws-exception/dynamic-api-ws-exception.filter.d.ts +5 -0
- package/src/filters/ws-exception/dynamic-api-ws-exception.filter.js +29 -0
- package/src/filters/ws-exception/dynamic-api-ws-exception.filter.js.map +1 -0
- package/src/gateways/base.gateway.d.ts +10 -0
- package/src/gateways/base.gateway.js +45 -0
- package/src/gateways/base.gateway.js.map +1 -0
- package/src/gateways/index.d.ts +1 -0
- package/src/gateways/index.js +18 -0
- package/src/gateways/index.js.map +1 -0
- package/src/helpers/controller-mixin.helper.js +2 -20
- package/src/helpers/controller-mixin.helper.js.map +1 -1
- package/src/helpers/format.helper.d.ts +7 -4
- package/src/helpers/format.helper.js +12 -4
- package/src/helpers/format.helper.js.map +1 -1
- package/src/helpers/index.d.ts +1 -0
- package/src/helpers/index.js +1 -0
- package/src/helpers/index.js.map +1 -1
- package/src/helpers/socket-config.helper.d.ts +5 -0
- package/src/helpers/socket-config.helper.js +30 -0
- package/src/helpers/socket-config.helper.js.map +1 -0
- package/src/index.d.ts +1 -0
- package/src/index.js +1 -0
- package/src/index.js.map +1 -1
- package/src/interfaces/dynamic-api-global-state.interface.d.ts +3 -0
- package/src/interfaces/dynamic-api-options.interface.d.ts +3 -0
- package/src/interfaces/dynamic-api-options.interface.js.map +1 -1
- package/src/interfaces/dynamic-api-policy-handler.interface.d.ts +2 -2
- package/src/interfaces/dynamic-api-route-config.interface.d.ts +2 -0
- package/src/interfaces/dynamic-api-web-socket.interface.d.ts +13 -0
- package/src/interfaces/dynamic-api-web-socket.interface.js +3 -0
- package/src/interfaces/dynamic-api-web-socket.interface.js.map +1 -0
- package/src/interfaces/index.d.ts +1 -0
- package/src/interfaces/index.js +1 -0
- package/src/interfaces/index.js.map +1 -1
- package/src/modules/auth/auth.helper.d.ts +7 -5
- package/src/modules/auth/auth.helper.js +29 -5
- package/src/modules/auth/auth.helper.js.map +1 -1
- package/src/modules/auth/auth.module.js +26 -8
- package/src/modules/auth/auth.module.js.map +1 -1
- package/src/modules/auth/guards/index.d.ts +4 -2
- package/src/modules/auth/guards/index.js +4 -2
- package/src/modules/auth/guards/index.js.map +1 -1
- package/src/modules/auth/guards/jwt-auth/jwt-auth.guard.js.map +1 -0
- package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.d.ts +5 -0
- package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.js +57 -0
- package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.js.map +1 -0
- package/src/modules/auth/guards/local-auth/local-auth.guard.js.map +1 -0
- package/src/modules/auth/guards/reset-password/reset-password.guard.d.ts +6 -0
- package/src/modules/auth/guards/reset-password/reset-password.guard.js +30 -0
- package/src/modules/auth/guards/reset-password/reset-password.guard.js.map +1 -0
- package/src/modules/auth/interfaces/auth-controller.interface.d.ts +3 -0
- package/src/modules/auth/interfaces/auth-gateway.interface.d.ts +16 -0
- package/src/modules/auth/interfaces/auth-gateway.interface.js +3 -0
- package/src/modules/auth/interfaces/auth-gateway.interface.js.map +1 -0
- package/src/modules/auth/interfaces/auth-options.interface.d.ts +14 -7
- package/src/modules/auth/interfaces/auth-service.interface.d.ts +1 -0
- package/src/modules/auth/interfaces/index.d.ts +1 -0
- package/src/modules/auth/interfaces/index.js +1 -0
- package/src/modules/auth/interfaces/index.js.map +1 -1
- package/src/modules/auth/mixins/auth-controller.mixin.d.ts +2 -2
- package/src/modules/auth/mixins/auth-controller.mixin.js +31 -5
- package/src/modules/auth/mixins/auth-controller.mixin.js.map +1 -1
- package/src/modules/auth/mixins/auth-gateway.mixin.d.ts +5 -0
- package/src/modules/auth/mixins/auth-gateway.mixin.js +191 -0
- package/src/modules/auth/mixins/auth-gateway.mixin.js.map +1 -0
- package/src/modules/auth/mixins/auth-policies-guard.mixin.d.ts +6 -0
- package/src/modules/auth/mixins/auth-policies-guard.mixin.js +52 -0
- package/src/modules/auth/mixins/auth-policies-guard.mixin.js.map +1 -0
- package/src/modules/auth/mixins/index.d.ts +2 -1
- package/src/modules/auth/mixins/index.js +2 -1
- package/src/modules/auth/mixins/index.js.map +1 -1
- package/src/modules/auth/services/base-auth.service.d.ts +2 -0
- package/src/modules/auth/services/base-auth.service.js +17 -1
- package/src/modules/auth/services/base-auth.service.js.map +1 -1
- package/src/routes/create-many/create-many-body-dto.mixin.d.ts +7 -0
- package/src/routes/create-many/create-many-body-dto.mixin.js +30 -0
- package/src/routes/create-many/create-many-body-dto.mixin.js.map +1 -0
- package/src/routes/create-many/create-many-controller.interface.d.ts +5 -4
- package/src/routes/create-many/create-many-gateway.interface.d.ts +10 -0
- package/src/routes/create-many/create-many-gateway.interface.js +3 -0
- package/src/routes/create-many/create-many-gateway.interface.js.map +1 -0
- package/src/routes/create-many/create-many-gateway.mixin.d.ts +6 -0
- package/src/routes/create-many/create-many-gateway.mixin.js +60 -0
- package/src/routes/create-many/create-many-gateway.mixin.js.map +1 -0
- package/src/routes/create-many/create-many.helper.d.ts +4 -2
- package/src/routes/create-many/create-many.helper.js +21 -1
- package/src/routes/create-many/create-many.helper.js.map +1 -1
- package/src/routes/create-many/create-many.module.d.ts +2 -2
- package/src/routes/create-many/create-many.module.js +12 -2
- package/src/routes/create-many/create-many.module.js.map +1 -1
- package/src/routes/create-many/index.d.ts +3 -0
- package/src/routes/create-many/index.js +3 -0
- package/src/routes/create-many/index.js.map +1 -1
- package/src/routes/create-one/create-one-gateway.interface.d.ts +9 -0
- package/src/routes/create-one/create-one-gateway.interface.js +3 -0
- package/src/routes/create-one/create-one-gateway.interface.js.map +1 -0
- package/src/routes/create-one/create-one-gateway.mixin.d.ts +6 -0
- package/src/routes/create-one/create-one-gateway.mixin.js +61 -0
- package/src/routes/create-one/create-one-gateway.mixin.js.map +1 -0
- package/src/routes/create-one/create-one.helper.d.ts +4 -2
- package/src/routes/create-one/create-one.helper.js +21 -1
- package/src/routes/create-one/create-one.helper.js.map +1 -1
- package/src/routes/create-one/create-one.module.d.ts +2 -2
- package/src/routes/create-one/create-one.module.js +12 -2
- package/src/routes/create-one/create-one.module.js.map +1 -1
- package/src/routes/create-one/index.d.ts +2 -0
- package/src/routes/create-one/index.js +2 -0
- package/src/routes/create-one/index.js.map +1 -1
- package/src/routes/delete-many/delete-many-controller.interface.d.ts +2 -2
- package/src/routes/delete-many/delete-many-controller.mixin.js +1 -1
- package/src/routes/delete-many/delete-many-controller.mixin.js.map +1 -1
- package/src/routes/delete-many/delete-many-gateway.interface.d.ts +10 -0
- package/src/routes/delete-many/delete-many-gateway.interface.js +3 -0
- package/src/routes/delete-many/delete-many-gateway.interface.js.map +1 -0
- package/src/routes/delete-many/delete-many-gateway.mixin.d.ts +6 -0
- package/src/routes/delete-many/delete-many-gateway.mixin.js +60 -0
- package/src/routes/delete-many/delete-many-gateway.mixin.js.map +1 -0
- package/src/routes/delete-many/delete-many.helper.d.ts +4 -2
- package/src/routes/delete-many/delete-many.helper.js +21 -1
- package/src/routes/delete-many/delete-many.helper.js.map +1 -1
- package/src/routes/delete-many/delete-many.module.d.ts +2 -2
- package/src/routes/delete-many/delete-many.module.js +12 -2
- package/src/routes/delete-many/delete-many.module.js.map +1 -1
- package/src/routes/delete-many/index.d.ts +2 -0
- package/src/routes/delete-many/index.js +2 -0
- package/src/routes/delete-many/index.js.map +1 -1
- package/src/routes/delete-one/delete-one-gateway.interface.d.ts +10 -0
- package/src/routes/delete-one/delete-one-gateway.interface.js +3 -0
- package/src/routes/delete-one/delete-one-gateway.interface.js.map +1 -0
- package/src/routes/delete-one/delete-one-gateway.mixin.d.ts +6 -0
- package/src/routes/delete-one/delete-one-gateway.mixin.js +60 -0
- package/src/routes/delete-one/delete-one-gateway.mixin.js.map +1 -0
- package/src/routes/delete-one/delete-one.helper.d.ts +4 -2
- package/src/routes/delete-one/delete-one.helper.js +21 -1
- package/src/routes/delete-one/delete-one.helper.js.map +1 -1
- package/src/routes/delete-one/delete-one.module.d.ts +2 -2
- package/src/routes/delete-one/delete-one.module.js +12 -2
- package/src/routes/delete-one/delete-one.module.js.map +1 -1
- package/src/routes/delete-one/index.d.ts +2 -0
- package/src/routes/delete-one/index.js +2 -0
- package/src/routes/delete-one/index.js.map +1 -1
- package/src/routes/duplicate-many/base-duplicate-many.service.js +1 -1
- package/src/routes/duplicate-many/base-duplicate-many.service.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many-gateway.interface.d.ts +10 -0
- package/src/routes/duplicate-many/duplicate-many-gateway.interface.js +3 -0
- package/src/routes/duplicate-many/duplicate-many-gateway.interface.js.map +1 -0
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.d.ts +6 -0
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js +60 -0
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js.map +1 -0
- package/src/routes/duplicate-many/duplicate-many.helper.d.ts +4 -2
- package/src/routes/duplicate-many/duplicate-many.helper.js +21 -1
- package/src/routes/duplicate-many/duplicate-many.helper.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many.module.d.ts +2 -2
- package/src/routes/duplicate-many/duplicate-many.module.js +12 -2
- package/src/routes/duplicate-many/duplicate-many.module.js.map +1 -1
- package/src/routes/duplicate-many/index.d.ts +2 -0
- package/src/routes/duplicate-many/index.js +2 -0
- package/src/routes/duplicate-many/index.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one-gateway.interface.d.ts +10 -0
- package/src/routes/duplicate-one/duplicate-one-gateway.interface.js +3 -0
- package/src/routes/duplicate-one/duplicate-one-gateway.interface.js.map +1 -0
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.d.ts +6 -0
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js +60 -0
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js.map +1 -0
- package/src/routes/duplicate-one/duplicate-one.helper.d.ts +4 -2
- package/src/routes/duplicate-one/duplicate-one.helper.js +21 -1
- package/src/routes/duplicate-one/duplicate-one.helper.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one.module.d.ts +2 -2
- package/src/routes/duplicate-one/duplicate-one.module.js +12 -2
- package/src/routes/duplicate-one/duplicate-one.module.js.map +1 -1
- package/src/routes/duplicate-one/index.d.ts +2 -0
- package/src/routes/duplicate-one/index.js +2 -0
- package/src/routes/duplicate-one/index.js.map +1 -1
- package/src/routes/get-many/get-many-gateway.interface.d.ts +9 -0
- package/src/routes/get-many/get-many-gateway.interface.js +3 -0
- package/src/routes/get-many/get-many-gateway.interface.js.map +1 -0
- package/src/routes/get-many/get-many-gateway.mixin.d.ts +6 -0
- package/src/routes/get-many/get-many-gateway.mixin.js +56 -0
- package/src/routes/get-many/get-many-gateway.mixin.js.map +1 -0
- package/src/routes/get-many/get-many.helper.d.ts +4 -2
- package/src/routes/get-many/get-many.helper.js +21 -1
- package/src/routes/get-many/get-many.helper.js.map +1 -1
- package/src/routes/get-many/get-many.module.d.ts +2 -2
- package/src/routes/get-many/get-many.module.js +12 -2
- package/src/routes/get-many/get-many.module.js.map +1 -1
- package/src/routes/get-many/index.d.ts +2 -0
- package/src/routes/get-many/index.js +2 -0
- package/src/routes/get-many/index.js.map +1 -1
- package/src/routes/get-one/get-one-gateway.interface.d.ts +10 -0
- package/src/routes/get-one/get-one-gateway.interface.js +3 -0
- package/src/routes/get-one/get-one-gateway.interface.js.map +1 -0
- package/src/routes/get-one/get-one-gateway.mixin.d.ts +6 -0
- package/src/routes/get-one/get-one-gateway.mixin.js +60 -0
- package/src/routes/get-one/get-one-gateway.mixin.js.map +1 -0
- package/src/routes/get-one/get-one.helper.d.ts +4 -2
- package/src/routes/get-one/get-one.helper.js +21 -1
- package/src/routes/get-one/get-one.helper.js.map +1 -1
- package/src/routes/get-one/get-one.module.d.ts +2 -2
- package/src/routes/get-one/get-one.module.js +12 -2
- package/src/routes/get-one/get-one.module.js.map +1 -1
- package/src/routes/get-one/index.d.ts +2 -0
- package/src/routes/get-one/index.js +2 -0
- package/src/routes/get-one/index.js.map +1 -1
- package/src/routes/replace-one/index.d.ts +2 -0
- package/src/routes/replace-one/index.js +2 -0
- package/src/routes/replace-one/index.js.map +1 -1
- package/src/routes/replace-one/replace-one-gateway.interface.d.ts +10 -0
- package/src/routes/replace-one/replace-one-gateway.interface.js +3 -0
- package/src/routes/replace-one/replace-one-gateway.interface.js.map +1 -0
- package/src/routes/replace-one/replace-one-gateway.mixin.d.ts +6 -0
- package/src/routes/replace-one/replace-one-gateway.mixin.js +60 -0
- package/src/routes/replace-one/replace-one-gateway.mixin.js.map +1 -0
- package/src/routes/replace-one/replace-one.helper.d.ts +4 -2
- package/src/routes/replace-one/replace-one.helper.js +21 -1
- package/src/routes/replace-one/replace-one.helper.js.map +1 -1
- package/src/routes/replace-one/replace-one.module.d.ts +2 -2
- package/src/routes/replace-one/replace-one.module.js +12 -2
- package/src/routes/replace-one/replace-one.module.js.map +1 -1
- package/src/routes/update-many/index.d.ts +2 -0
- package/src/routes/update-many/index.js +2 -0
- package/src/routes/update-many/index.js.map +1 -1
- package/src/routes/update-many/update-many-gateway.interface.d.ts +10 -0
- package/src/routes/update-many/update-many-gateway.interface.js +3 -0
- package/src/routes/update-many/update-many-gateway.interface.js.map +1 -0
- package/src/routes/update-many/update-many-gateway.mixin.d.ts +6 -0
- package/src/routes/update-many/update-many-gateway.mixin.js +63 -0
- package/src/routes/update-many/update-many-gateway.mixin.js.map +1 -0
- package/src/routes/update-many/update-many.helper.d.ts +4 -2
- package/src/routes/update-many/update-many.helper.js +21 -1
- package/src/routes/update-many/update-many.helper.js.map +1 -1
- package/src/routes/update-many/update-many.module.d.ts +2 -2
- package/src/routes/update-many/update-many.module.js +12 -2
- package/src/routes/update-many/update-many.module.js.map +1 -1
- package/src/routes/update-one/update-one-gateway.interface.d.ts +10 -0
- package/src/routes/update-one/update-one-gateway.interface.js +3 -0
- package/src/routes/update-one/update-one-gateway.interface.js.map +1 -0
- package/src/routes/update-one/update-one-gateway.mixin.d.ts +6 -0
- package/src/routes/update-one/update-one-gateway.mixin.js +60 -0
- package/src/routes/update-one/update-one-gateway.mixin.js.map +1 -0
- package/src/routes/update-one/update-one.helper.d.ts +4 -2
- package/src/routes/update-one/update-one.helper.js +21 -1
- package/src/routes/update-one/update-one.helper.js.map +1 -1
- package/src/routes/update-one/update-one.module.d.ts +2 -2
- package/src/routes/update-one/update-one.module.js +12 -2
- package/src/routes/update-one/update-one.module.js.map +1 -1
- package/src/services/base/base.service.d.ts +1 -0
- package/src/services/base/base.service.js +5 -0
- package/src/services/base/base.service.js.map +1 -1
- package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.js +1 -0
- package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.js.map +1 -1
- package/src/version.json +1 -1
- package/test/dynamic-api-for-root.e2e-spec.js +976 -641
- package/test/dynamic-api-for-root.e2e-spec.js.map +1 -1
- package/test/e2e.setup.d.ts +16 -1
- package/test/e2e.setup.js +62 -7
- package/test/e2e.setup.js.map +1 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/src/dtos/delete-many-entity.query.d.ts +0 -3
- package/src/dtos/delete-many-entity.query.js.map +0 -1
- package/src/modules/auth/guards/jwt-auth.guard.js.map +0 -1
- package/src/modules/auth/guards/local-auth.guard.js.map +0 -1
- package/src/modules/auth/mixins/auth-register-policies-guard.mixin.d.ts +0 -5
- package/src/modules/auth/mixins/auth-register-policies-guard.mixin.js +0 -31
- package/src/modules/auth/mixins/auth-register-policies-guard.mixin.js.map +0 -1
- /package/src/modules/auth/guards/{jwt-auth.guard.d.ts → jwt-auth/jwt-auth.guard.d.ts} +0 -0
- /package/src/modules/auth/guards/{jwt-auth.guard.js → jwt-auth/jwt-auth.guard.js} +0 -0
- /package/src/modules/auth/guards/{local-auth.guard.d.ts → local-auth/local-auth.guard.d.ts} +0 -0
- /package/src/modules/auth/guards/{local-auth.guard.js → local-auth/local-auth.guard.js} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/interfaces/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8DAA4C;AAC5C,2DAAyC;AACzC,2DAAyC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/interfaces/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8DAA4C;AAC5C,2DAAyC;AACzC,2DAAyC;AACzC,2DAAyC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { BaseEntity } from '../../../models';
|
|
3
|
-
import { AuthControllerConstructor, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions } from '../interfaces';
|
|
4
|
-
declare function AuthControllerMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, loginField: keyof Entity, passwordField: keyof Entity, additionalRequestFields?: (keyof Entity)[], { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, }?: DynamicApiRegisterOptions<Entity>, resetPasswordOptions?: DynamicApiResetPasswordOptions<Entity>): AuthControllerConstructor<Entity>;
|
|
3
|
+
import { AuthControllerConstructor, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions, DynamicApiUpdateAccountOptions } from '../interfaces';
|
|
4
|
+
declare function AuthControllerMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, loginField: keyof Entity, passwordField: keyof Entity, additionalRequestFields?: (keyof Entity)[], { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, }?: DynamicApiRegisterOptions<Entity>, resetPasswordOptions?: DynamicApiResetPasswordOptions<Entity>, updateAccountOptions?: DynamicApiUpdateAccountOptions<Entity>): AuthControllerConstructor<Entity>;
|
|
5
5
|
export { AuthControllerMixin };
|
|
@@ -18,11 +18,12 @@ const swagger_1 = require("@nestjs/swagger");
|
|
|
18
18
|
const builders_1 = require("../../../builders");
|
|
19
19
|
const decorators_1 = require("../../../decorators");
|
|
20
20
|
const helpers_1 = require("../../../helpers");
|
|
21
|
+
const mixins_1 = require("../../../mixins");
|
|
21
22
|
const change_password_dto_1 = require("../dtos/change-password.dto");
|
|
22
23
|
const reset_password_dto_1 = require("../dtos/reset-password.dto");
|
|
23
24
|
const guards_1 = require("../guards");
|
|
24
|
-
const
|
|
25
|
-
function AuthControllerMixin(userEntity, loginField, passwordField, additionalRequestFields = [], { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, } = {}, resetPasswordOptions) {
|
|
25
|
+
const auth_policies_guard_mixin_1 = require("./auth-policies-guard.mixin");
|
|
26
|
+
function AuthControllerMixin(userEntity, loginField, passwordField, additionalRequestFields = [], { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, } = {}, resetPasswordOptions = {}, updateAccountOptions = {}) {
|
|
26
27
|
var _a;
|
|
27
28
|
if (!loginField || !passwordField) {
|
|
28
29
|
throw new Error('Login and password fields are required');
|
|
@@ -58,6 +59,12 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
58
59
|
? (0, swagger_1.IntersectionType)(AuthBodyPasswordFieldDto, (0, swagger_1.PartialType)((0, swagger_1.PickType)(userEntity, additionalOptionalFields)))
|
|
59
60
|
: AuthBodyPasswordFieldDto) {
|
|
60
61
|
}
|
|
62
|
+
class AuthUpdateAccountDto extends (0, mixins_1.EntityBodyMixin)(userEntity, true, [
|
|
63
|
+
loginField,
|
|
64
|
+
passwordField,
|
|
65
|
+
...updateAccountOptions.additionalFieldsToExclude ?? [],
|
|
66
|
+
]) {
|
|
67
|
+
}
|
|
61
68
|
class AuthPresenter {
|
|
62
69
|
}
|
|
63
70
|
__decorate([
|
|
@@ -66,9 +73,12 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
66
73
|
], AuthPresenter.prototype, "accessToken", void 0);
|
|
67
74
|
class AuthUserPresenter extends (0, swagger_1.PickType)(userEntity, ['id', loginField, ...additionalRequestFields]) {
|
|
68
75
|
}
|
|
69
|
-
class AuthRegisterPoliciesGuard extends (0,
|
|
76
|
+
class AuthRegisterPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthPoliciesGuardMixin)(userEntity, registerAbilityPredicate) {
|
|
77
|
+
}
|
|
78
|
+
const authRegisterDecorators = new builders_1.AuthDecoratorsBuilder(registerProtected, AuthRegisterPoliciesGuard);
|
|
79
|
+
class AuthUpdateAccountPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthPoliciesGuardMixin)(userEntity, updateAccountOptions.abilityPredicate) {
|
|
70
80
|
}
|
|
71
|
-
const
|
|
81
|
+
const authUpdateAccountDecorators = new builders_1.AuthDecoratorsBuilder(true, AuthUpdateAccountPoliciesGuard);
|
|
72
82
|
class BaseAuthController {
|
|
73
83
|
constructor(service) {
|
|
74
84
|
this.service = service;
|
|
@@ -76,6 +86,9 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
76
86
|
getAccount(req) {
|
|
77
87
|
return this.service.getAccount(req.user);
|
|
78
88
|
}
|
|
89
|
+
updateAccount(req, body) {
|
|
90
|
+
return this.service.updateAccount(req.user, body);
|
|
91
|
+
}
|
|
79
92
|
login(req, _) {
|
|
80
93
|
return this.service.login(req.user);
|
|
81
94
|
}
|
|
@@ -100,6 +113,17 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
100
113
|
__metadata("design:paramtypes", [Object]),
|
|
101
114
|
__metadata("design:returntype", void 0)
|
|
102
115
|
], BaseAuthController.prototype, "getAccount", null);
|
|
116
|
+
__decorate([
|
|
117
|
+
(0, helpers_1.RouteDecoratorsHelper)(authUpdateAccountDecorators),
|
|
118
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.OK),
|
|
119
|
+
(0, swagger_1.ApiOkResponse)({ type: AuthUserPresenter }),
|
|
120
|
+
(0, common_1.Patch)('account'),
|
|
121
|
+
__param(0, (0, common_1.Request)()),
|
|
122
|
+
__param(1, (0, common_1.Body)()),
|
|
123
|
+
__metadata("design:type", Function),
|
|
124
|
+
__metadata("design:paramtypes", [Object, AuthUpdateAccountDto]),
|
|
125
|
+
__metadata("design:returntype", void 0)
|
|
126
|
+
], BaseAuthController.prototype, "updateAccount", null);
|
|
103
127
|
__decorate([
|
|
104
128
|
(0, decorators_1.Public)(),
|
|
105
129
|
(0, common_1.UseGuards)(guards_1.LocalAuthGuard),
|
|
@@ -113,7 +137,7 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
113
137
|
__metadata("design:returntype", void 0)
|
|
114
138
|
], BaseAuthController.prototype, "login", null);
|
|
115
139
|
__decorate([
|
|
116
|
-
(0, helpers_1.RouteDecoratorsHelper)(
|
|
140
|
+
(0, helpers_1.RouteDecoratorsHelper)(authRegisterDecorators),
|
|
117
141
|
(0, common_1.HttpCode)(common_1.HttpStatus.CREATED),
|
|
118
142
|
(0, swagger_1.ApiOkResponse)({ type: AuthPresenter }),
|
|
119
143
|
(0, common_1.Post)('register'),
|
|
@@ -124,6 +148,7 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
124
148
|
], BaseAuthController.prototype, "register", null);
|
|
125
149
|
__decorate([
|
|
126
150
|
(0, decorators_1.ApiEndpointVisibility)(!!resetPasswordOptions, (0, decorators_1.Public)()),
|
|
151
|
+
(0, common_1.UseGuards)(new guards_1.ResetPasswordGuard(!!resetPasswordOptions.emailField)),
|
|
127
152
|
(0, common_1.HttpCode)(common_1.HttpStatus.NO_CONTENT),
|
|
128
153
|
(0, common_1.Post)('reset-password'),
|
|
129
154
|
__param(0, (0, common_1.Body)()),
|
|
@@ -133,6 +158,7 @@ function AuthControllerMixin(userEntity, loginField, passwordField, additionalRe
|
|
|
133
158
|
], BaseAuthController.prototype, "resetPassword", null);
|
|
134
159
|
__decorate([
|
|
135
160
|
(0, decorators_1.ApiEndpointVisibility)(!!resetPasswordOptions, (0, decorators_1.Public)()),
|
|
161
|
+
(0, common_1.UseGuards)(new guards_1.ResetPasswordGuard(!!resetPasswordOptions.emailField)),
|
|
136
162
|
(0, common_1.HttpCode)(common_1.HttpStatus.NO_CONTENT),
|
|
137
163
|
(0, common_1.Patch)('change-password'),
|
|
138
164
|
__param(0, (0, common_1.Body)()),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-controller.mixin.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/auth-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAwG;AACxG,6CAAqH;AACrH,gDAA0D;AAC1D,oDAAoE;AACpE,8CAAyD;
|
|
1
|
+
{"version":3,"file":"auth-controller.mixin.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/auth-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Type } from '@nestjs/common';
|
|
2
|
+
import { BaseEntity } from '../../../models';
|
|
3
|
+
import { AuthGatewayConstructor, DynamicApiLoginOptions, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions, DynamicApiUpdateAccountOptions } from '../interfaces';
|
|
4
|
+
declare function AuthGatewayMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, { loginField, passwordField, abilityPredicate: loginAbilityPredicate, }: DynamicApiLoginOptions<Entity>, { additionalFields: additionalSocketRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, }?: DynamicApiRegisterOptions<Entity>, resetPasswordOptions?: DynamicApiResetPasswordOptions<Entity>, updateAccountOptions?: DynamicApiUpdateAccountOptions<Entity>): AuthGatewayConstructor<Entity>;
|
|
5
|
+
export { AuthGatewayMixin };
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AuthGatewayMixin = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const websockets_1 = require("@nestjs/websockets");
|
|
19
|
+
const lodash_1 = require("lodash");
|
|
20
|
+
const gateways_1 = require("../../../gateways");
|
|
21
|
+
const helpers_1 = require("../../../helpers");
|
|
22
|
+
const mixins_1 = require("../../../mixins");
|
|
23
|
+
const change_password_dto_1 = require("../dtos/change-password.dto");
|
|
24
|
+
const reset_password_dto_1 = require("../dtos/reset-password.dto");
|
|
25
|
+
const guards_1 = require("../guards");
|
|
26
|
+
const auth_policies_guard_mixin_1 = require("./auth-policies-guard.mixin");
|
|
27
|
+
function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredicate: loginAbilityPredicate, }, { additionalFields: additionalSocketRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, } = {}, resetPasswordOptions = {}, updateAccountOptions = {}) {
|
|
28
|
+
var _a;
|
|
29
|
+
class AuthSocketBodyPasswordFieldDto extends (0, swagger_1.PickType)(userEntity, [passwordField]) {
|
|
30
|
+
}
|
|
31
|
+
_a = passwordField;
|
|
32
|
+
__decorate([
|
|
33
|
+
(0, swagger_1.ApiProperty)(),
|
|
34
|
+
__metadata("design:type", String)
|
|
35
|
+
], AuthSocketBodyPasswordFieldDto.prototype, _a, void 0);
|
|
36
|
+
class AuthSocketLoginDto extends (0, swagger_1.IntersectionType)((0, swagger_1.PickType)(userEntity, [loginField]), AuthSocketBodyPasswordFieldDto) {
|
|
37
|
+
}
|
|
38
|
+
const additionalSocketMandatoryFields = [];
|
|
39
|
+
const additionalSocketOptionalFields = [];
|
|
40
|
+
if (!additionalSocketRegisterFields) {
|
|
41
|
+
additionalSocketRegisterFields = [];
|
|
42
|
+
}
|
|
43
|
+
additionalSocketRegisterFields.forEach((field) => {
|
|
44
|
+
if (typeof field === 'string') {
|
|
45
|
+
additionalSocketOptionalFields.push(field);
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const { required, name } = field;
|
|
49
|
+
if (required) {
|
|
50
|
+
additionalSocketMandatoryFields.push(name);
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
additionalSocketOptionalFields.push(name);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
class AuthSocketRegisterDto extends (0, swagger_1.IntersectionType)((0, swagger_1.PickType)(userEntity, [loginField, ...additionalSocketMandatoryFields]), additionalSocketOptionalFields?.length
|
|
57
|
+
? (0, swagger_1.IntersectionType)(AuthSocketBodyPasswordFieldDto, (0, swagger_1.PartialType)((0, swagger_1.PickType)(userEntity, additionalSocketOptionalFields)))
|
|
58
|
+
: AuthSocketBodyPasswordFieldDto) {
|
|
59
|
+
}
|
|
60
|
+
class AuthUpdateAccountDto extends (0, mixins_1.EntityBodyMixin)(userEntity, true, [
|
|
61
|
+
loginField,
|
|
62
|
+
passwordField,
|
|
63
|
+
...updateAccountOptions.additionalFieldsToExclude ?? [],
|
|
64
|
+
]) {
|
|
65
|
+
}
|
|
66
|
+
class AuthRegisterPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthSocketPoliciesGuardMixin)(userEntity, registerAbilityPredicate) {
|
|
67
|
+
}
|
|
68
|
+
class AuthUpdateAccountPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthSocketPoliciesGuardMixin)(userEntity, updateAccountOptions.abilityPredicate) {
|
|
69
|
+
}
|
|
70
|
+
const getAccountEvent = 'auth-get-account';
|
|
71
|
+
const updateAccountEvent = 'auth-update-account';
|
|
72
|
+
const loginEvent = 'auth-login';
|
|
73
|
+
const registerEvent = 'auth-register';
|
|
74
|
+
const resetPasswordEvent = 'auth-reset-password';
|
|
75
|
+
const changePasswordEvent = 'auth-change-password';
|
|
76
|
+
class BaseAuthGateway extends gateways_1.BaseGateway {
|
|
77
|
+
constructor(service, jwtService) {
|
|
78
|
+
super(jwtService);
|
|
79
|
+
this.service = service;
|
|
80
|
+
this.jwtService = jwtService;
|
|
81
|
+
}
|
|
82
|
+
async getAccount(socket) {
|
|
83
|
+
return {
|
|
84
|
+
event: getAccountEvent,
|
|
85
|
+
data: socket.user ? await this.service.getAccount(socket.user) : undefined,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
async updateAccount(socket, body) {
|
|
89
|
+
return {
|
|
90
|
+
event: updateAccountEvent,
|
|
91
|
+
data: socket.user ? await this.service.updateAccount(socket.user, body) : undefined,
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
async login(socket, { [loginField]: login, [passwordField]: password }) {
|
|
95
|
+
if (login && password) {
|
|
96
|
+
socket.user = await this.service.validateUser(login, password);
|
|
97
|
+
}
|
|
98
|
+
if (!socket.user) {
|
|
99
|
+
throw new websockets_1.WsException('Unauthorized');
|
|
100
|
+
}
|
|
101
|
+
if (loginAbilityPredicate && !loginAbilityPredicate(socket.user)) {
|
|
102
|
+
throw new websockets_1.WsException('Access denied');
|
|
103
|
+
}
|
|
104
|
+
return {
|
|
105
|
+
event: loginEvent,
|
|
106
|
+
data: await this.service.login(socket.user),
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
async register(socket, data) {
|
|
110
|
+
this.addUserToSocket(socket, !registerProtected && !registerAbilityPredicate);
|
|
111
|
+
if (registerAbilityPredicate && !registerAbilityPredicate(socket.user)) {
|
|
112
|
+
throw new websockets_1.WsException('Access denied');
|
|
113
|
+
}
|
|
114
|
+
return {
|
|
115
|
+
event: registerEvent,
|
|
116
|
+
data: await this.service.register(data),
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
async resetPassword({ email }) {
|
|
120
|
+
if ((0, lodash_1.isEmpty)(resetPasswordOptions)) {
|
|
121
|
+
throw new websockets_1.WsException('This feature is not enabled');
|
|
122
|
+
}
|
|
123
|
+
return {
|
|
124
|
+
event: resetPasswordEvent,
|
|
125
|
+
data: await this.service.resetPassword(email),
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
async changePassword({ resetPasswordToken, newPassword }) {
|
|
129
|
+
if ((0, lodash_1.isEmpty)(resetPasswordOptions)) {
|
|
130
|
+
throw new websockets_1.WsException('This feature is not enabled');
|
|
131
|
+
}
|
|
132
|
+
return {
|
|
133
|
+
event: changePasswordEvent,
|
|
134
|
+
data: await this.service.changePassword(resetPasswordToken, newPassword),
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
__decorate([
|
|
139
|
+
(0, common_1.UseGuards)(new guards_1.JwtSocketAuthGuard()),
|
|
140
|
+
(0, websockets_1.SubscribeMessage)(getAccountEvent),
|
|
141
|
+
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
142
|
+
__metadata("design:type", Function),
|
|
143
|
+
__metadata("design:paramtypes", [Object]),
|
|
144
|
+
__metadata("design:returntype", Promise)
|
|
145
|
+
], BaseAuthGateway.prototype, "getAccount", null);
|
|
146
|
+
__decorate([
|
|
147
|
+
(0, common_1.UseGuards)(new guards_1.JwtSocketAuthGuard(), new AuthUpdateAccountPoliciesGuard()),
|
|
148
|
+
(0, websockets_1.SubscribeMessage)(updateAccountEvent),
|
|
149
|
+
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
150
|
+
__param(1, (0, websockets_1.MessageBody)()),
|
|
151
|
+
__metadata("design:type", Function),
|
|
152
|
+
__metadata("design:paramtypes", [Object, AuthUpdateAccountDto]),
|
|
153
|
+
__metadata("design:returntype", Promise)
|
|
154
|
+
], BaseAuthGateway.prototype, "updateAccount", null);
|
|
155
|
+
__decorate([
|
|
156
|
+
(0, websockets_1.SubscribeMessage)(loginEvent),
|
|
157
|
+
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
158
|
+
__param(1, (0, websockets_1.MessageBody)()),
|
|
159
|
+
__metadata("design:type", Function),
|
|
160
|
+
__metadata("design:paramtypes", [Object, AuthSocketLoginDto]),
|
|
161
|
+
__metadata("design:returntype", Promise)
|
|
162
|
+
], BaseAuthGateway.prototype, "login", null);
|
|
163
|
+
__decorate([
|
|
164
|
+
(0, common_1.UseGuards)(new AuthRegisterPoliciesGuard()),
|
|
165
|
+
(0, websockets_1.SubscribeMessage)(registerEvent),
|
|
166
|
+
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
167
|
+
__param(1, (0, websockets_1.MessageBody)()),
|
|
168
|
+
__metadata("design:type", Function),
|
|
169
|
+
__metadata("design:paramtypes", [Object, AuthSocketRegisterDto]),
|
|
170
|
+
__metadata("design:returntype", Promise)
|
|
171
|
+
], BaseAuthGateway.prototype, "register", null);
|
|
172
|
+
__decorate([
|
|
173
|
+
(0, common_1.UseGuards)(new guards_1.ResetPasswordGuard((0, helpers_1.isNotEmptyObject)(resetPasswordOptions))),
|
|
174
|
+
(0, websockets_1.SubscribeMessage)(resetPasswordEvent),
|
|
175
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
176
|
+
__metadata("design:type", Function),
|
|
177
|
+
__metadata("design:paramtypes", [reset_password_dto_1.ResetPasswordDto]),
|
|
178
|
+
__metadata("design:returntype", Promise)
|
|
179
|
+
], BaseAuthGateway.prototype, "resetPassword", null);
|
|
180
|
+
__decorate([
|
|
181
|
+
(0, common_1.UseGuards)(new guards_1.ResetPasswordGuard((0, helpers_1.isNotEmptyObject)(resetPasswordOptions))),
|
|
182
|
+
(0, websockets_1.SubscribeMessage)(changePasswordEvent),
|
|
183
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
184
|
+
__metadata("design:type", Function),
|
|
185
|
+
__metadata("design:paramtypes", [change_password_dto_1.ChangePasswordDto]),
|
|
186
|
+
__metadata("design:returntype", Promise)
|
|
187
|
+
], BaseAuthGateway.prototype, "changePassword", null);
|
|
188
|
+
return BaseAuthGateway;
|
|
189
|
+
}
|
|
190
|
+
exports.AuthGatewayMixin = AuthGatewayMixin;
|
|
191
|
+
//# sourceMappingURL=auth-gateway.mixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-gateway.mixin.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/auth-gateway.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Type } from '@nestjs/common';
|
|
2
|
+
import { AuthAbilityPredicate, AuthPoliciesGuardConstructor } from '../../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../../models';
|
|
4
|
+
declare function AuthPoliciesGuardMixin<Entity extends BaseEntity>(entity: Type<Entity>, abilityPredicate: AuthAbilityPredicate | undefined): AuthPoliciesGuardConstructor;
|
|
5
|
+
declare function AuthSocketPoliciesGuardMixin<Entity extends BaseEntity>(entity: Type<Entity>, abilityPredicate: AuthAbilityPredicate | undefined): AuthPoliciesGuardConstructor;
|
|
6
|
+
export { AuthPoliciesGuardMixin, AuthSocketPoliciesGuardMixin };
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AuthSocketPoliciesGuardMixin = exports.AuthPoliciesGuardMixin = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const websockets_1 = require("@nestjs/websockets");
|
|
12
|
+
function AuthPoliciesGuardMixin(entity, abilityPredicate) {
|
|
13
|
+
let BaseAuthPoliciesGuard = class BaseAuthPoliciesGuard {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.entity = entity;
|
|
16
|
+
this.abilityPredicate = abilityPredicate;
|
|
17
|
+
}
|
|
18
|
+
canActivate(context) {
|
|
19
|
+
const { user } = context.switchToHttp().getRequest();
|
|
20
|
+
if (this.abilityPredicate && (!user || !this.abilityPredicate(user))) {
|
|
21
|
+
throw new common_1.ForbiddenException('Access denied');
|
|
22
|
+
}
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
BaseAuthPoliciesGuard = __decorate([
|
|
27
|
+
(0, common_1.Injectable)()
|
|
28
|
+
], BaseAuthPoliciesGuard);
|
|
29
|
+
return BaseAuthPoliciesGuard;
|
|
30
|
+
}
|
|
31
|
+
exports.AuthPoliciesGuardMixin = AuthPoliciesGuardMixin;
|
|
32
|
+
function AuthSocketPoliciesGuardMixin(entity, abilityPredicate) {
|
|
33
|
+
let BaseAuthSocketPoliciesGuard = class BaseAuthSocketPoliciesGuard {
|
|
34
|
+
constructor() {
|
|
35
|
+
this.entity = entity;
|
|
36
|
+
this.abilityPredicate = abilityPredicate;
|
|
37
|
+
}
|
|
38
|
+
canActivate(context) {
|
|
39
|
+
const [socket] = context.getArgs();
|
|
40
|
+
if (this.abilityPredicate && (!socket.user || !this.abilityPredicate(socket.user))) {
|
|
41
|
+
throw new websockets_1.WsException('Access denied');
|
|
42
|
+
}
|
|
43
|
+
return true;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
BaseAuthSocketPoliciesGuard = __decorate([
|
|
47
|
+
(0, common_1.Injectable)()
|
|
48
|
+
], BaseAuthSocketPoliciesGuard);
|
|
49
|
+
return BaseAuthSocketPoliciesGuard;
|
|
50
|
+
}
|
|
51
|
+
exports.AuthSocketPoliciesGuardMixin = AuthSocketPoliciesGuardMixin;
|
|
52
|
+
//# sourceMappingURL=auth-policies-guard.mixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-policies-guard.mixin.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/auth-policies-guard.mixin.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwF;AACxF,mDAAiD;AAIjD,SAAS,sBAAsB,CAC7B,MAAoB,EACpB,gBAAkD;IAGlD,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;QAA3B;YACY,WAAM,GAAG,MAAM,CAAC;YAChB,qBAAgB,GAAG,gBAAgB,CAAC;QAahD,CAAC;QAXC,WAAW,CAAC,OAAyB;YACnC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;YAErD,IAAI,IAAI,CAAC,gBAAgB,IAAI,CAC3B,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CACtC,EAAE,CAAC;gBACF,MAAM,IAAI,2BAAkB,CAAC,eAAe,CAAC,CAAC;YAChD,CAAC;YAED,OAAO,IAAI,CAAC;QACd,CAAC;KACF,CAAA;IAfK,qBAAqB;QAD1B,IAAA,mBAAU,GAAE;OACP,qBAAqB,CAe1B;IAED,OAAO,qBAAqB,CAAC;AAC/B,CAAC;AA2BQ,wDAAsB;AAzB/B,SAAS,4BAA4B,CACnC,MAAoB,EACpB,gBAAkD;IAGlD,IAAM,2BAA2B,GAAjC,MAAM,2BAA2B;QAAjC;YACY,WAAM,GAAG,MAAM,CAAC;YAChB,qBAAgB,GAAG,gBAAgB,CAAC;QAahD,CAAC;QAXC,WAAW,CAAC,OAAyB;YACnC,MAAM,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YAEnC,IAAI,IAAI,CAAC,gBAAgB,IAAI,CAC3B,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,CACpD,EAAE,CAAC;gBACF,MAAM,IAAI,wBAAW,CAAC,eAAe,CAAC,CAAC;YACzC,CAAC;YAED,OAAO,IAAI,CAAC;QACd,CAAC;KACF,CAAA;IAfK,2BAA2B;QADhC,IAAA,mBAAU,GAAE;OACP,2BAA2B,CAehC;IAED,OAAO,2BAA2B,CAAC;AACrC,CAAC;AAEgC,oEAA4B"}
|
|
@@ -15,5 +15,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./auth-controller.mixin"), exports);
|
|
18
|
-
__exportStar(require("./auth-
|
|
18
|
+
__exportStar(require("./auth-gateway.mixin"), exports);
|
|
19
|
+
__exportStar(require("./auth-policies-guard.mixin"), exports);
|
|
19
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAwC;AACxC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAwC;AACxC,uDAAqC;AACrC,8DAA4C"}
|
|
@@ -38,6 +38,7 @@ export declare abstract class BaseAuthService<Entity extends BaseEntity> extends
|
|
|
38
38
|
protected passwordField: keyof Entity;
|
|
39
39
|
protected additionalRequestFields: (keyof Entity)[];
|
|
40
40
|
protected registerCallback: DynamicApiServiceCallback<Entity> | undefined;
|
|
41
|
+
protected updateAccountCallback: DynamicApiServiceCallback<Entity> | undefined;
|
|
41
42
|
protected loginCallback: DynamicApiServiceCallback<Entity> | undefined;
|
|
42
43
|
protected resetPasswordOptions: DynamicApiResetPasswordOptions<Entity> | undefined;
|
|
43
44
|
private resetPasswordCallbackMethods;
|
|
@@ -51,6 +52,7 @@ export declare abstract class BaseAuthService<Entity extends BaseEntity> extends
|
|
|
51
52
|
accessToken: string;
|
|
52
53
|
}>;
|
|
53
54
|
protected getAccount({ id }: Entity): Promise<Entity>;
|
|
55
|
+
protected updateAccount({ id }: Entity, update: Partial<Entity>): Promise<Entity>;
|
|
54
56
|
protected resetPassword(email: string): Promise<void>;
|
|
55
57
|
protected changePassword(resetPasswordToken: string, newPassword: string): Promise<void>;
|
|
56
58
|
private buildUserFields;
|
|
@@ -15,6 +15,7 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
15
15
|
this.logger = new common_1.Logger('AuthService');
|
|
16
16
|
}
|
|
17
17
|
async validateUser(login, pass) {
|
|
18
|
+
this.verifyArguments(login, pass);
|
|
18
19
|
const user = (await this.model.findOne({ [this.loginField]: login }).lean().exec());
|
|
19
20
|
const isPasswordValid = user ? await this.bcryptService.comparePassword(pass, user[this.passwordField]) : false;
|
|
20
21
|
if (!user || !isPasswordValid) {
|
|
@@ -28,6 +29,7 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
28
29
|
return this.buildUserFields(user, fieldsToBuild);
|
|
29
30
|
}
|
|
30
31
|
async login(user, fromMember = false) {
|
|
32
|
+
this.verifyArguments(user);
|
|
31
33
|
if (!fromMember && !!this.loginCallback) {
|
|
32
34
|
const fullUser = (await this.model.findOne({ _id: user.id }).lean().exec());
|
|
33
35
|
const instance = this.buildInstance(fullUser);
|
|
@@ -47,6 +49,7 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
47
49
|
};
|
|
48
50
|
}
|
|
49
51
|
async register(userToCreate) {
|
|
52
|
+
this.verifyArguments(userToCreate);
|
|
50
53
|
this.checkFieldsValidity(userToCreate);
|
|
51
54
|
try {
|
|
52
55
|
const hashedPassword = await this.bcryptService.hashPassword(userToCreate[this.passwordField]);
|
|
@@ -65,6 +68,7 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
65
68
|
}
|
|
66
69
|
}
|
|
67
70
|
async getAccount({ id }) {
|
|
71
|
+
this.verifyArguments(id);
|
|
68
72
|
const user = (await this.model.findOne({ _id: id }).lean().exec());
|
|
69
73
|
const fieldsToBuild = [
|
|
70
74
|
'_id',
|
|
@@ -73,7 +77,18 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
73
77
|
];
|
|
74
78
|
return this.buildUserFields(user, fieldsToBuild);
|
|
75
79
|
}
|
|
80
|
+
async updateAccount({ id }, update) {
|
|
81
|
+
this.verifyArguments(id, update);
|
|
82
|
+
await this.model.updateOne({ _id: id }, { $set: update });
|
|
83
|
+
if (this.updateAccountCallback) {
|
|
84
|
+
const fullUser = (await this.model.findOne({ _id: id }).lean().exec());
|
|
85
|
+
const instance = this.buildInstance(fullUser);
|
|
86
|
+
await this.updateAccountCallback(instance, this.callbackMethods);
|
|
87
|
+
}
|
|
88
|
+
return this.getAccount({ id });
|
|
89
|
+
}
|
|
76
90
|
async resetPassword(email) {
|
|
91
|
+
this.verifyArguments(email);
|
|
77
92
|
if (!this.resetPasswordOptions) {
|
|
78
93
|
return;
|
|
79
94
|
}
|
|
@@ -100,6 +115,7 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
100
115
|
await resetPasswordCallback({ resetPasswordToken, email }, this.resetPasswordCallbackMethods);
|
|
101
116
|
}
|
|
102
117
|
async changePassword(resetPasswordToken, newPassword) {
|
|
118
|
+
this.verifyArguments(resetPasswordToken, newPassword);
|
|
103
119
|
let email;
|
|
104
120
|
let exp;
|
|
105
121
|
try {
|
|
@@ -132,7 +148,7 @@ class BaseAuthService extends services_1.BaseService {
|
|
|
132
148
|
return;
|
|
133
149
|
}
|
|
134
150
|
const hashedPassword = await this.bcryptService.hashPassword(newPassword);
|
|
135
|
-
await this.model.updateOne({ _id: userId }, { [this.passwordField]: hashedPassword });
|
|
151
|
+
await this.model.updateOne({ _id: userId }, { $set: { [this.passwordField]: hashedPassword } });
|
|
136
152
|
if (this.resetPasswordOptions?.changePasswordCallback) {
|
|
137
153
|
const user = (await this.model.findOne({ _id: userId }).lean().exec());
|
|
138
154
|
const instance = this.buildInstance(user);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-auth.service.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/services/base-auth.service.ts"],"names":[],"mappings":";;;AAAA,2CAA8G;AAK9G,gDAA+D;AAG/D,MAAsB,eAA2C,SAAQ,sBAAmB;
|
|
1
|
+
{"version":3,"file":"base-auth.service.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/services/base-auth.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.CreateManyBodyDtoMixin = void 0;
|
|
13
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
14
|
+
const class_transformer_1 = require("class-transformer");
|
|
15
|
+
const class_validator_1 = require("class-validator");
|
|
16
|
+
function CreateManyBodyDtoMixin(DtoBody) {
|
|
17
|
+
class CreateManyBodyDto {
|
|
18
|
+
}
|
|
19
|
+
__decorate([
|
|
20
|
+
(0, swagger_1.ApiProperty)({ type: [DtoBody] }),
|
|
21
|
+
(0, class_validator_1.ValidateNested)({ each: true }),
|
|
22
|
+
(0, class_validator_1.IsInstance)(DtoBody, { each: true }),
|
|
23
|
+
(0, class_validator_1.ArrayMinSize)(1),
|
|
24
|
+
(0, class_transformer_1.Type)(() => DtoBody),
|
|
25
|
+
__metadata("design:type", Array)
|
|
26
|
+
], CreateManyBodyDto.prototype, "list", void 0);
|
|
27
|
+
return CreateManyBodyDto;
|
|
28
|
+
}
|
|
29
|
+
exports.CreateManyBodyDtoMixin = CreateManyBodyDtoMixin;
|
|
30
|
+
//# sourceMappingURL=create-many-body-dto.mixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-many-body-dto.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-many-body-dto.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,6CAA8C;AAC9C,yDAA4D;AAC5D,qDAA2E;AAG3E,SAAS,sBAAsB,CAAc,OAA0B;IACrE,MAAM,iBAAiB;KAOtB;IADC;QALC,IAAA,qBAAW,EAAC,EAAE,IAAI,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;QAChC,IAAA,gCAAc,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAC9B,IAAA,4BAAU,EAAC,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QACnC,IAAA,8BAAY,EAAC,CAAC,CAAC;QACf,IAAA,wBAAe,EAAC,GAAG,EAAE,CAAC,OAAO,CAAC;;mDACX;IAGtB,OAAO,iBAAiB,CAAC;AAC3B,CAAC;AAEQ,wDAAsB"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { BaseEntity } from '../../models';
|
|
2
2
|
import { CreateManyService } from './create-many-service.interface';
|
|
3
|
+
type CreateManyBody<T = any> = {
|
|
4
|
+
list: Partial<T>[];
|
|
5
|
+
};
|
|
3
6
|
interface CreateManyController<Entity extends BaseEntity> {
|
|
4
|
-
createMany(body:
|
|
5
|
-
list: any;
|
|
6
|
-
}): Promise<Entity[]>;
|
|
7
|
+
createMany(body: CreateManyBody<Entity>): Promise<Entity[]>;
|
|
7
8
|
}
|
|
8
9
|
type CreateManyControllerConstructor<Entity extends BaseEntity> = new (service: CreateManyService<Entity>) => CreateManyController<Entity>;
|
|
9
|
-
export type { CreateManyController, CreateManyControllerConstructor };
|
|
10
|
+
export type { CreateManyBody, CreateManyController, CreateManyControllerConstructor };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { JwtService } from '@nestjs/jwt';
|
|
2
|
+
import { ExtendedSocket, GatewayResponse } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
import { CreateManyBody } from './create-many-controller.interface';
|
|
5
|
+
import { CreateManyService } from './create-many-service.interface';
|
|
6
|
+
interface CreateManyGateway<Entity extends BaseEntity> {
|
|
7
|
+
createMany(socket: ExtendedSocket, body: CreateManyBody<Entity>): GatewayResponse<Entity[]>;
|
|
8
|
+
}
|
|
9
|
+
type CreateManyGatewayConstructor<Entity extends BaseEntity> = new (service: CreateManyService<Entity>, jwtService: JwtService) => CreateManyGateway<Entity>;
|
|
10
|
+
export type { CreateManyGateway, CreateManyGatewayConstructor };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-many-gateway.interface.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-many-gateway.interface.ts"],"names":[],"mappings":""}
|