@nest-omni/core 4.1.3-11 → 4.1.3-13
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/LICENSE +17 -0
- package/README.md +444 -0
- package/build.sh +45 -0
- package/{audit → dist/audit}/audit.module.js +17 -0
- package/dist/audit/controllers/audit.controller.d.ts +108 -0
- package/{audit → dist/audit}/controllers/audit.controller.js +50 -0
- package/dist/audit/decorators/audit-action.decorator.d.ts +74 -0
- package/dist/audit/decorators/audit-action.decorator.js +42 -0
- package/{audit → dist/audit}/decorators/entity-audit.decorator.d.ts +10 -1
- package/{audit → dist/audit}/decorators/entity-audit.decorator.js +34 -16
- package/{audit → dist/audit}/decorators/index.d.ts +1 -0
- package/{audit → dist/audit}/decorators/index.js +1 -0
- package/dist/audit/entities/audit-action-summary.entity.d.ts +23 -0
- package/dist/audit/entities/audit-action-summary.entity.js +101 -0
- package/{audit → dist/audit}/entities/entity-audit-log.entity.d.ts +3 -0
- package/{audit → dist/audit}/entities/entity-audit-log.entity.js +25 -2
- package/{audit → dist/audit}/entities/entity-transaction.entity.d.ts +3 -4
- package/{audit → dist/audit}/entities/entity-transaction.entity.js +10 -3
- package/{audit → dist/audit}/entities/index.d.ts +1 -0
- package/{audit → dist/audit}/entities/index.js +1 -0
- package/{audit → dist/audit}/entities/manual-operation-log.entity.js +8 -1
- package/{audit → dist/audit}/enums/audit.enums.d.ts +1 -10
- package/{audit → dist/audit}/enums/audit.enums.js +7 -17
- package/{audit → dist/audit}/index.d.ts +2 -1
- package/{audit → dist/audit}/index.js +5 -1
- package/dist/audit/interceptors/audit-action.interceptor.d.ts +38 -0
- package/dist/audit/interceptors/audit-action.interceptor.js +215 -0
- package/dist/audit/interceptors/index.d.ts +2 -0
- package/{audit → dist/audit}/interceptors/index.js +1 -0
- package/{audit → dist/audit}/interfaces/audit.interfaces.d.ts +10 -5
- package/dist/audit/services/audit-action.service.d.ts +141 -0
- package/dist/audit/services/audit-action.service.js +244 -0
- package/dist/audit/services/audit-context.service.d.ts +107 -0
- package/dist/audit/services/audit-context.service.js +240 -0
- package/{audit → dist/audit}/services/entity-audit.service.d.ts +104 -3
- package/{audit → dist/audit}/services/entity-audit.service.js +306 -9
- package/{audit → dist/audit}/services/index.d.ts +1 -0
- package/{audit → dist/audit}/services/index.js +1 -0
- package/{audit → dist/audit}/services/manual-audit-log.service.d.ts +24 -23
- package/{audit → dist/audit}/services/manual-audit-log.service.js +32 -53
- package/{audit → dist/audit}/services/operation-description.service.d.ts +13 -3
- package/{audit → dist/audit}/services/operation-description.service.js +161 -24
- package/{audit → dist/audit}/services/transaction-audit.service.js +3 -3
- package/{audit → dist/audit}/subscribers/entity-audit.subscriber.d.ts +4 -0
- package/{audit → dist/audit}/subscribers/entity-audit.subscriber.js +47 -0
- package/dist/cache/dependencies/db.dependency.d.ts +109 -0
- package/{cache → dist/cache}/dependencies/db.dependency.js +64 -13
- package/{common → dist/common}/boilerplate.polyfill.js +1 -1
- package/dist/file-upload/controllers/file-access.controller.d.ts +23 -0
- package/dist/file-upload/controllers/file-access.controller.js +128 -0
- package/dist/file-upload/decorators/column.decorator.d.ts +151 -0
- package/dist/file-upload/decorators/column.decorator.js +273 -0
- package/dist/file-upload/decorators/csv-data.decorator.d.ts +30 -0
- package/dist/file-upload/decorators/csv-data.decorator.js +85 -0
- package/dist/file-upload/decorators/csv-import.decorator.d.ts +34 -0
- package/dist/file-upload/decorators/csv-import.decorator.js +24 -0
- package/dist/file-upload/decorators/examples/column-mapping.example.d.ts +76 -0
- package/dist/file-upload/decorators/examples/column-mapping.example.js +122 -0
- package/dist/file-upload/decorators/excel-data.decorator.d.ts +30 -0
- package/dist/file-upload/decorators/excel-data.decorator.js +85 -0
- package/dist/file-upload/decorators/file-upload.decorator.d.ts +83 -0
- package/dist/file-upload/decorators/file-upload.decorator.js +172 -0
- package/dist/file-upload/decorators/index.d.ts +5 -0
- package/dist/file-upload/decorators/index.js +38 -0
- package/dist/file-upload/decorators/process.decorator.d.ts +40 -0
- package/dist/file-upload/decorators/process.decorator.js +52 -0
- package/dist/file-upload/decorators/validate-data.decorator.d.ts +91 -0
- package/dist/file-upload/decorators/validate-data.decorator.js +39 -0
- package/dist/file-upload/dto/create-file.dto.d.ts +24 -0
- package/dist/file-upload/dto/create-file.dto.js +112 -0
- package/dist/file-upload/dto/find-files.dto.d.ts +15 -0
- package/dist/file-upload/dto/find-files.dto.js +76 -0
- package/dist/file-upload/dto/index.d.ts +4 -0
- package/dist/file-upload/dto/index.js +20 -0
- package/dist/file-upload/dto/pagination.dto.d.ts +7 -0
- package/dist/file-upload/dto/pagination.dto.js +39 -0
- package/dist/file-upload/dto/update-file.dto.d.ts +15 -0
- package/dist/file-upload/dto/update-file.dto.js +67 -0
- package/dist/file-upload/entities/file-metadata.entity.d.ts +25 -0
- package/dist/file-upload/entities/file-metadata.entity.js +76 -0
- package/dist/file-upload/entities/file.entity.d.ts +114 -0
- package/dist/file-upload/entities/file.entity.js +350 -0
- package/dist/file-upload/entities/index.d.ts +2 -0
- package/dist/file-upload/entities/index.js +18 -0
- package/dist/file-upload/enums/file-type.enum.d.ts +72 -0
- package/dist/file-upload/enums/file-type.enum.js +212 -0
- package/dist/file-upload/exceptions/file-upload.exception.d.ts +57 -0
- package/dist/file-upload/exceptions/file-upload.exception.js +120 -0
- package/dist/file-upload/exceptions/index.d.ts +1 -0
- package/dist/file-upload/exceptions/index.js +17 -0
- package/dist/file-upload/file-upload.module.d.ts +89 -0
- package/dist/file-upload/file-upload.module.js +292 -0
- package/dist/file-upload/index.d.ts +37 -0
- package/dist/file-upload/index.js +77 -0
- package/dist/file-upload/interceptors/file-upload.interceptor.d.ts +101 -0
- package/dist/file-upload/interceptors/file-upload.interceptor.js +594 -0
- package/dist/file-upload/interceptors/index.d.ts +1 -0
- package/dist/file-upload/interceptors/index.js +17 -0
- package/dist/file-upload/interfaces/custom-file-type.interface.d.ts +72 -0
- package/dist/file-upload/interfaces/file-buffer.interface.d.ts +72 -0
- package/dist/file-upload/interfaces/file-entity.interface.d.ts +142 -0
- package/dist/file-upload/interfaces/file-entity.interface.js +28 -0
- package/dist/file-upload/interfaces/file-metadata.interface.d.ts +21 -0
- package/dist/file-upload/interfaces/file-processor.interface.d.ts +93 -0
- package/dist/file-upload/interfaces/file-upload-options.interface.d.ts +74 -0
- package/dist/file-upload/interfaces/file-upload-options.interface.js +5 -0
- package/dist/file-upload/interfaces/index.d.ts +7 -0
- package/dist/file-upload/interfaces/index.js +24 -0
- package/dist/file-upload/interfaces/processor-options.interface.d.ts +102 -0
- package/dist/file-upload/interfaces/storage-provider.interface.d.ts +239 -0
- package/dist/file-upload/interfaces/upload-options.interface.d.ts +19 -0
- package/dist/file-upload/interfaces/upload-options.interface.js +2 -0
- package/dist/file-upload/processors/csv.processor.d.ts +98 -0
- package/dist/file-upload/processors/csv.processor.js +391 -0
- package/dist/file-upload/processors/excel.processor.d.ts +130 -0
- package/dist/file-upload/processors/excel.processor.js +547 -0
- package/dist/file-upload/processors/image.processor.d.ts +199 -0
- package/dist/file-upload/processors/image.processor.js +377 -0
- package/dist/file-upload/providers/index.d.ts +2 -0
- package/dist/file-upload/providers/index.js +18 -0
- package/dist/file-upload/providers/local-storage.provider.d.ts +98 -0
- package/dist/file-upload/providers/local-storage.provider.js +484 -0
- package/dist/file-upload/providers/s3-storage.provider.d.ts +87 -0
- package/dist/file-upload/providers/s3-storage.provider.js +455 -0
- package/dist/file-upload/services/file-signature-validator.service.d.ts +118 -0
- package/dist/file-upload/services/file-signature-validator.service.js +376 -0
- package/dist/file-upload/services/file.service.d.ts +193 -0
- package/dist/file-upload/services/file.service.js +638 -0
- package/dist/file-upload/services/index.d.ts +4 -0
- package/dist/file-upload/services/index.js +20 -0
- package/dist/file-upload/services/malicious-file-detector.service.d.ts +300 -0
- package/dist/file-upload/services/malicious-file-detector.service.js +1234 -0
- package/dist/file-upload/services/mime-registry.service.d.ts +47 -0
- package/dist/file-upload/services/mime-registry.service.js +167 -0
- package/dist/file-upload/utils/checksum.util.d.ts +28 -0
- package/dist/file-upload/utils/checksum.util.js +65 -0
- package/dist/file-upload/utils/dynamic-import.util.d.ts +54 -0
- package/dist/file-upload/utils/dynamic-import.util.js +156 -0
- package/dist/file-upload/utils/filename.util.d.ts +59 -0
- package/dist/file-upload/utils/filename.util.js +184 -0
- package/dist/file-upload/utils/filepath.util.d.ts +70 -0
- package/dist/file-upload/utils/filepath.util.js +152 -0
- package/dist/file-upload/utils/index.d.ts +4 -0
- package/dist/file-upload/utils/index.js +20 -0
- package/{http-client → dist/http-client}/decorators/http-client.decorators.d.ts +4 -2
- package/{http-client → dist/http-client}/decorators/http-client.decorators.js +2 -1
- package/{http-client → dist/http-client}/entities/http-log.entity.js +1 -9
- package/dist/http-client/examples/proxy-from-environment.example.d.ts +133 -0
- package/dist/http-client/examples/proxy-from-environment.example.js +410 -0
- package/{http-client → dist/http-client}/http-client.module.js +65 -6
- package/{http-client → dist/http-client}/interfaces/http-client-config.interface.d.ts +6 -0
- package/dist/http-client/interfaces/http-client-config.interface.js +2 -0
- package/{http-client → dist/http-client}/services/http-client.service.d.ts +8 -0
- package/{http-client → dist/http-client}/services/http-client.service.js +61 -17
- package/{http-client → dist/http-client}/services/logging.service.d.ts +1 -1
- package/{http-client → dist/http-client}/services/logging.service.js +74 -58
- package/{http-client → dist/http-client}/utils/index.d.ts +1 -0
- package/{http-client → dist/http-client}/utils/index.js +1 -0
- package/dist/http-client/utils/proxy-environment.util.d.ts +42 -0
- package/dist/http-client/utils/proxy-environment.util.js +148 -0
- package/{index.d.ts → dist/index.d.ts} +3 -1
- package/{index.js → dist/index.js} +4 -1
- package/dist/interfaces/IApiFile.js +2 -0
- package/dist/interfaces/IFile.js +2 -0
- package/dist/interfaces/ITranslationDecoratorInterface.js +2 -0
- package/dist/interfaces/response.js +2 -0
- package/dist/package.json +105 -0
- package/{setup → dist/setup}/bootstrap.setup.d.ts +1 -0
- package/{setup → dist/setup}/bootstrap.setup.js +1 -0
- package/dist/shared/index.d.ts +2 -0
- package/{shared → dist/shared}/index.js +1 -1
- package/{shared/serviceRegistryModule.js → dist/shared/service-registry.module.js} +18 -12
- package/{shared → dist/shared}/services/index.d.ts +0 -1
- package/{shared → dist/shared}/services/index.js +0 -1
- package/dist/transaction/__tests__/mocks.d.ts +9 -0
- package/dist/transaction/__tests__/mocks.js +33 -0
- package/dist/transaction/base-service-transaction.d.ts +99 -0
- package/dist/transaction/base-service-transaction.js +286 -0
- package/dist/transaction/cls-compatibility.service.d.ts +55 -0
- package/dist/transaction/cls-compatibility.service.js +127 -0
- package/dist/transaction/data-source-registry.d.ts +91 -0
- package/dist/transaction/data-source-registry.js +349 -0
- package/dist/transaction/data-source.util.d.ts +142 -0
- package/dist/transaction/data-source.util.js +330 -0
- package/dist/transaction/database-adapter.d.ts +44 -0
- package/dist/transaction/database-adapter.js +240 -0
- package/dist/transaction/decorators/entity-datasource.decorator.d.ts +62 -0
- package/dist/transaction/decorators/entity-datasource.decorator.js +105 -0
- package/dist/transaction/index.d.ts +15 -0
- package/dist/transaction/index.js +68 -0
- package/dist/transaction/logging-transactional.interceptor.d.ts +18 -0
- package/dist/transaction/logging-transactional.interceptor.js +163 -0
- package/dist/transaction/transaction-context.service.d.ts +137 -0
- package/dist/transaction/transaction-context.service.js +411 -0
- package/dist/transaction/transaction-manager.d.ts +230 -0
- package/dist/transaction/transaction-manager.js +1001 -0
- package/dist/transaction/transaction-synchronization.d.ts +171 -0
- package/dist/transaction/transaction-synchronization.js +380 -0
- package/dist/transaction/transaction.errors.d.ts +91 -0
- package/dist/transaction/transaction.errors.js +206 -0
- package/dist/transaction/transaction.module.d.ts +30 -0
- package/dist/transaction/transaction.module.js +98 -0
- package/dist/transaction/transactional.decorator.d.ts +82 -0
- package/dist/transaction/transactional.decorator.js +319 -0
- package/dist/transaction/typeorm-module-wrapper.d.ts +96 -0
- package/dist/transaction/typeorm-module-wrapper.js +197 -0
- package/{validators → dist/validators}/file-mimetype.validator.d.ts +0 -2
- package/{validators → dist/validators}/file-mimetype.validator.js +4 -6
- package/{validators → dist/validators}/is-exists.validator.d.ts +21 -7
- package/{validators → dist/validators}/is-exists.validator.js +30 -7
- package/{validators → dist/validators}/is-unique.validator.d.ts +14 -6
- package/{validators → dist/validators}/is-unique.validator.js +31 -11
- package/dist/vault/interfaces/vault-options.interface.js +2 -0
- package/package.json +10 -7
- package/tsconfig.build.json +16 -0
- package/audit/controllers/audit.controller.d.ts +0 -44
- package/audit/interceptors/index.d.ts +0 -1
- package/audit/services/audit-context.service.d.ts +0 -25
- package/audit/services/audit-context.service.js +0 -70
- package/cache/dependencies/db.dependency.d.ts +0 -60
- package/shared/index.d.ts +0 -2
- package/shared/services/validator.service.d.ts +0 -3
- package/shared/services/validator.service.js +0 -20
- /package/{.hygen → dist/.hygen}/new/crud/controller.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/create.dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/entity.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/get.dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/index-dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/index-response.dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/module.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/prompt.js +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/service.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/crud/update.dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/controller.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/create-command.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/create.dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/entity.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/get-query.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/module.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/not-found.exception.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/page-options.dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/prompt.js +0 -0
- /package/{.hygen → dist/.hygen}/new/module/repository.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/service.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/translation-dto.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/translation-entity.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/translation-repository.ejs.t +0 -0
- /package/{.hygen → dist/.hygen}/new/module/update.dto.ejs.t +0 -0
- /package/{.hygen.js → dist/.hygen.js} +0 -0
- /package/{audit → dist/audit}/audit.module.d.ts +0 -0
- /package/{audit → dist/audit}/controllers/index.d.ts +0 -0
- /package/{audit → dist/audit}/controllers/index.js +0 -0
- /package/{audit → dist/audit}/decorators/audit-controller.decorator.d.ts +0 -0
- /package/{audit → dist/audit}/decorators/audit-controller.decorator.js +0 -0
- /package/{audit → dist/audit}/decorators/audit-operation.decorator.d.ts +0 -0
- /package/{audit → dist/audit}/decorators/audit-operation.decorator.js +0 -0
- /package/{audit → dist/audit}/dto/audit-log-query.dto.d.ts +0 -0
- /package/{audit → dist/audit}/dto/audit-log-query.dto.js +0 -0
- /package/{audit → dist/audit}/dto/begin-transaction.dto.d.ts +0 -0
- /package/{audit → dist/audit}/dto/begin-transaction.dto.js +0 -0
- /package/{audit → dist/audit}/dto/compare-entities.dto.d.ts +0 -0
- /package/{audit → dist/audit}/dto/compare-entities.dto.js +0 -0
- /package/{audit → dist/audit}/dto/index.d.ts +0 -0
- /package/{audit → dist/audit}/dto/index.js +0 -0
- /package/{audit → dist/audit}/dto/pre-check-restore.dto.d.ts +0 -0
- /package/{audit → dist/audit}/dto/pre-check-restore.dto.js +0 -0
- /package/{audit → dist/audit}/dto/restore-entity.dto.d.ts +0 -0
- /package/{audit → dist/audit}/dto/restore-entity.dto.js +0 -0
- /package/{audit → dist/audit}/entities/manual-operation-log.entity.d.ts +0 -0
- /package/{audit → dist/audit}/entities/operation-template.entity.d.ts +0 -0
- /package/{audit → dist/audit}/entities/operation-template.entity.js +0 -0
- /package/{audit → dist/audit}/enums/index.d.ts +0 -0
- /package/{audit → dist/audit}/enums/index.js +0 -0
- /package/{audit → dist/audit}/interceptors/audit.interceptor.d.ts +0 -0
- /package/{audit → dist/audit}/interceptors/audit.interceptor.js +0 -0
- /package/{audit → dist/audit}/interfaces/audit.interfaces.js +0 -0
- /package/{audit → dist/audit}/interfaces/index.d.ts +0 -0
- /package/{audit → dist/audit}/interfaces/index.js +0 -0
- /package/{audit → dist/audit}/services/audit-strategy.service.d.ts +0 -0
- /package/{audit → dist/audit}/services/audit-strategy.service.js +0 -0
- /package/{audit → dist/audit}/services/multi-database.service.d.ts +0 -0
- /package/{audit → dist/audit}/services/multi-database.service.js +0 -0
- /package/{audit → dist/audit}/services/transaction-audit.service.d.ts +0 -0
- /package/{audit → dist/audit}/subscribers/index.d.ts +0 -0
- /package/{audit → dist/audit}/subscribers/index.js +0 -0
- /package/{cache → dist/cache}/cache-metrics.service.d.ts +0 -0
- /package/{cache → dist/cache}/cache-metrics.service.js +0 -0
- /package/{cache → dist/cache}/cache-serialization.service.d.ts +0 -0
- /package/{cache → dist/cache}/cache-serialization.service.js +0 -0
- /package/{cache → dist/cache}/cache.constants.d.ts +0 -0
- /package/{cache → dist/cache}/cache.constants.js +0 -0
- /package/{cache → dist/cache}/cache.health.d.ts +0 -0
- /package/{cache → dist/cache}/cache.health.js +0 -0
- /package/{cache → dist/cache}/cache.module.d.ts +0 -0
- /package/{cache → dist/cache}/cache.module.js +0 -0
- /package/{cache → dist/cache}/cache.service.d.ts +0 -0
- /package/{cache → dist/cache}/cache.service.js +0 -0
- /package/{cache → dist/cache}/cache.warmup.service.d.ts +0 -0
- /package/{cache → dist/cache}/cache.warmup.service.js +0 -0
- /package/{cache → dist/cache}/decorators/cache-evict.decorator.d.ts +0 -0
- /package/{cache → dist/cache}/decorators/cache-evict.decorator.js +0 -0
- /package/{cache → dist/cache}/decorators/cache-put.decorator.d.ts +0 -0
- /package/{cache → dist/cache}/decorators/cache-put.decorator.js +0 -0
- /package/{cache → dist/cache}/decorators/cacheable.decorator.d.ts +0 -0
- /package/{cache → dist/cache}/decorators/cacheable.decorator.js +0 -0
- /package/{cache → dist/cache}/decorators/index.d.ts +0 -0
- /package/{cache → dist/cache}/decorators/index.js +0 -0
- /package/{cache → dist/cache}/dependencies/callback.dependency.d.ts +0 -0
- /package/{cache → dist/cache}/dependencies/callback.dependency.js +0 -0
- /package/{cache → dist/cache}/dependencies/chain.dependency.d.ts +0 -0
- /package/{cache → dist/cache}/dependencies/chain.dependency.js +0 -0
- /package/{cache → dist/cache}/dependencies/file.dependency.d.ts +0 -0
- /package/{cache → dist/cache}/dependencies/file.dependency.js +0 -0
- /package/{cache → dist/cache}/dependencies/index.d.ts +0 -0
- /package/{cache → dist/cache}/dependencies/index.js +0 -0
- /package/{cache → dist/cache}/dependencies/tag.dependency.d.ts +0 -0
- /package/{cache → dist/cache}/dependencies/tag.dependency.js +0 -0
- /package/{cache → dist/cache}/dependencies/time.dependency.d.ts +0 -0
- /package/{cache → dist/cache}/dependencies/time.dependency.js +0 -0
- /package/{cache → dist/cache}/examples/basic-usage.d.ts +0 -0
- /package/{cache → dist/cache}/examples/basic-usage.js +0 -0
- /package/{cache → dist/cache}/index.d.ts +0 -0
- /package/{cache → dist/cache}/index.js +0 -0
- /package/{cache → dist/cache}/interfaces/cache-dependency.interface.d.ts +0 -0
- /package/{cache → dist/cache}/interfaces/cache-dependency.interface.js +0 -0
- /package/{cache → dist/cache}/interfaces/cache-options.interface.d.ts +0 -0
- /package/{cache → dist/cache}/interfaces/cache-options.interface.js +0 -0
- /package/{cache → dist/cache}/interfaces/cache-provider.interface.d.ts +0 -0
- /package/{cache → dist/cache}/interfaces/cache-provider.interface.js +0 -0
- /package/{cache → dist/cache}/interfaces/index.d.ts +0 -0
- /package/{cache → dist/cache}/interfaces/index.js +0 -0
- /package/{cache → dist/cache}/providers/base-cache.provider.d.ts +0 -0
- /package/{cache → dist/cache}/providers/base-cache.provider.js +0 -0
- /package/{cache → dist/cache}/providers/cls-cache.provider.d.ts +0 -0
- /package/{cache → dist/cache}/providers/cls-cache.provider.js +0 -0
- /package/{cache → dist/cache}/providers/index.d.ts +0 -0
- /package/{cache → dist/cache}/providers/index.js +0 -0
- /package/{cache → dist/cache}/providers/memory-cache.provider.d.ts +0 -0
- /package/{cache → dist/cache}/providers/memory-cache.provider.js +0 -0
- /package/{cache → dist/cache}/providers/redis-cache.provider.d.ts +0 -0
- /package/{cache → dist/cache}/providers/redis-cache.provider.js +0 -0
- /package/{cache → dist/cache}/utils/dependency-manager.util.d.ts +0 -0
- /package/{cache → dist/cache}/utils/dependency-manager.util.js +0 -0
- /package/{cache → dist/cache}/utils/index.d.ts +0 -0
- /package/{cache → dist/cache}/utils/index.js +0 -0
- /package/{cache → dist/cache}/utils/key-generator.util.d.ts +0 -0
- /package/{cache → dist/cache}/utils/key-generator.util.js +0 -0
- /package/{common → dist/common}/abstract.entity.d.ts +0 -0
- /package/{common → dist/common}/abstract.entity.js +0 -0
- /package/{common → dist/common}/boilerplate.polyfill.d.ts +0 -0
- /package/{common → dist/common}/dto/abstract.dto.d.ts +0 -0
- /package/{common → dist/common}/dto/abstract.dto.js +0 -0
- /package/{common → dist/common}/dto/bulk-id.dto.d.ts +0 -0
- /package/{common → dist/common}/dto/bulk-id.dto.js +0 -0
- /package/{common → dist/common}/dto/create-translation.dto.d.ts +0 -0
- /package/{common → dist/common}/dto/create-translation.dto.js +0 -0
- /package/{common → dist/common}/dto/dto-container.d.ts +0 -0
- /package/{common → dist/common}/dto/dto-container.js +0 -0
- /package/{common → dist/common}/dto/dto-decorators.d.ts +0 -0
- /package/{common → dist/common}/dto/dto-decorators.js +0 -0
- /package/{common → dist/common}/dto/dto-extensions.d.ts +0 -0
- /package/{common → dist/common}/dto/dto-extensions.js +0 -0
- /package/{common → dist/common}/dto/dto-service-accessor.d.ts +0 -0
- /package/{common → dist/common}/dto/dto-service-accessor.js +0 -0
- /package/{common → dist/common}/dto/dto-transformer.d.ts +0 -0
- /package/{common → dist/common}/dto/dto-transformer.js +0 -0
- /package/{common → dist/common}/dto/index.d.ts +0 -0
- /package/{common → dist/common}/dto/index.js +0 -0
- /package/{common → dist/common}/dto/page-meta.dto.d.ts +0 -0
- /package/{common → dist/common}/dto/page-meta.dto.js +0 -0
- /package/{common → dist/common}/dto/page-options.dto.d.ts +0 -0
- /package/{common → dist/common}/dto/page-options.dto.js +0 -0
- /package/{common → dist/common}/dto/page.dto.d.ts +0 -0
- /package/{common → dist/common}/dto/page.dto.js +0 -0
- /package/{common → dist/common}/examples/paginate-and-map.example.d.ts +0 -0
- /package/{common → dist/common}/examples/paginate-and-map.example.js +0 -0
- /package/{common → dist/common}/index.d.ts +0 -0
- /package/{common → dist/common}/index.js +0 -0
- /package/{common → dist/common}/snake-naming.strategy.d.ts +0 -0
- /package/{common → dist/common}/snake-naming.strategy.js +0 -0
- /package/{common → dist/common}/types.d.ts +0 -0
- /package/{common → dist/common}/types.js +0 -0
- /package/{common → dist/common}/utils.d.ts +0 -0
- /package/{common → dist/common}/utils.js +0 -0
- /package/{constants → dist/constants}/index.d.ts +0 -0
- /package/{constants → dist/constants}/index.js +0 -0
- /package/{constants → dist/constants}/language-code.d.ts +0 -0
- /package/{constants → dist/constants}/language-code.js +0 -0
- /package/{constants → dist/constants}/order.d.ts +0 -0
- /package/{constants → dist/constants}/order.js +0 -0
- /package/{decorators → dist/decorators}/api-page-ok-response.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/api-page-ok-response.decorator.js +0 -0
- /package/{decorators → dist/decorators}/api-paginated-response.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/api-paginated-response.decorator.js +0 -0
- /package/{decorators → dist/decorators}/auth-user.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/auth-user.decorator.js +0 -0
- /package/{decorators → dist/decorators}/controller.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/controller.decorator.js +0 -0
- /package/{decorators → dist/decorators}/field.decorators.d.ts +0 -0
- /package/{decorators → dist/decorators}/field.decorators.js +0 -0
- /package/{decorators → dist/decorators}/http.decorators.d.ts +0 -0
- /package/{decorators → dist/decorators}/http.decorators.js +0 -0
- /package/{decorators → dist/decorators}/index.d.ts +0 -0
- /package/{decorators → dist/decorators}/index.js +0 -0
- /package/{decorators → dist/decorators}/operation.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/operation.decorator.js +0 -0
- /package/{decorators → dist/decorators}/paginated-response.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/paginated-response.decorator.js +0 -0
- /package/{decorators → dist/decorators}/property.decorators.d.ts +0 -0
- /package/{decorators → dist/decorators}/property.decorators.js +0 -0
- /package/{decorators → dist/decorators}/public-route.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/public-route.decorator.js +0 -0
- /package/{decorators → dist/decorators}/swagger.schema.d.ts +0 -0
- /package/{decorators → dist/decorators}/swagger.schema.js +0 -0
- /package/{decorators → dist/decorators}/timestamp-column.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/timestamp-column.decorator.js +0 -0
- /package/{decorators → dist/decorators}/transform.decorators.d.ts +0 -0
- /package/{decorators → dist/decorators}/transform.decorators.js +0 -0
- /package/{decorators → dist/decorators}/translate.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/translate.decorator.js +0 -0
- /package/{decorators → dist/decorators}/use-dto.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/use-dto.decorator.js +0 -0
- /package/{decorators → dist/decorators}/user-check.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/user-check.decorator.js +0 -0
- /package/{decorators → dist/decorators}/user.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/user.decorator.js +0 -0
- /package/{decorators → dist/decorators}/user_auth.decorator.d.ts +0 -0
- /package/{decorators → dist/decorators}/user_auth.decorator.js +0 -0
- /package/{decorators → dist/decorators}/validator.decorators.d.ts +0 -0
- /package/{decorators → dist/decorators}/validator.decorators.js +0 -0
- /package/{exceptions → dist/exceptions}/file-not-image.exception.d.ts +0 -0
- /package/{exceptions → dist/exceptions}/file-not-image.exception.js +0 -0
- /package/{exceptions → dist/exceptions}/index.d.ts +0 -0
- /package/{exceptions → dist/exceptions}/index.js +0 -0
- /package/{exceptions → dist/exceptions}/page-type.exception.d.ts +0 -0
- /package/{exceptions → dist/exceptions}/page-type.exception.js +0 -0
- /package/{exceptions → dist/exceptions}/user-not-found.exception.d.ts +0 -0
- /package/{exceptions → dist/exceptions}/user-not-found.exception.js +0 -0
- /package/{http-client/interfaces/http-client-config.interface.js → dist/file-upload/interfaces/custom-file-type.interface.js} +0 -0
- /package/{interfaces/IApiFile.js → dist/file-upload/interfaces/file-buffer.interface.js} +0 -0
- /package/{interfaces/IFile.js → dist/file-upload/interfaces/file-metadata.interface.js} +0 -0
- /package/{interfaces/ITranslationDecoratorInterface.js → dist/file-upload/interfaces/file-processor.interface.js} +0 -0
- /package/{interfaces/response.js → dist/file-upload/interfaces/processor-options.interface.js} +0 -0
- /package/{vault/interfaces/vault-options.interface.js → dist/file-upload/interfaces/storage-provider.interface.js} +0 -0
- /package/{filters → dist/filters}/bad-request.filter.d.ts +0 -0
- /package/{filters → dist/filters}/bad-request.filter.js +0 -0
- /package/{filters → dist/filters}/constraint-errors.d.ts +0 -0
- /package/{filters → dist/filters}/constraint-errors.js +0 -0
- /package/{filters → dist/filters}/index.d.ts +0 -0
- /package/{filters → dist/filters}/index.js +0 -0
- /package/{filters → dist/filters}/query-failed.filter.d.ts +0 -0
- /package/{filters → dist/filters}/query-failed.filter.js +0 -0
- /package/{health-checker → dist/health-checker}/health-checker.controller.d.ts +0 -0
- /package/{health-checker → dist/health-checker}/health-checker.controller.js +0 -0
- /package/{health-checker → dist/health-checker}/health-checker.module.d.ts +0 -0
- /package/{health-checker → dist/health-checker}/health-checker.module.js +0 -0
- /package/{health-checker → dist/health-checker}/index.d.ts +0 -0
- /package/{health-checker → dist/health-checker}/index.js +0 -0
- /package/{helpers → dist/helpers}/common.helper.d.ts +0 -0
- /package/{helpers → dist/helpers}/common.helper.js +0 -0
- /package/{helpers → dist/helpers}/date.helper.d.ts +0 -0
- /package/{helpers → dist/helpers}/date.helper.js +0 -0
- /package/{helpers → dist/helpers}/index.d.ts +0 -0
- /package/{helpers → dist/helpers}/index.js +0 -0
- /package/{http-client → dist/http-client}/config/http-client.config.d.ts +0 -0
- /package/{http-client → dist/http-client}/config/http-client.config.js +0 -0
- /package/{http-client → dist/http-client}/config/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/config/index.js +0 -0
- /package/{http-client → dist/http-client}/decorators/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/decorators/index.js +0 -0
- /package/{http-client → dist/http-client}/entities/http-log.entity.d.ts +0 -0
- /package/{http-client → dist/http-client}/entities/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/entities/index.js +0 -0
- /package/{http-client → dist/http-client}/errors/http-client.errors.d.ts +0 -0
- /package/{http-client → dist/http-client}/errors/http-client.errors.js +0 -0
- /package/{http-client → dist/http-client}/errors/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/errors/index.js +0 -0
- /package/{http-client → dist/http-client}/examples/advanced-usage.example.d.ts +0 -0
- /package/{http-client → dist/http-client}/examples/advanced-usage.example.js +0 -0
- /package/{http-client → dist/http-client}/examples/auth-with-waiting-lock.example.d.ts +0 -0
- /package/{http-client → dist/http-client}/examples/auth-with-waiting-lock.example.js +0 -0
- /package/{http-client → dist/http-client}/examples/basic-usage.example.d.ts +0 -0
- /package/{http-client → dist/http-client}/examples/basic-usage.example.js +0 -0
- /package/{http-client → dist/http-client}/examples/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/examples/index.js +0 -0
- /package/{http-client → dist/http-client}/examples/multi-api-configuration.example.d.ts +0 -0
- /package/{http-client → dist/http-client}/examples/multi-api-configuration.example.js +0 -0
- /package/{http-client → dist/http-client}/http-client.module.d.ts +0 -0
- /package/{http-client → dist/http-client}/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/index.js +0 -0
- /package/{http-client → dist/http-client}/interfaces/api-client-config.interface.d.ts +0 -0
- /package/{http-client → dist/http-client}/interfaces/api-client-config.interface.js +0 -0
- /package/{http-client → dist/http-client}/services/api-client-registry.service.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/api-client-registry.service.js +0 -0
- /package/{http-client → dist/http-client}/services/cache.service.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/cache.service.js +0 -0
- /package/{http-client → dist/http-client}/services/circuit-breaker.service.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/circuit-breaker.service.js +0 -0
- /package/{http-client → dist/http-client}/services/http-log-query.service.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/http-log-query.service.js +0 -0
- /package/{http-client → dist/http-client}/services/http-replay.service.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/http-replay.service.js +0 -0
- /package/{http-client → dist/http-client}/services/index.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/index.js +0 -0
- /package/{http-client → dist/http-client}/services/log-cleanup.service.d.ts +0 -0
- /package/{http-client → dist/http-client}/services/log-cleanup.service.js +0 -0
- /package/{http-client → dist/http-client}/utils/call-stack-extractor.util.d.ts +0 -0
- /package/{http-client → dist/http-client}/utils/call-stack-extractor.util.js +0 -0
- /package/{http-client → dist/http-client}/utils/context-extractor.util.d.ts +0 -0
- /package/{http-client → dist/http-client}/utils/context-extractor.util.js +0 -0
- /package/{http-client → dist/http-client}/utils/curl-generator.util.d.ts +0 -0
- /package/{http-client → dist/http-client}/utils/curl-generator.util.js +0 -0
- /package/{http-client → dist/http-client}/utils/request-id.util.d.ts +0 -0
- /package/{http-client → dist/http-client}/utils/request-id.util.js +0 -0
- /package/{http-client → dist/http-client}/utils/retry-recorder.util.d.ts +0 -0
- /package/{http-client → dist/http-client}/utils/retry-recorder.util.js +0 -0
- /package/{i18n → dist/i18n}/en_US/validation.json +0 -0
- /package/{i18n → dist/i18n}/zh_CN/validation.json +0 -0
- /package/{interceptors → dist/interceptors}/index.d.ts +0 -0
- /package/{interceptors → dist/interceptors}/index.js +0 -0
- /package/{interceptors → dist/interceptors}/language-interceptor.service.d.ts +0 -0
- /package/{interceptors → dist/interceptors}/language-interceptor.service.js +0 -0
- /package/{interceptors → dist/interceptors}/translation-interceptor.service.d.ts +0 -0
- /package/{interceptors → dist/interceptors}/translation-interceptor.service.js +0 -0
- /package/{interfaces → dist/interfaces}/IApiFile.d.ts +0 -0
- /package/{interfaces → dist/interfaces}/IFile.d.ts +0 -0
- /package/{interfaces → dist/interfaces}/ITranslationDecoratorInterface.d.ts +0 -0
- /package/{interfaces → dist/interfaces}/index.d.ts +0 -0
- /package/{interfaces → dist/interfaces}/index.js +0 -0
- /package/{interfaces → dist/interfaces}/response.d.ts +0 -0
- /package/{middlewares → dist/middlewares}/index.d.ts +0 -0
- /package/{middlewares → dist/middlewares}/index.js +0 -0
- /package/{middlewares → dist/middlewares}/omni-auth.middleware.d.ts +0 -0
- /package/{middlewares → dist/middlewares}/omni-auth.middleware.js +0 -0
- /package/{middlewares → dist/middlewares}/powerby.middleware.d.ts +0 -0
- /package/{middlewares → dist/middlewares}/powerby.middleware.js +0 -0
- /package/{middlewares → dist/middlewares}/request-id.middleware.d.ts +0 -0
- /package/{middlewares → dist/middlewares}/request-id.middleware.js +0 -0
- /package/{middlewares → dist/middlewares}/xml.middleware.d.ts +0 -0
- /package/{middlewares → dist/middlewares}/xml.middleware.js +0 -0
- /package/{providers → dist/providers}/context.provider.d.ts +0 -0
- /package/{providers → dist/providers}/context.provider.js +0 -0
- /package/{providers → dist/providers}/generator.provider.d.ts +0 -0
- /package/{providers → dist/providers}/generator.provider.js +0 -0
- /package/{providers → dist/providers}/index.d.ts +0 -0
- /package/{providers → dist/providers}/index.js +0 -0
- /package/{redis-lock → dist/redis-lock}/comprehensive-lock-cleanup.service.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/comprehensive-lock-cleanup.service.js +0 -0
- /package/{redis-lock → dist/redis-lock}/examples/lock-strategy.examples.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/examples/lock-strategy.examples.js +0 -0
- /package/{redis-lock → dist/redis-lock}/index.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/index.js +0 -0
- /package/{redis-lock → dist/redis-lock}/lock-heartbeat.service.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/lock-heartbeat.service.js +0 -0
- /package/{redis-lock → dist/redis-lock}/redis-lock.decorator.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/redis-lock.decorator.js +0 -0
- /package/{redis-lock → dist/redis-lock}/redis-lock.module.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/redis-lock.module.js +0 -0
- /package/{redis-lock → dist/redis-lock}/redis-lock.service.d.ts +0 -0
- /package/{redis-lock → dist/redis-lock}/redis-lock.service.js +0 -0
- /package/{setup → dist/setup}/index.d.ts +0 -0
- /package/{setup → dist/setup}/index.js +0 -0
- /package/{setup → dist/setup}/mode.setup.d.ts +0 -0
- /package/{setup → dist/setup}/mode.setup.js +0 -0
- /package/{setup → dist/setup}/schedule.decorator.d.ts +0 -0
- /package/{setup → dist/setup}/schedule.decorator.js +0 -0
- /package/{setup → dist/setup}/worker.decorator.d.ts +0 -0
- /package/{setup → dist/setup}/worker.decorator.js +0 -0
- /package/{shared/serviceRegistryModule.d.ts → dist/shared/service-registry.module.d.ts} +0 -0
- /package/{shared → dist/shared}/services/api-config.service.d.ts +0 -0
- /package/{shared → dist/shared}/services/api-config.service.js +0 -0
- /package/{shared → dist/shared}/services/generator.service.d.ts +0 -0
- /package/{shared → dist/shared}/services/generator.service.js +0 -0
- /package/{shared → dist/shared}/services/translation.service.d.ts +0 -0
- /package/{shared → dist/shared}/services/translation.service.js +0 -0
- /package/{validator-json → dist/validator-json}/decorators.d.ts +0 -0
- /package/{validator-json → dist/validator-json}/decorators.js +0 -0
- /package/{validator-json → dist/validator-json}/default.d.ts +0 -0
- /package/{validator-json → dist/validator-json}/default.js +0 -0
- /package/{validator-json → dist/validator-json}/defaultConverters.d.ts +0 -0
- /package/{validator-json → dist/validator-json}/defaultConverters.js +0 -0
- /package/{validator-json → dist/validator-json}/index.d.ts +0 -0
- /package/{validator-json → dist/validator-json}/index.js +0 -0
- /package/{validator-json → dist/validator-json}/options.d.ts +0 -0
- /package/{validator-json → dist/validator-json}/options.js +0 -0
- /package/{validators → dist/validators}/common-validators.d.ts +0 -0
- /package/{validators → dist/validators}/common-validators.js +0 -0
- /package/{validators → dist/validators}/custom-validate.examples.d.ts +0 -0
- /package/{validators → dist/validators}/custom-validate.examples.js +0 -0
- /package/{validators → dist/validators}/custom-validate.validator.d.ts +0 -0
- /package/{validators → dist/validators}/custom-validate.validator.js +0 -0
- /package/{validators → dist/validators}/index.d.ts +0 -0
- /package/{validators → dist/validators}/index.js +0 -0
- /package/{validators → dist/validators}/phone-country-code.validator.d.ts +0 -0
- /package/{validators → dist/validators}/phone-country-code.validator.js +0 -0
- /package/{validators → dist/validators}/same-as.validator.d.ts +0 -0
- /package/{validators → dist/validators}/same-as.validator.js +0 -0
- /package/{validators → dist/validators}/skip-empty.validator.d.ts +0 -0
- /package/{validators → dist/validators}/skip-empty.validator.js +0 -0
- /package/{vault → dist/vault}/index.d.ts +0 -0
- /package/{vault → dist/vault}/index.js +0 -0
- /package/{vault → dist/vault}/interfaces/vault-options.interface.d.ts +0 -0
- /package/{vault → dist/vault}/vault-config.loader.d.ts +0 -0
- /package/{vault → dist/vault}/vault-config.loader.js +0 -0
- /package/{vault → dist/vault}/vault-config.service.d.ts +0 -0
- /package/{vault → dist/vault}/vault-config.service.js +0 -0
- /package/{vault → dist/vault}/vault.module.d.ts +0 -0
- /package/{vault → dist/vault}/vault.module.js +0 -0
|
@@ -26,6 +26,7 @@ const http_log_entity_1 = require("../entities/http-log.entity");
|
|
|
26
26
|
const request_id_util_1 = require("../utils/request-id.util");
|
|
27
27
|
const context_extractor_util_1 = require("../utils/context-extractor.util");
|
|
28
28
|
const call_stack_extractor_util_1 = require("../utils/call-stack-extractor.util");
|
|
29
|
+
const transaction_1 = require("../../transaction");
|
|
29
30
|
/**
|
|
30
31
|
* HTTP日志服务
|
|
31
32
|
* 基于Spring Boot的请求日志记录机制,集成现有的ContextProvider
|
|
@@ -74,71 +75,77 @@ let HttpLoggingService = HttpLoggingService_1 = class HttpLoggingService {
|
|
|
74
75
|
/**
|
|
75
76
|
* 记录请求成功响应
|
|
76
77
|
*/
|
|
77
|
-
logRequestSuccess(
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
userId: context.userId,
|
|
86
|
-
statusCode: response.status,
|
|
87
|
-
responseTime,
|
|
88
|
-
headers: logHeaders
|
|
89
|
-
? this.sanitizeHeaders(response.headers, sanitizeHeaders)
|
|
90
|
-
: undefined,
|
|
91
|
-
body: logBody ? this.sanitizeBody(response.data) : undefined,
|
|
92
|
-
responseSize: JSON.stringify(response.data).length,
|
|
93
|
-
cacheHit,
|
|
94
|
-
circuitBreakerState,
|
|
95
|
-
};
|
|
96
|
-
const logMessage = `HTTP Response [${requestId}]: ${response.status} (${responseTime}ms)${cacheHit ? ' [CACHE HIT]' : ''}`;
|
|
97
|
-
switch ((loggingOptions || {}).logLevel) {
|
|
98
|
-
case 'debug':
|
|
99
|
-
this.logger.debug(logMessage, logData);
|
|
100
|
-
break;
|
|
101
|
-
case 'info':
|
|
102
|
-
default:
|
|
103
|
-
this.logger.log(logMessage, logData);
|
|
104
|
-
break;
|
|
105
|
-
}
|
|
106
|
-
// 数据库日志记录
|
|
107
|
-
if (databaseLogging && this.logRepository) {
|
|
108
|
-
// 提取调用信息
|
|
109
|
-
const callInfo = this.extractCallInfo(decoratorContext, response.config);
|
|
110
|
-
this.saveToDatabase({
|
|
111
|
-
id: requestId,
|
|
78
|
+
logRequestSuccess(response_1, startTime_1, requestId_1, loggingOptions_1) {
|
|
79
|
+
return __awaiter(this, arguments, void 0, function* (response, startTime, requestId, loggingOptions, databaseLogging = false, retryRecords, cacheHit, circuitBreakerState, decoratorContext) {
|
|
80
|
+
var _a, _b;
|
|
81
|
+
const { logHeaders = true, logBody = true, sanitizeHeaders = [], } = loggingOptions || {};
|
|
82
|
+
const responseTime = Date.now() - startTime;
|
|
83
|
+
// 获取当前上下文信息
|
|
84
|
+
const context = context_extractor_util_1.ContextExtractor.getHttpContext();
|
|
85
|
+
const logData = {
|
|
112
86
|
requestId,
|
|
113
87
|
userId: context.userId,
|
|
114
|
-
method: ((_a = response.config.method) === null || _a === void 0 ? void 0 : _a.toUpperCase()) || 'UNKNOWN',
|
|
115
|
-
url: response.config.url || '',
|
|
116
|
-
headers: this.sanitizeHeaders(response.config.headers, sanitizeHeaders),
|
|
117
|
-
body: this.sanitizeBodyAsString(response.config.data),
|
|
118
|
-
params: response.config.params,
|
|
119
88
|
statusCode: response.status,
|
|
120
89
|
responseTime,
|
|
121
|
-
|
|
122
|
-
?
|
|
123
|
-
: 1,
|
|
124
|
-
success: true,
|
|
125
|
-
responseHeaders: this.sanitizeHeaders(response.headers, sanitizeHeaders),
|
|
126
|
-
responseBody: logBody
|
|
127
|
-
? this.sanitizeBodyAsString(response.data)
|
|
90
|
+
headers: logHeaders
|
|
91
|
+
? this.sanitizeHeaders(response.headers, sanitizeHeaders)
|
|
128
92
|
: undefined,
|
|
93
|
+
body: logBody ? this.sanitizeBody(response.data) : undefined,
|
|
129
94
|
responseSize: JSON.stringify(response.data).length,
|
|
130
|
-
requestSize: JSON.stringify(response.config.data).length,
|
|
131
|
-
serviceName: context.appId,
|
|
132
|
-
operationName: callInfo.operationName,
|
|
133
|
-
clientIp: context.clientIp,
|
|
134
|
-
source: (_b = context.metadata) === null || _b === void 0 ? void 0 : _b.source,
|
|
135
|
-
tags: context.tags,
|
|
136
|
-
metadata: logData,
|
|
137
|
-
retryRecords,
|
|
138
95
|
cacheHit,
|
|
139
96
|
circuitBreakerState,
|
|
140
|
-
}
|
|
141
|
-
|
|
97
|
+
};
|
|
98
|
+
const logMessage = `HTTP Response [${requestId}]: ${response.status} (${responseTime}ms)${cacheHit ? ' [CACHE HIT]' : ''}`;
|
|
99
|
+
switch ((loggingOptions || {}).logLevel) {
|
|
100
|
+
case 'debug':
|
|
101
|
+
this.logger.debug(logMessage, logData);
|
|
102
|
+
break;
|
|
103
|
+
``;
|
|
104
|
+
case 'info':
|
|
105
|
+
default:
|
|
106
|
+
this.logger.log(logMessage, logData);
|
|
107
|
+
break;
|
|
108
|
+
}
|
|
109
|
+
if (!this.logRepository) {
|
|
110
|
+
this.logRepository = transaction_1.TransactionContextService.getDataSource().getRepository(loggingOptions.databaseLogging.tableName);
|
|
111
|
+
}
|
|
112
|
+
// 数据库日志记录
|
|
113
|
+
if (databaseLogging && this.logRepository) {
|
|
114
|
+
// 提取调用信息
|
|
115
|
+
const callInfo = this.extractCallInfo(decoratorContext, response.config);
|
|
116
|
+
this.saveToDatabase({
|
|
117
|
+
id: requestId,
|
|
118
|
+
requestId,
|
|
119
|
+
userId: context.userId,
|
|
120
|
+
method: ((_a = response.config.method) === null || _a === void 0 ? void 0 : _a.toUpperCase()) || 'UNKNOWN',
|
|
121
|
+
url: response.config.url || '',
|
|
122
|
+
headers: this.sanitizeHeaders(response.config.headers, sanitizeHeaders),
|
|
123
|
+
body: this.sanitizeBodyAsString(response.config.data),
|
|
124
|
+
params: response.config.params,
|
|
125
|
+
statusCode: response.status,
|
|
126
|
+
responseTime,
|
|
127
|
+
attemptCount: (retryRecords === null || retryRecords === void 0 ? void 0 : retryRecords.length)
|
|
128
|
+
? Math.max(...retryRecords.map((r) => r.attempt))
|
|
129
|
+
: 1,
|
|
130
|
+
success: true,
|
|
131
|
+
responseHeaders: this.sanitizeHeaders(response.headers, sanitizeHeaders),
|
|
132
|
+
responseBody: logBody
|
|
133
|
+
? this.sanitizeBodyAsString(response.data)
|
|
134
|
+
: undefined,
|
|
135
|
+
responseSize: JSON.stringify(response.data).length,
|
|
136
|
+
requestSize: JSON.stringify(response.config.data).length,
|
|
137
|
+
serviceName: context.appId,
|
|
138
|
+
operationName: callInfo.operationName,
|
|
139
|
+
clientIp: context.clientIp,
|
|
140
|
+
source: (_b = context.metadata) === null || _b === void 0 ? void 0 : _b.source,
|
|
141
|
+
tags: context.tags,
|
|
142
|
+
metadata: logData,
|
|
143
|
+
retryRecords,
|
|
144
|
+
cacheHit,
|
|
145
|
+
circuitBreakerState,
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
});
|
|
142
149
|
}
|
|
143
150
|
/**
|
|
144
151
|
* 记录请求错误
|
|
@@ -389,13 +396,22 @@ let HttpLoggingService = HttpLoggingService_1 = class HttpLoggingService {
|
|
|
389
396
|
*/
|
|
390
397
|
saveToDatabase(logEntity) {
|
|
391
398
|
return __awaiter(this, void 0, void 0, function* () {
|
|
392
|
-
if (!this.logRepository)
|
|
399
|
+
if (!this.logRepository) {
|
|
400
|
+
this.logger.warn('Log repository not initialized, skipping database logging');
|
|
393
401
|
return;
|
|
402
|
+
}
|
|
394
403
|
try {
|
|
404
|
+
this.logger.debug('Saving HTTP log to database', {
|
|
405
|
+
requestId: logEntity.requestId,
|
|
406
|
+
});
|
|
395
407
|
yield this.logRepository.save(logEntity);
|
|
408
|
+
this.logger.debug('Successfully saved HTTP log to database', {
|
|
409
|
+
requestId: logEntity.requestId,
|
|
410
|
+
});
|
|
396
411
|
}
|
|
397
412
|
catch (error) {
|
|
398
413
|
this.logger.error('Failed to save HTTP log to database', error);
|
|
414
|
+
this.logger.error('Log entity details', logEntity);
|
|
399
415
|
}
|
|
400
416
|
});
|
|
401
417
|
}
|
|
@@ -18,3 +18,4 @@ __exportStar(require("./curl-generator.util"), exports);
|
|
|
18
18
|
__exportStar(require("./retry-recorder.util"), exports);
|
|
19
19
|
__exportStar(require("./context-extractor.util"), exports);
|
|
20
20
|
__exportStar(require("./call-stack-extractor.util"), exports);
|
|
21
|
+
__exportStar(require("./proxy-environment.util"), exports);
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { ProxyConfig } from '../interfaces/http-client-config.interface';
|
|
2
|
+
/**
|
|
3
|
+
* 代理环境变量解析工具
|
|
4
|
+
* 支持标准的代理环境变量:HTTP_PROXY, HTTPS_PROXY, NO_PROXY
|
|
5
|
+
*/
|
|
6
|
+
export declare class ProxyEnvironmentParser {
|
|
7
|
+
private static readonly logger;
|
|
8
|
+
/**
|
|
9
|
+
* 从环境变量解析代理配置
|
|
10
|
+
* @param protocol 请求协议 (http 或 https)
|
|
11
|
+
* @param targetUrl 目标 URL(用于检查 NO_PROXY)
|
|
12
|
+
* @returns 解析后的代理配置,如果不应使用代理则返回 false
|
|
13
|
+
*/
|
|
14
|
+
static parseFromEnvironment(protocol?: 'http' | 'https', targetUrl?: string): false | Required<Omit<ProxyConfig, 'enabled' | 'fromEnvironment'>>;
|
|
15
|
+
/**
|
|
16
|
+
* 解析代理 URL
|
|
17
|
+
* 支持格式: http://proxy:port, http://user:pass@proxy:port
|
|
18
|
+
*/
|
|
19
|
+
private static parseProxyUrl;
|
|
20
|
+
/**
|
|
21
|
+
* 检查是否应该绕过代理
|
|
22
|
+
* 基于 NO_PROXY 环境变量
|
|
23
|
+
*/
|
|
24
|
+
private static shouldBypassProxy;
|
|
25
|
+
/**
|
|
26
|
+
* 简单的 IP 地址匹配
|
|
27
|
+
* 支持精确匹配和 CIDR 表示法
|
|
28
|
+
*/
|
|
29
|
+
private static isIpMatch;
|
|
30
|
+
/**
|
|
31
|
+
* 获取所有代理相关的环境变量
|
|
32
|
+
*/
|
|
33
|
+
static getProxyEnvironmentVariables(): {
|
|
34
|
+
HTTP_PROXY?: string;
|
|
35
|
+
HTTPS_PROXY?: string;
|
|
36
|
+
NO_PROXY?: string;
|
|
37
|
+
};
|
|
38
|
+
/**
|
|
39
|
+
* 检查是否设置了代理环境变量
|
|
40
|
+
*/
|
|
41
|
+
static hasProxyEnvironment(): boolean;
|
|
42
|
+
}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProxyEnvironmentParser = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
/**
|
|
6
|
+
* 代理环境变量解析工具
|
|
7
|
+
* 支持标准的代理环境变量:HTTP_PROXY, HTTPS_PROXY, NO_PROXY
|
|
8
|
+
*/
|
|
9
|
+
class ProxyEnvironmentParser {
|
|
10
|
+
/**
|
|
11
|
+
* 从环境变量解析代理配置
|
|
12
|
+
* @param protocol 请求协议 (http 或 https)
|
|
13
|
+
* @param targetUrl 目标 URL(用于检查 NO_PROXY)
|
|
14
|
+
* @returns 解析后的代理配置,如果不应使用代理则返回 false
|
|
15
|
+
*/
|
|
16
|
+
static parseFromEnvironment(protocol = 'http', targetUrl) {
|
|
17
|
+
// 获取代理环境变量 (大写和小写都支持)
|
|
18
|
+
const proxyEnv = protocol === 'https'
|
|
19
|
+
? process.env.HTTPS_PROXY ||
|
|
20
|
+
process.env.https_proxy ||
|
|
21
|
+
process.env.HTTP_PROXY ||
|
|
22
|
+
process.env.http_proxy
|
|
23
|
+
: process.env.HTTP_PROXY || process.env.http_proxy;
|
|
24
|
+
// 检查是否应该跳过代理
|
|
25
|
+
if (targetUrl && this.shouldBypassProxy(targetUrl)) {
|
|
26
|
+
this.logger.debug(`Bypassing proxy for ${targetUrl} due to NO_PROXY`);
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
if (!proxyEnv) {
|
|
30
|
+
this.logger.debug('No proxy environment variable found');
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
const proxyConfig = this.parseProxyUrl(proxyEnv);
|
|
35
|
+
this.logger.debug(`Parsed proxy configuration from environment: ${JSON.stringify(proxyConfig)}`);
|
|
36
|
+
return proxyConfig;
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
this.logger.warn(`Failed to parse proxy URL from environment: ${error.message}`);
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* 解析代理 URL
|
|
45
|
+
* 支持格式: http://proxy:port, http://user:pass@proxy:port
|
|
46
|
+
*/
|
|
47
|
+
static parseProxyUrl(proxyUrl) {
|
|
48
|
+
try {
|
|
49
|
+
const url = new URL(proxyUrl);
|
|
50
|
+
const config = {
|
|
51
|
+
protocol: url.protocol.replace(':', '') || 'http',
|
|
52
|
+
host: url.hostname,
|
|
53
|
+
port: url.port ? parseInt(url.port, 10) : url.protocol === 'https:' ? 443 : 80,
|
|
54
|
+
auth: undefined,
|
|
55
|
+
};
|
|
56
|
+
// 解析认证信息
|
|
57
|
+
if (url.username || url.password) {
|
|
58
|
+
config.auth = {
|
|
59
|
+
username: decodeURIComponent(url.username),
|
|
60
|
+
password: decodeURIComponent(url.password),
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
return config;
|
|
64
|
+
}
|
|
65
|
+
catch (error) {
|
|
66
|
+
throw new Error(`Invalid proxy URL format: ${proxyUrl}`);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* 检查是否应该绕过代理
|
|
71
|
+
* 基于 NO_PROXY 环境变量
|
|
72
|
+
*/
|
|
73
|
+
static shouldBypassProxy(targetUrl) {
|
|
74
|
+
const noProxy = process.env.NO_PROXY || process.env.no_proxy;
|
|
75
|
+
if (!noProxy) {
|
|
76
|
+
return false;
|
|
77
|
+
}
|
|
78
|
+
try {
|
|
79
|
+
const url = new URL(targetUrl);
|
|
80
|
+
const hostname = url.hostname;
|
|
81
|
+
// NO_PROXY 可以是逗号分隔的列表
|
|
82
|
+
const bypassList = noProxy.split(',').map((item) => item.trim().toLowerCase());
|
|
83
|
+
for (const bypass of bypassList) {
|
|
84
|
+
if (!bypass)
|
|
85
|
+
continue;
|
|
86
|
+
// 精确匹配
|
|
87
|
+
if (hostname.toLowerCase() === bypass) {
|
|
88
|
+
return true;
|
|
89
|
+
}
|
|
90
|
+
// 通配符匹配 (例如 .example.com)
|
|
91
|
+
if (bypass.startsWith('.') && hostname.toLowerCase().endsWith(bypass)) {
|
|
92
|
+
return true;
|
|
93
|
+
}
|
|
94
|
+
// 后缀匹配 (例如 example.com 匹配 api.example.com)
|
|
95
|
+
if (hostname.toLowerCase().endsWith('.' + bypass)) {
|
|
96
|
+
return true;
|
|
97
|
+
}
|
|
98
|
+
// 特殊值 * 表示所有域名都绕过
|
|
99
|
+
if (bypass === '*') {
|
|
100
|
+
return true;
|
|
101
|
+
}
|
|
102
|
+
// IP 地址范围匹配 (简单实现)
|
|
103
|
+
if (this.isIpMatch(hostname, bypass)) {
|
|
104
|
+
return true;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
catch (error) {
|
|
109
|
+
this.logger.warn(`Failed to parse target URL for NO_PROXY check: ${error.message}`);
|
|
110
|
+
}
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* 简单的 IP 地址匹配
|
|
115
|
+
* 支持精确匹配和 CIDR 表示法
|
|
116
|
+
*/
|
|
117
|
+
static isIpMatch(hostname, pattern) {
|
|
118
|
+
// 精确 IP 匹配
|
|
119
|
+
if (hostname === pattern) {
|
|
120
|
+
return true;
|
|
121
|
+
}
|
|
122
|
+
// CIDR 匹配 (简化版本,不做完整的 CIDR 计算)
|
|
123
|
+
if (pattern.includes('/')) {
|
|
124
|
+
const [baseIp] = pattern.split('/');
|
|
125
|
+
return hostname.startsWith(baseIp.substring(0, baseIp.lastIndexOf('.')));
|
|
126
|
+
}
|
|
127
|
+
return false;
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* 获取所有代理相关的环境变量
|
|
131
|
+
*/
|
|
132
|
+
static getProxyEnvironmentVariables() {
|
|
133
|
+
return {
|
|
134
|
+
HTTP_PROXY: process.env.HTTP_PROXY || process.env.http_proxy,
|
|
135
|
+
HTTPS_PROXY: process.env.HTTPS_PROXY || process.env.https_proxy,
|
|
136
|
+
NO_PROXY: process.env.NO_PROXY || process.env.no_proxy,
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* 检查是否设置了代理环境变量
|
|
141
|
+
*/
|
|
142
|
+
static hasProxyEnvironment() {
|
|
143
|
+
const vars = this.getProxyEnvironmentVariables();
|
|
144
|
+
return !!(vars.HTTP_PROXY || vars.HTTPS_PROXY);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
exports.ProxyEnvironmentParser = ProxyEnvironmentParser;
|
|
148
|
+
ProxyEnvironmentParser.logger = new common_1.Logger(ProxyEnvironmentParser.name);
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export * from './common';
|
|
1
2
|
export * from './constants';
|
|
2
3
|
export * from './decorators';
|
|
3
4
|
export * from './exceptions';
|
|
@@ -7,10 +8,10 @@ export * from './interceptors';
|
|
|
7
8
|
export * from './shared';
|
|
8
9
|
export * from './middlewares';
|
|
9
10
|
export * from './validators';
|
|
10
|
-
export * from './common';
|
|
11
11
|
export * from './validator-json';
|
|
12
12
|
export * from './helpers';
|
|
13
13
|
export * from './providers';
|
|
14
|
+
export * from './transaction';
|
|
14
15
|
export * from './redis-lock';
|
|
15
16
|
export * from './cache';
|
|
16
17
|
export * from './http-client';
|
|
@@ -18,3 +19,4 @@ export * from './vault';
|
|
|
18
19
|
export * from './setup';
|
|
19
20
|
export * from './health-checker';
|
|
20
21
|
export * from './audit';
|
|
22
|
+
export * from './file-upload';
|
|
@@ -15,6 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
// Core modules
|
|
18
|
+
__exportStar(require("./common"), exports);
|
|
18
19
|
__exportStar(require("./constants"), exports);
|
|
19
20
|
__exportStar(require("./decorators"), exports);
|
|
20
21
|
__exportStar(require("./exceptions"), exports);
|
|
@@ -24,10 +25,10 @@ __exportStar(require("./interceptors"), exports);
|
|
|
24
25
|
__exportStar(require("./shared"), exports);
|
|
25
26
|
__exportStar(require("./middlewares"), exports);
|
|
26
27
|
__exportStar(require("./validators"), exports);
|
|
27
|
-
__exportStar(require("./common"), exports);
|
|
28
28
|
__exportStar(require("./validator-json"), exports);
|
|
29
29
|
__exportStar(require("./helpers"), exports);
|
|
30
30
|
__exportStar(require("./providers"), exports);
|
|
31
|
+
__exportStar(require("./transaction"), exports);
|
|
31
32
|
// Lock module
|
|
32
33
|
__exportStar(require("./redis-lock"), exports);
|
|
33
34
|
// Cache module
|
|
@@ -42,3 +43,5 @@ __exportStar(require("./setup"), exports);
|
|
|
42
43
|
__exportStar(require("./health-checker"), exports);
|
|
43
44
|
// Audit module
|
|
44
45
|
__exportStar(require("./audit"), exports);
|
|
46
|
+
// File upload module
|
|
47
|
+
__exportStar(require("./file-upload"), exports);
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@nest-omni/core",
|
|
3
|
+
"version": "4.1.3-13",
|
|
4
|
+
"description": "A comprehensive NestJS framework for building enterprise-grade applications with best practices",
|
|
5
|
+
"main": "index.js",
|
|
6
|
+
"types": "index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "tsc -p tsconfig.json",
|
|
9
|
+
"test": "jest --passWithNoTests",
|
|
10
|
+
"test:cache": "jest src/cache --verbose",
|
|
11
|
+
"test:cache:watch": "jest src/cache --watch",
|
|
12
|
+
"test:cache:coverage": "jest src/cache --coverage",
|
|
13
|
+
"lint": "eslint 'src/**/*.ts' --fix"
|
|
14
|
+
},
|
|
15
|
+
"bin": {
|
|
16
|
+
"nest-omni": "nest start",
|
|
17
|
+
"i18n": "i18n",
|
|
18
|
+
"gen": "gen"
|
|
19
|
+
},
|
|
20
|
+
"keywords": [
|
|
21
|
+
"nestjs",
|
|
22
|
+
"framework",
|
|
23
|
+
"typescript",
|
|
24
|
+
"decorators",
|
|
25
|
+
"validation",
|
|
26
|
+
"interceptors",
|
|
27
|
+
"filters",
|
|
28
|
+
"middleware",
|
|
29
|
+
"enterprise",
|
|
30
|
+
"omni",
|
|
31
|
+
"sentry",
|
|
32
|
+
"health-check",
|
|
33
|
+
"redis-lock",
|
|
34
|
+
"pm2"
|
|
35
|
+
],
|
|
36
|
+
"author": "Jinpy",
|
|
37
|
+
"license": "Apache-2.0",
|
|
38
|
+
"engines": {
|
|
39
|
+
"node": ">=22.0.0",
|
|
40
|
+
"npm": ">=9.0.0"
|
|
41
|
+
},
|
|
42
|
+
"devDependencies": {
|
|
43
|
+
"@types/compression": "^1.8.1",
|
|
44
|
+
"@types/express": "^5.0.4",
|
|
45
|
+
"@types/express-session": "^1.18.2",
|
|
46
|
+
"@types/lodash": "^4.17.20",
|
|
47
|
+
"@types/node": "^24.9.1",
|
|
48
|
+
"@types/sharp": "^0.31.1",
|
|
49
|
+
"@types/sprintf-js": "^1.1.4",
|
|
50
|
+
"@types/uuid": "^11.0.0",
|
|
51
|
+
"sqlite3": "^5.1.7",
|
|
52
|
+
"typescript": "^5.9.3"
|
|
53
|
+
},
|
|
54
|
+
"dependencies": {
|
|
55
|
+
"@dataui/crud": "^5.3.4",
|
|
56
|
+
"@dataui/crud-typeorm": "^5.3.4",
|
|
57
|
+
"@nestjs/bull": "^11.0.4",
|
|
58
|
+
"@nestjs/common": "^11.1.7",
|
|
59
|
+
"@nestjs/config": "^4.0.2",
|
|
60
|
+
"@nestjs/core": "^11.1.7",
|
|
61
|
+
"@nestjs/platform-express": "^11.1.7",
|
|
62
|
+
"@nestjs/schedule": "^6.0.1",
|
|
63
|
+
"@nestjs/swagger": "^11.2.1",
|
|
64
|
+
"@nestjs/terminus": "^11.0.0",
|
|
65
|
+
"@nestjs/typeorm": "^11.0.0",
|
|
66
|
+
"@sentry/nestjs": "^10.22.0",
|
|
67
|
+
"@sentry/profiling-node": "^10.22.0",
|
|
68
|
+
"@songkeys/nestjs-redis": "^11.0.0",
|
|
69
|
+
"@songkeys/nestjs-redis-health": "^11.0.0",
|
|
70
|
+
"axios": "^1.13.2",
|
|
71
|
+
"axios-retry": "^4.5.0",
|
|
72
|
+
"bcrypt": "^6.0.0",
|
|
73
|
+
"body-parser": "^2.2.0",
|
|
74
|
+
"bull": "^4.16.5",
|
|
75
|
+
"class-transformer": "^0.5.1",
|
|
76
|
+
"class-validator": "^0.14.2",
|
|
77
|
+
"compression": "^1.8.1",
|
|
78
|
+
"connect-redis": "^9.0.0",
|
|
79
|
+
"dotenv": "^17.2.3",
|
|
80
|
+
"express": "^5.1.0",
|
|
81
|
+
"express-session": "^1.18.2",
|
|
82
|
+
"hygen": "^6.2.11",
|
|
83
|
+
"ioredis": "^5.8.2",
|
|
84
|
+
"libphonenumber-js": "^1.12.25",
|
|
85
|
+
"lodash": "^4.17.21",
|
|
86
|
+
"mime-types": "^3.0.1",
|
|
87
|
+
"moment": "^2.30.1",
|
|
88
|
+
"mysql2": "^3.15.3",
|
|
89
|
+
"nestjs-cls": "^6.0.1",
|
|
90
|
+
"nestjs-i18n": "^10.5.1",
|
|
91
|
+
"nestjs-pino": "^4.4.1",
|
|
92
|
+
"node-vault": "^0.10.9",
|
|
93
|
+
"pino-http": "^11.0.0",
|
|
94
|
+
"pino-pretty": "^13.1.2",
|
|
95
|
+
"reflect-metadata": "^0.2.2",
|
|
96
|
+
"rxjs": "^7.8.2",
|
|
97
|
+
"source-map-support": "^0.5.21",
|
|
98
|
+
"sprintf-js": "^1.1.3",
|
|
99
|
+
"typeorm": "^0.3.27",
|
|
100
|
+
"uuid": "^13.0.0",
|
|
101
|
+
"fast-csv": "^5.0.5",
|
|
102
|
+
"xlsx": "git+https://git.sheetjs.com/sheetjs/sheetjs.git#v0.20.3"
|
|
103
|
+
},
|
|
104
|
+
"peerDependencies": {}
|
|
105
|
+
}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
+
import "../common/boilerplate.polyfill";
|
|
1
2
|
import type { NestExpressApplication } from '@nestjs/platform-express';
|
|
2
3
|
export declare function bootstrapSetup(AppModule: any, SetupSwagger: any): Promise<NestExpressApplication<import("http").Server<typeof import("http").IncomingMessage, typeof import("http").ServerResponse>>>;
|
|
@@ -10,6 +10,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.bootstrapSetup = bootstrapSetup;
|
|
13
|
+
require("../common/boilerplate.polyfill");
|
|
13
14
|
const Sentry = require("@sentry/nestjs");
|
|
14
15
|
const profiling_node_1 = require("@sentry/profiling-node");
|
|
15
16
|
const dotenv = require("dotenv");
|
|
@@ -14,5 +14,5 @@ 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
|
-
__exportStar(require("./
|
|
17
|
+
__exportStar(require("./service-registry.module"), exports);
|
|
18
18
|
__exportStar(require("./services"), exports);
|
|
@@ -27,8 +27,6 @@ const typeorm_1 = require("@nestjs/typeorm");
|
|
|
27
27
|
const schedule_1 = require("@nestjs/schedule");
|
|
28
28
|
const setup_1 = require("@sentry/nestjs/setup");
|
|
29
29
|
const cache_1 = require("../cache");
|
|
30
|
-
const transactional_1 = require("@nestjs-cls/transactional");
|
|
31
|
-
const transactional_adapter_typeorm_1 = require("@nestjs-cls/transactional-adapter-typeorm");
|
|
32
30
|
const nestjs_i18n_1 = require("nestjs-i18n");
|
|
33
31
|
const health_checker_1 = require("../health-checker");
|
|
34
32
|
const nestjs_redis_1 = require("@songkeys/nestjs-redis");
|
|
@@ -38,9 +36,9 @@ const redis_lock_1 = require("../redis-lock");
|
|
|
38
36
|
const typeorm_2 = require("typeorm");
|
|
39
37
|
const vault_1 = require("../vault");
|
|
40
38
|
const validators_1 = require("../validators");
|
|
39
|
+
const transaction_1 = require("../transaction");
|
|
41
40
|
const providers = [
|
|
42
41
|
services_1.ApiConfigService,
|
|
43
|
-
services_1.ValidatorService,
|
|
44
42
|
services_1.GeneratorService,
|
|
45
43
|
services_1.TranslationService,
|
|
46
44
|
validators_1.IsExistsValidator,
|
|
@@ -88,10 +86,27 @@ const modules = [
|
|
|
88
86
|
}),
|
|
89
87
|
];
|
|
90
88
|
if (services_1.ApiConfigService.toBoolean(process.env.DB_ENABLED, true)) {
|
|
89
|
+
// 1. 首先导入 TransactionModule
|
|
90
|
+
modules.push(transaction_1.TransactionModule.forRoot({
|
|
91
|
+
defaultDataSource: 'default',
|
|
92
|
+
enableDynamicRegistration: true,
|
|
93
|
+
}));
|
|
94
|
+
// 2. 导入 TypeORM 模块,并在初始化后注册数据源
|
|
91
95
|
modules.push(typeorm_1.TypeOrmModule.forRootAsync({
|
|
92
96
|
inject: [services_1.ApiConfigService],
|
|
93
97
|
useFactory: (config) => config.typeormConfig,
|
|
94
98
|
}));
|
|
99
|
+
// 3. 添加数据源注册服务,在应用启动时注册 DataSource
|
|
100
|
+
providers.push({
|
|
101
|
+
provide: 'DATASOURCE_REGISTRAR',
|
|
102
|
+
useFactory: (dataSource) => __awaiter(void 0, void 0, void 0, function* () {
|
|
103
|
+
// 手动注册 default 数据源到 DataSourceUtil
|
|
104
|
+
(0, transaction_1.addDataSource)('default', dataSource, true);
|
|
105
|
+
return dataSource;
|
|
106
|
+
}),
|
|
107
|
+
inject: [typeorm_2.DataSource],
|
|
108
|
+
});
|
|
109
|
+
// 4. 配置 CLS 模块
|
|
95
110
|
modules.push(nestjs_cls_1.ClsModule.forRootAsync({
|
|
96
111
|
imports: [typeorm_1.TypeOrmModule],
|
|
97
112
|
useFactory(args) {
|
|
@@ -100,15 +115,6 @@ if (services_1.ApiConfigService.toBoolean(process.env.DB_ENABLED, true)) {
|
|
|
100
115
|
};
|
|
101
116
|
},
|
|
102
117
|
global: true,
|
|
103
|
-
plugins: [
|
|
104
|
-
new transactional_1.ClsPluginTransactional({
|
|
105
|
-
imports: [typeorm_1.TypeOrmModule],
|
|
106
|
-
adapter: new transactional_adapter_typeorm_1.TransactionalAdapterTypeOrm({
|
|
107
|
-
dataSourceToken: (0, typeorm_1.getDataSourceToken)(),
|
|
108
|
-
}),
|
|
109
|
-
enableTransactionProxy: true,
|
|
110
|
-
}),
|
|
111
|
-
]
|
|
112
118
|
}));
|
|
113
119
|
}
|
|
114
120
|
if (services_1.ApiConfigService.toBoolean(process.env.BULL_ENABLED)) {
|
|
@@ -17,4 +17,3 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./api-config.service"), exports);
|
|
18
18
|
__exportStar(require("./generator.service"), exports);
|
|
19
19
|
__exportStar(require("./translation.service"), exports);
|
|
20
|
-
__exportStar(require("./validator.service"), exports);
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TransactionStatus } from '../transaction-manager';
|
|
2
|
+
/**
|
|
3
|
+
* 创建 Mock TransactionStatus
|
|
4
|
+
*/
|
|
5
|
+
export declare function createMockTransactionStatus(overrides?: Partial<TransactionStatus>): TransactionStatus;
|
|
6
|
+
/**
|
|
7
|
+
* 创建 Mock EntityManager
|
|
8
|
+
*/
|
|
9
|
+
export declare function createMockEntityManager(): any;
|