@nest-omni/core 4.1.3-2 → 4.1.3-20
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/audit/audit.module.d.ts +10 -0
- package/audit/audit.module.js +63 -1
- package/audit/controllers/audit.controller.d.ts +88 -0
- package/audit/controllers/audit.controller.js +74 -0
- package/audit/decorators/audit-action.decorator.d.ts +74 -0
- package/audit/decorators/audit-action.decorator.js +42 -0
- package/audit/decorators/audit-controller.decorator.d.ts +9 -1
- package/audit/decorators/audit-controller.decorator.js +11 -2
- package/audit/decorators/audit-operation.decorator.d.ts +45 -0
- package/audit/decorators/audit-operation.decorator.js +49 -0
- package/audit/decorators/entity-audit.decorator.d.ts +85 -1
- package/audit/decorators/entity-audit.decorator.js +153 -3
- package/audit/decorators/index.d.ts +2 -0
- package/audit/decorators/index.js +2 -0
- package/audit/dto/audit-log-query.dto.d.ts +3 -0
- package/audit/dto/audit-log-query.dto.js +3 -0
- package/audit/dto/begin-transaction.dto.d.ts +3 -0
- package/audit/dto/begin-transaction.dto.js +3 -0
- package/audit/dto/compare-entities.dto.d.ts +3 -0
- package/audit/dto/compare-entities.dto.js +3 -0
- package/audit/dto/pre-check-restore.dto.d.ts +3 -0
- package/audit/dto/pre-check-restore.dto.js +3 -0
- package/audit/dto/restore-entity.dto.d.ts +3 -0
- package/audit/dto/restore-entity.dto.js +3 -0
- package/audit/entities/audit-action-summary.entity.d.ts +23 -0
- package/audit/entities/audit-action-summary.entity.js +101 -0
- package/audit/entities/entity-audit-log.entity.d.ts +11 -0
- package/audit/entities/entity-audit-log.entity.js +57 -2
- package/audit/entities/entity-transaction.entity.d.ts +11 -2
- package/audit/entities/entity-transaction.entity.js +42 -3
- package/audit/entities/index.d.ts +3 -0
- package/audit/entities/index.js +3 -0
- package/audit/entities/manual-operation-log.entity.d.ts +4 -0
- package/audit/entities/manual-operation-log.entity.js +12 -1
- package/audit/entities/operation-template.entity.d.ts +4 -0
- package/audit/entities/operation-template.entity.js +4 -0
- package/audit/enums/audit.enums.d.ts +37 -6
- package/audit/enums/audit.enums.js +40 -7
- package/audit/index.d.ts +4 -1
- package/audit/index.js +34 -1
- package/audit/interceptors/audit-action.interceptor.d.ts +38 -0
- package/audit/interceptors/audit-action.interceptor.js +215 -0
- package/audit/interceptors/audit.interceptor.d.ts +15 -0
- package/audit/interceptors/audit.interceptor.js +23 -1
- package/audit/interceptors/index.d.ts +1 -0
- package/audit/interceptors/index.js +1 -0
- package/audit/interfaces/audit.interfaces.d.ts +187 -2
- package/audit/services/audit-action.service.d.ts +141 -0
- package/audit/services/audit-action.service.js +244 -0
- package/audit/services/audit-context.service.d.ts +97 -0
- package/audit/services/audit-context.service.js +185 -0
- package/audit/services/audit-strategy.service.d.ts +6 -0
- package/audit/services/audit-strategy.service.js +13 -0
- package/audit/services/entity-audit.service.d.ts +230 -3
- package/audit/services/entity-audit.service.js +607 -14
- package/audit/services/index.d.ts +3 -0
- package/audit/services/index.js +3 -0
- package/audit/services/manual-audit-log.service.d.ts +134 -9
- package/audit/services/manual-audit-log.service.js +157 -40
- package/audit/services/multi-database.service.d.ts +9 -2
- package/audit/services/multi-database.service.js +9 -21
- package/audit/services/operation-description.service.d.ts +71 -2
- package/audit/services/operation-description.service.js +231 -20
- package/audit/services/transaction-audit.service.d.ts +30 -0
- package/audit/services/transaction-audit.service.js +53 -5
- package/audit/subscribers/entity-audit.subscriber.d.ts +19 -0
- package/audit/subscribers/entity-audit.subscriber.js +76 -1
- package/cache/cache-metrics.service.d.ts +67 -0
- package/cache/cache-metrics.service.js +68 -4
- package/cache/cache-serialization.service.d.ts +31 -0
- package/cache/cache-serialization.service.js +25 -0
- package/cache/cache.constants.d.ts +9 -0
- package/cache/cache.constants.js +9 -0
- package/cache/cache.health.d.ts +26 -0
- package/cache/cache.health.js +30 -0
- package/cache/cache.module.d.ts +82 -2
- package/cache/cache.module.js +76 -5
- package/cache/cache.service.d.ts +140 -0
- package/cache/cache.service.js +169 -0
- package/cache/cache.warmup.service.d.ts +39 -0
- package/cache/cache.warmup.service.js +32 -0
- package/cache/decorators/cache-evict.decorator.d.ts +47 -0
- package/cache/decorators/cache-evict.decorator.js +56 -0
- package/cache/decorators/cache-put.decorator.d.ts +34 -0
- package/cache/decorators/cache-put.decorator.js +39 -0
- package/cache/decorators/cacheable.decorator.d.ts +40 -0
- package/cache/decorators/cacheable.decorator.js +55 -0
- package/cache/dependencies/callback.dependency.d.ts +33 -0
- package/cache/dependencies/callback.dependency.js +39 -1
- package/cache/dependencies/chain.dependency.d.ts +28 -0
- package/cache/dependencies/chain.dependency.js +34 -0
- package/cache/dependencies/db.dependency.d.ts +83 -7
- package/cache/dependencies/db.dependency.js +89 -14
- package/cache/dependencies/file.dependency.d.ts +32 -0
- package/cache/dependencies/file.dependency.js +34 -0
- package/cache/dependencies/tag.dependency.d.ts +75 -4
- package/cache/dependencies/tag.dependency.js +145 -11
- package/cache/dependencies/time.dependency.d.ts +43 -0
- package/cache/dependencies/time.dependency.js +43 -0
- package/cache/examples/basic-usage.d.ts +15 -0
- package/cache/examples/basic-usage.js +62 -8
- package/cache/index.js +9 -0
- package/cache/interfaces/cache-dependency.interface.d.ts +53 -0
- package/cache/interfaces/cache-options.interface.d.ts +89 -0
- package/cache/interfaces/cache-options.interface.js +6 -0
- package/cache/interfaces/cache-provider.interface.d.ts +78 -0
- package/cache/providers/base-cache.provider.d.ts +14 -0
- package/cache/providers/base-cache.provider.js +16 -0
- package/cache/providers/cls-cache.provider.d.ts +20 -0
- package/cache/providers/cls-cache.provider.js +28 -0
- package/cache/providers/memory-cache.provider.d.ts +43 -0
- package/cache/providers/memory-cache.provider.js +66 -0
- package/cache/providers/redis-cache.provider.d.ts +26 -0
- package/cache/providers/redis-cache.provider.js +29 -0
- package/cache/utils/dependency-manager.util.d.ts +52 -0
- package/cache/utils/dependency-manager.util.js +59 -0
- package/cache/utils/key-generator.util.d.ts +42 -0
- package/cache/utils/key-generator.util.js +53 -1
- package/common/abstract.entity.d.ts +14 -0
- package/common/abstract.entity.js +14 -0
- package/common/boilerplate.polyfill.d.ts +142 -0
- package/common/boilerplate.polyfill.js +18 -1
- package/common/dto/dto-container.d.ts +16 -0
- package/common/dto/dto-container.js +20 -0
- package/common/dto/dto-decorators.d.ts +18 -0
- package/common/dto/dto-decorators.js +14 -0
- package/common/dto/dto-extensions.d.ts +11 -0
- package/common/dto/dto-extensions.js +9 -0
- package/common/dto/dto-service-accessor.d.ts +17 -0
- package/common/dto/dto-service-accessor.js +18 -0
- package/common/dto/dto-transformer.d.ts +12 -0
- package/common/dto/dto-transformer.js +9 -0
- package/common/dto/index.js +2 -0
- package/common/examples/paginate-and-map.example.d.ts +6 -0
- package/common/examples/paginate-and-map.example.js +26 -0
- package/common/utils.d.ts +15 -0
- package/common/utils.js +15 -0
- package/constants/language-code.js +1 -0
- package/decorators/field.decorators.d.ts +1 -1
- package/decorators/field.decorators.js +8 -1
- package/decorators/property.decorators.js +1 -0
- package/decorators/public-route.decorator.js +1 -0
- package/decorators/transform.decorators.d.ts +27 -0
- package/decorators/transform.decorators.js +29 -0
- package/decorators/translate.decorator.js +1 -0
- package/decorators/user.decorator.js +1 -0
- package/decorators/validator.decorators.d.ts +8 -18
- package/decorators/validator.decorators.js +22 -190
- package/file-upload/controllers/file-access.controller.d.ts +23 -0
- package/file-upload/controllers/file-access.controller.js +128 -0
- package/file-upload/decorators/column.decorator.d.ts +151 -0
- package/file-upload/decorators/column.decorator.js +273 -0
- package/file-upload/decorators/csv-data.decorator.d.ts +30 -0
- package/file-upload/decorators/csv-data.decorator.js +85 -0
- package/file-upload/decorators/csv-import.decorator.d.ts +34 -0
- package/file-upload/decorators/csv-import.decorator.js +24 -0
- package/file-upload/decorators/examples/column-mapping.example.d.ts +76 -0
- package/file-upload/decorators/examples/column-mapping.example.js +122 -0
- package/file-upload/decorators/excel-data.decorator.d.ts +30 -0
- package/file-upload/decorators/excel-data.decorator.js +85 -0
- package/file-upload/decorators/file-upload.decorator.d.ts +83 -0
- package/file-upload/decorators/file-upload.decorator.js +172 -0
- package/file-upload/decorators/index.d.ts +5 -0
- package/file-upload/decorators/index.js +38 -0
- package/file-upload/decorators/process.decorator.d.ts +40 -0
- package/file-upload/decorators/process.decorator.js +52 -0
- package/file-upload/decorators/validate-data.decorator.d.ts +91 -0
- package/file-upload/decorators/validate-data.decorator.js +39 -0
- package/file-upload/dto/create-file.dto.d.ts +24 -0
- package/file-upload/dto/create-file.dto.js +112 -0
- package/file-upload/dto/find-files.dto.d.ts +15 -0
- package/file-upload/dto/find-files.dto.js +76 -0
- package/file-upload/dto/index.d.ts +4 -0
- package/file-upload/dto/index.js +20 -0
- package/file-upload/dto/pagination.dto.d.ts +7 -0
- package/file-upload/dto/pagination.dto.js +39 -0
- package/file-upload/dto/update-file.dto.d.ts +15 -0
- package/file-upload/dto/update-file.dto.js +67 -0
- package/file-upload/entities/file-metadata.entity.d.ts +25 -0
- package/file-upload/entities/file-metadata.entity.js +76 -0
- package/file-upload/entities/file.entity.d.ts +114 -0
- package/file-upload/entities/file.entity.js +350 -0
- package/file-upload/entities/index.d.ts +2 -0
- package/file-upload/entities/index.js +18 -0
- package/file-upload/enums/file-type.enum.d.ts +72 -0
- package/file-upload/enums/file-type.enum.js +212 -0
- package/file-upload/exceptions/file-upload.exception.d.ts +57 -0
- package/file-upload/exceptions/file-upload.exception.js +120 -0
- package/file-upload/exceptions/index.d.ts +1 -0
- package/file-upload/exceptions/index.js +17 -0
- package/file-upload/file-upload.module.d.ts +89 -0
- package/file-upload/file-upload.module.js +292 -0
- package/file-upload/index.d.ts +37 -0
- package/file-upload/index.js +77 -0
- package/file-upload/interceptors/file-upload.interceptor.d.ts +101 -0
- package/file-upload/interceptors/file-upload.interceptor.js +594 -0
- package/file-upload/interceptors/index.d.ts +1 -0
- package/file-upload/interceptors/index.js +17 -0
- package/file-upload/interfaces/custom-file-type.interface.d.ts +72 -0
- package/file-upload/interfaces/custom-file-type.interface.js +2 -0
- package/file-upload/interfaces/file-buffer.interface.d.ts +72 -0
- package/file-upload/interfaces/file-buffer.interface.js +2 -0
- package/file-upload/interfaces/file-entity.interface.d.ts +142 -0
- package/file-upload/interfaces/file-entity.interface.js +28 -0
- package/file-upload/interfaces/file-metadata.interface.d.ts +21 -0
- package/file-upload/interfaces/file-metadata.interface.js +2 -0
- package/file-upload/interfaces/file-processor.interface.d.ts +93 -0
- package/file-upload/interfaces/file-processor.interface.js +2 -0
- package/file-upload/interfaces/file-upload-options.interface.d.ts +74 -0
- package/file-upload/interfaces/file-upload-options.interface.js +5 -0
- package/file-upload/interfaces/index.d.ts +7 -0
- package/file-upload/interfaces/index.js +24 -0
- package/file-upload/interfaces/processor-options.interface.d.ts +102 -0
- package/file-upload/interfaces/processor-options.interface.js +2 -0
- package/file-upload/interfaces/storage-provider.interface.d.ts +239 -0
- package/file-upload/interfaces/storage-provider.interface.js +2 -0
- package/file-upload/interfaces/upload-options.interface.d.ts +19 -0
- package/file-upload/interfaces/upload-options.interface.js +2 -0
- package/file-upload/processors/csv.processor.d.ts +98 -0
- package/file-upload/processors/csv.processor.js +391 -0
- package/file-upload/processors/excel.processor.d.ts +130 -0
- package/file-upload/processors/excel.processor.js +547 -0
- package/file-upload/processors/image.processor.d.ts +199 -0
- package/file-upload/processors/image.processor.js +377 -0
- package/file-upload/providers/index.d.ts +2 -0
- package/file-upload/providers/index.js +18 -0
- package/file-upload/providers/local-storage.provider.d.ts +98 -0
- package/file-upload/providers/local-storage.provider.js +484 -0
- package/file-upload/providers/s3-storage.provider.d.ts +87 -0
- package/file-upload/providers/s3-storage.provider.js +455 -0
- package/file-upload/services/file-signature-validator.service.d.ts +118 -0
- package/file-upload/services/file-signature-validator.service.js +376 -0
- package/file-upload/services/file.service.d.ts +193 -0
- package/file-upload/services/file.service.js +638 -0
- package/file-upload/services/index.d.ts +4 -0
- package/file-upload/services/index.js +20 -0
- package/file-upload/services/malicious-file-detector.service.d.ts +300 -0
- package/file-upload/services/malicious-file-detector.service.js +1234 -0
- package/file-upload/services/mime-registry.service.d.ts +47 -0
- package/file-upload/services/mime-registry.service.js +167 -0
- package/file-upload/utils/checksum.util.d.ts +28 -0
- package/file-upload/utils/checksum.util.js +65 -0
- package/file-upload/utils/dynamic-import.util.d.ts +54 -0
- package/file-upload/utils/dynamic-import.util.js +156 -0
- package/file-upload/utils/filename.util.d.ts +59 -0
- package/file-upload/utils/filename.util.js +184 -0
- package/file-upload/utils/filepath.util.d.ts +70 -0
- package/file-upload/utils/filepath.util.js +152 -0
- package/file-upload/utils/index.d.ts +4 -0
- package/file-upload/utils/index.js +20 -0
- package/filters/constraint-errors.js +1 -0
- package/helpers/common.helper.d.ts +13 -0
- package/helpers/common.helper.js +13 -0
- package/http-client/config/http-client.config.d.ts +20 -0
- package/http-client/config/http-client.config.js +48 -21
- package/http-client/decorators/http-client.decorators.d.ts +55 -14
- package/http-client/decorators/http-client.decorators.js +154 -78
- package/http-client/entities/http-log.entity.d.ts +217 -8
- package/http-client/entities/http-log.entity.js +7 -22
- package/http-client/errors/http-client.errors.d.ts +57 -0
- package/http-client/errors/http-client.errors.js +58 -0
- package/http-client/examples/advanced-usage.example.d.ts +40 -0
- package/http-client/examples/advanced-usage.example.js +53 -61
- package/http-client/examples/auth-with-waiting-lock.example.d.ts +31 -0
- package/http-client/examples/auth-with-waiting-lock.example.js +52 -5
- package/http-client/examples/basic-usage.example.d.ts +60 -0
- package/http-client/examples/basic-usage.example.js +60 -0
- package/http-client/examples/multi-api-configuration.example.d.ts +60 -0
- package/http-client/examples/multi-api-configuration.example.js +76 -5
- package/http-client/examples/proxy-from-environment.example.d.ts +133 -0
- package/http-client/examples/proxy-from-environment.example.js +409 -0
- package/http-client/http-client.module.d.ts +48 -2
- package/http-client/http-client.module.js +147 -68
- package/http-client/index.d.ts +1 -1
- package/http-client/index.js +8 -0
- package/http-client/interfaces/api-client-config.interface.d.ts +80 -45
- package/http-client/interfaces/api-client-config.interface.js +3 -0
- package/http-client/interfaces/http-client-config.interface.d.ts +109 -52
- package/http-client/services/api-client-registry.service.d.ts +50 -11
- package/http-client/services/api-client-registry.service.js +90 -250
- package/http-client/services/circuit-breaker.service.d.ts +115 -2
- package/http-client/services/circuit-breaker.service.js +237 -7
- package/http-client/services/http-client.service.d.ts +124 -14
- package/http-client/services/http-client.service.js +437 -148
- package/http-client/services/http-log-query.service.d.ts +83 -0
- package/http-client/services/http-log-query.service.js +121 -13
- package/http-client/services/http-replay.service.d.ts +101 -0
- package/http-client/services/http-replay.service.js +86 -0
- package/http-client/services/index.d.ts +0 -1
- package/http-client/services/index.js +0 -1
- package/http-client/services/log-cleanup.service.d.ts +63 -0
- package/http-client/services/log-cleanup.service.js +54 -2
- package/http-client/services/logging.service.d.ts +116 -7
- package/http-client/services/logging.service.js +349 -86
- package/http-client/utils/call-stack-extractor.util.d.ts +63 -0
- package/http-client/utils/call-stack-extractor.util.js +83 -0
- package/http-client/utils/context-extractor.util.d.ts +49 -0
- package/http-client/utils/context-extractor.util.js +52 -0
- package/http-client/utils/curl-generator.util.d.ts +21 -0
- package/http-client/utils/curl-generator.util.js +44 -3
- package/http-client/utils/index.d.ts +1 -0
- package/http-client/utils/index.js +1 -0
- package/http-client/utils/proxy-environment.util.d.ts +42 -0
- package/http-client/utils/proxy-environment.util.js +148 -0
- package/http-client/utils/request-id.util.d.ts +18 -0
- package/http-client/utils/request-id.util.js +20 -0
- package/http-client/utils/retry-recorder.util.d.ts +42 -0
- package/http-client/utils/retry-recorder.util.js +44 -0
- package/http-client/utils/security-validator.util.d.ts +118 -0
- package/http-client/utils/security-validator.util.js +352 -0
- package/index.d.ts +3 -1
- package/index.js +12 -1
- package/interceptors/translation-interceptor.service.js +5 -0
- package/package.json +11 -7
- package/providers/context.provider.js +2 -0
- package/providers/generator.provider.d.ts +4 -0
- package/providers/generator.provider.js +4 -0
- package/redis-lock/comprehensive-lock-cleanup.service.d.ts +94 -0
- package/redis-lock/comprehensive-lock-cleanup.service.js +253 -0
- package/redis-lock/examples/lock-strategy.examples.d.ts +89 -0
- package/redis-lock/examples/lock-strategy.examples.js +130 -15
- package/redis-lock/index.d.ts +2 -0
- package/redis-lock/index.js +8 -1
- package/redis-lock/lock-heartbeat.service.d.ts +80 -0
- package/redis-lock/lock-heartbeat.service.js +232 -0
- package/redis-lock/redis-lock.decorator.d.ts +101 -0
- package/redis-lock/redis-lock.decorator.js +120 -0
- package/redis-lock/redis-lock.module.d.ts +66 -0
- package/redis-lock/redis-lock.module.js +175 -70
- package/redis-lock/redis-lock.service.d.ts +282 -0
- package/redis-lock/redis-lock.service.js +343 -20
- package/setup/bootstrap.setup.d.ts +1 -0
- package/setup/bootstrap.setup.js +21 -0
- package/setup/index.d.ts +1 -0
- package/setup/index.js +1 -0
- package/setup/mode.setup.d.ts +44 -0
- package/setup/mode.setup.js +44 -0
- package/setup/run-in-mode.decorator.d.ts +56 -0
- package/setup/run-in-mode.decorator.js +92 -0
- package/setup/schedule.decorator.d.ts +227 -0
- package/setup/schedule.decorator.js +240 -12
- package/setup/worker.decorator.d.ts +86 -0
- package/setup/worker.decorator.js +97 -0
- package/shared/index.d.ts +1 -1
- package/shared/index.js +1 -1
- package/shared/{serviceRegistryModule.js → service-registry.module.js} +19 -17
- package/shared/services/api-config.service.d.ts +3 -0
- package/shared/services/api-config.service.js +21 -9
- package/shared/services/index.d.ts +0 -1
- package/shared/services/index.js +0 -1
- package/validator-json/decorators.d.ts +17 -0
- package/validator-json/decorators.js +17 -2
- package/validator-json/default.d.ts +6 -0
- package/validator-json/default.js +30 -2
- package/validator-json/defaultConverters.js +1 -0
- package/validator-json/options.d.ts +23 -0
- package/validators/common-validators.d.ts +143 -0
- package/validators/common-validators.js +249 -0
- package/validators/custom-validate.examples.d.ts +23 -0
- package/validators/custom-validate.examples.js +78 -6
- package/validators/custom-validate.validator.d.ts +108 -0
- package/validators/custom-validate.validator.js +85 -0
- package/validators/file-mimetype.validator.d.ts +0 -2
- package/validators/file-mimetype.validator.js +4 -6
- package/validators/index.d.ts +1 -0
- package/validators/index.js +1 -0
- package/validators/is-exists.validator.d.ts +26 -6
- package/validators/is-exists.validator.js +30 -7
- package/validators/is-unique.validator.d.ts +33 -7
- package/validators/is-unique.validator.js +59 -17
- package/validators/skip-empty.validator.d.ts +5 -0
- package/validators/skip-empty.validator.js +5 -0
- package/vault/interfaces/vault-options.interface.d.ts +9 -0
- package/vault/vault-config.loader.d.ts +30 -0
- package/vault/vault-config.loader.js +48 -1
- package/vault/vault-config.service.d.ts +53 -0
- package/vault/vault-config.service.js +57 -0
- package/vault/vault.module.d.ts +4 -0
- package/vault/vault.module.js +4 -0
- package/decorators/examples/validation-decorators.example.d.ts +0 -69
- package/decorators/examples/validation-decorators.example.js +0 -331
- package/http-client/services/cache.service.d.ts +0 -24
- package/http-client/services/cache.service.js +0 -264
- package/shared/services/validator.service.d.ts +0 -3
- package/shared/services/validator.service.js +0 -20
- /package/shared/{serviceRegistryModule.d.ts → service-registry.module.d.ts} +0 -0
|
@@ -13,6 +13,9 @@ exports.EntityTransactionEntity = void 0;
|
|
|
13
13
|
const typeorm_1 = require("typeorm");
|
|
14
14
|
const abstract_entity_1 = require("../../common/abstract.entity");
|
|
15
15
|
const enums_1 = require("../enums");
|
|
16
|
+
/**
|
|
17
|
+
* 实体事务
|
|
18
|
+
*/
|
|
16
19
|
let EntityTransactionEntity = class EntityTransactionEntity extends abstract_entity_1.AbstractUuidPrimaryEntity {
|
|
17
20
|
};
|
|
18
21
|
exports.EntityTransactionEntity = EntityTransactionEntity;
|
|
@@ -21,7 +24,7 @@ __decorate([
|
|
|
21
24
|
__metadata("design:type", String)
|
|
22
25
|
], EntityTransactionEntity.prototype, "description", void 0);
|
|
23
26
|
__decorate([
|
|
24
|
-
(0, typeorm_1.Column)({ type: 'enum', enum: enums_1.
|
|
27
|
+
(0, typeorm_1.Column)({ type: 'enum', enum: enums_1.AuditTransactionStatus, comment: '事务状态' }),
|
|
25
28
|
__metadata("design:type", String)
|
|
26
29
|
], EntityTransactionEntity.prototype, "status", void 0);
|
|
27
30
|
__decorate([
|
|
@@ -43,9 +46,45 @@ __decorate([
|
|
|
43
46
|
(0, typeorm_1.Column)({ type: 'json', nullable: true, comment: '依赖图' }),
|
|
44
47
|
__metadata("design:type", Object)
|
|
45
48
|
], EntityTransactionEntity.prototype, "dependencyGraph", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, typeorm_1.Column)({ nullable: true, comment: '操作模板键(事务级别)' }),
|
|
51
|
+
__metadata("design:type", String)
|
|
52
|
+
], EntityTransactionEntity.prototype, "operationTemplateKey", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, typeorm_1.Column)({
|
|
55
|
+
type: 'json',
|
|
56
|
+
nullable: true,
|
|
57
|
+
comment: '描述参数,用于填充事务级别的模板占位符',
|
|
58
|
+
}),
|
|
59
|
+
__metadata("design:type", Object)
|
|
60
|
+
], EntityTransactionEntity.prototype, "descriptionParams", void 0);
|
|
61
|
+
__decorate([
|
|
62
|
+
(0, typeorm_1.Column)({ nullable: true, comment: '请求IP' }),
|
|
63
|
+
__metadata("design:type", String)
|
|
64
|
+
], EntityTransactionEntity.prototype, "requestIp", void 0);
|
|
65
|
+
__decorate([
|
|
66
|
+
(0, typeorm_1.Column)({ type: 'json', nullable: true, comment: '事务元数据' }),
|
|
67
|
+
__metadata("design:type", Object)
|
|
68
|
+
], EntityTransactionEntity.prototype, "metadata", void 0);
|
|
69
|
+
__decorate([
|
|
70
|
+
(0, typeorm_1.Column)({ type: 'timestamp', nullable: true, comment: '完成时间' }),
|
|
71
|
+
__metadata("design:type", Date)
|
|
72
|
+
], EntityTransactionEntity.prototype, "completedAt", void 0);
|
|
73
|
+
__decorate([
|
|
74
|
+
(0, typeorm_1.OneToMany)('ManualOperationLogEntity', 'transaction'),
|
|
75
|
+
__metadata("design:type", Array)
|
|
76
|
+
], EntityTransactionEntity.prototype, "manualOperations", void 0);
|
|
46
77
|
exports.EntityTransactionEntity = EntityTransactionEntity = __decorate([
|
|
47
|
-
(0, typeorm_1.Entity)('entity_transaction')
|
|
78
|
+
(0, typeorm_1.Entity)('entity_transaction')
|
|
79
|
+
// 单字段索引
|
|
80
|
+
,
|
|
48
81
|
(0, typeorm_1.Index)('idx_status', ['status']),
|
|
49
82
|
(0, typeorm_1.Index)('idx_user', ['userId']),
|
|
50
|
-
(0, typeorm_1.Index)('idx_created_at', ['createdAt'])
|
|
83
|
+
(0, typeorm_1.Index)('idx_created_at', ['createdAt']),
|
|
84
|
+
(0, typeorm_1.Index)('idx_template_key', ['operationTemplateKey'])
|
|
85
|
+
// 复合索引 - 优化常见查询
|
|
86
|
+
,
|
|
87
|
+
(0, typeorm_1.Index)('idx_user_status', ['userId', 'status']),
|
|
88
|
+
(0, typeorm_1.Index)('idx_user_time', ['userId', 'createdAt']),
|
|
89
|
+
(0, typeorm_1.Index)('idx_status_time', ['status', 'createdAt'])
|
|
51
90
|
], EntityTransactionEntity);
|
package/audit/entities/index.js
CHANGED
|
@@ -16,3 +16,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./entity-audit-log.entity"), exports);
|
|
18
18
|
__exportStar(require("./entity-transaction.entity"), exports);
|
|
19
|
+
__exportStar(require("./operation-template.entity"), exports);
|
|
20
|
+
__exportStar(require("./manual-operation-log.entity"), exports);
|
|
21
|
+
__exportStar(require("./audit-action-summary.entity"), exports);
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { AbstractUuidPrimaryEntity } from '../../common/abstract.entity';
|
|
2
2
|
import { EntityTransactionEntity } from './entity-transaction.entity';
|
|
3
3
|
import { RollbackAction } from '../interfaces';
|
|
4
|
+
/**
|
|
5
|
+
* 手动操作记录表
|
|
6
|
+
* 用于记录跨实体的复杂业务操作
|
|
7
|
+
*/
|
|
4
8
|
export declare class ManualOperationLogEntity extends AbstractUuidPrimaryEntity {
|
|
5
9
|
transactionId: string;
|
|
6
10
|
operationTemplateKey: string;
|
|
@@ -13,6 +13,10 @@ exports.ManualOperationLogEntity = void 0;
|
|
|
13
13
|
const typeorm_1 = require("typeorm");
|
|
14
14
|
const abstract_entity_1 = require("../../common/abstract.entity");
|
|
15
15
|
const entity_transaction_entity_1 = require("./entity-transaction.entity");
|
|
16
|
+
/**
|
|
17
|
+
* 手动操作记录表
|
|
18
|
+
* 用于记录跨实体的复杂业务操作
|
|
19
|
+
*/
|
|
16
20
|
let ManualOperationLogEntity = class ManualOperationLogEntity extends abstract_entity_1.AbstractUuidPrimaryEntity {
|
|
17
21
|
};
|
|
18
22
|
exports.ManualOperationLogEntity = ManualOperationLogEntity;
|
|
@@ -74,9 +78,16 @@ __decorate([
|
|
|
74
78
|
__metadata("design:type", entity_transaction_entity_1.EntityTransactionEntity)
|
|
75
79
|
], ManualOperationLogEntity.prototype, "transaction", void 0);
|
|
76
80
|
exports.ManualOperationLogEntity = ManualOperationLogEntity = __decorate([
|
|
77
|
-
(0, typeorm_1.Entity)('manual_operation_log')
|
|
81
|
+
(0, typeorm_1.Entity)('manual_operation_log')
|
|
82
|
+
// 单字段索引
|
|
83
|
+
,
|
|
78
84
|
(0, typeorm_1.Index)('idx_transaction', ['transactionId']),
|
|
79
85
|
(0, typeorm_1.Index)('idx_template_key', ['operationTemplateKey']),
|
|
80
86
|
(0, typeorm_1.Index)('idx_user', ['userId']),
|
|
81
87
|
(0, typeorm_1.Index)('idx_created_at', ['createdAt'])
|
|
88
|
+
// 复合索引 - 优化常见查询
|
|
89
|
+
,
|
|
90
|
+
(0, typeorm_1.Index)('idx_transaction_time', ['transactionId', 'createdAt']),
|
|
91
|
+
(0, typeorm_1.Index)('idx_user_time', ['userId', 'createdAt']),
|
|
92
|
+
(0, typeorm_1.Index)('idx_template_user', ['operationTemplateKey', 'userId'])
|
|
82
93
|
], ManualOperationLogEntity);
|
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import { AbstractUuidPrimaryEntity } from '../../common/abstract.entity';
|
|
2
2
|
import { AuditOperation } from '../enums';
|
|
3
|
+
/**
|
|
4
|
+
* 操作模板配置表
|
|
5
|
+
* 用于存储多语言操作描述模板
|
|
6
|
+
*/
|
|
3
7
|
export declare class OperationTemplateEntity extends AbstractUuidPrimaryEntity {
|
|
4
8
|
key: string;
|
|
5
9
|
entityName: string;
|
|
@@ -13,6 +13,10 @@ exports.OperationTemplateEntity = void 0;
|
|
|
13
13
|
const typeorm_1 = require("typeorm");
|
|
14
14
|
const abstract_entity_1 = require("../../common/abstract.entity");
|
|
15
15
|
const enums_1 = require("../enums");
|
|
16
|
+
/**
|
|
17
|
+
* 操作模板配置表
|
|
18
|
+
* 用于存储多语言操作描述模板
|
|
19
|
+
*/
|
|
16
20
|
let OperationTemplateEntity = class OperationTemplateEntity extends abstract_entity_1.AbstractUuidPrimaryEntity {
|
|
17
21
|
};
|
|
18
22
|
exports.OperationTemplateEntity = OperationTemplateEntity;
|
|
@@ -1,27 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 审计操作类型(兼容性别名,映射到 OperationType)
|
|
3
|
+
*/
|
|
1
4
|
export declare enum AuditOperation {
|
|
2
5
|
CREATE = "CREATE",
|
|
3
6
|
UPDATE = "UPDATE",
|
|
4
7
|
DELETE = "DELETE",
|
|
5
8
|
RESTORE = "RESTORE"
|
|
6
9
|
}
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
10
|
+
/**
|
|
11
|
+
* 事务状态(设计文档标准命名)
|
|
12
|
+
*/
|
|
13
|
+
export declare enum AuditTransactionStatus {
|
|
14
|
+
PENDING = "pending",
|
|
15
|
+
COMMITTED = "committed",
|
|
16
|
+
ROLLED_BACK = "rolled_back"
|
|
11
17
|
}
|
|
18
|
+
/**
|
|
19
|
+
* 恢复策略
|
|
20
|
+
*/
|
|
12
21
|
export declare enum RecoveryStrategy {
|
|
13
22
|
ENTITY_ONLY = "ENTITY_ONLY",
|
|
14
23
|
TRANSACTION_RESTORE = "TRANSACTION_RESTORE",
|
|
15
24
|
DEPENDENCY_GRAPH = "DEPENDENCY_GRAPH"
|
|
16
25
|
}
|
|
26
|
+
/**
|
|
27
|
+
* 记录策略
|
|
28
|
+
*/
|
|
17
29
|
export declare enum RecordStrategy {
|
|
18
|
-
FULL = "FULL"
|
|
19
|
-
DIFF_ONLY = "DIFF_ONLY"
|
|
30
|
+
FULL = "FULL",// 记录完整变更
|
|
31
|
+
DIFF_ONLY = "DIFF_ONLY",// 仅记录差异
|
|
20
32
|
DISABLED = "DISABLED"
|
|
21
33
|
}
|
|
34
|
+
/**
|
|
35
|
+
* 脱敏策略
|
|
36
|
+
*/
|
|
22
37
|
export declare enum MaskingStrategy {
|
|
23
38
|
NONE = "NONE",
|
|
24
39
|
HASH = "HASH",
|
|
25
40
|
MASK = "MASK",
|
|
26
41
|
PARTIAL = "PARTIAL"
|
|
27
42
|
}
|
|
43
|
+
/**
|
|
44
|
+
* 回滚操作类型(设计文档标准命名)
|
|
45
|
+
*/
|
|
46
|
+
export declare enum RollbackActionType {
|
|
47
|
+
ENTITY = "entity",// 实体回滚(删除/恢复)
|
|
48
|
+
FILE = "file",// 文件回滚(删除上传的文件)
|
|
49
|
+
CUSTOM = "custom"
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* 变更类型(设计文档标准命名)
|
|
53
|
+
*/
|
|
54
|
+
export declare enum ChangeType {
|
|
55
|
+
ADDED = "added",// 新增字段
|
|
56
|
+
REMOVED = "removed",// 删除字段
|
|
57
|
+
MODIFIED = "modified"
|
|
58
|
+
}
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MaskingStrategy = exports.RecordStrategy = exports.RecoveryStrategy = exports.
|
|
3
|
+
exports.ChangeType = exports.RollbackActionType = exports.MaskingStrategy = exports.RecordStrategy = exports.RecoveryStrategy = exports.AuditTransactionStatus = exports.AuditOperation = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* 审计操作类型(兼容性别名,映射到 OperationType)
|
|
6
|
+
*/
|
|
4
7
|
var AuditOperation;
|
|
5
8
|
(function (AuditOperation) {
|
|
6
9
|
AuditOperation["CREATE"] = "CREATE";
|
|
@@ -8,24 +11,36 @@ var AuditOperation;
|
|
|
8
11
|
AuditOperation["DELETE"] = "DELETE";
|
|
9
12
|
AuditOperation["RESTORE"] = "RESTORE";
|
|
10
13
|
})(AuditOperation || (exports.AuditOperation = AuditOperation = {}));
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
14
|
+
/**
|
|
15
|
+
* 事务状态(设计文档标准命名)
|
|
16
|
+
*/
|
|
17
|
+
var AuditTransactionStatus;
|
|
18
|
+
(function (AuditTransactionStatus) {
|
|
19
|
+
AuditTransactionStatus["PENDING"] = "pending";
|
|
20
|
+
AuditTransactionStatus["COMMITTED"] = "committed";
|
|
21
|
+
AuditTransactionStatus["ROLLED_BACK"] = "rolled_back";
|
|
22
|
+
})(AuditTransactionStatus || (exports.AuditTransactionStatus = AuditTransactionStatus = {}));
|
|
23
|
+
/**
|
|
24
|
+
* 恢复策略
|
|
25
|
+
*/
|
|
17
26
|
var RecoveryStrategy;
|
|
18
27
|
(function (RecoveryStrategy) {
|
|
19
28
|
RecoveryStrategy["ENTITY_ONLY"] = "ENTITY_ONLY";
|
|
20
29
|
RecoveryStrategy["TRANSACTION_RESTORE"] = "TRANSACTION_RESTORE";
|
|
21
30
|
RecoveryStrategy["DEPENDENCY_GRAPH"] = "DEPENDENCY_GRAPH";
|
|
22
31
|
})(RecoveryStrategy || (exports.RecoveryStrategy = RecoveryStrategy = {}));
|
|
32
|
+
/**
|
|
33
|
+
* 记录策略
|
|
34
|
+
*/
|
|
23
35
|
var RecordStrategy;
|
|
24
36
|
(function (RecordStrategy) {
|
|
25
37
|
RecordStrategy["FULL"] = "FULL";
|
|
26
38
|
RecordStrategy["DIFF_ONLY"] = "DIFF_ONLY";
|
|
27
39
|
RecordStrategy["DISABLED"] = "DISABLED";
|
|
28
40
|
})(RecordStrategy || (exports.RecordStrategy = RecordStrategy = {}));
|
|
41
|
+
/**
|
|
42
|
+
* 脱敏策略
|
|
43
|
+
*/
|
|
29
44
|
var MaskingStrategy;
|
|
30
45
|
(function (MaskingStrategy) {
|
|
31
46
|
MaskingStrategy["NONE"] = "NONE";
|
|
@@ -33,3 +48,21 @@ var MaskingStrategy;
|
|
|
33
48
|
MaskingStrategy["MASK"] = "MASK";
|
|
34
49
|
MaskingStrategy["PARTIAL"] = "PARTIAL";
|
|
35
50
|
})(MaskingStrategy || (exports.MaskingStrategy = MaskingStrategy = {}));
|
|
51
|
+
/**
|
|
52
|
+
* 回滚操作类型(设计文档标准命名)
|
|
53
|
+
*/
|
|
54
|
+
var RollbackActionType;
|
|
55
|
+
(function (RollbackActionType) {
|
|
56
|
+
RollbackActionType["ENTITY"] = "entity";
|
|
57
|
+
RollbackActionType["FILE"] = "file";
|
|
58
|
+
RollbackActionType["CUSTOM"] = "custom";
|
|
59
|
+
})(RollbackActionType || (exports.RollbackActionType = RollbackActionType = {}));
|
|
60
|
+
/**
|
|
61
|
+
* 变更类型(设计文档标准命名)
|
|
62
|
+
*/
|
|
63
|
+
var ChangeType;
|
|
64
|
+
(function (ChangeType) {
|
|
65
|
+
ChangeType["ADDED"] = "added";
|
|
66
|
+
ChangeType["REMOVED"] = "removed";
|
|
67
|
+
ChangeType["MODIFIED"] = "modified";
|
|
68
|
+
})(ChangeType || (exports.ChangeType = ChangeType = {}));
|
package/audit/index.d.ts
CHANGED
|
@@ -2,7 +2,10 @@ export * from './entities';
|
|
|
2
2
|
export * from './enums';
|
|
3
3
|
export * from './interfaces';
|
|
4
4
|
export * from './dto';
|
|
5
|
-
export
|
|
5
|
+
export { AuditEntity, AuditField, getEntityAuditConfig, getFieldAuditConfig, getFieldLabel, getFieldValueLabel, getEntityLabel, ENTITY_AUDIT_OPTIONS, FIELD_AUDIT_OPTIONS, } from './decorators/entity-audit.decorator';
|
|
6
|
+
export { AuditController, AuditMethod, CONTROLLER_AUDIT_OPTIONS, METHOD_AUDIT_OPTIONS, } from './decorators/audit-controller.decorator';
|
|
7
|
+
export { AuditLog, getAuditOperationConfig, hasAuditOperation, AUDIT_OPERATION_OPTIONS, } from './decorators/audit-operation.decorator';
|
|
8
|
+
export { AuditAction, AuditActionOptions, AuditActionMetadata, AUDIT_ACTION_METADATA, } from './decorators/audit-action.decorator';
|
|
6
9
|
export * from './services';
|
|
7
10
|
export * from './subscribers';
|
|
8
11
|
export * from './interceptors';
|
package/audit/index.js
CHANGED
|
@@ -14,13 +14,46 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.AUDIT_ACTION_METADATA = exports.AuditAction = exports.AUDIT_OPERATION_OPTIONS = exports.hasAuditOperation = exports.getAuditOperationConfig = exports.AuditLog = exports.METHOD_AUDIT_OPTIONS = exports.CONTROLLER_AUDIT_OPTIONS = exports.AuditMethod = exports.AuditController = exports.FIELD_AUDIT_OPTIONS = exports.ENTITY_AUDIT_OPTIONS = exports.getEntityLabel = exports.getFieldValueLabel = exports.getFieldLabel = exports.getFieldAuditConfig = exports.getEntityAuditConfig = exports.AuditField = exports.AuditEntity = void 0;
|
|
18
|
+
// Entities
|
|
17
19
|
__exportStar(require("./entities"), exports);
|
|
20
|
+
// Enums
|
|
18
21
|
__exportStar(require("./enums"), exports);
|
|
22
|
+
// Interfaces
|
|
19
23
|
__exportStar(require("./interfaces"), exports);
|
|
24
|
+
// DTO
|
|
20
25
|
__exportStar(require("./dto"), exports);
|
|
21
|
-
|
|
26
|
+
// Decorators - explicit exports
|
|
27
|
+
var entity_audit_decorator_1 = require("./decorators/entity-audit.decorator");
|
|
28
|
+
Object.defineProperty(exports, "AuditEntity", { enumerable: true, get: function () { return entity_audit_decorator_1.AuditEntity; } });
|
|
29
|
+
Object.defineProperty(exports, "AuditField", { enumerable: true, get: function () { return entity_audit_decorator_1.AuditField; } });
|
|
30
|
+
Object.defineProperty(exports, "getEntityAuditConfig", { enumerable: true, get: function () { return entity_audit_decorator_1.getEntityAuditConfig; } });
|
|
31
|
+
Object.defineProperty(exports, "getFieldAuditConfig", { enumerable: true, get: function () { return entity_audit_decorator_1.getFieldAuditConfig; } });
|
|
32
|
+
Object.defineProperty(exports, "getFieldLabel", { enumerable: true, get: function () { return entity_audit_decorator_1.getFieldLabel; } });
|
|
33
|
+
Object.defineProperty(exports, "getFieldValueLabel", { enumerable: true, get: function () { return entity_audit_decorator_1.getFieldValueLabel; } });
|
|
34
|
+
Object.defineProperty(exports, "getEntityLabel", { enumerable: true, get: function () { return entity_audit_decorator_1.getEntityLabel; } });
|
|
35
|
+
Object.defineProperty(exports, "ENTITY_AUDIT_OPTIONS", { enumerable: true, get: function () { return entity_audit_decorator_1.ENTITY_AUDIT_OPTIONS; } });
|
|
36
|
+
Object.defineProperty(exports, "FIELD_AUDIT_OPTIONS", { enumerable: true, get: function () { return entity_audit_decorator_1.FIELD_AUDIT_OPTIONS; } });
|
|
37
|
+
var audit_controller_decorator_1 = require("./decorators/audit-controller.decorator");
|
|
38
|
+
Object.defineProperty(exports, "AuditController", { enumerable: true, get: function () { return audit_controller_decorator_1.AuditController; } });
|
|
39
|
+
Object.defineProperty(exports, "AuditMethod", { enumerable: true, get: function () { return audit_controller_decorator_1.AuditMethod; } });
|
|
40
|
+
Object.defineProperty(exports, "CONTROLLER_AUDIT_OPTIONS", { enumerable: true, get: function () { return audit_controller_decorator_1.CONTROLLER_AUDIT_OPTIONS; } });
|
|
41
|
+
Object.defineProperty(exports, "METHOD_AUDIT_OPTIONS", { enumerable: true, get: function () { return audit_controller_decorator_1.METHOD_AUDIT_OPTIONS; } });
|
|
42
|
+
var audit_operation_decorator_1 = require("./decorators/audit-operation.decorator");
|
|
43
|
+
Object.defineProperty(exports, "AuditLog", { enumerable: true, get: function () { return audit_operation_decorator_1.AuditLog; } });
|
|
44
|
+
Object.defineProperty(exports, "getAuditOperationConfig", { enumerable: true, get: function () { return audit_operation_decorator_1.getAuditOperationConfig; } });
|
|
45
|
+
Object.defineProperty(exports, "hasAuditOperation", { enumerable: true, get: function () { return audit_operation_decorator_1.hasAuditOperation; } });
|
|
46
|
+
Object.defineProperty(exports, "AUDIT_OPERATION_OPTIONS", { enumerable: true, get: function () { return audit_operation_decorator_1.AUDIT_OPERATION_OPTIONS; } });
|
|
47
|
+
var audit_action_decorator_1 = require("./decorators/audit-action.decorator");
|
|
48
|
+
Object.defineProperty(exports, "AuditAction", { enumerable: true, get: function () { return audit_action_decorator_1.AuditAction; } });
|
|
49
|
+
Object.defineProperty(exports, "AUDIT_ACTION_METADATA", { enumerable: true, get: function () { return audit_action_decorator_1.AUDIT_ACTION_METADATA; } });
|
|
50
|
+
// Services
|
|
22
51
|
__exportStar(require("./services"), exports);
|
|
52
|
+
// Subscribers
|
|
23
53
|
__exportStar(require("./subscribers"), exports);
|
|
54
|
+
// Interceptors
|
|
24
55
|
__exportStar(require("./interceptors"), exports);
|
|
56
|
+
// Controllers
|
|
25
57
|
__exportStar(require("./controllers"), exports);
|
|
58
|
+
// Module
|
|
26
59
|
__exportStar(require("./audit.module"), exports);
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { Observable } from 'rxjs';
|
|
4
|
+
import { Repository } from 'typeorm';
|
|
5
|
+
import { AuditContextService } from '../services/audit-context.service';
|
|
6
|
+
import { OperationDescriptionService } from '../services/operation-description.service';
|
|
7
|
+
import { AuditActionSummaryEntity } from '../entities';
|
|
8
|
+
/**
|
|
9
|
+
* 审计动作拦截器
|
|
10
|
+
* 在请求开始时创建审计动作上下文,在请求结束时生成汇总记录
|
|
11
|
+
*/
|
|
12
|
+
export declare class AuditActionInterceptor implements NestInterceptor {
|
|
13
|
+
private readonly reflector;
|
|
14
|
+
private readonly contextService;
|
|
15
|
+
private readonly summaryRepository;
|
|
16
|
+
private readonly descriptionService?;
|
|
17
|
+
constructor(reflector: Reflector, contextService: AuditContextService, summaryRepository: Repository<AuditActionSummaryEntity>, descriptionService?: OperationDescriptionService);
|
|
18
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
19
|
+
/**
|
|
20
|
+
* 生成审计汇总记录
|
|
21
|
+
*/
|
|
22
|
+
private generateSummary;
|
|
23
|
+
/**
|
|
24
|
+
* 生成操作描述文本
|
|
25
|
+
* 优先从 OperationDescriptionService 获取多语言模板
|
|
26
|
+
* 如果没有,则使用默认格式
|
|
27
|
+
*/
|
|
28
|
+
private generateDescription;
|
|
29
|
+
/**
|
|
30
|
+
* 替换模板中的占位符
|
|
31
|
+
* 支持格式:{key} 或 {key:format}
|
|
32
|
+
*/
|
|
33
|
+
private replaceTemplatePlaceholders;
|
|
34
|
+
/**
|
|
35
|
+
* 格式化值为字符串
|
|
36
|
+
*/
|
|
37
|
+
private formatValue;
|
|
38
|
+
}
|
|
@@ -0,0 +1,215 @@
|
|
|
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 __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
15
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
16
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
17
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
18
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
19
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
20
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
+
exports.AuditActionInterceptor = void 0;
|
|
25
|
+
const common_1 = require("@nestjs/common");
|
|
26
|
+
const core_1 = require("@nestjs/core");
|
|
27
|
+
const rxjs_1 = require("rxjs");
|
|
28
|
+
const operators_1 = require("rxjs/operators");
|
|
29
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
30
|
+
const typeorm_2 = require("typeorm");
|
|
31
|
+
const audit_context_service_1 = require("../services/audit-context.service");
|
|
32
|
+
const operation_description_service_1 = require("../services/operation-description.service");
|
|
33
|
+
const entities_1 = require("../entities");
|
|
34
|
+
const audit_action_decorator_1 = require("../decorators/audit-action.decorator");
|
|
35
|
+
/**
|
|
36
|
+
* 审计动作拦截器
|
|
37
|
+
* 在请求开始时创建审计动作上下文,在请求结束时生成汇总记录
|
|
38
|
+
*/
|
|
39
|
+
let AuditActionInterceptor = class AuditActionInterceptor {
|
|
40
|
+
constructor(reflector, contextService, summaryRepository, descriptionService) {
|
|
41
|
+
this.reflector = reflector;
|
|
42
|
+
this.contextService = contextService;
|
|
43
|
+
this.summaryRepository = summaryRepository;
|
|
44
|
+
this.descriptionService = descriptionService;
|
|
45
|
+
}
|
|
46
|
+
intercept(context, next) {
|
|
47
|
+
// 获取装饰器元数据
|
|
48
|
+
const metadata = this.reflector.get(audit_action_decorator_1.AUDIT_ACTION_METADATA, context.getHandler());
|
|
49
|
+
// 如果没有 @AuditAction 装饰器或已禁用,直接放行
|
|
50
|
+
if (!metadata || metadata.options.enabled === false) {
|
|
51
|
+
return next.handle();
|
|
52
|
+
}
|
|
53
|
+
const request = context.switchToHttp().getRequest();
|
|
54
|
+
const actionId = this.contextService.generateActionId();
|
|
55
|
+
const startTime = new Date();
|
|
56
|
+
// 创建审计动作上下文
|
|
57
|
+
const actionContext = {
|
|
58
|
+
actionId,
|
|
59
|
+
actionName: metadata.actionName,
|
|
60
|
+
operationTemplateKey: metadata.options.templateKey,
|
|
61
|
+
paramsBuilder: metadata.options.paramsBuilder,
|
|
62
|
+
startTime,
|
|
63
|
+
entityChanges: [],
|
|
64
|
+
detailedChanges: [],
|
|
65
|
+
req: request,
|
|
66
|
+
};
|
|
67
|
+
// 设置到 CLS
|
|
68
|
+
this.contextService.setActionContext(actionContext);
|
|
69
|
+
return next.handle().pipe((0, operators_1.tap)((result) => __awaiter(this, void 0, void 0, function* () {
|
|
70
|
+
// 请求成功,记录结果
|
|
71
|
+
actionContext.result = result;
|
|
72
|
+
yield this.generateSummary(actionContext, metadata, false);
|
|
73
|
+
})), (0, operators_1.catchError)((error) => __awaiter(this, void 0, void 0, function* () {
|
|
74
|
+
// 请求失败,记录错误
|
|
75
|
+
actionContext.error = error;
|
|
76
|
+
yield this.generateSummary(actionContext, metadata, true, error);
|
|
77
|
+
return (0, rxjs_1.throwError)(() => error);
|
|
78
|
+
})));
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* 生成审计汇总记录
|
|
82
|
+
*/
|
|
83
|
+
generateSummary(actionContext, metadata, hasError, error) {
|
|
84
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
85
|
+
try {
|
|
86
|
+
const duration = Date.now() - actionContext.startTime.getTime();
|
|
87
|
+
const auditContext = yield this.contextService.getCurrentContext();
|
|
88
|
+
// 构建描述参数
|
|
89
|
+
let descriptionParams = {};
|
|
90
|
+
if (metadata.options.paramsBuilder) {
|
|
91
|
+
const paramsContext = this.contextService.buildParamsContext();
|
|
92
|
+
if (paramsContext) {
|
|
93
|
+
descriptionParams = metadata.options.paramsBuilder(paramsContext);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
// 生成描述文本
|
|
97
|
+
const description = yield this.generateDescription(actionContext.operationTemplateKey, actionContext.actionName, descriptionParams, !hasError);
|
|
98
|
+
// 统计实体类型和操作
|
|
99
|
+
const entityTypes = Array.from(new Set(actionContext.detailedChanges.map((c) => c.entityType)));
|
|
100
|
+
const operationStats = {};
|
|
101
|
+
actionContext.detailedChanges.forEach((change) => {
|
|
102
|
+
const op = change.operation;
|
|
103
|
+
operationStats[op] = (operationStats[op] || 0) + 1;
|
|
104
|
+
});
|
|
105
|
+
// 创建汇总记录
|
|
106
|
+
const summary = this.summaryRepository.create({
|
|
107
|
+
id: actionContext.actionId,
|
|
108
|
+
actionName: actionContext.actionName,
|
|
109
|
+
operationTemplateKey: actionContext.operationTemplateKey,
|
|
110
|
+
descriptionParams,
|
|
111
|
+
description,
|
|
112
|
+
requestId: auditContext.requestId || '',
|
|
113
|
+
userId: auditContext.userId || '',
|
|
114
|
+
username: auditContext.username || '',
|
|
115
|
+
requestIp: auditContext.requestIp || '',
|
|
116
|
+
userAgent: auditContext.userAgent || '',
|
|
117
|
+
entityChangesCount: actionContext.detailedChanges.length,
|
|
118
|
+
entityTypes,
|
|
119
|
+
operationStats,
|
|
120
|
+
success: !hasError,
|
|
121
|
+
errorMessage: error === null || error === void 0 ? void 0 : error.message,
|
|
122
|
+
duration,
|
|
123
|
+
metadata: metadata.options.metadata,
|
|
124
|
+
});
|
|
125
|
+
yield this.summaryRepository.save(summary);
|
|
126
|
+
}
|
|
127
|
+
catch (err) {
|
|
128
|
+
console.error('Failed to generate audit action summary:', err);
|
|
129
|
+
}
|
|
130
|
+
finally {
|
|
131
|
+
// 清除审计动作上下文
|
|
132
|
+
this.contextService.clearActionContext();
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* 生成操作描述文本
|
|
138
|
+
* 优先从 OperationDescriptionService 获取多语言模板
|
|
139
|
+
* 如果没有,则使用默认格式
|
|
140
|
+
*/
|
|
141
|
+
generateDescription(templateKey, actionName, params, success) {
|
|
142
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
143
|
+
let template;
|
|
144
|
+
// 1. 尝试从模板服务获取模板
|
|
145
|
+
if (templateKey && this.descriptionService) {
|
|
146
|
+
try {
|
|
147
|
+
template = yield this.descriptionService.getTemplate(templateKey);
|
|
148
|
+
}
|
|
149
|
+
catch (error) {
|
|
150
|
+
// 如果获取模板失败,继续使用默认逻辑
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// 2. 如果没有模板,使用默认格式
|
|
154
|
+
if (!template) {
|
|
155
|
+
template = success
|
|
156
|
+
? `执行操作: ${actionName}`
|
|
157
|
+
: `执行操作失败: ${actionName}`;
|
|
158
|
+
}
|
|
159
|
+
// 3. 执行模板替换
|
|
160
|
+
return this.replaceTemplatePlaceholders(template, params);
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* 替换模板中的占位符
|
|
165
|
+
* 支持格式:{key} 或 {key:format}
|
|
166
|
+
*/
|
|
167
|
+
replaceTemplatePlaceholders(template, params) {
|
|
168
|
+
let result = template;
|
|
169
|
+
// 遍历所有参数,替换占位符
|
|
170
|
+
Object.entries(params).forEach(([key, value]) => {
|
|
171
|
+
const placeholder = `{${key}}`;
|
|
172
|
+
const valueStr = this.formatValue(value);
|
|
173
|
+
// 替换所有匹配的占位符
|
|
174
|
+
const regex = new RegExp(placeholder.replace(/[{}]/g, '\\$&'), 'g');
|
|
175
|
+
result = result.replace(regex, valueStr);
|
|
176
|
+
});
|
|
177
|
+
// 清理未替换的占位符
|
|
178
|
+
result = result.replace(/\{[^}]+\}/g, '');
|
|
179
|
+
return result;
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* 格式化值为字符串
|
|
183
|
+
*/
|
|
184
|
+
formatValue(value) {
|
|
185
|
+
if (value === null || value === undefined) {
|
|
186
|
+
return '';
|
|
187
|
+
}
|
|
188
|
+
if (Array.isArray(value)) {
|
|
189
|
+
// 处理数组
|
|
190
|
+
if (value.length === 0) {
|
|
191
|
+
return '';
|
|
192
|
+
}
|
|
193
|
+
// 如果是对象数组,序列化
|
|
194
|
+
if (typeof value[0] === 'object') {
|
|
195
|
+
return JSON.stringify(value);
|
|
196
|
+
}
|
|
197
|
+
// 否则用顿号连接
|
|
198
|
+
return value.join('、');
|
|
199
|
+
}
|
|
200
|
+
if (typeof value === 'object') {
|
|
201
|
+
return JSON.stringify(value);
|
|
202
|
+
}
|
|
203
|
+
return String(value);
|
|
204
|
+
}
|
|
205
|
+
};
|
|
206
|
+
exports.AuditActionInterceptor = AuditActionInterceptor;
|
|
207
|
+
exports.AuditActionInterceptor = AuditActionInterceptor = __decorate([
|
|
208
|
+
(0, common_1.Injectable)(),
|
|
209
|
+
__param(2, (0, common_1.Inject)((0, typeorm_1.getRepositoryToken)(entities_1.AuditActionSummaryEntity))),
|
|
210
|
+
__param(3, (0, common_1.Optional)()),
|
|
211
|
+
__metadata("design:paramtypes", [core_1.Reflector,
|
|
212
|
+
audit_context_service_1.AuditContextService,
|
|
213
|
+
typeorm_2.Repository,
|
|
214
|
+
operation_description_service_1.OperationDescriptionService])
|
|
215
|
+
], AuditActionInterceptor);
|
|
@@ -1,12 +1,27 @@
|
|
|
1
1
|
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
2
|
import { Observable } from 'rxjs';
|
|
3
3
|
import { AuditContextService } from '../services/audit-context.service';
|
|
4
|
+
/**
|
|
5
|
+
* 审计拦截器
|
|
6
|
+
*/
|
|
4
7
|
export declare class AuditInterceptor implements NestInterceptor {
|
|
5
8
|
private readonly contextService;
|
|
6
9
|
constructor(contextService: AuditContextService);
|
|
7
10
|
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
11
|
+
/**
|
|
12
|
+
* 设置请求上下文
|
|
13
|
+
*/
|
|
8
14
|
private setRequestContext;
|
|
15
|
+
/**
|
|
16
|
+
* 处理错误
|
|
17
|
+
*/
|
|
9
18
|
private handleError;
|
|
19
|
+
/**
|
|
20
|
+
* 检查是否启用了审计
|
|
21
|
+
*/
|
|
10
22
|
private isAuditEnabled;
|
|
23
|
+
/**
|
|
24
|
+
* 生成请求ID
|
|
25
|
+
*/
|
|
11
26
|
private generateRequestId;
|
|
12
27
|
}
|