mongodb-dynamic-api 3.2.0 → 4.0.0
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 +59 -0
- package/README.md +34 -3
- package/package.json +14 -11
- package/src/adapters/socket-adapter.d.ts +3 -3
- package/src/adapters/socket-adapter.js.map +1 -1
- package/src/builders/route-decorators/auth-decorators.builder.d.ts +1 -1
- package/src/builders/route-decorators/route-decorators.builder.d.ts +1 -1
- package/src/builders/route-decorators/route-decorators.builder.js.map +1 -1
- package/src/decorators/api-endpoint-visibility.decorator.js +1 -2
- package/src/decorators/api-endpoint-visibility.decorator.js.map +1 -1
- package/src/decorators/schema-options.decorator.js +2 -2
- package/src/decorators/schema-options.decorator.js.map +1 -1
- package/src/decorators/validator-pipe.decorator.js +1 -2
- package/src/decorators/validator-pipe.decorator.js.map +1 -1
- package/src/dynamic-api.module.js +4 -1
- package/src/dynamic-api.module.js.map +1 -1
- package/src/gateways/dynamic-api-broadcast.gateway.js +1 -2
- package/src/gateways/dynamic-api-broadcast.gateway.js.map +1 -1
- package/src/guards/base-policies.guard.d.ts +0 -25
- package/src/guards/jwt-socket.guard.js +1 -1
- package/src/guards/jwt-socket.guard.js.map +1 -1
- package/src/helpers/controller-ability-predicates.helper.js +1 -2
- package/src/helpers/controller-ability-predicates.helper.js.map +1 -1
- package/src/helpers/format.helper.js +6 -7
- package/src/helpers/format.helper.js.map +1 -1
- package/src/helpers/mixin-data.helper.js +1 -2
- package/src/helpers/mixin-data.helper.js.map +1 -1
- package/src/helpers/repository.helper.d.ts +0 -25
- package/src/helpers/repository.helper.js.map +1 -1
- package/src/helpers/route-decorators.helper.d.ts +1 -1
- package/src/helpers/route-decorators.helper.js +1 -2
- package/src/helpers/route-decorators.helper.js.map +1 -1
- package/src/helpers/route-description.helper.js +1 -2
- package/src/helpers/route-description.helper.js.map +1 -1
- package/src/helpers/schema.helper.d.ts +0 -25
- package/src/helpers/schema.helper.js +1 -2
- package/src/helpers/schema.helper.js.map +1 -1
- package/src/helpers/socket-config.helper.js +2 -3
- package/src/helpers/socket-config.helper.js.map +1 -1
- package/src/helpers/swagger-config.helper.js +1 -2
- package/src/helpers/swagger-config.helper.js.map +1 -1
- package/src/helpers/validation-config.helper.js +1 -2
- package/src/helpers/validation-config.helper.js.map +1 -1
- package/src/helpers/versioning-config.helper.js +2 -3
- package/src/helpers/versioning-config.helper.js.map +1 -1
- package/src/interceptors/dynamic-api-cache.interceptor.d.ts +3 -2
- package/src/interceptors/dynamic-api-cache.interceptor.js +4 -0
- package/src/interceptors/dynamic-api-cache.interceptor.js.map +1 -1
- package/src/interfaces/dynamic-api-decorator-builder.interface.d.ts +1 -1
- package/src/interfaces/dynamic-api-global-state.interface.d.ts +3 -25
- package/src/interfaces/dynamic-api-policy-handler.interface.d.ts +0 -25
- package/src/interfaces/dynamic-api-schema-options.interface.d.ts +0 -25
- package/src/interfaces/dynamic-api-service-callback.interface.d.ts +0 -25
- package/src/interfaces/dynamic-api-swagger-options.type.d.ts +1 -1
- package/src/mixins/entity-body.mixin.js +2 -2
- package/src/mixins/entity-body.mixin.js.map +1 -1
- package/src/mixins/entity-presenter.mixin.js +1 -2
- package/src/mixins/entity-presenter.mixin.js.map +1 -1
- package/src/mixins/policies-guard.mixin.js +2 -3
- package/src/mixins/policies-guard.mixin.js.map +1 -1
- package/src/models/base-entity.model.d.ts +0 -25
- package/src/modules/auth/auth-broadcast.helper.d.ts +3 -0
- package/src/modules/auth/auth-broadcast.helper.js +11 -0
- package/src/modules/auth/auth-broadcast.helper.js.map +1 -0
- package/src/modules/auth/auth-events.constants.d.ts +13 -0
- package/src/modules/auth/auth-events.constants.js +28 -0
- package/src/modules/auth/auth-events.constants.js.map +1 -0
- package/src/modules/auth/auth.helper.d.ts +19 -5
- package/src/modules/auth/auth.helper.js +20 -13
- package/src/modules/auth/auth.helper.js.map +1 -1
- package/src/modules/auth/auth.module.d.ts +5 -2
- package/src/modules/auth/auth.module.js +46 -7
- package/src/modules/auth/auth.module.js.map +1 -1
- package/src/modules/auth/guards/index.d.ts +2 -0
- package/src/modules/auth/guards/index.js +2 -0
- package/src/modules/auth/guards/index.js.map +1 -1
- package/src/modules/auth/guards/jwt-refresh/jwt-refresh.guard.d.ts +4 -0
- package/src/modules/auth/guards/jwt-refresh/jwt-refresh.guard.js +18 -0
- package/src/modules/auth/guards/jwt-refresh/jwt-refresh.guard.js.map +1 -0
- package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.js +1 -1
- package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.js.map +1 -1
- package/src/modules/auth/guards/jwt-socket-refresh/jwt-socket-refresh.guard.d.ts +8 -0
- package/src/modules/auth/guards/jwt-socket-refresh/jwt-socket-refresh.guard.js +62 -0
- package/src/modules/auth/guards/jwt-socket-refresh/jwt-socket-refresh.guard.js.map +1 -0
- package/src/modules/auth/index.d.ts +2 -0
- package/src/modules/auth/index.js +2 -0
- package/src/modules/auth/index.js.map +1 -1
- package/src/modules/auth/interfaces/auth-controller.interface.d.ts +19 -4
- package/src/modules/auth/interfaces/auth-gateway.interface.d.ts +2 -0
- package/src/modules/auth/interfaces/auth-options.interface.d.ts +19 -2
- package/src/modules/auth/interfaces/auth-service.interface.d.ts +3 -0
- package/src/modules/auth/mixins/auth-controller.mixin.d.ts +2 -2
- package/src/modules/auth/mixins/auth-controller.mixin.js +113 -20
- package/src/modules/auth/mixins/auth-controller.mixin.js.map +1 -1
- package/src/modules/auth/mixins/auth-gateway.mixin.d.ts +2 -2
- package/src/modules/auth/mixins/auth-gateway.mixin.js +66 -33
- package/src/modules/auth/mixins/auth-gateway.mixin.js.map +1 -1
- package/src/modules/auth/mixins/auth-policies-guard.mixin.js +2 -3
- package/src/modules/auth/mixins/auth-policies-guard.mixin.js.map +1 -1
- package/src/modules/auth/services/base-auth.service.d.ts +9 -25
- package/src/modules/auth/services/base-auth.service.js +74 -15
- package/src/modules/auth/services/base-auth.service.js.map +1 -1
- package/src/modules/auth/strategies/index.d.ts +1 -0
- package/src/modules/auth/strategies/index.js +1 -0
- package/src/modules/auth/strategies/index.js.map +1 -1
- package/src/modules/auth/strategies/jwt-refresh.strategy.d.ts +14 -0
- package/src/modules/auth/strategies/jwt-refresh.strategy.js +45 -0
- package/src/modules/auth/strategies/jwt-refresh.strategy.js.map +1 -0
- package/src/modules/auth/strategies/jwt.strategy.d.ts +3 -1
- package/src/modules/auth/strategies/jwt.strategy.js.map +1 -1
- package/src/routes/aggregate/aggregate-controller.mixin.js +1 -2
- package/src/routes/aggregate/aggregate-controller.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate-gateway.mixin.js +1 -2
- package/src/routes/aggregate/aggregate-gateway.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate-presenter.mixin.js +1 -2
- package/src/routes/aggregate/aggregate-presenter.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate.helper.js +3 -4
- package/src/routes/aggregate/aggregate.helper.js.map +1 -1
- package/src/routes/aggregate/base-aggregate.service.d.ts +0 -25
- package/src/routes/aggregate/base-aggregate.service.js.map +1 -1
- package/src/routes/create-many/base-create-many.service.d.ts +0 -25
- package/src/routes/create-many/base-create-many.service.js.map +1 -1
- package/src/routes/create-many/create-many-body.mixin.js +1 -2
- package/src/routes/create-many/create-many-body.mixin.js.map +1 -1
- package/src/routes/create-many/create-many-controller.mixin.js +1 -2
- package/src/routes/create-many/create-many-controller.mixin.js.map +1 -1
- package/src/routes/create-many/create-many-gateway.mixin.js +1 -2
- package/src/routes/create-many/create-many-gateway.mixin.js.map +1 -1
- package/src/routes/create-many/create-many-presenter.mixin.js +1 -2
- package/src/routes/create-many/create-many-presenter.mixin.js.map +1 -1
- package/src/routes/create-many/create-many.helper.js +3 -4
- package/src/routes/create-many/create-many.helper.js.map +1 -1
- package/src/routes/create-one/base-create-one.service.d.ts +0 -25
- package/src/routes/create-one/base-create-one.service.js.map +1 -1
- package/src/routes/create-one/create-one-controller.mixin.js +1 -2
- package/src/routes/create-one/create-one-controller.mixin.js.map +1 -1
- package/src/routes/create-one/create-one-gateway.mixin.js +1 -2
- package/src/routes/create-one/create-one-gateway.mixin.js.map +1 -1
- package/src/routes/create-one/create-one.helper.js +3 -4
- package/src/routes/create-one/create-one.helper.js.map +1 -1
- package/src/routes/delete-many/base-delete-many.service.d.ts +0 -25
- package/src/routes/delete-many/base-delete-many.service.js.map +1 -1
- package/src/routes/delete-many/delete-many-controller.mixin.js +1 -2
- package/src/routes/delete-many/delete-many-controller.mixin.js.map +1 -1
- package/src/routes/delete-many/delete-many-gateway.mixin.js +1 -2
- package/src/routes/delete-many/delete-many-gateway.mixin.js.map +1 -1
- package/src/routes/delete-many/delete-many.helper.js +3 -4
- package/src/routes/delete-many/delete-many.helper.js.map +1 -1
- package/src/routes/delete-one/base-delete-one.service.d.ts +0 -25
- package/src/routes/delete-one/base-delete-one.service.js.map +1 -1
- package/src/routes/delete-one/delete-one-controller.mixin.js +1 -2
- package/src/routes/delete-one/delete-one-controller.mixin.js.map +1 -1
- package/src/routes/delete-one/delete-one-gateway.mixin.js +1 -2
- package/src/routes/delete-one/delete-one-gateway.mixin.js.map +1 -1
- package/src/routes/delete-one/delete-one.helper.js +3 -4
- package/src/routes/delete-one/delete-one.helper.js.map +1 -1
- package/src/routes/duplicate-many/base-duplicate-many.service.d.ts +0 -25
- package/src/routes/duplicate-many/base-duplicate-many.service.js +4 -3
- package/src/routes/duplicate-many/base-duplicate-many.service.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many-controller.mixin.js +1 -2
- package/src/routes/duplicate-many/duplicate-many-controller.mixin.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js +1 -2
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many.helper.js +3 -4
- package/src/routes/duplicate-many/duplicate-many.helper.js.map +1 -1
- package/src/routes/duplicate-one/base-duplicate-one.service.d.ts +0 -25
- package/src/routes/duplicate-one/base-duplicate-one.service.js +3 -2
- package/src/routes/duplicate-one/base-duplicate-one.service.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one-controller.mixin.js +1 -2
- package/src/routes/duplicate-one/duplicate-one-controller.mixin.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js +1 -2
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one.helper.js +3 -4
- package/src/routes/duplicate-one/duplicate-one.helper.js.map +1 -1
- package/src/routes/get-many/base-get-many.service.d.ts +0 -25
- package/src/routes/get-many/base-get-many.service.js.map +1 -1
- package/src/routes/get-many/get-many-controller.mixin.js +1 -2
- package/src/routes/get-many/get-many-controller.mixin.js.map +1 -1
- package/src/routes/get-many/get-many-gateway.mixin.js +1 -2
- package/src/routes/get-many/get-many-gateway.mixin.js.map +1 -1
- package/src/routes/get-many/get-many.helper.js +3 -4
- package/src/routes/get-many/get-many.helper.js.map +1 -1
- package/src/routes/get-one/base-get-one.service.d.ts +0 -25
- package/src/routes/get-one/base-get-one.service.js.map +1 -1
- package/src/routes/get-one/get-one-controller.mixin.js +1 -2
- package/src/routes/get-one/get-one-controller.mixin.js.map +1 -1
- package/src/routes/get-one/get-one-gateway.mixin.js +1 -2
- package/src/routes/get-one/get-one-gateway.mixin.js.map +1 -1
- package/src/routes/get-one/get-one.helper.js +3 -4
- package/src/routes/get-one/get-one.helper.js.map +1 -1
- package/src/routes/replace-one/base-replace-one.service.d.ts +0 -25
- package/src/routes/replace-one/base-replace-one.service.js +3 -2
- package/src/routes/replace-one/base-replace-one.service.js.map +1 -1
- package/src/routes/replace-one/replace-one-controller.mixin.js +1 -2
- package/src/routes/replace-one/replace-one-controller.mixin.js.map +1 -1
- package/src/routes/replace-one/replace-one-gateway.mixin.js +1 -2
- package/src/routes/replace-one/replace-one-gateway.mixin.js.map +1 -1
- package/src/routes/replace-one/replace-one.helper.js +3 -4
- package/src/routes/replace-one/replace-one.helper.js.map +1 -1
- package/src/routes/update-many/base-update-many.service.d.ts +0 -25
- package/src/routes/update-many/base-update-many.service.js.map +1 -1
- package/src/routes/update-many/update-many-controller.mixin.js +1 -2
- package/src/routes/update-many/update-many-controller.mixin.js.map +1 -1
- package/src/routes/update-many/update-many-gateway.mixin.js +1 -2
- package/src/routes/update-many/update-many-gateway.mixin.js.map +1 -1
- package/src/routes/update-many/update-many.helper.js +3 -4
- package/src/routes/update-many/update-many.helper.js.map +1 -1
- package/src/routes/update-one/base-update-one.service.d.ts +0 -25
- package/src/routes/update-one/base-update-one.service.js.map +1 -1
- package/src/routes/update-one/update-one-controller.mixin.js +1 -2
- package/src/routes/update-one/update-one-controller.mixin.js.map +1 -1
- package/src/routes/update-one/update-one-gateway.mixin.js +1 -2
- package/src/routes/update-one/update-one-gateway.mixin.js.map +1 -1
- package/src/routes/update-one/update-one.helper.js +3 -4
- package/src/routes/update-one/update-one.helper.js.map +1 -1
- package/src/services/base/base.service.d.ts +3 -28
- package/src/services/base/base.service.js +26 -8
- package/src/services/base/base.service.js.map +1 -1
- package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.d.ts +0 -25
- package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.js +3 -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/e2e.setup.d.ts +9 -34
- package/test/e2e.setup.js +8 -7
- package/test/e2e.setup.js.map +1 -1
- package/test/for-feature/base-entity.e2e-spec.js +316 -0
- package/test/for-feature/base-entity.e2e-spec.js.map +1 -0
- package/test/for-feature/http-broadcast.e2e-spec.js +187 -0
- package/test/for-feature/http-broadcast.e2e-spec.js.map +1 -0
- package/test/for-feature/soft-deletable-entity.e2e-spec.d.ts +1 -0
- package/test/for-feature/soft-deletable-entity.e2e-spec.js +335 -0
- package/test/for-feature/soft-deletable-entity.e2e-spec.js.map +1 -0
- package/test/for-feature/websockets.e2e-spec.d.ts +1 -0
- package/test/for-feature/websockets.e2e-spec.js +324 -0
- package/test/for-feature/websockets.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-basic.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-basic.e2e-spec.js +338 -0
- package/test/for-root/auth-api-basic.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-broadcast.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-broadcast.e2e-spec.js +82 -0
- package/test/for-root/auth-api-broadcast.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-login.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-login.e2e-spec.js +103 -0
- package/test/for-root/auth-api-login.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-logout.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-logout.e2e-spec.js +74 -0
- package/test/for-root/auth-api-logout.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-refresh-token-cookie.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-refresh-token-cookie.e2e-spec.js +110 -0
- package/test/for-root/auth-api-refresh-token-cookie.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-refresh-token.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-refresh-token.e2e-spec.js +153 -0
- package/test/for-root/auth-api-refresh-token.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-register.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-register.e2e-spec.js +116 -0
- package/test/for-root/auth-api-register.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-reset-password.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-reset-password.e2e-spec.js +168 -0
- package/test/for-root/auth-api-reset-password.e2e-spec.js.map +1 -0
- package/test/for-root/initialization.e2e-spec.d.ts +1 -0
- package/test/for-root/initialization.e2e-spec.js +84 -0
- package/test/for-root/initialization.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-basic.e2e-spec.d.ts +1 -0
- package/test/for-root/websockets-auth-basic.e2e-spec.js +313 -0
- package/test/for-root/websockets-auth-basic.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-broadcast.e2e-spec.d.ts +1 -0
- package/test/for-root/websockets-auth-broadcast.e2e-spec.js +86 -0
- package/test/for-root/websockets-auth-broadcast.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-login.e2e-spec.d.ts +1 -0
- package/test/for-root/websockets-auth-login.e2e-spec.js +107 -0
- package/test/for-root/websockets-auth-login.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-refresh-token.e2e-spec.d.ts +1 -0
- package/test/for-root/websockets-auth-refresh-token.e2e-spec.js +104 -0
- package/test/for-root/websockets-auth-refresh-token.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-register.e2e-spec.d.ts +1 -0
- package/test/for-root/websockets-auth-register.e2e-spec.js +131 -0
- package/test/for-root/websockets-auth-register.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-reset-password.e2e-spec.d.ts +1 -0
- package/test/for-root/websockets-auth-reset-password.e2e-spec.js +164 -0
- package/test/for-root/websockets-auth-reset-password.e2e-spec.js.map +1 -0
- package/test/shared/entities/basic-user.factory.d.ts +12 -0
- package/test/shared/entities/basic-user.factory.js +31 -0
- package/test/shared/entities/basic-user.factory.js.map +1 -0
- package/test/shared/entities/broadcast-user.factory.d.ts +13 -0
- package/test/shared/entities/broadcast-user.factory.js +35 -0
- package/test/shared/entities/broadcast-user.factory.js.map +1 -0
- package/test/shared/entities/index.d.ts +7 -0
- package/test/shared/entities/index.js +24 -0
- package/test/shared/entities/index.js.map +1 -0
- package/test/shared/entities/login-user.factory.d.ts +14 -0
- package/test/shared/entities/login-user.factory.js +39 -0
- package/test/shared/entities/login-user.factory.js.map +1 -0
- package/test/shared/entities/refresh-token-user.factory.d.ts +13 -0
- package/test/shared/entities/refresh-token-user.factory.js +35 -0
- package/test/shared/entities/refresh-token-user.factory.js.map +1 -0
- package/test/shared/entities/register-user.factory.d.ts +14 -0
- package/test/shared/entities/register-user.factory.js +39 -0
- package/test/shared/entities/register-user.factory.js.map +1 -0
- package/test/shared/entities/reset-password-user.factory.d.ts +14 -0
- package/test/shared/entities/reset-password-user.factory.js +39 -0
- package/test/shared/entities/reset-password-user.factory.js.map +1 -0
- package/test/shared/entities/validated-user.factory.d.ts +12 -0
- package/test/shared/entities/validated-user.factory.js +40 -0
- package/test/shared/entities/validated-user.factory.js.map +1 -0
- package/test/shared/fixtures/index.d.ts +2 -0
- package/test/shared/fixtures/index.js +19 -0
- package/test/shared/fixtures/index.js.map +1 -0
- package/test/shared/fixtures/login.fixtures.d.ts +16 -0
- package/test/shared/fixtures/login.fixtures.js +20 -0
- package/test/shared/fixtures/login.fixtures.js.map +1 -0
- package/test/shared/fixtures/register.fixtures.d.ts +10 -0
- package/test/shared/fixtures/register.fixtures.js +14 -0
- package/test/shared/fixtures/register.fixtures.js.map +1 -0
- package/test/shared/index.d.ts +4 -0
- package/test/shared/index.js +24 -0
- package/test/shared/index.js.map +1 -0
- package/test/shared/init-app.d.ts +3 -0
- package/test/shared/init-app.js +19 -0
- package/test/shared/init-app.js.map +1 -0
- package/test/shared/init-module.d.ts +4 -0
- package/test/shared/init-module.js +16 -0
- package/test/shared/init-module.js.map +1 -0
- package/test/utils.d.ts +0 -25
- package/tsconfig.tsbuildinfo +1 -1
- package/test/dynamic-api-for-feature.e2e-spec.js +0 -1100
- package/test/dynamic-api-for-feature.e2e-spec.js.map +0 -1
- package/test/dynamic-api-for-root.e2e-spec.js +0 -1573
- package/test/dynamic-api-for-root.e2e-spec.js.map +0 -1
- /package/test/{dynamic-api-for-feature.e2e-spec.d.ts → for-feature/base-entity.e2e-spec.d.ts} +0 -0
- /package/test/{dynamic-api-for-root.e2e-spec.d.ts → for-feature/http-broadcast.e2e-spec.d.ts} +0 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { BaseEntity } from '../../../models';
|
|
3
|
-
import { AuthControllerConstructor, DynamicApiGetAccountOptions, DynamicApiLoginOptions, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions, DynamicApiUpdateAccountOptions } from '../interfaces';
|
|
4
|
-
declare function AuthControllerMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, { loginField, passwordField, additionalFields: additionalRequestFields, useInterceptors: loginUseInterceptors, }: DynamicApiLoginOptions<Entity>, { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors, }?: DynamicApiRegisterOptions<Entity>, { resetPasswordUseInterceptors, changePasswordUseInterceptors, ...resetPasswordOptions }?: DynamicApiResetPasswordOptions<Entity>, { useInterceptors: updateAccountUseInterceptors, ...updateAccountOptions }?: DynamicApiUpdateAccountOptions<Entity>, { useInterceptors: getAccountUseInterceptors, }?: DynamicApiGetAccountOptions<Entity>): AuthControllerConstructor<Entity>;
|
|
3
|
+
import { AuthControllerConstructor, DynamicApiGetAccountOptions, DynamicApiLoginOptions, DynamicApiRefreshTokenOptions, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions, DynamicApiUpdateAccountOptions } from '../interfaces';
|
|
4
|
+
declare function AuthControllerMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, { loginField, passwordField, additionalFields: additionalRequestFields, useInterceptors: loginUseInterceptors, broadcast: loginBroadcastConfig, }: DynamicApiLoginOptions<Entity>, { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors, broadcast: registerBroadcastConfig, }?: DynamicApiRegisterOptions<Entity>, { resetPasswordUseInterceptors, changePasswordUseInterceptors, ...resetPasswordOptions }?: DynamicApiResetPasswordOptions<Entity>, { useInterceptors: updateAccountUseInterceptors, broadcast: updateAccountBroadcastConfig, ...updateAccountOptions }?: DynamicApiUpdateAccountOptions<Entity>, { useInterceptors: getAccountUseInterceptors, broadcast: getAccountBroadcastConfig, }?: DynamicApiGetAccountOptions<Entity>, { useInterceptors: refreshTokenUseInterceptors, useCookie, }?: DynamicApiRefreshTokenOptions<Entity>): AuthControllerConstructor<Entity>;
|
|
5
5
|
export { AuthControllerMixin };
|
|
@@ -12,18 +12,24 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
|
12
12
|
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.AuthControllerMixin =
|
|
15
|
+
exports.AuthControllerMixin = AuthControllerMixin;
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
|
+
const jwt_1 = require("@nestjs/jwt");
|
|
17
18
|
const swagger_1 = require("@nestjs/swagger");
|
|
18
19
|
const builders_1 = require("../../../builders");
|
|
19
20
|
const decorators_1 = require("../../../decorators");
|
|
20
21
|
const helpers_1 = require("../../../helpers");
|
|
21
22
|
const mixins_1 = require("../../../mixins");
|
|
23
|
+
const services_1 = require("../../../services");
|
|
24
|
+
const auth_broadcast_helper_1 = require("../auth-broadcast.helper");
|
|
25
|
+
const auth_events_constants_1 = require("../auth-events.constants");
|
|
22
26
|
const change_password_dto_1 = require("../dtos/change-password.dto");
|
|
23
27
|
const reset_password_dto_1 = require("../dtos/reset-password.dto");
|
|
24
28
|
const guards_1 = require("../guards");
|
|
25
29
|
const auth_policies_guard_mixin_1 = require("./auth-policies-guard.mixin");
|
|
26
|
-
|
|
30
|
+
const REFRESH_TOKEN_COOKIE = 'refreshToken';
|
|
31
|
+
const COOKIE_OPTIONS = { httpOnly: true, secure: process.env.NODE_ENV === 'production', sameSite: 'strict' };
|
|
32
|
+
function AuthControllerMixin(userEntity, { loginField, passwordField, additionalFields: additionalRequestFields = [], useInterceptors: loginUseInterceptors = [], broadcast: loginBroadcastConfig, }, { additionalFields: additionalRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors = [], broadcast: registerBroadcastConfig, } = {}, { resetPasswordUseInterceptors = [], changePasswordUseInterceptors = [], ...resetPasswordOptions } = {}, { useInterceptors: updateAccountUseInterceptors = [], broadcast: updateAccountBroadcastConfig, ...updateAccountOptions } = {}, { useInterceptors: getAccountUseInterceptors = [], broadcast: getAccountBroadcastConfig, } = {}, { useInterceptors: refreshTokenUseInterceptors = [], useCookie = false, } = {}) {
|
|
27
33
|
var _a;
|
|
28
34
|
if (!loginField || !passwordField) {
|
|
29
35
|
throw new Error('Login and password fields are required');
|
|
@@ -71,6 +77,10 @@ function AuthControllerMixin(userEntity, { loginField, passwordField, additional
|
|
|
71
77
|
(0, swagger_1.ApiProperty)(),
|
|
72
78
|
__metadata("design:type", String)
|
|
73
79
|
], AuthPresenter.prototype, "accessToken", void 0);
|
|
80
|
+
__decorate([
|
|
81
|
+
(0, swagger_1.ApiProperty)({ required: false }),
|
|
82
|
+
__metadata("design:type", String)
|
|
83
|
+
], AuthPresenter.prototype, "refreshToken", void 0);
|
|
74
84
|
class AuthUserPresenter extends (0, swagger_1.PickType)(userEntity, ['id', loginField, ...additionalRequestFields]) {
|
|
75
85
|
}
|
|
76
86
|
class AuthRegisterPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthPoliciesGuardMixin)(userEntity, registerAbilityPredicate) {
|
|
@@ -79,29 +89,81 @@ function AuthControllerMixin(userEntity, { loginField, passwordField, additional
|
|
|
79
89
|
class AuthUpdateAccountPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthPoliciesGuardMixin)(userEntity, updateAccountOptions.abilityPredicate) {
|
|
80
90
|
}
|
|
81
91
|
const authUpdateAccountDecorators = new builders_1.AuthDecoratorsBuilder(true, AuthUpdateAccountPoliciesGuard);
|
|
82
|
-
class BaseAuthController {
|
|
83
|
-
constructor(service) {
|
|
92
|
+
let BaseAuthController = class BaseAuthController {
|
|
93
|
+
constructor(service, broadcastService, jwtService) {
|
|
84
94
|
this.service = service;
|
|
95
|
+
this.broadcastService = broadcastService;
|
|
96
|
+
this.jwtService = jwtService;
|
|
85
97
|
}
|
|
86
|
-
getAccount(req) {
|
|
87
|
-
|
|
98
|
+
async getAccount(req) {
|
|
99
|
+
const account = await this.service.getAccount(req.user);
|
|
100
|
+
if (getAccountBroadcastConfig) {
|
|
101
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(account, getAccountBroadcastConfig.fields);
|
|
102
|
+
this.broadcastService?.broadcastFromHttp(getAccountBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_GET_ACCOUNT_BROADCAST_EVENT, [broadcastData], getAccountBroadcastConfig);
|
|
103
|
+
}
|
|
104
|
+
return account;
|
|
88
105
|
}
|
|
89
106
|
changePassword({ resetPasswordToken, newPassword }) {
|
|
90
107
|
return this.service.changePassword(resetPasswordToken, newPassword);
|
|
91
108
|
}
|
|
92
|
-
login(req, _) {
|
|
93
|
-
|
|
109
|
+
async login(req, _, res) {
|
|
110
|
+
const result = await this.service.login(req.user);
|
|
111
|
+
if (loginBroadcastConfig) {
|
|
112
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(req.user, loginBroadcastConfig.fields);
|
|
113
|
+
this.broadcastService?.broadcastFromHttp(loginBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_LOGIN_BROADCAST_EVENT, [broadcastData], loginBroadcastConfig);
|
|
114
|
+
}
|
|
115
|
+
if (useCookie) {
|
|
116
|
+
res.cookie(REFRESH_TOKEN_COOKIE, result.refreshToken, COOKIE_OPTIONS);
|
|
117
|
+
const { refreshToken: _rt, ...bodyResult } = result;
|
|
118
|
+
return bodyResult;
|
|
119
|
+
}
|
|
120
|
+
return result;
|
|
94
121
|
}
|
|
95
|
-
register(body) {
|
|
96
|
-
|
|
122
|
+
async register(body, res) {
|
|
123
|
+
const result = await this.service.register(body);
|
|
124
|
+
if (registerBroadcastConfig && this.jwtService) {
|
|
125
|
+
const decoded = this.jwtService.decode(result.accessToken);
|
|
126
|
+
const { iat, exp, ...userPayload } = (decoded && typeof decoded !== 'string' ? decoded : {});
|
|
127
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(userPayload, registerBroadcastConfig.fields);
|
|
128
|
+
this.broadcastService?.broadcastFromHttp(registerBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_REGISTER_BROADCAST_EVENT, [broadcastData], registerBroadcastConfig);
|
|
129
|
+
}
|
|
130
|
+
if (useCookie) {
|
|
131
|
+
res.cookie(REFRESH_TOKEN_COOKIE, result.refreshToken, COOKIE_OPTIONS);
|
|
132
|
+
const { refreshToken: _rt, ...bodyResult } = result;
|
|
133
|
+
return bodyResult;
|
|
134
|
+
}
|
|
135
|
+
return result;
|
|
97
136
|
}
|
|
98
137
|
resetPassword({ email }) {
|
|
99
138
|
return this.service.resetPassword(email);
|
|
100
139
|
}
|
|
101
|
-
updateAccount(req, body) {
|
|
102
|
-
|
|
140
|
+
async updateAccount(req, body) {
|
|
141
|
+
const account = await this.service.updateAccount(req.user, body);
|
|
142
|
+
if (updateAccountBroadcastConfig) {
|
|
143
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(account, updateAccountBroadcastConfig.fields);
|
|
144
|
+
this.broadcastService?.broadcastFromHttp(updateAccountBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_UPDATE_ACCOUNT_BROADCAST_EVENT, [broadcastData], updateAccountBroadcastConfig);
|
|
145
|
+
}
|
|
146
|
+
return account;
|
|
103
147
|
}
|
|
104
|
-
|
|
148
|
+
async refreshToken(req, res) {
|
|
149
|
+
const rawToken = useCookie
|
|
150
|
+
? req.cookies?.[REFRESH_TOKEN_COOKIE]
|
|
151
|
+
: req.headers?.authorization?.split(' ')[1];
|
|
152
|
+
const result = await this.service.refreshToken(req.user, rawToken);
|
|
153
|
+
if (useCookie) {
|
|
154
|
+
res.cookie(REFRESH_TOKEN_COOKIE, result.refreshToken, COOKIE_OPTIONS);
|
|
155
|
+
const { refreshToken: _rt, ...bodyResult } = result;
|
|
156
|
+
return bodyResult;
|
|
157
|
+
}
|
|
158
|
+
return result;
|
|
159
|
+
}
|
|
160
|
+
async logout(req, res) {
|
|
161
|
+
await this.service.logout(req.user);
|
|
162
|
+
if (useCookie) {
|
|
163
|
+
res.clearCookie(REFRESH_TOKEN_COOKIE);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
};
|
|
105
167
|
__decorate([
|
|
106
168
|
(0, swagger_1.ApiBearerAuth)(),
|
|
107
169
|
(0, common_1.UseGuards)(guards_1.JwtAuthGuard),
|
|
@@ -112,7 +174,7 @@ function AuthControllerMixin(userEntity, { loginField, passwordField, additional
|
|
|
112
174
|
__param(0, (0, common_1.Request)()),
|
|
113
175
|
__metadata("design:type", Function),
|
|
114
176
|
__metadata("design:paramtypes", [Object]),
|
|
115
|
-
__metadata("design:returntype",
|
|
177
|
+
__metadata("design:returntype", Promise)
|
|
116
178
|
], BaseAuthController.prototype, "getAccount", null);
|
|
117
179
|
__decorate([
|
|
118
180
|
(0, decorators_1.ApiEndpointVisibility)(!!resetPasswordOptions, (0, decorators_1.Public)()),
|
|
@@ -134,9 +196,10 @@ function AuthControllerMixin(userEntity, { loginField, passwordField, additional
|
|
|
134
196
|
(0, common_1.Post)('login'),
|
|
135
197
|
__param(0, (0, common_1.Request)()),
|
|
136
198
|
__param(1, (0, common_1.Body)()),
|
|
199
|
+
__param(2, (0, common_1.Res)({ passthrough: true })),
|
|
137
200
|
__metadata("design:type", Function),
|
|
138
|
-
__metadata("design:paramtypes", [Object, AuthLoginDto]),
|
|
139
|
-
__metadata("design:returntype",
|
|
201
|
+
__metadata("design:paramtypes", [Object, AuthLoginDto, Object]),
|
|
202
|
+
__metadata("design:returntype", Promise)
|
|
140
203
|
], BaseAuthController.prototype, "login", null);
|
|
141
204
|
__decorate([
|
|
142
205
|
(0, helpers_1.RouteDecoratorsHelper)(authRegisterDecorators),
|
|
@@ -145,9 +208,10 @@ function AuthControllerMixin(userEntity, { loginField, passwordField, additional
|
|
|
145
208
|
(0, common_1.UseInterceptors)(...registerUseInterceptors),
|
|
146
209
|
(0, common_1.Post)('register'),
|
|
147
210
|
__param(0, (0, common_1.Body)()),
|
|
211
|
+
__param(1, (0, common_1.Res)({ passthrough: true })),
|
|
148
212
|
__metadata("design:type", Function),
|
|
149
|
-
__metadata("design:paramtypes", [AuthRegisterDto]),
|
|
150
|
-
__metadata("design:returntype",
|
|
213
|
+
__metadata("design:paramtypes", [AuthRegisterDto, Object]),
|
|
214
|
+
__metadata("design:returntype", Promise)
|
|
151
215
|
], BaseAuthController.prototype, "register", null);
|
|
152
216
|
__decorate([
|
|
153
217
|
(0, decorators_1.ApiEndpointVisibility)(!!resetPasswordOptions, (0, decorators_1.Public)()),
|
|
@@ -170,9 +234,38 @@ function AuthControllerMixin(userEntity, { loginField, passwordField, additional
|
|
|
170
234
|
__param(1, (0, common_1.Body)()),
|
|
171
235
|
__metadata("design:type", Function),
|
|
172
236
|
__metadata("design:paramtypes", [Object, AuthUpdateAccountDto]),
|
|
173
|
-
__metadata("design:returntype",
|
|
237
|
+
__metadata("design:returntype", Promise)
|
|
174
238
|
], BaseAuthController.prototype, "updateAccount", null);
|
|
239
|
+
__decorate([
|
|
240
|
+
(0, swagger_1.ApiBearerAuth)(),
|
|
241
|
+
(0, common_1.UseGuards)(guards_1.JwtRefreshGuard),
|
|
242
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.OK),
|
|
243
|
+
(0, swagger_1.ApiOkResponse)({ type: AuthPresenter }),
|
|
244
|
+
(0, common_1.UseInterceptors)(...refreshTokenUseInterceptors),
|
|
245
|
+
(0, common_1.Post)('refresh-token'),
|
|
246
|
+
__param(0, (0, common_1.Request)()),
|
|
247
|
+
__param(1, (0, common_1.Res)({ passthrough: true })),
|
|
248
|
+
__metadata("design:type", Function),
|
|
249
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
250
|
+
__metadata("design:returntype", Promise)
|
|
251
|
+
], BaseAuthController.prototype, "refreshToken", null);
|
|
252
|
+
__decorate([
|
|
253
|
+
(0, swagger_1.ApiBearerAuth)(),
|
|
254
|
+
(0, common_1.UseGuards)(guards_1.JwtRefreshGuard),
|
|
255
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.NO_CONTENT),
|
|
256
|
+
(0, common_1.Post)('logout'),
|
|
257
|
+
__param(0, (0, common_1.Request)()),
|
|
258
|
+
__param(1, (0, common_1.Res)({ passthrough: true })),
|
|
259
|
+
__metadata("design:type", Function),
|
|
260
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
261
|
+
__metadata("design:returntype", Promise)
|
|
262
|
+
], BaseAuthController.prototype, "logout", null);
|
|
263
|
+
BaseAuthController = __decorate([
|
|
264
|
+
__param(1, (0, common_1.Optional)()),
|
|
265
|
+
__param(2, (0, common_1.Optional)()),
|
|
266
|
+
__metadata("design:paramtypes", [Object, services_1.DynamicApiBroadcastService,
|
|
267
|
+
jwt_1.JwtService])
|
|
268
|
+
], BaseAuthController);
|
|
175
269
|
return BaseAuthController;
|
|
176
270
|
}
|
|
177
|
-
exports.AuthControllerMixin = AuthControllerMixin;
|
|
178
271
|
//# sourceMappingURL=auth-controller.mixin.js.map
|
|
@@ -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":"
|
|
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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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { BaseEntity } from '../../../models';
|
|
3
|
-
import { AuthGatewayConstructor, DynamicApiGetAccountOptions, DynamicApiLoginOptions, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions, DynamicApiUpdateAccountOptions } from '../interfaces';
|
|
4
|
-
declare function AuthGatewayMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, { loginField, passwordField, abilityPredicate: loginAbilityPredicate, useInterceptors: loginUseInterceptors, }: DynamicApiLoginOptions<Entity>, { additionalFields: additionalSocketRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors, }?: DynamicApiRegisterOptions<Entity>, { resetPasswordUseInterceptors, changePasswordUseInterceptors, ...resetPasswordOptions }?: DynamicApiResetPasswordOptions<Entity>, { useInterceptors: updateAccountUseInterceptors, ...updateAccountOptions }?: DynamicApiUpdateAccountOptions<Entity>, { useInterceptors: getAccountUseInterceptors, }?: DynamicApiGetAccountOptions<Entity>): AuthGatewayConstructor<Entity>;
|
|
3
|
+
import { AuthGatewayConstructor, DynamicApiGetAccountOptions, DynamicApiLoginOptions, DynamicApiRefreshTokenOptions, DynamicApiRegisterOptions, DynamicApiResetPasswordOptions, DynamicApiUpdateAccountOptions } from '../interfaces';
|
|
4
|
+
declare function AuthGatewayMixin<Entity extends BaseEntity>(userEntity: Type<Entity>, { loginField, passwordField, abilityPredicate: loginAbilityPredicate, useInterceptors: loginUseInterceptors, broadcast: loginBroadcastConfig, }: DynamicApiLoginOptions<Entity>, { additionalFields: additionalSocketRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors, broadcast: registerBroadcastConfig, }?: DynamicApiRegisterOptions<Entity>, { resetPasswordUseInterceptors, changePasswordUseInterceptors, ...resetPasswordOptions }?: DynamicApiResetPasswordOptions<Entity>, { useInterceptors: updateAccountUseInterceptors, broadcast: updateAccountBroadcastConfig, ...updateAccountOptions }?: DynamicApiUpdateAccountOptions<Entity>, { useInterceptors: getAccountUseInterceptors, broadcast: getAccountBroadcastConfig, }?: DynamicApiGetAccountOptions<Entity>, { useInterceptors: refreshTokenUseInterceptors, }?: DynamicApiRefreshTokenOptions<Entity>): AuthGatewayConstructor<Entity>;
|
|
5
5
|
export { AuthGatewayMixin };
|
|
@@ -12,7 +12,7 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
|
12
12
|
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.AuthGatewayMixin =
|
|
15
|
+
exports.AuthGatewayMixin = AuthGatewayMixin;
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const swagger_1 = require("@nestjs/swagger");
|
|
18
18
|
const websockets_1 = require("@nestjs/websockets");
|
|
@@ -20,11 +20,13 @@ const lodash_1 = require("lodash");
|
|
|
20
20
|
const gateways_1 = require("../../../gateways");
|
|
21
21
|
const helpers_1 = require("../../../helpers");
|
|
22
22
|
const mixins_1 = require("../../../mixins");
|
|
23
|
+
const auth_broadcast_helper_1 = require("../auth-broadcast.helper");
|
|
24
|
+
const auth_events_constants_1 = require("../auth-events.constants");
|
|
23
25
|
const change_password_dto_1 = require("../dtos/change-password.dto");
|
|
24
26
|
const reset_password_dto_1 = require("../dtos/reset-password.dto");
|
|
25
27
|
const guards_1 = require("../guards");
|
|
26
28
|
const auth_policies_guard_mixin_1 = require("./auth-policies-guard.mixin");
|
|
27
|
-
function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredicate: loginAbilityPredicate, useInterceptors: loginUseInterceptors = [], }, { additionalFields: additionalSocketRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors = [], } = {}, { resetPasswordUseInterceptors = [], changePasswordUseInterceptors = [], ...resetPasswordOptions } = {}, { useInterceptors: updateAccountUseInterceptors = [], ...updateAccountOptions } = {}, { useInterceptors: getAccountUseInterceptors = [], } = {}) {
|
|
29
|
+
function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredicate: loginAbilityPredicate, useInterceptors: loginUseInterceptors = [], broadcast: loginBroadcastConfig, }, { additionalFields: additionalSocketRegisterFields, protected: registerProtected, abilityPredicate: registerAbilityPredicate, useInterceptors: registerUseInterceptors = [], broadcast: registerBroadcastConfig, } = {}, { resetPasswordUseInterceptors = [], changePasswordUseInterceptors = [], ...resetPasswordOptions } = {}, { useInterceptors: updateAccountUseInterceptors = [], broadcast: updateAccountBroadcastConfig, ...updateAccountOptions } = {}, { useInterceptors: getAccountUseInterceptors = [], broadcast: getAccountBroadcastConfig, } = {}, { useInterceptors: refreshTokenUseInterceptors = [], } = {}) {
|
|
28
30
|
var _a;
|
|
29
31
|
class AuthSocketBodyPasswordFieldDto extends (0, swagger_1.PickType)(userEntity, [passwordField]) {
|
|
30
32
|
}
|
|
@@ -67,12 +69,6 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
67
69
|
}
|
|
68
70
|
class AuthUpdateAccountPoliciesGuard extends (0, auth_policies_guard_mixin_1.AuthSocketPoliciesGuardMixin)(userEntity, updateAccountOptions.abilityPredicate) {
|
|
69
71
|
}
|
|
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
72
|
class BaseAuthGateway extends gateways_1.BaseGateway {
|
|
77
73
|
constructor(service, jwtService) {
|
|
78
74
|
super(jwtService);
|
|
@@ -80,16 +76,20 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
80
76
|
this.jwtService = jwtService;
|
|
81
77
|
}
|
|
82
78
|
async getAccount(socket) {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
79
|
+
const account = socket.user ? await this.service.getAccount(socket.user) : undefined;
|
|
80
|
+
if (getAccountBroadcastConfig && account) {
|
|
81
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(account, getAccountBroadcastConfig.fields);
|
|
82
|
+
this.broadcastIfNeeded(socket, getAccountBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_GET_ACCOUNT_BROADCAST_EVENT, [broadcastData], getAccountBroadcastConfig);
|
|
83
|
+
}
|
|
84
|
+
return { event: auth_events_constants_1.AUTH_GET_ACCOUNT_EVENT, data: account };
|
|
87
85
|
}
|
|
88
86
|
async updateAccount(socket, body) {
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
87
|
+
const account = socket.user ? await this.service.updateAccount(socket.user, body) : undefined;
|
|
88
|
+
if (updateAccountBroadcastConfig && account) {
|
|
89
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(account, updateAccountBroadcastConfig.fields);
|
|
90
|
+
this.broadcastIfNeeded(socket, updateAccountBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_UPDATE_ACCOUNT_BROADCAST_EVENT, [broadcastData], updateAccountBroadcastConfig);
|
|
91
|
+
}
|
|
92
|
+
return { event: auth_events_constants_1.AUTH_UPDATE_ACCOUNT_EVENT, data: account };
|
|
93
93
|
}
|
|
94
94
|
async login(socket, { [loginField]: login, [passwordField]: password }) {
|
|
95
95
|
if (login && password) {
|
|
@@ -101,24 +101,30 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
101
101
|
if (loginAbilityPredicate && !loginAbilityPredicate(socket.user)) {
|
|
102
102
|
throw new websockets_1.WsException('Access denied');
|
|
103
103
|
}
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
104
|
+
const result = await this.service.login(socket.user);
|
|
105
|
+
if (loginBroadcastConfig) {
|
|
106
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(socket.user, loginBroadcastConfig.fields);
|
|
107
|
+
this.broadcastIfNeeded(socket, loginBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_LOGIN_BROADCAST_EVENT, [broadcastData], loginBroadcastConfig);
|
|
108
|
+
}
|
|
109
|
+
return { event: auth_events_constants_1.AUTH_LOGIN_EVENT, data: result };
|
|
108
110
|
}
|
|
109
111
|
async register(socket, data) {
|
|
110
112
|
this.addUserToSocket(socket, !registerProtected && !registerAbilityPredicate);
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
113
|
+
const result = await this.service.register(data);
|
|
114
|
+
if (registerBroadcastConfig) {
|
|
115
|
+
const decoded = this.jwtService.decode(result.accessToken);
|
|
116
|
+
const { iat, exp, ...userPayload } = (decoded && typeof decoded !== 'string' ? decoded : {});
|
|
117
|
+
const broadcastData = (0, auth_broadcast_helper_1.buildAuthBroadcastData)(userPayload, registerBroadcastConfig.fields);
|
|
118
|
+
this.broadcastIfNeeded(socket, registerBroadcastConfig.eventName ?? auth_events_constants_1.AUTH_REGISTER_BROADCAST_EVENT, [broadcastData], registerBroadcastConfig);
|
|
119
|
+
}
|
|
120
|
+
return { event: auth_events_constants_1.AUTH_REGISTER_EVENT, data: result };
|
|
115
121
|
}
|
|
116
122
|
async resetPassword({ email }) {
|
|
117
123
|
if ((0, lodash_1.isEmpty)(resetPasswordOptions)) {
|
|
118
124
|
throw new websockets_1.WsException('This feature is not enabled');
|
|
119
125
|
}
|
|
120
126
|
return {
|
|
121
|
-
event:
|
|
127
|
+
event: auth_events_constants_1.AUTH_RESET_PASSWORD_EVENT,
|
|
122
128
|
data: await this.service.resetPassword(email),
|
|
123
129
|
};
|
|
124
130
|
}
|
|
@@ -127,15 +133,26 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
127
133
|
throw new websockets_1.WsException('This feature is not enabled');
|
|
128
134
|
}
|
|
129
135
|
return {
|
|
130
|
-
event:
|
|
136
|
+
event: auth_events_constants_1.AUTH_CHANGE_PASSWORD_EVENT,
|
|
131
137
|
data: await this.service.changePassword(resetPasswordToken, newPassword),
|
|
132
138
|
};
|
|
133
139
|
}
|
|
140
|
+
async refreshToken(socket) {
|
|
141
|
+
const rawToken = socket.handshake.query.refreshToken;
|
|
142
|
+
const result = socket.user ? await this.service.refreshToken(socket.user, rawToken) : undefined;
|
|
143
|
+
return { event: auth_events_constants_1.AUTH_REFRESH_TOKEN_EVENT, data: result };
|
|
144
|
+
}
|
|
145
|
+
async logout(socket) {
|
|
146
|
+
if (socket.user) {
|
|
147
|
+
await this.service.logout(socket.user);
|
|
148
|
+
}
|
|
149
|
+
return { event: auth_events_constants_1.AUTH_LOGOUT_EVENT, data: undefined };
|
|
150
|
+
}
|
|
134
151
|
}
|
|
135
152
|
__decorate([
|
|
136
153
|
(0, common_1.UseGuards)(new guards_1.JwtSocketAuthGuard()),
|
|
137
154
|
(0, common_1.UseInterceptors)(...getAccountUseInterceptors),
|
|
138
|
-
(0, websockets_1.SubscribeMessage)(
|
|
155
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_GET_ACCOUNT_EVENT),
|
|
139
156
|
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
140
157
|
__metadata("design:type", Function),
|
|
141
158
|
__metadata("design:paramtypes", [Object]),
|
|
@@ -144,7 +161,7 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
144
161
|
__decorate([
|
|
145
162
|
(0, common_1.UseGuards)(new guards_1.JwtSocketAuthGuard(), new AuthUpdateAccountPoliciesGuard()),
|
|
146
163
|
(0, common_1.UseInterceptors)(...updateAccountUseInterceptors),
|
|
147
|
-
(0, websockets_1.SubscribeMessage)(
|
|
164
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_UPDATE_ACCOUNT_EVENT),
|
|
148
165
|
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
149
166
|
__param(1, (0, websockets_1.MessageBody)()),
|
|
150
167
|
__metadata("design:type", Function),
|
|
@@ -153,7 +170,7 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
153
170
|
], BaseAuthGateway.prototype, "updateAccount", null);
|
|
154
171
|
__decorate([
|
|
155
172
|
(0, common_1.UseInterceptors)(...loginUseInterceptors),
|
|
156
|
-
(0, websockets_1.SubscribeMessage)(
|
|
173
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_LOGIN_EVENT),
|
|
157
174
|
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
158
175
|
__param(1, (0, websockets_1.MessageBody)()),
|
|
159
176
|
__metadata("design:type", Function),
|
|
@@ -163,7 +180,7 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
163
180
|
__decorate([
|
|
164
181
|
(0, common_1.UseGuards)(new AuthRegisterPoliciesGuard()),
|
|
165
182
|
(0, common_1.UseInterceptors)(...registerUseInterceptors),
|
|
166
|
-
(0, websockets_1.SubscribeMessage)(
|
|
183
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_REGISTER_EVENT),
|
|
167
184
|
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
168
185
|
__param(1, (0, websockets_1.MessageBody)()),
|
|
169
186
|
__metadata("design:type", Function),
|
|
@@ -173,7 +190,7 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
173
190
|
__decorate([
|
|
174
191
|
(0, common_1.UseGuards)(new guards_1.ResetPasswordGuard((0, helpers_1.isNotEmptyObject)(resetPasswordOptions))),
|
|
175
192
|
(0, common_1.UseInterceptors)(...resetPasswordUseInterceptors),
|
|
176
|
-
(0, websockets_1.SubscribeMessage)(
|
|
193
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_RESET_PASSWORD_EVENT),
|
|
177
194
|
__param(0, (0, websockets_1.MessageBody)()),
|
|
178
195
|
__metadata("design:type", Function),
|
|
179
196
|
__metadata("design:paramtypes", [reset_password_dto_1.ResetPasswordDto]),
|
|
@@ -182,13 +199,29 @@ function AuthGatewayMixin(userEntity, { loginField, passwordField, abilityPredic
|
|
|
182
199
|
__decorate([
|
|
183
200
|
(0, common_1.UseGuards)(new guards_1.ResetPasswordGuard((0, helpers_1.isNotEmptyObject)(resetPasswordOptions))),
|
|
184
201
|
(0, common_1.UseInterceptors)(...changePasswordUseInterceptors),
|
|
185
|
-
(0, websockets_1.SubscribeMessage)(
|
|
202
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_CHANGE_PASSWORD_EVENT),
|
|
186
203
|
__param(0, (0, websockets_1.MessageBody)()),
|
|
187
204
|
__metadata("design:type", Function),
|
|
188
205
|
__metadata("design:paramtypes", [change_password_dto_1.ChangePasswordDto]),
|
|
189
206
|
__metadata("design:returntype", Promise)
|
|
190
207
|
], BaseAuthGateway.prototype, "changePassword", null);
|
|
208
|
+
__decorate([
|
|
209
|
+
(0, common_1.UseGuards)(new guards_1.JwtSocketRefreshGuard()),
|
|
210
|
+
(0, common_1.UseInterceptors)(...refreshTokenUseInterceptors),
|
|
211
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_REFRESH_TOKEN_EVENT),
|
|
212
|
+
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
213
|
+
__metadata("design:type", Function),
|
|
214
|
+
__metadata("design:paramtypes", [Object]),
|
|
215
|
+
__metadata("design:returntype", Promise)
|
|
216
|
+
], BaseAuthGateway.prototype, "refreshToken", null);
|
|
217
|
+
__decorate([
|
|
218
|
+
(0, common_1.UseGuards)(new guards_1.JwtSocketRefreshGuard()),
|
|
219
|
+
(0, websockets_1.SubscribeMessage)(auth_events_constants_1.AUTH_LOGOUT_EVENT),
|
|
220
|
+
__param(0, (0, websockets_1.ConnectedSocket)()),
|
|
221
|
+
__metadata("design:type", Function),
|
|
222
|
+
__metadata("design:paramtypes", [Object]),
|
|
223
|
+
__metadata("design:returntype", Promise)
|
|
224
|
+
], BaseAuthGateway.prototype, "logout", null);
|
|
191
225
|
return BaseAuthGateway;
|
|
192
226
|
}
|
|
193
|
-
exports.AuthGatewayMixin = AuthGatewayMixin;
|
|
194
227
|
//# sourceMappingURL=auth-gateway.mixin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-gateway.mixin.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/auth/mixins/auth-gateway.mixin.ts"],"names":[],"mappings":"
|
|
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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"}
|
|
@@ -6,7 +6,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
6
6
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
7
|
};
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.
|
|
9
|
+
exports.AuthPoliciesGuardMixin = AuthPoliciesGuardMixin;
|
|
10
|
+
exports.AuthSocketPoliciesGuardMixin = AuthSocketPoliciesGuardMixin;
|
|
10
11
|
const common_1 = require("@nestjs/common");
|
|
11
12
|
const websockets_1 = require("@nestjs/websockets");
|
|
12
13
|
const guards_1 = require("../guards");
|
|
@@ -29,7 +30,6 @@ function AuthPoliciesGuardMixin(entity, abilityPredicate) {
|
|
|
29
30
|
], BaseAuthPoliciesGuard);
|
|
30
31
|
return BaseAuthPoliciesGuard;
|
|
31
32
|
}
|
|
32
|
-
exports.AuthPoliciesGuardMixin = AuthPoliciesGuardMixin;
|
|
33
33
|
function AuthSocketPoliciesGuardMixin(entity, abilityPredicate) {
|
|
34
34
|
let BaseAuthSocketPoliciesGuard = class BaseAuthSocketPoliciesGuard extends guards_1.JwtSocketAuthGuard {
|
|
35
35
|
constructor() {
|
|
@@ -54,5 +54,4 @@ function AuthSocketPoliciesGuardMixin(entity, abilityPredicate) {
|
|
|
54
54
|
], BaseAuthSocketPoliciesGuard);
|
|
55
55
|
return BaseAuthSocketPoliciesGuard;
|
|
56
56
|
}
|
|
57
|
-
exports.AuthSocketPoliciesGuardMixin = AuthSocketPoliciesGuardMixin;
|
|
58
57
|
//# sourceMappingURL=auth-policies-guard.mixin.js.map
|
|
@@ -1 +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":"
|
|
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":";;;;;;;;AA4DS,wDAAsB;AAAE,oEAA4B;AA5D7D,2CAAwF;AACxF,mDAAiD;AAGjD,sCAA+C;AAE/C,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,IAAI,EAAE,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;YAE3D,IAAI,IAAI,CAAC,gBAAgB,IAAI,CAC3B,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,CAC5C,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;AAED,SAAS,4BAA4B,CACnC,MAAoB,EACpB,gBAAkD;IAGlD,IAAM,2BAA2B,GAAjC,MAAM,2BAA4B,SAAQ,2BAAkB;QAA5D;;YACY,WAAM,GAAG,MAAM,CAAC;YAChB,qBAAgB,GAAG,gBAAgB,CAAC;QAiBhD,CAAC;QAfU,KAAK,CAAC,WAAW,CAAC,OAAyB;YAClD,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YAEpD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,MAAM,WAAW,GAAG,IAAI,CAAC,6BAA6B,CAAC,MAAM,CAAC,CAAC;gBAE/D,MAAM,CAAC,IAAI,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAC;gBAE3D,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;oBAC9D,MAAM,IAAI,wBAAW,CAAC,eAAe,CAAC,CAAC;gBACzC,CAAC;YACH,CAAC;YAED,OAAO,IAAI,CAAC;QACd,CAAC;KACF,CAAA;IAnBK,2BAA2B;QADhC,IAAA,mBAAU,GAAE;OACP,2BAA2B,CAmBhC;IAED,OAAO,2BAA2B,CAAC;AACrC,CAAC"}
|
|
@@ -1,28 +1,3 @@
|
|
|
1
|
-
/// <reference types="mongoose/types/aggregate" />
|
|
2
|
-
/// <reference types="mongoose/types/callback" />
|
|
3
|
-
/// <reference types="mongoose/types/collection" />
|
|
4
|
-
/// <reference types="mongoose/types/connection" />
|
|
5
|
-
/// <reference types="mongoose/types/cursor" />
|
|
6
|
-
/// <reference types="mongoose/types/document" />
|
|
7
|
-
/// <reference types="mongoose/types/error" />
|
|
8
|
-
/// <reference types="mongoose/types/expressions" />
|
|
9
|
-
/// <reference types="mongoose/types/helpers" />
|
|
10
|
-
/// <reference types="mongoose/types/middlewares" />
|
|
11
|
-
/// <reference types="mongoose/types/indexes" />
|
|
12
|
-
/// <reference types="mongoose/types/models" />
|
|
13
|
-
/// <reference types="mongoose/types/mongooseoptions" />
|
|
14
|
-
/// <reference types="mongoose/types/pipelinestage" />
|
|
15
|
-
/// <reference types="mongoose/types/populate" />
|
|
16
|
-
/// <reference types="mongoose/types/query" />
|
|
17
|
-
/// <reference types="mongoose/types/schemaoptions" />
|
|
18
|
-
/// <reference types="mongoose/types/schematypes" />
|
|
19
|
-
/// <reference types="mongoose/types/session" />
|
|
20
|
-
/// <reference types="mongoose/types/types" />
|
|
21
|
-
/// <reference types="mongoose/types/utility" />
|
|
22
|
-
/// <reference types="mongoose/types/validation" />
|
|
23
|
-
/// <reference types="mongoose/types/virtuals" />
|
|
24
|
-
/// <reference types="mongoose/types/inferschematype" />
|
|
25
|
-
/// <reference types="mongoose/types/inferrawdoctype" />
|
|
26
1
|
import { Type } from '@nestjs/common';
|
|
27
2
|
import { JwtService } from '@nestjs/jwt';
|
|
28
3
|
import { Model } from 'mongoose';
|
|
@@ -45,20 +20,29 @@ export declare abstract class BaseAuthService<Entity extends BaseEntity> extends
|
|
|
45
20
|
protected loginCallback: DynamicApiServiceCallback<Entity> | undefined;
|
|
46
21
|
protected getAccountCallback: DynamicApiServiceCallback<Entity> | undefined;
|
|
47
22
|
protected resetPasswordOptions: DynamicApiResetPasswordOptions<Entity> | undefined;
|
|
23
|
+
protected refreshTokenField: keyof Entity | undefined;
|
|
48
24
|
private resetPasswordCallbackMethods;
|
|
49
25
|
private readonly logger;
|
|
50
26
|
protected constructor(model: Model<Entity>, jwtService: JwtService, bcryptService: BcryptService);
|
|
51
27
|
protected validateUser(login: string, pass: string): Promise<Entity>;
|
|
52
28
|
protected login(user: Entity, fromMember?: boolean): Promise<{
|
|
53
29
|
accessToken: string;
|
|
30
|
+
refreshToken: string;
|
|
54
31
|
}>;
|
|
55
32
|
protected register(userToCreate: Partial<Entity>): Promise<{
|
|
56
33
|
accessToken: string;
|
|
34
|
+
refreshToken: string;
|
|
57
35
|
}>;
|
|
58
36
|
protected getAccount({ id }: Entity): Promise<Entity>;
|
|
59
37
|
protected updateAccount({ id }: Entity, update: Partial<Entity>): Promise<Entity>;
|
|
60
38
|
protected resetPassword(email: string): Promise<void>;
|
|
61
39
|
protected changePassword(resetPasswordToken: string, newPassword: string): Promise<void>;
|
|
40
|
+
protected refreshToken(user: Entity, rawToken?: string): Promise<{
|
|
41
|
+
accessToken: string;
|
|
42
|
+
refreshToken: string;
|
|
43
|
+
}>;
|
|
44
|
+
protected logout(user: Entity): Promise<void>;
|
|
45
|
+
private buildRefreshToken;
|
|
62
46
|
private buildUserFields;
|
|
63
47
|
private checkFieldsValidity;
|
|
64
48
|
}
|