@dofe/infra-common 0.1.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/dist/adapters/base.adapter.d.ts +84 -0
- package/dist/adapters/base.adapter.d.ts.map +1 -0
- package/dist/adapters/base.adapter.js +19 -0
- package/dist/adapters/base.adapter.js.map +1 -0
- package/dist/adapters/index.d.ts +35 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +53 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/common.module.d.ts +7 -0
- package/dist/common.module.d.ts.map +1 -0
- package/dist/common.module.js +26 -0
- package/dist/common.module.js.map +1 -0
- package/dist/config/agentx.config.d.ts +37 -0
- package/dist/config/agentx.config.d.ts.map +1 -0
- package/dist/config/agentx.config.js +81 -0
- package/dist/config/agentx.config.js.map +1 -0
- package/dist/config/configuration.d.ts +55 -0
- package/dist/config/configuration.d.ts.map +1 -0
- package/dist/config/configuration.js +336 -0
- package/dist/config/configuration.js.map +1 -0
- package/dist/config/constant/config.constants.d.ts +48 -0
- package/dist/config/constant/config.constants.d.ts.map +1 -0
- package/dist/config/constant/config.constants.js +86 -0
- package/dist/config/constant/config.constants.js.map +1 -0
- package/dist/config/dto/config.dto.d.ts +222 -0
- package/dist/config/dto/config.dto.d.ts.map +1 -0
- package/dist/config/dto/config.dto.js +42 -0
- package/dist/config/dto/config.dto.js.map +1 -0
- package/dist/config/env-config.service.d.ts +147 -0
- package/dist/config/env-config.service.d.ts.map +1 -0
- package/dist/config/env-config.service.js +296 -0
- package/dist/config/env-config.service.js.map +1 -0
- package/dist/config/features/feature-errors.d.ts +13 -0
- package/dist/config/features/feature-errors.d.ts.map +1 -0
- package/dist/config/features/feature-errors.js +25 -0
- package/dist/config/features/feature-errors.js.map +1 -0
- package/dist/config/features/feature-registry.d.ts +26 -0
- package/dist/config/features/feature-registry.d.ts.map +1 -0
- package/dist/config/features/feature-registry.js +172 -0
- package/dist/config/features/feature-registry.js.map +1 -0
- package/dist/config/features/index.d.ts +4 -0
- package/dist/config/features/index.d.ts.map +1 -0
- package/dist/config/features/index.js +9 -0
- package/dist/config/features/index.js.map +1 -0
- package/dist/config/validation/env.validation.d.ts +132 -0
- package/dist/config/validation/env.validation.d.ts.map +1 -0
- package/dist/config/validation/env.validation.js +304 -0
- package/dist/config/validation/env.validation.js.map +1 -0
- package/dist/config/validation/index.d.ts +21 -0
- package/dist/config/validation/index.d.ts.map +1 -0
- package/dist/config/validation/index.js +119 -0
- package/dist/config/validation/index.js.map +1 -0
- package/dist/config/validation/keys.validation.d.ts +884 -0
- package/dist/config/validation/keys.validation.d.ts.map +1 -0
- package/dist/config/validation/keys.validation.js +506 -0
- package/dist/config/validation/keys.validation.js.map +1 -0
- package/dist/config/validation/yaml.validation.d.ts +765 -0
- package/dist/config/validation/yaml.validation.d.ts.map +1 -0
- package/dist/config/validation/yaml.validation.js +488 -0
- package/dist/config/validation/yaml.validation.js.map +1 -0
- package/dist/config/vendor.config.d.ts +48 -0
- package/dist/config/vendor.config.d.ts.map +1 -0
- package/dist/config/vendor.config.js +136 -0
- package/dist/config/vendor.config.js.map +1 -0
- package/dist/decorators/api-key/api-key.decorator.d.ts +25 -0
- package/dist/decorators/api-key/api-key.decorator.d.ts.map +1 -0
- package/dist/decorators/api-key/api-key.decorator.js +30 -0
- package/dist/decorators/api-key/api-key.decorator.js.map +1 -0
- package/dist/decorators/api-key/index.d.ts +2 -0
- package/dist/decorators/api-key/index.d.ts.map +1 -0
- package/dist/decorators/api-key/index.js +18 -0
- package/dist/decorators/api-key/index.js.map +1 -0
- package/dist/decorators/app-version/app-version.controller.d.ts +30 -0
- package/dist/decorators/app-version/app-version.controller.d.ts.map +1 -0
- package/dist/decorators/app-version/app-version.controller.js +159 -0
- package/dist/decorators/app-version/app-version.controller.js.map +1 -0
- package/dist/decorators/app-version/app-version.interceptor.d.ts +15 -0
- package/dist/decorators/app-version/app-version.interceptor.d.ts.map +1 -0
- package/dist/decorators/app-version/app-version.interceptor.js +42 -0
- package/dist/decorators/app-version/app-version.interceptor.js.map +1 -0
- package/dist/decorators/app-version/app-version.module.d.ts +8 -0
- package/dist/decorators/app-version/app-version.module.d.ts.map +1 -0
- package/dist/decorators/app-version/app-version.module.js +39 -0
- package/dist/decorators/app-version/app-version.module.js.map +1 -0
- package/dist/decorators/app-version/app-version.service.d.ts +88 -0
- package/dist/decorators/app-version/app-version.service.d.ts.map +1 -0
- package/dist/decorators/app-version/app-version.service.js +251 -0
- package/dist/decorators/app-version/app-version.service.js.map +1 -0
- package/dist/decorators/app-version/index.d.ts +8 -0
- package/dist/decorators/app-version/index.d.ts.map +1 -0
- package/dist/decorators/app-version/index.js +15 -0
- package/dist/decorators/app-version/index.js.map +1 -0
- package/dist/decorators/audit-log.decorator.d.ts +41 -0
- package/dist/decorators/audit-log.decorator.d.ts.map +1 -0
- package/dist/decorators/audit-log.decorator.js +19 -0
- package/dist/decorators/audit-log.decorator.js.map +1 -0
- package/dist/decorators/cache/cache.decorator.d.ts +256 -0
- package/dist/decorators/cache/cache.decorator.d.ts.map +1 -0
- package/dist/decorators/cache/cache.decorator.js +339 -0
- package/dist/decorators/cache/cache.decorator.js.map +1 -0
- package/dist/decorators/cache/cache.interceptor.d.ts +43 -0
- package/dist/decorators/cache/cache.interceptor.d.ts.map +1 -0
- package/dist/decorators/cache/cache.interceptor.js +219 -0
- package/dist/decorators/cache/cache.interceptor.js.map +1 -0
- package/dist/decorators/cache/cache.module.d.ts +9 -0
- package/dist/decorators/cache/cache.module.d.ts.map +1 -0
- package/dist/decorators/cache/cache.module.js +36 -0
- package/dist/decorators/cache/cache.module.js.map +1 -0
- package/dist/decorators/cache/index.d.ts +7 -0
- package/dist/decorators/cache/index.d.ts.map +1 -0
- package/dist/decorators/cache/index.js +32 -0
- package/dist/decorators/cache/index.js.map +1 -0
- package/dist/decorators/data-visibility/data-visibility.decorator.d.ts +74 -0
- package/dist/decorators/data-visibility/data-visibility.decorator.d.ts.map +1 -0
- package/dist/decorators/data-visibility/data-visibility.decorator.js +87 -0
- package/dist/decorators/data-visibility/data-visibility.decorator.js.map +1 -0
- package/dist/decorators/data-visibility/index.d.ts +2 -0
- package/dist/decorators/data-visibility/index.d.ts.map +1 -0
- package/dist/decorators/data-visibility/index.js +18 -0
- package/dist/decorators/data-visibility/index.js.map +1 -0
- package/dist/decorators/event/event.decorator.d.ts +152 -0
- package/dist/decorators/event/event.decorator.d.ts.map +1 -0
- package/dist/decorators/event/event.decorator.js +158 -0
- package/dist/decorators/event/event.decorator.js.map +1 -0
- package/dist/decorators/event/event.interceptor.d.ts +23 -0
- package/dist/decorators/event/event.interceptor.d.ts.map +1 -0
- package/dist/decorators/event/event.interceptor.js +140 -0
- package/dist/decorators/event/event.interceptor.js.map +1 -0
- package/dist/decorators/event/event.module.d.ts +9 -0
- package/dist/decorators/event/event.module.d.ts.map +1 -0
- package/dist/decorators/event/event.module.js +59 -0
- package/dist/decorators/event/event.module.js.map +1 -0
- package/dist/decorators/event/handlers/cache-event.handler.d.ts +55 -0
- package/dist/decorators/event/handlers/cache-event.handler.d.ts.map +1 -0
- package/dist/decorators/event/handlers/cache-event.handler.js +159 -0
- package/dist/decorators/event/handlers/cache-event.handler.js.map +1 -0
- package/dist/decorators/event/index.d.ts +8 -0
- package/dist/decorators/event/index.d.ts.map +1 -0
- package/dist/decorators/event/index.js +26 -0
- package/dist/decorators/event/index.js.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.decorator.d.ts +144 -0
- package/dist/decorators/feature-flag/feature-flag.decorator.d.ts.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.decorator.js +135 -0
- package/dist/decorators/feature-flag/feature-flag.decorator.js.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.interceptor.d.ts +30 -0
- package/dist/decorators/feature-flag/feature-flag.interceptor.d.ts.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.interceptor.js +127 -0
- package/dist/decorators/feature-flag/feature-flag.interceptor.js.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.module.d.ts +9 -0
- package/dist/decorators/feature-flag/feature-flag.module.d.ts.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.module.js +39 -0
- package/dist/decorators/feature-flag/feature-flag.module.js.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.service.d.ts +102 -0
- package/dist/decorators/feature-flag/feature-flag.service.d.ts.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.service.js +373 -0
- package/dist/decorators/feature-flag/feature-flag.service.js.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.service.spec.d.ts +2 -0
- package/dist/decorators/feature-flag/feature-flag.service.spec.d.ts.map +1 -0
- package/dist/decorators/feature-flag/feature-flag.service.spec.js +264 -0
- package/dist/decorators/feature-flag/feature-flag.service.spec.js.map +1 -0
- package/dist/decorators/feature-flag/index.d.ts +8 -0
- package/dist/decorators/feature-flag/index.d.ts.map +1 -0
- package/dist/decorators/feature-flag/index.js +23 -0
- package/dist/decorators/feature-flag/index.js.map +1 -0
- package/dist/decorators/rate-limit/dto/rate-limit.dto.d.ts +174 -0
- package/dist/decorators/rate-limit/dto/rate-limit.dto.d.ts.map +1 -0
- package/dist/decorators/rate-limit/dto/rate-limit.dto.js +8 -0
- package/dist/decorators/rate-limit/dto/rate-limit.dto.js.map +1 -0
- package/dist/decorators/rate-limit/index.d.ts +24 -0
- package/dist/decorators/rate-limit/index.d.ts.map +1 -0
- package/dist/decorators/rate-limit/index.js +44 -0
- package/dist/decorators/rate-limit/index.js.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.constants.d.ts +16 -0
- package/dist/decorators/rate-limit/rate-limit.constants.d.ts.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.constants.js +22 -0
- package/dist/decorators/rate-limit/rate-limit.constants.js.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.decorator.d.ts +132 -0
- package/dist/decorators/rate-limit/rate-limit.decorator.d.ts.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.decorator.js +185 -0
- package/dist/decorators/rate-limit/rate-limit.decorator.js.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.exception.d.ts +39 -0
- package/dist/decorators/rate-limit/rate-limit.exception.d.ts.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.exception.js +67 -0
- package/dist/decorators/rate-limit/rate-limit.exception.js.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.module.d.ts +25 -0
- package/dist/decorators/rate-limit/rate-limit.module.d.ts.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.module.js +48 -0
- package/dist/decorators/rate-limit/rate-limit.module.js.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.service.d.ts +102 -0
- package/dist/decorators/rate-limit/rate-limit.service.d.ts.map +1 -0
- package/dist/decorators/rate-limit/rate-limit.service.js +390 -0
- package/dist/decorators/rate-limit/rate-limit.service.js.map +1 -0
- package/dist/decorators/response.decorator.d.ts +10 -0
- package/dist/decorators/response.decorator.d.ts.map +1 -0
- package/dist/decorators/response.decorator.js +58 -0
- package/dist/decorators/response.decorator.js.map +1 -0
- package/dist/decorators/skip-version-check.decorator.d.ts +25 -0
- package/dist/decorators/skip-version-check.decorator.d.ts.map +1 -0
- package/dist/decorators/skip-version-check.decorator.js +31 -0
- package/dist/decorators/skip-version-check.decorator.js.map +1 -0
- package/dist/decorators/tenant/index.d.ts +2 -0
- package/dist/decorators/tenant/index.d.ts.map +1 -0
- package/dist/decorators/tenant/index.js +18 -0
- package/dist/decorators/tenant/index.js.map +1 -0
- package/dist/decorators/tenant/tenant.decorator.d.ts +82 -0
- package/dist/decorators/tenant/tenant.decorator.d.ts.map +1 -0
- package/dist/decorators/tenant/tenant.decorator.js +98 -0
- package/dist/decorators/tenant/tenant.decorator.js.map +1 -0
- package/dist/decorators/transaction/index.d.ts +6 -0
- package/dist/decorators/transaction/index.d.ts.map +1 -0
- package/dist/decorators/transaction/index.js +12 -0
- package/dist/decorators/transaction/index.js.map +1 -0
- package/dist/decorators/transaction/transactional.decorator.d.ts +234 -0
- package/dist/decorators/transaction/transactional.decorator.d.ts.map +1 -0
- package/dist/decorators/transaction/transactional.decorator.js +433 -0
- package/dist/decorators/transaction/transactional.decorator.js.map +1 -0
- package/dist/decorators/ts-rest-controller.decorator.d.ts +38 -0
- package/dist/decorators/ts-rest-controller.decorator.d.ts.map +1 -0
- package/dist/decorators/ts-rest-controller.decorator.js +25 -0
- package/dist/decorators/ts-rest-controller.decorator.js.map +1 -0
- package/dist/decorators/validation.decorator.d.ts +4 -0
- package/dist/decorators/validation.decorator.d.ts.map +1 -0
- package/dist/decorators/validation.decorator.js +121 -0
- package/dist/decorators/validation.decorator.js.map +1 -0
- package/dist/decorators/version/index.d.ts +7 -0
- package/dist/decorators/version/index.d.ts.map +1 -0
- package/dist/decorators/version/index.js +25 -0
- package/dist/decorators/version/index.js.map +1 -0
- package/dist/decorators/version/version.decorator.d.ts +96 -0
- package/dist/decorators/version/version.decorator.d.ts.map +1 -0
- package/dist/decorators/version/version.decorator.js +146 -0
- package/dist/decorators/version/version.decorator.js.map +1 -0
- package/dist/decorators/version/version.interceptor.d.ts +19 -0
- package/dist/decorators/version/version.interceptor.d.ts.map +1 -0
- package/dist/decorators/version/version.interceptor.js +86 -0
- package/dist/decorators/version/version.interceptor.js.map +1 -0
- package/dist/decorators/version/version.module.d.ts +8 -0
- package/dist/decorators/version/version.module.d.ts.map +1 -0
- package/dist/decorators/version/version.module.js +33 -0
- package/dist/decorators/version/version.module.js.map +1 -0
- package/dist/encryption.service.d.ts +15 -0
- package/dist/encryption.service.d.ts.map +1 -0
- package/dist/encryption.service.js +35 -0
- package/dist/encryption.service.js.map +1 -0
- package/dist/enums/action.enum.d.ts +8 -0
- package/dist/enums/action.enum.d.ts.map +1 -0
- package/dist/enums/action.enum.js +12 -0
- package/dist/enums/action.enum.js.map +1 -0
- package/dist/enums/error-codes.d.ts +33 -0
- package/dist/enums/error-codes.d.ts.map +1 -0
- package/dist/enums/error-codes.js +52 -0
- package/dist/enums/error-codes.js.map +1 -0
- package/dist/enums/role.enum.d.ts +5 -0
- package/dist/enums/role.enum.d.ts.map +1 -0
- package/dist/enums/role.enum.js +9 -0
- package/dist/enums/role.enum.js.map +1 -0
- package/dist/filter/exception/api.exception.d.ts +77 -0
- package/dist/filter/exception/api.exception.d.ts.map +1 -0
- package/dist/filter/exception/api.exception.js +151 -0
- package/dist/filter/exception/api.exception.js.map +1 -0
- package/dist/filter/exception/exception.d.ts +8 -0
- package/dist/filter/exception/exception.d.ts.map +1 -0
- package/dist/filter/exception/exception.js +50 -0
- package/dist/filter/exception/exception.js.map +1 -0
- package/dist/filter/exception/http.exception.d.ts +11 -0
- package/dist/filter/exception/http.exception.d.ts.map +1 -0
- package/dist/filter/exception/http.exception.js +152 -0
- package/dist/filter/exception/http.exception.js.map +1 -0
- package/dist/guards/api-key.guard.d.ts +42 -0
- package/dist/guards/api-key.guard.d.ts.map +1 -0
- package/dist/guards/api-key.guard.js +159 -0
- package/dist/guards/api-key.guard.js.map +1 -0
- package/dist/guards/auth.guard.d.ts +39 -0
- package/dist/guards/auth.guard.d.ts.map +1 -0
- package/dist/guards/auth.guard.js +178 -0
- package/dist/guards/auth.guard.js.map +1 -0
- package/dist/guards/data-visibility.guard.d.ts +18 -0
- package/dist/guards/data-visibility.guard.d.ts.map +1 -0
- package/dist/guards/data-visibility.guard.js +84 -0
- package/dist/guards/data-visibility.guard.js.map +1 -0
- package/dist/guards/index.d.ts +7 -0
- package/dist/guards/index.d.ts.map +1 -0
- package/dist/guards/index.js +23 -0
- package/dist/guards/index.js.map +1 -0
- package/dist/guards/permission.guard.d.ts +20 -0
- package/dist/guards/permission.guard.d.ts.map +1 -0
- package/dist/guards/permission.guard.js +141 -0
- package/dist/guards/permission.guard.js.map +1 -0
- package/dist/guards/tenant-context.guard.d.ts +12 -0
- package/dist/guards/tenant-context.guard.d.ts.map +1 -0
- package/dist/guards/tenant-context.guard.js +94 -0
- package/dist/guards/tenant-context.guard.js.map +1 -0
- package/dist/guards/version.guard.d.ts +100 -0
- package/dist/guards/version.guard.d.ts.map +1 -0
- package/dist/guards/version.guard.js +233 -0
- package/dist/guards/version.guard.js.map +1 -0
- package/dist/index.d.ts +60 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +85 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptor/audit/audit-log.interceptor.d.ts +16 -0
- package/dist/interceptor/audit/audit-log.interceptor.d.ts.map +1 -0
- package/dist/interceptor/audit/audit-log.interceptor.js +156 -0
- package/dist/interceptor/audit/audit-log.interceptor.js.map +1 -0
- package/dist/interceptor/audit/index.d.ts +2 -0
- package/dist/interceptor/audit/index.d.ts.map +1 -0
- package/dist/interceptor/audit/index.js +18 -0
- package/dist/interceptor/audit/index.js.map +1 -0
- package/dist/interceptor/mask/index.d.ts +2 -0
- package/dist/interceptor/mask/index.d.ts.map +1 -0
- package/dist/interceptor/mask/index.js +18 -0
- package/dist/interceptor/mask/index.js.map +1 -0
- package/dist/interceptor/mask/mask.interceptor.d.ts +79 -0
- package/dist/interceptor/mask/mask.interceptor.d.ts.map +1 -0
- package/dist/interceptor/mask/mask.interceptor.js +197 -0
- package/dist/interceptor/mask/mask.interceptor.js.map +1 -0
- package/dist/interceptor/rate-limit/no-rate-limit.interceptor.d.ts +6 -0
- package/dist/interceptor/rate-limit/no-rate-limit.interceptor.d.ts.map +1 -0
- package/dist/interceptor/rate-limit/no-rate-limit.interceptor.js +20 -0
- package/dist/interceptor/rate-limit/no-rate-limit.interceptor.js.map +1 -0
- package/dist/interceptor/rate-limit/rate-limit.interceptor.d.ts +45 -0
- package/dist/interceptor/rate-limit/rate-limit.interceptor.d.ts.map +1 -0
- package/dist/interceptor/rate-limit/rate-limit.interceptor.js +193 -0
- package/dist/interceptor/rate-limit/rate-limit.interceptor.js.map +1 -0
- package/dist/interceptor/transform/transform.interceptor.d.ts +37 -0
- package/dist/interceptor/transform/transform.interceptor.d.ts.map +1 -0
- package/dist/interceptor/transform/transform.interceptor.js +72 -0
- package/dist/interceptor/transform/transform.interceptor.js.map +1 -0
- package/dist/interceptor/transform/transform.interceptor.spec.d.ts +2 -0
- package/dist/interceptor/transform/transform.interceptor.spec.d.ts.map +1 -0
- package/dist/interceptor/transform/transform.interceptor.spec.js +9 -0
- package/dist/interceptor/transform/transform.interceptor.spec.js.map +1 -0
- package/dist/interceptor/version/index.d.ts +2 -0
- package/dist/interceptor/version/index.d.ts.map +1 -0
- package/dist/interceptor/version/index.js +18 -0
- package/dist/interceptor/version/index.js.map +1 -0
- package/dist/interceptor/version/version-header.interceptor.d.ts +31 -0
- package/dist/interceptor/version/version-header.interceptor.d.ts.map +1 -0
- package/dist/interceptor/version/version-header.interceptor.js +62 -0
- package/dist/interceptor/version/version-header.interceptor.js.map +1 -0
- package/dist/middleware/request.middleware.d.ts +27 -0
- package/dist/middleware/request.middleware.d.ts.map +1 -0
- package/dist/middleware/request.middleware.js +141 -0
- package/dist/middleware/request.middleware.js.map +1 -0
- package/dist/middleware/tenant-isolation.middleware.d.ts +12 -0
- package/dist/middleware/tenant-isolation.middleware.d.ts.map +1 -0
- package/dist/middleware/tenant-isolation.middleware.js +51 -0
- package/dist/middleware/tenant-isolation.middleware.js.map +1 -0
- package/dist/pipes/transform-root.pipe.d.ts +5 -0
- package/dist/pipes/transform-root.pipe.d.ts.map +1 -0
- package/dist/pipes/transform-root.pipe.js +24 -0
- package/dist/pipes/transform-root.pipe.js.map +1 -0
- package/dist/ts-rest/index.d.ts +36 -0
- package/dist/ts-rest/index.d.ts.map +1 -0
- package/dist/ts-rest/index.js +65 -0
- package/dist/ts-rest/index.js.map +1 -0
- package/dist/ts-rest/response.helper.d.ts +261 -0
- package/dist/ts-rest/response.helper.d.ts.map +1 -0
- package/dist/ts-rest/response.helper.js +372 -0
- package/dist/ts-rest/response.helper.js.map +1 -0
- package/dist/utils/audit-log-helper.util.d.ts +41 -0
- package/dist/utils/audit-log-helper.util.d.ts.map +1 -0
- package/dist/utils/audit-log-helper.util.js +115 -0
- package/dist/utils/audit-log-helper.util.js.map +1 -0
- package/dist/utils/audit-signature.util.d.ts +64 -0
- package/dist/utils/audit-signature.util.d.ts.map +1 -0
- package/dist/utils/audit-signature.util.js +155 -0
- package/dist/utils/audit-signature.util.js.map +1 -0
- package/dist/utils/prisma-error.util.d.ts +160 -0
- package/dist/utils/prisma-error.util.d.ts.map +1 -0
- package/dist/utils/prisma-error.util.js +342 -0
- package/dist/utils/prisma-error.util.js.map +1 -0
- package/package.json +54 -0
|
@@ -0,0 +1,159 @@
|
|
|
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.ApiKeyGuard = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const core_1 = require("@nestjs/core");
|
|
18
|
+
const nest_winston_1 = require("nest-winston");
|
|
19
|
+
const winston_1 = require("winston");
|
|
20
|
+
const api_key_decorator_1 = require("@/common/decorators/api-key/api-key.decorator");
|
|
21
|
+
const API_KEY_HEADER = 'x-api-key';
|
|
22
|
+
const SERVICE_NAME_HEADER = 'x-service-name';
|
|
23
|
+
/**
|
|
24
|
+
* API Key 守卫
|
|
25
|
+
* 允许使用有效的 API Key 跳过部分验证(如用户认证、租户验证等)
|
|
26
|
+
*
|
|
27
|
+
* 安全特性:
|
|
28
|
+
* 1. API Key 必须预定义在环境变量中
|
|
29
|
+
* 2. 记录所有 API Key 调用日志
|
|
30
|
+
* 3. 支持可选的租户强制验证
|
|
31
|
+
*/
|
|
32
|
+
let ApiKeyGuard = class ApiKeyGuard {
|
|
33
|
+
reflector;
|
|
34
|
+
logger;
|
|
35
|
+
validApiKeys;
|
|
36
|
+
enabled;
|
|
37
|
+
constructor(reflector, logger) {
|
|
38
|
+
this.reflector = reflector;
|
|
39
|
+
this.logger = logger;
|
|
40
|
+
// 从环境变量加载 API Key(支持多个,逗号分隔)
|
|
41
|
+
const apiKeyString = process.env.INTERNAL_API_KEYS || process.env.INTERNAL_API_KEY || '';
|
|
42
|
+
this.validApiKeys = new Set(apiKeyString
|
|
43
|
+
.split(',')
|
|
44
|
+
.map((k) => k.trim())
|
|
45
|
+
.filter(Boolean));
|
|
46
|
+
this.enabled = this.validApiKeys.size > 0;
|
|
47
|
+
this.logger.info('ApiKeyGuard initialized', {
|
|
48
|
+
keyCount: this.validApiKeys.size,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
async canActivate(context) {
|
|
52
|
+
// 如果没有配置 API Key,跳过此守卫
|
|
53
|
+
if (!this.enabled) {
|
|
54
|
+
return true;
|
|
55
|
+
}
|
|
56
|
+
const request = context.switchToHttp().getRequest();
|
|
57
|
+
// 检查当前处理方法是否允许 API Key 访问
|
|
58
|
+
const allowApiKey = this.reflector.getAllAndOverride(api_key_decorator_1.ALLOW_API_KEY_KEY, [context.getHandler(), context.getClass()]);
|
|
59
|
+
if (!allowApiKey) {
|
|
60
|
+
return true; // 不允许 API Key,继续其他验证
|
|
61
|
+
}
|
|
62
|
+
const apiKey = this.extractApiKey(request);
|
|
63
|
+
if (!apiKey) {
|
|
64
|
+
return true; // 无 API Key,继续正常验证流程
|
|
65
|
+
}
|
|
66
|
+
// 验证 API Key
|
|
67
|
+
if (!this.validateApiKey(apiKey, request)) {
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
// 设置内部服务标识
|
|
71
|
+
this.setInternalServiceContext(request, apiKey);
|
|
72
|
+
this.logger.info('API key authenticated successfully', {
|
|
73
|
+
service: request.headers[SERVICE_NAME_HEADER] || 'unknown',
|
|
74
|
+
ip: request.ip,
|
|
75
|
+
tenantId: request.headers['x-current-tenant'] || 'none',
|
|
76
|
+
});
|
|
77
|
+
return true;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 从请求中提取 API Key
|
|
81
|
+
* 支持从 header 或 query 参数获取
|
|
82
|
+
*/
|
|
83
|
+
extractApiKey(request) {
|
|
84
|
+
// 优先从 header 获取
|
|
85
|
+
const headerApiKey = request.headers[API_KEY_HEADER];
|
|
86
|
+
if (headerApiKey) {
|
|
87
|
+
return headerApiKey;
|
|
88
|
+
}
|
|
89
|
+
// 从 query 参数获取(不推荐,仅用于某些特殊场景)
|
|
90
|
+
const queryApiKey = request.query?.api_key;
|
|
91
|
+
if (queryApiKey) {
|
|
92
|
+
return queryApiKey;
|
|
93
|
+
}
|
|
94
|
+
return undefined;
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* 验证 API Key
|
|
98
|
+
*/
|
|
99
|
+
validateApiKey(apiKey, request) {
|
|
100
|
+
// 检查 API Key 是否有效
|
|
101
|
+
if (!this.validApiKeys.has(apiKey)) {
|
|
102
|
+
this.logger.error('Invalid API key used', {
|
|
103
|
+
apiKey: this.maskApiKey(apiKey),
|
|
104
|
+
ip: request.ip,
|
|
105
|
+
userAgent: request.headers['user-agent'],
|
|
106
|
+
service: request.headers[SERVICE_NAME_HEADER],
|
|
107
|
+
path: request.url,
|
|
108
|
+
});
|
|
109
|
+
return false;
|
|
110
|
+
}
|
|
111
|
+
return true;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* 设置内部服务上下文
|
|
115
|
+
*/
|
|
116
|
+
setInternalServiceContext(request, apiKey) {
|
|
117
|
+
// 标记为内部服务
|
|
118
|
+
request.isInternalService = true;
|
|
119
|
+
// 设置服务名称
|
|
120
|
+
const serviceName = request.headers[SERVICE_NAME_HEADER];
|
|
121
|
+
request.internalServiceName = serviceName || 'unknown';
|
|
122
|
+
// 设置 API Key 标识(用于审计)
|
|
123
|
+
request.apiKeyId = this.getKeyId(apiKey);
|
|
124
|
+
// 跳过租户验证(但仍需解析租户用于数据隔离)
|
|
125
|
+
request.skipTenantCheck = true;
|
|
126
|
+
// 强制要求租户 Header(防止跨租户访问)
|
|
127
|
+
const headerTenantId = request.headers['x-current-tenant'];
|
|
128
|
+
if (process.env.INTERNAL_API_REQUIRE_TENANT === 'true' && !headerTenantId) {
|
|
129
|
+
this.logger.warn('API key used without required tenant header', {
|
|
130
|
+
service: serviceName,
|
|
131
|
+
path: request.url,
|
|
132
|
+
});
|
|
133
|
+
throw new Error('Tenant header (x-current-tenant) is required');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* 遮蔽 API Key 用于日志记录
|
|
138
|
+
*/
|
|
139
|
+
maskApiKey(apiKey) {
|
|
140
|
+
if (apiKey.length <= 8) {
|
|
141
|
+
return '****';
|
|
142
|
+
}
|
|
143
|
+
return `${apiKey.substring(0, 4)}...${apiKey.substring(apiKey.length - 4)}`;
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* 获取 API Key 标识符(用于区分不同的 Key)
|
|
147
|
+
*/
|
|
148
|
+
getKeyId(apiKey) {
|
|
149
|
+
return this.maskApiKey(apiKey);
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
exports.ApiKeyGuard = ApiKeyGuard;
|
|
153
|
+
exports.ApiKeyGuard = ApiKeyGuard = __decorate([
|
|
154
|
+
(0, common_1.Injectable)(),
|
|
155
|
+
__param(1, (0, common_1.Inject)(nest_winston_1.WINSTON_MODULE_PROVIDER)),
|
|
156
|
+
__metadata("design:paramtypes", [core_1.Reflector,
|
|
157
|
+
winston_1.Logger])
|
|
158
|
+
], ApiKeyGuard);
|
|
159
|
+
//# sourceMappingURL=api-key.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-key.guard.js","sourceRoot":"","sources":["../../src/guards/api-key.guard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { JwtService } from '@nestjs/jwt';
|
|
3
|
+
import { ConfigService } from '@nestjs/config';
|
|
4
|
+
import { Reflector } from '@nestjs/core';
|
|
5
|
+
import { Logger } from 'winston';
|
|
6
|
+
import { RedisService } from '@dofe/infra-redis';
|
|
7
|
+
import { UserInfoService } from '@app/db';
|
|
8
|
+
/**
|
|
9
|
+
* Auth Guard Token - 用于注入 AuthService
|
|
10
|
+
*/
|
|
11
|
+
export declare const AUTH_SERVICE_TOKEN = "AUTH_SERVICE";
|
|
12
|
+
/**
|
|
13
|
+
* Auth Service Interface - 用于解耦 infra 和 domain
|
|
14
|
+
*/
|
|
15
|
+
export interface IAuthService {
|
|
16
|
+
extractTokenFromHeader(request: {
|
|
17
|
+
headers: Record<string, string | string[] | undefined>;
|
|
18
|
+
}): string | undefined;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* AuthGuard - 认证守卫
|
|
22
|
+
*
|
|
23
|
+
* 位于 infra 层,通过依赖注入接收 AuthService 实现
|
|
24
|
+
* 避免直接依赖 domain 层
|
|
25
|
+
*/
|
|
26
|
+
export declare class AuthGuard implements CanActivate {
|
|
27
|
+
private readonly auth;
|
|
28
|
+
private readonly jwt;
|
|
29
|
+
private readonly config;
|
|
30
|
+
private readonly reflector;
|
|
31
|
+
private readonly redis;
|
|
32
|
+
private readonly user;
|
|
33
|
+
private readonly logger;
|
|
34
|
+
private readonly outOfAnonymityPathConfig;
|
|
35
|
+
private readonly outOfUserPathConfig;
|
|
36
|
+
constructor(auth: IAuthService, jwt: JwtService, config: ConfigService, reflector: Reflector, redis: RedisService, user: UserInfoService, logger: Logger);
|
|
37
|
+
canActivate(context: ExecutionContext): Promise<boolean>;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=auth.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.guard.d.ts","sourceRoot":"","sources":["../../src/guards/auth.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,gBAAgB,EAGjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAIjC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAO1C;;GAEG;AACH,eAAO,MAAM,kBAAkB,iBAAiB,CAAC;AAEjD;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,sBAAsB,CAAC,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,CAAA;KAAE,GAAG,MAAM,GAAG,SAAS,CAAC;CACjH;AAED;;;;;GAKG;AACH,qBACa,SAAU,YAAW,WAAW;IAMzC,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,IAAI;IACY,OAAO,CAAC,QAAQ,CAAC,MAAM;IAX1D,OAAO,CAAC,QAAQ,CAAC,wBAAwB,CAAC;IAC1C,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAC;gBAIlB,IAAI,EAAE,YAAY,EAClB,GAAG,EAAE,UAAU,EACf,MAAM,EAAE,aAAa,EACrB,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,YAAY,EACnB,IAAI,EAAE,eAAe,EACY,MAAM,EAAE,MAAM;IAc5D,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAyI/D"}
|
|
@@ -0,0 +1,178 @@
|
|
|
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
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
15
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
16
|
+
};
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.AuthGuard = exports.AUTH_SERVICE_TOKEN = void 0;
|
|
19
|
+
const common_1 = require("@nestjs/common");
|
|
20
|
+
const jwt_1 = require("@nestjs/jwt");
|
|
21
|
+
const config_1 = require("@nestjs/config");
|
|
22
|
+
const core_1 = require("@nestjs/core");
|
|
23
|
+
const nest_winston_1 = require("nest-winston");
|
|
24
|
+
const winston_1 = require("winston");
|
|
25
|
+
const infra_contracts_1 = require("@dofe/infra-contracts");
|
|
26
|
+
const infra_contracts_2 = require("@dofe/infra-contracts");
|
|
27
|
+
const infra_redis_1 = require("@dofe/infra-redis");
|
|
28
|
+
const db_1 = require("@app/db");
|
|
29
|
+
const string_util_1 = __importDefault(require("@dofe/infra-utils/string.util"));
|
|
30
|
+
const environment_util_1 = __importDefault(require("@dofe/infra-utils/environment.util"));
|
|
31
|
+
const env_config_service_1 = require("@/config/env-config.service");
|
|
32
|
+
const api_exception_1 = require("@/filter/exception/api.exception");
|
|
33
|
+
/**
|
|
34
|
+
* Auth Guard Token - 用于注入 AuthService
|
|
35
|
+
*/
|
|
36
|
+
exports.AUTH_SERVICE_TOKEN = 'AUTH_SERVICE';
|
|
37
|
+
/**
|
|
38
|
+
* AuthGuard - 认证守卫
|
|
39
|
+
*
|
|
40
|
+
* 位于 infra 层,通过依赖注入接收 AuthService 实现
|
|
41
|
+
* 避免直接依赖 domain 层
|
|
42
|
+
*/
|
|
43
|
+
let AuthGuard = class AuthGuard {
|
|
44
|
+
auth;
|
|
45
|
+
jwt;
|
|
46
|
+
config;
|
|
47
|
+
reflector;
|
|
48
|
+
redis;
|
|
49
|
+
user;
|
|
50
|
+
logger;
|
|
51
|
+
outOfAnonymityPathConfig;
|
|
52
|
+
outOfUserPathConfig;
|
|
53
|
+
constructor(auth, jwt, config, reflector, redis, user, logger) {
|
|
54
|
+
this.auth = auth;
|
|
55
|
+
this.jwt = jwt;
|
|
56
|
+
this.config = config;
|
|
57
|
+
this.reflector = reflector;
|
|
58
|
+
this.redis = redis;
|
|
59
|
+
this.user = user;
|
|
60
|
+
this.logger = logger;
|
|
61
|
+
// 这两个配置在早期版本的 YAML 中存在,但当前模板中是可选的
|
|
62
|
+
// 为了在本地/开发环境下更好地降级,这里给出空对象默认值
|
|
63
|
+
this.outOfAnonymityPathConfig =
|
|
64
|
+
this.config.get('outOfAnonymityPath') ?? {};
|
|
65
|
+
this.outOfUserPathConfig =
|
|
66
|
+
this.config.get('outOfUserPath') ?? {};
|
|
67
|
+
}
|
|
68
|
+
async canActivate(context) {
|
|
69
|
+
const request = context.switchToHttp().getRequest();
|
|
70
|
+
const _response = context.switchToHttp().getResponse();
|
|
71
|
+
const requestMethod = request.method.toLowerCase();
|
|
72
|
+
const requestPath = string_util_1.default.trimSlashes(string_util_1.default.splitString(request.url, '?')[0]);
|
|
73
|
+
// 检查是否在白名单路径中
|
|
74
|
+
if (this.outOfUserPathConfig[requestMethod]?.some((path) => new RegExp(`^${path.replace(/:\w+/g, '[^/]+')}$`).test(requestPath.replace('api/', '')))) {
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
// 检查是否标记为公开端点(@Public() 装饰器)
|
|
78
|
+
const isPublic = this.reflector.getAllAndOverride(infra_contracts_2.PUBLIC_ENDPOINT_KEY, [context.getHandler(), context.getClass()]);
|
|
79
|
+
if (isPublic)
|
|
80
|
+
return true;
|
|
81
|
+
// 从方法处理器获取元数据
|
|
82
|
+
let authTypes = this.reflector.get('auths', context.getHandler());
|
|
83
|
+
if (!authTypes) {
|
|
84
|
+
authTypes = this.reflector.get('auths', context.getClass());
|
|
85
|
+
}
|
|
86
|
+
const [authType = 'api', guardType = 'api'] = authTypes || ['api', 'api'];
|
|
87
|
+
const isMpTest = request.headers[infra_contracts_2.MPTRAIL_HEADER] === 'true';
|
|
88
|
+
let userId, isAdmin = false, isAnonymity = false;
|
|
89
|
+
if (!env_config_service_1.featureConfig.modeUserId) {
|
|
90
|
+
let access;
|
|
91
|
+
if (guardType === 'sse') {
|
|
92
|
+
access = decodeURIComponent(request.query['access_token']);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
access = this.auth.extractTokenFromHeader(request);
|
|
96
|
+
if (!access) {
|
|
97
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (!access) {
|
|
101
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
102
|
+
}
|
|
103
|
+
let payload;
|
|
104
|
+
try {
|
|
105
|
+
const jwtConfig = this.config.getOrThrow('jwt');
|
|
106
|
+
payload = await this.jwt.verifyAsync(access, {
|
|
107
|
+
secret: jwtConfig.secret,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
catch (_error) {
|
|
111
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
112
|
+
}
|
|
113
|
+
userId = payload?.sub;
|
|
114
|
+
isAnonymity = payload?.isAnonymity;
|
|
115
|
+
isAdmin = payload?.isAdmin;
|
|
116
|
+
if (isAnonymity) {
|
|
117
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
118
|
+
}
|
|
119
|
+
// 将 JWT payload 中的用户信息设置到 request 中
|
|
120
|
+
request.userInfo = {
|
|
121
|
+
id: userId,
|
|
122
|
+
nickname: payload?.nickname,
|
|
123
|
+
code: payload?.code,
|
|
124
|
+
headerImg: payload?.headerImg,
|
|
125
|
+
sex: payload?.sex,
|
|
126
|
+
isAdmin: isAdmin,
|
|
127
|
+
isAnonymity: isAnonymity,
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
if ((0, env_config_service_1.isProduction)()) {
|
|
132
|
+
this.logger.error('CRITICAL SECURITY ERROR: MODE_USER_ID is set in prod environment!');
|
|
133
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
134
|
+
}
|
|
135
|
+
this.logger.warn('Auth Guard is running in insecure bypass mode. DO NOT USE IN PROD.');
|
|
136
|
+
this.logger.warn(`Bypass mode activated with userId: ${env_config_service_1.featureConfig.modeUserId}`);
|
|
137
|
+
userId = env_config_service_1.featureConfig.modeUserId;
|
|
138
|
+
isAdmin = true;
|
|
139
|
+
isAnonymity = false;
|
|
140
|
+
}
|
|
141
|
+
if (!userId) {
|
|
142
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
143
|
+
}
|
|
144
|
+
if (request.method.toLowerCase() === 'post' &&
|
|
145
|
+
process.env?.PREVIEW_MODE === 'true' &&
|
|
146
|
+
environment_util_1.default.isWeChatMiniProgram(request) &&
|
|
147
|
+
isMpTest &&
|
|
148
|
+
process.env?.PREVIEW_USER_ID) {
|
|
149
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
150
|
+
}
|
|
151
|
+
if (authType === 'admin' && !isAdmin) {
|
|
152
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
153
|
+
}
|
|
154
|
+
// 检查匿名用户访问限制
|
|
155
|
+
if (this.outOfAnonymityPathConfig[requestMethod]?.some((path) => new RegExp(`^${path.replace(/:\w+/g, '[^/]+')}$`).test(requestPath.replace('api/', ''))) &&
|
|
156
|
+
request.isAnonymity) {
|
|
157
|
+
throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
|
|
158
|
+
}
|
|
159
|
+
// 将用户信息设置到request对象中
|
|
160
|
+
request.userId = userId;
|
|
161
|
+
request.isAnonymity = isAnonymity;
|
|
162
|
+
request.isAdmin = isAdmin;
|
|
163
|
+
return true;
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
exports.AuthGuard = AuthGuard;
|
|
167
|
+
exports.AuthGuard = AuthGuard = __decorate([
|
|
168
|
+
(0, common_1.Injectable)(),
|
|
169
|
+
__param(0, (0, common_1.Inject)(exports.AUTH_SERVICE_TOKEN)),
|
|
170
|
+
__param(6, (0, common_1.Inject)(nest_winston_1.WINSTON_MODULE_PROVIDER)),
|
|
171
|
+
__metadata("design:paramtypes", [Object, jwt_1.JwtService,
|
|
172
|
+
config_1.ConfigService,
|
|
173
|
+
core_1.Reflector,
|
|
174
|
+
infra_redis_1.RedisService,
|
|
175
|
+
db_1.UserInfoService,
|
|
176
|
+
winston_1.Logger])
|
|
177
|
+
], AuthGuard);
|
|
178
|
+
//# sourceMappingURL=auth.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.guard.js","sourceRoot":"","sources":["../../src/guards/auth.guard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { Logger } from 'winston';
|
|
4
|
+
import { OrganizationPermissionService } from '@app/tenant-management/organization-permission';
|
|
5
|
+
/**
|
|
6
|
+
* 数据可见性 Guard
|
|
7
|
+
*
|
|
8
|
+
* 根据用户角色自动解析数据可见范围,并注入到 request.dataScope 中
|
|
9
|
+
* 供后续 Service 层使用
|
|
10
|
+
*/
|
|
11
|
+
export declare class DataVisibilityGuard implements CanActivate {
|
|
12
|
+
private readonly reflector;
|
|
13
|
+
private readonly permissionService;
|
|
14
|
+
private readonly logger;
|
|
15
|
+
constructor(reflector: Reflector, permissionService: OrganizationPermissionService, logger: Logger);
|
|
16
|
+
canActivate(context: ExecutionContext): Promise<boolean>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data-visibility.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-visibility.guard.d.ts","sourceRoot":"","sources":["../../src/guards/data-visibility.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAEjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,6BAA6B,EAAE,MAAM,gDAAgD,CAAC;AAI/F;;;;;GAKG;AACH,qBACa,mBAAoB,YAAW,WAAW;IAEnD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IACD,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAFvC,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,6BAA6B,EACf,MAAM,EAAE,MAAM;IAG5D,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAoD/D"}
|
|
@@ -0,0 +1,84 @@
|
|
|
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.DataVisibilityGuard = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const core_1 = require("@nestjs/core");
|
|
18
|
+
const nest_winston_1 = require("nest-winston");
|
|
19
|
+
const winston_1 = require("winston");
|
|
20
|
+
const organization_permission_1 = require("@app/tenant-management/organization-permission");
|
|
21
|
+
const data_visibility_1 = require("@/common/decorators/data-visibility");
|
|
22
|
+
/**
|
|
23
|
+
* 数据可见性 Guard
|
|
24
|
+
*
|
|
25
|
+
* 根据用户角色自动解析数据可见范围,并注入到 request.dataScope 中
|
|
26
|
+
* 供后续 Service 层使用
|
|
27
|
+
*/
|
|
28
|
+
let DataVisibilityGuard = class DataVisibilityGuard {
|
|
29
|
+
reflector;
|
|
30
|
+
permissionService;
|
|
31
|
+
logger;
|
|
32
|
+
constructor(reflector, permissionService, logger) {
|
|
33
|
+
this.reflector = reflector;
|
|
34
|
+
this.permissionService = permissionService;
|
|
35
|
+
this.logger = logger;
|
|
36
|
+
}
|
|
37
|
+
async canActivate(context) {
|
|
38
|
+
const request = context.switchToHttp().getRequest();
|
|
39
|
+
// 获取资源类型
|
|
40
|
+
const resourceType = this.reflector.getAllAndOverride(data_visibility_1.DATA_VISIBILITY_KEY, [context.getHandler(), context.getClass()]);
|
|
41
|
+
// 如果没有设置资源类型,不需要处理可见性
|
|
42
|
+
if (!resourceType) {
|
|
43
|
+
return true;
|
|
44
|
+
}
|
|
45
|
+
// 获取用户信息
|
|
46
|
+
const userId = request.userId;
|
|
47
|
+
const tenantId = request.tenantId;
|
|
48
|
+
const isAdmin = request.isAdmin;
|
|
49
|
+
// 如果没有用户信息(公共端点),跳过可见性注入
|
|
50
|
+
if (!userId || !tenantId) {
|
|
51
|
+
this.logger.debug('No user context, skipping data visibility resolution', {
|
|
52
|
+
resourceType,
|
|
53
|
+
});
|
|
54
|
+
return true;
|
|
55
|
+
}
|
|
56
|
+
// 解析数据可见范围
|
|
57
|
+
const dataScope = await this.permissionService.resolveDataScope({
|
|
58
|
+
userId,
|
|
59
|
+
tenantId,
|
|
60
|
+
resourceType,
|
|
61
|
+
isSystemAdmin: isAdmin,
|
|
62
|
+
});
|
|
63
|
+
// 注入到请求上下文
|
|
64
|
+
request.dataScope = dataScope;
|
|
65
|
+
this.logger.debug('Data visibility resolved', {
|
|
66
|
+
userId,
|
|
67
|
+
tenantId,
|
|
68
|
+
resourceType,
|
|
69
|
+
scopeType: dataScope.type,
|
|
70
|
+
departmentCount: dataScope.departmentIds?.length ?? 0,
|
|
71
|
+
teamCount: dataScope.teamIds?.length ?? 0,
|
|
72
|
+
});
|
|
73
|
+
return true;
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
exports.DataVisibilityGuard = DataVisibilityGuard;
|
|
77
|
+
exports.DataVisibilityGuard = DataVisibilityGuard = __decorate([
|
|
78
|
+
(0, common_1.Injectable)(),
|
|
79
|
+
__param(2, (0, common_1.Inject)(nest_winston_1.WINSTON_MODULE_PROVIDER)),
|
|
80
|
+
__metadata("design:paramtypes", [core_1.Reflector,
|
|
81
|
+
organization_permission_1.OrganizationPermissionService,
|
|
82
|
+
winston_1.Logger])
|
|
83
|
+
], DataVisibilityGuard);
|
|
84
|
+
//# sourceMappingURL=data-visibility.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-visibility.guard.js","sourceRoot":"","sources":["../../src/guards/data-visibility.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAKwB;AACxB,uCAAyC;AACzC,+CAAuD;AACvD,qCAAiC;AAEjC,4FAA+F;AAC/F,yEAA0E;AAG1E;;;;;GAKG;AAEI,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAEX;IACA;IACiC;IAHpD,YACmB,SAAoB,EACpB,iBAAgD,EACf,MAAc;QAF/C,cAAS,GAAT,SAAS,CAAW;QACpB,sBAAiB,GAAjB,iBAAiB,CAA+B;QACf,WAAM,GAAN,MAAM,CAAQ;IAC/D,CAAC;IAEJ,KAAK,CAAC,WAAW,CAAC,OAAyB;QACzC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAkB,CAAC;QAEpE,SAAS;QACT,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CACnD,qCAAmB,EACnB,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAC3C,CAAC;QAEF,sBAAsB;QACtB,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,SAAS;QACT,MAAM,MAAM,GAAI,OAAe,CAAC,MAAM,CAAC;QACvC,MAAM,QAAQ,GAAI,OAAe,CAAC,QAAQ,CAAC;QAC3C,MAAM,OAAO,GAAI,OAAe,CAAC,OAAO,CAAC;QAEzC,yBAAyB;QACzB,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzB,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,sDAAsD,EACtD;gBACE,YAAY;aACb,CACF,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC;QAED,WAAW;QACX,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC;YAC9D,MAAM;YACN,QAAQ;YACR,YAAY;YACZ,aAAa,EAAE,OAAO;SACvB,CAAC,CAAC;QAEH,WAAW;QACV,OAAe,CAAC,SAAS,GAAG,SAAS,CAAC;QAEvC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE;YAC5C,MAAM;YACN,QAAQ;YACR,YAAY;YACZ,SAAS,EAAE,SAAS,CAAC,IAAI;YACzB,eAAe,EAAE,SAAS,CAAC,aAAa,EAAE,MAAM,IAAI,CAAC;YACrD,SAAS,EAAE,SAAS,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC;SAC1C,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AA3DY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,mBAAU,GAAE;IAKR,WAAA,IAAA,eAAM,EAAC,sCAAuB,CAAC,CAAA;qCAFJ,gBAAS;QACD,uDAA6B;QACP,gBAAM;GAJvD,mBAAmB,CA2D/B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/guards/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./version.guard"), exports);
|
|
18
|
+
__exportStar(require("./tenant-context.guard"), exports);
|
|
19
|
+
__exportStar(require("./permission.guard"), exports);
|
|
20
|
+
__exportStar(require("./auth.guard"), exports);
|
|
21
|
+
__exportStar(require("./api-key.guard"), exports);
|
|
22
|
+
__exportStar(require("./data-visibility.guard"), exports);
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/guards/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,yDAAuC;AACvC,qDAAmC;AACnC,+CAA6B;AAC7B,kDAAgC;AAChC,0DAAwC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { Logger } from 'winston';
|
|
4
|
+
import { JwtService } from '@nestjs/jwt';
|
|
5
|
+
import { ConfigService } from '@nestjs/config';
|
|
6
|
+
import { OrganizationPermissionService } from '@app/tenant-management/organization-permission';
|
|
7
|
+
export declare class PermissionGuard implements CanActivate {
|
|
8
|
+
private readonly reflector;
|
|
9
|
+
private readonly permissionService;
|
|
10
|
+
private readonly jwtService;
|
|
11
|
+
private readonly configService;
|
|
12
|
+
private readonly logger;
|
|
13
|
+
constructor(reflector: Reflector, permissionService: OrganizationPermissionService, jwtService: JwtService, configService: ConfigService, logger: Logger);
|
|
14
|
+
/**
|
|
15
|
+
* 从 Authorization header 中提取并验证 JWT token
|
|
16
|
+
*/
|
|
17
|
+
private extractUserFromToken;
|
|
18
|
+
canActivate(context: ExecutionContext): Promise<boolean>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=permission.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission.guard.d.ts","sourceRoot":"","sources":["../../src/guards/permission.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAIjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,6BAA6B,EAAE,MAAM,gDAAgD,CAAC;AAQ/F,qBACa,eAAgB,YAAW,WAAW;IAE/C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,aAAa;IACG,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAJvC,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,6BAA6B,EAChD,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,EACK,MAAM,EAAE,MAAM;IAGlE;;OAEG;YACW,oBAAoB;IA6B5B,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAsF/D"}
|